@db-ux/wc-core-components 3.0.2-copilot2-e7bf98b → 3.0.2-shell-ed0ed7c

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 (558) hide show
  1. package/README.md +0 -10
  2. package/dist/cjs/{constants-CTtyzyuo.js → constants-BOd99bQT.js} +7 -2
  3. package/dist/cjs/constants-BOd99bQT.js.map +1 -0
  4. package/dist/cjs/db-accordion-item.cjs.entry.js +2 -2
  5. package/dist/cjs/db-accordion.cjs.entry.js +2 -2
  6. package/dist/cjs/db-badge.cjs.entry.js +2 -2
  7. package/dist/cjs/db-button.cjs.entry.js +2 -2
  8. package/dist/cjs/db-card.cjs.entry.js +3 -3
  9. package/dist/cjs/db-checkbox.cjs.entry.js +6 -6
  10. package/dist/cjs/db-checkbox.cjs.entry.js.map +1 -1
  11. package/dist/cjs/db-checkbox.entry.cjs.js.map +1 -1
  12. package/dist/cjs/db-control-panel-brand.cjs.entry.js +57 -0
  13. package/dist/cjs/db-control-panel-brand.cjs.entry.js.map +1 -0
  14. package/dist/cjs/db-control-panel-brand.entry.cjs.js.map +1 -0
  15. package/dist/cjs/db-control-panel-desktop.cjs.entry.js +91 -0
  16. package/dist/cjs/db-control-panel-desktop.cjs.entry.js.map +1 -0
  17. package/dist/cjs/db-control-panel-desktop.entry.cjs.js.map +1 -0
  18. package/dist/cjs/db-control-panel-flat-icon-navigation.cjs.entry.js +76 -0
  19. package/dist/cjs/db-control-panel-flat-icon-navigation.cjs.entry.js.map +1 -0
  20. package/dist/cjs/db-control-panel-flat-icon-navigation.entry.cjs.js.map +1 -0
  21. package/dist/cjs/{db-brand.cjs.entry.js → db-control-panel-meta-navigation.cjs.entry.js} +8 -10
  22. package/dist/cjs/db-control-panel-meta-navigation.cjs.entry.js.map +1 -0
  23. package/dist/cjs/db-control-panel-meta-navigation.entry.cjs.js.map +1 -0
  24. package/dist/cjs/db-control-panel-mobile.cjs.entry.js +76 -0
  25. package/dist/cjs/db-control-panel-mobile.cjs.entry.js.map +1 -0
  26. package/dist/cjs/db-control-panel-mobile.entry.cjs.js.map +1 -0
  27. package/dist/cjs/db-control-panel-primary-actions.cjs.entry.js +55 -0
  28. package/dist/cjs/db-control-panel-primary-actions.cjs.entry.js.map +1 -0
  29. package/dist/cjs/db-control-panel-primary-actions.entry.cjs.js.map +1 -0
  30. package/dist/cjs/db-control-panel-secondary-actions.cjs.entry.js +55 -0
  31. package/dist/cjs/db-control-panel-secondary-actions.cjs.entry.js.map +1 -0
  32. package/dist/cjs/db-control-panel-secondary-actions.entry.cjs.js.map +1 -0
  33. package/dist/cjs/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.cjs.js.map +1 -1
  34. package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js +13 -13
  35. package/dist/cjs/db-custom-select-dropdown_5.cjs.entry.js.map +1 -1
  36. package/dist/cjs/db-custom-select-form-field.cjs.entry.js +3 -3
  37. package/dist/cjs/db-custom-select.cjs.entry.js +15 -15
  38. package/dist/cjs/db-custom-select.cjs.entry.js.map +1 -1
  39. package/dist/cjs/db-custom-select.entry.cjs.js.map +1 -1
  40. package/dist/cjs/db-divider.cjs.entry.js +2 -2
  41. package/dist/cjs/db-drawer.cjs.entry.js +6 -6
  42. package/dist/cjs/db-drawer.cjs.entry.js.map +1 -1
  43. package/dist/cjs/db-drawer.entry.cjs.js.map +1 -1
  44. package/dist/cjs/db-icon.cjs.entry.js +2 -2
  45. package/dist/cjs/db-infotext.cjs.entry.js +2 -2
  46. package/dist/cjs/db-link.cjs.entry.js +2 -2
  47. package/dist/cjs/db-navigation-item-group.cjs.entry.js +159 -0
  48. package/dist/cjs/db-navigation-item-group.cjs.entry.js.map +1 -0
  49. package/dist/cjs/db-navigation-item-group.entry.cjs.js.map +1 -0
  50. package/dist/cjs/db-navigation-item.cjs.entry.js +4 -72
  51. package/dist/cjs/db-navigation-item.cjs.entry.js.map +1 -1
  52. package/dist/cjs/db-navigation-item.entry.cjs.js.map +1 -1
  53. package/dist/cjs/db-navigation.cjs.entry.js +112 -6
  54. package/dist/cjs/db-navigation.cjs.entry.js.map +1 -1
  55. package/dist/cjs/db-navigation.entry.cjs.js.map +1 -1
  56. package/dist/cjs/db-notification.cjs.entry.js +4 -4
  57. package/dist/cjs/db-popover.cjs.entry.js +5 -6
  58. package/dist/cjs/db-popover.cjs.entry.js.map +1 -1
  59. package/dist/cjs/db-popover.entry.cjs.js.map +1 -1
  60. package/dist/cjs/db-radio.cjs.entry.js +2 -2
  61. package/dist/cjs/db-section.cjs.entry.js +4 -4
  62. package/dist/cjs/db-select.cjs.entry.js +7 -7
  63. package/dist/cjs/db-select.cjs.entry.js.map +1 -1
  64. package/dist/cjs/db-select.entry.cjs.js.map +1 -1
  65. package/dist/cjs/db-shell-sub-navigation.cjs.entry.js +71 -0
  66. package/dist/cjs/db-shell-sub-navigation.cjs.entry.js.map +1 -0
  67. package/dist/cjs/db-shell-sub-navigation.entry.cjs.js.map +1 -0
  68. package/dist/cjs/{db-page.cjs.entry.js → db-shell.cjs.entry.js} +9 -15
  69. package/dist/cjs/db-shell.cjs.entry.js.map +1 -0
  70. package/dist/cjs/db-shell.entry.cjs.js.map +1 -0
  71. package/dist/cjs/db-stack.cjs.entry.js +3 -3
  72. package/dist/cjs/db-switch.cjs.entry.js +2 -2
  73. package/dist/cjs/db-tab-item_3.cjs.entry.js +8 -8
  74. package/dist/cjs/db-tabs.cjs.entry.js +5 -5
  75. package/dist/cjs/db-tabs.cjs.entry.js.map +1 -1
  76. package/dist/cjs/db-tabs.entry.cjs.js.map +1 -1
  77. package/dist/cjs/db-textarea.cjs.entry.js +6 -6
  78. package/dist/cjs/db-textarea.cjs.entry.js.map +1 -1
  79. package/dist/cjs/db-textarea.entry.cjs.js.map +1 -1
  80. package/dist/cjs/db-tooltip.cjs.entry.js +7 -8
  81. package/dist/cjs/db-tooltip.cjs.entry.js.map +1 -1
  82. package/dist/cjs/db-tooltip.entry.cjs.js.map +1 -1
  83. package/dist/cjs/db-ux.cjs.js +3 -3
  84. package/dist/cjs/db-ux.cjs.js.map +1 -1
  85. package/dist/cjs/{floating-components-ogUqz72V.js → floating-components-DSENlGvK.js} +78 -50
  86. package/dist/cjs/floating-components-DSENlGvK.js.map +1 -0
  87. package/dist/cjs/{index-9urL1KCD.js → index-B1qpUQFv.js} +9 -3
  88. package/dist/cjs/index-B1qpUQFv.js.map +1 -0
  89. package/dist/cjs/index.cjs.js +21 -11
  90. package/dist/cjs/index.cjs.js.map +1 -1
  91. package/dist/cjs/loader.cjs.js +2 -2
  92. package/dist/cjs/{navigation-DauGE-qj.js → navigation-DWSyoPJm.js} +38 -21
  93. package/dist/cjs/navigation-DWSyoPJm.js.map +1 -0
  94. package/dist/collection/collection-manifest.json +14 -7
  95. package/dist/collection/components/button/button.js +1 -1
  96. package/dist/collection/components/card/card.js +2 -2
  97. package/dist/collection/components/checkbox/checkbox.js +4 -4
  98. package/dist/collection/components/checkbox/checkbox.js.map +1 -1
  99. package/dist/collection/components/{brand/brand.js → control-panel-brand/control-panel-brand.js} +22 -47
  100. package/dist/collection/components/control-panel-brand/control-panel-brand.js.map +1 -0
  101. package/dist/collection/components/control-panel-brand/index.js +3 -0
  102. package/dist/collection/components/control-panel-brand/index.js.map +1 -0
  103. package/dist/collection/components/control-panel-brand/model.js.map +1 -0
  104. package/dist/collection/components/control-panel-desktop/control-panel-desktop.js +267 -0
  105. package/dist/collection/components/control-panel-desktop/control-panel-desktop.js.map +1 -0
  106. package/dist/collection/components/control-panel-desktop/index.js +3 -0
  107. package/dist/collection/components/control-panel-desktop/index.js.map +1 -0
  108. package/dist/collection/components/control-panel-desktop/model.js.map +1 -0
  109. package/dist/collection/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.js +162 -0
  110. package/dist/collection/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.js.map +1 -0
  111. package/dist/collection/components/control-panel-flat-icon-navigation/index.js +3 -0
  112. package/dist/collection/components/control-panel-flat-icon-navigation/index.js.map +1 -0
  113. package/dist/collection/components/control-panel-flat-icon-navigation/model.js +2 -0
  114. package/dist/collection/components/control-panel-flat-icon-navigation/model.js.map +1 -0
  115. package/dist/collection/components/control-panel-meta-navigation/control-panel-meta-navigation.js +104 -0
  116. package/dist/collection/components/control-panel-meta-navigation/control-panel-meta-navigation.js.map +1 -0
  117. package/dist/collection/components/control-panel-meta-navigation/index.js +3 -0
  118. package/dist/collection/components/control-panel-meta-navigation/index.js.map +1 -0
  119. package/dist/collection/components/control-panel-meta-navigation/model.js +2 -0
  120. package/dist/collection/components/control-panel-meta-navigation/model.js.map +1 -0
  121. package/dist/collection/components/{header/header.js → control-panel-mobile/control-panel-mobile.js} +76 -76
  122. package/dist/collection/components/control-panel-mobile/control-panel-mobile.js.map +1 -0
  123. package/dist/collection/components/control-panel-mobile/index.js +3 -0
  124. package/dist/collection/components/control-panel-mobile/index.js.map +1 -0
  125. package/dist/collection/components/control-panel-mobile/model.js +2 -0
  126. package/dist/collection/components/control-panel-mobile/model.js.map +1 -0
  127. package/dist/collection/components/control-panel-primary-actions/control-panel-primary-actions.js +104 -0
  128. package/dist/collection/components/control-panel-primary-actions/control-panel-primary-actions.js.map +1 -0
  129. package/dist/collection/components/control-panel-primary-actions/index.js +3 -0
  130. package/dist/collection/components/control-panel-primary-actions/index.js.map +1 -0
  131. package/dist/collection/components/control-panel-primary-actions/model.js +2 -0
  132. package/dist/collection/components/control-panel-primary-actions/model.js.map +1 -0
  133. package/dist/collection/components/control-panel-secondary-actions/control-panel-secondary-actions.js +104 -0
  134. package/dist/collection/components/control-panel-secondary-actions/control-panel-secondary-actions.js.map +1 -0
  135. package/dist/collection/components/control-panel-secondary-actions/index.js +3 -0
  136. package/dist/collection/components/control-panel-secondary-actions/index.js.map +1 -0
  137. package/dist/collection/components/control-panel-secondary-actions/model.js +2 -0
  138. package/dist/collection/components/control-panel-secondary-actions/model.js.map +1 -0
  139. package/dist/collection/components/custom-select/custom-select.js +12 -12
  140. package/dist/collection/components/custom-select/custom-select.js.map +1 -1
  141. package/dist/collection/components/custom-select/model.js.map +1 -1
  142. package/dist/collection/components/custom-select-dropdown/custom-select-dropdown.js +2 -2
  143. package/dist/collection/components/custom-select-form-field/custom-select-form-field.js +2 -2
  144. package/dist/collection/components/custom-select-list/custom-select-list.js +2 -2
  145. package/dist/collection/components/custom-select-list-item/custom-select-list-item.js +1 -1
  146. package/dist/collection/components/divider/divider.js +1 -1
  147. package/dist/collection/components/drawer/drawer.js +30 -5
  148. package/dist/collection/components/drawer/drawer.js.map +1 -1
  149. package/dist/collection/components/drawer/model.js +1 -1
  150. package/dist/collection/components/drawer/model.js.map +1 -1
  151. package/dist/collection/components/icon/icon.js +1 -1
  152. package/dist/collection/components/infotext/infotext.js +1 -1
  153. package/dist/collection/components/input/input.js +4 -4
  154. package/dist/collection/components/input/input.js.map +1 -1
  155. package/dist/collection/components/link/link.js +1 -1
  156. package/dist/collection/components/navigation/model.js.map +1 -1
  157. package/dist/collection/components/navigation/navigation.js +206 -7
  158. package/dist/collection/components/navigation/navigation.js.map +1 -1
  159. package/dist/collection/components/navigation-item/model.js.map +1 -1
  160. package/dist/collection/components/navigation-item/navigation-item.js +9 -238
  161. package/dist/collection/components/navigation-item/navigation-item.js.map +1 -1
  162. package/dist/collection/components/navigation-item-group/index.js +3 -0
  163. package/dist/collection/components/navigation-item-group/index.js.map +1 -0
  164. package/dist/collection/components/navigation-item-group/model.js +2 -0
  165. package/dist/collection/components/navigation-item-group/model.js.map +1 -0
  166. package/dist/collection/components/navigation-item-group/navigation-item-group.js +453 -0
  167. package/dist/collection/components/navigation-item-group/navigation-item-group.js.map +1 -0
  168. package/dist/collection/components/notification/notification.js +2 -2
  169. package/dist/collection/components/popover/popover.js +28 -29
  170. package/dist/collection/components/popover/popover.js.map +1 -1
  171. package/dist/collection/components/radio/radio.js +1 -1
  172. package/dist/collection/components/section/section.js +2 -2
  173. package/dist/collection/components/select/select.js +5 -5
  174. package/dist/collection/components/select/select.js.map +1 -1
  175. package/dist/collection/components/shell/index.js +3 -0
  176. package/dist/collection/components/shell/index.js.map +1 -0
  177. package/dist/collection/components/shell/model.js +2 -0
  178. package/dist/collection/components/shell/model.js.map +1 -0
  179. package/dist/collection/components/shell/shell.js +299 -0
  180. package/dist/collection/components/shell/shell.js.map +1 -0
  181. package/dist/collection/components/shell-sub-navigation/index.js +3 -0
  182. package/dist/collection/components/shell-sub-navigation/index.js.map +1 -0
  183. package/dist/collection/components/shell-sub-navigation/model.js +2 -0
  184. package/dist/collection/components/shell-sub-navigation/model.js.map +1 -0
  185. package/dist/collection/components/{page/page.js → shell-sub-navigation/shell-sub-navigation.js} +43 -94
  186. package/dist/collection/components/shell-sub-navigation/shell-sub-navigation.js.map +1 -0
  187. package/dist/collection/components/stack/stack.js +2 -2
  188. package/dist/collection/components/switch/switch.js +1 -1
  189. package/dist/collection/components/tab-item/tab-item.js +2 -2
  190. package/dist/collection/components/tab-list/tab-list.js +2 -2
  191. package/dist/collection/components/tab-panel/tab-panel.js +2 -2
  192. package/dist/collection/components/tabs/model.js.map +1 -1
  193. package/dist/collection/components/tabs/tabs.js +4 -4
  194. package/dist/collection/components/tabs/tabs.js.map +1 -1
  195. package/dist/collection/components/tag/tag.js +2 -2
  196. package/dist/collection/components/textarea/textarea.js +4 -4
  197. package/dist/collection/components/textarea/textarea.js.map +1 -1
  198. package/dist/collection/components/tooltip/tooltip.js +29 -30
  199. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  200. package/dist/collection/index.js +19 -6
  201. package/dist/collection/index.js.map +1 -1
  202. package/dist/collection/shared/constants.js +3 -0
  203. package/dist/collection/shared/constants.js.map +1 -1
  204. package/dist/collection/shared/model.js +3 -0
  205. package/dist/collection/shared/model.js.map +1 -1
  206. package/dist/collection/utils/floating-components.js +76 -48
  207. package/dist/collection/utils/floating-components.js.map +1 -1
  208. package/dist/collection/utils/navigation.js +34 -22
  209. package/dist/collection/utils/navigation.js.map +1 -1
  210. package/dist/custom-elements.json +7740 -6149
  211. package/dist/db-ux/db-checkbox.entry.esm.js.map +1 -1
  212. package/dist/db-ux/db-control-panel-brand.entry.esm.js.map +1 -0
  213. package/dist/db-ux/db-control-panel-desktop.entry.esm.js.map +1 -0
  214. package/dist/db-ux/db-control-panel-flat-icon-navigation.entry.esm.js.map +1 -0
  215. package/dist/db-ux/db-control-panel-meta-navigation.entry.esm.js.map +1 -0
  216. package/dist/db-ux/db-control-panel-mobile.entry.esm.js.map +1 -0
  217. package/dist/db-ux/db-control-panel-primary-actions.entry.esm.js.map +1 -0
  218. package/dist/db-ux/db-control-panel-secondary-actions.entry.esm.js.map +1 -0
  219. package/dist/db-ux/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.esm.js.map +1 -1
  220. package/dist/db-ux/db-custom-select.entry.esm.js.map +1 -1
  221. package/dist/db-ux/db-drawer.entry.esm.js.map +1 -1
  222. package/dist/db-ux/db-navigation-item-group.entry.esm.js.map +1 -0
  223. package/dist/db-ux/db-navigation-item.entry.esm.js.map +1 -1
  224. package/dist/db-ux/db-navigation.entry.esm.js.map +1 -1
  225. package/dist/db-ux/db-popover.entry.esm.js.map +1 -1
  226. package/dist/db-ux/db-select.entry.esm.js.map +1 -1
  227. package/dist/db-ux/db-shell-sub-navigation.entry.esm.js.map +1 -0
  228. package/dist/db-ux/db-shell.entry.esm.js.map +1 -0
  229. package/dist/db-ux/db-tabs.entry.esm.js.map +1 -1
  230. package/dist/db-ux/db-textarea.entry.esm.js.map +1 -1
  231. package/dist/db-ux/db-tooltip.entry.esm.js.map +1 -1
  232. package/dist/db-ux/db-ux.esm.js +1 -1
  233. package/dist/db-ux/db-ux.esm.js.map +1 -1
  234. package/dist/db-ux/index.esm.js +1 -1
  235. package/dist/db-ux/index.esm.js.map +1 -1
  236. package/dist/db-ux/p-0262e847.entry.js +2 -0
  237. package/dist/db-ux/p-0262e847.entry.js.map +1 -0
  238. package/dist/db-ux/p-13f527fb.entry.js +2 -0
  239. package/dist/db-ux/p-13f527fb.entry.js.map +1 -0
  240. package/dist/db-ux/p-1a56dee3.entry.js +2 -0
  241. package/dist/db-ux/p-1a56dee3.entry.js.map +1 -0
  242. package/dist/db-ux/p-1b0815ab.entry.js +2 -0
  243. package/dist/db-ux/p-1b0815ab.entry.js.map +1 -0
  244. package/dist/db-ux/p-1d41f71c.entry.js +2 -0
  245. package/dist/db-ux/p-1d41f71c.entry.js.map +1 -0
  246. package/dist/db-ux/p-1dccdff4.entry.js +2 -0
  247. package/dist/db-ux/p-29dcb78d.entry.js +2 -0
  248. package/dist/db-ux/p-29dcb78d.entry.js.map +1 -0
  249. package/dist/db-ux/p-3f2ab801.entry.js +2 -0
  250. package/dist/db-ux/p-3f2ab801.entry.js.map +1 -0
  251. package/dist/db-ux/p-40e42146.entry.js +2 -0
  252. package/dist/db-ux/p-40e42146.entry.js.map +1 -0
  253. package/dist/db-ux/p-4645cc92.entry.js +2 -0
  254. package/dist/db-ux/{p-c5ff3d3f.entry.js → p-504a9cfc.entry.js} +2 -2
  255. package/dist/db-ux/{p-e6e7719e.entry.js → p-53682d25.entry.js} +2 -2
  256. package/dist/db-ux/p-5be272f0.entry.js +2 -0
  257. package/dist/db-ux/p-5cb180c4.entry.js +2 -0
  258. package/dist/db-ux/p-5cb180c4.entry.js.map +1 -0
  259. package/dist/db-ux/{p-16f1fa7c.entry.js → p-5d292f94.entry.js} +2 -2
  260. package/dist/db-ux/{p-02fcd4a8.entry.js → p-5e4ac324.entry.js} +2 -2
  261. package/dist/db-ux/p-6c023c87.entry.js +2 -0
  262. package/dist/db-ux/p-6c023c87.entry.js.map +1 -0
  263. package/dist/db-ux/{p-f03f7076.entry.js → p-6fd148ce.entry.js} +2 -2
  264. package/dist/db-ux/p-7153636c.entry.js +2 -0
  265. package/dist/db-ux/p-73614370.entry.js +2 -0
  266. package/dist/db-ux/{p-209cf793.entry.js → p-81d7921b.entry.js} +2 -2
  267. package/dist/db-ux/{p-d7168627.entry.js → p-8262ab69.entry.js} +2 -2
  268. package/dist/db-ux/p-8db3c126.entry.js +2 -0
  269. package/dist/db-ux/{p-d6aeabf0.entry.js.map → p-8db3c126.entry.js.map} +1 -1
  270. package/dist/db-ux/p-99d090b7.entry.js +2 -0
  271. package/dist/db-ux/p-9d18d065.entry.js +2 -0
  272. package/dist/db-ux/p-9d18d065.entry.js.map +1 -0
  273. package/dist/db-ux/p-CZxi1Pek.js +2 -0
  274. package/dist/db-ux/p-CZxi1Pek.js.map +1 -0
  275. package/dist/db-ux/p-D3kmGlOI.js +2 -0
  276. package/dist/db-ux/p-D3kmGlOI.js.map +1 -0
  277. package/dist/db-ux/p-Dst8dqRS.js +2 -0
  278. package/dist/db-ux/p-Dst8dqRS.js.map +1 -0
  279. package/dist/db-ux/p-a652e0d0.entry.js +2 -0
  280. package/dist/db-ux/p-a652e0d0.entry.js.map +1 -0
  281. package/dist/db-ux/{p-bd7d1646.entry.js → p-b713791b.entry.js} +2 -2
  282. package/dist/db-ux/p-b90f037e.entry.js +2 -0
  283. package/dist/db-ux/p-b90f037e.entry.js.map +1 -0
  284. package/dist/db-ux/p-bb9043b3.entry.js +2 -0
  285. package/dist/db-ux/p-bb9043b3.entry.js.map +1 -0
  286. package/dist/db-ux/p-bbbb47fe.entry.js +2 -0
  287. package/dist/db-ux/p-bbbb47fe.entry.js.map +1 -0
  288. package/dist/db-ux/p-c00303d4.entry.js +2 -0
  289. package/dist/db-ux/p-c00303d4.entry.js.map +1 -0
  290. package/dist/db-ux/p-c841ce92.entry.js +2 -0
  291. package/dist/db-ux/p-c841ce92.entry.js.map +1 -0
  292. package/dist/db-ux/{p-a2b55626.entry.js → p-d6047812.entry.js} +2 -2
  293. package/dist/db-ux/p-d8f87aaa.entry.js +2 -0
  294. package/dist/db-ux/p-d8f87aaa.entry.js.map +1 -0
  295. package/dist/db-ux/p-e39aeff2.entry.js +2 -0
  296. package/dist/db-ux/p-e39aeff2.entry.js.map +1 -0
  297. package/dist/db-ux/p-e418dace.entry.js +2 -0
  298. package/dist/db-ux/p-e418dace.entry.js.map +1 -0
  299. package/dist/db-ux/p-eaa14b89.entry.js +2 -0
  300. package/dist/db-ux/p-eaa14b89.entry.js.map +1 -0
  301. package/dist/db-ux/p-uOzX56mL.js +3 -0
  302. package/dist/db-ux/p-uOzX56mL.js.map +1 -0
  303. package/dist/esm/{constants-DC9V_oNU.js → constants-Dst8dqRS.js} +6 -3
  304. package/dist/esm/constants-Dst8dqRS.js.map +1 -0
  305. package/dist/esm/db-accordion-item.entry.js +2 -2
  306. package/dist/esm/db-accordion.entry.js +2 -2
  307. package/dist/esm/db-badge.entry.js +2 -2
  308. package/dist/esm/db-button.entry.js +2 -2
  309. package/dist/esm/db-card.entry.js +3 -3
  310. package/dist/esm/db-checkbox.entry.js +6 -6
  311. package/dist/esm/db-checkbox.entry.js.map +1 -1
  312. package/dist/esm/db-control-panel-brand.entry.js +55 -0
  313. package/dist/esm/db-control-panel-brand.entry.js.map +1 -0
  314. package/dist/esm/db-control-panel-desktop.entry.js +89 -0
  315. package/dist/esm/db-control-panel-desktop.entry.js.map +1 -0
  316. package/dist/esm/db-control-panel-flat-icon-navigation.entry.js +74 -0
  317. package/dist/esm/db-control-panel-flat-icon-navigation.entry.js.map +1 -0
  318. package/dist/esm/{db-brand.entry.js → db-control-panel-meta-navigation.entry.js} +9 -11
  319. package/dist/esm/db-control-panel-meta-navigation.entry.js.map +1 -0
  320. package/dist/esm/db-control-panel-mobile.entry.js +74 -0
  321. package/dist/esm/db-control-panel-mobile.entry.js.map +1 -0
  322. package/dist/esm/db-control-panel-primary-actions.entry.js +53 -0
  323. package/dist/esm/db-control-panel-primary-actions.entry.js.map +1 -0
  324. package/dist/esm/db-control-panel-secondary-actions.entry.js +53 -0
  325. package/dist/esm/db-control-panel-secondary-actions.entry.js.map +1 -0
  326. package/dist/esm/db-custom-select-dropdown.db-custom-select-list.db-custom-select-list-item.db-input.db-tag.entry.js.map +1 -1
  327. package/dist/esm/db-custom-select-dropdown_5.entry.js +13 -13
  328. package/dist/esm/db-custom-select-dropdown_5.entry.js.map +1 -1
  329. package/dist/esm/db-custom-select-form-field.entry.js +3 -3
  330. package/dist/esm/db-custom-select.entry.js +15 -15
  331. package/dist/esm/db-custom-select.entry.js.map +1 -1
  332. package/dist/esm/db-divider.entry.js +2 -2
  333. package/dist/esm/db-drawer.entry.js +6 -6
  334. package/dist/esm/db-drawer.entry.js.map +1 -1
  335. package/dist/esm/db-icon.entry.js +2 -2
  336. package/dist/esm/db-infotext.entry.js +2 -2
  337. package/dist/esm/db-link.entry.js +2 -2
  338. package/dist/esm/db-navigation-item-group.entry.js +157 -0
  339. package/dist/esm/db-navigation-item-group.entry.js.map +1 -0
  340. package/dist/esm/db-navigation-item.entry.js +5 -73
  341. package/dist/esm/db-navigation-item.entry.js.map +1 -1
  342. package/dist/esm/db-navigation.entry.js +113 -7
  343. package/dist/esm/db-navigation.entry.js.map +1 -1
  344. package/dist/esm/db-notification.entry.js +4 -4
  345. package/dist/esm/db-popover.entry.js +5 -6
  346. package/dist/esm/db-popover.entry.js.map +1 -1
  347. package/dist/esm/db-radio.entry.js +2 -2
  348. package/dist/esm/db-section.entry.js +4 -4
  349. package/dist/esm/db-select.entry.js +7 -7
  350. package/dist/esm/db-select.entry.js.map +1 -1
  351. package/dist/esm/db-shell-sub-navigation.entry.js +69 -0
  352. package/dist/esm/db-shell-sub-navigation.entry.js.map +1 -0
  353. package/dist/esm/{db-page.entry.js → db-shell.entry.js} +9 -15
  354. package/dist/esm/db-shell.entry.js.map +1 -0
  355. package/dist/esm/db-stack.entry.js +3 -3
  356. package/dist/esm/db-switch.entry.js +2 -2
  357. package/dist/esm/db-tab-item_3.entry.js +8 -8
  358. package/dist/esm/db-tabs.entry.js +5 -5
  359. package/dist/esm/db-tabs.entry.js.map +1 -1
  360. package/dist/esm/db-textarea.entry.js +6 -6
  361. package/dist/esm/db-textarea.entry.js.map +1 -1
  362. package/dist/esm/db-tooltip.entry.js +7 -8
  363. package/dist/esm/db-tooltip.entry.js.map +1 -1
  364. package/dist/esm/db-ux.js +4 -4
  365. package/dist/esm/db-ux.js.map +1 -1
  366. package/dist/esm/{floating-components-G-TursYV.js → floating-components-D3kmGlOI.js} +78 -50
  367. package/dist/esm/floating-components-D3kmGlOI.js.map +1 -0
  368. package/dist/esm/{index-CNzNv7KB.js → index-uOzX56mL.js} +9 -3
  369. package/dist/esm/index-uOzX56mL.js.map +1 -0
  370. package/dist/esm/index.js +12 -8
  371. package/dist/esm/index.js.map +1 -1
  372. package/dist/esm/loader.js +3 -3
  373. package/dist/esm/{navigation--UdC9CzO.js → navigation-CJ-OxodG.js} +38 -22
  374. package/dist/esm/navigation-CJ-OxodG.js.map +1 -0
  375. package/dist/types/components/control-panel-brand/control-panel-brand.d.ts +21 -0
  376. package/dist/types/components/control-panel-brand/index.d.ts +2 -0
  377. package/dist/types/components/control-panel-brand/model.d.ts +5 -0
  378. package/dist/types/components/control-panel-desktop/control-panel-desktop.d.ts +33 -0
  379. package/dist/types/components/control-panel-desktop/index.d.ts +2 -0
  380. package/dist/types/components/control-panel-desktop/model.d.ts +7 -0
  381. package/dist/types/components/control-panel-flat-icon-navigation/control-panel-flat-icon-navigation.d.ts +22 -0
  382. package/dist/types/components/control-panel-flat-icon-navigation/index.d.ts +2 -0
  383. package/dist/types/components/control-panel-flat-icon-navigation/model.d.ts +7 -0
  384. package/dist/types/components/{brand/brand.d.ts → control-panel-meta-navigation/control-panel-meta-navigation.d.ts} +4 -8
  385. package/dist/types/components/control-panel-meta-navigation/index.d.ts +2 -0
  386. package/dist/types/components/control-panel-meta-navigation/model.d.ts +5 -0
  387. package/dist/types/components/control-panel-mobile/control-panel-mobile.d.ts +32 -0
  388. package/dist/types/components/control-panel-mobile/index.d.ts +2 -0
  389. package/dist/types/components/control-panel-mobile/model.d.ts +30 -0
  390. package/dist/types/components/control-panel-primary-actions/control-panel-primary-actions.d.ts +18 -0
  391. package/dist/types/components/control-panel-primary-actions/index.d.ts +2 -0
  392. package/dist/types/components/control-panel-primary-actions/model.d.ts +5 -0
  393. package/dist/types/components/control-panel-secondary-actions/control-panel-secondary-actions.d.ts +18 -0
  394. package/dist/types/components/control-panel-secondary-actions/index.d.ts +2 -0
  395. package/dist/types/components/control-panel-secondary-actions/model.d.ts +5 -0
  396. package/dist/types/components/custom-select/custom-select.d.ts +1 -1
  397. package/dist/types/components/custom-select/model.d.ts +4 -1
  398. package/dist/types/components/drawer/drawer.d.ts +1 -0
  399. package/dist/types/components/drawer/model.d.ts +5 -1
  400. package/dist/types/components/navigation/model.d.ts +14 -5
  401. package/dist/types/components/navigation/navigation.d.ts +19 -1
  402. package/dist/types/components/navigation-item/model.d.ts +9 -24
  403. package/dist/types/components/navigation-item/navigation-item.d.ts +2 -24
  404. package/dist/types/components/navigation-item-group/index.d.ts +2 -0
  405. package/dist/types/components/navigation-item-group/model.d.ts +26 -0
  406. package/dist/types/components/navigation-item-group/navigation-item-group.d.ts +50 -0
  407. package/dist/types/components/popover/popover.d.ts +1 -1
  408. package/dist/types/components/shell/index.d.ts +2 -0
  409. package/dist/types/components/shell/model.d.ts +50 -0
  410. package/dist/types/components/shell/shell.d.ts +28 -0
  411. package/dist/types/components/shell-sub-navigation/index.d.ts +2 -0
  412. package/dist/types/components/shell-sub-navigation/model.d.ts +5 -0
  413. package/dist/types/components/shell-sub-navigation/shell-sub-navigation.d.ts +24 -0
  414. package/dist/types/components/tabs/model.d.ts +3 -11
  415. package/dist/types/components/tooltip/tooltip.d.ts +1 -1
  416. package/dist/types/components.d.ts +302 -119
  417. package/dist/types/index.d.ts +19 -6
  418. package/dist/types/shared/constants.d.ts +3 -0
  419. package/dist/types/shared/model.d.ts +82 -3
  420. package/dist/types/utils/floating-components.d.ts +17 -1
  421. package/dist/types/utils/navigation.d.ts +2 -6
  422. package/dist/vscode.html-custom-data.json +532 -327
  423. package/dist/web-types.json +1235 -795
  424. package/package.json +5 -7
  425. package/agent/Accordion.md +0 -23
  426. package/agent/AccordionItem.md +0 -29
  427. package/agent/Badge.md +0 -32
  428. package/agent/Brand.md +0 -13
  429. package/agent/Button.md +0 -47
  430. package/agent/Card.md +0 -23
  431. package/agent/Checkbox.md +0 -41
  432. package/agent/CustomSelect.md +0 -54
  433. package/agent/Divider.md +0 -21
  434. package/agent/Drawer.md +0 -71
  435. package/agent/Header.md +0 -29
  436. package/agent/Icon.md +0 -20
  437. package/agent/Infotext.md +0 -25
  438. package/agent/Input.md +0 -48
  439. package/agent/Link.md +0 -52
  440. package/agent/Navigation.md +0 -19
  441. package/agent/NavigationItem.md +0 -29
  442. package/agent/Notification.md +0 -38
  443. package/agent/Page.md +0 -27
  444. package/agent/Popover.md +0 -52
  445. package/agent/Radio.md +0 -28
  446. package/agent/Section.md +0 -21
  447. package/agent/Select.md +0 -62
  448. package/agent/Stack.md +0 -35
  449. package/agent/Switch.md +0 -44
  450. package/agent/TabItem.md +0 -25
  451. package/agent/Tabs.md +0 -61
  452. package/agent/Tag.md +0 -41
  453. package/agent/Textarea.md +0 -44
  454. package/agent/Tooltip.md +0 -37
  455. package/agent/_instructions.md +0 -31
  456. package/dist/cjs/constants-CTtyzyuo.js.map +0 -1
  457. package/dist/cjs/db-brand.cjs.entry.js.map +0 -1
  458. package/dist/cjs/db-brand.entry.cjs.js.map +0 -1
  459. package/dist/cjs/db-header.cjs.entry.js +0 -96
  460. package/dist/cjs/db-header.cjs.entry.js.map +0 -1
  461. package/dist/cjs/db-header.entry.cjs.js.map +0 -1
  462. package/dist/cjs/db-page.cjs.entry.js.map +0 -1
  463. package/dist/cjs/db-page.entry.cjs.js.map +0 -1
  464. package/dist/cjs/floating-components-ogUqz72V.js.map +0 -1
  465. package/dist/cjs/index-9urL1KCD.js.map +0 -1
  466. package/dist/cjs/navigation-DauGE-qj.js.map +0 -1
  467. package/dist/collection/components/brand/brand.js.map +0 -1
  468. package/dist/collection/components/brand/index.js +0 -3
  469. package/dist/collection/components/brand/index.js.map +0 -1
  470. package/dist/collection/components/brand/model.js.map +0 -1
  471. package/dist/collection/components/header/header.js.map +0 -1
  472. package/dist/collection/components/header/index.js +0 -3
  473. package/dist/collection/components/header/index.js.map +0 -1
  474. package/dist/collection/components/header/model.js.map +0 -1
  475. package/dist/collection/components/page/index.js +0 -3
  476. package/dist/collection/components/page/index.js.map +0 -1
  477. package/dist/collection/components/page/model.js +0 -3
  478. package/dist/collection/components/page/model.js.map +0 -1
  479. package/dist/collection/components/page/page.js.map +0 -1
  480. package/dist/db-ux/db-brand.entry.esm.js.map +0 -1
  481. package/dist/db-ux/db-header.entry.esm.js.map +0 -1
  482. package/dist/db-ux/db-page.entry.esm.js.map +0 -1
  483. package/dist/db-ux/p-340bb722.entry.js +0 -2
  484. package/dist/db-ux/p-340bb722.entry.js.map +0 -1
  485. package/dist/db-ux/p-3d7eb768.entry.js +0 -2
  486. package/dist/db-ux/p-3d7eb768.entry.js.map +0 -1
  487. package/dist/db-ux/p-51de401e.entry.js +0 -2
  488. package/dist/db-ux/p-58007675.entry.js +0 -2
  489. package/dist/db-ux/p-58007675.entry.js.map +0 -1
  490. package/dist/db-ux/p-5b45664d.entry.js +0 -2
  491. package/dist/db-ux/p-5c6da0f3.entry.js +0 -2
  492. package/dist/db-ux/p-6e35a260.entry.js +0 -2
  493. package/dist/db-ux/p-6e35a260.entry.js.map +0 -1
  494. package/dist/db-ux/p-72330d25.entry.js +0 -2
  495. package/dist/db-ux/p-72330d25.entry.js.map +0 -1
  496. package/dist/db-ux/p-84dd974f.entry.js +0 -2
  497. package/dist/db-ux/p-84dd974f.entry.js.map +0 -1
  498. package/dist/db-ux/p-8b41c30e.entry.js +0 -2
  499. package/dist/db-ux/p-8b41c30e.entry.js.map +0 -1
  500. package/dist/db-ux/p-971a16c3.entry.js +0 -2
  501. package/dist/db-ux/p-971a16c3.entry.js.map +0 -1
  502. package/dist/db-ux/p-9d0996e9.entry.js +0 -2
  503. package/dist/db-ux/p-CNzNv7KB.js +0 -3
  504. package/dist/db-ux/p-CNzNv7KB.js.map +0 -1
  505. package/dist/db-ux/p-DC9V_oNU.js +0 -2
  506. package/dist/db-ux/p-DC9V_oNU.js.map +0 -1
  507. package/dist/db-ux/p-G-TursYV.js +0 -2
  508. package/dist/db-ux/p-G-TursYV.js.map +0 -1
  509. package/dist/db-ux/p-a3541c03.entry.js +0 -2
  510. package/dist/db-ux/p-a3541c03.entry.js.map +0 -1
  511. package/dist/db-ux/p-c8bdd952.entry.js +0 -2
  512. package/dist/db-ux/p-c8cdde8c.entry.js +0 -2
  513. package/dist/db-ux/p-ce895e0c.entry.js +0 -2
  514. package/dist/db-ux/p-ce895e0c.entry.js.map +0 -1
  515. package/dist/db-ux/p-d4e3d1db.entry.js +0 -2
  516. package/dist/db-ux/p-d4e3d1db.entry.js.map +0 -1
  517. package/dist/db-ux/p-d6aeabf0.entry.js +0 -2
  518. package/dist/db-ux/p-e9c323af.entry.js +0 -2
  519. package/dist/db-ux/p-e9c323af.entry.js.map +0 -1
  520. package/dist/db-ux/p-ec957247.entry.js +0 -2
  521. package/dist/db-ux/p-ec957247.entry.js.map +0 -1
  522. package/dist/db-ux/p-fdf5578d.entry.js +0 -2
  523. package/dist/db-ux/p-fdf5578d.entry.js.map +0 -1
  524. package/dist/db-ux/p-sP2NlPcu.js +0 -2
  525. package/dist/db-ux/p-sP2NlPcu.js.map +0 -1
  526. package/dist/esm/constants-DC9V_oNU.js.map +0 -1
  527. package/dist/esm/db-brand.entry.js.map +0 -1
  528. package/dist/esm/db-header.entry.js +0 -94
  529. package/dist/esm/db-header.entry.js.map +0 -1
  530. package/dist/esm/db-page.entry.js.map +0 -1
  531. package/dist/esm/floating-components-G-TursYV.js.map +0 -1
  532. package/dist/esm/index-CNzNv7KB.js.map +0 -1
  533. package/dist/esm/navigation--UdC9CzO.js.map +0 -1
  534. package/dist/types/components/brand/index.d.ts +0 -2
  535. package/dist/types/components/brand/model.d.ts +0 -10
  536. package/dist/types/components/header/header.d.ts +0 -33
  537. package/dist/types/components/header/index.d.ts +0 -2
  538. package/dist/types/components/header/model.d.ts +0 -44
  539. package/dist/types/components/page/index.d.ts +0 -2
  540. package/dist/types/components/page/model.d.ts +0 -36
  541. package/dist/types/components/page/page.d.ts +0 -25
  542. /package/dist/collection/components/{brand → control-panel-brand}/model.js +0 -0
  543. /package/dist/collection/components/{header → control-panel-desktop}/model.js +0 -0
  544. /package/dist/db-ux/{p-5c6da0f3.entry.js.map → p-1dccdff4.entry.js.map} +0 -0
  545. /package/dist/db-ux/{p-c8bdd952.entry.js.map → p-4645cc92.entry.js.map} +0 -0
  546. /package/dist/db-ux/{p-c5ff3d3f.entry.js.map → p-504a9cfc.entry.js.map} +0 -0
  547. /package/dist/db-ux/{p-e6e7719e.entry.js.map → p-53682d25.entry.js.map} +0 -0
  548. /package/dist/db-ux/{p-51de401e.entry.js.map → p-5be272f0.entry.js.map} +0 -0
  549. /package/dist/db-ux/{p-16f1fa7c.entry.js.map → p-5d292f94.entry.js.map} +0 -0
  550. /package/dist/db-ux/{p-02fcd4a8.entry.js.map → p-5e4ac324.entry.js.map} +0 -0
  551. /package/dist/db-ux/{p-f03f7076.entry.js.map → p-6fd148ce.entry.js.map} +0 -0
  552. /package/dist/db-ux/{p-5b45664d.entry.js.map → p-7153636c.entry.js.map} +0 -0
  553. /package/dist/db-ux/{p-9d0996e9.entry.js.map → p-73614370.entry.js.map} +0 -0
  554. /package/dist/db-ux/{p-209cf793.entry.js.map → p-81d7921b.entry.js.map} +0 -0
  555. /package/dist/db-ux/{p-d7168627.entry.js.map → p-8262ab69.entry.js.map} +0 -0
  556. /package/dist/db-ux/{p-c8cdde8c.entry.js.map → p-99d090b7.entry.js.map} +0 -0
  557. /package/dist/db-ux/{p-bd7d1646.entry.js.map → p-b713791b.entry.js.map} +0 -0
  558. /package/dist/db-ux/{p-a2b55626.entry.js.map → p-d6047812.entry.js.map} +0 -0
