@postnord/pn-marketweb-components 4.2.5 → 4.3.1
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.
- package/cjs/header-theme-a250bf67.js +245 -0
- package/cjs/header-theme-a250bf67.js.map +1 -0
- package/cjs/index-9a9efa1c.js +24 -16
- package/cjs/loader.cjs.js +1 -1
- package/cjs/pn-app-banner.cjs.entry.js +1 -1
- package/cjs/pn-breakpoints.cjs.entry.js +1 -1
- package/cjs/pn-chat-message_2.cjs.entry.js +2 -2
- package/cjs/pn-chat.cjs.entry.js +2 -2
- package/cjs/pn-customernumber-selector-option.cjs.entry.js +1 -1
- package/cjs/pn-customernumber-selector.cjs.entry.js +1 -1
- package/cjs/pn-find-price-result.cjs.entry.js +1 -1
- package/cjs/pn-find-price.cjs.entry.js +2 -2
- package/cjs/pn-find-service-and-price-result.cjs.entry.js +1 -1
- package/cjs/pn-find-service-and-price.cjs.entry.js +1 -1
- package/cjs/pn-hero-block-international.cjs.entry.js +1 -1
- package/cjs/pn-language-selector_13.cjs.entry.js +1519 -0
- package/cjs/pn-language-selector_13.cjs.entry.js.map +1 -0
- package/cjs/pn-level-up-modal.cjs.entry.js +1 -1
- package/cjs/pn-level-up.cjs.entry.js +2 -2
- package/cjs/pn-link-list.cjs.entry.js +1 -1
- package/cjs/pn-market-web-components.cjs.js +1 -1
- package/cjs/pn-marketweb-header-main-row_2.cjs.entry.js +222 -0
- package/cjs/pn-marketweb-header-main-row_2.cjs.entry.js.map +1 -0
- package/cjs/pn-marketweb-header-skeleton-loader.cjs.entry.js +23 -0
- package/cjs/pn-marketweb-header-skeleton-loader.cjs.entry.js.map +1 -0
- package/cjs/pn-marketweb-header-toggle.cjs.entry.js +46 -0
- package/cjs/pn-marketweb-header-toggle.cjs.entry.js.map +1 -0
- package/cjs/pn-marketweb-header.cjs.entry.js +1043 -0
- package/cjs/pn-marketweb-header.cjs.entry.js.map +1 -0
- package/cjs/pn-marketweb-icon.cjs.entry.js +1 -1
- package/cjs/{pn-marketweb-siteheader-login-linklist.cjs.entry.js → pn-marketweb-siteheader-login-button_2.cjs.entry.js} +44 -2
- package/cjs/pn-marketweb-siteheader-login-button_2.cjs.entry.js.map +1 -0
- package/cjs/pn-marketweb-siteheader-login-mypage-button.cjs.entry.js +1 -1
- package/cjs/pn-marketweb-siteheader.cjs.entry.js +7 -199
- package/cjs/pn-marketweb-siteheader.cjs.entry.js.map +1 -1
- package/cjs/pn-marketweb-table.cjs.entry.js +1 -1
- package/cjs/pn-media-block.cjs.entry.js +1 -1
- package/cjs/pn-pex-pricefinder.cjs.entry.js +1 -1
- package/cjs/pn-product-card_3.cjs.entry.js +1 -1
- package/cjs/pn-product-pricelist-result.cjs.entry.js +1 -1
- package/cjs/pn-product-pricelist.cjs.entry.js +2 -2
- package/cjs/pn-product-tile-info_2.cjs.entry.js +1 -1
- package/cjs/pn-product-tile.cjs.entry.js +1 -1
- package/cjs/pn-profile-modal-customernumber.cjs.entry.js +1 -1
- package/cjs/pn-profile-modal-profile.cjs.entry.js +2 -2
- package/cjs/pn-profile-modal-type.cjs.entry.js +1 -1
- package/cjs/pn-profile-modal.cjs.entry.js +1 -1
- package/cjs/pn-profile-selector-option.cjs.entry.js +1 -1
- package/cjs/pn-profile-selector.cjs.entry.js +1 -1
- package/cjs/pn-proxio-findprice-result.cjs.entry.js +1 -1
- package/cjs/pn-proxio-findprice.cjs.entry.js +3 -3
- package/cjs/pn-proxio-pricegroup.cjs.entry.js +1 -1
- package/cjs/pn-proxio-productcard_4.cjs.entry.js +3 -3
- package/cjs/pn-qr-code-generator.cjs.entry.js +1 -1
- package/cjs/pn-sidenav-level.cjs.entry.js +1 -1
- package/cjs/pn-sidenav-link.cjs.entry.js +1 -1
- package/cjs/pn-sidenav-togglebutton.cjs.entry.js +1 -1
- package/cjs/pn-sidenav.cjs.entry.js +1 -1
- package/cjs/pn-site-footer_3.cjs.entry.js +3 -3
- package/cjs/pn-titletag.cjs.entry.js +1 -1
- package/cjs/pn-usp-promoter.cjs.entry.js +1 -1
- package/cjs/translations-9510f11c.js +198 -0
- package/cjs/translations-9510f11c.js.map +1 -0
- package/collection/collection-manifest.json +5 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.css +204 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.js +658 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.css +217 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.js +20 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.css +115 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.js +520 -0
- package/collection/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.js +37 -0
- package/collection/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.js +109 -0
- package/collection/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.css +225 -0
- package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.js +916 -0
- package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.js +638 -0
- package/collection/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.js +180 -0
- package/collection/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.js +2 -0
- package/collection/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-i18n.js +37 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-i18n.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-language.js +46 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-language.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-menu.js +36 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-menu.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-theme.js +48 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-theme.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.js +101 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.js +63 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-url.js +91 -0
- package/collection/components/layout-components/pn-marketweb-header/utils/header-url.js.map +1 -0
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-button.js +1 -1
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-linklist.css +34 -12
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-mypage-button.js +1 -1
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login-profileselection.css +36 -15
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.css +27 -13
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.js +29 -4
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.js.map +1 -1
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-types.js.map +1 -1
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-unified-login.js +1 -1
- package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader.js +4 -4
- package/collection/components/media/pn-media-block/pn-media-block.js +1 -1
- package/collection/components/minor/pn-app-banner/pn-app-banner.js +1 -1
- package/collection/components/minor/pn-marketweb-icon/pn-marketweb-icon.js +1 -1
- package/collection/components/minor/pn-swan/pn-swan.js +1 -1
- package/collection/components/minor/pn-titletag/pn-titletag.js +1 -1
- package/collection/components/navigation/pn-language-selector/pn-language-selector-option.css +25 -12
- package/collection/components/navigation/pn-language-selector/pn-language-selector-option.js +1 -1
- package/collection/components/navigation/pn-language-selector/pn-language-selector.css +17 -5
- package/collection/components/navigation/pn-language-selector/pn-language-selector.js +22 -3
- package/collection/components/navigation/pn-language-selector/pn-language-selector.js.map +1 -1
- package/collection/components/navigation/pn-mainnav/pn-mainnav-level.css +37 -17
- package/collection/components/navigation/pn-mainnav/pn-mainnav-level.js +2 -2
- package/collection/components/navigation/pn-mainnav/pn-mainnav-link.css +81 -33
- package/collection/components/navigation/pn-mainnav/pn-mainnav-link.js +1 -1
- package/collection/components/navigation/pn-mainnav/pn-mainnav-list.css +12 -2
- package/collection/components/navigation/pn-mainnav/pn-mainnav-list.js +1 -1
- package/collection/components/navigation/pn-mainnav/pn-mainnav.css +35 -22
- package/collection/components/navigation/pn-mainnav/pn-mainnav.js +1 -1
- package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.css +80 -0
- package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.js +147 -0
- package/collection/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.js.map +1 -0
- package/collection/components/navigation/pn-sidenav/pn-sidenav-level.js +1 -1
- package/collection/components/navigation/pn-sidenav/pn-sidenav-link.js +1 -1
- package/collection/components/navigation/pn-sidenav/pn-sidenav-togglebutton.js +1 -1
- package/collection/components/navigation/pn-sidenav/pn-sidenav.js +1 -1
- package/collection/components/navigation/pn-site-footer/pn-site-footer-col.js +1 -1
- package/collection/components/navigation/pn-site-footer/pn-site-footer.js +1 -1
- package/collection/components/navigation/pn-site-selector/pn-site-selector-item.css +16 -12
- package/collection/components/navigation/pn-site-selector/pn-site-selector-item.js +1 -1
- package/collection/components/navigation/pn-site-selector/pn-site-selector.css +15 -0
- package/collection/components/navigation/pn-site-selector/pn-site-selector.js +22 -3
- package/collection/components/navigation/pn-site-selector/pn-site-selector.js.map +1 -1
- package/collection/components/profile/pn-customernumber-selector/pn-customernumber-selector-option.js +1 -1
- package/collection/components/profile/pn-customernumber-selector/pn-customernumber-selector.js +1 -1
- package/collection/components/profile/pn-profile-modal/pn-profile-modal-customernumber.js +1 -1
- package/collection/components/profile/pn-profile-modal/pn-profile-modal-profile.js +2 -2
- package/collection/components/profile/pn-profile-modal/pn-profile-modal-type.js +1 -1
- package/collection/components/profile/pn-profile-modal/pn-profile-modal.js +1 -1
- package/collection/components/profile/pn-profile-selector/pn-profile-selector-option.js +1 -1
- package/collection/components/profile/pn-profile-selector/pn-profile-selector.js +1 -1
- package/collection/components/utilities/pn-breakpoints/pn-breakpoints.js +1 -1
- package/collection/components/widgets/pn-chat/pn-chat-message/pn-chat-message.js +1 -1
- package/collection/components/widgets/pn-chat/pn-chat.js +2 -2
- package/collection/components/widgets/pn-find-price/pn-find-price-result.js +1 -1
- package/collection/components/widgets/pn-find-price/pn-find-price.js +2 -2
- package/collection/components/widgets/pn-find-service-and-price/pn-find-service-and-price-result.js +1 -1
- package/collection/components/widgets/pn-find-service-and-price/pn-find-service-and-price.js +1 -1
- package/collection/components/widgets/pn-hero-block-international/pn-hero-block-international.js +1 -1
- package/collection/components/widgets/pn-level-up/pn-level-up-modal/pn-level-up-modal.js +1 -1
- package/collection/components/widgets/pn-level-up/pn-level-up.js +2 -2
- package/collection/components/widgets/pn-link-list/pn-link-list.js +1 -1
- package/collection/components/widgets/pn-marketweb-carousel/pn-marketweb-carousel.js +1 -1
- package/collection/components/widgets/pn-marketweb-table/pn-marketweb-table.js +1 -1
- package/collection/components/widgets/pn-pex-pricefinder/pn-pex-pricefinder.js +1 -1
- package/collection/components/widgets/pn-product-card/pn-product-card.js +1 -1
- package/collection/components/widgets/pn-product-pricelist/pn-product-pricelist-result.js +1 -1
- package/collection/components/widgets/pn-product-pricelist/pn-product-pricelist.js +2 -2
- package/collection/components/widgets/pn-product-tile/pn-product-tile-info.js +1 -1
- package/collection/components/widgets/pn-product-tile/pn-product-tile.js +1 -1
- package/collection/components/widgets/pn-proxio-findprice/pn-proxio-findprice-result.js +1 -1
- package/collection/components/widgets/pn-proxio-findprice/pn-proxio-findprice.js +3 -3
- package/collection/components/widgets/pn-proxio-pricegroup/pn-proxio-pricegroup.js +1 -1
- package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard-description.js +1 -1
- package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard-information.js +1 -1
- package/collection/components/widgets/pn-proxio-productcard/pn-proxio-productcard.js +1 -1
- package/collection/components/widgets/pn-qr-code-generator/pn-qr-code-generator.js +1 -1
- package/collection/components/widgets/pn-usp-promoter/pn-usp-promoter.js +1 -1
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.js +105 -0
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.js.map +1 -0
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.js +166 -0
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.js.map +1 -0
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.js +2 -0
- package/collection/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.js.map +1 -0
- package/components/pn-app-banner.js +1 -1
- package/components/pn-breakpoints.js +1 -1
- package/components/pn-chat-message2.js +1 -1
- package/components/pn-chat.js +2 -2
- package/components/pn-customernumber-selector-option.js +1 -1
- package/components/pn-customernumber-selector.js +1 -1
- package/components/pn-find-price-result2.js +1 -1
- package/components/pn-find-price.js +2 -2
- package/components/pn-find-service-and-price-result2.js +1 -1
- package/components/pn-find-service-and-price.js +1 -1
- package/components/pn-hero-block-international.js +1 -1
- package/components/pn-language-selector-option2.js +2 -2
- package/components/pn-language-selector-option2.js.map +1 -1
- package/components/pn-language-selector2.js +4 -2
- package/components/pn-language-selector2.js.map +1 -1
- package/components/pn-level-up-modal2.js +1 -1
- package/components/pn-level-up.js +2 -2
- package/components/pn-link-list.js +1 -1
- package/components/pn-mainnav-level2.js +3 -3
- package/components/pn-mainnav-level2.js.map +1 -1
- package/components/pn-mainnav-link2.js +2 -2
- package/components/pn-mainnav-link2.js.map +1 -1
- package/components/pn-mainnav-list2.js +2 -2
- package/components/pn-mainnav-list2.js.map +1 -1
- package/components/pn-mainnav2.js +2 -2
- package/components/pn-mainnav2.js.map +1 -1
- package/components/pn-marketweb-carousel2.js +1 -1
- package/components/pn-marketweb-header-main-row.d.ts +11 -0
- package/components/pn-marketweb-header-main-row.js +8 -0
- package/components/pn-marketweb-header-main-row.js.map +1 -0
- package/components/pn-marketweb-header-main-row2.js +281 -0
- package/components/pn-marketweb-header-main-row2.js.map +1 -0
- package/components/pn-marketweb-header-shared.js +192 -0
- package/components/pn-marketweb-header-shared.js.map +1 -0
- package/components/pn-marketweb-header-skeleton-loader.d.ts +11 -0
- package/components/pn-marketweb-header-skeleton-loader.js +37 -0
- package/components/pn-marketweb-header-skeleton-loader.js.map +1 -0
- package/components/pn-marketweb-header-toggle.d.ts +11 -0
- package/components/pn-marketweb-header-toggle.js +8 -0
- package/components/pn-marketweb-header-toggle.js.map +1 -0
- package/components/pn-marketweb-header-toggle2.js +61 -0
- package/components/pn-marketweb-header-toggle2.js.map +1 -0
- package/components/pn-marketweb-header-top-row.d.ts +11 -0
- package/components/pn-marketweb-header-top-row.js +8 -0
- package/components/pn-marketweb-header-top-row.js.map +1 -0
- package/components/pn-marketweb-header-top-row2.js +238 -0
- package/components/pn-marketweb-header-top-row2.js.map +1 -0
- package/components/pn-marketweb-header.d.ts +11 -0
- package/components/pn-marketweb-header.js +1206 -0
- package/components/pn-marketweb-header.js.map +1 -0
- package/components/pn-marketweb-icon.js +1 -1
- package/components/pn-marketweb-siteheader-login-button2.js +1 -1
- package/components/pn-marketweb-siteheader-login-linklist2.js +1 -1
- package/components/pn-marketweb-siteheader-login-linklist2.js.map +1 -1
- package/components/pn-marketweb-siteheader-login-mypage-button.js +1 -1
- package/components/pn-marketweb-siteheader-login-profileselection2.js +1 -1
- package/components/pn-marketweb-siteheader-login-profileselection2.js.map +1 -1
- package/components/pn-marketweb-siteheader-login2.js +4 -2
- package/components/pn-marketweb-siteheader-login2.js.map +1 -1
- package/components/pn-marketweb-siteheader-unified-login2.js +1 -1
- package/components/pn-marketweb-siteheader.js +5 -197
- package/components/pn-marketweb-siteheader.js.map +1 -1
- package/components/pn-marketweb-table.js +1 -1
- package/components/pn-media-block.js +1 -1
- package/components/pn-pex-pricefinder.js +1 -1
- package/components/pn-product-card2.js +1 -1
- package/components/pn-product-pricelist-result.js +1 -1
- package/components/pn-product-pricelist.js +2 -2
- package/components/pn-product-tile-info2.js +1 -1
- package/components/pn-product-tile.js +1 -1
- package/components/pn-profile-modal-customernumber.js +1 -1
- package/components/pn-profile-modal-profile.js +2 -2
- package/components/pn-profile-modal-type.js +1 -1
- package/components/pn-profile-modal.js +1 -1
- package/components/pn-profile-selector-option.js +1 -1
- package/components/pn-profile-selector.js +1 -1
- package/components/pn-proxio-findprice-result2.js +2 -2
- package/components/pn-proxio-findprice.js +3 -3
- package/components/pn-proxio-pricegroup.js +2 -2
- package/components/pn-proxio-productcard-description2.js +1 -1
- package/components/pn-proxio-productcard-information2.js +1 -1
- package/components/pn-proxio-productcard2.js +1 -1
- package/components/pn-qr-code-generator2.js +1 -1
- package/components/pn-sidenav-level.js +1 -1
- package/components/pn-sidenav-link.js +1 -1
- package/components/pn-sidenav-togglebutton.js +1 -1
- package/components/pn-sidenav.js +1 -1
- package/components/pn-site-footer-col2.js +1 -1
- package/components/pn-site-footer2.js +1 -1
- package/components/pn-site-selector-item2.js +2 -2
- package/components/pn-site-selector-item2.js.map +1 -1
- package/components/pn-site-selector2.js +4 -2
- package/components/pn-site-selector2.js.map +1 -1
- package/components/pn-swan2.js +1 -1
- package/components/pn-titletag2.js +1 -1
- package/components/pn-usp-promoter.js +1 -1
- package/components/translations.js +189 -14
- package/components/translations.js.map +1 -1
- package/components/translations2.js +21 -0
- package/components/translations2.js.map +1 -0
- package/esm/header-theme-d09b64c7.js +234 -0
- package/esm/header-theme-d09b64c7.js.map +1 -0
- package/esm/index-c0a4d8bd.js +24 -16
- package/esm/loader.js +1 -1
- package/esm/pn-app-banner.entry.js +1 -1
- package/esm/pn-breakpoints.entry.js +1 -1
- package/esm/pn-chat-message_2.entry.js +2 -2
- package/esm/pn-chat.entry.js +2 -2
- package/esm/pn-customernumber-selector-option.entry.js +1 -1
- package/esm/pn-customernumber-selector.entry.js +1 -1
- package/esm/pn-find-price-result.entry.js +1 -1
- package/esm/pn-find-price.entry.js +2 -2
- package/esm/pn-find-service-and-price-result.entry.js +1 -1
- package/esm/pn-find-service-and-price.entry.js +1 -1
- package/esm/pn-hero-block-international.entry.js +1 -1
- package/esm/{pn-language-selector_9.entry.js → pn-language-selector_13.entry.js} +381 -22
- package/esm/pn-language-selector_13.entry.js.map +1 -0
- package/esm/pn-level-up-modal.entry.js +1 -1
- package/esm/pn-level-up.entry.js +2 -2
- package/esm/pn-link-list.entry.js +1 -1
- package/esm/pn-market-web-components.js +1 -1
- package/esm/pn-marketweb-header-main-row_2.entry.js +217 -0
- package/esm/pn-marketweb-header-main-row_2.entry.js.map +1 -0
- package/esm/pn-marketweb-header-skeleton-loader.entry.js +19 -0
- package/esm/pn-marketweb-header-skeleton-loader.entry.js.map +1 -0
- package/esm/pn-marketweb-header-toggle.entry.js +42 -0
- package/esm/pn-marketweb-header-toggle.entry.js.map +1 -0
- package/esm/pn-marketweb-header.entry.js +1039 -0
- package/esm/pn-marketweb-header.entry.js.map +1 -0
- package/esm/pn-marketweb-icon.entry.js +1 -1
- package/esm/{pn-marketweb-siteheader-login-linklist.entry.js → pn-marketweb-siteheader-login-button_2.entry.js} +44 -3
- package/esm/pn-marketweb-siteheader-login-button_2.entry.js.map +1 -0
- package/esm/pn-marketweb-siteheader-login-mypage-button.entry.js +1 -1
- package/esm/pn-marketweb-siteheader.entry.js +5 -197
- package/esm/pn-marketweb-siteheader.entry.js.map +1 -1
- package/esm/pn-marketweb-table.entry.js +1 -1
- package/esm/pn-media-block.entry.js +1 -1
- package/esm/pn-pex-pricefinder.entry.js +1 -1
- package/esm/pn-product-card_3.entry.js +1 -1
- package/esm/pn-product-pricelist-result.entry.js +1 -1
- package/esm/pn-product-pricelist.entry.js +2 -2
- package/esm/pn-product-tile-info_2.entry.js +1 -1
- package/esm/pn-product-tile.entry.js +1 -1
- package/esm/pn-profile-modal-customernumber.entry.js +1 -1
- package/esm/pn-profile-modal-profile.entry.js +2 -2
- package/esm/pn-profile-modal-type.entry.js +1 -1
- package/esm/pn-profile-modal.entry.js +1 -1
- package/esm/pn-profile-selector-option.entry.js +1 -1
- package/esm/pn-profile-selector.entry.js +1 -1
- package/esm/pn-proxio-findprice-result.entry.js +1 -1
- package/esm/pn-proxio-findprice.entry.js +3 -3
- package/esm/pn-proxio-pricegroup.entry.js +1 -1
- package/esm/pn-proxio-productcard_4.entry.js +3 -3
- package/esm/pn-qr-code-generator.entry.js +1 -1
- package/esm/pn-sidenav-level.entry.js +1 -1
- package/esm/pn-sidenav-link.entry.js +1 -1
- package/esm/pn-sidenav-togglebutton.entry.js +1 -1
- package/esm/pn-sidenav.entry.js +1 -1
- package/esm/pn-site-footer_3.entry.js +3 -3
- package/esm/pn-titletag.entry.js +1 -1
- package/esm/pn-usp-promoter.entry.js +1 -1
- package/esm/translations-d2f5804e.js +196 -0
- package/esm/translations-d2f5804e.js.map +1 -0
- package/package.json +13 -6
- package/pn-market-web-components/{p-4a164ef8.entry.js → p-03728b0b.entry.js} +2 -2
- package/pn-market-web-components/p-04f51418.js +2 -0
- package/pn-market-web-components/p-04f51418.js.map +1 -0
- package/pn-market-web-components/{p-e43a36e0.entry.js → p-067c1c2f.entry.js} +2 -2
- package/pn-market-web-components/{p-2616cdc1.entry.js → p-191c8cfc.entry.js} +2 -2
- package/pn-market-web-components/{p-ca003c1f.entry.js → p-1a91c313.entry.js} +2 -2
- package/pn-market-web-components/{p-ab1e3dc2.entry.js → p-1f8304be.entry.js} +2 -2
- package/pn-market-web-components/{p-a3f601cb.entry.js → p-24ffac0a.entry.js} +2 -2
- package/pn-market-web-components/p-3239c36b.entry.js +2 -0
- package/pn-market-web-components/p-3239c36b.entry.js.map +1 -0
- package/pn-market-web-components/{p-12cafd55.entry.js → p-3aa74418.entry.js} +2 -2
- package/pn-market-web-components/p-3d27faee.entry.js +2 -0
- package/pn-market-web-components/{p-9d0ca27b.entry.js.map → p-3d27faee.entry.js.map} +1 -1
- package/pn-market-web-components/p-3e25f431.entry.js +2 -0
- package/pn-market-web-components/p-3e25f431.entry.js.map +1 -0
- package/pn-market-web-components/{p-64f6691d.entry.js → p-42da7c5f.entry.js} +2 -2
- package/pn-market-web-components/{p-f0d423d0.entry.js → p-43748ca2.entry.js} +2 -2
- package/pn-market-web-components/{p-1c644b91.entry.js → p-466958a8.entry.js} +2 -2
- package/pn-market-web-components/{p-150da889.entry.js → p-4ab53d5d.entry.js} +2 -2
- package/pn-market-web-components/{p-118fe47d.entry.js → p-4d595345.entry.js} +2 -2
- package/pn-market-web-components/{p-0f6f715b.entry.js → p-4dac1980.entry.js} +2 -2
- package/pn-market-web-components/{p-a13f1f73.entry.js → p-4fcce83d.entry.js} +2 -2
- package/pn-market-web-components/{p-89fbca3b.entry.js → p-5a51d0b0.entry.js} +2 -2
- package/pn-market-web-components/{p-f4d2d0d3.entry.js → p-61346425.entry.js} +2 -2
- package/pn-market-web-components/{p-6e693269.entry.js → p-6b557670.entry.js} +2 -2
- package/pn-market-web-components/{p-e6d6a752.entry.js → p-70a71854.entry.js} +2 -2
- package/pn-market-web-components/p-75311d67.js +2 -0
- package/pn-market-web-components/p-75311d67.js.map +1 -0
- package/pn-market-web-components/p-756d8d95.entry.js +2 -0
- package/pn-market-web-components/p-756d8d95.entry.js.map +1 -0
- package/pn-market-web-components/{p-c0315c45.entry.js → p-76fb0c21.entry.js} +2 -2
- package/pn-market-web-components/{p-b2b2bae0.entry.js → p-81210644.entry.js} +2 -2
- package/pn-market-web-components/p-81e4d75b.entry.js +2 -0
- package/pn-market-web-components/p-81e4d75b.entry.js.map +1 -0
- package/pn-market-web-components/{p-d0f27361.entry.js → p-8382794b.entry.js} +2 -2
- package/pn-market-web-components/{p-8f25176b.entry.js → p-8519e39e.entry.js} +2 -2
- package/pn-market-web-components/p-8c26c1f2.entry.js +2 -0
- package/pn-market-web-components/p-8c26c1f2.entry.js.map +1 -0
- package/pn-market-web-components/{p-461c8792.entry.js → p-92b6477c.entry.js} +2 -2
- package/pn-market-web-components/{p-0d4d9d90.entry.js → p-9eab8192.entry.js} +2 -2
- package/pn-market-web-components/{p-40e632cc.entry.js → p-a3beee11.entry.js} +2 -2
- package/pn-market-web-components/{p-01fbf1ce.entry.js → p-a6935dc2.entry.js} +2 -2
- package/pn-market-web-components/{p-af646091.entry.js → p-a6dd3e4f.entry.js} +2 -2
- package/pn-market-web-components/{p-6d77e747.entry.js → p-af89c95a.entry.js} +2 -2
- package/pn-market-web-components/p-b318ff19.entry.js +2 -0
- package/pn-market-web-components/{p-0700cb4c.entry.js.map → p-b318ff19.entry.js.map} +1 -1
- package/pn-market-web-components/{p-c89f3d6b.entry.js → p-ba14b0ef.entry.js} +2 -2
- package/pn-market-web-components/{p-c7965104.entry.js → p-ba680948.entry.js} +2 -2
- package/pn-market-web-components/{p-11c6e458.entry.js → p-ba75bfdb.entry.js} +2 -2
- package/pn-market-web-components/{p-4149e715.entry.js → p-c186ec41.entry.js} +2 -2
- package/pn-market-web-components/{p-66c0c8dc.entry.js → p-c38707f9.entry.js} +2 -2
- package/pn-market-web-components/{p-671a8129.entry.js → p-c89cdd5a.entry.js} +2 -2
- package/pn-market-web-components/{p-4d848e18.entry.js → p-e8cd1608.entry.js} +2 -2
- package/pn-market-web-components/{p-4517a3d4.entry.js → p-ef090656.entry.js} +2 -2
- package/pn-market-web-components/p-f23ed5d2.entry.js +2 -0
- package/pn-market-web-components/p-f23ed5d2.entry.js.map +1 -0
- package/pn-market-web-components/{p-bd8ec517.entry.js → p-f3b4c13d.entry.js} +2 -2
- package/pn-market-web-components/{p-ff38b9a5.entry.js → p-f710445f.entry.js} +2 -2
- package/pn-market-web-components/{p-2e585ed5.entry.js → p-fcefe4a4.entry.js} +2 -2
- package/pn-market-web-components/p-fded22b7.entry.js +2 -0
- package/pn-market-web-components/p-fded22b7.entry.js.map +1 -0
- package/pn-market-web-components/{p-32bd2ff8.entry.js → p-ff6118f8.entry.js} +2 -2
- package/pn-market-web-components/pn-market-web-components.esm.js +1 -1
- package/pn-market-web-components/pn-market-web-components.esm.js.map +1 -1
- package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-main-row.d.ts +40 -0
- package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-skeleton-loader.d.ts +3 -0
- package/types/components/layout-components/pn-marketweb-header/components/pn-marketweb-header-top-row.d.ts +30 -0
- package/types/components/layout-components/pn-marketweb-header/components/shared/pn-marketweb-header-shared.d.ts +48 -0
- package/types/components/layout-components/pn-marketweb-header/mapper/pn-marketweb-header.mapper.d.ts +34 -0
- package/types/components/layout-components/pn-marketweb-header/pn-marketweb-header.d.ts +121 -0
- package/types/components/layout-components/pn-marketweb-header/pn-marketweb-header.stories.d.ts +99 -0
- package/types/components/layout-components/pn-marketweb-header/services/pn-marketweb-header.service.d.ts +108 -0
- package/types/components/layout-components/pn-marketweb-header/types/pn-marketweb-header.types.d.ts +103 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-i18n.d.ts +16 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-language.d.ts +20 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-menu.d.ts +16 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-theme.d.ts +6 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.d.ts +49 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-toggle-menu.storage.d.ts +25 -0
- package/types/components/layout-components/pn-marketweb-header/utils/header-url.d.ts +41 -0
- package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.d.ts +2 -0
- package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-types.d.ts +1 -0
- package/types/components/navigation/pn-language-selector/pn-language-selector.d.ts +1 -0
- package/types/components/navigation/pn-marketweb-header-toggle/pn-marketweb-header-toggle.d.ts +25 -0
- package/types/components/navigation/pn-site-selector/pn-site-selector.d.ts +1 -0
- package/types/components/widgets/pn-proxio-pricegroup/pn-proxio-pricegroup.d.ts +1 -1
- package/types/components.d.ts +532 -2
- package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.constants.d.ts +7 -0
- package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.service.d.ts +24 -0
- package/types/services/pn-refined-marketweb-context/pn-refined-marketweb-context.types.d.ts +16 -0
- package/umd/pn-marketweb-init.js +1 -1
- package/umd/pn-marketweb-salesforce.js +1 -1
- package/vscode-data.json +421 -0
- package/cjs/pn-language-selector_9.cjs.entry.js +0 -1156
- package/cjs/pn-language-selector_9.cjs.entry.js.map +0 -1
- package/cjs/pn-mainnav-link.cjs.entry.js +0 -45
- package/cjs/pn-mainnav-link.cjs.entry.js.map +0 -1
- package/cjs/pn-mainnav-store-13aaa243.js +0 -22
- package/cjs/pn-mainnav-store-13aaa243.js.map +0 -1
- package/cjs/pn-marketweb-siteheader-login-button_4.cjs.entry.js +0 -366
- package/cjs/pn-marketweb-siteheader-login-button_4.cjs.entry.js.map +0 -1
- package/cjs/pn-marketweb-siteheader-login-linklist.cjs.entry.js.map +0 -1
- package/esm/pn-language-selector_9.entry.js.map +0 -1
- package/esm/pn-mainnav-link.entry.js +0 -41
- package/esm/pn-mainnav-link.entry.js.map +0 -1
- package/esm/pn-mainnav-store-c98d831e.js +0 -19
- package/esm/pn-mainnav-store-c98d831e.js.map +0 -1
- package/esm/pn-marketweb-siteheader-login-button_4.entry.js +0 -359
- package/esm/pn-marketweb-siteheader-login-button_4.entry.js.map +0 -1
- package/esm/pn-marketweb-siteheader-login-linklist.entry.js.map +0 -1
- package/pn-market-web-components/p-022780ab.entry.js +0 -2
- package/pn-market-web-components/p-022780ab.entry.js.map +0 -1
- package/pn-market-web-components/p-0700cb4c.entry.js +0 -2
- package/pn-market-web-components/p-4bc6d49f.entry.js +0 -2
- package/pn-market-web-components/p-4bc6d49f.entry.js.map +0 -1
- package/pn-market-web-components/p-4c8bda8f.entry.js +0 -2
- package/pn-market-web-components/p-4c8bda8f.entry.js.map +0 -1
- package/pn-market-web-components/p-5090bb1d.entry.js +0 -2
- package/pn-market-web-components/p-5090bb1d.entry.js.map +0 -1
- package/pn-market-web-components/p-9d0ca27b.entry.js +0 -2
- package/pn-market-web-components/p-a30de538.entry.js +0 -2
- package/pn-market-web-components/p-a30de538.entry.js.map +0 -1
- package/pn-market-web-components/p-e3b2486a.js +0 -2
- package/pn-market-web-components/p-e3b2486a.js.map +0 -1
- /package/pn-market-web-components/{p-4a164ef8.entry.js.map → p-03728b0b.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-e43a36e0.entry.js.map → p-067c1c2f.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-2616cdc1.entry.js.map → p-191c8cfc.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-ca003c1f.entry.js.map → p-1a91c313.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-ab1e3dc2.entry.js.map → p-1f8304be.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-a3f601cb.entry.js.map → p-24ffac0a.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-12cafd55.entry.js.map → p-3aa74418.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-64f6691d.entry.js.map → p-42da7c5f.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-f0d423d0.entry.js.map → p-43748ca2.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-1c644b91.entry.js.map → p-466958a8.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-150da889.entry.js.map → p-4ab53d5d.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-118fe47d.entry.js.map → p-4d595345.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-0f6f715b.entry.js.map → p-4dac1980.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-a13f1f73.entry.js.map → p-4fcce83d.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-89fbca3b.entry.js.map → p-5a51d0b0.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-f4d2d0d3.entry.js.map → p-61346425.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-6e693269.entry.js.map → p-6b557670.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-e6d6a752.entry.js.map → p-70a71854.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-c0315c45.entry.js.map → p-76fb0c21.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-b2b2bae0.entry.js.map → p-81210644.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-d0f27361.entry.js.map → p-8382794b.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-8f25176b.entry.js.map → p-8519e39e.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-461c8792.entry.js.map → p-92b6477c.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-0d4d9d90.entry.js.map → p-9eab8192.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-40e632cc.entry.js.map → p-a3beee11.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-01fbf1ce.entry.js.map → p-a6935dc2.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-af646091.entry.js.map → p-a6dd3e4f.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-6d77e747.entry.js.map → p-af89c95a.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-c89f3d6b.entry.js.map → p-ba14b0ef.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-c7965104.entry.js.map → p-ba680948.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-11c6e458.entry.js.map → p-ba75bfdb.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-4149e715.entry.js.map → p-c186ec41.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-66c0c8dc.entry.js.map → p-c38707f9.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-671a8129.entry.js.map → p-c89cdd5a.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-4d848e18.entry.js.map → p-e8cd1608.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-4517a3d4.entry.js.map → p-ef090656.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-bd8ec517.entry.js.map → p-f3b4c13d.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-ff38b9a5.entry.js.map → p-f710445f.entry.js.map} +0 -0
- /package/pn-market-web-components/{p-2e585ed5.entry.js.map → p-fcefe4a4.entry.js.map} +0 -0
- /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}
|