HEX
Server: Apache
System: Linux dev.epsylon.net 3.10.0-1160.144.1.el7.tuxcare.els2.x86_64 #1 SMP Sun Feb 15 11:22:42 UTC 2026 x86_64
User: nexper (1054)
PHP: 8.2.30
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/nexper/public_html/crm/modules/jjwg_Areas/jjwg_Areas.php
<?php

if (!defined('sugarEntry') || !sugarEntry)
    die('Not A Valid Entry Point');

require_once('modules/jjwg_Areas/jjwg_Areas_sugar.php');
require_once('modules/jjwg_Maps/jjwg_Maps.php');

class jjwg_Areas extends jjwg_Areas_sugar {

    /**
     * @var settings array
     */
    var $settings = array();
    /**
     * coords processed from coordinates string
     * @var array of strings ('lng,lat,elv')
     */
    var $coords = array();
    /**
     * polygon processed from coordinates strings
     * @var array of arrays (keys: lng, lat, elv)
     */
    var $polygon = null;
    /**
     * Point in Area/Polygon check on vertices
     * @var boolean
     */
    var $point_on_vertex = true;
    /**
     * @area Polygon Area 
     */
    var $area = 0;
    /**
     * Polygon Centroid (Area Balance Center)
     * @var array (keys: lng, lat, elv)
     */
    var $centroid = null;

    function jjwg_Areas($init=true) {

        parent::jjwg_Areas_sugar();
        // Admin Config Setting
        if($init) $this->configuration();
    }

    /**
     * Load Configuration Settings using Administration Module
     * See jjwg_Maps module for setting config
     * $GLOBALS['jjwg_config_defaults']
     * $GLOBALS['jjwg_config']
     */
    function configuration() {

        $this->jjwg_Maps = new jjwg_Maps();
        $this->settings = $GLOBALS['jjwg_config'];
    }

    /**
     * Retrieve object by id
     */
    function retrieve($id, $encode = true, $deleted = true) {
        
        parent::retrieve($id, $encode, $deleted);
        
        $this->polygon = $this->define_polygon();
        $this->area = $this->define_area();
        $this->centroid = $this->define_centroid();
        
        return $this;
    }

    /**
     * 
     * Define polygon coordinates
     */
    function define_polygon() {

        if (!empty($this->polygon)) return $this->polygon;
        
        if (preg_match('/[\n\r]/', $this->coordinates)) {
            $this->coords = preg_split("/[\n\r\s]+/", $this->coordinates, null, PREG_SPLIT_NO_EMPTY);
        } else {
            $this->coords = preg_split("/[\s]+/", $this->coordinates, null, PREG_SPLIT_NO_EMPTY);
        }
        if (count($this->coords) > 0) {
            foreach ($this->coords as $coord) {
                $p = preg_split("/[\s\(\)]*,[\s\(\)]*/", $coord, null, PREG_SPLIT_NO_EMPTY);
                if ($this->is_valid_lng($p[0]) && $this->is_valid_lat($p[1])) {
                    $this->polygon[] = array(
                        'lng' => $p[0],
                        'lat' => $p[1],
                        'elv' => $p[2],
                    );
                }
            }
        }
        if (count($this->polygon) > 0) {
            return $this->polygon;
        } else {
            return false;
        }
    }

    /**
     * 
     * Define Area Location based on Centroid
     * (Center of Gravity or Balance Point)
     * 
     */
    function define_area_loc() {

        $loc = array();
        $loc['name'] = $this->name;
        $loc['lng'] = $this->centroid['lng'];
        $loc['lat'] = $this->centroid['lat'];
        $loc = $this->define_loc($loc);

        return $loc;
    }

    /**
     * Define Centroid - Point
     * @return type 
     */
    function define_centroid() {
        
        if (!empty($this->centroid)) return $this->centroid;
        
        if (empty($this->polygon)) $this->polygon = $this->define_polygon();
        
        $n = count($this->polygon);
        $a = $this->define_area($this->polygon);
        if (empty($a)) return $this->centroid;
        $cx = 0.0;
        $cy = 0.0;

        for ($i = 0; $i < $n; $i++) {
            $cx += ($this->polygon[$i]['lng'] + $this->polygon[$i+1]['lng']) * ( ($this->polygon[$i]['lng'] * $this->polygon[$i+1]['lat']) - ($this->polygon[$i+1]['lng'] * $this->polygon[$i]['lat']) );
            $cy += ($this->polygon[$i]['lat'] + $this->polygon[$i+1]['lat']) * ( ($this->polygon[$i]['lng'] * $this->polygon[$i+1]['lat']) - ($this->polygon[$i+1]['lng'] * $this->polygon[$i]['lat']) );
        }
        $centroid_lng = (1/(6*$a))*$cx;
        $centroid_lat = (1/(6*$a))*$cy;
        
        if ($centroid_lng != 0 && $centroid_lat != 0) {
            $this->centroid = array(
                'lng' => $centroid_lng,
                'lat' => $centroid_lat,
                'elv' => 0
            );
        }

        return $this->centroid;
    }
    
    /**
     * Define Polygon Area
     * @return type 
     */
    function define_area() {
        
        if (!empty($this->area)) return $this->area;
        
        if (empty($this->polygon)) $this->polygon = $this->define_polygon();
        
        // Based on: http://forums.devnetwork.net/viewtopic.php?f=1&t=44074
        $n = count($this->polygon);
        $area = 0.0;
        for ($i = 0; $i < $n; $i++) {
            $j = ($i + 1);
            $area += $this->polygon[$i]['lng'] * $this->polygon[$j]['lat'];
            $area -= $this->polygon[$i]['lat'] * $this->polygon[$j]['lng'];
        }
        $area /= 2;
        $this->area = abs($area);
        
        return $this->area;
    }
    
