@six-group/ui-library 4.0.0-beta.1 → 4.0.0-beta.2

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 (973) hide show
  1. package/dist/cjs/event-listeners-fdfe838c.js +61 -0
  2. package/dist/cjs/event-listeners-fdfe838c.js.map +1 -0
  3. package/dist/cjs/{execution-control-46f388e0.js → execution-control-b4707294.js} +6 -3
  4. package/dist/cjs/execution-control-b4707294.js.map +1 -0
  5. package/dist/cjs/{focus-visible-0b352c74.js → focus-visible-ae2470dd.js} +3 -3
  6. package/dist/cjs/focus-visible-ae2470dd.js.map +1 -0
  7. package/dist/cjs/form-2df8c5bb.js +20 -0
  8. package/dist/cjs/form-2df8c5bb.js.map +1 -0
  9. package/dist/cjs/{form-control-2c17c573.js → form-control-d369af14.js} +10 -11
  10. package/dist/cjs/form-control-d369af14.js.map +1 -0
  11. package/dist/cjs/{index-2f6daa5b.js → index-900437fc.js} +186 -53
  12. package/dist/cjs/index-900437fc.js.map +1 -0
  13. package/dist/cjs/index.cjs.js +94 -0
  14. package/dist/cjs/index.cjs.js.map +1 -1
  15. package/dist/cjs/loader.cjs.js +3 -12
  16. package/dist/cjs/loader.cjs.js.map +1 -1
  17. package/dist/cjs/{modal-48d42228.js → modal-d5f074c7.js} +4 -3
  18. package/dist/cjs/modal-d5f074c7.js.map +1 -0
  19. package/dist/cjs/{popover-f743f62b.js → popover-2df7e154.js} +39 -31
  20. package/dist/cjs/popover-2df7e154.js.map +1 -0
  21. package/dist/cjs/popup-f1d9910f.js +103 -0
  22. package/dist/cjs/popup-f1d9910f.js.map +1 -0
  23. package/dist/cjs/{scroll-76e6f5d7.js → scroll-03678de1.js} +1 -1
  24. package/dist/cjs/scroll-03678de1.js.map +1 -0
  25. package/dist/cjs/set-attributes_2.cjs.entry.js +4 -2
  26. package/dist/cjs/set-attributes_2.cjs.entry.js.map +1 -1
  27. package/dist/cjs/six-alert.cjs.entry.js +18 -23
  28. package/dist/cjs/six-alert.cjs.entry.js.map +1 -1
  29. package/dist/cjs/six-avatar.cjs.entry.js +5 -8
  30. package/dist/cjs/six-avatar.cjs.entry.js.map +1 -1
  31. package/dist/cjs/six-badge.cjs.entry.js +2 -2
  32. package/dist/cjs/six-badge.cjs.entry.js.map +1 -1
  33. package/dist/cjs/six-button.cjs.entry.js +36 -34
  34. package/dist/cjs/six-button.cjs.entry.js.map +1 -1
  35. package/dist/cjs/six-card.cjs.entry.js +1 -1
  36. package/dist/cjs/six-card.cjs.entry.js.map +1 -1
  37. package/dist/cjs/six-checkbox.cjs.entry.js +50 -85
  38. package/dist/cjs/six-checkbox.cjs.entry.js.map +1 -1
  39. package/dist/cjs/six-datepicker.cjs.entry.js +154 -280
  40. package/dist/cjs/six-datepicker.cjs.entry.js.map +1 -1
  41. package/dist/cjs/six-details.cjs.entry.js +48 -47
  42. package/dist/cjs/six-details.cjs.entry.js.map +1 -1
  43. package/dist/cjs/six-dialog.cjs.entry.js +37 -41
  44. package/dist/cjs/six-dialog.cjs.entry.js.map +1 -1
  45. package/dist/cjs/six-drawer.cjs.entry.js +34 -38
  46. package/dist/cjs/six-drawer.cjs.entry.js.map +1 -1
  47. package/dist/cjs/six-dropdown_2.cjs.entry.js +215 -196
  48. package/dist/cjs/six-dropdown_2.cjs.entry.js.map +1 -1
  49. package/dist/cjs/six-error-page.cjs.entry.js +20 -22
  50. package/dist/cjs/six-error-page.cjs.entry.js.map +1 -1
  51. package/dist/cjs/six-file-list-item.cjs.entry.js +2 -2
  52. package/dist/cjs/six-file-list-item.cjs.entry.js.map +1 -1
  53. package/dist/cjs/six-file-list.cjs.entry.js +1 -1
  54. package/dist/cjs/six-file-list.cjs.entry.js.map +1 -1
  55. package/dist/cjs/six-file-upload.cjs.entry.js +21 -21
  56. package/dist/cjs/six-file-upload.cjs.entry.js.map +1 -1
  57. package/dist/cjs/six-footer.cjs.entry.js +1 -1
  58. package/dist/cjs/six-footer.cjs.entry.js.map +1 -1
  59. package/dist/cjs/six-group-label.cjs.entry.js +12 -11
  60. package/dist/cjs/six-group-label.cjs.entry.js.map +1 -1
  61. package/dist/cjs/six-header.cjs.entry.js +66 -44
  62. package/dist/cjs/six-header.cjs.entry.js.map +1 -1
  63. package/dist/cjs/six-icon-button.cjs.entry.js +4 -4
  64. package/dist/cjs/six-icon-button.cjs.entry.js.map +1 -1
  65. package/dist/cjs/six-icon.cjs.entry.js +1 -1
  66. package/dist/cjs/six-icon.cjs.entry.js.map +1 -1
  67. package/dist/cjs/six-input.cjs.entry.js +95 -128
  68. package/dist/cjs/six-input.cjs.entry.js.map +1 -1
  69. package/dist/cjs/six-item-picker.cjs.entry.js +62 -81
  70. package/dist/cjs/six-item-picker.cjs.entry.js.map +1 -1
  71. package/dist/cjs/six-language-switcher.cjs.entry.js +2 -2
  72. package/dist/cjs/six-language-switcher.cjs.entry.js.map +1 -1
  73. package/dist/cjs/six-layout-grid.cjs.entry.js +5 -3
  74. package/dist/cjs/six-layout-grid.cjs.entry.js.map +1 -1
  75. package/dist/cjs/six-main-container.cjs.entry.js +1 -1
  76. package/dist/cjs/six-main-container.cjs.entry.js.map +1 -1
  77. package/dist/cjs/six-menu-divider.cjs.entry.js +1 -1
  78. package/dist/cjs/six-menu-divider.cjs.entry.js.map +1 -1
  79. package/dist/cjs/six-menu-item.cjs.entry.js +9 -7
  80. package/dist/cjs/six-menu-item.cjs.entry.js.map +1 -1
  81. package/dist/cjs/six-menu-label.cjs.entry.js +1 -1
  82. package/dist/cjs/six-menu-label.cjs.entry.js.map +1 -1
  83. package/dist/cjs/six-picto.cjs.entry.js +5 -2
  84. package/dist/cjs/six-picto.cjs.entry.js.map +1 -1
  85. package/dist/cjs/six-progress-bar.cjs.entry.js +1 -1
  86. package/dist/cjs/six-progress-bar.cjs.entry.js.map +1 -1
  87. package/dist/cjs/six-progress-ring.cjs.entry.js +4 -4
  88. package/dist/cjs/six-progress-ring.cjs.entry.js.map +1 -1
  89. package/dist/cjs/six-radio.cjs.entry.js +63 -72
  90. package/dist/cjs/six-radio.cjs.entry.js.map +1 -1
  91. package/dist/cjs/six-range.cjs.entry.js +107 -106
  92. package/dist/cjs/six-range.cjs.entry.js.map +1 -1
  93. package/dist/cjs/six-root.cjs.entry.js +2 -2
  94. package/dist/cjs/six-root.cjs.entry.js.map +1 -1
  95. package/dist/cjs/six-search-field.cjs.entry.js +11 -6
  96. package/dist/cjs/six-search-field.cjs.entry.js.map +1 -1
  97. package/dist/cjs/six-select.cjs.entry.js +190 -223
  98. package/dist/cjs/six-select.cjs.entry.js.map +1 -1
  99. package/dist/cjs/six-sidebar-item-group.cjs.entry.js +10 -6
  100. package/dist/cjs/six-sidebar-item-group.cjs.entry.js.map +1 -1
  101. package/dist/cjs/six-sidebar-item.cjs.entry.js +1 -1
  102. package/dist/cjs/six-sidebar-item.cjs.entry.js.map +1 -1
  103. package/dist/cjs/six-sidebar.cjs.entry.js +41 -20
  104. package/dist/cjs/six-sidebar.cjs.entry.js.map +1 -1
  105. package/dist/cjs/six-spinner.cjs.entry.js +1 -1
  106. package/dist/cjs/six-spinner.cjs.entry.js.map +1 -1
  107. package/dist/cjs/six-switch.cjs.entry.js +58 -64
  108. package/dist/cjs/six-switch.cjs.entry.js.map +1 -1
  109. package/dist/cjs/six-tab-group.cjs.entry.js +132 -114
  110. package/dist/cjs/six-tab-group.cjs.entry.js.map +1 -1
  111. package/dist/cjs/six-tab-panel.cjs.entry.js +2 -2
  112. package/dist/cjs/six-tab-panel.cjs.entry.js.map +1 -1
  113. package/dist/cjs/six-tab.cjs.entry.js +5 -3
  114. package/dist/cjs/six-tab.cjs.entry.js.map +1 -1
  115. package/dist/cjs/six-tag.cjs.entry.js +6 -9
  116. package/dist/cjs/six-tag.cjs.entry.js.map +1 -1
  117. package/dist/cjs/six-textarea.cjs.entry.js +82 -108
  118. package/dist/cjs/six-textarea.cjs.entry.js.map +1 -1
  119. package/dist/cjs/six-tile.cjs.entry.js +14 -17
  120. package/dist/cjs/six-tile.cjs.entry.js.map +1 -1
  121. package/dist/cjs/six-timepicker.cjs.entry.js +159 -215
  122. package/dist/cjs/six-timepicker.cjs.entry.js.map +1 -1
  123. package/dist/cjs/six-tooltip.cjs.entry.js +54 -57
  124. package/dist/cjs/six-tooltip.cjs.entry.js.map +1 -1
  125. package/dist/cjs/{slot-ad537f24.js → slot-6e6a400f.js} +11 -10
  126. package/dist/cjs/slot-6e6a400f.js.map +1 -0
  127. package/dist/cjs/{types-64878648.js → types-47199040.js} +1 -1
  128. package/dist/cjs/types-47199040.js.map +1 -0
  129. package/dist/cjs/ui-library.cjs.js +3 -6
  130. package/dist/cjs/ui-library.cjs.js.map +1 -1
  131. package/dist/collection/collection-manifest.json +54 -55
  132. package/dist/collection/components/six-alert/six-alert.js +32 -30
  133. package/dist/collection/components/six-alert/six-alert.js.map +1 -1
  134. package/dist/collection/components/six-alert/test/six-alert.spec.js +25 -0
  135. package/dist/collection/components/six-alert/test/six-alert.spec.js.map +1 -0
  136. package/dist/collection/components/six-avatar/six-avatar.js +5 -8
  137. package/dist/collection/components/six-avatar/six-avatar.js.map +1 -1
  138. package/dist/collection/components/six-avatar/test/six-avatar.spec.js +26 -0
  139. package/dist/collection/components/six-avatar/test/six-avatar.spec.js.map +1 -0
  140. package/dist/collection/components/six-badge/six-badge.js +2 -2
  141. package/dist/collection/components/six-badge/six-badge.js.map +1 -1
  142. package/dist/collection/components/six-badge/test/six-badge.spec.js +20 -0
  143. package/dist/collection/components/six-badge/test/six-badge.spec.js.map +1 -0
  144. package/dist/collection/components/six-button/six-button.js +56 -47
  145. package/dist/collection/components/six-button/six-button.js.map +1 -1
  146. package/dist/collection/components/six-button/test/six-button.spec.js +69 -0
  147. package/dist/collection/components/six-button/test/six-button.spec.js.map +1 -0
  148. package/dist/collection/components/six-card/six-card.js +1 -1
  149. package/dist/collection/components/six-card/six-card.js.map +1 -1
  150. package/dist/collection/components/six-card/test/six-card.spec.js +18 -0
  151. package/dist/collection/components/six-card/test/six-card.spec.js.map +1 -0
  152. package/dist/collection/components/six-checkbox/six-checkbox.js +81 -194
  153. package/dist/collection/components/six-checkbox/six-checkbox.js.map +1 -1
  154. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js +79 -0
  155. package/dist/collection/components/six-checkbox/test/six-checkbox.spec.js.map +1 -0
  156. package/dist/collection/components/six-datepicker/components/day-selection.js +3 -3
  157. package/dist/collection/components/six-datepicker/components/day-selection.js.map +1 -1
  158. package/dist/collection/components/six-datepicker/components/month-selection.js +6 -5
  159. package/dist/collection/components/six-datepicker/components/month-selection.js.map +1 -1
  160. package/dist/collection/components/six-datepicker/components/year-selection.js +11 -8
  161. package/dist/collection/components/six-datepicker/components/year-selection.js.map +1 -1
  162. package/dist/collection/components/six-datepicker/six-datepicker.js +219 -395
  163. package/dist/collection/components/six-datepicker/six-datepicker.js.map +1 -1
  164. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js +26 -0
  165. package/dist/collection/components/six-datepicker/test/six-datepicker.spec.js.map +1 -0
  166. package/dist/collection/components/six-details/six-details.js +65 -58
  167. package/dist/collection/components/six-details/six-details.js.map +1 -1
  168. package/dist/collection/components/six-details/test/six-details.spec.js +36 -0
  169. package/dist/collection/components/six-details/test/six-details.spec.js.map +1 -0
  170. package/dist/collection/components/six-dialog/six-dialog.js +55 -51
  171. package/dist/collection/components/six-dialog/six-dialog.js.map +1 -1
  172. package/dist/collection/components/six-dialog/test/six-dialog.spec.js +34 -0
  173. package/dist/collection/components/six-dialog/test/six-dialog.spec.js.map +1 -0
  174. package/dist/collection/components/six-drawer/six-drawer.js +52 -48
  175. package/dist/collection/components/six-drawer/six-drawer.js.map +1 -1
  176. package/dist/collection/components/six-drawer/test/six-drawer.spec.js +34 -0
  177. package/dist/collection/components/six-drawer/test/six-drawer.spec.js.map +1 -0
  178. package/dist/collection/components/six-dropdown/six-dropdown.js +215 -191
  179. package/dist/collection/components/six-dropdown/six-dropdown.js.map +1 -1
  180. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js +122 -0
  181. package/dist/collection/components/six-dropdown/test/six-dropdown.spec.js.map +1 -0
  182. package/dist/collection/components/six-error-page/six-error-page.js +26 -28
  183. package/dist/collection/components/six-error-page/six-error-page.js.map +1 -1
  184. package/dist/collection/components/six-error-page/test/six-error-page.spec.js +240 -0
  185. package/dist/collection/components/six-error-page/test/six-error-page.spec.js.map +1 -0
  186. package/dist/collection/components/six-file-list/six-file-list.js +1 -1
  187. package/dist/collection/components/six-file-list/test/six-file-list.spec.js +67 -0
  188. package/dist/collection/components/six-file-list/test/six-file-list.spec.js.map +1 -0
  189. package/dist/collection/components/six-file-list-item/six-file-list-item.js +8 -6
  190. package/dist/collection/components/six-file-list-item/six-file-list-item.js.map +1 -1
  191. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js +169 -0
  192. package/dist/collection/components/six-file-list-item/test/six-file-list-item.spec.js.map +1 -0
  193. package/dist/collection/components/six-file-upload/six-file-upload.js +37 -35
  194. package/dist/collection/components/six-file-upload/six-file-upload.js.map +1 -1
  195. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js +103 -0
  196. package/dist/collection/components/six-file-upload/test/six-file-upload.spec.js.map +1 -0
  197. package/dist/collection/components/six-footer/six-footer.js +1 -1
  198. package/dist/collection/components/six-footer/test/six-footer.spec.js +21 -0
  199. package/dist/collection/components/six-footer/test/six-footer.spec.js.map +1 -0
  200. package/dist/collection/components/six-group-label/six-group-label.js +15 -13
  201. package/dist/collection/components/six-group-label/six-group-label.js.map +1 -1
  202. package/dist/collection/components/six-group-label/test/six-group-label.spec.js +43 -0
  203. package/dist/collection/components/six-group-label/test/six-group-label.spec.js.map +1 -0
  204. package/dist/collection/components/six-header/six-header.js +82 -52
  205. package/dist/collection/components/six-header/six-header.js.map +1 -1
  206. package/dist/collection/components/six-header/test/six-header.spec.js +133 -0
  207. package/dist/collection/components/six-header/test/six-header.spec.js.map +1 -0
  208. package/dist/collection/components/six-icon/six-icon.js +1 -1
  209. package/dist/collection/components/six-icon/test/six-icon.spec.js +20 -0
  210. package/dist/collection/components/six-icon/test/six-icon.spec.js.map +1 -0
  211. package/dist/collection/components/six-icon-button/six-icon-button.js +10 -10
  212. package/dist/collection/components/six-icon-button/six-icon-button.js.map +1 -1
  213. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js +23 -0
  214. package/dist/collection/components/six-icon-button/test/six-icon-button.spec.js.map +1 -0
  215. package/dist/collection/components/six-input/six-input.css +1 -1
  216. package/dist/collection/components/six-input/six-input.js +189 -362
  217. package/dist/collection/components/six-input/six-input.js.map +1 -1
  218. package/dist/collection/components/six-input/test/six-input.spec.js +37 -0
  219. package/dist/collection/components/six-input/test/six-input.spec.js.map +1 -0
  220. package/dist/collection/components/six-item-picker/six-item-picker.js +79 -94
  221. package/dist/collection/components/six-item-picker/six-item-picker.js.map +1 -1
  222. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js +90 -0
  223. package/dist/collection/components/six-item-picker/test/six-item-picker.spec.js.map +1 -0
  224. package/dist/collection/components/six-language-switcher/six-language-switcher.js +7 -5
  225. package/dist/collection/components/six-language-switcher/six-language-switcher.js.map +1 -1
  226. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js +196 -0
  227. package/dist/collection/components/six-language-switcher/test/six-language-switcher.spec.js.map +1 -0
  228. package/dist/collection/components/six-layout-grid/six-layout-grid.js +10 -8
  229. package/dist/collection/components/six-layout-grid/six-layout-grid.js.map +1 -1
  230. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js +18 -0
  231. package/dist/collection/components/six-layout-grid/test/six-layout-grid.spec.js.map +1 -0
  232. package/dist/collection/components/six-main-container/six-main-container.js +1 -1
  233. package/dist/collection/components/six-main-container/six-main-container.js.map +1 -1
  234. package/dist/collection/components/six-main-container/test/six-main-container.spec.js +22 -0
  235. package/dist/collection/components/six-main-container/test/six-main-container.spec.js.map +1 -0
  236. package/dist/collection/components/six-menu/six-menu.js +41 -31
  237. package/dist/collection/components/six-menu/six-menu.js.map +1 -1
  238. package/dist/collection/components/six-menu/test/six-menu.spec.js +93 -0
  239. package/dist/collection/components/six-menu/test/six-menu.spec.js.map +1 -0
  240. package/dist/collection/components/six-menu-divider/six-menu-divider.js +1 -1
  241. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js +18 -0
  242. package/dist/collection/components/six-menu-divider/test/six-menu-divider.spec.js.map +1 -0
  243. package/dist/collection/components/six-menu-item/six-menu-item.js +17 -11
  244. package/dist/collection/components/six-menu-item/six-menu-item.js.map +1 -1
  245. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js +33 -0
  246. package/dist/collection/components/six-menu-item/test/six-menu-item.spec.js.map +1 -0
  247. package/dist/collection/components/six-menu-label/six-menu-label.js +1 -1
  248. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js +20 -0
  249. package/dist/collection/components/six-menu-label/test/six-menu-label.spec.js.map +1 -0
  250. package/dist/collection/components/six-picto/six-picto.js +5 -2
  251. package/dist/collection/components/six-picto/six-picto.js.map +1 -1
  252. package/dist/collection/components/six-picto/test/six-picto.spec.js +33 -0
  253. package/dist/collection/components/six-picto/test/six-picto.spec.js.map +1 -0
  254. package/dist/collection/components/six-progress-bar/six-progress-bar.js +1 -1
  255. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js +24 -0
  256. package/dist/collection/components/six-progress-bar/test/six-progress-bar.spec.js.map +1 -0
  257. package/dist/collection/components/six-progress-ring/six-progress-ring.js +6 -5
  258. package/dist/collection/components/six-progress-ring/six-progress-ring.js.map +1 -1
  259. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js +26 -0
  260. package/dist/collection/components/six-progress-ring/test/six-progress-ring.spec.js.map +1 -0
  261. package/dist/collection/components/six-radio/six-radio.js +82 -148
  262. package/dist/collection/components/six-radio/six-radio.js.map +1 -1
  263. package/dist/collection/components/six-radio/test/six-radio.spec.js +63 -0
  264. package/dist/collection/components/six-radio/test/six-radio.spec.js.map +1 -0
  265. package/dist/collection/components/six-range/six-range.js +149 -190
  266. package/dist/collection/components/six-range/six-range.js.map +1 -1
  267. package/dist/collection/components/six-range/test/six-range.spec.js +32 -0
  268. package/dist/collection/components/six-range/test/six-range.spec.js.map +1 -0
  269. package/dist/collection/components/six-root/six-root.js +9 -7
  270. package/dist/collection/components/six-root/six-root.js.map +1 -1
  271. package/dist/collection/components/six-root/test/six-root.spec.js +43 -0
  272. package/dist/collection/components/six-root/test/six-root.spec.js.map +1 -0
  273. package/dist/collection/components/six-search-field/six-search-field.js +15 -9
  274. package/dist/collection/components/six-search-field/six-search-field.js.map +1 -1
  275. package/dist/collection/components/six-search-field/test/six-search-field.spec.js +22 -0
  276. package/dist/collection/components/six-search-field/test/six-search-field.spec.js.map +1 -0
  277. package/dist/collection/components/six-select/six-select.css +6 -9
  278. package/dist/collection/components/six-select/six-select.js +235 -349
  279. package/dist/collection/components/six-select/six-select.js.map +1 -1
  280. package/dist/collection/components/six-select/test/six-select.spec.js +82 -0
  281. package/dist/collection/components/six-select/test/six-select.spec.js.map +1 -0
  282. package/dist/collection/components/six-select/test/util.spec.js +81 -0
  283. package/dist/collection/components/six-select/test/util.spec.js.map +1 -0
  284. package/dist/collection/components/six-select/util.js +52 -0
  285. package/dist/collection/components/six-select/util.js.map +1 -0
  286. package/dist/collection/components/six-sidebar/six-sidebar.js +66 -33
  287. package/dist/collection/components/six-sidebar/six-sidebar.js.map +1 -1
  288. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js +22 -0
  289. package/dist/collection/components/six-sidebar/test/six-sidebar.spec.js.map +1 -0
  290. package/dist/collection/components/six-sidebar-item/six-sidebar-item.js +1 -1
  291. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js +50 -0
  292. package/dist/collection/components/six-sidebar-item/test/six-sidebar-item.spec.js.map +1 -0
  293. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js +14 -10
  294. package/dist/collection/components/six-sidebar-item-group/six-sidebar-item-group.js.map +1 -1
  295. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js +53 -0
  296. package/dist/collection/components/six-sidebar-item-group/test/six-sidebar-item-group.spec.js.map +1 -0
  297. package/dist/collection/components/six-spinner/six-spinner.js +1 -1
  298. package/dist/collection/components/six-spinner/six-spinner.js.map +1 -1
  299. package/dist/collection/components/six-spinner/test/six-spinner.spec.js +37 -0
  300. package/dist/collection/components/six-spinner/test/six-spinner.spec.js.map +1 -0
  301. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js +4 -3
  302. package/dist/collection/components/six-stage-indicator/six-stage-indicator.js.map +1 -1
  303. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js +117 -0
  304. package/dist/collection/components/six-stage-indicator/test/six-stage-indicator.spec.js.map +1 -0
  305. package/dist/collection/components/six-switch/six-switch.css +77 -0
  306. package/dist/collection/components/six-switch/six-switch.js +108 -139
  307. package/dist/collection/components/six-switch/six-switch.js.map +1 -1
  308. package/dist/collection/components/six-switch/test/six-switch.spec.js +69 -0
  309. package/dist/collection/components/six-switch/test/six-switch.spec.js.map +1 -0
  310. package/dist/collection/components/six-tab/six-tab.js +13 -7
  311. package/dist/collection/components/six-tab/six-tab.js.map +1 -1
  312. package/dist/collection/components/six-tab/test/six-tab.spec.js +20 -0
  313. package/dist/collection/components/six-tab/test/six-tab.spec.js.map +1 -0
  314. package/dist/collection/components/six-tab-group/six-tab-group.js +140 -119
  315. package/dist/collection/components/six-tab-group/six-tab-group.js.map +1 -1
  316. package/dist/collection/components/six-tab-group/test/six-tab-group.spec.js +45 -0
  317. package/dist/collection/components/six-tab-group/test/six-tab-group.spec.js.map +1 -0
  318. package/dist/collection/components/six-tab-panel/six-tab-panel.js +2 -2
  319. package/dist/collection/components/six-tab-panel/six-tab-panel.js.map +1 -1
  320. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js +20 -0
  321. package/dist/collection/components/six-tab-panel/test/six-tab-panel.spec.js.map +1 -0
  322. package/dist/collection/components/six-tag/six-tag.css +6 -0
  323. package/dist/collection/components/six-tag/six-tag.js +7 -9
  324. package/dist/collection/components/six-tag/six-tag.js.map +1 -1
  325. package/dist/collection/components/six-tag/test/six-tag.spec.js +42 -0
  326. package/dist/collection/components/six-tag/test/six-tag.spec.js.map +1 -0
  327. package/dist/collection/components/six-textarea/six-textarea.js +167 -282
  328. package/dist/collection/components/six-textarea/six-textarea.js.map +1 -1
  329. package/dist/collection/components/six-textarea/test/six-textarea.spec.js +117 -0
  330. package/dist/collection/components/six-textarea/test/six-textarea.spec.js.map +1 -0
  331. package/dist/collection/components/six-tile/six-tile.js +26 -25
  332. package/dist/collection/components/six-tile/six-tile.js.map +1 -1
  333. package/dist/collection/components/six-tile/test/six-tile.spec.js +69 -0
  334. package/dist/collection/components/six-tile/test/six-tile.spec.js.map +1 -0
  335. package/dist/collection/components/six-timepicker/six-timepicker.js +169 -264
  336. package/dist/collection/components/six-timepicker/six-timepicker.js.map +1 -1
  337. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js +496 -0
  338. package/dist/collection/components/six-timepicker/test/six-timepicker.spec.js.map +1 -0
  339. package/dist/collection/components/six-tooltip/six-tooltip.js +69 -66
  340. package/dist/collection/components/six-tooltip/six-tooltip.js.map +1 -1
  341. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js +28 -0
  342. package/dist/collection/components/six-tooltip/test/six-tooltip.spec.js.map +1 -0
  343. package/dist/collection/functional-components/form-control/form-control.js +9 -10
  344. package/dist/collection/functional-components/form-control/form-control.js.map +1 -1
  345. package/dist/collection/index.js +1 -1
  346. package/dist/collection/index.js.map +1 -1
  347. package/dist/collection/testUtil/delay.js.map +1 -1
  348. package/dist/collection/utils/date-util.js +25 -16
  349. package/dist/collection/utils/date-util.js.map +1 -1
  350. package/dist/collection/utils/date-util.spec.js +995 -0
  351. package/dist/collection/utils/date-util.spec.js.map +1 -0
  352. package/dist/collection/utils/error-messages.js +91 -0
  353. package/dist/collection/utils/error-messages.js.map +1 -0
  354. package/dist/collection/utils/event-listeners.js +22 -6
  355. package/dist/collection/utils/event-listeners.js.map +1 -1
  356. package/dist/collection/utils/execution-control.js +5 -4
  357. package/dist/collection/utils/execution-control.js.map +1 -1
  358. package/dist/collection/utils/focus-visible.js +2 -2
  359. package/dist/collection/utils/focus-visible.js.map +1 -1
  360. package/dist/collection/utils/form.js +15 -0
  361. package/dist/collection/utils/form.js.map +1 -0
  362. package/dist/collection/utils/modal.js +3 -2
  363. package/dist/collection/utils/modal.js.map +1 -1
  364. package/dist/collection/utils/popover.js +33 -19
  365. package/dist/collection/utils/popover.js.map +1 -1
  366. package/dist/collection/utils/popup.js +95 -0
  367. package/dist/collection/utils/popup.js.map +1 -0
  368. package/dist/collection/utils/scroll.js +1 -1
  369. package/dist/collection/utils/scroll.spec.js +122 -0
  370. package/dist/collection/utils/scroll.spec.js.map +1 -0
  371. package/dist/collection/utils/slot.js +9 -24
  372. package/dist/collection/utils/slot.js.map +1 -1
  373. package/dist/collection/utils/tabbable.js +6 -6
  374. package/dist/collection/utils/tabbable.js.map +1 -1
  375. package/dist/collection/utils/time.util.js +48 -34
  376. package/dist/collection/utils/time.util.js.map +1 -1
  377. package/dist/collection/utils/time.util.spec.js +368 -0
  378. package/dist/collection/utils/time.util.spec.js.map +1 -0
  379. package/dist/collection/utils/type-check.js +0 -1
  380. package/dist/collection/utils/type-check.js.map +1 -1
  381. package/dist/collection/wrappers/set-attributes/set-attributes.js +4 -2
  382. package/dist/collection/wrappers/set-attributes/set-attributes.js.map +1 -1
  383. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js +16 -0
  384. package/dist/collection/wrappers/set-attributes/test/set-attributes.spec.js.map +1 -0
  385. package/dist/components/event-listeners.js +22 -6
  386. package/dist/components/event-listeners.js.map +1 -1
  387. package/dist/components/execution-control.js +5 -2
  388. package/dist/components/execution-control.js.map +1 -1
  389. package/dist/components/focus-visible.js +2 -2
  390. package/dist/components/focus-visible.js.map +1 -1
  391. package/dist/components/form-control.js +8 -9
  392. package/dist/components/form-control.js.map +1 -1
  393. package/dist/components/form.js +18 -0
  394. package/dist/components/form.js.map +1 -0
  395. package/dist/components/index.js +92 -3
  396. package/dist/components/index.js.map +1 -1
  397. package/dist/components/modal.js +3 -2
  398. package/dist/components/modal.js.map +1 -1
  399. package/dist/components/popover.js +38 -30
  400. package/dist/components/popover.js.map +1 -1
  401. package/dist/components/scroll.js.map +1 -1
  402. package/dist/components/set-attributes2.js +3 -1
  403. package/dist/components/set-attributes2.js.map +1 -1
  404. package/dist/components/six-alert.js +17 -22
  405. package/dist/components/six-alert.js.map +1 -1
  406. package/dist/components/six-avatar.js +4 -7
  407. package/dist/components/six-avatar.js.map +1 -1
  408. package/dist/components/six-badge.js +1 -1
  409. package/dist/components/six-badge.js.map +1 -1
  410. package/dist/components/six-button.js +34 -32
  411. package/dist/components/six-button.js.map +1 -1
  412. package/dist/components/six-card.js.map +1 -1
  413. package/dist/components/six-checkbox.js +48 -89
  414. package/dist/components/six-checkbox.js.map +1 -1
  415. package/dist/components/six-datepicker.js +153 -282
  416. package/dist/components/six-datepicker.js.map +1 -1
  417. package/dist/components/six-details2.js +46 -45
  418. package/dist/components/six-details2.js.map +1 -1
  419. package/dist/components/six-dialog.js +33 -37
  420. package/dist/components/six-dialog.js.map +1 -1
  421. package/dist/components/six-drawer.js +30 -34
  422. package/dist/components/six-drawer.js.map +1 -1
  423. package/dist/components/six-dropdown2.js +185 -173
  424. package/dist/components/six-dropdown2.js.map +1 -1
  425. package/dist/components/six-error-page.js +19 -21
  426. package/dist/components/six-error-page.js.map +1 -1
  427. package/dist/components/six-file-list-item.js +1 -1
  428. package/dist/components/six-file-list-item.js.map +1 -1
  429. package/dist/components/six-file-list.js.map +1 -1
  430. package/dist/components/six-file-upload.js +20 -20
  431. package/dist/components/six-file-upload.js.map +1 -1
  432. package/dist/components/six-footer.js.map +1 -1
  433. package/dist/components/six-group-label.js +10 -9
  434. package/dist/components/six-group-label.js.map +1 -1
  435. package/dist/components/six-header.js +64 -42
  436. package/dist/components/six-header.js.map +1 -1
  437. package/dist/components/six-icon-button2.js +2 -2
  438. package/dist/components/six-icon-button2.js.map +1 -1
  439. package/dist/components/six-icon2.js.map +1 -1
  440. package/dist/components/six-input2.js +96 -138
  441. package/dist/components/six-input2.js.map +1 -1
  442. package/dist/components/six-item-picker2.js +58 -77
  443. package/dist/components/six-item-picker2.js.map +1 -1
  444. package/dist/components/six-language-switcher.js +1 -1
  445. package/dist/components/six-language-switcher.js.map +1 -1
  446. package/dist/components/six-layout-grid.js +5 -3
  447. package/dist/components/six-layout-grid.js.map +1 -1
  448. package/dist/components/six-main-container.js.map +1 -1
  449. package/dist/components/six-menu-divider.js.map +1 -1
  450. package/dist/components/six-menu-item2.js +7 -5
  451. package/dist/components/six-menu-item2.js.map +1 -1
  452. package/dist/components/six-menu-label.js.map +1 -1
  453. package/dist/components/six-menu2.js +25 -18
  454. package/dist/components/six-menu2.js.map +1 -1
  455. package/dist/components/six-picto2.js +4 -1
  456. package/dist/components/six-picto2.js.map +1 -1
  457. package/dist/components/six-progress-bar.js.map +1 -1
  458. package/dist/components/six-progress-ring.js +3 -3
  459. package/dist/components/six-progress-ring.js.map +1 -1
  460. package/dist/components/six-radio.js +65 -78
  461. package/dist/components/six-radio.js.map +1 -1
  462. package/dist/components/six-range.js +108 -111
  463. package/dist/components/six-range.js.map +1 -1
  464. package/dist/components/six-root.js +1 -1
  465. package/dist/components/six-root.js.map +1 -1
  466. package/dist/components/six-search-field.js +8 -3
  467. package/dist/components/six-search-field.js.map +1 -1
  468. package/dist/components/six-select.js +190 -229
  469. package/dist/components/six-select.js.map +1 -1
  470. package/dist/components/six-sidebar-item-group.js +8 -4
  471. package/dist/components/six-sidebar-item-group.js.map +1 -1
  472. package/dist/components/six-sidebar-item.js.map +1 -1
  473. package/dist/components/six-sidebar.js +39 -18
  474. package/dist/components/six-sidebar.js.map +1 -1
  475. package/dist/components/six-spinner2.js.map +1 -1
  476. package/dist/components/six-stage-indicator2.js.map +1 -1
  477. package/dist/components/six-switch.js +61 -69
  478. package/dist/components/six-switch.js.map +1 -1
  479. package/dist/components/six-tab-group.js +129 -111
  480. package/dist/components/six-tab-group.js.map +1 -1
  481. package/dist/components/six-tab-panel.js +1 -1
  482. package/dist/components/six-tab-panel.js.map +1 -1
  483. package/dist/components/six-tab.js +4 -2
  484. package/dist/components/six-tab.js.map +1 -1
  485. package/dist/components/six-tag2.js +5 -8
  486. package/dist/components/six-tag2.js.map +1 -1
  487. package/dist/components/six-textarea.js +83 -115
  488. package/dist/components/six-textarea.js.map +1 -1
  489. package/dist/components/six-tile.js +14 -17
  490. package/dist/components/six-tile.js.map +1 -1
  491. package/dist/components/six-timepicker.js +1 -1
  492. package/dist/components/six-timepicker2.js +247 -258
  493. package/dist/components/six-timepicker2.js.map +1 -1
  494. package/dist/components/six-tooltip2.js +52 -55
  495. package/dist/components/six-tooltip2.js.map +1 -1
  496. package/dist/components/slot.js +10 -9
  497. package/dist/components/slot.js.map +1 -1
  498. package/dist/components.d.ts +361 -88
  499. package/dist/components.json +4265 -1020
  500. package/dist/esm/event-listeners-f6e5b0ab.js +59 -0
  501. package/dist/esm/event-listeners-f6e5b0ab.js.map +1 -0
  502. package/dist/esm/{execution-control-1a60d709.js → execution-control-e0892a05.js} +6 -3
  503. package/dist/esm/execution-control-e0892a05.js.map +1 -0
  504. package/dist/esm/{focus-visible-97933ea9.js → focus-visible-fc6ac671.js} +3 -3
  505. package/dist/esm/focus-visible-fc6ac671.js.map +1 -0
  506. package/dist/esm/form-81252534.js +18 -0
  507. package/dist/esm/form-81252534.js.map +1 -0
  508. package/dist/esm/{form-control-3b440ea1.js → form-control-32cb533f.js} +10 -11
  509. package/dist/esm/form-control-32cb533f.js.map +1 -0
  510. package/dist/esm/{index-5c0f6628.js → index-8a74f992.js} +186 -53
  511. package/dist/esm/index-8a74f992.js.map +1 -0
  512. package/dist/esm/index.js +91 -0
  513. package/dist/esm/index.js.map +1 -1
  514. package/dist/esm/loader.js +4 -13
  515. package/dist/esm/loader.js.map +1 -1
  516. package/dist/esm/{modal-5ebdc320.js → modal-7d32e141.js} +4 -3
  517. package/dist/esm/modal-7d32e141.js.map +1 -0
  518. package/dist/esm/{popover-bd2c2fca.js → popover-136d1f73.js} +39 -31
  519. package/dist/esm/popover-136d1f73.js.map +1 -0
  520. package/dist/esm/popup-7f89a001.js +98 -0
  521. package/dist/esm/popup-7f89a001.js.map +1 -0
  522. package/dist/esm/{scroll-180b53fd.js → scroll-3fb087a2.js} +1 -1
  523. package/dist/esm/scroll-3fb087a2.js.map +1 -0
  524. package/dist/esm/set-attributes_2.entry.js +4 -2
  525. package/dist/esm/set-attributes_2.entry.js.map +1 -1
  526. package/dist/esm/six-alert.entry.js +18 -23
  527. package/dist/esm/six-alert.entry.js.map +1 -1
  528. package/dist/esm/six-avatar.entry.js +5 -8
  529. package/dist/esm/six-avatar.entry.js.map +1 -1
  530. package/dist/esm/six-badge.entry.js +2 -2
  531. package/dist/esm/six-badge.entry.js.map +1 -1
  532. package/dist/esm/six-button.entry.js +36 -34
  533. package/dist/esm/six-button.entry.js.map +1 -1
  534. package/dist/esm/six-card.entry.js +1 -1
  535. package/dist/esm/six-card.entry.js.map +1 -1
  536. package/dist/esm/six-checkbox.entry.js +50 -85
  537. package/dist/esm/six-checkbox.entry.js.map +1 -1
  538. package/dist/esm/six-datepicker.entry.js +152 -278
  539. package/dist/esm/six-datepicker.entry.js.map +1 -1
  540. package/dist/esm/six-details.entry.js +48 -47
  541. package/dist/esm/six-details.entry.js.map +1 -1
  542. package/dist/esm/six-dialog.entry.js +37 -41
  543. package/dist/esm/six-dialog.entry.js.map +1 -1
  544. package/dist/esm/six-drawer.entry.js +34 -38
  545. package/dist/esm/six-drawer.entry.js.map +1 -1
  546. package/dist/esm/six-dropdown_2.entry.js +215 -196
  547. package/dist/esm/six-dropdown_2.entry.js.map +1 -1
  548. package/dist/esm/six-error-page.entry.js +20 -22
  549. package/dist/esm/six-error-page.entry.js.map +1 -1
  550. package/dist/esm/six-file-list-item.entry.js +2 -2
  551. package/dist/esm/six-file-list-item.entry.js.map +1 -1
  552. package/dist/esm/six-file-list.entry.js +1 -1
  553. package/dist/esm/six-file-list.entry.js.map +1 -1
  554. package/dist/esm/six-file-upload.entry.js +21 -21
  555. package/dist/esm/six-file-upload.entry.js.map +1 -1
  556. package/dist/esm/six-footer.entry.js +1 -1
  557. package/dist/esm/six-footer.entry.js.map +1 -1
  558. package/dist/esm/six-group-label.entry.js +12 -11
  559. package/dist/esm/six-group-label.entry.js.map +1 -1
  560. package/dist/esm/six-header.entry.js +66 -44
  561. package/dist/esm/six-header.entry.js.map +1 -1
  562. package/dist/esm/six-icon-button.entry.js +4 -4
  563. package/dist/esm/six-icon-button.entry.js.map +1 -1
  564. package/dist/esm/six-icon.entry.js +1 -1
  565. package/dist/esm/six-icon.entry.js.map +1 -1
  566. package/dist/esm/six-input.entry.js +95 -128
  567. package/dist/esm/six-input.entry.js.map +1 -1
  568. package/dist/esm/six-item-picker.entry.js +62 -81
  569. package/dist/esm/six-item-picker.entry.js.map +1 -1
  570. package/dist/esm/six-language-switcher.entry.js +2 -2
  571. package/dist/esm/six-language-switcher.entry.js.map +1 -1
  572. package/dist/esm/six-layout-grid.entry.js +5 -3
  573. package/dist/esm/six-layout-grid.entry.js.map +1 -1
  574. package/dist/esm/six-main-container.entry.js +1 -1
  575. package/dist/esm/six-main-container.entry.js.map +1 -1
  576. package/dist/esm/six-menu-divider.entry.js +1 -1
  577. package/dist/esm/six-menu-divider.entry.js.map +1 -1
  578. package/dist/esm/six-menu-item.entry.js +9 -7
  579. package/dist/esm/six-menu-item.entry.js.map +1 -1
  580. package/dist/esm/six-menu-label.entry.js +1 -1
  581. package/dist/esm/six-menu-label.entry.js.map +1 -1
  582. package/dist/esm/six-picto.entry.js +5 -2
  583. package/dist/esm/six-picto.entry.js.map +1 -1
  584. package/dist/esm/six-progress-bar.entry.js +1 -1
  585. package/dist/esm/six-progress-bar.entry.js.map +1 -1
  586. package/dist/esm/six-progress-ring.entry.js +4 -4
  587. package/dist/esm/six-progress-ring.entry.js.map +1 -1
  588. package/dist/esm/six-radio.entry.js +63 -72
  589. package/dist/esm/six-radio.entry.js.map +1 -1
  590. package/dist/esm/six-range.entry.js +107 -106
  591. package/dist/esm/six-range.entry.js.map +1 -1
  592. package/dist/esm/six-root.entry.js +2 -2
  593. package/dist/esm/six-root.entry.js.map +1 -1
  594. package/dist/esm/six-search-field.entry.js +11 -6
  595. package/dist/esm/six-search-field.entry.js.map +1 -1
  596. package/dist/esm/six-select.entry.js +190 -223
  597. package/dist/esm/six-select.entry.js.map +1 -1
  598. package/dist/esm/six-sidebar-item-group.entry.js +10 -6
  599. package/dist/esm/six-sidebar-item-group.entry.js.map +1 -1
  600. package/dist/esm/six-sidebar-item.entry.js +1 -1
  601. package/dist/esm/six-sidebar-item.entry.js.map +1 -1
  602. package/dist/esm/six-sidebar.entry.js +41 -20
  603. package/dist/esm/six-sidebar.entry.js.map +1 -1
  604. package/dist/esm/six-spinner.entry.js +1 -1
  605. package/dist/esm/six-spinner.entry.js.map +1 -1
  606. package/dist/esm/six-switch.entry.js +58 -64
  607. package/dist/esm/six-switch.entry.js.map +1 -1
  608. package/dist/esm/six-tab-group.entry.js +132 -114
  609. package/dist/esm/six-tab-group.entry.js.map +1 -1
  610. package/dist/esm/six-tab-panel.entry.js +2 -2
  611. package/dist/esm/six-tab-panel.entry.js.map +1 -1
  612. package/dist/esm/six-tab.entry.js +5 -3
  613. package/dist/esm/six-tab.entry.js.map +1 -1
  614. package/dist/esm/six-tag.entry.js +6 -9
  615. package/dist/esm/six-tag.entry.js.map +1 -1
  616. package/dist/esm/six-textarea.entry.js +82 -108
  617. package/dist/esm/six-textarea.entry.js.map +1 -1
  618. package/dist/esm/six-tile.entry.js +14 -17
  619. package/dist/esm/six-tile.entry.js.map +1 -1
  620. package/dist/esm/six-timepicker.entry.js +159 -215
  621. package/dist/esm/six-timepicker.entry.js.map +1 -1
  622. package/dist/esm/six-tooltip.entry.js +54 -57
  623. package/dist/esm/six-tooltip.entry.js.map +1 -1
  624. package/dist/esm/{slot-6f3984c7.js → slot-ad36df3a.js} +11 -10
  625. package/dist/esm/slot-ad36df3a.js.map +1 -0
  626. package/dist/esm/{types-4b10b413.js → types-59b455aa.js} +1 -1
  627. package/dist/esm/types-59b455aa.js.map +1 -0
  628. package/dist/esm/ui-library.js +4 -7
  629. package/dist/esm/ui-library.js.map +1 -1
  630. package/dist/types/components/six-alert/six-alert.d.ts +5 -7
  631. package/dist/types/components/six-avatar/six-avatar.d.ts +1 -2
  632. package/dist/types/components/six-badge/six-badge.d.ts +0 -1
  633. package/dist/types/components/six-button/six-button.d.ts +8 -9
  634. package/dist/types/components/six-checkbox/six-checkbox.d.ts +23 -35
  635. package/dist/types/components/six-datepicker/components/day-selection.d.ts +9 -5
  636. package/dist/types/components/six-datepicker/components/month-selection.d.ts +8 -5
  637. package/dist/types/components/six-datepicker/components/year-selection.d.ts +7 -5
  638. package/dist/types/components/six-datepicker/six-datepicker.d.ts +41 -52
  639. package/dist/types/components/six-details/six-details.d.ts +12 -12
  640. package/dist/types/components/six-dialog/six-dialog.d.ts +12 -13
  641. package/dist/types/components/six-drawer/six-drawer.d.ts +12 -13
  642. package/dist/types/components/six-dropdown/six-dropdown.d.ts +28 -32
  643. package/dist/types/components/six-error-page/six-error-page.d.ts +1 -1
  644. package/dist/types/components/six-file-list-item/six-file-list-item.d.ts +3 -3
  645. package/dist/types/components/six-file-upload/six-file-upload.d.ts +11 -11
  646. package/dist/types/components/six-group-label/six-group-label.d.ts +5 -5
  647. package/dist/types/components/six-header/six-header.d.ts +16 -27
  648. package/dist/types/components/six-icon-button/six-icon-button.d.ts +4 -4
  649. package/dist/types/components/six-input/six-input.d.ts +32 -67
  650. package/dist/types/components/six-item-picker/six-item-picker.d.ts +13 -16
  651. package/dist/types/components/six-layout-grid/six-layout-grid.d.ts +1 -1
  652. package/dist/types/components/six-menu/six-menu.d.ts +10 -11
  653. package/dist/types/components/six-menu-item/six-menu-item.d.ts +6 -6
  654. package/dist/types/components/six-progress-ring/six-progress-ring.d.ts +2 -2
  655. package/dist/types/components/six-radio/six-radio.d.ts +14 -25
  656. package/dist/types/components/six-range/six-range.d.ts +27 -38
  657. package/dist/types/components/six-root/six-root.d.ts +3 -3
  658. package/dist/types/components/six-search-field/six-search-field.d.ts +4 -5
  659. package/dist/types/components/six-select/six-select.d.ts +41 -58
  660. package/dist/types/components/six-select/util.d.ts +7 -0
  661. package/dist/types/components/six-sidebar/six-sidebar.d.ts +5 -5
  662. package/dist/types/components/six-sidebar-item-group/six-sidebar-item-group.d.ts +7 -6
  663. package/dist/types/components/six-spinner/six-spinner.d.ts +2 -2
  664. package/dist/types/components/six-switch/six-switch.d.ts +18 -21
  665. package/dist/types/components/six-tab/six-tab.d.ts +3 -3
  666. package/dist/types/components/six-tab-group/six-tab-group.d.ts +20 -21
  667. package/dist/types/components/six-tab-panel/six-tab-panel.d.ts +1 -1
  668. package/dist/types/components/six-tag/six-tag.d.ts +1 -3
  669. package/dist/types/components/six-textarea/six-textarea.d.ts +27 -55
  670. package/dist/types/components/six-tile/six-tile.d.ts +2 -3
  671. package/dist/types/components/six-timepicker/six-timepicker.d.ts +26 -43
  672. package/dist/types/components/six-tooltip/six-tooltip.d.ts +19 -21
  673. package/dist/types/components.d.ts +209 -452
  674. package/dist/types/functional-components/form-control/form-control.d.ts +5 -6
  675. package/dist/types/index.d.ts +1 -0
  676. package/dist/types/stencil-public-runtime.d.ts +15 -2
  677. package/dist/types/testUtil/delay.d.ts +1 -1
  678. package/dist/types/types.d.ts +2 -0
  679. package/dist/types/utils/date-util.d.ts +18 -10
  680. package/dist/types/utils/error-messages.d.ts +42 -0
  681. package/dist/types/utils/event-listeners.d.ts +4 -3
  682. package/dist/types/utils/execution-control.d.ts +1 -3
  683. package/dist/types/utils/form.d.ts +1 -0
  684. package/dist/types/utils/modal.d.ts +2 -2
  685. package/dist/types/utils/popover.d.ts +5 -5
  686. package/dist/types/utils/popup.d.ts +9 -0
  687. package/dist/types/utils/slot.d.ts +2 -7
  688. package/dist/types/utils/tabbable.d.ts +1 -1
  689. package/dist/types/utils/time.util.d.ts +18 -9
  690. package/dist/types/utils/type-check.d.ts +3 -4
  691. package/dist/types/wrappers/set-attributes/set-attributes.d.ts +1 -1
  692. package/dist/ui-library/index.esm.js +1 -1
  693. package/dist/ui-library/index.esm.js.map +1 -1
  694. package/dist/ui-library/p-02981b91.entry.js +2 -0
  695. package/dist/ui-library/p-02981b91.entry.js.map +1 -0
  696. package/dist/ui-library/{p-25a3bf57.js → p-0f510624.js} +1 -1
  697. package/dist/ui-library/p-0f510624.js.map +1 -0
  698. package/dist/ui-library/p-0fdb185d.js +2 -0
  699. package/dist/ui-library/p-0fdb185d.js.map +1 -0
  700. package/dist/ui-library/{p-611e1978.entry.js → p-1256cc0a.entry.js} +2 -2
  701. package/dist/ui-library/p-1256cc0a.entry.js.map +1 -0
  702. package/dist/ui-library/{p-19364560.entry.js → p-13b43e04.entry.js} +2 -2
  703. package/dist/ui-library/p-13b43e04.entry.js.map +1 -0
  704. package/dist/ui-library/p-15559d38.js +2 -0
  705. package/dist/ui-library/p-15559d38.js.map +1 -0
  706. package/dist/ui-library/p-19ed7a4c.entry.js +2 -0
  707. package/dist/ui-library/p-19ed7a4c.entry.js.map +1 -0
  708. package/dist/ui-library/{p-97323ad7.entry.js → p-1d5ee1a0.entry.js} +2 -2
  709. package/dist/ui-library/p-1d5ee1a0.entry.js.map +1 -0
  710. package/dist/ui-library/{p-eb8f05a9.js → p-1f18768a.js} +1 -1
  711. package/dist/ui-library/p-1f18768a.js.map +1 -0
  712. package/dist/ui-library/p-21b3b321.entry.js +2 -0
  713. package/dist/ui-library/p-21b3b321.entry.js.map +1 -0
  714. package/dist/ui-library/p-264d4ea8.entry.js +2 -0
  715. package/dist/ui-library/p-264d4ea8.entry.js.map +1 -0
  716. package/dist/ui-library/{p-c30f9e0b.entry.js → p-29ac3d7d.entry.js} +2 -2
  717. package/dist/ui-library/p-29ac3d7d.entry.js.map +1 -0
  718. package/dist/ui-library/p-314b2096.entry.js +2 -0
  719. package/dist/ui-library/p-314b2096.entry.js.map +1 -0
  720. package/dist/ui-library/p-330a4988.entry.js +2 -0
  721. package/dist/ui-library/p-330a4988.entry.js.map +1 -0
  722. package/dist/ui-library/{p-21859bca.entry.js → p-346f9557.entry.js} +2 -2
  723. package/dist/ui-library/p-346f9557.entry.js.map +1 -0
  724. package/dist/ui-library/p-37557787.entry.js +2 -0
  725. package/dist/ui-library/p-37557787.entry.js.map +1 -0
  726. package/dist/ui-library/{p-baa03951.entry.js → p-3cc5addb.entry.js} +2 -2
  727. package/dist/ui-library/p-3cc5addb.entry.js.map +1 -0
  728. package/dist/ui-library/p-3d9de119.entry.js +2 -0
  729. package/dist/ui-library/p-3d9de119.entry.js.map +1 -0
  730. package/dist/ui-library/p-411ed539.entry.js +2 -0
  731. package/dist/ui-library/p-411ed539.entry.js.map +1 -0
  732. package/dist/ui-library/p-4705a51e.entry.js +2 -0
  733. package/dist/ui-library/p-4705a51e.entry.js.map +1 -0
  734. package/dist/ui-library/p-4abed9df.entry.js +2 -0
  735. package/dist/ui-library/p-4abed9df.entry.js.map +1 -0
  736. package/dist/ui-library/p-5654e4c7.js +2 -0
  737. package/dist/ui-library/p-5654e4c7.js.map +1 -0
  738. package/dist/ui-library/p-59210f0b.js +2 -0
  739. package/dist/ui-library/p-59210f0b.js.map +1 -0
  740. package/dist/ui-library/{p-19b50b5a.entry.js → p-5af44076.entry.js} +2 -2
  741. package/dist/ui-library/p-5af44076.entry.js.map +1 -0
  742. package/dist/ui-library/p-5d6b7353.entry.js +2 -0
  743. package/dist/ui-library/p-5d6b7353.entry.js.map +1 -0
  744. package/dist/ui-library/{p-097cced4.entry.js → p-613283a7.entry.js} +2 -2
  745. package/dist/ui-library/p-613283a7.entry.js.map +1 -0
  746. package/dist/ui-library/p-6153045b.js +3 -0
  747. package/dist/ui-library/p-6153045b.js.map +1 -0
  748. package/dist/ui-library/{p-e19a6c95.entry.js → p-6197fe2f.entry.js} +2 -2
  749. package/dist/ui-library/p-6197fe2f.entry.js.map +1 -0
  750. package/dist/ui-library/p-698bb2c8.js +2 -0
  751. package/dist/ui-library/p-698bb2c8.js.map +1 -0
  752. package/dist/ui-library/{p-d5633a29.entry.js → p-72254eef.entry.js} +2 -2
  753. package/dist/ui-library/p-72254eef.entry.js.map +1 -0
  754. package/dist/ui-library/p-724875b0.entry.js +2 -0
  755. package/dist/ui-library/p-724875b0.entry.js.map +1 -0
  756. package/dist/ui-library/{p-dd3c76f1.entry.js → p-7afafb9d.entry.js} +2 -2
  757. package/dist/ui-library/p-7afafb9d.entry.js.map +1 -0
  758. package/dist/ui-library/p-7d95def3.js +2 -0
  759. package/dist/ui-library/p-7d95def3.js.map +1 -0
  760. package/dist/ui-library/{p-63703ba3.entry.js → p-7e3ad38a.entry.js} +2 -2
  761. package/dist/ui-library/p-7e3ad38a.entry.js.map +1 -0
  762. package/dist/ui-library/p-83864cfe.entry.js +2 -0
  763. package/dist/ui-library/p-83864cfe.entry.js.map +1 -0
  764. package/dist/ui-library/{p-9328e5bc.entry.js → p-878226a0.entry.js} +2 -2
  765. package/dist/ui-library/p-878226a0.entry.js.map +1 -0
  766. package/dist/ui-library/p-8c0971e0.js +2 -0
  767. package/dist/ui-library/p-8c0971e0.js.map +1 -0
  768. package/dist/ui-library/p-91b51800.entry.js +2 -0
  769. package/dist/ui-library/p-91b51800.entry.js.map +1 -0
  770. package/dist/ui-library/p-95fbdd0b.entry.js +2 -0
  771. package/dist/ui-library/p-95fbdd0b.entry.js.map +1 -0
  772. package/dist/ui-library/p-99e24daf.entry.js +2 -0
  773. package/dist/ui-library/p-99e24daf.entry.js.map +1 -0
  774. package/dist/ui-library/{p-4f8394d7.js → p-9ace84c7.js} +2 -2
  775. package/dist/ui-library/p-9ace84c7.js.map +1 -0
  776. package/dist/ui-library/p-9b354f5d.entry.js +2 -0
  777. package/dist/ui-library/p-9b354f5d.entry.js.map +1 -0
  778. package/dist/ui-library/{p-c349d1d4.entry.js → p-9c1be3fb.entry.js} +2 -2
  779. package/dist/ui-library/p-9c1be3fb.entry.js.map +1 -0
  780. package/dist/ui-library/p-9f0b43f9.entry.js +2 -0
  781. package/dist/ui-library/p-9f0b43f9.entry.js.map +1 -0
  782. package/dist/ui-library/{p-af793d04.entry.js → p-a0f290d0.entry.js} +2 -2
  783. package/dist/ui-library/p-a0f290d0.entry.js.map +1 -0
  784. package/dist/ui-library/p-a55c7258.entry.js +2 -0
  785. package/dist/ui-library/p-a55c7258.entry.js.map +1 -0
  786. package/dist/ui-library/{p-6d75f216.entry.js → p-a6a9ee96.entry.js} +2 -2
  787. package/dist/ui-library/p-a6a9ee96.entry.js.map +1 -0
  788. package/dist/ui-library/{p-73597d13.entry.js → p-ac099e6b.entry.js} +2 -2
  789. package/dist/ui-library/p-ac099e6b.entry.js.map +1 -0
  790. package/dist/ui-library/p-ae601a0f.entry.js +2 -0
  791. package/dist/ui-library/p-ae601a0f.entry.js.map +1 -0
  792. package/dist/ui-library/p-b351f889.entry.js +2 -0
  793. package/dist/ui-library/p-b351f889.entry.js.map +1 -0
  794. package/dist/ui-library/{p-6433c0da.entry.js → p-b550a258.entry.js} +2 -2
  795. package/dist/ui-library/p-b550a258.entry.js.map +1 -0
  796. package/dist/ui-library/{p-90dc6af4.entry.js → p-bf87464b.entry.js} +2 -2
  797. package/dist/ui-library/p-bf87464b.entry.js.map +1 -0
  798. package/dist/ui-library/p-c03ebf7d.entry.js +2 -0
  799. package/dist/ui-library/p-c03ebf7d.entry.js.map +1 -0
  800. package/dist/ui-library/{p-a1d4f6cf.entry.js → p-cd67da3d.entry.js} +2 -2
  801. package/dist/ui-library/p-cd67da3d.entry.js.map +1 -0
  802. package/dist/ui-library/p-cdaed936.entry.js +2 -0
  803. package/dist/ui-library/p-cdaed936.entry.js.map +1 -0
  804. package/dist/ui-library/{p-8a970a40.entry.js → p-d367f4f9.entry.js} +2 -2
  805. package/dist/ui-library/p-d367f4f9.entry.js.map +1 -0
  806. package/dist/ui-library/p-d42c2025.js +2 -0
  807. package/dist/ui-library/p-d42c2025.js.map +1 -0
  808. package/dist/ui-library/{p-820c23f0.entry.js → p-dfed33c5.entry.js} +2 -2
  809. package/dist/ui-library/p-dfed33c5.entry.js.map +1 -0
  810. package/dist/ui-library/p-ed381ad9.entry.js +2 -0
  811. package/dist/ui-library/p-ed381ad9.entry.js.map +1 -0
  812. package/dist/ui-library/p-ee8342e1.entry.js +2 -0
  813. package/dist/ui-library/p-ee8342e1.entry.js.map +1 -0
  814. package/dist/ui-library/p-ee950ce2.entry.js +2 -0
  815. package/dist/ui-library/p-ee950ce2.entry.js.map +1 -0
  816. package/dist/ui-library/{p-7e0cc4ae.entry.js → p-ff90ffd1.entry.js} +2 -2
  817. package/dist/ui-library/p-ff90ffd1.entry.js.map +1 -0
  818. package/dist/ui-library/ui-library.esm.js +1 -1
  819. package/dist/ui-library/ui-library.esm.js.map +1 -1
  820. package/loader/index.d.ts +1 -1
  821. package/package.json +19 -20
  822. package/dist/cjs/event-listeners-74715e62.js +0 -45
  823. package/dist/cjs/event-listeners-74715e62.js.map +0 -1
  824. package/dist/cjs/execution-control-46f388e0.js.map +0 -1
  825. package/dist/cjs/focus-visible-0b352c74.js.map +0 -1
  826. package/dist/cjs/form-control-2c17c573.js.map +0 -1
  827. package/dist/cjs/index-2f6daa5b.js.map +0 -1
  828. package/dist/cjs/modal-48d42228.js.map +0 -1
  829. package/dist/cjs/popover-f743f62b.js.map +0 -1
  830. package/dist/cjs/scroll-76e6f5d7.js.map +0 -1
  831. package/dist/cjs/six-form.cjs.entry.js +0 -231
  832. package/dist/cjs/six-form.cjs.entry.js.map +0 -1
  833. package/dist/cjs/six-timepicker.types-c19ebff3.js +0 -56
  834. package/dist/cjs/six-timepicker.types-c19ebff3.js.map +0 -1
  835. package/dist/cjs/slot-ad537f24.js.map +0 -1
  836. package/dist/cjs/types-64878648.js.map +0 -1
  837. package/dist/collection/components/six-form/six-form.css +0 -11
  838. package/dist/collection/components/six-form/six-form.js +0 -419
  839. package/dist/collection/components/six-form/six-form.js.map +0 -1
  840. package/dist/collection/components/six-timepicker/six-time-format.js +0 -15
  841. package/dist/collection/components/six-timepicker/six-time-format.js.map +0 -1
  842. package/dist/collection/components/six-timepicker/six-timepicker.types.js +0 -41
  843. package/dist/collection/components/six-timepicker/six-timepicker.types.js.map +0 -1
  844. package/dist/collection/utils/as-array.js +0 -2
  845. package/dist/collection/utils/as-array.js.map +0 -1
  846. package/dist/collection/utils/matchers.js +0 -3
  847. package/dist/collection/utils/matchers.js.map +0 -1
  848. package/dist/collection/utils/testing.js +0 -39
  849. package/dist/collection/utils/testing.js.map +0 -1
  850. package/dist/components/six-form.d.ts +0 -11
  851. package/dist/components/six-form.js +0 -252
  852. package/dist/components/six-form.js.map +0 -1
  853. package/dist/esm/event-listeners-570a24ea.js +0 -43
  854. package/dist/esm/event-listeners-570a24ea.js.map +0 -1
  855. package/dist/esm/execution-control-1a60d709.js.map +0 -1
  856. package/dist/esm/focus-visible-97933ea9.js.map +0 -1
  857. package/dist/esm/form-control-3b440ea1.js.map +0 -1
  858. package/dist/esm/index-5c0f6628.js.map +0 -1
  859. package/dist/esm/modal-5ebdc320.js.map +0 -1
  860. package/dist/esm/polyfills/css-shim.js +0 -1
  861. package/dist/esm/popover-bd2c2fca.js.map +0 -1
  862. package/dist/esm/scroll-180b53fd.js.map +0 -1
  863. package/dist/esm/six-form.entry.js +0 -227
  864. package/dist/esm/six-form.entry.js.map +0 -1
  865. package/dist/esm/six-timepicker.types-e161a447.js +0 -50
  866. package/dist/esm/six-timepicker.types-e161a447.js.map +0 -1
  867. package/dist/esm/slot-6f3984c7.js.map +0 -1
  868. package/dist/esm/types-4b10b413.js.map +0 -1
  869. package/dist/types/components/six-form/six-form.d.ts +0 -69
  870. package/dist/types/components/six-timepicker/six-time-format.d.ts +0 -13
  871. package/dist/types/components/six-timepicker/six-timepicker.types.d.ts +0 -36
  872. package/dist/types/utils/as-array.d.ts +0 -1
  873. package/dist/types/utils/matchers.d.ts +0 -2
  874. package/dist/types/utils/popper.d.ts +0 -33
  875. package/dist/types/utils/testing.d.ts +0 -2
  876. package/dist/ui-library/p-054e12cc.entry.js +0 -2
  877. package/dist/ui-library/p-054e12cc.entry.js.map +0 -1
  878. package/dist/ui-library/p-0786fa7c.js +0 -2
  879. package/dist/ui-library/p-0786fa7c.js.map +0 -1
  880. package/dist/ui-library/p-097cced4.entry.js.map +0 -1
  881. package/dist/ui-library/p-0d79b0c6.entry.js +0 -2
  882. package/dist/ui-library/p-0d79b0c6.entry.js.map +0 -1
  883. package/dist/ui-library/p-14f20bbb.entry.js +0 -2
  884. package/dist/ui-library/p-14f20bbb.entry.js.map +0 -1
  885. package/dist/ui-library/p-18e5f772.entry.js +0 -2
  886. package/dist/ui-library/p-18e5f772.entry.js.map +0 -1
  887. package/dist/ui-library/p-18ea0c56.js +0 -2
  888. package/dist/ui-library/p-18ea0c56.js.map +0 -1
  889. package/dist/ui-library/p-19364560.entry.js.map +0 -1
  890. package/dist/ui-library/p-19b50b5a.entry.js.map +0 -1
  891. package/dist/ui-library/p-21859bca.entry.js.map +0 -1
  892. package/dist/ui-library/p-25a3bf57.js.map +0 -1
  893. package/dist/ui-library/p-2e48c8d2.entry.js +0 -2
  894. package/dist/ui-library/p-2e48c8d2.entry.js.map +0 -1
  895. package/dist/ui-library/p-308261c4.entry.js +0 -2
  896. package/dist/ui-library/p-308261c4.entry.js.map +0 -1
  897. package/dist/ui-library/p-33f7e22b.entry.js +0 -2
  898. package/dist/ui-library/p-33f7e22b.entry.js.map +0 -1
  899. package/dist/ui-library/p-4ae91795.entry.js +0 -2
  900. package/dist/ui-library/p-4ae91795.entry.js.map +0 -1
  901. package/dist/ui-library/p-4f8394d7.js.map +0 -1
  902. package/dist/ui-library/p-53a13db5.entry.js +0 -2
  903. package/dist/ui-library/p-53a13db5.entry.js.map +0 -1
  904. package/dist/ui-library/p-559c87f0.entry.js +0 -2
  905. package/dist/ui-library/p-559c87f0.entry.js.map +0 -1
  906. package/dist/ui-library/p-611e1978.entry.js.map +0 -1
  907. package/dist/ui-library/p-63703ba3.entry.js.map +0 -1
  908. package/dist/ui-library/p-6403fd87.entry.js +0 -2
  909. package/dist/ui-library/p-6403fd87.entry.js.map +0 -1
  910. package/dist/ui-library/p-6433c0da.entry.js.map +0 -1
  911. package/dist/ui-library/p-6d75f216.entry.js.map +0 -1
  912. package/dist/ui-library/p-73597d13.entry.js.map +0 -1
  913. package/dist/ui-library/p-79eee01b.js +0 -2
  914. package/dist/ui-library/p-79eee01b.js.map +0 -1
  915. package/dist/ui-library/p-7e0cc4ae.entry.js.map +0 -1
  916. package/dist/ui-library/p-820c23f0.entry.js.map +0 -1
  917. package/dist/ui-library/p-835c3ff7.entry.js +0 -2
  918. package/dist/ui-library/p-835c3ff7.entry.js.map +0 -1
  919. package/dist/ui-library/p-8a970a40.entry.js.map +0 -1
  920. package/dist/ui-library/p-90824648.entry.js +0 -2
  921. package/dist/ui-library/p-90824648.entry.js.map +0 -1
  922. package/dist/ui-library/p-90dc6af4.entry.js.map +0 -1
  923. package/dist/ui-library/p-9328e5bc.entry.js.map +0 -1
  924. package/dist/ui-library/p-97323ad7.entry.js.map +0 -1
  925. package/dist/ui-library/p-9a860acc.js +0 -2
  926. package/dist/ui-library/p-9a860acc.js.map +0 -1
  927. package/dist/ui-library/p-9d1d222f.entry.js +0 -2
  928. package/dist/ui-library/p-9d1d222f.entry.js.map +0 -1
  929. package/dist/ui-library/p-a1d4f6cf.entry.js.map +0 -1
  930. package/dist/ui-library/p-ac4f4d45.js +0 -3
  931. package/dist/ui-library/p-ac4f4d45.js.map +0 -1
  932. package/dist/ui-library/p-af793d04.entry.js.map +0 -1
  933. package/dist/ui-library/p-b0e5658f.entry.js +0 -2
  934. package/dist/ui-library/p-b0e5658f.entry.js.map +0 -1
  935. package/dist/ui-library/p-b1e66136.js +0 -2
  936. package/dist/ui-library/p-b1e66136.js.map +0 -1
  937. package/dist/ui-library/p-b4dfb7cf.js +0 -2
  938. package/dist/ui-library/p-b4dfb7cf.js.map +0 -1
  939. package/dist/ui-library/p-b997e43c.entry.js +0 -2
  940. package/dist/ui-library/p-b997e43c.entry.js.map +0 -1
  941. package/dist/ui-library/p-baa03951.entry.js.map +0 -1
  942. package/dist/ui-library/p-c0cb6436.entry.js +0 -2
  943. package/dist/ui-library/p-c0cb6436.entry.js.map +0 -1
  944. package/dist/ui-library/p-c30f9e0b.entry.js.map +0 -1
  945. package/dist/ui-library/p-c349d1d4.entry.js.map +0 -1
  946. package/dist/ui-library/p-c53a63f9.entry.js +0 -2
  947. package/dist/ui-library/p-c53a63f9.entry.js.map +0 -1
  948. package/dist/ui-library/p-c640c2d8.entry.js +0 -2
  949. package/dist/ui-library/p-c640c2d8.entry.js.map +0 -1
  950. package/dist/ui-library/p-c94d0b07.entry.js +0 -2
  951. package/dist/ui-library/p-c94d0b07.entry.js.map +0 -1
  952. package/dist/ui-library/p-d12c6092.js +0 -2
  953. package/dist/ui-library/p-d12c6092.js.map +0 -1
  954. package/dist/ui-library/p-d5633a29.entry.js.map +0 -1
  955. package/dist/ui-library/p-dd3c76f1.entry.js.map +0 -1
  956. package/dist/ui-library/p-df655bc9.entry.js +0 -2
  957. package/dist/ui-library/p-df655bc9.entry.js.map +0 -1
  958. package/dist/ui-library/p-e19a6c95.entry.js.map +0 -1
  959. package/dist/ui-library/p-eb8f05a9.js.map +0 -1
  960. package/dist/ui-library/p-edc96efc.entry.js +0 -2
  961. package/dist/ui-library/p-edc96efc.entry.js.map +0 -1
  962. package/dist/ui-library/p-f18ba86f.entry.js +0 -2
  963. package/dist/ui-library/p-f18ba86f.entry.js.map +0 -1
  964. package/dist/ui-library/p-f4938771.entry.js +0 -2
  965. package/dist/ui-library/p-f4938771.entry.js.map +0 -1
  966. package/dist/ui-library/p-f70e2403.entry.js +0 -2
  967. package/dist/ui-library/p-f70e2403.entry.js.map +0 -1
  968. package/dist/ui-library/p-f9d345e0.entry.js +0 -2
  969. package/dist/ui-library/p-f9d345e0.entry.js.map +0 -1
  970. package/dist/ui-library/p-fed07a1f.entry.js +0 -2
  971. package/dist/ui-library/p-fed07a1f.entry.js.map +0 -1
  972. package/dist/ui-library/p-ff0257bf.entry.js +0 -2
  973. package/dist/ui-library/p-ff0257bf.entry.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"six-textarea.js","sourceRoot":"","sources":["../../../src/components/six-textarea/six-textarea.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Method, Prop, State, Watch } from '@stencil/core';\nimport FormControl from '../../functional-components/form-control/form-control';\nimport { hasSlot } from '../../utils/slot';\nimport { EventListeners } from '../../utils/event-listeners';\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 label - The textarea's label. Alternatively, you can use the label prop.\n * @slot help-text - Help text that describes how to use the input.\n * @slot error-text - Error text that is shown for validation errors. Alternatively, you can use the error-text prop.\n *\n * @part base - The component's base wrapper.\n * @part form-control - The form control that wraps the label, textarea, and help text.\n * @part label - The textarea label.\n * @part textarea - The textarea control.\n * @part help-text - The textarea help text.\n */\n@Component({\n tag: 'six-textarea',\n styleUrl: 'six-textarea.scss',\n shadow: true,\n})\nexport class SixTextarea {\n inputId = `textarea-${++id}`;\n labelId = `textarea-label-${id}`;\n helpTextId = `textarea-help-text-${id}`;\n errorTextId = `input-error-text-${id}`;\n resizeObserver: ResizeObserver;\n textarea: HTMLTextAreaElement;\n customErrorText = '';\n customValidation = false;\n\n readonly eventListeners = new EventListeners();\n\n @Element() host: HTMLSixTextareaElement;\n\n @State() hasFocus = false;\n @State() hasHelpTextSlot = false;\n @State() hasErrorTextSlot = false;\n @State() hasLabelSlot = false;\n\n /** The textarea's size. */\n @Prop({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';\n\n /** The textarea's name attribute. */\n @Prop({ reflect: true }) name = '';\n\n /** The textarea's value attribute. */\n @Prop({ mutable: true, reflect: true }) value = '';\n\n /** The textarea's label. Alternatively, you can use the label slot. */\n @Prop() label = '';\n\n /** The textarea's help text. Alternatively, you can use the help-text slot. */\n @Prop() helpText = '';\n\n /** The textarea's error text. Alternatively, you can use the error-text slot. */\n @Prop() errorText = '';\n\n /** The textarea's placeholder text. */\n @Prop() placeholder: string;\n\n /** The number of rows to display by default. */\n @Prop() rows = 4;\n\n /** Controls how the textarea can be resized. */\n @Prop() resize: 'none' | 'vertical' | 'auto' = 'vertical';\n\n /** Set to true to disable the textarea. */\n @Prop({ reflect: true }) disabled = false;\n\n /** Set to true for a readonly textarea. */\n @Prop({ reflect: true }) readonly = false;\n\n /** The minimum length of input that will be considered valid. */\n @Prop({ reflect: true }) minlength: number;\n\n /** The maximum length of input that will be considered valid. */\n @Prop({ reflect: true }) maxlength: number;\n\n /** The textarea's required attribute. */\n @Prop({ reflect: true }) required: boolean;\n\n /**\n * This will be true when the control is in an invalid state. Validity is determined by props such as `required`,\n * `minlength`, and `maxlength` using the browser's constraint validation API.\n */\n @Prop({ mutable: true, reflect: true }) invalid = false;\n\n /** The textarea's autocaptialize attribute. */\n @Prop() autocapitalize: string;\n\n /** The textarea's autocorrect attribute. */\n @Prop() autocorrect: string;\n\n /** The textarea's autocomplete attribute. */\n @Prop() autocomplete: string;\n\n /** The textarea's autofocus attribute. */\n @Prop() autofocus: boolean;\n\n /** The textarea's spellcheck attribute. */\n @Prop() spellcheck: boolean;\n\n /** The textarea's inputmode attribute. */\n @Prop() inputmode: 'none' | 'text' | 'decimal' | 'numeric' | 'tel' | 'search' | 'email' | 'url';\n\n /** Set to display the error text on blur and not when typing */\n @Prop() errorOnBlur = false;\n\n /** Emitted when the control's value changes. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-change' }) sixChange: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control receives input. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-input' }) sixInput: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control gains focus. */\n @Event({ eventName: 'six-textarea-focus' }) sixFocus: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control loses focus. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-blur' }) sixBlur: EventEmitter<EmptyPayload>;\n\n /**\n * Emitted whenever the value changes. Access the new value via event.target.value.\n * six-textarea-value-change will emit whenever the value changes.\n * So be it on textarea or when dynamically set. six-textarea-input will only be emitted when the user enters data,\n * but not when a value is dynamically set. six-textarea-change will only be emitted when the user either presses enter\n * or leaves the textarea field after entering some data.\n * */\n\n @Event({ eventName: 'six-textarea-value-change' }) sixValueChange: EventEmitter<EmptyPayload>;\n\n @Watch('helpText')\n @Watch('errorText')\n @Watch('label')\n handleLabelChange() {\n this.handleSlotChange();\n }\n\n @Watch('rows')\n handleRowsChange() {\n if (this.textarea) {\n this.setTextareaHeight();\n }\n }\n\n @Watch('value')\n handleValueChange() {\n if (!this.textarea) {\n return;\n }\n this.textarea.value = this.value;\n this.invalid = !this.textarea.checkValidity();\n this.sixValueChange.emit();\n }\n\n /** default value the textarea will be reverted to when reset is executed */\n private defaultValue = '';\n\n connectedCallback() {\n this.handleChange = this.handleChange.bind(this);\n this.handleInput = this.handleInput.bind(this);\n this.handleInvalid = this.handleInvalid.bind(this);\n this.handleBlur = this.handleBlur.bind(this);\n this.handleFocus = this.handleFocus.bind(this);\n this.handleSlotChange = this.handleSlotChange.bind(this);\n\n this.host.shadowRoot.addEventListener('slotchange', this.handleSlotChange);\n }\n\n componentWillLoad() {\n this.defaultValue = this.value || '';\n this.handleSlotChange();\n }\n\n componentDidLoad() {\n this.setTextareaHeight();\n this.resizeObserver = new ResizeObserver(() => this.setTextareaHeight());\n this.resizeObserver.observe(this.textarea);\n this.eventListeners.add(this.textarea, 'invalid', (event) => {\n if (this.customValidation || (!this.hasErrorTextSlot && !this.errorText && !this.customErrorText)) {\n this.customErrorText = this.textarea.validationMessage;\n }\n event.preventDefault();\n });\n }\n\n disconnectedCallback() {\n this.resizeObserver.unobserve(this.textarea);\n this.host.shadowRoot.removeEventListener('slotchange', this.handleSlotChange);\n this.eventListeners.removeAll();\n }\n\n /** Sets focus on the textarea. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.textarea.focus(options);\n }\n\n /** Removes focus fromt the textarea. */\n @Method()\n async removeFocus() {\n this.textarea.blur();\n }\n\n /** Selects all the text in the input. */\n @Method()\n async select() {\n return this.textarea.select();\n }\n\n /** Sets the start and end positions of the text selection (0-based). */\n @Method()\n async setSelectionRange(\n selectionStart: number,\n selectionEnd: number,\n selectionDirection: 'forward' | 'backward' | 'none' = 'none'\n ) {\n return this.textarea.setSelectionRange(selectionStart, selectionEnd, selectionDirection);\n }\n\n /** Replaces a range of text with a new string. */\n @Method()\n async setRangeText(\n replacement: string,\n start: number,\n end: number,\n selectMode: 'select' | 'start' | 'end' | 'preserve' = 'preserve'\n ) {\n this.textarea.setRangeText(replacement, start, end, selectMode);\n\n if (this.value !== this.textarea.value) {\n this.value = this.textarea.value;\n this.setTextareaHeight();\n this.sixChange.emit();\n this.sixInput.emit();\n }\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.textarea.reportValidity();\n }\n\n /** Checks for validity. */\n @Method()\n async checkValidity() {\n return this.textarea.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.customErrorText = '';\n this.customValidation = message !== '';\n this.textarea.setCustomValidity(message);\n this.invalid = !this.textarea.checkValidity();\n }\n\n /** Resets the formcontrol */\n @Method()\n async reset() {\n this.value = this.defaultValue;\n this.customErrorText = '';\n this.customValidation = false;\n this.textarea.setCustomValidity('');\n this.invalid = false;\n }\n\n handleChange() {\n this.sixChange.emit();\n }\n\n handleInput() {\n this.value = this.textarea.value;\n this.setTextareaHeight();\n this.sixInput.emit();\n }\n\n handleInvalid() {\n this.invalid = true;\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 handleSlotChange() {\n this.hasLabelSlot = hasSlot(this.host, 'label');\n this.hasHelpTextSlot = hasSlot(this.host, 'help-text');\n this.hasErrorTextSlot = hasSlot(this.host, 'error-text');\n }\n\n setTextareaHeight() {\n if (this.resize === 'auto') {\n this.textarea.style.height = 'auto';\n this.textarea.style.height = this.textarea.scrollHeight + 'px';\n } else {\n this.textarea.style.height = undefined;\n }\n }\n\n displayError() {\n return this.invalid && (!this.errorOnBlur || !this.hasFocus);\n }\n\n render() {\n return (\n <FormControl\n inputId={this.inputId}\n label={this.label}\n labelId={this.labelId}\n hasLabelSlot={this.hasLabelSlot}\n helpTextId={this.helpTextId}\n helpText={this.helpText}\n hasHelpTextSlot={this.hasHelpTextSlot}\n errorTextId={this.errorTextId}\n errorText={this.customErrorText ? this.customErrorText : this.errorText}\n hasErrorTextSlot={this.hasErrorTextSlot}\n size={this.size}\n disabled={this.disabled}\n required={this.required}\n displayError={this.displayError()}\n >\n <div\n part=\"base\"\n class={{\n textarea: true,\n\n // Sizes\n 'textarea--small': this.size === 'small',\n 'textarea--medium': this.size === 'medium',\n 'textarea--large': this.size === 'large',\n\n // States\n 'textarea--disabled': this.disabled,\n 'textarea--focused': this.hasFocus,\n 'textarea--empty': this.value?.length === 0,\n 'textarea--invalid': this.invalid,\n\n // Modifiers\n 'textarea--resize-none': this.resize === 'none',\n 'textarea--resize-vertical': this.resize === 'vertical',\n 'textarea--resize-auto': this.resize === 'auto',\n }}\n >\n <textarea\n part=\"textarea\"\n ref={(el) => (this.textarea = el)}\n id={this.inputId}\n class=\"textarea__control\"\n name={this.name}\n placeholder={this.placeholder}\n disabled={this.disabled}\n readOnly={this.readonly}\n rows={this.rows}\n minLength={this.minlength}\n maxLength={this.maxlength}\n value={this.value}\n autoCapitalize={this.autocapitalize}\n autoCorrect={this.autocorrect}\n autoFocus={this.autofocus}\n spellcheck={this.spellcheck}\n required={this.required}\n inputMode={this.inputmode}\n aria-labelledby={this.labelId}\n onChange={this.handleChange}\n onInput={this.handleInput}\n onInvalid={this.handleInvalid}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n />\n </div>\n </FormControl>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"six-textarea.js","sourceRoot":"","sources":["../../../src/components/six-textarea/six-textarea.tsx"],"names":[],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Method, Prop, State, Watch } from '@stencil/core';\nimport FormControl from '../../functional-components/form-control/form-control';\nimport { hasSlot } from '../../utils/slot';\nimport { EventListeners } from '../../utils/event-listeners';\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 label - The textarea's label. Alternatively, you can use the label prop.\n * @slot help-text - Help text that describes how to use the input.\n * @slot error-text - Error text that is shown for validation errors. Alternatively, you can use the error-text prop.\n *\n * @part base - The component's base wrapper.\n * @part form-control - The form control that wraps the label, textarea, and help text.\n * @part label - The textarea label.\n * @part textarea - The textarea control.\n * @part help-text - The textarea help text.\n */\n@Component({\n tag: 'six-textarea',\n styleUrl: 'six-textarea.scss',\n shadow: true,\n})\nexport class SixTextarea {\n private inputId = `textarea-${++id}`;\n private labelId = `textarea-label-${id}`;\n private helpTextId = `textarea-help-text-${id}`;\n private errorTextId = `input-error-text-${id}`;\n private nativeTextarea?: HTMLTextAreaElement;\n private eventListeners = new EventListeners();\n private resizeObserver = new ResizeObserver(() => this.setTextareaHeight());\n\n @Element() host!: HTMLSixTextareaElement;\n\n @State() hasFocus = false;\n @State() hasHelpTextSlot = false;\n @State() hasLabelSlot = false;\n\n /** The textarea's size. */\n @Prop({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';\n\n /** The textarea's name attribute. */\n @Prop({ reflect: true }) name = '';\n\n /** The textarea's value attribute. */\n @Prop({ mutable: true, reflect: true }) value = '';\n\n /** The textarea's help text. Alternatively, you can use the help-text slot. */\n @Prop() helpText = '';\n\n /** The textarea's placeholder text. */\n @Prop() placeholder?: string;\n\n /** The number of rows to display by default. */\n @Prop() rows = 4;\n\n /** Controls how the textarea can be resized. */\n @Prop() resize: 'none' | 'vertical' | 'auto' = 'vertical';\n\n /** Set to true to disable the textarea. */\n @Prop({ reflect: true }) disabled = false;\n\n /** Set to true for a readonly textarea. */\n @Prop({ reflect: true }) readonly = false;\n\n /** The minimum length of input that will be considered valid. */\n @Prop({ reflect: true }) minlength?: number;\n\n /** The maximum length of input that will be considered valid. */\n @Prop({ reflect: true }) maxlength?: number;\n\n /** Set to true to show an asterisk beneath the label. */\n @Prop() required = false;\n\n /** The label text. */\n @Prop() label = '';\n\n /** The error message shown, if `invalid` is set to true. */\n @Prop() errorText = '';\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 /** The textarea's autocaptialize attribute. */\n @Prop() autocapitalize = 'off';\n\n /** The textarea's autocorrect attribute. */\n @Prop() autocorrect: 'on' | 'off' = 'off';\n\n /** The textarea's autocomplete attribute. */\n @Prop() autocomplete = 'off';\n\n /** The textarea's autofocus attribute. */\n @Prop() autofocus = false;\n\n /** The textarea's spellcheck attribute. */\n @Prop() spellcheck = false;\n\n /** The textarea's inputmode attribute. */\n @Prop() inputmode?: 'none' | 'text' | 'decimal' | 'numeric' | 'tel' | 'search' | 'email' | 'url';\n\n /** Emitted when the control's value changes. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-change' }) sixChange!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control receives input. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-input' }) sixInput!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control gains focus. */\n @Event({ eventName: 'six-textarea-focus' }) sixFocus!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the control loses focus. Access the new value via event.target.value. */\n @Event({ eventName: 'six-textarea-blur' }) sixBlur!: EventEmitter<EmptyPayload>;\n\n @Watch('helpText')\n @Watch('errorText')\n @Watch('label')\n handleLabelChange() {\n this.handleSlotChange();\n }\n\n @Watch('rows')\n handleRowsChange() {\n this.setTextareaHeight();\n }\n\n @Watch('value')\n handleValueChange() {\n this.value = this.getValue();\n if (this.nativeTextarea != null) {\n if (this.nativeTextarea.value !== this.value) {\n this.nativeTextarea.value = this.value;\n }\n }\n }\n\n connectedCallback() {\n this.host.shadowRoot?.addEventListener('slotchange', this.handleSlotChange);\n this.eventListeners.forward('six-textarea-input', 'input', this.host);\n this.eventListeners.forward('six-textarea-change', 'change', this.host);\n this.eventListeners.forward('six-textarea-focus', 'focus', this.host);\n this.eventListeners.forward('six-textarea-blur', 'blur', this.host);\n }\n\n componentWillLoad() {\n this.handleSlotChange();\n }\n\n componentDidLoad() {\n this.setTextareaHeight();\n if (this.nativeTextarea != null) {\n this.resizeObserver.observe(this.nativeTextarea);\n }\n }\n\n disconnectedCallback() {\n if (this.nativeTextarea != null) {\n this.resizeObserver.unobserve(this.nativeTextarea);\n }\n this.host.shadowRoot?.removeEventListener('slotchange', this.handleSlotChange);\n this.eventListeners.removeAll();\n }\n\n /** Sets focus on the textarea. */\n @Method()\n async setFocus(options?: FocusOptions) {\n this.nativeTextarea?.focus(options);\n }\n\n /** Removes focus fromt the textarea. */\n @Method()\n async removeFocus() {\n this.nativeTextarea?.blur();\n }\n\n /** Selects all the text in the input. */\n @Method()\n async select() {\n return this.nativeTextarea?.select();\n }\n\n /** Sets the start and end positions of the text selection (0-based). */\n @Method()\n async setSelectionRange(\n selectionStart: number,\n selectionEnd: number,\n selectionDirection: 'forward' | 'backward' | 'none' = 'none'\n ) {\n return this.nativeTextarea?.setSelectionRange(selectionStart, selectionEnd, selectionDirection);\n }\n\n /** Replaces a range of text with a new string. */\n @Method()\n async setRangeText(\n replacement: string,\n start: number,\n end: number,\n selectMode: 'select' | 'start' | 'end' | 'preserve' = 'preserve'\n ) {\n if (this.nativeTextarea == null) return;\n\n this.nativeTextarea.setRangeText(replacement, start, end, selectMode);\n if (this.getValue() !== this.nativeTextarea.value) {\n this.value = this.nativeTextarea.value;\n this.setTextareaHeight();\n this.sixChange.emit();\n this.sixInput.emit();\n }\n }\n\n private handleChange = () => {\n if (this.nativeTextarea != null) {\n this.value = this.nativeTextarea.value;\n this.sixChange.emit();\n }\n };\n\n private handleInput = () => {\n if (this.nativeTextarea != null) {\n this.value = this.nativeTextarea.value;\n this.setTextareaHeight();\n this.sixInput.emit();\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 handleSlotChange = () => {\n this.hasLabelSlot = hasSlot(this.host, 'label');\n this.hasHelpTextSlot = hasSlot(this.host, 'help-text');\n };\n\n private setTextareaHeight() {\n if (this.nativeTextarea == null) return;\n\n if (this.resize === 'auto') {\n this.nativeTextarea.style.height = 'auto';\n this.nativeTextarea.style.height = this.nativeTextarea.scrollHeight + 'px';\n } else {\n (this.nativeTextarea.style.height as string | undefined) = undefined;\n }\n }\n\n private getValue(): string {\n return (this.value ?? '').toString();\n }\n\n render() {\n return (\n <FormControl\n inputId={this.inputId}\n label={this.label}\n labelId={this.labelId}\n hasLabelSlot={this.hasLabelSlot}\n helpTextId={this.helpTextId}\n helpText={this.helpText}\n hasHelpTextSlot={this.hasHelpTextSlot}\n errorTextId={this.errorTextId}\n errorText={this.errorText}\n size={this.size}\n disabled={this.disabled}\n required={this.required}\n displayError={this.invalid}\n >\n <div\n part=\"base\"\n class={{\n textarea: true,\n\n // Sizes\n 'textarea--small': this.size === 'small',\n 'textarea--medium': this.size === 'medium',\n 'textarea--large': this.size === 'large',\n\n // States\n 'textarea--disabled': this.disabled,\n 'textarea--focused': this.hasFocus,\n 'textarea--empty': this.getValue().length === 0,\n 'textarea--invalid': this.invalid,\n\n // Modifiers\n 'textarea--resize-none': this.resize === 'none',\n 'textarea--resize-vertical': this.resize === 'vertical',\n 'textarea--resize-auto': this.resize === 'auto',\n }}\n >\n <textarea\n part=\"textarea\"\n ref={(el) => (this.nativeTextarea = el)}\n id={this.inputId}\n class=\"textarea__control\"\n name={this.name}\n placeholder={this.placeholder}\n disabled={this.disabled}\n readOnly={this.readonly}\n rows={this.rows}\n minLength={this.minlength}\n maxLength={this.maxlength}\n value={this.getValue()}\n autoCapitalize={this.autocapitalize}\n autoCorrect={this.autocorrect}\n autoFocus={this.autofocus}\n spellcheck={this.spellcheck}\n required={this.required}\n inputMode={this.inputmode}\n aria-labelledby={this.labelId}\n onChange={this.handleChange}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n />\n </div>\n </FormControl>\n );\n }\n}\n"]}
