@scania/tegel 0.0.9 → 0.0.10

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 (528) hide show
  1. package/README.md +3 -0
  2. package/dist/cjs/index-ee36ffa1.js +8 -16
  3. package/dist/cjs/loader.cjs.js +1 -1
  4. package/dist/cjs/{popper-9def2535.js → popper-d7adcfc6.js} +6 -12
  5. package/dist/cjs/tds-accordion-item.cjs.entry.js +1 -1
  6. package/dist/cjs/tds-badge.cjs.entry.js +3 -3
  7. package/dist/cjs/tds-banner.cjs.entry.js +10 -10
  8. package/dist/cjs/tds-breadcrumb.cjs.entry.js +2 -4
  9. package/dist/cjs/tds-breadcrumbs.cjs.entry.js +0 -3
  10. package/dist/cjs/tds-button.cjs.entry.js +4 -11
  11. package/dist/cjs/tds-card.cjs.entry.js +19 -23
  12. package/dist/cjs/tds-checkbox.cjs.entry.js +2 -1
  13. package/dist/cjs/tds-chip.cjs.entry.js +14 -3
  14. package/dist/cjs/tds-core-header-item_2.cjs.entry.js +1 -1
  15. package/dist/cjs/{tds-dropdown-option-v2.cjs.entry.js → tds-dropdown-option.cjs.entry.js} +5 -5
  16. package/dist/cjs/{tds-dropdown-v2.cjs.entry.js → tds-dropdown.cjs.entry.js} +19 -19
  17. package/dist/cjs/tds-folder-tab.cjs.entry.js +2 -3
  18. package/dist/cjs/tds-folder-tabs.cjs.entry.js +5 -5
  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 +6 -6
  22. package/dist/cjs/tds-header-cell.cjs.entry.js +1 -1
  23. package/dist/cjs/tds-header-dropdown-list-user.cjs.entry.js +4 -4
  24. package/dist/cjs/tds-header-dropdown-list.cjs.entry.js +1 -1
  25. package/dist/cjs/tds-header-dropdown.cjs.entry.js +4 -3
  26. package/dist/cjs/tds-header-hamburger.cjs.entry.js +1 -1
  27. package/dist/cjs/tds-header-launcher-button.cjs.entry.js +1 -1
  28. package/dist/cjs/tds-header-launcher-grid-title.cjs.entry.js +3 -2
  29. package/dist/cjs/tds-header-launcher-grid.cjs.entry.js +1 -1
  30. package/dist/cjs/tds-header-launcher-list-title.cjs.entry.js +3 -2
  31. package/dist/cjs/tds-header-launcher-list.cjs.entry.js +2 -1
  32. package/dist/cjs/tds-header-launcher.cjs.entry.js +2 -2
  33. package/dist/cjs/tds-header.cjs.entry.js +1 -1
  34. package/dist/cjs/tds-inline-tab.cjs.entry.js +1 -1
  35. package/dist/cjs/tds-inline-tabs.cjs.entry.js +5 -5
  36. package/dist/cjs/tds-link.cjs.entry.js +1 -1
  37. package/dist/cjs/tds-message.cjs.entry.js +4 -4
  38. package/dist/cjs/tds-modal.cjs.entry.js +13 -5
  39. package/dist/cjs/tds-navigation-tab.cjs.entry.js +1 -1
  40. package/dist/cjs/tds-navigation-tabs.cjs.entry.js +5 -5
  41. package/dist/cjs/tds-popover-canvas.cjs.entry.js +1 -1
  42. package/dist/cjs/tds-popover-menu.cjs.entry.js +1 -1
  43. package/dist/cjs/tds-radio-button.cjs.entry.js +3 -2
  44. package/dist/cjs/tds-side-menu-close-button.cjs.entry.js +1 -1
  45. package/dist/cjs/tds-side-menu-dropdown.cjs.entry.js +1 -1
  46. package/dist/cjs/tds-side-menu-item.cjs.entry.js +1 -1
  47. package/dist/cjs/tds-side-menu.cjs.entry.js +2 -2
  48. package/dist/cjs/tds-slider.cjs.entry.js +12 -15
  49. package/dist/cjs/tds-stepper.cjs.entry.js +3 -2
  50. package/dist/cjs/tds-table-body.cjs.entry.js +4 -51
  51. package/dist/cjs/tds-table-footer.cjs.entry.js +47 -39
  52. package/dist/cjs/tds-table-toolbar.cjs.entry.js +2 -2
  53. package/dist/cjs/tds-table.cjs.entry.js +2 -1
  54. package/dist/cjs/tds-text-field.cjs.entry.js +6 -2
  55. package/dist/cjs/tds-toast.cjs.entry.js +11 -26
  56. package/dist/cjs/tds-toggle.cjs.entry.js +2 -1
  57. package/dist/cjs/tds-tooltip.cjs.entry.js +6 -2
  58. package/dist/cjs/tegel.cjs.js +1 -1
  59. package/dist/cjs/{utils-2beb1aa0.js → utils-41de5fb2.js} +32 -12
  60. package/dist/collection/collection-manifest.json +0 -3
  61. package/dist/collection/components/accordion/accordion-item/accordion-item.js +4 -1
  62. package/dist/collection/components/accordion/accordion.stories.js +100 -0
  63. package/dist/collection/components/badge/badge.js +4 -4
  64. package/dist/collection/components/badge/badge.stories.js +106 -0
  65. package/dist/collection/components/banner/banner.css +12 -9
  66. package/dist/collection/components/banner/banner.js +33 -17
  67. package/dist/collection/components/banner/banner.stories.js +107 -0
  68. package/dist/collection/components/block/block.stories.js +49 -0
  69. package/dist/collection/components/breadcrumbs/breadcrumb/breadcrumb.css +4 -4
  70. package/dist/collection/components/breadcrumbs/breadcrumb/breadcrumb.js +1 -21
  71. package/dist/collection/components/breadcrumbs/breadcrumbs.js +0 -3
  72. package/dist/collection/components/breadcrumbs/breadcrumbs.stories.js +36 -0
  73. package/dist/collection/components/button/button.css +16 -0
  74. package/dist/collection/components/button/button.js +7 -12
  75. package/dist/collection/components/button/button.stories.js +167 -0
  76. package/dist/collection/components/card/card.css +18 -17
  77. package/dist/collection/components/card/card.js +32 -68
  78. package/dist/collection/components/card/card.stories.js +162 -0
  79. package/dist/collection/components/checkbox/checkbox.js +6 -2
  80. package/dist/collection/components/checkbox/checkbox.stories.js +80 -0
  81. package/dist/collection/components/chip/chip.css +23 -8
  82. package/dist/collection/components/chip/chip.js +19 -3
  83. package/dist/collection/components/chip/chip.stories.js +230 -0
  84. package/dist/collection/components/datetime/datetime.stories.js +195 -0
  85. package/dist/collection/components/divider/divider.stories.js +62 -0
  86. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +142 -116
  87. package/dist/collection/components/dropdown/dropdown.css +212 -386
  88. package/dist/collection/components/dropdown/dropdown.js +472 -329
  89. package/dist/collection/components/dropdown/dropdown.stories.js +268 -0
  90. package/dist/collection/components/footer/footer-group/footer-group.css +3 -3
  91. package/dist/collection/components/footer/footer-group/footer-group.js +2 -2
  92. package/dist/collection/components/footer/footer-item/footer-item.css +16 -8
  93. package/dist/collection/components/footer/footer.css +8 -12
  94. package/dist/collection/components/footer/footer.js +10 -10
  95. package/dist/collection/components/footer/footer.stories.js +145 -0
  96. package/dist/collection/components/header/header-dropdown/header-dropdown.js +10 -5
  97. package/dist/collection/components/header/header-dropdown-list-user/header-dropdown-list-user.css +1 -1
  98. package/dist/collection/components/header/header-dropdown-list-user/header-dropdown-list-user.js +13 -9
  99. package/dist/collection/components/header/header-hamburger/header-hamburger.css +0 -1
  100. package/dist/collection/components/header/header-launcher/header-launcher.js +2 -2
  101. package/dist/collection/components/header/header-launcher-grid-title/header-launcher-grid-title.js +3 -2
  102. package/dist/collection/components/header/header-launcher-list/header-launcher-list.js +2 -1
  103. package/dist/collection/components/header/header-launcher-list-title/header-launcher-list-title.js +3 -2
  104. package/dist/collection/components/header/header.css +1 -1
  105. package/dist/collection/components/header/header.js +5 -0
  106. package/dist/collection/components/header/header.stories.js +80 -0
  107. package/dist/collection/components/icon/icon.stories.js +48 -0
  108. package/dist/collection/components/link/link.css +16 -13
  109. package/dist/collection/components/link/link.js +1 -0
  110. package/dist/collection/components/link/link.stories.js +57 -0
  111. package/dist/collection/components/message/message.css +16 -16
  112. package/dist/collection/components/message/message.js +6 -3
  113. package/dist/collection/components/message/message.stories.js +110 -0
  114. package/dist/collection/components/modal/modal.css +19 -33
  115. package/dist/collection/components/modal/modal.js +36 -6
  116. package/dist/collection/components/modal/modal.stories.js +109 -0
  117. package/dist/collection/components/popover-canvas/popover-canvas.js +2 -2
  118. package/dist/collection/components/popover-canvas/popover-canvas.stories.js +92 -0
  119. package/dist/collection/components/popover-menu/popover-menu.js +2 -2
  120. package/dist/collection/components/popover-menu/popover-menu.stories.js +140 -0
  121. package/dist/collection/components/radio-button/radio-button.css +1 -1
  122. package/dist/collection/components/radio-button/radio-button.js +6 -2
  123. package/dist/collection/components/radio-button/radio-button.stories.js +91 -0
  124. package/dist/collection/components/side-menu/side-menu-collapse-button/side-menu-collapse-button.js +3 -0
  125. package/dist/collection/components/side-menu/side-menu-dropdown/side-menu-dropdown.css +1 -1
  126. package/dist/collection/components/side-menu/side-menu-dropdown/side-menu-dropdown.js +5 -0
  127. package/dist/collection/components/side-menu/side-menu-dropdown-list/side-menu-dropdown-list.js +3 -0
  128. package/dist/collection/components/side-menu/side-menu-dropdown-list-item/side-menu-dropdown-list-item.js +3 -0
  129. package/dist/collection/components/side-menu/side-menu-item/side-menu-item.css +1 -1
  130. package/dist/collection/components/side-menu/side-menu-item/side-menu-item.js +3 -0
  131. package/dist/collection/components/side-menu/side-menu-user/side-menu-user.js +3 -0
  132. package/dist/collection/components/side-menu/side-menu-user-image/side-menu-user-image.js +5 -0
  133. package/dist/collection/components/side-menu/side-menu.css +6 -5
  134. package/dist/collection/components/side-menu/side-menu.js +11 -3
  135. package/dist/collection/components/side-menu/side-menu.stories.js +215 -0
  136. package/dist/collection/components/slider/slider.js +13 -16
  137. package/dist/collection/components/slider/slider.stories.js +243 -0
  138. package/dist/collection/components/spinner/spinner.stories.js +61 -0
  139. package/dist/collection/components/stepper/step/step.js +3 -0
  140. package/dist/collection/components/stepper/stepper.css +3 -0
  141. package/dist/collection/components/stepper/stepper.js +4 -3
  142. package/dist/collection/components/stepper/stepper.stories.js +95 -0
  143. package/dist/collection/components/table/table/table.js +4 -3
  144. package/dist/collection/components/table/table-body/table-body.js +15 -60
  145. package/dist/collection/components/table/table-body-row-expandable/table-body-row-expandable.js +3 -0
  146. package/dist/collection/components/table/table-component-basic.stories.js +184 -0
  147. package/dist/collection/components/table/table-component-batch-actions.stories.js +201 -0
  148. package/dist/collection/components/table/table-component-bodydata.stories.js +101 -0
  149. package/dist/collection/components/table/table-component-custom-width.stories.js +174 -0
  150. package/dist/collection/components/table/table-component-event-listeners.stories.js +193 -0
  151. package/dist/collection/components/table/table-component-expandable-rows.stories.js +160 -0
  152. package/dist/collection/components/table/table-component-filtering.stories.js +210 -0
  153. package/dist/collection/components/table/table-component-multiselect.stories.js +230 -0
  154. package/dist/collection/components/table/table-component-pagination.stories.js +215 -0
  155. package/dist/collection/components/table/table-component-sorting.stories.js +238 -0
  156. package/dist/collection/components/table/table-footer/table-footer.js +65 -54
  157. package/dist/collection/components/table/table-header-cell/table-header-cell.css +1 -0
  158. package/dist/collection/components/table/table-toolbar/table-toolbar.css +2 -1
  159. package/dist/collection/components/table/table-toolbar/table-toolbar.js +4 -1
  160. package/dist/collection/components/table/table.filtering.spec.js +0 -6
  161. package/dist/collection/components/table/table.spec.js +0 -6
  162. package/dist/collection/components/tabs/folder-tabs/folder-tab/folder-tab.css +10 -11
  163. package/dist/collection/components/tabs/folder-tabs/folder-tab/folder-tab.js +1 -2
  164. package/dist/collection/components/tabs/folder-tabs/folder-tabs.js +5 -5
  165. package/dist/collection/components/tabs/folder-tabs/folder-tabs.stories.js +105 -0
  166. package/dist/collection/components/tabs/inline-tabs/inline-tab/inline-tab.css +13 -2
  167. package/dist/collection/components/tabs/inline-tabs/inline-tabs.js +5 -5
  168. package/dist/collection/components/tabs/inline-tabs/inline-tabs.stories.js +99 -0
  169. package/dist/collection/components/tabs/navigation-tabs/navigation-tab/navigation-tab.css +13 -2
  170. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +5 -5
  171. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js +101 -0
  172. package/dist/collection/components/text-field/text-field.js +10 -2
  173. package/dist/collection/components/text-field/text-field.stories.js +247 -0
  174. package/dist/collection/components/textarea/textarea.stories.js +188 -0
  175. package/dist/collection/components/toast/toast.css +32 -25
  176. package/dist/collection/components/toast/toast.js +17 -33
  177. package/dist/collection/components/toast/toast.stories.js +79 -0
  178. package/dist/collection/components/toggle/toggle.js +6 -2
  179. package/dist/collection/components/toggle/toggle.stories.js +95 -0
  180. package/dist/collection/components/tooltip/tooltip.js +27 -3
  181. package/dist/collection/components/tooltip/tooltip.stories.js +128 -0
  182. package/dist/collection/stories/Installation/installation.stories.js +222 -0
  183. package/dist/collection/stories/announcements/announce-tegel.stories.js +262 -0
  184. package/dist/collection/stories/announcements/prefix-change.stories.js +93 -0
  185. package/dist/collection/stories/foundations/color/color-brand.stories.js +38 -0
  186. package/dist/collection/stories/foundations/color/color-scales.stories.js +71 -0
  187. package/dist/collection/stories/foundations/color/color-semantic.stories.js +40 -0
  188. package/dist/collection/stories/foundations/grid/grid.stories.js +386 -0
  189. package/dist/collection/stories/foundations/spacing/spacing-element.stories.js +100 -0
  190. package/dist/collection/stories/foundations/spacing/spacing-layout.stories.js +94 -0
  191. package/dist/collection/stories/foundations/typography/typography-body.stories.js +16 -0
  192. package/dist/collection/stories/foundations/typography/typography-detail.stories.js +17 -0
  193. package/dist/collection/stories/foundations/typography/typography-headline.stories.js +39 -0
  194. package/dist/collection/stories/foundations/typography/typography-paragraph.stories.js +12 -0
  195. package/dist/collection/stories/patterns/navigation/navigation-basic.stories.js +85 -0
  196. package/dist/collection/stories/patterns/navigation/navigation-fewitems.stories.js +259 -0
  197. package/dist/collection/stories/patterns/navigation/navigation-manyitems.stories.js +246 -0
  198. package/dist/collection/stories/patterns/navigation/navigation-user-menu.stories.js +140 -0
  199. package/dist/collection/stories/tegel.stories.js +293 -0
  200. package/dist/collection/stories/utility/color/background-color.stories.js +96 -0
  201. package/dist/collection/stories/utility/color/text-color.stories.js +94 -0
  202. package/dist/collection/utils/utils.js +30 -11
  203. package/dist/components/checkbox.js +2 -1
  204. package/dist/components/header-dropdown-list.js +1 -1
  205. package/dist/components/header-item.js +1 -1
  206. package/dist/components/popper.js +6 -12
  207. package/dist/components/side-menu-item.js +1 -1
  208. package/dist/components/tds-accordion-item.js +1 -1
  209. package/dist/components/tds-badge.js +4 -4
  210. package/dist/components/tds-banner.js +12 -13
  211. package/dist/components/tds-breadcrumb.js +3 -6
  212. package/dist/components/tds-breadcrumbs.js +0 -3
  213. package/dist/components/tds-button.js +5 -13
  214. package/dist/components/tds-card.js +21 -29
  215. package/dist/components/tds-chip.js +14 -3
  216. package/dist/components/tds-dropdown-option.js +121 -1
  217. package/dist/components/tds-dropdown.js +318 -1
  218. package/dist/components/tds-folder-tab.js +2 -3
  219. package/dist/components/tds-folder-tabs.js +5 -5
  220. package/dist/components/tds-footer-group.js +3 -3
  221. package/dist/components/tds-footer-item.js +1 -1
  222. package/dist/components/tds-footer.js +7 -8
  223. package/dist/components/tds-header-cell.js +1 -1
  224. package/dist/components/tds-header-dropdown-list-user.js +6 -6
  225. package/dist/components/tds-header-dropdown.js +5 -4
  226. package/dist/components/tds-header-launcher-grid-title.js +3 -2
  227. package/dist/components/tds-header-launcher-grid.js +1 -1
  228. package/dist/components/tds-header-launcher-list-title.js +3 -2
  229. package/dist/components/tds-header-launcher-list.js +2 -1
  230. package/dist/components/tds-header-launcher.js +2 -2
  231. package/dist/components/tds-inline-tab.js +1 -1
  232. package/dist/components/tds-inline-tabs.js +5 -5
  233. package/dist/components/tds-link.js +3 -2
  234. package/dist/components/tds-message.js +4 -4
  235. package/dist/components/tds-modal.js +14 -5
  236. package/dist/components/tds-navigation-tab.js +1 -1
  237. package/dist/components/tds-navigation-tabs.js +5 -5
  238. package/dist/components/tds-radio-button.js +3 -2
  239. package/dist/components/tds-side-menu-dropdown.js +1 -1
  240. package/dist/components/tds-side-menu.js +2 -2
  241. package/dist/components/tds-slider.js +12 -15
  242. package/dist/components/tds-stepper.js +3 -2
  243. package/dist/components/tds-table-body.js +5 -53
  244. package/dist/components/tds-table-footer.js +50 -42
  245. package/dist/components/tds-table-toolbar.js +9 -3
  246. package/dist/components/tds-table.js +2 -1
  247. package/dist/components/tds-text-field.js +6 -2
  248. package/dist/components/tds-toast.js +12 -29
  249. package/dist/components/tds-toggle.js +2 -1
  250. package/dist/components/tds-tooltip.js +7 -2
  251. package/dist/components/utils.js +31 -12
  252. package/dist/esm/index-23ee700b.js +8 -16
  253. package/dist/esm/loader.js +1 -1
  254. package/dist/esm/{popper-bfa25c7f.js → popper-15e448b4.js} +6 -12
  255. package/dist/esm/tds-accordion-item.entry.js +1 -1
  256. package/dist/esm/tds-badge.entry.js +3 -3
  257. package/dist/esm/tds-banner.entry.js +10 -10
  258. package/dist/esm/tds-breadcrumb.entry.js +2 -4
  259. package/dist/esm/tds-breadcrumbs.entry.js +0 -3
  260. package/dist/esm/tds-button.entry.js +4 -11
  261. package/dist/esm/tds-card.entry.js +19 -23
  262. package/dist/esm/tds-checkbox.entry.js +2 -1
  263. package/dist/esm/tds-chip.entry.js +15 -4
  264. package/dist/esm/tds-core-header-item_2.entry.js +1 -1
  265. package/dist/esm/{tds-dropdown-option-v2.entry.js → tds-dropdown-option.entry.js} +5 -5
  266. package/dist/esm/{tds-dropdown-v2.entry.js → tds-dropdown.entry.js} +19 -19
  267. package/dist/esm/tds-folder-tab.entry.js +2 -3
  268. package/dist/esm/tds-folder-tabs.entry.js +5 -5
  269. package/dist/esm/tds-footer-group.entry.js +3 -3
  270. package/dist/esm/tds-footer-item.entry.js +1 -1
  271. package/dist/esm/tds-footer.entry.js +6 -6
  272. package/dist/esm/tds-header-cell.entry.js +1 -1
  273. package/dist/esm/tds-header-dropdown-list-user.entry.js +4 -4
  274. package/dist/esm/tds-header-dropdown-list.entry.js +1 -1
  275. package/dist/esm/tds-header-dropdown.entry.js +4 -3
  276. package/dist/esm/tds-header-hamburger.entry.js +1 -1
  277. package/dist/esm/tds-header-launcher-button.entry.js +1 -1
  278. package/dist/esm/tds-header-launcher-grid-title.entry.js +3 -2
  279. package/dist/esm/tds-header-launcher-grid.entry.js +1 -1
  280. package/dist/esm/tds-header-launcher-list-title.entry.js +3 -2
  281. package/dist/esm/tds-header-launcher-list.entry.js +2 -1
  282. package/dist/esm/tds-header-launcher.entry.js +2 -2
  283. package/dist/esm/tds-header.entry.js +1 -1
  284. package/dist/esm/tds-inline-tab.entry.js +1 -1
  285. package/dist/esm/tds-inline-tabs.entry.js +5 -5
  286. package/dist/esm/tds-link.entry.js +1 -1
  287. package/dist/esm/tds-message.entry.js +4 -4
  288. package/dist/esm/tds-modal.entry.js +13 -5
  289. package/dist/esm/tds-navigation-tab.entry.js +1 -1
  290. package/dist/esm/tds-navigation-tabs.entry.js +5 -5
  291. package/dist/esm/tds-popover-canvas.entry.js +1 -1
  292. package/dist/esm/tds-popover-menu.entry.js +1 -1
  293. package/dist/esm/tds-radio-button.entry.js +3 -2
  294. package/dist/esm/tds-side-menu-close-button.entry.js +1 -1
  295. package/dist/esm/tds-side-menu-dropdown.entry.js +1 -1
  296. package/dist/esm/tds-side-menu-item.entry.js +1 -1
  297. package/dist/esm/tds-side-menu.entry.js +2 -2
  298. package/dist/esm/tds-slider.entry.js +12 -15
  299. package/dist/esm/tds-stepper.entry.js +3 -2
  300. package/dist/esm/tds-table-body.entry.js +4 -51
  301. package/dist/esm/tds-table-footer.entry.js +47 -39
  302. package/dist/esm/tds-table-toolbar.entry.js +2 -2
  303. package/dist/esm/tds-table.entry.js +2 -1
  304. package/dist/esm/tds-text-field.entry.js +7 -3
  305. package/dist/esm/tds-toast.entry.js +11 -26
  306. package/dist/esm/tds-toggle.entry.js +2 -1
  307. package/dist/esm/tds-tooltip.entry.js +6 -2
  308. package/dist/esm/tegel.js +1 -1
  309. package/dist/esm/{utils-9ac24735.js → utils-74fb1bed.js} +31 -12
  310. package/dist/tegel/p-000d60e5.entry.js +1 -0
  311. package/dist/tegel/p-04bff255.entry.js +1 -0
  312. package/dist/tegel/p-06093e3e.entry.js +1 -0
  313. package/dist/tegel/p-099025f0.entry.js +1 -0
  314. package/dist/tegel/p-0995ca77.entry.js +1 -0
  315. package/dist/tegel/p-10337d3f.entry.js +1 -0
  316. package/dist/tegel/p-19fb9ad5.entry.js +1 -0
  317. package/dist/tegel/p-1bac7d2e.entry.js +1 -0
  318. package/dist/tegel/p-1c82ccf0.entry.js +1 -0
  319. package/dist/tegel/p-347414ad.entry.js +1 -0
  320. package/dist/tegel/p-34a06d2f.entry.js +1 -0
  321. package/dist/tegel/p-3c9865c3.entry.js +1 -0
  322. package/dist/tegel/{p-c8d4af09.entry.js → p-40142a58.entry.js} +1 -1
  323. package/dist/tegel/p-48136431.entry.js +1 -0
  324. package/dist/tegel/p-49a084db.entry.js +1 -0
  325. package/dist/tegel/p-4c809685.entry.js +1 -0
  326. package/dist/tegel/p-54e56257.entry.js +1 -0
  327. package/dist/tegel/{p-e8fccebc.entry.js → p-56189659.entry.js} +1 -1
  328. package/dist/tegel/p-6bee84a2.entry.js +1 -0
  329. package/dist/tegel/p-6f0072cc.entry.js +1 -0
  330. package/dist/tegel/p-73a8f43e.entry.js +1 -0
  331. package/dist/tegel/p-8ba77ea3.entry.js +1 -0
  332. package/dist/tegel/p-8bd0a233.entry.js +1 -0
  333. package/dist/tegel/{p-e0ee20ee.entry.js → p-8c194dd8.entry.js} +1 -1
  334. package/dist/tegel/p-95e170f3.entry.js +1 -0
  335. package/dist/tegel/p-99837611.entry.js +1 -0
  336. package/dist/tegel/p-9991a816.entry.js +1 -0
  337. package/dist/tegel/{p-bcb2fad3.entry.js → p-9b29bf68.entry.js} +1 -1
  338. package/dist/tegel/{p-39227588.js → p-9dc14c21.js} +1 -1
  339. package/dist/tegel/p-9f1e1cc0.entry.js +1 -0
  340. package/dist/tegel/{p-232f5889.entry.js → p-9fe0d654.entry.js} +1 -1
  341. package/dist/tegel/{p-135575ae.entry.js → p-a08be1c3.entry.js} +1 -1
  342. package/dist/tegel/{p-3aa634ed.entry.js → p-a1ad46d2.entry.js} +1 -1
  343. package/dist/tegel/p-a34bb501.entry.js +1 -0
  344. package/dist/tegel/p-a4e3eb95.entry.js +1 -0
  345. package/dist/tegel/{p-fb3f4a14.entry.js → p-aa443b06.entry.js} +1 -1
  346. package/dist/tegel/p-afe13096.entry.js +1 -0
  347. package/dist/tegel/{p-cd2a74d7.entry.js → p-b0d313cd.entry.js} +1 -1
  348. package/dist/tegel/p-b1067b50.entry.js +1 -0
  349. package/dist/tegel/{p-7b34156b.entry.js → p-b5424456.entry.js} +1 -1
  350. package/dist/tegel/p-c15bbe0b.entry.js +1 -0
  351. package/dist/tegel/p-c411f254.entry.js +1 -0
  352. package/dist/tegel/p-c5588508.entry.js +1 -0
  353. package/dist/tegel/{p-b6a16219.entry.js → p-c5ab3a3b.entry.js} +1 -1
  354. package/dist/tegel/p-d5bd9b2e.entry.js +1 -0
  355. package/dist/tegel/p-df95f0ae.entry.js +1 -0
  356. package/dist/tegel/{p-de799b9a.entry.js → p-e24835ba.entry.js} +1 -1
  357. package/dist/tegel/p-e3f8fc68.entry.js +1 -0
  358. package/dist/tegel/{p-89283891.entry.js → p-e4dc07bb.entry.js} +1 -1
  359. package/dist/tegel/p-f36ec03b.entry.js +1 -0
  360. package/dist/tegel/{p-7331ec7b.entry.js → p-f795bc11.entry.js} +1 -1
  361. package/dist/tegel/{p-7d3a66ae.entry.js → p-f9d04ff2.entry.js} +1 -1
  362. package/dist/tegel/p-fc6da19c.entry.js +1 -0
  363. package/dist/tegel/tegel.css +2 -2
  364. package/dist/tegel/tegel.esm.js +1 -1
  365. package/dist/types/components/accordion/accordion-item/accordion-item.d.ts +3 -0
  366. package/dist/types/components/accordion/accordion.stories.d.ts +77 -0
  367. package/dist/types/components/badge/badge.stories.d.ts +73 -0
  368. package/dist/types/components/banner/banner.d.ts +7 -2
  369. package/dist/types/components/banner/banner.stories.d.ts +82 -0
  370. package/dist/types/components/block/block.stories.d.ts +32 -0
  371. package/dist/types/components/breadcrumbs/breadcrumb/breadcrumb.d.ts +0 -2
  372. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +0 -1
  373. package/dist/types/components/breadcrumbs/breadcrumbs.stories.d.ts +16 -0
  374. package/dist/types/components/button/button.d.ts +3 -1
  375. package/dist/types/components/button/button.stories.d.ts +133 -0
  376. package/dist/types/components/card/card.d.ts +11 -9
  377. package/dist/types/components/card/card.stories.d.ts +128 -0
  378. package/dist/types/components/checkbox/checkbox.d.ts +3 -0
  379. package/dist/types/components/checkbox/checkbox.stories.d.ts +52 -0
  380. package/dist/types/components/chip/chip.d.ts +6 -0
  381. package/dist/types/components/chip/chip.stories.d.ts +99 -0
  382. package/dist/types/components/datetime/datetime.stories.d.ts +125 -0
  383. package/dist/types/components/divider/divider.stories.d.ts +58 -0
  384. package/dist/types/components/dropdown/dropdown-option/dropdown-option.d.ts +28 -17
  385. package/dist/types/components/dropdown/dropdown.d.ts +79 -54
  386. package/dist/types/components/dropdown/dropdown.stories.d.ts +183 -0
  387. package/dist/types/components/footer/footer-group/footer-group.d.ts +1 -1
  388. package/dist/types/components/footer/footer.d.ts +5 -3
  389. package/dist/types/components/footer/footer.stories.d.ts +44 -0
  390. package/dist/types/components/header/header-dropdown/header-dropdown.d.ts +5 -1
  391. package/dist/types/components/header/header-dropdown-list-user/header-dropdown-list-user.d.ts +8 -4
  392. package/dist/types/components/header/header.d.ts +5 -0
  393. package/dist/types/components/header/header.stories.d.ts +31 -0
  394. package/dist/types/components/icon/icon.stories.d.ts +36 -0
  395. package/dist/types/components/link/link.stories.d.ts +44 -0
  396. package/dist/types/components/message/message.d.ts +3 -0
  397. package/dist/types/components/message/message.stories.d.ts +88 -0
  398. package/dist/types/components/modal/modal.d.ts +9 -3
  399. package/dist/types/components/modal/modal.stories.d.ts +70 -0
  400. package/dist/types/components/popover-canvas/popover-canvas.d.ts +1 -1
  401. package/dist/types/components/popover-canvas/popover-canvas.stories.d.ts +27 -0
  402. package/dist/types/components/popover-menu/popover-menu.d.ts +1 -1
  403. package/dist/types/components/popover-menu/popover-menu.stories.d.ts +40 -0
  404. package/dist/types/components/radio-button/radio-button.d.ts +3 -0
  405. package/dist/types/components/radio-button/radio-button.stories.d.ts +39 -0
  406. package/dist/types/components/side-menu/side-menu-collapse-button/side-menu-collapse-button.d.ts +3 -0
  407. package/dist/types/components/side-menu/side-menu-dropdown/side-menu-dropdown.d.ts +5 -0
  408. package/dist/types/components/side-menu/side-menu-dropdown-list/side-menu-dropdown-list.d.ts +3 -0
  409. package/dist/types/components/side-menu/side-menu-dropdown-list-item/side-menu-dropdown-list-item.d.ts +3 -0
  410. package/dist/types/components/side-menu/side-menu-item/side-menu-item.d.ts +3 -0
  411. package/dist/types/components/side-menu/side-menu-user/side-menu-user.d.ts +3 -0
  412. package/dist/types/components/side-menu/side-menu-user-image/side-menu-user-image.d.ts +4 -0
  413. package/dist/types/components/side-menu/side-menu.d.ts +8 -0
  414. package/dist/types/components/side-menu/side-menu.stories.d.ts +53 -0
  415. package/dist/types/components/slider/slider.d.ts +0 -1
  416. package/dist/types/components/slider/slider.stories.d.ts +235 -0
  417. package/dist/types/components/spinner/spinner.stories.d.ts +46 -0
  418. package/dist/types/components/stepper/step/step.d.ts +3 -0
  419. package/dist/types/components/stepper/stepper.stories.d.ts +80 -0
  420. package/dist/types/components/table/table-body/table-body.d.ts +6 -3
  421. package/dist/types/components/table/table-body-row-expandable/table-body-row-expandable.d.ts +3 -0
  422. package/dist/types/components/table/table-component-basic.stories.d.ts +144 -0
  423. package/dist/types/components/table/table-component-batch-actions.stories.d.ts +139 -0
  424. package/dist/types/components/table/table-component-bodydata.stories.d.ts +35 -0
  425. package/dist/types/components/table/table-component-custom-width.stories.d.ts +131 -0
  426. package/dist/types/components/table/table-component-event-listeners.stories.d.ts +131 -0
  427. package/dist/types/components/table/table-component-expandable-rows.stories.d.ts +131 -0
  428. package/dist/types/components/table/table-component-filtering.stories.d.ts +139 -0
  429. package/dist/types/components/table/table-component-multiselect.stories.d.ts +144 -0
  430. package/dist/types/components/table/table-component-pagination.stories.d.ts +131 -0
  431. package/dist/types/components/table/table-component-sorting.stories.d.ts +183 -0
  432. package/dist/types/components/table/table-footer/table-footer.d.ts +7 -7
  433. package/dist/types/components/table/table-toolbar/table-toolbar.d.ts +3 -0
  434. package/dist/types/components/tabs/folder-tabs/folder-tabs.stories.d.ts +69 -0
  435. package/dist/types/components/tabs/inline-tabs/inline-tabs.stories.d.ts +61 -0
  436. package/dist/types/components/tabs/navigation-tabs/navigation-tabs.stories.d.ts +61 -0
  437. package/dist/types/components/text-field/text-field.d.ts +5 -0
  438. package/dist/types/components/text-field/text-field.stories.d.ts +201 -0
  439. package/dist/types/components/textarea/textarea.stories.d.ts +139 -0
  440. package/dist/types/components/toast/toast.d.ts +5 -4
  441. package/dist/types/components/toast/toast.stories.d.ts +56 -0
  442. package/dist/types/components/toggle/toggle.d.ts +3 -0
  443. package/dist/types/components/toggle/toggle.stories.d.ts +74 -0
  444. package/dist/types/components/tooltip/tooltip.d.ts +3 -1
  445. package/dist/types/components/tooltip/tooltip.stories.d.ts +66 -0
  446. package/dist/types/components.d.ts +105 -393
  447. package/dist/types/stories/Installation/installation.stories.d.ts +7 -0
  448. package/dist/types/stories/announcements/announce-tegel.stories.d.ts +6 -0
  449. package/dist/types/stories/announcements/prefix-change.stories.d.ts +6 -0
  450. package/dist/types/stories/foundations/color/color-brand.stories.d.ts +13 -0
  451. package/dist/types/stories/foundations/color/color-scales.stories.d.ts +30 -0
  452. package/dist/types/stories/foundations/color/color-semantic.stories.d.ts +13 -0
  453. package/dist/types/stories/foundations/grid/grid.stories.d.ts +35 -0
  454. package/dist/types/stories/foundations/spacing/spacing-element.stories.d.ts +8 -0
  455. package/dist/types/stories/foundations/spacing/spacing-layout.stories.d.ts +8 -0
  456. package/dist/types/stories/foundations/typography/typography-body.stories.d.ts +8 -0
  457. package/dist/types/stories/foundations/typography/typography-detail.stories.d.ts +8 -0
  458. package/dist/types/stories/foundations/typography/typography-headline.stories.d.ts +21 -0
  459. package/dist/types/stories/foundations/typography/typography-paragraph.stories.d.ts +8 -0
  460. package/dist/types/stories/patterns/navigation/navigation-basic.stories.d.ts +23 -0
  461. package/dist/types/stories/patterns/navigation/navigation-fewitems.stories.d.ts +23 -0
  462. package/dist/types/stories/patterns/navigation/navigation-manyitems.stories.d.ts +38 -0
  463. package/dist/types/stories/patterns/navigation/navigation-user-menu.stories.d.ts +33 -0
  464. package/dist/types/stories/tegel.stories.d.ts +6 -0
  465. package/dist/types/stories/utility/color/background-color.stories.d.ts +64 -0
  466. package/dist/types/stories/utility/color/text-color.stories.d.ts +64 -0
  467. package/dist/types/utils/utils.d.ts +20 -6
  468. package/package.json +21 -24
  469. package/dist/cjs/tds-dropdown-filter.cjs.entry.js +0 -96
  470. package/dist/cjs/tds-dropdown_2.cjs.entry.js +0 -339
  471. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js +0 -380
  472. package/dist/collection/components/dropdown-v2/dropdown-option-v2/dropdown-option-v2.js +0 -216
  473. package/dist/collection/components/dropdown-v2/dropdown-v2.css +0 -286
  474. package/dist/collection/components/dropdown-v2/dropdown-v2.js +0 -726
  475. package/dist/components/dropdown-option.js +0 -104
  476. package/dist/components/dropdown.js +0 -304
  477. package/dist/components/tds-dropdown-filter.d.ts +0 -11
  478. package/dist/components/tds-dropdown-filter.js +0 -150
  479. package/dist/components/tds-dropdown-option-v2.d.ts +0 -11
  480. package/dist/components/tds-dropdown-option-v2.js +0 -126
  481. package/dist/components/tds-dropdown-v2.d.ts +0 -11
  482. package/dist/components/tds-dropdown-v2.js +0 -323
  483. package/dist/esm/tds-dropdown-filter.entry.js +0 -92
  484. package/dist/esm/tds-dropdown_2.entry.js +0 -334
  485. package/dist/tegel/p-07e5df94.entry.js +0 -1
  486. package/dist/tegel/p-0a3e7512.entry.js +0 -1
  487. package/dist/tegel/p-0e55d72f.entry.js +0 -1
  488. package/dist/tegel/p-107d3da8.entry.js +0 -1
  489. package/dist/tegel/p-13b02a4f.entry.js +0 -1
  490. package/dist/tegel/p-19e9addd.entry.js +0 -1
  491. package/dist/tegel/p-1fb5c5d4.entry.js +0 -1
  492. package/dist/tegel/p-2bee16f6.entry.js +0 -1
  493. package/dist/tegel/p-2e2c91c4.entry.js +0 -1
  494. package/dist/tegel/p-330ed982.entry.js +0 -1
  495. package/dist/tegel/p-3604b5d3.entry.js +0 -1
  496. package/dist/tegel/p-375e361b.entry.js +0 -1
  497. package/dist/tegel/p-55dc4711.entry.js +0 -1
  498. package/dist/tegel/p-59f1cb9b.entry.js +0 -1
  499. package/dist/tegel/p-5a6aba01.entry.js +0 -1
  500. package/dist/tegel/p-60733f89.entry.js +0 -1
  501. package/dist/tegel/p-6a530c2f.entry.js +0 -1
  502. package/dist/tegel/p-732256e0.entry.js +0 -1
  503. package/dist/tegel/p-76f941e8.entry.js +0 -1
  504. package/dist/tegel/p-7b0853e6.entry.js +0 -1
  505. package/dist/tegel/p-90686bc7.entry.js +0 -1
  506. package/dist/tegel/p-95da9b7f.entry.js +0 -1
  507. package/dist/tegel/p-99f540db.entry.js +0 -1
  508. package/dist/tegel/p-9bcc42cf.entry.js +0 -1
  509. package/dist/tegel/p-9f57d275.entry.js +0 -1
  510. package/dist/tegel/p-9fe384ad.entry.js +0 -1
  511. package/dist/tegel/p-a5604352.entry.js +0 -1
  512. package/dist/tegel/p-acb62b52.entry.js +0 -1
  513. package/dist/tegel/p-aeffa257.entry.js +0 -1
  514. package/dist/tegel/p-b8d88873.entry.js +0 -1
  515. package/dist/tegel/p-beb8a6bd.entry.js +0 -1
  516. package/dist/tegel/p-c90a247c.entry.js +0 -1
  517. package/dist/tegel/p-ca4527de.entry.js +0 -1
  518. package/dist/tegel/p-cf4cfc54.entry.js +0 -1
  519. package/dist/tegel/p-d3f5cf74.entry.js +0 -1
  520. package/dist/tegel/p-d67d67be.entry.js +0 -1
  521. package/dist/tegel/p-da4c92b9.entry.js +0 -1
  522. package/dist/tegel/p-f6206d3c.entry.js +0 -1
  523. package/dist/tegel/p-fc47d911.entry.js +0 -1
  524. package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.d.ts +0 -47
  525. package/dist/types/components/dropdown-v2/dropdown-option-v2/dropdown-option-v2.d.ts +0 -35
  526. package/dist/types/components/dropdown-v2/dropdown-v2.d.ts +0 -86
  527. /package/dist/collection/components/{dropdown-v2/dropdown-option-v2/dropdown-option-v2.css → dropdown/dropdown-option/dropdown-option.css} +0 -0
  528. /package/dist/tegel/{p-9d707f6e.js → p-7c0dcd00.js} +0 -0
