@mhmo91/schmancy 0.4.67 → 0.4.69

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 (330) hide show
  1. package/ai/textarea.md +128 -43
  2. package/dist/ai/textarea.md +128 -43
  3. package/dist/{animated-text-Bgciqenw.cjs → animated-text-Bm1G50ol.cjs} +2 -2
  4. package/dist/{animated-text-Bgciqenw.cjs.map → animated-text-Bm1G50ol.cjs.map} +1 -1
  5. package/dist/{animated-text-BnE_bSQh.js → animated-text-DhaihRNU.js} +3 -3
  6. package/dist/{animated-text-BnE_bSQh.js.map → animated-text-DhaihRNU.js.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-4Xj6grAn.js → area.component-Cybfl9fo.js} +10 -10
  11. package/dist/{area.component-4Xj6grAn.js.map → area.component-Cybfl9fo.js.map} +1 -1
  12. package/dist/{area.component-jRAVAvAI.cjs → area.component-e7ccHmOi.cjs} +2 -2
  13. package/dist/{area.component-jRAVAvAI.cjs.map → area.component-e7ccHmOi.cjs.map} +1 -1
  14. package/dist/area.js +1 -1
  15. package/dist/{autocomplete-CdizrMKV.js → autocomplete-CHPr_eII.js} +3 -3
  16. package/dist/{autocomplete-CdizrMKV.js.map → autocomplete-CHPr_eII.js.map} +1 -1
  17. package/dist/{autocomplete-G8K-mb5t.cjs → autocomplete-DhRURo6G.cjs} +2 -2
  18. package/dist/{autocomplete-G8K-mb5t.cjs.map → autocomplete-DhRURo6G.cjs.map} +1 -1
  19. package/dist/autocomplete.cjs +1 -1
  20. package/dist/autocomplete.js +1 -1
  21. package/dist/{avatar-BSGuwqy5.js → avatar-B3rxuPbq.js} +62 -61
  22. package/dist/{avatar-BSGuwqy5.js.map → avatar-B3rxuPbq.js.map} +1 -1
  23. package/dist/{avatar-DdQOlXAG.cjs → avatar-BREyQJqy.cjs} +2 -2
  24. package/dist/{avatar-DdQOlXAG.cjs.map → avatar-BREyQJqy.cjs.map} +1 -1
  25. package/dist/badge.cjs +1 -1
  26. package/dist/badge.js +1 -1
  27. package/dist/{boat-rC0ERLqn.js → boat-Ch2Dn8n_.js} +2 -2
  28. package/dist/{boat-rC0ERLqn.js.map → boat-Ch2Dn8n_.js.map} +1 -1
  29. package/dist/{boat-CA8Wc6Hd.cjs → boat-IQenN8zy.cjs} +2 -2
  30. package/dist/{boat-CA8Wc6Hd.cjs.map → boat-IQenN8zy.cjs.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-xHdrDdwF.js → checkbox-DTtOgNWH.js} +2 -2
  40. package/dist/{checkbox-xHdrDdwF.js.map → checkbox-DTtOgNWH.js.map} +1 -1
  41. package/dist/{checkbox-DeYOFxaq.cjs → checkbox-EV_8e4Q9.cjs} +2 -2
  42. package/dist/{checkbox-DeYOFxaq.cjs.map → checkbox-EV_8e4Q9.cjs.map} +1 -1
  43. package/dist/checkbox.cjs +1 -1
  44. package/dist/checkbox.js +1 -1
  45. package/dist/{chips-DuCD124M.cjs → chips-D9bYHkvu.cjs} +2 -2
  46. package/dist/{chips-DuCD124M.cjs.map → chips-D9bYHkvu.cjs.map} +1 -1
  47. package/dist/{chips-Cd1wXy3x.js → chips-xlNsY8Dl.js} +3 -3
  48. package/dist/{chips-Cd1wXy3x.js.map → chips-xlNsY8Dl.js.map} +1 -1
  49. package/dist/chips.cjs +1 -1
  50. package/dist/chips.js +1 -1
  51. package/dist/code-highlight.cjs +1 -1
  52. package/dist/code-highlight.js +1 -1
  53. package/dist/{code-preview-C2z91M9H.cjs → code-preview-CC_QZwlB.cjs} +2 -2
  54. package/dist/{code-preview-C2z91M9H.cjs.map → code-preview-CC_QZwlB.cjs.map} +1 -1
  55. package/dist/{code-preview-BjdXVACE.js → code-preview-Dy4fNmOI.js} +2 -2
  56. package/dist/{code-preview-BjdXVACE.js.map → code-preview-Dy4fNmOI.js.map} +1 -1
  57. package/dist/components.cjs +1 -1
  58. package/dist/components.js +1 -1
  59. package/dist/content-drawer.cjs +1 -1
  60. package/dist/content-drawer.js +1 -1
  61. package/dist/{date-range-BS3TwBp1.js → date-range-CEhn7Gvg.js} +4 -4
  62. package/dist/{date-range-BS3TwBp1.js.map → date-range-CEhn7Gvg.js.map} +1 -1
  63. package/dist/{date-range-BfIiLrUu.cjs → date-range-XTs2K2Rp.cjs} +2 -2
  64. package/dist/{date-range-BfIiLrUu.cjs.map → date-range-XTs2K2Rp.cjs.map} +1 -1
  65. package/dist/{date-range-inline-BEfwxm4K.cjs → date-range-inline-BW6v6aDq.cjs} +2 -2
  66. package/dist/{date-range-inline-BEfwxm4K.cjs.map → date-range-inline-BW6v6aDq.cjs.map} +1 -1
  67. package/dist/{date-range-inline-zda6EO9f.js → date-range-inline-D-F8YwDL.js} +3 -3
  68. package/dist/{date-range-inline-zda6EO9f.js.map → date-range-inline-D-F8YwDL.js.map} +1 -1
  69. package/dist/date-range-inline.cjs +1 -1
  70. package/dist/date-range-inline.js +1 -1
  71. package/dist/date-range.cjs +1 -1
  72. package/dist/date-range.js +1 -1
  73. package/dist/{delay-BJ-Ce2HT.cjs → delay-BYwpzSYY.cjs} +2 -2
  74. package/dist/{delay-BJ-Ce2HT.cjs.map → delay-BYwpzSYY.cjs.map} +1 -1
  75. package/dist/{delay-5re8EU0Q.js → delay-CqcMq7V3.js} +12 -12
  76. package/dist/{delay-5re8EU0Q.js.map → delay-CqcMq7V3.js.map} +1 -1
  77. package/dist/delay.cjs +1 -1
  78. package/dist/delay.js +1 -1
  79. package/dist/{details-BeuCI3Tb.cjs → details-C9Vr2c8F.cjs} +2 -2
  80. package/dist/{details-BeuCI3Tb.cjs.map → details-C9Vr2c8F.cjs.map} +1 -1
  81. package/dist/{details-BBYG4_kG.js → details-gxjy3noS.js} +2 -2
  82. package/dist/{details-BBYG4_kG.js.map → details-gxjy3noS.js.map} +1 -1
  83. package/dist/details.cjs +1 -1
  84. package/dist/details.js +1 -1
  85. package/dist/{dialog-content-BHrlCw_t.js → dialog-content-CJ21oAff.js} +4 -4
  86. package/dist/{dialog-content-BHrlCw_t.js.map → dialog-content-CJ21oAff.js.map} +1 -1
  87. package/dist/{dialog-content-BYpfUBG3.cjs → dialog-content-DfXB0r6A.cjs} +2 -2
  88. package/dist/{dialog-content-BYpfUBG3.cjs.map → dialog-content-DfXB0r6A.cjs.map} +1 -1
  89. package/dist/dialog-service-ClZa-7cE.cjs +2 -0
  90. package/dist/dialog-service-ClZa-7cE.cjs.map +1 -0
  91. package/dist/dialog-service-Dwnyl4Gg.js +141 -0
  92. package/dist/dialog-service-Dwnyl4Gg.js.map +1 -0
  93. package/dist/dialog.cjs +1 -1
  94. package/dist/dialog.js +2 -2
  95. package/dist/{divider-B0LQxG1L.js → divider-Dw3OYKoH.js} +3 -3
  96. package/dist/{divider-B0LQxG1L.js.map → divider-Dw3OYKoH.js.map} +1 -1
  97. package/dist/{divider-Qgqzg8Od.cjs → divider-ZX6UG8fE.cjs} +2 -2
  98. package/dist/{divider-Qgqzg8Od.cjs.map → divider-ZX6UG8fE.cjs.map} +1 -1
  99. package/dist/divider.cjs +1 -1
  100. package/dist/divider.js +1 -1
  101. package/dist/{dropdown-content-Bh7Uek2_.js → dropdown-content-QWlP1OxV.js} +3 -3
  102. package/dist/{dropdown-content-Bh7Uek2_.js.map → dropdown-content-QWlP1OxV.js.map} +1 -1
  103. package/dist/{dropdown-content-B0T9NcP0.cjs → dropdown-content-ULdb1NeW.cjs} +2 -2
  104. package/dist/{dropdown-content-B0T9NcP0.cjs.map → dropdown-content-ULdb1NeW.cjs.map} +1 -1
  105. package/dist/dropdown.cjs +1 -1
  106. package/dist/dropdown.js +1 -1
  107. package/dist/email-recipients-DQ36ickQ.js +1358 -0
  108. package/dist/email-recipients-DQ36ickQ.js.map +1 -0
  109. package/dist/email-recipients-H9HVkFvE.cjs +851 -0
  110. package/dist/email-recipients-H9HVkFvE.cjs.map +1 -0
  111. package/dist/extra.cjs +1 -1
  112. package/dist/extra.js +1 -1
  113. package/dist/{flex-wnw8ri9G.js → flex-Cam0G_h7.js} +2 -2
  114. package/dist/{flex-wnw8ri9G.js.map → flex-Cam0G_h7.js.map} +1 -1
  115. package/dist/{flex-Cciddlkr.cjs → flex-DEiJ9fDk.cjs} +2 -2
  116. package/dist/{flex-Cciddlkr.cjs.map → flex-DEiJ9fDk.cjs.map} +1 -1
  117. package/dist/{form-LhR76UQp.cjs → form-B87v130C.cjs} +2 -2
  118. package/dist/{form-LhR76UQp.cjs.map → form-B87v130C.cjs.map} +1 -1
  119. package/dist/{form-Cd1Z72nI.js → form-EPO5N6pI.js} +2 -2
  120. package/dist/{form-Cd1Z72nI.js.map → form-EPO5N6pI.js.map} +1 -1
  121. package/dist/form.cjs +1 -1
  122. package/dist/form.js +1 -1
  123. package/dist/{formField.mixin-D67_ge3i.js → formField.mixin-B6XjIwKN.js} +2 -2
  124. package/dist/{formField.mixin-D67_ge3i.js.map → formField.mixin-B6XjIwKN.js.map} +1 -1
  125. package/dist/{formField.mixin-Dbrz3WX3.cjs → formField.mixin-Dpx2Zk8-.cjs} +2 -2
  126. package/dist/{formField.mixin-Dbrz3WX3.cjs.map → formField.mixin-Dpx2Zk8-.cjs.map} +1 -1
  127. package/dist/{icon--ULeGfN_.js → icon-C6CXTo3Z.js} +2 -2
  128. package/dist/{icon--ULeGfN_.js.map → icon-C6CXTo3Z.js.map} +1 -1
  129. package/dist/{icon-CZ3mMGdX.cjs → icon-MrlToWLJ.cjs} +2 -2
  130. package/dist/{icon-CZ3mMGdX.cjs.map → icon-MrlToWLJ.cjs.map} +1 -1
  131. package/dist/{icon-button-BXMUskpY.cjs → icon-button-BwAStx3H.cjs} +2 -2
  132. package/dist/{icon-button-BXMUskpY.cjs.map → icon-button-BwAStx3H.cjs.map} +1 -1
  133. package/dist/{icon-button-PxCZVq78.js → icon-button-Csj8jwj8.js} +3 -3
  134. package/dist/{icon-button-PxCZVq78.js.map → icon-button-Csj8jwj8.js.map} +1 -1
  135. package/dist/icons.cjs +1 -1
  136. package/dist/icons.js +1 -1
  137. package/dist/index.cjs +1 -1
  138. package/dist/index.js +171 -165
  139. package/dist/index.js.map +1 -1
  140. package/dist/{input-D3cF4qal.js → input-B9PDbNB9.js} +3 -3
  141. package/dist/{input-D3cF4qal.js.map → input-B9PDbNB9.js.map} +1 -1
  142. package/dist/{input-DxUZYu34.cjs → input-D4L413yG.cjs} +2 -2
  143. package/dist/{input-DxUZYu34.cjs.map → input-D4L413yG.cjs.map} +1 -1
  144. package/dist/input.cjs +1 -1
  145. package/dist/input.js +1 -1
  146. package/dist/layout.cjs +1 -1
  147. package/dist/layout.js +1 -1
  148. package/dist/{list-BiiXBLxU.js → list-Cdd7ht2E.js} +2 -2
  149. package/dist/{list-BiiXBLxU.js.map → list-Cdd7ht2E.js.map} +1 -1
  150. package/dist/{list-nLrSaYiQ.cjs → list-DLUbjS69.cjs} +2 -2
  151. package/dist/{list-nLrSaYiQ.cjs.map → list-DLUbjS69.cjs.map} +1 -1
  152. package/dist/list.cjs +1 -1
  153. package/dist/list.js +1 -1
  154. package/dist/{litElement.mixin-C7_rhUMZ.js → litElement.mixin-BYVS1wwl.js} +2 -2
  155. package/dist/{litElement.mixin-C7_rhUMZ.js.map → litElement.mixin-BYVS1wwl.js.map} +1 -1
  156. package/dist/{litElement.mixin-PLxdthiY.cjs → litElement.mixin-CbFQ2uxn.cjs} +2 -2
  157. package/dist/{litElement.mixin-PLxdthiY.cjs.map → litElement.mixin-CbFQ2uxn.cjs.map} +1 -1
  158. package/dist/mailbox.cjs +2 -0
  159. package/dist/mailbox.cjs.map +1 -0
  160. package/dist/mailbox.js +9 -0
  161. package/dist/mailbox.js.map +1 -0
  162. package/dist/{map-2DO-_UXg.js → map-DmjQ1Izx.js} +2 -2
  163. package/dist/{map-2DO-_UXg.js.map → map-DmjQ1Izx.js.map} +1 -1
  164. package/dist/{map-D_75VnFg.cjs → map-DxUajvGo.cjs} +2 -2
  165. package/dist/{map-D_75VnFg.cjs.map → map-DxUajvGo.cjs.map} +1 -1
  166. package/dist/map.cjs +1 -1
  167. package/dist/map.js +1 -1
  168. package/dist/{media-CdRUD9xD.cjs → media-DCIVM-cE.cjs} +2 -2
  169. package/dist/{media-CdRUD9xD.cjs.map → media-DCIVM-cE.cjs.map} +1 -1
  170. package/dist/{media-D1TDtKlB.js → media-DPurU9FS.js} +2 -2
  171. package/dist/{media-D1TDtKlB.js.map → media-DPurU9FS.js.map} +1 -1
  172. package/dist/{menu-9xXJweN3.cjs → menu-CIObvZ7n.cjs} +2 -2
  173. package/dist/{menu-9xXJweN3.cjs.map → menu-CIObvZ7n.cjs.map} +1 -1
  174. package/dist/{menu-B06dErqi.js → menu-CwRGjbC-.js} +3 -3
  175. package/dist/{menu-B06dErqi.js.map → menu-CwRGjbC-.js.map} +1 -1
  176. package/dist/menu.cjs +1 -1
  177. package/dist/menu.js +1 -1
  178. package/dist/nav-drawer.cjs +1 -1
  179. package/dist/nav-drawer.js +1 -1
  180. package/dist/netlify.toml +366 -0
  181. package/dist/{notification-service-DklXKZwa.cjs → notification-service-BMnjQVrQ.cjs} +2 -2
  182. package/dist/{notification-service-DklXKZwa.cjs.map → notification-service-BMnjQVrQ.cjs.map} +1 -1
  183. package/dist/{notification-service-BfUKN9-l.js → notification-service-DypTYarw.js} +4 -4
  184. package/dist/{notification-service-BfUKN9-l.js.map → notification-service-DypTYarw.js.map} +1 -1
  185. package/dist/notification.cjs +1 -1
  186. package/dist/notification.js +2 -2
  187. package/dist/{notify-D2k-BxXf.cjs → notify-CqCSy8Ek.cjs} +2 -2
  188. package/dist/{notify-D2k-BxXf.cjs.map → notify-CqCSy8Ek.cjs.map} +1 -1
  189. package/dist/{notify-BMbySVQI.js → notify-DUMaApt7.js} +2 -2
  190. package/dist/{notify-BMbySVQI.js.map → notify-DUMaApt7.js.map} +1 -1
  191. package/dist/{option-CXQpOQBl.cjs → option-BuN5MSy7.cjs} +2 -2
  192. package/dist/{option-CXQpOQBl.cjs.map → option-BuN5MSy7.cjs.map} +1 -1
  193. package/dist/{option-BS4qufvu.js → option-CvjLp3CB.js} +2 -2
  194. package/dist/{option-BS4qufvu.js.map → option-CvjLp3CB.js.map} +1 -1
  195. package/dist/option.cjs +1 -1
  196. package/dist/option.js +1 -1
  197. package/dist/{payment-card-form-CYT-w3-T.cjs → payment-card-form-C9VN_H07.cjs} +2 -2
  198. package/dist/{payment-card-form-CYT-w3-T.cjs.map → payment-card-form-C9VN_H07.cjs.map} +1 -1
  199. package/dist/{payment-card-form-Dj2YF8_1.js → payment-card-form-CFDdmSH2.js} +3 -3
  200. package/dist/{payment-card-form-Dj2YF8_1.js.map → payment-card-form-CFDdmSH2.js.map} +1 -1
  201. package/dist/{progress-J9tCvn5j.js → progress-BeOOCcPN.js} +2 -2
  202. package/dist/{progress-J9tCvn5j.js.map → progress-BeOOCcPN.js.map} +1 -1
  203. package/dist/{progress-DfFxDR56.cjs → progress-C-6ieScw.cjs} +2 -2
  204. package/dist/{progress-DfFxDR56.cjs.map → progress-C-6ieScw.cjs.map} +1 -1
  205. package/dist/progress.cjs +1 -1
  206. package/dist/progress.js +1 -1
  207. package/dist/{radio-button-CKUtPC82.cjs → radio-button-Bi4ywYhW.cjs} +2 -2
  208. package/dist/{radio-button-CKUtPC82.cjs.map → radio-button-Bi4ywYhW.cjs.map} +1 -1
  209. package/dist/{radio-button-BxGi5VfV.js → radio-button-D6zvMVQb.js} +3 -3
  210. package/dist/{radio-button-BxGi5VfV.js.map → radio-button-D6zvMVQb.js.map} +1 -1
  211. package/dist/radio-group.cjs +1 -1
  212. package/dist/radio-group.js +1 -1
  213. package/dist/{schmancy-steps-container-BFeVc0lq.js → schmancy-steps-container-CfDatUf8.js} +2 -2
  214. package/dist/{schmancy-steps-container-BFeVc0lq.js.map → schmancy-steps-container-CfDatUf8.js.map} +1 -1
  215. package/dist/{schmancy-steps-container-DoN92rxe.cjs → schmancy-steps-container-i8rqaPet.cjs} +2 -2
  216. package/dist/{schmancy-steps-container-DoN92rxe.cjs.map → schmancy-steps-container-i8rqaPet.cjs.map} +1 -1
  217. package/dist/{select-C426DSrs.cjs → select-BPkJhj-o.cjs} +2 -2
  218. package/dist/{select-C426DSrs.cjs.map → select-BPkJhj-o.cjs.map} +1 -1
  219. package/dist/{select-BWQJus8Q.js → select-X7b74OI8.js} +3 -3
  220. package/dist/{select-BWQJus8Q.js.map → select-X7b74OI8.js.map} +1 -1
  221. package/dist/select.cjs +1 -1
  222. package/dist/select.js +1 -1
  223. package/dist/{sheet-4oJm8fkG.cjs → sheet-BBT4JQ3Z.cjs} +2 -2
  224. package/dist/{sheet-4oJm8fkG.cjs.map → sheet-BBT4JQ3Z.cjs.map} +1 -1
  225. package/dist/{sheet-CD8QHsiF.js → sheet-DvCIJGFo.js} +4 -4
  226. package/dist/{sheet-CD8QHsiF.js.map → sheet-DvCIJGFo.js.map} +1 -1
  227. package/dist/sheet.cjs +1 -1
  228. package/dist/sheet.js +1 -1
  229. package/dist/{slider-Dexp5Nxu.cjs → slider-DWO4L_qC.cjs} +2 -2
  230. package/dist/{slider-Dexp5Nxu.cjs.map → slider-DWO4L_qC.cjs.map} +1 -1
  231. package/dist/{slider-Cfy-71n8.js → slider-py-bz6Vv.js} +3 -3
  232. package/dist/{slider-Cfy-71n8.js.map → slider-py-bz6Vv.js.map} +1 -1
  233. package/dist/slider.cjs +1 -1
  234. package/dist/slider.js +1 -1
  235. package/dist/{spinner-CFBJounC.js → spinner-DpmMO5_E.js} +2 -2
  236. package/dist/{spinner-CFBJounC.js.map → spinner-DpmMO5_E.js.map} +1 -1
  237. package/dist/{spinner-Cj8PYiDt.cjs → spinner-Dv1WJaIf.cjs} +2 -2
  238. package/dist/{spinner-Cj8PYiDt.cjs.map → spinner-Dv1WJaIf.cjs.map} +1 -1
  239. package/dist/steps.cjs +1 -1
  240. package/dist/steps.js +1 -1
  241. package/dist/{surface-DfnuU19H.cjs → surface-Bn4-n1lT.cjs} +2 -2
  242. package/dist/{surface-DfnuU19H.cjs.map → surface-Bn4-n1lT.cjs.map} +1 -1
  243. package/dist/{surface-CwbyjcPh.js → surface-CFNIITaq.js} +2 -2
  244. package/dist/{surface-CwbyjcPh.js.map → surface-CFNIITaq.js.map} +1 -1
  245. package/dist/surface.cjs +1 -1
  246. package/dist/surface.js +1 -1
  247. package/dist/{table-Bs4s_UXJ.cjs → table-A_oEWQzm.cjs} +2 -2
  248. package/dist/{table-Bs4s_UXJ.cjs.map → table-A_oEWQzm.cjs.map} +1 -1
  249. package/dist/{table-DKcZiidt.js → table-DNUpAcQk.js} +2 -2
  250. package/dist/{table-DKcZiidt.js.map → table-DNUpAcQk.js.map} +1 -1
  251. package/dist/table.cjs +1 -1
  252. package/dist/table.js +1 -1
  253. package/dist/{tabs-compatibility-CGLNEqTc.js → tabs-compatibility-Bxoz71f7.js} +2 -2
  254. package/dist/{tabs-compatibility-CGLNEqTc.js.map → tabs-compatibility-Bxoz71f7.js.map} +1 -1
  255. package/dist/{tabs-compatibility-BNmTv9gA.cjs → tabs-compatibility-DNVqDoQh.cjs} +2 -2
  256. package/dist/{tabs-compatibility-BNmTv9gA.cjs.map → tabs-compatibility-DNVqDoQh.cjs.map} +1 -1
  257. package/dist/tabs.cjs +1 -1
  258. package/dist/tabs.js +1 -1
  259. package/dist/tailwind.mixin-BU9fMdfc.cjs +2 -0
  260. package/dist/{tailwind.mixin-8-I14rPu.cjs.map → tailwind.mixin-BU9fMdfc.cjs.map} +1 -1
  261. package/dist/tailwind.mixin-Bpgmqass.js +43 -0
  262. package/dist/{tailwind.mixin-Bvelb8bX.js.map → tailwind.mixin-Bpgmqass.js.map} +1 -1
  263. package/dist/teleport.cjs +1 -1
  264. package/dist/teleport.js +1 -1
  265. package/dist/textarea-BE5TqYmx.js +131 -0
  266. package/dist/textarea-BE5TqYmx.js.map +1 -0
  267. package/dist/textarea-DTlpsJ-V.cjs +44 -0
  268. package/dist/textarea-DTlpsJ-V.cjs.map +1 -0
  269. package/dist/textarea.cjs +1 -1
  270. package/dist/textarea.js +1 -1
  271. package/dist/{theme-button-C0HcsMoz.js → theme-button-BsojGTM7.js} +2 -2
  272. package/dist/{theme-button-C0HcsMoz.js.map → theme-button-BsojGTM7.js.map} +1 -1
  273. package/dist/{theme-button-BVdmrvuO.cjs → theme-button-DG8sPYM-.cjs} +2 -2
  274. package/dist/{theme-button-BVdmrvuO.cjs.map → theme-button-DG8sPYM-.cjs.map} +1 -1
  275. package/dist/theme-button.cjs +1 -1
  276. package/dist/theme-button.js +1 -1
  277. package/dist/theme.cjs +1 -1
  278. package/dist/{theme.component-C5vE2dqN.js → theme.component-BG4oCMuV.js} +4 -4
  279. package/dist/{theme.component-C5vE2dqN.js.map → theme.component-BG4oCMuV.js.map} +1 -1
  280. package/dist/{theme.component-B70iwARu.cjs → theme.component-D7TpDD6q.cjs} +3 -3
  281. package/dist/{theme.component-B70iwARu.cjs.map → theme.component-D7TpDD6q.cjs.map} +1 -1
  282. package/dist/theme.js +1 -1
  283. package/dist/{timezone-B-nHxpsM.js → timezone-DtsS7reI.js} +3 -3
  284. package/dist/{timezone-B-nHxpsM.js.map → timezone-DtsS7reI.js.map} +1 -1
  285. package/dist/{timezone-C9aeURj9.cjs → timezone-dc6VVlU0.cjs} +2 -2
  286. package/dist/{timezone-C9aeURj9.cjs.map → timezone-dc6VVlU0.cjs.map} +1 -1
  287. package/dist/{tooltip-DGcANl1x.js → tooltip-C5C8KN_9.js} +2 -2
  288. package/dist/{tooltip-DGcANl1x.js.map → tooltip-C5C8KN_9.js.map} +1 -1
  289. package/dist/{tooltip-DLT2gEm_.cjs → tooltip-CA2yHZN6.cjs} +2 -2
  290. package/dist/{tooltip-DLT2gEm_.cjs.map → tooltip-CA2yHZN6.cjs.map} +1 -1
  291. package/dist/tooltip.cjs +1 -1
  292. package/dist/tooltip.js +1 -1
  293. package/dist/{tree-OqQirABn.cjs → tree-D7CAcAHa.cjs} +2 -2
  294. package/dist/{tree-OqQirABn.cjs.map → tree-D7CAcAHa.cjs.map} +1 -1
  295. package/dist/{tree-Bp3kM_9E.js → tree-jBMmDqPl.js} +2 -2
  296. package/dist/{tree-Bp3kM_9E.js.map → tree-jBMmDqPl.js.map} +1 -1
  297. package/dist/tree.cjs +1 -1
  298. package/dist/tree.js +1 -1
  299. package/dist/{typewriter-BxVFLdsv.cjs → typewriter-BMfjokvJ.cjs} +2 -2
  300. package/dist/{typewriter-BxVFLdsv.cjs.map → typewriter-BMfjokvJ.cjs.map} +1 -1
  301. package/dist/{typewriter-vjeXbFlZ.js → typewriter-DDgmwo1Z.js} +7 -7
  302. package/dist/{typewriter-vjeXbFlZ.js.map → typewriter-DDgmwo1Z.js.map} +1 -1
  303. package/dist/typewriter.cjs +1 -1
  304. package/dist/typewriter.js +1 -1
  305. package/dist/{typography-Deoe8ty2.cjs → typography-CeAzj0Al.cjs} +2 -2
  306. package/dist/{typography-Deoe8ty2.cjs.map → typography-CeAzj0Al.cjs.map} +1 -1
  307. package/dist/{typography-DvwRgRtf.js → typography-D0JH1nwp.js} +2 -2
  308. package/dist/{typography-DvwRgRtf.js.map → typography-D0JH1nwp.js.map} +1 -1
  309. package/dist/typography.cjs +1 -1
  310. package/dist/typography.js +1 -1
  311. package/package.json +1 -1
  312. package/types/src/index.d.ts +1 -0
  313. package/types/src/mailbox/email-editor.d.ts +103 -0
  314. package/types/src/mailbox/email-layout-selector.d.ts +19 -0
  315. package/types/src/mailbox/email-recipients.d.ts +118 -0
  316. package/types/src/mailbox/email-viewer.d.ts +86 -0
  317. package/types/src/mailbox/index.d.ts +12 -0
  318. package/types/src/mailbox/mailbox.d.ts +82 -0
  319. package/types/src/mailbox/types.d.ts +174 -0
  320. package/types/src/textarea/textarea.d.ts +24 -0
  321. package/dist/dialog-service-C8W7JHTQ.cjs +0 -2
  322. package/dist/dialog-service-C8W7JHTQ.cjs.map +0 -1
  323. package/dist/dialog-service-CQ6UYq9I.js +0 -135
  324. package/dist/dialog-service-CQ6UYq9I.js.map +0 -1
  325. package/dist/tailwind.mixin-8-I14rPu.cjs +0 -2
  326. package/dist/tailwind.mixin-Bvelb8bX.js +0 -43
  327. package/dist/textarea-Cdl89jnK.cjs +0 -42
  328. package/dist/textarea-Cdl89jnK.cjs.map +0 -1
  329. package/dist/textarea-DU0mANOS.js +0 -126
  330. package/dist/textarea-DU0mANOS.js.map +0 -1
