@six-group/ui-library 0.0.0-insider.9277796 → 0.0.0-insider.d16ec8e

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 (754) hide show
  1. package/dist/cjs/{event-listeners-74715e62.js → event-listeners-dd94dcfb.js} +7 -7
  2. package/dist/cjs/event-listeners-dd94dcfb.js.map +1 -0
  3. package/dist/cjs/{execution-control-46f388e0.js → execution-control-45c84c46.js} +6 -3
  4. package/dist/cjs/execution-control-45c84c46.js.map +1 -0
  5. package/dist/cjs/{focus-visible-0b352c74.js → focus-visible-e0d93a95.js} +3 -3
  6. package/dist/cjs/focus-visible-e0d93a95.js.map +1 -0
  7. package/dist/cjs/{form-control-2c17c573.js → form-control-7494488a.js} +10 -9
  8. package/dist/cjs/form-control-7494488a.js.map +1 -0
  9. package/dist/cjs/{index-2f6daa5b.js → index-ccf35821.js} +4 -1
  10. package/dist/cjs/index-ccf35821.js.map +1 -0
  11. package/dist/cjs/loader.cjs.js +2 -2
  12. package/dist/cjs/{modal-48d42228.js → modal-21350fb5.js} +4 -3
  13. package/dist/cjs/modal-21350fb5.js.map +1 -0
  14. package/dist/cjs/{popover-f743f62b.js → popover-b5e2d5ef.js} +33 -19
  15. package/dist/cjs/popover-b5e2d5ef.js.map +1 -0
  16. package/dist/cjs/popup-44836aaf.js +103 -0
  17. package/dist/cjs/popup-44836aaf.js.map +1 -0
  18. package/dist/cjs/set-attributes_2.cjs.entry.js +4 -2
  19. package/dist/cjs/set-attributes_2.cjs.entry.js.map +1 -1
  20. package/dist/cjs/six-alert.cjs.entry.js +18 -23
  21. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  22. package/dist/cjs/six-avatar.cjs.entry.js +5 -8
  23. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  24. package/dist/cjs/six-badge.cjs.entry.js +2 -2
  25. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  26. package/dist/cjs/six-button.cjs.entry.js +30 -34
  27. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  28. package/dist/cjs/six-card.cjs.entry.js +1 -1
  29. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  30. package/dist/cjs/six-checkbox.cjs.entry.js +62 -50
  31. package/dist/cjs/six-checkbox.cjs.entry.js.map +1 -1
  32. package/dist/cjs/six-datepicker.cjs.entry.js +148 -245
  33. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  34. package/dist/cjs/six-details.cjs.entry.js +48 -47
  35. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  36. package/dist/cjs/six-dialog.cjs.entry.js +36 -40
  37. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  38. package/dist/cjs/six-drawer.cjs.entry.js +33 -37
  39. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  40. package/dist/cjs/six-dropdown_2.cjs.entry.js +215 -196
  41. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  42. package/dist/cjs/six-error-page.cjs.entry.js +20 -22
  43. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  44. package/dist/cjs/six-file-list-item.cjs.entry.js +2 -2
  45. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  46. package/dist/cjs/six-file-list.cjs.entry.js +1 -1
  47. package/dist/cjs/six-file-upload.cjs.entry.js +21 -21
  48. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  49. package/dist/cjs/six-footer.cjs.entry.js +1 -1
  50. package/dist/cjs/six-form.cjs.entry.js +40 -35
  51. package/dist/cjs/six-form.cjs.entry.js.map +1 -1
  52. package/dist/cjs/six-group-label.cjs.entry.js +12 -11
  53. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  54. package/dist/cjs/six-header.cjs.entry.js +66 -44
  55. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  56. package/dist/cjs/six-icon-button.cjs.entry.js +4 -4
  57. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  58. package/dist/cjs/six-icon.cjs.entry.js +1 -1
  59. package/dist/cjs/six-input.cjs.entry.js +111 -85
  60. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  61. package/dist/cjs/six-item-picker.cjs.entry.js +59 -78
  62. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  63. package/dist/cjs/six-language-switcher.cjs.entry.js +2 -2
  64. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  65. package/dist/cjs/six-layout-grid.cjs.entry.js +5 -3
  66. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  67. package/dist/cjs/six-main-container.cjs.entry.js +1 -1
  68. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  69. package/dist/cjs/six-menu-divider.cjs.entry.js +1 -1
  70. package/dist/cjs/six-menu-item.cjs.entry.js +9 -7
  71. package/dist/cjs/six-menu-item.cjs.entry.js.map +1 -1
  72. package/dist/cjs/six-menu-label.cjs.entry.js +1 -1
  73. package/dist/cjs/six-picto.cjs.entry.js +5 -2
  74. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  75. package/dist/cjs/six-progress-bar.cjs.entry.js +1 -1
  76. package/dist/cjs/six-progress-ring.cjs.entry.js +4 -4
  77. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  78. package/dist/cjs/six-radio.cjs.entry.js +57 -52
  79. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  80. package/dist/cjs/six-range.cjs.entry.js +118 -79
  81. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  82. package/dist/cjs/six-root.cjs.entry.js +2 -2
  83. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  84. package/dist/cjs/six-search-field.cjs.entry.js +11 -6
  85. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  86. package/dist/cjs/six-select.cjs.entry.js +192 -186
  87. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  88. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +10 -6
  89. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  90. package/dist/cjs/six-sidebar-item.cjs.entry.js +1 -1
  91. package/dist/cjs/six-sidebar.cjs.entry.js +40 -19
  92. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  93. package/dist/cjs/six-spinner.cjs.entry.js +1 -1
  94. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  95. package/dist/cjs/six-switch.cjs.entry.js +51 -45
  96. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  97. package/dist/cjs/six-tab-group.cjs.entry.js +131 -113
  98. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  99. package/dist/cjs/six-tab-panel.cjs.entry.js +2 -2
  100. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  101. package/dist/cjs/six-tab.cjs.entry.js +5 -3
  102. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  103. package/dist/cjs/six-tag.cjs.entry.js +5 -8
  104. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  105. package/dist/cjs/six-textarea.cjs.entry.js +101 -78
  106. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  107. package/dist/cjs/six-tile.cjs.entry.js +14 -17
  108. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  109. package/dist/cjs/six-timepicker.cjs.entry.js +155 -201
  110. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  111. package/dist/cjs/six-tooltip.cjs.entry.js +54 -57
  112. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  113. package/dist/cjs/{slot-ad537f24.js → slot-bccbdb59.js} +11 -10
  114. package/dist/cjs/slot-bccbdb59.js.map +1 -0
  115. package/dist/cjs/ui-library.cjs.js +2 -2
  116. package/dist/collection/components/six-alert/six-alert.js +17 -22
  117. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  118. package/dist/collection/components/six-avatar/six-avatar.js +4 -7
  119. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  120. package/dist/collection/components/six-badge/six-badge.js +1 -1
  121. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  122. package/dist/collection/components/six-button/six-button.js +38 -40
  123. package/dist/collection/components/six-button/six-button.js.map +1 -1
  124. package/dist/collection/components/six-card/six-card.js +1 -1
  125. package/dist/collection/components/six-card/six-card.js.map +1 -1
  126. package/dist/collection/components/six-checkbox/six-checkbox.js +65 -51
  127. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  128. package/dist/collection/components/six-datepicker/components/day-selection.js +2 -2
  129. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  130. package/dist/collection/components/six-datepicker/components/month-selection.js +4 -3
  131. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  132. package/dist/collection/components/six-datepicker/components/year-selection.js +9 -6
  133. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  134. package/dist/collection/components/six-datepicker/six-datepicker.js +126 -240
  135. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  136. package/dist/collection/components/six-details/six-details.js +51 -50
  137. package/dist/collection/components/six-details/six-details.js.map +1 -1
  138. package/dist/collection/components/six-dialog/six-dialog.js +34 -38
  139. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  140. package/dist/collection/components/six-drawer/six-drawer.js +31 -35
  141. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  142. package/dist/collection/components/six-dropdown/six-dropdown.js +185 -173
  143. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  144. package/dist/collection/components/six-error-page/six-error-page.js +25 -27
  145. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  146. package/dist/collection/components/six-file-list-item/six-file-list-item.js +3 -3
  147. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  148. package/dist/collection/components/six-file-upload/six-file-upload.js +32 -32
  149. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  150. package/dist/collection/components/six-form/six-form.js +41 -33
  151. package/dist/collection/components/six-form/six-form.js.map +1 -1
  152. package/dist/collection/components/six-group-label/six-group-label.js +11 -9
  153. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  154. package/dist/collection/components/six-header/six-header.js +64 -42
  155. package/dist/collection/components/six-header/six-header.js.map +1 -1
  156. package/dist/collection/components/six-icon-button/six-icon-button.js +8 -8
  157. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  158. package/dist/collection/components/six-input/six-input.js +145 -132
  159. package/dist/collection/components/six-input/six-input.js.map +1 -1
  160. package/dist/collection/components/six-item-picker/six-item-picker.js +65 -84
  161. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  162. package/dist/collection/components/six-language-switcher/six-language-switcher.js +2 -2
  163. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  164. package/dist/collection/components/six-layout-grid/six-layout-grid.js +10 -8
  165. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  166. package/dist/collection/components/six-main-container/six-main-container.js +1 -1
  167. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  168. package/dist/collection/components/six-menu/six-menu.js +29 -23
  169. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  170. package/dist/collection/components/six-menu-item/six-menu-item.js +7 -5
  171. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  172. package/dist/collection/components/six-picto/six-picto.js +5 -2
  173. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  174. package/dist/collection/components/six-progress-ring/six-progress-ring.js +5 -4
  175. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  176. package/dist/collection/components/six-radio/six-radio.js +62 -55
  177. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  178. package/dist/collection/components/six-range/six-range.js +121 -76
  179. package/dist/collection/components/six-range/six-range.js.map +1 -1
  180. package/dist/collection/components/six-root/six-root.js +4 -4
  181. package/dist/collection/components/six-root/six-root.js.map +1 -1
  182. package/dist/collection/components/six-search-field/six-search-field.js +10 -5
  183. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  184. package/dist/collection/components/six-select/six-select.js +191 -190
  185. package/dist/collection/components/six-select/six-select.js.map +1 -1
  186. package/dist/collection/components/six-select/util.js +52 -0
  187. package/dist/collection/components/six-select/util.js.map +1 -0
  188. package/dist/collection/components/six-sidebar/six-sidebar.js +40 -19
  189. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  190. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +12 -8
  191. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  192. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  193. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +1 -1
  194. package/dist/collection/components/six-switch/six-switch.js +58 -50
  195. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  196. package/dist/collection/components/six-tab/six-tab.js +5 -3
  197. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  198. package/dist/collection/components/six-tab-group/six-tab-group.js +130 -112
  199. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  200. package/dist/collection/components/six-tab-panel/six-tab-panel.js +2 -2
  201. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  202. package/dist/collection/components/six-tag/six-tag.js +4 -7
  203. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  204. package/dist/collection/components/six-textarea/six-textarea.js +125 -115
  205. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  206. package/dist/collection/components/six-tile/six-tile.js +17 -20
  207. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  208. package/dist/collection/components/six-timepicker/six-timepicker.js +129 -177
  209. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  210. package/dist/collection/components/six-tooltip/six-tooltip.js +56 -59
  211. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  212. package/dist/collection/functional-components/form-control/form-control.js +8 -7
  213. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  214. package/dist/collection/testUtil/delay.js.map +1 -1
  215. package/dist/collection/utils/date-util.js +24 -16
  216. package/dist/collection/utils/date-util.js.map +1 -1
  217. package/dist/collection/utils/event-listeners.js +6 -6
  218. package/dist/collection/utils/event-listeners.js.map +1 -1
  219. package/dist/collection/utils/execution-control.js +5 -4
  220. package/dist/collection/utils/execution-control.js.map +1 -1
  221. package/dist/collection/utils/focus-visible.js +2 -2
  222. package/dist/collection/utils/focus-visible.js.map +1 -1
  223. package/dist/collection/utils/modal.js +3 -2
  224. package/dist/collection/utils/modal.js.map +1 -1
  225. package/dist/collection/utils/popover.js +32 -18
  226. package/dist/collection/utils/popover.js.map +1 -1
  227. package/dist/collection/utils/popup.js +95 -0
  228. package/dist/collection/utils/popup.js.map +1 -0
  229. package/dist/collection/utils/slot.js +9 -24
  230. package/dist/collection/utils/slot.js.map +1 -1
  231. package/dist/collection/utils/tabbable.js +6 -6
  232. package/dist/collection/utils/tabbable.js.map +1 -1
  233. package/dist/collection/utils/time.util.js +48 -34
  234. package/dist/collection/utils/time.util.js.map +1 -1
  235. package/dist/collection/utils/type-check.js +0 -1
  236. package/dist/collection/utils/type-check.js.map +1 -1
  237. package/dist/collection/wrappers/set-attributes/set-attributes.js +3 -1
  238. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +1 -1
  239. package/dist/components/event-listeners.js +6 -6
  240. package/dist/components/event-listeners.js.map +1 -1
  241. package/dist/components/execution-control.js +5 -2
  242. package/dist/components/execution-control.js.map +1 -1
  243. package/dist/components/focus-visible.js +2 -2
  244. package/dist/components/focus-visible.js.map +1 -1
  245. package/dist/components/form-control.js +8 -7
  246. package/dist/components/form-control.js.map +1 -1
  247. package/dist/components/modal.js +3 -2
  248. package/dist/components/modal.js.map +1 -1
  249. package/dist/components/popover.js +32 -18
  250. package/dist/components/popover.js.map +1 -1
  251. package/dist/components/set-attributes2.js +3 -1
  252. package/dist/components/set-attributes2.js.map +1 -1
  253. package/dist/components/six-alert.js +17 -22
  254. package/dist/components/six-alert.js.map +1 -1
  255. package/dist/components/six-avatar.js +4 -7
  256. package/dist/components/six-avatar.js.map +1 -1
  257. package/dist/components/six-badge.js +1 -1
  258. package/dist/components/six-badge.js.map +1 -1
  259. package/dist/components/six-button.js +28 -32
  260. package/dist/components/six-button.js.map +1 -1
  261. package/dist/components/six-card.js.map +1 -1
  262. package/dist/components/six-checkbox.js +58 -46
  263. package/dist/components/six-checkbox.js.map +1 -1
  264. package/dist/components/six-datepicker.js +141 -238
  265. package/dist/components/six-datepicker.js.map +1 -1
  266. package/dist/components/six-details2.js +46 -45
  267. package/dist/components/six-details2.js.map +1 -1
  268. package/dist/components/six-dialog.js +33 -37
  269. package/dist/components/six-dialog.js.map +1 -1
  270. package/dist/components/six-drawer.js +30 -34
  271. package/dist/components/six-drawer.js.map +1 -1
  272. package/dist/components/six-dropdown2.js +185 -173
  273. package/dist/components/six-dropdown2.js.map +1 -1
  274. package/dist/components/six-error-page.js +19 -21
  275. package/dist/components/six-error-page.js.map +1 -1
  276. package/dist/components/six-file-list-item.js +1 -1
  277. package/dist/components/six-file-list-item.js.map +1 -1
  278. package/dist/components/six-file-upload.js +20 -20
  279. package/dist/components/six-file-upload.js.map +1 -1
  280. package/dist/components/six-form.js +38 -33
  281. package/dist/components/six-form.js.map +1 -1
  282. package/dist/components/six-group-label.js +9 -8
  283. package/dist/components/six-group-label.js.map +1 -1
  284. package/dist/components/six-header.js +64 -42
  285. package/dist/components/six-header.js.map +1 -1
  286. package/dist/components/six-icon-button2.js +2 -2
  287. package/dist/components/six-icon-button2.js.map +1 -1
  288. package/dist/components/six-input2.js +107 -81
  289. package/dist/components/six-input2.js.map +1 -1
  290. package/dist/components/six-item-picker2.js +56 -75
  291. package/dist/components/six-item-picker2.js.map +1 -1
  292. package/dist/components/six-language-switcher.js +1 -1
  293. package/dist/components/six-language-switcher.js.map +1 -1
  294. package/dist/components/six-layout-grid.js +5 -3
  295. package/dist/components/six-layout-grid.js.map +1 -1
  296. package/dist/components/six-main-container.js.map +1 -1
  297. package/dist/components/six-menu-item2.js +7 -5
  298. package/dist/components/six-menu-item2.js.map +1 -1
  299. package/dist/components/six-menu2.js +25 -18
  300. package/dist/components/six-menu2.js.map +1 -1
  301. package/dist/components/six-picto2.js +4 -1
  302. package/dist/components/six-picto2.js.map +1 -1
  303. package/dist/components/six-progress-ring.js +3 -3
  304. package/dist/components/six-progress-ring.js.map +1 -1
  305. package/dist/components/six-radio.js +56 -51
  306. package/dist/components/six-radio.js.map +1 -1
  307. package/dist/components/six-range.js +114 -75
  308. package/dist/components/six-range.js.map +1 -1
  309. package/dist/components/six-root.js +1 -1
  310. package/dist/components/six-root.js.map +1 -1
  311. package/dist/components/six-search-field.js +8 -3
  312. package/dist/components/six-search-field.js.map +1 -1
  313. package/dist/components/six-select.js +188 -182
  314. package/dist/components/six-select.js.map +1 -1
  315. package/dist/components/six-sidebar-item-group.js +8 -4
  316. package/dist/components/six-sidebar-item-group.js.map +1 -1
  317. package/dist/components/six-sidebar.js +39 -18
  318. package/dist/components/six-sidebar.js.map +1 -1
  319. package/dist/components/six-spinner2.js.map +1 -1
  320. package/dist/components/six-switch.js +50 -44
  321. package/dist/components/six-switch.js.map +1 -1
  322. package/dist/components/six-tab-group.js +129 -111
  323. package/dist/components/six-tab-group.js.map +1 -1
  324. package/dist/components/six-tab-panel.js +1 -1
  325. package/dist/components/six-tab-panel.js.map +1 -1
  326. package/dist/components/six-tab.js +4 -2
  327. package/dist/components/six-tab.js.map +1 -1
  328. package/dist/components/six-tag2.js +4 -7
  329. package/dist/components/six-tag2.js.map +1 -1
  330. package/dist/components/six-textarea.js +97 -74
  331. package/dist/components/six-textarea.js.map +1 -1
  332. package/dist/components/six-tile.js +14 -17
  333. package/dist/components/six-tile.js.map +1 -1
  334. package/dist/components/six-timepicker.js +1 -1
  335. package/dist/components/six-timepicker2.js +241 -239
  336. package/dist/components/six-timepicker2.js.map +1 -1
  337. package/dist/components/six-tooltip2.js +52 -55
  338. package/dist/components/six-tooltip2.js.map +1 -1
  339. package/dist/components/slot.js +10 -9
  340. package/dist/components/slot.js.map +1 -1
  341. package/dist/components.json +388 -196
  342. package/dist/esm/{event-listeners-570a24ea.js → event-listeners-6b434035.js} +7 -7
  343. package/dist/esm/event-listeners-6b434035.js.map +1 -0
  344. package/dist/esm/{execution-control-1a60d709.js → execution-control-72cc50f4.js} +6 -3
  345. package/dist/esm/execution-control-72cc50f4.js.map +1 -0
  346. package/dist/esm/{focus-visible-97933ea9.js → focus-visible-fa7129a0.js} +3 -3
  347. package/dist/esm/focus-visible-fa7129a0.js.map +1 -0
  348. package/dist/esm/{form-control-3b440ea1.js → form-control-44a50dd6.js} +10 -9
  349. package/dist/esm/form-control-44a50dd6.js.map +1 -0
  350. package/dist/esm/{index-5c0f6628.js → index-371fb9d4.js} +4 -2
  351. package/dist/esm/index-371fb9d4.js.map +1 -0
  352. package/dist/esm/loader.js +3 -3
  353. package/dist/esm/{modal-5ebdc320.js → modal-b1d96441.js} +4 -3
  354. package/dist/esm/modal-b1d96441.js.map +1 -0
  355. package/dist/esm/{popover-bd2c2fca.js → popover-1aacbae8.js} +33 -19
  356. package/dist/{cjs/popover-f743f62b.js.map → esm/popover-1aacbae8.js.map} +1 -1
  357. package/dist/esm/popup-678b8592.js +98 -0
  358. package/dist/esm/popup-678b8592.js.map +1 -0
  359. package/dist/esm/set-attributes_2.entry.js +4 -2
  360. package/dist/esm/set-attributes_2.entry.js.map +1 -1
  361. package/dist/esm/six-alert.entry.js +18 -23
  362. package/dist/esm/six-alert.entry.js.map +1 -1
  363. package/dist/esm/six-avatar.entry.js +5 -8
  364. package/dist/esm/six-avatar.entry.js.map +1 -1
  365. package/dist/esm/six-badge.entry.js +2 -2
  366. package/dist/esm/six-badge.entry.js.map +1 -1
  367. package/dist/esm/six-button.entry.js +30 -34
  368. package/dist/esm/six-button.entry.js.map +1 -1
  369. package/dist/esm/six-card.entry.js +1 -1
  370. package/dist/esm/six-card.entry.js.map +1 -1
  371. package/dist/esm/six-checkbox.entry.js +62 -50
  372. package/dist/esm/six-checkbox.entry.js.map +1 -1
  373. package/dist/esm/six-datepicker.entry.js +145 -242
  374. package/dist/esm/six-datepicker.entry.js.map +1 -1
  375. package/dist/esm/six-details.entry.js +48 -47
  376. package/dist/esm/six-details.entry.js.map +1 -1
  377. package/dist/esm/six-dialog.entry.js +36 -40
  378. package/dist/esm/six-dialog.entry.js.map +1 -1
  379. package/dist/esm/six-drawer.entry.js +33 -37
  380. package/dist/esm/six-drawer.entry.js.map +1 -1
  381. package/dist/esm/six-dropdown_2.entry.js +215 -196
  382. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  383. package/dist/esm/six-error-page.entry.js +20 -22
  384. package/dist/esm/six-error-page.entry.js.map +1 -1
  385. package/dist/esm/six-file-list-item.entry.js +2 -2
  386. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  387. package/dist/esm/six-file-list.entry.js +1 -1
  388. package/dist/esm/six-file-upload.entry.js +21 -21
  389. package/dist/esm/six-file-upload.entry.js.map +1 -1
  390. package/dist/esm/six-footer.entry.js +1 -1
  391. package/dist/esm/six-form.entry.js +40 -35
  392. package/dist/esm/six-form.entry.js.map +1 -1
  393. package/dist/esm/six-group-label.entry.js +12 -11
  394. package/dist/esm/six-group-label.entry.js.map +1 -1
  395. package/dist/esm/six-header.entry.js +66 -44
  396. package/dist/esm/six-header.entry.js.map +1 -1
  397. package/dist/esm/six-icon-button.entry.js +4 -4
  398. package/dist/esm/six-icon-button.entry.js.map +1 -1
  399. package/dist/esm/six-icon.entry.js +1 -1
  400. package/dist/esm/six-input.entry.js +111 -85
  401. package/dist/esm/six-input.entry.js.map +1 -1
  402. package/dist/esm/six-item-picker.entry.js +59 -78
  403. package/dist/esm/six-item-picker.entry.js.map +1 -1
  404. package/dist/esm/six-language-switcher.entry.js +2 -2
  405. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  406. package/dist/esm/six-layout-grid.entry.js +5 -3
  407. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  408. package/dist/esm/six-main-container.entry.js +1 -1
  409. package/dist/esm/six-main-container.entry.js.map +1 -1
  410. package/dist/esm/six-menu-divider.entry.js +1 -1
  411. package/dist/esm/six-menu-item.entry.js +9 -7
  412. package/dist/esm/six-menu-item.entry.js.map +1 -1
  413. package/dist/esm/six-menu-label.entry.js +1 -1
  414. package/dist/esm/six-picto.entry.js +5 -2
  415. package/dist/esm/six-picto.entry.js.map +1 -1
  416. package/dist/esm/six-progress-bar.entry.js +1 -1
  417. package/dist/esm/six-progress-ring.entry.js +4 -4
  418. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  419. package/dist/esm/six-radio.entry.js +57 -52
  420. package/dist/esm/six-radio.entry.js.map +1 -1
  421. package/dist/esm/six-range.entry.js +118 -79
  422. package/dist/esm/six-range.entry.js.map +1 -1
  423. package/dist/esm/six-root.entry.js +2 -2
  424. package/dist/esm/six-root.entry.js.map +1 -1
  425. package/dist/esm/six-search-field.entry.js +11 -6
  426. package/dist/esm/six-search-field.entry.js.map +1 -1
  427. package/dist/esm/six-select.entry.js +192 -186
  428. package/dist/esm/six-select.entry.js.map +1 -1
  429. package/dist/esm/six-sidebar-item-group.entry.js +10 -6
  430. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  431. package/dist/esm/six-sidebar-item.entry.js +1 -1
  432. package/dist/esm/six-sidebar.entry.js +40 -19
  433. package/dist/esm/six-sidebar.entry.js.map +1 -1
  434. package/dist/esm/six-spinner.entry.js +1 -1
  435. package/dist/esm/six-spinner.entry.js.map +1 -1
  436. package/dist/esm/six-switch.entry.js +51 -45
  437. package/dist/esm/six-switch.entry.js.map +1 -1
  438. package/dist/esm/six-tab-group.entry.js +131 -113
  439. package/dist/esm/six-tab-group.entry.js.map +1 -1
  440. package/dist/esm/six-tab-panel.entry.js +2 -2
  441. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  442. package/dist/esm/six-tab.entry.js +5 -3
  443. package/dist/esm/six-tab.entry.js.map +1 -1
  444. package/dist/esm/six-tag.entry.js +5 -8
  445. package/dist/esm/six-tag.entry.js.map +1 -1
  446. package/dist/esm/six-textarea.entry.js +101 -78
  447. package/dist/esm/six-textarea.entry.js.map +1 -1
  448. package/dist/esm/six-tile.entry.js +14 -17
  449. package/dist/esm/six-tile.entry.js.map +1 -1
  450. package/dist/esm/six-timepicker.entry.js +155 -201
  451. package/dist/esm/six-timepicker.entry.js.map +1 -1
  452. package/dist/esm/six-tooltip.entry.js +54 -57
  453. package/dist/esm/six-tooltip.entry.js.map +1 -1
  454. package/dist/esm/{slot-6f3984c7.js → slot-2e64df19.js} +11 -10
  455. package/dist/esm/slot-2e64df19.js.map +1 -0
  456. package/dist/esm/ui-library.js +3 -3
  457. package/dist/types/components/six-alert/six-alert.d.ts +5 -7
  458. package/dist/types/components/six-avatar/six-avatar.d.ts +1 -2
  459. package/dist/types/components/six-badge/six-badge.d.ts +0 -1
  460. package/dist/types/components/six-button/six-button.d.ts +8 -9
  461. package/dist/types/components/six-checkbox/six-checkbox.d.ts +22 -18
  462. package/dist/types/components/six-datepicker/components/day-selection.d.ts +9 -5
  463. package/dist/types/components/six-datepicker/components/month-selection.d.ts +8 -5
  464. package/dist/types/components/six-datepicker/components/year-selection.d.ts +7 -5
  465. package/dist/types/components/six-datepicker/six-datepicker.d.ts +34 -39
  466. package/dist/types/components/six-details/six-details.d.ts +12 -12
  467. package/dist/types/components/six-dialog/six-dialog.d.ts +12 -13
  468. package/dist/types/components/six-drawer/six-drawer.d.ts +12 -13
  469. package/dist/types/components/six-dropdown/six-dropdown.d.ts +28 -32
  470. package/dist/types/components/six-error-page/six-error-page.d.ts +1 -1
  471. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +3 -3
  472. package/dist/types/components/six-file-upload/six-file-upload.d.ts +11 -11
  473. package/dist/types/components/six-form/six-form.d.ts +7 -16
  474. package/dist/types/components/six-group-label/six-group-label.d.ts +4 -4
  475. package/dist/types/components/six-header/six-header.d.ts +16 -27
  476. package/dist/types/components/six-icon-button/six-icon-button.d.ts +4 -4
  477. package/dist/types/components/six-input/six-input.d.ts +30 -39
  478. package/dist/types/components/six-item-picker/six-item-picker.d.ts +13 -16
  479. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +1 -1
  480. package/dist/types/components/six-menu/six-menu.d.ts +10 -11
  481. package/dist/types/components/six-menu-item/six-menu-item.d.ts +6 -6
  482. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +2 -2
  483. package/dist/types/components/six-radio/six-radio.d.ts +11 -12
  484. package/dist/types/components/six-range/six-range.d.ts +24 -20
  485. package/dist/types/components/six-root/six-root.d.ts +3 -3
  486. package/dist/types/components/six-search-field/six-search-field.d.ts +4 -5
  487. package/dist/types/components/six-select/six-select.d.ts +39 -41
  488. package/dist/types/components/six-select/util.d.ts +7 -0
  489. package/dist/types/components/six-sidebar/six-sidebar.d.ts +5 -5
  490. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +7 -6
  491. package/dist/types/components/six-spinner/six-spinner.d.ts +2 -2
  492. package/dist/types/components/six-switch/six-switch.d.ts +10 -11
  493. package/dist/types/components/six-tab/six-tab.d.ts +3 -3
  494. package/dist/types/components/six-tab-group/six-tab-group.d.ts +20 -21
  495. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +1 -1
  496. package/dist/types/components/six-tag/six-tag.d.ts +1 -3
  497. package/dist/types/components/six-textarea/six-textarea.d.ts +25 -34
  498. package/dist/types/components/six-tile/six-tile.d.ts +2 -3
  499. package/dist/types/components/six-timepicker/six-timepicker.d.ts +21 -33
  500. package/dist/types/components/six-tooltip/six-tooltip.d.ts +19 -21
  501. package/dist/types/components.d.ts +130 -126
  502. package/dist/types/functional-components/form-control/form-control.d.ts +5 -4
  503. package/dist/types/testUtil/delay.d.ts +1 -1
  504. package/dist/types/utils/date-util.d.ts +17 -10
  505. package/dist/types/utils/event-listeners.d.ts +1 -1
  506. package/dist/types/utils/execution-control.d.ts +1 -3
  507. package/dist/types/utils/modal.d.ts +2 -2
  508. package/dist/types/utils/popover.d.ts +5 -5
  509. package/dist/types/utils/popup.d.ts +9 -0
  510. package/dist/types/utils/slot.d.ts +2 -7
  511. package/dist/types/utils/tabbable.d.ts +1 -1
  512. package/dist/types/utils/time.util.d.ts +18 -9
  513. package/dist/types/utils/type-check.d.ts +3 -4
  514. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +1 -1
  515. package/dist/ui-library/p-02d5a6d8.js +2 -0
  516. package/dist/ui-library/p-02d5a6d8.js.map +1 -0
  517. package/dist/ui-library/p-053d6de8.entry.js +2 -0
  518. package/dist/ui-library/p-053d6de8.entry.js.map +1 -0
  519. package/dist/ui-library/p-0cc08e91.js +2 -0
  520. package/dist/ui-library/p-0cc08e91.js.map +1 -0
  521. package/dist/ui-library/{p-a1d4f6cf.entry.js → p-0eee4c41.entry.js} +2 -2
  522. package/dist/ui-library/p-0eee4c41.entry.js.map +1 -0
  523. package/dist/ui-library/p-0fe78f9b.js +2 -0
  524. package/dist/ui-library/p-0fe78f9b.js.map +1 -0
  525. package/dist/ui-library/{p-ac4f4d45.js → p-187fbba0.js} +3 -3
  526. package/dist/ui-library/p-187fbba0.js.map +1 -0
  527. package/dist/ui-library/p-25b42655.entry.js +2 -0
  528. package/dist/ui-library/p-25b42655.entry.js.map +1 -0
  529. package/dist/ui-library/p-271ba152.entry.js +2 -0
  530. package/dist/ui-library/p-271ba152.entry.js.map +1 -0
  531. package/dist/ui-library/{p-6d75f216.entry.js → p-27c4ee88.entry.js} +2 -2
  532. package/dist/ui-library/p-2a36b7d0.entry.js +2 -0
  533. package/dist/ui-library/p-2a36b7d0.entry.js.map +1 -0
  534. package/dist/ui-library/p-2a8ad91b.entry.js +2 -0
  535. package/dist/ui-library/p-2a8ad91b.entry.js.map +1 -0
  536. package/dist/ui-library/{p-90dc6af4.entry.js → p-30e0cdce.entry.js} +2 -2
  537. package/dist/ui-library/p-30e0cdce.entry.js.map +1 -0
  538. package/dist/ui-library/{p-63703ba3.entry.js → p-3a47c8ad.entry.js} +2 -2
  539. package/dist/ui-library/{p-63703ba3.entry.js.map → p-3a47c8ad.entry.js.map} +1 -1
  540. package/dist/ui-library/p-3a4815cb.entry.js +2 -0
  541. package/dist/ui-library/p-3a4815cb.entry.js.map +1 -0
  542. package/dist/ui-library/p-3b71cac4.entry.js +2 -0
  543. package/dist/ui-library/p-3b71cac4.entry.js.map +1 -0
  544. package/dist/ui-library/p-3d4a2e03.entry.js +2 -0
  545. package/dist/ui-library/p-3d4a2e03.entry.js.map +1 -0
  546. package/dist/ui-library/{p-73597d13.entry.js → p-3e4b9341.entry.js} +2 -2
  547. package/dist/ui-library/{p-73597d13.entry.js.map → p-3e4b9341.entry.js.map} +1 -1
  548. package/dist/ui-library/{p-7e0cc4ae.entry.js → p-41f0b6ff.entry.js} +2 -2
  549. package/dist/ui-library/p-41f0b6ff.entry.js.map +1 -0
  550. package/dist/ui-library/p-435242a8.entry.js +2 -0
  551. package/dist/ui-library/p-435242a8.entry.js.map +1 -0
  552. package/dist/ui-library/{p-19364560.entry.js → p-5084ca7c.entry.js} +2 -2
  553. package/dist/ui-library/{p-19364560.entry.js.map → p-5084ca7c.entry.js.map} +1 -1
  554. package/dist/ui-library/p-5b3e6eb7.entry.js +2 -0
  555. package/dist/ui-library/p-5b3e6eb7.entry.js.map +1 -0
  556. package/dist/ui-library/{p-8a970a40.entry.js → p-5c1dd25a.entry.js} +2 -2
  557. package/dist/ui-library/p-5c1dd25a.entry.js.map +1 -0
  558. package/dist/ui-library/p-5c60227f.entry.js +2 -0
  559. package/dist/ui-library/p-5c60227f.entry.js.map +1 -0
  560. package/dist/ui-library/p-5dc40a6a.entry.js +2 -0
  561. package/dist/ui-library/p-5dc40a6a.entry.js.map +1 -0
  562. package/dist/ui-library/{p-dd3c76f1.entry.js → p-649017db.entry.js} +2 -2
  563. package/dist/ui-library/p-713684c7.entry.js +2 -0
  564. package/dist/ui-library/p-713684c7.entry.js.map +1 -0
  565. package/dist/ui-library/{p-c30f9e0b.entry.js → p-73325eec.entry.js} +2 -2
  566. package/dist/ui-library/p-73325eec.entry.js.map +1 -0
  567. package/dist/ui-library/p-7639c68e.entry.js +2 -0
  568. package/dist/ui-library/p-7639c68e.entry.js.map +1 -0
  569. package/dist/ui-library/p-764f56dd.entry.js +2 -0
  570. package/dist/ui-library/p-764f56dd.entry.js.map +1 -0
  571. package/dist/ui-library/{p-e19a6c95.entry.js → p-886a35ee.entry.js} +2 -2
  572. package/dist/ui-library/p-8cf72af6.js +2 -0
  573. package/dist/ui-library/p-8cf72af6.js.map +1 -0
  574. package/dist/ui-library/p-8d6f4311.entry.js +2 -0
  575. package/dist/ui-library/p-8d6f4311.entry.js.map +1 -0
  576. package/dist/ui-library/p-90c2dc30.entry.js +2 -0
  577. package/dist/ui-library/p-90c2dc30.entry.js.map +1 -0
  578. package/dist/ui-library/{p-97323ad7.entry.js → p-965fa6a6.entry.js} +2 -2
  579. package/dist/ui-library/p-98234e3f.entry.js +2 -0
  580. package/dist/ui-library/p-98234e3f.entry.js.map +1 -0
  581. package/dist/ui-library/{p-820c23f0.entry.js → p-9b9c3afc.entry.js} +2 -2
  582. package/dist/ui-library/{p-14f20bbb.entry.js → p-9c34eab7.entry.js} +2 -2
  583. package/dist/ui-library/p-9c34eab7.entry.js.map +1 -0
  584. package/dist/ui-library/p-9e0c386f.entry.js +2 -0
  585. package/dist/ui-library/p-9e0c386f.entry.js.map +1 -0
  586. package/dist/ui-library/p-9f8b6144.entry.js +2 -0
  587. package/dist/ui-library/p-9f8b6144.entry.js.map +1 -0
  588. package/dist/ui-library/p-a3cc0521.entry.js +2 -0
  589. package/dist/ui-library/p-a3cc0521.entry.js.map +1 -0
  590. package/dist/ui-library/{p-21859bca.entry.js → p-a5143b8d.entry.js} +2 -2
  591. package/dist/ui-library/{p-097cced4.entry.js → p-aa6f71e1.entry.js} +2 -2
  592. package/dist/ui-library/{p-097cced4.entry.js.map → p-aa6f71e1.entry.js.map} +1 -1
  593. package/dist/ui-library/p-abb98245.entry.js +2 -0
  594. package/dist/ui-library/p-abb98245.entry.js.map +1 -0
  595. package/dist/ui-library/p-b183e44f.js +2 -0
  596. package/dist/ui-library/p-b183e44f.js.map +1 -0
  597. package/dist/ui-library/{p-19b50b5a.entry.js → p-b27f496f.entry.js} +2 -2
  598. package/dist/ui-library/p-b27f496f.entry.js.map +1 -0
  599. package/dist/ui-library/{p-4f8394d7.js → p-ba74863a.js} +2 -2
  600. package/dist/ui-library/p-ba74863a.js.map +1 -0
  601. package/dist/ui-library/p-bf4a35ec.js +2 -0
  602. package/dist/ui-library/p-bf4a35ec.js.map +1 -0
  603. package/dist/ui-library/{p-d5633a29.entry.js → p-c07adc21.entry.js} +2 -2
  604. package/dist/ui-library/p-c07adc21.entry.js.map +1 -0
  605. package/dist/ui-library/p-c700e3eb.entry.js +2 -0
  606. package/dist/ui-library/p-c700e3eb.entry.js.map +1 -0
  607. package/dist/ui-library/p-cab99e54.entry.js +2 -0
  608. package/dist/ui-library/p-cab99e54.entry.js.map +1 -0
  609. package/dist/ui-library/{p-baa03951.entry.js → p-cf1133a0.entry.js} +2 -2
  610. package/dist/ui-library/p-cf1d36c0.entry.js +2 -0
  611. package/dist/ui-library/p-cf1d36c0.entry.js.map +1 -0
  612. package/dist/ui-library/p-d87a6f4d.js +2 -0
  613. package/dist/ui-library/p-d87a6f4d.js.map +1 -0
  614. package/dist/ui-library/{p-c349d1d4.entry.js → p-d8c97778.entry.js} +2 -2
  615. package/dist/ui-library/p-d8c97778.entry.js.map +1 -0
  616. package/dist/ui-library/p-deb01174.entry.js +2 -0
  617. package/dist/ui-library/p-deb01174.entry.js.map +1 -0
  618. package/dist/ui-library/{p-af793d04.entry.js → p-e5ba13d2.entry.js} +2 -2
  619. package/dist/ui-library/p-e5ba13d2.entry.js.map +1 -0
  620. package/dist/ui-library/{p-611e1978.entry.js → p-f29ba9cb.entry.js} +2 -2
  621. package/dist/ui-library/{p-611e1978.entry.js.map → p-f29ba9cb.entry.js.map} +1 -1
  622. package/dist/ui-library/{p-9328e5bc.entry.js → p-f66eb76c.entry.js} +2 -2
  623. package/dist/ui-library/p-f66eb76c.entry.js.map +1 -0
  624. package/dist/ui-library/p-f974a184.entry.js +2 -0
  625. package/dist/ui-library/p-f974a184.entry.js.map +1 -0
  626. package/dist/ui-library/{p-b0e5658f.entry.js → p-fb8d0734.entry.js} +2 -2
  627. package/dist/ui-library/p-fb8d0734.entry.js.map +1 -0
  628. package/dist/ui-library/ui-library.esm.js +1 -1
  629. package/dist/ui-library/ui-library.esm.js.map +1 -1
  630. package/package.json +13 -14
  631. package/dist/cjs/event-listeners-74715e62.js.map +0 -1
  632. package/dist/cjs/execution-control-46f388e0.js.map +0 -1
  633. package/dist/cjs/focus-visible-0b352c74.js.map +0 -1
  634. package/dist/cjs/form-control-2c17c573.js.map +0 -1
  635. package/dist/cjs/index-2f6daa5b.js.map +0 -1
  636. package/dist/cjs/modal-48d42228.js.map +0 -1
  637. package/dist/cjs/six-timepicker.types-c19ebff3.js +0 -56
  638. package/dist/cjs/six-timepicker.types-c19ebff3.js.map +0 -1
  639. package/dist/cjs/slot-ad537f24.js.map +0 -1
  640. package/dist/collection/components/six-timepicker/six-time-format.js +0 -15
  641. package/dist/collection/components/six-timepicker/six-time-format.js.map +0 -1
  642. package/dist/collection/components/six-timepicker/six-timepicker.types.js +0 -41
  643. package/dist/collection/components/six-timepicker/six-timepicker.types.js.map +0 -1
  644. package/dist/collection/utils/as-array.js +0 -2
  645. package/dist/collection/utils/as-array.js.map +0 -1
  646. package/dist/collection/utils/matchers.js +0 -3
  647. package/dist/collection/utils/matchers.js.map +0 -1
  648. package/dist/collection/utils/testing.js +0 -39
  649. package/dist/collection/utils/testing.js.map +0 -1
  650. package/dist/esm/event-listeners-570a24ea.js.map +0 -1
  651. package/dist/esm/execution-control-1a60d709.js.map +0 -1
  652. package/dist/esm/focus-visible-97933ea9.js.map +0 -1
  653. package/dist/esm/form-control-3b440ea1.js.map +0 -1
  654. package/dist/esm/index-5c0f6628.js.map +0 -1
  655. package/dist/esm/modal-5ebdc320.js.map +0 -1
  656. package/dist/esm/popover-bd2c2fca.js.map +0 -1
  657. package/dist/esm/six-timepicker.types-e161a447.js +0 -50
  658. package/dist/esm/six-timepicker.types-e161a447.js.map +0 -1
  659. package/dist/esm/slot-6f3984c7.js.map +0 -1
  660. package/dist/types/components/six-timepicker/six-time-format.d.ts +0 -13
  661. package/dist/types/components/six-timepicker/six-timepicker.types.d.ts +0 -36
  662. package/dist/types/utils/as-array.d.ts +0 -1
  663. package/dist/types/utils/matchers.d.ts +0 -2
  664. package/dist/types/utils/popper.d.ts +0 -33
  665. package/dist/types/utils/testing.d.ts +0 -2
  666. package/dist/ui-library/p-054e12cc.entry.js +0 -2
  667. package/dist/ui-library/p-054e12cc.entry.js.map +0 -1
  668. package/dist/ui-library/p-0786fa7c.js +0 -2
  669. package/dist/ui-library/p-0786fa7c.js.map +0 -1
  670. package/dist/ui-library/p-0d79b0c6.entry.js +0 -2
  671. package/dist/ui-library/p-0d79b0c6.entry.js.map +0 -1
  672. package/dist/ui-library/p-14f20bbb.entry.js.map +0 -1
  673. package/dist/ui-library/p-18e5f772.entry.js +0 -2
  674. package/dist/ui-library/p-18e5f772.entry.js.map +0 -1
  675. package/dist/ui-library/p-18ea0c56.js +0 -2
  676. package/dist/ui-library/p-18ea0c56.js.map +0 -1
  677. package/dist/ui-library/p-19b50b5a.entry.js.map +0 -1
  678. package/dist/ui-library/p-2e48c8d2.entry.js +0 -2
  679. package/dist/ui-library/p-2e48c8d2.entry.js.map +0 -1
  680. package/dist/ui-library/p-308261c4.entry.js +0 -2
  681. package/dist/ui-library/p-308261c4.entry.js.map +0 -1
  682. package/dist/ui-library/p-33f7e22b.entry.js +0 -2
  683. package/dist/ui-library/p-33f7e22b.entry.js.map +0 -1
  684. package/dist/ui-library/p-4ae91795.entry.js +0 -2
  685. package/dist/ui-library/p-4ae91795.entry.js.map +0 -1
  686. package/dist/ui-library/p-4f8394d7.js.map +0 -1
  687. package/dist/ui-library/p-53a13db5.entry.js +0 -2
  688. package/dist/ui-library/p-53a13db5.entry.js.map +0 -1
  689. package/dist/ui-library/p-559c87f0.entry.js +0 -2
  690. package/dist/ui-library/p-559c87f0.entry.js.map +0 -1
  691. package/dist/ui-library/p-6403fd87.entry.js +0 -2
  692. package/dist/ui-library/p-6403fd87.entry.js.map +0 -1
  693. package/dist/ui-library/p-6433c0da.entry.js +0 -2
  694. package/dist/ui-library/p-6433c0da.entry.js.map +0 -1
  695. package/dist/ui-library/p-79eee01b.js +0 -2
  696. package/dist/ui-library/p-79eee01b.js.map +0 -1
  697. package/dist/ui-library/p-7e0cc4ae.entry.js.map +0 -1
  698. package/dist/ui-library/p-835c3ff7.entry.js +0 -2
  699. package/dist/ui-library/p-835c3ff7.entry.js.map +0 -1
  700. package/dist/ui-library/p-8a970a40.entry.js.map +0 -1
  701. package/dist/ui-library/p-90824648.entry.js +0 -2
  702. package/dist/ui-library/p-90824648.entry.js.map +0 -1
  703. package/dist/ui-library/p-90dc6af4.entry.js.map +0 -1
  704. package/dist/ui-library/p-9328e5bc.entry.js.map +0 -1
  705. package/dist/ui-library/p-9a860acc.js +0 -2
  706. package/dist/ui-library/p-9a860acc.js.map +0 -1
  707. package/dist/ui-library/p-9d1d222f.entry.js +0 -2
  708. package/dist/ui-library/p-9d1d222f.entry.js.map +0 -1
  709. package/dist/ui-library/p-a1d4f6cf.entry.js.map +0 -1
  710. package/dist/ui-library/p-ac4f4d45.js.map +0 -1
  711. package/dist/ui-library/p-af793d04.entry.js.map +0 -1
  712. package/dist/ui-library/p-b0e5658f.entry.js.map +0 -1
  713. package/dist/ui-library/p-b1e66136.js +0 -2
  714. package/dist/ui-library/p-b1e66136.js.map +0 -1
  715. package/dist/ui-library/p-b4dfb7cf.js +0 -2
  716. package/dist/ui-library/p-b4dfb7cf.js.map +0 -1
  717. package/dist/ui-library/p-b997e43c.entry.js +0 -2
  718. package/dist/ui-library/p-b997e43c.entry.js.map +0 -1
  719. package/dist/ui-library/p-c0cb6436.entry.js +0 -2
  720. package/dist/ui-library/p-c0cb6436.entry.js.map +0 -1
  721. package/dist/ui-library/p-c30f9e0b.entry.js.map +0 -1
  722. package/dist/ui-library/p-c349d1d4.entry.js.map +0 -1
  723. package/dist/ui-library/p-c53a63f9.entry.js +0 -2
  724. package/dist/ui-library/p-c53a63f9.entry.js.map +0 -1
  725. package/dist/ui-library/p-c640c2d8.entry.js +0 -2
  726. package/dist/ui-library/p-c640c2d8.entry.js.map +0 -1
  727. package/dist/ui-library/p-c94d0b07.entry.js +0 -2
  728. package/dist/ui-library/p-c94d0b07.entry.js.map +0 -1
  729. package/dist/ui-library/p-d12c6092.js +0 -2
  730. package/dist/ui-library/p-d12c6092.js.map +0 -1
  731. package/dist/ui-library/p-d5633a29.entry.js.map +0 -1
  732. package/dist/ui-library/p-df655bc9.entry.js +0 -2
  733. package/dist/ui-library/p-df655bc9.entry.js.map +0 -1
  734. package/dist/ui-library/p-edc96efc.entry.js +0 -2
  735. package/dist/ui-library/p-edc96efc.entry.js.map +0 -1
  736. package/dist/ui-library/p-f18ba86f.entry.js +0 -2
  737. package/dist/ui-library/p-f18ba86f.entry.js.map +0 -1
  738. package/dist/ui-library/p-f4938771.entry.js +0 -2
  739. package/dist/ui-library/p-f4938771.entry.js.map +0 -1
  740. package/dist/ui-library/p-f70e2403.entry.js +0 -2
  741. package/dist/ui-library/p-f70e2403.entry.js.map +0 -1
  742. package/dist/ui-library/p-f9d345e0.entry.js +0 -2
  743. package/dist/ui-library/p-f9d345e0.entry.js.map +0 -1
  744. package/dist/ui-library/p-fed07a1f.entry.js +0 -2
  745. package/dist/ui-library/p-fed07a1f.entry.js.map +0 -1
  746. package/dist/ui-library/p-ff0257bf.entry.js +0 -2
  747. package/dist/ui-library/p-ff0257bf.entry.js.map +0 -1
  748. /package/dist/ui-library/{p-6d75f216.entry.js.map → p-27c4ee88.entry.js.map} +0 -0
  749. /package/dist/ui-library/{p-dd3c76f1.entry.js.map → p-649017db.entry.js.map} +0 -0
  750. /package/dist/ui-library/{p-e19a6c95.entry.js.map → p-886a35ee.entry.js.map} +0 -0
  751. /package/dist/ui-library/{p-97323ad7.entry.js.map → p-965fa6a6.entry.js.map} +0 -0
  752. /package/dist/ui-library/{p-820c23f0.entry.js.map → p-9b9c3afc.entry.js.map} +0 -0
  753. /package/dist/ui-library/{p-21859bca.entry.js.map → p-a5143b8d.entry.js.map} +0 -0
  754. /package/dist/ui-library/{p-baa03951.entry.js.map → p-cf1133a0.entry.js.map} +0 -0
