leaflet-html 0.9.3 → 0.9.4
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/leaflet-html.js +1 -1
- package/dist/leaflet-html.js.map +1 -1
- package/package.json +1 -1
- package/dist/leaflet-html.cjs +0 -2
- package/dist/leaflet-html.cjs.map +0 -1
- package/dist/leaflet-html.modern.js +0 -2
- package/dist/leaflet-html.modern.js.map +0 -1
- package/dist/leaflet-html.umd.js +0 -2
- package/dist/leaflet-html.umd.js.map +0 -1
package/dist/leaflet-html.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1
|
-
import*as t from"leaflet";import{control as e,layerGroup as n,tileLayer as r,imageOverlay as a,videoOverlay as i,geoJSON as o,icon as l,divIcon as s,tooltip as u,Circle as c,Rectangle as p,Polygon as f,Polyline as b,circle as h,polyline as v,polygon as d,rectangle as m}from"leaflet";function y(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(y=function(){return!!t})()}function g(t){var e=function(t,e){if("object"!=typeof t||!t)return t;var n=t[Symbol.toPrimitive];if(void 0!==n){var r=n.call(t,"string");if("object"!=typeof r)return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==typeof e?e:e+""}function E(){return E=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(t[r]=n[r])}return t},E.apply(this,arguments)}function C(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,O(t,e)}function w(t){return w=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},w(t)}function O(t,e){return O=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},O(t,e)}function A(t){var e="function"==typeof Map?new Map:void 0;return A=function(t){if(null===t||!function(t){try{return-1!==Function.toString.call(t).indexOf("[native code]")}catch(e){return"function"==typeof t}}(t))return t;if("function"!=typeof t)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(t))return e.get(t);e.set(t,n)}function n(){return function(t,e,n){if(y())return Reflect.construct.apply(null,arguments);var r=[null];r.push.apply(r,e);var a=new(t.bind.apply(t,r));return n&&O(a,n.prototype),a}(t,arguments,w(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),O(n,t)},A(t)}function k(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=new Array(e);n<e;n++)r[n]=t[n];return r}var N="l:layer:connected",S="l:popup:connected",T="l:icon:connected",j="l:layer:removed",J="l:latlngbounds:connected",M="l:latlngbounds:changed",P="l:tooltip:connected",_="l:pane:connected",F=function(t,e,n){if(void 0===n&&(n=!0),t.hasAttribute("on")){var r=t.getAttribute("on");null!==r&&r.split(/\s+/).forEach(function(r){null!==e&&e.on(r,function(e){t.dispatchEvent(new CustomEvent(r,{bubbles:n,detail:e}))})})}},H=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.addEventListener(N,function(t){t.detail.type="base"})},e}(/*#__PURE__*/A(HTMLElement)),I=/*#__PURE__*/function(t){function n(){return t.call(this)||this}return C(n,t),n.prototype.connectedCallback=function(){var t=e.layers({},{});this.addEventListener(N,function(e){var n=e.detail,r=n.type,a=n.name,i=n.layer;"overlay"===r?t.addOverlay(i,a):"base"===r&&t.addBaseLayer(i,a),e.preventDefault()});var n=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:t}});this.dispatchEvent(n)},n}(/*#__PURE__*/A(HTMLElement)),z=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.disconnectedCallback=function(){var t;null==(t=this.layer)||t.remove()},e}(/*#__PURE__*/A(HTMLElement)),x=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=n();this.layer=e;var r=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:e,name:t}});this.dispatchEvent(r),this.addEventListener(N,function(t){t.stopPropagation(),e.addLayer(t.detail.layer)}),new MutationObserver(function(t){t.forEach(function(t){t.removedNodes.forEach(function(t){if(t instanceof HTMLElement){var n=t.getAttribute("leaflet-id");if(null!==n){var r=e.getLayer(parseInt(n));void 0!==r&&e.removeLayer(r)}}})})}).observe(this,{childList:!0})},e}(z),B=/*#__PURE__*/function(t){function e(e){var n;return(n=t.call(this)||this).issues=[],n.name="LeafletHTMLError",n.issues=e,n}return C(e,t),n=e,(r=[{key:"message",get:function(){return JSON.stringify(this.issues,null,2)}}])&&function(t,e){for(var n=0;n<e.length;n++){var r=e[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,g(r.key),r)}}(n.prototype,r),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,r}(/*#__PURE__*/A(Error)),U=function(t,e){var n=t(function(t){return{status:"clean",issues:[],value:t}}(e));if("clean"!==n.status)throw new B(n.issues);return n.value},R=function(t){return function(e){for(var n=e.issues,r="clean",a={},i=0,o=Object.keys(t);i<o.length;i++){var l=o[i],s=t[l](e);"clean"!==s.status&&(r=s.status),null===s.value&&"clean"===s.status||(n=[].concat(n,s.issues),a[l]=s.value)}return{status:r,issues:n,value:a}}},V=function(){var t=[].slice.call(arguments);return function(e){for(var n=0;n<t.length&&"abort"!==(e=t[n](e)).status;n++);return e}},D=function(){var t=[].slice.call(arguments);return function(e){for(var n=0;n<t.length;n++)e=t[n](e);return e}},G=function(t){return function(e){return null===e.value?e:t(e)}},W=function(t){return function(e){return null===(e=t(e)).value?{status:"clean",issues:[],value:null}:e}},Z=function(t){return function(e){var n=e.value,r=n.getAttribute(t);return null===r?{status:"abort",issues:[].concat(e.issues,[Q(n,t)]),value:null}:E({},e,{value:r})}},$=function(){return function(t){var e;try{e=JSON.parse(t.value)}catch(e){return{status:"abort",issues:[].concat(t.issues,[K(e)]),value:null}}return E({},t,{value:e})}},q=function(t){return V.apply(void 0,[Z(t)].concat([].slice.call(arguments,1)))},K=function(t){return{code:"parse_json",message:t.message}},Q=function(t,e){return{code:"missing_attribute",message:t.tagName.toLowerCase()+" missing attribute '"+e+"'"}},X=/*#__PURE__*/function(e){function n(){var t;(t=e.call(this)||this).map=null;var r=function(e){var n=e.detail;null!==t.map&&t.map[n.method](n.bounds)};return t.addEventListener(J,r),t.addEventListener(M,r),t.addEventListener(_,function(e){t.map.createPane(e.detail.name)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof n){var e=t.target;t.removedNodes.forEach(function(t){t instanceof z&&null!==e.map&&null!==t.layer&&(e.dispatchEvent(new CustomEvent(j,{bubbles:!0,detail:{layer:t.layer}})),e.map.removeLayer(t.layer))})}})}).observe(t,{childList:!0}),t}C(n,e);var r=n.prototype;return r.connectedCallback=function(){var e,n=this;if(this.map=t.map(this,{zoomControl:this.hasAttribute("zoom-control")}),this.map.whenReady(function(){n.dispatchEvent(new CustomEvent("ready",{bubbles:!0,cancelable:!0,detail:n.map}))}),F(this,this.map),this.hasAttribute("fit-world"))this.map.fitWorld();else{var r=(e={zoom:q("zoom",function(t){var e,n=parseInt(t.value);return isNaN(n)?{status:"abort",issues:[].concat(t.issues,[(e=t.value,{code:"parse_int",message:'could not parse int given: "'+e+'"'})]),value:n}:E({},t,{value:n})}),center:q("center",$())},function(t){for(var n=t.status,r=t.issues,a={},i=0,o=Object.keys(e);i<o.length;i++){var l=o[i],s=e[l](t);"abort"===s.status&&(n="abort",r=[].concat(r,s.issues)),a[l]=s.value}return{status:n,issues:r,value:a}}),a=U(r,this);this.map.setView(a.center,a.zoom)}if(this.hasAttribute("locate")){var i=q("locate",$());this.map.locate(U(i,this))}this.addEventListener(N,function(t){n.map.addLayer(t.detail.layer)}),this.addEventListener(j,function(t){null!==n.map&&n.map.removeLayer(t.detail.layer)})},r.attributeChangedCallback=function(t,e,n){null!==this.map&&("zoom"===t?this.map.setZoom(parseInt(n)):"center"===t&&this.map.setView(JSON.parse(n)))},n}(/*#__PURE__*/A(HTMLElement));X.observedAttributes=["zoom","center","zoom-control"];var Y=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t.addEventListener(T,function(e){e.stopPropagation(),t.layer.setIcon(e.detail.icon)}),t.addEventListener(P,function(e){e.stopPropagation(),t.layer.bindTooltip(e.detail.tooltip)}),t}C(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this,n=U(q("lat-lng",$()),this),r=U(R({opacity:D(W(Z("opacity")),G(function(t){var e,n=parseFloat(t.value);return isNaN(n)?{status:"abort",issues:[].concat(t.issues,[(e=t.value,{code:"parse_float",message:'could not parse float given: "'+e+'"'})]),value:n}:E({},t,{value:n})}))}),this),a=this.closest("l-pane");if(null!==a&&(r.pane=a.getAttribute("name")),this.layer=t.marker(n,r),this.hasAttribute("icon")){var i=t.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(i)}F(this,this.layer,!1),this.setAttribute("leaflet-id",t.stamp(this.layer)),this.addEventListener(S,function(t){var n=t.detail,r=n.openPopup,a=e.layer.bindPopup(n.content);r&&a.openPopup()});var o=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(o)},r.attributeChangedCallback=function(e,n,r){null!==this.layer&&("lat-lng"===e&&this.layer.setLatLng(JSON.parse(r)),"opacity"===e&&this.layer.setOpacity(parseFloat(r)),"icon"===e&&this.layer.setIcon(t.icon(JSON.parse(r))))},n}(z);Y.observedAttributes=["lat-lng","opacity","icon"];var tt=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.addEventListener(N,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/A(HTMLElement)),et=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("content"),e=!1,n=this.getAttribute("open-popup");null!==n&&(e="false"!==n);var r=new CustomEvent(S,{cancelable:!0,bubbles:!0,detail:{content:t,openPopup:e}});this.dispatchEvent(r)},e}(/*#__PURE__*/A(HTMLElement)),nt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){for(var t,n=U(Z("url-template"),this),a={},i=function(t,e){var n="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(n)return(n=n.call(t)).next.bind(n);if(Array.isArray(t)||(n=function(t,e){if(t){if("string"==typeof t)return k(t,e);var n=Object.prototype.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?k(t,e):void 0}}(t))){n&&(t=n);var r=0;return function(){return r>=t.length?{done:!0}:{done:!1,value:t[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(e.parseTemplateAttributes(n));!(t=i()).done;){var o=t.value,l=this.getAttribute(o);null!==l&&(a[o]=l)}var s={};"l-pane"===this.parentElement.tagName.toLowerCase()&&(s.pane=this.parentElement.getAttribute("name"));var u=this.getAttribute("name"),c=R({attribution:W(Z("attribution")),errorTileUrl:W(Z("error-tile-url"))}),p=U(c,this);this.layer=r(n,E({},a,s,p));var f=new CustomEvent(N,{detail:{name:u,layer:this.layer},bubbles:!0});this.dispatchEvent(f)},e.parseTemplateAttributes=function(t){return[].concat(t.matchAll(/{(.*?)}/g)).map(function(t){return t[1]})},e}(z),rt=/*#__PURE__*/function(t){function e(){return t.call(this)||this}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this.getAttribute("bounds");null!==t&&this.dispatchEvent(this.getEvent(J,JSON.parse(t)))},n.attributeChangedCallback=function(t,e,n){this.dispatchEvent(this.getEvent(M,JSON.parse(n)))},n.getEvent=function(t,e){return new CustomEvent(t,{bubbles:!0,detail:{bounds:e,method:this.getAttribute("method")||"fitBounds"}})},e}(/*#__PURE__*/A(HTMLElement));rt.observedAttributes=["bounds"];var at=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this.getAttribute("url");if(null!==t){var e=this.getAttribute("bounds");if(null!==e){var n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||""},r=this.closest("l-pane");null!==r&&(n.pane=r.getAttribute("name")),this.layer=a(t,JSON.parse(e),n),this.dispatchEvent(new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}}))}else console.warn("attribute 'bounds' not set")}else console.warn("attribute 'url' not set")},n.attributeChangedCallback=function(t,e,n){null!==this.layer&&("url"===t?this.layer.setUrl(n):"bounds"===t?this.layer.setBounds(JSON.parse(n)):"opacity"===t&&this.layer.setOpacity(parseFloat(n)))},e}(z);at.observedAttributes=["url","bounds","opacity"];var it=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){var t=JSON.parse(this.getAttribute("url")),e=JSON.parse(this.getAttribute("bounds")),n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||"",autoplay:!0,muted:!0,playsInline:!0},r=i(t,e,n);this.dispatchEvent(new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:r}}))},e}(z),ot=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("geojson"),e={},n=this.closest("l-pane");null!==n&&(e.pane=n.getAttribute("name")),null!==t&&(this.layer=o(JSON.parse(t),e),this.dispatchEvent(new CustomEvent(N,{bubbles:!0,cancelable:!0,detail:{layer:this.layer}})))},e}(/*#__PURE__*/A(HTMLElement)),lt=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},st=["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"],ut=["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"],ct=["cross-origin"],pt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){this.icon=l(this._parseOptions());var t=new CustomEvent(T,{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(t)},n.attributeChangedCallback=function(t,n,r){if(-1!==e.observedAttributes.indexOf(t)&&null!==this.icon){var a={};-1!==st.indexOf(t)?a[lt(t)]=r:-1!==ct.indexOf(t)?a[lt(t)]="true"===r.toLowerCase():a[lt(t)]=JSON.parse(r),this.icon=l(E({},this.icon.options,a));var i=new CustomEvent(T,{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(i)}},n._parseOptions=function(){var t={};st.forEach(function(e){t[lt(e)]=W(Z(e))}),ut.forEach(function(e){t[lt(e)]=D(W(Z(e)),G($()))}),t.crossOrigin=D(W(Z("cross-origin")),G(function(t){return E({},t,{value:"true"===t.value.toLowerCase()})}));var e=R(t);return U(e,this)},e}(/*#__PURE__*/A(HTMLElement));pt.observedAttributes=[].concat(st,ut,ct);var ft=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t={html:this.innerHTML},e=this.getAttribute("class-name");null!==e&&(t.className=e),this.icon=s(t),this.dispatchEvent(new CustomEvent(T,{bubbles:!0,cancelable:!0,detail:{icon:this.icon}}))},e}(/*#__PURE__*/A(HTMLElement)),bt=/*#__PURE__*/function(t){function e(){var e,n;return(n=t.call(this)||this).tooltip=u({permanent:n.hasAttribute("permanent"),direction:null!=(e=n.getAttribute("direction"))?e:"auto"}),n}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=new CustomEvent(P,{cancelable:!0,bubbles:!0,detail:{tooltip:this.tooltip}});this.dispatchEvent(t)},n.attributeChangedCallback=function(t,e,n){"content"===t&&this.tooltip.setContent(n)},e}(/*#__PURE__*/A(HTMLElement));bt.observedAttributes=["content","permanent","direction"];var ht=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.dispatchEvent(new CustomEvent(_,{bubbles:!0,cancelable:!0,detail:{name:this.getAttribute("name")}}))},e}(/*#__PURE__*/A(HTMLElement)),vt=function(t){switch(t){case"circle":return[dt("latLng","latlng",null)];case"rectangle":return[dt("latLngBounds","latlngbounds",null)];case"polygon":case"polyline":return[dt("latLngs","latlng",null)]}},dt=function(t,e,n){return{camel:t,kebab:(r=t,r.split("").map(function(t,e){return t.toUpperCase()===t?(0!==e?"-":"")+t.toLowerCase():t}).join("")),parser:mt(e),defaultValue:n};var r},mt=function(t){switch(t.toLowerCase()){case"boolean":return function(t){return"true"===t};case"number":return parseFloat;case"latlng":case"latlngbounds":return JSON.parse;default:return function(t){return t}}},yt=function(t){var e={circle:[dt("radius","number",null)],path:[dt("stroke","boolean",!0),dt("color","string","#3388ff"),dt("weight","number",3),dt("opacity","number",1),dt("lineCap","string","round"),dt("lineJoin","string","round"),dt("dashArray","string",null),dt("dashOffset","string",null),dt("fill","boolean",!0),dt("fillColor","string","#3388ff"),dt("fillOpacity","number",.2)],polyline:[dt("smoothFactor","number",1),dt("noClip","boolean",!1)],polygon:[],rectangle:[],interactiveLayer:[dt("interactive","boolean",!0)]};return Et(t).flatMap(function(t){return e[t]})},gt={circle:["path"],polyline:["path"],polygon:["polyline"],rectangle:["polygon"],path:["interactiveLayer"],interactiveLayer:[]},Et=function(t){for(var e=t,n=[t];gt[e].length>0;){var r=gt[e][0];n.push(r),e=r}return n},Ct=function(t,e){var n={};return yt(e).forEach(function(e){t.hasAttribute(e.kebab)&&(n[e.camel]=e.parser(t.getAttribute(e.kebab)))}),n},Lt=function(t,e){var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t.addEventListener(P,function(e){null!==t.layer&&t.layer.bindTooltip(e.detail.tooltip)}),t}C(r,n);var a=r.prototype;return a.connectedCallback=function(){var n=function(t,e){return vt(e).map(function(e){var n=Z(e.kebab),r=U(n,t);return e.parser(r)})}(this,e),r=Ct(this,e);this.layer=t.apply(void 0,n.concat([r]));var a=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(a)},a.attributeChangedCallback=function(t,n,r){null!==this.layer&&function(t,e,n,r){var a=[].concat(vt(e),yt(e)).find(function(t){return t.kebab===n});if(void 0!==a){var i=a.parser(r);if(t instanceof c)switch(n){case"lat-lng":t.setLatLng(JSON.parse(r));break;case"radius":t.setRadius(parseFloat(r))}else if(t instanceof p)switch(n){case"lat-lngs":t.setLatLngs(JSON.parse(r));break;case"lat-lng-bounds":t.setBounds(JSON.parse(r))}else t instanceof f?"lat-lngs"===n&&t.setLatLngs(JSON.parse(r)):t instanceof b&&"lat-lngs"===n&&t.setLatLngs(JSON.parse(r));var o,l=yt("polyline").find(function(t){return t.kebab===n});void 0!==l&&t.setStyle(((o={})[l.camel]=i,o))}}(this.layer,e,t,r)},r}(/*#__PURE__*/A(HTMLElement));return n.observedAttributes=function(t){var e=vt(t).map(function(t){return t.kebab}),n=yt(t).map(function(t){return t.kebab});return[].concat(e,n)}(e),n};import("leaflet.markercluster").catch(function(t){console.warn("Failed to import leaflet.markercluster",t)});var wt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this,e=this.getAttribute("name"),n=this.getAttribute("icon-options");this.layer=L.markerClusterGroup({showCoverageOnHover:this.hasAttribute("show-coverage-on-hover"),iconCreateFunction:this._createIconCreateFunction(n)});var r=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer,name:e}});this.dispatchEvent(r),this.addEventListener(N,function(e){e.stopPropagation(),t.layer.addLayer(e.detail.layer)})},n._createIconCreateFunction=function(t){var e=this;if(t){var n=JSON.parse(t),r=n.size,a=n.content,i=n.className;return function(t){var n=e._callClusterFunction(t,r),o=e._callClusterFunction(t,a);return L.divIcon({html:o,className:i,iconSize:new L.Point(n,n)})}}},n._callClusterFunction=function(t,e){return Function("cluster",'"use strict";return ('+e+")")(t)},e}(z);wt.observedAttributes=["show-coverage-on-hover","icon-options"];var Ot=(customElements.define("l-map",X),customElements.define("l-pane",ht),customElements.define("l-control-layers",I),customElements.define("l-base-layers",H),customElements.define("l-overlay-layers",tt),customElements.define("l-layer-group",x),customElements.define("l-tile-layer",nt),customElements.define("l-marker-cluster-group",wt),customElements.define("l-marker",Y),customElements.define("l-popup",et),customElements.define("l-lat-lng-bounds",rt),customElements.define("l-image-overlay",at),customElements.define("l-video-overlay",it),customElements.define("l-geojson",ot),customElements.define("l-icon",pt),customElements.define("l-circle",Lt(h,"circle")),customElements.define("l-polyline",Lt(v,"polyline")),customElements.define("l-polygon",Lt(d,"polygon")),customElements.define("l-rectangle",Lt(m,"rectangle")),customElements.define("l-tooltip",bt),void customElements.define("l-div-icon",ft));export{Ot as default};
|
1
|
+
import*as t from"leaflet";import{control as e,layerGroup as n,tileLayer as r,imageOverlay as a,videoOverlay as i,geoJSON as o,icon as l,divIcon as s,tooltip as u,Circle as c,Rectangle as p,Polygon as f,Polyline as b,circle as h,polyline as v,polygon as d,rectangle as m}from"leaflet";function y(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n<e;n++)r[n]=t[n];return r}function g(){return g=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)({}).hasOwnProperty.call(n,r)&&(t[r]=n[r])}return t},g.apply(null,arguments)}function E(t){return E=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},E(t)}function C(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,A(t,e)}function w(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(w=function(){return!!t})()}function A(t,e){return A=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},A(t,e)}function O(t){var e=function(t){if("object"!=typeof t||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=typeof n)return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==typeof e?e:e+""}function k(t){var e="function"==typeof Map?new Map:void 0;return k=function(t){if(null===t||!function(t){try{return-1!==Function.toString.call(t).indexOf("[native code]")}catch(e){return"function"==typeof t}}(t))return t;if("function"!=typeof t)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(t))return e.get(t);e.set(t,n)}function n(){return function(t,e,n){if(w())return Reflect.construct.apply(null,arguments);var r=[null];r.push.apply(r,e);var a=new(t.bind.apply(t,r));return n&&A(a,n.prototype),a}(t,arguments,E(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),A(n,t)},k(t)}var N="l:layer:connected",S="l:popup:connected",T="l:icon:connected",J="l:layer:removed",M="l:latlngbounds:connected",j="l:latlngbounds:changed",P="l:tooltip:connected",_="l:pane:connected",F=function(t,e,n){if(void 0===n&&(n=!0),t.hasAttribute("on")){var r=t.getAttribute("on");null!==r&&r.split(/\s+/).forEach(function(r){null!==e&&e.on(r,function(e){t.dispatchEvent(new CustomEvent(r,{bubbles:n,detail:e}))})})}},H=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.addEventListener(N,function(t){t.detail.type="base"})},e}(/*#__PURE__*/k(HTMLElement)),I=/*#__PURE__*/function(t){function n(){return t.call(this)||this}return C(n,t),n.prototype.connectedCallback=function(){var t=e.layers({},{});this.addEventListener(N,function(e){var n=e.detail,r=n.type,a=n.name,i=n.layer;"overlay"===r?t.addOverlay(i,a):"base"===r&&t.addBaseLayer(i,a),e.preventDefault()});var n=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:t}});this.dispatchEvent(n)},n}(/*#__PURE__*/k(HTMLElement)),z=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.disconnectedCallback=function(){var t;null==(t=this.layer)||t.remove()},e}(/*#__PURE__*/k(HTMLElement)),x=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=n();this.layer=e;var r=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:e,name:t}});this.dispatchEvent(r),this.addEventListener(N,function(t){t.stopPropagation(),e.addLayer(t.detail.layer)}),new MutationObserver(function(t){t.forEach(function(t){t.removedNodes.forEach(function(t){if(t instanceof HTMLElement){var n=t.getAttribute("leaflet-id");if(null!==n){var r=e.getLayer(parseInt(n));void 0!==r&&e.removeLayer(r)}}})})}).observe(this,{childList:!0})},e}(z),B=/*#__PURE__*/function(t){function e(e){var n;return(n=t.call(this)||this).issues=[],n.name="LeafletHTMLError",n.issues=e,n}return C(e,t),n=e,(r=[{key:"message",get:function(){return JSON.stringify(this.issues,null,2)}}])&&function(t,e){for(var n=0;n<e.length;n++){var r=e[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(t,O(r.key),r)}}(n.prototype,r),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,r}(/*#__PURE__*/k(Error)),U=function(t,e){var n=t(function(t){return{status:"clean",issues:[],value:t}}(e));if("clean"!==n.status)throw new B(n.issues);return n.value},R=function(t){return function(e){for(var n=e.issues,r="clean",a={},i=0,o=Object.keys(t);i<o.length;i++){var l=o[i],s=t[l](e);"clean"!==s.status&&(r=s.status),null===s.value&&"clean"===s.status||(n=[].concat(n,s.issues),a[l]=s.value)}return{status:r,issues:n,value:a}}},V=function(){var t=[].slice.call(arguments);return function(e){for(var n=0;n<t.length&&"abort"!==(e=t[n](e)).status;n++);return e}},D=function(){var t=[].slice.call(arguments);return function(e){for(var n=0;n<t.length;n++)e=t[n](e);return e}},G=function(t){return function(e){return null===e.value?e:t(e)}},W=function(t){return function(e){return null===(e=t(e)).value?{status:"clean",issues:[],value:null}:e}},Z=function(t){return function(e){var n=e.value,r=n.getAttribute(t);return null===r?{status:"abort",issues:[].concat(e.issues,[Q(n,t)]),value:null}:g({},e,{value:r})}},$=function(){return function(t){var e;try{e=JSON.parse(t.value)}catch(e){return{status:"abort",issues:[].concat(t.issues,[K(e)]),value:null}}return g({},t,{value:e})}},q=function(t){return V.apply(void 0,[Z(t)].concat([].slice.call(arguments,1)))},K=function(t){return{code:"parse_json",message:t.message}},Q=function(t,e){return{code:"missing_attribute",message:t.tagName.toLowerCase()+" missing attribute '"+e+"'"}},X=/*#__PURE__*/function(e){function n(){var t;(t=e.call(this)||this).map=null;var r=function(e){var n=e.detail;null!==t.map&&t.map[n.method](n.bounds)};return t.addEventListener(M,r),t.addEventListener(j,r),t.addEventListener(_,function(e){t.map.createPane(e.detail.name)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof n){var e=t.target;t.removedNodes.forEach(function(t){t instanceof z&&null!==e.map&&null!==t.layer&&(e.dispatchEvent(new CustomEvent(J,{bubbles:!0,detail:{layer:t.layer}})),e.map.removeLayer(t.layer))})}})}).observe(t,{childList:!0}),t}C(n,e);var r=n.prototype;return r.connectedCallback=function(){var e,n=this;if(this.map=t.map(this,{zoomControl:this.hasAttribute("zoom-control")}),this.map.whenReady(function(){n.dispatchEvent(new CustomEvent("ready",{bubbles:!0,cancelable:!0,detail:n.map}))}),F(this,this.map),this.hasAttribute("fit-world"))this.map.fitWorld();else{var r=(e={zoom:q("zoom",function(t){var e,n=parseInt(t.value);return isNaN(n)?{status:"abort",issues:[].concat(t.issues,[(e=t.value,{code:"parse_int",message:'could not parse int given: "'+e+'"'})]),value:n}:g({},t,{value:n})}),center:q("center",$())},function(t){for(var n=t.status,r=t.issues,a={},i=0,o=Object.keys(e);i<o.length;i++){var l=o[i],s=e[l](t);"abort"===s.status&&(n="abort",r=[].concat(r,s.issues)),a[l]=s.value}return{status:n,issues:r,value:a}}),a=U(r,this);this.map.setView(a.center,a.zoom)}if(this.hasAttribute("locate")){var i=q("locate",$());this.map.locate(U(i,this))}this.addEventListener(N,function(t){n.map.addLayer(t.detail.layer)}),this.addEventListener(J,function(t){null!==n.map&&n.map.removeLayer(t.detail.layer)})},r.attributeChangedCallback=function(t,e,n){null!==this.map&&("zoom"===t?this.map.setZoom(parseInt(n)):"center"===t&&this.map.setView(JSON.parse(n)))},n}(/*#__PURE__*/k(HTMLElement));X.observedAttributes=["zoom","center","zoom-control"];var Y=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t.addEventListener(T,function(e){e.stopPropagation(),t.layer.setIcon(e.detail.icon)}),t.addEventListener(P,function(e){e.stopPropagation(),t.layer.bindTooltip(e.detail.tooltip)}),t}C(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this,n=U(q("lat-lng",$()),this),r=U(R({opacity:D(W(Z("opacity")),G(function(t){var e,n=parseFloat(t.value);return isNaN(n)?{status:"abort",issues:[].concat(t.issues,[(e=t.value,{code:"parse_float",message:'could not parse float given: "'+e+'"'})]),value:n}:g({},t,{value:n})}))}),this),a=this.closest("l-pane");if(null!==a&&(r.pane=a.getAttribute("name")),this.layer=t.marker(n,r),this.hasAttribute("icon")){var i=t.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(i)}F(this,this.layer,!1),this.setAttribute("leaflet-id",t.stamp(this.layer)),this.addEventListener(S,function(t){var n=t.detail,r=n.openPopup,a=e.layer.bindPopup(n.content);r&&a.openPopup()});var o=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(o)},r.attributeChangedCallback=function(e,n,r){null!==this.layer&&("lat-lng"===e&&this.layer.setLatLng(JSON.parse(r)),"opacity"===e&&this.layer.setOpacity(parseFloat(r)),"icon"===e&&this.layer.setIcon(t.icon(JSON.parse(r))))},n}(z);Y.observedAttributes=["lat-lng","opacity","icon"];var tt=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.addEventListener(N,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/k(HTMLElement)),et=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("content"),e=!1,n=this.getAttribute("open-popup");null!==n&&(e="false"!==n);var r=new CustomEvent(S,{cancelable:!0,bubbles:!0,detail:{content:t,openPopup:e}});this.dispatchEvent(r)},e}(/*#__PURE__*/k(HTMLElement)),nt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){for(var t,n=U(Z("url-template"),this),a={},i=function(t){var e="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(e)return(e=e.call(t)).next.bind(e);if(Array.isArray(t)||(e=function(t,e){if(t){if("string"==typeof t)return y(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?y(t,e):void 0}}(t))){e&&(t=e);var n=0;return function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(e.parseTemplateAttributes(n));!(t=i()).done;){var o=t.value,l=this.getAttribute(o);null!==l&&(a[o]=l)}var s={};"l-pane"===this.parentElement.tagName.toLowerCase()&&(s.pane=this.parentElement.getAttribute("name"));var u=this.getAttribute("name"),c=R({attribution:W(Z("attribution")),errorTileUrl:W(Z("error-tile-url"))}),p=U(c,this);this.layer=r(n,g({},a,s,p));var f=new CustomEvent(N,{detail:{name:u,layer:this.layer},bubbles:!0});this.dispatchEvent(f)},e.parseTemplateAttributes=function(t){return[].concat(t.matchAll(/{(.*?)}/g)).map(function(t){return t[1]})},e}(z),rt=/*#__PURE__*/function(t){function e(){return t.call(this)||this}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this.getAttribute("bounds");null!==t&&this.dispatchEvent(this.getEvent(M,JSON.parse(t)))},n.attributeChangedCallback=function(t,e,n){this.dispatchEvent(this.getEvent(j,JSON.parse(n)))},n.getEvent=function(t,e){return new CustomEvent(t,{bubbles:!0,detail:{bounds:e,method:this.getAttribute("method")||"fitBounds"}})},e}(/*#__PURE__*/k(HTMLElement));rt.observedAttributes=["bounds"];var at=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this.getAttribute("url");if(null!==t){var e=this.getAttribute("bounds");if(null!==e){var n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||""},r=this.closest("l-pane");null!==r&&(n.pane=r.getAttribute("name")),this.layer=a(t,JSON.parse(e),n),this.dispatchEvent(new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}}))}else console.warn("attribute 'bounds' not set")}else console.warn("attribute 'url' not set")},n.attributeChangedCallback=function(t,e,n){null!==this.layer&&("url"===t?this.layer.setUrl(n):"bounds"===t?this.layer.setBounds(JSON.parse(n)):"opacity"===t&&this.layer.setOpacity(parseFloat(n)))},e}(z);at.observedAttributes=["url","bounds","opacity"];var it=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){var t=JSON.parse(this.getAttribute("url")),e=JSON.parse(this.getAttribute("bounds")),n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||"",autoplay:!0,muted:!0,playsInline:!0},r=i(t,e,n);this.dispatchEvent(new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:r}}))},e}(z),ot=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("geojson"),e={},n=this.closest("l-pane");null!==n&&(e.pane=n.getAttribute("name")),null!==t&&(this.layer=o(JSON.parse(t),e),this.dispatchEvent(new CustomEvent(N,{bubbles:!0,cancelable:!0,detail:{layer:this.layer}})))},e}(/*#__PURE__*/k(HTMLElement)),lt=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},st=["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"],ut=["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"],ct=["cross-origin"],pt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){this.icon=l(this._parseOptions());var t=new CustomEvent(T,{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(t)},n.attributeChangedCallback=function(t,n,r){if(-1!==e.observedAttributes.indexOf(t)&&null!==this.icon){var a={};-1!==st.indexOf(t)?a[lt(t)]=r:-1!==ct.indexOf(t)?a[lt(t)]="true"===r.toLowerCase():a[lt(t)]=JSON.parse(r),this.icon=l(g({},this.icon.options,a));var i=new CustomEvent(T,{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(i)}},n._parseOptions=function(){var t={};st.forEach(function(e){t[lt(e)]=W(Z(e))}),ut.forEach(function(e){t[lt(e)]=D(W(Z(e)),G($()))}),t.crossOrigin=D(W(Z("cross-origin")),G(function(t){return g({},t,{value:"true"===t.value.toLowerCase()})}));var e=R(t);return U(e,this)},e}(/*#__PURE__*/k(HTMLElement));pt.observedAttributes=[].concat(st,ut,ct);var ft=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}return C(e,t),e.prototype.connectedCallback=function(){var t={html:this.innerHTML},e=this.getAttribute("class-name");null!==e&&(t.className=e),this.icon=s(t),this.dispatchEvent(new CustomEvent(T,{bubbles:!0,cancelable:!0,detail:{icon:this.icon}}))},e}(/*#__PURE__*/k(HTMLElement)),bt=/*#__PURE__*/function(t){function e(){var e,n;return(n=t.call(this)||this).tooltip=u({permanent:n.hasAttribute("permanent"),direction:null!=(e=n.getAttribute("direction"))?e:"auto"}),n}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=new CustomEvent(P,{cancelable:!0,bubbles:!0,detail:{tooltip:this.tooltip}});this.dispatchEvent(t)},n.attributeChangedCallback=function(t,e,n){"content"===t&&this.tooltip.setContent(n)},e}(/*#__PURE__*/k(HTMLElement));bt.observedAttributes=["content","permanent","direction"];var ht=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return C(e,t),e.prototype.connectedCallback=function(){this.dispatchEvent(new CustomEvent(_,{bubbles:!0,cancelable:!0,detail:{name:this.getAttribute("name")}}))},e}(/*#__PURE__*/k(HTMLElement)),vt=function(t){switch(t){case"circle":return[dt("latLng","latlng",null)];case"rectangle":return[dt("latLngBounds","latlngbounds",null)];case"polygon":case"polyline":return[dt("latLngs","latlng",null)]}},dt=function(t,e,n){return{camel:t,kebab:(r=t,r.split("").map(function(t,e){return t.toUpperCase()===t?(0!==e?"-":"")+t.toLowerCase():t}).join("")),parser:mt(e),defaultValue:n};var r},mt=function(t){switch(t.toLowerCase()){case"boolean":return function(t){return"true"===t};case"number":return parseFloat;case"latlng":case"latlngbounds":return JSON.parse;default:return function(t){return t}}},yt=function(t){var e={circle:[dt("radius","number",null)],path:[dt("stroke","boolean",!0),dt("color","string","#3388ff"),dt("weight","number",3),dt("opacity","number",1),dt("lineCap","string","round"),dt("lineJoin","string","round"),dt("dashArray","string",null),dt("dashOffset","string",null),dt("fill","boolean",!0),dt("fillColor","string","#3388ff"),dt("fillOpacity","number",.2)],polyline:[dt("smoothFactor","number",1),dt("noClip","boolean",!1)],polygon:[],rectangle:[],interactiveLayer:[dt("interactive","boolean",!0)]};return Et(t).flatMap(function(t){return e[t]})},gt={circle:["path"],polyline:["path"],polygon:["polyline"],rectangle:["polygon"],path:["interactiveLayer"],interactiveLayer:[]},Et=function(t){for(var e=t,n=[t];gt[e].length>0;){var r=gt[e][0];n.push(r),e=r}return n},Ct=function(t,e){var n={};return yt(e).forEach(function(e){t.hasAttribute(e.kebab)&&(n[e.camel]=e.parser(t.getAttribute(e.kebab)))}),n},Lt=function(t,e){var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t.addEventListener(P,function(e){null!==t.layer&&t.layer.bindTooltip(e.detail.tooltip)}),t}C(r,n);var a=r.prototype;return a.connectedCallback=function(){var n=function(t,e){return vt(e).map(function(e){var n=Z(e.kebab),r=U(n,t);return e.parser(r)})}(this,e),r=Ct(this,e);this.layer=t.apply(void 0,n.concat([r]));var a=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(a)},a.attributeChangedCallback=function(t,n,r){null!==this.layer&&function(t,e,n,r){var a=[].concat(vt(e),yt(e)).find(function(t){return t.kebab===n});if(void 0!==a){var i=a.parser(r);if(t instanceof c)switch(n){case"lat-lng":t.setLatLng(JSON.parse(r));break;case"radius":t.setRadius(parseFloat(r))}else if(t instanceof p)switch(n){case"lat-lngs":t.setLatLngs(JSON.parse(r));break;case"lat-lng-bounds":t.setBounds(JSON.parse(r))}else t instanceof f?"lat-lngs"===n&&t.setLatLngs(JSON.parse(r)):t instanceof b&&"lat-lngs"===n&&t.setLatLngs(JSON.parse(r));var o,l=yt("polyline").find(function(t){return t.kebab===n});void 0!==l&&t.setStyle(((o={})[l.camel]=i,o))}}(this.layer,e,t,r)},r}(/*#__PURE__*/k(HTMLElement));return n.observedAttributes=function(t){var e=vt(t).map(function(t){return t.kebab}),n=yt(t).map(function(t){return t.kebab});return[].concat(e,n)}(e),n};import("leaflet.markercluster").catch(function(t){console.warn("Failed to import leaflet.markercluster",t)});var wt=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}C(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this,e=this.getAttribute("name"),n=this.getAttribute("icon-options");this.layer=L.markerClusterGroup({showCoverageOnHover:this.hasAttribute("show-coverage-on-hover"),iconCreateFunction:this._createIconCreateFunction(n)});var r=new CustomEvent(N,{cancelable:!0,bubbles:!0,detail:{layer:this.layer,name:e}});this.dispatchEvent(r),this.addEventListener(N,function(e){e.stopPropagation(),t.layer.addLayer(e.detail.layer)})},n._createIconCreateFunction=function(t){var e=this;if(t){var n=JSON.parse(t),r=n.size,a=n.content,i=n.className;return function(t){var n=e._callClusterFunction(t,r),o=e._callClusterFunction(t,a);return L.divIcon({html:o,className:i,iconSize:new L.Point(n,n)})}}},n._callClusterFunction=function(t,e){return Function("cluster",'"use strict";return ('+e+")")(t)},e}(z);wt.observedAttributes=["show-coverage-on-hover","icon-options"];var At=(customElements.define("l-map",X),customElements.define("l-pane",ht),customElements.define("l-control-layers",I),customElements.define("l-base-layers",H),customElements.define("l-overlay-layers",tt),customElements.define("l-layer-group",x),customElements.define("l-tile-layer",nt),customElements.define("l-marker-cluster-group",wt),customElements.define("l-marker",Y),customElements.define("l-popup",et),customElements.define("l-lat-lng-bounds",rt),customElements.define("l-image-overlay",at),customElements.define("l-video-overlay",it),customElements.define("l-geojson",ot),customElements.define("l-icon",pt),customElements.define("l-circle",Lt(h,"circle")),customElements.define("l-polyline",Lt(v,"polyline")),customElements.define("l-polygon",Lt(d,"polygon")),customElements.define("l-rectangle",Lt(m,"rectangle")),customElements.define("l-tooltip",bt),void customElements.define("l-div-icon",ft));export{At as default};
|
2
2
|
//# sourceMappingURL=leaflet-html.js.map
|
package/dist/leaflet-html.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"leaflet-html.js","sources":["../src/events.js","../src/l-base-layers.js","../src/l-control-layers.js","../src/l-layer.js","../src/l-layer-group.js","../src/parse.js","../src/l-map.js","../src/l-marker.js","../src/l-overlay-layers.js","../src/l-popup.js","../src/l-tile-layer.js","../src/l-lat-lng-bounds.js","../src/l-image-overlay.js","../src/l-video-overlay.js","../src/l-geojson.js","../src/util.js","../src/l-icon.js","../src/l-div-icon.js","../src/l-tooltip.js","../src/l-pane.js","../src/generator.js","../src/l-marker-cluster-group.js","../src/index.js"],"sourcesContent":["import { Evented } from \"leaflet\";\n\n// NOTE: These event keys are part of the public API of leaflet-html\nexport const layerConnected = \"l:layer:connected\";\nexport const popupConnected = \"l:popup:connected\";\nexport const iconConnected = \"l:icon:connected\";\nexport const layerRemoved = \"l:layer:removed\";\nexport const latLngBoundsConnected = \"l:latlngbounds:connected\";\nexport const latLngBoundsChanged = \"l:latlngbounds:changed\";\nexport const tooltipConnected = \"l:tooltip:connected\";\nexport const paneConnected = \"l:pane:connected\";\n\n/**\n * @param {HTMLElement} el\n * @param {Evented} evented\n * @param bubble determines whether events should bubble (defaults to true)\n */\nexport const connectLeafletEvents = (el, evented, bubble = true) => {\n if (el.hasAttribute(\"on\")) {\n const on = el.getAttribute(\"on\");\n if (on !== null) {\n on.split(/\\s+/).forEach((eventName) => {\n if (evented !== null) {\n evented.on(eventName, (e) => {\n el.dispatchEvent(\n new CustomEvent(eventName, { bubbles: bubble, detail: e })\n );\n });\n }\n });\n }\n }\n}\n","// @ts-check\nimport { layerConnected } from \"./events.js\";\n\nclass LBaseLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(layerConnected, (ev) => {\n ev.detail[\"type\"] = \"base\";\n });\n }\n}\n\nexport default LBaseLayers;\n","// @ts-check\n/** @typedef {import(\"leaflet\").Layer} Layer */\nimport { control } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\n\nclass LControlLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n /** @type {{ [key: string]: Layer }} */\n const base = {};\n /** @type {{ [key: string]: Layer }} */\n const overlay = {};\n const controlLayers = control.layers(base, overlay);\n\n this.addEventListener(layerConnected, (ev) => {\n const { type, name, layer } = ev.detail;\n if (type === \"overlay\") {\n controlLayers.addOverlay(layer, name);\n } else if (type === \"base\") {\n controlLayers.addBaseLayer(layer, name);\n }\n ev.preventDefault();\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: controlLayers,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LControlLayers;\n","class LLayer extends HTMLElement {\n constructor() {\n super()\n this.layer = null\n }\n\n disconnectedCallback() {\n this.layer?.remove();\n }\n}\n\nexport default LLayer\n","// @ts-check\nimport { layerGroup } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LLayerGroup extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const group = layerGroup();\n this.layer = group;\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: group,\n name,\n },\n });\n this.dispatchEvent(event);\n\n this.addEventListener(layerConnected, (ev) => {\n ev.stopPropagation();\n group.addLayer(ev.detail.layer);\n });\n\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n mutation.removedNodes.forEach((node) => {\n if (node instanceof HTMLElement) {\n const leafletId = node.getAttribute(\"leaflet-id\");\n if (leafletId !== null) {\n const layer = group.getLayer(parseInt(leafletId));\n if (typeof layer !== \"undefined\") {\n group.removeLayer(layer);\n }\n }\n }\n });\n });\n });\n observer.observe(this, { childList: true });\n }\n}\n\nexport default LLayerGroup;\n","/// <reference path=\"./parser.d.ts\" />\n \nexport class LeafletHTMLError extends Error {\n /** @type {Issue[]} */\n issues = [];\n\n /**\n * @param {Issue[]} issues\n */\n constructor(issues) {\n super();\n this.name = \"LeafletHTMLError\";\n this.issues = issues;\n }\n\n get message() {\n return JSON.stringify(this.issues, null, 2);\n }\n}\n\n/**\n * @template T\n * @param {T} value\n * @returns {Context<T>}\n */\nconst wrap = (value) => {\n return {\n status: \"clean\",\n issues: [],\n value,\n };\n};\n\n/**\n * @template T\n * @param {Context<T>} value\n * @returns {T}\n */\nconst unwrap = ({ value }) => value;\n\n/**\n * @template S\n * @template T\n * @param {Parser<T, S>} schema\n * @param {T} value\n * @returns {S}\n */\nexport const parse = (schema, value) => {\n const result = schema(wrap(value));\n if (result.status !== \"clean\") {\n throw new LeafletHTMLError(result.issues);\n } else {\n return unwrap(result);\n }\n};\n\n/**\n * @template S\n * @template T\n * @param {Parser<T, S>} schema\n * @param {T} value\n * @returns {Context<S>}\n */\nexport const safeParse = (schema, value) => schema(wrap(value));\n\n/**\n * @param {Object} obj\n * @returns {(ctx: Context<Object>) => Context<Object>}\n */\nexport const object = (obj) => (ctx) => {\n let { status, issues } = ctx;\n const result = {};\n for (const key of Object.keys(obj)) {\n if (key in ctx.value) {\n result[key] = obj[key](wrap(ctx.value[key])).value;\n } else {\n status = \"abort\";\n issues = [...issues, missingKeyIssue(key)];\n }\n }\n return { status, issues, value: result };\n};\n\n// CONNECTORS\n\n/**\n * @template T\n * @param {Object} obj\n * @returns {(ctx: Context<T>) => Context<Object>}\n */\nexport const distribute = (obj) => (ctx) => {\n let { status, issues } = ctx;\n const result = {};\n for (const key of Object.keys(obj)) {\n let localCtx = obj[key](ctx);\n if (localCtx.status === \"abort\") {\n status = \"abort\";\n issues = [...issues, ...localCtx.issues];\n }\n result[key] = localCtx.value;\n }\n return { status, issues, value: result };\n};\n\nexport const partial = (obj) => (ctx) => {\n let { issues } = ctx;\n let status = \"clean\"\n const result = {};\n for (const key of Object.keys(obj)) {\n let localCtx = obj[key](ctx);\n if (localCtx.status !== \"clean\") {\n status = localCtx.status\n }\n \n if ((localCtx.value === null) && (localCtx.status === \"clean\")) {\n continue\n } else {\n issues = [...issues, ...localCtx.issues];\n result[key] = localCtx.value;\n }\n }\n return { status, issues, value: result };\n};\n\nexport const pipe =\n (...parsers) =>\n (ctx) => {\n for (let i = 0; i < parsers.length; i++) {\n ctx = parsers[i](ctx);\n if (ctx.status === \"abort\") {\n break;\n }\n }\n return ctx;\n };\n\nexport const chain = (...parsers) => (ctx) => {\n for (let i=0; i<parsers.length; i++) {\n ctx = parsers[i](ctx)\n }\n return ctx\n}\n\n\n// PRIMITIVES\nexport const nullable = (parser) => (ctx) => {\n if (ctx.value === null) {\n return ctx\n }\n return parser(ctx)\n}\n\nexport const optional = (parser) => (ctx) => {\n ctx = parser(ctx)\n if (ctx.value === null) {\n return {status: \"clean\", issues: [], value: null}\n } else {\n return ctx\n }\n}\n\n/**\n * @param {string} attributeName\n * @returns {Parser<HTMLElement, string>}\n */\nexport const htmlAttribute = (attributeName) => (ctx) => {\n const el = ctx.value;\n let result = el.getAttribute(attributeName);\n if (result === null) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, htmlAttributeIssue(el, attributeName)],\n value: null,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const int = () => (ctx) => {\n let result = parseInt(ctx.value);\n if (isNaN(result)) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, intIssue(ctx.value)],\n value: result,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const float = () => (ctx) => {\n let result = parseFloat(ctx.value);\n if (isNaN(result)) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, floatIssue(ctx.value)],\n value: result,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const json = () => (ctx) => {\n let result;\n try {\n result = JSON.parse(ctx.value);\n } catch (e) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, jsonIssue(e)],\n value: null,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<boolean>}\n */\nexport const bool = () => (ctx) => {\n return { ...ctx, value: ctx.value.toLowerCase() === \"true\" };\n};\n\n/**\n * @template T\n * @template S\n * @param {string} key\n * @param {Parser<T, S>[]} fns\n */\nexport const option = (key, ...fns) => pipe(htmlAttribute(key), ...fns);\n\n\n// ISSUES\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const intIssue = (value) => {\n return {\n code: \"parse_int\",\n message: `could not parse int given: \"${value}\"`,\n };\n};\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const floatIssue = (value) => {\n return {\n code: \"parse_float\",\n message: `could not parse float given: \"${value}\"`,\n };\n};\n\n/**\n * @param {SyntaxError} e\n * @returns {Issue}\n */\nexport const jsonIssue = (e) => {\n return {\n code: \"parse_json\",\n message: e.message,\n };\n};\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const missingKeyIssue = (value) => {\n return {\n code: \"missing_key\",\n message: `key not found: ${value}`,\n };\n};\n\n/**\n * @param {HTMLElement} el\n * @param {string} attributeName\n * @returns {Issue}\n */\nexport const htmlAttributeIssue = (el, attributeName) => {\n return {\n code: \"missing_attribute\",\n message: `${el.tagName.toLowerCase()} missing attribute '${attributeName}'`,\n };\n};\n","// @ts-check\nimport * as L from \"leaflet\";\nimport { layerRemoved, layerConnected, latLngBoundsConnected, latLngBoundsChanged, paneConnected, connectLeafletEvents } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport { distribute, int, json, option, parse } from \"./parse.js\";\n\nclass LMap extends HTMLElement {\n static observedAttributes = [\"zoom\", \"center\", \"zoom-control\"];\n\n constructor() {\n super();\n\n this.map = null;\n\n // Handle <l-lat-lng-bounds> connection and modification(s)\n const boundsListener = (ev) => {\n const { bounds, method } = ev.detail;\n if (this.map !== null) {\n this.map[method](bounds);\n }\n };\n this.addEventListener(latLngBoundsConnected, boundsListener);\n this.addEventListener(latLngBoundsChanged, boundsListener);\n\n // Observe l-pane\n this.addEventListener(paneConnected, (ev) => {\n const { name } = ev.detail\n this.map.createPane(name)\n })\n\n // Observe removed l-tile-layers\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n if (mutation.target instanceof LMap) {\n const el = mutation.target;\n mutation.removedNodes.forEach((node) => {\n if (node instanceof LLayer) {\n if (el.map !== null && node.layer !== null) {\n // Notify listeners of layer removal\n el.dispatchEvent(new CustomEvent(layerRemoved, {\n bubbles: true,\n detail: {\n layer: node.layer\n }\n }))\n el.map.removeLayer(node.layer);\n }\n }\n });\n }\n });\n });\n observer.observe(this, { childList: true });\n }\n\n connectedCallback() {\n this.map = L.map(this, { zoomControl: this.hasAttribute(\"zoom-control\") });\n\n // Allow listeners to know when the map is \"ready\"\n this.map.whenReady(() => {\n this.dispatchEvent(\n new CustomEvent(\"ready\", {\n bubbles: true,\n cancelable: true,\n detail: this.map\n })\n )\n })\n\n // Connect Leaflet events\n connectLeafletEvents(this, this.map);\n\n if (this.hasAttribute(\"fit-world\")) {\n this.map.fitWorld();\n } else {\n const schema = distribute({\n zoom: option(\"zoom\", int()),\n center: option(\"center\", json())\n })\n const { zoom, center } = parse(schema, this)\n this.map.setView(center, zoom);\n }\n\n if (this.hasAttribute(\"locate\")) {\n const schema = option(\"locate\", json())\n this.map.locate(parse(schema, this));\n }\n\n this.addEventListener(layerConnected, (ev) => {\n const layer = ev.detail.layer;\n this.map.addLayer(layer);\n });\n\n this.addEventListener(layerRemoved, (ev) => {\n if (this.map !== null) {\n this.map.removeLayer(ev.detail.layer);\n }\n });\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.map !== null) {\n if (name === \"zoom\") {\n this.map.setZoom(parseInt(newValue));\n } else if (name === \"center\") {\n this.map.setView(JSON.parse(newValue));\n }\n }\n }\n}\n\nexport default LMap;\n","import * as L from \"leaflet\";\nimport {\n layerConnected,\n popupConnected,\n iconConnected,\n tooltipConnected,\n connectLeafletEvents,\n} from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport {\n chain,\n float,\n json,\n option,\n optional,\n htmlAttribute,\n parse,\n partial,\n nullable,\n} from \"./parse.js\";\n\nclass LMarker extends LLayer {\n static observedAttributes = [\"lat-lng\", \"opacity\", \"icon\"];\n\n constructor() {\n super();\n this.layer = null;\n\n // Icon connected\n this.addEventListener(iconConnected, (ev) => {\n ev.stopPropagation();\n this.layer.setIcon(ev.detail.icon);\n });\n\n // Tooltip connected\n this.addEventListener(tooltipConnected, (ev) => {\n ev.stopPropagation();\n this.layer.bindTooltip(ev.detail.tooltip);\n });\n }\n\n connectedCallback() {\n // Experimental parse/validate API\n const latLng = parse(option(\"lat-lng\", json()), this);\n const options = parse(\n partial({\n opacity: chain(optional(htmlAttribute(\"opacity\")), nullable(float())),\n }),\n this\n );\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n this.layer = L.marker(latLng, options);\n\n if (this.hasAttribute(\"icon\")) {\n const icon = L.icon(JSON.parse(this.getAttribute(\"icon\")));\n this.layer.setIcon(icon);\n }\n\n // Connect Leaflet events\n connectLeafletEvents(this, this.layer, false);\n\n this.setAttribute(\"leaflet-id\", L.stamp(this.layer));\n\n this.addEventListener(popupConnected, (ev) => {\n const { content, openPopup } = ev.detail;\n const popup = this.layer.bindPopup(content);\n if (openPopup) {\n popup.openPopup();\n }\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"lat-lng\") {\n this.layer.setLatLng(JSON.parse(newValue));\n }\n if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n if (name === \"icon\") {\n this.layer.setIcon(L.icon(JSON.parse(newValue)));\n }\n }\n }\n}\n\nexport default LMarker;\n","// @ts-check\nimport { layerConnected } from \"./events.js\";\n\nclass LOverlayLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(layerConnected, (ev) => {\n ev.detail[\"type\"] = \"overlay\";\n });\n }\n}\n\nexport default LOverlayLayers;\n","// @ts-check\nimport { popupConnected } from \"./events.js\";\n\nclass LPopup extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const content = this.getAttribute(\"content\");\n let openPopup = false;\n const openPopupAttribute = this.getAttribute(\"open-popup\");\n if (openPopupAttribute !== null) {\n openPopup = openPopupAttribute !== \"false\";\n }\n const event = new CustomEvent(popupConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n content,\n openPopup,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LPopup;\n","// @ts-check\nimport { tileLayer } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport { htmlAttribute, optional, parse, partial } from \"./parse.js\";\n\nclass LTileLayer extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const urlTemplate = parse(htmlAttribute(\"url-template\"), this)\n \n // Template attributes\n const urlAttributes = LTileLayer.parseTemplateAttributes(urlTemplate)\n const templateOptions = {}\n for (const attribute of urlAttributes) {\n const value = this.getAttribute(attribute)\n if (value !== null) {\n templateOptions[attribute] = value\n }\n }\n\n // Pane options\n const paneOptions = {}\n // Support <l-pane> parent element\n if (this.parentElement.tagName.toLowerCase() === \"l-pane\") {\n paneOptions[\"pane\"] = this.parentElement.getAttribute(\"name\")\n }\n \n // Options\n const name = this.getAttribute(\"name\");\n const schema = partial({\n attribution: optional(htmlAttribute(\"attribution\")),\n errorTileUrl: optional(htmlAttribute(\"error-tile-url\"))\n })\n const options = parse(schema, this)\n this.layer = tileLayer(urlTemplate, { ...templateOptions, ...paneOptions, ...options });\n const event = new CustomEvent(layerConnected, {\n detail: { name, layer: this.layer },\n bubbles: true,\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} urlTemplate\n * @returns {string[]}\n */\n static parseTemplateAttributes(urlTemplate) {\n const regex = /{(.*?)}/g\n return [...urlTemplate.matchAll(regex)].map(match => match[1])\n }\n}\n\nexport default LTileLayer;\n","// @ts-check\nimport { LatLngBounds } from \"leaflet\";\nimport { latLngBoundsChanged, latLngBoundsConnected } from \"./events\"; \n\nclass LLatLngBounds extends HTMLElement {\n static observedAttributes = [\"bounds\"];\n\n constructor() {\n super();\n }\n\n connectedCallback() {\n let value = this.getAttribute(\"bounds\")\n if (value !== null) {\n this.dispatchEvent(this.getEvent(latLngBoundsConnected, JSON.parse(value)))\n }\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n this.dispatchEvent(this.getEvent(latLngBoundsChanged, JSON.parse(newValue)));\n }\n\n /**\n * @param {LatLngBounds} bounds\n */\n getEvent(key, bounds) {\n return new CustomEvent(key, {\n bubbles: true,\n detail: {\n bounds,\n method: this.getAttribute(\"method\") || \"fitBounds\",\n },\n });\n }\n}\n\nexport default LLatLngBounds;\n","// @ts-check\nimport { imageOverlay } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LImageOverlay extends LLayer {\n static observedAttributes = [\"url\", \"bounds\", \"opacity\"];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const url = this.getAttribute(\"url\");\n if (url === null) {\n console.warn(\"attribute 'url' not set\");\n return;\n }\n let bounds = this.getAttribute(\"bounds\");\n if (bounds === null) {\n console.warn(\"attribute 'bounds' not set\");\n return;\n }\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n };\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n this.layer = imageOverlay(url, JSON.parse(bounds), options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n })\n );\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"url\") {\n this.layer.setUrl(newValue);\n } else if (name === \"bounds\") {\n this.layer.setBounds(JSON.parse(newValue));\n } else if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n }\n }\n}\n\nexport default LImageOverlay;\n","// @ts-check\nimport { videoOverlay } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LVideoOverlay extends LLayer {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const url = JSON.parse(this.getAttribute(\"url\"));\n const bounds = JSON.parse(this.getAttribute(\"bounds\"));\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n autoplay: true,\n muted: true,\n playsInline: true,\n };\n const layer = videoOverlay(url, bounds, options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer,\n },\n }),\n );\n }\n}\n\nexport default LVideoOverlay;\n","// @ts-check\nimport { geoJSON } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\n\nclass LGeoJSON extends HTMLElement {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const value = this.getAttribute(\"geojson\");\n const options = {};\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n if (value !== null) {\n this.layer = geoJSON(JSON.parse(value), options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n layer: this.layer,\n },\n })\n );\n }\n }\n}\n\nexport default LGeoJSON;\n","// Utility functions\nexport const kebabToCamel = (kebab) => kebab.replace(/-./g, (x) => x[1].toUpperCase());\nexport const camelToKebab = (s) => {\n return s.split('').map((letter, idx) => {\n return letter.toUpperCase() === letter\n ? `${idx !== 0 ? '-' : ''}${letter.toLowerCase()}`\n : letter;\n }).join('');\n}\n\n","import { icon } from \"leaflet\";\nimport { iconConnected } from \"./events.js\";\nimport {\n bool,\n chain,\n htmlAttribute,\n json,\n nullable,\n optional,\n parse,\n partial,\n} from \"./parse.js\";\nimport { kebabToCamel } from \"./util.js\";\n\nconst STRING_ATTRIBUTES = [\n \"icon-url\",\n \"icon-retina-url\",\n \"shadow-url\",\n \"shadow-retina-url\",\n \"class-name\",\n];\n\nconst JSON_ATTRIBUTES = [\n \"icon-anchor\",\n \"icon-size\",\n \"shadow-anchor\",\n \"shadow-size\",\n \"tooltip-anchor\",\n \"popup-anchor\",\n];\n\nconst BOOL_ATTRIBUTES = [\"cross-origin\"];\n\nclass LIcon extends HTMLElement {\n static observedAttributes = [\n ...STRING_ATTRIBUTES,\n ...JSON_ATTRIBUTES,\n ...BOOL_ATTRIBUTES,\n ];\n\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n this.icon = icon(this._parseOptions());\n\n const event = new CustomEvent(iconConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} name\n * @param {string} _\n * @param {string} newValue\n */\n attributeChangedCallback(name, _, newValue) {\n if (LIcon.observedAttributes.indexOf(name) !== -1) {\n if (this.icon !== null) {\n let update = {};\n if (STRING_ATTRIBUTES.indexOf(name) !== -1) {\n update[kebabToCamel(name)] = newValue;\n } else if (BOOL_ATTRIBUTES.indexOf(name) !== -1) {\n update[kebabToCamel(name)] = newValue.toLowerCase() === \"true\";\n } else {\n update[kebabToCamel(name)] = JSON.parse(newValue);\n }\n this.icon = icon({\n ...this.icon.options,\n ...update,\n });\n const event = new CustomEvent(iconConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n }\n }\n\n /**\n * @returns {import(\"leaflet\").IconOptions}\n */\n _parseOptions() {\n // Experimental parse/validate API\n const obj = {};\n STRING_ATTRIBUTES.forEach((key) => {\n obj[kebabToCamel(key)] = optional(htmlAttribute(key));\n });\n JSON_ATTRIBUTES.forEach((key) => {\n obj[kebabToCamel(key)] = chain(\n optional(htmlAttribute(key)),\n nullable(json())\n );\n });\n obj[\"crossOrigin\"] = chain(\n optional(htmlAttribute(\"cross-origin\")),\n nullable(bool())\n );\n const schema = partial(obj);\n return parse(schema, this);\n }\n}\n\nexport default LIcon;\n","import { divIcon } from \"leaflet\";\nimport { iconConnected } from \"./events\";\n\nexport default class CustomElement extends HTMLElement {\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n // Leaflet JS DivIcon options\n const options = {\n html: this.innerHTML,\n };\n const className = this.getAttribute(\"class-name\");\n if (className !== null) {\n options[\"className\"] = className;\n }\n\n this.icon = divIcon(options);\n this.dispatchEvent(\n new CustomEvent(iconConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n icon: this.icon,\n },\n })\n );\n }\n}\n","// @ts-check\n\nimport { tooltip } from \"leaflet\";\nimport { tooltipConnected } from \"./events\";\nimport { json, option, parse } from \"./parse.js\";\n\nclass LTooltip extends HTMLElement {\n static observedAttributes = [\"content\", \"permanent\", \"direction\"];\n\n constructor() {\n super();\n this.tooltip = tooltip({\n permanent: this.hasAttribute(\"permanent\"),\n direction: this.getAttribute(\"direction\") ?? \"auto\"\n });\n }\n\n connectedCallback() {\n const event = new CustomEvent(tooltipConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n tooltip: this.tooltip\n }\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} attName\n * @param {string} newValue\n */\n attributeChangedCallback(attName, _, newValue) {\n if (attName === \"content\") {\n this.tooltip.setContent(newValue);\n }\n }\n}\n\nexport default LTooltip;\n","import { paneConnected } from \"./events.js\";\n\nexport default class CustomElement extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.dispatchEvent(\n new CustomEvent(paneConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n name: this.getAttribute(\"name\"),\n },\n })\n );\n }\n}\n","// @ts-check\nimport { Circle, LatLng, Polygon, Polyline, Rectangle } from \"leaflet\";\nimport { camelToKebab } from \"./util.js\";\nimport { htmlAttribute, parse } from \"./parse.js\";\nimport { layerConnected, tooltipConnected } from \"./events.js\";\n\n/**\n * @typedef {Object} TagOption\n * @property {string} camel\n * @property {string} kebab\n * @property {(s: string) => AttributeValue} parser\n * @property {AttributeValue | null} defaultValue\n */\n/**\n * @typedef {(\"circle\"|\"rectangle\"|\"polygon\"|\"polyline\")} MethodName\n * @typedef {(\"path\"|\"interactiveLayer\")} LayerName\n * @typedef {(\"boolean\"|\"number\"|\"string\"|\"latlng\"|\"latlngbounds\")} AttributeType\n * @typedef {(boolean|number|string|LatLng)} AttributeValue\n */\n\n/**\n * @param {MethodName} methodName\n * @returns {TagOption[]}\n */\nconst positionalArguments = (methodName) => {\n switch (methodName) {\n case \"circle\":\n return [option(\"latLng\", \"latlng\", null)];\n case \"rectangle\":\n return [option(\"latLngBounds\", \"latlngbounds\", null)];\n case \"polygon\":\n return [option(\"latLngs\", \"latlng\", null)];\n case \"polyline\":\n return [option(\"latLngs\", \"latlng\", null)];\n }\n};\n\n/**\n * @param {string} name\n * @param {AttributeType} type\n * @param {AttributeValue | null} defaultValue\n * @returns {TagOption}\n */\nconst option = (name, type, defaultValue) => {\n return {\n camel: name,\n kebab: camelToKebab(name),\n parser: inferParser(type),\n defaultValue,\n };\n};\n\n/**\n * @param {AttributeType} type\n * @returns {(s: string) => AttributeValue}\n */\nconst inferParser = (type) => {\n switch (type.toLowerCase()) {\n case \"boolean\":\n return (s) => s === \"true\";\n case \"number\":\n return parseFloat;\n case \"latlng\":\n case \"latlngbounds\":\n return JSON.parse;\n case \"string\":\n return (s) => s;\n default:\n return (s) => s;\n }\n};\n\n/**\n * @param {MethodName} methodName\n * @returns {TagOption[]}\n */\nconst options = (methodName) => {\n const _OPTIONS = {\n circle: [option(\"radius\", \"number\", null)],\n path: [\n option(\"stroke\", \"boolean\", true),\n option(\"color\", \"string\", \"#3388ff\"),\n option(\"weight\", \"number\", 3),\n option(\"opacity\", \"number\", 1.0),\n option(\"lineCap\", \"string\", \"round\"),\n option(\"lineJoin\", \"string\", \"round\"),\n option(\"dashArray\", \"string\", null),\n option(\"dashOffset\", \"string\", null),\n option(\"fill\", \"boolean\", true),\n option(\"fillColor\", \"string\", \"#3388ff\"),\n option(\"fillOpacity\", \"number\", 0.2),\n ],\n polyline: [\n option(\"smoothFactor\", \"number\", 1.0),\n option(\"noClip\", \"boolean\", false),\n ],\n polygon: [],\n rectangle: [],\n interactiveLayer: [option(\"interactive\", \"boolean\", true)],\n };\n return inheritance(methodName).flatMap((parent) => _OPTIONS[parent]);\n};\n\n/**\n * @type {Object.<string, (MethodName | LayerName)[]>}\n */\nconst INHERITS = {\n circle: [\"path\"],\n polyline: [\"path\"],\n polygon: [\"polyline\"],\n rectangle: [\"polygon\"],\n path: [\"interactiveLayer\"],\n interactiveLayer: [],\n};\n\n/**\n * @param {MethodName} methodName\n * @returns {(MethodName | LayerName)[]}\n */\nconst inheritance = (methodName) => {\n /** @type {(MethodName | LayerName)} */\n let name = methodName;\n let chain = [methodName];\n while (INHERITS[name].length > 0) {\n let parent = INHERITS[name][0];\n chain.push(parent);\n name = parent;\n }\n return chain;\n};\n\n/**\n * @param {MethodName} methodName\n * @param {string} newValue\n * @param {string} name\n * @param {(Circle | Rectangle | Polygon | Polyline)} layer\n */\nconst setter = (layer, methodName, name, newValue) => {\n // Parse\n const allOptions = [\n ...positionalArguments(methodName),\n ...options(methodName),\n ];\n let _opt = allOptions.find((o) => o.kebab === name);\n if (typeof _opt === \"undefined\") {\n return;\n }\n const parsedValue = _opt.parser(newValue);\n\n // Update\n if (layer instanceof Circle) {\n switch (name) {\n case \"lat-lng\":\n layer.setLatLng(JSON.parse(newValue));\n break;\n case \"radius\":\n layer.setRadius(parseFloat(newValue));\n break;\n }\n } else if (layer instanceof Rectangle) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n case \"lat-lng-bounds\":\n layer.setBounds(JSON.parse(newValue));\n break;\n }\n } else if (layer instanceof Polygon) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n }\n } else if (layer instanceof Polyline) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n }\n }\n\n // setStyle options\n let opt = options(\"polyline\").find((o) => o.kebab === name);\n if (typeof opt !== \"undefined\") {\n layer.setStyle({ [opt.camel]: parsedValue });\n }\n};\n\n/**\n * @param {MethodName} methodName\n */\nconst attributes = (methodName) => {\n let args = positionalArguments(methodName).map((o) => o.kebab);\n let opts = options(methodName).map((o) => o.kebab);\n return [...args, ...opts];\n};\n\n/**\n * @param {HTMLElement} el\n * @param {MethodName} methodName\n */\nconst settings = (el, methodName) => {\n // Gather settings\n let result = {};\n\n // Process inheritance chain\n options(methodName).forEach((o) => {\n if (el.hasAttribute(o.kebab)) {\n result[o.camel] = o.parser(el.getAttribute(o.kebab));\n }\n });\n return result;\n};\n\n/**\n * Read positional arguments from HTMLElement\n *\n * @param {HTMLElement} el\n * @param {MethodName} methodName\n */\nconst positional = (el, methodName) => {\n return positionalArguments(methodName).map(option => {\n const schema = htmlAttribute(option.kebab)\n const value = parse(schema, el)\n return option.parser(value);\n })\n};\n\n/**\n * @param {MethodName} methodName\n */\nconst generator = (method, methodName) => {\n class cls extends HTMLElement {\n static observedAttributes = attributes(methodName);\n\n constructor() {\n super();\n this.layer = null;\n this.addEventListener(tooltipConnected, (ev) => {\n if (this.layer !== null) {\n this.layer.bindTooltip(ev.detail.tooltip);\n }\n });\n }\n\n connectedCallback() {\n const args = positional(this, methodName);\n const options = settings(this, methodName);\n this.layer = method(...args, options);\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} attName\n * @param {string} newValue\n */\n attributeChangedCallback(attName, _, newValue) {\n if (this.layer !== null) {\n setter(this.layer, methodName, attName, newValue);\n }\n }\n }\n return cls;\n};\n\nexport default generator;\n","// @ts-check\n\n// Make L.markerClusterGroup optional\nimport(\"leaflet.markercluster\").catch((error) => {\n console.warn(\"Failed to import leaflet.markercluster\", error)\n});\n\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMarkerClusterGroup extends LLayer {\n static observedAttributes = [\n \"show-coverage-on-hover\",\n \"icon-options\"\n ];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const iconOptions = this.getAttribute(\"icon-options\");\n this.layer = L.markerClusterGroup({\n showCoverageOnHover: this.hasAttribute(\"show-coverage-on-hover\"),\n iconCreateFunction: this._createIconCreateFunction(iconOptions)\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n name\n }\n });\n this.dispatchEvent(event);\n\n this.addEventListener(layerConnected, (ev) => {\n ev.stopPropagation();\n this.layer.addLayer(ev.detail.layer);\n });\n }\n\n _createIconCreateFunction(iconOptions) {\n if (iconOptions) {\n let { size, content, className } = JSON.parse(iconOptions);\n\n return (cluster) => {\n const resolvedSize = this._callClusterFunction(cluster, size);\n const resolvedContent = this._callClusterFunction(cluster, content);\n\n return L.divIcon({\n html: resolvedContent,\n className: className,\n iconSize: new L.Point(resolvedSize, resolvedSize)\n });\n };\n }\n }\n\n _callClusterFunction(cluster, body) {\n return Function(\"cluster\", `\"use strict\";return (${body})`)(cluster);\n }\n}\n\nexport default LMarkerClusterGroup;\n","// @ts-check\nimport LBaseLayers from \"./l-base-layers.js\";\nimport LControlLayers from \"./l-control-layers.js\";\nimport LLayerGroup from \"./l-layer-group.js\";\nimport LMap from \"./l-map.js\";\nimport LMarker from \"./l-marker.js\";\nimport LOverlayLayers from \"./l-overlay-layers.js\";\nimport LPopup from \"./l-popup.js\";\nimport LTileLayer from \"./l-tile-layer.js\";\nimport LLatLngBounds from \"./l-lat-lng-bounds.js\";\nimport LImageOverlay from \"./l-image-overlay.js\";\nimport LVideoOverlay from \"./l-video-overlay.js\";\nimport LGeoJSON from \"./l-geojson.js\";\nimport LIcon from \"./l-icon.js\";\nimport LDivIcon from \"./l-div-icon.js\";\nimport LTooltip from \"./l-tooltip.js\";\nimport LPane from \"./l-pane.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\";\nimport LMarkerClusterGroup from \"./l-marker-cluster-group.js\";\n\nconst init = (() => {\n // Custom elements (order of definition is important)\n customElements.define(\"l-map\", LMap);\n customElements.define(\"l-pane\", LPane);\n customElements.define(\"l-control-layers\", LControlLayers);\n customElements.define(\"l-base-layers\", LBaseLayers);\n customElements.define(\"l-overlay-layers\", LOverlayLayers);\n customElements.define(\"l-layer-group\", LLayerGroup);\n customElements.define(\"l-tile-layer\", LTileLayer);\n customElements.define(\"l-marker-cluster-group\", LMarkerClusterGroup);\n customElements.define(\"l-marker\", LMarker);\n customElements.define(\"l-popup\", LPopup);\n customElements.define(\"l-lat-lng-bounds\", LLatLngBounds);\n customElements.define(\"l-image-overlay\", LImageOverlay);\n customElements.define(\"l-video-overlay\", LVideoOverlay);\n customElements.define(\"l-geojson\", LGeoJSON);\n customElements.define(\"l-icon\", LIcon);\n customElements.define(\"l-circle\", generator(circle, \"circle\"));\n customElements.define(\"l-polyline\", generator(polyline, \"polyline\"));\n customElements.define(\"l-polygon\", generator(polygon, \"polygon\"));\n customElements.define(\"l-rectangle\", generator(rectangle, \"rectangle\"));\n customElements.define(\"l-tooltip\", LTooltip);\n customElements.define(\"l-div-icon\", LDivIcon);\n})();\n\nexport default init;\n"],"names":["layerConnected","popupConnected","iconConnected","layerRemoved","latLngBoundsConnected","latLngBoundsChanged","tooltipConnected","paneConnected","connectLeafletEvents","el","evented","bubble","hasAttribute","on","getAttribute","split","forEach","eventName","e","dispatchEvent","CustomEvent","bubbles","detail","LBaseLayers","_HTMLElement","call","this","_inheritsLoose","prototype","connectedCallback","addEventListener","ev","_wrapNativeSuper","HTMLElement","LControlLayers","controlLayers","control","layers","_ev$detail","type","name","layer","addOverlay","addBaseLayer","preventDefault","event","cancelable","LLayer","_this","disconnectedCallback","_this$layer","remove","LLayerGroup","_LLayer","group","layerGroup","stopPropagation","addLayer","MutationObserver","mutations","mutation","removedNodes","node","leafletId","getLayer","parseInt","removeLayer","observe","childList","LeafletHTMLError","_Error","issues","key","get","JSON","stringify","Error","parse","schema","value","result","status","wrap","partial","obj","ctx","_i3","_Object$keys3","Object","keys","length","localCtx","concat","pipe","parsers","slice","arguments","i","chain","nullable","parser","optional","htmlAttribute","attributeName","htmlAttributeIssue","_extends","json","jsonIssue","option","apply","code","message","tagName","toLowerCase","LMap","map","boundsListener","method","bounds","createPane","target","_proto","_this2","L","zoomControl","whenReady","fitWorld","zoom","isNaN","center","_i2","_Object$keys2","_parse","setView","locate","attributeChangedCallback","_oldValue","newValue","setZoom","observedAttributes","LMarker","setIcon","icon","bindTooltip","tooltip","latLng","options","opacity","parseFloat","pane","closest","marker","setAttribute","stamp","openPopup","popup","bindPopup","content","setLatLng","setOpacity","LOverlayLayers","LPopup","openPopupAttribute","LTileLayer","_step","urlTemplate","templateOptions","_iterator","_createForOfIteratorHelperLoose","parseTemplateAttributes","done","attribute","paneOptions","parentElement","attribution","errorTileUrl","tileLayer","matchAll","match","LLatLngBounds","getEvent","_name","LImageOverlay","url","alt","imageOverlay","console","warn","setUrl","setBounds","LVideoOverlay","autoplay","muted","playsInline","videoOverlay","LGeoJSON","geoJSON","kebabToCamel","kebab","replace","x","toUpperCase","STRING_ATTRIBUTES","JSON_ATTRIBUTES","BOOL_ATTRIBUTES","LIcon","_parseOptions","_","indexOf","update","CustomElement","html","innerHTML","className","divIcon","LTooltip","_this$getAttribute","permanent","direction","attName","setContent","positionalArguments","methodName","defaultValue","camel","s","letter","idx","join","inferParser","_OPTIONS","circle","path","polyline","polygon","rectangle","interactiveLayer","inheritance","flatMap","parent","INHERITS","push","settings","o","generator","cls","args","positional","_opt","find","parsedValue","Circle","setRadius","Rectangle","setLatLngs","Polygon","Polyline","_layer$setStyle","opt","setStyle","setter","opts","attributes","import","error","LMarkerClusterGroup","iconOptions","markerClusterGroup","showCoverageOnHover","iconCreateFunction","_createIconCreateFunction","_this3","_JSON$parse","size","cluster","resolvedSize","_callClusterFunction","resolvedContent","iconSize","Point","body","Function","init","customElements","define","LPane","LDivIcon"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"leaflet-html.js","sources":["../src/events.js","../src/l-base-layers.js","../src/l-control-layers.js","../src/l-layer.js","../src/l-layer-group.js","../src/parse.js","../src/l-map.js","../src/l-marker.js","../src/l-overlay-layers.js","../src/l-popup.js","../src/l-tile-layer.js","../src/l-lat-lng-bounds.js","../src/l-image-overlay.js","../src/l-video-overlay.js","../src/l-geojson.js","../src/util.js","../src/l-icon.js","../src/l-div-icon.js","../src/l-tooltip.js","../src/l-pane.js","../src/generator.js","../src/l-marker-cluster-group.js","../src/index.js"],"sourcesContent":["import { Evented } from \"leaflet\";\n\n// NOTE: These event keys are part of the public API of leaflet-html\nexport const layerConnected = \"l:layer:connected\";\nexport const popupConnected = \"l:popup:connected\";\nexport const iconConnected = \"l:icon:connected\";\nexport const layerRemoved = \"l:layer:removed\";\nexport const latLngBoundsConnected = \"l:latlngbounds:connected\";\nexport const latLngBoundsChanged = \"l:latlngbounds:changed\";\nexport const tooltipConnected = \"l:tooltip:connected\";\nexport const paneConnected = \"l:pane:connected\";\n\n/**\n * @param {HTMLElement} el\n * @param {Evented} evented\n * @param bubble determines whether events should bubble (defaults to true)\n */\nexport const connectLeafletEvents = (el, evented, bubble = true) => {\n if (el.hasAttribute(\"on\")) {\n const on = el.getAttribute(\"on\");\n if (on !== null) {\n on.split(/\\s+/).forEach((eventName) => {\n if (evented !== null) {\n evented.on(eventName, (e) => {\n el.dispatchEvent(\n new CustomEvent(eventName, { bubbles: bubble, detail: e })\n );\n });\n }\n });\n }\n }\n}\n","// @ts-check\nimport { layerConnected } from \"./events.js\";\n\nclass LBaseLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(layerConnected, (ev) => {\n ev.detail[\"type\"] = \"base\";\n });\n }\n}\n\nexport default LBaseLayers;\n","// @ts-check\n/** @typedef {import(\"leaflet\").Layer} Layer */\nimport { control } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\n\nclass LControlLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n /** @type {{ [key: string]: Layer }} */\n const base = {};\n /** @type {{ [key: string]: Layer }} */\n const overlay = {};\n const controlLayers = control.layers(base, overlay);\n\n this.addEventListener(layerConnected, (ev) => {\n const { type, name, layer } = ev.detail;\n if (type === \"overlay\") {\n controlLayers.addOverlay(layer, name);\n } else if (type === \"base\") {\n controlLayers.addBaseLayer(layer, name);\n }\n ev.preventDefault();\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: controlLayers,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LControlLayers;\n","class LLayer extends HTMLElement {\n constructor() {\n super()\n this.layer = null\n }\n\n disconnectedCallback() {\n this.layer?.remove();\n }\n}\n\nexport default LLayer\n","// @ts-check\nimport { layerGroup } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LLayerGroup extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const group = layerGroup();\n this.layer = group;\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: group,\n name,\n },\n });\n this.dispatchEvent(event);\n\n this.addEventListener(layerConnected, (ev) => {\n ev.stopPropagation();\n group.addLayer(ev.detail.layer);\n });\n\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n mutation.removedNodes.forEach((node) => {\n if (node instanceof HTMLElement) {\n const leafletId = node.getAttribute(\"leaflet-id\");\n if (leafletId !== null) {\n const layer = group.getLayer(parseInt(leafletId));\n if (typeof layer !== \"undefined\") {\n group.removeLayer(layer);\n }\n }\n }\n });\n });\n });\n observer.observe(this, { childList: true });\n }\n}\n\nexport default LLayerGroup;\n","/// <reference path=\"./parser.d.ts\" />\n \nexport class LeafletHTMLError extends Error {\n /** @type {Issue[]} */\n issues = [];\n\n /**\n * @param {Issue[]} issues\n */\n constructor(issues) {\n super();\n this.name = \"LeafletHTMLError\";\n this.issues = issues;\n }\n\n get message() {\n return JSON.stringify(this.issues, null, 2);\n }\n}\n\n/**\n * @template T\n * @param {T} value\n * @returns {Context<T>}\n */\nconst wrap = (value) => {\n return {\n status: \"clean\",\n issues: [],\n value,\n };\n};\n\n/**\n * @template T\n * @param {Context<T>} value\n * @returns {T}\n */\nconst unwrap = ({ value }) => value;\n\n/**\n * @template S\n * @template T\n * @param {Parser<T, S>} schema\n * @param {T} value\n * @returns {S}\n */\nexport const parse = (schema, value) => {\n const result = schema(wrap(value));\n if (result.status !== \"clean\") {\n throw new LeafletHTMLError(result.issues);\n } else {\n return unwrap(result);\n }\n};\n\n/**\n * @template S\n * @template T\n * @param {Parser<T, S>} schema\n * @param {T} value\n * @returns {Context<S>}\n */\nexport const safeParse = (schema, value) => schema(wrap(value));\n\n/**\n * @param {Object} obj\n * @returns {(ctx: Context<Object>) => Context<Object>}\n */\nexport const object = (obj) => (ctx) => {\n let { status, issues } = ctx;\n const result = {};\n for (const key of Object.keys(obj)) {\n if (key in ctx.value) {\n result[key] = obj[key](wrap(ctx.value[key])).value;\n } else {\n status = \"abort\";\n issues = [...issues, missingKeyIssue(key)];\n }\n }\n return { status, issues, value: result };\n};\n\n// CONNECTORS\n\n/**\n * @template T\n * @param {Object} obj\n * @returns {(ctx: Context<T>) => Context<Object>}\n */\nexport const distribute = (obj) => (ctx) => {\n let { status, issues } = ctx;\n const result = {};\n for (const key of Object.keys(obj)) {\n let localCtx = obj[key](ctx);\n if (localCtx.status === \"abort\") {\n status = \"abort\";\n issues = [...issues, ...localCtx.issues];\n }\n result[key] = localCtx.value;\n }\n return { status, issues, value: result };\n};\n\nexport const partial = (obj) => (ctx) => {\n let { issues } = ctx;\n let status = \"clean\"\n const result = {};\n for (const key of Object.keys(obj)) {\n let localCtx = obj[key](ctx);\n if (localCtx.status !== \"clean\") {\n status = localCtx.status\n }\n \n if ((localCtx.value === null) && (localCtx.status === \"clean\")) {\n continue\n } else {\n issues = [...issues, ...localCtx.issues];\n result[key] = localCtx.value;\n }\n }\n return { status, issues, value: result };\n};\n\nexport const pipe =\n (...parsers) =>\n (ctx) => {\n for (let i = 0; i < parsers.length; i++) {\n ctx = parsers[i](ctx);\n if (ctx.status === \"abort\") {\n break;\n }\n }\n return ctx;\n };\n\nexport const chain = (...parsers) => (ctx) => {\n for (let i=0; i<parsers.length; i++) {\n ctx = parsers[i](ctx)\n }\n return ctx\n}\n\n\n// PRIMITIVES\nexport const nullable = (parser) => (ctx) => {\n if (ctx.value === null) {\n return ctx\n }\n return parser(ctx)\n}\n\nexport const optional = (parser) => (ctx) => {\n ctx = parser(ctx)\n if (ctx.value === null) {\n return {status: \"clean\", issues: [], value: null}\n } else {\n return ctx\n }\n}\n\n/**\n * @param {string} attributeName\n * @returns {Parser<HTMLElement, string>}\n */\nexport const htmlAttribute = (attributeName) => (ctx) => {\n const el = ctx.value;\n let result = el.getAttribute(attributeName);\n if (result === null) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, htmlAttributeIssue(el, attributeName)],\n value: null,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const int = () => (ctx) => {\n let result = parseInt(ctx.value);\n if (isNaN(result)) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, intIssue(ctx.value)],\n value: result,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const float = () => (ctx) => {\n let result = parseFloat(ctx.value);\n if (isNaN(result)) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, floatIssue(ctx.value)],\n value: result,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<number>}\n */\nexport const json = () => (ctx) => {\n let result;\n try {\n result = JSON.parse(ctx.value);\n } catch (e) {\n return {\n status: \"abort\",\n issues: [...ctx.issues, jsonIssue(e)],\n value: null,\n };\n }\n return { ...ctx, value: result };\n};\n\n/**\n * @returns {(ctx: Context<string>) => Context<boolean>}\n */\nexport const bool = () => (ctx) => {\n return { ...ctx, value: ctx.value.toLowerCase() === \"true\" };\n};\n\n/**\n * @template T\n * @template S\n * @param {string} key\n * @param {Parser<T, S>[]} fns\n */\nexport const option = (key, ...fns) => pipe(htmlAttribute(key), ...fns);\n\n\n// ISSUES\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const intIssue = (value) => {\n return {\n code: \"parse_int\",\n message: `could not parse int given: \"${value}\"`,\n };\n};\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const floatIssue = (value) => {\n return {\n code: \"parse_float\",\n message: `could not parse float given: \"${value}\"`,\n };\n};\n\n/**\n * @param {SyntaxError} e\n * @returns {Issue}\n */\nexport const jsonIssue = (e) => {\n return {\n code: \"parse_json\",\n message: e.message,\n };\n};\n\n/**\n * @param {string} value\n * @returns {Issue}\n */\nexport const missingKeyIssue = (value) => {\n return {\n code: \"missing_key\",\n message: `key not found: ${value}`,\n };\n};\n\n/**\n * @param {HTMLElement} el\n * @param {string} attributeName\n * @returns {Issue}\n */\nexport const htmlAttributeIssue = (el, attributeName) => {\n return {\n code: \"missing_attribute\",\n message: `${el.tagName.toLowerCase()} missing attribute '${attributeName}'`,\n };\n};\n","// @ts-check\nimport * as L from \"leaflet\";\nimport { layerRemoved, layerConnected, latLngBoundsConnected, latLngBoundsChanged, paneConnected, connectLeafletEvents } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport { distribute, int, json, option, parse } from \"./parse.js\";\n\nclass LMap extends HTMLElement {\n static observedAttributes = [\"zoom\", \"center\", \"zoom-control\"];\n\n constructor() {\n super();\n\n this.map = null;\n\n // Handle <l-lat-lng-bounds> connection and modification(s)\n const boundsListener = (ev) => {\n const { bounds, method } = ev.detail;\n if (this.map !== null) {\n this.map[method](bounds);\n }\n };\n this.addEventListener(latLngBoundsConnected, boundsListener);\n this.addEventListener(latLngBoundsChanged, boundsListener);\n\n // Observe l-pane\n this.addEventListener(paneConnected, (ev) => {\n const { name } = ev.detail\n this.map.createPane(name)\n })\n\n // Observe removed l-tile-layers\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n if (mutation.target instanceof LMap) {\n const el = mutation.target;\n mutation.removedNodes.forEach((node) => {\n if (node instanceof LLayer) {\n if (el.map !== null && node.layer !== null) {\n // Notify listeners of layer removal\n el.dispatchEvent(new CustomEvent(layerRemoved, {\n bubbles: true,\n detail: {\n layer: node.layer\n }\n }))\n el.map.removeLayer(node.layer);\n }\n }\n });\n }\n });\n });\n observer.observe(this, { childList: true });\n }\n\n connectedCallback() {\n this.map = L.map(this, { zoomControl: this.hasAttribute(\"zoom-control\") });\n\n // Allow listeners to know when the map is \"ready\"\n this.map.whenReady(() => {\n this.dispatchEvent(\n new CustomEvent(\"ready\", {\n bubbles: true,\n cancelable: true,\n detail: this.map\n })\n )\n })\n\n // Connect Leaflet events\n connectLeafletEvents(this, this.map);\n\n if (this.hasAttribute(\"fit-world\")) {\n this.map.fitWorld();\n } else {\n const schema = distribute({\n zoom: option(\"zoom\", int()),\n center: option(\"center\", json())\n })\n const { zoom, center } = parse(schema, this)\n this.map.setView(center, zoom);\n }\n\n if (this.hasAttribute(\"locate\")) {\n const schema = option(\"locate\", json())\n this.map.locate(parse(schema, this));\n }\n\n this.addEventListener(layerConnected, (ev) => {\n const layer = ev.detail.layer;\n this.map.addLayer(layer);\n });\n\n this.addEventListener(layerRemoved, (ev) => {\n if (this.map !== null) {\n this.map.removeLayer(ev.detail.layer);\n }\n });\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.map !== null) {\n if (name === \"zoom\") {\n this.map.setZoom(parseInt(newValue));\n } else if (name === \"center\") {\n this.map.setView(JSON.parse(newValue));\n }\n }\n }\n}\n\nexport default LMap;\n","import * as L from \"leaflet\";\nimport {\n layerConnected,\n popupConnected,\n iconConnected,\n tooltipConnected,\n connectLeafletEvents,\n} from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport {\n chain,\n float,\n json,\n option,\n optional,\n htmlAttribute,\n parse,\n partial,\n nullable,\n} from \"./parse.js\";\n\nclass LMarker extends LLayer {\n static observedAttributes = [\"lat-lng\", \"opacity\", \"icon\"];\n\n constructor() {\n super();\n this.layer = null;\n\n // Icon connected\n this.addEventListener(iconConnected, (ev) => {\n ev.stopPropagation();\n this.layer.setIcon(ev.detail.icon);\n });\n\n // Tooltip connected\n this.addEventListener(tooltipConnected, (ev) => {\n ev.stopPropagation();\n this.layer.bindTooltip(ev.detail.tooltip);\n });\n }\n\n connectedCallback() {\n // Experimental parse/validate API\n const latLng = parse(option(\"lat-lng\", json()), this);\n const options = parse(\n partial({\n opacity: chain(optional(htmlAttribute(\"opacity\")), nullable(float())),\n }),\n this\n );\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n this.layer = L.marker(latLng, options);\n\n if (this.hasAttribute(\"icon\")) {\n const icon = L.icon(JSON.parse(this.getAttribute(\"icon\")));\n this.layer.setIcon(icon);\n }\n\n // Connect Leaflet events\n connectLeafletEvents(this, this.layer, false);\n\n this.setAttribute(\"leaflet-id\", L.stamp(this.layer));\n\n this.addEventListener(popupConnected, (ev) => {\n const { content, openPopup } = ev.detail;\n const popup = this.layer.bindPopup(content);\n if (openPopup) {\n popup.openPopup();\n }\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"lat-lng\") {\n this.layer.setLatLng(JSON.parse(newValue));\n }\n if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n if (name === \"icon\") {\n this.layer.setIcon(L.icon(JSON.parse(newValue)));\n }\n }\n }\n}\n\nexport default LMarker;\n","// @ts-check\nimport { layerConnected } from \"./events.js\";\n\nclass LOverlayLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(layerConnected, (ev) => {\n ev.detail[\"type\"] = \"overlay\";\n });\n }\n}\n\nexport default LOverlayLayers;\n","// @ts-check\nimport { popupConnected } from \"./events.js\";\n\nclass LPopup extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const content = this.getAttribute(\"content\");\n let openPopup = false;\n const openPopupAttribute = this.getAttribute(\"open-popup\");\n if (openPopupAttribute !== null) {\n openPopup = openPopupAttribute !== \"false\";\n }\n const event = new CustomEvent(popupConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n content,\n openPopup,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LPopup;\n","// @ts-check\nimport { tileLayer } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\nimport { htmlAttribute, optional, parse, partial } from \"./parse.js\";\n\nclass LTileLayer extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const urlTemplate = parse(htmlAttribute(\"url-template\"), this)\n \n // Template attributes\n const urlAttributes = LTileLayer.parseTemplateAttributes(urlTemplate)\n const templateOptions = {}\n for (const attribute of urlAttributes) {\n const value = this.getAttribute(attribute)\n if (value !== null) {\n templateOptions[attribute] = value\n }\n }\n\n // Pane options\n const paneOptions = {}\n // Support <l-pane> parent element\n if (this.parentElement.tagName.toLowerCase() === \"l-pane\") {\n paneOptions[\"pane\"] = this.parentElement.getAttribute(\"name\")\n }\n \n // Options\n const name = this.getAttribute(\"name\");\n const schema = partial({\n attribution: optional(htmlAttribute(\"attribution\")),\n errorTileUrl: optional(htmlAttribute(\"error-tile-url\"))\n })\n const options = parse(schema, this)\n this.layer = tileLayer(urlTemplate, { ...templateOptions, ...paneOptions, ...options });\n const event = new CustomEvent(layerConnected, {\n detail: { name, layer: this.layer },\n bubbles: true,\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} urlTemplate\n * @returns {string[]}\n */\n static parseTemplateAttributes(urlTemplate) {\n const regex = /{(.*?)}/g\n return [...urlTemplate.matchAll(regex)].map(match => match[1])\n }\n}\n\nexport default LTileLayer;\n","// @ts-check\nimport { LatLngBounds } from \"leaflet\";\nimport { latLngBoundsChanged, latLngBoundsConnected } from \"./events\"; \n\nclass LLatLngBounds extends HTMLElement {\n static observedAttributes = [\"bounds\"];\n\n constructor() {\n super();\n }\n\n connectedCallback() {\n let value = this.getAttribute(\"bounds\")\n if (value !== null) {\n this.dispatchEvent(this.getEvent(latLngBoundsConnected, JSON.parse(value)))\n }\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n this.dispatchEvent(this.getEvent(latLngBoundsChanged, JSON.parse(newValue)));\n }\n\n /**\n * @param {LatLngBounds} bounds\n */\n getEvent(key, bounds) {\n return new CustomEvent(key, {\n bubbles: true,\n detail: {\n bounds,\n method: this.getAttribute(\"method\") || \"fitBounds\",\n },\n });\n }\n}\n\nexport default LLatLngBounds;\n","// @ts-check\nimport { imageOverlay } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LImageOverlay extends LLayer {\n static observedAttributes = [\"url\", \"bounds\", \"opacity\"];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const url = this.getAttribute(\"url\");\n if (url === null) {\n console.warn(\"attribute 'url' not set\");\n return;\n }\n let bounds = this.getAttribute(\"bounds\");\n if (bounds === null) {\n console.warn(\"attribute 'bounds' not set\");\n return;\n }\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n };\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n this.layer = imageOverlay(url, JSON.parse(bounds), options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n })\n );\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"url\") {\n this.layer.setUrl(newValue);\n } else if (name === \"bounds\") {\n this.layer.setBounds(JSON.parse(newValue));\n } else if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n }\n }\n}\n\nexport default LImageOverlay;\n","// @ts-check\nimport { videoOverlay } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LVideoOverlay extends LLayer {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const url = JSON.parse(this.getAttribute(\"url\"));\n const bounds = JSON.parse(this.getAttribute(\"bounds\"));\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n autoplay: true,\n muted: true,\n playsInline: true,\n };\n const layer = videoOverlay(url, bounds, options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer,\n },\n }),\n );\n }\n}\n\nexport default LVideoOverlay;\n","// @ts-check\nimport { geoJSON } from \"leaflet\";\nimport { layerConnected } from \"./events.js\";\n\nclass LGeoJSON extends HTMLElement {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const value = this.getAttribute(\"geojson\");\n const options = {};\n\n // Pane\n const pane = this.closest(\"l-pane\");\n if (pane !== null) {\n options[\"pane\"] = pane.getAttribute(\"name\");\n }\n\n if (value !== null) {\n this.layer = geoJSON(JSON.parse(value), options);\n this.dispatchEvent(\n new CustomEvent(layerConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n layer: this.layer,\n },\n })\n );\n }\n }\n}\n\nexport default LGeoJSON;\n","// Utility functions\nexport const kebabToCamel = (kebab) => kebab.replace(/-./g, (x) => x[1].toUpperCase());\nexport const camelToKebab = (s) => {\n return s.split('').map((letter, idx) => {\n return letter.toUpperCase() === letter\n ? `${idx !== 0 ? '-' : ''}${letter.toLowerCase()}`\n : letter;\n }).join('');\n}\n\n","import { icon } from \"leaflet\";\nimport { iconConnected } from \"./events.js\";\nimport {\n bool,\n chain,\n htmlAttribute,\n json,\n nullable,\n optional,\n parse,\n partial,\n} from \"./parse.js\";\nimport { kebabToCamel } from \"./util.js\";\n\nconst STRING_ATTRIBUTES = [\n \"icon-url\",\n \"icon-retina-url\",\n \"shadow-url\",\n \"shadow-retina-url\",\n \"class-name\",\n];\n\nconst JSON_ATTRIBUTES = [\n \"icon-anchor\",\n \"icon-size\",\n \"shadow-anchor\",\n \"shadow-size\",\n \"tooltip-anchor\",\n \"popup-anchor\",\n];\n\nconst BOOL_ATTRIBUTES = [\"cross-origin\"];\n\nclass LIcon extends HTMLElement {\n static observedAttributes = [\n ...STRING_ATTRIBUTES,\n ...JSON_ATTRIBUTES,\n ...BOOL_ATTRIBUTES,\n ];\n\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n this.icon = icon(this._parseOptions());\n\n const event = new CustomEvent(iconConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} name\n * @param {string} _\n * @param {string} newValue\n */\n attributeChangedCallback(name, _, newValue) {\n if (LIcon.observedAttributes.indexOf(name) !== -1) {\n if (this.icon !== null) {\n let update = {};\n if (STRING_ATTRIBUTES.indexOf(name) !== -1) {\n update[kebabToCamel(name)] = newValue;\n } else if (BOOL_ATTRIBUTES.indexOf(name) !== -1) {\n update[kebabToCamel(name)] = newValue.toLowerCase() === \"true\";\n } else {\n update[kebabToCamel(name)] = JSON.parse(newValue);\n }\n this.icon = icon({\n ...this.icon.options,\n ...update,\n });\n const event = new CustomEvent(iconConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n }\n }\n\n /**\n * @returns {import(\"leaflet\").IconOptions}\n */\n _parseOptions() {\n // Experimental parse/validate API\n const obj = {};\n STRING_ATTRIBUTES.forEach((key) => {\n obj[kebabToCamel(key)] = optional(htmlAttribute(key));\n });\n JSON_ATTRIBUTES.forEach((key) => {\n obj[kebabToCamel(key)] = chain(\n optional(htmlAttribute(key)),\n nullable(json())\n );\n });\n obj[\"crossOrigin\"] = chain(\n optional(htmlAttribute(\"cross-origin\")),\n nullable(bool())\n );\n const schema = partial(obj);\n return parse(schema, this);\n }\n}\n\nexport default LIcon;\n","import { divIcon } from \"leaflet\";\nimport { iconConnected } from \"./events\";\n\nexport default class CustomElement extends HTMLElement {\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n // Leaflet JS DivIcon options\n const options = {\n html: this.innerHTML,\n };\n const className = this.getAttribute(\"class-name\");\n if (className !== null) {\n options[\"className\"] = className;\n }\n\n this.icon = divIcon(options);\n this.dispatchEvent(\n new CustomEvent(iconConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n icon: this.icon,\n },\n })\n );\n }\n}\n","// @ts-check\n\nimport { tooltip } from \"leaflet\";\nimport { tooltipConnected } from \"./events\";\nimport { json, option, parse } from \"./parse.js\";\n\nclass LTooltip extends HTMLElement {\n static observedAttributes = [\"content\", \"permanent\", \"direction\"];\n\n constructor() {\n super();\n this.tooltip = tooltip({\n permanent: this.hasAttribute(\"permanent\"),\n direction: this.getAttribute(\"direction\") ?? \"auto\"\n });\n }\n\n connectedCallback() {\n const event = new CustomEvent(tooltipConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n tooltip: this.tooltip\n }\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} attName\n * @param {string} newValue\n */\n attributeChangedCallback(attName, _, newValue) {\n if (attName === \"content\") {\n this.tooltip.setContent(newValue);\n }\n }\n}\n\nexport default LTooltip;\n","import { paneConnected } from \"./events.js\";\n\nexport default class CustomElement extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.dispatchEvent(\n new CustomEvent(paneConnected, {\n bubbles: true,\n cancelable: true,\n detail: {\n name: this.getAttribute(\"name\"),\n },\n })\n );\n }\n}\n","// @ts-check\nimport { Circle, LatLng, Polygon, Polyline, Rectangle } from \"leaflet\";\nimport { camelToKebab } from \"./util.js\";\nimport { htmlAttribute, parse } from \"./parse.js\";\nimport { layerConnected, tooltipConnected } from \"./events.js\";\n\n/**\n * @typedef {Object} TagOption\n * @property {string} camel\n * @property {string} kebab\n * @property {(s: string) => AttributeValue} parser\n * @property {AttributeValue | null} defaultValue\n */\n/**\n * @typedef {(\"circle\"|\"rectangle\"|\"polygon\"|\"polyline\")} MethodName\n * @typedef {(\"path\"|\"interactiveLayer\")} LayerName\n * @typedef {(\"boolean\"|\"number\"|\"string\"|\"latlng\"|\"latlngbounds\")} AttributeType\n * @typedef {(boolean|number|string|LatLng)} AttributeValue\n */\n\n/**\n * @param {MethodName} methodName\n * @returns {TagOption[]}\n */\nconst positionalArguments = (methodName) => {\n switch (methodName) {\n case \"circle\":\n return [option(\"latLng\", \"latlng\", null)];\n case \"rectangle\":\n return [option(\"latLngBounds\", \"latlngbounds\", null)];\n case \"polygon\":\n return [option(\"latLngs\", \"latlng\", null)];\n case \"polyline\":\n return [option(\"latLngs\", \"latlng\", null)];\n }\n};\n\n/**\n * @param {string} name\n * @param {AttributeType} type\n * @param {AttributeValue | null} defaultValue\n * @returns {TagOption}\n */\nconst option = (name, type, defaultValue) => {\n return {\n camel: name,\n kebab: camelToKebab(name),\n parser: inferParser(type),\n defaultValue,\n };\n};\n\n/**\n * @param {AttributeType} type\n * @returns {(s: string) => AttributeValue}\n */\nconst inferParser = (type) => {\n switch (type.toLowerCase()) {\n case \"boolean\":\n return (s) => s === \"true\";\n case \"number\":\n return parseFloat;\n case \"latlng\":\n case \"latlngbounds\":\n return JSON.parse;\n case \"string\":\n return (s) => s;\n default:\n return (s) => s;\n }\n};\n\n/**\n * @param {MethodName} methodName\n * @returns {TagOption[]}\n */\nconst options = (methodName) => {\n const _OPTIONS = {\n circle: [option(\"radius\", \"number\", null)],\n path: [\n option(\"stroke\", \"boolean\", true),\n option(\"color\", \"string\", \"#3388ff\"),\n option(\"weight\", \"number\", 3),\n option(\"opacity\", \"number\", 1.0),\n option(\"lineCap\", \"string\", \"round\"),\n option(\"lineJoin\", \"string\", \"round\"),\n option(\"dashArray\", \"string\", null),\n option(\"dashOffset\", \"string\", null),\n option(\"fill\", \"boolean\", true),\n option(\"fillColor\", \"string\", \"#3388ff\"),\n option(\"fillOpacity\", \"number\", 0.2),\n ],\n polyline: [\n option(\"smoothFactor\", \"number\", 1.0),\n option(\"noClip\", \"boolean\", false),\n ],\n polygon: [],\n rectangle: [],\n interactiveLayer: [option(\"interactive\", \"boolean\", true)],\n };\n return inheritance(methodName).flatMap((parent) => _OPTIONS[parent]);\n};\n\n/**\n * @type {Object.<string, (MethodName | LayerName)[]>}\n */\nconst INHERITS = {\n circle: [\"path\"],\n polyline: [\"path\"],\n polygon: [\"polyline\"],\n rectangle: [\"polygon\"],\n path: [\"interactiveLayer\"],\n interactiveLayer: [],\n};\n\n/**\n * @param {MethodName} methodName\n * @returns {(MethodName | LayerName)[]}\n */\nconst inheritance = (methodName) => {\n /** @type {(MethodName | LayerName)} */\n let name = methodName;\n let chain = [methodName];\n while (INHERITS[name].length > 0) {\n let parent = INHERITS[name][0];\n chain.push(parent);\n name = parent;\n }\n return chain;\n};\n\n/**\n * @param {MethodName} methodName\n * @param {string} newValue\n * @param {string} name\n * @param {(Circle | Rectangle | Polygon | Polyline)} layer\n */\nconst setter = (layer, methodName, name, newValue) => {\n // Parse\n const allOptions = [\n ...positionalArguments(methodName),\n ...options(methodName),\n ];\n let _opt = allOptions.find((o) => o.kebab === name);\n if (typeof _opt === \"undefined\") {\n return;\n }\n const parsedValue = _opt.parser(newValue);\n\n // Update\n if (layer instanceof Circle) {\n switch (name) {\n case \"lat-lng\":\n layer.setLatLng(JSON.parse(newValue));\n break;\n case \"radius\":\n layer.setRadius(parseFloat(newValue));\n break;\n }\n } else if (layer instanceof Rectangle) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n case \"lat-lng-bounds\":\n layer.setBounds(JSON.parse(newValue));\n break;\n }\n } else if (layer instanceof Polygon) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n }\n } else if (layer instanceof Polyline) {\n switch (name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue));\n break;\n }\n }\n\n // setStyle options\n let opt = options(\"polyline\").find((o) => o.kebab === name);\n if (typeof opt !== \"undefined\") {\n layer.setStyle({ [opt.camel]: parsedValue });\n }\n};\n\n/**\n * @param {MethodName} methodName\n */\nconst attributes = (methodName) => {\n let args = positionalArguments(methodName).map((o) => o.kebab);\n let opts = options(methodName).map((o) => o.kebab);\n return [...args, ...opts];\n};\n\n/**\n * @param {HTMLElement} el\n * @param {MethodName} methodName\n */\nconst settings = (el, methodName) => {\n // Gather settings\n let result = {};\n\n // Process inheritance chain\n options(methodName).forEach((o) => {\n if (el.hasAttribute(o.kebab)) {\n result[o.camel] = o.parser(el.getAttribute(o.kebab));\n }\n });\n return result;\n};\n\n/**\n * Read positional arguments from HTMLElement\n *\n * @param {HTMLElement} el\n * @param {MethodName} methodName\n */\nconst positional = (el, methodName) => {\n return positionalArguments(methodName).map(option => {\n const schema = htmlAttribute(option.kebab)\n const value = parse(schema, el)\n return option.parser(value);\n })\n};\n\n/**\n * @param {MethodName} methodName\n */\nconst generator = (method, methodName) => {\n class cls extends HTMLElement {\n static observedAttributes = attributes(methodName);\n\n constructor() {\n super();\n this.layer = null;\n this.addEventListener(tooltipConnected, (ev) => {\n if (this.layer !== null) {\n this.layer.bindTooltip(ev.detail.tooltip);\n }\n });\n }\n\n connectedCallback() {\n const args = positional(this, methodName);\n const options = settings(this, methodName);\n this.layer = method(...args, options);\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n /**\n * @param {string} attName\n * @param {string} newValue\n */\n attributeChangedCallback(attName, _, newValue) {\n if (this.layer !== null) {\n setter(this.layer, methodName, attName, newValue);\n }\n }\n }\n return cls;\n};\n\nexport default generator;\n","// @ts-check\n\n// Make L.markerClusterGroup optional\nimport(\"leaflet.markercluster\").catch((error) => {\n console.warn(\"Failed to import leaflet.markercluster\", error)\n});\n\nimport { layerConnected } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMarkerClusterGroup extends LLayer {\n static observedAttributes = [\n \"show-coverage-on-hover\",\n \"icon-options\"\n ];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const iconOptions = this.getAttribute(\"icon-options\");\n this.layer = L.markerClusterGroup({\n showCoverageOnHover: this.hasAttribute(\"show-coverage-on-hover\"),\n iconCreateFunction: this._createIconCreateFunction(iconOptions)\n });\n\n const event = new CustomEvent(layerConnected, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n name\n }\n });\n this.dispatchEvent(event);\n\n this.addEventListener(layerConnected, (ev) => {\n ev.stopPropagation();\n this.layer.addLayer(ev.detail.layer);\n });\n }\n\n _createIconCreateFunction(iconOptions) {\n if (iconOptions) {\n let { size, content, className } = JSON.parse(iconOptions);\n\n return (cluster) => {\n const resolvedSize = this._callClusterFunction(cluster, size);\n const resolvedContent = this._callClusterFunction(cluster, content);\n\n return L.divIcon({\n html: resolvedContent,\n className: className,\n iconSize: new L.Point(resolvedSize, resolvedSize)\n });\n };\n }\n }\n\n _callClusterFunction(cluster, body) {\n return Function(\"cluster\", `\"use strict\";return (${body})`)(cluster);\n }\n}\n\nexport default LMarkerClusterGroup;\n","// @ts-check\nimport LBaseLayers from \"./l-base-layers.js\";\nimport LControlLayers from \"./l-control-layers.js\";\nimport LLayerGroup from \"./l-layer-group.js\";\nimport LMap from \"./l-map.js\";\nimport LMarker from \"./l-marker.js\";\nimport LOverlayLayers from \"./l-overlay-layers.js\";\nimport LPopup from \"./l-popup.js\";\nimport LTileLayer from \"./l-tile-layer.js\";\nimport LLatLngBounds from \"./l-lat-lng-bounds.js\";\nimport LImageOverlay from \"./l-image-overlay.js\";\nimport LVideoOverlay from \"./l-video-overlay.js\";\nimport LGeoJSON from \"./l-geojson.js\";\nimport LIcon from \"./l-icon.js\";\nimport LDivIcon from \"./l-div-icon.js\";\nimport LTooltip from \"./l-tooltip.js\";\nimport LPane from \"./l-pane.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\";\nimport LMarkerClusterGroup from \"./l-marker-cluster-group.js\";\n\nconst init = (() => {\n // Custom elements (order of definition is important)\n customElements.define(\"l-map\", LMap);\n customElements.define(\"l-pane\", LPane);\n customElements.define(\"l-control-layers\", LControlLayers);\n customElements.define(\"l-base-layers\", LBaseLayers);\n customElements.define(\"l-overlay-layers\", LOverlayLayers);\n customElements.define(\"l-layer-group\", LLayerGroup);\n customElements.define(\"l-tile-layer\", LTileLayer);\n customElements.define(\"l-marker-cluster-group\", LMarkerClusterGroup);\n customElements.define(\"l-marker\", LMarker);\n customElements.define(\"l-popup\", LPopup);\n customElements.define(\"l-lat-lng-bounds\", LLatLngBounds);\n customElements.define(\"l-image-overlay\", LImageOverlay);\n customElements.define(\"l-video-overlay\", LVideoOverlay);\n customElements.define(\"l-geojson\", LGeoJSON);\n customElements.define(\"l-icon\", LIcon);\n customElements.define(\"l-circle\", generator(circle, \"circle\"));\n customElements.define(\"l-polyline\", generator(polyline, \"polyline\"));\n customElements.define(\"l-polygon\", generator(polygon, \"polygon\"));\n customElements.define(\"l-rectangle\", generator(rectangle, \"rectangle\"));\n customElements.define(\"l-tooltip\", LTooltip);\n customElements.define(\"l-div-icon\", LDivIcon);\n})();\n\nexport default init;\n"],"names":["layerConnected","popupConnected","iconConnected","layerRemoved","latLngBoundsConnected","latLngBoundsChanged","tooltipConnected","paneConnected","connectLeafletEvents","el","evented","bubble","hasAttribute","on","getAttribute","split","forEach","eventName","e","dispatchEvent","CustomEvent","bubbles","detail","LBaseLayers","_HTMLElement","call","this","_inheritsLoose","prototype","connectedCallback","addEventListener","ev","_wrapNativeSuper","HTMLElement","LControlLayers","controlLayers","control","layers","_ev$detail","type","name","layer","addOverlay","addBaseLayer","preventDefault","event","cancelable","LLayer","_this","disconnectedCallback","_this$layer","remove","LLayerGroup","_LLayer","group","layerGroup","stopPropagation","addLayer","MutationObserver","mutations","mutation","removedNodes","node","leafletId","getLayer","parseInt","removeLayer","observe","childList","LeafletHTMLError","_Error","issues","key","get","JSON","stringify","Error","parse","schema","value","result","status","wrap","partial","obj","ctx","_i3","_Object$keys3","Object","keys","length","localCtx","concat","pipe","parsers","slice","arguments","i","chain","nullable","parser","optional","htmlAttribute","attributeName","htmlAttributeIssue","_extends","json","jsonIssue","option","apply","code","message","tagName","toLowerCase","LMap","map","boundsListener","method","bounds","createPane","target","_proto","_this2","L","zoomControl","whenReady","fitWorld","zoom","isNaN","center","_i2","_Object$keys2","_parse","setView","locate","attributeChangedCallback","_oldValue","newValue","setZoom","observedAttributes","LMarker","setIcon","icon","bindTooltip","tooltip","latLng","options","opacity","parseFloat","pane","closest","marker","setAttribute","stamp","openPopup","popup","bindPopup","content","setLatLng","setOpacity","LOverlayLayers","LPopup","openPopupAttribute","LTileLayer","_step","urlTemplate","templateOptions","_iterator","_createForOfIteratorHelperLoose","parseTemplateAttributes","done","attribute","paneOptions","parentElement","attribution","errorTileUrl","tileLayer","matchAll","match","LLatLngBounds","getEvent","_name","LImageOverlay","url","alt","imageOverlay","console","warn","setUrl","setBounds","LVideoOverlay","autoplay","muted","playsInline","videoOverlay","LGeoJSON","geoJSON","kebabToCamel","kebab","replace","x","toUpperCase","STRING_ATTRIBUTES","JSON_ATTRIBUTES","BOOL_ATTRIBUTES","LIcon","_parseOptions","_","indexOf","update","CustomElement","html","innerHTML","className","divIcon","LTooltip","_this$getAttribute","permanent","direction","attName","setContent","positionalArguments","methodName","defaultValue","camel","s","letter","idx","join","inferParser","_OPTIONS","circle","path","polyline","polygon","rectangle","interactiveLayer","inheritance","flatMap","parent","INHERITS","push","settings","o","generator","cls","args","positional","_opt","find","parsedValue","Circle","setRadius","Rectangle","setLatLngs","Polygon","Polyline","_layer$setStyle","opt","setStyle","setter","opts","attributes","import","error","LMarkerClusterGroup","iconOptions","markerClusterGroup","showCoverageOnHover","iconCreateFunction","_createIconCreateFunction","_this3","_JSON$parse","size","cluster","resolvedSize","_callClusterFunction","resolvedContent","iconSize","Point","body","Function","init","customElements","define","LPane","LDivIcon"],"mappings":"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"}
|
package/package.json
CHANGED
package/dist/leaflet-html.cjs
DELETED
@@ -1,2 +0,0 @@
|
|
1
|
-
var t=require("leaflet");function e(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach(function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,r.get?r:{enumerable:!0,get:function(){return t[n]}})}}),e.default=t,e}var n=/*#__PURE__*/e(t);function r(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(r=function(){return!!t})()}function a(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,o(t,e)}function i(t){return i=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},i(t)}function o(t,e){return o=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},o(t,e)}function l(t){var e="function"==typeof Map?new Map:void 0;return l=function(t){if(null===t||!function(t){try{return-1!==Function.toString.call(t).indexOf("[native code]")}catch(e){return"function"==typeof t}}(t))return t;if("function"!=typeof t)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(t))return e.get(t);e.set(t,n)}function n(){return function(t,e,n){if(r())return Reflect.construct.apply(null,arguments);var a=[null];a.push.apply(a,e);var i=new(t.bind.apply(t,a));return n&&o(i,n.prototype),i}(t,arguments,i(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),o(n,t)},l(t)}var c="map:addTo",u="popup:add",s=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){this.addEventListener(c,function(t){t.detail.type="base"})},e}(/*#__PURE__*/l(HTMLElement)),p=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=t.control.layers({},{});this.addEventListener(c,function(t){var n=t.detail,r=n.type,a=n.name,i=n.layer;"overlay"===r?e.addOverlay(i,a):"base"===r&&e.addBaseLayer(i,a),t.preventDefault()});var n=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:e}});this.dispatchEvent(n)},n}(/*#__PURE__*/l(HTMLElement)),f=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return a(e,t),e}(/*#__PURE__*/l(HTMLElement)),h=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("name"),n=t.layerGroup();this.layer=n;var r=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:n,name:e}});this.dispatchEvent(r),this.addEventListener(c,function(t){t.stopPropagation(),n.addLayer(t.detail.layer)}),new MutationObserver(function(t){t.forEach(function(t){t.removedNodes.forEach(function(t){if(t instanceof HTMLElement){var e=t.getAttribute("leaflet-id");if(null!==e){var r=n.getLayer(parseInt(e));void 0!==r&&n.removeLayer(r)}}})})}).observe(this,{childList:!0})},n}(f),d=/*#__PURE__*/function(t){function e(){var n;return(n=t.call(this)||this).map=null,n.addEventListener("map:bounds",function(t){var e=t.detail;null!==n.map&&n.map[e.method](e.bounds)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof e){var n=t.target;t.removedNodes.forEach(function(t){t instanceof f&&null!==n.map&&null!==t.layer&&n.map.removeLayer(t.layer)})}})}).observe(n,{childList:!0}),n}return a(e,t),e.prototype.connectedCallback=function(){var t=this;this.map=n.map(this);var e=this.getAttribute("center"),r=this.getAttribute("zoom");null!==e&&null!==r&&this.map.setView(JSON.parse(e),parseInt(r)),this.addEventListener(c,function(e){e.detail.layer.addTo(t.map)}),this.addEventListener("layer:remove",function(e){null!==t.map&&t.map.removeLayer(e.detail.layer)})},e}(/*#__PURE__*/l(HTMLElement)),b=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e.addEventListener("icon:add",function(t){t.stopPropagation(),e.layer.setIcon(t.detail.icon)}),e}a(e,t);var r=e.prototype;return r.connectedCallback=function(){var t=this,e=JSON.parse(this.getAttribute("lat-lng")),r=parseFloat(this.getAttribute("opacity")||"1.0");if(this.layer=n.marker(e,{opacity:r}),this.hasAttribute("icon")){var a=n.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(a)}this.setAttribute("leaflet-id",n.stamp(this.layer)),this.addEventListener(u,function(e){t.layer.bindPopup(e.detail.content)});var i=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(i)},r.attributeChangedCallback=function(t,e,r){null!==this.layer&&("lat-lng"===t&&this.layer.setLatLng(JSON.parse(r)),"opacity"===t&&this.layer.setOpacity(parseFloat(r)),"icon"===t&&this.layer.setIcon(n.icon(JSON.parse(r))))},e}(f);b.observedAttributes=["lat-lng","opacity","icon"];var y=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){this.addEventListener(c,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/l(HTMLElement)),v=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("content"),e=new CustomEvent(u,{cancelable:!0,bubbles:!0,detail:{content:t}});this.dispatchEvent(e)},e}(/*#__PURE__*/l(HTMLElement)),m=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("name"),n=this.getAttribute("url-template");if(null!==n){var r={},a="attribution";this.hasAttribute(a)&&(r[a]=this.getAttribute(a)),this.layer=t.tileLayer(n,r);var i=new CustomEvent(c,{detail:{name:e,layer:this.layer},bubbles:!0});this.dispatchEvent(i)}},n}(f),g=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.attributeChangedCallback=function(t,e,n){var r=new CustomEvent("map:bounds",{bubbles:!0,detail:{bounds:JSON.parse(n),method:this.getAttribute("method")||"fitBounds"}});this.dispatchEvent(r)},e}(/*#__PURE__*/l(HTMLElement));g.observedAttributes=["bounds"];var E=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}a(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this.getAttribute("url");if(null!==e){var n=this.getAttribute("bounds");if(null!==n){var r={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||""};this.layer=t.imageOverlay(e,JSON.parse(n),r),this.dispatchEvent(new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}}))}else console.warn("attribute 'bounds' not set")}else console.warn("attribute 'url' not set")},r.attributeChangedCallback=function(t,e,n){null!==this.layer&&("url"===t?this.layer.setUrl(n):"bounds"===t?this.layer.setBounds(JSON.parse(n)):"opacity"===t&&this.layer.setOpacity(parseFloat(n)))},n}(f);E.observedAttributes=["url","bounds","opacity"];var L=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=JSON.parse(this.getAttribute("url")),n=JSON.parse(this.getAttribute("bounds")),r={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||"",autoplay:!0,muted:!0,playsInline:!0},a=t.videoOverlay(e,n,r);this.dispatchEvent(new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:a}}))},n}(f),O=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("geojson");if(null!==e){var n=t.geoJSON(JSON.parse(e));this.dispatchEvent(new CustomEvent(c,{bubbles:!0,cancelable:!0,detail:{layer:n}}))}},n}(/*#__PURE__*/l(HTMLElement)),C=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},A=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}return a(e,t),e.prototype.connectedCallback=function(){var t=this,e={};["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"].forEach(function(n){t.hasAttribute(n)&&(e[C(n)]=t.getAttribute(n))}),["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"].forEach(function(n){t.hasAttribute(n)&&(e[C(n)]=JSON.parse(t.getAttribute(n)))}),this.hasAttribute("cross-origin")&&(e.crossOrigin="true"===this.getAttribute("cross-origin")),this.icon=n.icon(e);var r=new CustomEvent("icon:add",{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(r)},e}(/*#__PURE__*/l(HTMLElement)),w={circle:[["lat-lng",t.LatLng]],polyline:[["lat-lngs",t.LatLng]],polygon:[["lat-lng",t.LatLng]],rectangle:[["lat-lng",t.LatLng]]},k={circle:{radius:[Number,null]},polyline:{smoothFactor:[Number,1],noClip:[Boolean,!1]},polygon:{},path:{stroke:[Boolean,!0],color:[String,"#3388ff"],weight:[Number,3],opacity:[Number,1],lineCap:[String,"round"],lineJoin:[String,"round"]},layer:{},rectangle:{}},S={circle:["path","layer"],polyline:["path","layer"],polygon:["polyline"],rectangle:["path","layer"]},N=function(t){var e,n=w[t].map(function(t){return t[0]}),r=Object.keys(k[t]);return S[t].forEach(function(t){var e;(e=r).push.apply(e,Object.keys(k[t]))}),(e=r=r.map(j)).push.apply(e,n),r},j=function(t){return t.split("").map(function(t,e){return t.toUpperCase()===t?(0!==e?"-":"")+t.toLowerCase():t}).join("")},J=function(e,n,r){switch(n){case Number:return parseFloat(e);case Boolean:return"true"===e.toLowerCase();case String:return e;case t.LatLng:return JSON.parse(e);default:return r}},M=function(t,e){console.log(N(e));var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t}a(r,n);var i=r.prototype;return i.connectedCallback=function(){var n=function(t,e){return w[e].map(function(e){var n=e[1];return J(t.getAttribute(e[0]),n,null)})}(this,e),r=function(t,e){var n={},r=function(e){Object.entries(e).forEach(function(e){var r=e[0],a=e[1],i=a[0],o=a[1],l=j(r);t.hasAttribute(l)&&(n[r]=J(t.getAttribute(l),i,o))})};return r(k[e]),S[e].forEach(function(t){r(k[t])}),n}(this,e);this.layer=t.apply(void 0,n.concat([r]));var a=new CustomEvent("map:addTo",{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(a)},i.attributeChangedCallback=function(t,e,n){null!==this.layer&&function(t,e,n){switch(e){case"lat-lngs":t.setLatLngs(JSON.parse(n));break;case"weight":t.setStyle({weight:parseInt(n)});break;case"color":t.setStyle({color:n})}}(this.layer,t,n)},r}(/*#__PURE__*/l(HTMLElement));return n.observedAttributes=N(e),n},T=(customElements.define("l-map",d),customElements.define("l-control-layers",p),customElements.define("l-base-layers",s),customElements.define("l-overlay-layers",y),customElements.define("l-layer-group",h),customElements.define("l-tile-layer",m),customElements.define("l-marker",b),customElements.define("l-popup",v),customElements.define("l-lat-lng-bounds",g),customElements.define("l-image-overlay",E),customElements.define("l-video-overlay",L),customElements.define("l-geojson",O),customElements.define("l-icon",A),customElements.define("l-circle",M(t.circle,"circle")),customElements.define("l-polyline",M(t.polyline,"polyline")),customElements.define("l-polygon",M(t.polygon,"polygon")),void customElements.define("l-rectangle",M(t.rectangle,"rectangle")));module.exports=T;
|
2
|
-
//# sourceMappingURL=leaflet-html.cjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"leaflet-html.cjs","sources":["../src/events.js","../src/l-base-layers.js","../src/l-control-layers.js","../src/l-layer.js","../src/l-layer-group.js","../src/l-map.js","../src/l-marker.js","../src/l-overlay-layers.js","../src/l-popup.js","../src/l-tile-layer.js","../src/l-lat-lng-bounds.js","../src/l-image-overlay.js","../src/l-video-overlay.js","../src/l-geojson.js","../src/l-icon.js","../src/generator.js","../src/index.js"],"sourcesContent":["export const mapAddTo = \"map:addTo\";\nexport const popupAdd = \"popup:add\";\nexport const layerRemove = \"layer:remove\";\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LBaseLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"base\";\n });\n }\n}\n\nexport default LBaseLayers;\n","// @ts-check\n/** @typedef {import(\"leaflet\").Layer} Layer */\nimport { control } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LControlLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n /** @type {{ [key: string]: Layer }} */\n const base = {};\n /** @type {{ [key: string]: Layer }} */\n const overlay = {};\n const controlLayers = control.layers(base, overlay);\n\n this.addEventListener(mapAddTo, (ev) => {\n const { type, name, layer } = ev.detail;\n if (type === \"overlay\") {\n controlLayers.addOverlay(layer, name);\n } else if (type === \"base\") {\n controlLayers.addBaseLayer(layer, name);\n }\n ev.preventDefault();\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: controlLayers,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LControlLayers;\n","class LLayer extends HTMLElement {\n constructor() {\n super()\n this.layer = null\n }\n}\n\nexport default LLayer\n","// @ts-check\nimport { layerGroup } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LLayerGroup extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const group = layerGroup();\n this.layer = group;\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: group,\n name,\n },\n });\n this.dispatchEvent(event);\n\n this.addEventListener(mapAddTo, (ev) => {\n ev.stopPropagation();\n group.addLayer(ev.detail.layer);\n });\n\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n mutation.removedNodes.forEach((node) => {\n if (node instanceof HTMLElement) {\n const leafletId = node.getAttribute(\"leaflet-id\");\n if (leafletId !== null) {\n const layer = group.getLayer(parseInt(leafletId));\n if (typeof layer !== \"undefined\") {\n group.removeLayer(layer);\n }\n }\n }\n });\n });\n });\n observer.observe(this, { childList: true });\n }\n}\n\nexport default LLayerGroup;\n","// @ts-check\nimport * as L from \"leaflet\";\nimport { layerRemove, mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMap extends HTMLElement {\n constructor() {\n super();\n\n this.map = null;\n this.addEventListener(\"map:bounds\", (ev) => {\n const { bounds, method } = ev.detail;\n if (this.map !== null) {\n this.map[method](bounds);\n }\n });\n\n // Observe removed l-tile-layers\n const observer = new MutationObserver(function(mutations) {\n mutations.forEach((mutation) => {\n if (mutation.target instanceof LMap) {\n const el = mutation.target\n mutation.removedNodes.forEach((node) => {\n if (node instanceof LLayer) {\n if ((el.map !== null) && (node.layer !== null)) {\n el.map.removeLayer(node.layer)\n }\n }\n })\n }\n })\n })\n observer.observe(this, { childList: true })\n }\n\n connectedCallback() {\n this.map = L.map(this);\n const center = this.getAttribute(\"center\");\n const zoom = this.getAttribute(\"zoom\");\n if (center !== null && zoom !== null) {\n this.map.setView(JSON.parse(center), parseInt(zoom));\n }\n this.addEventListener(mapAddTo, (ev) => {\n const layer = ev.detail.layer;\n layer.addTo(this.map);\n });\n\n this.addEventListener(layerRemove, (ev) => {\n if (this.map !== null) {\n this.map.removeLayer(ev.detail.layer);\n }\n });\n }\n}\n\nexport default LMap;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\nimport { mapAddTo, popupAdd } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMarker extends LLayer {\n static observedAttributes = [\"lat-lng\", \"opacity\", \"icon\"];\n\n constructor() {\n super();\n this.layer = null;\n this.addEventListener(\"icon:add\", (ev) => {\n ev.stopPropagation();\n this.layer.setIcon(ev.detail.icon);\n });\n }\n\n connectedCallback() {\n const latLng = JSON.parse(this.getAttribute(\"lat-lng\"));\n const opacity = parseFloat(this.getAttribute(\"opacity\") || \"1.0\");\n this.layer = L.marker(latLng, { opacity });\n if (this.hasAttribute(\"icon\")) {\n const icon = L.icon(JSON.parse(this.getAttribute(\"icon\")));\n this.layer.setIcon(icon);\n }\n\n this.setAttribute(\"leaflet-id\", L.stamp(this.layer));\n\n this.addEventListener(popupAdd, (ev) => {\n const { content } = ev.detail;\n this.layer.bindPopup(content);\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"lat-lng\") {\n this.layer.setLatLng(JSON.parse(newValue));\n }\n if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n if (name === \"icon\") {\n this.layer.setIcon(L.icon(JSON.parse(newValue)));\n }\n }\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-marker\", LMarker);\n });\n\n it(\"default icon\", () => {\n const el = document.createElement(\"l-marker\");\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = new L.Icon.Default();\n expect(actual).toEqual(expected);\n });\n\n it(\"adds an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute before appendChild\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"foo.png\" }));\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"foo.png\" });\n expect(actual).toEqual(expected);\n });\n\n it(\"changes an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute after appendChild\n document.body.appendChild(el);\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"bar.png\" }));\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"bar.png\" });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LMarker;\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LOverlayLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"overlay\";\n });\n }\n}\n\nexport default LOverlayLayers;\n","// @ts-check\nimport { popupAdd } from \"./events.js\";\n\nclass LPopup extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const content = this.getAttribute(\"content\");\n const event = new CustomEvent(popupAdd, {\n cancelable: true,\n bubbles: true,\n detail: {\n content,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LPopup;\n","// @ts-check\nimport { tileLayer } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LTileLayer extends LLayer {\n constructor() {\n super();\n this.layer = null\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const urlTemplate = this.getAttribute(\"url-template\");\n if (urlTemplate === null) {\n return;\n }\n const options = {};\n const key = \"attribution\";\n if (this.hasAttribute(key)) {\n options[key] = this.getAttribute(key);\n }\n this.layer = tileLayer(urlTemplate, options);\n const event = new CustomEvent(mapAddTo, {\n detail: { name, layer: this.layer },\n bubbles: true,\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LTileLayer;\n","// @ts-check\nclass LLatLngBounds extends HTMLElement {\n static observedAttributes = [\"bounds\"];\n\n constructor() {\n super();\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n const event = new CustomEvent(\"map:bounds\", {\n bubbles: true,\n detail: {\n bounds: JSON.parse(newValue),\n method: this.getAttribute(\"method\") || \"fitBounds\",\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LLatLngBounds;\n","// @ts-check\nimport { imageOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LImageOverlay extends LLayer {\n static observedAttributes = [\"url\", \"bounds\", \"opacity\"];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const url = this.getAttribute(\"url\");\n if (url === null) {\n console.warn(\"attribute 'url' not set\");\n return;\n }\n let bounds = this.getAttribute(\"bounds\");\n if (bounds === null) {\n console.warn(\"attribute 'bounds' not set\");\n return;\n }\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n };\n this.layer = imageOverlay(url, JSON.parse(bounds), options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n }),\n );\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"url\") {\n this.layer.setUrl(newValue);\n } else if (name === \"bounds\") {\n this.layer.setBounds(JSON.parse(newValue));\n } else if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n }\n }\n}\n\nexport default LImageOverlay;\n","// @ts-check\nimport { videoOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LVideoOverlay extends LLayer {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const url = JSON.parse(this.getAttribute(\"url\"));\n const bounds = JSON.parse(this.getAttribute(\"bounds\"));\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n autoplay: true,\n muted: true,\n playsInline: true,\n };\n const layer = videoOverlay(url, bounds, options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer,\n },\n }),\n );\n }\n}\n\nexport default LVideoOverlay;\n","// @ts-check\nimport { geoJSON } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LGeoJSON extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const value = this.getAttribute(\"geojson\");\n if (value !== null) {\n const layer = geoJSON(JSON.parse(value));\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n bubbles: true,\n cancelable: true,\n detail: {\n layer,\n },\n }),\n );\n }\n }\n}\n\nexport default LGeoJSON;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\n\nconst camelCase = (kebab) => kebab.replace(/-./g, (x) => x[1].toUpperCase());\n\nclass LIcon extends HTMLElement {\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n const options = {};\n\n // Strings\n let keys = [\n \"icon-url\",\n \"icon-retina-url\",\n \"shadow-url\",\n \"shadow-retina-url\",\n \"class-name\",\n ];\n keys.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = this.getAttribute(key);\n }\n });\n\n // Points\n let points = [\n \"icon-anchor\",\n \"icon-size\",\n \"shadow-anchor\",\n \"shadow-size\",\n \"tooltip-anchor\",\n \"popup-anchor\",\n ];\n points.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = JSON.parse(this.getAttribute(key));\n }\n });\n\n if (this.hasAttribute(\"cross-origin\")) {\n options.crossOrigin = this.getAttribute(\"cross-origin\") === \"true\";\n }\n this.icon = L.icon(options);\n\n const event = new CustomEvent(\"icon:add\", {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-icon\", LIcon);\n });\n\n it(\"default\", () => {\n const el = document.createElement(\"l-icon\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"emits icon:add event\", async () => {\n const el = document.createElement(\"l-icon\");\n let promise = new Promise((resolve) => {\n el.addEventListener(\"icon:add\", (ev) => {\n resolve(ev.detail.icon);\n });\n });\n document.body.appendChild(el);\n let actual = await promise;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"options\", () => {\n const el = document.createElement(\"l-icon\");\n el.setAttribute(\"icon-url\", \"url.png\");\n el.setAttribute(\"icon-retina-url\", \"retina.png\");\n el.setAttribute(\"icon-size\", \"[0, 0]\");\n el.setAttribute(\"icon-anchor\", \"[0, 0]\");\n el.setAttribute(\"popup-anchor\", \"[0, 0]\");\n el.setAttribute(\"tooltip-anchor\", \"[0, 0]\");\n el.setAttribute(\"shadow-url\", \"urlShadow.png\");\n el.setAttribute(\"shadow-retina-url\", \"retinaShadow.png\");\n el.setAttribute(\"shadow-size\", \"[0, 0]\");\n el.setAttribute(\"shadow-anchor\", \"[0, 0]\");\n el.setAttribute(\"class-name\", \"foo\");\n el.setAttribute(\"cross-origin\", \"true\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon({\n iconUrl: \"url.png\",\n iconRetinaUrl: \"retina.png\",\n iconSize: [0, 0],\n iconAnchor: [0, 0],\n popupAnchor: [0, 0],\n tooltipAnchor: [0, 0],\n shadowUrl: \"urlShadow.png\",\n shadowRetinaUrl: \"retinaShadow.png\",\n shadowSize: [0, 0],\n shadowAnchor: [0, 0],\n className: \"foo\",\n crossOrigin: true,\n });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LIcon;\n","import { LatLng } from \"leaflet\"\n\nconst ARGS = {\n circle: [[\"lat-lng\", LatLng]],\n polyline: [[\"lat-lngs\", LatLng]], // TODO: LatLng[] array\n polygon: [[\"lat-lng\", LatLng]],\n rectangle: [[\"lat-lng\", LatLng]],\n}\nconst OPTIONS = {\n circle: {\n radius: [Number, null]\n },\n polyline: {\n smoothFactor: [Number, 1.0],\n noClip: [Boolean, false]\n },\n polygon: {},\n path: {\n stroke: [Boolean, true],\n color: [String, \"#3388ff\"],\n weight: [Number, 3],\n opacity: [Number, 1.0],\n lineCap: [String, \"round\"],\n lineJoin: [String, \"round\"],\n },\n layer: {},\n rectangle: {}\n}\n\nconst INHERITS = {\n circle: [\"path\", \"layer\"],\n polyline: [\"path\", \"layer\"],\n polygon: [\"polyline\"],\n rectangle: [\"path\", \"layer\"],\n}\n\n// TODO: Generalise approach\nconst setter = (layer, name, newValue) => {\n switch(name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue))\n break;\n case \"weight\":\n layer.setStyle({ weight: parseInt(newValue) })\n break;\n case \"color\":\n layer.setStyle({ color: newValue })\n break;\n }\n}\n\nconst attributes = (methodName) => {\n let args = ARGS[methodName].map(x => x[0])\n let attrs = Object.keys(OPTIONS[methodName])\n INHERITS[methodName].forEach((parent) => {\n attrs.push(...Object.keys(OPTIONS[parent]))\n })\n attrs = attrs.map(camelToKebab)\n attrs.push(...args)\n return attrs\n}\n\nconst camelToKebab = (s) => {\n return s.split('').map((letter, idx) => {\n return letter.toUpperCase() === letter\n ? `${idx !== 0 ? '-' : ''}${letter.toLowerCase()}`\n : letter;\n }).join('');\n}\n\nconst settings = (el, methodName) => {\n // Gather settings\n let result = {} \n let process = (opts) => {\n Object.entries(opts).forEach(([key, value]) => {\n const [type, val] = value\n const attribute = camelToKebab(key)\n if (el.hasAttribute(attribute)) {\n result[key] = parse(el.getAttribute(attribute), type, val)\n }\n })\n }\n\n // Process inheritance chain\n process(OPTIONS[methodName])\n INHERITS[methodName].forEach(parent => {\n process(OPTIONS[parent])\n })\n return result\n}\n\nconst positional = (el, methodName) => {\n return ARGS[methodName].map(([key, type]) => {\n return parse(el.getAttribute(key), type, null)\n })\n}\n\nconst parse = (text, type, defaultValue) => {\n switch (type) {\n case Number:\n return parseFloat(text)\n case Boolean:\n return text.toLowerCase() === \"true\"\n case String:\n return text\n case LatLng:\n return JSON.parse(text)\n default:\n return defaultValue\n }\n}\n\nconst generator = (method, methodName) => {\n console.log(attributes(methodName))\n class cls extends HTMLElement {\n static observedAttributes = attributes(methodName);\n\n constructor() {\n super()\n this.layer = null\n // TODO: event handlers\n }\n\n connectedCallback() {\n const args = positional(this, methodName)\n const options = settings(this, methodName)\n this.layer = method(...args, options)\n const event = new CustomEvent(\"map:addTo\", {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _, newValue) {\n if (this.layer !== null) {\n setter(this.layer, name, newValue)\n }\n }\n }\n return cls\n}\n\n\nexport default generator\n","// @ts-check\nimport LBaseLayers from \"./l-base-layers.js\";\nimport LControlLayers from \"./l-control-layers.js\";\nimport LLayerGroup from \"./l-layer-group.js\";\nimport LMap from \"./l-map.js\";\nimport LMarker from \"./l-marker.js\";\nimport LOverlayLayers from \"./l-overlay-layers.js\";\nimport LPopup from \"./l-popup.js\";\nimport LTileLayer from \"./l-tile-layer.js\";\nimport LLatLngBounds from \"./l-lat-lng-bounds.js\";\nimport LImageOverlay from \"./l-image-overlay.js\";\nimport LVideoOverlay from \"./l-video-overlay.js\";\nimport LGeoJSON from \"./l-geojson.js\";\nimport LIcon from \"./l-icon.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\"\n\n\nconst init = (() => {\n // Custom elements (order of definition is important)\n customElements.define(\"l-map\", LMap);\n customElements.define(\"l-control-layers\", LControlLayers);\n customElements.define(\"l-base-layers\", LBaseLayers);\n customElements.define(\"l-overlay-layers\", LOverlayLayers);\n customElements.define(\"l-layer-group\", LLayerGroup);\n customElements.define(\"l-tile-layer\", LTileLayer);\n customElements.define(\"l-marker\", LMarker);\n customElements.define(\"l-popup\", LPopup);\n customElements.define(\"l-lat-lng-bounds\", LLatLngBounds);\n customElements.define(\"l-image-overlay\", LImageOverlay);\n customElements.define(\"l-video-overlay\", LVideoOverlay);\n customElements.define(\"l-geojson\", LGeoJSON);\n customElements.define(\"l-icon\", LIcon);\n customElements.define(\"l-circle\", generator(circle, \"circle\"))\n customElements.define(\"l-polyline\", generator(polyline, \"polyline\"))\n customElements.define(\"l-polygon\", generator(polygon, \"polygon\"))\n customElements.define(\"l-rectangle\", generator(rectangle, \"rectangle\"))\n})();\n\nexport default init;\n"],"names":["mapAddTo","popupAdd","LBaseLayers","_HTMLElement","call","this","_inheritsLoose","prototype","connectedCallback","addEventListener","ev","detail","_wrapNativeSuper","HTMLElement","LControlLayers","controlLayers","control","layers","_ev$detail","type","name","layer","addOverlay","addBaseLayer","preventDefault","event","CustomEvent","cancelable","bubbles","dispatchEvent","LLayer","_this","LLayerGroup","_LLayer","getAttribute","group","layerGroup","stopPropagation","addLayer","MutationObserver","mutations","forEach","mutation","removedNodes","node","leafletId","getLayer","parseInt","removeLayer","observe","childList","LMap","map","method","bounds","target","el","_this2","L","center","zoom","setView","JSON","parse","addTo","LMarker","setIcon","icon","_proto","latLng","opacity","parseFloat","marker","hasAttribute","setAttribute","stamp","bindPopup","content","attributeChangedCallback","_oldValue","newValue","setLatLng","setOpacity","observedAttributes","LOverlayLayers","LPopup","LTileLayer","urlTemplate","options","key","tileLayer","LLatLngBounds","_name","LImageOverlay","url","alt","imageOverlay","console","warn","setUrl","setBounds","LVideoOverlay","autoplay","muted","playsInline","videoOverlay","LGeoJSON","value","geoJSON","camelCase","kebab","replace","x","toUpperCase","LIcon","crossOrigin","ARGS","circle","LatLng","polyline","polygon","rectangle","OPTIONS","radius","Number","smoothFactor","noClip","Boolean","path","stroke","color","String","weight","lineCap","lineJoin","INHERITS","attributes","methodName","_attrs2","args","attrs","Object","keys","parent","_attrs","push","apply","camelToKebab","s","split","letter","idx","toLowerCase","join","text","defaultValue","generator","log","cls","_ref2","positional","result","process","opts","entries","_ref","val","attribute","settings","concat","_","setLatLngs","setStyle","setter","init","customElements","define"],"mappings":"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"}
|
@@ -1,2 +0,0 @@
|
|
1
|
-
import*as t from"leaflet";import{control as e,layerGroup as n,tileLayer as s,imageOverlay as a,videoOverlay as l,geoJSON as o,LatLng as i,circle as r,polyline as c,polygon as u,rectangle as d}from"leaflet";const h="map:addTo",p="popup:add";class b extends HTMLElement{constructor(){super()}connectedCallback(){this.addEventListener(h,t=>{t.detail.type="base"})}}class m extends HTMLElement{constructor(){super()}connectedCallback(){const t=e.layers({},{});this.addEventListener(h,e=>{const{type:n,name:s,layer:a}=e.detail;"overlay"===n?t.addOverlay(a,s):"base"===n&&t.addBaseLayer(a,s),e.preventDefault()});const n=new CustomEvent(h,{cancelable:!0,bubbles:!0,detail:{layer:t}});this.dispatchEvent(n)}}class y extends HTMLElement{constructor(){super(),this.layer=null}}class g extends HTMLElement{constructor(){super(),this.map=null,this.addEventListener("map:bounds",t=>{const{bounds:e,method:n}=t.detail;null!==this.map&&this.map[n](e)}),new MutationObserver(function(t){t.forEach(t=>{if(t.target instanceof g){const e=t.target;t.removedNodes.forEach(t=>{t instanceof y&&null!==e.map&&null!==t.layer&&e.map.removeLayer(t.layer)})}})}).observe(this,{childList:!0})}connectedCallback(){this.map=t.map(this);const e=this.getAttribute("center"),n=this.getAttribute("zoom");null!==e&&null!==n&&this.map.setView(JSON.parse(e),parseInt(n)),this.addEventListener(h,t=>{t.detail.layer.addTo(this.map)}),this.addEventListener("layer:remove",t=>{null!==this.map&&this.map.removeLayer(t.detail.layer)})}}class E extends y{constructor(){super(),this.layer=null,this.addEventListener("icon:add",t=>{t.stopPropagation(),this.layer.setIcon(t.detail.icon)})}connectedCallback(){const e=JSON.parse(this.getAttribute("lat-lng")),n=parseFloat(this.getAttribute("opacity")||"1.0");if(this.layer=t.marker(e,{opacity:n}),this.hasAttribute("icon")){const e=t.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(e)}this.setAttribute("leaflet-id",t.stamp(this.layer)),this.addEventListener(p,t=>{const{content:e}=t.detail;this.layer.bindPopup(e)});const s=new CustomEvent(h,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(s)}attributeChangedCallback(e,n,s){null!==this.layer&&("lat-lng"===e&&this.layer.setLatLng(JSON.parse(s)),"opacity"===e&&this.layer.setOpacity(parseFloat(s)),"icon"===e&&this.layer.setIcon(t.icon(JSON.parse(s))))}}if(E.observedAttributes=["lat-lng","opacity","icon"],import.meta.vitest){const{it:e,expect:n,beforeAll:s}=import.meta.vitest;s(()=>{customElements.define("l-marker",E)}),e("default icon",()=>{const e=document.createElement("l-marker");document.body.appendChild(e);let s=e.layer.getIcon(),a=new t.Icon.Default;n(s).toEqual(a)}),e("adds an icon",()=>{const e=document.createElement("l-marker");e.setAttribute("icon",JSON.stringify({iconUrl:"foo.png"})),document.body.appendChild(e);let s=e.layer.getIcon(),a=t.icon({iconUrl:"foo.png"});n(s).toEqual(a)}),e("changes an icon",()=>{const e=document.createElement("l-marker");document.body.appendChild(e),e.setAttribute("icon",JSON.stringify({iconUrl:"bar.png"}));let s=e.layer.getIcon(),a=t.icon({iconUrl:"bar.png"});n(s).toEqual(a)})}class f extends HTMLElement{constructor(){super()}connectedCallback(){this.addEventListener(h,t=>{t.detail.type="overlay"})}}class v extends HTMLElement{constructor(){super()}connectedCallback(){const t=this.getAttribute("content"),e=new CustomEvent(p,{cancelable:!0,bubbles:!0,detail:{content:t}});this.dispatchEvent(e)}}class A extends HTMLElement{constructor(){super()}attributeChangedCallback(t,e,n){const s=new CustomEvent("map:bounds",{bubbles:!0,detail:{bounds:JSON.parse(n),method:this.getAttribute("method")||"fitBounds"}});this.dispatchEvent(s)}}A.observedAttributes=["bounds"];class C extends y{constructor(){super(),this.layer=null}connectedCallback(){const t=this.getAttribute("url");if(null===t)return void console.warn("attribute 'url' not set");let e=this.getAttribute("bounds");if(null===e)return void console.warn("attribute 'bounds' not set");const n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||""};this.layer=a(t,JSON.parse(e),n),this.dispatchEvent(new CustomEvent(h,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}}))}attributeChangedCallback(t,e,n){null!==this.layer&&("url"===t?this.layer.setUrl(n):"bounds"===t?this.layer.setBounds(JSON.parse(n)):"opacity"===t&&this.layer.setOpacity(parseFloat(n)))}}C.observedAttributes=["url","bounds","opacity"];class w extends HTMLElement{constructor(){super()}connectedCallback(){const t=this.getAttribute("geojson");if(null!==t){const e=o(JSON.parse(t));this.dispatchEvent(new CustomEvent(h,{bubbles:!0,cancelable:!0,detail:{layer:e}}))}}}const L=t=>t.replace(/-./g,t=>t[1].toUpperCase());class k extends HTMLElement{constructor(){super(),this.icon=null}connectedCallback(){const e={};["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"].forEach(t=>{this.hasAttribute(t)&&(e[L(t)]=this.getAttribute(t))}),["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"].forEach(t=>{this.hasAttribute(t)&&(e[L(t)]=JSON.parse(this.getAttribute(t)))}),this.hasAttribute("cross-origin")&&(e.crossOrigin="true"===this.getAttribute("cross-origin")),this.icon=t.icon(e);const n=new CustomEvent("icon:add",{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(n)}}if(import.meta.vitest){const{it:e,expect:n,beforeAll:s}=import.meta.vitest;s(()=>{customElements.define("l-icon",k)}),e("default",()=>{const e=document.createElement("l-icon");document.body.appendChild(e);let s=e.icon,a=t.icon();n(s).toEqual(a)}),e("emits icon:add event",async()=>{const e=document.createElement("l-icon");let s=new Promise(t=>{e.addEventListener("icon:add",e=>{t(e.detail.icon)})});document.body.appendChild(e);let a=await s,l=t.icon();n(a).toEqual(l)}),e("options",()=>{const e=document.createElement("l-icon");e.setAttribute("icon-url","url.png"),e.setAttribute("icon-retina-url","retina.png"),e.setAttribute("icon-size","[0, 0]"),e.setAttribute("icon-anchor","[0, 0]"),e.setAttribute("popup-anchor","[0, 0]"),e.setAttribute("tooltip-anchor","[0, 0]"),e.setAttribute("shadow-url","urlShadow.png"),e.setAttribute("shadow-retina-url","retinaShadow.png"),e.setAttribute("shadow-size","[0, 0]"),e.setAttribute("shadow-anchor","[0, 0]"),e.setAttribute("class-name","foo"),e.setAttribute("cross-origin","true"),document.body.appendChild(e);let s=e.icon,a=t.icon({iconUrl:"url.png",iconRetinaUrl:"retina.png",iconSize:[0,0],iconAnchor:[0,0],popupAnchor:[0,0],tooltipAnchor:[0,0],shadowUrl:"urlShadow.png",shadowRetinaUrl:"retinaShadow.png",shadowSize:[0,0],shadowAnchor:[0,0],className:"foo",crossOrigin:!0});n(s).toEqual(a)})}const S={circle:[["lat-lng",i]],polyline:[["lat-lngs",i]],polygon:[["lat-lng",i]],rectangle:[["lat-lng",i]]},O={circle:{radius:[Number,null]},polyline:{smoothFactor:[Number,1],noClip:[Boolean,!1]},polygon:{},path:{stroke:[Boolean,!0],color:[String,"#3388ff"],weight:[Number,3],opacity:[Number,1],lineCap:[String,"round"],lineJoin:[String,"round"]},layer:{},rectangle:{}},N={circle:["path","layer"],polyline:["path","layer"],polygon:["polyline"],rectangle:["path","layer"]},x=t=>{let e=S[t].map(t=>t[0]),n=Object.keys(O[t]);return N[t].forEach(t=>{n.push(...Object.keys(O[t]))}),n=n.map(J),n.push(...e),n},J=t=>t.split("").map((t,e)=>t.toUpperCase()===t?`${0!==e?"-":""}${t.toLowerCase()}`:t).join(""),T=(t,e,n)=>{switch(e){case Number:return parseFloat(t);case Boolean:return"true"===t.toLowerCase();case String:return t;case i:return JSON.parse(t);default:return n}},M=(t,e)=>{console.log(x(e));class n extends HTMLElement{constructor(){super(),this.layer=null}connectedCallback(){const n=((t,e)=>S[e].map(([e,n])=>T(t.getAttribute(e),n,null)))(this,e),s=((t,e)=>{let n={},s=e=>{Object.entries(e).forEach(([e,s])=>{const[a,l]=s,o=J(e);t.hasAttribute(o)&&(n[e]=T(t.getAttribute(o),a,l))})};return s(O[e]),N[e].forEach(t=>{s(O[t])}),n})(this,e);this.layer=t(...n,s);const a=new CustomEvent("map:addTo",{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(a)}attributeChangedCallback(t,e,n){null!==this.layer&&((t,e,n)=>{switch(e){case"lat-lngs":t.setLatLngs(JSON.parse(n));break;case"weight":t.setStyle({weight:parseInt(n)});break;case"color":t.setStyle({color:n})}})(this.layer,t,n)}}return n.observedAttributes=x(e),n},H=(customElements.define("l-map",g),customElements.define("l-control-layers",m),customElements.define("l-base-layers",b),customElements.define("l-overlay-layers",f),customElements.define("l-layer-group",class extends y{constructor(){super(),this.layer=null}connectedCallback(){const t=this.getAttribute("name"),e=n();this.layer=e;const s=new CustomEvent(h,{cancelable:!0,bubbles:!0,detail:{layer:e,name:t}});this.dispatchEvent(s),this.addEventListener(h,t=>{t.stopPropagation(),e.addLayer(t.detail.layer)}),new MutationObserver(function(t){t.forEach(t=>{t.removedNodes.forEach(t=>{if(t instanceof HTMLElement){const n=t.getAttribute("leaflet-id");if(null!==n){const t=e.getLayer(parseInt(n));void 0!==t&&e.removeLayer(t)}}})})}).observe(this,{childList:!0})}}),customElements.define("l-tile-layer",class extends y{constructor(){super(),this.layer=null}connectedCallback(){const t=this.getAttribute("name"),e=this.getAttribute("url-template");if(null===e)return;const n={},a="attribution";this.hasAttribute(a)&&(n[a]=this.getAttribute(a)),this.layer=s(e,n);const l=new CustomEvent(h,{detail:{name:t,layer:this.layer},bubbles:!0});this.dispatchEvent(l)}}),customElements.define("l-marker",E),customElements.define("l-popup",v),customElements.define("l-lat-lng-bounds",A),customElements.define("l-image-overlay",C),customElements.define("l-video-overlay",class extends y{constructor(){super()}connectedCallback(){const t=JSON.parse(this.getAttribute("url")),e=JSON.parse(this.getAttribute("bounds")),n={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||"",autoplay:!0,muted:!0,playsInline:!0},s=l(t,e,n);this.dispatchEvent(new CustomEvent(h,{cancelable:!0,bubbles:!0,detail:{layer:s}}))}}),customElements.define("l-geojson",w),customElements.define("l-icon",k),customElements.define("l-circle",M(r,"circle")),customElements.define("l-polyline",M(c,"polyline")),customElements.define("l-polygon",M(u,"polygon")),void customElements.define("l-rectangle",M(d,"rectangle")));export{H as default};
|
2
|
-
//# sourceMappingURL=leaflet-html.modern.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"leaflet-html.modern.js","sources":["../src/events.js","../src/l-base-layers.js","../src/l-control-layers.js","../src/l-layer.js","../src/l-map.js","../src/l-marker.js","../src/l-overlay-layers.js","../src/l-popup.js","../src/l-lat-lng-bounds.js","../src/l-image-overlay.js","../src/l-geojson.js","../src/l-icon.js","../src/generator.js","../src/index.js","../src/l-layer-group.js","../src/l-tile-layer.js","../src/l-video-overlay.js"],"sourcesContent":["export const mapAddTo = \"map:addTo\";\nexport const popupAdd = \"popup:add\";\nexport const layerRemove = \"layer:remove\";\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LBaseLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"base\";\n });\n }\n}\n\nexport default LBaseLayers;\n","// @ts-check\n/** @typedef {import(\"leaflet\").Layer} Layer */\nimport { control } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LControlLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n /** @type {{ [key: string]: Layer }} */\n const base = {};\n /** @type {{ [key: string]: Layer }} */\n const overlay = {};\n const controlLayers = control.layers(base, overlay);\n\n this.addEventListener(mapAddTo, (ev) => {\n const { type, name, layer } = ev.detail;\n if (type === \"overlay\") {\n controlLayers.addOverlay(layer, name);\n } else if (type === \"base\") {\n controlLayers.addBaseLayer(layer, name);\n }\n ev.preventDefault();\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: controlLayers,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LControlLayers;\n","class LLayer extends HTMLElement {\n constructor() {\n super()\n this.layer = null\n }\n}\n\nexport default LLayer\n","// @ts-check\nimport * as L from \"leaflet\";\nimport { layerRemove, mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMap extends HTMLElement {\n constructor() {\n super();\n\n this.map = null;\n this.addEventListener(\"map:bounds\", (ev) => {\n const { bounds, method } = ev.detail;\n if (this.map !== null) {\n this.map[method](bounds);\n }\n });\n\n // Observe removed l-tile-layers\n const observer = new MutationObserver(function(mutations) {\n mutations.forEach((mutation) => {\n if (mutation.target instanceof LMap) {\n const el = mutation.target\n mutation.removedNodes.forEach((node) => {\n if (node instanceof LLayer) {\n if ((el.map !== null) && (node.layer !== null)) {\n el.map.removeLayer(node.layer)\n }\n }\n })\n }\n })\n })\n observer.observe(this, { childList: true })\n }\n\n connectedCallback() {\n this.map = L.map(this);\n const center = this.getAttribute(\"center\");\n const zoom = this.getAttribute(\"zoom\");\n if (center !== null && zoom !== null) {\n this.map.setView(JSON.parse(center), parseInt(zoom));\n }\n this.addEventListener(mapAddTo, (ev) => {\n const layer = ev.detail.layer;\n layer.addTo(this.map);\n });\n\n this.addEventListener(layerRemove, (ev) => {\n if (this.map !== null) {\n this.map.removeLayer(ev.detail.layer);\n }\n });\n }\n}\n\nexport default LMap;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\nimport { mapAddTo, popupAdd } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMarker extends LLayer {\n static observedAttributes = [\"lat-lng\", \"opacity\", \"icon\"];\n\n constructor() {\n super();\n this.layer = null;\n this.addEventListener(\"icon:add\", (ev) => {\n ev.stopPropagation();\n this.layer.setIcon(ev.detail.icon);\n });\n }\n\n connectedCallback() {\n const latLng = JSON.parse(this.getAttribute(\"lat-lng\"));\n const opacity = parseFloat(this.getAttribute(\"opacity\") || \"1.0\");\n this.layer = L.marker(latLng, { opacity });\n if (this.hasAttribute(\"icon\")) {\n const icon = L.icon(JSON.parse(this.getAttribute(\"icon\")));\n this.layer.setIcon(icon);\n }\n\n this.setAttribute(\"leaflet-id\", L.stamp(this.layer));\n\n this.addEventListener(popupAdd, (ev) => {\n const { content } = ev.detail;\n this.layer.bindPopup(content);\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"lat-lng\") {\n this.layer.setLatLng(JSON.parse(newValue));\n }\n if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n if (name === \"icon\") {\n this.layer.setIcon(L.icon(JSON.parse(newValue)));\n }\n }\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-marker\", LMarker);\n });\n\n it(\"default icon\", () => {\n const el = document.createElement(\"l-marker\");\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = new L.Icon.Default();\n expect(actual).toEqual(expected);\n });\n\n it(\"adds an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute before appendChild\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"foo.png\" }));\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"foo.png\" });\n expect(actual).toEqual(expected);\n });\n\n it(\"changes an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute after appendChild\n document.body.appendChild(el);\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"bar.png\" }));\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"bar.png\" });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LMarker;\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LOverlayLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"overlay\";\n });\n }\n}\n\nexport default LOverlayLayers;\n","// @ts-check\nimport { popupAdd } from \"./events.js\";\n\nclass LPopup extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const content = this.getAttribute(\"content\");\n const event = new CustomEvent(popupAdd, {\n cancelable: true,\n bubbles: true,\n detail: {\n content,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LPopup;\n","// @ts-check\nclass LLatLngBounds extends HTMLElement {\n static observedAttributes = [\"bounds\"];\n\n constructor() {\n super();\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n const event = new CustomEvent(\"map:bounds\", {\n bubbles: true,\n detail: {\n bounds: JSON.parse(newValue),\n method: this.getAttribute(\"method\") || \"fitBounds\",\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LLatLngBounds;\n","// @ts-check\nimport { imageOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LImageOverlay extends LLayer {\n static observedAttributes = [\"url\", \"bounds\", \"opacity\"];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const url = this.getAttribute(\"url\");\n if (url === null) {\n console.warn(\"attribute 'url' not set\");\n return;\n }\n let bounds = this.getAttribute(\"bounds\");\n if (bounds === null) {\n console.warn(\"attribute 'bounds' not set\");\n return;\n }\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n };\n this.layer = imageOverlay(url, JSON.parse(bounds), options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n }),\n );\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"url\") {\n this.layer.setUrl(newValue);\n } else if (name === \"bounds\") {\n this.layer.setBounds(JSON.parse(newValue));\n } else if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n }\n }\n}\n\nexport default LImageOverlay;\n","// @ts-check\nimport { geoJSON } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LGeoJSON extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const value = this.getAttribute(\"geojson\");\n if (value !== null) {\n const layer = geoJSON(JSON.parse(value));\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n bubbles: true,\n cancelable: true,\n detail: {\n layer,\n },\n }),\n );\n }\n }\n}\n\nexport default LGeoJSON;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\n\nconst camelCase = (kebab) => kebab.replace(/-./g, (x) => x[1].toUpperCase());\n\nclass LIcon extends HTMLElement {\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n const options = {};\n\n // Strings\n let keys = [\n \"icon-url\",\n \"icon-retina-url\",\n \"shadow-url\",\n \"shadow-retina-url\",\n \"class-name\",\n ];\n keys.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = this.getAttribute(key);\n }\n });\n\n // Points\n let points = [\n \"icon-anchor\",\n \"icon-size\",\n \"shadow-anchor\",\n \"shadow-size\",\n \"tooltip-anchor\",\n \"popup-anchor\",\n ];\n points.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = JSON.parse(this.getAttribute(key));\n }\n });\n\n if (this.hasAttribute(\"cross-origin\")) {\n options.crossOrigin = this.getAttribute(\"cross-origin\") === \"true\";\n }\n this.icon = L.icon(options);\n\n const event = new CustomEvent(\"icon:add\", {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-icon\", LIcon);\n });\n\n it(\"default\", () => {\n const el = document.createElement(\"l-icon\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"emits icon:add event\", async () => {\n const el = document.createElement(\"l-icon\");\n let promise = new Promise((resolve) => {\n el.addEventListener(\"icon:add\", (ev) => {\n resolve(ev.detail.icon);\n });\n });\n document.body.appendChild(el);\n let actual = await promise;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"options\", () => {\n const el = document.createElement(\"l-icon\");\n el.setAttribute(\"icon-url\", \"url.png\");\n el.setAttribute(\"icon-retina-url\", \"retina.png\");\n el.setAttribute(\"icon-size\", \"[0, 0]\");\n el.setAttribute(\"icon-anchor\", \"[0, 0]\");\n el.setAttribute(\"popup-anchor\", \"[0, 0]\");\n el.setAttribute(\"tooltip-anchor\", \"[0, 0]\");\n el.setAttribute(\"shadow-url\", \"urlShadow.png\");\n el.setAttribute(\"shadow-retina-url\", \"retinaShadow.png\");\n el.setAttribute(\"shadow-size\", \"[0, 0]\");\n el.setAttribute(\"shadow-anchor\", \"[0, 0]\");\n el.setAttribute(\"class-name\", \"foo\");\n el.setAttribute(\"cross-origin\", \"true\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon({\n iconUrl: \"url.png\",\n iconRetinaUrl: \"retina.png\",\n iconSize: [0, 0],\n iconAnchor: [0, 0],\n popupAnchor: [0, 0],\n tooltipAnchor: [0, 0],\n shadowUrl: \"urlShadow.png\",\n shadowRetinaUrl: \"retinaShadow.png\",\n shadowSize: [0, 0],\n shadowAnchor: [0, 0],\n className: \"foo\",\n crossOrigin: true,\n });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LIcon;\n","import { LatLng } from \"leaflet\"\n\nconst ARGS = {\n circle: [[\"lat-lng\", LatLng]],\n polyline: [[\"lat-lngs\", LatLng]], // TODO: LatLng[] array\n polygon: [[\"lat-lng\", LatLng]],\n rectangle: [[\"lat-lng\", LatLng]],\n}\nconst OPTIONS = {\n circle: {\n radius: [Number, null]\n },\n polyline: {\n smoothFactor: [Number, 1.0],\n noClip: [Boolean, false]\n },\n polygon: {},\n path: {\n stroke: [Boolean, true],\n color: [String, \"#3388ff\"],\n weight: [Number, 3],\n opacity: [Number, 1.0],\n lineCap: [String, \"round\"],\n lineJoin: [String, \"round\"],\n },\n layer: {},\n rectangle: {}\n}\n\nconst INHERITS = {\n circle: [\"path\", \"layer\"],\n polyline: [\"path\", \"layer\"],\n polygon: [\"polyline\"],\n rectangle: [\"path\", \"layer\"],\n}\n\n// TODO: Generalise approach\nconst setter = (layer, name, newValue) => {\n switch(name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue))\n break;\n case \"weight\":\n layer.setStyle({ weight: parseInt(newValue) })\n break;\n case \"color\":\n layer.setStyle({ color: newValue })\n break;\n }\n}\n\nconst attributes = (methodName) => {\n let args = ARGS[methodName].map(x => x[0])\n let attrs = Object.keys(OPTIONS[methodName])\n INHERITS[methodName].forEach((parent) => {\n attrs.push(...Object.keys(OPTIONS[parent]))\n })\n attrs = attrs.map(camelToKebab)\n attrs.push(...args)\n return attrs\n}\n\nconst camelToKebab = (s) => {\n return s.split('').map((letter, idx) => {\n return letter.toUpperCase() === letter\n ? `${idx !== 0 ? '-' : ''}${letter.toLowerCase()}`\n : letter;\n }).join('');\n}\n\nconst settings = (el, methodName) => {\n // Gather settings\n let result = {} \n let process = (opts) => {\n Object.entries(opts).forEach(([key, value]) => {\n const [type, val] = value\n const attribute = camelToKebab(key)\n if (el.hasAttribute(attribute)) {\n result[key] = parse(el.getAttribute(attribute), type, val)\n }\n })\n }\n\n // Process inheritance chain\n process(OPTIONS[methodName])\n INHERITS[methodName].forEach(parent => {\n process(OPTIONS[parent])\n })\n return result\n}\n\nconst positional = (el, methodName) => {\n return ARGS[methodName].map(([key, type]) => {\n return parse(el.getAttribute(key), type, null)\n })\n}\n\nconst parse = (text, type, defaultValue) => {\n switch (type) {\n case Number:\n return parseFloat(text)\n case Boolean:\n return text.toLowerCase() === \"true\"\n case String:\n return text\n case LatLng:\n return JSON.parse(text)\n default:\n return defaultValue\n }\n}\n\nconst generator = (method, methodName) => {\n console.log(attributes(methodName))\n class cls extends HTMLElement {\n static observedAttributes = attributes(methodName);\n\n constructor() {\n super()\n this.layer = null\n // TODO: event handlers\n }\n\n connectedCallback() {\n const args = positional(this, methodName)\n const options = settings(this, methodName)\n this.layer = method(...args, options)\n const event = new CustomEvent(\"map:addTo\", {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _, newValue) {\n if (this.layer !== null) {\n setter(this.layer, name, newValue)\n }\n }\n }\n return cls\n}\n\n\nexport default generator\n","// @ts-check\nimport LBaseLayers from \"./l-base-layers.js\";\nimport LControlLayers from \"./l-control-layers.js\";\nimport LLayerGroup from \"./l-layer-group.js\";\nimport LMap from \"./l-map.js\";\nimport LMarker from \"./l-marker.js\";\nimport LOverlayLayers from \"./l-overlay-layers.js\";\nimport LPopup from \"./l-popup.js\";\nimport LTileLayer from \"./l-tile-layer.js\";\nimport LLatLngBounds from \"./l-lat-lng-bounds.js\";\nimport LImageOverlay from \"./l-image-overlay.js\";\nimport LVideoOverlay from \"./l-video-overlay.js\";\nimport LGeoJSON from \"./l-geojson.js\";\nimport LIcon from \"./l-icon.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\"\n\n\nconst init = (() => {\n // Custom elements (order of definition is important)\n customElements.define(\"l-map\", LMap);\n customElements.define(\"l-control-layers\", LControlLayers);\n customElements.define(\"l-base-layers\", LBaseLayers);\n customElements.define(\"l-overlay-layers\", LOverlayLayers);\n customElements.define(\"l-layer-group\", LLayerGroup);\n customElements.define(\"l-tile-layer\", LTileLayer);\n customElements.define(\"l-marker\", LMarker);\n customElements.define(\"l-popup\", LPopup);\n customElements.define(\"l-lat-lng-bounds\", LLatLngBounds);\n customElements.define(\"l-image-overlay\", LImageOverlay);\n customElements.define(\"l-video-overlay\", LVideoOverlay);\n customElements.define(\"l-geojson\", LGeoJSON);\n customElements.define(\"l-icon\", LIcon);\n customElements.define(\"l-circle\", generator(circle, \"circle\"))\n customElements.define(\"l-polyline\", generator(polyline, \"polyline\"))\n customElements.define(\"l-polygon\", generator(polygon, \"polygon\"))\n customElements.define(\"l-rectangle\", generator(rectangle, \"rectangle\"))\n})();\n\nexport default init;\n","// @ts-check\nimport { layerGroup } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LLayerGroup extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const group = layerGroup();\n this.layer = group;\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: group,\n name,\n },\n });\n this.dispatchEvent(event);\n\n this.addEventListener(mapAddTo, (ev) => {\n ev.stopPropagation();\n group.addLayer(ev.detail.layer);\n });\n\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n mutation.removedNodes.forEach((node) => {\n if (node instanceof HTMLElement) {\n const leafletId = node.getAttribute(\"leaflet-id\");\n if (leafletId !== null) {\n const layer = group.getLayer(parseInt(leafletId));\n if (typeof layer !== \"undefined\") {\n group.removeLayer(layer);\n }\n }\n }\n });\n });\n });\n observer.observe(this, { childList: true });\n }\n}\n\nexport default LLayerGroup;\n","// @ts-check\nimport { tileLayer } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LTileLayer extends LLayer {\n constructor() {\n super();\n this.layer = null\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const urlTemplate = this.getAttribute(\"url-template\");\n if (urlTemplate === null) {\n return;\n }\n const options = {};\n const key = \"attribution\";\n if (this.hasAttribute(key)) {\n options[key] = this.getAttribute(key);\n }\n this.layer = tileLayer(urlTemplate, options);\n const event = new CustomEvent(mapAddTo, {\n detail: { name, layer: this.layer },\n bubbles: true,\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LTileLayer;\n","// @ts-check\nimport { videoOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LVideoOverlay extends LLayer {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const url = JSON.parse(this.getAttribute(\"url\"));\n const bounds = JSON.parse(this.getAttribute(\"bounds\"));\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n autoplay: true,\n muted: true,\n playsInline: true,\n };\n const layer = videoOverlay(url, bounds, options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer,\n },\n }),\n );\n }\n}\n\nexport default LVideoOverlay;\n"],"names":["mapAddTo","popupAdd","LBaseLayers","HTMLElement","constructor","super","connectedCallback","this","addEventListener","ev","detail","LControlLayers","controlLayers","control","layers","type","name","layer","addOverlay","addBaseLayer","preventDefault","event","CustomEvent","cancelable","bubbles","dispatchEvent","LLayer","LMap","map","bounds","method","MutationObserver","mutations","forEach","mutation","target","el","removedNodes","node","removeLayer","observe","childList","L","center","getAttribute","zoom","setView","JSON","parse","parseInt","addTo","LMarker","stopPropagation","setIcon","icon","latLng","opacity","parseFloat","marker","hasAttribute","setAttribute","stamp","content","bindPopup","attributeChangedCallback","_oldValue","newValue","setLatLng","setOpacity","observedAttributes","vitest","it","expect","beforeAll","customElements","define","document","createElement","body","appendChild","actual","getIcon","expected","Icon","Default","toEqual","stringify","iconUrl","LOverlayLayers","LPopup","LLatLngBounds","_name","LImageOverlay","url","console","warn","options","alt","imageOverlay","setUrl","setBounds","LGeoJSON","value","geoJSON","camelCase","kebab","replace","x","toUpperCase","LIcon","key","crossOrigin","async","promise","Promise","resolve","iconRetinaUrl","iconSize","iconAnchor","popupAnchor","tooltipAnchor","shadowUrl","shadowRetinaUrl","shadowSize","shadowAnchor","className","ARGS","circle","LatLng","polyline","polygon","rectangle","OPTIONS","radius","Number","smoothFactor","noClip","Boolean","path","stroke","color","String","weight","lineCap","lineJoin","INHERITS","attributes","methodName","args","attrs","Object","keys","parent","push","camelToKebab","s","split","letter","idx","toLowerCase","join","text","defaultValue","generator","log","cls","positional","settings","result","process","opts","entries","val","attribute","_","setter","setLatLngs","setStyle","init","group","layerGroup","addLayer","leafletId","getLayer","urlTemplate","tileLayer","autoplay","muted","playsInline","videoOverlay"],"mappings":"oNAAaA,EAAW,YACXC,EAAW,YCExB,MAAMC,UAAoBC,YACxBC,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GACEC,KAAKC,iBAAiBR,EAAWS,IAC/BA,EAAGC,OAAa,KAAI,MACtB,EACF,ECPF,MAAMC,UAAuBR,YAC3BC,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GAEE,MAGMM,EAAgBC,EAAQC,OAHjB,CAAE,EAEC,CAAA,GAGhBP,KAAKC,iBAAiBR,EAAWS,IAC/B,MAAMM,KAAEA,EAAIC,KAAEA,EAAIC,MAAEA,GAAUR,EAAGC,OACpB,YAATK,EACFH,EAAcM,WAAWD,EAAOD,GACd,SAATD,GACTH,EAAcO,aAAaF,EAAOD,GAEpCP,EAAGW,gBAAc,GAGnB,MAAMC,EAAQ,IAAIC,YAAYtB,EAAU,CACtCuB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,MAAOL,KAGXL,KAAKkB,cAAcJ,EACrB,ECnCF,MAAMK,UAAevB,YACnBC,WAAAA,GACEC,QACAE,KAAKU,MAAQ,IACf,ECCF,MAAMU,UAAaxB,YACjBC,WAAAA,GACEC,QAEAE,KAAKqB,IAAM,KACXrB,KAAKC,iBAAiB,aAAeC,IACnC,MAAMoB,OAAEA,EAAMC,OAAEA,GAAWrB,EAAGC,OACb,OAAbH,KAAKqB,KACPrB,KAAKqB,IAAIE,GAAQD,EACnB,GAIe,IAAIE,iBAAiB,SAASC,GAC7CA,EAAUC,QAASC,IACjB,GAAIA,EAASC,kBAAkBR,EAAM,CACnC,MAAMS,EAAKF,EAASC,OACpBD,EAASG,aAAaJ,QAASK,IACzBA,aAAgBZ,GACF,OAAXU,EAAGR,KAAiC,OAAfU,EAAKrB,OAC7BmB,EAAGR,IAAIW,YAAYD,EAAKrB,MAE5B,EAEJ,GAEJ,GACSuB,QAAQjC,KAAM,CAAEkC,WAAW,GACtC,CAEAnC,iBAAAA,GACEC,KAAKqB,IAAMc,EAAEd,IAAIrB,MACjB,MAAMoC,EAASpC,KAAKqC,aAAa,UAC3BC,EAAOtC,KAAKqC,aAAa,QAChB,OAAXD,GAA4B,OAATE,GACrBtC,KAAKqB,IAAIkB,QAAQC,KAAKC,MAAML,GAASM,SAASJ,IAEhDtC,KAAKC,iBAAiBR,EAAWS,IACjBA,EAAGC,OAAOO,MAClBiC,MAAM3C,KAAKqB,OAGnBrB,KAAKC,iBJ7CkB,eI6CaC,IACjB,OAAbF,KAAKqB,KACPrB,KAAKqB,IAAIW,YAAY9B,EAAGC,OAAOO,MACjC,EAEJ,EC/CF,MAAMkC,UAAgBzB,EAGpBtB,WAAAA,GACEC,QACAE,KAAKU,MAAQ,KACbV,KAAKC,iBAAiB,WAAaC,IACjCA,EAAG2C,kBACH7C,KAAKU,MAAMoC,QAAQ5C,EAAGC,OAAO4C,KAC/B,EACF,CAEAhD,iBAAAA,GACE,MAAMiD,EAASR,KAAKC,MAAMzC,KAAKqC,aAAa,YACtCY,EAAUC,WAAWlD,KAAKqC,aAAa,YAAc,OAE3D,GADArC,KAAKU,MAAQyB,EAAEgB,OAAOH,EAAQ,CAAEC,YAC5BjD,KAAKoD,aAAa,QAAS,CAC7B,MAAML,EAAOZ,EAAEY,KAAKP,KAAKC,MAAMzC,KAAKqC,aAAa,UACjDrC,KAAKU,MAAMoC,QAAQC,EACrB,CAEA/C,KAAKqD,aAAa,aAAclB,EAAEmB,MAAMtD,KAAKU,QAE7CV,KAAKC,iBAAiBP,EAAWQ,IAC/B,MAAMqD,QAAEA,GAAYrD,EAAGC,OACvBH,KAAKU,MAAM8C,UAAUD,EAAO,GAG9B,MAAMzC,EAAQ,IAAIC,YAAYtB,EAAU,CACtCuB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,MAAOV,KAAKU,SAGhBV,KAAKkB,cAAcJ,EACrB,CAEA2C,wBAAAA,CAAyBhD,EAAMiD,EAAWC,GACrB,OAAf3D,KAAKU,QACM,YAATD,GACFT,KAAKU,MAAMkD,UAAUpB,KAAKC,MAAMkB,IAErB,YAATlD,GACFT,KAAKU,MAAMmD,WAAWX,WAAWS,IAEtB,SAATlD,GACFT,KAAKU,MAAMoC,QAAQX,EAAEY,KAAKP,KAAKC,MAAMkB,KAG3C,EAGF,GArDMf,EACGkB,mBAAqB,CAAC,UAAW,UAAW,oBAoDrCC,OAAQ,CACtB,MAAMC,GAAEA,EAAEC,OAAEA,EAAMC,UAAEA,eAA0BH,OAE9CG,EAAU,KACRC,eAAeC,OAAO,WAAYxB,EAAO,GAG3CoB,EAAG,eAAgB,KACjB,MAAMnC,EAAKwC,SAASC,cAAc,YAClCD,SAASE,KAAKC,YAAY3C,GAC1B,IAAI4C,EAAS5C,EAAGnB,MAAMgE,UAClBC,EAAW,IAAIxC,EAAEyC,KAAKC,QAC1BZ,EAAOQ,GAAQK,QAAQH,KAGzBX,EAAG,eAAgB,KACjB,MAAMnC,EAAKwC,SAASC,cAAc,YAElCzC,EAAGwB,aAAa,OAAQb,KAAKuC,UAAU,CAAEC,QAAS,aAClDX,SAASE,KAAKC,YAAY3C,GAC1B,IAAI4C,EAAS5C,EAAGnB,MAAMgE,UAClBC,EAAWxC,EAAEY,KAAK,CAAEiC,QAAS,YACjCf,EAAOQ,GAAQK,QAAQH,KAGzBX,EAAG,kBAAmB,KACpB,MAAMnC,EAAKwC,SAASC,cAAc,YAElCD,SAASE,KAAKC,YAAY3C,GAC1BA,EAAGwB,aAAa,OAAQb,KAAKuC,UAAU,CAAEC,QAAS,aAClD,IAAIP,EAAS5C,EAAGnB,MAAMgE,UAClBC,EAAWxC,EAAEY,KAAK,CAAEiC,QAAS,YACjCf,EAAOQ,GAAQK,QAAQH,EAAQ,EAEnC,CCzFA,MAAMM,UAAuBrF,YAC3BC,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GACEC,KAAKC,iBAAiBR,EAAWS,IAC/BA,EAAGC,OAAa,KAAI,SACtB,EACF,ECTF,MAAM+E,UAAetF,YACnBC,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GACE,MAAMwD,EAAUvD,KAAKqC,aAAa,WAC5BvB,EAAQ,IAAIC,YAAYrB,EAAU,CACtCsB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNoD,aAGJvD,KAAKkB,cAAcJ,EACrB,ECjBF,MAAMqE,UAAsBvF,YAG1BC,WAAAA,GACEC,OACF,CAEA2D,wBAAAA,CAAyB2B,EAAO1B,EAAWC,GACzC,MAAM7C,EAAQ,IAAIC,YAAY,aAAc,CAC1CE,SAAS,EACTd,OAAQ,CACNmB,OAAQkB,KAAKC,MAAMkB,GACnBpC,OAAQvB,KAAKqC,aAAa,WAAa,eAG3CrC,KAAKkB,cAAcJ,EACrB,EAhBIqE,EACGrB,mBAAqB,CAAC,UCG/B,MAAMuB,UAAsBlE,EAG1BtB,WAAAA,GACEC,QACAE,KAAKU,MAAQ,IACf,CAEAX,iBAAAA,GACE,MAAMuF,EAAMtF,KAAKqC,aAAa,OAC9B,GAAY,OAARiD,EAEF,YADAC,QAAQC,KAAK,2BAGf,IAAIlE,EAAStB,KAAKqC,aAAa,UAC/B,GAAe,OAAXf,EAEF,YADAiE,QAAQC,KAAK,8BAGf,MAAMC,EAAU,CACdxC,QAASC,WAAWlD,KAAKqC,aAAa,YAAc,OACpDqD,IAAK1F,KAAKqC,aAAa,QAAU,IAEnCrC,KAAKU,MAAQiF,EAAaL,EAAK9C,KAAKC,MAAMnB,GAASmE,GACnDzF,KAAKkB,cACH,IAAIH,YAAYtB,EAAU,CACxBuB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,MAAOV,KAAKU,SAIpB,CAEA+C,wBAAAA,CAAyBhD,EAAMiD,EAAWC,GACrB,OAAf3D,KAAKU,QACM,QAATD,EACFT,KAAKU,MAAMkF,OAAOjC,GACA,WAATlD,EACTT,KAAKU,MAAMmF,UAAUrD,KAAKC,MAAMkB,IACd,YAATlD,GACTT,KAAKU,MAAMmD,WAAWX,WAAWS,IAGvC,EA7CI0B,EACGvB,mBAAqB,CAAC,MAAO,SAAU,WCFhD,MAAMgC,UAAiBlG,YACrBC,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GACE,MAAMgG,EAAQ/F,KAAKqC,aAAa,WAChC,GAAc,OAAV0D,EAAgB,CAClB,MAAMrF,EAAQsF,EAAQxD,KAAKC,MAAMsD,IACjC/F,KAAKkB,cACH,IAAIH,YAAYtB,EAAU,CACxBwB,SAAS,EACTD,YAAY,EACZb,OAAQ,CACNO,WAIR,CACF,ECpBF,MAAMuF,EAAaC,GAAUA,EAAMC,QAAQ,MAAQC,GAAMA,EAAE,GAAGC,eAE9D,MAAMC,UAAc1G,YAClBC,WAAAA,GACEC,QACAE,KAAK+C,KAAO,IACd,CAEAhD,iBAAAA,GACE,MAAM0F,EAAU,CAAE,EAGP,CACT,WACA,kBACA,aACA,oBACA,cAEG/D,QAAS6E,IACRvG,KAAKoD,aAAamD,KACpBd,EAAQQ,EAAUM,IAAQvG,KAAKqC,aAAakE,GAC9C,GAIW,CACX,cACA,YACA,gBACA,cACA,iBACA,gBAEK7E,QAAS6E,IACVvG,KAAKoD,aAAamD,KACpBd,EAAQQ,EAAUM,IAAQ/D,KAAKC,MAAMzC,KAAKqC,aAAakE,IACzD,GAGEvG,KAAKoD,aAAa,kBACpBqC,EAAQe,YAAoD,SAAtCxG,KAAKqC,aAAa,iBAE1CrC,KAAK+C,KAAOZ,EAAEY,KAAK0C,GAEnB,MAAM3E,EAAQ,IAAIC,YAAY,WAAY,CACxCC,YAAY,EACZC,SAAS,EACTd,OAAQ,CACN4C,KAAM/C,KAAK+C,QAGf/C,KAAKkB,cAAcJ,EACrB,EAGF,eAAgBiD,OAAQ,CACtB,MAAMC,GAAEA,EAAEC,OAAEA,EAAMC,UAAEA,eAA0BH,OAE9CG,EAAU,KACRC,eAAeC,OAAO,SAAUkC,EAClC,GAEAtC,EAAG,UAAW,KACZ,MAAMnC,EAAKwC,SAASC,cAAc,UAClCD,SAASE,KAAKC,YAAY3C,GAE1B,IAAI4C,EAAS5C,EAAGkB,KACZ4B,EAAWxC,EAAEY,OACjBkB,EAAOQ,GAAQK,QAAQH,EACzB,GAEAX,EAAG,uBAAwByC,UACzB,MAAM5E,EAAKwC,SAASC,cAAc,UAClC,IAAIoC,EAAU,IAAIC,QAASC,IACzB/E,EAAG5B,iBAAiB,WAAaC,IAC/B0G,EAAQ1G,EAAGC,OAAO4C,KAAI,EACvB,GAEHsB,SAASE,KAAKC,YAAY3C,GAC1B,IAAI4C,QAAeiC,EACf/B,EAAWxC,EAAEY,OACjBkB,EAAOQ,GAAQK,QAAQH,EAAQ,GAGjCX,EAAG,UAAW,KACZ,MAAMnC,EAAKwC,SAASC,cAAc,UAClCzC,EAAGwB,aAAa,WAAY,WAC5BxB,EAAGwB,aAAa,kBAAmB,cACnCxB,EAAGwB,aAAa,YAAa,UAC7BxB,EAAGwB,aAAa,cAAe,UAC/BxB,EAAGwB,aAAa,eAAgB,UAChCxB,EAAGwB,aAAa,iBAAkB,UAClCxB,EAAGwB,aAAa,aAAc,iBAC9BxB,EAAGwB,aAAa,oBAAqB,oBACrCxB,EAAGwB,aAAa,cAAe,UAC/BxB,EAAGwB,aAAa,gBAAiB,UACjCxB,EAAGwB,aAAa,aAAc,OAC9BxB,EAAGwB,aAAa,eAAgB,QAChCgB,SAASE,KAAKC,YAAY3C,GAE1B,IAAI4C,EAAS5C,EAAGkB,KACZ4B,EAAWxC,EAAEY,KAAK,CACpBiC,QAAS,UACT6B,cAAe,aACfC,SAAU,CAAC,EAAG,GACdC,WAAY,CAAC,EAAG,GAChBC,YAAa,CAAC,EAAG,GACjBC,cAAe,CAAC,EAAG,GACnBC,UAAW,gBACXC,gBAAiB,mBACjBC,WAAY,CAAC,EAAG,GAChBC,aAAc,CAAC,EAAG,GAClBC,UAAW,MACXd,aAAa,IAEfvC,EAAOQ,GAAQK,QAAQH,EAAQ,EAEnC,CCvHA,MAAM4C,EAAO,CACXC,OAAQ,CAAC,CAAC,UAAWC,IACrBC,SAAU,CAAC,CAAC,WAAYD,IACxBE,QAAS,CAAC,CAAC,UAAWF,IACtBG,UAAW,CAAC,CAAC,UAAWH,KAEpBI,EAAU,CACdL,OAAQ,CACNM,OAAQ,CAACC,OAAQ,OAEnBL,SAAU,CACRM,aAAc,CAACD,OAAQ,GACvBE,OAAQ,CAACC,SAAS,IAEpBP,QAAS,CAAE,EACXQ,KAAM,CACJC,OAAQ,CAACF,SAAS,GAClBG,MAAO,CAACC,OAAQ,WAChBC,OAAQ,CAACR,OAAQ,GACjB9E,QAAS,CAAC8E,OAAQ,GAClBS,QAAS,CAACF,OAAQ,SAClBG,SAAU,CAACH,OAAQ,UAErB5H,MAAO,CAAE,EACTkH,UAAW,CAAA,GAGPc,EAAW,CACflB,OAAQ,CAAC,OAAQ,SACjBE,SAAU,CAAC,OAAQ,SACnBC,QAAS,CAAC,YACVC,UAAW,CAAC,OAAQ,UAkBhBe,EAAcC,IAClB,IAAIC,EAAOtB,EAAKqB,GAAYvH,IAAI+E,GAAKA,EAAE,IACnC0C,EAAQC,OAAOC,KAAKnB,EAAQe,IAMhC,OALAF,EAASE,GAAYlH,QAASuH,IAC5BH,EAAMI,QAAQH,OAAOC,KAAKnB,EAAQoB,IACpC,GACAH,EAAQA,EAAMzH,IAAI8H,GAClBL,EAAMI,QAAQL,GACPC,GAGHK,EAAgBC,GACZA,EAAEC,MAAM,IAAIhI,IAAI,CAACiI,EAAQC,IACvBD,EAAOjD,gBAAkBiD,EAC5B,GAAU,IAARC,EAAY,IAAM,KAAKD,EAAOE,gBACjCF,GACFG,KAAK,IA8BLhH,EAAQA,CAACiH,EAAMlJ,EAAMmJ,KACzB,OAAQnJ,GACN,KAAKuH,OACH,OAAO7E,WAAWwG,GACpB,KAAKxB,QACH,MAA8B,SAAvBwB,EAAKF,cACd,KAAKlB,OACH,OAAOoB,EACT,KAAKjC,EACH,OAAOjF,KAAKC,MAAMiH,GACpB,QACE,OAAOC,EACX,EAGIC,EAAYA,CAACrI,EAAQqH,KACzBrD,QAAQsE,IAAIlB,EAAWC,IACvB,MAAMkB,UAAYlK,YAGhBC,WAAAA,GACEC,QACAE,KAAKU,MAAQ,IAEf,CAEAX,iBAAAA,GACE,MAAM8I,EAjCOkB,EAAClI,EAAI+G,IACfrB,EAAKqB,GAAYvH,IAAI,EAAEkF,EAAK/F,KAC1BiC,EAAMZ,EAAGQ,aAAakE,GAAM/F,EAAM,OA+B1BuJ,CAAW/J,KAAM4I,GACxBnD,EAvDKuE,EAACnI,EAAI+G,KAEpB,IAAIqB,EAAS,CAAE,EACXC,EAAWC,IACbpB,OAAOqB,QAAQD,GAAMzI,QAAQ,EAAE6E,EAAKR,MAClC,MAAOvF,EAAM6J,GAAOtE,EACduE,EAAYnB,EAAa5C,GAC3B1E,EAAGuB,aAAakH,KAClBL,EAAO1D,GAAO9D,EAAMZ,EAAGQ,aAAaiI,GAAY9J,EAAM6J,GACxD,EAEJ,EAOA,OAJAH,EAAQrC,EAAQe,IAChBF,EAASE,GAAYlH,QAAQuH,IAC3BiB,EAAQrC,EAAQoB,GAClB,GACOgB,GAqCaD,CAAShK,KAAM4I,GAC/B5I,KAAKU,MAAQa,KAAUsH,EAAMpD,GAC7B,MAAM3E,EAAQ,IAAIC,YAAY,YAAa,CACzCC,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,MAAOV,KAAKU,SAGhBV,KAAKkB,cAAcJ,EACrB,CAEA2C,wBAAAA,CAAyBhD,EAAM8J,EAAG5G,GACb,OAAf3D,KAAKU,OArGA8J,EAAC9J,EAAOD,EAAMkD,KAC3B,OAAOlD,GACL,IAAK,WACDC,EAAM+J,WAAWjI,KAAKC,MAAMkB,IAC5B,MACJ,IAAK,SACDjD,EAAMgK,SAAS,CAAEnC,OAAQ7F,SAASiB,KAClC,MACJ,IAAK,QACDjD,EAAMgK,SAAS,CAAErC,MAAO1E,IAE9B,EA2FM6G,CAAOxK,KAAKU,MAAOD,EAAMkD,EAE7B,EAEF,OA7BMmG,EACGhG,mBAAqB6E,EAAWC,GA4BlCkB,GC7HHa,GAEJxG,eAAeC,OAAO,QAAShD,GAC/B+C,eAAeC,OAAO,mBAAoBhE,GAC1C+D,eAAeC,OAAO,gBAAiBzE,GACvCwE,eAAeC,OAAO,mBAAoBa,GAC1Cd,eAAeC,OAAO,gBCnBxB,cAA0BjD,EACxBtB,WAAAA,GACEC,QACAE,KAAKU,MAAQ,IACf,CAEAX,iBAAAA,GACE,MAAMU,EAAOT,KAAKqC,aAAa,QACzBuI,EAAQC,IACd7K,KAAKU,MAAQkK,EAEb,MAAM9J,EAAQ,IAAIC,YAAYtB,EAAU,CACtCuB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,MAAOkK,EACPnK,UAGJT,KAAKkB,cAAcJ,GAEnBd,KAAKC,iBAAiBR,EAAWS,IAC/BA,EAAG2C,kBACH+H,EAAME,SAAS5K,EAAGC,OAAOO,SAGV,IAAIc,iBAAiB,SAAUC,GAC9CA,EAAUC,QAASC,IACjBA,EAASG,aAAaJ,QAASK,IAC7B,GAAIA,aAAgBnC,YAAa,CAC/B,MAAMmL,EAAYhJ,EAAKM,aAAa,cACpC,GAAkB,OAAd0I,EAAoB,CACtB,MAAMrK,EAAQkK,EAAMI,SAAStI,SAASqI,SACjB,IAAVrK,GACTkK,EAAM5I,YAAYtB,EAEtB,CACF,KAGN,GACSuB,QAAQjC,KAAM,CAAEkC,WAAW,GACtC,IDtBAiC,eAAeC,OAAO,eEpBxB,cAAyBjD,EACvBtB,WAAAA,GACEC,QACAE,KAAKU,MAAQ,IACf,CAEAX,iBAAAA,GACE,MAAMU,EAAOT,KAAKqC,aAAa,QACzB4I,EAAcjL,KAAKqC,aAAa,gBACtC,GAAoB,OAAhB4I,EACF,OAEF,MAAMxF,EAAU,CAAA,EACVc,EAAM,cACRvG,KAAKoD,aAAamD,KACpBd,EAAQc,GAAOvG,KAAKqC,aAAakE,IAEnCvG,KAAKU,MAAQwK,EAAUD,EAAaxF,GACpC,MAAM3E,EAAQ,IAAIC,YAAYtB,EAAU,CACtCU,OAAQ,CAAEM,OAAMC,MAAOV,KAAKU,OAC5BO,SAAS,IAEXjB,KAAKkB,cAAcJ,EACrB,IFFAqD,eAAeC,OAAO,WAAYxB,GAClCuB,eAAeC,OAAO,UAAWc,GACjCf,eAAeC,OAAO,mBAAoBe,GAC1ChB,eAAeC,OAAO,kBAAmBiB,GACzClB,eAAeC,OAAO,kBGzBxB,cAA4BjD,EAC1BtB,WAAAA,GACEC,OACF,CAEAC,iBAAAA,GACE,MAAMuF,EAAM9C,KAAKC,MAAMzC,KAAKqC,aAAa,QACnCf,EAASkB,KAAKC,MAAMzC,KAAKqC,aAAa,WACtCoD,EAAU,CACdxC,QAASC,WAAWlD,KAAKqC,aAAa,YAAc,OACpDqD,IAAK1F,KAAKqC,aAAa,QAAU,GACjC8I,UAAU,EACVC,OAAO,EACPC,aAAa,GAET3K,EAAQ4K,EAAahG,EAAKhE,EAAQmE,GACxCzF,KAAKkB,cACH,IAAIH,YAAYtB,EAAU,CACxBuB,YAAY,EACZC,SAAS,EACTd,OAAQ,CACNO,WAIR,IHCAyD,eAAeC,OAAO,YAAa0B,GACnC3B,eAAeC,OAAO,SAAUkC,GAChCnC,eAAeC,OAAO,WAAYwF,EAAUpC,EAAQ,WACpDrD,eAAeC,OAAO,aAAcwF,EAAUlC,EAAU,aACxDvD,eAAeC,OAAO,YAAawF,EAAUjC,EAAS,iBACtDxD,eAAeC,OAAO,cAAewF,EAAUhC,EAAW"}
|
package/dist/leaflet-html.umd.js
DELETED
@@ -1,2 +0,0 @@
|
|
1
|
-
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("leaflet")):"function"==typeof define&&define.amd?define(["leaflet"],e):(t||self).leafletHtml=e(t.leaflet)}(this,function(t){function e(t){if(t&&t.__esModule)return t;var e=Object.create(null);return t&&Object.keys(t).forEach(function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(t,n);Object.defineProperty(e,n,r.get?r:{enumerable:!0,get:function(){return t[n]}})}}),e.default=t,e}var n=/*#__PURE__*/e(t);function r(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(r=function(){return!!t})()}function a(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,o(t,e)}function i(t){return i=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},i(t)}function o(t,e){return o=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},o(t,e)}function l(t){var e="function"==typeof Map?new Map:void 0;return l=function(t){if(null===t||!function(t){try{return-1!==Function.toString.call(t).indexOf("[native code]")}catch(e){return"function"==typeof t}}(t))return t;if("function"!=typeof t)throw new TypeError("Super expression must either be null or a function");if(void 0!==e){if(e.has(t))return e.get(t);e.set(t,n)}function n(){return function(t,e,n){if(r())return Reflect.construct.apply(null,arguments);var a=[null];a.push.apply(a,e);var i=new(t.bind.apply(t,a));return n&&o(i,n.prototype),i}(t,arguments,i(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),o(n,t)},l(t)}var c="map:addTo",u="popup:add",s=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){this.addEventListener(c,function(t){t.detail.type="base"})},e}(/*#__PURE__*/l(HTMLElement)),p=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=t.control.layers({},{});this.addEventListener(c,function(t){var n=t.detail,r=n.type,a=n.name,i=n.layer;"overlay"===r?e.addOverlay(i,a):"base"===r&&e.addBaseLayer(i,a),t.preventDefault()});var n=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:e}});this.dispatchEvent(n)},n}(/*#__PURE__*/l(HTMLElement)),f=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return a(e,t),e}(/*#__PURE__*/l(HTMLElement)),h=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("name"),n=t.layerGroup();this.layer=n;var r=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:n,name:e}});this.dispatchEvent(r),this.addEventListener(c,function(t){t.stopPropagation(),n.addLayer(t.detail.layer)}),new MutationObserver(function(t){t.forEach(function(t){t.removedNodes.forEach(function(t){if(t instanceof HTMLElement){var e=t.getAttribute("leaflet-id");if(null!==e){var r=n.getLayer(parseInt(e));void 0!==r&&n.removeLayer(r)}}})})}).observe(this,{childList:!0})},n}(f),d=/*#__PURE__*/function(t){function e(){var n;return(n=t.call(this)||this).map=null,n.addEventListener("map:bounds",function(t){var e=t.detail;null!==n.map&&n.map[e.method](e.bounds)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof e){var n=t.target;t.removedNodes.forEach(function(t){t instanceof f&&null!==n.map&&null!==t.layer&&n.map.removeLayer(t.layer)})}})}).observe(n,{childList:!0}),n}return a(e,t),e.prototype.connectedCallback=function(){var t=this;this.map=n.map(this);var e=this.getAttribute("center"),r=this.getAttribute("zoom");null!==e&&null!==r&&this.map.setView(JSON.parse(e),parseInt(r)),this.addEventListener(c,function(e){e.detail.layer.addTo(t.map)}),this.addEventListener("layer:remove",function(e){null!==t.map&&t.map.removeLayer(e.detail.layer)})},e}(/*#__PURE__*/l(HTMLElement)),b=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e.addEventListener("icon:add",function(t){t.stopPropagation(),e.layer.setIcon(t.detail.icon)}),e}a(e,t);var r=e.prototype;return r.connectedCallback=function(){var t=this,e=JSON.parse(this.getAttribute("lat-lng")),r=parseFloat(this.getAttribute("opacity")||"1.0");if(this.layer=n.marker(e,{opacity:r}),this.hasAttribute("icon")){var a=n.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(a)}this.setAttribute("leaflet-id",n.stamp(this.layer)),this.addEventListener(u,function(e){t.layer.bindPopup(e.detail.content)});var i=new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(i)},r.attributeChangedCallback=function(t,e,r){null!==this.layer&&("lat-lng"===t&&this.layer.setLatLng(JSON.parse(r)),"opacity"===t&&this.layer.setOpacity(parseFloat(r)),"icon"===t&&this.layer.setIcon(n.icon(JSON.parse(r))))},e}(f);b.observedAttributes=["lat-lng","opacity","icon"];var y=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){this.addEventListener(c,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/l(HTMLElement)),v=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("content"),e=new CustomEvent(u,{cancelable:!0,bubbles:!0,detail:{content:t}});this.dispatchEvent(e)},e}(/*#__PURE__*/l(HTMLElement)),m=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("name"),n=this.getAttribute("url-template");if(null!==n){var r={},a="attribution";this.hasAttribute(a)&&(r[a]=this.getAttribute(a)),this.layer=t.tileLayer(n,r);var i=new CustomEvent(c,{detail:{name:e,layer:this.layer},bubbles:!0});this.dispatchEvent(i)}},n}(f),g=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return a(e,t),e.prototype.attributeChangedCallback=function(t,e,n){var r=new CustomEvent("map:bounds",{bubbles:!0,detail:{bounds:JSON.parse(n),method:this.getAttribute("method")||"fitBounds"}});this.dispatchEvent(r)},e}(/*#__PURE__*/l(HTMLElement));g.observedAttributes=["bounds"];var E=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t}a(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this.getAttribute("url");if(null!==e){var n=this.getAttribute("bounds");if(null!==n){var r={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||""};this.layer=t.imageOverlay(e,JSON.parse(n),r),this.dispatchEvent(new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}}))}else console.warn("attribute 'bounds' not set")}else console.warn("attribute 'url' not set")},r.attributeChangedCallback=function(t,e,n){null!==this.layer&&("url"===t?this.layer.setUrl(n):"bounds"===t?this.layer.setBounds(JSON.parse(n)):"opacity"===t&&this.layer.setOpacity(parseFloat(n)))},n}(f);E.observedAttributes=["url","bounds","opacity"];var L=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=JSON.parse(this.getAttribute("url")),n=JSON.parse(this.getAttribute("bounds")),r={opacity:parseFloat(this.getAttribute("opacity")||"1.0"),alt:this.getAttribute("alt")||"",autoplay:!0,muted:!0,playsInline:!0},a=t.videoOverlay(e,n,r);this.dispatchEvent(new CustomEvent(c,{cancelable:!0,bubbles:!0,detail:{layer:a}}))},n}(f),O=/*#__PURE__*/function(e){function n(){return e.call(this)||this}return a(n,e),n.prototype.connectedCallback=function(){var e=this.getAttribute("geojson");if(null!==e){var n=t.geoJSON(JSON.parse(e));this.dispatchEvent(new CustomEvent(c,{bubbles:!0,cancelable:!0,detail:{layer:n}}))}},n}(/*#__PURE__*/l(HTMLElement)),C=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},A=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).icon=null,e}return a(e,t),e.prototype.connectedCallback=function(){var t=this,e={};["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"].forEach(function(n){t.hasAttribute(n)&&(e[C(n)]=t.getAttribute(n))}),["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"].forEach(function(n){t.hasAttribute(n)&&(e[C(n)]=JSON.parse(t.getAttribute(n)))}),this.hasAttribute("cross-origin")&&(e.crossOrigin="true"===this.getAttribute("cross-origin")),this.icon=n.icon(e);var r=new CustomEvent("icon:add",{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(r)},e}(/*#__PURE__*/l(HTMLElement)),w={circle:[["lat-lng",t.LatLng]],polyline:[["lat-lngs",t.LatLng]],polygon:[["lat-lng",t.LatLng]],rectangle:[["lat-lng",t.LatLng]]},k={circle:{radius:[Number,null]},polyline:{smoothFactor:[Number,1],noClip:[Boolean,!1]},polygon:{},path:{stroke:[Boolean,!0],color:[String,"#3388ff"],weight:[Number,3],opacity:[Number,1],lineCap:[String,"round"],lineJoin:[String,"round"]},layer:{},rectangle:{}},S={circle:["path","layer"],polyline:["path","layer"],polygon:["polyline"],rectangle:["path","layer"]},N=function(t){var e,n=w[t].map(function(t){return t[0]}),r=Object.keys(k[t]);return S[t].forEach(function(t){var e;(e=r).push.apply(e,Object.keys(k[t]))}),(e=r=r.map(j)).push.apply(e,n),r},j=function(t){return t.split("").map(function(t,e){return t.toUpperCase()===t?(0!==e?"-":"")+t.toLowerCase():t}).join("")},T=function(e,n,r){switch(n){case Number:return parseFloat(e);case Boolean:return"true"===e.toLowerCase();case String:return e;case t.LatLng:return JSON.parse(e);default:return r}},J=function(t,e){console.log(N(e));var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t}a(r,n);var i=r.prototype;return i.connectedCallback=function(){var n=function(t,e){return w[e].map(function(e){var n=e[1];return T(t.getAttribute(e[0]),n,null)})}(this,e),r=function(t,e){var n={},r=function(e){Object.entries(e).forEach(function(e){var r=e[0],a=e[1],i=a[0],o=a[1],l=j(r);t.hasAttribute(l)&&(n[r]=T(t.getAttribute(l),i,o))})};return r(k[e]),S[e].forEach(function(t){r(k[t])}),n}(this,e);this.layer=t.apply(void 0,n.concat([r]));var a=new CustomEvent("map:addTo",{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(a)},i.attributeChangedCallback=function(t,e,n){null!==this.layer&&function(t,e,n){switch(e){case"lat-lngs":t.setLatLngs(JSON.parse(n));break;case"weight":t.setStyle({weight:parseInt(n)});break;case"color":t.setStyle({color:n})}}(this.layer,t,n)},r}(/*#__PURE__*/l(HTMLElement));return n.observedAttributes=N(e),n};return customElements.define("l-map",d),customElements.define("l-control-layers",p),customElements.define("l-base-layers",s),customElements.define("l-overlay-layers",y),customElements.define("l-layer-group",h),customElements.define("l-tile-layer",m),customElements.define("l-marker",b),customElements.define("l-popup",v),customElements.define("l-lat-lng-bounds",g),customElements.define("l-image-overlay",E),customElements.define("l-video-overlay",L),customElements.define("l-geojson",O),customElements.define("l-icon",A),customElements.define("l-circle",J(t.circle,"circle")),customElements.define("l-polyline",J(t.polyline,"polyline")),customElements.define("l-polygon",J(t.polygon,"polygon")),void customElements.define("l-rectangle",J(t.rectangle,"rectangle"))});
|
2
|
-
//# sourceMappingURL=leaflet-html.umd.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"leaflet-html.umd.js","sources":["../src/events.js","../src/l-base-layers.js","../src/l-control-layers.js","../src/l-layer.js","../src/l-layer-group.js","../src/l-map.js","../src/l-marker.js","../src/l-overlay-layers.js","../src/l-popup.js","../src/l-tile-layer.js","../src/l-lat-lng-bounds.js","../src/l-image-overlay.js","../src/l-video-overlay.js","../src/l-geojson.js","../src/l-icon.js","../src/generator.js","../src/index.js"],"sourcesContent":["export const mapAddTo = \"map:addTo\";\nexport const popupAdd = \"popup:add\";\nexport const layerRemove = \"layer:remove\";\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LBaseLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"base\";\n });\n }\n}\n\nexport default LBaseLayers;\n","// @ts-check\n/** @typedef {import(\"leaflet\").Layer} Layer */\nimport { control } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LControlLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n /** @type {{ [key: string]: Layer }} */\n const base = {};\n /** @type {{ [key: string]: Layer }} */\n const overlay = {};\n const controlLayers = control.layers(base, overlay);\n\n this.addEventListener(mapAddTo, (ev) => {\n const { type, name, layer } = ev.detail;\n if (type === \"overlay\") {\n controlLayers.addOverlay(layer, name);\n } else if (type === \"base\") {\n controlLayers.addBaseLayer(layer, name);\n }\n ev.preventDefault();\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: controlLayers,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LControlLayers;\n","class LLayer extends HTMLElement {\n constructor() {\n super()\n this.layer = null\n }\n}\n\nexport default LLayer\n","// @ts-check\nimport { layerGroup } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LLayerGroup extends LLayer {\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const group = layerGroup();\n this.layer = group;\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: group,\n name,\n },\n });\n this.dispatchEvent(event);\n\n this.addEventListener(mapAddTo, (ev) => {\n ev.stopPropagation();\n group.addLayer(ev.detail.layer);\n });\n\n const observer = new MutationObserver(function (mutations) {\n mutations.forEach((mutation) => {\n mutation.removedNodes.forEach((node) => {\n if (node instanceof HTMLElement) {\n const leafletId = node.getAttribute(\"leaflet-id\");\n if (leafletId !== null) {\n const layer = group.getLayer(parseInt(leafletId));\n if (typeof layer !== \"undefined\") {\n group.removeLayer(layer);\n }\n }\n }\n });\n });\n });\n observer.observe(this, { childList: true });\n }\n}\n\nexport default LLayerGroup;\n","// @ts-check\nimport * as L from \"leaflet\";\nimport { layerRemove, mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMap extends HTMLElement {\n constructor() {\n super();\n\n this.map = null;\n this.addEventListener(\"map:bounds\", (ev) => {\n const { bounds, method } = ev.detail;\n if (this.map !== null) {\n this.map[method](bounds);\n }\n });\n\n // Observe removed l-tile-layers\n const observer = new MutationObserver(function(mutations) {\n mutations.forEach((mutation) => {\n if (mutation.target instanceof LMap) {\n const el = mutation.target\n mutation.removedNodes.forEach((node) => {\n if (node instanceof LLayer) {\n if ((el.map !== null) && (node.layer !== null)) {\n el.map.removeLayer(node.layer)\n }\n }\n })\n }\n })\n })\n observer.observe(this, { childList: true })\n }\n\n connectedCallback() {\n this.map = L.map(this);\n const center = this.getAttribute(\"center\");\n const zoom = this.getAttribute(\"zoom\");\n if (center !== null && zoom !== null) {\n this.map.setView(JSON.parse(center), parseInt(zoom));\n }\n this.addEventListener(mapAddTo, (ev) => {\n const layer = ev.detail.layer;\n layer.addTo(this.map);\n });\n\n this.addEventListener(layerRemove, (ev) => {\n if (this.map !== null) {\n this.map.removeLayer(ev.detail.layer);\n }\n });\n }\n}\n\nexport default LMap;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\nimport { mapAddTo, popupAdd } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LMarker extends LLayer {\n static observedAttributes = [\"lat-lng\", \"opacity\", \"icon\"];\n\n constructor() {\n super();\n this.layer = null;\n this.addEventListener(\"icon:add\", (ev) => {\n ev.stopPropagation();\n this.layer.setIcon(ev.detail.icon);\n });\n }\n\n connectedCallback() {\n const latLng = JSON.parse(this.getAttribute(\"lat-lng\"));\n const opacity = parseFloat(this.getAttribute(\"opacity\") || \"1.0\");\n this.layer = L.marker(latLng, { opacity });\n if (this.hasAttribute(\"icon\")) {\n const icon = L.icon(JSON.parse(this.getAttribute(\"icon\")));\n this.layer.setIcon(icon);\n }\n\n this.setAttribute(\"leaflet-id\", L.stamp(this.layer));\n\n this.addEventListener(popupAdd, (ev) => {\n const { content } = ev.detail;\n this.layer.bindPopup(content);\n });\n\n const event = new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"lat-lng\") {\n this.layer.setLatLng(JSON.parse(newValue));\n }\n if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n if (name === \"icon\") {\n this.layer.setIcon(L.icon(JSON.parse(newValue)));\n }\n }\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-marker\", LMarker);\n });\n\n it(\"default icon\", () => {\n const el = document.createElement(\"l-marker\");\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = new L.Icon.Default();\n expect(actual).toEqual(expected);\n });\n\n it(\"adds an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute before appendChild\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"foo.png\" }));\n document.body.appendChild(el);\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"foo.png\" });\n expect(actual).toEqual(expected);\n });\n\n it(\"changes an icon\", () => {\n const el = document.createElement(\"l-marker\");\n // Set attribute after appendChild\n document.body.appendChild(el);\n el.setAttribute(\"icon\", JSON.stringify({ iconUrl: \"bar.png\" }));\n let actual = el.layer.getIcon();\n let expected = L.icon({ iconUrl: \"bar.png\" });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LMarker;\n","// @ts-check\nimport { mapAddTo } from \"./events.js\";\n\nclass LOverlayLayers extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n this.addEventListener(mapAddTo, (ev) => {\n ev.detail[\"type\"] = \"overlay\";\n });\n }\n}\n\nexport default LOverlayLayers;\n","// @ts-check\nimport { popupAdd } from \"./events.js\";\n\nclass LPopup extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const content = this.getAttribute(\"content\");\n const event = new CustomEvent(popupAdd, {\n cancelable: true,\n bubbles: true,\n detail: {\n content,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LPopup;\n","// @ts-check\nimport { tileLayer } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LTileLayer extends LLayer {\n constructor() {\n super();\n this.layer = null\n }\n\n connectedCallback() {\n const name = this.getAttribute(\"name\");\n const urlTemplate = this.getAttribute(\"url-template\");\n if (urlTemplate === null) {\n return;\n }\n const options = {};\n const key = \"attribution\";\n if (this.hasAttribute(key)) {\n options[key] = this.getAttribute(key);\n }\n this.layer = tileLayer(urlTemplate, options);\n const event = new CustomEvent(mapAddTo, {\n detail: { name, layer: this.layer },\n bubbles: true,\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LTileLayer;\n","// @ts-check\nclass LLatLngBounds extends HTMLElement {\n static observedAttributes = [\"bounds\"];\n\n constructor() {\n super();\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n const event = new CustomEvent(\"map:bounds\", {\n bubbles: true,\n detail: {\n bounds: JSON.parse(newValue),\n method: this.getAttribute(\"method\") || \"fitBounds\",\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nexport default LLatLngBounds;\n","// @ts-check\nimport { imageOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LImageOverlay extends LLayer {\n static observedAttributes = [\"url\", \"bounds\", \"opacity\"];\n\n constructor() {\n super();\n this.layer = null;\n }\n\n connectedCallback() {\n const url = this.getAttribute(\"url\");\n if (url === null) {\n console.warn(\"attribute 'url' not set\");\n return;\n }\n let bounds = this.getAttribute(\"bounds\");\n if (bounds === null) {\n console.warn(\"attribute 'bounds' not set\");\n return;\n }\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n };\n this.layer = imageOverlay(url, JSON.parse(bounds), options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer,\n },\n }),\n );\n }\n\n attributeChangedCallback(name, _oldValue, newValue) {\n if (this.layer !== null) {\n if (name === \"url\") {\n this.layer.setUrl(newValue);\n } else if (name === \"bounds\") {\n this.layer.setBounds(JSON.parse(newValue));\n } else if (name === \"opacity\") {\n this.layer.setOpacity(parseFloat(newValue));\n }\n }\n }\n}\n\nexport default LImageOverlay;\n","// @ts-check\nimport { videoOverlay } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\nimport LLayer from \"./l-layer.js\";\n\nclass LVideoOverlay extends LLayer {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const url = JSON.parse(this.getAttribute(\"url\"));\n const bounds = JSON.parse(this.getAttribute(\"bounds\"));\n const options = {\n opacity: parseFloat(this.getAttribute(\"opacity\") || \"1.0\"),\n alt: this.getAttribute(\"alt\") || \"\",\n autoplay: true,\n muted: true,\n playsInline: true,\n };\n const layer = videoOverlay(url, bounds, options);\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n cancelable: true,\n bubbles: true,\n detail: {\n layer,\n },\n }),\n );\n }\n}\n\nexport default LVideoOverlay;\n","// @ts-check\nimport { geoJSON } from \"leaflet\";\nimport { mapAddTo } from \"./events.js\";\n\nclass LGeoJSON extends HTMLElement {\n constructor() {\n super();\n }\n\n connectedCallback() {\n const value = this.getAttribute(\"geojson\");\n if (value !== null) {\n const layer = geoJSON(JSON.parse(value));\n this.dispatchEvent(\n new CustomEvent(mapAddTo, {\n bubbles: true,\n cancelable: true,\n detail: {\n layer,\n },\n }),\n );\n }\n }\n}\n\nexport default LGeoJSON;\n","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\n\nconst camelCase = (kebab) => kebab.replace(/-./g, (x) => x[1].toUpperCase());\n\nclass LIcon extends HTMLElement {\n constructor() {\n super();\n this.icon = null;\n }\n\n connectedCallback() {\n const options = {};\n\n // Strings\n let keys = [\n \"icon-url\",\n \"icon-retina-url\",\n \"shadow-url\",\n \"shadow-retina-url\",\n \"class-name\",\n ];\n keys.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = this.getAttribute(key);\n }\n });\n\n // Points\n let points = [\n \"icon-anchor\",\n \"icon-size\",\n \"shadow-anchor\",\n \"shadow-size\",\n \"tooltip-anchor\",\n \"popup-anchor\",\n ];\n points.forEach((key) => {\n if (this.hasAttribute(key)) {\n options[camelCase(key)] = JSON.parse(this.getAttribute(key));\n }\n });\n\n if (this.hasAttribute(\"cross-origin\")) {\n options.crossOrigin = this.getAttribute(\"cross-origin\") === \"true\";\n }\n this.icon = L.icon(options);\n\n const event = new CustomEvent(\"icon:add\", {\n cancelable: true,\n bubbles: true,\n detail: {\n icon: this.icon,\n },\n });\n this.dispatchEvent(event);\n }\n}\n\nif (import.meta.vitest) {\n const { it, expect, beforeAll } = import.meta.vitest;\n\n beforeAll(() => {\n customElements.define(\"l-icon\", LIcon);\n });\n\n it(\"default\", () => {\n const el = document.createElement(\"l-icon\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"emits icon:add event\", async () => {\n const el = document.createElement(\"l-icon\");\n let promise = new Promise((resolve) => {\n el.addEventListener(\"icon:add\", (ev) => {\n resolve(ev.detail.icon);\n });\n });\n document.body.appendChild(el);\n let actual = await promise;\n let expected = L.icon();\n expect(actual).toEqual(expected);\n });\n\n it(\"options\", () => {\n const el = document.createElement(\"l-icon\");\n el.setAttribute(\"icon-url\", \"url.png\");\n el.setAttribute(\"icon-retina-url\", \"retina.png\");\n el.setAttribute(\"icon-size\", \"[0, 0]\");\n el.setAttribute(\"icon-anchor\", \"[0, 0]\");\n el.setAttribute(\"popup-anchor\", \"[0, 0]\");\n el.setAttribute(\"tooltip-anchor\", \"[0, 0]\");\n el.setAttribute(\"shadow-url\", \"urlShadow.png\");\n el.setAttribute(\"shadow-retina-url\", \"retinaShadow.png\");\n el.setAttribute(\"shadow-size\", \"[0, 0]\");\n el.setAttribute(\"shadow-anchor\", \"[0, 0]\");\n el.setAttribute(\"class-name\", \"foo\");\n el.setAttribute(\"cross-origin\", \"true\");\n document.body.appendChild(el);\n\n let actual = el.icon;\n let expected = L.icon({\n iconUrl: \"url.png\",\n iconRetinaUrl: \"retina.png\",\n iconSize: [0, 0],\n iconAnchor: [0, 0],\n popupAnchor: [0, 0],\n tooltipAnchor: [0, 0],\n shadowUrl: \"urlShadow.png\",\n shadowRetinaUrl: \"retinaShadow.png\",\n shadowSize: [0, 0],\n shadowAnchor: [0, 0],\n className: \"foo\",\n crossOrigin: true,\n });\n expect(actual).toEqual(expected);\n });\n}\n\nexport default LIcon;\n","import { LatLng } from \"leaflet\"\n\nconst ARGS = {\n circle: [[\"lat-lng\", LatLng]],\n polyline: [[\"lat-lngs\", LatLng]], // TODO: LatLng[] array\n polygon: [[\"lat-lng\", LatLng]],\n rectangle: [[\"lat-lng\", LatLng]],\n}\nconst OPTIONS = {\n circle: {\n radius: [Number, null]\n },\n polyline: {\n smoothFactor: [Number, 1.0],\n noClip: [Boolean, false]\n },\n polygon: {},\n path: {\n stroke: [Boolean, true],\n color: [String, \"#3388ff\"],\n weight: [Number, 3],\n opacity: [Number, 1.0],\n lineCap: [String, \"round\"],\n lineJoin: [String, \"round\"],\n },\n layer: {},\n rectangle: {}\n}\n\nconst INHERITS = {\n circle: [\"path\", \"layer\"],\n polyline: [\"path\", \"layer\"],\n polygon: [\"polyline\"],\n rectangle: [\"path\", \"layer\"],\n}\n\n// TODO: Generalise approach\nconst setter = (layer, name, newValue) => {\n switch(name) {\n case \"lat-lngs\":\n layer.setLatLngs(JSON.parse(newValue))\n break;\n case \"weight\":\n layer.setStyle({ weight: parseInt(newValue) })\n break;\n case \"color\":\n layer.setStyle({ color: newValue })\n break;\n }\n}\n\nconst attributes = (methodName) => {\n let args = ARGS[methodName].map(x => x[0])\n let attrs = Object.keys(OPTIONS[methodName])\n INHERITS[methodName].forEach((parent) => {\n attrs.push(...Object.keys(OPTIONS[parent]))\n })\n attrs = attrs.map(camelToKebab)\n attrs.push(...args)\n return attrs\n}\n\nconst camelToKebab = (s) => {\n return s.split('').map((letter, idx) => {\n return letter.toUpperCase() === letter\n ? `${idx !== 0 ? '-' : ''}${letter.toLowerCase()}`\n : letter;\n }).join('');\n}\n\nconst settings = (el, methodName) => {\n // Gather settings\n let result = {} \n let process = (opts) => {\n Object.entries(opts).forEach(([key, value]) => {\n const [type, val] = value\n const attribute = camelToKebab(key)\n if (el.hasAttribute(attribute)) {\n result[key] = parse(el.getAttribute(attribute), type, val)\n }\n })\n }\n\n // Process inheritance chain\n process(OPTIONS[methodName])\n INHERITS[methodName].forEach(parent => {\n process(OPTIONS[parent])\n })\n return result\n}\n\nconst positional = (el, methodName) => {\n return ARGS[methodName].map(([key, type]) => {\n return parse(el.getAttribute(key), type, null)\n })\n}\n\nconst parse = (text, type, defaultValue) => {\n switch (type) {\n case Number:\n return parseFloat(text)\n case Boolean:\n return text.toLowerCase() === \"true\"\n case String:\n return text\n case LatLng:\n return JSON.parse(text)\n default:\n return defaultValue\n }\n}\n\nconst generator = (method, methodName) => {\n console.log(attributes(methodName))\n class cls extends HTMLElement {\n static observedAttributes = attributes(methodName);\n\n constructor() {\n super()\n this.layer = null\n // TODO: event handlers\n }\n\n connectedCallback() {\n const args = positional(this, methodName)\n const options = settings(this, methodName)\n this.layer = method(...args, options)\n const event = new CustomEvent(\"map:addTo\", {\n cancelable: true,\n bubbles: true,\n detail: {\n layer: this.layer\n },\n });\n this.dispatchEvent(event);\n }\n\n attributeChangedCallback(name, _, newValue) {\n if (this.layer !== null) {\n setter(this.layer, name, newValue)\n }\n }\n }\n return cls\n}\n\n\nexport default generator\n","// @ts-check\nimport LBaseLayers from \"./l-base-layers.js\";\nimport LControlLayers from \"./l-control-layers.js\";\nimport LLayerGroup from \"./l-layer-group.js\";\nimport LMap from \"./l-map.js\";\nimport LMarker from \"./l-marker.js\";\nimport LOverlayLayers from \"./l-overlay-layers.js\";\nimport LPopup from \"./l-popup.js\";\nimport LTileLayer from \"./l-tile-layer.js\";\nimport LLatLngBounds from \"./l-lat-lng-bounds.js\";\nimport LImageOverlay from \"./l-image-overlay.js\";\nimport LVideoOverlay from \"./l-video-overlay.js\";\nimport LGeoJSON from \"./l-geojson.js\";\nimport LIcon from \"./l-icon.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\"\n\n\nconst init = (() => {\n // Custom elements (order of definition is important)\n customElements.define(\"l-map\", LMap);\n customElements.define(\"l-control-layers\", LControlLayers);\n customElements.define(\"l-base-layers\", LBaseLayers);\n customElements.define(\"l-overlay-layers\", LOverlayLayers);\n customElements.define(\"l-layer-group\", LLayerGroup);\n customElements.define(\"l-tile-layer\", LTileLayer);\n customElements.define(\"l-marker\", LMarker);\n customElements.define(\"l-popup\", LPopup);\n customElements.define(\"l-lat-lng-bounds\", LLatLngBounds);\n customElements.define(\"l-image-overlay\", LImageOverlay);\n customElements.define(\"l-video-overlay\", LVideoOverlay);\n customElements.define(\"l-geojson\", LGeoJSON);\n customElements.define(\"l-icon\", LIcon);\n customElements.define(\"l-circle\", generator(circle, \"circle\"))\n customElements.define(\"l-polyline\", generator(polyline, \"polyline\"))\n customElements.define(\"l-polygon\", generator(polygon, \"polygon\"))\n customElements.define(\"l-rectangle\", generator(rectangle, \"rectangle\"))\n})();\n\nexport default init;\n"],"names":["mapAddTo","popupAdd","LBaseLayers","_HTMLElement","call","this","_inheritsLoose","prototype","connectedCallback","addEventListener","ev","detail","_wrapNativeSuper","HTMLElement","LControlLayers","controlLayers","control","layers","_ev$detail","type","name","layer","addOverlay","addBaseLayer","preventDefault","event","CustomEvent","cancelable","bubbles","dispatchEvent","LLayer","_this","LLayerGroup","_LLayer","getAttribute","group","layerGroup","stopPropagation","addLayer","MutationObserver","mutations","forEach","mutation","removedNodes","node","leafletId","getLayer","parseInt","removeLayer","observe","childList","LMap","map","method","bounds","target","el","_this2","L","center","zoom","setView","JSON","parse","addTo","LMarker","setIcon","icon","_proto","latLng","opacity","parseFloat","marker","hasAttribute","setAttribute","stamp","bindPopup","content","attributeChangedCallback","_oldValue","newValue","setLatLng","setOpacity","observedAttributes","LOverlayLayers","LPopup","LTileLayer","urlTemplate","options","key","tileLayer","LLatLngBounds","_name","LImageOverlay","url","alt","imageOverlay","console","warn","setUrl","setBounds","LVideoOverlay","autoplay","muted","playsInline","videoOverlay","LGeoJSON","value","geoJSON","camelCase","kebab","replace","x","toUpperCase","LIcon","crossOrigin","ARGS","circle","LatLng","polyline","polygon","rectangle","OPTIONS","radius","Number","smoothFactor","noClip","Boolean","path","stroke","color","String","weight","lineCap","lineJoin","INHERITS","attributes","methodName","_attrs2","args","attrs","Object","keys","parent","_attrs","push","apply","camelToKebab","s","split","letter","idx","toLowerCase","join","text","defaultValue","generator","log","cls","_ref2","positional","result","process","opts","entries","_ref","val","attribute","settings","concat","_","setLatLngs","setStyle","setter","customElements","define"],"mappings":"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"}
|