leaflet-html 0.5.0 → 0.6.0

Sign up to get free protection for your applications and to get access to all the features.
package/README.md CHANGED
@@ -1,17 +1,21 @@
1
1
  # Leaflet HTML
2
2
 
3
+ Leaflet expressed in HTML adds map capabilities to Hypermedia Driven Applications (HDA).
4
+
3
5
  [![npm version](http://img.shields.io/npm/v/leaflet-html.svg?style="for-the-badge")](https://npmjs.org/package/leaflet-html)
4
6
  [![tests](https://img.shields.io/github/actions/workflow/status/andrewgryan/leaflet-html/tests.yml?branch=master&logo=github&style=for-the-badge)](https://github.com/andrewgryan/leaflet-html/actions/workflows/tests.yml)
5
7
 
6
8
 
7
- Leaflet expressed in HTML to add maps to Hypermedia Driven Applications (HDA).
9
+ ## Motivation
8
10
 
9
- Indeed, since it is HTML, any front end framework should work with it.
11
+ Expressing Leaflet in HTML enables compatibility with a wide range of front end frameworks.
10
12
 
11
13
  Fine grained reactive frameworks such as [Solid JS](https://solidjs.com) or [Van JS](https://vanjs.org) are ideal candidates for client side development.
12
14
 
13
15
  RESTful frameworks, like [HTMX](Https://htmx.org), that serve HTML over the wire are perfect choices for server rendered content.
14
16
 
17
+ Even static site generators like [Zola](https://getzola.org) are ideal for this approach.
18
+
15
19
  ## Documentation
16
20
 
17
21
  A comprehensive documentation site is available.
@@ -87,6 +91,11 @@ l-map {
87
91
  block-size: 100vh;
88
92
  }
89
93
  ```
94
+ > [!NOTE]
95
+ > Only `l-map` tag needs dimensions.
96
+ > All other `l-*` elements are purely semantic.
97
+ > They do not take up space on the page.
98
+ > They just indicate the state of the map.
90
99
 
91
100
  ## Quick start
92
101
 
@@ -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,tooltip as l,Circle as c,Rectangle as s,Polygon as u,Polyline as p,circle as d,polyline as f,polygon as b,rectangle as h}from"leaflet";function m(t){return m=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},m(t)}function v(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,g(t,e)}function y(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(y=function(){return!!t})()}function g(t,e){return g=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},g(t,e)}function E(t){var e="function"==typeof Map?new Map:void 0;return E=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&&g(a,n.prototype),a}(t,arguments,m(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),g(n,t)},E(t)}var A="map:addTo",L="popup:add",C=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){this.addEventListener(A,function(t){t.detail.type="base"})},e}(/*#__PURE__*/E(HTMLElement)),w=/*#__PURE__*/function(t){function n(){return t.call(this)||this}return v(n,t),n.prototype.connectedCallback=function(){var t=e.layers({},{});this.addEventListener(A,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(A,{cancelable:!0,bubbles:!0,detail:{layer:t}});this.dispatchEvent(n)},n}(/*#__PURE__*/E(HTMLElement)),O=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e}(/*#__PURE__*/E(HTMLElement)),k=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=n();this.layer=e;var r=new CustomEvent(A,{cancelable:!0,bubbles:!0,detail:{layer:e,name:t}});this.dispatchEvent(r),this.addEventListener(A,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}(O),S=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).map=null,t.addEventListener("map:bounds",function(e){var n=e.detail;null!==t.map&&t.map[n.method](n.bounds)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof n){var e=t.target;t.removedNodes.forEach(function(t){t instanceof O&&null!==e.map&&null!==t.layer&&e.map.removeLayer(t.layer)})}})}).observe(t,{childList:!0}),t}return v(n,e),n.prototype.connectedCallback=function(){var e=this;this.map=t.map(this);var n=this.getAttribute("center"),r=this.getAttribute("zoom");null!==n&&null!==r&&this.map.setView(JSON.parse(n),parseInt(r)),this.addEventListener(A,function(t){t.detail.layer.addTo(e.map)}),this.addEventListener("layer:remove",function(t){null!==e.map&&e.map.removeLayer(t.detail.layer)})},n}(/*#__PURE__*/E(HTMLElement)),N=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t.addEventListener("icon:add",function(e){e.stopPropagation(),t.layer.setIcon(e.detail.icon)}),t}v(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this,n=JSON.parse(this.getAttribute("lat-lng")),r=parseFloat(this.getAttribute("opacity")||"1.0");if(this.layer=t.marker(n,{opacity:r}),this.hasAttribute("icon")){var a=t.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(a)}this.setAttribute("leaflet-id",t.stamp(this.layer)),this.addEventListener(L,function(t){e.layer.bindPopup(t.detail.content)});var i=new CustomEvent(A,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(i)},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}(O);if(N.observedAttributes=["lat-lng","opacity","icon"],import.meta.vitest){var J=import.meta.vitest,T=J.it,M=J.expect;(0,J.beforeAll)(function(){customElements.define("l-marker",N)}),T("default icon",function(){var e=document.createElement("l-marker");document.body.appendChild(e);var n=e.layer.getIcon(),r=new t.Icon.Default;M(n).toEqual(r)}),T("adds an icon",function(){var e=document.createElement("l-marker");e.setAttribute("icon",JSON.stringify({iconUrl:"foo.png"})),document.body.appendChild(e);var n=e.layer.getIcon(),r=t.icon({iconUrl:"foo.png"});M(n).toEqual(r)}),T("changes an icon",function(){var e=document.createElement("l-marker");document.body.appendChild(e),e.setAttribute("icon",JSON.stringify({iconUrl:"bar.png"}));var n=e.layer.getIcon(),r=t.icon({iconUrl:"bar.png"});M(n).toEqual(r)})}var H=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){this.addEventListener(A,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/E(HTMLElement)),j=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("content"),e=new CustomEvent(L,{cancelable:!0,bubbles:!0,detail:{content:t}});this.dispatchEvent(e)},e}(/*#__PURE__*/E(HTMLElement)),P=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=this.getAttribute("url-template");if(null!==e){var n={},a="attribution";this.hasAttribute(a)&&(n[a]=this.getAttribute(a)),this.layer=r(e,n);var i=new CustomEvent(A,{detail:{name:t,layer:this.layer},bubbles:!0});this.dispatchEvent(i)}},e}(O),U=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(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__*/E(HTMLElement));U.observedAttributes=["bounds"];var I=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}v(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")||""};this.layer=a(t,JSON.parse(e),n),this.dispatchEvent(new CustomEvent(A,{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}(O);I.observedAttributes=["url","bounds","opacity"];var F=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(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(A,{cancelable:!0,bubbles:!0,detail:{layer:r}}))},e}(O),_=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("geojson");if(null!==t){var e=o(JSON.parse(t));this.dispatchEvent(new CustomEvent(A,{bubbles:!0,cancelable:!0,detail:{layer:e}}))}},e}(/*#__PURE__*/E(HTMLElement)),z=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},B=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).icon=null,t}return v(n,e),n.prototype.connectedCallback=function(){var e=this,n={};["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"].forEach(function(t){e.hasAttribute(t)&&(n[z(t)]=e.getAttribute(t))}),["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"].forEach(function(t){e.hasAttribute(t)&&(n[z(t)]=JSON.parse(e.getAttribute(t)))}),this.hasAttribute("cross-origin")&&(n.crossOrigin="true"===this.getAttribute("cross-origin")),this.icon=t.icon(n);var r=new CustomEvent("icon:add",{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(r)},n}(/*#__PURE__*/E(HTMLElement));if(import.meta.vitest){var q=import.meta.vitest,x=q.it,R=q.expect;(0,q.beforeAll)(function(){customElements.define("l-icon",B)}),x("default",function(){var e=document.createElement("l-icon");document.body.appendChild(e);var n=e.icon,r=t.icon();R(n).toEqual(r)}),x("emits icon:add event",function(){try{var e=document.createElement("l-icon"),n=new Promise(function(t){e.addEventListener("icon:add",function(e){t(e.detail.icon)})});return document.body.appendChild(e),Promise.resolve(n).then(function(e){var n=t.icon();R(e).toEqual(n)})}catch(t){return Promise.reject(t)}}),x("options",function(){var 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);var n=e.icon,r=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});R(n).toEqual(r)})}var D=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).tooltip=l(),e}v(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=new CustomEvent("bindTooltip",{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__*/E(HTMLElement));D.observedAttributes=["content"];var V=function(t){switch(t){case"circle":return[G("latLng","latlng",null)];case"rectangle":return[G("latLngBounds","latlngbounds",null)];case"polygon":case"polyline":return[G("latLngs","latlng",null)]}},G=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:K(e),defaultValue:n};var r},K=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}}},Q=function(t){var e={circle:[G("radius","number",null)],path:[G("stroke","boolean",!0),G("color","string","#3388ff"),G("weight","number",3),G("opacity","number",1),G("lineCap","string","round"),G("lineJoin","string","round"),G("dashArray","string",null),G("dashOffset","string",null),G("fill","boolean",!0),G("fillColor","string","#3388ff"),G("fillOpacity","number",.2)],polyline:[G("smoothFactor","number",1),G("noClip","boolean",!1)],polygon:[],rectangle:[],interactiveLayer:[G("interactive","boolean",!0)]};return X(t).flatMap(function(t){return e[t]})},W={circle:["path"],polyline:["path"],polygon:["polyline"],rectangle:["polygon"],path:["interactiveLayer"],interactiveLayer:[]},X=function(t){for(var e=t,n=[t];W[e].length>0;){var r=W[e][0];n.push(r),e=r}return n},Y=function(t,e){var n={};return Q(e).forEach(function(e){t.hasAttribute(e.kebab)&&(n[e.camel]=e.parser(t.getAttribute(e.kebab)))}),n},Z=/*#__PURE__*/function(t){function e(e){var n;return(n=t.call(this,e)||this).name="LeafletHTMLError",n}return v(e,t),e}(/*#__PURE__*/E(Error)),$=function(t,e){var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t.addEventListener("bindTooltip",function(e){null!==t.layer&&t.layer.bindTooltip(e.detail.tooltip)}),t}v(r,n);var a=r.prototype;return a.connectedCallback=function(){var n=function(t,e){return V(e).map(function(n){if(!t.hasAttribute(n.kebab))throw new Z("l-"+e+" element missing "+n.kebab+" HTML attribute");return n.parser(t.getAttribute(n.kebab))})}(this,e),r=Y(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)},a.attributeChangedCallback=function(t,n,r){null!==this.layer&&function(t,e,n,r){var a=[].concat(V(e),Q(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 s)switch(n){case"lat-lngs":t.setLatLngs(JSON.parse(r));break;case"lat-lng-bounds":t.setBounds(JSON.parse(r))}else t instanceof u?"lat-lngs"===n&&t.setLatLngs(JSON.parse(r)):t instanceof p&&"lat-lngs"===n&&t.setLatLngs(JSON.parse(r));var o,l=Q("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__*/E(HTMLElement));return n.observedAttributes=function(t){var e=V(t).map(function(t){return t.kebab}),n=Q(t).map(function(t){return t.kebab});return[].concat(e,n)}(e),n},tt=(customElements.define("l-map",S),customElements.define("l-control-layers",w),customElements.define("l-base-layers",C),customElements.define("l-overlay-layers",H),customElements.define("l-layer-group",k),customElements.define("l-tile-layer",P),customElements.define("l-marker",N),customElements.define("l-popup",j),customElements.define("l-lat-lng-bounds",U),customElements.define("l-image-overlay",I),customElements.define("l-video-overlay",F),customElements.define("l-geojson",_),customElements.define("l-icon",B),customElements.define("l-circle",$(d,"circle")),customElements.define("l-polyline",$(f,"polyline")),customElements.define("l-polygon",$(b,"polygon")),customElements.define("l-rectangle",$(h,"rectangle")),void customElements.define("l-tooltip",D));export{tt 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,tooltip as l,Circle as s,Rectangle as c,Polygon as u,Polyline as p,circle as d,polyline as f,polygon as b,rectangle as h}from"leaflet";function m(t){return m=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},m(t)}function v(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,g(t,e)}function y(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(y=function(){return!!t})()}function g(t,e){return g=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},g(t,e)}function E(t){var e="function"==typeof Map?new Map:void 0;return E=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&&g(a,n.prototype),a}(t,arguments,m(this).constructor)}return n.prototype=Object.create(t.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),g(n,t)},E(t)}var A="map:addTo",C="popup:add",w=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){this.addEventListener(A,function(t){t.detail.type="base"})},e}(/*#__PURE__*/E(HTMLElement)),L=/*#__PURE__*/function(t){function n(){return t.call(this)||this}return v(n,t),n.prototype.connectedCallback=function(){var t=e.layers({},{});this.addEventListener(A,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(A,{cancelable:!0,bubbles:!0,detail:{layer:t}});this.dispatchEvent(n)},n}(/*#__PURE__*/E(HTMLElement)),O=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e}(/*#__PURE__*/E(HTMLElement)),k=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=n();this.layer=e;var r=new CustomEvent(A,{cancelable:!0,bubbles:!0,detail:{layer:e,name:t}});this.dispatchEvent(r),this.addEventListener(A,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}(O),S=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).map=null,t.addEventListener("map:bounds",function(e){var n=e.detail;null!==t.map&&t.map[n.method](n.bounds)}),new MutationObserver(function(t){t.forEach(function(t){if(t.target instanceof n){var e=t.target;t.removedNodes.forEach(function(t){t instanceof O&&null!==e.map&&null!==t.layer&&e.map.removeLayer(t.layer)})}})}).observe(t,{childList:!0}),t}v(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this;if(this.map=t.map(this),this.hasAttribute("on")){var n=this.getAttribute("on");null!==n&&n.split(/\s+/).forEach(function(t){null!==e.map&&e.map.on(t,function(n){e.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:n}))})})}if(this.hasAttribute("fit-world"))this.map.fitWorld();else{var r=this.getAttribute("center"),a=this.getAttribute("zoom");null!==r&&null!==a&&this.map.setView(JSON.parse(r),parseInt(a))}this.hasAttribute("locate")&&this.map.locate(JSON.parse(this.getAttribute("locate"))),this.addEventListener(A,function(t){t.detail.layer.addTo(e.map)}),this.addEventListener("layer:remove",function(t){null!==e.map&&e.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__*/E(HTMLElement));S.observedAttributes=["zoom","center"];var N=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).layer=null,t.addEventListener("icon:add",function(e){e.stopPropagation(),t.layer.setIcon(e.detail.icon)}),t}v(n,e);var r=n.prototype;return r.connectedCallback=function(){var e=this,n=JSON.parse(this.getAttribute("lat-lng")),r=parseFloat(this.getAttribute("opacity")||"1.0");if(this.layer=t.marker(n,{opacity:r}),this.hasAttribute("icon")){var a=t.icon(JSON.parse(this.getAttribute("icon")));this.layer.setIcon(a)}this.setAttribute("leaflet-id",t.stamp(this.layer)),this.addEventListener(C,function(t){var n=t.detail,r=n.openPopup,a=e.layer.bindPopup(n.content);r&&a.openPopup()});var i=new CustomEvent(A,{cancelable:!0,bubbles:!0,detail:{layer:this.layer}});this.dispatchEvent(i)},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}(O);if(N.observedAttributes=["lat-lng","opacity","icon"],import.meta.vitest){var J=import.meta.vitest,T=J.it,M=J.expect;(0,J.beforeAll)(function(){customElements.define("l-marker",N)}),T("default icon",function(){var e=document.createElement("l-marker");document.body.appendChild(e);var n=e.layer.getIcon(),r=new t.Icon.Default;M(n).toEqual(r)}),T("adds an icon",function(){var e=document.createElement("l-marker");e.setAttribute("icon",JSON.stringify({iconUrl:"foo.png"})),document.body.appendChild(e);var n=e.layer.getIcon(),r=t.icon({iconUrl:"foo.png"});M(n).toEqual(r)}),T("changes an icon",function(){var e=document.createElement("l-marker");document.body.appendChild(e),e.setAttribute("icon",JSON.stringify({iconUrl:"bar.png"}));var n=e.layer.getIcon(),r=t.icon({iconUrl:"bar.png"});M(n).toEqual(r)})}var H=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){this.addEventListener(A,function(t){t.detail.type="overlay"})},e}(/*#__PURE__*/E(HTMLElement)),P=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(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(C,{cancelable:!0,bubbles:!0,detail:{content:t,openPopup:e}});this.dispatchEvent(r)},e}(/*#__PURE__*/E(HTMLElement)),j=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("name"),e=this.getAttribute("url-template");if(null!==e){var n={},a="attribution";this.hasAttribute(a)&&(n[a]=this.getAttribute(a)),this.layer=r(e,n);var i=new CustomEvent(A,{detail:{name:t,layer:this.layer},bubbles:!0});this.dispatchEvent(i)}},e}(O),I=/*#__PURE__*/function(t){function e(){return t.call(this)||this}v(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=this.getAttribute("bounds");null!==t&&this.dispatchEvent(this.getEvent(JSON.parse(t)))},n.attributeChangedCallback=function(t,e,n){this.dispatchEvent(this.getEvent(JSON.parse(n)))},n.getEvent=function(t){return new CustomEvent("map:bounds",{bubbles:!0,detail:{bounds:t,method:this.getAttribute("method")||"fitBounds"}})},e}(/*#__PURE__*/E(HTMLElement));I.observedAttributes=["bounds"];var U=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).layer=null,e}v(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")||""};this.layer=a(t,JSON.parse(e),n),this.dispatchEvent(new CustomEvent(A,{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}(O);U.observedAttributes=["url","bounds","opacity"];var z=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(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(A,{cancelable:!0,bubbles:!0,detail:{layer:r}}))},e}(O),F=/*#__PURE__*/function(t){function e(){return t.call(this)||this}return v(e,t),e.prototype.connectedCallback=function(){var t=this.getAttribute("geojson");if(null!==t){var e=o(JSON.parse(t));this.dispatchEvent(new CustomEvent(A,{bubbles:!0,cancelable:!0,detail:{layer:e}}))}},e}(/*#__PURE__*/E(HTMLElement)),_=function(t){return t.replace(/-./g,function(t){return t[1].toUpperCase()})},B=/*#__PURE__*/function(e){function n(){var t;return(t=e.call(this)||this).icon=null,t}return v(n,e),n.prototype.connectedCallback=function(){var e=this,n={};["icon-url","icon-retina-url","shadow-url","shadow-retina-url","class-name"].forEach(function(t){e.hasAttribute(t)&&(n[_(t)]=e.getAttribute(t))}),["icon-anchor","icon-size","shadow-anchor","shadow-size","tooltip-anchor","popup-anchor"].forEach(function(t){e.hasAttribute(t)&&(n[_(t)]=JSON.parse(e.getAttribute(t)))}),this.hasAttribute("cross-origin")&&(n.crossOrigin="true"===this.getAttribute("cross-origin")),this.icon=t.icon(n);var r=new CustomEvent("icon:add",{cancelable:!0,bubbles:!0,detail:{icon:this.icon}});this.dispatchEvent(r)},n}(/*#__PURE__*/E(HTMLElement));if(import.meta.vitest){var q=import.meta.vitest,x=q.it,R=q.expect;(0,q.beforeAll)(function(){customElements.define("l-icon",B)}),x("default",function(){var e=document.createElement("l-icon");document.body.appendChild(e);var n=e.icon,r=t.icon();R(n).toEqual(r)}),x("emits icon:add event",function(){try{var e=document.createElement("l-icon"),n=new Promise(function(t){e.addEventListener("icon:add",function(e){t(e.detail.icon)})});return document.body.appendChild(e),Promise.resolve(n).then(function(e){var n=t.icon();R(e).toEqual(n)})}catch(t){return Promise.reject(t)}}),x("options",function(){var 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);var n=e.icon,r=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});R(n).toEqual(r)})}var V=/*#__PURE__*/function(t){function e(){var e;return(e=t.call(this)||this).tooltip=l(),e}v(e,t);var n=e.prototype;return n.connectedCallback=function(){var t=new CustomEvent("bindTooltip",{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__*/E(HTMLElement));V.observedAttributes=["content"];var D=function(t){switch(t){case"circle":return[W("latLng","latlng",null)];case"rectangle":return[W("latLngBounds","latlngbounds",null)];case"polygon":case"polyline":return[W("latLngs","latlng",null)]}},W=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:Z(e),defaultValue:n};var r},Z=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}}},G=function(t){var e={circle:[W("radius","number",null)],path:[W("stroke","boolean",!0),W("color","string","#3388ff"),W("weight","number",3),W("opacity","number",1),W("lineCap","string","round"),W("lineJoin","string","round"),W("dashArray","string",null),W("dashOffset","string",null),W("fill","boolean",!0),W("fillColor","string","#3388ff"),W("fillOpacity","number",.2)],polyline:[W("smoothFactor","number",1),W("noClip","boolean",!1)],polygon:[],rectangle:[],interactiveLayer:[W("interactive","boolean",!0)]};return Q(t).flatMap(function(t){return e[t]})},K={circle:["path"],polyline:["path"],polygon:["polyline"],rectangle:["polygon"],path:["interactiveLayer"],interactiveLayer:[]},Q=function(t){for(var e=t,n=[t];K[e].length>0;){var r=K[e][0];n.push(r),e=r}return n},X=function(t,e){var n={};return G(e).forEach(function(e){t.hasAttribute(e.kebab)&&(n[e.camel]=e.parser(t.getAttribute(e.kebab)))}),n},Y=/*#__PURE__*/function(t){function e(e){var n;return(n=t.call(this,e)||this).name="LeafletHTMLError",n}return v(e,t),e}(/*#__PURE__*/E(Error)),$=function(t,e){var n=/*#__PURE__*/function(n){function r(){var t;return(t=n.call(this)||this).layer=null,t.addEventListener("bindTooltip",function(e){null!==t.layer&&t.layer.bindTooltip(e.detail.tooltip)}),t}v(r,n);var a=r.prototype;return a.connectedCallback=function(){var n=function(t,e){return D(e).map(function(n){if(!t.hasAttribute(n.kebab))throw new Y("l-"+e+" element missing "+n.kebab+" HTML attribute");return n.parser(t.getAttribute(n.kebab))})}(this,e),r=X(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)},a.attributeChangedCallback=function(t,n,r){null!==this.layer&&function(t,e,n,r){var a=[].concat(D(e),G(e)).find(function(t){return t.kebab===n});if(void 0!==a){var i=a.parser(r);if(t instanceof s)switch(n){case"lat-lng":t.setLatLng(JSON.parse(r));break;case"radius":t.setRadius(parseFloat(r))}else if(t instanceof c)switch(n){case"lat-lngs":t.setLatLngs(JSON.parse(r));break;case"lat-lng-bounds":t.setBounds(JSON.parse(r))}else t instanceof u?"lat-lngs"===n&&t.setLatLngs(JSON.parse(r)):t instanceof p&&"lat-lngs"===n&&t.setLatLngs(JSON.parse(r));var o,l=G("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__*/E(HTMLElement));return n.observedAttributes=function(t){var e=D(t).map(function(t){return t.kebab}),n=G(t).map(function(t){return t.kebab});return[].concat(e,n)}(e),n},tt=(customElements.define("l-map",S),customElements.define("l-control-layers",L),customElements.define("l-base-layers",w),customElements.define("l-overlay-layers",H),customElements.define("l-layer-group",k),customElements.define("l-tile-layer",j),customElements.define("l-marker",N),customElements.define("l-popup",P),customElements.define("l-lat-lng-bounds",I),customElements.define("l-image-overlay",U),customElements.define("l-video-overlay",z),customElements.define("l-geojson",F),customElements.define("l-icon",B),customElements.define("l-circle",$(d,"circle")),customElements.define("l-polyline",$(f,"polyline")),customElements.define("l-polygon",$(b,"polygon")),customElements.define("l-rectangle",$(h,"rectangle")),void customElements.define("l-tooltip",V));export{tt as default};
2
2
  //# sourceMappingURL=leaflet-html.js.map
@@ -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/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-tooltip.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","// 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","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\nimport { kebabToCamel } from \"./util.js\"; \n\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[kebabToCamel(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[kebabToCamel(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","// @ts-check\n\nimport { tooltip } from \"leaflet\";\n\nclass LTooltip extends HTMLElement {\n static observedAttributes = [\"content\"];\n\n constructor() {\n super();\n this.tooltip = tooltip();\n }\n\n connectedCallback() {\n const event = new CustomEvent(\"bindTooltip\", {\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","// @ts-check\nimport { Circle, LatLng, Polygon, Polyline, Rectangle } from \"leaflet\";\nimport { camelToKebab } from \"./util.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\nclass LeafletHTMLError extends Error {\n /**\n * @param {string} message\n */\n constructor(message) {\n super(message);\n this.name = \"LeafletHTMLError\";\n }\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 if (!el.hasAttribute(option.kebab)) {\n throw new LeafletHTMLError(\n `l-${methodName} element missing ${option.kebab} HTML attribute`\n );\n }\n return option.parser(el.getAttribute(option.kebab));\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(\"bindTooltip\", (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(\"map:addTo\", {\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\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 LTooltip from \"./l-tooltip.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\";\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 customElements.define(\"l-tooltip\", LTooltip);\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","vitest","_import$meta$vitest","it","expect","beforeAll","customElements","define","document","createElement","body","appendChild","actual","getIcon","expected","Icon","Default","toEqual","stringify","iconUrl","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","kebabToCamel","kebab","replace","x","toUpperCase","LIcon","crossOrigin","promise","Promise","resolve","then","e","reject","iconRetinaUrl","iconSize","iconAnchor","popupAnchor","tooltipAnchor","shadowUrl","shadowRetinaUrl","shadowSize","shadowAnchor","className","LTooltip","tooltip","attName","_","setContent","positionalArguments","methodName","option","defaultValue","camel","s","split","letter","idx","toLowerCase","join","parser","inferParser","_OPTIONS","circle","path","polyline","polygon","rectangle","interactiveLayer","inheritance","flatMap","parent","INHERITS","chain","length","push","settings","result","o","LeafletHTMLError","_Error","message","Error","generator","cls","bindTooltip","args","positional","apply","concat","_opt","find","parsedValue","Circle","setRadius","Rectangle","setLatLngs","Polygon","Polyline","_layer$setStyle","opt","setStyle","setter","opts","attributes","init"],"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/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-tooltip.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 static observedAttributes = [\"zoom\", \"center\"];\n\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\n // Connect Leaflet events\n if (this.hasAttribute(\"on\")) {\n const on = this.getAttribute(\"on\");\n if (on !== null) {\n on.split(/\\s+/).forEach((eventName) => {\n if (this.map !== null) {\n this.map.on(eventName, (e) => {\n this.dispatchEvent(\n new CustomEvent(eventName, { bubbles: true, detail: e })\n );\n });\n }\n });\n }\n }\n\n if (this.hasAttribute(\"fit-world\")) {\n this.map.fitWorld();\n } else {\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 }\n if (this.hasAttribute(\"locate\")) {\n this.map.locate(JSON.parse(this.getAttribute(\"locate\")));\n }\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 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","// @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, openPopup } = ev.detail;\n const popup = this.layer.bindPopup(content);\n if (openPopup) {\n popup.openPopup();\n }\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 let openPopup = false;\n const openPopupAttribute = this.getAttribute(\"open-popup\");\n if (openPopupAttribute !== null) {\n openPopup = openPopupAttribute !== \"false\";\n }\n const event = new CustomEvent(popupAdd, {\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 { 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 { LatLngBounds } from \"leaflet\";\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(JSON.parse(value)))\n }\n }\n\n attributeChangedCallback(_name, _oldValue, newValue) {\n this.dispatchEvent(this.getEvent(JSON.parse(newValue)));\n }\n\n /**\n * @param {LatLngBounds} bounds\n */\n getEvent(bounds) {\n return new CustomEvent(\"map:bounds\", {\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 { 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","// 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","// @vitest-environment happy-dom\nimport * as L from \"leaflet\";\nimport { kebabToCamel } from \"./util.js\"; \n\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[kebabToCamel(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[kebabToCamel(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","// @ts-check\n\nimport { tooltip } from \"leaflet\";\n\nclass LTooltip extends HTMLElement {\n static observedAttributes = [\"content\"];\n\n constructor() {\n super();\n this.tooltip = tooltip();\n }\n\n connectedCallback() {\n const event = new CustomEvent(\"bindTooltip\", {\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","// @ts-check\nimport { Circle, LatLng, Polygon, Polyline, Rectangle } from \"leaflet\";\nimport { camelToKebab } from \"./util.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\nclass LeafletHTMLError extends Error {\n /**\n * @param {string} message\n */\n constructor(message) {\n super(message);\n this.name = \"LeafletHTMLError\";\n }\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 if (!el.hasAttribute(option.kebab)) {\n throw new LeafletHTMLError(\n `l-${methodName} element missing ${option.kebab} HTML attribute`\n );\n }\n return option.parser(el.getAttribute(option.kebab));\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(\"bindTooltip\", (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(\"map:addTo\", {\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\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 LTooltip from \"./l-tooltip.js\";\nimport generator from \"./generator.js\";\nimport { circle, polyline, polygon, rectangle } from \"leaflet\";\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 customElements.define(\"l-tooltip\", LTooltip);\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","_proto","_this2","L","hasAttribute","on","split","eventName","e","fitWorld","center","zoom","setView","JSON","parse","locate","addTo","attributeChangedCallback","_oldValue","newValue","setZoom","observedAttributes","LMarker","setIcon","icon","latLng","opacity","parseFloat","marker","setAttribute","stamp","openPopup","popup","bindPopup","content","setLatLng","setOpacity","vitest","_import$meta$vitest","it","expect","beforeAll","customElements","define","document","createElement","body","appendChild","actual","getIcon","expected","Icon","Default","toEqual","stringify","iconUrl","LOverlayLayers","LPopup","openPopupAttribute","LTileLayer","urlTemplate","options","key","tileLayer","LLatLngBounds","value","getEvent","_name","LImageOverlay","url","alt","imageOverlay","console","warn","setUrl","setBounds","LVideoOverlay","autoplay","muted","playsInline","videoOverlay","LGeoJSON","geoJSON","kebabToCamel","kebab","replace","x","toUpperCase","LIcon","crossOrigin","promise","Promise","resolve","then","reject","iconRetinaUrl","iconSize","iconAnchor","popupAnchor","tooltipAnchor","shadowUrl","shadowRetinaUrl","shadowSize","shadowAnchor","className","LTooltip","tooltip","attName","_","setContent","positionalArguments","methodName","option","defaultValue","camel","s","letter","idx","toLowerCase","join","parser","inferParser","_OPTIONS","circle","path","polyline","polygon","rectangle","interactiveLayer","inheritance","flatMap","parent","INHERITS","chain","length","push","settings","result","o","LeafletHTMLError","_Error","message","Error","generator","cls","bindTooltip","args","positional","apply","concat","_opt","find","parsedValue","Circle","setRadius","Rectangle","setLatLngs","Polygon","Polyline","_layer$setStyle","opt","setStyle","setter","opts","attributes","init"],"mappings":"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"}
package/package.json CHANGED
@@ -1,14 +1,14 @@
1
1
  {
2
2
  "name": "leaflet-html",
3
3
  "type": "module",
4
- "version": "0.5.0",
4
+ "version": "0.6.0",
5
5
  "description": "Leaflet expressed in HTML",
6
6
  "keywords": [
7
- "leaflet",
8
- "hda",
9
- "html",
10
- "hypermedia",
11
- "maps"
7
+ "leaflet",
8
+ "hda",
9
+ "html",
10
+ "hypermedia",
11
+ "maps"
12
12
  ],
13
13
  "source": "src/index.js",
14
14
  "main": "./dist/leaflet-html.cjs",
@@ -26,9 +26,12 @@
26
26
  "scripts": {
27
27
  "build": "microbundle --format esm",
28
28
  "watch": "microbundle watch -o ./docs/static --format esm",
29
- "test": "vitest"
29
+ "test": "vitest",
30
+ "coverage": "vitest run --coverage",
31
+ "coverage:watch": "vitest watch --coverage"
30
32
  },
31
33
  "devDependencies": {
34
+ "@vitest/coverage-v8": "^1.6.0",
32
35
  "happy-dom": "^14.10.1",
33
36
  "microbundle": "^0.15.1",
34
37
  "prettier": "3.2.5",