@scania/tegel 0.0.4 → 0.0.5

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 (745) hide show
  1. package/dist/cjs/{index-18eb94f0.js → index-5ad19933.js} +36 -9
  2. package/dist/cjs/index-5ad19933.js.map +1 -0
  3. package/dist/cjs/loader.cjs.js +2 -2
  4. package/dist/cjs/sdds-accordion-item.cjs.entry.js +1 -1
  5. package/dist/cjs/sdds-accordion.cjs.entry.js +2 -3
  6. package/dist/cjs/sdds-accordion.cjs.entry.js.map +1 -1
  7. package/dist/cjs/sdds-badges.cjs.entry.js +1 -1
  8. package/dist/cjs/sdds-banner.cjs.entry.js +2 -2
  9. package/dist/cjs/sdds-banner.cjs.entry.js.map +1 -1
  10. package/dist/cjs/sdds-block.cjs.entry.js +1 -1
  11. package/dist/cjs/sdds-body-cell_2.cjs.entry.js +12 -12
  12. package/dist/cjs/sdds-body-cell_2.cjs.entry.js.map +1 -1
  13. package/dist/cjs/sdds-breadcrumb-link.cjs.entry.js +27 -0
  14. package/dist/cjs/sdds-breadcrumb-link.cjs.entry.js.map +1 -0
  15. package/dist/cjs/sdds-breadcrumb.cjs.entry.js +4 -4
  16. package/dist/cjs/sdds-breadcrumb.cjs.entry.js.map +1 -1
  17. package/dist/cjs/sdds-button.cjs.entry.js +2 -2
  18. package/dist/cjs/sdds-button.cjs.entry.js.map +1 -1
  19. package/dist/cjs/sdds-card.cjs.entry.js +2 -2
  20. package/dist/cjs/sdds-card.cjs.entry.js.map +1 -1
  21. package/dist/cjs/sdds-checkbox.cjs.entry.js +1 -1
  22. package/dist/cjs/sdds-datetime.cjs.entry.js +15 -6
  23. package/dist/cjs/sdds-datetime.cjs.entry.js.map +1 -1
  24. package/dist/cjs/sdds-divider.cjs.entry.js +22 -0
  25. package/dist/cjs/sdds-divider.cjs.entry.js.map +1 -0
  26. package/dist/cjs/sdds-dropdown-filter.cjs.entry.js +10 -7
  27. package/dist/cjs/sdds-dropdown-filter.cjs.entry.js.map +1 -1
  28. package/dist/cjs/sdds-dropdown_2.cjs.entry.js +20 -20
  29. package/dist/cjs/sdds-dropdown_2.cjs.entry.js.map +1 -1
  30. package/dist/cjs/sdds-folder-tabs-button.cjs.entry.js +29 -0
  31. package/dist/cjs/sdds-folder-tabs-button.cjs.entry.js.map +1 -0
  32. package/dist/cjs/sdds-folder-tabs-link.cjs.entry.js +34 -0
  33. package/dist/cjs/sdds-folder-tabs-link.cjs.entry.js.map +1 -0
  34. package/dist/cjs/sdds-folder-tabs.cjs.entry.js +180 -0
  35. package/dist/cjs/sdds-folder-tabs.cjs.entry.js.map +1 -0
  36. package/dist/cjs/sdds-footer-link-group.cjs.entry.js +1 -1
  37. package/dist/cjs/sdds-footer-link.cjs.entry.js +1 -1
  38. package/dist/cjs/sdds-footer.cjs.entry.js +1 -1
  39. package/dist/cjs/sdds-header-cell.cjs.entry.js +9 -13
  40. package/dist/cjs/sdds-header-cell.cjs.entry.js.map +1 -1
  41. package/dist/cjs/sdds-icon.cjs.entry.js +1 -1
  42. package/dist/cjs/sdds-inline-tabs-button.cjs.entry.js +24 -0
  43. package/dist/cjs/sdds-inline-tabs-button.cjs.entry.js.map +1 -0
  44. package/dist/cjs/sdds-inline-tabs-link.cjs.entry.js +29 -0
  45. package/dist/cjs/sdds-inline-tabs-link.cjs.entry.js.map +1 -0
  46. package/dist/cjs/sdds-inline-tabs.cjs.entry.js +113 -148
  47. package/dist/cjs/sdds-inline-tabs.cjs.entry.js.map +1 -1
  48. package/dist/cjs/sdds-link.cjs.entry.js +1 -1
  49. package/dist/cjs/sdds-message.cjs.entry.js +1 -1
  50. package/dist/cjs/sdds-modal.cjs.entry.js +67 -22
  51. package/dist/cjs/sdds-modal.cjs.entry.js.map +1 -1
  52. package/dist/cjs/sdds-navigation-tabs-button.cjs.entry.js +24 -0
  53. package/dist/cjs/sdds-navigation-tabs-button.cjs.entry.js.map +1 -0
  54. package/dist/cjs/sdds-navigation-tabs-link.cjs.entry.js +29 -0
  55. package/dist/cjs/sdds-navigation-tabs-link.cjs.entry.js.map +1 -0
  56. package/dist/cjs/sdds-navigation-tabs.cjs.entry.js +69 -24
  57. package/dist/cjs/sdds-navigation-tabs.cjs.entry.js.map +1 -1
  58. package/dist/cjs/sdds-popover-canvas.cjs.entry.js +68 -41
  59. package/dist/cjs/sdds-popover-canvas.cjs.entry.js.map +1 -1
  60. package/dist/cjs/sdds-popover-menu.cjs.entry.js +1 -1
  61. package/dist/cjs/sdds-radio-button.cjs.entry.js +6 -2
  62. package/dist/cjs/sdds-radio-button.cjs.entry.js.map +1 -1
  63. package/dist/cjs/sdds-slider.cjs.entry.js +9 -9
  64. package/dist/cjs/sdds-slider.cjs.entry.js.map +1 -1
  65. package/dist/cjs/sdds-spinner.cjs.entry.js +1 -1
  66. package/dist/cjs/sdds-stepper-item.cjs.entry.js +1 -1
  67. package/dist/cjs/sdds-stepper.cjs.entry.js +1 -1
  68. package/dist/cjs/sdds-table-body-row-expandable.cjs.entry.js +6 -6
  69. package/dist/cjs/sdds-table-body-row-expandable.cjs.entry.js.map +1 -1
  70. package/dist/cjs/sdds-table-body.cjs.entry.js +13 -13
  71. package/dist/cjs/sdds-table-body.cjs.entry.js.map +1 -1
  72. package/dist/cjs/sdds-table-footer.cjs.entry.js +7 -7
  73. package/dist/cjs/sdds-table-footer.cjs.entry.js.map +1 -1
  74. package/dist/cjs/sdds-table-header.cjs.entry.js +6 -6
  75. package/dist/cjs/sdds-table-header.cjs.entry.js.map +1 -1
  76. package/dist/cjs/sdds-table-toolbar.cjs.entry.js +4 -4
  77. package/dist/cjs/sdds-table-toolbar.cjs.entry.js.map +1 -1
  78. package/dist/cjs/sdds-table.cjs.entry.js +10 -10
  79. package/dist/cjs/sdds-table.cjs.entry.js.map +1 -1
  80. package/dist/cjs/sdds-textarea.cjs.entry.js +12 -12
  81. package/dist/cjs/sdds-textarea.cjs.entry.js.map +1 -1
  82. package/dist/cjs/sdds-textfield.cjs.entry.js +13 -24
  83. package/dist/cjs/sdds-textfield.cjs.entry.js.map +1 -1
  84. package/dist/cjs/sdds-toast.cjs.entry.js +1 -1
  85. package/dist/cjs/sdds-toggle.cjs.entry.js +2 -2
  86. package/dist/cjs/sdds-toggle.cjs.entry.js.map +1 -1
  87. package/dist/cjs/sdds-tooltip.cjs.entry.js +1 -1
  88. package/dist/cjs/tegel.cjs.js +2 -2
  89. package/dist/collection/collection-manifest.json +10 -4
  90. package/dist/collection/components/accordion/accordion.js +1 -20
  91. package/dist/collection/components/accordion/accordion.js.map +1 -1
  92. package/dist/collection/components/accordion/accordion.stories.js +2 -2
  93. package/dist/collection/components/accordion/accordion.stories.js.map +1 -1
  94. package/dist/collection/components/badge/badge.stories.js +0 -3
  95. package/dist/collection/components/badge/badge.stories.js.map +1 -1
  96. package/dist/collection/components/banner/sdds-banner.css +1 -0
  97. package/dist/collection/components/banner/sdds-banner.stories.js +2 -5
  98. package/dist/collection/components/banner/sdds-banner.stories.js.map +1 -1
  99. package/dist/collection/components/breadcrumb/{sdds-breadcrumb-item/sdds-breadcrumb-item.css → sdds-breadcrumb-link/sdds-breadcrumb-link.css} +10 -10
  100. package/dist/collection/components/breadcrumb/{sdds-breadcrumb-item/sdds-breadcrumb-item.js → sdds-breadcrumb-link/sdds-breadcrumb-link.js} +7 -7
  101. package/dist/collection/components/breadcrumb/sdds-breadcrumb-link/sdds-breadcrumb-link.js.map +1 -0
  102. package/dist/collection/components/breadcrumb/sdds-breadcrumb.css +5 -20
  103. package/dist/collection/components/breadcrumb/sdds-breadcrumb.js +2 -2
  104. package/dist/collection/components/breadcrumb/sdds-breadcrumb.js.map +1 -1
  105. package/dist/collection/components/breadcrumb/sdds-breadcrumb.stories.js +6 -5
  106. package/dist/collection/components/breadcrumb/sdds-breadcrumb.stories.js.map +1 -1
  107. package/dist/collection/components/button/button-native.stories.js +39 -32
  108. package/dist/collection/components/button/button-native.stories.js.map +1 -1
  109. package/dist/collection/components/button/button-webcomponent.stories.js +36 -33
  110. package/dist/collection/components/button/button-webcomponent.stories.js.map +1 -1
  111. package/dist/collection/components/button/button.css +1 -1
  112. package/dist/collection/components/card/card.stories.js +48 -51
  113. package/dist/collection/components/card/card.stories.js.map +1 -1
  114. package/dist/collection/components/card/sdds-card.css +1 -0
  115. package/dist/collection/components/card/sdds-card.stories.js +27 -36
  116. package/dist/collection/components/card/sdds-card.stories.js.map +1 -1
  117. package/dist/collection/components/checkbox/checkbox.stories.js +20 -12
  118. package/dist/collection/components/checkbox/checkbox.stories.js.map +1 -1
  119. package/dist/collection/components/checkbox/sdds-checkbox.stories.js +20 -12
  120. package/dist/collection/components/checkbox/sdds-checkbox.stories.js.map +1 -1
  121. package/dist/collection/components/chips/chips.stories.js +51 -31
  122. package/dist/collection/components/chips/chips.stories.js.map +1 -1
  123. package/dist/collection/components/data-table/native-table.stories.js +44 -67
  124. package/dist/collection/components/data-table/native-table.stories.js.map +1 -1
  125. package/dist/collection/components/data-table/table/table.js +17 -14
  126. package/dist/collection/components/data-table/table/table.js.map +1 -1
  127. package/dist/collection/components/data-table/table-body/table-body.js +37 -28
  128. package/dist/collection/components/data-table/table-body/table-body.js.map +1 -1
  129. package/dist/collection/components/data-table/table-body-cell/table-body-cell.js +10 -10
  130. package/dist/collection/components/data-table/table-body-cell/table-body-cell.js.map +1 -1
  131. package/dist/collection/components/data-table/table-body-row/table-body-row.js +24 -18
  132. package/dist/collection/components/data-table/table-body-row/table-body-row.js.map +1 -1
  133. package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.js +19 -13
  134. package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.js.map +1 -1
  135. package/dist/collection/components/data-table/table-component-basic.stories.js +61 -39
  136. package/dist/collection/components/data-table/table-component-basic.stories.js.map +1 -1
  137. package/dist/collection/components/data-table/table-component-batch-actions.stories.js +61 -40
  138. package/dist/collection/components/data-table/table-component-batch-actions.stories.js.map +1 -1
  139. package/dist/collection/components/data-table/table-component-bodydata.stories.js +0 -6
  140. package/dist/collection/components/data-table/table-component-bodydata.stories.js.map +1 -1
  141. package/dist/collection/components/data-table/table-component-custom-width.stories.js +31 -55
  142. package/dist/collection/components/data-table/table-component-custom-width.stories.js.map +1 -1
  143. package/dist/collection/components/data-table/table-component-event-listeners.stories.js +65 -41
  144. package/dist/collection/components/data-table/table-component-event-listeners.stories.js.map +1 -1
  145. package/dist/collection/components/data-table/table-component-expandable-rows.stories.js +59 -35
  146. package/dist/collection/components/data-table/table-component-expandable-rows.stories.js.map +1 -1
  147. package/dist/collection/components/data-table/table-component-filtering.stories.js +63 -44
  148. package/dist/collection/components/data-table/table-component-filtering.stories.js.map +1 -1
  149. package/dist/collection/components/data-table/table-component-multiselect.stories.js +67 -45
  150. package/dist/collection/components/data-table/table-component-multiselect.stories.js.map +1 -1
  151. package/dist/collection/components/data-table/table-component-pagination.stories.js +65 -43
  152. package/dist/collection/components/data-table/table-component-pagination.stories.js.map +1 -1
  153. package/dist/collection/components/data-table/table-component-sorting.stories.js +87 -31
  154. package/dist/collection/components/data-table/table-component-sorting.stories.js.map +1 -1
  155. package/dist/collection/components/data-table/table-footer/table-footer.js +18 -15
  156. package/dist/collection/components/data-table/table-footer/table-footer.js.map +1 -1
  157. package/dist/collection/components/data-table/table-header/table-header.js +17 -14
  158. package/dist/collection/components/data-table/table-header/table-header.js.map +1 -1
  159. package/dist/collection/components/data-table/table-header-cell/table-header-cell.js +27 -31
  160. package/dist/collection/components/data-table/table-header-cell/table-header-cell.js.map +1 -1
  161. package/dist/collection/components/data-table/table-toolbar/table-toolbar.js +7 -7
  162. package/dist/collection/components/data-table/table-toolbar/table-toolbar.js.map +1 -1
  163. package/dist/collection/components/datetime/datetime.js +56 -11
  164. package/dist/collection/components/datetime/datetime.js.map +1 -1
  165. package/dist/collection/components/datetime/datetime.stories.js +62 -62
  166. package/dist/collection/components/datetime/datetime.stories.js.map +1 -1
  167. package/dist/collection/components/divider/divider-component.css +16 -0
  168. package/dist/collection/components/divider/divider-webcomponent.stories.js +62 -0
  169. package/dist/collection/components/divider/divider-webcomponent.stories.js.map +1 -0
  170. package/dist/collection/components/divider/divider.js +44 -0
  171. package/dist/collection/components/divider/divider.js.map +1 -0
  172. package/dist/collection/components/divider/divider.stories.js +13 -16
  173. package/dist/collection/components/divider/divider.stories.js.map +1 -1
  174. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js +35 -13
  175. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js.map +1 -1
  176. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.stories.js +78 -26
  177. package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.stories.js.map +1 -1
  178. package/dist/collection/components/dropdown/dropdown-native.stories.js +35 -22
  179. package/dist/collection/components/dropdown/dropdown-native.stories.js.map +1 -1
  180. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +21 -16
  181. package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js.map +1 -1
  182. package/dist/collection/components/dropdown/dropdown-wc-default.stories.js +58 -51
  183. package/dist/collection/components/dropdown/dropdown-wc-default.stories.js.map +1 -1
  184. package/dist/collection/components/dropdown/dropdown-wc-multiselect.stories.js +73 -50
  185. package/dist/collection/components/dropdown/dropdown-wc-multiselect.stories.js.map +1 -1
  186. package/dist/collection/components/dropdown/dropdown.css +6 -161
  187. package/dist/collection/components/dropdown/dropdown.js +22 -17
  188. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  189. package/dist/collection/components/footer/footer.stories.js +5 -5
  190. package/dist/collection/components/footer/footer.stories.js.map +1 -1
  191. package/dist/collection/components/footer/webcomponent/sdds-footer.stories.js +3 -3
  192. package/dist/collection/components/footer/webcomponent/sdds-footer.stories.js.map +1 -1
  193. package/dist/collection/components/header/header-all.stories.js +4 -2
  194. package/dist/collection/components/header/header-all.stories.js.map +1 -1
  195. package/dist/collection/components/header/header-default.stories.js +4 -2
  196. package/dist/collection/components/header/header-default.stories.js.map +1 -1
  197. package/dist/collection/components/header/header-inline.stories.js +4 -2
  198. package/dist/collection/components/header/header-inline.stories.js.map +1 -1
  199. package/dist/collection/components/header/header-search.stories.js +4 -2
  200. package/dist/collection/components/header/header-search.stories.js.map +1 -1
  201. package/dist/collection/components/header/header-toolbar.stories.js +4 -2
  202. package/dist/collection/components/header/header-toolbar.stories.js.map +1 -1
  203. package/dist/collection/components/link/link.stories.js +15 -9
  204. package/dist/collection/components/link/link.stories.js.map +1 -1
  205. package/dist/collection/components/link/sdds-link.stories.js +15 -15
  206. package/dist/collection/components/link/sdds-link.stories.js.map +1 -1
  207. package/dist/collection/components/message/message.stories.js +50 -32
  208. package/dist/collection/components/message/message.stories.js.map +1 -1
  209. package/dist/collection/components/message/sdds-message.stories.js +23 -22
  210. package/dist/collection/components/message/sdds-message.stories.js.map +1 -1
  211. package/dist/collection/components/modal/modal-native.stories.js +28 -20
  212. package/dist/collection/components/modal/modal-native.stories.js.map +1 -1
  213. package/dist/collection/components/modal/modal-webcomponent.stories.js +33 -22
  214. package/dist/collection/components/modal/modal-webcomponent.stories.js.map +1 -1
  215. package/dist/collection/components/modal/modal.js +147 -29
  216. package/dist/collection/components/modal/modal.js.map +1 -1
  217. package/dist/collection/components/popover-canvas/popover-canvas.css +0 -4
  218. package/dist/collection/components/popover-canvas/popover-canvas.js +99 -46
  219. package/dist/collection/components/popover-canvas/popover-canvas.js.map +1 -1
  220. package/dist/collection/components/popover-canvas/popover-canvas.stories.js +16 -14
  221. package/dist/collection/components/popover-canvas/popover-canvas.stories.js.map +1 -1
  222. package/dist/collection/components/popover-menu/popover-menu-icons.stories.js +7 -3
  223. package/dist/collection/components/popover-menu/popover-menu-icons.stories.js.map +1 -1
  224. package/dist/collection/components/popover-menu/popover-menu.stories.js +7 -3
  225. package/dist/collection/components/popover-menu/popover-menu.stories.js.map +1 -1
  226. package/dist/collection/components/radio-button/radio-button-component.stories.js +1 -6
  227. package/dist/collection/components/radio-button/radio-button-component.stories.js.map +1 -1
  228. package/dist/collection/components/radio-button/radio-button.js +5 -1
  229. package/dist/collection/components/radio-button/radio-button.js.map +1 -1
  230. package/dist/collection/components/radio-button/radio-button.stories.js +9 -6
  231. package/dist/collection/components/radio-button/radio-button.stories.js.map +1 -1
  232. package/dist/collection/components/slider/slider.js +19 -19
  233. package/dist/collection/components/slider/slider.js.map +1 -1
  234. package/dist/collection/components/slider/slider.stories.js +93 -67
  235. package/dist/collection/components/slider/slider.stories.js.map +1 -1
  236. package/dist/collection/components/spinner/spinner.stories.js +8 -2
  237. package/dist/collection/components/spinner/spinner.stories.js.map +1 -1
  238. package/dist/collection/components/stepper/stepper.stories.js +29 -17
  239. package/dist/collection/components/stepper/stepper.stories.js.map +1 -1
  240. package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.css +79 -0
  241. package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.js +100 -0
  242. package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.js.map +1 -0
  243. package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.css +77 -0
  244. package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.js +158 -0
  245. package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.js.map +1 -0
  246. package/dist/collection/components/tabs/folder-tabs/folder-tabs.css +64 -0
  247. package/dist/collection/components/tabs/folder-tabs/folder-tabs.js +256 -0
  248. package/dist/collection/components/tabs/folder-tabs/folder-tabs.js.map +1 -0
  249. package/dist/collection/components/tabs/folder-tabs/folder-tabs.stories.js +114 -0
  250. package/dist/collection/components/tabs/folder-tabs/folder-tabs.stories.js.map +1 -0
  251. package/dist/collection/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.css +73 -0
  252. package/dist/collection/components/tabs/{inline-tabs-default/inline-tab/inline-tab.js → inline-tabs/inline-tabs-button/sdds-inline-tabs-button.js} +12 -29
  253. package/dist/collection/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.js.map +1 -0
  254. package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.css +75 -0
  255. package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.js +122 -0
  256. package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.js.map +1 -0
  257. package/dist/collection/components/tabs/inline-tabs/inline-tabs.css +76 -0
  258. package/dist/collection/components/tabs/inline-tabs/inline-tabs.js +261 -0
  259. package/dist/collection/components/tabs/inline-tabs/inline-tabs.js.map +1 -0
  260. package/dist/collection/components/tabs/inline-tabs/inline-tabs.stories.js +109 -0
  261. package/dist/collection/components/tabs/inline-tabs/inline-tabs.stories.js.map +1 -0
  262. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.css +73 -0
  263. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.js +64 -0
  264. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.js.map +1 -0
  265. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.css +73 -0
  266. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.js +122 -0
  267. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.js.map +1 -0
  268. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.css +37 -118
  269. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +114 -26
  270. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js.map +1 -1
  271. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js +79 -9
  272. package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js.map +1 -1
  273. package/dist/collection/components/textarea/textarea.css +42 -123
  274. package/dist/collection/components/textarea/textarea.js +11 -10
  275. package/dist/collection/components/textarea/textarea.js.map +1 -1
  276. package/dist/collection/components/textarea/textarea.stories.js +59 -53
  277. package/dist/collection/components/textarea/textarea.stories.js.map +1 -1
  278. package/dist/collection/components/textfield/textfield.css +91 -175
  279. package/dist/collection/components/textfield/textfield.js +12 -22
  280. package/dist/collection/components/textfield/textfield.js.map +1 -1
  281. package/dist/collection/components/textfield/textfield.stories.js +87 -74
  282. package/dist/collection/components/textfield/textfield.stories.js.map +1 -1
  283. package/dist/collection/components/toast/sdds-toast.stories.js +6 -6
  284. package/dist/collection/components/toast/sdds-toast.stories.js.map +1 -1
  285. package/dist/collection/components/toast/toast.stories.js +19 -17
  286. package/dist/collection/components/toast/toast.stories.js.map +1 -1
  287. package/dist/collection/components/toggle/sdds-toggle.js +1 -1
  288. package/dist/collection/components/toggle/sdds-toggle.js.map +1 -1
  289. package/dist/collection/components/toggle/sdds-toggle.stories.js +19 -19
  290. package/dist/collection/components/toggle/sdds-toggle.stories.js.map +1 -1
  291. package/dist/collection/components/toggle/toggle.stories.js +19 -14
  292. package/dist/collection/components/toggle/toggle.stories.js.map +1 -1
  293. package/dist/collection/components/tooltip/tooltip.stories.js +30 -18
  294. package/dist/collection/components/tooltip/tooltip.stories.js.map +1 -1
  295. package/dist/components/dropdown-option.js +9 -11
  296. package/dist/components/dropdown-option.js.map +1 -1
  297. package/dist/components/dropdown.js +13 -10
  298. package/dist/components/dropdown.js.map +1 -1
  299. package/dist/components/sdds-accordion.js +1 -3
  300. package/dist/components/sdds-accordion.js.map +1 -1
  301. package/dist/components/sdds-banner.js +1 -1
  302. package/dist/components/sdds-banner.js.map +1 -1
  303. package/dist/components/{sdds-breadcrumb-item.d.ts → sdds-breadcrumb-link.d.ts} +4 -4
  304. package/dist/components/sdds-breadcrumb-link.js +47 -0
  305. package/dist/components/sdds-breadcrumb-link.js.map +1 -0
  306. package/dist/components/sdds-breadcrumb.js +3 -3
  307. package/dist/components/sdds-breadcrumb.js.map +1 -1
  308. package/dist/components/sdds-button.js +1 -1
  309. package/dist/components/sdds-button.js.map +1 -1
  310. package/dist/components/sdds-card.js +1 -1
  311. package/dist/components/sdds-card.js.map +1 -1
  312. package/dist/components/sdds-datetime.js +14 -5
  313. package/dist/components/sdds-datetime.js.map +1 -1
  314. package/dist/components/{sdds-inline-tab.d.ts → sdds-divider.d.ts} +4 -4
  315. package/dist/components/sdds-divider.js +38 -0
  316. package/dist/components/sdds-divider.js.map +1 -0
  317. package/dist/components/sdds-dropdown-filter.js +12 -8
  318. package/dist/components/sdds-dropdown-filter.js.map +1 -1
  319. package/dist/components/sdds-folder-tabs-button.d.ts +11 -0
  320. package/dist/components/sdds-folder-tabs-button.js +48 -0
  321. package/dist/components/sdds-folder-tabs-button.js.map +1 -0
  322. package/dist/components/sdds-folder-tabs-link.d.ts +11 -0
  323. package/dist/components/sdds-folder-tabs-link.js +56 -0
  324. package/dist/components/sdds-folder-tabs-link.js.map +1 -0
  325. package/dist/components/sdds-folder-tabs.d.ts +11 -0
  326. package/dist/components/sdds-folder-tabs.js +208 -0
  327. package/dist/components/sdds-folder-tabs.js.map +1 -0
  328. package/dist/components/sdds-header-cell.js +9 -13
  329. package/dist/components/sdds-header-cell.js.map +1 -1
  330. package/dist/components/sdds-inline-tabs-button.d.ts +11 -0
  331. package/dist/components/sdds-inline-tabs-button.js +41 -0
  332. package/dist/components/sdds-inline-tabs-button.js.map +1 -0
  333. package/dist/components/sdds-inline-tabs-link.d.ts +11 -0
  334. package/dist/components/sdds-inline-tabs-link.js +49 -0
  335. package/dist/components/sdds-inline-tabs-link.js.map +1 -0
  336. package/dist/components/sdds-inline-tabs.js +123 -155
  337. package/dist/components/sdds-inline-tabs.js.map +1 -1
  338. package/dist/components/sdds-modal.js +73 -24
  339. package/dist/components/sdds-modal.js.map +1 -1
  340. package/dist/components/sdds-navigation-tabs-button.d.ts +11 -0
  341. package/dist/components/sdds-navigation-tabs-button.js +41 -0
  342. package/dist/components/sdds-navigation-tabs-button.js.map +1 -0
  343. package/dist/components/sdds-navigation-tabs-link.d.ts +11 -0
  344. package/dist/components/sdds-navigation-tabs-link.js +49 -0
  345. package/dist/components/sdds-navigation-tabs-link.js.map +1 -0
  346. package/dist/components/sdds-navigation-tabs.js +79 -27
  347. package/dist/components/sdds-navigation-tabs.js.map +1 -1
  348. package/dist/components/sdds-popover-canvas.js +71 -42
  349. package/dist/components/sdds-popover-canvas.js.map +1 -1
  350. package/dist/components/sdds-radio-button.js +5 -1
  351. package/dist/components/sdds-radio-button.js.map +1 -1
  352. package/dist/components/sdds-slider.js +9 -9
  353. package/dist/components/sdds-slider.js.map +1 -1
  354. package/dist/components/sdds-table-body-row-expandable.js +6 -6
  355. package/dist/components/sdds-table-body-row-expandable.js.map +1 -1
  356. package/dist/components/sdds-table-body.js +13 -13
  357. package/dist/components/sdds-table-body.js.map +1 -1
  358. package/dist/components/sdds-table-footer.js +7 -7
  359. package/dist/components/sdds-table-footer.js.map +1 -1
  360. package/dist/components/sdds-table-header.js +6 -6
  361. package/dist/components/sdds-table-header.js.map +1 -1
  362. package/dist/components/sdds-table-toolbar.js +4 -4
  363. package/dist/components/sdds-table-toolbar.js.map +1 -1
  364. package/dist/components/sdds-table.js +9 -9
  365. package/dist/components/sdds-table.js.map +1 -1
  366. package/dist/components/sdds-textarea.js +12 -12
  367. package/dist/components/sdds-textarea.js.map +1 -1
  368. package/dist/components/sdds-textfield.js +13 -24
  369. package/dist/components/sdds-textfield.js.map +1 -1
  370. package/dist/components/sdds-toggle.js +1 -1
  371. package/dist/components/sdds-toggle.js.map +1 -1
  372. package/dist/components/table-body-cell.js +5 -5
  373. package/dist/components/table-body-cell.js.map +1 -1
  374. package/dist/components/table-body-row.js +8 -8
  375. package/dist/components/table-body-row.js.map +1 -1
  376. package/dist/esm/{index-96563708.js → index-fdfb114c.js} +36 -9
  377. package/dist/esm/index-fdfb114c.js.map +1 -0
  378. package/dist/esm/loader.js +3 -3
  379. package/dist/esm/sdds-accordion-item.entry.js +1 -1
  380. package/dist/esm/sdds-accordion.entry.js +2 -3
  381. package/dist/esm/sdds-accordion.entry.js.map +1 -1
  382. package/dist/esm/sdds-badges.entry.js +1 -1
  383. package/dist/esm/sdds-banner.entry.js +2 -2
  384. package/dist/esm/sdds-banner.entry.js.map +1 -1
  385. package/dist/esm/sdds-block.entry.js +1 -1
  386. package/dist/esm/sdds-body-cell_2.entry.js +12 -12
  387. package/dist/esm/sdds-body-cell_2.entry.js.map +1 -1
  388. package/dist/esm/sdds-breadcrumb-link.entry.js +23 -0
  389. package/dist/esm/sdds-breadcrumb-link.entry.js.map +1 -0
  390. package/dist/esm/sdds-breadcrumb.entry.js +4 -4
  391. package/dist/esm/sdds-breadcrumb.entry.js.map +1 -1
  392. package/dist/esm/sdds-button.entry.js +2 -2
  393. package/dist/esm/sdds-button.entry.js.map +1 -1
  394. package/dist/esm/sdds-card.entry.js +2 -2
  395. package/dist/esm/sdds-card.entry.js.map +1 -1
  396. package/dist/esm/sdds-checkbox.entry.js +1 -1
  397. package/dist/esm/sdds-datetime.entry.js +15 -6
  398. package/dist/esm/sdds-datetime.entry.js.map +1 -1
  399. package/dist/esm/sdds-divider.entry.js +18 -0
  400. package/dist/esm/sdds-divider.entry.js.map +1 -0
  401. package/dist/esm/sdds-dropdown-filter.entry.js +10 -7
  402. package/dist/esm/sdds-dropdown-filter.entry.js.map +1 -1
  403. package/dist/esm/sdds-dropdown_2.entry.js +20 -20
  404. package/dist/esm/sdds-dropdown_2.entry.js.map +1 -1
  405. package/dist/esm/sdds-folder-tabs-button.entry.js +25 -0
  406. package/dist/esm/sdds-folder-tabs-button.entry.js.map +1 -0
  407. package/dist/esm/sdds-folder-tabs-link.entry.js +30 -0
  408. package/dist/esm/sdds-folder-tabs-link.entry.js.map +1 -0
  409. package/dist/esm/sdds-folder-tabs.entry.js +176 -0
  410. package/dist/esm/sdds-folder-tabs.entry.js.map +1 -0
  411. package/dist/esm/sdds-footer-link-group.entry.js +1 -1
  412. package/dist/esm/sdds-footer-link.entry.js +1 -1
  413. package/dist/esm/sdds-footer.entry.js +1 -1
  414. package/dist/esm/sdds-header-cell.entry.js +9 -13
  415. package/dist/esm/sdds-header-cell.entry.js.map +1 -1
  416. package/dist/esm/sdds-icon.entry.js +1 -1
  417. package/dist/esm/sdds-inline-tabs-button.entry.js +20 -0
  418. package/dist/esm/sdds-inline-tabs-button.entry.js.map +1 -0
  419. package/dist/esm/sdds-inline-tabs-link.entry.js +25 -0
  420. package/dist/esm/sdds-inline-tabs-link.entry.js.map +1 -0
  421. package/dist/esm/sdds-inline-tabs.entry.js +113 -148
  422. package/dist/esm/sdds-inline-tabs.entry.js.map +1 -1
  423. package/dist/esm/sdds-link.entry.js +1 -1
  424. package/dist/esm/sdds-message.entry.js +1 -1
  425. package/dist/esm/sdds-modal.entry.js +67 -22
  426. package/dist/esm/sdds-modal.entry.js.map +1 -1
  427. package/dist/esm/sdds-navigation-tabs-button.entry.js +20 -0
  428. package/dist/esm/sdds-navigation-tabs-button.entry.js.map +1 -0
  429. package/dist/esm/sdds-navigation-tabs-link.entry.js +25 -0
  430. package/dist/esm/sdds-navigation-tabs-link.entry.js.map +1 -0
  431. package/dist/esm/sdds-navigation-tabs.entry.js +69 -24
  432. package/dist/esm/sdds-navigation-tabs.entry.js.map +1 -1
  433. package/dist/esm/sdds-popover-canvas.entry.js +68 -41
  434. package/dist/esm/sdds-popover-canvas.entry.js.map +1 -1
  435. package/dist/esm/sdds-popover-menu.entry.js +1 -1
  436. package/dist/esm/sdds-radio-button.entry.js +6 -2
  437. package/dist/esm/sdds-radio-button.entry.js.map +1 -1
  438. package/dist/esm/sdds-slider.entry.js +9 -9
  439. package/dist/esm/sdds-slider.entry.js.map +1 -1
  440. package/dist/esm/sdds-spinner.entry.js +1 -1
  441. package/dist/esm/sdds-stepper-item.entry.js +1 -1
  442. package/dist/esm/sdds-stepper.entry.js +1 -1
  443. package/dist/esm/sdds-table-body-row-expandable.entry.js +6 -6
  444. package/dist/esm/sdds-table-body-row-expandable.entry.js.map +1 -1
  445. package/dist/esm/sdds-table-body.entry.js +13 -13
  446. package/dist/esm/sdds-table-body.entry.js.map +1 -1
  447. package/dist/esm/sdds-table-footer.entry.js +7 -7
  448. package/dist/esm/sdds-table-footer.entry.js.map +1 -1
  449. package/dist/esm/sdds-table-header.entry.js +6 -6
  450. package/dist/esm/sdds-table-header.entry.js.map +1 -1
  451. package/dist/esm/sdds-table-toolbar.entry.js +4 -4
  452. package/dist/esm/sdds-table-toolbar.entry.js.map +1 -1
  453. package/dist/esm/sdds-table.entry.js +10 -10
  454. package/dist/esm/sdds-table.entry.js.map +1 -1
  455. package/dist/esm/sdds-textarea.entry.js +12 -12
  456. package/dist/esm/sdds-textarea.entry.js.map +1 -1
  457. package/dist/esm/sdds-textfield.entry.js +13 -24
  458. package/dist/esm/sdds-textfield.entry.js.map +1 -1
  459. package/dist/esm/sdds-toast.entry.js +1 -1
  460. package/dist/esm/sdds-toggle.entry.js +2 -2
  461. package/dist/esm/sdds-toggle.entry.js.map +1 -1
  462. package/dist/esm/sdds-tooltip.entry.js +1 -1
  463. package/dist/esm/tegel.js +3 -3
  464. package/dist/node_modules/@types/jest/index.d.ts +1512 -0
  465. package/dist/tegel/{p-68fca08c.entry.js → p-067789d2.entry.js} +2 -2
  466. package/dist/tegel/{p-c5537ff7.entry.js → p-12f566b7.entry.js} +2 -2
  467. package/dist/tegel/p-15c44320.entry.js +2 -0
  468. package/dist/tegel/p-15c44320.entry.js.map +1 -0
  469. package/dist/tegel/{p-525ec252.entry.js → p-1a7f94d3.entry.js} +2 -2
  470. package/dist/tegel/p-1a7f94d3.entry.js.map +1 -0
  471. package/dist/tegel/p-1baafb40.entry.js +2 -0
  472. package/dist/tegel/p-1baafb40.entry.js.map +1 -0
  473. package/dist/tegel/p-2080db62.entry.js +2 -0
  474. package/dist/tegel/p-2080db62.entry.js.map +1 -0
  475. package/dist/tegel/p-21e426f2.entry.js +2 -0
  476. package/dist/tegel/p-21e426f2.entry.js.map +1 -0
  477. package/dist/tegel/p-2c57f4bb.entry.js +2 -0
  478. package/dist/tegel/p-2c57f4bb.entry.js.map +1 -0
  479. package/dist/tegel/p-387e1798.js +3 -0
  480. package/dist/tegel/p-387e1798.js.map +1 -0
  481. package/dist/tegel/p-3a9db8c4.entry.js +2 -0
  482. package/dist/tegel/p-3a9db8c4.entry.js.map +1 -0
  483. package/dist/tegel/{p-6bdce8c1.entry.js → p-400d74c2.entry.js} +2 -2
  484. package/dist/tegel/{p-f51fe381.entry.js → p-4499e5cd.entry.js} +2 -2
  485. package/dist/tegel/p-479b1c4e.entry.js +2 -0
  486. package/dist/tegel/p-479b1c4e.entry.js.map +1 -0
  487. package/dist/tegel/p-52ecce88.entry.js +2 -0
  488. package/dist/tegel/p-52ecce88.entry.js.map +1 -0
  489. package/dist/tegel/p-58bc7a27.entry.js +2 -0
  490. package/dist/tegel/p-58bc7a27.entry.js.map +1 -0
  491. package/dist/tegel/{p-aff4d273.entry.js → p-5dc33f45.entry.js} +2 -2
  492. package/dist/tegel/p-5f6fe516.entry.js +2 -0
  493. package/dist/tegel/p-5f6fe516.entry.js.map +1 -0
  494. package/dist/tegel/{p-2fad34c4.entry.js → p-64dd37d4.entry.js} +2 -2
  495. package/dist/tegel/p-64dd37d4.entry.js.map +1 -0
  496. package/dist/tegel/{p-e5e10d8f.entry.js → p-750b7e5f.entry.js} +2 -2
  497. package/dist/tegel/{p-f9dacc11.entry.js → p-792e8c5d.entry.js} +2 -2
  498. package/dist/tegel/{p-b9ec54c5.entry.js → p-7991d22f.entry.js} +2 -2
  499. package/dist/tegel/p-7d2f2f58.entry.js +2 -0
  500. package/dist/tegel/p-7d2f2f58.entry.js.map +1 -0
  501. package/dist/tegel/{p-b2f1ec40.entry.js → p-7f10356d.entry.js} +2 -2
  502. package/dist/tegel/p-7f22cee6.entry.js +2 -0
  503. package/dist/tegel/p-7f22cee6.entry.js.map +1 -0
  504. package/dist/tegel/p-872bef70.entry.js +2 -0
  505. package/dist/tegel/p-872bef70.entry.js.map +1 -0
  506. package/dist/tegel/{p-5c390692.entry.js → p-8ee9e2f5.entry.js} +2 -2
  507. package/dist/tegel/p-8ee9e2f5.entry.js.map +1 -0
  508. package/dist/tegel/{p-9904d7ec.entry.js → p-90af19c6.entry.js} +2 -2
  509. package/dist/tegel/p-90af19c6.entry.js.map +1 -0
  510. package/dist/tegel/{p-262dca00.entry.js → p-a2cbef2c.entry.js} +2 -2
  511. package/dist/tegel/{p-b2e46497.entry.js → p-a5cd0006.entry.js} +2 -2
  512. package/dist/tegel/{p-72099402.entry.js → p-a61db32b.entry.js} +2 -2
  513. package/dist/tegel/p-a905302b.entry.js +2 -0
  514. package/dist/tegel/p-a905302b.entry.js.map +1 -0
  515. package/dist/tegel/p-aa487e40.entry.js +2 -0
  516. package/dist/tegel/p-aa487e40.entry.js.map +1 -0
  517. package/dist/tegel/p-ae631412.entry.js +2 -0
  518. package/dist/tegel/p-ae631412.entry.js.map +1 -0
  519. package/dist/tegel/p-b2269b6b.entry.js +2 -0
  520. package/dist/tegel/p-b2269b6b.entry.js.map +1 -0
  521. package/dist/tegel/{p-92869ad1.entry.js → p-b6fc0de7.entry.js} +2 -2
  522. package/dist/tegel/{p-92869ad1.entry.js.map → p-b6fc0de7.entry.js.map} +1 -1
  523. package/dist/tegel/{p-cd08f5f0.entry.js → p-b9b329c0.entry.js} +2 -2
  524. package/dist/tegel/{p-fc96cf21.entry.js → p-bd09c184.entry.js} +2 -2
  525. package/dist/tegel/{p-675d10c6.entry.js → p-bdae6bc9.entry.js} +2 -2
  526. package/dist/tegel/{p-675d10c6.entry.js.map → p-bdae6bc9.entry.js.map} +1 -1
  527. package/dist/tegel/p-bdaf0bc2.entry.js +2 -0
  528. package/dist/tegel/p-bdaf0bc2.entry.js.map +1 -0
  529. package/dist/tegel/p-bdceb07c.entry.js +2 -0
  530. package/dist/tegel/p-bdceb07c.entry.js.map +1 -0
  531. package/dist/tegel/{p-ebffa726.entry.js → p-c3351320.entry.js} +2 -2
  532. package/dist/tegel/p-c3351320.entry.js.map +1 -0
  533. package/dist/tegel/{p-e662e68d.entry.js → p-c4d28002.entry.js} +2 -2
  534. package/dist/tegel/p-c6c75439.entry.js +2 -0
  535. package/dist/tegel/p-c6c75439.entry.js.map +1 -0
  536. package/dist/tegel/{p-25af32a7.entry.js → p-ccb82bc3.entry.js} +2 -2
  537. package/dist/tegel/p-ccb82bc3.entry.js.map +1 -0
  538. package/dist/tegel/p-cfacd8e6.entry.js +2 -0
  539. package/dist/tegel/p-cfacd8e6.entry.js.map +1 -0
  540. package/dist/tegel/p-d517eaef.entry.js +2 -0
  541. package/dist/tegel/p-d517eaef.entry.js.map +1 -0
  542. package/dist/tegel/p-d87ce5e9.entry.js +2 -0
  543. package/dist/tegel/p-d87ce5e9.entry.js.map +1 -0
  544. package/dist/tegel/p-dffd418e.entry.js +2 -0
  545. package/dist/tegel/p-dffd418e.entry.js.map +1 -0
  546. package/dist/tegel/{p-a4127075.entry.js → p-e60b9366.entry.js} +2 -2
  547. package/dist/tegel/{p-5e50ce81.entry.js → p-ef5487a3.entry.js} +2 -2
  548. package/dist/tegel/p-ef5487a3.entry.js.map +1 -0
  549. package/dist/tegel/p-fcb9e2c1.entry.js +2 -0
  550. package/dist/tegel/p-fcb9e2c1.entry.js.map +1 -0
  551. package/dist/tegel/tegel.css +10 -22
  552. package/dist/tegel/tegel.esm.js +1 -1
  553. package/dist/tegel/tegel.esm.js.map +1 -1
  554. package/dist/types/components/accordion/accordion.d.ts +0 -2
  555. package/dist/types/components/accordion/accordion.stories.d.ts +2 -2
  556. package/dist/types/components/badge/badge.stories.d.ts +0 -5
  557. package/dist/types/components/banner/sdds-banner.stories.d.ts +1 -6
  558. package/dist/types/components/breadcrumb/{sdds-breadcrumb-item/sdds-breadcrumb-item.d.ts → sdds-breadcrumb-link/sdds-breadcrumb-link.d.ts} +1 -1
  559. package/dist/types/components/breadcrumb/sdds-breadcrumb.stories.d.ts +2 -1
  560. package/dist/types/components/button/button-native.stories.d.ts +36 -25
  561. package/dist/types/components/button/button-webcomponent.stories.d.ts +30 -26
  562. package/dist/types/components/card/card.stories.d.ts +29 -30
  563. package/dist/types/components/card/sdds-card.stories.d.ts +13 -24
  564. package/dist/types/components/checkbox/checkbox.stories.d.ts +17 -5
  565. package/dist/types/components/checkbox/sdds-checkbox.stories.d.ts +17 -5
  566. package/dist/types/components/chips/chips.stories.d.ts +42 -18
  567. package/dist/types/components/data-table/native-table.stories.d.ts +17 -31
  568. package/dist/types/components/data-table/table/table.d.ts +5 -4
  569. package/dist/types/components/data-table/table-body/table-body.d.ts +9 -9
  570. package/dist/types/components/data-table/table-body-cell/table-body-cell.d.ts +4 -4
  571. package/dist/types/components/data-table/table-body-row/table-body-row.d.ts +7 -7
  572. package/dist/types/components/data-table/table-body-row-expandable/table-body-row-expandable.d.ts +6 -6
  573. package/dist/types/components/data-table/table-component-basic.stories.d.ts +54 -11
  574. package/dist/types/components/data-table/table-component-batch-actions.stories.d.ts +54 -14
  575. package/dist/types/components/data-table/table-component-bodydata.stories.d.ts +0 -5
  576. package/dist/types/components/data-table/table-component-custom-width.stories.d.ts +15 -32
  577. package/dist/types/components/data-table/table-component-event-listeners.stories.d.ts +54 -11
  578. package/dist/types/components/data-table/table-component-expandable-rows.stories.d.ts +54 -11
  579. package/dist/types/components/data-table/table-component-filtering.stories.d.ts +54 -16
  580. package/dist/types/components/data-table/table-component-multiselect.stories.d.ts +57 -14
  581. package/dist/types/components/data-table/table-component-pagination.stories.d.ts +58 -15
  582. package/dist/types/components/data-table/table-component-sorting.stories.d.ts +93 -10
  583. package/dist/types/components/data-table/table-footer/table-footer.d.ts +7 -7
  584. package/dist/types/components/data-table/table-header/table-header.d.ts +6 -6
  585. package/dist/types/components/data-table/table-header-cell/table-header-cell.d.ts +9 -10
  586. package/dist/types/components/data-table/table-toolbar/table-toolbar.d.ts +4 -4
  587. package/dist/types/components/datetime/datetime.d.ts +11 -5
  588. package/dist/types/components/datetime/datetime.stories.d.ts +36 -35
  589. package/dist/types/components/divider/divider-webcomponent.stories.d.ts +58 -0
  590. package/dist/types/components/divider/divider.d.ts +5 -0
  591. package/dist/types/components/divider/divider.stories.d.ts +9 -14
  592. package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.d.ts +4 -2
  593. package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.stories.d.ts +76 -12
  594. package/dist/types/components/dropdown/dropdown-native.stories.d.ts +26 -11
  595. package/dist/types/components/dropdown/dropdown-option/dropdown-option.d.ts +7 -2
  596. package/dist/types/components/dropdown/dropdown-wc-default.stories.d.ts +48 -33
  597. package/dist/types/components/dropdown/dropdown-wc-multiselect.stories.d.ts +61 -32
  598. package/dist/types/components/dropdown/dropdown.d.ts +4 -3
  599. package/dist/types/components/footer/footer.stories.d.ts +4 -4
  600. package/dist/types/components/footer/webcomponent/sdds-footer.stories.d.ts +1 -1
  601. package/dist/types/components/header/header-all.stories.d.ts +3 -1
  602. package/dist/types/components/header/header-default.stories.d.ts +3 -1
  603. package/dist/types/components/header/header-inline.stories.d.ts +3 -1
  604. package/dist/types/components/header/header-search.stories.d.ts +3 -1
  605. package/dist/types/components/header/header-toolbar.stories.d.ts +3 -1
  606. package/dist/types/components/link/link.stories.d.ts +13 -3
  607. package/dist/types/components/link/sdds-link.stories.d.ts +9 -9
  608. package/dist/types/components/message/message.stories.d.ts +32 -12
  609. package/dist/types/components/message/sdds-message.stories.d.ts +9 -8
  610. package/dist/types/components/modal/modal-native.stories.d.ts +23 -8
  611. package/dist/types/components/modal/modal-webcomponent.stories.d.ts +22 -4
  612. package/dist/types/components/modal/modal.d.ts +27 -7
  613. package/dist/types/components/popover-canvas/popover-canvas.d.ts +13 -4
  614. package/dist/types/components/popover-canvas/popover-canvas.stories.d.ts +5 -3
  615. package/dist/types/components/popover-menu/popover-menu-icons.stories.d.ts +5 -0
  616. package/dist/types/components/popover-menu/popover-menu.stories.d.ts +5 -0
  617. package/dist/types/components/radio-button/radio-button-component.stories.d.ts +1 -1
  618. package/dist/types/components/radio-button/radio-button.stories.d.ts +6 -1
  619. package/dist/types/components/slider/slider.d.ts +1 -1
  620. package/dist/types/components/slider/slider.stories.d.ts +90 -24
  621. package/dist/types/components/spinner/spinner.stories.d.ts +12 -2
  622. package/dist/types/components/stepper/sdds-stepper.d.ts +17 -0
  623. package/dist/types/components/stepper/stepper-item/sdds-stepper-item.d.ts +17 -0
  624. package/dist/types/components/stepper/stepper.stories.d.ts +24 -4
  625. package/dist/types/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.d.ts +10 -0
  626. package/dist/types/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.d.ts +16 -0
  627. package/dist/types/components/tabs/folder-tabs/folder-tabs.d.ts +38 -0
  628. package/dist/types/components/tabs/{inline-tabs-default/inline-tabs.stories.d.ts → folder-tabs/folder-tabs.stories.d.ts} +14 -11
  629. package/dist/types/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.d.ts +7 -0
  630. package/dist/types/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.d.ts +13 -0
  631. package/dist/types/components/tabs/inline-tabs/inline-tabs.d.ts +40 -0
  632. package/dist/types/components/tabs/{inline-tabs-fullbleed/inline-tabs-fullbleed.stories.d.ts → inline-tabs/inline-tabs.stories.d.ts} +16 -2
  633. package/dist/types/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.d.ts +7 -0
  634. package/dist/types/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.d.ts +13 -0
  635. package/dist/types/components/tabs/navigation-tabs/navigation-tabs.d.ts +25 -10
  636. package/dist/types/components/tabs/navigation-tabs/navigation-tabs.stories.d.ts +32 -1
  637. package/dist/types/components/textarea/textarea.stories.d.ts +39 -29
  638. package/dist/types/components/textfield/textfield.stories.d.ts +68 -47
  639. package/dist/types/components/toast/toast.stories.d.ts +8 -9
  640. package/dist/types/components/toggle/sdds-toggle.stories.d.ts +9 -9
  641. package/dist/types/components/toggle/toggle.stories.d.ts +10 -7
  642. package/dist/types/components/tooltip/tooltip.stories.d.ts +15 -3
  643. package/dist/types/components.d.ts +424 -153
  644. package/package.json +1 -1
  645. package/readme.md +23 -1
  646. package/dist/cjs/index-18eb94f0.js.map +0 -1
  647. package/dist/cjs/sdds-breadcrumb-item.cjs.entry.js +0 -27
  648. package/dist/cjs/sdds-breadcrumb-item.cjs.entry.js.map +0 -1
  649. package/dist/cjs/sdds-inline-tab.cjs.entry.js +0 -24
  650. package/dist/cjs/sdds-inline-tab.cjs.entry.js.map +0 -1
  651. package/dist/cjs/sdds-inline-tabs-fullbleed.cjs.entry.js +0 -100
  652. package/dist/cjs/sdds-inline-tabs-fullbleed.cjs.entry.js.map +0 -1
  653. package/dist/collection/components/breadcrumb/sdds-breadcrumb-item/sdds-breadcrumb-item.js.map +0 -1
  654. package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.css +0 -3
  655. package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.js.map +0 -1
  656. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.css +0 -156
  657. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.js +0 -313
  658. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.js.map +0 -1
  659. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.stories.js +0 -72
  660. package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.stories.js.map +0 -1
  661. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.css +0 -141
  662. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.js +0 -129
  663. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.js.map +0 -1
  664. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.js +0 -47
  665. package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.js.map +0 -1
  666. package/dist/components/sdds-breadcrumb-item.js +0 -47
  667. package/dist/components/sdds-breadcrumb-item.js.map +0 -1
  668. package/dist/components/sdds-inline-tab.js +0 -42
  669. package/dist/components/sdds-inline-tab.js.map +0 -1
  670. package/dist/components/sdds-inline-tabs-fullbleed.d.ts +0 -11
  671. package/dist/components/sdds-inline-tabs-fullbleed.js +0 -119
  672. package/dist/components/sdds-inline-tabs-fullbleed.js.map +0 -1
  673. package/dist/esm/index-96563708.js.map +0 -1
  674. package/dist/esm/sdds-breadcrumb-item.entry.js +0 -23
  675. package/dist/esm/sdds-breadcrumb-item.entry.js.map +0 -1
  676. package/dist/esm/sdds-inline-tab.entry.js +0 -20
  677. package/dist/esm/sdds-inline-tab.entry.js.map +0 -1
  678. package/dist/esm/sdds-inline-tabs-fullbleed.entry.js +0 -96
  679. package/dist/esm/sdds-inline-tabs-fullbleed.entry.js.map +0 -1
  680. package/dist/tegel/p-0953710b.entry.js +0 -2
  681. package/dist/tegel/p-0953710b.entry.js.map +0 -1
  682. package/dist/tegel/p-0b4eba86.js +0 -3
  683. package/dist/tegel/p-0b4eba86.js.map +0 -1
  684. package/dist/tegel/p-1eb8dd92.entry.js +0 -2
  685. package/dist/tegel/p-1eb8dd92.entry.js.map +0 -1
  686. package/dist/tegel/p-22c49f25.entry.js +0 -2
  687. package/dist/tegel/p-22c49f25.entry.js.map +0 -1
  688. package/dist/tegel/p-25af32a7.entry.js.map +0 -1
  689. package/dist/tegel/p-2d45bffe.entry.js +0 -2
  690. package/dist/tegel/p-2d45bffe.entry.js.map +0 -1
  691. package/dist/tegel/p-2fad34c4.entry.js.map +0 -1
  692. package/dist/tegel/p-336efb27.entry.js +0 -2
  693. package/dist/tegel/p-336efb27.entry.js.map +0 -1
  694. package/dist/tegel/p-33e7f7e5.entry.js +0 -2
  695. package/dist/tegel/p-33e7f7e5.entry.js.map +0 -1
  696. package/dist/tegel/p-458cda76.entry.js +0 -2
  697. package/dist/tegel/p-458cda76.entry.js.map +0 -1
  698. package/dist/tegel/p-525ec252.entry.js.map +0 -1
  699. package/dist/tegel/p-5c390692.entry.js.map +0 -1
  700. package/dist/tegel/p-5e50ce81.entry.js.map +0 -1
  701. package/dist/tegel/p-62ed6fdc.entry.js +0 -2
  702. package/dist/tegel/p-62ed6fdc.entry.js.map +0 -1
  703. package/dist/tegel/p-6e54f5a2.entry.js +0 -2
  704. package/dist/tegel/p-6e54f5a2.entry.js.map +0 -1
  705. package/dist/tegel/p-77a4950d.entry.js +0 -2
  706. package/dist/tegel/p-77a4950d.entry.js.map +0 -1
  707. package/dist/tegel/p-84e5d141.entry.js +0 -2
  708. package/dist/tegel/p-84e5d141.entry.js.map +0 -1
  709. package/dist/tegel/p-913cb5e9.entry.js +0 -2
  710. package/dist/tegel/p-913cb5e9.entry.js.map +0 -1
  711. package/dist/tegel/p-93571e36.entry.js +0 -2
  712. package/dist/tegel/p-93571e36.entry.js.map +0 -1
  713. package/dist/tegel/p-9904d7ec.entry.js.map +0 -1
  714. package/dist/tegel/p-a3741fdd.entry.js +0 -2
  715. package/dist/tegel/p-a3741fdd.entry.js.map +0 -1
  716. package/dist/tegel/p-ba975249.entry.js +0 -2
  717. package/dist/tegel/p-ba975249.entry.js.map +0 -1
  718. package/dist/tegel/p-c79b3861.entry.js +0 -2
  719. package/dist/tegel/p-c79b3861.entry.js.map +0 -1
  720. package/dist/tegel/p-d910763a.entry.js +0 -2
  721. package/dist/tegel/p-d910763a.entry.js.map +0 -1
  722. package/dist/tegel/p-e25424af.entry.js +0 -2
  723. package/dist/tegel/p-e25424af.entry.js.map +0 -1
  724. package/dist/tegel/p-ebffa726.entry.js.map +0 -1
  725. package/dist/tegel/p-fa3dbeec.entry.js +0 -2
  726. package/dist/tegel/p-fa3dbeec.entry.js.map +0 -1
  727. package/dist/types/components/tabs/inline-tabs-default/inline-tab/inline-tab.d.ts +0 -6
  728. package/dist/types/components/tabs/inline-tabs-default/inline-tabs.d.ts +0 -40
  729. package/dist/types/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.d.ts +0 -20
  730. /package/dist/tegel/{p-68fca08c.entry.js.map → p-067789d2.entry.js.map} +0 -0
  731. /package/dist/tegel/{p-c5537ff7.entry.js.map → p-12f566b7.entry.js.map} +0 -0
  732. /package/dist/tegel/{p-6bdce8c1.entry.js.map → p-400d74c2.entry.js.map} +0 -0
  733. /package/dist/tegel/{p-f51fe381.entry.js.map → p-4499e5cd.entry.js.map} +0 -0
  734. /package/dist/tegel/{p-aff4d273.entry.js.map → p-5dc33f45.entry.js.map} +0 -0
  735. /package/dist/tegel/{p-e5e10d8f.entry.js.map → p-750b7e5f.entry.js.map} +0 -0
  736. /package/dist/tegel/{p-f9dacc11.entry.js.map → p-792e8c5d.entry.js.map} +0 -0
  737. /package/dist/tegel/{p-b9ec54c5.entry.js.map → p-7991d22f.entry.js.map} +0 -0
  738. /package/dist/tegel/{p-b2f1ec40.entry.js.map → p-7f10356d.entry.js.map} +0 -0
  739. /package/dist/tegel/{p-262dca00.entry.js.map → p-a2cbef2c.entry.js.map} +0 -0
  740. /package/dist/tegel/{p-b2e46497.entry.js.map → p-a5cd0006.entry.js.map} +0 -0
  741. /package/dist/tegel/{p-72099402.entry.js.map → p-a61db32b.entry.js.map} +0 -0
  742. /package/dist/tegel/{p-cd08f5f0.entry.js.map → p-b9b329c0.entry.js.map} +0 -0
  743. /package/dist/tegel/{p-fc96cf21.entry.js.map → p-bd09c184.entry.js.map} +0 -0
  744. /package/dist/tegel/{p-e662e68d.entry.js.map → p-c4d28002.entry.js.map} +0 -0
  745. /package/dist/tegel/{p-a4127075.entry.js.map → p-e60b9366.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"file":"sdds-modal.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,QAAQ,GAAG,8+MAA8+M;;MCOl/M,KAAK;;;mBAEW,KAAK;gBAGU,IAAI;mBAGP,QAAQ;gBAGvB,KAAK;;;EAQ7B,MAAM,SAAS;IACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;GAClB;EAED,kBAAkB;IAChB,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,CAAC;IAE/D,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE;MACpD,EAAE,CAAC,gBAAgB,CAAC,OAAO,EAAE;QAC3B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;OACnB,CAAC,CAAC;KACJ,CAAC,CAAC;GACJ;EAED,WAAW,CAAC,CAAC;IACX,MAAM,UAAU,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC;IACpC,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IAC7B,IACE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,kBAAkB;OACzC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,qBAAqB,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,CAAC,EACzE;MACA,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;KACnB;GACF;EAED,kBAAkB;IAChB,IAAI,CAAC,kBAAkB,EAAE,CAAC;GAC3B;EAED,MAAM;IACJ,QACEA,QAACC,UAAI,IACH,OAAO,EAAE,CAAC,KAAK;QACb,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;OACzB,EACD,KAAK,EAAE,uBAAuB,IAAI,CAAC,IAAI,GAAG,MAAM,GAAG,MAAM,EAAE,IAE3DD,iBACE,KAAK,EAAE,cAAc,IAAI,CAAC,OAAO,GAAG,uBAAuB,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,IAC5E,IAAI,CAAC,IAAI,GAAG,cAAc,IAAI,CAAC,IAAI,EAAE,GAAG,EAC1C,GAAG,IAEHA,iBAAK,KAAK,EAAC,mBAAmB,IAC5BA,kBAAM,IAAI,EAAC,qBAAqB,GAAQ,EACxCA,oBACE,KAAK,EAAC,kBAAkB,gBACb,OAAO,EAClB,GAAG,EAAE,CAAC,EAAE;QACN,IAAI,CAAC,aAAa,GAAG,EAAiB,CAAC;OACxC,IAEDA,uBAAW,IAAI,EAAC,OAAO,EAAC,IAAI,EAAC,MAAM,GAAa,CACzC,CACL,EAENA,iBAAK,KAAK,EAAC,iBAAiB,IAC1BA,kBAAM,IAAI,EAAC,iBAAiB,GAAQ,CAChC,EAENA,iBAAK,KAAK,EAAC,oBAAoB,IAC7BA,kBAAM,IAAI,EAAC,oBAAoB,GAAQ,CACnC,CACF,CACD,EACP;GACH;;;;;;;","names":["h","Host"],"sources":["./src/components/modal/modal.scss?tag=sdds-modal&encapsulation=shadow","./src/components/modal/modal.tsx"],"sourcesContent":["@import '../../mixins/z-index';\n@import 'modal-vars';\n@import '../../mixins/box-sizing';\n@import '../../mixins/focus-state';\n\n//TODO: Find a way to create a mixin in spacings that can be used for screen size in rem\n//Media rules doesn't calculate correct with using rem\n// Screen breakpoints\n$screen-s: 320px; //320px\n$screen-md: 672px; // 672px\n$screen-l: 1056px; //1056px\n$screen-xl: 1312px; //1312px\n$screen-xxl: 1584px; //1584px\n\n$modals: (\n $screen-s: (\n xs: 100%,\n sm: 100%,\n md: 100%,\n lg: 100%,\n ),\n $screen-md: (\n xs: 75%,\n sm: 62.5%,\n md: 75%,\n lg: 100%,\n ),\n $screen-l: (\n xs: 31.25%,\n sm: 43.75%,\n md: 62.5%,\n lg: 75%,\n ),\n $screen-xl: (\n xs: 31.25%,\n sm: 37.5%,\n md: 62.5%,\n lg: 75%,\n ),\n $screen-xxl: (\n xs: 25%,\n sm: 37.5%,\n md: 50%,\n lg: 75%,\n ),\n);\n\n/* MIXINS */\n\n@mixin modal-scroll-inner {\n /* SCROLL STUFF */\n\n /* width */\n &::-webkit-scrollbar {\n width: 5px;\n background-color: var(--sdds-grey-300);\n }\n\n /* Track */\n &::-webkit-scrollbar-track {\n background-color: var(--sdds-grey-300);\n }\n\n /* Handle */\n &::-webkit-scrollbar-thumb {\n background-color: var(--sdds-grey-500);\n }\n}\n\n@mixin modal-scroll-outer {\n /* SCROLL STUFF */\n\n /* width */\n &::-webkit-scrollbar {\n width: 5px;\n background-color: var(--sdds-grey-300);\n border-radius: 0 1em 1em 0;\n }\n\n /* Track */\n &::-webkit-scrollbar-track {\n background-color: var(--sdds-grey-300);\n border-radius: 0 1em 1em 0;\n }\n\n /* Handle */\n &::-webkit-scrollbar-thumb {\n background-color: var(--sdds-grey-500);\n border-radius: 0 1em 1em 0;\n }\n}\n\n@mixin modal-host {\n left: 0;\n top: 0;\n position: fixed;\n height: 100%;\n width: 100%;\n z-index: z(modal);\n background-color: var(--sdds-modal-backdrop);\n padding: 0 16px;\n\n @media (max-width: $screen-s) {\n padding: 0;\n }\n\n &.show {\n display: flex;\n }\n\n &.hide {\n display: none;\n }\n}\n\n@mixin modal-header {\n display: flex;\n padding-bottom: var(--sdds-spacing-element-8);\n position: sticky;\n top: 0;\n background-color: var(--sdds-modal-background);\n z-index: 1;\n\n &::before {\n content: ' ';\n position: absolute;\n height: 16px;\n top: -16px;\n width: 100%;\n background-color: var(--sdds-modal-background);\n }\n}\n\n@mixin modal-headline {\n color: var(--sdds-modal-text);\n font: var(--sdds-headline-05);\n letter-spacing: var(--sdds-headline-05-ls);\n margin: 0;\n flex: 1;\n}\n\n@mixin modal-body {\n color: var(--sdds-modal-text);\n font: var(--sdds-body-01);\n letter-spacing: var(--sdds-body-01-ls);\n padding-bottom: 40px;\n overflow-y: visible;\n padding-right: 16px;\n @include modal-scroll-inner;\n\n @media (min-width: $screen-l) {\n padding-right: 64px;\n }\n}\n\n/* MODAL STYLING */\n\n.sdds-modal {\n @include sdds-box-sizing;\n\n background-color: var(--sdds-modal-background);\n margin: auto;\n position: relative;\n border-radius: 4px;\n padding: 16px;\n max-height: 85vh;\n overflow-y: auto;\n\n @include modal-scroll-outer;\n\n &__actions-sticky {\n overflow: hidden;\n\n .sdds-modal-body {\n font: var(--sdds-body-01);\n letter-spacing: var(--sdds-body-01-ls);\n padding-bottom: 96px;\n margin: 0 -16px 0 0;\n max-height: calc(85vh - 36px);\n overflow-y: auto;\n }\n\n .sdds-modal-actions {\n position: absolute;\n bottom: -1px;\n left: 0;\n right: 0;\n background-color: var(--sdds-modal-background);\n padding: var(--sdds-spacing-element-16);\n display: flex;\n gap: 16px;\n }\n }\n\n &__actions-static {\n .sdds-modal-actions {\n background-color: var(--sdds-modal-background);\n display: flex;\n gap: 16px;\n }\n }\n}\n\n//Width of modals in different breakpoints\n@each $screen, $modals in $modals {\n @media (min-width: $screen) {\n @each $modal, $value in $modals {\n .sdds-modal-#{$modal} {\n width: $value;\n }\n }\n }\n}\n\n@media (max-width: $screen-s) {\n .sdds-modal-md,\n .sdds-modal-lg,\n .sdds-modal-sm {\n height: 100%;\n\n slot[name='sdds-modal-actions']::slotted(*) {\n display: flex;\n }\n }\n}\n\n/* MODAL SUBELEMENTS */\n\n.sdds-modal-header {\n @include modal-header;\n}\n\n.sdds-modal-headline {\n @include modal-headline;\n\n color: var(--sdds-modal-text);\n}\n\n.sdds-modal-body {\n @include modal-body;\n}\n\n.sdds-modal-backdrop {\n @include sdds-box-sizing;\n @include modal-host;\n}\n\nbutton.sdds-modal-close {\n background-color: transparent;\n border: 0;\n padding: 0;\n appearance: unset;\n}\n\n.sdds-modal-close {\n display: inline-block;\n height: auto;\n color: var(--sdds-modal-icon);\n cursor: pointer;\n\n &:focus {\n @include sdds-focus-state;\n }\n\n @media (min-width: $screen-s) {\n margin-left: var(--sdds-spacing-element-16);\n }\n\n @media (min-width: $screen-l) {\n margin-left: var(--sdds-spacing-element-48);\n }\n}\n\n//web component with nested svg\n.sdds-modal-close-btn {\n display: inline-block;\n height: auto;\n background-repeat: no-repeat;\n cursor: pointer;\n\n @media (min-width: $screen-s) {\n margin-left: var(--sdds-spacing-element-16);\n }\n\n @media (min-width: $screen-l) {\n margin-left: var(--sdds-spacing-element-48);\n }\n\n svg {\n fill: var(--sdds-modal-icon);\n }\n}\n\n.sdds-modal-overflow {\n overflow: hidden;\n}\n\n/* WEB COMPONENT STUFF */\n\n:host {\n @include modal-host;\n\n .sdds-modal-close {\n border: none;\n background-color: transparent;\n }\n\n .sdds-modal-close-btn {\n border: none;\n background-color: transparent;\n }\n}\n\n:host(.show) {\n display: flex;\n}\n\n:host(.hide) {\n display: none;\n}\n","import { Component, h, Host, Prop, Element, Method } from '@stencil/core';\n\n@Component({\n tag: 'sdds-modal',\n styleUrl: 'modal.scss',\n shadow: true,\n})\nexport class Modal {\n /** Disables closing modal on clicking on overlay area. */\n @Prop() prevent: boolean = false;\n\n /** Size of modal */\n @Prop() size: 'xs' | 'sm' | 'md' | 'lg' = 'md';\n\n /** Sticky or Static Actions */\n @Prop() actions: 'sticky' | 'static' = 'static';\n\n /* Opens or closes the modal. */\n @Prop() open: boolean = false;\n\n @Element() el: HTMLElement;\n\n closeButtonEl: HTMLElement;\n\n /** Shows the modal */\n @Method()\n async openModal() {\n this.open = true;\n }\n\n setDissmissButtons() {\n const nodes = this.el.querySelectorAll('[data-dismiss-modal]');\n\n [...Array.from(nodes), this.closeButtonEl].forEach((el) => {\n el.addEventListener('click', () => {\n this.open = false;\n });\n });\n }\n\n handleClick(e) {\n const targetList = e.composedPath();\n const target = targetList[0];\n if (\n target.classList[0] === 'sdds-modal-close' ||\n (target.classList[0] === 'sdds-modal-backdrop' && this.prevent === false)\n ) {\n this.open = false;\n }\n }\n\n componentDidRender() {\n this.setDissmissButtons();\n }\n\n render() {\n return (\n <Host\n onClick={(event) => {\n this.handleClick(event);\n }}\n class={`sdds-modal-backdrop ${this.open ? 'show' : 'hide'}`}\n >\n <div\n class={`sdds-modal ${this.actions ? `sdds-modal__actions-${this.actions}` : ''} ${\n this.size ? `sdds-modal-${this.size}` : ''\n } `}\n >\n <div class=\"sdds-modal-header\">\n <slot name=\"sdds-modal-headline\"></slot>\n <button\n class=\"sdds-modal-close\"\n aria-label=\"close\"\n ref={(el) => {\n this.closeButtonEl = el as HTMLElement;\n }}\n >\n <sdds-icon name=\"cross\" size=\"20px\"></sdds-icon>\n </button>\n </div>\n\n <div class=\"sdds-modal-body\">\n <slot name=\"sdds-modal-body\"></slot>\n </div>\n\n <div class=\"sdds-modal-actions\">\n <slot name=\"sdds-modal-actions\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"sdds-modal.entry.cjs.js","mappings":"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","names":["h","Host"],"sources":["./src/components/modal/modal.scss?tag=sdds-modal&encapsulation=shadow","./src/components/modal/modal.tsx"],"sourcesContent":["@import '../../mixins/z-index';\n@import 'modal-vars';\n@import '../../mixins/box-sizing';\n@import '../../mixins/focus-state';\n\n//TODO: Find a way to create a mixin in spacings that can be used for screen size in rem\n//Media rules doesn't calculate correct with using rem\n// Screen breakpoints\n$screen-s: 320px; //320px\n$screen-md: 672px; // 672px\n$screen-l: 1056px; //1056px\n$screen-xl: 1312px; //1312px\n$screen-xxl: 1584px; //1584px\n\n$modals: (\n $screen-s: (\n xs: 100%,\n sm: 100%,\n md: 100%,\n lg: 100%,\n ),\n $screen-md: (\n xs: 75%,\n sm: 62.5%,\n md: 75%,\n lg: 100%,\n ),\n $screen-l: (\n xs: 31.25%,\n sm: 43.75%,\n md: 62.5%,\n lg: 75%,\n ),\n $screen-xl: (\n xs: 31.25%,\n sm: 37.5%,\n md: 62.5%,\n lg: 75%,\n ),\n $screen-xxl: (\n xs: 25%,\n sm: 37.5%,\n md: 50%,\n lg: 75%,\n ),\n);\n\n/* MIXINS */\n\n@mixin modal-scroll-inner {\n /* SCROLL STUFF */\n\n /* width */\n &::-webkit-scrollbar {\n width: 5px;\n background-color: var(--sdds-grey-300);\n }\n\n /* Track */\n &::-webkit-scrollbar-track {\n background-color: var(--sdds-grey-300);\n }\n\n /* Handle */\n &::-webkit-scrollbar-thumb {\n background-color: var(--sdds-grey-500);\n }\n}\n\n@mixin modal-scroll-outer {\n /* SCROLL STUFF */\n\n /* width */\n &::-webkit-scrollbar {\n width: 5px;\n background-color: var(--sdds-grey-300);\n border-radius: 0 1em 1em 0;\n }\n\n /* Track */\n &::-webkit-scrollbar-track {\n background-color: var(--sdds-grey-300);\n border-radius: 0 1em 1em 0;\n }\n\n /* Handle */\n &::-webkit-scrollbar-thumb {\n background-color: var(--sdds-grey-500);\n border-radius: 0 1em 1em 0;\n }\n}\n\n@mixin modal-host {\n left: 0;\n top: 0;\n position: fixed;\n height: 100%;\n width: 100%;\n z-index: z(modal);\n background-color: var(--sdds-modal-backdrop);\n padding: 0 16px;\n\n @media (max-width: $screen-s) {\n padding: 0;\n }\n\n &.show {\n display: flex;\n }\n\n &.hide {\n display: none;\n }\n}\n\n@mixin modal-header {\n display: flex;\n padding-bottom: var(--sdds-spacing-element-8);\n position: sticky;\n top: 0;\n background-color: var(--sdds-modal-background);\n z-index: 1;\n\n &::before {\n content: ' ';\n position: absolute;\n height: 16px;\n top: -16px;\n width: 100%;\n background-color: var(--sdds-modal-background);\n }\n}\n\n@mixin modal-headline {\n color: var(--sdds-modal-text);\n font: var(--sdds-headline-05);\n letter-spacing: var(--sdds-headline-05-ls);\n margin: 0;\n flex: 1;\n}\n\n@mixin modal-body {\n color: var(--sdds-modal-text);\n font: var(--sdds-body-01);\n letter-spacing: var(--sdds-body-01-ls);\n padding-bottom: 40px;\n overflow-y: visible;\n padding-right: 16px;\n @include modal-scroll-inner;\n\n @media (min-width: $screen-l) {\n padding-right: 64px;\n }\n}\n\n/* MODAL STYLING */\n\n.sdds-modal {\n @include sdds-box-sizing;\n\n background-color: var(--sdds-modal-background);\n margin: auto;\n position: relative;\n border-radius: 4px;\n padding: 16px;\n max-height: 85vh;\n overflow-y: auto;\n\n @include modal-scroll-outer;\n\n &__actions-sticky {\n overflow: hidden;\n\n .sdds-modal-body {\n font: var(--sdds-body-01);\n letter-spacing: var(--sdds-body-01-ls);\n padding-bottom: 96px;\n margin: 0 -16px 0 0;\n max-height: calc(85vh - 36px);\n overflow-y: auto;\n }\n\n .sdds-modal-actions {\n position: absolute;\n bottom: -1px;\n left: 0;\n right: 0;\n background-color: var(--sdds-modal-background);\n padding: var(--sdds-spacing-element-16);\n display: flex;\n gap: 16px;\n }\n }\n\n &__actions-static {\n .sdds-modal-actions {\n background-color: var(--sdds-modal-background);\n display: flex;\n gap: 16px;\n }\n }\n}\n\n//Width of modals in different breakpoints\n@each $screen, $modals in $modals {\n @media (min-width: $screen) {\n @each $modal, $value in $modals {\n .sdds-modal-#{$modal} {\n width: $value;\n }\n }\n }\n}\n\n@media (max-width: $screen-s) {\n .sdds-modal-md,\n .sdds-modal-lg,\n .sdds-modal-sm {\n height: 100%;\n\n slot[name='sdds-modal-actions']::slotted(*) {\n display: flex;\n }\n }\n}\n\n/* MODAL SUBELEMENTS */\n\n.sdds-modal-header {\n @include modal-header;\n}\n\n.sdds-modal-headline {\n @include modal-headline;\n\n color: var(--sdds-modal-text);\n}\n\n.sdds-modal-body {\n @include modal-body;\n}\n\n.sdds-modal-backdrop {\n @include sdds-box-sizing;\n @include modal-host;\n}\n\nbutton.sdds-modal-close {\n background-color: transparent;\n border: 0;\n padding: 0;\n appearance: unset;\n}\n\n.sdds-modal-close {\n display: inline-block;\n height: auto;\n color: var(--sdds-modal-icon);\n cursor: pointer;\n\n &:focus {\n @include sdds-focus-state;\n }\n\n @media (min-width: $screen-s) {\n margin-left: var(--sdds-spacing-element-16);\n }\n\n @media (min-width: $screen-l) {\n margin-left: var(--sdds-spacing-element-48);\n }\n}\n\n//web component with nested svg\n.sdds-modal-close-btn {\n display: inline-block;\n height: auto;\n background-repeat: no-repeat;\n cursor: pointer;\n\n @media (min-width: $screen-s) {\n margin-left: var(--sdds-spacing-element-16);\n }\n\n @media (min-width: $screen-l) {\n margin-left: var(--sdds-spacing-element-48);\n }\n\n svg {\n fill: var(--sdds-modal-icon);\n }\n}\n\n.sdds-modal-overflow {\n overflow: hidden;\n}\n\n/* WEB COMPONENT STUFF */\n\n:host {\n @include modal-host;\n\n .sdds-modal-close {\n border: none;\n background-color: transparent;\n }\n\n .sdds-modal-close-btn {\n border: none;\n background-color: transparent;\n }\n}\n\n:host(.show) {\n display: flex;\n}\n\n:host(.hide) {\n display: none;\n}\n","import {\n Component,\n h,\n Host,\n Prop,\n Element,\n Method,\n State,\n Event,\n EventEmitter,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-modal',\n styleUrl: 'modal.scss',\n shadow: true,\n})\nexport class Modal {\n @Element() host: HTMLElement;\n\n /** Disables closing modal on clicking on overlay area. */\n @Prop() prevent: boolean = false;\n\n /** Size of modal */\n @Prop() size: 'xs' | 'sm' | 'md' | 'lg' = 'md';\n\n /** Sticky or Static Actions */\n @Prop() actions: 'sticky' | 'static' = 'static';\n\n /** CSS selector for the element that will show the modal. */\n @Prop() selector: string;\n\n /** Element that will show the modal (takes priority over selector) */\n @Prop() referenceEl: HTMLElement;\n\n /** Controls whether the modal is shown or not. If this is set hiding and showing\n * will be decided by this prop and will need to be controlled from the outside. */\n @Prop() show: boolean;\n\n // State that keeps track of show/closed state for the modal.\n @State() isShown: boolean = false;\n\n /** Shows the modal. */\n @Method()\n async showModal() {\n this.handleShow();\n }\n\n /** Closes the modal. */\n @Method()\n async closeModal() {\n this.handleClose();\n }\n\n /** Emitts when the modal is closed. */\n @Event({\n eventName: 'sddsClose',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n sddsClose: EventEmitter<any>;\n\n connectedCallback() {\n if (this.show !== null) {\n this.isShown = this.show;\n }\n this.setDissmissButtons();\n this.setShowButton();\n }\n\n /** Emits a close event and then close the modal if it is not prevented. */\n handleClose = (event?) => {\n const closeEvent = this.sddsClose.emit(event);\n if (!closeEvent.defaultPrevented) {\n this.isShown = false;\n }\n };\n\n handleShow = () => {\n this.isShown = true;\n };\n\n /** Checks if click on modal is on overlay, if so it closes the modal if prevent is not true. */\n handleOverlayClick(event) {\n const targetList = event.composedPath();\n const target = targetList[0];\n if (\n target.classList[0] === 'sdds-modal-close' ||\n (target.classList[0] === 'sdds-modal-backdrop' && this.prevent === false)\n ) {\n this.handleClose(event);\n }\n }\n\n /** Adds an event listener to the reference element that shows/closes the modal. */\n initializeReferenceElement = (referenceEl) => {\n if (referenceEl) {\n referenceEl.addEventListener('click', (event) => {\n event.stopPropagation();\n if (this.isShown) {\n this.handleClose(event);\n } else {\n this.handleShow();\n }\n });\n }\n };\n\n /** Check if there is a referenceElement or selector and adds event listener to them if so. */\n setShowButton = () => {\n if (this.selector || this.referenceEl) {\n const referenceEl = this.referenceEl ?? document.querySelector(this.selector);\n if (referenceEl) {\n this.initializeReferenceElement(referenceEl);\n }\n }\n };\n\n /** Adds an event listener to the dismiss buttons that closes the modal. */\n setDissmissButtons() {\n this.host.querySelectorAll('[data-dismiss-modal]').forEach((dismissButton) => {\n dismissButton.addEventListener('click', (event) => {\n this.handleClose(event);\n });\n });\n }\n\n render() {\n return (\n <Host\n onClick={(event) => {\n this.handleOverlayClick(event);\n }}\n class={`sdds-modal-backdrop ${this.isShown ? 'show' : 'hide'}`}\n >\n <div\n class={`sdds-modal ${this.actions ? `sdds-modal__actions-${this.actions}` : ''} ${\n this.size ? `sdds-modal-${this.size}` : ''\n } `}\n >\n <div class=\"sdds-modal-header\">\n <slot name=\"sdds-modal-headline\"></slot>\n <button class=\"sdds-modal-close\" aria-label=\"close\" onClick={() => this.handleClose()}>\n <sdds-icon name=\"cross\" size=\"20px\"></sdds-icon>\n </button>\n </div>\n\n <div class=\"sdds-modal-body\">\n <slot name=\"sdds-modal-body\"></slot>\n </div>\n\n <div class=\"sdds-modal-actions\">\n <slot name=\"sdds-modal-actions\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-5ad19933.js');
6
+
7
+ const sddsNavigationTabsButtonCss = ":host{box-sizing:border-box}:host *{box-sizing:border-box}:host button{font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);color:var(--sdds-navigation-tabs-tab-color);padding:18px 0;margin-right:32px;text-decoration:none;display:block;position:relative;transition:color 0.15s ease-in-out;white-space:nowrap;background-color:transparent;border:0}:host button.selected{color:var(--sdds-navigation-tabs-tab-color-selected)}:host button.selected::after{width:100%;background-color:var(--sdds-navigation-tabs-tab-indicator-background-active)}:host button .label{padding:8px 4px}:host button:focus-visible{outline:none}:host button:focus-visible .label{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}:host button:hover{color:var(--sdds-navigation-tabs-tab-color-hover);opacity:1}:host button:hover::after{width:100%}:host button.disabled{color:var(--sdds-navigation-tabs-tab-color-disabled);pointer-events:none}:host button.disabled .label{opacity:var(--sdds-navigation-tabs-tab-color-opacity-disabled)}:host button::after{content:\" \";position:absolute;bottom:0;right:0;left:0;margin-left:auto;width:0;margin-right:auto;height:2px;background-color:var(--sdds-navigation-tabs-tab-indicator-background-hover);transition:width 0.15s ease-in-out;z-index:1}:host(.first){margin-left:32px}:host(.last){margin-right:32px}";
8
+
9
+ const SddsNavigationTabsButton = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.disabled = false;
13
+ this.selected = false;
14
+ }
15
+ render() {
16
+ return (index.h(index.Host, { role: "listitem" }, index.h("button", { class: `${this.selected ? 'selected' : ''}
17
+ ${this.disabled ? 'disabled' : ''}`, disabled: this.disabled }, index.h("div", { class: "label" }, index.h("slot", null)))));
18
+ }
19
+ };
20
+ SddsNavigationTabsButton.style = sddsNavigationTabsButtonCss;
21
+
22
+ exports.sdds_navigation_tabs_button = SddsNavigationTabsButton;
23
+
24
+ //# sourceMappingURL=sdds-navigation-tabs-button.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"sdds-navigation-tabs-button.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,2BAA2B,GAAG,+zCAA+zC;;MCOt1C,wBAAwB;;;oBAEP,KAAK;oBAGL,KAAK;;EAEjC,MAAM;IACJ,QACEA,QAACC,UAAI,IAAC,IAAI,EAAC,UAAU,IACnBD,oBACE,KAAK,EAAE,GAAG,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;WACxC,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE,EAAE,EAClC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAEvBA,iBAAK,KAAK,EAAC,OAAO,IAChBA,qBAAa,CACT,CACC,CACJ,EACP;GACH;;;;;;","names":["h","Host"],"sources":["./src/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.scss?tag=sdds-navigation-tabs-button&encapsulation=shadow","./src/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.tsx"],"sourcesContent":["@import '../../../../mixins/focus-state';\n@import '../../../../mixins/box-sizing';\n\n:host {\n @include sdds-box-sizing;\n\n button {\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n color: var(--sdds-navigation-tabs-tab-color);\n padding: 18px 0;\n margin-right: 32px;\n text-decoration: none;\n display: block;\n position: relative;\n transition: color 0.15s ease-in-out;\n white-space: nowrap;\n background-color: transparent;\n border: 0;\n\n &.selected {\n color: var(--sdds-navigation-tabs-tab-color-selected);\n\n &::after {\n width: 100%;\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-active);\n }\n }\n\n .label {\n padding: 8px 4px;\n }\n\n &:focus-visible {\n outline: none;\n\n .label {\n @include sdds-focus-state;\n }\n }\n\n &:hover {\n color: var(--sdds-navigation-tabs-tab-color-hover);\n opacity: 1;\n\n &::after {\n width: 100%;\n }\n }\n\n &.disabled {\n color: var(--sdds-navigation-tabs-tab-color-disabled);\n pointer-events: none;\n\n .label {\n opacity: var(--sdds-navigation-tabs-tab-color-opacity-disabled);\n }\n }\n\n &::after {\n content: ' ';\n position: absolute;\n bottom: 0;\n right: 0;\n left: 0;\n margin-left: auto;\n width: 0;\n margin-right: auto;\n height: 2px;\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-hover);\n transition: width 0.15s ease-in-out;\n z-index: 1;\n }\n }\n}\n\n:host(.first) {\n margin-left: 32px;\n}\n\n:host(.last) {\n margin-right: 32px;\n}","import { Component, Host, h, Prop } from '@stencil/core';\n\n@Component({\n tag: 'sdds-navigation-tabs-button',\n styleUrl: 'sdds-navigation-tabs-button.scss',\n shadow: true,\n})\nexport class SddsNavigationTabsButton {\n /** Disables the tab. */\n @Prop() disabled: boolean = false;\n\n /** Marks the tab as the selected one. */\n @Prop() selected: boolean = false;\n\n render() {\n return (\n <Host role=\"listitem\">\n <button\n class={`${this.selected ? 'selected' : ''}\n ${this.disabled ? 'disabled' : ''}`}\n disabled={this.disabled}\n >\n <div class=\"label\">\n <slot></slot>\n </div>\n </button>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-5ad19933.js');
6
+
7
+ const sddsNavigationTabsLinkCss = ":host{box-sizing:border-box}:host *{box-sizing:border-box}:host a{font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);color:var(--sdds-navigation-tabs-tab-color);padding:18px 0;margin-right:32px;text-decoration:none;display:block;position:relative;transition:color 0.15s ease-in-out;white-space:nowrap;background-color:transparent;border:0}:host a.selected{color:var(--sdds-navigation-tabs-tab-color-selected)}:host a.selected::after{width:100%;background-color:var(--sdds-navigation-tabs-tab-indicator-background-active)}:host a .label{padding:8px 4px}:host a:focus-visible{outline:none}:host a:focus-visible .label{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}:host a:hover{color:var(--sdds-navigation-tabs-tab-color-hover);opacity:1}:host a:hover::after{width:100%}:host a.disabled{color:var(--sdds-navigation-tabs-tab-color-disabled);pointer-events:none}:host a.disabled .label{opacity:var(--sdds-navigation-tabs-tab-color-opacity-disabled)}:host a::after{content:\" \";position:absolute;bottom:0;right:0;left:0;margin-left:auto;width:0;margin-right:auto;height:2px;background-color:var(--sdds-navigation-tabs-tab-indicator-background-hover);transition:width 0.15s ease-in-out;z-index:1}:host(.first){margin-left:32px}:host(.last){margin-right:32px}";
8
+
9
+ const SddsNavigationTabsLink = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.disabled = false;
13
+ this.selected = false;
14
+ this.href = undefined;
15
+ this.target = '_self';
16
+ this.rel = 'noopener';
17
+ }
18
+ render() {
19
+ return (index.h(index.Host, { role: "listitem" }, index.h("a", { class: `
20
+ ${this.selected ? 'selected' : ''}
21
+ ${this.disabled ? 'disabled' : ''}
22
+ `, href: this.href, target: this.target, rel: this.rel }, index.h("div", { class: "label" }, index.h("slot", null)))));
23
+ }
24
+ };
25
+ SddsNavigationTabsLink.style = sddsNavigationTabsLinkCss;
26
+
27
+ exports.sdds_navigation_tabs_link = SddsNavigationTabsLink;
28
+
29
+ //# sourceMappingURL=sdds-navigation-tabs-link.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"sdds-navigation-tabs-link.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,yBAAyB,GAAG,wwCAAwwC;;MCO7xC,sBAAsB;;;oBAEL,KAAK;oBAGL,KAAK;;kBAMyB,OAAO;eAG3C,UAAU;;EAEhC,MAAM;IACJ,QACEA,QAACC,UAAI,IAAC,IAAI,EAAC,UAAU,IACnBD,eACE,KAAK,EAAE;UACP,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;UAC/B,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;SAChC,EACC,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,MAAM,EAAE,IAAI,CAAC,MAAM,EACnB,GAAG,EAAE,IAAI,CAAC,GAAG,IAEbA,iBAAK,KAAK,EAAC,OAAO,IAChBA,qBAAa,CACT,CACJ,CACC,EACP;GACH;;;;;;","names":["h","Host"],"sources":["./src/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.scss?tag=sdds-navigation-tabs-link&encapsulation=shadow","./src/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.tsx"],"sourcesContent":["@import '../../../../mixins/focus-state';\n@import '../../../../mixins/box-sizing';\n\n:host {\n @include sdds-box-sizing;\n\n a {\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n color: var(--sdds-navigation-tabs-tab-color);\n padding: 18px 0;\n margin-right: 32px;\n text-decoration: none;\n display: block;\n position: relative;\n transition: color 0.15s ease-in-out;\n white-space: nowrap;\n background-color: transparent;\n border: 0;\n\n &.selected {\n color: var(--sdds-navigation-tabs-tab-color-selected);\n\n &::after {\n width: 100%;\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-active);\n }\n }\n\n .label {\n padding: 8px 4px;\n }\n\n &:focus-visible {\n outline: none;\n\n .label {\n @include sdds-focus-state;\n }\n }\n\n &:hover {\n color: var(--sdds-navigation-tabs-tab-color-hover);\n opacity: 1;\n\n &::after {\n width: 100%;\n }\n }\n\n &.disabled {\n color: var(--sdds-navigation-tabs-tab-color-disabled);\n pointer-events: none;\n\n .label {\n opacity: var(--sdds-navigation-tabs-tab-color-opacity-disabled);\n }\n }\n\n &::after {\n content: ' ';\n position: absolute;\n bottom: 0;\n right: 0;\n left: 0;\n margin-left: auto;\n width: 0;\n margin-right: auto;\n height: 2px;\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-hover);\n transition: width 0.15s ease-in-out;\n z-index: 1;\n }\n }\n}\n\n:host(.first) {\n margin-left: 32px;\n}\n\n:host(.last) {\n margin-right: 32px;\n}\n","import { Component, Host, h, Prop } from '@stencil/core';\n\n@Component({\n tag: 'sdds-navigation-tabs-link',\n styleUrl: 'sdds-navigation-tabs-link.scss',\n shadow: true,\n})\nexport class SddsNavigationTabsLink {\n /** Disables the tab. */\n @Prop() disabled: boolean = false;\n\n /** Marks the tab as the selected one. */\n @Prop() selected: boolean = false;\n\n /** Href for the link */\n @Prop() href: string;\n\n /** Where to open the linked URL */\n @Prop() target: '_self' | '_blank' | '_parent' | '_top' = '_self';\n\n /** 'noopener' is a security measure for legacy browsers that preventsthe opened page from getting access to the original page when using target='_blank'. */\n @Prop() rel: string = 'noopener';\n\n render() {\n return (\n <Host role=\"listitem\">\n <a\n class={`\n ${this.selected ? 'selected' : ''}\n ${this.disabled ? 'disabled' : ''}\n `}\n href={this.href}\n target={this.target}\n rel={this.rel}\n >\n <div class=\"label\">\n <slot></slot>\n </div>\n </a>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,25 +2,80 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-18eb94f0.js');
5
+ const index = require('./index-5ad19933.js');
6
6
 