package/ai/textarea.md CHANGED
@@ -14,58 +14,85 @@
14
14
  required?
15
15
  disabled?
16
16
  readonly?
17
- error="Error message"
18
- resize="both|horizontal|vertical|none"
19
- @input=${handleInput}
20
- @change=${handleChange}>
17
+ spellcheck?
18
+ align="left|center|right"
19
+ hint="Helper text"
20
+ error?
21
+ fillHeight?
22
+ autoHeight?
23
+ resize="none|vertical|horizontal|both"
24
+ @change=${handleChange}
25
+ @enter=${handleEnter}>
21
26
  </schmancy-textarea>
22
27
 
23
- // Textarea with counter and helper text
28
+ // Textarea with fill height (fills container)
24
29
  <schmancy-textarea
25
30
  label="Description"
26
- maxlength="200"
27
- show-counter?
28
- helper-text="Briefly describe your issue">
31
+ fillHeight
32
+ placeholder="This fills the container height...">
29
33
  </schmancy-textarea>
30
34
 
31
35
  // Auto-growing textarea
32
36
  <schmancy-textarea
33
- auto-grow?
34
- min-rows="2"
35
- max-rows="10"
36
- label="Comments">
37
+ autoHeight
38
+ label="Comments"
39
+ placeholder="This grows with content...">
40
+ </schmancy-textarea>
41
+
42
+ // User-resizable textarea
43
+ <schmancy-textarea
44
+ resize="vertical"
45
+ rows="6"
46
+ label="Notes"
47
+ placeholder="Drag the corner to resize...">
48
+ </schmancy-textarea>
49
+
50
+ // Combined features
51
+ <schmancy-textarea
52
+ fillHeight
53
+ autoHeight
54
+ resize="both"
55
+ label="Full Featured"
56
+ placeholder="Fills container, auto-grows, and user resizable...">
37
57
  </schmancy-textarea>
