@mhmo91/schmancy 0.10.41 → 0.10.43

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 (764) hide show
  1. package/custom-elements.json +291 -179
  2. package/dist/SchmancyElement-CeKrBW2j.cjs +2 -0
  3. package/dist/SchmancyElement-CeKrBW2j.cjs.map +1 -0
  4. package/dist/SchmancyElement-Ob9yGkiG.js +286 -0
  5. package/dist/SchmancyElement-Ob9yGkiG.js.map +1 -0
  6. package/dist/agent/schmancy.agent.js +4057 -4082
  7. package/dist/agent/schmancy.agent.js.map +1 -1
  8. package/dist/agent/schmancy.manifest.json +225 -94
  9. package/dist/animation-CCOIW4wJ.cjs.map +1 -1
  10. package/dist/animation-DCznELuT.js.map +1 -1
  11. package/dist/area-CbajcnmJ.cjs +21 -0
  12. package/dist/area-CbajcnmJ.cjs.map +1 -0
  13. package/dist/{area-BiM7V2ns.js → area-MxLAyWgV.js} +22 -22
  14. package/dist/area-MxLAyWgV.js.map +1 -0
  15. package/dist/area.cjs +1 -1
  16. package/dist/area.js +1 -1
  17. package/dist/{audio-CxO_j__6.js → audio-B_0PGwYC.js} +1 -1
  18. package/dist/audio-B_0PGwYC.js.map +1 -0
  19. package/dist/{audio-xXFfMPCS.cjs → audio-CpwrIaw-.cjs} +1 -1
  20. package/dist/audio-CpwrIaw-.cjs.map +1 -0
  21. package/dist/audio.cjs +1 -1
  22. package/dist/audio.js +2 -2
  23. package/dist/autocomplete-CILzaDB7.cjs +115 -0
  24. package/dist/autocomplete-CILzaDB7.cjs.map +1 -0
  25. package/dist/{autocomplete-DUBY9RtH.js → autocomplete-DV9RxCun.js} +113 -113
  26. package/dist/autocomplete-DV9RxCun.js.map +1 -0
  27. package/dist/autocomplete.cjs +1 -1
  28. package/dist/autocomplete.js +1 -1
  29. package/dist/avatar.cjs +1 -1
  30. package/dist/avatar.cjs.map +1 -1
  31. package/dist/avatar.js +4 -4
  32. package/dist/avatar.js.map +1 -1
  33. package/dist/badge.cjs +1 -1
  34. package/dist/badge.js +1 -1
  35. package/dist/{boat-ScvAima3.js → boat-DoZGgQ0P.js} +6 -8
  36. package/dist/{boat-ScvAima3.js.map → boat-DoZGgQ0P.js.map} +1 -1
  37. package/dist/{boat-BIYaPAHp.cjs → boat-sg0cWO8a.cjs} +3 -5
  38. package/dist/{boat-BIYaPAHp.cjs.map → boat-sg0cWO8a.cjs.map} +1 -1
  39. package/dist/boat.cjs +1 -1
  40. package/dist/boat.js +1 -1
  41. package/dist/breadcrumb.cjs +32 -31
  42. package/dist/breadcrumb.cjs.map +1 -1
  43. package/dist/breadcrumb.js +33 -32
  44. package/dist/breadcrumb.js.map +1 -1
  45. package/dist/busy-Brs-TDh9.cjs +133 -0
  46. package/dist/busy-Brs-TDh9.cjs.map +1 -0
  47. package/dist/busy-g4LoQmhB.js +172 -0
  48. package/dist/busy-g4LoQmhB.js.map +1 -0
  49. package/dist/busy.cjs +1 -1
  50. package/dist/busy.js +1 -1
  51. package/dist/{button-BTpxQ1Kd.cjs → button-Cml67Y_d.cjs} +41 -32
  52. package/dist/button-Cml67Y_d.cjs.map +1 -0
  53. package/dist/{button-D7QHfYf4.js → button-DWANpZfD.js} +43 -34
  54. package/dist/button-DWANpZfD.js.map +1 -0
  55. package/dist/button.cjs +40 -33
  56. package/dist/button.cjs.map +1 -1
  57. package/dist/button.js +42 -35
  58. package/dist/button.js.map +1 -1
  59. package/dist/calendar-2dJrw9pR.cjs +58 -0
  60. package/dist/calendar-2dJrw9pR.cjs.map +1 -0
  61. package/dist/calendar-kCe5LaBa.js +434 -0
  62. package/dist/calendar-kCe5LaBa.js.map +1 -0
  63. package/dist/calendar.cjs +1 -0
  64. package/dist/calendar.js +2 -0
  65. package/dist/{card-DCdtJ5Dy.js → card-CS_hYJbz.js} +136 -136
  66. package/dist/card-CS_hYJbz.js.map +1 -0
  67. package/dist/card-d0KhTnx5.cjs +177 -0
  68. package/dist/card-d0KhTnx5.cjs.map +1 -0
  69. package/dist/card.cjs +1 -1
  70. package/dist/card.js +1 -1
  71. package/dist/{checkbox-DVtyPk7l.js → checkbox-Bjp7kWuE.js} +2 -2
  72. package/dist/{checkbox-DVtyPk7l.js.map → checkbox-Bjp7kWuE.js.map} +1 -1
  73. package/dist/{checkbox-CYGOVPP-.cjs → checkbox-DZ2Wrz7Y.cjs} +1 -1
  74. package/dist/{checkbox-CYGOVPP-.cjs.map → checkbox-DZ2Wrz7Y.cjs.map} +1 -1
  75. package/dist/checkbox.cjs +1 -1
  76. package/dist/checkbox.js +1 -1
  77. package/dist/{chips-DVes-BSz.cjs → chips-BHBVkxsa.cjs} +142 -153
  78. package/dist/chips-BHBVkxsa.cjs.map +1 -0
  79. package/dist/{chips-C5bpgWyf.js → chips-DACeW7YL.js} +127 -138
  80. package/dist/chips-DACeW7YL.js.map +1 -0
  81. package/dist/chips.cjs +1 -1
  82. package/dist/chips.js +2 -2
  83. package/dist/connectivity.cjs +54 -38
  84. package/dist/connectivity.cjs.map +1 -1
  85. package/dist/connectivity.js +56 -40
  86. package/dist/connectivity.js.map +1 -1
  87. package/dist/content-drawer.cjs +1 -1
  88. package/dist/content-drawer.js +1 -1
  89. package/dist/cursor-glow-Ah7VXSj7.js.map +1 -1
  90. package/dist/cursor-glow-Bulq-38P.cjs.map +1 -1
  91. package/dist/date-range-CVAWMdar.cjs +138 -0
  92. package/dist/date-range-CVAWMdar.cjs.map +1 -0
  93. package/dist/date-range-D2NZU5Yg.js +433 -0
  94. package/dist/date-range-D2NZU5Yg.js.map +1 -0
  95. package/dist/{date-range-inline-Dx4Reboo.cjs → date-range-inline-CGM0SPK9.cjs} +2 -4
  96. package/dist/date-range-inline-CGM0SPK9.cjs.map +1 -0
  97. package/dist/{date-range-inline-DPqY9YYf.js → date-range-inline-D6Ozerzw.js} +3 -5
  98. package/dist/date-range-inline-D6Ozerzw.js.map +1 -0
  99. package/dist/date-range-inline.cjs +1 -1
  100. package/dist/date-range-inline.js +1 -1
  101. package/dist/date-range.cjs +1 -1
  102. package/dist/date-range.js +2 -2
  103. package/dist/dayjs.min-CvRZTfam.cjs +1 -0
  104. package/dist/dayjs.min-CvRZTfam.cjs.map +1 -0
  105. package/dist/dayjs.min-DnELezPs.js +296 -0
  106. package/dist/dayjs.min-DnELezPs.js.map +1 -0
  107. package/dist/delay.cjs +1 -1
  108. package/dist/delay.js +3 -3
  109. package/dist/{details-BnleHmYe.js → details-Ct1_GwKr.js} +104 -92
  110. package/dist/details-Ct1_GwKr.js.map +1 -0
  111. package/dist/{details-Bx2jSJxG.cjs → details-D4fVOaj4.cjs} +109 -97
  112. package/dist/details-D4fVOaj4.cjs.map +1 -0
  113. package/dist/details.cjs +1 -1
  114. package/dist/details.js +1 -1
  115. package/dist/{directives-CYf2fAdA.cjs → directives-B2VxfwRL.cjs} +1 -1
  116. package/dist/directives-B2VxfwRL.cjs.map +1 -0
  117. package/dist/{directives-d1rEbW1A.js → directives-Dj8jlv-Q.js} +3 -3
  118. package/dist/directives-Dj8jlv-Q.js.map +1 -0
  119. package/dist/directives.cjs +1 -1
  120. package/dist/directives.js +2 -2
  121. package/dist/discovery.service-CIa3Eeuk.cjs.map +1 -1
  122. package/dist/discovery.service-DZFxtRwW.js.map +1 -1
  123. package/dist/divider-B3v33OnX.cjs +57 -0
  124. package/dist/divider-B3v33OnX.cjs.map +1 -0
  125. package/dist/divider-BJHW3q11.js +89 -0
  126. package/dist/divider-BJHW3q11.js.map +1 -0
  127. package/dist/divider.cjs +1 -1
  128. package/dist/divider.js +1 -1
  129. package/dist/dropdown.cjs +40 -40
  130. package/dist/dropdown.cjs.map +1 -1
  131. package/dist/dropdown.js +41 -41
  132. package/dist/dropdown.js.map +1 -1
  133. package/dist/{expand-DNrWuG_-.js → expand-BT8mOu8Q.js} +103 -97
  134. package/dist/expand-BT8mOu8Q.js.map +1 -0
  135. package/dist/expand-D0YdR9nR.cjs +147 -0
  136. package/dist/expand-D0YdR9nR.cjs.map +1 -0
  137. package/dist/expand.cjs +1 -1
  138. package/dist/expand.js +1 -1
  139. package/dist/fab.cjs +1 -1
  140. package/dist/fab.cjs.map +1 -1
  141. package/dist/fab.js +2 -2
  142. package/dist/fab.js.map +1 -1
  143. package/dist/{float-V7VQKTb8.cjs → float-BPQlDyai.cjs} +1 -1
  144. package/dist/{float-V7VQKTb8.cjs.map → float-BPQlDyai.cjs.map} +1 -1
  145. package/dist/{float-C_CMle0q.js → float-BQcxj3i_.js} +2 -2
  146. package/dist/{float-C_CMle0q.js.map → float-BQcxj3i_.js.map} +1 -1
  147. package/dist/float.cjs +1 -1
  148. package/dist/float.js +1 -1
  149. package/dist/{form-DaaAQd2A.cjs → form-CoWFnClb.cjs} +8 -13
  150. package/dist/form-CoWFnClb.cjs.map +1 -0
  151. package/dist/{form-CMgYSZ3y.js → form-hC2LvCHX.js} +10 -15
  152. package/dist/form-hC2LvCHX.js.map +1 -0
  153. package/dist/form.cjs +12 -13
  154. package/dist/form.cjs.map +1 -1
  155. package/dist/form.js +23 -24
  156. package/dist/form.js.map +1 -1
  157. package/dist/gravity-6pL6CfIr.cjs.map +1 -1
  158. package/dist/gravity-sVK3zGBF.js.map +1 -1
  159. package/dist/handover/agent-runtime-followups.md +1 -1
  160. package/dist/handover/agent-runtime-v1.md +3 -3
  161. package/dist/{hashContent-iRZJJWtE.cjs.map → hashContent--s09Ed_g.cjs.map} +1 -1
  162. package/dist/{hashContent-BqU6v1Xr.js.map → hashContent-CAvrQ56N.js.map} +1 -1
  163. package/dist/icons-BeGKDZ-k.cjs +22 -0
  164. package/dist/icons-BeGKDZ-k.cjs.map +1 -0
  165. package/dist/{icons-mbpHO_73.js → icons-DEJnIxml.js} +20 -22
  166. package/dist/icons-DEJnIxml.js.map +1 -0
  167. package/dist/icons.cjs +1 -1
  168. package/dist/icons.js +1 -1
  169. package/dist/{iframe-88SN5JPu.cjs → iframe-BkSukM9C.cjs} +9 -9
  170. package/dist/iframe-BkSukM9C.cjs.map +1 -0
  171. package/dist/{iframe-U3P1DnQv.js → iframe-V3S-bwEY.js} +10 -10
  172. package/dist/iframe-V3S-bwEY.js.map +1 -0
  173. package/dist/iframe.cjs +1 -1
  174. package/dist/iframe.js +1 -1
  175. package/dist/index.cjs +1 -1
  176. package/dist/index.js +61 -60
  177. package/dist/{input-CPWvGjE4.js → input-CPFCSQld.js} +3 -10
  178. package/dist/input-CPFCSQld.js.map +1 -0
  179. package/dist/{input-BY4Korc5.cjs → input-DSfwfhhj.cjs} +2 -9
  180. package/dist/input-DSfwfhhj.cjs.map +1 -0
  181. package/dist/input-chip-BUuFJUky.cjs +129 -0
  182. package/dist/input-chip-BUuFJUky.cjs.map +1 -0
  183. package/dist/{input-chip-CCZ3i3Sf.js → input-chip-C3a1fwKB.js} +87 -104
  184. package/dist/input-chip-C3a1fwKB.js.map +1 -0
  185. package/dist/input.cjs +1 -1
  186. package/dist/input.js +1 -1
  187. package/dist/json.cjs +5 -1
  188. package/dist/json.cjs.map +1 -1
  189. package/dist/json.js +8 -4
  190. package/dist/json.js.map +1 -1
  191. package/dist/kbd.cjs +28 -28
  192. package/dist/kbd.cjs.map +1 -1
  193. package/dist/kbd.js +29 -29
  194. package/dist/kbd.js.map +1 -1
  195. package/dist/{layout-BhfC26Ks.cjs → layout-CdyHy_oX.cjs} +1 -1
  196. package/dist/layout-CdyHy_oX.cjs.map +1 -0
  197. package/dist/{layout-DC0Npqu7.js → layout-k6fOkpif.js} +1 -1
  198. package/dist/layout-k6fOkpif.js.map +1 -0
  199. package/dist/layout.cjs +26 -26
  200. package/dist/layout.cjs.map +1 -1
  201. package/dist/layout.js +27 -27
  202. package/dist/layout.js.map +1 -1
  203. package/dist/lazy-BaAiIUru.js.map +1 -1
  204. package/dist/lazy-C-7a4FAe.cjs.map +1 -1
  205. package/dist/{lightbox-BSwWvDQc.js → lightbox-DIG0VLOK.js} +8 -14
  206. package/dist/lightbox-DIG0VLOK.js.map +1 -0
  207. package/dist/{lightbox-KrZQH9w9.cjs → lightbox-E5rgd-hu.cjs} +7 -13
  208. package/dist/lightbox-E5rgd-hu.cjs.map +1 -0
  209. package/dist/lightbox.cjs +1 -1
  210. package/dist/lightbox.js +1 -1
  211. package/dist/list-BRz0rDSH.cjs +47 -0
  212. package/dist/list-BRz0rDSH.cjs.map +1 -0
  213. package/dist/{list-BwGtAAfi.js → list-NrOYDPBo.js} +48 -34
  214. package/dist/list-NrOYDPBo.js.map +1 -0
  215. package/dist/list.cjs +1 -1
  216. package/dist/list.js +1 -1
  217. package/dist/magnetic-DKtc4umC.cjs.map +1 -1
  218. package/dist/magnetic-DaOOv5Dz.js.map +1 -1
  219. package/dist/{menu-DX8d96x-.js → menu-B1Ei9SVj.js} +12 -12
  220. package/dist/menu-B1Ei9SVj.js.map +1 -0
  221. package/dist/{menu-jT_yAk5V.cjs → menu-Duvl66Nl.cjs} +10 -10
  222. package/dist/menu-Duvl66Nl.cjs.map +1 -0
  223. package/dist/menu.cjs +1 -1
  224. package/dist/menu.js +1 -1
  225. package/dist/{mixins-XGVIOvKt.cjs → mixins-Cjn20BQH.cjs} +42 -170
  226. package/dist/mixins-Cjn20BQH.cjs.map +1 -0
  227. package/dist/{mixins-COeG4DiX.js → mixins-q4KAL8Xr.js} +43 -177
  228. package/dist/mixins-q4KAL8Xr.js.map +1 -0
  229. package/dist/mixins.cjs +1 -1
  230. package/dist/mixins.js +2 -2
  231. package/dist/nav-drawer.cjs +1 -1
  232. package/dist/nav-drawer.js +1 -1
  233. package/dist/navigation-bar.cjs +1 -1
  234. package/dist/navigation-bar.js +1 -1
  235. package/dist/navigation-rail.cjs +2 -4
  236. package/dist/navigation-rail.cjs.map +1 -1
  237. package/dist/navigation-rail.js +3 -5
  238. package/dist/navigation-rail.js.map +1 -1
  239. package/dist/{notification-CAJVpLne.js → notification-COhUhUCr.js} +5 -7
  240. package/dist/notification-COhUhUCr.js.map +1 -0
  241. package/dist/{notification-DO3VXceY.cjs → notification-DsdA_MJe.cjs} +2 -4
  242. package/dist/notification-DsdA_MJe.cjs.map +1 -0
  243. package/dist/notification.cjs +1 -1
  244. package/dist/notification.js +1 -1
  245. package/dist/{option-JISY0wZJ.js → option-BIzgTbXz.js} +20 -20
  246. package/dist/option-BIzgTbXz.js.map +1 -0
  247. package/dist/option-C5hhqR2z.cjs +43 -0
  248. package/dist/option-C5hhqR2z.cjs.map +1 -0
  249. package/dist/option.cjs +1 -1
  250. package/dist/option.js +1 -1
  251. package/dist/{overlay-B1jVf-ge.cjs → overlay-BzgF8P7i.cjs} +48 -41
  252. package/dist/overlay-BzgF8P7i.cjs.map +1 -0
  253. package/dist/{overlay-CT-tMHDX.js → overlay-LoRRemny.js} +52 -45
  254. package/dist/overlay-LoRRemny.js.map +1 -0
  255. package/dist/overlay-stack-Bdr9lOqi.cjs.map +1 -1
  256. package/dist/overlay-stack-D2rgxQLh.js.map +1 -1
  257. package/dist/overlay.cjs +1 -1
  258. package/dist/{overlay.confirm-body-Dn-Zgogx.js → overlay.confirm-body-D0b1MoCw.js} +30 -45
  259. package/dist/overlay.confirm-body-D0b1MoCw.js.map +1 -0
  260. package/dist/{overlay.confirm-body-mYDYoJL8.cjs → overlay.confirm-body-DCneq73Z.cjs} +22 -37
  261. package/dist/overlay.confirm-body-DCneq73Z.cjs.map +1 -0
  262. package/dist/overlay.js +3 -3
  263. package/dist/{overlay.service-yqTOyLlr.js → overlay.service-BuUeti6X.js} +2 -2
  264. package/dist/overlay.service-BuUeti6X.js.map +1 -0
  265. package/dist/{overlay.service-BQmva9GY.cjs → overlay.service-MMTiW2T3.cjs} +1 -1
  266. package/dist/overlay.service-MMTiW2T3.cjs.map +1 -0
  267. package/dist/{progress-CGWozq_n.js → progress-D7n3SKAO.js} +50 -50
  268. package/dist/progress-D7n3SKAO.js.map +1 -0
  269. package/dist/progress-DsCnFsH5.cjs +51 -0
  270. package/dist/progress-DsCnFsH5.cjs.map +1 -0
  271. package/dist/progress.cjs +1 -1
  272. package/dist/progress.js +1 -1
  273. package/dist/{radio-group-DoSX5D2V.cjs → radio-group-CaAjg9UV.cjs} +1 -1
  274. package/dist/radio-group-CaAjg9UV.cjs.map +1 -0
  275. package/dist/{radio-group-CXkq6qAF.js → radio-group-Drpl6Pl8.js} +2 -2
  276. package/dist/radio-group-Drpl6Pl8.js.map +1 -0
  277. package/dist/radio-group.cjs +1 -1
  278. package/dist/radio-group.js +1 -1
  279. package/dist/range.cjs +4 -2
  280. package/dist/range.cjs.map +1 -1
  281. package/dist/range.js +5 -3
  282. package/dist/range.js.map +1 -1
  283. package/dist/reduced-motion-D-L12p7G.js.map +1 -1
  284. package/dist/reduced-motion-Ds-HjMzn.cjs.map +1 -1
  285. package/dist/{rxjs-utils-Csnks202.cjs.map → rxjs-utils-4P2v57ke.cjs.map} +1 -1
  286. package/dist/{rxjs-utils-d-ivVN84.js.map → rxjs-utils-JMFdgQSl.js.map} +1 -1
  287. package/dist/rxjs-utils.cjs +1 -1
  288. package/dist/rxjs-utils.js +1 -1
  289. package/dist/search-DPKoC-dT.cjs.map +1 -1
  290. package/dist/search-MvIBA93K.js.map +1 -1
  291. package/dist/{select-CU90i50_.js → select-CTXkrrVZ.js} +13 -13
  292. package/dist/select-CTXkrrVZ.js.map +1 -0
  293. package/dist/select-DcLcpPCh.cjs +56 -0
  294. package/dist/select-DcLcpPCh.cjs.map +1 -0
  295. package/dist/select.cjs +1 -1
  296. package/dist/select.js +1 -1
  297. package/dist/skeleton.cjs +37 -33
  298. package/dist/skeleton.cjs.map +1 -1
  299. package/dist/skeleton.js +38 -34
  300. package/dist/skeleton.js.map +1 -1
  301. package/dist/skills/schmancy/surface.md +79 -39
  302. package/dist/skills/surface.md +79 -39
  303. package/dist/slider.cjs +31 -31
  304. package/dist/slider.cjs.map +1 -1
  305. package/dist/slider.js +32 -32
  306. package/dist/slider.js.map +1 -1
  307. package/dist/{sound.service-m8WjOhjn.js → sound.service-AJwuk3yr.js} +1 -1
  308. package/dist/sound.service-AJwuk3yr.js.map +1 -0
  309. package/dist/{sound.service-Qhr8nCeG.cjs → sound.service-CVsxhQkX.cjs} +1 -1
  310. package/dist/sound.service-CVsxhQkX.cjs.map +1 -0
  311. package/dist/{splash-screen-Cs3dbPN3.js → splash-screen-DANfqvlo.js} +23 -26
  312. package/dist/splash-screen-DANfqvlo.js.map +1 -0
  313. package/dist/splash-screen-K74cgU6S.cjs +38 -0
  314. package/dist/splash-screen-K74cgU6S.cjs.map +1 -0
  315. package/dist/splash-screen.cjs +1 -1
  316. package/dist/splash-screen.js +1 -1
  317. package/dist/{src-CCVbLLgC.js → src-DAtcPmCb.js} +295 -389
  318. package/dist/src-DAtcPmCb.js.map +1 -0
  319. package/dist/src-DuRvYagm.cjs +237 -0
  320. package/dist/src-DuRvYagm.cjs.map +1 -0
  321. package/dist/{state--x58-AuK.cjs → state-BWQiqN6I.cjs} +1 -1
  322. package/dist/state-BWQiqN6I.cjs.map +1 -0
  323. package/dist/{state-QSwQ61sA.js → state-DBA_gzJO.js} +1 -1
  324. package/dist/state-DBA_gzJO.js.map +1 -0
  325. package/dist/state.cjs +1 -1
  326. package/dist/state.js +2 -2
  327. package/dist/steps.cjs +20 -12
  328. package/dist/steps.cjs.map +1 -1
  329. package/dist/steps.js +21 -13
  330. package/dist/steps.js.map +1 -1
  331. package/dist/surface-COBvWWFb.cjs +7 -0
  332. package/dist/surface-COBvWWFb.cjs.map +1 -0
  333. package/dist/{surface-cqMsHJHM.js → surface-DXk1X1tL.js} +9 -9
  334. package/dist/surface-DXk1X1tL.js.map +1 -0
  335. package/dist/surface.cjs +1 -1
  336. package/dist/surface.js +1 -1
  337. package/dist/switch.cjs +13 -4
  338. package/dist/switch.cjs.map +1 -1
  339. package/dist/switch.js +14 -5
  340. package/dist/switch.js.map +1 -1
  341. package/dist/table.cjs +4 -10
  342. package/dist/table.cjs.map +1 -1
  343. package/dist/table.js +5 -11
  344. package/dist/table.js.map +1 -1
  345. package/dist/{tabs-Ib0Mh__1.js → tabs-BYhFWnsx.js} +7 -7
  346. package/dist/tabs-BYhFWnsx.js.map +1 -0
  347. package/dist/{tabs-Dk9UDWpq.cjs → tabs-CJwB0fr0.cjs} +6 -6
  348. package/dist/tabs-CJwB0fr0.cjs.map +1 -0
  349. package/dist/tabs.cjs +1 -1
  350. package/dist/tabs.js +1 -1
  351. package/dist/teleport.cjs +1 -1
  352. package/dist/teleport.js +1 -1
  353. package/dist/{textarea-CcRsw08B.js → textarea-BjDx1w2g.js} +37 -41
  354. package/dist/textarea-BjDx1w2g.js.map +1 -0
  355. package/dist/{textarea-Cntd9tfV.cjs → textarea-CGgznhd6.cjs} +36 -40
  356. package/dist/textarea-CGgznhd6.cjs.map +1 -0
  357. package/dist/textarea.cjs +1 -1
  358. package/dist/textarea.js +1 -1
  359. package/dist/{theme-wwFbvp5e.cjs → theme-BVul7lHS.cjs} +6 -6
  360. package/dist/{theme-wwFbvp5e.cjs.map → theme-BVul7lHS.cjs.map} +1 -1
  361. package/dist/{theme-CKYXG0le.js → theme-Dvm5J8nh.js} +11 -11
  362. package/dist/{theme-CKYXG0le.js.map → theme-Dvm5J8nh.js.map} +1 -1
  363. package/dist/{theme-button-iLqT56KA.js → theme-button-Bko5ohFP.js} +2 -2
  364. package/dist/{theme-button-iLqT56KA.js.map → theme-button-Bko5ohFP.js.map} +1 -1
  365. package/dist/{theme-button-DE9Lrl7m.cjs → theme-button-YLY7zR1c.cjs} +1 -1
  366. package/dist/{theme-button-DE9Lrl7m.cjs.map → theme-button-YLY7zR1c.cjs.map} +1 -1
  367. package/dist/theme-button.cjs +1 -1
  368. package/dist/theme-button.js +1 -1
  369. package/dist/theme.cjs +1 -1
  370. package/dist/{theme.interface-CSt7JUBD.cjs.map → theme.interface-B-qxDsZQ.cjs.map} +1 -1
  371. package/dist/{theme.interface-odQEpZZH.js.map → theme.interface-B7caS5cg.js.map} +1 -1
  372. package/dist/theme.js +4 -4
  373. package/dist/{theme.service-5RjyR7Sy.js → theme.service-D94nm7Bf.js} +1 -1
  374. package/dist/theme.service-D94nm7Bf.js.map +1 -0
  375. package/dist/{theme.service-DA6KY52G.cjs → theme.service-h2fXQq7x.cjs} +1 -1
  376. package/dist/theme.service-h2fXQq7x.cjs.map +1 -0
  377. package/dist/tooltip.cjs.map +1 -1
  378. package/dist/tooltip.js.map +1 -1
  379. package/dist/tree.cjs +14 -14
  380. package/dist/tree.cjs.map +1 -1
  381. package/dist/tree.js +15 -15
  382. package/dist/tree.js.map +1 -1
  383. package/dist/types.cjs +1 -1
  384. package/dist/types.cjs.map +1 -1
  385. package/dist/types.js +19 -2
  386. package/dist/types.js.map +1 -1
  387. package/dist/typewriter.cjs.map +1 -1
  388. package/dist/typewriter.js.map +1 -1
  389. package/dist/typography-ByF2k5yW.js +358 -0
  390. package/dist/typography-ByF2k5yW.js.map +1 -0
  391. package/dist/typography-Cfav17it.cjs +282 -0
  392. package/dist/typography-Cfav17it.cjs.map +1 -0
  393. package/dist/typography.cjs +1 -1
  394. package/dist/typography.js +1 -1
  395. package/dist/utils-DIXndz6Q.cjs.map +1 -0
  396. package/dist/utils-dSPH7Oh9.js.map +1 -0
  397. package/dist/utils.cjs +1 -1
  398. package/dist/utils.js +1 -1
  399. package/dist/visually-hidden.cjs +13 -13
  400. package/dist/visually-hidden.cjs.map +1 -1
  401. package/dist/visually-hidden.js +14 -14
  402. package/dist/visually-hidden.js.map +1 -1
  403. package/dist/window-Br1OmpL-.cjs +67 -0
  404. package/dist/window-Br1OmpL-.cjs.map +1 -0
  405. package/dist/{window-Db5ZYY6t.js → window-CCmN4but.js} +28 -20
  406. package/dist/window-CCmN4but.js.map +1 -0
  407. package/dist/window.cjs +1 -1
  408. package/dist/window.js +1 -1
  409. package/package.json +1 -1
  410. package/skills/schmancy/surface.md +79 -39
  411. package/src/area/area.component.ts +249 -163
  412. package/src/area/area.service.test.ts +994 -1006
  413. package/src/area/area.service.ts +76 -72
  414. package/src/area/index.ts +7 -7
  415. package/src/area/lazy.ts +39 -42
  416. package/src/area/route.component.ts +54 -52
  417. package/src/area/router.types.ts +7 -7
  418. package/src/audio/emotional-sounds.ts +880 -801
  419. package/src/audio/sound.service.ts +26 -5
  420. package/src/avatar/avatar.ts +4 -4
  421. package/src/badge/badge.ts +60 -209
  422. package/src/badge/index.ts +1 -1
  423. package/src/boat/boat.ts +2 -4
  424. package/src/breadcrumb/breadcrumb.ts +37 -32
  425. package/src/busy/busy.ts +15 -12
  426. package/src/busy/index.ts +2 -2
  427. package/src/busy/spinner.ts +132 -119
  428. package/src/button/button.test.ts +5 -1
  429. package/src/button/button.ts +113 -72
  430. package/src/button/icon-button.ts +64 -46
  431. package/src/button/index.ts +2 -2
  432. package/src/calendar/calendar.test.ts +504 -0
  433. package/src/calendar/calendar.ts +587 -0
  434. package/src/calendar/index.ts +2 -0
  435. package/src/card/actions.ts +11 -9
  436. package/src/card/card.ts +79 -77
  437. package/src/card/content.ts +8 -6
  438. package/src/card/index.ts +4 -4
  439. package/src/card/media.ts +50 -50
  440. package/src/chips/assist-chip.ts +1 -1
  441. package/src/chips/chips.ts +1 -1
  442. package/src/chips/filter-chip.ts +1 -1
  443. package/src/chips/index.ts +1 -1
  444. package/src/chips/input-chip.ts +1 -1
  445. package/src/chips/suggestion-chip.ts +1 -1
  446. package/src/connectivity/connectivity-status.ts +91 -65
  447. package/src/content-drawer/drawer.service.ts +47 -36
  448. package/src/content-drawer/drawer.ts +31 -18
  449. package/src/content-drawer/index.ts +5 -5
  450. package/src/content-drawer/main.ts +9 -7
  451. package/src/content-drawer/sheet.ts +8 -6
  452. package/src/date-range-inline/date-range-inline.ts +523 -522
  453. package/src/date-range-inline/index.ts +2 -2
  454. package/src/delay/index.ts +1 -1
  455. package/src/details/details.ts +119 -105
  456. package/src/details/index.ts +1 -1
  457. package/src/directives/ai-badge.ts +1 -5
  458. package/src/directives/animate-text.ts +43 -31
  459. package/src/directives/art/effects/howl.ts +1 -4
  460. package/src/directives/art/effects/samwa.ts +11 -5
  461. package/src/directives/art/effects/snow.ts +1 -2
  462. package/src/directives/battery.ts +21 -12
  463. package/src/directives/confirm-click.ts +9 -17
  464. package/src/directives/cursor-glow.ts +1 -1
  465. package/src/directives/cycle-text.ts +7 -21
  466. package/src/directives/drag.ts +50 -45
  467. package/src/directives/fyi.ts +1 -6
  468. package/src/directives/gravity.ts +10 -8
  469. package/src/directives/hummingbird.ts +256 -107
  470. package/src/directives/index.ts +29 -29
  471. package/src/directives/intersect.ts +11 -11
  472. package/src/directives/layout.ts +25 -36
  473. package/src/directives/liquid.ts +4 -10
  474. package/src/directives/living-border.ts +7 -5
  475. package/src/directives/long-press.ts +2 -1
  476. package/src/directives/magnetic.ts +7 -6
  477. package/src/directives/nebula.ts +34 -28
  478. package/src/directives/overflow-within.ts +18 -20
  479. package/src/directives/reduced-motion.ts +9 -9
  480. package/src/directives/reveal.ts +193 -195
  481. package/src/directives/ripple.ts +9 -7
  482. package/src/directives/urgent.ts +3 -1
  483. package/src/directives/working-snake.ts +1 -1
  484. package/src/discovery/discovery.service.ts +198 -210
  485. package/src/discovery/index.ts +1 -1
  486. package/src/divider/divider.ts +49 -47
  487. package/src/divider/index.ts +1 -1
  488. package/src/dropdown/dropdown-content.ts +42 -40
  489. package/src/dropdown/index.ts +2 -2
  490. package/src/expand/expand-root.component.ts +70 -61
  491. package/src/expand/expand.component.ts +48 -43
  492. package/src/fab/fab.test.ts +1 -2
  493. package/src/fab/fab.ts +2 -4
  494. package/src/form/fields/autocomplete/autocomplete.scss +6 -2
  495. package/src/form/fields/autocomplete/autocomplete.ts +712 -724
  496. package/src/form/fields/autocomplete/index.ts +1 -1
  497. package/src/form/fields/checkbox/checkbox.ts +1 -4
  498. package/src/form/fields/chips/assist-chip.ts +69 -72
  499. package/src/form/fields/chips/chips.ts +14 -15
  500. package/src/form/fields/chips/filter-chip.ts +36 -32
  501. package/src/form/fields/chips/index.ts +5 -5
  502. package/src/form/fields/chips/input-chip.ts +130 -142
  503. package/src/form/fields/chips/suggestion-chip.ts +69 -72
  504. package/src/form/fields/date-range/date-range-dialog.ts +141 -194
  505. package/src/form/fields/date-range/date-range-helpers.ts +63 -64
  506. package/src/form/fields/date-range/date-range.test.ts +359 -122
  507. package/src/form/fields/date-range/date-range.ts +319 -395
  508. package/src/form/fields/date-range/index.ts +2 -2
  509. package/src/form/fields/input/index.ts +8 -8
  510. package/src/form/fields/input/input.scss +30 -26
  511. package/src/form/fields/input/input.test.ts +4 -1
  512. package/src/form/fields/input/input.ts +4 -20
  513. package/src/form/fields/radio-group/index.ts +2 -2
  514. package/src/form/fields/radio-group/radio-button.ts +8 -8
  515. package/src/form/fields/radio-group/radio-group.ts +4 -1
  516. package/src/form/fields/range/range.ts +3 -1
  517. package/src/form/fields/select/index.ts +2 -2
  518. package/src/form/fields/select/select.ts +51 -45
  519. package/src/form/fields/switch/switch.ts +13 -7
  520. package/src/form/fields/textarea/index.ts +1 -1
  521. package/src/form/fields/textarea/textarea.ts +44 -49
  522. package/src/form/form-summary.ts +15 -14
  523. package/src/form/form.test.ts +0 -1
  524. package/src/form/form.ts +11 -23
  525. package/src/icons/icon.ts +25 -25
  526. package/src/icons/index.ts +1 -1
  527. package/src/iframe/iframe.ts +11 -9
  528. package/src/index.ts +1 -0
  529. package/src/json/json.ts +9 -2
  530. package/src/kbd/kbd.ts +30 -28
  531. package/src/layout/scroll/index.ts +1 -1
  532. package/src/layout/scroll/scroll.ts +54 -54
  533. package/src/lightbox/lightbox-service.ts +27 -18
  534. package/src/lightbox/lightbox.directive.ts +2 -1
  535. package/src/lightbox/lightbox.ts +21 -38
  536. package/src/list/index.ts +3 -3
  537. package/src/list/list-item.ts +32 -26
  538. package/src/list/list.ts +13 -8
  539. package/src/menu/index.ts +2 -2
  540. package/src/menu/menu-item.ts +7 -5
  541. package/src/menu/menu.ts +8 -6
  542. package/src/nav-drawer/appbar.ts +9 -7
  543. package/src/nav-drawer/content.ts +10 -8
  544. package/src/nav-drawer/drawer.ts +29 -25
  545. package/src/nav-drawer/index.ts +6 -6
  546. package/src/navigation-bar/index.ts +2 -2
  547. package/src/navigation-bar/navigation-bar-item.ts +127 -118
  548. package/src/navigation-bar/navigation-bar.ts +103 -91
  549. package/src/navigation-rail/index.ts +2 -2
  550. package/src/navigation-rail/navigation-rail.ts +21 -22
  551. package/src/notification/index.ts +6 -6
  552. package/src/notification/notification-service.ts +1 -2
  553. package/src/notification/notification.scss +5 -1
  554. package/src/notification/notification.ts +1 -3
  555. package/src/notification/notify.ts +204 -207
  556. package/src/option/index.ts +1 -1
  557. package/src/option/option.ts +26 -25
  558. package/src/overlay/overlay.animations.ts +4 -14
  559. package/src/overlay/overlay.component.ts +110 -131
  560. package/src/overlay/overlay.confirm-body.ts +26 -48
  561. package/src/overlay/overlay.gestures.ts +8 -10
  562. package/src/overlay/overlay.layout.ts +1 -4
  563. package/src/overlay/overlay.positioning.ts +4 -15
  564. package/src/overlay/overlay.service.ts +9 -24
  565. package/src/overlay/overlay.stack.test.ts +4 -1
  566. package/src/overlay/overlay.stack.ts +4 -4
  567. package/src/overlay/overlay.types.ts +11 -20
  568. package/src/progress/index.ts +1 -1
  569. package/src/progress/progress.ts +135 -133
  570. package/src/rxjs-utils/index.ts +6 -6
  571. package/src/rxjs-utils/waitForElement.ts +20 -20
  572. package/src/rxjs-utils/waitForElementAll.ts +21 -21
  573. package/src/rxjs-utils/waitForElements.ts +27 -27
  574. package/src/rxjs-utils/waitForElementsAll.ts +27 -29
  575. package/src/rxjs-utils/waitUntil.ts +7 -12
  576. package/src/skeleton/skeleton.ts +39 -33
  577. package/src/slider/index.ts +2 -2
  578. package/src/slider/slide.ts +14 -12
  579. package/src/slider/slider.ts +24 -22
  580. package/src/splash-screen/index.ts +1 -1
  581. package/src/splash-screen/splash-screen.ts +26 -27
  582. package/src/state/active-host.ts +4 -5
  583. package/src/state/index.ts +34 -53
  584. package/src/state/persist.ts +14 -11
  585. package/src/state/schmancy-context.ts +88 -88
  586. package/src/state/state.test-d.ts +3 -13
  587. package/src/state/state.test.ts +1 -4
  588. package/src/steps/index.ts +3 -3
  589. package/src/steps/schmancy-step.ts +41 -31
  590. package/src/steps/schmancy-steps.ts +7 -5
  591. package/src/surface/index.ts +1 -1
  592. package/src/surface/surface.styles.ts +55 -191
  593. package/src/surface/surface.ts +18 -16
  594. package/src/table/index.ts +2 -2
  595. package/src/table/row.ts +1 -4
  596. package/src/table/table.ts +2 -5
  597. package/src/tabs/index.ts +2 -2
  598. package/src/tabs/tabs-group.ts +8 -6
  599. package/src/teleport/index.ts +2 -2
  600. package/src/test-utils/a11y.ts +1 -3
  601. package/src/theme/index.ts +17 -17
  602. package/src/theme/theme-audio-player.ts +18 -16
  603. package/src/theme/theme-controller-boat.ts +1 -1
  604. package/src/theme/theme-controller.ts +36 -32
  605. package/src/theme/theme.component.ts +5 -9
  606. package/src/theme/theme.events.ts +1 -1
  607. package/src/theme/theme.format.ts +7 -7
  608. package/src/theme/theme.service.ts +453 -468
  609. package/src/theme/theme.style.css +78 -23
  610. package/src/theme-button/index.ts +1 -1
  611. package/src/tooltip/tooltip.directive.ts +1 -1
  612. package/src/tree/index.ts +1 -1
  613. package/src/tree/tree.ts +24 -16
  614. package/src/types/surface.ts +38 -44
  615. package/src/typewriter/typewriter.directive.ts +30 -39
  616. package/src/typography/typography.ts +289 -269
  617. package/src/utils/animation.ts +2 -8
  618. package/src/utils/index.ts +6 -6
  619. package/src/utils/number.ts +480 -517
  620. package/src/utils/overlay-stack.ts +1 -3
  621. package/src/utils/search.ts +5 -9
  622. package/src/visually-hidden/visually-hidden.ts +15 -13
  623. package/src/window/window-manager.ts +6 -1
  624. package/src/window/window-position.ts +7 -5
  625. package/src/window/window.ts +146 -114
  626. package/types/mixins/surface.mixin.d.ts +8 -14
  627. package/types/src/badge/badge.d.ts +15 -48
  628. package/types/src/calendar/calendar.d.ts +108 -0
  629. package/types/src/calendar/calendar.test.d.ts +1 -0
  630. package/types/src/calendar/index.d.ts +2 -0
  631. package/types/src/directives/cursor-glow.d.ts +1 -1
  632. package/types/src/directives/hummingbird.d.ts +3 -3
  633. package/types/src/form/fields/date-range/date-range-dialog.d.ts +24 -28
  634. package/types/src/form/fields/date-range/date-range.d.ts +35 -66
  635. package/types/src/form/fields/date-range/date-range.test.d.ts +1 -0
  636. package/types/src/form/fields/date-range/index.d.ts +1 -1
  637. package/types/src/index.d.ts +1 -0
  638. package/types/src/surface/surface.d.ts +9 -7
  639. package/types/src/surface/surface.styles.d.ts +15 -20
  640. package/types/src/types/surface.d.ts +17 -22
  641. package/types/src/utils/number.d.ts +1 -1
  642. package/types/src/window/window.d.ts +0 -1
  643. package/dist/SchmancyElement-D9WA9FP9.cjs +0 -2
  644. package/dist/SchmancyElement-D9WA9FP9.cjs.map +0 -1
  645. package/dist/SchmancyElement-OWgz9ePG.js +0 -286
  646. package/dist/SchmancyElement-OWgz9ePG.js.map +0 -1
  647. package/dist/area-BiM7V2ns.js.map +0 -1
  648. package/dist/area-C7XjCoet.cjs +0 -21
  649. package/dist/area-C7XjCoet.cjs.map +0 -1
  650. package/dist/audio-CxO_j__6.js.map +0 -1
  651. package/dist/audio-xXFfMPCS.cjs.map +0 -1
  652. package/dist/autocomplete-DD7Hd59N.cjs +0 -115
  653. package/dist/autocomplete-DD7Hd59N.cjs.map +0 -1
  654. package/dist/autocomplete-DUBY9RtH.js.map +0 -1
  655. package/dist/busy-BjsO3y2A.js +0 -173
  656. package/dist/busy-BjsO3y2A.js.map +0 -1
  657. package/dist/busy-UbCGkTAi.cjs +0 -134
  658. package/dist/busy-UbCGkTAi.cjs.map +0 -1
  659. package/dist/button-BTpxQ1Kd.cjs.map +0 -1
  660. package/dist/button-D7QHfYf4.js.map +0 -1
  661. package/dist/card-DCdtJ5Dy.js.map +0 -1
  662. package/dist/card-rprhCYIC.cjs +0 -177
  663. package/dist/card-rprhCYIC.cjs.map +0 -1
  664. package/dist/chips-C5bpgWyf.js.map +0 -1
  665. package/dist/chips-DVes-BSz.cjs.map +0 -1
  666. package/dist/date-range-DDUuBlJ6.cjs +0 -142
  667. package/dist/date-range-DDUuBlJ6.cjs.map +0 -1
  668. package/dist/date-range-IPlbrhwW.js +0 -966
  669. package/dist/date-range-IPlbrhwW.js.map +0 -1
  670. package/dist/date-range-inline-DPqY9YYf.js.map +0 -1
  671. package/dist/date-range-inline-Dx4Reboo.cjs.map +0 -1
  672. package/dist/details-BnleHmYe.js.map +0 -1
  673. package/dist/details-Bx2jSJxG.cjs.map +0 -1
  674. package/dist/directives-CYf2fAdA.cjs.map +0 -1
  675. package/dist/directives-d1rEbW1A.js.map +0 -1
  676. package/dist/divider-CimQJVr3.cjs +0 -57
  677. package/dist/divider-CimQJVr3.cjs.map +0 -1
  678. package/dist/divider-Cr-rx3vA.js +0 -89
  679. package/dist/divider-Cr-rx3vA.js.map +0 -1
  680. package/dist/expand-DNrWuG_-.js.map +0 -1
  681. package/dist/expand-_cp8oBjp.cjs +0 -141
  682. package/dist/expand-_cp8oBjp.cjs.map +0 -1
  683. package/dist/form-CMgYSZ3y.js.map +0 -1
  684. package/dist/form-DaaAQd2A.cjs.map +0 -1
  685. package/dist/icons-C2RkSXjP.cjs +0 -24
  686. package/dist/icons-C2RkSXjP.cjs.map +0 -1
  687. package/dist/icons-mbpHO_73.js.map +0 -1
  688. package/dist/iframe-88SN5JPu.cjs.map +0 -1
  689. package/dist/iframe-U3P1DnQv.js.map +0 -1
  690. package/dist/input-BY4Korc5.cjs.map +0 -1
  691. package/dist/input-CPWvGjE4.js.map +0 -1
  692. package/dist/input-chip-CCZ3i3Sf.js.map +0 -1
  693. package/dist/input-chip-kytMdbaM.cjs +0 -146
  694. package/dist/input-chip-kytMdbaM.cjs.map +0 -1
  695. package/dist/layout-BhfC26Ks.cjs.map +0 -1
  696. package/dist/layout-DC0Npqu7.js.map +0 -1
  697. package/dist/lightbox-BSwWvDQc.js.map +0 -1
  698. package/dist/lightbox-KrZQH9w9.cjs.map +0 -1
  699. package/dist/list-BwGtAAfi.js.map +0 -1
  700. package/dist/list-DIs02A3d.cjs +0 -40
  701. package/dist/list-DIs02A3d.cjs.map +0 -1
  702. package/dist/menu-DX8d96x-.js.map +0 -1
  703. package/dist/menu-jT_yAk5V.cjs.map +0 -1
  704. package/dist/mixins-COeG4DiX.js.map +0 -1
  705. package/dist/mixins-XGVIOvKt.cjs.map +0 -1
  706. package/dist/notification-CAJVpLne.js.map +0 -1
  707. package/dist/notification-DO3VXceY.cjs.map +0 -1
  708. package/dist/option-BNo1Zs-l.cjs +0 -43
  709. package/dist/option-BNo1Zs-l.cjs.map +0 -1
  710. package/dist/option-JISY0wZJ.js.map +0 -1
  711. package/dist/overlay-B1jVf-ge.cjs.map +0 -1
  712. package/dist/overlay-CT-tMHDX.js.map +0 -1
  713. package/dist/overlay.confirm-body-Dn-Zgogx.js.map +0 -1
  714. package/dist/overlay.confirm-body-mYDYoJL8.cjs.map +0 -1
  715. package/dist/overlay.service-BQmva9GY.cjs.map +0 -1
  716. package/dist/overlay.service-yqTOyLlr.js.map +0 -1
  717. package/dist/progress-CGWozq_n.js.map +0 -1
  718. package/dist/progress-DOVJhsR0.cjs +0 -51
  719. package/dist/progress-DOVJhsR0.cjs.map +0 -1
  720. package/dist/radio-group-CXkq6qAF.js.map +0 -1
  721. package/dist/radio-group-DoSX5D2V.cjs.map +0 -1
  722. package/dist/select-CObZenqg.cjs +0 -56
  723. package/dist/select-CObZenqg.cjs.map +0 -1
  724. package/dist/select-CU90i50_.js.map +0 -1
  725. package/dist/sound.service-Qhr8nCeG.cjs.map +0 -1
  726. package/dist/sound.service-m8WjOhjn.js.map +0 -1
  727. package/dist/splash-screen-Ca6Ew8p6.cjs +0 -41
  728. package/dist/splash-screen-Ca6Ew8p6.cjs.map +0 -1
  729. package/dist/splash-screen-Cs3dbPN3.js.map +0 -1
  730. package/dist/src-CCVbLLgC.js.map +0 -1
  731. package/dist/src-CpftzdZV.cjs +0 -264
  732. package/dist/src-CpftzdZV.cjs.map +0 -1
  733. package/dist/state--x58-AuK.cjs.map +0 -1
  734. package/dist/state-QSwQ61sA.js.map +0 -1
  735. package/dist/surface-bTjOiq8n.cjs +0 -7
  736. package/dist/surface-bTjOiq8n.cjs.map +0 -1
  737. package/dist/surface-cqMsHJHM.js.map +0 -1
  738. package/dist/tabs-Dk9UDWpq.cjs.map +0 -1
  739. package/dist/tabs-Ib0Mh__1.js.map +0 -1
  740. package/dist/textarea-CcRsw08B.js.map +0 -1
  741. package/dist/textarea-Cntd9tfV.cjs.map +0 -1
  742. package/dist/theme.service-5RjyR7Sy.js.map +0 -1
  743. package/dist/theme.service-DA6KY52G.cjs.map +0 -1
  744. package/dist/typography-DeEYdMhW.js +0 -358
  745. package/dist/typography-DeEYdMhW.js.map +0 -1
  746. package/dist/typography-Tm7wSaB2.cjs +0 -282
  747. package/dist/typography-Tm7wSaB2.cjs.map +0 -1
  748. package/dist/utils-DTa3QHxk.cjs.map +0 -1
  749. package/dist/utils-H8wNknWC.js.map +0 -1
  750. package/dist/window-Db5ZYY6t.js.map +0 -1
  751. package/dist/window-oQqx5xqQ.cjs +0 -59
  752. package/dist/window-oQqx5xqQ.cjs.map +0 -1
  753. package/src/form/fields/date-range/date-range-presets.ts +0 -220
  754. package/src/form/fields/date-range/date-utils.ts +0 -58
  755. package/types/src/form/fields/date-range/date-range-presets.d.ts +0 -18
  756. package/types/src/form/fields/date-range/date-utils.d.ts +0 -15
  757. /package/dist/{hashContent-iRZJJWtE.cjs → hashContent--s09Ed_g.cjs} +0 -0
  758. /package/dist/{hashContent-BqU6v1Xr.js → hashContent-CAvrQ56N.js} +0 -0
  759. /package/dist/{rxjs-utils-Csnks202.cjs → rxjs-utils-4P2v57ke.cjs} +0 -0
  760. /package/dist/{rxjs-utils-d-ivVN84.js → rxjs-utils-JMFdgQSl.js} +0 -0
  761. /package/dist/{theme.interface-CSt7JUBD.cjs → theme.interface-B-qxDsZQ.cjs} +0 -0
  762. /package/dist/{theme.interface-odQEpZZH.js → theme.interface-B7caS5cg.js} +0 -0
  763. /package/dist/{utils-DTa3QHxk.cjs → utils-DIXndz6Q.cjs} +0 -0
  764. /package/dist/{utils-H8wNknWC.js → utils-dSPH7Oh9.js} +0 -0