@@ -229,6 +229,9 @@ button.sm {
229
229
  padding: var(--tds-spacing-element-12);
230
230
  height: 40px;
231
231
  }
232
+ button.sm.icon {
233
+ padding: 10px var(--tds-spacing-element-12);
234
+ }
232
235
  button.sm.only-icon {
233
236
  padding: 11px;
234
237
  }
@@ -240,6 +243,9 @@ button.md {
240
243
  padding: var(--tds-spacing-element-16);
241
244
  height: 48px;
242
245
  }
246
+ button.md.icon {
247
+ padding: 14px var(--tds-spacing-element-16);
248
+ }
243
249
  button.md.only-icon {
244
250
  padding: 13px;
245
251
  }
@@ -251,6 +257,9 @@ button.lg {
251
257
  padding: var(--tds-spacing-element-20);
252
258
  height: 56px;
253
259
  }
260
+ button.lg.icon {
261
+ padding: 18px var(--tds-spacing-element-20);
262
+ }
254
263
  button.lg.only-icon {
255
264
  padding: 17px;
256
265
  }
@@ -489,6 +498,13 @@ button.danger.disabled, button.danger:disabled {
489
498
  height: var(--tds-spacing-element-16);
490
499
  }
491
500
 
501
+ :host(tds-button[disabled]) {
502
+ pointer-events: none;
503
+ }
504
+ :host(tds-button[disabled]) ::slotted([slot=icon]) {
505
+ pointer-events: none;
506
+ }
507
+
492
508
  :host(tds-button[fullbleed]) {
493
509
  width: 100%;
494
510
  justify-content: center;
@@ -1,5 +1,8 @@
1
1
  import { h, Host } from '@stencil/core';
2
- import { disableClickOnElement } from '../../utils/utils';
2
+ import { hasSlot } from '../../utils/utils';
3
+ /**
4
+ * @slot icon - Slot used to display an Icon in the Button.
5
+ */
3
6
  export class TdsButton {
4
7
  constructor() {
5
8
  this.text = undefined;
@@ -9,27 +12,20 @@ export class TdsButton {
9
12
  this.fullbleed = false;
10
13
  this.modeVariant = null;
11
14
  this.onlyIcon = false;
12
- this.slotElement = undefined;
13
15
  }
14
16
  connectedCallback() {
15
- var _a;
16
- this.slotElement = this.host.children ? this.host.children[0] : null;
17
- if (this.disabled) {
18
- disableClickOnElement(this.host);
19
- if (((_a = this.slotElement) === null || _a === void 0 ? void 0 : _a.slot) === 'icon') {
20
- disableClickOnElement(this.slotElement);
21
- }
22
- }
23
17
  if (!this.text) {
24
18
  this.onlyIcon = true;
25
19
  this.host.setAttribute('only-icon', '');
26
20
  }
27
21
  }
28
22
  render() {
23
+ const usesIconSlot = hasSlot('icon', this.host);
29
24
  return (h(Host, { class: `${this.modeVariant !== null ? `tds-mode-variant-${this.modeVariant}` : ''}` }, h("button", { disabled: this.disabled, class: `${this.type}
30
25
  ${this.size}
31
26
  ${this.disabled ? 'disabled' : ''}
32
27
  ${this.fullbleed ? 'fullbleed' : ''}
28
+ ${usesIconSlot ? 'icon' : ''}
33
29
  ${this.onlyIcon ? 'only-icon' : ''}
34
30
  ` }, this.text, h("slot", { name: "icon" }))));
35
31
  }
@@ -158,8 +154,7 @@ export class TdsButton {
158
154
  }
159
155
  static get states() {
160
156
  return {
161
- "onlyIcon": {},
162
- "slotElement": {}
157
+ "onlyIcon": {}
163
158
  };
164
159
  }
165
160
  static get elementRef() { return "host"; }
@@ -0,0 +1,167 @@
1
+ import { formatHtmlPreview } from '../../utils/utils';
2
+ import { iconsNames } from '../icon/iconsArray';
3
+ import readme from './readme.md';
4
+ import { ComponentsFolder } from '../../utils/constants';
5
+ export default {
6
+ title: `${ComponentsFolder}/Button`,
7
+ parameters: {
8
+ notes: readme,
9
+ layout: 'padded',
10
+ design: [
11
+ {
12
+ name: 'Figma',
13
+ type: 'figma',
14
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=1574%3A72148&t=rVXuTOgTmXPauyHd-1',
15
+ },
16
+ {
17
+ name: 'Link',
18
+ type: 'link',
19
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=1574%3A72148&t=rVXuTOgTmXPauyHd-1',
20
+ },
21
+ ],
22
+ },
23
+ argTypes: {
24
+ modeVariant: {
25
+ name: 'Mode variant',
26
+ description: 'Mode variant adjusts component colors to have better visibility depending on global mode and background.',
27
+ control: {
28
+ type: 'radio',
29
+ },
30
+ options: ['Inherit from parent', 'Primary', 'Secondary'],
31
+ table: {
32
+ defaultValue: { summary: 'Inherit from parent' },
33
+ },
34
+ },
35
+ btnType: {
36
+ name: 'Type',
37
+ description: 'Four different Button types to help the user to distinguish the level of importance of the task they represent.',
38
+ control: {
39
+ type: 'radio',
40
+ },
41
+ options: ['Primary', 'Secondary', 'Ghost', 'Danger'],
42
+ table: {
43
+ defaultValue: { summary: 'primary' },
44
+ },
45
+ },
46
+ size: {
47
+ name: 'Size',
48
+ description: 'Sets the size of the Button.',
49
+ control: {
50
+ type: 'radio',
51
+ },
52
+ options: ['Large', 'Medium', 'Small', 'Extra small'],
53
+ table: {
54
+ defaultValue: { summary: 'lg' },
55
+ },
56
+ },
57
+ text: {
58
+ name: 'Text',
59
+ description: 'Sets the text to be displayed on the Button.',
60
+ control: {
61
+ type: 'text',
62
+ },
63
+ if: { arg: 'onlyIcon', truthy: false },
64
+ },
65
+ fullbleed: {
66
+ name: 'Fullbleed',
67
+ description: 'Sets a fluid width on the Button.',
68
+ control: {
69
+ type: 'boolean',
70
+ },
71
+ table: {
72
+ defaultValue: { summary: false },
73
+ },
74
+ if: { arg: 'onlyIcon', truthy: false },
75
+ },
76
+ onlyIcon: {
77
+ name: 'Only Icon',
78
+ description: 'Displays only the icon and excludes any text from the Button.',
79
+ control: {
80
+ type: 'boolean',
81
+ },
82
+ table: {
83
+ defaultValue: { summary: false },
84
+ },
85
+ if: { arg: 'size', neq: 'Extra small' },
86
+ },
87
+ icon: {
88
+ name: 'Icon',
89
+ description: 'Sets icon to be displayed on the Button. Choose "none" to exclude the icon.',
90
+ control: {
91
+ type: 'select',
92
+ },
93
+ options: ['none', ...iconsNames],
94
+ if: { arg: 'size', neq: 'Extra small' },
95
+ },
96
+ disabled: {
97
+ name: 'Disabled',
98
+ description: 'Disables the Button.',
99
+ control: {
100
+ type: 'boolean',
101
+ },
102
+ table: {
103
+ defaultValue: { summary: false },
104
+ },
105
+ },
106
+ },
107
+ args: {
108
+ modeVariant: 'Inherit from parent',
109
+ btnType: 'Primary',
110
+ size: 'Large',
111
+ text: 'Button',
112
+ fullbleed: false,
113
+ onlyIcon: false,
114
+ icon: 'none',
115
+ disabled: false,
116
+ },
117
+ };
118
+ const WebComponentTemplate = ({ modeVariant, btnType, size, text = 'Button', fullbleed, onlyIcon, icon, disabled, }) => {
119
+ const btnTypeLookUp = {
120
+ Primary: 'primary',
121
+ Secondary: 'secondary',
122
+ Ghost: 'ghost',
123
+ Danger: 'danger',
124
+ };
125
+ const sizeLookUp = {
126
+ 'Large': 'lg',
127
+ 'Medium': 'md',
128
+ 'Small': 'sm',
129
+ 'Extra small': 'xs',
130
+ };
131
+ const modeVariantLookup = {
132
+ Primary: 'primary',
133
+ Secondary: 'secondary',
134
+ };
135
+ return formatHtmlPreview(`
136
+ <style>
137
+ /* demo-wrapper is for demonstration purposes only*/
138
+ .demo-wrapper{
139
+ width: 100%;
140
+ }
141
+ </style>
142
+
143
+ <div class="demo-wrapper">
144
+ <tds-button
145
+ type="${btnTypeLookUp[btnType]}"
146
+ size="${sizeLookUp[size]}" ${disabled ? 'disabled' : ''} ${fullbleed ? 'fullbleed' : ''}
147
+ ${!onlyIcon ? `text="${text}"` : ''}
148
+ ${modeVariant !== 'Inherit from parent'
149
+ ? `mode-variant="${modeVariantLookup[modeVariant]}"`
150
+ : ''}
151
+ >
152
+ ${onlyIcon || (icon && icon !== 'none')
153
+ ? `
154
+ <tds-icon slot="icon" class='tds-btn-icon ' size='${sizeLookUp[size] === 'sm' ? '16px' : '20px'}' name='${icon}'></tds-icon>
155
+ `
156
+ : ''}
157
+ </tds-button>
158
+ </div>
159
+ <script>
160
+ document.querySelector('tds-button').addEventListener('click', (event) => {
161
+ console.log(event)
162
+ })
163
+ </script>
164
+ `);
165
+ };
166
+ /** Button as a web component */
167
+ export const Default = WebComponentTemplate.bind({});
@@ -13,42 +13,43 @@
13
13
  box-shadow: var(--tds-card-box-hover);
14
14
  cursor: pointer;
15
15
  }
16
- .card .card-top {
16
+ .card .card-header {
17
17
  font: var(--tds-headline-06);
18
18
  letter-spacing: var(--tds-headline-06-ls);
19
19
  padding: 16px;
20
20
  display: flex;
21
21
  align-items: center;
22
22
  }
23
- .card .card-top img.card-top-image {
23
+ .card .card-header slot[name=thumbnail]::slotted(*) {
24
24
  width: 36px;
25
25
  height: 36px;
26
26
  border-radius: 100%;
27
+ margin-right: 16px;
27
28
  }
28
- .card .card-top .card-top-header {
29
+ .card .card-header .card-top-header {
29
30
  padding-left: 16px;
30
31
  display: flex;
31
32
  flex-direction: column;
32
- row-gap: 4px;
33
33
  }
34
- .card .card-top .card-top-header.no-header-img {
34
+ .card .card-header .card-top-header.no-header-img {
35
35
  padding-left: 0;
36
36
  }
37
- .card .card-top .card-top-header.single-line-header {
38
- row-gap: 0;
39
- }
40
- .card .card-top.below {
37
+ .card .card-header.below {
41
38
  padding-top: 16px;
42
39
  }
43
- .card .card-header {
40
+ .card .header-subheader {
41
+ display: flex;
42
+ flex-direction: column;
43
+ gap: 4px;
44
+ }
45
+ .card .header-subheader .header,
46
+ .card .header-subheader slot[name=header] {
44
47
  color: var(--tds-card-headline);
45
48
  }
46
- .card .card-subheader {
49
+ .card .header-subheader .subheader,
50
+ .card .header-subheader slot[name=subheader] {
47
51
  color: var(--tds-card-sub-headline);
48
52
  }
49
- .card .card-body-img {
50
- width: 100%;
51
- }
52
53
  .card .tds-divider {
53
54
  margin: 16px 16px 0;
54
55
  background-color: var(--tds-card-divider);
@@ -58,7 +59,7 @@
58
59
  display: block;
59
60
  word-wrap: break-word;
60
61
  }
61
- .card slot[name=card-body]::slotted(*) {
62
+ .card slot[name=body]::slotted(*) {
62
63
  font: var(--tds-detail-03);
63
64
  letter-spacing: var(--tds-detail-03-ls);
64
65
  color: var(--tds-card-body-color);
@@ -67,7 +68,7 @@
67
68
  margin-top: 16px;
68
69
  max-width: 336px;
69
70
  }
70
- .card slot[name=card-bottom]::slotted(*) {
71
+ .card slot[name=bottom]::slotted(*) {
71
72
  display: flex;
72
73
  padding: 16px;
73
74
  color: var(--tds-card-icon-color);
@@ -78,7 +79,7 @@ button {
78
79
  text-align: left;
79
80
  padding: 0;
80
81
  }
81
- button:focus {
82
+ button:focus-visible {
82
83
  outline: 2px solid var(--tds-blue-400);
83
84
  outline-offset: -2px;
84
85
  }
@@ -1,4 +1,13 @@
1
1
  import { h, Host } from '@stencil/core';
2
+ import { generateUniqueId, hasSlot } from '../../utils/utils';
3
+ /**
4
+ * @slot header - Slot for the Card header.
5
+ * @slot subheader - Slot for the Card subheader.
6
+ * @slot thumbnail - Slot for the Card thumbnail.
7
+ * @slot body - Slot for the body section of the Card.
8
+ * @slot body-image - Slot for the body section of the Card, used for image.
9
+ * @slot bottom - Slot for the bottom section of the Card.
10
+ */
2
11
  export class TdsCard {
3
12
  constructor() {
4
13
  this.handleClick = () => {
@@ -6,39 +15,34 @@ export class TdsCard {
6
15
  cardId: this.cardId,
7
16
  });
8
17
  };
9
- this.getCardContent = () => (h("div", null, this.headerPlacement === 'above' && (h("div", { class: `card-top ${this.headerPlacement}` }, this.headerImg && (h("img", { class: `card-top-image`, src: this.headerImg, alt: this.headerImgAlt })), ' ', h("div", { class: `
10
- card-top-header
11
- ${!this.headerImg ? 'no-header-img' : ''}
12
- ${!this.header || !this.subheader ? 'single-line-header' : ''}
13
- ` }, h("span", { class: `card-header` }, this.header), h("span", { class: `card-subheader` }, this.subheader)))), h("div", { class: `card-body` }, this.bodyImg && h("img", { class: `card-body-img`, src: this.bodyImg, alt: this.bodyImgAlt }), this.headerPlacement === 'below' && (this.headerImg || this.header || this.subheader) && (h("div", { class: `card-top ${this.headerPlacement}` }, this.headerImg && (h("img", { class: `card-top-image`, src: this.headerImg, alt: this.headerImgAlt })), h("div", { class: `
14
- card-top-header
15
- ${!this.headerImg ? 'no-header-img' : ''}
16
- ${!this.header || !this.subheader ? 'single-line-header' : ''}
17
- ` }, h("span", { class: `card-header` }, this.header), h("span", { class: `card-subheader` }, this.subheader)))), this.bodyDivider && h("tds-divider", null), h("slot", { name: "card-body" })), h("div", { class: `card-bottom` }, this.hasCardBottomSlot && h("slot", { name: `card-bottom` }))));
18
+ this.getCardHeader = () => {
19
+ const usesHeaderSlot = hasSlot('header', this.host);
20
+ const usesSubheaderSlot = hasSlot('subheader', this.host);
21
+ const usesThumbnailSlot = hasSlot('thumbnail', this.host);
22
+ return (h("div", { class: "card-header" }, usesThumbnailSlot && h("slot", { name: "thumbnail" }), h("div", { class: "header-subheader" }, this.header && h("span", { class: "header" }, this.header), usesHeaderSlot && h("slot", { name: "header" }), this.subheader && h("span", { class: "subheader" }, this.subheader), usesSubheaderSlot && h("slot", { name: "subheader" }))));
23
+ };
24
+ this.getCardContent = () => {
25
+ const usesBodySlot = hasSlot('body', this.host);
26
+ const usesBodyImageSlot = hasSlot('body-image', this.host);
27
+ const usesBottomSlot = hasSlot('bottom', this.host);
28
+ return (h("div", null, this.imagePlacement === 'below-header' && this.getCardHeader(), h("div", { class: `card-body` }, usesBodyImageSlot && h("slot", { name: "body-image" }), this.bodyImg && h("img", { class: `card-body-img`, src: this.bodyImg, alt: this.bodyImgAlt }), this.imagePlacement === 'above-header' && this.getCardHeader(), this.bodyDivider && h("tds-divider", null), usesBodySlot && h("slot", { name: "body" })), usesBottomSlot && h("slot", { name: `bottom` })));
29
+ };
18
30
  this.modeVariant = null;
19
- this.headerPlacement = 'above';
31
+ this.imagePlacement = 'below-header';
20
32
  this.header = undefined;
21
33
  this.subheader = undefined;
22
- this.headerImg = undefined;
23
- this.headerImgAlt = undefined;
24
34
  this.bodyImg = undefined;
25
35
  this.bodyImgAlt = undefined;
26
36
  this.bodyDivider = false;
27
37
  this.clickable = false;
28
- this.cardId = crypto.randomUUID();
29
- this.hasCardBottomSlot = false;
30
- this.hasCardBodySlot = false;
31
- }
32
- connectedCallback() {
33
- this.hasCardBottomSlot = !!this.hostElement.querySelector('[slot="card-bottom"]');
34
- this.hasCardBodySlot = !!this.hostElement.querySelector('[slot="card-body"]');
38
+ this.cardId = generateUniqueId();
35
39
  }
36
40
  render() {
37
- return (h(Host, { class: this.modeVariant && `tds-mode-variant-${this.modeVariant}` }, this.clickable ? (h("button", { class: `card ${this.clickable ? 'clickable' : ''} ${this.headerPlacement}`, onClick: () => {
41
+ return (h(Host, { class: this.modeVariant && `tds-mode-variant-${this.modeVariant}` }, this.clickable ? (h("button", { class: `card ${this.clickable ? 'clickable' : ''} ${this.imagePlacement}`, onClick: () => {
38
42
  if (this.clickable) {
39
43
  this.handleClick();
40
44
  }
41
- } }, this.getCardContent())) : (h("div", { class: `card ${this.clickable ? 'clickable' : ''} ${this.headerPlacement}` }, this.getCardContent()))));
45
+ } }, this.getCardContent())) : (h("div", { class: `card ${this.clickable ? 'clickable' : ''} ${this.imagePlacement}` }, this.getCardContent()))));
42
46
  }
43
47
  static get is() { return "tds-card"; }
44
48
  static get encapsulation() { return "shadow"; }
@@ -72,12 +76,12 @@ export class TdsCard {
72
76
  "reflect": false,
73
77
  "defaultValue": "null"
74
78
  },
75
- "headerPlacement": {
79
+ "imagePlacement": {
76
80
  "type": "string",
77
81
  "mutable": false,
78
82
  "complexType": {
79
- "original": "'above' | 'below'",
80
- "resolved": "\"above\" | \"below\"",
83
+ "original": "'above-header' | 'below-header'",
84
+ "resolved": "\"above-header\" | \"below-header\"",
81
85
  "references": {}
82
86
  },
83
87
  "required": false,
@@ -86,9 +90,9 @@ export class TdsCard {
86
90
  "tags": [],
87
91
  "text": "Placement of the header"
88
92
  },
89
- "attribute": "header-placement",
93
+ "attribute": "image-placement",
90
94
  "reflect": false,
91
- "defaultValue": "'above'"
95
+ "defaultValue": "'below-header'"
92
96
  },
93
97
  "header": {
94
98
  "type": "string",
@@ -124,40 +128,6 @@ export class TdsCard {
124
128
  "attribute": "subheader",
125
129
  "reflect": false
126
130
  },
127
- "headerImg": {
128
- "type": "string",
129
- "mutable": false,
130
- "complexType": {
131
- "original": "string",
132
- "resolved": "string",
133
- "references": {}
134
- },
135
- "required": false,
136
- "optional": false,
137
- "docs": {
138
- "tags": [],
139
- "text": "Header image src"
140
- },
141
- "attribute": "header-img",
142
- "reflect": false
143
- },
144
- "headerImgAlt": {
145
- "type": "string",
146
- "mutable": false,
147
- "complexType": {
148
- "original": "string",
149
- "resolved": "string",
150
- "references": {}
151
- },
152
- "required": false,
153
- "optional": false,
154
- "docs": {
155
- "tags": [],
156
- "text": "Alt text for the header image"
157
- },
158
- "attribute": "header-img-alt",
159
- "reflect": false
160
- },
161
131
  "bodyImg": {
162
132
  "type": "string",
163
133
  "mutable": false,
@@ -244,16 +214,10 @@ export class TdsCard {
244
214
  },
245
215
  "attribute": "card-id",
246
216
  "reflect": false,
247
- "defaultValue": "crypto.randomUUID()"
217
+ "defaultValue": "generateUniqueId()"
248
218
  }
249
219
  };
250
220
  }
251
- static get states() {
252
- return {
253
- "hasCardBottomSlot": {},
254
- "hasCardBodySlot": {}
255
- };
256
- }
257
221
  static get events() {
258
222
  return [{
259
223
  "method": "tdsClick",
@@ -272,5 +236,5 @@ export class TdsCard {
272
236
  }
273
237
  }];
274
238
  }
275
- static get elementRef() { return "hostElement"; }
239
+ static get elementRef() { return "host"; }
276
240
  }
@@ -0,0 +1,162 @@
1
+ import readme from './readme.md';
2
+ import CardPlaceholder from '../../stories/assets/image/card-placeholder.png';
3
+ import { formatHtmlPreview } from '../../utils/utils';
4
+ import { ComponentsFolder } from '../../utils/constants';
5
+ export default {
6
+ title: `${ComponentsFolder}/Card`,
7
+ parameters: {
8
+ notes: readme,
9
+ layout: 'centered',
10
+ design: [
11
+ {
12
+ name: 'Figma',
13
+ type: 'figma',
14
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=2891%3A125&t=rVXuTOgTmXPauyHd-1',
15
+ },
16
+ {
17
+ name: 'Link',
18
+ type: 'link',
19
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=2891%3A125&t=rVXuTOgTmXPauyHd-1',
20
+ },
21
+ ],
22
+ },
23
+ argTypes: {
24
+ modeVariant: {
25
+ name: 'Mode variant',
26
+ description: 'Mode variant adjusts component colors to have better visibility depending on global mode and background.',
27
+ control: {
28
+ type: 'radio',
29
+ },
30
+ options: ['Inherit from parent', 'Primary', 'Secondary'],
31
+ table: {
32
+ defaultValue: { summary: 'Inherit from parent' },
33
+ },
34
+ },
35
+ header: {
36
+ name: 'Header text',
37
+ description: 'Sets the header text.',
38
+ control: {
39
+ type: 'text',
40
+ },
41
+ },
42
+ subheader: {
43
+ name: 'Subheader text',
44
+ description: 'Sets the subheader text.',
45
+ control: {
46
+ type: 'text',
47
+ },
48
+ },
49
+ thumbnail: {
50
+ name: 'Header thumbnail',
51
+ description: 'Toggles a thumbnail in the header.',
52
+ control: {
53
+ type: 'boolean',
54
+ },
55
+ },
56
+ imagePlacement: {
57
+ name: 'Body image placement',
58
+ description: 'Sets the placement of the body image, above or below the header.',
59
+ control: {
60
+ type: 'radio',
61
+ },
62
+ options: ['Above', 'Below'],
63
+ table: {
64
+ defaultValue: { summary: 'below' },
65
+ },
66
+ },
67
+ bodyImg: {
68
+ name: 'Body image',
69
+ description: 'Toggles an image in the Card body. Cannot be combined with divider.',
70
+ control: {
71
+ type: 'boolean',
72
+ },
73
+ if: { arg: 'bodyDivider', eq: false },
74
+ },
75
+ bodyContent: {
76
+ name: 'Body text',
77
+ description: 'Sets the body text for the Card.',
78
+ control: {
79
+ type: 'text',
80
+ },
81
+ },
82
+ bodyDivider: {
83
+ name: 'Body divider',
84
+ description: 'Adds a divider above the body content. Cannot be combined with body image.',
85
+ control: {
86
+ type: 'boolean',
87
+ },
88
+ if: { arg: 'bodyImg', eq: false },
89
+ table: {
90
+ defaultValue: { summary: false },
91
+ },
92
+ },
93
+ cardBottom: {
94
+ name: 'Content of the bottom of the Card',
95
+ description: 'Slot to add custom HTML elements to the bottom of the Card.',
96
+ control: {
97
+ type: 'text',
98
+ },
99
+ },
100
+ clickable: {
101
+ name: 'Clickable',
102
+ description: 'Toggles if the Card is clickable or not.',
103
+ control: {
104
+ type: 'boolean',
105
+ },
106
+ table: {
107
+ defaultValue: { summary: false },
108
+ },
109
+ },
110
+ },
111
+ args: {
112
+ modeVariant: 'Inherit from parent',
113
+ header: 'Header text',
114
+ subheader: 'Subheader text',
115
+ thumbnail: true,
116
+ imagePlacement: 'Below',
117
+ bodyImg: false,
118
+ bodyContent: '',
119
+ bodyDivider: false,
120
+ cardBottom: `<tds-icon slot="bottom" size="20px" name="arrow_right"></tds-icon>`,
121
+ clickable: false,
122
+ },
123
+ };
124
+ const Template = ({ modeVariant, header, subheader, thumbnail, imagePlacement, bodyImg, bodyContent, bodyDivider, cardBottom, clickable, }) => formatHtmlPreview(`<style>
125
+ /* demo-wrapper is for demonstration purposes only*/
126
+ .demo-wrapper {
127
+ width: 368px;
128
+ }
129
+ </style>
130
+ <div class="demo-wrapper">
131
+ <tds-card
132
+ ${modeVariant !== 'Inherit from parent' ? `mode-variant="${modeVariant.toLowerCase()}"` : ''}
133
+ ${header ? `header="${header}"` : ''}
134
+ image-placement="${imagePlacement.toLowerCase()}-header"
135
+ ${subheader ? `subheader="${subheader}"` : ''}
136
+ ${bodyImg ? `body-img="${CardPlaceholder}"` : ''}
137
+ ${clickable ? 'clickable' : ''}
138
+ ${bodyDivider ? 'body-divider' : ''}
139
+ >
140
+ ${thumbnail
141
+ ? `<img slot="thumbnail" src="${CardPlaceholder}" alt="Thumbnail for the card."/>`
142
+ : ''}
143
+ ${bodyContent
144
+ ? `
145
+ <div slot="body">
146
+ ${bodyContent}
147
+ </div>`
148
+ : ''}
149
+ ${cardBottom ? `${cardBottom}` : ''}
150
+ </tds-card>
151
+ </div>
152
+ ${clickable
153
+ ? `
154
+ <script>
155
+ document.addEventListener('tdsClick', (event)=>{
156
+ console.log('Card with id: ', event.detail.cardId, ' was clicked.')
157
+ })
158
+ </script>
159
+ `
160
+ : ''}
161
+ `);
162
+ export const Default = Template.bind({});