@mhmo91/schmancy 0.4.93 → 0.4.95
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-Dqrad7cv.cjs → animated-text-DGYJHeql.cjs} +2 -2
- package/dist/{animated-text-Dqrad7cv.cjs.map → animated-text-DGYJHeql.cjs.map} +1 -1
- package/dist/{animated-text-mNos9Gw8.js → animated-text-M3MwaJkg.js} +3 -3
- package/dist/{animated-text-mNos9Gw8.js.map → animated-text-M3MwaJkg.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.js +1 -1
- package/dist/{autocomplete-CMxXFeC_.js → autocomplete-C_A62ItA.js} +3 -3
- package/dist/{autocomplete-CMxXFeC_.js.map → autocomplete-C_A62ItA.js.map} +1 -1
- package/dist/{autocomplete-CzYbBt-K.cjs → autocomplete-DjqSPfKI.cjs} +2 -2
- package/dist/{autocomplete-CzYbBt-K.cjs.map → autocomplete-DjqSPfKI.cjs.map} +1 -1
- package/dist/autocomplete.cjs +1 -1
- package/dist/autocomplete.js +1 -1
- package/dist/{avatar-CGGPvamo.cjs → avatar-CqnhaXXV.cjs} +2 -2
- package/dist/{avatar-CGGPvamo.cjs.map → avatar-CqnhaXXV.cjs.map} +1 -1
- package/dist/{avatar-CH-EctMv.js → avatar-Dzo_bHWz.js} +48 -48
- package/dist/{avatar-CH-EctMv.js.map → avatar-Dzo_bHWz.js.map} +1 -1
- package/dist/badge.cjs +1 -1
- package/dist/badge.js +1 -1
- package/dist/{boat-xekVVZab.js → boat-B1ek034g.js} +2 -2
- package/dist/{boat-xekVVZab.js.map → boat-B1ek034g.js.map} +1 -1
- package/dist/{boat-feSRWu7P.cjs → boat-C2tDxZ6q.cjs} +2 -2
- package/dist/{boat-feSRWu7P.cjs.map → boat-C2tDxZ6q.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-DwBANLb6.cjs → checkbox-03EPnFAK.cjs} +2 -2
- package/dist/{checkbox-DwBANLb6.cjs.map → checkbox-03EPnFAK.cjs.map} +1 -1
- package/dist/{checkbox-DTfIF2XH.js → checkbox-eulWj2PZ.js} +2 -2
- package/dist/{checkbox-DTfIF2XH.js.map → checkbox-eulWj2PZ.js.map} +1 -1
- package/dist/checkbox.cjs +1 -1
- package/dist/checkbox.js +1 -1
- package/dist/{chips-DORDPg5b.cjs → chips-6yP6k7JE.cjs} +108 -30
- package/dist/chips-6yP6k7JE.cjs.map +1 -0
- package/dist/{chips-7TbOS1By.js → chips-BdwPstWQ.js} +159 -81
- package/dist/chips-BdwPstWQ.js.map +1 -0
- package/dist/chips.cjs +1 -1
- package/dist/chips.js +1 -1
- package/dist/code-highlight.cjs +1 -1
- package/dist/code-highlight.js +1 -1
- package/dist/{code-preview-DWDE2pUe.js → code-preview-BbTWQ55v.js} +2 -2
- package/dist/{code-preview-DWDE2pUe.js.map → code-preview-BbTWQ55v.js.map} +1 -1
- package/dist/{code-preview-DqFuxCjV.cjs → code-preview-CMItpsiu.cjs} +2 -2
- package/dist/{code-preview-DqFuxCjV.cjs.map → code-preview-CMItpsiu.cjs.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-s2EHTGQM.js → date-range-DPUakZPo.js} +3 -3
- package/dist/{date-range-s2EHTGQM.js.map → date-range-DPUakZPo.js.map} +1 -1
- package/dist/{date-range-DwdO0vNv.cjs → date-range-DwRTfoCX.cjs} +2 -2
- package/dist/{date-range-DwdO0vNv.cjs.map → date-range-DwRTfoCX.cjs.map} +1 -1
- package/dist/{date-range-inline-yYh4Uw-k.js → date-range-inline-BDY8ta-_.js} +3 -3
- package/dist/{date-range-inline-yYh4Uw-k.js.map → date-range-inline-BDY8ta-_.js.map} +1 -1
- package/dist/{date-range-inline-B1WaAPY6.cjs → date-range-inline-Cbsauu_G.cjs} +2 -2
- package/dist/{date-range-inline-B1WaAPY6.cjs.map → date-range-inline-Cbsauu_G.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-l2gPaJoH.cjs → delay-C-TMlc4W.cjs} +2 -2
- package/dist/{delay-l2gPaJoH.cjs.map → delay-C-TMlc4W.cjs.map} +1 -1
- package/dist/{delay-D19Mpit_.js → delay-DcedOFSN.js} +2 -2
- package/dist/{delay-D19Mpit_.js.map → delay-DcedOFSN.js.map} +1 -1
- package/dist/delay.cjs +1 -1
- package/dist/delay.js +1 -1
- package/dist/{details-CEu4oDP7.js → details-D0KugZBN.js} +2 -2
- package/dist/{details-CEu4oDP7.js.map → details-D0KugZBN.js.map} +1 -1
- package/dist/{details-LNuoItTO.cjs → details-Z8HOTTt1.cjs} +2 -2
- package/dist/{details-LNuoItTO.cjs.map → details-Z8HOTTt1.cjs.map} +1 -1
- package/dist/details.cjs +1 -1
- package/dist/details.js +1 -1
- package/dist/{dialog-content-6wVlm9RL.cjs → dialog-content-BkEwkThE.cjs} +2 -2
- package/dist/{dialog-content-6wVlm9RL.cjs.map → dialog-content-BkEwkThE.cjs.map} +1 -1
- package/dist/{dialog-content-CQ3Xi4_b.js → dialog-content-KRxANHR0.js} +3 -3
- package/dist/{dialog-content-CQ3Xi4_b.js.map → dialog-content-KRxANHR0.js.map} +1 -1
- package/dist/dialog.cjs +1 -1
- package/dist/dialog.js +1 -1
- package/dist/{divider-5OCZNBJ7.js → divider-BGkqRkQl.js} +3 -3
- package/dist/{divider-5OCZNBJ7.js.map → divider-BGkqRkQl.js.map} +1 -1
- package/dist/{divider-auzbAyaR.cjs → divider-lCsVNqB-.cjs} +2 -2
- package/dist/{divider-auzbAyaR.cjs.map → divider-lCsVNqB-.cjs.map} +1 -1
- package/dist/divider.cjs +1 -1
- package/dist/divider.js +1 -1
- package/dist/{dropdown-content-BLZviV1z.js → dropdown-content-Bi8BCmaN.js} +3 -3
- package/dist/{dropdown-content-BLZviV1z.js.map → dropdown-content-Bi8BCmaN.js.map} +1 -1
- package/dist/{dropdown-content-BI541LSK.cjs → dropdown-content-OwW8ib3f.cjs} +2 -2
- package/dist/{dropdown-content-BI541LSK.cjs.map → dropdown-content-OwW8ib3f.cjs.map} +1 -1
- package/dist/dropdown.cjs +1 -1
- package/dist/dropdown.js +1 -1
- package/dist/{email-recipients-JeGKXcBj.js → email-recipients-BR7vUItj.js} +5 -5
- package/dist/{email-recipients-JeGKXcBj.js.map → email-recipients-BR7vUItj.js.map} +1 -1
- package/dist/{email-recipients-DizBUcJ2.cjs → email-recipients-pX6WGwHT.cjs} +2 -2
- package/dist/{email-recipients-DizBUcJ2.cjs.map → email-recipients-pX6WGwHT.cjs.map} +1 -1
- package/dist/extra.cjs +1 -1
- package/dist/extra.js +1 -1
- package/dist/{flex-ro_7y02P.js → flex-Bm7IDK0c.js} +2 -2
- package/dist/{flex-ro_7y02P.js.map → flex-Bm7IDK0c.js.map} +1 -1
- package/dist/{flex-BN7HdoGW.cjs → flex-DBNIiqdE.cjs} +2 -2
- package/dist/{flex-BN7HdoGW.cjs.map → flex-DBNIiqdE.cjs.map} +1 -1
- package/dist/{form-DT6f2KNH.cjs → form-BX4qk01B.cjs} +2 -2
- package/dist/{form-DT6f2KNH.cjs.map → form-BX4qk01B.cjs.map} +1 -1
- package/dist/{form-BqGTSZpr.js → form-eGKshh3r.js} +2 -2
- package/dist/{form-BqGTSZpr.js.map → form-eGKshh3r.js.map} +1 -1
- package/dist/form.cjs +1 -1
- package/dist/form.js +1 -1
- package/dist/{formField.mixin-DtegNyKv.js → formField.mixin-CLmHIFjr.js} +2 -2
- package/dist/{formField.mixin-DtegNyKv.js.map → formField.mixin-CLmHIFjr.js.map} +1 -1
- package/dist/{formField.mixin-CSy0dZ7Q.cjs → formField.mixin-DgYFicXI.cjs} +2 -2
- package/dist/{formField.mixin-CSy0dZ7Q.cjs.map → formField.mixin-DgYFicXI.cjs.map} +1 -1
- package/dist/{icon-GaL2G_1M.cjs → icon-BJ_liaGU.cjs} +2 -2
- package/dist/{icon-GaL2G_1M.cjs.map → icon-BJ_liaGU.cjs.map} +1 -1
- package/dist/{icon-CSxxuGxN.js → icon-Do3Co1Pc.js} +2 -2
- package/dist/{icon-CSxxuGxN.js.map → icon-Do3Co1Pc.js.map} +1 -1
- package/dist/{icon-button-B0jLowAy.js → icon-button-CbdmA0dk.js} +3 -3
- package/dist/{icon-button-B0jLowAy.js.map → icon-button-CbdmA0dk.js.map} +1 -1
- package/dist/{icon-button-DkvwZOHF.cjs → icon-button-CxULEtpN.cjs} +2 -2
- package/dist/{icon-button-DkvwZOHF.cjs.map → icon-button-CxULEtpN.cjs.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 +47 -47
- package/dist/{input-D0c-WhDi.js → input-DTGI9Hn0.js} +3 -3
- package/dist/{input-D0c-WhDi.js.map → input-DTGI9Hn0.js.map} +1 -1
- package/dist/{input-fPWOjQgP.cjs → input-DeYr4GOx.cjs} +2 -2
- package/dist/{input-fPWOjQgP.cjs.map → input-DeYr4GOx.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-3Ity7MFT.js → list-D7R2NDV7.js} +2 -2
- package/dist/{list-3Ity7MFT.js.map → list-D7R2NDV7.js.map} +1 -1
- package/dist/{list-CbXXjBUM.cjs → list-DQxUt3w0.cjs} +2 -2
- package/dist/{list-CbXXjBUM.cjs.map → list-DQxUt3w0.cjs.map} +1 -1
- package/dist/list.cjs +1 -1
- package/dist/list.js +1 -1
- package/dist/{litElement.mixin-DFG5Ckp7.cjs → litElement.mixin-C1UlW2yv.cjs} +2 -2
- package/dist/{litElement.mixin-DFG5Ckp7.cjs.map → litElement.mixin-C1UlW2yv.cjs.map} +1 -1
- package/dist/{litElement.mixin-Efwm8boA.js → litElement.mixin-D379V_-T.js} +2 -2
- package/dist/{litElement.mixin-Efwm8boA.js.map → litElement.mixin-D379V_-T.js.map} +1 -1
- package/dist/mailbox.cjs +1 -1
- package/dist/mailbox.js +1 -1
- package/dist/{map-BCQwFMpm.js → map-C16DoQah.js} +2 -2
- package/dist/{map-BCQwFMpm.js.map → map-C16DoQah.js.map} +1 -1
- package/dist/{map-DeRVVjHa.cjs → map-Dv-rxb2t.cjs} +2 -2
- package/dist/{map-DeRVVjHa.cjs.map → map-Dv-rxb2t.cjs.map} +1 -1
- package/dist/map.cjs +1 -1
- package/dist/map.js +1 -1
- package/dist/{media-nVQjNoX7.js → media-DruoNHFP.js} +62 -108
- package/dist/media-DruoNHFP.js.map +1 -0
- package/dist/{media-CL9LNHic.cjs → media-bbZayaf9.cjs} +29 -78
- package/dist/media-bbZayaf9.cjs.map +1 -0
- package/dist/{menu-CusvB2dY.js → menu-0iRALRYm.js} +3 -3
- package/dist/{menu-CusvB2dY.js.map → menu-0iRALRYm.js.map} +1 -1
- package/dist/{menu-Delwe6al.cjs → menu-DL_LIJDZ.cjs} +2 -2
- package/dist/{menu-Delwe6al.cjs.map → menu-DL_LIJDZ.cjs.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-DiTgelcm.js → notification-service-VTX0d4Mz.js} +4 -4
- package/dist/{notification-service-DiTgelcm.js.map → notification-service-VTX0d4Mz.js.map} +1 -1
- package/dist/{notification-service-BwcUY8O5.cjs → notification-service-duChj_fI.cjs} +2 -2
- package/dist/{notification-service-BwcUY8O5.cjs.map → notification-service-duChj_fI.cjs.map} +1 -1
- package/dist/notification.cjs +1 -1
- package/dist/notification.js +2 -2
- package/dist/{notify-JNbirYT5.js → notify-CsPnMOWA.js} +2 -2
- package/dist/{notify-JNbirYT5.js.map → notify-CsPnMOWA.js.map} +1 -1
- package/dist/{notify-C81e8flx.cjs → notify-DWzOE_a0.cjs} +2 -2
- package/dist/{notify-C81e8flx.cjs.map → notify-DWzOE_a0.cjs.map} +1 -1
- package/dist/{option-D4XcuvRK.cjs → option-BuxsrJGz.cjs} +2 -2
- package/dist/{option-D4XcuvRK.cjs.map → option-BuxsrJGz.cjs.map} +1 -1
- package/dist/{option-dihFw6qv.js → option-LU4u-XDp.js} +2 -2
- package/dist/{option-dihFw6qv.js.map → option-LU4u-XDp.js.map} +1 -1
- package/dist/option.cjs +1 -1
- package/dist/option.js +1 -1
- package/dist/{payment-card-form-CIm57Nfa.cjs → payment-card-form-BHOSDbBW.cjs} +2 -2
- package/dist/{payment-card-form-CIm57Nfa.cjs.map → payment-card-form-BHOSDbBW.cjs.map} +1 -1
- package/dist/{payment-card-form-pDuTrWgZ.js → payment-card-form-DRDYv0Kf.js} +3 -3
- package/dist/{payment-card-form-pDuTrWgZ.js.map → payment-card-form-DRDYv0Kf.js.map} +1 -1
- package/dist/{progress-C4o_zWvg.js → progress-C5J2ztGv.js} +2 -2
- package/dist/{progress-C4o_zWvg.js.map → progress-C5J2ztGv.js.map} +1 -1
- package/dist/{progress-BETtTl0y.cjs → progress-b31434it.cjs} +2 -2
- package/dist/{progress-BETtTl0y.cjs.map → progress-b31434it.cjs.map} +1 -1
- package/dist/progress.cjs +1 -1
- package/dist/progress.js +1 -1
- package/dist/{radio-button-DaSKbB-Z.js → radio-button-Be3kJGzb.js} +3 -3
- package/dist/{radio-button-DaSKbB-Z.js.map → radio-button-Be3kJGzb.js.map} +1 -1
- package/dist/{radio-button-h6y0tWJQ.cjs → radio-button-DqSE4JD0.cjs} +2 -2
- package/dist/{radio-button-h6y0tWJQ.cjs.map → radio-button-DqSE4JD0.cjs.map} +1 -1
- package/dist/radio-group.cjs +1 -1
- package/dist/radio-group.js +1 -1
- package/dist/{route.component-DzBfI9eE.cjs → route.component-CKDzt8bL.cjs} +2 -2
- package/dist/{route.component-DzBfI9eE.cjs.map → route.component-CKDzt8bL.cjs.map} +1 -1
- package/dist/{route.component-BaefEO15.js → route.component-CfXxSRSa.js} +3 -3
- package/dist/{route.component-BaefEO15.js.map → route.component-CfXxSRSa.js.map} +1 -1
- package/dist/{schmancy-steps-container-DpM5Kvt3.cjs → schmancy-steps-container-DdXbEWTp.cjs} +2 -2
- package/dist/{schmancy-steps-container-DpM5Kvt3.cjs.map → schmancy-steps-container-DdXbEWTp.cjs.map} +1 -1
- package/dist/{schmancy-steps-container-uRaJiCZE.js → schmancy-steps-container-O_Bkm1nD.js} +2 -2
- package/dist/{schmancy-steps-container-uRaJiCZE.js.map → schmancy-steps-container-O_Bkm1nD.js.map} +1 -1
- package/dist/{select-ClFVeWZA.cjs → select-9cgpvCx0.cjs} +2 -2
- package/dist/{select-ClFVeWZA.cjs.map → select-9cgpvCx0.cjs.map} +1 -1
- package/dist/{select-uQ5xnOKn.js → select-B2Om6sl5.js} +3 -3
- package/dist/{select-uQ5xnOKn.js.map → select-B2Om6sl5.js.map} +1 -1
- package/dist/select.cjs +1 -1
- package/dist/select.js +1 -1
- package/dist/{sheet-CEcMgg-2.cjs → sheet-6OY1xJf0.cjs} +2 -2
- package/dist/{sheet-CEcMgg-2.cjs.map → sheet-6OY1xJf0.cjs.map} +1 -1
- package/dist/{sheet-CvvdxIUZ.js → sheet-BSnev5gW.js} +3 -3
- package/dist/{sheet-CvvdxIUZ.js.map → sheet-BSnev5gW.js.map} +1 -1
- package/dist/sheet.cjs +1 -1
- package/dist/sheet.js +1 -1
- package/dist/{slider-T8sYw1p-.cjs → slider-BBYPWRwr.cjs} +2 -2
- package/dist/{slider-T8sYw1p-.cjs.map → slider-BBYPWRwr.cjs.map} +1 -1
- package/dist/{slider-DyxIZ-hn.js → slider-BkiCeMDd.js} +3 -3
- package/dist/{slider-DyxIZ-hn.js.map → slider-BkiCeMDd.js.map} +1 -1
- package/dist/slider.cjs +1 -1
- package/dist/slider.js +1 -1
- package/dist/{spinner-DJviKuwJ.cjs → spinner-BJeffsJM.cjs} +2 -2
- package/dist/{spinner-DJviKuwJ.cjs.map → spinner-BJeffsJM.cjs.map} +1 -1
- package/dist/{spinner-D9fC8P3H.js → spinner-Cp6KZZBA.js} +2 -2
- package/dist/{spinner-D9fC8P3H.js.map → spinner-Cp6KZZBA.js.map} +1 -1
- package/dist/steps.cjs +1 -1
- package/dist/steps.js +1 -1
- package/dist/{surface-CUyYCpFl.js → surface-SM_1ZWsE.js} +2 -2
- package/dist/{surface-CUyYCpFl.js.map → surface-SM_1ZWsE.js.map} +1 -1
- package/dist/{surface-B_SGQ1f7.cjs → surface-vZ-b0jGR.cjs} +2 -2
- package/dist/{surface-B_SGQ1f7.cjs.map → surface-vZ-b0jGR.cjs.map} +1 -1
- package/dist/surface.cjs +1 -1
- package/dist/surface.js +1 -1
- package/dist/{table-D7p7a-Ag.js → table-DDAICIrl.js} +2 -2
- package/dist/{table-D7p7a-Ag.js.map → table-DDAICIrl.js.map} +1 -1
- package/dist/{table-C-sWuoAy.cjs → table-EUh7lBkg.cjs} +2 -2
- package/dist/{table-C-sWuoAy.cjs.map → table-EUh7lBkg.cjs.map} +1 -1
- package/dist/table.cjs +1 -1
- package/dist/table.js +1 -1
- package/dist/{tabs-compatibility-XoF2vpv5.cjs → tabs-compatibility-B5N4LrZE.cjs} +2 -2
- package/dist/{tabs-compatibility-XoF2vpv5.cjs.map → tabs-compatibility-B5N4LrZE.cjs.map} +1 -1
- package/dist/{tabs-compatibility-Dn8bSEvA.js → tabs-compatibility-BLC9SZfW.js} +2 -2
- package/dist/{tabs-compatibility-Dn8bSEvA.js.map → tabs-compatibility-BLC9SZfW.js.map} +1 -1
- package/dist/tabs.cjs +1 -1
- package/dist/tabs.js +1 -1
- package/dist/tailwind.mixin-BYp3JxPB.js +43 -0
- package/dist/{tailwind.mixin-C13RR5x6.js.map → tailwind.mixin-BYp3JxPB.js.map} +1 -1
- package/dist/tailwind.mixin-DE8PuauZ.cjs +2 -0
- package/dist/{tailwind.mixin-O9jmUJ7m.cjs.map → tailwind.mixin-DE8PuauZ.cjs.map} +1 -1
- package/dist/teleport.cjs +1 -1
- package/dist/teleport.js +1 -1
- package/dist/{textarea-9rSwC34M.cjs → textarea-C7WOZ_sq.cjs} +2 -2
- package/dist/{textarea-9rSwC34M.cjs.map → textarea-C7WOZ_sq.cjs.map} +1 -1
- package/dist/{textarea-Dsqg9ted.js → textarea-DqLqZT9R.js} +2 -2
- package/dist/{textarea-Dsqg9ted.js.map → textarea-DqLqZT9R.js.map} +1 -1
- package/dist/textarea.cjs +1 -1
- package/dist/textarea.js +1 -1
- package/dist/{theme-button-BTH2A59w.cjs → theme-button-CL8Z3_3f.cjs} +2 -2
- package/dist/{theme-button-BTH2A59w.cjs.map → theme-button-CL8Z3_3f.cjs.map} +1 -1
- package/dist/{theme-button-pfkAwkvY.js → theme-button-CfhL1LUk.js} +2 -2
- package/dist/{theme-button-pfkAwkvY.js.map → theme-button-CfhL1LUk.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.component-BvoZuM2h.cjs → theme.component-BDEnZH7c.cjs} +2 -2
- package/dist/{theme.component-BvoZuM2h.cjs.map → theme.component-BDEnZH7c.cjs.map} +1 -1
- package/dist/{theme.component-C3G_OrjE.js → theme.component-DJ45zqsj.js} +2 -2
- package/dist/{theme.component-C3G_OrjE.js.map → theme.component-DJ45zqsj.js.map} +1 -1
- package/dist/theme.js +1 -1
- package/dist/{timezone-BKBME7Gq.cjs → timezone-Ej5Mkgdi.cjs} +2 -2
- package/dist/{timezone-BKBME7Gq.cjs.map → timezone-Ej5Mkgdi.cjs.map} +1 -1
- package/dist/{timezone-mQeoU0_O.js → timezone-rOawo-NZ.js} +3 -3
- package/dist/{timezone-mQeoU0_O.js.map → timezone-rOawo-NZ.js.map} +1 -1
- package/dist/{tooltip-Bcun7m0S.cjs → tooltip-C1m-GCOh.cjs} +2 -2
- package/dist/{tooltip-Bcun7m0S.cjs.map → tooltip-C1m-GCOh.cjs.map} +1 -1
- package/dist/{tooltip-Doh_evJW.js → tooltip-D9zzVulu.js} +2 -2
- package/dist/{tooltip-Doh_evJW.js.map → tooltip-D9zzVulu.js.map} +1 -1
- package/dist/tooltip.cjs +1 -1
- package/dist/tooltip.js +1 -1
- package/dist/{tree-cl3PdPTy.js → tree-C54uex1G.js} +2 -2
- package/dist/{tree-cl3PdPTy.js.map → tree-C54uex1G.js.map} +1 -1
- package/dist/{tree-DpKb9Q-1.cjs → tree-UVZHnodF.cjs} +2 -2
- package/dist/{tree-DpKb9Q-1.cjs.map → tree-UVZHnodF.cjs.map} +1 -1
- package/dist/tree.cjs +1 -1
- package/dist/tree.js +1 -1
- package/dist/{typewriter-peuqmq9f.js → typewriter-Bfe2Gpx9.js} +4 -4
- package/dist/{typewriter-peuqmq9f.js.map → typewriter-Bfe2Gpx9.js.map} +1 -1
- package/dist/{typewriter-QSd_xI9j.cjs → typewriter-CZ4VA1B3.cjs} +2 -2
- package/dist/{typewriter-QSd_xI9j.cjs.map → typewriter-CZ4VA1B3.cjs.map} +1 -1
- package/dist/typewriter.cjs +1 -1
- package/dist/typewriter.js +1 -1
- package/dist/{typography-BkuzOZ0g.js → typography-Cg1EBHYc.js} +2 -2
- package/dist/{typography-BkuzOZ0g.js.map → typography-Cg1EBHYc.js.map} +1 -1
- package/dist/{typography-BoI8HgTE.cjs → typography-CowH2wUG.cjs} +2 -2
- package/dist/{typography-BoI8HgTE.cjs.map → typography-CowH2wUG.cjs.map} +1 -1
- package/dist/typography.cjs +1 -1
- package/dist/typography.js +1 -1
- package/package.json +1 -1
- package/types/src/card/card.d.ts +1 -0
- package/types/src/chips/assist-chip.d.ts +1 -1
- package/types/src/chips/input-chip.d.ts +6 -1
- package/types/src/chips/suggestion-chip.d.ts +1 -1
- package/dist/chips-7TbOS1By.js.map +0 -1
- package/dist/chips-DORDPg5b.cjs.map +0 -1
- package/dist/media-CL9LNHic.cjs.map +0 -1
- package/dist/media-nVQjNoX7.js.map +0 -1
- package/dist/tailwind.mixin-C13RR5x6.js +0 -43
- package/dist/tailwind.mixin-O9jmUJ7m.cjs +0 -2
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chips-7TbOS1By.js","sources":["../src/chips/filter-chip.ts","../src/chips/assist-chip.ts","../src/chips/input-chip.ts","../src/chips/suggestion-chip.ts","../src/chips/chips.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { property, queryAssignedElements } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Filter chip component for content filtering.\n *\n * Filter chips are the ONLY chip type that maintains persistent selected state.\n * They are used for filtering content by toggling on/off different filter criteria.\n *\n * @fires change - Dispatched when selection state changes with {value, selected}\n * @fires remove - Dispatched when remove button is clicked (if removable)\n *\n * @example\n * ```html\n * <schmancy-filter-chip value=\"category-1\" selected>\n * Category 1\n * </schmancy-filter-chip>\n * ```\n */\nexport class SchmancyFilterChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t\topacity: 0.5;\n\t}\n\n\tbutton {\n\t\tfont-family: inherit;\n\t}\n\n\t/* Material Symbols font for icons */\n\t.material-symbols-outlined {\n\t\tfont-family: 'Material Symbols Outlined';\n\t\tfont-weight: normal;\n\t\tfont-style: normal;\n\t\tfont-size: 18px;\n\t\tline-height: 1;\n\t\tletter-spacing: normal;\n\t\ttext-transform: none;\n\t\tdisplay: inline-block;\n\t\twhite-space: nowrap;\n\t\tword-wrap: normal;\n\t\tdirection: ltr;\n\t\t-webkit-font-smoothing: antialiased;\n\t\ttext-rendering: optimizeLegibility;\n\t\t-moz-osx-font-smoothing: grayscale;\n\t\tfont-feature-settings: 'liga';\n\t\tvertical-align: middle;\n\t}\n`) {\n\t/** Unique identifier for this filter chip */\n\t@property({ type: String, reflect: true })\n\tvalue: string = ''\n\n\t/** Whether the filter chip is selected (active filter) */\n\tprivate _selected: boolean = false\n\n\t@property({ type: Boolean, reflect: true })\n\tget selected(): boolean {\n\t\treturn this._selected\n\t}\n\tset selected(value: boolean) {\n\t\tconst oldValue = this._selected\n\t\tthis._selected = value\n\t\tthis.requestUpdate('selected', oldValue)\n\t}\n\n\t/** Optional icon to display (Material Symbols name) */\n\t@property({ type: String, reflect: true })\n\ticon: string = ''\n\n\t/** Whether to show a remove button */\n\t@property({ type: Boolean, reflect: true })\n\tremovable: boolean = false\n\n\t/** Whether the chip is disabled */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled: boolean = false\n\n\t/** Whether to use elevated style with shadow */\n\t@property({ type: Boolean, reflect: true })\n\televated: boolean = false\n\n\t// Reactive state management with RxJS\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// Query assigned elements in the icon slot\n\t@queryAssignedElements({ slot: 'icon' }) iconSlotElements!: Element[]\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\n\tstatic formAssociated = true\n\tinternals: ElementInternals | undefined\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// RxJS streams are maintained for potential future use\n\t\t// Currently state is handled directly through event handlers\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$,\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting),\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = () => {\n\t\tif (this.disabled) return\n\n\t\t// Don't modify this.selected - let the parent container control it\n\t\t// Dispatch change event with the INTENDED state\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('change', {\n\t\t\t\tdetail: { value: this.value, selected: !this._selected },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleRemove = (e: Event) => {\n\t\tif (this.disabled) return\n\n\t\te.stopPropagation()\n\n\t\t// Dispatch remove event\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('remove', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\t// Dispatch event directly rather than calling handleClick to be explicit\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('change', {\n\t\t\t\t\tdetail: { value: this.value, selected: !this._selected },\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}\n\t}\n\n\tprivate handleMouseEnter = () => {\n\t\tthis.hover$.next(true)\n\t}\n\n\tprivate handleMouseLeave = () => {\n\t\tthis.hover$.next(false)\n\t\tthis.pressed$.next(false)\n\t}\n\n\tprivate handleMouseDown = () => {\n\t\tthis.pressed$.next(true)\n\t}\n\n\tprivate handleMouseUp = () => {\n\t\tthis.pressed$.next(false)\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst chipClasses = {\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'h-8 px-4': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'text-sm': true,\n\t\t\t'font-medium': true,\n\t\t\t'border': true,\n\t\t\t'relative': true,\n\t\t\t'min-h-[32px]': true,\n\n\t\t\t// Background and text colors based on selection state\n\t\t\t'bg-secondary-container': this._selected,\n\t\t\t'text-secondary-onContainer': this._selected,\n\t\t\t'border-secondary-container': this._selected,\n\t\t\t'bg-surface-container': !this._selected,\n\t\t\t'text-surface-on': !this._selected,\n\t\t\t'border-outline-variant': !this._selected,\n\n\t\t\t// Hover states\n\t\t\t'hover:brightness-95': this._selected && !this.disabled,\n\t\t\t'hover:bg-surface-containerHigh': !this._selected && !this.disabled,\n\n\t\t\t// Pressed state\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Focus-visible state for better UX\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\n\t\t\t// Elevated style\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\n\t\t\t// Disabled state\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\tclass=${this.classMap(chipClasses)}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${this.handleMouseEnter}\n\t\t\t\t@mouseleave=${this.handleMouseLeave}\n\t\t\t\t@mousedown=${this.handleMouseDown}\n\t\t\t\t@mouseup=${this.handleMouseUp}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\taria-pressed=${this._selected ? 'true' : 'false'}\n\t\t\t\trole=\"checkbox\"\n\t\t\t\ttabindex=\"0\"\n\t\t\t>\n\t\t\t\t<!-- Icon container - conditionally shown using when directive -->\n\t\t\t\t${when(\n\t\t\t\t\tthis._selected || this.icon || this.iconSlotElements?.length > 0,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<span class=\"inline-flex w-[18px] h-[18px] items-center justify-center shrink-0\">\n\t\t\t\t\t\t\t${this._selected ? html`\n\t\t\t\t\t\t\t\t<span class=\"material-symbols-outlined text-base sm:text-[18px]\">\n\t\t\t\t\t\t\t\t\tcheck\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t` : this.icon ? html`\n\t\t\t\t\t\t\t\t<span class=\"material-symbols-outlined text-base sm:text-[18px]\">\n\t\t\t\t\t\t\t\t\t${this.icon}\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t` : html`\n\t\t\t\t\t\t\t\t<slot name=\"icon\"></slot>\n\t\t\t\t\t\t\t`}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t`\n\t\t\t\t)}\n\n\t\t\t\t<!-- Chip content -->\n\t\t\t\t<slot></slot>\n\n\t\t\t\t<!-- Remove button (if removable) -->\n\t\t\t\t${this.removable ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\tclass=\"ml-1 -mr-1 p-0.5 rounded-full hover:bg-surface-containerHighest transition-colors\"\n\t\t\t\t\t\t@click=${this.handleRemove}\n\t\t\t\t\t\taria-label=\"Remove filter\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"material-symbols-outlined text-sm sm:text-[16px]\">\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</button>\n\t\t\t\t` : ''}\n\t\t\t</button>\n\t\t`\n\t}\n}\n\n// Register the element with both names for backward compatibility\n// Check if not already registered to prevent duplicate registration errors\nif (!customElements.get('schmancy-filter-chip')) {\n\tcustomElements.define('schmancy-filter-chip', SchmancyFilterChip)\n}\n\n// For backward compatibility, register 'schmancy-chip' with a subclass\n// to avoid duplicate constructor registration error\nif (!customElements.get('schmancy-chip')) {\n\tclass SchmancyChipCompat extends SchmancyFilterChip {}\n\tcustomElements.define('schmancy-chip', SchmancyChipCompat)\n}\n\n// Export alias for backward compatibility\nexport { SchmancyFilterChip as SchmancyChip }\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-chip': SchmancyFilterChip\n\t\t'schmancy-filter-chip': SchmancyFilterChip\n\t}\n}\n\nexport type FilterChipChangeEvent = { value: string; selected: boolean }\nexport type FilterChipRemoveEvent = { value: string }\n// Alias for backward compatibility\nexport type SchmancyChipChangeEvent = FilterChipChangeEvent","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Assist chip component - prompts user actions like opening calendar events or sharing content\n * Pure Schmancy implementation with Tailwind CSS and RxJS state management\n */\n@customElement('schmancy-assist-chip')\nexport class SchmancyAssistChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ reflect: true }) value = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ reflect: true }) icon = ''\n\n\t/** Optional href for navigation */\n\t@property({ reflect: true }) href = ''\n\n\t/** Target for navigation (e.g., '_blank') */\n\t@property({ reflect: true }) target = ''\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true }) elevated = false\n\n\t// RxJS state streams\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state - only ripples needed for rendering\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprotected static shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true }\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Stream management for future extensions\n\t\t// Currently, states are handled directly in event handlers\n\t\t// This pipeline can be extended for more complex state interactions\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst button = this.shadowRoot?.querySelector('button')\n\t\tif (button) {\n\t\t\tconst rect = button.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch action event\n\t\tthis.dispatchEvent(new CustomEvent('action', {\n\t\t\tdetail: { value: this.value },\n\t\t\tbubbles: true,\n\t\t\tcomposed: true\n\t\t}))\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed$.next(true)\n\n\t\t\t// Simulate click\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleClick(clickEvent)\n\n\t\t\tsetTimeout(() => this.pressed$.next(false), 100)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\trender() {\n\t\tconst classes = {\n\t\t\t'relative': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'px-2 py-1 sm:px-3 sm:py-1.5 md:px-4 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors\n\t\t\t'bg-surface-container': !this.elevated,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'bg-surface-containerLow': this.elevated,\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// States\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled && !this.elevated,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Disabled\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=${classMap(classes)}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.hover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.hover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\trole=\"button\"\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t${this.icon ? html`\n\t\t\t\t\t<schmancy-icon class=\"text-sm sm:text-base\">${this.icon}</schmancy-icon>\n\t\t\t\t` : ''}\n\t\t\t\t<span class=\"text-xs sm:text-sm font-medium\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\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-assist-chip': SchmancyAssistChip\n\t}\n}\n\nexport type AssistChipActionEvent = { value: string }","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { map, takeUntil, tap } from 'rxjs/operators'\n\n/**\n * Input chip component - represents user-provided information that can be removed.\n *\n * IMPORTANT: Per Material Design 3 specification, input chips do NOT have selected state.\n * They represent discrete pieces of user input (like entered tags, selections from lists, etc.)\n * that can only be removed, not toggled on/off.\n *\n * Use cases:\n * - Displaying selected recipients in an email\n * - Showing applied filters that can be removed\n * - Tags or keywords entered by the user\n * - Selected items from a multi-select dropdown\n *\n * @fires click - Optional click event on chip body (value)\n * @fires remove - Dispatched when remove button is clicked (value)\n *\n * @example\n * ```html\n * <schmancy-input-chip value=\"john@example.com\" avatar=\"/avatars/john.jpg\">\n * John Doe\n * </schmancy-input-chip>\n * ```\n */\n@customElement('schmancy-input-chip')\nexport class SchmancyInputChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\tbutton {\n\t\tfont-family: inherit;\n\t}\n\n\t.avatar-img {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tobject-fit: cover;\n\t}\n\n\t/* Material Symbols font for icons */\n\t.material-symbols-outlined {\n\t\tfont-family: 'Material Symbols Outlined';\n\t\tfont-weight: normal;\n\t\tfont-style: normal;\n\t\tfont-size: 18px;\n\t\tline-height: 1;\n\t\tletter-spacing: normal;\n\t\ttext-transform: none;\n\t\tdisplay: inline-block;\n\t\twhite-space: nowrap;\n\t\tword-wrap: normal;\n\t\tdirection: ltr;\n\t\t-webkit-font-smoothing: antialiased;\n\t\ttext-rendering: optimizeLegibility;\n\t\t-moz-osx-font-smoothing: grayscale;\n\t\tfont-feature-settings: 'liga';\n\t\tvertical-align: middle;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ type: String, reflect: true })\n\tvalue: string = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ type: String, reflect: true })\n\ticon: string = ''\n\n\t/** Optional avatar image URL */\n\t@property({ type: String, reflect: true })\n\tavatar: string = ''\n\n\t/** Whether to show remove button (default true for input chips) */\n\t@property({ type: Boolean, reflect: true })\n\tremovable: boolean = true\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled: boolean = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true })\n\televated: boolean = false\n\n\t// RxJS state streams\n\tprivate chipHover$ = new BehaviorSubject<boolean>(false)\n\tprivate removeHover$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state from combined streams\n\t@state() private uiState = {\n\t\tchipHover: false,\n\t\tremoveHover: false,\n\t\tfocused: false,\n\t\tpressed: false\n\t}\n\n\t// Ripple effects\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\tprivate nextRippleId = 0\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\n\tstatic formAssociated = true\n\tinternals: ElementInternals | undefined\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Combine all UI state streams\n\t\tcombineLatest([\n\t\t\tthis.chipHover$,\n\t\t\tthis.removeHover$,\n\t\t\tthis.focused$,\n\t\t\tthis.pressed$\n\t\t]).pipe(\n\t\t\tmap(([chipHover, removeHover, focused, pressed]) => ({\n\t\t\t\tchipHover,\n\t\t\t\tremoveHover,\n\t\t\t\tfocused,\n\t\t\t\tpressed\n\t\t\t})),\n\t\t\ttap(state => {\n\t\t\t\tthis.uiState = state\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleChipClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst chip = this.shadowRoot?.querySelector('.chip-container') as HTMLElement\n\t\tif (chip) {\n\t\t\tconst rect = chip.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Dispatch optional click event (for custom handling if needed)\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('click', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t})\n\t\t)\n\t}\n\n\tprivate handleRemove = (e: Event) => {\n\t\tif (this.disabled) return\n\n\t\te.stopPropagation()\n\n\t\t// Dispatch remove event\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('remove', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t})\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Delete or Backspace removes the chip\n\t\tif ((e.key === 'Delete' || e.key === 'Backspace') && this.removable) {\n\t\t\te.preventDefault()\n\t\t\tthis.handleRemove(e)\n\t\t}\n\t\t// Enter can optionally trigger click\n\t\telse if (e.key === 'Enter') {\n\t\t\te.preventDefault()\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleChipClick(clickEvent)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst chipClasses = {\n\t\t\t'chip-container': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'pl-3': !this.avatar, // Less padding if avatar present\n\t\t\t'pl-1': this.avatar, // Tight padding for avatar\n\t\t\t'pr-2': this.removable,\n\t\t\t'pr-3': !this.removable,\n\t\t\t'py-1 sm:py-1.5 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-default': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'text-xs sm:text-sm': true,\n\t\t\t'font-medium': true,\n\t\t\t'relative': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors\n\t\t\t'bg-surface-container': true,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// Hover state (subtle on chip body)\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled && !this.uiState.removeHover,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\n\t\t\t// Focus-visible state for better UX\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\n\t\t\t// Disabled state\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\tconst removeButtonClasses = {\n\t\t\t\"size-5 sm:size-6\":true,\n\t\t\t'rounded-full': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\n\t\t\t// Hover state for remove button\n\t\t\t'bg-error-container': this.uiState.removeHover && !this.disabled,\n\t\t\t'text-error-onContainer': this.uiState.removeHover && !this.disabled,\n\t\t\t'hover:scale-110': this.uiState.removeHover && !this.disabled,\n\n\t\t\t// Default state\n\t\t\t'hover:bg-surface-containerHighest': !this.uiState.removeHover && !this.disabled,\n\t\t\t'opacity-50': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${classMap(chipClasses)}\n\t\t\t\t@click=${this.handleChipClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.chipHover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.chipHover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\trole=\"button\"\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t<!-- Avatar image (if provided) -->\n\t\t\t\t${this.avatar ? html`\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=${this.avatar}\n\t\t\t\t\t\talt=\"\"\n\t\t\t\t\t\tclass=\"avatar-img rounded-full sm:size-6\"\n\t\t\t\t\t/>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Icon (if provided and no avatar) -->\n\t\t\t\t${this.icon && !this.avatar ? html`\n\t\t\t\t\t<span class=\"material-symbols-outlined rounded-full text-base sm:text-[18px]\">\n\t\t\t\t\t\t${this.icon}\n\t\t\t\t\t</span>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Chip content -->\n\t\t\t\t<span>\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Remove button (shown by default for input chips) -->\n\t\t\t\t${this.removable ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\tclass=${classMap(removeButtonClasses)}\n\t\t\t\t\t\t@click=${this.handleRemove}\n\t\t\t\t\t\t@mouseenter=${() => this.removeHover$.next(true)}\n\t\t\t\t\t\t@mouseleave=${() => this.removeHover$.next(false)}\n\t\t\t\t\t\taria-label=\"Remove\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"material-symbols-outlined text-sm sm:text-[16px]\">\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</button>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\n\t\t\t\t\t></span>\n\t\t\t\t`)}\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-input-chip': SchmancyInputChip\n\t}\n}\n\nexport type InputChipClickEvent = { value: string }\nexport type InputChipRemoveEvent = { value: string }","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Suggestion chip component - provides contextual recommendations to users\n *\n * IMPORTANT: Suggestion chips do NOT have a selected state. They are designed to\n * provide suggestions and recommendations that trigger actions when clicked.\n * Unlike filter chips, they cannot be toggled on/off.\n *\n * Pure Schmancy implementation with Tailwind CSS and RxJS state management\n */\n@customElement('schmancy-suggestion-chip')\nexport class SchmancySuggestionChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ reflect: true }) value = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ reflect: true }) icon = ''\n\n\t/** Optional href for navigation */\n\t@property({ reflect: true }) href = ''\n\n\t/** Target for navigation (e.g., '_blank') */\n\t@property({ reflect: true }) target = ''\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true }) elevated = false\n\n\t// RxJS state streams\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state - only ripples needed for rendering\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprotected static shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true }\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Stream management for future extensions\n\t\t// Currently, states are handled directly in event handlers\n\t\t// This pipeline can be extended for more complex state interactions\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst button = this.shadowRoot?.querySelector('button')\n\t\tif (button) {\n\t\t\tconst rect = button.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch action event\n\t\tthis.dispatchEvent(new CustomEvent('action', {\n\t\t\tdetail: { value: this.value },\n\t\t\tbubbles: true,\n\t\t\tcomposed: true\n\t\t}))\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed$.next(true)\n\n\t\t\t// Simulate click\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleClick(clickEvent)\n\n\t\t\tsetTimeout(() => this.pressed$.next(false), 100)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'relative': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'px-2 py-1 sm:px-3 sm:py-1.5 md:px-4 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors - slightly different from assist chips\n\t\t\t'bg-surface-containerLow': !this.elevated,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'bg-surface': this.elevated,\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// States\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Disabled\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=${classMap(classes)}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.hover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.hover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\trole=\"button\"\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t${this.icon ? html`\n\t\t\t\t\t<schmancy-icon class=\"text-sm sm:text-base\">${this.icon}</schmancy-icon>\n\t\t\t\t` : ''}\n\t\t\t\t<span class=\"text-xs sm:text-sm font-medium\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\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-suggestion-chip': SchmancySuggestionChip\n\t}\n}\n\nexport type SuggestionChipActionEvent = { value: string }","import { $LitElement } from '@mixins/index'\nimport { html, PropertyValues } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { SchmancyFilterChip as SchmancyChip } from './filter-chip'\nimport type { FilterChipChangeEvent as SchmancyChipChangeEvent } from './filter-chip'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil, distinctUntilChanged, debounceTime } from 'rxjs/operators'\n\n@customElement('schmancy-chips')\nexport default class SchmancyChips extends $LitElement() {\n\t// RxJS state streams - initialized with undefined to detect if properties were set\n\tprivate value$ = new BehaviorSubject<string>('')\n\tprivate values$ = new BehaviorSubject<string[]>([])\n\n\t// Track if properties were initialized from attributes/properties\n\tprivate _value: string = ''\n\tprivate _values: string[] = []\n\tprivate _multi: boolean = false\n\n\t// Track if properties have been explicitly set\n\tprivate _valueSet: boolean = false\n\tprivate _valuesSet: boolean = false\n\n\t/**\n\t * @deprecated Use .values for multi-selection or .value for single-selection instead.\n\t * The mode is now automatically determined based on which property is used.\n\t */\n\t@property({\n\t\ttype: Boolean,\n\t\treflect: true,\n\t})\n\tget multi(): boolean {\n\t\treturn this._multi\n\t}\n\tset multi(value: boolean) {\n\t\tthis._multi = value\n\t\t// Note: We don't update any BehaviorSubject here as mode is now computed\n\t}\n\n\t/**\n\t * Automatically determines the selection mode based on which properties are in use\n\t */\n\tprivate get mode(): 'multi' | 'single' | 'none' {\n\t\t// Check if values array is being used (explicitly set)\n\t\tif (this._valuesSet) {\n\t\t\treturn 'multi'\n\t\t}\n\t\t// Check if value string is being used (explicitly set)\n\t\tif (this._valueSet) {\n\t\t\treturn 'single'\n\t\t}\n\t\t// Check if either property has been set via attributes\n\t\tif (this.hasAttribute('values')) {\n\t\t\treturn 'multi'\n\t\t}\n\t\tif (this.hasAttribute('value')) {\n\t\t\treturn 'single'\n\t\t}\n\t\t// Fallback to deprecated multi prop for backward compatibility\n\t\tif (this._multi === true) {\n\t\t\treturn 'multi'\n\t\t}\n\t\t// Default to none (no selection management)\n\t\treturn 'none'\n\t}\n\n\t@property({\n\t\ttype: Array,\n\t\treflect: true,\n\t})\n\tget values(): string[] {\n\t\treturn this._values\n\t}\n\tset values(value: string[]) {\n\t\tthis._values = value || []\n\t\tthis._valuesSet = true // Mark that values has been explicitly set\n\t\tthis.values$.next(this._values)\n\t}\n\n\t@property({\n\t\ttype: String,\n\t\treflect: true,\n\t})\n\tget value(): string {\n\t\treturn this._value\n\t}\n\tset value(value: string) {\n\t\tthis._value = value || ''\n\t\tthis._valueSet = true // Mark that value has been explicitly set\n\t\tthis.value$.next(this._value)\n\t}\n\n\t@queryAssignedElements({\n\t\tselector:\n\t\t\t'schmancy-chip, schmancy-filter-chip, schmancy-assist-chip, schmancy-input-chip, schmancy-suggestion-chip',\n\t\tflatten: true,\n\t})\n\tchips!: (SchmancyChip | HTMLElement)[]\n\n\t@property({\n\t\ttype: Boolean,\n\t\treflect: true,\n\t})\n\twrap: boolean = false\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Initialize BehaviorSubjects with current property values\n\t\t// This ensures properties set before connectedCallback are respected\n\t\tthis.value$.next(this._value)\n\t\tthis.values$.next(this._values)\n\n\t\t// Set up reactive pipeline for state synchronization\n\t\tcombineLatest([\n\t\t\tthis.value$.pipe(distinctUntilChanged()),\n\t\t\tthis.values$.pipe(\n\t\t\t\tdistinctUntilChanged((prev, curr) => prev.length === curr.length && prev.every((v, i) => v === curr[i])),\n\t\t\t),\n\t\t])\n\t\t\t.pipe(\n\t\t\t\tdebounceTime(0), // Ensure DOM is ready\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(([value, values]) => {\n\t\t\t\t// Reactively update chip states based on container state and auto-detected mode\n\t\t\t\tthis.updateChipStates(this.mode, value, values)\n\t\t\t})\n\t}\n\n\tprivate updateChipStates(mode: 'multi' | 'single' | 'none', value: string, values: string[]) {\n\t\tif (!this.chips) return\n\n\t\t// If mode is 'none', don't manage selection state\n\t\tif (mode === 'none') return\n\n\t\tthis.chips.forEach(chip => {\n\t\t\tif ('value' in chip && 'selected' in chip) {\n\t\t\t\tconst filterChip = chip as SchmancyChip\n\t\t\t\tif (mode === 'multi') {\n\t\t\t\t\t// In multi mode: only select if values array explicitly includes this chip's value\n\t\t\t\t\tfilterChip.selected = values.length > 0 && values.includes(filterChip.value)\n\t\t\t\t} else if (mode === 'single') {\n\t\t\t\t\t// In single mode: only select if value is non-empty AND matches this chip's value\n\t\t\t\t\t// This prevents chips from being selected when value is empty string\n\t\t\t\t\tfilterChip.selected = value !== '' && value === filterChip.value\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t}\n\n\tasync change(e: CustomEvent<SchmancyChipChangeEvent>) {\n\t\te.preventDefault()\n\t\te.stopPropagation()\n\n\t\t// If mode is 'none', don't handle selection changes\n\t\tif (this.mode === 'none') return\n\n\t\tconst { value, selected } = e.detail\n\n\t\t// Update the reactive streams and internal tracking, which will trigger state synchronization\n\t\tif (this.mode === 'multi') {\n\t\t\tif (selected) {\n\t\t\t\t// Add value if not already present\n\t\t\t\tif (!this._values.includes(value)) {\n\t\t\t\t\tthis._values = [...this._values, value]\n\t\t\t\t\tthis.values$.next(this._values)\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Remove value\n\t\t\t\tthis._values = this._values.filter(v => v !== value)\n\t\t\t\tthis.values$.next(this._values)\n\t\t\t}\n\t\t} else if (this.mode === 'single') {\n\t\t\t// Single selection mode\n\t\t\tthis._value = selected ? value : ''\n\t\t\tthis.value$.next(this._value)\n\t\t}\n\n\t\t// Request update to trigger re-render and property reflection\n\t\tthis.requestUpdate()\n\n\t\t// Dispatch change event with appropriate detail based on mode\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent<SchmancyChipsChangeEvent>('change', {\n\t\t\t\tdetail: this.mode === 'multi' ? this._values : this._value,\n\t\t\t\tbubbles: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprotected firstUpdated(_changedProperties: PropertyValues): void {\n\t\tsuper.firstUpdated(_changedProperties)\n\t\t// Initial state synchronization will happen through the reactive pipeline\n\t\t// Force an initial update to ensure chips are synchronized\n\t\tthis.updateChipStates(this.mode, this._value, this._values)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst containerClasses = this.classMap({\n\t\t\t'inset-2': true,\n\t\t\tflex: true,\n\t\t\t'gap-2': true,\n\t\t\t'items-center': true,\n\t\t\t'flex-wrap': this.wrap,\n\t\t\t'overflow-x-auto': !this.wrap,\n\t\t\t'scrollbar-hide': !this.wrap,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div class=${containerClasses} @change=${this.change}>\n\t\t\t\t<slot\n\t\t\t\t\t@slotchange=${() => {\n\t\t\t\t\t\t// When slot changes, trigger state update through reactive pipeline\n\t\t\t\t\t\tthis.updateChipStates(this.mode, this._value, this._values)\n\t\t\t\t\t}}\n\t\t\t\t></slot>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-chips': SchmancyChips\n\t}\n}\nexport type SchmancyChipsChangeEvent = string | Array<string>\n"],"names":["SchmancyFilterChip","TailwindElement","css","super","this","value","_selected","icon","removable","disabled","elevated","hover$","BehaviorSubject","pressed$","focused$","handleClick","dispatchEvent","CustomEvent","detail","selected","bubbles","composed","handleRemove","e","stopPropagation","handleKeyDown","key","preventDefault","handleMouseEnter","next","handleMouseLeave","handleMouseDown","handleMouseUp","handleFocus","handleBlur","internals","attachInternals","oldValue","requestUpdate","form","connectedCallback","combineLatest","pipe","takeUntil","disconnecting","subscribe","render","chipClasses","border","relative","html","classMap","when","iconSlotElements","length","shadowRootOptions","LitElement","delegatesFocus","formAssociated","_w","__decorateClass","property","type","String","reflect","prototype","Boolean","queryAssignedElements","slot","customElements","get","define","SchmancyChipCompat","SchmancyAssistChip","constructor","arguments","href","target","ripples","nextRippleId","button","shadowRoot","querySelector","rect","getBoundingClientRect","x","clientX","left","y","clientY","top","id","setTimeout","filter","r","window","open","location","clickEvent","MouseEvent","cancelable","classes","map","ripple","state","customElement","SchmancyInputChip","avatar","chipHover$","removeHover$","uiState","chipHover","removeHover","focused","pressed","handleChipClick","chip","tap","removeButtonClasses","SchmancySuggestionChip","SchmancyChips","$LitElement","value$","values$","_value","_values","_multi","_valueSet","_valuesSet","wrap","multi","mode","hasAttribute","values","distinctUntilChanged","prev","curr","every","v","i","debounceTime","updateChipStates","chips","forEach","filterChip","includes","_changedProperties","firstUpdated","containerClasses","flex","change","Array","selector","flatten"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chips-DORDPg5b.cjs","sources":["../src/chips/filter-chip.ts","../src/chips/assist-chip.ts","../src/chips/input-chip.ts","../src/chips/suggestion-chip.ts","../src/chips/chips.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { property, queryAssignedElements } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Filter chip component for content filtering.\n *\n * Filter chips are the ONLY chip type that maintains persistent selected state.\n * They are used for filtering content by toggling on/off different filter criteria.\n *\n * @fires change - Dispatched when selection state changes with {value, selected}\n * @fires remove - Dispatched when remove button is clicked (if removable)\n *\n * @example\n * ```html\n * <schmancy-filter-chip value=\"category-1\" selected>\n * Category 1\n * </schmancy-filter-chip>\n * ```\n */\nexport class SchmancyFilterChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t\topacity: 0.5;\n\t}\n\n\tbutton {\n\t\tfont-family: inherit;\n\t}\n\n\t/* Material Symbols font for icons */\n\t.material-symbols-outlined {\n\t\tfont-family: 'Material Symbols Outlined';\n\t\tfont-weight: normal;\n\t\tfont-style: normal;\n\t\tfont-size: 18px;\n\t\tline-height: 1;\n\t\tletter-spacing: normal;\n\t\ttext-transform: none;\n\t\tdisplay: inline-block;\n\t\twhite-space: nowrap;\n\t\tword-wrap: normal;\n\t\tdirection: ltr;\n\t\t-webkit-font-smoothing: antialiased;\n\t\ttext-rendering: optimizeLegibility;\n\t\t-moz-osx-font-smoothing: grayscale;\n\t\tfont-feature-settings: 'liga';\n\t\tvertical-align: middle;\n\t}\n`) {\n\t/** Unique identifier for this filter chip */\n\t@property({ type: String, reflect: true })\n\tvalue: string = ''\n\n\t/** Whether the filter chip is selected (active filter) */\n\tprivate _selected: boolean = false\n\n\t@property({ type: Boolean, reflect: true })\n\tget selected(): boolean {\n\t\treturn this._selected\n\t}\n\tset selected(value: boolean) {\n\t\tconst oldValue = this._selected\n\t\tthis._selected = value\n\t\tthis.requestUpdate('selected', oldValue)\n\t}\n\n\t/** Optional icon to display (Material Symbols name) */\n\t@property({ type: String, reflect: true })\n\ticon: string = ''\n\n\t/** Whether to show a remove button */\n\t@property({ type: Boolean, reflect: true })\n\tremovable: boolean = false\n\n\t/** Whether the chip is disabled */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled: boolean = false\n\n\t/** Whether to use elevated style with shadow */\n\t@property({ type: Boolean, reflect: true })\n\televated: boolean = false\n\n\t// Reactive state management with RxJS\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// Query assigned elements in the icon slot\n\t@queryAssignedElements({ slot: 'icon' }) iconSlotElements!: Element[]\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\n\tstatic formAssociated = true\n\tinternals: ElementInternals | undefined\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// RxJS streams are maintained for potential future use\n\t\t// Currently state is handled directly through event handlers\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$,\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting),\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = () => {\n\t\tif (this.disabled) return\n\n\t\t// Don't modify this.selected - let the parent container control it\n\t\t// Dispatch change event with the INTENDED state\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('change', {\n\t\t\t\tdetail: { value: this.value, selected: !this._selected },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleRemove = (e: Event) => {\n\t\tif (this.disabled) return\n\n\t\te.stopPropagation()\n\n\t\t// Dispatch remove event\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('remove', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\t// Dispatch event directly rather than calling handleClick to be explicit\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('change', {\n\t\t\t\t\tdetail: { value: this.value, selected: !this._selected },\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}\n\t}\n\n\tprivate handleMouseEnter = () => {\n\t\tthis.hover$.next(true)\n\t}\n\n\tprivate handleMouseLeave = () => {\n\t\tthis.hover$.next(false)\n\t\tthis.pressed$.next(false)\n\t}\n\n\tprivate handleMouseDown = () => {\n\t\tthis.pressed$.next(true)\n\t}\n\n\tprivate handleMouseUp = () => {\n\t\tthis.pressed$.next(false)\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst chipClasses = {\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'h-8 px-4': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'text-sm': true,\n\t\t\t'font-medium': true,\n\t\t\t'border': true,\n\t\t\t'relative': true,\n\t\t\t'min-h-[32px]': true,\n\n\t\t\t// Background and text colors based on selection state\n\t\t\t'bg-secondary-container': this._selected,\n\t\t\t'text-secondary-onContainer': this._selected,\n\t\t\t'border-secondary-container': this._selected,\n\t\t\t'bg-surface-container': !this._selected,\n\t\t\t'text-surface-on': !this._selected,\n\t\t\t'border-outline-variant': !this._selected,\n\n\t\t\t// Hover states\n\t\t\t'hover:brightness-95': this._selected && !this.disabled,\n\t\t\t'hover:bg-surface-containerHigh': !this._selected && !this.disabled,\n\n\t\t\t// Pressed state\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Focus-visible state for better UX\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\n\t\t\t// Elevated style\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\n\t\t\t// Disabled state\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\tclass=${this.classMap(chipClasses)}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${this.handleMouseEnter}\n\t\t\t\t@mouseleave=${this.handleMouseLeave}\n\t\t\t\t@mousedown=${this.handleMouseDown}\n\t\t\t\t@mouseup=${this.handleMouseUp}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\taria-pressed=${this._selected ? 'true' : 'false'}\n\t\t\t\trole=\"checkbox\"\n\t\t\t\ttabindex=\"0\"\n\t\t\t>\n\t\t\t\t<!-- Icon container - conditionally shown using when directive -->\n\t\t\t\t${when(\n\t\t\t\t\tthis._selected || this.icon || this.iconSlotElements?.length > 0,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<span class=\"inline-flex w-[18px] h-[18px] items-center justify-center shrink-0\">\n\t\t\t\t\t\t\t${this._selected ? html`\n\t\t\t\t\t\t\t\t<span class=\"material-symbols-outlined text-base sm:text-[18px]\">\n\t\t\t\t\t\t\t\t\tcheck\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t` : this.icon ? html`\n\t\t\t\t\t\t\t\t<span class=\"material-symbols-outlined text-base sm:text-[18px]\">\n\t\t\t\t\t\t\t\t\t${this.icon}\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t` : html`\n\t\t\t\t\t\t\t\t<slot name=\"icon\"></slot>\n\t\t\t\t\t\t\t`}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t`\n\t\t\t\t)}\n\n\t\t\t\t<!-- Chip content -->\n\t\t\t\t<slot></slot>\n\n\t\t\t\t<!-- Remove button (if removable) -->\n\t\t\t\t${this.removable ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\tclass=\"ml-1 -mr-1 p-0.5 rounded-full hover:bg-surface-containerHighest transition-colors\"\n\t\t\t\t\t\t@click=${this.handleRemove}\n\t\t\t\t\t\taria-label=\"Remove filter\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"material-symbols-outlined text-sm sm:text-[16px]\">\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</button>\n\t\t\t\t` : ''}\n\t\t\t</button>\n\t\t`\n\t}\n}\n\n// Register the element with both names for backward compatibility\n// Check if not already registered to prevent duplicate registration errors\nif (!customElements.get('schmancy-filter-chip')) {\n\tcustomElements.define('schmancy-filter-chip', SchmancyFilterChip)\n}\n\n// For backward compatibility, register 'schmancy-chip' with a subclass\n// to avoid duplicate constructor registration error\nif (!customElements.get('schmancy-chip')) {\n\tclass SchmancyChipCompat extends SchmancyFilterChip {}\n\tcustomElements.define('schmancy-chip', SchmancyChipCompat)\n}\n\n// Export alias for backward compatibility\nexport { SchmancyFilterChip as SchmancyChip }\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-chip': SchmancyFilterChip\n\t\t'schmancy-filter-chip': SchmancyFilterChip\n\t}\n}\n\nexport type FilterChipChangeEvent = { value: string; selected: boolean }\nexport type FilterChipRemoveEvent = { value: string }\n// Alias for backward compatibility\nexport type SchmancyChipChangeEvent = FilterChipChangeEvent","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Assist chip component - prompts user actions like opening calendar events or sharing content\n * Pure Schmancy implementation with Tailwind CSS and RxJS state management\n */\n@customElement('schmancy-assist-chip')\nexport class SchmancyAssistChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ reflect: true }) value = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ reflect: true }) icon = ''\n\n\t/** Optional href for navigation */\n\t@property({ reflect: true }) href = ''\n\n\t/** Target for navigation (e.g., '_blank') */\n\t@property({ reflect: true }) target = ''\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true }) elevated = false\n\n\t// RxJS state streams\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state - only ripples needed for rendering\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprotected static shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true }\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Stream management for future extensions\n\t\t// Currently, states are handled directly in event handlers\n\t\t// This pipeline can be extended for more complex state interactions\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst button = this.shadowRoot?.querySelector('button')\n\t\tif (button) {\n\t\t\tconst rect = button.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch action event\n\t\tthis.dispatchEvent(new CustomEvent('action', {\n\t\t\tdetail: { value: this.value },\n\t\t\tbubbles: true,\n\t\t\tcomposed: true\n\t\t}))\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed$.next(true)\n\n\t\t\t// Simulate click\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleClick(clickEvent)\n\n\t\t\tsetTimeout(() => this.pressed$.next(false), 100)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\trender() {\n\t\tconst classes = {\n\t\t\t'relative': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'px-2 py-1 sm:px-3 sm:py-1.5 md:px-4 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors\n\t\t\t'bg-surface-container': !this.elevated,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'bg-surface-containerLow': this.elevated,\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// States\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled && !this.elevated,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Disabled\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=${classMap(classes)}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.hover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.hover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\trole=\"button\"\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t${this.icon ? html`\n\t\t\t\t\t<schmancy-icon class=\"text-sm sm:text-base\">${this.icon}</schmancy-icon>\n\t\t\t\t` : ''}\n\t\t\t\t<span class=\"text-xs sm:text-sm font-medium\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\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-assist-chip': SchmancyAssistChip\n\t}\n}\n\nexport type AssistChipActionEvent = { value: string }","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { map, takeUntil, tap } from 'rxjs/operators'\n\n/**\n * Input chip component - represents user-provided information that can be removed.\n *\n * IMPORTANT: Per Material Design 3 specification, input chips do NOT have selected state.\n * They represent discrete pieces of user input (like entered tags, selections from lists, etc.)\n * that can only be removed, not toggled on/off.\n *\n * Use cases:\n * - Displaying selected recipients in an email\n * - Showing applied filters that can be removed\n * - Tags or keywords entered by the user\n * - Selected items from a multi-select dropdown\n *\n * @fires click - Optional click event on chip body (value)\n * @fires remove - Dispatched when remove button is clicked (value)\n *\n * @example\n * ```html\n * <schmancy-input-chip value=\"john@example.com\" avatar=\"/avatars/john.jpg\">\n * John Doe\n * </schmancy-input-chip>\n * ```\n */\n@customElement('schmancy-input-chip')\nexport class SchmancyInputChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\tbutton {\n\t\tfont-family: inherit;\n\t}\n\n\t.avatar-img {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tobject-fit: cover;\n\t}\n\n\t/* Material Symbols font for icons */\n\t.material-symbols-outlined {\n\t\tfont-family: 'Material Symbols Outlined';\n\t\tfont-weight: normal;\n\t\tfont-style: normal;\n\t\tfont-size: 18px;\n\t\tline-height: 1;\n\t\tletter-spacing: normal;\n\t\ttext-transform: none;\n\t\tdisplay: inline-block;\n\t\twhite-space: nowrap;\n\t\tword-wrap: normal;\n\t\tdirection: ltr;\n\t\t-webkit-font-smoothing: antialiased;\n\t\ttext-rendering: optimizeLegibility;\n\t\t-moz-osx-font-smoothing: grayscale;\n\t\tfont-feature-settings: 'liga';\n\t\tvertical-align: middle;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ type: String, reflect: true })\n\tvalue: string = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ type: String, reflect: true })\n\ticon: string = ''\n\n\t/** Optional avatar image URL */\n\t@property({ type: String, reflect: true })\n\tavatar: string = ''\n\n\t/** Whether to show remove button (default true for input chips) */\n\t@property({ type: Boolean, reflect: true })\n\tremovable: boolean = true\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled: boolean = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true })\n\televated: boolean = false\n\n\t// RxJS state streams\n\tprivate chipHover$ = new BehaviorSubject<boolean>(false)\n\tprivate removeHover$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state from combined streams\n\t@state() private uiState = {\n\t\tchipHover: false,\n\t\tremoveHover: false,\n\t\tfocused: false,\n\t\tpressed: false\n\t}\n\n\t// Ripple effects\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\tprivate nextRippleId = 0\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\n\tstatic formAssociated = true\n\tinternals: ElementInternals | undefined\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Combine all UI state streams\n\t\tcombineLatest([\n\t\t\tthis.chipHover$,\n\t\t\tthis.removeHover$,\n\t\t\tthis.focused$,\n\t\t\tthis.pressed$\n\t\t]).pipe(\n\t\t\tmap(([chipHover, removeHover, focused, pressed]) => ({\n\t\t\t\tchipHover,\n\t\t\t\tremoveHover,\n\t\t\t\tfocused,\n\t\t\t\tpressed\n\t\t\t})),\n\t\t\ttap(state => {\n\t\t\t\tthis.uiState = state\n\t\t\t}),\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleChipClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst chip = this.shadowRoot?.querySelector('.chip-container') as HTMLElement\n\t\tif (chip) {\n\t\t\tconst rect = chip.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Dispatch optional click event (for custom handling if needed)\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('click', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t})\n\t\t)\n\t}\n\n\tprivate handleRemove = (e: Event) => {\n\t\tif (this.disabled) return\n\n\t\te.stopPropagation()\n\n\t\t// Dispatch remove event\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('remove', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t})\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Delete or Backspace removes the chip\n\t\tif ((e.key === 'Delete' || e.key === 'Backspace') && this.removable) {\n\t\t\te.preventDefault()\n\t\t\tthis.handleRemove(e)\n\t\t}\n\t\t// Enter can optionally trigger click\n\t\telse if (e.key === 'Enter') {\n\t\t\te.preventDefault()\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleChipClick(clickEvent)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst chipClasses = {\n\t\t\t'chip-container': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'pl-3': !this.avatar, // Less padding if avatar present\n\t\t\t'pl-1': this.avatar, // Tight padding for avatar\n\t\t\t'pr-2': this.removable,\n\t\t\t'pr-3': !this.removable,\n\t\t\t'py-1 sm:py-1.5 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-default': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'text-xs sm:text-sm': true,\n\t\t\t'font-medium': true,\n\t\t\t'relative': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors\n\t\t\t'bg-surface-container': true,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// Hover state (subtle on chip body)\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled && !this.uiState.removeHover,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\n\t\t\t// Focus-visible state for better UX\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\n\t\t\t// Disabled state\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\tconst removeButtonClasses = {\n\t\t\t\"size-5 sm:size-6\":true,\n\t\t\t'rounded-full': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\n\t\t\t// Hover state for remove button\n\t\t\t'bg-error-container': this.uiState.removeHover && !this.disabled,\n\t\t\t'text-error-onContainer': this.uiState.removeHover && !this.disabled,\n\t\t\t'hover:scale-110': this.uiState.removeHover && !this.disabled,\n\n\t\t\t// Default state\n\t\t\t'hover:bg-surface-containerHighest': !this.uiState.removeHover && !this.disabled,\n\t\t\t'opacity-50': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${classMap(chipClasses)}\n\t\t\t\t@click=${this.handleChipClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.chipHover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.chipHover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\trole=\"button\"\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t<!-- Avatar image (if provided) -->\n\t\t\t\t${this.avatar ? html`\n\t\t\t\t\t<img\n\t\t\t\t\t\tsrc=${this.avatar}\n\t\t\t\t\t\talt=\"\"\n\t\t\t\t\t\tclass=\"avatar-img rounded-full sm:size-6\"\n\t\t\t\t\t/>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Icon (if provided and no avatar) -->\n\t\t\t\t${this.icon && !this.avatar ? html`\n\t\t\t\t\t<span class=\"material-symbols-outlined rounded-full text-base sm:text-[18px]\">\n\t\t\t\t\t\t${this.icon}\n\t\t\t\t\t</span>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Chip content -->\n\t\t\t\t<span>\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Remove button (shown by default for input chips) -->\n\t\t\t\t${this.removable ? html`\n\t\t\t\t\t<button\n\t\t\t\t\t\tclass=${classMap(removeButtonClasses)}\n\t\t\t\t\t\t@click=${this.handleRemove}\n\t\t\t\t\t\t@mouseenter=${() => this.removeHover$.next(true)}\n\t\t\t\t\t\t@mouseleave=${() => this.removeHover$.next(false)}\n\t\t\t\t\t\taria-label=\"Remove\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"material-symbols-outlined text-sm sm:text-[16px]\">\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</button>\n\t\t\t\t` : ''}\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\n\t\t\t\t\t></span>\n\t\t\t\t`)}\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-input-chip': SchmancyInputChip\n\t}\n}\n\nexport type InputChipClickEvent = { value: string }\nexport type InputChipRemoveEvent = { value: string }","import { TailwindElement } from '@mixins/tailwind.mixin'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\n/**\n * Suggestion chip component - provides contextual recommendations to users\n *\n * IMPORTANT: Suggestion chips do NOT have a selected state. They are designed to\n * provide suggestions and recommendations that trigger actions when clicked.\n * Unlike filter chips, they cannot be toggled on/off.\n *\n * Pure Schmancy implementation with Tailwind CSS and RxJS state management\n */\n@customElement('schmancy-suggestion-chip')\nexport class SchmancySuggestionChip extends TailwindElement(css`\n\t:host {\n\t\tdisplay: inline-block;\n\t\toutline: none;\n\t\tmin-width:fit-content\n\t}\n\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: rgba(0, 0, 0, 0.08);\n\t\tpointer-events: none;\n\t}\n\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/** Value identifier for the chip */\n\t@property({ reflect: true }) value = ''\n\n\t/** Optional icon name (Material Symbols) */\n\t@property({ reflect: true }) icon = ''\n\n\t/** Optional href for navigation */\n\t@property({ reflect: true }) href = ''\n\n\t/** Target for navigation (e.g., '_blank') */\n\t@property({ reflect: true }) target = ''\n\n\t/** Disable the chip */\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\n\t/** Elevated style variant */\n\t@property({ type: Boolean, reflect: true }) elevated = false\n\n\t// RxJS state streams\n\tprivate hover$ = new BehaviorSubject<boolean>(false)\n\tprivate pressed$ = new BehaviorSubject<boolean>(false)\n\tprivate focused$ = new BehaviorSubject<boolean>(false)\n\n\t// UI state - only ripples needed for rendering\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprotected static shadowRootOptions = { ...LitElement.shadowRootOptions, delegatesFocus: true }\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Stream management for future extensions\n\t\t// Currently, states are handled directly in event handlers\n\t\t// This pipeline can be extended for more complex state interactions\n\t\tcombineLatest([\n\t\t\tthis.hover$,\n\t\t\tthis.pressed$,\n\t\t\tthis.focused$\n\t\t]).pipe(\n\t\t\t// States are managed through event handlers directly\n\t\t\t// This pipeline is kept for potential future state combinations\n\t\t\ttakeUntil(this.disconnecting)\n\t\t).subscribe()\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled) return\n\n\t\t// Add ripple effect\n\t\tconst button = this.shadowRoot?.querySelector('button')\n\t\tif (button) {\n\t\t\tconst rect = button.getBoundingClientRect()\n\t\t\tconst x = e.clientX - rect.left\n\t\t\tconst y = e.clientY - rect.top\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\t// Remove ripple after animation\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\t\t}\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch action event\n\t\tthis.dispatchEvent(new CustomEvent('action', {\n\t\t\tdetail: { value: this.value },\n\t\t\tbubbles: true,\n\t\t\tcomposed: true\n\t\t}))\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled) return\n\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed$.next(true)\n\n\t\t\t// Simulate click\n\t\t\tconst clickEvent = new MouseEvent('click', {\n\t\t\t\tbubbles: true,\n\t\t\t\tcancelable: true,\n\t\t\t\tclientX: 0,\n\t\t\t\tclientY: 0\n\t\t\t})\n\t\t\tthis.handleClick(clickEvent)\n\n\t\t\tsetTimeout(() => this.pressed$.next(false), 100)\n\t\t}\n\t}\n\n\tprivate handleFocus = () => {\n\t\tthis.focused$.next(true)\n\t}\n\n\tprivate handleBlur = () => {\n\t\tthis.focused$.next(false)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'relative': true,\n\t\t\t'inline-flex': true,\n\t\t\t'items-center': true,\n\t\t\t'gap-1 sm:gap-1.5 md:gap-2': true,\n\t\t\t'px-2 py-1 sm:px-3 sm:py-1.5 md:px-4 md:py-2': true,\n\t\t\t'rounded-full': true,\n\t\t\t'cursor-pointer': !this.disabled,\n\t\t\t'transition-all': true,\n\t\t\t'duration-200': true,\n\t\t\t'select-none': true,\n\t\t\t'overflow-hidden': true,\n\n\t\t\t// Colors - slightly different from assist chips\n\t\t\t'bg-surface-containerLow': !this.elevated,\n\t\t\t'text-surface-on': true,\n\n\t\t\t// Elevated variant\n\t\t\t'bg-surface': this.elevated,\n\t\t\t'shadow-md': this.elevated && !this.disabled,\n\n\t\t\t// States\n\t\t\t'hover:bg-surface-containerHigh': !this.disabled,\n\t\t\t'hover:shadow-lg': this.elevated && !this.disabled,\n\t\t\t'focus-visible:outline': !this.disabled,\n\t\t\t'focus-visible:outline-2': !this.disabled,\n\t\t\t'focus-visible:outline-primary-default': !this.disabled,\n\t\t\t'focus-visible:outline-offset-2': !this.disabled,\n\t\t\t'active:scale-95': !this.disabled,\n\n\t\t\t// Disabled\n\t\t\t'opacity-50': this.disabled,\n\t\t\t'cursor-not-allowed': this.disabled\n\t\t}\n\n\t\treturn html`\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=${classMap(classes)}\n\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@mouseenter=${() => this.hover$.next(true)}\n\t\t\t\t@mouseleave=${() => this.hover$.next(false)}\n\t\t\t\t@mousedown=${() => this.pressed$.next(true)}\n\t\t\t\t@mouseup=${() => this.pressed$.next(false)}\n\t\t\t\t@focus=${this.handleFocus}\n\t\t\t\t@blur=${this.handleBlur}\n\t\t\t\ttabindex=${this.disabled ? '-1' : '0'}\n\t\t\t\trole=\"button\"\n\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\taria-label=${this.value}\n\t\t\t>\n\t\t\t\t${this.icon ? html`\n\t\t\t\t\t<schmancy-icon class=\"text-sm sm:text-base\">${this.icon}</schmancy-icon>\n\t\t\t\t` : ''}\n\t\t\t\t<span class=\"text-xs sm:text-sm font-medium\">\n\t\t\t\t\t<slot></slot>\n\t\t\t\t</span>\n\n\t\t\t\t<!-- Ripple effects -->\n\t\t\t\t${this.ripples.map(ripple => html`\n\t\t\t\t\t<span\n\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\tstyle=\"left: ${ripple.x}px; top: ${ripple.y}px;\"\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-suggestion-chip': SchmancySuggestionChip\n\t}\n}\n\nexport type SuggestionChipActionEvent = { value: string }","import { $LitElement } from '@mixins/index'\nimport { html, PropertyValues } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { SchmancyFilterChip as SchmancyChip } from './filter-chip'\nimport type { FilterChipChangeEvent as SchmancyChipChangeEvent } from './filter-chip'\nimport { BehaviorSubject, combineLatest } from 'rxjs'\nimport { takeUntil, distinctUntilChanged, debounceTime } from 'rxjs/operators'\n\n@customElement('schmancy-chips')\nexport default class SchmancyChips extends $LitElement() {\n\t// RxJS state streams - initialized with undefined to detect if properties were set\n\tprivate value$ = new BehaviorSubject<string>('')\n\tprivate values$ = new BehaviorSubject<string[]>([])\n\n\t// Track if properties were initialized from attributes/properties\n\tprivate _value: string = ''\n\tprivate _values: string[] = []\n\tprivate _multi: boolean = false\n\n\t// Track if properties have been explicitly set\n\tprivate _valueSet: boolean = false\n\tprivate _valuesSet: boolean = false\n\n\t/**\n\t * @deprecated Use .values for multi-selection or .value for single-selection instead.\n\t * The mode is now automatically determined based on which property is used.\n\t */\n\t@property({\n\t\ttype: Boolean,\n\t\treflect: true,\n\t})\n\tget multi(): boolean {\n\t\treturn this._multi\n\t}\n\tset multi(value: boolean) {\n\t\tthis._multi = value\n\t\t// Note: We don't update any BehaviorSubject here as mode is now computed\n\t}\n\n\t/**\n\t * Automatically determines the selection mode based on which properties are in use\n\t */\n\tprivate get mode(): 'multi' | 'single' | 'none' {\n\t\t// Check if values array is being used (explicitly set)\n\t\tif (this._valuesSet) {\n\t\t\treturn 'multi'\n\t\t}\n\t\t// Check if value string is being used (explicitly set)\n\t\tif (this._valueSet) {\n\t\t\treturn 'single'\n\t\t}\n\t\t// Check if either property has been set via attributes\n\t\tif (this.hasAttribute('values')) {\n\t\t\treturn 'multi'\n\t\t}\n\t\tif (this.hasAttribute('value')) {\n\t\t\treturn 'single'\n\t\t}\n\t\t// Fallback to deprecated multi prop for backward compatibility\n\t\tif (this._multi === true) {\n\t\t\treturn 'multi'\n\t\t}\n\t\t// Default to none (no selection management)\n\t\treturn 'none'\n\t}\n\n\t@property({\n\t\ttype: Array,\n\t\treflect: true,\n\t})\n\tget values(): string[] {\n\t\treturn this._values\n\t}\n\tset values(value: string[]) {\n\t\tthis._values = value || []\n\t\tthis._valuesSet = true // Mark that values has been explicitly set\n\t\tthis.values$.next(this._values)\n\t}\n\n\t@property({\n\t\ttype: String,\n\t\treflect: true,\n\t})\n\tget value(): string {\n\t\treturn this._value\n\t}\n\tset value(value: string) {\n\t\tthis._value = value || ''\n\t\tthis._valueSet = true // Mark that value has been explicitly set\n\t\tthis.value$.next(this._value)\n\t}\n\n\t@queryAssignedElements({\n\t\tselector:\n\t\t\t'schmancy-chip, schmancy-filter-chip, schmancy-assist-chip, schmancy-input-chip, schmancy-suggestion-chip',\n\t\tflatten: true,\n\t})\n\tchips!: (SchmancyChip | HTMLElement)[]\n\n\t@property({\n\t\ttype: Boolean,\n\t\treflect: true,\n\t})\n\twrap: boolean = false\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Initialize BehaviorSubjects with current property values\n\t\t// This ensures properties set before connectedCallback are respected\n\t\tthis.value$.next(this._value)\n\t\tthis.values$.next(this._values)\n\n\t\t// Set up reactive pipeline for state synchronization\n\t\tcombineLatest([\n\t\t\tthis.value$.pipe(distinctUntilChanged()),\n\t\t\tthis.values$.pipe(\n\t\t\t\tdistinctUntilChanged((prev, curr) => prev.length === curr.length && prev.every((v, i) => v === curr[i])),\n\t\t\t),\n\t\t])\n\t\t\t.pipe(\n\t\t\t\tdebounceTime(0), // Ensure DOM is ready\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(([value, values]) => {\n\t\t\t\t// Reactively update chip states based on container state and auto-detected mode\n\t\t\t\tthis.updateChipStates(this.mode, value, values)\n\t\t\t})\n\t}\n\n\tprivate updateChipStates(mode: 'multi' | 'single' | 'none', value: string, values: string[]) {\n\t\tif (!this.chips) return\n\n\t\t// If mode is 'none', don't manage selection state\n\t\tif (mode === 'none') return\n\n\t\tthis.chips.forEach(chip => {\n\t\t\tif ('value' in chip && 'selected' in chip) {\n\t\t\t\tconst filterChip = chip as SchmancyChip\n\t\t\t\tif (mode === 'multi') {\n\t\t\t\t\t// In multi mode: only select if values array explicitly includes this chip's value\n\t\t\t\t\tfilterChip.selected = values.length > 0 && values.includes(filterChip.value)\n\t\t\t\t} else if (mode === 'single') {\n\t\t\t\t\t// In single mode: only select if value is non-empty AND matches this chip's value\n\t\t\t\t\t// This prevents chips from being selected when value is empty string\n\t\t\t\t\tfilterChip.selected = value !== '' && value === filterChip.value\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t}\n\n\tasync change(e: CustomEvent<SchmancyChipChangeEvent>) {\n\t\te.preventDefault()\n\t\te.stopPropagation()\n\n\t\t// If mode is 'none', don't handle selection changes\n\t\tif (this.mode === 'none') return\n\n\t\tconst { value, selected } = e.detail\n\n\t\t// Update the reactive streams and internal tracking, which will trigger state synchronization\n\t\tif (this.mode === 'multi') {\n\t\t\tif (selected) {\n\t\t\t\t// Add value if not already present\n\t\t\t\tif (!this._values.includes(value)) {\n\t\t\t\t\tthis._values = [...this._values, value]\n\t\t\t\t\tthis.values$.next(this._values)\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Remove value\n\t\t\t\tthis._values = this._values.filter(v => v !== value)\n\t\t\t\tthis.values$.next(this._values)\n\t\t\t}\n\t\t} else if (this.mode === 'single') {\n\t\t\t// Single selection mode\n\t\t\tthis._value = selected ? value : ''\n\t\t\tthis.value$.next(this._value)\n\t\t}\n\n\t\t// Request update to trigger re-render and property reflection\n\t\tthis.requestUpdate()\n\n\t\t// Dispatch change event with appropriate detail based on mode\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent<SchmancyChipsChangeEvent>('change', {\n\t\t\t\tdetail: this.mode === 'multi' ? this._values : this._value,\n\t\t\t\tbubbles: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprotected firstUpdated(_changedProperties: PropertyValues): void {\n\t\tsuper.firstUpdated(_changedProperties)\n\t\t// Initial state synchronization will happen through the reactive pipeline\n\t\t// Force an initial update to ensure chips are synchronized\n\t\tthis.updateChipStates(this.mode, this._value, this._values)\n\t}\n\n\tprotected render(): unknown {\n\t\tconst containerClasses = this.classMap({\n\t\t\t'inset-2': true,\n\t\t\tflex: true,\n\t\t\t'gap-2': true,\n\t\t\t'items-center': true,\n\t\t\t'flex-wrap': this.wrap,\n\t\t\t'overflow-x-auto': !this.wrap,\n\t\t\t'scrollbar-hide': !this.wrap,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div class=${containerClasses} @change=${this.change}>\n\t\t\t\t<slot\n\t\t\t\t\t@slotchange=${() => {\n\t\t\t\t\t\t// When slot changes, trigger state update through reactive pipeline\n\t\t\t\t\t\tthis.updateChipStates(this.mode, this._value, this._values)\n\t\t\t\t\t}}\n\t\t\t\t></slot>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-chips': SchmancyChips\n\t}\n}\nexport type SchmancyChipsChangeEvent = string | Array<string>\n"],"names":["SchmancyFilterChip","TailwindElement","css","super","this","value","_selected","icon","removable","disabled","elevated","hover$","BehaviorSubject","pressed$","focused$","handleClick","dispatchEvent","CustomEvent","detail","selected","bubbles","composed","handleRemove","e","stopPropagation","handleKeyDown","key","preventDefault","handleMouseEnter","next","handleMouseLeave","handleMouseDown","handleMouseUp","handleFocus","handleBlur","internals","attachInternals","oldValue","requestUpdate","form","connectedCallback","combineLatest","pipe","takeUntil","disconnecting","subscribe","render","chipClasses","border","relative","html","classMap","when","iconSlotElements","length","shadowRootOptions","LitElement","delegatesFocus","formAssociated","_u","__decorateClass","property","type","String","reflect","prototype","Boolean","queryAssignedElements","slot","customElements","get","define","SchmancyChipCompat","SchmancyAssistChip","constructor","arguments","href","target","ripples","nextRippleId","button","shadowRoot","querySelector","rect","getBoundingClientRect","x","clientX","left","y","clientY","top","id","setTimeout","filter","r","window","open","location","clickEvent","MouseEvent","cancelable","classes","map","ripple","state","customElement","SchmancyInputChip","avatar","chipHover$","removeHover$","uiState","chipHover","removeHover","focused","pressed","handleChipClick","chip","tap","removeButtonClasses","SchmancySuggestionChip","SchmancyChips","$LitElement","value$","values$","_value","_values","_multi","_valueSet","_valuesSet","wrap","multi","mode","hasAttribute","values","distinctUntilChanged","prev","curr","every","v","i","debounceTime","updateChipStates","chips","forEach","filterChip","includes","_changedProperties","firstUpdated","containerClasses","flex","change","Array","selector","flatten"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"media-CL9LNHic.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardAction extends TailwindElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tgap: 0.5rem;\n\t\tpadding: 0.5rem 1rem;\n\t\talign-items: center;\n\t\tjustify-content: flex-end;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardAction\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tborder-radius: 12px; /* M3 spec: 12px for cards */\n\t\ttransition: box-shadow 200ms cubic-bezier(0.4, 0, 0.2, 1);\n\t\toutline: none;\n\t}\n\n\t/* Type-specific base styles */\n\t:host([type='elevated']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-low);\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='filled']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-highest);\n\t\tbox-shadow: var(--schmancy-sys-elevation-0);\n\t}\n\n\t:host([type='outlined']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-default);\n\t\tborder: 1px solid var(--schmancy-sys-color-outline-variant);\n\t\tbox-shadow: var(--schmancy-sys-elevation-0);\n\t}\n\n\t/* Interactive state layers */\n\t:host([interactive]) {\n\t\tcursor: pointer;\n\t\t-webkit-tap-highlight-color: transparent;\n\t}\n\n\t:host([interactive]:hover:not([disabled])) .state-layer {\n\t\topacity: 0.08;\n\t}\n\n\t:host([interactive]:focus-visible:not([disabled])) .state-layer {\n\t\topacity: 0.12;\n\t}\n\n\t:host([interactive][pressed]:not([disabled])) .state-layer {\n\t\topacity: 0.12;\n\t}\n\n\t/* Elevated interactive states */\n\t:host([type='elevated'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-2);\n\t}\n\n\t:host([type='elevated'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Filled interactive states */\n\t:host([type='filled'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='filled'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Outlined interactive states */\n\t:host([type='outlined'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='outlined'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Disabled state */\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t\topacity: 0.38;\n\t}\n\n\t/* State layer overlay */\n\t.state-layer {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder-radius: inherit;\n\t\tbackground-color: var(--schmancy-sys-color-surface-on);\n\t\topacity: 0;\n\t\tpointer-events: none;\n\t\ttransition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1);\n\t}\n\n\t/* Focus ring */\n\t:host([interactive]:focus-visible:not([disabled])) {\n\t\toutline: 2px solid var(--schmancy-sys-color-primary);\n\t\toutline-offset: 2px;\n\t}\n\n\t/* Ripple effect container */\n\t.ripple-container {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder-radius: inherit;\n\t\toverflow: hidden;\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: var(--schmancy-sys-color-surface-on);\n\t\topacity: 0.12;\n\t\tpointer-events: none;\n\t}\n\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/* Content container */\n\t.content {\n\t\tposition: relative;\n\t\theight: 100%;\n\t\twidth: 100%;\n\t\tborder-radius: inherit;\n\t}\n`) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tmode: 'open',\n\t\tdelegatesFocus: true,\n\t}\n\n\t/**\n\t * The visual style of the card.\n\t * @default 'elevated'\n\t */\n\t@property({ reflect: true })\n\ttype: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\n\t/**\n\t * Makes the card interactive (clickable).\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tinteractive = false\n\n\t/**\n\t * Disables the card.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled = false\n\n\t/**\n\t * Indicates the card is being dragged.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdragged = false\n\n\t/**\n\t * URL to navigate to when card is clicked (makes it act like a link).\n\t */\n\t@property()\n\thref?: string\n\n\t/**\n\t * Target for the link navigation.\n\t */\n\t@property()\n\ttarget?: string\n\n\t/**\n\t * ARIA role for accessibility.\n\t */\n\t@property({ attribute: 'role' })\n\toverride role = 'article'\n\n\t/**\n\t * ARIA label for accessibility.\n\t */\n\t@property({ attribute: 'aria-label' })\n\toverride ariaLabel: string = ''\n\n\t// Internal state for interaction feedback\n\t@state() pressed = false\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Set appropriate ARIA attributes for interactive cards\n\t\tif (this.interactive && !this.disabled) {\n\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t}\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Update ARIA attributes when interactive or disabled state changes\n\t\tif (changedProperties.has('interactive') || changedProperties.has('disabled')) {\n\t\t\tif (this.interactive && !this.disabled) {\n\t\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.removeAttribute('tabindex')\n\t\t\t\tif (this.role === 'button' || this.role === 'link') {\n\t\t\t\t\tthis.role = 'article'\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Add ripple effect at click position\n\t\tconst rect = this.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\t\tconst y = e.clientY - rect.top\n\t\tconst id = this.nextRippleId++\n\n\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t// Remove ripple after animation completes\n\t\tsetTimeout(() => {\n\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t}, 600)\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch click event for parent components to handle\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\tdetail: { value: this.type },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Activate on Enter or Space for keyboard navigation\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed = true\n\t\t\tthis.setAttribute('pressed', '')\n\n\t\t\t// Simulate click\n\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\tconst x = rect.width / 2\n\t\t\tconst y = rect.height / 2\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\n\t\t\tif (this.href) {\n\t\t\t\tif (this.target === '_blank') {\n\t\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t\t} else {\n\t\t\t\t\twindow.location.href = this.href\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\t\tdetail: { value: this.type },\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}\n\t}\n\n\tprivate handleKeyUp = (e: KeyboardEvent) => {\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\tthis.pressed = false\n\t\t\tthis.removeAttribute('pressed')\n\t\t}\n\t}\n\n\tprivate handleMouseDown = () => {\n\t\tif (this.disabled || !this.interactive) return\n\t\tthis.pressed = true\n\t\tthis.setAttribute('pressed', '')\n\t}\n\n\tprivate handleMouseUp = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\tprivate handleMouseLeave = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\tprotected render() {\n\t\tconst containerClasses = classMap({\n\t\t\t'card-container': true,\n\t\t\tinteractive: this.interactive && !this.disabled,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${containerClasses}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@keyup=${this.handleKeyUp}\n\t\t\t\t@mousedown=${this.handleMouseDown}\n\t\t\t\t@mouseup=${this.handleMouseUp}\n\t\t\t\t@mouseleave=${this.handleMouseLeave}\n\t\t\t\taria-label=${ifDefined(this.ariaLabel)}\n\t\t\t\taria-disabled=${this.disabled ? 'true' : 'false'}\n\t\t\t>\n\t\t\t\t<!-- State layer for hover/focus/pressed states -->\n\t\t\t\t<div class=\"state-layer\"></div>\n\n\t\t\t\t<!-- Ripple container for click effects -->\n\t\t\t\t${this.interactive\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<div class=\"ripple-container\">\n\t\t\t\t\t\t\t\t${this.ripples.map(\n\t\t\t\t\t\t\t\t\tripple => html`\n\t\t\t\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\t\t\t\t\t\tstyle=\"\n\t\t\t\t\t\t\t\t\t\t\t\tleft: ${ripple.x}px;\n\t\t\t\t\t\t\t\t\t\t\t\ttop: ${ripple.y}px;\n\t\t\t\t\t\t\t\t\t\t\t\twidth: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\theight: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-left: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-top: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\"\n\t\t\t\t\t\t\t\t\t\t></span>\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</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t: ''}\n\n\t\t\t\t<!-- Card content -->\n\t\t\t\t<div class=\"content\">\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'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-content\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tpadding: 1rem;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\theight: 200px;\n\t\toverflow: hidden;\n\t}\n\t\n\t/* Allow height to be overridden when used in flex/grid layouts */\n\t:host-context(.h-full) {\n\t\theight: 100%;\n\t}\n\t\n\t::slotted(img),\n\timg {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tobject-position: center;\n\t}\n\t\n\t/* Object fit styles based on fit attribute */\n\t:host([fit=\"contain\"]) img,\n\t:host([fit=\"contain\"]) ::slotted(img) {\n\t\tobject-fit: contain;\n\t}\n\t\n\t:host([fit=\"cover\"]) img,\n\t:host([fit=\"cover\"]) ::slotted(img) {\n\t\tobject-fit: cover;\n\t}\n\t\n\t:host([fit=\"fill\"]) img,\n\t:host([fit=\"fill\"]) ::slotted(img) {\n\t\tobject-fit: fill;\n\t}\n\t\n\t:host([fit=\"none\"]) img,\n\t:host([fit=\"none\"]) ::slotted(img) {\n\t\tobject-fit: none;\n\t}\n\t\n\t:host([fit=\"scale-down\"]) img,\n\t:host([fit=\"scale-down\"]) ::slotted(img) {\n\t\tobject-fit: scale-down;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String, reflect: true })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\t\n\t@property({ type: String })\n\talt: string = ''\n\n\tprotected render(): unknown {\n\t\t// If src is provided, render an img element\n\t\t// Otherwise, allow users to slot their own content\n\t\treturn this.src \n\t\t\t? html`<img src=\"${this.src}\" alt=\"${this.alt}\" />` \n\t\t\t: html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n"],"names":["SchmancyCardAction","TailwindElement","css","render","html","customElement","SchmancyCard","super","arguments","this","type","interactive","disabled","dragged","role","ariaLabel","pressed","ripples","nextRippleId","handleClick","e","rect","getBoundingClientRect","x","clientX","left","y","clientY","top","id","setTimeout","filter","r","href","target","window","open","location","dispatchEvent","CustomEvent","detail","value","bubbles","composed","handleKeyDown","key","preventDefault","setAttribute","width","height","handleKeyUp","removeAttribute","handleMouseDown","handleMouseUp","handleMouseLeave","connectedCallback","changedProperties","updated","has","containerClasses","classMap","ifDefined","map","ripple","shadowRootOptions","LitElement","mode","delegatesFocus","__decorateClass","property","reflect","prototype","Boolean","attribute","state","SchmancyCardContent","SchmancyCardMedia","constructor","src","fit","alt","String"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"media-nVQjNoX7.js","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardAction extends TailwindElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tgap: 0.5rem;\n\t\tpadding: 0.5rem 1rem;\n\t\talign-items: center;\n\t\tjustify-content: flex-end;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardAction\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tborder-radius: 12px; /* M3 spec: 12px for cards */\n\t\ttransition: box-shadow 200ms cubic-bezier(0.4, 0, 0.2, 1);\n\t\toutline: none;\n\t}\n\n\t/* Type-specific base styles */\n\t:host([type='elevated']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-low);\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='filled']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-highest);\n\t\tbox-shadow: var(--schmancy-sys-elevation-0);\n\t}\n\n\t:host([type='outlined']) {\n\t\tbackground-color: var(--schmancy-sys-color-surface-default);\n\t\tborder: 1px solid var(--schmancy-sys-color-outline-variant);\n\t\tbox-shadow: var(--schmancy-sys-elevation-0);\n\t}\n\n\t/* Interactive state layers */\n\t:host([interactive]) {\n\t\tcursor: pointer;\n\t\t-webkit-tap-highlight-color: transparent;\n\t}\n\n\t:host([interactive]:hover:not([disabled])) .state-layer {\n\t\topacity: 0.08;\n\t}\n\n\t:host([interactive]:focus-visible:not([disabled])) .state-layer {\n\t\topacity: 0.12;\n\t}\n\n\t:host([interactive][pressed]:not([disabled])) .state-layer {\n\t\topacity: 0.12;\n\t}\n\n\t/* Elevated interactive states */\n\t:host([type='elevated'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-2);\n\t}\n\n\t:host([type='elevated'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Filled interactive states */\n\t:host([type='filled'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='filled'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Outlined interactive states */\n\t:host([type='outlined'][interactive]:hover:not([disabled])) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-1);\n\t}\n\n\t:host([type='outlined'][dragged]) {\n\t\tbox-shadow: var(--schmancy-sys-elevation-3);\n\t}\n\n\t/* Disabled state */\n\t:host([disabled]) {\n\t\tpointer-events: none;\n\t\topacity: 0.38;\n\t}\n\n\t/* State layer overlay */\n\t.state-layer {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder-radius: inherit;\n\t\tbackground-color: var(--schmancy-sys-color-surface-on);\n\t\topacity: 0;\n\t\tpointer-events: none;\n\t\ttransition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1);\n\t}\n\n\t/* Focus ring */\n\t:host([interactive]:focus-visible:not([disabled])) {\n\t\toutline: 2px solid var(--schmancy-sys-color-primary);\n\t\toutline-offset: 2px;\n\t}\n\n\t/* Ripple effect container */\n\t.ripple-container {\n\t\tposition: absolute;\n\t\tinset: 0;\n\t\tborder-radius: inherit;\n\t\toverflow: hidden;\n\t\tpointer-events: none;\n\t}\n\n\t.ripple {\n\t\tposition: absolute;\n\t\tborder-radius: 50%;\n\t\ttransform: scale(0);\n\t\tanimation: ripple 600ms linear;\n\t\tbackground-color: var(--schmancy-sys-color-surface-on);\n\t\topacity: 0.12;\n\t\tpointer-events: none;\n\t}\n\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/* Content container */\n\t.content {\n\t\tposition: relative;\n\t\theight: 100%;\n\t\twidth: 100%;\n\t\tborder-radius: inherit;\n\t}\n`) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tmode: 'open',\n\t\tdelegatesFocus: true,\n\t}\n\n\t/**\n\t * The visual style of the card.\n\t * @default 'elevated'\n\t */\n\t@property({ reflect: true })\n\ttype: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\n\t/**\n\t * Makes the card interactive (clickable).\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tinteractive = false\n\n\t/**\n\t * Disables the card.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdisabled = false\n\n\t/**\n\t * Indicates the card is being dragged.\n\t * @default false\n\t */\n\t@property({ type: Boolean, reflect: true })\n\tdragged = false\n\n\t/**\n\t * URL to navigate to when card is clicked (makes it act like a link).\n\t */\n\t@property()\n\thref?: string\n\n\t/**\n\t * Target for the link navigation.\n\t */\n\t@property()\n\ttarget?: string\n\n\t/**\n\t * ARIA role for accessibility.\n\t */\n\t@property({ attribute: 'role' })\n\toverride role = 'article'\n\n\t/**\n\t * ARIA label for accessibility.\n\t */\n\t@property({ attribute: 'aria-label' })\n\toverride ariaLabel: string = ''\n\n\t// Internal state for interaction feedback\n\t@state() pressed = false\n\t@state() private ripples: Array<{ x: number; y: number; id: number }> = []\n\n\tprivate nextRippleId = 0\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\n\t\t// Set appropriate ARIA attributes for interactive cards\n\t\tif (this.interactive && !this.disabled) {\n\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t}\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\n\t\t// Update ARIA attributes when interactive or disabled state changes\n\t\tif (changedProperties.has('interactive') || changedProperties.has('disabled')) {\n\t\t\tif (this.interactive && !this.disabled) {\n\t\t\t\tthis.setAttribute('tabindex', '0')\n\t\t\t\tif (!this.role || this.role === 'article') {\n\t\t\t\t\tthis.role = this.href ? 'link' : 'button'\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.removeAttribute('tabindex')\n\t\t\t\tif (this.role === 'button' || this.role === 'link') {\n\t\t\t\t\tthis.role = 'article'\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate handleClick = (e: MouseEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Add ripple effect at click position\n\t\tconst rect = this.getBoundingClientRect()\n\t\tconst x = e.clientX - rect.left\n\t\tconst y = e.clientY - rect.top\n\t\tconst id = this.nextRippleId++\n\n\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t// Remove ripple after animation completes\n\t\tsetTimeout(() => {\n\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t}, 600)\n\n\t\t// Navigate if href is provided\n\t\tif (this.href) {\n\t\t\tif (this.target === '_blank') {\n\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t} else {\n\t\t\t\twindow.location.href = this.href\n\t\t\t}\n\t\t}\n\n\t\t// Dispatch click event for parent components to handle\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\tdetail: { value: this.type },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\tif (this.disabled || !this.interactive) return\n\n\t\t// Activate on Enter or Space for keyboard navigation\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\te.preventDefault()\n\t\t\tthis.pressed = true\n\t\t\tthis.setAttribute('pressed', '')\n\n\t\t\t// Simulate click\n\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\tconst x = rect.width / 2\n\t\t\tconst y = rect.height / 2\n\t\t\tconst id = this.nextRippleId++\n\n\t\t\tthis.ripples = [...this.ripples, { x, y, id }]\n\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.ripples = this.ripples.filter(r => r.id !== id)\n\t\t\t}, 600)\n\n\t\t\tif (this.href) {\n\t\t\t\tif (this.target === '_blank') {\n\t\t\t\t\twindow.open(this.href, '_blank')\n\t\t\t\t} else {\n\t\t\t\t\twindow.location.href = this.href\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.dispatchEvent(\n\t\t\t\tnew CustomEvent('schmancy-click', {\n\t\t\t\t\tdetail: { value: this.type },\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}\n\t}\n\n\tprivate handleKeyUp = (e: KeyboardEvent) => {\n\t\tif (e.key === 'Enter' || e.key === ' ') {\n\t\t\tthis.pressed = false\n\t\t\tthis.removeAttribute('pressed')\n\t\t}\n\t}\n\n\tprivate handleMouseDown = () => {\n\t\tif (this.disabled || !this.interactive) return\n\t\tthis.pressed = true\n\t\tthis.setAttribute('pressed', '')\n\t}\n\n\tprivate handleMouseUp = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\tprivate handleMouseLeave = () => {\n\t\tthis.pressed = false\n\t\tthis.removeAttribute('pressed')\n\t}\n\n\tprotected render() {\n\t\tconst containerClasses = classMap({\n\t\t\t'card-container': true,\n\t\t\tinteractive: this.interactive && !this.disabled,\n\t\t})\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${containerClasses}\n\t\t\t\t@click=${this.handleClick}\n\t\t\t\t@keydown=${this.handleKeyDown}\n\t\t\t\t@keyup=${this.handleKeyUp}\n\t\t\t\t@mousedown=${this.handleMouseDown}\n\t\t\t\t@mouseup=${this.handleMouseUp}\n\t\t\t\t@mouseleave=${this.handleMouseLeave}\n\t\t\t\taria-label=${ifDefined(this.ariaLabel)}\n\t\t\t\taria-disabled=${this.disabled ? 'true' : 'false'}\n\t\t\t>\n\t\t\t\t<!-- State layer for hover/focus/pressed states -->\n\t\t\t\t<div class=\"state-layer\"></div>\n\n\t\t\t\t<!-- Ripple container for click effects -->\n\t\t\t\t${this.interactive\n\t\t\t\t\t? html`\n\t\t\t\t\t\t\t<div class=\"ripple-container\">\n\t\t\t\t\t\t\t\t${this.ripples.map(\n\t\t\t\t\t\t\t\t\tripple => html`\n\t\t\t\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\t\t\t\tclass=\"ripple\"\n\t\t\t\t\t\t\t\t\t\t\tstyle=\"\n\t\t\t\t\t\t\t\t\t\t\t\tleft: ${ripple.x}px;\n\t\t\t\t\t\t\t\t\t\t\t\ttop: ${ripple.y}px;\n\t\t\t\t\t\t\t\t\t\t\t\twidth: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\theight: 20px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-left: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\tmargin-top: -10px;\n\t\t\t\t\t\t\t\t\t\t\t\"\n\t\t\t\t\t\t\t\t\t\t></span>\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</div>\n\t\t\t\t\t\t`\n\t\t\t\t\t: ''}\n\n\t\t\t\t<!-- Card content -->\n\t\t\t\t<div class=\"content\">\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'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-content\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tpadding: 1rem;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\theight: 200px;\n\t\toverflow: hidden;\n\t}\n\t\n\t/* Allow height to be overridden when used in flex/grid layouts */\n\t:host-context(.h-full) {\n\t\theight: 100%;\n\t}\n\t\n\t::slotted(img),\n\timg {\n\t\twidth: 100%;\n\t\theight: 100%;\n\t\tobject-position: center;\n\t}\n\t\n\t/* Object fit styles based on fit attribute */\n\t:host([fit=\"contain\"]) img,\n\t:host([fit=\"contain\"]) ::slotted(img) {\n\t\tobject-fit: contain;\n\t}\n\t\n\t:host([fit=\"cover\"]) img,\n\t:host([fit=\"cover\"]) ::slotted(img) {\n\t\tobject-fit: cover;\n\t}\n\t\n\t:host([fit=\"fill\"]) img,\n\t:host([fit=\"fill\"]) ::slotted(img) {\n\t\tobject-fit: fill;\n\t}\n\t\n\t:host([fit=\"none\"]) img,\n\t:host([fit=\"none\"]) ::slotted(img) {\n\t\tobject-fit: none;\n\t}\n\t\n\t:host([fit=\"scale-down\"]) img,\n\t:host([fit=\"scale-down\"]) ::slotted(img) {\n\t\tobject-fit: scale-down;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String, reflect: true })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\t\n\t@property({ type: String })\n\talt: string = ''\n\n\tprotected render(): unknown {\n\t\t// If src is provided, render an img element\n\t\t// Otherwise, allow users to slot their own content\n\t\treturn this.src \n\t\t\t? html`<img src=\"${this.src}\" alt=\"${this.alt}\" />` \n\t\t\t: html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n"],"names":["SchmancyCardAction","TailwindElement","css","render","html","customElement","SchmancyCard","super","arguments","this","type","interactive","disabled","dragged","role","ariaLabel","pressed","ripples","nextRippleId","handleClick","e","rect","getBoundingClientRect","x","clientX","left","y","clientY","top","id","setTimeout","filter","r","href","target","window","open","location","dispatchEvent","CustomEvent","detail","value","bubbles","composed","handleKeyDown","key","preventDefault","setAttribute","width","height","handleKeyUp","removeAttribute","handleMouseDown","handleMouseUp","handleMouseLeave","connectedCallback","changedProperties","updated","has","containerClasses","classMap","ifDefined","map","ripple","shadowRootOptions","LitElement","mode","delegatesFocus","__decorateClass","property","reflect","prototype","Boolean","attribute","state","SchmancyCardContent","SchmancyCardMedia","constructor","src","fit","alt","String"],"mappings":"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"}
|