Browse Source

Mar 14 : [ADD] Initial Commit 'customer_geolocation'

pull/249/head
Sayooj 2 years ago
parent
commit
cc66b4c6d3
  1. 41
      customer_geolocation/README.rst
  2. 23
      customer_geolocation/__init__.py
  3. 53
      customer_geolocation/__manifest__.py
  4. 23
      customer_geolocation/controllers/__init__.py
  5. 117
      customer_geolocation/controllers/main.py
  6. 7
      customer_geolocation/doc/RELEASE_NOTES.md
  7. BIN
      customer_geolocation/static/description/assets/icons/check.png
  8. BIN
      customer_geolocation/static/description/assets/icons/chevron.png
  9. BIN
      customer_geolocation/static/description/assets/icons/cogs.png
  10. BIN
      customer_geolocation/static/description/assets/icons/consultation.png
  11. BIN
      customer_geolocation/static/description/assets/icons/ecom-black.png
  12. BIN
      customer_geolocation/static/description/assets/icons/education-black.png
  13. BIN
      customer_geolocation/static/description/assets/icons/hotel-black.png
  14. BIN
      customer_geolocation/static/description/assets/icons/license.png
  15. BIN
      customer_geolocation/static/description/assets/icons/lifebuoy.png
  16. BIN
      customer_geolocation/static/description/assets/icons/manufacturing-black.png
  17. BIN
      customer_geolocation/static/description/assets/icons/pos-black.png
  18. BIN
      customer_geolocation/static/description/assets/icons/puzzle.png
  19. BIN
      customer_geolocation/static/description/assets/icons/restaurant-black.png
  20. BIN
      customer_geolocation/static/description/assets/icons/service-black.png
  21. BIN
      customer_geolocation/static/description/assets/icons/trading-black.png
  22. BIN
      customer_geolocation/static/description/assets/icons/training.png
  23. BIN
      customer_geolocation/static/description/assets/icons/update.png
  24. BIN
      customer_geolocation/static/description/assets/icons/user.png
  25. BIN
      customer_geolocation/static/description/assets/icons/wrench.png
  26. BIN
      customer_geolocation/static/description/assets/misc/categories.png
  27. BIN
      customer_geolocation/static/description/assets/misc/check-box.png
  28. BIN
      customer_geolocation/static/description/assets/misc/compass.png
  29. BIN
      customer_geolocation/static/description/assets/misc/corporate.png
  30. BIN
      customer_geolocation/static/description/assets/misc/customer-support.png
  31. BIN
      customer_geolocation/static/description/assets/misc/cybrosys-logo.png
  32. BIN
      customer_geolocation/static/description/assets/misc/features.png
  33. BIN
      customer_geolocation/static/description/assets/misc/logo.png
  34. BIN
      customer_geolocation/static/description/assets/misc/pictures.png
  35. BIN
      customer_geolocation/static/description/assets/misc/pie-chart.png
  36. BIN
      customer_geolocation/static/description/assets/misc/right-arrow.png
  37. BIN
      customer_geolocation/static/description/assets/misc/star.png
  38. BIN
      customer_geolocation/static/description/assets/misc/support.png
  39. BIN
      customer_geolocation/static/description/assets/misc/whatsapp.png
  40. BIN
      customer_geolocation/static/description/assets/modules/1.png
  41. BIN
      customer_geolocation/static/description/assets/modules/2.png
  42. BIN
      customer_geolocation/static/description/assets/modules/3.png
  43. BIN
      customer_geolocation/static/description/assets/modules/4.png
  44. BIN
      customer_geolocation/static/description/assets/modules/5.gif
  45. BIN
      customer_geolocation/static/description/assets/modules/6.png
  46. BIN
      customer_geolocation/static/description/assets/screenshots/geo.gif
  47. BIN
      customer_geolocation/static/description/assets/screenshots/geo1.png
  48. BIN
      customer_geolocation/static/description/assets/screenshots/geo2.png
  49. BIN
      customer_geolocation/static/description/assets/screenshots/geo3.png
  50. BIN
      customer_geolocation/static/description/assets/screenshots/geo4.png
  51. BIN
      customer_geolocation/static/description/banner.png
  52. BIN
      customer_geolocation/static/description/icon.png
  53. 558
      customer_geolocation/static/description/index.html
  54. 8
      customer_geolocation/static/src/css/cust_geolocation.css
  55. 214
      customer_geolocation/views/portal_templates.xml

