summaryrefslogtreecommitdiff
path: root/addons/website/static/src/snippets/s_google_map
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/website/static/src/snippets/s_google_map
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website/static/src/snippets/s_google_map')
-rw-r--r--addons/website/static/src/snippets/s_google_map/000.js96
-rw-r--r--addons/website/static/src/snippets/s_google_map/000.scss42
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-blue.jpgbin0 -> 2617 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-bw.jpgbin0 -> 4105 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-caramello.jpgbin0 -> 2688 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-cobalt.jpgbin0 -> 2966 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-cupertino.jpgbin0 -> 3443 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-default.jpgbin0 -> 3440 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-flat.jpgbin0 -> 3109 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-lightMono.jpgbin0 -> 4149 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-lilla.jpgbin0 -> 2642 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/img/thumbs/map-retro.jpgbin0 -> 4055 bytes
-rw-r--r--addons/website/static/src/snippets/s_google_map/options.js56
13 files changed, 194 insertions, 0 deletions
diff --git a/addons/website/static/src/snippets/s_google_map/000.js b/addons/website/static/src/snippets/s_google_map/000.js
new file mode 100644
index 00000000..1fa5d3d7
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/000.js
@@ -0,0 +1,96 @@
+odoo.define('website.s_google_map', function (require) {
+'use strict';
+
+const publicWidget = require('web.public.widget');
+
+publicWidget.registry.GoogleMap = publicWidget.Widget.extend({
+ selector: '.s_google_map',
+ disabledInEditableMode: false,
+
+ mapColors: {
+ lightMonoMap: [{"featureType": "administrative.locality", "elementType": "all", "stylers": [{"hue": "#2c2e33"}, {"saturation": 7}, {"lightness": 19}, {"visibility": "on"}]}, {"featureType": "landscape", "elementType": "all", "stylers": [{"hue": "#ffffff"}, {"saturation": -100}, {"lightness": 100}, {"visibility": "simplified"}]}, {"featureType": "poi", "elementType": "all", "stylers": [{"hue": "#ffffff"}, {"saturation": -100}, {"lightness": 100}, {"visibility": "off"}]}, {"featureType": "road", "elementType": "geometry", "stylers": [{"hue": "#bbc0c4"}, {"saturation": -93}, {"lightness": 31}, {"visibility": "simplified"}]}, {"featureType": "road", "elementType": "labels", "stylers": [{"hue": "#bbc0c4"}, {"saturation": -93}, {"lightness": 31}, {"visibility": "on"}]}, {"featureType": "road.arterial", "elementType": "labels", "stylers": [{"hue": "#bbc0c4"}, {"saturation": -93}, {"lightness": -2}, {"visibility": "simplified"}]}, {"featureType": "road.local", "elementType": "geometry", "stylers": [{"hue": "#e9ebed"}, {"saturation": -90}, {"lightness": -8}, {"visibility": "simplified"}]}, {"featureType": "transit", "elementType": "all", "stylers": [{"hue": "#e9ebed"}, {"saturation": 10}, {"lightness": 69}, {"visibility": "on"}]}, {"featureType": "water", "elementType": "all", "stylers": [{"hue": "#e9ebed"}, {"saturation": -78}, {"lightness": 67}, {"visibility": "simplified"}]}],
+ lillaMap: [{elementType: "labels", stylers: [{saturation: -20}]}, {featureType: "poi", elementType: "labels", stylers: [{visibility: "off"}]}, {featureType: 'road.highway', elementType: 'labels', stylers: [{visibility: "off"}]}, {featureType: "road.local", elementType: "labels.icon", stylers: [{visibility: "off"}]}, {featureType: "road.arterial", elementType: "labels.icon", stylers: [{visibility: "off"}]}, {featureType: "road", elementType: "geometry.stroke", stylers: [{visibility: "off"}]}, {featureType: "transit", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "poi", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "poi.government", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "poi.sport_complex", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "poi.attraction", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "poi.business", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "transit", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "transit.station", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "landscape", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "road", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "road.highway", elementType: "geometry.fill", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}, {featureType: "water", elementType: "geometry", stylers: [{hue: '#2d313f'}, {visibility: "on"}, {lightness: 5}, {saturation: -20}]}],
+ blueMap: [{stylers: [{hue: "#00ffe6"}, {saturation: -20}]}, {featureType: "road", elementType: "geometry", stylers: [{lightness: 100}, {visibility: "simplified"}]}, {featureType: "road", elementType: "labels", stylers: [{visibility: "off"}]}],
+ retroMap: [{"featureType": "administrative", "elementType": "all", "stylers": [{"visibility": "on"}, {"lightness": 33}]}, {"featureType": "landscape", "elementType": "all", "stylers": [{"color": "#f2e5d4"}]}, {"featureType": "poi.park", "elementType": "geometry", "stylers": [{"color": "#c5dac6"}]}, {"featureType": "poi.park", "elementType": "labels", "stylers": [{"visibility": "on"}, {"lightness": 20}]}, {"featureType": "road", "elementType": "all", "stylers": [{"lightness": 20}]}, {"featureType": "road.highway", "elementType": "geometry", "stylers": [{"color": "#c5c6c6"}]}, {"featureType": "road.arterial", "elementType": "geometry", "stylers": [{"color": "#e4d7c6"}]}, {"featureType": "road.local", "elementType": "geometry", "stylers": [{"color": "#fbfaf7"}]}, {"featureType": "water", "elementType": "all", "stylers": [{"visibility": "on"}, {"color": "#acbcc9"}]}],
+ flatMap: [{"stylers": [{"visibility": "off"}]}, {"featureType": "road", "stylers": [{"visibility": "on"}, {"color": "#ffffff"}]}, {"featureType": "road.arterial", "stylers": [{"visibility": "on"}, {"color": "#fee379"}]}, {"featureType": "road.highway", "stylers": [{"visibility": "on"}, {"color": "#fee379"}]}, {"featureType": "landscape", "stylers": [{"visibility": "on"}, {"color": "#f3f4f4"}]}, {"featureType": "water", "stylers": [{"visibility": "on"}, {"color": "#7fc8ed"}]}, {}, {"featureType": "road", "elementType": "labels", "stylers": [{"visibility": "on"}]}, {"featureType": "poi.park", "elementType": "geometry.fill", "stylers": [{"visibility": "on"}, {"color": "#83cead"}]}, {"elementType": "labels", "stylers": [{"visibility": "on"}]}, {"featureType": "landscape.man_made", "elementType": "geometry", "stylers": [{"weight": 0.9}, {"visibility": "off"}]}],
+ cobaltMap: [{"featureType": "all", "elementType": "all", "stylers": [{"invert_lightness": true}, {"saturation": 10}, {"lightness": 30}, {"gamma": 0.5}, {"hue": "#435158"}]}],
+ cupertinoMap: [{"featureType": "water", "elementType": "geometry", "stylers": [{"color": "#a2daf2"}]}, {"featureType": "landscape.man_made", "elementType": "geometry", "stylers": [{"color": "#f7f1df"}]}, {"featureType": "landscape.natural", "elementType": "geometry", "stylers": [{"color": "#d0e3b4"}]}, {"featureType": "landscape.natural.terrain", "elementType": "geometry", "stylers": [{"visibility": "off"}]}, {"featureType": "poi.park", "elementType": "geometry", "stylers": [{"color": "#bde6ab"}]}, {"featureType": "poi", "elementType": "labels", "stylers": [{"visibility": "off"}]}, {"featureType": "poi.medical", "elementType": "geometry", "stylers": [{"color": "#fbd3da"}]}, {"featureType": "poi.business", "stylers": [{"visibility": "off"}]}, {"featureType": "road", "elementType": "geometry.stroke", "stylers": [{"visibility": "off"}]}, {"featureType": "road", "elementType": "labels", "stylers": [{"visibility": "off"}]}, {"featureType": "road.highway", "elementType": "geometry.fill", "stylers": [{"color": "#ffe15f"}]}, {"featureType": "road.highway", "elementType": "geometry.stroke", "stylers": [{"color": "#efd151"}]}, {"featureType": "road.arterial", "elementType": "geometry.fill", "stylers": [{"color": "#ffffff"}]}, {"featureType": "road.local", "elementType": "geometry.fill", "stylers": [{"color": "black"}]}, {"featureType": "transit.station.airport", "elementType": "geometry.fill", "stylers": [{"color": "#cfb2db"}]}],
+ carMap: [{"featureType": "administrative", "stylers": [{"visibility": "off"}]}, {"featureType": "poi", "stylers": [{"visibility": "simplified"}]}, {"featureType": "road", "stylers": [{"visibility": "simplified"}]}, {"featureType": "water", "stylers": [{"visibility": "simplified"}]}, {"featureType": "transit", "stylers": [{"visibility": "simplified"}]}, {"featureType": "landscape", "stylers": [{"visibility": "simplified"}]}, {"featureType": "road.highway", "stylers": [{"visibility": "off"}]}, {"featureType": "road.local", "stylers": [{"visibility": "on"}]}, {"featureType": "road.highway", "elementType": "geometry", "stylers": [{"visibility": "on"}]}, {"featureType": "water", "stylers": [{"color": "#84afa3"}, {"lightness": 52}]}, {"stylers": [{"saturation": -77}]}, {"featureType": "road"}],
+ bwMap: [{stylers: [{hue: "#00ffe6"}, {saturation: -100}]}, {featureType: "road", elementType: "geometry", stylers: [{lightness: 100}, {visibility: "simplified"}]}, {featureType: "road", elementType: "labels", stylers: [{visibility: "off"}]}],
+ },
+
+ /**
+ * @override
+ */
+ async start() {
+ await this._super(...arguments);
+
+ if (typeof google !== 'object' || typeof google.maps !== 'object') {
+ await new Promise(resolve => {
+ this.trigger_up('gmap_api_request', {
+ editableMode: this.editableMode,
+ onSuccess: () => resolve(),
+ });
+ });
+ // The animation will be restarted for all maps as soon as the
+ // google map script has been executed.
+ return;
+ }
+
+ // Define a default map's colors set
+ const std = [];
+ new google.maps.StyledMapType(std, {name: "Std Map"});
+
+ // Default options, will be overwritten by the user
+ const myOptions = {
+ zoom: 12,
+ center: new google.maps.LatLng(50.854975, 4.3753899),
+ mapTypeId: google.maps.MapTypeId.ROADMAP,
+ panControl: false,
+ zoomControl: false,
+ mapTypeControl: false,
+ streetViewControl: false,
+ scrollwheel: false,
+ mapTypeControlOptions: {
+ mapTypeIds: [google.maps.MapTypeId.ROADMAP, 'map_style']
+ }
+ };
+
+ // Render Map
+ const mapC = this.$('.map_container');
+ const map = new google.maps.Map(mapC.get(0), myOptions);
+
+ // Update GPS position
+ const p = this.el.dataset.mapGps.substring(1).slice(0, -1).split(',');
+ const gps = new google.maps.LatLng(p[0], p[1]);
+ map.setCenter(gps);
+
+ // Update Map on screen resize
+ google.maps.event.addDomListener(window, 'resize', () => {
+ map.setCenter(gps);
+ });
+
+ // Create Marker & Infowindow
+ const markerOptions = {
+ map: map,
+ animation: google.maps.Animation.DROP,
+ position: new google.maps.LatLng(p[0], p[1])
+ };
+ if (this.el.dataset.pinStyle === 'flat') {
+ markerOptions.icon = '/website/static/src/img/snippets_thumbs/s_google_map_marker.png';
+ }
+ new google.maps.Marker(markerOptions);
+
+ map.setMapTypeId(google.maps.MapTypeId[this.el.dataset.mapType]); // Update Map Type
+ map.setZoom(parseInt(this.el.dataset.mapZoom)); // Update Map Zoom
+
+ // Update Map Color
+ const mapColorAttr = this.el.dataset.mapColor;
+ if (mapColorAttr) {
+ const mapColor = this.mapColors[mapColorAttr];
+ map.mapTypes.set('map_style', new google.maps.StyledMapType(mapColor, {name: "Styled Map"}));
+ map.setMapTypeId('map_style');
+ }
+ },
+});
+});
diff --git a/addons/website/static/src/snippets/s_google_map/000.scss b/addons/website/static/src/snippets/s_google_map/000.scss
new file mode 100644
index 00000000..9a8df732
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/000.scss
@@ -0,0 +1,42 @@
+
+$s-google-map-desc-bg: theme-color('primary') !default;
+$s-google-map-desc-alpha: 0.80 !default;
+$s-google-map-desc-hover-bg: theme-color('primary') !default;
+$s-google-map-desc-hover-alpha: 0.55 !default;
+
+.s_google_map {
+ position: relative;
+ min-height: 100px;
+
+ .map_container {
+ @include o-position-absolute(0, 0, 0, 0);
+ }
+ .description {
+ @include o-position-absolute(auto, 0, 0, 0);
+ z-index: 99;
+ padding: 0 1em;
+ background: rgba($s-google-map-desc-bg, $s-google-map-desc-alpha);
+ color: color-yiq(rgba($s-google-map-desc-bg, $s-google-map-desc-alpha));
+ transition: background-color 250ms ease;
+
+ font {
+ float: left;
+ margin-top: 20px;
+ margin-bottom: 15px;
+ font-weight: bold;
+ text-transform: uppercase;
+ }
+ span {
+ float: left;
+ text-transform: none;
+ font-weight: normal;
+ margin-top: 20px;
+ margin-left: 10px;
+ }
+ }
+ &:hover .description {
+ background: $s-google-map-desc-hover-bg;
+ background: rgba($s-google-map-desc-hover-bg, $s-google-map-desc-hover-alpha);
+ color: color-yiq(rgba($s-google-map-desc-hover-bg, $s-google-map-desc-hover-alpha));
+ }
+}
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-blue.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-blue.jpg
new file mode 100644
index 00000000..a929e345
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-blue.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-bw.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-bw.jpg
new file mode 100644
index 00000000..1dad96b4
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-bw.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-caramello.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-caramello.jpg
new file mode 100644
index 00000000..55f1046c
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-caramello.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cobalt.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cobalt.jpg
new file mode 100644
index 00000000..dc0aa590
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cobalt.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cupertino.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cupertino.jpg
new file mode 100644
index 00000000..06c97ae0
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-cupertino.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-default.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-default.jpg
new file mode 100644
index 00000000..ea5c8360
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-default.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-flat.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-flat.jpg
new file mode 100644
index 00000000..9b4df178
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-flat.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lightMono.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lightMono.jpg
new file mode 100644
index 00000000..17e23249
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lightMono.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lilla.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lilla.jpg
new file mode 100644
index 00000000..62a19e7c
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-lilla.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/img/thumbs/map-retro.jpg b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-retro.jpg
new file mode 100644
index 00000000..2c36791b
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/img/thumbs/map-retro.jpg
Binary files differ
diff --git a/addons/website/static/src/snippets/s_google_map/options.js b/addons/website/static/src/snippets/s_google_map/options.js
new file mode 100644
index 00000000..6aad46f1
--- /dev/null
+++ b/addons/website/static/src/snippets/s_google_map/options.js
@@ -0,0 +1,56 @@
+odoo.define('options.s_google_map_options', function (require) {
+'use strict';
+
+const {_t} = require('web.core');
+const options = require('web_editor.snippets.options');
+
+options.registry.GoogleMap = options.Class.extend({
+
+ //--------------------------------------------------------------------------
+ // Options
+ //--------------------------------------------------------------------------
+
+ /**
+ * @see this.selectClass for parameters
+ */
+ resetMapColor(previewMode, widgetValue, params) {
+ this.$target[0].dataset.mapColor = '';
+ },
+ /**
+ * @see this.selectClass for parameters
+ */
+ setFormattedAddress(previewMode, widgetValue, params) {
+ this.$target[0].dataset.pinAddress = params.gmapPlace.formatted_address;
+ },
+ /**
+ * @see this.selectClass for parameters
+ */
+ async showDescription(previewMode, widgetValue, params) {
+ const descriptionEl = this.$target[0].querySelector('.description');
+ if (widgetValue && !descriptionEl) {
+ this.$target.append($(`
+ <div class="description">
+ <font>${_t('Visit us:')}</font>
+ <span>${_t('Our office is located in the northeast of Brussels. TEL (555) 432 2365')}</span>
+ </div>`)
+ );
+ } else if (!widgetValue && descriptionEl) {
+ descriptionEl.remove();
+ }
+ },
+
+ //--------------------------------------------------------------------------
+ // Private
+ //--------------------------------------------------------------------------
+
+ /**
+ * @override
+ */
+ _computeWidgetState(methodName, params) {
+ if (methodName === 'showDescription') {
+ return this.$target[0].querySelector('.description') ? 'true' : '';
+ }
+ return this._super(...arguments);
+ },
+});
+});