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

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 (738) hide show
  1. package/dist/cjs/event-listeners-b835dfae.js +61 -0
  2. package/dist/cjs/event-listeners-b835dfae.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-8cbd4e0e.js +20 -0
  8. package/dist/cjs/form-8cbd4e0e.js.map +1 -0
  9. package/dist/cjs/{form-control-2c17c573.js → form-control-8df00a52.js} +9 -10
  10. package/dist/cjs/form-control-8df00a52.js.map +1 -0
  11. package/dist/cjs/index.cjs.js +94 -0
  12. package/dist/cjs/index.cjs.js.map +1 -1
  13. package/dist/cjs/loader.cjs.js +1 -1
  14. package/dist/cjs/{modal-48d42228.js → modal-21350fb5.js} +4 -3
  15. package/dist/cjs/modal-21350fb5.js.map +1 -0
  16. package/dist/cjs/{popover-f743f62b.js → popover-8885d50f.js} +39 -31
  17. package/dist/cjs/popover-8885d50f.js.map +1 -0
  18. package/dist/cjs/popup-44836aaf.js +103 -0
  19. package/dist/cjs/popup-44836aaf.js.map +1 -0
  20. package/dist/cjs/set-attributes_2.cjs.entry.js +3 -1
  21. package/dist/cjs/set-attributes_2.cjs.entry.js.map +1 -1
  22. package/dist/cjs/six-alert.cjs.entry.js +17 -22
  23. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  24. package/dist/cjs/six-avatar.cjs.entry.js +4 -7
  25. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  26. package/dist/cjs/six-badge.cjs.entry.js +1 -1
  27. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  28. package/dist/cjs/six-button.cjs.entry.js +35 -33
  29. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  30. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  31. package/dist/cjs/six-checkbox.cjs.entry.js +48 -75
  32. package/dist/cjs/six-checkbox.cjs.entry.js.map +1 -1
  33. package/dist/cjs/six-datepicker.cjs.entry.js +150 -278
  34. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  35. package/dist/cjs/six-details.cjs.entry.js +47 -46
  36. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  37. package/dist/cjs/six-dialog.cjs.entry.js +35 -39
  38. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  39. package/dist/cjs/six-drawer.cjs.entry.js +32 -36
  40. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  41. package/dist/cjs/six-dropdown_2.cjs.entry.js +214 -195
  42. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  43. package/dist/cjs/six-error-page.cjs.entry.js +19 -21
  44. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  45. package/dist/cjs/six-file-list-item.cjs.entry.js +1 -1
  46. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  47. package/dist/cjs/six-file-upload.cjs.entry.js +20 -20
  48. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  49. package/dist/cjs/six-group-label.cjs.entry.js +11 -10
  50. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  51. package/dist/cjs/six-header.cjs.entry.js +65 -43
  52. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  53. package/dist/cjs/six-icon-button.cjs.entry.js +3 -3
  54. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  55. package/dist/cjs/six-input.cjs.entry.js +93 -126
  56. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  57. package/dist/cjs/six-item-picker.cjs.entry.js +58 -77
  58. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  59. package/dist/cjs/six-language-switcher.cjs.entry.js +1 -1
  60. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  61. package/dist/cjs/six-layout-grid.cjs.entry.js +4 -2
  62. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  63. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  64. package/dist/cjs/six-menu-item.cjs.entry.js +8 -6
  65. package/dist/cjs/six-menu-item.cjs.entry.js.map +1 -1
  66. package/dist/cjs/six-picto.cjs.entry.js +4 -1
  67. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  68. package/dist/cjs/six-progress-ring.cjs.entry.js +3 -3
  69. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  70. package/dist/cjs/six-radio.cjs.entry.js +59 -60
  71. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  72. package/dist/cjs/six-range.cjs.entry.js +106 -105
  73. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  74. package/dist/cjs/six-root.cjs.entry.js +1 -1
  75. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  76. package/dist/cjs/six-search-field.cjs.entry.js +10 -5
  77. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  78. package/dist/cjs/six-select.cjs.entry.js +185 -219
  79. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  80. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +9 -5
  81. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  82. package/dist/cjs/six-sidebar.cjs.entry.js +39 -18
  83. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  84. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  85. package/dist/cjs/six-switch.cjs.entry.js +54 -62
  86. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  87. package/dist/cjs/six-tab-group.cjs.entry.js +130 -112
  88. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  89. package/dist/cjs/six-tab-panel.cjs.entry.js +1 -1
  90. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  91. package/dist/cjs/six-tab.cjs.entry.js +4 -2
  92. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  93. package/dist/cjs/six-tag.cjs.entry.js +4 -7
  94. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  95. package/dist/cjs/six-textarea.cjs.entry.js +87 -109
  96. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  97. package/dist/cjs/six-tile.cjs.entry.js +13 -16
  98. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  99. package/dist/cjs/six-timepicker.cjs.entry.js +157 -213
  100. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  101. package/dist/cjs/six-tooltip.cjs.entry.js +53 -56
  102. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  103. package/dist/cjs/{slot-ad537f24.js → slot-bccbdb59.js} +11 -10
  104. package/dist/cjs/slot-bccbdb59.js.map +1 -0
  105. package/dist/cjs/ui-library.cjs.js +1 -1
  106. package/dist/collection/collection-manifest.json +0 -1
  107. package/dist/collection/components/six-alert/six-alert.js +17 -22
  108. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  109. package/dist/collection/components/six-avatar/six-avatar.js +4 -7
  110. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  111. package/dist/collection/components/six-badge/six-badge.js +1 -1
  112. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  113. package/dist/collection/components/six-button/six-button.js +44 -40
  114. package/dist/collection/components/six-button/six-button.js.map +1 -1
  115. package/dist/collection/components/six-card/six-card.js +1 -1
  116. package/dist/collection/components/six-card/six-card.js.map +1 -1
  117. package/dist/collection/components/six-checkbox/six-checkbox.js +64 -159
  118. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  119. package/dist/collection/components/six-datepicker/components/day-selection.js +2 -2
  120. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  121. package/dist/collection/components/six-datepicker/components/month-selection.js +4 -3
  122. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  123. package/dist/collection/components/six-datepicker/components/year-selection.js +9 -6
  124. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  125. package/dist/collection/components/six-datepicker/six-datepicker.js +186 -376
  126. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  127. package/dist/collection/components/six-details/six-details.js +51 -50
  128. package/dist/collection/components/six-details/six-details.js.map +1 -1
  129. package/dist/collection/components/six-dialog/six-dialog.js +34 -38
  130. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  131. package/dist/collection/components/six-drawer/six-drawer.js +31 -35
  132. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  133. package/dist/collection/components/six-dropdown/six-dropdown.js +185 -173
  134. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  135. package/dist/collection/components/six-error-page/six-error-page.js +25 -27
  136. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  137. package/dist/collection/components/six-file-list-item/six-file-list-item.js +3 -3
  138. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  139. package/dist/collection/components/six-file-upload/six-file-upload.js +32 -32
  140. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  141. package/dist/collection/components/six-group-label/six-group-label.js +12 -10
  142. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  143. package/dist/collection/components/six-header/six-header.js +64 -42
  144. package/dist/collection/components/six-header/six-header.js.map +1 -1
  145. package/dist/collection/components/six-icon-button/six-icon-button.js +8 -8
  146. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  147. package/dist/collection/components/six-input/six-input.js +163 -347
  148. package/dist/collection/components/six-input/six-input.js.map +1 -1
  149. package/dist/collection/components/six-item-picker/six-item-picker.js +65 -84
  150. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  151. package/dist/collection/components/six-language-switcher/six-language-switcher.js +2 -2
  152. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  153. package/dist/collection/components/six-layout-grid/six-layout-grid.js +10 -8
  154. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  155. package/dist/collection/components/six-main-container/six-main-container.js +1 -1
  156. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  157. package/dist/collection/components/six-menu/six-menu.js +29 -23
  158. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  159. package/dist/collection/components/six-menu-item/six-menu-item.js +7 -5
  160. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  161. package/dist/collection/components/six-picto/six-picto.js +5 -2
  162. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  163. package/dist/collection/components/six-progress-ring/six-progress-ring.js +5 -4
  164. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  165. package/dist/collection/components/six-radio/six-radio.js +66 -114
  166. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  167. package/dist/collection/components/six-range/six-range.js +133 -180
  168. package/dist/collection/components/six-range/six-range.js.map +1 -1
  169. package/dist/collection/components/six-root/six-root.js +4 -4
  170. package/dist/collection/components/six-root/six-root.js.map +1 -1
  171. package/dist/collection/components/six-search-field/six-search-field.js +10 -5
  172. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  173. package/dist/collection/components/six-select/six-select.js +215 -336
  174. package/dist/collection/components/six-select/six-select.js.map +1 -1
  175. package/dist/collection/components/six-select/util.js +52 -0
  176. package/dist/collection/components/six-select/util.js.map +1 -0
  177. package/dist/collection/components/six-sidebar/six-sidebar.js +40 -19
  178. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  179. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +12 -8
  180. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  181. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  182. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +1 -1
  183. package/dist/collection/components/six-switch/six-switch.css +77 -0
  184. package/dist/collection/components/six-switch/six-switch.js +96 -133
  185. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  186. package/dist/collection/components/six-tab/six-tab.js +5 -3
  187. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  188. package/dist/collection/components/six-tab-group/six-tab-group.js +130 -112
  189. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  190. package/dist/collection/components/six-tab-panel/six-tab-panel.js +2 -2
  191. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  192. package/dist/collection/components/six-tag/six-tag.js +4 -7
  193. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  194. package/dist/collection/components/six-textarea/six-textarea.js +149 -270
  195. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  196. package/dist/collection/components/six-tile/six-tile.js +17 -20
  197. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  198. package/dist/collection/components/six-timepicker/six-timepicker.js +153 -254
  199. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  200. package/dist/collection/components/six-tooltip/six-tooltip.js +56 -59
  201. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  202. package/dist/collection/functional-components/form-control/form-control.js +8 -9
  203. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  204. package/dist/collection/index.js +1 -1
  205. package/dist/collection/index.js.map +1 -1
  206. package/dist/collection/testUtil/delay.js.map +1 -1
  207. package/dist/collection/utils/date-util.js +25 -16
  208. package/dist/collection/utils/date-util.js.map +1 -1
  209. package/dist/collection/utils/error-messages.js +91 -0
  210. package/dist/collection/utils/error-messages.js.map +1 -0
  211. package/dist/collection/utils/event-listeners.js +22 -6
  212. package/dist/collection/utils/event-listeners.js.map +1 -1
  213. package/dist/collection/utils/execution-control.js +5 -4
  214. package/dist/collection/utils/execution-control.js.map +1 -1
  215. package/dist/collection/utils/focus-visible.js +2 -2
  216. package/dist/collection/utils/focus-visible.js.map +1 -1
  217. package/dist/collection/utils/form.js +15 -0
  218. package/dist/collection/utils/form.js.map +1 -0
  219. package/dist/collection/utils/modal.js +3 -2
  220. package/dist/collection/utils/modal.js.map +1 -1
  221. package/dist/collection/utils/popover.js +32 -18
  222. package/dist/collection/utils/popover.js.map +1 -1
  223. package/dist/collection/utils/popup.js +95 -0
  224. package/dist/collection/utils/popup.js.map +1 -0
  225. package/dist/collection/utils/slot.js +9 -24
  226. package/dist/collection/utils/slot.js.map +1 -1
  227. package/dist/collection/utils/tabbable.js +6 -6
  228. package/dist/collection/utils/tabbable.js.map +1 -1
  229. package/dist/collection/utils/time.util.js +48 -34
  230. package/dist/collection/utils/time.util.js.map +1 -1
  231. package/dist/collection/utils/type-check.js +0 -1
  232. package/dist/collection/utils/type-check.js.map +1 -1
  233. package/dist/collection/wrappers/set-attributes/set-attributes.js +3 -1
  234. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +1 -1
  235. package/dist/components/event-listeners.js +22 -6
  236. package/dist/components/event-listeners.js.map +1 -1
  237. package/dist/components/execution-control.js +5 -2
  238. package/dist/components/execution-control.js.map +1 -1
  239. package/dist/components/focus-visible.js +2 -2
  240. package/dist/components/focus-visible.js.map +1 -1
  241. package/dist/components/form-control.js +8 -9
  242. package/dist/components/form-control.js.map +1 -1
  243. package/dist/components/form.js +18 -0
  244. package/dist/components/form.js.map +1 -0
  245. package/dist/components/index.js +92 -3
  246. package/dist/components/index.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 +38 -30
  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 +34 -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 +46 -78
  263. package/dist/components/six-checkbox.js.map +1 -1
  264. package/dist/components/six-datepicker.js +150 -281
  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-group-label.js +10 -9
  281. package/dist/components/six-group-label.js.map +1 -1
  282. package/dist/components/six-header.js +64 -42
  283. package/dist/components/six-header.js.map +1 -1
  284. package/dist/components/six-icon-button2.js +2 -2
  285. package/dist/components/six-icon-button2.js.map +1 -1
  286. package/dist/components/six-input2.js +95 -137
  287. package/dist/components/six-input2.js.map +1 -1
  288. package/dist/components/six-item-picker2.js +56 -75
  289. package/dist/components/six-item-picker2.js.map +1 -1
  290. package/dist/components/six-language-switcher.js +1 -1
  291. package/dist/components/six-language-switcher.js.map +1 -1
  292. package/dist/components/six-layout-grid.js +5 -3
  293. package/dist/components/six-layout-grid.js.map +1 -1
  294. package/dist/components/six-main-container.js.map +1 -1
  295. package/dist/components/six-menu-item2.js +7 -5
  296. package/dist/components/six-menu-item2.js.map +1 -1
  297. package/dist/components/six-menu2.js +25 -18
  298. package/dist/components/six-menu2.js.map +1 -1
  299. package/dist/components/six-picto2.js +4 -1
  300. package/dist/components/six-picto2.js.map +1 -1
  301. package/dist/components/six-progress-ring.js +3 -3
  302. package/dist/components/six-progress-ring.js.map +1 -1
  303. package/dist/components/six-radio.js +61 -65
  304. package/dist/components/six-radio.js.map +1 -1
  305. package/dist/components/six-range.js +108 -111
  306. package/dist/components/six-range.js.map +1 -1
  307. package/dist/components/six-root.js +1 -1
  308. package/dist/components/six-root.js.map +1 -1
  309. package/dist/components/six-search-field.js +8 -3
  310. package/dist/components/six-search-field.js.map +1 -1
  311. package/dist/components/six-select.js +186 -226
  312. package/dist/components/six-select.js.map +1 -1
  313. package/dist/components/six-sidebar-item-group.js +8 -4
  314. package/dist/components/six-sidebar-item-group.js.map +1 -1
  315. package/dist/components/six-sidebar.js +39 -18
  316. package/dist/components/six-sidebar.js.map +1 -1
  317. package/dist/components/six-spinner2.js.map +1 -1
  318. package/dist/components/six-switch.js +58 -68
  319. package/dist/components/six-switch.js.map +1 -1
  320. package/dist/components/six-tab-group.js +129 -111
  321. package/dist/components/six-tab-group.js.map +1 -1
  322. package/dist/components/six-tab-panel.js +1 -1
  323. package/dist/components/six-tab-panel.js.map +1 -1
  324. package/dist/components/six-tab.js +4 -2
  325. package/dist/components/six-tab.js.map +1 -1
  326. package/dist/components/six-tag2.js +4 -7
  327. package/dist/components/six-tag2.js.map +1 -1
  328. package/dist/components/six-textarea.js +89 -117
  329. package/dist/components/six-textarea.js.map +1 -1
  330. package/dist/components/six-tile.js +14 -17
  331. package/dist/components/six-tile.js.map +1 -1
  332. package/dist/components/six-timepicker.js +1 -1
  333. package/dist/components/six-timepicker2.js +247 -258
  334. package/dist/components/six-timepicker2.js.map +1 -1
  335. package/dist/components/six-tooltip2.js +52 -55
  336. package/dist/components/six-tooltip2.js.map +1 -1
  337. package/dist/components/slot.js +10 -9
  338. package/dist/components/slot.js.map +1 -1
  339. package/dist/components.json +527 -914
  340. package/dist/esm/event-listeners-535f3ad1.js +59 -0
  341. package/dist/esm/event-listeners-535f3ad1.js.map +1 -0
  342. package/dist/esm/{execution-control-1a60d709.js → execution-control-72cc50f4.js} +6 -3
  343. package/dist/esm/execution-control-72cc50f4.js.map +1 -0
  344. package/dist/esm/{focus-visible-97933ea9.js → focus-visible-fa7129a0.js} +3 -3
  345. package/dist/esm/focus-visible-fa7129a0.js.map +1 -0
  346. package/dist/esm/form-0b9c11cd.js +18 -0
  347. package/dist/esm/form-0b9c11cd.js.map +1 -0
  348. package/dist/esm/{form-control-3b440ea1.js → form-control-785c5f79.js} +9 -10
  349. package/dist/esm/form-control-785c5f79.js.map +1 -0
  350. package/dist/esm/index.js +91 -0
  351. package/dist/esm/index.js.map +1 -1
  352. package/dist/esm/loader.js +1 -1
  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-2e72e7d8.js} +39 -31
  356. package/dist/esm/popover-2e72e7d8.js.map +1 -0
  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 +3 -1
  360. package/dist/esm/set-attributes_2.entry.js.map +1 -1
  361. package/dist/esm/six-alert.entry.js +17 -22
  362. package/dist/esm/six-alert.entry.js.map +1 -1
  363. package/dist/esm/six-avatar.entry.js +4 -7
  364. package/dist/esm/six-avatar.entry.js.map +1 -1
  365. package/dist/esm/six-badge.entry.js +1 -1
  366. package/dist/esm/six-badge.entry.js.map +1 -1
  367. package/dist/esm/six-button.entry.js +35 -33
  368. package/dist/esm/six-button.entry.js.map +1 -1
  369. package/dist/esm/six-card.entry.js.map +1 -1
  370. package/dist/esm/six-checkbox.entry.js +48 -75
  371. package/dist/esm/six-checkbox.entry.js.map +1 -1
  372. package/dist/esm/six-datepicker.entry.js +148 -276
  373. package/dist/esm/six-datepicker.entry.js.map +1 -1
  374. package/dist/esm/six-details.entry.js +47 -46
  375. package/dist/esm/six-details.entry.js.map +1 -1
  376. package/dist/esm/six-dialog.entry.js +35 -39
  377. package/dist/esm/six-dialog.entry.js.map +1 -1
  378. package/dist/esm/six-drawer.entry.js +32 -36
  379. package/dist/esm/six-drawer.entry.js.map +1 -1
  380. package/dist/esm/six-dropdown_2.entry.js +214 -195
  381. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  382. package/dist/esm/six-error-page.entry.js +19 -21
  383. package/dist/esm/six-error-page.entry.js.map +1 -1
  384. package/dist/esm/six-file-list-item.entry.js +1 -1
  385. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  386. package/dist/esm/six-file-upload.entry.js +20 -20
  387. package/dist/esm/six-file-upload.entry.js.map +1 -1
  388. package/dist/esm/six-group-label.entry.js +11 -10
  389. package/dist/esm/six-group-label.entry.js.map +1 -1
  390. package/dist/esm/six-header.entry.js +65 -43
  391. package/dist/esm/six-header.entry.js.map +1 -1
  392. package/dist/esm/six-icon-button.entry.js +3 -3
  393. package/dist/esm/six-icon-button.entry.js.map +1 -1
  394. package/dist/esm/six-input.entry.js +93 -126
  395. package/dist/esm/six-input.entry.js.map +1 -1
  396. package/dist/esm/six-item-picker.entry.js +58 -77
  397. package/dist/esm/six-item-picker.entry.js.map +1 -1
  398. package/dist/esm/six-language-switcher.entry.js +1 -1
  399. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  400. package/dist/esm/six-layout-grid.entry.js +4 -2
  401. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  402. package/dist/esm/six-main-container.entry.js.map +1 -1
  403. package/dist/esm/six-menu-item.entry.js +8 -6
  404. package/dist/esm/six-menu-item.entry.js.map +1 -1
  405. package/dist/esm/six-picto.entry.js +4 -1
  406. package/dist/esm/six-picto.entry.js.map +1 -1
  407. package/dist/esm/six-progress-ring.entry.js +3 -3
  408. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  409. package/dist/esm/six-radio.entry.js +59 -60
  410. package/dist/esm/six-radio.entry.js.map +1 -1
  411. package/dist/esm/six-range.entry.js +106 -105
  412. package/dist/esm/six-range.entry.js.map +1 -1
  413. package/dist/esm/six-root.entry.js +1 -1
  414. package/dist/esm/six-root.entry.js.map +1 -1
  415. package/dist/esm/six-search-field.entry.js +10 -5
  416. package/dist/esm/six-search-field.entry.js.map +1 -1
  417. package/dist/esm/six-select.entry.js +185 -219
  418. package/dist/esm/six-select.entry.js.map +1 -1
  419. package/dist/esm/six-sidebar-item-group.entry.js +9 -5
  420. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  421. package/dist/esm/six-sidebar.entry.js +39 -18
  422. package/dist/esm/six-sidebar.entry.js.map +1 -1
  423. package/dist/esm/six-spinner.entry.js.map +1 -1
  424. package/dist/esm/six-switch.entry.js +55 -63
  425. package/dist/esm/six-switch.entry.js.map +1 -1
  426. package/dist/esm/six-tab-group.entry.js +130 -112
  427. package/dist/esm/six-tab-group.entry.js.map +1 -1
  428. package/dist/esm/six-tab-panel.entry.js +1 -1
  429. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  430. package/dist/esm/six-tab.entry.js +4 -2
  431. package/dist/esm/six-tab.entry.js.map +1 -1
  432. package/dist/esm/six-tag.entry.js +4 -7
  433. package/dist/esm/six-tag.entry.js.map +1 -1
  434. package/dist/esm/six-textarea.entry.js +87 -109
  435. package/dist/esm/six-textarea.entry.js.map +1 -1
  436. package/dist/esm/six-tile.entry.js +13 -16
  437. package/dist/esm/six-tile.entry.js.map +1 -1
  438. package/dist/esm/six-timepicker.entry.js +157 -213
  439. package/dist/esm/six-timepicker.entry.js.map +1 -1
  440. package/dist/esm/six-tooltip.entry.js +53 -56
  441. package/dist/esm/six-tooltip.entry.js.map +1 -1
  442. package/dist/esm/{slot-6f3984c7.js → slot-2e64df19.js} +11 -10
  443. package/dist/esm/slot-2e64df19.js.map +1 -0
  444. package/dist/esm/ui-library.js +1 -1
  445. package/dist/types/components/six-alert/six-alert.d.ts +5 -7
  446. package/dist/types/components/six-avatar/six-avatar.d.ts +1 -2
  447. package/dist/types/components/six-badge/six-badge.d.ts +0 -1
  448. package/dist/types/components/six-button/six-button.d.ts +8 -9
  449. package/dist/types/components/six-checkbox/six-checkbox.d.ts +23 -31
  450. package/dist/types/components/six-datepicker/components/day-selection.d.ts +9 -5
  451. package/dist/types/components/six-datepicker/components/month-selection.d.ts +8 -5
  452. package/dist/types/components/six-datepicker/components/year-selection.d.ts +7 -5
  453. package/dist/types/components/six-datepicker/six-datepicker.d.ts +41 -52
  454. package/dist/types/components/six-details/six-details.d.ts +12 -12
  455. package/dist/types/components/six-dialog/six-dialog.d.ts +12 -13
  456. package/dist/types/components/six-drawer/six-drawer.d.ts +12 -13
  457. package/dist/types/components/six-dropdown/six-dropdown.d.ts +28 -32
  458. package/dist/types/components/six-error-page/six-error-page.d.ts +1 -1
  459. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +3 -3
  460. package/dist/types/components/six-file-upload/six-file-upload.d.ts +11 -11
  461. package/dist/types/components/six-group-label/six-group-label.d.ts +5 -5
  462. package/dist/types/components/six-header/six-header.d.ts +16 -27
  463. package/dist/types/components/six-icon-button/six-icon-button.d.ts +4 -4
  464. package/dist/types/components/six-input/six-input.d.ts +32 -67
  465. package/dist/types/components/six-item-picker/six-item-picker.d.ts +13 -16
  466. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +1 -1
  467. package/dist/types/components/six-menu/six-menu.d.ts +10 -11
  468. package/dist/types/components/six-menu-item/six-menu-item.d.ts +6 -6
  469. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +2 -2
  470. package/dist/types/components/six-radio/six-radio.d.ts +14 -20
  471. package/dist/types/components/six-range/six-range.d.ts +27 -38
  472. package/dist/types/components/six-root/six-root.d.ts +3 -3
  473. package/dist/types/components/six-search-field/six-search-field.d.ts +4 -5
  474. package/dist/types/components/six-select/six-select.d.ts +41 -58
  475. package/dist/types/components/six-select/util.d.ts +7 -0
  476. package/dist/types/components/six-sidebar/six-sidebar.d.ts +5 -5
  477. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +7 -6
  478. package/dist/types/components/six-spinner/six-spinner.d.ts +2 -2
  479. package/dist/types/components/six-switch/six-switch.d.ts +18 -21
  480. package/dist/types/components/six-tab/six-tab.d.ts +3 -3
  481. package/dist/types/components/six-tab-group/six-tab-group.d.ts +20 -21
  482. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +1 -1
  483. package/dist/types/components/six-tag/six-tag.d.ts +1 -3
  484. package/dist/types/components/six-textarea/six-textarea.d.ts +27 -55
  485. package/dist/types/components/six-tile/six-tile.d.ts +2 -3
  486. package/dist/types/components/six-timepicker/six-timepicker.d.ts +26 -43
  487. package/dist/types/components/six-tooltip/six-tooltip.d.ts +19 -21
  488. package/dist/types/components.d.ts +209 -444
  489. package/dist/types/functional-components/form-control/form-control.d.ts +5 -6
  490. package/dist/types/index.d.ts +1 -0
  491. package/dist/types/testUtil/delay.d.ts +1 -1
  492. package/dist/types/types.d.ts +2 -0
  493. package/dist/types/utils/date-util.d.ts +18 -10
  494. package/dist/types/utils/error-messages.d.ts +42 -0
  495. package/dist/types/utils/event-listeners.d.ts +2 -1
  496. package/dist/types/utils/execution-control.d.ts +1 -3
  497. package/dist/types/utils/form.d.ts +1 -0
  498. package/dist/types/utils/modal.d.ts +2 -2
  499. package/dist/types/utils/popover.d.ts +5 -5
  500. package/dist/types/utils/popup.d.ts +9 -0
  501. package/dist/types/utils/slot.d.ts +2 -7
  502. package/dist/types/utils/tabbable.d.ts +1 -1
  503. package/dist/types/utils/time.util.d.ts +18 -9
  504. package/dist/types/utils/type-check.d.ts +3 -4
  505. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +1 -1
  506. package/dist/ui-library/index.esm.js +1 -1
  507. package/dist/ui-library/index.esm.js.map +1 -1
  508. package/dist/ui-library/p-0045a402.entry.js +2 -0
  509. package/dist/ui-library/p-0045a402.entry.js.map +1 -0
  510. package/dist/ui-library/p-0108fe92.entry.js +2 -0
  511. package/dist/ui-library/p-0108fe92.entry.js.map +1 -0
  512. package/dist/ui-library/p-03a145f5.entry.js +2 -0
  513. package/dist/ui-library/p-03a145f5.entry.js.map +1 -0
  514. package/dist/ui-library/{p-7e0cc4ae.entry.js → p-087fdd96.entry.js} +2 -2
  515. package/dist/ui-library/p-087fdd96.entry.js.map +1 -0
  516. package/dist/ui-library/p-09779e47.entry.js +2 -0
  517. package/dist/ui-library/p-09779e47.entry.js.map +1 -0
  518. package/dist/ui-library/p-097cced4.entry.js.map +1 -1
  519. package/dist/ui-library/p-0b2c6348.js +2 -0
  520. package/dist/ui-library/p-0b2c6348.js.map +1 -0
  521. package/dist/ui-library/p-0cc08e91.js +2 -0
  522. package/dist/ui-library/p-0cc08e91.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-2761f908.js +2 -0
  526. package/dist/ui-library/p-2761f908.js.map +1 -0
  527. package/dist/ui-library/{p-19b50b5a.entry.js → p-28be55f0.entry.js} +2 -2
  528. package/dist/ui-library/p-28be55f0.entry.js.map +1 -0
  529. package/dist/ui-library/{p-c349d1d4.entry.js → p-3929b0af.entry.js} +2 -2
  530. package/dist/ui-library/p-3929b0af.entry.js.map +1 -0
  531. package/dist/ui-library/{p-9328e5bc.entry.js → p-445ba5b8.entry.js} +2 -2
  532. package/dist/ui-library/p-445ba5b8.entry.js.map +1 -0
  533. package/dist/ui-library/p-4d408fb4.js +2 -0
  534. package/dist/ui-library/p-4d408fb4.js.map +1 -0
  535. package/dist/ui-library/p-502ff3d3.entry.js +2 -0
  536. package/dist/ui-library/p-502ff3d3.entry.js.map +1 -0
  537. package/dist/ui-library/p-5a34c93e.entry.js +2 -0
  538. package/dist/ui-library/p-5a34c93e.entry.js.map +1 -0
  539. package/dist/ui-library/p-60621dc6.js +2 -0
  540. package/dist/ui-library/p-60621dc6.js.map +1 -0
  541. package/dist/ui-library/p-63703ba3.entry.js.map +1 -1
  542. package/dist/ui-library/p-66180e89.entry.js +2 -0
  543. package/dist/ui-library/p-66180e89.entry.js.map +1 -0
  544. package/dist/ui-library/p-686b12ec.entry.js +2 -0
  545. package/dist/ui-library/p-686b12ec.entry.js.map +1 -0
  546. package/dist/ui-library/p-71035abf.entry.js +2 -0
  547. package/dist/ui-library/p-71035abf.entry.js.map +1 -0
  548. package/dist/ui-library/{p-8a970a40.entry.js → p-724e154d.entry.js} +2 -2
  549. package/dist/ui-library/p-724e154d.entry.js.map +1 -0
  550. package/dist/ui-library/p-72ca96e1.entry.js +2 -0
  551. package/dist/ui-library/p-72ca96e1.entry.js.map +1 -0
  552. package/dist/ui-library/p-73597d13.entry.js.map +1 -1
  553. package/dist/ui-library/{p-c30f9e0b.entry.js → p-778cf804.entry.js} +2 -2
  554. package/dist/ui-library/p-778cf804.entry.js.map +1 -0
  555. package/dist/ui-library/p-87032e26.entry.js +2 -0
  556. package/dist/ui-library/p-87032e26.entry.js.map +1 -0
  557. package/dist/ui-library/p-8cf72af6.js +2 -0
  558. package/dist/ui-library/p-8cf72af6.js.map +1 -0
  559. package/dist/ui-library/p-8e0b6b7e.entry.js +2 -0
  560. package/dist/ui-library/p-8e0b6b7e.entry.js.map +1 -0
  561. package/dist/ui-library/p-912092c0.entry.js +2 -0
  562. package/dist/ui-library/p-912092c0.entry.js.map +1 -0
  563. package/dist/ui-library/p-92ca6a84.entry.js +2 -0
  564. package/dist/ui-library/p-92ca6a84.entry.js.map +1 -0
  565. package/dist/ui-library/{p-d5633a29.entry.js → p-9337cdd6.entry.js} +2 -2
  566. package/dist/ui-library/p-9337cdd6.entry.js.map +1 -0
  567. package/dist/ui-library/p-9461417e.entry.js +2 -0
  568. package/dist/ui-library/p-9461417e.entry.js.map +1 -0
  569. package/dist/ui-library/p-a1d4f6cf.entry.js.map +1 -1
  570. package/dist/ui-library/{p-611e1978.entry.js → p-a844cb72.entry.js} +2 -2
  571. package/dist/ui-library/{p-611e1978.entry.js.map → p-a844cb72.entry.js.map} +1 -1
  572. package/dist/ui-library/p-afcbe9da.entry.js +2 -0
  573. package/dist/ui-library/p-afcbe9da.entry.js.map +1 -0
  574. package/dist/ui-library/{p-0d79b0c6.entry.js → p-b2bf4ac8.entry.js} +2 -2
  575. package/dist/ui-library/p-b2bf4ac8.entry.js.map +1 -0
  576. package/dist/ui-library/{p-90dc6af4.entry.js → p-b3bff992.entry.js} +2 -2
  577. package/dist/ui-library/p-b3bff992.entry.js.map +1 -0
  578. package/dist/ui-library/p-b4547fb5.entry.js +2 -0
  579. package/dist/ui-library/p-b4547fb5.entry.js.map +1 -0
  580. package/dist/ui-library/{p-4f8394d7.js → p-ba74863a.js} +2 -2
  581. package/dist/ui-library/p-ba74863a.js.map +1 -0
  582. package/dist/ui-library/p-bd8f8eef.entry.js +2 -0
  583. package/dist/ui-library/p-bd8f8eef.entry.js.map +1 -0
  584. package/dist/ui-library/p-c57f16af.entry.js +2 -0
  585. package/dist/ui-library/p-c57f16af.entry.js.map +1 -0
  586. package/dist/ui-library/p-c5cdba08.entry.js +2 -0
  587. package/dist/ui-library/p-c5cdba08.entry.js.map +1 -0
  588. package/dist/ui-library/p-c87810b0.entry.js +2 -0
  589. package/dist/ui-library/p-c87810b0.entry.js.map +1 -0
  590. package/dist/ui-library/{p-af793d04.entry.js → p-cdcde4cd.entry.js} +2 -2
  591. package/dist/ui-library/p-cdcde4cd.entry.js.map +1 -0
  592. package/dist/ui-library/p-d6798d35.entry.js +2 -0
  593. package/dist/ui-library/p-d6798d35.entry.js.map +1 -0
  594. package/dist/ui-library/p-d87a6f4d.js +2 -0
  595. package/dist/ui-library/p-d87a6f4d.js.map +1 -0
  596. package/dist/ui-library/p-dc3f5996.entry.js +2 -0
  597. package/dist/ui-library/p-dc3f5996.entry.js.map +1 -0
  598. package/dist/ui-library/p-dcd7c547.entry.js +2 -0
  599. package/dist/ui-library/p-dcd7c547.entry.js.map +1 -0
  600. package/dist/ui-library/p-e07b3f0c.entry.js +2 -0
  601. package/dist/ui-library/p-e07b3f0c.entry.js.map +1 -0
  602. package/dist/ui-library/{p-19364560.entry.js → p-e8feb81f.entry.js} +2 -2
  603. package/dist/ui-library/{p-19364560.entry.js.map → p-e8feb81f.entry.js.map} +1 -1
  604. package/dist/ui-library/p-ef3936e5.entry.js +2 -0
  605. package/dist/ui-library/p-ef3936e5.entry.js.map +1 -0
  606. package/dist/ui-library/p-f0dd77e1.entry.js +2 -0
  607. package/dist/ui-library/p-f0dd77e1.entry.js.map +1 -0
  608. package/dist/ui-library/ui-library.esm.js +1 -1
  609. package/dist/ui-library/ui-library.esm.js.map +1 -1
  610. package/package.json +14 -15
  611. package/dist/cjs/event-listeners-74715e62.js +0 -45
  612. package/dist/cjs/event-listeners-74715e62.js.map +0 -1
  613. package/dist/cjs/execution-control-46f388e0.js.map +0 -1
  614. package/dist/cjs/focus-visible-0b352c74.js.map +0 -1
  615. package/dist/cjs/form-control-2c17c573.js.map +0 -1
  616. package/dist/cjs/modal-48d42228.js.map +0 -1
  617. package/dist/cjs/popover-f743f62b.js.map +0 -1
  618. package/dist/cjs/six-form.cjs.entry.js +0 -231
  619. package/dist/cjs/six-form.cjs.entry.js.map +0 -1
  620. package/dist/cjs/six-timepicker.types-c19ebff3.js +0 -56
  621. package/dist/cjs/six-timepicker.types-c19ebff3.js.map +0 -1
  622. package/dist/cjs/slot-ad537f24.js.map +0 -1
  623. package/dist/collection/components/six-form/six-form.css +0 -11
  624. package/dist/collection/components/six-form/six-form.js +0 -419
  625. package/dist/collection/components/six-form/six-form.js.map +0 -1
  626. package/dist/collection/components/six-timepicker/six-time-format.js +0 -15
  627. package/dist/collection/components/six-timepicker/six-time-format.js.map +0 -1
  628. package/dist/collection/components/six-timepicker/six-timepicker.types.js +0 -41
  629. package/dist/collection/components/six-timepicker/six-timepicker.types.js.map +0 -1
  630. package/dist/collection/utils/as-array.js +0 -2
  631. package/dist/collection/utils/as-array.js.map +0 -1
  632. package/dist/collection/utils/matchers.js +0 -3
  633. package/dist/collection/utils/matchers.js.map +0 -1
  634. package/dist/collection/utils/testing.js +0 -39
  635. package/dist/collection/utils/testing.js.map +0 -1
  636. package/dist/components/six-form.d.ts +0 -11
  637. package/dist/components/six-form.js +0 -252
  638. package/dist/components/six-form.js.map +0 -1
  639. package/dist/esm/event-listeners-570a24ea.js +0 -43
  640. package/dist/esm/event-listeners-570a24ea.js.map +0 -1
  641. package/dist/esm/execution-control-1a60d709.js.map +0 -1
  642. package/dist/esm/focus-visible-97933ea9.js.map +0 -1
  643. package/dist/esm/form-control-3b440ea1.js.map +0 -1
  644. package/dist/esm/modal-5ebdc320.js.map +0 -1
  645. package/dist/esm/popover-bd2c2fca.js.map +0 -1
  646. package/dist/esm/six-form.entry.js +0 -227
  647. package/dist/esm/six-form.entry.js.map +0 -1
  648. package/dist/esm/six-timepicker.types-e161a447.js +0 -50
  649. package/dist/esm/six-timepicker.types-e161a447.js.map +0 -1
  650. package/dist/esm/slot-6f3984c7.js.map +0 -1
  651. package/dist/types/components/six-form/six-form.d.ts +0 -69
  652. package/dist/types/components/six-timepicker/six-time-format.d.ts +0 -13
  653. package/dist/types/components/six-timepicker/six-timepicker.types.d.ts +0 -36
  654. package/dist/types/utils/as-array.d.ts +0 -1
  655. package/dist/types/utils/matchers.d.ts +0 -2
  656. package/dist/types/utils/popper.d.ts +0 -33
  657. package/dist/types/utils/testing.d.ts +0 -2
  658. package/dist/ui-library/p-054e12cc.entry.js +0 -2
  659. package/dist/ui-library/p-054e12cc.entry.js.map +0 -1
  660. package/dist/ui-library/p-0786fa7c.js +0 -2
  661. package/dist/ui-library/p-0786fa7c.js.map +0 -1
  662. package/dist/ui-library/p-0d79b0c6.entry.js.map +0 -1
  663. package/dist/ui-library/p-14f20bbb.entry.js +0 -2
  664. package/dist/ui-library/p-14f20bbb.entry.js.map +0 -1
  665. package/dist/ui-library/p-18e5f772.entry.js +0 -2
  666. package/dist/ui-library/p-18e5f772.entry.js.map +0 -1
  667. package/dist/ui-library/p-18ea0c56.js +0 -2
  668. package/dist/ui-library/p-18ea0c56.js.map +0 -1
  669. package/dist/ui-library/p-19b50b5a.entry.js.map +0 -1
  670. package/dist/ui-library/p-2e48c8d2.entry.js +0 -2
  671. package/dist/ui-library/p-2e48c8d2.entry.js.map +0 -1
  672. package/dist/ui-library/p-308261c4.entry.js +0 -2
  673. package/dist/ui-library/p-308261c4.entry.js.map +0 -1
  674. package/dist/ui-library/p-33f7e22b.entry.js +0 -2
  675. package/dist/ui-library/p-33f7e22b.entry.js.map +0 -1
  676. package/dist/ui-library/p-4ae91795.entry.js +0 -2
  677. package/dist/ui-library/p-4ae91795.entry.js.map +0 -1
  678. package/dist/ui-library/p-4f8394d7.js.map +0 -1
  679. package/dist/ui-library/p-53a13db5.entry.js +0 -2
  680. package/dist/ui-library/p-53a13db5.entry.js.map +0 -1
  681. package/dist/ui-library/p-559c87f0.entry.js +0 -2
  682. package/dist/ui-library/p-559c87f0.entry.js.map +0 -1
  683. package/dist/ui-library/p-6403fd87.entry.js +0 -2
  684. package/dist/ui-library/p-6403fd87.entry.js.map +0 -1
  685. package/dist/ui-library/p-6433c0da.entry.js +0 -2
  686. package/dist/ui-library/p-6433c0da.entry.js.map +0 -1
  687. package/dist/ui-library/p-79eee01b.js +0 -2
  688. package/dist/ui-library/p-79eee01b.js.map +0 -1
  689. package/dist/ui-library/p-7e0cc4ae.entry.js.map +0 -1
  690. package/dist/ui-library/p-835c3ff7.entry.js +0 -2
  691. package/dist/ui-library/p-835c3ff7.entry.js.map +0 -1
  692. package/dist/ui-library/p-8a970a40.entry.js.map +0 -1
  693. package/dist/ui-library/p-90824648.entry.js +0 -2
  694. package/dist/ui-library/p-90824648.entry.js.map +0 -1
  695. package/dist/ui-library/p-90dc6af4.entry.js.map +0 -1
  696. package/dist/ui-library/p-9328e5bc.entry.js.map +0 -1
  697. package/dist/ui-library/p-9a860acc.js +0 -2
  698. package/dist/ui-library/p-9a860acc.js.map +0 -1
  699. package/dist/ui-library/p-9d1d222f.entry.js +0 -2
  700. package/dist/ui-library/p-9d1d222f.entry.js.map +0 -1
  701. package/dist/ui-library/p-af793d04.entry.js.map +0 -1
  702. package/dist/ui-library/p-b0e5658f.entry.js +0 -2
  703. package/dist/ui-library/p-b0e5658f.entry.js.map +0 -1
  704. package/dist/ui-library/p-b1e66136.js +0 -2
  705. package/dist/ui-library/p-b1e66136.js.map +0 -1
  706. package/dist/ui-library/p-b4dfb7cf.js +0 -2
  707. package/dist/ui-library/p-b4dfb7cf.js.map +0 -1
  708. package/dist/ui-library/p-b997e43c.entry.js +0 -2
  709. package/dist/ui-library/p-b997e43c.entry.js.map +0 -1
  710. package/dist/ui-library/p-c0cb6436.entry.js +0 -2
  711. package/dist/ui-library/p-c0cb6436.entry.js.map +0 -1
  712. package/dist/ui-library/p-c30f9e0b.entry.js.map +0 -1
  713. package/dist/ui-library/p-c349d1d4.entry.js.map +0 -1
  714. package/dist/ui-library/p-c53a63f9.entry.js +0 -2
  715. package/dist/ui-library/p-c53a63f9.entry.js.map +0 -1
  716. package/dist/ui-library/p-c640c2d8.entry.js +0 -2
  717. package/dist/ui-library/p-c640c2d8.entry.js.map +0 -1
  718. package/dist/ui-library/p-c94d0b07.entry.js +0 -2
  719. package/dist/ui-library/p-c94d0b07.entry.js.map +0 -1
  720. package/dist/ui-library/p-d12c6092.js +0 -2
  721. package/dist/ui-library/p-d12c6092.js.map +0 -1
  722. package/dist/ui-library/p-d5633a29.entry.js.map +0 -1
  723. package/dist/ui-library/p-df655bc9.entry.js +0 -2
  724. package/dist/ui-library/p-df655bc9.entry.js.map +0 -1
  725. package/dist/ui-library/p-edc96efc.entry.js +0 -2
  726. package/dist/ui-library/p-edc96efc.entry.js.map +0 -1
  727. package/dist/ui-library/p-f18ba86f.entry.js +0 -2
  728. package/dist/ui-library/p-f18ba86f.entry.js.map +0 -1
  729. package/dist/ui-library/p-f4938771.entry.js +0 -2
  730. package/dist/ui-library/p-f4938771.entry.js.map +0 -1
  731. package/dist/ui-library/p-f70e2403.entry.js +0 -2
  732. package/dist/ui-library/p-f70e2403.entry.js.map +0 -1
  733. package/dist/ui-library/p-f9d345e0.entry.js +0 -2
  734. package/dist/ui-library/p-f9d345e0.entry.js.map +0 -1
  735. package/dist/ui-library/p-fed07a1f.entry.js +0 -2
  736. package/dist/ui-library/p-fed07a1f.entry.js.map +0 -1
  737. package/dist/ui-library/p-ff0257bf.entry.js +0 -2
  738. package/dist/ui-library/p-ff0257bf.entry.js.map +0 -1
