@smg-automotive/components 25.11.0-dgajin-vsst-4341-migrate-range-filter-input-with-slider.1 → 25.11.0-dgajin-vsst-4352-migrate-carousel.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (567) hide show
  1. package/dist/cjs/components/accordion/AccordionPanel.d.ts.map +1 -1
  2. package/dist/cjs/components/alert/index.d.ts +2 -2
  3. package/dist/cjs/components/alert/index.d.ts.map +1 -1
  4. package/dist/cjs/components/carousel/DotsPagination.d.ts +8 -0
  5. package/dist/cjs/components/carousel/DotsPagination.d.ts.map +1 -0
  6. package/dist/cjs/components/carousel/DotsPaginationIndicator.d.ts +7 -0
  7. package/dist/cjs/components/carousel/DotsPaginationIndicator.d.ts.map +1 -0
  8. package/dist/cjs/components/carousel/NavigationButton.d.ts +11 -0
  9. package/dist/cjs/components/carousel/NavigationButton.d.ts.map +1 -0
  10. package/dist/cjs/components/carousel/NumbersPagination.d.ts +10 -0
  11. package/dist/cjs/components/carousel/NumbersPagination.d.ts.map +1 -0
  12. package/dist/cjs/components/carousel/NumbersPaginationButton.d.ts +10 -0
  13. package/dist/cjs/components/carousel/NumbersPaginationButton.d.ts.map +1 -0
  14. package/dist/cjs/components/carousel/Slide.d.ts +13 -0
  15. package/dist/cjs/components/carousel/Slide.d.ts.map +1 -0
  16. package/dist/cjs/components/carousel/Thumbnail.d.ts +10 -0
  17. package/dist/cjs/components/carousel/Thumbnail.d.ts.map +1 -0
  18. package/dist/cjs/components/carousel/ThumbnailNavigationButton.d.ts +9 -0
  19. package/dist/cjs/components/carousel/ThumbnailNavigationButton.d.ts.map +1 -0
  20. package/dist/cjs/components/carousel/ThumbnailPagination.d.ts +12 -0
  21. package/dist/cjs/components/carousel/ThumbnailPagination.d.ts.map +1 -0
  22. package/dist/cjs/components/carousel/index.d.ts +36 -0
  23. package/dist/cjs/components/carousel/index.d.ts.map +1 -0
  24. package/dist/cjs/components/closeButton/index.d.ts +2 -2
  25. package/dist/cjs/components/closeButton/index.d.ts.map +1 -1
  26. package/dist/cjs/components/index.d.ts +4 -0
  27. package/dist/cjs/components/index.d.ts.map +1 -1
  28. package/dist/cjs/components/list/SearchableList.d.ts +20 -0
  29. package/dist/cjs/components/list/SearchableList.d.ts.map +1 -0
  30. package/dist/cjs/components/list/SearchableListItem.d.ts +26 -0
  31. package/dist/cjs/components/list/SearchableListItem.d.ts.map +1 -0
  32. package/dist/cjs/components/list/SearchableListItemLabel.d.ts +6 -0
  33. package/dist/cjs/components/list/SearchableListItemLabel.d.ts.map +1 -0
  34. package/dist/cjs/components/menu/index.d.ts.map +1 -1
  35. package/dist/cjs/components/mobileOnlyAccordion/MobileOnlyAccordionItem.d.ts.map +1 -1
  36. package/dist/cjs/components/mobileOnlyAccordion/MobileOnlyAccordionPanel.d.ts.map +1 -1
  37. package/dist/cjs/components/mobileOnlyAccordion/index.d.ts +1 -1
  38. package/dist/cjs/components/mobileOnlyAccordion/index.d.ts.map +1 -1
  39. package/dist/cjs/components/navigation/header/ComparisonItem.d.ts +11 -0
  40. package/dist/cjs/components/navigation/header/ComparisonItem.d.ts.map +1 -0
  41. package/dist/cjs/components/navigation/header/MobileMenuToggle.d.ts +11 -0
  42. package/dist/cjs/components/navigation/header/MobileMenuToggle.d.ts.map +1 -0
  43. package/dist/cjs/components/navigation/header/NavigationAvatar.d.ts +17 -0
  44. package/dist/cjs/components/navigation/header/NavigationAvatar.d.ts.map +1 -0
  45. package/dist/cjs/components/navigation/header/NavigationItem.d.ts +7 -0
  46. package/dist/cjs/components/navigation/header/NavigationItem.d.ts.map +1 -0
  47. package/dist/cjs/components/navigation/header/NavigationItems.d.ts +19 -0
  48. package/dist/cjs/components/navigation/header/NavigationItems.d.ts.map +1 -0
  49. package/dist/cjs/components/navigation/header/NavigationLanguageMenu.d.ts +8 -0
  50. package/dist/cjs/components/navigation/header/NavigationLanguageMenu.d.ts.map +1 -0
  51. package/dist/cjs/components/navigation/header/config/AutoRadar.d.ts +3 -0
  52. package/dist/cjs/components/navigation/header/config/AutoRadar.d.ts.map +1 -0
  53. package/dist/cjs/components/navigation/header/config/DrawerNodeItems.d.ts +40 -0
  54. package/dist/cjs/components/navigation/header/config/DrawerNodeItems.d.ts.map +1 -0
  55. package/dist/cjs/components/navigation/header/config/HeaderNavigationConfig.d.ts +90 -0
  56. package/dist/cjs/components/navigation/header/config/HeaderNavigationConfig.d.ts.map +1 -0
  57. package/dist/cjs/components/navigation/header/config/MarketPriceCheck.d.ts +4 -0
  58. package/dist/cjs/components/navigation/header/config/MarketPriceCheck.d.ts.map +1 -0
  59. package/dist/cjs/components/navigation/header/config/Optimizer.d.ts +3 -0
  60. package/dist/cjs/components/navigation/header/config/Optimizer.d.ts.map +1 -0
  61. package/dist/cjs/components/navigation/header/config/Presence.d.ts +8 -0
  62. package/dist/cjs/components/navigation/header/config/Presence.d.ts.map +1 -0
  63. package/dist/cjs/components/navigation/header/config/advertise.d.ts +3 -0
  64. package/dist/cjs/components/navigation/header/config/advertise.d.ts.map +1 -0
  65. package/dist/cjs/components/navigation/header/config/assure.d.ts +48 -0
  66. package/dist/cjs/components/navigation/header/config/assure.d.ts.map +1 -0
  67. package/dist/cjs/components/navigation/header/config/cockpit.d.ts +3 -0
  68. package/dist/cjs/components/navigation/header/config/cockpit.d.ts.map +1 -0
  69. package/dist/cjs/components/navigation/header/config/comparison.d.ts +34 -0
  70. package/dist/cjs/components/navigation/header/config/comparison.d.ts.map +1 -0
  71. package/dist/cjs/components/navigation/header/config/electroMobility.d.ts +25 -0
  72. package/dist/cjs/components/navigation/header/config/electroMobility.d.ts.map +1 -0
  73. package/dist/cjs/components/navigation/header/config/estimate.d.ts +25 -0
  74. package/dist/cjs/components/navigation/header/config/estimate.d.ts.map +1 -0
  75. package/dist/cjs/components/navigation/header/config/hci.d.ts +3 -0
  76. package/dist/cjs/components/navigation/header/config/hci.d.ts.map +1 -0
  77. package/dist/cjs/components/navigation/header/config/headerLinks.d.ts +27 -0
  78. package/dist/cjs/components/navigation/header/config/headerLinks.d.ts.map +1 -0
  79. package/dist/cjs/components/navigation/header/config/headerNavigationLink.d.ts +38 -0
  80. package/dist/cjs/components/navigation/header/config/headerNavigationLink.d.ts.map +1 -0
  81. package/dist/cjs/components/navigation/header/config/iconItems.d.ts +10 -0
  82. package/dist/cjs/components/navigation/header/config/iconItems.d.ts.map +1 -0
  83. package/dist/cjs/components/navigation/header/config/infoPortal.d.ts +3 -0
  84. package/dist/cjs/components/navigation/header/config/infoPortal.d.ts.map +1 -0
  85. package/dist/cjs/components/navigation/header/config/insuranceComparison.d.ts +25 -0
  86. package/dist/cjs/components/navigation/header/config/insuranceComparison.d.ts.map +1 -0
  87. package/dist/cjs/components/navigation/header/config/language.d.ts +12 -0
  88. package/dist/cjs/components/navigation/header/config/language.d.ts.map +1 -0
  89. package/dist/cjs/components/navigation/header/config/leadsManagement.d.ts +3 -0
  90. package/dist/cjs/components/navigation/header/config/leadsManagement.d.ts.map +1 -0
  91. package/dist/cjs/components/navigation/header/config/magazine.d.ts +25 -0
  92. package/dist/cjs/components/navigation/header/config/magazine.d.ts.map +1 -0
  93. package/dist/cjs/components/navigation/header/config/marketPriceCheckConfig.d.ts +3 -0
  94. package/dist/cjs/components/navigation/header/config/marketPriceCheckConfig.d.ts.map +1 -0
  95. package/dist/cjs/components/navigation/header/config/partnerHub.d.ts +22 -0
  96. package/dist/cjs/components/navigation/header/config/partnerHub.d.ts.map +1 -0
  97. package/dist/cjs/components/navigation/header/config/print.d.ts +3 -0
  98. package/dist/cjs/components/navigation/header/config/print.d.ts.map +1 -0
  99. package/dist/cjs/components/navigation/header/config/search.d.ts +8 -0
  100. package/dist/cjs/components/navigation/header/config/search.d.ts.map +1 -0
  101. package/dist/cjs/components/navigation/header/config/sell.d.ts +77 -0
  102. package/dist/cjs/components/navigation/header/config/sell.d.ts.map +1 -0
  103. package/dist/cjs/components/navigation/header/config/templates.d.ts +4 -0
  104. package/dist/cjs/components/navigation/header/config/templates.d.ts.map +1 -0
  105. package/dist/cjs/components/navigation/header/config/topListing.d.ts +3 -0
  106. package/dist/cjs/components/navigation/header/config/topListing.d.ts.map +1 -0
  107. package/dist/cjs/components/navigation/header/config/topVehicles.d.ts +4 -0
  108. package/dist/cjs/components/navigation/header/config/topVehicles.d.ts.map +1 -0
  109. package/dist/cjs/components/navigation/header/config/user.d.ts +13 -0
  110. package/dist/cjs/components/navigation/header/config/user.d.ts.map +1 -0
  111. package/dist/cjs/components/navigation/header/config/vehiclePool.d.ts +6 -0
  112. package/dist/cjs/components/navigation/header/config/vehiclePool.d.ts.map +1 -0
  113. package/dist/cjs/components/navigation/header/drawer/DrawerIndicator.d.ts +5 -0
  114. package/dist/cjs/components/navigation/header/drawer/DrawerIndicator.d.ts.map +1 -0
  115. package/dist/cjs/components/navigation/header/drawer/DrawerLoginToggle.d.ts +10 -0
  116. package/dist/cjs/components/navigation/header/drawer/DrawerLoginToggle.d.ts.map +1 -0
  117. package/dist/cjs/components/navigation/header/drawer/DrawerMenu.d.ts +6 -0
  118. package/dist/cjs/components/navigation/header/drawer/DrawerMenu.d.ts.map +1 -0
  119. package/dist/cjs/components/navigation/header/drawer/DrawerNavigationLink.d.ts +6 -0
  120. package/dist/cjs/components/navigation/header/drawer/DrawerNavigationLink.d.ts.map +1 -0
  121. package/dist/cjs/components/navigation/header/drawer/DrawerSections.d.ts +9 -0
  122. package/dist/cjs/components/navigation/header/drawer/DrawerSections.d.ts.map +1 -0
  123. package/dist/cjs/components/navigation/header/drawer/index.d.ts +17 -0
  124. package/dist/cjs/components/navigation/header/drawer/index.d.ts.map +1 -0
  125. package/dist/cjs/components/navigation/header/drawer/userInfo/SelectedTenantInfo.d.ts +9 -0
  126. package/dist/cjs/components/navigation/header/drawer/userInfo/SelectedTenantInfo.d.ts.map +1 -0
  127. package/dist/cjs/components/navigation/header/drawer/userInfo/TenantSelectionMenu.d.ts +11 -0
  128. package/dist/cjs/components/navigation/header/drawer/userInfo/TenantSelectionMenu.d.ts.map +1 -0
  129. package/dist/cjs/components/navigation/header/drawer/userInfo/index.d.ts +10 -0
  130. package/dist/cjs/components/navigation/header/drawer/userInfo/index.d.ts.map +1 -0
  131. package/dist/cjs/components/navigation/header/hooks/useNavigationDrawer.d.ts +26 -0
  132. package/dist/cjs/components/navigation/header/hooks/useNavigationDrawer.d.ts.map +1 -0
  133. package/dist/cjs/components/navigation/header/index.d.ts +28 -0
  134. package/dist/cjs/components/navigation/header/index.d.ts.map +1 -0
  135. package/dist/cjs/components/navigation/header/links/HeaderLink.d.ts +6 -0
  136. package/dist/cjs/components/navigation/header/links/HeaderLink.d.ts.map +1 -0
  137. package/dist/cjs/components/navigation/header/links/NavigationLink.d.ts +23 -0
  138. package/dist/cjs/components/navigation/header/links/NavigationLink.d.ts.map +1 -0
  139. package/dist/cjs/components/navigation/header/navigationTenantMenu/Content.d.ts +12 -0
  140. package/dist/cjs/components/navigation/header/navigationTenantMenu/Content.d.ts.map +1 -0
  141. package/dist/cjs/components/navigation/header/navigationTenantMenu/Loading.d.ts +3 -0
  142. package/dist/cjs/components/navigation/header/navigationTenantMenu/Loading.d.ts.map +1 -0
  143. package/dist/cjs/components/navigation/header/navigationTenantMenu/index.d.ts +9 -0
  144. package/dist/cjs/components/navigation/header/navigationTenantMenu/index.d.ts.map +1 -0
  145. package/dist/cjs/components/navigation/header/replaceLanguage.d.ts +6 -0
  146. package/dist/cjs/components/navigation/header/replaceLanguage.d.ts.map +1 -0
  147. package/dist/cjs/components/tenantSelection/Container.d.ts +6 -0
  148. package/dist/cjs/components/tenantSelection/Container.d.ts.map +1 -0
  149. package/dist/cjs/components/tenantSelection/Loading.d.ts +3 -0
  150. package/dist/cjs/components/tenantSelection/Loading.d.ts.map +1 -0
  151. package/dist/cjs/components/tenantSelection/ModalLayout.d.ts +3 -0
  152. package/dist/cjs/components/tenantSelection/ModalLayout.d.ts.map +1 -0
  153. package/dist/cjs/components/tenantSelection/Overview.d.ts +12 -0
  154. package/dist/cjs/components/tenantSelection/Overview.d.ts.map +1 -0
  155. package/dist/cjs/components/tenantSelection/__tests__/createTenantLabel.test.d.ts +2 -0
  156. package/dist/cjs/components/tenantSelection/__tests__/createTenantLabel.test.d.ts.map +1 -0
  157. package/dist/cjs/components/tenantSelection/createTenantLabel.d.ts +5 -0
  158. package/dist/cjs/components/tenantSelection/createTenantLabel.d.ts.map +1 -0
  159. package/dist/cjs/components/tenantSelection/index.d.ts +16 -0
  160. package/dist/cjs/components/tenantSelection/index.d.ts.map +1 -0
  161. package/dist/cjs/components/tenantSelection/select/List.d.ts +13 -0
  162. package/dist/cjs/components/tenantSelection/select/List.d.ts.map +1 -0
  163. package/dist/cjs/components/tenantSelection/select/index.d.ts +11 -0
  164. package/dist/cjs/components/tenantSelection/select/index.d.ts.map +1 -0
  165. package/dist/cjs/hooks/useToast/Toast.d.ts +12 -0
  166. package/dist/cjs/hooks/useToast/Toast.d.ts.map +1 -0
  167. package/dist/cjs/hooks/useToast/TopRightToast.d.ts +4 -0
  168. package/dist/cjs/hooks/useToast/TopRightToast.d.ts.map +1 -0
  169. package/dist/cjs/hooks/useToast/TopToaster.d.ts +4 -0
  170. package/dist/cjs/hooks/useToast/TopToaster.d.ts.map +1 -0
  171. package/dist/cjs/hooks/useToast/index.d.ts +9 -0
  172. package/dist/cjs/hooks/useToast/index.d.ts.map +1 -0
  173. package/dist/cjs/index.js +3075 -129
  174. package/dist/cjs/index.js.map +1 -1
  175. package/dist/cjs/themes/shared/animationStyles.d.ts.map +1 -1
  176. package/dist/cjs/themes/shared/index.d.ts +31 -0
  177. package/dist/cjs/themes/shared/index.d.ts.map +1 -1
  178. package/dist/cjs/themes/shared/keyframes.d.ts.map +1 -1
  179. package/dist/cjs/themes/shared/slotRecipes/alert.d.ts +16 -0
  180. package/dist/cjs/themes/shared/slotRecipes/alert.d.ts.map +1 -1
  181. package/dist/cjs/themes/shared/slotRecipes/carousel.d.ts +16 -0
  182. package/dist/cjs/themes/shared/slotRecipes/carousel.d.ts.map +1 -0
  183. package/dist/cjs/themes/shared/slotRecipes/index.d.ts +31 -0
  184. package/dist/cjs/themes/shared/slotRecipes/index.d.ts.map +1 -1
  185. package/dist/cjs/themes/shared/slotRecipes/menu.d.ts.map +1 -1
  186. package/dist/esm/assets/images/logo_as24.svg.js +4 -0
  187. package/dist/esm/assets/images/logo_as24.svg.js.map +1 -0
  188. package/dist/esm/assets/images/logo_ms24.svg.js +4 -0
  189. package/dist/esm/assets/images/logo_ms24.svg.js.map +1 -0
  190. package/dist/esm/components/accordion/AccordionPanel.d.ts.map +1 -1
  191. package/dist/esm/components/accordion/AccordionPanel.js +2 -2
  192. package/dist/esm/components/accordion/AccordionPanel.js.map +1 -1
  193. package/dist/esm/components/alert/index.d.ts +2 -2
  194. package/dist/esm/components/alert/index.d.ts.map +1 -1
  195. package/dist/esm/components/carousel/DotsPagination.d.ts +8 -0
  196. package/dist/esm/components/carousel/DotsPagination.d.ts.map +1 -0
  197. package/dist/esm/components/carousel/DotsPagination.js +16 -0
  198. package/dist/esm/components/carousel/DotsPagination.js.map +1 -0
  199. package/dist/esm/components/carousel/DotsPaginationIndicator.d.ts +7 -0
  200. package/dist/esm/components/carousel/DotsPaginationIndicator.d.ts.map +1 -0
  201. package/dist/esm/components/carousel/DotsPaginationIndicator.js +14 -0
  202. package/dist/esm/components/carousel/DotsPaginationIndicator.js.map +1 -0
  203. package/dist/esm/components/carousel/NavigationButton.d.ts +11 -0
  204. package/dist/esm/components/carousel/NavigationButton.d.ts.map +1 -0
  205. package/dist/esm/components/carousel/NavigationButton.js +186 -0
  206. package/dist/esm/components/carousel/NavigationButton.js.map +1 -0
  207. package/dist/esm/components/carousel/NumbersPagination.d.ts +10 -0
  208. package/dist/esm/components/carousel/NumbersPagination.d.ts.map +1 -0
  209. package/dist/esm/components/carousel/NumbersPagination.js +19 -0
  210. package/dist/esm/components/carousel/NumbersPagination.js.map +1 -0
  211. package/dist/esm/components/carousel/NumbersPaginationButton.d.ts +10 -0
  212. package/dist/esm/components/carousel/NumbersPaginationButton.d.ts.map +1 -0
  213. package/dist/esm/components/carousel/NumbersPaginationButton.js +14 -0
  214. package/dist/esm/components/carousel/NumbersPaginationButton.js.map +1 -0
  215. package/dist/esm/components/carousel/Slide.d.ts +13 -0
  216. package/dist/esm/components/carousel/Slide.d.ts.map +1 -0
  217. package/dist/esm/components/carousel/Slide.js +29 -0
  218. package/dist/esm/components/carousel/Slide.js.map +1 -0
  219. package/dist/esm/components/carousel/Thumbnail.d.ts +10 -0
  220. package/dist/esm/components/carousel/Thumbnail.d.ts.map +1 -0
  221. package/dist/esm/components/carousel/Thumbnail.js +10 -0
  222. package/dist/esm/components/carousel/Thumbnail.js.map +1 -0
  223. package/dist/esm/components/carousel/ThumbnailNavigationButton.d.ts +9 -0
  224. package/dist/esm/components/carousel/ThumbnailNavigationButton.d.ts.map +1 -0
  225. package/dist/esm/components/carousel/ThumbnailNavigationButton.js +186 -0
  226. package/dist/esm/components/carousel/ThumbnailNavigationButton.js.map +1 -0
  227. package/dist/esm/components/carousel/ThumbnailPagination.d.ts +12 -0
  228. package/dist/esm/components/carousel/ThumbnailPagination.d.ts.map +1 -0
  229. package/dist/esm/components/carousel/ThumbnailPagination.js +46 -0
  230. package/dist/esm/components/carousel/ThumbnailPagination.js.map +1 -0
  231. package/dist/esm/components/carousel/index.d.ts +36 -0
  232. package/dist/esm/components/carousel/index.d.ts.map +1 -0
  233. package/dist/esm/components/carousel/index.js +211 -0
  234. package/dist/esm/components/carousel/index.js.map +1 -0
  235. package/dist/esm/components/closeButton/index.d.ts +2 -2
  236. package/dist/esm/components/closeButton/index.d.ts.map +1 -1
  237. package/dist/esm/components/index.d.ts +4 -0
  238. package/dist/esm/components/index.d.ts.map +1 -1
  239. package/dist/esm/components/input/SearchField.js +185 -0
  240. package/dist/esm/components/input/SearchField.js.map +1 -0
  241. package/dist/esm/components/list/SearchableList.d.ts +20 -0
  242. package/dist/esm/components/list/SearchableList.d.ts.map +1 -0
  243. package/dist/esm/components/list/SearchableList.js +122 -0
  244. package/dist/esm/components/list/SearchableList.js.map +1 -0
  245. package/dist/esm/components/list/SearchableListItem.d.ts +26 -0
  246. package/dist/esm/components/list/SearchableListItem.d.ts.map +1 -0
  247. package/dist/esm/components/list/SearchableListItem.js +36 -0
  248. package/dist/esm/components/list/SearchableListItem.js.map +1 -0
  249. package/dist/esm/components/list/SearchableListItemLabel.d.ts +6 -0
  250. package/dist/esm/components/list/SearchableListItemLabel.d.ts.map +1 -0
  251. package/dist/esm/components/list/SearchableListItemLabel.js +184 -0
  252. package/dist/esm/components/list/SearchableListItemLabel.js.map +1 -0
  253. package/dist/esm/components/menu/index.d.ts.map +1 -1
  254. package/dist/esm/components/menu/index.js +1 -1
  255. package/dist/esm/components/menu/index.js.map +1 -1
  256. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionButton.js +1 -1
  257. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionButton.js.map +1 -1
  258. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionItem.d.ts.map +1 -1
  259. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionItem.js +2 -6
  260. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionItem.js.map +1 -1
  261. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionPanel.d.ts.map +1 -1
  262. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionPanel.js +1 -1
  263. package/dist/esm/components/mobileOnlyAccordion/MobileOnlyAccordionPanel.js.map +1 -1
  264. package/dist/esm/components/mobileOnlyAccordion/index.d.ts +1 -1
  265. package/dist/esm/components/mobileOnlyAccordion/index.d.ts.map +1 -1
  266. package/dist/esm/components/mobileOnlyAccordion/index.js.map +1 -1
  267. package/dist/esm/components/navigation/header/ComparisonItem.d.ts +11 -0
  268. package/dist/esm/components/navigation/header/ComparisonItem.d.ts.map +1 -0
  269. package/dist/esm/components/navigation/header/ComparisonItem.js +191 -0
  270. package/dist/esm/components/navigation/header/ComparisonItem.js.map +1 -0
  271. package/dist/esm/components/navigation/header/FavoritesItem.js +180 -0
  272. package/dist/esm/components/navigation/header/FavoritesItem.js.map +1 -0
  273. package/dist/esm/components/navigation/header/MobileMenuToggle.d.ts +11 -0
  274. package/dist/esm/components/navigation/header/MobileMenuToggle.d.ts.map +1 -0
  275. package/dist/esm/components/navigation/header/MobileMenuToggle.js +180 -0
  276. package/dist/esm/components/navigation/header/MobileMenuToggle.js.map +1 -0
  277. package/dist/esm/components/navigation/header/NavigationAvatar.d.ts +17 -0
  278. package/dist/esm/components/navigation/header/NavigationAvatar.d.ts.map +1 -0
  279. package/dist/esm/components/navigation/header/NavigationAvatar.js +33 -0
  280. package/dist/esm/components/navigation/header/NavigationAvatar.js.map +1 -0
  281. package/dist/esm/components/navigation/header/NavigationItem.d.ts +7 -0
  282. package/dist/esm/components/navigation/header/NavigationItem.d.ts.map +1 -0
  283. package/dist/esm/components/navigation/header/NavigationItem.js +19 -0
  284. package/dist/esm/components/navigation/header/NavigationItem.js.map +1 -0
  285. package/dist/esm/components/navigation/header/NavigationItems.d.ts +19 -0
  286. package/dist/esm/components/navigation/header/NavigationItems.d.ts.map +1 -0
  287. package/dist/esm/components/navigation/header/NavigationItems.js +34 -0
  288. package/dist/esm/components/navigation/header/NavigationItems.js.map +1 -0
  289. package/dist/esm/components/navigation/header/NavigationLanguageMenu.d.ts +8 -0
  290. package/dist/esm/components/navigation/header/NavigationLanguageMenu.d.ts.map +1 -0
  291. package/dist/esm/components/navigation/header/NavigationLanguageMenu.js +35 -0
  292. package/dist/esm/components/navigation/header/NavigationLanguageMenu.js.map +1 -0
  293. package/dist/esm/components/navigation/header/config/AutoRadar.d.ts +3 -0
  294. package/dist/esm/components/navigation/header/config/AutoRadar.d.ts.map +1 -0
  295. package/dist/esm/components/navigation/header/config/AutoRadar.js +205 -0
  296. package/dist/esm/components/navigation/header/config/AutoRadar.js.map +1 -0
  297. package/dist/esm/components/navigation/header/config/DrawerNodeItems.d.ts +40 -0
  298. package/dist/esm/components/navigation/header/config/DrawerNodeItems.d.ts.map +1 -0
  299. package/dist/esm/components/navigation/header/config/DrawerNodeItems.js +231 -0
  300. package/dist/esm/components/navigation/header/config/DrawerNodeItems.js.map +1 -0
  301. package/dist/esm/components/navigation/header/config/HeaderNavigationConfig.d.ts +90 -0
  302. package/dist/esm/components/navigation/header/config/HeaderNavigationConfig.d.ts.map +1 -0
  303. package/dist/esm/components/navigation/header/config/HeaderNavigationConfig.js +127 -0
  304. package/dist/esm/components/navigation/header/config/HeaderNavigationConfig.js.map +1 -0
  305. package/dist/esm/components/navigation/header/config/MarketPriceCheck.d.ts +4 -0
  306. package/dist/esm/components/navigation/header/config/MarketPriceCheck.d.ts.map +1 -0
  307. package/dist/esm/components/navigation/header/config/Optimizer.d.ts +3 -0
  308. package/dist/esm/components/navigation/header/config/Optimizer.d.ts.map +1 -0
  309. package/dist/esm/components/navigation/header/config/Optimizer.js +35 -0
  310. package/dist/esm/components/navigation/header/config/Optimizer.js.map +1 -0
  311. package/dist/esm/components/navigation/header/config/Presence.d.ts +8 -0
  312. package/dist/esm/components/navigation/header/config/Presence.d.ts.map +1 -0
  313. package/dist/esm/components/navigation/header/config/Presence.js +298 -0
  314. package/dist/esm/components/navigation/header/config/Presence.js.map +1 -0
  315. package/dist/esm/components/navigation/header/config/advertise.d.ts +3 -0
  316. package/dist/esm/components/navigation/header/config/advertise.d.ts.map +1 -0
  317. package/dist/esm/components/navigation/header/config/advertise.js +22 -0
  318. package/dist/esm/components/navigation/header/config/advertise.js.map +1 -0
  319. package/dist/esm/components/navigation/header/config/assure.d.ts +48 -0
  320. package/dist/esm/components/navigation/header/config/assure.d.ts.map +1 -0
  321. package/dist/esm/components/navigation/header/config/assure.js +63 -0
  322. package/dist/esm/components/navigation/header/config/assure.js.map +1 -0
  323. package/dist/esm/components/navigation/header/config/cockpit.d.ts +3 -0
  324. package/dist/esm/components/navigation/header/config/cockpit.d.ts.map +1 -0
  325. package/dist/esm/components/navigation/header/config/cockpit.js +23 -0
  326. package/dist/esm/components/navigation/header/config/cockpit.js.map +1 -0
  327. package/dist/esm/components/navigation/header/config/comparison.d.ts +34 -0
  328. package/dist/esm/components/navigation/header/config/comparison.d.ts.map +1 -0
  329. package/dist/esm/components/navigation/header/config/comparison.js +48 -0
  330. package/dist/esm/components/navigation/header/config/comparison.js.map +1 -0
  331. package/dist/esm/components/navigation/header/config/electroMobility.d.ts +25 -0
  332. package/dist/esm/components/navigation/header/config/electroMobility.d.ts.map +1 -0
  333. package/dist/esm/components/navigation/header/config/electroMobility.js +34 -0
  334. package/dist/esm/components/navigation/header/config/electroMobility.js.map +1 -0
  335. package/dist/esm/components/navigation/header/config/estimate.d.ts +25 -0
  336. package/dist/esm/components/navigation/header/config/estimate.d.ts.map +1 -0
  337. package/dist/esm/components/navigation/header/config/estimate.js +34 -0
  338. package/dist/esm/components/navigation/header/config/estimate.js.map +1 -0
  339. package/dist/esm/components/navigation/header/config/hci.d.ts +3 -0
  340. package/dist/esm/components/navigation/header/config/hci.d.ts.map +1 -0
  341. package/dist/esm/components/navigation/header/config/hci.js +23 -0
  342. package/dist/esm/components/navigation/header/config/hci.js.map +1 -0
  343. package/dist/esm/components/navigation/header/config/headerLinks.d.ts +27 -0
  344. package/dist/esm/components/navigation/header/config/headerLinks.d.ts.map +1 -0
  345. package/dist/esm/components/navigation/header/config/headerLinks.js +22 -0
  346. package/dist/esm/components/navigation/header/config/headerLinks.js.map +1 -0
  347. package/dist/esm/components/navigation/header/config/headerNavigationLink.d.ts +38 -0
  348. package/dist/esm/components/navigation/header/config/headerNavigationLink.d.ts.map +1 -0
  349. package/dist/esm/components/navigation/header/config/headerNavigationLink.js +36 -0
  350. package/dist/esm/components/navigation/header/config/headerNavigationLink.js.map +1 -0
  351. package/dist/esm/components/navigation/header/config/iconItems.d.ts +10 -0
  352. package/dist/esm/components/navigation/header/config/iconItems.d.ts.map +1 -0
  353. package/dist/esm/components/navigation/header/config/iconItems.js +26 -0
  354. package/dist/esm/components/navigation/header/config/iconItems.js.map +1 -0
  355. package/dist/esm/components/navigation/header/config/infoPortal.d.ts +3 -0
  356. package/dist/esm/components/navigation/header/config/infoPortal.d.ts.map +1 -0
  357. package/dist/esm/components/navigation/header/config/infoPortal.js +22 -0
  358. package/dist/esm/components/navigation/header/config/infoPortal.js.map +1 -0
  359. package/dist/esm/components/navigation/header/config/insuranceComparison.d.ts +25 -0
  360. package/dist/esm/components/navigation/header/config/insuranceComparison.d.ts.map +1 -0
  361. package/dist/esm/components/navigation/header/config/insuranceComparison.js +57 -0
  362. package/dist/esm/components/navigation/header/config/insuranceComparison.js.map +1 -0
  363. package/dist/esm/components/navigation/header/config/language.d.ts +12 -0
  364. package/dist/esm/components/navigation/header/config/language.d.ts.map +1 -0
  365. package/dist/esm/components/navigation/header/config/language.js +71 -0
  366. package/dist/esm/components/navigation/header/config/language.js.map +1 -0
  367. package/dist/esm/components/navigation/header/config/leadsManagement.d.ts +3 -0
  368. package/dist/esm/components/navigation/header/config/leadsManagement.d.ts.map +1 -0
  369. package/dist/esm/components/navigation/header/config/leadsManagement.js +22 -0
  370. package/dist/esm/components/navigation/header/config/leadsManagement.js.map +1 -0
  371. package/dist/esm/components/navigation/header/config/magazine.d.ts +25 -0
  372. package/dist/esm/components/navigation/header/config/magazine.d.ts.map +1 -0
  373. package/dist/esm/components/navigation/header/config/magazine.js +34 -0
  374. package/dist/esm/components/navigation/header/config/magazine.js.map +1 -0
  375. package/dist/esm/components/navigation/header/config/marketPriceCheckConfig.d.ts +3 -0
  376. package/dist/esm/components/navigation/header/config/marketPriceCheckConfig.d.ts.map +1 -0
  377. package/dist/esm/components/navigation/header/config/marketPriceCheckConfig.js +29 -0
  378. package/dist/esm/components/navigation/header/config/marketPriceCheckConfig.js.map +1 -0
  379. package/dist/esm/components/navigation/header/config/partnerHub.d.ts +22 -0
  380. package/dist/esm/components/navigation/header/config/partnerHub.d.ts.map +1 -0
  381. package/dist/esm/components/navigation/header/config/partnerHub.js +25 -0
  382. package/dist/esm/components/navigation/header/config/partnerHub.js.map +1 -0
  383. package/dist/esm/components/navigation/header/config/print.d.ts +3 -0
  384. package/dist/esm/components/navigation/header/config/print.d.ts.map +1 -0
  385. package/dist/esm/components/navigation/header/config/print.js +22 -0
  386. package/dist/esm/components/navigation/header/config/print.js.map +1 -0
  387. package/dist/esm/components/navigation/header/config/search.d.ts +8 -0
  388. package/dist/esm/components/navigation/header/config/search.d.ts.map +1 -0
  389. package/dist/esm/components/navigation/header/config/search.js +124 -0
  390. package/dist/esm/components/navigation/header/config/search.js.map +1 -0
  391. package/dist/esm/components/navigation/header/config/sell.d.ts +77 -0
  392. package/dist/esm/components/navigation/header/config/sell.d.ts.map +1 -0
  393. package/dist/esm/components/navigation/header/config/sell.js +94 -0
  394. package/dist/esm/components/navigation/header/config/sell.js.map +1 -0
  395. package/dist/esm/components/navigation/header/config/templates.d.ts +4 -0
  396. package/dist/esm/components/navigation/header/config/templates.d.ts.map +1 -0
  397. package/dist/esm/components/navigation/header/config/templates.js +41 -0
  398. package/dist/esm/components/navigation/header/config/templates.js.map +1 -0
  399. package/dist/esm/components/navigation/header/config/topListing.d.ts +3 -0
  400. package/dist/esm/components/navigation/header/config/topListing.d.ts.map +1 -0
  401. package/dist/esm/components/navigation/header/config/topListing.js +31 -0
  402. package/dist/esm/components/navigation/header/config/topListing.js.map +1 -0
  403. package/dist/esm/components/navigation/header/config/topVehicles.d.ts +4 -0
  404. package/dist/esm/components/navigation/header/config/topVehicles.d.ts.map +1 -0
  405. package/dist/esm/components/navigation/header/config/topVehicles.js +41 -0
  406. package/dist/esm/components/navigation/header/config/topVehicles.js.map +1 -0
  407. package/dist/esm/components/navigation/header/config/user.d.ts +13 -0
  408. package/dist/esm/components/navigation/header/config/user.d.ts.map +1 -0
  409. package/dist/esm/components/navigation/header/config/user.js +112 -0
  410. package/dist/esm/components/navigation/header/config/user.js.map +1 -0
  411. package/dist/esm/components/navigation/header/config/vehiclePool.d.ts +6 -0
  412. package/dist/esm/components/navigation/header/config/vehiclePool.d.ts.map +1 -0
  413. package/dist/esm/components/navigation/header/config/vehiclePool.js +83 -0
  414. package/dist/esm/components/navigation/header/config/vehiclePool.js.map +1 -0
  415. package/dist/esm/components/navigation/header/drawer/DrawerIndicator.d.ts +5 -0
  416. package/dist/esm/components/navigation/header/drawer/DrawerIndicator.d.ts.map +1 -0
  417. package/dist/esm/components/navigation/header/drawer/DrawerIndicator.js +177 -0
  418. package/dist/esm/components/navigation/header/drawer/DrawerIndicator.js.map +1 -0
  419. package/dist/esm/components/navigation/header/drawer/DrawerLoginToggle.d.ts +10 -0
  420. package/dist/esm/components/navigation/header/drawer/DrawerLoginToggle.d.ts.map +1 -0
  421. package/dist/esm/components/navigation/header/drawer/DrawerLoginToggle.js +180 -0
  422. package/dist/esm/components/navigation/header/drawer/DrawerLoginToggle.js.map +1 -0
  423. package/dist/esm/components/navigation/header/drawer/DrawerMenu.d.ts +6 -0
  424. package/dist/esm/components/navigation/header/drawer/DrawerMenu.d.ts.map +1 -0
  425. package/dist/esm/components/navigation/header/drawer/DrawerMenu.js +13 -0
  426. package/dist/esm/components/navigation/header/drawer/DrawerMenu.js.map +1 -0
  427. package/dist/esm/components/navigation/header/drawer/DrawerNavigationLink.d.ts +6 -0
  428. package/dist/esm/components/navigation/header/drawer/DrawerNavigationLink.d.ts.map +1 -0
  429. package/dist/esm/components/navigation/header/drawer/DrawerNavigationLink.js +20 -0
  430. package/dist/esm/components/navigation/header/drawer/DrawerNavigationLink.js.map +1 -0
  431. package/dist/esm/components/navigation/header/drawer/DrawerSections.d.ts +9 -0
  432. package/dist/esm/components/navigation/header/drawer/DrawerSections.d.ts.map +1 -0
  433. package/dist/esm/components/navigation/header/drawer/DrawerSections.js +35 -0
  434. package/dist/esm/components/navigation/header/drawer/DrawerSections.js.map +1 -0
  435. package/dist/esm/components/navigation/header/drawer/index.d.ts +17 -0
  436. package/dist/esm/components/navigation/header/drawer/index.d.ts.map +1 -0
  437. package/dist/esm/components/navigation/header/drawer/index.js +39 -0
  438. package/dist/esm/components/navigation/header/drawer/index.js.map +1 -0
  439. package/dist/esm/components/navigation/header/drawer/userInfo/SelectedTenantInfo.d.ts +9 -0
  440. package/dist/esm/components/navigation/header/drawer/userInfo/SelectedTenantInfo.d.ts.map +1 -0
  441. package/dist/esm/components/navigation/header/drawer/userInfo/SelectedTenantInfo.js +190 -0
  442. package/dist/esm/components/navigation/header/drawer/userInfo/SelectedTenantInfo.js.map +1 -0
  443. package/dist/esm/components/navigation/header/drawer/userInfo/TenantSelectionMenu.d.ts +11 -0
  444. package/dist/esm/components/navigation/header/drawer/userInfo/TenantSelectionMenu.d.ts.map +1 -0
  445. package/dist/esm/components/navigation/header/drawer/userInfo/TenantSelectionMenu.js +22 -0
  446. package/dist/esm/components/navigation/header/drawer/userInfo/TenantSelectionMenu.js.map +1 -0
  447. package/dist/esm/components/navigation/header/drawer/userInfo/index.d.ts +10 -0
  448. package/dist/esm/components/navigation/header/drawer/userInfo/index.d.ts.map +1 -0
  449. package/dist/esm/components/navigation/header/drawer/userInfo/index.js +49 -0
  450. package/dist/esm/components/navigation/header/drawer/userInfo/index.js.map +1 -0
  451. package/dist/esm/components/navigation/header/hooks/useNavigationDrawer.d.ts +26 -0
  452. package/dist/esm/components/navigation/header/hooks/useNavigationDrawer.d.ts.map +1 -0
  453. package/dist/esm/components/navigation/header/hooks/useNavigationDrawer.js +48 -0
  454. package/dist/esm/components/navigation/header/hooks/useNavigationDrawer.js.map +1 -0
  455. package/dist/esm/components/navigation/header/index.d.ts +28 -0
  456. package/dist/esm/components/navigation/header/index.d.ts.map +1 -0
  457. package/dist/esm/components/navigation/header/index.js +91 -0
  458. package/dist/esm/components/navigation/header/index.js.map +1 -0
  459. package/dist/esm/components/navigation/header/links/HeaderLink.d.ts +6 -0
  460. package/dist/esm/components/navigation/header/links/HeaderLink.d.ts.map +1 -0
  461. package/dist/esm/components/navigation/header/links/HeaderLink.js +13 -0
  462. package/dist/esm/components/navigation/header/links/HeaderLink.js.map +1 -0
  463. package/dist/esm/components/navigation/header/links/NavigationLink.d.ts +23 -0
  464. package/dist/esm/components/navigation/header/links/NavigationLink.d.ts.map +1 -0
  465. package/dist/esm/components/navigation/header/links/NavigationLink.js +21 -0
  466. package/dist/esm/components/navigation/header/links/NavigationLink.js.map +1 -0
  467. package/dist/esm/components/navigation/header/navigationTenantMenu/Content.d.ts +12 -0
  468. package/dist/esm/components/navigation/header/navigationTenantMenu/Content.d.ts.map +1 -0
  469. package/dist/esm/components/navigation/header/navigationTenantMenu/Content.js +35 -0
  470. package/dist/esm/components/navigation/header/navigationTenantMenu/Content.js.map +1 -0
  471. package/dist/esm/components/navigation/header/navigationTenantMenu/Loading.d.ts +3 -0
  472. package/dist/esm/components/navigation/header/navigationTenantMenu/Loading.d.ts.map +1 -0
  473. package/dist/esm/components/navigation/header/navigationTenantMenu/Loading.js +11 -0
  474. package/dist/esm/components/navigation/header/navigationTenantMenu/Loading.js.map +1 -0
  475. package/dist/esm/components/navigation/header/navigationTenantMenu/index.d.ts +9 -0
  476. package/dist/esm/components/navigation/header/navigationTenantMenu/index.d.ts.map +1 -0
  477. package/dist/esm/components/navigation/header/navigationTenantMenu/index.js +211 -0
  478. package/dist/esm/components/navigation/header/navigationTenantMenu/index.js.map +1 -0
  479. package/dist/esm/components/navigation/header/replaceLanguage.d.ts +6 -0
  480. package/dist/esm/components/navigation/header/replaceLanguage.d.ts.map +1 -0
  481. package/dist/esm/components/navigation/header/replaceLanguage.js +8 -0
  482. package/dist/esm/components/navigation/header/replaceLanguage.js.map +1 -0
  483. package/dist/esm/components/navigation/header/types.js +7 -0
  484. package/dist/esm/components/navigation/header/types.js.map +1 -0
  485. package/dist/esm/components/spinner/index.js +10 -0
  486. package/dist/esm/components/spinner/index.js.map +1 -0
  487. package/dist/esm/components/tenantSelection/Container.d.ts +6 -0
  488. package/dist/esm/components/tenantSelection/Container.d.ts.map +1 -0
  489. package/dist/esm/components/tenantSelection/Container.js +12 -0
  490. package/dist/esm/components/tenantSelection/Container.js.map +1 -0
  491. package/dist/esm/components/tenantSelection/Loading.d.ts +3 -0
  492. package/dist/esm/components/tenantSelection/Loading.d.ts.map +1 -0
  493. package/dist/esm/components/tenantSelection/Loading.js +13 -0
  494. package/dist/esm/components/tenantSelection/Loading.js.map +1 -0
  495. package/dist/esm/components/tenantSelection/ModalLayout.d.ts +3 -0
  496. package/dist/esm/components/tenantSelection/ModalLayout.d.ts.map +1 -0
  497. package/dist/esm/components/tenantSelection/ModalLayout.js +12 -0
  498. package/dist/esm/components/tenantSelection/ModalLayout.js.map +1 -0
  499. package/dist/esm/components/tenantSelection/Overview.d.ts +12 -0
  500. package/dist/esm/components/tenantSelection/Overview.d.ts.map +1 -0
  501. package/dist/esm/components/tenantSelection/Overview.js +40 -0
  502. package/dist/esm/components/tenantSelection/Overview.js.map +1 -0
  503. package/dist/esm/components/tenantSelection/__tests__/createTenantLabel.test.d.ts +2 -0
  504. package/dist/esm/components/tenantSelection/__tests__/createTenantLabel.test.d.ts.map +1 -0
  505. package/dist/esm/components/tenantSelection/createTenantLabel.d.ts +5 -0
  506. package/dist/esm/components/tenantSelection/createTenantLabel.d.ts.map +1 -0
  507. package/dist/esm/components/tenantSelection/createTenantLabel.js +12 -0
  508. package/dist/esm/components/tenantSelection/createTenantLabel.js.map +1 -0
  509. package/dist/esm/components/tenantSelection/index.d.ts +16 -0
  510. package/dist/esm/components/tenantSelection/index.d.ts.map +1 -0
  511. package/dist/esm/components/tenantSelection/index.js +29 -0
  512. package/dist/esm/components/tenantSelection/index.js.map +1 -0
  513. package/dist/esm/components/tenantSelection/select/List.d.ts +13 -0
  514. package/dist/esm/components/tenantSelection/select/List.d.ts.map +1 -0
  515. package/dist/esm/components/tenantSelection/select/List.js +27 -0
  516. package/dist/esm/components/tenantSelection/select/List.js.map +1 -0
  517. package/dist/esm/components/tenantSelection/select/index.d.ts +11 -0
  518. package/dist/esm/components/tenantSelection/select/index.d.ts.map +1 -0
  519. package/dist/esm/components/tenantSelection/select/index.js +20 -0
  520. package/dist/esm/components/tenantSelection/select/index.js.map +1 -0
  521. package/dist/esm/components/tenantSelection/tenantSelectionIllustration.png.js +4 -0
  522. package/dist/esm/components/tenantSelection/tenantSelectionIllustration.png.js.map +1 -0
  523. package/dist/esm/components/themeProvider/index.js +1 -0
  524. package/dist/esm/components/themeProvider/index.js.map +1 -1
  525. package/dist/esm/hooks/useToast/Toast.d.ts +12 -0
  526. package/dist/esm/hooks/useToast/Toast.d.ts.map +1 -0
  527. package/dist/esm/hooks/useToast/TopRightToast.d.ts +4 -0
  528. package/dist/esm/hooks/useToast/TopRightToast.d.ts.map +1 -0
  529. package/dist/esm/hooks/useToast/TopToaster.d.ts +4 -0
  530. package/dist/esm/hooks/useToast/TopToaster.d.ts.map +1 -0
  531. package/dist/esm/hooks/useToast/index.d.ts +9 -0
  532. package/dist/esm/hooks/useToast/index.d.ts.map +1 -0
  533. package/dist/esm/index.js +5 -0
  534. package/dist/esm/index.js.map +1 -1
  535. package/dist/esm/node_modules/tslib/tslib.es6.js +49 -1
  536. package/dist/esm/node_modules/tslib/tslib.es6.js.map +1 -1
  537. package/dist/esm/themes/shared/animationStyles.d.ts.map +1 -1
  538. package/dist/esm/themes/shared/animationStyles.js +10 -0
  539. package/dist/esm/themes/shared/animationStyles.js.map +1 -1
  540. package/dist/esm/themes/shared/index.d.ts +31 -0
  541. package/dist/esm/themes/shared/index.d.ts.map +1 -1
  542. package/dist/esm/themes/shared/keyframes.d.ts.map +1 -1
  543. package/dist/esm/themes/shared/keyframes.js +8 -0
  544. package/dist/esm/themes/shared/keyframes.js.map +1 -1
  545. package/dist/esm/themes/shared/slotRecipes/alert.d.ts +16 -0
  546. package/dist/esm/themes/shared/slotRecipes/alert.d.ts.map +1 -1
  547. package/dist/esm/themes/shared/slotRecipes/alert.js +19 -0
  548. package/dist/esm/themes/shared/slotRecipes/alert.js.map +1 -1
  549. package/dist/esm/themes/shared/slotRecipes/carousel.d.ts +16 -0
  550. package/dist/esm/themes/shared/slotRecipes/carousel.d.ts.map +1 -0
  551. package/dist/esm/themes/shared/slotRecipes/carousel.js +229 -0
  552. package/dist/esm/themes/shared/slotRecipes/carousel.js.map +1 -0
  553. package/dist/esm/themes/shared/slotRecipes/index.d.ts +31 -0
  554. package/dist/esm/themes/shared/slotRecipes/index.d.ts.map +1 -1
  555. package/dist/esm/themes/shared/slotRecipes/index.js +2 -0
  556. package/dist/esm/themes/shared/slotRecipes/index.js.map +1 -1
  557. package/dist/esm/themes/shared/slotRecipes/menu.d.ts.map +1 -1
  558. package/dist/esm/themes/shared/slotRecipes/menu.js +8 -0
  559. package/dist/esm/themes/shared/slotRecipes/menu.js.map +1 -1
  560. package/dist/esm/types/entitlements.js +14 -0
  561. package/dist/esm/types/entitlements.js.map +1 -0
  562. package/dist/esm/types/tracking.js +4 -0
  563. package/dist/esm/types/tracking.js.map +1 -0
  564. package/dist/esm/utilities/replacePathParameters.js +23 -0
  565. package/dist/esm/utilities/replacePathParameters.js.map +1 -0
  566. package/dist/index.d.ts +149 -27
  567. package/package.json +1 -1
