@mhmo91/schmancy 0.9.4 → 0.9.6
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/.claude-plugin/plugin.json +13 -0
- package/README.md +14 -4
- package/custom-elements.json +493 -718
- package/dist/.claude-plugin/plugin.json +13 -0
- package/dist/animation-Bcwh107v.cjs.map +1 -0
- package/dist/animation-CXKSuUoE.js.map +1 -0
- package/dist/area-BARjKpE9.js +590 -0
- package/dist/area-BARjKpE9.js.map +1 -0
- package/dist/area-D9b9dHQr.cjs +12 -0
- package/dist/area-D9b9dHQr.cjs.map +1 -0
- package/dist/area.cjs +1 -1
- package/dist/area.js +1 -1
- package/dist/audio-C7TzWI8M.js +335 -0
- package/dist/audio-C7TzWI8M.js.map +1 -0
- package/dist/audio-DUVz7Ars.cjs +1 -0
- package/dist/audio-DUVz7Ars.cjs.map +1 -0
- package/dist/audio.cjs +1 -1
- package/dist/audio.js +2 -2
- package/dist/autocomplete-AI2CCJmK.cjs +115 -0
- package/dist/autocomplete-AI2CCJmK.cjs.map +1 -0
- package/dist/autocomplete-DOimwVMP.js +404 -0
- package/dist/autocomplete-DOimwVMP.js.map +1 -0
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/boat-Bk4u-LzT.cjs +80 -0
- package/dist/boat-Bk4u-LzT.cjs.map +1 -0
- package/dist/boat-DrghVeWK.js +347 -0
- package/dist/boat-DrghVeWK.js.map +1 -0
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/breadcrumb.cjs +34 -0
- package/dist/breadcrumb.cjs.map +1 -0
- package/dist/breadcrumb.js +73 -0
- package/dist/breadcrumb.js.map +1 -0
- package/dist/busy-BmFfwyz_.js +168 -0
- package/dist/busy-BmFfwyz_.js.map +1 -0
- package/dist/busy-c_q_F8O0.cjs +134 -0
- package/dist/busy-c_q_F8O0.cjs.map +1 -0
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/button.cjs +4 -4
- package/dist/button.cjs.map +1 -1
- package/dist/button.js +25 -6
- package/dist/button.js.map +1 -1
- package/dist/card-BADJHUMA.js +285 -0
- package/dist/card-BADJHUMA.js.map +1 -0
- package/dist/card-C_E944_Z.cjs +177 -0
- package/dist/card-C_E944_Z.cjs.map +1 -0
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/charts.cjs +3 -3
- package/dist/charts.cjs.map +1 -1
- package/dist/charts.js +2 -2
- package/dist/checkbox-D7rvCrGk.js +629 -0
- package/dist/checkbox-D7rvCrGk.js.map +1 -0
- package/dist/checkbox-ZqDoCagB.cjs +39 -0
- package/dist/checkbox-ZqDoCagB.cjs.map +1 -0
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/chips-Cux635Qs.cjs +253 -0
- package/dist/chips-Cux635Qs.cjs.map +1 -0
- package/dist/chips-vdzIsesI.js +655 -0
- package/dist/chips-vdzIsesI.js.map +1 -0
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +2 -2
- package/dist/code-highlight-C9lKek2p.cjs +190 -0
- package/dist/code-highlight-C9lKek2p.cjs.map +1 -0
- package/dist/code-highlight-D6yruol6.js +291 -0
- package/dist/code-highlight-D6yruol6.js.map +1 -0
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/components-ByRyEzz5.cjs +73 -0
- package/dist/components-ByRyEzz5.cjs.map +1 -0
- package/dist/components-DSvPKR9Q.js +730 -0
- package/dist/components-DSvPKR9Q.js.map +1 -0
- package/dist/components.cjs +1 -1
- package/dist/components.js +1 -1
- package/dist/connectivity.cjs +7 -7
- package/dist/connectivity.cjs.map +1 -1
- package/dist/connectivity.js +5 -4
- package/dist/connectivity.js.map +1 -1
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/cursor-glow-82y5h3E4.cjs +1 -0
- package/dist/cursor-glow-82y5h3E4.cjs.map +1 -0
- package/dist/cursor-glow-C2YRrB8Z.js +46 -0
- package/dist/cursor-glow-C2YRrB8Z.js.map +1 -0
- package/dist/date-range-DJsavigf.cjs +131 -0
- package/dist/date-range-DJsavigf.cjs.map +1 -0
- package/dist/date-range-inline-B87TDYI6.js +267 -0
- package/dist/date-range-inline-B87TDYI6.js.map +1 -0
- package/dist/date-range-inline-De-M0VmL.cjs +43 -0
- package/dist/date-range-inline-De-M0VmL.cjs.map +1 -0
- package/dist/date-range-inline.cjs +1 -1
- package/dist/date-range-inline.js +1 -1
- package/dist/date-range-tEX2Jx2j.js +946 -0
- package/dist/date-range-tEX2Jx2j.js.map +1 -0
- package/dist/date-range.cjs +1 -1
- package/dist/date-range.js +1 -1
- package/dist/delay-BvVdfhAR.cjs +9 -0
- package/dist/delay-BvVdfhAR.cjs.map +1 -0
- package/dist/delay-CZw37zps.js +347 -0
- package/dist/delay-CZw37zps.js.map +1 -0
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/details-Bhz8_whd.cjs +168 -0
- package/dist/details-Bhz8_whd.cjs.map +1 -0
- package/dist/details-D7VTnLOh.js +294 -0
- package/dist/details-D7VTnLOh.js.map +1 -0
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/dialog-service-ClFrOWf4.js +193 -0
- package/dist/dialog-service-ClFrOWf4.js.map +1 -0
- package/dist/dialog-service-DcuAavp2.cjs +1 -0
- package/dist/dialog-service-DcuAavp2.cjs.map +1 -0
- package/dist/dialog.cjs +18 -11
- package/dist/dialog.cjs.map +1 -1
- package/dist/dialog.js +66 -43
- package/dist/dialog.js.map +1 -1
- package/dist/directives.cjs +1 -1
- package/dist/directives.js +5 -5
- package/dist/divider-S0bHwCCS.cjs +57 -0
- package/dist/divider-S0bHwCCS.cjs.map +1 -0
- package/dist/divider-zS232JDr.js +87 -0
- package/dist/divider-zS232JDr.js.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 +8 -7
- package/dist/dropdown.js.map +1 -1
- package/dist/expand-BXt9SqAF.js +337 -0
- package/dist/expand-BXt9SqAF.js.map +1 -0
- package/dist/expand-Dr7TFXpl.cjs +141 -0
- package/dist/expand-Dr7TFXpl.cjs.map +1 -0
- package/dist/expand.cjs +1 -1
- package/dist/expand.js +1 -1
- package/dist/extra-BmZTXAp0.cjs +31 -0
- package/dist/extra-BmZTXAp0.cjs.map +1 -0
- package/dist/extra-COYhsOyZ.js +3435 -0
- package/dist/extra-COYhsOyZ.js.map +1 -0
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/float-CSRW-Rrd.cjs +1 -0
- package/dist/float-CSRW-Rrd.cjs.map +1 -0
- package/dist/float-DCXafWh6.js +5 -0
- package/dist/float-DCXafWh6.js.map +1 -0
- package/dist/float.cjs +1 -1
- package/dist/float.js +1 -1
- package/dist/flow-CqgDEIqK.js.map +1 -0
- package/dist/flow-DSu4PLt1.cjs.map +1 -0
- package/dist/form-CAY9GSCd.cjs +1 -0
- package/dist/form-CAY9GSCd.cjs.map +1 -0
- package/dist/form-D2cJ58TB.js +68 -0
- package/dist/form-D2cJ58TB.js.map +1 -0
- package/dist/form.cjs +1 -1
- package/dist/form.js +2 -1
- package/dist/hashContent-kKvXKFa9.cjs.map +1 -0
- package/dist/hashContent-nD2uWwi2.js.map +1 -0
- package/dist/icons-BbaI9Zf-.js +162 -0
- package/dist/icons-BbaI9Zf-.js.map +1 -0
- package/dist/icons-DPUeLS_Y.cjs +52 -0
- package/dist/icons-DPUeLS_Y.cjs.map +1 -0
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/iframe-CEDOvkql.js +45 -0
- package/dist/iframe-CEDOvkql.js.map +1 -0
- package/dist/iframe-Ct50FYXq.cjs +24 -0
- package/dist/iframe-Ct50FYXq.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 +65 -59
- package/dist/input-DMjpf6V8.cjs +51 -0
- package/dist/input-DMjpf6V8.cjs.map +1 -0
- package/dist/input-Ri72dn5t.js +364 -0
- package/dist/input-Ri72dn5t.js.map +1 -0
- package/dist/input-chip-BhjGVpc3.cjs +146 -0
- package/dist/input-chip-BhjGVpc3.cjs.map +1 -0
- package/dist/input-chip-CI4__N8w.js +305 -0
- package/dist/input-chip-CI4__N8w.js.map +1 -0
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/intersection-D1v1UCVv.cjs.map +1 -0
- package/dist/intersection-LfEsy29T.js.map +1 -0
- package/dist/json.cjs +3 -3
- package/dist/json.cjs.map +1 -1
- package/dist/json.js +5 -4
- package/dist/json.js.map +1 -1
- package/dist/kbd.cjs +28 -0
- package/dist/kbd.cjs.map +1 -0
- package/dist/kbd.js +45 -0
- package/dist/kbd.js.map +1 -0
- package/dist/layout-BE2ld1IY.js +94 -0
- package/dist/layout-BE2ld1IY.js.map +1 -0
- package/dist/layout-D7xOqMkJ.cjs +17 -0
- package/dist/layout-D7xOqMkJ.cjs.map +1 -0
- package/dist/layout-PZCF3kwl.cjs +1 -0
- package/dist/layout-PZCF3kwl.cjs.map +1 -0
- package/dist/layout-uAQpJN31.js +268 -0
- package/dist/layout-uAQpJN31.js.map +1 -0
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +2 -2
- package/dist/lightbox-C0OEHns9.js +679 -0
- package/dist/lightbox-C0OEHns9.js.map +1 -0
- package/dist/lightbox-cXRnvHMN.cjs +202 -0
- package/dist/lightbox-cXRnvHMN.cjs.map +1 -0
- package/dist/lightbox.cjs +1 -1
- package/dist/lightbox.js +1 -1
- package/dist/list-CmJ5h35b.cjs +40 -0
- package/dist/list-CmJ5h35b.cjs.map +1 -0
- package/dist/list-d1mHar5p.js +106 -0
- package/dist/list-d1mHar5p.js.map +1 -0
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/litElement.mixin-Bj2q1yPw.cjs +1 -0
- package/dist/litElement.mixin-Bj2q1yPw.cjs.map +1 -0
- package/dist/litElement.mixin-CncaUoxz.js +12 -0
- package/dist/litElement.mixin-CncaUoxz.js.map +1 -0
- package/dist/magnetic-Dj52WplI.js +47 -0
- package/dist/magnetic-Dj52WplI.js.map +1 -0
- package/dist/magnetic-aBBnj_vk.cjs +1 -0
- package/dist/magnetic-aBBnj_vk.cjs.map +1 -0
- package/dist/mailbox-BmChskZc.cjs +1142 -0
- package/dist/mailbox-BmChskZc.cjs.map +1 -0
- package/dist/mailbox-C4-E93be.js +1585 -0
- package/dist/mailbox-C4-E93be.js.map +1 -0
- package/dist/mailbox.cjs +1 -1
- package/dist/mailbox.js +1 -1
- package/dist/map-DHyYLhvy.js +206 -0
- package/dist/map-DHyYLhvy.js.map +1 -0
- package/dist/map-DYEvlNl0.cjs +80 -0
- package/dist/map-DYEvlNl0.cjs.map +1 -0
- package/dist/map.cjs +1 -1
- package/dist/map.js +1 -1
- package/dist/menu-BlPTI6H9.cjs +23 -0
- package/dist/menu-BlPTI6H9.cjs.map +1 -0
- package/dist/menu-DFDBADp4.js +51 -0
- package/dist/menu-DFDBADp4.js.map +1 -0
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/mixins.cjs +1 -1
- package/dist/mixins.cjs.map +1 -1
- package/dist/mixins.js +43 -15
- package/dist/mixins.js.map +1 -1
- package/dist/nav-drawer.cjs +1 -1
- package/dist/nav-drawer.js +1 -1
- 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 +2 -2
- package/dist/notification-DGpv8g2H.js +304 -0
- package/dist/notification-DGpv8g2H.js.map +1 -0
- package/dist/notification-DKVWYhqs.cjs +23 -0
- package/dist/notification-DKVWYhqs.cjs.map +1 -0
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/option-BD2eh458.js +98 -0
- package/dist/option-BD2eh458.js.map +1 -0
- package/dist/option-LtSDy2xf.cjs +43 -0
- package/dist/option-LtSDy2xf.cjs.map +1 -0
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/overlay-stack-CEYGD9T1.cjs.map +1 -0
- package/dist/overlay-stack-Ca4EK2Mu.js.map +1 -0
- package/dist/page.cjs +2 -2
- package/dist/page.cjs.map +1 -1
- package/dist/page.js +5 -5
- package/dist/progress-B5ChDPbB.cjs +51 -0
- package/dist/progress-B5ChDPbB.cjs.map +1 -0
- package/dist/progress-CE1Pk2hi.js +128 -0
- package/dist/progress-CE1Pk2hi.js.map +1 -0
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/provide-BZ9lq_Be.cjs +1 -0
- package/dist/provide-BZ9lq_Be.cjs.map +1 -0
- package/dist/provide-jn1Fj1vv.js +107 -0
- package/dist/provide-jn1Fj1vv.js.map +1 -0
- package/dist/qr-scanner.cjs +2 -2
- package/dist/qr-scanner.cjs.map +1 -1
- package/dist/qr-scanner.js +2 -2
- package/dist/radio-group-Cd9pZ2MR.cjs +40 -0
- package/dist/radio-group-Cd9pZ2MR.cjs.map +1 -0
- package/dist/radio-group-CyRHgIF3.js +106 -0
- package/dist/radio-group-CyRHgIF3.js.map +1 -0
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/range.cjs +4 -4
- package/dist/range.cjs.map +1 -1
- package/dist/range.js +4 -3
- package/dist/range.js.map +1 -1
- package/dist/reduced-motion-B83yZbcO.js.map +1 -0
- package/dist/reduced-motion-DR32yKEO.cjs.map +1 -0
- package/dist/rxjs-utils-Bldch1RO.js.map +1 -0
- package/dist/rxjs-utils-hAgKC7vk.cjs.map +1 -0
- package/dist/rxjs-utils.cjs +1 -1
- package/dist/rxjs-utils.js +1 -1
- package/dist/scroll-C_iNOi7E.cjs +26 -0
- package/dist/scroll-C_iNOi7E.cjs.map +1 -0
- package/dist/scroll-DoliwpRu.js +113 -0
- package/dist/scroll-DoliwpRu.js.map +1 -0
- package/dist/search-BlGJ6uJv.js.map +1 -0
- package/dist/search-C8eAOzBm.cjs.map +1 -0
- package/dist/select-CWWuZ2iJ.cjs +56 -0
- package/dist/select-CWWuZ2iJ.cjs.map +1 -0
- package/dist/select-_vHPXi30.js +305 -0
- package/dist/select-_vHPXi30.js.map +1 -0
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/sheet-i1KtxGIj.js +168 -0
- package/dist/sheet-i1KtxGIj.js.map +1 -0
- package/dist/sheet-r0oEYIdi.cjs +35 -0
- package/dist/sheet-r0oEYIdi.cjs.map +1 -0
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +2 -2
- package/dist/sheet.service-Cr13Oo6G.cjs +1 -0
- package/dist/sheet.service-Cr13Oo6G.cjs.map +1 -0
- package/dist/sheet.service-DUO5_kmI.js +86 -0
- package/dist/sheet.service-DUO5_kmI.js.map +1 -0
- package/dist/skeleton.cjs +33 -0
- package/dist/skeleton.cjs.map +1 -0
- package/dist/skeleton.js +58 -0
- package/dist/skeleton.js.map +1 -0
- package/dist/skills/INDEX.md +73 -0
- package/dist/skills/SKILL.md +120 -0
- package/dist/skills/breadcrumb.md +53 -0
- package/dist/skills/kbd.md +40 -0
- package/dist/skills/schmancy/INDEX.md +73 -0
- package/dist/skills/schmancy/SKILL.md +120 -0
- package/dist/skills/schmancy/breadcrumb.md +53 -0
- package/dist/skills/schmancy/kbd.md +40 -0
- package/dist/skills/schmancy/skeleton.md +40 -0
- package/dist/skills/schmancy/splash-screen.md +60 -0
- package/dist/skills/schmancy/switch.md +58 -0
- package/dist/skills/schmancy/tooltip.md +38 -0
- package/dist/skills/schmancy/visually-hidden.md +41 -0
- package/dist/skills/skeleton.md +40 -0
- package/dist/skills/splash-screen.md +60 -0
- package/dist/skills/switch.md +58 -0
- package/dist/skills/tooltip.md +38 -0
- package/dist/skills/visually-hidden.md +41 -0
- package/dist/slider.cjs +3 -3
- package/dist/slider.cjs.map +1 -1
- package/dist/slider.js +2 -2
- package/dist/sound.service-BjSoGjmT.cjs +1 -0
- package/dist/sound.service-BjSoGjmT.cjs.map +1 -0
- package/dist/sound.service-cdkw3Wkv.js +2353 -0
- package/dist/sound.service-cdkw3Wkv.js.map +1 -0
- package/dist/splash-screen-CquyPP1C.cjs +41 -0
- package/dist/splash-screen-CquyPP1C.cjs.map +1 -0
- package/dist/splash-screen-CvucPkpD.js +83 -0
- package/dist/splash-screen-CvucPkpD.js.map +1 -0
- package/dist/splash-screen.cjs +1 -0
- package/dist/splash-screen.js +1 -0
- package/dist/src-Bemk2C2P.cjs +269 -0
- package/dist/src-Bemk2C2P.cjs.map +1 -0
- package/dist/src-f5a3W9Mj.js +1251 -0
- package/dist/src-f5a3W9Mj.js.map +1 -0
- package/dist/steps.cjs +10 -10
- package/dist/steps.cjs.map +1 -1
- package/dist/steps.js +10 -9
- package/dist/steps.js.map +1 -1
- package/dist/store-Bmj6rvZY.js.map +1 -0
- package/dist/store-CO4nJyGj.cjs.map +1 -0
- package/dist/store.cjs +1 -1
- package/dist/store.js +1 -1
- package/dist/surface-CDufon40.cjs +7 -0
- package/dist/surface-CDufon40.cjs.map +1 -0
- package/dist/surface-CkEYJCae.js +22 -0
- package/dist/surface-CkEYJCae.js.map +1 -0
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/surface.mixin-CSKqQH-0.cjs +297 -0
- package/dist/surface.mixin-CSKqQH-0.cjs.map +1 -0
- package/dist/surface.mixin-DqMwoddO.js +320 -0
- package/dist/surface.mixin-DqMwoddO.js.map +1 -0
- package/dist/switch.cjs +69 -0
- package/dist/switch.cjs.map +1 -0
- package/dist/switch.js +132 -0
- package/dist/switch.js.map +1 -0
- package/dist/table-DWc1mkpj.cjs +63 -0
- package/dist/table-DWc1mkpj.cjs.map +1 -0
- package/dist/table-P6VGG7NK.js +631 -0
- package/dist/table-P6VGG7NK.js.map +1 -0
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/tabs-CjGjGrqY.js +126 -0
- package/dist/tabs-CjGjGrqY.js.map +1 -0
- package/dist/tabs-DGJEKuhC.cjs +31 -0
- package/dist/tabs-DGJEKuhC.cjs.map +1 -0
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-Cpa-VnnX.cjs +2 -0
- package/dist/tailwind.mixin-Cpa-VnnX.cjs.map +1 -0
- package/dist/tailwind.mixin-DufHBjmb.js +219 -0
- package/dist/tailwind.mixin-DufHBjmb.js.map +1 -0
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/textarea-DZT_Ofp5.js +209 -0
- package/dist/textarea-DZT_Ofp5.js.map +1 -0
- package/dist/textarea-jmTOXrzl.cjs +39 -0
- package/dist/textarea-jmTOXrzl.cjs.map +1 -0
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/theme-CCKqaksQ.cjs +181 -0
- package/dist/theme-CCKqaksQ.cjs.map +1 -0
- package/dist/theme-CEc32pAv.js +4122 -0
- package/dist/theme-CEc32pAv.js.map +1 -0
- package/dist/theme-button-BsJcv-Zv.cjs +8 -0
- package/dist/theme-button-BsJcv-Zv.cjs.map +1 -0
- package/dist/theme-button-dOiAvdKU.js +20 -0
- package/dist/theme-button-dOiAvdKU.js.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-Bw3mYjUA.js.map +1 -0
- package/dist/theme.events-EznKK2Y0.cjs.map +1 -0
- package/dist/theme.interface-CM26m9te.cjs.map +1 -0
- package/dist/theme.interface-FAUIgbIq.js.map +1 -0
- package/dist/theme.js +5 -5
- package/dist/theme.service-ETiKUwVy.cjs +1 -0
- package/dist/theme.service-ETiKUwVy.cjs.map +1 -0
- package/dist/theme.service-_qP5WvB9.js +108 -0
- package/dist/theme.service-_qP5WvB9.js.map +1 -0
- package/dist/tooltip.cjs +1 -6
- package/dist/tooltip.cjs.map +1 -1
- package/dist/tooltip.js +51 -135
- package/dist/tooltip.js.map +1 -1
- package/dist/tree.cjs +14 -5
- package/dist/tree.cjs.map +1 -1
- package/dist/tree.js +28 -6
- package/dist/tree.js.map +1 -1
- package/dist/tslib.es6-Bd-92OW3.cjs +1 -0
- package/dist/tslib.es6-Bd-92OW3.cjs.map +1 -0
- package/dist/tslib.es6-CI1onEZb.js +7 -0
- package/dist/tslib.es6-CI1onEZb.js.map +1 -0
- package/dist/typewriter-ByIL2Mh-.cjs +123 -0
- package/dist/typewriter-ByIL2Mh-.cjs.map +1 -0
- package/dist/typewriter-vOQ3bDLb.js +701 -0
- package/dist/typewriter-vOQ3bDLb.js.map +1 -0
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/typography.cjs +4 -4
- package/dist/typography.cjs.map +1 -1
- package/dist/typography.js +10 -9
- package/dist/typography.js.map +1 -1
- package/dist/utils-Cq0m3LYo.js +259 -0
- package/dist/utils-Cq0m3LYo.js.map +1 -0
- package/dist/utils-D2kE-6zc.cjs +1 -0
- package/dist/utils-D2kE-6zc.cjs.map +1 -0
- package/dist/utils.cjs +1 -1
- package/dist/utils.js +5 -5
- package/dist/visually-hidden.cjs +13 -0
- package/dist/visually-hidden.cjs.map +1 -0
- package/dist/visually-hidden.js +24 -0
- package/dist/visually-hidden.js.map +1 -0
- package/dist/window-BS7ZQjgH.cjs +59 -0
- package/dist/window-BS7ZQjgH.cjs.map +1 -0
- package/dist/window-WnAihpsA.js +548 -0
- package/dist/window-WnAihpsA.js.map +1 -0
- package/dist/window.cjs +1 -1
- package/dist/window.js +1 -1
- package/mixins/formField.mixin.ts +96 -69
- package/mixins/tailwind.css +11 -0
- package/package.json +19 -28
- package/skills/schmancy/INDEX.md +73 -0
- package/skills/schmancy/SKILL.md +120 -0
- package/skills/schmancy/animation.md +64 -0
- package/skills/schmancy/area.md +141 -0
- package/skills/schmancy/audio.md +69 -0
- package/skills/schmancy/autocomplete.md +53 -0
- package/skills/schmancy/avatar.md +47 -0
- package/skills/schmancy/badge.md +41 -0
- package/skills/schmancy/boat.md +47 -0
- package/skills/schmancy/breadcrumb.md +53 -0
- package/skills/schmancy/busy.md +36 -0
- package/skills/schmancy/button.md +59 -0
- package/skills/schmancy/card.md +53 -0
- package/skills/schmancy/charts.md +93 -0
- package/skills/schmancy/checkbox.md +36 -0
- package/skills/schmancy/chips.md +87 -0
- package/skills/schmancy/code-highlight.md +47 -0
- package/skills/schmancy/connectivity.md +36 -0
- package/skills/schmancy/content-drawer.md +65 -0
- package/skills/schmancy/date-range-inline.md +44 -0
- package/skills/schmancy/date-range.md +50 -0
- package/skills/schmancy/delay.md +50 -0
- package/skills/schmancy/details.md +66 -0
- package/skills/schmancy/dialog.md +69 -0
- package/skills/schmancy/directives.md +298 -0
- package/skills/schmancy/discovery.md +67 -0
- package/skills/schmancy/divider.md +31 -0
- package/skills/schmancy/dropdown.md +47 -0
- package/skills/schmancy/expand.md +63 -0
- package/skills/schmancy/extra.md +59 -0
- package/skills/schmancy/float.md +14 -0
- package/skills/schmancy/form.md +49 -0
- package/skills/schmancy/icons.md +44 -0
- package/skills/schmancy/iframe.md +44 -0
- package/skills/schmancy/input.md +56 -0
- package/skills/schmancy/json.md +33 -0
- package/skills/schmancy/kbd.md +40 -0
- package/skills/schmancy/layout.md +63 -0
- package/skills/schmancy/lightbox.md +36 -0
- package/skills/schmancy/list.md +67 -0
- package/skills/schmancy/mailbox.md +102 -0
- package/skills/schmancy/map.md +55 -0
- package/skills/schmancy/menu.md +39 -0
- package/skills/schmancy/mixins.md +99 -0
- package/skills/schmancy/nav-drawer.md +52 -0
- package/skills/schmancy/navigation-bar.md +48 -0
- package/skills/schmancy/navigation-rail.md +62 -0
- package/skills/schmancy/notification.md +60 -0
- package/skills/schmancy/option.md +43 -0
- package/skills/schmancy/page.md +42 -0
- package/skills/schmancy/progress.md +30 -0
- package/skills/schmancy/qr-scanner.md +51 -0
- package/skills/schmancy/radio-group.md +50 -0
- package/skills/schmancy/range.md +47 -0
- package/skills/schmancy/rxjs-utils.md +60 -0
- package/skills/schmancy/select.md +49 -0
- package/skills/schmancy/sheet.md +76 -0
- package/skills/schmancy/skeleton.md +40 -0
- package/skills/schmancy/slider.md +43 -0
- package/skills/schmancy/splash-screen.md +60 -0
- package/skills/schmancy/steps.md +53 -0
- package/skills/schmancy/store.md +126 -0
- package/skills/schmancy/surface.md +86 -0
- package/skills/schmancy/switch.md +58 -0
- package/skills/schmancy/table.md +60 -0
- package/skills/schmancy/tabs.md +49 -0
- package/skills/schmancy/teleport.md +55 -0
- package/skills/schmancy/textarea.md +48 -0
- package/skills/schmancy/theme-button.md +26 -0
- package/skills/schmancy/theme.md +58 -0
- package/skills/schmancy/tooltip.md +38 -0
- package/skills/schmancy/tree.md +53 -0
- package/skills/schmancy/typewriter.md +46 -0
- package/skills/schmancy/typography.md +53 -0
- package/skills/schmancy/utils.md +95 -0
- package/skills/schmancy/visually-hidden.md +41 -0
- package/skills/schmancy/window.md +67 -0
- package/src/audio/emotional-sounds.ts +2 -4
- package/src/autocomplete/autocomplete.ts +52 -2
- package/src/breadcrumb/breadcrumb.ts +109 -0
- package/src/breadcrumb/index.ts +1 -0
- package/src/button/button.ts +40 -0
- package/src/button/icon-button.ts +2 -1
- package/src/checkbox/checkbox.test.ts +113 -0
- package/src/checkbox/checkbox.ts +41 -1
- package/src/chips/filter-chip.ts +15 -0
- package/src/chips/input-chip.ts +7 -0
- package/src/date-range/date-range-helpers.ts +0 -71
- package/src/dialog/dialog-base.mixin.ts +11 -0
- package/src/dialog/dialog.component.ts +28 -8
- package/src/dropdown/dropdown-content.ts +3 -1
- package/src/form/form.test.ts +137 -0
- package/src/form/form.ts +142 -158
- package/src/form/index.ts +2 -2
- package/src/icons/icon.ts +1 -0
- package/src/index.ts +6 -0
- package/src/kbd/index.ts +1 -0
- package/src/kbd/kbd.ts +59 -0
- package/src/skeleton/index.ts +1 -0
- package/src/skeleton/skeleton.ts +78 -0
- package/src/splash-screen/index.ts +1 -0
- package/src/splash-screen/splash-screen.ts +154 -0
- package/src/switch/index.ts +1 -0
- package/src/switch/switch.test.ts +93 -0
- package/src/switch/switch.ts +180 -0
- package/src/test-utils/a11y.ts +35 -0
- package/src/textarea/textarea.ts +32 -2
- package/src/tooltip/index.ts +1 -2
- package/src/tree/tree.ts +27 -2
- package/src/visually-hidden/index.ts +1 -0
- package/src/visually-hidden/visually-hidden.ts +39 -0
- package/src/window/window-position.ts +1 -74
- package/types/mixins/formField.mixin.d.ts +15 -8
- package/types/src/audio/emotional-sounds.d.ts +0 -2
- package/types/src/autocomplete/autocomplete.d.ts +7 -0
- package/types/src/breadcrumb/breadcrumb.d.ts +38 -0
- package/types/src/breadcrumb/index.d.ts +1 -0
- package/types/src/button/button.d.ts +7 -0
- package/types/src/button/icon-button.d.ts +2 -1
- package/types/src/checkbox/checkbox.d.ts +6 -0
- package/types/src/checkbox/checkbox.test.d.ts +1 -0
- package/types/src/chips/filter-chip.d.ts +3 -0
- package/types/src/chips/input-chip.d.ts +1 -0
- package/types/src/date-range/date-range-helpers.d.ts +0 -12
- package/types/src/dialog/dialog.component.d.ts +6 -0
- package/types/src/dropdown/dropdown-content.d.ts +3 -1
- package/types/src/form/form-v2.d.ts +12 -63
- package/types/src/form/form.d.ts +58 -40
- package/types/src/form/form.test.d.ts +4 -0
- package/types/src/form/index.d.ts +1 -1
- package/types/src/icons/icon.d.ts +1 -0
- package/types/src/index.d.ts +6 -0
- package/types/src/kbd/index.d.ts +1 -0
- package/types/src/kbd/kbd.d.ts +25 -0
- package/types/src/skeleton/index.d.ts +1 -0
- package/types/src/skeleton/skeleton.d.ts +27 -0
- package/types/src/splash-screen/index.d.ts +1 -0
- package/types/src/splash-screen/splash-screen.d.ts +60 -0
- package/types/src/switch/index.d.ts +1 -0
- package/types/src/switch/switch.d.ts +54 -0
- package/types/src/switch/switch.test.d.ts +1 -0
- package/types/src/test-utils/a11y.d.ts +11 -0
- package/types/src/textarea/textarea.d.ts +5 -1
- package/types/src/tooltip/index.d.ts +0 -1
- package/types/src/tree/tree.d.ts +5 -0
- package/types/src/visually-hidden/index.d.ts +1 -0
- package/types/src/visually-hidden/visually-hidden.d.ts +21 -0
- package/types/src/window/window-position.d.ts +1 -35
- package/ai/INDEX.md +0 -72
- package/ai/tooltip.md +0 -38
- package/dist/ai/INDEX.md +0 -72
- package/dist/ai/tooltip.md +0 -38
- package/dist/animation-BK-8BwY8.js.map +0 -1
- package/dist/animation-CO_Csq84.cjs.map +0 -1
- package/dist/area-CRoGqD_u.js +0 -590
- package/dist/area-CRoGqD_u.js.map +0 -1
- package/dist/area-JPykB7A9.cjs +0 -12
- package/dist/area-JPykB7A9.cjs.map +0 -1
- package/dist/audio-DtYYgzYD.cjs +0 -1
- package/dist/audio-DtYYgzYD.cjs.map +0 -1
- package/dist/audio-kz8UgPTO.js +0 -335
- package/dist/audio-kz8UgPTO.js.map +0 -1
- package/dist/autocomplete-5rVhbieU.cjs +0 -111
- package/dist/autocomplete-5rVhbieU.cjs.map +0 -1
- package/dist/autocomplete-BllPQwr8.js +0 -378
- package/dist/autocomplete-BllPQwr8.js.map +0 -1
- package/dist/boat-BDTQ-du9.js +0 -347
- package/dist/boat-BDTQ-du9.js.map +0 -1
- package/dist/boat-DYEAZ8Qj.cjs +0 -80
- package/dist/boat-DYEAZ8Qj.cjs.map +0 -1
- package/dist/busy-ChDAeaKF.js +0 -167
- package/dist/busy-ChDAeaKF.js.map +0 -1
- package/dist/busy-Dj7Xn0Z0.cjs +0 -134
- package/dist/busy-Dj7Xn0Z0.cjs.map +0 -1
- package/dist/card-BvPWVEJX.cjs +0 -177
- package/dist/card-BvPWVEJX.cjs.map +0 -1
- package/dist/card-DZFPRPqs.js +0 -284
- package/dist/card-DZFPRPqs.js.map +0 -1
- package/dist/checkbox-BC_37rsG.cjs +0 -39
- package/dist/checkbox-BC_37rsG.cjs.map +0 -1
- package/dist/checkbox-GSSjqo6w.js +0 -610
- package/dist/checkbox-GSSjqo6w.js.map +0 -1
- package/dist/chips-B19XS8Xc.cjs +0 -253
- package/dist/chips-B19XS8Xc.cjs.map +0 -1
- package/dist/chips-B9oAEfE_.js +0 -645
- package/dist/chips-B9oAEfE_.js.map +0 -1
- package/dist/code-highlight-DCk5lJY-.js +0 -290
- package/dist/code-highlight-DCk5lJY-.js.map +0 -1
- package/dist/code-highlight-fSLrlgOb.cjs +0 -190
- package/dist/code-highlight-fSLrlgOb.cjs.map +0 -1
- package/dist/components-COsM6sJZ.js +0 -730
- package/dist/components-COsM6sJZ.js.map +0 -1
- package/dist/components-CyD6a7gQ.cjs +0 -73
- package/dist/components-CyD6a7gQ.cjs.map +0 -1
- package/dist/cursor-glow-Ah7VXSj7.js +0 -46
- package/dist/cursor-glow-Ah7VXSj7.js.map +0 -1
- package/dist/cursor-glow-DtSy_PJd.cjs +0 -1
- package/dist/cursor-glow-DtSy_PJd.cjs.map +0 -1
- package/dist/date-range-Sfyco9-n.js +0 -946
- package/dist/date-range-Sfyco9-n.js.map +0 -1
- package/dist/date-range-ZAaQB22I.cjs +0 -131
- package/dist/date-range-ZAaQB22I.cjs.map +0 -1
- package/dist/date-range-inline-Bl8qbiQF.js +0 -267
- package/dist/date-range-inline-Bl8qbiQF.js.map +0 -1
- package/dist/date-range-inline-m7nLjOMI.cjs +0 -43
- package/dist/date-range-inline-m7nLjOMI.cjs.map +0 -1
- package/dist/delay-7boauN6N.cjs +0 -9
- package/dist/delay-7boauN6N.cjs.map +0 -1
- package/dist/delay-CgX6m0HN.js +0 -346
- package/dist/delay-CgX6m0HN.js.map +0 -1
- package/dist/details-BHnk8l4q.cjs +0 -168
- package/dist/details-BHnk8l4q.cjs.map +0 -1
- package/dist/details-BPkUg8Cq.js +0 -293
- package/dist/details-BPkUg8Cq.js.map +0 -1
- package/dist/dialog-service-NZEvyEK-.js +0 -193
- package/dist/dialog-service-NZEvyEK-.js.map +0 -1
- package/dist/dialog-service-VnW4gkmE.cjs +0 -1
- package/dist/dialog-service-VnW4gkmE.cjs.map +0 -1
- package/dist/divider-CW9a7MMj.js +0 -87
- package/dist/divider-CW9a7MMj.js.map +0 -1
- package/dist/divider-_khrhrZo.cjs +0 -57
- package/dist/divider-_khrhrZo.cjs.map +0 -1
- package/dist/expand-Cp7-PH8b.cjs +0 -141
- package/dist/expand-Cp7-PH8b.cjs.map +0 -1
- package/dist/expand-iQ7EOMP7.js +0 -336
- package/dist/expand-iQ7EOMP7.js.map +0 -1
- package/dist/extra-IKAiJJhv.cjs +0 -31
- package/dist/extra-IKAiJJhv.cjs.map +0 -1
- package/dist/extra-wEpvEFbK.js +0 -3435
- package/dist/extra-wEpvEFbK.js.map +0 -1
- package/dist/float-BQ_urmMs.js +0 -5
- package/dist/float-BQ_urmMs.js.map +0 -1
- package/dist/float-D5rNC82i.cjs +0 -1
- package/dist/float-D5rNC82i.cjs.map +0 -1
- package/dist/flow-Bbwn6dRN.cjs.map +0 -1
- package/dist/flow-CUj0fDT_.js.map +0 -1
- package/dist/form-BqN1AGFj.cjs +0 -1
- package/dist/form-BqN1AGFj.cjs.map +0 -1
- package/dist/form-CajC5HnO.js +0 -270
- package/dist/form-CajC5HnO.js.map +0 -1
- package/dist/hashContent-DYM21p6t.js.map +0 -1
- package/dist/hashContent-DaeGmY-p.cjs.map +0 -1
- package/dist/icons-B57_93VV.cjs +0 -52
- package/dist/icons-B57_93VV.cjs.map +0 -1
- package/dist/icons-BDqiGXrO.js +0 -161
- package/dist/icons-BDqiGXrO.js.map +0 -1
- package/dist/iframe-DNHL3GIk.cjs +0 -24
- package/dist/iframe-DNHL3GIk.cjs.map +0 -1
- package/dist/iframe-WnWPIrBG.js +0 -44
- package/dist/iframe-WnWPIrBG.js.map +0 -1
- package/dist/input-BiSrTcrR.cjs +0 -51
- package/dist/input-BiSrTcrR.cjs.map +0 -1
- package/dist/input-VaXHFrRn.js +0 -364
- package/dist/input-VaXHFrRn.js.map +0 -1
- package/dist/input-chip-Dy-AiP55.cjs +0 -146
- package/dist/input-chip-Dy-AiP55.cjs.map +0 -1
- package/dist/input-chip-QejNcRnS.js +0 -301
- package/dist/input-chip-QejNcRnS.js.map +0 -1
- package/dist/intersection-BPLpqYEd.js.map +0 -1
- package/dist/intersection-CZpaIHeT.cjs.map +0 -1
- package/dist/layout-4C-6_cre.cjs +0 -1
- package/dist/layout-4C-6_cre.cjs.map +0 -1
- package/dist/layout-CnsXeCAy.js +0 -267
- package/dist/layout-CnsXeCAy.js.map +0 -1
- package/dist/layout-DNYG3phx.cjs +0 -17
- package/dist/layout-DNYG3phx.cjs.map +0 -1
- package/dist/layout-yxSlLybo.js +0 -94
- package/dist/layout-yxSlLybo.js.map +0 -1
- package/dist/lightbox-BrI1Z31s.js +0 -678
- package/dist/lightbox-BrI1Z31s.js.map +0 -1
- package/dist/lightbox-CmACf0t5.cjs +0 -202
- package/dist/lightbox-CmACf0t5.cjs.map +0 -1
- package/dist/list-Cm-jjXxM.js +0 -105
- package/dist/list-Cm-jjXxM.js.map +0 -1
- package/dist/list-swIL9VDv.cjs +0 -40
- package/dist/list-swIL9VDv.cjs.map +0 -1
- package/dist/litElement.mixin-3llHwB-8.cjs +0 -1
- package/dist/litElement.mixin-3llHwB-8.cjs.map +0 -1
- package/dist/litElement.mixin-6jJYHCrZ.js +0 -12
- package/dist/litElement.mixin-6jJYHCrZ.js.map +0 -1
- package/dist/magnetic-BZGFxAWG.js +0 -47
- package/dist/magnetic-BZGFxAWG.js.map +0 -1
- package/dist/magnetic-Dux4QwO4.cjs +0 -1
- package/dist/magnetic-Dux4QwO4.cjs.map +0 -1
- package/dist/mailbox-BuvsVaAQ.js +0 -1584
- package/dist/mailbox-BuvsVaAQ.js.map +0 -1
- package/dist/mailbox-D6LkQcN5.cjs +0 -1142
- package/dist/mailbox-D6LkQcN5.cjs.map +0 -1
- package/dist/map-CQiKAxC3.js +0 -205
- package/dist/map-CQiKAxC3.js.map +0 -1
- package/dist/map-D5NN4VET.cjs +0 -80
- package/dist/map-D5NN4VET.cjs.map +0 -1
- package/dist/menu-C1x04YZw.js +0 -51
- package/dist/menu-C1x04YZw.js.map +0 -1
- package/dist/menu-CkgMO9K5.cjs +0 -23
- package/dist/menu-CkgMO9K5.cjs.map +0 -1
- package/dist/notification-BnBgxjF-.js +0 -304
- package/dist/notification-BnBgxjF-.js.map +0 -1
- package/dist/notification-CZFEhWxc.cjs +0 -23
- package/dist/notification-CZFEhWxc.cjs.map +0 -1
- package/dist/option-BrxCVwSx.cjs +0 -43
- package/dist/option-BrxCVwSx.cjs.map +0 -1
- package/dist/option-DBO8xZwd.js +0 -97
- package/dist/option-DBO8xZwd.js.map +0 -1
- package/dist/overlay-stack-DQey9Qph.cjs.map +0 -1
- package/dist/overlay-stack-DT1SdaGW.js.map +0 -1
- package/dist/progress-Db2e4_Zd.cjs +0 -51
- package/dist/progress-Db2e4_Zd.cjs.map +0 -1
- package/dist/progress-DeiHxXo7.js +0 -128
- package/dist/progress-DeiHxXo7.js.map +0 -1
- package/dist/provide-C1aQhxYo.js +0 -107
- package/dist/provide-C1aQhxYo.js.map +0 -1
- package/dist/provide-DHnhQtCH.cjs +0 -1
- package/dist/provide-DHnhQtCH.cjs.map +0 -1
- package/dist/radio-group-Cspwd-Vw.cjs +0 -40
- package/dist/radio-group-Cspwd-Vw.cjs.map +0 -1
- package/dist/radio-group-zSO0AkJf.js +0 -105
- package/dist/radio-group-zSO0AkJf.js.map +0 -1
- package/dist/reduced-motion-D-L12p7G.js.map +0 -1
- package/dist/reduced-motion-Ds05GPyz.cjs.map +0 -1
- package/dist/rxjs-utils-BSjmI9-Q.js.map +0 -1
- package/dist/rxjs-utils-DCsfzeap.cjs.map +0 -1
- package/dist/scroll-QMCmbbDv.cjs +0 -26
- package/dist/scroll-QMCmbbDv.cjs.map +0 -1
- package/dist/scroll-cBDzye64.js +0 -112
- package/dist/scroll-cBDzye64.js.map +0 -1
- package/dist/search-C4dFHYbX.js.map +0 -1
- package/dist/search-Ds8tt7Et.cjs.map +0 -1
- package/dist/select-Ct37l3lg.cjs +0 -56
- package/dist/select-Ct37l3lg.cjs.map +0 -1
- package/dist/select-c6HbWvKP.js +0 -305
- package/dist/select-c6HbWvKP.js.map +0 -1
- package/dist/sheet-BMXcUiIm.js +0 -168
- package/dist/sheet-BMXcUiIm.js.map +0 -1
- package/dist/sheet-CQec-bCV.cjs +0 -35
- package/dist/sheet-CQec-bCV.cjs.map +0 -1
- package/dist/sheet.service-BcPV3Du4.js +0 -86
- package/dist/sheet.service-BcPV3Du4.js.map +0 -1
- package/dist/sheet.service-Dumvr1HT.cjs +0 -1
- package/dist/sheet.service-Dumvr1HT.cjs.map +0 -1
- package/dist/sound.service-Bu3EQLv2.cjs +0 -1
- package/dist/sound.service-Bu3EQLv2.cjs.map +0 -1
- package/dist/sound.service-m3BrSfuH.js +0 -2353
- package/dist/sound.service-m3BrSfuH.js.map +0 -1
- package/dist/src-BLngW2bl.js +0 -1244
- package/dist/src-BLngW2bl.js.map +0 -1
- package/dist/src-BtQVyqMy.cjs +0 -269
- package/dist/src-BtQVyqMy.cjs.map +0 -1
- package/dist/store-CorvD3bT.cjs.map +0 -1
- package/dist/store-DYqDLAvT.js.map +0 -1
- package/dist/surface-BjKZoJxK.cjs +0 -7
- package/dist/surface-BjKZoJxK.cjs.map +0 -1
- package/dist/surface-pK8hME5c.js +0 -21
- package/dist/surface-pK8hME5c.js.map +0 -1
- package/dist/surface.mixin-C5sDI1-_.cjs +0 -297
- package/dist/surface.mixin-C5sDI1-_.cjs.map +0 -1
- package/dist/surface.mixin-CBNRpJum.js +0 -320
- package/dist/surface.mixin-CBNRpJum.js.map +0 -1
- package/dist/table-BXIHX9h4.js +0 -631
- package/dist/table-BXIHX9h4.js.map +0 -1
- package/dist/table-CiqgZzSd.cjs +0 -63
- package/dist/table-CiqgZzSd.cjs.map +0 -1
- package/dist/tabs-CKa-W4qA.cjs +0 -31
- package/dist/tabs-CKa-W4qA.cjs.map +0 -1
- package/dist/tabs-nbV5eblZ.js +0 -125
- package/dist/tabs-nbV5eblZ.js.map +0 -1
- package/dist/tailwind.mixin-BCJOOX1_.js +0 -225
- package/dist/tailwind.mixin-BCJOOX1_.js.map +0 -1
- package/dist/tailwind.mixin-BF1Huas7.cjs +0 -2
- package/dist/tailwind.mixin-BF1Huas7.cjs.map +0 -1
- package/dist/textarea-Cp1ZE60O.cjs +0 -35
- package/dist/textarea-Cp1ZE60O.cjs.map +0 -1
- package/dist/textarea-D7q8exMg.js +0 -195
- package/dist/textarea-D7q8exMg.js.map +0 -1
- package/dist/theme-Da4SPq9X.cjs +0 -181
- package/dist/theme-Da4SPq9X.cjs.map +0 -1
- package/dist/theme-_VPV6Bxh.js +0 -4121
- package/dist/theme-_VPV6Bxh.js.map +0 -1
- package/dist/theme-button--sX8A-m1.js +0 -19
- package/dist/theme-button--sX8A-m1.js.map +0 -1
- package/dist/theme-button-Ci8VQ7KW.cjs +0 -8
- package/dist/theme-button-Ci8VQ7KW.cjs.map +0 -1
- package/dist/theme.events-Cv7N4Toe.js.map +0 -1
- package/dist/theme.events-DM4H5F2d.cjs.map +0 -1
- package/dist/theme.interface-CXloMUCw.js.map +0 -1
- package/dist/theme.interface-Da23QAYb.cjs.map +0 -1
- package/dist/theme.service-C_tjlqgy.cjs +0 -1
- package/dist/theme.service-C_tjlqgy.cjs.map +0 -1
- package/dist/theme.service-D9lEas89.js +0 -108
- package/dist/theme.service-D9lEas89.js.map +0 -1
- package/dist/tslib.es6-D7BIeDVB.cjs.map +0 -1
- package/dist/tslib.es6-ErZEp3OO.js.map +0 -1
- package/dist/typewriter-B2TnHPjw.cjs +0 -123
- package/dist/typewriter-B2TnHPjw.cjs.map +0 -1
- package/dist/typewriter-BrZNa8T-.js +0 -700
- package/dist/typewriter-BrZNa8T-.js.map +0 -1
- package/dist/utils-BcaKtQuA.cjs +0 -1
- package/dist/utils-BcaKtQuA.cjs.map +0 -1
- package/dist/utils-CoU7M2YS.js +0 -259
- package/dist/utils-CoU7M2YS.js.map +0 -1
- package/dist/window-CM1ycigo.js +0 -548
- package/dist/window-CM1ycigo.js.map +0 -1
- package/dist/window-Uii13x_r.cjs +0 -59
- package/dist/window-Uii13x_r.cjs.map +0 -1
- package/src/form/form-v2.ts +0 -268
- package/src/layout/v2/grid.ts +0 -93
- package/src/notification/outlet.ts +0 -16
- package/src/store/immer-integration.ts +0 -99
- package/src/tooltip/tooltip.ts +0 -216
- /package/dist/{animation-CO_Csq84.cjs → animation-Bcwh107v.cjs} +0 -0
- /package/dist/{animation-BK-8BwY8.js → animation-CXKSuUoE.js} +0 -0
- /package/dist/{tslib.es6-ErZEp3OO.js → decorate-D_utPUsC.js} +0 -0
- /package/dist/{tslib.es6-D7BIeDVB.cjs → decorate-F9CuyeHg.cjs} +0 -0
- /package/dist/{flow-CUj0fDT_.js → flow-CqgDEIqK.js} +0 -0
- /package/dist/{flow-Bbwn6dRN.cjs → flow-DSu4PLt1.cjs} +0 -0
- /package/dist/{hashContent-DaeGmY-p.cjs → hashContent-kKvXKFa9.cjs} +0 -0
- /package/dist/{hashContent-DYM21p6t.js → hashContent-nD2uWwi2.js} +0 -0
- /package/dist/{intersection-CZpaIHeT.cjs → intersection-D1v1UCVv.cjs} +0 -0
- /package/dist/{intersection-BPLpqYEd.js → intersection-LfEsy29T.js} +0 -0
- /package/dist/{overlay-stack-DQey9Qph.cjs → overlay-stack-CEYGD9T1.cjs} +0 -0
- /package/dist/{overlay-stack-DT1SdaGW.js → overlay-stack-Ca4EK2Mu.js} +0 -0
- /package/dist/{reduced-motion-D-L12p7G.js → reduced-motion-B83yZbcO.js} +0 -0
- /package/dist/{reduced-motion-Ds05GPyz.cjs → reduced-motion-DR32yKEO.cjs} +0 -0
- /package/dist/{rxjs-utils-BSjmI9-Q.js → rxjs-utils-Bldch1RO.js} +0 -0
- /package/dist/{rxjs-utils-DCsfzeap.cjs → rxjs-utils-hAgKC7vk.cjs} +0 -0
- /package/dist/{search-C4dFHYbX.js → search-BlGJ6uJv.js} +0 -0
- /package/dist/{search-Ds8tt7Et.cjs → search-C8eAOzBm.cjs} +0 -0
- /package/{ai → dist/skills}/animation.md +0 -0
- /package/{ai → dist/skills}/area.md +0 -0
- /package/{ai → dist/skills}/audio.md +0 -0
- /package/{ai → dist/skills}/autocomplete.md +0 -0
- /package/{ai → dist/skills}/avatar.md +0 -0
- /package/{ai → dist/skills}/badge.md +0 -0
- /package/{ai → dist/skills}/boat.md +0 -0
- /package/{ai → dist/skills}/busy.md +0 -0
- /package/{ai → dist/skills}/button.md +0 -0
- /package/{ai → dist/skills}/card.md +0 -0
- /package/{ai → dist/skills}/charts.md +0 -0
- /package/{ai → dist/skills}/checkbox.md +0 -0
- /package/{ai → dist/skills}/chips.md +0 -0
- /package/{ai → dist/skills}/code-highlight.md +0 -0
- /package/{ai → dist/skills}/connectivity.md +0 -0
- /package/{ai → dist/skills}/content-drawer.md +0 -0
- /package/{ai → dist/skills}/date-range-inline.md +0 -0
- /package/{ai → dist/skills}/date-range.md +0 -0
- /package/{ai → dist/skills}/delay.md +0 -0
- /package/{ai → dist/skills}/details.md +0 -0
- /package/{ai → dist/skills}/dialog.md +0 -0
- /package/{ai → dist/skills}/directives.md +0 -0
- /package/{ai → dist/skills}/discovery.md +0 -0
- /package/{ai → dist/skills}/divider.md +0 -0
- /package/{ai → dist/skills}/dropdown.md +0 -0
- /package/{ai → dist/skills}/expand.md +0 -0
- /package/{ai → dist/skills}/extra.md +0 -0
- /package/{ai → dist/skills}/float.md +0 -0
- /package/{ai → dist/skills}/form.md +0 -0
- /package/{ai → dist/skills}/icons.md +0 -0
- /package/{ai → dist/skills}/iframe.md +0 -0
- /package/{ai → dist/skills}/input.md +0 -0
- /package/{ai → dist/skills}/json.md +0 -0
- /package/{ai → dist/skills}/layout.md +0 -0
- /package/{ai → dist/skills}/lightbox.md +0 -0
- /package/{ai → dist/skills}/list.md +0 -0
- /package/{ai → dist/skills}/mailbox.md +0 -0
- /package/{ai → dist/skills}/map.md +0 -0
- /package/{ai → dist/skills}/menu.md +0 -0
- /package/{ai → dist/skills}/mixins.md +0 -0
- /package/{ai → dist/skills}/nav-drawer.md +0 -0
- /package/{ai → dist/skills}/navigation-bar.md +0 -0
- /package/{ai → dist/skills}/navigation-rail.md +0 -0
- /package/{ai → dist/skills}/notification.md +0 -0
- /package/{ai → dist/skills}/option.md +0 -0
- /package/{ai → dist/skills}/page.md +0 -0
- /package/{ai → dist/skills}/progress.md +0 -0
- /package/{ai → dist/skills}/qr-scanner.md +0 -0
- /package/{ai → dist/skills}/radio-group.md +0 -0
- /package/{ai → dist/skills}/range.md +0 -0
- /package/{ai → dist/skills}/rxjs-utils.md +0 -0
- /package/dist/{ai → skills/schmancy}/animation.md +0 -0
- /package/dist/{ai → skills/schmancy}/area.md +0 -0
- /package/dist/{ai → skills/schmancy}/audio.md +0 -0
- /package/dist/{ai → skills/schmancy}/autocomplete.md +0 -0
- /package/dist/{ai → skills/schmancy}/avatar.md +0 -0
- /package/dist/{ai → skills/schmancy}/badge.md +0 -0
- /package/dist/{ai → skills/schmancy}/boat.md +0 -0
- /package/dist/{ai → skills/schmancy}/busy.md +0 -0
- /package/dist/{ai → skills/schmancy}/button.md +0 -0
- /package/dist/{ai → skills/schmancy}/card.md +0 -0
- /package/dist/{ai → skills/schmancy}/charts.md +0 -0
- /package/dist/{ai → skills/schmancy}/checkbox.md +0 -0
- /package/dist/{ai → skills/schmancy}/chips.md +0 -0
- /package/dist/{ai → skills/schmancy}/code-highlight.md +0 -0
- /package/dist/{ai → skills/schmancy}/connectivity.md +0 -0
- /package/dist/{ai → skills/schmancy}/content-drawer.md +0 -0
- /package/dist/{ai → skills/schmancy}/date-range-inline.md +0 -0
- /package/dist/{ai → skills/schmancy}/date-range.md +0 -0
- /package/dist/{ai → skills/schmancy}/delay.md +0 -0
- /package/dist/{ai → skills/schmancy}/details.md +0 -0
- /package/dist/{ai → skills/schmancy}/dialog.md +0 -0
- /package/dist/{ai → skills/schmancy}/directives.md +0 -0
- /package/dist/{ai → skills/schmancy}/discovery.md +0 -0
- /package/dist/{ai → skills/schmancy}/divider.md +0 -0
- /package/dist/{ai → skills/schmancy}/dropdown.md +0 -0
- /package/dist/{ai → skills/schmancy}/expand.md +0 -0
- /package/dist/{ai → skills/schmancy}/extra.md +0 -0
- /package/dist/{ai → skills/schmancy}/float.md +0 -0
- /package/dist/{ai → skills/schmancy}/form.md +0 -0
- /package/dist/{ai → skills/schmancy}/icons.md +0 -0
- /package/dist/{ai → skills/schmancy}/iframe.md +0 -0
- /package/dist/{ai → skills/schmancy}/input.md +0 -0
- /package/dist/{ai → skills/schmancy}/json.md +0 -0
- /package/dist/{ai → skills/schmancy}/layout.md +0 -0
- /package/dist/{ai → skills/schmancy}/lightbox.md +0 -0
- /package/dist/{ai → skills/schmancy}/list.md +0 -0
- /package/dist/{ai → skills/schmancy}/mailbox.md +0 -0
- /package/dist/{ai → skills/schmancy}/map.md +0 -0
- /package/dist/{ai → skills/schmancy}/menu.md +0 -0
- /package/dist/{ai → skills/schmancy}/mixins.md +0 -0
- /package/dist/{ai → skills/schmancy}/nav-drawer.md +0 -0
- /package/dist/{ai → skills/schmancy}/navigation-bar.md +0 -0
- /package/dist/{ai → skills/schmancy}/navigation-rail.md +0 -0
- /package/dist/{ai → skills/schmancy}/notification.md +0 -0
- /package/dist/{ai → skills/schmancy}/option.md +0 -0
- /package/dist/{ai → skills/schmancy}/page.md +0 -0
- /package/dist/{ai → skills/schmancy}/progress.md +0 -0
- /package/dist/{ai → skills/schmancy}/qr-scanner.md +0 -0
- /package/dist/{ai → skills/schmancy}/radio-group.md +0 -0
- /package/dist/{ai → skills/schmancy}/range.md +0 -0
- /package/dist/{ai → skills/schmancy}/rxjs-utils.md +0 -0
- /package/{ai → dist/skills/schmancy}/select.md +0 -0
- /package/{ai → dist/skills/schmancy}/sheet.md +0 -0
- /package/{ai → dist/skills/schmancy}/slider.md +0 -0
- /package/{ai → dist/skills/schmancy}/steps.md +0 -0
- /package/{ai → dist/skills/schmancy}/store.md +0 -0
- /package/{ai → dist/skills/schmancy}/surface.md +0 -0
- /package/{ai → dist/skills/schmancy}/table.md +0 -0
- /package/{ai → dist/skills/schmancy}/tabs.md +0 -0
- /package/{ai → dist/skills/schmancy}/teleport.md +0 -0
- /package/{ai → dist/skills/schmancy}/textarea.md +0 -0
- /package/{ai → dist/skills/schmancy}/theme-button.md +0 -0
- /package/{ai → dist/skills/schmancy}/theme.md +0 -0
- /package/{ai → dist/skills/schmancy}/tree.md +0 -0
- /package/{ai → dist/skills/schmancy}/typewriter.md +0 -0
- /package/{ai → dist/skills/schmancy}/typography.md +0 -0
- /package/{ai → dist/skills/schmancy}/utils.md +0 -0
- /package/{ai → dist/skills/schmancy}/window.md +0 -0
- /package/dist/{ai → skills}/select.md +0 -0
- /package/dist/{ai → skills}/sheet.md +0 -0
- /package/dist/{ai → skills}/slider.md +0 -0
- /package/dist/{ai → skills}/steps.md +0 -0
- /package/dist/{ai → skills}/store.md +0 -0
- /package/dist/{ai → skills}/surface.md +0 -0
- /package/dist/{ai → skills}/table.md +0 -0
- /package/dist/{ai → skills}/tabs.md +0 -0
- /package/dist/{ai → skills}/teleport.md +0 -0
- /package/dist/{ai → skills}/textarea.md +0 -0
- /package/dist/{ai → skills}/theme-button.md +0 -0
- /package/dist/{ai → skills}/theme.md +0 -0
- /package/dist/{ai → skills}/tree.md +0 -0
- /package/dist/{ai → skills}/typewriter.md +0 -0
- /package/dist/{ai → skills}/typography.md +0 -0
- /package/dist/{ai → skills}/utils.md +0 -0
- /package/dist/{ai → skills}/window.md +0 -0
- /package/dist/{store-DYqDLAvT.js → store-Bmj6rvZY.js} +0 -0
- /package/dist/{store-CorvD3bT.cjs → store-CO4nJyGj.cjs} +0 -0
- /package/dist/{theme.events-Cv7N4Toe.js → theme.events-Bw3mYjUA.js} +0 -0
- /package/dist/{theme.events-DM4H5F2d.cjs → theme.events-EznKK2Y0.cjs} +0 -0
- /package/dist/{theme.interface-Da23QAYb.cjs → theme.interface-CM26m9te.cjs} +0 -0
- /package/dist/{theme.interface-CXloMUCw.js → theme.interface-FAUIgbIq.js} +0 -0
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
# Schmancy Directives — AI Reference
|
|
2
|
+
|
|
3
|
+
## What Are Directives?
|
|
4
|
+
|
|
5
|
+
Lit directives that snap onto any element to add behavior. No components to wrap, no CSS to write — just `${directiveName()}` in your template.
|
|
6
|
+
|
|
7
|
+
```typescript
|
|
8
|
+
import { magnetic, cursorGlow, gravity, reveal } from '@mhmo91/schmancy/directives'
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
## Physics & Interaction (6 directives)
|
|
14
|
+
|
|
15
|
+
### `magnetic` — Elements lean toward the cursor
|
|
16
|
+
```html
|
|
17
|
+
<schmancy-button ${magnetic()}>Submit</schmancy-button>
|
|
18
|
+
<schmancy-icon-button ${magnetic({ strength: 6, radius: 120 })}>add</schmancy-icon-button>
|
|
19
|
+
```
|
|
20
|
+
| Option | Default | Description |
|
|
21
|
+
|--------|---------|-------------|
|
|
22
|
+
| `strength` | 4 | Max displacement in px |
|
|
23
|
+
| `radius` | 100 | Activation radius in px |
|
|
24
|
+
|
|
25
|
+
Embedded in: `schmancy-button`, `schmancy-icon-button`, `schmancy-filter-chip`, `schmancy-details` (summary)
|
|
26
|
+
|
|
27
|
+
### `cursorGlow` — Light follows cursor across a surface
|
|
28
|
+
```html
|
|
29
|
+
<schmancy-surface type="glass" ${cursorGlow()}>content</schmancy-surface>
|
|
30
|
+
<div ${cursorGlow({ radius: 300, intensity: 0.2, color: 'var(--schmancy-sys-color-secondary-default)' })}>
|
|
31
|
+
hero panel
|
|
32
|
+
</div>
|
|
33
|
+
```
|
|
34
|
+
| Option | Default | Description |
|
|
35
|
+
|--------|---------|-------------|
|
|
36
|
+
| `radius` | 200 | Glow radius in px |
|
|
37
|
+
| `color` | primary | CSS color value |
|
|
38
|
+
| `intensity` | 0.12 | Opacity 0-1 |
|
|
39
|
+
|
|
40
|
+
Embedded in: `schmancy-card` (interactive), `schmancy-dialog`
|
|
41
|
+
|
|
42
|
+
### `livingBorder` — Animated gradient light traces element edges
|
|
43
|
+
```html
|
|
44
|
+
<schmancy-card ${livingBorder()}>content</schmancy-card>
|
|
45
|
+
<div ${livingBorder({ duration: 4000, onHover: true, color: 'var(--schmancy-sys-color-secondary-default)' })}>
|
|
46
|
+
hero panel
|
|
47
|
+
</div>
|
|
48
|
+
```
|
|
49
|
+
| Option | Default | Description |
|
|
50
|
+
|--------|---------|-------------|
|
|
51
|
+
| `duration` | 3000 | Rotation speed in ms |
|
|
52
|
+
| `width` | 1 | Border width in px |
|
|
53
|
+
| `color` | primary | Glow color |
|
|
54
|
+
| `spread` | 6 | Glow spread in px |
|
|
55
|
+
| `onHover` | false | Only animate on hover |
|
|
56
|
+
|
|
57
|
+
### `gravity` — Elements fall into place with mass-based bounce
|
|
58
|
+
```html
|
|
59
|
+
<!-- Single element drops in -->
|
|
60
|
+
<schmancy-card ${gravity()}>content</schmancy-card>
|
|
61
|
+
|
|
62
|
+
<!-- Staggered list — each item falls 50ms after the previous -->
|
|
63
|
+
${repeat(items, item => item.id, (item, i) => html`
|
|
64
|
+
<div ${gravity({ stagger: 50 * i, mass: 0.8 })}>...</div>
|
|
65
|
+
`)}
|
|
66
|
+
```
|
|
67
|
+
| Option | Default | Description |
|
|
68
|
+
|--------|---------|-------------|
|
|
69
|
+
| `mass` | 1.0 | 0.5 (bouncy) to 2.0 (heavy) |
|
|
70
|
+
| `distance` | 30 | Fall distance in px |
|
|
71
|
+
| `delay` | 0 | Delay before falling in ms |
|
|
72
|
+
| `stagger` | 0 | Per-item stagger in ms |
|
|
73
|
+
|
|
74
|
+
Only animates once. Re-triggers on reconnect (route change, cache toggle).
|
|
75
|
+
|
|
76
|
+
### `depthOfField` — Progressive blur on background content
|
|
77
|
+
```html
|
|
78
|
+
<main ${depthOfField({ active: this.dialogOpen, maxBlur: 8 })}>
|
|
79
|
+
page content that blurs when dialog opens
|
|
80
|
+
</main>
|
|
81
|
+
```
|
|
82
|
+
| Option | Default | Description |
|
|
83
|
+
|--------|---------|-------------|
|
|
84
|
+
| `active` | required | Boolean — blur when true |
|
|
85
|
+
| `maxBlur` | 8 | Max blur radius in px |
|
|
86
|
+
| `duration` | 400 | Transition duration in ms |
|
|
87
|
+
|
|
88
|
+
### `longPress` — Press-and-hold gesture detection
|
|
89
|
+
```html
|
|
90
|
+
<div ${longPress(() => this.showContextMenu())}>Hold me</div>
|
|
91
|
+
<div ${longPress(() => this.showMenu(), { duration: 800, movementThreshold: 15 })}>
|
|
92
|
+
Custom timing
|
|
93
|
+
</div>
|
|
94
|
+
```
|
|
95
|
+
| Option | Default | Description |
|
|
96
|
+
|--------|---------|-------------|
|
|
97
|
+
| `duration` | 500 | Time before trigger in ms |
|
|
98
|
+
| `movementThreshold` | 10 | Max movement in px before cancel |
|
|
99
|
+
|
|
100
|
+
---
|
|
101
|
+
|
|
102
|
+
## Visual Effects (3 directives)
|
|
103
|
+
|
|
104
|
+
### `nebula` — Surreal dimensional rift loading effect
|
|
105
|
+
```html
|
|
106
|
+
<div ${nebula()}>Content with cosmic loading effect</div>
|
|
107
|
+
<div ${nebula({ active: this.loading, temperature: -0.5, speed: 1.5 })}>
|
|
108
|
+
Cool-toned, faster nebula
|
|
109
|
+
</div>
|
|
110
|
+
```
|
|
111
|
+
| Option | Default | Description |
|
|
112
|
+
|--------|---------|-------------|
|
|
113
|
+
| `active` | true | Show/hide the effect |
|
|
114
|
+
| `intensity` | 1 | Brightness 0-1 |
|
|
115
|
+
| `speed` | 1 | Animation speed multiplier |
|
|
116
|
+
| `temperature` | 0 | -1 (cool/blue) to 1 (warm/pink) |
|
|
117
|
+
| `particleCount` | 30 | Quantum particle count |
|
|
118
|
+
| `autoHideDuration` | 3000 | Auto-dim after ms (0 = never) |
|
|
119
|
+
| `background` | true | Render behind content |
|
|
120
|
+
|
|
121
|
+
### `liquid` — Apple Liquid Glass effect (pure CSS)
|
|
122
|
+
```html
|
|
123
|
+
<div ${liquid()}>Glass panel</div>
|
|
124
|
+
<div ${liquid({ intensity: 'strong', active: this.isActive })}>
|
|
125
|
+
Thick glass
|
|
126
|
+
</div>
|
|
127
|
+
```
|
|
128
|
+
| Option | Default | Description |
|
|
129
|
+
|--------|---------|-------------|
|
|
130
|
+
| `active` | true | Toggle effect on/off |
|
|
131
|
+
| `intensity` | 'medium' | 'light', 'medium', or 'strong' |
|
|
132
|
+
|
|
133
|
+
Zero DOM mutation — applies only inline styles.
|
|
134
|
+
|
|
135
|
+
### `ripple` — Material-style ink ripple on click
|
|
136
|
+
```html
|
|
137
|
+
<div ${ripple()}>Click me</div>
|
|
138
|
+
```
|
|
139
|
+
No options. Ripple appears at click position, fades out in 600ms.
|
|
140
|
+
|
|
141
|
+
---
|
|
142
|
+
|
|
143
|
+
## Text Animation (3 directives)
|
|
144
|
+
|
|
145
|
+
### `animateText` — 5 text animation modes
|
|
146
|
+
```html
|
|
147
|
+
<span ${animateText({ animation: 'blur-reveal', stagger: 60 })}>Hello world</span>
|
|
148
|
+
<span ${animateText({ animation: 'cyber-glitch', preset: 'snappy' })}>GLITCH</span>
|
|
149
|
+
<span ${animateText({ animation: 'fade-up' })}>Fade up</span>
|
|
150
|
+
```
|
|
151
|
+
| Animation | Description |
|
|
152
|
+
|-----------|-------------|
|
|
153
|
+
| `typewriter` | Characters appear one by one |
|
|
154
|
+
| `fade-up` | Whole element fades up |
|
|
155
|
+
| `word-reveal` | Words appear one by one from below |
|
|
156
|
+
| `blur-reveal` | Words deblur + scale in |
|
|
157
|
+
| `cyber-glitch` | Characters pop in with overshoot |
|
|
158
|
+
|
|
159
|
+
| Option | Default | Description |
|
|
160
|
+
|--------|---------|-------------|
|
|
161
|
+
| `animation` | required | Animation type |
|
|
162
|
+
| `preset` | 'snappy' | Spring preset: smooth, snappy, bouncy, gentle |
|
|
163
|
+
| `stagger` | 50 | Ms between characters/words |
|
|
164
|
+
| `text` | element content | Explicit text (for Lit bindings) |
|
|
165
|
+
| `restart` | false | Re-animate on viewport re-entry |
|
|
166
|
+
|
|
167
|
+
Waits for element visibility before starting.
|
|
168
|
+
|
|
169
|
+
### `cycleText` — Cycle through child elements with transitions
|
|
170
|
+
```html
|
|
171
|
+
<span ${cycleText({ transition: 'slide', hold: 1500 })}>
|
|
172
|
+
<span>First</span>
|
|
173
|
+
<span>Second</span>
|
|
174
|
+
<span>Third</span>
|
|
175
|
+
</span>
|
|
176
|
+
|
|
177
|
+
<!-- Add mode: accumulates items -->
|
|
178
|
+
<span ${cycleText({ mode: 'add', transition: 'typewriter' })}>
|
|
179
|
+
<span>guests</span>
|
|
180
|
+
<span>kitchen</span>
|
|
181
|
+
<span>team</span>
|
|
182
|
+
</span>
|
|
183
|
+
<!-- Shows: "guests" → "guests, kitchen" → "guests, kitchen, team" → clears → repeat -->
|
|
184
|
+
```
|
|
185
|
+
| Option | Default | Description |
|
|
186
|
+
|--------|---------|-------------|
|
|
187
|
+
| `transition` | 'fade' | 'fade', 'slide', or 'typewriter' |
|
|
188
|
+
| `hold` | 2000 | Display time per item in ms |
|
|
189
|
+
| `mode` | 'replace' | 'replace' or 'add' (accumulate) |
|
|
190
|
+
| `separator` | ', ' | Separator in add mode |
|
|
191
|
+
|
|
192
|
+
### `typewriter` — Phrase cycling with typing/deleting + sound
|
|
193
|
+
```html
|
|
194
|
+
<div ${typewriter(['Trustless', 'Permissionless', 'Transparent'])}>
|
|
195
|
+
<span class="typed"></span>
|
|
196
|
+
</div>
|
|
197
|
+
<div ${typewriter(['Fast', 'Typing'], { typeSpeed: 50, sound: true })}>
|
|
198
|
+
<span class="typed"></span>
|
|
199
|
+
</div>
|
|
200
|
+
```
|
|
201
|
+
| Option | Default | Description |
|
|
202
|
+
|--------|---------|-------------|
|
|
203
|
+
| `typeSpeed` | 50 | Ms per character typed |
|
|
204
|
+
| `deleteSpeed` | 30 | Ms per character deleted |
|
|
205
|
+
| `pauseDuration` | 1500 | Pause after typing in ms |
|
|
206
|
+
| `loop` | true | Loop through phrases |
|
|
207
|
+
| `sound` | true | Web Audio typing sounds |
|
|
208
|
+
| `cursor` | false | Show blinking cursor |
|
|
209
|
+
|
|
210
|
+
---
|
|
211
|
+
|
|
212
|
+
## Show/Hide (2 directives)
|
|
213
|
+
|
|
214
|
+
### `reveal` — Spring-physics show/hide with zero layout shift
|
|
215
|
+
```html
|
|
216
|
+
<div ${reveal(this.isVisible)}>Content</div>
|
|
217
|
+
<div ${reveal(this.isOpen, { preset: 'bouncy', maxHeight: '200px' })}>
|
|
218
|
+
Bouncy reveal
|
|
219
|
+
</div>
|
|
220
|
+
```
|
|
221
|
+
| Option | Default | Description |
|
|
222
|
+
|--------|---------|-------------|
|
|
223
|
+
| `preset` | 'smooth' | smooth, snappy, bouncy, gentle |
|
|
224
|
+
| `maxHeight` | '10rem' | Max height when revealed |
|
|
225
|
+
|
|
226
|
+
Element stays in DOM (no layout shift). Uses Blackbird spring physics.
|
|
227
|
+
|
|
228
|
+
### `intersect` — Simplified IntersectionObserver
|
|
229
|
+
```html
|
|
230
|
+
<!-- Fire once when visible (lazy load) -->
|
|
231
|
+
<img ${intersect(() => this.loadImage(), { once: true })} />
|
|
232
|
+
|
|
233
|
+
<!-- Enter/exit callbacks -->
|
|
234
|
+
<video ${intersect({ onEnter: () => this.play(), onExit: () => this.pause() })}>
|
|
235
|
+
```
|
|
236
|
+
| Option | Default | Description |
|
|
237
|
+
|--------|---------|-------------|
|
|
238
|
+
| `once` | false | Fire only once then disconnect |
|
|
239
|
+
| `threshold` | 0 | Visibility threshold |
|
|
240
|
+
| `rootMargin` | '0px' | Observer root margin |
|
|
241
|
+
| `delay` | 0 | Delay before callback in ms |
|
|
242
|
+
|
|
243
|
+
---
|
|
244
|
+
|
|
245
|
+
## Interaction (3 directives)
|
|
246
|
+
|
|
247
|
+
### `drag` & `drop` — HTML5 drag and drop with FLIP animations
|
|
248
|
+
```html
|
|
249
|
+
${repeat(items, item => item.id, item => html`
|
|
250
|
+
<div ${drag(item.id)} ${drop(item.id)} @drop=${this.handleReorder}>
|
|
251
|
+
${item.name}
|
|
252
|
+
</div>
|
|
253
|
+
`)}
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
### `color` — Dynamic background/text color
|
|
257
|
+
```html
|
|
258
|
+
<div ${color({ bgColor: '#ff0000', color: 'white' })}>Colored</div>
|
|
259
|
+
```
|
|
260
|
+
|
|
261
|
+
---
|
|
262
|
+
|
|
263
|
+
## Reactive Utilities
|
|
264
|
+
|
|
265
|
+
### `reducedMotion$` — Reactive reduced-motion preference
|
|
266
|
+
```typescript
|
|
267
|
+
import { reducedMotion$ } from '@mhmo91/schmancy/directives'
|
|
268
|
+
|
|
269
|
+
if (reducedMotion$.value) return // skip animation
|
|
270
|
+
|
|
271
|
+
// Or subscribe reactively
|
|
272
|
+
reducedMotion$.subscribe(reduced => {
|
|
273
|
+
// User toggled reduced motion mid-session
|
|
274
|
+
})
|
|
275
|
+
```
|
|
276
|
+
|
|
277
|
+
### `fromResizeObserver` — RxJS wrapper for ResizeObserver
|
|
278
|
+
```typescript
|
|
279
|
+
import { fromResizeObserver } from '@mhmo91/schmancy/directives'
|
|
280
|
+
|
|
281
|
+
fromResizeObserver(element).pipe(
|
|
282
|
+
takeUntil(this.disconnecting)
|
|
283
|
+
).subscribe(entries => {
|
|
284
|
+
const { width, height } = entries[0].contentRect
|
|
285
|
+
})
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
---
|
|
289
|
+
|
|
290
|
+
## Performance Notes
|
|
291
|
+
|
|
292
|
+
- All physics directives respect `prefers-reduced-motion` reactively
|
|
293
|
+
- `magnetic` and `cursorGlow` cache `getBoundingClientRect` on mouseenter (not per-frame)
|
|
294
|
+
- `gravity` only animates once — parent re-renders don't re-trigger
|
|
295
|
+
- `livingBorder` shares a single `<style>` element across all instances
|
|
296
|
+
- `nebula` uses a singleton IntersectionObserver + pauses off-screen animations
|
|
297
|
+
- All directives use `Subject` + `takeUntil` for subscription cleanup
|
|
298
|
+
- All directives implement `reconnected()` for cache/conditional rendering survival
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
# Schmancy Discovery
|
|
2
|
+
|
|
3
|
+
> Event-based component and element discovery across shadow DOM boundaries. No DOM traversal — just broadcast and race.
|
|
4
|
+
|
|
5
|
+
## Why
|
|
6
|
+
Web components hide inside shadow DOM. Traversing with `querySelector` + `shadowRoot` everywhere is fragile. Discovery broadcasts a "where are you?" event; components respond with themselves.
|
|
7
|
+
|
|
8
|
+
## API
|
|
9
|
+
```typescript
|
|
10
|
+
import {
|
|
11
|
+
discover,
|
|
12
|
+
discoverComponent,
|
|
13
|
+
discoverAnyComponent,
|
|
14
|
+
discoverElement,
|
|
15
|
+
discoverAllElements,
|
|
16
|
+
} from '@mhmo91/schmancy'
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
### `discover(query, timeout?)`
|
|
20
|
+
Smart auto-detect. Routes to `discoverElement` for CSS selectors (`#`, `.`, `[`) and `discoverComponent` for tag names.
|
|
21
|
+
```typescript
|
|
22
|
+
discover<SchmancyNavigationRail>('schmancy-navigation-rail').subscribe(el => el?.select('home'))
|
|
23
|
+
discover('#hero-card').subscribe(el => el?.focus())
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
### `discoverComponent(tag, timeout = 100)`
|
|
27
|
+
Broadcasts `{tag}-where-are-you`; first responder wins.
|
|
28
|
+
```typescript
|
|
29
|
+
discoverComponent<SchmancyDialog>('schmancy-dialog')
|
|
30
|
+
.subscribe(dialog => dialog?.open())
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### `discoverAnyComponent(...tags)`
|
|
34
|
+
Race between multiple tags — first to respond wins.
|
|
35
|
+
```typescript
|
|
36
|
+
discoverAnyComponent('schmancy-navigation-rail', 'schmancy-navigation-bar')
|
|
37
|
+
.subscribe(nav => nav?.select(route))
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
### `discoverElement(selector, timeout = 150)`
|
|
41
|
+
Finds any element by CSS selector across shadow DOM. Uses a request ID + universal `schmancy-discover` event. Every `$LitElement` responds if it finds a match in its shadow root.
|
|
42
|
+
```typescript
|
|
43
|
+
discoverElement('[data-section="pricing"]').subscribe(section => section?.scrollIntoView())
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
### `discoverAllElements(selector, timeout = 150)`
|
|
47
|
+
Collects **all** matching responses within the timeout window.
|
|
48
|
+
```typescript
|
|
49
|
+
discoverAllElements('.flagged').subscribe(all => console.log(all.length))
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
## How the Handshake Works
|
|
53
|
+
1. Caller creates a unique `requestId` and broadcasts `schmancy-discover` on `window` with `{ selector, requestId }`.
|
|
54
|
+
2. Every `$LitElement` listens for this event (wired up in the base class).
|
|
55
|
+
3. Any matching element dispatches `schmancy-discover-response` with `{ requestId, element }`.
|
|
56
|
+
4. Caller collects responses for the timeout window and emits via RxJS.
|
|
57
|
+
|
|
58
|
+
## Pattern in Base Class
|
|
59
|
+
Every `$LitElement` inherits auto-response: `discover<T>(tag)` (method on the component) and `{tagName}-where-are-you`/`{tagName}-here-i-am` events. See [mixins.md](./mixins.md).
|
|
60
|
+
|
|
61
|
+
## When to Use
|
|
62
|
+
- Cross-shadow coordination between unrelated components.
|
|
63
|
+
- Imperatively focusing or driving a far-away UI piece from a handler.
|
|
64
|
+
|
|
65
|
+
## When NOT to Use
|
|
66
|
+
- Same-tree data flow — use `@provide`/`@consume` (Lit context) or Schmancy [`store`](./store.md).
|
|
67
|
+
- Parent-to-child directly — just use `this.renderRoot.querySelector()`.
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# schmancy-divider
|
|
2
|
+
|
|
3
|
+
> Horizontal or vertical divider line with grow animation.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
```html
|
|
7
|
+
<schmancy-divider></schmancy-divider>
|
|
8
|
+
```
|
|
9
|
+
|
|
10
|
+
## Properties
|
|
11
|
+
| Property | Type | Default | Description |
|
|
12
|
+
|----------|------|---------|-------------|
|
|
13
|
+
| vertical | boolean | `false` | Vertical orientation (use inside flex/grid) |
|
|
14
|
+
| outline | `'default'\|'variant'` | `'variant'` | Line color intensity |
|
|
15
|
+
| grow | `'start'\|'end'\|'both'` | `'start'` | Animation origin direction |
|
|
16
|
+
|
|
17
|
+
## Examples
|
|
18
|
+
```html
|
|
19
|
+
<!-- Horizontal divider -->
|
|
20
|
+
<schmancy-divider></schmancy-divider>
|
|
21
|
+
|
|
22
|
+
<!-- Vertical divider in a flex container -->
|
|
23
|
+
<div class="flex items-stretch h-16">
|
|
24
|
+
<span>Left</span>
|
|
25
|
+
<schmancy-divider vertical></schmancy-divider>
|
|
26
|
+
<span>Right</span>
|
|
27
|
+
</div>
|
|
28
|
+
|
|
29
|
+
<!-- Grow from center -->
|
|
30
|
+
<schmancy-divider grow="both"></schmancy-divider>
|
|
31
|
+
```
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
# schmancy-dropdown
|
|
2
|
+
|
|
3
|
+
> Floating dropdown with trigger slot and auto-positioned content portal.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
```html
|
|
7
|
+
<schmancy-dropdown>
|
|
8
|
+
<schmancy-button slot="trigger">Open</schmancy-button>
|
|
9
|
+
<schmancy-dropdown-content>
|
|
10
|
+
<p>Dropdown content here</p>
|
|
11
|
+
</schmancy-dropdown-content>
|
|
12
|
+
</schmancy-dropdown>
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
## Properties
|
|
16
|
+
| Property | Type | Default | Description |
|
|
17
|
+
|----------|------|---------|-------------|
|
|
18
|
+
| open | boolean | `false` | Whether the dropdown is open |
|
|
19
|
+
| placement | string | `'bottom-start'` | Floating UI placement |
|
|
20
|
+
| distance | number | `8` | Offset distance in pixels |
|
|
21
|
+
|
|
22
|
+
## Placement Values
|
|
23
|
+
`top`, `top-start`, `top-end`, `right`, `right-start`, `right-end`, `bottom`, `bottom-start`, `bottom-end`, `left`, `left-start`, `left-end`
|
|
24
|
+
|
|
25
|
+
## Methods
|
|
26
|
+
| Method | Description |
|
|
27
|
+
|--------|-------------|
|
|
28
|
+
| toggle() | Toggle open/close state |
|
|
29
|
+
|
|
30
|
+
## Slots
|
|
31
|
+
| Slot | Description |
|
|
32
|
+
|------|-------------|
|
|
33
|
+
| trigger | Element that opens the dropdown on click |
|
|
34
|
+
| default | Dropdown content |
|
|
35
|
+
|
|
36
|
+
## Examples
|
|
37
|
+
```html
|
|
38
|
+
<!-- Right-aligned dropdown -->
|
|
39
|
+
<schmancy-dropdown placement="bottom-end">
|
|
40
|
+
<schmancy-icon-button slot="trigger">more_vert</schmancy-icon-button>
|
|
41
|
+
<schmancy-dropdown-content>
|
|
42
|
+
<div class="p-4">Custom content</div>
|
|
43
|
+
</schmancy-dropdown-content>
|
|
44
|
+
</schmancy-dropdown>
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
Content is teleported to a portal for proper z-index stacking. Closes on outside click or Escape key.
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
# schmancy-expand
|
|
2
|
+
|
|
3
|
+
> Expandable/accordion component. Inline mode uses grid-template-rows transitions; portal mode teleports content to a body-level `schmancy-expand-root` with backdrop.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
```html
|
|
7
|
+
<schmancy-expand summary="Details">
|
|
8
|
+
<p>Content appears when expanded.</p>
|
|
9
|
+
</schmancy-expand>
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
## Properties
|
|
13
|
+
| Property | Type | Default | Description |
|
|
14
|
+
|----------|------|---------|-------------|
|
|
15
|
+
| `summary` | string | `''` | Summary text shown when collapsed |
|
|
16
|
+
| `open` | boolean | `false` | Expansion state (reflected) |
|
|
17
|
+
| `summary-padding` | string | — | CSS padding for the summary row |
|
|
18
|
+
| `content-padding` | string | — | CSS padding for the body |
|
|
19
|
+
| `hide-indicator` | boolean | `false` | Hide the chevron indicator |
|
|
20
|
+
| `indicator-rotate` | number | `90` | Rotation angle (deg) when open |
|
|
21
|
+
| `backdrop` | boolean | `true` | Show semi-transparent backdrop in portal mode |
|
|
22
|
+
| `inline` | boolean | `false` | Inline expansion instead of portal (no backdrop) |
|
|
23
|
+
|
|
24
|
+
## Slots
|
|
25
|
+
| Slot | Purpose |
|
|
26
|
+
|------|---------|
|
|
27
|
+
| (default) | Expanded content |
|
|
28
|
+
| `summary` | Custom summary markup (overrides `summary` property) |
|
|
29
|
+
|
|
30
|
+
## Behavior
|
|
31
|
+
- **Portal mode (default)**: on open, content is teleported into a body-anchored `schmancy-expand-root` with a backdrop. Click outside or press `Escape` to close.
|
|
32
|
+
- **Inline mode** (`inline`): uses `grid-template-rows: 0fr → 1fr` transition inside the host — no portal, no backdrop.
|
|
33
|
+
- `SPRING_SNAPPY` physics for indicator rotation.
|
|
34
|
+
- Respects `prefers-reduced-motion`.
|
|
35
|
+
- Broadcast event `SCHMANCY_EXPAND_REQUEST_CLOSE` on `window` closes whichever instance is currently open.
|
|
36
|
+
|
|
37
|
+
## Example — inline accordion
|
|
38
|
+
```html
|
|
39
|
+
${repeat(this.faqs, faq => faq.id, faq => html`
|
|
40
|
+
<schmancy-expand inline .summary=${faq.question}>
|
|
41
|
+
<p>${faq.answer}</p>
|
|
42
|
+
</schmancy-expand>
|
|
43
|
+
`)}
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
## Example — portal with custom summary slot
|
|
47
|
+
```html
|
|
48
|
+
<schmancy-expand>
|
|
49
|
+
<div slot="summary" class="flex items-center gap-2">
|
|
50
|
+
<schmancy-icon>info</schmancy-icon>
|
|
51
|
+
<schmancy-typography type="title">Advanced options</schmancy-typography>
|
|
52
|
+
</div>
|
|
53
|
+
<div class="p-4">
|
|
54
|
+
<!-- settings form -->
|
|
55
|
+
</div>
|
|
56
|
+
</schmancy-expand>
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
## Programmatic Close
|
|
60
|
+
```typescript
|
|
61
|
+
import { SCHMANCY_EXPAND_REQUEST_CLOSE } from '@mhmo91/schmancy'
|
|
62
|
+
window.dispatchEvent(new Event(SCHMANCY_EXPAND_REQUEST_CLOSE))
|
|
63
|
+
```
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
# Schmancy Extra
|
|
2
|
+
|
|
3
|
+
> Data-driven dropdowns for common localization fields. Country and timezone pickers, form-associated and autocomplete-backed.
|
|
4
|
+
|
|
5
|
+
## schmancy-select-countries
|
|
6
|
+
Fully autocomplete-searchable country dropdown. Form-associated (participates in `<form>` submission and validation via `ElementInternals`).
|
|
7
|
+
|
|
8
|
+
```html
|
|
9
|
+
<schmancy-select-countries
|
|
10
|
+
name="country"
|
|
11
|
+
label="Country"
|
|
12
|
+
placeholder="Select a country"
|
|
13
|
+
required
|
|
14
|
+
value="DE"
|
|
15
|
+
@change=${e => this.country = e.target.value}
|
|
16
|
+
></schmancy-select-countries>
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
| Property | Type | Default | Description |
|
|
20
|
+
|----------|------|---------|-------------|
|
|
21
|
+
| `value` | string | — | ISO country code (reflected) |
|
|
22
|
+
| `name` | string | `''` | Form field name |
|
|
23
|
+
| `label` | string | `'Country'` | Visible label |
|
|
24
|
+
| `hint` | string | `'Please select a country'` | Helper text |
|
|
25
|
+
| `placeholder` | string | `'Select a country'` | Placeholder in the input |
|
|
26
|
+
| `required` | boolean | `false` | Validation constraint |
|
|
27
|
+
|
|
28
|
+
## schmancy-select-timezones
|
|
29
|
+
Same pattern as countries, backed by timezone data.
|
|
30
|
+
|
|
31
|
+
```html
|
|
32
|
+
<schmancy-select-timezones
|
|
33
|
+
name="timezone"
|
|
34
|
+
label="Timezone"
|
|
35
|
+
value="Europe/Berlin"
|
|
36
|
+
></schmancy-select-timezones>
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
Accepts the same set of properties (`value`, `name`, `label`, `hint`, `placeholder`, `required`).
|
|
40
|
+
|
|
41
|
+
## Raw Data Exports
|
|
42
|
+
If you want the underlying data without the component:
|
|
43
|
+
```typescript
|
|
44
|
+
import countries from '@mhmo91/schmancy' // default export from countries.data
|
|
45
|
+
import timezones from '@mhmo91/schmancy' // default export from timezones.data
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
Each countries row: `{ code, name, dialCode?, flag?, ... }`. Timezones: `{ name, offset, label, ... }`.
|
|
49
|
+
|
|
50
|
+
## Form Integration
|
|
51
|
+
Both use `formAssociated = true` and register with the parent `<form>`. Works with native `form.checkValidity()` and with [`schmancy-form`](./form.md).
|
|
52
|
+
|
|
53
|
+
```html
|
|
54
|
+
<schmancy-form @submit=${this.onSubmit}>
|
|
55
|
+
<schmancy-select-countries name="country" required></schmancy-select-countries>
|
|
56
|
+
<schmancy-select-timezones name="timezone" required></schmancy-select-timezones>
|
|
57
|
+
<schmancy-button type="submit" variant="filled">Save</schmancy-button>
|
|
58
|
+
</schmancy-form>
|
|
59
|
+
```
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
# schmancy-float (deprecated alias)
|
|
2
|
+
|
|
3
|
+
> Backward-compatibility alias for [`schmancy-window`](./window.md). Existing code keeps working — new code should use `schmancy-window` directly.
|
|
4
|
+
|
|
5
|
+
## Migration
|
|
6
|
+
```html
|
|
7
|
+
<!-- Before -->
|
|
8
|
+
<schmancy-float id="panel">…</schmancy-float>
|
|
9
|
+
|
|
10
|
+
<!-- After -->
|
|
11
|
+
<schmancy-window id="panel">…</schmancy-window>
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
All properties are identical. See [window.md](./window.md) for full API.
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# schmancy-form
|
|
2
|
+
|
|
3
|
+
> Form container that collects data from child controls, validates, and emits submit/reset events.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
```html
|
|
7
|
+
<schmancy-form @submit=${(e) => handleSubmit(e.detail)}>
|
|
8
|
+
<schmancy-input name="email" label="Email" required></schmancy-input>
|
|
9
|
+
<schmancy-button type="submit">Submit</schmancy-button>
|
|
10
|
+
</schmancy-form>
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Properties
|
|
14
|
+
| Property | Type | Default | Description |
|
|
15
|
+
|----------|------|---------|-------------|
|
|
16
|
+
| novalidate | boolean | `false` | Skip validation on submit |
|
|
17
|
+
|
|
18
|
+
## Events
|
|
19
|
+
| Event | Detail | Description |
|
|
20
|
+
|-------|--------|-------------|
|
|
21
|
+
| submit | FormData | Form data from all child controls |
|
|
22
|
+
| reset | - | When the form is reset |
|
|
23
|
+
|
|
24
|
+
## Methods
|
|
25
|
+
| Method | Returns | Description |
|
|
26
|
+
|--------|---------|-------------|
|
|
27
|
+
| submit() | boolean | Validates and dispatches submit event. Returns false if invalid. |
|
|
28
|
+
| reset() | void | Resets all child controls to default values |
|
|
29
|
+
| getFormData() | FormData | Collects current form data without submitting |
|
|
30
|
+
| reportValidity() | boolean | Checks and shows validation on all controls |
|
|
31
|
+
|
|
32
|
+
## Examples
|
|
33
|
+
```html
|
|
34
|
+
<!-- Form with validation -->
|
|
35
|
+
<schmancy-form @submit=${(e) => save(e.detail)} @reset=${() => clearForm()}>
|
|
36
|
+
<schmancy-input name="name" label="Name" required></schmancy-input>
|
|
37
|
+
<schmancy-select name="role" label="Role" required>
|
|
38
|
+
<schmancy-option value="admin" label="Admin"></schmancy-option>
|
|
39
|
+
<schmancy-option value="user" label="User"></schmancy-option>
|
|
40
|
+
</schmancy-select>
|
|
41
|
+
<schmancy-checkbox name="active" label="Active"></schmancy-checkbox>
|
|
42
|
+
<div class="flex gap-2">
|
|
43
|
+
<schmancy-button type="submit">Save</schmancy-button>
|
|
44
|
+
<schmancy-button type="reset">Reset</schmancy-button>
|
|
45
|
+
</div>
|
|
46
|
+
</schmancy-form>
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
Submit triggers on Enter key in inputs or clicking a submit-type button.
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
# schmancy-icon
|
|
2
|
+
|
|
3
|
+
> Material Symbols icon with configurable fill, weight, grade, variant, and size tokens.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
```html
|
|
7
|
+
<schmancy-icon>settings</schmancy-icon>
|
|
8
|
+
```
|
|
9
|
+
|
|
10
|
+
## Properties
|
|
11
|
+
| Property | Type | Default | Description |
|
|
12
|
+
|----------|------|---------|-------------|
|
|
13
|
+
| icon | string | `undefined` | Icon name (alternative to slot content, translation-safe) |
|
|
14
|
+
| size | `'xxs'\|'xs'\|'sm'\|'md'\|'lg'\|string` | `'md'` | Icon size (12/16/20/24/32px or custom) |
|
|
15
|
+
| fill | number (0-1) | `0` | Fill level (0=outlined, 1=filled) |
|
|
16
|
+
| weight | number (100-700) | `400` | Stroke thickness |
|
|
17
|
+
| grade | number (-50 to 200) | `0` | Visual weight adjustment |
|
|
18
|
+
| variant | `'outlined'\|'rounded'\|'sharp'` | `'outlined'` | Icon style variant |
|
|
19
|
+
|
|
20
|
+
## Size Tokens
|
|
21
|
+
| Token | Size | Optical Size | Best For |
|
|
22
|
+
|-------|------|-------------|----------|
|
|
23
|
+
| xxs | 12px | 20 | Ultra-compact UIs |
|
|
24
|
+
| xs | 16px | 20 | 32px buttons |
|
|
25
|
+
| sm | 20px | 20 | 40px buttons |
|
|
26
|
+
| md | 24px | 24 | Default (48px buttons) |
|
|
27
|
+
| lg | 32px | 40 | 56px buttons |
|
|
28
|
+
|
|
29
|
+
## Examples
|
|
30
|
+
```html
|
|
31
|
+
<!-- Filled icon -->
|
|
32
|
+
<schmancy-icon .fill=${1}>favorite</schmancy-icon>
|
|
33
|
+
|
|
34
|
+
<!-- Large rounded icon -->
|
|
35
|
+
<schmancy-icon size="lg" variant="rounded">home</schmancy-icon>
|
|
36
|
+
|
|
37
|
+
<!-- Custom size -->
|
|
38
|
+
<schmancy-icon size="48px" .weight=${300}>search</schmancy-icon>
|
|
39
|
+
|
|
40
|
+
<!-- Translation-safe (use icon property instead of slot) -->
|
|
41
|
+
<schmancy-icon icon="delete"></schmancy-icon>
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Auto-loads Google Fonts on first use. Translation-protected via `translate="no"` and `notranslate` class.
|