@shibui-ui/ui 1.24.1 → 1.25.1
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/dist/components/atoms/index.d.ts +45 -16
- package/dist/components/atoms/index.d.ts.map +1 -1
- package/dist/components/molecules/index.d.ts +20 -1
- package/dist/components/molecules/index.d.ts.map +1 -1
- package/dist/components/organisms/index.d.ts +17 -1
- package/dist/components/organisms/index.d.ts.map +1 -1
- package/dist/index.d.ts +3 -82
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +79 -80
- package/dist/index.js.map +1 -1
- package/dist/index10.js +82 -18
- package/dist/index10.js.map +1 -1
- package/dist/index11.js +84 -69
- package/dist/index11.js.map +1 -1
- package/dist/index12.js +40 -26
- package/dist/index12.js.map +1 -1
- package/dist/index13.js +16 -39
- package/dist/index13.js.map +1 -1
- package/dist/index14.js +29 -44
- package/dist/index14.js.map +1 -1
- package/dist/index15.js +16 -117
- package/dist/index15.js.map +1 -1
- package/dist/index16.js +48 -40
- package/dist/index16.js.map +1 -1
- package/dist/index17.js +41 -25
- package/dist/index17.js.map +1 -1
- package/dist/index18.js +76 -49
- package/dist/index18.js.map +1 -1
- package/dist/index19.js +19 -39
- package/dist/index19.js.map +1 -1
- package/dist/index194.js +94 -24
- package/dist/index194.js.map +1 -1
- package/dist/index195.js +2 -2
- package/dist/index197.js +2 -24
- package/dist/index197.js.map +1 -1
- package/dist/index198.js +74 -2
- package/dist/index198.js.map +1 -1
- package/dist/index199.js +64 -35
- package/dist/index199.js.map +1 -1
- package/dist/index20.js +21 -41
- package/dist/index20.js.map +1 -1
- package/dist/index200.js +2 -2
- package/dist/index201.js +54 -13
- package/dist/index201.js.map +1 -1
- package/dist/index202.js +2 -2
- package/dist/index203.js +2 -2
- package/dist/index204.js +143 -157
- package/dist/index204.js.map +1 -1
- package/dist/index205.js +43 -24
- package/dist/index205.js.map +1 -1
- package/dist/index206.js +51 -2
- package/dist/index206.js.map +1 -1
- package/dist/index207.js +2 -11
- package/dist/index207.js.map +1 -1
- package/dist/index208.js +33 -2
- package/dist/index208.js.map +1 -1
- package/dist/index209.js +2 -91
- package/dist/index209.js.map +1 -1
- package/dist/index21.js +90 -26
- package/dist/index21.js.map +1 -1
- package/dist/index210.js +6 -2
- package/dist/index210.js.map +1 -1
- package/dist/index211.js +2 -41
- package/dist/index211.js.map +1 -1
- package/dist/index212.js +260 -2
- package/dist/index212.js.map +1 -1
- package/dist/index213.js +16 -5
- package/dist/index213.js.map +1 -1
- package/dist/index214.js +2 -2
- package/dist/index215.js +2 -35
- package/dist/index215.js.map +1 -1
- package/dist/index216.js +59 -42
- package/dist/index216.js.map +1 -1
- package/dist/index217.js +32 -2
- package/dist/index217.js.map +1 -1
- package/dist/index218.js +2 -85
- package/dist/index218.js.map +1 -1
- package/dist/index219.js +2 -2
- package/dist/index22.js +41 -48
- package/dist/index22.js.map +1 -1
- package/dist/index220.js +73 -65
- package/dist/index220.js.map +1 -1
- package/dist/index221.js +81 -2
- package/dist/index221.js.map +1 -1
- package/dist/index222.js +2 -10
- package/dist/index222.js.map +1 -1
- package/dist/index223.js +133 -2
- package/dist/index223.js.map +1 -1
- package/dist/index224.js +2 -26
- package/dist/index224.js.map +1 -1
- package/dist/index225.js +2 -2
- package/dist/index226.js +66 -12
- package/dist/index226.js.map +1 -1
- package/dist/index227.js +97 -2
- package/dist/index227.js.map +1 -1
- package/dist/index228.js +2 -2
- package/dist/index229.js +62 -24
- package/dist/index229.js.map +1 -1
- package/dist/index23.js +50 -94
- package/dist/index23.js.map +1 -1
- package/dist/index230.js +2 -2
- package/dist/index231.js +2 -2
- package/dist/index232.js +12 -2
- package/dist/index232.js.map +1 -1
- package/dist/index233.js +5 -16
- package/dist/index233.js.map +1 -1
- package/dist/index234.js +2 -2
- package/dist/index235.js +11 -9
- package/dist/index235.js.map +1 -1
- package/dist/index236.js +2 -2
- package/dist/index237.js +76 -34
- package/dist/index237.js.map +1 -1
- package/dist/index238.js +2 -2
- package/dist/index239.js +2 -27
- package/dist/index239.js.map +1 -1
- package/dist/index24.js +37 -34
- package/dist/index24.js.map +1 -1
- package/dist/index240.js +39 -2
- package/dist/index240.js.map +1 -1
- package/dist/index241.js +2 -34
- package/dist/index241.js.map +1 -1
- package/dist/index242.js +235 -12
- package/dist/index242.js.map +1 -1
- package/dist/index243.js +82 -2
- package/dist/index243.js.map +1 -1
- package/dist/index244.js +2 -9
- package/dist/index244.js.map +1 -1
- package/dist/index245.js +94 -2
- package/dist/index245.js.map +1 -1
- package/dist/index246.js +2 -5
- package/dist/index246.js.map +1 -1
- package/dist/index247.js +268 -2
- package/dist/index247.js.map +1 -1
- package/dist/index248.js +2 -36
- package/dist/index248.js.map +1 -1
- package/dist/index249.js +21 -2
- package/dist/index249.js.map +1 -1
- package/dist/index25.js +51 -32
- package/dist/index25.js.map +1 -1
- package/dist/index250.js +2 -31
- package/dist/index250.js.map +1 -1
- package/dist/index251.js +9 -2
- package/dist/index251.js.map +1 -1
- package/dist/index252.js +2 -19
- package/dist/index252.js.map +1 -1
- package/dist/index253.js +15 -2
- package/dist/index253.js.map +1 -1
- package/dist/index254.js +2 -2
- package/dist/index255.js +135 -69
- package/dist/index255.js.map +1 -1
- package/dist/index256.js +2 -11
- package/dist/index256.js.map +1 -1
- package/dist/index257.js +5 -2
- package/dist/index257.js.map +1 -1
- package/dist/index258.js +2 -78
- package/dist/index258.js.map +1 -1
- package/dist/index259.js +9 -2
- package/dist/index259.js.map +1 -1
- package/dist/index26.js +31 -236
- package/dist/index26.js.map +1 -1
- package/dist/index260.js +2 -32
- package/dist/index260.js.map +1 -1
- package/dist/index261.js +2 -2
- package/dist/index262.js +92 -9
- package/dist/index262.js.map +1 -1
- package/dist/index263.js +59 -2
- package/dist/index263.js.map +1 -1
- package/dist/index264.js +2 -16
- package/dist/index264.js.map +1 -1
- package/dist/index265.js +41 -2
- package/dist/index265.js.map +1 -1
- package/dist/index266.js +2 -16
- package/dist/index266.js.map +1 -1
- package/dist/index267.js +34 -9
- package/dist/index267.js.map +1 -1
- package/dist/index268.js +8 -54
- package/dist/index268.js.map +1 -1
- package/dist/index269.js +2 -2
- package/dist/index27.js +27 -58
- package/dist/index27.js.map +1 -1
- package/dist/index270.js +42 -7
- package/dist/index270.js.map +1 -1
- package/dist/index271.js +2 -2
- package/dist/index272.js +2 -34
- package/dist/index272.js.map +1 -1
- package/dist/index273.js +16 -2
- package/dist/index273.js.map +1 -1
- package/dist/index274.js +9 -2
- package/dist/index274.js.map +1 -1
- package/dist/index275.js +6 -13
- package/dist/index275.js.map +1 -1
- package/dist/index276.js +2 -2
- package/dist/index277.js +8 -15
- package/dist/index277.js.map +1 -1
- package/dist/index278.js +2 -2
- package/dist/index279.js +55 -2
- package/dist/index279.js.map +1 -1
- package/dist/index28.js +247 -24
- package/dist/index28.js.map +1 -1
- package/dist/index280.js +2 -42
- package/dist/index280.js.map +1 -1
- package/dist/index281.js +2 -100
- package/dist/index281.js.map +1 -1
- package/dist/index282.js +20 -2
- package/dist/index282.js.map +1 -1
- package/dist/index283.js +2 -97
- package/dist/index283.js.map +1 -1
- package/dist/index284.js +33 -2
- package/dist/index284.js.map +1 -1
- package/dist/index285.js +6 -27
- package/dist/index285.js.map +1 -1
- package/dist/index286.js +2 -2
- package/dist/index287.js +9 -44
- package/dist/index287.js.map +1 -1
- package/dist/index288.js +2 -2
- package/dist/index289.js +2 -33
- package/dist/index289.js.map +1 -1
- package/dist/index29.js +249 -39
- package/dist/index29.js.map +1 -1
- package/dist/index290.js +36 -2
- package/dist/index290.js.map +1 -1
- package/dist/index291.js +2 -57
- package/dist/index291.js.map +1 -1
- package/dist/index292.js +24 -2
- package/dist/index292.js.map +1 -1
- package/dist/index293.js +2 -2
- package/dist/index294.js +26 -247
- package/dist/index294.js.map +1 -1
- package/dist/index295.js +2 -2
- package/dist/index296.js +2 -72
- package/dist/index296.js.map +1 -1
- package/dist/index297.js +42 -2
- package/dist/index297.js.map +1 -1
- package/dist/index298.js +7 -56
- package/dist/index298.js.map +1 -1
- package/dist/index299.js +2 -133
- package/dist/index299.js.map +1 -1
- package/dist/index30.js +32 -19
- package/dist/index30.js.map +1 -1
- package/dist/index300.js +30 -2
- package/dist/index300.js.map +1 -1
- package/dist/index301.js +2 -12
- package/dist/index301.js.map +1 -1
- package/dist/index302.js +34 -2
- package/dist/index302.js.map +1 -1
- package/dist/index303.js +2 -162
- package/dist/index303.js.map +1 -1
- package/dist/index304.js +26 -42
- package/dist/index304.js.map +1 -1
- package/dist/index305.js +2 -81
- package/dist/index305.js.map +1 -1
- package/dist/index306.js +10 -2
- package/dist/index306.js.map +1 -1
- package/dist/index307.js +2 -71
- package/dist/index307.js.map +1 -1
- package/dist/index308.js +2 -2
- package/dist/index309.js +19 -2
- package/dist/index309.js.map +1 -1
- package/dist/index31.js +96 -11
- package/dist/index31.js.map +1 -1
- package/dist/index310.js +2 -81
- package/dist/index310.js.map +1 -1
- package/dist/index311.js +2 -2
- package/dist/index312.js +42 -2
- package/dist/index312.js.map +1 -1
- package/dist/index313.js +2 -74
- package/dist/index313.js.map +1 -1
- package/dist/index314.js +25 -67
- package/dist/index314.js.map +1 -1
- package/dist/index315.js +2 -2
- package/dist/index316.js +9 -17
- package/dist/index316.js.map +1 -1
- package/dist/index317.js +2 -2
- package/dist/index318.js +84 -32
- package/dist/index318.js.map +1 -1
- package/dist/index319.js +2 -2
- package/dist/index32.js +40 -48
- package/dist/index32.js.map +1 -1
- package/dist/index320.js +68 -77
- package/dist/index320.js.map +1 -1
- package/dist/index321.js +2 -2
- package/dist/index322.js +12 -148
- package/dist/index322.js.map +1 -1
- package/dist/index323.js +1 -1
- package/dist/index324.js +28 -6
- package/dist/index324.js.map +1 -1
- package/dist/index325.js +2 -2
- package/dist/index326.js +78 -87
- package/dist/index326.js.map +1 -1
- package/dist/index327.js +2 -2
- package/dist/index328.js +78 -2
- package/dist/index328.js.map +1 -1
- package/dist/index329.js +2 -237
- package/dist/index329.js.map +1 -1
- package/dist/index33.js +20 -56
- package/dist/index33.js.map +1 -1
- package/dist/index330.js +11 -6
- package/dist/index330.js.map +1 -1
- package/dist/index331.js +2 -2
- package/dist/index332.js +18 -59
- package/dist/index332.js.map +1 -1
- package/dist/index333.js +2 -2
- package/dist/index334.js +12 -5
- package/dist/index334.js.map +1 -1
- package/dist/index335.js +2 -2
- package/dist/index336.js +2 -15
- package/dist/index336.js.map +1 -1
- package/dist/index337.js +88 -2
- package/dist/index337.js.map +1 -1
- package/dist/index338.js +24 -2
- package/dist/index338.js.map +1 -1
- package/dist/index339.js +2 -92
- package/dist/index339.js.map +1 -1
- package/dist/index34.js +59 -35
- package/dist/index34.js.map +1 -1
- package/dist/index340.js +42 -14
- package/dist/index340.js.map +1 -1
- package/dist/index341.js +2 -2
- package/dist/index342.js +22 -80
- package/dist/index342.js.map +1 -1
- package/dist/index343.js +2 -2
- package/dist/index344.js +2 -18
- package/dist/index344.js.map +1 -1
- package/dist/index345.js +16 -2
- package/dist/index345.js.map +1 -1
- package/dist/index346.js +2 -268
- package/dist/index346.js.map +1 -1
- package/dist/index347.js +176 -2
- package/dist/index347.js.map +1 -1
- package/dist/index348.js +2 -2
- package/dist/index349.js +35 -39
- package/dist/index349.js.map +1 -1
- package/dist/index35.js +101 -28
- package/dist/index35.js.map +1 -1
- package/dist/index350.js +3 -3
- package/dist/index350.js.map +1 -1
- package/dist/index351.js +2 -2
- package/dist/index352.js +19 -26
- package/dist/index352.js.map +1 -1
- package/dist/index357.js +26 -19
- package/dist/index357.js.map +1 -1
- package/dist/index36.js +115 -33
- package/dist/index36.js.map +1 -1
- package/dist/index37.js +41 -115
- package/dist/index37.js.map +1 -1
- package/dist/index38.js +34 -246
- package/dist/index38.js.map +1 -1
- package/dist/index39.js +30 -137
- package/dist/index39.js.map +1 -1
- package/dist/index4.js +26 -84
- package/dist/index4.js.map +1 -1
- package/dist/index40.js +26 -400
- package/dist/index40.js.map +1 -1
- package/dist/index41.js +28 -77
- package/dist/index41.js.map +1 -1
- package/dist/index42.js +23 -26
- package/dist/index42.js.map +1 -1
- package/dist/index43.js +36 -33
- package/dist/index43.js.map +1 -1
- package/dist/index44.js +62 -16
- package/dist/index44.js.map +1 -1
- package/dist/index45.js +138 -21
- package/dist/index45.js.map +1 -1
- package/dist/index46.js +129 -22
- package/dist/index46.js.map +1 -1
- package/dist/index47.js +41 -19
- package/dist/index47.js.map +1 -1
- package/dist/index48.js +11 -82
- package/dist/index48.js.map +1 -1
- package/dist/index49.js +56 -279
- package/dist/index49.js.map +1 -1
- package/dist/index5.js +21 -34
- package/dist/index5.js.map +1 -1
- package/dist/index50.js +280 -33
- package/dist/index50.js.map +1 -1
- package/dist/index51.js +74 -94
- package/dist/index51.js.map +1 -1
- package/dist/index52.js +66 -41
- package/dist/index52.js.map +1 -1
- package/dist/index53.js +333 -62
- package/dist/index53.js.map +1 -1
- package/dist/index54.js +96 -256
- package/dist/index54.js.map +1 -1
- package/dist/index55.js +38 -130
- package/dist/index55.js.map +1 -1
- package/dist/index56.js +251 -50
- package/dist/index56.js.map +1 -1
- package/dist/index57.js +144 -115
- package/dist/index57.js.map +1 -1
- package/dist/index58.js +93 -183
- package/dist/index58.js.map +1 -1
- package/dist/index59.js +33 -339
- package/dist/index59.js.map +1 -1
- package/dist/index6.js +2 -2
- package/dist/index60.js +102 -66
- package/dist/index60.js.map +1 -1
- package/dist/index61.js +73 -179
- package/dist/index61.js.map +1 -1
- package/dist/index62.js +117 -97
- package/dist/index62.js.map +1 -1
- package/dist/index63.js +113 -263
- package/dist/index63.js.map +1 -1
- package/dist/index64.js +258 -251
- package/dist/index64.js.map +1 -1
- package/dist/index65.js +177 -79
- package/dist/index65.js.map +1 -1
- package/dist/index66.js +261 -140
- package/dist/index66.js.map +1 -1
- package/dist/index67.js +183 -100
- package/dist/index67.js.map +1 -1
- package/dist/index68.js +28 -89
- package/dist/index68.js.map +1 -1
- package/dist/index69.js +20 -161
- package/dist/index69.js.map +1 -1
- package/dist/index7.js +394 -32
- package/dist/index7.js.map +1 -1
- package/dist/index70.js +190 -53
- package/dist/index70.js.map +1 -1
- package/dist/index71.js +204 -112
- package/dist/index71.js.map +1 -1
- package/dist/index72.js +2 -2
- package/dist/index73.js +89 -28
- package/dist/index73.js.map +1 -1
- package/dist/index74.js +126 -63
- package/dist/index74.js.map +1 -1
- package/dist/index75.js +122 -111
- package/dist/index75.js.map +1 -1
- package/dist/index76.js +67 -64
- package/dist/index76.js.map +1 -1
- package/dist/index77.js +112 -88
- package/dist/index77.js.map +1 -1
- package/dist/index78.js +87 -16
- package/dist/index78.js.map +1 -1
- package/dist/index79.js +151 -79
- package/dist/index79.js.map +1 -1
- package/dist/index8.js +25 -127
- package/dist/index8.js.map +1 -1
- package/dist/index80.js +104 -186
- package/dist/index80.js.map +1 -1
- package/dist/index81.js +59 -20
- package/dist/index81.js.map +1 -1
- package/dist/index82.js +17 -129
- package/dist/index82.js.map +1 -1
- package/dist/index83.js +88 -217
- package/dist/index83.js.map +1 -1
- package/dist/index84.js +64 -112
- package/dist/index84.js.map +1 -1
- package/dist/index9.js +30 -45
- package/dist/index9.js.map +1 -1
- package/dist/src/components/atoms/index.d.ts +45 -16
- package/dist/src/components/atoms/index.d.ts.map +1 -1
- package/dist/src/components/molecules/index.d.ts +20 -1
- package/dist/src/components/molecules/index.d.ts.map +1 -1
- package/dist/src/components/organisms/index.d.ts +17 -1
- package/dist/src/components/organisms/index.d.ts.map +1 -1
- package/dist/src/index.d.ts +3 -82
- package/dist/src/index.d.ts.map +1 -1
- package/dist/tokens.css +353 -7
- package/dist/vite.config.d.ts.map +1 -1
- package/package.json +4 -4
package/dist/index58.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index58.js","sources":["../src/components/molecules/tree-select/lib-tree-select.component.html.ts"],"sourcesContent":["import { html, nothing, TemplateResult } from 'lit';\nimport { map } from 'lit/directives/map.js';\nimport type {\n TreeNode,\n TreeNodeState,\n TreeSelectTemplateProps,\n RenderNodeCtx,\n} from './lib-tree-node.types';\n\n/* ──────────────────────────────────────────────────────────────\n HELPERS\n────────────────────────────────────────────────────────────── */\n\nfunction nodeMatchesSearch(node: TreeNode, term: string): boolean {\n if (!term) return true;\n const t = term.toLowerCase();\n if (node.label.toLowerCase().includes(t)) return true;\n return node.children?.some(c => nodeMatchesSearch(c, term)) ?? false;\n}\n\nfunction highlightLabel(label: string, term: string): TemplateResult {\n if (!term) return html`${label}`;\n const idx = label.toLowerCase().indexOf(term.toLowerCase());\n if (idx === -1) return html`${label}`;\n return html`${label.slice(0, idx)}<mark>${label.slice(idx, idx + term.length)}</mark>${label.slice(idx + term.length)}`;\n}\n\n/* ──────────────────────────────────────────────────────────────\n RENDERIZADO RECURSIVO DE NODO\n────────────────────────────────────────────────────────────── */\n\nfunction renderNode(\n node: TreeNode,\n ctx: RenderNodeCtx,\n depth: number,\n ancestorIsLast: boolean[],\n isLast: boolean,\n): TemplateResult | typeof nothing {\n\n if (ctx.searchValue && !nodeMatchesSearch(node, ctx.searchValue)) return nothing;\n\n const st: TreeNodeState = ctx.nodeStates.get(node.id)\n ?? { selected: false, indeterminate: false, expanded: false };\n\n const hasKids = (node.children?.length ?? 0) > 0;\n const isExpanded = ctx.searchValue ? hasKids : st.expanded;\n\n /* ── Líneas de indentación (estética bambú) ── */\n const indent: TemplateResult | typeof nothing = depth > 0\n ? html`<div class=\"ts-indent\">${\n Array.from({ length: depth }, (_, i) => {\n const isLastUnit = i === depth - 1;\n const ancestorWasLast = ancestorIsLast[i] ?? false;\n const cls = [\n 'ts-indent-unit',\n ancestorWasLast ? 'ts-indent-no-line' : '',\n isLastUnit ? 'ts-indent-last' : '',\n isLastUnit && isLast ? 'ts-indent-last-child' : '',\n ].filter(Boolean).join(' ');\n return html`<div class=\"${cls}\"></div>`;\n })\n }</div>`\n : nothing;\n\n /* ── Toggle expand/collapse ── */\n const toggle: TemplateResult = hasKids\n ? html`\n <div\n class=\"ts-toggle\"\n @click=\"${(e: Event): void => { e.stopPropagation(); ctx.onToggle(node.id); }}\"\n aria-label=\"${isExpanded ? 'Colapsar' : 'Expandir'}\"\n >\n <svg class=\"ts-toggle-icon\" viewBox=\"0 0 8 8\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <path d=\"M2 1.5l3 2.5-3 2.5\"/>\n </svg>\n </div>`\n : html`<div class=\"ts-toggle-spacer\"></div>`;\n\n /* ── Checkbox (solo en modo multi) ── */\n const checkbox: TemplateResult | typeof nothing = ctx.multi\n ? html`\n <div class=\"ts-checkbox\">\n <svg class=\"ts-checkbox-check\" viewBox=\"0 0 10 10\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n <path d=\"M1.5 5l2.5 2.5L8.5 2\"/>\n </svg>\n <div class=\"ts-checkbox-dash\"></div>\n </div>`\n : nothing;\n\n /* ── Row classes ── */\n const rowCls = [\n 'ts-node-row',\n st.selected && !st.indeterminate ? 'is-selected' : '',\n st.indeterminate ? 'is-indeterminate' : '',\n ].filter(Boolean).join(' ');\n\n /* ── Badge (número de hijos directos) ── */\n const badge: TemplateResult | typeof nothing = hasKids\n ? html`<span class=\"ts-node-badge\">${node.children!.length}</span>`\n : nothing;\n\n /* ── Hijos (siempre en DOM, animados con grid-template-rows) ── */\n const childAncestors = [...ancestorIsLast, isLast];\n const children: TemplateResult | typeof nothing = hasKids\n ? html`\n <div class=\"ts-children\">\n <div class=\"ts-children-inner\">\n ${map(node.children!, (child, ci) =>\n renderNode(child, ctx, depth + 1, childAncestors, ci === node.children!.length - 1)\n )}\n </div>\n </div>`\n : nothing;\n\n return html`\n <div class=\"ts-node ${isExpanded ? 'is-expanded' : ''}\">\n <div class=\"${rowCls}\" @click=\"${(): void => ctx.onSelect(node)}\">\n ${indent}\n ${toggle}\n ${checkbox}\n <span class=\"ts-node-label\">${highlightLabel(node.label, ctx.searchValue)}</span>\n ${badge}\n </div>\n ${children}\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n ÁRBOL COMPLETO\n────────────────────────────────────────────────────────────── */\nfunction renderTree(props: TreeSelectTemplateProps): TemplateResult {\n const ctx: RenderNodeCtx = {\n nodeStates: props.nodeStates,\n multi: props.multi,\n searchValue: props.searchValue,\n onToggle: props.onToggle,\n onSelect: props.onSelect,\n };\n\n const visibleNodes = props.nodes.filter(n =>\n !props.searchValue || nodeMatchesSearch(n, props.searchValue)\n );\n\n if (visibleNodes.length === 0) {\n return html`<div class=\"ts-empty\">${props.emptyText}</div>`;\n }\n\n return html`${map(visibleNodes, (node, i) =>\n renderNode(node, ctx, 0, [], i === visibleNodes.length - 1)\n )}`;\n}\n\n/* ──────────────────────────────────────────────────────────────\n BÚSQUEDA\n────────────────────────────────────────────────────────────── */\nfunction renderSearch(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.searchable) return nothing;\n return html`\n <div class=\"ts-search-wrap\">\n <svg class=\"ts-search-icon\" width=\"13\" height=\"13\" viewBox=\"0 0 16 16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <circle cx=\"7\" cy=\"7\" r=\"5\"/><path d=\"M12 12l2.5 2.5\"/>\n </svg>\n <input\n class=\"ts-search\"\n type=\"text\"\n placeholder=\"Buscar…\"\n .value=\"${props.searchValue}\"\n autocomplete=\"off\"\n @input=\"${(e: Event): void => props.onSearch((e.target as HTMLInputElement).value)}\"\n >\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n FOOTER (solo en multi)\n────────────────────────────────────────────────────────────── */\nfunction renderFooter(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.multi) return nothing;\n return html`\n <div class=\"ts-footer\">\n <span class=\"ts-footer-info\">${props.footerInfo}</span>\n <div class=\"ts-footer-actions\">\n <button class=\"ts-btn\" @click=\"${props.onClear}\">Limpiar</button>\n ${props.inline\n ? nothing\n : html`<button class=\"ts-btn ts-btn-confirm\" @click=\"${props.onConfirm}\">Aplicar</button>`}\n </div>\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n TAGS (multi dropdown — debajo del trigger)\n────────────────────────────────────────────────────────────── */\nfunction renderTags(props: TreeSelectTemplateProps): TemplateResult | typeof nothing {\n if (!props.multi || props.inline) return nothing;\n return html`\n <div class=\"ts-tags\">\n ${map(props.tags, tag => html`\n <div class=\"ts-tag\">\n ${tag.label}\n <span class=\"ts-tag-remove\" @click=\"${(): void => props.onTagRemove(tag.id)}\">×</span>\n </div>\n `)}\n </div>\n `;\n}\n\n/* ──────────────────────────────────────────────────────────────\n TEMPLATE PRINCIPAL\n────────────────────────────────────────────────────────────── */\nexport function treeSelectTemplate(props: TreeSelectTemplateProps): TemplateResult {\n\n /* ── Modo INLINE ── */\n if (props.inline) {\n return html`\n <div class=\"ts-inline\">\n ${renderSearch(props)}\n <div class=\"ts-tree\">${renderTree(props)}</div>\n ${renderFooter(props)}\n </div>\n `;\n }\n\n /* ── Modo DROPDOWN ── */\n return html`\n <div class=\"ts-wrap\">\n\n <div\n class=\"ts-trigger\"\n @click=\"${props.onTriggerClick}\"\n aria-haspopup=\"listbox\"\n aria-expanded=\"${props.open}\"\n >\n <span class=\"ts-trigger-label ${props.isPlaceholder ? 'is-placeholder' : ''}\">\n ${props.isPlaceholder ? props.placeholder : props.triggerLabel}\n </span>\n\n ${props.multi && props.selectionCount > 0\n ? html`<span class=\"ts-trigger-count\">${props.selectionCount}</span>`\n : nothing}\n\n <svg class=\"ts-trigger-chevron\" width=\"14\" height=\"14\" viewBox=\"0 0 16 16\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\">\n <path d=\"M3 6l5 5 5-5\"/>\n </svg>\n </div>\n\n <div class=\"ts-dropdown\" role=\"listbox\">\n ${renderSearch(props)}\n <div class=\"ts-tree\">${renderTree(props)}</div>\n ${renderFooter(props)}\n </div>\n\n </div>\n\n ${renderTags(props)}\n `;\n}"],"names":["map"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index58.js","sources":["../src/components/molecules/input/lib-input.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport inputStyles from './lib-input.css?inline';\nimport { inputTemplate } from './lib-input.html';\n\nexport interface LibInputEventDetail {\n value: string;\n}\n\n/**\n * @element lib-input\n * @fires ui-lib-input - Evento disparado al cambiar el valor del input.\n * @slot prefix - Icono o elemento antes del input.\n * @slot suffix - Icono o elemento después del input.\n */\n@customElement('lib-input')\nexport class LibInput extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(inputStyles)}`,\n ];\n\n @property({ type: String }) label = '';\n @property({ type: String }) placeholder = '';\n @property({ type: String }) type: 'text' | 'email' | 'password' = 'text';\n @property({ type: Boolean, reflect: true }) required = false;\n @property({ type: Boolean, reflect: true }) disabled = false;\n @property({ type: Boolean, reflect: true }) error = false;\n @property({ type: String }) errorMessage = '';\n @property({ type: String }) value = '';\n\n @state() private _showPassword = false;\n\n private readonly _uuid = `lib-input-${Math.random().toString(36).slice(2, 9)}`;\n\n override render(): TemplateResult {\n return inputTemplate({\n uuid: this._uuid,\n type: this.type,\n label: this.label,\n placeholder: this.placeholder,\n required: this.required,\n disabled: this.disabled,\n error: this.error,\n errorMessage: this.errorMessage,\n value: this.value,\n showPassword: this._showPassword,\n handleInput: this._handleInput.bind(this),\n handleTogglePassword: this._handleTogglePassword.bind(this),\n });\n }\n\n private _handleInput(e: InputEvent): void {\n const target = e.target as HTMLInputElement;\n this.value = target.value;\n\n this.dispatchEvent(\n new CustomEvent<LibInputEventDetail>('ui-lib-input', {\n detail: { value: this.value },\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private _handleTogglePassword(): void {\n this._showPassword = !this._showPassword;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-input': LibInput;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AAiBO,IAAM,WAAN,cAAuB,WAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA;AAMuB,SAAA,QAAQ;AACR,SAAA,cAAc;AACd,SAAA,OAAsC;AACtB,SAAA,WAAW;AACX,SAAA,WAAW;AACX,SAAA,QAAQ;AACxB,SAAA,eAAe;AACf,SAAA,QAAQ;AAE3B,SAAQ,gBAAgB;AAEjC,SAAiB,QAAQ,aAAa,KAAK,OAAA,EAAS,SAAS,EAAE,EAAE,MAAM,GAAG,CAAC,CAAC;AAAA,EAAA;AAAA,EAEnE,SAAyB;AAChC,WAAO,cAAc;AAAA,MACnB,MAAM,KAAK;AAAA,MACX,MAAM,KAAK;AAAA,MACX,OAAO,KAAK;AAAA,MACZ,aAAa,KAAK;AAAA,MAClB,UAAU,KAAK;AAAA,MACf,UAAU,KAAK;AAAA,MACf,OAAO,KAAK;AAAA,MACZ,cAAc,KAAK;AAAA,MACnB,OAAO,KAAK;AAAA,MACZ,cAAc,KAAK;AAAA,MACnB,aAAa,KAAK,aAAa,KAAK,IAAI;AAAA,MACxC,sBAAsB,KAAK,sBAAsB,KAAK,IAAI;AAAA,IAAA,CAC3D;AAAA,EACH;AAAA,EAEQ,aAAa,GAAqB;AACxC,UAAM,SAAS,EAAE;AACjB,SAAK,QAAQ,OAAO;AAEpB,SAAK;AAAA,MACH,IAAI,YAAiC,gBAAgB;AAAA,QACnD,QAAQ,EAAE,OAAO,KAAK,MAAA;AAAA,QACtB,SAAS;AAAA,QACT,UAAU;AAAA,MAAA,CACX;AAAA,IAAA;AAAA,EAEL;AAAA,EAEQ,wBAA8B;AACpC,SAAK,gBAAgB,CAAC,KAAK;AAAA,EAC7B;AACF;AApDa,SACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,WAAW,CAAC;AAC9B;AAE4B,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GANf,SAMiB,WAAA,SAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAPf,SAOiB,WAAA,eAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GARf,SAQiB,WAAA,QAAA,CAAA;AACgB,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAT/B,SASiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAV/B,SAUiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAX/B,SAWiC,WAAA,SAAA,CAAA;AAChB,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAZf,SAYiB,WAAA,gBAAA,CAAA;AACA,gBAAA;AAAA,EAA3B,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAbf,SAaiB,WAAA,SAAA,CAAA;AAEX,gBAAA;AAAA,EAAhB,MAAA;AAAM,GAfI,SAeM,WAAA,iBAAA,CAAA;AAfN,WAAN,gBAAA;AAAA,EADN,cAAc,WAAW;AAAA,GACb,QAAA;"}
|
package/dist/index59.js
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { unsafeCSS, css, LitElement } from "lit";
|
|
2
|
-
import { property,
|
|
3
|
-
import
|
|
2
|
+
import { property, customElement } from "lit/decorators.js";
|
|
3
|
+
import { alertTemplate } from "./index217.js";
|
|
4
|
+
import alertCss from "./index218.js";
|
|
4
5
|
import sharedTokens from "./index196.js";
|
|
5
|
-
import { colorPickerTemplate, swatchGridTemplate } from "./index303.js";
|
|
6
|
-
import { SHIBUI_SWATCHES } from "./index304.js";
|
|
7
6
|
var __defProp = Object.defineProperty;
|
|
8
7
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
9
8
|
var __decorateClass = (decorators, target, key, kind) => {
|
|
@@ -14,358 +13,53 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
14
13
|
if (kind && result) __defProp(target, key, result);
|
|
15
14
|
return result;
|
|
16
15
|
};
|
|
17
|
-
|
|
18
|
-
const sl = s / 100;
|
|
19
|
-
const ll = l / 100;
|
|
20
|
-
const k = (n) => (n + h / 30) % 12;
|
|
21
|
-
const a = sl * Math.min(ll, 1 - ll);
|
|
22
|
-
const f = (n) => ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));
|
|
23
|
-
return "#" + [f(0), f(8), f(4)].map((x) => Math.round(x * 255).toString(16).padStart(2, "0")).join("").toUpperCase();
|
|
24
|
-
}
|
|
25
|
-
function hexToRgb(hex) {
|
|
26
|
-
const clean = hex.replace("#", "");
|
|
27
|
-
return {
|
|
28
|
-
r: parseInt(clean.slice(0, 2), 16),
|
|
29
|
-
g: parseInt(clean.slice(2, 4), 16),
|
|
30
|
-
b: parseInt(clean.slice(4, 6), 16)
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
function hexToHsl(hex) {
|
|
34
|
-
const { r, g, b } = hexToRgb(hex);
|
|
35
|
-
const rn = r / 255;
|
|
36
|
-
const gn = g / 255;
|
|
37
|
-
const bn = b / 255;
|
|
38
|
-
const max = Math.max(rn, gn, bn);
|
|
39
|
-
const min = Math.min(rn, gn, bn);
|
|
40
|
-
let h = 0;
|
|
41
|
-
let s = 0;
|
|
42
|
-
const l = (max + min) / 2;
|
|
43
|
-
if (max !== min) {
|
|
44
|
-
const d = max - min;
|
|
45
|
-
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
|
|
46
|
-
if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;
|
|
47
|
-
else if (max === gn) h = ((bn - rn) / d + 2) / 6;
|
|
48
|
-
else h = ((rn - gn) / d + 4) / 6;
|
|
49
|
-
}
|
|
50
|
-
return {
|
|
51
|
-
h: Math.round(h * 360),
|
|
52
|
-
s: Math.round(s * 100),
|
|
53
|
-
l: Math.round(l * 100)
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
function isValidHex(v) {
|
|
57
|
-
return /^#[0-9A-Fa-f]{6}$/.test(v);
|
|
58
|
-
}
|
|
59
|
-
let LibColorPicker = class extends LitElement {
|
|
16
|
+
let LibAlert = class extends LitElement {
|
|
60
17
|
constructor() {
|
|
61
18
|
super(...arguments);
|
|
62
|
-
this.
|
|
63
|
-
this.
|
|
64
|
-
this.
|
|
65
|
-
this.
|
|
66
|
-
this.disabled = false;
|
|
67
|
-
this.label = "";
|
|
68
|
-
this.saved = "";
|
|
69
|
-
this._cs = { h: 25, s: 70, l: 36, alpha: 100 };
|
|
70
|
-
this._inputMode = "hex";
|
|
71
|
-
this._open = false;
|
|
72
|
-
this._savedColors = [];
|
|
73
|
-
this._prevCs = { ...this._cs };
|
|
74
|
-
this._dragging = false;
|
|
75
|
-
this._onDocMouseMove = (e) => {
|
|
76
|
-
if (!this._dragging) return;
|
|
77
|
-
this._updateFromCanvasEvent(e);
|
|
78
|
-
};
|
|
79
|
-
this._onDocMouseUp = () => {
|
|
80
|
-
this._dragging = false;
|
|
81
|
-
};
|
|
82
|
-
this._onDocClick = (e) => {
|
|
83
|
-
var _a;
|
|
84
|
-
if (this.variant !== "trigger" || !this._open) return;
|
|
85
|
-
if (!this.contains(e.target) && !(((_a = this.shadowRoot) == null ? void 0 : _a.contains(e.target)) ?? false)) {
|
|
86
|
-
this._cancel();
|
|
87
|
-
}
|
|
88
|
-
};
|
|
89
|
-
this._onKeyDown = (e) => {
|
|
90
|
-
if (e.key === "Escape" && this._open) this._cancel();
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
/* ── Lifecycle ── */
|
|
94
|
-
connectedCallback() {
|
|
95
|
-
super.connectedCallback();
|
|
96
|
-
this._initFromValue(this.value);
|
|
97
|
-
if (this.saved) {
|
|
98
|
-
try {
|
|
99
|
-
this._savedColors = JSON.parse(this.saved);
|
|
100
|
-
} catch {
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
document.addEventListener("mouseup", this._onDocMouseUp);
|
|
104
|
-
document.addEventListener("mousemove", this._onDocMouseMove);
|
|
105
|
-
document.addEventListener("click", this._onDocClick);
|
|
106
|
-
document.addEventListener("keydown", this._onKeyDown);
|
|
107
|
-
}
|
|
108
|
-
disconnectedCallback() {
|
|
109
|
-
super.disconnectedCallback();
|
|
110
|
-
document.removeEventListener("mouseup", this._onDocMouseUp);
|
|
111
|
-
document.removeEventListener("mousemove", this._onDocMouseMove);
|
|
112
|
-
document.removeEventListener("click", this._onDocClick);
|
|
113
|
-
document.removeEventListener("keydown", this._onKeyDown);
|
|
19
|
+
this.type = "default";
|
|
20
|
+
this.heading = "";
|
|
21
|
+
this.closable = false;
|
|
22
|
+
this.glass = false;
|
|
114
23
|
}
|
|
115
|
-
/* ── API pública ── */
|
|
116
|
-
/** Devuelve el color actual en todos los formatos */
|
|
117
|
-
getValue() {
|
|
118
|
-
return this._buildColorResult();
|
|
119
|
-
}
|
|
120
|
-
/** Establece el color desde hex */
|
|
121
|
-
setValue(hex) {
|
|
122
|
-
this._initFromValue(hex);
|
|
123
|
-
this.requestUpdate();
|
|
124
|
-
}
|
|
125
|
-
/* ── Render ── */
|
|
126
24
|
render() {
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
r: res.r,
|
|
134
|
-
g: res.g,
|
|
135
|
-
b: res.b,
|
|
136
|
-
h: res.h,
|
|
137
|
-
s: res.s,
|
|
138
|
-
l: res.l,
|
|
139
|
-
alpha: res.alpha,
|
|
140
|
-
inputMode: this._inputMode,
|
|
141
|
-
savedColors: this._savedColors,
|
|
142
|
-
showAlpha: this.showAlpha,
|
|
143
|
-
onTriggerClick: () => this._togglePanel(),
|
|
144
|
-
onCanvasMousedown: (e) => this._startCanvasDrag(e),
|
|
145
|
-
onHueInput: (e) => this._onHueInput(e),
|
|
146
|
-
onAlphaInput: (e) => this._onAlphaSliderInput(e),
|
|
147
|
-
onModeToggle: () => this._cycleMode(),
|
|
148
|
-
onHexInput: (e) => this._onHexInput(e),
|
|
149
|
-
onRgbInput: (idx, e) => this._onRgbInput(idx, e),
|
|
150
|
-
onHslInput: (idx, e) => this._onHslInput(idx, e),
|
|
151
|
-
onAlphaNumInput: (e) => this._onAlphaNumInput(e),
|
|
152
|
-
onSaveColor: () => this._saveCurrentColor(),
|
|
153
|
-
onSavedClick: (hex) => this._applySavedColor(hex),
|
|
154
|
-
onCancel: () => this._cancel(),
|
|
155
|
-
onApply: () => this._apply()
|
|
25
|
+
return alertTemplate({
|
|
26
|
+
type: this.type,
|
|
27
|
+
heading: this.heading,
|
|
28
|
+
closable: this.closable,
|
|
29
|
+
glass: this.glass,
|
|
30
|
+
handleClose: this._handleClose.bind(this)
|
|
156
31
|
});
|
|
157
32
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
if (!canvas) return;
|
|
167
|
-
const rect = canvas.getBoundingClientRect();
|
|
168
|
-
const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));
|
|
169
|
-
const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));
|
|
170
|
-
this._cs = {
|
|
171
|
-
...this._cs,
|
|
172
|
-
s: Math.round(x * 100),
|
|
173
|
-
l: Math.round((1 - y) * 100)
|
|
174
|
-
};
|
|
175
|
-
this._emitChange();
|
|
176
|
-
}
|
|
177
|
-
/* ── Sliders ── */
|
|
178
|
-
_onHueInput(e) {
|
|
179
|
-
this._cs = { ...this._cs, h: parseInt(e.target.value) };
|
|
180
|
-
this._emitChange();
|
|
181
|
-
}
|
|
182
|
-
_onAlphaSliderInput(e) {
|
|
183
|
-
this._cs = { ...this._cs, alpha: parseInt(e.target.value) };
|
|
184
|
-
this._emitChange();
|
|
185
|
-
}
|
|
186
|
-
/* ── Input mode ── */
|
|
187
|
-
_cycleMode() {
|
|
188
|
-
const modes = ["hex", "rgb", "hsl"];
|
|
189
|
-
const i = modes.indexOf(this._inputMode);
|
|
190
|
-
this._inputMode = modes[(i + 1) % modes.length];
|
|
191
|
-
}
|
|
192
|
-
/* ── Text inputs ── */
|
|
193
|
-
_onHexInput(e) {
|
|
194
|
-
const v = e.target.value;
|
|
195
|
-
if (isValidHex(v)) {
|
|
196
|
-
const hsl = hexToHsl(v);
|
|
197
|
-
this._cs = { ...this._cs, ...hsl };
|
|
198
|
-
this._emitChange();
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
_onRgbInput(idx, e) {
|
|
202
|
-
const val = parseInt(e.target.value) || 0;
|
|
203
|
-
const clamped = Math.max(0, Math.min(255, val));
|
|
204
|
-
const { r, g, b } = hexToRgb(this._buildHex());
|
|
205
|
-
const rgb = [r, g, b];
|
|
206
|
-
rgb[idx] = clamped;
|
|
207
|
-
const hex = "#" + rgb.map((x) => x.toString(16).padStart(2, "0")).join("").toUpperCase();
|
|
208
|
-
const hsl = hexToHsl(hex);
|
|
209
|
-
this._cs = { ...this._cs, ...hsl };
|
|
210
|
-
this._emitChange();
|
|
211
|
-
}
|
|
212
|
-
_onHslInput(idx, e) {
|
|
213
|
-
const val = parseInt(e.target.value) || 0;
|
|
214
|
-
const maxes = [360, 100, 100];
|
|
215
|
-
const clamped = Math.max(0, Math.min(maxes[idx], val));
|
|
216
|
-
const next = { ...this._cs };
|
|
217
|
-
if (idx === 0) next.h = clamped;
|
|
218
|
-
else if (idx === 1) next.s = clamped;
|
|
219
|
-
else next.l = clamped;
|
|
220
|
-
this._cs = next;
|
|
221
|
-
this._emitChange();
|
|
222
|
-
}
|
|
223
|
-
_onAlphaNumInput(e) {
|
|
224
|
-
const val = parseInt(e.target.value) || 0;
|
|
225
|
-
this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };
|
|
226
|
-
this._emitChange();
|
|
227
|
-
}
|
|
228
|
-
/* ── Saved colors ── */
|
|
229
|
-
_saveCurrentColor() {
|
|
230
|
-
const hex = this._buildHex();
|
|
231
|
-
if (!this._savedColors.includes(hex)) {
|
|
232
|
-
this._savedColors = [...this._savedColors, hex];
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
_applySavedColor(hex) {
|
|
236
|
-
this._initFromValue(hex);
|
|
237
|
-
this._emitChange();
|
|
238
|
-
}
|
|
239
|
-
/* ── Panel (trigger mode) ── */
|
|
240
|
-
_togglePanel() {
|
|
241
|
-
if (this._open) {
|
|
242
|
-
this._cancel();
|
|
243
|
-
} else {
|
|
244
|
-
this._prevCs = { ...this._cs };
|
|
245
|
-
this._open = true;
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
_cancel() {
|
|
249
|
-
this._cs = { ...this._prevCs };
|
|
250
|
-
this._open = false;
|
|
251
|
-
}
|
|
252
|
-
_apply() {
|
|
253
|
-
this._open = false;
|
|
254
|
-
this.dispatchEvent(new CustomEvent("ui-lib-apply", {
|
|
255
|
-
detail: this._buildColorResult(),
|
|
256
|
-
bubbles: true,
|
|
257
|
-
composed: true
|
|
258
|
-
}));
|
|
259
|
-
}
|
|
260
|
-
/* ── Helpers ── */
|
|
261
|
-
_initFromValue(hex) {
|
|
262
|
-
if (!isValidHex(hex)) return;
|
|
263
|
-
const hsl = hexToHsl(hex);
|
|
264
|
-
this._cs = { ...this._cs, ...hsl };
|
|
265
|
-
}
|
|
266
|
-
_buildHex() {
|
|
267
|
-
return hslToHex(this._cs.h, this._cs.s, this._cs.l);
|
|
268
|
-
}
|
|
269
|
-
_buildColorResult() {
|
|
270
|
-
const hex = this._buildHex();
|
|
271
|
-
const { r, g, b } = hexToRgb(hex);
|
|
272
|
-
return { hex, r, g, b, ...this._cs };
|
|
273
|
-
}
|
|
274
|
-
_emitChange() {
|
|
275
|
-
this.dispatchEvent(new CustomEvent("ui-lib-change", {
|
|
276
|
-
detail: this._buildColorResult(),
|
|
277
|
-
bubbles: true,
|
|
278
|
-
composed: true
|
|
279
|
-
}));
|
|
33
|
+
_handleClose() {
|
|
34
|
+
this.dispatchEvent(
|
|
35
|
+
new CustomEvent("ui-lib-alert-close", {
|
|
36
|
+
detail: { type: this.type },
|
|
37
|
+
bubbles: true,
|
|
38
|
+
composed: true
|
|
39
|
+
})
|
|
40
|
+
);
|
|
280
41
|
}
|
|
281
42
|
};
|
|
282
|
-
|
|
43
|
+
LibAlert.styles = [
|
|
283
44
|
css`${unsafeCSS(sharedTokens)}`,
|
|
284
|
-
css`${unsafeCSS(
|
|
45
|
+
css`${unsafeCSS(alertCss)}`
|
|
285
46
|
];
|
|
286
|
-
__decorateClass([
|
|
287
|
-
property({ type: String })
|
|
288
|
-
], LibColorPicker.prototype, "value", 2);
|
|
289
47
|
__decorateClass([
|
|
290
48
|
property({ type: String, reflect: true })
|
|
291
|
-
],
|
|
292
|
-
__decorateClass([
|
|
293
|
-
property({ type: Boolean, reflect: true, attribute: "show-alpha" })
|
|
294
|
-
], LibColorPicker.prototype, "showAlpha", 2);
|
|
295
|
-
__decorateClass([
|
|
296
|
-
property({ type: Boolean, reflect: true })
|
|
297
|
-
], LibColorPicker.prototype, "dark", 2);
|
|
298
|
-
__decorateClass([
|
|
299
|
-
property({ type: Boolean, reflect: true })
|
|
300
|
-
], LibColorPicker.prototype, "disabled", 2);
|
|
301
|
-
__decorateClass([
|
|
302
|
-
property({ type: String })
|
|
303
|
-
], LibColorPicker.prototype, "label", 2);
|
|
49
|
+
], LibAlert.prototype, "type", 2);
|
|
304
50
|
__decorateClass([
|
|
305
51
|
property({ type: String })
|
|
306
|
-
],
|
|
307
|
-
__decorateClass([
|
|
308
|
-
state()
|
|
309
|
-
], LibColorPicker.prototype, "_cs", 2);
|
|
310
|
-
__decorateClass([
|
|
311
|
-
state()
|
|
312
|
-
], LibColorPicker.prototype, "_inputMode", 2);
|
|
313
|
-
__decorateClass([
|
|
314
|
-
state()
|
|
315
|
-
], LibColorPicker.prototype, "_open", 2);
|
|
316
|
-
__decorateClass([
|
|
317
|
-
state()
|
|
318
|
-
], LibColorPicker.prototype, "_savedColors", 2);
|
|
319
|
-
LibColorPicker = __decorateClass([
|
|
320
|
-
customElement("lib-color-picker")
|
|
321
|
-
], LibColorPicker);
|
|
322
|
-
let LibColorSwatches = class extends LitElement {
|
|
323
|
-
constructor() {
|
|
324
|
-
super(...arguments);
|
|
325
|
-
this.dark = false;
|
|
326
|
-
this.value = "";
|
|
327
|
-
this.rowsJson = "";
|
|
328
|
-
}
|
|
329
|
-
render() {
|
|
330
|
-
let rows = SHIBUI_SWATCHES;
|
|
331
|
-
if (this.rowsJson) {
|
|
332
|
-
try {
|
|
333
|
-
rows = JSON.parse(this.rowsJson);
|
|
334
|
-
} catch {
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
return swatchGridTemplate({
|
|
338
|
-
rows,
|
|
339
|
-
selected: this.value,
|
|
340
|
-
onSelect: (c) => {
|
|
341
|
-
this.value = c.value;
|
|
342
|
-
this.dispatchEvent(new CustomEvent("ui-lib-swatch-click", {
|
|
343
|
-
detail: c,
|
|
344
|
-
bubbles: true,
|
|
345
|
-
composed: true
|
|
346
|
-
}));
|
|
347
|
-
}
|
|
348
|
-
});
|
|
349
|
-
}
|
|
350
|
-
};
|
|
351
|
-
LibColorSwatches.styles = [
|
|
352
|
-
css`${unsafeCSS(sharedTokens)}`,
|
|
353
|
-
css`${unsafeCSS(pickerCss)}`
|
|
354
|
-
];
|
|
52
|
+
], LibAlert.prototype, "heading", 2);
|
|
355
53
|
__decorateClass([
|
|
356
54
|
property({ type: Boolean, reflect: true })
|
|
357
|
-
],
|
|
358
|
-
__decorateClass([
|
|
359
|
-
property({ type: String })
|
|
360
|
-
], LibColorSwatches.prototype, "value", 2);
|
|
55
|
+
], LibAlert.prototype, "closable", 2);
|
|
361
56
|
__decorateClass([
|
|
362
|
-
property({ type:
|
|
363
|
-
],
|
|
364
|
-
|
|
365
|
-
customElement("lib-
|
|
366
|
-
],
|
|
57
|
+
property({ type: Boolean, reflect: true })
|
|
58
|
+
], LibAlert.prototype, "glass", 2);
|
|
59
|
+
LibAlert = __decorateClass([
|
|
60
|
+
customElement("lib-alert")
|
|
61
|
+
], LibAlert);
|
|
367
62
|
export {
|
|
368
|
-
|
|
369
|
-
LibColorSwatches
|
|
63
|
+
LibAlert
|
|
370
64
|
};
|
|
371
65
|
//# sourceMappingURL=index59.js.map
|
package/dist/index59.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index59.js","sources":["../src/components/molecules/color-picker/lib-color-picker.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport pickerCss from './lib-color-picker.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport { colorPickerTemplate, swatchGridTemplate } from './lib-color-picker.html';\nimport { SHIBUI_SWATCHES } from './lib-color-picker.types';\nimport type {\n ColorPickerVariant,\n ColorInputMode,\n SwatchRow,\n SwatchColor,\n ColorState,\n} from './lib-color-picker.types';\n\n/* ──────────────────────────────────────\n Color conversion utilities\n ────────────────────────────────────── */\nfunction hslToHex(h: number, s: number, l: number): string {\n const sl = s / 100;\n const ll = l / 100;\n const k = (n: number): number => (n + h / 30) % 12;\n const a = sl * Math.min(ll, 1 - ll);\n const f = (n: number): number =>\n ll - a * Math.max(-1, Math.min(k(n) - 3, Math.min(9 - k(n), 1)));\n return '#' + ([f(0), f(8), f(4)] as number[])\n .map(x => Math.round(x * 255).toString(16).padStart(2, '0'))\n .join('')\n .toUpperCase();\n}\n\nfunction hexToRgb(hex: string): { r: number; g: number; b: number } {\n const clean = hex.replace('#', '');\n return {\n r: parseInt(clean.slice(0, 2), 16),\n g: parseInt(clean.slice(2, 4), 16),\n b: parseInt(clean.slice(4, 6), 16),\n };\n}\n\nfunction hexToHsl(hex: string): { h: number; s: number; l: number } {\n const { r, g, b } = hexToRgb(hex);\n const rn = r / 255; const gn = g / 255; const bn = b / 255;\n const max = Math.max(rn, gn, bn);\n const min = Math.min(rn, gn, bn);\n let h = 0; let s = 0;\n const l = (max + min) / 2;\n\n if (max !== min) {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n if (max === rn) h = ((gn - bn) / d + (gn < bn ? 6 : 0)) / 6;\n else if (max === gn) h = ((bn - rn) / d + 2) / 6;\n else h = ((rn - gn) / d + 4) / 6;\n }\n return {\n h: Math.round(h * 360),\n s: Math.round(s * 100),\n l: Math.round(l * 100),\n };\n}\n\nfunction isValidHex(v: string): boolean {\n return /^#[0-9A-Fa-f]{6}$/.test(v);\n}\n\n/**\n * @element lib-color-picker\n *\n * Selector de color con canvas 2D (saturación/luminosidad), slider de tono,\n * slider de opacidad, inputs HEX/RGB/HSL intercambiables y colores guardados.\n *\n * @prop {string} value — Color inicial en HEX (#RRGGBB)\n * @prop {ColorPickerVariant} variant — inline · trigger (default: inline)\n * @prop {boolean} show-alpha— Mostrar slider y campo de opacidad\n * @prop {boolean} dark — Modo oscuro\n * @prop {boolean} disabled — Desactivado\n * @prop {string} label — Texto del trigger (variant=trigger)\n * @prop {string} saved — Colores guardados iniciales (JSON array)\n *\n * @fires ui-lib-change — {detail: {value: string, hex: string, r, g, b, h, s, l, alpha}}\n * @fires ui-lib-apply — Igual a change pero solo al pulsar \"Aplicar\"\n * @fires ui-lib-swatch-click — {detail: {value: string, name?: string}} al clickar un swatch\n *\n * @method getValue() — Devuelve el color actual como {hex, r, g, b, h, s, l, alpha}\n * @method setValue(hex)— Establece el color programáticamente\n */\n@customElement('lib-color-picker')\nexport class LibColorPicker extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n /* ── Props ── */\n\n @property({ type: String })\n value = '#B85A1E';\n\n @property({ type: String, reflect: true })\n variant: ColorPickerVariant = 'inline';\n\n @property({ type: Boolean, reflect: true, attribute: 'show-alpha' })\n showAlpha = false;\n\n @property({ type: Boolean, reflect: true })\n dark = false;\n\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n @property({ type: String })\n label = '';\n\n /** Colores guardados iniciales — JSON array, e.g. '[\"#B85A1E\",\"#357164\"]' */\n @property({ type: String })\n saved = '';\n\n /* ── Internal state ── */\n\n @state() private _cs: ColorState = { h: 25, s: 70, l: 36, alpha: 100 };\n @state() private _inputMode: ColorInputMode = 'hex';\n @state() private _open = false;\n @state() private _savedColors: string[] = [];\n\n /** Color anterior al abrir, para cancelar */\n private _prevCs: ColorState = { ...this._cs };\n\n /** Dragging en el canvas */\n private _dragging = false;\n\n /* ── Lifecycle ── */\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._initFromValue(this.value);\n\n if (this.saved) {\n try { this._savedColors = JSON.parse(this.saved) as string[]; }\n catch { /* ignore */ }\n }\n\n document.addEventListener('mouseup', this._onDocMouseUp);\n document.addEventListener('mousemove', this._onDocMouseMove);\n document.addEventListener('click', this._onDocClick);\n document.addEventListener('keydown', this._onKeyDown);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n document.removeEventListener('mouseup', this._onDocMouseUp);\n document.removeEventListener('mousemove', this._onDocMouseMove);\n document.removeEventListener('click', this._onDocClick);\n document.removeEventListener('keydown', this._onKeyDown);\n }\n\n /* ── API pública ── */\n\n /** Devuelve el color actual en todos los formatos */\n public getValue(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n return this._buildColorResult();\n }\n\n /** Establece el color desde hex */\n public setValue(hex: string): void {\n this._initFromValue(hex);\n this.requestUpdate();\n }\n\n /* ── Render ── */\n\n protected override render(): TemplateResult {\n const res = this._buildColorResult();\n\n return colorPickerTemplate({\n variant: this.variant,\n label: this.label || res.hex,\n panelOpen: this._open,\n hex: res.hex, r: res.r, g: res.g, b: res.b,\n h: res.h, s: res.s, l: res.l,\n alpha: res.alpha,\n inputMode: this._inputMode,\n savedColors: this._savedColors,\n showAlpha: this.showAlpha,\n\n onTriggerClick: (): void => this._togglePanel(),\n onCanvasMousedown: (e: MouseEvent): void => this._startCanvasDrag(e),\n onHueInput: (e: Event): void => this._onHueInput(e),\n onAlphaInput: (e: Event): void => this._onAlphaSliderInput(e),\n onModeToggle: (): void => this._cycleMode(),\n onHexInput: (e: Event): void => this._onHexInput(e),\n onRgbInput: (idx: 0|1|2, e: Event): void => this._onRgbInput(idx, e),\n onHslInput: (idx: 0|1|2, e: Event): void => this._onHslInput(idx, e),\n onAlphaNumInput: (e: Event): void => this._onAlphaNumInput(e),\n onSaveColor: (): void => this._saveCurrentColor(),\n onSavedClick: (hex: string): void => this._applySavedColor(hex),\n onCancel: (): void => this._cancel(),\n onApply: (): void => this._apply(),\n });\n }\n\n /* ── Canvas drag ── */\n\n private _startCanvasDrag(e: MouseEvent): void {\n this._dragging = true;\n this._updateFromCanvasEvent(e);\n }\n\n private _onDocMouseMove = (e: MouseEvent): void => {\n if (!this._dragging) return;\n this._updateFromCanvasEvent(e);\n };\n\n private _onDocMouseUp = (): void => { this._dragging = false; };\n\n private _updateFromCanvasEvent(e: MouseEvent): void {\n const canvas = this.shadowRoot?.querySelector('.cp-canvas');\n if (!canvas) return;\n const rect = canvas.getBoundingClientRect();\n const x = Math.max(0, Math.min(1, (e.clientX - rect.left) / rect.width));\n const y = Math.max(0, Math.min(1, (e.clientY - rect.top) / rect.height));\n this._cs = {\n ...this._cs,\n s: Math.round(x * 100),\n l: Math.round((1 - y) * 100),\n };\n this._emitChange();\n }\n\n /* ── Sliders ── */\n\n private _onHueInput(e: Event): void {\n this._cs = { ...this._cs, h: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n private _onAlphaSliderInput(e: Event): void {\n this._cs = { ...this._cs, alpha: parseInt((e.target as HTMLInputElement).value) };\n this._emitChange();\n }\n\n /* ── Input mode ── */\n\n private _cycleMode(): void {\n const modes: ColorInputMode[] = ['hex', 'rgb', 'hsl'];\n const i = modes.indexOf(this._inputMode);\n this._inputMode = modes[(i + 1) % modes.length]!;\n }\n\n /* ── Text inputs ── */\n\n private _onHexInput(e: Event): void {\n const v = (e.target as HTMLInputElement).value;\n if (isValidHex(v)) {\n const hsl = hexToHsl(v);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n }\n\n private _onRgbInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const clamped = Math.max(0, Math.min(255, val));\n const { r, g, b } = hexToRgb(this._buildHex());\n const rgb: [number, number, number] = [r, g, b];\n rgb[idx] = clamped;\n const hex = '#' + (rgb as number[]).map(x => x.toString(16).padStart(2, '0')).join('').toUpperCase();\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n this._emitChange();\n }\n\n private _onHslInput(idx: 0|1|2, e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n const maxes: [number, number, number] = [360, 100, 100];\n const clamped = Math.max(0, Math.min(maxes[idx]!, val));\n const next = { ...this._cs };\n if (idx === 0) next.h = clamped;\n else if (idx === 1) next.s = clamped;\n else next.l = clamped;\n this._cs = next;\n this._emitChange();\n }\n\n private _onAlphaNumInput(e: Event): void {\n const val = parseInt((e.target as HTMLInputElement).value) || 0;\n this._cs = { ...this._cs, alpha: Math.max(0, Math.min(100, val)) };\n this._emitChange();\n }\n\n /* ── Saved colors ── */\n\n private _saveCurrentColor(): void {\n const hex = this._buildHex();\n if (!this._savedColors.includes(hex)) {\n this._savedColors = [...this._savedColors, hex];\n }\n }\n\n private _applySavedColor(hex: string): void {\n this._initFromValue(hex);\n this._emitChange();\n }\n\n /* ── Panel (trigger mode) ── */\n\n private _togglePanel(): void {\n if (this._open) {\n this._cancel();\n } else {\n this._prevCs = { ...this._cs };\n this._open = true;\n }\n }\n\n private _cancel(): void {\n this._cs = { ...this._prevCs };\n this._open = false;\n }\n\n private _apply(): void {\n this._open = false;\n this.dispatchEvent(new CustomEvent('ui-lib-apply', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n\n /* ── Close on outside click / Escape ── */\n\n private _onDocClick = (e: MouseEvent): void => {\n if (this.variant !== 'trigger' || !this._open) return;\n if (!this.contains(e.target as Node) && !(this.shadowRoot?.contains(e.target as Node) ?? false)) {\n this._cancel();\n }\n };\n\n private _onKeyDown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this._open) this._cancel();\n };\n\n /* ── Helpers ── */\n\n private _initFromValue(hex: string): void {\n if (!isValidHex(hex)) return;\n const hsl = hexToHsl(hex);\n this._cs = { ...this._cs, ...hsl };\n }\n\n private _buildHex(): string {\n return hslToHex(this._cs.h, this._cs.s, this._cs.l);\n }\n\n private _buildColorResult(): { hex: string; r: number; g: number; b: number; h: number; s: number; l: number; alpha: number } {\n const hex = this._buildHex();\n const { r, g, b } = hexToRgb(hex);\n return { hex, r, g, b, ...this._cs };\n }\n\n private _emitChange(): void {\n this.dispatchEvent(new CustomEvent('ui-lib-change', {\n detail: this._buildColorResult(),\n bubbles: true,\n composed: true,\n }));\n }\n}\n\n/* ──────────────────────────────────────\n Swatch-only component\n ────────────────────────────────────── */\n\n/**\n * @element lib-color-swatches\n *\n * Cuadrícula de swatches de color. Puede usarse de forma independiente o\n * para mostrar la paleta del design system.\n *\n * @prop {boolean} dark\n * @prop {string} value — Color seleccionado (hex)\n *\n * @fires ui-lib-swatch-click — {detail: {value, name}}\n */\n@customElement('lib-color-swatches')\nexport class LibColorSwatches extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(pickerCss)}`,\n ];\n\n @property({ type: Boolean, reflect: true }) dark = false;\n @property({ type: String }) value = '';\n @property({ type: String }) rowsJson = '';\n\n protected override render(): TemplateResult {\n let rows: SwatchRow[] = SHIBUI_SWATCHES;\n if (this.rowsJson) {\n try { rows = JSON.parse(this.rowsJson) as SwatchRow[]; } catch { /* ignore */ }\n }\n return swatchGridTemplate({\n rows,\n selected: this.value,\n onSelect: (c: SwatchColor): void => {\n this.value = c.value;\n this.dispatchEvent(new CustomEvent('ui-lib-swatch-click', {\n detail: c, bubbles: true, composed: true,\n }));\n },\n });\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-color-picker': LibColorPicker;\n 'lib-color-swatches': LibColorSwatches;\n }\n}"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index59.js","sources":["../src/components/molecules/lib-alert/lib-alert.component.ts"],"sourcesContent":["import { LitElement, css, unsafeCSS, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { alertTemplate } from './lib-alert.html';\nimport alertCss from './lib-alert.css?inline';\nimport sharedTokens from '../../../styles/shared/tokens.css?inline';\nimport type { AlertType, AlertCloseDetail } from './lib-alert.types';\n\n/**\n * @element lib-alert\n *\n * Alerta estática para feedback contextual dentro del layout.\n * A diferencia de los Toasts, pertenece a una sección específica.\n *\n * @attr type — default · info · warning · error · success\n * @attr heading — Título override. Si no se pasa, se usa el nombre del tipo.\n * @attr closable — Muestra el botón ×\n * @attr glass — Activa el efecto Agua (glassmorphism)\n *\n * @fires ui-lib-alert-close — { type } — al pulsar el botón de cierre\n *\n * @slot — Cuerpo del mensaje\n */\n@customElement('lib-alert')\nexport class LibAlert extends LitElement {\n static override styles = [\n css`${unsafeCSS(sharedTokens)}`,\n css`${unsafeCSS(alertCss)}`,\n ];\n\n @property({ type: String, reflect: true }) type: AlertType = 'default';\n @property({ type: String }) heading = '';\n @property({ type: Boolean, reflect: true }) closable = false;\n @property({ type: Boolean, reflect: true }) glass = false;\n\n override render(): TemplateResult {\n return alertTemplate({\n type: this.type,\n heading: this.heading,\n closable: this.closable,\n glass: this.glass,\n handleClose: this._handleClose.bind(this),\n });\n }\n\n private _handleClose(): void {\n this.dispatchEvent(\n new CustomEvent<AlertCloseDetail>('ui-lib-alert-close', {\n detail: { type: this.type },\n bubbles: true,\n composed: true,\n })\n );\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'lib-alert': LibAlert;\n }\n}"],"names":[],"mappings":";;;;;;;;;;;;;;;AAuBO,IAAM,WAAN,cAAuB,WAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA;AAMsC,SAAA,OAAqB;AACrB,SAAA,UAAW;AACV,SAAA,WAAW;AACX,SAAA,QAAW;AAAA,EAAA;AAAA,EAE9C,SAAyB;AAChC,WAAO,cAAc;AAAA,MACnB,MAAa,KAAK;AAAA,MAClB,SAAa,KAAK;AAAA,MAClB,UAAa,KAAK;AAAA,MAClB,OAAa,KAAK;AAAA,MAClB,aAAa,KAAK,aAAa,KAAK,IAAI;AAAA,IAAA,CACzC;AAAA,EACH;AAAA,EAEQ,eAAqB;AAC3B,SAAK;AAAA,MACH,IAAI,YAA8B,sBAAsB;AAAA,QACtD,QAAU,EAAE,MAAM,KAAK,KAAA;AAAA,QACvB,SAAU;AAAA,QACV,UAAU;AAAA,MAAA,CACX;AAAA,IAAA;AAAA,EAEL;AACF;AA9Ba,SACK,SAAS;AAAA,EACvB,MAAM,UAAU,YAAY,CAAC;AAAA,EAC7B,MAAM,UAAU,QAAQ,CAAC;AAC3B;AAE2C,gBAAA;AAAA,EAA1C,SAAS,EAAE,MAAM,QAAQ,SAAS,MAAM;AAAA,GAN9B,SAMgC,WAAA,QAAA,CAAA;AACA,gBAAA;AAAA,EAA1C,SAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAPf,SAOgC,WAAA,WAAA,CAAA;AACC,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAR/B,SAQiC,WAAA,YAAA,CAAA;AACA,gBAAA;AAAA,EAA3C,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAT/B,SASiC,WAAA,SAAA,CAAA;AATjC,WAAN,gBAAA;AAAA,EADN,cAAc,WAAW;AAAA,GACb,QAAA;"}
|
package/dist/index6.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { unsafeCSS, css, LitElement } from "lit";
|
|
2
2
|
import { property, state, customElement } from "lit/decorators.js";
|
|
3
|
-
import { avatarTemplate } from "./
|
|
4
|
-
import avatarCss from "./
|
|
3
|
+
import { avatarTemplate } from "./index270.js";
|
|
4
|
+
import avatarCss from "./index271.js";
|
|
5
5
|
import sharedTokens from "./index196.js";
|
|
6
6
|
var __defProp = Object.defineProperty;
|
|
7
7
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|