@mhmo91/schmancy 0.2.38 → 0.2.40

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 (250) hide show
  1. package/dist/{animated-text-Daeoe5sn.cjs → animated-text-CaUJr-yL.cjs} +2 -2
  2. package/dist/{animated-text-Daeoe5sn.cjs.map → animated-text-CaUJr-yL.cjs.map} +1 -1
  3. package/dist/{animated-text-BVwxMOPR.js → animated-text-D8LhwMLu.js} +3 -3
  4. package/dist/{animated-text-BVwxMOPR.js.map → animated-text-D8LhwMLu.js.map} +1 -1
  5. package/dist/animated-text.cjs +1 -1
  6. package/dist/animated-text.js +1 -1
  7. package/dist/area.cjs +1 -1
  8. package/dist/{area.component-xmbcsTJK.cjs → area.component-DJYgP8NP.cjs} +2 -2
  9. package/dist/{area.component-xmbcsTJK.cjs.map → area.component-DJYgP8NP.cjs.map} +1 -1
  10. package/dist/{area.component-ByLp5c79.js → area.component-FgfXnOUF.js} +3 -3
  11. package/dist/{area.component-ByLp5c79.js.map → area.component-FgfXnOUF.js.map} +1 -1
  12. package/dist/area.js +1 -1
  13. package/dist/autocomplete-C36FPrMT.js +225 -0
  14. package/dist/autocomplete-C36FPrMT.js.map +1 -0
  15. package/dist/autocomplete-CFcZcrJm.cjs +48 -0
  16. package/dist/autocomplete-CFcZcrJm.cjs.map +1 -0
  17. package/dist/autocomplete.cjs +1 -1
  18. package/dist/autocomplete.js +1 -1
  19. package/dist/busy.cjs +1 -1
  20. package/dist/busy.js +1 -1
  21. package/dist/button.cjs +1 -1
  22. package/dist/button.js +1 -1
  23. package/dist/card.cjs +1 -1
  24. package/dist/card.js +1 -1
  25. package/dist/{checkbox-D9vaaSjw.cjs → checkbox-Drf8MwrJ.cjs} +2 -2
  26. package/dist/{checkbox-D9vaaSjw.cjs.map → checkbox-Drf8MwrJ.cjs.map} +1 -1
  27. package/dist/{checkbox-DkJYbF64.js → checkbox-Sf2HtMs9.js} +2 -2
  28. package/dist/{checkbox-DkJYbF64.js.map → checkbox-Sf2HtMs9.js.map} +1 -1
  29. package/dist/checkbox.cjs +1 -1
  30. package/dist/checkbox.js +1 -1
  31. package/dist/{chips-UBgldDF5.cjs → chips-8SMj1Siq.cjs} +12 -12
  32. package/dist/{chips-UBgldDF5.cjs.map → chips-8SMj1Siq.cjs.map} +1 -1
  33. package/dist/{chips-Cy9spfrp.js → chips-CA-B5JGD.js} +36 -36
  34. package/dist/{chips-Cy9spfrp.js.map → chips-CA-B5JGD.js.map} +1 -1
  35. package/dist/chips.cjs +1 -1
  36. package/dist/chips.js +1 -1
  37. package/dist/components.cjs +1 -1
  38. package/dist/components.js +1 -1
  39. package/dist/content-drawer.cjs +1 -1
  40. package/dist/content-drawer.js +1 -1
  41. package/dist/date-range-BFW0xGWz.js +148 -0
  42. package/dist/date-range-BFW0xGWz.js.map +1 -0
  43. package/dist/date-range-CAFOX_Sm.cjs +72 -0
  44. package/dist/date-range-CAFOX_Sm.cjs.map +1 -0
  45. package/dist/date-range.cjs +1 -1
  46. package/dist/date-range.js +1 -1
  47. package/dist/{delay-CpK5RGux.js → delay-DbaKftdS.js} +2 -2
  48. package/dist/{delay-CpK5RGux.js.map → delay-DbaKftdS.js.map} +1 -1
  49. package/dist/{delay-C0n9lJNW.cjs → delay-_LA9VzS1.cjs} +2 -2
  50. package/dist/{delay-C0n9lJNW.cjs.map → delay-_LA9VzS1.cjs.map} +1 -1
  51. package/dist/delay.cjs +1 -1
  52. package/dist/delay.js +1 -1
  53. package/dist/{divider-D85c35Sw.js → divider-Ba1jSOh5.js} +3 -3
  54. package/dist/{divider-D85c35Sw.js.map → divider-Ba1jSOh5.js.map} +1 -1
  55. package/dist/{divider-C4xBD1JH.cjs → divider-DUvuIyeA.cjs} +2 -2
  56. package/dist/{divider-C4xBD1JH.cjs.map → divider-DUvuIyeA.cjs.map} +1 -1
  57. package/dist/divider.cjs +1 -1
  58. package/dist/divider.js +1 -1
  59. package/dist/{form-B_0fvoO0.cjs → form-Dga1_eim.cjs} +2 -2
  60. package/dist/{form-B_0fvoO0.cjs.map → form-Dga1_eim.cjs.map} +1 -1
  61. package/dist/{form-Bau_XA_e.js → form-H0pfjyGl.js} +2 -2
  62. package/dist/{form-Bau_XA_e.js.map → form-H0pfjyGl.js.map} +1 -1
  63. package/dist/form.cjs +1 -1
  64. package/dist/form.js +1 -1
  65. package/dist/{icon-Bit7fi8d.cjs → icon-Dr1MeHJo.cjs} +2 -2
  66. package/dist/{icon-Bit7fi8d.cjs.map → icon-Dr1MeHJo.cjs.map} +1 -1
  67. package/dist/{icon-button-Dh6iR7gO.cjs → icon-button-B1Hzc1qy.cjs} +2 -2
  68. package/dist/{icon-button-Dh6iR7gO.cjs.map → icon-button-B1Hzc1qy.cjs.map} +1 -1
  69. package/dist/{icon-button-CEGE-KQJ.js → icon-button-BFdAiGNP.js} +3 -3
  70. package/dist/{icon-button-CEGE-KQJ.js.map → icon-button-BFdAiGNP.js.map} +1 -1
  71. package/dist/{icon-B-QZ23xF.js → icon-pvbFfBbz.js} +3 -3
  72. package/dist/{icon-B-QZ23xF.js.map → icon-pvbFfBbz.js.map} +1 -1
  73. package/dist/icons.cjs +1 -1
  74. package/dist/icons.js +1 -1
  75. package/dist/index.cjs +1 -1
  76. package/dist/index.js +98 -97
  77. package/dist/input-1-LnDYbT.cjs +53 -0
  78. package/dist/input-1-LnDYbT.cjs.map +1 -0
  79. package/dist/input-CBjD2PL8.js +137 -0
  80. package/dist/input-CBjD2PL8.js.map +1 -0
  81. package/dist/input.cjs +1 -1
  82. package/dist/input.js +1 -1
  83. package/dist/layout.cjs +1 -1
  84. package/dist/layout.js +1 -1
  85. package/dist/{list-ClV9Qdme.js → list-BdN19pT0.js} +2 -2
  86. package/dist/{list-ClV9Qdme.js.map → list-BdN19pT0.js.map} +1 -1
  87. package/dist/{list-CRW6i-kf.cjs → list-DSyxyPI_.cjs} +2 -2
  88. package/dist/{list-CRW6i-kf.cjs.map → list-DSyxyPI_.cjs.map} +1 -1
  89. package/dist/list.cjs +1 -1
  90. package/dist/list.js +1 -1
  91. package/dist/{litElement.mixin-d9rhslEw.cjs → litElement.mixin-B9kSOE4x.cjs} +2 -2
  92. package/dist/{litElement.mixin-d9rhslEw.cjs.map → litElement.mixin-B9kSOE4x.cjs.map} +1 -1
  93. package/dist/{litElement.mixin-COSnyAru.js → litElement.mixin-D9kneJpW.js} +2 -2
  94. package/dist/{litElement.mixin-COSnyAru.js.map → litElement.mixin-D9kneJpW.js.map} +1 -1
  95. package/dist/{menu-n_bI-TFp.js → menu-DjWA-lYK.js} +29 -27
  96. package/dist/menu-DjWA-lYK.js.map +1 -0
  97. package/dist/menu-XffIwQSn.cjs +29 -0
  98. package/dist/menu-XffIwQSn.cjs.map +1 -0
  99. package/dist/menu.cjs +1 -1
  100. package/dist/menu.js +1 -1
  101. package/dist/nav-drawer.cjs +1 -1
  102. package/dist/nav-drawer.js +1 -1
  103. package/dist/notification.cjs +1 -1
  104. package/dist/notification.js +1 -1
  105. package/dist/option-C4fWPkxl.js +45 -0
  106. package/dist/option-C4fWPkxl.js.map +1 -0
  107. package/dist/option-Dcuv7dNV.cjs +18 -0
  108. package/dist/option-Dcuv7dNV.cjs.map +1 -0
  109. package/dist/option.cjs +1 -1
  110. package/dist/option.js +1 -1
  111. package/dist/{outlet-hu2yX7iS.cjs → outlet-881x1gpm.cjs} +2 -2
  112. package/dist/{outlet-hu2yX7iS.cjs.map → outlet-881x1gpm.cjs.map} +1 -1
  113. package/dist/{outlet-DuFKgg_g.js → outlet-oc58T2jq.js} +2 -2
  114. package/dist/{outlet-DuFKgg_g.js.map → outlet-oc58T2jq.js.map} +1 -1
  115. package/dist/{payment-card-form-Bpa9jVym.cjs → payment-card-form-BlusjI2Q.cjs} +2 -2
  116. package/dist/{payment-card-form-Bpa9jVym.cjs.map → payment-card-form-BlusjI2Q.cjs.map} +1 -1
  117. package/dist/{payment-card-form-D6chLUG-.js → payment-card-form-D2NiZkJM.js} +3 -3
  118. package/dist/{payment-card-form-D6chLUG-.js.map → payment-card-form-D2NiZkJM.js.map} +1 -1
  119. package/dist/{radio-group-9wWEjibY.js → radio-group-BALwJIFj.js} +2 -2
  120. package/dist/{radio-group-9wWEjibY.js.map → radio-group-BALwJIFj.js.map} +1 -1
  121. package/dist/{radio-group-CekbhNf-.cjs → radio-group-DE6ao3xB.cjs} +2 -2
  122. package/dist/{radio-group-CekbhNf-.cjs.map → radio-group-DE6ao3xB.cjs.map} +1 -1
  123. package/dist/radio-group.cjs +1 -1
  124. package/dist/radio-group.js +1 -1
  125. package/dist/{scroll-B-tqDDOP.js → scroll-BbqxMyDc.js} +29 -29
  126. package/dist/scroll-BbqxMyDc.js.map +1 -0
  127. package/dist/scroll-BqLesKK7.cjs +33 -0
  128. package/dist/scroll-BqLesKK7.cjs.map +1 -0
  129. package/dist/select-CaBI5TrW.js +156 -0
  130. package/dist/select-CaBI5TrW.js.map +1 -0
  131. package/dist/select-N1WX3mjc.cjs +52 -0
  132. package/dist/select-N1WX3mjc.cjs.map +1 -0
  133. package/dist/select.cjs +1 -1
  134. package/dist/select.js +4 -1
  135. package/dist/{sheet-DeE5_yNQ.cjs → sheet-BLzXXxJz.cjs} +2 -2
  136. package/dist/{sheet-DeE5_yNQ.cjs.map → sheet-BLzXXxJz.cjs.map} +1 -1
  137. package/dist/{sheet-yFj2S1UP.js → sheet-CrFAERdT.js} +3 -3
  138. package/dist/{sheet-yFj2S1UP.js.map → sheet-CrFAERdT.js.map} +1 -1
  139. package/dist/sheet.cjs +1 -1
  140. package/dist/sheet.js +1 -1
  141. package/dist/{slider-PwJTXAJc.js → slider-BAQ6ue43.js} +3 -3
  142. package/dist/{slider-PwJTXAJc.js.map → slider-BAQ6ue43.js.map} +1 -1
  143. package/dist/{slider-BN-GC2a_.cjs → slider-Ck3rrBuj.cjs} +2 -2
  144. package/dist/{slider-BN-GC2a_.cjs.map → slider-Ck3rrBuj.cjs.map} +1 -1
  145. package/dist/slider.cjs +1 -1
  146. package/dist/slider.js +1 -1
  147. package/dist/{spinner-Calk9CE7.cjs → spinner-B1iL6lg7.cjs} +2 -2
  148. package/dist/{spinner-Calk9CE7.cjs.map → spinner-B1iL6lg7.cjs.map} +1 -1
  149. package/dist/{spinner-CA6KEbfu.js → spinner-Dp-BlzFE.js} +3 -3
  150. package/dist/{spinner-CA6KEbfu.js.map → spinner-Dp-BlzFE.js.map} +1 -1
  151. package/dist/{surface-VBotYgOg.js → surface-C-5hXuc0.js} +2 -2
  152. package/dist/{surface-VBotYgOg.js.map → surface-C-5hXuc0.js.map} +1 -1
  153. package/dist/{surface-QvhZSMt5.cjs → surface-KIYOpqYN.cjs} +2 -2
  154. package/dist/{surface-QvhZSMt5.cjs.map → surface-KIYOpqYN.cjs.map} +1 -1
  155. package/dist/surface.cjs +1 -1
  156. package/dist/surface.js +1 -1
  157. package/dist/{table-n4ftE_xg.cjs → table-COiGzwHG.cjs} +2 -2
  158. package/dist/{table-n4ftE_xg.cjs.map → table-COiGzwHG.cjs.map} +1 -1
  159. package/dist/{table-Da6LJPGK.js → table-D5Y7TtBM.js} +2 -2
  160. package/dist/{table-Da6LJPGK.js.map → table-D5Y7TtBM.js.map} +1 -1
  161. package/dist/table.cjs +1 -1
  162. package/dist/table.js +1 -1
  163. package/dist/{tabs-group-BK5fJqpY.js → tabs-group-DIv7H3ii.js} +2 -2
  164. package/dist/{tabs-group-BK5fJqpY.js.map → tabs-group-DIv7H3ii.js.map} +1 -1
  165. package/dist/{tabs-group-DThZAKqa.cjs → tabs-group-Dzw-rYWP.cjs} +2 -2
  166. package/dist/{tabs-group-DThZAKqa.cjs.map → tabs-group-Dzw-rYWP.cjs.map} +1 -1
  167. package/dist/tabs.cjs +1 -1
  168. package/dist/tabs.js +1 -1
  169. package/dist/tailwind.mixin-BBKdEPAU.js +43 -0
  170. package/dist/{tailwind.mixin-DNlFmovi.js.map → tailwind.mixin-BBKdEPAU.js.map} +1 -1
  171. package/dist/tailwind.mixin-gE-6eUQA.cjs +2 -0
  172. package/dist/{tailwind.mixin-DYx3IacW.cjs.map → tailwind.mixin-gE-6eUQA.cjs.map} +1 -1
  173. package/dist/teleport.cjs +1 -1
  174. package/dist/{teleport.component-Dose4RDi.js → teleport.component-DldJv9J6.js} +35 -35
  175. package/dist/{teleport.component-Dose4RDi.js.map → teleport.component-DldJv9J6.js.map} +1 -1
  176. package/dist/{teleport.component-D5v1j4mw.cjs → teleport.component-I1DFKmWM.cjs} +2 -2
  177. package/dist/{teleport.component-D5v1j4mw.cjs.map → teleport.component-I1DFKmWM.cjs.map} +1 -1
  178. package/dist/teleport.js +1 -1
  179. package/dist/{textarea-DHrkcyt8.cjs → textarea-Cm_0BDw5.cjs} +2 -2
  180. package/dist/{textarea-DHrkcyt8.cjs.map → textarea-Cm_0BDw5.cjs.map} +1 -1
  181. package/dist/{textarea-JWBhOVdN.js → textarea-DWBpogxd.js} +2 -2
  182. package/dist/{textarea-JWBhOVdN.js.map → textarea-DWBpogxd.js.map} +1 -1
  183. package/dist/textarea.cjs +1 -1
  184. package/dist/textarea.js +1 -1
  185. package/dist/{theme-button-DBPnjBHL.cjs → theme-button-B7JR-68y.cjs} +2 -2
  186. package/dist/{theme-button-DBPnjBHL.cjs.map → theme-button-B7JR-68y.cjs.map} +1 -1
  187. package/dist/{theme-button-BL3unPDt.js → theme-button-CdjTjQE-.js} +2 -2
  188. package/dist/{theme-button-BL3unPDt.js.map → theme-button-CdjTjQE-.js.map} +1 -1
  189. package/dist/theme-button.cjs +1 -1
  190. package/dist/theme-button.js +1 -1
  191. package/dist/theme.cjs +1 -1
  192. package/dist/{theme.component-BNRB5zlE.cjs → theme.component-D0pi4zH5.cjs} +2 -2
  193. package/dist/{theme.component-BNRB5zlE.cjs.map → theme.component-D0pi4zH5.cjs.map} +1 -1
  194. package/dist/{theme.component-iZ2Ty0WM.js → theme.component-DWRFe6NX.js} +2 -2
  195. package/dist/{theme.component-iZ2Ty0WM.js.map → theme.component-DWRFe6NX.js.map} +1 -1
  196. package/dist/theme.js +1 -1
  197. package/dist/{tree-DK6ii57L.js → tree-COFA9Z7I.js} +2 -2
  198. package/dist/{tree-DK6ii57L.js.map → tree-COFA9Z7I.js.map} +1 -1
  199. package/dist/{tree-BU8SHE74.cjs → tree-D8SHnBQ7.cjs} +2 -2
  200. package/dist/{tree-BU8SHE74.cjs.map → tree-D8SHnBQ7.cjs.map} +1 -1
  201. package/dist/tree.cjs +1 -1
  202. package/dist/tree.js +1 -1
  203. package/dist/{typewriter-BcUBG7Dc.cjs → typewriter-B254asJ6.cjs} +2 -2
  204. package/dist/{typewriter-BcUBG7Dc.cjs.map → typewriter-B254asJ6.cjs.map} +1 -1
  205. package/dist/{typewriter-BUNcKCUM.js → typewriter-CKloAbr2.js} +4 -4
  206. package/dist/{typewriter-BUNcKCUM.js.map → typewriter-CKloAbr2.js.map} +1 -1
  207. package/dist/typewriter.cjs +1 -1
  208. package/dist/typewriter.js +1 -1
  209. package/dist/{typography-CLlDUD5O.cjs → typography-BjmgtlSe.cjs} +2 -2
  210. package/dist/{typography-CLlDUD5O.cjs.map → typography-BjmgtlSe.cjs.map} +1 -1
  211. package/dist/{typography-CasDFLVv.js → typography-C0__6Aqk.js} +2 -2
  212. package/dist/{typography-CasDFLVv.js.map → typography-C0__6Aqk.js.map} +1 -1
  213. package/dist/typography.cjs +1 -1
  214. package/dist/typography.js +1 -1
  215. package/package.json +6 -6
  216. package/types/src/autocomplete/autocomplete.d.ts +16 -93
  217. package/types/src/chips/chip.d.ts +0 -2
  218. package/types/src/date-range/date-range.d.ts +14 -15
  219. package/types/src/input/input.d.ts +60 -80
  220. package/types/src/layout/flex/flex.d.ts +24 -1
  221. package/types/src/option/option.d.ts +2 -2
  222. package/types/src/select/select.d.ts +37 -15
  223. package/dist/autocomplete-8-xYgb2e.js +0 -212
  224. package/dist/autocomplete-8-xYgb2e.js.map +0 -1
  225. package/dist/autocomplete-CtUz_AlC.cjs +0 -43
  226. package/dist/autocomplete-CtUz_AlC.cjs.map +0 -1
  227. package/dist/date-range-Cvdpxn2J.js +0 -130
  228. package/dist/date-range-Cvdpxn2J.js.map +0 -1
  229. package/dist/date-range-DTUXT0Lf.cjs +0 -58
  230. package/dist/date-range-DTUXT0Lf.cjs.map +0 -1
  231. package/dist/input-6NTzj_Bn.js +0 -124
  232. package/dist/input-6NTzj_Bn.js.map +0 -1
  233. package/dist/input-CnvK8HG2.cjs +0 -43
  234. package/dist/input-CnvK8HG2.cjs.map +0 -1
  235. package/dist/menu-C4mb1XXA.cjs +0 -31
  236. package/dist/menu-C4mb1XXA.cjs.map +0 -1
  237. package/dist/menu-n_bI-TFp.js.map +0 -1
  238. package/dist/option-CxhioQ_d.js +0 -40
  239. package/dist/option-CxhioQ_d.js.map +0 -1
  240. package/dist/option-lA0IV4VJ.cjs +0 -14
  241. package/dist/option-lA0IV4VJ.cjs.map +0 -1
  242. package/dist/scroll-B-tqDDOP.js.map +0 -1
  243. package/dist/scroll-B7q9TYhV.cjs +0 -33
  244. package/dist/scroll-B7q9TYhV.cjs.map +0 -1
  245. package/dist/select-DAQdBUSl.cjs +0 -46
  246. package/dist/select-DAQdBUSl.cjs.map +0 -1
  247. package/dist/select-DUctHAIZ.js +0 -99
  248. package/dist/select-DUctHAIZ.js.map +0 -1
  249. package/dist/tailwind.mixin-DNlFmovi.js +0 -43
  250. package/dist/tailwind.mixin-DYx3IacW.cjs +0 -2
