@scania/tegel 0.0.1-beta.9 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (530) hide show
  1. package/dist/cjs/index-b98965c7.js +1919 -0
  2. package/dist/cjs/index.cjs.js +2 -0
  3. package/dist/cjs/loader.cjs.js +21 -0
  4. package/dist/cjs/popper-11d5f714.js +1801 -0
  5. package/dist/cjs/sdds-accordion-item.cjs.entry.js +34 -0
  6. package/dist/cjs/sdds-accordion.cjs.entry.js +21 -0
  7. package/dist/cjs/sdds-badges.cjs.entry.js +54 -0
  8. package/dist/cjs/sdds-banner.cjs.entry.js +79 -0
  9. package/dist/cjs/sdds-block.cjs.entry.js +32 -0
  10. package/dist/cjs/sdds-body-cell_2.cjs.entry.js +173 -0
  11. package/dist/cjs/sdds-breadcrumb-item.cjs.entry.js +25 -0
  12. package/dist/cjs/sdds-breadcrumb.cjs.entry.js +23 -0
  13. package/dist/cjs/sdds-button.cjs.entry.js +37 -0
  14. package/dist/cjs/sdds-card.cjs.entry.js +56 -0
  15. package/dist/cjs/sdds-checkbox.cjs.entry.js +55 -0
  16. package/dist/cjs/sdds-datetime.cjs.entry.js +95 -0
  17. package/dist/cjs/sdds-dropdown-filter.cjs.entry.js +92 -0
  18. package/dist/cjs/sdds-dropdown_2.cjs.entry.js +341 -0
  19. package/dist/cjs/sdds-header-cell.cjs.entry.js +139 -0
  20. package/dist/cjs/sdds-icon.cjs.entry.js +42 -0
  21. package/dist/cjs/sdds-inline-tab.cjs.entry.js +22 -0
  22. package/dist/cjs/sdds-inline-tabs-fullbleed.cjs.entry.js +98 -0
  23. package/dist/cjs/sdds-inline-tabs.cjs.entry.js +221 -0
  24. package/dist/cjs/sdds-link.cjs.entry.js +28 -0
  25. package/dist/cjs/sdds-message.cjs.entry.js +41 -0
  26. package/dist/cjs/sdds-modal.cjs.entry.js +51 -0
  27. package/dist/cjs/sdds-navigation-tabs.cjs.entry.js +98 -0
  28. package/dist/cjs/sdds-popover-canvas.cjs.entry.js +84 -0
  29. package/dist/cjs/sdds-popover-menu.cjs.entry.js +85 -0
  30. package/dist/cjs/sdds-radio-button.cjs.entry.js +32 -0
  31. package/dist/cjs/sdds-slider.cjs.entry.js +357 -0
  32. package/dist/cjs/sdds-spinner.cjs.entry.js +21 -0
  33. package/dist/cjs/sdds-table-body-row-expandable.cjs.entry.js +82 -0
  34. package/dist/cjs/sdds-table-body.cjs.entry.js +289 -0
  35. package/dist/cjs/sdds-table-footer.cjs.entry.js +164 -0
  36. package/dist/cjs/sdds-table-header.cjs.entry.js +99 -0
  37. package/dist/cjs/sdds-table-toolbar.cjs.entry.js +65 -0
  38. package/dist/cjs/sdds-table.cjs.entry.js +68 -0
  39. package/dist/cjs/sdds-textarea.cjs.entry.js +74 -0
  40. package/dist/cjs/sdds-textfield.cjs.entry.js +91 -0
  41. package/dist/cjs/sdds-toast.cjs.entry.js +86 -0
  42. package/dist/cjs/sdds-toggle.cjs.entry.js +44 -0
  43. package/dist/cjs/sdds-tooltip.cjs.entry.js +104 -0
  44. package/dist/cjs/tegel.cjs.js +19 -0
  45. package/dist/collection/collection-manifest.json +52 -0
  46. package/dist/collection/components/accordion/accordion-item/accordion-item.css +153 -0
  47. package/dist/collection/components/accordion/accordion-item/accordion-item.js +146 -0
  48. package/dist/collection/components/accordion/accordion.css +63 -0
  49. package/dist/collection/components/accordion/accordion.js +62 -0
  50. package/dist/collection/components/accordion/accordion.stories.js +90 -0
  51. package/dist/collection/components/badge/badge.stories.js +102 -0
  52. package/dist/collection/components/badge/badges.css +42 -0
  53. package/dist/collection/components/badge/badges.js +147 -0
  54. package/dist/collection/components/banner/banner.stories.js +92 -0
  55. package/dist/collection/components/banner/sdds-banner.css +88 -0
  56. package/dist/collection/components/banner/sdds-banner.js +330 -0
  57. package/dist/collection/components/banner/sdds-banner.stories.js +129 -0
  58. package/dist/collection/components/block/block-native.stories.js +48 -0
  59. package/dist/collection/components/block/sdds-block.css +22 -0
  60. package/dist/collection/components/block/sdds-block.js +55 -0
  61. package/dist/collection/components/block/sdds-block.stories.js +48 -0
  62. package/dist/collection/components/breadcrumb/breadcrumb-component.css +30 -0
  63. package/dist/collection/components/breadcrumb/breadcrumb-item/breadcrumb-item.css +43 -0
  64. package/dist/collection/components/breadcrumb/breadcrumb-item/breadcrumb-item.js +83 -0
  65. package/dist/collection/components/breadcrumb/breadcrumb.js +22 -0
  66. package/dist/collection/components/breadcrumb/breadcrumb.stories.js +26 -0
  67. package/dist/collection/components/button/button-component.js +155 -0
  68. package/dist/collection/components/button/button-native.stories.js +187 -0
  69. package/dist/collection/components/button/button-webcomponent.stories.js +189 -0
  70. package/dist/collection/components/button/button.css +670 -0
  71. package/dist/collection/components/card/card.stories.js +167 -0
  72. package/dist/collection/components/card/sdds-card.css +78 -0
  73. package/dist/collection/components/card/sdds-card.js +276 -0
  74. package/dist/collection/components/card/sdds-card.stories.js +168 -0
  75. package/dist/collection/components/checkbox/checkbox.stories.js +54 -0
  76. package/dist/collection/components/checkbox/sdds-checkbox.css +95 -0
  77. package/dist/collection/components/checkbox/sdds-checkbox.js +239 -0
  78. package/dist/collection/components/checkbox/sdds-checkbox.stories.js +71 -0
  79. package/dist/collection/components/chips/chips.stories.js +106 -0
  80. package/dist/collection/components/data-table/native-table.stories.js +160 -0
  81. package/dist/collection/components/data-table/table/table.css +15 -0
  82. package/dist/collection/components/data-table/table/table.js +252 -0
  83. package/dist/collection/components/data-table/table-body/table-body.css +22 -0
  84. package/dist/collection/components/data-table/table-body/table-body.js +425 -0
  85. package/dist/collection/components/data-table/table-body-cell/table-body-cell.css +40 -0
  86. package/dist/collection/components/data-table/table-body-cell/table-body-cell.js +168 -0
  87. package/dist/collection/components/data-table/table-body-row/table-body-row.css +175 -0
  88. package/dist/collection/components/data-table/table-body-row/table-body-row.js +165 -0
  89. package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.css +78 -0
  90. package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.js +156 -0
  91. package/dist/collection/components/data-table/table-component-basic.stories.js +161 -0
  92. package/dist/collection/components/data-table/table-component-batch-actions.stories.js +128 -0
  93. package/dist/collection/components/data-table/table-component-bodydata.stories.js +58 -0
  94. package/dist/collection/components/data-table/table-component-custom-width.stories.js +197 -0
  95. package/dist/collection/components/data-table/table-component-event-listeners.stories.js +151 -0
  96. package/dist/collection/components/data-table/table-component-expandable-rows.stories.js +135 -0
  97. package/dist/collection/components/data-table/table-component-filtering.stories.js +137 -0
  98. package/dist/collection/components/data-table/table-component-multiselect.stories.js +158 -0
  99. package/dist/collection/components/data-table/table-component-pagination.stories.js +127 -0
  100. package/dist/collection/components/data-table/table-component-sorting.stories.js +126 -0
  101. package/dist/collection/components/data-table/table-footer/table-footer.css +97 -0
  102. package/dist/collection/components/data-table/table-footer/table-footer.js +354 -0
  103. package/dist/collection/components/data-table/table-header/table-header.css +190 -0
  104. package/dist/collection/components/data-table/table-header/table-header.js +152 -0
  105. package/dist/collection/components/data-table/table-header-cell/table-header-cell.css +127 -0
  106. package/dist/collection/components/data-table/table-header-cell/table-header-cell.js +317 -0
  107. package/dist/collection/components/data-table/table-toolbar/table-toolbar.css +93 -0
  108. package/dist/collection/components/data-table/table-toolbar/table-toolbar.js +141 -0
  109. package/dist/collection/components/datetime/datetime.css +385 -0
  110. package/dist/collection/components/datetime/datetime.js +352 -0
  111. package/dist/collection/components/datetime/datetime.stories.js +207 -0
  112. package/dist/collection/components/divider/divider.stories.js +133 -0
  113. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js +339 -0
  114. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.stories.js +130 -0
  115. package/dist/collection/components/dropdown/dropdown-native.stories.js +90 -0
  116. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +185 -0
  117. package/dist/collection/components/dropdown/dropdown-wc-default.stories.js +167 -0
  118. package/dist/collection/components/dropdown/dropdown-wc-multiselect.stories.js +146 -0
  119. package/dist/collection/components/dropdown/dropdown.css +951 -0
  120. package/dist/collection/components/dropdown/dropdown.js +577 -0
  121. package/dist/collection/components/footer/footer.stories.js +117 -0
  122. package/dist/collection/components/header/header-all.stories.js +217 -0
  123. package/dist/collection/components/header/header-default.stories.js +47 -0
  124. package/dist/collection/components/header/header-inline.stories.js +113 -0
  125. package/dist/collection/components/header/header-search.stories.js +263 -0
  126. package/dist/collection/components/header/header-toolbar.stories.js +204 -0
  127. package/dist/collection/components/icon/icon-font.stories.js +57 -0
  128. package/dist/collection/components/icon/icon-web-component.stories.js +51 -0
  129. package/dist/collection/components/icon/icon.css +16 -0
  130. package/dist/collection/components/icon/icon.js +89 -0
  131. package/dist/collection/components/icon/iconsArray.js +2 -0
  132. package/dist/collection/components/link/link.stories.js +45 -0
  133. package/dist/collection/components/link/sdds-link.css +36 -0
  134. package/dist/collection/components/link/sdds-link.js +121 -0
  135. package/dist/collection/components/link/sdds-link.stories.js +70 -0
  136. package/dist/collection/components/message/message.stories.js +108 -0
  137. package/dist/collection/components/message/sdds-message.css +70 -0
  138. package/dist/collection/components/message/sdds-message.js +135 -0
  139. package/dist/collection/components/message/sdds-message.stories.js +106 -0
  140. package/dist/collection/components/modal/modal-native.stories.js +129 -0
  141. package/dist/collection/components/modal/modal-webcomponent.stories.js +86 -0
  142. package/dist/collection/components/modal/modal.css +350 -0
  143. package/dist/collection/components/modal/modal.js +148 -0
  144. package/dist/collection/components/popover-canvas/popover-canvas.css +20 -0
  145. package/dist/collection/components/popover-canvas/popover-canvas.js +219 -0
  146. package/dist/collection/components/popover-canvas/popover-canvas.stories.js +89 -0
  147. package/dist/collection/components/popover-menu/popover-menu-icons.stories.js +121 -0
  148. package/dist/collection/components/popover-menu/popover-menu.css +19 -0
  149. package/dist/collection/components/popover-menu/popover-menu.js +220 -0
  150. package/dist/collection/components/popover-menu/popover-menu.stories.js +114 -0
  151. package/dist/collection/components/radio-button/radio-button-component.css +123 -0
  152. package/dist/collection/components/radio-button/radio-button-component.stories.js +91 -0
  153. package/dist/collection/components/radio-button/radio-button.js +160 -0
  154. package/dist/collection/components/radio-button/radio-button.stories.js +68 -0
  155. package/dist/collection/components/side-menu/side-menu.stories.js +182 -0
  156. package/dist/collection/components/slider/slider.css +297 -0
  157. package/dist/collection/components/slider/slider.js +721 -0
  158. package/dist/collection/components/slider/slider.stories.js +208 -0
  159. package/dist/collection/components/spinner/spinner.css +79 -0
  160. package/dist/collection/components/spinner/spinner.js +61 -0
  161. package/dist/collection/components/spinner/spinner.stories.js +59 -0
  162. package/dist/collection/components/stepper/stepper.stories.js +139 -0
  163. package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.css +3 -0
  164. package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.js +80 -0
  165. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.css +156 -0
  166. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.js +312 -0
  167. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.stories.js +71 -0
  168. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.css +141 -0
  169. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.js +128 -0
  170. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.js +46 -0
  171. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.css +157 -0
  172. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +128 -0
  173. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js +32 -0
  174. package/dist/collection/components/textarea/textarea.css +298 -0
  175. package/dist/collection/components/textarea/textarea.js +402 -0
  176. package/dist/collection/components/textarea/textarea.stories.js +169 -0
  177. package/dist/collection/components/textfield/textfield.css +502 -0
  178. package/dist/collection/components/textfield/textfield.js +439 -0
  179. package/dist/collection/components/textfield/textfield.stories.js +239 -0
  180. package/dist/collection/components/toast/sdds-toast.css +102 -0
  181. package/dist/collection/components/toast/sdds-toast.js +256 -0
  182. package/dist/collection/components/toast/sdds-toast.stories.js +86 -0
  183. package/dist/collection/components/toast/toast.stories.js +129 -0
  184. package/dist/collection/components/toggle/sdds-toggle.css +104 -0
  185. package/dist/collection/components/toggle/sdds-toggle.js +261 -0
  186. package/dist/collection/components/toggle/sdds-toggle.stories.js +92 -0
  187. package/dist/collection/components/toggle/toggle.stories.js +72 -0
  188. package/dist/collection/components/tooltip/tooltip.css +46 -0
  189. package/dist/collection/components/tooltip/tooltip.js +229 -0
  190. package/dist/collection/components/tooltip/tooltip.stories.js +115 -0
  191. package/dist/collection/components/utility/colour/background-color.stories.js +96 -0
  192. package/dist/collection/components/utility/colour/text-color.stories.js +94 -0
  193. package/dist/collection/foundations-stories/colour/colour-brand.stories.js +38 -0
  194. package/dist/collection/foundations-stories/colour/colour-scales.stories.js +71 -0
  195. package/dist/collection/foundations-stories/colour/colour-semantic.stories.js +40 -0
  196. package/dist/collection/foundations-stories/grid/grid.stories.js +386 -0
  197. package/dist/collection/foundations-stories/spacing/spacing-element.stories.js +100 -0
  198. package/dist/collection/foundations-stories/spacing/spacing-layout.stories.js +94 -0
  199. package/dist/collection/foundations-stories/typography/typography-body.stories.js +16 -0
  200. package/dist/collection/foundations-stories/typography/typography-detail.stories.js +17 -0
  201. package/dist/collection/foundations-stories/typography/typography-headline.stories.js +39 -0
  202. package/dist/collection/foundations-stories/typography/typography-paragraph.stories.js +12 -0
  203. package/dist/collection/index.js +1 -0
  204. package/dist/collection/stories/assets/code-brackets.svg +1 -0
  205. package/dist/collection/stories/assets/colors.svg +1 -0
  206. package/dist/collection/stories/assets/comments.svg +1 -0
  207. package/dist/collection/stories/assets/direction.svg +1 -0
  208. package/dist/collection/stories/assets/flow.svg +1 -0
  209. package/dist/collection/stories/assets/plugin.svg +1 -0
  210. package/dist/collection/stories/assets/repo.svg +1 -0
  211. package/dist/collection/stories/assets/stackalt.svg +1 -0
  212. package/dist/collection/utils/utils.js +12 -0
  213. package/dist/components/dropdown-option.js +100 -0
  214. package/dist/components/dropdown.js +303 -0
  215. package/dist/components/icon.js +58 -0
  216. package/dist/components/index.d.ts +62 -0
  217. package/dist/components/index.js +42 -0
  218. package/dist/components/popper.js +1799 -0
  219. package/dist/components/sdds-accordion-item.d.ts +11 -0
  220. package/dist/components/sdds-accordion-item.js +60 -0
  221. package/dist/components/sdds-accordion.d.ts +11 -0
  222. package/dist/components/sdds-accordion.js +38 -0
  223. package/dist/components/sdds-badges.d.ts +11 -0
  224. package/dist/components/sdds-badges.js +75 -0
  225. package/dist/components/sdds-banner.d.ts +11 -0
  226. package/dist/components/sdds-banner.js +119 -0
  227. package/dist/components/sdds-block.d.ts +11 -0
  228. package/dist/components/sdds-block.js +48 -0
  229. package/dist/components/sdds-body-cell.d.ts +11 -0
  230. package/dist/components/sdds-body-cell.js +6 -0
  231. package/dist/components/sdds-breadcrumb-item.d.ts +11 -0
  232. package/dist/components/sdds-breadcrumb-item.js +43 -0
  233. package/dist/components/sdds-breadcrumb.d.ts +11 -0
  234. package/dist/components/sdds-breadcrumb.js +37 -0
  235. package/dist/components/sdds-button.d.ts +11 -0
  236. package/dist/components/sdds-button.js +59 -0
  237. package/dist/components/sdds-card.d.ts +11 -0
  238. package/dist/components/sdds-card.js +84 -0
  239. package/dist/components/sdds-checkbox.d.ts +11 -0
  240. package/dist/components/sdds-checkbox.js +76 -0
  241. package/dist/components/sdds-datetime.d.ts +11 -0
  242. package/dist/components/sdds-datetime.js +129 -0
  243. package/dist/components/sdds-dropdown-filter.d.ts +11 -0
  244. package/dist/components/sdds-dropdown-filter.js +138 -0
  245. package/dist/components/sdds-dropdown-option.d.ts +11 -0
  246. package/dist/components/sdds-dropdown-option.js +6 -0
  247. package/dist/components/sdds-dropdown.d.ts +11 -0
  248. package/dist/components/sdds-dropdown.js +6 -0
  249. package/dist/components/sdds-header-cell.d.ts +11 -0
  250. package/dist/components/sdds-header-cell.js +170 -0
  251. package/dist/components/sdds-icon.d.ts +11 -0
  252. package/dist/components/sdds-icon.js +6 -0
  253. package/dist/components/sdds-inline-tab.d.ts +11 -0
  254. package/dist/components/sdds-inline-tab.js +40 -0
  255. package/dist/components/sdds-inline-tabs-fullbleed.d.ts +11 -0
  256. package/dist/components/sdds-inline-tabs-fullbleed.js +117 -0
  257. package/dist/components/sdds-inline-tabs.d.ts +11 -0
  258. package/dist/components/sdds-inline-tabs.js +245 -0
  259. package/dist/components/sdds-link.d.ts +11 -0
  260. package/dist/components/sdds-link.js +6 -0
  261. package/dist/components/sdds-link2.js +44 -0
  262. package/dist/components/sdds-message.d.ts +11 -0
  263. package/dist/components/sdds-message.js +67 -0
  264. package/dist/components/sdds-modal.d.ts +11 -0
  265. package/dist/components/sdds-modal.js +77 -0
  266. package/dist/components/sdds-navigation-tabs.d.ts +11 -0
  267. package/dist/components/sdds-navigation-tabs.js +117 -0
  268. package/dist/components/sdds-popover-canvas.d.ts +11 -0
  269. package/dist/components/sdds-popover-canvas.js +108 -0
  270. package/dist/components/sdds-popover-menu.d.ts +11 -0
  271. package/dist/components/sdds-popover-menu.js +109 -0
  272. package/dist/components/sdds-radio-button.d.ts +11 -0
  273. package/dist/components/sdds-radio-button.js +52 -0
  274. package/dist/components/sdds-slider.d.ts +11 -0
  275. package/dist/components/sdds-slider.js +394 -0
  276. package/dist/components/sdds-spinner.d.ts +11 -0
  277. package/dist/components/sdds-spinner.js +37 -0
  278. package/dist/components/sdds-table-body-row-expandable.d.ts +11 -0
  279. package/dist/components/sdds-table-body-row-expandable.js +105 -0
  280. package/dist/components/sdds-table-body-row.d.ts +11 -0
  281. package/dist/components/sdds-table-body-row.js +6 -0
  282. package/dist/components/sdds-table-body.d.ts +11 -0
  283. package/dist/components/sdds-table-body.js +337 -0
  284. package/dist/components/sdds-table-footer.d.ts +11 -0
  285. package/dist/components/sdds-table-footer.js +195 -0
  286. package/dist/components/sdds-table-header.d.ts +11 -0
  287. package/dist/components/sdds-table-header.js +124 -0
  288. package/dist/components/sdds-table-toolbar.d.ts +11 -0
  289. package/dist/components/sdds-table-toolbar.js +87 -0
  290. package/dist/components/sdds-table.d.ts +11 -0
  291. package/dist/components/sdds-table.js +91 -0
  292. package/dist/components/sdds-textarea.d.ts +11 -0
  293. package/dist/components/sdds-textarea.js +109 -0
  294. package/dist/components/sdds-textfield.d.ts +11 -0
  295. package/dist/components/sdds-textfield.js +127 -0
  296. package/dist/components/sdds-toast.d.ts +11 -0
  297. package/dist/components/sdds-toast.js +117 -0
  298. package/dist/components/sdds-toggle.d.ts +11 -0
  299. package/dist/components/sdds-toggle.js +69 -0
  300. package/dist/components/sdds-tooltip.d.ts +11 -0
  301. package/dist/components/sdds-tooltip.js +127 -0
  302. package/dist/components/table-body-cell.js +101 -0
  303. package/dist/components/table-body-row.js +120 -0
  304. package/dist/esm/index-32571711.js +1891 -0
  305. package/dist/esm/index.js +1 -0
  306. package/dist/esm/loader.js +17 -0
  307. package/dist/esm/polyfills/core-js.js +11 -0
  308. package/dist/esm/polyfills/css-shim.js +1 -0
  309. package/dist/esm/polyfills/dom.js +79 -0
  310. package/dist/esm/polyfills/es5-html-element.js +1 -0
  311. package/dist/esm/polyfills/index.js +34 -0
  312. package/dist/esm/polyfills/system.js +6 -0
  313. package/dist/esm/popper-f860750c.js +1799 -0
  314. package/dist/esm/sdds-accordion-item.entry.js +30 -0
  315. package/dist/esm/sdds-accordion.entry.js +17 -0
  316. package/dist/esm/sdds-badges.entry.js +50 -0
  317. package/dist/esm/sdds-banner.entry.js +75 -0
  318. package/dist/esm/sdds-block.entry.js +28 -0
  319. package/dist/esm/sdds-body-cell_2.entry.js +168 -0
  320. package/dist/esm/sdds-breadcrumb-item.entry.js +21 -0
  321. package/dist/esm/sdds-breadcrumb.entry.js +19 -0
  322. package/dist/esm/sdds-button.entry.js +33 -0
  323. package/dist/esm/sdds-card.entry.js +52 -0
  324. package/dist/esm/sdds-checkbox.entry.js +51 -0
  325. package/dist/esm/sdds-datetime.entry.js +91 -0
  326. package/dist/esm/sdds-dropdown-filter.entry.js +88 -0
  327. package/dist/esm/sdds-dropdown_2.entry.js +336 -0
  328. package/dist/esm/sdds-header-cell.entry.js +135 -0
  329. package/dist/esm/sdds-icon.entry.js +38 -0
  330. package/dist/esm/sdds-inline-tab.entry.js +18 -0
  331. package/dist/esm/sdds-inline-tabs-fullbleed.entry.js +94 -0
  332. package/dist/esm/sdds-inline-tabs.entry.js +217 -0
  333. package/dist/esm/sdds-link.entry.js +24 -0
  334. package/dist/esm/sdds-message.entry.js +37 -0
  335. package/dist/esm/sdds-modal.entry.js +47 -0
  336. package/dist/esm/sdds-navigation-tabs.entry.js +94 -0
  337. package/dist/esm/sdds-popover-canvas.entry.js +80 -0
  338. package/dist/esm/sdds-popover-menu.entry.js +81 -0
  339. package/dist/esm/sdds-radio-button.entry.js +28 -0
  340. package/dist/esm/sdds-slider.entry.js +353 -0
  341. package/dist/esm/sdds-spinner.entry.js +17 -0
  342. package/dist/esm/sdds-table-body-row-expandable.entry.js +78 -0
  343. package/dist/esm/sdds-table-body.entry.js +285 -0
  344. package/dist/esm/sdds-table-footer.entry.js +160 -0
  345. package/dist/esm/sdds-table-header.entry.js +95 -0
  346. package/dist/esm/sdds-table-toolbar.entry.js +61 -0
  347. package/dist/esm/sdds-table.entry.js +64 -0
  348. package/dist/esm/sdds-textarea.entry.js +70 -0
  349. package/dist/esm/sdds-textfield.entry.js +87 -0
  350. package/dist/esm/sdds-toast.entry.js +82 -0
  351. package/dist/esm/sdds-toggle.entry.js +40 -0
  352. package/dist/esm/sdds-tooltip.entry.js +100 -0
  353. package/dist/esm/tegel.js +17 -0
  354. package/dist/index.cjs.js +1 -0
  355. package/dist/index.js +1 -0
  356. package/dist/node_modules/@types/jest/index.d.ts +1512 -0
  357. package/dist/tegel/index.esm.js +0 -0
  358. package/dist/tegel/p-05d3cfc8.entry.js +1 -0
  359. package/dist/tegel/p-13a25c7f.entry.js +1 -0
  360. package/dist/tegel/p-13b783f1.js +2 -0
  361. package/dist/tegel/p-1dda8de9.entry.js +1 -0
  362. package/dist/tegel/p-2248b59e.entry.js +1 -0
  363. package/dist/tegel/p-232e5c9a.entry.js +1 -0
  364. package/dist/tegel/p-2375f0eb.entry.js +1 -0
  365. package/dist/tegel/p-29deedc6.entry.js +1 -0
  366. package/dist/tegel/p-2f52021b.entry.js +1 -0
  367. package/dist/tegel/p-3344582d.entry.js +1 -0
  368. package/dist/tegel/p-4b14324d.entry.js +1 -0
  369. package/dist/tegel/p-561fbe77.entry.js +1 -0
  370. package/dist/tegel/p-5a215722.entry.js +1 -0
  371. package/dist/tegel/p-5f7b1539.entry.js +1 -0
  372. package/dist/tegel/p-6f382b38.entry.js +1 -0
  373. package/dist/tegel/p-765e2719.entry.js +1 -0
  374. package/dist/tegel/p-76f60546.entry.js +1 -0
  375. package/dist/tegel/p-7a5244b6.entry.js +1 -0
  376. package/dist/tegel/p-816ff5f7.entry.js +1 -0
  377. package/dist/tegel/p-81d2d57b.entry.js +1 -0
  378. package/dist/tegel/p-87650f36.entry.js +1 -0
  379. package/dist/tegel/p-8e6f885c.entry.js +1 -0
  380. package/dist/tegel/p-8e9dcc20.entry.js +1 -0
  381. package/dist/tegel/p-997fc919.entry.js +1 -0
  382. package/dist/tegel/p-9a057c9a.entry.js +1 -0
  383. package/dist/tegel/p-9a95e92c.entry.js +1 -0
  384. package/dist/tegel/p-a75ff060.entry.js +1 -0
  385. package/dist/tegel/p-bf1216f9.entry.js +1 -0
  386. package/dist/tegel/p-bf597564.entry.js +1 -0
  387. package/dist/tegel/p-d2217bf0.entry.js +1 -0
  388. package/dist/tegel/p-e335137d.entry.js +1 -0
  389. package/dist/tegel/p-e34cce75.entry.js +1 -0
  390. package/dist/tegel/p-e55d09f2.entry.js +1 -0
  391. package/dist/tegel/p-ebbffa8a.entry.js +1 -0
  392. package/dist/tegel/p-ec26fc38.js +1 -0
  393. package/dist/tegel/p-ed076d47.entry.js +1 -0
  394. package/dist/tegel/p-ef887910.entry.js +1 -0
  395. package/dist/tegel/p-f4b70868.entry.js +1 -0
  396. package/dist/tegel/p-f52a0b63.entry.js +1 -0
  397. package/dist/tegel/p-f5bf214b.entry.js +1 -0
  398. package/dist/tegel/p-fd1b5923.entry.js +1 -0
  399. package/dist/tegel/tegel.css +109 -0
  400. package/dist/tegel/tegel.esm.js +1 -0
  401. package/dist/types/components/accordion/accordion-item/accordion-item.d.ts +17 -0
  402. package/dist/types/components/accordion/accordion.d.ts +7 -0
  403. package/dist/types/components/accordion/accordion.stories.d.ts +77 -0
  404. package/dist/types/components/badge/badge.stories.d.ts +66 -0
  405. package/dist/types/components/badge/badges.d.ts +16 -0
  406. package/dist/types/components/banner/banner.stories.d.ts +68 -0
  407. package/dist/types/components/banner/sdds-banner.d.ts +48 -0
  408. package/dist/types/components/banner/sdds-banner.stories.d.ts +109 -0
  409. package/dist/types/components/block/block-native.stories.d.ts +31 -0
  410. package/dist/types/components/block/sdds-block.d.ts +9 -0
  411. package/dist/types/components/block/sdds-block.stories.d.ts +32 -0
  412. package/dist/types/components/breadcrumb/breadcrumb-item/breadcrumb-item.d.ts +9 -0
  413. package/dist/types/components/breadcrumb/breadcrumb.d.ts +5 -0
  414. package/dist/types/components/breadcrumb/breadcrumb.stories.d.ts +12 -0
  415. package/dist/types/components/button/button-component.d.ts +18 -0
  416. package/dist/types/components/button/button-native.stories.d.ts +148 -0
  417. package/dist/types/components/button/button-webcomponent.stories.d.ts +147 -0
  418. package/dist/types/components/card/card.stories.d.ts +138 -0
  419. package/dist/types/components/card/sdds-card.d.ts +39 -0
  420. package/dist/types/components/card/sdds-card.stories.d.ts +139 -0
  421. package/dist/types/components/checkbox/checkbox.stories.d.ts +39 -0
  422. package/dist/types/components/checkbox/sdds-checkbox.d.ts +38 -0
  423. package/dist/types/components/checkbox/sdds-checkbox.stories.d.ts +40 -0
  424. package/dist/types/components/chips/chips.stories.d.ts +77 -0
  425. package/dist/types/components/data-table/native-table.stories.d.ts +133 -0
  426. package/dist/types/components/data-table/table/table.d.ts +47 -0
  427. package/dist/types/components/data-table/table-body/table-body.d.ts +54 -0
  428. package/dist/types/components/data-table/table-body-cell/table-body-cell.d.ts +24 -0
  429. package/dist/types/components/data-table/table-body-row/table-body-row.d.ts +27 -0
  430. package/dist/types/components/data-table/table-body-row-expandable/table-body-row-expandable.d.ts +27 -0
  431. package/dist/types/components/data-table/table-component-basic.stories.d.ts +101 -0
  432. package/dist/types/components/data-table/table-component-batch-actions.stories.d.ts +99 -0
  433. package/dist/types/components/data-table/table-component-bodydata.stories.d.ts +38 -0
  434. package/dist/types/components/data-table/table-component-custom-width.stories.d.ts +148 -0
  435. package/dist/types/components/data-table/table-component-event-listeners.stories.d.ts +88 -0
  436. package/dist/types/components/data-table/table-component-expandable-rows.stories.d.ts +88 -0
  437. package/dist/types/components/data-table/table-component-filtering.stories.d.ts +101 -0
  438. package/dist/types/components/data-table/table-component-multiselect.stories.d.ts +101 -0
  439. package/dist/types/components/data-table/table-component-pagination.stories.d.ts +101 -0
  440. package/dist/types/components/data-table/table-component-sorting.stories.d.ts +100 -0
  441. package/dist/types/components/data-table/table-footer/table-footer.d.ts +50 -0
  442. package/dist/types/components/data-table/table-header/table-header.d.ts +27 -0
  443. package/dist/types/components/data-table/table-header-cell/table-header-cell.d.ts +44 -0
  444. package/dist/types/components/data-table/table-toolbar/table-toolbar.d.ts +22 -0
  445. package/dist/types/components/datetime/datetime.d.ts +42 -0
  446. package/dist/types/components/datetime/datetime.stories.d.ts +127 -0
  447. package/dist/types/components/divider/divider.stories.d.ts +65 -0
  448. package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.d.ts +42 -0
  449. package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.stories.d.ts +73 -0
  450. package/dist/types/components/dropdown/dropdown-native.stories.d.ts +57 -0
  451. package/dist/types/components/dropdown/dropdown-option/dropdown-option.d.ts +19 -0
  452. package/dist/types/components/dropdown/dropdown-wc-default.stories.d.ts +129 -0
  453. package/dist/types/components/dropdown/dropdown-wc-multiselect.stories.d.ts +115 -0
  454. package/dist/types/components/dropdown/dropdown.d.ts +58 -0
  455. package/dist/types/components/footer/footer.stories.d.ts +45 -0
  456. package/dist/types/components/header/header-all.stories.d.ts +29 -0
  457. package/dist/types/components/header/header-default.stories.d.ts +29 -0
  458. package/dist/types/components/header/header-inline.stories.d.ts +29 -0
  459. package/dist/types/components/header/header-search.stories.d.ts +29 -0
  460. package/dist/types/components/header/header-toolbar.stories.d.ts +29 -0
  461. package/dist/types/components/icon/icon-font.stories.d.ts +38 -0
  462. package/dist/types/components/icon/icon-web-component.stories.d.ts +38 -0
  463. package/dist/types/components/icon/icon.d.ts +12 -0
  464. package/dist/types/components/link/link.stories.d.ts +33 -0
  465. package/dist/types/components/link/sdds-link.d.ts +13 -0
  466. package/dist/types/components/link/sdds-link.stories.d.ts +58 -0
  467. package/dist/types/components/message/message.stories.d.ts +69 -0
  468. package/dist/types/components/message/sdds-message.d.ts +14 -0
  469. package/dist/types/components/message/sdds-message.stories.d.ts +87 -0
  470. package/dist/types/components/modal/modal-native.stories.d.ts +59 -0
  471. package/dist/types/components/modal/modal-webcomponent.stories.d.ts +52 -0
  472. package/dist/types/components/modal/modal.d.ts +17 -0
  473. package/dist/types/components/popover-canvas/popover-canvas.d.ts +24 -0
  474. package/dist/types/components/popover-canvas/popover-canvas.stories.d.ts +25 -0
  475. package/dist/types/components/popover-menu/popover-menu-icons.stories.d.ts +27 -0
  476. package/dist/types/components/popover-menu/popover-menu.d.ts +24 -0
  477. package/dist/types/components/popover-menu/popover-menu.stories.d.ts +27 -0
  478. package/dist/types/components/radio-button/radio-button-component.stories.d.ts +39 -0
  479. package/dist/types/components/radio-button/radio-button.d.ts +26 -0
  480. package/dist/types/components/radio-button/radio-button.stories.d.ts +33 -0
  481. package/dist/types/components/side-menu/side-menu.stories.d.ts +42 -0
  482. package/dist/types/components/slider/slider.d.ts +86 -0
  483. package/dist/types/components/slider/slider.stories.d.ts +169 -0
  484. package/dist/types/components/spinner/spinner.d.ts +7 -0
  485. package/dist/types/components/spinner/spinner.stories.d.ts +37 -0
  486. package/dist/types/components/stepper/stepper.stories.d.ts +56 -0
  487. package/dist/types/components/tabs/inline-tabs-default/inline-tab/inline-tab.d.ts +6 -0
  488. package/dist/types/components/tabs/inline-tabs-default/inline-tabs.d.ts +40 -0
  489. package/dist/types/components/tabs/inline-tabs-default/inline-tabs.stories.d.ts +49 -0
  490. package/dist/types/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.d.ts +20 -0
  491. package/dist/types/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.d.ts +30 -0
  492. package/dist/types/components/tabs/navigation-tabs/navigation-tabs.d.ts +20 -0
  493. package/dist/types/components/tabs/navigation-tabs/navigation-tabs.stories.d.ts +13 -0
  494. package/dist/types/components/textarea/textarea.d.ts +48 -0
  495. package/dist/types/components/textarea/textarea.stories.d.ts +116 -0
  496. package/dist/types/components/textfield/textfield.d.ts +52 -0
  497. package/dist/types/components/textfield/textfield.stories.d.ts +180 -0
  498. package/dist/types/components/toast/sdds-toast.d.ts +36 -0
  499. package/dist/types/components/toast/sdds-toast.stories.d.ts +56 -0
  500. package/dist/types/components/toast/toast.stories.d.ts +69 -0
  501. package/dist/types/components/toggle/sdds-toggle.d.ts +34 -0
  502. package/dist/types/components/toggle/sdds-toggle.stories.d.ts +74 -0
  503. package/dist/types/components/toggle/toggle.stories.d.ts +55 -0
  504. package/dist/types/components/tooltip/tooltip.d.ts +24 -0
  505. package/dist/types/components/tooltip/tooltip.stories.d.ts +54 -0
  506. package/dist/types/components/utility/colour/background-color.stories.d.ts +58 -0
  507. package/dist/types/components/utility/colour/text-color.stories.d.ts +58 -0
  508. package/dist/types/components.d.ts +2643 -0
  509. package/dist/types/foundations-stories/colour/colour-brand.stories.d.ts +13 -0
  510. package/dist/types/foundations-stories/colour/colour-scales.stories.d.ts +13 -0
  511. package/dist/types/foundations-stories/colour/colour-semantic.stories.d.ts +13 -0
  512. package/dist/types/foundations-stories/grid/grid.stories.d.ts +35 -0
  513. package/dist/types/foundations-stories/spacing/spacing-element.stories.d.ts +8 -0
  514. package/dist/types/foundations-stories/spacing/spacing-layout.stories.d.ts +8 -0
  515. package/dist/types/foundations-stories/typography/typography-body.stories.d.ts +8 -0
  516. package/dist/types/foundations-stories/typography/typography-detail.stories.d.ts +8 -0
  517. package/dist/types/foundations-stories/typography/typography-headline.stories.d.ts +21 -0
  518. package/dist/types/foundations-stories/typography/typography-paragraph.stories.d.ts +8 -0
  519. package/dist/types/global.d.ts +2 -0
  520. package/dist/types/index.d.ts +1 -0
  521. package/dist/types/stencil-public-runtime.d.ts +1581 -0
  522. package/dist/types/utils/utils.d.ts +2 -0
  523. package/loader/cdn.js +3 -0
  524. package/loader/index.cjs.js +3 -0
  525. package/loader/index.d.ts +12 -0
  526. package/loader/index.es2017.js +3 -0
  527. package/loader/index.js +4 -0
  528. package/loader/package.json +11 -0
  529. package/package.json +1 -1
  530. package/readme.md +34 -0