38
58
 
39
59
  // Textarea Methods
40
- textarea.focus() -> void // Focus the textarea
41
- textarea.blur() -> void // Remove focus
42
- textarea.select() -> void // Select all text
43
- textarea.validate() -> boolean // Validate and show error if invalid
44
- textarea.reset() -> void // Reset to initial value
45
- textarea.setCustomValidity(message) -> void // Set custom validation message
60
+ textarea.focus(options?) -> void // Focus the textarea
61
+ textarea.blur() -> void // Remove focus
62
+ textarea.select() -> void // Select all text
63
+ textarea.checkValidity() -> boolean // Check validity
64
+ textarea.reportValidity() -> boolean // Validate and show browser message if invalid
65
+ textarea.setCustomValidity(message) -> void // Set custom validation message
66
+ textarea.adjustHeight() -> void // Manually adjust height (for autoHeight)
67
+ textarea.setSelectionRange(start, end, direction?) -> void // Set text selection
68
+ textarea.setRangeText(replacement) -> void // Replace selected text
46
69
 
47
70
  // Textarea Properties
48
71
  value: string // The content of the textarea
49
72
  name: string // The name attribute
50
73
  label: string // Label text
51
74
  placeholder: string // Placeholder text
52
- rows: number // Number of rows to display
53
- cols: number // Number of columns to display
75
+ rows: number = 2 // Number of rows to display
76
+ cols: number = 20 // Number of columns to display
54
77
  minlength: number // Minimum number of characters required
