@mhmo91/schmancy 0.3.2 → 0.3.6

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 (308) hide show
  1. package/ai/boat.md +6 -6
  2. package/ai/index.md +1 -1
  3. package/ai/layout.md +161 -140
  4. package/dist/ai/boat.md +6 -6
  5. package/dist/ai/index.md +1 -1
  6. package/dist/ai/layout.md +161 -140
  7. package/dist/{animated-text-DuL0BVFF.cjs → animated-text-CvOxKhXc.cjs} +2 -2
  8. package/dist/{animated-text-DuL0BVFF.cjs.map → animated-text-CvOxKhXc.cjs.map} +1 -1
  9. package/dist/{animated-text-B2RjyIK5.js → animated-text-DzY-xfTP.js} +3 -3
  10. package/dist/{animated-text-B2RjyIK5.js.map → animated-text-DzY-xfTP.js.map} +1 -1
  11. package/dist/animated-text.cjs +1 -1
  12. package/dist/animated-text.js +1 -1
  13. package/dist/area.cjs +1 -1
  14. package/dist/{area.component-DYh2KKnh.cjs → area.component-DEOob0ox.cjs} +2 -2
  15. package/dist/{area.component-DYh2KKnh.cjs.map → area.component-DEOob0ox.cjs.map} +1 -1
  16. package/dist/{area.component-C4lraBSz.js → area.component-X7coBLB2.js} +3 -3
  17. package/dist/{area.component-C4lraBSz.js.map → area.component-X7coBLB2.js.map} +1 -1
  18. package/dist/area.js +1 -1
  19. package/dist/{autocomplete-C2MgBZdi.cjs → autocomplete-DqbWESS2.cjs} +2 -2
  20. package/dist/{autocomplete-C2MgBZdi.cjs.map → autocomplete-DqbWESS2.cjs.map} +1 -1
  21. package/dist/{autocomplete-BXf34fA-.js → autocomplete-KvR4MRDs.js} +3 -3
  22. package/dist/{autocomplete-BXf34fA-.js.map → autocomplete-KvR4MRDs.js.map} +1 -1
  23. package/dist/autocomplete.cjs +1 -1
  24. package/dist/autocomplete.js +1 -1
  25. package/dist/{avatar-DVN44OzV.cjs → avatar-BvqaPLuL.cjs} +2 -2
  26. package/dist/{avatar-DVN44OzV.cjs.map → avatar-BvqaPLuL.cjs.map} +1 -1
  27. package/dist/{avatar-DupGPy32.js → avatar-Dy63jAZP.js} +48 -47
  28. package/dist/{avatar-DupGPy32.js.map → avatar-Dy63jAZP.js.map} +1 -1
  29. package/dist/badge.cjs +1 -1
  30. package/dist/badge.js +1 -1
  31. package/dist/boat-CL-jiVBO.js +99 -0
  32. package/dist/boat-CL-jiVBO.js.map +1 -0
  33. package/dist/boat-DpwpvrwB.cjs +70 -0
  34. package/dist/boat-DpwpvrwB.cjs.map +1 -0
  35. package/dist/boat.cjs +1 -1
  36. package/dist/boat.js +1 -1
  37. package/dist/busy.cjs +1 -1
  38. package/dist/busy.js +1 -1
  39. package/dist/button.cjs +1 -1
  40. package/dist/button.js +1 -1
  41. package/dist/card.cjs +1 -1
  42. package/dist/card.js +1 -1
  43. package/dist/{checkbox-CZUwhaUm.js → checkbox-BjDdxFyz.js} +6 -6
  44. package/dist/{checkbox-CZUwhaUm.js.map → checkbox-BjDdxFyz.js.map} +1 -1
  45. package/dist/{checkbox-BSndX5zU.cjs → checkbox-DFSfKDe7.cjs} +2 -2
  46. package/dist/{checkbox-BSndX5zU.cjs.map → checkbox-DFSfKDe7.cjs.map} +1 -1
  47. package/dist/checkbox.cjs +1 -1
  48. package/dist/checkbox.js +1 -1
  49. package/dist/{chips-Cy-Uf0By.js → chips-DdDQGtnw.js} +9 -9
  50. package/dist/{chips-Cy-Uf0By.js.map → chips-DdDQGtnw.js.map} +1 -1
  51. package/dist/{chips-Do9LFtJA.cjs → chips-SlEVDtLL.cjs} +2 -2
  52. package/dist/{chips-Do9LFtJA.cjs.map → chips-SlEVDtLL.cjs.map} +1 -1
  53. package/dist/chips.cjs +1 -1
  54. package/dist/chips.js +1 -1
  55. package/dist/{circular-progress-DS6pw54i.cjs → circular-progress-D0Ei_TVO.cjs} +2 -2
  56. package/dist/{circular-progress-DS6pw54i.cjs.map → circular-progress-D0Ei_TVO.cjs.map} +1 -1
  57. package/dist/{circular-progress-D5vVDl4d.js → circular-progress-hBD2CBnQ.js} +3 -3
  58. package/dist/{circular-progress-D5vVDl4d.js.map → circular-progress-hBD2CBnQ.js.map} +1 -1
  59. package/dist/circular-progress.cjs +1 -1
  60. package/dist/circular-progress.js +1 -1
  61. package/dist/code-highlight.cjs +1 -1
  62. package/dist/code-highlight.js +1 -1
  63. package/dist/{code-preview-CXO3vsRi.cjs → code-preview-CHUDQgBs.cjs} +2 -2
  64. package/dist/{code-preview-CXO3vsRi.cjs.map → code-preview-CHUDQgBs.cjs.map} +1 -1
  65. package/dist/{code-preview-AQ1T_x11.js → code-preview-rZY7AeQl.js} +2 -2
  66. package/dist/{code-preview-AQ1T_x11.js.map → code-preview-rZY7AeQl.js.map} +1 -1
  67. package/dist/components.cjs +1 -1
  68. package/dist/components.js +1 -1
  69. package/dist/content-drawer.cjs +1 -1
  70. package/dist/content-drawer.js +1 -1
  71. package/dist/date-range-DYdBqzUs.js +638 -0
  72. package/dist/date-range-DYdBqzUs.js.map +1 -0
  73. package/dist/date-range-vfh_MQQ8.cjs +140 -0
  74. package/dist/date-range-vfh_MQQ8.cjs.map +1 -0
  75. package/dist/date-range.cjs +1 -1
  76. package/dist/date-range.js +3 -2
  77. package/dist/{delay-BjYDvkud.js → delay-D0iuwCUK.js} +2 -2
  78. package/dist/{delay-BjYDvkud.js.map → delay-D0iuwCUK.js.map} +1 -1
  79. package/dist/{delay-BV4QWYDw.cjs → delay-DSlalih2.cjs} +2 -2
  80. package/dist/{delay-BV4QWYDw.cjs.map → delay-DSlalih2.cjs.map} +1 -1
  81. package/dist/delay.cjs +1 -1
  82. package/dist/delay.js +1 -1
  83. package/dist/dialog-content-Bc8Dem2U.js +282 -0
  84. package/dist/dialog-content-Bc8Dem2U.js.map +1 -0
  85. package/dist/dialog-content-C2mSWw93.cjs +106 -0
  86. package/dist/dialog-content-C2mSWw93.cjs.map +1 -0
  87. package/dist/dialog-events--DuMbZ8T.cjs +2 -0
  88. package/dist/dialog-events--DuMbZ8T.cjs.map +1 -0
  89. package/dist/dialog-events-mjOcyPQ-.js +6 -0
  90. package/dist/dialog-events-mjOcyPQ-.js.map +1 -0
  91. package/dist/dialog-service-Di9NiBao.cjs +2 -0
  92. package/dist/dialog-service-Di9NiBao.cjs.map +1 -0
  93. package/dist/dialog-service-noGCuxg1.js +127 -0
  94. package/dist/dialog-service-noGCuxg1.js.map +1 -0
  95. package/dist/dialog.cjs +1 -1
  96. package/dist/dialog.js +7 -6
  97. package/dist/dialog.js.map +1 -1
  98. package/dist/{divider-CEyi1ooH.cjs → divider-BLWfsrgW.cjs} +2 -2
  99. package/dist/{divider-CEyi1ooH.cjs.map → divider-BLWfsrgW.cjs.map} +1 -1
  100. package/dist/{divider-3tv52Nso.js → divider-CE4Z74RZ.js} +3 -3
  101. package/dist/{divider-3tv52Nso.js.map → divider-CE4Z74RZ.js.map} +1 -1
  102. package/dist/divider.cjs +1 -1
  103. package/dist/divider.js +1 -1
  104. package/dist/{dropdown-content-BoKXumxT.cjs → dropdown-content-DGzqx1S_.cjs} +2 -2
  105. package/dist/{dropdown-content-BoKXumxT.cjs.map → dropdown-content-DGzqx1S_.cjs.map} +1 -1
  106. package/dist/{dropdown-content-R-EVmTas.js → dropdown-content-owobMGzG.js} +3 -3
  107. package/dist/{dropdown-content-R-EVmTas.js.map → dropdown-content-owobMGzG.js.map} +1 -1
  108. package/dist/dropdown.cjs +1 -1
  109. package/dist/dropdown.js +1 -1
  110. package/dist/extra.cjs +1 -1
  111. package/dist/extra.js +1 -1
  112. package/dist/{flex-DFGC-5rG.js → flex-BsSncdMc.js} +2 -2
  113. package/dist/flex-BsSncdMc.js.map +1 -0
  114. package/dist/{flex-Dfk62-Dn.cjs → flex-Dpr6dCxo.cjs} +2 -2
  115. package/dist/flex-Dpr6dCxo.cjs.map +1 -0
  116. package/dist/{form-C-YpNF0Z.cjs → form-BQE8JXxF.cjs} +2 -2
  117. package/dist/{form-C-YpNF0Z.cjs.map → form-BQE8JXxF.cjs.map} +1 -1
  118. package/dist/{form-DWz7p8Ru.js → form-CHNcjEbu.js} +2 -2
  119. package/dist/{form-DWz7p8Ru.js.map → form-CHNcjEbu.js.map} +1 -1
  120. package/dist/form.cjs +1 -1
  121. package/dist/form.js +1 -1
  122. package/dist/{icon-D-o0ZArk.js → icon-BEBPLEy5.js} +2 -2
  123. package/dist/{icon-D-o0ZArk.js.map → icon-BEBPLEy5.js.map} +1 -1
  124. package/dist/{icon-button-6K7j0Ifl.js → icon-button-2HzMutoD.js} +3 -3
  125. package/dist/{icon-button-6K7j0Ifl.js.map → icon-button-2HzMutoD.js.map} +1 -1
  126. package/dist/{icon-button-fT0E5fJN.cjs → icon-button-BCMiumJV.cjs} +2 -2
  127. package/dist/{icon-button-fT0E5fJN.cjs.map → icon-button-BCMiumJV.cjs.map} +1 -1
  128. package/dist/{icon-D_0MYmHT.cjs → icon-pSnkdbDc.cjs} +2 -2
  129. package/dist/{icon-D_0MYmHT.cjs.map → icon-pSnkdbDc.cjs.map} +1 -1
  130. package/dist/icons.cjs +1 -1
  131. package/dist/icons.js +1 -1
  132. package/dist/index.cjs +1 -1
  133. package/dist/index.js +149 -147
  134. package/dist/index.js.map +1 -1
  135. package/dist/{input-y7H2rS_c.cjs → input-BN2LXdXz.cjs} +2 -2
  136. package/dist/{input-y7H2rS_c.cjs.map → input-BN2LXdXz.cjs.map} +1 -1
  137. package/dist/{input-3-d9ijGr.js → input-BeF_sRNg.js} +2 -2
  138. package/dist/{input-3-d9ijGr.js.map → input-BeF_sRNg.js.map} +1 -1
  139. package/dist/input.cjs +1 -1
  140. package/dist/input.js +1 -1
  141. package/dist/layout.cjs +1 -1
  142. package/dist/layout.js +1 -1
  143. package/dist/{list-CQCRYpMc.cjs → list-BEbwK0js.cjs} +2 -2
  144. package/dist/{list-CQCRYpMc.cjs.map → list-BEbwK0js.cjs.map} +1 -1
  145. package/dist/{list-DdZ0XbRC.js → list-BL8wGmIx.js} +2 -2
  146. package/dist/{list-DdZ0XbRC.js.map → list-BL8wGmIx.js.map} +1 -1
  147. package/dist/list.cjs +1 -1
  148. package/dist/list.js +1 -1
  149. package/dist/{litElement.mixin-DCTPuIQ4.js → litElement.mixin-Csoyz9Ih.js} +2 -2
  150. package/dist/{litElement.mixin-DCTPuIQ4.js.map → litElement.mixin-Csoyz9Ih.js.map} +1 -1
  151. package/dist/{litElement.mixin-DcYItU_Y.cjs → litElement.mixin-DBKBn5-0.cjs} +2 -2
  152. package/dist/{litElement.mixin-DcYItU_Y.cjs.map → litElement.mixin-DBKBn5-0.cjs.map} +1 -1
  153. package/dist/{menu-DTNNwC3X.cjs → menu-BdzIXUjg.cjs} +2 -2
  154. package/dist/{menu-DTNNwC3X.cjs.map → menu-BdzIXUjg.cjs.map} +1 -1
  155. package/dist/{menu-BBeCodjv.js → menu-DyAZ0l5W.js} +3 -3
  156. package/dist/{menu-BBeCodjv.js.map → menu-DyAZ0l5W.js.map} +1 -1
  157. package/dist/menu.cjs +1 -1
  158. package/dist/menu.js +1 -1
  159. package/dist/nav-drawer.cjs +1 -1
  160. package/dist/nav-drawer.js +1 -1
  161. package/dist/{notification-service-Dw1vWE8m.cjs → notification-service-CXc-_Kb_.cjs} +2 -2
  162. package/dist/{notification-service-Dw1vWE8m.cjs.map → notification-service-CXc-_Kb_.cjs.map} +1 -1
  163. package/dist/{notification-service-cV_jYoFM.js → notification-service-DKZuIFCM.js} +3 -3
  164. package/dist/{notification-service-cV_jYoFM.js.map → notification-service-DKZuIFCM.js.map} +1 -1
  165. package/dist/notification.cjs +1 -1
  166. package/dist/notification.js +1 -1
  167. package/dist/{option-D9kAMX93.js → option-CYaG8vnG.js} +2 -2
  168. package/dist/{option-D9kAMX93.js.map → option-CYaG8vnG.js.map} +1 -1
  169. package/dist/{option-BkYybtqQ.cjs → option-EnoMfyR-.cjs} +2 -2
  170. package/dist/{option-BkYybtqQ.cjs.map → option-EnoMfyR-.cjs.map} +1 -1
  171. package/dist/option.cjs +1 -1
  172. package/dist/option.js +1 -1
  173. package/dist/{payment-card-form-C2X4AyyB.js → payment-card-form-BSmtEC4S.js} +3 -3
  174. package/dist/{payment-card-form-C2X4AyyB.js.map → payment-card-form-BSmtEC4S.js.map} +1 -1
  175. package/dist/{payment-card-form-CLRmWodS.cjs → payment-card-form-CpgGccLb.cjs} +2 -2
  176. package/dist/{payment-card-form-CLRmWodS.cjs.map → payment-card-form-CpgGccLb.cjs.map} +1 -1
  177. package/dist/{radio-button-b-3WocDM.cjs → radio-button-BJjvHX_o.cjs} +2 -2
  178. package/dist/{radio-button-b-3WocDM.cjs.map → radio-button-BJjvHX_o.cjs.map} +1 -1
  179. package/dist/{radio-button-C0IThgUp.js → radio-button-BURq74ON.js} +2 -2
  180. package/dist/{radio-button-C0IThgUp.js.map → radio-button-BURq74ON.js.map} +1 -1
  181. package/dist/radio-group.cjs +1 -1
  182. package/dist/radio-group.js +1 -1
  183. package/dist/{schmancy-steps-container-zat0B8ZS.cjs → schmancy-steps-container-DDTHvnOz.cjs} +2 -2
  184. package/dist/{schmancy-steps-container-zat0B8ZS.cjs.map → schmancy-steps-container-DDTHvnOz.cjs.map} +1 -1
  185. package/dist/{schmancy-steps-container-B1pLiWXH.js → schmancy-steps-container-Jm5DjyWr.js} +2 -2
  186. package/dist/{schmancy-steps-container-B1pLiWXH.js.map → schmancy-steps-container-Jm5DjyWr.js.map} +1 -1
  187. package/dist/{select-BLI7oX60.js → select-C7KUOvwM.js} +3 -3
  188. package/dist/{select-BLI7oX60.js.map → select-C7KUOvwM.js.map} +1 -1
  189. package/dist/{select-DsFHJyZw.cjs → select-DhsURRRa.cjs} +2 -2
  190. package/dist/{select-DsFHJyZw.cjs.map → select-DhsURRRa.cjs.map} +1 -1
  191. package/dist/select.cjs +1 -1
  192. package/dist/select.js +1 -1
  193. package/dist/{sheet-cxQG63jb.js → sheet-BD5cVkNb.js} +12 -12
  194. package/dist/{sheet-cxQG63jb.js.map → sheet-BD5cVkNb.js.map} +1 -1
  195. package/dist/{sheet-xbPPu7eJ.cjs → sheet-L0BMbi1B.cjs} +2 -2
  196. package/dist/{sheet-xbPPu7eJ.cjs.map → sheet-L0BMbi1B.cjs.map} +1 -1
  197. package/dist/sheet.cjs +1 -1
  198. package/dist/sheet.js +1 -1
  199. package/dist/{slider-DI42q9wf.cjs → slider-CAYWu8jw.cjs} +2 -2
  200. package/dist/{slider-DI42q9wf.cjs.map → slider-CAYWu8jw.cjs.map} +1 -1
  201. package/dist/{slider-D5GAJBtp.js → slider-DiRa4lW4.js} +3 -3
  202. package/dist/{slider-D5GAJBtp.js.map → slider-DiRa4lW4.js.map} +1 -1
  203. package/dist/slider.cjs +1 -1
  204. package/dist/slider.js +1 -1
  205. package/dist/{spinner-jxwBlOT6.js → spinner-CnjBDKlQ.js} +3 -3
  206. package/dist/{spinner-jxwBlOT6.js.map → spinner-CnjBDKlQ.js.map} +1 -1
  207. package/dist/{spinner-I_J8koHo.cjs → spinner-XXVCb3SB.cjs} +2 -2
  208. package/dist/{spinner-I_J8koHo.cjs.map → spinner-XXVCb3SB.cjs.map} +1 -1
  209. package/dist/steps.cjs +1 -1
  210. package/dist/steps.js +1 -1
  211. package/dist/{surface-CgjTa2At.cjs → surface-B93-RzTP.cjs} +2 -2
  212. package/dist/{surface-CgjTa2At.cjs.map → surface-B93-RzTP.cjs.map} +1 -1
  213. package/dist/{surface-KO5G93q6.js → surface-DPoDLP5m.js} +2 -2
  214. package/dist/{surface-KO5G93q6.js.map → surface-DPoDLP5m.js.map} +1 -1
  215. package/dist/surface.cjs +1 -1
  216. package/dist/surface.js +1 -1
  217. package/dist/{table-tMVVNYqd.cjs → table-CZ0Kxa-3.cjs} +2 -2
  218. package/dist/{table-tMVVNYqd.cjs.map → table-CZ0Kxa-3.cjs.map} +1 -1
  219. package/dist/{table-ae8AvxxX.js → table-Dsb3MObV.js} +2 -2
  220. package/dist/{table-ae8AvxxX.js.map → table-Dsb3MObV.js.map} +1 -1
  221. package/dist/table.cjs +1 -1
  222. package/dist/table.js +1 -1
  223. package/dist/{tabs-compatibility-K7hN1FMS.cjs → tabs-compatibility-B8L2QZNH.cjs} +2 -2
  224. package/dist/{tabs-compatibility-K7hN1FMS.cjs.map → tabs-compatibility-B8L2QZNH.cjs.map} +1 -1
  225. package/dist/{tabs-compatibility-DgqIx0_d.js → tabs-compatibility-Dx9gQzb8.js} +2 -2
  226. package/dist/{tabs-compatibility-DgqIx0_d.js.map → tabs-compatibility-Dx9gQzb8.js.map} +1 -1
  227. package/dist/tabs.cjs +1 -1
  228. package/dist/tabs.js +1 -1
  229. package/dist/tailwind.mixin-CYcf-U4R.cjs +2 -0
  230. package/dist/{tailwind.mixin-DWvvleWP.cjs.map → tailwind.mixin-CYcf-U4R.cjs.map} +1 -1
  231. package/dist/tailwind.mixin-D0pn9tte.js +43 -0
  232. package/dist/{tailwind.mixin-BPIDvfDe.js.map → tailwind.mixin-D0pn9tte.js.map} +1 -1
  233. package/dist/teleport.cjs +1 -1
  234. package/dist/teleport.js +1 -1
  235. package/dist/{textarea-Coqtz8dI.js → textarea-DRRZOHFq.js} +2 -2
  236. package/dist/{textarea-Coqtz8dI.js.map → textarea-DRRZOHFq.js.map} +1 -1
  237. package/dist/{textarea-DlxS_YbV.cjs → textarea-c08GNNdE.cjs} +2 -2
  238. package/dist/{textarea-DlxS_YbV.cjs.map → textarea-c08GNNdE.cjs.map} +1 -1
  239. package/dist/textarea.cjs +1 -1
  240. package/dist/textarea.js +1 -1
  241. package/dist/{theme-button-MLe6lqim.cjs → theme-button-C1WDEzCs.cjs} +2 -2
  242. package/dist/{theme-button-MLe6lqim.cjs.map → theme-button-C1WDEzCs.cjs.map} +1 -1
  243. package/dist/{theme-button-aGO9tJ2X.js → theme-button-CVyoV6wr.js} +2 -2
  244. package/dist/{theme-button-aGO9tJ2X.js.map → theme-button-CVyoV6wr.js.map} +1 -1
  245. package/dist/theme-button.cjs +1 -1
  246. package/dist/theme-button.js +1 -1
  247. package/dist/theme.cjs +1 -1
  248. package/dist/theme.component-hNNgXue7.cjs +3 -0
  249. package/dist/{theme.component-Bhodmw04.cjs.map → theme.component-hNNgXue7.cjs.map} +1 -1
  250. package/dist/{theme.component-DtSJBwyz.js → theme.component-rwAI-wT2.js} +112 -108
  251. package/dist/{theme.component-DtSJBwyz.js.map → theme.component-rwAI-wT2.js.map} +1 -1
  252. package/dist/theme.js +1 -1
  253. package/dist/{timezone-MNEWy4jq.cjs → timezone-B9ulERyu.cjs} +2 -2
  254. package/dist/{timezone-MNEWy4jq.cjs.map → timezone-B9ulERyu.cjs.map} +1 -1
  255. package/dist/{timezone-DRzBs7kc.js → timezone-D3qGsxoX.js} +3 -3
  256. package/dist/{timezone-DRzBs7kc.js.map → timezone-D3qGsxoX.js.map} +1 -1
  257. package/dist/{tooltip-DXepH6lG.cjs → tooltip-BcfZtAjX.cjs} +2 -2
  258. package/dist/{tooltip-DXepH6lG.cjs.map → tooltip-BcfZtAjX.cjs.map} +1 -1
  259. package/dist/{tooltip-CyHXFI4n.js → tooltip-wORJd0XU.js} +2 -2
  260. package/dist/{tooltip-CyHXFI4n.js.map → tooltip-wORJd0XU.js.map} +1 -1
  261. package/dist/tooltip.cjs +1 -1
  262. package/dist/tooltip.js +1 -1
  263. package/dist/{tree-BkqvB6rh.cjs → tree-D0gmqicQ.cjs} +2 -2
  264. package/dist/{tree-BkqvB6rh.cjs.map → tree-D0gmqicQ.cjs.map} +1 -1
  265. package/dist/{tree-BDvR_Ooq.js → tree-DbCTJGWZ.js} +2 -2
  266. package/dist/{tree-BDvR_Ooq.js.map → tree-DbCTJGWZ.js.map} +1 -1
  267. package/dist/tree.cjs +1 -1
  268. package/dist/tree.js +1 -1
  269. package/dist/{typewriter-CoOcshun.cjs → typewriter-B9CTFK02.cjs} +2 -2
  270. package/dist/{typewriter-CoOcshun.cjs.map → typewriter-B9CTFK02.cjs.map} +1 -1
  271. package/dist/{typewriter-B1uzg12Z.js → typewriter-CrSNqZl5.js} +16 -16
  272. package/dist/{typewriter-B1uzg12Z.js.map → typewriter-CrSNqZl5.js.map} +1 -1
  273. package/dist/typewriter.cjs +1 -1
  274. package/dist/typewriter.js +1 -1
  275. package/dist/{typography-CRa9BYOd.cjs → typography-846IJx5H.cjs} +2 -2
  276. package/dist/{typography-CRa9BYOd.cjs.map → typography-846IJx5H.cjs.map} +1 -1
  277. package/dist/{typography-BoHmbEy7.js → typography-B2HnnOVG.js} +2 -2
  278. package/dist/{typography-BoHmbEy7.js.map → typography-B2HnnOVG.js.map} +1 -1
  279. package/dist/typography.cjs +1 -1
  280. package/dist/typography.js +1 -1
  281. package/package.json +1 -1
  282. package/types/src/boat/boat.d.ts +3 -2
  283. package/types/src/date-range/date-range.d.ts +35 -5
  284. package/types/src/date-range/index.d.ts +1 -0
  285. package/types/src/dialog/dialog-events.d.ts +13 -0
  286. package/types/src/dialog/dialog-service.d.ts +11 -0
  287. package/types/src/dialog/dialog.component.d.ts +12 -0
  288. package/types/src/layout/flex/flex.d.ts +10 -0
  289. package/types/src/layout/grid/grid.d.ts +10 -0
  290. package/types/src/layout/layout.d.ts +10 -0
  291. package/types/src/layout/v2/flex.d.ts +9 -0
  292. package/dist/boat-D6RMa9wL.js +0 -95
  293. package/dist/boat-D6RMa9wL.js.map +0 -1
  294. package/dist/boat-DeEs020x.cjs +0 -64
  295. package/dist/boat-DeEs020x.cjs.map +0 -1
  296. package/dist/date-range-B0CSi1D6.cjs +0 -121
  297. package/dist/date-range-B0CSi1D6.cjs.map +0 -1
  298. package/dist/date-range-IrXoBUVr.js +0 -563
  299. package/dist/date-range-IrXoBUVr.js.map +0 -1
  300. package/dist/dialog-content-D5kti4-b.cjs +0 -106
  301. package/dist/dialog-content-D5kti4-b.cjs.map +0 -1
  302. package/dist/dialog-content-D9uVow4E.js +0 -343
  303. package/dist/dialog-content-D9uVow4E.js.map +0 -1
  304. package/dist/flex-DFGC-5rG.js.map +0 -1
  305. package/dist/flex-Dfk62-Dn.cjs.map +0 -1
  306. package/dist/tailwind.mixin-BPIDvfDe.js +0 -43
  307. package/dist/tailwind.mixin-DWvvleWP.cjs +0 -2
  308. package/dist/theme.component-Bhodmw04.cjs +0 -3
