tent-lib 0.0.282 → 0.0.284

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -132,16 +132,26 @@ export class ModuleGoogleMapsComponent {
132
132
  }
133
133
  ngOnInit() {
134
134
  this.scriptLoaded$ = this.loadScript();
135
+ this.scriptLoaded$.subscribe((loaded) => {
136
+ if (loaded) {
137
+ this.width =
138
+ document.getElementsByTagName('google-map')[0].clientWidth;
139
+ this.map = this.googleMaps.googleMap;
140
+ this.addCustomMarkers();
141
+ }
142
+ });
135
143
  fromEvent(window, 'resize')
136
144
  .pipe(tap(() => {
137
- this.width =
138
- document.getElementsByTagName('google-map')[0].clientWidth;
145
+ if (this.scriptLoaded) {
146
+ this.width =
147
+ document.getElementsByTagName('google-map')[0].clientWidth;
148
+ }
139
149
  }))
140
150
  .subscribe();
141
151
  }
142
152
  loadScript() {
143
153
  if (this.scriptLoaded) {
144
- return of(false);
154
+ return of(true);
145
155
  }
146
156
  const script = document.createElement('script');
147
157
  script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&loading=async`;
@@ -151,11 +161,6 @@ export class ModuleGoogleMapsComponent {
151
161
  return fromEvent(script, 'load').pipe(switchMap(() => {
152
162
  this.scriptLoaded = true;
153
163
  return of(true);
154
- }), tap(() => {
155
- this.width =
156
- document.getElementsByTagName('google-map')[0].clientWidth;
157
- this.map = this.googleMaps.googleMap;
158
- this.addCustomMarkers();
159
164
  }), catchError((error) => {
160
165
  return throwError(() => new Error('Error loading Google Maps script'));
161
166
  }));
@@ -199,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
199
204
  }], apiKey: [{
200
205
  type: Input
201
206
  }] } });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"module-google-maps.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/module-google-maps/module-google-maps.component.ts","../../../../../../../projects/tent/src/lib/components/core/module-google-maps/module-google-maps.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACpE,OAAO,EAAa,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACnE,OAAO,EAEH,UAAU,EACV,SAAS,EACT,EAAE,EACF,SAAS,EACT,GAAG,EACH,UAAU,GACb,MAAM,MAAM,CAAC;;;;AASd,MAAM,OAAO,yBAAyB;IAPtC;QAaI,iBAAY,GAAG,KAAK,CAAC;QAMrB,YAAO,GAA2B;YAC9B,MAAM,EAAE;gBACJ;oBACI,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,oBAAoB;oBACjC,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,gBAAgB;oBAC7B,WAAW,EAAE,iBAAiB;oBAC9B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,4BAA4B;oBACzC,WAAW,EAAE,iBAAiB;oBAC9B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,4BAA4B;oBACzC,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,mBAAmB;oBAChC,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,KAAK;oBAClB,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,KAAK;oBAClB,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,UAAU;oBACvB,WAAW,EAAE,eAAe;oBAC5B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,UAAU;oBACvB,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,MAAM;oBACnB,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,eAAe;oBAC5B,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,cAAc;oBAC3B,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,cAAc;oBAC3B,WAAW,EAAE,iBAAiB;oBAC9B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,gCAAgC;oBAC7C,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,gCAAgC;oBAC7C,WAAW,EAAE,iBAAiB;oBAC9B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,YAAY;oBACzB,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,cAAc;oBAC3B,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,cAAc;oBAC3B,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,cAAc;oBAC3B,WAAW,EAAE,oBAAoB;oBACjC,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,iBAAiB;oBAC9B,WAAW,EAAE,UAAU;oBACvB,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,OAAO;oBACpB,WAAW,EAAE,eAAe;oBAC5B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;gBACD;oBACI,WAAW,EAAE,OAAO;oBACpB,WAAW,EAAE,kBAAkB;oBAC/B,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;iBAClC;aACJ;SACJ,CAAC;KA8EL;IA5EG,QAAQ;QACJ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC;aACtB,IAAI,CACD,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,KAAK;gBACN,QAAQ,CAAC,oBAAoB,CACzB,YAAY,CACf,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;QACzB,CAAC,CAAC,CACL;aACA,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,UAAU;QACN,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;SACpB;QAED,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,CAAC,GAAG,GAAG,+CAA+C,IAAI,CAAC,MAAM,gBAAgB,CAAC;QACxF,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;QAEpB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAElC,OAAO,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,IAAI,CACjC,SAAS,CAAC,GAAG,EAAE;YACX,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,KAAK;gBACN,QAAQ,CAAC,oBAAoB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC/D,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,SAAU,CAAC;YACtC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,OAAO,UAAU,CACb,GAAG,EAAE,CAAC,IAAI,KAAK,CAAC,kCAAkC,CAAC,CACtD,CAAC;QACN,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED,gBAAgB;QACZ,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3B,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAChD,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAEzC,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC1C,GAAG,CAAC,GAAG,GAAG,kCAAkC,CAAC;YAE7C,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC/C,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAChC,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;YAEhC,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;YAC3B,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAEhC,MAAM,YAAY,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACnD,YAAY,CAAC,KAAK,GAAG;gBACjB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC9B,KAAK,EAAE,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAC/C,CAAC,CAAC;YACF,YAAY,CAAC,IAAI,GAAG;gBAChB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;gBACxC,MAAM,QAAQ,GAAG,UAAU,CAAC,oBAAoB,CAC5C,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAC/D,CAAC;gBACF,SAAS,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,EAAE,CAAC,GAAG,IAAI,CAAC;gBAC1C,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,QAAQ,EAAE,CAAC,GAAG,IAAI,CAAC;YAC7C,CAAC,CAAC;YACF,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACP,CAAC;8GAjNQ,yBAAyB;kGAAzB,yBAAyB,8OCpBtC,yWAaA,+uiBDGc,YAAY,mFAAE,gBAAgB;;2FAI/B,yBAAyB;kBAPrC,SAAS;+BACI,yBAAyB,cACvB,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,CAAC;8BAKjB,UAAU;sBAAjC,SAAS;uBAAC,WAAW;gBACb,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { GoogleMap, GoogleMapsModule } from '@angular/google-maps';\r\nimport {\r\n    Observable,\r\n    catchError,\r\n    fromEvent,\r\n    of,\r\n    switchMap,\r\n    tap,\r\n    throwError,\r\n} from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'tent-module-google-maps',\r\n    standalone: true,\r\n    imports: [CommonModule, GoogleMapsModule],\r\n    templateUrl: './module-google-maps.component.html',\r\n    styleUrl: './module-google-maps.component.scss',\r\n})\r\nexport class ModuleGoogleMapsComponent implements OnInit {\r\n    @ViewChild('googleMap') googleMaps!: GoogleMap;\r\n    @Input() markers?: GoogleMarker[];\r\n    @Input() apiKey?: string;\r\n\r\n    scriptLoaded$!: Observable<boolean>;\r\n    scriptLoaded = false;\r\n\r\n    //map config\r\n    width!: number;\r\n    map!: google.maps.Map;\r\n\r\n    options: google.maps.MapOptions = {\r\n        styles: [\r\n            {\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ebe3cd' }],\r\n            },\r\n            {\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#523735' }],\r\n            },\r\n            {\r\n                elementType: 'labels.text.stroke',\r\n                stylers: [{ color: '#f5f1e6' }],\r\n            },\r\n            {\r\n                featureType: 'administrative',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#c9b2a6' }],\r\n            },\r\n            {\r\n                featureType: 'administrative.land_parcel',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#dcd2be' }],\r\n            },\r\n            {\r\n                featureType: 'administrative.land_parcel',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#ae9e90' }],\r\n            },\r\n            {\r\n                featureType: 'landscape.natural',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'poi',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'poi',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#93817c' }],\r\n            },\r\n            {\r\n                featureType: 'poi.park',\r\n                elementType: 'geometry.fill',\r\n                stylers: [{ color: '#a5b076' }],\r\n            },\r\n            {\r\n                featureType: 'poi.park',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#447530' }],\r\n            },\r\n            {\r\n                featureType: 'road',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.arterial',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway.controlled_access',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway.controlled_access',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.local',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#8f7d77' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'labels.text.stroke',\r\n                stylers: [{ color: '#f0d0e4' }],\r\n            },\r\n            {\r\n                featureType: 'transit.station',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'water',\r\n                elementType: 'geometry.fill',\r\n                stylers: [{ color: '#c5d0d1' }],\r\n            },\r\n            {\r\n                featureType: 'water',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#c5d0d1' }],\r\n            },\r\n        ],\r\n    };\r\n\r\n    ngOnInit(): void {\r\n        this.scriptLoaded$ = this.loadScript();\r\n        fromEvent(window, 'resize')\r\n            .pipe(\r\n                tap(() => {\r\n                    this.width =\r\n                        document.getElementsByTagName(\r\n                            'google-map'\r\n                        )[0].clientWidth;\r\n                })\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    loadScript(): Observable<boolean> {\r\n        if (this.scriptLoaded) {\r\n            return of(false);\r\n        }\r\n\r\n        const script = document.createElement('script');\r\n        script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&loading=async`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        document.head.appendChild(script);\r\n\r\n        return fromEvent(script, 'load').pipe(\r\n            switchMap(() => {\r\n                this.scriptLoaded = true;\r\n                return of(true);\r\n            }),\r\n            tap(() => {\r\n                this.width =\r\n                    document.getElementsByTagName('google-map')[0].clientWidth;\r\n                this.map = this.googleMaps.googleMap!;\r\n                this.addCustomMarkers();\r\n            }),\r\n            catchError((error) => {\r\n                return throwError(\r\n                    () => new Error('Error loading Google Maps script')\r\n                );\r\n            })\r\n        );\r\n    }\r\n\r\n    addCustomMarkers() {\r\n        this.markers?.forEach((data) => {\r\n            const markerDiv = document.createElement('div');\r\n            markerDiv.classList.add('custom-marker');\r\n\r\n            const img = document.createElement('img');\r\n            img.src = '/assets/tent/img/marker_maps.svg';\r\n\r\n            const labelDiv = document.createElement('div');\r\n            labelDiv.classList.add('label');\r\n            labelDiv.innerText = data.label;\r\n\r\n            markerDiv.appendChild(img);\r\n            markerDiv.appendChild(labelDiv);\r\n\r\n            const customMarker = new google.maps.OverlayView();\r\n            customMarker.onAdd = function () {\r\n                const panes = this.getPanes();\r\n                panes?.overlayLayer.appendChild(markerDiv);\r\n            };\r\n            customMarker.draw = function () {\r\n                const projection = this.getProjection();\r\n                const position = projection.fromLatLngToDivPixel(\r\n                    new google.maps.LatLng(data.position.lat, data.position.lng)\r\n                );\r\n                markerDiv.style.left = position?.x + 'px';\r\n                markerDiv.style.top = position?.y + 'px';\r\n            };\r\n            customMarker.setMap(this.map);\r\n        });\r\n    }\r\n}\r\n\r\nexport interface GoogleMarker {\r\n    position: {\r\n        lat: number;\r\n        lng: number;\r\n    };\r\n    label: string;\r\n}\r\n","@if (scriptLoaded$ | async) { @if (markers?.length) {\r\n<section class=\"google-maps wrapper-medium module-spacer--bottom\">\r\n    <google-map\r\n        #googleMap\r\n        [options]=\"options\"\r\n        [width]=\"width\"\r\n        [center]=\"markers?.[0]!.position\"\r\n        [zoom]=\"12\"\r\n    >\r\n    </google-map>\r\n</section>\r\n\r\n} }\r\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"module-google-maps.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/module-google-maps/module-google-maps.component.ts","../../../../../../../projects/tent/src/lib/components/core/module-google-maps/module-google-maps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { GoogleMap, GoogleMapsModule } from '@angular/google-maps';\r\nimport {\r\n    Observable,\r\n    catchError,\r\n    fromEvent,\r\n    of,\r\n    switchMap,\r\n    tap,\r\n    throwError,\r\n} from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'tent-module-google-maps',\r\n    standalone: true,\r\n    imports: [CommonModule, GoogleMapsModule],\r\n    templateUrl: './module-google-maps.component.html',\r\n    styleUrl: './module-google-maps.component.scss',\r\n})\r\nexport class ModuleGoogleMapsComponent implements OnInit {\r\n    @ViewChild('googleMap') googleMaps!: GoogleMap;\r\n    @Input() markers?: GoogleMarker[];\r\n    @Input() apiKey?: string;\r\n\r\n    scriptLoaded$!: Observable<boolean>;\r\n    scriptLoaded = false;\r\n\r\n    //map config\r\n    width!: number;\r\n    map!: google.maps.Map;\r\n\r\n    options: google.maps.MapOptions = {\r\n        styles: [\r\n            {\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ebe3cd' }],\r\n            },\r\n            {\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#523735' }],\r\n            },\r\n            {\r\n                elementType: 'labels.text.stroke',\r\n                stylers: [{ color: '#f5f1e6' }],\r\n            },\r\n            {\r\n                featureType: 'administrative',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#c9b2a6' }],\r\n            },\r\n            {\r\n                featureType: 'administrative.land_parcel',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#dcd2be' }],\r\n            },\r\n            {\r\n                featureType: 'administrative.land_parcel',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#ae9e90' }],\r\n            },\r\n            {\r\n                featureType: 'landscape.natural',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'poi',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'poi',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#93817c' }],\r\n            },\r\n            {\r\n                featureType: 'poi.park',\r\n                elementType: 'geometry.fill',\r\n                stylers: [{ color: '#a5b076' }],\r\n            },\r\n            {\r\n                featureType: 'poi.park',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#447530' }],\r\n            },\r\n            {\r\n                featureType: 'road',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.arterial',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway.controlled_access',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.highway.controlled_access',\r\n                elementType: 'geometry.stroke',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'road.local',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#ffffff' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#8f7d77' }],\r\n            },\r\n            {\r\n                featureType: 'transit.line',\r\n                elementType: 'labels.text.stroke',\r\n                stylers: [{ color: '#f0d0e4' }],\r\n            },\r\n            {\r\n                featureType: 'transit.station',\r\n                elementType: 'geometry',\r\n                stylers: [{ color: '#e9d1bd' }],\r\n            },\r\n            {\r\n                featureType: 'water',\r\n                elementType: 'geometry.fill',\r\n                stylers: [{ color: '#c5d0d1' }],\r\n            },\r\n            {\r\n                featureType: 'water',\r\n                elementType: 'labels.text.fill',\r\n                stylers: [{ color: '#c5d0d1' }],\r\n            },\r\n        ],\r\n    };\r\n\r\n    ngOnInit(): void {\r\n        this.scriptLoaded$ = this.loadScript();\r\n        this.scriptLoaded$.subscribe((loaded) => {\r\n            if (loaded) {\r\n                this.width =\r\n                    document.getElementsByTagName('google-map')[0].clientWidth;\r\n                this.map = this.googleMaps.googleMap!;\r\n                this.addCustomMarkers();\r\n            }\r\n        });\r\n        fromEvent(window, 'resize')\r\n            .pipe(\r\n                tap(() => {\r\n                    if (this.scriptLoaded) {\r\n                        this.width =\r\n                            document.getElementsByTagName(\r\n                                'google-map'\r\n                            )[0].clientWidth;\r\n                    }\r\n                })\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    loadScript(): Observable<boolean> {\r\n        if (this.scriptLoaded) {\r\n            return of(true);\r\n        }\r\n\r\n        const script = document.createElement('script');\r\n        script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&loading=async`;\r\n        script.async = true;\r\n        script.defer = true;\r\n\r\n        document.head.appendChild(script);\r\n\r\n        return fromEvent(script, 'load').pipe(\r\n            switchMap(() => {\r\n                this.scriptLoaded = true;\r\n                return of(true);\r\n            }),\r\n            catchError((error) => {\r\n                return throwError(\r\n                    () => new Error('Error loading Google Maps script')\r\n                );\r\n            })\r\n        );\r\n    }\r\n\r\n    addCustomMarkers() {\r\n        this.markers?.forEach((data) => {\r\n            const markerDiv = document.createElement('div');\r\n            markerDiv.classList.add('custom-marker');\r\n\r\n            const img = document.createElement('img');\r\n            img.src = '/assets/tent/img/marker_maps.svg';\r\n\r\n            const labelDiv = document.createElement('div');\r\n            labelDiv.classList.add('label');\r\n            labelDiv.innerText = data.label;\r\n\r\n            markerDiv.appendChild(img);\r\n            markerDiv.appendChild(labelDiv);\r\n\r\n            const customMarker = new google.maps.OverlayView();\r\n            customMarker.onAdd = function () {\r\n                const panes = this.getPanes();\r\n                panes?.overlayLayer.appendChild(markerDiv);\r\n            };\r\n            customMarker.draw = function () {\r\n                const projection = this.getProjection();\r\n                const position = projection.fromLatLngToDivPixel(\r\n                    new google.maps.LatLng(data.position.lat, data.position.lng)\r\n                );\r\n                markerDiv.style.left = position?.x + 'px';\r\n                markerDiv.style.top = position?.y + 'px';\r\n            };\r\n            customMarker.setMap(this.map);\r\n        });\r\n    }\r\n}\r\n\r\nexport interface GoogleMarker {\r\n    position: {\r\n        lat: number;\r\n        lng: number;\r\n    };\r\n    label: string;\r\n}\r\n","@if (scriptLoaded$ | async) { @if (markers?.length) {\r\n<section class=\"google-maps wrapper-medium module-spacer--bottom\">\r\n    <google-map\r\n        #googleMap\r\n        [options]=\"options\"\r\n        [width]=\"width\"\r\n        [center]=\"markers?.[0]!.position\"\r\n        [zoom]=\"12\"\r\n    >\r\n    </google-map>\r\n</section>\r\n\r\n} }\r\n"]}
@@ -2547,16 +2547,26 @@ class ModuleGoogleMapsComponent {
2547
2547
  }
2548
2548
  ngOnInit() {
2549
2549
  this.scriptLoaded$ = this.loadScript();
2550
+ this.scriptLoaded$.subscribe((loaded) => {
2551
+ if (loaded) {
2552
+ this.width =
2553
+ document.getElementsByTagName('google-map')[0].clientWidth;
2554
+ this.map = this.googleMaps.googleMap;
2555
+ this.addCustomMarkers();
2556
+ }
2557
+ });
2550
2558
  fromEvent(window, 'resize')
2551
2559
  .pipe(tap(() => {
2552
- this.width =
2553
- document.getElementsByTagName('google-map')[0].clientWidth;
2560
+ if (this.scriptLoaded) {
2561
+ this.width =
2562
+ document.getElementsByTagName('google-map')[0].clientWidth;
2563
+ }
2554
2564
  }))
2555
2565
  .subscribe();
2556
2566
  }
2557
2567
  loadScript() {
2558
2568
  if (this.scriptLoaded) {
2559
- return of(false);
2569
+ return of(true);
2560
2570
  }
2561
2571
  const script = document.createElement('script');
2562
2572
  script.src = `https://maps.googleapis.com/maps/api/js?key=${this.apiKey}&loading=async`;
@@ -2566,11 +2576,6 @@ class ModuleGoogleMapsComponent {
2566
2576
  return fromEvent(script, 'load').pipe(switchMap(() => {
2567
2577
  this.scriptLoaded = true;
2568
2578
  return of(true);
2569
- }), tap(() => {
2570
- this.width =
2571
- document.getElementsByTagName('google-map')[0].clientWidth;
2572
- this.map = this.googleMaps.googleMap;
2573
- this.addCustomMarkers();
2574
2579
  }), catchError((error) => {
2575
2580
  return throwError(() => new Error('Error loading Google Maps script'));
2576
2581
  }));