55
78
  maxlength: number // Maximum number of characters allowed
56
79
  disabled: boolean // Whether the textarea is disabled
57
80
  readonly: boolean // Whether the textarea is read-only
58
81
  required: boolean // Whether the textarea is required
59
- error: string // Error message to display
60
- resize: string // Resize behavior: "both", "horizontal", "vertical", "none"
61
- autoGrow: boolean // Whether the textarea should automatically grow with content
62
- minRows: number // Minimum number of rows when auto-growing
63
- maxRows: number // Maximum number of rows when auto-growing
64
- showCounter: boolean // Whether to show the character counter
82
+ spellcheck: boolean // Whether spellcheck is enabled
83
+ align: 'left'|'center'|'right' = 'left' // Text alignment
84
+ hint: string // Helper text below the textarea
85
+ error: boolean // Error state
86
+ fillHeight: boolean = false // Fill container height
87
+ autoHeight: boolean = false // Auto-adjust height based on content
88
+ resize: 'none'|'vertical'|'horizontal'|'both' = 'none' // Resize behavior
89
+ wrap: 'hard'|'soft' = 'soft' // Text wrapping behavior
90
+ dirname: string // Direction attribute name
91
+ autofocus: boolean // Auto focus on page load
65
92
 
66
93
  // Textarea Events
