@mhmo91/schmancy 0.5.11 → 0.5.12

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 (317) hide show
  1. package/dist/{animated-text-DhWaYtKW.cjs → animated-text-B5QaGxL8.cjs} +2 -2
  2. package/dist/{animated-text-DhWaYtKW.cjs.map → animated-text-B5QaGxL8.cjs.map} +1 -1
  3. package/dist/{animated-text-Dty0fSbq.js → animated-text-BsyQD4N6.js} +3 -3
  4. package/dist/{animated-text-Dty0fSbq.js.map → animated-text-BsyQD4N6.js.map} +1 -1
  5. package/dist/animated-text.cjs +1 -1
  6. package/dist/animated-text.js +1 -1
  7. package/dist/area.cjs +1 -1
  8. package/dist/{area.component-LQXgflI2.js → area.component-B580xCvP.js} +3 -3
  9. package/dist/{area.component-LQXgflI2.js.map → area.component-B580xCvP.js.map} +1 -1
  10. package/dist/{area.component-D7wlGsfA.cjs → area.component-Y2lLafHN.cjs} +2 -2
  11. package/dist/{area.component-D7wlGsfA.cjs.map → area.component-Y2lLafHN.cjs.map} +1 -1
  12. package/dist/area.js +1 -1
  13. package/dist/{autocomplete-BFvzCShB.js → autocomplete-BOlaOLHB.js} +3 -3
  14. package/dist/{autocomplete-BFvzCShB.js.map → autocomplete-BOlaOLHB.js.map} +1 -1
  15. package/dist/{autocomplete-BcddCLwr.cjs → autocomplete-D3ZKMdEM.cjs} +2 -2
  16. package/dist/{autocomplete-BcddCLwr.cjs.map → autocomplete-D3ZKMdEM.cjs.map} +1 -1
  17. package/dist/autocomplete.cjs +1 -1
  18. package/dist/autocomplete.js +1 -1
  19. package/dist/{avatar-BrNa1pz6.js → avatar-C7ndhoPp.js} +49 -49
  20. package/dist/{avatar-BrNa1pz6.js.map → avatar-C7ndhoPp.js.map} +1 -1
  21. package/dist/{avatar-Lcb94SrU.cjs → avatar-CcLigUca.cjs} +2 -2
  22. package/dist/{avatar-Lcb94SrU.cjs.map → avatar-CcLigUca.cjs.map} +1 -1
  23. package/dist/badge.cjs +1 -1
  24. package/dist/badge.js +1 -1
  25. package/dist/{boat-OKaCjCVb.js → boat-2PWSAJll.js} +2 -2
  26. package/dist/{boat-OKaCjCVb.js.map → boat-2PWSAJll.js.map} +1 -1
  27. package/dist/{boat-SUt73FzK.cjs → boat-P1BU2cNy.cjs} +2 -2
  28. package/dist/{boat-SUt73FzK.cjs.map → boat-P1BU2cNy.cjs.map} +1 -1
  29. package/dist/boat.cjs +1 -1
  30. package/dist/boat.js +1 -1
  31. package/dist/busy.cjs +1 -1
  32. package/dist/busy.js +1 -1
  33. package/dist/button.cjs +1 -1
  34. package/dist/button.js +1 -1
  35. package/dist/card.cjs +1 -1
  36. package/dist/card.js +1 -1
  37. package/dist/{checkbox-BQ9zyi0G.cjs → checkbox-CDolsxpr.cjs} +2 -2
  38. package/dist/{checkbox-BQ9zyi0G.cjs.map → checkbox-CDolsxpr.cjs.map} +1 -1
  39. package/dist/{checkbox-DYgxPkRd.js → checkbox-D-aomCFE.js} +2 -2
  40. package/dist/{checkbox-DYgxPkRd.js.map → checkbox-D-aomCFE.js.map} +1 -1
  41. package/dist/checkbox.cjs +1 -1
  42. package/dist/checkbox.js +1 -1
  43. package/dist/chips.cjs +1 -1
  44. package/dist/chips.js +1 -1
  45. package/dist/code-highlight.cjs +1 -1
  46. package/dist/code-highlight.js +1 -1
  47. package/dist/{code-preview-BguhYQ-9.cjs → code-preview-17LDNYAj.cjs} +39 -40
  48. package/dist/{code-preview-BguhYQ-9.cjs.map → code-preview-17LDNYAj.cjs.map} +1 -1
  49. package/dist/{code-preview-BGYyQE-A.js → code-preview-BRteyh_a.js} +29 -30
  50. package/dist/{code-preview-BGYyQE-A.js.map → code-preview-BRteyh_a.js.map} +1 -1
  51. package/dist/components.cjs +1 -1
  52. package/dist/components.js +1 -1
  53. package/dist/content-drawer.cjs +1 -1
  54. package/dist/content-drawer.js +1 -1
  55. package/dist/{date-range-BHL6NVpp.cjs → date-range-B0tRQX6V.cjs} +2 -2
  56. package/dist/{date-range-BHL6NVpp.cjs.map → date-range-B0tRQX6V.cjs.map} +1 -1
  57. package/dist/{date-range-IAVmBRUY.js → date-range-_jkZME8Q.js} +3 -3
  58. package/dist/{date-range-IAVmBRUY.js.map → date-range-_jkZME8Q.js.map} +1 -1
  59. package/dist/{date-range-inline-tVo6MAVX.js → date-range-inline-BjEHA-mx.js} +3 -3
  60. package/dist/{date-range-inline-tVo6MAVX.js.map → date-range-inline-BjEHA-mx.js.map} +1 -1
  61. package/dist/{date-range-inline-lDogjrro.cjs → date-range-inline-CPjC3TLs.cjs} +2 -2
  62. package/dist/{date-range-inline-lDogjrro.cjs.map → date-range-inline-CPjC3TLs.cjs.map} +1 -1
  63. package/dist/date-range-inline.cjs +1 -1
  64. package/dist/date-range-inline.js +1 -1
  65. package/dist/date-range.cjs +1 -1
  66. package/dist/date-range.js +1 -1
  67. package/dist/{delay-Dqd6hPRo.cjs → delay-AcnUnqh7.cjs} +2 -2
  68. package/dist/{delay-Dqd6hPRo.cjs.map → delay-AcnUnqh7.cjs.map} +1 -1
  69. package/dist/{delay-D1UQizi7.js → delay-OWD0d-2e.js} +2 -2
  70. package/dist/{delay-D1UQizi7.js.map → delay-OWD0d-2e.js.map} +1 -1
  71. package/dist/delay.cjs +1 -1
  72. package/dist/delay.js +1 -1
  73. package/dist/details-BacTUeim.js +95 -0
  74. package/dist/details-BacTUeim.js.map +1 -0
  75. package/dist/details-BvRczwu8.cjs +69 -0
  76. package/dist/details-BvRczwu8.cjs.map +1 -0
  77. package/dist/details.cjs +1 -1
  78. package/dist/details.js +1 -1
  79. package/dist/{dialog-content-CoO1gbnP.js → dialog-content-DChjUKDm.js} +3 -3
  80. package/dist/{dialog-content-CoO1gbnP.js.map → dialog-content-DChjUKDm.js.map} +1 -1
  81. package/dist/{dialog-content-Ch1E0_XY.cjs → dialog-content-DDCW4nzj.cjs} +2 -2
  82. package/dist/{dialog-content-Ch1E0_XY.cjs.map → dialog-content-DDCW4nzj.cjs.map} +1 -1
  83. package/dist/dialog.cjs +1 -1
  84. package/dist/dialog.js +1 -1
  85. package/dist/{divider-DeIUf2pW.cjs → divider-CWRTgIQ1.cjs} +2 -2
  86. package/dist/{divider-DeIUf2pW.cjs.map → divider-CWRTgIQ1.cjs.map} +1 -1
  87. package/dist/{divider-qaTugaNg.js → divider-pVlwlgKf.js} +3 -3
  88. package/dist/{divider-qaTugaNg.js.map → divider-pVlwlgKf.js.map} +1 -1
  89. package/dist/divider.cjs +1 -1
  90. package/dist/divider.js +1 -1
  91. package/dist/{dropdown-content-Ddxpm5T4.js → dropdown-content-DYeZ6KJk.js} +3 -3
  92. package/dist/{dropdown-content-Ddxpm5T4.js.map → dropdown-content-DYeZ6KJk.js.map} +1 -1
  93. package/dist/{dropdown-content-BdGJaEb1.cjs → dropdown-content-DbElZHAU.cjs} +2 -2
  94. package/dist/{dropdown-content-BdGJaEb1.cjs.map → dropdown-content-DbElZHAU.cjs.map} +1 -1
  95. package/dist/dropdown.cjs +1 -1
  96. package/dist/dropdown.js +1 -1
  97. package/dist/{email-recipients-DmVTfoZx.js → email-recipients-02HYpea4.js} +5 -5
  98. package/dist/{email-recipients-DmVTfoZx.js.map → email-recipients-02HYpea4.js.map} +1 -1
  99. package/dist/{email-recipients-CWV3bcBZ.cjs → email-recipients-DaFmzOfp.cjs} +2 -2
  100. package/dist/{email-recipients-CWV3bcBZ.cjs.map → email-recipients-DaFmzOfp.cjs.map} +1 -1
  101. package/dist/extra.cjs +1 -1
  102. package/dist/extra.js +1 -1
  103. package/dist/{flex-CVGc2ncP.js → flex-CCqq8WLW.js} +2 -2
  104. package/dist/{flex-CVGc2ncP.js.map → flex-CCqq8WLW.js.map} +1 -1
  105. package/dist/{flex-D7Lk1FvV.cjs → flex-fSrnbN_9.cjs} +2 -2
  106. package/dist/{flex-D7Lk1FvV.cjs.map → flex-fSrnbN_9.cjs.map} +1 -1
  107. package/dist/{form-CQ9kXk8y.js → form-DthkgvVB.js} +2 -2
  108. package/dist/{form-CQ9kXk8y.js.map → form-DthkgvVB.js.map} +1 -1
  109. package/dist/{form-CIW_BgEw.cjs → form-dm1vg00L.cjs} +2 -2
  110. package/dist/{form-CIW_BgEw.cjs.map → form-dm1vg00L.cjs.map} +1 -1
  111. package/dist/form.cjs +1 -1
  112. package/dist/form.js +1 -1
  113. package/dist/{formField.mixin-CxOpZDW8.js → formField.mixin-BcSM8S0O.js} +2 -2
  114. package/dist/{formField.mixin-CxOpZDW8.js.map → formField.mixin-BcSM8S0O.js.map} +1 -1
  115. package/dist/{formField.mixin-BHyiuJ5K.cjs → formField.mixin-m6ohIgoI.cjs} +2 -2
  116. package/dist/{formField.mixin-BHyiuJ5K.cjs.map → formField.mixin-m6ohIgoI.cjs.map} +1 -1
  117. package/dist/{icon-7xUK_cdP.cjs → icon-A1Zx9yv9.cjs} +2 -2
  118. package/dist/{icon-7xUK_cdP.cjs.map → icon-A1Zx9yv9.cjs.map} +1 -1
  119. package/dist/{icon-button-BGp-CT3V.js → icon-button-Co6YjB0K.js} +3 -3
  120. package/dist/{icon-button-BGp-CT3V.js.map → icon-button-Co6YjB0K.js.map} +1 -1
  121. package/dist/{icon-button-BoKo-vxE.cjs → icon-button-CuupgLEV.cjs} +2 -2
  122. package/dist/{icon-button-BoKo-vxE.cjs.map → icon-button-CuupgLEV.cjs.map} +1 -1
  123. package/dist/{icon-DIfnwdEU.js → icon-ds6nBY4K.js} +2 -2
  124. package/dist/{icon-DIfnwdEU.js.map → icon-ds6nBY4K.js.map} +1 -1
  125. package/dist/icons.cjs +1 -1
  126. package/dist/icons.js +1 -1
  127. package/dist/index.cjs +1 -1
  128. package/dist/index.js +48 -48
  129. package/dist/{input-BTHdBKs2.cjs → input-C6nkFZ0J.cjs} +2 -2
  130. package/dist/{input-BTHdBKs2.cjs.map → input-C6nkFZ0J.cjs.map} +1 -1
  131. package/dist/{input-nDx_PH0i.js → input-CelKeexC.js} +3 -3
  132. package/dist/{input-nDx_PH0i.js.map → input-CelKeexC.js.map} +1 -1
  133. package/dist/input.cjs +1 -1
  134. package/dist/input.js +1 -1
  135. package/dist/layout.cjs +1 -1
  136. package/dist/layout.js +1 -1
  137. package/dist/{list-BToakhNz.js → list-C86nJOsl.js} +2 -2
  138. package/dist/{list-BToakhNz.js.map → list-C86nJOsl.js.map} +1 -1
  139. package/dist/{list-Cmj0mY-X.cjs → list-IHwpVck4.cjs} +2 -2
  140. package/dist/{list-Cmj0mY-X.cjs.map → list-IHwpVck4.cjs.map} +1 -1
  141. package/dist/list.cjs +1 -1
  142. package/dist/list.js +1 -1
  143. package/dist/{litElement.mixin-CEPZ0lJP.js → litElement.mixin-GWkzUR9Y.js} +2 -2
  144. package/dist/{litElement.mixin-CEPZ0lJP.js.map → litElement.mixin-GWkzUR9Y.js.map} +1 -1
  145. package/dist/{litElement.mixin-B2K_bdpW.cjs → litElement.mixin-yCbfNohf.cjs} +2 -2
  146. package/dist/{litElement.mixin-B2K_bdpW.cjs.map → litElement.mixin-yCbfNohf.cjs.map} +1 -1
  147. package/dist/mailbox.cjs +1 -1
  148. package/dist/mailbox.js +1 -1
  149. package/dist/{map-B_AGndzc.cjs → map-DN51DFdu.cjs} +2 -2
  150. package/dist/{map-B_AGndzc.cjs.map → map-DN51DFdu.cjs.map} +1 -1
  151. package/dist/{map-DuilOl8g.js → map-DQ5ce9nz.js} +2 -2
  152. package/dist/{map-DuilOl8g.js.map → map-DQ5ce9nz.js.map} +1 -1
  153. package/dist/map.cjs +1 -1
  154. package/dist/map.js +1 -1
  155. package/dist/{media-BYpO4hxM.cjs → media-d3VnD6_v.cjs} +2 -2
  156. package/dist/{media-BYpO4hxM.cjs.map → media-d3VnD6_v.cjs.map} +1 -1
  157. package/dist/{media-Flyi23Fn.js → media-mcCarDCh.js} +2 -2
  158. package/dist/{media-Flyi23Fn.js.map → media-mcCarDCh.js.map} +1 -1
  159. package/dist/{menu-qoixd8dd.js → menu-BiWjzRcQ.js} +3 -3
  160. package/dist/{menu-qoixd8dd.js.map → menu-BiWjzRcQ.js.map} +1 -1
  161. package/dist/{menu-DJM8tj5e.cjs → menu-C7jGvQWz.cjs} +2 -2
  162. package/dist/{menu-DJM8tj5e.cjs.map → menu-C7jGvQWz.cjs.map} +1 -1
  163. package/dist/menu.cjs +1 -1
  164. package/dist/menu.js +1 -1
  165. package/dist/nav-drawer.cjs +1 -1
  166. package/dist/nav-drawer.js +1 -1
  167. package/dist/{navigation-rail-item-B83ZIkBr.js → navigation-rail-item-2wuRm2wl.js} +2 -2
  168. package/dist/{navigation-rail-item-B83ZIkBr.js.map → navigation-rail-item-2wuRm2wl.js.map} +1 -1
  169. package/dist/{navigation-rail-item-hYAXrNQM.cjs → navigation-rail-item-k966YTHO.cjs} +2 -2
  170. package/dist/{navigation-rail-item-hYAXrNQM.cjs.map → navigation-rail-item-k966YTHO.cjs.map} +1 -1
  171. package/dist/navigation-rail.cjs +1 -1
  172. package/dist/navigation-rail.js +1 -1
  173. package/dist/{notification-service-C5ApldUR.cjs → notification-service-D3XQZkOg.cjs} +2 -2
  174. package/dist/{notification-service-C5ApldUR.cjs.map → notification-service-D3XQZkOg.cjs.map} +1 -1
  175. package/dist/{notification-service-DX4fJZ9W.js → notification-service-DkAfMw-v.js} +4 -4
  176. package/dist/{notification-service-DX4fJZ9W.js.map → notification-service-DkAfMw-v.js.map} +1 -1
  177. package/dist/notification.cjs +1 -1
  178. package/dist/notification.js +2 -2
  179. package/dist/{notify-CZXq5oqO.cjs → notify-BBva4qc1.cjs} +2 -2
  180. package/dist/{notify-CZXq5oqO.cjs.map → notify-BBva4qc1.cjs.map} +1 -1
  181. package/dist/{notify-BZR-r5pn.js → notify-DSEvb7Zy.js} +2 -2
  182. package/dist/{notify-BZR-r5pn.js.map → notify-DSEvb7Zy.js.map} +1 -1
  183. package/dist/{option-MTri6AjG.js → option-4VBpoxh8.js} +2 -2
  184. package/dist/{option-MTri6AjG.js.map → option-4VBpoxh8.js.map} +1 -1
  185. package/dist/{option-CLHsQQRu.cjs → option-UnJeq8w5.cjs} +2 -2
  186. package/dist/{option-CLHsQQRu.cjs.map → option-UnJeq8w5.cjs.map} +1 -1
  187. package/dist/option.cjs +1 -1
  188. package/dist/option.js +1 -1
  189. package/dist/{payment-card-form-BplCPLQi.cjs → payment-card-form-BNDh76A6.cjs} +2 -2
  190. package/dist/{payment-card-form-BplCPLQi.cjs.map → payment-card-form-BNDh76A6.cjs.map} +1 -1
  191. package/dist/{payment-card-form-BvHRTm6O.js → payment-card-form-yHhvCSzp.js} +3 -3
  192. package/dist/{payment-card-form-BvHRTm6O.js.map → payment-card-form-yHhvCSzp.js.map} +1 -1
  193. package/dist/{progress-BEhplYKZ.js → progress--zBKW6lh.js} +2 -2
  194. package/dist/{progress-BEhplYKZ.js.map → progress--zBKW6lh.js.map} +1 -1
  195. package/dist/{progress-C-2JM-2b.cjs → progress-CHiVbsav.cjs} +2 -2
  196. package/dist/{progress-C-2JM-2b.cjs.map → progress-CHiVbsav.cjs.map} +1 -1
  197. package/dist/progress.cjs +1 -1
  198. package/dist/progress.js +1 -1
  199. package/dist/{radio-button-DTTyHAW3.cjs → radio-button-DUx3hqS8.cjs} +2 -2
  200. package/dist/{radio-button-DTTyHAW3.cjs.map → radio-button-DUx3hqS8.cjs.map} +1 -1
  201. package/dist/{radio-button-1rUV1bEw.js → radio-button-DctI2QMg.js} +3 -3
  202. package/dist/{radio-button-1rUV1bEw.js.map → radio-button-DctI2QMg.js.map} +1 -1
  203. package/dist/radio-group.cjs +1 -1
  204. package/dist/radio-group.js +1 -1
  205. package/dist/{schmancy-steps-container-CjVzZKkk.js → schmancy-steps-container-C0Cbrg07.js} +2 -2
  206. package/dist/{schmancy-steps-container-CjVzZKkk.js.map → schmancy-steps-container-C0Cbrg07.js.map} +1 -1
  207. package/dist/{schmancy-steps-container-D9hAAg2V.cjs → schmancy-steps-container-DG_JYVmr.cjs} +2 -2
  208. package/dist/{schmancy-steps-container-D9hAAg2V.cjs.map → schmancy-steps-container-DG_JYVmr.cjs.map} +1 -1
  209. package/dist/{select-DcvpJkwX.js → select-D7Na7bJk.js} +41 -48
  210. package/dist/select-D7Na7bJk.js.map +1 -0
  211. package/dist/select-DFpxKCjD.cjs +57 -0
  212. package/dist/select-DFpxKCjD.cjs.map +1 -0
  213. package/dist/select.cjs +1 -1
  214. package/dist/select.js +1 -1
  215. package/dist/{sheet-DH0GSs0F.js → sheet-C22lei2O.js} +3 -3
  216. package/dist/{sheet-DH0GSs0F.js.map → sheet-C22lei2O.js.map} +1 -1
  217. package/dist/{sheet-WxZAbHZ5.cjs → sheet-ChDXaoVN.cjs} +2 -2
  218. package/dist/{sheet-WxZAbHZ5.cjs.map → sheet-ChDXaoVN.cjs.map} +1 -1
  219. package/dist/sheet.cjs +1 -1
  220. package/dist/sheet.js +1 -1
  221. package/dist/{slider-CG-N2RQo.js → slider-C6Li5MHC.js} +3 -3
  222. package/dist/{slider-CG-N2RQo.js.map → slider-C6Li5MHC.js.map} +1 -1
  223. package/dist/{slider-CY7W7Psq.cjs → slider-xELOc6Ws.cjs} +2 -2
  224. package/dist/{slider-CY7W7Psq.cjs.map → slider-xELOc6Ws.cjs.map} +1 -1
  225. package/dist/slider.cjs +1 -1
  226. package/dist/slider.js +1 -1
  227. package/dist/{spinner-CZaVYJ0a.cjs → spinner-C-wQ6wUU.cjs} +2 -2
  228. package/dist/{spinner-CZaVYJ0a.cjs.map → spinner-C-wQ6wUU.cjs.map} +1 -1
  229. package/dist/{spinner-D8Dc17fq.js → spinner-CFSIVLrg.js} +2 -2
  230. package/dist/{spinner-D8Dc17fq.js.map → spinner-CFSIVLrg.js.map} +1 -1
  231. package/dist/steps.cjs +1 -1
  232. package/dist/steps.js +1 -1
  233. package/dist/{suggestion-chip-p0k9PAya.js → suggestion-chip-B_nFmhAl.js} +3 -3
  234. package/dist/{suggestion-chip-p0k9PAya.js.map → suggestion-chip-B_nFmhAl.js.map} +1 -1
  235. package/dist/{suggestion-chip-BeGEK7BS.cjs → suggestion-chip-C94Hdcm4.cjs} +2 -2
  236. package/dist/{suggestion-chip-BeGEK7BS.cjs.map → suggestion-chip-C94Hdcm4.cjs.map} +1 -1
  237. package/dist/{surface-CvQMtIw-.cjs → surface-Ce2U640-.cjs} +2 -2
  238. package/dist/{surface-CvQMtIw-.cjs.map → surface-Ce2U640-.cjs.map} +1 -1
  239. package/dist/{surface-Cmmdx0F2.js → surface-DI8vxQvl.js} +2 -2
  240. package/dist/{surface-Cmmdx0F2.js.map → surface-DI8vxQvl.js.map} +1 -1
  241. package/dist/surface.cjs +1 -1
  242. package/dist/surface.js +1 -1
  243. package/dist/{table-BJVlDuQa.cjs → table-2nMRHsXv.cjs} +2 -2
  244. package/dist/{table-BJVlDuQa.cjs.map → table-2nMRHsXv.cjs.map} +1 -1
  245. package/dist/{table-CSDX6lDq.js → table-DgOm1D_k.js} +2 -2
  246. package/dist/{table-CSDX6lDq.js.map → table-DgOm1D_k.js.map} +1 -1
  247. package/dist/table.cjs +1 -1
  248. package/dist/table.js +1 -1
  249. package/dist/{tabs-compatibility-lRm3kfw7.cjs → tabs-compatibility-DCVwU0tQ.cjs} +2 -2
  250. package/dist/{tabs-compatibility-lRm3kfw7.cjs.map → tabs-compatibility-DCVwU0tQ.cjs.map} +1 -1
  251. package/dist/{tabs-compatibility-CpSB50Sr.js → tabs-compatibility-NEZy_F3K.js} +2 -2
  252. package/dist/{tabs-compatibility-CpSB50Sr.js.map → tabs-compatibility-NEZy_F3K.js.map} +1 -1
  253. package/dist/tabs.cjs +1 -1
  254. package/dist/tabs.js +1 -1
  255. package/dist/tailwind.mixin-BMDZASqc.js +43 -0
  256. package/dist/{tailwind.mixin-R2xLfpws.js.map → tailwind.mixin-BMDZASqc.js.map} +1 -1
  257. package/dist/tailwind.mixin-nOWQtiUE.cjs +2 -0
  258. package/dist/{tailwind.mixin-BvVlz7hG.cjs.map → tailwind.mixin-nOWQtiUE.cjs.map} +1 -1
  259. package/dist/teleport.cjs +1 -1
  260. package/dist/teleport.js +1 -1
  261. package/dist/{textarea-D5YjtfC7.js → textarea-DV9V1KEi.js} +2 -2
  262. package/dist/{textarea-D5YjtfC7.js.map → textarea-DV9V1KEi.js.map} +1 -1
  263. package/dist/{textarea-BE1uxnbN.cjs → textarea-DuUpfMu8.cjs} +2 -2
  264. package/dist/{textarea-BE1uxnbN.cjs.map → textarea-DuUpfMu8.cjs.map} +1 -1
  265. package/dist/textarea.cjs +1 -1
  266. package/dist/textarea.js +1 -1
  267. package/dist/{theme-button-DXJTRh4E.cjs → theme-button-A33a4Fmq.cjs} +2 -2
  268. package/dist/{theme-button-DXJTRh4E.cjs.map → theme-button-A33a4Fmq.cjs.map} +1 -1
  269. package/dist/{theme-button-CeLy95-B.js → theme-button-DnFLVVqg.js} +2 -2
  270. package/dist/{theme-button-CeLy95-B.js.map → theme-button-DnFLVVqg.js.map} +1 -1
  271. package/dist/theme-button.cjs +1 -1
  272. package/dist/theme-button.js +1 -1
  273. package/dist/theme.cjs +1 -1
  274. package/dist/{theme.component-zoufYNW7.cjs → theme.component-BHPk05S5.cjs} +2 -2
  275. package/dist/{theme.component-zoufYNW7.cjs.map → theme.component-BHPk05S5.cjs.map} +1 -1
  276. package/dist/{theme.component-C03A-Sve.js → theme.component-BrNpK0al.js} +2 -2
  277. package/dist/{theme.component-C03A-Sve.js.map → theme.component-BrNpK0al.js.map} +1 -1
  278. package/dist/theme.js +1 -1
  279. package/dist/{timezone-34kNWMce.cjs → timezone-C_3kyRa4.cjs} +2 -2
  280. package/dist/{timezone-34kNWMce.cjs.map → timezone-C_3kyRa4.cjs.map} +1 -1
  281. package/dist/{timezone-yu_c4i_H.js → timezone-IY32mohl.js} +3 -3
  282. package/dist/{timezone-yu_c4i_H.js.map → timezone-IY32mohl.js.map} +1 -1
  283. package/dist/{tooltip-37GQ15zd.js → tooltip-BDdltqjQ.js} +2 -2
  284. package/dist/{tooltip-37GQ15zd.js.map → tooltip-BDdltqjQ.js.map} +1 -1
  285. package/dist/{tooltip-DZK4j3n0.cjs → tooltip-hSj5Uvoc.cjs} +2 -2
  286. package/dist/{tooltip-DZK4j3n0.cjs.map → tooltip-hSj5Uvoc.cjs.map} +1 -1
  287. package/dist/tooltip.cjs +1 -1
  288. package/dist/tooltip.js +1 -1
  289. package/dist/{tree-D5fhY5eA.cjs → tree-DUAUNYYD.cjs} +2 -2
  290. package/dist/{tree-D5fhY5eA.cjs.map → tree-DUAUNYYD.cjs.map} +1 -1
  291. package/dist/{tree-CtMw5ja5.js → tree-DuSL6oYC.js} +2 -2
  292. package/dist/{tree-CtMw5ja5.js.map → tree-DuSL6oYC.js.map} +1 -1
  293. package/dist/tree.cjs +1 -1
  294. package/dist/tree.js +1 -1
  295. package/dist/{typewriter-DSTaSuRG.cjs → typewriter-BcKV5Epx.cjs} +2 -2
  296. package/dist/{typewriter-DSTaSuRG.cjs.map → typewriter-BcKV5Epx.cjs.map} +1 -1
  297. package/dist/{typewriter-DwS8NOZl.js → typewriter-DvruhGd6.js} +4 -4
  298. package/dist/{typewriter-DwS8NOZl.js.map → typewriter-DvruhGd6.js.map} +1 -1
  299. package/dist/typewriter.cjs +1 -1
  300. package/dist/typewriter.js +1 -1
  301. package/dist/{typography-DoswBHCt.cjs → typography-BobW25ix.cjs} +2 -2
  302. package/dist/{typography-DoswBHCt.cjs.map → typography-BobW25ix.cjs.map} +1 -1
  303. package/dist/{typography-CpKnNiTm.js → typography-CdVGbw4n.js} +2 -2
  304. package/dist/{typography-CpKnNiTm.js.map → typography-CdVGbw4n.js.map} +1 -1
  305. package/dist/typography.cjs +1 -1
  306. package/dist/typography.js +1 -1
  307. package/package.json +1 -1
  308. package/types/src/select/select.d.ts +0 -1
  309. package/dist/details-CL2VJWOL.cjs +0 -62
  310. package/dist/details-CL2VJWOL.cjs.map +0 -1
  311. package/dist/details-DPVTmuIs.js +0 -88
  312. package/dist/details-DPVTmuIs.js.map +0 -1
  313. package/dist/select-DcvpJkwX.js.map +0 -1
  314. package/dist/select-DzhUQc3r.cjs +0 -57
  315. package/dist/select-DzhUQc3r.cjs.map +0 -1
  316. package/dist/tailwind.mixin-BvVlz7hG.cjs +0 -2
  317. package/dist/tailwind.mixin-R2xLfpws.js +0 -43