@@ -0,0 +1,117 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixTextarea } from "../six-textarea";
3
+ describe('six-textarea', () => {
4
+ let page;
5
+ let textarea;
6
+ beforeEach(async () => {
7
+ var _a;
8
+ global.ResizeObserver = jest.fn().mockImplementation(() => ({
9
+ observe: jest.fn(),
10
+ unobserve: jest.fn(),
11
+ disconnect: jest.fn(),
12
+ }));
13
+ page = (await newSpecPage({
14
+ components: [SixTextarea],
15
+ html: `<six-textarea></six-textarea>`,
16
+ supportsShadowDom: true,
17
+ }));
18
+ const element = (_a = page.root.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('textarea');
19
+ if (element != null) {
20
+ textarea = element;
21
+ return;
22
+ }
23
+ fail('textarea not found');
24
+ });
25
+ it('renders', async () => {
26
+ // then
27
+ expect(page.root).toEqualHtml(`
28
+ <six-textarea size="medium" value="">
29
+ <mock:shadow-root>
30
+ <div class="form-control form-control--medium" part="form-control">
31
+ <label aria-hidden="true" class="form-control__label" htmlfor="textarea-1" id="textarea-label-1" part="label">
32
+ <slot name="label"></slot>
33
+ </label>
34
+ <div class="form-control__input">
35
+ <div class="textarea textarea--empty textarea--medium textarea--resize-vertical" part="base"><textarea aria-labelledby="textarea-label-1" autocapitalize="off" autocorrect="off" class="textarea__control" id="textarea-1" part="textarea" rows="4" value=""></textarea>
36
+ </div>
37
+ </div>
38
+ <div aria-hidden="true" class="form-control__error-text" id="input-error-text-1" part="error-text"></div>
39
+ <div aria-hidden="true" class="form-control__help-text" id="textarea-help-text-1" part="help-text">
40
+ <slot name="help-text"></slot>
41
+ </div>
42
+ </div>
43
+ </mock:shadow-root>
44
+ </six-textarea>
45
+ `);
46
+ });
47
+ it('should properly dispatch blur event', async () => {
48
+ const spy = jest.fn();
49
+ page.root.addEventListener('six-textarea-blur', spy);
50
+ await page.waitForChanges();
51
+ // when
52
+ textarea.dispatchEvent(new Event('blur'));
53
+ await page.waitForChanges();
54
+ // then
55
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
56
+ detail: undefined,
57
+ type: 'six-textarea-blur',
58
+ }));
59
+ // when
60
+ page.root.value = 'some new value';
61
+ await page.waitForChanges();
62
+ textarea.dispatchEvent(new Event('blur'));
63
+ await page.waitForChanges();
64
+ // then
65
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
66
+ detail: undefined,
67
+ type: 'six-textarea-blur',
68
+ }));
69
+ });
70
+ it('should properly dispatch focus event', async () => {
71
+ const spy = jest.fn();
72
+ page.root.addEventListener('six-textarea-focus', spy);
73
+ await page.waitForChanges();
74
+ // when
75
+ textarea.dispatchEvent(new Event('focus'));
76
+ await page.waitForChanges();
77
+ // then
78
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
79
+ detail: undefined,
80
+ type: 'six-textarea-focus',
81
+ }));
82
+ // when
83
+ page.root.value = 'some new value';
84
+ await page.waitForChanges();
85
+ textarea.dispatchEvent(new Event('focus'));
86
+ await page.waitForChanges();
87
+ // then
88
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
89
+ detail: undefined,
90
+ type: 'six-textarea-focus',
91
+ }));
92
+ });
93
+ it('should properly dispatch input event', async () => {
94
+ const spy = jest.fn();
95
+ page.root.addEventListener('six-textarea-input', spy);
96
+ await page.waitForChanges();
97
+ // when
98
+ textarea.dispatchEvent(new Event('input'));
99
+ await page.waitForChanges();
100
+ // then
101
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
102
+ detail: undefined,
103
+ type: 'six-textarea-input',
104
+ }));
105
+ // when
106
+ page.root.value = 'some new value';
107
+ await page.waitForChanges();
108
+ textarea.dispatchEvent(new Event('input'));
109
+ await page.waitForChanges();
110
+ // then
111
+ expect(spy).toHaveBeenCalledWith(expect.objectContaining({
112
+ detail: undefined,
113
+ type: 'six-textarea-input',
114
+ }));
115
+ });
116
+ });
117
+ //# sourceMappingURL=six-textarea.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-textarea.spec.js","sourceRoot":"","sources":["../../../../src/components/six-textarea/test/six-textarea.spec.tsx"],"names":[],"mappings":"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","sourcesContent":["import { newSpecPage, SpecPage } from '@stencil/core/testing';\nimport { SixTextarea } from '../six-textarea';\n\ninterface TypedSpecPage<T> extends SpecPage {\n root: HTMLElement & T;\n}\n\ndescribe('six-textarea', () => {\n let page: TypedSpecPage<SixTextarea>;\n let textarea: HTMLTextAreaElement;\n\n beforeEach(async () => {\n global.ResizeObserver = jest.fn().mockImplementation(() => ({\n observe: jest.fn(),\n unobserve: jest.fn(),\n disconnect: jest.fn(),\n }));\n\n page = (await newSpecPage({\n components: [SixTextarea],\n html: `<six-textarea></six-textarea>`,\n supportsShadowDom: true,\n })) as TypedSpecPage<SixTextarea>;\n\n const element = page.root.shadowRoot?.querySelector('textarea');\n if (element != null) {\n textarea = element;\n return;\n }\n fail('textarea not found');\n });\n\n it('renders', async () => {\n // then\n expect(page.root).toEqualHtml(`\n <six-textarea size=\"medium\" value=\"\">\n <mock:shadow-root>\n <div class=\"form-control form-control--medium\" part=\"form-control\">\n <label aria-hidden=\"true\" class=\"form-control__label\" htmlfor=\"textarea-1\" id=\"textarea-label-1\" part=\"label\">\n <slot name=\"label\"></slot>\n </label>\n <div class=\"form-control__input\">\n <div class=\"textarea textarea--empty textarea--medium textarea--resize-vertical\" part=\"base\"><textarea aria-labelledby=\"textarea-label-1\" autocapitalize=\"off\" autocorrect=\"off\" class=\"textarea__control\" id=\"textarea-1\" part=\"textarea\" rows=\"4\" value=\"\"></textarea>\n </div>\n </div>\n <div aria-hidden=\"true\" class=\"form-control__error-text\" id=\"input-error-text-1\" part=\"error-text\"></div>\n <div aria-hidden=\"true\" class=\"form-control__help-text\" id=\"textarea-help-text-1\" part=\"help-text\">\n <slot name=\"help-text\"></slot>\n </div>\n </div>\n </mock:shadow-root>\n </six-textarea>\n `);\n });\n\n it('should properly dispatch blur event', async () => {\n const spy = jest.fn();\n page.root.addEventListener('six-textarea-blur', spy);\n await page.waitForChanges();\n\n // when\n textarea.dispatchEvent(new Event('blur'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-blur',\n })\n );\n\n // when\n page.root.value = 'some new value';\n await page.waitForChanges();\n textarea.dispatchEvent(new Event('blur'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-blur',\n })\n );\n });\n\n it('should properly dispatch focus event', async () => {\n const spy = jest.fn();\n page.root.addEventListener('six-textarea-focus', spy);\n await page.waitForChanges();\n\n // when\n textarea.dispatchEvent(new Event('focus'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-focus',\n })\n );\n\n // when\n page.root.value = 'some new value';\n await page.waitForChanges();\n textarea.dispatchEvent(new Event('focus'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-focus',\n })\n );\n });\n\n it('should properly dispatch input event', async () => {\n const spy = jest.fn();\n page.root.addEventListener('six-textarea-input', spy);\n await page.waitForChanges();\n\n // when\n textarea.dispatchEvent(new Event('input'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-input',\n })\n );\n\n // when\n page.root.value = 'some new value';\n await page.waitForChanges();\n textarea.dispatchEvent(new Event('input'));\n await page.waitForChanges();\n\n // then\n expect(spy).toHaveBeenCalledWith(\n expect.objectContaining({\n detail: undefined,\n type: 'six-textarea-input',\n })\n );\n });\n});\n"]}
@@ -1,11 +1,23 @@
1
- import { h } from '@stencil/core';
2
- import { hasSlot } from '../../utils/slot';
1
+ import { h } from "@stencil/core";
2
+ import { getSlot, hasSlot } from "../../utils/slot";
3
3
  /**
4
4
  * @since 1.0
5
5
  * @status stable
6
6
  */