7
- const navigationTabsCss = ".sdds-navigation-tabs{box-sizing:border-box;background-color:var(--sdds-navigation-tabs-background);position:relative;display:flex;}.sdds-navigation-tabs *{box-sizing:border-box}.sdds-navigation-tabs::after{content:\" \";display:block;border-bottom:1px solid var(--sdds-navigation-tabs-horizontal-divider-background);opacity:var(--sdds-navigation-tabs-horizontal-divider-opacity);left:0;right:0;bottom:0;position:absolute}.sdds-navigation-tabs-wrapper{display:flex;flex-wrap:nowrap;width:100%;overflow-x:scroll;scrollbar-width:none}.sdds-navigation-tabs-wrapper::-webkit-scrollbar{display:none}.sdds-navigation-tabs-forward{cursor:pointer;width:48px;height:100%;border:0;position:absolute;right:0;top:0;background-color:var(--sdds-navigation-tabs-scroll-btn-background);display:flex;justify-content:center;align-items:center;opacity:0;pointer-events:none}.sdds-navigation-tabs-forward__show{opacity:1;pointer-events:all}.sdds-navigation-tabs-forward:hover{background-color:var(--sdds-navigation-tabs-scroll-btn-background-hover);text-decoration:none}.sdds-navigation-tabs-forward:active{background-color:var(--sdds-navigation-tabs-scroll-btn-background-active)}.sdds-navigation-tabs-forward:focus{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}.sdds-navigation-tabs-back{cursor:pointer;width:48px;height:100%;border:0;position:absolute;left:0;top:0;background-color:var(--sdds-navigation-tabs-scroll-btn-background);display:flex;justify-content:center;align-items:center;opacity:0;pointer-events:none}.sdds-navigation-tabs-back__show{opacity:1;pointer-events:all}.sdds-navigation-tabs-back:hover{background-color:var(--sdds-navigation-tabs-scroll-btn-background-hover)}.sdds-navigation-tabs-back:active{background-color:var(--sdds-navigation-tabs-scroll-btn-background-active)}.sdds-navigation-tabs-back:focus{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}::slotted(.sdds-navigation-tabs-tab){font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);color:var(--sdds-navigation-tabs-tab-color);opacity:0.6;padding:26px 0;margin-right:32px;text-decoration:none;display:block;position:relative;transition:color 0.15s ease-in-out;white-space:nowrap;background-color:transparent;border:0}::slotted(.sdds-navigation-tabs-tab)::after{content:\" \";position:absolute;bottom:0;right:0;left:0;margin-left:auto;width:0;margin-right:auto;height:2px;background-color:var(--sdds-navigation-tabs-tab-indicator-background-hover);transition:width 0.15s ease-in-out;z-index:1}::slotted(.sdds-navigation-tabs-tab:first-child){margin-left:32px}::slotted(.sdds-navigation-tabs-tab:last-child){margin-right:32px}::slotted(.sdds-navigation-tabs-tab:hover){color:var(--sdds-navigation-tabs-tab-color-hover);opacity:1}::slotted(.sdds-navigation-tabs-tab:hover)::after{width:100%}::slotted(.sdds-navigation-tabs-tab:focus){outline:2px solid var(--sdds-blue-400);outline-offset:-2px;color:var(--sdds-navigation-tabs-tab-color-focus);opacity:1}::slotted(.sdds-navigation-tabs-tab:focus)::after{width:0}::slotted(.sdds-navigation-tabs-tab-active){color:var(--sdds-navigation-tabs-tab-color-active);opacity:1}::slotted(.sdds-navigation-tabs-tab-active)::after{width:100%;background-color:var(--sdds-navigation-tabs-tab-indicator-background-active)}::slotted(.sdds-navigation-tabs-tab-active:focus)::after{width:100%}::slotted(.sdds-navigation-tabs-tab-disabled){color:var(--sdds-navigation-tabs-tab-color-disabled);opacity:var(--sdds-navigation-tabs-tab-color-opacity-disabled);pointer-events:none}";
7
+ const navigationTabsCss = ":host{box-sizing:border-box;display:flex;background-color:var(--sdds-inline-tabs-background);position:relative}:host *{box-sizing:border-box}:host::after{content:\" \";display:block;border-bottom:1px solid var(--sdds-inline-tabs-horizontal-divider-background);opacity:var(--sdds-inline-tabs-horizontal-divider-opacity);left:0;right:0;bottom:0;position:absolute}:host .wrapper{display:flex;flex-wrap:nowrap;white-space:nowrap;width:100%;overflow-x:scroll;scrollbar-width:none}:host .wrapper::-webkit-scrollbar{display:none}:host .scroll-right-button{right:0;z-index:201}:host .scroll-left-button{left:0;z-index:201}:host .scroll-right-button,:host .scroll-left-button{color:var(--sdds-folder-tabs-scroll-btn-color);cursor:pointer;border:0;width:0;background-color:var(--sdds-inline-tabs-scroll-btn-background);display:none;justify-content:center;align-items:center;opacity:0;pointer-events:none;position:sticky}:host .scroll-right-button.show,:host .scroll-left-button.show{min-width:48px;display:block;opacity:1;pointer-events:all}:host .scroll-right-button:hover,:host .scroll-left-button:hover{background-color:var(--sdds-folder-tabs-scroll-btn-background-hover)}:host .scroll-right-button:active,:host .scroll-left-button:active{background-color:var(--sdds-folder-tabs-scroll-btn-background-active)}:host .scroll-right-button:focus,:host .scroll-left-button:focus{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}:host .scroll-right-button svg,:host .scroll-left-button svg{fill:var(--sdds-folder-tabs-scroll-btn-color)}";
8
8
 