@@ -1,20 +1,20 @@
1
- import { autoUpdate as _, computePosition as $, offset as w, flip as V, shift as O } from "@floating-ui/dom";
2
- import { BehaviorSubject as y, Subject as S, fromEvent as c, takeUntil as p, combineLatest as x } from "rxjs";
3
- import { classMap as D } from "lit/directives/class-map.js";
1
+ import { autoUpdate as _, computePosition as $, offset as V, flip as w, shift as O } from "@floating-ui/dom";
2
+ import { BehaviorSubject as v, Subject as x, fromEvent as c, takeUntil as p, combineLatest as S } from "rxjs";
3
+ import { classMap as k } from "lit/directives/class-map.js";
4
4
  import "lit/directives/style-map.js";
5
- import { property as r, state as h, query as m, queryAssignedElements as k, customElement as R } from "lit/decorators.js";
6
- import "./tailwind.mixin-R2xLfpws.js";
7
- import { $ as A } from "./litElement.mixin-CEPZ0lJP.js";
8
- import { c as E } from "./ripple-Cy-nvO8W.js";
5
+ import { property as r, state as h, query as y, queryAssignedElements as D, customElement as R } from "lit/decorators.js";
6
+ import "./tailwind.mixin-BMDZASqc.js";
7
+ import { $ as A } from "./litElement.mixin-GWkzUR9Y.js";
8
+ import { c as I } from "./ripple-Cy-nvO8W.js";
9
9
  import "lit/directives/guard.js";
