@mhmo91/schmancy 0.4.24 → 0.4.33

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (325) hide show
  1. package/ai/sheet.md +87 -25
  2. package/dist/ai/sheet.md +87 -25
  3. package/dist/{animated-text-DcLpvyCq.js → animated-text-AbNgT7ie.js} +3 -3
  4. package/dist/{animated-text-DcLpvyCq.js.map → animated-text-AbNgT7ie.js.map} +1 -1
  5. package/dist/{animated-text-BitOmeE1.cjs → animated-text-CYmUxmlv.cjs} +2 -2
  6. package/dist/{animated-text-BitOmeE1.cjs.map → animated-text-CYmUxmlv.cjs.map} +1 -1
  7. package/dist/animated-text.cjs +1 -1
  8. package/dist/animated-text.js +1 -1
  9. package/dist/area.cjs +1 -1
  10. package/dist/{area.component-BTLn3oIv.cjs → area.component-B1Lmmsuk.cjs} +2 -2
  11. package/dist/{area.component-BTLn3oIv.cjs.map → area.component-B1Lmmsuk.cjs.map} +1 -1
  12. package/dist/{area.component-xbNRrst9.js → area.component-BxrgxiLv.js} +3 -3
  13. package/dist/{area.component-xbNRrst9.js.map → area.component-BxrgxiLv.js.map} +1 -1
  14. package/dist/area.js +2 -2
  15. package/dist/{autocomplete-BqRrw118.js → autocomplete-Bx1vWN32.js} +3 -3
  16. package/dist/{autocomplete-BqRrw118.js.map → autocomplete-Bx1vWN32.js.map} +1 -1
  17. package/dist/{autocomplete-Dvc06UNM.cjs → autocomplete-ClTDM1cy.cjs} +2 -2
  18. package/dist/{autocomplete-Dvc06UNM.cjs.map → autocomplete-ClTDM1cy.cjs.map} +1 -1
  19. package/dist/autocomplete.cjs +1 -1
  20. package/dist/autocomplete.js +1 -1
  21. package/dist/{avatar-CP5pbPbp.cjs → avatar-0h3VHdWs.cjs} +2 -2
  22. package/dist/{avatar-CP5pbPbp.cjs.map → avatar-0h3VHdWs.cjs.map} +1 -1
  23. package/dist/{avatar-Cb_cbT8R.js → avatar-C5iIJlD9.js} +46 -46
  24. package/dist/{avatar-Cb_cbT8R.js.map → avatar-C5iIJlD9.js.map} +1 -1
  25. package/dist/badge.cjs +1 -1
  26. package/dist/badge.js +1 -1
  27. package/dist/{boat-Dtum9CaN.cjs → boat--6fKaS1r.cjs} +2 -2
  28. package/dist/{boat-Dtum9CaN.cjs.map → boat--6fKaS1r.cjs.map} +1 -1
  29. package/dist/{boat-ByFTBKD2.js → boat-vVWqUMYt.js} +2 -2
  30. package/dist/{boat-ByFTBKD2.js.map → boat-vVWqUMYt.js.map} +1 -1
  31. package/dist/boat.cjs +1 -1
  32. package/dist/boat.js +1 -1
  33. package/dist/busy.cjs +1 -1
  34. package/dist/busy.js +1 -1
  35. package/dist/button.cjs +1 -1
  36. package/dist/button.js +1 -1
  37. package/dist/card.cjs +1 -1
  38. package/dist/card.js +1 -1
  39. package/dist/{checkbox-Dq0Lm3AM.js → checkbox-91xSd_El.js} +5 -5
  40. package/dist/{checkbox-Dq0Lm3AM.js.map → checkbox-91xSd_El.js.map} +1 -1
  41. package/dist/{checkbox-220X9LTx.cjs → checkbox-CcKQi7Hq.cjs} +2 -2
  42. package/dist/{checkbox-220X9LTx.cjs.map → checkbox-CcKQi7Hq.cjs.map} +1 -1
  43. package/dist/checkbox.cjs +1 -1
  44. package/dist/checkbox.js +1 -1
  45. package/dist/{chips-aRU1fwEV.js → chips-D26R6u7T.js} +3 -3
  46. package/dist/{chips-aRU1fwEV.js.map → chips-D26R6u7T.js.map} +1 -1
  47. package/dist/{chips-jORxgpG7.cjs → chips-Duj_48dP.cjs} +2 -2
  48. package/dist/{chips-jORxgpG7.cjs.map → chips-Duj_48dP.cjs.map} +1 -1
  49. package/dist/chips.cjs +1 -1
  50. package/dist/chips.js +1 -1
  51. package/dist/{circular-progress-Dis30LMa.js → circular-progress-BAzvWUr0.js} +3 -3
  52. package/dist/{circular-progress-Dis30LMa.js.map → circular-progress-BAzvWUr0.js.map} +1 -1
  53. package/dist/{circular-progress-DMccmWrI.cjs → circular-progress-CeiF8CYP.cjs} +2 -2
  54. package/dist/{circular-progress-DMccmWrI.cjs.map → circular-progress-CeiF8CYP.cjs.map} +1 -1
  55. package/dist/circular-progress.cjs +1 -1
  56. package/dist/circular-progress.js +1 -1
  57. package/dist/code-highlight.cjs +1 -1
  58. package/dist/code-highlight.js +1 -1
  59. package/dist/{code-preview-CCHcWZvS.cjs → code-preview-BCUSwkuU.cjs} +13 -13
  60. package/dist/{code-preview-CCHcWZvS.cjs.map → code-preview-BCUSwkuU.cjs.map} +1 -1
  61. package/dist/{code-preview-BwIb73Yd.js → code-preview-kNXSixdo.js} +333 -331
  62. package/dist/{code-preview-BwIb73Yd.js.map → code-preview-kNXSixdo.js.map} +1 -1
  63. package/dist/components.cjs +1 -1
  64. package/dist/components.js +1 -1
  65. package/dist/consume-5D1qfVWM.js.map +1 -1
  66. package/dist/consume-edta5ng5.cjs.map +1 -1
  67. package/dist/content-drawer.cjs +1 -1
  68. package/dist/content-drawer.js +1 -1
  69. package/dist/context-object-CDDP4bTk.js.map +1 -1
  70. package/dist/context-object-K_1gDFu-.cjs.map +1 -1
  71. package/dist/{date-range-DinaPWK0.cjs → date-range-CBrZ7Pm6.cjs} +2 -2
  72. package/dist/{date-range-DinaPWK0.cjs.map → date-range-CBrZ7Pm6.cjs.map} +1 -1
  73. package/dist/{date-range-CA_4vjWe.js → date-range-gp2cu49l.js} +3 -3
  74. package/dist/{date-range-CA_4vjWe.js.map → date-range-gp2cu49l.js.map} +1 -1
  75. package/dist/{date-range-inline-DFjyAvPv.js → date-range-inline-DZwtgeXX.js} +3 -3
  76. package/dist/{date-range-inline-DFjyAvPv.js.map → date-range-inline-DZwtgeXX.js.map} +1 -1
  77. package/dist/{date-range-inline-CGMvaSeh.cjs → date-range-inline-ZPM9dCG1.cjs} +2 -2
  78. package/dist/{date-range-inline-CGMvaSeh.cjs.map → date-range-inline-ZPM9dCG1.cjs.map} +1 -1
  79. package/dist/date-range-inline.cjs +1 -1
  80. package/dist/date-range-inline.js +1 -1
  81. package/dist/date-range.cjs +1 -1
  82. package/dist/date-range.js +1 -1
  83. package/dist/{delay-CHAH30wI.cjs → delay-CUpeZtD8.cjs} +2 -2
  84. package/dist/{delay-CHAH30wI.cjs.map → delay-CUpeZtD8.cjs.map} +1 -1
  85. package/dist/{delay-BJwsHbg3.js → delay-CYxt2x_w.js} +2 -2
  86. package/dist/{delay-BJwsHbg3.js.map → delay-CYxt2x_w.js.map} +1 -1
  87. package/dist/delay.cjs +1 -1
  88. package/dist/delay.js +1 -1
  89. package/dist/{dialog-content-Bp2kwzxD.cjs → dialog-content-Cz2MP3fS.cjs} +2 -2
  90. package/dist/{dialog-content-Bp2kwzxD.cjs.map → dialog-content-Cz2MP3fS.cjs.map} +1 -1
  91. package/dist/{dialog-content-CEZqJRzH.js → dialog-content-DmUr4jZM.js} +3 -3
  92. package/dist/{dialog-content-CEZqJRzH.js.map → dialog-content-DmUr4jZM.js.map} +1 -1
  93. package/dist/dialog-service-BZZK8N6A.cjs.map +1 -1
  94. package/dist/dialog-service-DFMlRcXf.js.map +1 -1
  95. package/dist/dialog.cjs +1 -1
  96. package/dist/dialog.js +1 -1
  97. package/dist/{divider-DfetUf4S.js → divider-BreFKYh2.js} +3 -3
  98. package/dist/{divider-DfetUf4S.js.map → divider-BreFKYh2.js.map} +1 -1
  99. package/dist/{divider-BEVgt1wl.cjs → divider-Cd5pOeZr.cjs} +2 -2
  100. package/dist/{divider-BEVgt1wl.cjs.map → divider-Cd5pOeZr.cjs.map} +1 -1
  101. package/dist/divider.cjs +1 -1
  102. package/dist/divider.js +1 -1
  103. package/dist/{dropdown-content-TJmZ3rpA.js → dropdown-content-DjIvlBvq.js} +3 -3
  104. package/dist/{dropdown-content-TJmZ3rpA.js.map → dropdown-content-DjIvlBvq.js.map} +1 -1
  105. package/dist/{dropdown-content-CERnSXjI.cjs → dropdown-content-zLE8scWl.cjs} +2 -2
  106. package/dist/{dropdown-content-CERnSXjI.cjs.map → dropdown-content-zLE8scWl.cjs.map} +1 -1
  107. package/dist/dropdown.cjs +1 -1
  108. package/dist/dropdown.js +1 -1
  109. package/dist/extra.cjs +1 -1
  110. package/dist/extra.js +1 -1
  111. package/dist/{flex-ByanQCYb.cjs → flex-CEq4v4cK.cjs} +2 -2
  112. package/dist/{flex-ByanQCYb.cjs.map → flex-CEq4v4cK.cjs.map} +1 -1
  113. package/dist/{flex-CXMNh-nH.js → flex-DRvBt9P0.js} +2 -2
  114. package/dist/{flex-CXMNh-nH.js.map → flex-DRvBt9P0.js.map} +1 -1
  115. package/dist/flow-D0e7hGXO.cjs.map +1 -1
  116. package/dist/flow-DXYqC9OA.js.map +1 -1
  117. package/dist/{form-lhQx_Ry0.cjs → form-B5CAbB2i.cjs} +2 -2
  118. package/dist/{form-lhQx_Ry0.cjs.map → form-B5CAbB2i.cjs.map} +1 -1
  119. package/dist/{form-Boc5Pqhf.js → form-BKqz7W6V.js} +2 -2
  120. package/dist/{form-Boc5Pqhf.js.map → form-BKqz7W6V.js.map} +1 -1
  121. package/dist/form.cjs +1 -1
  122. package/dist/form.js +1 -1
  123. package/dist/{formField.mixin-DhiLSVHT.cjs → formField.mixin-BuKEbib1.cjs} +2 -2
  124. package/dist/{formField.mixin-DhiLSVHT.cjs.map → formField.mixin-BuKEbib1.cjs.map} +1 -1
  125. package/dist/{formField.mixin-CX7_nvVy.js → formField.mixin-DCPfsyya.js} +2 -2
  126. package/dist/{formField.mixin-CX7_nvVy.js.map → formField.mixin-DCPfsyya.js.map} +1 -1
  127. package/dist/{icon-D1qw18N6.cjs → icon-B0_pMF_-.cjs} +2 -2
  128. package/dist/{icon-D1qw18N6.cjs.map → icon-B0_pMF_-.cjs.map} +1 -1
  129. package/dist/{icon-BZw88sCH.js → icon-DA0eDV8w.js} +2 -2
  130. package/dist/{icon-BZw88sCH.js.map → icon-DA0eDV8w.js.map} +1 -1
  131. package/dist/{icon-button-TbwQrO1b.js → icon-button-CEnel9Yg.js} +3 -3
  132. package/dist/{icon-button-TbwQrO1b.js.map → icon-button-CEnel9Yg.js.map} +1 -1
  133. package/dist/{icon-button-DBvZApEC.cjs → icon-button-DFVuusoz.cjs} +2 -2
  134. package/dist/{icon-button-DBvZApEC.cjs.map → icon-button-DFVuusoz.cjs.map} +1 -1
  135. package/dist/icons.cjs +1 -1
  136. package/dist/icons.js +1 -1
  137. package/dist/index-CuY8m6ta.js.map +1 -1
  138. package/dist/index-DyJ0oDpR.cjs.map +1 -1
  139. package/dist/index.cjs +1 -1
  140. package/dist/index.js +133 -134
  141. package/dist/{input-BUtEXu3y.js → input-B7Q3RRwE.js} +3 -3
  142. package/dist/{input-BUtEXu3y.js.map → input-B7Q3RRwE.js.map} +1 -1
  143. package/dist/{input-C0F9cNoD.cjs → input-C4tYxk-t.cjs} +2 -2
  144. package/dist/{input-C0F9cNoD.cjs.map → input-C4tYxk-t.cjs.map} +1 -1
  145. package/dist/input.cjs +1 -1
  146. package/dist/input.js +1 -1
  147. package/dist/intersection-CJxzz8c-.js.map +1 -1
  148. package/dist/intersection-CVvaDv96.cjs.map +1 -1
  149. package/dist/layout.cjs +1 -1
  150. package/dist/layout.js +1 -1
  151. package/dist/{list-BCD8h2Do.js → list-BTm67LuV.js} +2 -2
  152. package/dist/{list-BCD8h2Do.js.map → list-BTm67LuV.js.map} +1 -1
  153. package/dist/{list-Bz6tq7ZP.cjs → list-Bos26fD3.cjs} +2 -2
  154. package/dist/{list-Bz6tq7ZP.cjs.map → list-Bos26fD3.cjs.map} +1 -1
  155. package/dist/list.cjs +1 -1
  156. package/dist/list.js +1 -1
  157. package/dist/{litElement.mixin-DGeprHKB.js → litElement.mixin-Cn8IAazz.js} +2 -2
  158. package/dist/{litElement.mixin-DGeprHKB.js.map → litElement.mixin-Cn8IAazz.js.map} +1 -1
  159. package/dist/{litElement.mixin-CII9bbap.cjs → litElement.mixin-Cs3zx2X6.cjs} +2 -2
  160. package/dist/{litElement.mixin-CII9bbap.cjs.map → litElement.mixin-Cs3zx2X6.cjs.map} +1 -1
  161. package/dist/{media-D6ba0wB1.js → media-DPQecp4W.js} +2 -2
  162. package/dist/{media-D6ba0wB1.js.map → media-DPQecp4W.js.map} +1 -1
  163. package/dist/{media-CBLuAmNZ.cjs → media-YhMV6ELC.cjs} +2 -2
  164. package/dist/{media-CBLuAmNZ.cjs.map → media-YhMV6ELC.cjs.map} +1 -1
  165. package/dist/{menu-BDQr8EZ1.cjs → menu-BfNE5Pz2.cjs} +2 -2
  166. package/dist/{menu-BDQr8EZ1.cjs.map → menu-BfNE5Pz2.cjs.map} +1 -1
  167. package/dist/{menu-C0SauakY.js → menu-C5KQk1CK.js} +3 -3
  168. package/dist/{menu-C0SauakY.js.map → menu-C5KQk1CK.js.map} +1 -1
  169. package/dist/menu.cjs +1 -1
  170. package/dist/menu.js +1 -1
  171. package/dist/nav-drawer.cjs +1 -1
  172. package/dist/nav-drawer.js +1 -1
  173. package/dist/{notification-service-B1f848tO.cjs → notification-service-Bq_d-qqB.cjs} +2 -2
  174. package/dist/{notification-service-B1f848tO.cjs.map → notification-service-Bq_d-qqB.cjs.map} +1 -1
  175. package/dist/{notification-service-X8mRASdk.js → notification-service-unFpqUQn.js} +3 -3
  176. package/dist/{notification-service-X8mRASdk.js.map → notification-service-unFpqUQn.js.map} +1 -1
  177. package/dist/notification.cjs +1 -1
  178. package/dist/notification.js +1 -1
  179. package/dist/{option-ckV22mLf.cjs → option-B9LbtNdk.cjs} +2 -2
  180. package/dist/{option-ckV22mLf.cjs.map → option-B9LbtNdk.cjs.map} +1 -1
  181. package/dist/{option-DVlCqux7.js → option-Cy-nYxTs.js} +2 -2
  182. package/dist/{option-DVlCqux7.js.map → option-Cy-nYxTs.js.map} +1 -1
  183. package/dist/option.cjs +1 -1
  184. package/dist/option.js +1 -1
  185. package/dist/{payment-card-form-BUsPCZPp.cjs → payment-card-form-D45IjHFN.cjs} +2 -2
  186. package/dist/{payment-card-form-BUsPCZPp.cjs.map → payment-card-form-D45IjHFN.cjs.map} +1 -1
  187. package/dist/{payment-card-form-D7PV8spa.js → payment-card-form-ctWIc4vM.js} +3 -3
  188. package/dist/{payment-card-form-D7PV8spa.js.map → payment-card-form-ctWIc4vM.js.map} +1 -1
  189. package/dist/{progress-BZ6AFT0f.js → progress-4Ef6bw05.js} +2 -2
  190. package/dist/{progress-BZ6AFT0f.js.map → progress-4Ef6bw05.js.map} +1 -1
  191. package/dist/{progress-CABg45XF.cjs → progress-QXnS6DIm.cjs} +2 -2
  192. package/dist/{progress-CABg45XF.cjs.map → progress-QXnS6DIm.cjs.map} +1 -1
  193. package/dist/progress.cjs +1 -1
  194. package/dist/progress.js +1 -1
  195. package/dist/provide-BxZ2kn_p.cjs.map +1 -1
  196. package/dist/provide-tcktw8xB.js.map +1 -1
  197. package/dist/{radio-button-D4Y1bWGN.js → radio-button-CEp1kd-P.js} +3 -3
  198. package/dist/{radio-button-D4Y1bWGN.js.map → radio-button-CEp1kd-P.js.map} +1 -1
  199. package/dist/{radio-button-DQ4VclEZ.cjs → radio-button-CUzdKTtW.cjs} +2 -2
  200. package/dist/{radio-button-DQ4VclEZ.cjs.map → radio-button-CUzdKTtW.cjs.map} +1 -1
  201. package/dist/radio-group.cjs +1 -1
  202. package/dist/radio-group.js +1 -1
  203. package/dist/redispatch-event-BLom7yp4.js.map +1 -1
  204. package/dist/redispatch-event-DHcobAl6.cjs.map +1 -1
  205. package/dist/ripple-BumgqsDT.js.map +1 -1
  206. package/dist/ripple-C2BHbhcS.cjs.map +1 -1
  207. package/dist/rxjs-utils.cjs.map +1 -1
  208. package/dist/rxjs-utils.js.map +1 -1
  209. package/dist/{schmancy-steps-container-CZ0upElE.cjs → schmancy-steps-container-D3m07gLT.cjs} +2 -2
  210. package/dist/{schmancy-steps-container-CZ0upElE.cjs.map → schmancy-steps-container-D3m07gLT.cjs.map} +1 -1
  211. package/dist/{schmancy-steps-container-BskkdQwD.js → schmancy-steps-container-KI2azXpv.js} +2 -2
  212. package/dist/{schmancy-steps-container-BskkdQwD.js.map → schmancy-steps-container-KI2azXpv.js.map} +1 -1
  213. package/dist/{select-DfQogfes.cjs → select-Bw4QilHf.cjs} +3 -3
  214. package/dist/{select-DfQogfes.cjs.map → select-Bw4QilHf.cjs.map} +1 -1
  215. package/dist/{select-wui4bIUE.js → select-g77JoEFx.js} +18 -20
  216. package/dist/{select-wui4bIUE.js.map → select-g77JoEFx.js.map} +1 -1
  217. package/dist/select.cjs +1 -1
  218. package/dist/select.js +2 -3
  219. package/dist/selector-hook-Bf_lCnGW.cjs.map +1 -1
  220. package/dist/{selector-hook-DL0SIQiY.js → selector-hook-DPe2CGKx.js} +16 -16
  221. package/dist/{selector-hook-DL0SIQiY.js.map → selector-hook-DPe2CGKx.js.map} +1 -1
  222. package/dist/{sheet-DMOsLeJL.cjs → sheet--fG_jGSI.cjs} +2 -2
  223. package/dist/{sheet-DMOsLeJL.cjs.map → sheet--fG_jGSI.cjs.map} +1 -1
  224. package/dist/{sheet-DmrPnCAk.js → sheet-edcIHEMM.js} +4 -4
  225. package/dist/{sheet-DmrPnCAk.js.map → sheet-edcIHEMM.js.map} +1 -1
  226. package/dist/sheet.cjs +1 -1
  227. package/dist/sheet.js +6 -7
  228. package/dist/{sheet.service-22gvsyq8.js → sheet.service-BKQ7n7nz.js} +480 -471
  229. package/dist/{sheet.service-22gvsyq8.js.map → sheet.service-BKQ7n7nz.js.map} +1 -1
  230. package/dist/{sheet.service-sSYoAEbY.cjs → sheet.service-ihtgUWRM.cjs} +3 -3
  231. package/dist/{sheet.service-sSYoAEbY.cjs.map → sheet.service-ihtgUWRM.cjs.map} +1 -1
  232. package/dist/{slider-Dwm1KfNL.js → slider-BJQE9wHL.js} +3 -3
  233. package/dist/{slider-Dwm1KfNL.js.map → slider-BJQE9wHL.js.map} +1 -1
  234. package/dist/{slider-C2oEvRAS.cjs → slider-DMIOW38W.cjs} +2 -2
  235. package/dist/{slider-C2oEvRAS.cjs.map → slider-DMIOW38W.cjs.map} +1 -1
  236. package/dist/slider.cjs +1 -1
  237. package/dist/slider.js +1 -1
  238. package/dist/{spinner-DKgZemVU.cjs → spinner-ByMXQNV3.cjs} +2 -2
  239. package/dist/{spinner-DKgZemVU.cjs.map → spinner-ByMXQNV3.cjs.map} +1 -1
  240. package/dist/{spinner-Bh6XkC88.js → spinner-NFkGJJz1.js} +2 -2
  241. package/dist/{spinner-Bh6XkC88.js.map → spinner-NFkGJJz1.js.map} +1 -1
  242. package/dist/steps.cjs +1 -1
  243. package/dist/steps.js +1 -1
  244. package/dist/store.js +1 -1
  245. package/dist/{surface-DIIUamff.cjs → surface-BhCe8hp8.cjs} +2 -2
  246. package/dist/{surface-DIIUamff.cjs.map → surface-BhCe8hp8.cjs.map} +1 -1
  247. package/dist/{surface-DhiuAGb8.js → surface-C7jJaxVu.js} +2 -2
  248. package/dist/{surface-DhiuAGb8.js.map → surface-C7jJaxVu.js.map} +1 -1
  249. package/dist/surface.cjs +1 -1
  250. package/dist/surface.js +1 -1
  251. package/dist/{table-BrAoSQhN.cjs → table-BlwkABmS.cjs} +2 -2
  252. package/dist/{table-BrAoSQhN.cjs.map → table-BlwkABmS.cjs.map} +1 -1
  253. package/dist/{table-DSZ9kmUG.js → table-CmwIcTR5.js} +2 -2
  254. package/dist/{table-DSZ9kmUG.js.map → table-CmwIcTR5.js.map} +1 -1
  255. package/dist/table.cjs +1 -1
  256. package/dist/table.js +1 -1
  257. package/dist/{tabs-compatibility-B7aJnQ0X.js → tabs-compatibility-BdKslPOu.js} +2 -2
  258. package/dist/{tabs-compatibility-B7aJnQ0X.js.map → tabs-compatibility-BdKslPOu.js.map} +1 -1
  259. package/dist/{tabs-compatibility-Ck74XeID.cjs → tabs-compatibility-v0k0K0ID.cjs} +2 -2
  260. package/dist/{tabs-compatibility-Ck74XeID.cjs.map → tabs-compatibility-v0k0K0ID.cjs.map} +1 -1
  261. package/dist/tabs.cjs +1 -1
  262. package/dist/tabs.js +1 -1
  263. package/dist/{tailwind.mixin-CBu1BEQZ.cjs → tailwind.mixin-1kcW0BGm.cjs} +2 -2
  264. package/dist/{tailwind.mixin-CBu1BEQZ.cjs.map → tailwind.mixin-1kcW0BGm.cjs.map} +1 -1
  265. package/dist/{tailwind.mixin-DWhCm94g.js → tailwind.mixin-BHLwDiBj.js} +2 -2
  266. package/dist/{tailwind.mixin-DWhCm94g.js.map → tailwind.mixin-BHLwDiBj.js.map} +1 -1
  267. package/dist/teleport.cjs +1 -1
  268. package/dist/teleport.js +1 -1
  269. package/dist/{textarea-CGTMdhoF.cjs → textarea-CL3oExE7.cjs} +2 -2
  270. package/dist/{textarea-CGTMdhoF.cjs.map → textarea-CL3oExE7.cjs.map} +1 -1
  271. package/dist/{textarea-Bq0XdGaH.js → textarea-CfLyPiqF.js} +2 -2
  272. package/dist/{textarea-Bq0XdGaH.js.map → textarea-CfLyPiqF.js.map} +1 -1
  273. package/dist/textarea.cjs +1 -1
  274. package/dist/textarea.js +1 -1
  275. package/dist/{theme-button-CznhJ8g_.cjs → theme-button-D9DpgXlC.cjs} +2 -2
  276. package/dist/{theme-button-CznhJ8g_.cjs.map → theme-button-D9DpgXlC.cjs.map} +1 -1
  277. package/dist/{theme-button-DYoygmRA.js → theme-button-tekBpoTr.js} +2 -2
  278. package/dist/{theme-button-DYoygmRA.js.map → theme-button-tekBpoTr.js.map} +1 -1
  279. package/dist/theme-button.cjs +1 -1
  280. package/dist/theme-button.js +1 -1
  281. package/dist/theme.cjs +1 -1
  282. package/dist/theme.interface-C5Kj6WjD.js.map +1 -1
  283. package/dist/theme.interface-Xg5Zi46a.cjs.map +1 -1
  284. package/dist/theme.js +1 -1
  285. package/dist/{timezone-BCGcdasU.cjs → timezone-DIYE4qo4.cjs} +2 -2
  286. package/dist/{timezone-BCGcdasU.cjs.map → timezone-DIYE4qo4.cjs.map} +1 -1
  287. package/dist/{timezone-Co7gqqQt.js → timezone-rpn_HlNW.js} +3 -3
  288. package/dist/{timezone-Co7gqqQt.js.map → timezone-rpn_HlNW.js.map} +1 -1
  289. package/dist/{tooltip-DBuaAFmK.js → tooltip-C5DJ3omV.js} +2 -2
  290. package/dist/{tooltip-DBuaAFmK.js.map → tooltip-C5DJ3omV.js.map} +1 -1
  291. package/dist/{tooltip-Bqa0D34J.cjs → tooltip-apPpbYRb.cjs} +2 -2
  292. package/dist/{tooltip-Bqa0D34J.cjs.map → tooltip-apPpbYRb.cjs.map} +1 -1
  293. package/dist/tooltip.cjs +1 -1
  294. package/dist/tooltip.js +1 -1
  295. package/dist/{tree-CfE695gp.js → tree-B38B9Zts.js} +2 -2
  296. package/dist/{tree-CfE695gp.js.map → tree-B38B9Zts.js.map} +1 -1
  297. package/dist/{tree-CFeXYaJy.cjs → tree-DYOX-2CI.cjs} +2 -2
  298. package/dist/{tree-CFeXYaJy.cjs.map → tree-DYOX-2CI.cjs.map} +1 -1
  299. package/dist/tree.cjs +1 -1
  300. package/dist/tree.js +1 -1
  301. package/dist/tslib.es6-DgOcxv4s.cjs.map +1 -1
  302. package/dist/tslib.es6-ujVQHAQ4.js.map +1 -1
  303. package/dist/types.cjs.map +1 -1
  304. package/dist/types.js.map +1 -1
  305. package/dist/{typewriter-BZ_adVXB.js → typewriter-Cf1Bl0lI.js} +4 -4
  306. package/dist/{typewriter-BZ_adVXB.js.map → typewriter-Cf1Bl0lI.js.map} +1 -1
  307. package/dist/{typewriter-B6Jb22Pe.cjs → typewriter-D5sC3i_h.cjs} +2 -2
  308. package/dist/{typewriter-B6Jb22Pe.cjs.map → typewriter-D5sC3i_h.cjs.map} +1 -1
  309. package/dist/typewriter.cjs +1 -1
  310. package/dist/typewriter.js +1 -1
  311. package/dist/{typography-DvVeO1a_.cjs → typography-VDYy4xDQ.cjs} +2 -2
  312. package/dist/{typography-DvVeO1a_.cjs.map → typography-VDYy4xDQ.cjs.map} +1 -1
  313. package/dist/{typography-DI5RXpWs.js → typography-sm5Ne22S.js} +2 -2
  314. package/dist/{typography-DI5RXpWs.js.map → typography-sm5Ne22S.js.map} +1 -1
  315. package/dist/typography.cjs +1 -1
  316. package/dist/typography.js +1 -1
  317. package/dist/{utils-jduntaQU.js → utils-03Coa8AW.js} +2 -2
  318. package/dist/{utils-jduntaQU.js.map → utils-03Coa8AW.js.map} +1 -1
  319. package/dist/{utils-BqFGvnN9.cjs → utils-C9nzOWpR.cjs} +2 -2
  320. package/dist/{utils-BqFGvnN9.cjs.map → utils-C9nzOWpR.cjs.map} +1 -1
  321. package/package.json +10 -10
  322. package/types/src/index.d.ts +2 -0
  323. package/types/src/select/select.d.ts +2 -0
  324. package/types/src/sheet/sheet.service.d.ts +128 -26
  325. package/types/src/store/selector-hook.d.ts +1 -1
