@mhmo91/schmancy 0.10.35 → 0.10.37
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 +1165 -1109
- package/dist/SchmancyElement-BHfQg3Tj.cjs +2 -0
- package/dist/SchmancyElement-BHfQg3Tj.cjs.map +1 -0
- package/dist/SchmancyElement-CDT2q1lA.js +284 -0
- package/dist/SchmancyElement-CDT2q1lA.js.map +1 -0
- package/dist/agent/schmancy.agent.js +3488 -3290
- package/dist/agent/schmancy.agent.js.map +1 -1
- package/dist/agent/schmancy.manifest.json +335 -275
- package/dist/{area-DviXdbDx.js → area-KtULlxuA.js} +2 -2
- package/dist/{area-DviXdbDx.js.map → area-KtULlxuA.js.map} +1 -1
- package/dist/{area-CTSTgjlx.cjs → area-fdKhYB6T.cjs} +1 -1
- package/dist/{area-CTSTgjlx.cjs.map → area-fdKhYB6T.cjs.map} +1 -1
- package/dist/area.cjs +1 -1
- package/dist/area.js +1 -1
- package/dist/{audio-Q9oB_cQR.cjs → audio-CUMAv9D_.cjs} +1 -1
- package/dist/{audio-Q9oB_cQR.cjs.map → audio-CUMAv9D_.cjs.map} +1 -1
- package/dist/{audio-DFYoaw0M.js → audio-zIJVTo_V.js} +1 -1
- package/dist/{audio-DFYoaw0M.js.map → audio-zIJVTo_V.js.map} +1 -1
- package/dist/audio.cjs +1 -1
- package/dist/audio.js +2 -2
- package/dist/{autocomplete-DmLXJr7C.cjs → autocomplete-DEZk6wBD.cjs} +1 -1
- package/dist/{autocomplete-DmLXJr7C.cjs.map → autocomplete-DEZk6wBD.cjs.map} +1 -1
- package/dist/{autocomplete-BDvuma6D.js → autocomplete-DIScyo8Q.js} +3 -3
- package/dist/{autocomplete-BDvuma6D.js.map → autocomplete-DIScyo8Q.js.map} +1 -1
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/avatar.cjs +1 -1
- package/dist/avatar.js +3 -3
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/{boat-lr7MPZ7H.js → boat-BHPqSqJd.js} +67 -83
- package/dist/boat-BHPqSqJd.js.map +1 -0
- package/dist/boat-OBZ77exO.cjs +34 -0
- package/dist/boat-OBZ77exO.cjs.map +1 -0
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/breadcrumb.cjs +1 -1
- package/dist/breadcrumb.js +2 -2
- package/dist/{busy-CgzZbGfx.cjs → busy-BJNsKSCM.cjs} +1 -1
- package/dist/{busy-CgzZbGfx.cjs.map → busy-BJNsKSCM.cjs.map} +1 -1
- package/dist/{busy-DgQ4ux5N.js → busy-Dut78y4L.js} +2 -2
- package/dist/{busy-DgQ4ux5N.js.map → busy-Dut78y4L.js.map} +1 -1
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/{button-DFvR1iXX.cjs → button-DzlHLjWO.cjs} +1 -1
- package/dist/{button-DFvR1iXX.cjs.map → button-DzlHLjWO.cjs.map} +1 -1
- package/dist/{button-qbN1muQ0.js → button-kcpPQavY.js} +2 -2
- package/dist/{button-qbN1muQ0.js.map → button-kcpPQavY.js.map} +1 -1
- package/dist/button.cjs +4 -4
- package/dist/button.cjs.map +1 -1
- package/dist/button.js +16 -22
- package/dist/button.js.map +1 -1
- package/dist/{card-D_GlwZ5q.cjs → card-BLxPLqdQ.cjs} +1 -1
- package/dist/{card-D_GlwZ5q.cjs.map → card-BLxPLqdQ.cjs.map} +1 -1
- package/dist/{card-DAbr-7Vy.js → card-DxSKxCid.js} +2 -2
- package/dist/{card-DAbr-7Vy.js.map → card-DxSKxCid.js.map} +1 -1
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/{checkbox-BNORaxMF.js → checkbox-B1wiM3Dv.js} +2 -2
- package/dist/{checkbox-BNORaxMF.js.map → checkbox-B1wiM3Dv.js.map} +1 -1
- package/dist/{checkbox-BUY_uc_r.cjs → checkbox-BCLkhp5G.cjs} +1 -1
- package/dist/{checkbox-BUY_uc_r.cjs.map → checkbox-BCLkhp5G.cjs.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-CXZ4dJCK.cjs → chips-C9dS1WKn.cjs} +44 -33
- package/dist/chips-C9dS1WKn.cjs.map +1 -0
- package/dist/{chips-Dg6Lk6BT.js → chips-vWmwqQed.js} +145 -122
- package/dist/chips-vWmwqQed.js.map +1 -0
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +2 -2
- package/dist/connectivity.cjs +1 -1
- package/dist/connectivity.js +3 -3
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/{date-range-C-_be3_E.cjs → date-range-BV6HuvLw.cjs} +25 -19
- package/dist/date-range-BV6HuvLw.cjs.map +1 -0
- package/dist/{date-range-BU6WX7d5.js → date-range-D3ge1b4c.js} +129 -137
- package/dist/date-range-D3ge1b4c.js.map +1 -0
- package/dist/{date-range-inline-DJtUmHKF.cjs → date-range-inline-DpYgdLRv.cjs} +1 -1
- package/dist/{date-range-inline-DJtUmHKF.cjs.map → date-range-inline-DpYgdLRv.cjs.map} +1 -1
- package/dist/{date-range-inline-7o7xtVIu.js → date-range-inline-DuWQaWps.js} +2 -2
- package/dist/{date-range-inline-7o7xtVIu.js.map → date-range-inline-DuWQaWps.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 +1 -1
- package/dist/delay.js +2 -2
- package/dist/{details-EfbDPVEo.js → details-C-GZaq3j.js} +2 -2
- package/dist/{details-EfbDPVEo.js.map → details-C-GZaq3j.js.map} +1 -1
- package/dist/{details-Bs0MyyvF.cjs → details-Dp5rLIWk.cjs} +1 -1
- package/dist/{details-Bs0MyyvF.cjs.map → details-Dp5rLIWk.cjs.map} +1 -1
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{directives-fLwDj6b0.cjs → directives-D_l1E5H6.cjs} +3 -3
- package/dist/directives-D_l1E5H6.cjs.map +1 -0
- package/dist/{directives-zi1Mm2er.js → directives-DyS51FUh.js} +37 -21
- package/dist/directives-DyS51FUh.js.map +1 -0
- package/dist/directives.cjs +1 -1
- package/dist/directives.js +2 -2
- package/dist/{divider-CdIsWZrM.cjs → divider-CBnAmHMZ.cjs} +1 -1
- package/dist/{divider-CdIsWZrM.cjs.map → divider-CBnAmHMZ.cjs.map} +1 -1
- package/dist/{divider-CEPfrIwe.js → divider-nQffE0AD.js} +2 -2
- package/dist/{divider-CEPfrIwe.js.map → divider-nQffE0AD.js.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/dropdown.cjs +1 -1
- package/dist/dropdown.js +2 -2
- package/dist/{expand-g1vqqUp1.js → expand-DvTb-UPR.js} +3 -3
- package/dist/{expand-g1vqqUp1.js.map → expand-DvTb-UPR.js.map} +1 -1
- package/dist/{expand--at1k3qo.cjs → expand-mlP_3XWz.cjs} +1 -1
- package/dist/{expand--at1k3qo.cjs.map → expand-mlP_3XWz.cjs.map} +1 -1
- package/dist/expand.cjs +1 -1
- package/dist/expand.js +1 -1
- package/dist/fab.cjs +77 -0
- package/dist/fab.cjs.map +1 -0
- package/dist/fab.js +151 -0
- package/dist/fab.js.map +1 -0
- package/dist/{float-DxVzgI9o.js → float-C-Ko0Le3.js} +2 -2
- package/dist/{float-DxVzgI9o.js.map → float-C-Ko0Le3.js.map} +1 -1
- package/dist/{float-P9HukAm-.cjs → float-C17xgMT1.cjs} +1 -1
- package/dist/{float-P9HukAm-.cjs.map → float-C17xgMT1.cjs.map} +1 -1
- package/dist/float.cjs +1 -1
- package/dist/float.js +1 -1
- package/dist/{form-ByYhXe1p.cjs → form-CwPHcQYB.cjs} +1 -1
- package/dist/{form-ByYhXe1p.cjs.map → form-CwPHcQYB.cjs.map} +1 -1
- package/dist/{form-CqLaozHp.js → form-DA0hUu2h.js} +3 -3
- package/dist/{form-CqLaozHp.js.map → form-DA0hUu2h.js.map} +1 -1
- package/dist/form.cjs +6 -6
- package/dist/form.cjs.map +1 -1
- package/dist/form.js +25 -23
- package/dist/form.js.map +1 -1
- package/dist/handover/agent-runtime-followups.md +1 -1
- package/dist/handover/agent-runtime-v1.md +3 -3
- package/dist/{icons-CkphcMp6.js → icons-C6UfxmHZ.js} +2 -2
- package/dist/{icons-CkphcMp6.js.map → icons-C6UfxmHZ.js.map} +1 -1
- package/dist/{icons-DYtiRU5V.cjs → icons-CW3-oMSb.cjs} +1 -1
- package/dist/{icons-DYtiRU5V.cjs.map → icons-CW3-oMSb.cjs.map} +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/{iframe-CjqJksl8.js → iframe-BTjZfYyh.js} +2 -2
- package/dist/{iframe-CjqJksl8.js.map → iframe-BTjZfYyh.js.map} +1 -1
- package/dist/{iframe-C3trkP8q.cjs → iframe-wuYT2xFz.cjs} +1 -1
- package/dist/{iframe-C3trkP8q.cjs.map → iframe-wuYT2xFz.cjs.map} +1 -1
- package/dist/iframe.cjs +1 -1
- package/dist/iframe.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +57 -56
- package/dist/{input-CG51zDVh.js → input-B_4g2ulO.js} +2 -2
- package/dist/{input-CG51zDVh.js.map → input-B_4g2ulO.js.map} +1 -1
- package/dist/{input-DuavpwNL.cjs → input-BrDiIT60.cjs} +1 -1
- package/dist/{input-DuavpwNL.cjs.map → input-BrDiIT60.cjs.map} +1 -1
- package/dist/{input-chip-57tgNXKT.cjs → input-chip-B-XWh4aE.cjs} +1 -1
- package/dist/input-chip-B-XWh4aE.cjs.map +1 -0
- package/dist/{input-chip-C6Lq1927.js → input-chip-BlWhOruv.js} +2 -2
- package/dist/input-chip-BlWhOruv.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.js +3 -3
- package/dist/kbd.cjs +1 -1
- package/dist/kbd.js +2 -2
- package/dist/{layout-6ipbiWTl.cjs → layout-BhyIcEVu.cjs} +1 -1
- package/dist/{layout-6ipbiWTl.cjs.map → layout-BhyIcEVu.cjs.map} +1 -1
- package/dist/{layout-D4IOwx7p.js → layout-Dxit9enO.js} +1 -1
- package/dist/{layout-D4IOwx7p.js.map → layout-Dxit9enO.js.map} +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +2 -2
- package/dist/{lightbox-H8pVWGMX.cjs → lightbox-CVBogswK.cjs} +1 -1
- package/dist/{lightbox-H8pVWGMX.cjs.map → lightbox-CVBogswK.cjs.map} +1 -1
- package/dist/{lightbox-CsyO2XSr.js → lightbox-D85XAAuC.js} +2 -2
- package/dist/{lightbox-CsyO2XSr.js.map → lightbox-D85XAAuC.js.map} +1 -1
- package/dist/lightbox.cjs +1 -1
- package/dist/lightbox.js +1 -1
- package/dist/{list-BAwH0pQW.js → list-DOF_yVn5.js} +2 -2
- package/dist/{list-BAwH0pQW.js.map → list-DOF_yVn5.js.map} +1 -1
- package/dist/{list-Bs9m8kw7.cjs → list-nVjLskgx.cjs} +1 -1
- package/dist/{list-Bs9m8kw7.cjs.map → list-nVjLskgx.cjs.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{menu-BMcGzj1h.cjs → menu-DqmNjLgY.cjs} +1 -1
- package/dist/{menu-BMcGzj1h.cjs.map → menu-DqmNjLgY.cjs.map} +1 -1
- package/dist/{menu-tQVARVaC.js → menu-QrAK5Uu9.js} +3 -3
- package/dist/{menu-tQVARVaC.js.map → menu-QrAK5Uu9.js.map} +1 -1
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/{mixins-Bp0wIHg2.js → mixins-De1zjyhy.js} +1 -1
- package/dist/{mixins-Bp0wIHg2.js.map → mixins-De1zjyhy.js.map} +1 -1
- package/dist/{mixins-CGXSzZc7.cjs → mixins-DxHpyMHA.cjs} +1 -1
- package/dist/{mixins-CGXSzZc7.cjs.map → mixins-DxHpyMHA.cjs.map} +1 -1
- package/dist/mixins.cjs +1 -1
- package/dist/mixins.js +2 -2
- 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 +1 -1
- package/dist/navigation-rail.js +2 -2
- package/dist/{notification-D1tX2nx5.js → notification-BtAK7NK8.js} +4 -4
- package/dist/{notification-D1tX2nx5.js.map → notification-BtAK7NK8.js.map} +1 -1
- package/dist/{notification-Bz00zdpV.cjs → notification-DYzbUb5C.cjs} +1 -1
- package/dist/{notification-Bz00zdpV.cjs.map → notification-DYzbUb5C.cjs.map} +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/{option-BpGV8Apj.js → option-DHwA0miA.js} +2 -2
- package/dist/{option-BpGV8Apj.js.map → option-DHwA0miA.js.map} +1 -1
- package/dist/{option-BnybLEDO.cjs → option-DnSPa8ro.cjs} +1 -1
- package/dist/{option-BnybLEDO.cjs.map → option-DnSPa8ro.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{overlay-UQR2Dy3u.cjs → overlay-BVkqZmoS.cjs} +5 -5
- package/dist/overlay-BVkqZmoS.cjs.map +1 -0
- package/dist/{overlay-BpNhd74N.js → overlay-Del1sBEB.js} +108 -108
- package/dist/overlay-Del1sBEB.js.map +1 -0
- package/dist/overlay.cjs +1 -1
- package/dist/{overlay.confirm-body-CVDtVk5X.cjs → overlay.confirm-body-BV9umTAl.cjs} +1 -1
- package/dist/{overlay.confirm-body-CVDtVk5X.cjs.map → overlay.confirm-body-BV9umTAl.cjs.map} +1 -1
- package/dist/{overlay.confirm-body-BHcXu5Wk.js → overlay.confirm-body-DSONXUzl.js} +6 -6
- package/dist/{overlay.confirm-body-BHcXu5Wk.js.map → overlay.confirm-body-DSONXUzl.js.map} +1 -1
- package/dist/overlay.js +3 -3
- package/dist/{overlay.service-DTE6NwIM.js → overlay.service-BTp5Oq7f.js} +2 -2
- package/dist/{overlay.service-DTE6NwIM.js.map → overlay.service-BTp5Oq7f.js.map} +1 -1
- package/dist/{overlay.service-C8RsQzgM.cjs → overlay.service-XLlrsSdA.cjs} +1 -1
- package/dist/{overlay.service-C8RsQzgM.cjs.map → overlay.service-XLlrsSdA.cjs.map} +1 -1
- package/dist/{progress-gbIALDRs.cjs → progress-DUbTL9g9.cjs} +1 -1
- package/dist/{progress-gbIALDRs.cjs.map → progress-DUbTL9g9.cjs.map} +1 -1
- package/dist/{progress-CAKsxp29.js → progress-DYA83CFU.js} +2 -2
- package/dist/{progress-CAKsxp29.js.map → progress-DYA83CFU.js.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/{radio-group-CfJ5DtI4.cjs → radio-group-B-ORNtvR.cjs} +1 -1
- package/dist/{radio-group-CfJ5DtI4.cjs.map → radio-group-B-ORNtvR.cjs.map} +1 -1
- package/dist/{radio-group-otyvZvUk.js → radio-group-DxX0iJBo.js} +2 -2
- package/dist/{radio-group-otyvZvUk.js.map → radio-group-DxX0iJBo.js.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/range.cjs +1 -1
- package/dist/range.js +2 -2
- package/dist/{select-81jniVTs.cjs → select-B9uj_u-s.cjs} +1 -1
- package/dist/{select-81jniVTs.cjs.map → select-B9uj_u-s.cjs.map} +1 -1
- package/dist/{select-9vXx1fhr.js → select-C7gkA-ab.js} +3 -3
- package/dist/{select-9vXx1fhr.js.map → select-C7gkA-ab.js.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/skeleton.cjs +1 -1
- package/dist/skeleton.js +2 -2
- package/dist/skills/INDEX.md +1 -1
- package/dist/skills/SKILL.md +20 -18
- package/dist/skills/boat.md +21 -15
- package/dist/skills/fab.md +75 -0
- package/dist/skills/schmancy/INDEX.md +1 -1
- package/dist/skills/schmancy/SKILL.md +20 -18
- package/dist/skills/schmancy/boat.md +21 -15
- package/dist/skills/schmancy/fab.md +75 -0
- package/dist/skills/schmancy/steps.md +68 -34
- package/dist/skills/schmancy/theme.md +1 -1
- package/dist/skills/steps.md +68 -34
- package/dist/skills/theme.md +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +2 -2
- package/dist/{sound.service-CmIw63aM.cjs → sound.service-C7FDY_yD.cjs} +1 -1
- package/dist/{sound.service-CmIw63aM.cjs.map → sound.service-C7FDY_yD.cjs.map} +1 -1
- package/dist/{sound.service-D3ZSq1Kj.js → sound.service-O0232os6.js} +1 -1
- package/dist/{sound.service-D3ZSq1Kj.js.map → sound.service-O0232os6.js.map} +1 -1
- package/dist/{splash-screen-C5KAWXvA.cjs → splash-screen-DIS4odDr.cjs} +1 -1
- package/dist/{splash-screen-C5KAWXvA.cjs.map → splash-screen-DIS4odDr.cjs.map} +1 -1
- package/dist/{splash-screen-BOjrmGLk.js → splash-screen-jfE47xl0.js} +2 -2
- package/dist/{splash-screen-BOjrmGLk.js.map → splash-screen-jfE47xl0.js.map} +1 -1
- package/dist/splash-screen.cjs +1 -1
- package/dist/splash-screen.js +1 -1
- package/dist/{src-C5g3p1J5.js → src-BP3h-9d9.js} +36 -35
- package/dist/{src-C5g3p1J5.js.map → src-BP3h-9d9.js.map} +1 -1
- package/dist/{src-qzUpLbje.cjs → src-Um_pzb-U.cjs} +1 -1
- package/dist/{src-qzUpLbje.cjs.map → src-Um_pzb-U.cjs.map} +1 -1
- package/dist/{state-Cex3rmx2.cjs → state-Bj0M9a6T.cjs} +1 -1
- package/dist/{state-Cex3rmx2.cjs.map → state-Bj0M9a6T.cjs.map} +1 -1
- package/dist/{state-CWBRTSvE.js → state-DscWQpoM.js} +1 -1
- package/dist/{state-CWBRTSvE.js.map → state-DscWQpoM.js.map} +1 -1
- package/dist/state.cjs +1 -1
- package/dist/state.js +2 -2
- package/dist/steps.cjs +35 -19
- package/dist/steps.cjs.map +1 -1
- package/dist/steps.js +96 -73
- package/dist/steps.js.map +1 -1
- package/dist/{surface-9S5scTsD.js → surface-B4Wn4SOO.js} +2 -2
- package/dist/{surface-9S5scTsD.js.map → surface-B4Wn4SOO.js.map} +1 -1
- package/dist/{surface-PfiejLuw.cjs → surface-DRq6cVW6.cjs} +1 -1
- package/dist/{surface-PfiejLuw.cjs.map → surface-DRq6cVW6.cjs.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/switch.cjs +1 -1
- package/dist/switch.js +2 -2
- package/dist/table.cjs +1 -1
- package/dist/table.js +2 -2
- package/dist/{tabs-uYvb1P06.cjs → tabs-Ca_fbHPW.cjs} +1 -1
- package/dist/{tabs-uYvb1P06.cjs.map → tabs-Ca_fbHPW.cjs.map} +1 -1
- package/dist/{tabs-BBOjAmgG.js → tabs-CnQPo-XS.js} +2 -2
- package/dist/{tabs-BBOjAmgG.js.map → tabs-CnQPo-XS.js.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-QzSj8Dkl.js → textarea-BvqENhTW.js} +2 -2
- package/dist/{textarea-QzSj8Dkl.js.map → textarea-BvqENhTW.js.map} +1 -1
- package/dist/{textarea-YPHX4g7Y.cjs → textarea-qr7oL8oU.cjs} +1 -1
- package/dist/{textarea-YPHX4g7Y.cjs.map → textarea-qr7oL8oU.cjs.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/theme-BSwJ2YZo.cjs +181 -0
- package/dist/{theme-iKUaS9JB.cjs.map → theme-BSwJ2YZo.cjs.map} +1 -1
- package/dist/{theme-C2Mp-VGt.js → theme-BV0EzHQ1.js} +6 -5
- package/dist/{theme-C2Mp-VGt.js.map → theme-BV0EzHQ1.js.map} +1 -1
- package/dist/{theme-button-CJmhxfMe.cjs → theme-button-C6fpUzPM.cjs} +1 -1
- package/dist/{theme-button-CJmhxfMe.cjs.map → theme-button-C6fpUzPM.cjs.map} +1 -1
- package/dist/{theme-button-DGWAXhzd.js → theme-button-O_xNCgI7.js} +2 -2
- package/dist/{theme-button-DGWAXhzd.js.map → theme-button-O_xNCgI7.js.map} +1 -1
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/theme.js +3 -3
- package/dist/{theme.service-hc4N-1Oz.js → theme.service-DwLhhOmP.js} +1 -1
- package/dist/{theme.service-hc4N-1Oz.js.map → theme.service-DwLhhOmP.js.map} +1 -1
- package/dist/{theme.service-p61RsJBF.cjs → theme.service-kn9MC025.cjs} +1 -1
- package/dist/{theme.service-p61RsJBF.cjs.map → theme.service-kn9MC025.cjs.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +2 -2
- package/dist/{typography-DwV0sqht.js → typography-Dtdooaic.js} +2 -2
- package/dist/{typography-DwV0sqht.js.map → typography-Dtdooaic.js.map} +1 -1
- package/dist/{typography-Bdt8RlX2.cjs → typography-opFYuUYS.cjs} +1 -1
- package/dist/{typography-Bdt8RlX2.cjs.map → typography-opFYuUYS.cjs.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/dist/visually-hidden.cjs +1 -1
- package/dist/visually-hidden.js +2 -2
- package/dist/{window-D2WfvNng.cjs → window-BSAemI9J.cjs} +1 -1
- package/dist/{window-D2WfvNng.cjs.map → window-BSAemI9J.cjs.map} +1 -1
- package/dist/{window-n4jN60B_.js → window-ConcHirJ.js} +3 -3
- package/dist/{window-n4jN60B_.js.map → window-ConcHirJ.js.map} +1 -1
- package/dist/window.cjs +1 -1
- package/dist/window.js +1 -1
- package/package.json +1 -1
- package/skills/schmancy/INDEX.md +1 -1
- package/skills/schmancy/SKILL.md +20 -18
- package/skills/schmancy/boat.md +21 -15
- package/skills/schmancy/fab.md +75 -0
- package/skills/schmancy/steps.md +68 -34
- package/skills/schmancy/theme.md +1 -1
- package/src/CLAUDE.md +22 -16
- package/src/boat/boat.test.ts +130 -0
- package/src/boat/boat.ts +144 -121
- package/src/button/icon-button.ts +18 -30
- package/src/chips/assist-chip.ts +2 -263
- package/src/chips/chips.ts +2 -259
- package/src/chips/filter-chip.ts +2 -255
- package/src/chips/index.ts +2 -5
- package/src/chips/input-chip.ts +2 -413
- package/src/chips/suggestion-chip.ts +2 -266
- package/src/directives/fill.ts +28 -5
- package/src/directives/reveal.ts +192 -118
- package/src/fab/fab.test.ts +101 -0
- package/src/fab/fab.ts +226 -0
- package/src/fab/index.ts +1 -0
- package/src/form/fields/chips/assist-chip.ts +263 -0
- package/src/form/fields/chips/chips.ts +234 -0
- package/src/form/fields/chips/filter-chip.ts +255 -0
- package/src/form/fields/chips/index.ts +5 -0
- package/src/form/fields/chips/input-chip.ts +413 -0
- package/src/form/fields/chips/suggestion-chip.ts +266 -0
- package/src/form/fields/date-range/date-range.test.ts +44 -0
- package/src/form/fields/date-range/date-range.ts +103 -97
- package/src/form/fields/index.ts +1 -0
- package/src/index.ts +2 -1
- package/src/overlay/overlay.animations.ts +2 -3
- package/src/overlay/overlay.component.ts +8 -4
- package/src/overlay/overlay.types.ts +14 -2
- package/src/steps/index.ts +1 -1
- package/src/steps/schmancy-step.ts +91 -65
- package/src/steps/{schmancy-steps-container.ts → schmancy-steps.ts} +18 -38
- package/src/steps/steps.context.ts +5 -4
- package/src/steps/steps.test.ts +120 -0
- package/src/theme/theme.component.ts +1 -0
- package/src/theme/theme.style.css +3 -0
- package/types/src/boat/boat.d.ts +27 -9
- package/types/src/boat/boat.test.d.ts +2 -0
- package/types/src/button/icon-button.d.ts +3 -2
- package/types/src/chips/assist-chip.d.ts +1 -47
- package/types/src/chips/chips.d.ts +1 -43
- package/types/src/chips/filter-chip.d.ts +1 -67
- package/types/src/chips/index.d.ts +1 -5
- package/types/src/chips/input-chip.d.ts +1 -82
- package/types/src/chips/suggestion-chip.d.ts +1 -52
- package/types/src/directives/reveal.d.ts +15 -5
- package/types/src/fab/fab.d.ts +80 -0
- package/types/src/fab/fab.test.d.ts +2 -0
- package/types/src/fab/index.d.ts +1 -0
- package/types/src/form/fields/chips/assist-chip.d.ts +47 -0
- package/types/src/form/fields/chips/chips.d.ts +35 -0
- package/types/src/form/fields/chips/filter-chip.d.ts +67 -0
- package/types/src/form/fields/chips/index.d.ts +5 -0
- package/types/src/form/fields/chips/input-chip.d.ts +82 -0
- package/types/src/form/fields/chips/suggestion-chip.d.ts +52 -0
- package/types/src/form/fields/date-range/date-range.d.ts +5 -10
- package/types/src/form/fields/index.d.ts +1 -0
- package/types/src/index.d.ts +2 -1
- package/types/src/overlay/overlay.component.d.ts +1 -0
- package/types/src/overlay/overlay.types.d.ts +12 -2
- package/types/src/steps/index.d.ts +1 -1
- package/types/src/steps/schmancy-step.d.ts +8 -23
- package/types/src/steps/{schmancy-steps-container.d.ts → schmancy-steps.d.ts} +8 -9
- package/types/src/steps/steps.context.d.ts +2 -1
- package/types/src/steps/steps.test.d.ts +2 -0
- package/types/src/theme/theme.component.d.ts +1 -0
- package/dist/SchmancyElement-CA0Wqt8m.js +0 -284
- package/dist/SchmancyElement-CA0Wqt8m.js.map +0 -1
- package/dist/SchmancyElement-CYIif26I.cjs +0 -2
- package/dist/SchmancyElement-CYIif26I.cjs.map +0 -1
- package/dist/boat-Vqjgo10B.cjs +0 -33
- package/dist/boat-Vqjgo10B.cjs.map +0 -1
- package/dist/boat-lr7MPZ7H.js.map +0 -1
- package/dist/chips-CXZ4dJCK.cjs.map +0 -1
- package/dist/chips-Dg6Lk6BT.js.map +0 -1
- package/dist/date-range-BU6WX7d5.js.map +0 -1
- package/dist/date-range-C-_be3_E.cjs.map +0 -1
- package/dist/directives-fLwDj6b0.cjs.map +0 -1
- package/dist/directives-zi1Mm2er.js.map +0 -1
- package/dist/input-chip-57tgNXKT.cjs.map +0 -1
- package/dist/input-chip-C6Lq1927.js.map +0 -1
- package/dist/overlay-BpNhd74N.js.map +0 -1
- package/dist/overlay-UQR2Dy3u.cjs.map +0 -1
- package/dist/theme-iKUaS9JB.cjs +0 -181
package/src/chips/chips.ts
CHANGED
|
@@ -1,259 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { customElement, property, queryAssignedElements } from 'lit/decorators.js'
|
|
4
|
-
import { BehaviorSubject, combineLatest } from 'rxjs'
|
|
5
|
-
import { debounceTime, distinctUntilChanged, takeUntil } from 'rxjs/operators'
|
|
6
|
-
import { fullWidth } from '../directives/layout'
|
|
7
|
-
import type { FilterChipChangeEvent as SchmancyChipChangeEvent } from './filter-chip'
|
|
8
|
-
import { SchmancyFilterChip as SchmancyChip } from './filter-chip'
|
|
9
|
-
|
|
10
|
-
@customElement('schmancy-chips')
|
|
11
|
-
export default class SchmancyChips extends SchmancyElement {
|
|
12
|
-
static styles = [css`
|
|
13
|
-
:host{
|
|
14
|
-
display:block;
|
|
15
|
-
height:fit-content;
|
|
16
|
-
width:fit-content;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
`]
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
// RxJS state streams - initialized with undefined to detect if properties were set
|
|
23
|
-
private value$ = new BehaviorSubject<string>('')
|
|
24
|
-
private values$ = new BehaviorSubject<string[]>([])
|
|
25
|
-
|
|
26
|
-
// Track if properties were initialized from attributes/properties
|
|
27
|
-
private _value: string = ''
|
|
28
|
-
private _values: string[] = []
|
|
29
|
-
private _multi: boolean = false
|
|
30
|
-
|
|
31
|
-
// Track if properties have been explicitly set
|
|
32
|
-
private _valueSet: boolean = false
|
|
33
|
-
private _valuesSet: boolean = false
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* @deprecated Use .values for multi-selection or .value for single-selection instead.
|
|
37
|
-
* The mode is now automatically determined based on which property is used.
|
|
38
|
-
*/
|
|
39
|
-
@property({
|
|
40
|
-
type: Boolean,
|
|
41
|
-
reflect: true,
|
|
42
|
-
})
|
|
43
|
-
get multi(): boolean {
|
|
44
|
-
return this._multi
|
|
45
|
-
}
|
|
46
|
-
set multi(value: boolean) {
|
|
47
|
-
this._multi = value
|
|
48
|
-
// Note: We don't update any BehaviorSubject here as mode is now computed
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Automatically determines the selection mode based on which properties are in use
|
|
53
|
-
*/
|
|
54
|
-
private get mode(): 'multi' | 'single' | 'none' {
|
|
55
|
-
// Check if values array is being used (explicitly set)
|
|
56
|
-
if (this._valuesSet) {
|
|
57
|
-
return 'multi'
|
|
58
|
-
}
|
|
59
|
-
// Check if value string is being used (explicitly set)
|
|
60
|
-
if (this._valueSet) {
|
|
61
|
-
return 'single'
|
|
62
|
-
}
|
|
63
|
-
// Check if either property has been set via attributes
|
|
64
|
-
if (this.hasAttribute('values')) {
|
|
65
|
-
return 'multi'
|
|
66
|
-
}
|
|
67
|
-
if (this.hasAttribute('value')) {
|
|
68
|
-
return 'single'
|
|
69
|
-
}
|
|
70
|
-
// Fallback to deprecated multi prop for backward compatibility
|
|
71
|
-
if (this._multi === true) {
|
|
72
|
-
return 'multi'
|
|
73
|
-
}
|
|
74
|
-
// Default to none (no selection management)
|
|
75
|
-
return 'none'
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
@property({
|
|
79
|
-
type: Array,
|
|
80
|
-
reflect: true,
|
|
81
|
-
})
|
|
82
|
-
get values(): string[] {
|
|
83
|
-
return this._values
|
|
84
|
-
}
|
|
85
|
-
set values(value: string[]) {
|
|
86
|
-
this._values = value || []
|
|
87
|
-
this._valuesSet = true // Mark that values has been explicitly set
|
|
88
|
-
this.values$.next(this._values)
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
@property({
|
|
92
|
-
type: String,
|
|
93
|
-
reflect: true,
|
|
94
|
-
})
|
|
95
|
-
get value(): string {
|
|
96
|
-
return this._value
|
|
97
|
-
}
|
|
98
|
-
set value(value: string) {
|
|
99
|
-
this._value = value || ''
|
|
100
|
-
this._valueSet = true // Mark that value has been explicitly set
|
|
101
|
-
this.value$.next(this._value)
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
@queryAssignedElements({
|
|
105
|
-
selector:
|
|
106
|
-
'schmancy-chip, schmancy-filter-chip, schmancy-assist-chip, schmancy-input-chip, schmancy-suggestion-chip',
|
|
107
|
-
flatten: true,
|
|
108
|
-
})
|
|
109
|
-
chips!: (SchmancyChip | HTMLElement)[]
|
|
110
|
-
|
|
111
|
-
@property({
|
|
112
|
-
type: Boolean,
|
|
113
|
-
reflect: true,
|
|
114
|
-
})
|
|
115
|
-
wrap: boolean = false
|
|
116
|
-
|
|
117
|
-
@property({
|
|
118
|
-
type: Boolean,
|
|
119
|
-
reflect: true,
|
|
120
|
-
})
|
|
121
|
-
required: boolean = false
|
|
122
|
-
|
|
123
|
-
@property({
|
|
124
|
-
type: String,
|
|
125
|
-
reflect: true,
|
|
126
|
-
})
|
|
127
|
-
justify: 'start' | 'center' | 'end' = 'start'
|
|
128
|
-
|
|
129
|
-
connectedCallback() {
|
|
130
|
-
super.connectedCallback()
|
|
131
|
-
|
|
132
|
-
// Initialize BehaviorSubjects with current property values
|
|
133
|
-
// This ensures properties set before connectedCallback are respected
|
|
134
|
-
this.value$.next(this._value)
|
|
135
|
-
this.values$.next(this._values)
|
|
136
|
-
|
|
137
|
-
// Set up reactive pipeline for state synchronization
|
|
138
|
-
combineLatest([
|
|
139
|
-
this.value$.pipe(distinctUntilChanged()),
|
|
140
|
-
this.values$.pipe(
|
|
141
|
-
distinctUntilChanged((prev, curr) => prev.length === curr.length && prev.every((v, i) => v === curr[i])),
|
|
142
|
-
),
|
|
143
|
-
])
|
|
144
|
-
.pipe(
|
|
145
|
-
debounceTime(0), // Ensure DOM is ready
|
|
146
|
-
takeUntil(this.disconnecting),
|
|
147
|
-
)
|
|
148
|
-
.subscribe(([value, values]) => {
|
|
149
|
-
// Reactively update chip states based on container state and auto-detected mode
|
|
150
|
-
this.updateChipStates(this.mode, value, values)
|
|
151
|
-
})
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
private updateChipStates(mode: 'multi' | 'single' | 'none', value: string, values: string[]) {
|
|
155
|
-
if (!this.chips) return
|
|
156
|
-
|
|
157
|
-
// If mode is 'none', don't manage selection state
|
|
158
|
-
if (mode === 'none') return
|
|
159
|
-
|
|
160
|
-
this.chips.forEach(chip => {
|
|
161
|
-
if ('value' in chip && 'selected' in chip) {
|
|
162
|
-
const filterChip = chip as SchmancyChip
|
|
163
|
-
if (mode === 'multi') {
|
|
164
|
-
// In multi mode: only select if values array explicitly includes this chip's value
|
|
165
|
-
filterChip.selected = values.length > 0 && values.includes(filterChip.value)
|
|
166
|
-
} else if (mode === 'single') {
|
|
167
|
-
// In single mode: only select if value is non-empty AND matches this chip's value
|
|
168
|
-
// This prevents chips from being selected when value is empty string
|
|
169
|
-
filterChip.selected = value !== '' && value === filterChip.value
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
})
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
async change(e: CustomEvent<SchmancyChipChangeEvent>) {
|
|
176
|
-
e.preventDefault()
|
|
177
|
-
e.stopPropagation()
|
|
178
|
-
|
|
179
|
-
// If mode is 'none', don't handle selection changes
|
|
180
|
-
if (this.mode === 'none') return
|
|
181
|
-
|
|
182
|
-
const { value, selected } = e.detail
|
|
183
|
-
|
|
184
|
-
// Update the reactive streams and internal tracking, which will trigger state synchronization
|
|
185
|
-
if (this.mode === 'multi') {
|
|
186
|
-
if (selected) {
|
|
187
|
-
// Add value if not already present
|
|
188
|
-
if (!this._values.includes(value)) {
|
|
189
|
-
this._values = [...this._values, value]
|
|
190
|
-
this.values$.next(this._values)
|
|
191
|
-
}
|
|
192
|
-
} else {
|
|
193
|
-
// Remove value
|
|
194
|
-
this._values = this._values.filter(v => v !== value)
|
|
195
|
-
this.values$.next(this._values)
|
|
196
|
-
}
|
|
197
|
-
} else if (this.mode === 'single') {
|
|
198
|
-
if (selected) {
|
|
199
|
-
this._value = value
|
|
200
|
-
} else if (!this.required) {
|
|
201
|
-
// Allow deselection if not required
|
|
202
|
-
this._value = ''
|
|
203
|
-
} else {
|
|
204
|
-
// Required mode - ignore deselection
|
|
205
|
-
return
|
|
206
|
-
}
|
|
207
|
-
this.value$.next(this._value)
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
// Request update to trigger re-render and property reflection
|
|
211
|
-
this.requestUpdate()
|
|
212
|
-
|
|
213
|
-
// Dispatch change event with appropriate detail based on mode
|
|
214
|
-
this.dispatchEvent(
|
|
215
|
-
new CustomEvent<SchmancyChipsChangeEvent>('change', {
|
|
216
|
-
detail: this.mode === 'multi' ? this._values : this._value,
|
|
217
|
-
bubbles: true,
|
|
218
|
-
}),
|
|
219
|
-
)
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
protected firstUpdated(_changedProperties: PropertyValues): void {
|
|
223
|
-
super.firstUpdated(_changedProperties)
|
|
224
|
-
// Initial state synchronization will happen through the reactive pipeline
|
|
225
|
-
// Force an initial update to ensure chips are synchronized
|
|
226
|
-
this.updateChipStates(this.mode, this._value, this._values)
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
protected render(): unknown {
|
|
230
|
-
const classes = {
|
|
231
|
-
'flex flex-nowrap justify-center gap-2': true,
|
|
232
|
-
'flex-wrap': this.wrap,
|
|
233
|
-
'justify-center': this.justify === 'center',
|
|
234
|
-
}
|
|
235
|
-
return html`
|
|
236
|
-
<schmancy-scroll
|
|
237
|
-
hide
|
|
238
|
-
.direction=${this.wrap ? 'vertical' : 'horizontal'}
|
|
239
|
-
class="${this.classMap(classes)}"
|
|
240
|
-
${fullWidth()}
|
|
241
|
-
@change=${this.change}
|
|
242
|
-
>
|
|
243
|
-
<slot
|
|
244
|
-
@slotchange=${() => {
|
|
245
|
-
// When slot changes, trigger state update through reactive pipeline
|
|
246
|
-
this.updateChipStates(this.mode, this._value, this._values)
|
|
247
|
-
}}
|
|
248
|
-
></slot>
|
|
249
|
-
</schmancy-scroll>
|
|
250
|
-
`
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
declare global {
|
|
255
|
-
interface HTMLElementTagNameMap {
|
|
256
|
-
'schmancy-chips': SchmancyChips
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
export type SchmancyChipsChangeEvent = string | Array<string>
|
|
1
|
+
// Moved to src/form/fields/chips/ — this is a backward-compat re-export shim.
|
|
2
|
+
export * from '../form/fields/chips/chips';
|
package/src/chips/filter-chip.ts
CHANGED
|
@@ -1,255 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { property } from 'lit/decorators.js'
|
|
4
|
-
import { magnetic } from '../directives/magnetic'
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Filter chip component for content filtering.
|
|
8
|
-
*
|
|
9
|
-
* Filter chips are the ONLY chip type that maintains persistent selected state.
|
|
10
|
-
* They are used for filtering content by toggling on/off different filter criteria.
|
|
11
|
-
*
|
|
12
|
-
* @fires change - Dispatched when selection state changes with {value, selected}
|
|
13
|
-
* @fires remove - Dispatched when remove button is clicked (if removable)
|
|
14
|
-
*
|
|
15
|
-
* @example
|
|
16
|
-
* ```html
|
|
17
|
-
* <schmancy-filter-chip value="category-1" selected>
|
|
18
|
-
* Category 1
|
|
19
|
-
* </schmancy-filter-chip>
|
|
20
|
-
* ```
|
|
21
|
-
*/
|
|
22
|
-
export class SchmancyFilterChip extends SchmancyElement {
|
|
23
|
-
static styles = [css`
|
|
24
|
-
:host {
|
|
25
|
-
display: inline-flex;
|
|
26
|
-
outline: none;
|
|
27
|
-
border-radius: 0.5rem;
|
|
28
|
-
transition: transform 200ms cubic-bezier(0.34, 1.56, 0.64, 1);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
:host(:active:not([disabled])) {
|
|
32
|
-
transform: scale(0.95);
|
|
33
|
-
transition-duration: 100ms;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
:host([disabled]) {
|
|
37
|
-
pointer-events: none;
|
|
38
|
-
opacity: var(--schmancy-sys-state-disabled-opacity);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
@media (prefers-reduced-motion: reduce) {
|
|
42
|
-
:host { transition: none; }
|
|
43
|
-
:host(:active:not([disabled])) { transform: none; }
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
button {
|
|
47
|
-
font-family: inherit;
|
|
48
|
-
}
|
|
49
|
-
`];
|
|
50
|
-
/** Unique identifier for this filter chip */
|
|
51
|
-
@property({ type: String, reflect: true })
|
|
52
|
-
value: string = ''
|
|
53
|
-
|
|
54
|
-
/** Whether the filter chip is selected (active filter) */
|
|
55
|
-
private _selected: boolean = false
|
|
56
|
-
|
|
57
|
-
@property({ type: Boolean, reflect: true })
|
|
58
|
-
get selected(): boolean {
|
|
59
|
-
return this._selected
|
|
60
|
-
}
|
|
61
|
-
set selected(value: boolean) {
|
|
62
|
-
const oldValue = this._selected
|
|
63
|
-
this._selected = value
|
|
64
|
-
this.requestUpdate('selected', oldValue)
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/** Whether to show a remove button */
|
|
68
|
-
@property({ type: Boolean, reflect: true })
|
|
69
|
-
removable: boolean = false
|
|
70
|
-
|
|
71
|
-
/** Whether the chip is disabled */
|
|
72
|
-
@property({ type: Boolean, reflect: true })
|
|
73
|
-
disabled: boolean = false
|
|
74
|
-
|
|
75
|
-
/** Whether to use elevated style with shadow */
|
|
76
|
-
@property({ type: Boolean, reflect: true })
|
|
77
|
-
elevated: boolean = false
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
constructor() {
|
|
81
|
-
super()
|
|
82
|
-
try {
|
|
83
|
-
this.internals = this.attachInternals()
|
|
84
|
-
} catch {
|
|
85
|
-
this.internals = undefined
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
protected static shadowRootOptions = {
|
|
90
|
-
...LitElement.shadowRootOptions,
|
|
91
|
-
delegatesFocus: true,
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
static formAssociated = true
|
|
95
|
-
internals: ElementInternals | undefined
|
|
96
|
-
get form() {
|
|
97
|
-
return this.internals?.form
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
connectedCallback() {
|
|
101
|
-
super.connectedCallback()
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
protected updated(changed: Map<string, unknown>) {
|
|
105
|
-
super.updated?.(changed)
|
|
106
|
-
if (changed.has('value') || changed.has('selected')) {
|
|
107
|
-
this.internals?.setFormValue(this._selected ? (this.value || 'on') : null)
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
formResetCallback(): void {
|
|
112
|
-
this._selected = this.hasAttribute('selected')
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
formDisabledCallback(disabled: boolean): void {
|
|
116
|
-
this.disabled = disabled
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
private handleClick = () => {
|
|
120
|
-
if (this.disabled) return
|
|
121
|
-
|
|
122
|
-
this.dispatchEvent(
|
|
123
|
-
new CustomEvent('change', {
|
|
124
|
-
detail: { value: this.value, selected: !this._selected },
|
|
125
|
-
bubbles: true,
|
|
126
|
-
composed: true,
|
|
127
|
-
}),
|
|
128
|
-
)
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
private handleRemove = (e: Event) => {
|
|
132
|
-
if (this.disabled) return
|
|
133
|
-
|
|
134
|
-
e.stopPropagation()
|
|
135
|
-
|
|
136
|
-
this.dispatchEvent(
|
|
137
|
-
new CustomEvent('remove', {
|
|
138
|
-
detail: { value: this.value },
|
|
139
|
-
bubbles: true,
|
|
140
|
-
composed: true,
|
|
141
|
-
}),
|
|
142
|
-
)
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
private handleKeyDown = (e: KeyboardEvent) => {
|
|
146
|
-
if (this.disabled) return
|
|
147
|
-
|
|
148
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
|
149
|
-
e.preventDefault()
|
|
150
|
-
this.dispatchEvent(
|
|
151
|
-
new CustomEvent('change', {
|
|
152
|
-
detail: { value: this.value, selected: !this._selected },
|
|
153
|
-
bubbles: true,
|
|
154
|
-
composed: true,
|
|
155
|
-
}),
|
|
156
|
-
)
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
protected render(): unknown {
|
|
162
|
-
const chipClasses = {
|
|
163
|
-
'inline-flex': true,
|
|
164
|
-
'items-center': true,
|
|
165
|
-
'gap-2': true,
|
|
166
|
-
'rounded-lg': true,
|
|
167
|
-
'h-8 px-4': true,
|
|
168
|
-
'cursor-pointer': !this.disabled,
|
|
169
|
-
'transition-all': true,
|
|
170
|
-
'duration-200': true,
|
|
171
|
-
'select-none': true,
|
|
172
|
-
'text-sm': true,
|
|
173
|
-
'font-medium': true,
|
|
174
|
-
'relative': true,
|
|
175
|
-
'min-h-[32px]': true,
|
|
176
|
-
|
|
177
|
-
// Background and text colors based on selection state
|
|
178
|
-
'bg-secondary-container': this._selected,
|
|
179
|
-
'text-secondary-onContainer': this._selected,
|
|
180
|
-
'bg-surface-container': !this._selected,
|
|
181
|
-
'text-surface-on': !this._selected,
|
|
182
|
-
|
|
183
|
-
// Hover states
|
|
184
|
-
'hover:brightness-95': this._selected && !this.disabled,
|
|
185
|
-
'hover:bg-surface-containerHigh': !this._selected && !this.disabled,
|
|
186
|
-
|
|
187
|
-
// Pressed state
|
|
188
|
-
'active:brightness-90': !this.disabled,
|
|
189
|
-
|
|
190
|
-
// Focus-visible state
|
|
191
|
-
'focus-visible:outline': !this.disabled,
|
|
192
|
-
'focus-visible:outline-2': !this.disabled,
|
|
193
|
-
'focus-visible:outline-offset-2': !this.disabled,
|
|
194
|
-
'focus-visible:outline-primary-default': !this.disabled,
|
|
195
|
-
|
|
196
|
-
// Elevated style
|
|
197
|
-
'shadow-md': this.elevated && !this.disabled,
|
|
198
|
-
'hover:shadow-lg': this.elevated && !this.disabled,
|
|
199
|
-
|
|
200
|
-
// Disabled state
|
|
201
|
-
'opacity-[var(--schmancy-sys-state-disabled-opacity)]': this.disabled,
|
|
202
|
-
'cursor-not-allowed': this.disabled,
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
return html`
|
|
206
|
-
<button
|
|
207
|
-
${magnetic({ strength: 2, radius: 40 })}
|
|
208
|
-
class=${this.classMap(chipClasses)}
|
|
209
|
-
@click=${this.handleClick}
|
|
210
|
-
@keydown=${this.handleKeyDown}
|
|
211
|
-
?disabled=${this.disabled}
|
|
212
|
-
aria-pressed=${this._selected ? 'true' : 'false'}
|
|
213
|
-
role="checkbox"
|
|
214
|
-
tabindex="0"
|
|
215
|
-
>
|
|
216
|
-
<slot></slot>
|
|
217
|
-
|
|
218
|
-
${this.removable
|
|
219
|
-
? html`
|
|
220
|
-
<button
|
|
221
|
-
class="ml-1 -mr-1 p-0.5 rounded-full hover:bg-surface-containerHighest transition-colors duration-200"
|
|
222
|
-
@click=${this.handleRemove}
|
|
223
|
-
aria-label="Remove filter"
|
|
224
|
-
tabindex="-1"
|
|
225
|
-
>
|
|
226
|
-
<span class="material-symbols-outlined text-sm">close</span>
|
|
227
|
-
</button>
|
|
228
|
-
`
|
|
229
|
-
: ''}
|
|
230
|
-
</button>
|
|
231
|
-
`
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
if (!customElements.get('schmancy-filter-chip')) {
|
|
236
|
-
customElements.define('schmancy-filter-chip', SchmancyFilterChip)
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
if (!customElements.get('schmancy-chip')) {
|
|
240
|
-
class SchmancyChipCompat extends SchmancyFilterChip {}
|
|
241
|
-
customElements.define('schmancy-chip', SchmancyChipCompat)
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
export { SchmancyFilterChip as SchmancyChip }
|
|
245
|
-
|
|
246
|
-
declare global {
|
|
247
|
-
interface HTMLElementTagNameMap {
|
|
248
|
-
'schmancy-chip': SchmancyFilterChip
|
|
249
|
-
'schmancy-filter-chip': SchmancyFilterChip
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
export type FilterChipChangeEvent = { value: string; selected: boolean }
|
|
254
|
-
export type FilterChipRemoveEvent = { value: string }
|
|
255
|
-
export type SchmancyChipChangeEvent = FilterChipChangeEvent
|
|
1
|
+
// Moved to src/form/fields/chips/ — this is a backward-compat re-export shim.
|
|
2
|
+
export * from '../form/fields/chips/filter-chip';
|
package/src/chips/index.ts
CHANGED
|
@@ -1,5 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
export * from '
|
|
3
|
-
export * from './filter-chip';
|
|
4
|
-
export * from './input-chip';
|
|
5
|
-
export * from './suggestion-chip';
|
|
1
|
+
// Backward-compat shim — canonical source is src/form/fields/chips/
|
|
2
|
+
export * from '../form/fields/chips';
|