@@ -1 +1 @@
1
- {"version":3,"file":"teleport.component-D5v1j4mw.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts","../src/content-drawer/$sheet.ts","../src/content-drawer/context.ts","../src/content-drawer/drawer.ts","../src/content-drawer/main.ts","../src/content-drawer/sheet.ts","../src/nav-drawer/$navbar.ts","../src/nav-drawer/context.ts","../src/nav-drawer/appbar.ts","../src/nav-drawer/content.ts","../src/nav-drawer/drawer.ts","../src/nav-drawer/navbar.ts","../src/teleport/teleport.service.ts","../src/teleport/watcher.ts","../src/teleport/teleport.component.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html` <section class=\"pb-4 px-4\"><slot> </slot></section> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardMedia\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement() {\n\t@property() type: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\t@property({ type: Number }) elevation: 0 | 1 | 2 | 3 | 4 | 5 = 0\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'rounded-md': true,\n\t\t\t'shadow-xs': this.elevation === 1,\n\t\t\t'shadow-sm': this.elevation === 2,\n\t\t\t'shadow-md': this.elevation === 3,\n\t\t\t'shadow-lg': this.elevation === 4,\n\t\t\t'shadow-5': this.elevation === 5,\n\t\t\t'hover:shadow-xs': ['outlined', 'filled'].includes(this.type),\n\t\t\t'bg-surface-low shadow-xs hover:shadow-sm': this.type === 'elevated',\n\t\t\t'bg-surface-highest': this.type === 'filled',\n\t\t\t'bg-surface-default border border-solid border-1 border-outlineVariant': this.type === 'outlined',\n\t\t}\n\t\treturn html`<div class=\"${this.classMap(classes)}\">\n\t\t\t<slot> </slot>\n\t\t</div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-card-content\n * @slot headline\n * @slot subhead\n * @slot default - The content of the card\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement() {\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'px-[16px] py-[24px]': true,\n\t\t}\n\t\tconst onSurface = SchmancyTheme.sys.color.surface.on\n\t\tconst onSurfaceVariant = SchmancyTheme.sys.color.surface.onVariant\n\t\treturn html`<schmancy-grid gap=\"md\" class=\"${this.classMap(classes)}\">\n\t\t\t<schmancy-grid gap=\"xs\">\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurface,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"lg\"\n\t\t\t\t\t><slot name=\"headline\"> </slot\n\t\t\t\t></schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t><slot name=\"subhead\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t</schmancy-grid>\n\t\t\t<schmancy-typography\n\t\t\t\ttype=\"body\"\n\t\t\t\t${color({\n\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-typography>\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\n\tprotected render(): unknown {\n\t\tconst styles = {\n\t\t\theight: '200px',\n\t\t}\n\t\tconst classes = {\n\t\t\t'object-center': true,\n\t\t\t'object-contain': this.fit === 'contain',\n\t\t\t'object-cover w-full': this.fit === 'cover',\n\t\t\t'object-fill': this.fit === 'fill',\n\t\t\t'object-none': this.fit === 'none',\n\t\t\t'object-scale-down': this.fit === 'scale-down',\n\t\t}\n\t\treturn html`<schmancy-grid align=\"stretch\" justify=\"stretch\" gap=\"md\">\n\t\t\t<img src=\"${this.src}\" style=${this.styleMap(styles)} class=\"${this.classMap(classes)}\" />\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\ntype DrawerAction = 'dismiss' | 'render'\ntype TRef = Element | Window\ntype TRenderRequest = HTMLElement\nexport type TRenderCustomEvent = CustomEvent<{\n\tcomponent: TRenderRequest\n\ttitle?: string\n}>\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tref: TRef\n\t\taction: DrawerAction\n\t\tcomponent?: TRenderRequest\n\t\ttitle?: string\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe().subscribe(data => {\n\t\t\tif (data.action === 'dismiss') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'render') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tcomponent: data.component,\n\t\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\n\tdimiss(ref: TRef) {\n\t\tthis.$drawer.next({\n\t\t\taction: 'dismiss',\n\t\t\tref: ref,\n\t\t})\n\t}\n\n\trender(ref: TRef, component: TRenderRequest, title?: string) {\n\t\tref.dispatchEvent(new CustomEvent('custom-event'))\n\t\tthis.$drawer.next({\n\t\t\taction: 'render',\n\t\t\tref: ref,\n\t\t\tcomponent: component,\n\t\t\ttitle,\n\t\t})\n\t}\n}\n\nexport const schmancyContentDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyContentDrawerSheetMode = 'push' | 'overlay'\nexport const SchmancyContentDrawerSheetMode = createContext<TSchmancyContentDrawerSheetMode>('push')\n\nexport type TSchmancyContentDrawerSheetState = 'open' | 'close'\nexport const SchmancyContentDrawerSheetState = createContext<TSchmancyContentDrawerSheetState>('close')\n\nexport const SchmancyContentDrawerID = createContext<string>(Math.floor(Math.random() * Date.now()).toString())\nexport const SchmancyContentDrawerMaxHeight = createContext<string>('100%')\nexport const SchmancyContentDrawerMinWidth = createContext<{\n\tmain: number\n\tsheet: number\n}>({})\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, queryAssignedElements, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, merge, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, TRenderCustomEvent, area, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n/**\n * @element schmancy-content-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-content-drawer')\nexport class SchmancyContentDrawer extends $LitElement(css`\n\t:host {\n\t\tposition: relative;\n\t\tinset: 0;\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t/**\n\t * The minimum width of the sheet\n\t * @attr\tminWidth\n\t * @type {number}\n\t * @memberof SchmancyContentDrawer\n\t */\n\n\t@provide({ context: SchmancyContentDrawerMinWidth })\n\tminWidth: typeof SchmancyContentDrawerMinWidth.__context__ = {\n\t\tmain: 360,\n\t\tsheet: 576,\n\t}\n\n\t/**\n\t * The state of the sheet\n\t * @attr open\n\t * @type {TSchmancyContentDrawerSheetState}\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetState })\n\t@property()\n\topen: TSchmancyContentDrawerSheetState\n\n\t/**\n\t * The mode of the sheet\n\t * @type {TSchmancyContentDrawerSheetMode}\n\t * @memberof SchmancyContentDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetMode })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@provide({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID = Math.floor(Math.random() * Date.now()).toString()\n\n\t@provide({ context: SchmancyContentDrawerMaxHeight })\n\tmaxHeight = '100%'\n\n\t@queryAssignedElements({ flatten: true })\n\tassignedElements!: HTMLElement[]\n\tfirstUpdated(): void {\n\t\tmerge(fromEvent<CustomEvent>(window, 'resize'), fromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerResize))\n\t\t\t.pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\ttap(() => console.log(this.minWidth)),\n\t\t\t\tmap(() => (this.clientWidth ? this.clientWidth : window.innerWidth)),\n\t\t\t\tmap(width => width >= this.minWidth.main + this.minWidth.sheet),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.maxHeight = `${window.innerHeight - this.getOffsetTop(this) - 32}px`\n\t\t\t\t\tthis.style.setProperty('max-height', this.maxHeight)\n\t\t\t\t}),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerToggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\n\t\tfromEvent<TRenderCustomEvent>(window, 'schmancy-content-drawer-render')\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(({ component, title }) => {\n\t\t\t\tif (this.mode === 'push') {\n\t\t\t\t\t// TODO: Fix the router to render if constructor has different arguments\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: 'empty',\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: component,\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t} else if ((this.mode = 'overlay')) {\n\t\t\t\t\tsheet.open({ component: component, uid: this.schmancyContentDrawerID, title })\n\t\t\t\t}\n\t\t\t})\n\t}\n\n\tgetOffsetTop(element) {\n\t\tlet offsetTop = 0\n\t\twhile (element) {\n\t\t\toffsetTop += element.offsetTop\n\t\t\telement = element.offsetParent\n\t\t}\n\t\treturn offsetTop\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.mode === 'overlay' ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer': SchmancyContentDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { PropertyValueMap, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyEvents } from '..'\nimport {\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetMode,\n} from './context'\nimport { when } from 'lit/directives/when.js'\n\n@customElement('schmancy-content-drawer-main')\nexport class SchmancyContentDrawerMain extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) this.drawerMinWidth.main = this.minWidth\n\t\telse this.minWidth = this.drawerMinWidth.main\n\t}\n\n\tprotected update(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n\t\tsuper.update(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\tthis.drawerMinWidth.main = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t}\n\t}\n\n\trender() {\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\t\treturn html`\n\t\t\t<section class=\"relative inset-0 h-full\">\n\t\t\t\t<schmancy-grid\n\t\t\t\t\tclass=\"h-full relative overflow-scroll\"\n\t\t\t\t\tcols=\"${this.mode === 'push' ? 'auto 1fr' : '1fr'}\"\n\t\t\t\t\trows=\"1fr\"\n\t\t\t\t\tflow=\"col\"\n\t\t\t\t\talign=\"stretch\"\n\t\t\t\t\tjustify=\"stretch\"\n\t\t\t\t>\n\t\t\t\t\t<section style=${this.styleMap(styles)}>\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</section>\n\t\t\t\t</schmancy-grid>\n\t\t\t\t${when(\n\t\t\t\t\tthis.mode === 'push',\n\t\t\t\t\t() => html` <schmancy-divider class=\"absolute right-0 top-0\" orientation=\"vertical\"></schmancy-divider>`,\n\t\t\t\t)}\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-main': SchmancyContentDrawerMain\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { from, merge, Observable, of, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n// --- 1) Removed the custom animate import\n// import { animate } from '@packages/anime-beta-master'\n\n@customElement('schmancy-content-drawer-sheet')\nexport class SchmancyContentDrawerSheet extends $LitElement(css`\n\t:host {\n\t\toverflow: scroll;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerSheetState, subscribe: true })\n\t@state()\n\tstate: TSchmancyContentDrawerSheetState\n\n\t@consume({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID\n\n\t@query('#sheet') sheet!: HTMLElement\n\t@queryAssignedElements({ flatten: true, slot: undefined }) defaultSlot!: HTMLElement[]\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) {\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t} else {\n\t\t\tthis.minWidth = this.drawerMinWidth.sheet\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\t// If the 'minWidth' property changed\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t} else if (changedProperties.has('state') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\t// Overlay open logic if needed\n\t\t\t\t\t// this.open()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tsheet.dismiss(this.schmancyContentDrawerID)\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.open()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Open the sheet by sliding it into view.\n\t */\n\topen() {\n\t\t// \"onBegin\" logic from the old `animate(...)`\n\t\tif (this.mode === 'overlay') {\n\t\t\tthis.sheet.style.position = 'fixed'\n\t\t} else {\n\t\t\tthis.sheet.style.position = 'relative'\n\t\t}\n\t\tthis.sheet.style.display = 'block'\n\n\t\t// --- 2) Use native Web Animations API ---\n\t\tthis.sheet.animate(\n\t\t\t[\n\t\t\t\t{ opacity: 0, transform: 'translateX(100%)' },\n\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: 500,\n\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t},\n\t\t)\n\t\t// No return is needed if you don't rely on the result\n\t}\n\n\t/**\n\t * Close everything (modal sheet + the sheet itself).\n\t */\n\tcloseAll() {\n\t\t// Merge them into a single subscription,\n\t\t// so that everything closes in parallel.\n\t\tmerge(from(this.closeModalSheet()), from(this.closeSheet())).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Dismiss the \"modal sheet.\"\n\t * This just returns an Observable that completes immediately.\n\t */\n\tcloseModalSheet() {\n\t\treturn of(true).pipe(tap(() => sheet.dismiss(this.schmancyContentDrawerID)))\n\t}\n\n\t/**\n\t * Slide the sheet out of view + hide it.\n\t * Return an Observable so we can merge it with other close operations.\n\t */\n\tcloseSheet() {\n\t\t// --- 2) Use native Web Animations API and wrap in an Observable ---\n\t\treturn new Observable<void>(observer => {\n\t\t\tconst animation = this.sheet.animate(\n\t\t\t\t[\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(100%)' },\n\t\t\t\t],\n\t\t\t\t{\n\t\t\t\t\tduration: 500,\n\t\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tanimation.onfinish = () => {\n\t\t\t\t// \"onComplete\" logic\n\t\t\t\tthis.sheet.style.display = 'none'\n\t\t\t\tobserver.next()\n\t\t\t\tobserver.complete()\n\t\t\t}\n\t\t})\n\t}\n\n\tprotected render() {\n\t\tconst sheetClasses = {\n\t\t\tblock: this.mode === 'push',\n\t\t\t'absolute z-50': this.mode === 'overlay',\n\t\t\t'opacity-1': this.mode === 'overlay' && this.state === 'open',\n\t\t}\n\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\n\t\treturn html`\n\t\t\t<section id=\"sheet\" class=\"${this.classMap(sheetClasses)}\" style=${this.styleMap(styles)}>\n\t\t\t\t<schmancy-area name=\"${this.schmancyContentDrawerID}\">\n\t\t\t\t\t<slot name=\"placeholder\"></slot>\n\t\t\t\t</schmancy-area>\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-sheet': SchmancyContentDrawerSheet\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { debounceTime, distinctUntilKeyChanged, Subject } from 'rxjs'\n\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tself: HTMLElement\n\t\tstate: boolean\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe(distinctUntilKeyChanged('state'), debounceTime(100)).subscribe(data => {\n\t\t\tconsole.log('drawer', data)\n\t\t\tif (data.state) {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\topen(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: true,\n\t\t})\n\t}\n\tclose(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: false,\n\t\t})\n\t}\n}\n\nexport const schmancyNavDrawer = new Drawer()\nconst $drawer = schmancyNavDrawer\n\nexport { $drawer }\n","import { createContext } from '@lit/context'\nexport type TSchmancyDrawerNavbarMode = 'push' | 'overlay' | undefined\nexport const SchmancyDrawerNavbarMode = createContext<TSchmancyDrawerNavbarMode>('push')\n\nexport type TSchmancyDrawerNavbarState = 'open' | 'close' | undefined\nexport const SchmancyDrawerNavbarState = createContext<TSchmancyDrawerNavbarState>('close')\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n} from '@schmancy/nav-drawer/context'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyEvents } from '..'\n\n/**\n * @element schmancy-nav-drawer-appbar\n * @slot toggler - The toggler slot\n * @slot - The default slot\n */\n@customElement('schmancy-nav-drawer-appbar')\nexport class SchmancyDrawerAppbar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tsidebarMode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tsidebarOpen\n\n\t@property({ type: Boolean }) toggler = true\n\n\trender() {\n\t\tconst appbarClasses = {\n\t\t\t'block z-50': true,\n\t\t}\n\t\tconst sidebarToggler = {\n\t\t\t'block left-3 z-50': this.sidebarMode === 'overlay',\n\t\t\thidden: this.sidebarMode === 'push',\n\t\t}\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.sidebarMode === 'overlay' && this.toggler ? 'auto 1fr' : '1fr'}\n\t\t\t\tflow=\"col\"\n\t\t\t\tclass=${this.classMap(appbarClasses)}\n\t\t\t\tgap=\"sm\"\n\t\t\t\talign=\"center\"\n\t\t\t>\n\t\t\t\t${when(\n\t\t\t\t\tthis.sidebarMode === 'overlay' && this.toggler,\n\t\t\t\t\t() =>\n\t\t\t\t\t\thtml`<slot name=\"toggler\">\n\t\t\t\t\t\t\t<div class=\"${this.classMap(sidebarToggler)}\">\n\t\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\t\t\t\t\t\tdetail: { state: this.sidebarOpen === 'open' ? 'close' : 'open' },\n\t\t\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t${when(\n\t\t\t\t\t\t\t\t\t\tthis.sidebarOpen === 'close',\n\t\t\t\t\t\t\t\t\t\t() => html`menu`,\n\t\t\t\t\t\t\t\t\t\t() => html`menu_open`,\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</slot>`,\n\t\t\t\t)}\n\n\t\t\t\t<slot> </slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-appbar': SchmancyDrawerAppbar\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n@customElement('schmancy-nav-drawer-content')\nexport class SchmancyNavigationDrawerContent extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tinset: 0;\n\t\toverflow-y: auto;\n\t}\n`) {\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent(this, 'scroll')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(e => {\n\t\t\t\tthis.parentElement.dispatchEvent(new CustomEvent('scroll', { detail: e, bubbles: true, composed: true }))\n\t\t\t})\n\t}\n\trender() {\n\t\treturn html` <slot></slot> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-content': SchmancyNavigationDrawerContent\n\t}\n}\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents } from '..'\nimport { fullHeight } from './../directives/height'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n/**\n * @element schmancy-nav-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-nav-drawer')\nexport class SchmancyNavigationDrawer extends $LitElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex-grow: 1;\n\t\toverflow: hidden;\n\t}\n`) {\n\t// fullscreen property\n\t@property({ type: Boolean })\n\tfullscreen: boolean = false\n\n\t/**\n\t * The minimum width of the sidebar\n\t * @attr\tbreakpoint\n\t * @type {number}\n\t * @memberof SchmancyNavigationDrawer\n\t */\n\t@property({ type: Number, attribute: 'breakpoint' })\n\tbreakpoint: number = 768\n\n\t/**\n\t * The mode of the sidebar\n\t * @type {TSchmancyDrawerNavbarMode}\n\t * @memberof SchmancyNavigationDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyDrawerNavbarMode })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@provide({ context: SchmancyDrawerNavbarState })\n\t@property()\n\topen: TSchmancyDrawerNavbarState\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(window, 'resize')\n\t\t\t.pipe(\n\t\t\t\tmap(event => event.target as Window),\n\t\t\t\tstartWith(window),\n\t\t\t\tmap(window => window.innerWidth),\n\t\t\t\tmap(width => width >= this.breakpoint),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.NavDrawer_toggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\t// if the mode is push, we don't need to close the overlay when the state is close\n\t\t\t\tif (this.mode === 'push' && state === 'close') return\n\t\t\t\tthis.open = state\n\t\t\t})\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.fullscreen ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t\t${fullHeight()}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer': SchmancyNavigationDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { SchmancyEvents, SchmancyTheme, color } from '..'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n@customElement('schmancy-nav-drawer-navbar')\nexport class SchmancyNavigationDrawerSidebar extends $LitElement() {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tprivate state: TSchmancyDrawerNavbarState\n\n\t@query('#overlay') overlay!: HTMLElement\n\t@query('nav') nav!: HTMLElement\n\n\t@property({ type: String }) width = '320px'\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tif (changedProperties.has('state')) {\n\t\t\tconsole.log('state changed', this.state, this.mode)\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.hideNavDrawer()\n\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.openOverlay()\n\t\t\t\t\tthis.showNavDrawer()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tthis.showNavDrawer()\n\t\t\t\tthis.closeOverlay()\n\t\t\t}\n\t\t}\n\t}\n\n\topenOverlay() {\n\t\t// Equivalent to onBegin\n\t\tthis.overlay.style.display = 'block'\n\n\t\t// Animate opacity from 0 to 0.4\n\t\tthis.overlay.animate([{ opacity: 0 }, { opacity: 0.4 }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards', // <-- This keeps the final keyframe (0.4) after finishing\n\t\t})\n\t\t// If you want an onfinish here, you can add it:\n\t\t// .onfinish = () => console.log('overlay opened!')\n\t}\n\n\tcloseOverlay() {\n\t\t// Animate opacity from 0.4 to 0\n\t\tconst animation = this.overlay.animate([{ opacity: 0.4 }, { opacity: 0 }], {\n\t\t\tduration: 150,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\t// translateX(-100%) when the animation is finished\n\t\t// Equivalent to onComplete\n\t\tanimation.onfinish = () => {\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t}\n\n\t// show nav drawer\n\tshowNavDrawer() {\n\t\t// check the transform, skip if already open\n\t\tif (this.nav.style.transform === 'translateX(0)') return\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(-100%)' }, { transform: 'translateX(0)' }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.state = 'open'\n\t\t}\n\t}\n\n\t// hide nav drawer\n\thideNavDrawer() {\n\t\t// skip if already closed\n\t\tif (this.nav.style.transform === 'translateX(-100%)') return\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(0)' }, { transform: 'translateX(-100%)' }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.state = 'close'\n\t\t}\n\t}\n\n\tprotected render() {\n\t\tconst sidebarClasses = {\n\t\t\t'p-[16px] max-w-[360px] w-fit h-full overflow-auto': true,\n\t\t\tblock: this.mode === 'push',\n\t\t\t'fixed inset-0 z-50': this.mode === 'overlay',\n\t\t}\n\t\tconst overlayClass = {\n\t\t\t'fixed inset-0 z-49 hidden': true,\n\t\t}\n\n\t\tconst styleMap = {\n\t\t\twidth: this.width,\n\t\t}\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tstyle=${this.styleMap(styleMap)}\n\t\t\t\tclass=\"${this.classMap({ ...sidebarClasses })}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t\t<div\n\t\t\t\tid=\"overlay\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.scrim,\n\t\t\t\t})}\n\t\t\t\t@click=${() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\tdetail: { state: 'close' },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}}\n\t\t\t\tclass=\"${this.classMap({ ...overlayClass })}\"\n\t\t\t></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-navbar': SchmancyNavigationDrawerSidebar\n\t}\n}\n","import { bufferTime, concatMap, filter, fromEvent, map, of, Subject, take, tap, timeout, zip } from 'rxjs'\nimport { SchmancyTeleportation } from './teleport.component'\n\nexport type WhereAreYouRickyEvent = CustomEvent<{\n\tid: string\n\tcallerID: number\n}>\n\nexport const WhereAreYouRicky = 'whereAreYouRicky'\n\nexport type HereMortyEvent = CustomEvent<{\n\tcomponent: SchmancyTeleportation\n}>\n\nexport type FLIP_REQUEST = {\n\tfrom: {\n\t\trect: DOMRect\n\t\telement?: HTMLElement\n\t}\n\tto: {\n\t\trect: DOMRect\n\t\telement: HTMLElement\n\t}\n\tstagger?: number\n\thost: HTMLElement\n}\nexport const HereMorty = 'hereMorty'\n\nclass Teleportation {\n\tactiveTeleportations = new Map<string, DOMRect>()\n\tflipRequests = new Subject<FLIP_REQUEST>()\n\n\tconstructor() {\n\t\tthis.flipRequests\n\t\t\t.pipe(\n\t\t\t\tbufferTime(1),\n\t\t\t\tmap(requests =>\n\t\t\t\t\trequests.map(({ from, to, host }, i) => ({\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tto,\n\t\t\t\t\t\thost,\n\t\t\t\t\t\ti,\n\t\t\t\t\t})),\n\t\t\t\t),\n\t\t\t\tconcatMap(requests => zip(requests.map(request => of(this.flip(request))))),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tfind = (component: SchmancyTeleportation) => {\n\t\treturn zip([\n\t\t\tfromEvent<HereMortyEvent>(window, HereMorty).pipe(\n\t\t\t\tfilter(\n\t\t\t\t\te =>\n\t\t\t\t\t\t!!e.detail.component.uuid &&\n\t\t\t\t\t\t!!component.id &&\n\t\t\t\t\t\te.detail.component.id === component.id &&\n\t\t\t\t\t\te.detail.component.uuid !== component.uuid,\n\t\t\t\t),\n\t\t\t\tmap(e => e.detail.component),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\tof(component).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent<WhereAreYouRickyEvent['detail']>(WhereAreYouRicky, {\n\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\tid: component.id,\n\t\t\t\t\t\t\t\tcallerID: component.uuid,\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]).pipe(\n\t\t\tmap(([component]) => component),\n\t\t\ttimeout(0),\n\t\t)\n\t}\n\n\tflip = (request: {\n\t\tfrom: {\n\t\t\trect: DOMRect\n\t\t}\n\t\tto: {\n\t\t\telement: HTMLElement\n\t\t\trect: DOMRect\n\t\t}\n\t\thost: HTMLElement\n\t\ti: number\n\t}) => {\n\t\tconst { from, to } = request\n\n\t\t// Prepare the element for animation\n\t\tconst originalZIndex = to.element.style.zIndex\n\t\tto.element.style.transformOrigin = 'top left'\n\t\tto.element.style.setProperty('visibility', 'visible')\n\t\tto.element.style.zIndex = '1000'\n\n\t\t// \"onBegin\" logic goes here (since Web Animations doesn't have onBegin).\n\t\t// If you had more logic, place it here:\n\t\t// e.g., console.log('Starting FLIP animation...');\n\n\t\t// Calculate starting and ending transforms\n\t\tconst startX = from.rect.left - to.rect.left\n\t\tconst startY = from.rect.top - to.rect.top\n\t\tconst startScaleX = from.rect.width / to.rect.width\n\t\tconst startScaleY = from.rect.height / to.rect.height\n\n\t\t// Create keyframes\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\ttransform: `translate(${startX}px, ${startY}px) scale(${startScaleX}, ${startScaleY})`,\n\t\t\t},\n\t\t\t{\n\t\t\t\ttransform: 'translate(0, 0) scale(1, 1)',\n\t\t\t},\n\t\t]\n\n\t\t// Use native Web Animations API\n\t\tconst animation = to.element.animate(keyframes, {\n\t\t\tduration: 250,\n\t\t\tdelay: 10, // if desired\n\t\t\t// Approximate 'inOutQuad' via a cubic-bezier easing.\n\t\t\t// You can adjust these values to taste, or use a standard one:\n\t\t\teasing: 'cubic-bezier(0.455, 0.03, 0.515, 0.955)',\n\t\t\t// or simply 'ease-in-out'\n\t\t})\n\n\t\t// \"onComplete\" logic goes here\n\t\tanimation.onfinish = () => {\n\t\t\tto.element.style.zIndex = originalZIndex\n\t\t\tto.element.style.transformOrigin = ''\n\t\t\t// If you have additional cleanup, place it here\n\t\t\t// e.g., console.log('FLIP animation completed!');\n\t\t}\n\t}\n}\n\nexport const teleport = new Teleportation()\nexport default teleport\n","import { Observable, interval } from 'rxjs'\nimport { distinctUntilChanged, map, take } from 'rxjs/operators'\n\n// Function to monitor element's bounding client rect\nexport function watchElementRect(element: Element): Observable<DOMRectReadOnly> {\n\treturn interval(50).pipe(\n\t\t// startWith(true),\n\t\tmap(() => element.getBoundingClientRect()),\n\t\tdistinctUntilChanged(\n\t\t\t(prev, curr) =>\n\t\t\t\tprev.width === curr.width &&\n\t\t\t\tprev.height === curr.height &&\n\t\t\t\tprev.top === curr.top &&\n\t\t\t\tprev.right === curr.right &&\n\t\t\t\tprev.bottom === curr.bottom &&\n\t\t\t\tprev.left === curr.left,\n\t\t),\n\t\ttake(1),\n\t)\n}\n","import { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { filter, fromEvent, merge, of, takeUntil, tap, throwIfEmpty } from 'rxjs'\nimport { FINDING_MORTIES, FINDING_MORTIES_EVENT, HERE_RICKY, HERE_RICKY_EVENT } from '..'\nimport {\n\tHereMorty,\n\tHereMortyEvent,\n\tWhereAreYouRicky,\n\tWhereAreYouRickyEvent,\n\tdefault as teleport,\n\tdefault as teleportationService,\n} from './teleport.service'\nimport { watchElementRect } from './watcher'\nimport { $LitElement } from '@mixins/index'\n@customElement('schmancy-teleport')\nexport class SchmancyTeleportation extends $LitElement(css``) {\n\t/**\n\t * @attr {string} uuid - The component tag to teleport\n\t * @readonly\n\t */\n\t@property({ type: Number, reflect: true }) uuid = Math.floor(Math.random() * Date.now())\n\n\t/**\n\t * @attr {string} id - The component tag to teleport\n\t * @required\n\t */\n\t@property({ type: String }) id!: string\n\n\t@property({ type: Number }) delay = 0\n\n\tdebugging = import.meta.env.DEV ? true : false\n\n\tget _slottedChildren() {\n\t\tconst slot = this.shadowRoot.querySelector('slot')\n\t\treturn slot.assignedElements({ flatten: true })\n\t}\n\n\tconnectedCallback(): void {\n\t\tif (this.id === undefined) throw new Error('id is required')\n\t\tsuper.connectedCallback()\n\t\tmerge(\n\t\t\tfromEvent<FINDING_MORTIES_EVENT>(window, FINDING_MORTIES).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\tnew CustomEvent<HERE_RICKY_EVENT['detail']>(HERE_RICKY, {\n\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\tcomposed: true,\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\tfromEvent<WhereAreYouRickyEvent>(window, WhereAreYouRicky).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: e => {\n\t\t\t\t\t\tif (e.detail.id === this.id && this.uuid && e.detail.callerID !== this.uuid) {\n\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\tnew CustomEvent<HereMortyEvent['detail']>(HereMorty, {\n\t\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t}),\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)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe()\n\t}\n\n\tasync firstUpdated() {\n\t\tof(teleportationService.activeTeleportations.get(this.id))\n\t\t\t.pipe(\n\t\t\t\tfilter(a => !!a),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tthrowIfEmpty(),\n\t\t\t)\n\t\t\t.subscribe({\n\t\t\t\tnext: domRect => {\n\t\t\t\t\tconsole.count('teleport')\n\t\t\t\t\tthis.style.setProperty('visibility', 'hidden')\n\t\t\t\t\t// teleport.flipRequests.next({ from: component, to: this, stagger: 0 })\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\t// console.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t\tteleport.flipRequests.next({\n\t\t\t\t\t\t\t\t\tfrom: {\n\t\t\t\t\t\t\t\t\t\trect: domRect,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tto: {\n\t\t\t\t\t\t\t\t\t\trect: e,\n\t\t\t\t\t\t\t\t\t\telement: this._slottedChildren[0] as HTMLElement,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\thost: this,\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\terror: () => {\n\t\t\t\t\tthis.style.setProperty('visibility', 'visible')\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tconsole.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\tcomplete: () => {},\n\t\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-teleport': SchmancyTeleportation\n\t}\n}\n"],"names":["SchmancyCardMedia","TailwindElement","css","html","customElement","SchmancyCard","super","arguments","this","type","elevation","classes","includes","classMap","__decorateClass","property","prototype","Number","SchmancyCardContent","onSurface","SchmancyTheme","sys","color","surface","on","onSurfaceVariant","onVariant","src","fit","styleMap","height","String","reflect","schmancyContentDrawer","$drawer","Subject","pipe","subscribe","data","action","ref","dispatchEvent","CustomEvent","SchmancyEvents","ContentDrawerToggle","detail","state","bubbles","composed","component","title","next","t","SchmancyContentDrawerSheetMode","createContext","SchmancyContentDrawerSheetState","SchmancyContentDrawerID","n","Math","floor","random","Date","now","toString","SchmancyContentDrawerMaxHeight","SchmancyContentDrawerMinWidth","SchmancyContentDrawer","$LitElement","constructor","minWidth","main","sheet","schmancyContentDrawerID","maxHeight","merge","fromEvent","window","ContentDrawerResize","startWith","tap","map","clientWidth","innerWidth","width","debounceTime","innerHeight","getOffsetTop","style","setProperty","distinctUntilChanged","takeUntil","disconnecting","lgScreen","mode","open","event","stopPropagation","area","push","historyStrategy","uid","element","offsetTop","offsetParent","render","nothing","provide","context","queryAssignedElements","flatten","SchmancyContentDrawerMain","connectedCallback","drawerMinWidth","changedProperties","update","has","styles","when","consume","SchmancyContentDrawerSheet","updated","closeAll","dismiss","position","display","animate","opacity","transform","duration","easing","from","closeModalSheet","closeSheet","of","Observable","observer","onfinish","complete","sheetClasses","block","query","slot","schmancyNavDrawer","distinctUntilKeyChanged","NavDrawer_toggle","self","SchmancyDrawerNavbarMode","SchmancyDrawerNavbarState","SchmancyDrawerAppbar","toggler","sidebarToggler","sidebarMode","hidden","sidebarOpen","Boolean","SchmancyNavigationDrawerContent","e","parentElement","SchmancyNavigationDrawer","fullscreen","breakpoint","target","fullHeight","attribute","SchmancyNavigationDrawerSidebar","hideNavDrawer","closeOverlay","openOverlay","showNavDrawer","overlay","fill","nav","sidebarClasses","bgColor","container","scrim","WhereAreYouRicky","HereMorty","teleport","activeTeleportations","Map","flipRequests","find","zip","filter","uuid","id","take","callerID","timeout","flip","request","to","originalZIndex","zIndex","transformOrigin","keyframes","rect","left","top","delay","bufferTime","requests","host","i","concatMap","watchElementRect","interval","getBoundingClientRect","prev","curr","right","bottom","SchmancyTeleportation","debugging","shadowRoot","querySelector","assignedElements","Error","FINDING_MORTIES","HERE_RICKY","teleportationService","get","a","throwIfEmpty","domRect","set","_slottedChildren","error"],"mappings":"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"}
1
+ {"version":3,"file":"teleport.component-I1DFKmWM.cjs","sources":["../src/card/actions.ts","../src/card/card.ts","../src/card/content.ts","../src/card/media.ts","../src/content-drawer/$sheet.ts","../src/content-drawer/context.ts","../src/content-drawer/drawer.ts","../src/content-drawer/main.ts","../src/content-drawer/sheet.ts","../src/nav-drawer/$navbar.ts","../src/nav-drawer/context.ts","../src/nav-drawer/appbar.ts","../src/nav-drawer/content.ts","../src/nav-drawer/drawer.ts","../src/nav-drawer/navbar.ts","../src/teleport/teleport.service.ts","../src/teleport/watcher.ts","../src/teleport/teleport.component.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-action\n * @slot - The content of the action\n */\n@customElement('schmancy-card-action')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\tprotected render(): unknown {\n\t\treturn html` <section class=\"pb-4 px-4\"><slot> </slot></section> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-action': SchmancyCardMedia\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n@customElement('schmancy-card')\nexport default class SchmancyCard extends TailwindElement() {\n\t@property() type: 'elevated' | 'filled' | 'outlined' = 'elevated'\n\t@property({ type: Number }) elevation: 0 | 1 | 2 | 3 | 4 | 5 = 0\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'rounded-md': true,\n\t\t\t'shadow-xs': this.elevation === 1,\n\t\t\t'shadow-sm': this.elevation === 2,\n\t\t\t'shadow-md': this.elevation === 3,\n\t\t\t'shadow-lg': this.elevation === 4,\n\t\t\t'shadow-5': this.elevation === 5,\n\t\t\t'hover:shadow-xs': ['outlined', 'filled'].includes(this.type),\n\t\t\t'bg-surface-low shadow-xs hover:shadow-sm': this.type === 'elevated',\n\t\t\t'bg-surface-highest': this.type === 'filled',\n\t\t\t'bg-surface-default border border-solid border-1 border-outlineVariant': this.type === 'outlined',\n\t\t}\n\t\treturn html`<div class=\"${this.classMap(classes)}\">\n\t\t\t<slot> </slot>\n\t\t</div>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card': SchmancyCard\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { color } from '..'\n\n/**\n * @element schmancy-card-content\n * @slot headline\n * @slot subhead\n * @slot default - The content of the card\n */\n@customElement('schmancy-card-content')\nexport default class SchmancyCardContent extends TailwindElement() {\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'px-[16px] py-[24px]': true,\n\t\t}\n\t\tconst onSurface = SchmancyTheme.sys.color.surface.on\n\t\tconst onSurfaceVariant = SchmancyTheme.sys.color.surface.onVariant\n\t\treturn html`<schmancy-grid gap=\"md\" class=\"${this.classMap(classes)}\">\n\t\t\t<schmancy-grid gap=\"xs\">\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurface,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\ttoken=\"lg\"\n\t\t\t\t\t><slot name=\"headline\"> </slot\n\t\t\t\t></schmancy-typography>\n\t\t\t\t<schmancy-typography\n\t\t\t\t\t${color({\n\t\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t\t})}\n\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t><slot name=\"subhead\"></slot>\n\t\t\t\t</schmancy-typography>\n\t\t\t</schmancy-grid>\n\t\t\t<schmancy-typography\n\t\t\t\ttype=\"body\"\n\t\t\t\t${color({\n\t\t\t\t\tcolor: onSurfaceVariant,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-typography>\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-content': SchmancyCardContent\n\t}\n}\n","import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\n/**\n * @element schmancy-card-media\n */\n@customElement('schmancy-card-media')\nexport default class SchmancyCardMedia extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@property({ type: String, reflect: true })\n\tsrc: string = ''\n\n\t@property({ type: String })\n\tfit: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down' = 'contain'\n\n\tprotected render(): unknown {\n\t\tconst styles = {\n\t\t\theight: '200px',\n\t\t}\n\t\tconst classes = {\n\t\t\t'object-center': true,\n\t\t\t'object-contain': this.fit === 'contain',\n\t\t\t'object-cover w-full': this.fit === 'cover',\n\t\t\t'object-fill': this.fit === 'fill',\n\t\t\t'object-none': this.fit === 'none',\n\t\t\t'object-scale-down': this.fit === 'scale-down',\n\t\t}\n\t\treturn html`<schmancy-grid align=\"stretch\" justify=\"stretch\" gap=\"md\">\n\t\t\t<img src=\"${this.src}\" style=${this.styleMap(styles)} class=\"${this.classMap(classes)}\" />\n\t\t</schmancy-grid>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-card-media': SchmancyCardMedia\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { Subject } from 'rxjs'\n\ntype DrawerAction = 'dismiss' | 'render'\ntype TRef = Element | Window\ntype TRenderRequest = HTMLElement\nexport type TRenderCustomEvent = CustomEvent<{\n\tcomponent: TRenderRequest\n\ttitle?: string\n}>\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tref: TRef\n\t\taction: DrawerAction\n\t\tcomponent?: TRenderRequest\n\t\ttitle?: string\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe().subscribe(data => {\n\t\t\tif (data.action === 'dismiss') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else if (data.action === 'render') {\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.ContentDrawerToggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tdata.ref.dispatchEvent(\n\t\t\t\t\tnew CustomEvent('schmancy-content-drawer-render', {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tcomponent: data.component,\n\t\t\t\t\t\t\ttitle: data.title,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\n\tdimiss(ref: TRef) {\n\t\tthis.$drawer.next({\n\t\t\taction: 'dismiss',\n\t\t\tref: ref,\n\t\t})\n\t}\n\n\trender(ref: TRef, component: TRenderRequest, title?: string) {\n\t\tref.dispatchEvent(new CustomEvent('custom-event'))\n\t\tthis.$drawer.next({\n\t\t\taction: 'render',\n\t\t\tref: ref,\n\t\t\tcomponent: component,\n\t\t\ttitle,\n\t\t})\n\t}\n}\n\nexport const schmancyContentDrawer = new Drawer()\n","import { createContext } from '@lit/context'\nexport type TSchmancyContentDrawerSheetMode = 'push' | 'overlay'\nexport const SchmancyContentDrawerSheetMode = createContext<TSchmancyContentDrawerSheetMode>('push')\n\nexport type TSchmancyContentDrawerSheetState = 'open' | 'close'\nexport const SchmancyContentDrawerSheetState = createContext<TSchmancyContentDrawerSheetState>('close')\n\nexport const SchmancyContentDrawerID = createContext<string>(Math.floor(Math.random() * Date.now()).toString())\nexport const SchmancyContentDrawerMaxHeight = createContext<string>('100%')\nexport const SchmancyContentDrawerMinWidth = createContext<{\n\tmain: number\n\tsheet: number\n}>({})\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, queryAssignedElements, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, merge, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, TRenderCustomEvent, area, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n/**\n * @element schmancy-content-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-content-drawer')\nexport class SchmancyContentDrawer extends $LitElement(css`\n\t:host {\n\t\tposition: relative;\n\t\tinset: 0;\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t/**\n\t * The minimum width of the sheet\n\t * @attr\tminWidth\n\t * @type {number}\n\t * @memberof SchmancyContentDrawer\n\t */\n\n\t@provide({ context: SchmancyContentDrawerMinWidth })\n\tminWidth: typeof SchmancyContentDrawerMinWidth.__context__ = {\n\t\tmain: 360,\n\t\tsheet: 576,\n\t}\n\n\t/**\n\t * The state of the sheet\n\t * @attr open\n\t * @type {TSchmancyContentDrawerSheetState}\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetState })\n\t@property()\n\topen: TSchmancyContentDrawerSheetState\n\n\t/**\n\t * The mode of the sheet\n\t * @type {TSchmancyContentDrawerSheetMode}\n\t * @memberof SchmancyContentDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyContentDrawerSheetMode })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@provide({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID = Math.floor(Math.random() * Date.now()).toString()\n\n\t@provide({ context: SchmancyContentDrawerMaxHeight })\n\tmaxHeight = '100%'\n\n\t@queryAssignedElements({ flatten: true })\n\tassignedElements!: HTMLElement[]\n\tfirstUpdated(): void {\n\t\tmerge(fromEvent<CustomEvent>(window, 'resize'), fromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerResize))\n\t\t\t.pipe(\n\t\t\t\tstartWith(true),\n\t\t\t\ttap(() => console.log(this.minWidth)),\n\t\t\t\tmap(() => (this.clientWidth ? this.clientWidth : window.innerWidth)),\n\t\t\t\tmap(width => width >= this.minWidth.main + this.minWidth.sheet),\n\t\t\t\tdebounceTime(100),\n\t\t\t\ttap(() => {\n\t\t\t\t\tthis.maxHeight = `${window.innerHeight - this.getOffsetTop(this) - 32}px`\n\t\t\t\t\tthis.style.setProperty('max-height', this.maxHeight)\n\t\t\t\t}),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.ContentDrawerToggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\tthis.open = state\n\t\t\t})\n\n\t\tfromEvent<TRenderCustomEvent>(window, 'schmancy-content-drawer-render')\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t)\n\t\t\t.subscribe(({ component, title }) => {\n\t\t\t\tif (this.mode === 'push') {\n\t\t\t\t\t// TODO: Fix the router to render if constructor has different arguments\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: 'empty',\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t\tarea.push({\n\t\t\t\t\t\tarea: this.schmancyContentDrawerID,\n\t\t\t\t\t\tcomponent: component,\n\t\t\t\t\t\thistoryStrategy: 'silent',\n\t\t\t\t\t})\n\t\t\t\t} else if ((this.mode = 'overlay')) {\n\t\t\t\t\tsheet.open({ component: component, uid: this.schmancyContentDrawerID, title })\n\t\t\t\t}\n\t\t\t})\n\t}\n\n\tgetOffsetTop(element) {\n\t\tlet offsetTop = 0\n\t\twhile (element) {\n\t\t\toffsetTop += element.offsetTop\n\t\t\telement = element.offsetParent\n\t\t}\n\t\treturn offsetTop\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.mode === 'overlay' ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer': SchmancyContentDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { PropertyValueMap, css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { SchmancyEvents } from '..'\nimport {\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetMode,\n} from './context'\nimport { when } from 'lit/directives/when.js'\n\n@customElement('schmancy-content-drawer-main')\nexport class SchmancyContentDrawerMain extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\toverflow: hidden;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) this.drawerMinWidth.main = this.minWidth\n\t\telse this.minWidth = this.drawerMinWidth.main\n\t}\n\n\tprotected update(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void {\n\t\tsuper.update(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\tthis.drawerMinWidth.main = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t}\n\t}\n\n\trender() {\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\t\treturn html`\n\t\t\t<section class=\"relative inset-0 h-full\">\n\t\t\t\t<schmancy-grid\n\t\t\t\t\tclass=\"h-full relative overflow-scroll\"\n\t\t\t\t\tcols=\"${this.mode === 'push' ? 'auto 1fr' : '1fr'}\"\n\t\t\t\t\trows=\"1fr\"\n\t\t\t\t\tflow=\"col\"\n\t\t\t\t\talign=\"stretch\"\n\t\t\t\t\tjustify=\"stretch\"\n\t\t\t\t>\n\t\t\t\t\t<section style=${this.styleMap(styles)}>\n\t\t\t\t\t\t<slot></slot>\n\t\t\t\t\t</section>\n\t\t\t\t</schmancy-grid>\n\t\t\t\t${when(\n\t\t\t\t\tthis.mode === 'push',\n\t\t\t\t\t() => html` <schmancy-divider class=\"absolute right-0 top-0\" orientation=\"vertical\"></schmancy-divider>`,\n\t\t\t\t)}\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-main': SchmancyContentDrawerMain\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { from, merge, Observable, of, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents, sheet } from '..'\nimport {\n\tSchmancyContentDrawerID,\n\tSchmancyContentDrawerMaxHeight,\n\tSchmancyContentDrawerMinWidth,\n\tSchmancyContentDrawerSheetMode,\n\tSchmancyContentDrawerSheetState,\n\tTSchmancyContentDrawerSheetMode,\n\tTSchmancyContentDrawerSheetState,\n} from './context'\n\n// --- 1) Removed the custom animate import\n// import { animate } from '@packages/anime-beta-master'\n\n@customElement('schmancy-content-drawer-sheet')\nexport class SchmancyContentDrawerSheet extends $LitElement(css`\n\t:host {\n\t\toverflow: scroll;\n\t}\n`) {\n\t@property({ type: Number })\n\tminWidth\n\n\t@consume({ context: SchmancyContentDrawerSheetMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyContentDrawerSheetMode\n\n\t@consume({ context: SchmancyContentDrawerSheetState, subscribe: true })\n\t@state()\n\tstate: TSchmancyContentDrawerSheetState\n\n\t@consume({ context: SchmancyContentDrawerID })\n\tschmancyContentDrawerID\n\n\t@query('#sheet') sheet!: HTMLElement\n\t@queryAssignedElements({ flatten: true, slot: undefined }) defaultSlot!: HTMLElement[]\n\n\t@consume({ context: SchmancyContentDrawerMinWidth, subscribe: true })\n\tdrawerMinWidth: typeof SchmancyContentDrawerMinWidth.__context__\n\n\t@consume({ context: SchmancyContentDrawerMaxHeight, subscribe: true })\n\t@state()\n\tmaxHeight\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tif (this.minWidth) {\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t} else {\n\t\t\tthis.minWidth = this.drawerMinWidth.sheet\n\t\t}\n\t}\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tsuper.updated(changedProperties)\n\t\tif (changedProperties.has('minWidth') && this.minWidth) {\n\t\t\t// If the 'minWidth' property changed\n\t\t\tthis.drawerMinWidth.sheet = this.minWidth\n\t\t\tthis.dispatchEvent(new CustomEvent(SchmancyEvents.ContentDrawerResize, { bubbles: true, composed: true }))\n\t\t} else if (changedProperties.has('state') || changedProperties.has('mode')) {\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\t// Overlay open logic if needed\n\t\t\t\t\t// this.open()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tsheet.dismiss(this.schmancyContentDrawerID)\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.closeAll()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.open()\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Open the sheet by sliding it into view.\n\t */\n\topen() {\n\t\t// \"onBegin\" logic from the old `animate(...)`\n\t\tif (this.mode === 'overlay') {\n\t\t\tthis.sheet.style.position = 'fixed'\n\t\t} else {\n\t\t\tthis.sheet.style.position = 'relative'\n\t\t}\n\t\tthis.sheet.style.display = 'block'\n\n\t\t// --- 2) Use native Web Animations API ---\n\t\tthis.sheet.animate(\n\t\t\t[\n\t\t\t\t{ opacity: 0, transform: 'translateX(100%)' },\n\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t],\n\t\t\t{\n\t\t\t\tduration: 500,\n\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t},\n\t\t)\n\t\t// No return is needed if you don't rely on the result\n\t}\n\n\t/**\n\t * Close everything (modal sheet + the sheet itself).\n\t */\n\tcloseAll() {\n\t\t// Merge them into a single subscription,\n\t\t// so that everything closes in parallel.\n\t\tmerge(from(this.closeModalSheet()), from(this.closeSheet())).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\t/**\n\t * Dismiss the \"modal sheet.\"\n\t * This just returns an Observable that completes immediately.\n\t */\n\tcloseModalSheet() {\n\t\treturn of(true).pipe(tap(() => sheet.dismiss(this.schmancyContentDrawerID)))\n\t}\n\n\t/**\n\t * Slide the sheet out of view + hide it.\n\t * Return an Observable so we can merge it with other close operations.\n\t */\n\tcloseSheet() {\n\t\t// --- 2) Use native Web Animations API and wrap in an Observable ---\n\t\treturn new Observable<void>(observer => {\n\t\t\tconst animation = this.sheet.animate(\n\t\t\t\t[\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(0%)' },\n\t\t\t\t\t{ opacity: 1, transform: 'translateX(100%)' },\n\t\t\t\t],\n\t\t\t\t{\n\t\t\t\t\tduration: 500,\n\t\t\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\t\t},\n\t\t\t)\n\n\t\t\tanimation.onfinish = () => {\n\t\t\t\t// \"onComplete\" logic\n\t\t\t\tthis.sheet.style.display = 'none'\n\t\t\t\tobserver.next()\n\t\t\t\tobserver.complete()\n\t\t\t}\n\t\t})\n\t}\n\n\tprotected render() {\n\t\tconst sheetClasses = {\n\t\t\tblock: this.mode === 'push',\n\t\t\t'absolute z-50': this.mode === 'overlay',\n\t\t\t'opacity-1': this.mode === 'overlay' && this.state === 'open',\n\t\t}\n\n\t\tconst styles = {\n\t\t\tminWidth: `${this.minWidth}px`,\n\t\t\tmaxHeight: this.maxHeight,\n\t\t}\n\n\t\treturn html`\n\t\t\t<section id=\"sheet\" class=\"${this.classMap(sheetClasses)}\" style=${this.styleMap(styles)}>\n\t\t\t\t<schmancy-area name=\"${this.schmancyContentDrawerID}\">\n\t\t\t\t\t<slot name=\"placeholder\"></slot>\n\t\t\t\t</schmancy-area>\n\t\t\t</section>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-content-drawer-sheet': SchmancyContentDrawerSheet\n\t}\n}\n","import { SchmancyEvents } from '@schmancy/types/events'\nimport { debounceTime, distinctUntilKeyChanged, Subject } from 'rxjs'\n\nclass Drawer {\n\tprivate $drawer = new Subject<{\n\t\tself: HTMLElement\n\t\tstate: boolean\n\t}>()\n\tconstructor() {\n\t\tthis.$drawer.pipe(distinctUntilKeyChanged('state'), debounceTime(100)).subscribe(data => {\n\t\t\tconsole.log('drawer', data)\n\t\t\tif (data.state) {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'open',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t} else {\n\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\tstate: 'close',\n\t\t\t\t\t\t},\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}\n\t\t})\n\t}\n\topen(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: true,\n\t\t})\n\t}\n\tclose(self?: HTMLElement) {\n\t\tthis.$drawer.next({\n\t\t\tself,\n\t\t\tstate: false,\n\t\t})\n\t}\n}\n\nexport const schmancyNavDrawer = new Drawer()\nconst $drawer = schmancyNavDrawer\n\nexport { $drawer }\n","import { createContext } from '@lit/context'\nexport type TSchmancyDrawerNavbarMode = 'push' | 'overlay' | undefined\nexport const SchmancyDrawerNavbarMode = createContext<TSchmancyDrawerNavbarMode>('push')\n\nexport type TSchmancyDrawerNavbarState = 'open' | 'close' | undefined\nexport const SchmancyDrawerNavbarState = createContext<TSchmancyDrawerNavbarState>('close')\n","import { consume } from '@lit/context'\nimport { TailwindElement } from '@mixins/index'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n} from '@schmancy/nav-drawer/context'\nimport { css, html } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyEvents } from '..'\n\n/**\n * @element schmancy-nav-drawer-appbar\n * @slot toggler - The toggler slot\n * @slot - The default slot\n */\n@customElement('schmancy-nav-drawer-appbar')\nexport class SchmancyDrawerAppbar extends TailwindElement(css`\n\t:host {\n\t\tdisplay: block;\n\t}\n`) {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tsidebarMode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tsidebarOpen\n\n\t@property({ type: Boolean }) toggler = true\n\n\trender() {\n\t\tconst appbarClasses = {\n\t\t\t'block z-50': true,\n\t\t}\n\t\tconst sidebarToggler = {\n\t\t\t'block left-3 z-50': this.sidebarMode === 'overlay',\n\t\t\thidden: this.sidebarMode === 'push',\n\t\t}\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.sidebarMode === 'overlay' && this.toggler ? 'auto 1fr' : '1fr'}\n\t\t\t\tflow=\"col\"\n\t\t\t\tclass=${this.classMap(appbarClasses)}\n\t\t\t\tgap=\"sm\"\n\t\t\t\talign=\"center\"\n\t\t\t>\n\t\t\t\t${when(\n\t\t\t\t\tthis.sidebarMode === 'overlay' && this.toggler,\n\t\t\t\t\t() =>\n\t\t\t\t\t\thtml`<slot name=\"toggler\">\n\t\t\t\t\t\t\t<div class=\"${this.classMap(sidebarToggler)}\">\n\t\t\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\t\t\t\t\t\tdetail: { state: this.sidebarOpen === 'open' ? 'close' : 'open' },\n\t\t\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t${when(\n\t\t\t\t\t\t\t\t\t\tthis.sidebarOpen === 'close',\n\t\t\t\t\t\t\t\t\t\t() => html`menu`,\n\t\t\t\t\t\t\t\t\t\t() => html`menu_open`,\n\t\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</slot>`,\n\t\t\t\t)}\n\n\t\t\t\t<slot> </slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-appbar': SchmancyDrawerAppbar\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n@customElement('schmancy-nav-drawer-content')\nexport class SchmancyNavigationDrawerContent extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t\tinset: 0;\n\t\toverflow-y: auto;\n\t}\n`) {\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent(this, 'scroll')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe(e => {\n\t\t\t\tthis.parentElement.dispatchEvent(new CustomEvent('scroll', { detail: e, bubbles: true, composed: true }))\n\t\t\t})\n\t}\n\trender() {\n\t\treturn html` <slot></slot> `\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-content': SchmancyNavigationDrawerContent\n\t}\n}\n","import { provide } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { css, html, nothing } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\nimport { debounceTime, distinctUntilChanged, fromEvent, map, startWith, takeUntil, tap } from 'rxjs'\nimport { SchmancyEvents } from '..'\nimport { fullHeight } from './../directives/height'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n/**\n * @element schmancy-nav-drawer\n * @slot appbar - The appbar slot\n * @slot - The content slot\n */\n@customElement('schmancy-nav-drawer')\nexport class SchmancyNavigationDrawer extends $LitElement(css`\n\t:host {\n\t\tdisplay: flex;\n\t\tflex-grow: 1;\n\t\toverflow: hidden;\n\t}\n`) {\n\t// fullscreen property\n\t@property({ type: Boolean })\n\tfullscreen: boolean = false\n\n\t/**\n\t * The minimum width of the sidebar\n\t * @attr\tbreakpoint\n\t * @type {number}\n\t * @memberof SchmancyNavigationDrawer\n\t */\n\t@property({ type: Number, attribute: 'breakpoint' })\n\tbreakpoint: number = 768\n\n\t/**\n\t * The mode of the sidebar\n\t * @type {TSchmancyDrawerNavbarMode}\n\t * @memberof SchmancyNavigationDrawer\n\t * @protected\n\t */\n\t@provide({ context: SchmancyDrawerNavbarMode })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@provide({ context: SchmancyDrawerNavbarState })\n\t@property()\n\topen: TSchmancyDrawerNavbarState\n\n\tconnectedCallback(): void {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(window, 'resize')\n\t\t\t.pipe(\n\t\t\t\tmap(event => event.target as Window),\n\t\t\t\tstartWith(window),\n\t\t\t\tmap(window => window.innerWidth),\n\t\t\t\tmap(width => width >= this.breakpoint),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(lgScreen => {\n\t\t\t\tif (lgScreen) {\n\t\t\t\t\tthis.mode = 'push'\n\t\t\t\t\tthis.open = 'open'\n\t\t\t\t} else {\n\t\t\t\t\tthis.mode = 'overlay'\n\t\t\t\t\tthis.open = 'close'\n\t\t\t\t}\n\t\t\t})\n\n\t\t/*\n\t\t * Listen to the toggle event\n\t\t */\n\t\tfromEvent<CustomEvent>(window, SchmancyEvents.NavDrawer_toggle)\n\t\t\t.pipe(\n\t\t\t\ttap(event => {\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t}),\n\t\t\t\tmap(event => event.detail.state),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tdebounceTime(100),\n\t\t\t)\n\t\t\t.subscribe(state => {\n\t\t\t\t// if the mode is push, we don't need to close the overlay when the state is close\n\t\t\t\tif (this.mode === 'push' && state === 'close') return\n\t\t\t\tthis.open = state\n\t\t\t})\n\t}\n\n\tprotected render() {\n\t\tif (!this.mode || !this.open) return nothing\n\t\treturn html`\n\t\t\t<schmancy-grid\n\t\t\t\tcols=${this.fullscreen ? '1fr' : 'auto 1fr'}\n\t\t\t\trows=\"1fr\"\n\t\t\t\tflow=\"col\"\n\t\t\t\tjustify=\"stretch\"\n\t\t\t\talign=\"stretch\"\n\t\t\t\t${fullHeight()}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</schmancy-grid>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer': SchmancyNavigationDrawer\n\t}\n}\n","import { consume } from '@lit/context'\nimport { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\nimport { SchmancyEvents, SchmancyTheme, color } from '..'\nimport {\n\tSchmancyDrawerNavbarMode,\n\tSchmancyDrawerNavbarState,\n\tTSchmancyDrawerNavbarMode,\n\tTSchmancyDrawerNavbarState,\n} from './context'\n\n@customElement('schmancy-nav-drawer-navbar')\nexport class SchmancyNavigationDrawerSidebar extends $LitElement() {\n\t@consume({ context: SchmancyDrawerNavbarMode, subscribe: true })\n\t@state()\n\tmode: TSchmancyDrawerNavbarMode\n\n\t@consume({ context: SchmancyDrawerNavbarState, subscribe: true })\n\t@state()\n\tprivate state: TSchmancyDrawerNavbarState\n\n\t@query('#overlay') overlay!: HTMLElement\n\t@query('nav') nav!: HTMLElement\n\n\t@property({ type: String }) width = '320px'\n\n\tupdated(changedProperties: Map<string, any>) {\n\t\tif (changedProperties.has('state')) {\n\t\t\tconsole.log('state changed', this.state, this.mode)\n\t\t\tif (this.mode === 'overlay') {\n\t\t\t\tif (this.state === 'close') {\n\t\t\t\t\tthis.hideNavDrawer()\n\t\t\t\t\tthis.closeOverlay()\n\t\t\t\t} else if (this.state === 'open') {\n\t\t\t\t\tthis.openOverlay()\n\t\t\t\t\tthis.showNavDrawer()\n\t\t\t\t}\n\t\t\t} else if (this.mode === 'push') {\n\t\t\t\tthis.showNavDrawer()\n\t\t\t\tthis.closeOverlay()\n\t\t\t}\n\t\t}\n\t}\n\n\topenOverlay() {\n\t\t// Equivalent to onBegin\n\t\tthis.overlay.style.display = 'block'\n\n\t\t// Animate opacity from 0 to 0.4\n\t\tthis.overlay.animate([{ opacity: 0 }, { opacity: 0.4 }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards', // <-- This keeps the final keyframe (0.4) after finishing\n\t\t})\n\t\t// If you want an onfinish here, you can add it:\n\t\t// .onfinish = () => console.log('overlay opened!')\n\t}\n\n\tcloseOverlay() {\n\t\t// Animate opacity from 0.4 to 0\n\t\tconst animation = this.overlay.animate([{ opacity: 0.4 }, { opacity: 0 }], {\n\t\t\tduration: 150,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\t// translateX(-100%) when the animation is finished\n\t\t// Equivalent to onComplete\n\t\tanimation.onfinish = () => {\n\t\t\tthis.overlay.style.display = 'none'\n\t\t}\n\t}\n\n\t// show nav drawer\n\tshowNavDrawer() {\n\t\t// check the transform, skip if already open\n\t\tif (this.nav.style.transform === 'translateX(0)') return\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(-100%)' }, { transform: 'translateX(0)' }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.state = 'open'\n\t\t}\n\t}\n\n\t// hide nav drawer\n\thideNavDrawer() {\n\t\t// skip if already closed\n\t\tif (this.nav.style.transform === 'translateX(-100%)') return\n\t\tconst animation = this.nav.animate([{ transform: 'translateX(0)' }, { transform: 'translateX(-100%)' }], {\n\t\t\tduration: 200,\n\t\t\teasing: 'cubic-bezier(0.5, 0.01, 0.25, 1)',\n\t\t\tfill: 'forwards',\n\t\t})\n\t\tanimation.onfinish = () => {\n\t\t\tthis.state = 'close'\n\t\t}\n\t}\n\n\tprotected render() {\n\t\tconst sidebarClasses = {\n\t\t\t'p-[16px] max-w-[360px] w-fit h-full overflow-auto': true,\n\t\t\tblock: this.mode === 'push',\n\t\t\t'fixed inset-0 z-50': this.mode === 'overlay',\n\t\t}\n\t\tconst overlayClass = {\n\t\t\t'fixed inset-0 z-49 hidden': true,\n\t\t}\n\n\t\tconst styleMap = {\n\t\t\twidth: this.width,\n\t\t}\n\n\t\treturn html`\n\t\t\t<nav\n\t\t\t\tstyle=${this.styleMap(styleMap)}\n\t\t\t\tclass=\"${this.classMap({ ...sidebarClasses })}\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.container,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t<slot></slot>\n\t\t\t</nav>\n\t\t\t<div\n\t\t\t\tid=\"overlay\"\n\t\t\t\t${color({\n\t\t\t\t\tbgColor: SchmancyTheme.sys.color.scrim,\n\t\t\t\t})}\n\t\t\t\t@click=${() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SchmancyEvents.NavDrawer_toggle, {\n\t\t\t\t\t\t\tdetail: { state: 'close' },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t\t}}\n\t\t\t\tclass=\"${this.classMap({ ...overlayClass })}\"\n\t\t\t></div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-nav-drawer-navbar': SchmancyNavigationDrawerSidebar\n\t}\n}\n","import { bufferTime, concatMap, filter, fromEvent, map, of, Subject, take, tap, timeout, zip } from 'rxjs'\nimport { SchmancyTeleportation } from './teleport.component'\n\nexport type WhereAreYouRickyEvent = CustomEvent<{\n\tid: string\n\tcallerID: number\n}>\n\nexport const WhereAreYouRicky = 'whereAreYouRicky'\n\nexport type HereMortyEvent = CustomEvent<{\n\tcomponent: SchmancyTeleportation\n}>\n\nexport type FLIP_REQUEST = {\n\tfrom: {\n\t\trect: DOMRect\n\t\telement?: HTMLElement\n\t}\n\tto: {\n\t\trect: DOMRect\n\t\telement: HTMLElement\n\t}\n\tstagger?: number\n\thost: HTMLElement\n}\nexport const HereMorty = 'hereMorty'\n\nclass Teleportation {\n\tactiveTeleportations = new Map<string, DOMRect>()\n\tflipRequests = new Subject<FLIP_REQUEST>()\n\n\tconstructor() {\n\t\tthis.flipRequests\n\t\t\t.pipe(\n\t\t\t\tbufferTime(1),\n\t\t\t\tmap(requests =>\n\t\t\t\t\trequests.map(({ from, to, host }, i) => ({\n\t\t\t\t\t\tfrom,\n\t\t\t\t\t\tto,\n\t\t\t\t\t\thost,\n\t\t\t\t\t\ti,\n\t\t\t\t\t})),\n\t\t\t\t),\n\t\t\t\tconcatMap(requests => zip(requests.map(request => of(this.flip(request))))),\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tfind = (component: SchmancyTeleportation) => {\n\t\treturn zip([\n\t\t\tfromEvent<HereMortyEvent>(window, HereMorty).pipe(\n\t\t\t\tfilter(\n\t\t\t\t\te =>\n\t\t\t\t\t\t!!e.detail.component.uuid &&\n\t\t\t\t\t\t!!component.id &&\n\t\t\t\t\t\te.detail.component.id === component.id &&\n\t\t\t\t\t\te.detail.component.uuid !== component.uuid,\n\t\t\t\t),\n\t\t\t\tmap(e => e.detail.component),\n\t\t\t\ttake(1),\n\t\t\t),\n\t\t\tof(component).pipe(\n\t\t\t\ttap(() => {\n\t\t\t\t\twindow.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent<WhereAreYouRickyEvent['detail']>(WhereAreYouRicky, {\n\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\tid: component.id,\n\t\t\t\t\t\t\t\tcallerID: component.uuid,\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]).pipe(\n\t\t\tmap(([component]) => component),\n\t\t\ttimeout(0),\n\t\t)\n\t}\n\n\tflip = (request: {\n\t\tfrom: {\n\t\t\trect: DOMRect\n\t\t}\n\t\tto: {\n\t\t\telement: HTMLElement\n\t\t\trect: DOMRect\n\t\t}\n\t\thost: HTMLElement\n\t\ti: number\n\t}) => {\n\t\tconst { from, to } = request\n\n\t\t// Prepare the element for animation\n\t\tconst originalZIndex = to.element.style.zIndex\n\t\tto.element.style.transformOrigin = 'top left'\n\t\tto.element.style.setProperty('visibility', 'visible')\n\t\tto.element.style.zIndex = '1000'\n\n\t\t// \"onBegin\" logic goes here (since Web Animations doesn't have onBegin).\n\t\t// If you had more logic, place it here:\n\t\t// e.g., console.log('Starting FLIP animation...');\n\n\t\t// Calculate starting and ending transforms\n\t\tconst startX = from.rect.left - to.rect.left\n\t\tconst startY = from.rect.top - to.rect.top\n\t\tconst startScaleX = from.rect.width / to.rect.width\n\t\tconst startScaleY = from.rect.height / to.rect.height\n\n\t\t// Create keyframes\n\t\tconst keyframes: Keyframe[] = [\n\t\t\t{\n\t\t\t\ttransform: `translate(${startX}px, ${startY}px) scale(${startScaleX}, ${startScaleY})`,\n\t\t\t},\n\t\t\t{\n\t\t\t\ttransform: 'translate(0, 0) scale(1, 1)',\n\t\t\t},\n\t\t]\n\n\t\t// Use native Web Animations API\n\t\tconst animation = to.element.animate(keyframes, {\n\t\t\tduration: 250,\n\t\t\tdelay: 10, // if desired\n\t\t\t// Approximate 'inOutQuad' via a cubic-bezier easing.\n\t\t\t// You can adjust these values to taste, or use a standard one:\n\t\t\teasing: 'cubic-bezier(0.455, 0.03, 0.515, 0.955)',\n\t\t\t// or simply 'ease-in-out'\n\t\t})\n\n\t\t// \"onComplete\" logic goes here\n\t\tanimation.onfinish = () => {\n\t\t\tto.element.style.zIndex = originalZIndex\n\t\t\tto.element.style.transformOrigin = ''\n\t\t\t// If you have additional cleanup, place it here\n\t\t\t// e.g., console.log('FLIP animation completed!');\n\t\t}\n\t}\n}\n\nexport const teleport = new Teleportation()\nexport default teleport\n","import { Observable, interval } from 'rxjs'\nimport { distinctUntilChanged, map, take } from 'rxjs/operators'\n\n// Function to monitor element's bounding client rect\nexport function watchElementRect(element: Element): Observable<DOMRectReadOnly> {\n\treturn interval(50).pipe(\n\t\t// startWith(true),\n\t\tmap(() => element.getBoundingClientRect()),\n\t\tdistinctUntilChanged(\n\t\t\t(prev, curr) =>\n\t\t\t\tprev.width === curr.width &&\n\t\t\t\tprev.height === curr.height &&\n\t\t\t\tprev.top === curr.top &&\n\t\t\t\tprev.right === curr.right &&\n\t\t\t\tprev.bottom === curr.bottom &&\n\t\t\t\tprev.left === curr.left,\n\t\t),\n\t\ttake(1),\n\t)\n}\n","import { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { filter, fromEvent, merge, of, takeUntil, tap, throwIfEmpty } from 'rxjs'\nimport { FINDING_MORTIES, FINDING_MORTIES_EVENT, HERE_RICKY, HERE_RICKY_EVENT } from '..'\nimport {\n\tHereMorty,\n\tHereMortyEvent,\n\tWhereAreYouRicky,\n\tWhereAreYouRickyEvent,\n\tdefault as teleport,\n\tdefault as teleportationService,\n} from './teleport.service'\nimport { watchElementRect } from './watcher'\nimport { $LitElement } from '@mixins/index'\n@customElement('schmancy-teleport')\nexport class SchmancyTeleportation extends $LitElement(css``) {\n\t/**\n\t * @attr {string} uuid - The component tag to teleport\n\t * @readonly\n\t */\n\t@property({ type: Number, reflect: true }) uuid = Math.floor(Math.random() * Date.now())\n\n\t/**\n\t * @attr {string} id - The component tag to teleport\n\t * @required\n\t */\n\t@property({ type: String }) id!: string\n\n\t@property({ type: Number }) delay = 0\n\n\tdebugging = import.meta.env.DEV ? true : false\n\n\tget _slottedChildren() {\n\t\tconst slot = this.shadowRoot.querySelector('slot')\n\t\treturn slot.assignedElements({ flatten: true })\n\t}\n\n\tconnectedCallback(): void {\n\t\tif (this.id === undefined) throw new Error('id is required')\n\t\tsuper.connectedCallback()\n\t\tmerge(\n\t\t\tfromEvent<FINDING_MORTIES_EVENT>(window, FINDING_MORTIES).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: () => {\n\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\tnew CustomEvent<HERE_RICKY_EVENT['detail']>(HERE_RICKY, {\n\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\tcomposed: true,\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\tfromEvent<WhereAreYouRickyEvent>(window, WhereAreYouRicky).pipe(\n\t\t\t\ttap({\n\t\t\t\t\tnext: e => {\n\t\t\t\t\t\tif (e.detail.id === this.id && this.uuid && e.detail.callerID !== this.uuid) {\n\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\tnew CustomEvent<HereMortyEvent['detail']>(HereMorty, {\n\t\t\t\t\t\t\t\t\tdetail: {\n\t\t\t\t\t\t\t\t\t\tcomponent: this,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t}),\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)\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe()\n\t}\n\n\tasync firstUpdated() {\n\t\tof(teleportationService.activeTeleportations.get(this.id))\n\t\t\t.pipe(\n\t\t\t\tfilter(a => !!a),\n\t\t\t\ttakeUntil(this.disconnecting),\n\t\t\t\tthrowIfEmpty(),\n\t\t\t)\n\t\t\t.subscribe({\n\t\t\t\tnext: domRect => {\n\t\t\t\t\tconsole.count('teleport')\n\t\t\t\t\tthis.style.setProperty('visibility', 'hidden')\n\t\t\t\t\t// teleport.flipRequests.next({ from: component, to: this, stagger: 0 })\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\t// console.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t\tteleport.flipRequests.next({\n\t\t\t\t\t\t\t\t\tfrom: {\n\t\t\t\t\t\t\t\t\t\trect: domRect,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\tto: {\n\t\t\t\t\t\t\t\t\t\trect: e,\n\t\t\t\t\t\t\t\t\t\telement: this._slottedChildren[0] as HTMLElement,\n\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\thost: this,\n\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\terror: () => {\n\t\t\t\t\tthis.style.setProperty('visibility', 'visible')\n\t\t\t\t\twatchElementRect(this)\n\t\t\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t\t\t.subscribe({\n\t\t\t\t\t\t\tnext: e => {\n\t\t\t\t\t\t\t\tconsole.log(e)\n\t\t\t\t\t\t\t\tteleportationService.activeTeleportations.set(this.id, e)\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t})\n\t\t\t\t},\n\t\t\t\tcomplete: () => {},\n\t\t\t})\n\t}\n\n\trender() {\n\t\treturn html`<slot></slot>`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-teleport': SchmancyTeleportation\n\t}\n}\n"],"names":["SchmancyCardMedia","TailwindElement","css","html","customElement","SchmancyCard","super","arguments","this","type","elevation","classes","includes","classMap","__decorateClass","property","prototype","Number","SchmancyCardContent","onSurface","SchmancyTheme","sys","color","surface","on","onSurfaceVariant","onVariant","src","fit","styleMap","height","String","reflect","schmancyContentDrawer","$drawer","Subject","pipe","subscribe","data","action","ref","dispatchEvent","CustomEvent","SchmancyEvents","ContentDrawerToggle","detail","state","bubbles","composed","component","title","next","t","SchmancyContentDrawerSheetMode","createContext","SchmancyContentDrawerSheetState","SchmancyContentDrawerID","n","Math","floor","random","Date","now","toString","SchmancyContentDrawerMaxHeight","SchmancyContentDrawerMinWidth","SchmancyContentDrawer","$LitElement","constructor","minWidth","main","sheet","schmancyContentDrawerID","maxHeight","merge","fromEvent","window","ContentDrawerResize","startWith","tap","map","clientWidth","innerWidth","width","debounceTime","innerHeight","getOffsetTop","style","setProperty","distinctUntilChanged","takeUntil","disconnecting","lgScreen","mode","open","event","stopPropagation","area","push","historyStrategy","uid","element","offsetTop","offsetParent","render","nothing","provide","context","queryAssignedElements","flatten","SchmancyContentDrawerMain","connectedCallback","drawerMinWidth","changedProperties","update","has","styles","when","consume","SchmancyContentDrawerSheet","updated","closeAll","dismiss","position","display","animate","opacity","transform","duration","easing","from","closeModalSheet","closeSheet","of","Observable","observer","onfinish","complete","sheetClasses","block","query","slot","schmancyNavDrawer","distinctUntilKeyChanged","NavDrawer_toggle","self","SchmancyDrawerNavbarMode","SchmancyDrawerNavbarState","SchmancyDrawerAppbar","toggler","sidebarToggler","sidebarMode","hidden","sidebarOpen","Boolean","SchmancyNavigationDrawerContent","e","parentElement","SchmancyNavigationDrawer","fullscreen","breakpoint","target","fullHeight","attribute","SchmancyNavigationDrawerSidebar","hideNavDrawer","closeOverlay","openOverlay","showNavDrawer","overlay","fill","nav","sidebarClasses","bgColor","container","scrim","WhereAreYouRicky","HereMorty","teleport","activeTeleportations","Map","flipRequests","find","zip","filter","uuid","id","take","callerID","timeout","flip","request","to","originalZIndex","zIndex","transformOrigin","keyframes","rect","left","top","delay","bufferTime","requests","host","i","concatMap","watchElementRect","interval","getBoundingClientRect","prev","curr","right","bottom","SchmancyTeleportation","debugging","shadowRoot","querySelector","assignedElements","Error","FINDING_MORTIES","HERE_RICKY","teleportationService","get","a","throwIfEmpty","domRect","set","_slottedChildren","error"],"mappings":"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"}
package/dist/teleport.js CHANGED
@@ -1,4 +1,4 @@
1
- import { H as r, o as t, W as a, t as s } from "./teleport.component-Dose4RDi.js";
1
+ import { H as r, o as t, W as a, t as s } from "./teleport.component-DldJv9J6.js";
2
2
  export {
3
3
  r as HereMorty,
4
4
  t as SchmancyTeleportation,
@@ -1,4 +1,4 @@
1
- "use strict";const d=require("./ripple-C2BHbhcS.cjs"),l=require("./theme.interface-Xg5Zi46a.cjs"),c=require("lit"),r=require("lit/decorators.js"),p=require("lit/directives/if-defined.js"),m=require("lit/directives/ref.js"),f=require("lit/directives/when.js"),o=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const g=require("./tailwind.mixin-DYx3IacW.cjs");var x=Object.defineProperty,b=Object.getOwnPropertyDescriptor,i=(e,a,h,s)=>{for(var u,n=s>1?void 0:s?b(a,h):a,y=e.length-1;y>=0;y--)(u=e[y])&&(n=(s?u(a,h,n):u(n))||n);return s&&n&&x(a,h,n),n};let t=class extends g.TailwindElement(":host{border:unset!important;line-height:unset!important;background:unset!important;padding:unset!important;font-size:unset!important;box-shadow:unset!important;width:-webkit-fill-available}:host:focus{box-shadow:unset!important}textarea:focus-visible{outline:none!important}textarea{font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;text-decoration:inherit;text-indent:inherit;text-shadow:inherit;text-overflow:inherit;text-rendering:inherit;text-size-adjust:inherit;text-align-last:inherit;resize:none;overflow-y:auto}@keyframes onAutoFillStart{}textarea:-webkit-autofill{animation-name:onAutoFillStart}"){constructor(){super(),this.textareaRef=m.createRef(),this.label="",this.name="name_"+Date.now(),this.placeholder="",this.value="",this.cols=20,this.rows=2,this.wrap="soft",this.required=!1,this.disabled=!1,this.readonly=!1,this.spellcheck=!1,this.align="left",this.tabIndex=0,this.error=!1;try{this.internals=this.attachInternals()}catch{this.internals=void 0}}firstUpdated(){this.autofocus&&this.focus(),o.fromEvent(this.textareaElement,"input").pipe(o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0}))}),o.fromEvent(this.textareaElement,"change").pipe(o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0}))}),o.fromEvent(this.textareaElement,"keyup").pipe(o.filter(e=>e.key==="Enter"),o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0})),this.dispatchEvent(new CustomEvent("enter",{detail:{value:e},bubbles:!0,composed:!0}))})}get form(){var e;return(e=this.internals)==null?void 0:e.form}reportValidity(){var e;return(e=this.textareaRef.value)==null?void 0:e.reportValidity()}checkValidity(){var e;return(e=this.textareaRef.value)==null?void 0:e.checkValidity()}setCustomValidity(e){var a;return(a=this.textareaRef.value)==null?void 0:a.setCustomValidity(e)}select(){var e;return(e=this.textareaRef.value)==null?void 0:e.select()}setSelectionRange(e,a,h){var s;(s=this.textareaRef.value)==null||s.setSelectionRange(e,a,h)}get selectionStart(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionStart)??null}get selectionEnd(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionEnd)??null}get selectionDirection(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionDirection)??null}setRangeText(e){var a;(a=this.textareaRef.value)==null||a.setRangeText(e)}adjustHeight(){const e=this.textareaRef.value;e&&(e.style.height="auto",e.style.height=e.scrollHeight+"px")}validity(){var e;return(e=this.textareaRef.value)==null?void 0:e.validity}focus(e={preventScroll:!0}){var a;(a=this.textareaRef.value)==null||a.focus(e),this.dispatchEvent(new Event("focus"))}click(){var e;(e=this.textareaRef.value)==null||e.click(),this.dispatchEvent(new Event("click"))}blur(){var e;(e=this.textareaRef.value)==null||e.blur(),this.dispatchEvent(new Event("blur"))}render(){const e={"w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]":!0,"disabled:opacity-40 disabled:cursor-not-allowed":!0,"placeholder:text-muted":!0,"ring-0 ring-inset focus:ring-1 focus:ring-inset":!0,"ring-primary-default ring-outline focus:ring-primary-default":!this.error,"ring-error-default focus:ring-error-default":this.error,"text-center":this.align==="center","text-right":this.align==="right"},a={"opacity-40":this.disabled,"block mb-[4px]":!0};return c.html`
1
+ "use strict";const d=require("./ripple-C2BHbhcS.cjs"),l=require("./theme.interface-Xg5Zi46a.cjs"),c=require("lit"),r=require("lit/decorators.js"),p=require("lit/directives/if-defined.js"),m=require("lit/directives/ref.js"),f=require("lit/directives/when.js"),o=require("rxjs");require("lit/directives/class-map.js"),require("lit/directives/style-map.js");const g=require("./tailwind.mixin-gE-6eUQA.cjs");var x=Object.defineProperty,b=Object.getOwnPropertyDescriptor,i=(e,a,h,s)=>{for(var u,n=s>1?void 0:s?b(a,h):a,y=e.length-1;y>=0;y--)(u=e[y])&&(n=(s?u(a,h,n):u(n))||n);return s&&n&&x(a,h,n),n};let t=class extends g.TailwindElement(":host{border:unset!important;line-height:unset!important;background:unset!important;padding:unset!important;font-size:unset!important;box-shadow:unset!important;width:-webkit-fill-available}:host:focus{box-shadow:unset!important}textarea:focus-visible{outline:none!important}textarea{font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;text-decoration:inherit;text-indent:inherit;text-shadow:inherit;text-overflow:inherit;text-rendering:inherit;text-size-adjust:inherit;text-align-last:inherit;resize:none;overflow-y:auto}@keyframes onAutoFillStart{}textarea:-webkit-autofill{animation-name:onAutoFillStart}"){constructor(){super(),this.textareaRef=m.createRef(),this.label="",this.name="name_"+Date.now(),this.placeholder="",this.value="",this.cols=20,this.rows=2,this.wrap="soft",this.required=!1,this.disabled=!1,this.readonly=!1,this.spellcheck=!1,this.align="left",this.tabIndex=0,this.error=!1;try{this.internals=this.attachInternals()}catch{this.internals=void 0}}firstUpdated(){this.autofocus&&this.focus(),o.fromEvent(this.textareaElement,"input").pipe(o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0}))}),o.fromEvent(this.textareaElement,"change").pipe(o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0}))}),o.fromEvent(this.textareaElement,"keyup").pipe(o.filter(e=>e.key==="Enter"),o.map(e=>e.target.value),o.distinctUntilChanged()).subscribe(e=>{this.value=e,this.dispatchEvent(new CustomEvent("change",{detail:{value:e},bubbles:!0,composed:!0})),this.dispatchEvent(new CustomEvent("enter",{detail:{value:e},bubbles:!0,composed:!0}))})}get form(){var e;return(e=this.internals)==null?void 0:e.form}reportValidity(){var e;return(e=this.textareaRef.value)==null?void 0:e.reportValidity()}checkValidity(){var e;return(e=this.textareaRef.value)==null?void 0:e.checkValidity()}setCustomValidity(e){var a;return(a=this.textareaRef.value)==null?void 0:a.setCustomValidity(e)}select(){var e;return(e=this.textareaRef.value)==null?void 0:e.select()}setSelectionRange(e,a,h){var s;(s=this.textareaRef.value)==null||s.setSelectionRange(e,a,h)}get selectionStart(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionStart)??null}get selectionEnd(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionEnd)??null}get selectionDirection(){var e;return((e=this.textareaRef.value)==null?void 0:e.selectionDirection)??null}setRangeText(e){var a;(a=this.textareaRef.value)==null||a.setRangeText(e)}adjustHeight(){const e=this.textareaRef.value;e&&(e.style.height="auto",e.style.height=e.scrollHeight+"px")}validity(){var e;return(e=this.textareaRef.value)==null?void 0:e.validity}focus(e={preventScroll:!0}){var a;(a=this.textareaRef.value)==null||a.focus(e),this.dispatchEvent(new Event("focus"))}click(){var e;(e=this.textareaRef.value)==null||e.click(),this.dispatchEvent(new Event("click"))}blur(){var e;(e=this.textareaRef.value)==null||e.blur(),this.dispatchEvent(new Event("blur"))}render(){const e={"w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]":!0,"disabled:opacity-40 disabled:cursor-not-allowed":!0,"placeholder:text-muted":!0,"ring-0 ring-inset focus:ring-1 focus:ring-inset":!0,"ring-primary-default ring-outline focus:ring-primary-default":!this.error,"ring-error-default focus:ring-error-default":this.error,"text-center":this.align==="center","text-right":this.align==="right"},a={"opacity-40":this.disabled,"block mb-[4px]":!0};return c.html`
2
2
  ${f.when(this.label,()=>c.html`<label
3
3
  ${d.color({color:this.error?l.SchmancyTheme.sys.color.error.default:l.SchmancyTheme.sys.color.primary.default})}
4
4
  class="${this.classMap(a)}"
@@ -39,4 +39,4 @@
39
39
  </schmancy-typography>
40
40
  `)}
41
41
  `}};t.shadowRootOptions={...c.LitElement.shadowRootOptions,delegatesFocus:!0},t.formAssociated=!0,i([r.property()],t.prototype,"label",2),i([r.property()],t.prototype,"name",2),i([r.property()],t.prototype,"placeholder",2),i([r.property({type:String,reflect:!0})],t.prototype,"value",2),i([r.property({type:Number})],t.prototype,"minlength",2),i([r.property({type:Number})],t.prototype,"maxlength",2),i([r.property({type:Number})],t.prototype,"cols",2),i([r.property({type:Number})],t.prototype,"rows",2),i([r.property({type:String})],t.prototype,"wrap",2),i([r.property({type:String})],t.prototype,"dirname",2),i([r.property({type:Boolean,reflect:!0})],t.prototype,"required",2),i([r.property({type:Boolean,reflect:!0})],t.prototype,"disabled",2),i([r.property({type:Boolean,reflect:!0})],t.prototype,"readonly",2),i([r.property({type:Boolean,reflect:!0})],t.prototype,"spellcheck",2),i([r.property({type:String,reflect:!0})],t.prototype,"align",2),i([r.property({type:Boolean})],t.prototype,"autofocus",2),i([r.property({type:Number})],t.prototype,"tabIndex",2),i([r.query("textarea")],t.prototype,"textareaElement",2),i([r.property()],t.prototype,"hint",2),i([r.property({type:Boolean,reflect:!0})],t.prototype,"error",2),t=i([r.customElement("schmancy-textarea")],t);
42
- //# sourceMappingURL=textarea-DHrkcyt8.cjs.map
42
+ //# sourceMappingURL=textarea-Cm_0BDw5.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"textarea-DHrkcyt8.cjs","sources":["../src/textarea/textarea.ts"],"sourcesContent":["import { color } from '@schmancy/directives'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { LitElement, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { when } from 'lit/directives/when.js'\nimport { distinctUntilChanged, filter, fromEvent, map } from 'rxjs'\nimport style from './textarea.scss?inline'\nimport { TailwindElement } from '@mixins/index'\n@customElement('schmancy-textarea')\nexport default class SchmancyTextarea extends TailwindElement(style) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\tstatic formAssociated = true\n\t// private internals\n\tinternals: ElementInternals | undefined\n\ttextareaRef = createRef<HTMLTextAreaElement>()\n\n\t/**\n\t * The label of the control.\n\t * @attr\n\t * @type {string} label\n\t * @default ''\n\t * @public\n\t */\n\t@property() label = ''\n\n\t/**\n\t * The name of the control.\n\t * @attr name\n\t * @type {string} name\n\t * @default 'name_' + Date.now()\n\t * @public\n\t */\n\t@property() name = 'name_' + Date.now()\n\n\t/**\n\t * The placeholder of the control.\n\t * @attr placeholder\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property() placeholder = ''\n\n\t/**\n\t * The value of the control.\n\t * @attr {string} value - The value of the control.\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property({ type: String, reflect: true }) public value = ''\n\n\t/**\n\t * The minlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic minlength: number | undefined\n\n\t/**\n\t * The maxlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic maxlength!: number\n\n\t/**\n\t * The number of columns (width) of the control.\n\t * @attr cols\n\t * @type {number}\n\t * @default 20\n\t * @public\n\t */\n\t@property({ type: Number }) cols = 20\n\n\t/**\n\t * The number of rows (height) of the control.\n\t * @attr rows\n\t * @type {number}\n\t * @default 2\n\t * @public\n\t */\n\t@property({ type: Number }) rows = 2\n\n\t/**\n\t * Specifies how the text in a text area is to be wrapped when submitted in a form.\n\t * @attr wrap\n\t * @type {'hard' | 'soft'}\n\t * @default 'soft'\n\t * @public\n\t */\n\t@property({ type: String }) wrap: 'hard' | 'soft' = 'soft'\n\n\t/**\n\t * The dirname attribute of the control.\n\t * @attr dirname\n\t * @type {string}\n\t * @default undefined\n\t * @public\n\t */\n\t@property({ type: String }) dirname: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: Boolean, reflect: true }) readonly = false\n\t@property({ type: Boolean, reflect: true }) spellcheck = false\n\n\t@property({ type: String, reflect: true }) align: 'left' | 'center' | 'right' = 'left'\n\n\t/**\n\t * The autofocus attribute of the control.\n\t * @attr\n\t * @type {boolean}\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tpublic override autofocus!: boolean\n\n\t@property({ type: Number })\n\tpublic override tabIndex = 0\n\n\t@query('textarea') textareaElement!: HTMLTextAreaElement\n\n\t@property() hint: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) public error = false\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\tif (this.autofocus) {\n\t\t\tthis.focus()\n\t\t}\n\t\tfromEvent(this.textareaElement, 'input')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\tfromEvent(this.textareaElement, 'change')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\t// emit on enter\n\t\tfromEvent<KeyboardEvent>(this.textareaElement, 'keyup')\n\t\t\t.pipe(\n\t\t\t\tfilter(event => event.key === 'Enter'),\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('enter', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\t/** Checks for validity of the control and shows the browser message if it's invalid. */\n\tpublic reportValidity() {\n\t\treturn this.textareaRef.value?.reportValidity()\n\t}\n\n\t/** Checks for validity of the control and emits the invalid event if it invalid. */\n\tpublic checkValidity() {\n\t\treturn this.textareaRef.value?.checkValidity()\n\t}\n\n\t/** Sets a custom validity message. */\n\tpublic setCustomValidity(message: string) {\n\t\treturn this.textareaRef.value?.setCustomValidity(message)\n\t}\n\n\t/** Selects all text within the textarea. */\n\tpublic select() {\n\t\treturn this.textareaRef.value?.select()\n\t}\n\n\t/** Sets the selection range. */\n\tpublic setSelectionRange(start: number, end: number, direction?: 'forward' | 'backward' | 'none') {\n\t\tthis.textareaRef.value?.setSelectionRange(start, end, direction)\n\t}\n\n\t/** Returns the selected text within the textarea. */\n\tpublic get selectionStart(): number | null {\n\t\treturn this.textareaRef.value?.selectionStart ?? null\n\t}\n\n\tpublic get selectionEnd(): number | null {\n\t\treturn this.textareaRef.value?.selectionEnd ?? null\n\t}\n\n\tpublic get selectionDirection(): 'forward' | 'backward' | 'none' | null {\n\t\treturn this.textareaRef.value?.selectionDirection ?? null\n\t}\n\n\t/** Sets the range of text to be selected. */\n\tpublic setRangeText(replacement: string) {\n\t\tthis.textareaRef.value?.setRangeText(replacement)\n\t}\n\n\t/** Adjusts the height of the textarea based on its content. */\n\tpublic adjustHeight() {\n\t\tconst textarea = this.textareaRef.value\n\t\tif (textarea) {\n\t\t\ttextarea.style.height = 'auto'\n\t\t\ttextarea.style.height = textarea.scrollHeight + 'px'\n\t\t}\n\t}\n\n\tpublic validity(): ValidityState | undefined {\n\t\treturn this.textareaRef.value?.validity\n\t}\n\n\tpublic override focus(\n\t\toptions: FocusOptions = {\n\t\t\tpreventScroll: true,\n\t\t},\n\t) {\n\t\tthis.textareaRef.value?.focus(options)\n\t\tthis.dispatchEvent(new Event('focus'))\n\t}\n\n\tpublic override click() {\n\t\tthis.textareaRef.value?.click()\n\t\tthis.dispatchEvent(new Event('click'))\n\t}\n\n\tpublic override blur() {\n\t\tthis.textareaRef.value?.blur()\n\t\tthis.dispatchEvent(new Event('blur'))\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]': true,\n\t\t\t'disabled:opacity-40 disabled:cursor-not-allowed': true,\n\t\t\t'placeholder:text-muted': true,\n\t\t\t'ring-0 ring-inset focus:ring-1 focus:ring-inset': true,\n\t\t\t'ring-primary-default ring-outline focus:ring-primary-default': !this.error,\n\t\t\t'ring-error-default focus:ring-error-default': this.error,\n\t\t\t'text-center': this.align === 'center',\n\t\t\t'text-right': this.align === 'right',\n\t\t}\n\t\tconst labelClasses = {\n\t\t\t'opacity-40': this.disabled,\n\t\t\t'block mb-[4px]': true,\n\t\t}\n\t\treturn html`\n\t\t\t${when(\n\t\t\t\tthis.label,\n\t\t\t\t() =>\n\t\t\t\t\thtml`<label\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"${this.classMap(labelClasses)}\"\n\t\t\t\t\t\tfor=${this.id}\n\t\t\t\t\t>\n\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>\n\t\t\t\t\t</label>`,\n\t\t\t)}\n\n\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t<textarea\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.highest,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t\t${ref(this.textareaRef)}\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.id=${this.id}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\tclass=${this.classMap(classes)}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\tminlength=${ifDefined(this.minlength)}\n\t\t\t\t\tmaxlength=${ifDefined(this.maxlength)}\n\t\t\t\t\t.readonly=${this.readonly}\n\t\t\t\t\t.spellcheck=${this.spellcheck}\n\t\t\t\t\tcols=${ifDefined(this.cols)}\n\t\t\t\t\trows=${ifDefined(this.rows)}\n\t\t\t\t\twrap=${ifDefined(this.wrap)}\n\t\t\t\t\tdirname=${ifDefined(this.dirname)}\n\t\t\t\t></textarea>\n\t\t\t</schmancy-typography>\n\t\t\t${when(\n\t\t\t\tthis.hint,\n\t\t\t\t() => html`\n\t\t\t\t\t<schmancy-typography\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"pt-[4px]\"\n\t\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t\ttoken=\"sm\"\n\t\t\t\t\t>\n\t\t\t\t\t\t${this.hint}\n\t\t\t\t\t</schmancy-typography>\n\t\t\t\t`,\n\t\t\t)}\n\t\t`\n\t}\n}\n\ntype EventDetails = {\n\tvalue: string\n}\n\nexport type SchmancyTextareaChangeEvent = CustomEvent<EventDetails>\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-textarea': SchmancyTextarea\n\t}\n}\n"],"names":["SchmancyTextarea","TailwindElement","constructor","super","this","textareaRef","createRef","label","name","Date","now","placeholder","value","cols","rows","wrap","required","disabled","readonly","spellcheck","align","tabIndex","error","internals","attachInternals","autofocus","focus","fromEvent","textareaElement","pipe","map","event","target","distinctUntilChanged","subscribe","dispatchEvent","CustomEvent","detail","bubbles","composed","filter","key","form","reportValidity","checkValidity","message","setCustomValidity","select","start","end","direction","setSelectionRange","selectionStart","selectionEnd","selectionDirection","replacement","setRangeText","textarea","style","height","scrollHeight","validity","options","preventScroll","Event","click","blur","render","classes","labelClasses","html","when","color","SchmancyTheme","sys","default","primary","classMap","id","bgColor","surface","highest","on","ref","ifDefined","minlength","maxlength","dirname","hint","shadowRootOptions","LitElement","delegatesFocus","formAssociated","__decorateClass","property","prototype","type","String","reflect","Number","Boolean","query","customElement"],"mappings":"olBAWA,IAAqBA,EAArB,cAA8CC,2sBA0H7C,aAAAC,CACOC,MAnHPC,EAAAA,KAAAC,YAAcC,YASMF,EAAAA,KAAAG,MAAA,GASDH,KAAAI,KAAA,QAAUC,KAAKC,IAAAA,EASRN,KAAAO,YAAA,GASiBP,KAAOQ,MAAQ,GAuBvBR,KAAAS,KAAA,GASAT,KAAAU,KAAA,EASiBV,KAAAW,KAAA,OAWGX,KAAAY,SAAAA,GACAZ,KAAAa,SAAA,GACAb,KAAAc,SAAAA,GACEd,KAAAe,cAEuBf,KAAAgB,MAAA,OAahFhB,KAAgBiB,SAAW,EAMiBjB,KAAOkB,MAAQ,GAItD,GACElB,CAAAA,KAAAmB,UAAYnB,KAAKoB,iBAAgB,MAC/B,CACPpB,KAAKmB,UAAAA,MAAY,CAClB,CAGD,cACKnB,CAAAA,KAAKqB,WACRrB,KAAKsB,MAEIC,EAAAA,EAAAA,UAAAvB,KAAKwB,gBAAiB,OAC9BC,EAAAA,KACAC,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,KAAAA,EACnDqB,EAAqBA,qBAAAA,CAAAA,EAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,KAEF,CAEQZ,EAAAA,EAAAA,UAAAvB,KAAKwB,gBAAiB,QAAA,EAC9BC,KACAC,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,KACnDqB,EAAAA,EAAqBA,wBAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MAAAA,CAAAA,EACV0B,WACAC,SAAAA,EAEF,CAAA,CAAA,CAAA,CAAA,EAGuBZ,EAAAA,UAAAvB,KAAKwB,gBAAiB,OAC7CC,EAAAA,KACAW,EAAAA,OAAOT,GAASA,EAAMU,MAAQ,OAC9BX,EAAAA,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,OACnDqB,EAAqBA,qBAAAA,CAAAA,EAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,EAGGnC,CAAAA,CAAAA,EAAAA,KAAA+B,cACJ,IAAIC,YAA0B,QAAS,CACtCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,EAEF,CAAA,CAAA,CAAA,CAAA,CACA,CAGH,IAAA,aACC,OAAOnC,EAAAA,KAAKmB,YAALnB,YAAAA,EAAgBsC,IAAA,CAIjB,gBACC,OAAA,OAAAtC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBuC,gBAAe,CAIxC,sBACC,OAAAvC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBwC,eAAc,CAIvC,kBAAkBC,EACxB,OAAA,OAAOzC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwB0C,kBAAkBD,EAAO,CAIlD,QACC,OAAA,OAAAzC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwB2C,QAAO,CAIhC,kBAAkBC,EAAeC,EAAaC,EAAAA,QACpD9C,EAAAA,KAAKC,YAAYO,QAAjBR,MAAAA,EAAwB+C,kBAAkBH,EAAOC,EAAKC,EAAS,CAIhE,IAAA,gBACQ,OAAA,QAAA9C,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBgD,iBAAkB,IAAA,CAGlD,IAAA,cACQ,OAAA,QAAAhD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBiD,eAAgB,IAAA,CAGhD,IAAWC,oBAAAA,OACH,QAAAlD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBkD,qBAAsB,IAAA,CAI/C,aAAaC,EACdnD,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmBoD,aAAaD,EAAW,CAI1C,eACA,MAAAE,EAAWrD,KAAKC,YAAYO,MAC9B6C,IACHA,EAASC,MAAMC,OAAS,OACfF,EAAAC,MAAMC,OAASF,EAASG,aAAe,KACjD,CAGM,UAAAC,OACC,OAAAzD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwByD,QAAA,CAGhB,MACfC,EAAwB,CACvBC,gBAGI3D,EAAAA,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmBsB,MAAMoC,GAC9B1D,KAAK+B,cAAc,IAAI6B,MAAM,OAAQ,CAAA,CAAA,CAGtB,OAAAC,QACV7D,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmB6D,QACxB7D,KAAK+B,cAAc,IAAI6B,MAAM,OAAA,CAAA,CAAQ,CAGtB,MACV5D,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmB8D,OACxB9D,KAAK+B,cAAc,IAAI6B,MAAM,MAAO,CAAA,CAAA,CAG3B,QAAAG,CACT,MAAMC,EAAU,CACf,4EAAA,GACA,kDAAA,GACA,yBAA0B,GAC1B,kDAAmD,GACnD,+DAAiEhE,CAAAA,KAAKkB,MACtE,8CAA+ClB,KAAKkB,MACpD,cAAelB,KAAKgB,QAAU,SAC9B,aAAchB,KAAKgB,QAAU,OAExBiD,EAAAA,EAAe,CACpB,aAAcjE,KAAKa,SACnB,iBAAkB,EAAA,EAEZ,OAAAqD,EAAAA;AAAAA,KACJC,EAAAA,KACDnE,KAAKG,MACL,IACC+D;QACGE,QAAM,CACPA,MAAOpE,KAAKkB,MAAQmD,EAAAA,cAAcC,IAAIF,MAAMlD,MAAMqD,QAAUF,EAAAA,cAAcC,IAAIF,MAAMI,QAAQD,OAAAA,CAAAA,CAAAA;AAAAA,eAEpFvE,KAAKyE,SAASR,CAAAA,CAAAA;AAAAA,YACjBjE,KAAK0E,EAAAA;AAAAA;AAAAA,qDAEoC1E,KAAKG,KAAAA;AAAAA;;;;OAMnDiE,QAAM,CACPO,QAASN,EAAAA,cAAcC,IAAIF,MAAMQ,QAAQC,QACzCT,MAAOC,EAAAA,cAAcC,IAAIF,MAAMQ,QAAQE,EAAAA,CAAAA,CAAAA;AAAAA,OAEtCC,EAAAA,IAAI/E,KAAKC,WAAAA,CAAAA;AAAAA,cACFD,KAAKQ,KAAAA;AAAAA,WACRR,KAAK0E,EAAAA;AAAAA,aACH1E,KAAKI,IAAAA;AAAAA,oBACEJ,KAAKO,WAAAA;AAAAA,iBACRP,KAAKY,QAAAA;AAAAA,aACTZ,KAAKyE,SAAST,CAAAA,CAAAA;AAAAA,iBACVhE,KAAKa,QAAAA;AAAAA,iBACLmE,EAAAA,UAAUhF,KAAKiF,SAAAA,CAAAA;AAAAA,iBACfD,EAAAA,UAAUhF,KAAKkF,SAAAA,CAAAA;AAAAA,iBACflF,KAAKc,QAAAA;AAAAA,mBACHd,KAAKe,UAAAA;AAAAA,YACZiE,EAAAA,UAAUhF,KAAKS,IAAAA,CAAAA;AAAAA,YACfuE,EAAAA,UAAUhF,KAAKU,IAAAA,CAAAA;AAAAA,YACfsE,EAAAA,UAAUhF,KAAKW,IAAAA,CAAAA;AAAAA,eACZqE,EAAAA,UAAUhF,KAAKmF,OAAAA,CAAAA;AAAAA;AAAAA;AAAAA,KAGzBhB,EAAAA,KACDnE,KAAKoF,KACL,IAAMlB,EAAAA;AAAAA;AAAAA,QAEFE,QAAM,CACPA,MAAOpE,KAAKkB,MAAQmD,EAAAA,cAAcC,IAAIF,MAAMlD,MAAMqD,QAAUF,EAAAA,cAAcC,IAAIF,MAAMI,QAAQD,OAAAA,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,QAM3FvE,KAAKoF,IAAAA;AAAAA;AAAAA;GAGT,CAlViBxF,EAAAA,EACHyF,kBAAoB,CAAA,GACjCC,EAAWA,WAAAD,kBACdE,eAAAA,EAHmB3F,EAAAA,EAKb4F,eAAiB,GAYZC,EAAA,CAAXC,EAASA,SAjBU9F,CAAAA,EAAAA,EAiBR+F,UAAA,QAAA,CASAF,EAAAA,EAAA,CAAXC,EAASA,SA1BU9F,CAAAA,EAAAA,EA0BR+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAAXC,EAASA,SAAAA,CAAAA,EAnCU9F,EAmCR+F,UAAA,cAAA,CAAA,EASsCF,EAAA,CAAjDC,EAAAA,SAAS,CAAEE,KAAMC,OAAQC,QAAAA,MA5CNlG,EA4C8B+F,UAAA,QAAA,CAAA,EAO3CF,EAAA,CADNC,WAAS,CAAEE,KAAMG,MAlDEnG,CAAAA,CAAAA,EAAAA,EAmDb+F,UAAA,YAAA,GAOAF,EAAA,CADNC,WAAS,CAAEE,KAAMG,MAzDEnG,CAAAA,CAAAA,EAAAA,EA0Db+F,UAAA,YAAA,CASqBF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMG,MAnEEnG,CAAAA,CAAAA,EAAAA,EAmEQ+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMG,MAAAA,CAAAA,CAAAA,EA5EEnG,EA4EQ+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMC,MAAAA,CAAAA,CAAAA,EArFEjG,EAqFQ+F,UAAA,OAAA,CAAA,EASAF,EAAA,CAA3BC,WAAS,CAAEE,KAAMC,MAAAA,CAAAA,CAAAA,EA9FEjG,EA8FQ+F,UAAA,UAAA,CAAA,EAEgBF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAS,EAAA,CAAA,CAAA,EAhGhBlG,EAgGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAS,EAAA,CAAA,CAAA,EAjGhBlG,EAiGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,MAlGPlG,EAkGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,EAnGPlG,CAAAA,CAAAA,EAAAA,EAmGwB+F,UAAA,aAAA,CAAA,EAEDF,EAAA,CAA1CC,EAAAA,SAAS,CAAEE,KAAMC,OAAQC,QAAAA,EArGNlG,CAAAA,CAAAA,EAAAA,EAqGuB+F,UAAA,QAAA,GAU3BF,EAAA,CADfC,WAAS,CAAEE,KAAMI,OA9GEpG,CAAAA,CAAAA,EAAAA,EA+GJ+F,UAAA,YAAA,CAGAF,EAAAA,EAAA,CADfC,WAAS,CAAEE,KAAMG,MAjHEnG,CAAAA,CAAAA,EAAAA,EAkHJ+F,UAAA,WAAA,CAEGF,EAAAA,EAAA,CAAlBQ,EAAAA,MAAM,UAAA,CAAA,EApHarG,EAoHD+F,UAAA,kBAAA,CAEPF,EAAAA,EAAA,CAAXC,EAASA,SAtHU9F,CAAAA,EAAAA,EAsHR+F,UAAA,OAAA,CAEuCF,EAAAA,EAAA,CAAlDC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,EAxHPlG,CAAAA,CAAAA,EAAAA,EAwH+B+F,UAAA,QAAA,CAxH/B/F,EAAAA,EAArB6F,EAAA,CADCS,EAAAA,cAAc,mBACMtG,CAAAA,EAAAA,CAAAA"}
1
+ {"version":3,"file":"textarea-Cm_0BDw5.cjs","sources":["../src/textarea/textarea.ts"],"sourcesContent":["import { color } from '@schmancy/directives'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { LitElement, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { when } from 'lit/directives/when.js'\nimport { distinctUntilChanged, filter, fromEvent, map } from 'rxjs'\nimport style from './textarea.scss?inline'\nimport { TailwindElement } from '@mixins/index'\n@customElement('schmancy-textarea')\nexport default class SchmancyTextarea extends TailwindElement(style) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\tstatic formAssociated = true\n\t// private internals\n\tinternals: ElementInternals | undefined\n\ttextareaRef = createRef<HTMLTextAreaElement>()\n\n\t/**\n\t * The label of the control.\n\t * @attr\n\t * @type {string} label\n\t * @default ''\n\t * @public\n\t */\n\t@property() label = ''\n\n\t/**\n\t * The name of the control.\n\t * @attr name\n\t * @type {string} name\n\t * @default 'name_' + Date.now()\n\t * @public\n\t */\n\t@property() name = 'name_' + Date.now()\n\n\t/**\n\t * The placeholder of the control.\n\t * @attr placeholder\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property() placeholder = ''\n\n\t/**\n\t * The value of the control.\n\t * @attr {string} value - The value of the control.\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property({ type: String, reflect: true }) public value = ''\n\n\t/**\n\t * The minlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic minlength: number | undefined\n\n\t/**\n\t * The maxlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic maxlength!: number\n\n\t/**\n\t * The number of columns (width) of the control.\n\t * @attr cols\n\t * @type {number}\n\t * @default 20\n\t * @public\n\t */\n\t@property({ type: Number }) cols = 20\n\n\t/**\n\t * The number of rows (height) of the control.\n\t * @attr rows\n\t * @type {number}\n\t * @default 2\n\t * @public\n\t */\n\t@property({ type: Number }) rows = 2\n\n\t/**\n\t * Specifies how the text in a text area is to be wrapped when submitted in a form.\n\t * @attr wrap\n\t * @type {'hard' | 'soft'}\n\t * @default 'soft'\n\t * @public\n\t */\n\t@property({ type: String }) wrap: 'hard' | 'soft' = 'soft'\n\n\t/**\n\t * The dirname attribute of the control.\n\t * @attr dirname\n\t * @type {string}\n\t * @default undefined\n\t * @public\n\t */\n\t@property({ type: String }) dirname: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: Boolean, reflect: true }) readonly = false\n\t@property({ type: Boolean, reflect: true }) spellcheck = false\n\n\t@property({ type: String, reflect: true }) align: 'left' | 'center' | 'right' = 'left'\n\n\t/**\n\t * The autofocus attribute of the control.\n\t * @attr\n\t * @type {boolean}\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tpublic override autofocus!: boolean\n\n\t@property({ type: Number })\n\tpublic override tabIndex = 0\n\n\t@query('textarea') textareaElement!: HTMLTextAreaElement\n\n\t@property() hint: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) public error = false\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\tif (this.autofocus) {\n\t\t\tthis.focus()\n\t\t}\n\t\tfromEvent(this.textareaElement, 'input')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\tfromEvent(this.textareaElement, 'change')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\t// emit on enter\n\t\tfromEvent<KeyboardEvent>(this.textareaElement, 'keyup')\n\t\t\t.pipe(\n\t\t\t\tfilter(event => event.key === 'Enter'),\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('enter', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\t/** Checks for validity of the control and shows the browser message if it's invalid. */\n\tpublic reportValidity() {\n\t\treturn this.textareaRef.value?.reportValidity()\n\t}\n\n\t/** Checks for validity of the control and emits the invalid event if it invalid. */\n\tpublic checkValidity() {\n\t\treturn this.textareaRef.value?.checkValidity()\n\t}\n\n\t/** Sets a custom validity message. */\n\tpublic setCustomValidity(message: string) {\n\t\treturn this.textareaRef.value?.setCustomValidity(message)\n\t}\n\n\t/** Selects all text within the textarea. */\n\tpublic select() {\n\t\treturn this.textareaRef.value?.select()\n\t}\n\n\t/** Sets the selection range. */\n\tpublic setSelectionRange(start: number, end: number, direction?: 'forward' | 'backward' | 'none') {\n\t\tthis.textareaRef.value?.setSelectionRange(start, end, direction)\n\t}\n\n\t/** Returns the selected text within the textarea. */\n\tpublic get selectionStart(): number | null {\n\t\treturn this.textareaRef.value?.selectionStart ?? null\n\t}\n\n\tpublic get selectionEnd(): number | null {\n\t\treturn this.textareaRef.value?.selectionEnd ?? null\n\t}\n\n\tpublic get selectionDirection(): 'forward' | 'backward' | 'none' | null {\n\t\treturn this.textareaRef.value?.selectionDirection ?? null\n\t}\n\n\t/** Sets the range of text to be selected. */\n\tpublic setRangeText(replacement: string) {\n\t\tthis.textareaRef.value?.setRangeText(replacement)\n\t}\n\n\t/** Adjusts the height of the textarea based on its content. */\n\tpublic adjustHeight() {\n\t\tconst textarea = this.textareaRef.value\n\t\tif (textarea) {\n\t\t\ttextarea.style.height = 'auto'\n\t\t\ttextarea.style.height = textarea.scrollHeight + 'px'\n\t\t}\n\t}\n\n\tpublic validity(): ValidityState | undefined {\n\t\treturn this.textareaRef.value?.validity\n\t}\n\n\tpublic override focus(\n\t\toptions: FocusOptions = {\n\t\t\tpreventScroll: true,\n\t\t},\n\t) {\n\t\tthis.textareaRef.value?.focus(options)\n\t\tthis.dispatchEvent(new Event('focus'))\n\t}\n\n\tpublic override click() {\n\t\tthis.textareaRef.value?.click()\n\t\tthis.dispatchEvent(new Event('click'))\n\t}\n\n\tpublic override blur() {\n\t\tthis.textareaRef.value?.blur()\n\t\tthis.dispatchEvent(new Event('blur'))\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]': true,\n\t\t\t'disabled:opacity-40 disabled:cursor-not-allowed': true,\n\t\t\t'placeholder:text-muted': true,\n\t\t\t'ring-0 ring-inset focus:ring-1 focus:ring-inset': true,\n\t\t\t'ring-primary-default ring-outline focus:ring-primary-default': !this.error,\n\t\t\t'ring-error-default focus:ring-error-default': this.error,\n\t\t\t'text-center': this.align === 'center',\n\t\t\t'text-right': this.align === 'right',\n\t\t}\n\t\tconst labelClasses = {\n\t\t\t'opacity-40': this.disabled,\n\t\t\t'block mb-[4px]': true,\n\t\t}\n\t\treturn html`\n\t\t\t${when(\n\t\t\t\tthis.label,\n\t\t\t\t() =>\n\t\t\t\t\thtml`<label\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"${this.classMap(labelClasses)}\"\n\t\t\t\t\t\tfor=${this.id}\n\t\t\t\t\t>\n\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>\n\t\t\t\t\t</label>`,\n\t\t\t)}\n\n\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t<textarea\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.highest,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t\t${ref(this.textareaRef)}\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.id=${this.id}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\tclass=${this.classMap(classes)}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\tminlength=${ifDefined(this.minlength)}\n\t\t\t\t\tmaxlength=${ifDefined(this.maxlength)}\n\t\t\t\t\t.readonly=${this.readonly}\n\t\t\t\t\t.spellcheck=${this.spellcheck}\n\t\t\t\t\tcols=${ifDefined(this.cols)}\n\t\t\t\t\trows=${ifDefined(this.rows)}\n\t\t\t\t\twrap=${ifDefined(this.wrap)}\n\t\t\t\t\tdirname=${ifDefined(this.dirname)}\n\t\t\t\t></textarea>\n\t\t\t</schmancy-typography>\n\t\t\t${when(\n\t\t\t\tthis.hint,\n\t\t\t\t() => html`\n\t\t\t\t\t<schmancy-typography\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"pt-[4px]\"\n\t\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t\ttoken=\"sm\"\n\t\t\t\t\t>\n\t\t\t\t\t\t${this.hint}\n\t\t\t\t\t</schmancy-typography>\n\t\t\t\t`,\n\t\t\t)}\n\t\t`\n\t}\n}\n\ntype EventDetails = {\n\tvalue: string\n}\n\nexport type SchmancyTextareaChangeEvent = CustomEvent<EventDetails>\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-textarea': SchmancyTextarea\n\t}\n}\n"],"names":["SchmancyTextarea","TailwindElement","constructor","super","this","textareaRef","createRef","label","name","Date","now","placeholder","value","cols","rows","wrap","required","disabled","readonly","spellcheck","align","tabIndex","error","internals","attachInternals","autofocus","focus","fromEvent","textareaElement","pipe","map","event","target","distinctUntilChanged","subscribe","dispatchEvent","CustomEvent","detail","bubbles","composed","filter","key","form","reportValidity","checkValidity","message","setCustomValidity","select","start","end","direction","setSelectionRange","selectionStart","selectionEnd","selectionDirection","replacement","setRangeText","textarea","style","height","scrollHeight","validity","options","preventScroll","Event","click","blur","render","classes","labelClasses","html","when","color","SchmancyTheme","sys","default","primary","classMap","id","bgColor","surface","highest","on","ref","ifDefined","minlength","maxlength","dirname","hint","shadowRootOptions","LitElement","delegatesFocus","formAssociated","__decorateClass","property","prototype","type","String","reflect","Number","Boolean","query","customElement"],"mappings":"olBAWA,IAAqBA,EAArB,cAA8CC,2sBA0H7C,aAAAC,CACOC,MAnHPC,EAAAA,KAAAC,YAAcC,YASMF,EAAAA,KAAAG,MAAA,GASDH,KAAAI,KAAA,QAAUC,KAAKC,IAAAA,EASRN,KAAAO,YAAA,GASiBP,KAAOQ,MAAQ,GAuBvBR,KAAAS,KAAA,GASAT,KAAAU,KAAA,EASiBV,KAAAW,KAAA,OAWGX,KAAAY,SAAAA,GACAZ,KAAAa,SAAA,GACAb,KAAAc,SAAAA,GACEd,KAAAe,cAEuBf,KAAAgB,MAAA,OAahFhB,KAAgBiB,SAAW,EAMiBjB,KAAOkB,MAAQ,GAItD,GACElB,CAAAA,KAAAmB,UAAYnB,KAAKoB,iBAAgB,MAC/B,CACPpB,KAAKmB,UAAAA,MAAY,CAClB,CAGD,cACKnB,CAAAA,KAAKqB,WACRrB,KAAKsB,MAEIC,EAAAA,EAAAA,UAAAvB,KAAKwB,gBAAiB,OAC9BC,EAAAA,KACAC,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,KAAAA,EACnDqB,EAAqBA,qBAAAA,CAAAA,EAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,KAEF,CAEQZ,EAAAA,EAAAA,UAAAvB,KAAKwB,gBAAiB,QAAA,EAC9BC,KACAC,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,KACnDqB,EAAAA,EAAqBA,wBAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MAAAA,CAAAA,EACV0B,WACAC,SAAAA,EAEF,CAAA,CAAA,CAAA,CAAA,EAGuBZ,EAAAA,UAAAvB,KAAKwB,gBAAiB,OAC7CC,EAAAA,KACAW,EAAAA,OAAOT,GAASA,EAAMU,MAAQ,OAC9BX,EAAAA,EAAAA,IAAIC,GAAUA,EAAMC,OAA+BpB,OACnDqB,EAAqBA,qBAAAA,CAAAA,EAErBC,UAAmBtB,GAAAA,CACnBR,KAAKQ,MAAQA,EACRR,KAAA+B,cACJ,IAAIC,YAA0B,SAAU,CACvCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,EAGGnC,CAAAA,CAAAA,EAAAA,KAAA+B,cACJ,IAAIC,YAA0B,QAAS,CACtCC,OAAQ,CAAEzB,MACV0B,CAAAA,EAAAA,QAAAA,GACAC,SAAAA,EAEF,CAAA,CAAA,CAAA,CAAA,CACA,CAGH,IAAA,aACC,OAAOnC,EAAAA,KAAKmB,YAALnB,YAAAA,EAAgBsC,IAAA,CAIjB,gBACC,OAAA,OAAAtC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBuC,gBAAe,CAIxC,sBACC,OAAAvC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBwC,eAAc,CAIvC,kBAAkBC,EACxB,OAAA,OAAOzC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwB0C,kBAAkBD,EAAO,CAIlD,QACC,OAAA,OAAAzC,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwB2C,QAAO,CAIhC,kBAAkBC,EAAeC,EAAaC,EAAAA,QACpD9C,EAAAA,KAAKC,YAAYO,QAAjBR,MAAAA,EAAwB+C,kBAAkBH,EAAOC,EAAKC,EAAS,CAIhE,IAAA,gBACQ,OAAA,QAAA9C,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBgD,iBAAkB,IAAA,CAGlD,IAAA,cACQ,OAAA,QAAAhD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBiD,eAAgB,IAAA,CAGhD,IAAWC,oBAAAA,OACH,QAAAlD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwBkD,qBAAsB,IAAA,CAI/C,aAAaC,EACdnD,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmBoD,aAAaD,EAAW,CAI1C,eACA,MAAAE,EAAWrD,KAAKC,YAAYO,MAC9B6C,IACHA,EAASC,MAAMC,OAAS,OACfF,EAAAC,MAAMC,OAASF,EAASG,aAAe,KACjD,CAGM,UAAAC,OACC,OAAAzD,EAAAA,KAAKC,YAAYO,QAAjBR,YAAAA,EAAwByD,QAAA,CAGhB,MACfC,EAAwB,CACvBC,gBAGI3D,EAAAA,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmBsB,MAAMoC,GAC9B1D,KAAK+B,cAAc,IAAI6B,MAAM,OAAQ,CAAA,CAAA,CAGtB,OAAAC,QACV7D,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmB6D,QACxB7D,KAAK+B,cAAc,IAAI6B,MAAM,OAAA,CAAA,CAAQ,CAGtB,MACV5D,QAAAA,EAAAA,KAAAC,YAAYO,QAAZR,MAAAA,EAAmB8D,OACxB9D,KAAK+B,cAAc,IAAI6B,MAAM,MAAO,CAAA,CAAA,CAG3B,QAAAG,CACT,MAAMC,EAAU,CACf,4EAAA,GACA,kDAAA,GACA,yBAA0B,GAC1B,kDAAmD,GACnD,+DAAiEhE,CAAAA,KAAKkB,MACtE,8CAA+ClB,KAAKkB,MACpD,cAAelB,KAAKgB,QAAU,SAC9B,aAAchB,KAAKgB,QAAU,OAExBiD,EAAAA,EAAe,CACpB,aAAcjE,KAAKa,SACnB,iBAAkB,EAAA,EAEZ,OAAAqD,EAAAA;AAAAA,KACJC,EAAAA,KACDnE,KAAKG,MACL,IACC+D;QACGE,QAAM,CACPA,MAAOpE,KAAKkB,MAAQmD,EAAAA,cAAcC,IAAIF,MAAMlD,MAAMqD,QAAUF,EAAAA,cAAcC,IAAIF,MAAMI,QAAQD,OAAAA,CAAAA,CAAAA;AAAAA,eAEpFvE,KAAKyE,SAASR,CAAAA,CAAAA;AAAAA,YACjBjE,KAAK0E,EAAAA;AAAAA;AAAAA,qDAEoC1E,KAAKG,KAAAA;AAAAA;;;;OAMnDiE,QAAM,CACPO,QAASN,EAAAA,cAAcC,IAAIF,MAAMQ,QAAQC,QACzCT,MAAOC,EAAAA,cAAcC,IAAIF,MAAMQ,QAAQE,EAAAA,CAAAA,CAAAA;AAAAA,OAEtCC,EAAAA,IAAI/E,KAAKC,WAAAA,CAAAA;AAAAA,cACFD,KAAKQ,KAAAA;AAAAA,WACRR,KAAK0E,EAAAA;AAAAA,aACH1E,KAAKI,IAAAA;AAAAA,oBACEJ,KAAKO,WAAAA;AAAAA,iBACRP,KAAKY,QAAAA;AAAAA,aACTZ,KAAKyE,SAAST,CAAAA,CAAAA;AAAAA,iBACVhE,KAAKa,QAAAA;AAAAA,iBACLmE,EAAAA,UAAUhF,KAAKiF,SAAAA,CAAAA;AAAAA,iBACfD,EAAAA,UAAUhF,KAAKkF,SAAAA,CAAAA;AAAAA,iBACflF,KAAKc,QAAAA;AAAAA,mBACHd,KAAKe,UAAAA;AAAAA,YACZiE,EAAAA,UAAUhF,KAAKS,IAAAA,CAAAA;AAAAA,YACfuE,EAAAA,UAAUhF,KAAKU,IAAAA,CAAAA;AAAAA,YACfsE,EAAAA,UAAUhF,KAAKW,IAAAA,CAAAA;AAAAA,eACZqE,EAAAA,UAAUhF,KAAKmF,OAAAA,CAAAA;AAAAA;AAAAA;AAAAA,KAGzBhB,EAAAA,KACDnE,KAAKoF,KACL,IAAMlB,EAAAA;AAAAA;AAAAA,QAEFE,QAAM,CACPA,MAAOpE,KAAKkB,MAAQmD,EAAAA,cAAcC,IAAIF,MAAMlD,MAAMqD,QAAUF,EAAAA,cAAcC,IAAIF,MAAMI,QAAQD,OAAAA,CAAAA,CAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,QAM3FvE,KAAKoF,IAAAA;AAAAA;AAAAA;GAGT,CAlViBxF,EAAAA,EACHyF,kBAAoB,CAAA,GACjCC,EAAWA,WAAAD,kBACdE,eAAAA,EAHmB3F,EAAAA,EAKb4F,eAAiB,GAYZC,EAAA,CAAXC,EAASA,SAjBU9F,CAAAA,EAAAA,EAiBR+F,UAAA,QAAA,CASAF,EAAAA,EAAA,CAAXC,EAASA,SA1BU9F,CAAAA,EAAAA,EA0BR+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAAXC,EAASA,SAAAA,CAAAA,EAnCU9F,EAmCR+F,UAAA,cAAA,CAAA,EASsCF,EAAA,CAAjDC,EAAAA,SAAS,CAAEE,KAAMC,OAAQC,QAAAA,MA5CNlG,EA4C8B+F,UAAA,QAAA,CAAA,EAO3CF,EAAA,CADNC,WAAS,CAAEE,KAAMG,MAlDEnG,CAAAA,CAAAA,EAAAA,EAmDb+F,UAAA,YAAA,GAOAF,EAAA,CADNC,WAAS,CAAEE,KAAMG,MAzDEnG,CAAAA,CAAAA,EAAAA,EA0Db+F,UAAA,YAAA,CASqBF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMG,MAnEEnG,CAAAA,CAAAA,EAAAA,EAmEQ+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMG,MAAAA,CAAAA,CAAAA,EA5EEnG,EA4EQ+F,UAAA,OAAA,CASAF,EAAAA,EAAA,CAA3BC,WAAS,CAAEE,KAAMC,MAAAA,CAAAA,CAAAA,EArFEjG,EAqFQ+F,UAAA,OAAA,CAAA,EASAF,EAAA,CAA3BC,WAAS,CAAEE,KAAMC,MAAAA,CAAAA,CAAAA,EA9FEjG,EA8FQ+F,UAAA,UAAA,CAAA,EAEgBF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAS,EAAA,CAAA,CAAA,EAhGhBlG,EAgGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAS,EAAA,CAAA,CAAA,EAjGhBlG,EAiGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,MAlGPlG,EAkGwB+F,UAAA,WAAA,CAAA,EACAF,EAAA,CAA3CC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,EAnGPlG,CAAAA,CAAAA,EAAAA,EAmGwB+F,UAAA,aAAA,CAAA,EAEDF,EAAA,CAA1CC,EAAAA,SAAS,CAAEE,KAAMC,OAAQC,QAAAA,EArGNlG,CAAAA,CAAAA,EAAAA,EAqGuB+F,UAAA,QAAA,GAU3BF,EAAA,CADfC,WAAS,CAAEE,KAAMI,OA9GEpG,CAAAA,CAAAA,EAAAA,EA+GJ+F,UAAA,YAAA,CAGAF,EAAAA,EAAA,CADfC,WAAS,CAAEE,KAAMG,MAjHEnG,CAAAA,CAAAA,EAAAA,EAkHJ+F,UAAA,WAAA,CAEGF,EAAAA,EAAA,CAAlBQ,EAAAA,MAAM,UAAA,CAAA,EApHarG,EAoHD+F,UAAA,kBAAA,CAEPF,EAAAA,EAAA,CAAXC,EAASA,SAtHU9F,CAAAA,EAAAA,EAsHR+F,UAAA,OAAA,CAEuCF,EAAAA,EAAA,CAAlDC,EAAAA,SAAS,CAAEE,KAAMI,QAASF,QAAAA,EAxHPlG,CAAAA,CAAAA,EAAAA,EAwH+B+F,UAAA,QAAA,CAxH/B/F,EAAAA,EAArB6F,EAAA,CADCS,EAAAA,cAAc,mBACMtG,CAAAA,EAAAA,CAAAA"}
@@ -8,7 +8,7 @@ import { when as g } from "lit/directives/when.js";
8
8
  import { fromEvent as y, map as m, distinctUntilChanged as f, filter as E } from "rxjs";
9
9
  import "lit/directives/class-map.js";
10
10
  import "lit/directives/style-map.js";
11
- import { T as R } from "./tailwind.mixin-DNlFmovi.js";
11
+ import { T as R } from "./tailwind.mixin-BBKdEPAU.js";
12
12
  var k = Object.defineProperty, S = Object.getOwnPropertyDescriptor, r = (t, a, h, s) => {
13
13
  for (var p, o = s > 1 ? void 0 : s ? S(a, h) : a, c = t.length - 1; c >= 0; c--) (p = t[c]) && (o = (s ? p(a, h, o) : p(o)) || o);
14
14
  return s && o && k(a, h, o), o;
@@ -137,4 +137,4 @@ let e = class extends R(":host{border:unset!important;line-height:unset!importan
137
137
  }
138
138
  };
139
139
  e.shadowRootOptions = { ...x.shadowRootOptions, delegatesFocus: !0 }, e.formAssociated = !0, r([i()], e.prototype, "label", 2), r([i()], e.prototype, "name", 2), r([i()], e.prototype, "placeholder", 2), r([i({ type: String, reflect: !0 })], e.prototype, "value", 2), r([i({ type: Number })], e.prototype, "minlength", 2), r([i({ type: Number })], e.prototype, "maxlength", 2), r([i({ type: Number })], e.prototype, "cols", 2), r([i({ type: Number })], e.prototype, "rows", 2), r([i({ type: String })], e.prototype, "wrap", 2), r([i({ type: String })], e.prototype, "dirname", 2), r([i({ type: Boolean, reflect: !0 })], e.prototype, "required", 2), r([i({ type: Boolean, reflect: !0 })], e.prototype, "disabled", 2), r([i({ type: Boolean, reflect: !0 })], e.prototype, "readonly", 2), r([i({ type: Boolean, reflect: !0 })], e.prototype, "spellcheck", 2), r([i({ type: String, reflect: !0 })], e.prototype, "align", 2), r([i({ type: Boolean })], e.prototype, "autofocus", 2), r([i({ type: Number })], e.prototype, "tabIndex", 2), r([b("textarea")], e.prototype, "textareaElement", 2), r([i()], e.prototype, "hint", 2), r([i({ type: Boolean, reflect: !0 })], e.prototype, "error", 2), e = r([v("schmancy-textarea")], e);
140
- //# sourceMappingURL=textarea-JWBhOVdN.js.map
140
+ //# sourceMappingURL=textarea-DWBpogxd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"textarea-JWBhOVdN.js","sources":["../src/textarea/textarea.ts"],"sourcesContent":["import { color } from '@schmancy/directives'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { LitElement, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { when } from 'lit/directives/when.js'\nimport { distinctUntilChanged, filter, fromEvent, map } from 'rxjs'\nimport style from './textarea.scss?inline'\nimport { TailwindElement } from '@mixins/index'\n@customElement('schmancy-textarea')\nexport default class SchmancyTextarea extends TailwindElement(style) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\tstatic formAssociated = true\n\t// private internals\n\tinternals: ElementInternals | undefined\n\ttextareaRef = createRef<HTMLTextAreaElement>()\n\n\t/**\n\t * The label of the control.\n\t * @attr\n\t * @type {string} label\n\t * @default ''\n\t * @public\n\t */\n\t@property() label = ''\n\n\t/**\n\t * The name of the control.\n\t * @attr name\n\t * @type {string} name\n\t * @default 'name_' + Date.now()\n\t * @public\n\t */\n\t@property() name = 'name_' + Date.now()\n\n\t/**\n\t * The placeholder of the control.\n\t * @attr placeholder\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property() placeholder = ''\n\n\t/**\n\t * The value of the control.\n\t * @attr {string} value - The value of the control.\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property({ type: String, reflect: true }) public value = ''\n\n\t/**\n\t * The minlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic minlength: number | undefined\n\n\t/**\n\t * The maxlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic maxlength!: number\n\n\t/**\n\t * The number of columns (width) of the control.\n\t * @attr cols\n\t * @type {number}\n\t * @default 20\n\t * @public\n\t */\n\t@property({ type: Number }) cols = 20\n\n\t/**\n\t * The number of rows (height) of the control.\n\t * @attr rows\n\t * @type {number}\n\t * @default 2\n\t * @public\n\t */\n\t@property({ type: Number }) rows = 2\n\n\t/**\n\t * Specifies how the text in a text area is to be wrapped when submitted in a form.\n\t * @attr wrap\n\t * @type {'hard' | 'soft'}\n\t * @default 'soft'\n\t * @public\n\t */\n\t@property({ type: String }) wrap: 'hard' | 'soft' = 'soft'\n\n\t/**\n\t * The dirname attribute of the control.\n\t * @attr dirname\n\t * @type {string}\n\t * @default undefined\n\t * @public\n\t */\n\t@property({ type: String }) dirname: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: Boolean, reflect: true }) readonly = false\n\t@property({ type: Boolean, reflect: true }) spellcheck = false\n\n\t@property({ type: String, reflect: true }) align: 'left' | 'center' | 'right' = 'left'\n\n\t/**\n\t * The autofocus attribute of the control.\n\t * @attr\n\t * @type {boolean}\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tpublic override autofocus!: boolean\n\n\t@property({ type: Number })\n\tpublic override tabIndex = 0\n\n\t@query('textarea') textareaElement!: HTMLTextAreaElement\n\n\t@property() hint: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) public error = false\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\tif (this.autofocus) {\n\t\t\tthis.focus()\n\t\t}\n\t\tfromEvent(this.textareaElement, 'input')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\tfromEvent(this.textareaElement, 'change')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\t// emit on enter\n\t\tfromEvent<KeyboardEvent>(this.textareaElement, 'keyup')\n\t\t\t.pipe(\n\t\t\t\tfilter(event => event.key === 'Enter'),\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('enter', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\t/** Checks for validity of the control and shows the browser message if it's invalid. */\n\tpublic reportValidity() {\n\t\treturn this.textareaRef.value?.reportValidity()\n\t}\n\n\t/** Checks for validity of the control and emits the invalid event if it invalid. */\n\tpublic checkValidity() {\n\t\treturn this.textareaRef.value?.checkValidity()\n\t}\n\n\t/** Sets a custom validity message. */\n\tpublic setCustomValidity(message: string) {\n\t\treturn this.textareaRef.value?.setCustomValidity(message)\n\t}\n\n\t/** Selects all text within the textarea. */\n\tpublic select() {\n\t\treturn this.textareaRef.value?.select()\n\t}\n\n\t/** Sets the selection range. */\n\tpublic setSelectionRange(start: number, end: number, direction?: 'forward' | 'backward' | 'none') {\n\t\tthis.textareaRef.value?.setSelectionRange(start, end, direction)\n\t}\n\n\t/** Returns the selected text within the textarea. */\n\tpublic get selectionStart(): number | null {\n\t\treturn this.textareaRef.value?.selectionStart ?? null\n\t}\n\n\tpublic get selectionEnd(): number | null {\n\t\treturn this.textareaRef.value?.selectionEnd ?? null\n\t}\n\n\tpublic get selectionDirection(): 'forward' | 'backward' | 'none' | null {\n\t\treturn this.textareaRef.value?.selectionDirection ?? null\n\t}\n\n\t/** Sets the range of text to be selected. */\n\tpublic setRangeText(replacement: string) {\n\t\tthis.textareaRef.value?.setRangeText(replacement)\n\t}\n\n\t/** Adjusts the height of the textarea based on its content. */\n\tpublic adjustHeight() {\n\t\tconst textarea = this.textareaRef.value\n\t\tif (textarea) {\n\t\t\ttextarea.style.height = 'auto'\n\t\t\ttextarea.style.height = textarea.scrollHeight + 'px'\n\t\t}\n\t}\n\n\tpublic validity(): ValidityState | undefined {\n\t\treturn this.textareaRef.value?.validity\n\t}\n\n\tpublic override focus(\n\t\toptions: FocusOptions = {\n\t\t\tpreventScroll: true,\n\t\t},\n\t) {\n\t\tthis.textareaRef.value?.focus(options)\n\t\tthis.dispatchEvent(new Event('focus'))\n\t}\n\n\tpublic override click() {\n\t\tthis.textareaRef.value?.click()\n\t\tthis.dispatchEvent(new Event('click'))\n\t}\n\n\tpublic override blur() {\n\t\tthis.textareaRef.value?.blur()\n\t\tthis.dispatchEvent(new Event('blur'))\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]': true,\n\t\t\t'disabled:opacity-40 disabled:cursor-not-allowed': true,\n\t\t\t'placeholder:text-muted': true,\n\t\t\t'ring-0 ring-inset focus:ring-1 focus:ring-inset': true,\n\t\t\t'ring-primary-default ring-outline focus:ring-primary-default': !this.error,\n\t\t\t'ring-error-default focus:ring-error-default': this.error,\n\t\t\t'text-center': this.align === 'center',\n\t\t\t'text-right': this.align === 'right',\n\t\t}\n\t\tconst labelClasses = {\n\t\t\t'opacity-40': this.disabled,\n\t\t\t'block mb-[4px]': true,\n\t\t}\n\t\treturn html`\n\t\t\t${when(\n\t\t\t\tthis.label,\n\t\t\t\t() =>\n\t\t\t\t\thtml`<label\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"${this.classMap(labelClasses)}\"\n\t\t\t\t\t\tfor=${this.id}\n\t\t\t\t\t>\n\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>\n\t\t\t\t\t</label>`,\n\t\t\t)}\n\n\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t<textarea\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.highest,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t\t${ref(this.textareaRef)}\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.id=${this.id}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\tclass=${this.classMap(classes)}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\tminlength=${ifDefined(this.minlength)}\n\t\t\t\t\tmaxlength=${ifDefined(this.maxlength)}\n\t\t\t\t\t.readonly=${this.readonly}\n\t\t\t\t\t.spellcheck=${this.spellcheck}\n\t\t\t\t\tcols=${ifDefined(this.cols)}\n\t\t\t\t\trows=${ifDefined(this.rows)}\n\t\t\t\t\twrap=${ifDefined(this.wrap)}\n\t\t\t\t\tdirname=${ifDefined(this.dirname)}\n\t\t\t\t></textarea>\n\t\t\t</schmancy-typography>\n\t\t\t${when(\n\t\t\t\tthis.hint,\n\t\t\t\t() => html`\n\t\t\t\t\t<schmancy-typography\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"pt-[4px]\"\n\t\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t\ttoken=\"sm\"\n\t\t\t\t\t>\n\t\t\t\t\t\t${this.hint}\n\t\t\t\t\t</schmancy-typography>\n\t\t\t\t`,\n\t\t\t)}\n\t\t`\n\t}\n}\n\ntype EventDetails = {\n\tvalue: string\n}\n\nexport type SchmancyTextareaChangeEvent = CustomEvent<EventDetails>\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-textarea': SchmancyTextarea\n\t}\n}\n"],"names":["SchmancyTextarea","TailwindElement","constructor","super","this","textareaRef","createRef","label","name","Date","now","placeholder","value","cols","rows","wrap","required","disabled","readonly","spellcheck","align","tabIndex","error","internals","attachInternals","autofocus","focus","fromEvent","textareaElement","pipe","map","event","target","distinctUntilChanged","subscribe","dispatchEvent","CustomEvent","detail","bubbles","composed","filter","key","form","reportValidity","checkValidity","message","setCustomValidity","select","start","end","direction","setSelectionRange","selectionStart","selectionEnd","selectionDirection","replacement","setRangeText","adjustHeight","textarea","style","height","scrollHeight","validity","options","preventScroll","Event","click","blur","render","classes","labelClasses","html","when","color","SchmancyTheme","sys","default","primary","classMap","id","bgColor","surface","highest","on","ref","ifDefined","minlength","maxlength","dirname","hint","shadowRootOptions","LitElement","delegatesFocus","formAssociated","__decorateClass","property","prototype","type","String","reflect","Number","Boolean","query","customElement"],"mappings":"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"}
1
+ {"version":3,"file":"textarea-DWBpogxd.js","sources":["../src/textarea/textarea.ts"],"sourcesContent":["import { color } from '@schmancy/directives'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { LitElement, html } from 'lit'\nimport { customElement, property, query } from 'lit/decorators.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { when } from 'lit/directives/when.js'\nimport { distinctUntilChanged, filter, fromEvent, map } from 'rxjs'\nimport style from './textarea.scss?inline'\nimport { TailwindElement } from '@mixins/index'\n@customElement('schmancy-textarea')\nexport default class SchmancyTextarea extends TailwindElement(style) {\n\tprotected static shadowRootOptions = {\n\t\t...LitElement.shadowRootOptions,\n\t\tdelegatesFocus: true,\n\t}\n\tstatic formAssociated = true\n\t// private internals\n\tinternals: ElementInternals | undefined\n\ttextareaRef = createRef<HTMLTextAreaElement>()\n\n\t/**\n\t * The label of the control.\n\t * @attr\n\t * @type {string} label\n\t * @default ''\n\t * @public\n\t */\n\t@property() label = ''\n\n\t/**\n\t * The name of the control.\n\t * @attr name\n\t * @type {string} name\n\t * @default 'name_' + Date.now()\n\t * @public\n\t */\n\t@property() name = 'name_' + Date.now()\n\n\t/**\n\t * The placeholder of the control.\n\t * @attr placeholder\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property() placeholder = ''\n\n\t/**\n\t * The value of the control.\n\t * @attr {string} value - The value of the control.\n\t * @type {string}\n\t * @default ''\n\t * @public\n\t */\n\t@property({ type: String, reflect: true }) public value = ''\n\n\t/**\n\t * The minlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic minlength: number | undefined\n\n\t/**\n\t * The maxlength attribute of the control.\n\t * @attr\n\t */\n\t@property({ type: Number })\n\tpublic maxlength!: number\n\n\t/**\n\t * The number of columns (width) of the control.\n\t * @attr cols\n\t * @type {number}\n\t * @default 20\n\t * @public\n\t */\n\t@property({ type: Number }) cols = 20\n\n\t/**\n\t * The number of rows (height) of the control.\n\t * @attr rows\n\t * @type {number}\n\t * @default 2\n\t * @public\n\t */\n\t@property({ type: Number }) rows = 2\n\n\t/**\n\t * Specifies how the text in a text area is to be wrapped when submitted in a form.\n\t * @attr wrap\n\t * @type {'hard' | 'soft'}\n\t * @default 'soft'\n\t * @public\n\t */\n\t@property({ type: String }) wrap: 'hard' | 'soft' = 'soft'\n\n\t/**\n\t * The dirname attribute of the control.\n\t * @attr dirname\n\t * @type {string}\n\t * @default undefined\n\t * @public\n\t */\n\t@property({ type: String }) dirname: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: Boolean, reflect: true }) readonly = false\n\t@property({ type: Boolean, reflect: true }) spellcheck = false\n\n\t@property({ type: String, reflect: true }) align: 'left' | 'center' | 'right' = 'left'\n\n\t/**\n\t * The autofocus attribute of the control.\n\t * @attr\n\t * @type {boolean}\n\t * @default false\n\t * @public\n\t */\n\t@property({ type: Boolean })\n\tpublic override autofocus!: boolean\n\n\t@property({ type: Number })\n\tpublic override tabIndex = 0\n\n\t@query('textarea') textareaElement!: HTMLTextAreaElement\n\n\t@property() hint: string | undefined\n\n\t@property({ type: Boolean, reflect: true }) public error = false\n\n\tconstructor() {\n\t\tsuper()\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch {\n\t\t\tthis.internals = undefined\n\t\t}\n\t}\n\n\tfirstUpdated() {\n\t\tif (this.autofocus) {\n\t\t\tthis.focus()\n\t\t}\n\t\tfromEvent(this.textareaElement, 'input')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\tfromEvent(this.textareaElement, 'change')\n\t\t\t.pipe(\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t\t// emit on enter\n\t\tfromEvent<KeyboardEvent>(this.textareaElement, 'keyup')\n\t\t\t.pipe(\n\t\t\t\tfilter(event => event.key === 'Enter'),\n\t\t\t\tmap(event => (event.target as HTMLTextAreaElement).value),\n\t\t\t\tdistinctUntilChanged(),\n\t\t\t)\n\t\t\t.subscribe(value => {\n\t\t\t\tthis.value = value\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('change', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\tnew CustomEvent<EventDetails>('enter', {\n\t\t\t\t\t\tdetail: { value },\n\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t})\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\t/** Checks for validity of the control and shows the browser message if it's invalid. */\n\tpublic reportValidity() {\n\t\treturn this.textareaRef.value?.reportValidity()\n\t}\n\n\t/** Checks for validity of the control and emits the invalid event if it invalid. */\n\tpublic checkValidity() {\n\t\treturn this.textareaRef.value?.checkValidity()\n\t}\n\n\t/** Sets a custom validity message. */\n\tpublic setCustomValidity(message: string) {\n\t\treturn this.textareaRef.value?.setCustomValidity(message)\n\t}\n\n\t/** Selects all text within the textarea. */\n\tpublic select() {\n\t\treturn this.textareaRef.value?.select()\n\t}\n\n\t/** Sets the selection range. */\n\tpublic setSelectionRange(start: number, end: number, direction?: 'forward' | 'backward' | 'none') {\n\t\tthis.textareaRef.value?.setSelectionRange(start, end, direction)\n\t}\n\n\t/** Returns the selected text within the textarea. */\n\tpublic get selectionStart(): number | null {\n\t\treturn this.textareaRef.value?.selectionStart ?? null\n\t}\n\n\tpublic get selectionEnd(): number | null {\n\t\treturn this.textareaRef.value?.selectionEnd ?? null\n\t}\n\n\tpublic get selectionDirection(): 'forward' | 'backward' | 'none' | null {\n\t\treturn this.textareaRef.value?.selectionDirection ?? null\n\t}\n\n\t/** Sets the range of text to be selected. */\n\tpublic setRangeText(replacement: string) {\n\t\tthis.textareaRef.value?.setRangeText(replacement)\n\t}\n\n\t/** Adjusts the height of the textarea based on its content. */\n\tpublic adjustHeight() {\n\t\tconst textarea = this.textareaRef.value\n\t\tif (textarea) {\n\t\t\ttextarea.style.height = 'auto'\n\t\t\ttextarea.style.height = textarea.scrollHeight + 'px'\n\t\t}\n\t}\n\n\tpublic validity(): ValidityState | undefined {\n\t\treturn this.textareaRef.value?.validity\n\t}\n\n\tpublic override focus(\n\t\toptions: FocusOptions = {\n\t\t\tpreventScroll: true,\n\t\t},\n\t) {\n\t\tthis.textareaRef.value?.focus(options)\n\t\tthis.dispatchEvent(new Event('focus'))\n\t}\n\n\tpublic override click() {\n\t\tthis.textareaRef.value?.click()\n\t\tthis.dispatchEvent(new Event('click'))\n\t}\n\n\tpublic override blur() {\n\t\tthis.textareaRef.value?.blur()\n\t\tthis.dispatchEvent(new Event('blur'))\n\t}\n\n\tprotected render(): unknown {\n\t\tconst classes = {\n\t\t\t'w-full rounded-[8px] border-0 px-[8px] sm:px-[12px] md:px-[16px] py-[8px]': true,\n\t\t\t'disabled:opacity-40 disabled:cursor-not-allowed': true,\n\t\t\t'placeholder:text-muted': true,\n\t\t\t'ring-0 ring-inset focus:ring-1 focus:ring-inset': true,\n\t\t\t'ring-primary-default ring-outline focus:ring-primary-default': !this.error,\n\t\t\t'ring-error-default focus:ring-error-default': this.error,\n\t\t\t'text-center': this.align === 'center',\n\t\t\t'text-right': this.align === 'right',\n\t\t}\n\t\tconst labelClasses = {\n\t\t\t'opacity-40': this.disabled,\n\t\t\t'block mb-[4px]': true,\n\t\t}\n\t\treturn html`\n\t\t\t${when(\n\t\t\t\tthis.label,\n\t\t\t\t() =>\n\t\t\t\t\thtml`<label\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"${this.classMap(labelClasses)}\"\n\t\t\t\t\t\tfor=${this.id}\n\t\t\t\t\t>\n\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>\n\t\t\t\t\t</label>`,\n\t\t\t)}\n\n\t\t\t<schmancy-typography type=\"body\" token=\"lg\">\n\t\t\t\t<textarea\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.highest,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t\t${ref(this.textareaRef)}\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.id=${this.id}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\tclass=${this.classMap(classes)}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\tminlength=${ifDefined(this.minlength)}\n\t\t\t\t\tmaxlength=${ifDefined(this.maxlength)}\n\t\t\t\t\t.readonly=${this.readonly}\n\t\t\t\t\t.spellcheck=${this.spellcheck}\n\t\t\t\t\tcols=${ifDefined(this.cols)}\n\t\t\t\t\trows=${ifDefined(this.rows)}\n\t\t\t\t\twrap=${ifDefined(this.wrap)}\n\t\t\t\t\tdirname=${ifDefined(this.dirname)}\n\t\t\t\t></textarea>\n\t\t\t</schmancy-typography>\n\t\t\t${when(\n\t\t\t\tthis.hint,\n\t\t\t\t() => html`\n\t\t\t\t\t<schmancy-typography\n\t\t\t\t\t\t${color({\n\t\t\t\t\t\t\tcolor: this.error ? SchmancyTheme.sys.color.error.default : SchmancyTheme.sys.color.primary.default,\n\t\t\t\t\t\t})}\n\t\t\t\t\t\tclass=\"pt-[4px]\"\n\t\t\t\t\t\ttype=\"body\"\n\t\t\t\t\t\ttoken=\"sm\"\n\t\t\t\t\t>\n\t\t\t\t\t\t${this.hint}\n\t\t\t\t\t</schmancy-typography>\n\t\t\t\t`,\n\t\t\t)}\n\t\t`\n\t}\n}\n\ntype EventDetails = {\n\tvalue: string\n}\n\nexport type SchmancyTextareaChangeEvent = CustomEvent<EventDetails>\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-textarea': SchmancyTextarea\n\t}\n}\n"],"names":["SchmancyTextarea","TailwindElement","constructor","super","this","textareaRef","createRef","label","name","Date","now","placeholder","value","cols","rows","wrap","required","disabled","readonly","spellcheck","align","tabIndex","error","internals","attachInternals","autofocus","focus","fromEvent","textareaElement","pipe","map","event","target","distinctUntilChanged","subscribe","dispatchEvent","CustomEvent","detail","bubbles","composed","filter","key","form","reportValidity","checkValidity","message","setCustomValidity","select","start","end","direction","setSelectionRange","selectionStart","selectionEnd","selectionDirection","replacement","setRangeText","adjustHeight","textarea","style","height","scrollHeight","validity","options","preventScroll","Event","click","blur","render","classes","labelClasses","html","when","color","SchmancyTheme","sys","default","primary","classMap","id","bgColor","surface","highest","on","ref","ifDefined","minlength","maxlength","dirname","hint","shadowRootOptions","LitElement","delegatesFocus","formAssociated","__decorateClass","property","prototype","type","String","reflect","Number","Boolean","query","customElement"],"mappings":"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"}
package/dist/textarea.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";require("./textarea-DHrkcyt8.cjs");
1
+ "use strict";require("./textarea-Cm_0BDw5.cjs");
2
2
  //# sourceMappingURL=textarea.cjs.map