@@ -9,7 +9,7 @@ const SixProgressRing$1 = /*@__PURE__*/ proxyCustomElement(class SixProgressRing
9
9
  this.__attachShadow();
10
10
  this.size = 128;
11
11
  this.strokeWidth = 4;
12
- this.percentage = undefined;
12
+ this.percentage = 0;
13
13
  }
14
14
  handlePercentageChange() {
15
15
  this.updateProgress();
@@ -18,9 +18,9 @@ const SixProgressRing$1 = /*@__PURE__*/ proxyCustomElement(class SixProgressRing
18
18
  this.updateProgress();
19
19
  }
20
20
  updateProgress() {
21
- if (!this.indicator.r) {
21
+ var _a;
22
+ if (((_a = this.indicator) === null || _a === void 0 ? void 0 : _a.r) == null)
22
23
  return;
23
- }
24
24
  const radius = this.indicator.r.baseVal.value;
25
25
  const circumference = radius * 2 * Math.PI;
26
26
  const offset = circumference - (this.percentage / 100) * circumference;
@@ -1 +1 @@
1
- {"file":"six-progress-ring.js","mappings":";;AAAA,MAAM,kBAAkB,GAAG,+uBAA+uB;;MCmB7vBA,iBAAe;;;;;gBAIX,GAAG;uBAGI,CAAC;;;EAMvB,sBAAsB;IACpB,IAAI,CAAC,cAAc,EAAE,CAAC;GACvB;EAED,gBAAgB;IACd,IAAI,CAAC,cAAc,EAAE,CAAC;GACvB;EAED,cAAc;IACZ,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE;MACrB,OAAO;KACR;IACD,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9C,MAAM,aAAa,GAAG,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;IAC3C,MAAM,MAAM,GAAG,aAAa,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,aAAa,CAAC;IAEvE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,aAAa,IAAI,aAAa,EAAE,CAAC;IAC3E,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,MAAM,EAAE,CAAC;GACrD;EAED,MAAM;IACJ,QACE,WAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,eAAe,IACpC,WAAK,KAAK,EAAC,sBAAsB,EAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,IACnE,cACE,KAAK,EAAC,sBAAsB,kBACd,IAAI,CAAC,WAAW,oBACf,OAAO,EACtB,IAAI,EAAC,aAAa,EAClB,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,EACvC,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,EACjB,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GACjB,EAEF,cACE,GAAG,EAAE,CAAC,EAAoB,MAAM,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,EACpD,KAAK,EAAC,0BAA0B,kBAClB,IAAI,CAAC,WAAW,oBACf,OAAO,EACtB,IAAI,EAAC,aAAa,EAClB,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,EACvC,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,EACjB,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GACjB,CACE,EAEN,YAAM,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,sBAAsB,IAC7C,eAAQ,CACH,CACH,EACN;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["SixProgressRing"],"sources":["./src/components/six-progress-ring/six-progress-ring.scss?tag=six-progress-ring&encapsulation=shadow","./src/components/six-progress-ring/six-progress-ring.tsx"],"sourcesContent":["@import 'src/global/component';\n\n/**\n * @prop --track-color: The track color.\n * @prop --indicator-color: The indicator color.\n */\n:host {\n --track-color: var(--six-progress-track-color);\n --indicator-color: var(--six-progress-indicator-color);\n\n display: inline-flex;\n}\n\n.progress-ring {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n position: relative;\n}\n\n.progress-ring__image {\n transform: rotate(-90deg);\n transform-origin: 50% 50%;\n}\n\n.progress-ring__track {\n stroke: var(--track-color);\n}\n\n.progress-ring__indicator {\n stroke: var(--indicator-color);\n transition: 0.35s stroke-dashoffset, 0.35s stroke;\n}\n\n.progress-ring__label {\n display: flex;\n align-items: center;\n justify-content: center;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n text-align: center;\n user-select: none;\n font-family: var(--six-font-family);\n}\n","import { Component, h, Prop, Watch } from '@stencil/core';\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - A label to show inside the ring.\n *\n * @part base - The component's base wrapper.\n * @part label - The progress ring label.\n */\n\n@Component({\n tag: 'six-progress-ring',\n styleUrl: 'six-progress-ring.scss',\n shadow: true,\n})\nexport class SixProgressRing {\n indicator: SVGCircleElement;\n\n /** The size of the progress ring in pixels. */\n @Prop() size = 128;\n\n /** The stroke width of the progress ring in pixels. */\n @Prop() strokeWidth = 4;\n\n /** The current progress percentage, 0 - 100. */\n @Prop() percentage: number;\n\n @Watch('percentage')\n handlePercentageChange() {\n this.updateProgress();\n }\n\n componentDidLoad() {\n this.updateProgress();\n }\n\n updateProgress() {\n if (!this.indicator.r) {\n return;\n }\n const radius = this.indicator.r.baseVal.value;\n const circumference = radius * 2 * Math.PI;\n const offset = circumference - (this.percentage / 100) * circumference;\n\n this.indicator.style.strokeDasharray = `${circumference} ${circumference}`;\n this.indicator.style.strokeDashoffset = `${offset}`;\n }\n\n render() {\n return (\n <div part=\"base\" class=\"progress-ring\">\n <svg class=\"progress-ring__image\" width={this.size} height={this.size}>\n <circle\n class=\"progress-ring__track\"\n stroke-width={this.strokeWidth}\n stroke-linecap=\"round\"\n fill=\"transparent\"\n r={this.size / 2 - this.strokeWidth * 2}\n cx={this.size / 2}\n cy={this.size / 2}\n />\n\n <circle\n ref={(el: SVGCircleElement) => (this.indicator = el)}\n class=\"progress-ring__indicator\"\n stroke-width={this.strokeWidth}\n stroke-linecap=\"round\"\n fill=\"transparent\"\n r={this.size / 2 - this.strokeWidth * 2}\n cx={this.size / 2}\n cy={this.size / 2}\n />\n </svg>\n\n <span part=\"label\" class=\"progress-ring__label\">\n <slot />\n </span>\n </div>\n );\n }\n}\n"],"version":3}
1
+ {"file":"six-progress-ring.js","mappings":";;AAAA,MAAM,kBAAkB,GAAG,+uBAA+uB;;MCmB7vBA,iBAAe;;;;;gBAIX,GAAG;uBAGI,CAAC;sBAGF,CAAC;;EAGtB,sBAAsB;IACpB,IAAI,CAAC,cAAc,EAAE,CAAC;GACvB;EAED,gBAAgB;IACd,IAAI,CAAC,cAAc,EAAE,CAAC;GACvB;EAEO,cAAc;;IACpB,IAAI,CAAA,MAAA,IAAI,CAAC,SAAS,0CAAE,CAAC,KAAI,IAAI;MAAE,OAAO;IAEtC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9C,MAAM,aAAa,GAAG,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;IAC3C,MAAM,MAAM,GAAG,aAAa,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,aAAa,CAAC;IAEvE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,eAAe,GAAG,GAAG,aAAa,IAAI,aAAa,EAAE,CAAC;IAC3E,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,gBAAgB,GAAG,GAAG,MAAM,EAAE,CAAC;GACrD;EAED,MAAM;IACJ,QACE,WAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,eAAe,IACpC,WAAK,KAAK,EAAC,sBAAsB,EAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,IAAI,IACnE,cACE,KAAK,EAAC,sBAAsB,kBACd,IAAI,CAAC,WAAW,oBACf,OAAO,EACtB,IAAI,EAAC,aAAa,EAClB,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,EACvC,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,EACjB,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GACjB,EAEF,cACE,GAAG,EAAE,CAAC,EAAE,MAAM,IAAI,CAAC,SAAS,GAAG,EAAsB,CAAC,EACtD,KAAK,EAAC,0BAA0B,kBAClB,IAAI,CAAC,WAAW,oBACf,OAAO,EACtB,IAAI,EAAC,aAAa,EAClB,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,EACvC,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,EACjB,EAAE,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GACjB,CACE,EAEN,YAAM,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,sBAAsB,IAC7C,eAAQ,CACH,CACH,EACN;GACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["SixProgressRing"],"sources":["./src/components/six-progress-ring/six-progress-ring.scss?tag=six-progress-ring&encapsulation=shadow","./src/components/six-progress-ring/six-progress-ring.tsx"],"sourcesContent":["@import 'src/global/component';\n\n/**\n * @prop --track-color: The track color.\n * @prop --indicator-color: The indicator color.\n */\n:host {\n --track-color: var(--six-progress-track-color);\n --indicator-color: var(--six-progress-indicator-color);\n\n display: inline-flex;\n}\n\n.progress-ring {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n position: relative;\n}\n\n.progress-ring__image {\n transform: rotate(-90deg);\n transform-origin: 50% 50%;\n}\n\n.progress-ring__track {\n stroke: var(--track-color);\n}\n\n.progress-ring__indicator {\n stroke: var(--indicator-color);\n transition: 0.35s stroke-dashoffset, 0.35s stroke;\n}\n\n.progress-ring__label {\n display: flex;\n align-items: center;\n justify-content: center;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n text-align: center;\n user-select: none;\n font-family: var(--six-font-family);\n}\n","import { Component, h, Prop, Watch } from '@stencil/core';\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - A label to show inside the ring.\n *\n * @part base - The component's base wrapper.\n * @part label - The progress ring label.\n */\n\n@Component({\n tag: 'six-progress-ring',\n styleUrl: 'six-progress-ring.scss',\n shadow: true,\n})\nexport class SixProgressRing {\n private indicator?: SVGCircleElement;\n\n /** The size of the progress ring in pixels. */\n @Prop() size = 128;\n\n /** The stroke width of the progress ring in pixels. */\n @Prop() strokeWidth = 4;\n\n /** The current progress percentage, 0 - 100. */\n @Prop() percentage = 0;\n\n @Watch('percentage')\n handlePercentageChange() {\n this.updateProgress();\n }\n\n componentDidLoad() {\n this.updateProgress();\n }\n\n private updateProgress() {\n if (this.indicator?.r == null) return;\n\n const radius = this.indicator.r.baseVal.value;\n const circumference = radius * 2 * Math.PI;\n const offset = circumference - (this.percentage / 100) * circumference;\n\n this.indicator.style.strokeDasharray = `${circumference} ${circumference}`;\n this.indicator.style.strokeDashoffset = `${offset}`;\n }\n\n render() {\n return (\n <div part=\"base\" class=\"progress-ring\">\n <svg class=\"progress-ring__image\" width={this.size} height={this.size}>\n <circle\n class=\"progress-ring__track\"\n stroke-width={this.strokeWidth}\n stroke-linecap=\"round\"\n fill=\"transparent\"\n r={this.size / 2 - this.strokeWidth * 2}\n cx={this.size / 2}\n cy={this.size / 2}\n />\n\n <circle\n ref={(el) => (this.indicator = el as SVGCircleElement)}\n class=\"progress-ring__indicator\"\n stroke-width={this.strokeWidth}\n stroke-linecap=\"round\"\n fill=\"transparent\"\n r={this.size / 2 - this.strokeWidth * 2}\n cx={this.size / 2}\n cy={this.size / 2}\n />\n </svg>\n\n <span part=\"label\" class=\"progress-ring__label\">\n <slot />\n </span>\n </div>\n );\n }\n}\n"],"version":3}
@@ -15,9 +15,43 @@ const SixRadio$1 = /*@__PURE__*/ proxyCustomElement(class SixRadio extends HTMLE
15
15
  this.labelId = `radio-label-${id}`;
16
16
  /** default state whether the radio button should be checked or not when resetting */
17
17
  this.defaultState = false;
18
+ this.handleClick = () => {
19
+ if (this.nativeInput != null) {
20
+ this.checked = this.nativeInput.checked;
21
+ }
22
+ };
23
+ this.handleBlur = () => {
24
+ this.hasFocus = false;
25
+ this.sixBlur.emit();
26
+ };
27
+ this.handleFocus = () => {
28
+ this.hasFocus = true;
29
+ this.sixFocus.emit();
30
+ };
31
+ this.handleKeyDown = (event) => {
32
+ if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
33
+ const radios = this.getAllRadios().filter((radio) => !radio.disabled);
34
+ const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;
35
+ let index = radios.indexOf(this.host) + incr;
36
+ if (index < 0)
37
+ index = radios.length - 1;
38
+ if (index > radios.length - 1)
39
+ index = 0;
40
+ this.getAllRadios().map((radio) => (radio.checked = false));
41
+ radios[index].setFocus();
42
+ radios[index].checked = true;
43
+ event.preventDefault();
44
+ }
45
+ };
46
+ this.handleMouseDown = (event) => {
47
+ var _a;
48
+ // Prevent clicks on the label from briefly blurring the input
49
+ event.preventDefault();
50
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.focus();
51
+ };
18
52
  this.hasFocus = false;
19
- this.name = undefined;
20
- this.value = undefined;
53
+ this.name = '';
54
+ this.value = 'on';
21
55
  this.disabled = false;
22
56
  this.checked = false;
23
57
  this.invalid = false;
@@ -26,95 +60,66 @@ const SixRadio$1 = /*@__PURE__*/ proxyCustomElement(class SixRadio extends HTMLE
26
60
  if (this.checked) {
27
61
  this.getSiblingRadios().map((radio) => (radio.checked = false));
28
62
  }
29
- if (this.input) {
30
- this.input.checked = this.checked;
63
+ if (this.nativeInput != null) {
64
+ this.nativeInput.checked = this.checked;
31
65
  this.sixChange.emit();
32
66
  }
33
67
  }
34
- connectedCallback() {
35
- this.handleClick = this.handleClick.bind(this);
36
- this.handleBlur = this.handleBlur.bind(this);
37
- this.handleFocus = this.handleFocus.bind(this);
38
- this.handleKeyDown = this.handleKeyDown.bind(this);
39
- this.handleMouseDown = this.handleMouseDown.bind(this);
40
- }
41
68
  componentWillLoad() {
42
69
  this.defaultState = this.checked;
43
70
  }
44
71
  /** Sets focus on the radio. */
45
72
  async setFocus(options) {
46
- this.input.focus(options);
73
+ var _a;
74
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.focus(options);
47
75
  }
48
76
  /** Removes focus from the radio. */
49
77
  async removeFocus() {
50
- this.input.blur();
78
+ var _a;
79
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.blur();
51
80
  }
52
81
  /** Checks for validity and shows the browser's validation message if the control is invalid. */
53
82
  async reportValidity() {
54
- return this.input.reportValidity();
83
+ var _a;
84
+ return (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.reportValidity();
55
85
  }
56
86
  /** Checks for validity. */
57
87
  async checkValidity() {
58
- return this.input.validity.valid;
88
+ if (this.nativeInput == null) {
89
+ return true;
90
+ }
91
+ return this.nativeInput.validity.valid;
59
92
  }
60
93
  /** Sets a custom validation message. If `message` is not empty, the field will be considered invalid. */
61
94
  async setCustomValidity(message) {
62
- this.input.setCustomValidity(message);
63
- this.invalid = !this.input.checkValidity();
95
+ if (this.nativeInput != null) {
96
+ this.nativeInput.setCustomValidity(message);
97
+ this.invalid = !this.nativeInput.checkValidity();
98
+ }
64
99
  }
65
100
  /** Resets the formcontrol */
66
101
  async reset() {
102
+ var _a;
67
103
  this.checked = this.defaultState;
68
- this.input.setCustomValidity('');
104
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.setCustomValidity('');
69
105
  this.invalid = false;
70
106
  }
71
107
  getAllRadios() {
72
108
  const form = this.host.closest('six-form, form') || document.body;
73
- if (!this.name)
109
+ if (this.name === '')
74
110
  return [];
75
111
  return [...form.querySelectorAll('six-radio')].filter((radio) => radio.name === this.name);
76
112
  }
77
113
  getSiblingRadios() {
78
114
  return this.getAllRadios().filter((radio) => radio !== this.host);
79
115
  }
80
- handleClick() {
81
- this.checked = this.input.checked;
82
- }
83
- handleBlur() {
84
- this.hasFocus = false;
85
- this.sixBlur.emit();
86
- }
87
- handleFocus() {
88
- this.hasFocus = true;
89
- this.sixFocus.emit();
90
- }
91
- handleKeyDown(event) {
92
- if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
93
- const radios = this.getAllRadios().filter((radio) => !radio.disabled);
94
- const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;
95
- let index = radios.indexOf(this.host) + incr;
96
- if (index < 0)
97
- index = radios.length - 1;
98
- if (index > radios.length - 1)
99
- index = 0;
100
- this.getAllRadios().map((radio) => (radio.checked = false));
101
- radios[index].setFocus();
102
- radios[index].checked = true;
103
- event.preventDefault();
104
- }
105
- }
106
- handleMouseDown(event) {
107
- // Prevent clicks on the label from briefly blurring the input
108
- event.preventDefault();
109
- this.input.focus();
110
- }
111
116
  render() {
112
117
  return (h("label", { part: "base", class: {
113
118
  radio: true,
114
119
  'radio--checked': this.checked,
115
120
  'radio--disabled': this.disabled,
116
121
  'radio--focused': this.hasFocus,
117
- }, htmlFor: this.inputId, onKeyDown: this.handleKeyDown, onMouseDown: this.handleMouseDown }, h("span", { part: "control", class: "radio__control" }, h("span", { part: "checked-icon", class: "radio__icon" }, h("svg", { viewBox: "0 0 16 16" }, h("g", { stroke: "none", "stroke-width": "1", fill: "none", "fill-rule": "evenodd" }, h("g", { fill: "currentColor" }, h("circle", { cx: "8", cy: "8", r: "5" }))))), h("input", { ref: (el) => (this.input = el), id: this.inputId, type: "radio", name: this.name, value: this.value, checked: this.checked, disabled: this.disabled, role: "radio", "aria-checked": this.checked ? 'true' : 'false', "aria-labelledby": this.labelId, onClick: this.handleClick, onBlur: this.handleBlur, onFocus: this.handleFocus })), h("span", { part: "label", id: this.labelId, class: "radio__label" }, h("slot", null))));
122
+ }, htmlFor: this.inputId, onKeyDown: this.handleKeyDown, onMouseDown: this.handleMouseDown }, h("span", { part: "control", class: "radio__control" }, h("span", { part: "checked-icon", class: "radio__icon" }, h("svg", { viewBox: "0 0 16 16" }, h("g", { stroke: "none", "stroke-width": "1", fill: "none", "fill-rule": "evenodd" }, h("g", { fill: "currentColor" }, h("circle", { cx: "8", cy: "8", r: "5" }))))), h("input", { ref: (el) => (this.nativeInput = el), id: this.inputId, type: "radio", name: this.name, value: this.value, checked: this.checked, disabled: this.disabled, role: "radio", "aria-checked": this.checked ? 'true' : 'false', "aria-labelledby": this.labelId, onClick: this.handleClick, onBlur: this.handleBlur, onFocus: this.handleFocus })), h("span", { part: "label", id: this.labelId, class: "radio__label" }, h("slot", null))));
118
123
  }
119
124
  get host() { return this; }
120
125
  static get watchers() { return {
@@ -1 +1 @@
1
- {"file":"six-radio.js","mappings":"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","names":["SixRadio"],"sources":["./src/components/six-radio/six-radio.scss?tag=six-radio&encapsulation=shadow","./src/components/six-radio/six-radio.tsx"],"sourcesContent":["@import 'src/global/component';\n\n:host {\n display: inline-block;\n}\n\n.radio {\n display: inline-flex;\n align-items: center;\n font-family: var(--six-font-family);\n font-size: var(--six-input-font-size-medium);\n font-weight: var(--six-input-font-weight);\n color: var(--six-input-color);\n vertical-align: middle;\n cursor: pointer;\n}\n\n.radio__icon {\n display: inline-flex;\n width: var(--six-selection-control-toggle-size);\n height: var(--six-selection-control-toggle-size);\n\n svg {\n width: 100%;\n height: 100%;\n }\n}\n\n.radio__control {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--six-selection-control-toggle-size);\n height: var(--six-selection-control-toggle-size);\n border: solid var(--six-border-width) var(--six-input-border-color);\n border-radius: 50%;\n background-color: var(--six-input-background-color);\n color: transparent;\n transition: var(--six-transition-fast) border-color, var(--six-transition-fast) background-color,\n var(--six-transition-fast) color, var(--six-transition-fast) box-shadow;\n\n input[type='radio'] {\n position: absolute;\n opacity: 0;\n padding: 0;\n margin: 0;\n pointer-events: none;\n }\n}\n\n// Hover\n.radio:not(.radio--checked):not(.radio--disabled) .radio__control:hover {\n border-color: var(--six-input-border-color-hover);\n}\n\n// Checked\n.radio--checked .radio__control {\n color: var(--six-selection-control-color);\n border-color: var(--six-selection-control-color);\n}\n\n// Checked + hover\n.radio.radio--checked:not(.radio--disabled) .radio__control:hover {\n color: var(--six-input-border-color-focus);\n border-color: var(--six-input-border-color-focus);\n}\n\n// Disabled\n.radio--disabled {\n cursor: not-allowed;\n color: var(--six-input-color-disabled);\n\n .radio__control {\n border-color: var(--six-input-border-color-disabled);\n }\n\n &.radio--checked .radio__control {\n color: var(--six-selection-control-color-disabled);\n }\n}\n\n.radio__label {\n line-height: var(--six-selection-control-toggle-size);\n margin-left: 0.5em;\n user-select: none;\n}\n","import { Component, Element, Event, EventEmitter, Method, Prop, State, Watch, h } from '@stencil/core';\nimport { EmptyPayload } from '../../utils/types';\n\nlet id = 0;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The radio's label.\n *\n * @part base - The component's base wrapper.\n * @part control - The radio control.\n * @part checked-icon - The container the wraps the checked icon.\n * @part label - The radio label.\n */\n\n@Component({\n tag: 'six-radio',\n styleUrl: 'six-radio.scss',\n shadow: true,\n})\nexport class SixRadio {\n inputId = `radio-${++id}`;\n labelId = `radio-label-${id}`;\n input: HTMLInputElement;\n\n @Element() host: HTMLSixRadioElement;\n\n @State() hasFocus = false;\n\n /** The radio's name attribute. */\n @Prop() name: string;\n\n /** The radio's value attribute. */\n @Prop() value: string;\n\n /** Set to true to disable the radio. */\n @Prop() disabled = false;\n\n /** Set to true to draw the radio in a checked state. */\n @Prop({ mutable: true, reflect: true }) checked = false;\n\n /**\n * This will be true when the control is in an invalid state. Validity in range inputs is determined by the message\n * provided by the `setCustomValidity` method.\n */\n @Prop({ mutable: true, reflect: true }) invalid = false;\n\n @Watch('checked')\n handleCheckedChange() {\n if (this.checked) {\n this.getSiblingRadios().map((radio) => (radio.checked = false));\n }\n if (this.input) {\n this.input.checked = this.checked;\n this.sixChange.emit();\n }\n }\n\n /** Emitted when the control loses focus. */\n @Event({ eventName: 'six-radio-blur' }) sixBlur: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control's checked state changes. */\n @Event({ eventName: 'six-radio-change' }) sixChange: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control gains focus. */\n @Event({ eventName: 'six-radio-focus' }) sixFocus: EventEmitter<EmptyPayload>;\n\n /** default state whether the radio button should be checked or not when resetting */\n private defaultState = false;\n\n connectedCallback() {\n this.handleClick = this.handleClick.bind(this);\n this.handleBlur = this.handleBlur.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleKeyDown = this.handleKeyDown.bind(this);\n this.handleMouseDown = this.handleMouseDown.bind(this);\n }\n\n componentWillLoad() {\n this.defaultState = this.checked;\n }\n\n /** Sets focus on the radio. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.input.focus(options);\n }\n\n /** Removes focus from the radio. */\n @Method()\n async removeFocus() {\n this.input.blur();\n }\n\n /** Checks for validity and shows the browser's validation message if the control is invalid. */\n @Method()\n async reportValidity() {\n return this.input.reportValidity();\n }\n\n /** Checks for validity. */\n @Method()\n async checkValidity() {\n return this.input.validity.valid;\n }\n\n /** Sets a custom validation message. If `message` is not empty, the field will be considered invalid. */\n @Method()\n async setCustomValidity(message: string) {\n this.input.setCustomValidity(message);\n this.invalid = !this.input.checkValidity();\n }\n\n /** Resets the formcontrol */\n @Method()\n async reset() {\n this.checked = this.defaultState;\n this.input.setCustomValidity('');\n this.invalid = false;\n }\n\n getAllRadios() {\n const form = this.host.closest('six-form, form') || document.body;\n\n if (!this.name) return [];\n\n return [...form.querySelectorAll('six-radio')].filter(\n (radio: HTMLSixRadioElement) => radio.name === this.name\n ) as HTMLSixRadioElement[];\n }\n\n getSiblingRadios() {\n return this.getAllRadios().filter((radio) => radio !== this.host) as HTMLSixRadioElement[];\n }\n\n handleClick() {\n this.checked = this.input.checked;\n }\n\n handleBlur() {\n this.hasFocus = false;\n this.sixBlur.emit();\n }\n\n handleFocus() {\n this.hasFocus = true;\n this.sixFocus.emit();\n }\n\n handleKeyDown(event: KeyboardEvent) {\n if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {\n const radios = this.getAllRadios().filter((radio) => !radio.disabled);\n const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;\n let index = radios.indexOf(this.host) + incr;\n if (index < 0) index = radios.length - 1;\n if (index > radios.length - 1) index = 0;\n\n this.getAllRadios().map((radio) => (radio.checked = false));\n radios[index].setFocus();\n radios[index].checked = true;\n\n event.preventDefault();\n }\n }\n\n handleMouseDown(event: MouseEvent) {\n // Prevent clicks on the label from briefly blurring the input\n event.preventDefault();\n this.input.focus();\n }\n\n render() {\n return (\n <label\n part=\"base\"\n class={{\n radio: true,\n 'radio--checked': this.checked,\n 'radio--disabled': this.disabled,\n 'radio--focused': this.hasFocus,\n }}\n htmlFor={this.inputId}\n onKeyDown={this.handleKeyDown}\n onMouseDown={this.handleMouseDown}\n >\n <span part=\"control\" class=\"radio__control\">\n <span part=\"checked-icon\" class=\"radio__icon\">\n <svg viewBox=\"0 0 16 16\">\n <g stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <g fill=\"currentColor\">\n <circle cx=\"8\" cy=\"8\" r=\"5\"></circle>\n </g>\n </g>\n </svg>\n </span>\n\n <input\n ref={(el) => (this.input = el)}\n id={this.inputId}\n type=\"radio\"\n name={this.name}\n value={this.value}\n checked={this.checked}\n disabled={this.disabled}\n role=\"radio\"\n aria-checked={this.checked ? 'true' : 'false'}\n aria-labelledby={this.labelId}\n onClick={this.handleClick}\n onBlur={this.handleBlur}\n onFocus={this.handleFocus}\n />\n </span>\n\n <span part=\"label\" id={this.labelId} class=\"radio__label\">\n <slot />\n </span>\n </label>\n );\n }\n}\n"],"version":3}
1
+ {"file":"six-radio.js","mappings":"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","names":["SixRadio"],"sources":["./src/components/six-radio/six-radio.scss?tag=six-radio&encapsulation=shadow","./src/components/six-radio/six-radio.tsx"],"sourcesContent":["@import 'src/global/component';\n\n:host {\n display: inline-block;\n}\n\n.radio {\n display: inline-flex;\n align-items: center;\n font-family: var(--six-font-family);\n font-size: var(--six-input-font-size-medium);\n font-weight: var(--six-input-font-weight);\n color: var(--six-input-color);\n vertical-align: middle;\n cursor: pointer;\n}\n\n.radio__icon {\n display: inline-flex;\n width: var(--six-selection-control-toggle-size);\n height: var(--six-selection-control-toggle-size);\n\n svg {\n width: 100%;\n height: 100%;\n }\n}\n\n.radio__control {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: var(--six-selection-control-toggle-size);\n height: var(--six-selection-control-toggle-size);\n border: solid var(--six-border-width) var(--six-input-border-color);\n border-radius: 50%;\n background-color: var(--six-input-background-color);\n color: transparent;\n transition: var(--six-transition-fast) border-color, var(--six-transition-fast) background-color,\n var(--six-transition-fast) color, var(--six-transition-fast) box-shadow;\n\n input[type='radio'] {\n position: absolute;\n opacity: 0;\n padding: 0;\n margin: 0;\n pointer-events: none;\n }\n}\n\n// Hover\n.radio:not(.radio--checked):not(.radio--disabled) .radio__control:hover {\n border-color: var(--six-input-border-color-hover);\n}\n\n// Checked\n.radio--checked .radio__control {\n color: var(--six-selection-control-color);\n border-color: var(--six-selection-control-color);\n}\n\n// Checked + hover\n.radio.radio--checked:not(.radio--disabled) .radio__control:hover {\n color: var(--six-input-border-color-focus);\n border-color: var(--six-input-border-color-focus);\n}\n\n// Disabled\n.radio--disabled {\n cursor: not-allowed;\n color: var(--six-input-color-disabled);\n\n .radio__control {\n border-color: var(--six-input-border-color-disabled);\n }\n\n &.radio--checked .radio__control {\n color: var(--six-selection-control-color-disabled);\n }\n}\n\n.radio__label {\n line-height: var(--six-selection-control-toggle-size);\n margin-left: 0.5em;\n user-select: none;\n}\n","import { Component, Element, Event, EventEmitter, h, Method, Prop, State, Watch } from '@stencil/core';\nimport { EmptyPayload } from '../../utils/types';\n\nlet id = 0;\n\n/**\n * @since 1.0\n * @status stable\n *\n * Forked from https://github.com/shoelace-style/shoelace version v2.0.0-beta27.\n *\n * @slot - The radio's label.\n *\n * @part base - The component's base wrapper.\n * @part control - The radio control.\n * @part checked-icon - The container the wraps the checked icon.\n * @part label - The radio label.\n */\n\n@Component({\n tag: 'six-radio',\n styleUrl: 'six-radio.scss',\n shadow: true,\n})\nexport class SixRadio {\n private inputId = `radio-${++id}`;\n private labelId = `radio-label-${id}`;\n private nativeInput?: HTMLInputElement;\n\n @Element() host!: HTMLSixRadioElement;\n\n @State() hasFocus = false;\n\n /** The radio's name attribute. */\n @Prop() name = '';\n\n /** The radio's value attribute. */\n @Prop() value = 'on';\n\n /** Set to true to disable the radio. */\n @Prop() disabled = false;\n\n /** Set to true to draw the radio in a checked state. */\n @Prop({ mutable: true, reflect: true }) checked = false;\n\n /**\n * This will be true when the control is in an invalid state. Validity in range inputs is determined by the message\n * provided by the `setCustomValidity` method.\n */\n @Prop({ mutable: true, reflect: true }) invalid = false;\n\n @Watch('checked')\n handleCheckedChange() {\n if (this.checked) {\n this.getSiblingRadios().map((radio) => (radio.checked = false));\n }\n if (this.nativeInput != null) {\n this.nativeInput.checked = this.checked;\n this.sixChange.emit();\n }\n }\n\n /** Emitted when the control loses focus. */\n @Event({ eventName: 'six-radio-blur' }) sixBlur!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control's checked state changes. */\n @Event({ eventName: 'six-radio-change' }) sixChange!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control gains focus. */\n @Event({ eventName: 'six-radio-focus' }) sixFocus!: EventEmitter<EmptyPayload>;\n\n /** default state whether the radio button should be checked or not when resetting */\n private defaultState = false;\n\n componentWillLoad() {\n this.defaultState = this.checked;\n }\n\n /** Sets focus on the radio. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.nativeInput?.focus(options);\n }\n\n /** Removes focus from the radio. */\n @Method()\n async removeFocus() {\n this.nativeInput?.blur();\n }\n\n /** Checks for validity and shows the browser's validation message if the control is invalid. */\n @Method()\n async reportValidity() {\n return this.nativeInput?.reportValidity();\n }\n\n /** Checks for validity. */\n @Method()\n async checkValidity() {\n if (this.nativeInput == null) {\n return true;\n }\n return this.nativeInput.validity.valid;\n }\n\n /** Sets a custom validation message. If `message` is not empty, the field will be considered invalid. */\n @Method()\n async setCustomValidity(message: string) {\n if (this.nativeInput != null) {\n this.nativeInput.setCustomValidity(message);\n this.invalid = !this.nativeInput.checkValidity();\n }\n }\n\n /** Resets the formcontrol */\n @Method()\n async reset() {\n this.checked = this.defaultState;\n this.nativeInput?.setCustomValidity('');\n this.invalid = false;\n }\n\n private getAllRadios() {\n const form = this.host.closest('six-form, form') || document.body;\n\n if (this.name === '') return [];\n\n return [...form.querySelectorAll('six-radio')].filter(\n (radio: HTMLSixRadioElement) => radio.name === this.name\n ) as HTMLSixRadioElement[];\n }\n\n private getSiblingRadios() {\n return this.getAllRadios().filter((radio) => radio !== this.host) as HTMLSixRadioElement[];\n }\n\n private handleClick = () => {\n if (this.nativeInput != null) {\n this.checked = this.nativeInput.checked;\n }\n };\n\n private handleBlur = () => {\n this.hasFocus = false;\n this.sixBlur.emit();\n };\n\n private handleFocus = () => {\n this.hasFocus = true;\n this.sixFocus.emit();\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {\n const radios = this.getAllRadios().filter((radio) => !radio.disabled);\n const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;\n let index = radios.indexOf(this.host) + incr;\n if (index < 0) index = radios.length - 1;\n if (index > radios.length - 1) index = 0;\n\n this.getAllRadios().map((radio) => (radio.checked = false));\n radios[index].setFocus();\n radios[index].checked = true;\n\n event.preventDefault();\n }\n };\n\n private handleMouseDown = (event: MouseEvent) => {\n // Prevent clicks on the label from briefly blurring the input\n event.preventDefault();\n this.nativeInput?.focus();\n };\n\n render() {\n return (\n <label\n part=\"base\"\n class={{\n radio: true,\n 'radio--checked': this.checked,\n 'radio--disabled': this.disabled,\n 'radio--focused': this.hasFocus,\n }}\n htmlFor={this.inputId}\n onKeyDown={this.handleKeyDown}\n onMouseDown={this.handleMouseDown}\n >\n <span part=\"control\" class=\"radio__control\">\n <span part=\"checked-icon\" class=\"radio__icon\">\n <svg viewBox=\"0 0 16 16\">\n <g stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <g fill=\"currentColor\">\n <circle cx=\"8\" cy=\"8\" r=\"5\"></circle>\n </g>\n </g>\n </svg>\n </span>\n\n <input\n ref={(el) => (this.nativeInput = el)}\n id={this.inputId}\n type=\"radio\"\n name={this.name}\n value={this.value}\n checked={this.checked}\n disabled={this.disabled}\n role=\"radio\"\n aria-checked={this.checked ? 'true' : 'false'}\n aria-labelledby={this.labelId}\n onClick={this.handleClick}\n onBlur={this.handleBlur}\n onFocus={this.handleFocus}\n />\n </span>\n\n <span part=\"label\" id={this.labelId} class=\"radio__label\">\n <slot />\n </span>\n </label>\n );\n }\n}\n"],"version":3}
@@ -17,20 +17,54 @@ const SixRange$1 = /*@__PURE__*/ proxyCustomElement(class SixRange extends HTMLE
17
17
  this.inputId = `input-${++id}`;
18
18
  this.labelId = `input-label-${id}`;
19
19
  this.helpTextId = `input-help-text-${id}`;
20
- this.errorTextId = `input-error-text-${id}`;
21
20
  this.customErrorText = '';
22
21
  this.customValidation = false;
22
+ this.errorTextId = `input-error-text-${id}`;
23
23
  this.eventListeners = new EventListeners();
24
24
  /** default value the slider will be reverted to when reset is executed */
25
25
  this.defaultValue = 0;
26
+ this.handleInput = () => {
27
+ if (this.nativeInput != null) {
28
+ this.update(parseFloat(this.nativeInput.value));
29
+ }
30
+ requestAnimationFrame(() => {
31
+ this.sixChange.emit();
32
+ });
33
+ };
34
+ this.handleBlur = () => {
35
+ var _a;
36
+ this.hasFocus = false;
37
+ this.hasTooltip = false;
38
+ this.sixBlur.emit();
39
+ if (this.nativeInput != null) {
40
+ (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.unobserve(this.nativeInput);
41
+ }
42
+ };
43
+ this.handleFocus = () => {
44
+ var _a;
45
+ this.hasFocus = true;
46
+ this.hasTooltip = true;
47
+ this.sixFocus.emit();
48
+ if (this.nativeInput != null) {
49
+ (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.observe(this.nativeInput);
50
+ }
51
+ };
52
+ this.handleSlotChange = () => {
53
+ this.hasHelpTextSlot = hasSlot(this.host, 'help-text');
54
+ this.hasErrorTextSlot = hasSlot(this.host, 'error-text');
55
+ this.hasLabelSlot = hasSlot(this.host, 'label');
56
+ };
57
+ this.handleTouchStart = () => {
58
+ this.setFocus();
59
+ };
26
60
  this.hasFocus = false;
27
61
  this.hasHelpTextSlot = false;
28
62
  this.hasLabelSlot = false;
29
63
  this.hasErrorTextSlot = false;
30
64
  this.hasTooltip = false;
31
65
  this.name = '';
32
- this.value = undefined;
33
- this.required = undefined;
66
+ this.value = 0;
67
+ this.required = false;
34
68
  this.label = '';
35
69
  this.helpText = '';
36
70
  this.errorText = '';
@@ -47,119 +81,125 @@ const SixRange$1 = /*@__PURE__*/ proxyCustomElement(class SixRange extends HTMLE
47
81
  this.handleSlotChange();
48
82
  }
49
83
  handleValueChange() {
50
- if (this.input) {
51
- this.input.value = this.value;
52
- this.calculateColorRunnableTrack();
84
+ this.update();
85
+ if (this.nativeInput != null) {
86
+ this.invalid = !this.nativeInput.checkValidity();
53
87
  }
54
- // In rare cases, the watcher may be called before render so we need to make sure the input exists
55
- this.invalid = this.input ? !this.input.checkValidity() : false;
56
88
  }
57
89
  connectedCallback() {
58
- this.handleInput = this.handleInput.bind(this);
59
- this.handleBlur = this.handleBlur.bind(this);
60
- this.handleFocus = this.handleFocus.bind(this);
61
- this.handleSlotChange = this.handleSlotChange.bind(this);
62
- this.handleTouchStart = this.handleTouchStart.bind(this);
63
- this.host.shadowRoot.addEventListener('slotchange', this.handleSlotChange);
90
+ var _a;
91
+ (_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.addEventListener('slotchange', this.handleSlotChange);
64
92
  }
65
93
  componentWillLoad() {
66
- if (this.value === undefined || this.value === null)
67
- this.value = this.min;
68
- if (this.value < this.min)
69
- this.value = this.min;
70
- if (this.value > this.max)
71
- this.value = this.max;
94
+ this.update();
72
95
  this.defaultValue = this.value;
73
96
  this.handleSlotChange();
74
97
  }
75
98
  componentDidLoad() {
76
- this.syncTooltip();
77
- this.calculateColorRunnableTrack();
78
- this.resizeObserver = new ResizeObserver(() => this.syncTooltip());
79
- this.eventListeners.add(this.input, 'invalid', (event) => {
80
- if (this.customValidation || (!this.hasErrorTextSlot && !this.errorText && !this.customErrorText)) {
81
- this.customErrorText = this.input.validationMessage;
99
+ const nativeInput = this.nativeInput;
100
+ if (nativeInput == null) {
101
+ return;
102
+ }
103
+ this.update();
104
+ this.resizeObserver = new ResizeObserver(() => this.update());
105
+ this.eventListeners.add(nativeInput, 'invalid', (event) => {
106
+ if (this.customValidation || (!this.hasErrorTextSlot && this.errorText === '' && this.customErrorText === '')) {
107
+ this.customErrorText = nativeInput.validationMessage;
82
108
  }
83
109
  event.preventDefault();
84
110
  });
85
111
  }
86
112
  disconnectedCallback() {
87
- this.host.shadowRoot.removeEventListener('slotchange', this.handleSlotChange);
113
+ var _a;
114
+ (_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.removeEventListener('slotchange', this.handleSlotChange);
88
115
  this.eventListeners.removeAll();
89
116
  }
90
117
  /** Sets focus on the input. */
91
118
  async setFocus(options) {
92
- this.input.focus(options);
119
+ var _a;
120
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.focus(options);
93
121
  }
94
122
  /** Removes focus from the input. */
95
123
  async removeFocus() {
96
- this.input.blur();
124
+ var _a;
125
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.blur();
97
126
  }
98
127
  /** Sets a custom validation message. If `message` is not empty, the field will be considered invalid. */
99
128
  async setCustomValidity(message) {
100
129
  this.customErrorText = '';
101
130
  this.customValidation = message !== '';
102
- this.input.setCustomValidity(message);
103
- this.invalid = !this.input.checkValidity();
131
+ if (this.nativeInput != null) {
132
+ this.nativeInput.setCustomValidity(message);
133
+ this.invalid = !this.nativeInput.checkValidity();
134
+ }
104
135
  }
105
136
  /** Resets the formcontrol */
106
137
  async reset() {
138
+ var _a;
107
139
  this.value = this.defaultValue;
108
140
  this.customErrorText = '';
109
141
  this.customValidation = false;
110
- this.input.setCustomValidity('');
142
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.setCustomValidity('');
111
143
  this.invalid = false;
112
144
  }
113
- handleInput() {
114
- this.value = Number(this.input.value);
115
- this.sixChange.emit();
116
- requestAnimationFrame(() => this.syncTooltip());
117
- requestAnimationFrame(() => this.calculateColorRunnableTrack());
118
- }
119
- handleBlur() {
120
- this.hasFocus = false;
121
- this.hasTooltip = false;
122
- this.sixBlur.emit();
123
- this.resizeObserver.unobserve(this.input);
124
- }
125
- handleFocus() {
126
- this.hasFocus = true;
127
- this.hasTooltip = true;
128
- this.sixFocus.emit();
129
- this.resizeObserver.observe(this.input);
130
- }
131
- handleSlotChange() {
132
- this.hasHelpTextSlot = hasSlot(this.host, 'help-text');
133
- this.hasErrorTextSlot = hasSlot(this.host, 'error-text');
134
- this.hasLabelSlot = hasSlot(this.host, 'label');
135
- }
136
- handleTouchStart() {
137
- this.setFocus();
138
- }
139
145
  displayError() {
140
146
  return this.invalid && (!this.errorOnBlur || !this.hasFocus);
141
147
  }
142
- syncTooltip() {
143
- if (this.tooltip !== 'none') {
144
- const percent = Math.max(0, (this.value - this.min) / (this.max - this.min));
145
- const inputWidth = this.input.offsetWidth;
148
+ syncTooltip(min, max, value) {
149
+ if (this.tooltip !== 'none' && this.nativeInput != null && this.output != null) {
150
+ const percent = Math.max(0, (value - min) / (max - min));
151
+ const inputWidth = this.nativeInput.offsetWidth;
146
152
  const tooltipWidth = this.output.offsetWidth;
147
- const thumbSize = getComputedStyle(this.input).getPropertyValue('--thumb-size');
153
+ const thumbSize = getComputedStyle(this.nativeInput).getPropertyValue('--thumb-size');
148
154
  const x = `calc(${inputWidth * percent}px - calc(calc(${percent} * ${thumbSize}) - calc(${thumbSize} / 2)))`;
149
155
  this.output.style.transform = `translateX(${x})`;
150
156
  this.output.style.marginLeft = `-${tooltipWidth / 2}px`;
151
157
  }
152
158
  }
159
+ isFirefox() {
160
+ return navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
161
+ }
162
+ update(updateValue) {
163
+ var _a, _b;
164
+ if (updateValue != null) {
165
+ this.value = updateValue;
166
+ }
167
+ const min = (_a = Number(this.min)) !== null && _a !== void 0 ? _a : 0;
168
+ const max = (_b = Number(this.max)) !== null && _b !== void 0 ? _b : 0;
169
+ let value;
170
+ const parsedValue = parseFloat(this.value);
171
+ if (isNaN(parsedValue)) {
172
+ value = this.getDefaultValue(min, max);
173
+ }
174
+ else {
175
+ value = parsedValue;
176
+ }
177
+ if (this.nativeInput != null) {
178
+ // The value may have constraints, so we set the native control's
179
+ // value and sync it back to ensure it adheres to min, max, and step
180
+ // properly.
181
+ this.nativeInput.value = value.toString();
182
+ this.value = parseFloat(this.nativeInput.value);
183
+ }
184
+ else {
185
+ this.value = value;
186
+ }
187
+ this.calculateColorRunnableTrack(min, max, this.value);
188
+ this.syncTooltip(min, max, this.value);
189
+ }
190
+ /**
191
+ * from https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value
192
+ */
193
+ getDefaultValue(min, max) {
194
+ return max < min ? min : min + (max - min) / 2;
195
+ }
153
196
  /**
154
197
  * For Firefox this functionality is not needed because it is supported by standard CSS.
155
198
  */
156
- calculateColorRunnableTrack() {
157
- if (!this.isFirefox()) {
158
- const value = parseInt(this.input.value, 10);
159
- const min = parseInt(this.input.min, 10);
160
- const max = parseInt(this.input.max, 10);
199
+ calculateColorRunnableTrack(min, max, value) {
200
+ if (!this.isFirefox() && this.nativeInput != null) {
161
201
  const percent = Math.ceil(((value - min) / (max - min)) * 100);
162
- this.input.style.background =
202
+ this.nativeInput.style.background =
163
203
  '-webkit-linear-gradient(left, var(--track-color) 0%, var(--track-color) ' +
164
204
  percent +
165
205
  '%, var(--six-color-web-rock-300) ' +
@@ -167,11 +207,8 @@ const SixRange$1 = /*@__PURE__*/ proxyCustomElement(class SixRange extends HTMLE
167
207
  '%)';
168
208
  }
169
209
  }
170
- isFirefox() {
171
- return navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
172
- }
173
210
  render() {
174
- return (h(FormControl, { inputId: this.inputId, label: this.label, labelId: this.labelId, hasLabelSlot: this.hasLabelSlot, helpTextId: this.helpTextId, helpText: this.helpText, hasHelpTextSlot: this.hasHelpTextSlot, size: "medium", errorTextId: this.errorTextId, errorText: this.customErrorText ? this.customErrorText : this.errorText, hasErrorTextSlot: this.hasErrorTextSlot, disabled: this.disabled, required: this.required, displayError: this.displayError() }, h("div", { part: "base", class: {
211
+ return (h(FormControl, { inputId: this.inputId, label: this.label, labelId: this.labelId, hasLabelSlot: this.hasLabelSlot, helpTextId: this.helpTextId, helpText: this.helpText, hasHelpTextSlot: this.hasHelpTextSlot, size: "medium", errorTextId: this.errorTextId, errorText: this.customErrorText != null ? this.customErrorText : this.errorText, hasErrorTextSlot: this.hasErrorTextSlot, disabled: this.disabled, required: this.required, displayError: this.displayError() }, h("div", { part: "base", class: {
175
212
  range: true,
176
213
  // States
177
214
  'range--disabled': this.disabled,
@@ -179,14 +216,16 @@ const SixRange$1 = /*@__PURE__*/ proxyCustomElement(class SixRange extends HTMLE
179
216
  'range--tooltip-visible': this.hasTooltip,
180
217
  'range--tooltip-top': this.tooltip === 'top',
181
218
  'range--tooltip-bottom': this.tooltip === 'bottom',
182
- }, onTouchStart: this.handleTouchStart }, h("input", { part: "input", ref: (el) => (this.input = el), type: "range", class: "range__control", name: this.name, disabled: this.disabled, min: this.min, max: this.max, step: this.step, value: this.value, onInput: this.handleInput, onFocus: this.handleFocus, onBlur: this.handleBlur }), this.tooltip !== 'none' && (h("output", { part: "tooltip", ref: (el) => (this.output = el), class: "range__tooltip" }, this.tooltipFormatter(this.value))))));
219
+ }, onTouchStart: this.handleTouchStart }, h("input", { part: "input", ref: (el) => (this.nativeInput = el), type: "range", class: "range__control", name: this.name, disabled: this.disabled, min: this.min, max: this.max, step: this.step, value: this.value, onInput: this.handleInput, onFocus: this.handleFocus, onBlur: this.handleBlur }), this.tooltip !== 'none' && (h("output", { part: "tooltip", ref: (el) => (this.output = el), class: "range__tooltip" }, this.tooltipFormatter(this.value))))));
183
220
  }
184
221
  get host() { return this; }
185
222
  static get watchers() { return {
186
223
  "label": ["handleLabelChange"],
187
224
  "errorText": ["handleLabelChange"],
188
225
  "helpText": ["handleLabelChange"],
189
- "value": ["handleValueChange"]
226
+ "value": ["handleValueChange"],
227
+ "min": ["handleValueChange"],
228
+ "max": ["handleValueChange"]
190
229
  }; }
191
230
  static get style() { return sixRangeCss; }
192
231
  }, [1, "six-range", {