@@ -1,4 +1,5 @@
1
1
  import { h } from '@stencil/core';
2
+ import { EventListeners } from '../../utils/event-listeners';
2
3
  let id = 0;
3
4
  /**
4
5
  * @since 1.0
@@ -17,11 +18,46 @@ export class SixRadio {
17
18
  constructor() {
18
19
  this.inputId = `radio-${++id}`;
19
20
  this.labelId = `radio-label-${id}`;
21
+ this.eventListeners = new EventListeners();
20
22
  /** default state whether the radio button should be checked or not when resetting */
21
23
  this.defaultState = false;
24
+ this.handleClick = () => {
25
+ if (this.nativeInput != null) {
26
+ this.checked = this.nativeInput.checked;
27
+ }
28
+ };
29
+ this.handleBlur = () => {
30
+ this.hasFocus = false;
31
+ this.sixBlur.emit();
32
+ };
33
+ this.handleFocus = () => {
34
+ this.hasFocus = true;
35
+ this.sixFocus.emit();
36
+ };
37
+ this.handleKeyDown = (event) => {
38
+ if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
39
+ const radios = this.getAllRadios().filter((radio) => !radio.disabled);
40
+ const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;
41
+ let index = radios.indexOf(this.host) + incr;
42
+ if (index < 0)
43
+ index = radios.length - 1;
44
+ if (index > radios.length - 1)
45
+ index = 0;
46
+ this.getAllRadios().map((radio) => (radio.checked = false));
47
+ radios[index].setFocus();
48
+ radios[index].checked = true;
49
+ event.preventDefault();
50
+ }
51
+ };
52
+ this.handleMouseDown = (event) => {
53
+ var _a;
54
+ // Prevent clicks on the label from briefly blurring the input
55
+ event.preventDefault();
56
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.focus();
57
+ };
22
58
  this.hasFocus = false;
