@postnord/pn-marketweb-components 4.2.4 → 4.3.0

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 (522) hide show
  1. package/cjs/header-theme-a250bf67.js +245 -0
  2. package/cjs/header-theme-a250bf67.js.map +1 -0
  3. package/cjs/index-9a9efa1c.js +24 -16
  4. package/cjs/loader.cjs.js +1 -1
  5. package/cjs/pn-app-banner.cjs.entry.js +1 -1
  6. package/cjs/pn-breakpoints.cjs.entry.js +1 -1
  7. package/cjs/pn-chat-message_2.cjs.entry.js +2 -2
  8. package/cjs/pn-chat.cjs.entry.js +2 -2
  9. package/cjs/pn-customernumber-selector-option.cjs.entry.js +1 -1
  10. package/cjs/pn-customernumber-selector.cjs.entry.js +1 -1
  11. package/cjs/pn-find-price-result.cjs.entry.js +1 -1
  12. package/cjs/pn-find-price.cjs.entry.js +2 -2
  13. package/cjs/pn-find-service-and-price-result.cjs.entry.js +1 -1
  14. package/cjs/pn-find-service-and-price.cjs.entry.js +1 -1
  15. package/cjs/pn-hero-block-international.cjs.entry.js +1 -1
  16. package/cjs/pn-language-selector_13.cjs.entry.js +1519 -0
  17. package/cjs/pn-language-selector_13.cjs.entry.js.map +1 -0
  18. package/cjs/pn-level-up-modal.cjs.entry.js +1 -1
  19. package/cjs/pn-level-up.cjs.entry.js +2 -2
  20. package/cjs/pn-link-list.cjs.entry.js +1 -1
  21. package/cjs/pn-market-web-components.cjs.js +1 -1
  22. package/cjs/pn-marketweb-header-main-row_2.cjs.entry.js +222 -0
  23. package/cjs/pn-marketweb-header-main-row_2.cjs.entry.js.map +1 -0
  24. package/cjs/pn-marketweb-header-skeleton-loader.cjs.entry.js +23 -0
  25. package/cjs/pn-marketweb-header-skeleton-loader.cjs.entry.js.map +1 -0
  26. package/cjs/pn-marketweb-header-toggle.cjs.entry.js +46 -0
  27. package/cjs/pn-marketweb-header-toggle.cjs.entry.js.map +1 -0
  28. package/cjs/pn-marketweb-header.cjs.entry.js +1043 -0
  29. package/cjs/pn-marketweb-header.cjs.entry.js.map +1 -0
  30. package/cjs/pn-marketweb-icon.cjs.entry.js +1 -1
  31. package/cjs/{pn-marketweb-siteheader-login-linklist.cjs.entry.js → pn-marketweb-siteheader-login-button_2.cjs.entry.js} +44 -2
  32. package/cjs/pn-marketweb-siteheader-login-button_2.cjs.entry.js.map +1 -0
  33. package/cjs/pn-marketweb-siteheader-login-mypage-button.cjs.entry.js +1 -1
  34. package/cjs/pn-marketweb-siteheader.cjs.entry.js +7 -199
  35. package/cjs/pn-marketweb-siteheader.cjs.entry.js.map +1 -1
  36. package/cjs/pn-marketweb-table.cjs.entry.js +1 -1
  37. package/cjs/pn-media-block.cjs.entry.js +1 -1
  38. package/cjs/pn-pex-pricefinder.cjs.entry.js +1 -1
  39. package/cjs/pn-product-card_3.cjs.entry.js +1 -1
  40. package/cjs/pn-product-pricelist-result.cjs.entry.js +1 -1
  41. package/cjs/pn-product-pricelist.cjs.entry.js +2 -2
  42. package/cjs/pn-product-tile-info_2.cjs.entry.js +1 -1
  43. package/cjs/pn-product-tile.cjs.entry.js +1 -1
  44. package/cjs/pn-profile-modal-customernumber.cjs.entry.js +1 -1
  45. package/cjs/pn-profile-modal-profile.cjs.entry.js +2 -2
  46. package/cjs/pn-profile-modal-type.cjs.entry.js +1 -1
  47. package/cjs/pn-profile-modal.cjs.entry.js +1 -1
  48. package/cjs/pn-profile-selector-option.cjs.entry.js +1 -1
  49. package/cjs/pn-profile-selector.cjs.entry.js +1 -1
  50. package/cjs/pn-proxio-findprice-result.cjs.entry.js +1 -1
  51. package/cjs/pn-proxio-findprice.cjs.entry.js +3 -3
  52. package/cjs/pn-proxio-pricegroup.cjs.entry.js +1 -1
  53. package/cjs/pn-proxio-productcard_4.cjs.entry.js +3 -3
  54. package/cjs/pn-qr-code-generator.cjs.entry.js +1 -1
  55. package/cjs/pn-sidenav-level.cjs.entry.js +1 -1
  56. package/cjs/pn-sidenav-link.cjs.entry.js +1 -1
  57. package/cjs/pn-sidenav-togglebutton.cjs.entry.js +1 -1
  58. package/cjs/pn-sidenav.cjs.entry.js +1 -1
  59. package/cjs/pn-site-footer_3.cjs.entry.js +3 -3
  60. package/cjs/pn-titletag.cjs.entry.js +1 -1
  61. package/cjs/pn-usp-promoter.cjs.entry.js +1 -1
  62. package/cjs/pn-versa-card.cjs.entry.js +1 -1
  63. package/cjs/pn-versa-card.cjs.entry.js.map +1 -1
  64. package/cjs/translations-9510f11c.js +198 -0
  65. package/cjs/translations-9510f11c.js.map +1 -0
  66. package/collection/collection-manifest.json +5 -0
  67. package/collection/components/cards/pn-versa-card/pn-versa-card.css +27 -2
  68. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.css +204 -0
  69. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.js +658 -0
  70. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.js.map +1 -0
  71. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.css +217 -0
  72. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.js +20 -0
  73. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.js.map +1 -0
  74. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.css +115 -0
  75. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.js +520 -0
  76. package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.js.map +1 -0
  77. package/collection/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.js +37 -0
  78. package/collection/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.js.map +1 -0
  79. package/collection/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.js +109 -0
  80. package/collection/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.js.map +1 -0
  81. package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.css +225 -0
  82. package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.js +916 -0
  83. package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.js.map +1 -0
  84. package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.js +638 -0
  85. package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.js.map +1 -0
  86. package/collection/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.js +180 -0
  87. package/collection/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.js.map +1 -0
  88. package/collection/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.js +2 -0
  89. package/collection/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.js.map +1 -0
  90. package/collection/components/layout-components/pn-marketweb-header/utils/header-i18n.js +37 -0
  91. package/collection/components/layout-components/pn-marketweb-header/utils/header-i18n.js.map +1 -0
  92. package/collection/components/layout-components/pn-marketweb-header/utils/header-language.js +46 -0
  93. package/collection/components/layout-components/pn-marketweb-header/utils/header-language.js.map +1 -0
  94. package/collection/components/layout-components/pn-marketweb-header/utils/header-menu.js +36 -0
  95. package/collection/components/layout-components/pn-marketweb-header/utils/header-menu.js.map +1 -0
  96. package/collection/components/layout-components/pn-marketweb-header/utils/header-theme.js +48 -0
  97. package/collection/components/layout-components/pn-marketweb-header/utils/header-theme.js.map +1 -0
  98. package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.js +101 -0
  99. package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.js.map +1 -0
  100. package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.js +63 -0
  101. package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.js.map +1 -0
  102. package/collection/components/layout-components/pn-marketweb-header/utils/header-url.js +91 -0
  103. package/collection/components/layout-components/pn-marketweb-header/utils/header-url.js.map +1 -0
  104. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-button.js +1 -1
  105. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-linklist.css +34 -12
  106. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-mypage-button.js +1 -1
  107. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-profileselection.css +36 -15
  108. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.css +27 -13
  109. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.js +29 -4
  110. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.js.map +1 -1
  111. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-types.js.map +1 -1
  112. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-unified-login.js +1 -1
  113. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader.js +4 -4
  114. package/collection/components/media/pn-media-block/pn-media-block.js +1 -1
  115. package/collection/components/minor/pn-app-banner/pn-app-banner.js +1 -1
  116. package/collection/components/minor/pn-marketweb-icon/pn-marketweb-icon.js +1 -1
  117. package/collection/components/minor/pn-swan/pn-swan.js +1 -1
  118. package/collection/components/minor/pn-titletag/pn-titletag.js +1 -1
  119. package/collection/components/navigation/pn-language-selector/pn-language-selector-option.css +25 -12
  120. package/collection/components/navigation/pn-language-selector/pn-language-selector-option.js +1 -1
  121. package/collection/components/navigation/pn-language-selector/pn-language-selector.css +17 -5
  122. package/collection/components/navigation/pn-language-selector/pn-language-selector.js +22 -3
  123. package/collection/components/navigation/pn-language-selector/pn-language-selector.js.map +1 -1
  124. package/collection/components/navigation/pn-mainnav/pn-mainnav-level.css +37 -17
  125. package/collection/components/navigation/pn-mainnav/pn-mainnav-level.js +2 -2
  126. package/collection/components/navigation/pn-mainnav/pn-mainnav-link.css +81 -33
  127. package/collection/components/navigation/pn-mainnav/pn-mainnav-link.js +1 -1
  128. package/collection/components/navigation/pn-mainnav/pn-mainnav-list.css +12 -2
  129. package/collection/components/navigation/pn-mainnav/pn-mainnav-list.js +1 -1
  130. package/collection/components/navigation/pn-mainnav/pn-mainnav.css +35 -22
  131. package/collection/components/navigation/pn-mainnav/pn-mainnav.js +1 -1
  132. package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.css +80 -0
  133. package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.js +147 -0
  134. package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.js.map +1 -0
  135. package/collection/components/navigation/pn-sidenav/pn-sidenav-level.js +1 -1
  136. package/collection/components/navigation/pn-sidenav/pn-sidenav-link.js +1 -1
  137. package/collection/components/navigation/pn-sidenav/pn-sidenav-togglebutton.js +1 -1
  138. package/collection/components/navigation/pn-sidenav/pn-sidenav.js +1 -1
  139. package/collection/components/navigation/pn-site-footer/pn-site-footer-col.js +1 -1
  140. package/collection/components/navigation/pn-site-footer/pn-site-footer.js +1 -1
  141. package/collection/components/navigation/pn-site-selector/pn-site-selector-item.css +16 -12
  142. package/collection/components/navigation/pn-site-selector/pn-site-selector-item.js +1 -1
  143. package/collection/components/navigation/pn-site-selector/pn-site-selector.css +15 -0
  144. package/collection/components/navigation/pn-site-selector/pn-site-selector.js +22 -3
  145. package/collection/components/navigation/pn-site-selector/pn-site-selector.js.map +1 -1
  146. package/collection/components/profile/pn-customernumber-selector/pn-customernumber-selector-option.js +1 -1
  147. package/collection/components/profile/pn-customernumber-selector/pn-customernumber-selector.js +1 -1
  148. package/collection/components/profile/pn-profile-modal/pn-profile-modal-customernumber.js +1 -1
  149. package/collection/components/profile/pn-profile-modal/pn-profile-modal-profile.js +2 -2
  150. package/collection/components/profile/pn-profile-modal/pn-profile-modal-type.js +1 -1
  151. package/collection/components/profile/pn-profile-modal/pn-profile-modal.js +1 -1
  152. package/collection/components/profile/pn-profile-selector/pn-profile-selector-option.js +1 -1
  153. package/collection/components/profile/pn-profile-selector/pn-profile-selector.js +1 -1
  154. package/collection/components/utilities/pn-breakpoints/pn-breakpoints.js +1 -1
  155. package/collection/components/widgets/pn-chat/pn-chat-message/pn-chat-message.js +1 -1
  156. package/collection/components/widgets/pn-chat/pn-chat.js +2 -2
  157. package/collection/components/widgets/pn-find-price/pn-find-price-result.js +1 -1
  158. package/collection/components/widgets/pn-find-price/pn-find-price.js +2 -2
  159. package/collection/components/widgets/pn-find-service-and-price/pn-find-service-and-price-result.js +1 -1
  160. package/collection/components/widgets/pn-find-service-and-price/pn-find-service-and-price.js +1 -1
  161. package/collection/components/widgets/pn-hero-block-international/pn-hero-block-international.js +1 -1
  162. package/collection/components/widgets/pn-level-up/pn-level-up-modal/pn-level-up-modal.js +1 -1
  163. package/collection/components/widgets/pn-level-up/pn-level-up.js +2 -2
  164. package/collection/components/widgets/pn-link-list/pn-link-list.js +1 -1
  165. package/collection/components/widgets/pn-marketweb-carousel/pn-marketweb-carousel.js +1 -1
  166. package/collection/components/widgets/pn-marketweb-table/pn-marketweb-table.js +1 -1
  167. package/collection/components/widgets/pn-pex-pricefinder/pn-pex-pricefinder.js +1 -1
  168. package/collection/components/widgets/pn-product-card/pn-product-card.js +1 -1
  169. package/collection/components/widgets/pn-product-pricelist/pn-product-pricelist-result.js +1 -1
  170. package/collection/components/widgets/pn-product-pricelist/pn-product-pricelist.js +2 -2
  171. package/collection/components/widgets/pn-product-tile/pn-product-tile-info.js +1 -1
  172. package/collection/components/widgets/pn-product-tile/pn-product-tile.js +1 -1
  173. package/collection/components/widgets/pn-proxio-findprice/pn-proxio-findprice-result.js +1 -1
  174. package/collection/components/widgets/pn-proxio-findprice/pn-proxio-findprice.js +3 -3
  175. package/collection/components/widgets/pn-proxio-pricegroup/pn-proxio-pricegroup.js +1 -1
  176. package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard-description.js +1 -1
  177. package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard-information.js +1 -1
  178. package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard.js +1 -1
  179. package/collection/components/widgets/pn-qr-code-generator/pn-qr-code-generator.js +1 -1
  180. package/collection/components/widgets/pn-usp-promoter/pn-usp-promoter.js +1 -1
  181. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.js +105 -0
  182. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.js.map +1 -0
  183. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.js +166 -0
  184. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.js.map +1 -0
  185. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.js +2 -0
  186. package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.js.map +1 -0
  187. package/components/pn-app-banner.js +1 -1
  188. package/components/pn-breakpoints.js +1 -1
  189. package/components/pn-chat-message2.js +1 -1
  190. package/components/pn-chat.js +2 -2
  191. package/components/pn-customernumber-selector-option.js +1 -1
  192. package/components/pn-customernumber-selector.js +1 -1
  193. package/components/pn-find-price-result2.js +1 -1
  194. package/components/pn-find-price.js +2 -2
  195. package/components/pn-find-service-and-price-result2.js +1 -1
  196. package/components/pn-find-service-and-price.js +1 -1
  197. package/components/pn-hero-block-international.js +1 -1
  198. package/components/pn-language-selector-option2.js +2 -2
  199. package/components/pn-language-selector-option2.js.map +1 -1
  200. package/components/pn-language-selector2.js +4 -2
  201. package/components/pn-language-selector2.js.map +1 -1
  202. package/components/pn-level-up-modal2.js +1 -1
  203. package/components/pn-level-up.js +2 -2
  204. package/components/pn-link-list.js +1 -1
  205. package/components/pn-mainnav-level2.js +3 -3
  206. package/components/pn-mainnav-level2.js.map +1 -1
  207. package/components/pn-mainnav-link2.js +2 -2
  208. package/components/pn-mainnav-link2.js.map +1 -1
  209. package/components/pn-mainnav-list2.js +2 -2
  210. package/components/pn-mainnav-list2.js.map +1 -1
  211. package/components/pn-mainnav2.js +2 -2
  212. package/components/pn-mainnav2.js.map +1 -1
  213. package/components/pn-marketweb-carousel2.js +1 -1
  214. package/components/pn-marketweb-header-main-row.d.ts +11 -0
  215. package/components/pn-marketweb-header-main-row.js +8 -0
  216. package/components/pn-marketweb-header-main-row.js.map +1 -0
  217. package/components/pn-marketweb-header-main-row2.js +281 -0
  218. package/components/pn-marketweb-header-main-row2.js.map +1 -0
  219. package/components/pn-marketweb-header-shared.js +192 -0
  220. package/components/pn-marketweb-header-shared.js.map +1 -0
  221. package/components/pn-marketweb-header-skeleton-loader.d.ts +11 -0
  222. package/components/pn-marketweb-header-skeleton-loader.js +37 -0
  223. package/components/pn-marketweb-header-skeleton-loader.js.map +1 -0
  224. package/components/pn-marketweb-header-toggle.d.ts +11 -0
  225. package/components/pn-marketweb-header-toggle.js +8 -0
  226. package/components/pn-marketweb-header-toggle.js.map +1 -0
  227. package/components/pn-marketweb-header-toggle2.js +61 -0
  228. package/components/pn-marketweb-header-toggle2.js.map +1 -0
  229. package/components/pn-marketweb-header-top-row.d.ts +11 -0
  230. package/components/pn-marketweb-header-top-row.js +8 -0
  231. package/components/pn-marketweb-header-top-row.js.map +1 -0
  232. package/components/pn-marketweb-header-top-row2.js +238 -0
  233. package/components/pn-marketweb-header-top-row2.js.map +1 -0
  234. package/components/pn-marketweb-header.d.ts +11 -0
  235. package/components/pn-marketweb-header.js +1206 -0
  236. package/components/pn-marketweb-header.js.map +1 -0
  237. package/components/pn-marketweb-icon.js +1 -1
  238. package/components/pn-marketweb-siteheader-login-button2.js +1 -1
  239. package/components/pn-marketweb-siteheader-login-linklist2.js +1 -1
  240. package/components/pn-marketweb-siteheader-login-linklist2.js.map +1 -1
  241. package/components/pn-marketweb-siteheader-login-mypage-button.js +1 -1
  242. package/components/pn-marketweb-siteheader-login-profileselection2.js +1 -1
  243. package/components/pn-marketweb-siteheader-login-profileselection2.js.map +1 -1
  244. package/components/pn-marketweb-siteheader-login2.js +4 -2
  245. package/components/pn-marketweb-siteheader-login2.js.map +1 -1
  246. package/components/pn-marketweb-siteheader-unified-login2.js +1 -1
  247. package/components/pn-marketweb-siteheader.js +5 -197
  248. package/components/pn-marketweb-siteheader.js.map +1 -1
  249. package/components/pn-marketweb-table.js +1 -1
  250. package/components/pn-media-block.js +1 -1
  251. package/components/pn-pex-pricefinder.js +1 -1
  252. package/components/pn-product-card2.js +1 -1
  253. package/components/pn-product-pricelist-result.js +1 -1
  254. package/components/pn-product-pricelist.js +2 -2
  255. package/components/pn-product-tile-info2.js +1 -1
  256. package/components/pn-product-tile.js +1 -1
  257. package/components/pn-profile-modal-customernumber.js +1 -1
  258. package/components/pn-profile-modal-profile.js +2 -2
  259. package/components/pn-profile-modal-type.js +1 -1
  260. package/components/pn-profile-modal.js +1 -1
  261. package/components/pn-profile-selector-option.js +1 -1
  262. package/components/pn-profile-selector.js +1 -1
  263. package/components/pn-proxio-findprice-result2.js +2 -2
  264. package/components/pn-proxio-findprice.js +3 -3
  265. package/components/pn-proxio-pricegroup.js +2 -2
  266. package/components/pn-proxio-productcard-description2.js +1 -1
  267. package/components/pn-proxio-productcard-information2.js +1 -1
  268. package/components/pn-proxio-productcard2.js +1 -1
  269. package/components/pn-qr-code-generator2.js +1 -1
  270. package/components/pn-sidenav-level.js +1 -1
  271. package/components/pn-sidenav-link.js +1 -1
  272. package/components/pn-sidenav-togglebutton.js +1 -1
  273. package/components/pn-sidenav.js +1 -1
  274. package/components/pn-site-footer-col2.js +1 -1
  275. package/components/pn-site-footer2.js +1 -1
  276. package/components/pn-site-selector-item2.js +2 -2
  277. package/components/pn-site-selector-item2.js.map +1 -1
  278. package/components/pn-site-selector2.js +4 -2
  279. package/components/pn-site-selector2.js.map +1 -1
  280. package/components/pn-swan2.js +1 -1
  281. package/components/pn-titletag2.js +1 -1
  282. package/components/pn-usp-promoter.js +1 -1
  283. package/components/pn-versa-card.js +1 -1
  284. package/components/pn-versa-card.js.map +1 -1
  285. package/components/translations.js +189 -14
  286. package/components/translations.js.map +1 -1
  287. package/components/translations2.js +21 -0
  288. package/components/translations2.js.map +1 -0
  289. package/esm/header-theme-d09b64c7.js +234 -0
  290. package/esm/header-theme-d09b64c7.js.map +1 -0
  291. package/esm/index-c0a4d8bd.js +24 -16
  292. package/esm/loader.js +1 -1
  293. package/esm/pn-app-banner.entry.js +1 -1
  294. package/esm/pn-breakpoints.entry.js +1 -1
  295. package/esm/pn-chat-message_2.entry.js +2 -2
  296. package/esm/pn-chat.entry.js +2 -2
  297. package/esm/pn-customernumber-selector-option.entry.js +1 -1
  298. package/esm/pn-customernumber-selector.entry.js +1 -1
  299. package/esm/pn-find-price-result.entry.js +1 -1
  300. package/esm/pn-find-price.entry.js +2 -2
  301. package/esm/pn-find-service-and-price-result.entry.js +1 -1
  302. package/esm/pn-find-service-and-price.entry.js +1 -1
  303. package/esm/pn-hero-block-international.entry.js +1 -1
  304. package/esm/{pn-language-selector_9.entry.js → pn-language-selector_13.entry.js} +381 -22
  305. package/esm/pn-language-selector_13.entry.js.map +1 -0
  306. package/esm/pn-level-up-modal.entry.js +1 -1
  307. package/esm/pn-level-up.entry.js +2 -2
  308. package/esm/pn-link-list.entry.js +1 -1
  309. package/esm/pn-market-web-components.js +1 -1
  310. package/esm/pn-marketweb-header-main-row_2.entry.js +217 -0
  311. package/esm/pn-marketweb-header-main-row_2.entry.js.map +1 -0
  312. package/esm/pn-marketweb-header-skeleton-loader.entry.js +19 -0
  313. package/esm/pn-marketweb-header-skeleton-loader.entry.js.map +1 -0
  314. package/esm/pn-marketweb-header-toggle.entry.js +42 -0
  315. package/esm/pn-marketweb-header-toggle.entry.js.map +1 -0
  316. package/esm/pn-marketweb-header.entry.js +1039 -0
  317. package/esm/pn-marketweb-header.entry.js.map +1 -0
  318. package/esm/pn-marketweb-icon.entry.js +1 -1
  319. package/esm/{pn-marketweb-siteheader-login-linklist.entry.js → pn-marketweb-siteheader-login-button_2.entry.js} +44 -3
  320. package/esm/pn-marketweb-siteheader-login-button_2.entry.js.map +1 -0
  321. package/esm/pn-marketweb-siteheader-login-mypage-button.entry.js +1 -1
  322. package/esm/pn-marketweb-siteheader.entry.js +5 -197
  323. package/esm/pn-marketweb-siteheader.entry.js.map +1 -1
  324. package/esm/pn-marketweb-table.entry.js +1 -1
  325. package/esm/pn-media-block.entry.js +1 -1
  326. package/esm/pn-pex-pricefinder.entry.js +1 -1
  327. package/esm/pn-product-card_3.entry.js +1 -1
  328. package/esm/pn-product-pricelist-result.entry.js +1 -1
  329. package/esm/pn-product-pricelist.entry.js +2 -2
  330. package/esm/pn-product-tile-info_2.entry.js +1 -1
  331. package/esm/pn-product-tile.entry.js +1 -1
  332. package/esm/pn-profile-modal-customernumber.entry.js +1 -1
  333. package/esm/pn-profile-modal-profile.entry.js +2 -2
  334. package/esm/pn-profile-modal-type.entry.js +1 -1
  335. package/esm/pn-profile-modal.entry.js +1 -1
  336. package/esm/pn-profile-selector-option.entry.js +1 -1
  337. package/esm/pn-profile-selector.entry.js +1 -1
  338. package/esm/pn-proxio-findprice-result.entry.js +1 -1
  339. package/esm/pn-proxio-findprice.entry.js +3 -3
  340. package/esm/pn-proxio-pricegroup.entry.js +1 -1
  341. package/esm/pn-proxio-productcard_4.entry.js +3 -3
  342. package/esm/pn-qr-code-generator.entry.js +1 -1
  343. package/esm/pn-sidenav-level.entry.js +1 -1
  344. package/esm/pn-sidenav-link.entry.js +1 -1
  345. package/esm/pn-sidenav-togglebutton.entry.js +1 -1
  346. package/esm/pn-sidenav.entry.js +1 -1
  347. package/esm/pn-site-footer_3.entry.js +3 -3
  348. package/esm/pn-titletag.entry.js +1 -1
  349. package/esm/pn-usp-promoter.entry.js +1 -1
  350. package/esm/pn-versa-card.entry.js +1 -1
  351. package/esm/pn-versa-card.entry.js.map +1 -1
  352. package/esm/translations-d2f5804e.js +196 -0
  353. package/esm/translations-d2f5804e.js.map +1 -0
  354. package/package.json +1 -1
  355. package/pn-market-web-components/{p-4a164ef8.entry.js → p-03728b0b.entry.js} +2 -2
  356. package/pn-market-web-components/p-04f51418.js +2 -0
  357. package/pn-market-web-components/p-04f51418.js.map +1 -0
  358. package/pn-market-web-components/{p-e43a36e0.entry.js → p-067c1c2f.entry.js} +2 -2
  359. package/pn-market-web-components/p-16570ed2.entry.js +2 -0
  360. package/pn-market-web-components/p-16570ed2.entry.js.map +1 -0
  361. package/pn-market-web-components/{p-2616cdc1.entry.js → p-191c8cfc.entry.js} +2 -2
  362. package/pn-market-web-components/{p-ca003c1f.entry.js → p-1a91c313.entry.js} +2 -2
  363. package/pn-market-web-components/{p-ab1e3dc2.entry.js → p-1f8304be.entry.js} +2 -2
  364. package/pn-market-web-components/{p-a3f601cb.entry.js → p-24ffac0a.entry.js} +2 -2
  365. package/pn-market-web-components/p-3239c36b.entry.js +2 -0
  366. package/pn-market-web-components/p-3239c36b.entry.js.map +1 -0
  367. package/pn-market-web-components/{p-12cafd55.entry.js → p-3aa74418.entry.js} +2 -2
  368. package/pn-market-web-components/p-3d27faee.entry.js +2 -0
  369. package/pn-market-web-components/{p-9d0ca27b.entry.js.map → p-3d27faee.entry.js.map} +1 -1
  370. package/pn-market-web-components/p-3e25f431.entry.js +2 -0
  371. package/pn-market-web-components/p-3e25f431.entry.js.map +1 -0
  372. package/pn-market-web-components/{p-64f6691d.entry.js → p-42da7c5f.entry.js} +2 -2
  373. package/pn-market-web-components/{p-f0d423d0.entry.js → p-43748ca2.entry.js} +2 -2
  374. package/pn-market-web-components/{p-1c644b91.entry.js → p-466958a8.entry.js} +2 -2
  375. package/pn-market-web-components/{p-150da889.entry.js → p-4ab53d5d.entry.js} +2 -2
  376. package/pn-market-web-components/{p-118fe47d.entry.js → p-4d595345.entry.js} +2 -2
  377. package/pn-market-web-components/{p-0f6f715b.entry.js → p-4dac1980.entry.js} +2 -2
  378. package/pn-market-web-components/{p-a13f1f73.entry.js → p-4fcce83d.entry.js} +2 -2
  379. package/pn-market-web-components/{p-89fbca3b.entry.js → p-5a51d0b0.entry.js} +2 -2
  380. package/pn-market-web-components/{p-f4d2d0d3.entry.js → p-61346425.entry.js} +2 -2
  381. package/pn-market-web-components/{p-6e693269.entry.js → p-6b557670.entry.js} +2 -2
  382. package/pn-market-web-components/{p-e6d6a752.entry.js → p-70a71854.entry.js} +2 -2
  383. package/pn-market-web-components/p-75311d67.js +2 -0
  384. package/pn-market-web-components/p-75311d67.js.map +1 -0
  385. package/pn-market-web-components/p-756d8d95.entry.js +2 -0
  386. package/pn-market-web-components/p-756d8d95.entry.js.map +1 -0
  387. package/pn-market-web-components/{p-c0315c45.entry.js → p-76fb0c21.entry.js} +2 -2
  388. package/pn-market-web-components/{p-b2b2bae0.entry.js → p-81210644.entry.js} +2 -2
  389. package/pn-market-web-components/p-81e4d75b.entry.js +2 -0
  390. package/pn-market-web-components/p-81e4d75b.entry.js.map +1 -0
  391. package/pn-market-web-components/{p-d0f27361.entry.js → p-8382794b.entry.js} +2 -2
  392. package/pn-market-web-components/{p-8f25176b.entry.js → p-8519e39e.entry.js} +2 -2
  393. package/pn-market-web-components/p-8c26c1f2.entry.js +2 -0
  394. package/pn-market-web-components/p-8c26c1f2.entry.js.map +1 -0
  395. package/pn-market-web-components/{p-461c8792.entry.js → p-92b6477c.entry.js} +2 -2
  396. package/pn-market-web-components/{p-0d4d9d90.entry.js → p-9eab8192.entry.js} +2 -2
  397. package/pn-market-web-components/{p-40e632cc.entry.js → p-a3beee11.entry.js} +2 -2
  398. package/pn-market-web-components/{p-01fbf1ce.entry.js → p-a6935dc2.entry.js} +2 -2
  399. package/pn-market-web-components/{p-af646091.entry.js → p-a6dd3e4f.entry.js} +2 -2
  400. package/pn-market-web-components/{p-6d77e747.entry.js → p-af89c95a.entry.js} +2 -2
  401. package/pn-market-web-components/p-b318ff19.entry.js +2 -0
  402. package/pn-market-web-components/{p-0700cb4c.entry.js.map → p-b318ff19.entry.js.map} +1 -1
  403. package/pn-market-web-components/{p-c89f3d6b.entry.js → p-ba14b0ef.entry.js} +2 -2
  404. package/pn-market-web-components/{p-c7965104.entry.js → p-ba680948.entry.js} +2 -2
  405. package/pn-market-web-components/{p-11c6e458.entry.js → p-ba75bfdb.entry.js} +2 -2
  406. package/pn-market-web-components/{p-4149e715.entry.js → p-c186ec41.entry.js} +2 -2
  407. package/pn-market-web-components/{p-66c0c8dc.entry.js → p-c38707f9.entry.js} +2 -2
  408. package/pn-market-web-components/{p-671a8129.entry.js → p-c89cdd5a.entry.js} +2 -2
  409. package/pn-market-web-components/{p-4d848e18.entry.js → p-e8cd1608.entry.js} +2 -2
  410. package/pn-market-web-components/{p-4517a3d4.entry.js → p-ef090656.entry.js} +2 -2
  411. package/pn-market-web-components/p-f23ed5d2.entry.js +2 -0
  412. package/pn-market-web-components/p-f23ed5d2.entry.js.map +1 -0
  413. package/pn-market-web-components/{p-bd8ec517.entry.js → p-f3b4c13d.entry.js} +2 -2
  414. package/pn-market-web-components/{p-ff38b9a5.entry.js → p-f710445f.entry.js} +2 -2
  415. package/pn-market-web-components/{p-2e585ed5.entry.js → p-fcefe4a4.entry.js} +2 -2
  416. package/pn-market-web-components/p-fded22b7.entry.js +2 -0
  417. package/pn-market-web-components/p-fded22b7.entry.js.map +1 -0
  418. package/pn-market-web-components/{p-32bd2ff8.entry.js → p-ff6118f8.entry.js} +2 -2
  419. package/pn-market-web-components/pn-market-web-components.esm.js +1 -1
  420. package/pn-market-web-components/pn-market-web-components.esm.js.map +1 -1
  421. package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.d.ts +40 -0
  422. package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.d.ts +3 -0
  423. package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.d.ts +30 -0
  424. package/types/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.d.ts +48 -0
  425. package/types/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.d.ts +34 -0
  426. package/types/components/layout-components/pn-marketweb-header/pn-marketweb-header.d.ts +121 -0
  427. package/types/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.d.ts +99 -0
  428. package/types/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.d.ts +108 -0
  429. package/types/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.d.ts +103 -0
  430. package/types/components/layout-components/pn-marketweb-header/utils/header-i18n.d.ts +16 -0
  431. package/types/components/layout-components/pn-marketweb-header/utils/header-language.d.ts +20 -0
  432. package/types/components/layout-components/pn-marketweb-header/utils/header-menu.d.ts +16 -0
  433. package/types/components/layout-components/pn-marketweb-header/utils/header-theme.d.ts +6 -0
  434. package/types/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.d.ts +49 -0
  435. package/types/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.d.ts +25 -0
  436. package/types/components/layout-components/pn-marketweb-header/utils/header-url.d.ts +41 -0
  437. package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.d.ts +2 -0
  438. package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-types.d.ts +1 -0
  439. package/types/components/navigation/pn-language-selector/pn-language-selector.d.ts +1 -0
  440. package/types/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.d.ts +25 -0
  441. package/types/components/navigation/pn-site-selector/pn-site-selector.d.ts +1 -0
  442. package/types/components/widgets/pn-proxio-pricegroup/pn-proxio-pricegroup.d.ts +1 -1
  443. package/types/components.d.ts +532 -2
  444. package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.d.ts +7 -0
  445. package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.d.ts +24 -0
  446. package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.d.ts +16 -0
  447. package/umd/pn-marketweb-init.js +1 -1
  448. package/umd/pn-marketweb-salesforce.js +1 -1
  449. package/vscode-data.json +421 -0
  450. package/cjs/pn-language-selector_9.cjs.entry.js +0 -1156
  451. package/cjs/pn-language-selector_9.cjs.entry.js.map +0 -1
  452. package/cjs/pn-mainnav-link.cjs.entry.js +0 -45
  453. package/cjs/pn-mainnav-link.cjs.entry.js.map +0 -1
  454. package/cjs/pn-mainnav-store-13aaa243.js +0 -22
  455. package/cjs/pn-mainnav-store-13aaa243.js.map +0 -1
  456. package/cjs/pn-marketweb-siteheader-login-button_4.cjs.entry.js +0 -366
  457. package/cjs/pn-marketweb-siteheader-login-button_4.cjs.entry.js.map +0 -1
  458. package/cjs/pn-marketweb-siteheader-login-linklist.cjs.entry.js.map +0 -1
  459. package/esm/pn-language-selector_9.entry.js.map +0 -1
  460. package/esm/pn-mainnav-link.entry.js +0 -41
  461. package/esm/pn-mainnav-link.entry.js.map +0 -1
  462. package/esm/pn-mainnav-store-c98d831e.js +0 -19
  463. package/esm/pn-mainnav-store-c98d831e.js.map +0 -1
  464. package/esm/pn-marketweb-siteheader-login-button_4.entry.js +0 -359
  465. package/esm/pn-marketweb-siteheader-login-button_4.entry.js.map +0 -1
  466. package/esm/pn-marketweb-siteheader-login-linklist.entry.js.map +0 -1
  467. package/pn-market-web-components/p-022780ab.entry.js +0 -2
  468. package/pn-market-web-components/p-022780ab.entry.js.map +0 -1
  469. package/pn-market-web-components/p-0700cb4c.entry.js +0 -2
  470. package/pn-market-web-components/p-3c69298b.entry.js +0 -2
  471. package/pn-market-web-components/p-3c69298b.entry.js.map +0 -1
  472. package/pn-market-web-components/p-4bc6d49f.entry.js +0 -2
  473. package/pn-market-web-components/p-4bc6d49f.entry.js.map +0 -1
  474. package/pn-market-web-components/p-4c8bda8f.entry.js +0 -2
  475. package/pn-market-web-components/p-4c8bda8f.entry.js.map +0 -1
  476. package/pn-market-web-components/p-5090bb1d.entry.js +0 -2
  477. package/pn-market-web-components/p-5090bb1d.entry.js.map +0 -1
  478. package/pn-market-web-components/p-9d0ca27b.entry.js +0 -2
  479. package/pn-market-web-components/p-a30de538.entry.js +0 -2
  480. package/pn-market-web-components/p-a30de538.entry.js.map +0 -1
  481. package/pn-market-web-components/p-e3b2486a.js +0 -2
  482. package/pn-market-web-components/p-e3b2486a.js.map +0 -1
  483. /package/pn-market-web-components/{p-4a164ef8.entry.js.map → p-03728b0b.entry.js.map} +0 -0
  484. /package/pn-market-web-components/{p-e43a36e0.entry.js.map → p-067c1c2f.entry.js.map} +0 -0
  485. /package/pn-market-web-components/{p-2616cdc1.entry.js.map → p-191c8cfc.entry.js.map} +0 -0
  486. /package/pn-market-web-components/{p-ca003c1f.entry.js.map → p-1a91c313.entry.js.map} +0 -0
  487. /package/pn-market-web-components/{p-ab1e3dc2.entry.js.map → p-1f8304be.entry.js.map} +0 -0
  488. /package/pn-market-web-components/{p-a3f601cb.entry.js.map → p-24ffac0a.entry.js.map} +0 -0
  489. /package/pn-market-web-components/{p-12cafd55.entry.js.map → p-3aa74418.entry.js.map} +0 -0
  490. /package/pn-market-web-components/{p-64f6691d.entry.js.map → p-42da7c5f.entry.js.map} +0 -0
  491. /package/pn-market-web-components/{p-f0d423d0.entry.js.map → p-43748ca2.entry.js.map} +0 -0
  492. /package/pn-market-web-components/{p-1c644b91.entry.js.map → p-466958a8.entry.js.map} +0 -0
  493. /package/pn-market-web-components/{p-150da889.entry.js.map → p-4ab53d5d.entry.js.map} +0 -0
  494. /package/pn-market-web-components/{p-118fe47d.entry.js.map → p-4d595345.entry.js.map} +0 -0
  495. /package/pn-market-web-components/{p-0f6f715b.entry.js.map → p-4dac1980.entry.js.map} +0 -0
  496. /package/pn-market-web-components/{p-a13f1f73.entry.js.map → p-4fcce83d.entry.js.map} +0 -0
  497. /package/pn-market-web-components/{p-89fbca3b.entry.js.map → p-5a51d0b0.entry.js.map} +0 -0
  498. /package/pn-market-web-components/{p-f4d2d0d3.entry.js.map → p-61346425.entry.js.map} +0 -0
  499. /package/pn-market-web-components/{p-6e693269.entry.js.map → p-6b557670.entry.js.map} +0 -0
  500. /package/pn-market-web-components/{p-e6d6a752.entry.js.map → p-70a71854.entry.js.map} +0 -0
  501. /package/pn-market-web-components/{p-c0315c45.entry.js.map → p-76fb0c21.entry.js.map} +0 -0
  502. /package/pn-market-web-components/{p-b2b2bae0.entry.js.map → p-81210644.entry.js.map} +0 -0
  503. /package/pn-market-web-components/{p-d0f27361.entry.js.map → p-8382794b.entry.js.map} +0 -0
  504. /package/pn-market-web-components/{p-8f25176b.entry.js.map → p-8519e39e.entry.js.map} +0 -0
  505. /package/pn-market-web-components/{p-461c8792.entry.js.map → p-92b6477c.entry.js.map} +0 -0
  506. /package/pn-market-web-components/{p-0d4d9d90.entry.js.map → p-9eab8192.entry.js.map} +0 -0
  507. /package/pn-market-web-components/{p-40e632cc.entry.js.map → p-a3beee11.entry.js.map} +0 -0
  508. /package/pn-market-web-components/{p-01fbf1ce.entry.js.map → p-a6935dc2.entry.js.map} +0 -0
  509. /package/pn-market-web-components/{p-af646091.entry.js.map → p-a6dd3e4f.entry.js.map} +0 -0
  510. /package/pn-market-web-components/{p-6d77e747.entry.js.map → p-af89c95a.entry.js.map} +0 -0
  511. /package/pn-market-web-components/{p-c89f3d6b.entry.js.map → p-ba14b0ef.entry.js.map} +0 -0
  512. /package/pn-market-web-components/{p-c7965104.entry.js.map → p-ba680948.entry.js.map} +0 -0
  513. /package/pn-market-web-components/{p-11c6e458.entry.js.map → p-ba75bfdb.entry.js.map} +0 -0
  514. /package/pn-market-web-components/{p-4149e715.entry.js.map → p-c186ec41.entry.js.map} +0 -0
  515. /package/pn-market-web-components/{p-66c0c8dc.entry.js.map → p-c38707f9.entry.js.map} +0 -0
  516. /package/pn-market-web-components/{p-671a8129.entry.js.map → p-c89cdd5a.entry.js.map} +0 -0
  517. /package/pn-market-web-components/{p-4d848e18.entry.js.map → p-e8cd1608.entry.js.map} +0 -0
  518. /package/pn-market-web-components/{p-4517a3d4.entry.js.map → p-ef090656.entry.js.map} +0 -0
  519. /package/pn-market-web-components/{p-bd8ec517.entry.js.map → p-f3b4c13d.entry.js.map} +0 -0
  520. /package/pn-market-web-components/{p-ff38b9a5.entry.js.map → p-f710445f.entry.js.map} +0 -0
  521. /package/pn-market-web-components/{p-2e585ed5.entry.js.map → p-fcefe4a4.entry.js.map} +0 -0
  522. /package/pn-market-web-components/{p-32bd2ff8.entry.js.map → p-ff6118f8.entry.js.map} +0 -0
