@mhmo91/schmancy 0.4.24 → 0.4.33
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/ai/sheet.md +87 -25
- package/dist/ai/sheet.md +87 -25
- package/dist/{animated-text-DcLpvyCq.js → animated-text-AbNgT7ie.js} +3 -3
- package/dist/{animated-text-DcLpvyCq.js.map → animated-text-AbNgT7ie.js.map} +1 -1
- package/dist/{animated-text-BitOmeE1.cjs → animated-text-CYmUxmlv.cjs} +2 -2
- package/dist/{animated-text-BitOmeE1.cjs.map → animated-text-CYmUxmlv.cjs.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-BTLn3oIv.cjs → area.component-B1Lmmsuk.cjs} +2 -2
- package/dist/{area.component-BTLn3oIv.cjs.map → area.component-B1Lmmsuk.cjs.map} +1 -1
- package/dist/{area.component-xbNRrst9.js → area.component-BxrgxiLv.js} +3 -3
- package/dist/{area.component-xbNRrst9.js.map → area.component-BxrgxiLv.js.map} +1 -1
- package/dist/area.js +2 -2
- package/dist/{autocomplete-BqRrw118.js → autocomplete-Bx1vWN32.js} +3 -3
- package/dist/{autocomplete-BqRrw118.js.map → autocomplete-Bx1vWN32.js.map} +1 -1
- package/dist/{autocomplete-Dvc06UNM.cjs → autocomplete-ClTDM1cy.cjs} +2 -2
- package/dist/{autocomplete-Dvc06UNM.cjs.map → autocomplete-ClTDM1cy.cjs.map} +1 -1
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/{avatar-CP5pbPbp.cjs → avatar-0h3VHdWs.cjs} +2 -2
- package/dist/{avatar-CP5pbPbp.cjs.map → avatar-0h3VHdWs.cjs.map} +1 -1
- package/dist/{avatar-Cb_cbT8R.js → avatar-C5iIJlD9.js} +46 -46
- package/dist/{avatar-Cb_cbT8R.js.map → avatar-C5iIJlD9.js.map} +1 -1
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/{boat-Dtum9CaN.cjs → boat--6fKaS1r.cjs} +2 -2
- package/dist/{boat-Dtum9CaN.cjs.map → boat--6fKaS1r.cjs.map} +1 -1
- package/dist/{boat-ByFTBKD2.js → boat-vVWqUMYt.js} +2 -2
- package/dist/{boat-ByFTBKD2.js.map → boat-vVWqUMYt.js.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-Dq0Lm3AM.js → checkbox-91xSd_El.js} +5 -5
- package/dist/{checkbox-Dq0Lm3AM.js.map → checkbox-91xSd_El.js.map} +1 -1
- package/dist/{checkbox-220X9LTx.cjs → checkbox-CcKQi7Hq.cjs} +2 -2
- package/dist/{checkbox-220X9LTx.cjs.map → checkbox-CcKQi7Hq.cjs.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-aRU1fwEV.js → chips-D26R6u7T.js} +3 -3
- package/dist/{chips-aRU1fwEV.js.map → chips-D26R6u7T.js.map} +1 -1
- package/dist/{chips-jORxgpG7.cjs → chips-Duj_48dP.cjs} +2 -2
- package/dist/{chips-jORxgpG7.cjs.map → chips-Duj_48dP.cjs.map} +1 -1
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +1 -1
- package/dist/{circular-progress-Dis30LMa.js → circular-progress-BAzvWUr0.js} +3 -3
- package/dist/{circular-progress-Dis30LMa.js.map → circular-progress-BAzvWUr0.js.map} +1 -1
- package/dist/{circular-progress-DMccmWrI.cjs → circular-progress-CeiF8CYP.cjs} +2 -2
- package/dist/{circular-progress-DMccmWrI.cjs.map → circular-progress-CeiF8CYP.cjs.map} +1 -1
- package/dist/circular-progress.cjs +1 -1
- package/dist/circular-progress.js +1 -1
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/{code-preview-CCHcWZvS.cjs → code-preview-BCUSwkuU.cjs} +13 -13
- package/dist/{code-preview-CCHcWZvS.cjs.map → code-preview-BCUSwkuU.cjs.map} +1 -1
- package/dist/{code-preview-BwIb73Yd.js → code-preview-kNXSixdo.js} +333 -331
- package/dist/{code-preview-BwIb73Yd.js.map → code-preview-kNXSixdo.js.map} +1 -1
- package/dist/components.cjs +1 -1
- package/dist/components.js +1 -1
- package/dist/consume-5D1qfVWM.js.map +1 -1
- package/dist/consume-edta5ng5.cjs.map +1 -1
- package/dist/content-drawer.cjs +1 -1
- package/dist/content-drawer.js +1 -1
- package/dist/context-object-CDDP4bTk.js.map +1 -1
- package/dist/context-object-K_1gDFu-.cjs.map +1 -1
- package/dist/{date-range-DinaPWK0.cjs → date-range-CBrZ7Pm6.cjs} +2 -2
- package/dist/{date-range-DinaPWK0.cjs.map → date-range-CBrZ7Pm6.cjs.map} +1 -1
- package/dist/{date-range-CA_4vjWe.js → date-range-gp2cu49l.js} +3 -3
- package/dist/{date-range-CA_4vjWe.js.map → date-range-gp2cu49l.js.map} +1 -1
- package/dist/{date-range-inline-DFjyAvPv.js → date-range-inline-DZwtgeXX.js} +3 -3
- package/dist/{date-range-inline-DFjyAvPv.js.map → date-range-inline-DZwtgeXX.js.map} +1 -1
- package/dist/{date-range-inline-CGMvaSeh.cjs → date-range-inline-ZPM9dCG1.cjs} +2 -2
- package/dist/{date-range-inline-CGMvaSeh.cjs.map → date-range-inline-ZPM9dCG1.cjs.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-CHAH30wI.cjs → delay-CUpeZtD8.cjs} +2 -2
- package/dist/{delay-CHAH30wI.cjs.map → delay-CUpeZtD8.cjs.map} +1 -1
- package/dist/{delay-BJwsHbg3.js → delay-CYxt2x_w.js} +2 -2
- package/dist/{delay-BJwsHbg3.js.map → delay-CYxt2x_w.js.map} +1 -1
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/{dialog-content-Bp2kwzxD.cjs → dialog-content-Cz2MP3fS.cjs} +2 -2
- package/dist/{dialog-content-Bp2kwzxD.cjs.map → dialog-content-Cz2MP3fS.cjs.map} +1 -1
- package/dist/{dialog-content-CEZqJRzH.js → dialog-content-DmUr4jZM.js} +3 -3
- package/dist/{dialog-content-CEZqJRzH.js.map → dialog-content-DmUr4jZM.js.map} +1 -1
- package/dist/dialog-service-BZZK8N6A.cjs.map +1 -1
- package/dist/dialog-service-DFMlRcXf.js.map +1 -1
- package/dist/dialog.cjs +1 -1
- package/dist/dialog.js +1 -1
- package/dist/{divider-DfetUf4S.js → divider-BreFKYh2.js} +3 -3
- package/dist/{divider-DfetUf4S.js.map → divider-BreFKYh2.js.map} +1 -1
- package/dist/{divider-BEVgt1wl.cjs → divider-Cd5pOeZr.cjs} +2 -2
- package/dist/{divider-BEVgt1wl.cjs.map → divider-Cd5pOeZr.cjs.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/{dropdown-content-TJmZ3rpA.js → dropdown-content-DjIvlBvq.js} +3 -3
- package/dist/{dropdown-content-TJmZ3rpA.js.map → dropdown-content-DjIvlBvq.js.map} +1 -1
- package/dist/{dropdown-content-CERnSXjI.cjs → dropdown-content-zLE8scWl.cjs} +2 -2
- package/dist/{dropdown-content-CERnSXjI.cjs.map → dropdown-content-zLE8scWl.cjs.map} +1 -1
- package/dist/dropdown.cjs +1 -1
- package/dist/dropdown.js +1 -1
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{flex-ByanQCYb.cjs → flex-CEq4v4cK.cjs} +2 -2
- package/dist/{flex-ByanQCYb.cjs.map → flex-CEq4v4cK.cjs.map} +1 -1
- package/dist/{flex-CXMNh-nH.js → flex-DRvBt9P0.js} +2 -2
- package/dist/{flex-CXMNh-nH.js.map → flex-DRvBt9P0.js.map} +1 -1
- package/dist/flow-D0e7hGXO.cjs.map +1 -1
- package/dist/flow-DXYqC9OA.js.map +1 -1
- package/dist/{form-lhQx_Ry0.cjs → form-B5CAbB2i.cjs} +2 -2
- package/dist/{form-lhQx_Ry0.cjs.map → form-B5CAbB2i.cjs.map} +1 -1
- package/dist/{form-Boc5Pqhf.js → form-BKqz7W6V.js} +2 -2
- package/dist/{form-Boc5Pqhf.js.map → form-BKqz7W6V.js.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{formField.mixin-DhiLSVHT.cjs → formField.mixin-BuKEbib1.cjs} +2 -2
- package/dist/{formField.mixin-DhiLSVHT.cjs.map → formField.mixin-BuKEbib1.cjs.map} +1 -1
- package/dist/{formField.mixin-CX7_nvVy.js → formField.mixin-DCPfsyya.js} +2 -2
- package/dist/{formField.mixin-CX7_nvVy.js.map → formField.mixin-DCPfsyya.js.map} +1 -1
- package/dist/{icon-D1qw18N6.cjs → icon-B0_pMF_-.cjs} +2 -2
- package/dist/{icon-D1qw18N6.cjs.map → icon-B0_pMF_-.cjs.map} +1 -1
- package/dist/{icon-BZw88sCH.js → icon-DA0eDV8w.js} +2 -2
- package/dist/{icon-BZw88sCH.js.map → icon-DA0eDV8w.js.map} +1 -1
- package/dist/{icon-button-TbwQrO1b.js → icon-button-CEnel9Yg.js} +3 -3
- package/dist/{icon-button-TbwQrO1b.js.map → icon-button-CEnel9Yg.js.map} +1 -1
- package/dist/{icon-button-DBvZApEC.cjs → icon-button-DFVuusoz.cjs} +2 -2
- package/dist/{icon-button-DBvZApEC.cjs.map → icon-button-DFVuusoz.cjs.map} +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/icons.js +1 -1
- package/dist/index-CuY8m6ta.js.map +1 -1
- package/dist/index-DyJ0oDpR.cjs.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +133 -134
- package/dist/{input-BUtEXu3y.js → input-B7Q3RRwE.js} +3 -3
- package/dist/{input-BUtEXu3y.js.map → input-B7Q3RRwE.js.map} +1 -1
- package/dist/{input-C0F9cNoD.cjs → input-C4tYxk-t.cjs} +2 -2
- package/dist/{input-C0F9cNoD.cjs.map → input-C4tYxk-t.cjs.map} +1 -1
- package/dist/input.cjs +1 -1
- package/dist/input.js +1 -1
- package/dist/intersection-CJxzz8c-.js.map +1 -1
- package/dist/intersection-CVvaDv96.cjs.map +1 -1
- package/dist/layout.cjs +1 -1
- package/dist/layout.js +1 -1
- package/dist/{list-BCD8h2Do.js → list-BTm67LuV.js} +2 -2
- package/dist/{list-BCD8h2Do.js.map → list-BTm67LuV.js.map} +1 -1
- package/dist/{list-Bz6tq7ZP.cjs → list-Bos26fD3.cjs} +2 -2
- package/dist/{list-Bz6tq7ZP.cjs.map → list-Bos26fD3.cjs.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-DGeprHKB.js → litElement.mixin-Cn8IAazz.js} +2 -2
- package/dist/{litElement.mixin-DGeprHKB.js.map → litElement.mixin-Cn8IAazz.js.map} +1 -1
- package/dist/{litElement.mixin-CII9bbap.cjs → litElement.mixin-Cs3zx2X6.cjs} +2 -2
- package/dist/{litElement.mixin-CII9bbap.cjs.map → litElement.mixin-Cs3zx2X6.cjs.map} +1 -1
- package/dist/{media-D6ba0wB1.js → media-DPQecp4W.js} +2 -2
- package/dist/{media-D6ba0wB1.js.map → media-DPQecp4W.js.map} +1 -1
- package/dist/{media-CBLuAmNZ.cjs → media-YhMV6ELC.cjs} +2 -2
- package/dist/{media-CBLuAmNZ.cjs.map → media-YhMV6ELC.cjs.map} +1 -1
- package/dist/{menu-BDQr8EZ1.cjs → menu-BfNE5Pz2.cjs} +2 -2
- package/dist/{menu-BDQr8EZ1.cjs.map → menu-BfNE5Pz2.cjs.map} +1 -1
- package/dist/{menu-C0SauakY.js → menu-C5KQk1CK.js} +3 -3
- package/dist/{menu-C0SauakY.js.map → menu-C5KQk1CK.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/{notification-service-B1f848tO.cjs → notification-service-Bq_d-qqB.cjs} +2 -2
- package/dist/{notification-service-B1f848tO.cjs.map → notification-service-Bq_d-qqB.cjs.map} +1 -1
- package/dist/{notification-service-X8mRASdk.js → notification-service-unFpqUQn.js} +3 -3
- package/dist/{notification-service-X8mRASdk.js.map → notification-service-unFpqUQn.js.map} +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +1 -1
- package/dist/{option-ckV22mLf.cjs → option-B9LbtNdk.cjs} +2 -2
- package/dist/{option-ckV22mLf.cjs.map → option-B9LbtNdk.cjs.map} +1 -1
- package/dist/{option-DVlCqux7.js → option-Cy-nYxTs.js} +2 -2
- package/dist/{option-DVlCqux7.js.map → option-Cy-nYxTs.js.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{payment-card-form-BUsPCZPp.cjs → payment-card-form-D45IjHFN.cjs} +2 -2
- package/dist/{payment-card-form-BUsPCZPp.cjs.map → payment-card-form-D45IjHFN.cjs.map} +1 -1
- package/dist/{payment-card-form-D7PV8spa.js → payment-card-form-ctWIc4vM.js} +3 -3
- package/dist/{payment-card-form-D7PV8spa.js.map → payment-card-form-ctWIc4vM.js.map} +1 -1
- package/dist/{progress-BZ6AFT0f.js → progress-4Ef6bw05.js} +2 -2
- package/dist/{progress-BZ6AFT0f.js.map → progress-4Ef6bw05.js.map} +1 -1
- package/dist/{progress-CABg45XF.cjs → progress-QXnS6DIm.cjs} +2 -2
- package/dist/{progress-CABg45XF.cjs.map → progress-QXnS6DIm.cjs.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/provide-BxZ2kn_p.cjs.map +1 -1
- package/dist/provide-tcktw8xB.js.map +1 -1
- package/dist/{radio-button-D4Y1bWGN.js → radio-button-CEp1kd-P.js} +3 -3
- package/dist/{radio-button-D4Y1bWGN.js.map → radio-button-CEp1kd-P.js.map} +1 -1
- package/dist/{radio-button-DQ4VclEZ.cjs → radio-button-CUzdKTtW.cjs} +2 -2
- package/dist/{radio-button-DQ4VclEZ.cjs.map → radio-button-CUzdKTtW.cjs.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/redispatch-event-BLom7yp4.js.map +1 -1
- package/dist/redispatch-event-DHcobAl6.cjs.map +1 -1
- package/dist/ripple-BumgqsDT.js.map +1 -1
- package/dist/ripple-C2BHbhcS.cjs.map +1 -1
- package/dist/rxjs-utils.cjs.map +1 -1
- package/dist/rxjs-utils.js.map +1 -1
- package/dist/{schmancy-steps-container-CZ0upElE.cjs → schmancy-steps-container-D3m07gLT.cjs} +2 -2
- package/dist/{schmancy-steps-container-CZ0upElE.cjs.map → schmancy-steps-container-D3m07gLT.cjs.map} +1 -1
- package/dist/{schmancy-steps-container-BskkdQwD.js → schmancy-steps-container-KI2azXpv.js} +2 -2
- package/dist/{schmancy-steps-container-BskkdQwD.js.map → schmancy-steps-container-KI2azXpv.js.map} +1 -1
- package/dist/{select-DfQogfes.cjs → select-Bw4QilHf.cjs} +3 -3
- package/dist/{select-DfQogfes.cjs.map → select-Bw4QilHf.cjs.map} +1 -1
- package/dist/{select-wui4bIUE.js → select-g77JoEFx.js} +18 -20
- package/dist/{select-wui4bIUE.js.map → select-g77JoEFx.js.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +2 -3
- package/dist/selector-hook-Bf_lCnGW.cjs.map +1 -1
- package/dist/{selector-hook-DL0SIQiY.js → selector-hook-DPe2CGKx.js} +16 -16
- package/dist/{selector-hook-DL0SIQiY.js.map → selector-hook-DPe2CGKx.js.map} +1 -1
- package/dist/{sheet-DMOsLeJL.cjs → sheet--fG_jGSI.cjs} +2 -2
- package/dist/{sheet-DMOsLeJL.cjs.map → sheet--fG_jGSI.cjs.map} +1 -1
- package/dist/{sheet-DmrPnCAk.js → sheet-edcIHEMM.js} +4 -4
- package/dist/{sheet-DmrPnCAk.js.map → sheet-edcIHEMM.js.map} +1 -1
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +6 -7
- package/dist/{sheet.service-22gvsyq8.js → sheet.service-BKQ7n7nz.js} +480 -471
- package/dist/{sheet.service-22gvsyq8.js.map → sheet.service-BKQ7n7nz.js.map} +1 -1
- package/dist/{sheet.service-sSYoAEbY.cjs → sheet.service-ihtgUWRM.cjs} +3 -3
- package/dist/{sheet.service-sSYoAEbY.cjs.map → sheet.service-ihtgUWRM.cjs.map} +1 -1
- package/dist/{slider-Dwm1KfNL.js → slider-BJQE9wHL.js} +3 -3
- package/dist/{slider-Dwm1KfNL.js.map → slider-BJQE9wHL.js.map} +1 -1
- package/dist/{slider-C2oEvRAS.cjs → slider-DMIOW38W.cjs} +2 -2
- package/dist/{slider-C2oEvRAS.cjs.map → slider-DMIOW38W.cjs.map} +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{spinner-DKgZemVU.cjs → spinner-ByMXQNV3.cjs} +2 -2
- package/dist/{spinner-DKgZemVU.cjs.map → spinner-ByMXQNV3.cjs.map} +1 -1
- package/dist/{spinner-Bh6XkC88.js → spinner-NFkGJJz1.js} +2 -2
- package/dist/{spinner-Bh6XkC88.js.map → spinner-NFkGJJz1.js.map} +1 -1
- package/dist/steps.cjs +1 -1
- package/dist/steps.js +1 -1
- package/dist/store.js +1 -1
- package/dist/{surface-DIIUamff.cjs → surface-BhCe8hp8.cjs} +2 -2
- package/dist/{surface-DIIUamff.cjs.map → surface-BhCe8hp8.cjs.map} +1 -1
- package/dist/{surface-DhiuAGb8.js → surface-C7jJaxVu.js} +2 -2
- package/dist/{surface-DhiuAGb8.js.map → surface-C7jJaxVu.js.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/{table-BrAoSQhN.cjs → table-BlwkABmS.cjs} +2 -2
- package/dist/{table-BrAoSQhN.cjs.map → table-BlwkABmS.cjs.map} +1 -1
- package/dist/{table-DSZ9kmUG.js → table-CmwIcTR5.js} +2 -2
- package/dist/{table-DSZ9kmUG.js.map → table-CmwIcTR5.js.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/{tabs-compatibility-B7aJnQ0X.js → tabs-compatibility-BdKslPOu.js} +2 -2
- package/dist/{tabs-compatibility-B7aJnQ0X.js.map → tabs-compatibility-BdKslPOu.js.map} +1 -1
- package/dist/{tabs-compatibility-Ck74XeID.cjs → tabs-compatibility-v0k0K0ID.cjs} +2 -2
- package/dist/{tabs-compatibility-Ck74XeID.cjs.map → tabs-compatibility-v0k0K0ID.cjs.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/{tailwind.mixin-CBu1BEQZ.cjs → tailwind.mixin-1kcW0BGm.cjs} +2 -2
- package/dist/{tailwind.mixin-CBu1BEQZ.cjs.map → tailwind.mixin-1kcW0BGm.cjs.map} +1 -1
- package/dist/{tailwind.mixin-DWhCm94g.js → tailwind.mixin-BHLwDiBj.js} +2 -2
- package/dist/{tailwind.mixin-DWhCm94g.js.map → tailwind.mixin-BHLwDiBj.js.map} +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-CGTMdhoF.cjs → textarea-CL3oExE7.cjs} +2 -2
- package/dist/{textarea-CGTMdhoF.cjs.map → textarea-CL3oExE7.cjs.map} +1 -1
- package/dist/{textarea-Bq0XdGaH.js → textarea-CfLyPiqF.js} +2 -2
- package/dist/{textarea-Bq0XdGaH.js.map → textarea-CfLyPiqF.js.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-button-CznhJ8g_.cjs → theme-button-D9DpgXlC.cjs} +2 -2
- package/dist/{theme-button-CznhJ8g_.cjs.map → theme-button-D9DpgXlC.cjs.map} +1 -1
- package/dist/{theme-button-DYoygmRA.js → theme-button-tekBpoTr.js} +2 -2
- package/dist/{theme-button-DYoygmRA.js.map → theme-button-tekBpoTr.js.map} +1 -1
- package/dist/theme-button.cjs +1 -1
- package/dist/theme-button.js +1 -1
- package/dist/theme.cjs +1 -1
- package/dist/theme.interface-C5Kj6WjD.js.map +1 -1
- package/dist/theme.interface-Xg5Zi46a.cjs.map +1 -1
- package/dist/theme.js +1 -1
- package/dist/{timezone-BCGcdasU.cjs → timezone-DIYE4qo4.cjs} +2 -2
- package/dist/{timezone-BCGcdasU.cjs.map → timezone-DIYE4qo4.cjs.map} +1 -1
- package/dist/{timezone-Co7gqqQt.js → timezone-rpn_HlNW.js} +3 -3
- package/dist/{timezone-Co7gqqQt.js.map → timezone-rpn_HlNW.js.map} +1 -1
- package/dist/{tooltip-DBuaAFmK.js → tooltip-C5DJ3omV.js} +2 -2
- package/dist/{tooltip-DBuaAFmK.js.map → tooltip-C5DJ3omV.js.map} +1 -1
- package/dist/{tooltip-Bqa0D34J.cjs → tooltip-apPpbYRb.cjs} +2 -2
- package/dist/{tooltip-Bqa0D34J.cjs.map → tooltip-apPpbYRb.cjs.map} +1 -1
- package/dist/tooltip.cjs +1 -1
- package/dist/tooltip.js +1 -1
- package/dist/{tree-CfE695gp.js → tree-B38B9Zts.js} +2 -2
- package/dist/{tree-CfE695gp.js.map → tree-B38B9Zts.js.map} +1 -1
- package/dist/{tree-CFeXYaJy.cjs → tree-DYOX-2CI.cjs} +2 -2
- package/dist/{tree-CFeXYaJy.cjs.map → tree-DYOX-2CI.cjs.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/tslib.es6-DgOcxv4s.cjs.map +1 -1
- package/dist/tslib.es6-ujVQHAQ4.js.map +1 -1
- package/dist/types.cjs.map +1 -1
- package/dist/types.js.map +1 -1
- package/dist/{typewriter-BZ_adVXB.js → typewriter-Cf1Bl0lI.js} +4 -4
- package/dist/{typewriter-BZ_adVXB.js.map → typewriter-Cf1Bl0lI.js.map} +1 -1
- package/dist/{typewriter-B6Jb22Pe.cjs → typewriter-D5sC3i_h.cjs} +2 -2
- package/dist/{typewriter-B6Jb22Pe.cjs.map → typewriter-D5sC3i_h.cjs.map} +1 -1
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/{typography-DvVeO1a_.cjs → typography-VDYy4xDQ.cjs} +2 -2
- package/dist/{typography-DvVeO1a_.cjs.map → typography-VDYy4xDQ.cjs.map} +1 -1
- package/dist/{typography-DI5RXpWs.js → typography-sm5Ne22S.js} +2 -2
- package/dist/{typography-DI5RXpWs.js.map → typography-sm5Ne22S.js.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/dist/{utils-jduntaQU.js → utils-03Coa8AW.js} +2 -2
- package/dist/{utils-jduntaQU.js.map → utils-03Coa8AW.js.map} +1 -1
- package/dist/{utils-BqFGvnN9.cjs → utils-C9nzOWpR.cjs} +2 -2
- package/dist/{utils-BqFGvnN9.cjs.map → utils-C9nzOWpR.cjs.map} +1 -1
- package/package.json +10 -10
- package/types/src/index.d.ts +2 -0
- package/types/src/select/select.d.ts +2 -0
- package/types/src/sheet/sheet.service.d.ts +128 -26
- package/types/src/store/selector-hook.d.ts +1 -1
package/ai/sheet.md
CHANGED
|
@@ -2,6 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
The sheet component provides a sliding panel overlay that can be used for forms, details views, or any content that needs to be displayed in a drawer-style interface.
|
|
4
4
|
|
|
5
|
+
**Important Note about Templates**: The sheet service now only accepts HTMLElement components. If you're using Lit's `html` template literals, you need to either:
|
|
6
|
+
1. Create a wrapper element and use innerHTML (for simple content)
|
|
7
|
+
2. Create a custom element class (for complex interactions)
|
|
8
|
+
3. Use the `render` function from Lit to render into a container element
|
|
9
|
+
|
|
5
10
|
```js
|
|
6
11
|
// Import Options
|
|
7
12
|
import { sheet } from '@mhmo91/schmancy'; // Legacy import
|
|
@@ -9,7 +14,7 @@ import { $sheet } from '@mhmo91/schmancy'; // New recommended import
|
|
|
9
14
|
|
|
10
15
|
// Sheet Service API
|
|
11
16
|
$sheet.open({
|
|
12
|
-
component: HTMLElement
|
|
17
|
+
component: HTMLElement, // Content to display (must be an HTMLElement)
|
|
13
18
|
uid?: string, // Unique identifier for the sheet
|
|
14
19
|
position?: 'side' | 'bottom', // Position (default: responsive based on screen size)
|
|
15
20
|
persist?: boolean, // Keep sheet in DOM after closing (default: false)
|
|
@@ -54,20 +59,22 @@ SchmancySheetPosition.Bottom // Bottom sheet (mobile)
|
|
|
54
59
|
|
|
55
60
|
// Examples
|
|
56
61
|
|
|
57
|
-
// 1. Basic Sheet with Form
|
|
62
|
+
// 1. Basic Sheet with Form - Using a wrapper element for template content
|
|
63
|
+
const formContent = document.createElement('div');
|
|
64
|
+
formContent.className = 'p-6';
|
|
65
|
+
formContent.innerHTML = `
|
|
66
|
+
<schmancy-typography type="headline" token="md" class="mb-4">
|
|
67
|
+
User Details
|
|
68
|
+
</schmancy-typography>
|
|
69
|
+
<schmancy-form>
|
|
70
|
+
<schmancy-input label="Name" value="John Doe"></schmancy-input>
|
|
71
|
+
<schmancy-input label="Email" value="john@example.com"></schmancy-input>
|
|
72
|
+
<schmancy-button type="submit">Save</schmancy-button>
|
|
73
|
+
</schmancy-form>
|
|
74
|
+
`;
|
|
75
|
+
|
|
58
76
|
$sheet.open({
|
|
59
|
-
component:
|
|
60
|
-
<div class="p-6">
|
|
61
|
-
<schmancy-typography type="headline" token="md" class="mb-4">
|
|
62
|
-
User Details
|
|
63
|
-
</schmancy-typography>
|
|
64
|
-
<schmancy-form>
|
|
65
|
-
<schmancy-input label="Name" value="John Doe"></schmancy-input>
|
|
66
|
-
<schmancy-input label="Email" value="john@example.com"></schmancy-input>
|
|
67
|
-
<schmancy-button type="submit">Save</schmancy-button>
|
|
68
|
-
</schmancy-form>
|
|
69
|
-
</div>
|
|
70
|
-
`,
|
|
77
|
+
component: formContent,
|
|
71
78
|
title: "Edit User"
|
|
72
79
|
});
|
|
73
80
|
|
|
@@ -80,18 +87,23 @@ $sheet.open({
|
|
|
80
87
|
title: "Custom Component"
|
|
81
88
|
});
|
|
82
89
|
|
|
83
|
-
// 3. Sheet with Lock (
|
|
90
|
+
// 3. Sheet with Lock (using Lit render for interactive content)
|
|
91
|
+
import { render, html } from 'lit';
|
|
92
|
+
|
|
93
|
+
const lockContent = document.createElement('div');
|
|
94
|
+
render(html`
|
|
95
|
+
<div class="p-6">
|
|
96
|
+
<schmancy-typography type="body" token="lg">
|
|
97
|
+
This action requires confirmation. Please complete the form.
|
|
98
|
+
</schmancy-typography>
|
|
99
|
+
<schmancy-button @click=${() => $sheet.dismiss()}>
|
|
100
|
+
Complete Action
|
|
101
|
+
</schmancy-button>
|
|
102
|
+
</div>
|
|
103
|
+
`, lockContent);
|
|
104
|
+
|
|
84
105
|
$sheet.open({
|
|
85
|
-
component:
|
|
86
|
-
<div class="p-6">
|
|
87
|
-
<schmancy-typography type="body" token="lg">
|
|
88
|
-
This action requires confirmation. Please complete the form.
|
|
89
|
-
</schmancy-typography>
|
|
90
|
-
<schmancy-button @click=${() => $sheet.dismiss()}>
|
|
91
|
-
Complete Action
|
|
92
|
-
</schmancy-button>
|
|
93
|
-
</div>
|
|
94
|
-
`,
|
|
106
|
+
component: lockContent,
|
|
95
107
|
lock: true,
|
|
96
108
|
title: "Required Action"
|
|
97
109
|
});
|
|
@@ -352,6 +364,56 @@ class WizardSheet extends LitElement {
|
|
|
352
364
|
}
|
|
353
365
|
}
|
|
354
366
|
|
|
367
|
+
// Template Handling Patterns
|
|
368
|
+
|
|
369
|
+
// Pattern 1: Simple content with innerHTML
|
|
370
|
+
function openSimpleSheet(content) {
|
|
371
|
+
const wrapper = document.createElement('div');
|
|
372
|
+
wrapper.innerHTML = content;
|
|
373
|
+
$sheet.open({ component: wrapper, title: "Simple Sheet" });
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
// Pattern 2: Using Lit's render for reactive content
|
|
377
|
+
function openReactiveSheet() {
|
|
378
|
+
const container = document.createElement('div');
|
|
379
|
+
const state = { count: 0 };
|
|
380
|
+
|
|
381
|
+
const updateContent = () => {
|
|
382
|
+
render(html`
|
|
383
|
+
<div class="p-6">
|
|
384
|
+
<p>Count: ${state.count}</p>
|
|
385
|
+
<schmancy-button @click=${() => {
|
|
386
|
+
state.count++;
|
|
387
|
+
updateContent(); // Re-render with new state
|
|
388
|
+
}}>
|
|
389
|
+
Increment
|
|
390
|
+
</schmancy-button>
|
|
391
|
+
</div>
|
|
392
|
+
`, container);
|
|
393
|
+
};
|
|
394
|
+
|
|
395
|
+
updateContent();
|
|
396
|
+
$sheet.open({ component: container, title: "Reactive Sheet" });
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
// Pattern 3: Custom Element (Recommended for complex components)
|
|
400
|
+
@customElement('my-sheet-content')
|
|
401
|
+
class MySheetContent extends LitElement {
|
|
402
|
+
@property() data = {};
|
|
403
|
+
|
|
404
|
+
render() {
|
|
405
|
+
return html`
|
|
406
|
+
<div class="p-6">
|
|
407
|
+
<!-- Your complex component logic here -->
|
|
408
|
+
</div>
|
|
409
|
+
`;
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
const myContent = document.createElement('my-sheet-content');
|
|
414
|
+
myContent.data = { /* your data */ };
|
|
415
|
+
$sheet.open({ component: myContent, title: "Complex Sheet" });
|
|
416
|
+
|
|
355
417
|
// Best Practices
|
|
356
418
|
|
|
357
419
|
// 1. Always provide a title for accessibility
|
package/dist/ai/sheet.md
CHANGED
|
@@ -2,6 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
The sheet component provides a sliding panel overlay that can be used for forms, details views, or any content that needs to be displayed in a drawer-style interface.
|
|
4
4
|
|
|
5
|
+
**Important Note about Templates**: The sheet service now only accepts HTMLElement components. If you're using Lit's `html` template literals, you need to either:
|
|
6
|
+
1. Create a wrapper element and use innerHTML (for simple content)
|
|
7
|
+
2. Create a custom element class (for complex interactions)
|
|
8
|
+
3. Use the `render` function from Lit to render into a container element
|
|
9
|
+
|
|
5
10
|
```js
|
|
6
11
|
// Import Options
|
|
7
12
|
import { sheet } from '@mhmo91/schmancy'; // Legacy import
|
|
@@ -9,7 +14,7 @@ import { $sheet } from '@mhmo91/schmancy'; // New recommended import
|
|
|
9
14
|
|
|
10
15
|
// Sheet Service API
|
|
11
16
|
$sheet.open({
|
|
12
|
-
component: HTMLElement
|
|
17
|
+
component: HTMLElement, // Content to display (must be an HTMLElement)
|
|
13
18
|
uid?: string, // Unique identifier for the sheet
|
|
14
19
|
position?: 'side' | 'bottom', // Position (default: responsive based on screen size)
|
|
15
20
|
persist?: boolean, // Keep sheet in DOM after closing (default: false)
|
|
@@ -54,20 +59,22 @@ SchmancySheetPosition.Bottom // Bottom sheet (mobile)
|
|
|
54
59
|
|
|
55
60
|
// Examples
|
|
56
61
|
|
|
57
|
-
// 1. Basic Sheet with Form
|
|
62
|
+
// 1. Basic Sheet with Form - Using a wrapper element for template content
|
|
63
|
+
const formContent = document.createElement('div');
|
|
64
|
+
formContent.className = 'p-6';
|
|
65
|
+
formContent.innerHTML = `
|
|
66
|
+
<schmancy-typography type="headline" token="md" class="mb-4">
|
|
67
|
+
User Details
|
|
68
|
+
</schmancy-typography>
|
|
69
|
+
<schmancy-form>
|
|
70
|
+
<schmancy-input label="Name" value="John Doe"></schmancy-input>
|
|
71
|
+
<schmancy-input label="Email" value="john@example.com"></schmancy-input>
|
|
72
|
+
<schmancy-button type="submit">Save</schmancy-button>
|
|
73
|
+
</schmancy-form>
|
|
74
|
+
`;
|
|
75
|
+
|
|
58
76
|
$sheet.open({
|
|
59
|
-
component:
|
|
60
|
-
<div class="p-6">
|
|
61
|
-
<schmancy-typography type="headline" token="md" class="mb-4">
|
|
62
|
-
User Details
|
|
63
|
-
</schmancy-typography>
|
|
64
|
-
<schmancy-form>
|
|
65
|
-
<schmancy-input label="Name" value="John Doe"></schmancy-input>
|
|
66
|
-
<schmancy-input label="Email" value="john@example.com"></schmancy-input>
|
|
67
|
-
<schmancy-button type="submit">Save</schmancy-button>
|
|
68
|
-
</schmancy-form>
|
|
69
|
-
</div>
|
|
70
|
-
`,
|
|
77
|
+
component: formContent,
|
|
71
78
|
title: "Edit User"
|
|
72
79
|
});
|
|
73
80
|
|
|
@@ -80,18 +87,23 @@ $sheet.open({
|
|
|
80
87
|
title: "Custom Component"
|
|
81
88
|
});
|
|
82
89
|
|
|
83
|
-
// 3. Sheet with Lock (
|
|
90
|
+
// 3. Sheet with Lock (using Lit render for interactive content)
|
|
91
|
+
import { render, html } from 'lit';
|
|
92
|
+
|
|
93
|
+
const lockContent = document.createElement('div');
|
|
94
|
+
render(html`
|
|
95
|
+
<div class="p-6">
|
|
96
|
+
<schmancy-typography type="body" token="lg">
|
|
97
|
+
This action requires confirmation. Please complete the form.
|
|
98
|
+
</schmancy-typography>
|
|
99
|
+
<schmancy-button @click=${() => $sheet.dismiss()}>
|
|
100
|
+
Complete Action
|
|
101
|
+
</schmancy-button>
|
|
102
|
+
</div>
|
|
103
|
+
`, lockContent);
|
|
104
|
+
|
|
84
105
|
$sheet.open({
|
|
85
|
-
component:
|
|
86
|
-
<div class="p-6">
|
|
87
|
-
<schmancy-typography type="body" token="lg">
|
|
88
|
-
This action requires confirmation. Please complete the form.
|
|
89
|
-
</schmancy-typography>
|
|
90
|
-
<schmancy-button @click=${() => $sheet.dismiss()}>
|
|
91
|
-
Complete Action
|
|
92
|
-
</schmancy-button>
|
|
93
|
-
</div>
|
|
94
|
-
`,
|
|
106
|
+
component: lockContent,
|
|
95
107
|
lock: true,
|
|
96
108
|
title: "Required Action"
|
|
97
109
|
});
|
|
@@ -352,6 +364,56 @@ class WizardSheet extends LitElement {
|
|
|
352
364
|
}
|
|
353
365
|
}
|
|
354
366
|
|
|
367
|
+
// Template Handling Patterns
|
|
368
|
+
|
|
369
|
+
// Pattern 1: Simple content with innerHTML
|
|
370
|
+
function openSimpleSheet(content) {
|
|
371
|
+
const wrapper = document.createElement('div');
|
|
372
|
+
wrapper.innerHTML = content;
|
|
373
|
+
$sheet.open({ component: wrapper, title: "Simple Sheet" });
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
// Pattern 2: Using Lit's render for reactive content
|
|
377
|
+
function openReactiveSheet() {
|
|
378
|
+
const container = document.createElement('div');
|
|
379
|
+
const state = { count: 0 };
|
|
380
|
+
|
|
381
|
+
const updateContent = () => {
|
|
382
|
+
render(html`
|
|
383
|
+
<div class="p-6">
|
|
384
|
+
<p>Count: ${state.count}</p>
|
|
385
|
+
<schmancy-button @click=${() => {
|
|
386
|
+
state.count++;
|
|
387
|
+
updateContent(); // Re-render with new state
|
|
388
|
+
}}>
|
|
389
|
+
Increment
|
|
390
|
+
</schmancy-button>
|
|
391
|
+
</div>
|
|
392
|
+
`, container);
|
|
393
|
+
};
|
|
394
|
+
|
|
395
|
+
updateContent();
|
|
396
|
+
$sheet.open({ component: container, title: "Reactive Sheet" });
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
// Pattern 3: Custom Element (Recommended for complex components)
|
|
400
|
+
@customElement('my-sheet-content')
|
|
401
|
+
class MySheetContent extends LitElement {
|
|
402
|
+
@property() data = {};
|
|
403
|
+
|
|
404
|
+
render() {
|
|
405
|
+
return html`
|
|
406
|
+
<div class="p-6">
|
|
407
|
+
<!-- Your complex component logic here -->
|
|
408
|
+
</div>
|
|
409
|
+
`;
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
const myContent = document.createElement('my-sheet-content');
|
|
414
|
+
myContent.data = { /* your data */ };
|
|
415
|
+
$sheet.open({ component: myContent, title: "Complex Sheet" });
|
|
416
|
+
|
|
355
417
|
// Best Practices
|
|
356
418
|
|
|
357
419
|
// 1. Always provide a title for accessibility
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { concat as u, interval as g, startWith as y, filter as h, take as d, fromEvent as f, throttleTime as w, map as b, distinctUntilChanged as $, tap as c } from "rxjs";
|
|
2
2
|
import "lit/directives/class-map.js";
|
|
3
3
|
import "lit/directives/style-map.js";
|
|
4
|
-
import { $ as x } from "./litElement.mixin-
|
|
5
|
-
import "./tailwind.mixin-
|
|
4
|
+
import { $ as x } from "./litElement.mixin-Cn8IAazz.js";
|
|
5
|
+
import "./tailwind.mixin-BHLwDiBj.js";
|
|
6
6
|
import { property as a, queryAssignedNodes as S, query as m, customElement as Z } from "lit/decorators.js";
|
|
7
7
|
import { css as v, html as A } from "lit";
|
|
8
8
|
var E = Object.defineProperty, O = Object.getOwnPropertyDescriptor, e = (r, s, n, i) => {
|
|
@@ -72,4 +72,4 @@ let t = class extends x(v`
|
|
|
72
72
|
}
|
|
73
73
|
};
|
|
74
74
|
e([a({ type: String })], t.prototype, "ease", 2), e([a({ type: Number })], t.prototype, "delay", 2), e([a({ type: Number })], t.prototype, "stagger", 2), e([a({ type: Number })], t.prototype, "duration", 2), e([a({ type: Array })], t.prototype, "scale", 2), e([a({ type: Array })], t.prototype, "opacity", 2), e([a({ type: Array })], t.prototype, "translateX", 2), e([a({ type: Array })], t.prototype, "translateY", 2), e([a({ type: Array })], t.prototype, "translateZ", 2), e([a({ type: Array })], t.prototype, "rotateZ", 2), e([a({ type: Boolean })], t.prototype, "resetOnScroll", 2), e([S()], t.prototype, "defaultSlot", 2), e([m(".letters")], t.prototype, "letters", 2), e([m(".ml7")], t.prototype, "ml7", 2), t = e([Z("schmancy-animated-text")], t);
|
|
75
|
-
//# sourceMappingURL=animated-text-
|
|
75
|
+
//# sourceMappingURL=animated-text-AbNgT7ie.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"animated-text-DcLpvyCq.js","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\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).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"animated-text-AbNgT7ie.js","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\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).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","constructor","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","render","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";const e=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const h=require("./litElement.mixin-
|
|
1
|
+
"use strict";const e=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const h=require("./litElement.mixin-Cs3zx2X6.cjs");require("./tailwind.mixin-1kcW0BGm.cjs");const r=require("lit/decorators.js"),c=require("lit");var d=Object.defineProperty,u=Object.getOwnPropertyDescriptor,s=(i,a,p,n)=>{for(var l,o=n>1?void 0:n?u(a,p):a,y=i.length-1;y>=0;y--)(l=i[y])&&(o=(n?l(a,p,o):l(o))||o);return n&&o&&d(a,p,o),o};let t=class extends h.$LitElement(c.css`
|
|
2
2
|
:host {
|
|
3
3
|
font-family: inherit;
|
|
4
4
|
display: block;
|
|
@@ -34,4 +34,4 @@
|
|
|
34
34
|
</span>
|
|
35
35
|
</span>
|
|
36
36
|
`}};s([r.property({type:String})],t.prototype,"ease",2),s([r.property({type:Number})],t.prototype,"delay",2),s([r.property({type:Number})],t.prototype,"stagger",2),s([r.property({type:Number})],t.prototype,"duration",2),s([r.property({type:Array})],t.prototype,"scale",2),s([r.property({type:Array})],t.prototype,"opacity",2),s([r.property({type:Array})],t.prototype,"translateX",2),s([r.property({type:Array})],t.prototype,"translateY",2),s([r.property({type:Array})],t.prototype,"translateZ",2),s([r.property({type:Array})],t.prototype,"rotateZ",2),s([r.property({type:Boolean})],t.prototype,"resetOnScroll",2),s([r.queryAssignedNodes()],t.prototype,"defaultSlot",2),s([r.query(".letters")],t.prototype,"letters",2),s([r.query(".ml7")],t.prototype,"ml7",2),t=s([r.customElement("schmancy-animated-text")],t);
|
|
37
|
-
//# sourceMappingURL=animated-text-
|
|
37
|
+
//# sourceMappingURL=animated-text-CYmUxmlv.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"animated-text-BitOmeE1.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\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).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"animated-text-CYmUxmlv.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\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).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","constructor","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","render","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
|
package/dist/animated-text.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";require("./animated-text-
|
|
1
|
+
"use strict";require("./animated-text-CYmUxmlv.cjs");
|
|
2
2
|
//# sourceMappingURL=animated-text.cjs.map
|
package/dist/animated-text.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import "./animated-text-
|
|
1
|
+
import "./animated-text-AbNgT7ie.js";
|
|
2
2
|
//# sourceMappingURL=animated-text.js.map
|
package/dist/area.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./area.component-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./area.component-B1Lmmsuk.cjs"),e=require("./utils-C9nzOWpR.cjs");exports.FINDING_MORTIES=t.FINDING_MORTIES,exports.HERE_RICKY=t.HERE_RICKY,exports.HISTORY_STRATEGY=t.HISTORY_STRATEGY,Object.defineProperty(exports,"SchmancyArea",{enumerable:!0,get:()=>t.SchmancyArea}),exports.area=t.area,exports.routerHistory=t.routerHistory,exports.buildQueryString=e.buildQueryString,exports.compareActiveRoutes=e.compareActiveRoutes,exports.compareCustomElementConstructors=e.compareCustomElementConstructors,exports.compareRouteActions=e.compareRouteActions,exports.createRouteCacheKey=e.createRouteCacheKey,exports.debounce=e.debounce,exports.decodeRouteState=e.decodeRouteState,exports.deepMerge=e.deepMerge,exports.encodeRouteState=e.encodeRouteState,exports.extractQueryParams=e.extractQueryParams,exports.getTagName=e.getTagName,exports.isObject=e.isObject,exports.normalizeTagName=e.normalizeTagName,exports.sanitizeRouteState=e.sanitizeRouteState;
|
|
2
2
|
//# sourceMappingURL=area.cjs.map
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
"use strict";const r=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const b=require("./litElement.mixin-
|
|
1
|
+
"use strict";const r=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const b=require("./litElement.mixin-Cs3zx2X6.cjs");require("./tailwind.mixin-1kcW0BGm.cjs");const y=require("lit/decorators.js"),S=require("lit"),O=require("./index-DyJ0oDpR.cjs"),g=new r.Subject,w="FINDING_MORTIES",E="HERE_RICKY",d=new WeakMap;class l{constructor(){this.prettyURL=!1,this.mode="HISTORY",this.request=new r.ReplaySubject(1),this.current=new Map,this.$current=new r.ReplaySubject(1),this.enableHistoryMode=!0,this.findingMortiesEvent=new CustomEvent(w),this.disposed=!1,this.isProcessingPopstate=!1,this.$current.next(this.current),this.$current.subscribe(t=>{this.disposed||t.forEach((e,s)=>{this.getOrCreateAreaSubject(s).next(e)})}),this.initializeFromBrowserState()}get areaSubjects(){let t=d.get(this);return t||(t=new Map,d.set(this,t)),t}initializeFromBrowserState(){try{const t=history.state;t&&t.schmancyAreas&&(Object.entries(t.schmancyAreas).forEach(([e,s])=>{this.current.set(e,s)}),this.$current.next(this.current))}catch{}}getOrCreateAreaSubject(t){let e=this.areaSubjects.get(t);if(!e||e.closed){e=new r.ReplaySubject(1),this.areaSubjects.set(t,e);const s=this.current.get(t);s&&e.next({...s,state:s.state||{},params:s.params||{},props:s.props||{}})}return e}on(t,e=!1){if(!t)throw new Error("Area name is required");const s=this.getOrCreateAreaSubject(t).asObservable().pipe(r.distinctUntilChanged((n,o)=>n.component===o.component&&JSON.stringify(n.state)===JSON.stringify(o.state)&&JSON.stringify(n.params)===JSON.stringify(o.params)),r.shareReplay(1));return e?s.pipe(r.skip(1)):s}all(t=!1){const e=this.$current.asObservable().pipe(r.shareReplay(1));return t?e.pipe(r.skip(1)):e}getState(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.state),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}params(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.params),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}param(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.params(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}props(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.props),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}prop(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.props(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}find(){return r.zip([r.fromEvent(window,E).pipe(r.map(t=>t.detail),r.bufferTime(0)),r.of(1).pipe(r.tap(()=>window.dispatchEvent(this.findingMortiesEvent)))]).pipe(r.map(([t])=>t),r.timeout(1),r.catchError(()=>r.EMPTY))}push(t){if(!t.area)throw new Error("Area is required for route action");if(this.isProcessingPopstate)return;const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"programmatic"};this.enableHistoryMode&&g.next(e),this.request.next(e),this.dispatchAreaEvent(e.area,e)}_updateFromBrowser(t){const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"browser"};this.isProcessingPopstate=!0,this.request.next(e),this.isProcessingPopstate=!1}_updateBrowserHistory(t,e,s,n){if(this.enableHistoryMode)try{const o=history.state||{},i=o.schmancyAreas||{},c={component:e.component,area:e.area};e.state&&Object.keys(e.state).length>0&&(c.state=e.state),e.params&&Object.keys(e.params).length>0&&(c.params=e.params),e.props&&Object.keys(e.props).length>0&&(c.props=e.props),i[t]=c;const m={...o,schmancyAreas:i},u=this.createCleanURL(i,n);s==="replace"||s==="pop"?history.replaceState(m,"",u):s!=="push"&&s||history.pushState(m,"",u)}catch{}}createCleanURL(t,e){let s="";if(e!==!0){const n=new URLSearchParams(location.search);Array.isArray(e)&&e.forEach(o=>n.delete(o)),s=n.toString(),s=s?`?${s}`:""}if(this.prettyURL){const n=t.main;if(n){let o=`/${n.component}`;const i=new URLSearchParams(s);n.params&&Object.entries(n.params).forEach(([m,u])=>{typeof u!="string"&&typeof u!="number"||i.set(m,String(u))});const c=i.toString();return o+(c?`?${c}`:"")}}try{const n={};return Object.entries(t).forEach(([o,i])=>{const c={component:i.component};i.state&&Object.keys(i.state).length>0&&(c.state=i.state),i.params&&Object.keys(i.params).length>0&&(c.params=i.params),i.props&&Object.keys(i.props).length>0&&(c.props=i.props),n[o]=c}),`/${encodeURIComponent(JSON.stringify(n))}${s}`}catch{return location.pathname}}restoreFromBrowserState(t){try{if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}parseStateFromURL(){const t=location.pathname.split("/").pop();if(!t)return{};try{const e=decodeURIComponent(t),s=JSON.parse(e);if(typeof s=="object"&&s!==null)return s}catch{}return{}}dispatchAreaEvent(t,e){const s=new CustomEvent(`schmancy-area-${t}-changed`,{detail:{area:t,component:e.component,state:e.state,params:e.params,props:e.props,historyStrategy:e.historyStrategy},bubbles:!0,composed:!0});window.dispatchEvent(s)}pop(t){if(!t)throw new Error("Area name is required");if(this.current.delete(t),this.$current.next(this.current),this.enableHistoryMode)try{const e=history.state||{},s={...e.schmancyAreas||{}};delete s[t];const n={...e,schmancyAreas:s},o=this.createCleanURL(s);history.replaceState(n,"",o)}catch{}}clear(){this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.current.clear(),this.$current.next(this.current),this.enableHistoryMode&&history.replaceState({schmancyAreas:{}},"",`/${location.search}`)}dispose(){this.disposed||(this.disposed=!0,this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.request.complete(),this.$current.complete(),g.complete(),this.current.clear(),d.delete(this))}static getInstance(){return l.instance||(l.instance=new l),l.instance}get state(){try{const t=history.state;if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}hasArea(t){return this.current.has(t)}getActiveAreas(){return Array.from(this.current.keys())}getRoute(t){return this.current.get(t)}}const p=l.getInstance();typeof window<"u"&&window.addEventListener("unload",()=>{p.dispose()});var h=(a=>(a.push="push",a.replace="replace",a.pop="pop",a.silent="silent",a))(h||{}),A=Object.defineProperty,C=Object.getOwnPropertyDescriptor,f=(a,t,e,s)=>{for(var n,o=s>1?void 0:s?C(t,e):t,i=a.length-1;i>=0;i--)(n=a[i])&&(o=(s?n(t,e,o):n(o))||o);return s&&o&&A(t,e,o),o};exports.SchmancyArea=class extends b.$LitElement(S.css`
|
|
2
2
|
:host {
|
|
3
3
|
position: relative;
|
|
4
4
|
display: block;
|
|
5
5
|
inset: 0;
|
|
6
6
|
}
|
|
7
7
|
`){getComponentFromPathname(a,t){return r.of(a).pipe(r.map(e=>e.split("/").pop()??""),r.map(e=>{try{return JSON.parse(decodeURIComponent(e))}catch{return{}}}),r.map(e=>e[this.name]),r.map(e=>!e&&this.default?{component:this.default,state:void 0,params:void 0}:e),r.filter(e=>O.libExports.isPresent(e)),r.map(e=>({area:this.name,component:e.component??this.default,state:e.state||{},params:e.params||{},historyStrategy:t})),r.catchError(e=>this.default?r.of({area:this.name,component:this.default,historyStrategy:t,state:{},params:{},props:{}}):r.EMPTY))}getComponentFromBrowserState(a){try{const t=a.state;if(t&&t.schmancyAreas&&t.schmancyAreas[this.name]){const e=t.schmancyAreas[this.name];return{area:this.name,component:e.component,state:e.state||{},params:e.params||{},historyStrategy:h.silent,_source:"browser"}}}catch{}return null}firstUpdated(){if(!this.name)throw new Error("Area name or default component not set");r.merge(r.of(location.pathname).pipe(r.switchMap(a=>this.getComponentFromPathname(a,h.silent)),r.take(1),r.tap(a=>{})),p.request.pipe(r.filter(({area:a})=>a===this.name),r.tap(a=>{})),r.fromEvent(window,"popstate").pipe(r.switchMap(a=>{const t=a.state?.schmancyAreas?.[this.name],e=a.target.location.pathname;return t?r.of({area:this.name,component:t.component,state:t.state||{},params:t.params||{},historyStrategy:h.silent}):this.getComponentFromPathname(e,h.silent).pipe(r.switchMap(s=>s.component||this.default?r.of(s):r.of({area:this.name,component:"",state:{},params:{},historyStrategy:h.silent})))}),r.tap(a=>{})),p.$current.pipe(r.map(a=>!a.has(this.name)),r.distinctUntilChanged(),r.filter(a=>a),r.map(()=>({area:this.name,component:this.default||"",state:{},params:{},historyStrategy:h.silent})),r.tap(()=>{}))).pipe(r.filter(a=>a.component!==null&&a.component!==void 0),r.takeUntil(this.disconnecting),r.distinctUntilChanged((a,t)=>{let e="",s="";typeof a.component=="function"?e=a.component.name||a.component.toString():typeof a.component=="string"&&(e=a.component),typeof t.component=="function"?s=t.component.name||t.component.toString():typeof t.component=="string"&&(s=t.component);const n=m=>m?.replaceAll("-","").toLowerCase(),o=n(e)===n(s),i=JSON.stringify(a.params||{})===JSON.stringify(t.params||{}),c=JSON.stringify(a.state||{})===JSON.stringify(t.state||{});return o&&i&&c})).pipe(r.switchMap(a=>{const t=a.component;return t instanceof Promise?r.from(t).pipe(r.map(e=>({component:e.exports?.default||e.default,route:a})),r.catchError(e=>r.EMPTY)):r.of({component:t,route:a})}),r.map(({component:a,route:t})=>{let e=null;return e=a===""?null:typeof a=="string"?document.createElement(a):a instanceof HTMLElement?a:typeof a=="function"?new a:a,e&&t.params&&Object.entries(t.params).forEach(([s,n])=>{e[s]=n}),e&&t.state&&(e.state=t.state),{component:e,route:t}}),r.tap(({component:a,route:t})=>{this.updateDOM(a),this.updateInternalState(t,a),this.updateBrowserHistory(t,a)}),r.catchError(a=>r.EMPTY),r.takeUntil(this.disconnecting)).subscribe({error:a=>{}})}updateDOM(a){const t=this.shadowRoot?.children[0],e=!!t;t?.remove(),a&&(a.classList.add("opacity-0"),this.shadowRoot?.append(a),a.animate([{opacity:0},{opacity:1}],{duration:e?150:100,easing:"cubic-bezier(0.25, 0.8, 0.25, 1)",fill:"forwards"}))}updateInternalState(a,t){if(!t)return;const e={component:t.tagName.toLowerCase(),state:a.state||{},area:this.name,params:a.params||{}};p.current.set(this.name,e),p.$current.next(p.current)}updateBrowserHistory(a,t){if(!p.enableHistoryMode||!t)return;const e={component:t.tagName.toLowerCase(),state:a.state||{},area:this.name,params:a.params||{}};p._updateBrowserHistory(this.name,e,a.historyStrategy,a.clearQueryParams)}newPath(a,t){const e=location.pathname.split("/").pop();let s={};try{s=e?JSON.parse(decodeURIComponent(e)):{}}catch{s={}}t.state=t.state??{};const n=t.clearQueryParams?this.queryParamClear(t.clearQueryParams):document.location.search;return encodeURIComponent(JSON.stringify({...s,[this.name]:{component:a.toLowerCase(),state:t.state,params:t.params}})).concat(`${n}`)}queryParamClear(a){if(!a)return"";const t=new URLSearchParams(location.search);return a===!0?"":(a.forEach(e=>t.delete(e)),t.toString()===""?"":`?${t.toString()}`)}render(){return S.html` <slot> </slot> `}},f([y.property()],exports.SchmancyArea.prototype,"name",2),f([y.property()],exports.SchmancyArea.prototype,"default",2),exports.SchmancyArea=f([y.customElement("schmancy-area")],exports.SchmancyArea),exports.FINDING_MORTIES=w,exports.HERE_RICKY=E,exports.HISTORY_STRATEGY=h,exports.area=p,exports.routerHistory=g;
|
|
8
|
-
//# sourceMappingURL=area.component-
|
|
8
|
+
//# sourceMappingURL=area.component-B1Lmmsuk.cjs.map
|