package/ai/sheet.md CHANGED
@@ -2,6 +2,11 @@
2
2
 
3
3
  The sheet component provides a sliding panel overlay that can be used for forms, details views, or any content that needs to be displayed in a drawer-style interface.
4
4
 
5
+ **Important Note about Templates**: The sheet service now only accepts HTMLElement components. If you're using Lit's `html` template literals, you need to either:
6
+ 1. Create a wrapper element and use innerHTML (for simple content)
7
+ 2. Create a custom element class (for complex interactions)
8
+ 3. Use the `render` function from Lit to render into a container element
9
+
5
10
  ```js
6
11
  // Import Options
7
12
  import { sheet } from '@mhmo91/schmancy'; // Legacy import
@@ -9,7 +14,7 @@ import { $sheet } from '@mhmo91/schmancy'; // New recommended import
9
14
 
10
15
  // Sheet Service API
11
16
  $sheet.open({
12
- component: HTMLElement | TemplateResult, // Content to display
17
+ component: HTMLElement, // Content to display (must be an HTMLElement)
13
18
  uid?: string, // Unique identifier for the sheet
14
19
  position?: 'side' | 'bottom', // Position (default: responsive based on screen size)
15
20
  persist?: boolean, // Keep sheet in DOM after closing (default: false)
@@ -54,20 +59,22 @@ SchmancySheetPosition.Bottom // Bottom sheet (mobile)
54
59
 
55
60
  // Examples
56
61
 
57
- // 1. Basic Sheet with Form
62
+ // 1. Basic Sheet with Form - Using a wrapper element for template content
63
+ const formContent = document.createElement('div');
64
+ formContent.className = 'p-6';
65
+ formContent.innerHTML = `
66
+ <schmancy-typography type="headline" token="md" class="mb-4">
67
+ User Details
68
+ </schmancy-typography>
69
+ <schmancy-form>
70
+ <schmancy-input label="Name" value="John Doe"></schmancy-input>
71
+ <schmancy-input label="Email" value="john@example.com"></schmancy-input>
72
+ <schmancy-button type="submit">Save</schmancy-button>
73
+ </schmancy-form>
74
+ `;
75
+
58
76
  $sheet.open({
59
- component: html`
60
- <div class="p-6">
61
- <schmancy-typography type="headline" token="md" class="mb-4">
62
- User Details
63
- </schmancy-typography>
64
- <schmancy-form>
65
- <schmancy-input label="Name" value="John Doe"></schmancy-input>
66
- <schmancy-input label="Email" value="john@example.com"></schmancy-input>
67
- <schmancy-button type="submit">Save</schmancy-button>
68
- </schmancy-form>
69
- </div>
70
- `,
77
+ component: formContent,
71
78
  title: "Edit User"
72
79
  });
73
80
 
@@ -80,18 +87,23 @@ $sheet.open({
80
87
  title: "Custom Component"
81
88
  });
82
89
 
83
- // 3. Sheet with Lock (cannot be dismissed by ESC or clicking outside)
90
+ // 3. Sheet with Lock (using Lit render for interactive content)
91
+ import { render, html } from 'lit';
92
+
93
+ const lockContent = document.createElement('div');
94
+ render(html`
95
+ <div class="p-6">
96
+ <schmancy-typography type="body" token="lg">
97
+ This action requires confirmation. Please complete the form.
98
+ </schmancy-typography>
99
+ <schmancy-button @click=${() => $sheet.dismiss()}>
100
+ Complete Action
101
+ </schmancy-button>
102
+ </div>
103
+ `, lockContent);
104
+
84
105
  $sheet.open({
85
- component: html`
86
- <div class="p-6">
87
- <schmancy-typography type="body" token="lg">
88
- This action requires confirmation. Please complete the form.
89
- </schmancy-typography>
90
- <schmancy-button @click=${() => $sheet.dismiss()}>
91
- Complete Action
92
- </schmancy-button>
93
- </div>
94
- `,
106
+ component: lockContent,
95
107
  lock: true,
96
108
  title: "Required Action"
97
109
  });
@@ -352,6 +364,56 @@ class WizardSheet extends LitElement {
352
364
  }
353
365
  }
354
366
 
367
+ // Template Handling Patterns
368
+
369
+ // Pattern 1: Simple content with innerHTML
370
+ function openSimpleSheet(content) {
371
+ const wrapper = document.createElement('div');
372
+ wrapper.innerHTML = content;
373
+ $sheet.open({ component: wrapper, title: "Simple Sheet" });
374
+ }
375
+
376
+ // Pattern 2: Using Lit's render for reactive content
377
+ function openReactiveSheet() {
378
+ const container = document.createElement('div');
379
+ const state = { count: 0 };
380
+
381
+ const updateContent = () => {
382
+ render(html`
383
+ <div class="p-6">
384
+ <p>Count: ${state.count}</p>
385
+ <schmancy-button @click=${() => {
386
+ state.count++;
387
+ updateContent(); // Re-render with new state
388
+ }}>
389
+ Increment
390
+ </schmancy-button>
391
+ </div>
392
+ `, container);
393
+ };
394
+
395
+ updateContent();
396
+ $sheet.open({ component: container, title: "Reactive Sheet" });
397
+ }
398
+
399
+ // Pattern 3: Custom Element (Recommended for complex components)
400
+ @customElement('my-sheet-content')
401
+ class MySheetContent extends LitElement {
402
+ @property() data = {};
403
+
404
+ render() {
405
+ return html`
406
+ <div class="p-6">
407
+ <!-- Your complex component logic here -->
408
+ </div>
409
+ `;
410
+ }
411
+ }
412
+
413
+ const myContent = document.createElement('my-sheet-content');
414
+ myContent.data = { /* your data */ };
415
+ $sheet.open({ component: myContent, title: "Complex Sheet" });
416
+
355
417
  // Best Practices
356
418
 
357
419
  // 1. Always provide a title for accessibility
package/dist/ai/sheet.md CHANGED
@@ -2,6 +2,11 @@
2
2
 
3
3
  The sheet component provides a sliding panel overlay that can be used for forms, details views, or any content that needs to be displayed in a drawer-style interface.
4
4
 
5
+ **Important Note about Templates**: The sheet service now only accepts HTMLElement components. If you're using Lit's `html` template literals, you need to either:
6
+ 1. Create a wrapper element and use innerHTML (for simple content)
7
+ 2. Create a custom element class (for complex interactions)
8
+ 3. Use the `render` function from Lit to render into a container element
9
+
5
10
  ```js
