@scania/tegel 1.24.0-value-prop.beta.6 → 1.25.0-config-for-china.beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (445) hide show
  1. package/dist/cjs/loader.cjs.js +1 -1
  2. package/dist/cjs/tds-accordion-item.cjs.entry.js +7 -4
  3. package/dist/cjs/tds-badge.cjs.entry.js +6 -1
  4. package/dist/cjs/tds-banner.cjs.entry.js +6 -3
  5. package/dist/cjs/tds-block.cjs.entry.js +10 -6
  6. package/dist/cjs/tds-body-cell.cjs.entry.js +9 -6
  7. package/dist/cjs/tds-breadcrumb.cjs.entry.js +1 -1
  8. package/dist/cjs/tds-breadcrumbs.cjs.entry.js +1 -1
  9. package/dist/cjs/tds-button.cjs.entry.js +7 -3
  10. package/dist/cjs/tds-card.cjs.entry.js +9 -5
  11. package/dist/cjs/tds-checkbox.cjs.entry.js +2 -2
  12. package/dist/cjs/tds-chip.cjs.entry.js +1 -1
  13. package/dist/cjs/tds-core-header-item_2.cjs.entry.js +3 -3
  14. package/dist/cjs/tds-datetime.cjs.entry.js +2 -2
  15. package/dist/cjs/tds-divider.cjs.entry.js +1 -1
  16. package/dist/cjs/tds-dropdown_2.cjs.entry.js +262 -156
  17. package/dist/cjs/tds-folder-tab.cjs.entry.js +4 -2
  18. package/dist/cjs/tds-folder-tabs.cjs.entry.js +2 -2
  19. package/dist/cjs/tds-footer-group.cjs.entry.js +3 -3
  20. package/dist/cjs/tds-footer-item.cjs.entry.js +1 -1
  21. package/dist/cjs/tds-footer.cjs.entry.js +3 -1
  22. package/dist/cjs/tds-header-brand-symbol.cjs.entry.js +1 -1
  23. package/dist/cjs/tds-header-cell.cjs.entry.js +1 -1
  24. package/dist/cjs/tds-header-dropdown-list-item.cjs.entry.js +2 -2
  25. package/dist/cjs/tds-header-dropdown-list-user.cjs.entry.js +1 -1
  26. package/dist/cjs/tds-header-dropdown-list.cjs.entry.js +1 -1
  27. package/dist/cjs/tds-header-dropdown.cjs.entry.js +3 -3
  28. package/dist/cjs/tds-header-hamburger.cjs.entry.js +1 -1
  29. package/dist/cjs/tds-header-launcher-button.cjs.entry.js +1 -1
  30. package/dist/cjs/tds-header-launcher-grid-item.cjs.entry.js +1 -1
  31. package/dist/cjs/tds-header-launcher-grid-title.cjs.entry.js +1 -1
  32. package/dist/cjs/tds-header-launcher-grid.cjs.entry.js +1 -1
  33. package/dist/cjs/tds-header-launcher-list-item.cjs.entry.js +1 -1
  34. package/dist/cjs/tds-header-launcher-list-title.cjs.entry.js +1 -1
  35. package/dist/cjs/tds-header-launcher-list.cjs.entry.js +1 -1
  36. package/dist/cjs/tds-header-launcher.cjs.entry.js +2 -2
  37. package/dist/cjs/tds-header-title.cjs.entry.js +1 -1
  38. package/dist/cjs/tds-header.cjs.entry.js +1 -1
  39. package/dist/cjs/tds-icon.cjs.entry.js +1 -1
  40. package/dist/cjs/tds-inline-tab.cjs.entry.js +5 -2
  41. package/dist/cjs/tds-inline-tabs.cjs.entry.js +2 -2
  42. package/dist/cjs/tds-link.cjs.entry.js +5 -5
  43. package/dist/cjs/tds-message.cjs.entry.js +6 -4
  44. package/dist/cjs/tds-modal.cjs.entry.js +4 -1
  45. package/dist/cjs/tds-navigation-tab.cjs.entry.js +2 -2
  46. package/dist/cjs/tds-navigation-tabs.cjs.entry.js +8 -2
  47. package/dist/cjs/tds-popover-canvas.cjs.entry.js +2 -2
  48. package/dist/cjs/tds-popover-core.cjs.entry.js +1 -1
  49. package/dist/cjs/tds-popover-menu-item.cjs.entry.js +2 -2
  50. package/dist/cjs/tds-popover-menu.cjs.entry.js +2 -2
  51. package/dist/cjs/tds-radio-button.cjs.entry.js +1 -1
  52. package/dist/cjs/tds-side-menu-close-button.cjs.entry.js +1 -1
  53. package/dist/cjs/tds-side-menu-collapse-button.cjs.entry.js +4 -4
  54. package/dist/cjs/tds-side-menu-dropdown-list-item.cjs.entry.js +2 -2
  55. package/dist/cjs/tds-side-menu-dropdown-list.cjs.entry.js +2 -2
  56. package/dist/cjs/tds-side-menu-dropdown.cjs.entry.js +3 -3
  57. package/dist/cjs/tds-side-menu-item.cjs.entry.js +2 -2
  58. package/dist/cjs/tds-side-menu-overlay.cjs.entry.js +1 -1
  59. package/dist/cjs/tds-side-menu-user-image_2.cjs.entry.js +2 -2
  60. package/dist/cjs/tds-side-menu-user.cjs.entry.js +1 -1
  61. package/dist/cjs/tds-slider.cjs.entry.js +8 -8
  62. package/dist/cjs/tds-spinner.cjs.entry.js +1 -1
  63. package/dist/cjs/tds-step.cjs.entry.js +1 -1
  64. package/dist/cjs/tds-table-body-input-wrapper.cjs.entry.js +1 -1
  65. package/dist/cjs/tds-table-body-row-expandable.cjs.entry.js +7 -7
  66. package/dist/cjs/tds-table-body-row.cjs.entry.js +9 -6
  67. package/dist/cjs/tds-table-body.cjs.entry.js +2 -2
  68. package/dist/cjs/tds-table-footer.cjs.entry.js +3 -3
  69. package/dist/cjs/tds-table-header-input-wrapper.cjs.entry.js +1 -1
  70. package/dist/cjs/tds-table-header.cjs.entry.js +2 -2
  71. package/dist/cjs/tds-table-toolbar.cjs.entry.js +2 -2
  72. package/dist/cjs/tds-text-field.cjs.entry.js +8 -6
  73. package/dist/cjs/tds-textarea.cjs.entry.js +14 -12
  74. package/dist/cjs/tds-toast.cjs.entry.js +3 -3
  75. package/dist/cjs/tds-toggle.cjs.entry.js +4 -1
  76. package/dist/cjs/tds-tooltip.cjs.entry.js +2 -2
  77. package/dist/cjs/tegel.cjs.js +1 -1
  78. package/dist/collection/components/accordion/accordion-item/accordion-item.js +25 -4
  79. package/dist/collection/components/badge/badge.js +6 -1
  80. package/dist/collection/components/banner/banner.js +24 -3
  81. package/dist/collection/components/block/block.js +10 -6
  82. package/dist/collection/components/breadcrumbs/breadcrumb/breadcrumb.js +1 -1
  83. package/dist/collection/components/breadcrumbs/breadcrumbs.js +1 -1
  84. package/dist/collection/components/button/button.css +3 -3
  85. package/dist/collection/components/button/button.js +6 -2
  86. package/dist/collection/components/card/card.js +9 -5
  87. package/dist/collection/components/checkbox/checkbox.js +2 -2
  88. package/dist/collection/components/chip/chip.js +1 -1
  89. package/dist/collection/components/datetime/datetime.js +2 -2
  90. package/dist/collection/components/divider/divider.js +1 -1
  91. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +26 -11
  92. package/dist/collection/components/dropdown/dropdown.js +283 -226
  93. package/dist/collection/components/footer/footer-group/footer-group.js +3 -3
  94. package/dist/collection/components/footer/footer-item/footer-item.js +1 -1
  95. package/dist/collection/components/footer/footer.js +3 -1
  96. package/dist/collection/components/header/core-header-item/core-header-item.js +1 -1
  97. package/dist/collection/components/header/header-brand-symbol/header-brand-symbol.js +1 -1
  98. package/dist/collection/components/header/header-dropdown/header-dropdown.js +3 -3
  99. package/dist/collection/components/header/header-dropdown-list/header-dropdown-list.js +1 -1
  100. package/dist/collection/components/header/header-dropdown-list-item/header-dropdown-list-item.js +2 -2
  101. package/dist/collection/components/header/header-dropdown-list-user/header-dropdown-list-user.js +1 -1
  102. package/dist/collection/components/header/header-hamburger/header-hamburger.js +1 -1
  103. package/dist/collection/components/header/header-item/header-item.js +2 -2
  104. package/dist/collection/components/header/header-launcher/header-launcher.js +2 -2
  105. package/dist/collection/components/header/header-launcher-button/header-launcher-button.js +1 -1
  106. package/dist/collection/components/header/header-launcher-grid/header-launcher-grid.js +1 -1
  107. package/dist/collection/components/header/header-launcher-grid-item/header-launcher-grid-item.js +1 -1
  108. package/dist/collection/components/header/header-launcher-grid-title/header-launcher-grid-title.js +1 -1
  109. package/dist/collection/components/header/header-launcher-list/header-launcher-list.js +1 -1
  110. package/dist/collection/components/header/header-launcher-list-item/header-launcher-list-item.js +1 -1
  111. package/dist/collection/components/header/header-launcher-list-title/header-launcher-list-title.js +1 -1
  112. package/dist/collection/components/header/header-title/header-title.js +1 -1
  113. package/dist/collection/components/header/header.js +1 -1
  114. package/dist/collection/components/icon/icon.js +1 -1
  115. package/dist/collection/components/link/link.js +5 -5
  116. package/dist/collection/components/message/message.js +6 -4
  117. package/dist/collection/components/modal/modal.js +4 -1
  118. package/dist/collection/components/popover-canvas/popover-canvas.js +2 -2
  119. package/dist/collection/components/popover-core/popover-core.js +1 -1
  120. package/dist/collection/components/popover-menu/popover-menu-item/popover-menu-item.js +2 -2
  121. package/dist/collection/components/popover-menu/popover-menu.js +2 -2
  122. package/dist/collection/components/radio-button/radio-button.js +1 -1
  123. package/dist/collection/components/side-menu/side-menu-close-button/side-menu-close-button.js +1 -1
  124. package/dist/collection/components/side-menu/side-menu-collapse-button/side-menu-collapse-button.js +4 -4
  125. package/dist/collection/components/side-menu/side-menu-dropdown/side-menu-dropdown.js +3 -3
  126. package/dist/collection/components/side-menu/side-menu-dropdown-list/side-menu-dropdown-list.js +2 -2
  127. package/dist/collection/components/side-menu/side-menu-dropdown-list-item/side-menu-dropdown-list-item.js +2 -2
  128. package/dist/collection/components/side-menu/side-menu-item/side-menu-item.js +2 -2
  129. package/dist/collection/components/side-menu/side-menu-overlay/side-menu-overlay.js +1 -1
  130. package/dist/collection/components/side-menu/side-menu-user/side-menu-user.js +1 -1
  131. package/dist/collection/components/side-menu/side-menu-user-image/side-menu-user-image.js +1 -1
  132. package/dist/collection/components/side-menu/side-menu-user-label/side-menu-user-label.js +1 -1
  133. package/dist/collection/components/slider/slider.css +13 -0
  134. package/dist/collection/components/slider/slider.js +7 -7
  135. package/dist/collection/components/spinner/spinner.js +1 -1
  136. package/dist/collection/components/stepper/step/step.js +1 -1
  137. package/dist/collection/components/table/table-body/table-body.js +2 -2
  138. package/dist/collection/components/table/table-body-cell/table-body-cell.js +9 -6
  139. package/dist/collection/components/table/table-body-input-wrapper/table-body-input-wrapper.js +1 -1
  140. package/dist/collection/components/table/table-body-row/table-body-row.js +9 -6
  141. package/dist/collection/components/table/table-body-row-expandable/table-body-row-expandable.js +7 -7
  142. package/dist/collection/components/table/table-footer/table-footer.js +3 -3
  143. package/dist/collection/components/table/table-header/table-header.js +2 -2
  144. package/dist/collection/components/table/table-header-cell/table-header-cell.js +1 -1
  145. package/dist/collection/components/table/table-header-input-wrapper/table-header-input-wrapper.js +1 -1
  146. package/dist/collection/components/table/table-toolbar/table-toolbar.js +2 -2
  147. package/dist/collection/components/tabs/folder-tabs/folder-tab/folder-tab.js +4 -2
  148. package/dist/collection/components/tabs/folder-tabs/folder-tabs.js +2 -2
  149. package/dist/collection/components/tabs/inline-tabs/inline-tab/inline-tab.js +5 -2
  150. package/dist/collection/components/tabs/inline-tabs/inline-tabs.js +2 -2
  151. package/dist/collection/components/tabs/navigation-tabs/navigation-tab/navigation-tab.js +2 -2
  152. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +8 -2
  153. package/dist/collection/components/text-field/text-field.js +9 -7
  154. package/dist/collection/components/textarea/textarea.js +14 -12
  155. package/dist/collection/components/toast/toast.js +3 -3
  156. package/dist/collection/components/toggle/toggle.js +4 -1
  157. package/dist/collection/components/tooltip/tooltip.js +2 -2
  158. package/dist/collection/utils/axeHelpers.js +3 -0
  159. package/dist/collection/utils/convertToString.js +14 -0
  160. package/dist/components/{p-0c3cab16.js → p-2ef329f1.js} +2 -2
  161. package/dist/components/{p-5e1a9abc.js → p-3351035f.js} +1 -1
  162. package/dist/components/{p-0676aa23.js → p-3a7f88ff.js} +3 -3
  163. package/dist/components/{p-1aae42d5.js → p-467fe701.js} +241 -160
  164. package/dist/components/{p-09d36119.js → p-4bdaf254.js} +1 -1
  165. package/dist/components/{p-4030e9bc.js → p-6c2d5c85.js} +24 -10
  166. package/dist/components/{p-30de8ac4.js → p-707a562e.js} +1 -1
  167. package/dist/components/{p-fcec766c.js → p-75437dea.js} +1 -1
  168. package/dist/components/{p-e46088d9.js → p-8f8b0827.js} +1 -1
  169. package/dist/components/{p-cfb1b588.js → p-9d7232d0.js} +2 -2
  170. package/dist/components/{p-e323cd2a.js → p-ad77fb02.js} +1 -1
  171. package/dist/components/p-b1d21573.js +16 -0
  172. package/dist/components/{p-dddaa520.js → p-d1ace0be.js} +1 -1
  173. package/dist/components/{p-d921fe75.js → p-eac79032.js} +2 -2
  174. package/dist/components/{p-aea7fa6b.js → p-f0a50868.js} +3 -3
  175. package/dist/components/{p-8a2d7b2f.js → p-f1980746.js} +4 -4
  176. package/dist/components/tds-accordion-item.js +9 -5
  177. package/dist/components/tds-badge.js +6 -1
  178. package/dist/components/tds-banner.js +8 -4
  179. package/dist/components/tds-block.js +10 -6
  180. package/dist/components/tds-body-cell.js +9 -6
  181. package/dist/components/tds-breadcrumb.js +1 -1
  182. package/dist/components/tds-breadcrumbs.js +1 -1
  183. package/dist/components/tds-button.js +7 -3
  184. package/dist/components/tds-card.js +10 -6
  185. package/dist/components/tds-checkbox.js +1 -1
  186. package/dist/components/tds-chip.js +1 -1
  187. package/dist/components/tds-core-header-item.js +1 -1
  188. package/dist/components/tds-datetime.js +3 -3
  189. package/dist/components/tds-divider.js +1 -1
  190. package/dist/components/tds-dropdown-option.js +1 -1
  191. package/dist/components/tds-dropdown.js +1 -1
  192. package/dist/components/tds-folder-tab.js +4 -2
  193. package/dist/components/tds-folder-tabs.js +3 -3
  194. package/dist/components/tds-footer-group.js +4 -4
  195. package/dist/components/tds-footer-item.js +1 -1
  196. package/dist/components/tds-footer.js +3 -1
  197. package/dist/components/tds-header-brand-symbol.js +3 -3
  198. package/dist/components/tds-header-cell.js +2 -2
  199. package/dist/components/tds-header-dropdown-list-item.js +1 -1
  200. package/dist/components/tds-header-dropdown-list-user.js +1 -1
  201. package/dist/components/tds-header-dropdown-list.js +1 -1
  202. package/dist/components/tds-header-dropdown.js +8 -8
  203. package/dist/components/tds-header-hamburger.js +4 -4
  204. package/dist/components/tds-header-item.js +1 -1
  205. package/dist/components/tds-header-launcher-button.js +1 -1
  206. package/dist/components/tds-header-launcher-grid-item.js +1 -1
  207. package/dist/components/tds-header-launcher-grid-title.js +1 -1
  208. package/dist/components/tds-header-launcher-grid.js +1 -1
  209. package/dist/components/tds-header-launcher-list-item.js +2 -2
  210. package/dist/components/tds-header-launcher-list-title.js +1 -1
  211. package/dist/components/tds-header-launcher-list.js +2 -2
  212. package/dist/components/tds-header-launcher.js +8 -8
  213. package/dist/components/tds-header-title.js +1 -1
  214. package/dist/components/tds-header.js +1 -1
  215. package/dist/components/tds-icon.js +1 -1
  216. package/dist/components/tds-inline-tab.js +5 -2
  217. package/dist/components/tds-inline-tabs.js +3 -3
  218. package/dist/components/tds-link.js +5 -5
  219. package/dist/components/tds-message.js +7 -5
  220. package/dist/components/tds-modal.js +5 -2
  221. package/dist/components/tds-navigation-tab.js +2 -2
  222. package/dist/components/tds-navigation-tabs.js +9 -3
  223. package/dist/components/tds-popover-canvas.js +1 -1
  224. package/dist/components/tds-popover-core.js +1 -1
  225. package/dist/components/tds-popover-menu-item.js +2 -2
  226. package/dist/components/tds-popover-menu.js +3 -3
  227. package/dist/components/tds-radio-button.js +1 -1
  228. package/dist/components/tds-side-menu-close-button.js +2 -2
  229. package/dist/components/tds-side-menu-collapse-button.js +5 -5
  230. package/dist/components/tds-side-menu-dropdown-list-item.js +2 -2
  231. package/dist/components/tds-side-menu-dropdown-list.js +2 -2
  232. package/dist/components/tds-side-menu-dropdown.js +5 -5
  233. package/dist/components/tds-side-menu-item.js +1 -1
  234. package/dist/components/tds-side-menu-overlay.js +1 -1
  235. package/dist/components/tds-side-menu-user-image.js +1 -1
  236. package/dist/components/tds-side-menu-user-label.js +1 -1
  237. package/dist/components/tds-side-menu-user.js +3 -3
  238. package/dist/components/tds-slider.js +9 -9
  239. package/dist/components/tds-spinner.js +1 -1
  240. package/dist/components/tds-step.js +2 -2
  241. package/dist/components/tds-table-body-input-wrapper.js +2 -2
  242. package/dist/components/tds-table-body-row-expandable.js +7 -7
  243. package/dist/components/tds-table-body-row.js +10 -7
  244. package/dist/components/tds-table-body.js +2 -2
  245. package/dist/components/tds-table-footer.js +7 -7
  246. package/dist/components/tds-table-header-input-wrapper.js +2 -2
  247. package/dist/components/tds-table-header.js +3 -3
  248. package/dist/components/tds-table-toolbar.js +3 -3
  249. package/dist/components/tds-text-field.js +9 -7
  250. package/dist/components/tds-textarea.js +15 -13
  251. package/dist/components/tds-toast.js +4 -4
  252. package/dist/components/tds-toggle.js +4 -1
  253. package/dist/components/tds-tooltip.js +3 -3
  254. package/dist/esm/loader.js +1 -1
  255. package/dist/esm/tds-accordion-item.entry.js +7 -4
  256. package/dist/esm/tds-badge.entry.js +6 -1
  257. package/dist/esm/tds-banner.entry.js +6 -3
  258. package/dist/esm/tds-block.entry.js +10 -6
  259. package/dist/esm/tds-body-cell.entry.js +9 -6
  260. package/dist/esm/tds-breadcrumb.entry.js +1 -1
  261. package/dist/esm/tds-breadcrumbs.entry.js +1 -1
  262. package/dist/esm/tds-button.entry.js +7 -3
  263. package/dist/esm/tds-card.entry.js +9 -5
  264. package/dist/esm/tds-checkbox.entry.js +2 -2
  265. package/dist/esm/tds-chip.entry.js +1 -1
  266. package/dist/esm/tds-core-header-item_2.entry.js +3 -3
  267. package/dist/esm/tds-datetime.entry.js +2 -2
  268. package/dist/esm/tds-divider.entry.js +1 -1
  269. package/dist/esm/tds-dropdown_2.entry.js +262 -156
  270. package/dist/esm/tds-folder-tab.entry.js +4 -2
  271. package/dist/esm/tds-folder-tabs.entry.js +2 -2
  272. package/dist/esm/tds-footer-group.entry.js +3 -3
  273. package/dist/esm/tds-footer-item.entry.js +1 -1
  274. package/dist/esm/tds-footer.entry.js +3 -1
  275. package/dist/esm/tds-header-brand-symbol.entry.js +1 -1
  276. package/dist/esm/tds-header-cell.entry.js +1 -1
  277. package/dist/esm/tds-header-dropdown-list-item.entry.js +2 -2
  278. package/dist/esm/tds-header-dropdown-list-user.entry.js +1 -1
  279. package/dist/esm/tds-header-dropdown-list.entry.js +1 -1
  280. package/dist/esm/tds-header-dropdown.entry.js +3 -3
  281. package/dist/esm/tds-header-hamburger.entry.js +1 -1
  282. package/dist/esm/tds-header-launcher-button.entry.js +1 -1
  283. package/dist/esm/tds-header-launcher-grid-item.entry.js +1 -1
  284. package/dist/esm/tds-header-launcher-grid-title.entry.js +1 -1
  285. package/dist/esm/tds-header-launcher-grid.entry.js +1 -1
  286. package/dist/esm/tds-header-launcher-list-item.entry.js +1 -1
  287. package/dist/esm/tds-header-launcher-list-title.entry.js +1 -1
  288. package/dist/esm/tds-header-launcher-list.entry.js +1 -1
  289. package/dist/esm/tds-header-launcher.entry.js +2 -2
  290. package/dist/esm/tds-header-title.entry.js +1 -1
  291. package/dist/esm/tds-header.entry.js +1 -1
  292. package/dist/esm/tds-icon.entry.js +1 -1
  293. package/dist/esm/tds-inline-tab.entry.js +5 -2
  294. package/dist/esm/tds-inline-tabs.entry.js +2 -2
  295. package/dist/esm/tds-link.entry.js +5 -5
  296. package/dist/esm/tds-message.entry.js +6 -4
  297. package/dist/esm/tds-modal.entry.js +4 -1
  298. package/dist/esm/tds-navigation-tab.entry.js +2 -2
  299. package/dist/esm/tds-navigation-tabs.entry.js +8 -2
  300. package/dist/esm/tds-popover-canvas.entry.js +2 -2
  301. package/dist/esm/tds-popover-core.entry.js +1 -1
  302. package/dist/esm/tds-popover-menu-item.entry.js +2 -2
  303. package/dist/esm/tds-popover-menu.entry.js +2 -2
  304. package/dist/esm/tds-radio-button.entry.js +1 -1
  305. package/dist/esm/tds-side-menu-close-button.entry.js +1 -1
  306. package/dist/esm/tds-side-menu-collapse-button.entry.js +4 -4
  307. package/dist/esm/tds-side-menu-dropdown-list-item.entry.js +2 -2
  308. package/dist/esm/tds-side-menu-dropdown-list.entry.js +2 -2
  309. package/dist/esm/tds-side-menu-dropdown.entry.js +3 -3
  310. package/dist/esm/tds-side-menu-item.entry.js +2 -2
  311. package/dist/esm/tds-side-menu-overlay.entry.js +1 -1
  312. package/dist/esm/tds-side-menu-user-image_2.entry.js +2 -2
  313. package/dist/esm/tds-side-menu-user.entry.js +1 -1
  314. package/dist/esm/tds-slider.entry.js +8 -8
  315. package/dist/esm/tds-spinner.entry.js +1 -1
  316. package/dist/esm/tds-step.entry.js +1 -1
  317. package/dist/esm/tds-table-body-input-wrapper.entry.js +1 -1
  318. package/dist/esm/tds-table-body-row-expandable.entry.js +7 -7
  319. package/dist/esm/tds-table-body-row.entry.js +9 -6
  320. package/dist/esm/tds-table-body.entry.js +2 -2
  321. package/dist/esm/tds-table-footer.entry.js +3 -3
  322. package/dist/esm/tds-table-header-input-wrapper.entry.js +1 -1
  323. package/dist/esm/tds-table-header.entry.js +2 -2
  324. package/dist/esm/tds-table-toolbar.entry.js +2 -2
  325. package/dist/esm/tds-text-field.entry.js +8 -6
  326. package/dist/esm/tds-textarea.entry.js +14 -12
  327. package/dist/esm/tds-toast.entry.js +3 -3
  328. package/dist/esm/tds-toggle.entry.js +4 -1
  329. package/dist/esm/tds-tooltip.entry.js +2 -2
  330. package/dist/esm/tegel.js +1 -1
  331. package/dist/tegel/{p-b4c7099f.entry.js → p-038c22ff.entry.js} +1 -1
  332. package/dist/tegel/{p-57f95a1b.entry.js → p-059a9499.entry.js} +1 -1
  333. package/dist/tegel/{p-9de400f4.entry.js → p-06968bd7.entry.js} +1 -1
  334. package/dist/tegel/{p-ede11de8.entry.js → p-0939b9fb.entry.js} +1 -1
  335. package/dist/tegel/p-0b773208.entry.js +1 -0
  336. package/dist/tegel/{p-b9e37cf2.entry.js → p-1703f73a.entry.js} +1 -1
  337. package/dist/tegel/p-170ab61b.entry.js +1 -0
  338. package/dist/tegel/p-1aecae56.entry.js +1 -0
  339. package/dist/tegel/{p-ac46b0a4.entry.js → p-24ff5903.entry.js} +1 -1
  340. package/dist/tegel/{p-9bf7f5cd.entry.js → p-2795009a.entry.js} +1 -1
  341. package/dist/tegel/{p-4ab7461e.entry.js → p-2a38b053.entry.js} +1 -1
  342. package/dist/tegel/{p-6b405a0f.entry.js → p-2a96bd05.entry.js} +1 -1
  343. package/dist/tegel/{p-50fcdc56.entry.js → p-2f32991e.entry.js} +1 -1
  344. package/dist/tegel/p-32b7f431.entry.js +1 -0
  345. package/dist/tegel/{p-2557b79b.entry.js → p-3a32fe40.entry.js} +1 -1
  346. package/dist/tegel/p-3c22aef7.entry.js +1 -0
  347. package/dist/tegel/{p-bcae4d3a.entry.js → p-3d3ee51f.entry.js} +1 -1
  348. package/dist/tegel/p-3e144a83.entry.js +1 -0
  349. package/dist/tegel/p-3e1b1399.entry.js +1 -0
  350. package/dist/tegel/{p-2e44b4e9.entry.js → p-44c33b20.entry.js} +1 -1
  351. package/dist/tegel/p-48bbc11f.entry.js +1 -0
  352. package/dist/tegel/p-4a282c25.entry.js +1 -0
  353. package/dist/tegel/p-4b231bf9.entry.js +1 -0
  354. package/dist/tegel/{p-1634247e.entry.js → p-4b7c53a6.entry.js} +1 -1
  355. package/dist/tegel/{p-0df92ce7.entry.js → p-4c2f313d.entry.js} +1 -1
  356. package/dist/tegel/{p-ff5cd75f.entry.js → p-54154f09.entry.js} +1 -1
  357. package/dist/tegel/{p-ff7ae8a3.entry.js → p-59293f88.entry.js} +1 -1
  358. package/dist/tegel/p-5e0fc86c.entry.js +1 -0
  359. package/dist/tegel/{p-e63f827f.entry.js → p-5eaa23dc.entry.js} +1 -1
  360. package/dist/tegel/{p-bb129d43.entry.js → p-5fea857b.entry.js} +1 -1
  361. package/dist/tegel/{p-088bfcd4.entry.js → p-68859ddc.entry.js} +1 -1
  362. package/dist/tegel/p-69b38504.entry.js +1 -0
  363. package/dist/tegel/{p-a5a67770.entry.js → p-6d022f47.entry.js} +1 -1
  364. package/dist/tegel/{p-868435cd.entry.js → p-6eeded00.entry.js} +1 -1
  365. package/dist/tegel/{p-0f38bea7.entry.js → p-708a8bab.entry.js} +1 -1
  366. package/dist/tegel/p-7090a95c.entry.js +1 -0
  367. package/dist/tegel/{p-4e3e2601.entry.js → p-72106a5c.entry.js} +1 -1
  368. package/dist/tegel/{p-ed02ad2b.entry.js → p-7929d22f.entry.js} +1 -1
  369. package/dist/tegel/p-85a9032e.entry.js +1 -0
  370. package/dist/tegel/{p-f9325536.entry.js → p-86b30f71.entry.js} +1 -1
  371. package/dist/tegel/p-88204e0a.entry.js +1 -0
  372. package/dist/tegel/{p-6a52ed63.entry.js → p-9016758e.entry.js} +1 -1
  373. package/dist/tegel/p-92f81cda.entry.js +1 -0
  374. package/dist/tegel/p-93930c03.entry.js +1 -0
  375. package/dist/tegel/{p-aed1c5cf.entry.js → p-96bdf035.entry.js} +1 -1
  376. package/dist/tegel/{p-7097a39a.entry.js → p-99da056d.entry.js} +1 -1
  377. package/dist/tegel/p-9c3f2c12.entry.js +1 -0
  378. package/dist/tegel/p-a38dda58.entry.js +1 -0
  379. package/dist/tegel/{p-de540cc0.entry.js → p-a392e6e7.entry.js} +1 -1
  380. package/dist/tegel/p-a86fe122.entry.js +1 -0
  381. package/dist/tegel/p-ab0528bf.entry.js +1 -0
  382. package/dist/tegel/p-b0a5eba7.entry.js +1 -0
  383. package/dist/tegel/{p-220affa9.entry.js → p-b19ce79c.entry.js} +1 -1
  384. package/dist/tegel/{p-987084a5.entry.js → p-b2018a5b.entry.js} +1 -1
  385. package/dist/tegel/{p-c790ef93.entry.js → p-b425b2f4.entry.js} +1 -1
  386. package/dist/tegel/p-b647d20e.entry.js +1 -0
  387. package/dist/tegel/{p-c18b2746.entry.js → p-b96cd80d.entry.js} +1 -1
  388. package/dist/tegel/{p-f1c172a4.entry.js → p-b9b63210.entry.js} +1 -1
  389. package/dist/tegel/p-be1d1345.entry.js +1 -0
  390. package/dist/tegel/p-be88c5ab.entry.js +1 -0
  391. package/dist/tegel/{p-91dcddd5.entry.js → p-c289dfb9.entry.js} +1 -1
  392. package/dist/tegel/p-cc2730d8.entry.js +1 -0
  393. package/dist/tegel/p-d1112915.entry.js +1 -0
  394. package/dist/tegel/{p-e65dba91.entry.js → p-d7f48112.entry.js} +1 -1
  395. package/dist/tegel/p-d926d075.entry.js +1 -0
  396. package/dist/tegel/{p-26ae4a93.entry.js → p-ddd33cce.entry.js} +1 -1
  397. package/dist/tegel/{p-c917d8be.entry.js → p-e478953c.entry.js} +1 -1
  398. package/dist/tegel/p-e7300cca.entry.js +1 -0
  399. package/dist/tegel/{p-6c26e66f.entry.js → p-e9ac7a1a.entry.js} +1 -1
  400. package/dist/tegel/{p-dd060c11.entry.js → p-ea4a9a4f.entry.js} +1 -1
  401. package/dist/tegel/{p-e7108828.entry.js → p-f4db0231.entry.js} +1 -1
  402. package/dist/tegel/p-f67b4047.entry.js +1 -0
  403. package/dist/tegel/{p-a642c800.entry.js → p-fd3d56aa.entry.js} +1 -1
  404. package/dist/tegel/{p-06d2fa56.entry.js → p-fd432c54.entry.js} +1 -1
  405. package/dist/tegel/{p-ad434031.entry.js → p-ffd827ef.entry.js} +1 -1
  406. package/dist/tegel/tegel.esm.js +1 -1
  407. package/dist/types/components/accordion/accordion-item/accordion-item.d.ts +2 -0
  408. package/dist/types/components/banner/banner.d.ts +4 -0
  409. package/dist/types/components/checkbox/checkbox.d.ts +1 -1
  410. package/dist/types/components/dropdown/dropdown-option/dropdown-option.d.ts +6 -2
  411. package/dist/types/components/dropdown/dropdown.d.ts +39 -27
  412. package/dist/types/components.d.ts +33 -27
  413. package/dist/types/utils/axeHelpers.d.ts +2 -0
  414. package/dist/types/utils/convertToString.d.ts +7 -0
  415. package/package.json +5 -5
  416. package/dist/tegel/p-12303135.entry.js +0 -1
  417. package/dist/tegel/p-1a2f3852.entry.js +0 -1
  418. package/dist/tegel/p-1bc2c73c.entry.js +0 -1
  419. package/dist/tegel/p-54a105a4.entry.js +0 -1
  420. package/dist/tegel/p-5a891dd2.entry.js +0 -1
  421. package/dist/tegel/p-5d0e8f1e.entry.js +0 -1
  422. package/dist/tegel/p-6938329a.entry.js +0 -1
  423. package/dist/tegel/p-693e48cf.entry.js +0 -1
  424. package/dist/tegel/p-6aabf7e1.entry.js +0 -1
  425. package/dist/tegel/p-7a83cf55.entry.js +0 -1
  426. package/dist/tegel/p-7d39487c.entry.js +0 -1
  427. package/dist/tegel/p-7d83ba98.entry.js +0 -1
  428. package/dist/tegel/p-845e1fca.entry.js +0 -1
  429. package/dist/tegel/p-930e767e.entry.js +0 -1
  430. package/dist/tegel/p-959a6780.entry.js +0 -1
  431. package/dist/tegel/p-9aefb942.entry.js +0 -1
  432. package/dist/tegel/p-9c2dfecc.entry.js +0 -1
  433. package/dist/tegel/p-a9654cd4.entry.js +0 -1
  434. package/dist/tegel/p-b00bcf39.entry.js +0 -1
  435. package/dist/tegel/p-b9ac3122.entry.js +0 -1
  436. package/dist/tegel/p-bda3d846.entry.js +0 -1
  437. package/dist/tegel/p-cd5219ac.entry.js +0 -1
  438. package/dist/tegel/p-d1cbe5be.entry.js +0 -1
  439. package/dist/tegel/p-dcbd977f.entry.js +0 -1
  440. package/dist/tegel/p-e13935b6.entry.js +0 -1
  441. package/dist/tegel/p-e86f2d31.entry.js +0 -1
  442. package/dist/tegel/p-e97a2700.entry.js +0 -1
  443. package/dist/tegel/p-f45d905c.entry.js +0 -1
  444. package/dist/tegel/p-f841f094.entry.js +0 -1
  445. package/dist/tegel/p-fc0079d2.entry.js +0 -1