package/dist/ai/layout.md CHANGED
@@ -1,166 +1,187 @@
1
1
  # Schmancy Layout - AI Reference
2
2
 
3
- ```js
4
- // Grid Layout
5
- <schmancy-grid
6
- columns="3" // Number of columns or template
7
- rows="auto" // Number of rows or template
8
- gap="16px" // Gap between items
9
- column-gap="16px" // Column-specific gap
10
- row-gap="16px" // Row-specific gap
11
- justify-items="start|center|end|stretch"
12
- align-items="start|center|end|stretch"
13
- justify-content="start|center|end|space-between|space-around|space-evenly"
14
- align-content="start|center|end|space-between|space-around|space-evenly">
15
-
3
+ ## ⚠️ DEPRECATION NOTICE
4
+
5
+ The following layout components are **deprecated** and will be removed in a future version:
6
+ - `<schmancy-grid>` - Use Tailwind CSS grid classes instead
7
+ - `<schmancy-flex>` - Use Tailwind CSS flex classes instead
8
+ - `<sch-flex>` - Use Tailwind CSS flex classes instead
9
+ - Layout base class - Use Tailwind utilities directly
10
+
11
+ ### Migration Guide
12
+
13
+ ```html
14
+ <!-- OLD (deprecated) -->
15
+ <schmancy-grid columns="3" gap="16px">
16
16
  <div>Item 1</div>
