@scania/tegel 1.25.0-fix-a11y-checkbox-beta.0 → 1.25.0-fix-a11y-chip-more-improvements-beta.0

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 (416) hide show
  1. package/dist/cjs/loader.cjs.js +1 -1
  2. package/dist/cjs/tds-body-cell.cjs.entry.js +2 -2
  3. package/dist/cjs/tds-breadcrumb.cjs.entry.js +2 -2
  4. package/dist/cjs/tds-breadcrumbs.cjs.entry.js +7 -1
  5. package/dist/cjs/tds-button.cjs.entry.js +9 -3
  6. package/dist/cjs/tds-card.cjs.entry.js +1 -1
  7. package/dist/cjs/tds-checkbox.cjs.entry.js +3 -13
  8. package/dist/cjs/tds-chip.cjs.entry.js +12 -2
  9. package/dist/cjs/tds-core-header-item_2.cjs.entry.js +40 -3
  10. package/dist/cjs/tds-datetime.cjs.entry.js +20 -13
  11. package/dist/cjs/tds-divider.cjs.entry.js +1 -1
  12. package/dist/cjs/tds-dropdown_2.cjs.entry.js +186 -199
  13. package/dist/cjs/tds-folder-tab.cjs.entry.js +2 -2
  14. package/dist/cjs/tds-folder-tabs.cjs.entry.js +2 -2
  15. package/dist/cjs/tds-footer-group.cjs.entry.js +3 -3
  16. package/dist/cjs/tds-footer-item.cjs.entry.js +1 -1
  17. package/dist/cjs/tds-footer.cjs.entry.js +2 -2
  18. package/dist/cjs/tds-header-brand-symbol.cjs.entry.js +1 -1
  19. package/dist/cjs/tds-header-cell.cjs.entry.js +1 -1
  20. package/dist/cjs/tds-header-dropdown-list-item.cjs.entry.js +2 -2
  21. package/dist/cjs/tds-header-dropdown-list-user.cjs.entry.js +1 -1
  22. package/dist/cjs/tds-header-dropdown-list.cjs.entry.js +1 -1
  23. package/dist/cjs/tds-header-dropdown.cjs.entry.js +3 -3
  24. package/dist/cjs/tds-header-hamburger.cjs.entry.js +1 -1
  25. package/dist/cjs/tds-header-launcher-button.cjs.entry.js +1 -1
  26. package/dist/cjs/tds-header-launcher-grid-item.cjs.entry.js +1 -1
  27. package/dist/cjs/tds-header-launcher-grid-title.cjs.entry.js +1 -1
  28. package/dist/cjs/tds-header-launcher-grid.cjs.entry.js +1 -1
  29. package/dist/cjs/tds-header-launcher-list-item.cjs.entry.js +1 -1
  30. package/dist/cjs/tds-header-launcher-list-title.cjs.entry.js +1 -1
  31. package/dist/cjs/tds-header-launcher-list.cjs.entry.js +1 -1
  32. package/dist/cjs/tds-header-launcher.cjs.entry.js +2 -2
  33. package/dist/cjs/tds-header-title.cjs.entry.js +1 -1
  34. package/dist/cjs/tds-header.cjs.entry.js +1 -1
  35. package/dist/cjs/tds-icon.cjs.entry.js +1 -1
  36. package/dist/cjs/tds-inline-tab.cjs.entry.js +2 -2
  37. package/dist/cjs/tds-inline-tabs.cjs.entry.js +2 -2
  38. package/dist/cjs/tds-link.cjs.entry.js +2 -2
  39. package/dist/cjs/tds-message.cjs.entry.js +2 -2
  40. package/dist/cjs/tds-modal.cjs.entry.js +2 -2
  41. package/dist/cjs/tds-navigation-tab.cjs.entry.js +2 -2
  42. package/dist/cjs/tds-navigation-tabs.cjs.entry.js +4 -4
  43. package/dist/cjs/tds-popover-canvas.cjs.entry.js +2 -2
  44. package/dist/cjs/tds-popover-core.cjs.entry.js +1 -1
  45. package/dist/cjs/tds-popover-menu-item.cjs.entry.js +2 -2
  46. package/dist/cjs/tds-popover-menu.cjs.entry.js +2 -2
  47. package/dist/cjs/tds-radio-button.cjs.entry.js +1 -1
  48. package/dist/cjs/tds-side-menu-close-button.cjs.entry.js +1 -1
  49. package/dist/cjs/tds-side-menu-collapse-button.cjs.entry.js +4 -4
  50. package/dist/cjs/tds-side-menu-dropdown-list-item.cjs.entry.js +2 -2
  51. package/dist/cjs/tds-side-menu-dropdown-list.cjs.entry.js +2 -2
  52. package/dist/cjs/tds-side-menu-dropdown.cjs.entry.js +3 -3
  53. package/dist/cjs/tds-side-menu-item.cjs.entry.js +2 -2
  54. package/dist/cjs/tds-side-menu-overlay.cjs.entry.js +1 -1
  55. package/dist/cjs/tds-side-menu-user-image_2.cjs.entry.js +2 -2
  56. package/dist/cjs/tds-side-menu-user.cjs.entry.js +1 -1
  57. package/dist/cjs/tds-slider.cjs.entry.js +7 -7
  58. package/dist/cjs/tds-spinner.cjs.entry.js +1 -1
  59. package/dist/cjs/tds-step.cjs.entry.js +1 -1
  60. package/dist/cjs/tds-table-body-input-wrapper.cjs.entry.js +1 -1
  61. package/dist/cjs/tds-table-body-row-expandable.cjs.entry.js +7 -7
  62. package/dist/cjs/tds-table-body-row.cjs.entry.js +2 -2
  63. package/dist/cjs/tds-table-body.cjs.entry.js +2 -2
  64. package/dist/cjs/tds-table-footer.cjs.entry.js +3 -3
  65. package/dist/cjs/tds-table-header-input-wrapper.cjs.entry.js +1 -1
  66. package/dist/cjs/tds-table-header.cjs.entry.js +2 -2
  67. package/dist/cjs/tds-table-toolbar.cjs.entry.js +2 -2
  68. package/dist/cjs/tds-text-field.cjs.entry.js +6 -6
  69. package/dist/cjs/tds-textarea.cjs.entry.js +3 -3
  70. package/dist/cjs/tds-toast.cjs.entry.js +3 -3
  71. package/dist/cjs/tds-toggle.cjs.entry.js +11 -2
  72. package/dist/cjs/tds-tooltip.cjs.entry.js +2 -2
  73. package/dist/cjs/tegel.cjs.js +1 -1
  74. package/dist/collection/components/breadcrumbs/breadcrumb/breadcrumb.css +9 -10
  75. package/dist/collection/components/breadcrumbs/breadcrumb/breadcrumb.js +2 -2
  76. package/dist/collection/components/breadcrumbs/breadcrumbs.js +30 -1
  77. package/dist/collection/components/button/button.js +26 -3
  78. package/dist/collection/components/card/card.js +1 -1
  79. package/dist/collection/components/checkbox/checkbox.js +3 -30
  80. package/dist/collection/components/chip/chip.js +30 -3
  81. package/dist/collection/components/datetime/datetime.css +20 -0
  82. package/dist/collection/components/datetime/datetime.js +22 -15
  83. package/dist/collection/components/divider/divider.js +1 -1
  84. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +16 -6
  85. package/dist/collection/components/dropdown/dropdown.js +236 -242
  86. package/dist/collection/components/footer/footer-group/footer-group.js +3 -3
  87. package/dist/collection/components/footer/footer-item/footer-item.js +1 -1
  88. package/dist/collection/components/footer/footer.js +2 -2
  89. package/dist/collection/components/header/core-header-item/core-header-item.js +1 -1
  90. package/dist/collection/components/header/header-brand-symbol/header-brand-symbol.js +1 -1
  91. package/dist/collection/components/header/header-dropdown/header-dropdown.js +3 -3
  92. package/dist/collection/components/header/header-dropdown-list/header-dropdown-list.js +1 -1
  93. package/dist/collection/components/header/header-dropdown-list-item/header-dropdown-list-item.js +2 -2
  94. package/dist/collection/components/header/header-dropdown-list-user/header-dropdown-list-user.js +1 -1
  95. package/dist/collection/components/header/header-hamburger/header-hamburger.js +1 -1
  96. package/dist/collection/components/header/header-item/header-item.js +39 -2
  97. package/dist/collection/components/header/header-launcher/header-launcher.js +2 -2
  98. package/dist/collection/components/header/header-launcher-button/header-launcher-button.js +1 -1
  99. package/dist/collection/components/header/header-launcher-grid/header-launcher-grid.js +1 -1
  100. package/dist/collection/components/header/header-launcher-grid-item/header-launcher-grid-item.js +1 -1
  101. package/dist/collection/components/header/header-launcher-grid-title/header-launcher-grid-title.js +1 -1
  102. package/dist/collection/components/header/header-launcher-list/header-launcher-list.js +1 -1
  103. package/dist/collection/components/header/header-launcher-list-item/header-launcher-list-item.js +1 -1
  104. package/dist/collection/components/header/header-launcher-list-title/header-launcher-list-title.js +1 -1
  105. package/dist/collection/components/header/header-title/header-title.js +1 -1
  106. package/dist/collection/components/header/header.js +1 -1
  107. package/dist/collection/components/icon/icon.js +1 -1
  108. package/dist/collection/components/link/link.js +2 -2
  109. package/dist/collection/components/message/message.js +2 -2
  110. package/dist/collection/components/modal/modal.js +2 -2
  111. package/dist/collection/components/popover-canvas/popover-canvas.js +2 -2
  112. package/dist/collection/components/popover-core/popover-core.js +1 -1
  113. package/dist/collection/components/popover-menu/popover-menu-item/popover-menu-item.js +2 -2
  114. package/dist/collection/components/popover-menu/popover-menu.js +2 -2
  115. package/dist/collection/components/radio-button/radio-button.js +1 -1
  116. package/dist/collection/components/side-menu/side-menu-close-button/side-menu-close-button.js +1 -1
  117. package/dist/collection/components/side-menu/side-menu-collapse-button/side-menu-collapse-button.js +4 -4
  118. package/dist/collection/components/side-menu/side-menu-dropdown/side-menu-dropdown.js +3 -3
  119. package/dist/collection/components/side-menu/side-menu-dropdown-list/side-menu-dropdown-list.js +2 -2
  120. package/dist/collection/components/side-menu/side-menu-dropdown-list-item/side-menu-dropdown-list-item.js +2 -2
  121. package/dist/collection/components/side-menu/side-menu-item/side-menu-item.js +2 -2
  122. package/dist/collection/components/side-menu/side-menu-overlay/side-menu-overlay.js +1 -1
  123. package/dist/collection/components/side-menu/side-menu-user/side-menu-user.js +1 -1
  124. package/dist/collection/components/side-menu/side-menu-user-image/side-menu-user-image.js +1 -1
  125. package/dist/collection/components/side-menu/side-menu-user-label/side-menu-user-label.js +1 -1
  126. package/dist/collection/components/slider/slider.js +7 -7
  127. package/dist/collection/components/spinner/spinner.js +1 -1
  128. package/dist/collection/components/stepper/step/step.js +1 -1
  129. package/dist/collection/components/table/table-body/table-body.js +2 -2
  130. package/dist/collection/components/table/table-body-cell/table-body-cell.js +2 -2
  131. package/dist/collection/components/table/table-body-input-wrapper/table-body-input-wrapper.js +1 -1
  132. package/dist/collection/components/table/table-body-row/table-body-row.js +2 -2
  133. package/dist/collection/components/table/table-body-row-expandable/table-body-row-expandable.js +7 -7
  134. package/dist/collection/components/table/table-footer/table-footer.js +3 -3
  135. package/dist/collection/components/table/table-header/table-header.js +2 -2
  136. package/dist/collection/components/table/table-header-cell/table-header-cell.js +1 -1
  137. package/dist/collection/components/table/table-header-input-wrapper/table-header-input-wrapper.js +1 -1
  138. package/dist/collection/components/table/table-toolbar/table-toolbar.js +2 -2
  139. package/dist/collection/components/tabs/folder-tabs/folder-tab/folder-tab.js +2 -2
  140. package/dist/collection/components/tabs/folder-tabs/folder-tabs.js +2 -2
  141. package/dist/collection/components/tabs/inline-tabs/inline-tab/inline-tab.js +2 -2
  142. package/dist/collection/components/tabs/inline-tabs/inline-tabs.js +2 -2
  143. package/dist/collection/components/tabs/navigation-tabs/navigation-tab/navigation-tab.js +2 -2
  144. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +4 -4
  145. package/dist/collection/components/text-field/text-field.js +6 -6
  146. package/dist/collection/components/textarea/textarea.js +3 -3
  147. package/dist/collection/components/toast/toast.js +3 -3
  148. package/dist/collection/components/toggle/toggle.js +28 -2
  149. package/dist/collection/components/tooltip/tooltip.js +2 -2
  150. package/dist/components/{p-2ef329f1.js → p-0e6efec9.js} +2 -2
  151. package/dist/components/{p-4bdaf254.js → p-265c3467.js} +1 -1
  152. package/dist/components/{p-f0a50868.js → p-29d19dc8.js} +3 -3
  153. package/dist/components/{p-96d51054.js → p-2a43e410.js} +18 -8
  154. package/dist/components/{p-75437dea.js → p-34737ed9.js} +1 -1
  155. package/dist/components/{p-d1ace0be.js → p-3e93886d.js} +1 -1
  156. package/dist/components/{p-3351035f.js → p-4764a1d5.js} +1 -1
  157. package/dist/components/{p-f1980746.js → p-4c1e3344.js} +4 -4
  158. package/dist/components/{p-9d7232d0.js → p-8c849aa2.js} +2 -2
  159. package/dist/components/{p-ad77fb02.js → p-a2b7bdef.js} +1 -1
  160. package/dist/components/{p-467fe701.js → p-a64dc22e.js} +179 -199
  161. package/dist/components/{p-ece57b20.js → p-c65351ab.js} +3 -14
  162. package/dist/components/{p-3a7f88ff.js → p-d61bd22e.js} +40 -3
  163. package/dist/components/{p-707a562e.js → p-e49a0ceb.js} +1 -1
  164. package/dist/components/{p-8f8b0827.js → p-e8d2dbbf.js} +1 -1
  165. package/dist/components/tds-accordion-item.js +1 -1
  166. package/dist/components/tds-banner.js +1 -1
  167. package/dist/components/tds-body-cell.js +2 -2
  168. package/dist/components/tds-breadcrumb.js +3 -3
  169. package/dist/components/tds-breadcrumbs.js +10 -2
  170. package/dist/components/tds-button.js +10 -3
  171. package/dist/components/tds-card.js +2 -2
  172. package/dist/components/tds-checkbox.js +1 -1
  173. package/dist/components/tds-chip.js +14 -3
  174. package/dist/components/tds-core-header-item.js +1 -1
  175. package/dist/components/tds-datetime.js +21 -14
  176. package/dist/components/tds-divider.js +1 -1
  177. package/dist/components/tds-dropdown-option.js +1 -1
  178. package/dist/components/tds-dropdown.js +1 -1
  179. package/dist/components/tds-folder-tab.js +2 -2
  180. package/dist/components/tds-folder-tabs.js +3 -3
  181. package/dist/components/tds-footer-group.js +4 -4
  182. package/dist/components/tds-footer-item.js +1 -1
  183. package/dist/components/tds-footer.js +2 -2
  184. package/dist/components/tds-header-brand-symbol.js +3 -3
  185. package/dist/components/tds-header-cell.js +2 -2
  186. package/dist/components/tds-header-dropdown-list-item.js +1 -1
  187. package/dist/components/tds-header-dropdown-list-user.js +1 -1
  188. package/dist/components/tds-header-dropdown-list.js +1 -1
  189. package/dist/components/tds-header-dropdown.js +8 -8
  190. package/dist/components/tds-header-hamburger.js +4 -4
  191. package/dist/components/tds-header-item.js +1 -1
  192. package/dist/components/tds-header-launcher-button.js +1 -1
  193. package/dist/components/tds-header-launcher-grid-item.js +1 -1
  194. package/dist/components/tds-header-launcher-grid-title.js +1 -1
  195. package/dist/components/tds-header-launcher-grid.js +1 -1
  196. package/dist/components/tds-header-launcher-list-item.js +2 -2
  197. package/dist/components/tds-header-launcher-list-title.js +1 -1
  198. package/dist/components/tds-header-launcher-list.js +2 -2
  199. package/dist/components/tds-header-launcher.js +8 -8
  200. package/dist/components/tds-header-title.js +1 -1
  201. package/dist/components/tds-header.js +1 -1
  202. package/dist/components/tds-icon.js +1 -1
  203. package/dist/components/tds-inline-tab.js +2 -2
  204. package/dist/components/tds-inline-tabs.js +3 -3
  205. package/dist/components/tds-link.js +2 -2
  206. package/dist/components/tds-message.js +3 -3
  207. package/dist/components/tds-modal.js +3 -3
  208. package/dist/components/tds-navigation-tab.js +2 -2
  209. package/dist/components/tds-navigation-tabs.js +5 -5
  210. package/dist/components/tds-popover-canvas.js +1 -1
  211. package/dist/components/tds-popover-core.js +1 -1
  212. package/dist/components/tds-popover-menu-item.js +2 -2
  213. package/dist/components/tds-popover-menu.js +3 -3
  214. package/dist/components/tds-radio-button.js +1 -1
  215. package/dist/components/tds-side-menu-close-button.js +2 -2
  216. package/dist/components/tds-side-menu-collapse-button.js +5 -5
  217. package/dist/components/tds-side-menu-dropdown-list-item.js +2 -2
  218. package/dist/components/tds-side-menu-dropdown-list.js +2 -2
  219. package/dist/components/tds-side-menu-dropdown.js +5 -5
  220. package/dist/components/tds-side-menu-item.js +1 -1
  221. package/dist/components/tds-side-menu-overlay.js +1 -1
  222. package/dist/components/tds-side-menu-user-image.js +1 -1
  223. package/dist/components/tds-side-menu-user-label.js +1 -1
  224. package/dist/components/tds-side-menu-user.js +3 -3
  225. package/dist/components/tds-slider.js +8 -8
  226. package/dist/components/tds-spinner.js +1 -1
  227. package/dist/components/tds-step.js +2 -2
  228. package/dist/components/tds-table-body-input-wrapper.js +2 -2
  229. package/dist/components/tds-table-body-row-expandable.js +7 -7
  230. package/dist/components/tds-table-body-row.js +3 -3
  231. package/dist/components/tds-table-body.js +2 -2
  232. package/dist/components/tds-table-footer.js +7 -7
  233. package/dist/components/tds-table-header-input-wrapper.js +2 -2
  234. package/dist/components/tds-table-header.js +3 -3
  235. package/dist/components/tds-table-toolbar.js +3 -3
  236. package/dist/components/tds-text-field.js +7 -7
  237. package/dist/components/tds-textarea.js +4 -4
  238. package/dist/components/tds-toast.js +4 -4
  239. package/dist/components/tds-toggle.js +12 -2
  240. package/dist/components/tds-tooltip.js +3 -3
  241. package/dist/esm/loader.js +1 -1
  242. package/dist/esm/tds-body-cell.entry.js +2 -2
  243. package/dist/esm/tds-breadcrumb.entry.js +3 -3
  244. package/dist/esm/tds-breadcrumbs.entry.js +7 -1
  245. package/dist/esm/tds-button.entry.js +9 -3
  246. package/dist/esm/tds-card.entry.js +1 -1
  247. package/dist/esm/tds-checkbox.entry.js +3 -13
  248. package/dist/esm/tds-chip.entry.js +12 -2
  249. package/dist/esm/tds-core-header-item_2.entry.js +40 -3
  250. package/dist/esm/tds-datetime.entry.js +20 -13
  251. package/dist/esm/tds-divider.entry.js +1 -1
  252. package/dist/esm/tds-dropdown_2.entry.js +186 -199
  253. package/dist/esm/tds-folder-tab.entry.js +2 -2
  254. package/dist/esm/tds-folder-tabs.entry.js +2 -2
  255. package/dist/esm/tds-footer-group.entry.js +3 -3
  256. package/dist/esm/tds-footer-item.entry.js +1 -1
  257. package/dist/esm/tds-footer.entry.js +2 -2
  258. package/dist/esm/tds-header-brand-symbol.entry.js +1 -1
  259. package/dist/esm/tds-header-cell.entry.js +1 -1
  260. package/dist/esm/tds-header-dropdown-list-item.entry.js +2 -2
  261. package/dist/esm/tds-header-dropdown-list-user.entry.js +1 -1
  262. package/dist/esm/tds-header-dropdown-list.entry.js +1 -1
  263. package/dist/esm/tds-header-dropdown.entry.js +3 -3
  264. package/dist/esm/tds-header-hamburger.entry.js +1 -1
  265. package/dist/esm/tds-header-launcher-button.entry.js +1 -1
  266. package/dist/esm/tds-header-launcher-grid-item.entry.js +1 -1
  267. package/dist/esm/tds-header-launcher-grid-title.entry.js +1 -1
  268. package/dist/esm/tds-header-launcher-grid.entry.js +1 -1
  269. package/dist/esm/tds-header-launcher-list-item.entry.js +1 -1
  270. package/dist/esm/tds-header-launcher-list-title.entry.js +1 -1
  271. package/dist/esm/tds-header-launcher-list.entry.js +1 -1
  272. package/dist/esm/tds-header-launcher.entry.js +2 -2
  273. package/dist/esm/tds-header-title.entry.js +1 -1
  274. package/dist/esm/tds-header.entry.js +1 -1
  275. package/dist/esm/tds-icon.entry.js +1 -1
  276. package/dist/esm/tds-inline-tab.entry.js +2 -2
  277. package/dist/esm/tds-inline-tabs.entry.js +2 -2
  278. package/dist/esm/tds-link.entry.js +2 -2
  279. package/dist/esm/tds-message.entry.js +2 -2
  280. package/dist/esm/tds-modal.entry.js +2 -2
  281. package/dist/esm/tds-navigation-tab.entry.js +2 -2
  282. package/dist/esm/tds-navigation-tabs.entry.js +4 -4
  283. package/dist/esm/tds-popover-canvas.entry.js +2 -2
  284. package/dist/esm/tds-popover-core.entry.js +1 -1
  285. package/dist/esm/tds-popover-menu-item.entry.js +2 -2
  286. package/dist/esm/tds-popover-menu.entry.js +2 -2
  287. package/dist/esm/tds-radio-button.entry.js +1 -1
  288. package/dist/esm/tds-side-menu-close-button.entry.js +1 -1
  289. package/dist/esm/tds-side-menu-collapse-button.entry.js +4 -4
  290. package/dist/esm/tds-side-menu-dropdown-list-item.entry.js +2 -2
  291. package/dist/esm/tds-side-menu-dropdown-list.entry.js +2 -2
  292. package/dist/esm/tds-side-menu-dropdown.entry.js +3 -3
  293. package/dist/esm/tds-side-menu-item.entry.js +2 -2
  294. package/dist/esm/tds-side-menu-overlay.entry.js +1 -1
  295. package/dist/esm/tds-side-menu-user-image_2.entry.js +2 -2
  296. package/dist/esm/tds-side-menu-user.entry.js +1 -1
  297. package/dist/esm/tds-slider.entry.js +7 -7
  298. package/dist/esm/tds-spinner.entry.js +1 -1
  299. package/dist/esm/tds-step.entry.js +1 -1
  300. package/dist/esm/tds-table-body-input-wrapper.entry.js +1 -1
  301. package/dist/esm/tds-table-body-row-expandable.entry.js +7 -7
  302. package/dist/esm/tds-table-body-row.entry.js +2 -2
  303. package/dist/esm/tds-table-body.entry.js +2 -2
  304. package/dist/esm/tds-table-footer.entry.js +3 -3
  305. package/dist/esm/tds-table-header-input-wrapper.entry.js +1 -1
  306. package/dist/esm/tds-table-header.entry.js +2 -2
  307. package/dist/esm/tds-table-toolbar.entry.js +2 -2
  308. package/dist/esm/tds-text-field.entry.js +6 -6
  309. package/dist/esm/tds-textarea.entry.js +3 -3
  310. package/dist/esm/tds-toast.entry.js +3 -3
  311. package/dist/esm/tds-toggle.entry.js +11 -2
  312. package/dist/esm/tds-tooltip.entry.js +2 -2
  313. package/dist/esm/tegel.js +1 -1
  314. package/dist/tegel/{p-d027f6b9.entry.js → p-01edebef.entry.js} +1 -1
  315. package/dist/tegel/{p-3e144a83.entry.js → p-035e58e6.entry.js} +1 -1
  316. package/dist/tegel/{p-170ab61b.entry.js → p-065d6f83.entry.js} +1 -1
  317. package/dist/tegel/{p-72106a5c.entry.js → p-168122a7.entry.js} +1 -1
  318. package/dist/tegel/{p-6eeded00.entry.js → p-19eb4ae1.entry.js} +1 -1
  319. package/dist/tegel/{p-b0a5eba7.entry.js → p-1b390acb.entry.js} +1 -1
  320. package/dist/tegel/{p-059a9499.entry.js → p-288a09ef.entry.js} +1 -1
  321. package/dist/tegel/{p-b2018a5b.entry.js → p-3204ae8f.entry.js} +1 -1
  322. package/dist/tegel/p-32be63ea.entry.js +1 -0
  323. package/dist/tegel/{p-cc2730d8.entry.js → p-34b793c9.entry.js} +1 -1
  324. package/dist/tegel/p-3c2f7033.entry.js +1 -0
  325. package/dist/tegel/p-46205cfb.entry.js +1 -0
  326. package/dist/tegel/p-4d5963d0.entry.js +1 -0
  327. package/dist/tegel/{p-68859ddc.entry.js → p-4e298888.entry.js} +1 -1
  328. package/dist/tegel/{p-9c3f2c12.entry.js → p-4e33cbda.entry.js} +1 -1
  329. package/dist/tegel/{p-b425b2f4.entry.js → p-4ee344e5.entry.js} +1 -1
  330. package/dist/tegel/p-4f5f152a.entry.js +1 -0
  331. package/dist/tegel/p-4fe6512b.entry.js +1 -0
  332. package/dist/tegel/{p-038c22ff.entry.js → p-542d7b3e.entry.js} +1 -1
  333. package/dist/tegel/{p-5eaa23dc.entry.js → p-5a7110b8.entry.js} +1 -1
  334. package/dist/tegel/{p-93930c03.entry.js → p-5ba254ee.entry.js} +1 -1
  335. package/dist/tegel/{p-06968bd7.entry.js → p-60b38806.entry.js} +1 -1
  336. package/dist/tegel/p-64c80f14.entry.js +1 -0
  337. package/dist/tegel/{p-7929d22f.entry.js → p-654785d2.entry.js} +1 -1
  338. package/dist/tegel/p-6f17d37f.entry.js +1 -0
  339. package/dist/tegel/p-70795d6e.entry.js +1 -0
  340. package/dist/tegel/{p-4a282c25.entry.js → p-72fd0083.entry.js} +1 -1
  341. package/dist/tegel/{p-3d3ee51f.entry.js → p-74fc9c92.entry.js} +1 -1
  342. package/dist/tegel/p-77c79b91.entry.js +1 -0
  343. package/dist/tegel/{p-54154f09.entry.js → p-77d457b8.entry.js} +1 -1
  344. package/dist/tegel/{p-4b7c53a6.entry.js → p-78d5acd7.entry.js} +1 -1
  345. package/dist/tegel/{p-44c33b20.entry.js → p-7c4c65c9.entry.js} +1 -1
  346. package/dist/tegel/{p-3a32fe40.entry.js → p-848c2732.entry.js} +1 -1
  347. package/dist/tegel/p-868757d9.entry.js +1 -0
  348. package/dist/tegel/p-8c8b9908.entry.js +1 -0
  349. package/dist/tegel/{p-59293f88.entry.js → p-93a4bd11.entry.js} +1 -1
  350. package/dist/tegel/{p-2f32991e.entry.js → p-96635c10.entry.js} +1 -1
  351. package/dist/tegel/p-9e0b31a1.entry.js +1 -0
  352. package/dist/tegel/{p-c289dfb9.entry.js → p-a0fc0cc2.entry.js} +1 -1
  353. package/dist/tegel/{p-96bdf035.entry.js → p-aa9d281b.entry.js} +1 -1
  354. package/dist/tegel/p-ae46766a.entry.js +1 -0
  355. package/dist/tegel/{p-86b30f71.entry.js → p-aef6b130.entry.js} +1 -1
  356. package/dist/tegel/p-b08886e3.entry.js +1 -0
  357. package/dist/tegel/{p-f67b4047.entry.js → p-b35e7208.entry.js} +1 -1
  358. package/dist/tegel/{p-a86fe122.entry.js → p-b39ffad4.entry.js} +1 -1
  359. package/dist/tegel/p-b5ced8e5.entry.js +1 -0
  360. package/dist/tegel/{p-fd3d56aa.entry.js → p-b6526302.entry.js} +1 -1
  361. package/dist/tegel/{p-e7300cca.entry.js → p-b686f1ad.entry.js} +1 -1
  362. package/dist/tegel/{p-b96cd80d.entry.js → p-b9576881.entry.js} +1 -1
  363. package/dist/tegel/p-b9f81e53.entry.js +1 -0
  364. package/dist/tegel/{p-708a8bab.entry.js → p-bee533b5.entry.js} +1 -1
  365. package/dist/tegel/{p-99da056d.entry.js → p-c56be8d1.entry.js} +1 -1
  366. package/dist/tegel/{p-2a38b053.entry.js → p-c8404432.entry.js} +1 -1
  367. package/dist/tegel/{p-24ff5903.entry.js → p-ca93de01.entry.js} +1 -1
  368. package/dist/tegel/p-cc6c06e3.entry.js +1 -0
  369. package/dist/tegel/{p-b19ce79c.entry.js → p-cca85da0.entry.js} +1 -1
  370. package/dist/tegel/{p-ab0528bf.entry.js → p-cde32bc6.entry.js} +1 -1
  371. package/dist/tegel/p-d0abf078.entry.js +1 -0
  372. package/dist/tegel/{p-6d022f47.entry.js → p-d267665e.entry.js} +1 -1
  373. package/dist/tegel/{p-e9ac7a1a.entry.js → p-d33cb2d1.entry.js} +1 -1
  374. package/dist/tegel/{p-5fea857b.entry.js → p-d47c744f.entry.js} +1 -1
  375. package/dist/tegel/p-d65dfe04.entry.js +1 -0
  376. package/dist/tegel/{p-2a96bd05.entry.js → p-d853f8c2.entry.js} +1 -1
  377. package/dist/tegel/p-d9511720.entry.js +1 -0
  378. package/dist/tegel/{p-0b773208.entry.js → p-dcbc35af.entry.js} +1 -1
  379. package/dist/tegel/{p-fd432c54.entry.js → p-dfbbaefd.entry.js} +1 -1
  380. package/dist/tegel/{p-88204e0a.entry.js → p-ea3e071f.entry.js} +1 -1
  381. package/dist/tegel/{p-2795009a.entry.js → p-ed17283a.entry.js} +1 -1
  382. package/dist/tegel/{p-e478953c.entry.js → p-ee7f07ae.entry.js} +1 -1
  383. package/dist/tegel/{p-b9b63210.entry.js → p-f1b0211a.entry.js} +1 -1
  384. package/dist/tegel/{p-a392e6e7.entry.js → p-fa07db58.entry.js} +1 -1
  385. package/dist/tegel/tegel.esm.js +1 -1
  386. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +3 -0
  387. package/dist/types/components/button/button.d.ts +3 -0
  388. package/dist/types/components/checkbox/checkbox.d.ts +0 -3
  389. package/dist/types/components/chip/chip.d.ts +3 -0
  390. package/dist/types/components/datetime/datetime.d.ts +2 -2
  391. package/dist/types/components/dropdown/dropdown.d.ts +24 -23
  392. package/dist/types/components/header/header-item/header-item.d.ts +7 -0
  393. package/dist/types/components/toggle/toggle.d.ts +5 -0
  394. package/dist/types/components.d.ts +48 -25
  395. package/package.json +1 -1
  396. package/dist/tegel/p-0939b9fb.entry.js +0 -1
  397. package/dist/tegel/p-1703f73a.entry.js +0 -1
  398. package/dist/tegel/p-1aecae56.entry.js +0 -1
  399. package/dist/tegel/p-32b7f431.entry.js +0 -1
  400. package/dist/tegel/p-3c22aef7.entry.js +0 -1
  401. package/dist/tegel/p-3e1b1399.entry.js +0 -1
  402. package/dist/tegel/p-48bbc11f.entry.js +0 -1
  403. package/dist/tegel/p-4b231bf9.entry.js +0 -1
  404. package/dist/tegel/p-4c2f313d.entry.js +0 -1
  405. package/dist/tegel/p-5e0fc86c.entry.js +0 -1
  406. package/dist/tegel/p-7090a95c.entry.js +0 -1
  407. package/dist/tegel/p-85a9032e.entry.js +0 -1
  408. package/dist/tegel/p-92f81cda.entry.js +0 -1
  409. package/dist/tegel/p-a38dda58.entry.js +0 -1
  410. package/dist/tegel/p-b647d20e.entry.js +0 -1
  411. package/dist/tegel/p-be88c5ab.entry.js +0 -1
  412. package/dist/tegel/p-d7f48112.entry.js +0 -1
  413. package/dist/tegel/p-e328e039.entry.js +0 -1
  414. package/dist/tegel/p-ea4a9a4f.entry.js +0 -1
  415. package/dist/tegel/p-f4db0231.entry.js +0 -1
  416. package/dist/tegel/p-ffd827ef.entry.js +0 -1