41
customer_geolocation/README.rst

@ -0,0 +1,41 @@
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
Customer Geolocation
=======================
This module allow to set users address through Google Map.
Configuration
=============
This helps customer to add their address through Google Map and locate their address.
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
Developer: Ansil P V @cybrosys, Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

23
customer_geolocation/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Ansil pv (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# 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 (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#####################################################################################
from . import controllers

53
customer_geolocation/__manifest__.py

@ -0,0 +1,53 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# 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 (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': "Geolocation Website",
'version': '16.0.1.0.0 ',
'depends': ['base', 'website', 'website_google_map', 'portal'],
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'images': ['static/description/banner.png'],
'website': 'https://www.cybrosys.com',
'category': 'Website',
'description': "Geolocation is very useful to users",
'summary': 'Geolocation In website. '
'This helps customer to add their address through map and locate the address.',
'assets': {
'web.assets_frontend': [
'customer_geolocation/static/src/css/cust_geolocation.css',
],
},
'data': [
'views/portal_templates.xml',
],
'external_dependencies': {
'python': ['pytz', 'geopy'],
},
'license': 'AGPL-3',
'installable': True,
'application': False,
'auto_install': False,
}

23
customer_geolocation/controllers/__init__.py

@ -0,0 +1,23 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Ansil pv (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# 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 (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#####################################################################################
from . import main

117
customer_geolocation/controllers/main.py

@ -0,0 +1,117 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Ansil pv (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# 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 (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
################################################################################
"""
Install geopy package to decoding geocodes and vise versa
"""
import json
import pytz
from geopy import Nominatim
from odoo import http
from odoo.http import request, route
from odoo.addons.portal.controllers.portal import CustomerPortal
class PortalGeolocation(CustomerPortal):
@route()
def account(self, **post):
""" Super CustomerPortal class function and pass the api key value
from settings using params to website view file"""
res = super(PortalGeolocation, self).account(**post)
params = request.env['ir.config_parameter'].sudo()
values = params.get_param('base_geolocalize.google_map_api_key')
res.qcontext.update({
'api': values
})
return res
@http.route(['/geo/change/<coordinates>'], type='json', auth="none",
website=False, csrf=False)
def geo_changer(self, coordinates):
"""Controller function for get address details from latitude and
longitude that we pinpointed in map using geopy package from python
Parameters ---------- coordinates :The stringify value from map that
contains latitude and longitude
Returns ------- Returning the address details back to view file from
the converted Latitude and longitude
"""
res = json.loads(coordinates)
geolocator = Nominatim(user_agent="geoapiExercises")
location = geolocator.reverse(
str(res.get('lat')) + "," + str(res.get('lng')))
city = "Undefined"
suburb = "Undefined"
state = "Undefined"
country = "Undefined"
p_code = "Undefined"
if location:
addresses = location.raw['address']
if addresses.get('village'):
city = addresses.get('village')
if addresses.get('suburb'):
suburb = addresses.get('suburb')
state = addresses.get('state')
country_code = addresses.get('country_code')
country = pytz.country_names[country_code]
if addresses.get('postcode'):
p_code = addresses.get('postcode')
return {
'city': city,
'suburb': suburb,
'state': state,
'country': country,
'p_code': p_code,
}
@http.route(['/geo/location/<address>'], type='json', auth="none",
website=False, csrf=False)
def geo_location(self, address):
""" Get value from city field in 'my_account' page and convert into
lat and long and return back to website and set the map and fields
Parameters ---------- address : The city name that in city field in
website
Returns
-------
Pass the value to website view and set required fields and map
"""
locator = Nominatim(user_agent="myGeocoder")
location = locator.geocode(address)
geolocator = Nominatim(user_agent="geoapiExercises")
location_country = geolocator.reverse(
str(location.latitude) + "," + str(location.longitude))
addresses = location_country.raw['address']
country_code = addresses.get('country_code')
country = pytz.country_names[country_code]
p_code = "undefined"
if addresses.get('postcode'):
p_code = addresses.get('postcode')
return {
'lat': location.latitude,
'lng': location.longitude,
'country': country,
'p_code': p_code
}

7
customer_geolocation/doc/RELEASE_NOTES.md

@ -0,0 +1,7 @@
## Module <custmer_geolocation>
#### 14.03.2023
#### Version 16.0.1.0.0
#### ADD
- Initial commit for Customer Geolocation

BIN
customer_geolocation/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

BIN
customer_geolocation/static/description/assets/icons/chevron.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

BIN
customer_geolocation/static/description/assets/icons/cogs.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
customer_geolocation/static/description/assets/icons/consultation.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
customer_geolocation/static/description/assets/icons/ecom-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

BIN
customer_geolocation/static/description/assets/icons/education-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

BIN
customer_geolocation/static/description/assets/icons/hotel-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
customer_geolocation/static/description/assets/icons/license.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
customer_geolocation/static/description/assets/icons/lifebuoy.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
customer_geolocation/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
customer_geolocation/static/description/assets/icons/pos-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

BIN
customer_geolocation/static/description/assets/icons/puzzle.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

BIN
customer_geolocation/static/description/assets/icons/restaurant-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

BIN
customer_geolocation/static/description/assets/icons/service-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

BIN
customer_geolocation/static/description/assets/icons/trading-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

BIN
customer_geolocation/static/description/assets/icons/training.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

BIN
customer_geolocation/static/description/assets/icons/update.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
customer_geolocation/static/description/assets/icons/user.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

BIN
customer_geolocation/static/description/assets/icons/wrench.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
customer_geolocation/static/description/assets/misc/categories.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

BIN
customer_geolocation/static/description/assets/misc/check-box.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
customer_geolocation/static/description/assets/misc/compass.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

BIN
customer_geolocation/static/description/assets/misc/corporate.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
customer_geolocation/static/description/assets/misc/customer-support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

BIN
customer_geolocation/static/description/assets/misc/cybrosys-logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

BIN
customer_geolocation/static/description/assets/misc/features.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

BIN
customer_geolocation/static/description/assets/misc/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
customer_geolocation/static/description/assets/misc/pictures.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

BIN
customer_geolocation/static/description/assets/misc/pie-chart.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
customer_geolocation/static/description/assets/misc/right-arrow.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

BIN
customer_geolocation/static/description/assets/misc/star.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

BIN
customer_geolocation/static/description/assets/misc/support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

BIN
customer_geolocation/static/description/assets/misc/whatsapp.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

BIN
customer_geolocation/static/description/assets/modules/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

BIN
customer_geolocation/static/description/assets/modules/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
customer_geolocation/static/description/assets/modules/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
customer_geolocation/static/description/assets/modules/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

BIN
customer_geolocation/static/description/assets/modules/5.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 MiB

BIN
customer_geolocation/static/description/assets/modules/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

BIN
customer_geolocation/static/description/assets/screenshots/geo.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 315 KiB

BIN
customer_geolocation/static/description/assets/screenshots/geo1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 167 KiB

BIN
customer_geolocation/static/description/assets/screenshots/geo2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 557 KiB

BIN
customer_geolocation/static/description/assets/screenshots/geo3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 511 KiB

BIN
customer_geolocation/static/description/assets/screenshots/geo4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 579 KiB

BIN
customer_geolocation/static/description/banner.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

BIN
customer_geolocation/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

558
customer_geolocation/static/description/index.html

@ -0,0 +1,558 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between"
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42" style="width: 42px; height: 42px;" />
<div>
<div
style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Customer GeoLocation In Website</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">Helps Customers to Fetch their Address through Map.</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/geo.gif" class="img-responsive"
style="width: 100%; margin-left: auto; margin-right: auto;" />
</div>
</div>
</div>
</div>
<!-- NAVIGATION SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/compass.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Explore This
Module</h2>
</div>
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;">
<div class="col-sm-12 col-md-6 my-3">
<a href="#overview">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn
more about this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#features">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
features of this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#screenshots">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
screenshots for this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36" />
</div>
</a>
</div>
</div>
<!-- END OF NAVIGATION SECTION -->
<!-- OVERVIEW SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pie-chart.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Overview
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 py-4">
It will help customer to add their address from website when they logged in.The customer can pinpoint their exact location in map it will automatically
load into belongs fields like city,zip and country,customers don’t need to add addresses manually.
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Features
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center" style="margin-top: 40px; margin-bottom: 40px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">The users do not need to add address details manually
.</span>
</div>
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Page will automatically load existing address and shows in map when page open.</span>
</div>
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">When user change their city name manually, the map will shows existing address and the country name and zip code will also change.</span>
</div>
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2" />
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Users can pinpoint their exact location in the map, the details will load into fields automatically and users can confirm it.</span>
</div>
</div>
<div class="col-sm-12 col-md-6">
</div>
</div>
<!-- END OF FEATURES SECTION -->
<!-- SCREENSHOTS SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="screenshots">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pictures.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Screenshots
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> Create Google API Key from https://console.cloud.google.com/
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"><h4><b>*Required:</b>install Python packages <u>Geopy</u> and <u>Pytz</u></h4></p>
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Copy and paste the api key in field that we set in odoo settings
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p>
<img src="assets/screenshots/geo1.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Open the website, in my account page the existing address will load in fields and maps in there
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p>
<img src="assets/screenshots/geo2.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">When we change the city in field, map and other fields like country and zip will change automatically
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p>
<img src="assets/screenshots/geo3.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">If user change location through map the address will automatically change in their fields, it helps the users
</h3>
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p>
<img src="assets/screenshots/geo4.png" class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- RELATED PRODUCTS -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/categories.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Related
Products
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/dynamic_accounts_report/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/custom_gantt_view/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/project_custom_gantt/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/account_reports_xlsx/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/4.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/base_accounting_kit/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/5.gif">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/hr_payroll_community/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev" style="width:35px; color:#000"> <span
class="carousel-control-prev-icon"><i class="fa fa-chevron-left" style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1" data-slide="next" style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i class="fa fa-chevron-right" style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png" />
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48" style="width: 42px; height: 42px;" />
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help? Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52" style="width: 52px; height: 52px;" />
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">+91 86068
27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31" style="width:144px; height: 31px; margin-top: 40px;" />
</div>
</div>
</div>
<!-- END OF SUPPORT -->

8
customer_geolocation/static/src/css/cust_geolocation.css

@ -0,0 +1,8 @@
#wrap {
}
#map {
float: right;
width: 70%;
height: 450px;
}

