@epa-wg/custom-element-dist 0.0.26 → 0.0.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.idea/custom-element-dist.iml +1 -5
- package/.storybook/preview.ts +1 -1
- package/README.md +4 -4
- package/bin/vitest/vitest-browser-importmaps.mjs +20 -20
- package/coverage/coverage-final.json +9 -9
- package/coverage/index.html +25 -25
- package/coverage/src/custom-element/coverage.svg +1 -1
- package/coverage/src/custom-element/custom-element.js/coverage.svg +1 -1
- package/coverage/src/custom-element/custom-element.js.html +467 -308
- package/coverage/src/custom-element/demo/index.html +1 -1
- package/coverage/src/custom-element/demo/z.js.html +1 -1
- package/coverage/src/custom-element/http-request.js.html +12 -12
- package/coverage/src/custom-element/index.html +20 -20
- package/coverage/src/custom-element/local-storage.js.html +56 -41
- package/coverage/src/custom-element/location-element.js.html +4 -4
- package/coverage/src/custom-element/module-url.js/coverage.svg +1 -1
- package/coverage/src/custom-element/module-url.js.html +16 -10
- package/coverage/src/index.html +1 -1
- package/coverage/src/mocks/handlers.ts.html +1 -1
- package/coverage/src/mocks/index.html +1 -1
- package/coverage/src/stories/attributes.test.stories.ts.html +9 -12
- package/coverage/src/stories/coverage.svg +1 -1
- package/coverage/src/stories/css.test.stories.ts.html +1 -1
- package/coverage/src/stories/dom-merge.test.stories.ts.html +15 -9
- package/coverage/src/stories/external-template.test.stories.ts.html +8 -11
- package/coverage/src/stories/form.test.stories.ts.html +1 -1
- package/coverage/src/stories/http-request.stories.ts.html +1 -1
- package/coverage/src/stories/index.html +26 -26
- package/coverage/src/stories/local-storage.test.stories.ts/coverage.svg +1 -1
- package/coverage/src/stories/local-storage.test.stories.ts.html +87 -63
- package/coverage/src/stories/location-element.test.stories.ts.html +1 -1
- package/coverage/src/stories/module-url.test.stories.ts.html +1 -1
- package/coverage/src/stories/set-url.test.stories.ts.html +1 -1
- package/coverage/src/stories/slice-events.test.stories.ts.html +1 -1
- package/coverage/src/stories/slots.test.stories.ts.html +1 -1
- package/coverage/src/stories/testStoryBook.ts.html +1 -1
- package/coverage/src/stories/version-select.test.stories.ts.html +1 -1
- package/coverage/src/sum.ts.html +1 -1
- package/dist/{custom-element-b7c_7Kz4.js → custom-element-BMMsP1Dy.js} +204 -156
- package/dist/custom-element-CPSk7s0j.cjs +87 -0
- package/dist/custom-element-bundle.cjs +1 -1
- package/dist/custom-element-bundle.js +28 -25
- package/dist/demo/a.svg +27 -0
- package/dist/demo/demo.css +6 -7
- package/dist/demo/external-template.html +3 -3
- package/dist/demo/npm-versions-demo.html +21 -8
- package/dist/demo/npm-versions.html +54 -25
- package/dist/demo/s.xml +3 -28
- package/dist/demo/s.xslt +51 -92
- package/dist/demo/z.html +32 -61
- package/dist/demo/z1.html +34 -0
- package/dist/local-storage-78EivJ_B.cjs +1 -0
- package/dist/local-storage-DzmNKzgN.js +66 -0
- package/dist/mockServiceWorker.js +1 -1
- package/package.json +27 -25
- package/public/demo/a.svg +27 -0
- package/public/demo/demo.css +6 -7
- package/public/demo/external-template.html +3 -3
- package/public/demo/npm-versions-demo.html +21 -8
- package/public/demo/npm-versions.html +54 -25
- package/public/demo/s.xml +3 -28
- package/public/demo/s.xslt +51 -92
- package/public/demo/z.html +32 -61
- package/public/demo/z1.html +34 -0
- package/public/mockServiceWorker.js +1 -1
- package/src/custom-element/custom-element.js +67 -14
- package/src/custom-element/demo/a.svg +27 -0
- package/src/custom-element/demo/demo.css +6 -7
- package/src/custom-element/demo/external-template.html +3 -3
- package/src/custom-element/demo/npm-versions-demo.html +21 -8
- package/src/custom-element/demo/npm-versions.html +54 -25
- package/src/custom-element/demo/s.xml +3 -28
- package/src/custom-element/demo/s.xslt +51 -92
- package/src/custom-element/demo/z.html +32 -61
- package/src/custom-element/demo/z1.html +34 -0
- package/src/custom-element/ide/web-types-dce.json +1 -1
- package/src/custom-element/ide/web-types-xsl.json +1 -1
- package/src/custom-element/index.html +19 -2
- package/src/custom-element/local-storage.js +19 -14
- package/src/custom-element/module-url.js +3 -2
- package/src/mocks/versions.mock.ts +8 -8
- package/src/stories/__screenshots__/http-request.test.ts/http-request-url-change-1.png +0 -0
- package/src/stories/attributes.test.stories.ts +3 -4
- package/src/stories/dom-merge.test.stories.ts +9 -7
- package/src/stories/external-template.test.stories.ts +2 -3
- package/src/stories/local-storage.test.stories.ts +61 -53
- package/src/sum.test.ts +5 -5
- package/src/sum.ts +3 -3
- package/storybook-static/assets/{Color-KGDBMAHA-CH-YyWYq.js → Color-KGDBMAHA-CJo5gHY3.js} +1 -1
- package/storybook-static/assets/{Configure-DFL_bm2M.js → Configure-DdXbGKhY.js} +1 -1
- package/storybook-static/assets/{DocsRenderer-PKQXORMH-Bz-_1hmS.js → DocsRenderer-PKQXORMH-DLnpL5hE.js} +2 -2
- package/storybook-static/assets/{attributes.test.stories-DIQXccHc.js → attributes.test.stories-Bt5V18qO.js} +10 -11
- package/storybook-static/assets/{css.test.stories-BV2hi4CY.js → css.test.stories-CGYy2daE.js} +1 -1
- package/storybook-static/assets/{custom-element-wn23PUwN.js → custom-element-D8hcDZHh.js} +116 -82
- package/storybook-static/assets/{dom-merge.test.stories-Dws0C2-g.js → dom-merge.test.stories-XlsZ0UvX.js} +22 -20
- package/storybook-static/assets/{external-template.test.stories-BHO48b0j.js → external-template.test.stories-Bt_Pflu8.js} +7 -8
- package/storybook-static/assets/{form.test.stories-dv9mwp24.js → form.test.stories-B0NoI8wm.js} +1 -1
- package/storybook-static/assets/{handlers-CaCq2ZPF.js → handlers-B5969HUu.js} +13 -13
- package/storybook-static/assets/{http-request.stories-B2ke7LtS.js → http-request.stories-B2skuTFV.js} +1 -1
- package/storybook-static/assets/iframe-Dfrt81rk.js +2 -0
- package/storybook-static/assets/{index-BnXBQqj9.js → index-Ay195x2L.js} +4 -4
- package/storybook-static/assets/{index-sm7QlJZE.js → index-C3ChPTMh.js} +1 -1
- package/storybook-static/assets/{index-Dz4OaB2k.js → index-C7lvoJNv.js} +1 -1
- package/storybook-static/assets/{index-Cpxqn5iQ.js → index-Gpdhz4ab.js} +1 -1
- package/storybook-static/assets/local-storage.test.stories-DfY6feqG.js +420 -0
- package/storybook-static/assets/{location-element.test.stories-BiFvBop7.js → location-element.test.stories-944AotIJ.js} +1 -1
- package/storybook-static/assets/{module-url.test.stories-BXoM34tX.js → module-url.test.stories-DSKcwApl.js} +1 -1
- package/storybook-static/assets/preview-AJR7rVPD.js +52 -0
- package/storybook-static/assets/{preview-Cg7hXPRq.js → preview-CadgX-4y.js} +2 -2
- package/storybook-static/assets/{set-url.test.stories-Cg5Z0r7x.js → set-url.test.stories-DjLHKkEh.js} +1 -1
- package/storybook-static/assets/{slice-events.test.stories-D_ttGp3g.js → slice-events.test.stories-8I_BrHd6.js} +1 -1
- package/storybook-static/assets/{slots.test.stories-DBNXOm0T.js → slots.test.stories-CvZz4jyP.js} +1 -1
- package/storybook-static/assets/{version-select.test.stories-CgV3UCim.js → version-select.test.stories-DSxmJylI.js} +1 -1
- package/storybook-static/demo/a.svg +27 -0
- package/storybook-static/demo/demo.css +6 -7
- package/storybook-static/demo/external-template.html +3 -3
- package/storybook-static/demo/npm-versions-demo.html +21 -8
- package/storybook-static/demo/npm-versions.html +54 -25
- package/storybook-static/demo/s.xml +3 -28
- package/storybook-static/demo/s.xslt +51 -92
- package/storybook-static/demo/z.html +32 -61
- package/storybook-static/demo/z1.html +34 -0
- package/storybook-static/iframe.html +1 -1
- package/storybook-static/mockServiceWorker.js +1 -1
- package/storybook-static/project.json +1 -1
- package/storybook-static/sb-addons/chromatic-com-storybook-9/manager-bundle.js +39 -36
- package/storybook-static/sb-addons/chromatic-com-storybook-9/manager-bundle.js.LEGAL.txt +38 -1
- package/.idea/codeStyles/codeStyleConfig.xml +0 -5
- package/.idea/compiler.xml +0 -6
- package/.idea/inspectionProfiles/Project_Default.xml +0 -6
- package/.vscode/settings.json +0 -24
- package/dist/custom-element-CckoVsvO.cjs +0 -53
- package/dist/local-storage-Boafngui.cjs +0 -1
- package/dist/local-storage-BqDEu2kF.js +0 -59
- package/storybook-static/assets/iframe-D4Sos1HO.js +0 -2
- package/storybook-static/assets/local-storage.test.stories-BpogLNq-.js +0 -419
- package/storybook-static/assets/preview-oHxXRSIu.js +0 -48
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";const F="http://www.w3.org/1999/XSL/Transform",q="http://www.w3.org/1999/xhtml",ye="http://exslt.org/common",y=(e,l)=>e.getAttribute?.(l),K=e=>e.nodeType===3,be=e=>typeof e=="string",ge=e=>e&&typeof e.nodeType=="number",C=(e,l)=>(e.ownerDocument||e).createTextNode(l),ee=e=>{for(;e.firstChild;)e.firstChild.remove();return e},H=e=>(e.getAttributeNames().map(l=>e.removeAttribute(l)),ee(e)),te=e=>(e?.setAttribute("xmlns:xsl",F),e),se=e=>(e?.setAttribute("xmlns:xhtml",q),te(e)),le=e=>/^[_a-zA-Z][-_:a-zA-Z0-9]*$/.test(e),N=(e,l="",t=document)=>{const s=i=>(r=>(l&&r.append(C(t.ownerDocument||t,l)),r))((t.ownerDocument||t).createElement(i));if(le(e))return s(e);const n=s("dce-object");return n.setAttribute("dce-object-name",e),n},Q=(e,l)=>{const t=e.ownerDocument.createElementNS(e.namespaceURI,l);for(let s of e.attributes)t.setAttribute(s.name,s.value);for(;e.firstChild;)t.append(e.firstChild);return t};function z(e){return new DOMParser().parseFromString(e,"application/xml")}function L(e){return new XMLSerializer().serializeToString(e)}function U(e,l,t,s){const n=h=>e.ownerDocument.createElement(h),r=((h,p,u)=>(p.append(u=n(h)),u))(l,e);return[...t].forEach(h=>r.append(s(h))),r}function ve(e){return e.slot||(e.setAttribute||(e=N("span",e.textContent.replaceAll(`
|
|
2
|
+
`,""))),e.setAttribute("slot","")),e}function D(e,l,t){const s=typeof e;if(s==="string")return N(l,e,t);if(s==="number")return N(l,""+e,t);if(e instanceof Array){const i=N("array","",t);return e.map(r=>i.append(D(r,l,t))),i}if(e instanceof FormData){const i=N("form-data","",t);for(const r of e)i.append(D(r[1],r[0],t));return i}const n=N(l,"",t);for(let i in e)ge(e[i])||typeof e[i]=="function"||e[i]instanceof Window||(typeof e[i]!="object"&&le(i)?n.setAttribute(i,e[i]):n.append(D(e[i],i,t)));return n}function W(e){if(S(e,"*",l=>[...l.childNodes].filter(t=>t.nodeType===3&&t.parentNode.localName!=="style"&&t.data).forEach(t=>{const s=t.data,n=s.matchAll(/{([^}]*)}/g);if(n){let i=0,r=p=>C(t,p),h=[];if([...n].forEach(p=>{p.index>i&&h.push(r(p.input.substring(i,p.index)));const u=e.querySelector("value-of").cloneNode();u.setAttribute("select",p[1]),h.push(u),i=p.index+p[0].length}),i<s.length&&h.push(r(s.substring(i,s.length))),h.length){for(let p of h)l.insertBefore(p,t);l.removeChild(t)}}})),"all"in e){let l=1;for(let t of e.all)t.setAttribute&&!t.tagName.startsWith("xsl:")&&t.setAttribute("data-dce-id",""+l++)}return e}function ne(e,l="xsl:stylesheet"){if(e.tagName===l||e.documentElement?.tagName===l)return W(e);const t=z(`<xsl:stylesheet version="1.0" xmlns:xsl="${F}" xmlns:xhtml="${q}" xmlns:exsl="${ye}" exclude-result-prefixes="exsl" >
|
|
3
|
+
<xsl:output method="xml"/>
|
|
4
|
+
<xsl:template match="/"><dce-root xmlns="${q}"><xsl:apply-templates select="*" /></dce-root></xsl:template>
|
|
5
|
+
<xsl:template match="*[name()='template']">
|
|
6
|
+
<xsl:apply-templates mode="sanitize" select="*|text()"/>
|
|
7
|
+
</xsl:template>
|
|
8
|
+
<xsl:template match="*">
|
|
9
|
+
<xsl:apply-templates mode="sanitize" select="*|text()"/>
|
|
10
|
+
</xsl:template>
|
|
11
|
+
<xsl:template match="*[name()='svg']|*[name()='math']">
|
|
12
|
+
<xsl:apply-templates mode="sanitize" select="."/>
|
|
13
|
+
</xsl:template>
|
|
14
|
+
<xsl:template mode="sanitize" match="*[count(text())=1 and count(*)=0]">
|
|
15
|
+
<xsl:copy>
|
|
16
|
+
<xsl:apply-templates mode="sanitize" select="@*"/>
|
|
17
|
+
<xsl:value-of select="text()"></xsl:value-of>
|
|
18
|
+
</xsl:copy>
|
|
19
|
+
</xsl:template>
|
|
20
|
+
<xsl:template mode="sanitize" match="xhtml:*[count(text())=1 and count(*)=0]">
|
|
21
|
+
<xsl:element name="{local-name()}">
|
|
22
|
+
<xsl:apply-templates mode="sanitize" select="@*"/>
|
|
23
|
+
<xsl:value-of select="text()"></xsl:value-of>
|
|
24
|
+
</xsl:element>
|
|
25
|
+
</xsl:template>
|
|
26
|
+
<xsl:template mode="sanitize" match="*|@*">
|
|
27
|
+
<xsl:copy>
|
|
28
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
29
|
+
</xsl:copy>
|
|
30
|
+
</xsl:template>
|
|
31
|
+
<xsl:template mode="sanitize" match="text()[normalize-space(.) = '']"/>
|
|
32
|
+
<xsl:template mode="sanitize" match="text()">
|
|
33
|
+
<dce-text>
|
|
34
|
+
<xsl:copy/>
|
|
35
|
+
</dce-text>
|
|
36
|
+
</xsl:template>
|
|
37
|
+
<xsl:template mode="sanitize" match="xsl:value-of|*[name()='slot']">
|
|
38
|
+
<dce-text>
|
|
39
|
+
<xsl:copy>
|
|
40
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
41
|
+
</xsl:copy>
|
|
42
|
+
</dce-text>
|
|
43
|
+
</xsl:template>
|
|
44
|
+
<xsl:template mode="sanitize" match="xhtml:*">
|
|
45
|
+
<xsl:element name="{local-name()}">
|
|
46
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
47
|
+
</xsl:element>
|
|
48
|
+
</xsl:template>
|
|
49
|
+
</xsl:stylesheet>`),s=new XSLTProcessor,n=(a=>{S(a,"custom-element",x=>{x.firstElementChild.localName==="template"&&([...x.firstElementChild.content.childNodes].forEach(b=>x.append(b)),x.firstElementChild.remove())}),S(a,"script",x=>x.remove());const c=a.content??a.firstElementChild?.content??a.body??a;pe.forEach(x=>S(c,x,b=>fe(b,c)));const E=a.firstElementChild?.content||a.content,v=x=>{const b=z("<xhtml/>"),j=b.importNode(x,!0);return b.replaceChild(j,b.documentElement),se(j)};if(E){const x=N("div");return[...E.childNodes].map(b=>x.append(b.cloneNode(!0))),v(x)}return v(a.documentElement||a.body||a)})(e),i=z(`<xsl:stylesheet version="1.0"
|
|
50
|
+
xmlns:xsl="${F}"
|
|
51
|
+
xmlns:xhtml="${q}"
|
|
52
|
+
xmlns:dce="urn:schemas-epa-wg:dce"
|
|
53
|
+
xmlns:exsl="http://exslt.org/common"
|
|
54
|
+
exclude-result-prefixes="exsl"
|
|
55
|
+
>
|
|
56
|
+
<xsl:template match="ignore">
|
|
57
|
+
<xsl:choose>
|
|
58
|
+
<xsl:when test="//attr">{//attr}</xsl:when>
|
|
59
|
+
<xsl:otherwise>{def}</xsl:otherwise>
|
|
60
|
+
</xsl:choose><xsl:value-of select="."></xsl:value-of></xsl:template>
|
|
61
|
+
<xsl:template mode="payload" match="attributes"></xsl:template>
|
|
62
|
+
<xsl:template match="/">
|
|
63
|
+
<xsl:apply-templates mode="payload" select="/datadom/attributes"/>
|
|
64
|
+
</xsl:template>
|
|
65
|
+
<xsl:template name="slot" >
|
|
66
|
+
<xsl:param name="slotname" />
|
|
67
|
+
<xsl:param name="defaultvalue" />
|
|
68
|
+
<xsl:choose>
|
|
69
|
+
<xsl:when test="//payload/*[@slot=$slotname]">
|
|
70
|
+
<xsl:copy-of select="//payload/*[@slot=$slotname]"/>
|
|
71
|
+
</xsl:when>
|
|
72
|
+
<xsl:otherwise>
|
|
73
|
+
<xsl:copy-of select="$defaultvalue"/>
|
|
74
|
+
</xsl:otherwise>
|
|
75
|
+
</xsl:choose>
|
|
76
|
+
</xsl:template>
|
|
77
|
+
<xsl:variable name="js-injected-body">
|
|
78
|
+
<xsl:call-template name="slot" >
|
|
79
|
+
<xsl:with-param name="slotname" select="''"/>
|
|
80
|
+
<xsl:with-param name="defaultvalue"/>
|
|
81
|
+
</xsl:call-template>
|
|
82
|
+
</xsl:variable>
|
|
83
|
+
</xsl:stylesheet>`);s.importStylesheet(t);const r=s.transformToFragment(n,document),h=(a,c)=>a.querySelector(c),p=h(i,'template[mode="payload"]');if(!r)return console.error("transformation error",{xml:n.outerHTML,xsl:L(t)});if(r.firstElementChild.localName!=="dce-root"){const a=r.ownerDocument.createElement("dce-root");[...r.childNodes].forEach(c=>a.append(c)),r.append(a)}const u=[];[...r.querySelectorAll("dce-root>attribute")].forEach(a=>{const c=Q(a,"xsl:param"),E=y(a,"name");p.append(c);let v=y(c,"select")?.split("??");v||(v=["//"+E,`'${c.textContent}'`],H(c),c.setAttribute("name",E));let x;if(v?.length>1){c.removeAttribute("select");const b=h(i,'template[match="ignore"]>choose').cloneNode(!0);H(b.firstElementChild).append(C(b,"{"+v[0]+"}")),H(b.lastElementChild).append(C(b,"{"+v[1]+"}")),b.firstElementChild.setAttribute("test",v[0]),c.append(b),x=b.cloneNode(!0)}else x=Q(a,"xsl:value-of");x.removeAttribute("name"),a.append(x),a.removeAttribute("select"),u.push(c)}),[...r.querySelectorAll("[value]")].filter(a=>a.getAttribute("value").match(/\{(.*)\?\?(.*)\}/g)).forEach(a=>{const c=y(a,"value");c&&a.setAttribute("value",de(c))});for(const a of r.childNodes)p.append(i.importNode(a,!0));[...p.getElementsByTagName("xsl:template")].forEach(a=>p.ownerDocument.documentElement.append(a));const I=h(i,'call-template[name="slot"]'),d=a=>{const c=I.cloneNode(!0),E=y(a,"name");E&&c.firstElementChild.setAttribute("select",`'${E}'`);for(let v of a.childNodes)c.lastElementChild.append(v);return c};S(p,"slot",a=>a.parentNode.replaceChild(d(a),a));const m=W(i);return m.params=u,m}async function ae(e){return await new Promise((t,s)=>{const n=new XMLHttpRequest;n.open("GET",e),n.responseType="document",n.onload=()=>{n.readyState===n.DONE&&n.status===200?t(n.responseXML?.body||n.responseXML||N("div",n.responseText)):s(`${n.statusText} - ${e}`)},n.addEventListener("error",i=>s(i)),n.send()})}function ie(e,l,t=!1){if(e===l)return!0;if(typeof e!="object"||e===null||typeof l!="object"||l===null||Object.keys(e).length!==Object.keys(l).length)return t;for(let s in e)if(!(s in l)||!ie(e[s],l[s]))return t;return!0}const oe=e=>e.split("|").map(l=>l.trim()).filter(l=>l),re=(e,l)=>oe(l).map(t=>{let s=e.ownerDocument,n=i=>(e.append(i),i);if(t.includes("/")){const i=[],r=s.evaluate(t,e);for(let h;h=r.iterateNext();)i.push(h);return i}return[...e.childNodes].find(i=>i.localName===t)||n(N(t,"",s))}).flat();function Y(e,l,t,s){if(!t.sliceProcessed)return t.sliceProcessed=1,re(e,l??"").map(n=>{const i=e.ownerDocument,r=t.sliceEventSource,h=t.sliceElement,p=()=>[...n.childNodes].filter(u=>u.nodeType===3||u.localName==="value"||u.localName==="form-data").map(u=>u.remove());if(r.getAttributeNames().map(u=>n.setAttribute(u,y(r,u))),[...n.childNodes].filter(u=>u.localName==="event").map(u=>u.remove()),"validationMessage"in r&&n.setAttribute("validation-message",r.validationMessage),t.type==="init"&&p(),n.append(D(t,"event",i)),h.hasAttribute("slice-value")){r.value===void 0?n.removeAttribute("value"):n.setAttribute("value",r.value);const u=$(y(h,"slice-value"),n);p(),n.append(C(i,u))}else{if("elements"in r)return p(),n.append(D(new FormData(r),"value",n.ownerDocument)),n;const u=r.value??y(r,"value");p(),u==null?[...n.childNodes].filter(T=>T.localName!=="event").map(T=>T.remove()):be(u)?n.append(C(i,u)):n.append(D(u,"value",n.ownerDocument))}return n})}function S(e,l,t){e.querySelectorAll&&[...e.querySelectorAll(l)].forEach(t)}const Ee=async(e,l)=>{if(!e||!e.trim())return[l];if(e.startsWith("#"))return(t=>{const s=t.querySelectorAll(e);return[...s.length?s:t.getRootNode().querySelectorAll(e)]})(l.parentElement);try{const[t,s]=e.split("#");if(e.charAt(0)===".")e=new URL(t,l.closest("[base]")?.getAttribute("base")||location).href;else try{e=(void 0)(t),s&&(e+="#"+s)}catch(i){console.error(i.message)}const n=await ae(e);if(l.setAttributeNS("xml","base",e),s){const i=n.querySelectorAll("#"+s);return i.length?[...i]:[l]}return[n]}catch{return[l]}};function ce(e,l){for(let t of e.attributes)t.namespaceURI?l.setAttributeNS(t.namespaceURI,t.name,t.value):l.setAttribute(t.name,t.value),t.name==="value"&&(l.value=t.value)}function G(e,l=0){const t={};for(const s of e.childNodes){const n=y(s,"data-dce-id")||s.dceId||0;if(!t[n])n?t[n]=1:(t[n]=s.dceId=++l,s.setAttribute&&s.setAttribute("data-dce-id",s.dceId));else{const i=s.dceId=n+"-"+t[n]++;s.setAttribute&&s.setAttribute("data-dce-id",i)}s.childNodes.length&&G(s)}}function me(e,l,t){t=1*t;for(let s of e.childNodes)if((s.dceId??s.getAttribute("data-dce-id")*1)>t)return e.insertBefore(l,s);e.append(l)}function Z(e,l){if(e.firstElementChild?.localName==="dce-root"&&l[0].localName!=="dce-root")return;if(!l.length)return e.firstElementChild?.localName!=="dce-root"&&ee(e);const t={};for(let s of e.childNodes)t[s.dceId],K(s)?(s.data.trim(),t[s.dceId||0]=s):t[y(s,"data-dce-id")||0]=s;for(let s of[...l]){const n=y(s,"data-dce-id")||s.dceId,i=t[n];i?(K(s)?i.nodeValue!==s.nodeValue&&(i.nodeValue=s.nodeValue):(ce(s,i),(i.childNodes.length||s.childNodes.length)&&Z(i,s.childNodes)),delete t[n]):me(e,s,n)}for(let s of Object.values(t))s.localName!=="dce-root"&&s.remove()}function ue(e,l){return e.hasAttribute(l)||e.setAttribute(l,crypto.randomUUID()),e.getAttribute(l)}const de=e=>[...e?.matchAll(/([^{}]*)(\{)([^}]+)}([^{}]*)/g)].map(t=>`${t[1]}{${V(t[3])}}${t[4]}`).join(""),V=e=>{if(!e.trim())return e;const l=e.split("??"),t=l.shift(),s=V(l.join("??"));return l.length?`concat( ${t} , substring( ${s} , (1+string-length( ${s} )) * string-length( ${t} ) ) )`:e},$=(e,l)=>{const t=e.split("??");if(t.length>1)return $(t[0],l)||$(t[1],l);e=V(e);const s=l.ownerDocument.evaluate(e,l);switch(s.resultType){case XPathResult.NUMBER_TYPE:return s.numberValue;case XPathResult.STRING_TYPE:return s.stringValue;case XPathResult.BOOLEAN_TYPE:return s.booleanValue}let n="";for(let i;i=s.iterateNext();)n+=i.textContent;return n},pe="stylesheet,transform,import,include,strip-space,preserve-space,output,key,decimal-format,namespace-alias,value-of,copy-of,number,apply-templates,apply-imports,for-each,sort,if,choose,when,otherwise,attribute-set,call-template,with-param,variable,param,text,processing-instruction,element,attribute,comment,copy,message,fallback".split(","),fe=(e,l)=>{const t=N("xsl:"+e.localName);for(let s of e.attributes)t.setAttribute(s.name,s.value);for(;e.firstChild;)t.append(e.firstChild);if(e.parentElement)e.parentElement.replaceChild(t,e);else{const s=e.parentElement||l,n=[...s.childNodes];n.forEach((i,r)=>{i===e&&(n[r]=t)}),s.replaceChildren(...n)}};class he extends HTMLElement{static observedAttributes=["src","tag","hidden"];async connectedCallback(){const l=await Ee(y(this,"src"),this),t=y(this,"tag"),s=t||"dce-"+crypto.randomUUID();for(const d of l)S(d.templateNode||d.content||d,"style",m=>{const a=m.closest("slot"),c=a?`slot[name="${a.name}"]`:"";m.innerHTML=`${s} ${c}{${m.innerHTML}}`,this.append(m)});const n=l.map(d=>ne(d)),i=n.map((d,m)=>{m=new XSLTProcessor;try{m.importStylesheet(d)}catch(a){console.error(a,L(d))}return m});Object.defineProperty(this,"xsltString",{get:()=>n.map(d=>L(d)).join(`
|
|
84
|
+
`)});const r=this,h=[...this.templateNode.querySelectorAll("[slice]")],p=h.map(d=>y(d,"slice")).filter(d=>!d.includes("/")).filter((d,m,a)=>a.indexOf(d)===m).map(oe).flat(),u=n.reduce((d,m)=>(m.params&&d.push(...m.params),d),[]);class T extends HTMLElement{static get observedAttributes(){return u.map(m=>y(m,"name"))}#e=0;connectedCallback(){let m=this.childNodes;if(this.firstElementChild?.tagName==="TEMPLATE"){this.firstElementChild!==this.lastElementChild&&console.error("payload should have TEMPLATE as only child",this.outerHTML);const f=this.firstElementChild;f.remove(),m=f.content.childNodes;for(const o of[...f.content.childNodes])if(o.localName==="style"){const g=ue(this,"data-dce-style");o.innerHTML=`${s}[data-dce-style="${g}"]{${o.innerHTML}}`,f.insertAdjacentElement("beforebegin",o)}else o.nodeType===1?f.insertAdjacentElement("beforebegin",o):o.nodeType===3&&f.insertAdjacentText("beforebegin",o.data)}const a=z("<datadom/>").documentElement,c=(f,o="")=>(g=>(o&&g.append(C(a,o)),g))(a.ownerDocument.createElement(f)),E=U(a,"payload",m,ve);te(E),se(E),this.innerHTML="";const v=U(a,"attributes",this.attributes,f=>c(f.nodeName,f.value));U(a,"dataset",Object.keys(this.dataset),f=>c(f,this.dataset[f]));const x=U(a,"slice",p,f=>c(f,"")),b=f=>$(f,x);this.xml=a;const j=[],J=()=>{const f={};for(let o;o=j.pop();){const g=y(o.sliceElement,"slice");f[g]||(Y(x,g,o),f[g]=o)}Object.keys(f).length!==0&&X()};let O;this.onSlice=f=>{j.push(f),O||(O=setTimeout(()=>{J(),O=0},1))};const X=this.transform=()=>{if(this.#e)debugger;this.#e=1,i.map((o,g)=>{const R=o.transformToFragment(a.ownerDocument,document);return R||console.error(`XSLT transformation error. xsl:
|
|
85
|
+
`,L(n[g]),`
|
|
86
|
+
xml:
|
|
87
|
+
`,L(a)),R}).map(o=>{o&&(G(o),Z(this,o.childNodes))}),T.observedAttributes.map(o=>{let g=y(this.firstElementChild,o);g!==y(this,o)&&(this.setAttribute(o,g),this.#t(o,g))}),S(this,"[slice],[slice-event]",o=>{if(!o.dceInitialized){o.dceInitialized=1;let g=y(o,"slice-event");o.hasAttribute("custom-validity")&&(g+=" change submit"),[...new Set((g||"change").split(" "))].forEach(R=>(o.localName==="slice"?o.parentElement:o).addEventListener(R,A=>{A.sliceElement=o,A.sliceEventSource=A.currentTarget||A.target;const xe=Y(x,y(A.sliceElement,"slice"),A);S(this,"[custom-validity]",P=>{if(!P.setCustomValidity)return;const B=y(P,"custom-validity");try{const M=B&&$(B,v);P.setCustomValidity(M===!0?"":M===!1?"invalid":M)}catch(M){console.error(M,"xPath",B)}});const _=y(o,"custom-validity"),w=_&&$(_,v),k=w===!0?"":w;if(_){if(o.setCustomValidity?o.setCustomValidity(k):o.validationMessage=k,xe.map(P=>P.setAttribute("validation-message",k)),A.type==="submit")return w===!0?void 0:(setTimeout(X,1),!!w===w?(w||A.preventDefault(),w):w?(A.preventDefault(),!1):void 0);setTimeout(X,1)}this.onSlice(A)})),(!g||g.includes("init"))&&(o.hasAttribute("slice-value")||o.hasAttribute("value")||o.value?this.onSlice({type:"init",target:o,sliceElement:o,sliceEventSource:o}):o.value=b(y(o,"slice")))}}),this.#e=0};X(),J()}#t(m,a){m==="value"&&(this.value=a);let c=this.xml.querySelector(`attributes>${m}`);c?H(c).append(C(c,a)):(c=N(m,a,this.xml),this.xml.querySelector("attributes").append(c)),this.dispatchEvent(new CustomEvent("change",{bubbles:!0,detail:{[m]:a}}))}attributeChangedCallback(m,a,c){!this.xml||this.#e||(this.#t(m,c),this.transform())}get dce(){return r}}const I=d=>{window.customElements.get(d)!==T&&window.customElements.define(d,T)};if(t)I(t);else{const d=s;this.setAttribute("tag",d),I(d);const m=document.createElement(d);this.getAttributeNames().forEach(a=>m.setAttribute(a,this.getAttribute(a))),m.append(...[...this.childNodes].filter(a=>a.localName!=="style")),this.append(m)}}get templateNode(){return this.firstElementChild?.tagName==="TEMPLATE"?this.firstElementChild.content:this}get dce(){return this}get xslt(){return z(this.xsltString)}}window.customElements.define("custom-element",he);exports.CustomElement=he;exports.appendByDceId=me;exports.assureSlices=re;exports.assureUID=ue;exports.assureUnique=G;exports.createXsltFromDom=ne;exports.deepEqual=ie;exports.evalCurly=de;exports.event2slice=Y;exports.merge=Z;exports.mergeAttr=ce;exports.obj2node=D;exports.tagUid=W;exports.toXsl=fe;exports.xPath=$;exports.xPathDefaults=V;exports.xhrTemplate=ae;exports.xml2dom=z;exports.xmlString=L;exports.xslTags=pe;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./custom-element-
|
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./custom-element-CPSk7s0j.cjs"),l=require("./http-request-DPrY7mGh.cjs"),t=require("./local-storage-78EivJ_B.cjs"),a=require("./location-element-DRB7hCwA.cjs");exports.CustomElement=e.CustomElement;exports.appendByDceId=e.appendByDceId;exports.assureSlices=e.assureSlices;exports.assureUID=e.assureUID;exports.assureUnique=e.assureUnique;exports.createXsltFromDom=e.createXsltFromDom;exports.deepEqual=e.deepEqual;exports.default=e.CustomElement;exports.evalCurly=e.evalCurly;exports.event2slice=e.event2slice;exports.merge=e.merge;exports.mergeAttr=e.mergeAttr;exports.obj2node=e.obj2node;exports.tagUid=e.tagUid;exports.toXsl=e.toXsl;exports.xPath=e.xPath;exports.xPathDefaults=e.xPathDefaults;exports.xhrTemplate=e.xhrTemplate;exports.xml2dom=e.xml2dom;exports.xmlString=e.xmlString;exports.xslTags=e.xslTags;exports.HttpRequestElement=l.HttpRequestElement;exports.LocalStorageElement=t.LocalStorageElement;exports.localStorageSetItem=t.localStorageSetItem;exports.localStorage_clear=t.localStorage_clear;exports.localStorage_removeItem=t.localStorage_removeItem;exports.localStorage_setItem=t.localStorage_setItem;exports.LocationElement=a.LocationElement;
|
|
@@ -1,32 +1,35 @@
|
|
|
1
|
-
import { C as e } from "./custom-element-
|
|
2
|
-
import { h as o, e as
|
|
3
|
-
import { H as
|
|
4
|
-
import { L as b,
|
|
5
|
-
import { L as
|
|
1
|
+
import { C as e } from "./custom-element-BMMsP1Dy.js";
|
|
2
|
+
import { h as o, e as l, j as r, g as m, c, d as p, k as x, f as g, i as n, m as u, o as d, t as f, q as i, n as S, l as E, b as I, x as h, a as q, p as D } from "./custom-element-BMMsP1Dy.js";
|
|
3
|
+
import { H as b } from "./http-request-BOvP4KTl.js";
|
|
4
|
+
import { L as C, c as U, b as _, a as j, l as y } from "./local-storage-DzmNKzgN.js";
|
|
5
|
+
import { L as P } from "./location-element-FJlONi2n.js";
|
|
6
6
|
export {
|
|
7
7
|
e as CustomElement,
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
b as HttpRequestElement,
|
|
9
|
+
C as LocalStorageElement,
|
|
10
|
+
P as LocationElement,
|
|
11
11
|
o as appendByDceId,
|
|
12
|
-
|
|
13
|
-
|
|
12
|
+
l as assureSlices,
|
|
13
|
+
r as assureUID,
|
|
14
14
|
m as assureUnique,
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
c as createXsltFromDom,
|
|
16
|
+
p as deepEqual,
|
|
17
17
|
e as default,
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
18
|
+
x as evalCurly,
|
|
19
|
+
g as event2slice,
|
|
20
|
+
U as localStorageSetItem,
|
|
21
|
+
_ as localStorage_clear,
|
|
22
|
+
j as localStorage_removeItem,
|
|
23
|
+
y as localStorage_setItem,
|
|
24
|
+
n as merge,
|
|
25
|
+
u as mergeAttr,
|
|
26
|
+
d as obj2node,
|
|
27
|
+
f as tagUid,
|
|
25
28
|
i as toXsl,
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
S as xPath,
|
|
30
|
+
E as xPathDefaults,
|
|
31
|
+
I as xhrTemplate,
|
|
32
|
+
h as xml2dom,
|
|
33
|
+
q as xmlString,
|
|
34
|
+
D as xslTags
|
|
32
35
|
};
|
package/dist/demo/a.svg
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
<svg id="dwc-logo" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 216 209.18" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
2
|
+
<defs>
|
|
3
|
+
|
|
4
|
+
</defs>
|
|
5
|
+
<polygon class="cls-3" points="0 82.47 0 126.71 34.84 146.83 34.84 187.06 73.16 209.18 108 189.07 142.84 209.18 181.16 187.06 181.16 146.83 216 126.71 216 82.47 181.16 62.35 181.16 22.12 142.84 0 108 20.12 73.16 0 34.84 22.12 34.84 62.35 0 82.47"/>
|
|
6
|
+
<path class="cls-2" d="m114.33,56.69l20.64-11.92c.47-.27.47-.79,0-1.06l-20.65-11.92h0c-4.44-2.57-8.22-2.57-12.67,0l-20.65,11.92c-.47.27-.47.79,0,1.06l20.64,11.92c4.44,2.57,8.22,2.57,12.67,0h0Z"/>
|
|
7
|
+
<path class="cls-2" d="m98.19,62.71h0s-20.64-11.92-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84s0,0,0,0c0,5.13,1.89,8.4,6.33,10.97l20.65,11.92c.47.27.92,0,.92-.54v-23.84c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
8
|
+
<path class="cls-1" d="m48.12,66.01l20.65,11.92c.47.27.92,0,.92-.54v-23.84c0-5.13-1.89-8.4-6.33-10.97h0s-20.64-11.92-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84s0,0,0,0c0,5.13,1.89,8.4,6.33,10.97Z"/>
|
|
9
|
+
<path class="cls-2" d="m46.18,24.66l20.64,11.92c4.44,2.57,8.22,2.57,12.67,0h0s20.64-11.92,20.64-11.92c.47-.27.47-.79,0-1.06l-20.65-11.92h0c-4.44-2.57-8.22-2.57-12.67,0l-20.65,11.92c-.47.27-.47.79,0,1.06Z"/>
|
|
10
|
+
<path class="cls-2" d="m115.87,24.66l20.64,11.92c4.44,2.57,8.22,2.57,12.67,0h0s20.64-11.92,20.64-11.92c.47-.27.47-.79,0-1.06l-20.65-11.92h0c-4.44-2.57-8.22-2.57-12.67,0l-20.65,11.92c-.47.27-.47.79,0,1.06Z"/>
|
|
11
|
+
<path class="cls-2" d="m152.65,42.59c-4.44,2.56-6.33,5.84-6.33,10.97v23.84c0,.54.45.8.92.54l20.65-11.92c4.44-2.57,6.33-5.84,6.33-10.97h0v-23.84c0-.54-.45-.8-.92-.53l-20.64,11.92h0Z"/>
|
|
12
|
+
<path class="cls-2" d="m77.55,158.4l20.65-11.92h0c4.44-2.57,6.33-5.84,6.33-10.97v-23.84c0-.54-.45-.8-.92-.53l-20.64,11.92c-4.44,2.57-6.33,5.84-6.33,10.97h0s0,23.84,0,23.84c0,.54.45.8.92.54Z"/>
|
|
13
|
+
<path class="cls-4" d="m146.31,134.03v23.84c0,.54.45.8.92.54l20.65-11.92c4.44-2.57,6.33-5.84,6.33-10.97h0s0-23.84,0-23.84c0-.54-.45-.8-.92-.53l-20.64,11.92h0c-4.44,2.57-6.33,5.84-6.33,10.97Z"/>
|
|
14
|
+
<path class="cls-4" d="m63.35,123.06h0s-20.64-11.92-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84s0,0,0,0c0,5.13,1.89,8.4,6.33,10.97l20.65,11.92c.47.27.92,0,.92-.54v-23.84c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
15
|
+
<path class="cls-4" d="m103.61,151.37l-20.64,11.92c-4.44,2.57-6.33,5.84-6.33,10.97h0s0,23.84,0,23.84c0,.54.45.8.92.54l20.65-11.92h0c4.44-2.57,6.33-5.84,6.33-10.97v-23.84c0-.54-.45-.8-.92-.53Z"/>
|
|
16
|
+
<path class="cls-4" d="m63.35,163.29h0s-20.64-11.92-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84s0,0,0,0c0,5.13,1.89,8.4,6.33,10.97l20.65,11.92c.47.27.92,0,.92-.54v-23.84c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
17
|
+
<path class="cls-4" d="m28.51,102.94h0s-20.64-11.92-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84s0,0,0,0c0,5.13,1.89,8.4,6.33,10.97l20.65,11.92c.47.27.92,0,.92-.54v-23.84c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
18
|
+
<path class="cls-4" d="m133.04,163.29l-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84c0,5.13,1.89,8.4,6.33,10.97h0s20.65,11.92,20.65,11.92c.47.27.92,0,.92-.54v-23.84s0,0,0,0c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
19
|
+
<path class="cls-4" d="m173.29,151.37l-20.64,11.92h0c-4.44,2.57-6.33,5.84-6.33,10.97v23.84c0,.54.45.8.92.54l20.65-11.92c4.44-2.57,6.33-5.84,6.33-10.97h0s0-23.84,0-23.84c0-.54-.45-.8-.92-.53Z"/>
|
|
20
|
+
<path class="cls-4" d="m209.06,91.55c0-.54-.45-.8-.92-.53l-20.64,11.92h0c-4.44,2.57-6.33,5.84-6.33,10.97v23.84c0,.54.45.8.92.54l20.65-11.92c4.44-2.57,6.33-5.84,6.33-10.97h0v-23.84Z"/>
|
|
21
|
+
<path class="cls-2" d="m149.18,117.04l20.64-11.92c.47-.27.47-.79,0-1.06l-20.65-11.92h0c-4.44-2.57-8.22-2.57-12.67,0l-20.65,11.92c-.47.27-.47.79,0,1.06l20.64,11.92c4.44,2.57,8.22,2.57,12.67,0h0Z"/>
|
|
22
|
+
<path class="cls-1" d="m112.39,98.05l20.65-11.92c4.44-2.57,6.33-5.84,6.33-10.97h0v-23.84c0-.54-.45-.8-.92-.53l-20.64,11.92h0c-4.44,2.57-6.33,5.84-6.33,10.97v23.84c0,.54.45.8.92.54Z"/>
|
|
23
|
+
<path class="cls-1" d="m100.13,105.12c.47-.27.47-.79,0-1.06l-20.65-11.92c-4.44-2.57-8.22-2.57-12.67,0h0s-20.65,11.92-20.65,11.92c-.47.27-.47.79,0,1.06l20.64,11.92h0c4.44,2.57,8.22,2.57,12.67,0l20.64-11.92Z"/>
|
|
24
|
+
<path class="cls-2" d="m65.29,85.01c.47-.27.47-.79,0-1.06l-20.65-11.92c-4.44-2.57-8.22-2.57-12.67,0h0s-20.65,11.92-20.65,11.92c-.47.27-.47.79,0,1.06l20.64,11.92h0c4.44,2.57,8.22,2.57,12.67,0l20.64-11.92Z"/>
|
|
25
|
+
<path class="cls-1" d="m133.04,123.06l-20.64-11.92c-.47-.27-.92-.01-.92.53v23.84c0,5.13,1.89,8.4,6.33,10.97h0s20.65,11.92,20.65,11.92c.47.27.92,0,.92-.54v-23.84s0,0,0,0c0-5.13-1.89-8.4-6.33-10.97Z"/>
|
|
26
|
+
<path class="cls-1" d="m184.02,96.93l20.64-11.92c.47-.27.47-.79,0-1.06l-20.65-11.92h0c-4.44-2.57-8.22-2.57-12.67,0l-20.65,11.92c-.47.27-.47.79,0,1.06l20.64,11.92c4.44,2.57,8.22,2.57,12.67,0h0Z"/>
|
|
27
|
+
</svg>
|
package/dist/demo/demo.css
CHANGED
|
@@ -4,13 +4,12 @@ html
|
|
|
4
4
|
}
|
|
5
5
|
body,nav{ display: flex; flex-wrap: wrap; align-content: stretch; gap: 1rem; }
|
|
6
6
|
body>*{flex: auto;}
|
|
7
|
-
nav
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
{ box-shadow: 0 0 0.5rem lime; padding: 1rem; display: inline-block; flex:1; }
|
|
7
|
+
nav
|
|
8
|
+
{ flex-direction: column;
|
|
9
|
+
dce-root{ box-shadow:none; padding: 0;}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
html-demo-element *:has(>dce-root){ box-shadow: 0 0 0.5rem lime; padding: 1rem; flex:1; display: block; }
|
|
14
13
|
script{ display:none !important; }
|
|
15
14
|
dd{ padding: 1rem;}
|
|
16
15
|
p{ margin: 0;}
|
|
@@ -141,13 +141,13 @@
|
|
|
141
141
|
<html-demo-element legend="6. HTML, SVG by ID within external file" description="Should render 👋, svg, formula">
|
|
142
142
|
<a href="html-template.html">html-template.html</a>
|
|
143
143
|
<template>
|
|
144
|
-
<custom-element src="html-template.html#wave">
|
|
144
|
+
<custom-element src="./html-template.html#wave">
|
|
145
145
|
<template><i>loading HTML from templates file ...</i></template>
|
|
146
146
|
</custom-element>
|
|
147
|
-
<custom-element src="html-template.html#dwc-logo">
|
|
147
|
+
<custom-element src="./html-template.html#dwc-logo">
|
|
148
148
|
<template><i>loading SVG from templates file ...</i></template>
|
|
149
149
|
</custom-element>
|
|
150
|
-
<custom-element src="html-template.html#sophomores-dream">
|
|
150
|
+
<custom-element src="./html-template.html#sophomores-dream">
|
|
151
151
|
<template><i>loading MathML from HTML file ...</i></template>
|
|
152
152
|
</custom-element>
|
|
153
153
|
</template>
|
|
@@ -4,8 +4,16 @@
|
|
|
4
4
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
|
|
5
5
|
<title>DOM merge - Declarative Custom Element implementation demo</title>
|
|
6
6
|
<link rel="icon" href="./wc-square.svg"/>
|
|
7
|
-
|
|
7
|
+
<script type="importmap">
|
|
8
|
+
{
|
|
9
|
+
"imports": {
|
|
10
|
+
"@epa-wg/custom-element/": "../",
|
|
11
|
+
"@epa-wg/custom-element-dist/": "../"
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
</script>
|
|
8
15
|
<script type="module" src="../http-request.js"></script>
|
|
16
|
+
<script type="module" src="../location-element.js"></script>
|
|
9
17
|
<script type="module" src="../custom-element.js"></script>
|
|
10
18
|
<style>
|
|
11
19
|
@import "./demo.css";
|
|
@@ -40,16 +48,20 @@
|
|
|
40
48
|
<html-demo-element legend="1. NPM package version picker"
|
|
41
49
|
description="defaults, last version should be preselected">
|
|
42
50
|
<template>
|
|
43
|
-
<custom-element
|
|
44
|
-
|
|
51
|
+
<custom-element src="./npm-versions.html#npm-version"
|
|
52
|
+
package-name="@epa-wg/custom-element-dist"></custom-element>
|
|
45
53
|
</template>
|
|
46
54
|
</html-demo-element>
|
|
47
55
|
|
|
48
56
|
<html-demo-element legend="2. preselected NPM package version picker"
|
|
49
|
-
description="version 22 should be selected">
|
|
57
|
+
description="version 22 should be selected and date shown">
|
|
50
58
|
<template>
|
|
51
59
|
<custom-element tag="custom-element-version" src="./npm-versions.html#npm-version"></custom-element>
|
|
52
|
-
<custom-element-version
|
|
60
|
+
<custom-element-version
|
|
61
|
+
package-name="@epa-wg/custom-element"
|
|
62
|
+
current-version="0.0.22"
|
|
63
|
+
show-date="true"
|
|
64
|
+
></custom-element-version>
|
|
53
65
|
</template>
|
|
54
66
|
</html-demo-element>
|
|
55
67
|
|
|
@@ -90,11 +102,12 @@
|
|
|
90
102
|
|
|
91
103
|
<html-demo-element legend="5. control version in URL"
|
|
92
104
|
description="">
|
|
93
|
-
1. <button onclick="window.location.hash = `#@epa-wg/custom-element-dist@0.0.
|
|
94
|
-
(can be skipped when run from unpkg.com)<br/>
|
|
105
|
+
1. <button onclick="window.location.hash = `#@epa-wg/custom-element-dist@0.0.25/storybook-static/index.html`">set in page URL to version 0.0.25</button><br/>
|
|
95
106
|
2. switch the package version in select and observe the URL change.
|
|
96
107
|
<template>
|
|
97
|
-
<custom-element src="
|
|
108
|
+
<custom-element src="@epa-wg/custom-element-dist/demo/npm-versions.html#npm-version-to-url"
|
|
109
|
+
package-name="@epa-wg/custom-element-dist"
|
|
110
|
+
></custom-element>
|
|
98
111
|
</template>
|
|
99
112
|
</html-demo-element>
|
|
100
113
|
|
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
|
|
5
5
|
<title>npm-version template</title>
|
|
6
6
|
<link rel="icon" href="./wc-square.svg"/>
|
|
7
|
+
|
|
7
8
|
</head>
|
|
8
9
|
<body>
|
|
9
10
|
|
|
@@ -11,28 +12,29 @@
|
|
|
11
12
|
<a href="./npm-versions-demo.html">docs</a>
|
|
12
13
|
<template id="npm-version">
|
|
13
14
|
<attribute name="package-name"></attribute>
|
|
14
|
-
<attribute name="current-version"></attribute>
|
|
15
|
+
<attribute name="current-version" aria-description="version to select"></attribute>
|
|
16
|
+
<attribute name="show-date" aria-description="set to 'true' to append the date to the version"></attribute>
|
|
15
17
|
<attribute name="value" select="//selected-version"></attribute>
|
|
16
|
-
|
|
17
18
|
<http-request
|
|
18
|
-
url="https://registry.npmjs.org
|
|
19
|
+
url="https://registry.npmjs.org/{$package-name}"
|
|
19
20
|
method="GET"
|
|
20
21
|
header-accept="application/json"
|
|
21
22
|
slice="versions-ajax"></http-request>
|
|
22
23
|
|
|
23
|
-
<label
|
|
24
|
+
<label>
|
|
25
|
+
<slot name="label"><var>{$package-name}</var> version:</slot>
|
|
24
26
|
<xhtml:select slice="selected-version" autocomplete="off" name="version">
|
|
25
27
|
<for-each select="//versions/*">
|
|
26
28
|
<option value="{./@version}">
|
|
27
29
|
<variable name="item-version">{./@version}</variable>
|
|
28
|
-
{ $item-version } - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}
|
|
30
|
+
{ $item-version }<if test="$show-date = 'true' "> - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}</if>
|
|
29
31
|
</option>
|
|
30
32
|
</for-each>
|
|
31
33
|
<for-each select="//versions/*">
|
|
32
34
|
<if test="./@version = $current-version">
|
|
33
35
|
<option selected value="{./@version}">
|
|
34
36
|
<variable name="item-version">{./@version}</variable>
|
|
35
|
-
{ $item-version } - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}
|
|
37
|
+
{ $item-version }<if test="$show-date = 'true' "> - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}</if>
|
|
36
38
|
</option>
|
|
37
39
|
</if>
|
|
38
40
|
</for-each>
|
|
@@ -41,25 +43,52 @@
|
|
|
41
43
|
</template>
|
|
42
44
|
|
|
43
45
|
<template id="npm-version-to-url">
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
substring-after($url, $current-version) ) }</attribute>
|
|
53
|
-
<attribute name="method">location.href</attribute>
|
|
54
|
-
</if>
|
|
55
|
-
</location-element>
|
|
56
|
-
<http-request
|
|
57
|
-
url="https://registry.npmjs.org/@epa-wg/custom-element-dist"
|
|
58
|
-
method="GET"
|
|
59
|
-
header-accept="application/json"
|
|
60
|
-
slice="versions-ajax" ></http-request>
|
|
46
|
+
<attribute name="package-name"></attribute>
|
|
47
|
+
<attribute name="value" select="//selected-version"></attribute>
|
|
48
|
+
<variable name="url" select="//window-location/value/@href"></variable>
|
|
49
|
+
|
|
50
|
+
<variable name="url-version">0{
|
|
51
|
+
substring-before(substring-after(substring($url, string-length(substring-before($url, '/')) -
|
|
52
|
+
string-length(substring-before(substring-before($url, '/'), '@0')) + 2), '@0'), '/')
|
|
53
|
+
}</variable>
|
|
61
54
|
|
|
62
|
-
|
|
63
|
-
|
|
55
|
+
<location-element slice="window-location" live>
|
|
56
|
+
<if test="//selected-version">
|
|
57
|
+
<if test=" not(//url-version = //selected-version ) ">
|
|
58
|
+
<attribute name="src">{ concat( substring-before($url, $url-version),
|
|
59
|
+
//selected-version,
|
|
60
|
+
substring-after($url, $url-version) ) }
|
|
61
|
+
</attribute>
|
|
62
|
+
<attribute name="method">location.href</attribute>
|
|
63
|
+
</if>
|
|
64
|
+
</if>
|
|
65
|
+
</location-element>
|
|
66
|
+
|
|
67
|
+
<http-request
|
|
68
|
+
url="https://registry.npmjs.org/{$package-name}"
|
|
69
|
+
method="GET"
|
|
70
|
+
header-accept="application/json"
|
|
71
|
+
slice="versions-ajax"></http-request>
|
|
72
|
+
|
|
73
|
+
<label>
|
|
74
|
+
<slot name="label">{$package-name} version:</slot>
|
|
75
|
+
<xhtml:select slice="selected-version" autocomplete="off" name="version">
|
|
76
|
+
<for-each select="//versions/*">
|
|
77
|
+
<option value="{./@version}">
|
|
78
|
+
<variable name="item-version">{./@version}</variable>
|
|
79
|
+
{ $item-version } - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}
|
|
80
|
+
</option>
|
|
81
|
+
</for-each>
|
|
82
|
+
<for-each select="//versions/*">
|
|
83
|
+
<if test="./@version = $url-version">
|
|
84
|
+
<option selected value="{./@version}">
|
|
85
|
+
<variable name="item-version">{./@version}</variable>
|
|
86
|
+
{ $item-version } - { substring( //time/*[@dce-object-name = $item-version ], 1,10)}
|
|
87
|
+
</option>
|
|
88
|
+
</if>
|
|
89
|
+
</for-each>
|
|
90
|
+
</xhtml:select>
|
|
91
|
+
</label>
|
|
92
|
+
</template>
|
|
64
93
|
</body>
|
|
65
94
|
</html>
|
package/dist/demo/s.xml
CHANGED
|
@@ -1,28 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
<
|
|
3
|
-
|
|
4
|
-
<span xmlns="http://www.w3.org/1999/xhtml" slot=""></span>
|
|
5
|
-
<npm-version xmlns="http://www.w3.org/1999/xhtml" slice="selected-version" package-name="@epa-wg/custom-element"
|
|
6
|
-
slot=""></npm-version>
|
|
7
|
-
<span xmlns="http://www.w3.org/1999/xhtml" slot=""></span>
|
|
8
|
-
<p xmlns="http://www.w3.org/1999/xhtml" slot="">
|
|
9
|
-
<code>selected-version</code>
|
|
10
|
-
slice: {//selected-version}
|
|
11
|
-
</p>
|
|
12
|
-
<span xmlns="http://www.w3.org/1999/xhtml" slot=""></span>
|
|
13
|
-
</payload>
|
|
14
|
-
<attributes>
|
|
15
|
-
<tag>dce-bbc8e8b4-575f-40d3-9880-2f1d56d85d80</tag>
|
|
16
|
-
</attributes>
|
|
17
|
-
<dataset/>
|
|
18
|
-
<slice>
|
|
19
|
-
<selected-version xmlns="" slice="selected-version" package-name="@epa-wg/custom-element" data-dce-id="2"
|
|
20
|
-
current-version="" value="0.0.21">
|
|
21
|
-
<event isTrusted="false" sliceProcessed="1" type="change" eventPhase="2" bubbles="true" cancelable="false"
|
|
22
|
-
defaultPrevented="false" composed="false" timeStamp="2225577.4000000954" returnValue="true"
|
|
23
|
-
cancelBubble="false" NONE="0" CAPTURING_PHASE="1" AT_TARGET="2" BUBBLING_PHASE="3">
|
|
24
|
-
<detail package-name="@epa-wg/custom-element"/>
|
|
25
|
-
</event>
|
|
26
|
-
</selected-version>
|
|
27
|
-
</slice>
|
|
28
|
-
</datadom>
|
|
1
|
+
<body xmlns="http://www.w3.org/1999/xhtml" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"><h4>embed-1.html</h4>
|
|
2
|
+
<custom-element><template>🖖</template></custom-element>
|
|
3
|
+
</body>
|
package/dist/demo/s.xslt
CHANGED
|
@@ -1,97 +1,56 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
<xsl:
|
|
10
|
-
<xsl:value-of select="def"/>
|
|
11
|
-
</xsl:otherwise>
|
|
12
|
-
</xsl:choose>
|
|
13
|
-
<xsl:value-of select="."/>
|
|
14
|
-
</xsl:template>
|
|
15
|
-
<xsl:template mode="payload" match="attributes">
|
|
16
|
-
<dce-root xmlns="http://www.w3.org/1999/xhtml" xmlns:xhtml="http://www.w3.org/1999/xhtml" data-dce-id="1">
|
|
17
|
-
<xsl:variable xmlns:xsl="http://www.w3.org/1999/XSL/Transform" name="methods">
|
|
18
|
-
<a xmlns="" href="https://developer.mozilla.org/en-US/docs/Web/API/Location/href" data-dce-id="2">
|
|
19
|
-
location.href
|
|
20
|
-
</a>
|
|
21
|
-
<a xmlns="" href="https://developer.mozilla.org/en-US/docs/Web/API/Location/hash" data-dce-id="3">
|
|
22
|
-
location.hash
|
|
23
|
-
</a>
|
|
24
|
-
<a xmlns="" href="https://developer.mozilla.org/en-US/docs/Web/API/Location/assign" data-dce-id="4">
|
|
25
|
-
location.assign
|
|
26
|
-
</a>
|
|
27
|
-
</xsl:variable>
|
|
28
|
-
<fieldset xmlns="" data-dce-id="5">
|
|
29
|
-
<legend data-dce-id="6">
|
|
30
|
-
<b data-dce-id="7">set-by</b>
|
|
31
|
-
</legend>
|
|
32
|
-
<xsl:for-each xmlns:xsl="http://www.w3.org/1999/XSL/Transform" select="$methods">
|
|
33
|
-
<p data-dce-id="8">
|
|
34
|
-
<label data-dce-id="9">
|
|
35
|
-
<input type="radio" name="method" value="{.}" data-dce-id="10"/>
|
|
36
|
-
<dce-text data-dce-id="11">
|
|
37
|
-
<xsl:value-of select="."/>
|
|
38
|
-
</dce-text>
|
|
39
|
-
</label>
|
|
40
|
-
<a class="infolink" href="https://developer.mozilla.org/en-US/docs/Web/API/Location/assign"
|
|
41
|
-
data-dce-id="12">mdn
|
|
42
|
-
</a>
|
|
43
|
-
</p>
|
|
44
|
-
</xsl:for-each>
|
|
45
|
-
<label data-dce-id="13">
|
|
46
|
-
<input type="radio" name="method" value="location.href" data-dce-id="14"/>
|
|
47
|
-
<dce-text data-dce-id="15">location.href</dce-text>
|
|
48
|
-
</label>
|
|
49
|
-
<label data-dce-id="16">
|
|
50
|
-
<input type="radio" name="method" value="location" data-dce-id="17"/>
|
|
51
|
-
<dce-text data-dce-id="18">location</dce-text>
|
|
52
|
-
</label>
|
|
53
|
-
<label data-dce-id="19">
|
|
54
|
-
<input type="radio" name="method" value="location.replace" data-dce-id="20"/>
|
|
55
|
-
<dce-text data-dce-id="21">location.replace</dce-text>
|
|
56
|
-
</label>
|
|
57
|
-
<label data-dce-id="22">
|
|
58
|
-
<input type="radio" name="method" value="location.assign" data-dce-id="23"/>
|
|
59
|
-
<dce-text data-dce-id="24">location.assign</dce-text>
|
|
60
|
-
</label>
|
|
61
|
-
<label data-dce-id="25">
|
|
62
|
-
<input type="radio" name="method" value="location.hash" data-dce-id="26"/>
|
|
63
|
-
<dce-text data-dce-id="27">location.hash</dce-text>
|
|
64
|
-
</label>
|
|
65
|
-
<label data-dce-id="28">
|
|
66
|
-
<input type="radio" name="method" value="history.pushState" data-dce-id="29"/>
|
|
67
|
-
<dce-text data-dce-id="30">history.pushState</dce-text>
|
|
68
|
-
</label>
|
|
69
|
-
<label data-dce-id="31">
|
|
70
|
-
<input type="radio" name="method" value="history.replaceState" data-dce-id="32"/>
|
|
71
|
-
<dce-text data-dce-id="33">history.replaceState</dce-text>
|
|
72
|
-
</label>
|
|
73
|
-
</fieldset>
|
|
1
|
+
<?xml version='1.0' encoding='UTF-8'?>
|
|
2
|
+
<xsl:stylesheet version="1.0"
|
|
3
|
+
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
|
4
|
+
xmlns:xhtml="http://www.w3.org/1999/xhtml"
|
|
5
|
+
>
|
|
6
|
+
<xsl:output method="xml"/>
|
|
7
|
+
<xsl:template match="/">
|
|
8
|
+
<dce-root >
|
|
9
|
+
<xsl:apply-templates select="*"/>
|
|
74
10
|
</dce-root>
|
|
75
11
|
</xsl:template>
|
|
76
|
-
<xsl:template match="
|
|
77
|
-
<xsl:apply-templates mode="
|
|
12
|
+
<xsl:template match="*[name()='template']">
|
|
13
|
+
<xsl:apply-templates mode="sanitize" select="*|text()"/>
|
|
14
|
+
</xsl:template>
|
|
15
|
+
<xsl:template match="*">
|
|
16
|
+
<xsl:apply-templates mode="sanitize" select="*|text()"/>
|
|
17
|
+
</xsl:template>
|
|
18
|
+
<xsl:template match="*[name()='svg']|*[name()='math']">
|
|
19
|
+
<xsl:apply-templates mode="sanitize" select="."/>
|
|
20
|
+
</xsl:template>
|
|
21
|
+
<xsl:template mode="sanitize" match="*[count(text())=1 and count(*)=0]">
|
|
22
|
+
<xsl:copy>
|
|
23
|
+
<xsl:apply-templates mode="sanitize" select="@*"/>
|
|
24
|
+
<xsl:value-of select="text()"></xsl:value-of>
|
|
25
|
+
</xsl:copy>
|
|
26
|
+
</xsl:template>
|
|
27
|
+
<xsl:template mode="sanitize" match="xhtml:*[count(text())=1 and count(*)=0]">
|
|
28
|
+
<xsl:element name="{local-name()}">
|
|
29
|
+
<xsl:apply-templates mode="sanitize" select="@*"/>
|
|
30
|
+
<xsl:value-of select="text()"></xsl:value-of>
|
|
31
|
+
</xsl:element>
|
|
32
|
+
</xsl:template>
|
|
33
|
+
<xsl:template mode="sanitize" match="*|@*">
|
|
34
|
+
<xsl:copy>
|
|
35
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
36
|
+
</xsl:copy>
|
|
37
|
+
</xsl:template>
|
|
38
|
+
<xsl:template mode="sanitize" match="text()[normalize-space(.) = '']"/>
|
|
39
|
+
<xsl:template mode="sanitize" match="text()">
|
|
40
|
+
<dce-text>
|
|
41
|
+
<xsl:copy/>
|
|
42
|
+
</dce-text>
|
|
43
|
+
</xsl:template>
|
|
44
|
+
<xsl:template mode="sanitize" match="xsl:value-of|*[name()='slot']">
|
|
45
|
+
<dce-text>
|
|
46
|
+
<xsl:copy>
|
|
47
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
48
|
+
</xsl:copy>
|
|
49
|
+
</dce-text>
|
|
78
50
|
</xsl:template>
|
|
79
|
-
<xsl:template
|
|
80
|
-
<xsl:
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
<xsl:when test="//payload/*[@slot=$slotname]">
|
|
84
|
-
<xsl:copy-of select="//payload/*[@slot=$slotname]"/>
|
|
85
|
-
</xsl:when>
|
|
86
|
-
<xsl:otherwise>
|
|
87
|
-
<xsl:copy-of select="$defaultvalue"/>
|
|
88
|
-
</xsl:otherwise>
|
|
89
|
-
</xsl:choose>
|
|
51
|
+
<xsl:template mode="sanitize" match="xhtml:*">
|
|
52
|
+
<xsl:element name="{local-name()}">
|
|
53
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
54
|
+
</xsl:element>
|
|
90
55
|
</xsl:template>
|
|
91
|
-
<xsl:variable name="js-injected-body">
|
|
92
|
-
<xsl:call-template name="slot">
|
|
93
|
-
<xsl:with-param name="slotname" select="''"/>
|
|
94
|
-
<xsl:with-param name="defaultvalue"/>
|
|
95
|
-
</xsl:call-template>
|
|
96
|
-
</xsl:variable>
|
|
97
56
|
</xsl:stylesheet>
|