@@ -0,0 +1,157 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-uOzX56mL.js';
2
+ import { n as DEFAULT_BACK } from './constants-Dst8dqRS.js';
3
+ import { u as uuid, d as delay, b as getBoolean, g as getBooleanAsString, j as getHideProp, c as cls } from './index-YECpAE3G.js';
4
+ import { h as handleSubNavigationPosition, N as NavigationItemSafeTriangle } from './navigation-CJ-OxodG.js';
5
+ import './floating-components-D3kmGlOI.js';
6
+
7
+ const DBNavigationItemGroup = class {
8
+ constructor(hostRef) {
9
+ registerInstance(this, hostRef);
10
+ this.click = createEvent(this, "click");
11
+ this.hasSubNavigation = true;
12
+ this.isSubNavigationExpanded = false;
13
+ this.autoClose = false;
14
+ this.hasPopup = false;
15
+ this.initialized = false;
16
+ this.subNavigationId = "db-navigation-item-group-menu-" + uuid();
17
+ this.navigationItemSafeTriangle = undefined;
18
+ }
19
+ onScroll() {
20
+ if (this.hasPopup) {
21
+ handleSubNavigationPosition(this._ref);
22
+ }
23
+ }
24
+ handleNavigationItemClick(event) {
25
+ var _a;
26
+ if (((_a = event === null || event === void 0 ? void 0 : event.target) === null || _a === void 0 ? void 0 : _a.nodeName) === "A") {
27
+ this.forceClose();
28
+ }
29
+ }
30
+ forceClose() {
31
+ this.autoClose = true;
32
+ void delay(() => {
33
+ this.autoClose = false;
34
+ }, 300);
35
+ }
36
+ handleClick(event) {
37
+ if (this.click) {
38
+ event.stopPropagation();
39
+ this.click.emit(event);
40
+ }
41
+ this.isSubNavigationExpanded = !this.isSubNavigationExpanded;
42
+ }
43
+ handleBackClick(event) {
44
+ event.stopPropagation();
45
+ this.isSubNavigationExpanded = false;
46
+ }
47
+ handleEscape(event) {
48
+ if (!event || event.key === "Escape") {
49
+ this.forceClose();
50
+ this._buttonRef.blur();
51
+ }
52
+ }
53
+ /**
54
+ * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
55
+ * @param element the ref for the component
56
+ * @param customElementSelector the custom element like `my-component`
57
+ */
58
+ enableAttributePassing(element, customElementSelector) {
59
+ const parent = element === null || element === void 0 ? void 0 : element.closest(customElementSelector);
60
+ if (element && parent) {
61
+ const attributes = parent.attributes;
62
+ for (let i = 0; i < attributes.length; i++) {
63
+ const attr = attributes.item(i);
64
+ if (attr &&
65
+ (attr.name.startsWith("data-") || attr.name.startsWith("aria-"))) {
66
+ element.setAttribute(attr.name, attr.value);
67
+ parent.removeAttribute(attr.name);
68
+ }
69
+ if (attr && attr.name === "class") {
70
+ const isWebComponent = attr.value.includes("hydrated");
71
+ const value = attr.value.replace("hydrated", "").trim();
72
+ const currentClass = element.getAttribute("class");
73
+ element.setAttribute(attr.name, `${currentClass ? `${currentClass} ` : ""}${value}`);
74
+ if (isWebComponent) {
75
+ // Stencil is using this class for lazy loading component
76
+ parent.setAttribute("class", "hydrated");
77
+ }
78
+ else {
79
+ parent.removeAttribute(attr.name);
80
+ }
81
+ }
82
+ }
83
+ }
84
+ }
85
+ watch0Fn() {
86
+ if (this.expanded !== undefined) {
87
+ this.isSubNavigationExpanded = !!getBoolean(this.expanded, "subNavigationExpanded");
88
+ }
89
+ }
90
+ watch0() {
91
+ this.watch0Fn();
92
+ }
93
+ watch1Fn() {
94
+ if (this._ref && this.initialized) {
95
+ this.initialized = false;
96
+ // We delay this because the navigation variant check is delayed as well
97
+ void delay(() => {
98
+ const element = this._ref;
99
+ const nav = element.closest(".db-navigation");
100
+ this.hasPopup =
101
+ !nav ||
102
+ !nav.dataset["variant"] ||
103
+ nav.dataset["variant"] === "popover";
104
+ }, 200);
105
+ }
106
+ }
107
+ watch1() {
108
+ this.watch1Fn();
109
+ }
110
+ watch2Fn() {
111
+ if (this._ref &&
112
+ this._buttonRef &&
113
+ this._menuRef &&
114
+ this.hasPopup &&
115
+ !this.navigationItemSafeTriangle) {
116
+ void delay(() => {
117
+ this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(this._ref, this._menuRef);
118
+ }, 1);
119
+ ["mouseenter", "focusin"].forEach((event) => {
120
+ this._ref.addEventListener(event, () => handleSubNavigationPosition(this._menuRef));
121
+ });
122
+ }
123
+ }
124
+ watch2() {
125
+ this.watch2Fn();
126
+ }
127
+ componentDidLoad() {
128
+ this.enableAttributePassing(this._ref, "db-navigation-item-group");
129
+ this.initialized = true;
130
+ this.watch0Fn();
131
+ this.watch1Fn();
132
+ this.watch2Fn();
133
+ }
134
+ render() {
135
+ var _a;
136
+ return (h("li", { key: '0feb40fc1eb885450f2f61aab591b3d05aa2eb0d', class: cls("db-navigation-item-group", this.className), ref: (el) => {
137
+ this._ref = el;
138
+ }, id: this.id, onMouseOver: () => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.enableFollow(); }, onMouseLeave: () => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.disableFollow(); }, onMouseMove: (event) => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.followByMouseEvent(event); }, onKeyDown: (event) => this.handleEscape(event), "data-icon": this.icon, "data-hide-icon": getHideProp(this.showIcon), "data-active": this.active, "aria-disabled": getBooleanAsString(this.disabled) }, h("button", { key: '5bd2b1dcfb1a30e4ffce5ec597a8caef7c7b2a1f', class: "db-navigation-item-group-expand-button", type: "button", ref: (el) => {
139
+ this._buttonRef = el;
140
+ }, "aria-haspopup": getBooleanAsString(this.hasPopup ? true : undefined), "aria-owns": this.hasPopup ? undefined : this.subNavigationId, "aria-expanded": getBooleanAsString(this.isSubNavigationExpanded), disabled: getBoolean(this.disabled, "disabled"), onClick: (event) => this.handleClick(event) }, this.text, h("slot", { key: '0af1cd7b5f6734de52b5abcf7af50f3052e1b242', name: "additionalInformation" })), h("menu", { key: '54c731d61026b1d0897e46da7e9820e971720a4f', class: "db-navigation-item-group-menu", role: "group", ref: (el) => {
141
+ this._menuRef = el;
142
+ }, "data-force-close": getBooleanAsString(this.autoClose), id: this.subNavigationId, onScroll: () => this.onScroll(), onClick: (event) => this.handleNavigationItemClick(event) }, h("div", { key: 'c20e8df3f651f7aeaeb2f61a2e1feba3f511dbcc', class: "db-navigation-item-group-back-button" }, h("db-button", { key: 'fe353a18a5f38c52e1d03d5ed5f3b239dabd25ad', icon: "arrow_left", variant: "ghost", id: this.backButtonId, onClick: (event) => this.handleBackClick(event) }, (_a = this.backButtonText) !== null && _a !== void 0 ? _a : DEFAULT_BACK)), h("slot", { key: 'd06eb8d06cf68f06dbad2443c664b6ddfb5e533b' }))));
143
+ }
144
+ static get watchers() { return {
145
+ "expanded": ["watch0"],
146
+ "_ref": ["watch1", "watch2"],
147
+ "initialized": ["watch1"],
148
+ "_menuRef": ["watch2"],
149
+ "_buttonRef": ["watch2"],
150
+ "hasPopup": ["watch2"]
151
+ }; }
152
+ };
153
+
154
+ export { DBNavigationItemGroup as db_navigation_item_group };
155
+ //# sourceMappingURL=db-navigation-item-group.entry.js.map
156
+
157
+ //# sourceMappingURL=db-navigation-item-group.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db-navigation-item-group.entry.js","sources":["src/components/navigation-item-group/navigation-item-group.tsx"],"sourcesContent":["import { DEFAULT_BACK } from \"../../shared/constants\";\nimport { ClickEvent } from \"../../shared/model\";\nimport {\n cls,\n delay,\n getBoolean,\n getBooleanAsString,\n getHideProp,\n uuid,\n} from \"../../utils\";\nimport {\n handleSubNavigationPosition,\n NavigationItemSafeTriangle,\n} from \"../../utils/navigation\";\nimport { DBButton } from \"../button/button\";\nimport {\n DBNavigationItemGroupProps,\n DBNavigationItemGroupState,\n} from \"./model\";\n\nimport {\n Component,\n h,\n Fragment,\n Watch,\n Event,\n EventEmitter,\n Prop,\n State,\n} from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n * @slot additionalInformation - TODO: Add description for slotAdditionalInformation\n */\n @Component({\n tag: \"db-navigation-item-group\",\n})\nexport class DBNavigationItemGroup {\n private _ref!: HTMLLIElement | any;\n private _menuRef!: HTMLElement | any;\n private _buttonRef!: HTMLButtonElement | any;\n @Prop() expanded: DBNavigationItemGroupProps[\"expanded\"];\n @Event() click: EventEmitter<\n Parameters<Required<DBNavigationItemGroupProps>[\"onClick\"]>[number]\n > | void;\n @Prop() id: DBNavigationItemGroupProps[\"id\"];\n @Prop({attribute: \"classname\"}) className: DBNavigationItemGroupProps[\"className\"];\n @Prop() icon: DBNavigationItemGroupProps[\"icon\"];\n @Prop() showIcon: DBNavigationItemGroupProps[\"showIcon\"];\n @Prop() active: DBNavigationItemGroupProps[\"active\"];\n @Prop() disabled: DBNavigationItemGroupProps[\"disabled\"];\n @Prop() text: DBNavigationItemGroupProps[\"text\"];\n @Prop() backButtonId: DBNavigationItemGroupProps[\"backButtonId\"];\n @Prop() backButtonText: DBNavigationItemGroupProps[\"backButtonText\"];\n @State() hasSubNavigation = true;\n @State() isSubNavigationExpanded = false;\n @State() autoClose = false;\n @State() hasPopup = false;\n @State() initialized = false;\n @State() subNavigationId = \"db-navigation-item-group-menu-\" + uuid();\n @State() navigationItemSafeTriangle = undefined;\n\n onScroll() {\n if (this.hasPopup) {\n handleSubNavigationPosition(this._ref);\n }\n }\n handleNavigationItemClick(event: any) {\n if (event?.target?.nodeName === \"A\") {\n this.forceClose();\n }\n }\n forceClose() {\n this.autoClose = true;\n void delay(() => {\n this.autoClose = false;\n }, 300);\n }\n handleClick(event: ClickEvent<HTMLButtonElement> | any) {\n if (this.click) {\n event.stopPropagation();\n this.click.emit(event);\n }\n this.isSubNavigationExpanded = !this.isSubNavigationExpanded;\n }\n handleBackClick(event: ClickEvent<HTMLButtonElement> | any) {\n event.stopPropagation();\n this.isSubNavigationExpanded = false;\n }\n handleEscape(event: any) {\n if (!event || event.key === \"Escape\") {\n this.forceClose();\n this._buttonRef.blur();\n }\n }\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n watch0Fn() {\n if (this.expanded !== undefined) {\n this.isSubNavigationExpanded = !!getBoolean(\n this.expanded,\n \"subNavigationExpanded\"\n );\n }\n }\n\n @Watch(\"expanded\")\n watch0() {\n this.watch0Fn();\n }\n\n watch1Fn() {\n if (this._ref && this.initialized) {\n this.initialized = false;\n // We delay this because the navigation variant check is delayed as well\n void delay(() => {\n const element = this._ref as HTMLLIElement;\n const nav = element.closest<HTMLElement>(\".db-navigation\");\n this.hasPopup =\n !nav ||\n !nav.dataset[\"variant\"] ||\n nav.dataset[\"variant\"] === \"popover\";\n }, 200);\n }\n }\n\n @Watch(\"_ref\")\n @Watch(\"initialized\")\n watch1() {\n this.watch1Fn();\n }\n\n watch2Fn() {\n if (\n this._ref &&\n this._buttonRef &&\n this._menuRef &&\n this.hasPopup &&\n !this.navigationItemSafeTriangle\n ) {\n void delay(() => {\n this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(\n this._ref,\n this._menuRef\n );\n }, 1);\n [\"mouseenter\", \"focusin\"].forEach((event) => {\n this._ref.addEventListener(event, () =>\n handleSubNavigationPosition(this._menuRef)\n );\n });\n }\n }\n\n @Watch(\"_ref\")\n @Watch(\"_menuRef\")\n @Watch(\"_buttonRef\")\n @Watch(\"hasPopup\")\n watch2() {\n this.watch2Fn();\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-navigation-item-group\");\n this.initialized = true;\n this.watch0Fn();\n this.watch1Fn();\n this.watch2Fn();\n }\n\n render() {\n return (\n <li\n class={cls(\"db-navigation-item-group\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this.id}\n onMouseOver={() => this.navigationItemSafeTriangle?.enableFollow()}\n onMouseLeave={() => this.navigationItemSafeTriangle?.disableFollow()}\n onMouseMove={(event) =>\n this.navigationItemSafeTriangle?.followByMouseEvent(event)\n }\n onKeyDown={(event) => this.handleEscape(event)}\n data-icon={this.icon}\n data-hide-icon={getHideProp(this.showIcon)}\n data-active={this.active}\n aria-disabled={getBooleanAsString(this.disabled)}\n >\n <button\n class=\"db-navigation-item-group-expand-button\"\n type=\"button\"\n ref={(el: any) => {\n this._buttonRef = el;\n }}\n aria-haspopup={getBooleanAsString(this.hasPopup ? true : undefined)}\n aria-owns={this.hasPopup ? undefined : this.subNavigationId}\n aria-expanded={getBooleanAsString(this.isSubNavigationExpanded)}\n disabled={getBoolean(this.disabled, \"disabled\")}\n onClick={(event) => this.handleClick(event)}\n >\n {this.text}\n <slot name=\"additionalInformation\"></slot>\n </button>\n <menu\n class=\"db-navigation-item-group-menu\"\n role=\"group\"\n ref={(el: any) => {\n this._menuRef = el;\n }}\n data-force-close={getBooleanAsString(this.autoClose)}\n id={this.subNavigationId}\n onScroll={() => this.onScroll()}\n onClick={(event) => this.handleNavigationItemClick(event)}\n >\n <div class=\"db-navigation-item-group-back-button\">\n <db-button\n icon=\"arrow_left\"\n variant=\"ghost\"\n id={this.backButtonId}\n onClick={(event) => this.handleBackClick(event)}\n >\n {this.backButtonText ?? DEFAULT_BACK}\n </db-button>\n </div>\n <slot></slot>\n </menu>\n </li>\n );\n }\n}\n"],"names":[],"mappings":"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"}
@@ -1,42 +1,10 @@
1
- import { r as registerInstance, c as createEvent, h, F as Fragment } from './index-CNzNv7KB.js';
2
- import { n as DEFAULT_BACK } from './constants-DC9V_oNU.js';
3
- import { u as uuid, d as delay, b as getBoolean, g as getBooleanAsString, c as cls } from './index-YECpAE3G.js';
4
- import { N as NavigationItemSafeTriangle } from './navigation--UdC9CzO.js';
5
- import './floating-components-G-TursYV.js';
1
+ import { r as registerInstance, h } from './index-uOzX56mL.js';
2
+ import { a as DEFAULT_LABEL } from './constants-Dst8dqRS.js';
3
+ import { g as getBooleanAsString, c as cls } from './index-YECpAE3G.js';
6
4
 