17
17
  <div>Item 2</div>
18
18
  <div>Item 3</div>
19
19
  </schmancy-grid>
20
20
 
21
- // Advanced grid with template
22
- <schmancy-grid
23
- columns="repeat(12, 1fr)"
24
- rows="auto auto 1fr"
25
- template-areas="
26
- 'header header header header'
27
- 'sidebar content content content'
28
- 'footer footer footer footer'
29
- ">
30
- <div style="grid-area: header">Header</div>
31
- <div style="grid-area: sidebar">Sidebar</div>
32
- <div style="grid-area: content">Content</div>
33
- <div style="grid-area: footer">Footer</div>
34
- </schmancy-grid>
35
-
36
- // Flex Layout
37
- <schmancy-flex
38
- direction="row|column|row-reverse|column-reverse"
39
- wrap="nowrap|wrap|wrap-reverse"
40
- justify-content="start|center|end|space-between|space-around|space-evenly"
41
- align-items="start|center|end|stretch|baseline"
42
- align-content="start|center|end|space-between|space-around|space-evenly"
43
- gap="16px" // Gap between items
44
- column-gap="16px" // Column-specific gap
45
- row-gap="16px"> // Row-specific gap
46
-
21
+ <!-- NEW (recommended) -->
22
+ <div class="grid grid-cols-3 gap-4">
47
23
  <div>Item 1</div>
