@scania/tegel 1.24.0-value-prop.beta.6 → 1.25.0-fix-a11y-checkbox-beta.1

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