package/dist/cjs/index.js CHANGED
@@ -5,6 +5,9 @@ var react = require('@emotion/react');
5
5
  var useDebounce = require('use-debounce');
6
6
  var React = require('react');
7
7
  var i18nPkg = require('@smg-automotive/i18n-pkg');
8
+ var Fuse = require('fuse.js');
9
+ var auth$4 = require('@smg-automotive/auth');
10
+ var useEmblaCarousel = require('embla-carousel-react');
8
11
 
9
12
  var zIndex = react$1.defineTokens.zIndex({
10
13
  hide: { value: -1 },
@@ -1058,6 +1061,54 @@ function __rest(s, e) {
1058
1061
  return t;
1059
1062
  }
1060
1063
 
1064
+ function __awaiter(thisArg, _arguments, P, generator) {
1065
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
1066
+ return new (P || (P = Promise))(function (resolve, reject) {
1067
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
1068
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
1069
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
1070
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
1071
+ });
1072
+ }
1073
+
1074
+ function __generator(thisArg, body) {
1075
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
1076
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
1077
+ function verb(n) { return function (v) { return step([n, v]); }; }
1078
+ function step(op) {
1079
+ if (f) throw new TypeError("Generator is already executing.");
1080
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
1081
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
1082
+ if (y = 0, t) op = [op[0] & 2, t.value];
1083
+ switch (op[0]) {
1084
+ case 0: case 1: t = op; break;
1085
+ case 4: _.label++; return { value: op[1], done: false };
1086
+ case 5: _.label++; y = op[1]; op = [0]; continue;
1087
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
1088
+ default:
1089
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
1090
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
1091
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
1092
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
1093
+ if (t[2]) _.ops.pop();
1094
+ _.trys.pop(); continue;
1095
+ }
1096
+ op = body.call(thisArg, _);
1097
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
1098
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
1099
+ }
1100
+ }
1101
+
1102
+ function __spreadArray(to, from, pack) {
1103
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
1104
+ if (ar || !(i in from)) {
1105
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
1106
+ ar[i] = from[i];
1107
+ }
1108
+ }
1109
+ return to.concat(ar || Array.prototype.slice.call(from));
1110
+ }
1111
+
1061
1112
  typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
1062
1113
  var e = new Error(message);
1063
1114
  return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
@@ -1573,6 +1624,14 @@ var content = react$1.defineStyle({
1573
1624
  _focusVisible: {
1574
1625
  outline: 'none',
1575
1626
  },
1627
+ _open: {
1628
+ animationStyle: 'scale-fade-in',
1629
+ animationDuration: 'fast',
1630
+ },
1631
+ _closed: {
1632
+ animationStyle: 'scale-fade-out',
1633
+ animationDuration: 'fast',
1634
+ },
1576
1635
  });
1577
1636
  var item = react$1.defineStyle({
1578
1637
  display: 'flex',
@@ -1732,14 +1791,14 @@ var baseStyleCloseContainer = react$1.defineStyle({
1732
1791
  alignItems: 'center',
1733
1792
  justifyContent: 'flex-end',
1734
1793
  });
1735
- var slots$1 = [
1794
+ var slots$2 = [
1736
1795
  'container',
1737
1796
  'grid',
1738
1797
  'countContainer',
1739
1798
  'closeContainer',
1740
1799
  ];
1741
1800
  var galleryHeaderRecipe = react$1.defineSlotRecipe({
1742
- slots: slots$1,
1801
+ slots: slots$2,
1743
1802
  className: 'chakra-gallery-header',
1744
1803
  base: {
1745
1804
  container: baseStyleContainer,
@@ -2256,7 +2315,7 @@ var sizeContent = function (w) {
2256
2315
  borderRadius: { base: 'none', sm: 'sm' },
2257
2316
  });
2258
2317
  };
2259
- var slots = [
2318
+ var slots$1 = [
2260
2319
  'header',
2261
2320
  'body',
2262
2321
  'footer',
@@ -2266,7 +2325,7 @@ var slots = [
2266
2325
  'closeTrigger',
2267
2326
  ];
2268
2327
  var dialogRecipe = react$1.defineSlotRecipe({
2269
- slots: slots,
2328
+ slots: slots$1,
2270
2329
  className: 'chakra-dialog',
2271
2330
  base: {
2272
2331
  positioner: baseStyleDialogContainer,
@@ -2463,6 +2522,230 @@ var checkboxRecipe = react$1.defineSlotRecipe({
2463
2522
  },
2464
2523
  });
2465
2524
 
2525
+ var slots = [
2526
+ 'container',
2527
+ 'carousel',
2528
+ 'slide',
2529
+ 'slideContainer',
2530
+ 'buttonContainer',
2531
+ 'button',
2532
+ 'icon',
2533
+ 'pagination',
2534
+ 'paginationButton',
2535
+ 'paginationIconContainer',
2536
+ 'dotsPaginationContainer',
2537
+ 'dotsPaginationIndicator',
2538
+ 'dotsPaginationIndicatorActive',
2539
+ 'numbersPaginationButton',
2540
+ 'numbersPaginationButtonActive',
2541
+ ];
2542
+ var baseContainer = react$1.defineStyle({
2543
+ height: 'full',
2544
+ width: 'full',
2545
+ '--carousel-overlay-weak': 'rgba(51,51,51,0.4)',
2546
+ '--carousel-overlay-strong': 'rgba(51,51,51,0.8)',
2547
+ '--carousel-pagination-height': '7.5rem',
2548
+ '--carousel-numbers-pagination-height': '5rem',
2549
+ '--carousel-dot-size': '6px',
2550
+ '--carousel-dot-size-active': '8px',
2551
+ '--carousel-dot-size-last': '4px',
2552
+ '--carousel-dot-margin-x': '6px',
2553
+ });
2554
+ var baseCarousel = react$1.defineStyle({
2555
+ overflow: 'hidden',
2556
+ position: 'relative',
2557
+ });
2558
+ var baseSlide = react$1.defineStyle({
2559
+ flexGrow: '0',
2560
+ flexShrink: '0',
2561
+ flexBasis: 'full',
2562
+ });
2563
+ var baseSlideContainer = react$1.defineStyle({
2564
+ height: 'full',
2565
+ alignItems: 'center',
2566
+ display: 'flex',
2567
+ });
2568
+ var baseButtonContainer = react$1.defineStyle({
2569
+ position: 'absolute',
2570
+ top: '0',
2571
+ width: 'lg',
2572
+ height: 'full',
2573
+ display: 'flex',
2574
+ justifyContent: 'center',
2575
+ alignItems: 'center',
2576
+ color: 'white',
2577
+ visibility: 'hidden',
2578
+ pointerEvents: 'none',
2579
+ cursor: 'pointer',
2580
+ _groupHover: { md: { visibility: 'visible', pointerEvents: 'auto' } },
2581
+ _focus: {
2582
+ outline: 'none',
2583
+ },
2584
+ });
2585
+ var baseButton = react$1.defineStyle({
2586
+ display: 'flex',
2587
+ justifyContent: 'center',
2588
+ alignItems: 'center',
2589
+ width: 'md',
2590
+ height: 'md',
2591
+ borderRadius: 'sm',
2592
+ backgroundColor: 'var(--carousel-overlay-weak)',
2593
+ color: 'white',
2594
+ _hover: { background: 'var(--carousel-overlay-strong)' },
2595
+ });
2596
+ var baseIcon = react$1.defineStyle({
2597
+ boxSize: 'sm',
2598
+ });
2599
+ var numbersPaginationButton = react$1.defineStyle({
2600
+ display: 'inline-flex',
2601
+ alignItems: 'center',
2602
+ justifyContent: 'center',
2603
+ verticalAlign: 'middle',
2604
+ textAlign: 'center',
2605
+ minWidth: 'md',
2606
+ height: 'md',
2607
+ borderRadius: 'sm',
2608
+ _hover: {
2609
+ backgroundColor: 'gray.100',
2610
+ },
2611
+ });
2612
+ var numbersPaginationButtonActive = react$1.defineStyle(__assign(__assign({}, numbersPaginationButton), { color: 'white', backgroundColor: 'gray.900', _hover: {
2613
+ backgroundColor: 'gray.900',
2614
+ } }));
2615
+ var dotsPaginationIndicator = react$1.defineStyle({
2616
+ backgroundColor: 'transparent',
2617
+ touchAction: 'pan-x',
2618
+ display: 'inline-flex',
2619
+ textDecoration: 'none',
2620
+ border: 'none',
2621
+ padding: '0',
2622
+ width: 'var(--carousel-dot-size)',
2623
+ height: 'var(--carousel-dot-size)',
2624
+ marginX: 'var(--carousel-dot-margin-x)',
2625
+ _last: {
2626
+ width: 'var(--carousel-dot-size-last)',
2627
+ height: 'var(--carousel-dot-size-last)',
2628
+ _after: {
2629
+ width: 'full',
2630
+ height: 'var(--carousel-dot-size-last)',
2631
+ content: '""',
2632
+ },
2633
+ },
2634
+ _after: {
2635
+ backgroundColor: 'gray.300',
2636
+ opacity: '40',
2637
+ borderRadius: 'full',
2638
+ width: 'full',
2639
+ height: 'var(--carousel-dot-size)',
2640
+ content: '""',
2641
+ },
2642
+ });
2643
+ var dotsPaginationIndicatorActive = react$1.defineStyle(__assign(__assign({}, dotsPaginationIndicator), { width: 'var(--carousel-dot-size-active)', height: 'var(--carousel-dot-size-active)', _last: {
2644
+ width: 'var(--carousel-dot-size-active)',
2645
+ height: 'var(--carousel-dot-size-active)',
2646
+ _after: {
2647
+ width: 'full',
2648
+ height: 'var(--carousel-dot-size-active)',
2649
+ content: '""',
2650
+ },
2651
+ }, _after: {
2652
+ backgroundColor: 'white',
2653
+ borderRadius: 'full',
2654
+ opacity: '100',
2655
+ width: 'full',
2656
+ height: 'var(--carousel-dot-size-active)',
2657
+ content: '""',
2658
+ } }));
2659
+ var fullScreenVariant = {
2660
+ container: react$1.defineStyle({
2661
+ backgroundColor: 'black',
2662
+ position: {
2663
+ base: 'fixed',
2664
+ md: 'static',
2665
+ },
2666
+ }),
2667
+ carousel: react$1.defineStyle({
2668
+ paddingX: {
2669
+ md: '5xl',
2670
+ },
2671
+ }),
2672
+ pagination: react$1.defineStyle({
2673
+ overflow: 'hidden',
2674
+ position: 'relative',
2675
+ paddingX: {
2676
+ base: 'md',
2677
+ md: '5xl',
2678
+ },
2679
+ height: 'var(--carousel-pagination-height)',
2680
+ }),
2681
+ paginationButton: react$1.defineStyle({
2682
+ position: 'absolute',
2683
+ top: '0',
2684
+ width: 'lg',
2685
+ height: 'full',
2686
+ display: 'flex',
2687
+ justifyContent: 'center',
2688
+ alignItems: 'center',
2689
+ color: 'white',
2690
+ backgroundColor: 'transparent',
2691
+ }),
2692
+ paginationIconContainer: react$1.defineStyle({
2693
+ display: 'flex',
2694
+ justifyContent: 'center',
2695
+ alignItems: 'center',
2696
+ width: 'md',
2697
+ height: 'md',
2698
+ borderRadius: 'sm',
2699
+ backgroundColor: 'var(--carousel-overlay-strong)',
2700
+ }),
2701
+ buttonContainer: react$1.defineStyle({
2702
+ backgroundColor: 'black',
2703
+ width: 'xl',
2704
+ visibility: { base: 'hidden', md: 'visible' },
2705
+ pointerEvents: { base: 'none', md: 'auto' },
2706
+ }),
2707
+ slide: react$1.defineStyle({
2708
+ height: 'full',
2709
+ }),
2710
+ button: react$1.defineStyle({
2711
+ opacity: '100',
2712
+ backgroundColor: 'black',
2713
+ }),
2714
+ icon: react$1.defineStyle({
2715
+ boxSize: 'md',
2716
+ }),
2717
+ };
2718
+ var carouselRecipe = react$1.defineSlotRecipe({
2719
+ slots: slots,
2720
+ className: 'chakra-carousel',
2721
+ base: {
2722
+ container: baseContainer,
2723
+ carousel: baseCarousel,
2724
+ slide: baseSlide,
2725
+ slideContainer: baseSlideContainer,
2726
+ buttonContainer: baseButtonContainer,
2727
+ button: baseButton,
2728
+ icon: baseIcon,
2729
+ numbersPaginationButton: numbersPaginationButton,
2730
+ numbersPaginationButtonActive: numbersPaginationButtonActive,
2731
+ dotsPaginationContainer: react$1.defineStyle({
2732
+ position: 'absolute',
2733
+ width: 'full',
2734
+ bottom: 'lg',
2735
+ display: 'flex',
2736
+ justifyContent: 'center',
2737
+ alignItems: 'center',
2738
+ }),
2739
+ dotsPaginationIndicator: dotsPaginationIndicator,
2740
+ dotsPaginationIndicatorActive: dotsPaginationIndicatorActive,
2741
+ },
2742
+ variants: {
2743
+ variant: {
2744
+ fullScreen: fullScreenVariant,
2745
+ },
2746
+ },
2747
+ });
2748
+
2466
2749
  var cardRecipe = react$1.defineSlotRecipe({
2467
2750
  className: 'chakra-card',
2468
2751
  slots: ['root', 'header', 'body', 'footer'],
@@ -2591,6 +2874,25 @@ var alertRecipe = react$1.defineSlotRecipe({
2591
2874
  },
2592
2875
  },
2593
2876
  },
2877
+ variant: {
2878
+ toast: {
2879
+ root: {
2880
+ translate: 'var(--x) var(--y)',
2881
+ scale: 'var(--scale)',
2882
+ width: 'full',
2883
+ position: 'relative',
2884
+ zIndex: 'var(--z-index)',
2885
+ height: 'var(--height)',
2886
+ opacity: 'var(--opacity)',
2887
+ willChange: 'translate, opacity, scale',
2888
+ transitionProperty: 'common',
2889
+ transitionDuration: 'normal',
2890
+ },
2891
+ },
2892
+ },
2893
+ },
2894
+ defaultVariants: {
2895
+ variant: 'toast',
2594
2896
  },
2595
2897
  });
2596
2898
 
@@ -2715,6 +3017,7 @@ var accordionRecipe = react$1.defineSlotRecipe({
2715
3017
  var slotRecipes = {
2716
3018
  articleTeaser: articleTeaserRecipe,
2717
3019
  accordion: accordionRecipe,
3020
+ carousel: carouselRecipe,
2718
3021
  breadcrumbs: breadcrumbsRecipe,
2719
3022
  card: cardRecipe,
2720
3023
  energyLabel: energyLabelRecipe,
@@ -3144,6 +3447,14 @@ var keyframes = react$1.defineKeyframes({
3144
3447
  from: { height: 'var(--height)' },
3145
3448
  to: { height: '0' },
3146
3449
  },
3450
+ 'slide-in-top': {
3451
+ from: { transform: 'translateY(-100%)' },
3452
+ to: { transform: 'translateY(0)' },
3453
+ },
3454
+ 'slide-out-top': {
3455
+ from: { transform: 'translateY(0)' },
3456
+ to: { transform: 'translateY(-100%)' },
3457
+ },
3147
3458
  'fade-in': {
3148
3459
  from: { opacity: 0 },
3149
3460
  to: { opacity: 1 },
@@ -3275,6 +3586,16 @@ var animationStyles = react$1.defineAnimationStyles({
3275
3586
  animationName: ['scale-out', 'fade-out'],
3276
3587
  },
3277
3588
  },
3589
+ 'slide-fade-in-top': {
3590
+ value: {
3591
+ animationName: ['fade-in'],
3592
+ },
3593
+ },
3594
+ 'slide-fade-out-top': {
3595
+ value: {
3596
+ animationName: ['fade-out'],
3597
+ },
3598
+ },
3278
3599
  });
3279
3600
 
3280
3601
  var getSharedConfig = function () { return ({
@@ -6706,11 +7027,11 @@ var PageLayout = function (_a) {
6706
7027
  return (React.createElement(BaseLayout, { header: header, footer: footer, skyScraperAd: skyScraperAd, heroAd: heroAd, maxContentWidth: maxContentWidth }, children));
6707
7028
  };
6708
7029
 
6709
- var img$4 = "";
7030
+ var img$7 = "";
6710
7031
 
6711
- var img$3 = "";
7032
+ var img$6 = "";
6712
7033
 
6713
- var img$2 = "";
7034
+ var img$5 = "";
6714
7035
 
6715
7036
  var EmailChangeVerificationErrorContent = function () {
6716
7037
  return (React.createElement(react$1.Box, { width: "full" },
@@ -6772,56 +7093,56 @@ var Nonce = function () {
6772
7093
  };
6773
7094
  var config = {
6774
7095
  404: {
6775
- illustration: img$2,
7096
+ illustration: img$5,
6776
7097
  buttonColumns: 1,
6777
7098
  content: Nonce,
6778
7099
  primaryAction: Nonce,
6779
7100
  secondaryAction: BackToHomepageSecondary,
6780
7101
  },
6781
7102
  500: {
6782
- illustration: img$3,
7103
+ illustration: img$6,
6783
7104
  buttonColumns: 1,
6784
7105
  content: Nonce,
6785
7106
  primaryAction: Nonce,
6786
7107
  secondaryAction: BackToHomepageSecondary,
6787
7108
  },
6788
7109
  clientSide: {
6789
- illustration: img$3,
7110
+ illustration: img$6,
6790
7111
  buttonColumns: 2,
6791
7112
  content: Nonce,
6792
7113
  primaryAction: Reload,
6793
7114
  secondaryAction: BackToHomepageSecondary,
6794
7115
  },
6795
7116
  UNVERIFIED_EMAIL: {
6796
- illustration: img$2,
7117
+ illustration: img$5,
6797
7118
  buttonColumns: 2,
6798
7119
  content: Nonce,
6799
7120
  primaryAction: BackToLogin,
6800
7121
  secondaryAction: ContactSupport,
6801
7122
  },
6802
7123
  INITIAL_UNVERIFIED_EMAIL: {
6803
- illustration: img$4,
7124
+ illustration: img$7,
6804
7125
  buttonColumns: 1,
6805
7126
  content: Nonce,
6806
7127
  primaryAction: BackToLogin,
6807
7128
  secondaryAction: Nonce,
6808
7129
  },
6809
7130
  USER_BLOCKED: {
6810
- illustration: img$2,
7131
+ illustration: img$5,
6811
7132
  buttonColumns: 1,
6812
7133
  content: Nonce,
6813
7134
  primaryAction: Nonce,
6814
7135
  secondaryAction: ContactSupport,
6815
7136
  },
6816
7137
  UNKNOWN_AUTH_ERROR: {
6817
- illustration: img$2,
7138
+ illustration: img$5,
6818
7139
  buttonColumns: 2,
6819
7140
  content: Nonce,
6820
7141
  primaryAction: BackToLogin,
6821
7142
  secondaryAction: ContactSupport,
6822
7143
  },
6823
7144
  EMAIL_CHANGE_VERIFICATION_ERROR: {
6824
- illustration: img$2,
7145
+ illustration: img$5,
6825
7146
  buttonColumns: 1,
6826
7147
  content: EmailChangeVerificationErrorContent,
6827
7148
  primaryAction: BackToHomepagePrimary,
@@ -7105,7 +7426,7 @@ var Menu = function (_a) {
7105
7426
  var title = _a.title, items = _a.items, value = _a.value, _b = _a.fontWeightTitle, fontWeightTitle = _b === void 0 ? 'regular' : _b, _c = _a.offset, offset = _c === void 0 ? [8, 0] : _c, menuColor = _a.menuColor, menuOptionColor = _a.menuOptionColor, _d = _a.showChevron, showChevron = _d === void 0 ? true : _d, icon = _a.icon, _e = _a.iconSpacing, iconSpacing = _e === void 0 ? 'sm' : _e, placement = _a.placement, _f = _a.showOptionsCheckmark, showOptionsCheckmark = _f === void 0 ? false : _f;
7106
7427
  var recipe = react$1.useSlotRecipe({ key: 'menu' });
7107
7428
  var styles = recipe();
7108
- var _g = offset[0], mainAxis = _g === void 0 ? 0 : _g, _h = offset[1], crossAxis = _h === void 0 ? 0 : _h;
7429
+ var _g = offset[0], crossAxis = _g === void 0 ? 0 : _g, _h = offset[1], mainAxis = _h === void 0 ? 0 : _h;
7109
7430
  return (React.createElement(react$1.Menu.Root, { positioning: { placement: placement, offset: { mainAxis: mainAxis, crossAxis: crossAxis } } },
7110
7431
  React.createElement(react$1.Menu.Context, null, function (_a) {
7111
7432
  var open = _a.open;
@@ -7184,15 +7505,15 @@ var AccordionPanel = function (props) {
7184
7505
  var recipe = react$1.useSlotRecipe({ key: 'accordion' });
7185
7506
  var _a = recipe.splitVariantProps(props), recipeProps = _a[0], restProps = _a[1];
7186
7507
  var styles = recipe(__assign({}, recipeProps));
7187
- var children = restProps.children, rest = __rest(restProps, ["children"]);
7508
+ var children = restProps.children, pb = restProps.pb, rest = __rest(restProps, ["children", "pb"]);
7188
7509
  return (React.createElement(react$1.Accordion.ItemContent, { css: styles.content },
7189
- React.createElement(react$1.Accordion.ItemBody, __assign({}, rest, { css: styles.body }), children)));
7510
+ React.createElement(react$1.Accordion.ItemBody, __assign({}, rest, { css: __assign(__assign({}, styles.body), (pb !== undefined && { pb: pb })) }), children)));
7190
7511
  };
7191
7512
 
7192
7513
  var MobileOnlyAccordionPanel = function (props) {
7193
7514
  var children = props.children, rest = __rest(props, ["children"]);
7194
7515
  return (React.createElement(React.Fragment, null,
7195
- React.createElement(react$1.Box, __assign({ hideBelow: "md", textStyle: "body-small", pb: "md", paddingX: "lg" }, rest), children),
7516
+ React.createElement(react$1.Box, __assign({ hideBelow: "md", textStyle: "body-small", paddingX: "lg" }, rest), children),
7196
7517
  React.createElement(react$1.Box, { hideFrom: "md" },
7197
7518
  React.createElement(AccordionPanel, __assign({}, rest), children))));
7198
7519
  };
@@ -7212,13 +7533,9 @@ var AccordionItem = function (props) {
7212
7533
  };
7213
7534
 
7214
7535
  var MobileOnlyAccordionItem = function (props) {
7215
- var children = props.children, rest = __rest(props, ["children"]);
7536
+ var children = props.children, style = props.style, rest = __rest(props, ["children", "style"]);
7216
7537
  var isAboveMd = useMediaQuery({ above: 'md' });
7217
- return (React.createElement(AccordionItem, __assign({ style: isAboveMd
7218
- ? {
7219
- border: 'none',
7220
- }
7221
- : undefined }, rest), children));
7538
+ return (React.createElement(AccordionItem, __assign({ style: isAboveMd ? { border: 'none' } : style }, rest), children));
7222
7539
  };
7223
7540
 
7224
7541
  var AccordionButton = function (props) {
@@ -7235,7 +7552,7 @@ var AccordionButton = function (props) {
7235
7552
  var MobileOnlyAccordionButton = function (props) {
7236
7553
  var children = props.children, rest = __rest(props, ["children"]);
7237
7554
  return (React.createElement(React.Fragment, null,
7238
- React.createElement(react$1.Box, { hideBelow: "md", textStyle: "heading5", paddingX: "lg", paddingY: "md" }, children),
7555
+ React.createElement(react$1.Box, { hideBelow: "md", textStyle: "heading5", paddingX: "lg", paddingBottom: "md" }, children),
7239
7556
  React.createElement(react$1.Box, { hideFrom: "md" },
7240
7557
  React.createElement(AccordionButton, __assign({}, rest), children))));
7241
7558
  };
@@ -7262,9 +7579,9 @@ var FooterSections = function (_a) {
7262
7579
  })));
7263
7580
  };
7264
7581
 
7265
- var img$1 = "";
7582
+ var img$4 = "";
7266
7583
 
7267
- var img = "";
7584
+ var img$3 = "";
7268
7585
 
7269
7586
  var FooterApps = function (_a) {
7270
7587
  var config = _a.config;
@@ -7275,10 +7592,10 @@ var FooterApps = function (_a) {
7275
7592
  React.createElement(Root$1, null,
7276
7593
  React.createElement(Item, { display: "flex", alignItems: "center" },
7277
7594
  React.createElement(FooterLink, { linkInstance: config.apps.android[0] },
7278
- React.createElement(react$1.Image, { src: img$1, alt: 'Googleplay Icon', width: "3xl", height: "auto", loading: "lazy" }))),
7595
+ React.createElement(react$1.Image, { src: img$4, alt: 'Googleplay Icon', width: "3xl", height: "auto", loading: "lazy" }))),
7279
7596
  React.createElement(Item, { display: "flex", alignItems: "center", mt: "md" },
7280
7597
  React.createElement(FooterLink, { linkInstance: config.apps.apple[0] },
7281
- React.createElement(react$1.Image, { src: img, alt: 'Appsore Icon', width: "3xl", height: "auto", loading: "lazy" })))))));
7598
+ React.createElement(react$1.Image, { src: img$3, alt: 'Appsore Icon', width: "3xl", height: "auto", loading: "lazy" })))))));
7282
7599
  };
7283
7600
 
7284
7601
  var FooterSectionGrid = function (_a) {
@@ -8194,99 +8511,2399 @@ var Footer$1 = function (_a) {
8194
8511
  React.createElement(FooterCopyright, null)))))));
8195
8512
  };
8196
8513
 
8197
- var Pagination = function (_a) {
8198
- var totalPages = _a.totalPages, _b = _a.currentPage, currentPage = _b === void 0 ? 0 : _b, onChange = _a.onChange, marginBottom = _a.marginBottom, marginTop = _a.marginTop;
8199
- var recipe = react$1.useSlotRecipe({ key: 'pagination' });
8200
- var styles = recipe();
8201
- if (totalPages <= 1) {
8202
- return null;
8514
+ var SearchField = function (_a) {
8515
+ var name = _a.name, _b = _a.placeholder, placeholder = _b === void 0 ? '' : _b, _c = _a.ariaControls, ariaControls = _c === void 0 ? '' : _c, searchQuery = _a.searchQuery, setSearchQuery = _a.setSearchQuery, _d = _a.onFocus, onFocus = _d === void 0 ? function () { return null; } : _d, _e = _a.onBlur, onBlur = _e === void 0 ? function () { return null; } : _e, _f = _a.autofocusOnDesktop, autofocusOnDesktop = _f === void 0 ? true : _f, autoComplete = _a.autoComplete;
8516
+ var isDesktopOnly = useMediaQuery({ above: 'md' });
8517
+ var inputRef = React.useRef(null);
8518
+ React.useEffect(function () {
8519
+ var _a;
8520
+ if (autofocusOnDesktop && isDesktopOnly) {
8521
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
8522
+ }
8523
+ }, [isDesktopOnly, autofocusOnDesktop]);
8524
+ return (React.createElement(Input, { ref: inputRef, icon: MagnifierIcon, name: name, placeholder: placeholder, value: searchQuery, setInputValue: setSearchQuery, size: "lg", isClearable: true, debounce: true, onFocus: onFocus, onBlur: onBlur, "aria-controls": ariaControls, autoComplete: autoComplete }));
8525
+ };
8526
+
8527
+ var HighlightedText = function (_a) {
8528
+ var text = _a.text, _b = _a.highlightIndices, highlightIndices = _b === void 0 ? [] : _b, textProps = __rest(_a, ["text", "highlightIndices"]);
8529
+ if (highlightIndices.length === 0)
8530
+ return (React.createElement(Text, __assign({ as: "span" }, textProps), text));
8531
+ var result = [];
8532
+ var currentIndex = 0;
8533
+ for (var _i = 0, highlightIndices_1 = highlightIndices; _i < highlightIndices_1.length; _i++) {
8534
+ var _c = highlightIndices_1[_i], start = _c[0], end = _c[1];
8535
+ // Append the non-matching part
8536
+ result.push(React.createElement(Text, __assign({ key: "non-highlight-".concat(currentIndex, "-").concat(start, "-").concat(text), as: "span" }, textProps), text.substring(currentIndex, start)));
8537
+ // Append the matching part
8538
+ result.push(React.createElement(Text, __assign({ key: "highlight-".concat(start, "-").concat(end + 1, "-").concat(text), as: "u", fontWeight: "bold" }, textProps), text.substring(start, end + 1)));
8539
+ currentIndex = end + 1;
8203
8540
  }
8204
- return (React.createElement(react$1.Pagination.Root, { count: totalPages, pageSize: 1, page: currentPage + 1, onPageChange: function (e) { return onChange(e.page - 1); } },
8205
- React.createElement(react$1.Box, { marginTop: marginTop, marginBottom: marginBottom, css: styles.paginationContainer },
8206
- React.createElement(react$1.Pagination.PrevTrigger, { asChild: true, css: styles.paginationButton, display: { base: 'none', xs: 'inline-flex' } },
8207
- React.createElement(react$1.IconButton, null,
8208
- React.createElement(ChevronLeftSmallIcon, null))),
8209
- React.createElement(react$1.Pagination.Context, null, function (_a) {
8210
- var pages = _a.pages;
8211
- return pages.map(function (page, index) {
8212
- return page.type === 'page' ? (React.createElement(react$1.Pagination.Item, __assign({ key: index }, page, { css: styles.paginationButton }), page.value)) : (React.createElement(react$1.Pagination.Ellipsis, { css: styles.dots, key: index, index: index }, "\u2026"));
8213
- });
8214
- }),
8215
- React.createElement(react$1.Pagination.NextTrigger, { asChild: true, css: styles.paginationButton, display: { base: 'none', xs: 'inline-flex' } },
8216
- React.createElement(react$1.IconButton, null,
8217
- React.createElement(ChevronRightSmallIcon, null))))));
8541
+ // Append the remaining non-matching part
8542
+ result.push(React.createElement(Text, __assign({ key: "non-highlight-end-".concat(text), as: "span" }, textProps), text.substring(currentIndex)));
8543
+ return (React.createElement(Text, __assign({ as: "span" }, textProps), result));
8218
8544
  };
8219
8545
 
8220
- var Rating = function (_a) {
8221
- var rating = _a.rating, props = __rest(_a, ["rating"]);
8222
- var percent = "calc((".concat(rating.toString(), " - 0.16) / 5 * 100%)");
8223
- var recipe = react$1.useRecipe({ key: 'rating' });
8224
- var recipeProps = recipe.splitVariantProps(props)[0];
8225
- var styles = recipe(recipeProps);
8226
- return (React.createElement(react$1.Box, { "aria-label": "Rating is ".concat(rating, " out of 5"), css: __assign(__assign({}, styles), { '--percent': percent, '--star-color': 'colors.orange.300', '&::before': {
8227
- content: '"★★★★★"',
8228
- letterSpacing: '0.5em',
8229
- color: 'var(--star-color)',
8230
- background: 'linear-gradient(90deg, var(--star-color) var(--percent), white var(--percent))',
8231
- backgroundClip: 'text',
8232
- WebkitTextFillColor: 'transparent',
8233
- WebkitTextStroke: '0.1em var(--star-color)',
8234
- } }) }));
8546
+ var SearchableListItemLabel = function (_a) {
8547
+ var label = _a.label, isSelected = _a.isSelected, _b = _a.showChevron, showChevron = _b === void 0 ? true : _b, _c = _a.highlightIndices, highlightIndices = _c === void 0 ? [] : _c, _d = _a.isCheckbox, isCheckbox = _d === void 0 ? false : _d, facet = _a.facet;
8548
+ return (React.createElement(Flex, { width: "full", justifyContent: "space-between", whiteSpace: "pre-wrap", fontWeight: isSelected && !isCheckbox ? 'bold' : undefined, color: "gray.900", cursor: "pointer" },
8549
+ React.createElement(Flex, null,
8550
+ isSelected && !isCheckbox ? (React.createElement(CheckmarkIcon, { w: "xs", mr: "xs", color: "gray.900" })) : null,
8551
+ React.createElement(HighlightedText, { text: label, highlightIndices: highlightIndices, textAlign: "left" })),
8552
+ React.createElement(Flex, { as: "span" },
8553
+ facet ? (React.createElement(Text, { as: "span", color: "gray.400", mr: showChevron ? 'lg' : undefined, ml: "sm", minW: "lg", textAlign: "right", fontWeight: "regular" }, facet)) : null,
8554
+ showChevron ? (React.createElement(ChevronRightSmallIcon, { color: "gray.500", w: "sm", h: "sm" })) : null)));
8555
+ };
8556
+
8557
+ var isCheckboxType = function (listItem) {
8558
+ return !!listItem.isCheckbox;
8559
+ };
8560
+ var SearchableListItem = function (props) {
8561
+ var isCheckbox = isCheckboxType(props);
8562
+ var label = props.label, value = props.value, facet = props.facet, isSelected = props.isSelected, _a = props.showChevron, showChevron = _a === void 0 ? true : _a, _b = props.highlightIndices, highlightIndices = _b === void 0 ? [] : _b, children = props.children;
8563
+ var labelProps = {
8564
+ label: label,
8565
+ isSelected: isSelected,
8566
+ showChevron: showChevron,
8567
+ highlightIndices: highlightIndices,
8568
+ isCheckbox: isCheckbox,
8569
+ facet: facet,
8570
+ };
8571
+ var commonProps = {
8572
+ value: value,
8573
+ paddingY: 'sm',
8574
+ name: "searchable-list-item-".concat(value),
8575
+ 'aria-current': isSelected,
8576
+ };
8577
+ var checkboxProps = __assign(__assign({}, commonProps), { label: React.createElement(SearchableListItemLabel, __assign({}, labelProps)), checked: isSelected, indeterminate: isCheckbox ? !!props.isIndeterminate : false, fullWidth: true, variant: 'alignTop', onChange: isCheckbox ? props.onClick : undefined });
8578
+ return (React.createElement(List.Item, { css: { breakInside: 'avoid' }, paddingLeft: props.paddingLeft },
8579
+ isCheckbox ? (React.createElement(Checkbox, __assign({}, checkboxProps))) : (React.createElement(react$1.Button, { value: value, paddingY: "sm", name: "searchable-list-item-".concat(value), "aria-current": isSelected, onClick: !isCheckbox ? props.onClick : undefined, width: "full", display: "flex", paddingX: "0" },
8580
+ React.createElement(SearchableListItemLabel, __assign({}, labelProps)))),
8581
+ children));
8582
+ };
8583
+
8584
+ var fuseOptions = {
8585
+ keys: ['label', 'children.label'],
8586
+ includeMatches: true,
8587
+ threshold: 0,
8588
+ ignoreLocation: true,
8589
+ minMatchCharLength: 1,
8590
+ shouldSort: false,
8591
+ };
8592
+ var mapItemsFromSearchResult = function (searchResults) {
8593
+ return searchResults.map(function (_a) {
8594
+ var _b = _a.matches, matches = _b === void 0 ? [] : _b, item = _a.item;
8595
+ var parentMatch = matches.find(function (match) { return match.key === 'label'; });
8596
+ var parentHighlightIndices = parentMatch ? parentMatch.indices : [];
8597
+ var childMatches = item.children
8598
+ ? matches.filter(function (match) { return match.key === 'children.label'; })
8599
+ : [];
8600
+ if (!item.children ||
8601
+ item.children.length === 0 ||
8602
+ childMatches.length === 0) {
8603
+ return __assign(__assign({}, item), { highlightIndices: parentHighlightIndices });
8604
+ }
8605
+ var itemChildren = item.children || [];
8606
+ var children = childMatches.reduce(function (accumulator, childMatch) {
8607
+ if (childMatch.refIndex === undefined) {
8608
+ return accumulator;
8609
+ }
8610
+ var child = itemChildren[childMatch.refIndex];
8611
+ accumulator.push(__assign(__assign({}, child), { highlightIndices: childMatch.indices }));
8612
+ return accumulator;
8613
+ }, []);
8614
+ return __assign(__assign(__assign({}, item), (children ? { children: children } : {})), { highlightIndices: parentMatch ? parentMatch.indices : [] });
8615
+ });
8616
+ };
8617
+ var empty = function () { return null; };
8618
+ var search = function (_a) {
8619
+ var query = _a.query, fuse = _a.fuse;
8620
+ fuse.options.minMatchCharLength = query.length || 1;
8621
+ return fuse.search(query);
8622
+ };
8623
+ var getFuseInstance = function (listItems) {
8624
+ // Not casting the instance will result in the options not being typed
8625
+ return new Fuse(listItems, fuseOptions);
8626
+ };
8627
+ var SearchableList = function (_a) {
8628
+ var listItems = _a.listItems, _b = _a.NoResults, NoResults = _b === void 0 ? empty : _b, _c = _a.EmptyQueryPlaceholder, EmptyQueryPlaceholder = _c === void 0 ? empty : _c, _d = _a.listAriaLabel, listAriaLabel = _d === void 0 ? 'searchable list' : _d, _e = _a.searchFieldOptions, searchFieldOptions = _e === void 0 ? {} : _e, _f = _a.listOptions, listOptions = _f === void 0 ? { columns: 1, childrenSpacing: 'md' } : _f, listRef = _a.listRef;
8629
+ var gray200 = useToken('colors', ['gray.200'])[0];
8630
+ var _g = React.useState({
8631
+ query: '',
8632
+ listItems: listItems,
8633
+ fullListItems: __spreadArray([], listItems, true),
8634
+ fuse: getFuseInstance(listItems),
8635
+ }), searchState = _g[0], setSearchState = _g[1];
8636
+ var _h = searchFieldOptions.placeholder, placeholder = _h === void 0 ? '' : _h, _j = searchFieldOptions.autofocusOnDesktop, autofocusOnDesktop = _j === void 0 ? true : _j, autoComplete = searchFieldOptions.autoComplete;
8637
+ var _k = listOptions.columns, columns = _k === void 0 ? 1 : _k, _l = listOptions.childrenSpacing, childrenSpacing = _l === void 0 ? 'md' : _l;
8638
+ var areaId = 'searchableList';
8639
+ var query = searchState.query;
8640
+ React.useEffect(function () {
8641
+ setSearchState(function (currentState) {
8642
+ var fuse = getFuseInstance(listItems);
8643
+ if (currentState.query === '') {
8644
+ return {
8645
+ listItems: listItems,
8646
+ fullListItems: __spreadArray([], listItems, true),
8647
+ fuse: fuse,
8648
+ query: currentState.query,
8649
+ };
8650
+ }
8651
+ var searchResults = search({ fuse: fuse, query: currentState.query });
8652
+ var filteredListItems = mapItemsFromSearchResult(searchResults);
8653
+ return {
8654
+ listItems: filteredListItems,
8655
+ fuse: fuse,
8656
+ query: currentState.query,
8657
+ fullListItems: __spreadArray([], listItems, true),
8658
+ };
8659
+ });
8660
+ }, [listItems]);
8661
+ var setSearchQuery = React.useCallback(function (newQuery) {
8662
+ setSearchState(function (currentState) {
8663
+ var trimmedQuery = newQuery.trim();
8664
+ if (!trimmedQuery) {
8665
+ return __assign(__assign({}, currentState), { listItems: currentState.fullListItems, query: trimmedQuery });
8666
+ }
8667
+ var searchResults = search({
8668
+ fuse: currentState.fuse,
8669
+ query: trimmedQuery,
8670
+ });
8671
+ var filteredListItems = mapItemsFromSearchResult(searchResults);
8672
+ return __assign(__assign({}, currentState), { listItems: filteredListItems, query: trimmedQuery });
8673
+ });
8674
+ }, []);
8675
+ return (React.createElement(Flex, { gridGap: "md", direction: "column", width: "full" },
8676
+ React.createElement(SearchField, { name: "searchableListSearchFiled", searchQuery: query, setSearchQuery: setSearchQuery, ariaControls: areaId, placeholder: placeholder, autofocusOnDesktop: autofocusOnDesktop, autoComplete: autoComplete }),
8677
+ searchState.query.length === 0 ? React.createElement(EmptyQueryPlaceholder, null) : null,
8678
+ searchState.listItems.length > 0 ? (React.createElement(List.Root, { ref: listRef, width: "full", height: "full", id: areaId, "aria-live": "polite", css: {
8679
+ columns: { base: 1, md: columns },
8680
+ columnGap: '4xl',
8681
+ columnRule: "1px solid ".concat(gray200),
8682
+ }, "aria-label": listAriaLabel }, searchState.listItems.map(function (item, itemIndex) {
8683
+ var parentKey = "".concat(itemIndex, "-").concat(item.value);
8684
+ var children = item.children || [];
8685
+ return (React.createElement(SearchableListItem, __assign({}, item, { key: parentKey }), children.length > 0 ? (React.createElement(List.Root, { width: "full" }, children.map(function (child, childIndex) {
8686
+ var childKey = "".concat(childIndex, "-").concat(child.value);
8687
+ return (React.createElement(SearchableListItem, __assign({}, child, { key: childKey, paddingLeft: childrenSpacing })));
8688
+ }))) : null));
8689
+ }))) : (React.createElement(NoResults, null))));
8690
+ };
8691
+
8692
+ var createTenantLabel = function (managedSeller) {
8693
+ if (!managedSeller)
8694
+ return '';
8695
+ var nameWithCity = "".concat(managedSeller.billingName || '', " ").concat(managedSeller.billingCity || '').trim();
8696
+ if (nameWithCity) {
8697
+ return "".concat(nameWithCity, " - ").concat(managedSeller.id);
8698
+ }
8699
+ return managedSeller.id.toString();
8235
8700
  };
8236
8701
 
8237
- var Section = function (_a) {
8238
- var _b = _a.maxImgW, maxImgW = _b === void 0 ? '2xl' : _b, props = __rest(_a, ["maxImgW"]);
8239
- var recipe = react$1.useSlotRecipe({ key: 'section' });
8240
- var _c = recipe.splitVariantProps(props), recipeProps = _c[0], componentProps = _c[1];
8241
- var styles = recipe(recipeProps);
8242
- var title = componentProps.title, text = componentProps.text, image = componentProps.image;
8243
- return (React.createElement(react$1.Stack, { css: styles.root },
8244
- image ? (React.createElement(react$1.Box, { css: styles.imageContainer, maxW: maxImgW }, image)) : null,
8245
- React.createElement(react$1.Stack, { css: styles.textContainer },
8246
- React.createElement(react$1.chakra.span, { css: styles.title }, title),
8247
- text ? React.createElement(react$1.chakra.span, { css: styles.text }, text) : null)));
8702
+ var TenantSelectionSelectList = function (_a) {
8703
+ var managedSellers = _a.managedSellers, selectedTenantId = _a.selectedTenantId, onTenantSelect = _a.onTenantSelect, title = _a.title, searchFieldOptions = _a.searchFieldOptions;
8704
+ var listItems = React.useMemo(function () {
8705
+ return managedSellers.map(function (managedSeller) {
8706
+ return {
8707
+ value: managedSeller.id.toString(),
8708
+ label: createTenantLabel(managedSeller),
8709
+ onClick: function (event) {
8710
+ return onTenantSelect(parseInt(event.currentTarget.value, 10));
8711
+ },
8712
+ showChevron: true,
8713
+ isSelected: managedSeller.id === selectedTenantId,
8714
+ };
8715
+ });
8716
+ }, [managedSellers, selectedTenantId, onTenantSelect]);
8717
+ return (React.createElement(React.Fragment, null,
8718
+ title ? React.createElement(H1, { textStyle: "heading3" }, title) : null,
8719
+ React.createElement(SearchableList, { listItems: listItems, searchFieldOptions: searchFieldOptions })));
8720
+ };
8721
+
8722
+ var Spinner = function (_a) {
8723
+ var size = _a.size;
8724
+ return (React.createElement(react$1.Spinner, { size: size }));
8725
+ };
8726
+
8727
+ var NavigationTenantMenuLoading = function () { return (React.createElement(React.Fragment, null,
8728
+ React.createElement(react$1.Box, { position: "absolute", top: "0", bottom: "0", left: "0", right: "0", bg: "gray.900", css: { opacity: 0.7 } }),
8729
+ React.createElement(react$1.Box, { position: "absolute", css: { top: '50%', left: '50%', transform: 'translate(-50%, -50%)' } },
8730
+ React.createElement(Spinner, null)))); };
8731
+
8732
+ var NavigationTenantMenuContent = function (_a) {
8733
+ var user = _a.user, selectTenant = _a.selectTenant, onClose = _a.onClose, title = _a.title, selectedTenantId = _a.selectedTenantId;
8734
+ var _b = React.useState(false), isLoading = _b[0], setIsLoading = _b[1];
8735
+ var onTenantSelect = React.useCallback(function (newTenantId) { return __awaiter(void 0, void 0, void 0, function () {
8736
+ return __generator(this, function (_a) {
8737
+ switch (_a.label) {
8738
+ case 0:
8739
+ setIsLoading(true);
8740
+ _a.label = 1;
8741
+ case 1:
8742
+ _a.trys.push([1, , 3, 4]);
8743
+ return [4 /*yield*/, selectTenant(newTenantId)];
8744
+ case 2:
8745
+ _a.sent();
8746
+ return [3 /*break*/, 4];
8747
+ case 3:
8748
+ onClose();
8749
+ setIsLoading(false);
8750
+ return [7 /*endfinally*/];
8751
+ case 4: return [2 /*return*/];
8752
+ }
8753
+ });
8754
+ }); }, [selectTenant, onClose]);
8755
+ return (React.createElement(React.Fragment, null,
8756
+ React.createElement(TenantSelectionSelectList, { managedSellers: user.managedSellers, selectedTenantId: selectedTenantId, onTenantSelect: onTenantSelect, title: title, searchFieldOptions: { autoComplete: 'off' } }),
8757
+ isLoading ? React.createElement(NavigationTenantMenuLoading, null) : null));
8248
8758
  };
8249
8759
 
8250
- var Select = React.forwardRef(function (_a, ref) {
8251
- var options = _a.options, props = __rest(_a, ["options"]);
8252
- var selectRecipe = react$1.useSlotRecipe({ key: 'select' });
8253
- var _b = selectRecipe.splitVariantProps(props), selectRecipeProps = _b[0], restProps = _b[1];
8254
- var selectStyles = selectRecipe(selectRecipeProps);
8255
- var disabled = restProps.disabled, invalid = restProps.invalid, rest = __rest(restProps, ["disabled", "invalid"]);
8256
- return (React.createElement(react$1.NativeSelect.Root, { disabled: disabled, invalid: invalid, css: selectStyles.root },
8257
- React.createElement(react$1.NativeSelect.Field, __assign({ ref: ref }, rest, { css: selectStyles.field }), options.map(function (option) { return (React.createElement("option", { value: option.value, key: option.value }, option.label)); })),
8258
- React.createElement(react$1.NativeSelect.Indicator, { css: [
8259
- selectStyles.indicator,
8260
- disabled && selectStyles.indicator._disabled,
8760
+ var NavigationTenantMenu = function (_a) {
8761
+ var user = _a.user, selectTenant = _a.selectTenant;
8762
+ var _b = react$1.useDisclosure(), onClose = _b.onClose, open = _b.open, onToggle = _b.onToggle;
8763
+ var t = i18nPkg.useI18n().t;
8764
+ var selectedTenant = React.useMemo(function () {
8765
+ var _a;
8766
+ return (_a = user === null || user === void 0 ? void 0 : user.managedSellers) === null || _a === void 0 ? void 0 : _a.find(function (seller) { return seller.id === Number(user.sellerId); });
8767
+ }, [user === null || user === void 0 ? void 0 : user.managedSellers, user === null || user === void 0 ? void 0 : user.sellerId]);
8768
+ if (!user || !user.isMultiTenantUser || !selectedTenant)
8769
+ return null;
8770
+ var selectedTenantInfo = "".concat(selectedTenant.billingName || '', " ").concat(selectedTenant.billingCity || '').trim() ||
8771
+ selectedTenant.id.toString();
8772
+ return (React.createElement(react$1.Box, { hideBelow: "sm", display: "flex", alignItems: "center" },
8773
+ React.createElement(react$1.Popover.Root, { positioning: { placement: 'bottom-end' }, onOpenChange: function (e) {
8774
+ if (!e.open)
8775
+ onClose();
8776
+ }, open: open, lazyMount: true, unmountOnExit: true },
8777
+ React.createElement(react$1.Popover.Trigger, { asChild: true },
8778
+ React.createElement(react$1.Button, { p: "0", color: open ? 'blue.700' : 'gray.900', _hover: { color: 'blue.700' }, onClick: onToggle, display: "inline-flex", flexDirection: "row", alignItems: "center", gap: "xs", cursor: "pointer", css: { background: 'transparent' } },
8779
+ React.createElement(GarageIcon, null),
8780
+ React.createElement(react$1.Box, { hideBelow: "md" },
8781
+ React.createElement(Text, { fontWeight: "bold", lineClamp: 1, maxW: "2xl", textAlign: "left", title: selectedTenantInfo }, selectedTenantInfo)),
8782
+ React.createElement(ChevronDownSmallIcon, { transition: "transform", transitionDuration: "fast", transform: open ? 'rotate(180deg)' : 'rotate(0deg)' }))),
8783
+ React.createElement(react$1.Portal, null,
8784
+ React.createElement(react$1.Box, { zIndex: "popover", w: "full", h: "full", position: "relative" },
8785
+ React.createElement(react$1.Popover.Positioner, null,
8786
+ React.createElement(react$1.Popover.Content, { bg: "white", boxShadow: "sm", color: "gray.900", width: {
8787
+ base: 'full',
8788
+ md: '6xl',
8789
+ }, css: {
8790
+ maxHeight: 'auth0-height',
8791
+ borderWidth: '1px',
8792
+ marginTop: '10px',
8793
+ }, p: "2xl", borderRadius: "sm", borderColor: "gray.200", display: "flex", alignItems: "center", flexDirection: "column", gap: "2xl", overflow: "auto" },
8794
+ React.createElement(NavigationTenantMenuContent, { user: user, selectTenant: selectTenant, onClose: onClose, selectedTenantId: selectedTenant.id, title: t('auth.tenantSelection.selectionTitle') }))))))));
8795
+ };
8796
+
8797
+ var replaceLanguage = function (_a) {
8798
+ var activeLanguage = _a.activeLanguage, newLanguage = _a.newLanguage;
8799
+ var updatedUrl = window.location.href.replace("/".concat(activeLanguage), "/".concat(newLanguage));
8800
+ window.location.replace(updatedUrl);
8801
+ };
8802
+
8803
+ var NavigationLanguageMenu = function (_a) {
8804
+ var activeLanguage = _a.activeLanguage;
8805
+ return (React.createElement(react$1.Box, { hideBelow: "sm" },
8806
+ React.createElement(Menu, { title: activeLanguage.toUpperCase(), fontWeightTitle: "bold", menuColor: "gray.900", offset: [0, 18], iconSpacing: "xs", placement: "bottom-end", items: [
8807
+ {
8808
+ text: 'Deutsch',
8809
+ onClick: function () {
8810
+ return replaceLanguage({ activeLanguage: activeLanguage, newLanguage: 'de' });
8811
+ },
8812
+ value: 'de',
8813
+ },
8814
+ {
8815
+ text: 'Français',
8816
+ onClick: function () {
8817
+ return replaceLanguage({ activeLanguage: activeLanguage, newLanguage: 'fr' });
8818
+ },
8819
+ value: 'fr',
8820
+ },
8821
+ {
8822
+ text: 'Italiano',
8823
+ onClick: function () {
8824
+ return replaceLanguage({ activeLanguage: activeLanguage, newLanguage: 'it' });
8825
+ },
8826
+ value: 'it',
8827
+ },
8261
8828
  ] })));
8262
- });
8263
- Select.displayName = 'Select';
8829
+ };
8264
8830
 
8265
- var SimpleHeader = function (props) {
8266
- var recipe = react$1.useSlotRecipe({ key: 'simpleHeader' });
8267
- var _a = recipe.splitVariantProps(props), recipeProps = _a[0], componentProps = _a[1];
8268
- var styles = recipe(recipeProps);
8269
- var title = componentProps.title, url = componentProps.url;
8270
- return (React.createElement(react$1.chakra.header, { css: styles.header },
8271
- React.createElement(Center, null,
8272
- React.createElement(Flex, { css: styles.mainContainer },
8273
- React.createElement(Flex, { justify: "space-between", minWidth: "full" },
8274
- React.createElement(react$1.chakra.h1, { css: styles.title }, title),
8275
- React.createElement(Flex, { css: styles.iconWrapper },
8276
- React.createElement("a", { href: url },
8277
- React.createElement(CloseIcon, null))))))));
8831
+ var img$2 = "data:image/svg+xml,%3csvg viewBox='0 0 144 34' xmlns='http://www.w3.org/2000/svg'%3e%3cg fill-rule='nonzero' fill='none'%3e%3cpath d='M.139 32.345c-.017-.292.055-.351.105-.47.011-.026.035-.007.044-.034a.448.448 0 0 0 .033-.162 1.438 1.438 0 0 0-.054-.275 1.305 1.305 0 0 1-.029-.62.852.852 0 0 0 .001-.375 1.245 1.245 0 0 0-.135-.404 1.205 1.205 0 0 1-.095-.226.502.502 0 0 1-.005-.15c.05-.07.101-.133.154-.181.03-.026.07.013.092-.032.042-.084-.023-.183-.018-.283l-.003-.058c-.006-.162-.004-.32-.055-.462-.023-.063-.021-.197.024-.216.066-.03.043-.122.013-.235a3.934 3.934 0 0 1-.058-.256c-.01-.05-.068-.242-.049-.299.01-.027.027.01.039.011.017 0 .025-.016.034-.06.015-.066.03-.193.06-.198.054-.009.06-.34.108-.433.073-.14.07-.349.057-.576-.018-.318-.02-.318.045-.513.008-.026.018-.051.022-.084.018-.12.05-.145.093-.13a.1.1 0 0 0 .058.005c.053-.012.064-.082.023-.191-.048-.124-.106-.207-.159-.312-.032-.067-.072-.127-.092-.219a1.519 1.519 0 0 1-.015-.303c0-.023.038-.044.058-.033.026.014.054.11.07-.019.014-.11-.013-.158-.039-.212-.005-.011-.01-.028-.014-.043-.055-.174-.053-.259.014-.33.056-.061.082-.174.073-.366-.005-.116 0-.242-.015-.347-.021-.144-.002-.14.032-.145.02-.003.055-.035.054-.06a1 1 0 0 0-.029-.204c-.017-.072-.042-.128-.059-.2-.006-.023 0-.071.002-.108.01.013.02.029.03.04.033.034.067.086.1.094.02.006.058-.057.056-.087-.004-.085-.02-.222-.039-.246-.085-.102-.1-.335-.11-.52-.012-.23-.05-.354-.113-.412-.068-.063-.035-.113-.01-.164.05-.102.067-.231.044-.432-.01-.09-.02-.228.032-.247.064-.024.064-.17.04-.3-.04-.199.003-.152.038-.158.023-.004.054-.01.066-.054.022-.084-.024-.365-.063-.42-.04-.054-.081-.092-.118-.16-.015-.025-.02-.11-.028-.168.015-.003.032-.024.044-.005.077.12.123-.066.184-.102a.348.348 0 0 0 .01-.126 1.509 1.509 0 0 0-.039-.198c-.028-.112-.07-.204.003-.291.044-.053.029-.196-.021-.283a1.024 1.024 0 0 1-.078-.178c-.015-.043-.02-.112-.03-.169.019-.02.037-.048.057-.056.022-.008.046.014.067 0a.123.123 0 0 0 .049-.09.69.69 0 0 0-.018-.21c-.093-.15-.078-.385-.059-.561a.588.588 0 0 0-.03-.316c-.011-.032-.014-.099-.02-.15.016.004.031.001.047.013.012.01.023.044.035.054.005.004.017-.042.016-.044-.035-.135-.022-.349-.101-.416-.062-.051-.097-.25-.095-.422.001-.168.044-.228.086-.237.078-.016.094-.141.093-.356 0-.227.015-.252.09-.254.083-.001.093-.063.043-.282a.751.751 0 0 0-.051-.148.293.293 0 0 1-.017-.213.617.617 0 0 0-.038-.378 2.45 2.45 0 0 1-.057-.158 2.937 2.937 0 0 1-.03-.147c-.012-.066-.006-.15.011-.18.025-.04.05-.077.074-.121a.275.275 0 0 0 .02-.143l-.008-.103c-.01-.11-.033-.222-.013-.333.016-.083.008-.2.034-.27.01-.03.005-.063-.015-.11l-.017-.042c.022-.065.022-.19.06-.212.007-.004.013-.015.019-.026a.284.284 0 0 0 .023-.166l-.028-.271a.962.962 0 0 0 .016-.181.314.314 0 0 0 .005-.12 1.157 1.157 0 0 0-.008-.051 3.257 3.257 0 0 0-.014-.212 2.202 2.202 0 0 1-.015-.26c.003-.18.2-.424.16-.557-.017-.06-.038-.114-.055-.177-.043-.169-.04-.173.017-.262a.272.272 0 0 0 .036-.13.683.683 0 0 0-.035-.197c-.054-.134-.113-.25-.169-.376-.034-.077.15-.303.155-.433.008-.188.012-.453-.026-.55-.061-.15-.034-.119-.095-.27 0 0 .19-.39.17-.512-.001-.01.036-.065.054-.1.01-.02.023-.035.028-.064 0 0 .063-.146-.072-.262 0 0-.27-.5.026-.596l.064-.12.042-.165s.083-.321.146-.373l.035-.034c.023-.02.077-.023.107-.03a.174.174 0 0 0 .067-.027c.04-.03.086-.04.132-.056a.277.277 0 0 1 .194 0c.017.007.035.014.053.015 0 0 .166.028.387.086 7.983 2.08 35.738-.172 54.358-5.236.475-.13 1.256-.308 1.418-.347.162-.04.051.133-.123.275-.115.094-.693.19-.729.218-.02.015-.05.052-.044.066.12.27.85-.01 1.14-.044.293-.034.273.09.106.195-.254.159-.319.37-.206.476.024.023.078.016.1.04.034.037.084.098.073.131a.454.454 0 0 1-.128.188c-.128.114-.175.308-.075.453.07.102.053.19-.004.28-.075.118-.904.436-1.039.49-.079.032-.221.095-.286.15-.023.018-.048.103-.034.112.113.07.979-.302 1.1-.249.065.029 1.093-.3.64.019-.1.07-.424.352-.416.428.002.014-.005.028-.007.043-.017.119-.014.237-.133.326-.052.04-.05.14.052.17.15.043.096.105.026.18-.147.155-.633.367-.775.526-.015.017-.013.048-.018.072.028.003.07.018.08.006.08-.083.18-.039.281-.081.224-.094.794-.298.866-.369.138-.133.362-.058.216.173-.048.075-.092.023-.137.158-.008.026-.049.069-.156.182-.096.102-.18.213-.07.298.166.129.154.284.122.45-.045.231-.048.23.095.397.019.022.04.045.05.07.038.096.113.125.21.128a.707.707 0 0 1 .131.015c.122.027.147.083.05.15-.11.077-.244.12-.365.181-.076.039-.168.07-.215.133-.042.054-.098.174-.038.221.099.078.447-.089.492-.09.06-.002.126-.064.161.037.03.087-.761.326-.82.358-.013.007-.023.018-.034.027-.128.113.114.147.28.182.14.029.588-.142.503-.049-.033.036-.288.158-.316.242-.04.123-.139.081-.145.12-.014.086-.004.182-.04.255-.051.1-.006.103.071.118.046.01-.009.098-.01.117a.274.274 0 0 1-.07.142c-.039.049-.096.082-.137.13-.014.015 0 .054.002.082.023-.007.585-.162.609-.166.076-.015.183-.055.258-.05.046.003.22-.025.12.102-.04.05-.016.026-.2.108s-.168.068-.695.427c-.298.203-.184.112-.347.246-.065.054.015.151.15.092.377-.167 1.177-.37 1.118-.242-.072.156-.222.265-.272.414-.062.185-.19.126-.252.168-.057.04-.054.187.064.218.146.04.06.162 0 .25-.092.137.007.116.085.132.054.01.483-.07.509-.034.049.07-.316.244-.432.282-.026.008-.159.032-.358.208-.017.051-.093.163-.064.166.095.008.174-.025.343-.039.328-.028.356-.162.526-.14.131.016-.238.105-.332.286-.072.138-.128.109-.164.149-.068.074-.163.129 0 .218.1.054.255.124.14.173-.064.027-.086.104-.084.172.002.049.107.002.216.06.043.02.164.019.21.032.048.013.083.012.13.029.043.016.192.021.197.055.009.049-.205.155-.237.167-.16.06-.42.232-.41.387.003.046.5-.222.614-.158.128.072-.18.05-.247.216-.08.198-.376.165-.388.2-.012.033-.038.06-.08.09-.028.02-.034.069-.05.104.036.003.072.01.107.006.028-.003.054-.025.082-.028.01-.001.037.036.035.038-.08.09-.288.19-.237.276.02.034.204-.068.34-.097.211-.045.183-.11.296-.116.104-.005.2-.092.163.002-.013.03-.06.074-.143.086-.085.013-.128.1-.108.1.086 0 .22.027.221.063 0 .063.092.032.128.065.036.033.297-.138.277.023-.01.09-.179.268-.372.355-.087.04-.339.145-.343.262-.005.17.74-.009.911.017.19.029.212.078.095.225a.407.407 0 0 1-.12.093c-.07.04-.088.077-.042.154.07.115.015.2-.091.27a1.41 1.41 0 0 0-.217.175c-.026.025-.026.074-.038.112.042.008.085.028.124.022.084-.012.167-.055.25-.054.139.004.147.035.097.17a.533.533 0 0 0-.037.189c.003.136-.07.23-.161.316-.042.039-.09.071-.13.113-.1.112-.095.115.034.201.037.025.083.075.08.109a.205.205 0 0 1-.081.136c-.126.082.45-.064.58.362.016.143.493.222.403.28-.14.093-.31.142-.45.235-.077.05-.12.152-.167.236-.004.007.079.06.12.092.022.018.052.034.062.058.06.14.176.176.319.189.072.006.14.054.21.084-.061.056-.114.127-.186.166-.08.044-.183.048-.267.089-.073.036.091.065.05.13-.034.052-.024.138-.011.205.002.014.1.008.152.018.03.006.078.018.085.038.011.035.012.09-.009.116-.035.043-.341.085-.381.126-.086.088-.076.17.042.212.28.103.632.282.495.51-.063.104-.008.086.045.1.035.008.074.006.11.015.102.027.108.06.028.14-.051.052-.359.162-.405.217-.01.013-1.053.485.02.165.018-.003.135-.048.229-.087.072-.03.198-.044.283-.077.047-.019.114.037.13.087.022.065-.017.121-.1.14-.043.01-.102.038-.118.074-.055.126-.19.21-.184.376.003.05-.097.117-.164.152a.316.316 0 0 0-.08.055l-.017.08a.107.107 0 0 0 .041.034c.147.078.11.176.09.29-.014.084.362-.09.488-.057.122.032.12.136.062.204-.087.1-.043.102.052.116.058.008.158.046.159.074a.555.555 0 0 1-.06.24c-.015.03-.072.048-.112.062-.089.033-.18.056-.269.09-.018.007-.036.045-.033.066.002.017.046.045.057.04.148-.077.25.032.364.086.061.03-.362.175-.2.242.127.053.132-.037.208-.035.173.006-.046.142-.323.155-.158.007-.22.175-.254.2-.063.049-.047.163.277.039.151-.058.614.172.457.229a4.203 4.203 0 0 0-.25.155c-.051.065-.142.066-.05.157.063.027.023.1.086.124.026.01.162.008.186.02.047.026.251-.212.308-.088.022.048-.321.296-.366.327-.1.069-.347.177-.435.287-.027.036.226-.046.256-.068.121-.088.242.002.246.018.008.029-.395.143-.501.286-.04.054-.043.118-.105.165-.081.061-.094.082.018.11.036.01.588-.167.79-.147.217.02.014.128-.02.16-.024.023-.041.265-.068.287-.054.045-.211.14-.238.201-.069.153 1.044.294.865.368C29.677 38.658.816 32.69.128 32.408c0 0 .013-.022.01-.063' fill='%23FF4C52'/%3e%3cpath fill='%23333' d='M141.07 20.133V15.21l-2.16.845v4.078h-4.849l5.913-10.207h-2.399l-6.254 10.769v1.649h7.589v4.054h2.16v-4.054h2.794v-2.211zM123.394 24.14c.338-.268.68-.535 1.022-.802 3.155-2.46 6.418-5.004 6.418-8.723 0-2.914-2.076-4.948-5.05-4.948-2.61 0-5.42 1.77-5.42 5.655 0 .187.011.396.03.526l2.13-.833c0-2.137 1.57-3.255 3.121-3.255 1.508 0 3.028.97 3.028 3.137 0 2.807-2.829 5.004-6.745 8.045-.558.434-1.14.885-1.74 1.359l-.034.027v2.07h11.122V24.14h-7.882ZM116.071 10.81l-2.114.824v2.635h-2.002v1.952h2.002v6.65c0 3.32 1.865 3.816 2.977 3.816.495 0 1.005-.078 1.562-.24l.066-.018v-2.124l-.14.091c-.326.212-.708.34-1.022.34-.845 0-1.329-.62-1.329-1.7V16.22h2.49V14.27h-2.49v-3.46ZM108.448 21.244c0 2.237-1.62 3.444-3.145 3.444-1.16 0-2.4-.7-2.4-2.666V14.27h-2.113v7.753c0 3.443 2.206 4.665 4.095 4.665 1.519 0 2.858-.736 3.552-1.937l.403 1.654h1.722V14.27h-2.114v6.975ZM93.538 13.963c-3.41 0-5.887 2.676-5.887 6.362 0 3.687 2.476 6.362 5.887 6.362 3.412 0 5.887-2.675 5.887-6.362 0-3.686-2.475-6.362-5.887-6.362m3.727 6.362c0 2.818-1.863 4.292-3.703 4.292-1.864 0-3.75-1.474-3.75-4.292 0-2.474 1.577-4.269 3.75-4.269 2.145 0 3.703 1.795 3.703 4.269M85.116 22.722c-.617 1.16-1.77 1.872-3.066 1.872-1.797 0-3.61-1.327-3.61-4.293 0-2.044 1.086-4.245 3.47-4.245 1.19 0 2.247.644 2.806 1.695l2.016-.781-.037-.078c-.837-1.807-2.67-2.93-4.784-2.93-1.489 0-2.868.562-3.882 1.58-1.144 1.15-1.75 2.803-1.75 4.783 0 4.371 2.944 6.362 5.678 6.362 2.126 0 4.01-1.172 5.039-3.137l.04-.077-.017-.008-1.903-.743ZM70.382 16.876l-.193-.078c-1.752-.715-2.992-1.343-2.992-2.932 0-1.564 1.23-2.383 2.446-2.383.98 0 2.224.528 2.708 1.683l2.063-.812-.03-.078c-.813-2.042-2.955-2.957-4.718-2.957-2.308 0-4.793 1.475-4.793 4.712 0 3.162 2.392 4.147 4.314 4.938l.235.098c1.963.82 3.25 1.478 3.25 3.097 0 1.678-1.393 2.43-2.773 2.43-1.364 0-2.992-.737-3.473-2.805l-.021-.091-2.188.84c.659 2.584 2.835 4.243 5.589 4.243 1.385 0 2.674-.427 3.63-1.204 1.08-.878 1.652-2.132 1.652-3.626 0-3.175-2.5-4.185-4.706-5.075M49.367 14.072c3.558 0 5.829 2.845 5.829 6.306 0 3.484-2.27 6.305-5.83 6.305-3.58 0-5.828-2.821-5.828-6.305 0-3.461 2.247-6.306 5.829-6.306m.023 10.714c2.341 0 3.816-2.038 3.816-4.408 0-2.37-1.475-4.386-3.816-4.386-2.364 0-3.862 2.015-3.862 4.386 0 2.37 1.498 4.408 3.862 4.408M41.735 24.905c.351 0 .75-.142 1.077-.356v1.897a5.535 5.535 0 0 1-1.545.237c-1.498 0-2.903-.877-2.903-3.746v-6.779h-2.013V14.38h2.013v-2.678l1.943-.759v3.437h2.505v1.778h-2.505v6.945c0 1.257.632 1.802 1.428 1.802M29.993 14.072c3.558 0 5.829 2.845 5.829 6.306 0 3.484-2.271 6.305-5.83 6.305-3.581 0-5.828-2.821-5.828-6.305 0-3.461 2.247-6.306 5.829-6.306m.023 10.714c2.341 0 3.816-2.038 3.816-4.408 0-2.37-1.475-4.386-3.816-4.386-2.364 0-3.862 2.015-3.862 4.386 0 2.37 1.498 4.408 3.862 4.408M12.884 24.052l-4.869-9.458v11.804H5.908V9.758h2.107l5.853 11.662L19.72 9.758h2.083v16.64H19.72V14.594l-4.846 9.458z'/%3e%3c/g%3e%3c/svg%3e";
8832
+
8833
+ var img$1 = "data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1005.62 238.86'%3e %3cpath d='M.93 227.76a5.25 5.25 0 01.74-3.3c.07-.18.23-.05.3-.24a3.17 3.17 0 00.22-1.14 10.37 10.37 0 00-.36-1.93 9.32 9.32 0 01-.2-4.35 6.18 6.18 0 000-2.64 8.9 8.9 0 00-.93-2.84 9 9 0 01-.65-1.59 3.88 3.88 0 010-1 7.87 7.87 0 011.07-1.28c.2-.18.48.09.63-.22.29-.59-.15-1.29-.12-2v-.41a11.06 11.06 0 00-.38-3.25c-.15-.44-.14-1.38.17-1.52s.3-.85.09-1.65c-.15-.58-.28-1.17-.4-1.8a7.74 7.74 0 01-.33-2.1c.06-.19.19.08.27.08s.17-.11.23-.43.21-1.35.42-1.38c.37-.07.4-2.4.74-3a8.44 8.44 0 00.39-4.05c-.11-2.24-.12-2.23.32-3.6a3.09 3.09 0 00.15-.6c.12-.84.35-1 .64-.91a.79.79 0 00.4 0c.37-.09.44-.58.16-1.35A23.52 23.52 0 003.36 177a6.1 6.1 0 01-.63-1.54 9.7 9.7 0 01-.1-2.13.3.3 0 01.39-.23c.18.1.38.77.49-.13a2.19 2.19 0 00-.27-1.49c0-.08-.06-.2-.1-.3-.37-1.23-.36-1.83.1-2.33a3.62 3.62 0 00.51-2.57c0-.82 0-1.7-.1-2.44-.15-1 0-1 .22-1a.53.53 0 00.37-.42A6.76 6.76 0 004 161c-.11-.5-.28-.9-.4-1.39a4 4 0 010-.77c.07.09.14.2.21.28.22.24.46.61.68.67s.4-.4.39-.62a6 6 0 00-.26-1.72c-.59-.72-.69-2.36-.76-3.67-.08-1.6-.34-2.48-.77-2.89s-.25-.79-.07-1.15a5.46 5.46 0 00.31-3c-.07-.63-.14-1.6.22-1.74s.44-1.18.27-2.1c-.27-1.4 0-1.07.26-1.11s.38-.07.46-.38a6.72 6.72 0 00-.43-2.95 8.65 8.65 0 01-.81-1.13 6.16 6.16 0 01-.19-1.18c.1 0 .22-.17.3 0 .53.85.85-.46 1.27-.72a2.55 2.55 0 00.07-.88 11 11 0 00-.27-1.39c-.19-.79-.48-1.43 0-2.05a2.23 2.23 0 00-.14-2 7.08 7.08 0 01-.54-1.25 8.49 8.49 0 01-.2-1.18c.13-.14.26-.34.39-.4s.32.1.46 0a.87.87 0 00.34-.63 5.1 5.1 0 00-.12-1.48c-.64-1-.53-2.7-.4-3.94a4.26 4.26 0 00-.2-2.22 6.43 6.43 0 01-.15-1 .59.59 0 01.33.09c.08.07.16.3.24.37s.11-.29.11-.31c-.24-.94-.15-2.44-.69-2.91s-.67-1.77-.65-3 .3-1.61.59-1.67c.54-.11.65-1 .64-2.5s.11-1.78.62-1.79.64-.44.3-2a5.49 5.49 0 00-.35-1 2.13 2.13 0 01-.12-1.5A4.46 4.46 0 004.76 98c-.14-.34-.27-.72-.39-1.11s-.15-.67-.21-1a2.45 2.45 0 01.08-1.26c.17-.29.35-.54.51-.86a1.94 1.94 0 00.13-1v-.72a8.35 8.35 0 01-.08-2.34 13.68 13.68 0 01.2-1.94 1.06 1.06 0 00-.1-.77l-.12-.29c.15-.46.15-1.33.41-1.49a.7.7 0 00.12-.22 2.11 2.11 0 00.16-1.17c-.06-.64-.13-1.27-.19-1.91a6.76 6.76 0 00.1-1.27 2.24 2.24 0 000-.84v-.36c0-.56-.06-1.1-.1-1.49a16 16 0 01-.1-1.83c0-1.27 1.38-3 1.11-3.91-.12-.43-.27-.8-.38-1.25-.3-1.18-.28-1.21.11-1.84a1.85 1.85 0 00.25-.91A5 5 0 006 66.87c-.37-.94-.78-1.75-1.16-2.64-.23-.54 1-2.13 1.06-3.05a14.16 14.16 0 00-.17-3.86c-.42-1-.23-.84-.65-1.9 0 0 1.31-2.74 1.18-3.6a4.68 4.68 0 01.36-.7 1.3 1.3 0 00.19-.46 1.64 1.64 0 00-.49-1.84s-1.85-3.5.19-4.18l.49-.85.28-1.16a9.56 9.56 0 011-2.62l.24-.24c.16-.14.54-.16.74-.22a1.23 1.23 0 00.46-.18 2.75 2.75 0 01.91-.4A1.82 1.82 0 0112 39a1.4 1.4 0 00.35.1s1.15.19 2.67.59c54.84 14.55 245.7-1.47 373.77-37.2 3.27-.91 8.64-2.17 9.75-2.45s.36.96-.84 1.96c-.79.66-4.77 1.34-5 1.53s-.34.37-.3.47c.82 1.89 5.84-.07 7.84-.32s1.87.64.73 1.37c-1.76 1.12-2.2 2.61-1.42 3.35.16.16.53.11.68.28s.58.69.5.92a3.17 3.17 0 01-.88 1.32 2.49 2.49 0 00-.52 3.18 1.63 1.63 0 010 2c-.52.83-6.22 3.07-7.15 3.46a8.47 8.47 0 00-2 1c-.16.13-.33.73-.24.79.78.49 6.74-2.13 7.57-1.76.44.2 7.51-2.11 4.4.13-.68.49-2.92 2.48-2.86 3a1.57 1.57 0 01-.05.3c-.12.84-.1 1.67-.92 2.3a.68.68 0 00.36 1.19c1 .3.66.74.17 1.26-1 1.1-4.35 2.59-5.33 3.71-.1.12-.08.33-.12.5.19 0 .48.13.56.05.53-.59 1.23-.28 1.92-.57 1.54-.67 5.46-2.1 6-2.6 1-.94 2.49-.41 1.48 1.21-.32.53-.63.17-.94 1.11a6.06 6.06 0 01-1.07 1.28c-.67.72-1.24 1.5-.48 2.1 1.13.9 1.05 2 .83 3.15-.31 1.63-.33 1.63.65 2.8a1.74 1.74 0 01.35.5 1.37 1.37 0 001.43.89 4 4 0 01.91.11c.83.18 1 .58.34 1a21.26 21.26 0 01-2.52 1.28 4.07 4.07 0 00-1.47.93c-.29.38-.68 1.23-.26 1.56.67.54 3.07-.63 3.38-.64s.86-.45 1.11.26-5.24 2.3-5.65 2.52a1.37 1.37 0 00-.23.19c-.88.79.78 1 1.92 1.27 1 .21 4.05-1 3.46-.34-.22.25-2 1.11-2.17 1.7-.28.86-1 .57-1 .85a6.84 6.84 0 01-.28 1.79c-.35.7 0 .73.49.83.32.06-.06.69-.07.82a1.89 1.89 0 01-.47 1c-.28.34-.67.58-.95.91-.1.11 0 .38 0 .58.16 0 4-1.14 4.19-1.17a7.4 7.4 0 011.77-.35c.32 0 1.52-.18.82.71-.27.35-.1.19-1.37.76s-1.15.48-4.78 3a19 19 0 00-2.39 1.73c-.44.38.1 1.06 1 .64 2.59-1.17 8.1-2.61 7.69-1.7-.5 1.1-1.52 1.86-1.87 2.91-.43 1.3-1.31.89-1.73 1.18a.94.94 0 00.44 1.54c1 .27.4 1.13 0 1.76-.63 1 .05.8.59.92.36.08 3.32-.5 3.5-.24.33.49-2.18 1.72-3 2a5.61 5.61 0 00-2.46 1.47c-.12.36-.64 1.14-.44 1.16a18.32 18.32 0 002.36-.27c2.25-.2 2.45-1.14 3.62-1 .9.11-1.64.74-2.29 2-.49 1-.88.77-1.13 1-.46.52-1.12.91 0 1.53.69.38 1.75.87 1 1.22a1.2 1.2 0 00-.57 1.21c0 .34.73 0 1.48.42a13.12 13.12 0 001.44.22 8.82 8.82 0 01.89.2c.3.12 1.32.15 1.36.39s-1.41 1.09-1.63 1.18c-1.1.42-2.89 1.63-2.82 2.72 0 .32 3.44-1.57 4.22-1.12s-1.24.36-1.7 1.53c-.55 1.38-2.58 1.15-2.67 1.4a1.38 1.38 0 01-.55.63c-.19.14-.24.49-.34.74a4.47 4.47 0 00.73 0c.2 0 .37-.18.57-.2s.25.25.24.27c-.56.62-2 1.33-1.64 1.94.14.24 1.41-.48 2.34-.69 1.46-.32 1.26-.77 2-.81s1.38-.65 1.12 0a1.26 1.26 0 01-1 .61c-.59.09-.88.7-.75.7.59 0 1.52.18 1.52.44 0 .45.63.22.88.45s2-1 1.91.16a4.78 4.78 0 01-2.57 2.5c-.59.28-2.32 1-2.35 1.85 0 1.19 5.09-.07 6.26.11s1.46.55.65 1.58a2.77 2.77 0 01-.82.66c-.49.28-.61.54-.29 1.08.48.81.1 1.41-.63 1.89a10.51 10.51 0 00-1.5 1.24c-.17.18-.17.52-.26.79a2.69 2.69 0 00.86.15 10.5 10.5 0 011.71-.38c1 0 1 .24.67 1.2a3.77 3.77 0 00-.25 1.32 2.94 2.94 0 01-1.11 2.22c-.29.28-.63.51-.89.8-.7.79-.67.81.23 1.42.25.17.57.52.54.76a1.45 1.45 0 01-.56 1c-.86.57 3.1-.46 4 2.54.1 1 3.38 1.55 2.76 2-1 .64-2.14 1-3.1 1.64a4.49 4.49 0 00-1.15 1.67 5.64 5.64 0 00.83.64c.15.13.36.24.43.41a2.26 2.26 0 002.19 1.32 5.68 5.68 0 011.44.59 7.47 7.47 0 01-1.28 1.18c-.55.3-1.26.33-1.83.62s.62.45.33.91a2.19 2.19 0 00-.07 1.44c0 .1.68.06 1 .13s.54.12.59.27a1 1 0 01-.06.81c-.25.3-2.35.6-2.63.89-.59.62-.52 1.19.29 1.49 1.93.72 4.35 2 3.4 3.58-.43.73-.06.6.31.7s.51 0 .75.11c.71.19.75.42.2 1-.35.36-2.47 1.13-2.79 1.52-.07.09-7.24 3.42.14 1.16.12 0 .92-.34 1.57-.61.5-.21 1.37-.32 1.95-.55.32-.13.79.26.9.62s-.12.85-.69 1a1.28 1.28 0 00-.82.52c-.37.89-1.31 1.48-1.26 2.64 0 .35-.67.83-1.13 1.07a2.37 2.37 0 00-.55.39c0 .19-.09.37-.12.56a.77.77 0 00.28.24c1 .55.75 1.24.62 2-.1.59 2.49-.64 3.35-.41a.83.83 0 01.43 1.44c-.6.71-.3.71.36.81.4.06 1.08.33 1.09.52a4.09 4.09 0 01-.42 1.69c-.1.22-.49.34-.77.44-.61.23-1.24.39-1.84.63a.55.55 0 00-.24.47c0 .11.32.31.39.28 1-.54 1.72.22 2.51.6.42.2-2.49 1.23-1.38 1.7.88.38.91-.26 1.44-.24 1.19 0-.32 1-2.23 1.08-1.08.06-1.51 1.23-1.75 1.42-.43.34-.32 1.14 1.91.26 1-.41 4.22 1.21 3.14 1.61-.1 0-1.67 1-1.72 1.1-.35.45-1 .46-.34 1.1.42.19.15.7.58.87.18.07 1.12.05 1.28.14.32.18 1.73-1.5 2.12-.62.15.34-2.21 2.08-2.52 2.3-.68.48-2.39 1.24-3 2-.19.25 1.55-.33 1.76-.48a1.26 1.26 0 011.69.12c.05.21-2.71 1-3.45 2-.27.38-.29.83-.72 1.16s-.65.57.12.77c.25.07 4.05-1.18 5.44-1s.09.9-.14 1.13-.29 1.86-.47 2c-.37.32-1.45 1-1.64 1.42-.47 1.08 7.18 2 5.95 2.58C204 271.93 5.59 230.18.86 228.21a.86.86 0 00.07-.45z' fill='%23f5f200'%3e %3c/path%3e %3cpath d='M859.91 169.81c2.41-1.89 4.84-3.76 7.28-5.64 22.46-17.29 45.68-35.18 45.68-61.32 0-20.48-14.78-34.78-35.94-34.78-18.58 0-38.59 12.44-38.59 39.75a29.55 29.55 0 00.22 3.7l15.16-5.85c0-15 11.18-22.88 22.22-22.88 10.73 0 21.55 6.82 21.55 22 0 19.73-20.14 35.17-48 56.55-4 3.05-8.11 6.22-12.38 9.55l-.25.2v14.55H916v-15.83zM482.57 118.75l-1.37-.55c-12.47-5-21.3-9.44-21.3-20.61 0-11 8.76-16.75 17.41-16.75 7 0 15.83 3.71 19.28 11.83L511.27 87l-.22-.55c-5.78-14.35-21-20.78-33.57-20.78-16.43 0-34.12 10.36-34.12 33.12 0 22.22 17 29.15 30.7 34.71l1.68.69c14 5.76 23.13 10.39 23.13 21.77 0 11.8-9.91 17.08-19.73 17.08s-21.31-5.18-24.73-19.72l-.15-.64-15.57 5.91c4.69 18.16 20.18 29.83 39.78 29.83 9.86 0 19-3 25.84-8.47 7.69-6.17 11.76-15 11.76-25.48 0-22.37-17.8-29.47-33.5-35.72zM647.4 98.27c-24.28 0-41.91 18.81-41.91 44.72s17.63 44.73 41.91 44.73 41.91-18.81 41.91-44.73-17.63-44.72-41.91-44.72zM673.93 143c0 19.81-13.26 30.17-26.36 30.17-13.27 0-26.7-10.36-26.7-30.17 0-17.38 11.23-30 26.7-30 15.27 0 26.36 12.61 26.36 30zM753.53 149.45c0 15.73-11.53 24.21-22.38 24.21-8.26 0-17.09-4.92-17.09-18.74v-54.5H699v54.5c0 24.21 15.7 32.8 29.14 32.8 10.82 0 20.35-5.18 25.29-13.62l2.87 11.63h12.26v-85.31h-15.03zM807.79 76.1l-15 5.8v18.52h-14.3v13.73h14.25v46.74c0 23.34 13.28 26.83 21.2 26.83a40.24 40.24 0 0011.11-1.72l.47-.13V171l-1 .64a14.27 14.27 0 01-7.27 2.38c-6 0-9.46-4.35-9.46-11.94v-47.9h17.73v-13.76h-17.73zM985.73 141.64v-34.6l-15.37 5.94v28.66h-34.51l42.08-71.75h-17.07l-44.52 75.7v11.6h54.02v28.5h15.37v-28.5h19.89v-15.55h-19.89zM587.45 159.84A24.6 24.6 0 01565.63 173c-12.79 0-25.7-9.33-25.7-30.17 0-14.38 7.73-29.84 24.7-29.84a22.5 22.5 0 0120 11.91l14.37-5.49-.26-.55c-6-12.7-19-20.59-34.06-20.59a38.86 38.86 0 00-27.68 11.1c-8.15 8.08-12.46 19.71-12.46 33.62 0 30.73 21 44.73 40.42 44.73 15.12 0 28.53-8.25 35.86-22.06l.29-.54-.12-.06z M96.94 67.69h-15.8l-50.93 118h18.64L61 156.5h56.16l12.1 29.19h18.65zm13.88 73.63H67.09L89 88.46zM204.47 100v49.21c0 15.64-11.47 24.09-22.26 24.09-8.2 0-17-4.89-17-18.62V100h-15.3v54.68c0 10.44 3.09 19.06 9 24.92a28.41 28.41 0 0020.35 8.05c10.75 0 20.23-5.09 25.26-13.4l2.81 11.41h12.52V100zM277.6 114.05V100h-17.75V75.62l-15.34 5.92V100h-14.26v14h14.26v46.63c0 23.49 13.38 27 21.35 27A40.59 40.59 0 00277 186l.57-.17v-15.32l-1.22.79a14.2 14.2 0 01-7.2 2.36c-5.93 0-9.33-4.31-9.33-11.82v-47.79zM325.78 97.87c-12.38 0-23 4.58-30.75 13.24-7.31 8.18-11.33 19.42-11.33 31.66s4 23.57 11.33 31.73c7.73 8.62 18.36 13.18 30.75 13.18 24.38 0 42.08-18.89 42.08-44.91s-17.7-44.9-42.08-44.9zm.17 75c-13.21 0-26.58-10.32-26.58-30.06 0-17.32 11.18-29.89 26.58-29.89 15.2 0 26.24 12.57 26.24 29.89 0 19.7-13.19 30.02-26.19 30.02z'%3e %3c/path%3e%3c/svg%3e";
8834
+
8835
+ var DrawerIndicator = function (_a) {
8836
+ var isOpen = _a.isOpen;
8837
+ return (React.createElement(react$1.Box, { hideBelow: "xs", display: "inline-flex" },
8838
+ React.createElement(ChevronDownSmallIcon, { transition: "transform", transitionDuration: "fast", color: isOpen ? 'blue.700' : 'currentColor', transform: isOpen ? 'rotate(180deg)' : 'rotate(0deg)' })));
8278
8839
  };
8279
8840
 
8280
- var Tab = function (_a) {
8281
- var variant = _a.variant, children = _a.children, rest = __rest(_a, ["variant", "children"]);
8282
- var recipe = react$1.useSlotRecipe({ key: 'tabs' });
8283
- var styles = recipe({ variant: variant });
8284
- return (React.createElement(react$1.Tabs.Trigger, __assign({}, rest, { css: styles.trigger }), children));
8841
+ var NavigationItem = function (_a) {
8842
+ var translationKey = _a.translationKey, drawerHandler = _a.drawerHandler, isOpen = _a.isOpen;
8843
+ var t = i18nPkg.useI18n().t;
8844
+ var recipe = react$1.useSlotRecipe({ key: 'link' });
8845
+ var styles = recipe({ variant: 'navigationLink' });
8846
+ return (React.createElement(react$1.Box, { onClick: drawerHandler, css: __assign({}, styles.root), fontWeight: "bold", color: isOpen ? 'blue.700' : 'gray.900', _hover: { color: 'blue.700' }, position: "relative", cursor: "pointer", display: "flex", alignItems: "center" },
8847
+ t(translationKey),
8848
+ " ",
8849
+ React.createElement(DrawerIndicator, { isOpen: isOpen })));
8285
8850
  };
8286
8851
 
8287
- var TabList = function (_a) {
8288
- var variant = _a.variant, children = _a.children, rest = __rest(_a, ["variant", "children"]);
8289
- var recipe = react$1.useSlotRecipe({ key: 'tabs' });
8852
+ var NavigationLink = function (_a) {
8853
+ var link = _a.link, title = _a.title, translationKey = _a.translationKey, _b = _a.translationParameters, translationParameters = _b === void 0 ? {} : _b, isNew = _a.isNew, _c = _a.fontWeight, fontWeight = _c === void 0 ? 'regular' : _c, _d = _a.variant, variant = _d === void 0 ? 'navigationLink' : _d, color = _a.color, leftIcon = _a.leftIcon, rightIcon = _a.rightIcon, hideTextBelow = _a.hideTextBelow, onClick = _a.onClick;
8854
+ var _e = i18nPkg.useI18n(), t = _e.t, language = _e.language;
8855
+ var linkColor = color || 'gray.900';
8856
+ var hoverStyle = variant === 'navigationLink' ? { color: 'blue.700' } : undefined;
8857
+ return (React.createElement(Link$1, { href: link && link[language], variant: variant, fontWeight: fontWeight, css: { color: linkColor }, _hover: hoverStyle, onClick: onClick, display: "flex", alignItems: "center", gap: "md" },
8858
+ leftIcon,
8859
+ (translationKey || title) && (React.createElement(react$1.Box, { hideBelow: hideTextBelow },
8860
+ translationKey ? t(translationKey, translationParameters) : title,
8861
+ isNew ? React.createElement(Badge, { variant: "navigationLinkBadge", text: "New" }) : null)),
8862
+ rightIcon));
8863
+ };
8864
+
8865
+ var HeaderLink = function (_a) {
8866
+ var link = _a.link;
8867
+ return (React.createElement(react$1.Box, { hideBelow: link.showUnderMoreLinkBelow },
8868
+ React.createElement(NavigationLink, __assign({}, link, { fontWeight: "bold" }))));
8869
+ };
8870
+
8871
+ var autoScoutVehiclesLinkConfig = {
8872
+ translationKey: 'header.userMenu.myVehicles',
8873
+ projectIdentifier: 'seller-web',
8874
+ link: {
8875
+ de: '/de/vehicle-management',
8876
+ en: '/en/vehicle-management',
8877
+ fr: '/fr/vehicle-management',
8878
+ it: '/it/vehicle-management',
8879
+ },
8880
+ visibilitySettings: {
8881
+ userType: {
8882
+ private: true,
8883
+ professional: true,
8884
+ },
8885
+ brand: {
8886
+ autoscout24: true,
8887
+ motoscout24: false,
8888
+ },
8889
+ },
8890
+ };
8891
+ var motoScoutVehiclesLinkConfig = {
8892
+ translationKey: 'header.userMenu.myMotorcycles',
8893
+ projectIdentifier: 'seller-web',
8894
+ link: {
8895
+ de: '/de/vehicle-management',
8896
+ en: '/en/vehicle-management',
8897
+ fr: '/fr/vehicle-management',
8898
+ it: '/it/vehicle-management',
8899
+ },
8900
+ visibilitySettings: {
8901
+ userType: {
8902
+ private: true,
8903
+ professional: true,
8904
+ },
8905
+ brand: {
8906
+ autoscout24: false,
8907
+ motoscout24: true,
8908
+ },
8909
+ },
8910
+ };
8911
+ var motorcycleParkLinkConfig = {
8912
+ translationKey: 'header.userMenu.motorcyclePark',
8913
+ forceMotoscoutLink: true,
8914
+ link: {
8915
+ de: '/de/vehicle-management',
8916
+ en: '/en/vehicle-management',
8917
+ fr: '/fr/vehicle-management',
8918
+ it: '/it/vehicle-management',
8919
+ },
8920
+ visibilitySettings: {
8921
+ userType: {
8922
+ private: true,
8923
+ professional: true,
8924
+ },
8925
+ brand: {
8926
+ autoscout24: true,
8927
+ motoscout24: false,
8928
+ },
8929
+ },
8930
+ };
8931
+ var carParkLinkConfig = {
8932
+ translationKey: 'header.userMenu.carPark',
8933
+ forceAutoscoutLink: true,
8934
+ link: {
8935
+ de: '/de/vehicle-management',
8936
+ en: '/en/vehicle-management',
8937
+ fr: '/fr/vehicle-management',
8938
+ it: '/it/vehicle-management',
8939
+ },
8940
+ visibilitySettings: {
8941
+ userType: {
8942
+ private: true,
8943
+ professional: true,
8944
+ },
8945
+ brand: {
8946
+ autoscout24: false,
8947
+ motoscout24: true,
8948
+ },
8949
+ },
8950
+ };
8951
+
8952
+ var navigationEventCategory = 'www_Interaction_PI-Navigation';
8953
+
8954
+ var savedSearchesLinkConfig = {
8955
+ translationKey: 'header.userMenu.requisitions',
8956
+ link: {
8957
+ de: '/de/me/saved-searches',
8958
+ en: '/de/me/saved-searches',
8959
+ fr: '/fr/me/saved-searches',
8960
+ it: '/it/me/saved-searches',
8961
+ },
8962
+ visibilitySettings: {
8963
+ userType: {
8964
+ private: true,
8965
+ professional: true,
8966
+ },
8967
+ brand: {
8968
+ autoscout24: true,
8969
+ motoscout24: true,
8970
+ },
8971
+ },
8972
+ projectIdentifier: 'listings-web',
8973
+ };
8974
+ var editUsersLinkConfig = {
8975
+ translationKey: 'header.userMenu.editUser',
8976
+ link: {
8977
+ de: '/de/account/user-list',
8978
+ en: '/en/account/user-list',
8979
+ fr: '/fr/account/user-list',
8980
+ it: '/it/account/user-list',
8981
+ },
8982
+ visibilitySettings: {
8983
+ userType: {
8984
+ private: false,
8985
+ professional: true,
8986
+ },
8987
+ brand: {
8988
+ autoscout24: true,
8989
+ motoscout24: true,
8990
+ },
8991
+ },
8992
+ };
8993
+ var changeLanguageLinkConfig = {
8994
+ translationKey: 'header.userMenu.userLanguage',
8995
+ link: {
8996
+ de: '/de/account/change-language',
8997
+ en: '/en/account/change-language',
8998
+ fr: '/fr/account/change-language',
8999
+ it: '/it/account/change-language',
9000
+ },
9001
+ visibilitySettings: {
9002
+ userType: {
9003
+ private: true,
9004
+ professional: true,
9005
+ },
9006
+ brand: {
9007
+ autoscout24: true,
9008
+ motoscout24: true,
9009
+ },
9010
+ },
9011
+ };
9012
+ var getFavoritesLinkConfig = function (_a) {
9013
+ var trackEvent = _a.trackEvent, eventLabel = _a.eventLabel;
9014
+ return ({
9015
+ translationKey: 'header.userMenu.bookmarks',
9016
+ link: {
9017
+ de: '/de/me/favorites',
9018
+ en: '/de/me/favorites',
9019
+ fr: '/fr/me/favorites',
9020
+ it: '/it/me/favorites',
9021
+ },
9022
+ visibilitySettings: {
9023
+ userType: {
9024
+ private: true,
9025
+ professional: true,
9026
+ guest: false,
9027
+ },
9028
+ brand: {
9029
+ autoscout24: true,
9030
+ motoscout24: true,
9031
+ },
9032
+ },
9033
+ projectIdentifier: 'listings-web',
9034
+ onClick: function () {
9035
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9036
+ eventCategory: navigationEventCategory,
9037
+ eventAction: 'open_favorites',
9038
+ eventLabel: eventLabel,
9039
+ });
9040
+ },
9041
+ });
9042
+ };
9043
+ var getLogoutLinkConfig = function (_a) {
9044
+ var onLogout = _a.onLogout;
9045
+ return ({
9046
+ translationKey: 'header.userMenu.logout',
9047
+ color: 'red.500',
9048
+ onClick: onLogout,
9049
+ visibilitySettings: {
9050
+ userType: {
9051
+ private: true,
9052
+ professional: true,
9053
+ },
9054
+ brand: {
9055
+ autoscout24: true,
9056
+ motoscout24: true,
9057
+ },
9058
+ },
9059
+ });
9060
+ };
9061
+
9062
+ var autoScoutTopVehiclesLinkConfig = {
9063
+ translationKey: 'header.userMenu.topCars',
9064
+ link: {
9065
+ de: '/de/features/top-vehicle/manage',
9066
+ en: '/de/features/top-vehicle/manage',
9067
+ fr: '/fr/features/top-vehicle/manage',
9068
+ it: '/it/features/top-vehicle/manage',
9069
+ },
9070
+ visibilitySettings: {
9071
+ userType: {
9072
+ private: false,
9073
+ professional: true,
9074
+ },
9075
+ brand: {
9076
+ autoscout24: true,
9077
+ motoscout24: false,
9078
+ },
9079
+ },
9080
+ };
9081
+ var motoScoutTopVehiclesLinkConfig = {
9082
+ translationKey: 'header.userMenu.topMotos',
9083
+ link: {
9084
+ de: '/de/features/top-vehicle/manage',
9085
+ en: '/de/features/top-vehicle/manage',
9086
+ fr: '/fr/features/top-vehicle/manage',
9087
+ it: '/it/features/top-vehicle/manage',
9088
+ },
9089
+ visibilitySettings: {
9090
+ userType: {
9091
+ private: false,
9092
+ professional: true,
9093
+ },
9094
+ brand: {
9095
+ autoscout24: false,
9096
+ motoscout24: true,
9097
+ },
9098
+ },
9099
+ };
9100
+
9101
+ var Entitlement;
9102
+ (function (Entitlement) {
9103
+ Entitlement["BusinessImage"] = "business-image";
9104
+ Entitlement["Optimizer"] = "optimizer";
9105
+ Entitlement["OptimizerPro"] = "optimizer-pro";
9106
+ Entitlement["AutoRadar"] = "auto-radar";
9107
+ Entitlement["AutoRadarFast"] = "auto-radar-fast";
9108
+ Entitlement["ListingVisibilityStandard"] = "listing-visibility-standard";
9109
+ Entitlement["ListingVisibilityPremium"] = "listing-visibility-premium";
9110
+ Entitlement["MarketPriceCheck"] = "market-price-check";
9111
+ })(Entitlement || (Entitlement = {}));
9112
+
9113
+ var topListingProLinkConfig = {
9114
+ translationKey: 'header.userMenu.topListingPro',
9115
+ link: {
9116
+ de: '/de/features/top-list/manage',
9117
+ en: '/de/features/top-list/manage',
9118
+ fr: '/fr/features/top-list/manage',
9119
+ it: '/it/features/top-list/manage',
9120
+ },
9121
+ visibilitySettings: {
9122
+ userType: {
9123
+ private: false,
9124
+ professional: true,
9125
+ },
9126
+ brand: {
9127
+ autoscout24: true,
9128
+ motoscout24: true,
9129
+ },
9130
+ },
9131
+ entitlementConfig: {
9132
+ singleRequiredEntitlement: [
9133
+ Entitlement.ListingVisibilityStandard,
9134
+ Entitlement.ListingVisibilityPremium,
9135
+ ],
9136
+ missingEntitlementTranslationKey: 'header.userMenu.topListing',
9137
+ },
9138
+ };
9139
+
9140
+ var teaserTemplatesLinkConfig = {
9141
+ translationKey: 'header.userMenu.manageAdditionalTitles',
9142
+ link: {
9143
+ de: '/de/info-management/additional-titles',
9144
+ en: '/en/info-management/additional-titles',
9145
+ fr: '/fr/info-management/additional-titles',
9146
+ it: '/it/info-management/additional-titles',
9147
+ },
9148
+ visibilitySettings: {
9149
+ userType: {
9150
+ private: false,
9151
+ professional: true,
9152
+ },
9153
+ brand: {
9154
+ autoscout24: true,
9155
+ motoscout24: true,
9156
+ },
9157
+ },
9158
+ };
9159
+ var commentTemplatesLinkConfig = {
9160
+ translationKey: 'header.userMenu.manageNotes',
9161
+ link: {
9162
+ de: '/de/info-management/comment',
9163
+ en: '/en/info-management/comment',
9164
+ fr: '/fr/info-management/comment',
9165
+ it: '/it/info-management/comment',
9166
+ },
9167
+ visibilitySettings: {
9168
+ userType: {
9169
+ private: false,
9170
+ professional: true,
9171
+ },
9172
+ brand: {
9173
+ autoscout24: true,
9174
+ motoscout24: true,
9175
+ },
9176
+ },
9177
+ };
9178
+
9179
+ var sellLinkConfig = function (_a) {
9180
+ var trackEvent = _a.trackEvent;
9181
+ return {
9182
+ translationKey: 'header.sell',
9183
+ showUnderMoreLinkBelow: 'sm',
9184
+ onClick: function () {
9185
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9186
+ eventCategory: navigationEventCategory,
9187
+ eventAction: 'sell',
9188
+ });
9189
+ },
9190
+ };
9191
+ };
9192
+ var privateAutoScoutSellLinkConfig = function (_a) {
9193
+ var trackEvent = _a.trackEvent;
9194
+ return __assign(__assign({}, sellLinkConfig({ trackEvent: trackEvent })), { projectIdentifier: 'seller-web', link: {
9195
+ de: '/de/sell',
9196
+ en: '/en/sell',
9197
+ fr: '/fr/sell',
9198
+ it: '/it/sell',
9199
+ }, visibilitySettings: {
9200
+ userType: {
9201
+ private: true,
9202
+ professional: false,
9203
+ },
9204
+ brand: {
9205
+ autoscout24: true,
9206
+ motoscout24: false,
9207
+ },
9208
+ } });
9209
+ };
9210
+ var professionalSellLinkConfig = function (_a) {
9211
+ var trackEvent = _a.trackEvent;
9212
+ return __assign(__assign({}, sellLinkConfig({ trackEvent: trackEvent })), { projectIdentifier: 'seller-web', link: {
9213
+ de: '/de/insertion/identify',
9214
+ en: '/en/insertion/identify',
9215
+ fr: '/fr/insertion/identify',
9216
+ it: '/it/insertion/identify',
9217
+ }, visibilitySettings: {
9218
+ userType: {
9219
+ guest: false,
9220
+ private: false,
9221
+ professional: true,
9222
+ },
9223
+ brand: {
9224
+ autoscout24: true,
9225
+ motoscout24: true,
9226
+ },
9227
+ } });
9228
+ };
9229
+ var privateMotoScoutSellLinkConfig = function (_a) {
9230
+ var trackEvent = _a.trackEvent;
9231
+ return __assign(__assign({ projectIdentifier: 'seller-web' }, sellLinkConfig({ trackEvent: trackEvent })), { link: {
9232
+ de: '/de/insertion/identify',
9233
+ en: '/en/insertion/identify',
9234
+ fr: '/fr/insertion/identify',
9235
+ it: '/it/insertion/identify',
9236
+ }, visibilitySettings: {
9237
+ userType: {
9238
+ private: true,
9239
+ professional: false,
9240
+ },
9241
+ brand: {
9242
+ autoscout24: false,
9243
+ motoscout24: true,
9244
+ },
9245
+ } });
9246
+ };
9247
+ var insertionLinkConfig = {
9248
+ translationKey: 'header.userMenu.createAd',
9249
+ projectIdentifier: 'seller-web',
9250
+ link: {
9251
+ de: '/de/insertion/identify',
9252
+ en: '/en/insertion/identify',
9253
+ fr: '/fr/insertion/identify',
9254
+ it: '/it/insertion/identify',
9255
+ },
9256
+ visibilitySettings: {
9257
+ userType: {
9258
+ private: true,
9259
+ professional: true,
9260
+ },
9261
+ brand: {
9262
+ autoscout24: true,
9263
+ motoscout24: true,
9264
+ },
9265
+ },
9266
+ };
9267
+
9268
+ var simpleSearchLinkConfig = {
9269
+ translationKey: 'header.searchMenu.simpleSearch',
9270
+ link: {
9271
+ de: '/de',
9272
+ en: '/de',
9273
+ fr: '/fr',
9274
+ it: '/it',
9275
+ },
9276
+ visibilitySettings: {
9277
+ userType: {
9278
+ private: true,
9279
+ professional: true,
9280
+ },
9281
+ brand: {
9282
+ autoscout24: true,
9283
+ motoscout24: true,
9284
+ },
9285
+ },
9286
+ projectIdentifier: 'listings-web',
9287
+ };
9288
+ var advancedSearchLinkConfig = {
9289
+ translationKey: 'header.searchMenu.advancedSearch',
9290
+ link: {
9291
+ de: '/de/s/advanced',
9292
+ en: '/de/s/advanced',
9293
+ fr: '/fr/s/advanced',
9294
+ it: '/it/s/advanced',
9295
+ },
9296
+ visibilitySettings: {
9297
+ userType: {
9298
+ private: true,
9299
+ professional: true,
9300
+ },
9301
+ brand: {
9302
+ autoscout24: true,
9303
+ motoscout24: true,
9304
+ },
9305
+ },
9306
+ projectIdentifier: 'listings-web',
9307
+ };
9308
+ var autoScoutSellerSearchLinkConfig = {
9309
+ translationKey: 'header.searchMenu.searchMerchant',
9310
+ link: {
9311
+ de: '/de/sellers/search',
9312
+ en: '/de/sellers/search',
9313
+ fr: '/fr/sellers/search',
9314
+ it: '/it/sellers/search',
9315
+ },
9316
+ visibilitySettings: {
9317
+ userType: {
9318
+ private: true,
9319
+ professional: true,
9320
+ },
9321
+ brand: {
9322
+ autoscout24: true,
9323
+ motoscout24: false,
9324
+ },
9325
+ },
9326
+ projectIdentifier: 'listings-web',
9327
+ };
9328
+ var motoScoutSellerSearchLinkConfig = {
9329
+ translationKey: 'header.searchMenu.searchMerchant',
9330
+ link: {
9331
+ de: '/de/sellers/search',
9332
+ en: '/de/sellers/search',
9333
+ fr: '/fr/sellers/search',
9334
+ it: '/it/sellers/search',
9335
+ },
9336
+ visibilitySettings: {
9337
+ userType: {
9338
+ private: true,
9339
+ professional: true,
9340
+ },
9341
+ brand: {
9342
+ autoscout24: false,
9343
+ motoscout24: true,
9344
+ },
9345
+ },
9346
+ };
9347
+ var searchMotorcycleLinkConfig = {
9348
+ translationKey: 'header.searchMenu.searchMotorcycles',
9349
+ forceMotoscoutLink: true,
9350
+ link: {
9351
+ de: '/de',
9352
+ en: '/de',
9353
+ fr: '/fr',
9354
+ it: '/it',
9355
+ },
9356
+ visibilitySettings: {
9357
+ userType: {
9358
+ private: true,
9359
+ professional: true,
9360
+ },
9361
+ brand: {
9362
+ autoscout24: true,
9363
+ motoscout24: false,
9364
+ },
9365
+ },
9366
+ projectIdentifier: 'listings-web',
9367
+ };
9368
+ var searchCarsLinkConfig = {
9369
+ translationKey: 'header.searchMenu.searchCars',
9370
+ forceAutoscoutLink: true,
9371
+ link: {
9372
+ de: '/de',
9373
+ en: '/de',
9374
+ fr: '/fr',
9375
+ it: '/it',
9376
+ },
9377
+ visibilitySettings: {
9378
+ userType: {
9379
+ private: true,
9380
+ professional: true,
9381
+ },
9382
+ brand: {
9383
+ autoscout24: false,
9384
+ motoscout24: true,
9385
+ },
9386
+ },
9387
+ projectIdentifier: 'listings-web',
9388
+ };
9389
+
9390
+ var printCenterLinkConfig = {
9391
+ translationKey: 'header.userMenu.printingCenter',
9392
+ link: {
9393
+ de: '/de/vehicle-management',
9394
+ en: '/en/vehicle-management',
9395
+ fr: '/fr/vehicle-management',
9396
+ it: '/it/vehicle-management',
9397
+ },
9398
+ visibilitySettings: {
9399
+ userType: {
9400
+ private: false,
9401
+ professional: true,
9402
+ },
9403
+ brand: {
9404
+ autoscout24: true,
9405
+ motoscout24: true,
9406
+ },
9407
+ },
9408
+ };
9409
+
9410
+ var infoPageLinkConfig = {
9411
+ translationKey: 'header.userMenu.infoPage',
9412
+ projectIdentifier: 'seller-web',
9413
+ link: {
9414
+ de: '/de/info-management/hero-image',
9415
+ en: '/en/info-management/hero-image',
9416
+ fr: '/fr/info-management/hero-image',
9417
+ it: '/it/info-management/hero-image',
9418
+ },
9419
+ visibilitySettings: {
9420
+ userType: {
9421
+ private: false,
9422
+ professional: true,
9423
+ },
9424
+ brand: {
9425
+ autoscout24: true,
9426
+ motoscout24: true,
9427
+ },
9428
+ },
9429
+ };
9430
+ var contactDetailsLinkConfig = {
9431
+ translationKey: 'header.userMenu.contactDetails',
9432
+ link: {
9433
+ de: '/de/profile',
9434
+ en: '/en/profile',
9435
+ fr: '/fr/profile',
9436
+ it: '/it/profile',
9437
+ },
9438
+ visibilitySettings: {
9439
+ userType: {
9440
+ private: true,
9441
+ professional: true,
9442
+ },
9443
+ brand: {
9444
+ autoscout24: true,
9445
+ motoscout24: true,
9446
+ },
9447
+ },
9448
+ projectIdentifier: 'seller-web',
9449
+ };
9450
+ var openingHoursLinkConfig = {
9451
+ translationKey: 'header.userMenu.openingHours',
9452
+ link: {
9453
+ de: '/de/info-management/opening-hours',
9454
+ en: '/en/info-management/opening-hours',
9455
+ fr: '/fr/info-management/opening-hours',
9456
+ it: '/it/info-management/opening-hours',
9457
+ },
9458
+ visibilitySettings: {
9459
+ userType: {
9460
+ private: false,
9461
+ professional: true,
9462
+ },
9463
+ brand: {
9464
+ autoscout24: true,
9465
+ motoscout24: true,
9466
+ },
9467
+ },
9468
+ };
9469
+ var businessImageLinkConfig = {
9470
+ translationKey: 'header.userMenu.businessImage',
9471
+ link: {
9472
+ de: '/de/info-management/business-image',
9473
+ en: '/en/info-management/business-image',
9474
+ fr: '/fr/info-management/business-image',
9475
+ it: '/it/info-management/business-image',
9476
+ },
9477
+ visibilitySettings: {
9478
+ userType: {
9479
+ private: false,
9480
+ professional: true,
9481
+ },
9482
+ brand: {
9483
+ autoscout24: true,
9484
+ motoscout24: true,
9485
+ },
9486
+ },
9487
+ entitlementConfig: {
9488
+ singleRequiredEntitlement: [Entitlement.BusinessImage],
9489
+ missingEntitlementFallbackLink: {
9490
+ de: '/de/info-management/business-image',
9491
+ en: '/en/info-management/business-image',
9492
+ fr: '/fr/info-management/business-image',
9493
+ it: '/it/info-management/business-image',
9494
+ },
9495
+ missingEntitlementLinkIcon: React.createElement(CartIcon, null),
9496
+ },
9497
+ };
9498
+ var photoBarLinkConfig = {
9499
+ translationKey: 'header.userMenu.editPhotobar',
9500
+ link: {
9501
+ de: '/de/info-management/photo-bar',
9502
+ en: '/en/info-management/photo-bar',
9503
+ fr: '/fr/info-management/photo-bar',
9504
+ it: '/it/info-management/photo-bar',
9505
+ },
9506
+ visibilitySettings: {
9507
+ userType: {
9508
+ private: false,
9509
+ professional: true,
9510
+ },
9511
+ brand: {
9512
+ autoscout24: true,
9513
+ motoscout24: true,
9514
+ },
9515
+ },
9516
+ };
9517
+ var qualilogoLinkConfig = {
9518
+ translationKey: 'header.userMenu.qualityLogo',
9519
+ link: {
9520
+ de: '/de/info-management/quali-logo',
9521
+ en: '/en/info-management/quali-logo',
9522
+ fr: '/fr/info-management/quali-logo',
9523
+ it: '/it/info-management/quali-logo',
9524
+ },
9525
+ visibilitySettings: {
9526
+ userType: {
9527
+ private: false,
9528
+ professional: true,
9529
+ },
9530
+ brand: {
9531
+ autoscout24: true,
9532
+ motoscout24: true,
9533
+ },
9534
+ },
9535
+ };
9536
+
9537
+ var getPartnerHubLinkConfig = function (_a) {
9538
+ var sellerId = _a.sellerId;
9539
+ return ({
9540
+ translationKey: 'header.userMenu.partnerHub',
9541
+ link: {
9542
+ de: "https://partnerhub.financescout24.ch/de/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation"),
9543
+ en: "https://partnerhub.financescout24.ch/de/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation"),
9544
+ fr: "https://partnerhub.financescout24.ch/fr/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation"),
9545
+ it: "https://partnerhub.financescout24.ch/it/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation"),
9546
+ },
9547
+ visibilitySettings: {
9548
+ userType: {
9549
+ private: false,
9550
+ professional: true,
9551
+ },
9552
+ brand: {
9553
+ autoscout24: true,
9554
+ motoscout24: false,
9555
+ },
9556
+ },
9557
+ });
9558
+ };
9559
+
9560
+ var optimizerLinkConfig = {
9561
+ translationKey: 'header.userMenu.optimizerPro',
9562
+ link: {
9563
+ de: 'https://b2b.autoscout24.ch/aboss/optimizer-2/',
9564
+ en: 'https://b2b.autoscout24.ch/aboss/optimizer-2/',
9565
+ fr: 'https://b2b.autoscout24.ch/fr/aboss/optimizer-2/',
9566
+ it: 'https://b2b.autoscout24.ch/it/aboss/optimizer-2/',
9567
+ },
9568
+ visibilitySettings: {
9569
+ userType: {
9570
+ private: false,
9571
+ professional: true,
9572
+ },
9573
+ brand: {
9574
+ autoscout24: true,
9575
+ motoscout24: true,
9576
+ },
9577
+ },
9578
+ entitlementConfig: {
9579
+ hideIfEntitlementIsPresent: Entitlement.OptimizerPro,
9580
+ singleRequiredEntitlement: [Entitlement.Optimizer],
9581
+ missingEntitlementFallbackLink: {
9582
+ de: 'https://b2b.autoscout24.ch/aboss/optimizer-2/',
9583
+ en: 'https://b2b.autoscout24.ch/aboss/optimizer-2/',
9584
+ fr: 'https://b2b.autoscout24.ch/fr/aboss/optimizer-2/',
9585
+ it: 'https://b2b.autoscout24.ch/it/aboss/optimizer-2/',
9586
+ },
9587
+ missingEntitlementTranslationKey: 'header.userMenu.optimizer',
9588
+ },
9589
+ };
9590
+
9591
+ var marketPriceCheckLinkConfig = {
9592
+ translationKey: 'header.userMenu.marketPriceCheck',
9593
+ link: {
9594
+ de: '/de/market-price-check',
9595
+ en: '/de/market-price-check',
9596
+ fr: '/fr/market-price-check',
9597
+ it: '/it/market-price-check',
9598
+ },
9599
+ visibilitySettings: {
9600
+ userType: {
9601
+ private: false,
9602
+ professional: true,
9603
+ },
9604
+ brand: {
9605
+ autoscout24: true,
9606
+ motoscout24: true,
9607
+ },
9608
+ },
9609
+ entitlementConfig: {
9610
+ hideIfRequiredEntitlementIsMissing: !!Entitlement.MarketPriceCheck,
9611
+ singleRequiredEntitlement: [Entitlement.MarketPriceCheck],
9612
+ missingEntitlementTranslationKey: '',
9613
+ },
9614
+ };
9615
+
9616
+ var magazineLinkConfig = function (_a) {
9617
+ var trackEvent = _a.trackEvent;
9618
+ return {
9619
+ translationKey: 'header.magazine',
9620
+ link: {
9621
+ de: 'https://guide.motoscout24.ch/de/',
9622
+ en: 'https://guide.motoscout24.ch/de/',
9623
+ fr: 'https://guide.motoscout24.ch/fr/',
9624
+ it: 'https://guide.motoscout24.ch/it/',
9625
+ },
9626
+ showUnderMoreLinkBelow: 'lg',
9627
+ visibilitySettings: {
9628
+ userType: {
9629
+ private: true,
9630
+ professional: true,
9631
+ },
9632
+ brand: {
9633
+ autoscout24: false,
9634
+ motoscout24: true,
9635
+ },
9636
+ },
9637
+ onClick: function () {
9638
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9639
+ eventCategory: navigationEventCategory,
9640
+ eventAction: 'magazine',
9641
+ });
9642
+ },
9643
+ };
9644
+ };
9645
+
9646
+ var leadsManagementLinkConfig = {
9647
+ translationKey: 'header.userMenu.contactRequests',
9648
+ link: {
9649
+ de: '/de/message-manager',
9650
+ en: '/de/message-manager',
9651
+ fr: '/fr/message-manager',
9652
+ it: '/it/message-manager',
9653
+ },
9654
+ visibilitySettings: {
9655
+ userType: {
9656
+ private: true,
9657
+ professional: true,
9658
+ },
9659
+ brand: {
9660
+ autoscout24: true,
9661
+ motoscout24: true,
9662
+ },
9663
+ },
9664
+ };
9665
+
9666
+ var switchToGermanLinkConfig = function (_a) {
9667
+ var currentLanguage = _a.currentLanguage;
9668
+ return ({
9669
+ title: 'Deutsch',
9670
+ onClick: function () {
9671
+ return replaceLanguage({
9672
+ activeLanguage: currentLanguage,
9673
+ newLanguage: 'de',
9674
+ });
9675
+ },
9676
+ visibilitySettings: {
9677
+ userType: {
9678
+ private: true,
9679
+ professional: true,
9680
+ },
9681
+ brand: {
9682
+ autoscout24: true,
9683
+ motoscout24: true,
9684
+ },
9685
+ },
9686
+ });
9687
+ };
9688
+ var switchToFrenchLinkConfig = function (_a) {
9689
+ var currentLanguage = _a.currentLanguage;
9690
+ return ({
9691
+ title: 'Français',
9692
+ onClick: function () {
9693
+ return replaceLanguage({
9694
+ activeLanguage: currentLanguage,
9695
+ newLanguage: 'fr',
9696
+ });
9697
+ },
9698
+ visibilitySettings: {
9699
+ userType: {
9700
+ private: true,
9701
+ professional: true,
9702
+ },
9703
+ brand: {
9704
+ autoscout24: true,
9705
+ motoscout24: true,
9706
+ },
9707
+ },
9708
+ });
9709
+ };
9710
+ var switchToItalianLinkConfig = function (_a) {
9711
+ var currentLanguage = _a.currentLanguage;
9712
+ return ({
9713
+ title: 'Italiano',
9714
+ onClick: function () {
9715
+ return replaceLanguage({
9716
+ activeLanguage: currentLanguage,
9717
+ newLanguage: 'it',
9718
+ });
9719
+ },
9720
+ visibilitySettings: {
9721
+ userType: {
9722
+ private: true,
9723
+ professional: true,
9724
+ },
9725
+ brand: {
9726
+ autoscout24: true,
9727
+ motoscout24: true,
9728
+ },
9729
+ },
9730
+ });
9731
+ };
9732
+
9733
+ var getAutoScoutInsuranceComparisonLinkConfig = function (userVisibilitySettings) { return ({
9734
+ translationKey: 'header.searchMenu.insuranceComparison',
9735
+ link: {
9736
+ de: 'https://www.financescout24.ch/de/lp/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_car_',
9737
+ en: 'https://www.financescout24.ch/de/lp/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_car_',
9738
+ fr: 'https://www.financescout24.ch/fr/lp/trouver-assurance-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_car_',
9739
+ it: 'https://www.financescout24.ch/it/lp/trova-assicurazione-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_car_',
9740
+ },
9741
+ visibilitySettings: {
9742
+ userType: userVisibilitySettings,
9743
+ brand: {
9744
+ autoscout24: true,
9745
+ motoscout24: false,
9746
+ },
9747
+ },
9748
+ }); };
9749
+ var getMotoScoutInsuranceComparisonLinkConfig = function (userVisibilitySettings) { return ({
9750
+ translationKey: 'header.searchMenu.insuranceComparison',
9751
+ link: {
9752
+ de: 'https://www.financescout24.ch/de/lp/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_moto_',
9753
+ en: 'https://www.financescout24.ch/de/lp/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_moto_',
9754
+ fr: 'https://www.financescout24.ch/fr/lp/trouver-assurance-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_moto_',
9755
+ it: 'https://www.financescout24.ch/it/lp/trova-assicurazione-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=subnavigation_moto_',
9756
+ },
9757
+ visibilitySettings: {
9758
+ userType: userVisibilitySettings,
9759
+ brand: {
9760
+ autoscout24: false,
9761
+ motoscout24: true,
9762
+ },
9763
+ },
9764
+ }); };
9765
+ var getProfessionalAutoScoutInsuranceComparisonLinkConfig = function (_a) {
9766
+ var sellerId = _a.sellerId;
9767
+ return ({
9768
+ translationKey: 'header.userMenu.insuranceComparison',
9769
+ link: {
9770
+ de: "https://partnerhub.financescout24.ch/de/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation_insurance"),
9771
+ en: "https://partnerhub.financescout24.ch/de/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation_insurance"),
9772
+ fr: "https://partnerhub.financescout24.ch/fr/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation_insurance"),
9773
+ it: "https://partnerhub.financescout24.ch/it/landing?dealerId=".concat(sellerId, "&utm_source=autoscout24.ch&utm_medium=web&utm_campaign=link_as24_cardealer_portal_headernavigation_insurance"),
9774
+ },
9775
+ visibilitySettings: {
9776
+ userType: {
9777
+ private: false,
9778
+ professional: true,
9779
+ },
9780
+ brand: {
9781
+ autoscout24: true,
9782
+ motoscout24: false,
9783
+ },
9784
+ },
9785
+ });
9786
+ };
9787
+
9788
+ var infoPortalLinkConfig = {
9789
+ translationKey: 'header.userMenu.infoPortal',
9790
+ link: {
9791
+ de: 'https://b2b.autoscout24.ch/',
9792
+ en: 'https://b2b.autoscout24.ch/',
9793
+ fr: 'https://b2b.autoscout24.ch/fr/',
9794
+ it: 'https://b2b.autoscout24.ch/it/',
9795
+ },
9796
+ visibilitySettings: {
9797
+ userType: {
9798
+ private: false,
9799
+ professional: true,
9800
+ },
9801
+ brand: {
9802
+ autoscout24: true,
9803
+ motoscout24: false,
9804
+ },
9805
+ },
9806
+ };
9807
+
9808
+ var hciLinkConfig = {
9809
+ translationKey: 'header.userMenu.hci',
9810
+ link: {
9811
+ de: '/de/hci-management',
9812
+ en: '/en/hci-management',
9813
+ fr: '/fr/hci-management',
9814
+ it: '/it/hci-management',
9815
+ },
9816
+ visibilitySettings: {
9817
+ userType: {
9818
+ private: false,
9819
+ professional: true,
9820
+ },
9821
+ brand: {
9822
+ autoscout24: true,
9823
+ motoscout24: true,
9824
+ },
9825
+ },
9826
+ projectIdentifier: 'seller-web',
9827
+ };
9828
+
9829
+ var estimateLinkConfig = function (_a) {
9830
+ var trackEvent = _a.trackEvent;
9831
+ return {
9832
+ translationKey: 'header.estimate',
9833
+ link: {
9834
+ de: '/de/price-estimate',
9835
+ en: '/de/price-estimate',
9836
+ fr: '/fr/price-estimate',
9837
+ it: '/it/price-estimate',
9838
+ },
9839
+ showUnderMoreLinkBelow: 'sm',
9840
+ visibilitySettings: {
9841
+ userType: {
9842
+ private: true,
9843
+ professional: false,
9844
+ },
9845
+ brand: {
9846
+ autoscout24: true,
9847
+ motoscout24: false,
9848
+ },
9849
+ },
9850
+ onClick: function () {
9851
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9852
+ eventCategory: navigationEventCategory,
9853
+ eventAction: 'estimate',
9854
+ });
9855
+ },
9856
+ };
9857
+ };
9858
+
9859
+ var electromobilityLinkConfig = function (_a) {
9860
+ var trackEvent = _a.trackEvent;
9861
+ return {
9862
+ translationKey: 'header.electromobility',
9863
+ link: {
9864
+ de: 'https://guide.autoscout24.ch/de/elektromobilitaet/',
9865
+ en: 'https://guide.autoscout24.ch/de/elektromobilitaet/',
9866
+ fr: 'https://guide.autoscout24.ch/fr/mobilite-electrique/',
9867
+ it: 'https://guide.autoscout24.ch/it/mobilita-elettrica/',
9868
+ },
9869
+ showUnderMoreLinkBelow: 'lg',
9870
+ visibilitySettings: {
9871
+ userType: {
9872
+ private: true,
9873
+ professional: true,
9874
+ },
9875
+ brand: {
9876
+ autoscout24: true,
9877
+ motoscout24: false,
9878
+ },
9879
+ },
9880
+ onClick: function () {
9881
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9882
+ eventCategory: navigationEventCategory,
9883
+ eventAction: 'electromobility',
9884
+ });
9885
+ },
9886
+ };
9887
+ };
9888
+
9889
+ var shouldShowComparisonLink = function (comparisonItemIds) {
9890
+ return !!comparisonItemIds && Array.isArray(comparisonItemIds);
9891
+ };
9892
+ var getComparisonUrl = function (comparisonItemIds) {
9893
+ var basePathSegment = 'comparison';
9894
+ if (comparisonItemIds.length === 0)
9895
+ return basePathSegment;
9896
+ return "".concat(basePathSegment, "/").concat(comparisonItemIds.join('/'));
9897
+ };
9898
+ var ComparisonItem = function (_a) {
9899
+ var _b, _c;
9900
+ var link = _a.link, count = _a.count;
9901
+ var _d = i18nPkg.useI18n(), t = _d.t, language = _d.language;
9902
+ return (React.createElement(react$1.chakra.a, { position: "relative", display: "block", href: (_b = link.link) === null || _b === void 0 ? void 0 : _b[language], onClick: link.onClick, "aria-label": t((_c = link.translationKey) !== null && _c !== void 0 ? _c : '', link.translationParameters), mr: "lg" },
9903
+ React.createElement(CompareIcon, { color: "gray.900" }),
9904
+ React.createElement(react$1.Box, { position: "absolute", css: { top: '-10px', right: '-15px' } }, count > 0 ? React.createElement(Count, { count: count }) : null)));
9905
+ };
9906
+
9907
+ var comparisonLinkConfig = function (_a) {
9908
+ var comparisonItemIds = _a.comparisonItemIds;
9909
+ return {
9910
+ translationKey: 'header.searchMenu.comparison',
9911
+ translationParameters: {
9912
+ numberOfItems: comparisonItemIds.length,
9913
+ },
9914
+ link: {
9915
+ de: "/de/".concat(getComparisonUrl(comparisonItemIds)),
9916
+ en: "/en/".concat(getComparisonUrl(comparisonItemIds)),
9917
+ fr: "/fr/".concat(getComparisonUrl(comparisonItemIds)),
9918
+ it: "/it/".concat(getComparisonUrl(comparisonItemIds)),
9919
+ },
9920
+ visibilitySettings: {
9921
+ userType: {
9922
+ guest: true,
9923
+ private: true,
9924
+ professional: true,
9925
+ },
9926
+ brand: {
9927
+ autoscout24: true,
9928
+ motoscout24: true,
9929
+ },
9930
+ },
9931
+ projectIdentifier: 'listings-web',
9932
+ };
9933
+ };
9934
+ var getComparisonNodeItem = function (_a) {
9935
+ var comparisonItemIds = _a.comparisonItemIds, trackEvent = _a.trackEvent, eventLabel = _a.eventLabel;
9936
+ return shouldShowComparisonLink(comparisonItemIds)
9937
+ ? [
9938
+ __assign(__assign({}, comparisonLinkConfig({ comparisonItemIds: comparisonItemIds })), { onClick: function () {
9939
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
9940
+ eventCategory: navigationEventCategory,
9941
+ eventAction: 'open_comparison_tool',
9942
+ eventLabel: eventLabel,
9943
+ });
9944
+ } }),
9945
+ ]
9946
+ : [];
9947
+ };
9948
+
9949
+ var cockpitLinkConfig = {
9950
+ translationKey: 'header.userMenu.cockpit',
9951
+ link: {
9952
+ de: '/de/cockpit',
9953
+ en: '/de/cockpit',
9954
+ fr: '/fr/cockpit',
9955
+ it: '/it/cockpit',
9956
+ },
9957
+ visibilitySettings: {
9958
+ userType: {
9959
+ private: false,
9960
+ professional: true,
9961
+ },
9962
+ brand: {
9963
+ autoscout24: true,
9964
+ motoscout24: true,
9965
+ },
9966
+ },
9967
+ projectIdentifier: 'seller-web',
9968
+ };
9969
+
9970
+ var autoRadarLinkConfig = {
9971
+ translationKey: 'header.userMenu.autoRadar',
9972
+ link: {
9973
+ de: '/de/autoradar/saved-searches/all',
9974
+ en: '/de/autoradar/saved-searches/all',
9975
+ fr: '/fr/autoradar/saved-searches/all',
9976
+ it: '/it/autoradar/saved-searches/all',
9977
+ },
9978
+ visibilitySettings: {
9979
+ userType: {
9980
+ private: false,
9981
+ professional: true,
9982
+ },
9983
+ brand: {
9984
+ autoscout24: true,
9985
+ motoscout24: false,
9986
+ },
9987
+ },
9988
+ entitlementConfig: {
9989
+ singleRequiredEntitlement: [
9990
+ Entitlement.AutoRadar,
9991
+ Entitlement.AutoRadarFast,
9992
+ ],
9993
+ missingEntitlementFallbackLink: {
9994
+ de: '/de/autoradar',
9995
+ en: '/de/autoradar',
9996
+ fr: '/fr/autoradar',
9997
+ it: '/it/autoradar',
9998
+ },
9999
+ missingEntitlementLinkIcon: React.createElement(CartIcon, null),
10000
+ },
10001
+ projectIdentifier: 'listings-web',
10002
+ };
10003
+
10004
+ var autoScoutAssureLinkConfig = function (_a) {
10005
+ var trackEvent = _a.trackEvent;
10006
+ return {
10007
+ translationKey: 'header.assure',
10008
+ link: {
10009
+ de: 'https://www.financescout24.ch/de/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=insurance_hub_car_',
10010
+ en: 'https://www.financescout24.ch/de/autoversicherung-finden?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=insurance_hub_car_',
10011
+ fr: 'https://www.financescout24.ch/fr/trouver-assurance-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=insurance_hub_car_',
10012
+ it: 'https://www.financescout24.ch/it/trova-assicurazione-auto?utm_source=autoscout24.ch&utm_medium=web&utm_campaign=insurance_hub_car_',
10013
+ },
10014
+ showUnderMoreLinkBelow: 'lg',
10015
+ visibilitySettings: {
10016
+ userType: {
10017
+ private: true,
10018
+ professional: true,
10019
+ },
10020
+ brand: {
10021
+ autoscout24: true,
10022
+ motoscout24: false,
10023
+ },
10024
+ },
10025
+ onClick: function () {
10026
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
10027
+ eventCategory: navigationEventCategory,
10028
+ eventAction: 'insurance',
10029
+ });
10030
+ },
10031
+ };
10032
+ };
10033
+ var motoScoutAssureLinkConfig = function (_a) {
10034
+ var trackEvent = _a.trackEvent;
10035
+ return {
10036
+ translationKey: 'header.assure',
10037
+ link: {
10038
+ de: 'https://www.financescout24.ch/de/motorradversicherung?utm_source=motoscout24.ch&utm_medium=web&utm_campaign=main_navigation_moto_',
10039
+ en: 'https://www.financescout24.ch/de/motorradversicherung?utm_source=motoscout24.ch&utm_medium=web&utm_campaign=main_navigation_moto_',
10040
+ fr: 'https://www.financescout24.ch/fr/assurance-moto?utm_source=motoscout24.ch&utm_medium=web&utm_campaign=main_navigation_moto_',
10041
+ it: 'https://www.financescout24.ch/it/assicurazione-moto?utm_source=motoscout24.ch&utm_medium=web&utm_campaign=main_navigation_moto_',
10042
+ },
10043
+ showUnderMoreLinkBelow: 'lg',
10044
+ visibilitySettings: {
10045
+ userType: {
10046
+ private: true,
10047
+ professional: true,
10048
+ },
10049
+ brand: {
10050
+ autoscout24: false,
10051
+ motoscout24: true,
10052
+ },
10053
+ },
10054
+ onClick: function () {
10055
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
10056
+ eventCategory: navigationEventCategory,
10057
+ eventAction: 'insurance',
10058
+ });
10059
+ },
10060
+ };
10061
+ };
10062
+
10063
+ var onlineAdvertisingLinkConfig = {
10064
+ translationKey: 'header.userMenu.onlineAdvertising',
10065
+ link: {
10066
+ de: '/de/contact',
10067
+ en: '/en/contact',
10068
+ fr: '/fr/contact',
10069
+ it: '/it/contact',
10070
+ },
10071
+ visibilitySettings: {
10072
+ userType: {
10073
+ private: false,
10074
+ professional: true,
10075
+ },
10076
+ brand: {
10077
+ autoscout24: true,
10078
+ motoscout24: true,
10079
+ },
10080
+ },
10081
+ };
10082
+
10083
+ var DrawerNode;
10084
+ (function (DrawerNode) {
10085
+ DrawerNode["Search"] = "search";
10086
+ DrawerNode["User"] = "user";
10087
+ DrawerNode["More"] = "more";
10088
+ DrawerNode["Combined"] = "combined";
10089
+ })(DrawerNode || (DrawerNode = {}));
10090
+ var getUserNodeItems = function (_a) {
10091
+ var sellerId = _a.sellerId, onLogout = _a.onLogout, trackEvent = _a.trackEvent, comparisonItemIds = _a.comparisonItemIds;
10092
+ return [
10093
+ {
10094
+ translationKey: 'header.userMenu.manageVehicles',
10095
+ items: [
10096
+ insertionLinkConfig,
10097
+ autoScoutVehiclesLinkConfig,
10098
+ motoScoutVehiclesLinkConfig,
10099
+ optimizerLinkConfig,
10100
+ cockpitLinkConfig,
10101
+ carParkLinkConfig,
10102
+ motorcycleParkLinkConfig,
10103
+ ],
10104
+ },
10105
+ {
10106
+ translationKey: 'header.userMenu.toolsForSelling',
10107
+ items: [
10108
+ leadsManagementLinkConfig,
10109
+ printCenterLinkConfig,
10110
+ getPartnerHubLinkConfig({ sellerId: sellerId }),
10111
+ topListingProLinkConfig,
10112
+ autoScoutTopVehiclesLinkConfig,
10113
+ motoScoutTopVehiclesLinkConfig,
10114
+ onlineAdvertisingLinkConfig,
10115
+ getProfessionalAutoScoutInsuranceComparisonLinkConfig({ sellerId: sellerId }),
10116
+ getAutoScoutInsuranceComparisonLinkConfig({
10117
+ private: true,
10118
+ professional: false,
10119
+ }),
10120
+ getMotoScoutInsuranceComparisonLinkConfig({
10121
+ private: true,
10122
+ professional: false,
10123
+ }),
10124
+ ],
10125
+ },
10126
+ {
10127
+ translationKey: 'header.userMenu.toolsForPurchasing',
10128
+ items: __spreadArray(__spreadArray([
10129
+ savedSearchesLinkConfig,
10130
+ getFavoritesLinkConfig({
10131
+ trackEvent: trackEvent,
10132
+ eventLabel: 'drawer-user',
10133
+ })
10134
+ ], getComparisonNodeItem({
10135
+ comparisonItemIds: comparisonItemIds,
10136
+ trackEvent: trackEvent,
10137
+ eventLabel: 'drawer-user',
10138
+ }), true), [
10139
+ autoRadarLinkConfig,
10140
+ marketPriceCheckLinkConfig,
10141
+ ], false),
10142
+ },
10143
+ {
10144
+ translationKey: 'header.userMenu.accountSettings',
10145
+ items: [
10146
+ editUsersLinkConfig,
10147
+ changeLanguageLinkConfig,
10148
+ getLogoutLinkConfig({ onLogout: onLogout }),
10149
+ ],
10150
+ },
10151
+ {
10152
+ translationKey: 'header.userMenu.settings',
10153
+ items: [
10154
+ infoPageLinkConfig,
10155
+ contactDetailsLinkConfig,
10156
+ openingHoursLinkConfig,
10157
+ businessImageLinkConfig,
10158
+ photoBarLinkConfig,
10159
+ teaserTemplatesLinkConfig,
10160
+ commentTemplatesLinkConfig,
10161
+ qualilogoLinkConfig,
10162
+ autoRadarLinkConfig,
10163
+ hciLinkConfig,
10164
+ infoPortalLinkConfig,
10165
+ ],
10166
+ },
10167
+ ];
10168
+ };
10169
+ var drawerNodeItems = function (_a) {
10170
+ var comparisonItemIds = _a.comparisonItemIds, sellerId = _a.sellerId, trackEvent = _a.trackEvent, onLogout = _a.onLogout, currentLanguage = _a.currentLanguage, isLoggedIn = _a.isLoggedIn;
10171
+ return ({
10172
+ search: [
10173
+ {
10174
+ translationKey: 'header.searchMenu.vehicles',
10175
+ items: __spreadArray([
10176
+ simpleSearchLinkConfig,
10177
+ advancedSearchLinkConfig
10178
+ ], getComparisonNodeItem({
10179
+ comparisonItemIds: comparisonItemIds,
10180
+ trackEvent: trackEvent,
10181
+ eventLabel: 'drawer-search',
10182
+ }), true),
10183
+ },
10184
+ {
10185
+ translationKey: 'header.searchMenu.dealer',
10186
+ items: [autoScoutSellerSearchLinkConfig, motoScoutSellerSearchLinkConfig],
10187
+ },
10188
+ {
10189
+ translationKey: 'header.searchMenu.additional',
10190
+ items: [
10191
+ searchMotorcycleLinkConfig,
10192
+ searchCarsLinkConfig,
10193
+ getAutoScoutInsuranceComparisonLinkConfig({
10194
+ private: true,
10195
+ professional: true,
10196
+ }),
10197
+ getMotoScoutInsuranceComparisonLinkConfig({
10198
+ private: true,
10199
+ professional: true,
10200
+ }),
10201
+ __assign(__assign({}, privateAutoScoutSellLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10202
+ __assign(__assign({}, professionalSellLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10203
+ __assign(__assign({}, privateMotoScoutSellLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10204
+ __assign(__assign({}, estimateLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10205
+ __assign(__assign({}, autoScoutAssureLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10206
+ __assign(__assign({}, motoScoutAssureLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10207
+ __assign(__assign({}, electromobilityLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10208
+ __assign(__assign({}, magazineLinkConfig({ trackEvent: trackEvent })), { showUnderMoreLinkBelow: 'sm' }),
10209
+ ],
10210
+ },
10211
+ ],
10212
+ user: getUserNodeItems({ sellerId: sellerId, onLogout: onLogout, trackEvent: trackEvent, comparisonItemIds: comparisonItemIds }),
10213
+ more: [
10214
+ {
10215
+ items: [
10216
+ privateAutoScoutSellLinkConfig({ trackEvent: trackEvent }),
10217
+ professionalSellLinkConfig({ trackEvent: trackEvent }),
10218
+ privateMotoScoutSellLinkConfig({ trackEvent: trackEvent }),
10219
+ estimateLinkConfig({ trackEvent: trackEvent }),
10220
+ autoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10221
+ motoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10222
+ electromobilityLinkConfig({ trackEvent: trackEvent }),
10223
+ magazineLinkConfig({ trackEvent: trackEvent }),
10224
+ ],
10225
+ },
10226
+ ],
10227
+ combined: __spreadArray(__spreadArray([
10228
+ {
10229
+ translationKey: 'header.search',
10230
+ items: __spreadArray(__spreadArray([
10231
+ simpleSearchLinkConfig,
10232
+ advancedSearchLinkConfig
10233
+ ], getComparisonNodeItem({
10234
+ comparisonItemIds: comparisonItemIds,
10235
+ trackEvent: trackEvent,
10236
+ eventLabel: 'drawer-search',
10237
+ }), true), [
10238
+ autoScoutSellerSearchLinkConfig,
10239
+ motoScoutSellerSearchLinkConfig,
10240
+ searchMotorcycleLinkConfig,
10241
+ searchCarsLinkConfig,
10242
+ ], false),
10243
+ },
10244
+ {
10245
+ translationKey: 'header.sell',
10246
+ items: [
10247
+ privateAutoScoutSellLinkConfig({ trackEvent: trackEvent }),
10248
+ professionalSellLinkConfig({ trackEvent: trackEvent }),
10249
+ privateMotoScoutSellLinkConfig({ trackEvent: trackEvent }),
10250
+ estimateLinkConfig({ trackEvent: trackEvent }),
10251
+ ],
10252
+ },
10253
+ {
10254
+ translationKey: 'header.searchMenu.additional',
10255
+ items: [
10256
+ getAutoScoutInsuranceComparisonLinkConfig({
10257
+ private: true,
10258
+ professional: true,
10259
+ }),
10260
+ getMotoScoutInsuranceComparisonLinkConfig({
10261
+ private: true,
10262
+ professional: true,
10263
+ }),
10264
+ autoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10265
+ motoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10266
+ electromobilityLinkConfig({ trackEvent: trackEvent }),
10267
+ magazineLinkConfig({ trackEvent: trackEvent }),
10268
+ ],
10269
+ }
10270
+ ], (isLoggedIn
10271
+ ? getUserNodeItems({ sellerId: sellerId, onLogout: onLogout, trackEvent: trackEvent, comparisonItemIds: comparisonItemIds })
10272
+ : []), true), [
10273
+ {
10274
+ title: currentLanguage.toUpperCase(),
10275
+ items: [
10276
+ switchToGermanLinkConfig({ currentLanguage: currentLanguage }),
10277
+ switchToFrenchLinkConfig({ currentLanguage: currentLanguage }),
10278
+ switchToItalianLinkConfig({ currentLanguage: currentLanguage }),
10279
+ ],
10280
+ },
10281
+ ], false),
10282
+ });
10283
+ };
10284
+
10285
+ var NavigationItems = function (_a) {
10286
+ var platform = _a.platform, headerLinks = _a.headerLinks, drawer = _a.drawer, isOpen = _a.isOpen, createDrawerHandler = _a.createDrawerHandler, language = _a.language;
10287
+ var logo = platform === 'autoscout24' ? img$1 : img$2;
10288
+ var moreDrawerHandler = createDrawerHandler({
10289
+ nodeName: DrawerNode.More,
10290
+ });
10291
+ var searchDrawerHandler = createDrawerHandler({
10292
+ nodeName: DrawerNode.Search,
10293
+ });
10294
+ return (React.createElement(Stack, { direction: "row", gap: { base: 'lg', sm: '2xl' }, align: "center" },
10295
+ React.createElement(Link$1, { href: "/".concat(language === 'en' ? 'de' : language) },
10296
+ React.createElement(react$1.Image, { css: {
10297
+ width: { sm: '124px', base: '101px' },
10298
+ height: { sm: '30px', base: 'var(--spacing-sm)' },
10299
+ }, src: logo, alt: "Platform logo", htmlWidth: 300, htmlHeight: 71 })),
10300
+ React.createElement(react$1.Box, { hideBelow: "sm" },
10301
+ React.createElement(NavigationItem, { translationKey: "header.search", drawerHandler: searchDrawerHandler, isOpen: isOpen && (drawer === null || drawer === void 0 ? void 0 : drawer.current) === DrawerNode.Search })),
10302
+ headerLinks.map(function (link, index) { return (React.createElement(HeaderLink, { key: "link-".concat(index), link: link })); }),
10303
+ React.createElement(react$1.Box, { display: { base: 'none', sm: 'block', lg: 'none' } },
10304
+ React.createElement(NavigationItem, { translationKey: "header.more", drawerHandler: moreDrawerHandler, isOpen: isOpen && (drawer === null || drawer === void 0 ? void 0 : drawer.current) === DrawerNode.More }))));
10305
+ };
10306
+
10307
+ var NavigationAvatar = function (_a) {
10308
+ var user = _a.user, isOpen = _a.isOpen, drawer = _a.drawer, hasNotification = _a.hasNotification, createDrawerHandler = _a.createDrawerHandler, onLogin = _a.onLogin;
10309
+ var isDrawerOpened = isOpen && (drawer === null || drawer === void 0 ? void 0 : drawer.current) === DrawerNode.User;
10310
+ var recipe = react$1.useSlotRecipe({ key: 'link' });
10311
+ var styles = recipe({ variant: 'navigationLink' });
10312
+ var t = i18nPkg.useI18n().t;
10313
+ if (user) {
10314
+ return (React.createElement(react$1.Box, { hideBelow: "sm" },
10315
+ React.createElement(react$1.Box, { display: "flex", flexDirection: "row", gap: "xs", cursor: "pointer", _hover: { color: 'blue.700' }, color: isDrawerOpened ? 'blue.700' : 'gray.900', onClick: createDrawerHandler({
10316
+ nodeName: DrawerNode.User,
10317
+ }), alignItems: "center" },
10318
+ React.createElement(Avatar, { withNotification: hasNotification }),
10319
+ React.createElement(react$1.Box, { hideBelow: "md" },
10320
+ React.createElement(Text, { fontWeight: "bold", lineClamp: 1, maxW: "2xl", title: user.email }, user.email)),
10321
+ React.createElement(DrawerIndicator, { isOpen: isDrawerOpened }))));
10322
+ }
10323
+ return (React.createElement(react$1.Box, { hideBelow: "sm" },
10324
+ React.createElement(react$1.Box, { display: "flex", flexDirection: "row", onClick: onLogin, css: __assign({}, styles.root), fontWeight: "bold", position: "relative", cursor: "pointer", alignItems: "center", gap: "sm", color: "gray.900" },
10325
+ React.createElement(react$1.Box, { as: Avatar, css: { marginLeft: 'xxs' } }),
10326
+ React.createElement(react$1.Box, { hideBelow: "md", marginRight: "xs" }, t('header.login')))));
10327
+ };
10328
+
10329
+ var MobileHeaderMenuToggle = function (_a) {
10330
+ var isOpen = _a.isOpen, createDrawerHandler = _a.createDrawerHandler;
10331
+ var mobileDrawerHandler = createDrawerHandler({
10332
+ nodeName: DrawerNode.Combined,
10333
+ });
10334
+ return (React.createElement(react$1.Box, { hideFrom: "sm", as: "button", onClick: mobileDrawerHandler, color: isOpen ? 'blue.700' : 'gray.900' }, isOpen ? React.createElement(CloseIcon, null) : React.createElement(HamburgerMenuIcon, null)));
10335
+ };
10336
+
10337
+ var drawerHandlerFactory = function (_a) {
10338
+ var nodeName = _a.nodeName, drawerNodeItems = _a.drawerNodeItems, isOpen = _a.isOpen, onOpen = _a.onOpen, onClose = _a.onClose, drawer = _a.drawer, setDrawer = _a.setDrawer;
10339
+ return function () {
10340
+ if (!isOpen) {
10341
+ setDrawer({
10342
+ nodes: drawerNodeItems[nodeName],
10343
+ current: nodeName,
10344
+ });
10345
+ onOpen();
10346
+ return;
10347
+ }
10348
+ if ((drawer === null || drawer === void 0 ? void 0 : drawer.current) !== nodeName) {
10349
+ onClose();
10350
+ // Note: can be wrapped in a set timeout for slideup and down variations
10351
+ setDrawer({
10352
+ nodes: drawerNodeItems[nodeName],
10353
+ current: nodeName,
10354
+ });
10355
+ onOpen();
10356
+ return;
10357
+ }
10358
+ onClose();
10359
+ };
10360
+ };
10361
+ var useNavigationDrawer = function (_a) {
10362
+ var drawerNodeItems = _a.drawerNodeItems;
10363
+ var _b = React.useState(null), drawer = _b[0], setDrawer = _b[1];
10364
+ var _c = react$1.useDisclosure(), isOpen = _c.open, onOpen = _c.onOpen, onClose = _c.onClose;
10365
+ var createDrawerHandler = function (_a) {
10366
+ var nodeName = _a.nodeName;
10367
+ return drawerHandlerFactory({
10368
+ nodeName: nodeName,
10369
+ drawerNodeItems: drawerNodeItems,
10370
+ isOpen: isOpen,
10371
+ onOpen: onOpen,
10372
+ onClose: onClose,
10373
+ drawer: drawer,
10374
+ setDrawer: setDrawer,
10375
+ });
10376
+ };
10377
+ return { drawer: drawer, createDrawerHandler: createDrawerHandler, isOpen: isOpen, onOpen: onOpen, onClose: onClose };
10378
+ };
10379
+
10380
+ var FavoritesItem = function (_a) {
10381
+ var _b, _c;
10382
+ var link = _a.link;
10383
+ var _d = i18nPkg.useI18n(), t = _d.t, language = _d.language;
10384
+ return (React.createElement(react$1.chakra.a, { position: "relative", href: (_b = link.link) === null || _b === void 0 ? void 0 : _b[language], onClick: link.onClick, "aria-label": t((_c = link.translationKey) !== null && _c !== void 0 ? _c : '') },
10385
+ React.createElement(HeartIcon, { color: "gray.900" })));
10386
+ };
10387
+
10388
+ var SelectedTenantInfo = function (_a) {
10389
+ var selectedTenant = _a.selectedTenant;
10390
+ return (React.createElement(Stack, { direction: "row" },
10391
+ React.createElement(GarageIcon, null),
10392
+ React.createElement(Stack, { direction: {
10393
+ base: 'column',
10394
+ sm: 'row',
10395
+ }, gap: {
10396
+ base: '0',
10397
+ sm: 'sm',
10398
+ } },
10399
+ React.createElement(react$1.Box, { as: "span", textStyle: "body", fontWeight: "bold" }, selectedTenant.billingName || selectedTenant.id),
10400
+ React.createElement(react$1.Box, { as: "span", textStyle: "body" },
10401
+ selectedTenant.billingZipCode,
10402
+ " ",
10403
+ selectedTenant.billingCity))));
10404
+ };
10405
+
10406
+ var TenantSelectionMenu = function (_a) {
10407
+ var user = _a.user, selectedTenant = _a.selectedTenant, selectTenant = _a.selectTenant;
10408
+ var _b = React.useState([]), expandedItems = _b[0], setExpandedItems = _b[1];
10409
+ return (React.createElement(MobileOnlyAccordion, { multiple: true, collapsible: true, value: expandedItems, onValueChange: function (details) { return setExpandedItems(details.value); } },
10410
+ React.createElement(MobileOnlyAccordionItem, { value: "tenant-selection", style: { borderTop: 'none', borderBottom: '1px solid #CFCFCF' } },
10411
+ React.createElement(MobileOnlyAccordionButton, { "data-testid": "tenant-selection-accordion-toggle" },
10412
+ React.createElement(SelectedTenantInfo, { selectedTenant: selectedTenant })),
10413
+ React.createElement(react$1.Box, { as: MobileOnlyAccordionPanel, position: "relative", "data-testid": "tenant-selection-accordion-panel" },
10414
+ React.createElement(NavigationTenantMenuContent, { user: user, onClose: function () { return setExpandedItems([]); }, selectedTenantId: selectedTenant.id, selectTenant: selectTenant })))));
10415
+ };
10416
+
10417
+ var DrawerUserInfo = function (_a) {
10418
+ var _b;
10419
+ var user = _a.user, selectTenant = _a.selectTenant, showTenantSelection = _a.showTenantSelection;
10420
+ if (!user)
10421
+ return null;
10422
+ var selectedTenant = (_b = user.managedSellers) === null || _b === void 0 ? void 0 : _b.find(function (seller) { return seller.id === Number(user.sellerId); });
10423
+ return (React.createElement(react$1.GridItem, { colSpan: { base: 1, md: 5 } },
10424
+ React.createElement(Stack, { paddingX: "lg", marginBottom: "lg", direction: {
10425
+ base: 'column',
10426
+ md: 'row',
10427
+ }, gap: { base: 'sm', md: '2xl' } },
10428
+ React.createElement(Stack, { direction: "row" },
10429
+ React.createElement(Avatar, null),
10430
+ React.createElement(Stack, { direction: {
10431
+ base: 'column',
10432
+ md: 'row',
10433
+ }, gap: {
10434
+ base: '0',
10435
+ md: 'sm',
10436
+ } },
10437
+ React.createElement(react$1.Box, { as: "span", fontWeight: "bold", css: {
10438
+ maxWidth: 'calc(100vw - 2 * var(--chakra-space-lg) - var(--chakra-space-sm) - var(--chakra-sizes-sm))',
10439
+ } }, user.email),
10440
+ user.userType === auth$4.Auth0UserType.Professional ? (React.createElement(react$1.Box, { as: "span" },
10441
+ "(",
10442
+ user.sellerId,
10443
+ ")")) : null)),
10444
+ selectedTenant && showTenantSelection ? (React.createElement(React.Fragment, null,
10445
+ React.createElement(react$1.Box, { hideBelow: "md" },
10446
+ React.createElement(SelectedTenantInfo, { selectedTenant: selectedTenant })),
10447
+ React.createElement(react$1.Box, { hideFrom: "sm", marginX: "-lg", marginBottom: "-lg" },
10448
+ React.createElement(TenantSelectionMenu, { user: user, selectedTenant: selectedTenant, selectTenant: selectTenant })))) : null),
10449
+ React.createElement(react$1.Separator, { css: {
10450
+ borderBottomWidth: selectedTenant
10451
+ ? { base: 0, md: '1px' }
10452
+ : { base: '1px', md: '1px' },
10453
+ } })));
10454
+ };
10455
+
10456
+ var DrawerNavigationLink = function (_a) {
10457
+ var item = _a.item;
10458
+ // Only apply hideFrom if the breakpoint is defined
10459
+ // Items without showUnderMoreLinkBelow should always be visible
10460
+ var hideProps = item.showUnderMoreLinkBelow
10461
+ ? { hideFrom: item.showUnderMoreLinkBelow }
10462
+ : {};
10463
+ return (React.createElement(react$1.Box, __assign({}, hideProps),
10464
+ React.createElement(List.Item, { paddingBottom: { base: 'lg', md: 'md' } },
10465
+ React.createElement(NavigationLink, __assign({}, item, { variant: "subNavigationLink", color: item.color })))));
10466
+ };
10467
+
10468
+ var NonCollapsibleSection = function (_a) {
10469
+ var node = _a.node;
10470
+ return (React.createElement(react$1.Box, { py: { base: '2xl', md: '0' }, px: "2xl" },
10471
+ React.createElement(List.Root, null, node.items.map(function (item, index) {
10472
+ return React.createElement(DrawerNavigationLink, { item: item, key: index });
10473
+ }))));
10474
+ };
10475
+ var CollapsibleSection = function (_a) {
10476
+ var node = _a.node;
10477
+ var t = i18nPkg.useI18n().t;
10478
+ if (!node.translationKey && !node.title) {
10479
+ return null;
10480
+ }
10481
+ return (React.createElement(react$1.GridItem, null,
10482
+ React.createElement(MobileOnlyAccordion, { multiple: true, collapsible: true },
10483
+ React.createElement(MobileOnlyAccordionItem, { value: "section", style: { borderTop: 'none', borderBottom: '1px solid #CFCFCF' } },
10484
+ React.createElement(MobileOnlyAccordionButton, null,
10485
+ React.createElement(react$1.Box, { flex: "1", textAlign: "left", fontSize: "base" }, node.translationKey ? t(node.translationKey) : node.title)),
10486
+ React.createElement(MobileOnlyAccordionPanel, { pb: "0" },
10487
+ React.createElement(react$1.Box, { paddingTop: { base: 'lg', md: '0' } },
10488
+ React.createElement(List.Root, null, node.items.map(function (item, index) { return (React.createElement(DrawerNavigationLink, { item: item, key: index })); }))))))));
10489
+ };
10490
+
10491
+ var DrawerMenu = function (_a) {
10492
+ var node = _a.node;
10493
+ if (!node.translationKey && !node.title) {
10494
+ return React.createElement(NonCollapsibleSection, { node: node });
10495
+ }
10496
+ return React.createElement(CollapsibleSection, { node: node });
10497
+ };
10498
+
10499
+ var DrawerLoginToggle = function (_a) {
10500
+ var user = _a.user, onLogin = _a.onLogin, onLogout = _a.onLogout;
10501
+ var t = i18nPkg.useI18n().t;
10502
+ return (React.createElement(Button, { as: "button", variant: "secondary", size: "md", marginTop: "md", marginX: "lg", onClick: user ? onLogout : onLogin },
10503
+ user ? React.createElement(LogoutIcon, null) : React.createElement(AvatarIcon, null),
10504
+ user ? t('header.userMenu.logout') : t('header.login')));
10505
+ };
10506
+
10507
+ var NavigationDrawer = function (_a) {
10508
+ var drawer = _a.drawer, isOpen = _a.isOpen, onClose = _a.onClose, menuHeight = _a.menuHeight, user = _a.user, onLogin = _a.onLogin, onLogout = _a.onLogout, selectTenant = _a.selectTenant, showTenantSelection = _a.showTenantSelection;
10509
+ return (React.createElement(react$1.Portal, null,
10510
+ React.createElement(react$1.Box, { position: "fixed", inset: "0", zIndex: "overlay", onClick: onClose, css: {
10511
+ top: menuHeight,
10512
+ opacity: isOpen ? 1 : 0,
10513
+ pointerEvents: isOpen ? 'auto' : 'none',
10514
+ } }),
10515
+ React.createElement(react$1.Box, { position: "fixed", left: "0", right: "0", zIndex: "modal", css: {
10516
+ top: menuHeight,
10517
+ transform: isOpen ? 'translateY(0)' : 'translateY(-100%)',
10518
+ opacity: isOpen ? 1 : 0,
10519
+ transition: 'transform 0.3s ease-in-out, opacity 0.2s ease-in-out',
10520
+ pointerEvents: isOpen ? 'auto' : 'none',
10521
+ } },
10522
+ React.createElement(react$1.Box, { overflowY: "scroll", bg: "white", boxShadow: "xs", borderBottom: "1px", borderBottomColor: "gray.200", css: {
10523
+ maxHeight: "calc(100vh - ".concat(menuHeight, ")"),
10524
+ maxWidth: '100vw',
10525
+ width: '100%',
10526
+ } },
10527
+ React.createElement(react$1.Box, { "data-testid": "drawer-body", py: "lg", px: { md: 'xs' }, maxWidth: "container.2xl", width: "full", margin: "auto" }, isOpen ? (React.createElement(Grid, { height: "full", width: "full", templateColumns: {
10528
+ '2xs': 'minmax(0, 1fr)',
10529
+ md: 'repeat(5, 1fr)',
10530
+ }, gap: { md: '3xl' } },
10531
+ [DrawerNode.User, DrawerNode.Combined].includes(drawer === null || drawer === void 0 ? void 0 : drawer.current) ? (React.createElement(DrawerUserInfo, { user: user, selectTenant: selectTenant, showTenantSelection: showTenantSelection })) : null, drawer === null || drawer === void 0 ? void 0 :
10532
+ drawer.nodes.map(function (node, index) { return (React.createElement(DrawerMenu, { key: "node-".concat(index), node: node })); }),
10533
+ (drawer === null || drawer === void 0 ? void 0 : drawer.current) === DrawerNode.Combined ? (React.createElement(DrawerLoginToggle, { user: user, onLogin: onLogin, onLogout: onLogout })) : null)) : null)))));
10534
+ };
10535
+
10536
+ var iconItems = function (_a) {
10537
+ var comparisonItemIds = _a.comparisonItemIds, trackEvent = _a.trackEvent;
10538
+ return ({
10539
+ comparison: shouldShowComparisonLink(comparisonItemIds)
10540
+ ? __assign(__assign({}, comparisonLinkConfig({ comparisonItemIds: comparisonItemIds })), { onClick: function () {
10541
+ return trackEvent === null || trackEvent === void 0 ? void 0 : trackEvent({
10542
+ eventCategory: navigationEventCategory,
10543
+ eventAction: 'open_comparison_tool',
10544
+ eventLabel: 'icon',
10545
+ });
10546
+ } }) : null,
10547
+ favorites: getFavoritesLinkConfig({
10548
+ trackEvent: trackEvent,
10549
+ eventLabel: 'icon',
10550
+ }),
10551
+ });
10552
+ };
10553
+
10554
+ var paramName = function (param) { return param.replace(/[{}]/g, ''); };
10555
+ var replaceParameters = function (_a) {
10556
+ var path = _a.path, params = _a.params;
10557
+ var parameters = path.match(/{([A-Za-z0-9_-]+)}/g) || [];
10558
+ if (parameters.length === 0) {
10559
+ return path;
10560
+ }
10561
+ var replacedPath = path;
10562
+ parameters.forEach(function (paramPattern) {
10563
+ var name = paramName(paramPattern);
10564
+ var value = params === null || params === void 0 ? void 0 : params[name];
10565
+ if (!value) {
10566
+ throw new Error("Parameter ".concat(name, " missing. Expected parameters are: ").concat(parameters
10567
+ .map(paramName)
10568
+ .join(', ')));
10569
+ }
10570
+ replacedPath = replacedPath.replace(paramPattern, "".concat(value));
10571
+ });
10572
+ return replacedPath;
10573
+ };
10574
+
10575
+ var UserTypeExternal;
10576
+ (function (UserTypeExternal) {
10577
+ UserTypeExternal["Guest"] = "guest";
10578
+ })(UserTypeExternal || (UserTypeExternal = {}));
10579
+
10580
+ var HeaderNavigationLink = /** @class */ (function (_super) {
10581
+ __extends(HeaderNavigationLink, _super);
10582
+ function HeaderNavigationLink(_a) {
10583
+ var config = _a.config, brand = _a.brand, userType = _a.userType, environment = _a.environment, useAbsoluteUrls = _a.useAbsoluteUrls, project = _a.project, linkProtocol = _a.linkProtocol, domains = _a.domains, isNew = _a.isNew, rightIcon = _a.rightIcon, showUnderMoreLinkBelow = _a.showUnderMoreLinkBelow, fontWeight = _a.fontWeight, variant = _a.variant, color = _a.color, userAvatar = _a.userAvatar, _b = _a.forceMotoscoutLink, forceMotoscoutLink = _b === void 0 ? false : _b, _c = _a.forceAutoscoutLink, forceAutoscoutLink = _c === void 0 ? false : _c, _d = _a.userEntitlements, userEntitlements = _d === void 0 ? [] : _d;
10584
+ var _this = _super.call(this, {
10585
+ config: config,
10586
+ brand: brand,
10587
+ userType: userType,
10588
+ environment: environment,
10589
+ useAbsoluteUrls: useAbsoluteUrls,
10590
+ project: project,
10591
+ linkProtocol: linkProtocol,
10592
+ domains: domains,
10593
+ forceMotoscoutLink: forceMotoscoutLink,
10594
+ forceAutoscoutLink: forceAutoscoutLink,
10595
+ userEntitlements: userEntitlements,
10596
+ rightIcon: rightIcon,
10597
+ }) || this;
10598
+ _this.isNew = isNew;
10599
+ _this.showUnderMoreLinkBelow = showUnderMoreLinkBelow;
10600
+ _this.fontWeight = fontWeight;
10601
+ _this.variant = variant;
10602
+ _this.color = color;
10603
+ _this.forceAutoscoutLink = forceAutoscoutLink;
10604
+ _this.forceMotoscoutLink = forceMotoscoutLink;
10605
+ _this.userAvatar = userAvatar;
10606
+ return _this;
10607
+ }
10608
+ return HeaderNavigationLink;
10609
+ }(Link));
10610
+
10611
+ var menuHeightConfig = '60px';
10612
+ var HeaderNavigationConfig = /** @class */ (function (_super) {
10613
+ __extends(HeaderNavigationConfig, _super);
10614
+ function HeaderNavigationConfig(_a) {
10615
+ var brand = _a.brand, environment = _a.environment, useAbsoluteUrls = _a.useAbsoluteUrls, project = _a.project, config = _a.config, user = _a.user, urlPathParams = _a.urlPathParams;
10616
+ var _this = this;
10617
+ var entitlements = Object.keys((user === null || user === void 0 ? void 0 : user.entitlements) || {});
10618
+ _this = _super.call(this, { brand: brand, environment: environment, useAbsoluteUrls: useAbsoluteUrls, project: project, entitlements: entitlements }) || this;
10619
+ _this.replacePathParams = function (link) {
10620
+ if (link && _this.urlPathParams) {
10621
+ return Object.entries(link).reduce(function (acc, _a) {
10622
+ var _b;
10623
+ var key = _a[0], value = _a[1];
10624
+ return __assign(__assign({}, acc), (_b = {}, _b[key] = replaceParameters({
10625
+ path: value,
10626
+ params: _this.urlPathParams,
10627
+ }), _b));
10628
+ }, {});
10629
+ }
10630
+ return link;
10631
+ };
10632
+ _this.getHeaderLinks = function () {
10633
+ return _this.config.headerItems
10634
+ .map(function (link) { return _this.mapLink(link); })
10635
+ .filter(function (item) { return item.isVisible; });
10636
+ };
10637
+ _this.getIconItems = function () {
10638
+ return Object.keys(_this.config.iconItems).reduce(function (previousValue, currentValue) {
10639
+ var linkToMap = _this.config.iconItems[currentValue];
10640
+ previousValue[currentValue] = linkToMap
10641
+ ? _this.mapLink(linkToMap)
10642
+ : null;
10643
+ return previousValue;
10644
+ }, {});
10645
+ };
10646
+ _this.getDrawerNodeItems = function () {
10647
+ var itemsEntires = Object.entries(_this.config.drawerItems);
10648
+ var mappedEntries = _this.mapDrawerItemsEntries(itemsEntires);
10649
+ return Object.fromEntries(mappedEntries);
10650
+ };
10651
+ _this.mapDrawerItemsEntries = function (itemsEntires) {
10652
+ return itemsEntires.map(function (_a) {
10653
+ var nodeKey = _a[0], nodes = _a[1];
10654
+ var mappedNodes = _this.mapDrawerNodes(nodes);
10655
+ return [nodeKey, mappedNodes];
10656
+ });
10657
+ };
10658
+ _this.mapDrawerNodes = function (nodeEntry) {
10659
+ return nodeEntry.map(function (node) {
10660
+ var mappedItems = _this.mapDrawerNodeItems(node.items);
10661
+ return __assign(__assign({}, node), { items: mappedItems });
10662
+ });
10663
+ };
10664
+ _this.mapDrawerNodeItems = function (items) {
10665
+ return items
10666
+ .map(function (item) { return _this.mapLink(item); })
10667
+ .filter(function (item) { return item.isVisible; });
10668
+ };
10669
+ _this.config = config;
10670
+ _this.homeUrl = '/';
10671
+ _this.menuHeight = menuHeightConfig;
10672
+ _this.user = user;
10673
+ _this.userType = user ? user.userType : UserTypeExternal.Guest;
10674
+ _this.urlPathParams = urlPathParams;
10675
+ return _this;
10676
+ }
10677
+ HeaderNavigationConfig.prototype.getMappedConfig = function () {
10678
+ if (this.mappedConfig)
10679
+ return this.mappedConfig;
10680
+ var mappedConfig = {
10681
+ homeUrl: this.homeUrl,
10682
+ menuHeight: this.menuHeight,
10683
+ user: this.user,
10684
+ headerItems: this.getHeaderLinks(),
10685
+ drawerItems: this.getDrawerNodeItems(),
10686
+ iconItems: this.getIconItems(),
10687
+ };
10688
+ this.mappedConfig = mappedConfig;
10689
+ return this.mappedConfig;
10690
+ };
10691
+ HeaderNavigationConfig.prototype.mapEntitlementConfig = function (entitlementConfig) {
10692
+ return __assign(__assign({}, entitlementConfig), { missingEntitlementFallbackLink: this.replacePathParams(entitlementConfig.missingEntitlementFallbackLink) });
10693
+ };
10694
+ HeaderNavigationConfig.prototype.mapLink = function (link) {
10695
+ var entitlementConfig = link.entitlementConfig;
10696
+ return new HeaderNavigationLink({
10697
+ config: {
10698
+ title: link.title,
10699
+ translationKey: link.translationKey,
10700
+ translationParameters: link.translationParameters,
10701
+ link: this.replacePathParams(link.link),
10702
+ onClick: link.onClick,
10703
+ target: undefined,
10704
+ visibilitySettings: link.visibilitySettings,
10705
+ entitlementConfig: entitlementConfig && this.mapEntitlementConfig(entitlementConfig),
10706
+ projectIdentifier: link.projectIdentifier,
10707
+ },
10708
+ forceMotoscoutLink: link.forceMotoscoutLink,
10709
+ forceAutoscoutLink: link.forceAutoscoutLink,
10710
+ brand: this.brand,
10711
+ userType: this.userType,
10712
+ environment: this.environment,
10713
+ useAbsoluteUrls: this.useAbsoluteUrls,
10714
+ project: this.project,
10715
+ linkProtocol: this.linkProtocol,
10716
+ domains: this.domains,
10717
+ isNew: link.isNew,
10718
+ rightIcon: link.rightIcon,
10719
+ showUnderMoreLinkBelow: link.showUnderMoreLinkBelow,
10720
+ fontWeight: link.fontWeight,
10721
+ variant: link.variant,
10722
+ color: link.color,
10723
+ userAvatar: link.userAvatar,
10724
+ userEntitlements: this.entitlements,
10725
+ });
10726
+ };
10727
+ return HeaderNavigationConfig;
10728
+ }(BaseConfig));
10729
+
10730
+ var headerLinks = function (_a) {
10731
+ var trackEvent = _a.trackEvent;
10732
+ return [
10733
+ privateAutoScoutSellLinkConfig({ trackEvent: trackEvent }),
10734
+ privateMotoScoutSellLinkConfig({ trackEvent: trackEvent }),
10735
+ professionalSellLinkConfig({ trackEvent: trackEvent }),
10736
+ estimateLinkConfig({ trackEvent: trackEvent }),
10737
+ autoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10738
+ motoScoutAssureLinkConfig({ trackEvent: trackEvent }),
10739
+ electromobilityLinkConfig({ trackEvent: trackEvent }),
10740
+ magazineLinkConfig({ trackEvent: trackEvent }),
10741
+ ];
10742
+ };
10743
+
10744
+ var Navigation = function (_a) {
10745
+ var _b, _c;
10746
+ var brand = _a.brand, comparisonItemIds = _a.comparisonItemIds, environment = _a.environment, hasNotification = _a.hasNotification, language = _a.language, onLogin = _a.onLogin, onLogout = _a.onLogout, trackEvent = _a.trackEvent, _d = _a.useAbsoluteUrls, useAbsoluteUrls = _d === void 0 ? false : _d, project = _a.project, user = _a.user, selectTenant = _a.selectTenant, _e = _a.showTenantSelection, showTenantSelection = _e === void 0 ? true : _e;
10747
+ var config = React.useMemo(function () {
10748
+ var urlPathParams = (user === null || user === void 0 ? void 0 : user.sellerId)
10749
+ ? { accountId: user === null || user === void 0 ? void 0 : user.sellerId }
10750
+ : undefined;
10751
+ var headerNavigationConfigInstance = new HeaderNavigationConfig({
10752
+ brand: brand,
10753
+ environment: environment,
10754
+ useAbsoluteUrls: useAbsoluteUrls,
10755
+ project: project,
10756
+ config: {
10757
+ headerItems: headerLinks({ trackEvent: trackEvent }),
10758
+ drawerItems: drawerNodeItems({
10759
+ trackEvent: trackEvent,
10760
+ onLogout: onLogout,
10761
+ comparisonItemIds: comparisonItemIds,
10762
+ sellerId: user === null || user === void 0 ? void 0 : user.sellerId,
10763
+ currentLanguage: language,
10764
+ isLoggedIn: !!user,
10765
+ }),
10766
+ iconItems: iconItems({
10767
+ trackEvent: trackEvent,
10768
+ comparisonItemIds: comparisonItemIds,
10769
+ }),
10770
+ },
10771
+ user: user,
10772
+ urlPathParams: urlPathParams,
10773
+ });
10774
+ return headerNavigationConfigInstance.getMappedConfig();
10775
+ }, [
10776
+ user,
10777
+ brand,
10778
+ environment,
10779
+ useAbsoluteUrls,
10780
+ project,
10781
+ trackEvent,
10782
+ onLogout,
10783
+ comparisonItemIds,
10784
+ language,
10785
+ ]);
10786
+ var _f = useNavigationDrawer({
10787
+ drawerNodeItems: config.drawerItems,
10788
+ }), drawer = _f.drawer, isOpen = _f.isOpen, onClose = _f.onClose, createDrawerHandler = _f.createDrawerHandler;
10789
+ // We can't pass `onClose` to logout callback when instancing the config
10790
+ // because config is needed to call `useNavigationDrawer` hook
10791
+ // which returns `onClose` callback
10792
+ // that's why we need to call onClose like this
10793
+ React.useEffect(function () {
10794
+ if (!(user === null || user === void 0 ? void 0 : user.userId)) {
10795
+ onClose();
10796
+ }
10797
+ }, [user === null || user === void 0 ? void 0 : user.userId, onClose]);
10798
+ return (React.createElement(TranslationProvider, { language: language, scopes: ['header', 'auth.tenantSelection'] },
10799
+ React.createElement(react$1.Box, __assign({ width: "full", borderBottom: "1px", borderBottomColor: "gray.200", zIndex: "header", backgroundColor: "white" }, (isOpen
10800
+ ? { position: 'fixed', top: '0' }
10801
+ : { position: 'relative' })),
10802
+ React.createElement(react$1.Box, { maxWidth: "container.2xl", css: { height: config.menuHeight }, alignItems: "center", margin: "auto", display: "flex", justifyContent: "space-between", px: { base: 'sm', xs: 'lg', sm: '2xl' } },
10803
+ React.createElement(NavigationItems, { platform: brand, headerLinks: config.headerItems, drawer: drawer, isOpen: isOpen, createDrawerHandler: createDrawerHandler, language: language }),
10804
+ React.createElement(Stack, { direction: "row", gap: "2xl", align: "center" },
10805
+ ((_b = config.iconItems.favorites) === null || _b === void 0 ? void 0 : _b.isVisible) ? (React.createElement(FavoritesItem, { link: config.iconItems.favorites })) : null,
10806
+ config.iconItems.comparison ? (React.createElement(ComparisonItem, { link: config.iconItems.comparison, count: (_c = comparisonItemIds === null || comparisonItemIds === void 0 ? void 0 : comparisonItemIds.length) !== null && _c !== void 0 ? _c : 0 })) : null,
10807
+ React.createElement(NavigationAvatar, { user: user, createDrawerHandler: createDrawerHandler, isOpen: isOpen, drawer: drawer, hasNotification: hasNotification, onLogin: onLogin }),
10808
+ showTenantSelection ? (React.createElement(NavigationTenantMenu, { user: user, selectTenant: selectTenant })) : null,
10809
+ React.createElement(NavigationLanguageMenu, { activeLanguage: language }),
10810
+ React.createElement(MobileHeaderMenuToggle, { isOpen: isOpen, createDrawerHandler: createDrawerHandler })))),
10811
+ React.createElement(NavigationDrawer, { user: user, showTenantSelection: showTenantSelection, drawer: drawer, isOpen: isOpen, onClose: onClose, menuHeight: config.menuHeight, onLogin: onLogin, onLogout: onLogout, selectTenant: selectTenant })));
10812
+ };
10813
+
10814
+ var Pagination = function (_a) {
10815
+ var totalPages = _a.totalPages, _b = _a.currentPage, currentPage = _b === void 0 ? 0 : _b, onChange = _a.onChange, marginBottom = _a.marginBottom, marginTop = _a.marginTop;
10816
+ var recipe = react$1.useSlotRecipe({ key: 'pagination' });
10817
+ var styles = recipe();
10818
+ if (totalPages <= 1) {
10819
+ return null;
10820
+ }
10821
+ return (React.createElement(react$1.Pagination.Root, { count: totalPages, pageSize: 1, page: currentPage + 1, onPageChange: function (e) { return onChange(e.page - 1); } },
10822
+ React.createElement(react$1.Box, { marginTop: marginTop, marginBottom: marginBottom, css: styles.paginationContainer },
10823
+ React.createElement(react$1.Pagination.PrevTrigger, { asChild: true, css: styles.paginationButton, display: { base: 'none', xs: 'inline-flex' } },
10824
+ React.createElement(react$1.IconButton, null,
10825
+ React.createElement(ChevronLeftSmallIcon, null))),
10826
+ React.createElement(react$1.Pagination.Context, null, function (_a) {
10827
+ var pages = _a.pages;
10828
+ return pages.map(function (page, index) {
10829
+ return page.type === 'page' ? (React.createElement(react$1.Pagination.Item, __assign({ key: index }, page, { css: styles.paginationButton }), page.value)) : (React.createElement(react$1.Pagination.Ellipsis, { css: styles.dots, key: index, index: index }, "\u2026"));
10830
+ });
10831
+ }),
10832
+ React.createElement(react$1.Pagination.NextTrigger, { asChild: true, css: styles.paginationButton, display: { base: 'none', xs: 'inline-flex' } },
10833
+ React.createElement(react$1.IconButton, null,
10834
+ React.createElement(ChevronRightSmallIcon, null))))));
10835
+ };
10836
+
10837
+ var Rating = function (_a) {
10838
+ var rating = _a.rating, props = __rest(_a, ["rating"]);
10839
+ var percent = "calc((".concat(rating.toString(), " - 0.16) / 5 * 100%)");
10840
+ var recipe = react$1.useRecipe({ key: 'rating' });
10841
+ var recipeProps = recipe.splitVariantProps(props)[0];
10842
+ var styles = recipe(recipeProps);
10843
+ return (React.createElement(react$1.Box, { "aria-label": "Rating is ".concat(rating, " out of 5"), css: __assign(__assign({}, styles), { '--percent': percent, '--star-color': 'colors.orange.300', '&::before': {
10844
+ content: '"★★★★★"',
10845
+ letterSpacing: '0.5em',
10846
+ color: 'var(--star-color)',
10847
+ background: 'linear-gradient(90deg, var(--star-color) var(--percent), white var(--percent))',
10848
+ backgroundClip: 'text',
10849
+ WebkitTextFillColor: 'transparent',
10850
+ WebkitTextStroke: '0.1em var(--star-color)',
10851
+ } }) }));
10852
+ };
10853
+
10854
+ var Section = function (_a) {
10855
+ var _b = _a.maxImgW, maxImgW = _b === void 0 ? '2xl' : _b, props = __rest(_a, ["maxImgW"]);
10856
+ var recipe = react$1.useSlotRecipe({ key: 'section' });
10857
+ var _c = recipe.splitVariantProps(props), recipeProps = _c[0], componentProps = _c[1];
10858
+ var styles = recipe(recipeProps);
10859
+ var title = componentProps.title, text = componentProps.text, image = componentProps.image;
10860
+ return (React.createElement(react$1.Stack, { css: styles.root },
10861
+ image ? (React.createElement(react$1.Box, { css: styles.imageContainer, maxW: maxImgW }, image)) : null,
10862
+ React.createElement(react$1.Stack, { css: styles.textContainer },
10863
+ React.createElement(react$1.chakra.span, { css: styles.title }, title),
10864
+ text ? React.createElement(react$1.chakra.span, { css: styles.text }, text) : null)));
10865
+ };
10866
+
10867
+ var Select = React.forwardRef(function (_a, ref) {
10868
+ var options = _a.options, props = __rest(_a, ["options"]);
10869
+ var selectRecipe = react$1.useSlotRecipe({ key: 'select' });
10870
+ var _b = selectRecipe.splitVariantProps(props), selectRecipeProps = _b[0], restProps = _b[1];
10871
+ var selectStyles = selectRecipe(selectRecipeProps);
10872
+ var disabled = restProps.disabled, invalid = restProps.invalid, rest = __rest(restProps, ["disabled", "invalid"]);
10873
+ return (React.createElement(react$1.NativeSelect.Root, { disabled: disabled, invalid: invalid, css: selectStyles.root },
10874
+ React.createElement(react$1.NativeSelect.Field, __assign({ ref: ref }, rest, { css: selectStyles.field }), options.map(function (option) { return (React.createElement("option", { value: option.value, key: option.value }, option.label)); })),
10875
+ React.createElement(react$1.NativeSelect.Indicator, { css: [
10876
+ selectStyles.indicator,
10877
+ disabled && selectStyles.indicator._disabled,
10878
+ ] })));
10879
+ });
10880
+ Select.displayName = 'Select';
10881
+
10882
+ var SimpleHeader = function (props) {
10883
+ var recipe = react$1.useSlotRecipe({ key: 'simpleHeader' });
10884
+ var _a = recipe.splitVariantProps(props), recipeProps = _a[0], componentProps = _a[1];
10885
+ var styles = recipe(recipeProps);
10886
+ var title = componentProps.title, url = componentProps.url;
10887
+ return (React.createElement(react$1.chakra.header, { css: styles.header },
10888
+ React.createElement(Center, null,
10889
+ React.createElement(Flex, { css: styles.mainContainer },
10890
+ React.createElement(Flex, { justify: "space-between", minWidth: "full" },
10891
+ React.createElement(react$1.chakra.h1, { css: styles.title }, title),
10892
+ React.createElement(Flex, { css: styles.iconWrapper },
10893
+ React.createElement("a", { href: url },
10894
+ React.createElement(CloseIcon, null))))))));
10895
+ };
10896
+
10897
+ var Tab = function (_a) {
10898
+ var variant = _a.variant, children = _a.children, rest = __rest(_a, ["variant", "children"]);
10899
+ var recipe = react$1.useSlotRecipe({ key: 'tabs' });
10900
+ var styles = recipe({ variant: variant });
10901
+ return (React.createElement(react$1.Tabs.Trigger, __assign({}, rest, { css: styles.trigger }), children));
10902
+ };
10903
+
10904
+ var TabList = function (_a) {
10905
+ var variant = _a.variant, children = _a.children, rest = __rest(_a, ["variant", "children"]);
10906
+ var recipe = react$1.useSlotRecipe({ key: 'tabs' });
8290
10907
  var styles = recipe({ variant: variant });
8291
10908
  return (React.createElement(react$1.Box, { overflowX: "auto" },
8292
10909
  React.createElement(react$1.Tabs.List, __assign({}, rest, { css: styles.list }), React.Children.map(children, function (child) {
@@ -8351,25 +10968,6 @@ var Table = {
8351
10968
  ScrollArea: ScrollArea,
8352
10969
  };
8353
10970
 
8354
- var HighlightedText = function (_a) {
8355
- var text = _a.text, _b = _a.highlightIndices, highlightIndices = _b === void 0 ? [] : _b, textProps = __rest(_a, ["text", "highlightIndices"]);
8356
- if (highlightIndices.length === 0)
8357
- return (React.createElement(Text, __assign({ as: "span" }, textProps), text));
8358
- var result = [];
8359
- var currentIndex = 0;
8360
- for (var _i = 0, highlightIndices_1 = highlightIndices; _i < highlightIndices_1.length; _i++) {
8361
- var _c = highlightIndices_1[_i], start = _c[0], end = _c[1];
8362
- // Append the non-matching part
8363
- result.push(React.createElement(Text, __assign({ key: "non-highlight-".concat(currentIndex, "-").concat(start, "-").concat(text), as: "span" }, textProps), text.substring(currentIndex, start)));
8364
- // Append the matching part
8365
- result.push(React.createElement(Text, __assign({ key: "highlight-".concat(start, "-").concat(end + 1, "-").concat(text), as: "u", fontWeight: "bold" }, textProps), text.substring(start, end + 1)));
8366
- currentIndex = end + 1;
8367
- }
8368
- // Append the remaining non-matching part
8369
- result.push(React.createElement(Text, __assign({ key: "non-highlight-end-".concat(text), as: "span" }, textProps), text.substring(currentIndex)));
8370
- return (React.createElement(Text, __assign({ as: "span" }, textProps), result));
8371
- };
8372
-
8373
10971
  var Underline = function (props) {
8374
10972
  var recipe = react$1.useSlotRecipe({ key: 'markedText' });
8375
10973
  var recipeProps = recipe.splitVariantProps(props)[0];
@@ -8598,6 +11196,350 @@ var RangeSlider = function (_a) {
8598
11196
  React.createElement(react$1.Slider.Thumb, { index: 1, "aria-label": "Max", width: { base: 'md', sm: 'sm' }, height: { base: 'md', sm: 'sm' } }))));
8599
11197
  };
8600
11198
 
11199
+ var icons = {
11200
+ previous: React.createElement(ChevronLeftSmallIcon, null),
11201
+ next: React.createElement(ChevronRightSmallIcon, null),
11202
+ };
11203
+ var ThumbnailNavigationButton = function (_a) {
11204
+ var direction = _a.direction, onClick = _a.onClick;
11205
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11206
+ var styles = recipe({ variant: 'fullScreen' });
11207
+ var side = direction === 'previous' ? { left: '0' } : { right: '0' };
11208
+ return (React.createElement(react$1.chakra.button, { onClick: onClick, "aria-label": "scroll to ".concat(direction, " thumbnail group"), "aria-controls": "thumbnails-wrapper", css: __assign(__assign({}, styles.paginationButton), side) },
11209
+ React.createElement(Flex, { css: styles.paginationIconContainer }, icons[direction])));
11210
+ };
11211
+
11212
+ var Thumbnail = function (_a) {
11213
+ var onClick = _a.onClick, isCurrent = _a.isCurrent, thumbnailIndex = _a.thumbnailIndex, totalThumbnails = _a.totalThumbnails, children = _a.children;
11214
+ return (React.createElement(AspectRatio, { ratio: 4 / 3, onClick: onClick, width: "3xl", flexShrink: "0", cursor: "pointer", mr: "xs", border: "4px", borderColor: isCurrent ? 'blue.400' : 'transparent', "aria-current": isCurrent, "aria-label": "thumbnail ".concat(thumbnailIndex + 1, " of ").concat(totalThumbnails) }, children));
11215
+ };
11216
+
11217
+ var ThumbnailPagination = function (_a) {
11218
+ var currentSlideIndex = _a.currentSlideIndex, thumbnails = _a.thumbnails, mainCarousel = _a.mainCarousel, paginationCarouselRef = _a.paginationCarouselRef, paginationCarousel = _a.paginationCarousel;
11219
+ var _b = React.useState({ previous: false, next: true }), paginationButtonVisibility = _b[0], setPaginationButtonVisibility = _b[1];
11220
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11221
+ var styles = recipe({ variant: 'fullScreen' });
11222
+ var scrollPrev = React.useCallback(function () { return paginationCarousel && paginationCarousel.scrollPrev(true); }, [paginationCarousel]);
11223
+ var scrollNext = React.useCallback(function () { return paginationCarousel && paginationCarousel.scrollNext(true); }, [paginationCarousel]);
11224
+ var onThumbnailClick = React.useCallback(function (index) {
11225
+ if (!mainCarousel || !paginationCarousel)
11226
+ return;
11227
+ mainCarousel.scrollTo(index, true);
11228
+ }, [mainCarousel, paginationCarousel]);
11229
+ var evalPaginationButtonVisibility = React.useCallback(function () {
11230
+ if (!paginationCarousel ||
11231
+ paginationCarousel.slidesNotInView().length === 0) {
11232
+ setPaginationButtonVisibility({ previous: false, next: false });
11233
+ return;
11234
+ }
11235
+ var progress = Math.max(0, Math.min(1, paginationCarousel.scrollProgress()));
11236
+ var slideWidth = 1 / thumbnails.length;
11237
+ setPaginationButtonVisibility({
11238
+ previous: progress > slideWidth,
11239
+ next: progress < 1 - slideWidth,
11240
+ });
11241
+ }, [paginationCarousel, thumbnails.length]);
11242
+ React.useEffect(function () {
11243
+ if (!paginationCarousel)
11244
+ return;
11245
+ evalPaginationButtonVisibility();
11246
+ paginationCarousel.on('scroll', evalPaginationButtonVisibility);
11247
+ paginationCarousel.on('slidesInView', evalPaginationButtonVisibility);
11248
+ }, [paginationCarousel, evalPaginationButtonVisibility]);
11249
+ return (React.createElement(react$1.Box, { ref: paginationCarouselRef, css: styles.pagination, "aria-label": "Pagination" },
11250
+ React.createElement(Flex, { alignItems: "center", height: "full", id: "thumbnail-wrapper" }, thumbnails.map(function (slide, index) { return (React.createElement(Thumbnail, { key: "slide-".concat(index), onClick: function () { return onThumbnailClick(index); }, isCurrent: index === currentSlideIndex, thumbnailIndex: index, totalThumbnails: thumbnails.length }, paginationCarouselRef ? (slide) : (React.createElement(react$1.Box, { h: "full", w: "full", backgroundColor: "gray.50" })))); })),
11251
+ paginationButtonVisibility.previous ? (React.createElement(ThumbnailNavigationButton, { onClick: scrollPrev, direction: "previous" })) : null,
11252
+ paginationButtonVisibility.next ? (React.createElement(ThumbnailNavigationButton, { onClick: scrollNext, direction: "next" })) : null));
11253
+ };
11254
+
11255
+ var Slide = function (_a) {
11256
+ var onClick = _a.onClick, slideIndex = _a.slideIndex, totalSlides = _a.totalSlides, isCurrent = _a.isCurrent, children = _a.children, fullScreen = _a.fullScreen, slidesPerView = _a.slidesPerView;
11257
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11258
+ var styles = recipe(fullScreen ? { variant: 'fullScreen' } : {});
11259
+ var flexBasisTokenOrVar = slidesPerView === 1 ? 'full' : 'var(--carousel-slide-basis)';
11260
+ var basisVarResponsive = slidesPerView === 1
11261
+ ? undefined
11262
+ : (function () {
11263
+ var map = slidesPerView;
11264
+ var result = {};
11265
+ Object.keys(map).forEach(function (bp) {
11266
+ var value = map[bp];
11267
+ if (typeof value === 'number') {
11268
+ result[bp] = "calc(100% / ".concat(value, ")");
11269
+ }
11270
+ });
11271
+ return result;
11272
+ })();
11273
+ return (React.createElement(react$1.Box, { css: __assign(__assign({}, styles.slide), (basisVarResponsive
11274
+ ? { '--carousel-slide-basis': basisVarResponsive }
11275
+ : {})), flexBasis: flexBasisTokenOrVar, paddingLeft: slidesPerView === 1 ? '0' : { base: 'md', md: '2xl' }, onClick: onClick, "aria-roledescription": "slide", "aria-label": "".concat(slideIndex + 1, " of ").concat(totalSlides), "aria-current": isCurrent }, children));
11276
+ };
11277
+
11278
+ var NumbersPaginationButton = function (_a) {
11279
+ var onClick = _a.onClick, isCurrent = _a.isCurrent, currentPageNumber = _a.currentPageNumber, totalNumbers = _a.totalNumbers;
11280
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11281
+ var styles = recipe();
11282
+ return (React.createElement(react$1.chakra.button, { css: isCurrent
11283
+ ? styles.numbersPaginationButtonActive
11284
+ : styles.numbersPaginationButton, onClick: onClick, "aria-current": isCurrent, "aria-label": "numbers pagination ".concat(currentPageNumber, " of ").concat(totalNumbers) }, currentPageNumber));
11285
+ };
11286
+
11287
+ var NumbersPagination = function (_a) {
11288
+ var currentSlideIndex = _a.currentSlideIndex, numberOfSlides = _a.numberOfSlides, mainCarousel = _a.mainCarousel;
11289
+ var onClick = React.useCallback(function (index) {
11290
+ if (mainCarousel) {
11291
+ mainCarousel.scrollTo(index);
11292
+ }
11293
+ }, [mainCarousel]);
11294
+ var pagination = Array.from({ length: numberOfSlides }, function (_, i) { return i; });
11295
+ return (React.createElement(react$1.Box, { "aria-label": "Numbers Pagination" },
11296
+ React.createElement(Flex, { flexDirection: "row", alignItems: "center", justifyContent: "center" }, pagination.map(function (index) { return (React.createElement(NumbersPaginationButton, { key: "slide-".concat(index), isCurrent: index === currentSlideIndex, currentPageNumber: index + 1, totalNumbers: numberOfSlides, onClick: function () { return onClick(index); } })); }))));
11297
+ };
11298
+
11299
+ var NavigationButton = function (_a) {
11300
+ var direction = _a.direction, onClick = _a.onClick, fullScreen = _a.fullScreen, _b = _a.isHovered, isHovered = _b === void 0 ? false : _b;
11301
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11302
+ var styles = recipe(fullScreen ? { variant: 'fullScreen' } : {});
11303
+ var side = direction === 'previous' ? { left: '0' } : { right: '0' };
11304
+ var icons = {
11305
+ previous: React.createElement(ChevronLeftLargeIcon, { boxSize: undefined, css: styles.icon }),
11306
+ next: React.createElement(ChevronRightLargeIcon, { boxSize: undefined, css: styles.icon }),
11307
+ };
11308
+ return (React.createElement(react$1.chakra.button, { onClick: onClick, "aria-label": "".concat(direction, " slide"), css: __assign(__assign(__assign({}, styles.buttonContainer), (isHovered ? { visibility: 'visible', pointerEvents: 'auto' } : {})), side) },
11309
+ React.createElement(Flex, { css: styles.button }, icons[direction])));
11310
+ };
11311
+
11312
+ var DotsPaginationIndicator = function (_a) {
11313
+ var isCurrent = _a.isCurrent;
11314
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11315
+ var styles = recipe();
11316
+ return (React.createElement(react$1.chakra.span, { css: isCurrent
11317
+ ? styles.dotsPaginationIndicatorActive
11318
+ : styles.dotsPaginationIndicator }));
11319
+ };
11320
+
11321
+ var NumbersDotsPagination = function (_a) {
11322
+ var currentSlideIndex = _a.currentSlideIndex, numberOfSlides = _a.numberOfSlides;
11323
+ var pagination = Array.from({ length: numberOfSlides }, function (_, i) { return i; });
11324
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11325
+ var styles = recipe();
11326
+ return (React.createElement(react$1.Box, { "aria-label": "Dots Pagination", css: styles.dotsPaginationContainer },
11327
+ React.createElement(Flex, { flexDirection: "row", alignItems: "center", justifyContent: "center" }, pagination.map(function (index) { return (React.createElement(DotsPaginationIndicator, { key: "slide-".concat(index), isCurrent: index === currentSlideIndex })); }))));
11328
+ };
11329
+
11330
+ exports.PaginationType = void 0;
11331
+ (function (PaginationType) {
11332
+ PaginationType["Thumbnail"] = "thumbnail";
11333
+ PaginationType["Number"] = "number";
11334
+ PaginationType["None"] = "none";
11335
+ PaginationType["Dot"] = "dot";
11336
+ })(exports.PaginationType || (exports.PaginationType = {}));
11337
+ var isFullScreenSlide = function (value) {
11338
+ return typeof value === 'object' && value !== null && 'slide' in value;
11339
+ };
11340
+ // eslint-disable-next-line sonarjs/cognitive-complexity
11341
+ var Carousel = function (props) {
11342
+ var _a;
11343
+ var _b;
11344
+ var _c = props.startIndex, startIndex = _c === void 0 ? 0 : _c, onSlideClick = props.onSlideClick, onSlideSelect = props.onSlideSelect, fullScreen = props.fullScreen, _d = props.paginationType, paginationType = _d === void 0 ? exports.PaginationType.None : _d, _e = props.slidesPerView, slidesPerView = _e === void 0 ? 1 : _e, _f = props.loop, loop = _f === void 0 ? true : _f, _g = props.slidesToScroll, slidesToScroll = _g === void 0 ? 1 : _g;
11345
+ var _h = React.useState(loop), canScrollPrevious = _h[0], setCanScrollPrevious = _h[1];
11346
+ var _j = React.useState(loop), canScrollNext = _j[0], setCanScrollNext = _j[1];
11347
+ var _k = React.useState(startIndex), selectedIndex = _k[0], setSelectedIndex = _k[1];
11348
+ var isSmallLandscapeViewport = react$1.useMediaQuery(["(max-height: ".concat(breakpoints.sm.px, "px) and (orientation: landscape)")], {
11349
+ ssr: true,
11350
+ fallback: [false],
11351
+ })[0];
11352
+ var recipe = react$1.useSlotRecipe({ key: 'carousel' });
11353
+ var styles = recipe(fullScreen ? { variant: 'fullScreen' } : {});
11354
+ var _l = useEmblaCarousel({
11355
+ loop: loop,
11356
+ startIndex: startIndex,
11357
+ duration: 20,
11358
+ align: 'start',
11359
+ slidesToScroll: slidesToScroll,
11360
+ }), mainCarouselRef = _l[0], mainCarousel = _l[1];
11361
+ var _m = useEmblaCarousel({
11362
+ containScroll: 'keepSnaps',
11363
+ dragFree: true,
11364
+ slidesToScroll: 'auto',
11365
+ inViewThreshold: 1,
11366
+ duration: 20,
11367
+ }), paginationCarouselRef = _m[0], paginationCarousel = _m[1];
11368
+ var scrollPrev = React.useCallback(function () { return mainCarousel && mainCarousel.scrollPrev(true); }, [mainCarousel]);
11369
+ var scrollNext = React.useCallback(function () { return mainCarousel && mainCarousel.scrollNext(true); }, [mainCarousel]);
11370
+ var onClick = React.useCallback(function (index) {
11371
+ if (onSlideClick) {
11372
+ onSlideClick(index);
11373
+ }
11374
+ }, [onSlideClick]);
11375
+ var numberOfSlides = props.children.length;
11376
+ var hasThumbnailPagination = fullScreen && !isSmallLandscapeViewport;
11377
+ var onSelect = React.useCallback(function () {
11378
+ var _a, _b;
11379
+ if (!mainCarousel)
11380
+ return;
11381
+ var newIndex = mainCarousel.selectedScrollSnap();
11382
+ var previousIndex = mainCarousel.previousScrollSnap();
11383
+ setSelectedIndex(newIndex);
11384
+ setCanScrollPrevious(mainCarousel.canScrollPrev());
11385
+ setCanScrollNext(mainCarousel.canScrollNext());
11386
+ if (paginationCarousel && hasThumbnailPagination) {
11387
+ var slideRegistry = paginationCarousel.internalEngine().slideRegistry;
11388
+ var snapIndexThatSlideBelongsTo = slideRegistry.findIndex(function (group) {
11389
+ return group.includes(newIndex);
11390
+ });
11391
+ if (typeof snapIndexThatSlideBelongsTo !== 'undefined') {
11392
+ paginationCarousel.scrollTo(snapIndexThatSlideBelongsTo);
11393
+ }
11394
+ }
11395
+ if (onSlideSelect) {
11396
+ onSlideSelect(newIndex);
11397
+ }
11398
+ if (!props.fullScreen) {
11399
+ return;
11400
+ }
11401
+ var fullScreenChildren = props.children;
11402
+ if (newIndex !== undefined) {
11403
+ var currentSlide = fullScreenChildren[newIndex];
11404
+ (_a = currentSlide === null || currentSlide === void 0 ? void 0 : currentSlide.onSlideEnter) === null || _a === void 0 ? void 0 : _a.call(currentSlide);
11405
+ }
11406
+ if (previousIndex !== undefined && previousIndex !== newIndex) {
11407
+ var previousSlide = fullScreenChildren[previousIndex];
11408
+ (_b = previousSlide === null || previousSlide === void 0 ? void 0 : previousSlide.onSlideLeave) === null || _b === void 0 ? void 0 : _b.call(previousSlide);
11409
+ }
11410
+ }, [
11411
+ mainCarousel,
11412
+ paginationCarousel,
11413
+ onSlideSelect,
11414
+ hasThumbnailPagination,
11415
+ props.children,
11416
+ props.fullScreen,
11417
+ ]);
11418
+ React.useEffect(function () {
11419
+ if (!mainCarousel)
11420
+ return;
11421
+ onSelect();
11422
+ mainCarousel.on('select', onSelect);
11423
+ }, [mainCarousel, onSelect]);
11424
+ React.useEffect(function () {
11425
+ var keydownListener = function (e) {
11426
+ if (fullScreen) {
11427
+ switch (e.code) {
11428
+ case 'ArrowRight':
11429
+ scrollNext();
11430
+ break;
11431
+ case 'ArrowLeft':
11432
+ scrollPrev();
11433
+ break;
11434
+ }
11435
+ }
11436
+ };
11437
+ document.addEventListener('keydown', keydownListener);
11438
+ return function () { return document.removeEventListener('keydown', keydownListener); };
11439
+ }, [fullScreen, scrollNext, scrollPrev]);
11440
+ var prerenderFallbackSlide = startIndex !== 0 && !mainCarouselRef;
11441
+ var carouselHeightByPaginationTypeMap = (_a = {},
11442
+ _a[exports.PaginationType.None] = '100%',
11443
+ _a[exports.PaginationType.Dot] = '100%',
11444
+ _a[exports.PaginationType.Thumbnail] = 'calc(100% - var(--carousel-pagination-height))',
11445
+ _a[exports.PaginationType.Number] = 'calc(100% - var(--carousel-numbers-pagination-height))',
11446
+ _a);
11447
+ var carouselHeightCssVarValue = hasThumbnailPagination
11448
+ ? carouselHeightByPaginationTypeMap[exports.PaginationType.Thumbnail]
11449
+ : carouselHeightByPaginationTypeMap[paginationType];
11450
+ var _o = React.useState(false), isHovered = _o[0], setIsHovered = _o[1];
11451
+ return (React.createElement(react$1.Box, { css: styles.container, "data-group": true },
11452
+ prerenderFallbackSlide ? (React.createElement(Slide, { slideIndex: startIndex, onClick: function () { return onClick(startIndex); }, totalSlides: numberOfSlides, isCurrent: startIndex === selectedIndex, fullScreen: !!fullScreen, slidesPerView: slidesPerView }, props.fullScreen
11453
+ ? (_b = props.children[startIndex]) === null || _b === void 0 ? void 0 : _b.slide
11454
+ : props.children[startIndex])) : (React.createElement(react$1.Box, { ref: mainCarouselRef, "aria-label": "Carousel", "aria-roledescription": "Carousel", role: "group", "data-group": true, onMouseEnter: function () { return setIsHovered(true); }, onMouseLeave: function () { return setIsHovered(false); }, height: 'var(--carousel-height)', css: __assign(__assign({}, styles.carousel), { '--carousel-height': carouselHeightCssVarValue }) },
11455
+ React.createElement(Flex, { css: styles.slideContainer, marginLeft: slidesPerView === 1 ? '0' : { base: '-md', md: '-2xl' } }, props.children.map(function (slide, index) { return (React.createElement(Slide, { key: "slide-".concat(index), slideIndex: index, onClick: function () { return onClick(index); }, totalSlides: numberOfSlides, isCurrent: index === selectedIndex, fullScreen: !!fullScreen, slidesPerView: slidesPerView }, isFullScreenSlide(slide) ? slide.slide : slide)); })),
11456
+ canScrollPrevious ? (React.createElement(NavigationButton, { onClick: scrollPrev, direction: "previous", fullScreen: !!fullScreen, isHovered: isHovered || (!!fullScreen && !isSmallLandscapeViewport) })) : null,
11457
+ canScrollNext ? (React.createElement(NavigationButton, { onClick: scrollNext, direction: "next", fullScreen: !!fullScreen, isHovered: isHovered || (!!fullScreen && !isSmallLandscapeViewport) })) : null,
11458
+ paginationType === exports.PaginationType.Dot ? (React.createElement(NumbersDotsPagination, { currentSlideIndex: selectedIndex, numberOfSlides: props.children.length })) : null)),
11459
+ hasThumbnailPagination ? (React.createElement(ThumbnailPagination, { currentSlideIndex: selectedIndex, thumbnails: props.children.map(function (slide) { return slide.thumbnail; }), mainCarousel: mainCarousel, paginationCarousel: paginationCarousel, paginationCarouselRef: paginationCarouselRef })) : null,
11460
+ paginationType === exports.PaginationType.Number ? (React.createElement(NumbersPagination, { mainCarousel: mainCarousel, currentSlideIndex: selectedIndex, numberOfSlides: props.children.length })) : null));
11461
+ };
11462
+
11463
+ var TenantSelectionModalLayout = function (_a) {
11464
+ var children = _a.children;
11465
+ return (React.createElement(react$1.Box, { height: { base: 'full', sm: 'auth0-height' }, maxH: "screen-height", overflowX: "hidden", overflowY: "auto", paddingX: "2xl", paddingY: { base: '3xl', sm: '2xl' }, color: "gray.900" },
11466
+ React.createElement(Flex, { direction: "column", alignItems: "center", gridGap: "md", minHeight: "full" }, children)));
11467
+ };
11468
+
11469
+ var TenantSelectionSelect = function (_a) {
11470
+ var tenantSelection = _a.tenantSelection, setTenantSelection = _a.setTenantSelection, user = _a.user;
11471
+ var t = i18nPkg.useI18n().t;
11472
+ var onTenantSelect = React.useCallback(function (selectedTenantId) {
11473
+ setTenantSelection(function (current) {
11474
+ return __assign(__assign({}, current), { selectedTenant: selectedTenantId, showSelection: false });
11475
+ });
11476
+ }, [setTenantSelection]);
11477
+ return (React.createElement(TenantSelectionModalLayout, null,
11478
+ React.createElement(TenantSelectionSelectList, { title: t('auth.tenantSelection.selectionTitle'), managedSellers: user.managedSellers, selectedTenantId: tenantSelection.selectedTenant, onTenantSelect: onTenantSelect })));
11479
+ };
11480
+
11481
+ var img = "";
11482
+
11483
+ var TenantSelectionOverview = function (_a) {
11484
+ var tenantSelection = _a.tenantSelection, setTenantSelection = _a.setTenantSelection, user = _a.user, selectTenant = _a.selectTenant;
11485
+ var t = i18nPkg.useI18n().t;
11486
+ var getSelectButtonLabel = function () {
11487
+ if (!tenantSelection.selectedTenant)
11488
+ return t('auth.tenantSelection.selectButton');
11489
+ var selectedManagedSeller = user.managedSellers.find(function (managedSeller) {
11490
+ return managedSeller.id === tenantSelection.selectedTenant;
11491
+ });
11492
+ return createTenantLabel(selectedManagedSeller);
11493
+ };
11494
+ return (React.createElement(TenantSelectionModalLayout, null,
11495
+ React.createElement(react$1.Image, { src: img, alt: "tenant selection illustration", width: "3xl", height: "3xl", loading: "lazy" }),
11496
+ React.createElement(H1, { textStyle: "heading3" }, t('auth.tenantSelection.title')),
11497
+ React.createElement(Text, { textAlign: "center" }, t('auth.tenantSelection.description')),
11498
+ React.createElement(Button, { variant: "secondary", onClick: function () {
11499
+ setTenantSelection(function (currentState) {
11500
+ return __assign(__assign({}, currentState), { showSelection: true });
11501
+ });
11502
+ }, width: "full" }, getSelectButtonLabel()),
11503
+ React.createElement(Button, { disabled: !tenantSelection.selectedTenant, onClick: function () {
11504
+ if (!tenantSelection.selectedTenant)
11505
+ return;
11506
+ selectTenant(tenantSelection.selectedTenant);
11507
+ }, width: "full" }, t('auth.tenantSelection.loginButton'))));
11508
+ };
11509
+
11510
+ var TenantSelectionLoadingState = function () {
11511
+ return (React.createElement(TenantSelectionModalLayout, null,
11512
+ React.createElement(react$1.Box, { margin: "auto" },
11513
+ React.createElement(Spinner, null))));
11514
+ };
11515
+
11516
+ var TenantSelectionContainer = function (_a) {
11517
+ var language = _a.language, children = _a.children;
11518
+ return (React.createElement(TranslationProvider, { language: language, scopes: ['auth.tenantSelection'] },
11519
+ React.createElement(Dialog, { open: true, onOpenChange: function () { }, motionPreset: "none", size: "auth0", overlayColor: "gray", disableBodyPadding: true }, children)));
11520
+ };
11521
+
11522
+ var TenantSelection = function (_a) {
11523
+ var user = _a.user, _b = _a.isLoading, isLoading = _b === void 0 ? false : _b, selectTenant = _a.selectTenant, language = _a.language;
11524
+ var _c = React.useState({
11525
+ showSelection: false,
11526
+ selectedTenant: null,
11527
+ persistSelection: true,
11528
+ }), tenantSelection = _c[0], setTenantSelection = _c[1];
11529
+ if (!user || !user.forceTenantSelection)
11530
+ return null;
11531
+ if (isLoading) {
11532
+ return (React.createElement(TenantSelectionContainer, { language: language },
11533
+ React.createElement(TenantSelectionLoadingState, null)));
11534
+ }
11535
+ if (tenantSelection.showSelection) {
11536
+ return (React.createElement(TenantSelectionContainer, { language: language },
11537
+ React.createElement(TenantSelectionSelect, { user: user, tenantSelection: tenantSelection, setTenantSelection: setTenantSelection })));
11538
+ }
11539
+ return (React.createElement(TenantSelectionContainer, { language: language },
11540
+ React.createElement(TenantSelectionOverview, { user: user, tenantSelection: tenantSelection, setTenantSelection: setTenantSelection, selectTenant: selectTenant })));
11541
+ };
11542
+
8601
11543
  Object.defineProperty(exports, "Box", {
8602
11544
  enumerable: true,
8603
11545
  get: function () { return react$1.Box; }
@@ -8661,6 +11603,7 @@ exports.CardBody = Body$1;
8661
11603
  exports.CardFooter = Footer$2;
8662
11604
  exports.CardHeader = Header$1;
8663
11605
  exports.CardRoot = Root$2;
11606
+ exports.Carousel = Carousel;
8664
11607
  exports.CartIcon = CartIcon;
8665
11608
  exports.CategoryAIcon = CategoryAIcon;
8666
11609
  exports.CategoryAMinusIcon = CategoryAMinusIcon;
@@ -8782,6 +11725,7 @@ exports.MobileOnlyAccordion = MobileOnlyAccordion;
8782
11725
  exports.MotoScout24AppLogo = MotoScout24AppLogo;
8783
11726
  exports.MotoScout24Icon = MotoScout24Icon;
8784
11727
  exports.MotorcycleIcon = MotorcycleIcon;
11728
+ exports.Navigation = Navigation;
8785
11729
  exports.NoPhotoIcon = NoPhotoIcon;
8786
11730
  exports.NotAvailableIcon = NotAvailableIcon;
8787
11731
  exports.NotAvailableSquareIcon = NotAvailableSquareIcon;
@@ -8806,6 +11750,7 @@ exports.RotateIcon = RotateIcon;
8806
11750
  exports.SafeNumberIcon = SafeNumberIcon;
8807
11751
  exports.SaveSearchIcon = SaveSearchIcon;
8808
11752
  exports.ScreenIcon = ScreenIcon;
11753
+ exports.SearchableList = SearchableList;
8809
11754
  exports.Section = Section;
8810
11755
  exports.SedanIcon = SedanIcon;
8811
11756
  exports.Select = Select;
@@ -8841,6 +11786,7 @@ exports.TableRoot = Root;
8841
11786
  exports.TableRow = Row;
8842
11787
  exports.TableScrollArea = ScrollArea;
8843
11788
  exports.Tabs = Tabs;
11789
+ exports.TenantSelection = TenantSelection;
8844
11790
  exports.Text = Text;
8845
11791
  exports.ThemeProvider = ThemeProvider;
8846
11792
  exports.ThreeSixtyIcon = ThreeSixtyIcon;