@@ -62,6 +62,21 @@ const appendHiddenInput = (element, name, value, disabled, additionalAttributes)
62
62
  input.value = value || '';
63
63
  };
64
64
 
65
+ /**
66
+ * Converts a value (string or number) to string
67
+ * @param value - The value to convert
68
+ * @returns The string representation of the value, or empty string if null/undefined
69
+ */
70
+ const convertToString = (value) => {
71
+ if (value === null || value === undefined)
72
+ return '';
73
+ return value.toString();
74
+ };
75
+ // Optional: If we need array conversion often
76
+ const convertArrayToStrings = (values) => {
77
+ return values.map((value) => convertToString(value));
78
+ };
79
+
65
80
  const dropdownCss = "@charset \"UTF-8\";:host button{all:unset;height:100%;width:100%;background-color:var(--tds-dropdown-bg);border-bottom:1px solid var(--tds-dropdown-border-bottom);border-radius:var(--tds-dropdown-border-radius)}:host button:hover{border-bottom:1px solid var(--tds-dropdown-border-bottom-hover)}:host button .value-wrapper{padding:0 16px;display:flex;align-items:center;justify-content:space-between}:host button.placeholder{color:var(--tds-dropdown-placeholder-color);line-height:1.3}:host button.value{color:var(--tds-dropdown-value-color);font:var(--tds-detail-02);letter-spacing:var(--tds-detail-02-ls);line-height:1.3}:host button:focus{border-bottom-color:var(--tds-dropdown-border-bottom-open)}:host button:focus::before{content:\"\";position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--tds-dropdown-border-bottom-open)}:host button.error{border-bottom:1px solid var(--tds-negative)}:host button.error:focus{border-bottom-color:transparent}:host button.error:focus::before{content:\"\";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--tds-negative)}:host button:disabled{color:var(--tds-dropdown-disabled-color);border-bottom:1px solid transparent}:host button .menu-icon{margin-right:0}:host .filter{display:flex;align-items:center;justify-content:space-between;height:100%;background-color:var(--tds-dropdown-bg);border-bottom:1px solid var(--tds-dropdown-border-bottom);padding-left:16px;border-radius:4px 4px 0 0}:host .filter:hover{border-bottom:1px solid var(--tds-dropdown-border-bottom-hover)}:host .filter.disabled{color:var(--tds-dropdown-disabled-color);border-bottom:1px solid transparent}:host .filter .value-wrapper{display:flex;width:100%;height:100%}:host .filter .value-wrapper input{color:var(--tds-dropdown-filter-input-color)}:host .filter .label-inside-as-placeholder{position:absolute;font:var(--tds-detail-02);letter-spacing:var(--tds-detail-02-ls);line-height:1.3;color:var(--tds-dropdown-placeholder-color)}:host .filter .label-inside-as-placeholder.lg{top:20px}:host .filter .label-inside-as-placeholder.md{top:16px}:host .filter .label-inside-as-placeholder.sm{display:none}:host .filter .label-inside-as-placeholder.selected{font:var(--tds-detail-07);letter-spacing:var(--tds-detail-07-ls);transition:all 0.2s ease-in-out}:host .filter .label-inside-as-placeholder.selected.lg{top:12px}:host .filter .label-inside-as-placeholder.selected.md{top:8px}:host .filter .label-inside-as-placeholder.selected.sm{display:none}:host .filter .label-inside-as-placeholder.selected+.placeholder:not(.sm){margin-top:8px}:host .filter.focus{border-bottom-color:transparent}:host .filter.focus::before{content:\"\";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--tds-dropdown-border-bottom-open)}:host .filter.error{border-bottom:1px solid var(--tds-negative)}:host .filter.error.focus{border-bottom-color:transparent}:host .filter.error.focus::before{content:\"\";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--tds-negative)}:host .filter input{flex:1;all:unset;width:100%}:host .filter input::placeholder{color:var(--tds-dropdown-placeholder-color)}:host .filter input:disabled::placeholder{color:var(--tds-dropdown-disabled-color)}:host .filter tds-icon{cursor:pointer}:host .filter .menu-icon{margin-right:16px}:host .filter .clear-icon{margin:0 8px;color:var(--tds-dropdown-clear-icon-color);padding-right:8px;border-right:1px solid var(--tds-dropdown-clear-icon-color)}:host .filter .clear-icon:hover{color:var(--tds-dropdown-clear-icon-hover-color)}:host .filter .clear-icon.hide{display:none;visibility:hidden}:host{--tds-scrollbar-width-standard:thin;--tds-scrollbar-width:10px;--tds-scrollbar-height:10px;--tds-scrollbar-thumb-border-width:3px;--tds-scrollbar-thumb-border-hover-width:2px}body{scrollbar-width:thin}:host{display:block;position:relative;font:var(--tds-detail-02);letter-spacing:var(--tds-detail-02-ls)}:host .label-outside{font:var(--tds-detail-05);letter-spacing:var(--tds-detail-05-ls);color:var(--tds-dropdown-label-color);margin-bottom:8px}:host .label-outside.disabled{color:var(--tds-dropdown-disabled-color)}:host .dropdown-select{position:relative}:host .dropdown-select button{transition:border-bottom-color var(--tds-motion-duration-fast-02) var(--tds-motion-easing-scania)}:host .dropdown-select button:focus{border-bottom-color:var(--tds-dropdown-border-bottom)}:host .dropdown-select button:hover{border-bottom-color:var(--tds-dropdown-border-bottom-hover)}:host .dropdown-select button{border-bottom-color:var(--tds-dropdown-border-bottom)}:host .dropdown-select button.error{border-bottom-color:var(--tds-negative)}:host .dropdown-select button.error:focus{border-bottom-color:transparent}:host .dropdown-select.disabled .label-inside,:host .dropdown-select.disabled .placeholder,:host .dropdown-select.disabled .label-inside-as-placeholder,:host .dropdown-select.disabled .value-wrapper{color:var(--tds-dropdown-disabled-color)}:host .dropdown-select.disabled button{border:none}:host .dropdown-select .label-inside{position:absolute;font:var(--tds-detail-07);letter-spacing:var(--tds-detail-07-ls);color:var(--tds-dropdown-label-inside-color)}:host .dropdown-select .label-inside.lg{top:12px;left:16px}:host .dropdown-select .label-inside.md{top:8px;left:16px}:host .dropdown-select .label-inside.sm{display:none}:host .dropdown-select .label-inside.xs{display:none}:host .dropdown-select .label-inside+.placeholder:not(.sm){margin-top:8px}:host .dropdown-select .placeholder{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:var(--tds-placeholder-margin);}:host .dropdown-select .placeholder.xs{line-height:1}:host .dropdown-select .label-inside-as-placeholder{color:var(--tds-dropdown-placeholder-color)}:host .dropdown-select .label-inside-as-placeholder.selected{position:absolute;font:var(--tds-detail-07);letter-spacing:var(--tds-detail-07-ls);transition:all 0.2s ease-in-out}:host .dropdown-select .label-inside-as-placeholder.selected.lg{top:12px}:host .dropdown-select .label-inside-as-placeholder.selected.md{top:8px}:host .dropdown-select .label-inside-as-placeholder.selected.sm{display:none}:host .dropdown-select .label-inside-as-placeholder.selected+.placeholder:not(.sm){margin-top:8px}:host .dropdown-select.lg{height:55px}:host .dropdown-select.md{height:47px}:host .dropdown-select.sm{height:39px}:host .dropdown-select.xs{height:29px}:host .helper{margin-top:4px;color:var(--tds-dropdown-helper-color);font:var(--tds-detail-05);letter-spacing:var(--tds-detail-05-ls);display:flex;align-items:center;gap:8px}:host .helper.error{color:var(--tds-negative)}:host .helper.disabled{color:var(--tds-dropdown-disabled-color)}:host .dropdown-list{z-index:100;position:absolute;margin-top:1px;width:100%;transform-origin:top;box-shadow:rgba(0, 0, 0, 0.1) 0 2px 3px 0;border-radius:var(--tds-dropdown-list-border-radius-down);overflow-y:auto;transform:scaleY(0);pointer-events:none}:host .dropdown-list:hover::-webkit-scrollbar-thumb{border:var(--tds-scrollbar-thumb-border-hover-width) solid transparent;background:var(--tds-scrollbar-hover-thumb-color);background-clip:padding-box}:host .dropdown-list::-webkit-scrollbar{width:var(--tds-scrollbar-width)}:host .dropdown-list::-webkit-scrollbar-track{background:var(--tds-scrollbar-track-color)}:host .dropdown-list::-webkit-scrollbar-thumb{border-radius:40px;background:var(--tds-scrollbar-thumb-color);border:var(--tds-scrollbar-thumb-border-width) solid transparent;background-clip:padding-box}:host .dropdown-list::-webkit-scrollbar-button{height:0;width:0}@supports not selector(::-webkit-scrollbar){:host .dropdown-list{scrollbar-color:var(--tds-scrollbar-thumb-color) var(--tds-scrollbar-track-color);scrollbar-width:var(--tds-scrollbar-width-standard)}}:host .dropdown-list.lg{max-height:312px}:host .dropdown-list.md{max-height:312px}:host .dropdown-list.sm{max-height:260px}:host .dropdown-list.xs{max-height:260px}:host .dropdown-list.up{bottom:100%;margin-top:0;margin-bottom:1px;transform-origin:bottom;display:flex;flex-direction:column-reverse;box-shadow:rgba(0, 0, 0, 0.1) 0 -1px 3px 0;border-radius:var(--tds-dropdown-list-border-radius-up)}:host .dropdown-list.up.label-outside{bottom:calc(100% - 24px)}:host .dropdown-list.closed{transform:scaleY(0);pointer-events:none}:host .dropdown-list.open{transform:scaleY(1);visibility:visible;opacity:1;pointer-events:auto}:host .dropdown-list.animation-enter-slide{transition:transform var(--tds-motion-duration-moderate-01) var(--tds-motion-easing-enter)}:host .dropdown-list.animation-exit-slide{transition:transform var(--tds-motion-duration-moderate-01) var(--tds-motion-easing-exit)}:host .dropdown-list .no-result{font:var(--tds-detail-02);letter-spacing:var(--tds-detail-02-ls);display:flex;align-items:center;padding:0 16px;background-color:var(--tds-dropdown-bg)}:host .dropdown-list .no-result.lg{height:56px}:host .dropdown-list .no-result.md{height:48px}:host .dropdown-list .no-result.sm{height:40px}:host .dropdown-list .no-result.xs{height:40px}:host .menu-icon{color:var(--tds-dropdown-menu-icon-color)}:host tds-icon{transition:transform var(--tds-motion-duration-fast-02) var(--tds-motion-easing-scania)}:host tds-icon.open{transform:rotateZ(180deg)}";