9
9
  const NavigationTabs = class {
10
10
  constructor(hostRef) {
11
11
  index.registerInstance(this, hostRef);
12
+ this.sddsChange = index.createEvent(this, "sddsChange", 7);
12
13
  this.navWrapperElement = null; // reference to container with nav buttons
13
14
  this.componentWidth = 0; // visible width of this component
14
15
  this.buttonsWidth = 0; // total width of all nav items combined
15
16
  this.scrollWidth = 0; // total amount that is possible to scroll in the nav wrapper
16
- this.buttonWidth = 0; // current calculated width of the largest nav button
17
- this.tabs = [];
17
+ this.modeVariant = 'primary';
18
18
  this.showLeftScroll = false;
19
19
  this.showRightScroll = false;
20
- this.modeVariant = null;
20
+ this.selectedTab = undefined;
21
21
  }
22
- componentDidRender() {
23
- this.calculateButtonWidth();
22
+ /** Selects a tab based on tabindex, will not select a disabled tab. */
23
+ async selectTab(tabIndex) {
24
+ if (!this.children[tabIndex].disabled) {
25
+ this.children.forEach((element) => element.removeAttribute('selected'));
26
+ this.children = this.children.map((element, index) => {
27
+ if (index === tabIndex) {
28
+ element.setAttribute('selected', '');
29
+ this.selectedTab = {
30
+ tab: element.innerText,
31
+ tabIndex: index,
32
+ };
33
+ }
34
+ return element;
35
+ });
36
+ }
37
+ return {
38
+ selectedTab: this.selectedTab.tab,
39
+ selectedTabIndex: this.selectedTab.tabIndex,
40
+ };
41
+ }
42
+ handleSelectedTabChange() {
43
+ this.host.setAttribute('selected-tab', this.selectedTab.tab);
44
+ this.host.setAttribute('selected-tab-index', `${this.selectedTab.tabIndex}`);
45
+ this.sddsChange.emit({
46
+ selectedTab: this.selectedTab,
47
+ });
48
+ }
49
+ connectedCallback() {
50
+ this.children = Array.from(this.host.children);
51
+ this.children = this.children.map((item, index) => {
52
+ item.addEventListener('click', () => {
53
+ if (!item.disabled) {
54
+ this.children.forEach((element) => element.removeAttribute('selected'));
55
+ item.setAttribute('selected', '');
56
+ this.selectedTab = {
57
+ tab: item.innerText,
58
+ tabIndex: index,
59
+ };
60
+ }
61
+ });
62
+ if (index === 0) {
63
+ item.classList.add('first');
64
+ }
65
+ if (index === this.children.length - 1) {
66
+ item.classList.add('last');
67
+ }
68
+ if (item.selected) {
69
+ this.selectedTab = {
70
+ tab: item.innerText,
71
+ tabIndex: index,
72
+ };
73
+ }
74
+ return item;
75
+ });
76
+ this.children = Array.from(this.host.children);
77
+ this.children[0].classList.add('first');
78
+ this.children[this.children.length - 1].classList.add('last');
24
79
  }
25
80
  componentDidLoad() {
26
81
  const resizeObserver = new ResizeObserver((entries) => {
@@ -47,28 +102,15 @@ const NavigationTabs = class {
47
102
  });
48
103
  });
49
104
  resizeObserver.observe(this.navWrapperElement);
50
- this.calculateButtonWidth();
51
- }
52
- calculateButtonWidth() {
53
- let best = 0;
54
- const navButtons = Array.from(this.host.children);
55
- navButtons.forEach((navButton) => {
56
- const style = window.getComputedStyle(navButton);
57
- const width = navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);
58
- if (width > best) {
59
- best = width;
60
- }
61
- });
62
- this.buttonWidth = best;
63
105
  }