@@ -0,0 +1,156 @@
1
+ :host {
2
+ outline: 0 !important;
3
+ box-sizing: border-box;
4
+ }
5
+ :host * {
6
+ box-sizing: border-box;
7
+ }
8
+
9
+ .sdds-inline-tabs {
10
+ overflow: hidden;
11
+ outline: 0;
12
+ }
13
+ .sdds-inline-tabs-header {
14
+ position: relative;
15
+ }
16
+ .sdds-inline-tabs-main {
17
+ background-color: var(--sdds-inline-tabs-main-background);
18
+ padding: 24px 24px 48px;
19
+ }
20
+ .sdds-inline-tabs-wrapper {
21
+ display: flex;
22
+ overflow-x: scroll;
23
+ scrollbar-width: none;
24
+ }
25
+ .sdds-inline-tabs-wrapper::-webkit-scrollbar {
26
+ display: none;
27
+ }
28
+ .sdds-inline-tabs--forward, .sdds-inline-tabs--back {
29
+ cursor: pointer;
30
+ width: 48px;
31
+ height: 100%;
32
+ border: 0;
33
+ position: absolute;
34
+ top: 0;
35
+ background-color: var(--sdds-inline-tabs-scroll-btn-background);
36
+ display: flex;
37
+ justify-content: center;
38
+ align-items: center;
39
+ opacity: 0;
40
+ pointer-events: none;
41
+ }
42
+ .sdds-inline-tabs--forward__show, .sdds-inline-tabs--back__show {
43
+ opacity: 1;
44
+ pointer-events: all;
45
+ }
46
+ .sdds-inline-tabs--forward:hover, .sdds-inline-tabs--back:hover {
47
+ background-color: var(--sdds-inline-tabs-scroll-btn-background-hover);
48
+ }
49
+ .sdds-inline-tabs--forward:active, .sdds-inline-tabs--back:active {
50
+ background-color: var(--sdds-inline-tabs-scroll-btn-background-active);
51
+ }
52
+ .sdds-inline-tabs--forward:focus, .sdds-inline-tabs--back:focus {
53
+ outline: 2px solid var(--sdds-blue-400);
54
+ outline-offset: -2px;
55
+ }
56
+ .sdds-inline-tabs--forward svg, .sdds-inline-tabs--back svg {
57
+ fill: var(--sdds-inline-tabs-scroll-btn-color);
58
+ }
59
+ .sdds-inline-tabs--back {
60
+ left: 0;
61
+ }
62
+ .sdds-inline-tabs--forward {
63
+ right: 0;
64
+ }
65
+ .sdds-inline-tabs--tab {
66
+ font: var(--sdds-headline-07);
67
+ letter-spacing: var(--sdds-headline-07-ls);
68
+ cursor: pointer;
69
+ border: 0;
70
+ color: var(--sdds-inline-tabs-tab-color);
71
+ background-color: var(--sdds-inline-tabs-tab-background);
72
+ padding: 16px;
73
+ min-width: 142px;
74
+ text-decoration: none;
75
+ display: block;
76
+ position: relative;
77
+ transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out;
78
+ white-space: nowrap;
79
+ flex-shrink: 0;
80
+ text-align: left;
81
+ outline: none;
82
+ }
83
+ .sdds-inline-tabs--tab > * {
84
+ opacity: 0.6;
85
+ }
86
+ .sdds-inline-tabs--tab:not(:last-child) {
87
+ border-right: 1px solid var(--sdds-inline-tabs-tab-border-color);
88
+ }
89
+ .sdds-inline-tabs--tab::after {
90
+ content: " ";
91
+ position: absolute;
92
+ top: 0;
93
+ right: 0;
94
+ left: 0;
95
+ margin-left: auto;
96
+ width: 0;
97
+ margin-right: auto;
98
+ height: 2px;
99
+ background-color: var(--sdds-inline-tabs-tab-indicator-background);
100
+ transition: width 0.15s ease-in-out;
101
+ }
102
+ .sdds-inline-tabs--tab:hover {
103
+ background-color: var(--sdds-inline-tabs-tab-background-hover);
104
+ color: var(--sdds-inline-tabs-tab-color-hover);
105
+ text-decoration: none;
106
+ }
107
+ .sdds-inline-tabs--tab:focus {
108
+ outline: 2px solid var(--sdds-blue-400);
109
+ outline-offset: -2px;
110
+ }
111
+ .sdds-inline-tabs--tab__active {
112
+ background-color: var(--sdds-inline-tabs-tab-background-active);
113
+ color: var(--sdds-inline-tabs-tab-color-active);
114
+ cursor: initial;
115
+ border-right: 1px solid transparent !important;
116
+ }
117
+ .sdds-inline-tabs--tab__active > * {
118
+ opacity: 1;
119
+ }
120
+ .sdds-inline-tabs--tab__active:hover {
121
+ background-color: var(--sdds-inline-tabs-tab-background-active);
122
+ }
123
+ .sdds-inline-tabs--tab__active::after {
124
+ width: calc(100% + 2px);
125
+ left: -1px;
126
+ background-color: var(--sdds-inline-tabs-tab-indicator-background-active);
127
+ }
128
+ .sdds-inline-tabs--tab__active::before {
129
+ content: " ";
130
+ background-color: var(--sdds-inline-tabs-tab-background-active);
131
+ width: 1px;
132
+ top: 0;
133
+ bottom: 0;
134
+ left: -1px;
135
+ display: block;
136
+ position: absolute;
137
+ }
138
+ .sdds-inline-tabs--tab__active:first-child:focus::before {
139
+ left: 0;
140
+ }
141
+ .sdds-inline-tabs--tab:disabled, .sdds-inline-tabs--tab__disabled {
142
+ cursor: initial;
143
+ color: var(--sdds-navigation-tabs-tab-color-disabled);
144
+ pointer-events: none;
145
+ }
146
+ .sdds-inline-tabs--tab:disabled > *, .sdds-inline-tabs--tab__disabled > * {
147
+ opacity: 0.16;
148
+ }
149
+
150
+ .sdds-inline-tabs--tab__active {
151
+ background-color: var(--sdds-inline-tabs-tab-background-active);
152
+ }
153
+
154
+ .sdds-inline-tabs-main {
155
+ background-color: var(--sdds-inline-tabs-main-background);
156
+ }
@@ -0,0 +1,312 @@
1
+ import { Host, h } from '@stencil/core';
2
+ function generateKeyFromName(name) {
3
+ return name
4
+ .replace(/\s/g, '-')
5
+ .replace(/[^a-z0-9-]/gi, '')
6
+ .toLowerCase();
7
+ }
8
+ export class InlineTabs {
9
+ constructor() {
10
+ this.startingTab = null; // name of the tab to show by default (infered from either "default-tab"-prop (on component) or "default"-prop (on a slotted child)
11
+ this.navWrapperElement = null; // reference to container with nav buttons
12
+ this.tabWrapperElement = null; // reference to container with slotted children
13
+ this.componentWidth = 0; // visible width of this component
14
+ this.buttonsWidth = 0; // total width of all nav items combined
15
+ this.scrollWidth = 0; // total amount that is possible to scroll in the nav wrapper
16
+ this.useAutoHeight = false; // set height for slotted children or not
17
+ this.defaultTab = '';
18
+ this.autoHeight = false;
19
+ this.modeVariant = null;
20
+ this.tabs = [];
21
+ this.buttonWidth = 0;
22
+ this.tabHeight = 0;
23
+ this.showLeftScroll = false;
24
+ this.showRightScroll = false;
25
+ }
26
+ /** used for switching to a tab programmatically */
27
+ async showTab(key) {
28
+ this.switchToTab(key);
29
+ }
30
+ componentWillLoad() {
31
+ this.initComponent();
32
+ }
33
+ initComponent(createInitialState = true) {
34
+ if (this.autoHeight) {
35
+ this.useAutoHeight = true;
36
+ }
37
+ this.tabs = Array.from(this.host.children).map((item, index) => {
38
+ const name = item.label ? item.label : item.getAttribute('name') || `Tab ${index + 1}`;
39
+ const key = generateKeyFromName(name);
40
+ if (item.default) {
41
+ this.startingTab = key;
42
+ }
43
+ let disabled = false;
44
+ if (item.disabled) {
45
+ disabled = true;
46
+ }
47
+ return {
48
+ name,
49
+ key,
50
+ element: item,
51
+ disabled,
52
+ visible: true,
53
+ initialDisplay: window.getComputedStyle(item).display,
54
+ };
55
+ });
56
+ if (createInitialState) {
57
+ this.setInitialState();
58
+ }
59
+ this.tabs = Array.from(this.tabs);
60
+ }
61
+ calculateButtonWidth() {
62
+ const navButtons = this.navWrapperElement.querySelectorAll('button.sdds-inline-tabs--tab');
63
+ let best = 0;
64
+ Array.from(navButtons).forEach((navButton) => {
65
+ const oldStyle = navButton.style.width;
66
+ // eslint-disable-next-line no-param-reassign
67
+ navButton.style.width = '';
68
+ const width = navButton.clientWidth;
69
+ // eslint-disable-next-line no-param-reassign
70
+ navButton.style.width = oldStyle;
71
+ if (navButton.clientWidth > best) {
72
+ best = width;
73
+ }
74
+ });
75
+ this.buttonWidth = best;
76
+ }
77
+ calculateTabHeight() {
78
+ let best = 0;
79
+ this.tabs.forEach((_, tabIndex) => {
80
+ const tab = this.tabs[tabIndex];
81
+ // TODO: add comment on what this does
82
+ const oldStyle = tab.element.style.display;
83
+ tab.element.style.display = '';
84
+ const height = tab.element.clientHeight;
85
+ tab.element.style.display = oldStyle;
86
+ if (height > best) {
87
+ best = height;
88
+ }
89
+ });
90
+ this.tabHeight = best;
91
+ }
92
+ componentDidRender() {
93
+ this.calculateTabHeight();
94
+ this.calculateButtonWidth();
95
+ }
96
+ componentDidLoad() {
97
+ const mutationObserver = new MutationObserver(( /* mutations, observer */) => {
98
+ const visibleTab = this.tabs.find((tab) => tab.visible);
99
+ this.initComponent(false);
100
+ this.calculateTabHeight();
101
+ this.calculateButtonWidth();
102
+ if (visibleTab) {
103
+ this.switchToTab(visibleTab.key);
104
+ }
105
+ });
106
+ const resizeObserver = new ResizeObserver((entries) => {
107
+ entries.forEach((entry) => {
108
+ const componentWidth = entry.contentRect.width;
109
+ let buttonsWidth = 0;
110
+ const navButtons = entry.target.querySelectorAll('button.sdds-inline-tabs--tab');
111
+ Array.from(navButtons).forEach((navButton) => {
112
+ buttonsWidth += navButton.clientWidth;
113
+ });
114
+ this.componentWidth = componentWidth;
115
+ this.buttonsWidth = buttonsWidth;
116
+ this.scrollWidth = buttonsWidth - componentWidth;
117
+ if (this.buttonsWidth > this.componentWidth) {
118
+ this.evaluateScrollButtons();
119
+ }
120
+ else {
121
+ this.showLeftScroll = false;
122
+ this.showRightScroll = false;
123
+ }
124
+ this.calculateTabHeight();
125
+ });
126
+ });
127
+ mutationObserver.observe(this.host, {
128
+ childList: true,
129
+ attributes: true,
130
+ });
131
+ resizeObserver.observe(this.navWrapperElement);
132
+ this.calculateButtonWidth();
133
+ this.calculateTabHeight();
134
+ }
135
+ setInitialState() {
136
+ if (this.defaultTab) {
137
+ this.startingTab = this.defaultTab;
138
+ }
139
+ this.tabs.forEach((tab, index) => {
140
+ if (this.startingTab) {
141
+ if (tab.key !== this.startingTab) {
142
+ this.hideTab(index);
143
+ }
144
+ }
145
+ else {
146
+ if (index > 0) {
147
+ this.hideTab(index);
148
+ }
149
+ }
150
+ });
151
+ }
152
+ unhideTab(tabIndex) {
153
+ const tab = this.tabs[tabIndex];
154
+ tab.element.style.display = '';
155
+ tab.visible = true;
156
+ }
157
+ hideTab(tabIndex) {
158
+ const tab = this.tabs[tabIndex];
159
+ tab.element.style.display = 'none';
160
+ tab.visible = false;
161
+ }
162
+ switchToTab(key) {
163
+ this.tabs.forEach((tab, index) => {
164
+ if (tab.key === key) {
165
+ this.unhideTab(index);
166
+ }
167
+ else {
168
+ this.hideTab(index);
169
+ }
170
+ });
171
+ this.tabs = Array.from(this.tabs);
172
+ }
173
+ scrollRight() {
174
+ const scroll = this.navWrapperElement.scrollLeft;
175
+ this.navWrapperElement.scrollLeft = scroll + this.buttonWidth;
176
+ this.evaluateScrollButtons();
177
+ }
178
+ scrollLeft() {
179
+ const scroll = this.navWrapperElement.scrollLeft;
180
+ this.navWrapperElement.scrollLeft = scroll - this.buttonWidth;
181
+ this.evaluateScrollButtons();
182
+ }
183
+ evaluateScrollButtons() {
184
+ const scroll = this.navWrapperElement.scrollLeft;
185
+ if (scroll >= this.scrollWidth) {
186
+ this.showRightScroll = false;
187
+ }
188
+ else {
189
+ this.showRightScroll = true;
190
+ }
191
+ if (scroll <= 0) {
192
+ this.showLeftScroll = false;
193
+ }
194
+ else {
195
+ this.showLeftScroll = true;
196
+ }
197
+ }
198
+ render() {
199
+ const style = {};
200
+ if (this.useAutoHeight) {
201
+ style.height = `${this.tabHeight}px`;
202
+ }
203
+ return (h(Host, { class: `${this.modeVariant !== null ? `sdds-mode-variant-${this.modeVariant}` : ''}` }, h("div", { class: `sdds-inline-tabs sdds-inline-tabs` }, h("nav", { class: "sdds-inline-tabs-header" }, h("div", { ref: (el) => {
204
+ this.navWrapperElement = el;
205
+ }, class: "sdds-inline-tabs-wrapper" }, this.tabs.map((tab) => (h("button", { style: { width: `${this.buttonWidth}px` }, disabled: tab.disabled, class: `sdds-inline-tabs--tab ${tab.visible ? 'sdds-inline-tabs--tab__active' : ''}`, onClick: () => this.switchToTab(tab.key) }, h("span", null, tab.name))))), h("div", { class: "sdds-inline-tabs-header-navigation" }, h("button", { class: `sdds-inline-tabs--forward ${this.showRightScroll ? 'sdds-inline-tabs--back__show' : ''}`, disabled: !this.showRightScroll, onClick: () => this.scrollRight() }, h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M6.1147 17.3291C5.87062 17.0851 5.87062 16.6893 6.1147 16.4453L12.2948 10.2652C12.4412 10.1187 12.4412 9.8813 12.2948 9.73485L6.1147 3.55476C5.87062 3.31068 5.87062 2.91496 6.1147 2.67088C6.35878 2.4268 6.75451 2.4268 6.99858 2.67088L13.1787 8.85097C13.8133 9.48557 13.8133 10.5145 13.1787 11.1491L6.99858 17.3291C6.75451 17.5732 6.35878 17.5732 6.1147 17.3291Z" }))), h("button", { class: `sdds-inline-tabs--back ${this.showLeftScroll ? 'sdds-inline-tabs--back__show' : ''}`, disabled: !this.showLeftScroll, onClick: () => this.scrollLeft() }, h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M13.8853 2.67085C14.1294 2.91493 14.1294 3.31066 13.8853 3.55473L7.70522 9.73482C7.55878 9.88127 7.55878 10.1187 7.70522 10.2652L13.8853 16.4452C14.1294 16.6893 14.1294 17.085 13.8853 17.3291C13.6412 17.5732 13.2455 17.5732 13.0014 17.3291L6.82134 11.149C6.18674 10.5144 6.18674 9.48554 6.82134 8.85094L13.0014 2.67085C13.2455 2.42677 13.6412 2.42677 13.8853 2.67085Z" }))))), h("div", { ref: (el) => {
206
+ this.tabWrapperElement = el;
207
+ }, class: "sdds-inline-tabs-main", style: style }, h("slot", null)))));
208
+ }
209
+ static get is() { return "sdds-inline-tabs"; }
210
+ static get encapsulation() { return "shadow"; }
211
+ static get originalStyleUrls() {
212
+ return {
213
+ "$": ["inline-tabs.scss"]
214
+ };
215
+ }
216
+ static get styleUrls() {
217
+ return {
218
+ "$": ["inline-tabs.css"]
219
+ };
220
+ }
221
+ static get properties() {
222
+ return {
223
+ "defaultTab": {
224
+ "type": "string",
225
+ "mutable": false,
226
+ "complexType": {
227
+ "original": "string",
228
+ "resolved": "string",
229
+ "references": {}
230
+ },
231
+ "required": false,
232
+ "optional": false,
233
+ "docs": {
234
+ "tags": [],
235
+ "text": "either use this (default-tab=\"...\") or read attribute \"default\" from one of the slotted children."
236
+ },
237
+ "attribute": "default-tab",
238
+ "reflect": false,
239
+ "defaultValue": "''"
240
+ },
241
+ "autoHeight": {
242
+ "type": "boolean",
243
+ "mutable": false,
244
+ "complexType": {
245
+ "original": "boolean",
246
+ "resolved": "boolean",
247
+ "references": {}
248
+ },
249
+ "required": false,
250
+ "optional": false,
251
+ "docs": {
252
+ "tags": [],
253
+ "text": "different height settings. right now only supports \"auto\", otherwise ignored"
254
+ },
255
+ "attribute": "auto-height",
256
+ "reflect": false,
257
+ "defaultValue": "false"
258
+ },
259
+ "modeVariant": {
260
+ "type": "string",
261
+ "mutable": false,
262
+ "complexType": {
263
+ "original": "'primary' | 'secondary'",
264
+ "resolved": "\"primary\" | \"secondary\"",
265
+ "references": {}
266
+ },
267
+ "required": false,
268
+ "optional": false,
269
+ "docs": {
270
+ "tags": [],
271
+ "text": "Variant of the tabs, primary= on white, secondary= on grey50"
272
+ },
273
+ "attribute": "mode-variant",
274
+ "reflect": false,
275
+ "defaultValue": "null"
276
+ }
277
+ };
278
+ }
279
+ static get states() {
280
+ return {
281
+ "tabs": {},
282
+ "buttonWidth": {},
283
+ "tabHeight": {},
284
+ "showLeftScroll": {},
285
+ "showRightScroll": {}
286
+ };
287
+ }
288
+ static get methods() {
289
+ return {
290
+ "showTab": {
291
+ "complexType": {
292
+ "signature": "(key: string) => Promise<void>",
293
+ "parameters": [{
294
+ "tags": [],
295
+ "text": ""
296
+ }],
297
+ "references": {
298
+ "Promise": {
299
+ "location": "global"
300
+ }
301
+ },
302
+ "return": "Promise<void>"
303
+ },
304
+ "docs": {
305
+ "text": "used for switching to a tab programmatically",
306
+ "tags": []
307
+ }
308
+ }
309
+ };
310
+ }
311
+ static get elementRef() { return "host"; }
312
+ }
@@ -0,0 +1,71 @@
1
+ import { formatHtmlPreview } from '../../../utils/utils';
2
+ import readme from './readme.md';
3
+ import readmeTab from './inline-tab/readme.md';
4
+ export default {
5
+ title: 'Components/Tabs',
6
+ parameters: {
7
+ notes: { 'Inline Tabs': readme, 'Inline Tab': readmeTab },
8
+ backgrounds: { default: 'white' },
9
+ design: [
10
+ {
11
+ name: 'Figma',
12
+ type: 'figma',
13
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=10544%3A32834&t=Ne6myqwca5m00de7-1',
14
+ },
15
+ {
16
+ name: 'Link',
17
+ type: 'link',
18
+ url: 'https://www.figma.com/file/d8bTgEx7h694MSesi2CTLF/Tegel-UI-Library?node-id=10544%3A32834&t=Ne6myqwca5m00de7-1',
19
+ },
20
+ ],
21
+ },
22
+ argTypes: {
23
+ autoHeight: {
24
+ name: 'Same height',
25
+ description: 'Make all tab panels as tall as the tallest tab panel',
26
+ control: {
27
+ type: 'boolean',
28
+ },
29
+ },
30
+ modeVariant: {
31
+ name: 'Mode variant',
32
+ control: {
33
+ type: 'radio',
34
+ },
35
+ options: ['Inherit from parent', 'Primary', 'Secondary'],
36
+ table: {
37
+ defaultValue: { summary: 'Inherit from parent' },
38
+ },
39
+ },
40
+ backgrounds: {
41
+ table: {
42
+ disable: true,
43
+ },
44
+ },
45
+ },
46
+ args: {
47
+ autoHeight: false,
48
+ modeVariant: 'Inherit from parent',
49
+ },
50
+ };
51
+ // eslint-disable-next-line arrow-body-style
52
+ const Template = ({ autoHeight = false, modeVariant }) => {
53
+ return formatHtmlPreview(`
54
+ <sdds-inline-tabs ${autoHeight ? 'auto-height' : ''} ${modeVariant !== 'Inherit from parent' ? `mode-variant="${modeVariant.toLowerCase()}"` : ''}>
55
+ <sdds-inline-tab label="Tab with tall content">
56
+ <div data-name="Tab with tall content">
57
+ Tab panel 1
58
+ <div style="width:200px; height:200px; background: linear-gradient(125deg,rgba(255, 0, 0, 1) 0%,rgba(255, 255, 0, 1) 33%,rgba(0, 192, 255, 1) 66%,rgba(192, 0, 255, 1) 100%);"></div>
59
+ </div>
60
+ </sdds-inline-tab>
61
+ <sdds-inline-tab label="Default tab" default>
62
+ Tab panel 2
63
+ </sdds-inline-tab>
64
+ <sdds-inline-tab label="Disabled tab" disabled>
65
+ Tab panel 3
66
+ </sdds-inline-tab>
67
+ </sdds-inline-tabs>
68
+ `);
69
+ };
70
+ export const InlineTabs = Template.bind({});
71
+ InlineTabs.args = {};
@@ -0,0 +1,141 @@
1
+ .sdds-inline-tabs-fullbleed {
2
+ box-sizing: border-box;
3
+ display: flex;
4
+ position: relative;
5
+ /* tab */
6
+ /* tab states */
7
+ }
8
+ .sdds-inline-tabs-fullbleed * {
9
+ box-sizing: border-box;
10
+ }
11
+ .sdds-inline-tabs-fullbleed::after {
12
+ content: " ";
13
+ display: block;
14
+ border-bottom: 1px solid var(--sdds-inline-tabs-fullbleed-horizontal-divider-background);
15
+ opacity: var(--sdds-inline-tabs-fullbleed-horizontal-divider-opacity);
16
+ left: 0;
17
+ right: 0;
18
+ bottom: 0;
19
+ position: absolute;
20
+ }
21
+ .sdds-inline-tabs-fullbleed-wrapper {
22
+ display: flex;
23
+ flex-wrap: nowrap;
24
+ width: 100%;
25
+ overflow-x: scroll;
26
+ scrollbar-width: none;
27
+ }
28
+ .sdds-inline-tabs-fullbleed-wrapper::-webkit-scrollbar {
29
+ display: none;
30
+ }
31
+ .sdds-inline-tabs-fullbleed--forward, .sdds-inline-tabs-fullbleed--back {
32
+ cursor: pointer;
33
+ width: 48px;
34
+ height: 100%;
35
+ border: 0;
36
+ position: absolute;
37
+ right: 0;
38
+ top: 0;
39
+ background-color: var(--sdds-inline-tabs-fullbleed-scroll-btn-background);
40
+ display: flex;
41
+ justify-content: center;
42
+ align-items: center;
43
+ opacity: 0;
44
+ pointer-events: none;
45
+ }
46
+ .sdds-inline-tabs-fullbleed--forward__show, .sdds-inline-tabs-fullbleed--back__show {
47
+ opacity: 1;
48
+ pointer-events: all;
49
+ }
50
+ .sdds-inline-tabs-fullbleed--forward:hover, .sdds-inline-tabs-fullbleed--back:hover {
51
+ background-color: var(--sdds-inline-tabs-fullbleed-scroll-btn-background-hover);
52
+ }
53
+ .sdds-inline-tabs-fullbleed--forward:active, .sdds-inline-tabs-fullbleed--back:active {
54
+ background-color: var(--sdds-inline-tabs-fullbleed-scroll-btn-background-active);
55
+ }
56
+ .sdds-inline-tabs-fullbleed--forward:focus, .sdds-inline-tabs-fullbleed--back:focus {
57
+ outline: 2px solid var(--sdds-blue-400);
58
+ outline-offset: -2px;
59
+ }
60
+ .sdds-inline-tabs-fullbleed--forward svg, .sdds-inline-tabs-fullbleed--back svg {
61
+ fill: var(--sdds-inline-tabs-scroll-btn-color);
62
+ }
63
+ .sdds-inline-tabs-fullbleed-centered {
64
+ justify-content: center;
65
+ }
66
+ ::slotted(.sdds-inline-tabs-fullbleed--tab) {
67
+ font: var(--sdds-headline-07);
68
+ letter-spacing: var(--sdds-headline-07-ls);
69
+ color: var(--sdds-inline-tabs-fullbleed-tab-color);
70
+ opacity: 0.6;
71
+ padding: 16px 0;
72
+ margin-right: 32px;
73
+ text-decoration: none;
74
+ display: block;
75
+ position: relative;
76
+ transition: color 0.15s ease-in-out;
77
+ white-space: nowrap;
78
+ text-align: left;
79
+ }
80
+ ::slotted(.sdds-inline-tabs-fullbleed--tab)::after {
81
+ content: " ";
82
+ position: absolute;
83
+ bottom: 0;
84
+ right: 0;
85
+ left: 0;
86
+ margin-left: auto;
87
+ width: 0;
88
+ margin-right: auto;
89
+ height: 2px;
90
+ background-color: var(--sdds-inline-tabs-fullbleed-tab-indicator-background-hover);
91
+ transition: width 0.15s ease-in-out;
92
+ z-index: 1;
93
+ }
94
+ ::slotted(.sdds-inline-tabs-fullbleed--tab__active) {
95
+ color: var(--sdds-inline-tabs-fullbleed-tab-color-active);
96
+ opacity: 1;
97
+ }
98
+ ::slotted(.sdds-inline-tabs-fullbleed--tab__active)::after {
99
+ width: 100%;
100
+ background-color: var(--sdds-inline-tabs-fullbleed-tab-indicator-background-active);
101
+ }
102
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:first-child) {
103
+ margin-left: 32px;
104
+ }
105
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:last-child) {
106
+ margin-right: 32px;
107
+ }
108
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:hover) {
109
+ color: var(--sdds-inline-tabs-fullbleed-tab-color-hover);
110
+ opacity: 1;
111
+ }
112
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:hover)::after {
113
+ width: 100%;
114
+ }
115
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:focus) {
116
+ outline: 2px solid var(--sdds-blue-400);
117
+ outline-offset: -2px;
118
+ color: var(--sdds-inline-tabs-fullbleed-tab-color-focus);
119
+ opacity: 1;
120
+ }
121
+ ::slotted(.sdds-inline-tabs-fullbleed--tab:focus)::after {
122
+ width: 0;
123
+ }
124
+ ::slotted(.sdds-inline-tabs-fullbleed--tab__active:focus)::after {
125
+ width: 100%;
126
+ }
127
+ ::slotted(.sdds-inline-tabs-fullbleed--tab__disabled) {
128
+ color: var(--sdds-inline-tabs-fullbleed-tab-color-disabled);
129
+ pointer-events: none;
130
+ opacity: var(--sdds-inline-tabs-fullbleed-tab-color-opacity-disabled);
131
+ }
132
+
133
+ .sdds-inline-tabs-fullbleed {
134
+ background-color: var(--sdds-inline-tabs-fullbleed-tab-background);
135
+ }
136
+ .sdds-inline-tabs-fullbleed .sdds-inline-tabs-fullbleed--forward {
137
+ background-color: var(--sdds-inline-tabs-fullbleed-tab-background);
138
+ }
139
+ .sdds-inline-tabs-fullbleed .sdds-inline-tabs-fullbleed--back {
140
+ background-color: var(--sdds-inline-tabs-fullbleed-tab-background);
141
+ }