48
24
  <div>Item 2</div>
49
- <div style="flex: 1">Flexible Item</div>
25
+ <div>Item 3</div>
26
+ </div>
27
+
28
+ <!-- OLD (deprecated) -->
29
+ <schmancy-flex direction="row" gap="16px" justify-content="space-between">
30
+ <div>Left</div>
31
+ <div>Right</div>
50
32
  </schmancy-flex>
51
33
 
52
- // Responsive layouts (using attributes)
53
- <schmancy-grid
54
- columns="1"
55
- columns-md="2"
56
- columns-lg="3"
57
- columns-xl="4"
58
- gap="8px"
59
- gap-md="16px"
60
- gap-lg="24px">
61
-
62
- <!-- Content -->
63
- </schmancy-grid>
34
+ <!-- NEW (recommended) -->
35
+ <div class="flex flex-row gap-4 justify-between">
36
+ <div>Left</div>
37
+ <div>Right</div>
38
+ </div>
39
+ ```
64
40
 
65
- <schmancy-flex
66
- direction="column"
67
- direction-md="row"
68
- align-items="center"
69
- justify-content-md="space-between">
70
-
71
- <!-- Content -->
72
- </schmancy-flex>
41
+ ## Modern Layout Approach with Tailwind CSS
73
42
 
74
- // Scroll Container
75
- <schmancy-scroll
76
- direction="vertical|horizontal|both"
77
- scrollbar="auto|always|hover|none">
78
-
79
- <!-- Scrollable content -->
80
- </schmancy-scroll>
43
+ Instead of using deprecated layout components, use Tailwind CSS utilities directly:
81
44
 
82
- // Layout v2 Components (enhanced versions)
83
- <schmancy-flex-v2
84
- display="flex|inline-flex"
85
- direction="row|column"
86
- wrap="nowrap|wrap|wrap-reverse"
87
- justify="flex-start|flex-end|center|space-between|space-around|space-evenly"
88
- items="flex-start|flex-end|center|stretch|baseline"
89
- content="flex-start|flex-end|center|space-between|space-around|space-evenly"
90
- gap="none|xs|sm|md|lg|xl">
91
-
92
- <!-- Content -->
93
- </schmancy-flex-v2>
94
-
95
- <schmancy-grid-v2
96
- display="grid|inline-grid"
97
- template-columns="1fr 1fr|repeat(3, 1fr)"
98
- template-rows="auto|1fr auto"
99
- template-areas="'header header' 'sidebar content' 'footer footer'"
100
- gap="none|xs|sm|md|lg|xl"
101
- justify-content="start|end|center|stretch|space-around|space-between|space-evenly"
102
- align-content="start|end|center|stretch|space-around|space-between|space-evenly"
103
- justify-items="start|end|center|stretch"
104
- align-items="start|end|center|stretch">
105
-
106
- <!-- Content -->
107
- </schmancy-grid-v2>
108
-
109
- // Examples
110
- // Responsive grid layout
111
- <schmancy-grid
112
- columns="1"
113
- columns-md="2"
114
- columns-lg="4"
115
- gap="16px">
45
+ ### Grid Layouts
46
+ ```html
47
+ <!-- Basic grid -->
48
+ <div class="grid grid-cols-3 gap-4">
49
+ <div>Item 1</div>
50
+ <div>Item 2</div>
51
+ <div>Item 3</div>
52
+ </div>
53
+
54
+ <!-- Responsive grid -->
55
+ <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-4">
116
56
  <div>Card 1</div>