6
11
  // Import Options
7
12
  import { sheet } from '@mhmo91/schmancy'; // Legacy import
@@ -9,7 +14,7 @@ import { $sheet } from '@mhmo91/schmancy'; // New recommended import
9
14
 
10
15
  // Sheet Service API
11
16
  $sheet.open({
12
- component: HTMLElement | TemplateResult, // Content to display
17
+ component: HTMLElement, // Content to display (must be an HTMLElement)
13
18
  uid?: string, // Unique identifier for the sheet
14
19
  position?: 'side' | 'bottom', // Position (default: responsive based on screen size)
15
20
  persist?: boolean, // Keep sheet in DOM after closing (default: false)
@@ -54,20 +59,22 @@ SchmancySheetPosition.Bottom // Bottom sheet (mobile)
54
59
 
55
60
  // Examples
56
61
 
57
- // 1. Basic Sheet with Form
62
+ // 1. Basic Sheet with Form - Using a wrapper element for template content
63
+ const formContent = document.createElement('div');
64
+ formContent.className = 'p-6';
65
+ formContent.innerHTML = `
66
+ <schmancy-typography type="headline" token="md" class="mb-4">
67
+ User Details
68
+ </schmancy-typography>
69
+ <schmancy-form>
70
+ <schmancy-input label="Name" value="John Doe"></schmancy-input>
71
+ <schmancy-input label="Email" value="john@example.com"></schmancy-input>
72
+ <schmancy-button type="submit">Save</schmancy-button>
73
+ </schmancy-form>
74
+ `;
75
+
58
76
  $sheet.open({
59
- component: html`
60
- <div class="p-6">
61
- <schmancy-typography type="headline" token="md" class="mb-4">
62
- User Details
63
- </schmancy-typography>
64
- <schmancy-form>
65
- <schmancy-input label="Name" value="John Doe"></schmancy-input>
66
- <schmancy-input label="Email" value="john@example.com"></schmancy-input>
67
- <schmancy-button type="submit">Save</schmancy-button>
68
- </schmancy-form>
69
- </div>
70
- `,
77
+ component: formContent,
71
78
  title: "Edit User"
72
79
  });
73
80
 
@@ -80,18 +87,23 @@ $sheet.open({
80
87
  title: "Custom Component"
81
88
  });
82
89
 
83
- // 3. Sheet with Lock (cannot be dismissed by ESC or clicking outside)
90
+ // 3. Sheet with Lock (using Lit render for interactive content)
91
+ import { render, html } from 'lit';
92
+
93
+ const lockContent = document.createElement('div');
94
+ render(html`
95
+ <div class="p-6">
96
+ <schmancy-typography type="body" token="lg">
97
+ This action requires confirmation. Please complete the form.
98
+ </schmancy-typography>
99
+ <schmancy-button @click=${() => $sheet.dismiss()}>
100
+ Complete Action
101
+ </schmancy-button>
102
+ </div>
103
+ `, lockContent);
104
+
84
105
  $sheet.open({
85
- component: html`
86
- <div class="p-6">
87
- <schmancy-typography type="body" token="lg">
88
- This action requires confirmation. Please complete the form.
89
- </schmancy-typography>
90
- <schmancy-button @click=${() => $sheet.dismiss()}>
91
- Complete Action
92
- </schmancy-button>
93
- </div>
94
- `,
106
+ component: lockContent,
95
107
  lock: true,
96
108
  title: "Required Action"
97
109
  });
@@ -352,6 +364,56 @@ class WizardSheet extends LitElement {
352
364
  }
353
365
  }
354
366
 
367
+ // Template Handling Patterns
368
+
369
+ // Pattern 1: Simple content with innerHTML
370
+ function openSimpleSheet(content) {
371
+ const wrapper = document.createElement('div');
372
+ wrapper.innerHTML = content;
373
+ $sheet.open({ component: wrapper, title: "Simple Sheet" });
374
+ }
375
+
376
+ // Pattern 2: Using Lit's render for reactive content
377
+ function openReactiveSheet() {
378
+ const container = document.createElement('div');
379
+ const state = { count: 0 };
380
+
381
+ const updateContent = () => {
382
+ render(html`
383
+ <div class="p-6">
384
+ <p>Count: ${state.count}</p>
385
+ <schmancy-button @click=${() => {
386
+ state.count++;
387
+ updateContent(); // Re-render with new state
388
+ }}>
389
+ Increment
390
+ </schmancy-button>
391
+ </div>
392
+ `, container);
393
+ };
394
+
395
+ updateContent();
396
+ $sheet.open({ component: container, title: "Reactive Sheet" });
397
+ }
398
+
399
+ // Pattern 3: Custom Element (Recommended for complex components)
400
+ @customElement('my-sheet-content')
401
+ class MySheetContent extends LitElement {
402
+ @property() data = {};
403
+
404
+ render() {
405
+ return html`
406
+ <div class="p-6">
407
+ <!-- Your complex component logic here -->
408
+ </div>
409
+ `;
410
+ }
411
+ }
412
+
413
+ const myContent = document.createElement('my-sheet-content');
414
+ myContent.data = { /* your data */ };
415
+ $sheet.open({ component: myContent, title: "Complex Sheet" });
416
+
355
417
  // Best Practices
356
418
 
357
419
  // 1. Always provide a title for accessibility
@@ -1,8 +1,8 @@
1
1
  import { concat as u, interval as g, startWith as y, filter as h, take as d, fromEvent as f, throttleTime as w, map as b, distinctUntilChanged as $, tap as c } from "rxjs";
2
2
  import "lit/directives/class-map.js";
3
3
  import "lit/directives/style-map.js";
4
- import { $ as x } from "./litElement.mixin-DGeprHKB.js";
5
- import "./tailwind.mixin-DWhCm94g.js";
4
+ import { $ as x } from "./litElement.mixin-Cn8IAazz.js";
5
+ import "./tailwind.mixin-BHLwDiBj.js";
6
6
  import { property as a, queryAssignedNodes as S, query as m, customElement as Z } from "lit/decorators.js";
7
7
  import { css as v, html as A } from "lit";
8
8
  var E = Object.defineProperty, O = Object.getOwnPropertyDescriptor, e = (r, s, n, i) => {
@@ -72,4 +72,4 @@ let t = class extends x(v`
72
72
  }
73
73
  };
74
74
  e([a({ type: String })], t.prototype, "ease", 2), e([a({ type: Number })], t.prototype, "delay", 2), e([a({ type: Number })], t.prototype, "stagger", 2), e([a({ type: Number })], t.prototype, "duration", 2), e([a({ type: Array })], t.prototype, "scale", 2), e([a({ type: Array })], t.prototype, "opacity", 2), e([a({ type: Array })], t.prototype, "translateX", 2), e([a({ type: Array })], t.prototype, "translateY", 2), e([a({ type: Array })], t.prototype, "translateZ", 2), e([a({ type: Array })], t.prototype, "rotateZ", 2), e([a({ type: Boolean })], t.prototype, "resetOnScroll", 2), e([S()], t.prototype, "defaultSlot", 2), e([m(".letters")], t.prototype, "letters", 2), e([m(".ml7")], t.prototype, "ml7", 2), t = e([Z("schmancy-animated-text")], t);
75
- //# sourceMappingURL=animated-text-DcLpvyCq.js.map
75
+ //# sourceMappingURL=animated-text-AbNgT7ie.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-DcLpvyCq.js","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"animated-text-AbNgT7ie.js","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","constructor","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","render","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- "use strict";const e=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const h=require("./litElement.mixin-CII9bbap.cjs");require("./tailwind.mixin-CBu1BEQZ.cjs");const r=require("lit/decorators.js"),c=require("lit");var d=Object.defineProperty,u=Object.getOwnPropertyDescriptor,s=(i,a,p,n)=>{for(var l,o=n>1?void 0:n?u(a,p):a,y=i.length-1;y>=0;y--)(l=i[y])&&(o=(n?l(a,p,o):l(o))||o);return n&&o&&d(a,p,o),o};let t=class extends h.$LitElement(c.css`
1
+ "use strict";const e=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const h=require("./litElement.mixin-Cs3zx2X6.cjs");require("./tailwind.mixin-1kcW0BGm.cjs");const r=require("lit/decorators.js"),c=require("lit");var d=Object.defineProperty,u=Object.getOwnPropertyDescriptor,s=(i,a,p,n)=>{for(var l,o=n>1?void 0:n?u(a,p):a,y=i.length-1;y>=0;y--)(l=i[y])&&(o=(n?l(a,p,o):l(o))||o);return n&&o&&d(a,p,o),o};let t=class extends h.$LitElement(c.css`
2
2
  :host {
3
3
  font-family: inherit;
4
4
  display: block;
@@ -34,4 +34,4 @@
34
34
  </span>
35
35
  </span>
36
36
  `}};s([r.property({type:String})],t.prototype,"ease",2),s([r.property({type:Number})],t.prototype,"delay",2),s([r.property({type:Number})],t.prototype,"stagger",2),s([r.property({type:Number})],t.prototype,"duration",2),s([r.property({type:Array})],t.prototype,"scale",2),s([r.property({type:Array})],t.prototype,"opacity",2),s([r.property({type:Array})],t.prototype,"translateX",2),s([r.property({type:Array})],t.prototype,"translateY",2),s([r.property({type:Array})],t.prototype,"translateZ",2),s([r.property({type:Array})],t.prototype,"rotateZ",2),s([r.property({type:Boolean})],t.prototype,"resetOnScroll",2),s([r.queryAssignedNodes()],t.prototype,"defaultSlot",2),s([r.query(".letters")],t.prototype,"letters",2),s([r.query(".ml7")],t.prototype,"ml7",2),t=s([r.customElement("schmancy-animated-text")],t);
37
- //# sourceMappingURL=animated-text-BitOmeE1.cjs.map
37
+ //# sourceMappingURL=animated-text-CYmUxmlv.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-BitOmeE1.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"qcAsBA,IAAqBA,EAArB,cAAkDC,EAAAA,YAAYC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAA9D,CAAA,CAAA,aAAAC,CAAAA,MAAAA,GAAAC,SAoBoCC,EAAAA,KAAAC,KAAA,UACCD,KAAAE,MAAA,EACEF,KAAAG,QAAA,GACCH,KAAAI,SAAA,IACJJ,KAAAK,MAAA,CAAC,EAAG,CACFL,EAAAA,KAAAM,QAAA,CAAC,EAAG,CAAA,EACDN,KAAAO,WAAA,CAAC,SAAU,OACXP,KAAAQ,WAAA,CAAC,QAAS,KACVR,EAAAA,KAAAS,WAAA,CAAC,EAAG,CAAA,EACPT,KAAAU,QAAA,CAAC,IAAK,CACEV,EAAAA,KAAAW,gBAAA,CAO7C,aAAaC,EACN,CAAA,MAAAC,EAAOD,EAAQE,sBACrB,EAAA,OACCD,EAAKE,KAAO,GACZF,EAAKG,MAAQ,GACbH,EAAKI,SAAWC,OAAOC,aAAeC,SAASC,gBAAgBC,eAC/DT,EAAKU,QAAUL,OAAOM,YAAcJ,SAASC,gBAAgBI,YAAA,CAI/D,MAAMC,cAAAA,CAEA1B,KAAA2B,QAAQC,UAAY5B,KAAK6B,YAAY,CAAGC,EAAAA,YAAaC,QAAQ,MAAO,gCAGzEC,EAAAA,EAAAA,OAECC,EAAAA,SAAS,EAAA,EAAIC,KACZC,EAAAA,YACAC,EAAAA,EAAAA,OAAO,IAAA,CACA,MAAAvB,EAAOb,KAAKc,sBAAAA,EAClB,OAAOD,EAAKwB,MAAQ,GAAKxB,EAAKyB,OAAS,CAAA,CAAA,EAExCC,EAAAA,KAAK,CAAA,CAAA,EAGNC,YAAUtB,OAAQ,QAAA,EAAUgB,KAC3BO,EAAAA,aAAa,EAAA,OAAc,CAC1BC,QAAS,GACTC,SAAU,EAAA,CAAA,EAEXR,EAAAA,UAAU,EAAA,EACVS,EAAAA,IAAI,IAAM5C,KAAK6C,aAAa7C,IAAAA,CAAAA,EAC5B8C,yBACAC,MAAkBC,GAEZA,CAAAA,CAAAA,GAAchD,KAAKW,eACvBsC,MAAMC,KAAKlD,KAAK2B,QAAQwB,QAAAA,EAAUC,QAASC,GAAAA,CAC1CA,EAAOC,MAAMhD,QAAU,GAAA,CACvB,CAAA,CAAA,EAGH8B,YAAuBS,CAAAA,EAEvB7C,KAAKW,cAAgBoC,EAAAA,IAAQR,EAAAA,EAAAA,KAAK,CAAA,EAClCQ,MAAI,CACHQ,KAAM,IAEWvD,CAAAA,KAAKwD,WAAYC,iBAA8B,cAEvDL,EAAAA,QAAQ,CAACC,EAAQK,IAAAA,CAGxB,MAAMC,EAAgB;AAAA,8BACC3D,KAAKO,WAAW,CAAA,CAAA,KAAOP,KAAKQ,WAAW,CAAOR,CAAAA,KAAAA,KAAKS,WAAW,CAAA,CAAA;AAAA,0BAClET,KAAKU,QAAQ;wBACfV,KAAKK,MAAM,CAGtBuD,CAAAA;AAAAA,gBAAAA,EAAc;AAAA,8BACG5D,KAAKO,WAAW,CAAA,CAAA,KAAOP,KAAKQ,WAAW,CAAOR,CAAAA,KAAAA,KAAKS,WAAW,CAAA,CAAA;AAAA,0BAClET,KAAKU,QAAQ;wBACfV,KAAKK,MAAM,CAQtBwD,CAAAA;AAAAA,gBAAAA,EAAwB,CAC7B,CAAEC,UAAWH,EAAerD,QAASyD,OAAO/D,KAAKM,QAAQ,CACzD,CAAA,CAAA,EAAA,CAAEwD,UAAWF,EAAatD,QAASyD,OAAO/D,KAAKM,QAAQ,CAAA,CAAA,CAAA,CAAA,EAGxD+C,EAAOW,QAAQH,EAAW,CACzBzD,SAAUJ,KAAKI,SACf6D,OAXyC,CACzCC,QAAS,gCAUSlE,EAAAA,KAAKC,OAAS,WAChCC,MAAOF,KAAKE,MAAQwD,EAAI1D,KAAKG,QAC7BgE,KAAM,UACN,CAAA,CAAA,CAAA,CACD,CAIHC,CAAAA,CAAAA,CAAAA,EAAAA,UAAAA,CAAU,CAGb,QACQ,CAAA,OAAAC,EAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,GAAA,CAAA,EA1GoBC,EAAA,CAA3BC,WAAS,CAAEC,KAAMT,MAAAA,CAAAA,CAAAA,EApBEpE,EAoBQ8E,UAAA,OAAA,CACAH,EAAAA,EAAA,CAA3BC,WAAS,CAAEC,KAAME,MArBE/E,CAAAA,CAAAA,EAAAA,EAqBQ8E,UAAA,QAAA,CAAA,EACAH,EAAA,CAA3BC,WAAS,CAAEC,KAAME,MAAAA,CAAAA,CAAAA,EAtBE/E,EAsBQ8E,UAAA,UAAA,CACAH,EAAAA,EAAA,CAA3BC,WAAS,CAAEC,KAAME,MAvBE/E,CAAAA,CAAAA,EAAAA,EAuBQ8E,UAAA,WAAA,GACDH,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KAAAA,CAAAA,CAAAA,EAxBEtD,EAwBO8E,UAAA,QAAA,CACAH,EAAAA,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KAzBEtD,CAAAA,CAAAA,EAAAA,EAyBO8E,UAAA,UAAA,CAAA,EACAH,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KAAAA,CAAAA,CAAAA,EA1BEtD,EA0BO8E,UAAA,aAAA,CACAH,EAAAA,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KA3BEtD,CAAAA,CAAAA,EAAAA,EA2BO8E,UAAA,aAAA,GACAH,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KAAAA,CAAAA,CAAAA,EA5BEtD,EA4BO8E,UAAA,aAAA,CACAH,EAAAA,EAAA,CAA1BC,WAAS,CAAEC,KAAMvB,KA7BEtD,CAAAA,CAAAA,EAAAA,EA6BO8E,UAAA,UAAA,CAAA,EACEH,EAAA,CAA5BC,WAAS,CAAEC,KAAMG,OAAAA,CAAAA,CAAAA,EA9BEhF,EA8BS8E,UAAA,gBAAA,CAAA,EAEPH,EAAA,CAArBM,EAAmBA,mBAhCAjF,CAAAA,EAAAA,EAgCE8E,UAAA,cAAA,CAAA,EACHH,EAAA,CAAlBO,EAAAA,MAAM,UAAA,CAAA,EAjCalF,EAiCD8E,UAAA,UAAA,CACJH,EAAAA,EAAA,CAAdO,EAAAA,MAAM,MAlCalF,CAAAA,EAAAA,EAkCL8E,UAAA,MAAA,GAlCK9E,EAArB2E,EAAA,CADCQ,EAAAA,cAAc,wBACMnF,CAAAA,EAAAA,CAAAA"}
1
+ {"version":3,"file":"animated-text-CYmUxmlv.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","constructor","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","render","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";require("./animated-text-BitOmeE1.cjs");
1
+ "use strict";require("./animated-text-CYmUxmlv.cjs");
2
2
  //# sourceMappingURL=animated-text.cjs.map
@@ -1,2 +1,2 @@
1
- import "./animated-text-DcLpvyCq.js";
1
+ import "./animated-text-AbNgT7ie.js";
2
2
  //# sourceMappingURL=animated-text.js.map
package/dist/area.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./area.component-BTLn3oIv.cjs"),e=require("./utils-BqFGvnN9.cjs");exports.FINDING_MORTIES=t.FINDING_MORTIES,exports.HERE_RICKY=t.HERE_RICKY,exports.HISTORY_STRATEGY=t.HISTORY_STRATEGY,Object.defineProperty(exports,"SchmancyArea",{enumerable:!0,get:()=>t.SchmancyArea}),exports.area=t.area,exports.routerHistory=t.routerHistory,exports.buildQueryString=e.buildQueryString,exports.compareActiveRoutes=e.compareActiveRoutes,exports.compareCustomElementConstructors=e.compareCustomElementConstructors,exports.compareRouteActions=e.compareRouteActions,exports.createRouteCacheKey=e.createRouteCacheKey,exports.debounce=e.debounce,exports.decodeRouteState=e.decodeRouteState,exports.deepMerge=e.deepMerge,exports.encodeRouteState=e.encodeRouteState,exports.extractQueryParams=e.extractQueryParams,exports.getTagName=e.getTagName,exports.isObject=e.isObject,exports.normalizeTagName=e.normalizeTagName,exports.sanitizeRouteState=e.sanitizeRouteState;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./area.component-B1Lmmsuk.cjs"),e=require("./utils-C9nzOWpR.cjs");exports.FINDING_MORTIES=t.FINDING_MORTIES,exports.HERE_RICKY=t.HERE_RICKY,exports.HISTORY_STRATEGY=t.HISTORY_STRATEGY,Object.defineProperty(exports,"SchmancyArea",{enumerable:!0,get:()=>t.SchmancyArea}),exports.area=t.area,exports.routerHistory=t.routerHistory,exports.buildQueryString=e.buildQueryString,exports.compareActiveRoutes=e.compareActiveRoutes,exports.compareCustomElementConstructors=e.compareCustomElementConstructors,exports.compareRouteActions=e.compareRouteActions,exports.createRouteCacheKey=e.createRouteCacheKey,exports.debounce=e.debounce,exports.decodeRouteState=e.decodeRouteState,exports.deepMerge=e.deepMerge,exports.encodeRouteState=e.encodeRouteState,exports.extractQueryParams=e.extractQueryParams,exports.getTagName=e.getTagName,exports.isObject=e.isObject,exports.normalizeTagName=e.normalizeTagName,exports.sanitizeRouteState=e.sanitizeRouteState;
2
2
  //# sourceMappingURL=area.cjs.map
@@ -1,8 +1,8 @@
1
- "use strict";const r=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const b=require("./litElement.mixin-CII9bbap.cjs");require("./tailwind.mixin-CBu1BEQZ.cjs");const y=require("lit/decorators.js"),S=require("lit"),O=require("./index-DyJ0oDpR.cjs"),g=new r.Subject,w="FINDING_MORTIES",E="HERE_RICKY",d=new WeakMap;class l{constructor(){this.prettyURL=!1,this.mode="HISTORY",this.request=new r.ReplaySubject(1),this.current=new Map,this.$current=new r.ReplaySubject(1),this.enableHistoryMode=!0,this.findingMortiesEvent=new CustomEvent(w),this.disposed=!1,this.isProcessingPopstate=!1,this.$current.next(this.current),this.$current.subscribe(t=>{this.disposed||t.forEach((e,s)=>{this.getOrCreateAreaSubject(s).next(e)})}),this.initializeFromBrowserState()}get areaSubjects(){let t=d.get(this);return t||(t=new Map,d.set(this,t)),t}initializeFromBrowserState(){try{const t=history.state;t&&t.schmancyAreas&&(Object.entries(t.schmancyAreas).forEach(([e,s])=>{this.current.set(e,s)}),this.$current.next(this.current))}catch{}}getOrCreateAreaSubject(t){let e=this.areaSubjects.get(t);if(!e||e.closed){e=new r.ReplaySubject(1),this.areaSubjects.set(t,e);const s=this.current.get(t);s&&e.next({...s,state:s.state||{},params:s.params||{},props:s.props||{}})}return e}on(t,e=!1){if(!t)throw new Error("Area name is required");const s=this.getOrCreateAreaSubject(t).asObservable().pipe(r.distinctUntilChanged((n,o)=>n.component===o.component&&JSON.stringify(n.state)===JSON.stringify(o.state)&&JSON.stringify(n.params)===JSON.stringify(o.params)),r.shareReplay(1));return e?s.pipe(r.skip(1)):s}all(t=!1){const e=this.$current.asObservable().pipe(r.shareReplay(1));return t?e.pipe(r.skip(1)):e}getState(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.state),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}params(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.params),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}param(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.params(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}props(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.props),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}prop(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.props(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}find(){return r.zip([r.fromEvent(window,E).pipe(r.map(t=>t.detail),r.bufferTime(0)),r.of(1).pipe(r.tap(()=>window.dispatchEvent(this.findingMortiesEvent)))]).pipe(r.map(([t])=>t),r.timeout(1),r.catchError(()=>r.EMPTY))}push(t){if(!t.area)throw new Error("Area is required for route action");if(this.isProcessingPopstate)return;const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"programmatic"};this.enableHistoryMode&&g.next(e),this.request.next(e),this.dispatchAreaEvent(e.area,e)}_updateFromBrowser(t){const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"browser"};this.isProcessingPopstate=!0,this.request.next(e),this.isProcessingPopstate=!1}_updateBrowserHistory(t,e,s,n){if(this.enableHistoryMode)try{const o=history.state||{},i=o.schmancyAreas||{},c={component:e.component,area:e.area};e.state&&Object.keys(e.state).length>0&&(c.state=e.state),e.params&&Object.keys(e.params).length>0&&(c.params=e.params),e.props&&Object.keys(e.props).length>0&&(c.props=e.props),i[t]=c;const m={...o,schmancyAreas:i},u=this.createCleanURL(i,n);s==="replace"||s==="pop"?history.replaceState(m,"",u):s!=="push"&&s||history.pushState(m,"",u)}catch{}}createCleanURL(t,e){let s="";if(e!==!0){const n=new URLSearchParams(location.search);Array.isArray(e)&&e.forEach(o=>n.delete(o)),s=n.toString(),s=s?`?${s}`:""}if(this.prettyURL){const n=t.main;if(n){let o=`/${n.component}`;const i=new URLSearchParams(s);n.params&&Object.entries(n.params).forEach(([m,u])=>{typeof u!="string"&&typeof u!="number"||i.set(m,String(u))});const c=i.toString();return o+(c?`?${c}`:"")}}try{const n={};return Object.entries(t).forEach(([o,i])=>{const c={component:i.component};i.state&&Object.keys(i.state).length>0&&(c.state=i.state),i.params&&Object.keys(i.params).length>0&&(c.params=i.params),i.props&&Object.keys(i.props).length>0&&(c.props=i.props),n[o]=c}),`/${encodeURIComponent(JSON.stringify(n))}${s}`}catch{return location.pathname}}restoreFromBrowserState(t){try{if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}parseStateFromURL(){const t=location.pathname.split("/").pop();if(!t)return{};try{const e=decodeURIComponent(t),s=JSON.parse(e);if(typeof s=="object"&&s!==null)return s}catch{}return{}}dispatchAreaEvent(t,e){const s=new CustomEvent(`schmancy-area-${t}-changed`,{detail:{area:t,component:e.component,state:e.state,params:e.params,props:e.props,historyStrategy:e.historyStrategy},bubbles:!0,composed:!0});window.dispatchEvent(s)}pop(t){if(!t)throw new Error("Area name is required");if(this.current.delete(t),this.$current.next(this.current),this.enableHistoryMode)try{const e=history.state||{},s={...e.schmancyAreas||{}};delete s[t];const n={...e,schmancyAreas:s},o=this.createCleanURL(s);history.replaceState(n,"",o)}catch{}}clear(){this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.current.clear(),this.$current.next(this.current),this.enableHistoryMode&&history.replaceState({schmancyAreas:{}},"",`/${location.search}`)}dispose(){this.disposed||(this.disposed=!0,this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.request.complete(),this.$current.complete(),g.complete(),this.current.clear(),d.delete(this))}static getInstance(){return l.instance||(l.instance=new l),l.instance}get state(){try{const t=history.state;if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}hasArea(t){return this.current.has(t)}getActiveAreas(){return Array.from(this.current.keys())}getRoute(t){return this.current.get(t)}}const p=l.getInstance();typeof window<"u"&&window.addEventListener("unload",()=>{p.dispose()});var h=(a=>(a.push="push",a.replace="replace",a.pop="pop",a.silent="silent",a))(h||{}),A=Object.defineProperty,C=Object.getOwnPropertyDescriptor,f=(a,t,e,s)=>{for(var n,o=s>1?void 0:s?C(t,e):t,i=a.length-1;i>=0;i--)(n=a[i])&&(o=(s?n(t,e,o):n(o))||o);return s&&o&&A(t,e,o),o};exports.SchmancyArea=class extends b.$LitElement(S.css`
1
+ "use strict";const r=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const b=require("./litElement.mixin-Cs3zx2X6.cjs");require("./tailwind.mixin-1kcW0BGm.cjs");const y=require("lit/decorators.js"),S=require("lit"),O=require("./index-DyJ0oDpR.cjs"),g=new r.Subject,w="FINDING_MORTIES",E="HERE_RICKY",d=new WeakMap;class l{constructor(){this.prettyURL=!1,this.mode="HISTORY",this.request=new r.ReplaySubject(1),this.current=new Map,this.$current=new r.ReplaySubject(1),this.enableHistoryMode=!0,this.findingMortiesEvent=new CustomEvent(w),this.disposed=!1,this.isProcessingPopstate=!1,this.$current.next(this.current),this.$current.subscribe(t=>{this.disposed||t.forEach((e,s)=>{this.getOrCreateAreaSubject(s).next(e)})}),this.initializeFromBrowserState()}get areaSubjects(){let t=d.get(this);return t||(t=new Map,d.set(this,t)),t}initializeFromBrowserState(){try{const t=history.state;t&&t.schmancyAreas&&(Object.entries(t.schmancyAreas).forEach(([e,s])=>{this.current.set(e,s)}),this.$current.next(this.current))}catch{}}getOrCreateAreaSubject(t){let e=this.areaSubjects.get(t);if(!e||e.closed){e=new r.ReplaySubject(1),this.areaSubjects.set(t,e);const s=this.current.get(t);s&&e.next({...s,state:s.state||{},params:s.params||{},props:s.props||{}})}return e}on(t,e=!1){if(!t)throw new Error("Area name is required");const s=this.getOrCreateAreaSubject(t).asObservable().pipe(r.distinctUntilChanged((n,o)=>n.component===o.component&&JSON.stringify(n.state)===JSON.stringify(o.state)&&JSON.stringify(n.params)===JSON.stringify(o.params)),r.shareReplay(1));return e?s.pipe(r.skip(1)):s}all(t=!1){const e=this.$current.asObservable().pipe(r.shareReplay(1));return t?e.pipe(r.skip(1)):e}getState(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.state),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}params(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.params),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}param(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.params(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}props(t){if(!t)throw new Error("Area name is required");return this.on(t).pipe(r.map(e=>e.props),r.filter(e=>e!=null),r.distinctUntilChanged((e,s)=>JSON.stringify(e)===JSON.stringify(s)),r.map(e=>e),r.catchError(e=>r.EMPTY))}prop(t,e){if(!t||!e)throw new Error("Area name and key are required");return this.props(t).pipe(r.map(s=>s[e]),r.filter(s=>s!==void 0),r.distinctUntilChanged(),r.map(s=>s),r.catchError(s=>r.EMPTY))}find(){return r.zip([r.fromEvent(window,E).pipe(r.map(t=>t.detail),r.bufferTime(0)),r.of(1).pipe(r.tap(()=>window.dispatchEvent(this.findingMortiesEvent)))]).pipe(r.map(([t])=>t),r.timeout(1),r.catchError(()=>r.EMPTY))}push(t){if(!t.area)throw new Error("Area is required for route action");if(this.isProcessingPopstate)return;const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"programmatic"};this.enableHistoryMode&&g.next(e),this.request.next(e),this.dispatchAreaEvent(e.area,e)}_updateFromBrowser(t){const e={...t,state:t.state||{},params:t.params||{},props:t.props||{},_source:"browser"};this.isProcessingPopstate=!0,this.request.next(e),this.isProcessingPopstate=!1}_updateBrowserHistory(t,e,s,n){if(this.enableHistoryMode)try{const o=history.state||{},i=o.schmancyAreas||{},c={component:e.component,area:e.area};e.state&&Object.keys(e.state).length>0&&(c.state=e.state),e.params&&Object.keys(e.params).length>0&&(c.params=e.params),e.props&&Object.keys(e.props).length>0&&(c.props=e.props),i[t]=c;const m={...o,schmancyAreas:i},u=this.createCleanURL(i,n);s==="replace"||s==="pop"?history.replaceState(m,"",u):s!=="push"&&s||history.pushState(m,"",u)}catch{}}createCleanURL(t,e){let s="";if(e!==!0){const n=new URLSearchParams(location.search);Array.isArray(e)&&e.forEach(o=>n.delete(o)),s=n.toString(),s=s?`?${s}`:""}if(this.prettyURL){const n=t.main;if(n){let o=`/${n.component}`;const i=new URLSearchParams(s);n.params&&Object.entries(n.params).forEach(([m,u])=>{typeof u!="string"&&typeof u!="number"||i.set(m,String(u))});const c=i.toString();return o+(c?`?${c}`:"")}}try{const n={};return Object.entries(t).forEach(([o,i])=>{const c={component:i.component};i.state&&Object.keys(i.state).length>0&&(c.state=i.state),i.params&&Object.keys(i.params).length>0&&(c.params=i.params),i.props&&Object.keys(i.props).length>0&&(c.props=i.props),n[o]=c}),`/${encodeURIComponent(JSON.stringify(n))}${s}`}catch{return location.pathname}}restoreFromBrowserState(t){try{if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}parseStateFromURL(){const t=location.pathname.split("/").pop();if(!t)return{};try{const e=decodeURIComponent(t),s=JSON.parse(e);if(typeof s=="object"&&s!==null)return s}catch{}return{}}dispatchAreaEvent(t,e){const s=new CustomEvent(`schmancy-area-${t}-changed`,{detail:{area:t,component:e.component,state:e.state,params:e.params,props:e.props,historyStrategy:e.historyStrategy},bubbles:!0,composed:!0});window.dispatchEvent(s)}pop(t){if(!t)throw new Error("Area name is required");if(this.current.delete(t),this.$current.next(this.current),this.enableHistoryMode)try{const e=history.state||{},s={...e.schmancyAreas||{}};delete s[t];const n={...e,schmancyAreas:s},o=this.createCleanURL(s);history.replaceState(n,"",o)}catch{}}clear(){this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.current.clear(),this.$current.next(this.current),this.enableHistoryMode&&history.replaceState({schmancyAreas:{}},"",`/${location.search}`)}dispose(){this.disposed||(this.disposed=!0,this.areaSubjects.forEach(t=>t.complete()),this.areaSubjects.clear(),this.request.complete(),this.$current.complete(),g.complete(),this.current.clear(),d.delete(this))}static getInstance(){return l.instance||(l.instance=new l),l.instance}get state(){try{const t=history.state;if(t&&t.schmancyAreas)return t.schmancyAreas}catch{}return this.parseStateFromURL()}hasArea(t){return this.current.has(t)}getActiveAreas(){return Array.from(this.current.keys())}getRoute(t){return this.current.get(t)}}const p=l.getInstance();typeof window<"u"&&window.addEventListener("unload",()=>{p.dispose()});var h=(a=>(a.push="push",a.replace="replace",a.pop="pop",a.silent="silent",a))(h||{}),A=Object.defineProperty,C=Object.getOwnPropertyDescriptor,f=(a,t,e,s)=>{for(var n,o=s>1?void 0:s?C(t,e):t,i=a.length-1;i>=0;i--)(n=a[i])&&(o=(s?n(t,e,o):n(o))||o);return s&&o&&A(t,e,o),o};exports.SchmancyArea=class extends b.$LitElement(S.css`
2
2
  :host {
3
3
  position: relative;
4
4
  display: block;
5
5
  inset: 0;
6
6
  }
7
7
  `){getComponentFromPathname(a,t){return r.of(a).pipe(r.map(e=>e.split("/").pop()??""),r.map(e=>{try{return JSON.parse(decodeURIComponent(e))}catch{return{}}}),r.map(e=>e[this.name]),r.map(e=>!e&&this.default?{component:this.default,state:void 0,params:void 0}:e),r.filter(e=>O.libExports.isPresent(e)),r.map(e=>({area:this.name,component:e.component??this.default,state:e.state||{},params:e.params||{},historyStrategy:t})),r.catchError(e=>this.default?r.of({area:this.name,component:this.default,historyStrategy:t,state:{},params:{},props:{}}):r.EMPTY))}getComponentFromBrowserState(a){try{const t=a.state;if(t&&t.schmancyAreas&&t.schmancyAreas[this.name]){const e=t.schmancyAreas[this.name];return{area:this.name,component:e.component,state:e.state||{},params:e.params||{},historyStrategy:h.silent,_source:"browser"}}}catch{}return null}firstUpdated(){if(!this.name)throw new Error("Area name or default component not set");r.merge(r.of(location.pathname).pipe(r.switchMap(a=>this.getComponentFromPathname(a,h.silent)),r.take(1),r.tap(a=>{})),p.request.pipe(r.filter(({area:a})=>a===this.name),r.tap(a=>{})),r.fromEvent(window,"popstate").pipe(r.switchMap(a=>{const t=a.state?.schmancyAreas?.[this.name],e=a.target.location.pathname;return t?r.of({area:this.name,component:t.component,state:t.state||{},params:t.params||{},historyStrategy:h.silent}):this.getComponentFromPathname(e,h.silent).pipe(r.switchMap(s=>s.component||this.default?r.of(s):r.of({area:this.name,component:"",state:{},params:{},historyStrategy:h.silent})))}),r.tap(a=>{})),p.$current.pipe(r.map(a=>!a.has(this.name)),r.distinctUntilChanged(),r.filter(a=>a),r.map(()=>({area:this.name,component:this.default||"",state:{},params:{},historyStrategy:h.silent})),r.tap(()=>{}))).pipe(r.filter(a=>a.component!==null&&a.component!==void 0),r.takeUntil(this.disconnecting),r.distinctUntilChanged((a,t)=>{let e="",s="";typeof a.component=="function"?e=a.component.name||a.component.toString():typeof a.component=="string"&&(e=a.component),typeof t.component=="function"?s=t.component.name||t.component.toString():typeof t.component=="string"&&(s=t.component);const n=m=>m?.replaceAll("-","").toLowerCase(),o=n(e)===n(s),i=JSON.stringify(a.params||{})===JSON.stringify(t.params||{}),c=JSON.stringify(a.state||{})===JSON.stringify(t.state||{});return o&&i&&c})).pipe(r.switchMap(a=>{const t=a.component;return t instanceof Promise?r.from(t).pipe(r.map(e=>({component:e.exports?.default||e.default,route:a})),r.catchError(e=>r.EMPTY)):r.of({component:t,route:a})}),r.map(({component:a,route:t})=>{let e=null;return e=a===""?null:typeof a=="string"?document.createElement(a):a instanceof HTMLElement?a:typeof a=="function"?new a:a,e&&t.params&&Object.entries(t.params).forEach(([s,n])=>{e[s]=n}),e&&t.state&&(e.state=t.state),{component:e,route:t}}),r.tap(({component:a,route:t})=>{this.updateDOM(a),this.updateInternalState(t,a),this.updateBrowserHistory(t,a)}),r.catchError(a=>r.EMPTY),r.takeUntil(this.disconnecting)).subscribe({error:a=>{}})}updateDOM(a){const t=this.shadowRoot?.children[0],e=!!t;t?.remove(),a&&(a.classList.add("opacity-0"),this.shadowRoot?.append(a),a.animate([{opacity:0},{opacity:1}],{duration:e?150:100,easing:"cubic-bezier(0.25, 0.8, 0.25, 1)",fill:"forwards"}))}updateInternalState(a,t){if(!t)return;const e={component:t.tagName.toLowerCase(),state:a.state||{},area:this.name,params:a.params||{}};p.current.set(this.name,e),p.$current.next(p.current)}updateBrowserHistory(a,t){if(!p.enableHistoryMode||!t)return;const e={component:t.tagName.toLowerCase(),state:a.state||{},area:this.name,params:a.params||{}};p._updateBrowserHistory(this.name,e,a.historyStrategy,a.clearQueryParams)}newPath(a,t){const e=location.pathname.split("/").pop();let s={};try{s=e?JSON.parse(decodeURIComponent(e)):{}}catch{s={}}t.state=t.state??{};const n=t.clearQueryParams?this.queryParamClear(t.clearQueryParams):document.location.search;return encodeURIComponent(JSON.stringify({...s,[this.name]:{component:a.toLowerCase(),state:t.state,params:t.params}})).concat(`${n}`)}queryParamClear(a){if(!a)return"";const t=new URLSearchParams(location.search);return a===!0?"":(a.forEach(e=>t.delete(e)),t.toString()===""?"":`?${t.toString()}`)}render(){return S.html` <slot> </slot> `}},f([y.property()],exports.SchmancyArea.prototype,"name",2),f([y.property()],exports.SchmancyArea.prototype,"default",2),exports.SchmancyArea=f([y.customElement("schmancy-area")],exports.SchmancyArea),exports.FINDING_MORTIES=w,exports.HERE_RICKY=E,exports.HISTORY_STRATEGY=h,exports.area=p,exports.routerHistory=g;
8
- //# sourceMappingURL=area.component-BTLn3oIv.cjs.map
8
+ //# sourceMappingURL=area.component-B1Lmmsuk.cjs.map