@mhmo91/schmancy 0.9.28 → 0.10.2
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/custom-elements.json +1005 -2215
- package/dist/active-host-CcIa2tmW.cjs +1 -0
- package/dist/active-host-CcIa2tmW.cjs.map +1 -0
- package/dist/active-host-CvNYoprt.js +57 -0
- package/dist/active-host-CvNYoprt.js.map +1 -0
- package/dist/agent/{flow-CvG1fLW5.js.map → flow-CaPi2G8y.js.map} +1 -1
- package/dist/agent/{rolldown-runtime-BIIoCavz.js → rolldown-runtime-DsMetpgY.js} +2 -9
- package/dist/agent/schmancy.agent.js +12678 -7791
- package/dist/agent/schmancy.agent.js.map +1 -1
- package/dist/agent/schmancy.manifest.json +265 -1453
- package/dist/agent/{vendor-highlight-Dow87ZL_.js → vendor-highlight-CHJZQQB7.js} +85 -90
- package/dist/agent/{vendor-highlight-Dow87ZL_.js.map → vendor-highlight-CHJZQQB7.js.map} +1 -1
- package/dist/agent/{vendor-jsqr-Bl4iAtKC.js → vendor-jsqr-r7GNh4P3.js} +1 -1
- package/dist/agent/{vendor-jsqr-Bl4iAtKC.js.map → vendor-jsqr-r7GNh4P3.js.map} +1 -1
- package/dist/agent/{vendor-material-color-DcL7ZPxx.js.map → vendor-material-color-Be96dpGE.js.map} +1 -1
- package/dist/{animation-hXFClrIn.js.map → animation-BK-8BwY8.js.map} +1 -1
- package/dist/{animation-CQRdLgzX.cjs.map → animation-CO_Csq84.cjs.map} +1 -1
- package/dist/{area-BGBCMC79.js → area-DHVANBbr.js} +20 -15
- package/dist/area-DHVANBbr.js.map +1 -0
- package/dist/area-ZupIezvU.cjs +12 -0
- package/dist/area-ZupIezvU.cjs.map +1 -0
- package/dist/area.cjs +1 -1
- package/dist/area.js +2 -2
- package/dist/{audio-Dvr-RBzE.cjs → audio-CluX8Qpq.cjs} +1 -1
- package/dist/{audio-Dvr-RBzE.cjs.map → audio-CluX8Qpq.cjs.map} +1 -1
- package/dist/{audio-ql6nvY0y.js → audio-DcXphulJ.js} +1 -1
- package/dist/{audio-ql6nvY0y.js.map → audio-DcXphulJ.js.map} +1 -1
- package/dist/audio.cjs +1 -1
- package/dist/audio.js +2 -2
- package/dist/autocomplete-Bn525CTp.cjs +115 -0
- package/dist/autocomplete-Bn525CTp.cjs.map +1 -0
- package/dist/{autocomplete-C2P0Soht.js → autocomplete-pHvsyfbH.js} +29 -26
- package/dist/autocomplete-pHvsyfbH.js.map +1 -0
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/avatar.cjs +7 -0
- package/dist/avatar.cjs.map +1 -0
- package/dist/avatar.js +87 -0
- package/dist/avatar.js.map +1 -0
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/boat-IyEtsNI4.cjs +80 -0
- package/dist/boat-IyEtsNI4.cjs.map +1 -0
- package/dist/{boat-DXZ0k7oa.js → boat-_Yv3M6YM.js} +43 -54
- package/dist/boat-_Yv3M6YM.js.map +1 -0
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/breadcrumb.cjs +4 -4
- package/dist/breadcrumb.cjs.map +1 -1
- package/dist/breadcrumb.js +16 -11
- package/dist/breadcrumb.js.map +1 -1
- package/dist/{busy-DGYhpTnO.cjs → busy-CjM39APN.cjs} +4 -4
- package/dist/busy-CjM39APN.cjs.map +1 -0
- package/dist/{busy-iRjq6Nvd.js → busy-Ck2IXJ4r.js} +14 -9
- package/dist/busy-Ck2IXJ4r.js.map +1 -0
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/button.cjs +24 -24
- package/dist/button.cjs.map +1 -1
- package/dist/button.js +42 -37
- package/dist/button.js.map +1 -1
- package/dist/{card-DjYnCckw.cjs → card-DIxDuuth.cjs} +6 -6
- package/dist/card-DIxDuuth.cjs.map +1 -0
- package/dist/{card-wUTjx0EC.js → card-DUWZmMHc.js} +41 -30
- package/dist/card-DUWZmMHc.js.map +1 -0
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/charts.cjs +5 -5
- package/dist/charts.cjs.map +1 -1
- package/dist/charts.js +21 -16
- package/dist/charts.js.map +1 -1
- package/dist/checkbox-CGdFXuWQ.cjs +39 -0
- package/dist/checkbox-CGdFXuWQ.cjs.map +1 -0
- package/dist/{checkbox-VBSenxgb.js → checkbox-DPS1mWG-.js} +86 -82
- package/dist/checkbox-DPS1mWG-.js.map +1 -0
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-BDS9lkPa.js → chips-BnnXQSA-.js} +146 -136
- package/dist/chips-BnnXQSA-.js.map +1 -0
- package/dist/{chips-D6ptH5re.cjs → chips-UoFbwmlG.cjs} +19 -19
- package/dist/chips-UoFbwmlG.cjs.map +1 -0
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +2 -2
- package/dist/{code-highlight-BzRmBZzz.cjs → code-highlight-CMilN0B8.cjs} +15 -15
- package/dist/code-highlight-CMilN0B8.cjs.map +1 -0
- package/dist/{code-highlight-Bi91XHJN.js → code-highlight-kFUJ1Eet.js} +37 -40
- package/dist/code-highlight-kFUJ1Eet.js.map +1 -0
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/connectivity.cjs +2 -2
- package/dist/connectivity.cjs.map +1 -1
- package/dist/connectivity.js +10 -7
- package/dist/connectivity.js.map +1 -1
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +2 -2
- package/dist/context-Bdu1xt0W.js +3 -0
- package/dist/{context-BerzpUhI.js.map → context-Bdu1xt0W.js.map} +1 -1
- package/dist/context-daN5G6HS.cjs +1 -0
- package/dist/{context-C6dHUHhi.cjs.map → context-daN5G6HS.cjs.map} +1 -1
- package/dist/{cursor-glow-BydlDInj.js → cursor-glow-Ah7VXSj7.js} +1 -1
- package/dist/{cursor-glow-BydlDInj.js.map → cursor-glow-Ah7VXSj7.js.map} +1 -1
- package/dist/{cursor-glow-Duw9jHmh.cjs → cursor-glow-Bulq-38P.cjs} +1 -1
- package/dist/{cursor-glow-Duw9jHmh.cjs.map → cursor-glow-Bulq-38P.cjs.map} +1 -1
- package/dist/date-range-BIyrzTRZ.cjs +131 -0
- package/dist/date-range-BIyrzTRZ.cjs.map +1 -0
- package/dist/{date-range-ClTMg1AB.js → date-range-DOstCIg8.js} +16 -17
- package/dist/date-range-DOstCIg8.js.map +1 -0
- package/dist/date-range-inline-4P7zqeVe.cjs +43 -0
- package/dist/{date-range-inline-B9Dp2z6C.cjs.map → date-range-inline-4P7zqeVe.cjs.map} +1 -1
- package/dist/{date-range-inline-CpKG6qt2.js → date-range-inline-BVycTWLb.js} +5 -5
- package/dist/{date-range-inline-CpKG6qt2.js.map → date-range-inline-BVycTWLb.js.map} +1 -1
- package/dist/date-range-inline.cjs +1 -1
- package/dist/date-range-inline.js +1 -1
- package/dist/date-range.cjs +1 -1
- package/dist/date-range.js +1 -1
- package/dist/delay.cjs +9 -1
- package/dist/delay.cjs.map +1 -0
- package/dist/delay.js +77 -2
- package/dist/delay.js.map +1 -0
- package/dist/{details-Cz9ok9si.cjs → details-BJBbZOO6.cjs} +9 -9
- package/dist/details-BJBbZOO6.cjs.map +1 -0
- package/dist/{details-CPjlqQD4.js → details-DPc5GxPa.js} +19 -18
- package/dist/details-DPc5GxPa.js.map +1 -0
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{dialog-service-DH-tjPuE.js → dialog-service-DI9PPy4H.js} +2 -2
- package/dist/dialog-service-DI9PPy4H.js.map +1 -0
- package/dist/{dialog-service-CzDO08Gy.cjs → dialog-service-DJd5L0f5.cjs} +1 -1
- package/dist/dialog-service-DJd5L0f5.cjs.map +1 -0
- package/dist/dialog.cjs +2 -2
- package/dist/dialog.cjs.map +1 -1
- package/dist/dialog.js +13 -14
- package/dist/dialog.js.map +1 -1
- package/dist/directives.cjs +2 -11
- package/dist/directives.cjs.map +1 -1
- package/dist/directives.js +141 -227
- package/dist/directives.js.map +1 -1
- package/dist/discovery.cjs +1 -1
- package/dist/discovery.cjs.map +1 -1
- package/dist/discovery.js +1 -1
- package/dist/discovery.js.map +1 -1
- package/dist/{divider-ghgyw5CU.js → divider-BvJsmSPH.js} +11 -9
- package/dist/divider-BvJsmSPH.js.map +1 -0
- package/dist/{divider-CILo3_vi.cjs → divider-DPT3XnG5.cjs} +3 -3
- package/dist/divider-DPT3XnG5.cjs.map +1 -0
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/dropdown.cjs +4 -4
- package/dist/dropdown.cjs.map +1 -1
- package/dist/dropdown.js +29 -28
- package/dist/dropdown.js.map +1 -1
- package/dist/{expand-CbjBr_Ds.js → expand-BMzocdtj.js} +24 -20
- package/dist/expand-BMzocdtj.js.map +1 -0
- package/dist/expand-CTqBWVXo.cjs +141 -0
- package/dist/expand-CTqBWVXo.cjs.map +1 -0
- package/dist/expand.cjs +1 -1
- package/dist/expand.js +1 -1
- package/dist/{extra-DK9MQtPJ.js → extra-BeHlUhzv.js} +19 -14
- package/dist/extra-BeHlUhzv.js.map +1 -0
- package/dist/{extra-BZeZOMBI.cjs → extra-h_cuxRII.cjs} +6 -6
- package/dist/extra-h_cuxRII.cjs.map +1 -0
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{float-BfCvGeY9.js → float-CTc1xxqH.js} +2 -2
- package/dist/{float-BfCvGeY9.js.map → float-CTc1xxqH.js.map} +1 -1
- package/dist/float-CwVBs11k.cjs +1 -0
- package/dist/{float-CuZ8LOgB.cjs.map → float-CwVBs11k.cjs.map} +1 -1
- package/dist/float.cjs +1 -1
- package/dist/float.js +1 -1
- package/dist/{form-rCZqoAoK.js → form-BtwOBMZ9.js} +1 -1
- package/dist/form-BtwOBMZ9.js.map +1 -0
- package/dist/{form-wI58M85H.cjs → form-CSJp687X.cjs} +1 -1
- package/dist/form-CSJp687X.cjs.map +1 -0
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/handover/agent-runtime-followups.md +1 -1
- package/dist/handover/agent-runtime-v1.md +3 -3
- package/dist/handover/claude-design-brief.md +19 -54
- package/dist/handover/claude-design-setup.md +57 -0
- package/dist/{hashContent-B2IntJQf.js.map → hashContent-1ARKIsx9.js.map} +1 -1
- package/dist/{hashContent-CahnEuut.cjs.map → hashContent-Bp5S6T4U.cjs.map} +1 -1
- package/dist/{icons-Drq4kKy2.js → icons-BbCVrcas.js} +27 -24
- package/dist/icons-BbCVrcas.js.map +1 -0
- package/dist/icons-qEQW4pjM.cjs +52 -0
- package/dist/icons-qEQW4pjM.cjs.map +1 -0
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/{iframe-BmyHW8km.js → iframe-BJfDIEJf.js} +17 -11
- package/dist/iframe-BJfDIEJf.js.map +1 -0
- package/dist/iframe-D6HTruav.cjs +24 -0
- package/dist/iframe-D6HTruav.cjs.map +1 -0
- package/dist/iframe.cjs +1 -1
- package/dist/iframe.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +77 -77
- package/dist/{input-Bc3bVISm.js → input-LTK3cctF.js} +34 -34
- package/dist/input-LTK3cctF.js.map +1 -0
- package/dist/input-U26axtcs.cjs +51 -0
- package/dist/input-U26axtcs.cjs.map +1 -0
- package/dist/{input-chip-DN-cwf11.cjs → input-chip-CADXt0X5.cjs} +2 -2
- package/dist/input-chip-CADXt0X5.cjs.map +1 -0
- package/dist/{input-chip-BQrjpjaQ.js → input-chip-Ch-aCs3c.js} +7 -4
- package/dist/input-chip-Ch-aCs3c.js.map +1 -0
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/json.cjs +1 -1
- package/dist/json.cjs.map +1 -1
- package/dist/json.js +7 -5
- package/dist/json.js.map +1 -1
- package/dist/kbd.cjs +2 -2
- package/dist/kbd.cjs.map +1 -1
- package/dist/kbd.js +9 -7
- package/dist/kbd.js.map +1 -1
- package/dist/{layout-fjM1DWlF.js → layout-C4xmnU4n.js} +1 -1
- package/dist/{layout-fjM1DWlF.js.map → layout-C4xmnU4n.js.map} +1 -1
- package/dist/{layout-CTfRXQoz.cjs → layout-Dmh6fxh0.cjs} +1 -1
- package/dist/{layout-CTfRXQoz.cjs.map → layout-Dmh6fxh0.cjs.map} +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +2 -3
- package/dist/{lazy-D6R5N5v4.js.map → lazy-B0ia54tT.js.map} +1 -1
- package/dist/{lazy-BDNnH_r7.cjs.map → lazy-Dq9mRRjT.cjs.map} +1 -1
- package/dist/lightbox-DbYUSfVl.cjs +202 -0
- package/dist/lightbox-DbYUSfVl.cjs.map +1 -0
- package/dist/{lightbox-CY52Z_ig.js → lightbox-DqG2z3Cn.js} +13 -12
- package/dist/lightbox-DqG2z3Cn.js.map +1 -0
- package/dist/lightbox.cjs +1 -1
- package/dist/lightbox.js +1 -1
- package/dist/list-CLX4sSAw.cjs +40 -0
- package/dist/list-CLX4sSAw.cjs.map +1 -0
- package/dist/{list-D7wUxu1C.js → list-D6-_E5ZD.js} +26 -21
- package/dist/list-D6-_E5ZD.js.map +1 -0
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{magnetic-CVXEkYTA.cjs → magnetic-BH0TsofV.cjs} +1 -1
- package/dist/{magnetic-CVXEkYTA.cjs.map → magnetic-BH0TsofV.cjs.map} +1 -1
- package/dist/{magnetic-BhXebqF3.js → magnetic-BZGFxAWG.js} +2 -2
- package/dist/{magnetic-BhXebqF3.js.map → magnetic-BZGFxAWG.js.map} +1 -1
- package/dist/{mailbox-DLiBGJhY.cjs → mailbox-Ct6iYe-4.cjs} +64 -66
- package/dist/mailbox-Ct6iYe-4.cjs.map +1 -0
- package/dist/{mailbox--EN-JhjV.js → mailbox-DsPII8HR.js} +137 -126
- package/dist/mailbox-DsPII8HR.js.map +1 -0
- package/dist/mailbox.cjs +1 -1
- package/dist/mailbox.js +1 -1
- package/dist/{map-B0S_q3ma.js → map-Dhy3ta9v.js} +11 -9
- package/dist/map-Dhy3ta9v.js.map +1 -0
- package/dist/map-WXeVkx2K.cjs +80 -0
- package/dist/map-WXeVkx2K.cjs.map +1 -0
- package/dist/map.cjs +1 -1
- package/dist/map.js +1 -1
- package/dist/{menu-COeFpb6n.js → menu-Bhd3EapX.js} +15 -10
- package/dist/menu-Bhd3EapX.js.map +1 -0
- package/dist/{menu-3edZGQ1x.cjs → menu-Cg2aaDjs.cjs} +5 -5
- package/dist/menu-Cg2aaDjs.cjs.map +1 -0
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/mixins-CcIWET41.js +627 -0
- package/dist/mixins-CcIWET41.js.map +1 -0
- package/dist/mixins-De3xfjrm.cjs +298 -0
- package/dist/mixins-De3xfjrm.cjs.map +1 -0
- package/dist/mixins.cjs +1 -1
- package/dist/mixins.js +2 -87
- package/dist/nav-drawer.cjs +1 -1
- package/dist/nav-drawer.js +2 -2
- package/dist/navigation-bar.cjs +1 -1
- package/dist/navigation-bar.js +1 -1
- package/dist/navigation-rail.cjs +3 -3
- package/dist/navigation-rail.cjs.map +1 -1
- package/dist/navigation-rail.js +15 -16
- package/dist/navigation-rail.js.map +1 -1
- package/dist/{notification-CC-TFN5v.js → notification-CVLqQ8c_.js} +40 -38
- package/dist/notification-CVLqQ8c_.js.map +1 -0
- package/dist/notification-D_PQjBSf.cjs +23 -0
- package/dist/notification-D_PQjBSf.cjs.map +1 -0
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/option-DDU_goh1.cjs +43 -0
- package/dist/option-DDU_goh1.cjs.map +1 -0
- package/dist/{option-BwAF4nAw.js → option-rm4HebVs.js} +9 -7
- package/dist/option-rm4HebVs.js.map +1 -0
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{overlay-stack-7bs4ZNnh.cjs → overlay-stack-BprhAE9a.cjs} +1 -1
- package/dist/{overlay-stack-7bs4ZNnh.cjs.map → overlay-stack-BprhAE9a.cjs.map} +1 -1
- package/dist/{overlay-stack-DXPYHPhk.js → overlay-stack-CAQno0CK.js} +1 -1
- package/dist/{overlay-stack-DXPYHPhk.js.map → overlay-stack-CAQno0CK.js.map} +1 -1
- package/dist/overlay.cjs +43 -45
- package/dist/overlay.cjs.map +1 -1
- package/dist/overlay.js +684 -268
- package/dist/overlay.js.map +1 -1
- package/dist/page.cjs +3 -3
- package/dist/page.cjs.map +1 -1
- package/dist/page.js +15 -13
- package/dist/page.js.map +1 -1
- package/dist/{components-DZgJWHdZ.js → payment-card-form-C0dHYZIv.js} +21 -22
- package/dist/{components-DZgJWHdZ.js.map → payment-card-form-C0dHYZIv.js.map} +1 -1
- package/dist/payment-card-form-DNvmZxs4.cjs +73 -0
- package/dist/{components-DkmEgyAc.cjs.map → payment-card-form-DNvmZxs4.cjs.map} +1 -1
- package/dist/payment-card-form.cjs +1 -0
- package/dist/payment-card-form.js +2 -0
- package/dist/{progress-Bk_Q1Shy.js → progress-BRerM5Bn.js} +16 -13
- package/dist/progress-BRerM5Bn.js.map +1 -0
- package/dist/{progress-Yz6EMNSu.cjs → progress-U3LQkpM2.cjs} +3 -3
- package/dist/progress-U3LQkpM2.cjs.map +1 -0
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/qr-scanner.cjs +5 -5
- package/dist/qr-scanner.cjs.map +1 -1
- package/dist/qr-scanner.js +14 -15
- package/dist/qr-scanner.js.map +1 -1
- package/dist/{radio-group-BcdcjLNC.js → radio-group-BZ2WoOXJ.js} +14 -12
- package/dist/radio-group-BZ2WoOXJ.js.map +1 -0
- package/dist/radio-group-D7mm-yvJ.cjs +40 -0
- package/dist/radio-group-D7mm-yvJ.cjs.map +1 -0
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/range.cjs +2 -2
- package/dist/range.cjs.map +1 -1
- package/dist/range.js +9 -7
- package/dist/range.js.map +1 -1
- package/dist/{reduced-motion-BZTLqAyl.js.map → reduced-motion-D-L12p7G.js.map} +1 -1
- package/dist/{reduced-motion-9RjNnhIg.cjs.map → reduced-motion-Ds-HjMzn.cjs.map} +1 -1
- package/dist/{rxjs-utils-DJbZRjp3.cjs.map → rxjs-utils-Csnks202.cjs.map} +1 -1
- package/dist/{rxjs-utils-CKTnEKUH.js.map → rxjs-utils-d-ivVN84.js.map} +1 -1
- package/dist/rxjs-utils.cjs +1 -1
- package/dist/rxjs-utils.js +1 -1
- package/dist/scroll-DJTjNIT_.cjs +26 -0
- package/dist/scroll-DJTjNIT_.cjs.map +1 -0
- package/dist/{scroll-DXQv0ejL.js → scroll-qL-HkMdP.js} +9 -7
- package/dist/scroll-qL-HkMdP.js.map +1 -0
- package/dist/search-BLCRsxIC.cjs +1 -0
- package/dist/{search-CwMav5QB.cjs.map → search-BLCRsxIC.cjs.map} +1 -1
- package/dist/{search-CvUZRLF1.js → search-BTz7-Rev.js} +1 -1
- package/dist/{search-CvUZRLF1.js.map → search-BTz7-Rev.js.map} +1 -1
- package/dist/{select-BV4lK2zy.cjs → select-BvA7v-gL.cjs} +6 -6
- package/dist/select-BvA7v-gL.cjs.map +1 -0
- package/dist/{select-DKyGWDsG.js → select-CnPXUeSf.js} +23 -20
- package/dist/select-CnPXUeSf.js.map +1 -0
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/{sheet-C3TLKItO.js → sheet-BRL07BB4.js} +22 -20
- package/dist/sheet-BRL07BB4.js.map +1 -0
- package/dist/sheet-BYQJAHQn.cjs +35 -0
- package/dist/sheet-BYQJAHQn.cjs.map +1 -0
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +2 -2
- package/dist/sheet.service-B25bsrYG.cjs +1 -0
- package/dist/{sheet.service-RcDBwHmv.cjs.map → sheet.service-B25bsrYG.cjs.map} +1 -1
- package/dist/{sheet.service-Dlv20Zfc.js → sheet.service-SPQ8oLCi.js} +3 -3
- package/dist/{sheet.service-Dlv20Zfc.js.map → sheet.service-SPQ8oLCi.js.map} +1 -1
- package/dist/skeleton.cjs +2 -2
- package/dist/skeleton.cjs.map +1 -1
- package/dist/skeleton.js +9 -7
- package/dist/skeleton.js.map +1 -1
- package/dist/skills/INDEX.md +1 -1
- package/dist/skills/SKILL.md +17 -5
- package/dist/skills/mixins.md +78 -20
- package/dist/skills/schmancy/INDEX.md +1 -1
- package/dist/skills/schmancy/SKILL.md +17 -5
- package/dist/skills/schmancy/mixins.md +78 -20
- package/dist/skills/schmancy/state.md +501 -0
- package/dist/skills/schmancy/theme.md +15 -0
- package/dist/skills/schmancy/timeline-tile.md +95 -0
- package/dist/skills/state.md +501 -0
- package/dist/skills/theme.md +15 -0
- package/dist/skills/timeline-tile.md +95 -0
- package/dist/slider.cjs +5 -5
- package/dist/slider.cjs.map +1 -1
- package/dist/slider.js +18 -13
- package/dist/slider.js.map +1 -1
- package/dist/sound.service-BGs6m0Cm.cjs +1 -0
- package/dist/sound.service-BGs6m0Cm.cjs.map +1 -0
- package/dist/{sound.service-DWZe6swU.js → sound.service-kKfsN0m-.js} +3 -3
- package/dist/sound.service-kKfsN0m-.js.map +1 -0
- package/dist/splash-screen-BDt4PInk.cjs +41 -0
- package/dist/splash-screen-BDt4PInk.cjs.map +1 -0
- package/dist/{splash-screen-DbI5RgBf.js → splash-screen-C8JCqX5L.js} +12 -9
- package/dist/splash-screen-C8JCqX5L.js.map +1 -0
- package/dist/splash-screen.cjs +1 -1
- package/dist/splash-screen.js +1 -1
- package/dist/src-CpRNClhg.cjs +263 -0
- package/dist/src-CpRNClhg.cjs.map +1 -0
- package/dist/{src-00DfxCJq.js → src-CqdnWGgr.js} +299 -351
- package/dist/src-CqdnWGgr.js.map +1 -0
- package/dist/state-BusMG6sM.js +868 -0
- package/dist/state-BusMG6sM.js.map +1 -0
- package/dist/state-DNdCPITt.cjs +1 -0
- package/dist/state-DNdCPITt.cjs.map +1 -0
- package/dist/state.cjs +1 -0
- package/dist/state.js +3 -0
- package/dist/steps.cjs +10 -10
- package/dist/steps.cjs.map +1 -1
- package/dist/steps.js +29 -24
- package/dist/steps.js.map +1 -1
- package/dist/surface-C8jQy8Ym.js +24 -0
- package/dist/surface-C8jQy8Ym.js.map +1 -0
- package/dist/surface-Du2Y4vXd.cjs +7 -0
- package/dist/surface-Du2Y4vXd.cjs.map +1 -0
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/switch.cjs +2 -2
- package/dist/switch.cjs.map +1 -1
- package/dist/switch.js +7 -5
- package/dist/switch.js.map +1 -1
- package/dist/table.cjs +72 -1
- package/dist/table.cjs.map +1 -0
- package/dist/table.js +174 -2
- package/dist/table.js.map +1 -0
- package/dist/tabs-0RfeCa00.cjs +31 -0
- package/dist/tabs-0RfeCa00.cjs.map +1 -0
- package/dist/{tabs-Ce55RbwF.js → tabs-Cyahh9Q6.js} +22 -22
- package/dist/tabs-Cyahh9Q6.js.map +1 -0
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +2 -2
- package/dist/{textarea-DjN1D9u0.js → textarea-CXCcTVnf.js} +30 -28
- package/dist/textarea-CXCcTVnf.js.map +1 -0
- package/dist/textarea-jqRrLxmo.cjs +39 -0
- package/dist/textarea-jqRrLxmo.cjs.map +1 -0
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-pbxlt72h.js → theme-2KZW2Rfs.js} +45 -41
- package/dist/{theme-pbxlt72h.js.map → theme-2KZW2Rfs.js.map} +1 -1
- package/dist/theme-Hjz9sCN-.cjs +181 -0
- package/dist/{theme-B-IJ2r7Q.cjs.map → theme-Hjz9sCN-.cjs.map} +1 -1
- package/dist/{theme-button-CEMeAUOL.js → theme-button-9uF1eoHz.js} +3 -4
- package/dist/theme-button-9uF1eoHz.js.map +1 -0
- package/dist/theme-button-C7QIbke1.cjs +8 -0
- package/dist/theme-button-C7QIbke1.cjs.map +1 -0
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/{theme.events-NuihzD_p.js.map → theme.events-Cv7N4Toe.js.map} +1 -1
- package/dist/{theme.events-DakXxZeP.cjs.map → theme.events-DM4H5F2d.cjs.map} +1 -1
- package/dist/{theme.interface-DTwkuAKJ.cjs.map → theme.interface-D9l33b-M.cjs.map} +1 -1
- package/dist/{theme.interface-Buged9Cg.js.map → theme.interface-DnVNre4O.js.map} +1 -1
- package/dist/theme.js +5 -5
- package/dist/theme.service-BrUbGoeQ.cjs +1 -0
- package/dist/theme.service-BrUbGoeQ.cjs.map +1 -0
- package/dist/{theme.service-cOfPrtfe.js → theme.service-CmbOGMA8.js} +4 -4
- package/dist/theme.service-CmbOGMA8.js.map +1 -0
- package/dist/timeline.cjs +277 -0
- package/dist/timeline.cjs.map +1 -0
- package/dist/timeline.js +326 -0
- package/dist/timeline.js.map +1 -0
- package/dist/tree.cjs +2 -2
- package/dist/tree.cjs.map +1 -1
- package/dist/tree.js +15 -13
- package/dist/tree.js.map +1 -1
- package/dist/typewriter.cjs +10 -123
- package/dist/typewriter.cjs.map +1 -1
- package/dist/typewriter.js +90 -212
- package/dist/typewriter.js.map +1 -1
- package/dist/typography.cjs +3 -3
- package/dist/typography.cjs.map +1 -1
- package/dist/typography.js +18 -112
- package/dist/typography.js.map +1 -1
- package/dist/utils-Cr-YO4Np.cjs +1 -0
- package/dist/utils-Cr-YO4Np.cjs.map +1 -0
- package/dist/{utils-Bp2jhyZc.js → utils-hp-DnFf5.js} +16 -6
- package/dist/utils-hp-DnFf5.js.map +1 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +4 -5
- package/dist/visually-hidden.cjs +2 -2
- package/dist/visually-hidden.cjs.map +1 -1
- package/dist/visually-hidden.js +7 -5
- package/dist/visually-hidden.js.map +1 -1
- package/dist/{window-CrjZdf7Y.js → window-C7yY9yp5.js} +28 -30
- package/dist/window-C7yY9yp5.js.map +1 -0
- package/dist/window-DtUOWiAj.cjs +59 -0
- package/dist/window-DtUOWiAj.cjs.map +1 -0
- package/dist/window.cjs +1 -1
- package/dist/window.js +1 -1
- package/package.json +15 -4
- package/plugins/vite-plugin-schmancy-auto-import.ts +143 -0
- package/plugins/vite-plugin-schmancy-manifest.ts +438 -0
- package/skills/schmancy/INDEX.md +1 -1
- package/skills/schmancy/SKILL.md +17 -5
- package/skills/schmancy/mixins.md +78 -20
- package/skills/schmancy/state.md +501 -0
- package/skills/schmancy/theme.md +15 -0
- package/skills/schmancy/timeline-tile.md +95 -0
- package/src/agent/agent-bundle.test.ts +71 -54
- package/src/agent/agent-entry.ts +5 -21
- package/src/agent/helpers.ts +159 -0
- package/src/agent/schmancy-skill.ts +71 -0
- package/src/agent/virtual-manifest.d.ts +1 -12
- package/src/area/area.component.ts +7 -19
- package/src/area/area.service.test.ts +4 -5
- package/src/area/area.service.ts +4 -3
- package/src/area/route.component.ts +17 -4
- package/src/area/utils.ts +3 -2
- package/src/audio/emotional-sounds.ts +0 -2
- package/src/audio/sound.service.ts +7 -13
- package/src/autocomplete/autocomplete.ts +18 -21
- package/src/{avatar.ts → avatar/avatar.ts} +2 -2
- package/src/avatar/index.ts +1 -0
- package/src/badge/badge.ts +4 -3
- package/src/boat/boat.ts +28 -36
- package/src/breadcrumb/breadcrumb.ts +11 -19
- package/src/busy/busy.ts +4 -3
- package/src/busy/spinner.ts +4 -3
- package/src/button/button.ts +6 -11
- package/src/button/icon-button.ts +8 -12
- package/src/card/actions.ts +4 -12
- package/src/card/card.ts +5 -23
- package/src/card/content.ts +4 -12
- package/src/card/media.ts +4 -9
- package/src/charts/area-chart.ts +7 -4
- package/src/charts/pills.ts +6 -4
- package/src/checkbox/checkbox.test.ts +2 -2
- package/src/checkbox/checkbox.ts +3 -9
- package/src/chips/assist-chip.ts +6 -14
- package/src/chips/chips.ts +7 -21
- package/src/chips/filter-chip.ts +4 -3
- package/src/chips/input-chip.ts +10 -9
- package/src/chips/suggestion-chip.ts +10 -12
- package/src/code-highlight/code-highlight.ts +28 -59
- package/src/code-highlight/code-preview.ts +11 -9
- package/src/connectivity/connectivity-status.ts +4 -3
- package/src/content-drawer/drawer.ts +5 -3
- package/src/content-drawer/main.ts +5 -3
- package/src/content-drawer/sheet.ts +6 -4
- package/src/date-range/date-range-dialog.ts +2 -2
- package/src/date-range/date-range.ts +3 -2
- package/src/delay/delay.ts +2 -2
- package/src/details/details.ts +4 -17
- package/src/dialog/dialog-service.ts +2 -0
- package/src/dialog/dialog.component.ts +9 -9
- package/src/directives/drag.ts +1 -9
- package/src/directives/index.ts +0 -1
- package/src/discovery/discovery.service.ts +1 -1
- package/src/divider/divider.ts +5 -14
- package/src/dropdown/dropdown-component.ts +5 -16
- package/src/dropdown/dropdown-content.ts +7 -14
- package/src/expand/expand-root.component.ts +5 -15
- package/src/expand/expand.component.ts +4 -17
- package/src/extra/countries/countries.ts +5 -13
- package/src/extra/timezone/timezone.ts +7 -12
- package/src/form/form.test.ts +2 -2
- package/src/form/form.ts +2 -9
- package/src/icons/icon.ts +4 -3
- package/src/iframe/iframe.ts +13 -4
- package/src/index.ts +3 -3
- package/src/input/input.ts +6 -13
- package/src/json/json.ts +4 -3
- package/src/kbd/kbd.ts +4 -3
- package/src/layout/index.ts +1 -5
- package/src/layout/scroll/scroll.ts +5 -8
- package/src/lightbox/flip-directive.ts +1 -1
- package/src/lightbox/lightbox.ts +5 -14
- package/src/list/list-item.ts +4 -13
- package/src/list/list.ts +12 -10
- package/src/mailbox/email-editor.ts +17 -11
- package/src/mailbox/email-layout-selector.ts +2 -2
- package/src/mailbox/email-recipients.ts +13 -8
- package/src/mailbox/email-template-picker.ts +6 -5
- package/src/mailbox/email-viewer.ts +5 -3
- package/src/mailbox/mailbox.ts +6 -5
- package/src/map/map.ts +8 -6
- package/src/menu/menu-item.ts +5 -16
- package/src/menu/menu.ts +27 -13
- package/src/nav-drawer/appbar.ts +4 -14
- package/src/nav-drawer/content.ts +5 -14
- package/src/nav-drawer/drawer.ts +5 -18
- package/src/nav-drawer/navbar.ts +3 -17
- package/src/navigation-bar/navigation-bar-item.ts +8 -6
- package/src/navigation-bar/navigation-bar.ts +19 -19
- package/src/navigation-rail/navigation-rail-item.ts +9 -5
- package/src/navigation-rail/navigation-rail.ts +10 -14
- package/src/notification/notification-service.ts +0 -2
- package/src/notification/notification.ts +6 -3
- package/src/option/option.ts +4 -3
- package/src/overlay/overlay.animations.ts +183 -37
- package/src/overlay/overlay.component.ts +397 -190
- package/src/overlay/overlay.confirm-body.ts +21 -7
- package/src/overlay/overlay.gestures.ts +72 -36
- package/src/overlay/overlay.layout.ts +103 -1
- package/src/overlay/overlay.positioning.ts +301 -0
- package/src/overlay/overlay.service.ts +81 -3
- package/src/overlay/overlay.stack.ts +8 -10
- package/src/overlay/overlay.types.ts +83 -5
- package/src/page/page.ts +16 -11
- package/src/payment-card-form/index.ts +1 -0
- package/src/{components/form-elements → payment-card-form}/payment-card-form.ts +23 -23
- package/src/progress/progress.ts +5 -3
- package/src/qr-scanner/qr-scanner.ts +7 -30
- package/src/radio-group/radio-button.ts +3 -13
- package/src/radio-group/radio-group.ts +5 -22
- package/src/range/range.ts +4 -3
- package/src/rxjs-utils/waitForElements.ts +1 -1
- package/src/rxjs-utils/waitForElementsAll.ts +1 -1
- package/src/select/select.ts +10 -18
- package/src/sheet/hook.ts +1 -1
- package/src/sheet/sheet.ts +5 -20
- package/src/skeleton/skeleton.ts +4 -3
- package/src/slider/slide.ts +5 -3
- package/src/slider/slider.ts +5 -3
- package/src/splash-screen/splash-screen.ts +5 -3
- package/src/state/CLAUDE.md +161 -0
- package/src/state/MIGRATION.md +258 -0
- package/src/state/SCOPING.md +134 -0
- package/src/state/active-host.ts +190 -0
- package/src/state/index.ts +877 -0
- package/src/state/persist.ts +208 -0
- package/src/state/schmancy-context.ts +130 -0
- package/src/state/state.test-d.ts +227 -0
- package/src/state/state.test.ts +868 -0
- package/src/steps/schmancy-step.ts +5 -3
- package/src/steps/schmancy-steps-container.ts +5 -3
- package/src/surface/surface.ts +14 -9
- package/src/switch/switch.test.ts +2 -2
- package/src/switch/switch.ts +8 -10
- package/src/table/row.ts +7 -4
- package/src/table/table.ts +17 -14
- package/src/tabs/index.ts +0 -2
- package/src/tabs/tab.ts +2 -2
- package/src/tabs/tabs-group.ts +7 -4
- package/src/teleport/teleport.component.ts +5 -3
- package/src/textarea/textarea.ts +6 -12
- package/src/theme/theme-audio-player.ts +7 -5
- package/src/theme/theme-controller.ts +2 -2
- package/src/theme/theme.component.ts +22 -15
- package/src/theme/theme.service.ts +6 -7
- package/src/theme/theme.style.css +1 -0
- package/src/theme-button/theme-button.ts +2 -2
- package/src/timeline/index.ts +1 -0
- package/src/timeline/timeline-tile.ts +431 -0
- package/src/tree/tree.ts +4 -16
- package/src/typewriter/index.ts +1 -1
- package/src/typography/typography.ts +5 -98
- package/src/utils/intersection.ts +5 -1
- package/src/utils/overlay-stack.ts +1 -1
- package/src/utils/search.ts +2 -2
- package/src/visually-hidden/visually-hidden.ts +4 -3
- package/src/window/window-position.ts +3 -6
- package/src/window/window.ts +9 -7
- package/types/mixins/SchmancyElement.d.ts +49 -0
- package/types/mixins/formField.mixin.d.ts +4 -2
- package/types/mixins/index.d.ts +1 -0
- package/types/mixins/litElement.mixin.d.ts +11 -0
- package/types/src/agent/agent-entry.d.ts +2 -19
- package/types/src/agent/helpers.d.ts +0 -27
- package/types/src/agent/schmancy-skill.d.ts +3 -5
- package/types/src/area/area.component.d.ts +3 -17
- package/types/src/area/route.component.d.ts +14 -4
- package/types/src/audio/emotional-sounds.d.ts +0 -1
- package/types/src/audio/sound.service.d.ts +1 -1
- package/types/src/autocomplete/autocomplete.d.ts +4 -15
- package/types/src/{avatar.d.ts → avatar/avatar.d.ts} +2 -3
- package/types/src/avatar/index.d.ts +1 -0
- package/types/src/badge/badge.d.ts +3 -3
- package/types/src/boat/boat.d.ts +3 -2
- package/types/src/breadcrumb/breadcrumb.d.ts +9 -19
- package/types/src/busy/busy.d.ts +3 -3
- package/types/src/busy/spinner.d.ts +3 -3
- package/types/src/button/button.d.ts +4 -10
- package/types/src/button/icon-button.d.ts +5 -11
- package/types/src/card/actions.d.ts +3 -12
- package/types/src/card/card.d.ts +4 -24
- package/types/src/card/content.d.ts +3 -12
- package/types/src/card/media.d.ts +3 -9
- package/types/src/charts/area-chart.d.ts +3 -3
- package/types/src/charts/pills.d.ts +3 -3
- package/types/src/checkbox/checkbox.d.ts +3 -10
- package/types/src/chips/assist-chip.d.ts +5 -15
- package/types/src/chips/chips.d.ts +3 -17
- package/types/src/chips/filter-chip.d.ts +3 -3
- package/types/src/chips/input-chip.d.ts +9 -10
- package/types/src/chips/suggestion-chip.d.ts +9 -13
- package/types/src/code-highlight/code-highlight.d.ts +4 -11
- package/types/src/code-highlight/code-preview.d.ts +3 -3
- package/types/src/connectivity/connectivity-status.d.ts +3 -3
- package/types/src/content-drawer/drawer.d.ts +4 -4
- package/types/src/content-drawer/main.d.ts +3 -3
- package/types/src/content-drawer/sheet.d.ts +4 -4
- package/types/src/date-range/date-range-dialog.d.ts +2 -3
- package/types/src/date-range/date-range.d.ts +2 -3
- package/types/src/delay/delay.d.ts +2 -3
- package/types/src/details/details.d.ts +3 -14
- package/types/src/dialog/dialog.component.d.ts +9 -9
- package/types/src/directives/drag.d.ts +1 -3
- package/types/src/directives/index.d.ts +0 -1
- package/types/src/divider/divider.d.ts +3 -14
- package/types/src/dropdown/dropdown-component.d.ts +4 -17
- package/types/src/dropdown/dropdown-content.d.ts +6 -14
- package/types/src/expand/expand-root.component.d.ts +4 -14
- package/types/src/expand/expand.component.d.ts +3 -17
- package/types/src/extra/countries/countries.d.ts +3 -13
- package/types/src/extra/timezone/timezone.d.ts +4 -11
- package/types/src/form/form.d.ts +2 -9
- package/types/src/icons/icon.d.ts +3 -3
- package/types/src/iframe/iframe.d.ts +5 -3
- package/types/src/index.d.ts +3 -3
- package/types/src/input/input.d.ts +4 -11
- package/types/src/json/json.d.ts +3 -3
- package/types/src/kbd/kbd.d.ts +3 -3
- package/types/src/layout/index.d.ts +0 -4
- package/types/src/layout/scroll/scroll.d.ts +4 -8
- package/types/src/lightbox/lightbox.d.ts +3 -14
- package/types/src/list/list-item.d.ts +3 -13
- package/types/src/list/list.d.ts +11 -10
- package/types/src/mailbox/email-editor.d.ts +3 -3
- package/types/src/mailbox/email-layout-selector.d.ts +2 -3
- package/types/src/mailbox/email-recipients.d.ts +7 -3
- package/types/src/mailbox/email-template-picker.d.ts +4 -4
- package/types/src/mailbox/email-viewer.d.ts +3 -3
- package/types/src/mailbox/mailbox.d.ts +4 -4
- package/types/src/map/map.d.ts +4 -3
- package/types/src/menu/menu-item.d.ts +3 -16
- package/types/src/menu/menu.d.ts +25 -13
- package/types/src/nav-drawer/appbar.d.ts +3 -14
- package/types/src/nav-drawer/content.d.ts +3 -14
- package/types/src/nav-drawer/drawer.d.ts +3 -18
- package/types/src/nav-drawer/navbar.d.ts +3 -18
- package/types/src/navigation-bar/navigation-bar-item.d.ts +7 -6
- package/types/src/navigation-bar/navigation-bar.d.ts +13 -7
- package/types/src/navigation-rail/navigation-rail-item.d.ts +9 -6
- package/types/src/navigation-rail/navigation-rail.d.ts +10 -15
- package/types/src/notification/notification-service.d.ts +0 -1
- package/types/src/notification/notification.d.ts +3 -3
- package/types/src/option/option.d.ts +3 -3
- package/types/src/overlay/overlay.animations.d.ts +54 -6
- package/types/src/overlay/overlay.component.d.ts +39 -15
- package/types/src/overlay/overlay.confirm-body.d.ts +4 -4
- package/types/src/overlay/overlay.gestures.d.ts +26 -17
- package/types/src/overlay/overlay.layout.d.ts +27 -1
- package/types/src/overlay/overlay.positioning.d.ts +87 -0
- package/types/src/overlay/overlay.stack.d.ts +0 -2
- package/types/src/overlay/overlay.types.d.ts +59 -5
- package/types/src/page/page.d.ts +14 -11
- package/types/src/{components/form-elements → payment-card-form}/payment-card-form.d.ts +2 -3
- package/types/src/progress/progress.d.ts +3 -3
- package/types/src/qr-scanner/qr-scanner.d.ts +3 -3
- package/types/src/radio-group/radio-button.d.ts +3 -12
- package/types/src/radio-group/radio-group.d.ts +4 -20
- package/types/src/range/range.d.ts +3 -3
- package/types/src/rxjs-utils/waitForElements.d.ts +1 -1
- package/types/src/rxjs-utils/waitForElementsAll.d.ts +1 -1
- package/types/src/select/select.d.ts +4 -15
- package/types/src/sheet/sheet.d.ts +3 -20
- package/types/src/skeleton/skeleton.d.ts +3 -3
- package/types/src/slider/slide.d.ts +3 -2
- package/types/src/slider/slider.d.ts +3 -3
- package/types/src/splash-screen/splash-screen.d.ts +3 -3
- package/types/src/state/active-host.d.ts +23 -0
- package/types/src/state/index.d.ts +145 -0
- package/types/src/state/persist.d.ts +14 -0
- package/types/src/state/schmancy-context.d.ts +32 -0
- package/types/src/state/state.test-d.d.ts +131 -0
- package/types/src/state/state.test.d.ts +1 -0
- package/types/src/steps/schmancy-step.d.ts +3 -3
- package/types/src/steps/schmancy-steps-container.d.ts +3 -3
- package/types/src/surface/surface.d.ts +13 -5
- package/types/src/switch/switch.d.ts +7 -11
- package/types/src/table/row.d.ts +2 -3
- package/types/src/table/table.d.ts +4 -11
- package/types/src/tabs/index.d.ts +0 -2
- package/types/src/tabs/tab.d.ts +2 -3
- package/types/src/tabs/tabs-group.d.ts +3 -3
- package/types/src/teleport/teleport.component.d.ts +3 -3
- package/types/src/textarea/textarea.d.ts +5 -12
- package/types/src/theme/theme-audio-player.d.ts +3 -3
- package/types/src/theme/theme-controller.d.ts +2 -2
- package/types/src/theme/theme.component.d.ts +18 -13
- package/types/src/theme-button/theme-button.d.ts +2 -3
- package/types/src/timeline/index.d.ts +1 -0
- package/types/src/timeline/timeline-tile.d.ts +44 -0
- package/types/src/tree/tree.d.ts +3 -16
- package/types/src/typewriter/index.d.ts +1 -1
- package/types/src/typography/typography.d.ts +3 -36
- package/types/src/visually-hidden/visually-hidden.d.ts +3 -3
- package/types/src/window/window.d.ts +3 -3
- package/dist/agent/index.es-Dymj8REP.js +0 -489
- package/dist/agent/index.es-Dymj8REP.js.map +0 -1
- package/dist/area-BGBCMC79.js.map +0 -1
- package/dist/area-D7l9KR2N.cjs +0 -12
- package/dist/area-D7l9KR2N.cjs.map +0 -1
- package/dist/autocomplete-BPD5uraA.cjs +0 -115
- package/dist/autocomplete-BPD5uraA.cjs.map +0 -1
- package/dist/autocomplete-C2P0Soht.js.map +0 -1
- package/dist/boat-BkIO-0No.cjs +0 -80
- package/dist/boat-BkIO-0No.cjs.map +0 -1
- package/dist/boat-DXZ0k7oa.js.map +0 -1
- package/dist/busy-DGYhpTnO.cjs.map +0 -1
- package/dist/busy-iRjq6Nvd.js.map +0 -1
- package/dist/card-DjYnCckw.cjs.map +0 -1
- package/dist/card-wUTjx0EC.js.map +0 -1
- package/dist/checkbox-CiYEtw9F.cjs +0 -39
- package/dist/checkbox-CiYEtw9F.cjs.map +0 -1
- package/dist/checkbox-VBSenxgb.js.map +0 -1
- package/dist/chips-BDS9lkPa.js.map +0 -1
- package/dist/chips-D6ptH5re.cjs.map +0 -1
- package/dist/code-highlight-Bi91XHJN.js.map +0 -1
- package/dist/code-highlight-BzRmBZzz.cjs.map +0 -1
- package/dist/components-DkmEgyAc.cjs +0 -73
- package/dist/components.cjs +0 -1
- package/dist/components.js +0 -2
- package/dist/context-BerzpUhI.js +0 -3
- package/dist/context-C6dHUHhi.cjs +0 -1
- package/dist/date-range-BmFxTXiU.cjs +0 -131
- package/dist/date-range-BmFxTXiU.cjs.map +0 -1
- package/dist/date-range-ClTMg1AB.js.map +0 -1
- package/dist/date-range-inline-B9Dp2z6C.cjs +0 -43
- package/dist/delay-BHODnTg-.cjs +0 -9
- package/dist/delay-BHODnTg-.cjs.map +0 -1
- package/dist/delay-Dlk0A3he.js +0 -347
- package/dist/delay-Dlk0A3he.js.map +0 -1
- package/dist/details-CPjlqQD4.js.map +0 -1
- package/dist/details-Cz9ok9si.cjs.map +0 -1
- package/dist/dialog-service-CzDO08Gy.cjs.map +0 -1
- package/dist/dialog-service-DH-tjPuE.js.map +0 -1
- package/dist/divider-CILo3_vi.cjs.map +0 -1
- package/dist/divider-ghgyw5CU.js.map +0 -1
- package/dist/expand-CbjBr_Ds.js.map +0 -1
- package/dist/expand-r3OrSoDk.cjs +0 -141
- package/dist/expand-r3OrSoDk.cjs.map +0 -1
- package/dist/extra-BZeZOMBI.cjs.map +0 -1
- package/dist/extra-DK9MQtPJ.js.map +0 -1
- package/dist/float-CuZ8LOgB.cjs +0 -1
- package/dist/flow-BPDtbhLe.js +0 -386
- package/dist/flow-BPDtbhLe.js.map +0 -1
- package/dist/flow-Dn9AZktE.cjs +0 -1
- package/dist/flow-Dn9AZktE.cjs.map +0 -1
- package/dist/form-rCZqoAoK.js.map +0 -1
- package/dist/form-wI58M85H.cjs.map +0 -1
- package/dist/handover/agent-runtime-v2-loopback.md +0 -71
- package/dist/handover/claude-design-v2-paste.md +0 -42
- package/dist/icons-Drq4kKy2.js.map +0 -1
- package/dist/icons-DtdhaZdc.cjs +0 -52
- package/dist/icons-DtdhaZdc.cjs.map +0 -1
- package/dist/iframe-BkwwWIbQ.cjs +0 -24
- package/dist/iframe-BkwwWIbQ.cjs.map +0 -1
- package/dist/iframe-BmyHW8km.js.map +0 -1
- package/dist/index.es-BgmFX1JM.cjs +0 -1
- package/dist/index.es-BgmFX1JM.cjs.map +0 -1
- package/dist/index.es-CLyb_o3Y.js +0 -489
- package/dist/index.es-CLyb_o3Y.js.map +0 -1
- package/dist/input-BGNZlfL8.cjs +0 -51
- package/dist/input-BGNZlfL8.cjs.map +0 -1
- package/dist/input-Bc3bVISm.js.map +0 -1
- package/dist/input-chip-BQrjpjaQ.js.map +0 -1
- package/dist/input-chip-DN-cwf11.cjs.map +0 -1
- package/dist/intersection-BrXp4YTO.js +0 -12
- package/dist/intersection-BrXp4YTO.js.map +0 -1
- package/dist/intersection-DqBqnpgh.cjs +0 -1
- package/dist/intersection-DqBqnpgh.cjs.map +0 -1
- package/dist/layout-7eyMBmZk.cjs +0 -17
- package/dist/layout-7eyMBmZk.cjs.map +0 -1
- package/dist/layout-Ox6nJkzC.js +0 -268
- package/dist/layout-Ox6nJkzC.js.map +0 -1
- package/dist/lightbox-CY52Z_ig.js.map +0 -1
- package/dist/lightbox-H8Uq3AXy.cjs +0 -202
- package/dist/lightbox-H8Uq3AXy.cjs.map +0 -1
- package/dist/list-BGjVo6zb.cjs +0 -40
- package/dist/list-BGjVo6zb.cjs.map +0 -1
- package/dist/list-D7wUxu1C.js.map +0 -1
- package/dist/litElement.mixin-CszkJuNl.js +0 -12
- package/dist/litElement.mixin-CszkJuNl.js.map +0 -1
- package/dist/litElement.mixin-qh5-IIUq.cjs +0 -1
- package/dist/litElement.mixin-qh5-IIUq.cjs.map +0 -1
- package/dist/mailbox--EN-JhjV.js.map +0 -1
- package/dist/mailbox-DLiBGJhY.cjs.map +0 -1
- package/dist/map-B0S_q3ma.js.map +0 -1
- package/dist/map-EDQN0I6e.cjs +0 -80
- package/dist/map-EDQN0I6e.cjs.map +0 -1
- package/dist/menu-3edZGQ1x.cjs.map +0 -1
- package/dist/menu-COeFpb6n.js.map +0 -1
- package/dist/metric.cjs +0 -69
- package/dist/metric.cjs.map +0 -1
- package/dist/metric.js +0 -93
- package/dist/metric.js.map +0 -1
- package/dist/mixins.cjs.map +0 -1
- package/dist/mixins.js.map +0 -1
- package/dist/notification-CC-TFN5v.js.map +0 -1
- package/dist/notification-P4c-kFdH.cjs +0 -23
- package/dist/notification-P4c-kFdH.cjs.map +0 -1
- package/dist/option-BwAF4nAw.js.map +0 -1
- package/dist/option-Cu0ertuF.cjs +0 -43
- package/dist/option-Cu0ertuF.cjs.map +0 -1
- package/dist/progress-Bk_Q1Shy.js.map +0 -1
- package/dist/progress-Yz6EMNSu.cjs.map +0 -1
- package/dist/provide-CYgj58u_.cjs +0 -1
- package/dist/provide-CYgj58u_.cjs.map +0 -1
- package/dist/provide-ydIskwf2.js +0 -107
- package/dist/provide-ydIskwf2.js.map +0 -1
- package/dist/radio-group-BcdcjLNC.js.map +0 -1
- package/dist/radio-group-BpBz5tRA.cjs +0 -40
- package/dist/radio-group-BpBz5tRA.cjs.map +0 -1
- package/dist/scroll-DXQv0ejL.js.map +0 -1
- package/dist/scroll-DbZMTv0K.cjs +0 -26
- package/dist/scroll-DbZMTv0K.cjs.map +0 -1
- package/dist/search-CwMav5QB.cjs +0 -1
- package/dist/select-BV4lK2zy.cjs.map +0 -1
- package/dist/select-DKyGWDsG.js.map +0 -1
- package/dist/sheet-BAI_jH1t.cjs +0 -35
- package/dist/sheet-BAI_jH1t.cjs.map +0 -1
- package/dist/sheet-C3TLKItO.js.map +0 -1
- package/dist/sheet.service-RcDBwHmv.cjs +0 -1
- package/dist/skills/schmancy/store.md +0 -126
- package/dist/skills/store.md +0 -126
- package/dist/sound.service-BEN6Xjy_.cjs +0 -1
- package/dist/sound.service-BEN6Xjy_.cjs.map +0 -1
- package/dist/sound.service-DWZe6swU.js.map +0 -1
- package/dist/splash-screen-DbI5RgBf.js.map +0 -1
- package/dist/splash-screen-DoHRTHi8.cjs +0 -41
- package/dist/splash-screen-DoHRTHi8.cjs.map +0 -1
- package/dist/src-00DfxCJq.js.map +0 -1
- package/dist/src-C_JjQovE.cjs +0 -269
- package/dist/src-C_JjQovE.cjs.map +0 -1
- package/dist/store-CjFHCSDb.cjs +0 -1
- package/dist/store-CjFHCSDb.cjs.map +0 -1
- package/dist/store-CjzZDQt8.js +0 -1654
- package/dist/store-CjzZDQt8.js.map +0 -1
- package/dist/store.cjs +0 -1
- package/dist/store.js +0 -2
- package/dist/surface-D-GWBcsh.cjs +0 -7
- package/dist/surface-D-GWBcsh.cjs.map +0 -1
- package/dist/surface-D23JtxYP.js +0 -22
- package/dist/surface-D23JtxYP.js.map +0 -1
- package/dist/surface.mixin-DqMwoddO.js +0 -320
- package/dist/surface.mixin-DqMwoddO.js.map +0 -1
- package/dist/surface.mixin-DxOi-xo0.cjs +0 -297
- package/dist/surface.mixin-DxOi-xo0.cjs.map +0 -1
- package/dist/table-C7b73kdg.cjs +0 -63
- package/dist/table-C7b73kdg.cjs.map +0 -1
- package/dist/table-CTrhV9-k.js +0 -631
- package/dist/table-CTrhV9-k.js.map +0 -1
- package/dist/tabs-Ce55RbwF.js.map +0 -1
- package/dist/tabs-DAzB8O7w.cjs +0 -31
- package/dist/tabs-DAzB8O7w.cjs.map +0 -1
- package/dist/tailwind.mixin-DRI1oTYQ.cjs +0 -2
- package/dist/tailwind.mixin-DRI1oTYQ.cjs.map +0 -1
- package/dist/tailwind.mixin-mdQR3BEO.js +0 -219
- package/dist/tailwind.mixin-mdQR3BEO.js.map +0 -1
- package/dist/textarea-DjN1D9u0.js.map +0 -1
- package/dist/textarea-PuHxBvJA.cjs +0 -39
- package/dist/textarea-PuHxBvJA.cjs.map +0 -1
- package/dist/theme-B-IJ2r7Q.cjs +0 -181
- package/dist/theme-button-BSbYmS4p.cjs +0 -8
- package/dist/theme-button-BSbYmS4p.cjs.map +0 -1
- package/dist/theme-button-CEMeAUOL.js.map +0 -1
- package/dist/theme.service-DxJPUGlu.cjs +0 -1
- package/dist/theme.service-DxJPUGlu.cjs.map +0 -1
- package/dist/theme.service-cOfPrtfe.js.map +0 -1
- package/dist/tslib.es6-Cnt75pb6.cjs +0 -1
- package/dist/tslib.es6-Cnt75pb6.cjs.map +0 -1
- package/dist/tslib.es6-DMzzJKHV.js +0 -7
- package/dist/tslib.es6-DMzzJKHV.js.map +0 -1
- package/dist/utils-Bp2jhyZc.js.map +0 -1
- package/dist/utils-CBPQvxNW.cjs +0 -1
- package/dist/utils-CBPQvxNW.cjs.map +0 -1
- package/dist/window-CrjZdf7Y.js.map +0 -1
- package/dist/window-DTUARSrU.cjs +0 -59
- package/dist/window-DTUARSrU.cjs.map +0 -1
- package/skills/schmancy/store.md +0 -126
- package/src/components/form-elements/index.ts +0 -1
- package/src/components/index.ts +0 -1
- package/src/layout/flex/flex.scss +0 -4
- package/src/layout/flex/flex.ts +0 -74
- package/src/layout/flex/index.ts +0 -1
- package/src/layout/grid/.readme +0 -79
- package/src/layout/grid/grid.scss +0 -5
- package/src/layout/grid/grid.ts +0 -121
- package/src/layout/grid/index.ts +0 -1
- package/src/layout/layout.ts +0 -122
- package/src/layout/v2/flex.ts +0 -243
- package/src/layout/v2/index.ts +0 -1
- package/src/metric/index.ts +0 -1
- package/src/metric/metric.ts +0 -127
- package/src/store/context-array.ts +0 -358
- package/src/store/context-collection.ts +0 -218
- package/src/store/context-create.ts +0 -284
- package/src/store/context-object.ts +0 -298
- package/src/store/filter-directive.ts +0 -614
- package/src/store/index.ts +0 -10
- package/src/store/selector-hook.ts +0 -259
- package/src/store/selectors.ts +0 -289
- package/src/store/storage-manager.ts +0 -269
- package/src/store/store.class.ts +0 -239
- package/src/store/types.ts +0 -327
- package/src/tabs/tabs-compatibility.ts +0 -20
- package/src/typewriter/typewriter.ts +0 -410
- package/types/src/agent/index.d.ts +0 -1
- package/types/src/area/route.test.d.ts +0 -20
- package/types/src/button/button.test.d.ts +0 -1
- package/types/src/chips/chip.d.ts +0 -3
- package/types/src/components/index.d.ts +0 -1
- package/types/src/content-drawer/$sheet.d.ts +0 -14
- package/types/src/dialog/dailog.d.ts +0 -116
- package/types/src/dialog/dialog-content.d.ts +0 -17
- package/types/src/directives/guard.d.ts +0 -1
- package/types/src/directives/visibility.d.ts +0 -11
- package/types/src/form/form-v2.d.ts +0 -22
- package/types/src/input/input-v2.d.ts +0 -250
- package/types/src/layout/flex/flex.d.ts +0 -26
- package/types/src/layout/flex/index.d.ts +0 -1
- package/types/src/layout/grid/grid.d.ts +0 -39
- package/types/src/layout/grid/index.d.ts +0 -1
- package/types/src/layout/layout.d.ts +0 -59
- package/types/src/layout/v2/flex.d.ts +0 -65
- package/types/src/layout/v2/grid.d.ts +0 -51
- package/types/src/layout/v2/index.d.ts +0 -1
- package/types/src/lightbox/flip.directive.d.ts +0 -22
- package/types/src/metric/index.d.ts +0 -1
- package/types/src/metric/metric.d.ts +0 -39
- package/types/src/notification/outlet.d.ts +0 -10
- package/types/src/sheet/header.d.ts +0 -10
- package/types/src/store/context-array.d.ts +0 -83
- package/types/src/store/context-collection.d.ts +0 -74
- package/types/src/store/context-create.d.ts +0 -43
- package/types/src/store/context-object.d.ts +0 -46
- package/types/src/store/filter-directive.d.ts +0 -116
- package/types/src/store/immer-integration.d.ts +0 -54
- package/types/src/store/index.d.ts +0 -10
- package/types/src/store/selector-hook.d.ts +0 -46
- package/types/src/store/selectors.d.ts +0 -90
- package/types/src/store/storage-manager.d.ts +0 -48
- package/types/src/store/store.class.d.ts +0 -73
- package/types/src/store/types.d.ts +0 -241
- package/types/src/tabs/tabs-compatibility.d.ts +0 -13
- package/types/src/theme/theme.elevation.d.ts +0 -131
- package/types/src/theme/theme.motion.d.ts +0 -198
- package/types/src/theme/theme.shape.d.ts +0 -144
- package/types/src/theme/theme.state.d.ts +0 -546
- package/types/src/theme/theme.typography.d.ts +0 -74
- package/types/src/tooltip/tooltip.d.ts +0 -33
- package/types/src/typewriter/typewriter.d.ts +0 -94
- /package/dist/agent/{flow-CvG1fLW5.js → flow-CaPi2G8y.js} +0 -0
- /package/dist/agent/{vendor-material-color-DcL7ZPxx.js → vendor-material-color-Be96dpGE.js} +0 -0
- /package/dist/{animation-hXFClrIn.js → animation-BK-8BwY8.js} +0 -0
- /package/dist/{animation-CQRdLgzX.cjs → animation-CO_Csq84.cjs} +0 -0
- /package/dist/{decorate-D_utPUsC.js → decorate-23nYs4Le.js} +0 -0
- /package/dist/{decorate-F9CuyeHg.cjs → decorate-DpFmy0nm.cjs} +0 -0
- /package/dist/{hashContent-B2IntJQf.js → hashContent-1ARKIsx9.js} +0 -0
- /package/dist/{hashContent-CahnEuut.cjs → hashContent-Bp5S6T4U.cjs} +0 -0
- /package/dist/{lazy-D6R5N5v4.js → lazy-B0ia54tT.js} +0 -0
- /package/dist/{lazy-BDNnH_r7.cjs → lazy-Dq9mRRjT.cjs} +0 -0
- /package/dist/{reduced-motion-BZTLqAyl.js → reduced-motion-D-L12p7G.js} +0 -0
- /package/dist/{reduced-motion-9RjNnhIg.cjs → reduced-motion-Ds-HjMzn.cjs} +0 -0
- /package/dist/{rxjs-utils-DJbZRjp3.cjs → rxjs-utils-Csnks202.cjs} +0 -0
- /package/dist/{rxjs-utils-CKTnEKUH.js → rxjs-utils-d-ivVN84.js} +0 -0
- /package/dist/{theme.events-NuihzD_p.js → theme.events-Cv7N4Toe.js} +0 -0
- /package/dist/{theme.events-DakXxZeP.cjs → theme.events-DM4H5F2d.cjs} +0 -0
- /package/dist/{theme.interface-DTwkuAKJ.cjs → theme.interface-D9l33b-M.cjs} +0 -0
- /package/dist/{theme.interface-Buged9Cg.js → theme.interface-DnVNre4O.js} +0 -0
- /package/src/{directives/typewriter.ts → typewriter/typewriter.directive.ts} +0 -0
- /package/types/src/{components/form-elements → payment-card-form}/index.d.ts +0 -0
- /package/types/src/{directives/typewriter.d.ts → typewriter/typewriter.directive.d.ts} +0 -0
|
@@ -0,0 +1,431 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Timeline tile — one cell in a procurement-stage rail.
|
|
3
|
+
*
|
|
4
|
+
* Three render states (one component, four `state` values):
|
|
5
|
+
* - `empty` dashed-border outline + glyph
|
|
6
|
+
* - `filled` paper-card with glyph; hoverable / focusable / clickable
|
|
7
|
+
* - `stack-top` paper-card on top of N siblings; carries the ×N badge
|
|
8
|
+
* - `stack-sibling` paper-card behind the top; revealed when the wrapper
|
|
9
|
+
* is fanned
|
|
10
|
+
*
|
|
11
|
+
* Stack fan is coordinated by a `data-fanned` attribute on the parent
|
|
12
|
+
* wrapper element. The `stack-top` tile owns the orchestration: a
|
|
13
|
+
* `pointerover` pipe on the wrapper element with hover-intent (immediate
|
|
14
|
+
* enter, 800ms leave debounce) toggles the attribute. Sibling tiles read
|
|
15
|
+
* the attribute via the `:host-context([data-fanned])` selector. Native
|
|
16
|
+
* `:hover` would drop the moment the cursor crosses the gap between
|
|
17
|
+
* fanned siblings; the attribute survives that crossing because the
|
|
18
|
+
* pointerover stream stays on the wrapper subtree.
|
|
19
|
+
*/
|
|
20
|
+
import { SchmancyElement } from '@mixins/index'
|
|
21
|
+
import { css, html } from 'lit'
|
|
22
|
+
import { customElement, property } from 'lit/decorators.js'
|
|
23
|
+
import { when } from 'lit/directives/when.js'
|
|
24
|
+
import {
|
|
25
|
+
EMPTY,
|
|
26
|
+
Observable,
|
|
27
|
+
distinctUntilChanged,
|
|
28
|
+
fromEvent,
|
|
29
|
+
map,
|
|
30
|
+
of,
|
|
31
|
+
switchMap,
|
|
32
|
+
takeUntil,
|
|
33
|
+
timer,
|
|
34
|
+
} from 'rxjs'
|
|
35
|
+
|
|
36
|
+
export type TimelineTileState = 'empty' | 'filled' | 'stack-top' | 'stack-sibling'
|
|
37
|
+
|
|
38
|
+
export type TimelineTileClickEvent = CustomEvent<{
|
|
39
|
+
glyph: string
|
|
40
|
+
state: TimelineTileState
|
|
41
|
+
}>
|
|
42
|
+
|
|
43
|
+
@customElement('schmancy-timeline-tile')
|
|
44
|
+
export class SchmancyTimelineTile extends SchmancyElement {
|
|
45
|
+
static styles = [css`
|
|
46
|
+
:host {
|
|
47
|
+
--schmancy-tile-w: 32px;
|
|
48
|
+
--schmancy-tile-h: 40px;
|
|
49
|
+
display: inline-block;
|
|
50
|
+
position: relative;
|
|
51
|
+
width: var(--schmancy-tile-w);
|
|
52
|
+
height: var(--schmancy-tile-h);
|
|
53
|
+
font-size: 14px;
|
|
54
|
+
line-height: 1.45;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/* Inner box that paints the cell. The host is a layout container only;
|
|
58
|
+
the box owns the border / background / hover transform so the host
|
|
59
|
+
stays a clean focus target. */
|
|
60
|
+
.tile {
|
|
61
|
+
position: absolute;
|
|
62
|
+
inset: 0;
|
|
63
|
+
border-radius: 2px;
|
|
64
|
+
overflow: visible;
|
|
65
|
+
appearance: none;
|
|
66
|
+
padding: 0;
|
|
67
|
+
font: inherit;
|
|
68
|
+
color: inherit;
|
|
69
|
+
background: transparent;
|
|
70
|
+
z-index: 1;
|
|
71
|
+
transition:
|
|
72
|
+
transform 120ms ease-in-out,
|
|
73
|
+
box-shadow 120ms ease-in-out,
|
|
74
|
+
border-color 120ms ease-in-out;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/* Empty state */
|
|
78
|
+
:host([state='empty']) .tile {
|
|
79
|
+
border: 1px dashed var(--schmancy-sys-color-outline);
|
|
80
|
+
background: transparent;
|
|
81
|
+
cursor: default;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
:host([state='empty']) .glyph {
|
|
85
|
+
color: var(--schmancy-sys-color-surface-onVariant);
|
|
86
|
+
opacity: 0.7;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/* Shared filled-state card styling (filled / stack-top / stack-sibling) */
|
|
90
|
+
:host([state='filled']) .tile,
|
|
91
|
+
:host([state='stack-top']) .tile,
|
|
92
|
+
:host([state='stack-sibling']) .tile {
|
|
93
|
+
border: 1px solid var(--schmancy-sys-color-outline);
|
|
94
|
+
background: var(--schmancy-sys-color-surface-containerLowest);
|
|
95
|
+
cursor: pointer;
|
|
96
|
+
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.02);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
/* Paper-card line texture: five thin lines emulating ruled paper */
|
|
100
|
+
:host([state='filled']) .tile::before,
|
|
101
|
+
:host([state='stack-top']) .tile::before,
|
|
102
|
+
:host([state='stack-sibling']) .tile::before {
|
|
103
|
+
content: '';
|
|
104
|
+
position: absolute;
|
|
105
|
+
left: 4px;
|
|
106
|
+
right: 4px;
|
|
107
|
+
top: 16px;
|
|
108
|
+
bottom: 5px;
|
|
109
|
+
background-image:
|
|
110
|
+
linear-gradient(var(--schmancy-sys-color-outline) 1px, transparent 1px),
|
|
111
|
+
linear-gradient(var(--schmancy-sys-color-outline) 1px, transparent 1px),
|
|
112
|
+
linear-gradient(var(--schmancy-sys-color-outline) 1px, transparent 1px),
|
|
113
|
+
linear-gradient(var(--schmancy-sys-color-outline) 1px, transparent 1px),
|
|
114
|
+
linear-gradient(var(--schmancy-sys-color-outline) 1px, transparent 1px);
|
|
115
|
+
background-repeat: no-repeat;
|
|
116
|
+
background-size:
|
|
117
|
+
100% 1px,
|
|
118
|
+
80% 1px,
|
|
119
|
+
92% 1px,
|
|
120
|
+
65% 1px,
|
|
121
|
+
78% 1px;
|
|
122
|
+
background-position:
|
|
123
|
+
0 0,
|
|
124
|
+
0 4px,
|
|
125
|
+
0 8px,
|
|
126
|
+
0 12px,
|
|
127
|
+
0 16px;
|
|
128
|
+
opacity: 0.3;
|
|
129
|
+
pointer-events: none;
|
|
130
|
+
z-index: 0;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/* Tinted accent strip across the top edge */
|
|
134
|
+
:host([state='filled']) .tile::after,
|
|
135
|
+
:host([state='stack-top']) .tile::after,
|
|
136
|
+
:host([state='stack-sibling']) .tile::after {
|
|
137
|
+
content: '';
|
|
138
|
+
position: absolute;
|
|
139
|
+
left: 0;
|
|
140
|
+
right: 0;
|
|
141
|
+
top: 0;
|
|
142
|
+
height: 11px;
|
|
143
|
+
background: color-mix(
|
|
144
|
+
in oklch,
|
|
145
|
+
var(--schmancy-sys-color-primary-default) 10%,
|
|
146
|
+
transparent
|
|
147
|
+
);
|
|
148
|
+
border-bottom: 1px solid
|
|
149
|
+
color-mix(
|
|
150
|
+
in oklch,
|
|
151
|
+
var(--schmancy-sys-color-primary-default) 25%,
|
|
152
|
+
var(--schmancy-sys-color-outline)
|
|
153
|
+
);
|
|
154
|
+
pointer-events: none;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
:host([state='filled']) .glyph,
|
|
158
|
+
:host([state='stack-top']) .glyph,
|
|
159
|
+
:host([state='stack-sibling']) .glyph {
|
|
160
|
+
color: var(--schmancy-sys-color-primary-onContainer);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/* Single-card hover: lift 1px + soft shadow */
|
|
164
|
+
:host([state='filled']) .tile:hover {
|
|
165
|
+
border-color: var(--schmancy-sys-color-primary-default);
|
|
166
|
+
transform: translateY(-1px);
|
|
167
|
+
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.06);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
/* Focus ring in primary color */
|
|
171
|
+
:host([state='filled']) .tile:focus-visible,
|
|
172
|
+
:host([state='stack-top']) .tile:focus-visible,
|
|
173
|
+
:host([state='stack-sibling']) .tile:focus-visible {
|
|
174
|
+
outline: 2px solid var(--schmancy-sys-color-primary-default);
|
|
175
|
+
outline-offset: 3px;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
/* Stacked tiles position absolutely on the host's grid cell so the
|
|
179
|
+
wrapper's --fan-count / --i custom properties drive the offset. */
|
|
180
|
+
:host([state='stack-top']),
|
|
181
|
+
:host([state='stack-sibling']) {
|
|
182
|
+
position: absolute;
|
|
183
|
+
top: 0;
|
|
184
|
+
left: 0;
|
|
185
|
+
transition:
|
|
186
|
+
transform 200ms cubic-bezier(0.2, 0.8, 0.2, 1),
|
|
187
|
+
box-shadow 200ms cubic-bezier(0.2, 0.8, 0.2, 1);
|
|
188
|
+
transform: translate(
|
|
189
|
+
calc((var(--fan-count, 1) - 1 - var(--i, 0)) * -3px),
|
|
190
|
+
calc((var(--fan-count, 1) - 1 - var(--i, 0)) * 3px)
|
|
191
|
+
);
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
/* Sibling tiles only become interactive once the wrapper is fanned —
|
|
195
|
+
otherwise they're stacked underneath and would steal pointer events
|
|
196
|
+
from the top card. */
|
|
197
|
+
:host([state='stack-sibling']) {
|
|
198
|
+
pointer-events: none;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
/* Fanned: every tile slides edge-to-edge along the wrapper's row */
|
|
202
|
+
:host([state='stack-top']:host-context([data-fanned])),
|
|
203
|
+
:host-context([data-fanned]):host([state='stack-top']) {
|
|
204
|
+
transform: translate(
|
|
205
|
+
calc((var(--fan-count, 1) - 1 - var(--i, 0)) * var(--schmancy-tile-w) * -1),
|
|
206
|
+
0
|
|
207
|
+
);
|
|
208
|
+
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.06);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
:host([state='stack-sibling']:host-context([data-fanned])),
|
|
212
|
+
:host-context([data-fanned]):host([state='stack-sibling']) {
|
|
213
|
+
pointer-events: auto;
|
|
214
|
+
transform: translate(
|
|
215
|
+
calc((var(--fan-count, 1) - 1 - var(--i, 0)) * var(--schmancy-tile-w) * -1),
|
|
216
|
+
0
|
|
217
|
+
);
|
|
218
|
+
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.06);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
:host-context([data-fanned]):host([state='stack-top']) .tile:hover,
|
|
222
|
+
:host-context([data-fanned]):host([state='stack-sibling']) .tile:hover {
|
|
223
|
+
border-color: var(--schmancy-sys-color-primary-default);
|
|
224
|
+
box-shadow: 0 6px 14px rgba(0, 0, 0, 0.1);
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
.glyph {
|
|
228
|
+
position: absolute;
|
|
229
|
+
top: 0;
|
|
230
|
+
left: 0;
|
|
231
|
+
right: 0;
|
|
232
|
+
height: 11px;
|
|
233
|
+
display: flex;
|
|
234
|
+
align-items: center;
|
|
235
|
+
justify-content: center;
|
|
236
|
+
font-size: 7.5px;
|
|
237
|
+
font-weight: 500;
|
|
238
|
+
letter-spacing: 0.12em;
|
|
239
|
+
line-height: 1;
|
|
240
|
+
z-index: 1;
|
|
241
|
+
font-variant-caps: all-petite-caps;
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
.tooltip {
|
|
245
|
+
position: absolute;
|
|
246
|
+
bottom: calc(100% + 6px);
|
|
247
|
+
left: 50%;
|
|
248
|
+
transform: translate(-50%, 2px);
|
|
249
|
+
font-size: 10px;
|
|
250
|
+
line-height: 1.2;
|
|
251
|
+
color: var(--schmancy-sys-color-surface-on);
|
|
252
|
+
background: var(--schmancy-sys-color-surface-containerLowest);
|
|
253
|
+
border: 1px solid var(--schmancy-sys-color-outline);
|
|
254
|
+
padding: 2px 6px;
|
|
255
|
+
border-radius: 3px;
|
|
256
|
+
white-space: nowrap;
|
|
257
|
+
opacity: 0;
|
|
258
|
+
pointer-events: none;
|
|
259
|
+
transition:
|
|
260
|
+
opacity 150ms ease-in-out,
|
|
261
|
+
transform 150ms ease-in-out;
|
|
262
|
+
z-index: 2;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
.tile:hover .tooltip,
|
|
266
|
+
.tile:focus-visible .tooltip {
|
|
267
|
+
opacity: 1;
|
|
268
|
+
transform: translate(-50%, 0);
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
.caption {
|
|
272
|
+
position: absolute;
|
|
273
|
+
top: calc(100% + 6px);
|
|
274
|
+
left: 50%;
|
|
275
|
+
transform: translateX(-50%);
|
|
276
|
+
font-size: 11px;
|
|
277
|
+
line-height: 1.2;
|
|
278
|
+
font-weight: 500;
|
|
279
|
+
white-space: nowrap;
|
|
280
|
+
color: var(--schmancy-sys-color-surface-on);
|
|
281
|
+
font-variant-numeric: tabular-nums;
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
.stack-count {
|
|
285
|
+
position: absolute;
|
|
286
|
+
top: -5px;
|
|
287
|
+
right: -7px;
|
|
288
|
+
min-width: 14px;
|
|
289
|
+
height: 14px;
|
|
290
|
+
padding: 0 4px;
|
|
291
|
+
border-radius: 7px;
|
|
292
|
+
background: var(--schmancy-sys-color-primary-default);
|
|
293
|
+
color: var(--schmancy-sys-color-primary-on);
|
|
294
|
+
font-size: 9px;
|
|
295
|
+
font-weight: 500;
|
|
296
|
+
line-height: 14px;
|
|
297
|
+
text-align: center;
|
|
298
|
+
z-index: 10;
|
|
299
|
+
pointer-events: none;
|
|
300
|
+
transition: opacity 150ms ease-in-out;
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
:host-context([data-fanned]) .stack-count {
|
|
304
|
+
opacity: 0;
|
|
305
|
+
}
|
|
306
|
+
`]
|
|
307
|
+
|
|
308
|
+
@property({ type: String, reflect: true }) state: TimelineTileState = 'empty'
|
|
309
|
+
|
|
310
|
+
@property({ type: String }) glyph = ''
|
|
311
|
+
|
|
312
|
+
@property({ type: Number, attribute: 'stack-count' }) stackCount?: number
|
|
313
|
+
|
|
314
|
+
@property({ type: Number, reflect: true }) index?: number
|
|
315
|
+
|
|
316
|
+
@property({ type: String }) tooltip?: string
|
|
317
|
+
|
|
318
|
+
@property({ type: String }) caption?: string
|
|
319
|
+
|
|
320
|
+
override connectedCallback(): void {
|
|
321
|
+
super.connectedCallback()
|
|
322
|
+
|
|
323
|
+
// Mirror `index` onto the host's `--i` custom property so the
|
|
324
|
+
// fan-offset transforms don't depend on the consumer setting both
|
|
325
|
+
// the prop and an inline style.
|
|
326
|
+
if (this.index !== undefined) {
|
|
327
|
+
this.style.setProperty('--i', String(this.index))
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
// Stack-top owns the fan orchestration. The pointerover stream lives
|
|
331
|
+
// on the parent wrapper (the element holding all sibling tiles); a
|
|
332
|
+
// hover-intent pipe drives the `data-fanned` attribute on that
|
|
333
|
+
// wrapper. Enter is immediate (`of(wrapper)`); leave waits 800ms
|
|
334
|
+
// (`timer(800)`) so the cursor can cross the gap between fanned
|
|
335
|
+
// cards without collapsing the stack. The inner Observable's
|
|
336
|
+
// subscription lifetime IS the fanned state — subscribe sets the
|
|
337
|
+
// attribute, teardown removes it.
|
|
338
|
+
if (this.state !== 'stack-top') return
|
|
339
|
+
const wrapper = this.parentElement
|
|
340
|
+
if (!wrapper) return
|
|
341
|
+
|
|
342
|
+
fromEvent<PointerEvent>(wrapper, 'pointerover')
|
|
343
|
+
.pipe(
|
|
344
|
+
map(
|
|
345
|
+
(e) =>
|
|
346
|
+
(e.target as HTMLElement | null)?.closest<HTMLElement>(
|
|
347
|
+
'[data-stack-id]',
|
|
348
|
+
) ?? null,
|
|
349
|
+
),
|
|
350
|
+
distinctUntilChanged(),
|
|
351
|
+
switchMap((target) =>
|
|
352
|
+
target === wrapper ? of(wrapper) : timer(800).pipe(map(() => null)),
|
|
353
|
+
),
|
|
354
|
+
distinctUntilChanged(),
|
|
355
|
+
switchMap((target) =>
|
|
356
|
+
target
|
|
357
|
+
? new Observable<never>(() => {
|
|
358
|
+
target.setAttribute('data-fanned', '')
|
|
359
|
+
return () => target.removeAttribute('data-fanned')
|
|
360
|
+
})
|
|
361
|
+
: EMPTY,
|
|
362
|
+
),
|
|
363
|
+
takeUntil(this.disconnecting),
|
|
364
|
+
)
|
|
365
|
+
.subscribe()
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
protected override updated(changed: Map<string, unknown>): void {
|
|
369
|
+
super.updated(changed)
|
|
370
|
+
if (changed.has('index') && this.index !== undefined) {
|
|
371
|
+
this.style.setProperty('--i', String(this.index))
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
private _onClick = (): void => {
|
|
376
|
+
if (this.state === 'empty') return
|
|
377
|
+
this.dispatchEvent(
|
|
378
|
+
new CustomEvent<TimelineTileClickEvent['detail']>('tile-click', {
|
|
379
|
+
detail: { glyph: this.glyph, state: this.state },
|
|
380
|
+
bubbles: true,
|
|
381
|
+
composed: true,
|
|
382
|
+
}),
|
|
383
|
+
)
|
|
384
|
+
}
|
|
385
|
+
|
|
386
|
+
private _ariaLabel(): string {
|
|
387
|
+
const parts = [this.glyph]
|
|
388
|
+
if (this.caption) parts.push(this.caption)
|
|
389
|
+
if (this.tooltip) parts.push(this.tooltip)
|
|
390
|
+
if (this.state === 'empty') parts.push('empty')
|
|
391
|
+
return parts.join(' · ')
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
protected override render(): unknown {
|
|
395
|
+
const isInteractive = this.state !== 'empty'
|
|
396
|
+
const ariaLabel = this._ariaLabel()
|
|
397
|
+
return html`
|
|
398
|
+
<button
|
|
399
|
+
type="button"
|
|
400
|
+
class="tile"
|
|
401
|
+
role=${isInteractive ? 'button' : 'presentation'}
|
|
402
|
+
tabindex=${isInteractive ? 0 : -1}
|
|
403
|
+
aria-label=${ariaLabel}
|
|
404
|
+
?disabled=${!isInteractive}
|
|
405
|
+
@click=${this._onClick}
|
|
406
|
+
>
|
|
407
|
+
<span class="glyph">${this.glyph}</span>
|
|
408
|
+
${when(
|
|
409
|
+
this.tooltip && isInteractive,
|
|
410
|
+
() => html`<span class="tooltip">${this.tooltip}</span>`,
|
|
411
|
+
)}
|
|
412
|
+
${when(
|
|
413
|
+
this.caption && this.state !== 'stack-sibling',
|
|
414
|
+
() => html`<span class="caption">${this.caption}</span>`,
|
|
415
|
+
)}
|
|
416
|
+
${when(
|
|
417
|
+
this.state === 'stack-top' &&
|
|
418
|
+
this.stackCount !== undefined &&
|
|
419
|
+
this.stackCount > 1,
|
|
420
|
+
() => html`<span class="stack-count">×${this.stackCount}</span>`,
|
|
421
|
+
)}
|
|
422
|
+
</button>
|
|
423
|
+
`
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
declare global {
|
|
428
|
+
interface HTMLElementTagNameMap {
|
|
429
|
+
'schmancy-timeline-tile': SchmancyTimelineTile
|
|
430
|
+
}
|
|
431
|
+
}
|
package/src/tree/tree.ts
CHANGED
|
@@ -1,28 +1,16 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SchmancyElement } from '@mixins/index'
|
|
2
2
|
import { css, html } from 'lit'
|
|
3
3
|
import { customElement, property, query } from 'lit/decorators.js'
|
|
4
4
|
import { fromEvent, merge, switchMap, takeUntil, tap, zip } from 'rxjs'
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
|
-
* Expandable tree node — a recursive disclosure widget. One root slot, one default slot for child nodes. Each node can itself contain schmancy-tree children.
|
|
8
|
-
*
|
|
9
7
|
* @element schmancy-tree
|
|
10
|
-
* @summary Use for hierarchical navigation / file-explorer layouts. Each level is a schmancy-tree with a `root` slot (the parent label) and default slot (the children, which may be more schmancy-trees).
|
|
11
|
-
* @example
|
|
12
|
-
* <schmancy-tree>
|
|
13
|
-
* <schmancy-list-item slot="root">src/</schmancy-list-item>
|
|
14
|
-
* <schmancy-tree>
|
|
15
|
-
* <schmancy-list-item slot="root">components/</schmancy-list-item>
|
|
16
|
-
* <schmancy-list-item>button.ts</schmancy-list-item>
|
|
17
|
-
* </schmancy-tree>
|
|
18
|
-
* </schmancy-tree>
|
|
19
|
-
* @platform details toggle - Recursive `<details>`-like disclosure. Degrades to a plain nested list if the tag never registers — loses expand/collapse but stays navigable.
|
|
20
8
|
* @slot root - The root element of the tree
|
|
21
9
|
* @slot - The children of the tree
|
|
22
|
-
* @fires toggle - When the root toggler or chevron is clicked. Fires before the open state flips; the host's `open` property reflects the new state on the next animation frame.
|
|
23
10
|
*/
|
|
24
11
|
@customElement('schmancy-tree')
|
|
25
|
-
export class SchmancyTree extends
|
|
12
|
+
export class SchmancyTree extends SchmancyElement {
|
|
13
|
+
static styles = [css`
|
|
26
14
|
:host {
|
|
27
15
|
display: block;
|
|
28
16
|
position: relative;
|
|
@@ -35,7 +23,7 @@ export class SchmancyTree extends TailwindElement(css`
|
|
|
35
23
|
::slotted([slot='root'] + *) {
|
|
36
24
|
margin-top: 0.5rem;
|
|
37
25
|
}
|
|
38
|
-
`
|
|
26
|
+
`];
|
|
39
27
|
/**
|
|
40
28
|
* Whether the tree’s children are visible
|
|
41
29
|
*/
|
package/src/typewriter/index.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './typewriter'
|
|
1
|
+
export * from './typewriter.directive'
|
|
@@ -1,70 +1,19 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { css, html
|
|
1
|
+
import { SchmancyElement } from '@mixins/index'
|
|
2
|
+
import { css, html } from 'lit'
|
|
3
3
|
import { customElement, property } from 'lit/decorators.js'
|
|
4
4
|
import { createRef, ref } from 'lit/directives/ref.js'
|
|
5
|
-
import { html as staticHtml, literal } from 'lit/static-html.js'
|
|
6
5
|
import { fromEvent } from 'rxjs'
|
|
7
6
|
import { filter, tap, takeUntil } from 'rxjs/operators'
|
|
8
7
|
|
|
9
|
-
/**
|
|
10
|
-
* Preset → (type, token) shorthand. Saves the two-decision-per-text-node
|
|
11
|
-
* fatigue that 50+ typography nodes in a single page cause.
|
|
12
|
-
*/
|
|
13
|
-
export type TypographyPreset =
|
|
14
|
-
| 'display' | 'display-lg' | 'display-md' | 'display-sm'
|
|
15
|
-
| 'heading-lg' | 'heading-md' | 'heading-sm'
|
|
16
|
-
| 'title-lg' | 'title-md' | 'title-sm'
|
|
17
|
-
| 'body-lg' | 'body-md' | 'body-sm'
|
|
18
|
-
| 'label-lg' | 'label-md' | 'label-sm'
|
|
19
|
-
| 'caption'
|
|
20
|
-
|
|
21
|
-
const PRESET_MAP: Record<TypographyPreset, { type: string; token: string }> = {
|
|
22
|
-
'display': { type: 'display', token: 'lg' },
|
|
23
|
-
'display-lg': { type: 'display', token: 'lg' },
|
|
24
|
-
'display-md': { type: 'display', token: 'md' },
|
|
25
|
-
'display-sm': { type: 'display', token: 'sm' },
|
|
26
|
-
'heading-lg': { type: 'headline', token: 'lg' },
|
|
27
|
-
'heading-md': { type: 'headline', token: 'md' },
|
|
28
|
-
'heading-sm': { type: 'headline', token: 'sm' },
|
|
29
|
-
'title-lg': { type: 'title', token: 'lg' },
|
|
30
|
-
'title-md': { type: 'title', token: 'md' },
|
|
31
|
-
'title-sm': { type: 'title', token: 'sm' },
|
|
32
|
-
'body-lg': { type: 'body', token: 'lg' },
|
|
33
|
-
'body-md': { type: 'body', token: 'md' },
|
|
34
|
-
'body-sm': { type: 'body', token: 'sm' },
|
|
35
|
-
'label-lg': { type: 'label', token: 'lg' },
|
|
36
|
-
'label-md': { type: 'label', token: 'md' },
|
|
37
|
-
'label-sm': { type: 'label', token: 'sm' },
|
|
38
|
-
'caption': { type: 'label', token: 'sm' },
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Allowed semantic tag names for the `as` prop. Closed enum so we can
|
|
43
|
-
* use `literal` template parts safely with `lit/static-html`.
|
|
44
|
-
*/
|
|
45
|
-
export type TypographyTag = 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6' | 'p' | 'span' | 'div'
|
|
46
|
-
|
|
47
|
-
const TAG_LITERALS: Record<TypographyTag, ReturnType<typeof literal>> = {
|
|
48
|
-
h1: literal`h1`,
|
|
49
|
-
h2: literal`h2`,
|
|
50
|
-
h3: literal`h3`,
|
|
51
|
-
h4: literal`h4`,
|
|
52
|
-
h5: literal`h5`,
|
|
53
|
-
h6: literal`h6`,
|
|
54
|
-
p: literal`p`,
|
|
55
|
-
span: literal`span`,
|
|
56
|
-
div: literal`div`,
|
|
57
|
-
}
|
|
58
|
-
|
|
59
8
|
// Material Design 3 typography - https://m3.material.io/styles/typography/type-scale-tokens
|
|
60
9
|
|
|
61
10
|
/**
|
|
62
11
|
* @element schmancy-typography
|
|
63
12
|
* @slot - The text for the typography.
|
|
64
|
-
* @fires change - When `editable` is true, fires on blur or Enter with `detail.value` set to the new text content. Not fired when `editable` is unset (the default).
|
|
65
13
|
*/
|
|
66
14
|
@customElement('schmancy-typography')
|
|
67
|
-
export class SchmancyTypography extends
|
|
15
|
+
export class SchmancyTypography extends SchmancyElement {
|
|
16
|
+
static styles = [css`
|
|
68
17
|
:host {
|
|
69
18
|
display: block;
|
|
70
19
|
font-family: inherit;
|
|
@@ -340,7 +289,7 @@ export class SchmancyTypography extends TailwindElement(css`
|
|
|
340
289
|
display: block;
|
|
341
290
|
opacity: 0.35;
|
|
342
291
|
}
|
|
343
|
-
`
|
|
292
|
+
`];
|
|
344
293
|
static shadowRootOptions: ShadowRootInit = {
|
|
345
294
|
mode: 'open',
|
|
346
295
|
delegatesFocus: true,
|
|
@@ -354,30 +303,6 @@ export class SchmancyTypography extends TailwindElement(css`
|
|
|
354
303
|
@property({ type: String, reflect: true })
|
|
355
304
|
type: 'display' | 'headline' | 'title' | 'subtitle' | 'body' | 'label' = 'body'
|
|
356
305
|
|
|
357
|
-
/**
|
|
358
|
-
* Shorthand for picking a (type, token) pair in one go. When set, derives
|
|
359
|
-
* `type` and `token` automatically — saves the two-decisions-per-text-node
|
|
360
|
-
* fatigue that hits when a single page has 50+ typography nodes.
|
|
361
|
-
*
|
|
362
|
-
* @attr preset
|
|
363
|
-
* @type {TypographyPreset}
|
|
364
|
-
* @example <schmancy-typography preset="heading-md">Title</schmancy-typography>
|
|
365
|
-
*/
|
|
366
|
-
@property({ type: String, reflect: true })
|
|
367
|
-
preset?: TypographyPreset
|
|
368
|
-
|
|
369
|
-
/**
|
|
370
|
-
* Render the slot wrapped in the requested semantic HTML element so screen
|
|
371
|
-
* readers expose the right role / heading level. Without `as`, the slot
|
|
372
|
-
* sits directly in the shadow root and the host is a generic element.
|
|
373
|
-
*
|
|
374
|
-
* @attr as
|
|
375
|
-
* @type {TypographyTag}
|
|
376
|
-
* @example <schmancy-typography preset="heading-md" as="h2">Section</schmancy-typography>
|
|
377
|
-
*/
|
|
378
|
-
@property({ type: String, reflect: true })
|
|
379
|
-
as?: TypographyTag
|
|
380
|
-
|
|
381
306
|
/**
|
|
382
307
|
* @attr token - The size token.
|
|
383
308
|
* @deprecated Prefer using Tailwind responsive text classes for better responsive design.
|
|
@@ -428,17 +353,6 @@ export class SchmancyTypography extends TailwindElement(css`
|
|
|
428
353
|
|
|
429
354
|
private _editRef = createRef<HTMLDivElement>()
|
|
430
355
|
|
|
431
|
-
protected override willUpdate(changed: PropertyValues): void {
|
|
432
|
-
super.willUpdate?.(changed)
|
|
433
|
-
// `preset` shorthand expands to (type, token) so the existing CSS
|
|
434
|
-
// selectors keep matching without duplicating the size scale.
|
|
435
|
-
if (changed.has('preset') && this.preset && PRESET_MAP[this.preset]) {
|
|
436
|
-
const { type, token } = PRESET_MAP[this.preset]
|
|
437
|
-
this.type = type as typeof this.type
|
|
438
|
-
this.token = token as typeof this.token
|
|
439
|
-
}
|
|
440
|
-
}
|
|
441
|
-
|
|
442
356
|
/** Focus and select all text in editable mode */
|
|
443
357
|
selectAll() {
|
|
444
358
|
const el = this._editRef.value
|
|
@@ -524,13 +438,6 @@ export class SchmancyTypography extends TailwindElement(css`
|
|
|
524
438
|
data-placeholder=${this.placeholder ?? ''}
|
|
525
439
|
></div>`
|
|
526
440
|
}
|
|
527
|
-
// `as` wraps the slot in the requested semantic tag so heading levels
|
|
528
|
-
// land in the accessibility tree. Without `as` the slot is bare and
|
|
529
|
-
// the host element carries the visual styling only.
|
|
530
|
-
if (this.as && TAG_LITERALS[this.as]) {
|
|
531
|
-
const tag = TAG_LITERALS[this.as]
|
|
532
|
-
return staticHtml`<${tag}><slot></slot></${tag}>`
|
|
533
|
-
}
|
|
534
441
|
return html`<slot></slot>`
|
|
535
442
|
}
|
|
536
443
|
}
|
|
@@ -12,7 +12,11 @@ export function intersection$(
|
|
|
12
12
|
}, options)
|
|
13
13
|
|
|
14
14
|
// Observe each element
|
|
15
|
-
Array.isArray(element)
|
|
15
|
+
if (Array.isArray(element)) {
|
|
16
|
+
element.forEach(el => observer.observe(el))
|
|
17
|
+
} else {
|
|
18
|
+
observer.observe(element)
|
|
19
|
+
}
|
|
16
20
|
|
|
17
21
|
// Cleanup on unsubscription
|
|
18
22
|
return () => {
|
package/src/utils/search.ts
CHANGED
|
@@ -286,8 +286,8 @@ function calculateLevenshtein(a: string, b: string, maxDistance = 0): number {
|
|
|
286
286
|
}
|
|
287
287
|
|
|
288
288
|
// Use two rolling arrays instead of full matrix: O(n) space instead of O(n*m)
|
|
289
|
-
let prevRow =
|
|
290
|
-
let currRow =
|
|
289
|
+
let prevRow = Array.from({ length: a.length + 1 }) as number[]
|
|
290
|
+
let currRow = Array.from({ length: a.length + 1 }) as number[]
|
|
291
291
|
|
|
292
292
|
// Initialize first row
|
|
293
293
|
for (let j = 0; j <= a.length; j++) {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SchmancyElement } from '@mixins/index'
|
|
2
2
|
import { css, html } from 'lit'
|
|
3
3
|
import { customElement } from 'lit/decorators.js'
|
|
4
4
|
|
|
@@ -14,7 +14,8 @@ import { customElement } from 'lit/decorators.js'
|
|
|
14
14
|
* @slot - Content hidden from sighted users but exposed to assistive tech.
|
|
15
15
|
*/
|
|
16
16
|
@customElement('schmancy-visually-hidden')
|
|
17
|
-
export class SchmancyVisuallyHidden extends
|
|
17
|
+
export class SchmancyVisuallyHidden extends SchmancyElement {
|
|
18
|
+
static styles = [css`
|
|
18
19
|
:host {
|
|
19
20
|
position: absolute;
|
|
20
21
|
width: 1px;
|
|
@@ -26,7 +27,7 @@ export class SchmancyVisuallyHidden extends TailwindElement(css`
|
|
|
26
27
|
white-space: nowrap;
|
|
27
28
|
border-width: 0;
|
|
28
29
|
}
|
|
29
|
-
`
|
|
30
|
+
`];
|
|
30
31
|
render() {
|
|
31
32
|
return html`<slot></slot>`
|
|
32
33
|
}
|