117
57
  <div>Card 2</div>
118
58
  <div>Card 3</div>
119
59
  <div>Card 4</div>
120
- </schmancy-grid>
60
+ </div>
61
+
62
+ <!-- Grid with template areas -->
63
+ <div class="grid grid-rows-[auto_1fr_auto] grid-cols-[250px_1fr] h-screen">
64
+ <header class="col-span-2">Header</header>
65
+ <aside>Sidebar</aside>
66
+ <main>Content</main>
67
+ <footer class="col-span-2">Footer</footer>
68
+ </div>
69
+ ```
121
70
 
122
- // Flex layout for a form
123
- <schmancy-flex
124
- direction="column"
125
- gap="16px">
126
- <h2>Contact Form</h2>
71
+ ### Flex Layouts
72
+ ```html
73
+ <!-- Basic flex -->
74
+ <div class="flex gap-4">
75
+ <div>Item 1</div>
76
+ <div>Item 2</div>
77
+ <div class="flex-1">Flexible Item</div>
78
+ </div>
79
+
80
+ <!-- Column direction with alignment -->
81
+ <div class="flex flex-col items-center gap-4">
82
+ <h2>Title</h2>
83
+ <p>Content</p>
84
+ <button>Action</button>
85
+ </div>
86
+
87
+ <!-- Responsive flex -->
88
+ <div class="flex flex-col md:flex-row items-center md:justify-between gap-4">
89
+ <div>Logo</div>
90
+ <nav class="flex gap-2">
91
+ <a href="#">Link 1</a>
92
+ <a href="#">Link 2</a>
93
+ </nav>
94
+ </div>
95
+ ```
96
+
97
+ ### Common Layout Patterns
98
+
99
+ ```html
100
+ <!-- Form layout -->
101
+ <form class="flex flex-col gap-4 max-w-md mx-auto">
102
+ <h2 class="text-2xl font-bold">Contact Form</h2>
127
103
  <schmancy-input label="Name"></schmancy-input>
