@epa-wg/custom-element-dist 0.0.29 → 0.0.32
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 +11 -0
- package/.idea/inspectionProfiles/Project_Default.xml +25 -0
- package/.idea/misc.xml +6 -0
- package/.idea/modules.xml +8 -0
- package/.idea/vcs.xml +6 -0
- package/.storybook/main.ts +21 -19
- package/.storybook/preview.ts +25 -25
- package/README.md +4 -4
- package/coverage/coverage-final.json +21 -21
- package/coverage/index.html +26 -26
- 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 +543 -441
- package/coverage/src/custom-element/http-request.js.html +12 -12
- package/coverage/src/custom-element/index.html +18 -18
- package/coverage/src/custom-element/local-storage.js.html +52 -52
- package/coverage/src/custom-element/location-element.js.html +4 -4
- package/coverage/src/custom-element/module-url.js.html +1 -1
- 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/coverage.svg +1 -1
- package/coverage/src/stories/attributes.test.stories.ts.html +335 -35
- 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 +1 -1
- package/coverage/src/stories/external-template.test.stories.ts.html +2 -2
- 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 +22 -22
- package/coverage/src/stories/local-storage.test.stories.ts.html +17 -17
- package/coverage/src/stories/location-element.test.stories.ts.html +3 -6
- 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/coverage.svg +1 -1
- package/coverage/src/stories/slice-events.test.stories.ts.html +284 -23
- package/coverage/src/stories/slots.test.stories.ts.html +1 -1
- package/coverage/src/stories/testStoryBook.ts.html +12 -12
- package/coverage/src/stories/version-select.test.stories.ts.html +3 -3
- package/coverage/src/sum.ts.html +1 -1
- package/dist/custom-element-D2wf_rqP.js +576 -0
- package/dist/custom-element-Dtzhbjkc.cjs +97 -0
- package/dist/custom-element-bundle.cjs +1 -1
- package/dist/custom-element-bundle.js +30 -28
- package/dist/demo/a.html +51 -38
- package/dist/demo/a.svg +26 -26
- package/dist/demo/data-slices.html +37 -0
- package/dist/demo/external-template.html +1 -0
- package/dist/demo/form.html +42 -0
- package/dist/demo/hex-grid-dce.html +1 -1
- package/dist/demo/hex-grid.html +1 -1
- package/dist/demo/parameters.html +20 -1
- package/dist/demo/s.xml +6 -12
- package/dist/demo/s.xslt +64 -15
- package/dist/demo/ss.html +4 -23
- package/package.json +13 -13
- package/public/demo/a.html +51 -38
- package/public/demo/a.svg +26 -26
- package/public/demo/data-slices.html +37 -0
- package/public/demo/external-template.html +1 -0
- package/public/demo/form.html +42 -0
- package/public/demo/hex-grid-dce.html +1 -1
- package/public/demo/hex-grid.html +1 -1
- package/public/demo/parameters.html +20 -1
- package/public/demo/s.xml +6 -12
- package/public/demo/s.xslt +64 -15
- package/public/demo/ss.html +4 -23
- package/src/custom-element/custom-element.js +76 -42
- package/src/custom-element/demo/a.html +51 -38
- package/src/custom-element/demo/a.svg +26 -26
- package/src/custom-element/demo/data-slices.html +37 -0
- package/src/custom-element/demo/external-template.html +1 -0
- package/src/custom-element/demo/form.html +42 -0
- package/src/custom-element/demo/hex-grid-dce.html +1 -1
- package/src/custom-element/demo/hex-grid.html +1 -1
- package/src/custom-element/demo/parameters.html +20 -1
- package/src/custom-element/demo/s.xml +6 -12
- package/src/custom-element/demo/s.xslt +64 -15
- package/src/custom-element/demo/ss.html +4 -23
- package/src/custom-element/ide/web-types-dce.json +1 -1
- package/src/custom-element/ide/web-types-xsl.json +1 -1
- package/src/material/angular.css +987 -987
- package/src/material/components/autocomplete.html +239 -240
- package/src/material/components/dropdown.html +110 -46
- package/src/material/components/icon-link.html +160 -160
- package/src/material/components/input.html +363 -0
- package/src/material/components/menu.html +234 -234
- package/src/material/components.html +121 -120
- package/src/material/demo.css +36 -31
- package/src/material/index.html +110 -110
- package/src/material/material.css +356 -356
- package/src/material/theme/README.md +17 -17
- package/src/material/theme/semantic.css +113 -112
- package/src/mocks/versions.mock.ts +8 -8
- package/src/stories/attributes.test.stories.ts +123 -23
- package/src/stories/external-template.test.stories.ts +1 -1
- package/src/stories/location-element.test.stories.ts +1 -2
- package/src/stories/slice-events.test.stories.ts +87 -0
- package/storybook-static/assets/Color-F6OSRLHC-BU3iy8jH.js +1 -0
- package/storybook-static/assets/{Configure-DOhzHFEs.js → Configure-DN6ifayP.js} +1 -1
- package/storybook-static/assets/{DocsRenderer-CFRXHY34-BSJkbsd6.js → DocsRenderer-CFRXHY34-BaVEufDj.js} +2 -2
- package/storybook-static/assets/attributes.test.stories-D1X6EBrd.js +278 -0
- package/storybook-static/assets/{css.test.stories-pgbBc17d.js → css.test.stories-Cp_g2hE1.js} +1 -1
- package/storybook-static/assets/custom-element-uuAtIYWS.js +97 -0
- package/storybook-static/assets/{dom-merge.test.stories-CXcYP_-J.js → dom-merge.test.stories-hbpdCka0.js} +1 -1
- package/storybook-static/assets/entry-preview-DHVXbf3x.js +26 -0
- package/storybook-static/assets/entry-preview-docs-BbcIMweR.js +2 -0
- package/storybook-static/assets/{external-template.test.stories-CpJ68Ghy.js → external-template.test.stories-BK89h6sk.js} +3 -3
- package/storybook-static/assets/{form.test.stories-D35lyqd8.js → form.test.stories-BfoLe_rw.js} +1 -1
- package/storybook-static/assets/{handlers-CW9pDZnt.js → handlers-yVPwH_Nz.js} +21 -21
- package/storybook-static/assets/{http-request.stories-CBbknCOO.js → http-request.stories-CBFJS2Ws.js} +1 -1
- package/storybook-static/assets/iframe-CJEL_4Nu.js +2 -0
- package/storybook-static/assets/index-BcZLpTeD.js +8 -0
- package/storybook-static/assets/{index-BSz1w4Gl.js → index-CxRwF5Or.js} +130 -130
- package/storybook-static/assets/index-D5fBh-7N.js +1 -0
- package/storybook-static/assets/{index-YxUFxnQR.js → index-DM-KBPdl.js} +1 -1
- package/storybook-static/assets/{index-B3QjF0Ed.js → index-RSFf30w1.js} +1 -1
- package/storybook-static/assets/index-SnjB5uV8.js +769 -0
- package/storybook-static/assets/{local-storage.test.stories-BY-PWhuk.js → local-storage.test.stories-C0Yzy6Am.js} +1 -1
- package/storybook-static/assets/{location-element.test.stories-3auBYEaU.js → location-element.test.stories-DNFrEu5A.js} +1 -1
- package/storybook-static/assets/{module-url.test.stories-B7L9cL60.js → module-url.test.stories-CXibF5Ta.js} +1 -1
- package/storybook-static/assets/{preview-CfWMRsRq.js → preview-Bnd0XhaF.js} +2 -2
- package/storybook-static/assets/{preview-BRPR-UXC.js → preview-CNKoaWES.js} +1 -1
- package/storybook-static/assets/preview-DAeyCMnM.js +1 -0
- package/storybook-static/assets/preview-DJMlNTk8.js +2 -0
- package/storybook-static/assets/{set-url.test.stories-CuSuDLIx.js → set-url.test.stories-BBfLxv2u.js} +1 -1
- package/storybook-static/assets/{slice-events.test.stories-BkRKsKem.js → slice-events.test.stories-HcXF8XQI.js} +138 -13
- package/storybook-static/assets/{slots.test.stories-BJCUWFkE.js → slots.test.stories-i6mnIFM2.js} +1 -1
- package/storybook-static/assets/tiny-invariant-CopsF_GD.js +1 -0
- package/storybook-static/assets/{version-select.test.stories-B3ybJn_Z.js → version-select.test.stories-BsUFH6Va.js} +1 -1
- package/storybook-static/demo/a.html +51 -38
- package/storybook-static/demo/a.svg +26 -26
- package/storybook-static/demo/data-slices.html +37 -0
- package/storybook-static/demo/external-template.html +1 -0
- package/storybook-static/demo/form.html +42 -0
- package/storybook-static/demo/hex-grid-dce.html +1 -1
- package/storybook-static/demo/hex-grid.html +1 -1
- package/storybook-static/demo/parameters.html +20 -1
- package/storybook-static/demo/s.xml +6 -12
- package/storybook-static/demo/s.xslt +64 -15
- package/storybook-static/demo/ss.html +4 -23
- package/storybook-static/iframe.html +2 -2
- package/storybook-static/index.html +4 -0
- package/storybook-static/index.json +1 -1
- package/storybook-static/project.json +1 -1
- package/storybook-static/sb-addons/chromatic-com-storybook-10/manager-bundle.js +333 -0
- package/storybook-static/sb-addons/chromatic-com-storybook-10/manager-bundle.js.LEGAL.txt +40 -0
- package/storybook-static/sb-addons/essentials-actions-3/manager-bundle.js +1 -1
- package/storybook-static/sb-addons/essentials-backgrounds-4/manager-bundle.js +8 -8
- package/storybook-static/sb-addons/essentials-controls-2/manager-bundle.js +82 -85
- package/storybook-static/sb-addons/essentials-measure-7/manager-bundle.js +1 -1
- package/storybook-static/sb-addons/essentials-outline-8/manager-bundle.js +1 -1
- package/storybook-static/sb-addons/essentials-viewport-5/manager-bundle.js +1 -1
- package/storybook-static/sb-addons/interactions-9/manager-bundle.js +66 -67
- package/storybook-static/sb-addons/storybook-core-core-server-presets-0/common-manager-bundle.js +1 -1
- package/storybook-static/sb-manager/globals-module-info.js +25 -3
- package/storybook-static/sb-manager/globals-runtime.js +29585 -43124
- package/storybook-static/sb-manager/runtime.js +10647 -9399
- package/storybook-static/sb-preview/runtime.js +3536 -5860
- package/test-runner-jest.config.js +15 -0
- package/dist/custom-element-BOIPgtxz.js +0 -565
- package/dist/custom-element-CUsSENWc.cjs +0 -97
- package/src/stories/__screenshots__/http-request.test.ts/http-request-url-change-1.png +0 -0
- package/storybook-static/assets/Color-ERTF36HU-CQkSD2nd.js +0 -1
- package/storybook-static/assets/attributes.test.stories-BJBuuXgZ.js +0 -150
- package/storybook-static/assets/custom-element-BDGsYgbP.js +0 -97
- package/storybook-static/assets/entry-preview-C313OLrj.js +0 -26
- package/storybook-static/assets/entry-preview-docs-B7ORr9w5.js +0 -2
- package/storybook-static/assets/iframe-DOi4N7qI.js +0 -2
- package/storybook-static/assets/index-BdcJ-iJ7.js +0 -8
- package/storybook-static/assets/index-CaL3Qp7t.js +0 -634
- package/storybook-static/assets/index-DgFM0Ce3.js +0 -1
- package/storybook-static/assets/preview-C992A1Y-.js +0 -2
- package/storybook-static/assets/preview-CcS4DQh8.js +0 -1
- package/storybook-static/assets/tiny-invariant-BxWVcicq.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{ae as ce,af as v,ag as p,ah as E,a2 as Y,a0 as he,N as fe,ai as de,aj as ge,ak as be,al as H}from"./index-SnjB5uV8.js";import"./iframe-CJEL_4Nu.js";import"../sb-preview/runtime.js";import"./index-BcZLpTeD.js";import"./index-D-8MO0q_.js";import"./index-DrFu-skq.js";var ve=H({"../../node_modules/color-name/index.js"(n,l){l.exports={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]}}}),J=H({"../../node_modules/color-convert/conversions.js"(n,l){var c=ve(),h={};for(let e of Object.keys(c))h[c[e]]=e;var i={rgb:{channels:3,labels:"rgb"},hsl:{channels:3,labels:"hsl"},hsv:{channels:3,labels:"hsv"},hwb:{channels:3,labels:"hwb"},cmyk:{channels:4,labels:"cmyk"},xyz:{channels:3,labels:"xyz"},lab:{channels:3,labels:"lab"},lch:{channels:3,labels:"lch"},hex:{channels:1,labels:["hex"]},keyword:{channels:1,labels:["keyword"]},ansi16:{channels:1,labels:["ansi16"]},ansi256:{channels:1,labels:["ansi256"]},hcg:{channels:3,labels:["h","c","g"]},apple:{channels:3,labels:["r16","g16","b16"]},gray:{channels:1,labels:["gray"]}};l.exports=i;for(let e of Object.keys(i)){if(!("channels"in i[e]))throw new Error("missing channels property: "+e);if(!("labels"in i[e]))throw new Error("missing channel labels property: "+e);if(i[e].labels.length!==i[e].channels)throw new Error("channel and label counts mismatch: "+e);let{channels:t,labels:r}=i[e];delete i[e].channels,delete i[e].labels,Object.defineProperty(i[e],"channels",{value:t}),Object.defineProperty(i[e],"labels",{value:r})}i.rgb.hsl=function(e){let t=e[0]/255,r=e[1]/255,a=e[2]/255,o=Math.min(t,r,a),u=Math.max(t,r,a),s=u-o,f,g;u===o?f=0:t===u?f=(r-a)/s:r===u?f=2+(a-t)/s:a===u&&(f=4+(t-r)/s),f=Math.min(f*60,360),f<0&&(f+=360);let b=(o+u)/2;return u===o?g=0:b<=.5?g=s/(u+o):g=s/(2-u-o),[f,g*100,b*100]},i.rgb.hsv=function(e){let t,r,a,o,u,s=e[0]/255,f=e[1]/255,g=e[2]/255,b=Math.max(s,f,g),y=b-Math.min(s,f,g),m=function(k){return(b-k)/6/y+1/2};return y===0?(o=0,u=0):(u=y/b,t=m(s),r=m(f),a=m(g),s===b?o=a-r:f===b?o=1/3+t-a:g===b&&(o=2/3+r-t),o<0?o+=1:o>1&&(o-=1)),[o*360,u*100,b*100]},i.rgb.hwb=function(e){let t=e[0],r=e[1],a=e[2],o=i.rgb.hsl(e)[0],u=1/255*Math.min(t,Math.min(r,a));return a=1-1/255*Math.max(t,Math.max(r,a)),[o,u*100,a*100]},i.rgb.cmyk=function(e){let t=e[0]/255,r=e[1]/255,a=e[2]/255,o=Math.min(1-t,1-r,1-a),u=(1-t-o)/(1-o)||0,s=(1-r-o)/(1-o)||0,f=(1-a-o)/(1-o)||0;return[u*100,s*100,f*100,o*100]};function d(e,t){return(e[0]-t[0])**2+(e[1]-t[1])**2+(e[2]-t[2])**2}i.rgb.keyword=function(e){let t=h[e];if(t)return t;let r=1/0,a;for(let o of Object.keys(c)){let u=c[o],s=d(e,u);s<r&&(r=s,a=o)}return a},i.keyword.rgb=function(e){return c[e]},i.rgb.xyz=function(e){let t=e[0]/255,r=e[1]/255,a=e[2]/255;t=t>.04045?((t+.055)/1.055)**2.4:t/12.92,r=r>.04045?((r+.055)/1.055)**2.4:r/12.92,a=a>.04045?((a+.055)/1.055)**2.4:a/12.92;let o=t*.4124+r*.3576+a*.1805,u=t*.2126+r*.7152+a*.0722,s=t*.0193+r*.1192+a*.9505;return[o*100,u*100,s*100]},i.rgb.lab=function(e){let t=i.rgb.xyz(e),r=t[0],a=t[1],o=t[2];r/=95.047,a/=100,o/=108.883,r=r>.008856?r**(1/3):7.787*r+16/116,a=a>.008856?a**(1/3):7.787*a+16/116,o=o>.008856?o**(1/3):7.787*o+16/116;let u=116*a-16,s=500*(r-a),f=200*(a-o);return[u,s,f]},i.hsl.rgb=function(e){let t=e[0]/360,r=e[1]/100,a=e[2]/100,o,u,s;if(r===0)return s=a*255,[s,s,s];a<.5?o=a*(1+r):o=a+r-a*r;let f=2*a-o,g=[0,0,0];for(let b=0;b<3;b++)u=t+1/3*-(b-1),u<0&&u++,u>1&&u--,6*u<1?s=f+(o-f)*6*u:2*u<1?s=o:3*u<2?s=f+(o-f)*(2/3-u)*6:s=f,g[b]=s*255;return g},i.hsl.hsv=function(e){let t=e[0],r=e[1]/100,a=e[2]/100,o=r,u=Math.max(a,.01);a*=2,r*=a<=1?a:2-a,o*=u<=1?u:2-u;let s=(a+r)/2,f=a===0?2*o/(u+o):2*r/(a+r);return[t,f*100,s*100]},i.hsv.rgb=function(e){let t=e[0]/60,r=e[1]/100,a=e[2]/100,o=Math.floor(t)%6,u=t-Math.floor(t),s=255*a*(1-r),f=255*a*(1-r*u),g=255*a*(1-r*(1-u));switch(a*=255,o){case 0:return[a,g,s];case 1:return[f,a,s];case 2:return[s,a,g];case 3:return[s,f,a];case 4:return[g,s,a];case 5:return[a,s,f]}},i.hsv.hsl=function(e){let t=e[0],r=e[1]/100,a=e[2]/100,o=Math.max(a,.01),u,s;s=(2-r)*a;let f=(2-r)*o;return u=r*o,u/=f<=1?f:2-f,u=u||0,s/=2,[t,u*100,s*100]},i.hwb.rgb=function(e){let t=e[0]/360,r=e[1]/100,a=e[2]/100,o=r+a,u;o>1&&(r/=o,a/=o);let s=Math.floor(6*t),f=1-a;u=6*t-s,s&1&&(u=1-u);let g=r+u*(f-r),b,y,m;switch(s){default:case 6:case 0:b=f,y=g,m=r;break;case 1:b=g,y=f,m=r;break;case 2:b=r,y=f,m=g;break;case 3:b=r,y=g,m=f;break;case 4:b=g,y=r,m=f;break;case 5:b=f,y=r,m=g;break}return[b*255,y*255,m*255]},i.cmyk.rgb=function(e){let t=e[0]/100,r=e[1]/100,a=e[2]/100,o=e[3]/100,u=1-Math.min(1,t*(1-o)+o),s=1-Math.min(1,r*(1-o)+o),f=1-Math.min(1,a*(1-o)+o);return[u*255,s*255,f*255]},i.xyz.rgb=function(e){let t=e[0]/100,r=e[1]/100,a=e[2]/100,o,u,s;return o=t*3.2406+r*-1.5372+a*-.4986,u=t*-.9689+r*1.8758+a*.0415,s=t*.0557+r*-.204+a*1.057,o=o>.0031308?1.055*o**(1/2.4)-.055:o*12.92,u=u>.0031308?1.055*u**(1/2.4)-.055:u*12.92,s=s>.0031308?1.055*s**(1/2.4)-.055:s*12.92,o=Math.min(Math.max(0,o),1),u=Math.min(Math.max(0,u),1),s=Math.min(Math.max(0,s),1),[o*255,u*255,s*255]},i.xyz.lab=function(e){let t=e[0],r=e[1],a=e[2];t/=95.047,r/=100,a/=108.883,t=t>.008856?t**(1/3):7.787*t+16/116,r=r>.008856?r**(1/3):7.787*r+16/116,a=a>.008856?a**(1/3):7.787*a+16/116;let o=116*r-16,u=500*(t-r),s=200*(r-a);return[o,u,s]},i.lab.xyz=function(e){let t=e[0],r=e[1],a=e[2],o,u,s;u=(t+16)/116,o=r/500+u,s=u-a/200;let f=u**3,g=o**3,b=s**3;return u=f>.008856?f:(u-16/116)/7.787,o=g>.008856?g:(o-16/116)/7.787,s=b>.008856?b:(s-16/116)/7.787,o*=95.047,u*=100,s*=108.883,[o,u,s]},i.lab.lch=function(e){let t=e[0],r=e[1],a=e[2],o;o=Math.atan2(a,r)*360/2/Math.PI,o<0&&(o+=360);let u=Math.sqrt(r*r+a*a);return[t,u,o]},i.lch.lab=function(e){let t=e[0],r=e[1],a=e[2]/360*2*Math.PI,o=r*Math.cos(a),u=r*Math.sin(a);return[t,o,u]},i.rgb.ansi16=function(e,t=null){let[r,a,o]=e,u=t===null?i.rgb.hsv(e)[2]:t;if(u=Math.round(u/50),u===0)return 30;let s=30+(Math.round(o/255)<<2|Math.round(a/255)<<1|Math.round(r/255));return u===2&&(s+=60),s},i.hsv.ansi16=function(e){return i.rgb.ansi16(i.hsv.rgb(e),e[2])},i.rgb.ansi256=function(e){let t=e[0],r=e[1],a=e[2];return t===r&&r===a?t<8?16:t>248?231:Math.round((t-8)/247*24)+232:16+36*Math.round(t/255*5)+6*Math.round(r/255*5)+Math.round(a/255*5)},i.ansi16.rgb=function(e){let t=e%10;if(t===0||t===7)return e>50&&(t+=3.5),t=t/10.5*255,[t,t,t];let r=(~~(e>50)+1)*.5,a=(t&1)*r*255,o=(t>>1&1)*r*255,u=(t>>2&1)*r*255;return[a,o,u]},i.ansi256.rgb=function(e){if(e>=232){let u=(e-232)*10+8;return[u,u,u]}e-=16;let t,r=Math.floor(e/36)/5*255,a=Math.floor((t=e%36)/6)/5*255,o=t%6/5*255;return[r,a,o]},i.rgb.hex=function(e){let t=(((Math.round(e[0])&255)<<16)+((Math.round(e[1])&255)<<8)+(Math.round(e[2])&255)).toString(16).toUpperCase();return"000000".substring(t.length)+t},i.hex.rgb=function(e){let t=e.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);if(!t)return[0,0,0];let r=t[0];t[0].length===3&&(r=r.split("").map(f=>f+f).join(""));let a=parseInt(r,16),o=a>>16&255,u=a>>8&255,s=a&255;return[o,u,s]},i.rgb.hcg=function(e){let t=e[0]/255,r=e[1]/255,a=e[2]/255,o=Math.max(Math.max(t,r),a),u=Math.min(Math.min(t,r),a),s=o-u,f,g;return s<1?f=u/(1-s):f=0,s<=0?g=0:o===t?g=(r-a)/s%6:o===r?g=2+(a-t)/s:g=4+(t-r)/s,g/=6,g%=1,[g*360,s*100,f*100]},i.hsl.hcg=function(e){let t=e[1]/100,r=e[2]/100,a=r<.5?2*t*r:2*t*(1-r),o=0;return a<1&&(o=(r-.5*a)/(1-a)),[e[0],a*100,o*100]},i.hsv.hcg=function(e){let t=e[1]/100,r=e[2]/100,a=t*r,o=0;return a<1&&(o=(r-a)/(1-a)),[e[0],a*100,o*100]},i.hcg.rgb=function(e){let t=e[0]/360,r=e[1]/100,a=e[2]/100;if(r===0)return[a*255,a*255,a*255];let o=[0,0,0],u=t%1*6,s=u%1,f=1-s,g=0;switch(Math.floor(u)){case 0:o[0]=1,o[1]=s,o[2]=0;break;case 1:o[0]=f,o[1]=1,o[2]=0;break;case 2:o[0]=0,o[1]=1,o[2]=s;break;case 3:o[0]=0,o[1]=f,o[2]=1;break;case 4:o[0]=s,o[1]=0,o[2]=1;break;default:o[0]=1,o[1]=0,o[2]=f}return g=(1-r)*a,[(r*o[0]+g)*255,(r*o[1]+g)*255,(r*o[2]+g)*255]},i.hcg.hsv=function(e){let t=e[1]/100,r=e[2]/100,a=t+r*(1-t),o=0;return a>0&&(o=t/a),[e[0],o*100,a*100]},i.hcg.hsl=function(e){let t=e[1]/100,r=e[2]/100*(1-t)+.5*t,a=0;return r>0&&r<.5?a=t/(2*r):r>=.5&&r<1&&(a=t/(2*(1-r))),[e[0],a*100,r*100]},i.hcg.hwb=function(e){let t=e[1]/100,r=e[2]/100,a=t+r*(1-t);return[e[0],(a-t)*100,(1-a)*100]},i.hwb.hcg=function(e){let t=e[1]/100,r=1-e[2]/100,a=r-t,o=0;return a<1&&(o=(r-a)/(1-a)),[e[0],a*100,o*100]},i.apple.rgb=function(e){return[e[0]/65535*255,e[1]/65535*255,e[2]/65535*255]},i.rgb.apple=function(e){return[e[0]/255*65535,e[1]/255*65535,e[2]/255*65535]},i.gray.rgb=function(e){return[e[0]/100*255,e[0]/100*255,e[0]/100*255]},i.gray.hsl=function(e){return[0,0,e[0]]},i.gray.hsv=i.gray.hsl,i.gray.hwb=function(e){return[0,100,e[0]]},i.gray.cmyk=function(e){return[0,0,0,e[0]]},i.gray.lab=function(e){return[e[0],0,0]},i.gray.hex=function(e){let t=Math.round(e[0]/100*255)&255,r=((t<<16)+(t<<8)+t).toString(16).toUpperCase();return"000000".substring(r.length)+r},i.rgb.gray=function(e){return[(e[0]+e[1]+e[2])/3/255*100]}}}),me=H({"../../node_modules/color-convert/route.js"(n,l){var c=J();function h(){let t={},r=Object.keys(c);for(let a=r.length,o=0;o<a;o++)t[r[o]]={distance:-1,parent:null};return t}function i(t){let r=h(),a=[t];for(r[t].distance=0;a.length;){let o=a.pop(),u=Object.keys(c[o]);for(let s=u.length,f=0;f<s;f++){let g=u[f],b=r[g];b.distance===-1&&(b.distance=r[o].distance+1,b.parent=o,a.unshift(g))}}return r}function d(t,r){return function(a){return r(t(a))}}function e(t,r){let a=[r[t].parent,t],o=c[r[t].parent][t],u=r[t].parent;for(;r[u].parent;)a.unshift(r[u].parent),o=d(c[r[u].parent][u],o),u=r[u].parent;return o.conversion=a,o}l.exports=function(t){let r=i(t),a={},o=Object.keys(r);for(let u=o.length,s=0;s<u;s++){let f=o[s];r[f].parent!==null&&(a[f]=e(f,r))}return a}}}),pe=H({"../../node_modules/color-convert/index.js"(n,l){var c=J(),h=me(),i={},d=Object.keys(c);function e(r){let a=function(...o){let u=o[0];return u==null?u:(u.length>1&&(o=u),r(o))};return"conversion"in r&&(a.conversion=r.conversion),a}function t(r){let a=function(...o){let u=o[0];if(u==null)return u;u.length>1&&(o=u);let s=r(o);if(typeof s=="object")for(let f=s.length,g=0;g<f;g++)s[g]=Math.round(s[g]);return s};return"conversion"in r&&(a.conversion=r.conversion),a}d.forEach(r=>{i[r]={},Object.defineProperty(i[r],"channels",{value:c[r].channels}),Object.defineProperty(i[r],"labels",{value:c[r].labels});let a=h(r);Object.keys(a).forEach(o=>{let u=a[o];i[r][o]=t(u),i[r][o].raw=e(u)})}),l.exports=i}}),_=ce(pe());function M(){return(M=Object.assign||function(n){for(var l=1;l<arguments.length;l++){var c=arguments[l];for(var h in c)Object.prototype.hasOwnProperty.call(c,h)&&(n[h]=c[h])}return n}).apply(this,arguments)}function X(n,l){if(n==null)return{};var c,h,i={},d=Object.keys(n);for(h=0;h<d.length;h++)l.indexOf(c=d[h])>=0||(i[c]=n[c]);return i}function P(n){var l=p.useRef(n),c=p.useRef(function(h){l.current&&l.current(h)});return l.current=n,c.current}var $=function(n,l,c){return l===void 0&&(l=0),c===void 0&&(c=1),n>c?c:n<l?l:n},N=function(n){return"touches"in n},L=function(n){return n&&n.ownerDocument.defaultView||self},G=function(n,l,c){var h=n.getBoundingClientRect(),i=N(l)?function(d,e){for(var t=0;t<d.length;t++)if(d[t].identifier===e)return d[t];return d[0]}(l.touches,c):l;return{left:$((i.pageX-(h.left+L(n).pageXOffset))/h.width),top:$((i.pageY-(h.top+L(n).pageYOffset))/h.height)}},F=function(n){!N(n)&&n.preventDefault()},D=v.memo(function(n){var l=n.onMove,c=n.onKey,h=X(n,["onMove","onKey"]),i=p.useRef(null),d=P(l),e=P(c),t=p.useRef(null),r=p.useRef(!1),a=p.useMemo(function(){var f=function(y){F(y),(N(y)?y.touches.length>0:y.buttons>0)&&i.current?d(G(i.current,y,t.current)):b(!1)},g=function(){return b(!1)};function b(y){var m=r.current,k=L(i.current),w=y?k.addEventListener:k.removeEventListener;w(m?"touchmove":"mousemove",f),w(m?"touchend":"mouseup",g)}return[function(y){var m=y.nativeEvent,k=i.current;if(k&&(F(m),!function(q,se){return se&&!N(q)}(m,r.current)&&k)){if(N(m)){r.current=!0;var w=m.changedTouches||[];w.length&&(t.current=w[0].identifier)}k.focus(),d(G(k,m,t.current)),b(!0)}},function(y){var m=y.which||y.keyCode;m<37||m>40||(y.preventDefault(),e({left:m===39?.05:m===37?-.05:0,top:m===40?.05:m===38?-.05:0}))},b]},[e,d]),o=a[0],u=a[1],s=a[2];return p.useEffect(function(){return s},[s]),v.createElement("div",M({},h,{onTouchStart:o,onMouseDown:o,className:"react-colorful__interactive",ref:i,onKeyDown:u,tabIndex:0,role:"slider"}))}),O=function(n){return n.filter(Boolean).join(" ")},V=function(n){var l=n.color,c=n.left,h=n.top,i=h===void 0?.5:h,d=O(["react-colorful__pointer",n.className]);return v.createElement("div",{className:d,style:{top:100*i+"%",left:100*c+"%"}},v.createElement("div",{className:"react-colorful__pointer-fill",style:{backgroundColor:l}}))},x=function(n,l,c){return l===void 0&&(l=0),c===void 0&&(c=Math.pow(10,l)),Math.round(c*n)/c},ye={grad:.9,turn:360,rad:360/(2*Math.PI)},xe=function(n){return ee(B(n))},B=function(n){return n[0]==="#"&&(n=n.substring(1)),n.length<6?{r:parseInt(n[0]+n[0],16),g:parseInt(n[1]+n[1],16),b:parseInt(n[2]+n[2],16),a:n.length===4?x(parseInt(n[3]+n[3],16)/255,2):1}:{r:parseInt(n.substring(0,2),16),g:parseInt(n.substring(2,4),16),b:parseInt(n.substring(4,6),16),a:n.length===8?x(parseInt(n.substring(6,8),16)/255,2):1}},we=function(n,l){return l===void 0&&(l="deg"),Number(n)*(ye[l]||1)},ke=function(n){var l=/hsla?\(?\s*(-?\d*\.?\d+)(deg|rad|grad|turn)?[,\s]+(-?\d*\.?\d+)%?[,\s]+(-?\d*\.?\d+)%?,?\s*[/\s]*(-?\d*\.?\d+)?(%)?\s*\)?/i.exec(n);return l?_e({h:we(l[1],l[2]),s:Number(l[3]),l:Number(l[4]),a:l[5]===void 0?1:Number(l[5])/(l[6]?100:1)}):{h:0,s:0,v:0,a:1}},_e=function(n){var l=n.s,c=n.l;return{h:n.h,s:(l*=(c<50?c:100-c)/100)>0?2*l/(c+l)*100:0,v:c+l,a:n.a}},Ee=function(n){return Ce(Z(n))},Q=function(n){var l=n.s,c=n.v,h=n.a,i=(200-l)*c/100;return{h:x(n.h),s:x(i>0&&i<200?l*c/100/(i<=100?i:200-i)*100:0),l:x(i/2),a:x(h,2)}},T=function(n){var l=Q(n);return"hsl("+l.h+", "+l.s+"%, "+l.l+"%)"},z=function(n){var l=Q(n);return"hsla("+l.h+", "+l.s+"%, "+l.l+"%, "+l.a+")"},Z=function(n){var l=n.h,c=n.s,h=n.v,i=n.a;l=l/360*6,c/=100,h/=100;var d=Math.floor(l),e=h*(1-c),t=h*(1-(l-d)*c),r=h*(1-(1-l+d)*c),a=d%6;return{r:x(255*[h,t,e,e,r,h][a]),g:x(255*[r,h,h,t,e,e][a]),b:x(255*[e,e,r,h,h,t][a]),a:x(i,2)}},Me=function(n){var l=/rgba?\(?\s*(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?,?\s*[/\s]*(-?\d*\.?\d+)?(%)?\s*\)?/i.exec(n);return l?ee({r:Number(l[1])/(l[2]?100/255:1),g:Number(l[3])/(l[4]?100/255:1),b:Number(l[5])/(l[6]?100/255:1),a:l[7]===void 0?1:Number(l[7])/(l[8]?100:1)}):{h:0,s:0,v:0,a:1}},S=function(n){var l=n.toString(16);return l.length<2?"0"+l:l},Ce=function(n){var l=n.r,c=n.g,h=n.b,i=n.a,d=i<1?S(x(255*i)):"";return"#"+S(l)+S(c)+S(h)+d},ee=function(n){var l=n.r,c=n.g,h=n.b,i=n.a,d=Math.max(l,c,h),e=d-Math.min(l,c,h),t=e?d===l?(c-h)/e:d===c?2+(h-l)/e:4+(l-c)/e:0;return{h:x(60*(t<0?t+6:t)),s:x(d?e/d*100:0),v:x(d/255*100),a:i}},re=v.memo(function(n){var l=n.hue,c=n.onChange,h=O(["react-colorful__hue",n.className]);return v.createElement("div",{className:h},v.createElement(D,{onMove:function(i){c({h:360*i.left})},onKey:function(i){c({h:$(l+360*i.left,0,360)})},"aria-label":"Hue","aria-valuenow":x(l),"aria-valuemax":"360","aria-valuemin":"0"},v.createElement(V,{className:"react-colorful__hue-pointer",left:l/360,color:T({h:l,s:100,v:100,a:1})})))}),te=v.memo(function(n){var l=n.hsva,c=n.onChange,h={backgroundColor:T({h:l.h,s:100,v:100,a:1})};return v.createElement("div",{className:"react-colorful__saturation",style:h},v.createElement(D,{onMove:function(i){c({s:100*i.left,v:100-100*i.top})},onKey:function(i){c({s:$(l.s+100*i.left,0,100),v:$(l.v-100*i.top,0,100)})},"aria-label":"Color","aria-valuetext":"Saturation "+x(l.s)+"%, Brightness "+x(l.v)+"%"},v.createElement(V,{className:"react-colorful__saturation-pointer",top:1-l.v/100,left:l.s/100,color:T(l)})))}),ne=function(n,l){if(n===l)return!0;for(var c in n)if(n[c]!==l[c])return!1;return!0},ae=function(n,l){return n.replace(/\s/g,"")===l.replace(/\s/g,"")},$e=function(n,l){return n.toLowerCase()===l.toLowerCase()||ne(B(n),B(l))};function oe(n,l,c){var h=P(c),i=p.useState(function(){return n.toHsva(l)}),d=i[0],e=i[1],t=p.useRef({color:l,hsva:d});p.useEffect(function(){if(!n.equal(l,t.current.color)){var a=n.toHsva(l);t.current={hsva:a,color:l},e(a)}},[l,n]),p.useEffect(function(){var a;ne(d,t.current.hsva)||n.equal(a=n.fromHsva(d),t.current.color)||(t.current={hsva:d,color:a},h(a))},[d,n,h]);var r=p.useCallback(function(a){e(function(o){return Object.assign({},o,a)})},[]);return[d,r]}var Ne=typeof window<"u"?p.useLayoutEffect:p.useEffect,Oe=function(){return typeof __webpack_nonce__<"u"?__webpack_nonce__:void 0},W=new Map,le=function(n){Ne(function(){var l=n.current?n.current.ownerDocument:document;if(l!==void 0&&!W.has(l)){var c=l.createElement("style");c.innerHTML=`.react-colorful{position:relative;display:flex;flex-direction:column;width:200px;height:200px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:default}.react-colorful__saturation{position:relative;flex-grow:1;border-color:transparent;border-bottom:12px solid #000;border-radius:8px 8px 0 0;background-image:linear-gradient(0deg,#000,transparent),linear-gradient(90deg,#fff,hsla(0,0%,100%,0))}.react-colorful__alpha-gradient,.react-colorful__pointer-fill{content:"";position:absolute;left:0;top:0;right:0;bottom:0;pointer-events:none;border-radius:inherit}.react-colorful__alpha-gradient,.react-colorful__saturation{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}.react-colorful__alpha,.react-colorful__hue{position:relative;height:24px}.react-colorful__hue{background:linear-gradient(90deg,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red)}.react-colorful__last-control{border-radius:0 0 8px 8px}.react-colorful__interactive{position:absolute;left:0;top:0;right:0;bottom:0;border-radius:inherit;outline:none;touch-action:none}.react-colorful__pointer{position:absolute;z-index:1;box-sizing:border-box;width:28px;height:28px;transform:translate(-50%,-50%);background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2)}.react-colorful__interactive:focus .react-colorful__pointer{transform:translate(-50%,-50%) scale(1.1)}.react-colorful__alpha,.react-colorful__alpha-pointer{background-color:#fff;background-image:url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill-opacity=".05"><path d="M8 0h8v8H8zM0 8h8v8H0z"/></svg>')}.react-colorful__saturation-pointer{z-index:3}.react-colorful__hue-pointer{z-index:2}`,W.set(l,c);var h=Oe();h&&c.setAttribute("nonce",h),l.head.appendChild(c)}},[])},Se=function(n){var l=n.className,c=n.colorModel,h=n.color,i=h===void 0?c.defaultColor:h,d=n.onChange,e=X(n,["className","colorModel","color","onChange"]),t=p.useRef(null);le(t);var r=oe(c,i,d),a=r[0],o=r[1],u=O(["react-colorful",l]);return v.createElement("div",M({},e,{ref:t,className:u}),v.createElement(te,{hsva:a,onChange:o}),v.createElement(re,{hue:a.h,onChange:o,className:"react-colorful__last-control"}))},je={defaultColor:"000",toHsva:xe,fromHsva:function(n){return Ee({h:n.h,s:n.s,v:n.v,a:1})},equal:$e},Re=function(n){return v.createElement(Se,M({},n,{colorModel:je}))},ze=function(n){var l=n.className,c=n.hsva,h=n.onChange,i={backgroundImage:"linear-gradient(90deg, "+z(Object.assign({},c,{a:0}))+", "+z(Object.assign({},c,{a:1}))+")"},d=O(["react-colorful__alpha",l]),e=x(100*c.a);return v.createElement("div",{className:d},v.createElement("div",{className:"react-colorful__alpha-gradient",style:i}),v.createElement(D,{onMove:function(t){h({a:t.left})},onKey:function(t){h({a:$(c.a+t.left)})},"aria-label":"Alpha","aria-valuetext":e+"%","aria-valuenow":e,"aria-valuemin":"0","aria-valuemax":"100"},v.createElement(V,{className:"react-colorful__alpha-pointer",left:c.a,color:z(c)})))},ue=function(n){var l=n.className,c=n.colorModel,h=n.color,i=h===void 0?c.defaultColor:h,d=n.onChange,e=X(n,["className","colorModel","color","onChange"]),t=p.useRef(null);le(t);var r=oe(c,i,d),a=r[0],o=r[1],u=O(["react-colorful",l]);return v.createElement("div",M({},e,{ref:t,className:u}),v.createElement(te,{hsva:a,onChange:o}),v.createElement(re,{hue:a.h,onChange:o}),v.createElement(ze,{hsva:a,onChange:o,className:"react-colorful__last-control"}))},Ie={defaultColor:"hsla(0, 0%, 0%, 1)",toHsva:ke,fromHsva:z,equal:ae},He=function(n){return v.createElement(ue,M({},n,{colorModel:Ie}))},qe={defaultColor:"rgba(0, 0, 0, 1)",toHsva:Me,fromHsva:function(n){var l=Z(n);return"rgba("+l.r+", "+l.g+", "+l.b+", "+l.a+")"},equal:ae},Pe=function(n){return v.createElement(ue,M({},n,{colorModel:qe}))},Le=E.div({position:"relative",maxWidth:250,'&[aria-readonly="true"]':{opacity:.5}}),Be=E(Y)({position:"absolute",zIndex:1,top:4,left:4,"[aria-readonly=true] &":{cursor:"not-allowed"}}),Te=E.div({width:200,margin:5,".react-colorful__saturation":{borderRadius:"4px 4px 0 0"},".react-colorful__hue":{boxShadow:"inset 0 0 0 1px rgb(0 0 0 / 5%)"},".react-colorful__last-control":{borderRadius:"0 0 4px 4px"}}),Ke=E(he)(({theme:n})=>({fontFamily:n.typography.fonts.base})),Xe=E.div({display:"grid",gridTemplateColumns:"repeat(9, 16px)",gap:6,padding:3,marginTop:5,width:200}),De=E.div(({theme:n,active:l})=>({width:16,height:16,boxShadow:l?`${n.appBorderColor} 0 0 0 1px inset, ${n.textMutedColor}50 0 0 0 4px`:`${n.appBorderColor} 0 0 0 1px inset`,borderRadius:n.appBorderRadius})),Ve=`url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill-opacity=".05"><path d="M8 0h8v8H8zM0 8h8v8H0z"/></svg>')`,A=({value:n,style:l,...c})=>{let h=`linear-gradient(${n}, ${n}), ${Ve}, linear-gradient(#fff, #fff)`;return v.createElement(De,{...c,style:{...l,backgroundImage:h}})},Ge=E(fe.Input)(({theme:n,readOnly:l})=>({width:"100%",paddingLeft:30,paddingRight:30,boxSizing:"border-box",fontFamily:n.typography.fonts.base})),Fe=E(de)(({theme:n})=>({position:"absolute",zIndex:1,top:6,right:7,width:20,height:20,padding:4,boxSizing:"border-box",cursor:"pointer",color:n.input.color})),ie=(n=>(n.RGB="rgb",n.HSL="hsl",n.HEX="hex",n))(ie||{}),j=Object.values(ie),We=/\(([0-9]+),\s*([0-9]+)%?,\s*([0-9]+)%?,?\s*([0-9.]+)?\)/,Ae=/^\s*rgba?\(([0-9]+),\s*([0-9]+),\s*([0-9]+),?\s*([0-9.]+)?\)\s*$/i,Ue=/^\s*hsla?\(([0-9]+),\s*([0-9]+)%,\s*([0-9]+)%,?\s*([0-9.]+)?\)\s*$/i,K=/^\s*#?([0-9a-f]{3}|[0-9a-f]{6})\s*$/i,Ye=/^\s*#?([0-9a-f]{3})\s*$/i,Je={hex:Re,rgb:Pe,hsl:He},R={hex:"transparent",rgb:"rgba(0, 0, 0, 0)",hsl:"hsla(0, 0%, 0%, 0)"},U=n=>{let l=n?.match(We);if(!l)return[0,0,0,1];let[,c,h,i,d=1]=l;return[c,h,i,d].map(Number)},C=n=>{if(!n)return;let l=!0;if(Ae.test(n)){let[e,t,r,a]=U(n),[o,u,s]=_.default.rgb.hsl([e,t,r])||[0,0,0];return{valid:l,value:n,keyword:_.default.rgb.keyword([e,t,r]),colorSpace:"rgb",rgb:n,hsl:`hsla(${o}, ${u}%, ${s}%, ${a})`,hex:`#${_.default.rgb.hex([e,t,r]).toLowerCase()}`}}if(Ue.test(n)){let[e,t,r,a]=U(n),[o,u,s]=_.default.hsl.rgb([e,t,r])||[0,0,0];return{valid:l,value:n,keyword:_.default.hsl.keyword([e,t,r]),colorSpace:"hsl",rgb:`rgba(${o}, ${u}, ${s}, ${a})`,hsl:n,hex:`#${_.default.hsl.hex([e,t,r]).toLowerCase()}`}}let c=n.replace("#",""),h=_.default.keyword.rgb(c)||_.default.hex.rgb(c),i=_.default.rgb.hsl(h),d=n;if(/[^#a-f0-9]/i.test(n)?d=c:K.test(n)&&(d=`#${c}`),d.startsWith("#"))l=K.test(d);else try{_.default.keyword.hex(d)}catch{l=!1}return{valid:l,value:d,keyword:_.default.rgb.keyword(h),colorSpace:"hex",rgb:`rgba(${h[0]}, ${h[1]}, ${h[2]}, 1)`,hsl:`hsla(${i[0]}, ${i[1]}%, ${i[2]}%, 1)`,hex:d}},Qe=(n,l,c)=>{if(!n||!l?.valid)return R[c];if(c!=="hex")return l?.[c]||R[c];if(!l.hex.startsWith("#"))try{return`#${_.default.keyword.hex(l.hex)}`}catch{return R.hex}let h=l.hex.match(Ye);if(!h)return K.test(l.hex)?l.hex:R.hex;let[i,d,e]=h[1].split("");return`#${i}${i}${d}${d}${e}${e}`},Ze=(n,l)=>{let[c,h]=p.useState(n||""),[i,d]=p.useState(()=>C(c)),[e,t]=p.useState(i?.colorSpace||"hex");p.useEffect(()=>{let u=n||"",s=C(u);h(u),d(s),t(s?.colorSpace||"hex")},[n]);let r=p.useMemo(()=>Qe(c,i,e).toLowerCase(),[c,i,e]),a=p.useCallback(u=>{let s=C(u),f=s?.value||u||"";h(f),f===""&&(d(void 0),l(void 0)),s&&(d(s),t(s.colorSpace),l(s.value))},[l]),o=p.useCallback(()=>{let u=j.indexOf(e)+1;u>=j.length&&(u=0),t(j[u]);let s=i?.[j[u]]||"";h(s),l(s)},[i,e,l]);return{value:c,realValue:r,updateValue:a,color:i,colorSpace:e,cycleColorSpace:o}},I=n=>n.replace(/\s*/,"").toLowerCase(),er=(n,l,c)=>{let[h,i]=p.useState(l?.valid?[l]:[]);p.useEffect(()=>{l===void 0&&i([])},[l]);let d=p.useMemo(()=>(n||[]).map(t=>typeof t=="string"?C(t):t.title?{...C(t.color),keyword:t.title}:C(t.color)).concat(h).filter(Boolean).slice(-27),[n,h]),e=p.useCallback(t=>{t?.valid&&(d.some(r=>I(r[c])===I(t[c]))||i(r=>r.concat(t)))},[c,d]);return{presets:d,addPreset:e}},rr=({name:n,value:l,onChange:c,onFocus:h,onBlur:i,presetColors:d,startOpen:e=!1,argType:t})=>{let r=p.useCallback(ge(c,200),[c]),{value:a,realValue:o,updateValue:u,color:s,colorSpace:f,cycleColorSpace:g}=Ze(l,r),{presets:b,addPreset:y}=er(d,s,f),m=Je[f],k=!!t?.table?.readonly;return v.createElement(Le,{"aria-readonly":k},v.createElement(Be,{startOpen:e,trigger:k?[null]:void 0,closeOnOutsideClick:!0,onVisibleChange:()=>y(s),tooltip:v.createElement(Te,null,v.createElement(m,{color:o==="transparent"?"#000000":o,onChange:u,onFocus:h,onBlur:i}),b.length>0&&v.createElement(Xe,null,b.map((w,q)=>v.createElement(Y,{key:`${w.value}-${q}`,hasChrome:!1,tooltip:v.createElement(Ke,{note:w.keyword||w.value})},v.createElement(A,{value:w[f],active:s&&I(w[f])===I(s[f]),onClick:()=>u(w.value)})))))},v.createElement(A,{value:o,style:{margin:4}})),v.createElement(Ge,{id:be(n),value:a,onChange:w=>u(w.target.value),onFocus:w=>w.target.select(),readOnly:k,placeholder:"Choose color..."}),a?v.createElement(Fe,{onClick:g}):null)},ir=rr;export{rr as ColorControl,ir as default};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{ar as e,as as a}from"./index-CaL3Qp7t.js";import{u as o}from"./index-B3QjF0Ed.js";import"./iframe-DOi4N7qI.js";import"../sb-preview/runtime.js";import"./index-BdcJ-iJ7.js";import"./index-D-8MO0q_.js";import"./index-DrFu-skq.js";const n="",p=""+new URL("docs---vsFbMi.png",import.meta.url).href,x=""+new URL("share-DGA-UcQf.png",import.meta.url).href,b=""+new URL("figma-plugin-CH2hELiO.png",import.meta.url).href,C=""+new URL("testing-cbzR9l9r.png",import.meta.url).href,u=""+new URL("accessibility-W_h2acOZ.png",import.meta.url).href,j=""+new URL("theming-D6WJLNoW.png",import.meta.url).href,f=""+new URL("addon-library-BWUCAmyN.png",import.meta.url).href,s=()=>{const t={path:"path",svg:"svg",...o()};return e.jsx(t.svg,{viewBox:"0 0 14 14",width:"8px",height:"14px",style:{marginLeft:"4px",display:"inline-block",shapeRendering:"inherit",verticalAlign:"middle",fill:"currentColor","path fill":"currentColor"},children:e.jsx(t.path,{d:"m11.1 7.35-5.5 5.5a.5.5 0 0 1-.7-.7L10.04 7 4.9 1.85a.5.5 0 1 1 .7-.7l5.5 5.5c.2.2.2.5 0 .7Z"})})};function r(t){const i={code:"code",h1:"h1",p:"p",...o(),...t.components};return e.jsxs(e.Fragment,{children:[e.jsx(a,{title:"Configure your project"}),`
|
|
1
|
+
import{ar as e,as as a}from"./index-SnjB5uV8.js";import{u as o}from"./index-RSFf30w1.js";import"./iframe-CJEL_4Nu.js";import"../sb-preview/runtime.js";import"./index-BcZLpTeD.js";import"./index-D-8MO0q_.js";import"./index-DrFu-skq.js";const n="",p=""+new URL("docs---vsFbMi.png",import.meta.url).href,x=""+new URL("share-DGA-UcQf.png",import.meta.url).href,b=""+new URL("figma-plugin-CH2hELiO.png",import.meta.url).href,C=""+new URL("testing-cbzR9l9r.png",import.meta.url).href,u=""+new URL("accessibility-W_h2acOZ.png",import.meta.url).href,j=""+new URL("theming-D6WJLNoW.png",import.meta.url).href,f=""+new URL("addon-library-BWUCAmyN.png",import.meta.url).href,s=()=>{const t={path:"path",svg:"svg",...o()};return e.jsx(t.svg,{viewBox:"0 0 14 14",width:"8px",height:"14px",style:{marginLeft:"4px",display:"inline-block",shapeRendering:"inherit",verticalAlign:"middle",fill:"currentColor","path fill":"currentColor"},children:e.jsx(t.path,{d:"m11.1 7.35-5.5 5.5a.5.5 0 0 1-.7-.7L10.04 7 4.9 1.85a.5.5 0 1 1 .7-.7l5.5 5.5c.2.2.2.5 0 .7Z"})})};function r(t){const i={code:"code",h1:"h1",p:"p",...o(),...t.components};return e.jsxs(e.Fragment,{children:[e.jsx(a,{title:"Configure your project"}),`
|
|
2
2
|
`,e.jsxs("div",{className:"sb-container",children:[e.jsxs("div",{className:"sb-section-title",children:[e.jsx(i.h1,{id:"configure-your-project",children:"Configure your project"}),e.jsx(i.p,{children:"Because Storybook works separately from your app, you'll need to configure it for your specific stack and setup. Below, explore guides for configuring Storybook with popular frameworks and tools. If you get stuck, learn how you can ask for help from our community."})]}),e.jsxs("div",{className:"sb-section",children:[e.jsxs("div",{className:"sb-section-item",children:[e.jsx("img",{src:g,alt:"A wall of logos representing different styling technologies"}),e.jsx("h4",{className:"sb-section-item-heading",children:"Add styling and CSS"}),e.jsx("p",{className:"sb-section-item-paragraph",children:"Like with web applications, there are many ways to include CSS within Storybook. Learn more about setting up styling within Storybook."}),e.jsxs("a",{href:"https://storybook.js.org/docs/web-components/configure/styling-and-css",target:"_blank",children:["Learn more",e.jsx(s,{})]})]}),e.jsxs("div",{className:"sb-section-item",children:[e.jsx("img",{src:h,alt:"An abstraction representing the composition of data for a component"}),e.jsx("h4",{className:"sb-section-item-heading",children:"Provide context and mocking"}),e.jsx("p",{className:"sb-section-item-paragraph",children:"Often when a story doesn't render, it's because your component is expecting a specific environment or context (like a theme provider) to be available."}),e.jsxs("a",{href:"https://storybook.js.org/docs/web-components/writing-stories/decorators#context-for-mocking",target:"_blank",children:["Learn more",e.jsx(s,{})]})]}),e.jsxs("div",{className:"sb-section-item",children:[e.jsx("img",{src:m,alt:"A representation of typography and image assets"}),e.jsxs("div",{children:[e.jsx("h4",{className:"sb-section-item-heading",children:"Load assets and resources"}),e.jsxs("p",{className:"sb-section-item-paragraph",children:[`To link static files (like fonts) to your projects and stories, use the
|
|
3
3
|
`,e.jsx(i.code,{children:"staticDirs"}),` configuration option to specify folders to load when
|
|
4
4
|
starting Storybook.`]}),e.jsxs("a",{href:"https://storybook.js.org/docs/web-components/configure/images-and-assets",target:"_blank",children:["Learn more",e.jsx(s,{})]})]})]})]})]}),`
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["./index-
|
|
2
|
-
import{_ as
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["./index-D5fBh-7N.js","./index-RSFf30w1.js","./index-SnjB5uV8.js","./iframe-CJEL_4Nu.js","./index-BcZLpTeD.js","./index-D-8MO0q_.js","./index-DrFu-skq.js"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{_ as d}from"./iframe-CJEL_4Nu.js";import{am as h,ag as s,an as E,ao as v,ap as R,af as n,aq as w}from"./index-SnjB5uV8.js";import"../sb-preview/runtime.js";import"./index-BcZLpTeD.js";import"./index-D-8MO0q_.js";import"./index-DrFu-skq.js";var l,u=h;l=u.createRoot,u.hydrateRoot;var a=new Map;function _(){return globalThis.IS_REACT_ACT_ENVIRONMENT}var f=({callback:e,children:t})=>{let r=s.useRef();return s.useLayoutEffect(()=>{r.current!==e&&(r.current=e,e())},[e]),t};typeof Promise.withResolvers>"u"&&(Promise.withResolvers=()=>{let e=null,t=null;return{promise:new Promise((r,o)=>{e=r,t=o}),resolve:e,reject:t}});var g=async(e,t,r)=>{let o=await y(t,r);if(_()){o.render(e);return}let{promise:i,resolve:c}=Promise.withResolvers();return o.render(s.createElement(f,{callback:c},e)),i},x=(e,t)=>{let r=a.get(e);r&&(r.unmount(),a.delete(e))},y=async(e,t)=>{let r=a.get(e);return r||(r=l(e,t),a.set(e,r)),r},D={code:E,a:v,...R},C=class extends s.Component{constructor(){super(...arguments),this.state={hasError:!1}}static getDerivedStateFromError(){return{hasError:!0}}componentDidCatch(e){let{showException:t}=this.props;t(e)}render(){let{hasError:e}=this.state,{children:t}=this.props;return e?null:n.createElement(n.Fragment,null,t)}},O=class{constructor(){this.render=async(e,t,r)=>{let o={...D,...t?.components},i=w;return new Promise((c,p)=>{d(async()=>{const{MDXProvider:m}=await import("./index-D5fBh-7N.js");return{MDXProvider:m}},__vite__mapDeps([0,1,2,3,4,5,6]),import.meta.url).then(({MDXProvider:m})=>g(n.createElement(C,{showException:p,key:Math.random()},n.createElement(m,{components:o},n.createElement(i,{context:e,docsParameter:t}))),r)).then(()=>c())})},this.unmount=e=>{x(e)}}};export{O as DocsRenderer,D as defaultComponents};
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import{w as c,e as t,u as v}from"./index-CxRwF5Or.js";import{m as y,c as x}from"./custom-element-uuAtIYWS.js";function w(i){return new Promise(a=>setTimeout(a,i))}function f(i){const{title:a,body:e}=i;return`
|
|
2
|
+
<fieldset>
|
|
3
|
+
<legend>${a}</legend>
|
|
4
|
+
${e}
|
|
5
|
+
</fieldset>
|
|
6
|
+
`}const T={title:"attributes",render:f},r={args:{title:"cloneAs(el,newTag)",body:`
|
|
7
|
+
<p><code>cloneAs()</code> used for conversion of <code>attribute</code> to <code>xsl:param</code></p>
|
|
8
|
+
<attribute data-testid="t1" >default_P1 </attribute>
|
|
9
|
+
<attribute data-testid="t2" select="'always_p2'" ></attribute>
|
|
10
|
+
<attribute data-testid="t3" ></attribute>
|
|
11
|
+
`},play:async({canvasElement:i})=>{const a=c(i),e=async s=>{const o=await a.findByTestId(s),n=x(o,"xsl:param");for(let p of o.attributes)await t(p.value).toEqual(n.getAttribute(p.name));await t(n.textContent).toEqual(o.textContent)};await e("t1"),await e("t2"),await e("t3")}},u={args:{title:"mix(to,from)",body:`
|
|
12
|
+
<p><code>mix(to,from)</code> used for <code>attribute</code> collections</p>
|
|
13
|
+
`},play:async()=>{await t(y({},{a:1,b:"2"})).toEqual({a:1,b:"2"})}},d={args:{title:"Attributes definition",body:`
|
|
14
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also is used by IDE and validation.</p>
|
|
15
|
+
<custom-element tag="dce-link" >
|
|
16
|
+
<template>
|
|
17
|
+
<attribute name="p1">default_P1</attribute>
|
|
18
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
19
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
20
|
+
p1: <code data-testid="p1">{$p1}</code> <br/>
|
|
21
|
+
p2: <code data-testid="p2">{$p2}</code> <br/>
|
|
22
|
+
p3: <code data-testid="p3">{$p3}</code>
|
|
23
|
+
</template>
|
|
24
|
+
</custom-element>
|
|
25
|
+
<dce-link id="dce1"></dce-link>
|
|
26
|
+
`},play:async({canvasElement:i})=>{d.args.title;const a=c(i);t(await await a.findByTestId("p1")).toHaveTextContent("default_P1"),t(await await a.findByTestId("p2")).toHaveTextContent("always_p2"),t(await await a.findByTestId("p3")).toHaveTextContent("def_P3")}},l={args:{title:"Attributes runtime change",body:`
|
|
27
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also be used by IDE and validation.</p>
|
|
28
|
+
<custom-element tag="dce-link2" >
|
|
29
|
+
<template>
|
|
30
|
+
<attribute name="p1">default_P1 </attribute>
|
|
31
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
32
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
33
|
+
p1: <code data-testid="t1">{$p1}</code> <br/>
|
|
34
|
+
p2: <code data-testid="t2">{$p2}</code> <br/>
|
|
35
|
+
p3: <code data-testid="t3">{$p3}</code>
|
|
36
|
+
</template>
|
|
37
|
+
</custom-element>
|
|
38
|
+
<section>
|
|
39
|
+
<dce-link2 id="dce2" p1="123" p2="override ignored as select is defined"></dce-link2> <br>
|
|
40
|
+
<div><input id="i1" value="P1"> <button onclick="dce2.setAttribute('p1',i1.value)"> set p1</button> </div>
|
|
41
|
+
<div><input id="i2" value="P2"> <button onclick="dce2.setAttribute('p2',i2.value)"> set p2</button> </div>
|
|
42
|
+
<div><input id="i3" value="P3"> <button onclick="dce2.setAttribute('p3',i3.value)"> set p3</button> </div>
|
|
43
|
+
</section>
|
|
44
|
+
`},play:async({canvasElement:i})=>{const a=c(i),e=async o=>await a.findByTestId(o);await w(20),t(await e("t1")).toHaveTextContent("123"),t(await e("t2")).toHaveTextContent("always_p2"),t(await e("t3")).toHaveTextContent("def_P3");const s=window.dce2;s.setAttribute("P1",i1.value),await t(await a.findByText("P1")).toBeInTheDocument(),t(await e("t1")).toHaveTextContent("P1"),s.setAttribute("p2",i2.value),t(a.getByTestId("t2")).toHaveTextContent("always_p2"),s.setAttribute("p3",i3.value),await t(await a.findByText("P3")).toBeInTheDocument(),t(a.getByTestId("t3")).toHaveTextContent("P3")}},b={args:{title:"Instance Attributes",body:`
|
|
45
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also is used by IDE and validation.</p>
|
|
46
|
+
<custom-element tag="dce-link3" >
|
|
47
|
+
<template>
|
|
48
|
+
<attribute name="p1">default_P1 </attribute>
|
|
49
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
50
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
51
|
+
p1: <code data-testid="p1">{$p1}</code> <br/>
|
|
52
|
+
p2: <code data-testid="p2">{$p2}</code> <br/>
|
|
53
|
+
p3: <code data-testid="p3">{$p3}</code>
|
|
54
|
+
</template>
|
|
55
|
+
</custom-element>
|
|
56
|
+
<dce-link3 id="dce3" p1="123" p3="qwe"></dce-link3> |
|
|
57
|
+
`},play:async({canvasElement:i})=>{d.args.title;const a=c(i),e=async s=>(await a.findByTestId(s)).textContent.trim();await w(20),t(await e("p1")).toEqual("123"),t(await e("p2")).toEqual("always_p2"),t(await e("p3")).toEqual("qwe")}},m={args:{title:"Instance Attributes",body:`
|
|
58
|
+
<p>Attributes with value(p2) or <code>select</code>(p3) should be propagated to DCE</p>
|
|
59
|
+
<p>p1 attribute is not propagated as does not have the value.</p>
|
|
60
|
+
<custom-element tag="sample-el">
|
|
61
|
+
<template>
|
|
62
|
+
<attribute name="data-testid"></attribute>
|
|
63
|
+
<attribute name="p1"></attribute>
|
|
64
|
+
<attribute name="p2">DEFAULT VALUE</attribute>
|
|
65
|
+
<attribute name="p3" select=" //from-input ?? 'abc' "></attribute>
|
|
66
|
+
<input slice="from-input" slice-event="input"/><br/>
|
|
67
|
+
p1:<code data-testid="{$data-testid}-p1" >{ $p1 }</code><br/>
|
|
68
|
+
p2:<code data-testid="{$data-testid}-p2" >{ $p2 }</code><br/>
|
|
69
|
+
p2:<code data-testid="{$data-testid}-p3" >{ $p3 }</code><br/>
|
|
70
|
+
//from-input: {//from-input} <hr/>
|
|
71
|
+
</template>
|
|
72
|
+
</custom-element>
|
|
73
|
+
|
|
74
|
+
<sample-el data-testid="t1" value="123" ></sample-el>
|
|
75
|
+
<sample-el data-testid="t2" p1="P1" p2="123" p3="P3" ></sample-el>
|
|
76
|
+
<sample-el data-testid="t3" ></sample-el>
|
|
77
|
+
`},play:async({canvasElement:i})=>{const a=c(i),e=async p=>(await a.findByTestId(p)).textContent?.trim();await w(20),await t(await e("t1-p1")).toEqual(""),await t(await e("t1-p2")).toEqual("DEFAULT VALUE"),await t(await e("t1-p3")).toEqual("abc");const s=await a.findByTestId("t1");await t(s).toHaveAttribute("value","123"),await t(s).toHaveAttribute("p2","DEFAULT VALUE"),await t(s).toHaveAttribute("p3","abc"),await t(s).not.toHaveAttribute("p1"),await t(await e("t2-p1")).toEqual("P1"),await t(await e("t2-p2")).toEqual("123"),await t(await e("t2-p3")).toEqual("abc");const o=await a.findByTestId("t2");await t(o).toHaveAttribute("p1","P1"),await t(o).toHaveAttribute("p2","123"),await t(o).toHaveAttribute("p3","abc"),await t(await e("t3-p1")).toEqual(""),await t(await e("t3-p2")).toEqual("DEFAULT VALUE"),await t(await e("t3-p3")).toEqual("abc");const n=await a.findByTestId("t3");await t(s).not.toHaveAttribute("p1"),await t(n).toHaveAttribute("p2","DEFAULT VALUE"),await t(n).toHaveAttribute("p3","abc"),n.querySelector("input")?.focus(),await v.keyboard("DCE"),await t(n).toHaveAttribute("p3","DCE")}};r.parameters={...r.parameters,docs:{...r.parameters?.docs,source:{originalSource:`{
|
|
78
|
+
args: {
|
|
79
|
+
title: 'cloneAs(el,newTag)',
|
|
80
|
+
body: \`
|
|
81
|
+
<p><code>cloneAs()</code> used for conversion of <code>attribute</code> to <code>xsl:param</code></p>
|
|
82
|
+
<attribute data-testid="t1" >default_P1 </attribute>
|
|
83
|
+
<attribute data-testid="t2" select="'always_p2'" ></attribute>
|
|
84
|
+
<attribute data-testid="t3" ></attribute>
|
|
85
|
+
\`
|
|
86
|
+
},
|
|
87
|
+
play: async ({
|
|
88
|
+
canvasElement
|
|
89
|
+
}) => {
|
|
90
|
+
const canvas = within(canvasElement);
|
|
91
|
+
const cmp = async (tid: string) => {
|
|
92
|
+
const t1 = await canvas.findByTestId(tid);
|
|
93
|
+
const c1 = cloneAs(t1, 'xsl:param');
|
|
94
|
+
for (let a of t1.attributes) {
|
|
95
|
+
await expect(a.value).toEqual(c1.getAttribute(a.name));
|
|
96
|
+
}
|
|
97
|
+
await expect(c1.textContent).toEqual(t1.textContent);
|
|
98
|
+
};
|
|
99
|
+
await cmp('t1');
|
|
100
|
+
await cmp('t2');
|
|
101
|
+
await cmp('t3');
|
|
102
|
+
}
|
|
103
|
+
}`,...r.parameters?.docs?.source}}};u.parameters={...u.parameters,docs:{...u.parameters?.docs,source:{originalSource:`{
|
|
104
|
+
args: {
|
|
105
|
+
title: 'mix(to,from)',
|
|
106
|
+
body: \`
|
|
107
|
+
<p><code>mix(to,from)</code> used for <code>attribute</code> collections</p>
|
|
108
|
+
\`
|
|
109
|
+
},
|
|
110
|
+
play: async () => {
|
|
111
|
+
await expect(mix({}, {
|
|
112
|
+
a: 1,
|
|
113
|
+
b: '2'
|
|
114
|
+
})).toEqual({
|
|
115
|
+
a: 1,
|
|
116
|
+
b: '2'
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
}`,...u.parameters?.docs?.source}}};d.parameters={...d.parameters,docs:{...d.parameters?.docs,source:{originalSource:`{
|
|
120
|
+
args: {
|
|
121
|
+
title: 'Attributes definition',
|
|
122
|
+
body: \`
|
|
123
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also is used by IDE and validation.</p>
|
|
124
|
+
<custom-element tag="dce-link" >
|
|
125
|
+
<template>
|
|
126
|
+
<attribute name="p1">default_P1</attribute>
|
|
127
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
128
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
129
|
+
p1: <code data-testid="p1">{$p1}</code> <br/>
|
|
130
|
+
p2: <code data-testid="p2">{$p2}</code> <br/>
|
|
131
|
+
p3: <code data-testid="p3">{$p3}</code>
|
|
132
|
+
</template>
|
|
133
|
+
</custom-element>
|
|
134
|
+
<dce-link id="dce1"></dce-link>
|
|
135
|
+
\`
|
|
136
|
+
},
|
|
137
|
+
play: async ({
|
|
138
|
+
canvasElement
|
|
139
|
+
}) => {
|
|
140
|
+
const titleText = AttributeDefaults.args!.title as string;
|
|
141
|
+
const canvas = within(canvasElement),
|
|
142
|
+
code = async id => (await canvas.findByTestId(id)).textContent.trim();
|
|
143
|
+
expect(await await canvas.findByTestId('p1')).toHaveTextContent('default_P1');
|
|
144
|
+
expect(await await canvas.findByTestId('p2')).toHaveTextContent('always_p2');
|
|
145
|
+
expect(await await canvas.findByTestId('p3')).toHaveTextContent('def_P3');
|
|
146
|
+
}
|
|
147
|
+
}`,...d.parameters?.docs?.source}}};l.parameters={...l.parameters,docs:{...l.parameters?.docs,source:{originalSource:`{
|
|
148
|
+
args: {
|
|
149
|
+
title: 'Attributes runtime change',
|
|
150
|
+
body: \`
|
|
151
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also be used by IDE and validation.</p>
|
|
152
|
+
<custom-element tag="dce-link2" >
|
|
153
|
+
<template>
|
|
154
|
+
<attribute name="p1">default_P1 </attribute>
|
|
155
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
156
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
157
|
+
p1: <code data-testid="t1">{$p1}</code> <br/>
|
|
158
|
+
p2: <code data-testid="t2">{$p2}</code> <br/>
|
|
159
|
+
p3: <code data-testid="t3">{$p3}</code>
|
|
160
|
+
</template>
|
|
161
|
+
</custom-element>
|
|
162
|
+
<section>
|
|
163
|
+
<dce-link2 id="dce2" p1="123" p2="override ignored as select is defined"></dce-link2> <br>
|
|
164
|
+
<div><input id="i1" value="P1"> <button onclick="dce2.setAttribute('p1',i1.value)"> set p1</button> </div>
|
|
165
|
+
<div><input id="i2" value="P2"> <button onclick="dce2.setAttribute('p2',i2.value)"> set p2</button> </div>
|
|
166
|
+
<div><input id="i3" value="P3"> <button onclick="dce2.setAttribute('p3',i3.value)"> set p3</button> </div>
|
|
167
|
+
</section>
|
|
168
|
+
\`
|
|
169
|
+
},
|
|
170
|
+
play: async ({
|
|
171
|
+
canvasElement
|
|
172
|
+
}) => {
|
|
173
|
+
const canvas = within(canvasElement),
|
|
174
|
+
code = async (id: string) => await canvas.findByTestId(id);
|
|
175
|
+
await sleep(20);
|
|
176
|
+
expect(await code('t1')).toHaveTextContent('123');
|
|
177
|
+
expect(await code('t2')).toHaveTextContent('always_p2'); // no overrides due to value is hardcoded
|
|
178
|
+
expect(await code('t3')).toHaveTextContent('def_P3');
|
|
179
|
+
const dce2 = window.dce2;
|
|
180
|
+
dce2.setAttribute('P1', i1.value);
|
|
181
|
+
await expect(await canvas.findByText('P1')).toBeInTheDocument();
|
|
182
|
+
expect(await code('t1')).toHaveTextContent('P1'); // 4. set p1 in runtime'
|
|
183
|
+
|
|
184
|
+
dce2.setAttribute('p2', i2.value);
|
|
185
|
+
// await expect(await canvas.findByText('P2')).toBeInTheDocument();
|
|
186
|
+
expect(canvas.getByTestId('t2')).toHaveTextContent('always_p2'); // can not set p2 in runtime
|
|
187
|
+
|
|
188
|
+
dce2.setAttribute('p3', i3.value);
|
|
189
|
+
await expect(await canvas.findByText('P3')).toBeInTheDocument();
|
|
190
|
+
expect(canvas.getByTestId('t3')).toHaveTextContent('P3'); // set p3 in runtime
|
|
191
|
+
}
|
|
192
|
+
}`,...l.parameters?.docs?.source}}};b.parameters={...b.parameters,docs:{...b.parameters?.docs,source:{originalSource:`{
|
|
193
|
+
args: {
|
|
194
|
+
title: 'Instance Attributes',
|
|
195
|
+
body: \`
|
|
196
|
+
<p>Params needed to declare DCE attributes and track the attributes changes. It also is used by IDE and validation.</p>
|
|
197
|
+
<custom-element tag="dce-link3" >
|
|
198
|
+
<template>
|
|
199
|
+
<attribute name="p1">default_P1 </attribute>
|
|
200
|
+
<attribute name="p2" select="'always_p2'" ></attribute>
|
|
201
|
+
<attribute name="p3" select="//p3 ?? 'def_P3' "></attribute>
|
|
202
|
+
p1: <code data-testid="p1">{$p1}</code> <br/>
|
|
203
|
+
p2: <code data-testid="p2">{$p2}</code> <br/>
|
|
204
|
+
p3: <code data-testid="p3">{$p3}</code>
|
|
205
|
+
</template>
|
|
206
|
+
</custom-element>
|
|
207
|
+
<dce-link3 id="dce3" p1="123" p3="qwe"></dce-link3> |
|
|
208
|
+
\`
|
|
209
|
+
},
|
|
210
|
+
play: async ({
|
|
211
|
+
canvasElement
|
|
212
|
+
}) => {
|
|
213
|
+
const titleText = AttributeDefaults.args!.title as string;
|
|
214
|
+
const canvas = within(canvasElement),
|
|
215
|
+
code = async id => (await canvas.findByTestId(id)).textContent.trim();
|
|
216
|
+
await sleep(20);
|
|
217
|
+
expect(await code('p1')).toEqual('123');
|
|
218
|
+
expect(await code('p2')).toEqual('always_p2');
|
|
219
|
+
expect(await code('p3')).toEqual('qwe');
|
|
220
|
+
}
|
|
221
|
+
}`,...b.parameters?.docs?.source}}};m.parameters={...m.parameters,docs:{...m.parameters?.docs,source:{originalSource:`{
|
|
222
|
+
args: {
|
|
223
|
+
title: 'Instance Attributes',
|
|
224
|
+
body: \`
|
|
225
|
+
<p>Attributes with value(p2) or <code>select</code>(p3) should be propagated to DCE</p>
|
|
226
|
+
<p>p1 attribute is not propagated as does not have the value.</p>
|
|
227
|
+
<custom-element tag="sample-el">
|
|
228
|
+
<template>
|
|
229
|
+
<attribute name="data-testid"></attribute>
|
|
230
|
+
<attribute name="p1"></attribute>
|
|
231
|
+
<attribute name="p2">DEFAULT VALUE</attribute>
|
|
232
|
+
<attribute name="p3" select=" //from-input ?? 'abc' "></attribute>
|
|
233
|
+
<input slice="from-input" slice-event="input"/><br/>
|
|
234
|
+
p1:<code data-testid="{$data-testid}-p1" >{ $p1 }</code><br/>
|
|
235
|
+
p2:<code data-testid="{$data-testid}-p2" >{ $p2 }</code><br/>
|
|
236
|
+
p2:<code data-testid="{$data-testid}-p3" >{ $p3 }</code><br/>
|
|
237
|
+
//from-input: {//from-input} <hr/>
|
|
238
|
+
</template>
|
|
239
|
+
</custom-element>
|
|
240
|
+
|
|
241
|
+
<sample-el data-testid="t1" value="123" ></sample-el>
|
|
242
|
+
<sample-el data-testid="t2" p1="P1" p2="123" p3="P3" ></sample-el>
|
|
243
|
+
<sample-el data-testid="t3" ></sample-el>
|
|
244
|
+
\`
|
|
245
|
+
},
|
|
246
|
+
play: async ({
|
|
247
|
+
canvasElement
|
|
248
|
+
}) => {
|
|
249
|
+
const canvas = within(canvasElement),
|
|
250
|
+
code = async (id: string) => (await canvas.findByTestId(id)).textContent?.trim();
|
|
251
|
+
await sleep(20);
|
|
252
|
+
await expect(await code('t1-p1')).toEqual('');
|
|
253
|
+
await expect(await code('t1-p2')).toEqual('DEFAULT VALUE');
|
|
254
|
+
await expect(await code('t1-p3')).toEqual('abc');
|
|
255
|
+
const t1 = await canvas.findByTestId('t1');
|
|
256
|
+
await expect(t1).toHaveAttribute('value', '123');
|
|
257
|
+
await expect(t1).toHaveAttribute('p2', 'DEFAULT VALUE');
|
|
258
|
+
await expect(t1).toHaveAttribute('p3', 'abc');
|
|
259
|
+
await expect(t1).not.toHaveAttribute('p1');
|
|
260
|
+
await expect(await code('t2-p1')).toEqual('P1');
|
|
261
|
+
await expect(await code('t2-p2')).toEqual('123');
|
|
262
|
+
await expect(await code('t2-p3')).toEqual('abc');
|
|
263
|
+
const t2 = await canvas.findByTestId('t2');
|
|
264
|
+
await expect(t2).toHaveAttribute('p1', 'P1');
|
|
265
|
+
await expect(t2).toHaveAttribute('p2', '123');
|
|
266
|
+
await expect(t2).toHaveAttribute('p3', 'abc');
|
|
267
|
+
await expect(await code('t3-p1')).toEqual('');
|
|
268
|
+
await expect(await code('t3-p2')).toEqual('DEFAULT VALUE');
|
|
269
|
+
await expect(await code('t3-p3')).toEqual('abc');
|
|
270
|
+
const t3 = await canvas.findByTestId('t3');
|
|
271
|
+
await expect(t1).not.toHaveAttribute('p1');
|
|
272
|
+
await expect(t3).toHaveAttribute('p2', 'DEFAULT VALUE');
|
|
273
|
+
await expect(t3).toHaveAttribute('p3', 'abc');
|
|
274
|
+
t3.querySelector('input')?.focus();
|
|
275
|
+
await userEvent.keyboard('DCE');
|
|
276
|
+
await expect(t3).toHaveAttribute('p3', 'DCE');
|
|
277
|
+
}
|
|
278
|
+
}`,...m.parameters?.docs?.source}}};const g=["CloneAs","Mix","AttributeDefaults","AttributesRuntimeChange","InstanceAttributes","AttributesPropagationUp"];export{d as AttributeDefaults,m as AttributesPropagationUp,l as AttributesRuntimeChange,r as CloneAs,b as InstanceAttributes,u as Mix,g as __namedExportsOrder,T as default};
|
package/storybook-static/assets/{css.test.stories-pgbBc17d.js → css.test.stories-Cp_g2hE1.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{w as i,e as t}from"./index-
|
|
1
|
+
import{w as i,e as t}from"./index-CxRwF5Or.js";import"./custom-element-uuAtIYWS.js";const g={title:"",tag:"",style:"",slot:"",payload:""};function p(n){const{title:e,tag:o,style:s,slot:a,payload:l}={...g,...n};return`
|
|
2
2
|
<fieldset>
|
|
3
3
|
<legend>${e}</legend>
|
|
4
4
|
<custom-element ${o?`tag="${o}"`:""} >
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
const G="http://www.w3.org/1999/XSL/Transform",k="http://www.w3.org/1999/xhtml",fe="http://exslt.org/common",h=(e,l)=>e.getAttribute?.(l),ee=e=>e.nodeType===3,xe=e=>typeof e=="string",be=e=>e&&typeof e.nodeType=="number",$=(e,l)=>(e.ownerDocument||e).createTextNode(l),ie=e=>{for(;e.firstChild;)e.firstChild.remove();return e},Z=e=>(e.getAttributeNames().map(l=>e.removeAttribute(l)),ie(e)),oe=e=>(e?.setAttribute("xmlns:xsl",G),e),re=e=>(e?.setAttribute("xmlns:xhtml",k),oe(e)),ce=e=>/^[_a-zA-Z][-_:a-zA-Z0-9]*$/.test(e),te=(e,l)=>(Object.keys(l).map(t=>e[t]=l[t]),e),S=(e,l="",t=document)=>{const s=i=>(r=>(l&&r.append($(t.ownerDocument||t,l)),r))((t.ownerDocument||t).createElement(i));if(ce(e))return s(e);const n=s("dce-object");return n.setAttribute("dce-object-name",e),n},se=(e,l)=>{const t=e.ownerDocument.createElementNS(e.namespaceURI,l);for(let s of e.attributes)t.setAttribute(s.name,s.value);for(let s of e.childNodes)t.append(s.cloneNode(!0));return t};function X(e){return new DOMParser().parseFromString(e,"application/xml")}function I(e){return new XMLSerializer().serializeToString(e)}function O(e,l,t,s){const n=x=>e.ownerDocument.createElement(x),r=((x,f,v)=>(f.append(v=n(x)),v))(l,e);return[...t].forEach(x=>r.append(s(x))),r}function ye(e){return e.slot||(e.setAttribute||(e=S("span",e.textContent.replaceAll(`
|
|
2
|
+
`,""))),e.setAttribute("slot","")),e}function Y(e,l){e.getAttributeNames().forEach(t=>l.includes(t)||e.removeAttribute(t))}const le=e=>[...e].filter(l=>!(l.nodeType===3&&l.data.trim()===""));function z(e,l,t){const s=typeof e;if(s==="string")return S(l,e,t);if(s==="number")return S(l,""+e,t);if(e instanceof Array){const i=S("array","",t);return e.map(r=>i.append(z(r,l,t))),i}if(e instanceof FormData){const i=S("form-data","",t);for(const r of e)i.append(z(r[1],r[0],t));return i}const n=S(l,"",t);for(let i in e)be(e[i])||typeof e[i]=="function"||e[i]instanceof Window||(typeof e[i]!="object"&&ce(i)?n.setAttribute(i,e[i]):n.append(z(e[i],i,t)));return n}function ne(e){if(D(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=f=>$(t,f),x=[];if([...n].forEach(f=>{f.index>i&&x.push(r(f.input.substring(i,f.index)));const v=e.querySelector("value-of").cloneNode();v.setAttribute("select",f[1]),x.push(v),i=f.index+f[0].length}),i<s.length&&x.push(r(s.substring(i,s.length))),x.length){for(let f of x)l.insertBefore(f,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 ge(e,l="xsl:stylesheet"){const t=[],s={},n={};if(e.tagName===l||e.documentElement?.tagName===l)return ne(te(e,{declaredAttributes:t,hardcodedAttributes:s,exposedAttributes:n}));const i=X(`<xsl:stylesheet version="1.0" xmlns:xsl="${G}" xmlns:xhtml="${k}" xmlns:exsl="${fe}" exclude-result-prefixes="exsl" >
|
|
3
|
+
<xsl:output method="xml"/>
|
|
4
|
+
<xsl:template match="/"><dce-root xmlns="${k}"><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
|
+
<xsl:copy>
|
|
39
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
40
|
+
</xsl:copy>
|
|
41
|
+
</xsl:template>
|
|
42
|
+
<xsl:template mode="sanitize" match="xhtml:*">
|
|
43
|
+
<xsl:element name="{local-name()}">
|
|
44
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
45
|
+
</xsl:element>
|
|
46
|
+
</xsl:template>
|
|
47
|
+
<xsl:template mode="sanitize" match="xhtml:input">
|
|
48
|
+
<xsl:element name="{local-name()}">
|
|
49
|
+
<xsl:apply-templates mode="sanitize" select="*[not(name()='slice')]|@*|text()"/>
|
|
50
|
+
</xsl:element>
|
|
51
|
+
<xsl:for-each select="slice">
|
|
52
|
+
<xsl:copy>
|
|
53
|
+
<xsl:attribute name="for" >^</xsl:attribute>
|
|
54
|
+
<xsl:apply-templates mode="sanitize" select="*|@*|text()"/>
|
|
55
|
+
</xsl:copy>
|
|
56
|
+
</xsl:for-each>
|
|
57
|
+
</xsl:template>
|
|
58
|
+
</xsl:stylesheet>`),r=new XSLTProcessor,x=(a=>{D(a,"custom-element",y=>{y.firstElementChild.localName==="template"&&([...y.firstElementChild.content.childNodes].forEach(g=>y.append(g)),y.firstElementChild.remove())}),D(a,"script",y=>y.remove());const c=a.content??a.firstElementChild?.content??a.body??a;Ce.forEach(y=>D(c,y,g=>Le(g,c)));const A=a.firstElementChild?.content||a.content,N=y=>{const g=X("<xhtml/>"),U=g.importNode(y,!0);return g.replaceChild(U,g.documentElement),re(U)};if(A){const y=S("div");return[...A.childNodes].map(g=>y.append(g.cloneNode(!0))),N(y)}return N(a.documentElement||a.body||a)})(e),f=X(`<xsl:stylesheet version="1.0"
|
|
59
|
+
xmlns:xsl="${G}"
|
|
60
|
+
xmlns:xhtml="${k}"
|
|
61
|
+
xmlns:dce="urn:schemas-epa-wg:dce"
|
|
62
|
+
xmlns:exsl="http://exslt.org/common"
|
|
63
|
+
exclude-result-prefixes="exsl"
|
|
64
|
+
>
|
|
65
|
+
<xsl:template match="ignore">
|
|
66
|
+
<xsl:choose>
|
|
67
|
+
<xsl:when test="//attr">{//attr}</xsl:when>
|
|
68
|
+
<xsl:otherwise>{def}</xsl:otherwise>
|
|
69
|
+
</xsl:choose><xsl:value-of select="."></xsl:value-of></xsl:template>
|
|
70
|
+
<xsl:template mode="payload" match="attributes"></xsl:template>
|
|
71
|
+
<xsl:template match="/">
|
|
72
|
+
<xsl:apply-templates mode="payload" select="/datadom/attributes"/>
|
|
73
|
+
</xsl:template>
|
|
74
|
+
<xsl:template name="slot" >
|
|
75
|
+
<xsl:param name="slotname" />
|
|
76
|
+
<xsl:param name="defaultvalue" />
|
|
77
|
+
<xsl:choose>
|
|
78
|
+
<xsl:when test="//payload/*[@slot=$slotname]">
|
|
79
|
+
<xsl:copy-of select="//payload/*[@slot=$slotname]"/>
|
|
80
|
+
</xsl:when>
|
|
81
|
+
<xsl:otherwise>
|
|
82
|
+
<xsl:copy-of select="$defaultvalue"/>
|
|
83
|
+
</xsl:otherwise>
|
|
84
|
+
</xsl:choose>
|
|
85
|
+
</xsl:template>
|
|
86
|
+
<xsl:variable name="js-injected-body">
|
|
87
|
+
<xsl:call-template name="slot" >
|
|
88
|
+
<xsl:with-param name="slotname" select="''"/>
|
|
89
|
+
<xsl:with-param name="defaultvalue"/>
|
|
90
|
+
</xsl:call-template>
|
|
91
|
+
</xsl:variable>
|
|
92
|
+
</xsl:stylesheet>`);r.importStylesheet(i);const v=r.transformToFragment(x,document),d=(a,c)=>a.querySelector(c),w=d(f,'template[mode="payload"]');if(!v)return console.error("transformation error",{xml:x.outerHTML,xsl:I(i)});if(v.firstElementChild.localName!=="dce-root"){const a=v.ownerDocument.createElement("dce-root");[...v.childNodes].forEach(c=>a.append(c)),v.append(a)}[...v.querySelectorAll("dce-root>attribute")].forEach(a=>{Y(a,"namespace,name,select");const c=se(a,"xsl:param"),A=h(a,"name");if(t.push(A),a.childNodes.length&&(s[A]=a.textContent),w.append(c),a.hasAttribute("select")){n[A]=h(a,"select"),Y(c,"select,name");let N=h(a,"select").split("??"),y;if(N?.length>1){c.removeAttribute("select");const g=d(f,'template[match="ignore"]>choose').cloneNode(!0);Z(g.firstElementChild).append($(g,"{"+N[0]+"}")),Z(g.lastElementChild).append($(g,"{"+N[1]+"}")),g.firstElementChild.setAttribute("test","string-length("+N[0]+")"),c.append(g),y=g.cloneNode(!0)}else y=se(a,"xsl:value-of");y.removeAttribute("name"),a.append(y),a.removeAttribute("select")}else Y(c,"name"),c.setAttribute("select","/datadom/attributes/"+A)}),[...v.querySelectorAll("[value]")].filter(a=>a.getAttribute("value").match(/\{(.*)\?\?(.*)\}/g)).forEach(a=>{const c=h(a,"value");c&&a.setAttribute("value",Se(c))});for(const a of v.childNodes)w.append(f.importNode(a,!0));[...w.getElementsByTagName("xsl:template")].forEach(a=>w.ownerDocument.documentElement.append(a));const q=d(f,'call-template[name="slot"]'),p=a=>{const c=q.cloneNode(!0),A=h(a,"name");A&&c.firstElementChild.setAttribute("select",`'${A}'`);for(let N of a.childNodes)c.lastElementChild.append(N);return c};D(w,"slot",a=>a.parentNode.replaceChild(p(a),a));const u=ne(f);return te(u,{declaredAttributes:t,hardcodedAttributes:s,exposedAttributes:n}),u}async function ve(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||S("div",n.responseText)):s(`${n.statusText} - ${e}`)},n.addEventListener("error",i=>s(i)),n.send()})}const me=e=>e.split("|").map(l=>l.trim()).filter(l=>l),Ee=(e,l)=>me(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 x;x=r.iterateNext();)i.push(x);return i}return[...e.childNodes].find(i=>i.localName===t)||n(S(t,"",s))}).flat();function ae(e,l,t,s){if(!t.sliceProcessed)return t.sliceProcessed=1,Ee(e,l??"").map(n=>{const i=e.ownerDocument,r=t.sliceEventSource,x=t.sliceElement,f=()=>[...n.childNodes].filter(d=>d.nodeType===3||d.localName==="value"||d.localName==="form-data").map(d=>d.remove());r.getAttributeNames().map(d=>n.setAttribute(d,h(r,d))),[...n.childNodes].filter(d=>d.localName==="event").map(d=>d.remove()),"validationMessage"in r&&n.setAttribute("validation-message",r.validationMessage),t.type==="init"&&f(),n.append(z(t,"event",i));const v=(r.type==="checkbox"||r.type==="radio")&&!r.checked;if(x.hasAttribute("slice-value")){r.value===void 0?n.removeAttribute("value"):n.setAttribute("value",r.value);const d=v?"":M(h(x,"slice-value"),n);f(),n.append($(i,d))}else{if("elements"in r)return f(),n.append(z(new FormData(r),"value",n.ownerDocument)),n;const d=v?"":r.value??h(r,"value");f(),d==null?[...n.childNodes].filter(w=>w.localName!=="event").map(w=>w.remove()):xe(d)?n.append($(i,d)):n.append(z(d,"value",n.ownerDocument))}return n})}function D(e,l,t){e.querySelectorAll&&[...e.querySelectorAll(l)].forEach(t)}const Ne=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=import.meta.resolve(t),s&&(e+="#"+s)}catch(i){console.error(i.message)}const n=await ve(e);if(l.setAttributeNS("xml","base",e),s){const i=n.querySelectorAll("#"+s);return i.length?[...i]:(console.error("template not found",e+"#"+s),[l])}return[n]}catch{return[l]}};function Ae(e,l){for(let t of e.attributes)try{t.namespaceURI?l.setAttributeNS(t.namespaceURI,t.name,t.value):l.setAttribute(t.name,t.value),t.name==="value"&&(l.value=t.value)}catch(s){console.warn("attribute assignment error",s?.message||s)}}function de(e,l=0){const t={};for(const s of e.childNodes){const n=h(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&&de(s)}}function we(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 ue(e,l){if(e.firstElementChild?.localName==="dce-root"&&l[0]?.localName!=="dce-root")return;if(!l.length)return e.firstElementChild?.localName!=="dce-root"&&ie(e);const t={};for(let s of e.childNodes)t[s.dceId],ee(s)?(s.data.trim(),t[s.dceId||0]=s):t[h(s,"data-dce-id")||0]=s;for(let s of[...l]){const n=h(s,"data-dce-id")||s.dceId,i=t[n];i?(ee(s)?i.nodeValue!==s.nodeValue&&(i.nodeValue=s.nodeValue):(Ae(s,i),(i.childNodes.length||s.childNodes.length)&&ue(i,s.childNodes)),delete t[n]):we(e,s,n)}for(let s of Object.values(t))s.localName!=="dce-root"&&s.remove()}function Te(e,l){return e.hasAttribute(l)||e.setAttribute(l,crypto.randomUUID()),e.getAttribute(l)}const Se=e=>[...e?.matchAll(/([^{}]*)(\{)([^}]+)}([^{}]*)/g)].map(t=>`${t[1]}{${J(t[3])}}${t[4]}`).join(""),J=e=>{if(!e.trim())return e;const l=e.split("??"),t=l.shift(),s=J(l.join("??"));return l.length?`concat( ${t} , substring( ${s} , (1+string-length( ${s} )) * string-length( ${t} ) ) )`:e},M=(e,l)=>{const t=e.split("??");if(t.length>1)return M(t[0],l)||M(t[1],l);e=J(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},Ce="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(","),Le=(e,l)=>{const t=S("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 De extends HTMLElement{static observedAttributes=["src","tag","hidden"];async connectedCallback(){this.firstElementChild&&this.firstElementChild.localName!=="template"&&console.warn(`custom-element used without template wrapping content
|
|
93
|
+
`,this.outerHTML);const l=await Ne(h(this,"src"),this),t=h(this,"tag"),s=t||"dce-"+crypto.randomUUID();for(const p of l)D(p.templateNode||p.content||p,"style",u=>{const a=u.closest("slot"),c=a?`slot[name="${a.name}"]`:"";u.innerHTML=`${s} ${c}{${u.innerHTML}}`,this.append(u)});const n=l.map(p=>ge(p)),i=n.map((p,u)=>{u=new XSLTProcessor;try{u.importStylesheet(p)}catch(a){console.error(a,I(p))}return u});Object.defineProperty(this,"xsltString",{get:()=>n.map(p=>I(p)).join(`
|
|
94
|
+
`)});const r=this,x=[...this.templateNode.querySelectorAll("[slice]")],f=x.map(p=>h(p,"slice")).filter(p=>!p.includes("/")).filter((p,u,a)=>a.indexOf(p)===u).map(me).flat(),{declaredAttributes:v,hardcodedAttributes:d,exposedAttributes:w}=n[0];class V extends HTMLElement{static get observedAttributes(){return v}#e=0;connectedCallback(){let u=le(this.childNodes);if(this.firstElementChild?.tagName==="TEMPLATE"){this.firstElementChild!==this.lastElementChild&&console.error("payload should have TEMPLATE as only child",this.outerHTML);const m=this.firstElementChild;m.remove(),u=le(m.content.childNodes);for(const E of u)if(E.localName==="style"){const o=Te(this,"data-dce-style");E.innerHTML=`${s}[data-dce-style="${o}"]{${E.innerHTML}}`,m.insertAdjacentElement("beforebegin",E)}else E.nodeType===1?m.insertAdjacentElement("beforebegin",E):E.nodeType===3&&m.insertAdjacentText("beforebegin",E.data)}const a=X("<datadom/>").documentElement,c=(m,E="")=>(o=>(E&&o.append($(a,E)),o))(a.ownerDocument.createElement(m)),A=O(a,"payload",u,ye);oe(A),re(A),this.innerHTML="";const N=O(a,"attributes",this.attributes,m=>c(m.nodeName,m.value)),y=m=>this.hasAttribute(m)||[...N.children].find(E=>E.localName===m);Object.keys(d).map(m=>y(m)||N.append(c(m,d[m]))),v.map(m=>y(m)||N.append(c(m))),O(a,"dataset",Object.keys(this.dataset),m=>c(m,this.dataset[m]));const g=O(a,"slice",f,m=>c(m,"")),U=m=>M(m,g);this.xml=a;const K=[],Q=()=>{const m={};for(let E;E=K.pop();){const o=h(E.sliceElement,"slice");m[o]||(ae(g,o,E),m[o]=E)}Object.keys(m).length!==0&&H()};let _;this.onSlice=m=>{K.push(m),_||(_=setTimeout(()=>{Q(),_=0},1))};const H=this.transform=()=>{if(this.#e)debugger;this.#e=1,i.map((o,b)=>{const C=o.transformToFragment(a.ownerDocument,document);return C||console.error(`XSLT transformation error. xsl:
|
|
95
|
+
`,I(n[b]),`
|
|
96
|
+
xml:
|
|
97
|
+
`,I(a)),C}).map(o=>{o&&(de(o),ue(this,o.childNodes))}),Object.entries(d).map(([o,b])=>{!this.hasAttribute(o)&&b!==h(this,o)&&(this.setAttribute(o,b),this.#t(o,b))}),Object.keys(w).map(o=>{let b=h(this.firstElementChild,o);b!==h(this,o)&&(this.setAttribute(o,b),this.#t(o,b))});function E(o){let b=o;if(o.localName==="slice"){const C=h(o,"for");if(C||(b=o.parentElement),C==="^")do b=b.previousElementSibling;while(b.localName==="slice");else b=this.querySelector(C);if(!b)return console.warn(`can not find selector in "slice for=${C}" `,o.outerHTML);h(o,"slice")||o.setAttribute("slice",h(o,"name"))}return b}D(this,"[slice],[slice-event]",o=>{let b=h(o,"slice-event");const C=o.hasAttribute("slice-value")||o.hasAttribute("value")||o.value,j=E(o);o.dceInitialized||(o.dceInitialized=1,j.hasAttribute("custom-validity")&&(b+=" change submit"),[...new Set((b||"change").split(" "))].forEach(pe=>j.addEventListener(pe,T=>{T.sliceElement=o,T.sliceEventSource=T.currentTarget||T.target,T.sliceProcessed=0;const he=ae(g,h(T.sliceElement,"slice"),T);D(this,"[custom-validity]",P=>{if(!P.setCustomValidity)return;const W=h(P,"custom-validity");try{const R=W&&M(W,N);P.setCustomValidity(R===!0?"":R===!1?"invalid":R)}catch(R){console.error(R,"xPath",W)}});const B=h(j,"custom-validity"),L=B&&M(B,N),F=L===!0?"":L;if(B){if(o.setCustomValidity?o.setCustomValidity(F):o.validationMessage=F,he.map(P=>P.setAttribute("validation-message",F)),T.type==="submit")return L===!0?void 0:(setTimeout(H,1),!!L===L?(L||T.preventDefault(),L):L?(T.preventDefault(),!1):void 0);setTimeout(H,1)}this.onSlice(T)})),(!b||b.includes("init"))&&(C?this.onSlice({type:"init",target:j,sliceElement:o,sliceEventSource:j}):o.value=U(h(o,"slice"))))}),this.#e=0};H(),Q()}#t(u,a){u==="value"&&(this.value=a);let c=this.xml.querySelector(`attributes>${u}`);c?Z(c).append($(c,a)):(c=S(u,a,this.xml),this.xml.querySelector("attributes").append(c)),this.dispatchEvent(new CustomEvent("change",{bubbles:!0,detail:{[u]:a}}))}attributeChangedCallback(u,a,c){!this.xml||this.#e||(this.#t(u,c),this.transform())}get dce(){return r}}const q=p=>{window.customElements.get(p)!==V&&window.customElements.define(p,V)};if(t)q(t);else{const p=s;this.setAttribute("tag",p),q(p);const u=document.createElement(p);this.getAttributeNames().forEach(a=>u.setAttribute(a,this.getAttribute(a))),u.append(...[...this.childNodes].filter(a=>a.localName!=="style")),this.append(u)}}get templateNode(){return this.firstElementChild?.tagName==="TEMPLATE"?this.firstElementChild.content:this}get dce(){return this}get xslt(){return X(this.xsltString)}}window.customElements.define("custom-element",De);export{se as c,te as m};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{w as d,e as a,u as c,f as u}from"./index-
|
|
1
|
+
import{w as d,e as a,u as c,f as u}from"./index-CxRwF5Or.js";import"./custom-element-uuAtIYWS.js";function p(n){return new Promise(e=>setTimeout(e,n))}function m(n){const{title:e,body:t}=n;return`
|
|
2
2
|
<fieldset>
|
|
3
3
|
<legend>${e}</legend>
|
|
4
4
|
${t}
|