67
- @input // Fires on input with { detail: { value } }
68
- @change // Fires when value changes and focus is lost with { detail: { value } }
94
+ @change // Fires when value changes with { detail: { value } }
95
+ @enter // Fires when enter key is pressed with { detail: { value } }
69
96
  @focus // Fires when textarea gains focus
70
97
  @blur // Fires when textarea loses focus
71
98
 
@@ -80,25 +107,53 @@ showCounter: boolean // Whether to show the character counter
80
107
  @change=${(e) => console.log('Comments:', e.detail.value)}>
81
108
  </schmancy-textarea>
82
109
 
83
- // Textarea with character counter
110
+ // Textarea with hint and error state
84
111
  <schmancy-textarea
85
112
  name="bio"
86
113
  label="Biography"
87
114
  maxlength="500"
88
- show-counter
89
- helper-text="Tell us about yourself">
115
+ hint="Tell us about yourself (max 500 chars)"
116
+ error=${bio.length > 500}
117
+ @change=${(e) => bio = e.detail.value}>
90
118
  </schmancy-textarea>
91
119
 
120
+ // Fill container height
121
+ <div style="height: 300px; display: flex; flex-direction: column;">
122
+ <schmancy-textarea
123
+ fillHeight
124
+ label="Full Height Textarea"
125
+ placeholder="This fills the container...">
126
+ </schmancy-textarea>
127
+ </div>
128
+
92
129
  // Auto-growing textarea