128
104
  <schmancy-input label="Email"></schmancy-input>
129
105
  <schmancy-textarea label="Message"></schmancy-textarea>
130
106
 
131
- <schmancy-flex
132
- direction="row"
133
- justify-content="end"
134
- gap="8px">
135
- <schmancy-button kind="secondary">Cancel</schmancy-button>
136
- <schmancy-button kind="primary">Submit</schmancy-button>
137
- </schmancy-flex>
138
- </schmancy-flex>
139
-
140
- // App layout with header, sidebar and content
141
- <schmancy-grid
142
- style="height: 100vh"
143
- template-areas="
144
- 'header header'
145
- 'sidebar content'
146
- "
147
- template-rows="64px 1fr"
148
- template-columns="250px 1fr">
149
-
150
- <div style="grid-area: header">
151
- <schmancy-appbar>App Title</schmancy-appbar>
107
+ <div class="flex gap-2 justify-end">
108
+ <schmancy-button variant="outlined">Cancel</schmancy-button>
109
+ <schmancy-button variant="filled">Submit</schmancy-button>
152
110
  </div>
153
-
154
- <div style="grid-area: sidebar">
155
- <schmancy-list>
156
- <schmancy-list-item>Dashboard</schmancy-list-item>
157
- <schmancy-list-item>Settings</schmancy-list-item>
158
- <schmancy-list-item>Profile</schmancy-list-item>
159
- </schmancy-list>
111
+ </form>
112
+
113
+ <!-- App layout -->
114
+ <div class="grid grid-rows-[auto_1fr] h-screen">
115
+ <header class="border-b">
116
+ <!-- Navigation -->
117
+ </header>
118
+ <div class="grid grid-cols-[250px_1fr]">
119
+ <aside class="border-r">
120
+ <!-- Sidebar -->
121
+ </aside>
122
+ <main class="overflow-auto p-4">
123
+ <!-- Content -->
124
+ </main>
160
125
  </div>