23
- this.name = undefined;
24
- this.value = undefined;
59
+ this.name = '';
60
+ this.value = 'on';
25
61
  this.disabled = false;
26
62
  this.checked = false;
27
63
  this.invalid = false;
@@ -30,95 +66,57 @@ export class SixRadio {
30
66
  if (this.checked) {
31
67
  this.getSiblingRadios().map((radio) => (radio.checked = false));
32
68
  }
33
- if (this.input) {
34
- this.input.checked = this.checked;
69
+ if (this.nativeInput != null) {
70
+ this.nativeInput.checked = this.checked;
35
71
  this.sixChange.emit();
36
72
  }
37
73
  }
74
+ handleNameChange(name) {
75
+ if (this.nativeInput != null) {
76
+ this.nativeInput.name = name;
77
+ }
78
+ }
38
79
  connectedCallback() {
39
- this.handleClick = this.handleClick.bind(this);
40
- this.handleBlur = this.handleBlur.bind(this);
41
- this.handleFocus = this.handleFocus.bind(this);
42
- this.handleKeyDown = this.handleKeyDown.bind(this);
43
- this.handleMouseDown = this.handleMouseDown.bind(this);
80
+ this.eventListeners.forward('six-radio-change', 'change', this.host);
81
+ this.eventListeners.forward('six-radio-blur', 'blur', this.host);
82
+ this.eventListeners.forward('six-radio-focus', 'focus', this.host);
44
83
  }
45
84
  componentWillLoad() {
46
85
  this.defaultState = this.checked;
47
86
  }
87
+ disconnectedCallback() {
88
+ this.eventListeners.removeAll();
89
+ }
48
90
  /** Sets focus on the radio. */
49
91
  async setFocus(options) {
50
- this.input.focus(options);
92
+ var _a;
93
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.focus(options);
51
94
  }
52
95
  /** Removes focus from the radio. */
53
96
  async removeFocus() {
54
- this.input.blur();
55
- }
56
- /** Checks for validity and shows the browser's validation message if the control is invalid. */
57
- async reportValidity() {
58
- return this.input.reportValidity();
59
- }
60
- /** Checks for validity. */
61
- async checkValidity() {
62
- return this.input.validity.valid;
63
- }
64
- /** Sets a custom validation message. If `message` is not empty, the field will be considered invalid. */
65
- async setCustomValidity(message) {
66
- this.input.setCustomValidity(message);
67
- this.invalid = !this.input.checkValidity();
97
+ var _a;
98
+ (_a = this.nativeInput) === null || _a === void 0 ? void 0 : _a.blur();
68
99
  }
69
100
  /** Resets the formcontrol */
70
101
  async reset() {
71
102
  this.checked = this.defaultState;
72
- this.input.setCustomValidity('');
73
- this.invalid = false;
74
103
  }
75
104
  getAllRadios() {
76
105
  const form = this.host.closest('six-form, form') || document.body;
77
- if (!this.name)
106
+ if (this.name === '')
78
107
  return [];
79
108
  return [...form.querySelectorAll('six-radio')].filter((radio) => radio.name === this.name);
80
109
  }
81
110
  getSiblingRadios() {
82
111
  return this.getAllRadios().filter((radio) => radio !== this.host);
83
112
  }
84
- handleClick() {
85
- this.checked = this.input.checked;
86
- }
87
- handleBlur() {
88
- this.hasFocus = false;
89
- this.sixBlur.emit();
90
- }
91
- handleFocus() {
92
- this.hasFocus = true;
93
- this.sixFocus.emit();
94
- }
95
- handleKeyDown(event) {
96
- if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {
97
- const radios = this.getAllRadios().filter((radio) => !radio.disabled);
98
- const incr = ['ArrowUp', 'ArrowLeft'].includes(event.key) ? -1 : 1;
99
- let index = radios.indexOf(this.host) + incr;
100
- if (index < 0)
101
- index = radios.length - 1;
102
- if (index > radios.length - 1)
103
- index = 0;
104
- this.getAllRadios().map((radio) => (radio.checked = false));
105
- radios[index].setFocus();
106
- radios[index].checked = true;
107
- event.preventDefault();
108
- }
109
- }
110
- handleMouseDown(event) {
111
- // Prevent clicks on the label from briefly blurring the input
112
- event.preventDefault();
113
- this.input.focus();
114
- }
115
113
  render() {
116
114
  return (h("label", { part: "base", class: {
117
115
  radio: true,
118
116
  'radio--checked': this.checked,
119
117
  'radio--disabled': this.disabled,
120
118
  'radio--focused': this.hasFocus,
121
- }, 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))));
119
+ }, 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))));
122
120
  }
