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