161
-
162
- <schmancy-scroll style="grid-area: content">
163
- <!-- Main content -->
164
- </schmancy-scroll>
165
- </schmancy-grid>
126
+ </div>
127
+
128
+ <!-- Card grid -->
129
+ <div class="grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-6 p-6">
130
+ <schmancy-card>Card 1</schmancy-card>
131
+ <schmancy-card>Card 2</schmancy-card>
132
+ <schmancy-card>Card 3</schmancy-card>
133
+ </div>
134
+ ```
135
+
136
+ ### Useful Tailwind Classes
137
+
138
+ #### Grid
139
+ - `grid` - Display grid
140
+ - `grid-cols-{n}` - Number of columns
141
+ - `grid-rows-{n}` - Number of rows
142
+ - `gap-{size}` - Gap between items
143
+ - `col-span-{n}` - Column span
144
+ - `row-span-{n}` - Row span
145
+ - `place-items-{align}` - Align items
146
+ - `place-content-{align}` - Align content
147
+
148
+ #### Flex
149
+ - `flex` - Display flex
150
+ - `flex-row` / `flex-col` - Direction
151
+ - `flex-wrap` / `flex-nowrap` - Wrapping
152
+ - `items-{align}` - Align items
153
+ - `justify-{align}` - Justify content
154
+ - `gap-{size}` - Gap between items
155
+ - `flex-1` / `flex-none` - Flex grow/shrink
156
+
157
+ #### Spacing
158
+ - `p-{size}` - Padding
159
+ - `m-{size}` - Margin
160
+ - `space-x-{size}` - Horizontal spacing
161
+ - `space-y-{size}` - Vertical spacing
162
+
163
+ #### Sizing
164
+ - `w-{size}` - Width
165
+ - `h-{size}` - Height
166
+ - `min-w-{size}` - Min width
167
+ - `max-w-{size}` - Max width
168
+ - `min-h-{size}` - Min height
169
+ - `max-h-{size}` - Max height
170
+
171
+ ## Non-Deprecated Components
172
+
173
+ ### Scroll Container (if available)
174
+ ```html
175
+ <schmancy-scroll
176
+ direction="vertical|horizontal|both"
177
+ scrollbar="auto|always|hover|none">
178
+ <!-- Scrollable content -->
179
+ </schmancy-scroll>
180
+ ```
181
+
182
+ For most cases, use Tailwind's overflow utilities instead:
183
+ ```html
184
+ <div class="overflow-auto h-64">
185
+ <!-- Scrollable content -->
186
+ </div>
166
187
  ```
@@ -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-DcYItU_Y.cjs");require("./tailwind.mixin-DWvvleWP.cjs");const c=require("lit"),r=require("lit/decorators.js");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-DBKBn5-0.cjs");require("./tailwind.mixin-CYcf-U4R.cjs");const c=require("lit"),r=require("lit/decorators.js");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-DuL0BVFF.cjs.map
37
+ //# sourceMappingURL=animated-text-CvOxKhXc.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-DuL0BVFF.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"animated-text-CvOxKhXc.cjs","sources":["../src/animated-text/animated-text.ts"],"sourcesContent":["// Removed: import { createTimeline, stagger } from '@packages/anime-beta-master'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedNodes } from 'lit/decorators.js'\nimport {\n\tconcat,\n\tdistinctUntilChanged,\n\tfilter,\n\tfromEvent,\n\tinterval,\n\tmap,\n\tstartWith,\n\ttake,\n\ttap,\n\tthrottleTime,\n} from 'rxjs'\n\n/**\n * @element schmancy-animated-text\n * Inspired by https://tobiasahlin.com/moving-letters/#1\n */\n@customElement('schmancy-animated-text')\nexport default class SchmancyAnimatedText extends $LitElement(css`\n\t:host {\n\t\tfont-family: inherit;\n\t\tdisplay: block;\n\t}\n\t.ml7 {\n\t\tposition: relative;\n\t\tdisplay: flex;\n\t}\n\t.ml7 .text-wrapper {\n\t\tposition: relative;\n\t\tdisplay: inline-block;\n\t\toverflow: hidden;\n\t}\n\t.ml7 .letter {\n\t\ttransform-origin: 0 100%;\n\t\tdisplay: inline-block;\n\t\topacity: 0;\n\t}\n`) {\n\t@property({ type: String }) ease = 'outExpo' // not a built-in string for Web Animations\n\t@property({ type: Number }) delay = 0\n\t@property({ type: Number }) stagger = 50\n\t@property({ type: Number }) duration = 750\n\t@property({ type: Array }) scale = [0, 1]\n\t@property({ type: Array }) opacity = [0, 1]\n\t@property({ type: Array }) translateX = ['0.55em', '0em']\n\t@property({ type: Array }) translateY = ['1.1em', '0em']\n\t@property({ type: Array }) translateZ = [0, 0]\n\t@property({ type: Array }) rotateZ = [180, 0]\n\t@property({ type: Boolean }) resetOnScroll = true\n\n\t@queryAssignedNodes() defaultSlot!: HTMLElement[]\n\t@query('.letters') letters!: HTMLElement\n\t@query('.ml7') ml7!: HTMLElement\n\n\t// Function to check if an element is in the viewport\n\tisInViewport(element: HTMLElement) {\n\t\tconst rect = element.getBoundingClientRect()\n\t\treturn (\n\t\t\trect.top >= 0 &&\n\t\t\trect.left >= 0 &&\n\t\t\trect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&\n\t\t\trect.right <= (window.innerWidth || document.documentElement.clientWidth)\n\t\t)\n\t}\n\n\tasync firstUpdated() {\n\t\t// Split the text into <span class=\"letter\"> ... </span> elements\n\t\tthis.letters.innerHTML = this.defaultSlot[0].textContent!.replace(/\\S/g, `<span class=\"letter\">$&</span>`)\n\n\t\t// Observe viewport + initial readiness\n\t\tconcat(\n\t\t\t// 1) Wait until the element is rendered (width/height > 0)\n\t\t\tinterval(10).pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\tfilter(() => {\n\t\t\t\t\tconst rect = this.getBoundingClientRect()\n\t\t\t\t\treturn rect.width > 0 && rect.height > 0\n\t\t\t\t}),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\t// 2) Then handle scroll events, throttled\n\t\t\tfromEvent(window, 'scroll').pipe(\n\t\t\t\tthrottleTime(0, undefined, {\n\t\t\t\t\tleading: true,\n\t\t\t\t\ttrailing: true,\n\t\t\t\t}),\n\t\t\t\tstartWith(true),\n\t\t\t\tmap(() => this.isInViewport(this)),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttap(inViewport => {\n\t\t\t\t\t// If leaving viewport and `resetOnScroll` is true, reset letters to opacity 0\n\t\t\t\t\tif (!inViewport && this.resetOnScroll) {\n\t\t\t\t\t\tArray.from(this.letters.children).forEach((letter: HTMLElement) => {\n\t\t\t\t\t\t\tletter.style.opacity = '0'\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\tfilter(isInViewport => isInViewport),\n\t\t\t\t// If resetOnScroll = false, animate only the first time inView. If true, repeat.\n\t\t\t\tthis.resetOnScroll ? tap() : take(1),\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\t// Animate letters with the native Web Animations API\n\t\t\t\t\t\tconst letters = this.shadowRoot!.querySelectorAll<HTMLElement>('.ml7 .letter')\n\n\t\t\t\t\t\tletters.forEach((letter, i) => {\n\t\t\t\t\t\t\t// Combine all transforms into one CSS transform string\n\t\t\t\t\t\t\t// From\n\t\t\t\t\t\t\tconst fromTransform = `\n translate3d(${this.translateX[0]}, ${this.translateY[0]}, ${this.translateZ[0]}px)\n rotateZ(${this.rotateZ[0]}deg)\n scale(${this.scale[0]})\n `\n\t\t\t\t\t\t\t// To\n\t\t\t\t\t\t\tconst toTransform = `\n translate3d(${this.translateX[1]}, ${this.translateY[1]}, ${this.translateZ[1]}px)\n rotateZ(${this.rotateZ[1]}deg)\n scale(${this.scale[1]})\n `\n\t\t\t\t\t\t\t// Approximate `outExpo` or pick a standard easing (like 'ease-out'):\n\t\t\t\t\t\t\t// outExpo often approximated by cubic-bezier(0.19, 1, 0.22, 1)\n\t\t\t\t\t\t\tconst easingMap: Record<string, string> = {\n\t\t\t\t\t\t\t\toutExpo: 'cubic-bezier(0.19, 1, 0.22, 1)',\n\t\t\t\t\t\t\t\t// add more if you want\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tconst keyframes: Keyframe[] = [\n\t\t\t\t\t\t\t\t{ transform: fromTransform, opacity: String(this.opacity[0]) },\n\t\t\t\t\t\t\t\t{ transform: toTransform, opacity: String(this.opacity[1]) },\n\t\t\t\t\t\t\t]\n\n\t\t\t\t\t\t\tletter.animate(keyframes, {\n\t\t\t\t\t\t\t\tduration: this.duration,\n\t\t\t\t\t\t\t\teasing: easingMap[this.ease] || 'ease-out',\n\t\t\t\t\t\t\t\tdelay: this.delay + i * this.stagger, // staggered start\n\t\t\t\t\t\t\t\tfill: 'forwards', // so the letters remain visible\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})\n\t\t\t\t\t},\n\t\t\t\t}),\n\t\t\t),\n\t\t).subscribe()\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<span class=\"ml7\">\n\t\t\t\t<span class=\"text-wrapper\">\n\t\t\t\t\t<span class=\"letters\">\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</span>\n\t\t\t\t</span>\n\t\t\t</span>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-animated-text': SchmancyAnimatedText\n\t}\n}\n"],"names":["SchmancyAnimatedText","$LitElement","css","super","arguments","this","ease","delay","stagger","duration","scale","opacity","translateX","translateY","translateZ","rotateZ","resetOnScroll","element","rect","getBoundingClientRect","top","left","bottom","window","innerHeight","document","documentElement","clientHeight","right","innerWidth","clientWidth","firstUpdated","letters","innerHTML","defaultSlot","textContent","replace","concat","interval","pipe","startWith","filter","width","height","take","fromEvent","throttleTime","leading","trailing","map","isInViewport","distinctUntilChanged","tap","inViewport","Array","from","children","forEach","letter","style","next","shadowRoot","querySelectorAll","i","fromTransform","toTransform","keyframes","transform","String","animate","easing","outExpo","fill","subscribe","html","__decorateClass","property","type","prototype","Number","Boolean","queryAssignedNodes","query","customElement"],"mappings":"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"}
@@ -1,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-DCTPuIQ4.js";
5
- import "./tailwind.mixin-BPIDvfDe.js";
4
+ import { $ as x } from "./litElement.mixin-Csoyz9Ih.js";
5
+ import "./tailwind.mixin-D0pn9tte.js";
6
6
  import { css as S, html as Z } from "lit";
