diff options
| author | Indoteknik . <it@fixcomart.co.id> | 2025-06-10 15:47:32 +0700 |
|---|---|---|
| committer | Indoteknik . <it@fixcomart.co.id> | 2025-06-10 15:47:32 +0700 |
| commit | df0467f8e493840f3013bc58ca26fc6d98793c95 (patch) | |
| tree | 05a01e1dee6bf866caaecfb5651f849fcf37cf86 /ab_openstreetmap/static | |
| parent | 5ca33915f1e3d052cfa989163d43a15dbc9ddec9 (diff) | |
(andri) add openstreetmaps pada contact
Diffstat (limited to 'ab_openstreetmap/static')
| -rw-r--r-- | ab_openstreetmap/static/src/js/openstreetmap_widget.js | 86 | ||||
| -rw-r--r-- | ab_openstreetmap/static/src/xml/openstreetmap_template.xml | 8 |
2 files changed, 94 insertions, 0 deletions
diff --git a/ab_openstreetmap/static/src/js/openstreetmap_widget.js b/ab_openstreetmap/static/src/js/openstreetmap_widget.js new file mode 100644 index 00000000..42760d2d --- /dev/null +++ b/ab_openstreetmap/static/src/js/openstreetmap_widget.js @@ -0,0 +1,86 @@ +odoo.define("ab_openstreetmap.openstreetmap_widget", function (require) { + "use strict"; + var fieldRegistry = require("web.field_registry"); + var abstractField = require("web.AbstractField"); + + var openstreetmap = abstractField.extend({ + template: "openstreetmap_template", + start: function () { + var self = this; + this._super(); + self._initMap(); + }, + _initMap: function () { + var self = this + $(document).ready(function () { + setTimeout(() => { + var lat = self.recordData.lat; + var lng = self.recordData.lng; + + if (!lat && !lng) { + lat = -6.2349; + lng = 106.9896; + } + + var mymap = L.map('mapid').setView([lat, lng], 13); + L.tileLayer("https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", { + attribution: + '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors', + }).addTo(mymap); + + var edit = self.mode == "edit" ? true : false; + var marker = L.marker([lat, lng], { draggable: edit }).addTo(mymap); + + marker.on("dragend", function (e) { + var latlng = e.target._latlng; + self.trigger_up("field_changed", { + dataPointID: self.dataPointID, + changes: { + lat: latlng.lat, + lng: latlng.lng, + }, + viewType: self.viewType, + }); + }); + + if (edit) { + var geocode = L.Control.geocoder({ + defaultMarkGeocode: false, + }).addTo(mymap); + + geocode.on("markgeocode", function (e) { + var lat = e.geocode.center.lat; + var lng = e.geocode.center.lng; + + mymap.flyTo([lat, lng]); + marker.setLatLng(new L.LatLng(lat, lng)); + self.trigger_up("field_changed", { + dataPointID: self.dataPointID, + changes: { + lat: lat, + lng: lng, + }, + viewType: self.viewType, + }); + }); + } + + var interval = setInterval(() => { + if (mymap && mymap._size.x > 0){ + clearInterval(interval); + } else if (!document.getElementById("mapid")) { + clearInterval(interval); + } + window.dispatchEvent(new Event("resize")); + }, 500); + }, 100); + + }); + }, + isSet: function () { + return true; + }, + }); + + fieldRegistry.add("openstreetmap", openstreetmap); +}); diff --git a/ab_openstreetmap/static/src/xml/openstreetmap_template.xml b/ab_openstreetmap/static/src/xml/openstreetmap_template.xml new file mode 100644 index 00000000..82672748 --- /dev/null +++ b/ab_openstreetmap/static/src/xml/openstreetmap_template.xml @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8"?> +<templates id="template" xml:space="preserve"> + <t t-name="openstreetmap_template"> + <div style="width:100%"> + <div id="mapid" style="height: 500px;"/> + </div> + </t> +</templates>
\ No newline at end of file |
