@openremote/or-map 1.8.0-snapshot.20250725074716 → 1.8.0-snapshot.20250725120001

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.
package/lib/index.js CHANGED
@@ -1,41 +1,521 @@
1
- var __decorate=this&&this.__decorate||function(e,t,o,r){var a,n=arguments.length,s=n<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,o):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,o,r);else for(var i=e.length-1;i>=0;i--)(a=e[i])&&(s=(n<3?a(s):n>3?a(t,o,s):a(t,o))||s);return n>3&&s&&Object.defineProperty(t,o,s),s};import e from"@openremote/core";import{FlattenedNodesObserver as t}from"@polymer/polymer/lib/utils/flattened-nodes-observer.js";import{html as o,LitElement as r}from"lit";import{customElement as a,property as n,query as s}from"lit/decorators.js";import{LngLat as i,GeolocateControl as l}from"maplibre-gl";import{MapWidget as p}from"./mapwidget";import{style as d}from"./style";import"./markers/or-map-marker";import"./markers/or-map-marker-asset";import{OrMapMarker as m,OrMapMarkerChangedEvent as c}from"./markers/or-map-marker";import*as h from"./util";import{InputType as u,OrMwcInput as v}from"@openremote/or-mwc-components/or-mwc-input";import{OrMwcDialog as g,showDialog as y}from"@openremote/or-mwc-components/or-mwc-dialog";import{getMarkerIconAndColorFromAssetType as f}from"./util";import{i18next as C}from"@openremote/or-translate";import{debounce as _}from"lodash";export*from"./markers/or-map-marker";export*from"./markers/or-map-marker-asset";export*from"./or-map-asset-card";export class OrMapLoadedEvent extends CustomEvent{constructor(){super(OrMapLoadedEvent.NAME,{bubbles:!0,composed:!0})}}OrMapLoadedEvent.NAME="or-map-loaded";export class OrMapClickedEvent extends CustomEvent{constructor(e,t=!1){super(OrMapClickedEvent.NAME,{detail:{doubleClick:t,lngLat:e},bubbles:!0,composed:!0})}}OrMapClickedEvent.NAME="or-map-clicked";export class OrMapLongPressEvent extends CustomEvent{constructor(e){super(OrMapLongPressEvent.NAME,{detail:{doubleClick:!1,lngLat:e},bubbles:!0,composed:!0})}}OrMapLongPressEvent.NAME="or-map-long-press";export class OrMapGeocoderChangeEvent extends CustomEvent{constructor(e){super(OrMapGeocoderChangeEvent.NAME,{detail:{geocode:e},bubbles:!0,composed:!0})}}OrMapGeocoderChangeEvent.NAME="or-map-geocoder-change";export class CenterControl{onAdd(e){this.map=e;let t=document.createElement("div");t.classList.add("maplibregl-ctrl"),t.classList.add("maplibregl-ctrl-group");let o=document.createElement("button");o.className="maplibregl-ctrl-compass",o.addEventListener("click",t=>e.flyTo({center:this.pos,zoom:e.getZoom()}));let r=document.createElement("span");return r.className="maplibregl-ctrl-icon",o.appendChild(r),t.appendChild(o),this.elem=t,t}onRemove(e){this.map=void 0,this.elem=void 0}}let CoordinatesRegexPattern="^[ ]*(?:Lat: )?(-?\\d+\\.?\\d*)[, ]+(?:Lng: )?(-?\\d+\\.?\\d*)[ ]*$";function getCoordinatesInputKeyHandler(e){return t=>{if("Enter"===t.code||"NumpadEnter"===t.code){let o=t.target.value,r=o?{}:void 0;if(o){let e=o.split(/[ ,]/).filter(e=>!!e);2===e.length&&(r=new i(Number.parseFloat(e[0]),Number.parseFloat(e[1])))}e(r)}}}export class CoordinatesControl{constructor(e=!1,t){this._readonly=!1,this._readonly=e,this._valueChangedHandler=t}onAdd(e){this.map=e;let t=document.createElement("div");t.classList.add("maplibregl-ctrl"),t.classList.add("maplibregl-ctrl-group");let o=new v;return o.type=u.TEXT,o.outlined=!0,o.compact=!0,o.readonly=this._readonly,o.icon="crosshairs-gps",o.value=this._value,o.pattern=CoordinatesRegexPattern,o.onkeyup=getCoordinatesInputKeyHandler(this._valueChangedHandler),t.appendChild(o),this.elem=t,this.input=o,t}onRemove(e){this.map=void 0,this.elem=void 0}set readonly(e){this._readonly=e,this.input&&(this.input.readonly=e)}set value(e){this._value=e,this.input&&(this.input.value=e)}}export const geoJsonPointInputTemplateProvider=(e,t,r,a,n,s)=>{let p,d=!!(s&&s.disabled),m=!!(s&&s.readonly),c=!!(s&&s.compact),v=!!(s&&s.comfortable),_=new CenterControl,b=e=>{n&&(void 0!==e?n({value:e?h.getGeoJSONPoint(e):null}):n(void 0))},A=new CoordinatesControl(d,b);return{templateFunction:(t,r,a,n,s,M)=>{let k,w;t&&(k=(p=h.getLngLat(t))?Object.values(p):void 0);let E=k?k.join(", "):void 0;_.pos=p||void 0,A.readonly=d||m||n||a,A.value=E;let O=f(e),x=e=>{if(!m&&!d)if(p=e?h.getLngLat(e):null,w){let e=w.shadowRoot.getElementById("geo-json-point-marker");e.lng=p?p.lng:void 0,e.lat=p?p.lat:void 0,A.value=(k=p?Object.values(p):void 0)?k.join(", "):void 0}else b(p)},z=[[_,"bottom-left"],[A,"top-right"]];if(!m){let e=new l({positionOptions:{enableHighAccuracy:!0},showAccuracyCircle:!1,showUserLocation:!1});e.on("geolocate",e=>{x(new i(e.coords.longitude,e.coords.latitude))}),e.on("outofmaxbounds",e=>{x(new i(e.coords.longitude,e.coords.latitude))}),z.push([e,"bottom-left"])}let N=o`
2
- <or-map id="geo-json-point-map" class="or-map" @or-map-long-press="${e=>{x(e.detail.lngLat)}}" .center="${k}" .controls="${z}" .showGeoCodingControl=${!m}>
3
- <or-map-marker id="geo-json-point-marker" active .lng="${p?p.lng:void 0}" .lat="${p?p.lat:void 0}" .icon="${O?O.icon:void 0}" .activeColor="${O?"#"+O.color:void 0}" .colour="${O?"#"+O.color:void 0}"></or-map-marker>
4
- </or-map>
5
- <span class="long-press-msg">${C.t("longPressSetLoc")}</span>
6
- `;if(c){let e=N;N=o`
7
- <style>
8
- #geo-json-point-input-compact-wrapper {
9
- display: table-cell;
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import manager from "@openremote/core";
8
+ import { FlattenedNodesObserver } from "@polymer/polymer/lib/utils/flattened-nodes-observer.js";
9
+ import { html, LitElement } from "lit";
10
+ import { customElement, property, query } from "lit/decorators.js";
11
+ import { LngLat, GeolocateControl } from "maplibre-gl";
12
+ import { MapWidget } from "./mapwidget";
13
+ import { style } from "./style";
14
+ import "./markers/or-map-marker";
15
+ import "./markers/or-map-marker-asset";
16
+ import { OrMapMarker, OrMapMarkerChangedEvent } from "./markers/or-map-marker";
17
+ import * as Util from "./util";
18
+ import { InputType, OrMwcInput } from "@openremote/or-mwc-components/or-mwc-input";
19
+ import { OrMwcDialog, showDialog } from "@openremote/or-mwc-components/or-mwc-dialog";
20
+ import { getMarkerIconAndColorFromAssetType } from "./util";
21
+ import { i18next } from "@openremote/or-translate";
22
+ import { debounce } from "lodash";
23
+ // Re-exports
24
+ export { Util };
25
+ export * from "./markers/or-map-marker";
26
+ export * from "./markers/or-map-marker-asset";
27
+ export * from "./or-map-asset-card";
28
+ export class OrMapLoadedEvent extends CustomEvent {
29
+ constructor() {
30
+ super(OrMapLoadedEvent.NAME, {
31
+ bubbles: true,
32
+ composed: true
33
+ });
34
+ }
35
+ }
36
+ OrMapLoadedEvent.NAME = "or-map-loaded";
37
+ export class OrMapClickedEvent extends CustomEvent {
38
+ constructor(lngLat, doubleClick = false) {
39
+ super(OrMapClickedEvent.NAME, {
40
+ detail: {
41
+ doubleClick: doubleClick,
42
+ lngLat: lngLat
43
+ },
44
+ bubbles: true,
45
+ composed: true
46
+ });
47
+ }
48
+ }
49
+ OrMapClickedEvent.NAME = "or-map-clicked";
50
+ export class OrMapLongPressEvent extends CustomEvent {
51
+ constructor(lngLat) {
52
+ super(OrMapLongPressEvent.NAME, {
53
+ detail: {
54
+ doubleClick: false,
55
+ lngLat: lngLat
56
+ },
57
+ bubbles: true,
58
+ composed: true
59
+ });
60
+ }
61
+ }
62
+ OrMapLongPressEvent.NAME = "or-map-long-press";
63
+ export class OrMapGeocoderChangeEvent extends CustomEvent {
64
+ constructor(geocode) {
65
+ super(OrMapGeocoderChangeEvent.NAME, {
66
+ detail: {
67
+ geocode
68
+ },
69
+ bubbles: true,
70
+ composed: true
71
+ });
72
+ }
73
+ }
74
+ OrMapGeocoderChangeEvent.NAME = "or-map-geocoder-change";
75
+ export class CenterControl {
76
+ onAdd(map) {
77
+ this.map = map;
78
+ const control = document.createElement("div");
79
+ control.classList.add("maplibregl-ctrl");
80
+ control.classList.add("maplibregl-ctrl-group");
81
+ const button = document.createElement("button");
82
+ button.className = "maplibregl-ctrl-compass";
83
+ button.addEventListener("click", (ev) => map.flyTo({
84
+ center: this.pos,
85
+ zoom: map.getZoom()
86
+ }));
87
+ const buttonIcon = document.createElement("span");
88
+ buttonIcon.className = "maplibregl-ctrl-icon";
89
+ button.appendChild(buttonIcon);
90
+ control.appendChild(button);
91
+ this.elem = control;
92
+ return control;
93
+ }
94
+ onRemove(map) {
95
+ this.map = undefined;
96
+ this.elem = undefined;
97
+ }
98
+ }
99
+ const CoordinatesRegexPattern = "^[ ]*(?:Lat: )?(-?\\d+\\.?\\d*)[, ]+(?:Lng: )?(-?\\d+\\.?\\d*)[ ]*$";
100
+ function getCoordinatesInputKeyHandler(valueChangedHandler) {
101
+ return (e) => {
102
+ if (e.code === "Enter" || e.code === "NumpadEnter") {
103
+ const valStr = e.target.value;
104
+ let value = !valStr ? undefined : {};
105
+ if (valStr) {
106
+ const lngLatArr = valStr.split(/[ ,]/).filter(v => !!v);
107
+ if (lngLatArr.length === 2) {
108
+ value = new LngLat(Number.parseFloat(lngLatArr[0]), Number.parseFloat(lngLatArr[1]));
109
+ }
110
+ }
111
+ valueChangedHandler(value);
112
+ }
113
+ };
114
+ }
115
+ export class CoordinatesControl {
116
+ constructor(disabled = false, valueChangedHandler) {
117
+ this._readonly = false;
118
+ this._readonly = disabled;
119
+ this._valueChangedHandler = valueChangedHandler;
120
+ }
121
+ onAdd(map) {
122
+ this.map = map;
123
+ const control = document.createElement("div");
124
+ control.classList.add("maplibregl-ctrl");
125
+ control.classList.add("maplibregl-ctrl-group");
126
+ const input = new OrMwcInput();
127
+ input.type = InputType.TEXT;
128
+ input.outlined = true;
129
+ input.compact = true;
130
+ input.readonly = this._readonly;
131
+ input.icon = "crosshairs-gps";
132
+ input.value = this._value;
133
+ input.pattern = CoordinatesRegexPattern;
134
+ input.onkeyup = getCoordinatesInputKeyHandler(this._valueChangedHandler);
135
+ control.appendChild(input);
136
+ this.elem = control;
137
+ this.input = input;
138
+ return control;
139
+ }
140
+ onRemove(map) {
141
+ this.map = undefined;
142
+ this.elem = undefined;
143
+ }
144
+ set readonly(readonly) {
145
+ this._readonly = readonly;
146
+ if (this.input) {
147
+ this.input.readonly = readonly;
148
+ }
149
+ }
150
+ set value(value) {
151
+ this._value = value;
152
+ if (this.input) {
153
+ this.input.value = value;
154
+ }
155
+ }
156
+ }
157
+ export const geoJsonPointInputTemplateProvider = (assetDescriptor, valueHolder, valueHolderDescriptor, valueDescriptor, valueChangeNotifier, options) => {
158
+ const disabled = !!(options && options.disabled);
159
+ const readonly = !!(options && options.readonly);
160
+ const compact = !!(options && options.compact);
161
+ const comfortable = !!(options && options.comfortable);
162
+ const centerControl = new CenterControl();
163
+ const valueChangeHandler = (value) => {
164
+ if (!valueChangeNotifier) {
165
+ return;
166
+ }
167
+ if (value !== undefined) {
168
+ valueChangeNotifier({
169
+ value: value ? Util.getGeoJSONPoint(value) : null
170
+ });
171
+ }
172
+ else {
173
+ valueChangeNotifier(undefined);
174
+ }
175
+ };
176
+ const coordinatesControl = new CoordinatesControl(disabled, valueChangeHandler);
177
+ let pos;
178
+ const templateFunction = (value, focused, loading, sending, error, helperText) => {
179
+ let center;
180
+ if (value) {
181
+ pos = Util.getLngLat(value);
182
+ center = pos ? Object.values(pos) : undefined;
183
+ }
184
+ const centerStr = center ? center.join(", ") : undefined;
185
+ centerControl.pos = pos || undefined;
186
+ coordinatesControl.readonly = disabled || readonly || sending || loading;
187
+ coordinatesControl.value = centerStr;
188
+ const iconAndColor = getMarkerIconAndColorFromAssetType(assetDescriptor);
189
+ let dialog;
190
+ const setPos = (lngLat) => {
191
+ if (readonly || disabled) {
192
+ return;
193
+ }
194
+ pos = lngLat ? Util.getLngLat(lngLat) : null;
195
+ if (dialog) {
196
+ // We're in compact mode modal
197
+ const marker = dialog.shadowRoot.getElementById("geo-json-point-marker");
198
+ marker.lng = pos ? pos.lng : undefined;
199
+ marker.lat = pos ? pos.lat : undefined;
200
+ center = pos ? Object.values(pos) : undefined;
201
+ const centerStr = center ? center.join(", ") : undefined;
202
+ coordinatesControl.value = centerStr;
203
+ }
204
+ else {
205
+ valueChangeHandler(pos);
206
+ }
207
+ };
208
+ const controls = [[centerControl, "bottom-left"], [coordinatesControl, "top-right"]];
209
+ if (!readonly) {
210
+ const userLocationControl = new GeolocateControl({
211
+ positionOptions: {
212
+ enableHighAccuracy: true
213
+ },
214
+ showAccuracyCircle: false,
215
+ showUserLocation: false
216
+ });
217
+ userLocationControl.on('geolocate', (currentLocation) => {
218
+ setPos(new LngLat(currentLocation.coords.longitude, currentLocation.coords.latitude));
219
+ });
220
+ userLocationControl.on('outofmaxbounds', (currentLocation) => {
221
+ setPos(new LngLat(currentLocation.coords.longitude, currentLocation.coords.latitude));
222
+ });
223
+ controls.push([userLocationControl, "bottom-left"]);
224
+ }
225
+ let content = html `
226
+ <or-map id="geo-json-point-map" class="or-map" @or-map-long-press="${(ev) => { setPos(ev.detail.lngLat); }}" .center="${center}" .controls="${controls}" .showGeoCodingControl=${!readonly}>
227
+ <or-map-marker id="geo-json-point-marker" active .lng="${pos ? pos.lng : undefined}" .lat="${pos ? pos.lat : undefined}" .icon="${iconAndColor ? iconAndColor.icon : undefined}" .activeColor="${iconAndColor ? "#" + iconAndColor.color : undefined}" .colour="${iconAndColor ? "#" + iconAndColor.color : undefined}"></or-map-marker>
228
+ </or-map>
229
+ <span class="long-press-msg">${i18next.t('longPressSetLoc')}</span>
230
+ `;
231
+ if (compact) {
232
+ const mapContent = content;
233
+ const onClick = () => {
234
+ dialog = showDialog(new OrMwcDialog()
235
+ .setContent(mapContent)
236
+ .setStyles(html `
237
+ <style>
238
+ .dialog-container {
239
+ flex-direction: column !important;
240
+ }
241
+ .dialog-container .long-press-msg {
242
+ display: block;
243
+ text-align: center;
244
+ }
245
+ or-map {
246
+ width: 600px !important;
247
+ min-height: 600px !important;
248
+ }
249
+ </style>
250
+ `)
251
+ .setActions([
252
+ {
253
+ actionName: "none",
254
+ content: "none",
255
+ action: () => {
256
+ setPos(null);
257
+ valueChangeHandler(pos);
258
+ }
259
+ },
260
+ {
261
+ actionName: "ok",
262
+ content: "ok",
263
+ action: () => {
264
+ valueChangeHandler(pos);
265
+ }
266
+ },
267
+ {
268
+ default: true,
269
+ actionName: "cancel",
270
+ content: "cancel"
10
271
  }
11
- #geo-json-point-input-compact-wrapper > * {
12
- vertical-align: middle;
272
+ ]));
273
+ };
274
+ content = html `
275
+ <style>
276
+ #geo-json-point-input-compact-wrapper {
277
+ display: table-cell;
278
+ }
279
+ #geo-json-point-input-compact-wrapper > * {
280
+ vertical-align: middle;
281
+ }
282
+ </style>
283
+ <div id="geo-json-point-input-compact-wrapper">
284
+ <or-mwc-input style="width: auto;" .comfortable="${comfortable}" .type="${InputType.TEXT}" .value="${centerStr}" .pattern="${CoordinatesRegexPattern}" @keyup="${(e) => getCoordinatesInputKeyHandler(valueChangeHandler)(e)}"></or-mwc-input>
285
+ <or-mwc-input style="width: auto;" .type="${InputType.BUTTON}" compact icon="crosshairs-gps" @or-mwc-input-changed="${onClick}"></or-mwc-input>
286
+ </div>
287
+ `;
288
+ }
289
+ return content;
290
+ };
291
+ return {
292
+ templateFunction: templateFunction,
293
+ supportsHelperText: false,
294
+ supportsLabel: false,
295
+ supportsSendButton: false,
296
+ validator: () => !pos || (pos.lat !== undefined && pos.lat !== null && pos.lng !== undefined && pos.lng !== null)
297
+ };
298
+ };
299
+ let OrMap = class OrMap extends LitElement {
300
+ constructor() {
301
+ super();
302
+ this.type = manager.mapType;
303
+ this._markerStyles = [];
304
+ this.showGeoCodingControl = false;
305
+ this.showBoundaryBoxControl = false;
306
+ this.useZoomControl = true;
307
+ this.showGeoJson = true;
308
+ this.boundary = [];
309
+ this._loaded = false;
310
+ this._markers = [];
311
+ this.addEventListener(OrMapMarkerChangedEvent.NAME, this._onMarkerChangedEvent);
312
+ }
313
+ firstUpdated(_changedProperties) {
314
+ super.firstUpdated(_changedProperties);
315
+ if (manager.ready) {
316
+ this.loadMap();
317
+ }
318
+ }
319
+ get markers() {
320
+ return this._markers;
321
+ }
322
+ connectedCallback() {
323
+ super.connectedCallback();
324
+ }
325
+ disconnectedCallback() {
326
+ var _a;
327
+ super.disconnectedCallback();
328
+ if (this._observer) {
329
+ this._observer.disconnect();
330
+ }
331
+ if (this._resizeObserver) {
332
+ this._resizeObserver.disconnect();
333
+ }
334
+ // Clean up of internal resources associated with the map
335
+ (_a = this._map) === null || _a === void 0 ? void 0 : _a.unload();
336
+ }
337
+ render() {
338
+ return html `
339
+ <div id="container">
340
+ <div id="map"></div>
341
+ <slot></slot>
342
+ <a id="openremote" href="https://openremote.io/" target="_blank">
343
+ <img src="" />
344
+ </a>
345
+ </div>
346
+ `;
347
+ }
348
+ updated(changedProperties) {
349
+ var _a;
350
+ super.updated(changedProperties);
351
+ if (changedProperties.has("center") || changedProperties.has("zoom")) {
352
+ this.flyTo(this.center, this.zoom);
353
+ }
354
+ if (changedProperties.has("boundary") && this.showBoundaryBoxControl) {
355
+ (_a = this._map) === null || _a === void 0 ? void 0 : _a.createBoundaryBox(this.boundary);
356
+ }
357
+ }
358
+ refresh() {
359
+ if (this._map) {
360
+ this._map.loadViewSettings().then(() => {
361
+ if (!this._map)
362
+ return;
363
+ this._map.setCenter();
364
+ this._map.flyTo();
365
+ });
366
+ }
367
+ }
368
+ loadMap() {
369
+ if (this._loaded) {
370
+ return;
371
+ }
372
+ if (this._mapContainer && this._slotElement) {
373
+ this._map = new MapWidget(this.type, this.shadowRoot, this._mapContainer, this.showGeoCodingControl, this.showBoundaryBoxControl, this.useZoomControl, this.showGeoJson)
374
+ .setCenter(this.center)
375
+ .setZoom(this.zoom)
376
+ .setControls(this.controls)
377
+ .setGeoJson(this.geoJson);
378
+ this._map.load().then(() => {
379
+ var _a, _b;
380
+ // Get markers from slot
381
+ this._observer = new FlattenedNodesObserver(this._slotElement, (info) => {
382
+ this._processNewMarkers(info.addedNodes);
383
+ this._processRemovedMarkers(info.removedNodes);
384
+ });
385
+ (_a = this._resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
386
+ this._resizeObserver = new ResizeObserver(debounce(() => {
387
+ this.resize();
388
+ }, 200));
389
+ var container = (_b = this._mapContainer) === null || _b === void 0 ? void 0 : _b.parentElement;
390
+ if (container) {
391
+ this._resizeObserver.observe(container);
392
+ }
393
+ });
394
+ }
395
+ this._loaded = true;
396
+ }
397
+ resize() {
398
+ if (this._map) {
399
+ this._map.resize();
400
+ }
401
+ }
402
+ flyTo(coordinates, zoom) {
403
+ if (this._map) {
404
+ this._map.flyTo(coordinates, zoom);
405
+ }
406
+ }
407
+ _onMarkerChangedEvent(evt) {
408
+ if (this._map) {
409
+ this._map.onMarkerChanged(evt.detail.marker, evt.detail.property);
410
+ }
411
+ }
412
+ _processNewMarkers(nodes) {
413
+ nodes.forEach((node) => {
414
+ if (!this._map) {
415
+ return;
416
+ }
417
+ if (node instanceof OrMapMarker) {
418
+ this._markers.push(node);
419
+ // Add styles of marker class to the shadow root if not already added
420
+ const className = node.constructor.name;
421
+ if (this._markerStyles.indexOf(className) < 0) {
422
+ const styles = node.constructor.styles;
423
+ let stylesArr = [];
424
+ if (styles) {
425
+ if (!Array.isArray(styles)) {
426
+ stylesArr.push(styles);
427
+ }
428
+ else {
429
+ stylesArr = styles;
430
+ }
431
+ stylesArr.forEach((styleItem) => {
432
+ const styleElem = document.createElement("style");
433
+ styleElem.textContent = String(styleItem.toString());
434
+ if (this._mapContainer.children.length > 0) {
435
+ this._mapContainer.insertBefore(styleElem, this._mapContainer.children[0]);
436
+ }
437
+ else {
438
+ this._mapContainer.appendChild(styleElem);
439
+ }
440
+ });
13
441
  }
14
- </style>
15
- <div id="geo-json-point-input-compact-wrapper">
16
- <or-mwc-input style="width: auto;" .comfortable="${v}" .type="${u.TEXT}" .value="${E}" .pattern="${CoordinatesRegexPattern}" @keyup="${e=>getCoordinatesInputKeyHandler(b)(e)}"></or-mwc-input>
17
- <or-mwc-input style="width: auto;" .type="${u.BUTTON}" compact icon="crosshairs-gps" @or-mwc-input-changed="${()=>{w=y(new g().setContent(e).setStyles(o`
18
- <style>
19
- .dialog-container {
20
- flex-direction: column !important;
21
- }
22
- .dialog-container .long-press-msg {
23
- display: block;
24
- text-align: center;
25
- }
26
- or-map {
27
- width: 600px !important;
28
- min-height: 600px !important;
29
- }
30
- </style>
31
- `).setActions([{actionName:"none",content:"none",action:()=>{x(null),b(p)}},{actionName:"ok",content:"ok",action:()=>{b(p)}},{default:!0,actionName:"cancel",content:"cancel"}]))}}"></or-mwc-input>
32
- </div>
33
- `}return N},supportsHelperText:!1,supportsLabel:!1,supportsSendButton:!1,validator:()=>!p||void 0!==p.lat&&null!==p.lat&&void 0!==p.lng&&null!==p.lng}};let OrMap=class extends r{constructor(){super(),this.type=e.mapType,this._markerStyles=[],this.showGeoCodingControl=!1,this.showBoundaryBoxControl=!1,this.useZoomControl=!0,this.showGeoJson=!0,this.boundary=[],this._loaded=!1,this._markers=[],this.addEventListener(c.NAME,this._onMarkerChangedEvent)}firstUpdated(t){super.firstUpdated(t),e.ready&&this.loadMap()}get markers(){return this._markers}connectedCallback(){super.connectedCallback()}disconnectedCallback(){var e;super.disconnectedCallback(),this._observer&&this._observer.disconnect(),this._resizeObserver&&this._resizeObserver.disconnect(),null==(e=this._map)||e.unload()}render(){return o`
34
- <div id="container">
35
- <div id="map"></div>
36
- <slot></slot>
37
- <a id="openremote" href="https://openremote.io/" target="_blank">
38
- <img src="" />
39
- </a>
40
- </div>
41
- `}updated(e){var t;super.updated(e),(e.has("center")||e.has("zoom"))&&this.flyTo(this.center,this.zoom),e.has("boundary")&&this.showBoundaryBoxControl&&(null==(t=this._map)||t.createBoundaryBox(this.boundary))}refresh(){this._map&&this._map.loadViewSettings().then(()=>{this._map&&(this._map.setCenter(),this._map.flyTo())})}loadMap(){this._loaded||(this._mapContainer&&this._slotElement&&(this._map=new p(this.type,this.shadowRoot,this._mapContainer,this.showGeoCodingControl,this.showBoundaryBoxControl,this.useZoomControl,this.showGeoJson).setCenter(this.center).setZoom(this.zoom).setControls(this.controls).setGeoJson(this.geoJson),this._map.load().then(()=>{this._observer=new t(this._slotElement,e=>{this._processNewMarkers(e.addedNodes),this._processRemovedMarkers(e.removedNodes)}),null==(e=this._resizeObserver)||e.disconnect(),this._resizeObserver=new ResizeObserver(_(()=>{this.resize()},200));var e,o,r=null==(o=this._mapContainer)?void 0:o.parentElement;r&&this._resizeObserver.observe(r)})),this._loaded=!0)}resize(){this._map&&this._map.resize()}flyTo(e,t){this._map&&this._map.flyTo(e,t)}_onMarkerChangedEvent(e){this._map&&this._map.onMarkerChanged(e.detail.marker,e.detail.property)}_processNewMarkers(e){e.forEach(e=>{if(this._map&&e instanceof m){this._markers.push(e);let t=e.constructor.name;if(0>this._markerStyles.indexOf(t)){let o=e.constructor.styles,r=[];o&&(Array.isArray(o)?r=o:r.push(o),r.forEach(e=>{let t=document.createElement("style");t.textContent=String(e.toString()),this._mapContainer.children.length>0?this._mapContainer.insertBefore(t,this._mapContainer.children[0]):this._mapContainer.appendChild(t)})),this._markerStyles.push(t)}this._map.addMarker(e)}})}_processRemovedMarkers(e){e.forEach(e=>{if(this._map&&e instanceof m){let t=this._markers.indexOf(e);t>=0&&this._markers.splice(t,1),this._map.removeMarker(e)}})}};OrMap.styles=d,__decorate([n({type:String})],OrMap.prototype,"type",void 0),__decorate([n({type:String,converter:{fromAttribute(e,t){if(!e)return;let o=e.split(",");if(2===o.length)return new i(Number(o[0]),Number(o[1]))},toAttribute(e,t){let o=h.getLngLat(e);return o?""+o.lng+","+o.lat:""}}})],OrMap.prototype,"center",void 0),__decorate([n({type:Number})],OrMap.prototype,"zoom",void 0),__decorate([n({type:Boolean})],OrMap.prototype,"showGeoCodingControl",void 0),__decorate([n({type:Boolean})],OrMap.prototype,"showBoundaryBoxControl",void 0),__decorate([n({type:Boolean})],OrMap.prototype,"useZoomControl",void 0),__decorate([n({type:Object})],OrMap.prototype,"geoJson",void 0),__decorate([n({type:Boolean})],OrMap.prototype,"showGeoJson",void 0),__decorate([n({type:Array})],OrMap.prototype,"boundary",void 0),__decorate([s("#map")],OrMap.prototype,"_mapContainer",void 0),__decorate([s("slot")],OrMap.prototype,"_slotElement",void 0),OrMap=__decorate([a("or-map")],OrMap);export{h as Util,OrMap};
442
+ this._markerStyles.push(className);
443
+ }
444
+ this._map.addMarker(node);
445
+ }
446
+ });
447
+ }
448
+ _processRemovedMarkers(nodes) {
449
+ nodes.forEach((node) => {
450
+ if (!this._map) {
451
+ return;
452
+ }
453
+ if (node instanceof OrMapMarker) {
454
+ const i = this._markers.indexOf(node);
455
+ if (i >= 0) {
456
+ this._markers.splice(i, 1);
457
+ }
458
+ this._map.removeMarker(node);
459
+ }
460
+ });
461
+ }
462
+ };
463
+ OrMap.styles = style;
464
+ __decorate([
465
+ property({ type: String })
466
+ ], OrMap.prototype, "type", void 0);
467
+ __decorate([
468
+ property({ type: String, converter: {
469
+ fromAttribute(value, type) {
470
+ if (!value) {
471
+ return;
472
+ }
473
+ const coords = value.split(",");
474
+ if (coords.length !== 2) {
475
+ return;
476
+ }
477
+ const lng = Number(coords[0]);
478
+ const lat = Number(coords[1]);
479
+ return new LngLat(lng, lat);
480
+ },
481
+ toAttribute(value, type) {
482
+ const lngLat = Util.getLngLat(value);
483
+ if (!lngLat) {
484
+ return "";
485
+ }
486
+ return "" + lngLat.lng + "," + lngLat.lat;
487
+ }
488
+ } })
489
+ ], OrMap.prototype, "center", void 0);
490
+ __decorate([
491
+ property({ type: Number })
492
+ ], OrMap.prototype, "zoom", void 0);
493
+ __decorate([
494
+ property({ type: Boolean })
495
+ ], OrMap.prototype, "showGeoCodingControl", void 0);
496
+ __decorate([
497
+ property({ type: Boolean })
498
+ ], OrMap.prototype, "showBoundaryBoxControl", void 0);
499
+ __decorate([
500
+ property({ type: Boolean })
501
+ ], OrMap.prototype, "useZoomControl", void 0);
502
+ __decorate([
503
+ property({ type: Object })
504
+ ], OrMap.prototype, "geoJson", void 0);
505
+ __decorate([
506
+ property({ type: Boolean })
507
+ ], OrMap.prototype, "showGeoJson", void 0);
508
+ __decorate([
509
+ property({ type: Array })
510
+ ], OrMap.prototype, "boundary", void 0);
511
+ __decorate([
512
+ query("#map")
513
+ ], OrMap.prototype, "_mapContainer", void 0);
514
+ __decorate([
515
+ query("slot")
516
+ ], OrMap.prototype, "_slotElement", void 0);
517
+ OrMap = __decorate([
518
+ customElement("or-map")
519
+ ], OrMap);
520
+ export { OrMap };
521
+ //# sourceMappingURL=index.js.map
@@ -1 +1,66 @@
1
- export function isMapboxURL(r){return 0===r.indexOf("mapbox:")}export function transformMapboxUrl(r,t,e){return r.indexOf("/styles/")>-1&&-1===r.indexOf("/sprite")?{url:normalizeStyleURL(r,t)}:r.indexOf("/sprites/")>-1?{url:normalizeSpriteURL(r,t)}:r.indexOf("/fonts/")>-1?{url:normalizeGlyphsURL(r,t)}:r.indexOf("/v4/")>-1||"Source"===e?{url:normalizeSourceURL(r,t)}:void 0}function parseUrl(r){let t=r.match(/^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/);if(!t)throw Error("Unable to parse URL object");return{protocol:t[1],authority:t[2],path:t[3]||"/",params:t[4]?t[4].split("&"):[]}}function formatUrl(r,t){let e=parseUrl("https://api.mapbox.com");r.protocol=e.protocol,r.authority=e.authority,r.params.push(`access_token=${t}`);let o=r.params.length?`?${r.params.join("&")}`:"";return`${r.protocol}://${r.authority}${r.path}${o}`}function normalizeStyleURL(r,t){let e=parseUrl(r);return e.path=`/styles/v1${e.path}`,formatUrl(e,t)}function normalizeGlyphsURL(r,t){let e=parseUrl(r);return e.path=`/fonts/v1${e.path}`,formatUrl(e,t)}function normalizeSourceURL(r,t){let e=parseUrl(r);return e.path=`/v4/${e.authority}.json`,e.params.push("secure"),formatUrl(e,t)}function normalizeSpriteURL(r,t){let e=parseUrl(r),o=e.path.split("."),a=o[0],l=o[1],n="";return a.indexOf("@2x")&&(a=a.split("@2x")[0],n="@2x"),e.path=`/styles/v1${a}/sprite${n}.${l}`,formatUrl(e,t)}
1
+ export function isMapboxURL(url) {
2
+ return url.indexOf("mapbox:") === 0;
3
+ }
4
+ export function transformMapboxUrl(url, accessToken, resourceType) {
5
+ if (url.indexOf("/styles/") > -1 && url.indexOf("/sprite") === -1)
6
+ return { url: normalizeStyleURL(url, accessToken) };
7
+ if (url.indexOf("/sprites/") > -1)
8
+ return { url: normalizeSpriteURL(url, accessToken) };
9
+ if (url.indexOf("/fonts/") > -1)
10
+ return { url: normalizeGlyphsURL(url, accessToken) };
11
+ if (url.indexOf("/v4/") > -1)
12
+ return { url: normalizeSourceURL(url, accessToken) };
13
+ if (resourceType === "Source" /* ResourceType.Source */)
14
+ return { url: normalizeSourceURL(url, accessToken) };
15
+ }
16
+ function parseUrl(url) {
17
+ const urlRe = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/;
18
+ const parts = url.match(urlRe);
19
+ if (!parts) {
20
+ throw new Error("Unable to parse URL object");
21
+ }
22
+ return {
23
+ protocol: parts[1],
24
+ authority: parts[2],
25
+ path: parts[3] || "/",
26
+ params: parts[4] ? parts[4].split("&") : [],
27
+ };
28
+ }
29
+ function formatUrl(urlObject, accessToken) {
30
+ const apiUrlObject = parseUrl("https://api.mapbox.com");
31
+ urlObject.protocol = apiUrlObject.protocol;
32
+ urlObject.authority = apiUrlObject.authority;
33
+ urlObject.params.push(`access_token=${accessToken}`);
34
+ const params = urlObject.params.length ? `?${urlObject.params.join("&")}` : "";
35
+ return `${urlObject.protocol}://${urlObject.authority}${urlObject.path}${params}`;
36
+ }
37
+ function normalizeStyleURL(url, accessToken) {
38
+ const urlObject = parseUrl(url);
39
+ urlObject.path = `/styles/v1${urlObject.path}`;
40
+ return formatUrl(urlObject, accessToken);
41
+ }
42
+ function normalizeGlyphsURL(url, accessToken) {
43
+ const urlObject = parseUrl(url);
44
+ urlObject.path = `/fonts/v1${urlObject.path}`;
45
+ return formatUrl(urlObject, accessToken);
46
+ }
47
+ function normalizeSourceURL(url, accessToken) {
48
+ const urlObject = parseUrl(url);
49
+ urlObject.path = `/v4/${urlObject.authority}.json`;
50
+ urlObject.params.push("secure");
51
+ return formatUrl(urlObject, accessToken);
52
+ }
53
+ function normalizeSpriteURL(url, accessToken) {
54
+ const urlObject = parseUrl(url);
55
+ const path = urlObject.path.split(".");
56
+ let properPath = path[0];
57
+ const extension = path[1];
58
+ let format = "";
59
+ if (properPath.indexOf("@2x")) {
60
+ properPath = properPath.split("@2x")[0];
61
+ format = "@2x";
62
+ }
63
+ urlObject.path = `/styles/v1${properPath}/sprite${format}.${extension}`;
64
+ return formatUrl(urlObject, accessToken);
65
+ }
66
+ //# sourceMappingURL=mapbox-url-utils.js.map