@mhmo91/schmancy 0.10.37 → 0.10.38
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 +39 -0
- package/dist/{SchmancyElement-CDT2q1lA.js → SchmancyElement-BNnyBOwk.js} +9 -7
- package/dist/{SchmancyElement-CDT2q1lA.js.map → SchmancyElement-BNnyBOwk.js.map} +1 -1
- package/dist/{SchmancyElement-BHfQg3Tj.cjs → SchmancyElement-C41uPa6l.cjs} +2 -2
- package/dist/{SchmancyElement-BHfQg3Tj.cjs.map → SchmancyElement-C41uPa6l.cjs.map} +1 -1
- package/dist/agent/schmancy.agent.js +2329 -2297
- package/dist/agent/schmancy.agent.js.map +1 -1
- package/dist/area-2FrTZI_T.cjs +21 -0
- package/dist/area-2FrTZI_T.cjs.map +1 -0
- package/dist/{area-KtULlxuA.js → area-KVDzhT4s.js} +4 -4
- package/dist/area-KVDzhT4s.js.map +1 -0
- package/dist/area.cjs +1 -1
- package/dist/area.js +2 -2
- package/dist/{audio-zIJVTo_V.js → audio-D3gnp15Y.js} +1 -1
- package/dist/{audio-zIJVTo_V.js.map → audio-D3gnp15Y.js.map} +1 -1
- package/dist/{audio-CUMAv9D_.cjs → audio-EaD0Ggfh.cjs} +1 -1
- package/dist/{audio-CUMAv9D_.cjs.map → audio-EaD0Ggfh.cjs.map} +1 -1
- package/dist/audio.cjs +1 -1
- package/dist/audio.js +2 -2
- package/dist/autocomplete-DMmxsvUe.cjs +115 -0
- package/dist/autocomplete-DMmxsvUe.cjs.map +1 -0
- package/dist/{autocomplete-DIScyo8Q.js → autocomplete-DWiEqlQf.js} +96 -96
- package/dist/autocomplete-DWiEqlQf.js.map +1 -0
- 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-BHPqSqJd.js → boat-DmyG7y1V.js} +4 -4
- package/dist/{boat-BHPqSqJd.js.map → boat-DmyG7y1V.js.map} +1 -1
- package/dist/{boat-OBZ77exO.cjs → boat-dB1_qLm0.cjs} +1 -1
- package/dist/{boat-OBZ77exO.cjs.map → boat-dB1_qLm0.cjs.map} +1 -1
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/breadcrumb.cjs +3 -3
- package/dist/breadcrumb.cjs.map +1 -1
- package/dist/breadcrumb.js +4 -4
- package/dist/breadcrumb.js.map +1 -1
- package/dist/{busy-BJNsKSCM.cjs → busy-Cj_PV7oC.cjs} +1 -1
- package/dist/{busy-BJNsKSCM.cjs.map → busy-Cj_PV7oC.cjs.map} +1 -1
- package/dist/{busy-Dut78y4L.js → busy-enYCTssB.js} +2 -2
- package/dist/{busy-Dut78y4L.js.map → busy-enYCTssB.js.map} +1 -1
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/{button-kcpPQavY.js → button-BQSOVnHn.js} +10 -9
- package/dist/button-BQSOVnHn.js.map +1 -0
- package/dist/button-WRmXlNyw.cjs +62 -0
- package/dist/button-WRmXlNyw.cjs.map +1 -0
- package/dist/button.cjs +6 -6
- package/dist/button.cjs.map +1 -1
- package/dist/button.js +17 -16
- package/dist/button.js.map +1 -1
- package/dist/{card-DxSKxCid.js → card-BHTz1GwB.js} +16 -16
- package/dist/card-BHTz1GwB.js.map +1 -0
- package/dist/{card-BLxPLqdQ.cjs → card-ThG_ZaQE.cjs} +3 -3
- package/dist/card-ThG_ZaQE.cjs.map +1 -0
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/{checkbox-BCLkhp5G.cjs → checkbox-C4zeib84.cjs} +2 -2
- package/dist/{checkbox-BCLkhp5G.cjs.map → checkbox-C4zeib84.cjs.map} +1 -1
- package/dist/{checkbox-B1wiM3Dv.js → checkbox-Ce0DlAdW.js} +6 -6
- package/dist/{checkbox-B1wiM3Dv.js.map → checkbox-Ce0DlAdW.js.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-C9dS1WKn.cjs → chips-B1jui8Pe.cjs} +3 -3
- package/dist/chips-B1jui8Pe.cjs.map +1 -0
- package/dist/{chips-vWmwqQed.js → chips-DAy6v93f.js} +20 -19
- package/dist/chips-DAy6v93f.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/cursor-glow-Ah7VXSj7.js.map +1 -1
- package/dist/cursor-glow-Bulq-38P.cjs.map +1 -1
- package/dist/{date-range-BV6HuvLw.cjs → date-range-BUaPgbTZ.cjs} +2 -2
- package/dist/date-range-BUaPgbTZ.cjs.map +1 -0
- package/dist/{date-range-D3ge1b4c.js → date-range-NTpoA1in.js} +4 -4
- package/dist/date-range-NTpoA1in.js.map +1 -0
- package/dist/{date-range-inline-DpYgdLRv.cjs → date-range-inline-D0I6k84h.cjs} +1 -1
- package/dist/{date-range-inline-DpYgdLRv.cjs.map → date-range-inline-D0I6k84h.cjs.map} +1 -1
- package/dist/{date-range-inline-DuWQaWps.js → date-range-inline-DjRdMZ1z.js} +2 -2
- package/dist/{date-range-inline-DuWQaWps.js.map → date-range-inline-DjRdMZ1z.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-C-GZaq3j.js → details-CY49XVfp.js} +43 -35
- package/dist/details-CY49XVfp.js.map +1 -0
- package/dist/details-DQNj2oaU.cjs +164 -0
- package/dist/details-DQNj2oaU.cjs.map +1 -0
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{directives-D_l1E5H6.cjs → directives-Bb0S1DKZ.cjs} +3 -3
- package/dist/directives-Bb0S1DKZ.cjs.map +1 -0
- package/dist/{directives-DyS51FUh.js → directives-Bfm1lkoy.js} +6 -8
- package/dist/directives-Bfm1lkoy.js.map +1 -0
- package/dist/directives.cjs +1 -1
- package/dist/directives.js +2 -2
- package/dist/{divider-nQffE0AD.js → divider-BeyX_C0A.js} +2 -2
- package/dist/{divider-nQffE0AD.js.map → divider-BeyX_C0A.js.map} +1 -1
- package/dist/{divider-CBnAmHMZ.cjs → divider-Ck2C1sKl.cjs} +1 -1
- package/dist/{divider-CBnAmHMZ.cjs.map → divider-Ck2C1sKl.cjs.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-DvTb-UPR.js → expand-BYsSEtp6.js} +53 -53
- package/dist/expand-BYsSEtp6.js.map +1 -0
- package/dist/expand-CUF163mg.cjs +141 -0
- package/dist/expand-CUF163mg.cjs.map +1 -0
- package/dist/expand.cjs +1 -1
- package/dist/expand.js +1 -1
- package/dist/fab.cjs +1 -1
- package/dist/fab.js +2 -2
- package/dist/{float-C-Ko0Le3.js → float-Cgllk_H9.js} +2 -2
- package/dist/{float-C-Ko0Le3.js.map → float-Cgllk_H9.js.map} +1 -1
- package/dist/{float-C17xgMT1.cjs → float-OvqX0nqG.cjs} +1 -1
- package/dist/{float-C17xgMT1.cjs.map → float-OvqX0nqG.cjs.map} +1 -1
- package/dist/float.cjs +1 -1
- package/dist/float.js +1 -1
- package/dist/form-4GKROq2P.cjs +27 -0
- package/dist/form-4GKROq2P.cjs.map +1 -0
- package/dist/{form-DA0hUu2h.js → form-DxaV_Ose.js} +39 -39
- package/dist/form-DxaV_Ose.js.map +1 -0
- package/dist/form.cjs +3 -3
- package/dist/form.cjs.map +1 -1
- package/dist/form.js +34 -34
- package/dist/form.js.map +1 -1
- package/dist/gravity-6pL6CfIr.cjs.map +1 -1
- package/dist/gravity-sVK3zGBF.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-C6UfxmHZ.js → icons-CJ2mXcBi.js} +9 -9
- package/dist/icons-CJ2mXcBi.js.map +1 -0
- package/dist/icons-sZ-LybA9.cjs +24 -0
- package/dist/icons-sZ-LybA9.cjs.map +1 -0
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/{iframe-BTjZfYyh.js → iframe-DWvN5nGB.js} +11 -11
- package/dist/iframe-DWvN5nGB.js.map +1 -0
- package/dist/{iframe-wuYT2xFz.cjs → iframe-DpCv-QH2.cjs} +7 -7
- package/dist/iframe-DpCv-QH2.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 +35 -35
- package/dist/{input-B_4g2ulO.js → input-BCCHz6tB.js} +7 -7
- package/dist/input-BCCHz6tB.js.map +1 -0
- package/dist/{input-BrDiIT60.cjs → input-Z-3N5JMv.cjs} +2 -2
- package/dist/input-Z-3N5JMv.cjs.map +1 -0
- package/dist/{input-chip-BlWhOruv.js → input-chip-BOrcKH-H.js} +2 -2
- package/dist/{input-chip-BlWhOruv.js.map → input-chip-BOrcKH-H.js.map} +1 -1
- package/dist/{input-chip-B-XWh4aE.cjs → input-chip-ChAgRCXZ.cjs} +1 -1
- package/dist/{input-chip-B-XWh4aE.cjs.map → input-chip-ChAgRCXZ.cjs.map} +1 -1
- 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-Dxit9enO.js → layout-CFiG3lNT.js} +1 -1
- package/dist/{layout-Dxit9enO.js.map → layout-CFiG3lNT.js.map} +1 -1
- package/dist/{layout-BhyIcEVu.cjs → layout-DZ4dpLh9.cjs} +1 -1
- package/dist/{layout-BhyIcEVu.cjs.map → layout-DZ4dpLh9.cjs.map} +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +2 -2
- package/dist/lazy-BaAiIUru.js +19 -0
- package/dist/lazy-BaAiIUru.js.map +1 -0
- package/dist/lazy-C-7a4FAe.cjs +1 -0
- package/dist/lazy-C-7a4FAe.cjs.map +1 -0
- package/dist/{lightbox-D85XAAuC.js → lightbox-B7Y4Nij_.js} +2 -2
- package/dist/lightbox-B7Y4Nij_.js.map +1 -0
- package/dist/{lightbox-CVBogswK.cjs → lightbox-Dpwsn8Qr.cjs} +1 -1
- package/dist/lightbox-Dpwsn8Qr.cjs.map +1 -0
- package/dist/lightbox.cjs +1 -1
- package/dist/lightbox.js +1 -1
- package/dist/{list-nVjLskgx.cjs → list-BhM-6dAi.cjs} +1 -1
- package/dist/{list-nVjLskgx.cjs.map → list-BhM-6dAi.cjs.map} +1 -1
- package/dist/{list-DOF_yVn5.js → list-C5WVoIfJ.js} +2 -2
- package/dist/{list-DOF_yVn5.js.map → list-C5WVoIfJ.js.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/magnetic-DKtc4umC.cjs.map +1 -1
- package/dist/magnetic-DaOOv5Dz.js.map +1 -1
- package/dist/{menu-QrAK5Uu9.js → menu-CBAAJoHu.js} +3 -3
- package/dist/{menu-QrAK5Uu9.js.map → menu-CBAAJoHu.js.map} +1 -1
- package/dist/{menu-DqmNjLgY.cjs → menu-DFQjJk3H.cjs} +1 -1
- package/dist/{menu-DqmNjLgY.cjs.map → menu-DFQjJk3H.cjs.map} +1 -1
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/{mixins-De1zjyhy.js → mixins-DGBI7YPO.js} +11 -11
- package/dist/mixins-DGBI7YPO.js.map +1 -0
- package/dist/{mixins-DxHpyMHA.cjs → mixins-fIpzhVMd.cjs} +1 -1
- package/dist/mixins-fIpzhVMd.cjs.map +1 -0
- 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 +3 -3
- package/dist/navigation-rail.cjs.map +1 -1
- package/dist/navigation-rail.js +11 -10
- package/dist/navigation-rail.js.map +1 -1
- package/dist/notification-B6yDL91t.cjs +24 -0
- package/dist/notification-B6yDL91t.cjs.map +1 -0
- package/dist/{notification-BtAK7NK8.js → notification-BB9OBRCr.js} +22 -22
- package/dist/notification-BB9OBRCr.js.map +1 -0
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/{option-DHwA0miA.js → option-B21ImL0k.js} +2 -2
- package/dist/{option-DHwA0miA.js.map → option-B21ImL0k.js.map} +1 -1
- package/dist/{option-DnSPa8ro.cjs → option-CJQM5I9q.cjs} +1 -1
- package/dist/{option-DnSPa8ro.cjs.map → option-CJQM5I9q.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{overlay-Del1sBEB.js → overlay-CWsihJ-E.js} +75 -67
- package/dist/overlay-CWsihJ-E.js.map +1 -0
- package/dist/overlay-DkIX9Ig3.cjs +58 -0
- package/dist/overlay-DkIX9Ig3.cjs.map +1 -0
- package/dist/overlay.cjs +1 -1
- package/dist/{overlay.confirm-body-DSONXUzl.js → overlay.confirm-body-CPqqPNks.js} +10 -10
- package/dist/overlay.confirm-body-CPqqPNks.js.map +1 -0
- package/dist/{overlay.confirm-body-BV9umTAl.cjs → overlay.confirm-body-DwTfiNlV.cjs} +3 -3
- package/dist/overlay.confirm-body-DwTfiNlV.cjs.map +1 -0
- package/dist/overlay.js +4 -4
- package/dist/overlay.service-DU1nqh6A.cjs +1 -0
- package/dist/{overlay.service-XLlrsSdA.cjs.map → overlay.service-DU1nqh6A.cjs.map} +1 -1
- package/dist/{overlay.service-BTp5Oq7f.js → overlay.service-KTgBxjFb.js} +4 -4
- package/dist/{overlay.service-BTp5Oq7f.js.map → overlay.service-KTgBxjFb.js.map} +1 -1
- package/dist/{progress-DUbTL9g9.cjs → progress-B-Qg44XY.cjs} +1 -1
- package/dist/{progress-DUbTL9g9.cjs.map → progress-B-Qg44XY.cjs.map} +1 -1
- package/dist/{progress-DYA83CFU.js → progress-CUSS1sNz.js} +2 -2
- package/dist/{progress-DYA83CFU.js.map → progress-CUSS1sNz.js.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/{radio-group-DxX0iJBo.js → radio-group-AHLvrN8O.js} +7 -7
- package/dist/radio-group-AHLvrN8O.js.map +1 -0
- package/dist/{radio-group-B-ORNtvR.cjs → radio-group-BEtvCSS1.cjs} +2 -2
- package/dist/radio-group-BEtvCSS1.cjs.map +1 -0
- 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-BWpV2iv-.cjs +56 -0
- package/dist/select-BWpV2iv-.cjs.map +1 -0
- package/dist/{select-C7gkA-ab.js → select-Cawz88lG.js} +46 -46
- package/dist/select-Cawz88lG.js.map +1 -0
- 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/SKILL.md +3 -0
- package/dist/skills/overlay.md +14 -7
- package/dist/skills/schmancy/SKILL.md +3 -0
- package/dist/skills/schmancy/overlay.md +14 -7
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +2 -2
- package/dist/{sound.service-O0232os6.js → sound.service-CK-5zob-.js} +4 -3
- package/dist/sound.service-CK-5zob-.js.map +1 -0
- package/dist/{sound.service-C7FDY_yD.cjs → sound.service-D2GGaBXc.cjs} +1 -1
- package/dist/sound.service-D2GGaBXc.cjs.map +1 -0
- package/dist/{splash-screen-jfE47xl0.js → splash-screen-BUEtjHXC.js} +13 -13
- package/dist/splash-screen-BUEtjHXC.js.map +1 -0
- package/dist/{splash-screen-DIS4odDr.cjs → splash-screen-DqPuipox.cjs} +6 -6
- package/dist/splash-screen-DqPuipox.cjs.map +1 -0
- package/dist/splash-screen.cjs +1 -1
- package/dist/splash-screen.js +1 -1
- package/dist/{src-BP3h-9d9.js → src-CIqAj3Eh.js} +45 -45
- package/dist/src-CIqAj3Eh.js.map +1 -0
- package/dist/{src-Um_pzb-U.cjs → src-CYqBQTyt.cjs} +6 -6
- package/dist/src-CYqBQTyt.cjs.map +1 -0
- package/dist/{state-Bj0M9a6T.cjs → state-BxDNox-2.cjs} +1 -1
- package/dist/{state-Bj0M9a6T.cjs.map → state-BxDNox-2.cjs.map} +1 -1
- package/dist/{state-DscWQpoM.js → state-CnZCDMT0.js} +9 -9
- package/dist/{state-DscWQpoM.js.map → state-CnZCDMT0.js.map} +1 -1
- package/dist/state.cjs +1 -1
- package/dist/state.js +2 -2
- package/dist/steps.cjs +1 -1
- package/dist/steps.js +2 -2
- package/dist/{surface-B4Wn4SOO.js → surface-BMdG3dKQ.js} +2 -2
- package/dist/{surface-B4Wn4SOO.js.map → surface-BMdG3dKQ.js.map} +1 -1
- package/dist/{surface-DRq6cVW6.cjs → surface-CWwYD_z2.cjs} +1 -1
- package/dist/{surface-DRq6cVW6.cjs.map → surface-CWwYD_z2.cjs.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/switch.cjs +4 -4
- package/dist/switch.cjs.map +1 -1
- package/dist/switch.js +11 -11
- package/dist/switch.js.map +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +2 -2
- package/dist/{tabs-CnQPo-XS.js → tabs-CDQYDc6v.js} +2 -2
- package/dist/{tabs-CnQPo-XS.js.map → tabs-CDQYDc6v.js.map} +1 -1
- package/dist/{tabs-Ca_fbHPW.cjs → tabs-CbD9E1gd.cjs} +1 -1
- package/dist/{tabs-Ca_fbHPW.cjs.map → tabs-CbD9E1gd.cjs.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-Brgi-vD2.cjs +43 -0
- package/dist/textarea-Brgi-vD2.cjs.map +1 -0
- package/dist/{textarea-BvqENhTW.js → textarea-MPyrMi-S.js} +4 -4
- package/dist/textarea-MPyrMi-S.js.map +1 -0
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-BSwJ2YZo.cjs → theme-BMbXoqi0.cjs} +1 -1
- package/dist/{theme-BSwJ2YZo.cjs.map → theme-BMbXoqi0.cjs.map} +1 -1
- package/dist/{theme-BV0EzHQ1.js → theme-DZu-xmVp.js} +5 -5
- package/dist/{theme-BV0EzHQ1.js.map → theme-DZu-xmVp.js.map} +1 -1
- package/dist/{theme-button-C6fpUzPM.cjs → theme-button-B0OLb-43.cjs} +1 -1
- package/dist/{theme-button-C6fpUzPM.cjs.map → theme-button-B0OLb-43.cjs.map} +1 -1
- package/dist/{theme-button-O_xNCgI7.js → theme-button-D_qGvEYs.js} +2 -2
- package/dist/{theme-button-O_xNCgI7.js.map → theme-button-D_qGvEYs.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-DwLhhOmP.js → theme.service-7VkM-hVf.js} +15 -11
- package/dist/theme.service-7VkM-hVf.js.map +1 -0
- package/dist/theme.service-B15FdjOS.cjs +1 -0
- package/dist/theme.service-B15FdjOS.cjs.map +1 -0
- package/dist/tree.cjs +4 -4
- package/dist/tree.cjs.map +1 -1
- package/dist/tree.js +8 -8
- package/dist/tree.js.map +1 -1
- package/dist/{typography-opFYuUYS.cjs → typography-D4Fo1UGh.cjs} +3 -3
- package/dist/{typography-opFYuUYS.cjs.map → typography-D4Fo1UGh.cjs.map} +1 -1
- package/dist/{typography-Dtdooaic.js → typography-SZhjb_4R.js} +9 -9
- package/dist/{typography-Dtdooaic.js.map → typography-SZhjb_4R.js.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-ConcHirJ.js → window-BDVyrBnk.js} +101 -100
- package/dist/window-BDVyrBnk.js.map +1 -0
- package/dist/window-BbBYjm7R.cjs +59 -0
- package/dist/window-BbBYjm7R.cjs.map +1 -0
- package/dist/window.cjs +1 -1
- package/dist/window.js +1 -1
- package/package.json +1 -1
- package/skills/schmancy/SKILL.md +3 -0
- package/skills/schmancy/overlay.md +14 -7
- package/src/area/area.component.ts +1 -1
- package/src/area/area.service.test.ts +2 -2
- package/src/area/area.service.ts +1 -1
- package/src/area/lazy.ts +87 -83
- package/src/audio/sound.service.ts +3 -3
- package/src/breadcrumb/breadcrumb.ts +2 -2
- package/src/button/button.ts +11 -11
- package/src/button/icon-button.ts +18 -18
- package/src/card/card.ts +16 -16
- package/src/content-drawer/drawer.ts +6 -6
- package/src/details/details.ts +55 -55
- package/src/directives/ai-badge.ts +2 -1
- package/src/directives/animate-text.ts +2 -1
- package/src/directives/art/art.directive.ts +2 -1
- package/src/directives/battery.ts +2 -1
- package/src/directives/confirm-click.ts +5 -3
- package/src/directives/cursor-glow.ts +2 -1
- package/src/directives/cycle-text.ts +2 -1
- package/src/directives/depth-of-field.ts +2 -1
- package/src/directives/drag.ts +4 -2
- package/src/directives/fyi.ts +2 -1
- package/src/directives/gravity.ts +2 -1
- package/src/directives/hummingbird.ts +2 -1
- package/src/directives/intersect.ts +3 -2
- package/src/directives/liquid.ts +2 -1
- package/src/directives/living-border.ts +2 -1
- package/src/directives/long-press.ts +2 -1
- package/src/directives/magnetic.ts +2 -1
- package/src/directives/missed-punch.ts +2 -1
- package/src/directives/nebula.ts +6 -5
- package/src/directives/overflow-within.ts +2 -1
- package/src/directives/reveal.ts +2 -1
- package/src/directives/urgent.ts +2 -1
- package/src/directives/working-snake.ts +2 -1
- package/src/expand/expand-root.component.ts +27 -27
- package/src/expand/expand.component.ts +48 -48
- package/src/form/fields/autocomplete/autocomplete.ts +154 -154
- package/src/form/fields/checkbox/checkbox.ts +4 -4
- package/src/form/fields/chips/chips.ts +2 -2
- package/src/form/fields/chips/filter-chip.ts +15 -15
- package/src/form/fields/date-range/date-range.ts +2 -2
- package/src/form/fields/input/input.ts +12 -12
- package/src/form/fields/radio-group/radio-button.ts +2 -2
- package/src/form/fields/radio-group/radio-group.ts +3 -3
- package/src/form/fields/select/select.ts +56 -56
- package/src/form/fields/switch/switch.ts +10 -10
- package/src/form/fields/textarea/textarea.ts +2 -2
- package/src/form/form-summary.ts +33 -33
- package/src/form/form.ts +45 -45
- package/src/icons/icon.ts +10 -8
- package/src/iframe/iframe.ts +11 -11
- package/src/lightbox/flip-directive.ts +2 -1
- package/src/lightbox/lightbox.directive.ts +2 -1
- package/src/nav-drawer/navbar.ts +3 -3
- package/src/navigation-rail/navigation-rail.ts +10 -10
- package/src/notification/notification.ts +22 -22
- package/src/overlay/overlay.component.ts +106 -83
- package/src/overlay/overlay.confirm-body.ts +4 -4
- package/src/overlay/overlay.service.ts +3 -3
- package/src/overlay/overlay.types.ts +4 -2
- package/src/splash-screen/splash-screen.ts +11 -11
- package/src/state/index.ts +12 -12
- package/src/state/schmancy-context.ts +9 -9
- package/src/teleport/teleport.component.ts +2 -2
- package/src/theme/theme.service.ts +17 -17
- package/src/tree/tree.ts +7 -7
- package/src/typography/typography.ts +7 -7
- package/src/window/window-manager.ts +20 -20
- package/src/window/window.ts +100 -100
- package/types/mixins/SchmancyElement.d.ts +3 -2
- package/types/mixins/formField.mixin.d.ts +1 -1
- package/types/src/area/area.service.d.ts +1 -1
- package/types/src/area/lazy.d.ts +0 -6
- package/types/src/audio/sound.service.d.ts +1 -2
- package/types/src/breadcrumb/breadcrumb.d.ts +1 -1
- package/types/src/button/button.d.ts +3 -3
- package/types/src/button/icon-button.d.ts +6 -7
- package/types/src/card/card.d.ts +5 -5
- package/types/src/content-drawer/drawer.d.ts +1 -1
- package/types/src/details/details.d.ts +2 -21
- package/types/src/directives/ai-badge.d.ts +2 -2
- package/types/src/directives/animate-text.d.ts +2 -2
- package/types/src/directives/art/art.directive.d.ts +2 -2
- package/types/src/directives/battery.d.ts +2 -2
- package/types/src/directives/confirm-click.d.ts +2 -2
- package/types/src/directives/cursor-glow.d.ts +2 -2
- package/types/src/directives/cycle-text.d.ts +2 -2
- package/types/src/directives/depth-of-field.d.ts +2 -2
- package/types/src/directives/drag.d.ts +4 -4
- package/types/src/directives/fyi.d.ts +2 -2
- package/types/src/directives/gravity.d.ts +2 -2
- package/types/src/directives/hummingbird.d.ts +2 -2
- package/types/src/directives/intersect.d.ts +2 -2
- package/types/src/directives/liquid.d.ts +2 -2
- package/types/src/directives/living-border.d.ts +2 -2
- package/types/src/directives/long-press.d.ts +2 -2
- package/types/src/directives/magnetic.d.ts +2 -2
- package/types/src/directives/missed-punch.d.ts +2 -2
- package/types/src/directives/nebula.d.ts +2 -2
- package/types/src/directives/overflow-within.d.ts +2 -2
- package/types/src/directives/reveal.d.ts +2 -2
- package/types/src/directives/urgent.d.ts +2 -2
- package/types/src/directives/working-snake.d.ts +2 -2
- package/types/src/expand/expand-root.component.d.ts +8 -8
- package/types/src/expand/expand.component.d.ts +11 -11
- package/types/src/form/fields/autocomplete/autocomplete.d.ts +29 -29
- package/types/src/form/fields/checkbox/checkbox.d.ts +1 -1
- package/types/src/form/fields/chips/chips.d.ts +1 -1
- package/types/src/form/fields/chips/filter-chip.d.ts +1 -2
- package/types/src/form/fields/input/input.d.ts +3 -3
- package/types/src/form/fields/radio-group/radio-button.d.ts +1 -1
- package/types/src/form/fields/radio-group/radio-group.d.ts +1 -1
- package/types/src/form/fields/select/select.d.ts +8 -8
- package/types/src/form/fields/switch/switch.d.ts +3 -3
- package/types/src/form/fields/textarea/textarea.d.ts +1 -1
- package/types/src/form/form-summary.d.ts +7 -7
- package/types/src/form/form.d.ts +11 -11
- package/types/src/icons/icon.d.ts +2 -2
- package/types/src/iframe/iframe.d.ts +3 -3
- package/types/src/lightbox/flip-directive.d.ts +2 -2
- package/types/src/lightbox/lightbox.directive.d.ts +2 -2
- package/types/src/nav-drawer/navbar.d.ts +1 -1
- package/types/src/navigation-rail/navigation-rail.d.ts +2 -2
- package/types/src/notification/notification.d.ts +8 -8
- package/types/src/overlay/overlay.component.d.ts +16 -16
- package/types/src/overlay/overlay.confirm-body.d.ts +1 -1
- package/types/src/overlay/overlay.types.d.ts +4 -2
- package/types/src/splash-screen/splash-screen.d.ts +2 -2
- package/types/src/state/index.d.ts +1 -1
- package/types/src/state/schmancy-context.d.ts +3 -3
- package/types/src/teleport/teleport.component.d.ts +1 -1
- package/types/src/theme/theme.service.d.ts +1 -4
- package/types/src/tree/tree.d.ts +3 -3
- package/types/src/typography/typography.d.ts +1 -1
- package/types/src/window/window-manager.d.ts +2 -2
- package/types/src/window/window.d.ts +20 -20
- package/dist/area-KtULlxuA.js.map +0 -1
- package/dist/area-fdKhYB6T.cjs +0 -21
- package/dist/area-fdKhYB6T.cjs.map +0 -1
- package/dist/autocomplete-DEZk6wBD.cjs +0 -115
- package/dist/autocomplete-DEZk6wBD.cjs.map +0 -1
- package/dist/autocomplete-DIScyo8Q.js.map +0 -1
- package/dist/button-DzlHLjWO.cjs +0 -62
- package/dist/button-DzlHLjWO.cjs.map +0 -1
- package/dist/button-kcpPQavY.js.map +0 -1
- package/dist/card-BLxPLqdQ.cjs.map +0 -1
- package/dist/card-DxSKxCid.js.map +0 -1
- package/dist/chips-C9dS1WKn.cjs.map +0 -1
- package/dist/chips-vWmwqQed.js.map +0 -1
- package/dist/date-range-BV6HuvLw.cjs.map +0 -1
- package/dist/date-range-D3ge1b4c.js.map +0 -1
- package/dist/details-C-GZaq3j.js.map +0 -1
- package/dist/details-Dp5rLIWk.cjs +0 -164
- package/dist/details-Dp5rLIWk.cjs.map +0 -1
- package/dist/directives-D_l1E5H6.cjs.map +0 -1
- package/dist/directives-DyS51FUh.js.map +0 -1
- package/dist/expand-DvTb-UPR.js.map +0 -1
- package/dist/expand-mlP_3XWz.cjs +0 -141
- package/dist/expand-mlP_3XWz.cjs.map +0 -1
- package/dist/form-CwPHcQYB.cjs +0 -27
- package/dist/form-CwPHcQYB.cjs.map +0 -1
- package/dist/form-DA0hUu2h.js.map +0 -1
- package/dist/icons-C6UfxmHZ.js.map +0 -1
- package/dist/icons-CW3-oMSb.cjs +0 -24
- package/dist/icons-CW3-oMSb.cjs.map +0 -1
- package/dist/iframe-BTjZfYyh.js.map +0 -1
- package/dist/iframe-wuYT2xFz.cjs.map +0 -1
- package/dist/input-B_4g2ulO.js.map +0 -1
- package/dist/input-BrDiIT60.cjs.map +0 -1
- package/dist/lazy-CayEFyC3.cjs +0 -1
- package/dist/lazy-CayEFyC3.cjs.map +0 -1
- package/dist/lazy-D-bO2r4m.js +0 -13
- package/dist/lazy-D-bO2r4m.js.map +0 -1
- package/dist/lightbox-CVBogswK.cjs.map +0 -1
- package/dist/lightbox-D85XAAuC.js.map +0 -1
- package/dist/mixins-De1zjyhy.js.map +0 -1
- package/dist/mixins-DxHpyMHA.cjs.map +0 -1
- package/dist/notification-BtAK7NK8.js.map +0 -1
- package/dist/notification-DYzbUb5C.cjs +0 -24
- package/dist/notification-DYzbUb5C.cjs.map +0 -1
- package/dist/overlay-BVkqZmoS.cjs +0 -58
- package/dist/overlay-BVkqZmoS.cjs.map +0 -1
- package/dist/overlay-Del1sBEB.js.map +0 -1
- package/dist/overlay.confirm-body-BV9umTAl.cjs.map +0 -1
- package/dist/overlay.confirm-body-DSONXUzl.js.map +0 -1
- package/dist/overlay.service-XLlrsSdA.cjs +0 -1
- package/dist/radio-group-B-ORNtvR.cjs.map +0 -1
- package/dist/radio-group-DxX0iJBo.js.map +0 -1
- package/dist/select-B9uj_u-s.cjs +0 -56
- package/dist/select-B9uj_u-s.cjs.map +0 -1
- package/dist/select-C7gkA-ab.js.map +0 -1
- package/dist/sound.service-C7FDY_yD.cjs.map +0 -1
- package/dist/sound.service-O0232os6.js.map +0 -1
- package/dist/splash-screen-DIS4odDr.cjs.map +0 -1
- package/dist/splash-screen-jfE47xl0.js.map +0 -1
- package/dist/src-BP3h-9d9.js.map +0 -1
- package/dist/src-Um_pzb-U.cjs.map +0 -1
- package/dist/textarea-BvqENhTW.js.map +0 -1
- package/dist/textarea-qr7oL8oU.cjs +0 -43
- package/dist/textarea-qr7oL8oU.cjs.map +0 -1
- package/dist/theme.service-DwLhhOmP.js.map +0 -1
- package/dist/theme.service-kn9MC025.cjs +0 -1
- package/dist/theme.service-kn9MC025.cjs.map +0 -1
- package/dist/window-BSAemI9J.cjs +0 -59
- package/dist/window-BSAemI9J.cjs.map +0 -1
- package/dist/window-ConcHirJ.js.map +0 -1
|
@@ -60,18 +60,18 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
60
60
|
/** Override mixin's resetForm with autocomplete-specific subject reset. */
|
|
61
61
|
override resetForm(): void {
|
|
62
62
|
if (this.multi) {
|
|
63
|
-
this.
|
|
63
|
+
this.selectedValues$.next([])
|
|
64
64
|
} else {
|
|
65
|
-
this.
|
|
65
|
+
this.selectedValue$.next('')
|
|
66
66
|
}
|
|
67
|
-
this.
|
|
68
|
-
this.
|
|
67
|
+
this.inputValue = ''
|
|
68
|
+
this.inputValue$.next('')
|
|
69
69
|
super.resetForm()
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
// Track whether value/values have been explicitly set
|
|
73
|
-
|
|
74
|
-
|
|
73
|
+
valueSet: boolean = false
|
|
74
|
+
valuesSet: boolean = false
|
|
75
75
|
|
|
76
76
|
// Autocomplete-specific properties only — `name`, `label`, `required`,
|
|
77
77
|
// `error`, `validationMessage` come from the mixin.
|
|
@@ -84,76 +84,76 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
84
84
|
@property({ type: Number }) debounceMs = 200
|
|
85
85
|
@property({ type: Number }) similarityThreshold = 0.3 // Minimum similarity score to show option
|
|
86
86
|
|
|
87
|
-
private readonly
|
|
87
|
+
private readonly a11yId = `schmancy-autocomplete-${Math.random().toString(36).slice(2, 10)}`
|
|
88
88
|
|
|
89
89
|
// Values property for multi-select mode
|
|
90
90
|
@property({ type: Array })
|
|
91
91
|
get values() {
|
|
92
|
-
return [...this.
|
|
92
|
+
return [...this.selectedValues$.value]
|
|
93
93
|
}
|
|
94
94
|
set values(vals: string[]) {
|
|
95
|
-
this.
|
|
96
|
-
this.
|
|
95
|
+
this.valuesSet = true
|
|
96
|
+
this.selectedValues$.next(Array.isArray(vals) ? [...vals] : [])
|
|
97
97
|
}
|
|
98
98
|
|
|
99
99
|
// Value property — narrowed override of the mixin's wide value union.
|
|
100
100
|
@property({ type: String, reflect: true })
|
|
101
101
|
override get value(): string {
|
|
102
102
|
return this.multi
|
|
103
|
-
? this.
|
|
104
|
-
: this.
|
|
103
|
+
? this.selectedValues$.value.join(',')
|
|
104
|
+
: this.selectedValue$.value
|
|
105
105
|
}
|
|
106
106
|
override set value(val: string) {
|
|
107
|
-
this.
|
|
107
|
+
this.valueSet = true
|
|
108
108
|
if (this.multi) {
|
|
109
109
|
const newValues = val ? val.split(',').map(v => v.trim()).filter(Boolean) : []
|
|
110
|
-
const currentValues = this.
|
|
110
|
+
const currentValues = this.selectedValues$.value
|
|
111
111
|
// Only update if values actually changed
|
|
112
112
|
if (JSON.stringify(newValues) !== JSON.stringify(currentValues)) {
|
|
113
|
-
this.
|
|
113
|
+
this.selectedValues$.next(newValues)
|
|
114
114
|
}
|
|
115
115
|
} else {
|
|
116
116
|
// Only update if value actually changed
|
|
117
|
-
if (val !== this.
|
|
118
|
-
this.
|
|
117
|
+
if (val !== this.selectedValue$.value) {
|
|
118
|
+
this.selectedValue$.next(val)
|
|
119
119
|
// Update the input display when value is set
|
|
120
|
-
this.
|
|
120
|
+
this.updateInputDisplay()
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
|
|
125
125
|
// State
|
|
126
|
-
@state() private
|
|
127
|
-
@state() private
|
|
128
|
-
@state() private
|
|
129
|
-
@state() private
|
|
126
|
+
@state() private open = false
|
|
127
|
+
@state() private inputValue = ''
|
|
128
|
+
@state() private visibleOptionsCount = 0
|
|
129
|
+
@state() private hasResults = true
|
|
130
130
|
|
|
131
131
|
// DOM references
|
|
132
|
-
@query('#options')
|
|
133
|
-
@query('sch-input')
|
|
134
|
-
@queryAssignedElements({ flatten: true }) private
|
|
135
|
-
private
|
|
132
|
+
@query('#options') listbox!: HTMLUListElement
|
|
133
|
+
@query('sch-input') input!: SchmancyInput
|
|
134
|
+
@queryAssignedElements({ flatten: true }) private options!: SchmancyOption[]
|
|
135
|
+
private inputElementRef = createRef<HTMLInputElement>()
|
|
136
136
|
|
|
137
137
|
// RxJS Subjects - only what we actually need
|
|
138
|
-
private
|
|
139
|
-
private
|
|
140
|
-
private
|
|
138
|
+
private selectedValue$ = new BehaviorSubject<string>('')
|
|
139
|
+
private selectedValues$ = new BehaviorSubject<string[]>([])
|
|
140
|
+
private inputValue$ = new BehaviorSubject<string>('')
|
|
141
141
|
|
|
142
142
|
override connectedCallback() {
|
|
143
143
|
// FIELD_CONNECT_EVENT is dispatched by the mixin's connectedCallback.
|
|
144
144
|
super.connectedCallback()
|
|
145
|
-
this.
|
|
146
|
-
this.
|
|
145
|
+
this.setupAutocompleteLogic()
|
|
146
|
+
this.setupDocumentClickHandler()
|
|
147
147
|
}
|
|
148
148
|
|
|
149
|
-
private
|
|
149
|
+
private setupAutocompleteLogic() {
|
|
150
150
|
// Sync selection state
|
|
151
151
|
combineLatest([
|
|
152
|
-
this.
|
|
153
|
-
this.
|
|
152
|
+
this.selectedValue$,
|
|
153
|
+
this.selectedValues$
|
|
154
154
|
]).pipe(
|
|
155
155
|
tap(([selectedValue, selectedValues]) => {
|
|
156
|
-
this.
|
|
156
|
+
this.updateOptionSelection(selectedValue, selectedValues)
|
|
157
157
|
// Keep ElementInternals form value in sync with selection (single and multi).
|
|
158
158
|
const formValue = this.multi ? selectedValues.join(',') : selectedValue
|
|
159
159
|
this.internals?.setFormValue(formValue || null)
|
|
@@ -169,20 +169,20 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
169
169
|
).subscribe()
|
|
170
170
|
|
|
171
171
|
// Filter options based on input
|
|
172
|
-
this.
|
|
172
|
+
this.inputValue$.pipe(
|
|
173
173
|
distinctUntilChanged(),
|
|
174
174
|
debounceTime(this.debounceMs),
|
|
175
175
|
tap(searchTerm => {
|
|
176
|
-
if (this.
|
|
177
|
-
this.
|
|
176
|
+
if (this.open) {
|
|
177
|
+
this.filterOptions(searchTerm)
|
|
178
178
|
}
|
|
179
179
|
}),
|
|
180
180
|
takeUntil(this.disconnecting)
|
|
181
181
|
).subscribe()
|
|
182
182
|
}
|
|
183
183
|
|
|
184
|
-
private
|
|
185
|
-
this.
|
|
184
|
+
private setupOptionHandlers() {
|
|
185
|
+
this.options.forEach((option, index) => {
|
|
186
186
|
option.setAttribute('role', 'option')
|
|
187
187
|
option.tabIndex = -1
|
|
188
188
|
if (!option.id) {
|
|
@@ -203,13 +203,13 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
203
203
|
.pipe(takeUntil(this.disconnecting))
|
|
204
204
|
.subscribe(e => {
|
|
205
205
|
e.stopPropagation()
|
|
206
|
-
this.
|
|
206
|
+
this.selectOption(option)
|
|
207
207
|
})
|
|
208
208
|
})
|
|
209
209
|
}
|
|
210
210
|
|
|
211
|
-
private
|
|
212
|
-
this.
|
|
211
|
+
private updateOptionSelection(selectedValue: string, selectedValues: string[]) {
|
|
212
|
+
this.options.forEach(option => {
|
|
213
213
|
option.selected = this.multi
|
|
214
214
|
? selectedValues.includes(option.value)
|
|
215
215
|
: option.value === selectedValue
|
|
@@ -217,20 +217,20 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
217
217
|
})
|
|
218
218
|
}
|
|
219
219
|
|
|
220
|
-
private
|
|
220
|
+
private filterOptions(searchTerm: string) {
|
|
221
221
|
const term = searchTerm.trim()
|
|
222
222
|
|
|
223
223
|
if (!term) {
|
|
224
224
|
// Show all options if no search term
|
|
225
|
-
this.
|
|
225
|
+
this.options.forEach(option => {
|
|
226
226
|
option.hidden = false
|
|
227
227
|
option.style.order = '0'
|
|
228
228
|
})
|
|
229
|
-
this.
|
|
230
|
-
this.
|
|
229
|
+
this.visibleOptionsCount = this.options.length
|
|
230
|
+
this.hasResults = true
|
|
231
231
|
} else {
|
|
232
232
|
// Calculate similarity scores for all options
|
|
233
|
-
const scoredOptions: FilteredOption[] = this.
|
|
233
|
+
const scoredOptions: FilteredOption[] = this.options.map(option => {
|
|
234
234
|
const optionLabel = option.label || option.textContent || ''
|
|
235
235
|
const optionValue = option.value
|
|
236
236
|
|
|
@@ -258,108 +258,108 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
258
258
|
}
|
|
259
259
|
})
|
|
260
260
|
|
|
261
|
-
this.
|
|
262
|
-
this.
|
|
261
|
+
this.visibleOptionsCount = visibleCount
|
|
262
|
+
this.hasResults = visibleCount > 0
|
|
263
263
|
}
|
|
264
264
|
|
|
265
|
-
this.
|
|
266
|
-
this.
|
|
267
|
-
? `${this.
|
|
265
|
+
this.announceToScreenReader(
|
|
266
|
+
this.visibleOptionsCount > 0
|
|
267
|
+
? `${this.visibleOptionsCount} option${this.visibleOptionsCount === 1 ? '' : 's'} available.`
|
|
268
268
|
: 'No results found.'
|
|
269
269
|
)
|
|
270
270
|
}
|
|
271
271
|
|
|
272
|
-
private
|
|
273
|
-
this.
|
|
272
|
+
private openDropdown() {
|
|
273
|
+
this.open = true
|
|
274
274
|
// Reset filters based on current input value when dropdown opens
|
|
275
|
-
this.
|
|
275
|
+
this.filterOptions(this.inputValue)
|
|
276
276
|
}
|
|
277
277
|
|
|
278
|
-
private
|
|
278
|
+
private selectOption(option: SchmancyOption) {
|
|
279
279
|
if (this.multi) {
|
|
280
|
-
const currentValues = this.
|
|
280
|
+
const currentValues = this.selectedValues$.value
|
|
281
281
|
const index = currentValues.indexOf(option.value)
|
|
282
282
|
const newValues = index > -1
|
|
283
283
|
? currentValues.filter(v => v !== option.value)
|
|
284
284
|
: [...currentValues, option.value]
|
|
285
285
|
|
|
286
|
-
this.
|
|
287
|
-
this.
|
|
286
|
+
this.selectedValues$.next(newValues)
|
|
287
|
+
this.announceToScreenReader(
|
|
288
288
|
newValues.length > 0
|
|
289
|
-
? `Selected: ${this.
|
|
289
|
+
? `Selected: ${this.getSelectedLabels().join(', ')}`
|
|
290
290
|
: 'No options selected'
|
|
291
291
|
)
|
|
292
|
-
this.
|
|
292
|
+
this.fireChangeEvent()
|
|
293
293
|
} else {
|
|
294
294
|
// Update value first
|
|
295
|
-
this.
|
|
295
|
+
this.selectedValue$.next(option.value)
|
|
296
296
|
|
|
297
297
|
// Close dropdown IMMEDIATELY to prevent blur handler from firing
|
|
298
|
-
this.
|
|
298
|
+
this.open = false
|
|
299
299
|
|
|
300
300
|
// Now fire event with the NEW value
|
|
301
|
-
this.
|
|
301
|
+
this.fireChangeEvent()
|
|
302
302
|
|
|
303
303
|
// Update UI
|
|
304
|
-
this.
|
|
305
|
-
this.
|
|
304
|
+
this.inputValue = option.label || option.textContent || ''
|
|
305
|
+
this.inputValue$.next(this.inputValue)
|
|
306
306
|
|
|
307
|
-
this.
|
|
307
|
+
this.announceToScreenReader(`Selected: ${option.label || option.textContent}`)
|
|
308
308
|
}
|
|
309
309
|
}
|
|
310
310
|
|
|
311
|
-
private
|
|
311
|
+
private setupDocumentClickHandler() {
|
|
312
312
|
fromEvent<MouseEvent>(document, 'click')
|
|
313
313
|
.pipe(takeUntil(this.disconnecting))
|
|
314
314
|
.subscribe(e => {
|
|
315
|
-
if (!this.
|
|
315
|
+
if (!this.open) return
|
|
316
316
|
const path = e.composedPath()
|
|
317
|
-
if (!path.includes(this) && !this.
|
|
318
|
-
this.
|
|
319
|
-
this.
|
|
317
|
+
if (!path.includes(this) && !this.options.some(opt => path.includes(opt))) {
|
|
318
|
+
this.open = false
|
|
319
|
+
this.updateInputDisplay()
|
|
320
320
|
}
|
|
321
321
|
})
|
|
322
322
|
}
|
|
323
323
|
|
|
324
324
|
|
|
325
|
-
private
|
|
325
|
+
private updateInputDisplay() {
|
|
326
326
|
// For multi-select, we don't update input display since chips show the selections
|
|
327
327
|
if (this.multi) return
|
|
328
328
|
|
|
329
|
-
const selectedValue = this.
|
|
330
|
-
const option = this.
|
|
331
|
-
this.
|
|
332
|
-
this.
|
|
329
|
+
const selectedValue = this.selectedValue$.value
|
|
330
|
+
const option = this.options.find(opt => opt.value === selectedValue)
|
|
331
|
+
this.inputValue = option ? option.label || option.textContent || '' : ''
|
|
332
|
+
this.inputValue$.next(this.inputValue)
|
|
333
333
|
|
|
334
|
-
if (this.
|
|
335
|
-
this.
|
|
334
|
+
if (this.inputElementRef.value) {
|
|
335
|
+
this.inputElementRef.value.value = this.inputValue
|
|
336
336
|
}
|
|
337
337
|
}
|
|
338
338
|
|
|
339
|
-
private
|
|
340
|
-
return this.
|
|
339
|
+
private getSelectedLabels(): string[] {
|
|
340
|
+
return this.options
|
|
341
341
|
.filter(option =>
|
|
342
342
|
this.multi
|
|
343
|
-
? this.
|
|
344
|
-
: option.value === this.
|
|
343
|
+
? this.selectedValues$.value.includes(option.value)
|
|
344
|
+
: option.value === this.selectedValue$.value
|
|
345
345
|
)
|
|
346
346
|
.map(option => option.label || option.textContent || '')
|
|
347
347
|
}
|
|
348
348
|
|
|
349
|
-
private
|
|
349
|
+
private announceToScreenReader(message: string) {
|
|
350
350
|
const liveRegion = this.shadowRoot?.querySelector('#live-status')
|
|
351
351
|
if (liveRegion) {
|
|
352
352
|
liveRegion.textContent = message
|
|
353
353
|
}
|
|
354
354
|
}
|
|
355
355
|
|
|
356
|
-
private
|
|
356
|
+
private fireChangeEvent() {
|
|
357
357
|
const detail: SchmancyAutocompleteChangeEvent['detail'] = {
|
|
358
358
|
value: this.value,
|
|
359
359
|
}
|
|
360
360
|
|
|
361
361
|
if (this.multi) {
|
|
362
|
-
detail.values = [...this.
|
|
362
|
+
detail.values = [...this.selectedValues$.value]
|
|
363
363
|
}
|
|
364
364
|
|
|
365
365
|
this.dispatchEvent(
|
|
@@ -374,47 +374,47 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
374
374
|
public checkValidity(): boolean {
|
|
375
375
|
if (!this.required) return true
|
|
376
376
|
return this.multi
|
|
377
|
-
? this.
|
|
378
|
-
: Boolean(this.
|
|
377
|
+
? this.selectedValues$.value.length > 0
|
|
378
|
+
: Boolean(this.selectedValue$.value)
|
|
379
379
|
}
|
|
380
380
|
|
|
381
381
|
public reportValidity(): boolean {
|
|
382
|
-
if (this.
|
|
383
|
-
return this.
|
|
382
|
+
if (this.inputElementRef.value) {
|
|
383
|
+
return this.inputElementRef.value.reportValidity()
|
|
384
384
|
}
|
|
385
385
|
return this.checkValidity()
|
|
386
386
|
}
|
|
387
387
|
|
|
388
388
|
firstUpdated() {
|
|
389
|
-
this.
|
|
389
|
+
this.setupOptionHandlers()
|
|
390
390
|
|
|
391
391
|
// Sync initial value with display after options are available
|
|
392
|
-
this.
|
|
392
|
+
this.updateInputDisplay()
|
|
393
393
|
|
|
394
394
|
// Update options when slot changes
|
|
395
395
|
const slot = this.shadowRoot?.querySelector('slot')
|
|
396
396
|
slot?.addEventListener('slotchange', () => {
|
|
397
|
-
this.
|
|
398
|
-
this.
|
|
397
|
+
this.setupOptionHandlers()
|
|
398
|
+
this.updateOptionSelection(this.selectedValue$.value, this.selectedValues$.value)
|
|
399
399
|
})
|
|
400
400
|
}
|
|
401
401
|
|
|
402
402
|
private handleChipRemove(value: string) {
|
|
403
|
-
const currentValues = this.
|
|
403
|
+
const currentValues = this.selectedValues$.value
|
|
404
404
|
const newValues = currentValues.filter(v => v !== value)
|
|
405
|
-
this.
|
|
406
|
-
this.
|
|
407
|
-
this.
|
|
405
|
+
this.selectedValues$.next(newValues)
|
|
406
|
+
this.fireChangeEvent()
|
|
407
|
+
this.announceToScreenReader(`Removed: ${this.getChipLabel(value)}`)
|
|
408
408
|
}
|
|
409
409
|
|
|
410
|
-
private
|
|
411
|
-
const option = this.
|
|
410
|
+
private getChipLabel(value: string): string {
|
|
411
|
+
const option = this.options.find(opt => opt.value === value)
|
|
412
412
|
return option ? option.label || option.textContent || value : value
|
|
413
413
|
}
|
|
414
414
|
|
|
415
|
-
private
|
|
416
|
-
if (this.
|
|
417
|
-
this.
|
|
415
|
+
private focusTextInput() {
|
|
416
|
+
if (this.inputElementRef.value) {
|
|
417
|
+
this.inputElementRef.value.focus()
|
|
418
418
|
}
|
|
419
419
|
}
|
|
420
420
|
|
|
@@ -487,16 +487,16 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
487
487
|
'ring-error-default focus-within:ring-error-default': this.error,
|
|
488
488
|
'cursor-text transition-colors duration-200': true
|
|
489
489
|
})}"
|
|
490
|
-
@click=${() => this.
|
|
490
|
+
@click=${() => this.focusTextInput()}
|
|
491
491
|
role="combobox"
|
|
492
492
|
aria-autocomplete="list"
|
|
493
493
|
aria-haspopup="listbox"
|
|
494
494
|
aria-controls="options"
|
|
495
|
-
aria-expanded=${this.
|
|
495
|
+
aria-expanded=${this.open}
|
|
496
496
|
>
|
|
497
497
|
<!-- Render chips inline -->
|
|
498
498
|
${repeat(
|
|
499
|
-
this.
|
|
499
|
+
this.selectedValues$.value,
|
|
500
500
|
value => value,
|
|
501
501
|
value => html`
|
|
502
502
|
<schmancy-input-chip
|
|
@@ -504,49 +504,49 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
504
504
|
@remove=${(e: CustomEvent) => this.handleChipRemove(e.detail.value)}
|
|
505
505
|
class="shrink-0 my-0.5"
|
|
506
506
|
>
|
|
507
|
-
${this.
|
|
507
|
+
${this.getChipLabel(value)}
|
|
508
508
|
</schmancy-input-chip>
|
|
509
509
|
`
|
|
510
510
|
)}
|
|
511
511
|
|
|
512
512
|
<!-- Text input for typing -->
|
|
513
513
|
<input
|
|
514
|
-
${ref(this.
|
|
514
|
+
${ref(this.inputElementRef)}
|
|
515
515
|
id="autocomplete-input"
|
|
516
516
|
type="text"
|
|
517
517
|
class="flex-1 min-w-[120px] py-1 bg-transparent border-none outline-none ${fontSize} font-medium text-surface-on placeholder:text-muted"
|
|
518
518
|
name=${this.name || this.label?.toLowerCase().replace(/\s+/g, '-') || ''}
|
|
519
|
-
.placeholder=${this.
|
|
520
|
-
.value=${this.
|
|
519
|
+
.placeholder=${this.selectedValues$.value.length > 0 ? 'Add more...' : this.placeholder}
|
|
520
|
+
.value=${this.inputValue}
|
|
521
521
|
.autocomplete=${this.autocomplete}
|
|
522
522
|
aria-invalid=${this.error ? 'true' : 'false'}
|
|
523
523
|
aria-required=${this.required ? 'true' : 'false'}
|
|
524
|
-
aria-describedby=${this.error && this.validationMessage ? `${this.
|
|
524
|
+
aria-describedby=${this.error && this.validationMessage ? `${this.a11yId}-err` : nothing}
|
|
525
525
|
aria-label=${!this.label && this.placeholder ? this.placeholder : nothing}
|
|
526
526
|
@input=${(e: Event) => {
|
|
527
527
|
const value = (e.target as HTMLInputElement).value
|
|
528
|
-
this.
|
|
529
|
-
this.
|
|
528
|
+
this.inputValue = value
|
|
529
|
+
this.inputValue$.next(value)
|
|
530
530
|
}}
|
|
531
531
|
@focus=${(e: FocusEvent) => {
|
|
532
532
|
e.stopPropagation()
|
|
533
533
|
// Clear input on focus for new searches
|
|
534
|
-
this.
|
|
535
|
-
this.
|
|
536
|
-
this.
|
|
534
|
+
this.inputValue = ''
|
|
535
|
+
this.inputValue$.next('')
|
|
536
|
+
this.openDropdown()
|
|
537
537
|
}}
|
|
538
538
|
@keydown=${(e: KeyboardEvent) => {
|
|
539
|
-
this.
|
|
539
|
+
this.handleKeyDown(e)
|
|
540
540
|
}}
|
|
541
541
|
@blur=${() => {
|
|
542
|
-
this.
|
|
542
|
+
this.handleAutoSelectOnBlur()
|
|
543
543
|
}}
|
|
544
544
|
/>
|
|
545
545
|
</div>
|
|
546
546
|
|
|
547
547
|
<!-- Validation message -->
|
|
548
548
|
${when(this.error && this.validationMessage, () => html`
|
|
549
|
-
<div id="${this.
|
|
549
|
+
<div id="${this.a11yId}-err" class="mt-1 text-sm text-error-default" role="alert">
|
|
550
550
|
${this.validationMessage}
|
|
551
551
|
</div>
|
|
552
552
|
`)}
|
|
@@ -556,14 +556,14 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
556
556
|
<!-- Regular single-select input -->
|
|
557
557
|
<schmancy-input
|
|
558
558
|
.size=${this.size}
|
|
559
|
-
${ref(this.
|
|
559
|
+
${ref(this.inputElementRef)}
|
|
560
560
|
id="autocomplete-input"
|
|
561
561
|
class="w-full"
|
|
562
562
|
.name=${this.name || this.label?.toLowerCase().replace(/\s+/g, '-') || ''}
|
|
563
563
|
.label=${this.label}
|
|
564
564
|
.placeholder=${this.placeholder}
|
|
565
565
|
.required=${this.required}
|
|
566
|
-
.value=${this.
|
|
566
|
+
.value=${this.inputValue}
|
|
567
567
|
type="text"
|
|
568
568
|
autocomplete=${this.autocomplete}
|
|
569
569
|
clickable
|
|
@@ -571,26 +571,26 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
571
571
|
aria-autocomplete="list"
|
|
572
572
|
aria-haspopup="listbox"
|
|
573
573
|
aria-controls="options"
|
|
574
|
-
aria-expanded=${this.
|
|
574
|
+
aria-expanded=${this.open}
|
|
575
575
|
aria-describedby=${ifDefined(this.description ? descriptionId : undefined)}
|
|
576
576
|
@input=${(e: Event) => {
|
|
577
577
|
const value = (e.target as HTMLInputElement).value
|
|
578
|
-
this.
|
|
579
|
-
this.
|
|
578
|
+
this.inputValue = value
|
|
579
|
+
this.inputValue$.next(value)
|
|
580
580
|
}}
|
|
581
581
|
@focus=${(e: FocusEvent) => {
|
|
582
582
|
e.stopPropagation()
|
|
583
|
-
this.
|
|
583
|
+
this.openDropdown()
|
|
584
584
|
}}
|
|
585
585
|
@click=${(e: MouseEvent) => {
|
|
586
586
|
e.stopPropagation()
|
|
587
|
-
this.
|
|
587
|
+
this.openDropdown()
|
|
588
588
|
}}
|
|
589
589
|
@keydown=${(e: KeyboardEvent) => {
|
|
590
|
-
this.
|
|
590
|
+
this.handleKeyDown(e)
|
|
591
591
|
}}
|
|
592
592
|
@blur=${() => {
|
|
593
|
-
this.
|
|
593
|
+
this.handleAutoSelectOnBlur()
|
|
594
594
|
}}
|
|
595
595
|
>
|
|
596
596
|
</schmancy-input>
|
|
@@ -617,14 +617,14 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
617
617
|
role="listbox"
|
|
618
618
|
aria-multiselectable=${this.multi ? 'true' : 'false'}
|
|
619
619
|
aria-label=${`${this.label || 'Options'} dropdown`}
|
|
620
|
-
?hidden=${!this.
|
|
621
|
-
style="max-height: ${this.maxHeight}; display: ${this.
|
|
620
|
+
?hidden=${!this.open}
|
|
621
|
+
style="max-height: ${this.maxHeight}; display: ${this.open ? 'flex' : 'none'};"
|
|
622
622
|
@slotchange=${() => {
|
|
623
|
-
this.
|
|
623
|
+
this.setupOptionHandlers()
|
|
624
624
|
}}
|
|
625
625
|
>
|
|
626
626
|
<slot></slot>
|
|
627
|
-
${!this.
|
|
627
|
+
${!this.hasResults ? html`
|
|
628
628
|
<li class="px-3 py-2 text-sm text-muted">No results found</li>
|
|
629
629
|
` : ''}
|
|
630
630
|
</ul>
|
|
@@ -632,19 +632,19 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
632
632
|
`
|
|
633
633
|
}
|
|
634
634
|
|
|
635
|
-
private
|
|
635
|
+
private handleAutoSelectOnBlur() {
|
|
636
636
|
// Only auto-select in single-select mode and when dropdown is open with a search term
|
|
637
|
-
if (this.multi || !this.
|
|
637
|
+
if (this.multi || !this.open || !this.inputValue.trim()) {
|
|
638
638
|
return
|
|
639
639
|
}
|
|
640
640
|
|
|
641
|
-
const searchTerm = this.
|
|
641
|
+
const searchTerm = this.inputValue.trim()
|
|
642
642
|
|
|
643
643
|
// Find the best matching option using the same similarity logic as filtering
|
|
644
644
|
let bestMatch: SchmancyOption | null = null
|
|
645
645
|
let bestScore = 0
|
|
646
646
|
|
|
647
|
-
this.
|
|
647
|
+
this.options.forEach(option => {
|
|
648
648
|
// Skip hidden options
|
|
649
649
|
if (option.hidden) return
|
|
650
650
|
|
|
@@ -669,19 +669,19 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
669
669
|
// Auto-select the best match if found
|
|
670
670
|
if (bestMatch) {
|
|
671
671
|
// Silently update the selected value without firing change event
|
|
672
|
-
this.
|
|
673
|
-
this.
|
|
674
|
-
this.
|
|
675
|
-
this.
|
|
672
|
+
this.selectedValue$.next(bestMatch.value)
|
|
673
|
+
this.inputValue = bestMatch.label || bestMatch.textContent || ''
|
|
674
|
+
this.inputValue$.next(this.inputValue)
|
|
675
|
+
this.open = false
|
|
676
676
|
}
|
|
677
677
|
}
|
|
678
678
|
|
|
679
|
-
private
|
|
680
|
-
const isOpen = this.
|
|
681
|
-
const selectedValues = this.
|
|
679
|
+
private handleKeyDown(event: KeyboardEvent) {
|
|
680
|
+
const isOpen = this.open
|
|
681
|
+
const selectedValues = this.selectedValues$.value
|
|
682
682
|
|
|
683
683
|
// Handle backspace to remove last chip in multi-select when input is empty
|
|
684
|
-
if (this.multi && event.key === 'Backspace' && !this.
|
|
684
|
+
if (this.multi && event.key === 'Backspace' && !this.inputValue && selectedValues.length > 0 && !isOpen) {
|
|
685
685
|
event.preventDefault()
|
|
686
686
|
const lastValue = selectedValues[selectedValues.length - 1]
|
|
687
687
|
this.handleChipRemove(lastValue)
|
|
@@ -690,12 +690,12 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
690
690
|
|
|
691
691
|
if (!isOpen && (event.key === 'ArrowDown' || event.key === 'Enter')) {
|
|
692
692
|
event.preventDefault()
|
|
693
|
-
this.
|
|
693
|
+
this.openDropdown()
|
|
694
694
|
|
|
695
695
|
timer(10)
|
|
696
696
|
.pipe(takeUntil(this.disconnecting))
|
|
697
697
|
.subscribe(() => {
|
|
698
|
-
const firstVisible = this.
|
|
698
|
+
const firstVisible = this.options.find(opt => !opt.hidden)
|
|
699
699
|
firstVisible?.focus()
|
|
700
700
|
})
|
|
701
701
|
return
|
|
@@ -703,7 +703,7 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
703
703
|
|
|
704
704
|
if (!isOpen) return
|
|
705
705
|
|
|
706
|
-
const visibleOptions = this.
|
|
706
|
+
const visibleOptions = this.options.filter(opt => !opt.hidden)
|
|
707
707
|
.toSorted((a, b) => parseInt(a.style.order || '0') - parseInt(b.style.order || '0'))
|
|
708
708
|
|
|
709
709
|
const focusedOption = visibleOptions.find(opt => opt === document.activeElement)
|
|
@@ -712,14 +712,14 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
712
712
|
switch (event.key) {
|
|
713
713
|
case 'Escape':
|
|
714
714
|
event.preventDefault()
|
|
715
|
-
this.
|
|
716
|
-
this.
|
|
717
|
-
this.
|
|
715
|
+
this.open = false
|
|
716
|
+
this.updateInputDisplay()
|
|
717
|
+
this.inputElementRef.value?.focus()
|
|
718
718
|
break
|
|
719
719
|
|
|
720
720
|
case 'Tab':
|
|
721
|
-
this.
|
|
722
|
-
this.
|
|
721
|
+
this.open = false
|
|
722
|
+
this.updateInputDisplay()
|
|
723
723
|
break
|
|
724
724
|
|
|
725
725
|
case 'ArrowDown':
|
|
@@ -748,7 +748,7 @@ export default class SchmancyAutocomplete extends SchmancyFormField(unsafeCSS(st
|
|
|
748
748
|
case ' ':
|
|
749
749
|
if (focusedOption) {
|
|
750
750
|
event.preventDefault()
|
|
751
|
-
this.
|
|
751
|
+
this.selectOption(focusedOption)
|
|
752
752
|
}
|
|
753
753
|
break
|
|
754
754
|
}
|