93
130
  <schmancy-textarea
94
131
  name="notes"
95
132
  label="Meeting Notes"
96
- auto-grow
97
- min-rows="3"
98
- max-rows="15"
99
- placeholder="Type your notes here...">
133
+ autoHeight
134
+ placeholder="Type your notes here, field grows automatically...">
135
+ </schmancy-textarea>
136
+
137
+ // User resizable textarea
138
+ <schmancy-textarea
139
+ name="description"
140
+ label="Description"
141
+ resize="vertical"
142
+ rows="5"
143
+ placeholder="You can drag the corner to resize this...">
100
144
  </schmancy-textarea>
101
145
 
146
+ // Combined features
147
+ <div style="height: 400px; display: flex; flex-direction: column;">
148
+ <schmancy-textarea
149
+ fillHeight
150
+ autoHeight
151
+ resize="both"
152
+ label="Advanced Textarea"
153
+ placeholder="Fills height, auto-grows, and is resizable...">
154
+ </schmancy-textarea>
155
+ </div>
156
+
102
157
  // Usage in a form
103
158
  <schmancy-form @submit=${handleSubmit}>
104
159
  <schmancy-input
@@ -111,19 +166,31 @@ showCounter: boolean // Whether to show the character counter
111
166
  name="description"
112
167
  label="Description"
113
168
  rows="5"
114
- required>
169
+ required
170
+ hint="Provide a detailed description">
115
171
  </schmancy-textarea>
116
172
 
117
173
  <schmancy-button type="submit">Submit</schmancy-button>
118
174
  </schmancy-form>
119
175
 
120
- // Textarea with error state
176
+ // Textarea with enter key handling
177
+ <schmancy-textarea
178
+ name="message"
179
+ label="Chat Message"
180
+ placeholder="Type message and press Enter to send..."
181
+ @enter=${(e) => {
182
+ sendMessage(e.detail.value);
183
+ e.target.value = '';
184
+ }}>
185
+ </schmancy-textarea>
186
+
187
+ // Centered text alignment
121
188
  <schmancy-textarea
122
- name="feedback"
123
- label="Feedback"
124
- value=${feedback}
125
- error=${feedback.length < 10 ? 'Feedback must be at least 10 characters' : ''}
126
- @input=${(e) => feedback = e.detail.value}>
189
+ name="poem"
190
+ label="Poetry"
191
+ align="center"
192
+ rows="8"
193
+ placeholder="Write your poem here...">
127
194
  </schmancy-textarea>
128
195
 
129
196
  // Textarea with prefilled markdown template
@@ -142,6 +209,24 @@ showCounter: boolean // Whether to show the character counter
142
209
  ## Expected Behavior
143
210
 
144
211
  "
145
- rows="12">
212
+ rows="12"
213
+ autoHeight>
214
+ </schmancy-textarea>
215
+
216
+ // Readonly textarea for displaying content
217
+ <schmancy-textarea
218
+ label="Terms and Conditions"
219
+ value="Lorem ipsum dolor sit amet..."
220
+ readonly
221
+ rows="10">
222
+ </schmancy-textarea>
223
+
224
+ // Textarea with spellcheck disabled
225
+ <schmancy-textarea
226
+ name="code"
227
+ label="Code Snippet"
228
+ placeholder="Paste your code here..."
229
+ spellcheck=${false}
230
+ rows="8">
146
231
  </schmancy-textarea>