    /**
     * 
     * Define Marker Location
     * @param $marker mixed (array or object)
     */
    function define_loc($marker = array()) {

        $loc = array();
        if (is_object($marker)) {
            $loc['name'] = $marker->name;
            $loc['lat'] = $marker->jjwg_maps_lat;
            $loc['lng'] = $marker->jjwg_maps_lng;
        } elseif (is_array($marker) && !empty($marker)) {
            $loc['name'] = $marker['name'];
            $loc['lat'] = $marker['lat'];
            $loc['lng'] = $marker['lng'];
        } else {
            $loc['name'] = '';
            $loc['lat'] = $this->centroid['lat'];
            $loc['lng'] = $this->centroid['lng'];
        }
        
        if (empty($loc['name'])) {
            $loc['name'] = 'N/A';
        }
        if (!$this->is_valid_lat($loc['lat'])) {
            $loc['lat'] = $this->settings['map_default_center_latitude'];
        }
        if (!$this->is_valid_lng($loc['lng'])) {
            $loc['lng'] = $this->settings['map_default_center_longitude'];
        }
        return $loc;
    }

    /**
     * 
     * Check for valid longitude
     * @param $lng float
     */
    function is_valid_lng($lng) {
        return (is_numeric($lng) && $lng >= -180 && $lng <= 180);
    }

    /**
     * 
     * Check for valid latitude
     * @param $lat float
     */
    function is_valid_lat($lat) {
        return (is_numeric($lat) && $lat >= -90 && $lat <= 90);
    }

    /**
     * Determine if Marker Object is in Area (Polygon)
     * @param object $marker
     */
    function is_marker_in_area($marker) {
        
        $loc = array();
        if (is_object($marker)) {
            $loc['lat'] = $marker->jjwg_maps_lat;
            $loc['lng'] = $marker->jjwg_maps_lng;
        } elseif (is_array($marker)) {
            $loc['lat'] = $marker['lat'];
            $loc['lng'] = $marker['lng'];
        }
        
        return $this->is_point_in_area($loc['lng'], $loc['lat']);
    }

    /**
     * Determine if lng/lat point is in Area Polygon
     * 
     * @param float $lng
     * @param float $lat
     */
    function is_point_in_area($lng, $lat) {
        
        // lng,lat,elv
        $point = $lng.','.$lat.',0.0';
        
        return $this->point_in_polygon($point);
    }
    
    /**
     * Determine if Point lies within Polygon
     * 
     * Polygon Algorithm: http://assemblysys.com/php-point-in-polygon-algorithm/
     * Modified by JJWDesign 07/16/2013
     *
     * @param string $point
     * @param boolean $point_on_vertex
     * @return boolean
     */
    function point_in_polygon($point, $point_on_vertex = true) {
        
        $this->point_on_vertex = $point_on_vertex;
        $polygon = preg_split('/[\s]+/', $this->coordinates);
        
        // Chek $polygon count
        if (!(count($polygon) > 1)) return false;
        // Add the first point to the end, in order to properly close the loop completely
        if ($polygon[count($polygon)-1] != $polygon[0]) $polygon[] = $polygon[0];
        
        // Transform string coordinates into arrays with x and y values
        $point = $this->point_string_to_coordinates($point);
        $vertices = array();
        foreach ($polygon as $vertex) {
            $vertices[] = $this->point_string_to_coordinates($vertex);
        }
        
        // Check if the point sits exactly on a vertex
        if ($this->point_on_vertex == true and $this->point_on_vertex($point, $vertices) == true) {
            return true;
        }
 
        // Check if the point is inside the polygon or on the boundary
        $intersections = 0;
        $vertices_count = count($vertices);
 
        for ($i=1; $i < $vertices_count; $i++) {
            $vertex1 = $vertices[$i-1];
            $vertex2 = $vertices[$i];
            if ($vertex1['y'] == $vertex2['y'] and $vertex1['y'] == $point['y'] and $point['x'] > min($vertex1['x'], $vertex2['x']) and $point['x'] < max($vertex1['x'], $vertex2['x'])) { // Check if point is on an horizontal polygon boundary
                return true;
            }
            if ($point['y'] > min($vertex1['y'], $vertex2['y']) and $point['y'] <= max($vertex1['y'], $vertex2['y']) and $point['x'] <= max($vertex1['x'], $vertex2['x']) and $vertex1['y'] != $vertex2['y']) {
                $xinters = ($point['y'] - $vertex1['y']) * ($vertex2['x'] - $vertex1['x']) / ($vertex2['y'] - $vertex1['y']) + $vertex1['x'];
                if ($xinters == $point['x']) { // Check if point is on the polygon boundary (other than horizontal)
                    return true;
                }
                if ($vertex1['x'] == $vertex2['x'] || $point['x'] <= $xinters) {
                    $intersections++;
                }
            }
        }
        // If the number of edges we passed through is odd, then it's in the polygon.
        if ($intersections % 2 != 0) {
            return true;
        } else {
            return false;
        }
    }
 
    function point_on_vertex($point, $vertices) {
        
        foreach($vertices as $vertex) {
            if ($point == $vertex) {
                return true;
            }
        }
    }

    function point_string_to_coordinates($pointString) {
        
        // Coordinate Results (lng,lat,elv)
        $coordinates = preg_split('/[,]+/', $pointString);
        return array("x" => $coordinates[0], "y" => $coordinates[1]);
    }
    

}