@@ -1 +1 @@
1
- require(`./chunk-CncqDLb2.cjs`);const e=require(`./discovery.service-CIa3Eeuk.cjs`);let t=require(`rxjs`);var n=new t.BehaviorSubject([]),r=n.asObservable();function i(){return n.value}var a=!1,o=``,s=``;n.pipe((0,t.map)(e=>e.some(e=>e.modal)),(0,t.distinctUntilChanged)()).subscribe(e=>{typeof document<`u`&&(e&&!a?(o=document.documentElement.style.overflow,s=document.documentElement.style.getPropertyValue(`scrollbar-gutter`),document.documentElement.style.overflow=`hidden`,document.documentElement.style.setProperty(`scrollbar-gutter`,`stable`),a=!0):!e&&a&&(document.documentElement.style.overflow=o,s?document.documentElement.style.setProperty(`scrollbar-gutter`,s):document.documentElement.style.removeProperty(`scrollbar-gutter`),o=``,s=``,a=!1))});var c=new Set,l=new Set;function u(e,t){c.add(e),c.size===1&&function(e){let t=e.parentElement??document.body;for(let n=0;n<t.children.length;n++){let r=t.children[n];r!==e&&r instanceof HTMLElement&&!r.inert&&(r.inert=!0,l.add(r))}}(t)}function d(e){c.delete(e),c.size===0&&function(){for(let e of l)e.inert=!1;l.clear()}()}var f=r,p=new t.BehaviorSubject(null);function m(){let e=p.value;if(e&&!(performance.now()-e.capturedAt>750))return e.event}function h(r,i={}){return(0,t.defer)(()=>{let a={...i,anchor:i.anchor??m()},o=`ov_`+Math.random().toString(36).slice(2,10)+Date.now().toString(36),s={settled:!1,historyPushed:!1};return e.o(`schmancy-theme`).pipe((0,t.switchMap)(e=>{let i=document.createElement(`schmancy-overlay`);(e??document.body??document.documentElement).appendChild(i);let c=(0,t.from)(i.updateComplete.then(()=>i.open(r,a))).pipe((0,t.tap)(()=>{var e={id:o,element:i,layout:i.layout,modal:i.modal,tier:i.tier};n.next([...n.value,e]),i.modal&&i.parentElement&&u(o,i);let t=a.historyStrategy??`push`;t===`push`?(history.pushState({schmancyOverlayId:o},``,location.href),s.historyPushed=!0):t===`replace`&&history.replaceState({schmancyOverlayId:o},``,location.href)})),l=(0,t.fromEvent)(window,`popstate`).pipe((0,t.take)(1),(0,t.filter)(()=>s.historyPushed),(0,t.tap)(()=>{s.settled=!0,i.close(`popstate`)}),(0,t.ignoreElements)()),f=i.closed$.pipe((0,t.take)(1),(0,t.tap)(()=>{s.settled=!0}),(0,t.map)(({result:e})=>e));return c.pipe((0,t.switchMap)(()=>(0,t.merge)(f,l).pipe((0,t.take)(1))),(0,t.finalize)(()=>{s.settled||i.close(`programmatic`),d(o),function(e){let t=n.value,r=t.filter(t=>t.id!==e);r.length!==t.length&&n.next(r)}(o),s.historyPushed&&!s.settled&&history.state?.schmancyOverlayId===o&&history.back(),queueMicrotask(()=>i.remove())}))}))})}async function g(e={}){let{SchmancyOverlayPromptBody:n}=await Promise.resolve().then(()=>require(`./overlay.confirm-body-mYDYoJL8.cjs`)).then(e=>e.n);return!0===await(0,t.firstValueFrom)(h(n,{anchor:e.anchor,signal:e.signal,props:{mode:`confirm`,heading:e.title,subtitle:e.subtitle,message:e.message,confirmText:e.confirmText??`Confirm`,cancelText:e.cancelText??`Cancel`,variant:e.variant??`default`}}).pipe((0,t.defaultIfEmpty)(!1)))}async function _(e={}){let{SchmancyOverlayPromptBody:n}=await Promise.resolve().then(()=>require(`./overlay.confirm-body-mYDYoJL8.cjs`)).then(e=>e.n),r=await(0,t.firstValueFrom)(h(n,{anchor:e.anchor,signal:e.signal,props:{mode:`prompt`,heading:e.title,subtitle:e.subtitle,message:e.message,label:e.label,defaultValue:e.defaultValue??``,placeholder:e.placeholder,inputType:e.inputType??`text`,pattern:e.pattern,required:e.required??!1,confirmText:e.confirmText??`OK`,cancelText:e.cancelText??`Cancel`}}).pipe((0,t.defaultIfEmpty)(null)));return typeof r==`string`?r:null}function v(e,r){return function(e){let r=e.toLowerCase();return n.pipe((0,t.map)(e=>{let t=[];for(let n of e){let e=n.element.querySelector(r);e&&t.push(e)}return t}),(0,t.distinctUntilChanged)((e,t)=>e.length===t.length&&e.every((e,n)=>e===t[n])))}(e).pipe((0,t.distinctUntilChanged)((e,t)=>e.length===t.length&&e.every((e,n)=>e===t[n])),(0,t.switchMap)(e=>e.length===0?t.EMPTY:(0,t.merge)(...e.map(e=>(0,t.fromEvent)(e,r)))),(0,t.map)(e=>e))}function y(){let e=[...i()];for(let t=e.length-1;t>=0;t--)e[t].element.close(`programmatic`);n.value.length>0&&n.next([])}typeof document<`u`&&(0,t.merge)((0,t.fromEvent)(document,`pointerdown`,{capture:!0,passive:!0}).pipe((0,t.map)(e=>({event:e,capturedAt:performance.now()}))),(0,t.fromEvent)(document,`click`,{capture:!0,passive:!0}).pipe((0,t.map)(e=>({event:e,capturedAt:performance.now()}))),(0,t.fromEvent)(document,`keydown`,{capture:!0}).pipe((0,t.filter)(e=>e.target instanceof Element),(0,t.map)(e=>{let t=e.target.getBoundingClientRect();return{event:new MouseEvent(`click`,{clientX:t.left+t.width/2,clientY:t.top+t.height/2,bubbles:!0}),capturedAt:performance.now()}}))).subscribe(e=>p.next(e)),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return g}});
1
+ require(`./chunk-CncqDLb2.cjs`);const e=require(`./discovery.service-CIa3Eeuk.cjs`);let t=require(`rxjs`);var n=new t.BehaviorSubject([]),r=n.asObservable();function i(){return n.value}var a=!1,o=``,s=``;n.pipe((0,t.map)(e=>e.some(e=>e.modal)),(0,t.distinctUntilChanged)()).subscribe(e=>{typeof document<`u`&&(e&&!a?(o=document.documentElement.style.overflow,s=document.documentElement.style.getPropertyValue(`scrollbar-gutter`),document.documentElement.style.overflow=`hidden`,document.documentElement.style.setProperty(`scrollbar-gutter`,`stable`),a=!0):!e&&a&&(document.documentElement.style.overflow=o,s?document.documentElement.style.setProperty(`scrollbar-gutter`,s):document.documentElement.style.removeProperty(`scrollbar-gutter`),o=``,s=``,a=!1))});var c=new Set,l=new Set;function u(e,t){c.add(e),c.size===1&&function(e){let t=e.parentElement??document.body;for(let n=0;n<t.children.length;n++){let r=t.children[n];r!==e&&r instanceof HTMLElement&&!r.inert&&(r.inert=!0,l.add(r))}}(t)}function d(e){c.delete(e),c.size===0&&function(){for(let e of l)e.inert=!1;l.clear()}()}var f=r,p=new t.BehaviorSubject(null);function m(){let e=p.value;if(e&&!(performance.now()-e.capturedAt>750))return e.event}function h(r,i={}){return(0,t.defer)(()=>{let a={...i,anchor:i.anchor??m()},o=`ov_`+Math.random().toString(36).slice(2,10)+Date.now().toString(36),s={settled:!1,historyPushed:!1};return e.o(`schmancy-theme`).pipe((0,t.switchMap)(e=>{let i=document.createElement(`schmancy-overlay`);(e??document.body??document.documentElement).appendChild(i);let c=(0,t.from)(i.updateComplete.then(()=>i.open(r,a))).pipe((0,t.tap)(()=>{var e={id:o,element:i,layout:i.layout,modal:i.modal,tier:i.tier};n.next([...n.value,e]),i.modal&&i.parentElement&&u(o,i);let t=a.historyStrategy??`push`;t===`push`?(history.pushState({schmancyOverlayId:o},``,location.href),s.historyPushed=!0):t===`replace`&&history.replaceState({schmancyOverlayId:o},``,location.href)})),l=(0,t.fromEvent)(window,`popstate`).pipe((0,t.take)(1),(0,t.filter)(()=>s.historyPushed),(0,t.tap)(()=>{s.settled=!0,i.close(`popstate`)}),(0,t.ignoreElements)()),f=i.closed$.pipe((0,t.take)(1),(0,t.tap)(()=>{s.settled=!0}),(0,t.map)(({result:e})=>e));return c.pipe((0,t.switchMap)(()=>(0,t.merge)(f,l).pipe((0,t.take)(1))),(0,t.finalize)(()=>{s.settled||i.close(`programmatic`),d(o),function(e){let t=n.value,r=t.filter(t=>t.id!==e);r.length!==t.length&&n.next(r)}(o),s.historyPushed&&!s.settled&&history.state?.schmancyOverlayId===o&&history.back(),queueMicrotask(()=>i.remove())}))}))})}async function g(e={}){let{SchmancyOverlayPromptBody:n}=await Promise.resolve().then(()=>require(`./overlay.confirm-body-DCneq73Z.cjs`)).then(e=>e.n);return!0===await(0,t.firstValueFrom)(h(n,{anchor:e.anchor,signal:e.signal,props:{mode:`confirm`,heading:e.title,subtitle:e.subtitle,message:e.message,confirmText:e.confirmText??`Confirm`,cancelText:e.cancelText??`Cancel`,variant:e.variant??`default`}}).pipe((0,t.defaultIfEmpty)(!1)))}async function _(e={}){let{SchmancyOverlayPromptBody:n}=await Promise.resolve().then(()=>require(`./overlay.confirm-body-DCneq73Z.cjs`)).then(e=>e.n),r=await(0,t.firstValueFrom)(h(n,{anchor:e.anchor,signal:e.signal,props:{mode:`prompt`,heading:e.title,subtitle:e.subtitle,message:e.message,label:e.label,defaultValue:e.defaultValue??``,placeholder:e.placeholder,inputType:e.inputType??`text`,pattern:e.pattern,required:e.required??!1,confirmText:e.confirmText??`OK`,cancelText:e.cancelText??`Cancel`}}).pipe((0,t.defaultIfEmpty)(null)));return typeof r==`string`?r:null}function v(e,r){return function(e){let r=e.toLowerCase();return n.pipe((0,t.map)(e=>{let t=[];for(let n of e){let e=n.element.querySelector(r);e&&t.push(e)}return t}),(0,t.distinctUntilChanged)((e,t)=>e.length===t.length&&e.every((e,n)=>e===t[n])))}(e).pipe((0,t.distinctUntilChanged)((e,t)=>e.length===t.length&&e.every((e,n)=>e===t[n])),(0,t.switchMap)(e=>e.length===0?t.EMPTY:(0,t.merge)(...e.map(e=>(0,t.fromEvent)(e,r)))),(0,t.map)(e=>e))}function y(){let e=[...i()];for(let t=e.length-1;t>=0;t--)e[t].element.close(`programmatic`);n.value.length>0&&n.next([])}typeof document<`u`&&(0,t.merge)((0,t.fromEvent)(document,`pointerdown`,{capture:!0,passive:!0}).pipe((0,t.map)(e=>({event:e,capturedAt:performance.now()}))),(0,t.fromEvent)(document,`click`,{capture:!0,passive:!0}).pipe((0,t.map)(e=>({event:e,capturedAt:performance.now()}))),(0,t.fromEvent)(document,`keydown`,{capture:!0}).pipe((0,t.filter)(e=>e.target instanceof Element),(0,t.map)(e=>{let t=e.target.getBoundingClientRect();return{event:new MouseEvent(`click`,{clientX:t.left+t.width/2,clientY:t.top+t.height/2,bubbles:!0}),capturedAt:performance.now()}}))).subscribe(e=>p.next(e)),Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return _}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return v}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return y}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return h}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return f}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return i}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return g}});
@@ -0,0 +1 @@
1
+ {"version":3,"file":"overlay.service-MMTiW2T3.cjs","names":[],"sources":["../src/overlay/overlay.stack.ts","../src/overlay/overlay.service.ts"],"sourcesContent":["import { BehaviorSubject, distinctUntilChanged, map, Observable } from 'rxjs'\nimport type { OverlayEntry } from './overlay.types'\n\n/**\n * Overlay stack — single source of truth for \"what is currently open.\"\n *\n * A module-scope BehaviorSubject matching the `schmancy` skill's\n * \"contexts at module scope; many small contexts beat one monolith\"\n * guidance. Reactive pipelines inside the overlay service and public\n * `openOverlays$` observable project off this.\n *\n * Scroll lock and the stack-aware inert manager are both derived from\n * the stack state — no separate mutable counter variables. Honors rxjs\n * SUBSCRIPTION_IS_STATE: the stack IS the state; scroll lock / inert\n * are declarative projections.\n */\n\nconst stack$$ = new BehaviorSubject<readonly OverlayEntry[]>([])\n\n/** Public read-only stream of the current stack. Emits on every push/pop. */\nexport const stack$: Observable<readonly OverlayEntry[]> = stack$$.asObservable()\n\n/** Synchronous snapshot. Use only when a component can't subscribe. */\nexport function currentStack(): readonly OverlayEntry[] {\n\treturn stack$$.value\n}\n\n/** Append an entry (top of stack). */\nexport function pushEntry(entry: OverlayEntry): void {\n\tstack$$.next([...stack$$.value, entry])\n}\n\n/** Remove by id. No-op if the id is not in the stack. */\nexport function removeEntry(id: string): void {\n\tconst current = stack$$.value\n\tconst next = current.filter(e => e.id !== id)\n\tif (next.length !== current.length) {\n\t\tstack$$.next(next)\n\t}\n}\n\n/** Clear the entire stack. Used by dismissAll(). */\nexport function clearStack(): void {\n\tif (stack$$.value.length > 0) {\n\t\tstack$$.next([])\n\t}\n}\n\n/* ---------------- scroll lock -------------------------------------------- */\n\n/**\n * Ref-counted body scroll lock. Active whenever ANY modal-tier overlay is\n * in the stack. Popover-tier (Tier 1/2) overlays do NOT lock body scroll —\n * a menu / share card / picker shouldn't freeze the page scroll behind it\n * (that's platform UX convention).\n *\n * Subscription is idempotent — subscribing multiple times won't stack\n * effects, because it's a distinctUntilChanged boolean projection.\n *\n * Inner overlay close does NOT release the lock while an outer modal is\n * still open (this was the pre-existing bug in sheet.service.ts).\n */\nlet scrollLockActive = false\nlet previousOverflow = ''\nlet previousScrollbarGutter = ''\n\nstack$$\n\t.pipe(\n\t\tmap(s => s.some(e => e.modal)),\n\t\tdistinctUntilChanged(),\n\t)\n\t.subscribe(shouldLock => {\n\t\tif (typeof document === 'undefined') return\n\n\t\tif (shouldLock && !scrollLockActive) {\n\t\t\tpreviousOverflow = document.documentElement.style.overflow\n\t\t\tpreviousScrollbarGutter = document.documentElement.style.getPropertyValue('scrollbar-gutter')\n\t\t\tdocument.documentElement.style.overflow = 'hidden'\n\t\t\tdocument.documentElement.style.setProperty('scrollbar-gutter', 'stable')\n\t\t\tscrollLockActive = true\n\t\t} else if (!shouldLock && scrollLockActive) {\n\t\t\tdocument.documentElement.style.overflow = previousOverflow\n\t\t\tif (previousScrollbarGutter) {\n\t\t\t\tdocument.documentElement.style.setProperty('scrollbar-gutter', previousScrollbarGutter)\n\t\t\t} else {\n\t\t\t\tdocument.documentElement.style.removeProperty('scrollbar-gutter')\n\t\t\t}\n\t\t\tpreviousOverflow = ''\n\t\t\tpreviousScrollbarGutter = ''\n\t\t\tscrollLockActive = false\n\t\t}\n\t})\n\n/* ---------------- stack-aware inert -------------------------------------- */\n\n/**\n * When the first modal overlay opens, mark every sibling outside the\n * overlay host subtree as `inert` so AT and keyboard focus can't reach\n * them. Restored when the last modal overlay closes.\n *\n * Note: native `<dialog>.showModal()` already inerts the rest of the\n * document automatically. We keep this as a safety net for:\n * - anchored (popover) overlays which are non-modal by design but may\n * carry `modal: true` as the escape hatch;\n * - stacked overlays where an inner modal opens above a non-modal —\n * the sibling-inert is a no-op but we still guarantee the invariant.\n *\n * Callers that don't want inert (anchored/menu overlays) skip registration\n * via `markNonModal(id)`.\n */\nconst modalIds = new Set<string>()\nconst inertedSiblings = new Set<HTMLElement>()\n\nexport function markModal(id: string, hostContainer: HTMLElement): void {\n\tmodalIds.add(id)\n\tif (modalIds.size === 1) {\n\t\tapplyInert(hostContainer)\n\t}\n}\n\nexport function unmarkModal(id: string): void {\n\tmodalIds.delete(id)\n\tif (modalIds.size === 0) {\n\t\treleaseInert()\n\t}\n}\n\nfunction applyInert(hostContainer: HTMLElement): void {\n\tconst parent = hostContainer.parentElement ?? document.body\n\tfor (let i = 0; i < parent.children.length; i++) {\n\t\tconst child = parent.children[i]\n\t\tif (child !== hostContainer && child instanceof HTMLElement && !child.inert) {\n\t\t\tchild.inert = true\n\t\t\tinertedSiblings.add(child)\n\t\t}\n\t}\n}\n\nfunction releaseInert(): void {\n\tfor (const el of inertedSiblings) {\n\t\tel.inert = false\n\t}\n\tinertedSiblings.clear()\n}\n\n/* ---------------- overlayEvents multicast helper ------------------------- */\n\n/**\n * Returns an Observable of `tagName` elements currently in the stack.\n * The overlayEvents public helper composes `fromEvent` over this stream\n * via switchMap to tap events without owning the overlay lifecycle.\n *\n * Stays alive across open/close cycles — the caller owns completion via\n * `takeUntil(this.disconnecting)`, matching the house rxjs convention.\n */\nexport function elementsByTag$(tagName: string): Observable<readonly HTMLElement[]> {\n\tconst lower = tagName.toLowerCase()\n\treturn stack$$.pipe(\n\t\tmap(entries => {\n\t\t\tconst matches: HTMLElement[] = []\n\t\t\tfor (const entry of entries) {\n\t\t\t\tconst inner = entry.element.querySelector<HTMLElement>(lower)\n\t\t\t\tif (inner) matches.push(inner)\n\t\t\t}\n\t\t\treturn matches\n\t\t}),\n\t\tdistinctUntilChanged((a, b) => a.length === b.length && a.every((el, i) => el === b[i])),\n\t)\n}\n","import {\n\tBehaviorSubject,\n\tdefer,\n\tdefaultIfEmpty,\n\tdistinctUntilChanged,\n\tEMPTY,\n\tfilter,\n\tfinalize,\n\tfirstValueFrom,\n\tfrom,\n\tfromEvent,\n\tignoreElements,\n\tmap,\n\tmerge,\n\tObservable,\n\tswitchMap,\n\ttake,\n\ttap,\n} from 'rxjs'\nimport type { THistoryStrategy } from '../area/router.types'\nimport { discoverComponent } from '../discovery/discovery.service'\nimport { SchmancyOverlay } from './overlay.component'\nimport {\n\tclearStack,\n\tcurrentStack,\n\telementsByTag$,\n\tmarkModal,\n\tpushEntry,\n\tremoveEntry,\n\tstack$ as internalStack$,\n\tunmarkModal,\n} from './overlay.stack'\nimport type {\n\tCloseReason,\n\tOverlayConfirmOptions,\n\tContent,\n\tOverlayEntry,\n\tOverlayPromptOptions,\n\tShowOptions,\n} from './overlay.types'\n\n/**\n * Public read-only stream of the current overlay stack. Subscribe to\n * observe stack changes — e.g. to update a breadcrumb, show a \"close\n * all\" button, or gate another action while any overlay is open.\n *\n * Emits synchronously with the current snapshot on subscribe. Never\n * completes — the caller owns teardown via `takeUntil(this.disconnecting)`.\n */\nexport const openOverlays$: Observable<readonly OverlayEntry[]> = internalStack$\n\n/* ======================================================================= *\n * ambient event capture *\n * ======================================================================= *\n * Novel: callers do not need to pass `anchor: event` manually. The service\n * listens to pointerdown / click / keydown at capture phase on the document\n * and remembers the most-recent user gesture. When show() is invoked\n * synchronously (or shortly after) in response to that gesture, the remembered\n * event becomes the default anchor. This matches the \"anchored is the novel\n * default\" principle without forcing callers to thread events through\n * handlers.\n *\n * Staleness guard: an event older than AMBIENT_ANCHOR_MAX_AGE_MS is ignored.\n * Timer-driven or async show() calls that don't originate from a user gesture\n * fall through to centered / sheet layout.\n */\nconst AMBIENT_ANCHOR_MAX_AGE_MS = 750\n\ninterface AmbientAnchor {\n\tevent: MouseEvent\n\tcapturedAt: number\n}\n\n/**\n * BehaviorSubject projected off three document-level event streams,\n * merged as Observables per rxjs principle 3 (every async source\n * lifted into fromEvent). Keydown activations synthesize a MouseEvent\n * at the focused element's bounding rect so the anchor path can\n * carry keyboard-triggered opens uniformly.\n *\n * The singleton subscribe has no explicit teardown — the module's\n * lifetime IS the subscription's lifetime, which is the correct\n * SUBSCRIPTION_IS_STATE shape for a document-level event sink.\n */\nconst ambientAnchor$ = new BehaviorSubject<AmbientAnchor | null>(null)\n\nif (typeof document !== 'undefined') {\n\tconst pointerdown$ = fromEvent<PointerEvent>(document, 'pointerdown', { capture: true, passive: true }).pipe(\n\t\tmap((e): AmbientAnchor => ({ event: e, capturedAt: performance.now() })),\n\t)\n\tconst click$ = fromEvent<MouseEvent>(document, 'click', { capture: true, passive: true }).pipe(\n\t\tmap((e): AmbientAnchor => ({ event: e, capturedAt: performance.now() })),\n\t)\n\tconst keydown$ = fromEvent<KeyboardEvent>(document, 'keydown', { capture: true }).pipe(\n\t\tfilter(e => e.target instanceof Element),\n\t\tmap((e): AmbientAnchor => {\n\t\t\tconst rect = (e.target as Element).getBoundingClientRect()\n\t\t\tconst synthetic = new MouseEvent('click', {\n\t\t\t\tclientX: rect.left + rect.width / 2,\n\t\t\t\tclientY: rect.top + rect.height / 2,\n\t\t\t\tbubbles: true,\n\t\t\t})\n\t\t\treturn { event: synthetic, capturedAt: performance.now() }\n\t\t}),\n\t)\n\n\tmerge(pointerdown$, click$, keydown$).subscribe(ambient => ambientAnchor$.next(ambient))\n}\n\nfunction ambientAnchor(): MouseEvent | undefined {\n\tconst cur = ambientAnchor$.value\n\tif (!cur) return undefined\n\tif (performance.now() - cur.capturedAt > AMBIENT_ANCHOR_MAX_AGE_MS) return undefined\n\treturn cur.event\n}\n\n/* ======================================================================= *\n * show *\n * ======================================================================= */\n\n/**\n * Open an overlay containing `content`. Returns a cold Observable — the\n * overlay mounts on subscribe and dismisses on unsubscribe. Emits at\n * most one value (the result from content's `close` event) then completes.\n *\n * The subscription IS the overlay lifecycle. `takeUntil(this.disconnecting)`\n * on the caller's side means the overlay auto-dismisses when the caller\n * unmounts — no handles to track, no leaks.\n *\n * **Anchored is the novel default.** When triggered by a user event, pass\n * it as `anchor` — the overlay blooms from the point of attention. Falls\n * back to centered or sheet when the viewport / content makes that the\n * better layout (see overlay.layout.ts).\n *\n * @example\n * show(MyEditor, { props: { id }, anchor: event })\n * .pipe(takeUntil(this.disconnecting))\n * .subscribe(saved => saved && this.store.persist(saved))\n */\nexport function show<T = void>(content: Content, options: ShowOptions = {}): Observable<T | undefined> {\n\treturn defer(() => {\n\t\t// Resolve anchor + theme container at subscribe time. Anchor: caller's\n\t\t// explicit value wins, otherwise the ambient gesture fills in. Theme:\n\t\t// dispatch `schmancy-theme-where-are-you` via the discovery service so\n\t\t// the overlay mounts inside the nearest <schmancy-theme> and inherits\n\t\t// its --schmancy-* tokens (same mechanism the old $dialog used). Falls\n\t\t// back to body when no theme responds.\n\t\tconst resolvedOptions: ShowOptions = {\n\t\t\t...options,\n\t\t\tanchor: options.anchor ?? ambientAnchor(),\n\t\t}\n\t\tconst id = generateId()\n\t\tconst state = { settled: false, historyPushed: false }\n\n\t\treturn discoverComponent<HTMLElement>('schmancy-theme').pipe(\n\t\t\tswitchMap(theme => {\n\t\t\t\tconst el = document.createElement('schmancy-overlay') as SchmancyOverlay\n\t\t\t\t;(theme ?? document.body ?? document.documentElement).appendChild(el)\n\n\t\t\t\tconst opened$ = from(el.updateComplete.then(() => el.open(content, resolvedOptions))).pipe(\n\t\t\t\t\ttap(() => {\n\t\t\t\t\t\tpushEntry({\n\t\t\t\t\t\t\tid,\n\t\t\t\t\t\t\telement: el,\n\t\t\t\t\t\t\tlayout: el.layout,\n\t\t\t\t\t\t\tmodal: el.modal,\n\t\t\t\t\t\t\ttier: el.tier,\n\t\t\t\t\t\t})\n\t\t\t\t\t\tif (el.modal && el.parentElement) markModal(id, el)\n\n\t\t\t\t\t\tconst strategy: THistoryStrategy = resolvedOptions.historyStrategy ?? 'push'\n\t\t\t\t\t\tif (strategy === 'push') {\n\t\t\t\t\t\t\thistory.pushState({ schmancyOverlayId: id }, '', location.href)\n\t\t\t\t\t\t\tstate.historyPushed = true\n\t\t\t\t\t\t} else if (strategy === 'replace') {\n\t\t\t\t\t\t\thistory.replaceState({ schmancyOverlayId: id }, '', location.href)\n\t\t\t\t\t\t}\n\t\t\t\t\t}),\n\t\t\t\t)\n\n\t\t\t\t// popstate side-channel — listened only after history.pushState\n\t\t\t\t// completed inside opened$'s tap. ignoreElements keeps the merge\n\t\t\t\t// emitting only the eventual close result.\n\t\t\t\tconst popstateClose$ = fromEvent<PopStateEvent>(window, 'popstate').pipe(\n\t\t\t\t\ttake(1),\n\t\t\t\t\tfilter(() => state.historyPushed),\n\t\t\t\t\ttap(() => {\n\t\t\t\t\t\tstate.settled = true\n\t\t\t\t\t\tvoid el.close('popstate')\n\t\t\t\t\t}),\n\t\t\t\t\tignoreElements(),\n\t\t\t\t)\n\n\t\t\t\tconst closed$ = el.closed$.pipe(\n\t\t\t\t\ttake(1),\n\t\t\t\t\ttap(() => {\n\t\t\t\t\t\tstate.settled = true\n\t\t\t\t\t}),\n\t\t\t\t\tmap(({ result }) => result as T | undefined),\n\t\t\t\t)\n\n\t\t\t\treturn opened$.pipe(\n\t\t\t\t\tswitchMap(() => merge(closed$, popstateClose$).pipe(take(1))),\n\t\t\t\t\tfinalize(() => {\n\t\t\t\t\t\tif (!state.settled) void el.close('programmatic')\n\t\t\t\t\t\tunmarkModal(id)\n\t\t\t\t\t\tremoveEntry(id)\n\t\t\t\t\t\tif (state.historyPushed && !state.settled && history.state?.schmancyOverlayId === id) {\n\t\t\t\t\t\t\thistory.back()\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqueueMicrotask(() => el.remove())\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t}),\n\t\t)\n\t})\n}\n\n/* ======================================================================= *\n * confirm / prompt sugar *\n * ======================================================================= */\n\n/**\n * Yes/no confirmation dialog. Returns a Promise that resolves with the\n * user's choice. `variant: 'danger'` flips to destructive styling and\n * `role=\"alertdialog\"`.\n */\nexport async function confirm(options: OverlayConfirmOptions = {}): Promise<boolean> {\n\t// Lazy-import the confirm body so push-only callers don't ship these\n\t// deps. The module is small; one-shot import penalty is fine.\n\tconst { SchmancyOverlayPromptBody } = await import('./overlay.confirm-body')\n\n\tconst result = await firstValueFrom(\n\t\tshow<boolean>(SchmancyOverlayPromptBody, {\n\t\t\tanchor: options.anchor,\n\t\t\tsignal: options.signal,\n\t\t\tprops: {\n\t\t\t\tmode: 'confirm',\n\t\t\t\theading: options.title,\n\t\t\t\tsubtitle: options.subtitle,\n\t\t\t\tmessage: options.message,\n\t\t\t\tconfirmText: options.confirmText ?? 'Confirm',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t\tvariant: options.variant ?? 'default',\n\t\t\t},\n\t\t}).pipe(defaultIfEmpty(false as boolean | undefined)),\n\t)\n\treturn result === true\n}\n\n/**\n * Input prompt dialog. Returns the entered string, or `null` if the user\n * cancels or dismisses.\n */\nexport async function prompt(options: OverlayPromptOptions = {}): Promise<string | null> {\n\tconst { SchmancyOverlayPromptBody } = await import('./overlay.confirm-body')\n\n\tconst result = await firstValueFrom(\n\t\tshow<string | null>(SchmancyOverlayPromptBody, {\n\t\t\tanchor: options.anchor,\n\t\t\tsignal: options.signal,\n\t\t\tprops: {\n\t\t\t\tmode: 'prompt',\n\t\t\t\theading: options.title,\n\t\t\t\tsubtitle: options.subtitle,\n\t\t\t\tmessage: options.message,\n\t\t\t\tlabel: options.label,\n\t\t\t\tdefaultValue: options.defaultValue ?? '',\n\t\t\t\tplaceholder: options.placeholder,\n\t\t\t\tinputType: options.inputType ?? 'text',\n\t\t\t\tpattern: options.pattern,\n\t\t\t\trequired: options.required ?? false,\n\t\t\t\tconfirmText: options.confirmText ?? 'OK',\n\t\t\t\tcancelText: options.cancelText ?? 'Cancel',\n\t\t\t},\n\t\t}).pipe(defaultIfEmpty(null as string | null | undefined)),\n\t)\n\treturn typeof result === 'string' ? result : null\n}\n\n/* ======================================================================= *\n * overlayEvents *\n * ======================================================================= */\n\n/**\n * Subscribe to custom events emitted from any currently-open overlay\n * whose content matches `tagName`. Inspired by `area.on(name)` — keyed\n * by tag name (stable across HMR / lazy chunks) rather than a uid or\n * class reference.\n *\n * The returned Observable never completes on its own — the caller owns\n * teardown via `takeUntil(this.disconnecting)`. During gaps where no\n * matching overlay is open, no events are emitted; when an instance\n * mounts, events flow.\n *\n * Stacked instances of the same content merge their event streams.\n */\nexport function overlayEvents<E extends Event = CustomEvent>(tagName: string, eventName: string): Observable<E> {\n\treturn elementsByTag$(tagName).pipe(\n\t\tdistinctUntilChanged((a, b) => a.length === b.length && a.every((el, i) => el === b[i])),\n\t\tswitchMap(elements => (elements.length === 0 ? EMPTY : merge(...elements.map(el => fromEvent<E>(el, eventName))))),\n\t\tmap(e => e),\n\t)\n}\n\n/* ======================================================================= *\n * dismissAll *\n * ======================================================================= */\n\n/**\n * Close every currently-open overlay. LIFO order. Imperative — use for\n * app-level flows like logout or route reset.\n */\nexport function dismissAll(): void {\n\tconst stack = [...currentStack()]\n\t// LIFO: close top-of-stack first.\n\tfor (let i = stack.length - 1; i >= 0; i--) {\n\t\tconst entry = stack[i]\n\t\tconst overlay = entry.element as SchmancyOverlay\n\t\tvoid overlay.close('programmatic')\n\t}\n\tclearStack()\n}\n\n/* ======================================================================= *\n * helpers *\n * ======================================================================= */\n\nfunction generateId(): string {\n\t// 8-char base36 is enough entropy for session-scoped uniqueness.\n\treturn 'ov_' + Math.random().toString(36).slice(2, 10) + Date.now().toString(36)\n}\n\n// Re-export the close reason type for consumers who want to narrow on it.\nexport type { CloseReason }\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { t as e, u as t } from "./SchmancyElement-OWgz9ePG.js";
2
- import "./mixins-COeG4DiX.js";
1
+ import { t as e, u as t } from "./SchmancyElement-Ob9yGkiG.js";
2
+ import "./mixins-q4KAL8Xr.js";
3
3
  import { classMap as n } from "lit/directives/class-map.js";
4
4
  import { styleMap as r } from "lit/directives/style-map.js";
5
5
  import { customElement as i, property as a } from "lit/decorators.js";
@@ -10,40 +10,40 @@ var c = class extends e {
10
10
  }
11
11
  static {
12
12
  this.styles = [o`
13
- :host {
14
- display: block;
15
- }
13
+ :host {
14
+ display: block;
15
+ }
16
16
 
17
- /* Blackbird-style indeterminate animation with organic easing */
18
- @keyframes indeterminate {
19
- 0% {
20
- left: -30%;
21
- width: 20%;
22
- opacity: 0.6;
23
- }
24
- 25% {
25
- width: 35%;
26
- opacity: 1;
27
- }
28
- 50% {
29
- left: 40%;
30
- width: 30%;
31
- }
32
- 75% {
33
- width: 25%;
34
- opacity: 0.9;
35
- }
36
- 100% {
37
- left: 100%;
38
- width: 20%;
39
- opacity: 0.6;
40
- }
41
- }
17
+ /* Blackbird-style indeterminate animation with organic easing */
18
+ @keyframes indeterminate {
19
+ 0% {
20
+ left: -30%;
21
+ width: 20%;
22
+ opacity: 0.6;
23
+ }
24
+ 25% {
25
+ width: 35%;
26
+ opacity: 1;
27
+ }
28
+ 50% {
29
+ left: 40%;
30
+ width: 30%;
31
+ }
32
+ 75% {
33
+ width: 25%;
34
+ opacity: 0.9;
35
+ }
36
+ 100% {
37
+ left: 100%;
38
+ width: 20%;
39
+ opacity: 0.6;
40
+ }
41
+ }
42
42
 
43
- .indeterminate-animation {
44
- animation: indeterminate 1.8s cubic-bezier(0.34, 1.2, 0.64, 1) infinite;
45
- }
46
- `];
43
+ .indeterminate-animation {
44
+ animation: indeterminate 1.8s cubic-bezier(0.34, 1.2, 0.64, 1) infinite;
45
+ }
46
+ `];
47
47
  }
48
48
  get percentage() {
49
49
  return this.indeterminate ? 0 : Math.min(100, Math.max(0, this.value / this.max * 100));
@@ -89,25 +89,25 @@ var c = class extends e {
89
89
  "bg-success-default/70": this.glass && this.color === "success"
90
90
  };
91
91
  return s`
92
- <div class="${n(e)}">
93
- <div
94
- class="${n({
92
+ <div class="${n(e)}">
93
+ <div
94
+ class="${n({
95
95
  ...t,
96
96
  ...a
97
97
  })}"
