diff --git a/geoengine_base_geolocalize/README.rst b/geoengine_base_geolocalize/README.rst new file mode 100644 index 0000000000..ac333308ef --- /dev/null +++ b/geoengine_base_geolocalize/README.rst @@ -0,0 +1,51 @@ +.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg + :alt: License + +Geospatial support for base_geolocalize +======================================= + +Geolocalise your partner based on longitude and latitude provided by +`OpenStreetMap via its Nominatim service +`_. Please read carefully the +`usage policy `_ +before using the module. + +Installation +============ + +Take a look at the installation section in the description of the module +'base_geoengine'. + +The module also requires one additional python libs: + +* `requests `_ + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us smashing it by providing a detailed and welcomed feedback +`here `_. + + +Credits +======= + +Contributors +------------ + +* Laurent Mignon + +Maintainer +---------- + +.. image:: http://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: http://odoo-community.org + +This module is maintained by the OCA. + +OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use. + +To contribute to this module, please visit http://odoo-community.org. diff --git a/geoengine_base_geolocalize/__init__.py b/geoengine_base_geolocalize/__init__.py new file mode 100644 index 0000000000..19b92ca2b4 --- /dev/null +++ b/geoengine_base_geolocalize/__init__.py @@ -0,0 +1,20 @@ +############################################################################## +# +# Author: Laurent Mignon +# Copyright (c) 2015 Acsone SA/NV (http://www.acsone.eu) +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero 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 Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see . +# +############################################################################## +from . import models diff --git a/geoengine_base_geolocalize/__manifest__.py b/geoengine_base_geolocalize/__manifest__.py new file mode 100644 index 0000000000..39a75ea273 --- /dev/null +++ b/geoengine_base_geolocalize/__manifest__.py @@ -0,0 +1,15 @@ +# Copyright 2015-2017 ACSONE SA/NV () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). +{ + "name": "Geospatial support for base_geolocalize", + "version": "16.0.1.0.1", + "category": "GeoBI", + "author": "ACSONE SA/NV, Odoo Community Association (OCA)", + "license": "AGPL-3", + "website": "https://github.com/OCA/geospatial", + "depends": ["base", "geoengine_partner", "base_geolocalize"], + "external_dependencies": {"python": ["requests"]}, + "data": ["views/res_partner_view.xml"], + "application": True, + "autoinstall": True, +} diff --git a/geoengine_base_geolocalize/i18n/geoengine_base_geolocalize.pot b/geoengine_base_geolocalize/i18n/geoengine_base_geolocalize.pot new file mode 100644 index 0000000000..ce8caf93f9 --- /dev/null +++ b/geoengine_base_geolocalize/i18n/geoengine_base_geolocalize.pot @@ -0,0 +1,20 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * geoengine_base_geolocalize +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: <>\n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: geoengine_base_geolocalize +#: model:ir.model,name:geoengine_base_geolocalize.model_res_partner +msgid "Partner" +msgstr "" + diff --git a/geoengine_base_geolocalize/models/__init__.py b/geoengine_base_geolocalize/models/__init__.py new file mode 100644 index 0000000000..91fed54d40 --- /dev/null +++ b/geoengine_base_geolocalize/models/__init__.py @@ -0,0 +1 @@ +from . import res_partner diff --git a/geoengine_base_geolocalize/models/res_partner.py b/geoengine_base_geolocalize/models/res_partner.py new file mode 100644 index 0000000000..366397236b --- /dev/null +++ b/geoengine_base_geolocalize/models/res_partner.py @@ -0,0 +1,41 @@ +# Copyright 2015 ACSONE SA/NV () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from odoo import api, fields, models + + +class ResPartner(models.Model): + """Add geo_point to partner using a function field""" + + _inherit = "res.partner" + + @api.depends("partner_latitude", "partner_longitude") + def _compute_geo_point(self): + """ + Set the `geo_point` of the partner depending of its `partner_latitude` + and its `partner_longitude` + **Notes** + If one of those parameters is not set then reset the partner's + geo_point and do not recompute it + """ + for rec in self: + if not rec.partner_latitude or not rec.partner_longitude: + rec.geo_point = False + else: + rec.geo_point = fields.GeoPoint.from_latlon( + rec.env.cr, rec.partner_latitude, rec.partner_longitude + ) + + geo_point = fields.GeoPoint( + store=True, compute="_compute_geo_point", inverse="_inverse_geo_point" + ) + + def _inverse_geo_point(self): + for rec in self: + if not rec.geo_point: + rec.partner_longitude, rec.partner_latitude = False, False + else: + ( + rec.partner_longitude, + rec.partner_latitude, + ) = fields.GeoPoint.to_latlon(rec.env.cr, rec.geo_point) diff --git a/geoengine_base_geolocalize/static/description/icon.png b/geoengine_base_geolocalize/static/description/icon.png new file mode 100644 index 0000000000..b698310eef Binary files /dev/null and b/geoengine_base_geolocalize/static/description/icon.png differ diff --git a/geoengine_base_geolocalize/tests/__init__.py b/geoengine_base_geolocalize/tests/__init__.py new file mode 100644 index 0000000000..f16f53569b --- /dev/null +++ b/geoengine_base_geolocalize/tests/__init__.py @@ -0,0 +1 @@ +from . import test_geoengine_partner diff --git a/geoengine_base_geolocalize/tests/test_geoengine_partner.py b/geoengine_base_geolocalize/tests/test_geoengine_partner.py new file mode 100644 index 0000000000..03b86d7838 --- /dev/null +++ b/geoengine_base_geolocalize/tests/test_geoengine_partner.py @@ -0,0 +1,42 @@ +# Copyright 2015-2017 ACSONE SA/NV () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). +from odoo.tests.common import TransactionCase + + +class TestGeoenginePartner(TransactionCase): + def test_get_geo_point(self): + partner_id = self.env.ref("base.user_root").partner_id + partner_id.partner_longitude = False + partner_id.partner_latitude = False + self.assertFalse( + partner_id.geo_point, "Should not have geo_point with no latlon" + ) + partner_id.partner_latitude = 20 + self.assertFalse( + partner_id.geo_point, "Should not have geo_point with no latlon" + ) + partner_id.partner_longitude = 20 + self.assertTrue(partner_id.geo_point, "Should have geo_point") + + def test_geo_localize(self): + vals = { + "name": "Partner Project", + "street": "Rue au bois la dame", + "country_id": self.env.ref("base.be").id, + "zip": "6800", + } + partner_id = self.env["res.partner"].create(vals) + partner_id.name = "Other Partner" + partner_id.with_context(force_geo_localize=True).geo_localize() + self.assertAlmostEqual( + partner_id.partner_latitude, 49.9535323, 2, "Latitude Should be equals" + ) + self.assertAlmostEqual( + partner_id.partner_longitude, 5.4119073, 2, "Longitude Should be equals" + ) + domain = [("id", "=", partner_id.id)] + partner_id.unlink() + self.assertFalse( + self.env["res.partner"].search(domain), + "Should not have this partner anymore", + ) diff --git a/geoengine_base_geolocalize/views/res_partner_view.xml b/geoengine_base_geolocalize/views/res_partner_view.xml new file mode 100644 index 0000000000..1e1d104cf1 --- /dev/null +++ b/geoengine_base_geolocalize/views/res_partner_view.xml @@ -0,0 +1,21 @@ + + + + + geo_partner_form + res.partner + + + + 1 + + + + + + + + diff --git a/requirements.txt b/requirements.txt index 644dd4f273..938375c961 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,5 @@ # generated from manifests external_dependencies geojson +requests shapely simplejson diff --git a/setup/geoengine_base_geolocalize/odoo/addons/geoengine_base_geolocalize b/setup/geoengine_base_geolocalize/odoo/addons/geoengine_base_geolocalize new file mode 120000 index 0000000000..0497e47d24 --- /dev/null +++ b/setup/geoengine_base_geolocalize/odoo/addons/geoengine_base_geolocalize @@ -0,0 +1 @@ +../../../../geoengine_base_geolocalize \ No newline at end of file diff --git a/setup/geoengine_base_geolocalize/setup.py b/setup/geoengine_base_geolocalize/setup.py new file mode 100644 index 0000000000..28c57bb640 --- /dev/null +++ b/setup/geoengine_base_geolocalize/setup.py @@ -0,0 +1,6 @@ +import setuptools + +setuptools.setup( + setup_requires=['setuptools-odoo'], + odoo_addon=True, +)