@mhmo91/schmancy 0.5.44 → 0.5.45
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{animated-text-Dr32Ckh7.cjs → animated-text-2eNprXDV.cjs} +2 -2
- package/dist/{animated-text-Dr32Ckh7.cjs.map → animated-text-2eNprXDV.cjs.map} +1 -1
- package/dist/{animated-text-CPA937x-.js → animated-text-CCfSintu.js} +3 -3
- package/dist/{animated-text-CPA937x-.js.map → animated-text-CCfSintu.js.map} +1 -1
- package/dist/animated-text.cjs +1 -1
- package/dist/animated-text.js +1 -1
- package/dist/area.cjs +1 -1
- package/dist/area.component-DAPQYHtN.cjs +12 -0
- package/dist/area.component-DAPQYHtN.cjs.map +1 -0
- package/dist/{area.component-CgAISzZ3.js → area.component-DUGxsL2-.js} +38 -38
- package/dist/area.component-DUGxsL2-.js.map +1 -0
- package/dist/area.js +1 -1
- package/dist/autocomplete-CbsmZ0p6.cjs +112 -0
- package/dist/autocomplete-CbsmZ0p6.cjs.map +1 -0
- package/dist/{autocomplete--0ZoSIp0.js → autocomplete-Dcw5go_X.js} +47 -46
- package/dist/autocomplete-Dcw5go_X.js.map +1 -0
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/{avatar-BixWcgH7.js → avatar-C6l64slz.js} +204 -195
- package/dist/avatar-C6l64slz.js.map +1 -0
- package/dist/{avatar-5cjrkZS5.cjs → avatar-wheGmG83.cjs} +39 -52
- package/dist/avatar-wheGmG83.cjs.map +1 -0
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/{boat-Bou0hRnM.js → boat-Ct95p20s.js} +3 -3
- package/dist/{boat-Bou0hRnM.js.map → boat-Ct95p20s.js.map} +1 -1
- package/dist/{boat-CkkEmZcE.cjs → boat-pwsR3UrD.cjs} +2 -2
- package/dist/{boat-CkkEmZcE.cjs.map → boat-pwsR3UrD.cjs.map} +1 -1
- package/dist/boat.cjs +1 -1
- package/dist/boat.js +1 -1
- package/dist/busy.cjs +1 -1
- package/dist/busy.js +1 -1
- package/dist/button.cjs +1 -1
- package/dist/button.js +1 -1
- package/dist/card.cjs +1 -1
- package/dist/card.js +1 -1
- package/dist/{checkbox-DODyS0zq.cjs → checkbox-BXpnd4MJ.cjs} +2 -2
- package/dist/{checkbox-DODyS0zq.cjs.map → checkbox-BXpnd4MJ.cjs.map} +1 -1
- package/dist/{checkbox-D8ZJSnVa.js → checkbox-DedHgVWe.js} +2 -2
- package/dist/{checkbox-D8ZJSnVa.js.map → checkbox-DedHgVWe.js.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +2 -2
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/{code-preview-BZmBRwu-.cjs → code-preview-DC1nnjD6.cjs} +2 -2
- package/dist/{code-preview-BZmBRwu-.cjs.map → code-preview-DC1nnjD6.cjs.map} +1 -1
- package/dist/{code-preview-CTnFGeWr.js → code-preview-DmYqwM0J.js} +2 -2
- package/dist/{code-preview-CTnFGeWr.js.map → code-preview-DmYqwM0J.js.map} +1 -1
- package/dist/components.cjs +1 -1
- package/dist/components.js +1 -1
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/{date-range-CoETNfZb.cjs → date-range-B1l0Wnyd.cjs} +2 -2
- package/dist/{date-range-CoETNfZb.cjs.map → date-range-B1l0Wnyd.cjs.map} +1 -1
- package/dist/{date-range-ClsaySUj.js → date-range-D5kBOyG0.js} +3 -3
- package/dist/{date-range-ClsaySUj.js.map → date-range-D5kBOyG0.js.map} +1 -1
- package/dist/{date-range-inline-DANhDNYe.cjs → date-range-inline-BbTCdiL0.cjs} +2 -2
- package/dist/{date-range-inline-DANhDNYe.cjs.map → date-range-inline-BbTCdiL0.cjs.map} +1 -1
- package/dist/{date-range-inline-DGlKBtNK.js → date-range-inline-Curj100b.js} +3 -3
- package/dist/{date-range-inline-DGlKBtNK.js.map → date-range-inline-Curj100b.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-BYgsZZlo.js → delay-B8D9ePlX.js} +2 -2
- package/dist/{delay-BYgsZZlo.js.map → delay-B8D9ePlX.js.map} +1 -1
- package/dist/{delay-C_eK0GWj.cjs → delay-BR6cMb_F.cjs} +2 -2
- package/dist/{delay-C_eK0GWj.cjs.map → delay-BR6cMb_F.cjs.map} +1 -1
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/{details-YOyqdGM4.js → details-CpuplvIM.js} +2 -2
- package/dist/{details-YOyqdGM4.js.map → details-CpuplvIM.js.map} +1 -1
- package/dist/{details-CRLG7_Rx.cjs → details-DCzexjYw.cjs} +2 -2
- package/dist/{details-CRLG7_Rx.cjs.map → details-DCzexjYw.cjs.map} +1 -1
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{dialog-content-Bm8humI-.cjs → dialog-content-DUnSEoaA.cjs} +2 -2
- package/dist/{dialog-content-Bm8humI-.cjs.map → dialog-content-DUnSEoaA.cjs.map} +1 -1
- package/dist/{dialog-content-CXshnL4t.js → dialog-content-wcZn95Gx.js} +3 -3
- package/dist/{dialog-content-CXshnL4t.js.map → dialog-content-wcZn95Gx.js.map} +1 -1
- package/dist/dialog.cjs +1 -1
- package/dist/dialog.js +1 -1
- package/dist/{divider-BD7cCM-N.js → divider-C4d0QNQU.js} +3 -3
- package/dist/{divider-BD7cCM-N.js.map → divider-C4d0QNQU.js.map} +1 -1
- package/dist/{divider-W9uJ8C3q.cjs → divider-nVB0kEMZ.cjs} +2 -2
- package/dist/{divider-W9uJ8C3q.cjs.map → divider-nVB0kEMZ.cjs.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/{dropdown-content-DnWgB8CR.cjs → dropdown-content-CNc79RjI.cjs} +2 -2
- package/dist/{dropdown-content-DnWgB8CR.cjs.map → dropdown-content-CNc79RjI.cjs.map} +1 -1
- package/dist/{dropdown-content-C7b_9CMw.js → dropdown-content-D2GCSD5Z.js} +3 -3
- package/dist/{dropdown-content-C7b_9CMw.js.map → dropdown-content-D2GCSD5Z.js.map} +1 -1
- package/dist/dropdown.cjs +1 -1
- package/dist/dropdown.js +1 -1
- package/dist/{email-recipients-CyIXLoSh.js → email-recipients-C-5ER5TU.js} +5 -5
- package/dist/{email-recipients-CyIXLoSh.js.map → email-recipients-C-5ER5TU.js.map} +1 -1
- package/dist/{email-recipients-whsZqIpA.cjs → email-recipients-DRxGI7gT.cjs} +2 -2
- package/dist/{email-recipients-whsZqIpA.cjs.map → email-recipients-DRxGI7gT.cjs.map} +1 -1
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{flex-DvZKaAtN.js → flex-BeghKdy8.js} +2 -2
- package/dist/{flex-DvZKaAtN.js.map → flex-BeghKdy8.js.map} +1 -1
- package/dist/{flex-C0O9O1yV.cjs → flex-C66W_bVN.cjs} +2 -2
- package/dist/{flex-C0O9O1yV.cjs.map → flex-C66W_bVN.cjs.map} +1 -1
- package/dist/{form-D4AZek8y.cjs → form-BLnfpLCB.cjs} +2 -2
- package/dist/{form-D4AZek8y.cjs.map → form-BLnfpLCB.cjs.map} +1 -1
- package/dist/{form-BsI5Sk-R.js → form-CzSXaOL2.js} +2 -2
- package/dist/{form-BsI5Sk-R.js.map → form-CzSXaOL2.js.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{formField.mixin-DfxR1FzZ.cjs → formField.mixin-DdQvbwbp.cjs} +2 -2
- package/dist/{formField.mixin-DfxR1FzZ.cjs.map → formField.mixin-DdQvbwbp.cjs.map} +1 -1
- package/dist/{formField.mixin-C_a5Hccx.js → formField.mixin-SU-0UQ6O.js} +2 -2
- package/dist/{formField.mixin-C_a5Hccx.js.map → formField.mixin-SU-0UQ6O.js.map} +1 -1
- package/dist/{icon-J11blFZq.cjs → icon-B38Atn5F.cjs} +2 -2
- package/dist/{icon-J11blFZq.cjs.map → icon-B38Atn5F.cjs.map} +1 -1
- package/dist/{icon-5LbOG-V0.js → icon-BAE9GvxI.js} +2 -2
- package/dist/{icon-5LbOG-V0.js.map → icon-BAE9GvxI.js.map} +1 -1
- package/dist/{icon-button-DjfEYUdj.cjs → icon-button-D24NUFs7.cjs} +2 -2
- package/dist/{icon-button-DjfEYUdj.cjs.map → icon-button-D24NUFs7.cjs.map} +1 -1
- package/dist/{icon-button-Cwm3vcDO.js → icon-button-gNZEaDU2.js} +3 -3
- package/dist/{icon-button-Cwm3vcDO.js.map → icon-button-gNZEaDU2.js.map} +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +49 -49
- package/dist/{input-DbzpwrUh.cjs → input-B-87Y5m2.cjs} +2 -2
- package/dist/{input-DbzpwrUh.cjs.map → input-B-87Y5m2.cjs.map} +1 -1
- package/dist/{input-DO5pS6fE.js → input-Db0akZJI.js} +3 -3
- package/dist/{input-DO5pS6fE.js.map → input-Db0akZJI.js.map} +1 -1
- package/dist/{input-chip-CXZTmfwT.js → input-chip-DT7Zln32.js} +2 -2
- package/dist/{input-chip-CXZTmfwT.js.map → input-chip-DT7Zln32.js.map} +1 -1
- package/dist/{input-chip-CBJxQ2MI.cjs → input-chip-Y6Umqn68.cjs} +2 -2
- package/dist/{input-chip-CBJxQ2MI.cjs.map → input-chip-Y6Umqn68.cjs.map} +1 -1
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +1 -1
- package/dist/{list-C7wTsdkZ.cjs → list-Bx4nE-9X.cjs} +2 -2
- package/dist/{list-C7wTsdkZ.cjs.map → list-Bx4nE-9X.cjs.map} +1 -1
- package/dist/{list-Cbrv1Y7B.js → list-D5CL0Hmr.js} +2 -2
- package/dist/{list-Cbrv1Y7B.js.map → list-D5CL0Hmr.js.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-DwXXrxwO.js → litElement.mixin-DLWHaMp5.js} +2 -2
- package/dist/{litElement.mixin-DwXXrxwO.js.map → litElement.mixin-DLWHaMp5.js.map} +1 -1
- package/dist/{litElement.mixin-Dlq4PNEh.cjs → litElement.mixin-vtpQghkf.cjs} +2 -2
- package/dist/{litElement.mixin-Dlq4PNEh.cjs.map → litElement.mixin-vtpQghkf.cjs.map} +1 -1
- package/dist/mailbox.cjs +1 -1
- package/dist/mailbox.js +1 -1
- package/dist/{map-6p1rwGq_.js → map-BgWSgSOf.js} +2 -2
- package/dist/{map-6p1rwGq_.js.map → map-BgWSgSOf.js.map} +1 -1
- package/dist/{map-B3Ond3EJ.cjs → map-ChhBWqG-.cjs} +2 -2
- package/dist/{map-B3Ond3EJ.cjs.map → map-ChhBWqG-.cjs.map} +1 -1
- package/dist/map.cjs +1 -1
- package/dist/map.js +1 -1
- package/dist/{media-8qL5J_9U.js → media-DnpRpbFQ.js} +2 -2
- package/dist/{media-8qL5J_9U.js.map → media-DnpRpbFQ.js.map} +1 -1
- package/dist/{media-urvTQuhG.cjs → media-hFrznC-7.cjs} +2 -2
- package/dist/{media-urvTQuhG.cjs.map → media-hFrznC-7.cjs.map} +1 -1
- package/dist/{menu-CAqcdA-t.cjs → menu-DkRVRYp4.cjs} +2 -2
- package/dist/{menu-CAqcdA-t.cjs.map → menu-DkRVRYp4.cjs.map} +1 -1
- package/dist/{menu-DqPjhh0F.js → menu-DqRauRjT.js} +3 -3
- package/dist/{menu-DqPjhh0F.js.map → menu-DqRauRjT.js.map} +1 -1
- package/dist/menu.cjs +1 -1
- package/dist/menu.js +1 -1
- package/dist/nav-drawer.cjs +1 -1
- package/dist/nav-drawer.js +1 -1
- package/dist/navigation-bar.cjs +1 -1
- package/dist/navigation-bar.js +1 -1
- package/dist/{navigation-rail-G9DFyu8b.cjs → navigation-rail-CBhirMNF.cjs} +3 -3
- package/dist/{navigation-rail-G9DFyu8b.cjs.map → navigation-rail-CBhirMNF.cjs.map} +1 -1
- package/dist/{navigation-rail-B1JZU-E_.js → navigation-rail-Ncy6rBEj.js} +4 -4
- package/dist/{navigation-rail-B1JZU-E_.js.map → navigation-rail-Ncy6rBEj.js.map} +1 -1
- package/dist/navigation-rail.cjs +1 -1
- package/dist/navigation-rail.js +1 -1
- package/dist/{notification-service-D2iAqL5y.cjs → notification-service-BcrHAzSN.cjs} +2 -2
- package/dist/{notification-service-D2iAqL5y.cjs.map → notification-service-BcrHAzSN.cjs.map} +1 -1
- package/dist/{notification-service-C2FCNL6K.js → notification-service-CRAcOFSD.js} +4 -4
- package/dist/{notification-service-C2FCNL6K.js.map → notification-service-CRAcOFSD.js.map} +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +2 -2
- package/dist/{notify-CGUpuJK_.cjs → notify-BZLGxTpL.cjs} +2 -2
- package/dist/{notify-CGUpuJK_.cjs.map → notify-BZLGxTpL.cjs.map} +1 -1
- package/dist/{notify-CXgvep0J.js → notify-zBmyDMjt.js} +2 -2
- package/dist/{notify-CXgvep0J.js.map → notify-zBmyDMjt.js.map} +1 -1
- package/dist/{option-CWqav-ae.js → option-BOs02M9F.js} +2 -2
- package/dist/{option-CWqav-ae.js.map → option-BOs02M9F.js.map} +1 -1
- package/dist/{option-D8qnpwBr.cjs → option-CJZFrYDI.cjs} +2 -2
- package/dist/{option-D8qnpwBr.cjs.map → option-CJZFrYDI.cjs.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{payment-card-form-pQBAeXvc.cjs → payment-card-form-C3RKAyE-.cjs} +2 -2
- package/dist/{payment-card-form-pQBAeXvc.cjs.map → payment-card-form-C3RKAyE-.cjs.map} +1 -1
- package/dist/{payment-card-form-09YuBc3U.js → payment-card-form-S9DUk7kb.js} +3 -3
- package/dist/{payment-card-form-09YuBc3U.js.map → payment-card-form-S9DUk7kb.js.map} +1 -1
- package/dist/{progress-nWFc1Ixd.cjs → progress-C36hgIf5.cjs} +2 -2
- package/dist/{progress-nWFc1Ixd.cjs.map → progress-C36hgIf5.cjs.map} +1 -1
- package/dist/{progress-BLRwJ_un.js → progress-DtJc6jWJ.js} +2 -2
- package/dist/{progress-BLRwJ_un.js.map → progress-DtJc6jWJ.js.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/{radio-button-DIjkirPr.cjs → radio-button-BEoY5yRc.cjs} +2 -2
- package/dist/{radio-button-DIjkirPr.cjs.map → radio-button-BEoY5yRc.cjs.map} +1 -1
- package/dist/{radio-button-BC0Of2-G.js → radio-button-aKwgu1bt.js} +3 -3
- package/dist/{radio-button-BC0Of2-G.js.map → radio-button-aKwgu1bt.js.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/{schmancy-steps-container-Sf8RjF0N.js → schmancy-steps-container-D5sbskLl.js} +2 -2
- package/dist/{schmancy-steps-container-Sf8RjF0N.js.map → schmancy-steps-container-D5sbskLl.js.map} +1 -1
- package/dist/{schmancy-steps-container-B8B2ZnTB.cjs → schmancy-steps-container-DINAsJgP.cjs} +2 -2
- package/dist/{schmancy-steps-container-B8B2ZnTB.cjs.map → schmancy-steps-container-DINAsJgP.cjs.map} +1 -1
- package/dist/{select-C6QlML9m.js → select-Bq_CyEe1.js} +3 -3
- package/dist/{select-C6QlML9m.js.map → select-Bq_CyEe1.js.map} +1 -1
- package/dist/{select-CqlN3vWr.cjs → select-C0gf-GTX.cjs} +2 -2
- package/dist/{select-CqlN3vWr.cjs.map → select-C0gf-GTX.cjs.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/{sheet-Dxx7iH9V.js → sheet-PXddkPIR.js} +3 -3
- package/dist/{sheet-Dxx7iH9V.js.map → sheet-PXddkPIR.js.map} +1 -1
- package/dist/{sheet-D6yxukD7.cjs → sheet-vJ5lJw8A.cjs} +2 -2
- package/dist/{sheet-D6yxukD7.cjs.map → sheet-vJ5lJw8A.cjs.map} +1 -1
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +1 -1
- package/dist/{slider-BIjiRBMB.js → slider-CSC7AOPU.js} +3 -3
- package/dist/{slider-BIjiRBMB.js.map → slider-CSC7AOPU.js.map} +1 -1
- package/dist/{slider-BGgXG44k.cjs → slider-In_OE4B9.cjs} +2 -2
- package/dist/{slider-BGgXG44k.cjs.map → slider-In_OE4B9.cjs.map} +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{spinner-D8IKqMrW.js → spinner-Db7i3EZh.js} +2 -2
- package/dist/{spinner-D8IKqMrW.js.map → spinner-Db7i3EZh.js.map} +1 -1
- package/dist/{spinner-CFx3p13n.cjs → spinner-DpIB845r.cjs} +2 -2
- package/dist/{spinner-CFx3p13n.cjs.map → spinner-DpIB845r.cjs.map} +1 -1
- package/dist/steps.cjs +1 -1
- package/dist/steps.js +1 -1
- package/dist/{suggestion-chip-DHpWcimf.js → suggestion-chip-CJygiEf_.js} +3 -3
- package/dist/{suggestion-chip-DHpWcimf.js.map → suggestion-chip-CJygiEf_.js.map} +1 -1
- package/dist/{suggestion-chip-KkPIwkYP.cjs → suggestion-chip-DgwbXrI1.cjs} +2 -2
- package/dist/{suggestion-chip-KkPIwkYP.cjs.map → suggestion-chip-DgwbXrI1.cjs.map} +1 -1
- package/dist/{surface-pMQpuZWM.cjs → surface-Do6Jvjgs.cjs} +2 -2
- package/dist/{surface-pMQpuZWM.cjs.map → surface-Do6Jvjgs.cjs.map} +1 -1
- package/dist/{surface-CkSAxbh2.js → surface-OK-98YMi.js} +2 -2
- package/dist/{surface-CkSAxbh2.js.map → surface-OK-98YMi.js.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/{table-CVHtS_w_.cjs → table-CJAjGdP2.cjs} +2 -2
- package/dist/{table-CVHtS_w_.cjs.map → table-CJAjGdP2.cjs.map} +1 -1
- package/dist/{table-BgQCOk5g.js → table-IX2oy6pR.js} +2 -2
- package/dist/{table-BgQCOk5g.js.map → table-IX2oy6pR.js.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/{tabs-compatibility-BCtEpyN5.js → tabs-compatibility-BcjBZAcx.js} +2 -2
- package/dist/{tabs-compatibility-BCtEpyN5.js.map → tabs-compatibility-BcjBZAcx.js.map} +1 -1
- package/dist/{tabs-compatibility-w2lmMs2h.cjs → tabs-compatibility-DRL9DJHu.cjs} +2 -2
- package/dist/{tabs-compatibility-w2lmMs2h.cjs.map → tabs-compatibility-DRL9DJHu.cjs.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-CfBr6oca.cjs +2 -0
- package/dist/{tailwind.mixin-Bz_Bv8SX.cjs.map → tailwind.mixin-CfBr6oca.cjs.map} +1 -1
- package/dist/tailwind.mixin-Cx1vOdFr.js +64 -0
- package/dist/{tailwind.mixin-Be9DoonS.js.map → tailwind.mixin-Cx1vOdFr.js.map} +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-BRI0tufi.cjs → textarea-D6tLCvgH.cjs} +2 -2
- package/dist/{textarea-BRI0tufi.cjs.map → textarea-D6tLCvgH.cjs.map} +1 -1
- package/dist/{textarea-DBc8Uh7D.js → textarea-DOdMuK9D.js} +2 -2
- package/dist/{textarea-DBc8Uh7D.js.map → textarea-DOdMuK9D.js.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-button-DXCpzc5c.cjs → theme-button-BygpnNZP.cjs} +2 -2
- package/dist/{theme-button-DXCpzc5c.cjs.map → theme-button-BygpnNZP.cjs.map} +1 -1
- package/dist/{theme-button-DCYQYmF-.js → theme-button-Mtmrrq0s.js} +2 -2
- package/dist/{theme-button-DCYQYmF-.js.map → theme-button-Mtmrrq0s.js.map} +1 -1
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/{theme-controller-boat-HDnVrCW1.cjs → theme-controller-boat-6PcxsUUQ.cjs} +2 -2
- package/dist/{theme-controller-boat-HDnVrCW1.cjs.map → theme-controller-boat-6PcxsUUQ.cjs.map} +1 -1
- package/dist/{theme-controller-boat-C_6tVWSS.js → theme-controller-boat-CFWhF7oJ.js} +3 -3
- package/dist/{theme-controller-boat-C_6tVWSS.js.map → theme-controller-boat-CFWhF7oJ.js.map} +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/theme.js +1 -1
- package/dist/{timezone-Atm5Dy-B.js → timezone-CZ3y_y_n.js} +3 -3
- package/dist/{timezone-Atm5Dy-B.js.map → timezone-CZ3y_y_n.js.map} +1 -1
- package/dist/{timezone-BQaIFLiV.cjs → timezone-GffBsJxM.cjs} +2 -2
- package/dist/{timezone-BQaIFLiV.cjs.map → timezone-GffBsJxM.cjs.map} +1 -1
- package/dist/{tooltip-C-PhMMvT.js → tooltip-BlwQ_fIF.js} +2 -2
- package/dist/{tooltip-C-PhMMvT.js.map → tooltip-BlwQ_fIF.js.map} +1 -1
- package/dist/{tooltip-SBsMu8ZQ.cjs → tooltip-PI0IE4wA.cjs} +2 -2
- package/dist/{tooltip-SBsMu8ZQ.cjs.map → tooltip-PI0IE4wA.cjs.map} +1 -1
- package/dist/tooltip.cjs +1 -1
- package/dist/tooltip.js +1 -1
- package/dist/{tree-BagJ6dD2.js → tree-Cum3Na-a.js} +2 -2
- package/dist/{tree-BagJ6dD2.js.map → tree-Cum3Na-a.js.map} +1 -1
- package/dist/{tree-j0lH3CZh.cjs → tree-Cxfl4yJv.cjs} +2 -2
- package/dist/{tree-j0lH3CZh.cjs.map → tree-Cxfl4yJv.cjs.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/{typewriter-BawsYtHa.cjs → typewriter-BaiAOEvZ.cjs} +2 -2
- package/dist/{typewriter-BawsYtHa.cjs.map → typewriter-BaiAOEvZ.cjs.map} +1 -1
- package/dist/{typewriter-BjiolWBJ.js → typewriter-DTcmDBnt.js} +4 -4
- package/dist/{typewriter-BjiolWBJ.js.map → typewriter-DTcmDBnt.js.map} +1 -1
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/{typography-CyDDUJ9J.js → typography-BLHV8e7O.js} +2 -2
- package/dist/{typography-CyDDUJ9J.js.map → typography-BLHV8e7O.js.map} +1 -1
- package/dist/{typography-Bk9jOEtx.cjs → typography-CtesPGRT.cjs} +2 -2
- package/dist/{typography-Bk9jOEtx.cjs.map → typography-CtesPGRT.cjs.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/package.json +1 -1
- package/types/src/autocomplete/autocomplete.d.ts +1 -1
- package/types/src/content-drawer/drawer.d.ts +6 -0
- package/types/src/content-drawer/drawer.service.d.ts +12 -1
- package/types/src/content-drawer/main.d.ts +2 -2
- package/dist/area.component-C3uCk-c1.cjs +0 -12
- package/dist/area.component-C3uCk-c1.cjs.map +0 -1
- package/dist/area.component-CgAISzZ3.js.map +0 -1
- package/dist/autocomplete--0ZoSIp0.js.map +0 -1
- package/dist/autocomplete-CpCXamUl.cjs +0 -112
- package/dist/autocomplete-CpCXamUl.cjs.map +0 -1
- package/dist/avatar-5cjrkZS5.cjs.map +0 -1
- package/dist/avatar-BixWcgH7.js.map +0 -1
- package/dist/tailwind.mixin-Be9DoonS.js +0 -64
- package/dist/tailwind.mixin-Bz_Bv8SX.cjs +0 -2
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"autocomplete-CpCXamUl.cjs","sources":["../src/autocomplete/autocomplete.ts"],"sourcesContent":["import { $LitElement } from '@mixins/index'\nimport { InputSize, SchmancyInput } from '@schmancy/input'\nimport SchmancyOption from '@schmancy/option/option'\nimport { html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { repeat } from 'lit/directives/repeat.js'\nimport { when } from 'lit/directives/when.js'\nimport {\n BehaviorSubject,\n combineLatest\n} from 'rxjs'\nimport {\n debounceTime,\n distinctUntilChanged,\n take,\n takeUntil,\n tap\n} from 'rxjs/operators'\nimport style from './autocomplete.scss?inline'\n\n// Import the similarity function (or include it inline)\nimport { similarity } from '../utils/search'\n// Import chip component for multi-select display\nimport '../chips/input-chip'\n\nexport type SchmancyAutocompleteChangeEvent = CustomEvent<{\n value: string | string[]\n values?: string[]\n}>\n\ninterface FilteredOption {\n option: SchmancyOption\n score: number\n}\n\n@customElement('schmancy-autocomplete')\nexport default class SchmancyAutocomplete extends $LitElement(style) {\n // Track whether value/values have been explicitly set\n _valueSet: boolean = false\n _valuesSet: boolean = false\n\n // Public API properties\n @property({ type: Boolean }) required = false\n @property({ type: String }) placeholder = ''\n @property({ type: String, reflect: true }) label = ''\n @property({ type: String }) name = ''\n @property({ type: String }) maxHeight = '300px'\n @property({ type: Boolean }) multi = false\n @property({ type: String }) description = ''\n @property({ type: String, reflect: true }) size: InputSize = 'md'\n @property({ type: String }) autocomplete = 'off'\n @property({ type: Number }) debounceMs = 200\n @property({ type: Number }) similarityThreshold = 0.3 // Minimum similarity score to show option\n @property({ type: Boolean }) error = false\n @property({ type: String }) validationMessage = ''\n\n // Values property for multi-select mode\n @property({ type: Array })\n get values() {\n return [...this._selectedValues$.value]\n }\n set values(vals: string[]) {\n this._valuesSet = true\n this._selectedValues$.next(Array.isArray(vals) ? [...vals] : [])\n }\n\n // Value property\n @property({ type: String, reflect: true })\n get value() {\n return this.multi \n ? this._selectedValues$.value.join(',')\n : this._selectedValue$.value\n }\n set value(val: string) {\n this._valueSet = true\n if (this.multi) {\n const newValues = val ? val.split(',').map(v => v.trim()).filter(Boolean) : []\n const currentValues = this._selectedValues$.value\n // Only update if values actually changed\n if (JSON.stringify(newValues) !== JSON.stringify(currentValues)) {\n this._selectedValues$.next(newValues)\n }\n } else {\n // Only update if value actually changed\n if (val !== this._selectedValue$.value) {\n this._selectedValue$.next(val)\n // Update the input display when value is set\n this._updateInputDisplay()\n }\n }\n }\n\n // State\n @state() private _open = false\n @state() private _inputValue = ''\n @state() private _visibleOptionsCount = 0\n @state() private _hasResults = true\n\n // Track if we're clicking on an option to prevent blur interference\n private _isSelectingOption = false\n\n // DOM references\n @query('#options') _listbox!: HTMLUListElement\n @query('sch-input') _input!: SchmancyInput\n @queryAssignedElements({ flatten: true }) private _options!: SchmancyOption[]\n private _inputElementRef = createRef<HTMLInputElement>()\n\n // RxJS Subjects - only what we actually need\n private _selectedValue$ = new BehaviorSubject<string>('')\n private _selectedValues$ = new BehaviorSubject<string[]>([])\n private _inputValue$ = new BehaviorSubject<string>('')\n\n connectedCallback() {\n super.connectedCallback()\n\n if (!this.id) {\n this.id = `sch-autocomplete-${Math.random().toString(36).slice(2, 9)}`\n }\n\n this._setupAutocompleteLogic()\n this._setupDocumentClickHandler()\n }\n\n private _setupAutocompleteLogic() {\n // Sync selection state\n combineLatest([\n this._selectedValue$,\n this._selectedValues$\n ]).pipe(\n tap(([selectedValue, selectedValues]) => {\n this._updateOptionSelection(selectedValue, selectedValues)\n }),\n takeUntil(this.disconnecting)\n ).subscribe()\n\n // Filter options based on input\n this._inputValue$.pipe(\n distinctUntilChanged(),\n debounceTime(this.debounceMs),\n tap(searchTerm => {\n if (this._open) {\n this._filterOptions(searchTerm)\n }\n }),\n takeUntil(this.disconnecting)\n ).subscribe()\n }\n\n private _setupOptionHandlers() {\n this._options.forEach((option, index) => {\n option.setAttribute('role', 'option')\n option.tabIndex = -1\n if (!option.id) {\n option.id = `${this.id}-option-${index}`\n }\n // Prevent blur handler from interfering with option selection\n option.onmousedown = (e: MouseEvent) => {\n e.preventDefault() // Prevent focus loss\n this._isSelectingOption = true\n }\n\n // Handle the actual selection\n option.onclick = (e: MouseEvent) => {\n e.stopPropagation()\n this._selectOption(option)\n // Reset flag after a short delay\n setTimeout(() => {\n this._isSelectingOption = false\n }, 50)\n }\n })\n }\n\n private _updateOptionSelection(selectedValue: string, selectedValues: string[]) {\n this._options.forEach(option => {\n option.selected = this.multi\n ? selectedValues.includes(option.value)\n : option.value === selectedValue\n option.setAttribute('aria-selected', String(option.selected))\n })\n }\n\n private _filterOptions(searchTerm: string) {\n const term = searchTerm.trim()\n\n if (!term) {\n // Show all options if no search term\n this._options.forEach(option => {\n option.hidden = false\n option.style.order = '0'\n })\n this._visibleOptionsCount = this._options.length\n this._hasResults = true\n } else {\n // Calculate similarity scores for all options\n const scoredOptions: FilteredOption[] = this._options.map(option => {\n const optionLabel = option.label || option.textContent || ''\n const optionValue = option.value\n\n const labelScore = similarity(term, optionLabel)\n const valueScore = similarity(term, optionValue)\n const score = Math.max(labelScore * 1.1, valueScore)\n\n return { option, score }\n })\n\n // Sort by score (highest first)\n scoredOptions.sort((a, b) => b.score - a.score)\n\n // Apply visibility and ordering\n let visibleCount = 0\n scoredOptions.forEach((item, index) => {\n const { option, score } = item\n\n if (score < this.similarityThreshold) {\n option.hidden = true\n } else {\n option.hidden = false\n visibleCount++\n option.style.order = String(index)\n }\n })\n\n this._visibleOptionsCount = visibleCount\n this._hasResults = visibleCount > 0\n }\n\n this._announceToScreenReader(\n this._visibleOptionsCount > 0\n ? `${this._visibleOptionsCount} option${this._visibleOptionsCount === 1 ? '' : 's'} available.`\n : 'No results found.'\n )\n }\n\n private _selectOption(option: SchmancyOption) {\n if (this.multi) {\n const currentValues = this._selectedValues$.value\n const index = currentValues.indexOf(option.value)\n const newValues = index > -1\n ? currentValues.filter(v => v !== option.value)\n : [...currentValues, option.value]\n\n this._selectedValues$.next(newValues)\n this._announceToScreenReader(\n newValues.length > 0\n ? `Selected: ${this._getSelectedLabels().join(', ')}`\n : 'No options selected'\n )\n this._fireChangeEvent()\n } else {\n // Fix the bug: Update value BEFORE firing event\n this._selectedValue$.next(option.value)\n\n // Now fire event with the NEW value\n this._fireChangeEvent()\n\n // Update UI\n this._open = false\n this._inputValue = option.label || option.textContent || ''\n this._inputValue$.next(this._inputValue)\n\n // Blur the input\n setTimeout(() => this._inputElementRef.value?.blur(), 100)\n\n this._announceToScreenReader(`Selected: ${option.label || option.textContent}`)\n }\n }\n\n private _setupDocumentClickHandler() {\n // Simple document click handler\n const handleDocumentClick = (e: MouseEvent) => {\n if (!this._open) return\n\n const path = e.composedPath()\n if (!path.includes(this) && !this._options.some(opt => path.includes(opt))) {\n this._open = false\n this._updateInputDisplay()\n }\n }\n\n document.addEventListener('click', handleDocumentClick)\n\n // Cleanup on disconnect\n this.disconnecting.pipe(take(1)).subscribe(() => {\n document.removeEventListener('click', handleDocumentClick)\n })\n }\n\n\n private _updateInputDisplay() {\n // For multi-select, we don't update input display since chips show the selections\n if (this.multi) return\n\n const selectedValue = this._selectedValue$.value\n const option = this._options.find(opt => opt.value === selectedValue)\n this._inputValue = option ? option.label || option.textContent || '' : ''\n this._inputValue$.next(this._inputValue)\n\n if (this._inputElementRef.value) {\n this._inputElementRef.value.value = this._inputValue\n }\n }\n\n private _getSelectedLabels(): string[] {\n return this._options\n .filter(option => \n this.multi \n ? this._selectedValues$.value.includes(option.value)\n : option.value === this._selectedValue$.value\n )\n .map(option => option.label || option.textContent || '')\n }\n\n private _announceToScreenReader(message: string) {\n const liveRegion = this.shadowRoot?.querySelector('#live-status')\n if (liveRegion) {\n liveRegion.textContent = message\n }\n }\n\n private _fireChangeEvent() {\n const detail: SchmancyAutocompleteChangeEvent['detail'] = {\n value: this.value,\n }\n\n if (this.multi) {\n detail.values = [...this._selectedValues$.value]\n }\n\n this.dispatchEvent(\n new CustomEvent<SchmancyAutocompleteChangeEvent['detail']>('change', {\n detail,\n bubbles: true,\n composed: true,\n })\n )\n }\n\n public checkValidity(): boolean {\n if (!this.required) return true\n return this.multi \n ? this._selectedValues$.value.length > 0 \n : Boolean(this._selectedValue$.value)\n }\n\n public reportValidity(): boolean {\n if (this._inputElementRef.value) {\n return this._inputElementRef.value.reportValidity()\n }\n return this.checkValidity()\n }\n\n firstUpdated() {\n this._setupOptionHandlers()\n\n // Sync initial value with display after options are available\n this._updateInputDisplay()\n\n // Update options when slot changes\n const slot = this.shadowRoot?.querySelector('slot')\n slot?.addEventListener('slotchange', () => {\n this._setupOptionHandlers()\n this._updateOptionSelection(this._selectedValue$.value, this._selectedValues$.value)\n })\n }\n\n private handleChipRemove(value: string) {\n const currentValues = this._selectedValues$.value\n const newValues = currentValues.filter(v => v !== value)\n this._selectedValues$.next(newValues)\n this._fireChangeEvent()\n this._announceToScreenReader(`Removed: ${this._getChipLabel(value)}`)\n }\n\n private _getChipLabel(value: string): string {\n const option = this._options.find(opt => opt.value === value)\n return option ? option.label || option.textContent || value : value\n }\n\n private _focusTextInput() {\n if (this._inputElementRef.value) {\n this._inputElementRef.value.focus()\n }\n }\n\n render() {\n const descriptionId = `${this.id}-desc`\n\n // Get size-based styling to match Schmancy input\n const getSizeStyles = () => {\n switch (this.size) {\n case 'sm':\n return {\n height: 'min-h-[40px]',\n padding: 'px-2',\n fontSize: 'text-sm', // 14px\n labelSize: 'text-sm'\n }\n case 'lg':\n return {\n height: 'min-h-[60px]',\n padding: 'px-5',\n fontSize: 'text-lg', // 18px\n labelSize: 'text-lg'\n }\n case 'md':\n default:\n return {\n height: 'min-h-[50px]',\n padding: 'px-4',\n fontSize: 'text-base', // 16px\n labelSize: 'text-base'\n }\n }\n }\n\n const { height, padding, fontSize, labelSize } = getSizeStyles()\n\n return html`\n <div class=\"relative\">\n <!-- Screen reader live region -->\n <div id=\"live-status\" role=\"status\" aria-live=\"polite\" class=\"sr-only\"></div>\n\n <!-- Description -->\n ${this.description ? html`<div id=\"${descriptionId}\" class=\"sr-only\">${this.description}</div>` : ''}\n\n <!-- Custom input wrapper for Gmail-style chip input -->\n <slot name=\"trigger\">\n ${when(this.multi,\n () => html`\n <!-- Custom multi-select input with inline chips -->\n <div class=\"relative\">\n ${when(this.label, () => html`\n <label class=\"${classMap({\n 'block mb-1 font-medium': true,\n 'text-primary-default': !this.error,\n 'text-error-default': this.error,\n [labelSize]: true\n })}\">\n ${this.label}${this.required ? html`<span class=\"text-error-default ml-1\">*</span>` : ''}\n </label>\n `)}\n <div\n class=\"${classMap({\n 'flex flex-wrap items-center gap-1': true,\n [height]: true,\n [padding]: true,\n 'block w-full min-w-0 rounded-[8px] border-0': true,\n 'bg-surface-highest text-surface-on': true,\n 'ring-0 ring-inset focus-within:ring-1 focus-within:ring-inset': true,\n 'ring-secondary-default focus-within:ring-secondary-default': !this.error,\n 'ring-error-default focus-within:ring-error-default': this.error,\n 'cursor-text transition-colors duration-200': true\n })}\"\n @click=${() => this._focusTextInput()}\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-haspopup=\"listbox\"\n aria-controls=\"options\"\n aria-expanded=${this._open}\n >\n <!-- Render chips inline -->\n ${repeat(\n this._selectedValues$.value,\n value => value,\n value => html`\n <schmancy-input-chip\n .value=${value}\n @remove=${(e: CustomEvent) => this.handleChipRemove(e.detail.value)}\n class=\"flex-shrink-0 my-0.5\"\n >\n ${this._getChipLabel(value)}\n </schmancy-input-chip>\n `\n )}\n\n <!-- Text input for typing -->\n <input\n ${ref(this._inputElementRef)}\n id=\"autocomplete-input\"\n type=\"text\"\n class=\"flex-1 min-w-[120px] py-1 bg-transparent border-none outline-none ${fontSize} font-medium text-surface-on placeholder:text-muted\"\n name=${this.name || this.label?.toLowerCase().replace(/\\s+/g, '-') || ''}\n .placeholder=${this._selectedValues$.value.length > 0 ? 'Add more...' : this.placeholder}\n .value=${this._inputValue}\n .autocomplete=${this.autocomplete}\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._inputValue = value\n this._inputValue$.next(value)\n }}\n @focus=${(e: FocusEvent) => {\n e.stopPropagation()\n // Clear input on focus for new searches\n this._inputValue = ''\n this._inputValue$.next('')\n this._open = true\n }}\n @keydown=${(e: KeyboardEvent) => {\n this._handleKeyDown(e)\n }}\n @blur=${() => {\n this._handleAutoSelectOnBlur()\n }}\n />\n </div>\n\n <!-- Validation message -->\n ${when(this.error && this.validationMessage, () => html`\n <div class=\"mt-1 text-sm text-error-default\">\n ${this.validationMessage}\n </div>\n `)}\n </div>\n `,\n () => html`\n <!-- Regular single-select input -->\n <schmancy-input\n .size=${this.size}\n ${ref(this._inputElementRef)}\n id=\"autocomplete-input\"\n class=\"w-full\"\n .name=${this.name || this.label?.toLowerCase().replace(/\\s+/g, '-') || ''}\n .label=${this.label}\n .placeholder=${this.placeholder}\n .required=${this.required}\n .value=${this._inputValue}\n type=\"text\"\n autocomplete=${this.autocomplete}\n clickable\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-haspopup=\"listbox\"\n aria-controls=\"options\"\n aria-expanded=${this._open}\n aria-describedby=${this.description ? descriptionId : undefined}\n @input=${(e: Event) => {\n const value = (e.target as HTMLInputElement).value\n this._inputValue = value\n this._inputValue$.next(value)\n }}\n @focus=${(e: FocusEvent) => {\n e.stopPropagation()\n this._open = true\n }}\n @click=${(e: MouseEvent) => {\n e.stopPropagation()\n this._open = true\n }}\n @keydown=${(e: KeyboardEvent) => {\n this._handleKeyDown(e)\n }}\n @blur=${() => {\n this._handleAutoSelectOnBlur()\n }}\n >\n </schmancy-input>\n `\n )}\n </slot>\n\n <!-- Options dropdown -->\n <ul\n id=\"options\"\n class=${classMap({\n 'absolute': true,\n 'z-[1000]': true,\n 'mt-1': true,\n 'w-full': true,\n 'rounded-md': true,\n 'shadow-md': true,\n 'overflow-auto': true,\n 'min-w-full': true,\n 'bg-surface-low': true,\n 'flex': true,\n 'flex-col': true, // Enable flexbox for ordering\n })}\n role=\"listbox\"\n aria-multiselectable=${this.multi ? 'true' : 'false'}\n aria-label=${`${this.label || 'Options'} dropdown`}\n ?hidden=${!this._open}\n style=\"max-height: ${this.maxHeight}; display: ${this._open ? 'flex' : 'none'};\"\n @slotchange=${() => {\n this._setupOptionHandlers()\n }}\n >\n <slot></slot>\n ${!this._hasResults ? html`\n <li class=\"px-3 py-2 text-sm text-muted\">No results found</li>\n ` : ''}\n </ul>\n </div>\n `\n }\n\n private _handleAutoSelectOnBlur() {\n // Don't run if we're clicking on an option (prevents interference with click handler)\n if (this._isSelectingOption) {\n return\n }\n\n // Only auto-select in single-select mode and when dropdown is open with a search term\n if (this.multi || !this._open || !this._inputValue.trim()) {\n return\n }\n \n const searchTerm = this._inputValue.trim()\n \n // Find the best matching option using the same similarity logic as filtering\n let bestMatch: SchmancyOption | null = null\n let bestScore = 0\n \n this._options.forEach(option => {\n // Skip hidden options\n if (option.hidden) return\n \n // Get text to search in (prioritize label, then textContent, then value)\n const optionLabel = option.label || option.textContent || ''\n const optionValue = option.value\n \n // Calculate similarity scores for both label and value\n const labelScore = similarity(searchTerm, optionLabel)\n const valueScore = similarity(searchTerm, optionValue)\n \n // Use the higher score (prioritizing label matches)\n const score = Math.max(labelScore * 1.1, valueScore) // Slight boost for label matches\n \n // Keep track of best match that meets threshold\n if (score > bestScore && score >= this.similarityThreshold) {\n bestScore = score\n bestMatch = option\n }\n })\n \n // Auto-select the best match if found\n if (bestMatch) {\n // Select the option directly\n this._selectOption(bestMatch)\n\n // Close the dropdown\n this._open = false\n }\n }\n\n private _handleKeyDown(event: KeyboardEvent) {\n const isOpen = this._open\n const selectedValues = this._selectedValues$.value\n\n // Handle backspace to remove last chip in multi-select when input is empty\n if (this.multi && event.key === 'Backspace' && !this._inputValue && selectedValues.length > 0 && !isOpen) {\n event.preventDefault()\n const lastValue = selectedValues[selectedValues.length - 1]\n this.handleChipRemove(lastValue)\n return\n }\n\n if (!isOpen && (event.key === 'ArrowDown' || event.key === 'Enter')) {\n event.preventDefault()\n this._open = true\n\n setTimeout(() => {\n const firstVisible = this._options.find(opt => !opt.hidden)\n firstVisible?.focus()\n }, 10)\n return\n }\n\n if (!isOpen) return\n\n const visibleOptions = this._options.filter(opt => !opt.hidden)\n .sort((a, b) => parseInt(a.style.order || '0') - parseInt(b.style.order || '0'))\n\n const focusedOption = visibleOptions.find(opt => opt === document.activeElement)\n const currentIndex = focusedOption ? visibleOptions.indexOf(focusedOption) : -1\n\n switch (event.key) {\n case 'Escape':\n event.preventDefault()\n this._open = false\n this._updateInputDisplay()\n this._inputElementRef.value?.focus()\n break\n\n case 'Tab':\n this._open = false\n this._updateInputDisplay()\n break\n\n case 'ArrowDown':\n event.preventDefault()\n const nextIndex = currentIndex < visibleOptions.length - 1 ? currentIndex + 1 : 0\n visibleOptions[nextIndex]?.focus()\n break\n\n case 'ArrowUp':\n event.preventDefault()\n const prevIndex = currentIndex > 0 ? currentIndex - 1 : visibleOptions.length - 1\n visibleOptions[prevIndex]?.focus()\n break\n\n case 'Home':\n event.preventDefault()\n visibleOptions[0]?.focus()\n break\n\n case 'End':\n event.preventDefault()\n visibleOptions[visibleOptions.length - 1]?.focus()\n break\n\n case 'Enter':\n case ' ':\n if (focusedOption) {\n event.preventDefault()\n this._selectOption(focusedOption)\n }\n break\n }\n }\n}\n\n\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'schmancy-autocomplete': SchmancyAutocomplete\n }\n}"],"names":["SchmancyAutocomplete","$LitElement","constructor","super","arguments","this","_valueSet","_valuesSet","required","placeholder","label","name","maxHeight","multi","description","size","autocomplete","debounceMs","similarityThreshold","error","validationMessage","_open","_inputValue","_visibleOptionsCount","_hasResults","_isSelectingOption","_inputElementRef","createRef","_selectedValue$","BehaviorSubject","_selectedValues$","_inputValue$","values","value","vals","next","Array","isArray","join","val","newValues","split","map","v","trim","filter","Boolean","currentValues","JSON","stringify","_updateInputDisplay","connectedCallback","id","Math","random","toString","slice","_setupAutocompleteLogic","_setupDocumentClickHandler","combineLatest","pipe","tap","selectedValue","selectedValues","_updateOptionSelection","takeUntil","disconnecting","subscribe","distinctUntilChanged","debounceTime","searchTerm","_filterOptions","_setupOptionHandlers","_options","forEach","option","index","setAttribute","tabIndex","onmousedown","e","preventDefault","onclick","stopPropagation","_selectOption","setTimeout","selected","includes","String","term","scoredOptions","optionLabel","textContent","optionValue","labelScore","similarity","valueScore","score","max","sort","a","b","visibleCount","item","hidden","style","order","length","_announceToScreenReader","indexOf","_getSelectedLabels","_fireChangeEvent","blur","handleDocumentClick","path","composedPath","some","opt","document","addEventListener","take","removeEventListener","find","message","liveRegion","shadowRoot","querySelector","detail","dispatchEvent","CustomEvent","bubbles","composed","checkValidity","reportValidity","firstUpdated","_getChipLabel","_focusTextInput","focus","render","descriptionId","height","padding","fontSize","labelSize","getSizeStyles","html","when","classMap","repeat","handleChipRemove","ref","toLowerCase","replace","target","_handleKeyDown","_handleAutoSelectOnBlur","absolute","flex","bestMatch","bestScore","event","isOpen","key","lastValue","visibleOptions","parseInt","focusedOption","activeElement","currentIndex","nextIndex","prevIndex","__decorateClass","property","type","prototype","reflect","Number","state","query","queryAssignedElements","flatten","customElement"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"avatar-5cjrkZS5.cjs","sources":["../src/badge/badge.ts","../src/content-drawer/drawer.service.ts","../src/content-drawer/context.ts","../src/content-drawer/drawer.ts","../src/content-drawer/main.ts","../src/content-drawer/sheet.ts","../src/nav-drawer/$navbar.ts","../src/nav-drawer/context.ts","../src/nav-drawer/appbar.ts","../src/nav-drawer/content.ts","../src/nav-drawer/drawer.ts","../src/nav-drawer/navbar.ts","../src/navigation-bar/navigation-bar-item.ts","../src/navigation-bar/navigation-bar.ts","../src/teleport/teleport.service.ts","../src/teleport/watcher.ts","../src/teleport/teleport.component.ts","../src/avatar.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { color } from '@schmancy/directives'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { SchmancyTheme } from '..'\n\n/**\n * Badge color types for predefined styles\n */\nexport type BadgeColor = 'primary' | 'secondary' | 'tertiary' | 'success' | 'warning' | 'error' | 'neutral'\n\n/**\n * Badge size variants\n */\nexport type BadgeSize = 'xs' | 'sm' | 'md' | 'lg'\n\n/**\n * Badge shape variants\n */\nexport type BadgeShape = 'rounded' | 'pill' | 'square'\n\n/**\n * @element sch-badge\n * A versatile badge component for status indicators, labels, and counts\n *\n * @slot - The content of the badge (text or HTML)\n * @slot icon - Optional icon to display before the content\n *\n * @csspart badge - The badge element container\n * @csspart content - The content container\n * @csspart icon - The icon container\n */\n@customElement('schmancy-badge')\nexport class SchmancyBadgeV2 extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-flex;\n\t}\n\n\t/* Enhanced pulse animation for better attention-getting */\n\t@keyframes elegant-pulse {\n\t\t0%, 100% {\n\t\t\topacity: 1;\n\t\t}\n\t\t50% {\n\t\t\topacity: 0.85;\n\t\t}\n\t}\n\n\t.animate-pulse {\n\t\tanimation: elegant-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\n\t}\n`) {\n\t/**\n\t * The color variant of the badge\n\t * @attr\n\t */\n\t@property({ type: String, reflect: true })\n\tcolor: BadgeColor = 'primary'\n\n\t/**\n\t * The size of the badge\n\t * @attr\n\t */\n\t@property({ type: String, reflect: true })\n\tsize: BadgeSize = 'md'\n\n\t/**\n\t * The shape of the badge\n\t * @attr\n\t */\n\t@property({ type: String, reflect: true })\n\tshape: BadgeShape = 'pill'\n\n\t/**\n\t * Whether the badge has an outlined style\n\t * @attr\n\t */\n\t@property({ type: Boolean, reflect: true })\n\toutlined = false\n\n\t/**\n\t * Custom icon name to display (if no icon slot is provided)\n\t * @attr\n\t */\n\t@property({ type: String })\n\ticon = ''\n\n\t/**\n\t * Whether to make the badge pulse to draw attention\n\t * @attr\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tpulse = false\n\n\t/**\n\t * Convert the size to appropriate Tailwind classes for the badge container\n\t * Using harmonious padding ratios based on golden ratio principles\n\t * Refined for more elegant proportions\n\t */\n\tprivate getSizeClasses(): string {\n\t\tswitch (this.size) {\n\t\t\tcase 'xs':\n\t\t\t\treturn 'text-xs py-0.75 px-1.5 gap-0.5 leading-none'\n\t\t\tcase 'sm':\n\t\t\t\treturn 'text-xs py-1.5 px-2.5 gap-0.5 tracking-wide leading-none'\n\t\t\tcase 'lg':\n\t\t\t\treturn 'text-base py-2 px-4 gap-1 tracking-wide'\n\t\t\tcase 'md':\n\t\t\tdefault:\n\t\t\t\treturn 'text-sm py-1.5 px-3 gap-0.5'\n\t\t}\n\t}\n\n\t/**\n\t * Get shape classes based on selected shape\n\t */\n\tprivate getShapeClasses(): string {\n\t\tswitch (this.shape) {\n\t\t\tcase 'square':\n\t\t\t\treturn 'rounded'\n\t\t\tcase 'rounded':\n\t\t\t\treturn 'rounded-md'\n\t\t\tcase 'pill':\n\t\t\tdefault:\n\t\t\t\treturn 'rounded-full'\n\t\t}\n\t}\n\n\t/**\n\t * Get icon size based on badge size with harmonious proportions\n\t * Using golden ratio-inspired proportions relative to text size\n\t */\n\tprivate getIconSize(): string {\n\t\tswitch (this.size) {\n\t\t\tcase 'xs':\n\t\t\t\treturn '11px' // Approximately 0.9 × text size (12px × 0.9)\n\t\t\tcase 'sm':\n\t\t\t\treturn '13px' // Approximately 1.1 × text size (12px × 1.1)\n\t\t\tcase 'lg':\n\t\t\t\treturn '18px' // Approximately 1.1 × text size (16px × 1.1)\n\t\t\tcase 'md':\n\t\t\tdefault:\n\t\t\t\treturn '15px' // Approximately 1.1 × text size (14px × 1.1)\n\t\t}\n\t}\n\n\t/**\n\t * Get additional styling for specific sizes\n\t */\n\tprivate getExoticStyles(): Record<string, string> {\n\t\tconst styles: Record<string, string> = {}\n\n\t\tif (this.size === 'lg') {\n\t\t\tstyles.letterSpacing = '0.03em'\n\t\t\tstyles.fontWeight = '500'\n\t\t}\n\n\t\tif (this.size === 'sm') {\n\t\t\tstyles.letterSpacing = '0.02em'\n\t\t}\n\n\t\treturn styles\n\t}\n\n\t/**\n\t * Get background and text colors based on selected color variant\n\t * Enhanced for more elegant color combinations with refined contrasts\n\t */\n\tprivate getColorStyles() {\n\t\tconst colors: Record<BadgeColor, { bg: string; text: string; border?: string }> = {\n\t\t\tprimary: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.primary.container} 92%, ${SchmancyTheme.sys.color.primary.default} 8%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.primary.default : SchmancyTheme.sys.color.primary.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.primary.default} 90%, ${SchmancyTheme.sys.color.surface.highest} 10%)` : undefined,\n\t\t\t},\n\t\t\tsecondary: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.secondary.container} 95%, ${SchmancyTheme.sys.color.secondary.default} 5%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.secondary.default : SchmancyTheme.sys.color.secondary.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.secondary.default} 85%, ${SchmancyTheme.sys.color.surface.highest} 15%)` : undefined,\n\t\t\t},\n\t\t\ttertiary: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.tertiary.container} 94%, ${SchmancyTheme.sys.color.tertiary.default} 6%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.tertiary.default : SchmancyTheme.sys.color.tertiary.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.tertiary.default} 88%, ${SchmancyTheme.sys.color.surface.highest} 12%)` : undefined,\n\t\t\t},\n\t\t\tsuccess: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.success.container} 90%, ${SchmancyTheme.sys.color.success.default} 10%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.success.default : SchmancyTheme.sys.color.success.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.success.default} 85%, ${SchmancyTheme.sys.color.surface.bright} 15%)` : undefined,\n\t\t\t},\n\t\t\twarning: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.tertiary.container} 85%, ${SchmancyTheme.sys.color.tertiary.default} 15%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.tertiary.default : SchmancyTheme.sys.color.tertiary.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.tertiary.default} 90%, ${SchmancyTheme.sys.color.surface.highest} 10%)` : undefined,\n\t\t\t},\n\t\t\terror: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.error.container} 92%, ${SchmancyTheme.sys.color.error.default} 8%)`,\n\t\t\t\ttext: this.outlined ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.error.onContainer,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.error.default} 88%, ${SchmancyTheme.sys.color.surface.bright} 12%)` : undefined,\n\t\t\t},\n\t\t\tneutral: {\n\t\t\t\tbg: this.outlined ? 'transparent' : `color-mix(in srgb, ${SchmancyTheme.sys.color.surface.high} 95%, ${SchmancyTheme.sys.color.outline} 5%)`,\n\t\t\t\ttext: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.surface.on} 95%, ${SchmancyTheme.sys.color.surface.default} 5%)` : SchmancyTheme.sys.color.surface.on,\n\t\t\t\tborder: this.outlined ? `color-mix(in srgb, ${SchmancyTheme.sys.color.outline} 85%, ${SchmancyTheme.sys.color.surface.highest} 15%)` : undefined,\n\t\t\t},\n\t\t}\n\n\t\treturn colors[this.color]\n\t}\n\n\trender() {\n\t\tconst sizeClasses = this.getSizeClasses()\n\t\tconst shapeClasses = this.getShapeClasses()\n\t\tconst colorStyles = this.getColorStyles()\n\t\tconst iconSize = this.getIconSize()\n\t\tconst exoticStyles = this.getExoticStyles()\n\n\t\tconst badgeClasses = {\n\t\t\t'inline-flex items-center justify-center font-medium': true,\n\t\t\t'transition-all duration-200 ease-in-out': true,\n\t\t\t[sizeClasses]: true,\n\t\t\t[shapeClasses]: true,\n\t\t\t'animate-pulse': this.pulse,\n\t\t\t'border border-solid': this.outlined,\n\t\t\t'shadow-sm': !this.outlined && this.size === 'sm',\n\t\t\t'shadow': !this.outlined && this.size === 'md',\n\t\t\t'shadow-md': !this.outlined && this.size === 'lg',\n\t\t\t'hover:brightness-95 hover:-translate-y-px': this.outlined,\n\t\t\t'hover:brightness-[0.98]': !this.outlined,\n\t\t}\n\n\t\t// Refined styles for a more elegant look (only CSS that can't be done with Tailwind)\n\t\tconst styles = {\n\t\t\tborderColor: colorStyles.border,\n\t\t\t...(this.outlined ? {\n\t\t\t\tbackdropFilter: 'blur(4px)',\n\t\t\t} : {}),\n\t\t\t...(this.size === 'lg' && !this.outlined ? {\n\t\t\t\tboxShadow: '0 1px 2px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.1)'\n\t\t\t} : {}),\n\t\t\t...exoticStyles,\n\t\t}\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tpart=\"badge\"\n\t\t\t\tclass=\"${this.classMap(badgeClasses)}\"\n\t\t\t\tstyle=\"${this.styleMap(styles)}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: colorStyles.bg,\n\t\t\t\t\tcolor: colorStyles.text,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<!-- Icon slot or named icon -->\n\t\t\t\t<slot name=\"icon\">\n\t\t\t\t\t${this.icon\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<div part=\"icon\" class=\"flex-shrink-0 flex items-center justify-center leading-none\">\n\t\t\t\t\t\t\t\t\t<schmancy-icon .size=${iconSize} class=\"flex items-center justify-center\">${this.icon}</schmancy-icon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t`\n\t\t\t\t\t\t: ''}\n\t\t\t\t</slot>\n\n\t\t\t\t<!-- Content with proper spacing from icon -->\n\t\t\t\t<div part=\"content\" class=\"flex items-center leading-none tracking-[0.01em] ${this.icon ? 'ml-[0.38em]' : ''}\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'sch-badge': SchmancyBadgeV2,\n\t\t'schmancy-badge': SchmancyBadgeV2\n\t}\n}\n\n\n// Register the component with the legacy tag name for backward compatibility\n@customElement('sch-badge')\nexport class ScBadgeV2 extends SchmancyBadgeV2 {}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\ntype DrawerAction = 'dismiss' | 'render' | 'push'\ntype TRef = Element | Window\ntype TRenderRequest = HTMLElement\nexport type TRenderCustomEvent = CustomEvent<{\n\tcomponent: TRenderRequest\n\ttitle?: string\n}>\n\ntype ComponentType = string | HTMLElement | (() => HTMLElement) | (() => Promise<{ default: any }>)\n\nclass DrawerService {\n\tprivate $drawer = new Subject<{\n\t\tref: TRef\n\t\taction: DrawerAction\n\t\tcomponent?: TRenderRequest | ComponentType\n\t\ttitle?: string\n\t}>()\n\tprivate lastComponent: HTMLElement | null = null\n\n\tconstructor() {\n\t\tthis.$drawer.pipe().subscribe(data => {\n\t\t\tif (data.action === 'dismiss') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'render') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tcomponent: data.component,\n\t\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'push') {\n\t\t\t\tthis.handlePush(data.ref, data.component as ComponentType)\n\t\t\t}\n\t\t})\n\t}\n\n\tdimiss(ref: TRef) {\n\t\tthis.$drawer.next({\n\t\t\taction: 'dismiss',\n\t\t\tref: ref,\n\t\t})\n\t}\n\n\trender(ref: TRef, component: TRenderRequest, title?: string) {\n\t\tref.dispatchEvent(new CustomEvent('custom-event'))\n\t\tthis.$drawer.next({\n\t\t\taction: 'render',\n\t\t\tref: ref,\n\t\t\tcomponent: component,\n\t\t\ttitle,\n\t\t})\n\t}\n\n\tprivate async handlePush(ref: TRef, component: ComponentType) {\n\t\tlet resolvedComponent: HTMLElement\n\n\t\t// Resolve component to HTMLElement\n\t\tif (typeof component === 'string') {\n\t\t\t// String tag name - create element\n\t\t\tresolvedComponent = document.createElement(component) as HTMLElement\n\t\t} else if (component instanceof HTMLElement) {\n\t\t\t// Already an HTMLElement\n\t\t\tresolvedComponent = component\n\t\t} else if (typeof component === 'function') {\n\t\t\t// Factory function or async module\n\t\t\ttry {\n\t\t\t\tconst result = await component()\n\t\t\t\tif (result && typeof result === 'object' && 'default' in result) {\n\t\t\t\t\t// ES module with default export\n\t\t\t\t\tconst Constructor = result.default\n\t\t\t\t\tresolvedComponent = new Constructor() as HTMLElement\n\t\t\t\t} else if (result instanceof HTMLElement) {\n\t\t\t\t\t// Factory returned HTMLElement\n\t\t\t\t\tresolvedComponent = result\n\t\t\t\t} else {\n\t\t\t\t\t// Assume it's a constructor\n\t\t\t\t\tresolvedComponent = new (result as any)() as HTMLElement\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tconsole.error('Failed to resolve component:', error)\n\t\t\t\treturn\n\t\t\t}\n\t\t} else {\n\t\t\tconsole.error('Invalid component type:', component)\n\t\t\treturn\n\t\t}\n\n\t\t// Check if it's the same component instance and force update\n\t\tif (this.lastComponent === resolvedComponent && 'requestUpdate' in resolvedComponent) {\n\t\t\t(resolvedComponent as any).requestUpdate()\n\t\t}\n\t\tthis.lastComponent = resolvedComponent\n\n\t\t// Dispatch events to open drawer and render component\n\t\tref.dispatchEvent(\n\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\tdetail: { state: 'open' },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t\tref.dispatchEvent(\n\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\tdetail: { component: resolvedComponent },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tpush(component: ComponentType) {\n\t\t// Use window as default ref for simplicity\n\t\tthis.$drawer.next({\n\t\t\taction: 'push',\n\t\t\tref: window,\n\t\t\tcomponent: component,\n\t\t})\n\t}\n}\n\nexport const schmancyContentDrawer = new DrawerService()","import { createContext } from '@lit/context'\nexport type TSchmancyContentDrawerSheetMode = 'push' | 'overlay'\nexport const SchmancyContentDrawerSheetMode = createContext<TSchmancyContentDrawerSheetMode>('push')\n\nexport type TSchmancyContentDrawerSheetState = 'open' | 'close'\nexport const SchmancyContentDrawerSheetState = createContext<TSchmancyContentDrawerSheetState>('close')\n\nexport const SchmancyContentDrawerID = createContext<string>(Math.floor(Math.random() * Date.now()).toString())\nexport const SchmancyContentDrawerMaxHeight = createContext<string>('100%')\nexport const SchmancyContentDrawerMinWidth = createContext<{\n\tmain: number\n\tsheet: number\n}>({})\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, queryAssignedElements, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, merge, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, TRenderCustomEvent, area, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n/**\n * @element schmancy-content-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-content-drawer')\nexport class SchmancyContentDrawer extends $LitElement(css`\n\t:host {\n\t\tposition: relative;\n\t\tinset: 0;\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t/**\n\t * The minimum width of the sheet\n\t * @attr\tminWidth\n\t * @type {number}\n\t * @memberof SchmancyContentDrawer\n\t */\n\n\t@provide({ context: SchmancyContentDrawerMinWidth })\n\tminWidth: typeof SchmancyContentDrawerMinWidth.__context__ = {\n\t\tmain: 360,\n\t\tsheet: 576,\n\t}\n\n\t/**\n\t * The state of the sheet\n\t * @attr open\n\t * @type {TSchmancyContentDrawerSheetState}\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetState })\n\t@property()\n\topen: TSchmancyContentDrawerSheetState\n\n\t/**\n\t * The mode of the sheet\n\t * @type {TSchmancyContentDrawerSheetMode}\n\t * @memberof SchmancyContentDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetMode })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@provide({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID = Math.floor(Math.random() * Date.now()).toString()\n\n\t@provide({ context: SchmancyContentDrawerMaxHeight })\n\tmaxHeight = '100%'\n\n\t@queryAssignedElements({ flatten: true })\n\tassignedElements!: HTMLElement[]\n\tfirstUpdated(): void {\n\t\tmerge(fromEvent<CustomEvent>(window, 'resize'), fromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerResize))\n\t\t\t.pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => (this.clientWidth ? this.clientWidth : window.innerWidth)),\n\t\t\t\tmap(width => width >= this.minWidth.main + this.minWidth.sheet),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.maxHeight = `${window.innerHeight - this.getOffsetTop(this) - 32}px`\n\t\t\t\t\tthis.style.setProperty('max-height', this.maxHeight)\n\t\t\t\t}),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerToggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\n\t\tfromEvent<TRenderCustomEvent>(window, 'schmancy-content-drawer-render')\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(({ component, title }) => {\n\t\t\t\tif (this.mode === 'push') {\n\t\t\t\t\t// TODO: Fix the router to render if constructor has different arguments\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: 'empty',\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: component,\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t} else if ((this.mode = 'overlay')) {\n\t\t\t\t\tsheet.open({ component: component, uid: this.schmancyContentDrawerID, title })\n\t\t\t\t}\n\t\t\t})\n\t}\n\n\tgetOffsetTop(element: HTMLElement | null) {\n\t\tlet offsetTop = 0\n\t\twhile (element) {\n\t\t\toffsetTop += element.offsetTop\n\t\t\telement = element.offsetParent as HTMLElement | null\n\t\t}\n\t\treturn offsetTop\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.mode === 'overlay' ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer': SchmancyContentDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { PropertyValueMap, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyEvents } from '..'\nimport {\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetMode,\n} from './context'\nimport { when } from 'lit/directives/when.js'\n\n@customElement('schmancy-content-drawer-main')\nexport class SchmancyContentDrawerMain extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) this.drawerMinWidth.main = this.minWidth\n\t\telse this.minWidth = this.drawerMinWidth.main\n\t}\n\n\tprotected update(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n\t\tsuper.update(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\tthis.drawerMinWidth.main = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t}\n\t}\n\n\trender() {\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\t\treturn html`\n\t\t\t<section class=\"relative inset-0 h-full\">\n\t\t\t\t<schmancy-grid\n\t\t\t\t\tclass=\"h-full relative overflow-scroll\"\n\t\t\t\t\tcols=\"${this.mode === 'push' ? 'auto 1fr' : '1fr'}\"\n\t\t\t\t\trows=\"1fr\"\n\t\t\t\t\tflow=\"col\"\n\t\t\t\t\talign=\"stretch\"\n\t\t\t\t\tjustify=\"stretch\"\n\t\t\t\t>\n\t\t\t\t\t<section style=${this.styleMap(styles)}>\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</section>\n\t\t\t\t</schmancy-grid>\n\t\t\t\t${when(\n\t\t\t\t\tthis.mode === 'push',\n\t\t\t\t\t() => html` <schmancy-divider class=\"absolute right-0 top-0\" orientation=\"vertical\"></schmancy-divider>`,\n\t\t\t\t)}\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-main': SchmancyContentDrawerMain\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { from, merge, Observable, of, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n// --- 1) Removed the custom animate import\n// import { animate } from '@packages/anime-beta-master'\n\n@customElement('schmancy-content-drawer-sheet')\nexport class SchmancyContentDrawerSheet extends $LitElement(css`\n\t:host {\n\t\toverflow: scroll;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerSheetState, subscribe: true })\n\t@state()\n\tstate: TSchmancyContentDrawerSheetState\n\n\t@consume({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID\n\n\t@query('#sheet') sheet!: HTMLElement\n\t@queryAssignedElements({ flatten: true, slot: undefined }) defaultSlot!: HTMLElement[]\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) {\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t} else {\n\t\t\tthis.minWidth = this.drawerMinWidth.sheet\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\t// If the 'minWidth' property changed\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t} else if (changedProperties.has('state') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\t// Overlay open logic if needed\n\t\t\t\t\t// this.open()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tsheet.dismiss(this.schmancyContentDrawerID)\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.open()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Open the sheet by sliding it into view.\n\t */\n\topen() {\n\t\t// \"onBegin\" logic from the old `animate(...)`\n\t\tif (this.mode === 'overlay') {\n\t\t\tthis.sheet.style.position = 'fixed'\n\t\t} else {\n\t\t\tthis.sheet.style.position = 'relative'\n\t\t}\n\t\tthis.sheet.style.display = 'block'\n\n\t\t// --- 2) Use native Web Animations API ---\n\t\tthis.sheet.animate(\n\t\t\t[\n\t\t\t\t{ opacity: 0, transform: 'translateX(100%)' },\n\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: 500,\n\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t},\n\t\t)\n\t\t// No return is needed if you don't rely on the result\n\t}\n\n\t/**\n\t * Close everything (modal sheet + the sheet itself).\n\t */\n\tcloseAll() {\n\t\t// Merge them into a single subscription,\n\t\t// so that everything closes in parallel.\n\t\tmerge(from(this.closeModalSheet()), from(this.closeSheet())).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Dismiss the \"modal sheet.\"\n\t * This just returns an Observable that completes immediately.\n\t */\n\tcloseModalSheet() {\n\t\treturn of(true).pipe(tap(() => sheet.dismiss(this.schmancyContentDrawerID)))\n\t}\n\n\t/**\n\t * Slide the sheet out of view + hide it.\n\t * Return an Observable so we can merge it with other close operations.\n\t */\n\tcloseSheet() {\n\t\t// --- 2) Use native Web Animations API and wrap in an Observable ---\n\t\treturn new Observable<void>(observer => {\n\t\t\tconst animation = this.sheet.animate(\n\t\t\t\t[\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(100%)' },\n\t\t\t\t],\n\t\t\t\t{\n\t\t\t\t\tduration: 500,\n\t\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tanimation.onfinish = () => {\n\t\t\t\t// \"onComplete\" logic\n\t\t\t\tthis.sheet.style.display = 'none'\n\t\t\t\tobserver.next()\n\t\t\t\tobserver.complete()\n\t\t\t}\n\t\t})\n\t}\n\n\tprotected render() {\n\t\tconst sheetClasses = {\n\t\t\tblock: this.mode === 'push',\n\t\t\t'absolute z-50': this.mode === 'overlay',\n\t\t\t'opacity-1': this.mode === 'overlay' && this.state === 'open',\n\t\t}\n\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\n\t\treturn html`\n\t\t\t<section id=\"sheet\" class=\"${this.classMap(sheetClasses)}\" style=${this.styleMap(styles)}>\n\t\t\t\t<schmancy-area name=\"${this.schmancyContentDrawerID}\">\n\t\t\t\t\t<slot name=\"placeholder\"></slot>\n\t\t\t\t</schmancy-area>\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-sheet': SchmancyContentDrawerSheet\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { debounceTime, Subject } from 'rxjs'\n\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tself: HTMLElement\n\t\tstate: boolean\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe(debounceTime(10)).subscribe(data => {\n\t\t\tif (data.state) {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\topen(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: true,\n\t\t})\n\t}\n\tclose(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: false,\n\t\t})\n\t}\n}\n\nexport const schmancyNavDrawer = new Drawer()\nconst $drawer = schmancyNavDrawer\n\nexport { $drawer }\n","import { createContext } from '@lit/context'\nexport type TSchmancyDrawerNavbarMode = 'push' | 'overlay' | undefined\nexport const SchmancyDrawerNavbarMode = createContext<TSchmancyDrawerNavbarMode>('push')\n\nexport type TSchmancyDrawerNavbarState = 'open' | 'close' | undefined\nexport const SchmancyDrawerNavbarState = createContext<TSchmancyDrawerNavbarState>('close')\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n} from '@schmancy/nav-drawer/context'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyEvents } from '..'\n\n/**\n * @element schmancy-nav-drawer-appbar\n * @slot toggler - The toggler slot\n * @slot - The default slot\n */\n@customElement('schmancy-nav-drawer-appbar')\nexport class SchmancyDrawerAppbar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tsidebarMode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tsidebarOpen\n\n\t@property({ type: Boolean }) toggler = true\n\n\trender() {\n\t\tconst appbarClasses = {\n\t\t\t'block z-50': true,\n\t\t}\n\t\tconst sidebarToggler = {\n\t\t\t'block left-3 z-50': this.sidebarMode === 'overlay',\n\t\t\thidden: this.sidebarMode === 'push',\n\t\t}\n\t\tconst gridClasses = {\n\t\t\t...appbarClasses,\n\t\t\t'grid gap-2 items-center': true,\n\t\t\t'grid-cols-[auto_1fr]': this.sidebarMode === 'overlay' && this.toggler,\n\t\t\t'grid-cols-1': !(this.sidebarMode === 'overlay' && this.toggler),\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=${this.classMap(gridClasses)}>\n\t\t\t\t${when(\n\t\t\t\t\tthis.sidebarMode === 'overlay' && this.toggler,\n\t\t\t\t\t() =>\n\t\t\t\t\t\thtml`<slot name=\"toggler\">\n\t\t\t\t\t\t\t<div class=\"${this.classMap(sidebarToggler)}\">\n\t\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\t\t\t\t\t\tdetail: { state: this.sidebarOpen === 'open' ? 'close' : 'open' },\n\t\t\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t${when(\n\t\t\t\t\t\t\t\t\t\tthis.sidebarOpen === 'close',\n\t\t\t\t\t\t\t\t\t\t() => html`menu`,\n\t\t\t\t\t\t\t\t\t\t() => html`menu_open`,\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</slot>`,\n\t\t\t\t)}\n\n\t\t\t\t<slot> </slot>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-appbar': SchmancyDrawerAppbar\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n@customElement('schmancy-nav-drawer-content')\nexport class SchmancyNavigationDrawerContent extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tinset: 0;\n\t\toverflow-y: auto;\n\t}\n`) {\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent(this, 'scroll')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(e => {\n\t\t\t\tthis.parentElement.dispatchEvent(new CustomEvent('scroll', { detail: e, bubbles: true, composed: true }))\n\t\t\t})\n\t}\n\trender() {\n\t\treturn html` <slot></slot> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-content': SchmancyNavigationDrawerContent\n\t}\n}\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents } from '..'\nimport { fullHeight } from './../directives/height'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n/**\n * @element schmancy-nav-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-nav-drawer')\nexport class SchmancyNavigationDrawer extends $LitElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex-grow: 1;\n\t\toverflow: hidden;\n\t\t/* Initially hide the component until it’s ready */\n\t\tvisibility: hidden;\n\t}\n\t/* Once the component is ready, remove the hidden style */\n\t:host([data-ready]) {\n\t\tvisibility: visible;\n\t}\n`) {\n\t// fullscreen property\n\t@property({ type: Boolean })\n\tfullscreen: boolean = false\n\n\t/**\n\t * The breakpoint for the sidebar based on Tailwind CSS breakpoints.\n\t * Accepts: \"sm\", \"md\", \"lg\", or \"xl\".\n\t *\n\t * The following default values are used:\n\t * - sm: 640px\n\t * - md: 768px (default)\n\t * - lg: 1024px\n\t * - xl: 1280px\n\t *\n\t * @attr breakpoint\n\t * @type {\"sm\" | \"md\" | \"lg\" | \"xl\"}\n\t */\n\t@property({ type: String, attribute: 'breakpoint' })\n\tbreakpoint: 'sm' | 'md' | 'lg' | 'xl' = 'md'\n\n\t/**\n\t * Mapping of Tailwind breakpoint tokens to their numeric pixel values.\n\t */\n\tprivate static BREAKPOINTS: Record<'sm' | 'md' | 'lg' | 'xl', number> = {\n\t\tsm: 640,\n\t\tmd: 768,\n\t\tlg: 1024,\n\t\txl: 1280,\n\t}\n\n\t/**\n\t * The mode of the sidebar.\n\t */\n\t@provide({ context: SchmancyDrawerNavbarMode })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t/**\n\t * The open/close state of the sidebar.\n\t */\n\t@provide({ context: SchmancyDrawerNavbarState })\n\t@property()\n\topen: TSchmancyDrawerNavbarState\n\n\t/**\n\t * A flag indicating that the initial state has been set.\n\t */\n\t@state()\n\tprivate _initialized = false\n\n\t/**\n\t * In firstUpdated, we can safely read attribute-set properties.\n\t * We also initialize our state and subscribe to events.\n\t */\n\tfirstUpdated() {\n\t\t// Set the initial state based on the current window width.\n\t\tthis.updateState(window.innerWidth)\n\t\t// Mark the component as ready\n\t\tthis._initialized = true\n\t\tthis.setAttribute('data-ready', '')\n\n\t\t// Subscribe to window resize events.\n\t\tfromEvent(window, 'resize')\n\t\t\t.pipe(\n\t\t\t\t// Extract the inner width.\n\t\t\t\tmap(event => (event.target as Window).innerWidth),\n\t\t\t\t// Determine if we're above the breakpoint.\n\t\t\t\tmap(width => width >= SchmancyNavigationDrawer.BREAKPOINTS[this.breakpoint]),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(isLargeScreen => {\n\t\t\t\tif (isLargeScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t// Listen to fullscreen events\n\t\tfromEvent(window, 'fullscreen').pipe(\n\t\t\ttap((event: Event) => {\n\t\t\t\tconst customEvent = event as CustomEvent\n\t\t\t\tthis.fullscreen = customEvent.detail\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\n\t\t// Listen to the custom toggle event.\n\t\tfromEvent(window, SchmancyEvents.NavDrawer_toggle)\n\t\t\t.pipe(\n\t\t\t\ttap((event: CustomEvent) => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap((event: CustomEvent) => event.detail.state),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(10),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\t// When in push mode, ignore a request to close the sidebar.\n\t\t\t\tif (this.mode === 'push' && state === 'close') return\n\t\t\t\tthis.open = state\n\t\t\t})\n\t}\n\n\t/**\n\t * Helper method to update state based on a given width.\n\t */\n\tprivate updateState(width: number) {\n\t\tconst isLargeScreen = width >= SchmancyNavigationDrawer.BREAKPOINTS[this.breakpoint]\n\t\tthis.mode = isLargeScreen ? 'push' : 'overlay'\n\t\tthis.open = isLargeScreen ? 'open' : 'close'\n\t}\n\n\tprotected render() {\n\t\t// Optionally, you can check _initialized here,\n\t\t// but the CSS will already hide the component until it's ready.\n\t\tif (!this._initialized) return nothing\n\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.fullscreen ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t\t${fullHeight()}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer': SchmancyNavigationDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { SchmancyEvents, SchmancyTheme, color } from '..'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n// Animation configuration constants.\nconst ANIMATION_EASING = 'cubic-bezier(0.5, 0.01, 0.25, 1)'\nconst OVERLAY_ANIM_DURATION_OPEN = 200\nconst OVERLAY_ANIM_DURATION_CLOSE = 150\nconst NAV_ANIM_DURATION = 200\n\n@customElement('schmancy-nav-drawer-navbar')\nexport class SchmancyNavigationDrawerSidebar extends $LitElement() {\n\t// Consume context values. Renamed from \"state\" to \"drawerState\" to avoid confusion.\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tmode!: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tdrawerState!: TSchmancyDrawerNavbarState\n\n\t@query('#overlay') overlay!: HTMLElement\n\t@query('nav') nav!: HTMLElement\n\n\t@property({ type: String }) width = '220px'\n\t@state() private _initialized = false\n\n\t/**\n\t * firstUpdated()\n\t * Set initial styles based on the current mode and consumed state.\n\t */\n\tfirstUpdated() {\n\t\tif (this.mode === 'overlay') {\n\t\t\tif (this.drawerState === 'close') {\n\t\t\t\tthis.nav.style.transform = 'translateX(-100%)'\n\t\t\t\tthis.overlay.style.display = 'none'\n\t\t\t} else if (this.drawerState === 'open') {\n\t\t\t\tthis.nav.style.transform = 'translateX(0)'\n\t\t\t\tthis.overlay.style.display = 'block'\n\t\t\t\tthis.overlay.style.opacity = '0.4'\n\t\t\t}\n\t\t} else if (this.mode === 'push') {\n\t\t\t// In push mode, the nav is always visible and the overlay hidden.\n\t\t\tthis.nav.style.transform = 'translateX(0)'\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t\tthis._initialized = true\n\t}\n\n\t/**\n\t * updated()\n\t * Trigger animations when either the consumed mode or state changes.\n\t */\n\tupdated(changedProperties: Map<string, any>) {\n\t\tif (!this._initialized) return\n\n\t\tif (changedProperties.has('drawerState') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.drawerState === 'open') {\n\t\t\t\t\t// Animate only if the nav isn’t already open.\n\t\t\t\t\tif (this.nav.style.transform !== 'translateX(0)') {\n\t\t\t\t\t\tthis.openOverlay()\n\t\t\t\t\t\tthis.showNavDrawer()\n\t\t\t\t\t}\n\t\t\t\t} else if (this.drawerState === 'close') {\n\t\t\t\t\tif (this.nav.style.transform !== 'translateX(-100%)') {\n\t\t\t\t\t\tthis.hideNavDrawer()\n\t\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tif (this.nav.style.transform !== 'translateX(0)') {\n\t\t\t\t\tthis.showNavDrawer()\n\t\t\t\t}\n\t\t\t\tif (this.overlay.style.display !== 'none') {\n\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Animate the overlay to fade in.\n\t */\n\topenOverlay() {\n\t\tthis.overlay.style.display = 'block'\n\t\tthis.overlay.animate([{ opacity: 0 }, { opacity: 0.4 }], {\n\t\t\tduration: OVERLAY_ANIM_DURATION_OPEN,\n\t\t\teasing: ANIMATION_EASING,\n\t\t\tfill: 'forwards',\n\t\t})\n\t}\n\n\t/**\n\t * Animate the overlay to fade out, then hide it.\n\t */\n\tcloseOverlay() {\n\t\tconst animation = this.overlay.animate([{ opacity: 0.4 }, { opacity: 0 }], {\n\t\t\tduration: OVERLAY_ANIM_DURATION_CLOSE,\n\t\t\teasing: ANIMATION_EASING,\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t}\n\tshowNavDrawer() {\n\t\t// Use computed style if needed, but here we directly update inline style after animation.\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(-100%)' }, { transform: 'translateX(0)' }], {\n\t\t\tduration: NAV_ANIM_DURATION,\n\t\t\teasing: ANIMATION_EASING,\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.nav.style.transform = 'translateX(0)'\n\t\t}\n\t}\n\n\thideNavDrawer() {\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(0)' }, { transform: 'translateX(-100%)' }], {\n\t\t\tduration: NAV_ANIM_DURATION,\n\t\t\teasing: ANIMATION_EASING,\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.nav.style.transform = 'translateX(-100%)'\n\t\t}\n\t}\n\n\t/**\n\t * Handle overlay click events by dispatching a custom event\n\t * to close the navigation drawer.\n\t */\n\tprivate handleOverlayClick() {\n\t\twindow.dispatchEvent(\n\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\tdetail: { state: 'close' },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprotected render() {\n\t\tconst sidebarClasses = {\n\t\t\t'p-2 max-w-[360px] w-fit h-full overflow-auto': true,\n\t\t\tblock: this.mode === 'push',\n\t\t\t'fixed inset-0 z-50': this.mode === 'overlay',\n\t\t}\n\t\tconst overlayClass = {\n\t\t\t'fixed inset-0 z-49 hidden': true,\n\t\t}\n\t\tconst styleMap = {\n\t\t\twidth: this.width,\n\t\t}\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tstyle=${this.styleMap(styleMap)}\n\t\t\t\tclass=\"${this.classMap({ ...sidebarClasses })}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t\t<div\n\t\t\t\tid=\"overlay\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.scrim,\n\t\t\t\t})}\n\t\t\t\t@click=${this.handleOverlayClick}\n\t\t\t\tclass=\"${this.classMap({ ...overlayClass })}\"\n\t\t\t></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-navbar': SchmancyNavigationDrawerSidebar\n\t}\n}\n","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { color } from '@schmancy/directives'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyTheme } from '..'\nimport { BehaviorSubject, fromEvent, merge, timer } from 'rxjs'\nimport { takeUntil, tap, filter } from 'rxjs/operators'\n\n/**\n * `<schmancy-navigation-bar-item>` component\n *\n * Individual navigation item for use within a navigation bar.\n * Represents a single destination with an icon and optional label following Material Design 3 specifications.\n *\n * @element schmancy-navigation-bar-item\n * @slot icon - Slot for custom icon content\n * @slot - Default slot for custom content\n *\n * @fires bar-item-click - When the item is clicked\n * @fires focus - When the item receives focus\n * @fires blur - When the item loses focus\n *\n * @example\n * <schmancy-navigation-bar-item icon=\"home\" label=\"Home\" active></schmancy-navigation-bar-item>\n *\n * @example\n * <schmancy-navigation-bar-item label=\"Custom\">\n * <span slot=\"icon\">🏠</span>\n * </schmancy-navigation-bar-item>\n */\n@customElement('schmancy-navigation-bar-item')\nexport class SchmancyNavigationBarItem extends TailwindElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex: 1;\n\t\tmin-width: 48px;\n\t\tmax-width: 168px;\n\t\tuser-select: none;\n\t\t-webkit-tap-highlight-color: transparent;\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\tbutton {\n\t\tfont-family: inherit;\n\t\tborder: none;\n\t\tbackground: none;\n\t\twidth: 100%;\n\t\tpadding: 0;\n\t\tmargin: 0;\n\t\ttext-align: center;\n\t\tcolor: inherit;\n\t}\n\n\tbutton:focus {\n\t\toutline: none;\n\t}\n\n\tbutton:focus-visible {\n\t\toutline: 2px solid var(--focus-color);\n\t\toutline-offset: 2px;\n\t\tborder-radius: 8px;\n\t}\n\n\t/* Ripple animation */\n\t@keyframes ripple {\n\t\tto {\n\t\t\ttransform: scale(4);\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t.ripple-effect {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tbackground-color: currentColor;\n\t\topacity: 0.25;\n\t\tanimation: ripple 0.6s ease-out;\n\t\tpointer-events: none;\n\t}\n`) {\n\t/**\n\t * Icon name for the navigation item (Material Symbols Outlined)\n\t */\n\t@property({ type: String })\n\ticon = ''\n\n\t/**\n\t * Label text for the navigation item\n\t */\n\t@property({ type: String })\n\tlabel = ''\n\n\t/**\n\t * Badge content (can be a number or short text)\n\t */\n\t@property({ type: String })\n\tbadge = ''\n\n\t/**\n\t * Observable for active state\n\t */\n\tprivate active$ = new BehaviorSubject<boolean>(false)\n\n\t/**\n\t * Whether this item is currently active/selected\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tget active() { return this.active$.value }\n\tset active(value: boolean) { this.active$.next(value) }\n\n\t/**\n\t * Whether this item is disabled\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled = false\n\n\t/**\n\t * Whether to hide labels (controlled by parent navigation bar)\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\thideLabels = false\n\n\t/**\n\t * Track ripple effects\n\t */\n\t@state()\n\tprivate ripples: { x: number; y: number; id: number }[] = []\n\n\t/**\n\t * Add ripple effect (immediate, no debounce)\n\t */\n\tprivate addRippleEffect = (event: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Find the icon indicator div for ripple positioning\n\t\tconst indicatorDiv = this.shadowRoot?.querySelector('.w-16.h-8')\n\t\tif (indicatorDiv) {\n\t\t\tconst rect = indicatorDiv.getBoundingClientRect()\n\t\t\tconst ripple = {\n\t\t\t\tx: event.clientX - rect.left,\n\t\t\t\ty: event.clientY - rect.top,\n\t\t\t\tid: Date.now()\n\t\t\t}\n\t\t\tthis.ripples = [...this.ripples, ripple]\n\n\t\t\t// Remove ripple after animation\n\t\t\ttimer(600).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== ripple.id)\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t).subscribe()\n\t\t}\n\t}\n\n\t/**\n\t * Handle click events with RxJS\n\t */\n\tprivate handleClick = (event: MouseEvent) => {\n\t\tif (this.disabled) {\n\t\t\tevent.preventDefault()\n\t\t\tevent.stopPropagation()\n\t\t\treturn\n\t\t}\n\n\t\t// Add ripple immediately\n\t\tthis.addRippleEffect(event)\n\n\t\t// Navigation event is handled in connectedCallback\n\t}\n\n\t/**\n\t * Handle keyboard events for accessibility (non-Enter/Space keys)\n\t */\n\tprivate handleKeyDown = (event: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Enter and Space are handled by the RxJS stream\n\t\tif (event.key === 'Enter' || event.key === ' ') {\n\t\t\tevent.preventDefault()\n\t\t\t// Keyboard activation is handled in connectedCallback\n\t\t}\n\t}\n\n\t/**\n\t * Method called by parent to set active state\n\t */\n\tsetActive(isActive: boolean) {\n\t\tthis.active = isActive\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Subscribe to active state changes\n\t\tthis.active$.pipe(\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe(() => {\n\t\t\tthis.requestUpdate()\n\t\t})\n\n\t\t// Set up navigation event stream\n\t\tthis.setupNavigationStream()\n\t}\n\n\t/**\n\t * Set up RxJS stream for navigation events\n\t */\n\tprivate setupNavigationStream() {\n\t\tconst button = this.shadowRoot?.querySelector('button')\n\t\tif (!button) return\n\n\t\t// Create click stream\n\t\tconst click$ = fromEvent<MouseEvent>(button, 'click').pipe(\n\t\t\tfilter(() => !this.disabled)\n\t\t)\n\n\t\t// Create keyboard activation stream (Enter/Space)\n\t\tconst keyActivation$ = fromEvent<KeyboardEvent>(button, 'keydown').pipe(\n\t\t\tfilter(() => !this.disabled),\n\t\t\tfilter(event => event.key === 'Enter' || event.key === ' '),\n\t\t\ttap(event => event.preventDefault())\n\t\t)\n\n\t\t// Merge click and keyboard streams for instant navigation\n\t\tmerge(click$, keyActivation$).pipe(\n\t\t\ttap(() => {\n\t\t\t\t// Dispatch navigation event\n\t\t\t\tthis.dispatchEvent(new CustomEvent('bar-item-click', {\n\t\t\t\t\tdetail: {\n\t\t\t\t\t\ticon: this.icon,\n\t\t\t\t\t\tlabel: this.label,\n\t\t\t\t\t\tactive: this.active\n\t\t\t\t\t},\n\t\t\t\t\tbubbles: true,\n\t\t\t\t\tcomposed: true\n\t\t\t\t}))\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\t/**\n\t * Format badge content for display\n\t */\n\tprivate formatBadge(badge: string): string {\n\t\t// Convert to number if possible\n\t\tconst num = Number(badge)\n\t\tif (!isNaN(num)) {\n\t\t\t// Show 99+ for large numbers\n\t\t\treturn num > 99 ? '99+' : String(num)\n\t\t}\n\t\t// For text badges, limit to 3 characters\n\t\treturn badge.slice(0, 3)\n\t}\n\n\tprotected firstUpdated() {\n\t\t// Set up navigation stream after first render when button is available\n\t\tthis.setupNavigationStream()\n\t}\n\n\tprotected render() {\n\t\tconst hasSlotContent = this.querySelector('[slot]') || (this.textContent?.trim() && !this.label)\n\t\tconst badgeText = this.badge ? this.formatBadge(this.badge) : ''\n\t\tconst showBadgeText = badgeText && badgeText !== '0'\n\n\t\t// Check for custom icon slot content\n\t\tconst hasCustomIcon = this.querySelector('[slot=\"icon\"]')\n\n\t\t// Main container classes - now the clickable area\n\t\tconst containerClasses = {\n\t\t\t'relative flex flex-col items-center justify-center': true,\n\t\t\t'flex-1 min-w-[48px] max-w-[168px]': true, // Fill available space\n\t\t\t'py-2 px-1 cursor-pointer': !this.disabled,\n\t\t\t'transition-all duration-200': true,\n\t\t\t'hover:bg-surface-container-high': !this.disabled && !this.active,\n\t\t\t'cursor-not-allowed opacity-38': this.disabled,\n\t\t\t'outline-none': true,\n\t\t\t'focus-visible:outline-2 focus-visible:outline-offset-2': true\n\t\t}\n\n\t\t// Icon indicator - just visual, not clickable\n\t\tconst indicatorClasses = {\n\t\t\t'w-16 h-8 rounded-2xl': true,\n\t\t\t'flex items-center justify-center': true,\n\t\t\t'transition-all duration-200': true,\n\t\t\t'bg-secondary-container': this.active,\n\t\t\t'group-hover:bg-surface-container-highest': !this.active && !this.disabled,\n\t\t\t'relative overflow-hidden': true\n\t\t}\n\n\t\tconst labelClasses = {\n\t\t\t'text-xs font-medium leading-4 mt-1': true,\n\t\t\t'text-center max-w-full': true,\n\t\t\t'overflow-hidden text-ellipsis whitespace-nowrap': true,\n\t\t\t'transition-all duration-200': true\n\t\t}\n\n\t\tconst badgeClasses = {\n\t\t\t'absolute top-0 right-3': true,\n\t\t\t'min-w-[6px] h-1.5': !showBadgeText,\n\t\t\t'min-w-[16px] h-4': showBadgeText,\n\t\t\t'rounded-full': !showBadgeText,\n\t\t\t'rounded-lg': showBadgeText,\n\t\t\t'flex items-center justify-center': showBadgeText,\n\t\t\t'px-1': showBadgeText,\n\t\t\t'transition-all duration-200': true,\n\t\t\t'z-10': true\n\t\t}\n\n\t\t// Determine colors\n\t\tconst containerColors = this.active\n\t\t\t? {\n\t\t\t\t\tcolor: SchmancyTheme.sys.color.secondary.onContainer\n\t\t\t }\n\t\t\t: {\n\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.onVariant\n\t\t\t }\n\n\t\t// Set CSS variables for focus state\n\t\tconst styleVars = {\n\t\t\t'--focus-color': SchmancyTheme.sys.color.primary.default\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=${this.classMap(containerClasses)}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\taria-pressed=${this.active}\n\t\t\t\taria-label=${this.label || 'Navigation item'}\n\t\t\t\tstyle=${this.styleMap({\n\t\t\t\t\t...styleVars,\n\t\t\t\t\t'outline-color': 'var(--focus-color)'\n\t\t\t\t})}\n\t\t\t\t${color(containerColors)}\n\t\t\t>\n\t\t\t\t<!-- Icon with indicator background -->\n\t\t\t\t<div class=${this.classMap(indicatorClasses)}>\n\t\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t\t${this.ripples.map(\n\t\t\t\t\t\tripple => html`\n\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\tclass=\"ripple-effect\"\n\t\t\t\t\t\t\t\tstyle=${this.styleMap({\n\t\t\t\t\t\t\t\t\tleft: `${ripple.x}px`,\n\t\t\t\t\t\t\t\t\ttop: `${ripple.y}px`,\n\t\t\t\t\t\t\t\t\ttransform: 'translate(-50%, -50%)'\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t></span>\n\t\t\t\t\t\t`\n\t\t\t\t\t)}\n\n\t\t\t\t\t${hasCustomIcon\n\t\t\t\t\t\t? html`<slot name=\"icon\"></slot>`\n\t\t\t\t\t\t: this.icon\n\t\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t\t<schmancy-icon\n\t\t\t\t\t\t\t\t\t\t.fill=${this.active ? 1 : 0}\n\t\t\t\t\t\t\t\t\t\tclass=\"relative z-10 flex items-center justify-center transition-all duration-200\"\n\t\t\t\t\t\t\t\t\t\tstyle=\"--schmancy-icon-size: 24px;\"\n\t\t\t\t\t\t\t\t\t\taria-hidden=\"true\"\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t${this.icon}\n\t\t\t\t\t\t\t\t\t</schmancy-icon>\n\t\t\t\t\t\t\t `\n\t\t\t\t\t\t\t: hasSlotContent\n\t\t\t\t\t\t\t\t? html`<slot></slot>`\n\t\t\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\n\t\t\t\t<!-- Label below icon -->\n\t\t\t\t${!this.hideLabels && this.label ? html`\n\t\t\t\t\t<span class=${this.classMap(labelClasses)}>${this.label}</span>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Badge -->\n\t\t\t\t${showBadgeText ? html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=${this.classMap(badgeClasses)}\n\t\t\t\t\t\taria-label=\"${badgeText} notifications\"\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.error.default,\n\t\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.error.on\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"text-[10px] font-medium leading-none\">${badgeText}</span>\n\t\t\t\t\t</span>\n\t\t\t\t` : this.badge ? html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=${this.classMap(badgeClasses)}\n\t\t\t\t\t\taria-label=\"Has notifications\"\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.error.default\n\t\t\t\t\t\t})}\n\t\t\t\t\t></span>\n\t\t\t\t` : ''}\n\t\t\t</button>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-navigation-bar-item': SchmancyNavigationBarItem\n\t}\n}","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { color } from '@schmancy/directives'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyTheme } from '..'\nimport { BehaviorSubject, fromEvent } from 'rxjs'\nimport { takeUntil, throttleTime, tap, pairwise, map, filter } from 'rxjs/operators'\nimport type { SchmancyNavigationBarItem } from './navigation-bar-item'\n\n/**\n * `<schmancy-navigation-bar>` component\n *\n * A horizontal navigation component following Material Design 3 specifications.\n * Navigation bars provide access to between 3-7 primary destinations, fixed at the bottom of the viewport.\n * Automatically hides in fullscreen mode when triggered via schmancyTheme.next({ fullscreen: true }).\n *\n * @element schmancy-navigation-bar\n * @slot - Default slot for navigation bar items\n *\n * @fires navigation-change - When an item is selected\n *\n * @example\n * <schmancy-navigation-bar activeIndex=\"0\">\n * <schmancy-navigation-bar-item icon=\"home\" label=\"Home\"></schmancy-navigation-bar-item>\n * <schmancy-navigation-bar-item icon=\"search\" label=\"Search\"></schmancy-navigation-bar-item>\n * <schmancy-navigation-bar-item icon=\"favorite\" label=\"Favorites\"></schmancy-navigation-bar-item>\n * <schmancy-navigation-bar-item icon=\"settings\" label=\"Settings\"></schmancy-navigation-bar-item>\n * </schmancy-navigation-bar>\n */\n@customElement('schmancy-navigation-bar')\nexport class SchmancyNavigationBar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: fixed;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tright: 0;\n\t\tz-index: 10;\n\t\ttransition: transform 0.3s ease-in-out;\n\t}\n\n\t:host([hide-on-scroll]) {\n\t\ttransition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n\t}\n\n\t/* Support 3-7 items with equal distribution */\n\t::slotted(schmancy-navigation-bar-item) {\n\t\tflex: 1;\n\t\tmax-width: 168px; /* Prevent items from being too wide */\n\t}\n\n\t/* Accessibility focus indicators */\n\t:host(:focus-within) {\n\t\toutline: 2px solid var(--schmancy-sys-color-primary);\n\t\toutline-offset: -2px;\n\t}\n`) {\n\t/**\n\t * Observable for active index state\n\t */\n\tprivate activeIndex$ = new BehaviorSubject<number>(-1)\n\n\t/**\n\t * Currently active item index\n\t * @default -1\n\t */\n\t@property({ type: Number })\n\tget activeIndex() { return this.activeIndex$.value }\n\tset activeIndex(value: number) { this.activeIndex$.next(value) }\n\n\t/**\n\t * Hide labels and show only icons\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\thideLabels = false\n\n\t/**\n\t * Elevation level for the navigation bar\n\t * @default 2\n\t */\n\t@property({ type: Number, reflect: true })\n\televation = 2\n\n\t/**\n\t * Hide navigation bar on scroll down, show on scroll up\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\thideOnScroll = false\n\n\n\t/**\n\t * Current focused item index for keyboard navigation\n\t */\n\t@state()\n\tprivate focusedIndex = -1\n\n\t/**\n\t * Whether the navigation bar is hidden due to scrolling\n\t */\n\t@state()\n\tprivate isHiddenByScroll = false\n\n\t/**\n\t * Whether the navigation bar is hidden due to fullscreen mode\n\t */\n\t@state()\n\tprivate isFullscreen = false\n\n\t/**\n\t * Get all navigation bar items from the slot\n\t */\n\tprivate getItems(): SchmancyNavigationBarItem[] {\n\t\tconst slot = this.shadowRoot?.querySelector('slot') as HTMLSlotElement | null\n\t\tif (!slot) return []\n\t\treturn slot.assignedElements({ flatten: true })\n\t\t\t.filter((el): el is SchmancyNavigationBarItem =>\n\t\t\t\tel.tagName.toLowerCase() === 'schmancy-navigation-bar-item'\n\t\t\t)\n\t}\n\n\t/**\n\t * Minimum scroll threshold before triggering hide/show\n\t */\n\tprivate readonly SCROLL_THRESHOLD = 10\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Listen to bar-item-click events using RxJS\n\t\tfromEvent(this, 'bar-item-click').pipe(\n\t\t\ttap((event: Event) => this.handleItemClick(event as CustomEvent)),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\n\t\t// Listen to keydown events using RxJS\n\t\tfromEvent(this, 'keydown').pipe(\n\t\t\ttap((event: Event) => this.handleKeyDown(event as KeyboardEvent)),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\n\t\t// Subscribe to active index changes\n\t\tthis.activeIndex$.pipe(\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe(index => {\n\t\t\tthis.updateActiveStates(index)\n\t\t})\n\n\t\t// Listen to fullscreen events\n\t\tfromEvent(window, 'fullscreen').pipe(\n\t\t\ttap((event: Event) => {\n\t\t\t\tconst customEvent = event as CustomEvent\n\t\t\t\tthis.isFullscreen = customEvent.detail\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\n\t\t// Set up scroll listener if hideOnScroll is enabled\n\t\tif (this.hideOnScroll) {\n\t\t\tthis.setupScrollListener()\n\t\t}\n\n\t\tthis.updateItems()\n\t}\n\n\t/**\n\t * Set up RxJS-based scroll listener\n\t */\n\tprivate setupScrollListener() {\n\t\t// Create scroll observable\n\t\tfromEvent(window, 'scroll').pipe(\n\t\t\tthrottleTime(100), // Throttle for performance\n\t\t\tmap(() => window.scrollY),\n\t\t\tpairwise(), // Get pairs of [previous, current] scroll positions\n\t\t\tfilter(([prev, curr]) => Math.abs(curr - prev) > this.SCROLL_THRESHOLD), // Only react if scrolled enough\n\t\t\ttap(([prev, curr]) => {\n\t\t\t\tconst scrollingDown = curr > prev\n\t\t\t\tconst scrollingUp = curr < prev\n\n\t\t\t\t// Hide when scrolling down, show when scrolling up\n\t\t\t\tif (scrollingDown && !this.isHiddenByScroll) {\n\t\t\t\t\tthis.isHiddenByScroll = true\n\t\t\t\t} else if (scrollingUp && this.isHiddenByScroll) {\n\t\t\t\t\tthis.isHiddenByScroll = false\n\t\t\t\t}\n\n\t\t\t\t// Always show when near top\n\t\t\t\tif (curr <= this.SCROLL_THRESHOLD) {\n\t\t\t\t\tthis.isHiddenByScroll = false\n\t\t\t\t}\n\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\n\t/**\n\t * Handle item click events\n\t */\n\tprivate handleItemClick = (event: CustomEvent) => {\n\t\tconst items = this.getItems()\n\t\tconst clickedItem = event.target as HTMLElement\n\t\tconst index = items.indexOf(clickedItem as any)\n\n\t\tif (index !== -1 && this.activeIndex !== index) {\n\t\t\tconst oldIndex = this.activeIndex\n\t\t\t// Setting activeIndex will trigger the BehaviorSubject\n\t\t\tthis.activeIndex = index\n\n\t\t\t// Emit navigation change event\n\t\t\tthis.dispatchEvent(new CustomEvent('navigation-change', {\n\t\t\t\tdetail: {\n\t\t\t\t\toldIndex,\n\t\t\t\t\tnewIndex: index,\n\t\t\t\t\titem: clickedItem\n\t\t\t\t},\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true\n\t\t\t}))\n\t\t}\n\t}\n\n\t/**\n\t * Handle keyboard navigation\n\t */\n\tprivate handleKeyDown = (event: KeyboardEvent) => {\n\t\tconst items = this.getItems()\n\t\tconst currentIndex = this.focusedIndex === -1 ? this.activeIndex : this.focusedIndex\n\n\t\tswitch (event.key) {\n\t\t\tcase 'ArrowLeft':\n\t\t\t\tevent.preventDefault()\n\t\t\t\tif (currentIndex > 0) {\n\t\t\t\t\tthis.focusItem(currentIndex - 1)\n\t\t\t\t}\n\t\t\t\tbreak\n\n\t\t\tcase 'ArrowRight':\n\t\t\t\tevent.preventDefault()\n\t\t\t\tif (currentIndex < items.length - 1) {\n\t\t\t\t\tthis.focusItem(currentIndex + 1)\n\t\t\t\t}\n\t\t\t\tbreak\n\n\t\t\tcase 'Home':\n\t\t\t\tevent.preventDefault()\n\t\t\t\tthis.focusItem(0)\n\t\t\t\tbreak\n\n\t\t\tcase 'End':\n\t\t\t\tevent.preventDefault()\n\t\t\t\tthis.focusItem(items.length - 1)\n\t\t\t\tbreak\n\n\t\t\tcase 'Enter':\n\t\t\tcase ' ':\n\t\t\t\tevent.preventDefault()\n\t\t\t\tif (this.focusedIndex !== -1) {\n\t\t\t\t\tconst item = items[this.focusedIndex] as any\n\t\t\t\t\titem?.click()\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t}\n\t}\n\n\t/**\n\t * Focus a specific item by index\n\t */\n\tprivate focusItem(index: number) {\n\t\tconst items = this.getItems()\n\t\tif (items[index]) {\n\t\t\tthis.focusedIndex = index\n\t\t\t;(items[index] as HTMLElement).focus()\n\t\t}\n\t}\n\n\t/**\n\t * Update the list of navigation items\n\t */\n\tprivate updateItems() {\n\t\tconst slot = this.shadowRoot?.querySelector('slot')\n\t\tif (slot) {\n\t\t\tconst handleSlotChange = () => {\n\t\t\t\t// Update active states when slot content changes\n\t\t\t\tthis.updateActiveStates(this.activeIndex)\n\t\t\t}\n\t\t\tslot.addEventListener('slotchange', handleSlotChange)\n\t\t\thandleSlotChange() // Initial update\n\t\t}\n\t}\n\n\n\t/**\n\t * Add a boat item to the navigation bar\n\t * @param config Configuration for the boat item\n\t * @returns The created or existing navigation bar item element\n\t */\n\tpublic addBoatItem(config: { id: string; title: string; icon?: string }) {\n\t\t// Check if item already exists\n\t\tconst existingItem = this.querySelector(`[value=\"${config.id}\"]`) as HTMLElement\n\t\tif (existingItem) {\n\t\t\t// Item already exists, just return it\n\t\t\treturn existingItem\n\t\t}\n\n\t\t// Create new item\n\t\tconst item = document.createElement('schmancy-navigation-bar-item')\n\t\titem.setAttribute('value', config.id)\n\t\titem.innerHTML = `\n\t\t\t<schmancy-icon>${config.icon || 'widgets'}</schmancy-icon>\n\t\t\t<span>${config.title}</span>\n\t\t`\n\t\tthis.appendChild(item)\n\t\treturn item\n\t}\n\n\t/**\n\t * Update active states on all items\n\t */\n\tprivate updateActiveStates(activeIndex: number) {\n\t\tconst items = this.getItems()\n\t\titems.forEach((item, index) => {\n\t\t\tconst navItem = item as any\n\t\t\t// Use setActive method to trigger item's reactive update\n\t\t\tif (navItem.setActive) {\n\t\t\t\tnavItem.setActive(index === activeIndex)\n\t\t\t} else {\n\t\t\t\t// Fallback for backward compatibility\n\t\t\t\tnavItem.active = index === activeIndex\n\t\t\t}\n\t\t\tnavItem.hideLabels = this.hideLabels\n\t\t\t// Set tabindex for accessibility\n\t\t\t;(item as HTMLElement).tabIndex = index === activeIndex ? 0 : -1\n\t\t})\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\n\t\tif (changedProperties.has('hideLabels')) {\n\t\t\t// Only update hide labels, active state is handled by the BehaviorSubject\n\t\t\tthis.updateActiveStates(this.activeIndex)\n\t\t}\n\n\t\tif (changedProperties.has('hideOnScroll')) {\n\t\t\tif (this.hideOnScroll && !changedProperties.get('hideOnScroll')) {\n\t\t\t\t// hideOnScroll was just enabled\n\t\t\t\tthis.setupScrollListener()\n\t\t\t} else if (!this.hideOnScroll) {\n\t\t\t\t// hideOnScroll was disabled, reset hidden state\n\t\t\t\tthis.isHiddenByScroll = false\n\t\t\t}\n\t\t}\n\t}\n\n\tprotected render() {\n\t\t// Determine if the bar should be visually hidden\n\t\tconst isVisuallyHidden = this.isFullscreen || this.isHiddenByScroll\n\n\t\tconst containerClasses = {\n\t\t\t'h-20': true, // 80px height\n\t\t\t'fixed bottom-0 left-0 right-0': true,\n\t\t\t'flex items-center justify-around': true,\n\t\t\t'px-2 py-3 box-border': true,\n\t\t\t'transition-all duration-300 ease-in-out': true,\n\t\t\t// Elevation shadows\n\t\t\t'shadow-none': this.elevation === 0,\n\t\t\t'shadow-sm': this.elevation === 1,\n\t\t\t'shadow-md': this.elevation === 2,\n\t\t\t'shadow-lg': this.elevation === 3,\n\t\t\t'shadow-xl': this.elevation === 4,\n\t\t\t'shadow-2xl': this.elevation === 5,\n\t\t}\n\n\t\t// Apply transform for hide/show animation\n\t\tconst transformStyle = isVisuallyHidden ? 'translateY(100%)' : 'translateY(0)'\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tclass=${this.classMap(containerClasses)}\n\t\t\t\trole=\"navigation\"\n\t\t\t\taria-label=\"Main navigation\"\n\t\t\t\taria-hidden=${isVisuallyHidden}\n\t\t\t\tstyle=\"transform: ${transformStyle};\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-navigation-bar': SchmancyNavigationBar\n\t}\n}","import { bufferTime, concatMap, filter, fromEvent, map, of, Subject, take, tap, timeout, zip } from 'rxjs'\nimport { SchmancyTeleportation } from './teleport.component'\n\nexport type WhereAreYouRickyEvent = CustomEvent<{\n\tid: string\n\tcallerID: number\n}>\n\nexport const WhereAreYouRicky = 'whereAreYouRicky'\n\nexport type HereMortyEvent = CustomEvent<{\n\tcomponent: SchmancyTeleportation\n}>\n\nexport type FLIP_REQUEST = {\n\tfrom: {\n\t\trect: DOMRect\n\t\telement?: HTMLElement\n\t}\n\tto: {\n\t\trect: DOMRect\n\t\telement: HTMLElement\n\t}\n\tstagger?: number\n\thost: HTMLElement\n}\nexport const HereMorty = 'hereMorty'\n\nclass Teleportation {\n\tactiveTeleportations = new Map<string, DOMRect>()\n\tflipRequests = new Subject<FLIP_REQUEST>()\n\n\tconstructor() {\n\t\tthis.flipRequests\n\t\t\t.pipe(\n\t\t\t\tbufferTime(1),\n\t\t\t\tmap(requests =>\n\t\t\t\t\trequests.map(({ from, to, host }, i) => ({\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tto,\n\t\t\t\t\t\thost,\n\t\t\t\t\t\ti,\n\t\t\t\t\t})),\n\t\t\t\t),\n\t\t\t\tconcatMap(requests => zip(requests.map(request => of(this.flip(request))))),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tfind = (component: SchmancyTeleportation) => {\n\t\treturn zip([\n\t\t\tfromEvent<HereMortyEvent>(window, HereMorty).pipe(\n\t\t\t\tfilter(\n\t\t\t\t\te =>\n\t\t\t\t\t\t!!e.detail.component.uuid &&\n\t\t\t\t\t\t!!component.id &&\n\t\t\t\t\t\te.detail.component.id === component.id &&\n\t\t\t\t\t\te.detail.component.uuid !== component.uuid,\n\t\t\t\t),\n\t\t\t\tmap(e => e.detail.component),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\tof(component).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent<WhereAreYouRickyEvent['detail']>(WhereAreYouRicky, {\n\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\tid: component.id,\n\t\t\t\t\t\t\t\tcallerID: component.uuid,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}),\n\t\t\t),\n\t\t]).pipe(\n\t\t\tmap(([component]) => component),\n\t\t\ttimeout(0),\n\t\t)\n\t}\n\n\tflip = (request: {\n\t\tfrom: {\n\t\t\trect: DOMRect\n\t\t}\n\t\tto: {\n\t\t\telement: HTMLElement\n\t\t\trect: DOMRect\n\t\t}\n\t\thost: HTMLElement\n\t\ti: number\n\t}) => {\n\t\tconst { from, to } = request\n\n\t\t// Prepare the element for animation\n\t\tconst originalZIndex = to.element.style.zIndex\n\t\tto.element.style.transformOrigin = 'top left'\n\t\tto.element.style.setProperty('visibility', 'visible')\n\t\tto.element.style.zIndex = '1000'\n\n\t\t// \"onBegin\" logic goes here (since Web Animations doesn't have onBegin).\n\t\t// If you had more logic, place it here:\n\n\t\t// Calculate starting and ending transforms\n\t\tconst startX = from.rect.left - to.rect.left\n\t\tconst startY = from.rect.top - to.rect.top\n\t\tconst startScaleX = from.rect.width / to.rect.width\n\t\tconst startScaleY = from.rect.height / to.rect.height\n\n\t\t// Create keyframes\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\ttransform: `translate(${startX}px, ${startY}px) scale(${startScaleX}, ${startScaleY})`,\n\t\t\t},\n\t\t\t{\n\t\t\t\ttransform: 'translate(0, 0) scale(1, 1)',\n\t\t\t},\n\t\t]\n\n\t\t// Use native Web Animations API\n\t\tconst animation = to.element.animate(keyframes, {\n\t\t\tduration: 250,\n\t\t\tdelay: 10, // if desired\n\t\t\t// Approximate 'inOutQuad' via a cubic-bezier easing.\n\t\t\t// You can adjust these values to taste, or use a standard one:\n\t\t\teasing: 'cubic-bezier(0.455, 0.03, 0.515, 0.955)',\n\t\t\t// or simply 'ease-in-out'\n\t\t})\n\n\t\t// \"onComplete\" logic goes here\n\t\tanimation.onfinish = () => {\n\t\t\tto.element.style.zIndex = originalZIndex\n\t\t\tto.element.style.transformOrigin = ''\n\t\t\t// If you have additional cleanup, place it here\n\t\t}\n\t}\n}\n\nexport const teleport = new Teleportation()\nexport default teleport\n","import { Observable, interval } from 'rxjs'\nimport { distinctUntilChanged, map, take } from 'rxjs/operators'\n\n// Function to monitor element's bounding client rect\nexport function watchElementRect(element: Element): Observable<DOMRectReadOnly> {\n\treturn interval(50).pipe(\n\t\t// startWith(true),\n\t\tmap(() => element.getBoundingClientRect()),\n\t\tdistinctUntilChanged(\n\t\t\t(prev, curr) =>\n\t\t\t\tprev.width === curr.width &&\n\t\t\t\tprev.height === curr.height &&\n\t\t\t\tprev.top === curr.top &&\n\t\t\t\tprev.right === curr.right &&\n\t\t\t\tprev.bottom === curr.bottom &&\n\t\t\t\tprev.left === curr.left,\n\t\t),\n\t\ttake(1),\n\t)\n}\n","import { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { filter, fromEvent, merge, of, takeUntil, tap, throwIfEmpty } from 'rxjs'\nimport { FINDING_MORTIES, FINDING_MORTIES_EVENT, HERE_RICKY, HERE_RICKY_EVENT } from '..'\nimport {\n\tHereMorty,\n\tHereMortyEvent,\n\tWhereAreYouRicky,\n\tWhereAreYouRickyEvent,\n\tdefault as teleport,\n\tdefault as teleportationService,\n} from './teleport.service'\nimport { watchElementRect } from './watcher'\nimport { $LitElement } from '@mixins/index'\n@customElement('schmancy-teleport')\nexport class SchmancyTeleportation extends $LitElement(css``) {\n\t/**\n\t * @attr {string} uuid - The component tag to teleport\n\t * @readonly\n\t */\n\t@property({ type: Number, reflect: true }) uuid = Math.floor(Math.random() * Date.now())\n\n\t/**\n\t * @attr {string} id - The component tag to teleport\n\t * @required\n\t */\n\t@property({ type: String }) id!: string\n\n\t@property({ type: Number }) delay = 0\n\n\tdebugging = import.meta.env.DEV ? true : false\n\n\tget _slottedChildren() {\n\t\tconst slot = this.shadowRoot.querySelector('slot')\n\t\treturn slot.assignedElements({ flatten: true })\n\t}\n\n\tconnectedCallback(): void {\n\t\tif (this.id === undefined) throw new Error('id is required')\n\t\tsuper.connectedCallback()\n\t\tmerge(\n\t\t\tfromEvent<FINDING_MORTIES_EVENT>(window, FINDING_MORTIES).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\tnew CustomEvent<HERE_RICKY_EVENT['detail']>(HERE_RICKY, {\n\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t)\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t\tfromEvent<WhereAreYouRickyEvent>(window, WhereAreYouRicky).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: e => {\n\t\t\t\t\t\tif (e.detail.id === this.id && this.uuid && e.detail.callerID !== this.uuid) {\n\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\tnew CustomEvent<HereMortyEvent['detail']>(HereMorty, {\n\t\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe()\n\t}\n\n\tasync firstUpdated() {\n\t\tof(teleportationService.activeTeleportations.get(this.id))\n\t\t\t.pipe(\n\t\t\t\tfilter(a => !!a),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tthrowIfEmpty(),\n\t\t\t)\n\t\t\t.subscribe({\n\t\t\t\tnext: domRect => {\n\t\t\t\t\tconsole.count('teleport')\n\t\t\t\t\tthis.style.setProperty('visibility', 'hidden')\n\t\t\t\t\t// teleport.flipRequests.next({ from: component, to: this, stagger: 0 })\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t\tteleport.flipRequests.next({\n\t\t\t\t\t\t\t\t\tfrom: {\n\t\t\t\t\t\t\t\t\t\trect: domRect,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tto: {\n\t\t\t\t\t\t\t\t\t\trect: e,\n\t\t\t\t\t\t\t\t\t\telement: this._slottedChildren[0] as HTMLElement,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\thost: this,\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\terror: () => {\n\t\t\t\t\tthis.style.setProperty('visibility', 'visible')\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\tcomplete: () => {},\n\t\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-teleport': SchmancyTeleportation\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { color } from '@schmancy/directives'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\n\nexport type AvatarSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'\nexport type AvatarColor = 'primary' | 'secondary' | 'tertiary' | 'success' | 'error' | 'neutral'\nexport type AvatarShape = 'circle' | 'square'\nexport type AvatarStatus = 'online' | 'offline' | 'busy' | 'away' | 'none'\n\n/**\n * A customizable avatar component that displays initials or an icon\n * Designed to match the Schmancy design system\n *\n * @element schmancy-avatar\n *\n * @property {string} initials - Text initials to display (limited to 2 characters)\n * @property {string} src - URL of an image to display\n * @property {string} icon - Name of an icon to display\n * @property {AvatarSize} size - Size of the avatar (xs, sm, md, lg, xl)\n * @property {AvatarColor} color - Color theme of the avatar\n * @property {AvatarShape} shape - Shape of the avatar (circle or square)\n * @property {boolean} bordered - Whether to add a border around the avatar\n * @property {AvatarStatus} status - Optional status indicator to display\n *\n * @example\n * <schmancy-avatar\n * initials=\"JD\"\n * size=\"md\"\n * color=\"primary\"\n * ></schmancy-avatar>\n */\n@customElement('schmancy-avatar')\nexport class SchmancyAvatar extends $LitElement() {\n\t@property({ type: String }) initials: string = ''\n\t@property({ type: String }) src: string = ''\n\t@property({ type: String }) icon: string = ''\n\t@property({ type: String }) size: AvatarSize = 'md'\n\t@property({ type: String }) color: AvatarColor = 'primary'\n\t@property({ type: String }) shape: AvatarShape = 'circle'\n\t@property({ type: Boolean }) bordered: boolean = false\n\t@property({ type: String }) status: AvatarStatus = 'none'\n\n\trender() {\n\t\t// Determine content to display (image, initials, or icon)\n\t\tlet content\n\t\tif (this.src) {\n\t\t\tcontent = html`<img class=\"w-full h-full object-cover\" src=\"${this.src}\" alt=\"Avatar\" />`\n\t\t} else if (this.initials) {\n\t\t\tcontent = html`<span class=\"text-center font-medium\">${this.initials.substring(0, 2).toUpperCase()}</span>`\n\t\t} else if (this.icon) {\n\t\t\tcontent = html`<schmancy-icon>${this.icon}</schmancy-icon>`\n\t\t} else {\n\t\t\tcontent = html`<schmancy-icon>person</schmancy-icon>`\n\t\t}\n\n\t\t// Size classes\n\t\tconst sizeClasses = {\n\t\t\txs: 'w-6 h-6 text-xs',\n\t\t\tsm: 'w-8 h-8 text-sm',\n\t\t\tmd: 'w-10 h-10 text-base',\n\t\t\tlg: 'w-12 h-12 text-lg',\n\t\t\txl: 'w-16 h-16 text-xl',\n\t\t}\n\n\t\t// Shape classes\n\t\tconst shapeClasses = {\n\t\t\tcircle: 'rounded-full',\n\t\t\tsquare: 'rounded-md',\n\t\t}\n\n\t\t// Combine classes\n\t\tconst avatarClasses = {\n\t\t\t'relative flex items-center justify-center overflow-hidden': true,\n\t\t\t[sizeClasses[this.size]]: true,\n\t\t\t[shapeClasses[this.shape]]: true,\n\t\t\t'border-2 border-surface-container': this.bordered,\n\t\t}\n\n\t\t// Get theme colors\n\t\tconst colorAttrs = this.getColorAttributes()\n\n\t\treturn html`\n\t\t\t<div class=\"${this.classMap(avatarClasses)}\" ${colorAttrs}>\n\t\t\t\t${content} ${this.status !== 'none' ? this.renderStatusIndicator() : ''}\n\t\t\t</div>\n\t\t`\n\t}\n\n\tprivate getColorAttributes() {\n\t\tconst colorMap = {\n\t\t\tprimary: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.primary.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.primary.onContainer,\n\t\t\t},\n\t\t\tsecondary: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.secondary.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.secondary.onContainer,\n\t\t\t},\n\t\t\ttertiary: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.tertiary.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.tertiary.onContainer,\n\t\t\t},\n\t\t\tsuccess: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.success.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.success.onContainer,\n\t\t\t},\n\t\t\terror: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.error.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.error.onContainer,\n\t\t\t},\n\t\t\tneutral: {\n\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t},\n\t\t}\n\n\t\treturn color(colorMap[this.color])\n\t}\n\n\tprivate renderStatusIndicator() {\n\t\tconst statusColors = {\n\t\t\tonline: SchmancyTheme.sys.color.success.default,\n\t\t\toffline: SchmancyTheme.sys.color.surface.onVariant,\n\t\t\tbusy: SchmancyTheme.sys.color.error.default,\n\t\t\taway: SchmancyTheme.sys.color.tertiary.default,\n\t\t}\n\n\t\tconst sizeMap = {\n\t\t\txs: 'w-1.5 h-1.5',\n\t\t\tsm: 'w-2 h-2',\n\t\t\tmd: 'w-2.5 h-2.5',\n\t\t\tlg: 'w-3 h-3',\n\t\t\txl: 'w-4 h-4',\n\t\t}\n\n\t\tconst statusClasses = {\n\t\t\t'absolute bottom-0 right-0 rounded-full border-2 border-surface-default': true,\n\t\t\t[sizeMap[this.size]]: true,\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"${this.classMap(statusClasses)}\" style=\"background-color: ${statusColors[this.status]};\"></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-avatar': SchmancyAvatar\n\t}\n}\n"],"names":["SchmancyBadgeV2","TailwindElement","css","constructor","super","arguments","this","color","size","shape","outlined","icon","pulse","getSizeClasses","getShapeClasses","getIconSize","styles","letterSpacing","fontWeight","getColorStyles","primary","bg","SchmancyTheme","sys","container","default","text","onContainer","border","surface","highest","secondary","tertiary","success","bright","warning","error","neutral","high","outline","on","render","sizeClasses","shapeClasses","colorStyles","iconSize","exoticStyles","getExoticStyles","badgeClasses","shadow","borderColor","backdropFilter","boxShadow","html","classMap","styleMap","bgColor","__decorateClass","property","type","String","reflect","prototype","Boolean","customElement","ScBadgeV2","schmancyContentDrawer","$drawer","Subject","lastComponent","pipe","subscribe","data","action","ref","dispatchEvent","CustomEvent","SchmancyEvents","ContentDrawerToggle","detail","state","bubbles","composed","component","title","handlePush","next","resolvedComponent","document","createElement","HTMLElement","result","requestUpdate","window","SchmancyContentDrawerSheetMode","createContext","SchmancyContentDrawerSheetState","SchmancyContentDrawerID","Math","floor","random","Date","now","toString","SchmancyContentDrawerMaxHeight","SchmancyContentDrawerMinWidth","SchmancyContentDrawer","$LitElement","minWidth","main","sheet","schmancyContentDrawerID","maxHeight","firstUpdated","merge","fromEvent","ContentDrawerResize","startWith","map","clientWidth","innerWidth","width","debounceTime","tap","innerHeight","getOffsetTop","style","setProperty","distinctUntilChanged","takeUntil","disconnecting","lgScreen","mode","open","event","stopPropagation","area","push","historyStrategy","uid","element","offsetTop","offsetParent","nothing","provide","context","queryAssignedElements","flatten","SchmancyContentDrawerMain","connectedCallback","drawerMinWidth","changedProperties","update","has","when","Number","consume","SchmancyContentDrawerSheet","updated","closeAll","dismiss","position","display","animate","opacity","transform","duration","easing","from","closeModalSheet","closeSheet","of","Observable","observer","onfinish","complete","sheetClasses","block","query","slot","schmancyNavDrawer","NavDrawer_toggle","self","SchmancyDrawerNavbarMode","SchmancyDrawerNavbarState","SchmancyDrawerAppbar","toggler","sidebarToggler","sidebarMode","hidden","gridClasses","sidebarOpen","SchmancyNavigationDrawerContent","e","parentElement","SchmancyNavigationDrawer","fullscreen","breakpoint","_initialized","updateState","setAttribute","target","BREAKPOINTS","isLargeScreen","customEvent","fullHeight","sm","md","lg","xl","attribute","ANIMATION_EASING","SchmancyNavigationDrawerSidebar","drawerState","nav","overlay","openOverlay","showNavDrawer","hideNavDrawer","closeOverlay","fill","handleOverlayClick","sidebarClasses","scrim","SchmancyNavigationBarItem","label","badge","active$","BehaviorSubject","disabled","hideLabels","ripples","addRippleEffect","indicatorDiv","shadowRoot","querySelector","rect","getBoundingClientRect","ripple","x","clientX","left","y","clientY","top","id","timer","filter","r","handleClick","preventDefault","handleKeyDown","key","active","value","isActive","setupNavigationStream","button","click$","keyActivation$","num","isNaN","slice","hasSlotContent","textContent","trim","badgeText","formatBadge","showBadgeText","hasCustomIcon","containerClasses","indicatorClasses","containerColors","onVariant","styleVars","SchmancyNavigationBar","activeIndex$","elevation","hideOnScroll","focusedIndex","isHiddenByScroll","isFullscreen","SCROLL_THRESHOLD","handleItemClick","items","getItems","clickedItem","index","indexOf","activeIndex","oldIndex","newIndex","item","currentIndex","focusItem","length","click","assignedElements","el","tagName","toLowerCase","updateActiveStates","setupScrollListener","updateItems","throttleTime","scrollY","pairwise","prev","curr","abs","scrollingUp","focus","handleSlotChange","addEventListener","config","existingItem","innerHTML","appendChild","forEach","navItem","setActive","tabIndex","get","isVisuallyHidden","transformStyle","WhereAreYouRicky","HereMorty","teleport","activeTeleportations","Map","flipRequests","find","zip","uuid","take","callerID","timeout","flip","request","to","originalZIndex","zIndex","transformOrigin","keyframes","height","delay","bufferTime","requests","host","i","concatMap","watchElementRect","interval","right","bottom","SchmancyTeleportation","debugging","_slottedChildren","Error","FINDING_MORTIES","HERE_RICKY","teleportationService","a","throwIfEmpty","domRect","set","SchmancyAvatar","initials","src","bordered","status","content","substring","toUpperCase","avatarClasses","xs","circle","square","colorAttrs","getColorAttributes","renderStatusIndicator","colorMap","statusColors","online","offline","busy","away","statusClasses"],"mappings":"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"}
|