214
customer_geolocation/views/portal_templates.xml

@ -0,0 +1,214 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template for rearranging fields from my_account page in website -->
<template id="website_geolocation_fields" inherit_id="portal.portal_my_details_fields">
<xpath expr="//input[@name='city']" position="replace">
<input type="text" id="cities" name="city"
t-attf-class="form-control #{error.get('city') and 'is-invalid' or ''}"
t-att-value="city or partner.city"/>
</xpath>
<xpath expr="//input[@name='zipcode']" position="replace">
<input type="text" name="zipcode" id="p_code"
t-attf-class="form-control #{error.get('zip') and 'is-invalid' or ''}"
t-att-value="zipcode or partner.zip"/>
</xpath>
<xpath expr="//select[@name='country_id']" position="replace">
<br/>
<input class="form-control" style="width: 100%" type="text" name="country_id" id="country_show"
t-att-value=""/>
</xpath>
<xpath expr="//select[@name='state_id']" position="replace">
<select name="state_id" id="state_geo"
t-attf-class="form-select #{error.get('state_id') and 'is-invalid' or ''}">
<option value="">select...</option>
<t t-foreach="states or []" t-as="state">
<option t-att-value="state.id" style="display:none;" t-att-data-country_id="state.country_id.id"
t-att-selected="state.id == int(state_id) if state_id else state.id == partner.state_id.id">
<t t-esc="state.name"/>
</option>
</t>
</select>
</xpath>
</template>
<!-- Template for adding GoogleMap to our website -->
<template id="website_geolocation" inherit_id="portal.portal_my_details">
<xpath expr="//div[hasclass('o_portal_details')]" position="inside">
<div id="wrap">
<div class="map_containers">
<script src="https://polyfill.io/v3/polyfill.min.js?features=default"></script>
<script src="https://www.npmjs.com/package/@googlemaps/js-api-loader"></script>
<div id="map-wrapper row">
<script defer="defer"
t-attf-src="https://maps.googleapis.com/maps/api/js?key={{api}}&amp;callback=_onMapLoads&amp;v=weekly&amp;sensor=false&amp;libraries=places"></script>
<div class="row" style="width: 100%" id="map"/>
</div>
</div>
</div>
<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"/>
<script>
<!-- Function for load map in google map router -->
_onMapLoads = function () {
var latlong;
var lat_lng;
var lat;
var lng;
var address = document.getElementById("cities").value
<!-- ajax function for pass value to controller using dynamic router -->
$.ajax({
url: '/geo/location/' + address,
type: 'post',
contentType: 'Application/json',
dataType: 'Application/json',
data:JSON.stringify({main:address}),
success: function(data) {
lat_lng = JSON.parse(data);
lat = lat_lng.result.lat
lng = lat_lng.result.lng
var country_show = lat_lng.result.country
var p_code = lat_lng.result.p_code
$('#country_show').val(country_show);
$('#p_code').val(p_code);
const location = { lat: lat, lng: lng };
const map = new
google.maps.Map(document.getElementById("map"),
{
zoom: 12,
center: location,
});
const marker = new google.maps.Marker({
position: location,
map: map,
});
let InfoWindow = new google.maps.InfoWindow({
content: "Click in the map to get Latitude/Longitude!",
position: location,
});
InfoWindow.open(map);
// Configure the click listener.
map.addListener("click", (mapsMouseEvent) => {
// Close the current InfoWindow.
InfoWindow.close();
// Create a new InfoWindow.
InfoWindow = new google.maps.InfoWindow({
position: mapsMouseEvent.latLng,
});
InfoWindow.setContent(
JSON.stringify(mapsMouseEvent.latLng.toJSON(), null, 2)
);
InfoWindow.open(map);
var coordinates=InfoWindow.content
var j=InfoWindow
latlong = JSON.parse(coordinates);
$.ajax({
url: '/geo/change/' + coordinates,
type: 'post',
contentType: 'Application/json',
dataType: 'Application/json',
data:JSON.stringify({main:coordinates}),
success: function(data) {
}, error: function(data){
var addrs = JSON.parse(data.responseText);
<!-- if (addrs){-->
var city = addrs.result.city
var suburb = addrs.result.suburb
var state = addrs.result.state
var country = addrs.result.country
var p_code = addrs.result.p_code
if (suburb) {
$('#cities').val(suburb);
}
else {
$('#cities').val(city);
}
$('#p_code').val(p_code);
$('#country_show').val(country);
$('#geo_state').val("2");
<!-- }-->
}
})
});
}, error: function(data){
lat_lng = JSON.parse(data.responseText);
lat = lat_lng.result.lat
lng = lat_lng.result.lng
var country_show = lat_lng.result.country
var p_code = lat_lng.result.p_code
$('#country_show').val(country_show);
$('#p_code').val(p_code);
const location = { lat: lat, lng: lng };
const map = new
google.maps.Map(document.getElementById("map"),
{
zoom: 12,
center: location,
});
const marker = new google.maps.Marker({
position: location,
map: map,
});
let InfoWindow = new google.maps.InfoWindow({
content: "Click in the map to get Latitude/Longitude!",
position: location,
});
InfoWindow.open(map);
// Configure the click listener.
map.addListener("click", (mapsMouseEvent) => {
// Close the current InfoWindow.
InfoWindow.close();
// Create a new InfoWindow.
InfoWindow = new google.maps.InfoWindow({
position: mapsMouseEvent.latLng,
});
InfoWindow.setContent(
JSON.stringify(mapsMouseEvent.latLng.toJSON(), null, 2)
);
InfoWindow.open(map);
var coordinates =InfoWindow.content
var j=InfoWindow
latlong = JSON.parse(coordinates);
$.ajax({
url: '/geo/change/' + coordinates,
type: 'post',
contentType: 'Application/json',
dataType: 'Application/json',
data:JSON.stringify({main:coordinates}),
success: function(data) {
}, error: function(data){
var addrs = JSON.parse(data.responseText);
var city = addrs.result.city
var suburb = addrs.result.suburb
var state = addrs.result.state
var country = addrs.result.country
var p_code = addrs.result.p_code
if (suburb) {
$('#cities').val(suburb);
}
else {
$('#cities').val(city);
}
$('#p_code').val(p_code);
$('#country_show').val(country);
$('#geo_state').val("2");
}
})
});
}
})
}
document.getElementById("cities").addEventListener("change", _onMapLoads);
</script>
</xpath>
</template>
</odoo>
Loading…
Cancel
Save