123
121
  static get is() { return "six-radio"; }
124
122
  static get encapsulation() { return "shadow"; }
@@ -149,7 +147,8 @@ export class SixRadio {
149
147
  "text": "The radio's name attribute."
150
148
  },
151
149
  "attribute": "name",
152
- "reflect": false
150
+ "reflect": false,
151
+ "defaultValue": "''"
153
152
  },
154
153
  "value": {
155
154
  "type": "string",
@@ -166,7 +165,8 @@ export class SixRadio {
166
165
  "text": "The radio's value attribute."
167
166
  },
168
167
  "attribute": "value",
169
- "reflect": false
168
+ "reflect": true,
169
+ "defaultValue": "'on'"
170
170
  },
171
171
  "disabled": {
172
172
  "type": "boolean",
@@ -206,7 +206,7 @@ export class SixRadio {
206
206
  },
207
207
  "invalid": {
208
208
  "type": "boolean",
209
- "mutable": true,
209
+ "mutable": false,
210
210
  "complexType": {
211
211
  "original": "boolean",
212
212
  "resolved": "boolean",
@@ -216,7 +216,7 @@ export class SixRadio {
216
216
  "optional": false,
217
217
  "docs": {
218
218
  "tags": [],
219
- "text": "This will be true when the control is in an invalid state. Validity in range inputs is determined by the message\nprovided by the `setCustomValidity` method."
219
+ "text": "If this property is set to true and an error message is provided by `errorText`, the error message is displayed."
220
220
  },
221
221
  "attribute": "invalid",
222
222
  "reflect": true,
@@ -332,57 +332,6 @@ export class SixRadio {
332
332
  "tags": []
333
333
  }
334
334
  },
335
- "reportValidity": {
336
- "complexType": {
337
- "signature": "() => Promise<boolean>",
338
- "parameters": [],
339
- "references": {
340
- "Promise": {
341
- "location": "global"
342
- }
343
- },
344
- "return": "Promise<boolean>"
345
- },
346
- "docs": {
347
- "text": "Checks for validity and shows the browser's validation message if the control is invalid.",
348
- "tags": []
349
- }
350
- },
351
- "checkValidity": {
352
- "complexType": {
353
- "signature": "() => Promise<boolean>",
354
- "parameters": [],
355
- "references": {
356
- "Promise": {
357
- "location": "global"
358
- }
359
- },
360
- "return": "Promise<boolean>"
361
- },
362
- "docs": {
363
- "text": "Checks for validity.",
364
- "tags": []
365
- }
366
- },
367
- "setCustomValidity": {
368
- "complexType": {
369
- "signature": "(message: string) => Promise<void>",
370
- "parameters": [{
371
- "tags": [],
372
- "text": ""
373
- }],
374
- "references": {
375
- "Promise": {
376
- "location": "global"
377
- }
378
- },
379
- "return": "Promise<void>"
380
- },
381
- "docs": {
382
- "text": "Sets a custom validation message. If `message` is not empty, the field will be considered invalid.",
383
- "tags": []
384
- }
385
- },
386
335
  "reset": {
387
336
  "complexType": {
388
337
  "signature": "() => Promise<void>",
@@ -406,6 +355,9 @@ export class SixRadio {
406
355
  return [{
407
356
  "propName": "checked",
408
357
  "methodName": "handleCheckedChange"
358
+ }, {
359
+ "propName": "name",
360
+ "methodName": "handleNameChange"
409
361
  }];
410
362
  }
411
363
  }
@@ -1 +1 @@
1
- {"version":3,"file":"six-radio.js","sourceRoot":"","sources":["../../../src/components/six-radio/six-radio.tsx"],"names":[],"mappings":"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","sourcesContent":["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"]}
1
+ {"version":3,"file":"six-radio.js","sourceRoot":"","sources":["../../../src/components/six-radio/six-radio.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Method, Prop, State, Watch } from '@stencil/core';\nimport { EmptyPayload } from '../../utils/types';\nimport { EventListeners } from '../../utils/event-listeners';\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 private eventListeners = new EventListeners();\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({ reflect: true }) 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 /** If this property is set to true and an error message is provided by `errorText`, the error message is displayed. */\n @Prop({ 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 @Watch('name')\n handleNameChange(name: string) {\n if (this.nativeInput != null) {\n this.nativeInput.name = name;\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.eventListeners.forward('six-radio-change', 'change', this.host);\n this.eventListeners.forward('six-radio-blur', 'blur', this.host);\n this.eventListeners.forward('six-radio-focus', 'focus', this.host);\n }\n\n componentWillLoad() {\n this.defaultState = this.checked;\n }\n\n disconnectedCallback() {\n this.eventListeners.removeAll();\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 /** Resets the formcontrol */\n @Method()\n async reset() {\n this.checked = this.defaultState;\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"]}