66
81
  const TdsDropdownStyle0 = dropdownCss;
67
82
 
@@ -72,16 +87,35 @@ const TdsDropdown = class {
72
87
  this.tdsFocus = index.createEvent(this, "tdsFocus", 6);
73
88
  this.tdsBlur = index.createEvent(this, "tdsBlur", 6);
74
89
  this.tdsInput = index.createEvent(this, "tdsInput", 6);
75
- this.tdsValueChange = index.createEvent(this, "tdsValueChange", 6);
76
90
  this.setDefaultOption = () => {
77
- if (this.defaultValue) {
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
+ }
78
97
  const defaultValues = this.multiselect
79
- ? new Set(this.defaultValue.split(','))
80
- : [this.defaultValue];
81
- const normalizedValues = Array.from(defaultValues);
82
- this.updateDropdownState(normalizedValues);
98
+ ? new Set(this.internalDefaultValue.split(','))
99
+ : [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
+ }
83
116
  }
84
117
  };
118
+ /* Returns a list of all children that are tds-dropdown-option elements */
85
119
  this.getChildren = () => {
86
120
  const tdsDropdownOptions = Array.from(this.host.children).filter((element) => element.tagName === 'TDS-DROPDOWN-OPTION');
87
121
  if (tdsDropdownOptions.length === 0) {
@@ -90,36 +124,6 @@ const TdsDropdown = class {
90
124
  else
91
125
  return tdsDropdownOptions;
92
126
  };
93
- this.getSelectedChildren = () => {
94
- if (this.selectedOptions.length === 0)
95
- return [];
96
- return this.selectedOptions
97
- .map((stringValue) => {
98
- var _a;
99
- const matchingElement = (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.find((element) => element.value === stringValue);
100
- return matchingElement;
101
- })
102
- .filter(Boolean);
103
- };
104
- this.getSelectedChildrenLabels = () => {
105
- var _a;
106
- return (_a = this.getSelectedChildren()) === null || _a === void 0 ? void 0 : _a.map((element) => element.textContent.trim());
107
- };
108
- this.getValue = () => {
109
- const labels = this.getSelectedChildrenLabels();
110
- if (!labels) {
111
- return '';
112
- }
113
- return labels === null || labels === void 0 ? void 0 : labels.join(', ');
114
- };
115
- this.setValueAttribute = () => {
116
- if (this.selectedOptions.length === 0) {
117
- this.host.removeAttribute('value');
118
- }
119
- else {
120
- this.host.setAttribute('value', this.selectedOptions.join(','));
121
- }
122
- };
123
127
  this.getOpenDirection = () => {
124
128
  var _a, _b, _c, _d, _e;
125
129
  if (this.openDirection === 'auto' || !this.openDirection) {
@@ -133,6 +137,7 @@ const TdsDropdown = class {
133
137
  }
134
138
  return this.openDirection;
135
139
  };
140
+ /* Toggles the open state of the Dropdown and sets focus to the input element */
136
141
  this.handleToggleOpen = () => {
137
142
  if (!this.disabled) {
138
143
  this.open = !this.open;
@@ -141,10 +146,38 @@ const TdsDropdown = class {
141
146
  }
142
147
  }
143
148
  };
149
+ /* Focuses the input element in the Dropdown, if the reference is present. */
144
150
  this.focusInputElement = () => {
145
151
  if (this.inputElement)
146
152
  this.inputElement.focus();
147
153
  };
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
+ };
148
181
  this.handleFilter = (event) => {
149
182
  this.tdsInput.emit(event);
150
183
  const query = event.target.value.toLowerCase();
@@ -175,10 +208,8 @@ const TdsDropdown = class {
175
208
  this.handleFilterReset = () => {
176
209
  this.reset();
177
210
  this.inputElement.value = '';
178
- this.handleFilter({ target: { value: '' } });
211
+ this.handleFilter({ target: { value: this.inputElement.value } });
179
212
  this.inputElement.focus();
180
- // Add this line to ensure internal value is cleared
181
- this.internalValue = '';
182
213
  };
183
214
  this.handleFocus = (event) => {
184
215
  this.open = true;
@@ -192,6 +223,12 @@ const TdsDropdown = class {
192
223
  this.handleBlur = (event) => {
193
224
  this.tdsBlur.emit(event);
194
225
  };
226
+ this.handleChange = () => {
227
+ this.tdsChange.emit({
228
+ name: this.name,
229
+ value: this.value ? convertArrayToStrings(this.value).join(',') : null,
230
+ });
231
+ };
195
232
  this.resetInput = () => {
196
233
  const inputEl = this.host.querySelector('input');
197
234
  if (inputEl) {
@@ -214,101 +251,110 @@ const TdsDropdown = class {
214
251
  this.normalizeText = true;
215
252
  this.noResultText = 'No result';
216
253
  this.defaultValue = undefined;
217
- this.value = null;
218
254
  this.open = false;
219
- this.internalValue = undefined;
255
+ this.value = undefined;
220
256
  this.filterResult = undefined;
221
257
  this.filterFocus = undefined;
222
- this.selectedOptions = [];
258
+ this.internalDefaultValue = undefined;
223
259
  }
224
- handleValueChange(newValue) {
225
- // Normalize to array
226
- const normalizedValue = this.normalizeValue(newValue);
227
- // Only update if actually changed
228
- if (this.hasValueChanged(normalizedValue, this.selectedOptions)) {
229
- this.updateDropdownState(normalizedValue);
230
- }
231
- }
232
- normalizeValue(value) {
233
- if (!value || value === '')
234
- return []; // Handle both null and empty string
235
- // For multiselect, keep array. For single select, wrap in array
236
- if (this.multiselect) {
237
- return Array.isArray(value) ? value : value.split(',').filter((v) => v !== '');
238
- }
239
- return Array.isArray(value) ? value : [value];
240
- }
241
- hasValueChanged(newValue, currentValue) {
242
- if (newValue.length !== currentValue.length)
243
- return true;
244
- return newValue.some((val) => !currentValue.includes(val));
260
+ /** Method that resets the Dropdown, marks all children as non-selected and resets the value to null. */
261
+ async reset() {
262
+ this.dropdownList.scrollTop = 0;
263
+ this.internalReset();
264
+ this.handleChange();
245
265
  }
246
- updateDropdownState(values) {
247
- // Update internal state
248
- this.selectedOptions = [...this.validateValues(values)]; // Force new array reference
249
- // Then update the value prop to match
250
- this.value = this.multiselect ? this.selectedOptions : this.selectedOptions[0] || null;
251
- // Force update of internal value
252
- this.internalValue = this.getValue();
253
- // Update DOM
254
- this.updateOptionElements();
255
- // Update display value
256
- this.updateDisplayValue();
257
- // Emit change event
258
- this.emitChange();
259
- // Update value attribute
260
- this.setValueAttribute();
266
+ /** Method that forces focus on the input element. */
267
+ async focusElement() {
268
+ this.focusInputElement();
269
+ this.handleFocus({});
261
270
  }
262
- validateValues(values) {
263
- return values.filter((val) => {
264
- var _a;
265
- const isValid = (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.some((element) => element.value === val);
266
- if (!isValid) {
267
- console.warn(`Option with value "${val}" does not exist`);
271
+ /** Method for setting the value of the Dropdown.
272
+ *
273
+ * Single selection example:
274
+ *
275
+ * <code>
276
+ * dropdown.setValue('option-1', 'Option 1');
277
+ * </code>
278
+ *
279
+ * Multiselect example:
280
+ *
281
+ * <code>
282
+ * dropdown.setValue(['option-1', 'option-2']);
283
+ * </code>
284
+ */
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);
268
306
  }
269
- return isValid;
270
- });
271
- }
272
- updateOptionElements() {
273
- var _a;
274
- (_a = this.getChildren()) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
275
- element.setSelected(this.selectedOptions.includes(element.value));
276
- });
277
- }
278
- updateDisplayValue() {
279
- this.internalValue = this.getSelectedChildrenLabels().join(', ');
280
- if (this.filter && this.inputElement) {
281
- this.inputElement.value = this.internalValue;
282
307
  }
283
- }
284
- emitChange() {
285
- const value = this.multiselect
286
- ? this.selectedOptions.join(',')
287
- : this.selectedOptions[0] || null;
288
- this.tdsChange.emit({
289
- name: this.name,
290
- value: value !== null && value !== void 0 ? value : null,
291
- });
292
- }
293
- async setValue(value) {
294
- const normalizedValue = this.normalizeValue(value);
295
- this.updateDropdownState(normalizedValue);
296
- return this.getSelectedChildren().map((element) => ({
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) => ({
297
315
  value: element.value,
298
316
  label: element.textContent.trim(),
299
317
  }));
318
+ // Update inputElement value and placeholder text
319
+ if (this.filter) {
320
+ this.inputElement.value = this.getValue();
321
+ }
322
+ return selection;
300
323
  }
301
- async reset() {
302
- this.updateDropdownState([]);
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
+ }
303
334
  }
335
+ /** Method for removing a selected value in the Dropdown. */
304
336
  async removeValue(oldValue) {
305
- const newValues = this.selectedOptions.filter((v) => v !== oldValue);
306
- this.updateDropdownState(newValues);
307
- }
308
- /** Method that forces focus on the input element. */
309
- async focusElement() {
310
- this.focusInputElement();
311
- this.handleFocus({});
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 }));
312
358
  }
313
359
  /** Method for closing the Dropdown. */
314
360
  async close() {
@@ -357,15 +403,21 @@ const TdsDropdown = class {
357
403
  handleOpenState() {
358
404
  if (this.filter && this.multiselect) {
359
405
  if (!this.open) {
360
- this.inputElement.value = this.selectedOptions.length ? this.getValue() : '';
406
+ this.inputElement.value = this.getValue();
361
407
  }
362
408
  }
363
409
  }
410
+ handleDefaultValueChange(newValue) {
411
+ if (newValue !== undefined && newValue !== null) {
412
+ this.internalDefaultValue = convertToString(newValue);
413
+ this.setDefaultOption();
414
+ }
415
+ }
364
416
  componentWillLoad() {
365
- if (this.defaultValue && !this.value) {
366
- const initialValue = this.multiselect ? this.defaultValue.split(',') : [this.defaultValue];
367
- this.updateDropdownState(initialValue);
417
+ if (this.defaultValue !== undefined && this.defaultValue !== null) {
418
+ this.internalDefaultValue = convertToString(this.defaultValue);
368
419
  }
420
+ this.setDefaultOption();
369
421
  }
370
422
  /** Method to handle slot changes */
371
423
  handleSlotChange() {
@@ -375,13 +427,29 @@ const TdsDropdown = class {
375
427
  normalizeString(text) {
376
428
  return this.normalizeText ? text.normalize('NFD').replace(/\p{Diacritic}/gu, '') : text;
377
429
  }
378
- async appendValue(value) {
379
- if (this.multiselect) {
380
- this.updateDropdownState([...this.selectedOptions, value]);
381
- }
382
- else {
383
- this.updateDropdownState([value]);
384
- }
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
+ });
385
453
  }
386
454
  componentDidRender() {
387
455
  const form = this.host.closest('form');
@@ -396,8 +464,15 @@ const TdsDropdown = class {
396
464
  }
397
465
  }
398
466
  render() {
399
- appendHiddenInput(this.host, this.name, this.selectedOptions.join(','), this.disabled);
400
- return (index.h(index.Host, { key: 'e61969b03dc211a0007166d7319285cc50207910', role: "select", class: `${this.modeVariant ? `tds-mode-variant-${this.modeVariant}` : ''}` }, this.label && this.labelPosition === 'outside' && (index.h("div", { key: 'd97ce5d02635b30698564226be8c55b477f42de5', class: `label-outside ${this.disabled ? 'disabled' : ''}` }, this.label)), index.h("div", { key: '29099efd6d106a5c6013ac83a545c290bb1d0af7', class: `dropdown-select ${this.size} ${this.disabled ? 'disabled' : ''}` }, this.filter ? (index.h("div", { class: {
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: {
470
+ [`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: {
472
+ 'dropdown-select': true,
473
+ [this.size]: true,
474
+ 'disabled': this.disabled,
475
+ } }, this.filter ? (index.h("div", { class: {
401
476
  filter: true,
402
477
  focus: this.filterFocus,
403
478
  disabled: this.disabled,
@@ -405,16 +480,26 @@ const TdsDropdown = class {
405
480
  } }, 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: `
406
481
  label-inside-as-placeholder
407
482
  ${this.size}
408
- ${this.selectedOptions.length ? 'selected' : ''}
483
+ ${((_a = this.value) === null || _a === void 0 ? void 0 : _a.length) ? 'selected' : ''}
409
484
  ` }, this.label)), index.h("input", {
410
485
  // eslint-disable-next-line no-return-assign
411
- ref: (inputEl) => (this.inputElement = inputEl), class: `${this.labelPosition === 'inside' ? 'placeholder' : ''}`, type: "text", placeholder: this.filterFocus ? '' : this.placeholder, value: this.multiselect && this.filterFocus ? '' : this.getValue(), disabled: this.disabled, onInput: (event) => this.handleFilter(event), onBlur: (event) => {
486
+ ref: (inputEl) => (this.inputElement = inputEl), class: {
487
+ placeholder: this.labelPosition === 'inside',
488
+ }, type: "text", placeholder: this.filterFocus ? '' : this.placeholder, value: this.multiselect && this.filterFocus ? '' : this.getValue(), disabled: this.disabled, onInput: (event) => this.handleFilter(event), onBlur: (event) => {
412
489
  this.filterFocus = false;
413
490
  if (this.multiselect) {
414
491
  this.inputElement.value = this.getValue();
415
492
  }
416
493
  this.handleBlur(event);
417
- }, onFocus: (event) => this.handleFocus(event), onKeyDown: (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) => {
418
503
  if (event.key === 'Escape') {
419
504
  this.open = false;
420
505
  }
@@ -423,7 +508,10 @@ const TdsDropdown = class {
423
508
  if (event.key === 'Enter') {
424
509
  this.handleFilterReset();
425
510
  }
426
- }, class: `clear-icon ${this.open && this.inputElement.value !== '' ? '' : 'hide'}`, name: "cross", size: "16px" }), index.h("tds-icon", { tabIndex: 0, role: "button", "aria-label": "Open/Close dropdown", svgTitle: "Open/Close dropdown", onClick: this.handleToggleOpen, onKeyDown: (event) => {
511
+ }, class: {
512
+ 'clear-icon': true,
513
+ 'hide': !(this.open && this.inputElement.value !== ''),
514
+ }, name: "cross", size: "16px" }), index.h("tds-icon", { tabIndex: 0, role: "button", "aria-label": "Open/Close dropdown", svgTitle: "Open/Close dropdown", onClick: this.handleToggleOpen, onKeyDown: (event) => {
427
515
  if (event.key === 'Enter') {
428
516
  this.handleToggleOpen();
429
517
  }
@@ -431,15 +519,19 @@ const TdsDropdown = class {
431
519
  if (event.key === 'Escape') {
432
520
  this.open = false;
433
521
  }
434
- }, class: `
435
- ${this.selectedOptions.length ? 'value' : 'placeholder'}
436
- ${this.open ? 'open' : 'closed'}
437
- ${this.error ? 'error' : ''}
438
- `, 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: `
439
- label-inside-as-placeholder
440
- ${this.size}
441
- ${this.selectedOptions.length ? 'selected' : ''}
442
- ` }, 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: '04cf1b3b829f482b189a59fb5fd8f9c3932b4982', ref: (element) => (this.dropdownList = element), class: {
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) => {
533
+ this.dropdownList = element;
534
+ }, class: {
443
535
  'dropdown-list': true,
444
536
  [this.size]: true,
445
537
  [this.getOpenDirection()]: true,
@@ -448,12 +540,16 @@ const TdsDropdown = class {
448
540
  'closed': !this.open,
449
541
  [`animation-enter-${this.animation}`]: this.animation !== 'none' && this.open,
450
542
  [`animation-exit-${this.animation}`]: this.animation !== 'none' && !this.open,
451
- } }, index.h("slot", { key: '3dce31c592336d9b5c2e8e5fa25a0a8ff23694d3', onSlotchange: () => this.handleSlotChange() }), this.filterResult === 0 && this.noResultText !== '' && (index.h("div", { key: '7f1e8b0d7fff2f09412f389507ff7c2f2430a70b', class: `no-result ${this.size}` }, this.noResultText))), this.helper && (index.h("div", { key: '0c728acc0d233f674ad7bc394176aa89b01ee66d', class: `helper ${this.error ? 'error' : ''} ${this.disabled ? 'disabled' : ''}` }, this.error && index.h("tds-icon", { key: '65691c3c11f4b6c908028475c03d1f4b6f35ce74', name: "error", size: "16px" }), this.helper))));
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: {
544
+ helper: true,
545
+ error: this.error,
546
+ disabled: this.disabled,
547
+ } }, this.error && index.h("tds-icon", { key: 'ffd574d493f3bbaa37ddc7b14a8372ba4b23bd70', name: "error", size: "16px" }), this.helper))));
452
548
  }
453
549
  get host() { return index.getElement(this); }
454
550
  static get watchers() { return {
455
- "value": ["handleValueChange"],
456
- "open": ["handleOpenState"]
551
+ "open": ["handleOpenState"],
552
+ "defaultValue": ["handleDefaultValueChange"]
457
553
  }; }
458
554
  };
459
555
  TdsDropdown.style = TdsDropdownStyle0;
@@ -479,10 +575,10 @@ const TdsDropdownOption = class {
479
575
  this.handleSingleSelect = () => {
480
576
  if (!this.disabled) {
481
577
  this.selected = true;
482
- this.parentElement.appendValue(this.value);
578
+ this.parentElement.appendValue(this.internalValue);
483
579
  this.parentElement.close();
484
580
  this.tdsSelect.emit({
485
- value: this.value,
581
+ value: this.internalValue,
486
582
  selected: this.selected,
487
583
  });
488
584
  }
@@ -490,18 +586,18 @@ const TdsDropdownOption = class {
490
586
  this.handleMultiselect = (event) => {
491
587
  if (!this.disabled) {
492
588
  if (event.detail.checked) {
493
- this.parentElement.appendValue(this.value);
589
+ this.parentElement.appendValue(this.internalValue);
494
590
  this.selected = true;
495
591
  this.tdsSelect.emit({
496
- value: this.value,
592
+ value: this.internalValue,
497
593
  selected: this.selected,
498
594
  });
499
595
  }
500
596
  else {
501
- this.parentElement.removeValue(this.value);
597
+ this.parentElement.removeValue(this.internalValue);
502
598
  this.selected = false;
503
599
  this.tdsSelect.emit({
504
- value: this.value,
600
+ value: this.internalValue,
505
601
  selected: this.selected,
506
602
  });
507
603
  }
@@ -515,6 +611,7 @@ const TdsDropdownOption = class {
515
611
  this.tdsBlur.emit(event);
516
612
  };
517
613
  this.value = undefined;
614
+ this.internalValue = undefined;
518
615
  this.disabled = false;
519
616
  this.selected = false;
520
617
  this.multiselect = undefined;
@@ -524,8 +621,14 @@ const TdsDropdownOption = class {
524
621
  async setSelected(selected) {
525
622
  this.selected = selected;
526
623
  }
624
+ valueWatcher(newValue) {
625
+ this.internalValue = convertToString(newValue);
626
+ }
627
+ componentWillLoad() {
628
+ this.internalValue = convertToString(this.value);
629
+ }
527
630
  render() {
528
- return (index.h(index.Host, { key: '1cb00a19c5dbcc47e1b2bc97d1d5ccc8ac5a532a', role: "option", "aria-disabled": this.disabled, "aria-selected": this.selected }, index.h("div", { key: '5deaf44c7306f4b1856200bf0a5640e99fcb449d', class: `dropdown-option
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
529
632
  ${this.size}
530
633
  ${this.selected ? 'selected' : ''}
531
634
  ${this.disabled ? 'disabled' : ''}
@@ -543,6 +646,9 @@ const TdsDropdownOption = class {
543
646
  }
544
647
  static get delegatesFocus() { return true; }
545
648
  get host() { return index.getElement(this); }
649
+ static get watchers() { return {
650
+ "value": ["valueWatcher"]
651
+ }; }
546
652
  };
547
653
  TdsDropdownOption.style = TdsDropdownOptionStyle0;
548
654
 
@@ -23,8 +23,10 @@ const TdsFolderTab = class {
23
23
  this.selected = selected;
24
24
  }
25
25
  render() {
26
- return (index.h(index.Host, { key: '37ae53ec0d9c0bc3674365d14d61c6b1fbafe168', role: "listitem" }, index.h("div", { key: 'a977243b499569668ef7428829644f3f2ca23033', class: `${this.disabled ? 'disabled' : ''}
27
- ${this.selected ? 'selected' : ''}`, style: { width: `${this.tabWidth}px` } }, index.h("slot", { key: '1e8b9cc10f032a64ffef70bb061f57ddc8a4a1a5' }))));
26
+ return (index.h(index.Host, { key: '3ebe8719ec0bae1d4de2f698b032d9914f01fc65', role: "listitem" }, index.h("div", { key: '26e4df6a7c2c3ec3cc9b391004b0ecc2e08886ce', class: {
27
+ selected: this.selected,
28
+ disabled: this.disabled,
29
+ }, style: { width: `${this.tabWidth}px` } }, index.h("slot", { key: '78549272532f6fa272660fde77c61464dbede36c' }))));
28
30
  }
29
31
  };
30
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: '3164044436f7029d85c4eed0ff7e0cc2b4e35752', role: "list", class: `${this.modeVariant ? `tds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { key: '59beaa0776ff83a30e84b69c5715a2f0d62ec6d9', class: "wrapper", ref: (el) => {
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) => {
171
171
  this.navWrapperElement = el;
172
- } }, index.h("button", { key: '0bd461d469592983e08043c23e295c21df04c80f', class: `scroll-left-button ${this.showLeftScroll ? 'show' : ''}`, disabled: !this.showLeftScroll, onClick: () => this.scrollLeft() }, index.h("tds-icon", { key: 'd21448eea9cab4d73087fec72d29270b52bf0999', name: "chevron_left", size: "20px" })), index.h("slot", { key: 'efe348a98b964486a73d1aac235ce894277c6249', onSlotchange: () => this.handleSlotChange() }), index.h("button", { key: 'ea819f59668994e328410941b5b7455620ecb321', class: `scroll-right-button ${this.showRightScroll ? 'show' : ''}`, disabled: !this.showRightScroll, onClick: () => this.scrollRight() }, index.h("tds-icon", { key: 'c52241bb7c77eabbdb8de5a19bb4400c32aa2062', name: "chevron_right", size: "20px" })))));
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" })))));
173
173
  }
174
174
  get host() { return index.getElement(this); }
175
175
  static get watchers() { return {