98
- style="${r(i)}"
99
- role="progressbar"
100
- aria-valuenow="${this.value}"
101
- aria-valuemin="0"
102
- aria-valuemax="${this.max}"
103
- >
104
- ${this.glass ? s`
105
- <!-- Glass shine effect -->
106
- <div class="absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full"></div>
107
- ` : ""}
108
- </div>
109
- </div>
110
- `;
98
+ style="${r(i)}"
99
+ role="progressbar"
100
+ aria-valuenow="${this.value}"
101
+ aria-valuemin="0"
102
+ aria-valuemax="${this.max}"
103
+ >
104
+ ${this.glass ? s`
105
+ <!-- Glass shine effect -->
106
+ <div class="absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full"></div>
107
+ ` : ""}
108
+ </div>
109
+ </div>
110
+ `;
111
111
  }
112
112
  };
113
113
  t([a({
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-D7n3SKAO.js","names":[],"sources":["../src/progress/progress.ts"],"sourcesContent":["import { SchmancyElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { styleMap } from 'lit/directives/style-map.js'\n\n@customElement('schmancy-progress')\nexport default class SchmancyProgress extends SchmancyElement {\n\tstatic styles = [\n\t\tcss`\n\t\t\t:host {\n\t\t\t\tdisplay: block;\n\t\t\t}\n\n\t\t\t/* Blackbird-style indeterminate animation with organic easing */\n\t\t\t@keyframes indeterminate {\n\t\t\t\t0% {\n\t\t\t\t\tleft: -30%;\n\t\t\t\t\twidth: 20%;\n\t\t\t\t\topacity: 0.6;\n\t\t\t\t}\n\t\t\t\t25% {\n\t\t\t\t\twidth: 35%;\n\t\t\t\t\topacity: 1;\n\t\t\t\t}\n\t\t\t\t50% {\n\t\t\t\t\tleft: 40%;\n\t\t\t\t\twidth: 30%;\n\t\t\t\t}\n\t\t\t\t75% {\n\t\t\t\t\twidth: 25%;\n\t\t\t\t\topacity: 0.9;\n\t\t\t\t}\n\t\t\t\t100% {\n\t\t\t\t\tleft: 100%;\n\t\t\t\t\twidth: 20%;\n\t\t\t\t\topacity: 0.6;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t.indeterminate-animation {\n\t\t\t\tanimation: indeterminate 1.8s cubic-bezier(0.34, 1.2, 0.64, 1) infinite;\n\t\t\t}\n\t\t`,\n\t]\n\n\t@property({ type: Number, reflect: true })\n\tvalue = 0\n\n\t@property({ type: Number, reflect: true })\n\tmax = 100\n\n\t@property({ type: Boolean, reflect: true })\n\tindeterminate = false\n\n\t// M3 aligned track heights: xs=1px, sm=2px, md=4px, lg=8px\n\t@property({ type: String, reflect: true })\n\tsize: 'xs' | 'sm' | 'md' | 'lg' = 'md'\n\n\t@property({ type: String, reflect: true })\n\tcolor: 'primary' | 'secondary' | 'tertiary' | 'error' | 'success' = 'primary'\n\n\t@property({ type: Boolean, reflect: true })\n\tglass = false\n\n\tprivate get percentage(): number {\n\t\tif (this.indeterminate) return 0\n\t\treturn Math.min(100, Math.max(0, (this.value / this.max) * 100))\n\t}\n\n\tprotected render() {\n\t\tconst containerClasses = {\n\t\t\t'w-full': true,\n\t\t\trelative: true,\n\t\t\t'overflow-hidden': true,\n\t\t\t'rounded-full': true,\n\t\t\t'h-px': this.size === 'xs', // 1px - M3 linear indicator track\n\t\t\t'h-0.5': this.size === 'sm', // 2px\n\t\t\t'h-1': this.size === 'md', // 4px - M3 default\n\t\t\t'h-2': this.size === 'lg', // 8px\n\t\t\t// Glass effect background\n\t\t\t'backdrop-blur-xl': this.glass,\n\t\t\t'backdrop-saturate-150': this.glass,\n\t\t\t'bg-surface-container/20': this.glass && !this.indeterminate,\n\t\t\t'bg-surface-container': !this.glass,\n\t\t\t'shadow-[inset_0_1px_2px_0_rgba(0,0,0,0.1)]': this.glass,\n\t\t\tborder: this.glass,\n\t\t\t'border-outline/20': this.glass,\n\t\t}\n\n\t\tconst barClasses = {\n\t\t\t'h-full': true,\n\t\t\t'rounded-full': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-300': true,\n\t\t\t'ease-in-out': true,\n\t\t\trelative: true,\n\t\t\t'bg-primary-default': this.color === 'primary' && !this.glass,\n\t\t\t'bg-secondary-default': this.color === 'secondary' && !this.glass,\n\t\t\t'bg-tertiary-default': this.color === 'tertiary' && !this.glass,\n\t\t\t'bg-error-default': this.color === 'error' && !this.glass,\n\t\t\t'bg-success-default': this.color === 'success' && !this.glass,\n\t\t\tabsolute: this.indeterminate,\n\t\t\t'indeterminate-animation': this.indeterminate,\n\t\t}\n\n\t\tconst barStyles = this.indeterminate ? {} : { width: `${this.percentage}%` }\n\n\t\t// Glass effect bar classes\n\t\tconst glassBarClasses = {\n\t\t\t'backdrop-blur-sm': this.glass,\n\t\t\t'shadow-[0_0_20px_rgba(0,0,0,0.1)]': this.glass,\n\t\t\t// Use semi-transparent background colors for glass effect\n\t\t\t'bg-primary-default/70': this.glass && this.color === 'primary',\n\t\t\t'bg-secondary-default/70': this.glass && this.color === 'secondary',\n\t\t\t'bg-tertiary-default/70': this.glass && this.color === 'tertiary',\n\t\t\t'bg-error-default/70': this.glass && this.color === 'error',\n\t\t\t'bg-success-default/70': this.glass && this.color === 'success',\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"${classMap(containerClasses)}\">\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${classMap({ ...barClasses, ...glassBarClasses })}\"\n\t\t\t\t\tstyle=\"${styleMap(barStyles)}\"\n\t\t\t\t\trole=\"progressbar\"\n\t\t\t\t\taria-valuenow=\"${this.value}\"\n\t\t\t\t\taria-valuemin=\"0\"\n\t\t\t\t\taria-valuemax=\"${this.max}\"\n\t\t\t\t>\n\t\t\t\t\t${this.glass\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<!-- Glass shine effect -->\n\t\t\t\t\t\t\t\t<div class=\"absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full\"></div>\n\t\t\t\t\t\t\t`\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-progress': SchmancyProgress\n\t}\n}\n"],"mappings":"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"}
@@ -0,0 +1,51 @@
1
+ require(`./chunk-CncqDLb2.cjs`);const e=require(`./SchmancyElement-CeKrBW2j.cjs`);require(`./mixins-Cjn20BQH.cjs`);let t=require(`lit/directives/class-map.js`),n=require(`lit/directives/style-map.js`),r=require(`lit/decorators.js`),i=require(`lit`);var a=class extends e.t{constructor(...e){super(...e),this.value=0,this.max=100,this.indeterminate=!1,this.size=`md`,this.color=`primary`,this.glass=!1}static{this.styles=[i.css`
2
+ :host {
3
+ display: block;
4
+ }
5
+
6
+ /* Blackbird-style indeterminate animation with organic easing */
7
+ @keyframes indeterminate {
8
+ 0% {
9
+ left: -30%;
10
+ width: 20%;
11
+ opacity: 0.6;
12
+ }
13
+ 25% {
14
+ width: 35%;
15
+ opacity: 1;
16
+ }
17
+ 50% {
18
+ left: 40%;
19
+ width: 30%;
20
+ }
21
+ 75% {
22
+ width: 25%;
23
+ opacity: 0.9;
24
+ }
25
+ 100% {
26
+ left: 100%;
27
+ width: 20%;
28
+ opacity: 0.6;
29
+ }
30
+ }
31
+
32
+ .indeterminate-animation {
33
+ animation: indeterminate 1.8s cubic-bezier(0.34, 1.2, 0.64, 1) infinite;
34
+ }
35
+ `]}get percentage(){return this.indeterminate?0:Math.min(100,Math.max(0,this.value/this.max*100))}render(){let e={"w-full":!0,relative:!0,"overflow-hidden":!0,"rounded-full":!0,"h-px":this.size===`xs`,"h-0.5":this.size===`sm`,"h-1":this.size===`md`,"h-2":this.size===`lg`,"backdrop-blur-xl":this.glass,"backdrop-saturate-150":this.glass,"bg-surface-container/20":this.glass&&!this.indeterminate,"bg-surface-container":!this.glass,"shadow-[inset_0_1px_2px_0_rgba(0,0,0,0.1)]":this.glass,border:this.glass,"border-outline/20":this.glass},r={"h-full":!0,"rounded-full":!0,"transition-all":!0,"duration-300":!0,"ease-in-out":!0,relative:!0,"bg-primary-default":this.color===`primary`&&!this.glass,"bg-secondary-default":this.color===`secondary`&&!this.glass,"bg-tertiary-default":this.color===`tertiary`&&!this.glass,"bg-error-default":this.color===`error`&&!this.glass,"bg-success-default":this.color===`success`&&!this.glass,absolute:this.indeterminate,"indeterminate-animation":this.indeterminate},a=this.indeterminate?{}:{width:`${this.percentage}%`},o={"backdrop-blur-sm":this.glass,"shadow-[0_0_20px_rgba(0,0,0,0.1)]":this.glass,"bg-primary-default/70":this.glass&&this.color===`primary`,"bg-secondary-default/70":this.glass&&this.color===`secondary`,"bg-tertiary-default/70":this.glass&&this.color===`tertiary`,"bg-error-default/70":this.glass&&this.color===`error`,"bg-success-default/70":this.glass&&this.color===`success`};return i.html`
36
+ <div class="${(0,t.classMap)(e)}">
37
+ <div
38
+ class="${(0,t.classMap)({...r,...o})}"
39
+ style="${(0,n.styleMap)(a)}"
40
+ role="progressbar"
41
+ aria-valuenow="${this.value}"
42
+ aria-valuemin="0"
43
+ aria-valuemax="${this.max}"
44
+ >
45
+ ${this.glass?i.html`
46
+ <!-- Glass shine effect -->
47
+ <div class="absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full"></div>
48
+ `:``}
49
+ </div>
50
+ </div>
51
+ `}};e.u([(0,r.property)({type:Number,reflect:!0})],a.prototype,`value`,void 0),e.u([(0,r.property)({type:Number,reflect:!0})],a.prototype,`max`,void 0),e.u([(0,r.property)({type:Boolean,reflect:!0})],a.prototype,`indeterminate`,void 0),e.u([(0,r.property)({type:String,reflect:!0})],a.prototype,`size`,void 0),e.u([(0,r.property)({type:String,reflect:!0})],a.prototype,`color`,void 0),e.u([(0,r.property)({type:Boolean,reflect:!0})],a.prototype,`glass`,void 0),a=e.u([(0,r.customElement)(`schmancy-progress`)],a);
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-DsCnFsH5.cjs","names":[],"sources":["../src/progress/progress.ts"],"sourcesContent":["import { SchmancyElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { styleMap } from 'lit/directives/style-map.js'\n\n@customElement('schmancy-progress')\nexport default class SchmancyProgress extends SchmancyElement {\n\tstatic styles = [\n\t\tcss`\n\t\t\t:host {\n\t\t\t\tdisplay: block;\n\t\t\t}\n\n\t\t\t/* Blackbird-style indeterminate animation with organic easing */\n\t\t\t@keyframes indeterminate {\n\t\t\t\t0% {\n\t\t\t\t\tleft: -30%;\n\t\t\t\t\twidth: 20%;\n\t\t\t\t\topacity: 0.6;\n\t\t\t\t}\n\t\t\t\t25% {\n\t\t\t\t\twidth: 35%;\n\t\t\t\t\topacity: 1;\n\t\t\t\t}\n\t\t\t\t50% {\n\t\t\t\t\tleft: 40%;\n\t\t\t\t\twidth: 30%;\n\t\t\t\t}\n\t\t\t\t75% {\n\t\t\t\t\twidth: 25%;\n\t\t\t\t\topacity: 0.9;\n\t\t\t\t}\n\t\t\t\t100% {\n\t\t\t\t\tleft: 100%;\n\t\t\t\t\twidth: 20%;\n\t\t\t\t\topacity: 0.6;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t.indeterminate-animation {\n\t\t\t\tanimation: indeterminate 1.8s cubic-bezier(0.34, 1.2, 0.64, 1) infinite;\n\t\t\t}\n\t\t`,\n\t]\n\n\t@property({ type: Number, reflect: true })\n\tvalue = 0\n\n\t@property({ type: Number, reflect: true })\n\tmax = 100\n\n\t@property({ type: Boolean, reflect: true })\n\tindeterminate = false\n\n\t// M3 aligned track heights: xs=1px, sm=2px, md=4px, lg=8px\n\t@property({ type: String, reflect: true })\n\tsize: 'xs' | 'sm' | 'md' | 'lg' = 'md'\n\n\t@property({ type: String, reflect: true })\n\tcolor: 'primary' | 'secondary' | 'tertiary' | 'error' | 'success' = 'primary'\n\n\t@property({ type: Boolean, reflect: true })\n\tglass = false\n\n\tprivate get percentage(): number {\n\t\tif (this.indeterminate) return 0\n\t\treturn Math.min(100, Math.max(0, (this.value / this.max) * 100))\n\t}\n\n\tprotected render() {\n\t\tconst containerClasses = {\n\t\t\t'w-full': true,\n\t\t\trelative: true,\n\t\t\t'overflow-hidden': true,\n\t\t\t'rounded-full': true,\n\t\t\t'h-px': this.size === 'xs', // 1px - M3 linear indicator track\n\t\t\t'h-0.5': this.size === 'sm', // 2px\n\t\t\t'h-1': this.size === 'md', // 4px - M3 default\n\t\t\t'h-2': this.size === 'lg', // 8px\n\t\t\t// Glass effect background\n\t\t\t'backdrop-blur-xl': this.glass,\n\t\t\t'backdrop-saturate-150': this.glass,\n\t\t\t'bg-surface-container/20': this.glass && !this.indeterminate,\n\t\t\t'bg-surface-container': !this.glass,\n\t\t\t'shadow-[inset_0_1px_2px_0_rgba(0,0,0,0.1)]': this.glass,\n\t\t\tborder: this.glass,\n\t\t\t'border-outline/20': this.glass,\n\t\t}\n\n\t\tconst barClasses = {\n\t\t\t'h-full': true,\n\t\t\t'rounded-full': true,\n\t\t\t'transition-all': true,\n\t\t\t'duration-300': true,\n\t\t\t'ease-in-out': true,\n\t\t\trelative: true,\n\t\t\t'bg-primary-default': this.color === 'primary' && !this.glass,\n\t\t\t'bg-secondary-default': this.color === 'secondary' && !this.glass,\n\t\t\t'bg-tertiary-default': this.color === 'tertiary' && !this.glass,\n\t\t\t'bg-error-default': this.color === 'error' && !this.glass,\n\t\t\t'bg-success-default': this.color === 'success' && !this.glass,\n\t\t\tabsolute: this.indeterminate,\n\t\t\t'indeterminate-animation': this.indeterminate,\n\t\t}\n\n\t\tconst barStyles = this.indeterminate ? {} : { width: `${this.percentage}%` }\n\n\t\t// Glass effect bar classes\n\t\tconst glassBarClasses = {\n\t\t\t'backdrop-blur-sm': this.glass,\n\t\t\t'shadow-[0_0_20px_rgba(0,0,0,0.1)]': this.glass,\n\t\t\t// Use semi-transparent background colors for glass effect\n\t\t\t'bg-primary-default/70': this.glass && this.color === 'primary',\n\t\t\t'bg-secondary-default/70': this.glass && this.color === 'secondary',\n\t\t\t'bg-tertiary-default/70': this.glass && this.color === 'tertiary',\n\t\t\t'bg-error-default/70': this.glass && this.color === 'error',\n\t\t\t'bg-success-default/70': this.glass && this.color === 'success',\n\t\t}\n\n\t\treturn html`\n\t\t\t<div class=\"${classMap(containerClasses)}\">\n\t\t\t\t<div\n\t\t\t\t\tclass=\"${classMap({ ...barClasses, ...glassBarClasses })}\"\n\t\t\t\t\tstyle=\"${styleMap(barStyles)}\"\n\t\t\t\t\trole=\"progressbar\"\n\t\t\t\t\taria-valuenow=\"${this.value}\"\n\t\t\t\t\taria-valuemin=\"0\"\n\t\t\t\t\taria-valuemax=\"${this.max}\"\n\t\t\t\t>\n\t\t\t\t\t${this.glass\n\t\t\t\t\t\t? html`\n\t\t\t\t\t\t\t\t<!-- Glass shine effect -->\n\t\t\t\t\t\t\t\t<div class=\"absolute inset-0 bg-linear-to-b from-surface-on/20 to-transparent rounded-full\"></div>\n\t\t\t\t\t\t\t`\n\t\t\t\t\t\t: ''}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-progress': SchmancyProgress\n\t}\n}\n"],"mappings":"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"}
package/dist/progress.cjs CHANGED
@@ -1 +1 @@
1
- require(`./progress-DOVJhsR0.cjs`);
1
+ require(`./progress-DsCnFsH5.cjs`);
package/dist/progress.js CHANGED
@@ -1 +1 @@
1
- import "./progress-CGWozq_n.js";
1
+ import "./progress-D7n3SKAO.js";
@@ -1,4 +1,4 @@
1
- require(`./chunk-CncqDLb2.cjs`);const e=require(`./SchmancyElement-D9WA9FP9.cjs`),t=require(`./mixins-XGVIOvKt.cjs`);let n=require(`rxjs`),r=require(`lit/decorators.js`),i=require(`lit`),a=require(`lit/directives/when.js`);var o=class extends t.i(e.t){constructor(...e){super(...e),this.label=``,this.name=``,this.value=``,this.required=!1}static{this.styles=[(0,i.unsafeCSS)(`:host{display:inherit;position:inherit}`)]}connectedCallback(){super.connectedCallback(),(0,n.fromEvent)(this,`radio-button-click`).pipe((0,n.takeUntil)(this.disconnecting)).subscribe(e=>{this.value=e.detail.value,this.emitChange({value:e.detail.value}),this.syncChildren()})}updated(e){super.updated(e),e.has(`value`)&&this.syncChildren()}syncChildren(){this.querySelectorAll(`schmancy-radio-button`).forEach(e=>{e.checked=e.value===this.value})}render(){return i.html`
1
+ require(`./chunk-CncqDLb2.cjs`);const e=require(`./SchmancyElement-CeKrBW2j.cjs`),t=require(`./mixins-Cjn20BQH.cjs`);let n=require(`rxjs`),r=require(`lit/decorators.js`),i=require(`lit`),a=require(`lit/directives/when.js`);var o=class extends t.i(e.t){constructor(...e){super(...e),this.label=``,this.name=``,this.value=``,this.required=!1}static{this.styles=[(0,i.unsafeCSS)(`:host{display:inherit;position:inherit}`)]}connectedCallback(){super.connectedCallback(),(0,n.fromEvent)(this,`radio-button-click`).pipe((0,n.takeUntil)(this.disconnecting)).subscribe(e=>{this.value=e.detail.value,this.emitChange({value:e.detail.value}),this.syncChildren()})}updated(e){super.updated(e),e.has(`value`)&&this.syncChildren()}syncChildren(){this.querySelectorAll(`schmancy-radio-button`).forEach(e=>{e.checked=e.value===this.value})}render(){return i.html`
2
2
  <div role="radiogroup" aria-label=${this.label} aria-required=${this.required} class="grid gap-2">
3
3
  ${(0,a.when)(this.label,()=>i.html`<schmancy-typography type="label" token="lg">${this.label}</schmancy-typography>`)}
4
4
  <slot></slot>
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-group-CaAjg9UV.cjs","names":[],"sources":["../src/form/fields/radio-group/radio-group.scss?inline","../src/form/fields/radio-group/radio-group.ts","../src/form/fields/radio-group/radio-button.ts"],"sourcesContent":[":host {\n\tdisplay: inherit;\n\tposition: inherit;\n}\n","import { html, unsafeCSS } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\nimport style from './radio-group.scss?inline'\nimport { SchmancyElement } from '@mixins/index'\nimport { when } from 'lit/directives/when.js'\nimport { FormFieldMixin } from '@mixins/formField.mixin'\nimport type { RadioButton } from './radio-button.ts'\n\nexport type SchmancyRadioGroupChangeEvent = CustomEvent<{ value: string }>\n\n@customElement('schmancy-radio-group')\nexport class RadioGroup extends FormFieldMixin(SchmancyElement) {\n\tstatic styles = [unsafeCSS(style)]\n\t@property({ type: String }) override label = ''\n\t@property({ type: String }) override name = ''\n\t@property({ type: String }) override value = ''\n\t@property({ type: Boolean }) override required = false\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(this, 'radio-button-click')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe((e: CustomEvent<{ value: string }>) => {\n\t\t\t\tthis.value = e.detail.value\n\t\t\t\tthis.emitChange({ value: e.detail.value })\n\t\t\t\tthis.syncChildren()\n\t\t\t})\n\t}\n\n\tupdated(changed: Map<string, unknown>) {\n\t\tsuper.updated(changed)\n\t\tif (changed.has('value')) this.syncChildren()\n\t}\n\n\tprivate syncChildren() {\n\t\tthis.querySelectorAll<RadioButton>('schmancy-radio-button').forEach(btn => {\n\t\t\tbtn.checked = btn.value === this.value\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div role=\"radiogroup\" aria-label=${this.label} aria-required=${this.required} class=\"grid gap-2\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>`,\n\t\t\t\t)}\n\t\t\t\t<slot></slot>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-radio-group': RadioGroup\n\t}\n}\n","import { SchmancyElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n/**\n * Radio button component for use within radio groups.\n *\n * @prop {string} name - Name attribute for grouping radio buttons\n * @prop {string} value - Value of this radio button\n * @prop {boolean} checked - Whether the radio button is selected\n * @prop {boolean} disabled - Whether the radio button is disabled\n */\n@customElement('schmancy-radio-button')\nexport class RadioButton extends SchmancyElement {\n\t@property({ type: String }) value = ''\n\t@property({ type: Boolean, reflect: true }) checked = false\n\t@property({ type: Boolean }) disabled = false\n\t@property({ type: String }) name = ''\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<MouseEvent>(this, 'click').pipe(takeUntil(this.disconnecting)).subscribe(this.handleClick)\n\t}\n\n\tprivate handleClick = () => {\n\t\tif (this.disabled) return\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('radio-button-click', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<label class=\"flex items-center gap-3 cursor-pointer\">\n\t\t\t\t<input\n\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\tclass=\"h-4 w-4 text-primary-default focus:ring-primary-container border-outline\"\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.checked=${this.checked}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t@change=${() => {}}\n\t\t\t\t/>\n\t\t\t\t<slot></slot>\n\t\t\t</label>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-radio-button': RadioButton\n\t}\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { t as e, u as t } from "./SchmancyElement-OWgz9ePG.js";
2
- import { i as n } from "./mixins-COeG4DiX.js";
1
+ import { t as e, u as t } from "./SchmancyElement-Ob9yGkiG.js";
2
+ import { i as n } from "./mixins-q4KAL8Xr.js";
3
3
  import { fromEvent as r, takeUntil as i } from "rxjs";
4
4
  import { customElement as a, property as o } from "lit/decorators.js";
5
5
  import { html as s, unsafeCSS as c } from "lit";
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-group-Drpl6Pl8.js","names":[],"sources":["../src/form/fields/radio-group/radio-group.scss?inline","../src/form/fields/radio-group/radio-group.ts","../src/form/fields/radio-group/radio-button.ts"],"sourcesContent":[":host {\n\tdisplay: inherit;\n\tposition: inherit;\n}\n","import { html, unsafeCSS } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\nimport style from './radio-group.scss?inline'\nimport { SchmancyElement } from '@mixins/index'\nimport { when } from 'lit/directives/when.js'\nimport { FormFieldMixin } from '@mixins/formField.mixin'\nimport type { RadioButton } from './radio-button.ts'\n\nexport type SchmancyRadioGroupChangeEvent = CustomEvent<{ value: string }>\n\n@customElement('schmancy-radio-group')\nexport class RadioGroup extends FormFieldMixin(SchmancyElement) {\n\tstatic styles = [unsafeCSS(style)]\n\t@property({ type: String }) override label = ''\n\t@property({ type: String }) override name = ''\n\t@property({ type: String }) override value = ''\n\t@property({ type: Boolean }) override required = false\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<CustomEvent>(this, 'radio-button-click')\n\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t.subscribe((e: CustomEvent<{ value: string }>) => {\n\t\t\t\tthis.value = e.detail.value\n\t\t\t\tthis.emitChange({ value: e.detail.value })\n\t\t\t\tthis.syncChildren()\n\t\t\t})\n\t}\n\n\tupdated(changed: Map<string, unknown>) {\n\t\tsuper.updated(changed)\n\t\tif (changed.has('value')) this.syncChildren()\n\t}\n\n\tprivate syncChildren() {\n\t\tthis.querySelectorAll<RadioButton>('schmancy-radio-button').forEach(btn => {\n\t\t\tbtn.checked = btn.value === this.value\n\t\t})\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div role=\"radiogroup\" aria-label=${this.label} aria-required=${this.required} class=\"grid gap-2\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`<schmancy-typography type=\"label\" token=\"lg\">${this.label}</schmancy-typography>`,\n\t\t\t\t)}\n\t\t\t\t<slot></slot>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-radio-group': RadioGroup\n\t}\n}\n","import { SchmancyElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { fromEvent, takeUntil } from 'rxjs'\n\n/**\n * Radio button component for use within radio groups.\n *\n * @prop {string} name - Name attribute for grouping radio buttons\n * @prop {string} value - Value of this radio button\n * @prop {boolean} checked - Whether the radio button is selected\n * @prop {boolean} disabled - Whether the radio button is disabled\n */\n@customElement('schmancy-radio-button')\nexport class RadioButton extends SchmancyElement {\n\t@property({ type: String }) value = ''\n\t@property({ type: Boolean, reflect: true }) checked = false\n\t@property({ type: Boolean }) disabled = false\n\t@property({ type: String }) name = ''\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tfromEvent<MouseEvent>(this, 'click').pipe(takeUntil(this.disconnecting)).subscribe(this.handleClick)\n\t}\n\n\tprivate handleClick = () => {\n\t\tif (this.disabled) return\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent('radio-button-click', {\n\t\t\t\tdetail: { value: this.value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<label class=\"flex items-center gap-3 cursor-pointer\">\n\t\t\t\t<input\n\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\tclass=\"h-4 w-4 text-primary-default focus:ring-primary-container border-outline\"\n\t\t\t\t\t.value=${this.value}\n\t\t\t\t\t.checked=${this.checked}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\t@change=${() => {}}\n\t\t\t\t/>\n\t\t\t\t<slot></slot>\n\t\t\t</label>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-radio-button': RadioButton\n\t}\n}\n"],"mappings":";;;;;;ICYO,IAAA,cAAyB,EAAe,CAAA,EAAA;CAAA,YAAA,GAAA,GAAA;EAAA,MAAA,GAAA,CAAA,GAAA,KAAA,QAED,IAAA,KAAA,OACD,IAAA,KAAA,QACC,IAAA,KAAA,WAAA,CACI;CAAA;CAAA;EAAA,KAAA,SAJjC,CAAC,EAAA,yCAAA,CAAA;CAAA;CAMjB,oBAAA;EACC,MAAM,kBAAA,GACN,EAAuB,MAAM,oBAAA,EAC3B,KAAK,EAAU,KAAK,aAAA,CAAA,EACpB,WAAW,MAAA;GACX,KAAK,QAAQ,EAAE,OAAO,OACtB,KAAK,WAAW,EAAE,OAAO,EAAE,OAAO,MAAA,CAAA,GAClC,KAAK,aAAA;EAAA,CAAA;CAER;CAEA,QAAQ,GAAA;EACP,MAAM,QAAQ,CAAA,GACV,EAAQ,IAAI,OAAA,KAAU,KAAK,aAAA;CAChC;CAEA,eAAA;EACC,KAAK,iBAA8B,uBAAA,EAAyB,SAAQ,MAAA;GACnE,EAAI,UAAU,EAAI,UAAU,KAAK;EAAA,CAAA;CAEnC;CAEA,SAAA;EACC,OAAO,CAAI;uCAC0B,KAAK,MAAA,iBAAuB,KAAK,SAAA;MAClE,EACD,KAAK,aACC,CAAI,gDAAgD,KAAK,MAAA,uBAAA,EAAA;;;;CAKnE;AAAA;AAAA,EAAA,CArCC,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,SAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,QAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,SAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,QAAA,CAAA,CAAA,GAAS,EAAA,WAAA,YAAA,KAAA,CAAA,GAAA,IAAA,EAAA,CAN3B,EAAc,sBAAA,CAAA,GAAsB,CAAA;ACG9B,IAAA,IAAA,cAA0B,EAAA;CAAA,YAAA,GAAA,GAAA;EAAA,MAAA,GAAA,CAAA,GAAA,KAAA,QACI,IAAA,KAAA,UAAA,CACkB,GAAA,KAAA,WAAA,CACd,GAAA,KAAA,OACL,IAAA,KAAA,oBAAA;GAQ9B,KAAK,YACT,KAAK,cACJ,IAAI,YAAY,sBAAsB;IACrC,QAAQ,EAAE,OAAO,KAAK,MAAA;IACtB,SAAA,CAAS;IACT,UAAA,CAAU;GAAA,CAAA,CAAA;EAAA;CAAA;CAXb,oBAAA;EACC,MAAM,kBAAA,GACN,EAAsB,MAAM,OAAA,EAAS,KAAK,EAAU,KAAK,aAAA,CAAA,EAAgB,UAAU,KAAK,WAAA;CACzF;CAaA,SAAA;EACC,OAAO,CAAI;;;;;cAKC,KAAK,MAAA;gBACH,KAAK,QAAA;iBACJ,KAAK,SAAA;aACT,KAAK,KAAA;;;;;;CAMjB;AAAA;AAAA,EAAA,CApCC,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,SAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS;CAAE,MAAM;CAAS,SAAA,CAAS;AAAA,CAAA,CAAA,GAAM,EAAA,WAAA,WAAA,KAAA,CAAA,GAAA,EAAA,CACzC,EAAS,EAAE,MAAM,QAAA,CAAA,CAAA,GAAS,EAAA,WAAA,YAAA,KAAA,CAAA,GAAA,EAAA,CAC1B,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,QAAA,KAAA,CAAA,GAAA,IAAA,EAAA,CAL1B,EAAc,uBAAA,CAAA,GAAuB,CAAA;AAAA,SAAA,KAAA,GAAA,KAAA"}
@@ -1 +1 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./radio-group-DoSX5D2V.cjs`);Object.defineProperty(exports,`RadioButton`,{enumerable:!0,get:function(){return e.t}}),Object.defineProperty(exports,`RadioGroup`,{enumerable:!0,get:function(){return e.n}});
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./radio-group-CaAjg9UV.cjs`);Object.defineProperty(exports,`RadioButton`,{enumerable:!0,get:function(){return e.t}}),Object.defineProperty(exports,`RadioGroup`,{enumerable:!0,get:function(){return e.n}});
@@ -1,2 +1,2 @@
1
- import { n as e, t } from "./radio-group-CXkq6qAF.js";
1
+ import { n as e, t } from "./radio-group-Drpl6Pl8.js";
2
2
  export { t as RadioButton, e as RadioGroup };
package/dist/range.cjs CHANGED
@@ -1,4 +1,4 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-CncqDLb2.cjs`);const e=require(`./SchmancyElement-D9WA9FP9.cjs`),t=require(`./mixins-XGVIOvKt.cjs`);let n=require(`lit/decorators.js`),r=require(`lit`),i=require(`lit/directives/when.js`);var a=class extends t.o(r.css`
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./chunk-CncqDLb2.cjs`);const e=require(`./SchmancyElement-CeKrBW2j.cjs`),t=require(`./mixins-Cjn20BQH.cjs`);let n=require(`lit/decorators.js`),r=require(`lit`),i=require(`lit/directives/when.js`);var a=class extends t.o(r.css`
2
2
  input[type='range'] {
3
3
  -webkit-appearance: none;
4
4
  appearance: none;
@@ -45,7 +45,9 @@ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`}),require(`./ch
45
45
  ${(0,i.when)(this.label,()=>r.html`
46
46
  <div class="flex justify-between items-center">
47
47
  <schmancy-typography type="label" token="sm" class="text-surface-on">${this.label}</schmancy-typography>
48
- <schmancy-typography type="label" token="sm" class="text-surface-on opacity-60">${this.value}</schmancy-typography>
48
+ <schmancy-typography type="label" token="sm" class="text-surface-on opacity-60"
49
+ >${this.value}</schmancy-typography
50
+ >
49
51
  </div>
50
52
  `)}
51
53
  <input
@@ -1 +1 @@
1
- {"version":3,"file":"range.cjs","names":[],"sources":["../src/form/fields/range/range.ts"],"sourcesContent":["import { css, html, type PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyFormField } from '@mixins/index'\n\nexport type SchmancyRangeChangeEvent = CustomEvent<{ value: number }>\n\n/**\n * @element schmancy-range\n * Range input (numeric slider).\n * @fires change - Fires on value change with `{ value: number }`.\n */\n@customElement('schmancy-range')\nexport class SchmancyRange extends SchmancyFormField(css`\n\tinput[type='range'] {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 100%;\n\t\theight: 4px;\n\t\tborder-radius: 2px;\n\t\tbackground: linear-gradient(\n\t\t\tto right,\n\t\t\tvar(--color-primary, #6750a4) 0%,\n\t\t\tvar(--color-primary, #6750a4) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) 100%\n\t\t);\n\t\toutline: none;\n\t\tcursor: pointer;\n\t}\n\tinput[type='range']:disabled {\n\t\topacity: 0.38;\n\t\tcursor: not-allowed;\n\t}\n\tinput[type='range']::-webkit-slider-thumb {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t\ttransition: box-shadow 0.1s ease;\n\t}\n\tinput[type='range']::-webkit-slider-thumb:hover {\n\t\tbox-shadow: 0 0 0 8px color-mix(in srgb, var(--color-primary, #6750a4) 12%, transparent);\n\t}\n\tinput[type='range']::-moz-range-thumb {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tborder: none;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t}\n`) {\n\t// `formAssociated`, `internals`, `name`, `disabled`, `required`, `id`,\n\t// `label`, `error`, `validationMessage`, `validateOn`, touched/dirty/submitted,\n\t// `markTouched/markSubmitted`, `formResetCallback`, FIELD_CONNECT_EVENT\n\t// dispatch — all from the mixin.\n\n\t@property({ type: Number }) min: number = 0\n\t@property({ type: Number }) max: number = 1\n\t@property({ type: Number }) step: number = 0.01\n\n\t/** Numeric value — narrowed override of the mixin's wide value union. */\n\t@property({ type: Number, reflect: true })\n\toverride value: number = 0\n\n\tprivate get progress(): string {\n\t\treturn `${((this.value - this.min) / (this.max - this.min)) * 100}%`\n\t}\n\n\toverride willUpdate(changed: PropertyValues): void {\n\t\tsuper.willUpdate(changed)\n\t\tif (changed.has('value') || changed.has('name')) {\n\t\t\tthis.internals?.setFormValue(String(this.value))\n\t\t}\n\t}\n\n\t/** FormData contributes the value as a string (native range input convention). */\n\toverride toFormEntries(): Array<[string, FormDataEntryValue]> {\n\t\tif (!this.name || this.disabled) return []\n\t\treturn [[this.name, String(this.value)]]\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex flex-col gap-1 w-full\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<div class=\"flex justify-between items-center\">\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on\">${this.label}</schmancy-typography>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on opacity-60\">${this.value}</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t)}\n\t\t\t\t<input\n\t\t\t\t\ttype=\"range\"\n\t\t\t\t\t.min=${String(this.min)}\n\t\t\t\t\t.max=${String(this.max)}\n\t\t\t\t\t.step=${String(this.step)}\n\t\t\t\t\t.value=${String(this.value)}\n\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\taria-label=${this.label || 'Range'}\n\t\t\t\t\taria-valuetext=${String(this.value)}\n\t\t\t\t\tstyle=\"--range-progress: ${this.progress}\"\n\t\t\t\t\t@input=${(e: Event) => {\n\t\t\t\t\t\tthis.value = Number((e.target as HTMLInputElement).value)\n\t\t\t\t\t\tthis.markTouched()\n\t\t\t\t\t\tthis.emitChange({ value: this.value })\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-range': SchmancyRange\n\t}\n}\n"],"mappings":"gRAaO,IAAA,EAAA,cAA4B,EAAA,EAAkB,EAAA,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAgDb,EAAA,KAAA,IACA,EAAA,KAAA,KACC,IAAA,KAAA,MAIlB,CAAA,CAEzB,IAAA,UAAY,CACX,OAAY,KAAK,MAAQ,KAAK,MAAQ,KAAK,IAAM,KAAK,KAAQ,IAAvD,GACR,CAEA,WAAoB,EAAA,CACnB,MAAM,WAAW,CAAA,GACb,EAAQ,IAAI,OAAA,GAAY,EAAQ,IAAI,MAAA,IACvC,KAAK,WAAW,aAAa,OAAO,KAAK,KAAA,CAAA,CAE3C,CAGA,eAAA,CACC,MAAA,CAAK,KAAK,MAAQ,KAAK,SAAiB,CAAA,EACjC,CAAC,CAAC,KAAK,KAAM,OAAO,KAAK,KAAA,CAAA,CAAA,CACjC,CAEA,QAAA,CACC,MAAO,GAAA,IAAI;;iBAGR,KAAK,UACC,EAAA,IAAI;;8EAE+D,KAAK,MAAA;yFACM,KAAK,MAAA;;;;;YAMlF,OAAO,KAAK,GAAA,EAAA;YACZ,OAAO,KAAK,GAAA,EAAA;aACX,OAAO,KAAK,IAAA,EAAA;cACX,OAAO,KAAK,KAAA,EAAA;iBACT,KAAK,SAAA;kBACJ,KAAK,OAAS,QAAA;sBACV,OAAO,KAAK,KAAA,EAAA;gCACF,KAAK,SAAA;cACtB,GAAA,CACT,KAAK,MAAQ,OAAQ,EAAE,OAA4B,KAAA,EACnD,KAAK,YAAA,EACL,KAAK,WAAW,CAAE,MAAO,KAAK,KAAA,CAAA,CAAA,EAAA;;;GAKnC,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAvDU,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,MAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAChB,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,MAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAChB,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,OAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAGhB,CAAE,KAAM,OAAQ,QAAA,CAAS,CAAA,CAAA,CAAA,EAAM,EAAA,UAAA,QAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,eAtD3B,gBAAA,CAAA,EAAgB,CAAA,EAAA,OAAA,eAAA,QAAA,gBAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"range.cjs","names":[],"sources":["../src/form/fields/range/range.ts"],"sourcesContent":["import { css, html, type PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyFormField } from '@mixins/index'\n\nexport type SchmancyRangeChangeEvent = CustomEvent<{ value: number }>\n\n/**\n * @element schmancy-range\n * Range input (numeric slider).\n * @fires change - Fires on value change with `{ value: number }`.\n */\n@customElement('schmancy-range')\nexport class SchmancyRange extends SchmancyFormField(css`\n\tinput[type='range'] {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 100%;\n\t\theight: 4px;\n\t\tborder-radius: 2px;\n\t\tbackground: linear-gradient(\n\t\t\tto right,\n\t\t\tvar(--color-primary, #6750a4) 0%,\n\t\t\tvar(--color-primary, #6750a4) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) 100%\n\t\t);\n\t\toutline: none;\n\t\tcursor: pointer;\n\t}\n\tinput[type='range']:disabled {\n\t\topacity: 0.38;\n\t\tcursor: not-allowed;\n\t}\n\tinput[type='range']::-webkit-slider-thumb {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t\ttransition: box-shadow 0.1s ease;\n\t}\n\tinput[type='range']::-webkit-slider-thumb:hover {\n\t\tbox-shadow: 0 0 0 8px color-mix(in srgb, var(--color-primary, #6750a4) 12%, transparent);\n\t}\n\tinput[type='range']::-moz-range-thumb {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tborder: none;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t}\n`) {\n\t// `formAssociated`, `internals`, `name`, `disabled`, `required`, `id`,\n\t// `label`, `error`, `validationMessage`, `validateOn`, touched/dirty/submitted,\n\t// `markTouched/markSubmitted`, `formResetCallback`, FIELD_CONNECT_EVENT\n\t// dispatch — all from the mixin.\n\n\t@property({ type: Number }) min: number = 0\n\t@property({ type: Number }) max: number = 1\n\t@property({ type: Number }) step: number = 0.01\n\n\t/** Numeric value — narrowed override of the mixin's wide value union. */\n\t@property({ type: Number, reflect: true })\n\toverride value: number = 0\n\n\tprivate get progress(): string {\n\t\treturn `${((this.value - this.min) / (this.max - this.min)) * 100}%`\n\t}\n\n\toverride willUpdate(changed: PropertyValues): void {\n\t\tsuper.willUpdate(changed)\n\t\tif (changed.has('value') || changed.has('name')) {\n\t\t\tthis.internals?.setFormValue(String(this.value))\n\t\t}\n\t}\n\n\t/** FormData contributes the value as a string (native range input convention). */\n\toverride toFormEntries(): Array<[string, FormDataEntryValue]> {\n\t\tif (!this.name || this.disabled) return []\n\t\treturn [[this.name, String(this.value)]]\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex flex-col gap-1 w-full\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<div class=\"flex justify-between items-center\">\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on\">${this.label}</schmancy-typography>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on opacity-60\"\n\t\t\t\t\t\t\t\t>${this.value}</schmancy-typography\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t)}\n\t\t\t\t<input\n\t\t\t\t\ttype=\"range\"\n\t\t\t\t\t.min=${String(this.min)}\n\t\t\t\t\t.max=${String(this.max)}\n\t\t\t\t\t.step=${String(this.step)}\n\t\t\t\t\t.value=${String(this.value)}\n\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\taria-label=${this.label || 'Range'}\n\t\t\t\t\taria-valuetext=${String(this.value)}\n\t\t\t\t\tstyle=\"--range-progress: ${this.progress}\"\n\t\t\t\t\t@input=${(e: Event) => {\n\t\t\t\t\t\tthis.value = Number((e.target as HTMLInputElement).value)\n\t\t\t\t\t\tthis.markTouched()\n\t\t\t\t\t\tthis.emitChange({ value: this.value })\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-range': SchmancyRange\n\t}\n}\n"],"mappings":"gRAaO,IAAA,EAAA,cAA4B,EAAA,EAAkB,EAAA,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAgDb,EAAA,KAAA,IACA,EAAA,KAAA,KACC,IAAA,KAAA,MAIlB,CAAA,CAEzB,IAAA,UAAY,CACX,OAAY,KAAK,MAAQ,KAAK,MAAQ,KAAK,IAAM,KAAK,KAAQ,IAAvD,GACR,CAEA,WAAoB,EAAA,CACnB,MAAM,WAAW,CAAA,GACb,EAAQ,IAAI,OAAA,GAAY,EAAQ,IAAI,MAAA,IACvC,KAAK,WAAW,aAAa,OAAO,KAAK,KAAA,CAAA,CAE3C,CAGA,eAAA,CACC,MAAA,CAAK,KAAK,MAAQ,KAAK,SAAiB,CAAA,EACjC,CAAC,CAAC,KAAK,KAAM,OAAO,KAAK,KAAA,CAAA,CAAA,CACjC,CAEA,QAAA,CACC,MAAO,GAAA,IAAI;;iBAGR,KAAK,UACC,EAAA,IAAI;;8EAE+D,KAAK,MAAA;;WAExE,KAAK,MAAA;;;;;;YAOJ,OAAO,KAAK,GAAA,EAAA;YACZ,OAAO,KAAK,GAAA,EAAA;aACX,OAAO,KAAK,IAAA,EAAA;cACX,OAAO,KAAK,KAAA,EAAA;iBACT,KAAK,SAAA;kBACJ,KAAK,OAAS,QAAA;sBACV,OAAO,KAAK,KAAA,EAAA;gCACF,KAAK,SAAA;cACtB,GAAA,CACT,KAAK,MAAQ,OAAQ,EAAE,OAA4B,KAAA,EACnD,KAAK,YAAA,EACL,KAAK,WAAW,CAAE,MAAO,KAAK,KAAA,CAAA,CAAA,EAAA;;;GAKnC,CAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAzDU,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,MAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAChB,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,MAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAChB,CAAE,KAAM,MAAA,CAAA,CAAA,EAAQ,EAAA,UAAA,OAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,UAGhB,CAAE,KAAM,OAAQ,QAAA,CAAS,CAAA,CAAA,CAAA,EAAM,EAAA,UAAA,QAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,eAtD3B,gBAAA,CAAA,EAAgB,CAAA,EAAA,OAAA,eAAA,QAAA,gBAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
package/dist/range.js CHANGED
@@ -1,5 +1,5 @@
1
- import { u as e } from "./SchmancyElement-OWgz9ePG.js";
2
- import { o as t } from "./mixins-COeG4DiX.js";
1
+ import { u as e } from "./SchmancyElement-Ob9yGkiG.js";
2
+ import { o as t } from "./mixins-q4KAL8Xr.js";
3
3
  import { customElement as n, property as r } from "lit/decorators.js";
4
4
  import { css as i, html as a } from "lit";
5
5
  import { when as o } from "lit/directives/when.js";
@@ -64,7 +64,9 @@ var s = class extends t(i`
64
64
  ${o(this.label, () => a`
65
65
  <div class="flex justify-between items-center">
66
66
  <schmancy-typography type="label" token="sm" class="text-surface-on">${this.label}</schmancy-typography>
67
- <schmancy-typography type="label" token="sm" class="text-surface-on opacity-60">${this.value}</schmancy-typography>
67
+ <schmancy-typography type="label" token="sm" class="text-surface-on opacity-60"
68
+ >${this.value}</schmancy-typography
69
+ >
68
70
  </div>
69
71
  `)}
70
72
  <input
package/dist/range.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"range.js","names":[],"sources":["../src/form/fields/range/range.ts"],"sourcesContent":["import { css, html, type PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyFormField } from '@mixins/index'\n\nexport type SchmancyRangeChangeEvent = CustomEvent<{ value: number }>\n\n/**\n * @element schmancy-range\n * Range input (numeric slider).\n * @fires change - Fires on value change with `{ value: number }`.\n */\n@customElement('schmancy-range')\nexport class SchmancyRange extends SchmancyFormField(css`\n\tinput[type='range'] {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 100%;\n\t\theight: 4px;\n\t\tborder-radius: 2px;\n\t\tbackground: linear-gradient(\n\t\t\tto right,\n\t\t\tvar(--color-primary, #6750a4) 0%,\n\t\t\tvar(--color-primary, #6750a4) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) 100%\n\t\t);\n\t\toutline: none;\n\t\tcursor: pointer;\n\t}\n\tinput[type='range']:disabled {\n\t\topacity: 0.38;\n\t\tcursor: not-allowed;\n\t}\n\tinput[type='range']::-webkit-slider-thumb {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t\ttransition: box-shadow 0.1s ease;\n\t}\n\tinput[type='range']::-webkit-slider-thumb:hover {\n\t\tbox-shadow: 0 0 0 8px color-mix(in srgb, var(--color-primary, #6750a4) 12%, transparent);\n\t}\n\tinput[type='range']::-moz-range-thumb {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tborder: none;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t}\n`) {\n\t// `formAssociated`, `internals`, `name`, `disabled`, `required`, `id`,\n\t// `label`, `error`, `validationMessage`, `validateOn`, touched/dirty/submitted,\n\t// `markTouched/markSubmitted`, `formResetCallback`, FIELD_CONNECT_EVENT\n\t// dispatch — all from the mixin.\n\n\t@property({ type: Number }) min: number = 0\n\t@property({ type: Number }) max: number = 1\n\t@property({ type: Number }) step: number = 0.01\n\n\t/** Numeric value — narrowed override of the mixin's wide value union. */\n\t@property({ type: Number, reflect: true })\n\toverride value: number = 0\n\n\tprivate get progress(): string {\n\t\treturn `${((this.value - this.min) / (this.max - this.min)) * 100}%`\n\t}\n\n\toverride willUpdate(changed: PropertyValues): void {\n\t\tsuper.willUpdate(changed)\n\t\tif (changed.has('value') || changed.has('name')) {\n\t\t\tthis.internals?.setFormValue(String(this.value))\n\t\t}\n\t}\n\n\t/** FormData contributes the value as a string (native range input convention). */\n\toverride toFormEntries(): Array<[string, FormDataEntryValue]> {\n\t\tif (!this.name || this.disabled) return []\n\t\treturn [[this.name, String(this.value)]]\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex flex-col gap-1 w-full\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<div class=\"flex justify-between items-center\">\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on\">${this.label}</schmancy-typography>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on opacity-60\">${this.value}</schmancy-typography>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t)}\n\t\t\t\t<input\n\t\t\t\t\ttype=\"range\"\n\t\t\t\t\t.min=${String(this.min)}\n\t\t\t\t\t.max=${String(this.max)}\n\t\t\t\t\t.step=${String(this.step)}\n\t\t\t\t\t.value=${String(this.value)}\n\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\taria-label=${this.label || 'Range'}\n\t\t\t\t\taria-valuetext=${String(this.value)}\n\t\t\t\t\tstyle=\"--range-progress: ${this.progress}\"\n\t\t\t\t\t@input=${(e: Event) => {\n\t\t\t\t\t\tthis.value = Number((e.target as HTMLInputElement).value)\n\t\t\t\t\t\tthis.markTouched()\n\t\t\t\t\t\tthis.emitChange({ value: this.value })\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-range': SchmancyRange\n\t}\n}\n"],"mappings":";;;;;AAaO,IAAA,IAAA,cAA4B,EAAkB,CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAgDb,GAAA,KAAA,MACA,GAAA,KAAA,OACC,KAAA,KAAA,QAIlB;CAAA;CAEzB,IAAA,WAAY;EACX,QAAY,KAAK,QAAQ,KAAK,QAAQ,KAAK,MAAM,KAAK,OAAQ,MAAvD;CACR;CAEA,WAAoB,GAAA;EACnB,MAAM,WAAW,CAAA,IACb,EAAQ,IAAI,OAAA,KAAY,EAAQ,IAAI,MAAA,MACvC,KAAK,WAAW,aAAa,OAAO,KAAK,KAAA,CAAA;CAE3C;CAGA,gBAAA;EACC,OAAA,CAAK,KAAK,QAAQ,KAAK,WAAiB,CAAA,IACjC,CAAC,CAAC,KAAK,MAAM,OAAO,KAAK,KAAA,CAAA,CAAA;CACjC;CAEA,SAAA;EACC,OAAO,CAAI;;MAEP,EACD,KAAK,aACC,CAAI;;8EAE+D,KAAK,MAAA;yFACM,KAAK,MAAA;;;;;YAMlF,OAAO,KAAK,GAAA,EAAA;YACZ,OAAO,KAAK,GAAA,EAAA;aACX,OAAO,KAAK,IAAA,EAAA;cACX,OAAO,KAAK,KAAA,EAAA;iBACT,KAAK,SAAA;kBACJ,KAAK,SAAS,QAAA;sBACV,OAAO,KAAK,KAAA,EAAA;gCACF,KAAK,SAAA;eACtB,MAAA;GACT,KAAK,QAAQ,OAAQ,EAAE,OAA4B,KAAA,GACnD,KAAK,YAAA,GACL,KAAK,WAAW,EAAE,OAAO,KAAK,MAAA,CAAA;EAAA,EAAA;;;;CAKnC;AAAA;AAAA,EAAA,CAvDC,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,OAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,OAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,QAAA,KAAA,CAAA,GAAA,EAAA,CAGzB,EAAS;CAAE,MAAM;CAAQ,SAAA,CAAS;AAAA,CAAA,CAAA,GAAM,EAAA,WAAA,SAAA,KAAA,CAAA,GAAA,IAAA,EAAA,CAtDzC,EAAc,gBAAA,CAAA,GAAgB,CAAA;AAAA,SAAA,KAAA"}
1
+ {"version":3,"file":"range.js","names":[],"sources":["../src/form/fields/range/range.ts"],"sourcesContent":["import { css, html, type PropertyValues } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { when } from 'lit/directives/when.js'\nimport { SchmancyFormField } from '@mixins/index'\n\nexport type SchmancyRangeChangeEvent = CustomEvent<{ value: number }>\n\n/**\n * @element schmancy-range\n * Range input (numeric slider).\n * @fires change - Fires on value change with `{ value: number }`.\n */\n@customElement('schmancy-range')\nexport class SchmancyRange extends SchmancyFormField(css`\n\tinput[type='range'] {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 100%;\n\t\theight: 4px;\n\t\tborder-radius: 2px;\n\t\tbackground: linear-gradient(\n\t\t\tto right,\n\t\t\tvar(--color-primary, #6750a4) 0%,\n\t\t\tvar(--color-primary, #6750a4) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) var(--range-progress, 0%),\n\t\t\tcolor-mix(in srgb, var(--color-primary, #6750a4) 30%, transparent) 100%\n\t\t);\n\t\toutline: none;\n\t\tcursor: pointer;\n\t}\n\tinput[type='range']:disabled {\n\t\topacity: 0.38;\n\t\tcursor: not-allowed;\n\t}\n\tinput[type='range']::-webkit-slider-thumb {\n\t\t-webkit-appearance: none;\n\t\tappearance: none;\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t\ttransition: box-shadow 0.1s ease;\n\t}\n\tinput[type='range']::-webkit-slider-thumb:hover {\n\t\tbox-shadow: 0 0 0 8px color-mix(in srgb, var(--color-primary, #6750a4) 12%, transparent);\n\t}\n\tinput[type='range']::-moz-range-thumb {\n\t\twidth: 20px;\n\t\theight: 20px;\n\t\tborder-radius: 50%;\n\t\tborder: none;\n\t\tbackground: var(--color-primary, #6750a4);\n\t\tcursor: pointer;\n\t}\n`) {\n\t// `formAssociated`, `internals`, `name`, `disabled`, `required`, `id`,\n\t// `label`, `error`, `validationMessage`, `validateOn`, touched/dirty/submitted,\n\t// `markTouched/markSubmitted`, `formResetCallback`, FIELD_CONNECT_EVENT\n\t// dispatch — all from the mixin.\n\n\t@property({ type: Number }) min: number = 0\n\t@property({ type: Number }) max: number = 1\n\t@property({ type: Number }) step: number = 0.01\n\n\t/** Numeric value — narrowed override of the mixin's wide value union. */\n\t@property({ type: Number, reflect: true })\n\toverride value: number = 0\n\n\tprivate get progress(): string {\n\t\treturn `${((this.value - this.min) / (this.max - this.min)) * 100}%`\n\t}\n\n\toverride willUpdate(changed: PropertyValues): void {\n\t\tsuper.willUpdate(changed)\n\t\tif (changed.has('value') || changed.has('name')) {\n\t\t\tthis.internals?.setFormValue(String(this.value))\n\t\t}\n\t}\n\n\t/** FormData contributes the value as a string (native range input convention). */\n\toverride toFormEntries(): Array<[string, FormDataEntryValue]> {\n\t\tif (!this.name || this.disabled) return []\n\t\treturn [[this.name, String(this.value)]]\n\t}\n\n\trender() {\n\t\treturn html`\n\t\t\t<div class=\"flex flex-col gap-1 w-full\">\n\t\t\t\t${when(\n\t\t\t\t\tthis.label,\n\t\t\t\t\t() => html`\n\t\t\t\t\t\t<div class=\"flex justify-between items-center\">\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on\">${this.label}</schmancy-typography>\n\t\t\t\t\t\t\t<schmancy-typography type=\"label\" token=\"sm\" class=\"text-surface-on opacity-60\"\n\t\t\t\t\t\t\t\t>${this.value}</schmancy-typography\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t`,\n\t\t\t\t)}\n\t\t\t\t<input\n\t\t\t\t\ttype=\"range\"\n\t\t\t\t\t.min=${String(this.min)}\n\t\t\t\t\t.max=${String(this.max)}\n\t\t\t\t\t.step=${String(this.step)}\n\t\t\t\t\t.value=${String(this.value)}\n\t\t\t\t\t?disabled=${this.disabled}\n\t\t\t\t\taria-label=${this.label || 'Range'}\n\t\t\t\t\taria-valuetext=${String(this.value)}\n\t\t\t\t\tstyle=\"--range-progress: ${this.progress}\"\n\t\t\t\t\t@input=${(e: Event) => {\n\t\t\t\t\t\tthis.value = Number((e.target as HTMLInputElement).value)\n\t\t\t\t\t\tthis.markTouched()\n\t\t\t\t\t\tthis.emitChange({ value: this.value })\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-range': SchmancyRange\n\t}\n}\n"],"mappings":";;;;;AAaO,IAAA,IAAA,cAA4B,EAAkB,CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAgDb,GAAA,KAAA,MACA,GAAA,KAAA,OACC,KAAA,KAAA,QAIlB;CAAA;CAEzB,IAAA,WAAY;EACX,QAAY,KAAK,QAAQ,KAAK,QAAQ,KAAK,MAAM,KAAK,OAAQ,MAAvD;CACR;CAEA,WAAoB,GAAA;EACnB,MAAM,WAAW,CAAA,IACb,EAAQ,IAAI,OAAA,KAAY,EAAQ,IAAI,MAAA,MACvC,KAAK,WAAW,aAAa,OAAO,KAAK,KAAA,CAAA;CAE3C;CAGA,gBAAA;EACC,OAAA,CAAK,KAAK,QAAQ,KAAK,WAAiB,CAAA,IACjC,CAAC,CAAC,KAAK,MAAM,OAAO,KAAK,KAAA,CAAA,CAAA;CACjC;CAEA,SAAA;EACC,OAAO,CAAI;;MAEP,EACD,KAAK,aACC,CAAI;;8EAE+D,KAAK,MAAA;;WAExE,KAAK,MAAA;;;;;;YAOJ,OAAO,KAAK,GAAA,EAAA;YACZ,OAAO,KAAK,GAAA,EAAA;aACX,OAAO,KAAK,IAAA,EAAA;cACX,OAAO,KAAK,KAAA,EAAA;iBACT,KAAK,SAAA;kBACJ,KAAK,SAAS,QAAA;sBACV,OAAO,KAAK,KAAA,EAAA;gCACF,KAAK,SAAA;eACtB,MAAA;GACT,KAAK,QAAQ,OAAQ,EAAE,OAA4B,KAAA,GACnD,KAAK,YAAA,GACL,KAAK,WAAW,EAAE,OAAO,KAAK,MAAA,CAAA;EAAA,EAAA;;;;CAKnC;AAAA;AAAA,EAAA,CAzDC,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,OAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,OAAA,KAAA,CAAA,GAAA,EAAA,CACzB,EAAS,EAAE,MAAM,OAAA,CAAA,CAAA,GAAQ,EAAA,WAAA,QAAA,KAAA,CAAA,GAAA,EAAA,CAGzB,EAAS;CAAE,MAAM;CAAQ,SAAA,CAAS;AAAA,CAAA,CAAA,GAAM,EAAA,WAAA,SAAA,KAAA,CAAA,GAAA,IAAA,EAAA,CAtDzC,EAAc,gBAAA,CAAA,GAAgB,CAAA;AAAA,SAAA,KAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"reduced-motion-D-L12p7G.js","names":[],"sources":["../src/directives/reduced-motion.ts"],"sourcesContent":["import { BehaviorSubject, fromEvent } from 'rxjs'\nimport { map, startWith } from 'rxjs/operators'\n\n/**\n * Shared reactive reduced-motion preference.\n *\n * All physics directives observe this — if the user toggles reduced motion\n * while the page is open, directives respond immediately.\n *\n * @example\n * ```ts\n * import { reducedMotion$ } from './reduced-motion'\n * if (reducedMotion$.value) return // skip animation\n * ```\n */\nconst mediaQuery = typeof window !== 'undefined'\n\t? window.matchMedia('(prefers-reduced-motion: reduce)')\n\t: undefined\n\nexport const reducedMotion$ = new BehaviorSubject<boolean>(mediaQuery?.matches ?? false)\n\n// Reactively listen for changes via RxJS\nif (mediaQuery) {\n\tfromEvent<MediaQueryListEvent>(mediaQuery, 'change').pipe(\n\t\tmap(e => e.matches),\n\t\tstartWith(mediaQuery.matches),\n\t).subscribe(matches => {\n\t\treducedMotion$.next(matches)\n\t})\n}\n"],"mappings":";;AAeA,IAAM,IAA+B,OAAX,SAAW,MAClC,OAAO,WAAW,kCAAA,IAAA,KAClB,GAEU,IAAiB,IAAI,EAAyB,GAAY,WAAA,CAAW,CAAA;AAG9E,KACH,EAA+B,GAAY,QAAA,EAAU,KACpD,GAAI,MAAK,EAAE,OAAA,GACX,EAAU,EAAW,OAAA,CAAA,EACpB,WAAU,MAAA;CACX,EAAe,KAAK,CAAA;AAAA,CAAA;AAAA,SAAA,KAAA"}
1
+ {"version":3,"file":"reduced-motion-D-L12p7G.js","names":[],"sources":["../src/directives/reduced-motion.ts"],"sourcesContent":["import { BehaviorSubject, fromEvent } from 'rxjs'\nimport { map, startWith } from 'rxjs/operators'\n\n/**\n * Shared reactive reduced-motion preference.\n *\n * All physics directives observe this — if the user toggles reduced motion\n * while the page is open, directives respond immediately.\n *\n * @example\n * ```ts\n * import { reducedMotion$ } from './reduced-motion'\n * if (reducedMotion$.value) return // skip animation\n * ```\n */\nconst mediaQuery = typeof window !== 'undefined' ? window.matchMedia('(prefers-reduced-motion: reduce)') : undefined\n\nexport const reducedMotion$ = new BehaviorSubject<boolean>(mediaQuery?.matches ?? false)\n\n// Reactively listen for changes via RxJS\nif (mediaQuery) {\n\tfromEvent<MediaQueryListEvent>(mediaQuery, 'change')\n\t\t.pipe(\n\t\t\tmap(e => e.matches),\n\t\t\tstartWith(mediaQuery.matches),\n\t\t)\n\t\t.subscribe(matches => {\n\t\t\treducedMotion$.next(matches)\n\t\t})\n}\n"],"mappings":";;AAeA,IAAM,IAA+B,OAAX,SAAW,MAAc,OAAO,WAAW,kCAAA,IAAA,KAAsC,GAE9F,IAAiB,IAAI,EAAyB,GAAY,WAAA,CAAW,CAAA;AAG9E,KACH,EAA+B,GAAY,QAAA,EACzC,KACA,GAAI,MAAK,EAAE,OAAA,GACX,EAAU,EAAW,OAAA,CAAA,EAErB,WAAU,MAAA;CACV,EAAe,KAAK,CAAA;AAAA,CAAA;AAAA,SAAA,KAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"reduced-motion-Ds-HjMzn.cjs","names":[],"sources":["../src/directives/reduced-motion.ts"],"sourcesContent":["import { BehaviorSubject, fromEvent } from 'rxjs'\nimport { map, startWith } from 'rxjs/operators'\n\n/**\n * Shared reactive reduced-motion preference.\n *\n * All physics directives observe this — if the user toggles reduced motion\n * while the page is open, directives respond immediately.\n *\n * @example\n * ```ts\n * import { reducedMotion$ } from './reduced-motion'\n * if (reducedMotion$.value) return // skip animation\n * ```\n */\nconst mediaQuery = typeof window !== 'undefined'\n\t? window.matchMedia('(prefers-reduced-motion: reduce)')\n\t: undefined\n\nexport const reducedMotion$ = new BehaviorSubject<boolean>(mediaQuery?.matches ?? false)\n\n// Reactively listen for changes via RxJS\nif (mediaQuery) {\n\tfromEvent<MediaQueryListEvent>(mediaQuery, 'change').pipe(\n\t\tmap(e => e.matches),\n\t\tstartWith(mediaQuery.matches),\n\t).subscribe(matches => {\n\t\treducedMotion$.next(matches)\n\t})\n}\n"],"mappings":"kFAeA,IAAM,EAA+B,OAAX,OAAW,IAClC,OAAO,WAAW,kCAAA,EAAA,IAClB,GAEU,EAAiB,IAAI,EAAA,gBAAyB,GAAY,SAAA,CAAW,CAAA,EAG9E,IACH,EAAA,EAAA,WAA+B,EAAY,QAAA,EAAU,MAAA,EAAA,EAAA,KAChD,GAAK,EAAE,OAAA,GAAO,EAAA,EAAA,WACR,EAAW,OAAA,CAAA,EACpB,UAAU,GAAA,CACX,EAAe,KAAK,CAAA,CAAA,CAAA,EAAA,OAAA,eAAA,QAAA,IAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"reduced-motion-Ds-HjMzn.cjs","names":[],"sources":["../src/directives/reduced-motion.ts"],"sourcesContent":["import { BehaviorSubject, fromEvent } from 'rxjs'\nimport { map, startWith } from 'rxjs/operators'\n\n/**\n * Shared reactive reduced-motion preference.\n *\n * All physics directives observe this — if the user toggles reduced motion\n * while the page is open, directives respond immediately.\n *\n * @example\n * ```ts\n * import { reducedMotion$ } from './reduced-motion'\n * if (reducedMotion$.value) return // skip animation\n * ```\n */\nconst mediaQuery = typeof window !== 'undefined' ? window.matchMedia('(prefers-reduced-motion: reduce)') : undefined\n\nexport const reducedMotion$ = new BehaviorSubject<boolean>(mediaQuery?.matches ?? false)\n\n// Reactively listen for changes via RxJS\nif (mediaQuery) {\n\tfromEvent<MediaQueryListEvent>(mediaQuery, 'change')\n\t\t.pipe(\n\t\t\tmap(e => e.matches),\n\t\t\tstartWith(mediaQuery.matches),\n\t\t)\n\t\t.subscribe(matches => {\n\t\t\treducedMotion$.next(matches)\n\t\t})\n}\n"],"mappings":"kFAeA,IAAM,EAA+B,OAAX,OAAW,IAAc,OAAO,WAAW,kCAAA,EAAA,IAAsC,GAE9F,EAAiB,IAAI,EAAA,gBAAyB,GAAY,SAAA,CAAW,CAAA,EAG9E,IACH,EAAA,EAAA,WAA+B,EAAY,QAAA,EACzC,MAAA,EAAA,EAAA,KACI,GAAK,EAAE,OAAA,GAAO,EAAA,EAAA,WACR,EAAW,OAAA,CAAA,EAErB,UAAU,GAAA,CACV,EAAe,KAAK,CAAA,CAAA,CAAA,EAAA,OAAA,eAAA,QAAA,IAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"rxjs-utils-Csnks202.cjs","names":[],"sources":["../src/rxjs-utils/mutation-observer.ts","../node_modules/ts-is-present/lib/index.js","../src/rxjs-utils/waitForElements.ts"],"sourcesContent":["import { Observable } from 'rxjs'\n\nexport const mutationObserver = (\n\ttarget: HTMLElement,\n\tconfig: MutationObserverInit = {\n\t\tattributes: true,\n\t\tchildList: true,\n\t\tsubtree: true,\n\t},\n): Observable<MutationRecord[]> => {\n\treturn new Observable(observer => {\n\t\tconst mutation = new MutationObserver(mutations => {\n\t\t\tobserver.next(mutations)\n\t\t})\n\t\tmutation.observe(target, config)\n\t\tconst unsubscribe = () => {\n\t\t\tmutation.disconnect()\n\t\t}\n\t\treturn unsubscribe\n\t})\n}\nexport default mutationObserver\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasValueAtKey = exports.hasPresentKey = exports.isFilled = exports.isDefined = exports.isPresent = void 0;\nfunction isPresent(t) {\n return t !== undefined && t !== null;\n}\nexports.isPresent = isPresent;\nfunction isDefined(t) {\n return t !== undefined;\n}\nexports.isDefined = isDefined;\nfunction isFilled(t) {\n return t !== null;\n}\nexports.isFilled = isFilled;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a defined non-null value under the key `k`.\n *\n * @example\n * ```ts\n * const filesWithUrl = files.filter(file => file.url);\n * files[0].url // In this case, TS might still treat this as undefined/null\n *\n * const filesWithUrl = files.filter(hasPresentKey(\"url\"));\n * files[0].url // TS will know that this is present\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasPresentKey(k) {\n return function (a) {\n return a[k] !== undefined && a[k] !== null;\n };\n}\nexports.hasPresentKey = hasPresentKey;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a specific value V under a key `k`.\n *\n * @example\n * ```ts\n * type File = { type: \"image\", imageUrl: string } | { type: \"pdf\", pdfUrl: string };\n * const files: File[] = [];\n *\n * const imageFiles = files.filter(file => file.type === \"image\");\n * files[0].type // In this case, TS will still treat it as `\"image\" | \"pdf\"`\n *\n * const filesWithUrl = files.filter(hasValueKey(\"type\", \"image\" as const));\n * files[0].type // TS will now know that this is \"image\"\n * files[0].imageUrl // TS will know this is present, because already it excluded the other union members.\n *\n * Note: the cast `as const` is necessary, otherwise TS will only know that type is a string.\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasValueAtKey(k, v) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (a) {\n return a[k] === v;\n };\n}\nexports.hasValueAtKey = hasValueAtKey;\n//# sourceMappingURL=index.js.map","import { filter, map, startWith, take, tap, timeout } from 'rxjs'\nimport { isPresent } from 'ts-is-present'\nimport observeOnMutation from './mutation-observer'\n\n/**\n * @returns An observable that emits the elements when they are found\n * @description This function is useful when you want to wait for multiple elements to appear\n * @example waitForElements(['button', 'input']).subscribe(([button, input]) => button.click())\n * @returns\n */\nexport default function waitForElements(\n /**\n * @param selectors The selectors to use to find the elements\n * @type { string[] }\n * @description The order of the elements in the array is the same as the order of the elements in the emitted array\n */\n selectors: string[],\n /**\n * @param timeoutAfter How long to wait for the elements to appear before throwing an error\n * @default 5000\n * @type { number | undefined }\n * @description If you don't want to wait for the elements to appear, pass `undefined` as the second argument\n */\n timeoutAfter = 5000,\n) {\n return observeOnMutation(document.body).pipe(\n startWith(document.body),\n filter(() => selectors.every(s => !!document.querySelector(s))),\n take(1),\n map(() => selectors.map(s => document.querySelector(s)).filter(isPresent)), // why filter again? see https://github.com/Microsoft/TypeScript/issues/16069\n map(elements => {\n if (elements.length === selectors.length) {\n return elements\n } else {\n throw new Error('Not all elements were found')\n }\n }),\n timeoutAfter ? timeout(timeoutAfter) : tap(),\n )\n}\n"],"x_google_ignoreList":[1],"mappings":"8DAEA,IAAa,GACZ,EACA,EAA+B,CAC9B,WAAA,CAAY,EACZ,UAAA,CAAW,EACX,QAAA,CAAS,CAAA,IAGH,IAAI,EAAA,WAAW,GAAA,CACrB,IAAM,EAAW,IAAI,iBAAiB,GAAA,CACrC,EAAS,KAAK,CAAA,CAAA,CAAA,EAMf,OAJA,EAAS,QAAQ,EAAQ,CAAA,MACnB,CACL,EAAS,WAAA,CAAA,CAAA,CAAA,EAAA,EAAA,EAAA,GAAA,CCfZ,OAAO,eAAe,EAAS,IAAc,CAAE,MAAA,CAAO,CAAA,CAAA,EACtD,EAAQ,cAAgB,EAAQ,cAAgB,EAAQ,SAAW,EAAQ,UAAY,EAAQ,UAAA,IAAiB,GAIhH,EAAQ,UAHR,SAAmB,EAAA,CACf,OAAO,GAAA,IACX,EAKA,EAAQ,UAHR,SAAmB,EAAA,CACf,OAAO,IAAP,IAAa,EACjB,EAKA,EAAQ,SAHR,SAAkB,EAAA,CACd,OAAO,IAAM,IACjB,EAuBA,EAAQ,cALR,SAAuB,EAAA,CACnB,OAAO,SAAU,EAAA,CACb,OAAO,EAAE,KAAT,IAAgB,IAAa,EAAE,KAAO,IAC1C,CACJ,EA8BA,EAAQ,cANR,SAAuB,EAAG,EAAA,CAEtB,OAAO,SAAU,EAAA,CACb,OAAO,EAAE,KAAO,CACpB,CACJ,CAAA,CAAA,EAAA,EAAA,OAAA,eAAA,QAAA,IAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"rxjs-utils-4P2v57ke.cjs","names":[],"sources":["../src/rxjs-utils/mutation-observer.ts","../node_modules/ts-is-present/lib/index.js","../src/rxjs-utils/waitForElements.ts"],"sourcesContent":["import { Observable } from 'rxjs'\n\nexport const mutationObserver = (\n\ttarget: HTMLElement,\n\tconfig: MutationObserverInit = {\n\t\tattributes: true,\n\t\tchildList: true,\n\t\tsubtree: true,\n\t},\n): Observable<MutationRecord[]> => {\n\treturn new Observable(observer => {\n\t\tconst mutation = new MutationObserver(mutations => {\n\t\t\tobserver.next(mutations)\n\t\t})\n\t\tmutation.observe(target, config)\n\t\tconst unsubscribe = () => {\n\t\t\tmutation.disconnect()\n\t\t}\n\t\treturn unsubscribe\n\t})\n}\nexport default mutationObserver\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasValueAtKey = exports.hasPresentKey = exports.isFilled = exports.isDefined = exports.isPresent = void 0;\nfunction isPresent(t) {\n return t !== undefined && t !== null;\n}\nexports.isPresent = isPresent;\nfunction isDefined(t) {\n return t !== undefined;\n}\nexports.isDefined = isDefined;\nfunction isFilled(t) {\n return t !== null;\n}\nexports.isFilled = isFilled;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a defined non-null value under the key `k`.\n *\n * @example\n * ```ts\n * const filesWithUrl = files.filter(file => file.url);\n * files[0].url // In this case, TS might still treat this as undefined/null\n *\n * const filesWithUrl = files.filter(hasPresentKey(\"url\"));\n * files[0].url // TS will know that this is present\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasPresentKey(k) {\n return function (a) {\n return a[k] !== undefined && a[k] !== null;\n };\n}\nexports.hasPresentKey = hasPresentKey;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a specific value V under a key `k`.\n *\n * @example\n * ```ts\n * type File = { type: \"image\", imageUrl: string } | { type: \"pdf\", pdfUrl: string };\n * const files: File[] = [];\n *\n * const imageFiles = files.filter(file => file.type === \"image\");\n * files[0].type // In this case, TS will still treat it as `\"image\" | \"pdf\"`\n *\n * const filesWithUrl = files.filter(hasValueKey(\"type\", \"image\" as const));\n * files[0].type // TS will now know that this is \"image\"\n * files[0].imageUrl // TS will know this is present, because already it excluded the other union members.\n *\n * Note: the cast `as const` is necessary, otherwise TS will only know that type is a string.\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasValueAtKey(k, v) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (a) {\n return a[k] === v;\n };\n}\nexports.hasValueAtKey = hasValueAtKey;\n//# sourceMappingURL=index.js.map","import { filter, map, startWith, take, tap, timeout } from 'rxjs'\nimport { isPresent } from 'ts-is-present'\nimport observeOnMutation from './mutation-observer'\n\n/**\n * @returns An observable that emits the elements when they are found\n * @description This function is useful when you want to wait for multiple elements to appear\n * @example waitForElements(['button', 'input']).subscribe(([button, input]) => button.click())\n * @returns\n */\nexport default function waitForElements(\n\t/**\n\t * @param selectors The selectors to use to find the elements\n\t * @type { string[] }\n\t * @description The order of the elements in the array is the same as the order of the elements in the emitted array\n\t */\n\tselectors: string[],\n\t/**\n\t * @param timeoutAfter How long to wait for the elements to appear before throwing an error\n\t * @default 5000\n\t * @type { number | undefined }\n\t * @description If you don't want to wait for the elements to appear, pass `undefined` as the second argument\n\t */\n\ttimeoutAfter = 5000,\n) {\n\treturn observeOnMutation(document.body).pipe(\n\t\tstartWith(document.body),\n\t\tfilter(() => selectors.every(s => !!document.querySelector(s))),\n\t\ttake(1),\n\t\tmap(() => selectors.map(s => document.querySelector(s)).filter(isPresent)), // why filter again? see https://github.com/Microsoft/TypeScript/issues/16069\n\t\tmap(elements => {\n\t\t\tif (elements.length === selectors.length) {\n\t\t\t\treturn elements\n\t\t\t} else {\n\t\t\t\tthrow new Error('Not all elements were found')\n\t\t\t}\n\t\t}),\n\t\ttimeoutAfter ? timeout(timeoutAfter) : tap(),\n\t)\n}\n"],"x_google_ignoreList":[1],"mappings":"8DAEA,IAAa,GACZ,EACA,EAA+B,CAC9B,WAAA,CAAY,EACZ,UAAA,CAAW,EACX,QAAA,CAAS,CAAA,IAGH,IAAI,EAAA,WAAW,GAAA,CACrB,IAAM,EAAW,IAAI,iBAAiB,GAAA,CACrC,EAAS,KAAK,CAAA,CAAA,CAAA,EAMf,OAJA,EAAS,QAAQ,EAAQ,CAAA,MACnB,CACL,EAAS,WAAA,CAAA,CAAA,CAAA,EAAA,EAAA,EAAA,GAAA,CCfZ,OAAO,eAAe,EAAS,IAAc,CAAE,MAAA,CAAO,CAAA,CAAA,EACtD,EAAQ,cAAgB,EAAQ,cAAgB,EAAQ,SAAW,EAAQ,UAAY,EAAQ,UAAA,IAAiB,GAIhH,EAAQ,UAHR,SAAmB,EAAA,CACf,OAAO,GAAA,IACX,EAKA,EAAQ,UAHR,SAAmB,EAAA,CACf,OAAO,IAAP,IAAa,EACjB,EAKA,EAAQ,SAHR,SAAkB,EAAA,CACd,OAAO,IAAM,IACjB,EAuBA,EAAQ,cALR,SAAuB,EAAA,CACnB,OAAO,SAAU,EAAA,CACb,OAAO,EAAE,KAAT,IAAgB,IAAa,EAAE,KAAO,IAC1C,CACJ,EA8BA,EAAQ,cANR,SAAuB,EAAG,EAAA,CAEtB,OAAO,SAAU,EAAA,CACb,OAAO,EAAE,KAAO,CACpB,CACJ,CAAA,CAAA,EAAA,EAAA,OAAA,eAAA,QAAA,IAAA,CAAA,WAAA,CAAA,EAAA,IAAA,UAAA,CAAA,OAAA,CAAA,CAAA,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"rxjs-utils-d-ivVN84.js","names":[],"sources":["../src/rxjs-utils/mutation-observer.ts","../node_modules/ts-is-present/lib/index.js","../src/rxjs-utils/waitForElements.ts"],"sourcesContent":["import { Observable } from 'rxjs'\n\nexport const mutationObserver = (\n\ttarget: HTMLElement,\n\tconfig: MutationObserverInit = {\n\t\tattributes: true,\n\t\tchildList: true,\n\t\tsubtree: true,\n\t},\n): Observable<MutationRecord[]> => {\n\treturn new Observable(observer => {\n\t\tconst mutation = new MutationObserver(mutations => {\n\t\t\tobserver.next(mutations)\n\t\t})\n\t\tmutation.observe(target, config)\n\t\tconst unsubscribe = () => {\n\t\t\tmutation.disconnect()\n\t\t}\n\t\treturn unsubscribe\n\t})\n}\nexport default mutationObserver\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasValueAtKey = exports.hasPresentKey = exports.isFilled = exports.isDefined = exports.isPresent = void 0;\nfunction isPresent(t) {\n return t !== undefined && t !== null;\n}\nexports.isPresent = isPresent;\nfunction isDefined(t) {\n return t !== undefined;\n}\nexports.isDefined = isDefined;\nfunction isFilled(t) {\n return t !== null;\n}\nexports.isFilled = isFilled;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a defined non-null value under the key `k`.\n *\n * @example\n * ```ts\n * const filesWithUrl = files.filter(file => file.url);\n * files[0].url // In this case, TS might still treat this as undefined/null\n *\n * const filesWithUrl = files.filter(hasPresentKey(\"url\"));\n * files[0].url // TS will know that this is present\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasPresentKey(k) {\n return function (a) {\n return a[k] !== undefined && a[k] !== null;\n };\n}\nexports.hasPresentKey = hasPresentKey;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a specific value V under a key `k`.\n *\n * @example\n * ```ts\n * type File = { type: \"image\", imageUrl: string } | { type: \"pdf\", pdfUrl: string };\n * const files: File[] = [];\n *\n * const imageFiles = files.filter(file => file.type === \"image\");\n * files[0].type // In this case, TS will still treat it as `\"image\" | \"pdf\"`\n *\n * const filesWithUrl = files.filter(hasValueKey(\"type\", \"image\" as const));\n * files[0].type // TS will now know that this is \"image\"\n * files[0].imageUrl // TS will know this is present, because already it excluded the other union members.\n *\n * Note: the cast `as const` is necessary, otherwise TS will only know that type is a string.\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasValueAtKey(k, v) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (a) {\n return a[k] === v;\n };\n}\nexports.hasValueAtKey = hasValueAtKey;\n//# sourceMappingURL=index.js.map","import { filter, map, startWith, take, tap, timeout } from 'rxjs'\nimport { isPresent } from 'ts-is-present'\nimport observeOnMutation from './mutation-observer'\n\n/**\n * @returns An observable that emits the elements when they are found\n * @description This function is useful when you want to wait for multiple elements to appear\n * @example waitForElements(['button', 'input']).subscribe(([button, input]) => button.click())\n * @returns\n */\nexport default function waitForElements(\n /**\n * @param selectors The selectors to use to find the elements\n * @type { string[] }\n * @description The order of the elements in the array is the same as the order of the elements in the emitted array\n */\n selectors: string[],\n /**\n * @param timeoutAfter How long to wait for the elements to appear before throwing an error\n * @default 5000\n * @type { number | undefined }\n * @description If you don't want to wait for the elements to appear, pass `undefined` as the second argument\n */\n timeoutAfter = 5000,\n) {\n return observeOnMutation(document.body).pipe(\n startWith(document.body),\n filter(() => selectors.every(s => !!document.querySelector(s))),\n take(1),\n map(() => selectors.map(s => document.querySelector(s)).filter(isPresent)), // why filter again? see https://github.com/Microsoft/TypeScript/issues/16069\n map(elements => {\n if (elements.length === selectors.length) {\n return elements\n } else {\n throw new Error('Not all elements were found')\n }\n }),\n timeoutAfter ? timeout(timeoutAfter) : tap(),\n )\n}\n"],"x_google_ignoreList":[1],"mappings":";;AAEA,IAAa,KACZ,GACA,IAA+B;CAC9B,YAAA,CAAY;CACZ,WAAA,CAAW;CACX,SAAA,CAAS;AAAA,MAGH,IAAI,GAAW,MAAA;CACrB,IAAM,IAAW,IAAI,kBAAiB,MAAA;EACrC,EAAS,KAAK,CAAA;CAAA,CAAA;CAMf,OAJA,EAAS,QAAQ,GAAQ,CAAA,SACnB;EACL,EAAS,WAAA;CAAA;AAAA,CAAA;AAAA,GAAA,MAAA;CCfZ,OAAO,eAAe,GAAS,KAAc,EAAE,OAAA,CAAO,EAAA,CAAA,GACtD,EAAQ,gBAAgB,EAAQ,gBAAgB,EAAQ,WAAW,EAAQ,YAAY,EAAQ,YAAA,KAAiB,GAIhH,EAAQ,YAHR,SAAmB,GAAA;EACf,OAAO,KAAA;CACX,GAKA,EAAQ,YAHR,SAAmB,GAAA;EACf,OAAO,MAAP,KAAa;CACjB,GAKA,EAAQ,WAHR,SAAkB,GAAA;EACd,OAAO,MAAM;CACjB,GAuBA,EAAQ,gBALR,SAAuB,GAAA;EACnB,OAAO,SAAU,GAAA;GACb,OAAO,EAAE,OAAT,KAAgB,KAAa,EAAE,OAAO;EAC1C;CACJ,GA8BA,EAAQ,gBANR,SAAuB,GAAG,GAAA;EAEtB,OAAO,SAAU,GAAA;GACb,OAAO,EAAE,OAAO;EACpB;CACJ;AAAA,CAAA,EAAA;AAAA,SAAA,KAAA"}
1
+ {"version":3,"file":"rxjs-utils-JMFdgQSl.js","names":[],"sources":["../src/rxjs-utils/mutation-observer.ts","../node_modules/ts-is-present/lib/index.js","../src/rxjs-utils/waitForElements.ts"],"sourcesContent":["import { Observable } from 'rxjs'\n\nexport const mutationObserver = (\n\ttarget: HTMLElement,\n\tconfig: MutationObserverInit = {\n\t\tattributes: true,\n\t\tchildList: true,\n\t\tsubtree: true,\n\t},\n): Observable<MutationRecord[]> => {\n\treturn new Observable(observer => {\n\t\tconst mutation = new MutationObserver(mutations => {\n\t\t\tobserver.next(mutations)\n\t\t})\n\t\tmutation.observe(target, config)\n\t\tconst unsubscribe = () => {\n\t\t\tmutation.disconnect()\n\t\t}\n\t\treturn unsubscribe\n\t})\n}\nexport default mutationObserver\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasValueAtKey = exports.hasPresentKey = exports.isFilled = exports.isDefined = exports.isPresent = void 0;\nfunction isPresent(t) {\n return t !== undefined && t !== null;\n}\nexports.isPresent = isPresent;\nfunction isDefined(t) {\n return t !== undefined;\n}\nexports.isDefined = isDefined;\nfunction isFilled(t) {\n return t !== null;\n}\nexports.isFilled = isFilled;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a defined non-null value under the key `k`.\n *\n * @example\n * ```ts\n * const filesWithUrl = files.filter(file => file.url);\n * files[0].url // In this case, TS might still treat this as undefined/null\n *\n * const filesWithUrl = files.filter(hasPresentKey(\"url\"));\n * files[0].url // TS will know that this is present\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasPresentKey(k) {\n return function (a) {\n return a[k] !== undefined && a[k] !== null;\n };\n}\nexports.hasPresentKey = hasPresentKey;\n/**\n * Returns a function that can be used to filter down objects\n * to the ones that have a specific value V under a key `k`.\n *\n * @example\n * ```ts\n * type File = { type: \"image\", imageUrl: string } | { type: \"pdf\", pdfUrl: string };\n * const files: File[] = [];\n *\n * const imageFiles = files.filter(file => file.type === \"image\");\n * files[0].type // In this case, TS will still treat it as `\"image\" | \"pdf\"`\n *\n * const filesWithUrl = files.filter(hasValueKey(\"type\", \"image\" as const));\n * files[0].type // TS will now know that this is \"image\"\n * files[0].imageUrl // TS will know this is present, because already it excluded the other union members.\n *\n * Note: the cast `as const` is necessary, otherwise TS will only know that type is a string.\n * ```\n *\n * See https://github.com/microsoft/TypeScript/issues/16069\n * why is that useful.\n */\nfunction hasValueAtKey(k, v) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (a) {\n return a[k] === v;\n };\n}\nexports.hasValueAtKey = hasValueAtKey;\n//# sourceMappingURL=index.js.map","import { filter, map, startWith, take, tap, timeout } from 'rxjs'\nimport { isPresent } from 'ts-is-present'\nimport observeOnMutation from './mutation-observer'\n\n/**\n * @returns An observable that emits the elements when they are found\n * @description This function is useful when you want to wait for multiple elements to appear\n * @example waitForElements(['button', 'input']).subscribe(([button, input]) => button.click())\n * @returns\n */\nexport default function waitForElements(\n\t/**\n\t * @param selectors The selectors to use to find the elements\n\t * @type { string[] }\n\t * @description The order of the elements in the array is the same as the order of the elements in the emitted array\n\t */\n\tselectors: string[],\n\t/**\n\t * @param timeoutAfter How long to wait for the elements to appear before throwing an error\n\t * @default 5000\n\t * @type { number | undefined }\n\t * @description If you don't want to wait for the elements to appear, pass `undefined` as the second argument\n\t */\n\ttimeoutAfter = 5000,\n) {\n\treturn observeOnMutation(document.body).pipe(\n\t\tstartWith(document.body),\n\t\tfilter(() => selectors.every(s => !!document.querySelector(s))),\n\t\ttake(1),\n\t\tmap(() => selectors.map(s => document.querySelector(s)).filter(isPresent)), // why filter again? see https://github.com/Microsoft/TypeScript/issues/16069\n\t\tmap(elements => {\n\t\t\tif (elements.length === selectors.length) {\n\t\t\t\treturn elements\n\t\t\t} else {\n\t\t\t\tthrow new Error('Not all elements were found')\n\t\t\t}\n\t\t}),\n\t\ttimeoutAfter ? timeout(timeoutAfter) : tap(),\n\t)\n}\n"],"x_google_ignoreList":[1],"mappings":";;AAEA,IAAa,KACZ,GACA,IAA+B;CAC9B,YAAA,CAAY;CACZ,WAAA,CAAW;CACX,SAAA,CAAS;AAAA,MAGH,IAAI,GAAW,MAAA;CACrB,IAAM,IAAW,IAAI,kBAAiB,MAAA;EACrC,EAAS,KAAK,CAAA;CAAA,CAAA;CAMf,OAJA,EAAS,QAAQ,GAAQ,CAAA,SACnB;EACL,EAAS,WAAA;CAAA;AAAA,CAAA;AAAA,GAAA,MAAA;CCfZ,OAAO,eAAe,GAAS,KAAc,EAAE,OAAA,CAAO,EAAA,CAAA,GACtD,EAAQ,gBAAgB,EAAQ,gBAAgB,EAAQ,WAAW,EAAQ,YAAY,EAAQ,YAAA,KAAiB,GAIhH,EAAQ,YAHR,SAAmB,GAAA;EACf,OAAO,KAAA;CACX,GAKA,EAAQ,YAHR,SAAmB,GAAA;EACf,OAAO,MAAP,KAAa;CACjB,GAKA,EAAQ,WAHR,SAAkB,GAAA;EACd,OAAO,MAAM;CACjB,GAuBA,EAAQ,gBALR,SAAuB,GAAA;EACnB,OAAO,SAAU,GAAA;GACb,OAAO,EAAE,OAAT,KAAgB,KAAa,EAAE,OAAO;EAC1C;CACJ,GA8BA,EAAQ,gBANR,SAAuB,GAAG,GAAA;EAEtB,OAAO,SAAU,GAAA;GACb,OAAO,EAAE,OAAO;EACpB;CACJ;AAAA,CAAA,EAAA;AAAA,SAAA,KAAA"}
@@ -1 +1 @@
1
- Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./rxjs-utils-Csnks202.cjs`);exports.mutationObserver=e.t;
1
+ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./rxjs-utils-4P2v57ke.cjs`);exports.mutationObserver=e.t;
@@ -1,2 +1,2 @@
1
- import { t as e } from "./rxjs-utils-d-ivVN84.js";
1
+ import { t as e } from "./rxjs-utils-JMFdgQSl.js";
2
2
  export { e as mutationObserver };