@mhmo91/schmancy 0.10.37 → 0.10.39

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 (558) hide show
  1. package/custom-elements.json +39 -0
  2. package/dist/{SchmancyElement-CDT2q1lA.js → SchmancyElement-BNnyBOwk.js} +9 -7
  3. package/dist/{SchmancyElement-CDT2q1lA.js.map → SchmancyElement-BNnyBOwk.js.map} +1 -1
  4. package/dist/{SchmancyElement-BHfQg3Tj.cjs → SchmancyElement-C41uPa6l.cjs} +2 -2
  5. package/dist/{SchmancyElement-BHfQg3Tj.cjs.map → SchmancyElement-C41uPa6l.cjs.map} +1 -1
  6. package/dist/agent/schmancy.agent.js +2334 -2297
  7. package/dist/agent/schmancy.agent.js.map +1 -1
  8. package/dist/area-2FrTZI_T.cjs +21 -0
  9. package/dist/area-2FrTZI_T.cjs.map +1 -0
  10. package/dist/{area-KtULlxuA.js → area-KVDzhT4s.js} +4 -4
  11. package/dist/area-KVDzhT4s.js.map +1 -0
  12. package/dist/area.cjs +1 -1
  13. package/dist/area.js +2 -2
  14. package/dist/{audio-zIJVTo_V.js → audio-D3gnp15Y.js} +1 -1
  15. package/dist/{audio-zIJVTo_V.js.map → audio-D3gnp15Y.js.map} +1 -1
  16. package/dist/{audio-CUMAv9D_.cjs → audio-EaD0Ggfh.cjs} +1 -1
  17. package/dist/{audio-CUMAv9D_.cjs.map → audio-EaD0Ggfh.cjs.map} +1 -1
  18. package/dist/audio.cjs +1 -1
  19. package/dist/audio.js +2 -2
  20. package/dist/autocomplete-DMmxsvUe.cjs +115 -0
  21. package/dist/autocomplete-DMmxsvUe.cjs.map +1 -0
  22. package/dist/{autocomplete-DIScyo8Q.js → autocomplete-DWiEqlQf.js} +96 -96
  23. package/dist/autocomplete-DWiEqlQf.js.map +1 -0
  24. package/dist/autocomplete.cjs +1 -1
  25. package/dist/autocomplete.js +1 -1
  26. package/dist/avatar.cjs +1 -1
  27. package/dist/avatar.js +3 -3
  28. package/dist/badge.cjs +1 -1
  29. package/dist/badge.js +1 -1
  30. package/dist/{boat-OBZ77exO.cjs → boat-DsFJNfPH.cjs} +1 -1
  31. package/dist/{boat-OBZ77exO.cjs.map → boat-DsFJNfPH.cjs.map} +1 -1
  32. package/dist/{boat-BHPqSqJd.js → boat-fqodYt2n.js} +4 -4
  33. package/dist/{boat-BHPqSqJd.js.map → boat-fqodYt2n.js.map} +1 -1
  34. package/dist/boat.cjs +1 -1
  35. package/dist/boat.js +1 -1
  36. package/dist/breadcrumb.cjs +3 -3
  37. package/dist/breadcrumb.cjs.map +1 -1
  38. package/dist/breadcrumb.js +4 -4
  39. package/dist/breadcrumb.js.map +1 -1
  40. package/dist/{busy-BJNsKSCM.cjs → busy-Cj_PV7oC.cjs} +1 -1
  41. package/dist/{busy-BJNsKSCM.cjs.map → busy-Cj_PV7oC.cjs.map} +1 -1
  42. package/dist/{busy-Dut78y4L.js → busy-enYCTssB.js} +2 -2
  43. package/dist/{busy-Dut78y4L.js.map → busy-enYCTssB.js.map} +1 -1
  44. package/dist/busy.cjs +1 -1
  45. package/dist/busy.js +1 -1
  46. package/dist/button-B9RfBt-n.cjs +63 -0
  47. package/dist/button-B9RfBt-n.cjs.map +1 -0
  48. package/dist/{button-kcpPQavY.js → button-D6LJC-HC.js} +11 -9
  49. package/dist/button-D6LJC-HC.js.map +1 -0
  50. package/dist/button.cjs +7 -6
  51. package/dist/button.cjs.map +1 -1
  52. package/dist/button.js +18 -16
  53. package/dist/button.js.map +1 -1
  54. package/dist/{card-DxSKxCid.js → card-BHTz1GwB.js} +16 -16
  55. package/dist/card-BHTz1GwB.js.map +1 -0
  56. package/dist/{card-BLxPLqdQ.cjs → card-ThG_ZaQE.cjs} +3 -3
  57. package/dist/card-ThG_ZaQE.cjs.map +1 -0
  58. package/dist/card.cjs +1 -1
  59. package/dist/card.js +1 -1
  60. package/dist/{checkbox-BCLkhp5G.cjs → checkbox-C4zeib84.cjs} +2 -2
  61. package/dist/{checkbox-BCLkhp5G.cjs.map → checkbox-C4zeib84.cjs.map} +1 -1
  62. package/dist/{checkbox-B1wiM3Dv.js → checkbox-Ce0DlAdW.js} +6 -6
  63. package/dist/{checkbox-B1wiM3Dv.js.map → checkbox-Ce0DlAdW.js.map} +1 -1
  64. package/dist/checkbox.cjs +1 -1
  65. package/dist/checkbox.js +1 -1
  66. package/dist/{chips-vWmwqQed.js → chips-BoZSpSh_.js} +21 -19
  67. package/dist/chips-BoZSpSh_.js.map +1 -0
  68. package/dist/{chips-C9dS1WKn.cjs → chips-wfJ7YtWv.cjs} +4 -3
  69. package/dist/chips-wfJ7YtWv.cjs.map +1 -0
  70. package/dist/chips.cjs +1 -1
  71. package/dist/chips.js +2 -2
  72. package/dist/connectivity.cjs +1 -1
  73. package/dist/connectivity.js +3 -3
  74. package/dist/content-drawer.cjs +1 -1
  75. package/dist/content-drawer.js +1 -1
  76. package/dist/cursor-glow-Ah7VXSj7.js.map +1 -1
  77. package/dist/cursor-glow-Bulq-38P.cjs.map +1 -1
  78. package/dist/{date-range-BV6HuvLw.cjs → date-range-BHSzlwSL.cjs} +2 -2
  79. package/dist/date-range-BHSzlwSL.cjs.map +1 -0
  80. package/dist/{date-range-D3ge1b4c.js → date-range-DJrdpzev.js} +4 -4
  81. package/dist/date-range-DJrdpzev.js.map +1 -0
  82. package/dist/{date-range-inline-DpYgdLRv.cjs → date-range-inline-D0I6k84h.cjs} +1 -1
  83. package/dist/{date-range-inline-DpYgdLRv.cjs.map → date-range-inline-D0I6k84h.cjs.map} +1 -1
  84. package/dist/{date-range-inline-DuWQaWps.js → date-range-inline-DjRdMZ1z.js} +2 -2
  85. package/dist/{date-range-inline-DuWQaWps.js.map → date-range-inline-DjRdMZ1z.js.map} +1 -1
  86. package/dist/date-range-inline.cjs +1 -1
  87. package/dist/date-range-inline.js +1 -1
  88. package/dist/date-range.cjs +1 -1
  89. package/dist/date-range.js +1 -1
  90. package/dist/delay.cjs +1 -1
  91. package/dist/delay.js +2 -2
  92. package/dist/{details-C-GZaq3j.js → details-CY49XVfp.js} +43 -35
  93. package/dist/details-CY49XVfp.js.map +1 -0
  94. package/dist/details-DQNj2oaU.cjs +164 -0
  95. package/dist/details-DQNj2oaU.cjs.map +1 -0
  96. package/dist/details.cjs +1 -1
  97. package/dist/details.js +1 -1
  98. package/dist/{directives-D_l1E5H6.cjs → directives-Bb0S1DKZ.cjs} +3 -3
  99. package/dist/directives-Bb0S1DKZ.cjs.map +1 -0
  100. package/dist/{directives-DyS51FUh.js → directives-Bfm1lkoy.js} +6 -8
  101. package/dist/directives-Bfm1lkoy.js.map +1 -0
  102. package/dist/directives.cjs +1 -1
  103. package/dist/directives.js +2 -2
  104. package/dist/{divider-nQffE0AD.js → divider-BeyX_C0A.js} +2 -2
  105. package/dist/{divider-nQffE0AD.js.map → divider-BeyX_C0A.js.map} +1 -1
  106. package/dist/{divider-CBnAmHMZ.cjs → divider-Ck2C1sKl.cjs} +1 -1
  107. package/dist/{divider-CBnAmHMZ.cjs.map → divider-Ck2C1sKl.cjs.map} +1 -1
  108. package/dist/divider.cjs +1 -1
  109. package/dist/divider.js +1 -1
  110. package/dist/dropdown.cjs +1 -1
  111. package/dist/dropdown.js +2 -2
  112. package/dist/{expand-DvTb-UPR.js → expand-BYsSEtp6.js} +53 -53
  113. package/dist/expand-BYsSEtp6.js.map +1 -0
  114. package/dist/expand-CUF163mg.cjs +141 -0
  115. package/dist/expand-CUF163mg.cjs.map +1 -0
  116. package/dist/expand.cjs +1 -1
  117. package/dist/expand.js +1 -1
  118. package/dist/fab.cjs +2 -1
  119. package/dist/fab.cjs.map +1 -1
  120. package/dist/fab.js +3 -2
  121. package/dist/fab.js.map +1 -1
  122. package/dist/{float-C-Ko0Le3.js → float-Cgllk_H9.js} +2 -2
  123. package/dist/{float-C-Ko0Le3.js.map → float-Cgllk_H9.js.map} +1 -1
  124. package/dist/{float-C17xgMT1.cjs → float-OvqX0nqG.cjs} +1 -1
  125. package/dist/{float-C17xgMT1.cjs.map → float-OvqX0nqG.cjs.map} +1 -1
  126. package/dist/float.cjs +1 -1
  127. package/dist/float.js +1 -1
  128. package/dist/form-4GKROq2P.cjs +27 -0
  129. package/dist/form-4GKROq2P.cjs.map +1 -0
  130. package/dist/{form-DA0hUu2h.js → form-DxaV_Ose.js} +39 -39
  131. package/dist/form-DxaV_Ose.js.map +1 -0
  132. package/dist/form.cjs +3 -3
  133. package/dist/form.cjs.map +1 -1
  134. package/dist/form.js +34 -34
  135. package/dist/form.js.map +1 -1
  136. package/dist/gravity-6pL6CfIr.cjs.map +1 -1
  137. package/dist/gravity-sVK3zGBF.js.map +1 -1
  138. package/dist/handover/agent-runtime-followups.md +1 -1
  139. package/dist/handover/agent-runtime-v1.md +3 -3
  140. package/dist/{icons-C6UfxmHZ.js → icons-CJ2mXcBi.js} +9 -9
  141. package/dist/icons-CJ2mXcBi.js.map +1 -0
  142. package/dist/icons-sZ-LybA9.cjs +24 -0
  143. package/dist/icons-sZ-LybA9.cjs.map +1 -0
  144. package/dist/icons.cjs +1 -1
  145. package/dist/icons.js +1 -1
  146. package/dist/{iframe-BTjZfYyh.js → iframe-DWvN5nGB.js} +11 -11
  147. package/dist/iframe-DWvN5nGB.js.map +1 -0
  148. package/dist/{iframe-wuYT2xFz.cjs → iframe-DpCv-QH2.cjs} +7 -7
  149. package/dist/iframe-DpCv-QH2.cjs.map +1 -0
  150. package/dist/iframe.cjs +1 -1
  151. package/dist/iframe.js +1 -1
  152. package/dist/index.cjs +1 -1
  153. package/dist/index.js +35 -35
  154. package/dist/{input-B_4g2ulO.js → input-BCCHz6tB.js} +7 -7
  155. package/dist/input-BCCHz6tB.js.map +1 -0
  156. package/dist/{input-BrDiIT60.cjs → input-Z-3N5JMv.cjs} +2 -2
  157. package/dist/input-Z-3N5JMv.cjs.map +1 -0
  158. package/dist/{input-chip-BlWhOruv.js → input-chip-BOrcKH-H.js} +2 -2
  159. package/dist/{input-chip-BlWhOruv.js.map → input-chip-BOrcKH-H.js.map} +1 -1
  160. package/dist/{input-chip-B-XWh4aE.cjs → input-chip-ChAgRCXZ.cjs} +1 -1
  161. package/dist/{input-chip-B-XWh4aE.cjs.map → input-chip-ChAgRCXZ.cjs.map} +1 -1
  162. package/dist/input.cjs +1 -1
  163. package/dist/input.js +1 -1
  164. package/dist/json.cjs +1 -1
  165. package/dist/json.js +3 -3
  166. package/dist/kbd.cjs +1 -1
  167. package/dist/kbd.js +2 -2
  168. package/dist/{layout-Dxit9enO.js → layout-CFiG3lNT.js} +1 -1
  169. package/dist/{layout-Dxit9enO.js.map → layout-CFiG3lNT.js.map} +1 -1
  170. package/dist/{layout-BhyIcEVu.cjs → layout-DZ4dpLh9.cjs} +1 -1
  171. package/dist/{layout-BhyIcEVu.cjs.map → layout-DZ4dpLh9.cjs.map} +1 -1
  172. package/dist/layout.cjs +1 -1
  173. package/dist/layout.js +2 -2
  174. package/dist/lazy-BaAiIUru.js +19 -0
  175. package/dist/lazy-BaAiIUru.js.map +1 -0
  176. package/dist/lazy-C-7a4FAe.cjs +1 -0
  177. package/dist/lazy-C-7a4FAe.cjs.map +1 -0
  178. package/dist/{lightbox-D85XAAuC.js → lightbox-B7Y4Nij_.js} +2 -2
  179. package/dist/lightbox-B7Y4Nij_.js.map +1 -0
  180. package/dist/{lightbox-CVBogswK.cjs → lightbox-Dpwsn8Qr.cjs} +1 -1
  181. package/dist/lightbox-Dpwsn8Qr.cjs.map +1 -0
  182. package/dist/lightbox.cjs +1 -1
  183. package/dist/lightbox.js +1 -1
  184. package/dist/{list-nVjLskgx.cjs → list-BhM-6dAi.cjs} +1 -1
  185. package/dist/{list-nVjLskgx.cjs.map → list-BhM-6dAi.cjs.map} +1 -1
  186. package/dist/{list-DOF_yVn5.js → list-C5WVoIfJ.js} +2 -2
  187. package/dist/{list-DOF_yVn5.js.map → list-C5WVoIfJ.js.map} +1 -1
  188. package/dist/list.cjs +1 -1
  189. package/dist/list.js +1 -1
  190. package/dist/magnetic-DKtc4umC.cjs.map +1 -1
  191. package/dist/magnetic-DaOOv5Dz.js.map +1 -1
  192. package/dist/{menu-QrAK5Uu9.js → menu-Dvi_tQgH.js} +3 -3
  193. package/dist/{menu-QrAK5Uu9.js.map → menu-Dvi_tQgH.js.map} +1 -1
  194. package/dist/{menu-DqmNjLgY.cjs → menu-GZARYp6I.cjs} +1 -1
  195. package/dist/{menu-DqmNjLgY.cjs.map → menu-GZARYp6I.cjs.map} +1 -1
  196. package/dist/menu.cjs +1 -1
  197. package/dist/menu.js +1 -1
  198. package/dist/{mixins-De1zjyhy.js → mixins-DGBI7YPO.js} +11 -11
  199. package/dist/mixins-DGBI7YPO.js.map +1 -0
  200. package/dist/{mixins-DxHpyMHA.cjs → mixins-fIpzhVMd.cjs} +1 -1
  201. package/dist/mixins-fIpzhVMd.cjs.map +1 -0
  202. package/dist/mixins.cjs +1 -1
  203. package/dist/mixins.js +2 -2
  204. package/dist/nav-drawer.cjs +1 -1
  205. package/dist/nav-drawer.js +1 -1
  206. package/dist/navigation-bar.cjs +1 -1
  207. package/dist/navigation-bar.js +1 -1
  208. package/dist/navigation-rail.cjs +3 -3
  209. package/dist/navigation-rail.cjs.map +1 -1
  210. package/dist/navigation-rail.js +11 -10
  211. package/dist/navigation-rail.js.map +1 -1
  212. package/dist/notification-B6yDL91t.cjs +24 -0
  213. package/dist/notification-B6yDL91t.cjs.map +1 -0
  214. package/dist/{notification-BtAK7NK8.js → notification-BB9OBRCr.js} +22 -22
  215. package/dist/notification-BB9OBRCr.js.map +1 -0
  216. package/dist/notification.cjs +1 -1
  217. package/dist/notification.js +1 -1
  218. package/dist/{option-DHwA0miA.js → option-B21ImL0k.js} +2 -2
  219. package/dist/{option-DHwA0miA.js.map → option-B21ImL0k.js.map} +1 -1
  220. package/dist/{option-DnSPa8ro.cjs → option-CJQM5I9q.cjs} +1 -1
  221. package/dist/{option-DnSPa8ro.cjs.map → option-CJQM5I9q.cjs.map} +1 -1
  222. package/dist/option.cjs +1 -1
  223. package/dist/option.js +1 -1
  224. package/dist/{overlay-Del1sBEB.js → overlay-DwJWVyk2.js} +75 -67
  225. package/dist/overlay-DwJWVyk2.js.map +1 -0
  226. package/dist/overlay-N0trD-4u.cjs +58 -0
  227. package/dist/overlay-N0trD-4u.cjs.map +1 -0
  228. package/dist/overlay.cjs +1 -1
  229. package/dist/{overlay.confirm-body-BV9umTAl.cjs → overlay.confirm-body-CtXIi421.cjs} +3 -3
  230. package/dist/overlay.confirm-body-CtXIi421.cjs.map +1 -0
  231. package/dist/{overlay.confirm-body-DSONXUzl.js → overlay.confirm-body-DwzKhXxM.js} +10 -10
  232. package/dist/overlay.confirm-body-DwzKhXxM.js.map +1 -0
  233. package/dist/overlay.js +4 -4
  234. package/dist/{overlay.service-BTp5Oq7f.js → overlay.service-BDLi0p5M.js} +4 -4
  235. package/dist/{overlay.service-BTp5Oq7f.js.map → overlay.service-BDLi0p5M.js.map} +1 -1
  236. package/dist/overlay.service-Dbu5uP9E.cjs +1 -0
  237. package/dist/{overlay.service-XLlrsSdA.cjs.map → overlay.service-Dbu5uP9E.cjs.map} +1 -1
  238. package/dist/{progress-DUbTL9g9.cjs → progress-B-Qg44XY.cjs} +1 -1
  239. package/dist/{progress-DUbTL9g9.cjs.map → progress-B-Qg44XY.cjs.map} +1 -1
  240. package/dist/{progress-DYA83CFU.js → progress-CUSS1sNz.js} +2 -2
  241. package/dist/{progress-DYA83CFU.js.map → progress-CUSS1sNz.js.map} +1 -1
  242. package/dist/progress.cjs +1 -1
  243. package/dist/progress.js +1 -1
  244. package/dist/{radio-group-DxX0iJBo.js → radio-group-AHLvrN8O.js} +7 -7
  245. package/dist/radio-group-AHLvrN8O.js.map +1 -0
  246. package/dist/{radio-group-B-ORNtvR.cjs → radio-group-BEtvCSS1.cjs} +2 -2
  247. package/dist/radio-group-BEtvCSS1.cjs.map +1 -0
  248. package/dist/radio-group.cjs +1 -1
  249. package/dist/radio-group.js +1 -1
  250. package/dist/range.cjs +1 -1
  251. package/dist/range.js +2 -2
  252. package/dist/select-BWpV2iv-.cjs +56 -0
  253. package/dist/select-BWpV2iv-.cjs.map +1 -0
  254. package/dist/{select-C7gkA-ab.js → select-Cawz88lG.js} +46 -46
  255. package/dist/select-Cawz88lG.js.map +1 -0
  256. package/dist/select.cjs +1 -1
  257. package/dist/select.js +1 -1
  258. package/dist/skeleton.cjs +1 -1
  259. package/dist/skeleton.js +2 -2
  260. package/dist/skills/SKILL.md +9 -0
  261. package/dist/skills/overlay.md +14 -7
  262. package/dist/skills/schmancy/SKILL.md +9 -0
  263. package/dist/skills/schmancy/overlay.md +14 -7
  264. package/dist/slider.cjs +1 -1
  265. package/dist/slider.js +2 -2
  266. package/dist/{sound.service-O0232os6.js → sound.service-CK-5zob-.js} +4 -3
  267. package/dist/sound.service-CK-5zob-.js.map +1 -0
  268. package/dist/{sound.service-C7FDY_yD.cjs → sound.service-D2GGaBXc.cjs} +1 -1
  269. package/dist/sound.service-D2GGaBXc.cjs.map +1 -0
  270. package/dist/{splash-screen-jfE47xl0.js → splash-screen-BUEtjHXC.js} +13 -13
  271. package/dist/splash-screen-BUEtjHXC.js.map +1 -0
  272. package/dist/{splash-screen-DIS4odDr.cjs → splash-screen-DqPuipox.cjs} +6 -6
  273. package/dist/splash-screen-DqPuipox.cjs.map +1 -0
  274. package/dist/splash-screen.cjs +1 -1
  275. package/dist/splash-screen.js +1 -1
  276. package/dist/{src-BP3h-9d9.js → src-8VJ7eluk.js} +46 -45
  277. package/dist/src-8VJ7eluk.js.map +1 -0
  278. package/dist/{src-Um_pzb-U.cjs → src-GJA8uSAS.cjs} +7 -6
  279. package/dist/src-GJA8uSAS.cjs.map +1 -0
  280. package/dist/{state-Bj0M9a6T.cjs → state-BxDNox-2.cjs} +1 -1
  281. package/dist/{state-Bj0M9a6T.cjs.map → state-BxDNox-2.cjs.map} +1 -1
  282. package/dist/{state-DscWQpoM.js → state-CnZCDMT0.js} +9 -9
  283. package/dist/{state-DscWQpoM.js.map → state-CnZCDMT0.js.map} +1 -1
  284. package/dist/state.cjs +1 -1
  285. package/dist/state.js +2 -2
  286. package/dist/steps.cjs +1 -1
  287. package/dist/steps.js +2 -2
  288. package/dist/{surface-B4Wn4SOO.js → surface-BMdG3dKQ.js} +2 -2
  289. package/dist/{surface-B4Wn4SOO.js.map → surface-BMdG3dKQ.js.map} +1 -1
  290. package/dist/{surface-DRq6cVW6.cjs → surface-CWwYD_z2.cjs} +1 -1
  291. package/dist/{surface-DRq6cVW6.cjs.map → surface-CWwYD_z2.cjs.map} +1 -1
  292. package/dist/surface.cjs +1 -1
  293. package/dist/surface.js +1 -1
  294. package/dist/switch.cjs +4 -4
  295. package/dist/switch.cjs.map +1 -1
  296. package/dist/switch.js +11 -11
  297. package/dist/switch.js.map +1 -1
  298. package/dist/table.cjs +1 -1
  299. package/dist/table.js +2 -2
  300. package/dist/{tabs-CnQPo-XS.js → tabs-CDQYDc6v.js} +2 -2
  301. package/dist/{tabs-CnQPo-XS.js.map → tabs-CDQYDc6v.js.map} +1 -1
  302. package/dist/{tabs-Ca_fbHPW.cjs → tabs-CbD9E1gd.cjs} +1 -1
  303. package/dist/{tabs-Ca_fbHPW.cjs.map → tabs-CbD9E1gd.cjs.map} +1 -1
  304. package/dist/tabs.cjs +1 -1
  305. package/dist/tabs.js +1 -1
  306. package/dist/teleport.cjs +1 -1
  307. package/dist/teleport.js +1 -1
  308. package/dist/textarea-Brgi-vD2.cjs +43 -0
  309. package/dist/textarea-Brgi-vD2.cjs.map +1 -0
  310. package/dist/{textarea-BvqENhTW.js → textarea-MPyrMi-S.js} +4 -4
  311. package/dist/textarea-MPyrMi-S.js.map +1 -0
  312. package/dist/textarea.cjs +1 -1
  313. package/dist/textarea.js +1 -1
  314. package/dist/{theme-BSwJ2YZo.cjs → theme-BMbXoqi0.cjs} +1 -1
  315. package/dist/{theme-BSwJ2YZo.cjs.map → theme-BMbXoqi0.cjs.map} +1 -1
  316. package/dist/{theme-BV0EzHQ1.js → theme-DZu-xmVp.js} +5 -5
  317. package/dist/{theme-BV0EzHQ1.js.map → theme-DZu-xmVp.js.map} +1 -1
  318. package/dist/{theme-button-C6fpUzPM.cjs → theme-button-B0OLb-43.cjs} +1 -1
  319. package/dist/{theme-button-C6fpUzPM.cjs.map → theme-button-B0OLb-43.cjs.map} +1 -1
  320. package/dist/{theme-button-O_xNCgI7.js → theme-button-D_qGvEYs.js} +2 -2
  321. package/dist/{theme-button-O_xNCgI7.js.map → theme-button-D_qGvEYs.js.map} +1 -1
  322. package/dist/theme-button.cjs +1 -1
  323. package/dist/theme-button.js +1 -1
  324. package/dist/theme.cjs +1 -1
  325. package/dist/theme.js +3 -3
  326. package/dist/{theme.service-DwLhhOmP.js → theme.service-7VkM-hVf.js} +15 -11
  327. package/dist/theme.service-7VkM-hVf.js.map +1 -0
  328. package/dist/theme.service-B15FdjOS.cjs +1 -0
  329. package/dist/theme.service-B15FdjOS.cjs.map +1 -0
  330. package/dist/tree.cjs +4 -4
  331. package/dist/tree.cjs.map +1 -1
  332. package/dist/tree.js +8 -8
  333. package/dist/tree.js.map +1 -1
  334. package/dist/{typography-opFYuUYS.cjs → typography-D4Fo1UGh.cjs} +3 -3
  335. package/dist/{typography-opFYuUYS.cjs.map → typography-D4Fo1UGh.cjs.map} +1 -1
  336. package/dist/{typography-Dtdooaic.js → typography-SZhjb_4R.js} +9 -9
  337. package/dist/{typography-Dtdooaic.js.map → typography-SZhjb_4R.js.map} +1 -1
  338. package/dist/typography.cjs +1 -1
  339. package/dist/typography.js +1 -1
  340. package/dist/visually-hidden.cjs +1 -1
  341. package/dist/visually-hidden.js +2 -2
  342. package/dist/{window-ConcHirJ.js → window-BDVyrBnk.js} +101 -100
  343. package/dist/window-BDVyrBnk.js.map +1 -0
  344. package/dist/window-BbBYjm7R.cjs +59 -0
  345. package/dist/window-BbBYjm7R.cjs.map +1 -0
  346. package/dist/window.cjs +1 -1
  347. package/dist/window.js +1 -1
  348. package/package.json +1 -1
  349. package/skills/schmancy/SKILL.md +9 -0
  350. package/skills/schmancy/overlay.md +14 -7
  351. package/src/area/area.component.ts +1 -1
  352. package/src/area/area.service.test.ts +2 -2
  353. package/src/area/area.service.ts +1 -1
  354. package/src/area/lazy.ts +87 -83
  355. package/src/audio/sound.service.ts +3 -3
  356. package/src/badge/badge.ts +1 -0
  357. package/src/breadcrumb/breadcrumb.ts +2 -2
  358. package/src/button/button.ts +12 -11
  359. package/src/button/icon-button.ts +19 -18
  360. package/src/card/card.ts +16 -16
  361. package/src/content-drawer/drawer.ts +6 -6
  362. package/src/details/details.ts +55 -55
  363. package/src/directives/ai-badge.ts +2 -1
  364. package/src/directives/animate-text.ts +2 -1
  365. package/src/directives/art/art.directive.ts +2 -1
  366. package/src/directives/battery.ts +2 -1
  367. package/src/directives/confirm-click.ts +5 -3
  368. package/src/directives/cursor-glow.ts +2 -1
  369. package/src/directives/cycle-text.ts +2 -1
  370. package/src/directives/depth-of-field.ts +2 -1
  371. package/src/directives/drag.ts +4 -2
  372. package/src/directives/fyi.ts +2 -1
  373. package/src/directives/gravity.ts +2 -1
  374. package/src/directives/hummingbird.ts +2 -1
  375. package/src/directives/intersect.ts +3 -2
  376. package/src/directives/liquid.ts +2 -1
  377. package/src/directives/living-border.ts +2 -1
  378. package/src/directives/long-press.ts +2 -1
  379. package/src/directives/magnetic.ts +2 -1
  380. package/src/directives/missed-punch.ts +2 -1
  381. package/src/directives/nebula.ts +6 -5
  382. package/src/directives/overflow-within.ts +2 -1
  383. package/src/directives/reveal.ts +2 -1
  384. package/src/directives/urgent.ts +2 -1
  385. package/src/directives/working-snake.ts +2 -1
  386. package/src/expand/expand-root.component.ts +27 -27
  387. package/src/expand/expand.component.ts +48 -48
  388. package/src/fab/fab.ts +1 -0
  389. package/src/form/fields/autocomplete/autocomplete.ts +154 -154
  390. package/src/form/fields/checkbox/checkbox.ts +4 -4
  391. package/src/form/fields/chips/chips.ts +2 -2
  392. package/src/form/fields/chips/filter-chip.ts +16 -15
  393. package/src/form/fields/date-range/date-range.ts +2 -2
  394. package/src/form/fields/input/input.ts +12 -12
  395. package/src/form/fields/radio-group/radio-button.ts +2 -2
  396. package/src/form/fields/radio-group/radio-group.ts +3 -3
  397. package/src/form/fields/select/select.ts +56 -56
  398. package/src/form/fields/switch/switch.ts +10 -10
  399. package/src/form/fields/textarea/textarea.ts +2 -2
  400. package/src/form/form-summary.ts +33 -33
  401. package/src/form/form.ts +45 -45
  402. package/src/icons/icon.ts +10 -8
  403. package/src/iframe/iframe.ts +11 -11
  404. package/src/lightbox/flip-directive.ts +2 -1
  405. package/src/lightbox/lightbox.directive.ts +2 -1
  406. package/src/nav-drawer/navbar.ts +3 -3
  407. package/src/navigation-rail/navigation-rail.ts +10 -10
  408. package/src/notification/notification.ts +22 -22
  409. package/src/overlay/overlay.component.ts +106 -83
  410. package/src/overlay/overlay.confirm-body.ts +4 -4
  411. package/src/overlay/overlay.service.ts +3 -3
  412. package/src/overlay/overlay.types.ts +4 -2
  413. package/src/splash-screen/splash-screen.ts +11 -11
  414. package/src/state/index.ts +12 -12
  415. package/src/state/schmancy-context.ts +9 -9
  416. package/src/teleport/teleport.component.ts +2 -2
  417. package/src/theme/theme.service.ts +17 -17
  418. package/src/tree/tree.ts +7 -7
  419. package/src/typography/typography.ts +7 -7
  420. package/src/window/window-manager.ts +20 -20
  421. package/src/window/window.ts +100 -100
  422. package/types/mixins/SchmancyElement.d.ts +3 -2
  423. package/types/mixins/formField.mixin.d.ts +1 -1
  424. package/types/src/area/area.service.d.ts +1 -1
  425. package/types/src/area/lazy.d.ts +0 -6
  426. package/types/src/audio/sound.service.d.ts +1 -2
  427. package/types/src/breadcrumb/breadcrumb.d.ts +1 -1
  428. package/types/src/button/button.d.ts +3 -3
  429. package/types/src/button/icon-button.d.ts +6 -7
  430. package/types/src/card/card.d.ts +5 -5
  431. package/types/src/content-drawer/drawer.d.ts +1 -1
  432. package/types/src/details/details.d.ts +2 -21
  433. package/types/src/directives/ai-badge.d.ts +2 -2
  434. package/types/src/directives/animate-text.d.ts +2 -2
  435. package/types/src/directives/art/art.directive.d.ts +2 -2
  436. package/types/src/directives/battery.d.ts +2 -2
  437. package/types/src/directives/confirm-click.d.ts +2 -2
  438. package/types/src/directives/cursor-glow.d.ts +2 -2
  439. package/types/src/directives/cycle-text.d.ts +2 -2
  440. package/types/src/directives/depth-of-field.d.ts +2 -2
  441. package/types/src/directives/drag.d.ts +4 -4
  442. package/types/src/directives/fyi.d.ts +2 -2
  443. package/types/src/directives/gravity.d.ts +2 -2
  444. package/types/src/directives/hummingbird.d.ts +2 -2
  445. package/types/src/directives/intersect.d.ts +2 -2
  446. package/types/src/directives/liquid.d.ts +2 -2
  447. package/types/src/directives/living-border.d.ts +2 -2
  448. package/types/src/directives/long-press.d.ts +2 -2
  449. package/types/src/directives/magnetic.d.ts +2 -2
  450. package/types/src/directives/missed-punch.d.ts +2 -2
  451. package/types/src/directives/nebula.d.ts +2 -2
  452. package/types/src/directives/overflow-within.d.ts +2 -2
  453. package/types/src/directives/reveal.d.ts +2 -2
  454. package/types/src/directives/urgent.d.ts +2 -2
  455. package/types/src/directives/working-snake.d.ts +2 -2
  456. package/types/src/expand/expand-root.component.d.ts +8 -8
  457. package/types/src/expand/expand.component.d.ts +11 -11
  458. package/types/src/form/fields/autocomplete/autocomplete.d.ts +29 -29
  459. package/types/src/form/fields/checkbox/checkbox.d.ts +1 -1
  460. package/types/src/form/fields/chips/chips.d.ts +1 -1
  461. package/types/src/form/fields/chips/filter-chip.d.ts +1 -2
  462. package/types/src/form/fields/input/input.d.ts +3 -3
  463. package/types/src/form/fields/radio-group/radio-button.d.ts +1 -1
  464. package/types/src/form/fields/radio-group/radio-group.d.ts +1 -1
  465. package/types/src/form/fields/select/select.d.ts +8 -8
  466. package/types/src/form/fields/switch/switch.d.ts +3 -3
  467. package/types/src/form/fields/textarea/textarea.d.ts +1 -1
  468. package/types/src/form/form-summary.d.ts +7 -7
  469. package/types/src/form/form.d.ts +11 -11
  470. package/types/src/icons/icon.d.ts +2 -2
  471. package/types/src/iframe/iframe.d.ts +3 -3
  472. package/types/src/lightbox/flip-directive.d.ts +2 -2
  473. package/types/src/lightbox/lightbox.directive.d.ts +2 -2
  474. package/types/src/nav-drawer/navbar.d.ts +1 -1
  475. package/types/src/navigation-rail/navigation-rail.d.ts +2 -2
  476. package/types/src/notification/notification.d.ts +8 -8
  477. package/types/src/overlay/overlay.component.d.ts +16 -16
  478. package/types/src/overlay/overlay.confirm-body.d.ts +1 -1
  479. package/types/src/overlay/overlay.types.d.ts +4 -2
  480. package/types/src/splash-screen/splash-screen.d.ts +2 -2
  481. package/types/src/state/index.d.ts +1 -1
  482. package/types/src/state/schmancy-context.d.ts +3 -3
  483. package/types/src/teleport/teleport.component.d.ts +1 -1
  484. package/types/src/theme/theme.service.d.ts +1 -4
  485. package/types/src/tree/tree.d.ts +3 -3
  486. package/types/src/typography/typography.d.ts +1 -1
  487. package/types/src/window/window-manager.d.ts +2 -2
  488. package/types/src/window/window.d.ts +20 -20
  489. package/dist/area-KtULlxuA.js.map +0 -1
  490. package/dist/area-fdKhYB6T.cjs +0 -21
  491. package/dist/area-fdKhYB6T.cjs.map +0 -1
  492. package/dist/autocomplete-DEZk6wBD.cjs +0 -115
  493. package/dist/autocomplete-DEZk6wBD.cjs.map +0 -1
  494. package/dist/autocomplete-DIScyo8Q.js.map +0 -1
  495. package/dist/button-DzlHLjWO.cjs +0 -62
  496. package/dist/button-DzlHLjWO.cjs.map +0 -1
  497. package/dist/button-kcpPQavY.js.map +0 -1
  498. package/dist/card-BLxPLqdQ.cjs.map +0 -1
  499. package/dist/card-DxSKxCid.js.map +0 -1
  500. package/dist/chips-C9dS1WKn.cjs.map +0 -1
  501. package/dist/chips-vWmwqQed.js.map +0 -1
  502. package/dist/date-range-BV6HuvLw.cjs.map +0 -1
  503. package/dist/date-range-D3ge1b4c.js.map +0 -1
  504. package/dist/details-C-GZaq3j.js.map +0 -1
  505. package/dist/details-Dp5rLIWk.cjs +0 -164
  506. package/dist/details-Dp5rLIWk.cjs.map +0 -1
  507. package/dist/directives-D_l1E5H6.cjs.map +0 -1
  508. package/dist/directives-DyS51FUh.js.map +0 -1
  509. package/dist/expand-DvTb-UPR.js.map +0 -1
  510. package/dist/expand-mlP_3XWz.cjs +0 -141
  511. package/dist/expand-mlP_3XWz.cjs.map +0 -1
  512. package/dist/form-CwPHcQYB.cjs +0 -27
  513. package/dist/form-CwPHcQYB.cjs.map +0 -1
  514. package/dist/form-DA0hUu2h.js.map +0 -1
  515. package/dist/icons-C6UfxmHZ.js.map +0 -1
  516. package/dist/icons-CW3-oMSb.cjs +0 -24
  517. package/dist/icons-CW3-oMSb.cjs.map +0 -1
  518. package/dist/iframe-BTjZfYyh.js.map +0 -1
  519. package/dist/iframe-wuYT2xFz.cjs.map +0 -1
  520. package/dist/input-B_4g2ulO.js.map +0 -1
  521. package/dist/input-BrDiIT60.cjs.map +0 -1
  522. package/dist/lazy-CayEFyC3.cjs +0 -1
  523. package/dist/lazy-CayEFyC3.cjs.map +0 -1
  524. package/dist/lazy-D-bO2r4m.js +0 -13
  525. package/dist/lazy-D-bO2r4m.js.map +0 -1
  526. package/dist/lightbox-CVBogswK.cjs.map +0 -1
  527. package/dist/lightbox-D85XAAuC.js.map +0 -1
  528. package/dist/mixins-De1zjyhy.js.map +0 -1
  529. package/dist/mixins-DxHpyMHA.cjs.map +0 -1
  530. package/dist/notification-BtAK7NK8.js.map +0 -1
  531. package/dist/notification-DYzbUb5C.cjs +0 -24
  532. package/dist/notification-DYzbUb5C.cjs.map +0 -1
  533. package/dist/overlay-BVkqZmoS.cjs +0 -58
  534. package/dist/overlay-BVkqZmoS.cjs.map +0 -1
  535. package/dist/overlay-Del1sBEB.js.map +0 -1
  536. package/dist/overlay.confirm-body-BV9umTAl.cjs.map +0 -1
  537. package/dist/overlay.confirm-body-DSONXUzl.js.map +0 -1
  538. package/dist/overlay.service-XLlrsSdA.cjs +0 -1
  539. package/dist/radio-group-B-ORNtvR.cjs.map +0 -1
  540. package/dist/radio-group-DxX0iJBo.js.map +0 -1
  541. package/dist/select-B9uj_u-s.cjs +0 -56
  542. package/dist/select-B9uj_u-s.cjs.map +0 -1
  543. package/dist/select-C7gkA-ab.js.map +0 -1
  544. package/dist/sound.service-C7FDY_yD.cjs.map +0 -1
  545. package/dist/sound.service-O0232os6.js.map +0 -1
  546. package/dist/splash-screen-DIS4odDr.cjs.map +0 -1
  547. package/dist/splash-screen-jfE47xl0.js.map +0 -1
  548. package/dist/src-BP3h-9d9.js.map +0 -1
  549. package/dist/src-Um_pzb-U.cjs.map +0 -1
  550. package/dist/textarea-BvqENhTW.js.map +0 -1
  551. package/dist/textarea-qr7oL8oU.cjs +0 -43
  552. package/dist/textarea-qr7oL8oU.cjs.map +0 -1
  553. package/dist/theme.service-DwLhhOmP.js.map +0 -1
  554. package/dist/theme.service-kn9MC025.cjs +0 -1
  555. package/dist/theme.service-kn9MC025.cjs.map +0 -1
  556. package/dist/window-BSAemI9J.cjs +0 -59
  557. package/dist/window-BSAemI9J.cjs.map +0 -1
  558. package/dist/window-ConcHirJ.js.map +0 -1