147
232
  ```
@@ -14,58 +14,85 @@
14
14
  required?
15
15
  disabled?
16
16
  readonly?
17
- error="Error message"
18
- resize="both|horizontal|vertical|none"
19
- @input=${handleInput}
20
- @change=${handleChange}>
17
+ spellcheck?
18
+ align="left|center|right"
19
+ hint="Helper text"
20
+ error?
21
+ fillHeight?
22
+ autoHeight?
23
+ resize="none|vertical|horizontal|both"
24
+ @change=${handleChange}
25
+ @enter=${handleEnter}>
21
26
  </schmancy-textarea>
22
27
 
23
- // Textarea with counter and helper text
28
+ // Textarea with fill height (fills container)
24
29
  <schmancy-textarea
25
30
  label="Description"
26
- maxlength="200"
27
- show-counter?
28
- helper-text="Briefly describe your issue">
31
+ fillHeight
32
+ placeholder="This fills the container height...">
29
33
  </schmancy-textarea>
30
34
 
31
35
  // Auto-growing textarea
32
36
  <schmancy-textarea
33
- auto-grow?
34
- min-rows="2"
35
- max-rows="10"
36
- label="Comments">
37
+ autoHeight
38
+ label="Comments"
39
+ placeholder="This grows with content...">
40
+ </schmancy-textarea>
41
+
42
+ // User-resizable textarea
43
+ <schmancy-textarea
44
+ resize="vertical"
45
+ rows="6"
46
+ label="Notes"
47
+ placeholder="Drag the corner to resize...">
48
+ </schmancy-textarea>
49
+
50
+ // Combined features
51
+ <schmancy-textarea
52
+ fillHeight
53
+ autoHeight
54
+ resize="both"
55
+ label="Full Featured"
56
+ placeholder="Fills container, auto-grows, and user resizable...">
37
57
  </schmancy-textarea>
38
58
 
39
59
  // Textarea Methods
40
- textarea.focus() -> void // Focus the textarea
41
- textarea.blur() -> void // Remove focus
42
- textarea.select() -> void // Select all text
43
- textarea.validate() -> boolean // Validate and show error if invalid
44
- textarea.reset() -> void // Reset to initial value
45
- textarea.setCustomValidity(message) -> void // Set custom validation message
60
+ textarea.focus(options?) -> void // Focus the textarea
61
+ textarea.blur() -> void // Remove focus
62
+ textarea.select() -> void // Select all text
63
+ textarea.checkValidity() -> boolean // Check validity
64
+ textarea.reportValidity() -> boolean // Validate and show browser message if invalid
65
+ textarea.setCustomValidity(message) -> void // Set custom validation message
66
+ textarea.adjustHeight() -> void // Manually adjust height (for autoHeight)
67
+ textarea.setSelectionRange(start, end, direction?) -> void // Set text selection
68
+ textarea.setRangeText(replacement) -> void // Replace selected text
46
69
 
47
70
  // Textarea Properties
48
71
  value: string // The content of the textarea
49
72
  name: string // The name attribute
50
73
  label: string // Label text
51
74
  placeholder: string // Placeholder text
52
- rows: number // Number of rows to display
53
- cols: number // Number of columns to display
75
+ rows: number = 2 // Number of rows to display
76
+ cols: number = 20 // Number of columns to display
54
77
  minlength: number // Minimum number of characters required
55
78
  maxlength: number // Maximum number of characters allowed
56
79
  disabled: boolean // Whether the textarea is disabled
57
80
  readonly: boolean // Whether the textarea is read-only
58
81
  required: boolean // Whether the textarea is required
59
- error: string // Error message to display
60
- resize: string // Resize behavior: "both", "horizontal", "vertical", "none"
61
- autoGrow: boolean // Whether the textarea should automatically grow with content
62
- minRows: number // Minimum number of rows when auto-growing
63
- maxRows: number // Maximum number of rows when auto-growing
64
- showCounter: boolean // Whether to show the character counter
82
+ spellcheck: boolean // Whether spellcheck is enabled
83
+ align: 'left'|'center'|'right' = 'left' // Text alignment
84
+ hint: string // Helper text below the textarea
85
+ error: boolean // Error state
86
+ fillHeight: boolean = false // Fill container height
87
+ autoHeight: boolean = false // Auto-adjust height based on content
88
+ resize: 'none'|'vertical'|'horizontal'|'both' = 'none' // Resize behavior
89
+ wrap: 'hard'|'soft' = 'soft' // Text wrapping behavior
90
+ dirname: string // Direction attribute name
91
+ autofocus: boolean // Auto focus on page load
65
92
 
66
93
  // Textarea Events
67
- @input // Fires on input with { detail: { value } }
68
- @change // Fires when value changes and focus is lost with { detail: { value } }
94
+ @change // Fires when value changes with { detail: { value } }
95
+ @enter // Fires when enter key is pressed with { detail: { value } }
69
96
  @focus // Fires when textarea gains focus
70
97
  @blur // Fires when textarea loses focus
71
98
 
@@ -80,25 +107,53 @@ showCounter: boolean // Whether to show the character counter
80
107
  @change=${(e) => console.log('Comments:', e.detail.value)}>
81
108
  </schmancy-textarea>
82
109
 
83
- // Textarea with character counter
110
+ // Textarea with hint and error state
84
111
  <schmancy-textarea
85
112
  name="bio"
86
113
  label="Biography"
87
114
  maxlength="500"
88
- show-counter
89
- helper-text="Tell us about yourself">
115
+ hint="Tell us about yourself (max 500 chars)"
116
+ error=${bio.length > 500}
117
+ @change=${(e) => bio = e.detail.value}>
90
118
  </schmancy-textarea>
91
119
 
120
+ // Fill container height
121
+ <div style="height: 300px; display: flex; flex-direction: column;">
122
+ <schmancy-textarea
123
+ fillHeight
124
+ label="Full Height Textarea"
125
+ placeholder="This fills the container...">
126
+ </schmancy-textarea>
127
+ </div>
128
+
92
129
  // Auto-growing textarea
93
130
  <schmancy-textarea
94
131
  name="notes"
95
132
  label="Meeting Notes"
96
- auto-grow
97
- min-rows="3"
98
- max-rows="15"
99
- placeholder="Type your notes here...">
133
+ autoHeight
134
+ placeholder="Type your notes here, field grows automatically...">
135
+ </schmancy-textarea>
136
+
137
+ // User resizable textarea
138
+ <schmancy-textarea
139
+ name="description"
140
+ label="Description"
141
+ resize="vertical"
142
+ rows="5"
143
+ placeholder="You can drag the corner to resize this...">
100
144
  </schmancy-textarea>
101
145
 
146
+ // Combined features
147
+ <div style="height: 400px; display: flex; flex-direction: column;">
148
+ <schmancy-textarea
149
+ fillHeight
150
+ autoHeight
151
+ resize="both"
152
+ label="Advanced Textarea"
153
+ placeholder="Fills height, auto-grows, and is resizable...">
154
+ </schmancy-textarea>
155
+ </div>
156
+
102
157
  // Usage in a form
103
158
  <schmancy-form @submit=${handleSubmit}>
104
159
  <schmancy-input
@@ -111,19 +166,31 @@ showCounter: boolean // Whether to show the character counter
111
166
  name="description"
112
167
  label="Description"
113
168
  rows="5"
114
- required>
169
+ required
170
+ hint="Provide a detailed description">
115
171
  </schmancy-textarea>
116
172
 
117
173
  <schmancy-button type="submit">Submit</schmancy-button>
118
174
  </schmancy-form>
119
175
 
120
- // Textarea with error state
176
+ // Textarea with enter key handling
177
+ <schmancy-textarea
178
+ name="message"
179
+ label="Chat Message"
180
+ placeholder="Type message and press Enter to send..."
181
+ @enter=${(e) => {
182
+ sendMessage(e.detail.value);
183
+ e.target.value = '';
184
+ }}>
185
+ </schmancy-textarea>
186
+
187
+ // Centered text alignment
121
188
  <schmancy-textarea
122
- name="feedback"
123
- label="Feedback"
124
- value=${feedback}
125
- error=${feedback.length < 10 ? 'Feedback must be at least 10 characters' : ''}
126
- @input=${(e) => feedback = e.detail.value}>
189
+ name="poem"
190
+ label="Poetry"
191
+ align="center"
192
+ rows="8"
193
+ placeholder="Write your poem here...">
127
194
  </schmancy-textarea>
128
195
 
129
196
  // Textarea with prefilled markdown template
@@ -142,6 +209,24 @@ showCounter: boolean // Whether to show the character counter
142
209
  ## Expected Behavior
143
210
 
144
211
  "
145
- rows="12">
212
+ rows="12"
213
+ autoHeight>
214
+ </schmancy-textarea>
215
+
216
+ // Readonly textarea for displaying content
217
+ <schmancy-textarea
218
+ label="Terms and Conditions"
219
+ value="Lorem ipsum dolor sit amet..."
220
+ readonly
221
+ rows="10">
222
+ </schmancy-textarea>
223
+
224
+ // Textarea with spellcheck disabled
225
+ <schmancy-textarea
226
+ name="code"
227
+ label="Code Snippet"
228
+ placeholder="Paste your code here..."
229
+ spellcheck=${false}
230
+ rows="8">
146
231
  </schmancy-textarea>
147
232
  ```