7
5
  const DBNavigationItem = class {
8
6
  constructor(hostRef) {
9
7
  registerInstance(this, hostRef);
10
- this.click = createEvent(this, "click");
11
- this.initialized = false;
12
- this.hasAreaPopup = false;
13
- this.hasSubNavigation = true;
14
- this.isSubNavigationExpanded = false;
15
- this.autoClose = false;
16
- this.subNavigationId = "sub-navigation-" + uuid();
17
- this.navigationItemSafeTriangle = undefined;
18
- }
19
- handleNavigationItemClick(event) {
20
- var _a;
21
- if (((_a = event === null || event === void 0 ? void 0 : event.target) === null || _a === void 0 ? void 0 : _a.nodeName) === "A") {
22
- this.autoClose = true;
23
- void delay(() => {
24
- this.autoClose = false;
25
- }, 1000);
26
- }
27
- }
28
- handleClick(event) {
29
- if (this.click) {
30
- event.stopPropagation();
31
- this.click.emit(event);
32
- }
33
- if (this.hasAreaPopup) {
34
- this.isSubNavigationExpanded = true;
35
- }
36
- }
37
- handleBackClick(event) {
38
- event.stopPropagation();
39
- this.isSubNavigationExpanded = false;
40
8
  }
41
9
  /**
42
10
  * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
@@ -70,51 +38,15 @@ const DBNavigationItem = class {
70
38
  }
71
39
  }
72
40
  }
73
- watch0Fn() {
74
- if (this.subNavigationExpanded !== undefined) {
75
- this.isSubNavigationExpanded = !!getBoolean(this.subNavigationExpanded, "subNavigationExpanded");
76
- }
77
- }
78
- watch0() {
79
- this.watch0Fn();
80
- }
81
- watch1Fn() {
82
- var _a;
83
- if (this.initialized && this._ref) {
84
- const subNavigationSlot = this._ref.querySelector("menu");
85
- if (subNavigationSlot) {
86
- if (((_a = subNavigationSlot.children) === null || _a === void 0 ? void 0 : _a.length) > 0) {
87
- this.hasAreaPopup = true;
88
- if (!this.navigationItemSafeTriangle) {
89
- this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(this._ref, subNavigationSlot);
90
- }
91
- }
92
- else {
93
- this.hasSubNavigation = false;
94
- }
95
- }
96
- }
97
- }
98
- watch1() {
99
- this.watch1Fn();
100
- }
101
41
  componentDidLoad() {
102
42
  this.enableAttributePassing(this._ref, "db-navigation-item");
103
- this.initialized = true;
104
- this.watch0Fn();
105
- this.watch1Fn();
106
43
  }
107
44
  render() {
108
45
  var _a;
109
- return (h("li", { key: 'd00b7b4852a729301d545abaf1a65cd3e0cdcee7', class: cls("db-navigation-item", this.className), ref: (el) => {
46
+ return (h("li", { key: 'ddd7b3cf6316c49bb356d25d7315fe5ed3998df5', class: cls("db-navigation-item", this.className), ref: (el) => {
110
47
  this._ref = el;
111
- }, id: this.id, onMouseOver: () => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.enableFollow(); }, onMouseLeave: () => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.disableFollow(); }, onMouseMove: (event) => { var _a; return (_a = this.navigationItemSafeTriangle) === null || _a === void 0 ? void 0 : _a.followByMouseEvent(event); }, "data-width": this.width, "data-icon": this.icon, "data-show-icon": getBooleanAsString(this.showIcon), "data-active": this.active, "data-wrap": getBooleanAsString(this.wrap), "aria-disabled": getBooleanAsString(this.disabled) }, !this.hasSubNavigation ? this.text ? this.text : h("slot", null) : null, this.hasSubNavigation ? (h(Fragment, null, h("button", { class: "db-navigation-item-expand-button", "aria-haspopup": this.hasAreaPopup, "aria-expanded": this.isSubNavigationExpanded, disabled: getBoolean(this.disabled, "disabled"), onClick: (event) => this.handleClick(event) }, this.text ? this.text : h("slot", null)), h("menu", { class: "db-sub-navigation", "data-force-close": this.autoClose, id: this.subNavigationId, onClick: (event) => this.handleNavigationItemClick(event) }, this.hasAreaPopup ? (h("div", { class: "db-mobile-navigation-back" }, h("db-button", { icon: "arrow_left", variant: "ghost", id: this.backButtonId, onClick: (event) => this.handleBackClick(event) }, (_a = this.backButtonText) !== null && _a !== void 0 ? _a : DEFAULT_BACK))) : null, h("slot", { name: "subNavigation" })))) : null));
48
+ }, id: this.id, "data-icon": this.icon, "data-show-icon": getBooleanAsString(this.showIcon), "data-active": getBooleanAsString(this.active), "aria-disabled": getBooleanAsString(this.disabled) }, h("slot", { key: 'baf789cb7779341537252a5d62270a313ae9f359' }), h("slot", { key: 'b725066ff8f5364ef240cd88a129c4689bbe832d', name: "additionalInformation" }), h("db-tooltip", { key: 'f651a7c03ce89a69de73a26deea5780fd0d7a6b1', placement: "right", delay: "slow" }, (_a = this.tooltip) !== null && _a !== void 0 ? _a : DEFAULT_LABEL)));
112
49
  }
113
- static get watchers() { return {
114
- "subNavigationExpanded": ["watch0"],
115
- "initialized": ["watch1"],
116
- "_ref": ["watch1"]
117
- }; }
118
50
  };
119
51
 
120
52
  export { DBNavigationItem as db_navigation_item };
@@ -1 +1 @@
1
- {"version":3,"file":"db-navigation-item.entry.js","sources":["src/components/navigation-item/navigation-item.tsx"],"sourcesContent":["import { DEFAULT_BACK } from \"../../shared/constants\";\nimport { ClickEvent } from \"../../shared/model\";\nimport { cls, delay, getBoolean, getBooleanAsString, uuid } from \"../../utils\";\nimport { NavigationItemSafeTriangle } from \"../../utils/navigation\";\nimport { DBButton } from \"../button/button\";\nimport { DBNavigationItemProps, DBNavigationItemState } from \"./model\";\n\nimport {\n Component,\n h,\n Fragment,\n Watch,\n Event,\n EventEmitter,\n Prop,\n State,\n} from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n * @slot subNavigation - TODO: Add description for slotSubNavigation\n */\n @Component({\n tag: \"db-navigation-item\",\n})\nexport class DBNavigationItem {\n private _ref!: HTMLLIElement | any;\n @Prop() subNavigationExpanded: DBNavigationItemProps[\"subNavigationExpanded\"];\n @Event() click: EventEmitter<\n Parameters<Required<DBNavigationItemProps>[\"onClick\"]>[number]\n > | void;\n @Prop() id: DBNavigationItemProps[\"id\"];\n @Prop({attribute: \"classname\"}) className: DBNavigationItemProps[\"className\"];\n @Prop() width: DBNavigationItemProps[\"width\"];\n @Prop() icon: DBNavigationItemProps[\"icon\"];\n @Prop() showIcon: DBNavigationItemProps[\"showIcon\"];\n @Prop() active: DBNavigationItemProps[\"active\"];\n @Prop() wrap: DBNavigationItemProps[\"wrap\"];\n @Prop() disabled: DBNavigationItemProps[\"disabled\"];\n @Prop() text: DBNavigationItemProps[\"text\"];\n @Prop() backButtonId: DBNavigationItemProps[\"backButtonId\"];\n @Prop() backButtonText: DBNavigationItemProps[\"backButtonText\"];\n @State() initialized = false;\n @State() hasAreaPopup = false;\n @State() hasSubNavigation = true;\n @State() isSubNavigationExpanded = false;\n @State() autoClose = false;\n @State() subNavigationId = \"sub-navigation-\" + uuid();\n @State() navigationItemSafeTriangle = undefined;\n\n handleNavigationItemClick(event: any) {\n if (event?.target?.nodeName === \"A\") {\n this.autoClose = true;\n void delay(() => {\n this.autoClose = false;\n }, 1000);\n }\n }\n handleClick(event: ClickEvent<HTMLButtonElement> | any) {\n if (this.click) {\n event.stopPropagation();\n this.click.emit(event);\n }\n if (this.hasAreaPopup) {\n this.isSubNavigationExpanded = true;\n }\n }\n handleBackClick(event: ClickEvent<HTMLButtonElement> | any) {\n event.stopPropagation();\n this.isSubNavigationExpanded = false;\n }\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n watch0Fn() {\n if (this.subNavigationExpanded !== undefined) {\n this.isSubNavigationExpanded = !!getBoolean(\n this.subNavigationExpanded,\n \"subNavigationExpanded\"\n );\n }\n }\n\n @Watch(\"subNavigationExpanded\")\n watch0() {\n this.watch0Fn();\n }\n\n watch1Fn() {\n if (this.initialized && this._ref) {\n const subNavigationSlot = this._ref.querySelector(\"menu\");\n if (subNavigationSlot) {\n if (subNavigationSlot.children?.length > 0) {\n this.hasAreaPopup = true;\n if (!this.navigationItemSafeTriangle) {\n this.navigationItemSafeTriangle = new NavigationItemSafeTriangle(\n this._ref,\n subNavigationSlot\n );\n }\n } else {\n this.hasSubNavigation = false;\n }\n }\n }\n }\n\n @Watch(\"initialized\")\n @Watch(\"_ref\")\n watch1() {\n this.watch1Fn();\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-navigation-item\");\n this.initialized = true;\n this.watch0Fn();\n this.watch1Fn();\n }\n\n render() {\n return (\n <li\n class={cls(\"db-navigation-item\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this.id}\n onMouseOver={() => this.navigationItemSafeTriangle?.enableFollow()}\n onMouseLeave={() => this.navigationItemSafeTriangle?.disableFollow()}\n onMouseMove={(event) =>\n this.navigationItemSafeTriangle?.followByMouseEvent(event)\n }\n data-width={this.width}\n data-icon={this.icon}\n data-show-icon={getBooleanAsString(this.showIcon)}\n data-active={this.active}\n data-wrap={getBooleanAsString(this.wrap)}\n aria-disabled={getBooleanAsString(this.disabled)}\n >\n {!this.hasSubNavigation ? this.text ? this.text : <slot></slot> : null}\n {this.hasSubNavigation ? (\n <Fragment>\n <button\n class=\"db-navigation-item-expand-button\"\n aria-haspopup={this.hasAreaPopup}\n aria-expanded={this.isSubNavigationExpanded}\n disabled={getBoolean(this.disabled, \"disabled\")}\n onClick={(event) => this.handleClick(event)}\n >\n {this.text ? this.text : <slot></slot>}\n </button>\n <menu\n class=\"db-sub-navigation\"\n data-force-close={this.autoClose}\n id={this.subNavigationId}\n onClick={(event) => this.handleNavigationItemClick(event)}\n >\n {this.hasAreaPopup ? (\n <div class=\"db-mobile-navigation-back\">\n <db-button\n icon=\"arrow_left\"\n variant=\"ghost\"\n id={this.backButtonId}\n onClick={(event) => this.handleBackClick(event)}\n >\n {this.backButtonText ?? DEFAULT_BACK}\n </db-button>\n </div>\n ) : null}\n <slot name=\"subNavigation\"></slot>\n </menu>\n </Fragment>\n ) : null}\n </li>\n );\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"db-navigation-item.entry.js","sources":["src/components/navigation-item/navigation-item.tsx"],"sourcesContent":["import { DEFAULT_LABEL } from \"../../shared/constants\";\nimport { cls, getBooleanAsString } from \"../../utils\";\nimport { DBTooltip } from \"../tooltip/tooltip\";\nimport { DBNavigationItemProps } from \"./model\";\n\nimport { Component, h, Fragment, Prop } from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n * @slot additionalInformation - TODO: Add description for slotAdditionalInformation\n */\n @Component({\n tag: \"db-navigation-item\",\n})\nexport class DBNavigationItem {\n private _ref!: HTMLLIElement | any;\n @Prop() id: DBNavigationItemProps[\"id\"];\n @Prop({attribute: \"classname\"}) className: DBNavigationItemProps[\"className\"];\n @Prop() icon: DBNavigationItemProps[\"icon\"];\n @Prop() showIcon: DBNavigationItemProps[\"showIcon\"];\n @Prop() active: DBNavigationItemProps[\"active\"];\n @Prop() disabled: DBNavigationItemProps[\"disabled\"];\n @Prop() tooltip: DBNavigationItemProps[\"tooltip\"];\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-navigation-item\");\n }\n\n render() {\n return (\n <li\n class={cls(\"db-navigation-item\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this.id}\n data-icon={this.icon}\n data-show-icon={getBooleanAsString(this.showIcon)}\n data-active={getBooleanAsString(this.active)}\n aria-disabled={getBooleanAsString(this.disabled)}\n >\n <slot></slot>\n <slot name=\"additionalInformation\"></slot>\n <db-tooltip placement=\"right\" delay=\"slow\">\n {this.tooltip ?? DEFAULT_LABEL}\n </db-tooltip>\n </li>\n );\n }\n}\n"],"names":[],"mappings":";;;;MAea,gBAAgB,GAAA,MAAA;;;;AAU3B;;;;AAIG;IACK,sBAAsB,CAC5B,OAA2B,EAC3B,qBAA6B,EAAA;QAE7B,MAAM,MAAM,GAAG,OAAO,KAAA,IAAA,IAAP,OAAO,KAAA,MAAA,GAAA,MAAA,GAAP,OAAO,CAAE,OAAO,CAAC,qBAAqB,CAAC;AACtD,QAAA,IAAI,OAAO,IAAI,MAAM,EAAE;AACrB,YAAA,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU;AACpC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;AAC/B,gBAAA,IACE,IAAI;AACJ,qBAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAChE;oBACA,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC;AAC3C,oBAAA,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;;gBAEnC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;oBACjC,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC;AACtD,oBAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE;oBACvD,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC;oBAClD,OAAO,CAAC,YAAY,CAClB,IAAI,CAAC,IAAI,EACT,CAAG,EAAA,YAAY,GAAG,CAAG,EAAA,YAAY,CAAG,CAAA,CAAA,GAAG,EAAE,CAAG,EAAA,KAAK,CAAE,CAAA,CACpD;oBACD,IAAI,cAAc,EAAE;;AAElB,wBAAA,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,UAAU,CAAC;;yBACnC;AACL,wBAAA,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;;IAO3C,gBAAgB,GAAA;QACd,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,oBAAoB,CAAC;;IAG9D,MAAM,GAAA;;QACJ,QACE,CACE,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,GAAG,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,EAChD,GAAG,EAAE,CAAC,EAAO,KAAI;AACf,gBAAA,IAAI,CAAC,IAAI,GAAG,EAAE;aACf,EACD,EAAE,EAAE,IAAI,CAAC,EAAE,EACA,WAAA,EAAA,IAAI,CAAC,IAAI,EACJ,gBAAA,EAAA,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,EACpC,aAAA,EAAA,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAA,eAAA,EAC7B,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAA,EAEhD,CAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,EACb,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,uBAAuB,EAAQ,CAAA,EAC1C,CAAA,CAAA,YAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAY,SAAS,EAAC,OAAO,EAAC,KAAK,EAAC,MAAM,EAAA,EACvC,CAAA,EAAA,GAAA,IAAI,CAAC,OAAO,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,aAAa,CACnB,CACV;;;;;;"}
@@ -1,11 +1,49 @@
1
- import { r as registerInstance, h } from './index-CNzNv7KB.js';
2
- import { D as DEFAULT_ID } from './constants-DC9V_oNU.js';
3
- import { u as uuid, c as cls } from './index-YECpAE3G.js';
1
+ import { r as registerInstance, h } from './index-uOzX56mL.js';
2
+ import { d as delay, g as getBooleanAsString, c as cls } from './index-YECpAE3G.js';
3
+ import { h as handleSubNavigationPosition } from './navigation-CJ-OxodG.js';
4
+ import './floating-components-D3kmGlOI.js';
4
5
 
5
6
  const DBNavigation = class {
6
7
  constructor(hostRef) {
7
8
  registerInstance(this, hostRef);
8
- this._id = DEFAULT_ID;
9
+ this.showScrollLeft = false;
10
+ this.showScrollRight = false;
11
+ this._shellDesktopPosition = undefined;
12
+ this._subNavigationDesktopPosition = undefined;
13
+ this._variant = undefined;
14
+ this.initialized = false;
15
+ this._isSubNavigation = false;
16
+ }
17
+ evaluateScrollButtons(tList) {
18
+ const needsScroll = tList.scrollWidth > tList.clientWidth;
19
+ const scrollLeft = Math.ceil(tList.scrollLeft);
20
+ this.showScrollLeft = needsScroll && scrollLeft > 1;
21
+ this.showScrollRight =
22
+ needsScroll && scrollLeft < tList.scrollWidth - tList.clientWidth;
23
+ }
24
+ scroll(left) {
25
+ var _a;
26
+ let step = Number(this.arrowScrollDistance) || 100;
27
+ if (left) {
28
+ step *= -1;
29
+ }
30
+ (_a = this.menuRef) === null || _a === void 0 ? void 0 : _a.scrollBy({
31
+ top: 0,
32
+ left: step,
33
+ behavior: "smooth",
34
+ });
35
+ }
36
+ onScroll() {
37
+ this.evaluateScrollButtons(this.menuRef);
38
+ this._handleSubNavigation();
39
+ }
40
+ _handleSubNavigation() {
41
+ handleSubNavigationPosition(this.menuRef, this._shellDesktopPosition === "left" ||
42
+ (this._shellDesktopPosition === "top" &&
43
+ this._subNavigationDesktopPosition === "left" &&
44
+ this._isSubNavigation)
45
+ ? 1
46
+ : 0);
9
47
  }
10
48
  /**
11
49
  * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.
@@ -39,15 +77,83 @@ const DBNavigation = class {
39
77
  }
40
78
  }
41
79
  }
80
+ watch0Fn() {
81
+ if (this._ref && this.initialized) {
82
+ void delay(() => {
83
+ var _a, _b, _c, _d, _e;
84
+ const element = this._ref;
85
+ if (!element)
86
+ return;
87
+ let endVariant = (_a = this.variant) !== null && _a !== void 0 ? _a : "popover";
88
+ const parentClassList = ((_b = element.parentElement) === null || _b === void 0 ? void 0 : _b.nodeName.startsWith("DB"))
89
+ ? (_d = (_c = element.parentElement) === null || _c === void 0 ? void 0 : _c.parentElement) === null || _d === void 0 ? void 0 : _d.classList
90
+ : (_e = element.parentElement) === null || _e === void 0 ? void 0 : _e.classList;
91
+ const shell = element.closest(".db-shell");
92
+ const shellDesktopPosition = shell === null || shell === void 0 ? void 0 : shell.getAttribute("data-control-panel-desktop-position");
93
+ const shellSubNaviDesktopPosition = shell === null || shell === void 0 ? void 0 : shell.getAttribute("data-sub-navigation-desktop-position");
94
+ this._shellDesktopPosition = shellDesktopPosition;
95
+ this._subNavigationDesktopPosition = shellSubNaviDesktopPosition;
96
+ const isSubNavigation = parentClassList === null || parentClassList === void 0 ? void 0 : parentClassList.contains("db-shell-sub-navigation");
97
+ this._isSubNavigation = isSubNavigation;
98
+ const requiresPopover = (shellDesktopPosition === "top" &&
99
+ (parentClassList === null || parentClassList === void 0 ? void 0 : parentClassList.contains("db-control-panel-desktop-scroll-container"))) ||
100
+ ((shellSubNaviDesktopPosition === "top" ||
101
+ shellDesktopPosition === "left") &&
102
+ isSubNavigation);
103
+ if (requiresPopover) {
104
+ endVariant = "popover";
105
+ }
106
+ this._variant = endVariant;
107
+ }, 1);
108
+ }
109
+ }
110
+ watch0() {
111
+ this.watch0Fn();
112
+ }
113
+ watch1Fn() {
114
+ var _a;
115
+ if (this.menuRef && this._variant) {
116
+ if (!this._variant || this._variant === "popover") {
117
+ this._handleSubNavigation();
118
+ }
119
+ else if (this._variant === "tree") {
120
+ for (const menu of Array.from(this.menuRef.querySelectorAll(".db-navigation-item-group-menu"))) {
121
+ menu.style.position = "";
122
+ }
123
+ for (const navItem of Array.from(this.menuRef.querySelectorAll(".db-navigation-item, .db-navigation-item-group"))) {
124
+ // TODO: Add keyboard navigation support
125
+ navItem.setAttribute("role", "none");
126
+ (_a = navItem.querySelector("a, button")) === null || _a === void 0 ? void 0 : _a.setAttribute("role", "treeitem");
127
+ }
128
+ }
129
+ this.evaluateScrollButtons(this.menuRef);
130
+ }
131
+ }
132
+ watch1() {
133
+ this.watch1Fn();
134
+ }
42
135
  componentDidLoad() {
43
136
  this.enableAttributePassing(this._ref, "db-navigation");
44
- this._id = this.id || "navigation-" + uuid();
137
+ this.initialized = true;
138
+ this.watch0Fn();
139
+ this.watch1Fn();
45
140
  }
46
141
  render() {
47
- return (h("nav", { key: 'ed27159179b89985cbf0711be7dc494ca820cf75', class: cls("db-navigation", this.className), ref: (el) => {
142
+ var _a;
143
+ return (h("nav", { key: '3107723e96a604419f96e712778e5924fd3336cf', class: cls("db-navigation", this.className), ref: (el) => {
48
144
  this._ref = el;
49
- }, id: this._id }, h("menu", { key: '6aa518535f6c802abec874a174d6e8d028572269' }, h("slot", { key: '2307ee2093cf4bcec3c8f4b8d5e8e88a8d78cf08' }))));
145
+ }, id: this.id, "data-variant": this._variant, "data-show-tree-line": getBooleanAsString((_a = this.showTreeLine) !== null && _a !== void 0 ? _a : "true"), onScroll: () => this.onScroll() }, this.showScrollLeft ? (h("db-button", { class: "overflow-scroll-left-button", variant: "filled", icon: "chevron_left", type: "button", noText: true, onClick: () => this.scroll(true) }, "Scroll left")) : null, h("menu", { key: 'fe0b919e9981a4fbdb5a5cdc86caf5d6ab754e77', role: this._variant === "tree" ? "tree" : undefined, ref: (el) => {
146
+ this.menuRef = el;
147
+ }, onScroll: () => this.onScroll() }, h("slot", { key: '2a4141b4b2d5f7845590fb00fda5f10c80ad1e3e' })), this.showScrollRight ? (h("db-button", { class: "overflow-scroll-right-button", variant: "filled", icon: "chevron_right", type: "button", noText: true, onClick: () => this.scroll() }, "Scroll right")) : null));
50
148
  }
149
+ static get watchers() { return {
150
+ "_ref": ["watch0"],
151
+ "variant": ["watch0"],
152
+ "initialized": ["watch0"],
153
+ "menuRef": ["watch1"],
154
+ "_variant": ["watch1"],
155
+ "_shellDesktopPosition": ["watch1"]
156
+ }; }
51
157
  };
52
158
 
53
159
  export { DBNavigation as db_navigation };
@@ -1 +1 @@
1
- {"version":3,"file":"db-navigation.entry.js","sources":["src/components/navigation/navigation.tsx"],"sourcesContent":["import { DEFAULT_ID } from \"../../shared/constants\";\nimport { cls, uuid } from \"../../utils\";\nimport { DBNavigationProps, DBNavigationState } from \"./model\";\n\nimport { Component, h, Fragment, Prop, State } from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n\n */\n @Component({\n tag: \"db-navigation\",\n})\nexport class DBNavigation {\n private _ref!: HTMLDivElement | any;\n @Prop() id: DBNavigationProps[\"id\"];\n @Prop({attribute: \"classname\"}) className: DBNavigationProps[\"className\"];\n @State() _id = DEFAULT_ID;\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-navigation\");\n this._id = this.id || \"navigation-\" + uuid();\n }\n\n render() {\n return (\n <nav\n class={cls(\"db-navigation\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this._id}\n >\n <menu>\n <slot></slot>\n </menu>\n </nav>\n );\n }\n}\n"],"names":[],"mappings":";;;;MAca,YAAY,GAAA,MAAA;AAHxB,IAAA,WAAA,CAAA,OAAA,EAAA;;AAOU,QAAA,IAAG,CAAA,GAAA,GAAG,UAAU;AA8D1B;AA5DC;;;;AAIG;IACK,sBAAsB,CAC5B,OAA2B,EAC3B,qBAA6B,EAAA;QAE7B,MAAM,MAAM,GAAG,OAAO,KAAA,IAAA,IAAP,OAAO,KAAA,MAAA,GAAA,MAAA,GAAP,OAAO,CAAE,OAAO,CAAC,qBAAqB,CAAC;AACtD,QAAA,IAAI,OAAO,IAAI,MAAM,EAAE;AACrB,YAAA,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU;AACpC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;AAC/B,gBAAA,IACE,IAAI;AACJ,qBAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAChE;oBACA,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC;AAC3C,oBAAA,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;;gBAEnC,IAAI,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;oBACjC,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC;AACtD,oBAAA,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE;oBACvD,MAAM,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC;oBAClD,OAAO,CAAC,YAAY,CAClB,IAAI,CAAC,IAAI,EACT,CAAG,EAAA,YAAY,GAAG,CAAG,EAAA,YAAY,CAAG,CAAA,CAAA,GAAG,EAAE,CAAG,EAAA,KAAK,CAAE,CAAA,CACpD;oBACD,IAAI,cAAc,EAAE;;AAElB,wBAAA,MAAM,CAAC,YAAY,CAAC,OAAO,EAAE,UAAU,CAAC;;yBACnC;AACL,wBAAA,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;;;;;;IAO3C,gBAAgB,GAAA;QACd,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,EAAE,eAAe,CAAC;QACvD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,aAAa,GAAG,IAAI,EAAE;;IAG9C,MAAM,GAAA;QACJ,QACE,CACE,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,EAC3C,GAAG,EAAE,CAAC,EAAO,KAAI;AACf,gBAAA,IAAI,CAAC,IAAI,GAAG,EAAE;AAChB,aAAC,EACD,EAAE,EAAE,IAAI,CAAC,GAAG,EAAA,EAEZ,CAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACE,CAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACR,CACH;;;;;;"}
1
+ {"version":3,"file":"db-navigation.entry.js","sources":["src/components/navigation/navigation.tsx"],"sourcesContent":["import { cls, delay, getBooleanAsString } from \"../../utils\";\nimport { handleSubNavigationPosition } from \"../../utils/navigation\";\nimport { DBButton } from \"../button/button\";\nimport { DBNavigationProps, DBNavigationState } from \"./model\";\n\nimport { Component, h, Fragment, Watch, Prop, State } from \"@stencil/core\";\n\n\n/**\n * @slot children - This is a default/unnamed slot\n\n */\n @Component({\n tag: \"db-navigation\",\n})\nexport class DBNavigation {\n private _ref!: HTMLDivElement | any;\n private menuRef!: HTMLMenuElement | any;\n @Prop() variant: DBNavigationProps[\"variant\"];\n @Prop() arrowScrollDistance: DBNavigationProps[\"arrowScrollDistance\"];\n @Prop() id: DBNavigationProps[\"id\"];\n @Prop() showTreeLine: DBNavigationProps[\"showTreeLine\"];\n @Prop({attribute: \"classname\"}) className: DBNavigationProps[\"className\"];\n @State() showScrollLeft = false;\n @State() showScrollRight = false;\n @State() _shellDesktopPosition = undefined;\n @State() _subNavigationDesktopPosition = undefined;\n @State() _variant = undefined;\n @State() initialized = false;\n @State() _isSubNavigation = false;\n\n evaluateScrollButtons(tList: Element) {\n const needsScroll = tList.scrollWidth > tList.clientWidth;\n const scrollLeft = Math.ceil(tList.scrollLeft);\n this.showScrollLeft = needsScroll && scrollLeft > 1;\n this.showScrollRight =\n needsScroll && scrollLeft < tList.scrollWidth - tList.clientWidth;\n }\n scroll(left?: boolean) {\n let step = Number(this.arrowScrollDistance) || 100;\n if (left) {\n step *= -1;\n }\n this.menuRef?.scrollBy({\n top: 0,\n left: step,\n behavior: \"smooth\",\n });\n }\n onScroll() {\n this.evaluateScrollButtons(this.menuRef);\n this._handleSubNavigation();\n }\n _handleSubNavigation() {\n handleSubNavigationPosition(\n this.menuRef,\n this._shellDesktopPosition === \"left\" ||\n (this._shellDesktopPosition === \"top\" &&\n this._subNavigationDesktopPosition === \"left\" &&\n this._isSubNavigation)\n ? 1\n : 0\n );\n }\n\n /**\n * Passes `aria-*`, `data-*` & `class` attributes to correct child. Used in angular and stencil.\n * @param element the ref for the component\n * @param customElementSelector the custom element like `my-component`\n */\n private enableAttributePassing(\n element: HTMLElement | null,\n customElementSelector: string\n ) {\n const parent = element?.closest(customElementSelector);\n if (element && parent) {\n const attributes = parent.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i);\n if (\n attr &&\n (attr.name.startsWith(\"data-\") || attr.name.startsWith(\"aria-\"))\n ) {\n element.setAttribute(attr.name, attr.value);\n parent.removeAttribute(attr.name);\n }\n if (attr && attr.name === \"class\") {\n const isWebComponent = attr.value.includes(\"hydrated\");\n const value = attr.value.replace(\"hydrated\", \"\").trim();\n const currentClass = element.getAttribute(\"class\");\n element.setAttribute(\n attr.name,\n `${currentClass ? `${currentClass} ` : \"\"}${value}`\n );\n if (isWebComponent) {\n // Stencil is using this class for lazy loading component\n parent.setAttribute(\"class\", \"hydrated\");\n } else {\n parent.removeAttribute(attr.name);\n }\n }\n }\n }\n }\n\n watch0Fn() {\n if (this._ref && this.initialized) {\n void delay(() => {\n const element = this._ref as HTMLElement;\n if (!element) return;\n let endVariant = this.variant ?? \"popover\";\n const parentClassList = element.parentElement?.nodeName.startsWith(\"DB\")\n ? element.parentElement?.parentElement?.classList\n : element.parentElement?.classList;\n const shell = element.closest(\".db-shell\");\n const shellDesktopPosition = shell?.getAttribute(\n \"data-control-panel-desktop-position\"\n );\n const shellSubNaviDesktopPosition = shell?.getAttribute(\n \"data-sub-navigation-desktop-position\"\n );\n this._shellDesktopPosition = shellDesktopPosition;\n this._subNavigationDesktopPosition = shellSubNaviDesktopPosition;\n const isSubNavigation = parentClassList?.contains(\n \"db-shell-sub-navigation\"\n );\n this._isSubNavigation = isSubNavigation;\n const requiresPopover =\n (shellDesktopPosition === \"top\" &&\n parentClassList?.contains(\n \"db-control-panel-desktop-scroll-container\"\n )) ||\n ((shellSubNaviDesktopPosition === \"top\" ||\n shellDesktopPosition === \"left\") &&\n isSubNavigation);\n if (requiresPopover) {\n endVariant = \"popover\";\n }\n this._variant = endVariant;\n }, 1);\n }\n }\n\n @Watch(\"_ref\")\n @Watch(\"variant\")\n @Watch(\"initialized\")\n watch0() {\n this.watch0Fn();\n }\n\n watch1Fn() {\n if (this.menuRef && this._variant) {\n if (!this._variant || this._variant === \"popover\") {\n this._handleSubNavigation();\n } else if (this._variant === \"tree\") {\n for (const menu of Array.from(\n (this.menuRef as HTMLElement).querySelectorAll(\n \".db-navigation-item-group-menu\"\n )\n )) {\n (menu as HTMLElement).style.position = \"\";\n }\n for (const navItem of Array.from(\n (this.menuRef as HTMLElement).querySelectorAll(\n \".db-navigation-item, .db-navigation-item-group\"\n )\n )) {\n // TODO: Add keyboard navigation support\n navItem.setAttribute(\"role\", \"none\");\n navItem.querySelector(\"a, button\")?.setAttribute(\"role\", \"treeitem\");\n }\n }\n this.evaluateScrollButtons(this.menuRef);\n }\n }\n\n @Watch(\"menuRef\")\n @Watch(\"_variant\")\n @Watch(\"_shellDesktopPosition\")\n watch1() {\n this.watch1Fn();\n }\n\n componentDidLoad() {\n this.enableAttributePassing(this._ref, \"db-navigation\");\n this.initialized = true;\n this.watch0Fn();\n this.watch1Fn();\n }\n\n render() {\n return (\n <nav\n class={cls(\"db-navigation\", this.className)}\n ref={(el: any) => {\n this._ref = el;\n }}\n id={this.id}\n data-variant={this._variant}\n data-show-tree-line={getBooleanAsString(this.showTreeLine ?? \"true\")}\n onScroll={() => this.onScroll()}\n >\n {this.showScrollLeft ? (\n <db-button\n class=\"overflow-scroll-left-button\"\n variant=\"filled\"\n icon=\"chevron_left\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll(true)}\n >\n Scroll left\n </db-button>\n ) : null}\n <menu\n role={this._variant === \"tree\" ? \"tree\" : undefined}\n ref={(el: any) => {\n this.menuRef = el;\n }}\n onScroll={() => this.onScroll()}\n >\n <slot></slot>\n </menu>\n {this.showScrollRight ? (\n <db-button\n class=\"overflow-scroll-right-button\"\n variant=\"filled\"\n icon=\"chevron_right\"\n type=\"button\"\n noText={true}\n onClick={() => this.scroll()}\n >\n Scroll right\n </db-button>\n ) : null}\n </nav>\n );\n }\n}\n"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { r as registerInstance, c as createEvent, h } from './index-CNzNv7KB.js';
2
- import { s as DEFAULT_CLOSE_BUTTON } from './constants-DC9V_oNU.js';
1
+ import { r as registerInstance, c as createEvent, h } from './index-uOzX56mL.js';
2
+ import { u as DEFAULT_CLOSE_BUTTON } from './constants-Dst8dqRS.js';
3
3
  import { b as getBoolean, s as stringPropVisible, g as getBooleanAsString, c as cls } from './index-YECpAE3G.js';
4
4
 
5
5
  const DBNotification = class {
@@ -52,9 +52,9 @@ const DBNotification = class {
52
52
  }
53
53
  render() {
54
54
  var _a;
55
- return (h("article", { key: '5c2aed4066efbc207ade969f84c5cea58350a49a', class: cls("db-notification", this.className), ref: (el) => {
55
+ return (h("article", { key: '4ba30272915f370c403f76af94167074676884c9', class: cls("db-notification", this.className), ref: (el) => {
56
56
  this._ref = el;
57
- }, id: this.id, "aria-live": this.ariaLive, "data-semantic": this.semantic, "data-variant": this.variant, "data-icon": this.icon, "data-show-icon": getBooleanAsString(this.showIcon), "data-link-variant": this.linkVariant }, h("slot", { key: '5b4a5fbc5dad5b04b3f2a0d269cf2ca48f79df7e', name: "image" }), stringPropVisible(this.headline, this.showHeadline) ? (h("header", null, this.headline)) : null, h("p", { key: 'a72611c45ee17745a354e243fdb5cc3e22abf5be' }, this.text ? this.text : h("slot", null)), stringPropVisible(this.timestamp, this.showTimestamp) ? (h("span", null, this.timestamp)) : null, h("slot", { key: '7679c3681608babce822cd7d4251e0bfc2ce08d4', name: "link" }), getBoolean(this.closeable, "closeable") ? (h("db-button", { icon: "cross", variant: "ghost", size: "small", id: this.closeButtonId, noText: true, onClick: (event) => this.handleClose(event) }, (_a = this.closeButtonText) !== null && _a !== void 0 ? _a : DEFAULT_CLOSE_BUTTON)) : null));
57
+ }, id: this.id, "aria-live": this.ariaLive, "data-semantic": this.semantic, "data-variant": this.variant, "data-icon": this.icon, "data-show-icon": getBooleanAsString(this.showIcon), "data-link-variant": this.linkVariant }, h("slot", { key: '15d84713938eeaac63dc188c687f040f4c4d8be7', name: "image" }), stringPropVisible(this.headline, this.showHeadline) ? (h("header", null, this.headline)) : null, h("p", { key: '3001384c9467b01c42a1a3c0f41cbc90bb3f042e' }, this.text ? this.text : h("slot", null)), stringPropVisible(this.timestamp, this.showTimestamp) ? (h("span", null, this.timestamp)) : null, h("slot", { key: 'd4ba480a50b685bb6041928ab6be28ae7dbd2f91', name: "link" }), getBoolean(this.closeable, "closeable") ? (h("db-button", { icon: "cross", variant: "ghost", size: "small", id: this.closeButtonId, noText: true, onClick: (event) => this.handleClose(event) }, (_a = this.closeButtonText) !== null && _a !== void 0 ? _a : DEFAULT_CLOSE_BUTTON)) : null));
58
58
  }
59
59
  };
60
60
 
@@ -1,7 +1,7 @@
1
- import { r as registerInstance, h } from './index-CNzNv7KB.js';
1
+ import { r as registerInstance, h } from './index-uOzX56mL.js';
2
2
  import { d as delay, g as getBooleanAsString, c as cls } from './index-YECpAE3G.js';
3
3
  import { D as DocumentScrollListener } from './document-scroll-listener-DC7DAxof.js';
4
- import { b as handleFixedPopover } from './floating-components-G-TursYV.js';
4
+ import { b as handleFixedPopover } from './floating-components-D3kmGlOI.js';
5
5
 
6
6
  const DBPopover = class {
7
7
  constructor(hostRef) {
@@ -26,8 +26,7 @@ const DBPopover = class {
26
26
  if (article) {
27
27
  // This is a workaround for angular
28
28
  delay(() => {
29
- var _a;
30
- handleFixedPopover(article, this._ref, (_a = this.placement) !== null && _a !== void 0 ? _a : "bottom");
29
+ handleFixedPopover(article, this._ref);
31
30
  }, 1);
32
31
  }
33
32
  }
@@ -164,9 +163,9 @@ const DBPopover = class {
164
163
  }
165
164
  render() {
166
165
  var _a;
167
- return (h("div", { key: '4d902919abc8bf5b55a617a31424f35582e029c1', class: cls("db-popover", this.className), ref: (el) => {
166
+ return (h("div", { key: 'd257fcc711d6b7e42f388a1e83e79e0f2b5ca907', class: cls("db-popover", this.className), ref: (el) => {
168
167
  this._ref = el;
169
- }, id: this.id }, h("slot", { key: '166a0b766f6f0c003e6d7a250fd466267117f59a', name: "trigger" }), h("article", { key: '4fa535dc081c76eb21671e0abfb7d090b38e6e5c', class: "db-popover-content", "data-spacing": this.spacing, "data-gap": getBooleanAsString(this.gap), "data-animation": getBooleanAsString((_a = this.animation) !== null && _a !== void 0 ? _a : true), "data-open": getBooleanAsString(this.open), "data-delay": this.delay, "data-width": this.width, "data-placement": this.placement }, h("slot", { key: 'ef47687b496cfe4d6cce11ef5d282a2ec3a88004' }))));
168
+ }, id: this.id }, h("slot", { key: '3703b88b293e6f6e8b59fd64c21a67cae94e799d', name: "trigger" }), h("article", { key: '2337d6715bf1d96ea1f268a993f54bdcd9f8ff11', class: "db-popover-content", "data-spacing": this.spacing, "data-gap": getBooleanAsString(this.gap), "data-animation": getBooleanAsString((_a = this.animation) !== null && _a !== void 0 ? _a : true), "data-open": getBooleanAsString(this.open), "data-delay": this.delay, "data-width": this.width, "data-placement": this.placement }, h("slot", { key: '6752ce6d69fbe88182e7927ba66ae45bf6ec6ba5' }))));
170
169
  }
171
170
  static get watchers() { return {
172
171
  "_ref": ["watch0", "watch1"],