7
7
  import { property as a, queryAssignedNodes as v, query as m, customElement as A } from "lit/decorators.js";
8
8
  var E = Object.defineProperty, O = Object.getOwnPropertyDescriptor, e = (r, s, n, i) => {
@@ -72,4 +72,4 @@ let t = class extends x(S`
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([v()], t.prototype, "defaultSlot", 2), e([m(".letters")], t.prototype, "letters", 2), e([m(".ml7")], t.prototype, "ml7", 2), t = e([A("schmancy-animated-text")], t);
75
- //# sourceMappingURL=animated-text-B2RjyIK5.js.map
75
+ //# sourceMappingURL=animated-text-DzY-xfTP.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-B2RjyIK5.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-DzY-xfTP.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,2 +1,2 @@
1
- "use strict";require("./animated-text-DuL0BVFF.cjs");
1
+ "use strict";require("./animated-text-CvOxKhXc.cjs");
2
2
  //# sourceMappingURL=animated-text.cjs.map
@@ -1,2 +1,2 @@
1
- import "./animated-text-B2RjyIK5.js";
1
+ import "./animated-text-DzY-xfTP.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-DYh2KKnh.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-DEOob0ox.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;
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-DcYItU_Y.cjs");require("./tailwind.mixin-DWvvleWP.cjs");const S=require("lit"),y=require("lit/decorators.js"),A=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||{}})}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))}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||{},_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||{},_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),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),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,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||{}),O=Object.defineProperty,R=Object.getOwnPropertyDescriptor,f=(a,t,e,s)=>{for(var n,o=s>1?void 0:s?R(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&&O(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-DBKBn5-0.cjs");require("./tailwind.mixin-CYcf-U4R.cjs");const S=require("lit"),y=require("lit/decorators.js"),A=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||{}})}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))}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||{},_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||{},_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),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),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,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||{}),O=Object.defineProperty,R=Object.getOwnPropertyDescriptor,f=(a,t,e,s)=>{for(var n,o=s>1?void 0:s?R(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&&O(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=>A.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:{}}):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=>{var s,n;const t=(n=(s=a.state)==null?void 0:s.schmancyAreas)==null?void 0:n[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(o=>o.component||this.default?r.of(o):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==null?void 0: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=>{var s;return{component:((s=e.exports)==null?void 0:s.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){var s,n;const t=(s=this.shadowRoot)==null?void 0:s.children[0],e=!!t;t==null||t.remove(),a&&(a.classList.add("opacity-0"),(n=this.shadowRoot)==null||n.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-DYh2KKnh.cjs.map
8
+ //# sourceMappingURL=area.component-DEOob0ox.cjs.map