@@ -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-PLxdthiY.cjs");require("./tailwind.mixin-8-I14rPu.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-CbFQ2uxn.cjs");require("./tailwind.mixin-BU9fMdfc.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-Bgciqenw.cjs.map
37
+ //# sourceMappingURL=animated-text-Bm1G50ol.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-Bgciqenw.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
+ {"version":3,"file":"animated-text-Bm1G50ol.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,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-C7_rhUMZ.js";
5
- import "./tailwind.mixin-Bvelb8bX.js";
4
+ import { $ as x } from "./litElement.mixin-BYVS1wwl.js";
5
+ import "./tailwind.mixin-Bpgmqass.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-BnE_bSQh.js.map
75
+ //# sourceMappingURL=animated-text-DhaihRNU.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"animated-text-BnE_bSQh.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
+ {"version":3,"file":"animated-text-DhaihRNU.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":";;;;;;;;;;;AAsBA,IAAqBA,IAArB,cAAkDC,EAAYC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;EAA9D,cAAAC;AAAAC,UAAAA,GAAAC,SAAAA,GAoB6BC,KAAAC,OAAO,WACPD,KAAAE,QAAQ,GACRF,KAAAG,UAAU,IACVH,KAAAI,WAAW,KACZJ,KAAAK,QAAQ,CAAC,GAAG,CAAA,GACZL,KAAAM,UAAU,CAAC,GAAG,CAAA,GACdN,KAAAO,aAAa,CAAC,UAAU,QACxBP,KAAAQ,aAAa,CAAC,SAAS,KAAA,GACvBR,KAAAS,aAAa,CAAC,GAAG,CAAA,GACjBT,KAAAU,UAAU,CAAC,KAAK,CAAA,GACdV,KAAAW,gBAAAA;AAAAA,EAAgB;AAAA,EAO7C,aAAaC,GAAAA;AACZ,UAAMC,IAAOD,EAAQE,sBAAAA;AACrB,WACCD,EAAKE,OAAO,KACZF,EAAKG,QAAQ,KACbH,EAAKI,WAAWC,OAAOC,eAAeC,SAASC,gBAAgBC,iBAC/DT,EAAKU,UAAUL,OAAOM,cAAcJ,SAASC,gBAAgBI;AAAAA,EAE/D;AAAA,EAEA,MAAA,eAAMC;AAEL1B,SAAK2B,QAAQC,YAAY5B,KAAK6B,YAAY,CAAA,EAAGC,YAAaC,QAAQ,OAAO,gCAAA,GAGzEC,EAECC,EAAS,EAAA,EAAIC,KACZC,EAAAA,EAAU,GACVC,EAAO,MAAA;AACN,YAAMvB,IAAOb,KAAKc,sBAAAA;AAClB,aAAOD,EAAKwB,QAAQ,KAAKxB,EAAKyB,SAAS;AAAA,IAAA,CAAA,GAExCC,EAAK,CAAA,CAAA,GAGNC,EAAUtB,QAAQ,QAAA,EAAUgB,KAC3BO,EAAa,GAAA,QAAc,EAC1BC,SAAAA,IACAC,UAAAA,GAAU,CAAA,GAEXR,IAAU,GACVS,EAAI,MAAM5C,KAAK6C,aAAa7C,IAAAA,CAAAA,GAC5B8C,EAAAA,GACAC,EAAIC,CAAAA,MAAAA;AAAAA,OAEEA,KAAchD,KAAKW,iBACvBsC,MAAMC,KAAKlD,KAAK2B,QAAQwB,QAAAA,EAAUC,QAASC,CAAAA,MAAAA;AAC1CA,QAAAA,EAAOC,MAAMhD,UAAU;AAAA,MAAA,CAAA;AAAA,IAAA,CAAA,GAI1B8B,SAAuBS,CAAAA,GAEvB7C,KAAKW,gBAAgBoC,EAAAA,IAAQR,EAAK,CAAA,GAClCQ,EAAI,EACHQ,MAAM,MAAA;AAEWvD,WAAKwD,WAAYC,iBAA8B,cAAA,EAEvDL,QAAQ,CAACC,GAAQK,MAAAA;AAGxB,cAAMC,IAAgB;AAAA,8BACC3D,KAAKO,WAAW,CAAA,CAAA,KAAOP,KAAKQ,WAAW,CAAA,CAAA,KAAOR,KAAKS,WAAW,CAAA,CAAA;AAAA,0BAClET,KAAKU,QAAQ,CAAA,CAAA;AAAA,wBACfV,KAAKK,MAAM,CAAA,CAAA;AAAA,iBAGtBuD,IAAc;AAAA,8BACG5D,KAAKO,WAAW,CAAA,CAAA,KAAOP,KAAKQ,WAAW,CAAA,CAAA,KAAOR,KAAKS,WAAW,CAAA,CAAA;AAAA,0BAClET,KAAKU,QAAQ,CAAA,CAAA;AAAA,wBACfV,KAAKK,MAAM,CAAA,CAAA;AAAA,iBAQtBwD,IAAwB,CAC7B,EAAEC,WAAWH,GAAerD,SAASyD,OAAO/D,KAAKM,QAAQ,CAAA,CAAA,EAAA,GACzD,EAAEwD,WAAWF,GAAatD,SAASyD,OAAO/D,KAAKM,QAAQ,CAAA,CAAA,EAAA,CAAA;AAGxD+C,QAAAA,EAAOW,QAAQH,GAAW,EACzBzD,UAAUJ,KAAKI,UACf6D,QAXyC,EACzCC,SAAS,iCAAA,EAUSlE,KAAKC,IAAAA,KAAS,YAChCC,OAAOF,KAAKE,QAAQwD,IAAI1D,KAAKG,SAC7BgE,MAAM,WAAA,CAAA;AAAA,MAAA,CAAA;AAAA,IAAA,EAAA,CAAA,CAAA,CAAA,EAMVC,UAAAA;AAAAA,EACH;AAAA,EAEA,SAAAC;AACC,WAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,EASR;AAAA;AAnH4BC,EAAA,CAA3BC,EAAS,EAAEC,MAAMV,OAAAA,CAAAA,CAAAA,GApBErE,EAoBQgF,WAAA,QAAA,CAAA,GACAH,EAAA,CAA3BC,EAAS,EAAEC,MAAME,OAAAA,CAAAA,CAAAA,GArBEjF,EAqBQgF,WAAA,SAAA,CAAA,GACAH,EAAA,CAA3BC,EAAS,EAAEC,MAAME,OAAAA,CAAAA,CAAAA,GAtBEjF,EAsBQgF,WAAA,WAAA,CAAA,GACAH,EAAA,CAA3BC,EAAS,EAAEC,MAAME,OAAAA,CAAAA,CAAAA,GAvBEjF,EAuBQgF,WAAA,YAAA,CAAA,GACDH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,MAAAA,CAAAA,CAAAA,GAxBEvD,EAwBOgF,WAAA,SAAA,CAAA,GACAH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,MAAAA,CAAAA,CAAAA,GAzBEvD,EAyBOgF,WAAA,WAAA,CAAA,GACAH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,WA1BEvD,EA0BOgF,WAAA,cAAA,CAAA,GACAH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,MAAAA,CAAAA,CAAAA,GA3BEvD,EA2BOgF,WAAA,cAAA,CAAA,GACAH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,MAAAA,CAAAA,CAAAA,GA5BEvD,EA4BOgF,WAAA,cAAA,CAAA,GACAH,EAAA,CAA1BC,EAAS,EAAEC,MAAMxB,MAAAA,CAAAA,CAAAA,GA7BEvD,EA6BOgF,WAAA,WAAA,CAAA,GACEH,EAAA,CAA5BC,EAAS,EAAEC,MAAMG,QAAAA,CAAAA,CAAAA,GA9BElF,EA8BSgF,WAAA,iBAAA,IAEPH,EAAA,CAArBM,EAAAA,CAAAA,GAhCmBnF,EAgCEgF,WAAA,eAAA,CAAA,GACHH,EAAA,CAAlBO,EAAM,UAAA,CAAA,GAjCapF,EAiCDgF,WAAA,WAAA,CAAA,GACJH,EAAA,CAAdO,EAAM,MAAA,CAAA,GAlCapF,EAkCLgF,WAAA,OAAA,CAAA,GAlCKhF,IAArB6E,EAAA,CADCQ,EAAc,wBAAA,CAAA,GACMrF,CAAAA;"}
@@ -1,2 +1,2 @@
1
- "use strict";require("./animated-text-Bgciqenw.cjs");
1
+ "use strict";require("./animated-text-Bm1G50ol.cjs");
2
2
  //# sourceMappingURL=animated-text.cjs.map
@@ -1,2 +1,2 @@
1
- import "./animated-text-BnE_bSQh.js";
1
+ import "./animated-text-DhaihRNU.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-jRAVAvAI.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;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./area.component-e7ccHmOi.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