@@ -0,0 +1,192 @@
1
+ import { h } from '@stencil/core/internal/client';
2
+
3
+ /**
4
+ * Builds the list of language options that should actually be shown.
5
+ *
6
+ * What it does:
7
+ * - Reads the backend-provided language selector model
8
+ * - Checks page <link rel="alternate" hreflang="..."> tags
9
+ * - If hreflang tags exist, only languages with matching tags are shown
10
+ * - If no hreflang tags exist, all backend-provided languages are shown
11
+ */
12
+ function getLanguageOptions(languageSelector) {
13
+ if (!languageSelector?.languages?.length) {
14
+ return [];
15
+ }
16
+ const hrefLangTags = Array.from(document.querySelectorAll('link[rel="alternate"][hreflang]'));
17
+ const hrefLangs = hrefLangTags.map(tag => {
18
+ let value = tag.getAttribute('hreflang') ?? '';
19
+ if (value.indexOf('en-') !== -1 || value.indexOf('en_') !== -1) {
20
+ value = value.substring(0, 2);
21
+ }
22
+ return value;
23
+ });
24
+ if (!hrefLangs.length) {
25
+ return [...languageSelector.languages];
26
+ }
27
+ return languageSelector.languages.filter(option => hrefLangs.includes(option.twoLetterISOLanguageName));
28
+ }
29
+ /**
30
+ * Resolves the URL for a given language option.
31
+ *
32
+ * What it does:
33
+ * - Returns null in SPA mode so language switching can be handled by events only
34
+ * - Uses an existing hreflang alternate URL if one exists in the document
35
+ * - Otherwise falls back to generating a language URL from the site definition
36
+ */
37
+ function getLanguageVersionUrl(item, siteDefinition, spaMode) {
38
+ if (spaMode) {
39
+ return null;
40
+ }
41
+ const alternativeTag = document.querySelector(`link[rel="alternate"][hreflang="${item.twoLetterISOLanguageName}"]`);
42
+ if (alternativeTag) {
43
+ return alternativeTag.getAttribute('href');
44
+ }
45
+ const siteUrl = siteDefinition?.url ?? '/';
46
+ return siteUrl + (siteUrl.lastIndexOf('/') !== siteUrl.length - 1 ? '/' : '') + item.twoLetterISOLanguageName;
47
+ }
48
+
49
+ function getLastMenuItem(menuItems) {
50
+ return menuItems.length > 0
51
+ ? menuItems[menuItems.length - 1]
52
+ : null;
53
+ }
54
+ function getModeRoots(menuItems) {
55
+ if (menuItems.length <= 1) {
56
+ return [];
57
+ }
58
+ return menuItems.slice(0, -1);
59
+ }
60
+ /**
61
+ * Header menu mode utilities.
62
+ *
63
+ * Purpose
64
+ * -------
65
+ * Interprets the backend top-level menu structure used for header menu
66
+ * switching.
67
+ *
68
+ * Expected top-level order:
69
+ * - all items except the last = switchable root menus
70
+ * - last item = shared/common root
71
+ *
72
+ * Responsibilities
73
+ * ----------------
74
+ * - extract a structured representation of the switchable menu roots
75
+ * - resolve the active root for a selected mode
76
+ * - return grouped or flat visible items for rendering
77
+ */
78
+ function extractToggleableMenuStructure(menuItems) {
79
+ const sharedRoot = getLastMenuItem(menuItems);
80
+ const modeRoots = getModeRoots(menuItems);
81
+ const menuModeOptions = modeRoots.map((root, index) => ({
82
+ index,
83
+ label: root.name,
84
+ href: root.href || undefined,
85
+ root,
86
+ }));
87
+ return {
88
+ hasMenuSwitching: menuModeOptions.length > 0,
89
+ modeRoots,
90
+ menuModeOptions,
91
+ sharedRoot,
92
+ sharedItems: sharedRoot?.children ?? [],
93
+ };
94
+ }
95
+ /**
96
+ * Returns the active root item for the selected mode.
97
+ *
98
+ * Falls back to the first available mode root when the requested mode
99
+ * is out of bounds.
100
+ */
101
+ function getToggleRootForMode(structure, mode) {
102
+ return structure.modeRoots[mode] ?? structure.modeRoots[0] ?? null;
103
+ }
104
+ /**
105
+ * Returns the active root item for the selected mode directly from raw menu items.
106
+ */
107
+ function getToggleRootForMenuItems(menuItems, mode) {
108
+ const structure = extractToggleableMenuStructure(menuItems);
109
+ return getToggleRootForMode(structure, mode);
110
+ }
111
+ /**
112
+ * Returns grouped visible items for rendering.
113
+ *
114
+ * - primaryItems = children of the active root
115
+ * - sharedItems = children of the shared/common root
116
+ */
117
+ function getMenuGroupsForMode(structure, mode) {
118
+ const activeRoot = getToggleRootForMode(structure, mode);
119
+ if (!activeRoot) {
120
+ return {
121
+ primaryItems: structure.sharedItems,
122
+ sharedItems: [],
123
+ };
124
+ }
125
+ return {
126
+ primaryItems: activeRoot?.children ?? [],
127
+ sharedItems: structure.sharedItems,
128
+ };
129
+ }
130
+ /**
131
+ * Returns grouped visible items directly from raw menu items.
132
+ */
133
+ function getVisibleMenuGroupsForMode(menuItems, mode) {
134
+ const structure = extractToggleableMenuStructure(menuItems);
135
+ return getMenuGroupsForMode(structure, mode);
136
+ }
137
+ /**
138
+ * Builds a flat list of visible menu items for the selected mode.
139
+ *
140
+ * Useful for render paths that do not need grouped rendering.
141
+ */
142
+ function buildMenuItemsForMode(structure, mode) {
143
+ const groups = getMenuGroupsForMode(structure, mode);
144
+ return [
145
+ ...groups.primaryItems,
146
+ ...groups.sharedItems,
147
+ ];
148
+ }
149
+
150
+ function renderHeaderMenuSwitcher(props) {
151
+ const structure = extractToggleableMenuStructure(props.vm.rawMenuItems);
152
+ if (!structure.hasMenuSwitching) {
153
+ return null;
154
+ }
155
+ const options = structure.menuModeOptions.map(option => ({
156
+ ...option,
157
+ href: props.navigateOnMenuToggle ? option.href : undefined,
158
+ }));
159
+ return (h("pn-marketweb-header-toggle", { value: props.activeMenuMode, options: options, onToggleChange: props.onMenuToggleChange }));
160
+ }
161
+ function renderHeaderLogo(props) {
162
+ const homePageLink = props.homePageLink ?? '/';
163
+ return (h("div", { class: "siteheader-logocontainer" },
164
+ h("a", { href: homePageLink, title: props.homeLabel, "aria-label": props.homeLabel, class: "siteheader-logolink" },
165
+ h("slot", { name: "logo" },
166
+ h("svg", { class: "siteheader-logo", xmlns: "http://www.w3.org/2000/svg", width: "12.7rem", height: "2.4rem", viewBox: "0 0 141.73 26.65", role: "img", "aria-label": "PostNord" },
167
+ h("path", { d: "M108.84,13.35c0,6.34-5.17,9-10,9S89,19.76,89,13.63c0-6.28,5.08-9,10-9S108.84,7.25,108.84,13.35Zm-6.56.18a3.4,3.4,0,1,0-6.8,0,3.29,3.29,0,0,0,3.42,3.41A3.24,3.24,0,0,0,102.28,13.54Zm-83,0c0,4.83-3.32,8.82-8.49,8.82a6.54,6.54,0,0,1-4.65-1.57v5.86H0V5.16H6.17V6.8a6.43,6.43,0,0,1,5.11-2.18C16.41,4.62,19.31,8.58,19.31,13.54Zm-6.53,0A3.27,3.27,0,0,0,9.4,10,3.28,3.28,0,0,0,6,13.54,3.29,3.29,0,0,0,9.4,16.95,3.24,3.24,0,0,0,12.78,13.54Zm103.69,0.27c0-2.54,1.54-3.32,3.6-3.32a6.56,6.56,0,0,1,2.08.3L122.3,5.1a3.92,3.92,0,0,0-1.45-.18c-3.45,0-4.38,2.18-4.38,2.18V5.16H110.3V21.84h6.17v-8ZM141.73,0V21.84h-6.16V20.21a6.43,6.43,0,0,1-5.11,2.18c-5.14,0-8-4-8-8.91s3.32-8.82,8.49-8.82a6.54,6.54,0,0,1,4.65,1.57v-5Zm-6,13.48a3.28,3.28,0,0,0-3.41-3.41A3.24,3.24,0,0,0,129,13.47,3.4,3.4,0,1,0,135.75,13.47ZM81.35,4.62c-3.6,0-4.9,2.18-4.9,2.18V5.16H70.29V21.84h6.16V13.29c0-2.11.79-3.08,2.69-3.08s2.18,1.57,2.18,3.57v8.07h6.22V11.6C87.55,7,85.34,4.62,81.35,4.62ZM64.07,1.42H57.9V21.84h6.16V10.36H67l2.81-5.2H64.07V1.42ZM50.26,11.21c-2-.3-2.87-0.3-2.87-1.09s0.81-.94,2.42-0.94a16.15,16.15,0,0,1,5.11.91L56,5.41a24.56,24.56,0,0,0-6.13-.75c-5.89,0-9,2.27-9,5.89,0,2.81,1.66,4.47,6.53,5.11,2.06,0.27,2.81.39,2.81,1.15s-0.82,1-2.24,1a16.67,16.67,0,0,1-6-1.3L40.77,21.3a22.14,22.14,0,0,0,6.68,1c6.35,0,9.28-2.24,9.28-5.89C56.72,13.54,55.15,12,50.26,11.21ZM40.19,13.35c0,6.34-5.17,9-10,9s-9.82-2.6-9.82-8.73c0-6.28,5.08-9,10-9S40.19,7.25,40.19,13.35Zm-6.56.18a3.4,3.4,0,1,0-6.8,0,3.28,3.28,0,0,0,3.41,3.41A3.24,3.24,0,0,0,33.63,13.54Z", fill: "currentColor", transform: "translate(0 0)" }))))));
168
+ }
169
+ function renderHeaderLogin(props) {
170
+ if (!props.vm.loginDialog || props.hideLogin) {
171
+ return null;
172
+ }
173
+ return (h("pn-marketweb-siteheader-login", { token: props.userToken, siteUrl: props.vm.siteDefinition?.url, fullname: props.userFullname, loggedin: props.userLoggedin, loginDialog: props.vm.loginDialog, endpoint: props.endpoint ?? '', i18n: props.i18n, showProfileSelection: props.showProfileSelection, showUnifiedLogin: props.showUnifiedLogin, "check-user-logged-in-state-interval": props.checkUserLoggedInStateInterval, useMarketwebLogin: props.useMarketwebLogin, environment: props.environment, appearance: props.appearance }));
174
+ }
175
+ function renderHeaderLanguageSelector(props) {
176
+ if (!props.vm.languageOptions.length || props.hideLanguageSelector) {
177
+ return null;
178
+ }
179
+ return (h("pn-language-selector", { value: props.language, appearance: props.appearance }, props.vm.languageOptions.map(language => (h("pn-language-selector-option", { name: language.nativeName, code: language.twoLetterISOLanguageName, selected: language.isCurrent, url: getLanguageVersionUrl(language, props.vm.siteDefinition, props.spaMode) })))));
180
+ }
181
+ function renderHeaderSiteSelector(props) {
182
+ if (!props.vm.siteSelector || props.hideSiteSelector) {
183
+ return null;
184
+ }
185
+ return (h("pn-site-selector", { language: props.language, buttontext: props.buttonText, appearance: props.appearance },
186
+ props.vm.siteSelector.currentSiteTitle && (h("pn-site-selector-item", { heading: props.vm.siteSelector.currentSiteTitle, description: props.vm.siteSelector.currentSiteDescription })),
187
+ (props.vm.siteSelector.siteSelections ?? []).map(site => (h("pn-site-selector-item", { heading: site.linkText, description: site.linkDescription, url: props.adjustSiteSelectorUrl(site.href ?? site.pageLink ?? ''), newwindow: site.openInNewWindow })))));
188
+ }
189
+
190
+ export { getToggleRootForMenuItems as a, buildMenuItemsForMode as b, getVisibleMenuGroupsForMode as c, renderHeaderLanguageSelector as d, extractToggleableMenuStructure as e, renderHeaderSiteSelector as f, getLanguageOptions as g, renderHeaderLogo as h, renderHeaderMenuSwitcher as i, renderHeaderLogin as r };
191
+
192
+ //# sourceMappingURL=pn-marketweb-header-shared.js.map
@@ -0,0 +1 @@
1
+ {"file":"pn-marketweb-header-shared.js","mappings":"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","names":[],"sources":["src/components/layout-components/pn-marketweb-header/utils/header-language.ts","src/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.ts","src/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.tsx"],"sourcesContent":["import {\n LanguageSelector,\n LanguageSelectorItem,\n MenuSiteDefinition,\n} from '../../pn-marketweb-siteheader/pn-marketweb-siteheader-types';\n\n/**\n * Builds the list of language options that should actually be shown.\n *\n * What it does:\n * - Reads the backend-provided language selector model\n * - Checks page <link rel=\"alternate\" hreflang=\"...\"> tags\n * - If hreflang tags exist, only languages with matching tags are shown\n * - If no hreflang tags exist, all backend-provided languages are shown\n */\nexport function getLanguageOptions(languageSelector: LanguageSelector | null): LanguageSelectorItem[] {\n if (!languageSelector?.languages?.length) {\n return [];\n }\n\n const hrefLangTags = Array.from(document.querySelectorAll('link[rel=\"alternate\"][hreflang]'));\n const hrefLangs = hrefLangTags.map(tag => {\n let value = tag.getAttribute('hreflang') ?? '';\n if (value.indexOf('en-') !== -1 || value.indexOf('en_') !== -1) {\n value = value.substring(0, 2);\n }\n return value;\n });\n\n if (!hrefLangs.length) {\n return [...languageSelector.languages];\n }\n\n return languageSelector.languages.filter(option =>\n hrefLangs.includes(option.twoLetterISOLanguageName),\n );\n}\n\n/**\n * Resolves the URL for a given language option.\n *\n * What it does:\n * - Returns null in SPA mode so language switching can be handled by events only\n * - Uses an existing hreflang alternate URL if one exists in the document\n * - Otherwise falls back to generating a language URL from the site definition\n */\nexport function getLanguageVersionUrl(\n item: LanguageSelectorItem,\n siteDefinition: MenuSiteDefinition | null,\n spaMode: boolean,\n): string | null {\n if (spaMode) {\n return null;\n }\n\n const alternativeTag = document.querySelector(\n `link[rel=\"alternate\"][hreflang=\"${item.twoLetterISOLanguageName}\"]`,\n );\n\n if (alternativeTag) {\n return alternativeTag.getAttribute('href');\n }\n\n const siteUrl = siteDefinition?.url ?? '/';\n return siteUrl + (siteUrl.lastIndexOf('/') !== siteUrl.length - 1 ? '/' : '') + item.twoLetterISOLanguageName;\n}","import type {\n MenuItem,\n} from '../../pn-marketweb-siteheader/pn-marketweb-siteheader-types';\nimport type {\n HeaderMenuGroups,\n HeaderMenuMode,\n HeaderMenuModeOption,\n HeaderMenuStructure,\n} from '../types/pn-marketweb-header.types';\n\nfunction getLastMenuItem(menuItems: MenuItem[]): MenuItem | null {\n return menuItems.length > 0\n ? menuItems[menuItems.length - 1]\n : null;\n}\n\nfunction getModeRoots(menuItems: MenuItem[]): MenuItem[] {\n if (menuItems.length <= 1) {\n return [];\n }\n\n return menuItems.slice(0, -1);\n}\n\n/**\n * Header menu mode utilities.\n *\n * Purpose\n * -------\n * Interprets the backend top-level menu structure used for header menu\n * switching.\n *\n * Expected top-level order:\n * - all items except the last = switchable root menus\n * - last item = shared/common root\n *\n * Responsibilities\n * ----------------\n * - extract a structured representation of the switchable menu roots\n * - resolve the active root for a selected mode\n * - return grouped or flat visible items for rendering\n */\nexport function extractToggleableMenuStructure(\n menuItems: MenuItem[],\n): HeaderMenuStructure {\n const sharedRoot = getLastMenuItem(menuItems);\n const modeRoots = getModeRoots(menuItems);\n\n const menuModeOptions: HeaderMenuModeOption[] = modeRoots.map((root, index) => ({\n index,\n label: root.name,\n href: root.href || undefined,\n root,\n }));\n\n return {\n hasMenuSwitching: menuModeOptions.length > 0,\n modeRoots,\n menuModeOptions,\n sharedRoot,\n sharedItems: sharedRoot?.children ?? [],\n };\n}\n\n/**\n * Returns the active root item for the selected mode.\n *\n * Falls back to the first available mode root when the requested mode\n * is out of bounds.\n */\nexport function getToggleRootForMode(\n structure: HeaderMenuStructure,\n mode: HeaderMenuMode,\n): MenuItem | null {\n return structure.modeRoots[mode] ?? structure.modeRoots[0] ?? null;\n}\n\n/**\n * Returns the active root item for the selected mode directly from raw menu items.\n */\nexport function getToggleRootForMenuItems(\n menuItems: MenuItem[],\n mode: HeaderMenuMode,\n): MenuItem | null {\n const structure = extractToggleableMenuStructure(menuItems);\n return getToggleRootForMode(structure, mode);\n}\n\n/**\n * Returns grouped visible items for rendering.\n *\n * - primaryItems = children of the active root\n * - sharedItems = children of the shared/common root\n */\nexport function getMenuGroupsForMode(\n structure: HeaderMenuStructure,\n mode: HeaderMenuMode,\n): HeaderMenuGroups {\n const activeRoot = getToggleRootForMode(structure, mode);\n\n if (!activeRoot) {\n return {\n primaryItems: structure.sharedItems,\n sharedItems: [],\n };\n }\n\n return {\n primaryItems: activeRoot?.children ?? [],\n sharedItems: structure.sharedItems,\n };\n}\n\n/**\n * Returns grouped visible items directly from raw menu items.\n */\nexport function getVisibleMenuGroupsForMode(\n menuItems: MenuItem[],\n mode: HeaderMenuMode,\n): HeaderMenuGroups {\n const structure = extractToggleableMenuStructure(menuItems);\n return getMenuGroupsForMode(structure, mode);\n}\n\n/**\n * Builds a flat list of visible menu items for the selected mode.\n *\n * Useful for render paths that do not need grouped rendering.\n */\nexport function buildMenuItemsForMode(\n structure: HeaderMenuStructure,\n mode: HeaderMenuMode,\n): MenuItem[] {\n const groups = getMenuGroupsForMode(structure, mode);\n\n return [\n ...groups.primaryItems,\n ...groups.sharedItems,\n ];\n}","import { h } from '@stencil/core';\n\nimport type {\n SiteHeaderI18N,\n} from '../../../pn-marketweb-siteheader/pn-marketweb-siteheader-types';\nimport type {\n HeaderMenuMode,\n HeaderViewModel,\n} from '../../types/pn-marketweb-header.types';\nimport { getLanguageVersionUrl } from '../../utils/header-language';\nimport { HeaderAppearance } from '../../utils/header-theme';\nimport { extractToggleableMenuStructure } from '../../utils/header-toggle-menu';\n\nexport interface HeaderLogoRenderProps {\n homePageLink?: string;\n homeLabel: string;\n}\n\nexport interface HeaderMenuToggleRenderProps {\n vm: HeaderViewModel;\n activeMenuMode: HeaderMenuMode;\n navigateOnMenuToggle: boolean;\n onMenuToggleChange: (e: CustomEvent<HeaderMenuMode>) => void;\n}\n\nexport interface HeaderLoginRenderProps {\n vm: HeaderViewModel;\n hideLogin: boolean;\n userToken: string;\n userFullname: string;\n userLoggedin: boolean;\n endpoint?: string;\n environment?: string;\n i18n: SiteHeaderI18N;\n showProfileSelection: boolean;\n showUnifiedLogin: boolean;\n checkUserLoggedInStateInterval: number;\n useMarketwebLogin: boolean;\n appearance: HeaderAppearance;\n}\n\nexport interface HeaderLanguageSelectorRenderProps {\n vm: HeaderViewModel;\n hideLanguageSelector: boolean;\n language?: string;\n spaMode: boolean;\n appearance: HeaderAppearance;\n}\n\nexport interface HeaderSiteSelectorRenderProps {\n vm: HeaderViewModel;\n hideSiteSelector: boolean;\n language?: string;\n buttonText?: string;\n appearance: HeaderAppearance;\n adjustSiteSelectorUrl: (href: string) => string;\n}\n\nexport function renderHeaderMenuSwitcher(props: HeaderMenuToggleRenderProps) {\n const structure = extractToggleableMenuStructure(props.vm.rawMenuItems);\n\n if (!structure.hasMenuSwitching) {\n return null;\n }\n\n const options = structure.menuModeOptions.map(option => ({\n ...option,\n href: props.navigateOnMenuToggle ? option.href : undefined,\n }));\n\n return (\n <pn-marketweb-header-toggle\n value={props.activeMenuMode}\n options={options}\n onToggleChange={props.onMenuToggleChange}\n />\n );\n}\n\nexport function renderHeaderLogo(props: HeaderLogoRenderProps) {\n const homePageLink = props.homePageLink ?? '/';\n\n return (\n <div class=\"siteheader-logocontainer\">\n <a\n href={homePageLink}\n title={props.homeLabel}\n aria-label={props.homeLabel}\n class=\"siteheader-logolink\"\n >\n <slot name=\"logo\">\n <svg\n class=\"siteheader-logo\"\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12.7rem\"\n height=\"2.4rem\"\n viewBox=\"0 0 141.73 26.65\"\n role=\"img\"\n aria-label=\"PostNord\"\n >\n <path\n d=\"M108.84,13.35c0,6.34-5.17,9-10,9S89,19.76,89,13.63c0-6.28,5.08-9,10-9S108.84,7.25,108.84,13.35Zm-6.56.18a3.4,3.4,0,1,0-6.8,0,3.29,3.29,0,0,0,3.42,3.41A3.24,3.24,0,0,0,102.28,13.54Zm-83,0c0,4.83-3.32,8.82-8.49,8.82a6.54,6.54,0,0,1-4.65-1.57v5.86H0V5.16H6.17V6.8a6.43,6.43,0,0,1,5.11-2.18C16.41,4.62,19.31,8.58,19.31,13.54Zm-6.53,0A3.27,3.27,0,0,0,9.4,10,3.28,3.28,0,0,0,6,13.54,3.29,3.29,0,0,0,9.4,16.95,3.24,3.24,0,0,0,12.78,13.54Zm103.69,0.27c0-2.54,1.54-3.32,3.6-3.32a6.56,6.56,0,0,1,2.08.3L122.3,5.1a3.92,3.92,0,0,0-1.45-.18c-3.45,0-4.38,2.18-4.38,2.18V5.16H110.3V21.84h6.17v-8ZM141.73,0V21.84h-6.16V20.21a6.43,6.43,0,0,1-5.11,2.18c-5.14,0-8-4-8-8.91s3.32-8.82,8.49-8.82a6.54,6.54,0,0,1,4.65,1.57v-5Zm-6,13.48a3.28,3.28,0,0,0-3.41-3.41A3.24,3.24,0,0,0,129,13.47,3.4,3.4,0,1,0,135.75,13.47ZM81.35,4.62c-3.6,0-4.9,2.18-4.9,2.18V5.16H70.29V21.84h6.16V13.29c0-2.11.79-3.08,2.69-3.08s2.18,1.57,2.18,3.57v8.07h6.22V11.6C87.55,7,85.34,4.62,81.35,4.62ZM64.07,1.42H57.9V21.84h6.16V10.36H67l2.81-5.2H64.07V1.42ZM50.26,11.21c-2-.3-2.87-0.3-2.87-1.09s0.81-.94,2.42-0.94a16.15,16.15,0,0,1,5.11.91L56,5.41a24.56,24.56,0,0,0-6.13-.75c-5.89,0-9,2.27-9,5.89,0,2.81,1.66,4.47,6.53,5.11,2.06,0.27,2.81.39,2.81,1.15s-0.82,1-2.24,1a16.67,16.67,0,0,1-6-1.3L40.77,21.3a22.14,22.14,0,0,0,6.68,1c6.35,0,9.28-2.24,9.28-5.89C56.72,13.54,55.15,12,50.26,11.21ZM40.19,13.35c0,6.34-5.17,9-10,9s-9.82-2.6-9.82-8.73c0-6.28,5.08-9,10-9S40.19,7.25,40.19,13.35Zm-6.56.18a3.4,3.4,0,1,0-6.8,0,3.28,3.28,0,0,0,3.41,3.41A3.24,3.24,0,0,0,33.63,13.54Z\"\n fill=\"currentColor\"\n transform=\"translate(0 0)\"\n ></path>\n </svg>\n </slot>\n </a>\n </div>\n );\n}\n\nexport function renderHeaderLogin(props: HeaderLoginRenderProps) {\n if (!props.vm.loginDialog || props.hideLogin) {\n return null;\n }\n\n\n\n return (\n <pn-marketweb-siteheader-login\n token={props.userToken}\n siteUrl={props.vm.siteDefinition?.url}\n fullname={props.userFullname}\n loggedin={props.userLoggedin}\n loginDialog={props.vm.loginDialog}\n endpoint={props.endpoint ?? ''}\n i18n={props.i18n}\n showProfileSelection={props.showProfileSelection}\n showUnifiedLogin={props.showUnifiedLogin}\n check-user-logged-in-state-interval={props.checkUserLoggedInStateInterval}\n useMarketwebLogin={props.useMarketwebLogin}\n environment={props.environment}\n appearance={props.appearance}\n ></pn-marketweb-siteheader-login>\n );\n}\n\nexport function renderHeaderLanguageSelector(props: HeaderLanguageSelectorRenderProps) {\n if (!props.vm.languageOptions.length || props.hideLanguageSelector) {\n return null;\n }\n\n return (\n <pn-language-selector value={props.language} appearance={props.appearance}>\n {props.vm.languageOptions.map(language => (\n <pn-language-selector-option\n name={language.nativeName}\n code={language.twoLetterISOLanguageName}\n selected={language.isCurrent}\n url={getLanguageVersionUrl(language, props.vm.siteDefinition, props.spaMode)}\n ></pn-language-selector-option>\n ))}\n </pn-language-selector>\n );\n}\n\nexport function renderHeaderSiteSelector(props: HeaderSiteSelectorRenderProps) {\n if (!props.vm.siteSelector || props.hideSiteSelector) {\n return null;\n }\n\n return (\n <pn-site-selector\n language={props.language}\n buttontext={props.buttonText}\n appearance={props.appearance}\n >\n {props.vm.siteSelector.currentSiteTitle && (\n <pn-site-selector-item\n heading={props.vm.siteSelector.currentSiteTitle}\n description={props.vm.siteSelector.currentSiteDescription}\n ></pn-site-selector-item>\n )}\n\n {(props.vm.siteSelector.siteSelections ?? []).map(site => (\n <pn-site-selector-item\n heading={site.linkText}\n description={site.linkDescription}\n url={props.adjustSiteSelectorUrl(site.href ?? site.pageLink ?? '')}\n newwindow={site.openInNewWindow}\n ></pn-site-selector-item>\n ))}\n </pn-site-selector>\n );\n}"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface PnMarketwebHeaderSkeletonLoader extends Components.PnMarketwebHeaderSkeletonLoader, HTMLElement {}
4
+ export const PnMarketwebHeaderSkeletonLoader: {
5
+ prototype: PnMarketwebHeaderSkeletonLoader;
6
+ new (): PnMarketwebHeaderSkeletonLoader;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,37 @@
1
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
2
+
3
+ const pnMarketwebHeaderSkeletonLoaderCss = ":host{display:block;width:100%;--header-skeleton-bg:var(--siteheader-skeleton-bg, #e8edf2);--header-skeleton-shine:var(--siteheader-skeleton-shine,\n rgba(255, 255, 255, 0.65));--header-skeleton-radius:var(--siteheader-skeleton-radius, 0.4rem);--header-skeleton-gap:var(--siteheader-skeleton-gap, 1.2rem);--header-skeleton-padding-x:var(--siteheader-skeleton-padding-x, 1.6rem);--header-skeleton-padding-y:var(--siteheader-skeleton-padding-y, 1.2rem);--header-skeleton-border-color:var(--siteheader-skeleton-border-color,\n #d9e1e8);--header-skeleton-mobile-height:var(--siteheader-skeleton-mobile-height,\n 6.4rem);--header-skeleton-top-row-height:var(--siteheader-skeleton-top-row-height,\n 7.2rem);--header-skeleton-bottom-row-height:var(--siteheader-skeleton-bottom-row-height,\n 6.4rem)}.header-skeleton{width:100%;box-sizing:border-box;border-bottom:0.1rem solid var(--header-skeleton-border-color);background:var(--siteheader-skeleton-background, #fff)}.mobile-layout,.tablet-desktop-layout{width:100%;box-sizing:border-box}.mobile-row,.top-row,.bottom-row{display:flex;align-items:center;width:100%;box-sizing:border-box;padding-left:var(--header-skeleton-padding-x);padding-right:var(--header-skeleton-padding-x)}.skel{position:relative;overflow:hidden;flex:0 0 auto;background:var(--header-skeleton-bg)}.skel::after{content:\"\";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg, transparent, var(--header-skeleton-shine), transparent);animation:header-skeleton-shimmer 1.4s infinite}.skel-logo{width:11.2rem;height:2.8rem;border-radius:var(--header-skeleton-radius)}.skel-icon-button{width:4rem;height:4rem;border-radius:50%}.skel-chip{width:10rem;height:3.6rem;border-radius:1.8rem}.skel-pill{width:7.2rem;height:3.6rem;border-radius:1.8rem}.skel-menu-button{width:12rem;height:4rem;border-radius:0.4rem}.skel-search{width:min(100%, 36rem);height:4rem;border-radius:2rem}.mobile-layout{display:block}.mobile-row{justify-content:space-between;min-height:var(--header-skeleton-mobile-height);padding-top:var(--header-skeleton-padding-y);padding-bottom:var(--header-skeleton-padding-y)}.tablet-desktop-layout{display:none}.top-row{min-height:var(--header-skeleton-top-row-height);padding-top:var(--header-skeleton-padding-y);padding-bottom:var(--header-skeleton-padding-y);display:grid;grid-template-columns:1fr auto 1fr;column-gap:var(--header-skeleton-gap);align-items:center}.top-row-left,.top-row-center,.top-row-right,.bottom-row-left,.bottom-row-right{display:flex;align-items:center}.top-row-left{justify-content:flex-start;gap:var(--header-skeleton-gap);min-width:0}.top-row-center{justify-content:center}.top-row-right{justify-content:flex-end;gap:var(--header-skeleton-gap);min-width:0}.bottom-row{min-height:var(--header-skeleton-bottom-row-height);justify-content:space-between;gap:var(--header-skeleton-gap);padding-top:0.8rem;padding-bottom:1.2rem}.bottom-row-left{justify-content:flex-start;flex:0 0 auto}.bottom-row-right{justify-content:flex-end;flex:1 1 auto;min-width:0}.bottom-row-right .skel-search{margin-left:auto}@media screen and (min-width: 768px){.mobile-layout{display:none}.tablet-desktop-layout{display:block}}@media screen and (min-width: 1200px){:host{--header-skeleton-padding-x:var(--siteheader-skeleton-padding-x-desktop, 2.4rem);--header-skeleton-top-row-height:var(--siteheader-skeleton-top-row-height-desktop,\n 8rem);--header-skeleton-bottom-row-height:var(--siteheader-skeleton-bottom-row-height-desktop,\n 6.8rem)}.skel-logo{width:13rem;height:3rem}.skel-search{width:min(100%, 42rem)}}@keyframes header-skeleton-shimmer{100%{transform:translateX(100%)}}@media (prefers-reduced-motion: reduce){.skel::after{animation:none}}";
4
+ const PnMarketwebHeaderSkeletonLoaderStyle0 = pnMarketwebHeaderSkeletonLoaderCss;
5
+
6
+ const PnMarketwebHeaderSkeletonLoader$1 = /*@__PURE__*/ proxyCustomElement(class PnMarketwebHeaderSkeletonLoader extends HTMLElement {
7
+ constructor() {
8
+ super();
9
+ this.__registerHost();
10
+ this.__attachShadow();
11
+ }
12
+ render() {
13
+ console.log('Rendering PnMarketwebHeaderSkeletonLoader...');
14
+ return (h(Host, { key: 'df31cc237329e033c4ace683027a6458a3790ef1' }, h("header", { key: '51d25dc2af64660068fcabfa5f95cc0872d29cce', class: "header-skeleton", "aria-hidden": "true" }, h("div", { key: '1469d90c9ca66cc371257818dbf1aacbdc2c0b8c', class: "mobile-layout" }, h("div", { key: '591d0124da5d93e45809cf35f514b590c60d666f', class: "mobile-row" }, h("div", { key: '1e8ec053ab87561b5f3a6a5c6e45c4fbcbe66212', class: "skel skel-logo" }), h("div", { key: '83c7c0f633155348cb92e3370f16daf3c5d0e6c2', class: "skel skel-icon-button" }))), h("div", { key: '847b9bbe3de7c3a0aa5954e82167e99a5813fcd2', class: "tablet-desktop-layout" }, h("div", { key: '5b4f7867da490285dd1032fdf9b7387b705a51f2', class: "top-row" }, h("div", { key: '208485c9f664ef1008bf57eb5a98e6687ba70949', class: "top-row-left" }, h("div", { key: 'b2fdca97d9b576d20d16ca833e84a80191653e3f', class: "skel skel-chip" }), h("div", { key: 'ca6b630a8c38cd87c4e65ffd483e0e65e4774326', class: "skel skel-icon-button" })), h("div", { key: '0923c1a855f32159dd42dc49eb9e84b47a70a549', class: "top-row-center" }, h("div", { key: 'dda22514ffd4a1ceae80252dafe49597a63ec364', class: "skel skel-logo" })), h("div", { key: 'a6ec95a525889c8cc13b35ccc03a90c509a2c35c', class: "top-row-right" }, h("div", { key: '41d4a9998a8478423a2b1ce566568fe845c8767a', class: "skel skel-icon-button" }), h("div", { key: '0fb5f413dad85ffab8e8038c7720f3828fb24b72', class: "skel skel-icon-button" }), h("div", { key: 'b53f8b517499a89c30ee3c46179ffed6cc7e12b4', class: "skel skel-pill" }))), h("div", { key: 'e7c90c573556c1599f25bf99761d437e7ed3e7c8', class: "bottom-row" }, h("div", { key: '0c9d2b72369a256efa2daf8eafd8f938369601a0', class: "bottom-row-left" }, h("div", { key: '9835aa30019d52084f98c362e0e8a255fc747d46', class: "skel skel-menu-button" })), h("div", { key: '4cc96d47f41114dbe08ce67b62106664b2f8deee', class: "bottom-row-right" }, h("div", { key: '5bcab9e4e0f36f838b7467e3dcf130d4b95faa85', class: "skel skel-search" })))))));
15
+ }
16
+ static get style() { return PnMarketwebHeaderSkeletonLoaderStyle0; }
17
+ }, [1, "pn-marketweb-header-skeleton-loader"]);
18
+ function defineCustomElement$1() {
19
+ if (typeof customElements === "undefined") {
20
+ return;
21
+ }
22
+ const components = ["pn-marketweb-header-skeleton-loader"];
23
+ components.forEach(tagName => { switch (tagName) {
24
+ case "pn-marketweb-header-skeleton-loader":
25
+ if (!customElements.get(tagName)) {
26
+ customElements.define(tagName, PnMarketwebHeaderSkeletonLoader$1);
27
+ }
28
+ break;
29
+ } });
30
+ }
31
+
32
+ const PnMarketwebHeaderSkeletonLoader = PnMarketwebHeaderSkeletonLoader$1;
33
+ const defineCustomElement = defineCustomElement$1;
34
+
35
+ export { PnMarketwebHeaderSkeletonLoader, defineCustomElement };
36
+
37
+ //# sourceMappingURL=pn-marketweb-header-skeleton-loader.js.map
@@ -0,0 +1 @@
1
+ {"file":"pn-marketweb-header-skeleton-loader.js","mappings":";;AAAA,MAAM,kCAAkC,GAAG,msHAAmsH,CAAC;AAC/uH,8CAAe,kCAAkC;;MCUpCA,iCAA+B;;;;;;IACxC,MAAM;QAEF,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,QACI,EAAC,IAAI,uDACD,+DAAQ,KAAK,EAAC,iBAAiB,iBAAa,MAAM,IAE9C,4DAAK,KAAK,EAAC,eAAe,IACtB,4DAAK,KAAK,EAAC,YAAY,IACnB,4DAAK,KAAK,EAAC,gBAAgB,GAAG,EAC9B,4DAAK,KAAK,EAAC,uBAAuB,GAAG,CACnC,CACJ,EAGN,4DAAK,KAAK,EAAC,uBAAuB,IAC9B,4DAAK,KAAK,EAAC,SAAS,IAChB,4DAAK,KAAK,EAAC,cAAc,IACrB,4DAAK,KAAK,EAAC,gBAAgB,GAAG,EAC9B,4DAAK,KAAK,EAAC,uBAAuB,GAAG,CACnC,EAEN,4DAAK,KAAK,EAAC,gBAAgB,IACvB,4DAAK,KAAK,EAAC,gBAAgB,GAAG,CAC5B,EAEN,4DAAK,KAAK,EAAC,eAAe,IACtB,4DAAK,KAAK,EAAC,uBAAuB,GAAG,EACrC,4DAAK,KAAK,EAAC,uBAAuB,GAAG,EACrC,4DAAK,KAAK,EAAC,gBAAgB,GAAG,CAC5B,CACJ,EAEN,4DAAK,KAAK,EAAC,YAAY,IACnB,4DAAK,KAAK,EAAC,iBAAiB,IACxB,4DAAK,KAAK,EAAC,uBAAuB,GAAG,CACnC,EAEN,4DAAK,KAAK,EAAC,kBAAkB,IACzB,4DAAK,KAAK,EAAC,kBAAkB,GAAG,CAC9B,CACJ,CACJ,CACD,CACN,EACT;KACL;;;;;;;;;;;;;;;;;;;;;;","names":["PnMarketwebHeaderSkeletonLoader"],"sources":["src/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.scss?tag=pn-marketweb-header-skeleton-loader&encapsulation=shadow","src/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n --header-skeleton-bg: var(--siteheader-skeleton-bg, #e8edf2);\n --header-skeleton-shine: var(--siteheader-skeleton-shine,\n rgba(255, 255, 255, 0.65));\n --header-skeleton-radius: var(--siteheader-skeleton-radius, 0.4rem);\n --header-skeleton-gap: var(--siteheader-skeleton-gap, 1.2rem);\n --header-skeleton-padding-x: var(--siteheader-skeleton-padding-x, 1.6rem);\n --header-skeleton-padding-y: var(--siteheader-skeleton-padding-y, 1.2rem);\n --header-skeleton-border-color: var(--siteheader-skeleton-border-color,\n #d9e1e8);\n --header-skeleton-mobile-height: var(--siteheader-skeleton-mobile-height,\n 6.4rem);\n --header-skeleton-top-row-height: var(--siteheader-skeleton-top-row-height,\n 7.2rem);\n --header-skeleton-bottom-row-height: var(--siteheader-skeleton-bottom-row-height,\n 6.4rem);\n}\n\n.header-skeleton {\n width: 100%;\n box-sizing: border-box;\n border-bottom: 0.1rem solid var(--header-skeleton-border-color);\n background: var(--siteheader-skeleton-background, #fff);\n}\n\n.mobile-layout,\n.tablet-desktop-layout {\n width: 100%;\n box-sizing: border-box;\n}\n\n.mobile-row,\n.top-row,\n.bottom-row {\n display: flex;\n align-items: center;\n width: 100%;\n box-sizing: border-box;\n padding-left: var(--header-skeleton-padding-x);\n padding-right: var(--header-skeleton-padding-x);\n}\n\n/* -------------------------------------------------------------------------- */\n/* Skeleton blocks */\n/* -------------------------------------------------------------------------- */\n\n.skel {\n position: relative;\n overflow: hidden;\n flex: 0 0 auto;\n background: var(--header-skeleton-bg);\n}\n\n.skel::after {\n content: '';\n position: absolute;\n inset: 0;\n transform: translateX(-100%);\n background: linear-gradient(90deg,\n transparent,\n var(--header-skeleton-shine),\n transparent);\n animation: header-skeleton-shimmer 1.4s infinite;\n}\n\n.skel-logo {\n width: 11.2rem;\n height: 2.8rem;\n border-radius: var(--header-skeleton-radius);\n}\n\n.skel-icon-button {\n width: 4rem;\n height: 4rem;\n border-radius: 50%;\n}\n\n.skel-chip {\n width: 10rem;\n height: 3.6rem;\n border-radius: 1.8rem;\n}\n\n.skel-pill {\n width: 7.2rem;\n height: 3.6rem;\n border-radius: 1.8rem;\n}\n\n.skel-menu-button {\n width: 12rem;\n height: 4rem;\n border-radius: 0.4rem;\n}\n\n.skel-search {\n width: min(100%, 36rem);\n height: 4rem;\n border-radius: 2rem;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Mobile */\n/* -------------------------------------------------------------------------- */\n\n.mobile-layout {\n display: block;\n}\n\n.mobile-row {\n justify-content: space-between;\n min-height: var(--header-skeleton-mobile-height);\n padding-top: var(--header-skeleton-padding-y);\n padding-bottom: var(--header-skeleton-padding-y);\n}\n\n/* -------------------------------------------------------------------------- */\n/* Tablet / Desktop */\n/* -------------------------------------------------------------------------- */\n\n.tablet-desktop-layout {\n display: none;\n}\n\n.top-row {\n min-height: var(--header-skeleton-top-row-height);\n padding-top: var(--header-skeleton-padding-y);\n padding-bottom: var(--header-skeleton-padding-y);\n display: grid;\n grid-template-columns: 1fr auto 1fr;\n column-gap: var(--header-skeleton-gap);\n align-items: center;\n}\n\n.top-row-left,\n.top-row-center,\n.top-row-right,\n.bottom-row-left,\n.bottom-row-right {\n display: flex;\n align-items: center;\n}\n\n.top-row-left {\n justify-content: flex-start;\n gap: var(--header-skeleton-gap);\n min-width: 0;\n}\n\n.top-row-center {\n justify-content: center;\n}\n\n.top-row-right {\n justify-content: flex-end;\n gap: var(--header-skeleton-gap);\n min-width: 0;\n}\n\n.bottom-row {\n min-height: var(--header-skeleton-bottom-row-height);\n justify-content: space-between;\n gap: var(--header-skeleton-gap);\n padding-top: 0.8rem;\n padding-bottom: 1.2rem;\n}\n\n.bottom-row-left {\n justify-content: flex-start;\n flex: 0 0 auto;\n}\n\n.bottom-row-right {\n justify-content: flex-end;\n flex: 1 1 auto;\n min-width: 0;\n}\n\n.bottom-row-right .skel-search {\n margin-left: auto;\n}\n\n/* -------------------------------------------------------------------------- */\n/* Breakpoints */\n/* -------------------------------------------------------------------------- */\n\n/* Tablet and up */\n@media screen and (min-width: 768px) {\n .mobile-layout {\n display: none;\n }\n\n .tablet-desktop-layout {\n display: block;\n }\n}\n\n/* Desktop */\n@media screen and (min-width: 1200px) {\n :host {\n --header-skeleton-padding-x: var(--siteheader-skeleton-padding-x-desktop, 2.4rem);\n --header-skeleton-top-row-height: var(--siteheader-skeleton-top-row-height-desktop,\n 8rem);\n --header-skeleton-bottom-row-height: var(--siteheader-skeleton-bottom-row-height-desktop,\n 6.8rem);\n }\n\n .skel-logo {\n width: 13rem;\n height: 3rem;\n }\n\n .skel-search {\n width: min(100%, 42rem);\n }\n}\n\n@keyframes header-skeleton-shimmer {\n 100% {\n transform: translateX(100%);\n }\n}\n\n@media (prefers-reduced-motion: reduce) {\n .skel::after {\n animation: none;\n }\n}","import {\n Component,\n h,\n Host,\n} from '@stencil/core';\n\n@Component({\n tag: 'pn-marketweb-header-skeleton-loader',\n styleUrl: 'pn-marketweb-header-skeleton-loader.scss',\n shadow: true,\n})\nexport class PnMarketwebHeaderSkeletonLoader {\n render() {\n\n console.log('Rendering PnMarketwebHeaderSkeletonLoader...');\n return (\n <Host>\n <header class=\"header-skeleton\" aria-hidden=\"true\">\n {/* Mobile */}\n <div class=\"mobile-layout\">\n <div class=\"mobile-row\">\n <div class=\"skel skel-logo\" />\n <div class=\"skel skel-icon-button\" />\n </div>\n </div>\n\n {/* Tablet / Desktop */}\n <div class=\"tablet-desktop-layout\">\n <div class=\"top-row\">\n <div class=\"top-row-left\">\n <div class=\"skel skel-chip\" />\n <div class=\"skel skel-icon-button\" />\n </div>\n\n <div class=\"top-row-center\">\n <div class=\"skel skel-logo\" />\n </div>\n\n <div class=\"top-row-right\">\n <div class=\"skel skel-icon-button\" />\n <div class=\"skel skel-icon-button\" />\n <div class=\"skel skel-pill\" />\n </div>\n </div>\n\n <div class=\"bottom-row\">\n <div class=\"bottom-row-left\">\n <div class=\"skel skel-menu-button\" />\n </div>\n\n <div class=\"bottom-row-right\">\n <div class=\"skel skel-search\" />\n </div>\n </div>\n </div>\n </header>\n </Host>\n );\n }\n}"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface PnMarketwebHeaderToggle extends Components.PnMarketwebHeaderToggle, HTMLElement {}
4
+ export const PnMarketwebHeaderToggle: {
5
+ prototype: PnMarketwebHeaderToggle;
6
+ new (): PnMarketwebHeaderToggle;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,8 @@
1
+ import { P as PnMarketwebHeaderToggle$1, d as defineCustomElement$1 } from './pn-marketweb-header-toggle2.js';
2
+
3
+ const PnMarketwebHeaderToggle = PnMarketwebHeaderToggle$1;
4
+ const defineCustomElement = defineCustomElement$1;
5
+
6
+ export { PnMarketwebHeaderToggle, defineCustomElement };
7
+
8
+ //# sourceMappingURL=pn-marketweb-header-toggle.js.map
@@ -0,0 +1 @@
1
+ {"file":"pn-marketweb-header-toggle.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
@@ -0,0 +1,61 @@
1
+ import { proxyCustomElement, HTMLElement, createEvent, h, Host } from '@stencil/core/internal/client';
2
+
3
+ const pnMarketwebHeaderToggleCss = "pn-button-dropdown .pn-button-dropdown>pn-button>.pn-button{min-height:initial}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}@media screen and (max-width: 767px){.sr-only-mobile{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}}:host{--toggle-color:var(--siteheader-toggle-color, #005d92);--toggle-hover-color:var(--siteheader-toggle-hover-color, #000000);--toggle-active-color:var(--siteheader-toggle-active-color, #000000);--toggle-active-underline-color:var(--siteheader-toggle-active-underline-color, #00a0d6);--toggle-after-visibility:hidden;display:inline-block}.marketweb-header-toggle{display:flex;align-items:center;gap:1.2rem}.marketweb-header-toggle-button{display:inline-block;position:relative;cursor:pointer;text-decoration:none;line-height:1;transition:color 0.2s ease;font-size:1.6rem;color:var(--toggle-color)}.marketweb-header-toggle-button:hover{color:var(--toggle-hover-color);--toggle-after-visibility:visible}.marketweb-header-toggle-button:focus-visible{outline:2px solid #007c89;outline-offset:2px}.marketweb-header-toggle-button--active{color:var(--toggle-active-color);font-weight:500}.marketweb-header-toggle-button--active::after{--toggle-after-visibility:visible}.marketweb-header-toggle-button::after{visibility:var(--toggle-after-visibility);content:\"\";position:absolute;bottom:-0.8rem;width:110%;left:-5%;height:2px;background:var(--toggle-active-underline-color);border-radius:8px}";
4
+ const PnMarketwebHeaderToggleStyle0 = pnMarketwebHeaderToggleCss;
5
+
6
+ const PnMarketwebHeaderToggle = /*@__PURE__*/ proxyCustomElement(class PnMarketwebHeaderToggle extends HTMLElement {
7
+ constructor() {
8
+ super();
9
+ this.__registerHost();
10
+ this.__attachShadow();
11
+ this.toggleChange = createEvent(this, "toggleChange", 7);
12
+ this.options = [];
13
+ this.ariaLabel = 'Header mode';
14
+ this.value = 0;
15
+ }
16
+ /** Emitted whenever the user selects a different mode. */
17
+ toggleChange;
18
+ onClick(event, option) {
19
+ if (option.index !== this.value) {
20
+ this.toggleChange.emit(option.index);
21
+ }
22
+ if (!option.href) {
23
+ event.preventDefault();
24
+ }
25
+ }
26
+ renderOption(option) {
27
+ const isActive = option.index === this.value;
28
+ return (h("a", { href: option.href ?? '#', class: {
29
+ 'marketweb-header-toggle-button': true,
30
+ 'marketweb-header-toggle-button--active': isActive,
31
+ }, "aria-current": isActive ? 'page' : undefined, onClick: (event) => this.onClick(event, option) }, option.label));
32
+ }
33
+ render() {
34
+ if (this.options.length === 0) {
35
+ return h(Host, null);
36
+ }
37
+ return (h(Host, null, h("nav", { class: "marketweb-header-toggle", "aria-label": this.ariaLabel }, this.options.map(option => this.renderOption(option)))));
38
+ }
39
+ static get style() { return PnMarketwebHeaderToggleStyle0; }
40
+ }, [1, "pn-marketweb-header-toggle", {
41
+ "options": [16],
42
+ "ariaLabel": [1, "aria-label"],
43
+ "value": [514]
44
+ }]);
45
+ function defineCustomElement() {
46
+ if (typeof customElements === "undefined") {
47
+ return;
48
+ }
49
+ const components = ["pn-marketweb-header-toggle"];
50
+ components.forEach(tagName => { switch (tagName) {
51
+ case "pn-marketweb-header-toggle":
52
+ if (!customElements.get(tagName)) {
53
+ customElements.define(tagName, PnMarketwebHeaderToggle);
54
+ }
55
+ break;
56
+ } });
57
+ }
58
+
59
+ export { PnMarketwebHeaderToggle as P, defineCustomElement as d };
60
+
61
+ //# sourceMappingURL=pn-marketweb-header-toggle2.js.map
@@ -0,0 +1 @@
1
+ {"file":"pn-marketweb-header-toggle2.js","mappings":";;AAAA,MAAM,0BAA0B,GAAG,8jDAA8jD,CAAC;AAClmD,sCAAe,0BAA0B;;MC4B5B,uBAAuB;;;;;;uBACQ,EAAE;yBAGhB,aAAa;qBAGQ,CAAC;;;IAIzC,YAAY,CAA+B;IAE5C,OAAO,CACb,KAAiB,EACjB,MAA4B;QAE5B,IAAI,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;YAC/B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SACtC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YAChB,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;KACF;IAEO,YAAY,CAAC,MAA4B;QAC/C,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;QAC7C,QACE,SACE,IAAI,EACF,MAAM,CAAC,IAAI,IAAI,GAAG,EAEpB,KAAK,EAAE;gBACL,gCAAgC,EAAE,IAAI;gBACtC,wCAAwC,EAAE,QAAQ;aACnD,kBACa,QAAQ,GAAG,MAAM,GAAG,SAAS,EAC3C,OAAO,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,IAE9C,MAAM,CAAC,KAAK,CACX,EACJ;KACH;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,OAAO,EAAC,IAAI,OAAQ,CAAC;SACtB;QAED,QACE,EAAC,IAAI,QACH,WAAK,KAAK,EAAC,yBAAyB,gBAAa,IAAI,CAAC,SAAS,IAC5D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAClD,CACD,EACP;KACH;;;;;;;;;;;;;;;;;;;;;;;","names":[],"sources":["src/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.scss?tag=pn-marketweb-header-toggle&encapsulation=shadow","src/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.tsx"],"sourcesContent":["@import \"../../../globals/main.scss\";\n\n// -----------------------------------------------------------------------------\n// Component token defaults\n// Styling API\n// -----------------------------------------------------------------------------\n:host {\n --toggle-color: var(--siteheader-toggle-color, #{$blue700});\n --toggle-hover-color: var(--siteheader-toggle-hover-color, #{$black});\n --toggle-active-color: var(--siteheader-toggle-active-color, #{$black});\n --toggle-active-underline-color: var(--siteheader-toggle-active-underline-color, #{$blue400});\n\n --toggle-after-visibility: hidden; \n\n display: inline-block;\n}\n\n// -----------------------------------------------------------------------------\n// Host shell / layout\n// -----------------------------------------------------------------------------\n.marketweb-header-toggle {\n display: flex;\n align-items: center;\n gap: 1.2rem;\n}\n\n// -----------------------------------------------------------------------------\n// Internal elements\n// -----------------------------------------------------------------------------\n.marketweb-header-toggle-button {\n display: inline-block;\n position: relative;\n cursor: pointer;\n text-decoration: none;\n line-height: 1;\n transition: color 0.2s ease;\n\n font-size: 1.6rem; \n color: var(--toggle-color);\n\n &:hover {\n color: var(--toggle-hover-color); \n --toggle-after-visibility:visible;\n }\n \n\n &:focus-visible {\n outline: 2px solid #007c89;\n outline-offset: 2px;\n }\n\n &--active {\n color: var(--toggle-active-color);\n font-weight: 500;\n\n &::after {\n --toggle-after-visibility:visible;\n }\n }\n\n \n &::after { \n visibility:var(--toggle-after-visibility);\n content: '';\n position: absolute; \n bottom: rem16(-8px);\n width: 110%;\n left:-5%;\n height: 2px;\n background: var(--toggle-active-underline-color);\n border-radius: 8px;\n }\n}","import {\n HeaderMenuMode,\n HeaderMenuModeOption,\n} from '@/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types';\nimport {\n Component,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n} from '@stencil/core';\n\n/**\n * Small segmented toggle used for switching between Private and Business menu modes.\n *\n * Responsibilities:\n * - render two selectable links\n * - reflect current active mode\n * - emit the selected mode when changed\n *\n * This component is intentionally presentation-only.\n * The parent header decides what switching mode actually means.\n */\n@Component({\n tag: 'pn-marketweb-header-toggle',\n styleUrl: 'pn-marketweb-header-toggle.scss',\n shadow: true,\n})\nexport class PnMarketwebHeaderToggle {\n @Prop() options: HeaderMenuModeOption[] = [];\n\n /** Accessible label for the toggle group. */\n @Prop() ariaLabel: string = 'Header mode';\n\n /** Currently active mode. */\n @Prop({ reflect: true }) value: HeaderMenuMode = 0;\n\n\n /** Emitted whenever the user selects a different mode. */\n @Event() toggleChange: EventEmitter<HeaderMenuMode>;\n\n private onClick(\n event: MouseEvent,\n option: HeaderMenuModeOption,\n ) {\n if (option.index !== this.value) {\n this.toggleChange.emit(option.index);\n }\n\n if (!option.href) {\n event.preventDefault();\n }\n }\n\n private renderOption(option: HeaderMenuModeOption) {\n const isActive = option.index === this.value;\n return (\n <a\n href={\n option.href ?? '#'\n }\n class={{\n 'marketweb-header-toggle-button': true,\n 'marketweb-header-toggle-button--active': isActive,\n }} \n aria-current={isActive ? 'page' : undefined} \n onClick={(event) => this.onClick(event, option)}\n >\n {option.label}\n </a>\n );\n }\n\n render() {\n if (this.options.length === 0) {\n return <Host></Host>;\n }\n\n return (\n <Host>\n <nav class=\"marketweb-header-toggle\" aria-label={this.ariaLabel}>\n {this.options.map(option => this.renderOption(option))}\n </nav>\n </Host>\n );\n }\n}"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface PnMarketwebHeaderTopRow extends Components.PnMarketwebHeaderTopRow, HTMLElement {}
4
+ export const PnMarketwebHeaderTopRow: {
5
+ prototype: PnMarketwebHeaderTopRow;
6
+ new (): PnMarketwebHeaderTopRow;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,8 @@
1
+ import { P as PnMarketwebHeaderTopRow$1, d as defineCustomElement$1 } from './pn-marketweb-header-top-row2.js';
2
+
3
+ const PnMarketwebHeaderTopRow = PnMarketwebHeaderTopRow$1;
4
+ const defineCustomElement = defineCustomElement$1;
5
+
6
+ export { PnMarketwebHeaderTopRow, defineCustomElement };
7
+
8
+ //# sourceMappingURL=pn-marketweb-header-top-row.js.map
@@ -0,0 +1 @@
1
+ {"file":"pn-marketweb-header-top-row.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}