7
7
  export class SixTile {
8
8
  constructor() {
9
+ this.handleSlotChange = () => {
10
+ this.hasIconSlot = hasSlot(this.host, 'icon');
11
+ this.hasLabelSlot = hasSlot(this.host, 'label');
12
+ if (this.hasIconSlot) {
13
+ const slot = getSlot(this.host, 'icon');
14
+ slot === null || slot === void 0 ? void 0 : slot.addEventListener('click', this.handleClickEvent);
15
+ }
16
+ if (this.hasLabelSlot) {
17
+ const slot = getSlot(this.host, 'label');
18
+ slot === null || slot === void 0 ? void 0 : slot.addEventListener('click', this.handleClickEvent);
19
+ }
20
+ };
9
21
  this.handleCloseClickEvent = () => {
10
22
  this.visible = false;
11
23
  this.sixTileClose.emit();
@@ -32,24 +44,9 @@ export class SixTile {
32
44
  async show() {
33
45
  this.visible = true;
34
46
  }
35
- connectedCallback() {
36
- this.handleSlotChange = this.handleSlotChange.bind(this);
37
- }
38
47
  componentWillLoad() {
39
48
  this.handleSlotChange();
40
49
  }
41
- handleSlotChange() {
42
- this.hasIconSlot = hasSlot(this.host, 'icon');
43
- this.hasLabelSlot = hasSlot(this.host, 'label');
44
- if (this.hasIconSlot) {
45
- let slot = this.host.querySelector(`[slot="icon"]`);
46
- slot.addEventListener('click', this.handleClickEvent);
47
- }
48
- if (this.hasLabelSlot) {
49
- let slot = this.host.querySelector(`[slot="label"]`);
50
- slot.addEventListener('click', this.handleClickEvent);
51
- }
52
- }
53
50
  render() {
54
51
  return (h("six-tooltip", { disabled: this.disableTooltip || this.label === '', content: this.label }, h("div", { part: "base", class: {
55
52
  tile: true,
@@ -101,15 +98,15 @@ export class SixTile {
101
98
  "defaultValue": "''"
102
99
  },
103
100
  "iconName": {
104
- "type": "any",
101
+ "type": "string",
105
102
  "mutable": false,
106
103
  "complexType": {
107
- "original": "any",
108
- "resolved": "any",
104
+ "original": "string",
105
+ "resolved": "string | undefined",
109
106
  "references": {}
110
107
  },
111
108
  "required": false,
112
- "optional": false,
109
+ "optional": true,
113
110
  "docs": {
114
111
  "tags": [],
115
112
  "text": "The icon's name."
@@ -233,7 +230,8 @@ export class SixTile {
233
230
  "references": {
234
231
  "EmptyPayload": {
235
232
  "location": "import",
236
- "path": "../../utils/types"
233
+ "path": "../../utils/types",
234
+ "id": "src/utils/types.ts::EmptyPayload"
237
235
  }
238
236
  }
239
237
  }
@@ -253,7 +251,8 @@ export class SixTile {
253
251
  "references": {
254
252
  "EmptyPayload": {
255
253
  "location": "import",
256
- "path": "../../utils/types"
254
+ "path": "../../utils/types",
255
+ "id": "src/utils/types.ts::EmptyPayload"
257
256
  }
258
257
  }
259
258
  }
@@ -267,7 +266,8 @@ export class SixTile {
267
266
  "parameters": [],
268
267
  "references": {
269
268
  "Promise": {
270
- "location": "global"
269
+ "location": "global",
270
+ "id": "global::Promise"
271
271
  }
272
272
  },
273
273
  "return": "Promise<void>"
@@ -283,7 +283,8 @@ export class SixTile {
283
283
  "parameters": [],
284
284
  "references": {
285
285
  "Promise": {
286
- "location": "global"
286
+ "location": "global",
287
+ "id": "global::Promise"
287
288
  }
288
289
  },
289
290
  "return": "Promise<void>"
@@ -1 +1 @@
1
- {"version":3,"file":"six-tile.js","sourceRoot":"","sources":["../../../src/components/six-tile/six-tile.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAgB,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEhG,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE3C;;;GAGG;AAOH,MAAM,OAAO,OAAO;;IAkIV,0BAAqB,GAAG,GAAG,EAAE;MACnC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;MACrB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC,CAAC;IAEM,qBAAgB,GAAG,GAAG,EAAE;MAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC,CAAC;iBArIc,EAAE;;qBAME,IAAI;oBAGL,KAAK;0BAGU,IAAI;oBAGF,KAAK;gBAGqB,QAAQ;mBAEnD,IAAI;uBAoBA,KAAK;wBAEJ,KAAK;;EAd7B,qBAAqB;EAErB,KAAK,CAAC,IAAI;IACR,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;EACvB,CAAC;EAED,qBAAqB;EAErB,KAAK,CAAC,IAAI;IACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;EACtB,CAAC;EAMD,iBAAiB;IACf,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;EAC3D,CAAC;EAED,iBAAiB;IACf,IAAI,CAAC,gBAAgB,EAAE,CAAC;EAC1B,CAAC;EAED,gBAAgB;IACd,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC9C,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAEhD,IAAI,IAAI,CAAC,WAAW,EAAE;MACpB,IAAI,IAAI,GAAgB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;MACjE,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;KACvD;IAED,IAAI,IAAI,CAAC,YAAY,EAAE;MACrB,IAAI,IAAI,GAAgB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;MAClE,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;KACvD;EACH,CAAC;EAED,MAAM;IACJ,OAAO,CACL,mBAAa,QAAQ,EAAE,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,KAAK,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK;MAClF,WACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;UACL,IAAI,EAAE,IAAI;UACV,eAAe,EAAE,IAAI,CAAC,OAAO;UAC7B,aAAa,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;UACpC,cAAc,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ;UACtC,aAAa,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;UACpC,gBAAgB,EAAE,IAAI,CAAC,QAAQ;SAChC;QAED,WAAK,IAAI,EAAC,QAAQ,EAAC,KAAK,EAAC,cAAc;UACrC,uBACE,KAAK,EAAE;cACL,sBAAsB,EAAE,CAAC,IAAI,CAAC,SAAS;aACxC,EACD,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAC9B,OAAO,EAAE,IAAI,CAAC,qBAAqB,GACnC,CACE;QAEN,WAAK,IAAI,EAAC,MAAM,EAAC,KAAK,EAAC,YAAY;UAChC,IAAI,CAAC,QAAQ,IAAI,CAChB,gBAAU,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAChE,IAAI,CAAC,QAAQ,CACL,CACZ;UACA,IAAI,CAAC,WAAW,IAAI,YAAM,IAAI,EAAC,MAAM,GAAQ,CAC1C;QAEN,WACE,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE;YACL,qBAAqB,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;YAC5C,sBAAsB,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ;YAC9C,qBAAqB,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO;WAC7C;UAEA,IAAI,CAAC,KAAK,IAAI,CACb,WACE,KAAK,EAAE;cACL,gBAAgB,EAAE,IAAI;aACvB,EACD,OAAO,EAAE,IAAI,CAAC,gBAAgB,IAE7B,IAAI,CAAC,KAAK,CACP,CACP;UACA,IAAI,CAAC,YAAY,IAAI,YAAM,IAAI,EAAC,OAAO,GAAQ,CAC5C,CACF,CACM,CACf,CAAC;EACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAUF;AAED,MAAM,aAAa,GAAG,CAAC,IAAY,EAAE,EAAE;EACrC,OAAO;IACL,KAAK,EAAE,SAAS;IAChB,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,QAAQ;GAChB,CAAC,IAAI,CAAwB,CAAC;AACjC,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAE,EAAE;EAChC,OAAO;IACL,KAAK,EAAE,QAAQ;IACf,MAAM,EAAE,SAAS;IACjB,KAAK,EAAE,UAAU;GAClB,CAAC,IAAI,CAAsC,CAAC;AAC/C,CAAC,CAAC","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Method, Prop, State } from '@stencil/core';\nimport { EmptyPayload } from '../../utils/types';\nimport { hasSlot } from '../../utils/slot';\n\n/**\n * @since 1.0\n * @status stable\n */\n\n@Component({\n tag: 'six-tile',\n styleUrl: 'six-tile.scss',\n shadow: true,\n})\nexport class SixTile {\n @Element() host: HTMLSixTileElement;\n\n /** The tile's label. */\n @Prop() label = '';\n\n /** The icon's name. */\n @Prop() iconName;\n\n /** Flag, whether the tile is closeable. */\n @Prop() closeable = true;\n\n /** Flag, whether the tile should cast a shadow. */\n @Prop() elevated = false;\n\n /** Enables tile tooltip for tiles */\n @Prop() disableTooltip: boolean = true;\n\n /** Set to true to disable the tile. */\n @Prop({ reflect: true }) disabled = false;\n\n /** The tile's size. */\n @Prop({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';\n\n @State() visible = true;\n\n /** Emitted when the tile was closed. */\n @Event({ eventName: 'six-tile-closed' }) sixTileClose: EventEmitter<EmptyPayload>;\n\n /** Emitted when the tile is selected. */\n @Event({ eventName: 'six-tile-selected' }) sixTileSelected: EventEmitter<EmptyPayload>;\n\n /** Hides the tile */\n @Method()\n async hide() {\n this.visible = false;\n }\n\n /** Shows the tile */\n @Method()\n async show() {\n this.visible = true;\n }\n\n @State() hasIconSlot = false;\n\n @State() hasLabelSlot = false;\n\n connectedCallback() {\n this.handleSlotChange = this.handleSlotChange.bind(this);\n }\n\n componentWillLoad() {\n this.handleSlotChange();\n }\n\n handleSlotChange() {\n this.hasIconSlot = hasSlot(this.host, 'icon');\n this.hasLabelSlot = hasSlot(this.host, 'label');\n\n if (this.hasIconSlot) {\n let slot: HTMLElement = this.host.querySelector(`[slot=\"icon\"]`);\n slot.addEventListener('click', this.handleClickEvent);\n }\n\n if (this.hasLabelSlot) {\n let slot: HTMLElement = this.host.querySelector(`[slot=\"label\"]`);\n slot.addEventListener('click', this.handleClickEvent);\n }\n }\n\n render() {\n return (\n <six-tooltip disabled={this.disableTooltip || this.label === ''} content={this.label}>\n <div\n part=\"base\"\n class={{\n tile: true,\n 'tile--visible': this.visible,\n 'tile--small': this.size === 'small',\n 'tile--medium': this.size === 'medium',\n 'tile--large': this.size === 'large',\n 'tile--elevated': this.elevated,\n }}\n >\n <div part=\"header\" class=\"tile__header\">\n <six-icon-button\n class={{\n 'tile__header--hidden': !this.closeable,\n }}\n name=\"close\"\n size={closeIconSize(this.size)}\n onClick={this.handleCloseClickEvent}\n />\n </div>\n\n <div part=\"body\" class=\"tile__body\">\n {this.iconName && (\n <six-icon onClick={this.handleClickEvent} size={iconSize(this.size)}>\n {this.iconName}\n </six-icon>\n )}\n {this.hasIconSlot && <slot name=\"icon\"></slot>}\n </div>\n\n <div\n part=\"footer\"\n class={{\n 'tile__footer--small': this.size === 'small',\n 'tile__footer--medium': this.size === 'medium',\n 'tile__footer--large': this.size === 'large',\n }}\n >\n {this.label && (\n <div\n class={{\n '.label__footer': true,\n }}\n onClick={this.handleClickEvent}\n >\n {this.label}\n </div>\n )}\n {this.hasLabelSlot && <slot name=\"label\"></slot>}\n </div>\n </div>\n </six-tooltip>\n );\n }\n\n private handleCloseClickEvent = () => {\n this.visible = false;\n this.sixTileClose.emit();\n };\n\n private handleClickEvent = () => {\n this.sixTileSelected.emit();\n };\n}\n\nconst closeIconSize = (size: string) => {\n return {\n small: 'xxSmall',\n medium: 'medium',\n large: 'medium',\n }[size] as 'xSmall' | 'medium';\n};\n\nconst iconSize = (size: string) => {\n return {\n small: 'xLarge',\n medium: 'xxLarge',\n large: 'xxxLarge',\n }[size] as 'xLarge' | 'xxLarge' | 'xxxLarge';\n};\n"]}
1
+ {"version":3,"file":"six-tile.js","sourceRoot":"","sources":["../../../src/components/six-tile/six-tile.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Method, Prop, State } from '@stencil/core';\nimport { EmptyPayload } from '../../utils/types';\nimport { getSlot, hasSlot } from '../../utils/slot';\n\n/**\n * @since 1.0\n * @status stable\n */\n\n@Component({\n tag: 'six-tile',\n styleUrl: 'six-tile.scss',\n shadow: true,\n})\nexport class SixTile {\n @Element() host!: HTMLSixTileElement;\n\n /** The tile's label. */\n @Prop() label = '';\n\n /** The icon's name. */\n @Prop() iconName?: string;\n\n /** Flag, whether the tile is closeable. */\n @Prop() closeable = true;\n\n /** Flag, whether the tile should cast a shadow. */\n @Prop() elevated = false;\n\n /** Enables tile tooltip for tiles */\n @Prop() disableTooltip = true;\n\n /** Set to true to disable the tile. */\n @Prop({ reflect: true }) disabled = false;\n\n /** The tile's size. */\n @Prop({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';\n\n @State() visible = true;\n\n /** Emitted when the tile was closed. */\n @Event({ eventName: 'six-tile-closed' }) sixTileClose!: EventEmitter<EmptyPayload>;\n\n /** Emitted when the tile is selected. */\n @Event({ eventName: 'six-tile-selected' }) sixTileSelected!: EventEmitter<EmptyPayload>;\n\n /** Hides the tile */\n @Method()\n async hide() {\n this.visible = false;\n }\n\n /** Shows the tile */\n @Method()\n async show() {\n this.visible = true;\n }\n\n @State() hasIconSlot = false;\n\n @State() hasLabelSlot = false;\n\n componentWillLoad() {\n this.handleSlotChange();\n }\n\n private handleSlotChange = () => {\n this.hasIconSlot = hasSlot(this.host, 'icon');\n this.hasLabelSlot = hasSlot(this.host, 'label');\n\n if (this.hasIconSlot) {\n const slot = getSlot(this.host, 'icon');\n slot?.addEventListener('click', this.handleClickEvent);\n }\n\n if (this.hasLabelSlot) {\n const slot = getSlot(this.host, 'label');\n slot?.addEventListener('click', this.handleClickEvent);\n }\n };\n\n render() {\n return (\n <six-tooltip disabled={this.disableTooltip || this.label === ''} content={this.label}>\n <div\n part=\"base\"\n class={{\n tile: true,\n 'tile--visible': this.visible,\n 'tile--small': this.size === 'small',\n 'tile--medium': this.size === 'medium',\n 'tile--large': this.size === 'large',\n 'tile--elevated': this.elevated,\n }}\n >\n <div part=\"header\" class=\"tile__header\">\n <six-icon-button\n class={{\n 'tile__header--hidden': !this.closeable,\n }}\n name=\"close\"\n size={closeIconSize(this.size)}\n onClick={this.handleCloseClickEvent}\n />\n </div>\n\n <div part=\"body\" class=\"tile__body\">\n {this.iconName && (\n <six-icon onClick={this.handleClickEvent} size={iconSize(this.size)}>\n {this.iconName}\n </six-icon>\n )}\n {this.hasIconSlot && <slot name=\"icon\"></slot>}\n </div>\n\n <div\n part=\"footer\"\n class={{\n 'tile__footer--small': this.size === 'small',\n 'tile__footer--medium': this.size === 'medium',\n 'tile__footer--large': this.size === 'large',\n }}\n >\n {this.label && (\n <div\n class={{\n '.label__footer': true,\n }}\n onClick={this.handleClickEvent}\n >\n {this.label}\n </div>\n )}\n {this.hasLabelSlot && <slot name=\"label\"></slot>}\n </div>\n </div>\n </six-tooltip>\n );\n }\n\n private handleCloseClickEvent = () => {\n this.visible = false;\n this.sixTileClose.emit();\n };\n\n private handleClickEvent = () => {\n this.sixTileSelected.emit();\n };\n}\n\nconst closeIconSize = (size: string) => {\n return {\n small: 'xxSmall',\n medium: 'medium',\n large: 'medium',\n }[size] as 'xSmall' | 'medium';\n};\n\nconst iconSize = (size: string) => {\n return {\n small: 'xLarge',\n medium: 'xxLarge',\n large: 'xxxLarge',\n }[size] as 'xLarge' | 'xxLarge' | 'xxxLarge';\n};\n"]}
@@ -0,0 +1,69 @@
1
+ import { newSpecPage } from "@stencil/core/testing";
2
+ import { SixTile } from "../six-tile";
3
+ describe('six-tile', () => {
4
+ it('renders six-tile with props', async () => {
5
+ const page = await newSpecPage({
6
+ components: [SixTile],
7
+ html: `<six-tile label="Medium" icon-name="home"></six-tile>`,
8
+ });
9
+ expect(page.root).toEqualHtml(`
10
+ <six-tile label="Medium" icon-name="home" size="medium">
11
+ <mock:shadow-root>
12
+ <six-tooltip disabled="" content="Medium">
13
+ <div class="tile tile--medium tile--visible" part="base">
14
+ <div class="tile__header" part="header">
15
+ <six-icon-button name="close" size="medium"></six-icon-button>
16
+ </div>
17
+ <div class="tile__body" part="body">
18
+ <six-icon size="xxLarge">
19
+ home
20
+ </six-icon>
21
+ </div>
22
+ <div class="tile__footer--medium" part="footer">
23
+ <div class=".label__footer">
24
+ Medium
25
+ </div>
26
+ </div>
27
+ </div>
28
+ </six-tooltip>
29
+ </mock:shadow-root>
30
+ </six-tile>
31
+ `);
32
+ });
33
+ it('renders six-tile with slot', async () => {
34
+ const page = await newSpecPage({
35
+ components: [SixTile],
36
+ html: `
37
+ <six-tile>
38
+ <six-icon slot="icon">delete</six-icon>
39
+ <div slot="label">short label</div>
40
+ </six-tile>`,
41
+ });
42
+ expect(page.root).toEqualHtml(`
43
+ <six-tile size="medium">
44
+ <mock:shadow-root>
45
+ <six-tooltip content="" disabled="">
46
+ <div class="tile tile--medium tile--visible" part="base">
47
+ <div class="tile__header" part="header">
48
+ <six-icon-button name="close" size="medium"></six-icon-button>
49
+ </div>
50
+ <div class="tile__body" part="body">
51
+ <slot name="icon"></slot>
52
+ </div>
53
+ <div class="tile__footer--medium" part="footer">
54
+ <slot name="label"></slot>
55
+ </div>
56
+ </div>
57
+ </six-tooltip>
58
+ </mock:shadow-root>
59
+ <six-icon slot="icon">
60
+ delete
61
+ </six-icon>
62
+ <div slot="label">
63
+ short label
64
+ </div>
65
+ </six-tile>
66
+ `);
67
+ });
68
+ });
69
+ //# sourceMappingURL=six-tile.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"six-tile.spec.js","sourceRoot":"","sources":["../../../../src/components/six-tile/test/six-tile.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;EACxB,EAAE,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;IAC3C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE,uDAAuD;KAC9D,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;;;;KAsB7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;IAC1C,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,OAAO,CAAC;MACrB,IAAI,EAAE;;;;kBAIM;KACb,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;;;;;;KAwB7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { SixTile } from '../six-tile';\n\ndescribe('six-tile', () => {\n it('renders six-tile with props', async () => {\n const page = await newSpecPage({\n components: [SixTile],\n html: `<six-tile label=\"Medium\" icon-name=\"home\"></six-tile>`,\n });\n expect(page.root).toEqualHtml(`\n <six-tile label=\"Medium\" icon-name=\"home\" size=\"medium\">\n <mock:shadow-root>\n <six-tooltip disabled=\"\" content=\"Medium\">\n <div class=\"tile tile--medium tile--visible\" part=\"base\">\n <div class=\"tile__header\" part=\"header\">\n <six-icon-button name=\"close\" size=\"medium\"></six-icon-button>\n </div>\n <div class=\"tile__body\" part=\"body\">\n <six-icon size=\"xxLarge\">\n home\n </six-icon>\n </div>\n <div class=\"tile__footer--medium\" part=\"footer\">\n <div class=\".label__footer\">\n Medium\n </div>\n </div>\n </div>\n </six-tooltip>\n </mock:shadow-root>\n </six-tile>\n `);\n });\n\n it('renders six-tile with slot', async () => {\n const page = await newSpecPage({\n components: [SixTile],\n html: `\n <six-tile>\n <six-icon slot=\"icon\">delete</six-icon>\n <div slot=\"label\">short label</div>\n </six-tile>`,\n });\n expect(page.root).toEqualHtml(`\n <six-tile size=\"medium\">\n <mock:shadow-root>\n <six-tooltip content=\"\" disabled=\"\">\n <div class=\"tile tile--medium tile--visible\" part=\"base\">\n <div class=\"tile__header\" part=\"header\">\n <six-icon-button name=\"close\" size=\"medium\"></six-icon-button>\n </div>\n <div class=\"tile__body\" part=\"body\">\n <slot name=\"icon\"></slot>\n </div>\n <div class=\"tile__footer--medium\" part=\"footer\">\n <slot name=\"label\"></slot>\n </div>\n </div>\n </six-tooltip>\n </mock:shadow-root>\n <six-icon slot=\"icon\">\n delete\n </six-icon>\n <div slot=\"label\">\n short label\n </div>\n </six-tile>\n `);\n });\n});\n"]}