HEX
Server: Apache
System: Linux srv13.cpanelhost.cl 3.10.0-962.3.2.lve1.5.38.el7.x86_64 #1 SMP Thu Jun 18 05:28:41 EDT 2020 x86_64
User: cca63905 (4205)
PHP: 7.3.20
Disabled: NONE
Upload Files
File: /home4/cca63905/public_html/guiaweb/htdocs/core/class/dolgeophp.class.php
<?php
/* Copyright (C) 2024 Laurent Destailleur  <eldy@users.sourceforge.net>
 * Copyright (C) 2024       Frédéric France             <frederic.france@free.fr>
 * Copyright (C) 2024		MDW							<mdeweerd@users.noreply.github.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see <https://www.gnu.org/licenses/>.
 * or see https://www.gnu.org/
 */

/**
 *       \file       htdocs/core/class/dolgeophp.class.php
 *       \brief      Absctraction class to manage a WYSIWYG editor
 */

require_once DOL_DOCUMENT_ROOT.'/includes/geoPHP/geoPHP.inc.php';


/**
 *      Class to manage Geo processing
 *		Usage: $dolgeophp=new DolGeoPHP($db);
 */
class DolGeoPHP
{
	/**
	 * @var DoliDB	$db		Database handler
	 */
	public $db;

	/**
	 *  Create an object to build an HTML area to edit a large string content
	 *
	 *  @param	DoliDB	$db		Database handler
	 */
	public function __construct($db)
	{
		$this->db = $db;
	}

	/**
	 * Return data from a value
	 *
	 * @param	string	$value		Value
	 * @return	array{}|array{geojson:string,centroid:Geometry,centroidjson:string}	Centroid
	 */
	public function parseGeoString($value)
	{
		$geom = geoPHP::load($value, 'wkt');
		if ($geom) {
			'@phan-var-force Geometry $geom';
			$geojson = $geom->out('json');
			$centroid = $geom->getCentroid();
			'@phan-var-force Geometry $centroid';
			$centroidjson = $centroid->out('json');

			return array('geojson' => $geojson, 'centroid' => $centroid, 'centroidjson' => $centroidjson);
		} else {
			return array();
		}
	}

	/**
	 * Return a string with x and y
	 *
	 * @param	mixed	$value		Value
	 * @return	string				X space Y
	 */
	public function getXYString($value)
	{
		$value = '';

		$geom = geoPHP::load($value, 'wkt');
		if ($geom) {
			'@phan-var-force Geometry $geom';
			$value = $geom->x().' '.$geom->y();
		}
		return $value;
	}

	/**
	 * Return a string with x and y
	 *
	 * @param	mixed	$value		Value
	 * @return	string				Class : num points
	 */
	public function getPointString($value)
	{
		$value = '';

		$geom = geoPHP::load($value, 'wkt');
		if ($geom) {
			'@phan-var-force Geometry $geom';
			$value = get_class($geom) . ' : '. $geom->numPoints() . ' Points';
		}
		return $value;
	}

	/**
	 * Return wkt
	 *
	 * @param	string	$geojson	A json string
	 * @return	mixed				Value key
	 */
	public function getWkt($geojson)
	{
		$value_key = '';

		try {
			$geom = geoPHP::load($geojson, 'json');
			if ($geom) {
				'@phan-var-force Geometry $geom';
				$value_key = $geom->out('wkt');
			}
		} catch (Exception $e) {
			// Do nothing
			$value_key = 'Error: Bad value for property';
		}
		return $value_key;
	}
}