@@ -73,22 +73,22 @@ export default class SchmancyWindow extends SchmancyElement {
73
73
  /** Whether the body is expanded. */
74
74
  @property({ type: Boolean, reflect: true }) open = false
75
75
 
76
- private _currentAnimation?: Animation
76
+ private currentAnimation?: Animation
77
77
 
78
78
  /** Lazy rendering: body content not in DOM until first expand. */
79
- @state() private _hasOpened = false
79
+ @state() private hasOpened = false
80
80
 
81
81
  // Internal position -- plain fields, updated directly during drag
82
- private _position: Position = { x: 16, y: 16 }
83
- @state() private _currentCorner: SnapCorner = 'bottom-right'
82
+ private position: Position = { x: 16, y: 16 }
83
+ @state() private currentCorner: SnapCorner = 'bottom-right'
84
84
 
85
85
  // Track applied corner to avoid unnecessary style.removeProperty calls during drag
86
- private _appliedCorner: string = ''
86
+ private appliedCorner: string = ''
87
87
 
88
88
  // Refs
89
- private _containerRef = createRef<HTMLElement>()
90
- private _bodyRef = createRef<HTMLElement>()
91
- private _headRef = createRef<HTMLElement>()
89
+ private containerRef = createRef<HTMLElement>()
90
+ private bodyRef = createRef<HTMLElement>()
91
+ private headRef = createRef<HTMLElement>()
92
92
 
93
93
  // ============================================
94
94
  // COMPUTED
@@ -99,7 +99,7 @@ export default class SchmancyWindow extends SchmancyElement {
99
99
  }
100
100
 
101
101
  private get isBottomCorner(): boolean {
102
- return this._currentCorner.startsWith('bottom')
102
+ return this.currentCorner.startsWith('bottom')
103
103
  }
104
104
 
105
105
  private get closedClipPath(): string {
@@ -121,24 +121,24 @@ export default class SchmancyWindow extends SchmancyElement {
121
121
  // POSITION MANAGEMENT
122
122
  // ============================================
123
123
 
124
- private _applyContainerPosition() {
125
- const container = this._containerRef.value
124
+ private applyContainerPosition() {
125
+ const container = this.containerRef.value
126
126
  if (!container) return
127
127
  // Only clear position properties when corner changes (avoids 4 style invalidations per drag frame)
128
- if (this._appliedCorner !== this._currentCorner) {
128
+ if (this.appliedCorner !== this.currentCorner) {
129
129
  container.style.removeProperty('left')
130
130
  container.style.removeProperty('right')
131
131
  container.style.removeProperty('top')
132
132
  container.style.removeProperty('bottom')
133
- this._appliedCorner = this._currentCorner
133
+ this.appliedCorner = this.currentCorner
134
134
  }
135
- const { x, y } = this._position
136
- if (this._currentCorner.includes('right')) {
135
+ const { x, y } = this.position
136
+ if (this.currentCorner.includes('right')) {
137
137
  container.style.right = `${x}px`
138
138
  } else {
139
139
  container.style.left = `${x}px`
140
140
  }
141
- if (this._currentCorner.includes('bottom')) {
141
+ if (this.currentCorner.includes('bottom')) {
142
142
  container.style.bottom = `${y + theme.bottomOffset}px`
143
143
  } else {
144
144
  container.style.top = `${y}px`
@@ -147,63 +147,63 @@ export default class SchmancyWindow extends SchmancyElement {
147
147
 
148
148
  private static readonly VALID_CORNERS = new Set<string>(['top-left', 'top-right', 'bottom-left', 'bottom-right'])
149
149
 
150
- private _loadPosition() {
150
+ private loadPosition() {
151
151
  const saved = windowManager.loadPosition(this.id)
152
152
  if (saved) {
153
- this._position = { x: saved.x, y: saved.y }
153
+ this.position = { x: saved.x, y: saved.y }
154
154
  if (SchmancyWindow.VALID_CORNERS.has(saved.anchor)) {
155
- this._currentCorner = saved.anchor as SnapCorner
155
+ this.currentCorner = saved.anchor as SnapCorner
156
156
  }
157
157
  }
158
158
  }
159
159
 
160
- private _savePosition() {
161
- windowManager.savePosition(this.id, { ...this._position, anchor: this._currentCorner })
160
+ private savePosition() {
161
+ windowManager.savePosition(this.id, { ...this.position, anchor: this.currentCorner })
162
162
  }
163
163
 
164
- private _validateBounds() {
165
- const container = this._containerRef.value
164
+ private validateBounds() {
165
+ const container = this.containerRef.value
166
166
  if (!container) return
167
167
  const rect = container.getBoundingClientRect()
168
168
  if (rect.width === 0) return
169
169
  const vw = window.innerWidth
170
170
  const vh = window.innerHeight
171
- const isRight = this._currentCorner.includes('right')
172
- const isBottom = this._currentCorner.includes('bottom')
173
- const actualLeft = isRight ? vw - this._position.x - rect.width : this._position.x
174
- const actualTop = isBottom ? vh - this._position.y - rect.height : this._position.y
171
+ const isRight = this.currentCorner.includes('right')
172
+ const isBottom = this.currentCorner.includes('bottom')
173
+ const actualLeft = isRight ? vw - this.position.x - rect.width : this.position.x
174
+ const actualTop = isBottom ? vh - this.position.y - rect.height : this.position.y
175
175
  const newLeft = Math.max(0, Math.min(actualLeft, vw - rect.width))
176
176
  const newTop = Math.max(0, Math.min(actualTop, vh - rect.height))
177
- this._position = {
177
+ this.position = {
178
178
  x: isRight ? vw - newLeft - rect.width : newLeft,
179
179
  y: isBottom ? vh - newTop - rect.height : newTop,
180
180
  }
181
- this._applyContainerPosition()
181
+ this.applyContainerPosition()
182
182
  }
183
183
 
184
184
  // ============================================
185
185
  // CORNER SNAPPING
186
186
  // ============================================
187
187
 
188
- private _reorientToNearestCorner(skipAnimation = false): void {
188
+ private reorientToNearestCorner(skipAnimation = false): void {
189
189
  // Free position mode: skip corner snapping
190
190
  if (this.freePosition) {
191
- this._savePosition()
192
- const rect = this._containerRef.value?.getBoundingClientRect()
191
+ this.savePosition()
192
+ const rect = this.containerRef.value?.getBoundingClientRect()
193
193
  if (rect) {
194
194
  windowManager.updateBounds(this.id, { left: rect.left, top: rect.top, width: rect.width, height: rect.height })
195
195
  }
196
196
  return
197
197
  }
198
198
 
199
- const container = this._containerRef.value
199
+ const container = this.containerRef.value
200
200
  if (!container) return
201
201
 
202
202
  // F -- record current screen position before DOM mutation
203
203
  const rect = container.getBoundingClientRect()
204
204
 
205
205
  // L -- calculate nearest corner using head visual center
206
- const currentIsBottom = this._currentCorner.includes('bottom')
206
+ const currentIsBottom = this.currentCorner.includes('bottom')
207
207
  const headCenterX = rect.left + rect.width / 2
208
208
  const headCenterY = currentIsBottom
209
209
  ? rect.bottom - HEAD_HEIGHT / 2
@@ -213,16 +213,16 @@ export default class SchmancyWindow extends SchmancyElement {
213
213
  const newCorner: SnapCorner = `${vert}-${side}` as SnapCorner
214
214
 
215
215
  // Snap corner and reset offset to standard edge gap
216
- this._currentCorner = newCorner
217
- this._position = { x: 16, y: 16 }
218
- this._applyContainerPosition()
216
+ this.currentCorner = newCorner
217
+ this.position = { x: 16, y: 16 }
218
+ this.applyContainerPosition()
219
219
  // Sync clip-path to new corner
220
220
  if (!this.open) {
221
221
  container.style.clipPath = this.closedClipPath
222
222
  }
223
223
 
224
224
  if (skipAnimation || reducedMotion$.value) {
225
- this._savePosition()
225
+ this.savePosition()
226
226
  const snapRect = container.getBoundingClientRect()
227
227
  windowManager.updateBounds(this.id, { left: snapRect.left, top: snapRect.top, width: snapRect.width, height: snapRect.height })
228
228
  return
@@ -256,17 +256,17 @@ export default class SchmancyWindow extends SchmancyElement {
256
256
  takeUntil(this.disconnecting),
257
257
  ).subscribe()
258
258
 
259
- this._savePosition()
259
+ this.savePosition()
260
260
  }
261
261
 
262
262
  // ============================================
263
263
  // DRAG PIPELINE
264
264
  // ============================================
265
265
 
266
- private _drag$(): Observable<never> {
266
+ private drag$(): Observable<never> {
267
267
  return new Observable(() => {
268
- const head = this._headRef.value
269
- const container = this._containerRef.value
268
+ const head = this.headRef.value
269
+ const container = this.containerRef.value
270
270
  if (!head || !container) return
271
271
 
272
272
  let didDrag = false
@@ -286,7 +286,7 @@ export default class SchmancyWindow extends SchmancyElement {
286
286
  .pipe(
287
287
  map(e => {
288
288
  const rect = container.getBoundingClientRect()
289
- const isBottom = this._currentCorner.includes('bottom')
289
+ const isBottom = this.currentCorner.includes('bottom')
290
290
  const wasOpen = this.open
291
291
  didDrag = false
292
292
  return {
@@ -318,13 +318,13 @@ export default class SchmancyWindow extends SchmancyElement {
318
318
  const dy = clientY - startY
319
319
  if (Math.sqrt(dx * dx + dy * dy) > DRAG_THRESHOLD && !didDrag) {
320
320
  didDrag = true
321
- this._applyDragVisuals(true)
321
+ this.applyDragVisuals(true)
322
322
  // Collapse on first confirmed drag move
323
323
  if (wasOpen) {
324
324
  this.open = false
325
325
  container.style.clipPath = this.closedClipPath
326
326
  container.style.overflow = 'hidden'
327
- const body = this._bodyRef.value
327
+ const body = this.bodyRef.value
328
328
  if (body) {
329
329
  body.inert = true
330
330
  body.style.visibility = 'hidden'
@@ -338,17 +338,17 @@ export default class SchmancyWindow extends SchmancyElement {
338
338
  const maxTop = isBottom ? vh - rect.height : vh - HEAD_HEIGHT
339
339
  const top = Math.max(minTop, Math.min(clientY - offsetY, maxTop))
340
340
 
341
- this._position = {
342
- x: this._currentCorner.includes('right') ? vw - left - rect.width : left,
341
+ this.position = {
342
+ x: this.currentCorner.includes('right') ? vw - left - rect.width : left,
343
343
  y: isBottom ? vh - top - rect.height : top,
344
344
  }
345
- this._applyContainerPosition()
345
+ this.applyContainerPosition()
346
346
  }),
347
347
  takeUntil(end$),
348
348
  finalize(() => {
349
349
  if (didDrag) {
350
- this._reorientToNearestCorner()
351
- this._applyDragVisuals(false)
350
+ this.reorientToNearestCorner()
351
+ this.applyDragVisuals(false)
352
352
  didDrag = false
353
353
  } else {
354
354
  didDrag = false
@@ -375,24 +375,24 @@ export default class SchmancyWindow extends SchmancyElement {
375
375
  from(this.updateComplete).pipe(
376
376
  take(1),
377
377
  tap(() => {
378
- this._currentCorner = this.corner
379
- this._loadPosition()
380
- this._applyContainerPosition()
381
- this._initDOMState()
378
+ this.currentCorner = this.corner
379
+ this.loadPosition()
380
+ this.applyContainerPosition()
381
+ this.initDOMState()
382
382
  // Register with window manager
383
- const container = this._containerRef.value
383
+ const container = this.containerRef.value
384
384
  if (container) {
385
385
  const rect = container.getBoundingClientRect()
386
386
  const bounds: WindowBounds = { left: rect.left, top: rect.top, width: rect.width, height: rect.height }
387
- windowManager.register(this.id, bounds, this.freePosition ? 'free' : this._currentCorner)
387
+ windowManager.register(this.id, bounds, this.freePosition ? 'free' : this.currentCorner)
388
388
  }
389
389
  }),
390
390
  switchMap(() => merge(
391
- this._drag$(),
391
+ this.drag$(),
392
392
  windowManager.selectWindow(this.id).pipe(
393
393
  tap(record => {
394
394
  if (!record) return
395
- const container = this._containerRef.value
395
+ const container = this.containerRef.value
396
396
  if (container) container.style.zIndex = String(record.zIndex)
397
397
  }),
398
398
  ),
@@ -405,10 +405,10 @@ export default class SchmancyWindow extends SchmancyElement {
405
405
  merge(
406
406
  fromEvent(window, 'resize').pipe(
407
407
  auditTime(0, animationFrameScheduler),
408
- tap(() => this._validateBounds()),
408
+ tap(() => this.validateBounds()),
409
409
  ),
410
410
  theme.bottomOffset$.pipe(
411
- tap(() => this._applyContainerPosition()),
411
+ tap(() => this.applyContainerPosition()),
412
412
  ),
413
413
  ).pipe(takeUntil(this.disconnecting)).subscribe()
414
414
  }
@@ -418,15 +418,15 @@ export default class SchmancyWindow extends SchmancyElement {
418
418
  windowManager.unregister(this.id)
419
419
  }
420
420
 
421
- private _initDOMState() {
422
- const container = this._containerRef.value
423
- const body = this._bodyRef.value
421
+ private initDOMState() {
422
+ const container = this.containerRef.value
423
+ const body = this.bodyRef.value
424
424
  if (!container) return
425
425
 
426
- this._applyContainerPosition()
426
+ this.applyContainerPosition()
427
427
 
428
428
  if (this.open) {
429
- this._hasOpened = true
429
+ this.hasOpened = true
430
430
  container.style.overflow = ''
431
431
  if (body) {
432
432
  body.inert = false
@@ -446,12 +446,12 @@ export default class SchmancyWindow extends SchmancyElement {
446
446
  // ANIMATION
447
447
  // ============================================
448
448
 
449
- private _animateOpen() {
450
- const container = this._containerRef.value
451
- const body = this._bodyRef.value
449
+ private animateOpen() {
450
+ const container = this.containerRef.value
451
+ const body = this.bodyRef.value
452
452
  if (!container) return
453
453
 
454
- this._hasOpened = true
454
+ this.hasOpened = true
455
455
  this.open = true
456
456
 
457
457
  // Overlap avoidance
@@ -466,13 +466,13 @@ export default class SchmancyWindow extends SchmancyElement {
466
466
  if (overlaps.length > 0) {
467
467
  const resolved = resolveOverlap(projectedBounds, overlaps, { width: window.innerWidth, height: window.innerHeight })
468
468
  if (Math.abs(resolved.left - projectedBounds.left) > 10 || Math.abs(resolved.top - projectedBounds.top) > 10) {
469
- const isRight = this._currentCorner.includes('right')
470
- const isBottom = this._currentCorner.includes('bottom')
471
- this._position = {
469
+ const isRight = this.currentCorner.includes('right')
470
+ const isBottom = this.currentCorner.includes('bottom')
471
+ this.position = {
472
472
  x: isRight ? window.innerWidth - resolved.left - resolved.width : resolved.left,
473
473
  y: isBottom ? window.innerHeight - resolved.top - resolved.height : resolved.top,
474
474
  }
475
- this._applyContainerPosition()
475
+ this.applyContainerPosition()
476
476
  }
477
477
  }
478
478
 
@@ -488,7 +488,7 @@ export default class SchmancyWindow extends SchmancyElement {
488
488
  return
489
489
  }
490
490
 
491
- this._currentAnimation?.cancel()
491
+ this.currentAnimation?.cancel()
492
492
  container.style.overflow = 'hidden'
493
493
  container.style.willChange = 'opacity'
494
494
  const openKeyframes: Keyframe[] = [
@@ -500,7 +500,7 @@ export default class SchmancyWindow extends SchmancyElement {
500
500
  easing: SPRING_SNAPPY.easingFallback,
501
501
  fill: 'forwards',
502
502
  })
503
- this._currentAnimation = anim
503
+ this.currentAnimation = anim
504
504
 
505
505
  from(anim.finished).pipe(
506
506
  take(1),
@@ -518,21 +518,21 @@ export default class SchmancyWindow extends SchmancyElement {
518
518
  this.dispatchScopedEvent('window-toggle', { state: 'expanded' })
519
519
  }
520
520
 
521
- private _animateClose() {
522
- const container = this._containerRef.value
521
+ private animateClose() {
522
+ const container = this.containerRef.value
523
523
  if (!container) return
524
524
 
525
525
  if (reducedMotion$.value) {
526
526
  container.style.clipPath = this.closedClipPath
527
527
  container.style.overflow = 'hidden'
528
528
  this.open = false
529
- const body = this._bodyRef.value
529
+ const body = this.bodyRef.value
530
530
  if (body) { body.inert = true; body.style.visibility = 'hidden' }
531
531
  this.dispatchScopedEvent('window-toggle', { state: 'collapsed' })
532
532
  return
533
533
  }
534
534
 
535
- this._currentAnimation?.cancel()
535
+ this.currentAnimation?.cancel()
536
536
  container.style.overflow = 'hidden'
537
537
  container.style.willChange = 'opacity'
538
538
  const closeKeyframes: Keyframe[] = [
@@ -544,14 +544,14 @@ export default class SchmancyWindow extends SchmancyElement {
544
544
  easing: 'cubic-bezier(0.4, 0, 0.8, 0.15)',
545
545
  fill: 'forwards',
546
546
  })
547
- this._currentAnimation = anim
547
+ this.currentAnimation = anim
548
548
 
549
549
  from(anim.finished).pipe(
550
550
  take(1),
551
551
  tap(() => {
552
552
  this.open = false
553
553
  container.style.willChange = ''
554
- const body = this._bodyRef.value
554
+ const body = this.bodyRef.value
555
555
  if (body) { body.inert = true; body.style.visibility = 'hidden' }
556
556
  }),
557
557
  catchError(() => EMPTY),
@@ -566,9 +566,9 @@ export default class SchmancyWindow extends SchmancyElement {
566
566
  // ============================================
567
567
 
568
568
  /** Apply drag visuals directly on DOM refs — avoids full Lit re-render for cursor + opacity */
569
- private _applyDragVisuals(dragging: boolean) {
570
- const head = this._headRef.value
571
- const container = this._containerRef.value
569
+ private applyDragVisuals(dragging: boolean) {
570
+ const head = this.headRef.value
571
+ const container = this.containerRef.value
572
572
  if (head) {
573
573
  head.classList.toggle('cursor-grabbing', dragging)
574
574
  head.classList.toggle('cursor-move', !dragging)
@@ -578,9 +578,9 @@ export default class SchmancyWindow extends SchmancyElement {
578
578
  }
579
579
  }
580
580
 
581
- private _handleFocus = () => windowManager.focus(this.id)
581
+ private handleFocus = () => windowManager.focus(this.id)
582
582
 
583
- private _handleHeadKeydown = (e: KeyboardEvent) => {
583
+ private handleHeadKeydown = (e: KeyboardEvent) => {
584
584
  if (e.key === 'Enter' || e.key === ' ') {
585
585
  e.preventDefault()
586
586
  this.toggle()
@@ -591,9 +591,9 @@ export default class SchmancyWindow extends SchmancyElement {
591
591
  const step = e.shiftKey ? 20 : 5
592
592
  const dx = e.key === 'ArrowRight' ? step : e.key === 'ArrowLeft' ? -step : 0
593
593
  const dy = e.key === 'ArrowDown' ? step : e.key === 'ArrowUp' ? -step : 0
594
- this._position = { x: this._position.x + dx, y: this._position.y + dy }
595
- this._applyContainerPosition()
596
- this._savePosition()
594
+ this.position = { x: this.position.x + dx, y: this.position.y + dy }
595
+ this.applyContainerPosition()
596
+ this.savePosition()
597
597
  }
598
598
  }
599
599
 
@@ -602,18 +602,18 @@ export default class SchmancyWindow extends SchmancyElement {
602
602
  // ============================================
603
603
 
604
604
  toggle() {
605
- if (this.open) this._animateClose()
606
- else this._animateOpen()
605
+ if (this.open) this.animateClose()
606
+ else this.animateOpen()
607
607
  }
608
608
 
609
609
  expand() {
610
610
  if (this.open) return
611
- this._animateOpen()
611
+ this.animateOpen()
612
612
  }
613
613
 
614
614
  close() {
615
615
  if (!this.open) return
616
- this._animateClose()
616
+ this.animateClose()
617
617
  }
618
618
 
619
619
  // ============================================
@@ -621,7 +621,7 @@ export default class SchmancyWindow extends SchmancyElement {
621
621
  // ============================================
622
622
 
623
623
  protected render(): unknown {
624
- const isBottom = this._currentCorner.startsWith('bottom')
624
+ const isBottom = this.currentCorner.startsWith('bottom')
625
625
 
626
626
  const containerClasses = classMap({
627
627
  fixed: true,
@@ -656,23 +656,23 @@ export default class SchmancyWindow extends SchmancyElement {
656
656
 
657
657
  return html`
658
658
  <schmancy-surface
659
- ${ref(this._containerRef)}
659
+ ${ref(this.containerRef)}
660
660
  type="glass"
661
661
  .elevation=${this.elevation}
662
662
  class=${containerClasses}
663
663
  style=${containerStyles}
664
664
  aria-expanded=${this.open}
665
- @pointerdown=${this._handleFocus}
665
+ @pointerdown=${this.handleFocus}
666
666
  >
667
667
  <!-- Details section (visually above summary for bottom corners) -->
668
668
  <section
669
- ${ref(this._bodyRef)}
669
+ ${ref(this.bodyRef)}
670
670
  class="flex-1 min-h-0 overflow-hidden flex flex-col"
671
671
  style=${bodyStyles}
672
672
  role="region"
673
673
  aria-label="Expandable content"
674
674
  >
675
- ${this._hasOpened ? html`<slot name="details"></slot>` : nothing}
675
+ ${this.hasOpened ? html`<slot name="details"></slot>` : nothing}
676
676
  </section>
677
677
 
678
678
  <!-- Summary section -- always interactive, always visible -->
@@ -681,14 +681,14 @@ export default class SchmancyWindow extends SchmancyElement {
681
681
  style=${styleMap({ 'pointer-events': 'auto', height: `${HEAD_HEIGHT}px` })}
682
682
  >
683
683
  <div
684
- ${ref(this._headRef)}
684
+ ${ref(this.headRef)}
685
685
  ${cursorGlow({ radius: 200, intensity: 0.10 })}
686
686
  class=${headClasses}
687
687
  role="button"
688
688
  tabindex="0"
689
689
  title="Drag to move, click to expand"
690
690
  aria-label="${this.open ? 'Collapse window' : 'Expand window'}"
691
- @keydown=${this._handleHeadKeydown}
691
+ @keydown=${this.handleHeadKeydown}
692
692
  >
693
693
  <div class="flex-1 min-w-0">
694
694
  <slot></slot>
@@ -1,10 +1,11 @@
1
1
  import { LitElement, type CSSResultGroup, type CSSResultOrNative } from 'lit';
2
+ import { type SignalWatcherApi } from '@lit-labs/signals';
2
3
  import { type IBaseMixin } from './baseElement';
3
4
  import type { Constructor } from './constructor';
4
5
  type StaticFinalizeStyles = {
5
6
  finalizeStyles(styles?: CSSResultGroup): CSSResultOrNative[];
6
7
  };
7
- declare const SchmancyElementBase: CustomElementConstructor & Constructor<LitElement> & Constructor<IBaseMixin> & StaticFinalizeStyles;
8
+ declare const SchmancyElementBase: CustomElementConstructor & Constructor<LitElement> & Constructor<IBaseMixin> & Constructor<SignalWatcherApi> & StaticFinalizeStyles;
8
9
  /**
9
10
  * Base class for Schmancy components. A concrete named class — not a mixin
10
11
  * factory — so DevTools shows `SchmancyElement` in the prototype chain and
@@ -37,7 +38,7 @@ declare const SchmancyElementBase: CustomElementConstructor & Constructor<LitEle
37
38
  * (`NO_SIGNAL_WATCHER_WRAP`) blocks it as belt-and-suspenders.
38
39
  */
39
40
  export declare class SchmancyElement extends SchmancyElementBase {
40
- private _abortController;
41
+ private abortController;
41
42
  /** AbortSignal that fires when the element disconnects. */
42
43
  readonly disconnectedSignal: AbortSignal;
43
44
  constructor();
@@ -115,7 +115,7 @@ export interface IFormFieldMixin extends Element {
115
115
  * Subclasses should not override this — extend the truth table by changing
116
116
  * `validateOn` instead.
117
117
  */
118
- _shouldShowError(): boolean;
118
+ shouldShowError(): boolean;
119
119
  toFormEntries(): Array<[string, FormDataEntryValue]>;
120
120
  resetForm(): void;
121
121
  emitChange(detail: any): void;
@@ -80,7 +80,7 @@ declare class AreaService implements AreaSubscription {
80
80
  /**
81
81
  * Update browser history state (called by area components)
82
82
  */
83
- _updateBrowserHistory(areaName: string, route: ActiveRoute, historyStrategy?: string, clearQueryParams?: string[] | boolean | null, customPath?: string): void;
83
+ updateBrowserHistory(areaName: string, route: ActiveRoute, historyStrategy?: string, clearQueryParams?: string[] | boolean | null, customPath?: string): void;
84
84
  /**
85
85
  * Create a clean URL from area states
86
86
  */
@@ -11,12 +11,6 @@ export interface LazyComponent<T extends CustomElementConstructor = CustomElemen
11
11
  default: T;
12
12
  }>;
13
13
  preload(): Promise<void>;
14
- _promise?: Promise<{
15
- default: T;
16
- }>;
17
- _module?: {
18
- default: T;
19
- };
20
14
  }
21
15
  /**
22
16
  * Create a lazy-loaded component that will be imported on demand
@@ -37,14 +37,13 @@ import type { Feeling, FeelingSound, SoundTheme } from '../types/mood-audio.type
37
37
  * - Persists settings to session storage
38
38
  */
39
39
  declare class SoundService {
40
+ #private;
40
41
  private static instance;
41
42
  /** Audio context for Web Audio API */
42
43
  private audioContext;
43
44
  readonly theme$: import("rxjs").Observable<SoundTheme>;
44
45
  readonly volume$: import("rxjs").Observable<number>;
45
46
  readonly muted$: import("rxjs").Observable<boolean>;
46
- /** BehaviorSubject for current theme name (for debugging/display) */
47
- private readonly _themeName$;
48
47
  readonly themeName$: import("rxjs").Observable<string>;
49
48
  get theme(): SoundTheme | null;
50
49
  get volume(): number;
@@ -13,7 +13,7 @@ export declare class SchmancyBreadcrumb extends SchmancyElement {
13
13
  separator: string;
14
14
  connectedCallback(): void;
15
15
  render(): import("lit-html").TemplateResult<1>;
16
- private _insertSeparators;
16
+ private insertSeparators;
17
17
  }
18
18
  /**
19
19
  * Individual breadcrumb item. Renders as a link when `href` is provided,
@@ -15,6 +15,7 @@ export type ButtonColor = 'primary' | 'secondary' | 'success' | 'error' | 'warni
15
15
  * @csspart base - The underlying native `<button>` (or `<a>` when `href` is set).
16
16
  */
17
17
  export declare class SchmancyButton extends SchmancyElement {
18
+ #private;
18
19
  static styles: import("lit").CSSResult[];
19
20
  protected static shadowRootOptions: {
20
21
  mode: string;
@@ -32,7 +33,7 @@ export declare class SchmancyButton extends SchmancyElement {
32
33
  * while a submit is in flight. Stays focusable; disabled buttons drop from
33
34
  * the tab order and are unreachable to AT (WCAG 2.2 AA).
34
35
  */
35
- private _formBusyObserver?;
36
+ private formBusyObserver?;
36
37
  constructor();
37
38
  /** Associated form, when placed inside a <form>. */
38
39
  get form(): HTMLFormElement | null;
@@ -40,7 +41,6 @@ export declare class SchmancyButton extends SchmancyElement {
40
41
  connectedCallback(): void;
41
42
  disconnectedCallback(): void;
42
43
  private nativeElement;
43
- private _ariaLabel;
44
44
  /**
45
45
  * The variant of the button.
46
46
  * @attr
@@ -106,7 +106,7 @@ export declare class SchmancyButton extends SchmancyElement {
106
106
  protected get imgClasses(): string[];
107
107
  firstUpdated(): void;
108
108
  click(): void;
109
- private _preventDefault;
109
+ private preventDefault;
110
110
  render(): import("lit-html").TemplateResult<1>;
111
111
  }
112
112
  declare global {