64
106
  scrollRight() {
65
107
  const scroll = this.navWrapperElement.scrollLeft;
66
- this.navWrapperElement.scrollLeft = scroll + this.buttonWidth;
108
+ this.navWrapperElement.scrollLeft = scroll + this.buttonsWidth;
67
109
  this.evaluateScrollButtons();
68
110
  }
69
111
  scrollLeft() {
70
112
  const scroll = this.navWrapperElement.scrollLeft;
71
- this.navWrapperElement.scrollLeft = scroll - this.buttonWidth;
113
+ this.navWrapperElement.scrollLeft = scroll - this.buttonsWidth;
72
114
  this.evaluateScrollButtons();
73
115
  }
74
116
  evaluateScrollButtons() {
@@ -87,11 +129,14 @@ const NavigationTabs = class {
87
129
  }
88
130
  }
89
131
  render() {
90
- return (index.h(index.Host, { class: `${this.modeVariant !== null ? `sdds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { class: "sdds-navigation-tabs" }, index.h("div", { class: "sdds-navigation-tabs-wrapper", ref: (el) => {
132
+ return (index.h(index.Host, { class: `${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { role: "list", class: "wrapper", ref: (el) => {
91
133
  this.navWrapperElement = el;
92
- } }, index.h("slot", null)), index.h("div", { class: "sdds-navigation-tabs-navigation" }, index.h("button", { class: `sdds-navigation-tabs-forward ${this.showRightScroll ? 'sdds-navigation-tabs-forward-show' : ''}`, onClick: () => this.scrollRight(), disabled: !this.showRightScroll }, index.h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, index.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", fill: "#0D0F13" }))), index.h("button", { class: `sdds-navigation-tabs-back ${this.showLeftScroll ? 'sdds-navigation-tabs-back-show' : ''}`, onClick: () => this.scrollLeft(), disabled: !this.showLeftScroll }, index.h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, index.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", fill: "#0D0F13" })))))));
134
+ } }, index.h("button", { class: `scroll-left-button ${this.showLeftScroll ? 'show' : ''}`, onClick: () => this.scrollLeft(), disabled: !this.showLeftScroll }, index.h("sdds-icon", { name: "chevron_left", size: "20px" })), index.h("slot", null), index.h("button", { class: `scroll-right-button ${this.showRightScroll ? 'show' : ''}`, onClick: () => this.scrollRight(), disabled: !this.showRightScroll }, index.h("sdds-icon", { name: "chevron_right", size: "20px" })))));
93
135
  }
94
136
  get host() { return index.getElement(this); }
137
+ static get watchers() { return {
138
+ "selectedTab": ["handleSelectedTabChange"]
139
+ }; }
95
140
  };
96
141
  NavigationTabs.style = navigationTabsCss;
97
142
 
@@ -1 +1 @@
1
- {"file":"sdds-navigation-tabs.entry.cjs.js","mappings":"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","names":["h","Host"],"sources":["./src/components/tabs/navigation-tabs/navigation-tabs.scss?tag=sdds-navigation-tabs&encapsulation=shadow","./src/components/tabs/navigation-tabs/navigation-tabs.tsx"],"sourcesContent":["@import '../../../mixins/focus-state';\n@import '../../../mixins/box-sizing';\n\n\n.sdds-navigation-tabs {\n @include sdds-box-sizing;\n\n background-color: var(--sdds-navigation-tabs-background);\n position: relative;\n display: flex;\n\n &::after {\n content: ' ';\n display: block;\n border-bottom: 1px solid var(--sdds-navigation-tabs-horizontal-divider-background);\n opacity: var(--sdds-navigation-tabs-horizontal-divider-opacity);\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n }\n\n &-wrapper {\n display: flex;\n flex-wrap: nowrap;\n width: 100%;\n overflow-x: scroll;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n &-forward {\n cursor: pointer;\n width: 48px;\n height: 100%;\n border: 0;\n position: absolute;\n right: 0;\n top: 0;\n background-color: var(--sdds-navigation-tabs-scroll-btn-background);\n display: flex;\n justify-content: center;\n align-items: center;\n opacity: 0;\n pointer-events: none;\n\n &__show {\n opacity: 1;\n pointer-events: all;\n }\n\n &:hover {\n background-color: var(--sdds-navigation-tabs-scroll-btn-background-hover);\n text-decoration: none;\n }\n\n &:active {\n background-color: var(--sdds-navigation-tabs-scroll-btn-background-active);\n }\n\n &:focus {\n @include sdds-focus-state;\n }\n }\n\n &-back {\n cursor: pointer;\n width: 48px;\n height: 100%;\n border: 0;\n position: absolute;\n left: 0;\n top: 0;\n background-color: var(--sdds-navigation-tabs-scroll-btn-background);\n display: flex;\n justify-content: center;\n align-items: center;\n opacity: 0;\n pointer-events: none;\n\n &__show {\n opacity: 1;\n pointer-events: all;\n }\n\n &:hover {\n background-color: var(--sdds-navigation-tabs-scroll-btn-background-hover);\n }\n\n &:active {\n background-color: var(--sdds-navigation-tabs-scroll-btn-background-active);\n }\n\n &:focus {\n @include sdds-focus-state;\n }\n }\n\n /* tab */\n ::slotted(&-tab) {\n //fixme: headline-07 has a line-height that is not matching old storybook\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n color: var(--sdds-navigation-tabs-tab-color);\n opacity:0.6;\n padding: 26px 0;\n margin-right: 32px;\n text-decoration: none;\n display: block;\n position: relative;\n transition: color 0.15s ease-in-out;\n white-space: nowrap;\n background-color: transparent;\n border: 0;\n\n &::after {\n content: ' ';\n position: absolute;\n bottom: 0;\n right: 0;\n left: 0;\n margin-left: auto;\n width: 0;\n margin-right: auto;\n height: 2px;\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-hover);\n transition: width 0.15s ease-in-out;\n z-index: 1;\n }\n }\n\n ::slotted(&-tab:first-child) {\n margin-left: 32px;\n }\n\n ::slotted(&-tab:last-child) {\n margin-right: 32px;\n }\n\n /* tab states */\n ::slotted(&-tab:hover) {\n color: var(--sdds-navigation-tabs-tab-color-hover);\n opacity: 1;\n\n &::after {\n width: 100%;\n }\n }\n\n ::slotted(&-tab:focus) {\n @include sdds-focus-state;\n\n color: var(--sdds-navigation-tabs-tab-color-focus);\n opacity: 1;\n\n &::after {\n width: 0;\n }\n }\n\n ::slotted(&-tab-active) {\n color: var(--sdds-navigation-tabs-tab-color-active);\n opacity:1;\n\n &::after {\n width: 100%;\n\n background-color: var(--sdds-navigation-tabs-tab-indicator-background-active);\n }\n }\n\n ::slotted(&-tab-active:focus)::after {\n width: 100%;\n }\n\n ::slotted(&-tab-disabled) {\n color: var(--sdds-navigation-tabs-tab-color-disabled);\n opacity: var(--sdds-navigation-tabs-tab-color-opacity-disabled);\n pointer-events: none;\n }\n}\n","import { Component, Host, State, Element, h, Prop } from '@stencil/core';\n\n@Component({\n tag: 'sdds-navigation-tabs',\n styleUrl: 'navigation-tabs.scss',\n shadow: true,\n})\nexport class NavigationTabs {\n @Element() host: HTMLElement;\n\n @State() tabs: Array<any> = []; // array with metadata for slotted children\n\n @State() showLeftScroll: boolean = false;\n\n @State() showRightScroll: boolean = false;\n \n /** Variant of the tabs, primary= on white, secondary= on grey50 */\n @Prop() modeVariant: 'primary' | 'secondary' = null;\n\n navWrapperElement: HTMLElement = null; // reference to container with nav buttons\n\n componentWidth: number = 0; // visible width of this component\n\n buttonsWidth: number = 0; // total width of all nav items combined\n\n scrollWidth: number = 0; // total amount that is possible to scroll in the nav wrapper\n\n buttonWidth: number = 0; // current calculated width of the largest nav button\n\n componentDidRender() {\n this.calculateButtonWidth();\n }\n\n componentDidLoad() {\n const resizeObserver = new ResizeObserver((entries) => {\n entries.forEach((entry) => {\n const componentWidth = entry.contentRect.width;\n let buttonsWidth = 0;\n\n const navButtons = Array.from(this.host.children);\n navButtons.forEach((navButton: HTMLElement) => {\n const style = window.getComputedStyle(navButton);\n buttonsWidth +=\n navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n\n navButton.classList.add('sdds-navigation-tabs-tab');\n });\n\n this.componentWidth = componentWidth;\n this.buttonsWidth = buttonsWidth;\n this.scrollWidth = buttonsWidth - componentWidth;\n\n if (this.buttonsWidth > this.componentWidth) {\n this.evaluateScrollButtons();\n } else {\n this.showLeftScroll = false;\n this.showRightScroll = false;\n }\n });\n });\n\n resizeObserver.observe(this.navWrapperElement);\n\n this.calculateButtonWidth();\n }\n\n calculateButtonWidth() {\n let best = 0;\n const navButtons = Array.from(this.host.children);\n navButtons.forEach((navButton: HTMLElement) => {\n const style = window.getComputedStyle(navButton);\n const width =\n navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n\n if (width > best) {\n best = width;\n }\n });\n\n this.buttonWidth = best;\n }\n\n scrollRight() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll + this.buttonWidth;\n\n this.evaluateScrollButtons();\n }\n\n scrollLeft() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll - this.buttonWidth;\n\n this.evaluateScrollButtons();\n }\n\n evaluateScrollButtons() {\n const scroll = this.navWrapperElement.scrollLeft;\n\n if (scroll >= this.scrollWidth) {\n this.showRightScroll = false;\n } else {\n this.showRightScroll = true;\n }\n\n if (scroll <= 0) {\n this.showLeftScroll = false;\n } else {\n this.showLeftScroll = true;\n }\n }\n\n render() {\n return (\n <Host class={`${this.modeVariant !== null ? `sdds-mode-variant-${this.modeVariant}`: ''}`}>\n <div class=\"sdds-navigation-tabs\">\n <div\n class=\"sdds-navigation-tabs-wrapper\"\n ref={(el) => {\n this.navWrapperElement = el as HTMLElement;\n }}\n >\n <slot />\n </div>\n <div class=\"sdds-navigation-tabs-navigation\">\n <button\n class={`sdds-navigation-tabs-forward ${\n this.showRightScroll ? 'sdds-navigation-tabs-forward-show' : ''\n }`}\n onClick={() => this.scrollRight()}\n disabled={!this.showRightScroll}\n >\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n 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\"\n fill=\"#0D0F13\"\n ></path>\n </svg>\n </button>\n <button\n class={`sdds-navigation-tabs-back ${\n this.showLeftScroll ? 'sdds-navigation-tabs-back-show' : ''\n }`}\n onClick={() => this.scrollLeft()}\n disabled={!this.showLeftScroll}\n >\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n 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\"\n fill=\"#0D0F13\"\n ></path>\n </svg>\n </button>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"sdds-navigation-tabs.entry.cjs.js","mappings":"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","names":["h","Host"],"sources":["./src/components/tabs/navigation-tabs/navigation-tabs.scss?tag=sdds-navigation-tabs&encapsulation=shadow","./src/components/tabs/navigation-tabs/navigation-tabs.tsx"],"sourcesContent":["@import '../../../mixins/focus-state';\n@import '../../../mixins/box-sizing';\n@import '../../../mixins/z-index';\n\n:host {\n @include sdds-box-sizing;\n\n display: flex;\n background-color: var(--sdds-inline-tabs-background);\n position: relative;\n\n &::after {\n content: ' ';\n display: block;\n border-bottom: 1px solid var(--sdds-inline-tabs-horizontal-divider-background);\n opacity: var(--sdds-inline-tabs-horizontal-divider-opacity);\n left: 0;\n right: 0;\n bottom: 0;\n position: absolute;\n }\n\n .wrapper {\n display: flex;\n flex-wrap: nowrap;\n white-space: nowrap;\n width: 100%;\n overflow-x: scroll;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n .scroll-right-button {\n right: 0;\n z-index: calc(z(tab) + 1);\n }\n\n .scroll-left-button {\n left: 0;\n z-index: calc(z(tab) + 1);\n }\n\n .scroll-right-button,\n .scroll-left-button {\n color: var(--sdds-folder-tabs-scroll-btn-color);\n cursor: pointer;\n border: 0;\n width: 0;\n background-color: var(--sdds-inline-tabs-scroll-btn-background);\n display: none;\n justify-content: center;\n align-items: center;\n opacity: 0;\n pointer-events: none;\n position: sticky;\n\n &.show {\n min-width: 48px;\n display: block;\n opacity: 1;\n pointer-events: all;\n }\n\n &:hover {\n background-color: var(--sdds-folder-tabs-scroll-btn-background-hover);\n }\n\n &:active {\n background-color: var(--sdds-folder-tabs-scroll-btn-background-active);\n }\n\n &:focus {\n @include sdds-focus-state;\n }\n\n svg {\n fill: var(--sdds-folder-tabs-scroll-btn-color);\n }\n }\n}\n","import {\n Component,\n Host,\n State,\n Element,\n h,\n Prop,\n Event,\n EventEmitter,\n Watch,\n Method,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-navigation-tabs',\n styleUrl: 'navigation-tabs.scss',\n shadow: true,\n})\nexport class NavigationTabs {\n /** Variant of the tabs, primary= on white, secondary= on grey50 */\n @Prop() modeVariant: 'primary' | 'secondary' = 'primary';\n\n @Element() host: HTMLElement;\n\n @State() showLeftScroll: boolean = false;\n\n @State() showRightScroll: boolean = false;\n\n @State() selectedTab: {\n tab: string;\n tabIndex: number;\n };\n\n private navWrapperElement: HTMLElement = null; // reference to container with nav buttons\n\n private componentWidth: number = 0; // visible width of this component\n\n private buttonsWidth: number = 0; // total width of all nav items combined\n\n private scrollWidth: number = 0; // total amount that is possible to scroll in the nav wrapper\n\n private children: Array<HTMLSddsNavigationTabsLinkElement | HTMLSddsNavigationTabsButtonElement>;\n\n /** Selects a tab based on tabindex, will not select a disabled tab. */\n @Method()\n async selectTab(tabIndex: number) {\n if (!this.children[tabIndex].disabled) {\n this.children.forEach((element) => element.removeAttribute('selected'));\n this.children = this.children.map((element, index) => {\n if (index === tabIndex) {\n element.setAttribute('selected', '');\n this.selectedTab = {\n tab: element.innerText,\n tabIndex: index,\n };\n }\n return element;\n });\n }\n return {\n selectedTab: this.selectedTab.tab,\n selectedTabIndex: this.selectedTab.tabIndex,\n };\n }\n\n @Event({\n eventName: 'sddsChange',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n sddsChange: EventEmitter<{\n selectedTab: {\n tab: string;\n tabIndex: number;\n };\n }>;\n\n @Watch('selectedTab')\n handleSelectedTabChange() {\n this.host.setAttribute('selected-tab', this.selectedTab.tab);\n this.host.setAttribute('selected-tab-index', `${this.selectedTab.tabIndex}`);\n this.sddsChange.emit({\n selectedTab: this.selectedTab,\n });\n }\n\n connectedCallback() {\n this.children = Array.from(this.host.children) as Array<\n HTMLSddsFolderTabsLinkElement | HTMLSddsFolderTabsButtonElement\n >;\n this.children = this.children.map((item, index) => {\n item.addEventListener('click', () => {\n if (!item.disabled) {\n this.children.forEach((element) => element.removeAttribute('selected'));\n item.setAttribute('selected', '');\n this.selectedTab = {\n tab: item.innerText,\n tabIndex: index,\n };\n }\n });\n if (index === 0) {\n item.classList.add('first');\n }\n if (index === this.children.length - 1) {\n item.classList.add('last');\n }\n if (item.selected) {\n this.selectedTab = {\n tab: item.innerText,\n tabIndex: index,\n };\n }\n return item;\n });\n\n this.children = Array.from(this.host.children) as Array<\n HTMLSddsNavigationTabsLinkElement | HTMLSddsNavigationTabsButtonElement\n >;\n this.children[0].classList.add('first');\n this.children[this.children.length - 1].classList.add('last');\n }\n\n componentDidLoad() {\n const resizeObserver = new ResizeObserver((entries) => {\n entries.forEach((entry) => {\n const componentWidth = entry.contentRect.width;\n let buttonsWidth = 0;\n\n const navButtons = Array.from(this.host.children);\n navButtons.forEach((navButton: HTMLElement) => {\n const style = window.getComputedStyle(navButton);\n buttonsWidth +=\n navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n\n navButton.classList.add('sdds-navigation-tabs-tab');\n });\n\n this.componentWidth = componentWidth;\n this.buttonsWidth = buttonsWidth;\n this.scrollWidth = buttonsWidth - componentWidth;\n\n if (this.buttonsWidth > this.componentWidth) {\n this.evaluateScrollButtons();\n } else {\n this.showLeftScroll = false;\n this.showRightScroll = false;\n }\n });\n });\n\n resizeObserver.observe(this.navWrapperElement);\n }\n\n scrollRight() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll + this.buttonsWidth;\n\n this.evaluateScrollButtons();\n }\n\n scrollLeft() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll - this.buttonsWidth;\n\n this.evaluateScrollButtons();\n }\n\n evaluateScrollButtons() {\n const scroll = this.navWrapperElement.scrollLeft;\n\n if (scroll >= this.scrollWidth) {\n this.showRightScroll = false;\n } else {\n this.showRightScroll = true;\n }\n\n if (scroll <= 0) {\n this.showLeftScroll = false;\n } else {\n this.showLeftScroll = true;\n }\n }\n\n render() {\n return (\n <Host class={`${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}`}>\n <div\n role=\"list\"\n class=\"wrapper\"\n ref={(el) => {\n this.navWrapperElement = el as HTMLElement;\n }}\n >\n <button\n class={`scroll-left-button ${this.showLeftScroll ? 'show' : ''}`}\n onClick={() => this.scrollLeft()}\n disabled={!this.showLeftScroll}\n >\n <sdds-icon name=\"chevron_left\" size=\"20px\"></sdds-icon>\n </button>\n <slot />\n <button\n class={`scroll-right-button ${this.showRightScroll ? 'show' : ''}`}\n onClick={() => this.scrollRight()}\n disabled={!this.showRightScroll}\n >\n <sdds-icon name=\"chevron_right\" size=\"20px\"></sdds-icon>\n </button>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,82 +2,109 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-18eb94f0.js');
5
+ const index = require('./index-5ad19933.js');
6
6
  const popper = require('./popper-11d5f714.js');
7
7
 
8
- const popoverCanvasCss = ":host{box-sizing:border-box;min-width:160px;min-height:160px;color:var(--sdds-popover-canvas-color);background-color:var(--sdds-popover-canvas-background);padding:16px;box-shadow:0 3px 3px rgba(0, 0, 0, 0.15), 0 -1px 1px rgba(0, 0, 0, 0.1);border-radius:4px;z-index:800;display:none}:host *{box-sizing:border-box}:host(.sdds-popover-canvas-show){opacity:1;display:block}";
8
+ const popoverCanvasCss = ":host{box-sizing:border-box;color:var(--sdds-popover-canvas-color);background-color:var(--sdds-popover-canvas-background);box-shadow:0 3px 3px rgba(0, 0, 0, 0.15), 0 -1px 1px rgba(0, 0, 0, 0.1);border-radius:4px;z-index:800;display:none}:host *{box-sizing:border-box}:host(.sdds-popover-canvas-show){display:block}";
9
9
 
10
10
  const PopoverCanvas = class {
11
11
  constructor(hostRef) {
12
12
  index.registerInstance(this, hostRef);
13
+ this.initialize = (referenceEl) => {
14
+ this.popperInstance = popper.createPopper(referenceEl, this.host, {
15
+ placement: this.placement,
16
+ modifiers: [
17
+ {
18
+ name: 'offset',
19
+ options: {
20
+ offset: [this.offsetSkidding, this.offsetDistance],
21
+ },
22
+ },
23
+ ...this.modifiers,
24
+ ],
25
+ });
26
+ if (this.show === null) {
27
+ referenceEl.addEventListener('click', (event) => {
28
+ event.stopPropagation();
29
+ if (this.isShown) {
30
+ this.isShown = false;
31
+ }
32
+ else {
33
+ this.isShown = true;
34
+ }
35
+ });
36
+ }
37
+ };
13
38
  this.selector = '';
14
39
  this.referenceEl = undefined;
15
- this.show = false;
40
+ this.show = null;
16
41
  this.placement = 'auto';
17
42
  this.offsetSkidding = 0;
18
43
  this.offsetDistance = 8;
44
+ this.modifiers = [];
19
45
  this.renderedShowValue = false;
20
46
  this.popperInstance = undefined;
21
47
  this.target = undefined;
48
+ this.isShown = false;
49
+ }
50
+ onShowChange(newValue) {
51
+ this.isShown = newValue;
22
52
  }
23
- handleOutsideClick() {
24
- if (this.show) {
25
- this.show = false;
53
+ onReferenceElChange(newValue, oldValue) {
54
+ var _a;
55
+ if (newValue !== oldValue) {
56
+ (_a = this.popperInstance) === null || _a === void 0 ? void 0 : _a.destroy();
57
+ if (newValue) {
58
+ this.initialize(newValue);
59
+ }
60
+ }
61
+ }
62
+ onAnyClick(event) {
63
+ if (this.isShown && this.show === null) {
64
+ // Source: https://lamplightdev.com/blog/2021/04/10/how-to-detect-clicks-outside-of-a-web-component/
65
+ const isClickOutside = !event.composedPath().includes(this.host);
66
+ if (isClickOutside) {
67
+ this.isShown = false;
68
+ }
69
+ }
70
+ }
71
+ connectedCallback() {
72
+ if (this.show !== null) {
73
+ this.isShown = this.show;
26
74
  }
27
75
  }
28
76
  componentDidLoad() {
29
77
  var _a;
30
- this.target = (_a = this.referenceEl) !== null && _a !== void 0 ? _a : document.querySelector(this.selector);
31
- this.renderedShowValue = this.show;
32
- this.popperInstance = popper.createPopper(this.target, this.popoverCanvasElement, {
33
- placement: this.placement,
34
- modifiers: [
35
- {
36
- name: 'offset',
37
- options: {
38
- offset: [this.offsetSkidding, this.offsetDistance],
39
- },
40
- },
41
- ],
42
- });
43
- const showCanvas = () => {
44
- this.show = true;
45
- };
46
- const hideCanvas = () => {
47
- this.show = false;
48
- };
49
- this.target.addEventListener('mousedown', (event) => {
50
- event.stopPropagation();
51
- if (this.show) {
52
- hideCanvas();
78
+ if (this.selector || this.referenceEl) {
79
+ const referenceEl = (_a = this.referenceEl) !== null && _a !== void 0 ? _a : document.querySelector(this.selector);
80
+ if (referenceEl) {
81
+ this.initialize(referenceEl);
53
82
  }
54
83
  else {
55
- showCanvas();
84
+ console.error(`Could not initialize popover-canvas: element with selector '${this.selector}' not found.`);
56
85
  }
57
- });
58
- this.popoverCanvasElement.addEventListener('mousemove', (event) => {
59
- event.stopPropagation();
60
- });
61
- this.popoverCanvasElement.addEventListener('mousedown', (event) => {
62
- event.stopPropagation();
63
- });
86
+ }
64
87
  }
65
88
  componentDidRender() {
66
- if (this.show && !this.renderedShowValue) {
89
+ if (this.isShown && !this.renderedShowValue) {
67
90
  // Here we update the popper position since its position is wrong
68
91
  // before it is rendered.
69
92
  this.popperInstance.update();
70
93
  }
71
- this.renderedShowValue = this.show;
94
+ this.renderedShowValue = this.isShown;
72
95
  }
73
96
  disconnectedCallback() {
74
97
  var _a;
75
98
  (_a = this.popperInstance) === null || _a === void 0 ? void 0 : _a.destroy();
76
99
  }
77
100
  render() {
78
- return (index.h(index.Host, { class: `sdds-popover-canvas ${this.show ? 'sdds-popover-canvas-show' : ''}` }, index.h("slot", null)));
101
+ return (index.h(index.Host, { class: `sdds-popover-canvas ${this.isShown ? 'sdds-popover-canvas-show' : ''}` }, index.h("slot", null)));
79
102
  }
80
- get popoverCanvasElement() { return index.getElement(this); }
103
+ get host() { return index.getElement(this); }
104
+ static get watchers() { return {
105
+ "show": ["onShowChange"],
106
+ "referenceEl": ["onReferenceElChange"]
107
+ }; }
81
108
  };
82
109
  PopoverCanvas.style = popoverCanvasCss;
83
110
 
@@ -1 +1 @@
1
- {"file":"sdds-popover-canvas.entry.cjs.js","mappings":";;;;;;;AAAA,MAAM,gBAAgB,GAAG,oXAAoX;;MCShY,aAAa;;;oBAIG,EAAE;;gBAML,KAAK;qBAGE,MAAM;0BAGJ,CAAC;0BAGD,CAAC;6BAEI,KAAK;;;;EAO3C,kBAAkB;IAChB,IAAI,IAAI,CAAC,IAAI,EAAE;MACb,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;KACnB;GACF;EAED,gBAAgB;;IACd,IAAI,CAAC,MAAM,GAAG,MAAA,IAAI,CAAC,WAAW,mCAAI,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACxE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC;IAEnC,IAAI,CAAC,cAAc,GAAGA,mBAAY,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,oBAAoB,EAAE;MACzE,SAAS,EAAE,IAAI,CAAC,SAAS;MACzB,SAAS,EAAE;QACT;UACE,IAAI,EAAE,QAAQ;UACd,OAAO,EAAE;YACP,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC;WACnD;SACF;OACF;KACF,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG;MACjB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;KAClB,CAAC;IAEF,MAAM,UAAU,GAAG;MACjB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;KACnB,CAAC;IAEF,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,KAAK;MAC9C,KAAK,CAAC,eAAe,EAAE,CAAC;MAExB,IAAI,IAAI,CAAC,IAAI,EAAE;QACb,UAAU,EAAE,CAAC;OACd;WAAM;QACL,UAAU,EAAE,CAAC;OACd;KACF,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,KAAK;MAC5D,KAAK,CAAC,eAAe,EAAE,CAAC;KACzB,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,KAAK;MAC5D,KAAK,CAAC,eAAe,EAAE,CAAC;KACzB,CAAC,CAAC;GACJ;EAED,kBAAkB;IAChB,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;;;MAGxC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;KAC9B;IACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC;GACpC;EAED,oBAAoB;;IAClB,MAAA,IAAI,CAAC,cAAc,0CAAE,OAAO,EAAE,CAAC;GAChC;EAED,MAAM;IACJ,QACEC,QAACC,UAAI,IAAC,KAAK,EAAE,uBAAuB,IAAI,CAAC,IAAI,GAAG,0BAA0B,GAAG,EAAE,EAAE,IAC/ED,qBAAa,CACR,EACP;GACH;;;;;;;","names":["createPopper","h","Host"],"sources":["./src/components/popover-canvas/popover-canvas.scss?tag=sdds-popover-canvas&encapsulation=shadow","./src/components/popover-canvas/popover-canvas.tsx"],"sourcesContent":["@import '../../mixins/box-sizing';\n\n@import '../../mixins/z-index';\n\n:host {\n @include sdds-box-sizing;\n\n min-width: 160px;\n min-height: 160px;\n color: var(--sdds-popover-canvas-color);\n background-color: var(--sdds-popover-canvas-background);\n padding: 16px;\n box-shadow: 0 3px 3px rgb(0 0 0 / 15%), 0 -1px 1px rgb(0 0 0 / 10%);\n border-radius: 4px;\n z-index: z(tooltip);\n display: none;\n}\n\n:host(.sdds-popover-canvas-show) {\n opacity: 1;\n display: block;\n}\n","import { Component, Host, Element, Listen, h, Prop, State } from '@stencil/core';\nimport { createPopper } from '@popperjs/core';\nimport type { Placement, Instance } from '@popperjs/core';\n\n@Component({\n tag: 'sdds-popover-canvas',\n styleUrl: 'popover-canvas.scss',\n shadow: true,\n})\nexport class PopoverCanvas {\n @Element() popoverCanvasElement!: HTMLElement;\n\n /** The CSS-selector for an element that will trigger the popover */\n @Prop() selector: string = '';\n\n /** Element that will trigger the popover (takes priority over selector) */\n @Prop() referenceEl: HTMLElement;\n\n /** Decides if the Popover Canvas should be visible from the start */\n @Prop() show: boolean = false;\n\n /** Decides the placement of the Popover Canvas */\n @Prop() placement: Placement = 'auto';\n\n /** Sets the offset skidding */\n @Prop() offsetSkidding: number = 0;\n\n /** Sets the offset distance */\n @Prop() offsetDistance: number = 8;\n\n @State() renderedShowValue: boolean = false;\n\n @State() popperInstance: Instance;\n\n @State() target: any;\n\n @Listen('mousedown', { target: 'window' })\n handleOutsideClick() {\n if (this.show) {\n this.show = false;\n }\n }\n\n componentDidLoad() {\n this.target = this.referenceEl ?? document.querySelector(this.selector);\n this.renderedShowValue = this.show;\n\n this.popperInstance = createPopper(this.target, this.popoverCanvasElement, {\n placement: this.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [this.offsetSkidding, this.offsetDistance],\n },\n },\n ],\n });\n\n const showCanvas = () => {\n this.show = true;\n };\n\n const hideCanvas = () => {\n this.show = false;\n };\n\n this.target.addEventListener('mousedown', (event) => {\n event.stopPropagation();\n\n if (this.show) {\n hideCanvas();\n } else {\n showCanvas();\n }\n });\n\n this.popoverCanvasElement.addEventListener('mousemove', (event) => {\n event.stopPropagation();\n });\n\n this.popoverCanvasElement.addEventListener('mousedown', (event) => {\n event.stopPropagation();\n });\n }\n\n componentDidRender() {\n if (this.show && !this.renderedShowValue) {\n // Here we update the popper position since its position is wrong\n // before it is rendered.\n this.popperInstance.update();\n }\n this.renderedShowValue = this.show;\n }\n\n disconnectedCallback() {\n this.popperInstance?.destroy();\n }\n\n render() {\n return (\n <Host class={`sdds-popover-canvas ${this.show ? 'sdds-popover-canvas-show' : ''}`}>\n <slot></slot>\n </Host>\n );\n }\n}\n"],"version":3}
1
+ {"file":"sdds-popover-canvas.entry.cjs.js","mappings":";;;;;;;AAAA,MAAM,gBAAgB,GAAG,4TAA4T;;MCSxU,aAAa;;;IA6DxB,eAAU,GAAG,CAAC,WAAW;MACvB,IAAI,CAAC,cAAc,GAAGA,mBAAY,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE;QACzD,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,SAAS,EAAE;UACT;YACE,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE;cACP,MAAM,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC;aACnD;WACF;UACD,GAAG,IAAI,CAAC,SAAS;SAClB;OACF,CAAC,CAAC;MAEH,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE;QACtB,WAAW,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAK;UAC1C,KAAK,CAAC,eAAe,EAAE,CAAC;UACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;WACtB;eAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;WACrB;SACF,CAAC,CAAC;OACJ;KACF,CAAC;oBAjFyB,EAAE;;gBAQL,IAAI;qBAGG,MAAM;0BAGJ,CAAC;0BAGD,CAAC;qBAGJ,EAAE;6BAEM,KAAK;;;mBAMf,KAAK;;EAGjC,YAAY,CAAC,QAAiB;IAC5B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;GACzB;EAGD,mBAAmB,CAAC,QAAqB,EAAE,QAAqB;;IAC9D,IAAI,QAAQ,KAAK,QAAQ,EAAE;MACzB,MAAA,IAAI,CAAC,cAAc,0CAAE,OAAO,EAAE,CAAC;MAE/B,IAAI,QAAQ,EAAE;QACZ,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;OAC3B;KACF;GACF;EAGD,UAAU,CAAC,KAAiB;IAC1B,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE;;MAEtC,MAAM,cAAc,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAW,CAAC,CAAC;MACxE,IAAI,cAAc,EAAE;QAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;OACtB;KACF;GACF;EA4BD,iBAAiB;IACf,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,EAAE;MACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC;KAC1B;GACF;EAED,gBAAgB;;IACd,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,EAAE;MACrC,MAAM,WAAW,GAAG,MAAA,IAAI,CAAC,WAAW,mCAAI,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;MAE9E,IAAI,WAAW,EAAE;QACf,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;OAC9B;WAAM;QACL,OAAO,CAAC,KAAK,CACX,+DAA+D,IAAI,CAAC,QAAQ,cAAc,CAC3F,CAAC;OACH;KACF;GACF;EAED,kBAAkB;IAChB,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;;;MAG3C,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC;KAC9B;IACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC;GACvC;EAED,oBAAoB;;IAClB,MAAA,IAAI,CAAC,cAAc,0CAAE,OAAO,EAAE,CAAC;GAChC;EAED,MAAM;IACJ,QACEC,QAACC,UAAI,IAAC,KAAK,EAAE,uBAAuB,IAAI,CAAC,OAAO,GAAG,0BAA0B,GAAG,EAAE,EAAE,IAClFD,qBAAa,CACR,EACP;GACH;;;;;;;;;;;","names":["createPopper","h","Host"],"sources":["./src/components/popover-canvas/popover-canvas.scss?tag=sdds-popover-canvas&encapsulation=shadow","./src/components/popover-canvas/popover-canvas.tsx"],"sourcesContent":["@import '../../mixins/box-sizing';\n\n@import '../../mixins/z-index';\n\n:host {\n @include sdds-box-sizing;\n\n color: var(--sdds-popover-canvas-color);\n background-color: var(--sdds-popover-canvas-background);\n box-shadow: 0 3px 3px rgb(0 0 0 / 15%), 0 -1px 1px rgb(0 0 0 / 10%);\n border-radius: 4px;\n z-index: z(tooltip);\n display: none;\n}\n\n:host(.sdds-popover-canvas-show) {\n display: block;\n}\n","import { Component, Host, Element, Listen, h, Prop, State, Watch } from '@stencil/core';\nimport { createPopper } from '@popperjs/core';\nimport type { Placement, Instance } from '@popperjs/core';\n\n@Component({\n tag: 'sdds-popover-canvas',\n styleUrl: 'popover-canvas.scss',\n shadow: true,\n})\nexport class PopoverCanvas {\n @Element() host!: HTMLSddsPopoverCanvasElement;\n\n /** The CSS-selector for an element that will trigger the popover */\n @Prop() selector: string = '';\n\n /** Element that will trigger the popover (takes priority over selector) */\n @Prop() referenceEl: HTMLElement;\n\n /** Controls wether the popover is shown or not. If this is set hiding and showing\n * will be decided by this prop and will need to be controlled from the outside.\n */\n @Prop() show: boolean = null;\n\n /** Decides the placement of the Popover Canvas. See https://popper.js.org/docs/v2/constructors/#placement */\n @Prop() placement: Placement = 'auto';\n\n /** Sets the offset skidding */\n @Prop() offsetSkidding: number = 0;\n\n /** Sets the offset distance */\n @Prop() offsetDistance: number = 8;\n\n /** Array of modifier objects to pass to popper.js. See https://popper.js.org/docs/v2/modifiers/ */\n @Prop() modifiers: Object[] = [];\n\n @State() renderedShowValue: boolean = false;\n\n @State() popperInstance: Instance;\n\n @State() target: any;\n\n @State() isShown: boolean = false;\n\n @Watch('show')\n onShowChange(newValue: boolean) {\n this.isShown = newValue;\n }\n\n @Watch('referenceEl')\n onReferenceElChange(newValue: HTMLElement, oldValue: HTMLElement) {\n if (newValue !== oldValue) {\n this.popperInstance?.destroy();\n\n if (newValue) {\n this.initialize(newValue);\n }\n }\n }\n\n @Listen('click', { target: 'window' })\n onAnyClick(event: MouseEvent) {\n if (this.isShown && this.show === null) {\n // Source: https://lamplightdev.com/blog/2021/04/10/how-to-detect-clicks-outside-of-a-web-component/\n const isClickOutside = !event.composedPath().includes(this.host as any);\n if (isClickOutside) {\n this.isShown = false;\n }\n }\n }\n\n initialize = (referenceEl) => {\n this.popperInstance = createPopper(referenceEl, this.host, {\n placement: this.placement,\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [this.offsetSkidding, this.offsetDistance],\n },\n },\n ...this.modifiers,\n ],\n });\n\n if (this.show === null) {\n referenceEl.addEventListener('click', (event) => {\n event.stopPropagation();\n if (this.isShown) {\n this.isShown = false;\n } else {\n this.isShown = true;\n }\n });\n }\n };\n\n connectedCallback() {\n if (this.show !== null) {\n this.isShown = this.show;\n }\n }\n\n componentDidLoad() {\n if (this.selector || this.referenceEl) {\n const referenceEl = this.referenceEl ?? document.querySelector(this.selector);\n\n if (referenceEl) {\n this.initialize(referenceEl);\n } else {\n console.error(\n `Could not initialize popover-canvas: element with selector '${this.selector}' not found.`,\n );\n }\n }\n }\n\n componentDidRender() {\n if (this.isShown && !this.renderedShowValue) {\n // Here we update the popper position since its position is wrong\n // before it is rendered.\n this.popperInstance.update();\n }\n this.renderedShowValue = this.isShown;\n }\n\n disconnectedCallback() {\n this.popperInstance?.destroy();\n }\n\n render() {\n return (\n <Host class={`sdds-popover-canvas ${this.isShown ? 'sdds-popover-canvas-show' : ''}`}>\n <slot></slot>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-18eb94f0.js');
5
+ const index = require('./index-5ad19933.js');
6
6
  const popper = require('./popper-11d5f714.js');
7
7
 
8
8
  const popoverMenuCss = ":host{box-sizing:border-box;overflow:hidden;width:160px;background-color:var(--sdds-popover-menu-background);padding:16px;box-shadow:0 3px 3px rgba(0, 0, 0, 0.15), 0 -1px 1px rgba(0, 0, 0, 0.1);border-radius:4px;display:none;z-index:800}:host *{box-sizing:border-box}:host(.sdds-popover-menu-show){opacity:1;display:block}";
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-18eb94f0.js');
5
+ const index = require('./index-5ad19933.js');
6
6
 
7
7
  const radioButtonComponentCss = ".sc-sdds-radio-button:root,.sdds-mode-light.sc-sdds-radio-button{--sdds-radio-button-color:var(--sdds-grey-958);--sdds-radio-button-interaction-01:var(--sdds-blue-800);--sdds-radio-button-interaction-02:var(--sdds-white);--sdds-radio-button-background-hover:var(--sdds-blue-800);--sdds-radio-button-background-focus:var(--sdds-blue-800);--sdds-radio-button-disabled:var(--sdds-grey-600);--sdds-radio-button-border-color-disabled-after:var(--sdds-grey-700);--sdds-radio-button-color-disabled-after:var(--sdds-grey-700);--sdds-radio-button-color-disabled-before:var(--sdds-grey-700)}.sdds-mode-dark.sc-sdds-radio-button{--sdds-radio-button-color:var(--sdds-white);--sdds-radio-button-interaction-01:var(--sdds-white);--sdds-radio-button-interaction-02:var(--sdds-grey-958);--sdds-radio-button-background-hover:var(--sdds-white);--sdds-radio-button-background-focus:var(--sdds-white);--sdds-radio-button-disabled:var(--sdds-grey-600);--sdds-radio-button-border-color-disabled-after:var(--sdds-grey-700);--sdds-radio-button-color-disabled-after:var(--sdds-grey-700)}.sdds-radio-button.sc-sdds-radio-button{box-sizing:border-box;display:flex;align-items:center;margin-left:-4px;font:var(--sdds-detail-02);letter-spacing:var(--sdds-detail-02-ls);color:var(--sdds-radio-button-color)}.sdds-radio-button.sc-sdds-radio-button *.sc-sdds-radio-button{box-sizing:border-box}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button{appearance:none;outline:none;margin:0;border:0;width:24px;height:24px;border-radius:50%;position:relative;cursor:pointer}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button+label.sc-sdds-radio-button{padding:var(--sdds-spacing-element-4) 0 var(--sdds-spacing-element-4) var(--sdds-spacing-element-4);cursor:pointer}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button::before,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button::after{content:\"\";position:absolute;border-radius:50%;box-sizing:border-box}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button::before{width:24px;height:24px;left:0;top:0}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button::after{border:1px solid var(--sdds-radio-button-interaction-01);background-color:var(--sdds-radio-button-interaction-02);width:16px;height:16px;left:4px;top:4px}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:hover::before{background-color:var(--sdds-radio-button-background-hover);opacity:0.12}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:focus::before{background-color:var(--sdds-radio-button-background-focus);opacity:0.24;animation:rb-focus 0.4s cubic-bezier(0.65, 0.05, 0.38, 0.95) forwards}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:disabled,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].disabled.sc-sdds-radio-button{cursor:not-allowed}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:disabled::after,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].disabled.sc-sdds-radio-button::after{border-color:var(--sdds-radio-button-border-color-disabled-after);background-color:var(--sdds-radio-button-interaction-02)}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:disabled+label.sc-sdds-radio-button,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].disabled.sc-sdds-radio-button+label.sc-sdds-radio-button{color:var(--sdds-radio-button-disabled);cursor:not-allowed}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:disabled:hover::before,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].disabled.sc-sdds-radio-button:hover::before{display:none;opacity:1}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked::after{border:4px solid var(--sdds-radio-button-interaction-01)}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked:disabled:hover::before,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked:disabled::before,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked.disabled:hover::before,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked.disabled::before{display:block;width:16px;height:16px;left:4px;top:4px;border:1px solid var(--sdds-radio-button-color-disabled-before);box-sizing:content-box}.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked:disabled::after,.sdds-radio-button.sc-sdds-radio-button .sdds-form-input[type=radio].sc-sdds-radio-button:checked.disabled::after{border:4px solid var(--sdds-radio-button-interaction-02);background-color:var(--sdds-radio-button-color-disabled-after);left:5px;top:5px}@keyframes rb-focus{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:0.24}}";
8
8
 
@@ -18,7 +18,11 @@ const RadioButton = class {
18
18
  this.disabled = false;
19
19
  }
20
20
  render() {
21
- return (index.h("div", { class: "sdds-radio-button" }, index.h("input", { class: "sdds-form-input", type: "radio", name: this.name, id: this.radioId, value: this.value, checked: this.checked, "aria-checked": this.checked, "aria-describedby": this.host.getAttribute('aria-describedby'), required: this.required, disabled: this.disabled, onChange: () => {
21
+ return (index.h("div", { class: "sdds-radio-button" }, index.h("input", { class: "sdds-form-input", type: "radio", name: this.name, id: this.radioId, value: this.value, checked: this.checked, "aria-checked": this.checked,
22
+ // REMEMBER TO ENABLE ARIA PROPS ONCE ALIGNMENT HAS BEEN MADE!
23
+ // aria-labelledby={this.ariaLabelledBy}
24
+ // aria-describedby={this.host.getAttribute('aria-describedby')}
25
+ required: this.required, disabled: this.disabled, onChange: () => {
22
26
  this.sddsChange.emit({
23
27
  radioId: this.radioId,
24
28
  value: this.value,