10
- import { S as b } from "./theme.interface-C5Kj6WjD.js";
11
- import { css as I, html as f } from "lit";
12
- import { tap as v } from "rxjs/operators";
13
- var M = Object.defineProperty, P = Object.getOwnPropertyDescriptor, a = (t, e, i, s) => {
10
+ import { S as m } from "./theme.interface-C5Kj6WjD.js";
11
+ import { css as E, html as b } from "lit";
12
+ import { tap as u, withLatestFrom as M } from "rxjs/operators";
13
+ var C = Object.defineProperty, P = Object.getOwnPropertyDescriptor, a = (t, e, i, s) => {
14
14
  for (var n, l = s > 1 ? void 0 : s ? P(e, i) : e, d = t.length - 1; d >= 0; d--) (n = t[d]) && (l = (s ? n(e, i, l) : n(l)) || l);
15
- return s && l && M(e, i, l), l;
15
+ return s && l && C(e, i, l), l;
16
16
  };
17
- let o = class extends A(I`
17
+ let o = class extends A(E`
18
18
  :host {
19
19
  display: block;
20
20
  position: relative;
@@ -26,7 +26,7 @@ let o = class extends A(I`
26
26
  }
27
27
  `) {
28
28
  constructor() {
29
- super(), this.required = !1, this.disabled = !1, this.placeholder = "", this.multi = !1, this.label = "", this.hint = "", this.validateOn = "touched", this.size = "md", this.isOpen = !1, this.valueLabel = "", this.isValid = !0, this.validationMessage = "", this.defaultValue = "", this._options$ = new y([]), this._selectedValue$ = new y(""), this._selectedValues$ = new y([]), this._optionSelect$ = new S(), this._userInteracted = !1, this._touched = !1, this._dirty = !1, this._submitted = !1, this._focusedOptionId = "", this.formSubmitHandler = () => {
29
+ super(), this.required = !1, this.disabled = !1, this.placeholder = "", this.multi = !1, this.label = "", this.hint = "", this.validateOn = "touched", this.size = "md", this.isOpen = !1, this.valueLabel = "", this.isValid = !0, this.validationMessage = "", this.defaultValue = "", this._options$ = new v([]), this._selectedValue$ = new v(""), this._selectedValues$ = new v([]), this._optionSelect$ = new x(), this._userInteracted = !1, this._touched = !1, this._dirty = !1, this._submitted = !1, this._focusedOptionId = "", this.formSubmitHandler = () => {
30
30
  this._submitted = !0, this.checkValidity();
31
31
  }, this.formResetHandler = () => {
32
32
  this.reset();
@@ -60,10 +60,6 @@ let o = class extends A(I`
60
60
  case "Tab":
61
61
  this.closeDropdown();
62
62
  }
63
- }, this._handleOptionPointerDown = (t) => {
64
- t.preventDefault();
65
- const e = t.target;
66
- e && e.value && this._optionSelect$.next(e);
67
63
  };
68
64
  try {
69
65
  this.internals = this.attachInternals();
@@ -114,15 +110,15 @@ let o = class extends A(I`
114
110
  }
115
111
  syncSelection() {
116
112
  if (this.multi) {
117
- const t = Array.isArray(this.value) ? this.value : this.value ? this.value.split(",") : [];
118
- this.options?.forEach((e) => e.selected = t.includes(e.value)), this.valueLabel = t.length > 0 && this.options?.filter((e) => t.includes(e.value)).map((e) => e.label).join(", ") || this.placeholder;
113
+ const t = this._selectedValues$.value;
114
+ this.options?.forEach((e) => e.selected = t.includes(e.value)), this.valueLabel = t.length > 0 && this.options?.filter((e) => t.includes(e.value)).map((e) => e.label || e.textContent || "").join(", ") || this.placeholder;
119
115
  } else {
120
- const t = String(this.value);
116
+ const t = this._selectedValue$.value;
121
117
  this.options?.forEach((i) => {
122
118
  i.selected = i.value === t;
123
119
  });
124
120
  const e = this.options?.find((i) => i.value === t);
125
- this.valueLabel = e?.label || this.placeholder;
121
+ this.valueLabel = e ? e.label || e.textContent || "" : this.placeholder;
126
122
  }
127
123
  }
128
124
  setupOptionsAccessibility() {
@@ -137,8 +133,8 @@ let o = class extends A(I`
137
133
  t && this.ul && (this.cleanupPositioner = _(t, this.ul, async () => {
138
134
  const e = window.innerHeight, i = t.getBoundingClientRect(), s = e - i.bottom, n = i.top, l = Math.max(0.75 * Math.max(s, n), 150), d = s < 200 && n > s;
139
135
  this.ul.style.maxHeight = `${l}px`;
140
- const { x: u, y: g } = await $(t, this.ul, { placement: d ? "top-start" : "bottom-start", middleware: [w(5), V(), O({ padding: 5 })] });
141
- Object.assign(this.ul.style, { left: `${u}px`, top: `${g}px`, position: "absolute", width: `${t.offsetWidth}px` });
136
+ const { x: f, y: g } = await $(t, this.ul, { placement: d ? "top-start" : "bottom-start", middleware: [V(5), w(), O({ padding: 5 })] });
137
+ Object.assign(this.ul.style, { left: `${f}px`, top: `${g}px`, position: "absolute", width: `${t.offsetWidth}px` });
142
138
  }));
143
139
  }
144
140
  focusOption(t, e) {
@@ -147,8 +143,8 @@ let o = class extends A(I`
147
143
  i.focus(), this._focusedOptionId = i.id;
148
144
  const s = this.renderRoot.querySelector(".trigger");
149
145
  if (s && s.setAttribute("aria-activedescendant", i.id), this.ul && i.offsetTop !== void 0) {
150
- const n = i.offsetTop, l = i.offsetHeight, d = this.ul.scrollTop, u = this.ul.clientHeight;
151
- n < d ? this.ul.scrollTop = n : n + l > d + u && (this.ul.scrollTop = n + l - u);
146
+ const n = i.offsetTop, l = i.offsetHeight, d = this.ul.scrollTop, f = this.ul.clientHeight;
147
+ n < d ? this.ul.scrollTop = n : n + l > d + f && (this.ul.scrollTop = n + l - f);
152
148
  }
153
149
  }
154
150
  }
@@ -164,26 +160,23 @@ let o = class extends A(I`
164
160
  t && (t.removeAttribute("aria-activedescendant"), t?.focus()), this._userInteracted && this.shouldShowValidation() && this.checkValidity();
165
161
  }
166
162
  _setupReactivePipelines() {
167
- c(this, "option-select").pipe(v((t) => {
163
+ c(this, "option-select").pipe(u((t) => {
168
164
  t.stopPropagation();
169
165
  const e = this.options.find((i) => i.value === t.detail.value);
170
166
  e && this._optionSelect$.next(e);
171
- }), p(this.disconnecting)).subscribe(), this._optionSelect$.pipe(v((t) => {
167
+ }), p(this.disconnecting)).subscribe(), this._optionSelect$.pipe(M(this._selectedValue$, this._selectedValues$), u(([t, e, i]) => {
172
168
  if (this._userInteracted = !0, this._touched = !0, this._dirty = !0, this.multi) {
173
- t.selected = !t.selected;
174
- const e = this._selectedValues$.value;
175
- t.selected ? e.includes(t.value) || this._selectedValues$.next([...e, t.value]) : this._selectedValues$.next(e.filter((s) => s !== t.value));
176
- const i = this._selectedValues$.value;
177
- this.valueLabel = i.length > 0 ? this.options.filter((s) => i.includes(s.value)).map((s) => s.label).join(", ") : this.placeholder;
178
- } else this.options.forEach((e) => {
179
- e.selected = e.value === t.value;
180
- }), this._selectedValue$.next(t.value), this.valueLabel = t.label || this.placeholder, this.closeDropdown();
169
+ const s = i.indexOf(t.value), n = s > -1 ? [...i.slice(0, s), ...i.slice(s + 1)] : [...i, t.value];
170
+ this._selectedValues$.next(n), this.valueLabel = n.length > 0 ? this.options.filter((l) => n.includes(l.value)).map((l) => l.label || l.textContent || "").join(", ") : this.placeholder;
171
+ } else this._selectedValue$.next(t.value), this.valueLabel = t.label || t.textContent || this.placeholder, this.closeDropdown();
181
172
  this.setupOptionsAccessibility(), this._fireChangeEvent();
182
- }), p(this.disconnecting)).subscribe(), this._options$.pipe(v((t) => {
183
- t.forEach((e) => {
184
- e.removeEventListener("pointerdown", this._handleOptionPointerDown), e.addEventListener("pointerdown", this._handleOptionPointerDown);
173
+ }), p(this.disconnecting)).subscribe(), this._options$.pipe(u((t) => {
174
+ t.forEach((e, i) => {
175
+ e.setAttribute("role", "option"), e.tabIndex = -1, e.id || (e.id = `${this.id}-option-${i}`), e.hasAttribute("data-event-bound") || (c(e, "pointerdown").pipe(u((s) => {
176
+ s.preventDefault(), s.stopPropagation();
177
+ }), p(this.disconnecting)).subscribe(() => this._optionSelect$.next(e)), e.setAttribute("data-event-bound", "true"));
185
178
  });
186
- }), p(this.disconnecting)).subscribe(), x([this._selectedValue$, this._selectedValues$, this._options$]).pipe(v(([t, e, i]) => {
179
+ }), p(this.disconnecting)).subscribe(), S([this._selectedValue$, this._selectedValues$, this._options$]).pipe(u(([t, e, i]) => {
187
180
  i.length !== 0 && (this.multi ? i.forEach((s) => {
188
181
  s.selected = e.includes(s.value);
189
182
  }) : i.forEach((s) => {
@@ -219,8 +212,8 @@ let o = class extends A(I`
219
212
  this.value = this.defaultValue, this.valueLabel = this.placeholder, this.isValid = !0, this.validationMessage = "", this._touched = !1, this._dirty = !1, this._submitted = !1, this._userInteracted = !1, this.internals?.setValidity({}), this.inputRef && (this.inputRef.error = !1, this.inputRef.hint = this.hint);
220
213
  }
221
214
  render() {
222
- const t = !this.isValid && this.shouldShowValidation() && !this.isOpen, e = this.isOpen ? f`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▲</span>` : f`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▼</span>`;
223
- return f`
215
+ const t = !this.isValid && this.shouldShowValidation() && !this.isOpen, e = this.isOpen ? b`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▲</span>` : b`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▼</span>`;
216
+ return b`
224
217
  <div class="relative ${this.disabled ? "opacity-60 cursor-not-allowed" : ""}">
225
218
  <sch-input
226
219
  .name=${this.name}
@@ -254,18 +247,18 @@ let o = class extends A(I`
254
247
  </sch-input>
255
248
 
256
249
  <!-- Overlay for capturing clicks outside when dropdown is open -->
257
- ${this.isOpen ? f` <div class="fixed inset-0 z-10" @click=${this.closeDropdown} tabindex="-1" aria-hidden="true"></div> ` : ""}
250
+ ${this.isOpen ? b` <div class="fixed inset-0 z-10" @click=${this.closeDropdown} tabindex="-1" aria-hidden="true"></div> ` : ""}
258
251
 
259
252
  <ul
260
253
  id="options"
261
254
  role="listbox"
262
255
  aria-multiselectable=${this.multi}
263
- class=${D({ "absolute min-w-full w-full z-20 mt-1 rounded-md shadow-lg": !0, hidden: !this.isOpen })}
264
- ${E({ bgColor: b.sys.color.surface.low, color: b.sys.color.surface.on })}
256
+ class=${k({ "absolute min-w-full w-full z-20 mt-1 rounded-md shadow-lg": !0, hidden: !this.isOpen })}
257
+ ${I({ bgColor: m.sys.color.surface.low, color: m.sys.color.surface.on })}
265
258
  >
266
259
  <slot
267
260
  @slotchange=${() => {
268
- this._options$.next(this.options);
261
+ this._options$.next(this.options), this.syncSelection();
269
262
  }}
270
263
  ></slot>
271
264
  </ul>
@@ -273,8 +266,8 @@ let o = class extends A(I`
273
266
  `;
274
267
  }
275
268
  };
276
- o.formAssociated = !0, a([r({ type: String })], o.prototype, "name", 2), a([r({ type: Boolean, reflect: !0 })], o.prototype, "required", 2), a([r({ type: Boolean, reflect: !0 })], o.prototype, "disabled", 2), a([r({ type: String })], o.prototype, "placeholder", 2), a([r({ type: String, reflect: !0 })], o.prototype, "value", 1), a([r({ type: Boolean })], o.prototype, "multi", 2), a([r({ type: String })], o.prototype, "label", 2), a([r({ type: String })], o.prototype, "hint", 2), a([r({ type: String })], o.prototype, "validateOn", 2), a([r({ type: String })], o.prototype, "size", 2), a([h()], o.prototype, "isOpen", 2), a([h()], o.prototype, "valueLabel", 2), a([h()], o.prototype, "isValid", 2), a([r({ type: String })], o.prototype, "validationMessage", 2), a([h()], o.prototype, "defaultValue", 2), a([m("ul")], o.prototype, "ul", 2), a([m("sch-input")], o.prototype, "inputRef", 2), a([k({ flatten: !0 })], o.prototype, "options", 2), a([h()], o.prototype, "_userInteracted", 2), a([h()], o.prototype, "_touched", 2), a([h()], o.prototype, "_dirty", 2), a([h()], o.prototype, "_submitted", 2), a([h()], o.prototype, "_focusedOptionId", 2), o = a([R("schmancy-select")], o);
269
+ o.formAssociated = !0, a([r({ type: String })], o.prototype, "name", 2), a([r({ type: Boolean, reflect: !0 })], o.prototype, "required", 2), a([r({ type: Boolean, reflect: !0 })], o.prototype, "disabled", 2), a([r({ type: String })], o.prototype, "placeholder", 2), a([r({ type: String, reflect: !0 })], o.prototype, "value", 1), a([r({ type: Boolean })], o.prototype, "multi", 2), a([r({ type: String })], o.prototype, "label", 2), a([r({ type: String })], o.prototype, "hint", 2), a([r({ type: String })], o.prototype, "validateOn", 2), a([r({ type: String })], o.prototype, "size", 2), a([h()], o.prototype, "isOpen", 2), a([h()], o.prototype, "valueLabel", 2), a([h()], o.prototype, "isValid", 2), a([r({ type: String })], o.prototype, "validationMessage", 2), a([h()], o.prototype, "defaultValue", 2), a([y("ul")], o.prototype, "ul", 2), a([y("sch-input")], o.prototype, "inputRef", 2), a([D({ flatten: !0 })], o.prototype, "options", 2), a([h()], o.prototype, "_userInteracted", 2), a([h()], o.prototype, "_touched", 2), a([h()], o.prototype, "_dirty", 2), a([h()], o.prototype, "_submitted", 2), a([h()], o.prototype, "_focusedOptionId", 2), o = a([R("schmancy-select")], o);
277
270
  export {
278
271
  o as S
279
272
  };
280
- //# sourceMappingURL=select-DcvpJkwX.js.map
273
+ //# sourceMappingURL=select-D7Na7bJk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select-D7Na7bJk.js","sources":["../src/select/select.ts"],"sourcesContent":["import { autoUpdate, computePosition, flip, offset, shift } from '@floating-ui/dom'\nimport { $LitElement } from '@mixins/index'\nimport { color } from '@schmancy/directives'\nimport SchmancyInput from '@schmancy/input/input'\nimport SchmancyOption from '@schmancy/option/option'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { css, html, PropertyValues, TemplateResult } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest, fromEvent, Subject, takeUntil } from 'rxjs'\nimport { tap, withLatestFrom } from 'rxjs/operators'\n\nexport type SchmancySelectChangeEvent = CustomEvent<{\n\tvalue: string | string[]\n}>\n\n@customElement('schmancy-select')\nexport class SchmancySelect extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t}\n\n\t[role='listbox'] {\n\t\toverflow-y: auto;\n\t\toutline: none;\n\t}\n`) {\n\t// Form association setup\n\tstatic formAssociated = true\n\tprivate internals?: ElementInternals\n\n\t// API\n\t@property({ type: String }) name: string | undefined\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: String }) placeholder = ''\n\t@property({ type: String, reflect: true })\n\tget value() {\n\t\treturn this.multi\n\t\t\t? this._selectedValues$.value.join(',')\n\t\t\t: this._selectedValue$.value\n\t}\n\tset value(val: string | string[]) {\n\t\tif (this.multi) {\n\t\t\tconst values = Array.isArray(val)\n\t\t\t\t? val\n\t\t\t\t: val ? String(val).split(',').map(v => v.trim()).filter(Boolean) : []\n\t\t\tthis._selectedValues$.next(values)\n\t\t} else {\n\t\t\tthis._selectedValue$.next(String(val || ''))\n\t\t}\n\t}\n\t@property({ type: Boolean }) multi = false\n\t@property({ type: String }) label = ''\n\t@property({ type: String }) hint = ''\n\t@property({ type: String }) validateOn: 'always' | 'touched' | 'dirty' | 'submitted' = 'touched'\n\t@property({ type: String }) size: 'sm' | 'md' | 'lg' = 'md'\n\n\t// Internal states\n\t@state() private isOpen = false\n\t@state() private valueLabel = ''\n\t@state() private isValid = true\n\t@property({ type: String }) validationMessage = ''\n\n\t// Store the initial/default value for reset behavior\n\t@state() private defaultValue: string | string[] = ''\n\n\t@query('ul') private ul!: HTMLUListElement\n\t@query('sch-input') private inputRef!: SchmancyInput\n\t@queryAssignedElements({ flatten: true }) private options!: SchmancyOption[]\n\tprivate cleanupPositioner?: () => void\n\n\t// Reactive state management\n\tprivate _options$ = new BehaviorSubject<SchmancyOption[]>([])\n\tprivate _selectedValue$ = new BehaviorSubject<string>('')\n\tprivate _selectedValues$ = new BehaviorSubject<string[]>([])\n\tprivate _optionSelect$ = new Subject<SchmancyOption>()\n\t@state() _userInteracted = false\n\t@state() private _touched = false\n\t@state() private _dirty = false\n\t@state() private _submitted = false\n\n\t// Reference to current focused option (for keyboard navigation)\n\t@state() private _focusedOptionId = ''\n\n\t// Form event handlers\n\tprivate formSubmitHandler = () => {\n\t\tthis._submitted = true\n\t\tthis.checkValidity()\n\t}\n\n\tprivate formResetHandler = () => {\n\t\tthis.reset()\n\t}\n\n\tconstructor() {\n\t\tsuper()\n\t\t// Initialize ElementInternals for form association\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch (e) {\n\t\t\tconsole.warn('FormAssociated elements not supported in this browser', e)\n\t\t}\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tif (!this.id) {\n\t\t\tthis.id = `schmancy-select-${Math.random().toString(36).substring(2, 9)}`\n\t\t}\n\n\t\t// Store initial value for reset\n\t\tthis.defaultValue = this.value\n\n\t\t// Add keyboard handling to host element\n\t\tfromEvent<KeyboardEvent>(this, 'keydown').pipe(takeUntil(this.disconnecting)).subscribe(this.handleKeyDown)\n\n\t\t// Setup reactive pipelines\n\t\tthis._setupReactivePipelines()\n\n\t\t// Listen for form submission events to mark field as submitted\n\t\tif (this.internals?.form) {\n\t\t\tfromEvent(this.internals.form, 'submit')\n\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t.subscribe(this.formSubmitHandler)\n\n\t\t\t// Listen for form reset\n\t\t\tfromEvent(this.internals.form, 'reset')\n\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t.subscribe(this.formResetHandler)\n\t\t}\n\n\t\t// Initially hide any validation errors until user interacts\n\t\tif (this.inputRef) {\n\t\t\tthis.inputRef.error = false\n\t\t}\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanupPositioner?.()\n\t\t// Form event listeners are automatically cleaned up via takeUntil(this.disconnecting)\n\t}\n\n\tfirstUpdated() {\n\t\tthis.syncSelection()\n\t\tthis.setupOptionsAccessibility()\n\t}\n\n\tupdated(changedProps: PropertyValues) {\n\t\tsuper.updated(changedProps)\n\n\t\tif (changedProps.has('value')) {\n\t\t\t// Update form value when component value changes\n\t\t\tconst formValue = Array.isArray(this.value) ? this.value.join(',') : this.value\n\t\t\tthis.internals?.setFormValue(formValue)\n\n\t\t\t// Mark as dirty if value changes from initial value\n\t\t\tif (this.hasUpdated) {\n\t\t\t\tthis._dirty = true\n\t\t\t}\n\n\t\t\t// Check validity based on validation strategy\n\t\t\tif (this.hasUpdated) {\n\t\t\t\tthis.checkValidity()\n\t\t\t}\n\t\t}\n\n\t\t// When open state changes, setup or cleanup the dropdown positioner\n\t\tif (changedProps.has('isOpen')) {\n\t\t\tif (this.isOpen) {\n\t\t\t\tthis.positionDropdown()\n\t\t\t} else {\n\t\t\t\tthis.cleanupPositioner?.()\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Determines if validation errors should be shown based on current state\n\t * and validation strategy\n\t */\n\tprivate shouldShowValidation(forceValidation = false): boolean {\n\t\tif (forceValidation) return true\n\n\t\tswitch (this.validateOn) {\n\t\t\tcase 'always':\n\t\t\t\treturn true\n\t\t\tcase 'touched':\n\t\t\t\treturn this._touched\n\t\t\tcase 'dirty':\n\t\t\t\treturn this._dirty\n\t\t\tcase 'submitted':\n\t\t\t\treturn this._submitted\n\t\t\tdefault:\n\t\t\t\treturn this._touched\n\t\t}\n\t}\n\n\tprivate syncSelection() {\n\t\tif (this.multi) {\n\t\t\t// Read directly from the BehaviorSubject to avoid string conversion issues\n\t\t\tconst selectedValues = this._selectedValues$.value\n\t\t\tthis.options?.forEach(o => (o.selected = selectedValues.includes(o.value))) // Update option selected state\n\t\t\tthis.valueLabel =\n\t\t\t\tselectedValues.length > 0\n\t\t\t\t\t? this.options\n\t\t\t\t\t\t\t?.filter(o => selectedValues.includes(o.value))\n\t\t\t\t\t\t\t.map(o => o.label || o.textContent || '')\n\t\t\t\t\t\t\t.join(', ') || this.placeholder\n\t\t\t\t\t: this.placeholder\n\t\t} else {\n\t\t\t// Single select - read from BehaviorSubject\n\t\t\tconst currentValue = this._selectedValue$.value\n\t\t\tthis.options?.forEach(o => {\n\t\t\t\t// Set selected property on each option based on matching value\n\t\t\t\to.selected = o.value === currentValue\n\t\t\t})\n\t\t\tconst selectedOption = this.options?.find(o => o.value === currentValue)\n\t\t\tthis.valueLabel = selectedOption ? (selectedOption.label || selectedOption.textContent || '') : this.placeholder\n\t\t}\n\t}\n\n\tprivate setupOptionsAccessibility() {\n\t\tthis.options?.forEach((option, index) => {\n\t\t\toption.setAttribute('role', 'option')\n\t\t\tif (!option.id) {\n\t\t\t\toption.id = `${this.id}-option-${index}`\n\t\t\t}\n\n\t\t\t// Set tabindex to -1 so they're focusable programmatically but not in the tab order\n\t\t\toption.tabIndex = -1\n\t\t\tconst selectedValues = Array.isArray(this.value) ? this.value : this.value ? this.value.split(',') : []\n\n\t\t\toption.setAttribute(\n\t\t\t\t'aria-selected',\n\t\t\t\tString(this.multi ? selectedValues.includes(option.value) : option.value === this.value),\n\t\t\t)\n\t\t})\n\t}\n\n\tprivate async positionDropdown() {\n\t\tconst reference = this.renderRoot.querySelector('.trigger') as HTMLElement\n\t\tif (!reference || !this.ul) return\n\n\t\tthis.cleanupPositioner = autoUpdate(reference, this.ul, async () => {\n\t\t\t// Get viewport dimensions\n\t\t\tconst viewportHeight = window.innerHeight\n\t\t\tconst triggerRect = reference.getBoundingClientRect()\n\n\t\t\t// Calculate available space below and above\n\t\t\tconst spaceBelow = viewportHeight - triggerRect.bottom\n\t\t\tconst spaceAbove = triggerRect.top\n\n\t\t\t// Calculate max height - use 75% of the largest available space, but at least 150px\n\t\t\tconst maxHeight = Math.max(Math.max(spaceBelow, spaceAbove) * 0.75, 150)\n\n\t\t\t// Determine if we should flip\n\t\t\tconst shouldFlip = spaceBelow < 200 && spaceAbove > spaceBelow\n\n\t\t\t// Apply max height\n\t\t\tthis.ul.style.maxHeight = `${maxHeight}px`\n\n\t\t\tconst { x, y } = await computePosition(reference, this.ul, {\n\t\t\t\tplacement: shouldFlip ? 'top-start' : 'bottom-start',\n\t\t\t\tmiddleware: [offset(5), flip(), shift({ padding: 5 })],\n\t\t\t})\n\n\t\t\tObject.assign(this.ul.style, {\n\t\t\t\tleft: `${x}px`,\n\t\t\t\ttop: `${y}px`,\n\t\t\t\tposition: 'absolute',\n\t\t\t\twidth: `${reference.offsetWidth}px`, // Match the width of the trigger\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\t// Don't handle keyboard events when disabled\n\t\tif (this.disabled) {\n\t\t\treturn\n\t\t}\n\n\t\tif (!this.isOpen) {\n\t\t\tif (['Enter', ' ', 'ArrowDown'].includes(e.key)) {\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.openDropdown(false)\n\t\t\t}\n\t\t\treturn\n\t\t}\n\n\t\t// Find current focused option\n\t\tconst options = Array.from(this.options || [])\n\t\tconst current = options.findIndex(o => o.id === this._focusedOptionId) ?? -1\n\n\t\tswitch (e.key) {\n\t\t\tcase 'Escape':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.closeDropdown()\n\t\t\t\tbreak\n\t\t\tcase 'ArrowDown':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, Math.min(current + 1, options.length - 1))\n\t\t\t\tbreak\n\t\t\tcase 'ArrowUp':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, Math.max(current - 1, 0))\n\t\t\t\tbreak\n\t\t\tcase 'Home':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, 0)\n\t\t\t\tbreak\n\t\t\tcase 'End':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, options.length - 1)\n\t\t\t\tbreak\n\t\t\tcase 'Enter':\n\t\t\tcase ' ':\n\t\t\t\te.preventDefault()\n\t\t\t\tif (this._focusedOptionId) {\n\t\t\t\t\tconst focusedOption = options.find(opt => opt.id === this._focusedOptionId)\n\t\t\t\t\tif (focusedOption) {\n\t\t\t\t\t\tthis.handleOptionSelect(focusedOption.value)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\tcase 'Tab':\n\t\t\t\tthis.closeDropdown()\n\t\t\t\tbreak\n\t\t}\n\t}\n\n\tprivate focusOption(options: SchmancyOption[], index: number) {\n\t\tconst option = options[index]\n\t\tif (option) {\n\t\t\toption.focus()\n\t\t\tthis._focusedOptionId = option.id\n\n\t\t\t// Update aria-activedescendant on the combobox\n\t\t\tconst combobox = this.renderRoot.querySelector('.trigger')\n\t\t\tif (combobox) {\n\t\t\t\tcombobox.setAttribute('aria-activedescendant', option.id)\n\t\t\t}\n\n\t\t\t// Ensure option is visible in the scrollable area\n\t\t\tif (this.ul && option.offsetTop !== undefined) {\n\t\t\t\t// Get position info\n\t\t\t\tconst optionTop = option.offsetTop\n\t\t\t\tconst optionHeight = option.offsetHeight\n\t\t\t\tconst scrollTop = this.ul.scrollTop\n\t\t\t\tconst ulHeight = this.ul.clientHeight\n\n\t\t\t\t// Scroll into view if needed\n\t\t\t\tif (optionTop < scrollTop) {\n\t\t\t\t\tthis.ul.scrollTop = optionTop\n\t\t\t\t} else if (optionTop + optionHeight > scrollTop + ulHeight) {\n\t\t\t\t\tthis.ul.scrollTop = optionTop + optionHeight - ulHeight\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async openDropdown(report = false) {\n\t\t// Don't open if disabled\n\t\tif (this.disabled) {\n\t\t\treturn\n\t\t}\n\n\t\t// Don't mark as touched on opening - we'll do that on closing\n\t\t// so errors only show after interaction is complete\n\n\t\tthis.isOpen = true\n\t\tawait this.updateComplete\n\n\t\t// Focus first or selected option\n\t\tconst options = Array.from(this.options || [])\n\t\tconst selectedIndex = this.multi ? 0 : options.findIndex(o => o.value === String(this.value))\n\n\t\tthis.focusOption(options, Math.max(selectedIndex, 0))\n\n\t\t// Don't automatically validate when opening\n\t\t// Only validate if explicitly requested (like from a form submission)\n\t\tif (report) this.reportValidity()\n\t}\n\n\tprivate closeDropdown() {\n\t\t// Only mark as touched if the user actually interacted with the component\n\t\t// and made a selection or explicitly closed it without selecting\n\t\tif (this._userInteracted) {\n\t\t\tthis._touched = true\n\t\t}\n\n\t\tthis.isOpen = false\n\t\tthis._focusedOptionId = ''\n\n\t\t// Update combobox to remove aria-activedescendant\n\t\tconst combobox = this.renderRoot.querySelector<HTMLElement>('.trigger')\n\t\tif (combobox) {\n\t\t\tcombobox.removeAttribute('aria-activedescendant')\n\t\t\tcombobox?.focus()\n\t\t}\n\n\t\t// Only check validity when closing if the user has actually interacted\n\t\t// with the component and validation should be shown\n\t\tif (this._userInteracted && this.shouldShowValidation()) {\n\t\t\tthis.checkValidity()\n\t\t}\n\t}\n\n\tprivate _setupReactivePipelines() {\n\t\t// Listen for option-select events from child options\n\t\tfromEvent<CustomEvent>(this, 'option-select')\n\t\t\t.pipe(\n\t\t\t\ttap((e) => {\n\t\t\t\t\te.stopPropagation() // Prevent event from bubbling further\n\t\t\t\t\tconst option = this.options.find(o => o.value === e.detail.value)\n\t\t\t\t\tif (option) {\n\t\t\t\t\t\tthis._optionSelect$.next(option)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Handle option selection through reactive pipeline\n\t\tthis._optionSelect$\n\t\t\t.pipe(\n\t\t\t\twithLatestFrom(this._selectedValue$, this._selectedValues$),\n\t\t\t\ttap(([option, _, currentValues]) => {\n\t\t\t\t\tthis._userInteracted = true\n\t\t\t\t\tthis._touched = true\n\t\t\t\t\tthis._dirty = true\n\n\t\t\t\t\tif (this.multi) {\n\t\t\t\t\t\tconst index = currentValues.indexOf(option.value)\n\t\t\t\t\t\tconst newValues = index > -1\n\t\t\t\t\t\t\t? [...currentValues.slice(0, index), ...currentValues.slice(index + 1)]\n\t\t\t\t\t\t\t: [...currentValues, option.value]\n\t\t\t\t\t\tthis._selectedValues$.next(newValues)\n\n\t\t\t\t\t\t// Update display label\n\t\t\t\t\t\tthis.valueLabel = newValues.length > 0\n\t\t\t\t\t\t\t? this.options\n\t\t\t\t\t\t\t\t\t.filter(o => newValues.includes(o.value))\n\t\t\t\t\t\t\t\t\t.map(o => o.label || o.textContent || '')\n\t\t\t\t\t\t\t\t\t.join(', ')\n\t\t\t\t\t\t\t: this.placeholder\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Single select\n\t\t\t\t\t\tthis._selectedValue$.next(option.value)\n\t\t\t\t\t\tthis.valueLabel = option.label || option.textContent || this.placeholder\n\t\t\t\t\t\tthis.closeDropdown()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Update the option's accessibility state\n\t\t\t\t\tthis.setupOptionsAccessibility()\n\n\t\t\t\t\t// Dispatch change event\n\t\t\t\t\tthis._fireChangeEvent()\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Options management pipeline - bind pointerdown events exactly like autocomplete\n\t\tthis._options$\n\t\t\t.pipe(\n\t\t\t\ttap((options) => {\n\t\t\t\t\toptions.forEach((option, index) => {\n\t\t\t\t\t\toption.setAttribute('role', 'option')\n\t\t\t\t\t\toption.tabIndex = -1\n\t\t\t\t\t\tif (!option.id) {\n\t\t\t\t\t\t\toption.id = `${this.id}-option-${index}`\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Use data-event-bound to prevent duplicate bindings\n\t\t\t\t\t\tif (!option.hasAttribute('data-event-bound')) {\n\t\t\t\t\t\t\tfromEvent(option, 'pointerdown').pipe(\n\t\t\t\t\t\t\t\ttap(e => {\n\t\t\t\t\t\t\t\t\te.preventDefault() // Prevent blur from firing\n\t\t\t\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t\t\t\t\t).subscribe(() => this._optionSelect$.next(option))\n\t\t\t\t\t\t\toption.setAttribute('data-event-bound', 'true')\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Selection sync pipeline - sync selected states with value changes\n\t\tcombineLatest([this._selectedValue$, this._selectedValues$, this._options$])\n\t\t\t.pipe(\n\t\t\t\ttap(([singleValue, multiValues, options]) => {\n\t\t\t\t\tif (options.length === 0) return\n\n\t\t\t\t\tif (this.multi) {\n\t\t\t\t\t\toptions.forEach(option => {\n\t\t\t\t\t\t\toption.selected = multiValues.includes(option.value)\n\t\t\t\t\t\t})\n\t\t\t\t\t} else {\n\t\t\t\t\t\toptions.forEach(option => {\n\t\t\t\t\t\t\toption.selected = option.value === singleValue\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate handleOptionSelect(value: string) {\n\t\t// This method is now called from keyboard navigation only\n\t\tconst option = this.options.find(o => o.value === value)\n\t\tif (option) {\n\t\t\tthis._optionSelect$.next(option)\n\t\t}\n\t}\n\n\tprivate _fireChangeEvent() {\n\t\t// Get the current value based on multi/single mode\n\t\tconst value = this.multi ? this._selectedValues$.value : this._selectedValue$.value\n\n\t\t// Dispatch only one change event with the value in detail\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent<SchmancySelectChangeEvent['detail']>('change', {\n\t\t\t\tdetail: { value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\n\t\t// Then check validity (only show error if validation should be shown)\n\t\tthis.checkValidity()\n\t}\n\n\tpublic checkValidity(): boolean {\n\t\t// Disabled fields are always valid\n\t\tif (this.disabled) {\n\t\t\treturn true\n\t\t}\n\n\t\t// Determine if the select is empty based on whether it's multi-select or single-select\n\t\tconst isEmpty = this.multi ? (Array.isArray(this.value) ? this.value.length === 0 : !this.value) : !this.value\n\n\t\t// Check if the value is valid (not empty when required)\n\t\tconst isValid = !(this.required && isEmpty)\n\n\t\t// Set the validity state\n\t\tthis.isValid = isValid\n\n\t\tif (!this.isValid) {\n\t\t\tthis.validationMessage = 'Please select an option.'\n\t\t\tthis.internals?.setValidity({ valueMissing: true }, 'Please select an option.', this.inputRef)\n\t\t} else {\n\t\t\t// Clear validation message\n\t\t\tthis.validationMessage = ''\n\t\t\tthis.internals?.setValidity({})\n\t\t}\n\n\t\t// Update the input component to reflect our validation state\n\t\tif (this.inputRef && this.hasUpdated) {\n\t\t\tconst showError = !this.isValid && this.shouldShowValidation()\n\t\t\tthis.inputRef.error = showError\n\t\t\tthis.inputRef.hint = showError ? this.validationMessage : this.hint\n\t\t}\n\n\t\treturn this.isValid\n\t}\n\n\tpublic reportValidity(): boolean {\n\t\t// Force validation display regardless of validation strategy\n\t\tconst valid = this.checkValidity()\n\n\t\t// Force the input to show validation errors\n\t\tif (this.inputRef) {\n\t\t\t// Set the input's error state\n\t\t\tthis.inputRef.error = !valid\n\t\t\tthis.inputRef.hint = !valid ? this.validationMessage : this.hint\n\n\t\t\t// If invalid and not already open, automatically open the dropdown to show options\n\t\t\tif (!valid && !this.isOpen) {\n\t\t\t\t// Open the dropdown but don't mark as user interaction yet\n\t\t\t\t// This helps users immediately see available options when validation fails\n\t\t\t\tthis.openDropdown(false)\n\t\t\t}\n\n\t\t\t// Only call reportValidity on the input if invalid to show the native popup\n\t\t\tif (!valid) {\n\t\t\t\tthis.inputRef.reportValidity()\n\t\t\t}\n\t\t}\n\n\t\treturn valid\n\t}\n\n\tpublic setCustomValidity(message: string) {\n\t\tthis.validationMessage = message\n\t\tif (message) {\n\t\t\tthis.isValid = false\n\t\t\tthis.internals?.setValidity({ customError: true }, message, this.inputRef)\n\t\t} else {\n\t\t\tthis.isValid = true\n\t\t\tthis.internals?.setValidity({})\n\t\t}\n\n\t\t// Update input if needed\n\t\tif (this.inputRef && this.shouldShowValidation()) {\n\t\t\tthis.inputRef.error = !this.isValid\n\t\t\tthis.inputRef.hint = !this.isValid ? this.validationMessage : this.hint\n\t\t}\n\t}\n\n\tpublic reset() {\n\t\t// Reset to initial value\n\t\tthis.value = this.defaultValue\n\t\tthis.valueLabel = this.placeholder\n\t\tthis.isValid = true\n\t\tthis.validationMessage = ''\n\t\tthis._touched = false\n\t\tthis._dirty = false\n\t\tthis._submitted = false\n\t\tthis._userInteracted = false\n\t\tthis.internals?.setValidity({})\n\n\t\tif (this.inputRef) {\n\t\t\tthis.inputRef.error = false\n\t\t\tthis.inputRef.hint = this.hint\n\t\t}\n\t}\n\n\trender(): TemplateResult {\n\t\t// Determine if we should show errors based on the validation strategy and interaction\n\t\t// Never show errors on initial render or if the dropdown is open\n\t\tconst showErrors = !this.isValid && this.shouldShowValidation() && !this.isOpen\n\n\t\t// Add caret icon based on open state\n\t\tconst caretIcon = this.isOpen\n\t\t\t? html`<span class=\"absolute right-3 top-1/2 transform -translate-y-1/2\">▲</span>`\n\t\t\t: html`<span class=\"absolute right-3 top-1/2 transform -translate-y-1/2\">▼</span>`\n\n\t\treturn html`\n\t\t\t<div class=\"relative ${this.disabled ? 'opacity-60 cursor-not-allowed' : ''}\">\n\t\t\t\t<sch-input\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\ttabIndex=${this.disabled ? '-1' : '0'}\n\t\t\t\t\tclass=\"trigger\"\n\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\taria-haspopup=\"listbox\"\n\t\t\t\t\taria-expanded=${this.isOpen}\n\t\t\t\t\taria-controls=\"options\"\n\t\t\t\t\taria-autocomplete=\"none\"\n\t\t\t\t\taria-required=${this.required}\n\t\t\t\t\taria-activedescendant=${this._focusedOptionId || undefined}\n\t\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\t\t.label=${this.label}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.value=${this.valueLabel}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\t.hint=${showErrors ? this.validationMessage : this.hint}\n\t\t\t\t\t.error=${showErrors}\n\t\t\t\t\t.validateOn=${this.validateOn}\n\t\t\t\t\t.size=${this.size}\n\t\t\t\t\treadonly\n\t\t\t\t\tclickable\n\t\t\t\t\t@click=${(e: MouseEvent) => {\n\t\t\t\t\t\t// Don't process clicks if disabled\n\t\t\t\t\t\tif (this.disabled) {\n\t\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// On first click, don't count this as user interaction yet\n\t\t\t\t\t\tif (!this.isOpen) {\n\t\t\t\t\t\t\t// Open without triggering validation - we'll validate when they close\n\t\t\t\t\t\t\tthis.openDropdown(false)\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Mark as interacted when they close the dropdown\n\t\t\t\t\t\t\tthis._userInteracted = true\n\t\t\t\t\t\t\tthis.closeDropdown()\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t${caretIcon}\n\t\t\t\t</sch-input>\n\n\t\t\t\t<!-- Overlay for capturing clicks outside when dropdown is open -->\n\t\t\t\t${this.isOpen\n\t\t\t\t\t? html` <div class=\"fixed inset-0 z-10\" @click=${this.closeDropdown} tabindex=\"-1\" aria-hidden=\"true\"></div> `\n\t\t\t\t\t: ''}\n\n\t\t\t\t<ul\n\t\t\t\t\tid=\"options\"\n\t\t\t\t\trole=\"listbox\"\n\t\t\t\t\taria-multiselectable=${this.multi}\n\t\t\t\t\tclass=${classMap({\n\t\t\t\t\t\t'absolute min-w-full w-full z-20 mt-1 rounded-md shadow-lg': true,\n\t\t\t\t\t\thidden: !this.isOpen,\n\t\t\t\t\t})}\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.low,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t>\n\t\t\t\t\t<slot\n\t\t\t\t\t\t@slotchange=${() => {\n\t\t\t\t\t\t\tthis._options$.next(this.options)\n\t\t\t\t\t\t\t// Sync selection state when options re-render\n\t\t\t\t\t\t\tthis.syncSelection()\n\t\t\t\t\t\t}}\n\t\t\t\t\t></slot>\n\t\t\t\t</ul>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\n// Don't export 'select' here as it conflicts with the store's select decorator\n// export const select = SchmancySelect\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-select': SchmancySelect\n\t}\n}\n"],"names":["SchmancySelect","$LitElement","css","super","this","required","disabled","placeholder","multi","label","hint","validateOn","size","isOpen","valueLabel","isValid","validationMessage","defaultValue","_options$","BehaviorSubject","_selectedValue$","_selectedValues$","_optionSelect$","Subject","_userInteracted","_touched","_dirty","_submitted","_focusedOptionId","formSubmitHandler","checkValidity","formResetHandler","reset","handleKeyDown","e","includes","key","preventDefault","openDropdown","options","Array","from","current","findIndex","o","id","closeDropdown","focusOption","Math","min","length","max","focusedOption","find","opt","handleOptionSelect","value","internals","attachInternals","join","val","values","isArray","String","split","map","v","trim","filter","Boolean","next","form","connectedCallback","random","toString","substring","fromEvent","pipe","takeUntil","disconnecting","subscribe","_setupReactivePipelines","inputRef","error","disconnectedCallback","cleanupPositioner","firstUpdated","syncSelection","setupOptionsAccessibility","changedProps","updated","has","formValue","setFormValue","hasUpdated","positionDropdown","forceValidation","selectedValues","forEach","selected","textContent","currentValue","selectedOption","option","index","setAttribute","tabIndex","reference","renderRoot","querySelector","ul","autoUpdate","async","viewportHeight","window","innerHeight","triggerRect","getBoundingClientRect","spaceBelow","bottom","spaceAbove","top","maxHeight","shouldFlip","style","x","y","computePosition","placement","middleware","offset","flip","shift","padding","Object","assign","left","position","width","offsetWidth","focus","combobox","offsetTop","optionTop","optionHeight","offsetHeight","scrollTop","ulHeight","clientHeight","report","updateComplete","selectedIndex","reportValidity","removeAttribute","shouldShowValidation","tap","stopPropagation","detail","withLatestFrom","_","currentValues","indexOf","newValues","slice","_fireChangeEvent","hasAttribute","combineLatest","singleValue","multiValues","dispatchEvent","CustomEvent","bubbles","composed","isEmpty","setValidity","valueMissing","showError","valid","message","customError","showErrors","caretIcon","html","name","classMap","hidden","color","bgColor","SchmancyTheme","sys","surface","low","on","formAssociated","__decorateClass","property","type","prototype","reflect","state","query","queryAssignedElements","flatten","customElement"],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ "use strict";const d=require("@floating-ui/dom"),o=require("rxjs"),m=require("lit/directives/class-map.js");require("lit/directives/style-map.js");const a=require("lit/decorators.js");require("./tailwind.mixin-nOWQtiUE.cjs");const v=require("./litElement.mixin-yCbfNohf.cjs"),b=require("./ripple-DqQrvaTe.cjs");require("lit/directives/guard.js");const y=require("./theme.interface-Xg5Zi46a.cjs"),p=require("lit"),c=require("rxjs/operators");var S=Object.defineProperty,g=Object.getOwnPropertyDescriptor,n=(t,e,i,s)=>{for(var l,r=s>1?void 0:s?g(e,i):e,h=t.length-1;h>=0;h--)(l=t[h])&&(r=(s?l(e,i,r):l(r))||r);return s&&r&&S(e,i,r),r};exports.SchmancySelect=class extends v.$LitElement(p.css`
2
+ :host {
3
+ display: block;
4
+ position: relative;
5
+ }
6
+
7
+ [role='listbox'] {
8
+ overflow-y: auto;
9
+ outline: none;
10
+ }
11
+ `){constructor(){super(),this.required=!1,this.disabled=!1,this.placeholder="",this.multi=!1,this.label="",this.hint="",this.validateOn="touched",this.size="md",this.isOpen=!1,this.valueLabel="",this.isValid=!0,this.validationMessage="",this.defaultValue="",this._options$=new o.BehaviorSubject([]),this._selectedValue$=new o.BehaviorSubject(""),this._selectedValues$=new o.BehaviorSubject([]),this._optionSelect$=new o.Subject,this._userInteracted=!1,this._touched=!1,this._dirty=!1,this._submitted=!1,this._focusedOptionId="",this.formSubmitHandler=()=>{this._submitted=!0,this.checkValidity()},this.formResetHandler=()=>{this.reset()},this.handleKeyDown=t=>{if(this.disabled)return;if(!this.isOpen)return void(["Enter"," ","ArrowDown"].includes(t.key)&&(t.preventDefault(),this.openDropdown(!1)));const e=Array.from(this.options||[]),i=e.findIndex(s=>s.id===this._focusedOptionId)??-1;switch(t.key){case"Escape":t.preventDefault(),this.closeDropdown();break;case"ArrowDown":t.preventDefault(),this.focusOption(e,Math.min(i+1,e.length-1));break;case"ArrowUp":t.preventDefault(),this.focusOption(e,Math.max(i-1,0));break;case"Home":t.preventDefault(),this.focusOption(e,0);break;case"End":t.preventDefault(),this.focusOption(e,e.length-1);break;case"Enter":case" ":if(t.preventDefault(),this._focusedOptionId){const s=e.find(l=>l.id===this._focusedOptionId);s&&this.handleOptionSelect(s.value)}break;case"Tab":this.closeDropdown()}};try{this.internals=this.attachInternals()}catch{}}get value(){return this.multi?this._selectedValues$.value.join(","):this._selectedValue$.value}set value(t){if(this.multi){const e=Array.isArray(t)?t:t?String(t).split(",").map(i=>i.trim()).filter(Boolean):[];this._selectedValues$.next(e)}else this._selectedValue$.next(String(t||""))}get form(){return this.internals?.form}connectedCallback(){super.connectedCallback(),this.id||(this.id=`schmancy-select-${Math.random().toString(36).substring(2,9)}`),this.defaultValue=this.value,o.fromEvent(this,"keydown").pipe(o.takeUntil(this.disconnecting)).subscribe(this.handleKeyDown),this._setupReactivePipelines(),this.internals?.form&&(o.fromEvent(this.internals.form,"submit").pipe(o.takeUntil(this.disconnecting)).subscribe(this.formSubmitHandler),o.fromEvent(this.internals.form,"reset").pipe(o.takeUntil(this.disconnecting)).subscribe(this.formResetHandler)),this.inputRef&&(this.inputRef.error=!1)}disconnectedCallback(){super.disconnectedCallback(),this.cleanupPositioner?.()}firstUpdated(){this.syncSelection(),this.setupOptionsAccessibility()}updated(t){if(super.updated(t),t.has("value")){const e=Array.isArray(this.value)?this.value.join(","):this.value;this.internals?.setFormValue(e),this.hasUpdated&&(this._dirty=!0),this.hasUpdated&&this.checkValidity()}t.has("isOpen")&&(this.isOpen?this.positionDropdown():this.cleanupPositioner?.())}shouldShowValidation(t=!1){if(t)return!0;switch(this.validateOn){case"always":return!0;case"touched":default:return this._touched;case"dirty":return this._dirty;case"submitted":return this._submitted}}syncSelection(){if(this.multi){const t=this._selectedValues$.value;this.options?.forEach(e=>e.selected=t.includes(e.value)),this.valueLabel=t.length>0&&this.options?.filter(e=>t.includes(e.value)).map(e=>e.label||e.textContent||"").join(", ")||this.placeholder}else{const t=this._selectedValue$.value;this.options?.forEach(i=>{i.selected=i.value===t});const e=this.options?.find(i=>i.value===t);this.valueLabel=e?e.label||e.textContent||"":this.placeholder}}setupOptionsAccessibility(){this.options?.forEach((t,e)=>{t.setAttribute("role","option"),t.id||(t.id=`${this.id}-option-${e}`),t.tabIndex=-1;const i=Array.isArray(this.value)?this.value:this.value?this.value.split(","):[];t.setAttribute("aria-selected",String(this.multi?i.includes(t.value):t.value===this.value))})}async positionDropdown(){const t=this.renderRoot.querySelector(".trigger");t&&this.ul&&(this.cleanupPositioner=d.autoUpdate(t,this.ul,async()=>{const e=window.innerHeight,i=t.getBoundingClientRect(),s=e-i.bottom,l=i.top,r=Math.max(.75*Math.max(s,l),150),h=s<200&&l>s;this.ul.style.maxHeight=`${r}px`;const{x:u,y:f}=await d.computePosition(t,this.ul,{placement:h?"top-start":"bottom-start",middleware:[d.offset(5),d.flip(),d.shift({padding:5})]});Object.assign(this.ul.style,{left:`${u}px`,top:`${f}px`,position:"absolute",width:`${t.offsetWidth}px`})}))}focusOption(t,e){const i=t[e];if(i){i.focus(),this._focusedOptionId=i.id;const s=this.renderRoot.querySelector(".trigger");if(s&&s.setAttribute("aria-activedescendant",i.id),this.ul&&i.offsetTop!==void 0){const l=i.offsetTop,r=i.offsetHeight,h=this.ul.scrollTop,u=this.ul.clientHeight;l<h?this.ul.scrollTop=l:l+r>h+u&&(this.ul.scrollTop=l+r-u)}}}async openDropdown(t=!1){if(this.disabled)return;this.isOpen=!0,await this.updateComplete;const e=Array.from(this.options||[]),i=this.multi?0:e.findIndex(s=>s.value===String(this.value));this.focusOption(e,Math.max(i,0)),t&&this.reportValidity()}closeDropdown(){this._userInteracted&&(this._touched=!0),this.isOpen=!1,this._focusedOptionId="";const t=this.renderRoot.querySelector(".trigger");t&&(t.removeAttribute("aria-activedescendant"),t?.focus()),this._userInteracted&&this.shouldShowValidation()&&this.checkValidity()}_setupReactivePipelines(){o.fromEvent(this,"option-select").pipe(c.tap(t=>{t.stopPropagation();const e=this.options.find(i=>i.value===t.detail.value);e&&this._optionSelect$.next(e)}),o.takeUntil(this.disconnecting)).subscribe(),this._optionSelect$.pipe(c.withLatestFrom(this._selectedValue$,this._selectedValues$),c.tap(([t,e,i])=>{if(this._userInteracted=!0,this._touched=!0,this._dirty=!0,this.multi){const s=i.indexOf(t.value),l=s>-1?[...i.slice(0,s),...i.slice(s+1)]:[...i,t.value];this._selectedValues$.next(l),this.valueLabel=l.length>0?this.options.filter(r=>l.includes(r.value)).map(r=>r.label||r.textContent||"").join(", "):this.placeholder}else this._selectedValue$.next(t.value),this.valueLabel=t.label||t.textContent||this.placeholder,this.closeDropdown();this.setupOptionsAccessibility(),this._fireChangeEvent()}),o.takeUntil(this.disconnecting)).subscribe(),this._options$.pipe(c.tap(t=>{t.forEach((e,i)=>{e.setAttribute("role","option"),e.tabIndex=-1,e.id||(e.id=`${this.id}-option-${i}`),e.hasAttribute("data-event-bound")||(o.fromEvent(e,"pointerdown").pipe(c.tap(s=>{s.preventDefault(),s.stopPropagation()}),o.takeUntil(this.disconnecting)).subscribe(()=>this._optionSelect$.next(e)),e.setAttribute("data-event-bound","true"))})}),o.takeUntil(this.disconnecting)).subscribe(),o.combineLatest([this._selectedValue$,this._selectedValues$,this._options$]).pipe(c.tap(([t,e,i])=>{i.length!==0&&(this.multi?i.forEach(s=>{s.selected=e.includes(s.value)}):i.forEach(s=>{s.selected=s.value===t}))}),o.takeUntil(this.disconnecting)).subscribe()}handleOptionSelect(t){const e=this.options.find(i=>i.value===t);e&&this._optionSelect$.next(e)}_fireChangeEvent(){const t=this.multi?this._selectedValues$.value:this._selectedValue$.value;this.dispatchEvent(new CustomEvent("change",{detail:{value:t},bubbles:!0,composed:!0})),this.checkValidity()}checkValidity(){if(this.disabled)return!0;const t=this.multi&&Array.isArray(this.value)?this.value.length===0:!this.value,e=!(this.required&&t);if(this.isValid=e,this.isValid?(this.validationMessage="",this.internals?.setValidity({})):(this.validationMessage="Please select an option.",this.internals?.setValidity({valueMissing:!0},"Please select an option.",this.inputRef)),this.inputRef&&this.hasUpdated){const i=!this.isValid&&this.shouldShowValidation();this.inputRef.error=i,this.inputRef.hint=i?this.validationMessage:this.hint}return this.isValid}reportValidity(){const t=this.checkValidity();return this.inputRef&&(this.inputRef.error=!t,this.inputRef.hint=t?this.hint:this.validationMessage,t||this.isOpen||this.openDropdown(!1),t||this.inputRef.reportValidity()),t}setCustomValidity(t){this.validationMessage=t,t?(this.isValid=!1,this.internals?.setValidity({customError:!0},t,this.inputRef)):(this.isValid=!0,this.internals?.setValidity({})),this.inputRef&&this.shouldShowValidation()&&(this.inputRef.error=!this.isValid,this.inputRef.hint=this.isValid?this.hint:this.validationMessage)}reset(){this.value=this.defaultValue,this.valueLabel=this.placeholder,this.isValid=!0,this.validationMessage="",this._touched=!1,this._dirty=!1,this._submitted=!1,this._userInteracted=!1,this.internals?.setValidity({}),this.inputRef&&(this.inputRef.error=!1,this.inputRef.hint=this.hint)}render(){const t=!this.isValid&&this.shouldShowValidation()&&!this.isOpen,e=this.isOpen?p.html`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▲</span>`:p.html`<span class="absolute right-3 top-1/2 transform -translate-y-1/2">▼</span>`;return p.html`
12
+ <div class="relative ${this.disabled?"opacity-60 cursor-not-allowed":""}">
13
+ <sch-input
14
+ .name=${this.name}
15
+ tabIndex=${this.disabled?"-1":"0"}
16
+ class="trigger"
17
+ role="combobox"
18
+ aria-haspopup="listbox"
19
+ aria-expanded=${this.isOpen}
20
+ aria-controls="options"
21
+ aria-autocomplete="none"
22
+ aria-required=${this.required}
23
+ aria-activedescendant=${this._focusedOptionId||void 0}
24
+ aria-disabled=${this.disabled}
25
+ .label=${this.label}
26
+ .placeholder=${this.placeholder}
27
+ .value=${this.valueLabel}
28
+ .required=${this.required}
29
+ .disabled=${this.disabled}
30
+ .hint=${t?this.validationMessage:this.hint}
31
+ .error=${t}
32
+ .validateOn=${this.validateOn}
33
+ .size=${this.size}
34
+ readonly
35
+ clickable
36
+ @click=${i=>{if(this.disabled)return i.preventDefault(),void i.stopPropagation();this.isOpen?(this._userInteracted=!0,this.closeDropdown()):this.openDropdown(!1)}}
37
+ >
38
+ ${e}
39
+ </sch-input>
40
+
41
+ <!-- Overlay for capturing clicks outside when dropdown is open -->
42
+ ${this.isOpen?p.html` <div class="fixed inset-0 z-10" @click=${this.closeDropdown} tabindex="-1" aria-hidden="true"></div> `:""}
43
+
44
+ <ul
45
+ id="options"
46
+ role="listbox"
47
+ aria-multiselectable=${this.multi}
48
+ class=${m.classMap({"absolute min-w-full w-full z-20 mt-1 rounded-md shadow-lg":!0,hidden:!this.isOpen})}
49
+ ${b.color({bgColor:y.SchmancyTheme.sys.color.surface.low,color:y.SchmancyTheme.sys.color.surface.on})}
50
+ >
51
+ <slot
52
+ @slotchange=${()=>{this._options$.next(this.options),this.syncSelection()}}
53
+ ></slot>
54
+ </ul>
55
+ </div>
56
+ `}},exports.SchmancySelect.formAssociated=!0,n([a.property({type:String})],exports.SchmancySelect.prototype,"name",2),n([a.property({type:Boolean,reflect:!0})],exports.SchmancySelect.prototype,"required",2),n([a.property({type:Boolean,reflect:!0})],exports.SchmancySelect.prototype,"disabled",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"placeholder",2),n([a.property({type:String,reflect:!0})],exports.SchmancySelect.prototype,"value",1),n([a.property({type:Boolean})],exports.SchmancySelect.prototype,"multi",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"label",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"hint",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"validateOn",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"size",2),n([a.state()],exports.SchmancySelect.prototype,"isOpen",2),n([a.state()],exports.SchmancySelect.prototype,"valueLabel",2),n([a.state()],exports.SchmancySelect.prototype,"isValid",2),n([a.property({type:String})],exports.SchmancySelect.prototype,"validationMessage",2),n([a.state()],exports.SchmancySelect.prototype,"defaultValue",2),n([a.query("ul")],exports.SchmancySelect.prototype,"ul",2),n([a.query("sch-input")],exports.SchmancySelect.prototype,"inputRef",2),n([a.queryAssignedElements({flatten:!0})],exports.SchmancySelect.prototype,"options",2),n([a.state()],exports.SchmancySelect.prototype,"_userInteracted",2),n([a.state()],exports.SchmancySelect.prototype,"_touched",2),n([a.state()],exports.SchmancySelect.prototype,"_dirty",2),n([a.state()],exports.SchmancySelect.prototype,"_submitted",2),n([a.state()],exports.SchmancySelect.prototype,"_focusedOptionId",2),exports.SchmancySelect=n([a.customElement("schmancy-select")],exports.SchmancySelect);
57
+ //# sourceMappingURL=select-DFpxKCjD.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select-DFpxKCjD.cjs","sources":["../src/select/select.ts"],"sourcesContent":["import { autoUpdate, computePosition, flip, offset, shift } from '@floating-ui/dom'\nimport { $LitElement } from '@mixins/index'\nimport { color } from '@schmancy/directives'\nimport SchmancyInput from '@schmancy/input/input'\nimport SchmancyOption from '@schmancy/option/option'\nimport { SchmancyTheme } from '@schmancy/theme/theme.interface'\nimport { css, html, PropertyValues, TemplateResult } from 'lit'\nimport { customElement, property, query, queryAssignedElements, state } from 'lit/decorators.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { BehaviorSubject, combineLatest, fromEvent, Subject, takeUntil } from 'rxjs'\nimport { tap, withLatestFrom } from 'rxjs/operators'\n\nexport type SchmancySelectChangeEvent = CustomEvent<{\n\tvalue: string | string[]\n}>\n\n@customElement('schmancy-select')\nexport class SchmancySelect extends $LitElement(css`\n\t:host {\n\t\tdisplay: block;\n\t\tposition: relative;\n\t}\n\n\t[role='listbox'] {\n\t\toverflow-y: auto;\n\t\toutline: none;\n\t}\n`) {\n\t// Form association setup\n\tstatic formAssociated = true\n\tprivate internals?: ElementInternals\n\n\t// API\n\t@property({ type: String }) name: string | undefined\n\t@property({ type: Boolean, reflect: true }) required = false\n\t@property({ type: Boolean, reflect: true }) disabled = false\n\t@property({ type: String }) placeholder = ''\n\t@property({ type: String, reflect: true })\n\tget value() {\n\t\treturn this.multi\n\t\t\t? this._selectedValues$.value.join(',')\n\t\t\t: this._selectedValue$.value\n\t}\n\tset value(val: string | string[]) {\n\t\tif (this.multi) {\n\t\t\tconst values = Array.isArray(val)\n\t\t\t\t? val\n\t\t\t\t: val ? String(val).split(',').map(v => v.trim()).filter(Boolean) : []\n\t\t\tthis._selectedValues$.next(values)\n\t\t} else {\n\t\t\tthis._selectedValue$.next(String(val || ''))\n\t\t}\n\t}\n\t@property({ type: Boolean }) multi = false\n\t@property({ type: String }) label = ''\n\t@property({ type: String }) hint = ''\n\t@property({ type: String }) validateOn: 'always' | 'touched' | 'dirty' | 'submitted' = 'touched'\n\t@property({ type: String }) size: 'sm' | 'md' | 'lg' = 'md'\n\n\t// Internal states\n\t@state() private isOpen = false\n\t@state() private valueLabel = ''\n\t@state() private isValid = true\n\t@property({ type: String }) validationMessage = ''\n\n\t// Store the initial/default value for reset behavior\n\t@state() private defaultValue: string | string[] = ''\n\n\t@query('ul') private ul!: HTMLUListElement\n\t@query('sch-input') private inputRef!: SchmancyInput\n\t@queryAssignedElements({ flatten: true }) private options!: SchmancyOption[]\n\tprivate cleanupPositioner?: () => void\n\n\t// Reactive state management\n\tprivate _options$ = new BehaviorSubject<SchmancyOption[]>([])\n\tprivate _selectedValue$ = new BehaviorSubject<string>('')\n\tprivate _selectedValues$ = new BehaviorSubject<string[]>([])\n\tprivate _optionSelect$ = new Subject<SchmancyOption>()\n\t@state() _userInteracted = false\n\t@state() private _touched = false\n\t@state() private _dirty = false\n\t@state() private _submitted = false\n\n\t// Reference to current focused option (for keyboard navigation)\n\t@state() private _focusedOptionId = ''\n\n\t// Form event handlers\n\tprivate formSubmitHandler = () => {\n\t\tthis._submitted = true\n\t\tthis.checkValidity()\n\t}\n\n\tprivate formResetHandler = () => {\n\t\tthis.reset()\n\t}\n\n\tconstructor() {\n\t\tsuper()\n\t\t// Initialize ElementInternals for form association\n\t\ttry {\n\t\t\tthis.internals = this.attachInternals()\n\t\t} catch (e) {\n\t\t\tconsole.warn('FormAssociated elements not supported in this browser', e)\n\t\t}\n\t}\n\n\tget form() {\n\t\treturn this.internals?.form\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tif (!this.id) {\n\t\t\tthis.id = `schmancy-select-${Math.random().toString(36).substring(2, 9)}`\n\t\t}\n\n\t\t// Store initial value for reset\n\t\tthis.defaultValue = this.value\n\n\t\t// Add keyboard handling to host element\n\t\tfromEvent<KeyboardEvent>(this, 'keydown').pipe(takeUntil(this.disconnecting)).subscribe(this.handleKeyDown)\n\n\t\t// Setup reactive pipelines\n\t\tthis._setupReactivePipelines()\n\n\t\t// Listen for form submission events to mark field as submitted\n\t\tif (this.internals?.form) {\n\t\t\tfromEvent(this.internals.form, 'submit')\n\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t.subscribe(this.formSubmitHandler)\n\n\t\t\t// Listen for form reset\n\t\t\tfromEvent(this.internals.form, 'reset')\n\t\t\t\t.pipe(takeUntil(this.disconnecting))\n\t\t\t\t.subscribe(this.formResetHandler)\n\t\t}\n\n\t\t// Initially hide any validation errors until user interacts\n\t\tif (this.inputRef) {\n\t\t\tthis.inputRef.error = false\n\t\t}\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.cleanupPositioner?.()\n\t\t// Form event listeners are automatically cleaned up via takeUntil(this.disconnecting)\n\t}\n\n\tfirstUpdated() {\n\t\tthis.syncSelection()\n\t\tthis.setupOptionsAccessibility()\n\t}\n\n\tupdated(changedProps: PropertyValues) {\n\t\tsuper.updated(changedProps)\n\n\t\tif (changedProps.has('value')) {\n\t\t\t// Update form value when component value changes\n\t\t\tconst formValue = Array.isArray(this.value) ? this.value.join(',') : this.value\n\t\t\tthis.internals?.setFormValue(formValue)\n\n\t\t\t// Mark as dirty if value changes from initial value\n\t\t\tif (this.hasUpdated) {\n\t\t\t\tthis._dirty = true\n\t\t\t}\n\n\t\t\t// Check validity based on validation strategy\n\t\t\tif (this.hasUpdated) {\n\t\t\t\tthis.checkValidity()\n\t\t\t}\n\t\t}\n\n\t\t// When open state changes, setup or cleanup the dropdown positioner\n\t\tif (changedProps.has('isOpen')) {\n\t\t\tif (this.isOpen) {\n\t\t\t\tthis.positionDropdown()\n\t\t\t} else {\n\t\t\t\tthis.cleanupPositioner?.()\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Determines if validation errors should be shown based on current state\n\t * and validation strategy\n\t */\n\tprivate shouldShowValidation(forceValidation = false): boolean {\n\t\tif (forceValidation) return true\n\n\t\tswitch (this.validateOn) {\n\t\t\tcase 'always':\n\t\t\t\treturn true\n\t\t\tcase 'touched':\n\t\t\t\treturn this._touched\n\t\t\tcase 'dirty':\n\t\t\t\treturn this._dirty\n\t\t\tcase 'submitted':\n\t\t\t\treturn this._submitted\n\t\t\tdefault:\n\t\t\t\treturn this._touched\n\t\t}\n\t}\n\n\tprivate syncSelection() {\n\t\tif (this.multi) {\n\t\t\t// Read directly from the BehaviorSubject to avoid string conversion issues\n\t\t\tconst selectedValues = this._selectedValues$.value\n\t\t\tthis.options?.forEach(o => (o.selected = selectedValues.includes(o.value))) // Update option selected state\n\t\t\tthis.valueLabel =\n\t\t\t\tselectedValues.length > 0\n\t\t\t\t\t? this.options\n\t\t\t\t\t\t\t?.filter(o => selectedValues.includes(o.value))\n\t\t\t\t\t\t\t.map(o => o.label || o.textContent || '')\n\t\t\t\t\t\t\t.join(', ') || this.placeholder\n\t\t\t\t\t: this.placeholder\n\t\t} else {\n\t\t\t// Single select - read from BehaviorSubject\n\t\t\tconst currentValue = this._selectedValue$.value\n\t\t\tthis.options?.forEach(o => {\n\t\t\t\t// Set selected property on each option based on matching value\n\t\t\t\to.selected = o.value === currentValue\n\t\t\t})\n\t\t\tconst selectedOption = this.options?.find(o => o.value === currentValue)\n\t\t\tthis.valueLabel = selectedOption ? (selectedOption.label || selectedOption.textContent || '') : this.placeholder\n\t\t}\n\t}\n\n\tprivate setupOptionsAccessibility() {\n\t\tthis.options?.forEach((option, index) => {\n\t\t\toption.setAttribute('role', 'option')\n\t\t\tif (!option.id) {\n\t\t\t\toption.id = `${this.id}-option-${index}`\n\t\t\t}\n\n\t\t\t// Set tabindex to -1 so they're focusable programmatically but not in the tab order\n\t\t\toption.tabIndex = -1\n\t\t\tconst selectedValues = Array.isArray(this.value) ? this.value : this.value ? this.value.split(',') : []\n\n\t\t\toption.setAttribute(\n\t\t\t\t'aria-selected',\n\t\t\t\tString(this.multi ? selectedValues.includes(option.value) : option.value === this.value),\n\t\t\t)\n\t\t})\n\t}\n\n\tprivate async positionDropdown() {\n\t\tconst reference = this.renderRoot.querySelector('.trigger') as HTMLElement\n\t\tif (!reference || !this.ul) return\n\n\t\tthis.cleanupPositioner = autoUpdate(reference, this.ul, async () => {\n\t\t\t// Get viewport dimensions\n\t\t\tconst viewportHeight = window.innerHeight\n\t\t\tconst triggerRect = reference.getBoundingClientRect()\n\n\t\t\t// Calculate available space below and above\n\t\t\tconst spaceBelow = viewportHeight - triggerRect.bottom\n\t\t\tconst spaceAbove = triggerRect.top\n\n\t\t\t// Calculate max height - use 75% of the largest available space, but at least 150px\n\t\t\tconst maxHeight = Math.max(Math.max(spaceBelow, spaceAbove) * 0.75, 150)\n\n\t\t\t// Determine if we should flip\n\t\t\tconst shouldFlip = spaceBelow < 200 && spaceAbove > spaceBelow\n\n\t\t\t// Apply max height\n\t\t\tthis.ul.style.maxHeight = `${maxHeight}px`\n\n\t\t\tconst { x, y } = await computePosition(reference, this.ul, {\n\t\t\t\tplacement: shouldFlip ? 'top-start' : 'bottom-start',\n\t\t\t\tmiddleware: [offset(5), flip(), shift({ padding: 5 })],\n\t\t\t})\n\n\t\t\tObject.assign(this.ul.style, {\n\t\t\t\tleft: `${x}px`,\n\t\t\t\ttop: `${y}px`,\n\t\t\t\tposition: 'absolute',\n\t\t\t\twidth: `${reference.offsetWidth}px`, // Match the width of the trigger\n\t\t\t})\n\t\t})\n\t}\n\n\tprivate handleKeyDown = (e: KeyboardEvent) => {\n\t\t// Don't handle keyboard events when disabled\n\t\tif (this.disabled) {\n\t\t\treturn\n\t\t}\n\n\t\tif (!this.isOpen) {\n\t\t\tif (['Enter', ' ', 'ArrowDown'].includes(e.key)) {\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.openDropdown(false)\n\t\t\t}\n\t\t\treturn\n\t\t}\n\n\t\t// Find current focused option\n\t\tconst options = Array.from(this.options || [])\n\t\tconst current = options.findIndex(o => o.id === this._focusedOptionId) ?? -1\n\n\t\tswitch (e.key) {\n\t\t\tcase 'Escape':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.closeDropdown()\n\t\t\t\tbreak\n\t\t\tcase 'ArrowDown':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, Math.min(current + 1, options.length - 1))\n\t\t\t\tbreak\n\t\t\tcase 'ArrowUp':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, Math.max(current - 1, 0))\n\t\t\t\tbreak\n\t\t\tcase 'Home':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, 0)\n\t\t\t\tbreak\n\t\t\tcase 'End':\n\t\t\t\te.preventDefault()\n\t\t\t\tthis.focusOption(options, options.length - 1)\n\t\t\t\tbreak\n\t\t\tcase 'Enter':\n\t\t\tcase ' ':\n\t\t\t\te.preventDefault()\n\t\t\t\tif (this._focusedOptionId) {\n\t\t\t\t\tconst focusedOption = options.find(opt => opt.id === this._focusedOptionId)\n\t\t\t\t\tif (focusedOption) {\n\t\t\t\t\t\tthis.handleOptionSelect(focusedOption.value)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\tcase 'Tab':\n\t\t\t\tthis.closeDropdown()\n\t\t\t\tbreak\n\t\t}\n\t}\n\n\tprivate focusOption(options: SchmancyOption[], index: number) {\n\t\tconst option = options[index]\n\t\tif (option) {\n\t\t\toption.focus()\n\t\t\tthis._focusedOptionId = option.id\n\n\t\t\t// Update aria-activedescendant on the combobox\n\t\t\tconst combobox = this.renderRoot.querySelector('.trigger')\n\t\t\tif (combobox) {\n\t\t\t\tcombobox.setAttribute('aria-activedescendant', option.id)\n\t\t\t}\n\n\t\t\t// Ensure option is visible in the scrollable area\n\t\t\tif (this.ul && option.offsetTop !== undefined) {\n\t\t\t\t// Get position info\n\t\t\t\tconst optionTop = option.offsetTop\n\t\t\t\tconst optionHeight = option.offsetHeight\n\t\t\t\tconst scrollTop = this.ul.scrollTop\n\t\t\t\tconst ulHeight = this.ul.clientHeight\n\n\t\t\t\t// Scroll into view if needed\n\t\t\t\tif (optionTop < scrollTop) {\n\t\t\t\t\tthis.ul.scrollTop = optionTop\n\t\t\t\t} else if (optionTop + optionHeight > scrollTop + ulHeight) {\n\t\t\t\t\tthis.ul.scrollTop = optionTop + optionHeight - ulHeight\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate async openDropdown(report = false) {\n\t\t// Don't open if disabled\n\t\tif (this.disabled) {\n\t\t\treturn\n\t\t}\n\n\t\t// Don't mark as touched on opening - we'll do that on closing\n\t\t// so errors only show after interaction is complete\n\n\t\tthis.isOpen = true\n\t\tawait this.updateComplete\n\n\t\t// Focus first or selected option\n\t\tconst options = Array.from(this.options || [])\n\t\tconst selectedIndex = this.multi ? 0 : options.findIndex(o => o.value === String(this.value))\n\n\t\tthis.focusOption(options, Math.max(selectedIndex, 0))\n\n\t\t// Don't automatically validate when opening\n\t\t// Only validate if explicitly requested (like from a form submission)\n\t\tif (report) this.reportValidity()\n\t}\n\n\tprivate closeDropdown() {\n\t\t// Only mark as touched if the user actually interacted with the component\n\t\t// and made a selection or explicitly closed it without selecting\n\t\tif (this._userInteracted) {\n\t\t\tthis._touched = true\n\t\t}\n\n\t\tthis.isOpen = false\n\t\tthis._focusedOptionId = ''\n\n\t\t// Update combobox to remove aria-activedescendant\n\t\tconst combobox = this.renderRoot.querySelector<HTMLElement>('.trigger')\n\t\tif (combobox) {\n\t\t\tcombobox.removeAttribute('aria-activedescendant')\n\t\t\tcombobox?.focus()\n\t\t}\n\n\t\t// Only check validity when closing if the user has actually interacted\n\t\t// with the component and validation should be shown\n\t\tif (this._userInteracted && this.shouldShowValidation()) {\n\t\t\tthis.checkValidity()\n\t\t}\n\t}\n\n\tprivate _setupReactivePipelines() {\n\t\t// Listen for option-select events from child options\n\t\tfromEvent<CustomEvent>(this, 'option-select')\n\t\t\t.pipe(\n\t\t\t\ttap((e) => {\n\t\t\t\t\te.stopPropagation() // Prevent event from bubbling further\n\t\t\t\t\tconst option = this.options.find(o => o.value === e.detail.value)\n\t\t\t\t\tif (option) {\n\t\t\t\t\t\tthis._optionSelect$.next(option)\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Handle option selection through reactive pipeline\n\t\tthis._optionSelect$\n\t\t\t.pipe(\n\t\t\t\twithLatestFrom(this._selectedValue$, this._selectedValues$),\n\t\t\t\ttap(([option, _, currentValues]) => {\n\t\t\t\t\tthis._userInteracted = true\n\t\t\t\t\tthis._touched = true\n\t\t\t\t\tthis._dirty = true\n\n\t\t\t\t\tif (this.multi) {\n\t\t\t\t\t\tconst index = currentValues.indexOf(option.value)\n\t\t\t\t\t\tconst newValues = index > -1\n\t\t\t\t\t\t\t? [...currentValues.slice(0, index), ...currentValues.slice(index + 1)]\n\t\t\t\t\t\t\t: [...currentValues, option.value]\n\t\t\t\t\t\tthis._selectedValues$.next(newValues)\n\n\t\t\t\t\t\t// Update display label\n\t\t\t\t\t\tthis.valueLabel = newValues.length > 0\n\t\t\t\t\t\t\t? this.options\n\t\t\t\t\t\t\t\t\t.filter(o => newValues.includes(o.value))\n\t\t\t\t\t\t\t\t\t.map(o => o.label || o.textContent || '')\n\t\t\t\t\t\t\t\t\t.join(', ')\n\t\t\t\t\t\t\t: this.placeholder\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Single select\n\t\t\t\t\t\tthis._selectedValue$.next(option.value)\n\t\t\t\t\t\tthis.valueLabel = option.label || option.textContent || this.placeholder\n\t\t\t\t\t\tthis.closeDropdown()\n\t\t\t\t\t}\n\n\t\t\t\t\t// Update the option's accessibility state\n\t\t\t\t\tthis.setupOptionsAccessibility()\n\n\t\t\t\t\t// Dispatch change event\n\t\t\t\t\tthis._fireChangeEvent()\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Options management pipeline - bind pointerdown events exactly like autocomplete\n\t\tthis._options$\n\t\t\t.pipe(\n\t\t\t\ttap((options) => {\n\t\t\t\t\toptions.forEach((option, index) => {\n\t\t\t\t\t\toption.setAttribute('role', 'option')\n\t\t\t\t\t\toption.tabIndex = -1\n\t\t\t\t\t\tif (!option.id) {\n\t\t\t\t\t\t\toption.id = `${this.id}-option-${index}`\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// Use data-event-bound to prevent duplicate bindings\n\t\t\t\t\t\tif (!option.hasAttribute('data-event-bound')) {\n\t\t\t\t\t\t\tfromEvent(option, 'pointerdown').pipe(\n\t\t\t\t\t\t\t\ttap(e => {\n\t\t\t\t\t\t\t\t\te.preventDefault() // Prevent blur from firing\n\t\t\t\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t\t\t\t\t).subscribe(() => this._optionSelect$.next(option))\n\t\t\t\t\t\t\toption.setAttribute('data-event-bound', 'true')\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\n\t\t// Selection sync pipeline - sync selected states with value changes\n\t\tcombineLatest([this._selectedValue$, this._selectedValues$, this._options$])\n\t\t\t.pipe(\n\t\t\t\ttap(([singleValue, multiValues, options]) => {\n\t\t\t\t\tif (options.length === 0) return\n\n\t\t\t\t\tif (this.multi) {\n\t\t\t\t\t\toptions.forEach(option => {\n\t\t\t\t\t\t\toption.selected = multiValues.includes(option.value)\n\t\t\t\t\t\t})\n\t\t\t\t\t} else {\n\t\t\t\t\t\toptions.forEach(option => {\n\t\t\t\t\t\t\toption.selected = option.value === singleValue\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t\ttakeUntil(this.disconnecting)\n\t\t\t)\n\t\t\t.subscribe()\n\t}\n\n\tprivate handleOptionSelect(value: string) {\n\t\t// This method is now called from keyboard navigation only\n\t\tconst option = this.options.find(o => o.value === value)\n\t\tif (option) {\n\t\t\tthis._optionSelect$.next(option)\n\t\t}\n\t}\n\n\tprivate _fireChangeEvent() {\n\t\t// Get the current value based on multi/single mode\n\t\tconst value = this.multi ? this._selectedValues$.value : this._selectedValue$.value\n\n\t\t// Dispatch only one change event with the value in detail\n\t\tthis.dispatchEvent(\n\t\t\tnew CustomEvent<SchmancySelectChangeEvent['detail']>('change', {\n\t\t\t\tdetail: { value },\n\t\t\t\tbubbles: true,\n\t\t\t\tcomposed: true,\n\t\t\t}),\n\t\t)\n\n\t\t// Then check validity (only show error if validation should be shown)\n\t\tthis.checkValidity()\n\t}\n\n\tpublic checkValidity(): boolean {\n\t\t// Disabled fields are always valid\n\t\tif (this.disabled) {\n\t\t\treturn true\n\t\t}\n\n\t\t// Determine if the select is empty based on whether it's multi-select or single-select\n\t\tconst isEmpty = this.multi ? (Array.isArray(this.value) ? this.value.length === 0 : !this.value) : !this.value\n\n\t\t// Check if the value is valid (not empty when required)\n\t\tconst isValid = !(this.required && isEmpty)\n\n\t\t// Set the validity state\n\t\tthis.isValid = isValid\n\n\t\tif (!this.isValid) {\n\t\t\tthis.validationMessage = 'Please select an option.'\n\t\t\tthis.internals?.setValidity({ valueMissing: true }, 'Please select an option.', this.inputRef)\n\t\t} else {\n\t\t\t// Clear validation message\n\t\t\tthis.validationMessage = ''\n\t\t\tthis.internals?.setValidity({})\n\t\t}\n\n\t\t// Update the input component to reflect our validation state\n\t\tif (this.inputRef && this.hasUpdated) {\n\t\t\tconst showError = !this.isValid && this.shouldShowValidation()\n\t\t\tthis.inputRef.error = showError\n\t\t\tthis.inputRef.hint = showError ? this.validationMessage : this.hint\n\t\t}\n\n\t\treturn this.isValid\n\t}\n\n\tpublic reportValidity(): boolean {\n\t\t// Force validation display regardless of validation strategy\n\t\tconst valid = this.checkValidity()\n\n\t\t// Force the input to show validation errors\n\t\tif (this.inputRef) {\n\t\t\t// Set the input's error state\n\t\t\tthis.inputRef.error = !valid\n\t\t\tthis.inputRef.hint = !valid ? this.validationMessage : this.hint\n\n\t\t\t// If invalid and not already open, automatically open the dropdown to show options\n\t\t\tif (!valid && !this.isOpen) {\n\t\t\t\t// Open the dropdown but don't mark as user interaction yet\n\t\t\t\t// This helps users immediately see available options when validation fails\n\t\t\t\tthis.openDropdown(false)\n\t\t\t}\n\n\t\t\t// Only call reportValidity on the input if invalid to show the native popup\n\t\t\tif (!valid) {\n\t\t\t\tthis.inputRef.reportValidity()\n\t\t\t}\n\t\t}\n\n\t\treturn valid\n\t}\n\n\tpublic setCustomValidity(message: string) {\n\t\tthis.validationMessage = message\n\t\tif (message) {\n\t\t\tthis.isValid = false\n\t\t\tthis.internals?.setValidity({ customError: true }, message, this.inputRef)\n\t\t} else {\n\t\t\tthis.isValid = true\n\t\t\tthis.internals?.setValidity({})\n\t\t}\n\n\t\t// Update input if needed\n\t\tif (this.inputRef && this.shouldShowValidation()) {\n\t\t\tthis.inputRef.error = !this.isValid\n\t\t\tthis.inputRef.hint = !this.isValid ? this.validationMessage : this.hint\n\t\t}\n\t}\n\n\tpublic reset() {\n\t\t// Reset to initial value\n\t\tthis.value = this.defaultValue\n\t\tthis.valueLabel = this.placeholder\n\t\tthis.isValid = true\n\t\tthis.validationMessage = ''\n\t\tthis._touched = false\n\t\tthis._dirty = false\n\t\tthis._submitted = false\n\t\tthis._userInteracted = false\n\t\tthis.internals?.setValidity({})\n\n\t\tif (this.inputRef) {\n\t\t\tthis.inputRef.error = false\n\t\t\tthis.inputRef.hint = this.hint\n\t\t}\n\t}\n\n\trender(): TemplateResult {\n\t\t// Determine if we should show errors based on the validation strategy and interaction\n\t\t// Never show errors on initial render or if the dropdown is open\n\t\tconst showErrors = !this.isValid && this.shouldShowValidation() && !this.isOpen\n\n\t\t// Add caret icon based on open state\n\t\tconst caretIcon = this.isOpen\n\t\t\t? html`<span class=\"absolute right-3 top-1/2 transform -translate-y-1/2\">▲</span>`\n\t\t\t: html`<span class=\"absolute right-3 top-1/2 transform -translate-y-1/2\">▼</span>`\n\n\t\treturn html`\n\t\t\t<div class=\"relative ${this.disabled ? 'opacity-60 cursor-not-allowed' : ''}\">\n\t\t\t\t<sch-input\n\t\t\t\t\t.name=${this.name}\n\t\t\t\t\ttabIndex=${this.disabled ? '-1' : '0'}\n\t\t\t\t\tclass=\"trigger\"\n\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\taria-haspopup=\"listbox\"\n\t\t\t\t\taria-expanded=${this.isOpen}\n\t\t\t\t\taria-controls=\"options\"\n\t\t\t\t\taria-autocomplete=\"none\"\n\t\t\t\t\taria-required=${this.required}\n\t\t\t\t\taria-activedescendant=${this._focusedOptionId || undefined}\n\t\t\t\t\taria-disabled=${this.disabled}\n\t\t\t\t\t.label=${this.label}\n\t\t\t\t\t.placeholder=${this.placeholder}\n\t\t\t\t\t.value=${this.valueLabel}\n\t\t\t\t\t.required=${this.required}\n\t\t\t\t\t.disabled=${this.disabled}\n\t\t\t\t\t.hint=${showErrors ? this.validationMessage : this.hint}\n\t\t\t\t\t.error=${showErrors}\n\t\t\t\t\t.validateOn=${this.validateOn}\n\t\t\t\t\t.size=${this.size}\n\t\t\t\t\treadonly\n\t\t\t\t\tclickable\n\t\t\t\t\t@click=${(e: MouseEvent) => {\n\t\t\t\t\t\t// Don't process clicks if disabled\n\t\t\t\t\t\tif (this.disabled) {\n\t\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\t\te.stopPropagation()\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// On first click, don't count this as user interaction yet\n\t\t\t\t\t\tif (!this.isOpen) {\n\t\t\t\t\t\t\t// Open without triggering validation - we'll validate when they close\n\t\t\t\t\t\t\tthis.openDropdown(false)\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Mark as interacted when they close the dropdown\n\t\t\t\t\t\t\tthis._userInteracted = true\n\t\t\t\t\t\t\tthis.closeDropdown()\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t${caretIcon}\n\t\t\t\t</sch-input>\n\n\t\t\t\t<!-- Overlay for capturing clicks outside when dropdown is open -->\n\t\t\t\t${this.isOpen\n\t\t\t\t\t? html` <div class=\"fixed inset-0 z-10\" @click=${this.closeDropdown} tabindex=\"-1\" aria-hidden=\"true\"></div> `\n\t\t\t\t\t: ''}\n\n\t\t\t\t<ul\n\t\t\t\t\tid=\"options\"\n\t\t\t\t\trole=\"listbox\"\n\t\t\t\t\taria-multiselectable=${this.multi}\n\t\t\t\t\tclass=${classMap({\n\t\t\t\t\t\t'absolute min-w-full w-full z-20 mt-1 rounded-md shadow-lg': true,\n\t\t\t\t\t\thidden: !this.isOpen,\n\t\t\t\t\t})}\n\t\t\t\t\t${color({\n\t\t\t\t\t\tbgColor: SchmancyTheme.sys.color.surface.low,\n\t\t\t\t\t\tcolor: SchmancyTheme.sys.color.surface.on,\n\t\t\t\t\t})}\n\t\t\t\t>\n\t\t\t\t\t<slot\n\t\t\t\t\t\t@slotchange=${() => {\n\t\t\t\t\t\t\tthis._options$.next(this.options)\n\t\t\t\t\t\t\t// Sync selection state when options re-render\n\t\t\t\t\t\t\tthis.syncSelection()\n\t\t\t\t\t\t}}\n\t\t\t\t\t></slot>\n\t\t\t\t</ul>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\n// Don't export 'select' here as it conflicts with the store's select decorator\n// export const select = SchmancySelect\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-select': SchmancySelect\n\t}\n}\n"],"names":["SchmancySelect","$LitElement","css","super","this","required","disabled","placeholder","multi","label","hint","validateOn","size","isOpen","valueLabel","isValid","validationMessage","defaultValue","_options$","BehaviorSubject","_selectedValue$","_selectedValues$","_optionSelect$","Subject","_userInteracted","_touched","_dirty","_submitted","_focusedOptionId","formSubmitHandler","checkValidity","formResetHandler","reset","handleKeyDown","e","includes","key","preventDefault","openDropdown","options","Array","from","current","findIndex","o","id","closeDropdown","focusOption","Math","min","length","max","focusedOption","find","opt","handleOptionSelect","value","internals","attachInternals","join","val","values","isArray","String","split","map","v","trim","filter","Boolean","next","form","connectedCallback","random","toString","substring","fromEvent","pipe","takeUntil","disconnecting","subscribe","_setupReactivePipelines","inputRef","error","disconnectedCallback","cleanupPositioner","syncSelection","setupOptionsAccessibility","changedProps","updated","has","formValue","setFormValue","hasUpdated","positionDropdown","forceValidation","selectedValues","forEach","selected","textContent","currentValue","selectedOption","option","index","setAttribute","tabIndex","reference","renderRoot","querySelector","ul","autoUpdate","async","viewportHeight","window","innerHeight","triggerRect","getBoundingClientRect","spaceBelow","bottom","spaceAbove","top","maxHeight","shouldFlip","style","x","y","computePosition","placement","middleware","offset","flip","shift","padding","Object","assign","left","position","width","offsetWidth","focus","combobox","offsetTop","optionTop","optionHeight","offsetHeight","scrollTop","ulHeight","clientHeight","report","updateComplete","selectedIndex","reportValidity","removeAttribute","shouldShowValidation","tap","stopPropagation","detail","withLatestFrom","_","currentValues","indexOf","newValues","slice","_fireChangeEvent","hasAttribute","combineLatest","singleValue","multiValues","dispatchEvent","CustomEvent","bubbles","composed","isEmpty","setValidity","valueMissing","showError","valid","message","customError","render","showErrors","caretIcon","html","name","classMap","hidden","color","bgColor","SchmancyTheme","sys","surface","low","on","formAssociated","__decorateClass","property","type","prototype","reflect","state","query","queryAssignedElements","flatten","customElement"],"mappings":"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"}
package/dist/select.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./select-DzhUQc3r.cjs");Object.defineProperty(exports,"SchmancySelect",{enumerable:!0,get:()=>e.SchmancySelect});
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./select-DFpxKCjD.cjs");Object.defineProperty(exports,"SchmancySelect",{enumerable:!0,get:()=>e.SchmancySelect});
2
2
  //# sourceMappingURL=select.cjs.map
package/dist/select.js CHANGED
@@ -1,4 +1,4 @@
1
- import { S } from "./select-DcvpJkwX.js";
1
+ import { S } from "./select-D7Na7bJk.js";
2
2
  export {
3
3
  S as SchmancySelect
4
4
  };
@@ -2,9 +2,9 @@ import { fromEvent as d, tap as p, of as w, take as k, merge as E, takeUntil as
2
2
  import { classMap as y } from "lit/directives/class-map.js";
3
3
  import "lit/directives/style-map.js";
4
4
  import { customElement as g, property as c, queryAssignedElements as $ } from "lit/decorators.js";
5
- import { T as S } from "./tailwind.mixin-R2xLfpws.js";
5
+ import { T as S } from "./tailwind.mixin-BMDZASqc.js";
6
6
  import { css as C, html as f } from "lit";
7
- import { $ as A } from "./litElement.mixin-CEPZ0lJP.js";
7
+ import { $ as A } from "./litElement.mixin-GWkzUR9Y.js";
8
8
  import { cache as O } from "lit/directives/cache.js";
9
9
  import { ifDefined as v } from "lit/directives/if-defined.js";
10
10
  import { createRef as B, ref as F } from "lit/directives/ref.js";
@@ -141,4 +141,4 @@ a([c({ type: String, reflect: !0 })], n.prototype, "uid", 2), a([c({ type: Boole
141
141
  }
142
142
  };
143
143
  })], n.prototype, "onOpenChange", 1), n = a([g("schmancy-sheet")], n);
144
- //# sourceMappingURL=sheet-DH0GSs0F.js.map
144
+ //# sourceMappingURL=sheet-C22lei2O.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"sheet-DH0GSs0F.js","sources":["../src/sheet/header.ts","../src/sheet/sheet.ts","../src/sheet/hook.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n@customElement('schmancy-sheet-header')\nexport default class SchmancySheetHeader extends TailwindElement(css``) {\n\trender() {\n\t\treturn html`\n\t\t\t<sch-flex class=\"absolute top-0 left-0 md:left-[unset] md:right-0\">\n\t\t\t\t<div class=\"block md:hidden flex-1 justify-start items-start\">\n\t\t\t\t\t<slot name=\"back\">\n\t\t\t\t\t\t<schmancy-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<span class=\"text-[24px]\">&#8592; </span>\n\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"hidden md:block flex-1 justify-end items-end\">\n\t\t\t\t\t<slot name=\"actions\">\n\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\t\t\t</sch-flex>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet-header': SchmancySheetHeader\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { fromEvent, merge, of, take, takeUntil, tap } from 'rxjs'\nimport { on } from './hook'\nimport style from './sheet.scss?inline'\nimport {\n\tSchmancySheetPosition,\n\tSheetHereMorty,\n\tSheetWhereAreYouRicky,\n\tSheetWhereAreYouRickyEvent,\n\tsheet,\n} from './sheet.service'\n\n@customElement('schmancy-sheet')\nexport default class SchmancySheet extends $LitElement(style) {\n\t@property({ type: String, reflect: true }) uid!: string\n\t@property({ type: Boolean, reflect: true }) open = false\n\t@property({ type: String, reflect: true }) header: 'hidden' | 'visible' = 'visible'\n\t@property({ type: String, reflect: true }) position: SchmancySheetPosition = SchmancySheetPosition.Side\n\t@property({ type: Boolean, reflect: true }) persist = false\n\t@property({ type: Boolean, reflect: true }) lock = false\n\t@property({ type: Boolean, reflect: true }) handleHistory = true\n\t@property({ type: String, reflect: true }) title = ''\n\n\t// Use ref directive instead of @query\n\tprivate sheetRef = createRef<HTMLDivElement>()\n\t@queryAssignedElements({ flatten: true }) private assignedElements!: HTMLElement[]\n\n\t@property() focusAttribute = 'autofocus'\n\tprivate lastFocusedElement: HTMLElement | null = null\n\n\t@on('open')\n\tonOpenChange(_oldValue: boolean, newValue: boolean) {\n\t\tif (newValue) {\n\t\t\tthis.lastFocusedElement = document.activeElement as HTMLElement\n\t\t\t// Use native inert attribute to prevent focus outside sheet\n\t\t\tthis.setBackgroundInert(true)\n\t\t\tthis.focus()\n\t\t} else {\n\t\t\tthis.setBackgroundInert(false)\n\t\t\tthis.lastFocusedElement?.focus()\n\t\t\tthis.lastFocusedElement = null\n\t\t}\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupEventListeners()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.disconnecting.next(true)\n\t}\n\n\tprivate setupEventListeners() {\n\t\t// Handle browser back button - only if handleHistory is true\n\t\tconst popState$ = this.handleHistory\n\t\t\t? fromEvent<PopStateEvent>(window, 'popstate').pipe(\n\t\t\t\t\ttap(e => {\n\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\tthis.closeSheet()\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t: of(null).pipe(take(0)) // Empty observable if handleHistory is false\n\n\t\t// Handle ESC key - listen on the sheet element for better event capture\n\t\tconst keyUp$ = fromEvent<KeyboardEvent>(this, 'keydown').pipe(\n\t\t\ttap(event => {\n\t\t\t\tif (event.key === 'Escape' && !this.lock && this.open) {\n\t\t\t\t\tevent.preventDefault()\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t\tsheet.dismiss(this.uid)\n\t\t\t\t}\n\t\t\t}),\n\t\t)\n\n\t\t// Handle inter-component communication\n\t\tconst rickyComm$ = fromEvent<SheetWhereAreYouRickyEvent>(window, SheetWhereAreYouRicky).pipe(\n\t\t\ttap(e => {\n\t\t\t\tif (e.detail.uid === this.uid)\n\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SheetHereMorty, {\n\t\t\t\t\t\t\tdetail: { sheet: this },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t}),\n\t\t)\n\n\t\tmerge(popState$, keyUp$, rickyComm$).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\tprivate setBackgroundInert(inert: boolean) {\n\t\t// Get all sibling elements and make them inert\n\t\tconst parent = this.parentElement\n\t\tif (parent) {\n\t\t\tArray.from(parent.children).forEach(child => {\n\t\t\t\tif (child !== this && child instanceof HTMLElement) {\n\t\t\t\t\tif (inert) {\n\t\t\t\t\t\tchild.setAttribute('inert', '')\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchild.removeAttribute('inert')\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\n\t\t// Also handle body's direct children if sheet is attached to body\n\t\tif (this.parentElement === document.body) {\n\t\t\tArray.from(document.body.children).forEach(child => {\n\t\t\t\tif (child !== this && child !== parent && child instanceof HTMLElement) {\n\t\t\t\t\tif (inert) {\n\t\t\t\t\t\tchild.setAttribute('inert', '')\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchild.removeAttribute('inert')\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tsetIsSheetShown(isShown: boolean) {\n\t\tthis.sheetRef.value?.setAttribute('aria-hidden', String(!isShown))\n\t\tthis.sheetRef.value?.setAttribute('aria-modal', String(isShown))\n\t}\n\n\tcloseSheet() {\n\t\tthis.open = false\n\t\tthis.dispatchEvent(new CustomEvent('close'))\n\t}\n\n\tprivate getFocusElement(): HTMLElement | null {\n\t\tconst selector = `[${this.focusAttribute}]`\n\t\treturn (this.assignedElements.find(el => el.matches(selector) || el.querySelector(selector)) as HTMLElement) ?? null\n\t}\n\n\toverride focus() {\n\t\t// First try native autofocus attribute\n\t\tconst autofocusElement = this.querySelector('[autofocus]') as HTMLElement\n\t\tif (autofocusElement) {\n\t\t\tautofocusElement.focus()\n\t\t\treturn\n\t\t}\n\n\t\t// Fallback to custom focus attribute\n\t\tthis.getFocusElement()?.focus()\n\t}\n\n\tprivate handleOverlayClick = (e: Event) => {\n\t\te.stopPropagation()\n\t\tif (!this.lock) {\n\t\t\tsheet.dismiss(this.uid)\n\t\t}\n\t}\n\n\tprivate handleHeaderDismiss = (e: CustomEvent) => {\n\t\te.stopPropagation()\n\t\tsheet.dismiss(this.uid)\n\t}\n\n\trender() {\n\t\tconst sheetClasses = {\n\t\t\tsheet: true,\n\t\t\t'sheet--open': this.open,\n\t\t\t'sheet--locked': this.lock,\n\t\t}\n\n\t\tconst overlayClasses = {\n\t\t\toverlay: true,\n\t\t\t'overlay--interactive': !this.lock,\n\t\t}\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${classMap(sheetClasses)}\n\t\t\t\trole=\"dialog\"\n\t\t\t\taria-labelledby=${ifDefined(this.header !== 'hidden' ? 'sheet-title' : undefined)}\n\t\t\t\taria-hidden=${!this.open}\n\t\t\t\taria-modal=${this.open}\n\t\t\t\ttabindex=\"0\"\n\t\t\t\t${ref(this.sheetRef)}\n\t\t\t>\n\t\t\t\t<div class=${classMap(overlayClasses)} @click=${this.lock ? undefined : this.handleOverlayClick}></div>\n\t\t\t\t<schmancy-grid\n\t\t\t\t\trows=${this.header === 'hidden' ? '1fr' : 'auto 1fr'}\n\t\t\t\t\tclass=\"content w-full\"\n\t\t\t\t\tdata-position=${this.position}\n\t\t\t\t>\n\t\t\t\t\t${cache(\n\t\t\t\t\t\tthis.header !== 'hidden'\n\t\t\t\t\t\t\t? html`<schmancy-sheet-header\n\t\t\t\t\t\t\t\t\tclass=\"sticky top-0 z-50 w-full\"\n\t\t\t\t\t\t\t\t\t@dismiss=${this.handleHeaderDismiss}\n\t\t\t\t\t\t\t\t\tid=\"sheet-title\"\n\t\t\t\t\t\t\t\t\ttitle=${ifDefined(this.title || undefined)}\n\t\t\t\t\t\t\t\t></schmancy-sheet-header>`\n\t\t\t\t\t\t\t: '',\n\t\t\t\t\t)}\n\n\t\t\t\t\t<schmancy-surface rounded=\"left\" fill=\"all\" id=\"body\" class=\"overflow-auto\" type=\"surface\">\n\t\t\t\t\t\t<schmancy-scroll> <slot></slot></schmancy-scroll>\n\t\t\t\t\t</schmancy-surface>\n\t\t\t\t</schmancy-grid>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet': SchmancySheet\n\t}\n}\n","// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n// @watch('propName')\n// handlePropChange(oldValue, newValue) {\n// ...\n// }\n//\ninterface WatchOptions {\n\twaitUntilFirstUpdate?: boolean\n}\n\nexport function on(propName: string, options?: WatchOptions) {\n\treturn (protoOrDescriptor: any, name: string): any => {\n\t\tconst { willUpdate } = protoOrDescriptor\n\n\t\toptions = Object.assign({ waitUntilFirstUpdate: false }, options) as WatchOptions\n\n\t\tprotoOrDescriptor.willUpdate = function (changedProps: Map<string, any>) {\n\t\t\twillUpdate.call(this, changedProps)\n\n\t\t\tif (changedProps.has(propName)) {\n\t\t\t\tconst oldValue = changedProps.get(propName)\n\t\t\t\tconst newValue = this[propName]\n\n\t\t\t\tif (oldValue !== newValue) {\n\t\t\t\t\tif (!options?.waitUntilFirstUpdate || this.hasUpdated) {\n\t\t\t\t\t\tthis[name].call(this, oldValue, newValue)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"],"names":["SchmancySheetHeader","TailwindElement","css","render","html","this","dispatchEvent","CustomEvent","bubbles","composed","customElement","SchmancySheet","$LitElement","constructor","super","arguments","open","header","position","SchmancySheetPosition","Side","persist","lock","handleHistory","title","sheetRef","createRef","focusAttribute","lastFocusedElement","handleOverlayClick","e","stopPropagation","sheet","dismiss","uid","handleHeaderDismiss","_oldValue","newValue","document","activeElement","setBackgroundInert","focus","connectedCallback","setupEventListeners","disconnectedCallback","disconnecting","next","popState$","fromEvent","window","pipe","tap","preventDefault","closeSheet","of","take","keyUp$","event","key","rickyComm$","SheetWhereAreYouRicky","detail","SheetHereMorty","merge","takeUntil","subscribe","inert","parent","parentElement","Array","from","children","forEach","child","HTMLElement","setAttribute","removeAttribute","body","isShown","value","String","getFocusElement","selector","assignedElements","find","el","matches","querySelector","autofocusElement","sheetClasses","overlayClasses","overlay","classMap","ifDefined","ref","cache","propName","options","__decorateClass","property","type","reflect","prototype","Boolean","queryAssignedElements","flatten","protoOrDescriptor","name","willUpdate","Object","assign","waitUntilFirstUpdate","changedProps","call","has","oldValue","get","hasUpdated"],"mappings":"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"}
1
+ {"version":3,"file":"sheet-C22lei2O.js","sources":["../src/sheet/header.ts","../src/sheet/sheet.ts","../src/sheet/hook.ts"],"sourcesContent":["import { TailwindElement } from '@mixins/index'\nimport { css, html } from 'lit'\nimport { customElement } from 'lit/decorators.js'\n\n@customElement('schmancy-sheet-header')\nexport default class SchmancySheetHeader extends TailwindElement(css``) {\n\trender() {\n\t\treturn html`\n\t\t\t<sch-flex class=\"absolute top-0 left-0 md:left-[unset] md:right-0\">\n\t\t\t\t<div class=\"block md:hidden flex-1 justify-start items-start\">\n\t\t\t\t\t<slot name=\"back\">\n\t\t\t\t\t\t<schmancy-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<span class=\"text-[24px]\">&#8592; </span>\n\t\t\t\t\t\t</schmancy-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\n\t\t\t\t<div class=\"hidden md:block flex-1 justify-end items-end\">\n\t\t\t\t\t<slot name=\"actions\">\n\t\t\t\t\t\t<schmancy-icon-button\n\t\t\t\t\t\t\t@click=${() => {\n\t\t\t\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\t\t\t\tnew CustomEvent('dismiss', {\n\t\t\t\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\tclose\n\t\t\t\t\t\t</schmancy-icon-button>\n\t\t\t\t\t</slot>\n\t\t\t\t</div>\n\t\t\t</sch-flex>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet-header': SchmancySheetHeader\n\t}\n}\n","import { $LitElement } from '@mixins/index'\nimport { html } from 'lit'\nimport { customElement, property, queryAssignedElements } from 'lit/decorators.js'\nimport { cache } from 'lit/directives/cache.js'\nimport { classMap } from 'lit/directives/class-map.js'\nimport { ifDefined } from 'lit/directives/if-defined.js'\nimport { createRef, ref } from 'lit/directives/ref.js'\nimport { fromEvent, merge, of, take, takeUntil, tap } from 'rxjs'\nimport { on } from './hook'\nimport style from './sheet.scss?inline'\nimport {\n\tSchmancySheetPosition,\n\tSheetHereMorty,\n\tSheetWhereAreYouRicky,\n\tSheetWhereAreYouRickyEvent,\n\tsheet,\n} from './sheet.service'\n\n@customElement('schmancy-sheet')\nexport default class SchmancySheet extends $LitElement(style) {\n\t@property({ type: String, reflect: true }) uid!: string\n\t@property({ type: Boolean, reflect: true }) open = false\n\t@property({ type: String, reflect: true }) header: 'hidden' | 'visible' = 'visible'\n\t@property({ type: String, reflect: true }) position: SchmancySheetPosition = SchmancySheetPosition.Side\n\t@property({ type: Boolean, reflect: true }) persist = false\n\t@property({ type: Boolean, reflect: true }) lock = false\n\t@property({ type: Boolean, reflect: true }) handleHistory = true\n\t@property({ type: String, reflect: true }) title = ''\n\n\t// Use ref directive instead of @query\n\tprivate sheetRef = createRef<HTMLDivElement>()\n\t@queryAssignedElements({ flatten: true }) private assignedElements!: HTMLElement[]\n\n\t@property() focusAttribute = 'autofocus'\n\tprivate lastFocusedElement: HTMLElement | null = null\n\n\t@on('open')\n\tonOpenChange(_oldValue: boolean, newValue: boolean) {\n\t\tif (newValue) {\n\t\t\tthis.lastFocusedElement = document.activeElement as HTMLElement\n\t\t\t// Use native inert attribute to prevent focus outside sheet\n\t\t\tthis.setBackgroundInert(true)\n\t\t\tthis.focus()\n\t\t} else {\n\t\t\tthis.setBackgroundInert(false)\n\t\t\tthis.lastFocusedElement?.focus()\n\t\t\tthis.lastFocusedElement = null\n\t\t}\n\t}\n\n\tconnectedCallback() {\n\t\tsuper.connectedCallback()\n\t\tthis.setupEventListeners()\n\t}\n\n\tdisconnectedCallback() {\n\t\tsuper.disconnectedCallback()\n\t\tthis.disconnecting.next(true)\n\t}\n\n\tprivate setupEventListeners() {\n\t\t// Handle browser back button - only if handleHistory is true\n\t\tconst popState$ = this.handleHistory\n\t\t\t? fromEvent<PopStateEvent>(window, 'popstate').pipe(\n\t\t\t\t\ttap(e => {\n\t\t\t\t\t\te.preventDefault()\n\t\t\t\t\t\tthis.closeSheet()\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t: of(null).pipe(take(0)) // Empty observable if handleHistory is false\n\n\t\t// Handle ESC key - listen on the sheet element for better event capture\n\t\tconst keyUp$ = fromEvent<KeyboardEvent>(this, 'keydown').pipe(\n\t\t\ttap(event => {\n\t\t\t\tif (event.key === 'Escape' && !this.lock && this.open) {\n\t\t\t\t\tevent.preventDefault()\n\t\t\t\t\tevent.stopPropagation()\n\t\t\t\t\tsheet.dismiss(this.uid)\n\t\t\t\t}\n\t\t\t}),\n\t\t)\n\n\t\t// Handle inter-component communication\n\t\tconst rickyComm$ = fromEvent<SheetWhereAreYouRickyEvent>(window, SheetWhereAreYouRicky).pipe(\n\t\t\ttap(e => {\n\t\t\t\tif (e.detail.uid === this.uid)\n\t\t\t\t\tthis.dispatchEvent(\n\t\t\t\t\t\tnew CustomEvent(SheetHereMorty, {\n\t\t\t\t\t\t\tdetail: { sheet: this },\n\t\t\t\t\t\t\tbubbles: true,\n\t\t\t\t\t\t\tcomposed: true,\n\t\t\t\t\t\t}),\n\t\t\t\t\t)\n\t\t\t}),\n\t\t)\n\n\t\tmerge(popState$, keyUp$, rickyComm$).pipe(takeUntil(this.disconnecting)).subscribe()\n\t}\n\n\tprivate setBackgroundInert(inert: boolean) {\n\t\t// Get all sibling elements and make them inert\n\t\tconst parent = this.parentElement\n\t\tif (parent) {\n\t\t\tArray.from(parent.children).forEach(child => {\n\t\t\t\tif (child !== this && child instanceof HTMLElement) {\n\t\t\t\t\tif (inert) {\n\t\t\t\t\t\tchild.setAttribute('inert', '')\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchild.removeAttribute('inert')\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\n\t\t// Also handle body's direct children if sheet is attached to body\n\t\tif (this.parentElement === document.body) {\n\t\t\tArray.from(document.body.children).forEach(child => {\n\t\t\t\tif (child !== this && child !== parent && child instanceof HTMLElement) {\n\t\t\t\t\tif (inert) {\n\t\t\t\t\t\tchild.setAttribute('inert', '')\n\t\t\t\t\t} else {\n\t\t\t\t\t\tchild.removeAttribute('inert')\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t})\n\t\t}\n\t}\n\n\tsetIsSheetShown(isShown: boolean) {\n\t\tthis.sheetRef.value?.setAttribute('aria-hidden', String(!isShown))\n\t\tthis.sheetRef.value?.setAttribute('aria-modal', String(isShown))\n\t}\n\n\tcloseSheet() {\n\t\tthis.open = false\n\t\tthis.dispatchEvent(new CustomEvent('close'))\n\t}\n\n\tprivate getFocusElement(): HTMLElement | null {\n\t\tconst selector = `[${this.focusAttribute}]`\n\t\treturn (this.assignedElements.find(el => el.matches(selector) || el.querySelector(selector)) as HTMLElement) ?? null\n\t}\n\n\toverride focus() {\n\t\t// First try native autofocus attribute\n\t\tconst autofocusElement = this.querySelector('[autofocus]') as HTMLElement\n\t\tif (autofocusElement) {\n\t\t\tautofocusElement.focus()\n\t\t\treturn\n\t\t}\n\n\t\t// Fallback to custom focus attribute\n\t\tthis.getFocusElement()?.focus()\n\t}\n\n\tprivate handleOverlayClick = (e: Event) => {\n\t\te.stopPropagation()\n\t\tif (!this.lock) {\n\t\t\tsheet.dismiss(this.uid)\n\t\t}\n\t}\n\n\tprivate handleHeaderDismiss = (e: CustomEvent) => {\n\t\te.stopPropagation()\n\t\tsheet.dismiss(this.uid)\n\t}\n\n\trender() {\n\t\tconst sheetClasses = {\n\t\t\tsheet: true,\n\t\t\t'sheet--open': this.open,\n\t\t\t'sheet--locked': this.lock,\n\t\t}\n\n\t\tconst overlayClasses = {\n\t\t\toverlay: true,\n\t\t\t'overlay--interactive': !this.lock,\n\t\t}\n\n\t\treturn html`\n\t\t\t<div\n\t\t\t\tclass=${classMap(sheetClasses)}\n\t\t\t\trole=\"dialog\"\n\t\t\t\taria-labelledby=${ifDefined(this.header !== 'hidden' ? 'sheet-title' : undefined)}\n\t\t\t\taria-hidden=${!this.open}\n\t\t\t\taria-modal=${this.open}\n\t\t\t\ttabindex=\"0\"\n\t\t\t\t${ref(this.sheetRef)}\n\t\t\t>\n\t\t\t\t<div class=${classMap(overlayClasses)} @click=${this.lock ? undefined : this.handleOverlayClick}></div>\n\t\t\t\t<schmancy-grid\n\t\t\t\t\trows=${this.header === 'hidden' ? '1fr' : 'auto 1fr'}\n\t\t\t\t\tclass=\"content w-full\"\n\t\t\t\t\tdata-position=${this.position}\n\t\t\t\t>\n\t\t\t\t\t${cache(\n\t\t\t\t\t\tthis.header !== 'hidden'\n\t\t\t\t\t\t\t? html`<schmancy-sheet-header\n\t\t\t\t\t\t\t\t\tclass=\"sticky top-0 z-50 w-full\"\n\t\t\t\t\t\t\t\t\t@dismiss=${this.handleHeaderDismiss}\n\t\t\t\t\t\t\t\t\tid=\"sheet-title\"\n\t\t\t\t\t\t\t\t\ttitle=${ifDefined(this.title || undefined)}\n\t\t\t\t\t\t\t\t></schmancy-sheet-header>`\n\t\t\t\t\t\t\t: '',\n\t\t\t\t\t)}\n\n\t\t\t\t\t<schmancy-surface rounded=\"left\" fill=\"all\" id=\"body\" class=\"overflow-auto\" type=\"surface\">\n\t\t\t\t\t\t<schmancy-scroll> <slot></slot></schmancy-scroll>\n\t\t\t\t\t</schmancy-surface>\n\t\t\t\t</schmancy-grid>\n\t\t\t</div>\n\t\t`\n\t}\n}\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t'schmancy-sheet': SchmancySheet\n\t}\n}\n","// @watch decorator\n//\n// Runs when an observed property changes, e.g. @property or @state, but before the component updates.\n//\n// To wait for an update to complete after a change occurs, use `await this.updateComplete` in the handler. To start\n// watching after the initial update/render, use `{ waitUntilFirstUpdate: true }` or `this.hasUpdated` in the handler.\n//\n// Usage:\n//\n// @watch('propName')\n// handlePropChange(oldValue, newValue) {\n// ...\n// }\n//\ninterface WatchOptions {\n\twaitUntilFirstUpdate?: boolean\n}\n\nexport function on(propName: string, options?: WatchOptions) {\n\treturn (protoOrDescriptor: any, name: string): any => {\n\t\tconst { willUpdate } = protoOrDescriptor\n\n\t\toptions = Object.assign({ waitUntilFirstUpdate: false }, options) as WatchOptions\n\n\t\tprotoOrDescriptor.willUpdate = function (changedProps: Map<string, any>) {\n\t\t\twillUpdate.call(this, changedProps)\n\n\t\t\tif (changedProps.has(propName)) {\n\t\t\t\tconst oldValue = changedProps.get(propName)\n\t\t\t\tconst newValue = this[propName]\n\n\t\t\t\tif (oldValue !== newValue) {\n\t\t\t\t\tif (!options?.waitUntilFirstUpdate || this.hasUpdated) {\n\t\t\t\t\t\tthis[name].call(this, oldValue, newValue)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n"],"names":["SchmancySheetHeader","TailwindElement","css","render","html","this","dispatchEvent","CustomEvent","bubbles","composed","customElement","SchmancySheet","$LitElement","constructor","super","arguments","open","header","position","SchmancySheetPosition","Side","persist","lock","handleHistory","title","sheetRef","createRef","focusAttribute","lastFocusedElement","handleOverlayClick","e","stopPropagation","sheet","dismiss","uid","handleHeaderDismiss","_oldValue","newValue","document","activeElement","setBackgroundInert","focus","connectedCallback","setupEventListeners","disconnectedCallback","disconnecting","next","popState$","fromEvent","window","pipe","tap","preventDefault","closeSheet","of","take","keyUp$","event","key","rickyComm$","SheetWhereAreYouRicky","detail","SheetHereMorty","merge","takeUntil","subscribe","inert","parent","parentElement","Array","from","children","forEach","child","HTMLElement","setAttribute","removeAttribute","body","isShown","value","String","getFocusElement","selector","assignedElements","find","el","matches","querySelector","autofocusElement","sheetClasses","overlayClasses","overlay","classMap","ifDefined","ref","cache","propName","options","__decorateClass","property","type","reflect","prototype","Boolean","queryAssignedElements","flatten","protoOrDescriptor","name","willUpdate","Object","assign","waitUntilFirstUpdate","changedProps","call","has","oldValue","get","hasUpdated"],"mappings":"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"}