@@ -89,33 +89,13 @@ const TdsDropdown = class {
89
89
  this.tdsInput = index.createEvent(this, "tdsInput", 6);
90
90
  this.setDefaultOption = () => {
91
91
  if (this.internalDefaultValue) {
92
- const children = Array.from(this.host.children).filter((element) => element.tagName === 'TDS-DROPDOWN-OPTION');
93
- if (children.length === 0) {
94
- console.warn('TDS DROPDOWN: No options found. Disregard if loading data asynchronously.');
95
- return;
96
- }
92
+ // Convert the internal default value to an array if it's not already
97
93
  const defaultValues = this.multiselect
98
- ? new Set(this.internalDefaultValue.split(','))
94
+ ? this.internalDefaultValue.split(',')
99
95
  : [this.internalDefaultValue];
100
- const childrenMap = new Map(children.map((element) => [element.value, element]));
101
- const matchedValues = Array.from(defaultValues).filter((value) => {
102
- const element = childrenMap.get(value);
103
- if (element) {
104
- element.setSelected(true);
105
- return true;
106
- }
107
- return false;
108
- });
109
- if (matchedValues.length > 0) {
110
- this.value = [...new Set(this.value ? [...this.value, ...matchedValues] : matchedValues)];
111
- this.setValueAttribute();
112
- }
113
- else {
114
- console.warn(`TDS DROPDOWN: No matching option found for defaultValue "${this.internalDefaultValue}"`);
115
- }
96
+ this.updateDropdownState(defaultValues);
116
97
  }
117
98
  };
118
- /* Returns a list of all children that are tds-dropdown-option elements */
119
99
  this.getChildren = () => {
120
100
  const tdsDropdownOptions = Array.from(this.host.children).filter((element) => element.tagName === 'TDS-DROPDOWN-OPTION');
121
101
  if (tdsDropdownOptions.length === 0) {
@@ -124,6 +104,36 @@ const TdsDropdown = class {
124
104
  else
125
105
  return tdsDropdownOptions;
126
106
  };
107
+ this.getSelectedChildren = () => {
108
+ if (this.selectedOptions.length === 0)
109
+ return [];
110
+ return this.selectedOptions
111
+ .map((stringValue) => {
112
+ var _a;
113
+ const matchingElement = (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.find((element) => element.value === stringValue);
114
+ return matchingElement;
115
+ })
116
+ .filter(Boolean);
117
+ };
118
+ this.getSelectedChildrenLabels = () => {
119
+ var _a;
120
+ return (_a = this.getSelectedChildren()) === null || _a === void 0 ? void 0 : _a.map((element) => element.textContent.trim());
121
+ };
122
+ this.getValue = () => {
123
+ const labels = this.getSelectedChildrenLabels();
124
+ if (!labels) {
125
+ return '';
126
+ }
127
+ return labels === null || labels === void 0 ? void 0 : labels.join(', ');
128
+ };
129
+ this.setValueAttribute = () => {
130
+ if (this.selectedOptions.length === 0) {
131
+ this.host.removeAttribute('value');
132
+ }
133
+ else {
134
+ this.host.setAttribute('value', this.selectedOptions.join(','));
135
+ }
136
+ };
127
137
  this.getOpenDirection = () => {
128
138
  var _a, _b, _c, _d, _e;
129
139
  if (this.openDirection === 'auto' || !this.openDirection) {
@@ -137,7 +147,6 @@ const TdsDropdown = class {
137
147
  }
138
148
  return this.openDirection;
139
149
  };
140
- /* Toggles the open state of the Dropdown and sets focus to the input element */
141
150
  this.handleToggleOpen = () => {
142
151
  if (!this.disabled) {
143
152
  this.open = !this.open;
@@ -146,38 +155,10 @@ const TdsDropdown = class {
146
155
  }
147
156
  }
148
157
  };
149
- /* Focuses the input element in the Dropdown, if the reference is present. */
150
158
  this.focusInputElement = () => {
151
159
  if (this.inputElement)
152
160
  this.inputElement.focus();
153
161
  };
154
- this.getSelectedChildren = () => {
155
- var _a;
156
- return (_a = this.value) === null || _a === void 0 ? void 0 : _a.map((stringValue) => {
157
- const matchingElement = this.getChildren().find((element) => element.value === stringValue);
158
- return matchingElement;
159
- }).filter(Boolean);
160
- };
161
- this.getSelectedChildrenLabels = () => {
162
- var _a;
163
- return (_a = this.getSelectedChildren()) === null || _a === void 0 ? void 0 : _a.map((element) => element.textContent.trim());
164
- };
165
- this.getValue = () => {
166
- const labels = this.getSelectedChildrenLabels();
167
- if (!labels) {
168
- return '';
169
- }
170
- return labels === null || labels === void 0 ? void 0 : labels.join(', ');
171
- };
172
- this.setValueAttribute = () => {
173
- var _a;
174
- if (!this.value || ((_a = this.value) === null || _a === void 0 ? void 0 : _a.toString()) === '') {
175
- this.host.removeAttribute('value');
176
- }
177
- else {
178
- this.host.setAttribute('value', convertArrayToStrings(this.value).join(','));
179
- }
180
- };
181
162
  this.handleFilter = (event) => {
182
163
  this.tdsInput.emit(event);
183
164
  const query = event.target.value.toLowerCase();
@@ -208,8 +189,10 @@ const TdsDropdown = class {
208
189
  this.handleFilterReset = () => {
209
190
  this.reset();
210
191
  this.inputElement.value = '';
211
- this.handleFilter({ target: { value: this.inputElement.value } });
192
+ this.handleFilter({ target: { value: '' } });
212
193
  this.inputElement.focus();
194
+ // Add this line to ensure internal value is cleared
195
+ this.internalValue = '';
213
196
  };
214
197
  this.handleFocus = (event) => {
215
198
  this.open = true;
@@ -223,12 +206,6 @@ const TdsDropdown = class {
223
206
  this.handleBlur = (event) => {
224
207
  this.tdsBlur.emit(event);
225
208
  };
226
- this.handleChange = () => {
227
- this.tdsChange.emit({
228
- name: this.name,
229
- value: this.value ? convertArrayToStrings(this.value).join(',') : null,
230
- });
231
- };
232
209
  this.resetInput = () => {
233
210
  const inputEl = this.host.querySelector('input');
234
211
  if (inputEl) {
@@ -251,17 +228,111 @@ const TdsDropdown = class {
251
228
  this.normalizeText = true;
252
229
  this.noResultText = 'No result';
253
230
  this.defaultValue = undefined;
231
+ this.value = null;
254
232
  this.open = false;
255
- this.value = undefined;
233
+ this.internalValue = undefined;
256
234
  this.filterResult = undefined;
257
235
  this.filterFocus = undefined;
258
236
  this.internalDefaultValue = undefined;
237
+ this.selectedOptions = [];
238
+ }
239
+ handleValueChange(newValue) {
240
+ // Normalize to array
241
+ const normalizedValue = this.normalizeValue(newValue);
242
+ // Only update if actually changed
243
+ if (this.hasValueChanged(normalizedValue, this.selectedOptions)) {
244
+ this.updateDropdownState(normalizedValue);
245
+ }
246
+ }
247
+ normalizeValue(value) {
248
+ if (!value || value === '')
249
+ return []; // Handle both null and empty string
250
+ // For multiselect, keep array. For single select, wrap in array
251
+ if (this.multiselect) {
252
+ if (Array.isArray(value)) {
253
+ return convertArrayToStrings(value);
254
+ }
255
+ return value
256
+ .toString()
257
+ .split(',')
258
+ .filter((v) => v !== '');
259
+ }
260
+ // Single select - convert to string array
261
+ return Array.isArray(value) ? convertArrayToStrings(value) : [convertToString(value)];
262
+ }
263
+ hasValueChanged(newValue, currentValue) {
264
+ if (newValue.length !== currentValue.length)
265
+ return true;
266
+ return newValue.some((val) => !currentValue.includes(val));
267
+ }
268
+ updateDropdownState(values) {
269
+ // Update internal state
270
+ this.selectedOptions = [...this.validateValues(values)]; // Force new array reference
271
+ // Then update the value prop to match
272
+ this.value = this.multiselect ? this.selectedOptions : this.selectedOptions[0] || null;
273
+ // Force update of internal value
274
+ this.internalValue = this.getValue();
275
+ // Update DOM
276
+ this.updateOptionElements();
277
+ // Update display value
278
+ this.updateDisplayValue();
279
+ // Emit change event
280
+ this.emitChange();
281
+ // Update value attribute
282
+ this.setValueAttribute();
283
+ }
284
+ validateValues(values) {
285
+ return values.filter((val) => {
286
+ var _a;
287
+ const isValid = (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.some((element) => element.value === val);
288
+ if (!isValid) {
289
+ console.warn(`Option with value "${val}" does not exist`);
290
+ }
291
+ return isValid;
292
+ });
293
+ }
294
+ updateOptionElements() {
295
+ var _a;
296
+ (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
297
+ // Convert element.value to string for comparison
298
+ element.setSelected(this.selectedOptions.includes(convertToString(element.value)));
299
+ });
300
+ }
301
+ updateDisplayValue() {
302
+ this.internalValue = this.getSelectedChildrenLabels().join(', ');
303
+ if (this.filter && this.inputElement) {
304
+ this.inputElement.value = this.internalValue;
305
+ }
306
+ }
307
+ emitChange() {
308
+ const value = this.multiselect
309
+ ? this.selectedOptions.join(',')
310
+ : this.selectedOptions[0] || null;
311
+ this.tdsChange.emit({
312
+ name: this.name,
313
+ value: value !== null && value !== void 0 ? value : null,
314
+ });
315
+ }
316
+ async setValue(value) {
317
+ let normalizedValue;
318
+ if (Array.isArray(value)) {
319
+ normalizedValue = convertArrayToStrings(value);
320
+ }
321
+ else {
322
+ normalizedValue = [convertToString(value)];
323
+ }
324
+ this.updateDropdownState(normalizedValue);
325
+ return this.getSelectedChildren().map((element) => ({
326
+ value: element.value,
327
+ label: element.textContent.trim(),
328
+ }));
259
329
  }
260
- /** Method that resets the Dropdown, marks all children as non-selected and resets the value to null. */
261
330
  async reset() {
262
- this.dropdownList.scrollTop = 0;
263
- this.internalReset();
264
- this.handleChange();
331
+ this.updateDropdownState([]);
332
+ }
333
+ async removeValue(oldValue) {
334
+ const newValues = this.selectedOptions.filter((v) => v !== oldValue);
335
+ this.updateDropdownState(newValues);
265
336
  }
266
337
  /** Method that forces focus on the input element. */
267
338
  async focusElement() {
@@ -282,81 +353,6 @@ const TdsDropdown = class {
282
353
  * dropdown.setValue(['option-1', 'option-2']);
283
354
  * </code>
284
355
  */
285
- // The label is optional here ONLY to not break the API. Should be removed for 2.0.
286
- // @ts-ignore
287
- // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars
288
- async setValue(value) {
289
- let nextValue;
290
- if (Array.isArray(value)) {
291
- nextValue = convertArrayToStrings(value);
292
- }
293
- else {
294
- nextValue = [convertToString(value)];
295
- }
296
- if (!this.multiselect && nextValue.length > 1) {
297
- console.warn('Tried to select multiple items, but multiselect is not enabled.');
298
- nextValue = [nextValue[0]];
299
- }
300
- nextValue = [...new Set(nextValue)];
301
- this.internalReset();
302
- for (let i = 0; i < nextValue.length; i++) {
303
- const optionExist = this.getChildren().some((element) => element.value === nextValue[i]);
304
- if (!optionExist) {
305
- nextValue.splice(i, 1);
306
- }
307
- }
308
- this.value = nextValue;
309
- this.setValueAttribute();
310
- this.selectChildrenAsSelectedBasedOnSelectionProp();
311
- this.handleChange();
312
- /* This returns an array of object with a value and label pair. This is ONLY to not break the API. Should be removed for 2.0. */
313
- /* https://tegel.atlassian.net/browse/CDEP-2703 */
314
- const selection = this.getSelectedChildren().map((element) => ({
315
- value: element.value,
316
- label: element.textContent.trim(),
317
- }));
318
- // Update inputElement value and placeholder text
319
- if (this.filter) {
320
- this.inputElement.value = this.getValue();
321
- }
322
- return selection;
323
- }
324
- /**
325
- * @internal
326
- */
327
- async appendValue(value) {
328
- if (this.multiselect && this.value) {
329
- this.setValue([...this.value, value]);
330
- }
331
- else {
332
- this.setValue(value);
333
- }
334
- }
335
- /** Method for removing a selected value in the Dropdown. */
336
- async removeValue(oldValue) {
337
- var _a, _b;
338
- let label;
339
- if (this.multiselect) {
340
- (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
341
- var _a;
342
- if (element.value === oldValue) {
343
- this.value = (_a = this.value) === null || _a === void 0 ? void 0 : _a.filter((value) => value !== element.value);
344
- label = element.textContent.trim();
345
- element.setSelected(false);
346
- }
347
- return element;
348
- });
349
- }
350
- else {
351
- this.reset();
352
- }
353
- this.handleChange();
354
- this.setValueAttribute();
355
- /* This returns an array of object with a value and label pair. This is ONLY to not break the API. Should be removed for 2.0. */
356
- /* https://tegel.atlassian.net/browse/CDEP-2703 */
357
- return (_b = this.value) === null || _b === void 0 ? void 0 : _b.map((value) => ({ value, label }));
358
- }
359
- /** Method for closing the Dropdown. */
360
356
  async close() {
361
357
  this.open = false;
362
358
  }
@@ -403,7 +399,7 @@ const TdsDropdown = class {
403
399
  handleOpenState() {
404
400
  if (this.filter && this.multiselect) {
405
401
  if (!this.open) {
406
- this.inputElement.value = this.getValue();
402
+ this.inputElement.value = this.selectedOptions.length ? this.getValue() : '';
407
403
  }
408
404
  }
409
405
  }
@@ -414,10 +410,14 @@ const TdsDropdown = class {
414
410
  }
415
411
  }
416
412
  componentWillLoad() {
417
- if (this.defaultValue !== undefined && this.defaultValue !== null) {
418
- this.internalDefaultValue = convertToString(this.defaultValue);
413
+ if (this.defaultValue && !this.value) {
414
+ // Convert defaultValue to string before splitting
415
+ const defaultValueStr = convertToString(this.defaultValue);
416
+ const initialValue = this.multiselect
417
+ ? defaultValueStr.split(',').map(convertToString)
418
+ : [convertToString(this.defaultValue)];
419
+ this.updateDropdownState(initialValue);
419
420
  }
420
- this.setDefaultOption();
421
421
  }
422
422
  /** Method to handle slot changes */
423
423
  handleSlotChange() {
@@ -427,29 +427,16 @@ const TdsDropdown = class {
427
427
  normalizeString(text) {
428
428
  return this.normalizeText ? text.normalize('NFD').replace(/\p{Diacritic}/gu, '') : text;
429
429
  }
430
- /** Method that resets the dropdown without emitting an event. */
431
- internalReset() {
432
- this.getChildren().forEach((element) => {
433
- element.setSelected(false);
434
- return element;
435
- });
436
- this.value = null;
437
- this.setValueAttribute();
438
- }
439
- selectChildrenAsSelectedBasedOnSelectionProp() {
440
- this.getChildren().forEach((element) => {
441
- this.value.forEach((selection) => {
442
- if (element.value !== selection) {
443
- // If not multiselect, we need to unselect all other options.
444
- if (!this.multiselect) {
445
- element.setSelected(false);
446
- }
447
- }
448
- else {
449
- element.setSelected(true);
450
- }
451
- });
452
- });
430
+ /**
431
+ * @internal
432
+ */
433
+ async appendValue(value) {
434
+ if (this.multiselect) {
435
+ this.updateDropdownState([...this.selectedOptions, value]);
436
+ }
437
+ else {
438
+ this.updateDropdownState([value]);
439
+ }
453
440
  }
454
441
  componentDidRender() {
455
442
  const form = this.host.closest('form');
@@ -464,11 +451,10 @@ const TdsDropdown = class {
464
451
  }
465
452
  }
466
453
  render() {
467
- var _a, _b, _c;
468
- appendHiddenInput(this.host, this.name, this.value ? convertArrayToStrings(this.value).join(',') : null, this.disabled);
469
- return (index.h(index.Host, { key: '0bb6532a6a87ba128f556022792fe5afb3e3e482', role: "select", class: {
454
+ appendHiddenInput(this.host, this.name, this.selectedOptions.join(','), this.disabled);
455
+ return (index.h(index.Host, { key: '490d34545b3a09c3b4342fa09d38f6bf9c782498', role: "select", class: {
470
456
  [`tds-mode-variant-${this.modeVariant}`]: Boolean(this.modeVariant),
471
- } }, this.label && this.labelPosition === 'outside' && (index.h("div", { key: 'c65377474abaae962436d53b42e19eeda2bcdda6', class: `label-outside ${this.disabled ? 'disabled' : ''}` }, this.label)), index.h("div", { key: '80d21a17eef6a3d8ff7f73e5a52a744ae4aa08b6', class: {
457
+ } }, this.label && this.labelPosition === 'outside' && (index.h("div", { key: '7eb96c0134032654df98a3b68ffb692a2cd91d2b', class: `label-outside ${this.disabled ? 'disabled' : ''}` }, this.label)), index.h("div", { key: '439fddb188ad65239e9d5451a82ab3bbe8f47fb7', class: {
472
458
  'dropdown-select': true,
473
459
  [this.size]: true,
474
460
  'disabled': this.disabled,
@@ -480,7 +466,7 @@ const TdsDropdown = class {
480
466
  } }, index.h("div", { class: "value-wrapper" }, this.label && this.labelPosition === 'inside' && this.placeholder && (index.h("div", { class: `label-inside ${this.size}` }, this.label)), this.label && this.labelPosition === 'inside' && !this.placeholder && (index.h("div", { class: `
481
467
  label-inside-as-placeholder
482
468
  ${this.size}
483
- ${((_a = this.value) === null || _a === void 0 ? void 0 : _a.length) ? 'selected' : ''}
469
+ ${this.selectedOptions.length ? 'selected' : ''}
484
470
  ` }, this.label)), index.h("input", {
485
471
  // eslint-disable-next-line no-return-assign
486
472
  ref: (inputEl) => (this.inputElement = inputEl), class: {
@@ -491,15 +477,7 @@ const TdsDropdown = class {
491
477
  this.inputElement.value = this.getValue();
492
478
  }
493
479
  this.handleBlur(event);
494
- }, onFocus: (event) => {
495
- this.open = true;
496
- this.filterFocus = true;
497
- if (this.multiselect) {
498
- this.inputElement.value = '';
499
- }
500
- this.handleFocus(event);
501
- this.handleFilter({ target: { value: '' } });
502
- }, onKeyDown: (event) => {
480
+ }, onFocus: (event) => this.handleFocus(event), onKeyDown: (event) => {
503
481
  if (event.key === 'Escape') {
504
482
  this.open = false;
505
483
  }
@@ -519,17 +497,15 @@ const TdsDropdown = class {
519
497
  if (event.key === 'Escape') {
520
498
  this.open = false;
521
499
  }
522
- }, class: {
523
- value: Boolean(this.value),
524
- placeholder: Boolean(!this.value),
525
- open: this.open,
526
- closed: !this.open,
527
- error: this.error,
528
- }, disabled: this.disabled }, index.h("div", { class: `value-wrapper ${this.size}` }, this.label && this.labelPosition === 'inside' && this.placeholder && (index.h("div", { class: `label-inside ${this.size}` }, this.label)), this.label && this.labelPosition === 'inside' && !this.placeholder && (index.h("div", { class: {
529
- 'label-inside-as-placeholder': true,
530
- [this.size]: true,
531
- 'selected': Boolean((_b = this.value) === null || _b === void 0 ? void 0 : _b.length),
532
- } }, this.label)), index.h("div", { class: `placeholder ${this.size}` }, ((_c = this.value) === null || _c === void 0 ? void 0 : _c.length) ? this.getValue() : this.placeholder), index.h("tds-icon", { "aria-label": "Open/Close dropdown", svgTitle: "Open/Close dropdown", class: `menu-icon ${this.open ? 'open' : 'closed'}`, name: "chevron_down", size: "16px" }))))), index.h("div", { key: '1f1c87b17a78c2a65add834208f487c6e9a4f77e', ref: (element) => {
500
+ }, class: `
501
+ ${this.selectedOptions.length ? 'value' : 'placeholder'}
502
+ ${this.open ? 'open' : 'closed'}
503
+ ${this.error ? 'error' : ''}
504
+ `, disabled: this.disabled }, index.h("div", { class: `value-wrapper ${this.size}` }, this.label && this.labelPosition === 'inside' && this.placeholder && (index.h("div", { class: `label-inside ${this.size}` }, this.label)), this.label && this.labelPosition === 'inside' && !this.placeholder && (index.h("div", { class: `
505
+ label-inside-as-placeholder
506
+ ${this.size}
507
+ ${this.selectedOptions.length ? 'selected' : ''}
508
+ ` }, this.label)), index.h("div", { class: `placeholder ${this.size}` }, this.selectedOptions.length ? this.getValue() : this.placeholder), index.h("tds-icon", { "aria-label": "Open/Close dropdown", svgTitle: "Open/Close dropdown", class: `menu-icon ${this.open ? 'open' : 'closed'}`, name: "chevron_down", size: "16px" }))))), index.h("div", { key: 'd6381f78466994f05415cf8981b3cedaaf4df6a9', ref: (element) => {
533
509
  this.dropdownList = element;
534
510
  }, class: {
535
511
  'dropdown-list': true,
@@ -540,14 +516,15 @@ const TdsDropdown = class {
540
516
  'closed': !this.open,
541
517
  [`animation-enter-${this.animation}`]: this.animation !== 'none' && this.open,
542
518
  [`animation-exit-${this.animation}`]: this.animation !== 'none' && !this.open,
543
- } }, index.h("slot", { key: '6eb6b21f865702aa56af12b9e54bdb2c6c7c8cc2', onSlotchange: () => this.handleSlotChange() }), this.filterResult === 0 && this.noResultText !== '' && (index.h("div", { key: '58c15bd69f38c001e0d6c74466ddfe97d6d77a79', class: `no-result ${this.size}` }, this.noResultText))), this.helper && (index.h("div", { key: 'cc7e1a7f988e6bc61f3bacb7dd9a564b6c1f738d', class: {
519
+ } }, index.h("slot", { key: 'c36a9cb5398a7d290f11576431982e869986e4a0', onSlotchange: () => this.handleSlotChange() }), this.filterResult === 0 && this.noResultText !== '' && (index.h("div", { key: '5ec07552d105f8a4addc46da0172f67cf9233817', class: `no-result ${this.size}` }, this.noResultText))), this.helper && (index.h("div", { key: 'b3e240c31060f2d2bce6e3647f903f9ff1250ed5', class: {
544
520
  helper: true,
545
521
  error: this.error,
546
522
  disabled: this.disabled,
547
- } }, this.error && index.h("tds-icon", { key: 'ffd574d493f3bbaa37ddc7b14a8372ba4b23bd70', name: "error", size: "16px" }), this.helper))));
523
+ } }, this.error && index.h("tds-icon", { key: 'c0eb10dfeaa5236f5ac02dabf44329e85d52dcda', name: "error", size: "16px" }), this.helper))));
548
524
  }
549
525
  get host() { return index.getElement(this); }
550
526
  static get watchers() { return {
527
+ "value": ["handleValueChange"],
551
528
  "open": ["handleOpenState"],
552
529
  "defaultValue": ["handleDefaultValueChange"]
553
530
  }; }
@@ -563,14 +540,24 @@ const TdsDropdownOption = class {
563
540
  this.tdsSelect = index.createEvent(this, "tdsSelect", 6);
564
541
  this.tdsFocus = index.createEvent(this, "tdsFocus", 6);
565
542
  this.tdsBlur = index.createEvent(this, "tdsBlur", 6);
543
+ this.parentElement = null;
544
+ // @ts-ignore
545
+ // eslint-disable-next-line no-unused-vars,
546
+ this.label = '';
566
547
  this.componentWillRender = () => {
548
+ var _a, _b, _c;
549
+ if (!this.host.parentElement) {
550
+ return;
551
+ }
567
552
  this.parentElement =
568
- this.host.parentElement.tagName === 'TDS-DROPDOWN'
553
+ ((_a = this.host.parentElement) === null || _a === void 0 ? void 0 : _a.tagName) === 'TDS-DROPDOWN'
569
554
  ? this.host.parentElement
570
555
  : this.host.getRootNode().host;
571
- this.multiselect = this.parentElement.multiselect;
572
- this.size = this.parentElement.size;
573
- this.label = this.host.textContent.trim();
556
+ if (this.parentElement) {
557
+ this.multiselect = (_b = this.parentElement.multiselect) !== null && _b !== void 0 ? _b : false;
558
+ this.size = this.parentElement.size || 'lg';
559
+ }
560
+ this.label = ((_c = this.host.textContent) === null || _c === void 0 ? void 0 : _c.trim()) || '';
574
561
  };
575
562
  this.handleSingleSelect = () => {
576
563
  if (!this.disabled) {
@@ -614,7 +601,7 @@ const TdsDropdownOption = class {
614
601
  this.internalValue = undefined;
615
602
  this.disabled = false;
616
603
  this.selected = false;
617
- this.multiselect = undefined;
604
+ this.multiselect = false;
618
605
  this.size = 'lg';
619
606
  }
620
607
  /** Method to select/deselect an option. */
@@ -628,7 +615,7 @@ const TdsDropdownOption = class {
628
615
  this.internalValue = convertToString(this.value);
629
616
  }
630
617
  render() {
631
- return (index.h(index.Host, { key: '5d13306d202a3c488fdd75daa3aa8cfc15e4b9cf', role: "option", "aria-disabled": this.disabled, "aria-selected": this.selected }, index.h("div", { key: 'df8b33467c49913853b2d86dff7115b6cea37f55', class: `dropdown-option
618
+ return (index.h(index.Host, { key: 'af1229553e89c02aca1d7c11bbc80acd25ce44b5', role: "option", "aria-disabled": this.disabled, "aria-selected": this.selected }, index.h("div", { key: 'c93eb33d1864028690ab981c0f676f03993265c4', class: `dropdown-option
632
619
  ${this.size}
633
620
  ${this.selected ? 'selected' : ''}
634
621
  ${this.disabled ? 'disabled' : ''}
@@ -23,10 +23,10 @@ const TdsFolderTab = class {
23
23
  this.selected = selected;
24
24
  }
25
25
  render() {
26
- return (index.h(index.Host, { key: '3ebe8719ec0bae1d4de2f698b032d9914f01fc65', role: "listitem" }, index.h("div", { key: '26e4df6a7c2c3ec3cc9b391004b0ecc2e08886ce', class: {
26
+ return (index.h(index.Host, { key: '919cd453da1e3649fb5da8783ab8fabc47322d47', role: "listitem" }, index.h("div", { key: 'f00bf3eea1ee0d670d8989e23e27d6c54fbe7c17', class: {
27
27
  selected: this.selected,
28
28
  disabled: this.disabled,
29
- }, style: { width: `${this.tabWidth}px` } }, index.h("slot", { key: '78549272532f6fa272660fde77c61464dbede36c' }))));
29
+ }, style: { width: `${this.tabWidth}px` } }, index.h("slot", { key: '3e3bd62fd02c922fa0592dc0f2dae5a8b49d6c4c' }))));
30
30
  }
31
31
  };
32
32
  TdsFolderTab.style = TdsFolderTabStyle0;
@@ -167,9 +167,9 @@ const TdsFolderTabs = class {
167
167
  this.removeEventListenerFromTabs();
168
168
  }
169
169
  render() {
170
- return (index.h(index.Host, { key: 'ab95c2616920aa0feb451cdc8e05697bfedb12b6', role: "list", class: `${this.modeVariant ? `tds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { key: '5330ac0094013711f2d85befe37e7f02de22d8c9', class: "wrapper", ref: (el) => {
170
+ return (index.h(index.Host, { key: '19b773750f13304194341caf79242c7be95b41be', role: "list", class: `${this.modeVariant ? `tds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { key: '915b525f1d8fc67f3edf82f0841ea89cfd8424bc', class: "wrapper", ref: (el) => {
171
171
  this.navWrapperElement = el;
172
- } }, index.h("button", { key: 'cf1d97ff6db378f1a9d2306dce45ccc24ff00718', class: `scroll-left-button ${this.showLeftScroll ? 'show' : ''}`, disabled: !this.showLeftScroll, onClick: () => this.scrollLeft() }, index.h("tds-icon", { key: 'df3cd8050d37eeb32e957ec22796c551476f003b', name: "chevron_left", size: "20px" })), index.h("slot", { key: '695ba9188c06a56785b1362e7554cf0bdfa0c635', onSlotchange: () => this.handleSlotChange() }), index.h("button", { key: 'c64fa2e8788ef3ae78dd1c32b6755625abd4a115', class: `scroll-right-button ${this.showRightScroll ? 'show' : ''}`, disabled: !this.showRightScroll, onClick: () => this.scrollRight() }, index.h("tds-icon", { key: '3d7f40dcc022b37d1d5419ff4b111bf085011698', name: "chevron_right", size: "20px" })))));
172
+ } }, index.h("button", { key: '806f5ce973b4b9bf842ae4c3fdf42c6160255db4', class: `scroll-left-button ${this.showLeftScroll ? 'show' : ''}`, disabled: !this.showLeftScroll, onClick: () => this.scrollLeft() }, index.h("tds-icon", { key: '4762c8fcfb5f7bb9a67ce2515fc3cab557180ca8', name: "chevron_left", size: "20px" })), index.h("slot", { key: '498f04374cb1ad240df2a6e02830eba9bc6c3c8d', onSlotchange: () => this.handleSlotChange() }), index.h("button", { key: '47f114815e98c22f26b021df2b5f53f4498ba24b', class: `scroll-right-button ${this.showRightScroll ? 'show' : ''}`, disabled: !this.showRightScroll, onClick: () => this.scrollRight() }, index.h("tds-icon", { key: 'b4f3a0e137c84b996bdf7eb7e497e788637ac401', name: "chevron_right", size: "20px" })))));
173
173
  }
174
174
  get host() { return index.getElement(this); }
175
175
  static get watchers() { return {
@@ -25,11 +25,11 @@ const TdsFooterGroup = class {
25
25
  }
26
26
  }
27
27
  render() {
28
- return (index.h(index.Host, { key: 'ae2797031aeb5ca057aa00b43d927dff915a5f12' }, this.titleText && this.topPartGroup && (index.h("div", { key: '9ea90a96330835356332d48efdb0e4d8dd7ea645', class: "footer-top-title" }, this.titleText)), this.titleText && this.topPartGroup && (index.h("button", { key: '91b8365113700710108d6207f32968354c660014', onClick: () => {
28
+ return (index.h(index.Host, { key: '9932f2146509bb7f804c15a3b716308c658893c5' }, this.titleText && this.topPartGroup && (index.h("div", { key: '511c348c160a1d1144464ce562b616f38a5fd524', class: "footer-top-title" }, this.titleText)), this.titleText && this.topPartGroup && (index.h("button", { key: 'c64b3662379de7308d8f64b0e5769296e7f48a02', onClick: () => {
29
29
  this.open = !this.open;
30
- }, class: `footer-top-title-button ${this.open ? 'expanded' : 'closed'}` }, this.titleText, index.h("tds-icon", { key: '4faa5b64abb3c37659efeaf8a4e9a610ccbce607', name: "chevron_down", size: "20px" }))), index.h("div", { key: 'b3e3bda445b7b9c244072c2d188a6fe0fcb2e7e0', role: "list", class: `${this.slotPosition ? this.slotPosition : ''}
30
+ }, class: `footer-top-title-button ${this.open ? 'expanded' : 'closed'}` }, this.titleText, index.h("tds-icon", { key: 'f3d5d5bec3f3f9af67bf28e7164eb3190189039c', name: "chevron_down", size: "20px" }))), index.h("div", { key: '4f5a8b626d572e51f67547d0c3280d946e44203f', role: "list", class: `${this.slotPosition ? this.slotPosition : ''}
31
31
  ${this.topPartGroup ? 'top-part-child' : ''}
32
- ${this.open ? 'expanded' : 'closed'}` }, index.h("slot", { key: '99197656b6b371c43da12f1dcf39ef0a0b41fae9' }))));
32
+ ${this.open ? 'expanded' : 'closed'}` }, index.h("slot", { key: '414c481365b866d921aeb8145fd4358a05d8c90f' }))));
33
33
  }
34
34
  get host() { return index.getElement(this); }
35
35
  };
@@ -16,7 +16,7 @@ const TdsFooterItem = class {
16
16
  this.parentIsTopPart = this.host.closest('tds-footer-group').parentElement.slot === 'top';
17
17
  }
18
18
  render() {
19
- return (index.h("div", { key: 'a25461642c0ec629b7c9201a62c0e5c1373e0f68', role: "listitem", class: `${this.parentIsTopPart ? 'top-part-child' : ''}` }, index.h("slot", { key: '19341c71e073cf8b06a24bef448d2b74486a65b7' })));
19
+ return (index.h("div", { key: '8efe2aba383be6dbbf0c1a95e4a5f247623289bd', role: "listitem", class: `${this.parentIsTopPart ? 'top-part-child' : ''}` }, index.h("slot", { key: 'b1406197ba6239bcdec807ebdb2de181ea6a49b7' })));
20
20
  }
21
21
  get host() { return index.getElement(this); }
22
22
  };
@@ -19,9 +19,9 @@ const TdsFooter = class {
19
19
  const usesStartSlot = hasSlot.hasSlot('start', this.host);
20
20
  const usesEndSlot = hasSlot.hasSlot('end', this.host);
21
21
  const usesCopyrightSlot = hasSlot.hasSlot('copyright', this.host);
22
- return (index.h(index.Host, { key: '9da56bcf06badf33f3096c4cf980e775090d70d4', class: {
22
+ return (index.h(index.Host, { key: '169867665b36b555dc5c70815dd2b2a70672f4c9', class: {
23
23
  [`tds-mode-variant-${this.modeVariant}`]: this.modeVariant !== null,
24
- } }, index.h("footer", { key: '0bcb1d24d91f26eb8f44fb0faff172c3e140aeff' }, usesTopSlot && index.h("slot", { key: '4ab849118b1e4822aab9b2779b38569b413595e5', name: "top" }), index.h("div", { key: 'f84c3c4ac78776da6f127675b24c467dcd7eedca', class: "footer-main" }, (usesStartSlot || usesEndSlot) && (index.h("div", { key: 'a12d5aa87d7b731b16b40d42e78005a7dbd92c07', class: "footer-main-top" }, usesStartSlot && index.h("slot", { key: '590a118da2562908606173cc562fbf4c1deae6d3', name: "start" }), usesEndSlot && index.h("slot", { key: 'bd5a1d47df4a4d3089efa7658c62c1c2aed22550', name: "end" }))), index.h("div", { key: '67254f6335af0686cf12461fe6baf9e4cac20c73', class: "footer-main-bottom" }, index.h("small", { key: '99735b151f41ed0a376b98d4b6401b7098a1712c', class: "copyright" }, usesCopyrightSlot ? index.h("slot", { name: "copyright" }) : this.copyrightText), index.h("div", { key: '59774a132d0af546b2e19ae801fa850ae41bdeeb', class: "brand" }, index.h("p", { key: '304b381e47c96c93cae26abcf0042c6a0128c7e0' }, "Scania")))))));
24
+ } }, index.h("footer", { key: '097adec9cd011d4c78d0b468d3165c374d8692f0' }, usesTopSlot && index.h("slot", { key: '72acf005c6c6baf4799db83f420be796f5b5f639', name: "top" }), index.h("div", { key: '016c70c48377f907c0ce01d0e2c88ddd146c0e2a', class: "footer-main" }, (usesStartSlot || usesEndSlot) && (index.h("div", { key: '192b05a7289a94df418b9c85984ce0e86f204fd4', class: "footer-main-top" }, usesStartSlot && index.h("slot", { key: 'ff4b7b591b3a51b3181ad66b54aa63b97391cb18', name: "start" }), usesEndSlot && index.h("slot", { key: 'cf2a1d5aeba4a10310b2f54c93154cd88a90e217', name: "end" }))), index.h("div", { key: '9b37ea980774d696c06d961b7d705b7d90929638', class: "footer-main-bottom" }, index.h("small", { key: 'cec4e9c9975f9d557a33564d9b998ce80067be79', class: "copyright" }, usesCopyrightSlot ? index.h("slot", { name: "copyright" }) : this.copyrightText), index.h("div", { key: '765d79bb0d846d8d31fd62d9193905b86cc15eea', class: "brand" }, index.h("p", { key: '8e88d331cededa03d42c1579c07f28e8ef89ad88' }, "Scania")))))));
25
25
  }
26
26
  get host() { return index.getElement(this); }
27
27
  };
@@ -12,7 +12,7 @@ const TdsHeaderBrandSymbol = class {
12
12
  index.registerInstance(this, hostRef);
13
13
  }
14
14
  render() {
15
- return (index.h(index.Host, { key: '65232b3c21bfec646f7d3e3cf308135f74674034' }, index.h("tds-header-item", { key: '83517481088ba021f329834aa2d0f987f3edd9f0' }, index.h("slot", { key: 'e2bc371fd7f310347b8da5a0bc30a6dfd3dee979' }))));
15
+ return (index.h(index.Host, { key: 'c2e5f418268bf172b1e039aca188489afbc98aa7' }, index.h("tds-header-item", { key: '375b50758e8616093635a0a1ba194296841e4bbc' }, index.h("slot", { key: '2f641711d2e2c5b0fdf2042a44181a699df7fe95' }))));
16
16
  }
17
17
  get host() { return index.getElement(this); }
18
18
  };
@@ -115,7 +115,7 @@ const TdsTableHeaderCell = class {
115
115
  this.host.closest('tds-table').getElementsByTagName('tds-table-toolbar').length >= 1;
116
116
  }
117
117
  render() {
118
- return (index.h(index.Host, { key: '967a02c87d37c0eb75219c84c09edbb34b0257df', class: {
118
+ return (index.h(index.Host, { key: '5bfbed888fd12522741f991542a308772799ceee', class: {
119
119
  'tds-table__header-cell': true,
120
120
  'tds-table__header-cell--sortable': this.sortable,
121
121
  'tds-table__header-cell--is-sorted': this.sortedByMyKey,
@@ -14,10 +14,10 @@ const TdsHeaderDropdownListItem = class {
14
14
  this.size = 'md';
15
15
  }
16
16
  render() {
17
- return (index.h(index.Host, { key: 'e907df68566401506c20283daeeeabf1ebcaa7c8' }, index.h("div", { key: '5a784414662a0da44aeada1496801146606852df', class: {
17
+ return (index.h(index.Host, { key: 'ca37bc294a28794d8bcd7aea18464665b5e8edad' }, index.h("div", { key: '640cee1fd256dbbc046f8564808ea45ed838d2c5', class: {
18
18
  'component': true,
19
19
  'component-selected': this.selected,
20
- } }, index.h("slot", { key: 'a1027ad30124faea7cadbf48c07d3e5e021426f2' }))));
20
+ } }, index.h("slot", { key: 'e5cf6d2af513224921c836206f16d6c44879369c' }))));
21
21
  }
22
22
  get host() { return index.getElement(this); }
23
23
  };