@postnord/pn-marketweb-components 1.0.21 → 1.0.26

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 (51) hide show
  1. package/cjs/loader.cjs.js +1 -1
  2. package/cjs/pn-filter-checkbox.cjs.entry.js +1 -0
  3. package/cjs/pn-language-selector_9.cjs.entry.js +31 -17
  4. package/cjs/pn-market-web-components.cjs.js +1 -1
  5. package/cjs/pn-marketweb-siteheader.cjs.entry.js +29 -8
  6. package/cjs/pn-site-footer_2.cjs.entry.js +2 -2
  7. package/collection/components/input/pn-filter-checkbox/pn-filter-checkbox.js +1 -0
  8. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.js +45 -6
  9. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-loginmanager.js +17 -12
  10. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader.js +77 -8
  11. package/collection/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader.stories.js +19 -4
  12. package/collection/components/navigation/pn-language-selector/pn-language-selector.js +19 -2
  13. package/collection/components/navigation/pn-mainnav/pn-mainnav-level.css +1 -0
  14. package/collection/components/navigation/pn-site-footer/pn-site-footer-col.css +6 -1
  15. package/collection/components/navigation/pn-site-footer/pn-site-footer.css +5 -0
  16. package/collection/components/navigation/pn-site-footer/site-footer.stories.js +78 -0
  17. package/custom-elements/index.js +66 -30
  18. package/esm/loader.js +1 -1
  19. package/esm/pn-filter-checkbox.entry.js +1 -0
  20. package/esm/pn-language-selector_9.entry.js +32 -18
  21. package/esm/pn-market-web-components.js +1 -1
  22. package/esm/pn-marketweb-siteheader.entry.js +29 -8
  23. package/esm/pn-site-footer_2.entry.js +2 -2
  24. package/esm-es5/loader.js +1 -1
  25. package/esm-es5/pn-filter-checkbox.entry.js +1 -1
  26. package/esm-es5/pn-language-selector_9.entry.js +1 -1
  27. package/esm-es5/pn-market-web-components.js +1 -1
  28. package/esm-es5/pn-marketweb-siteheader.entry.js +1 -1
  29. package/esm-es5/pn-site-footer_2.entry.js +1 -1
  30. package/package.json +2 -2
  31. package/pn-market-web-components/p-015a433e.entry.js +1 -0
  32. package/pn-market-web-components/p-25bdf3f8.system.js +1 -1
  33. package/pn-market-web-components/p-441c80e7.system.entry.js +1 -0
  34. package/pn-market-web-components/{p-8d62c46f.system.entry.js → p-4feb3557.system.entry.js} +1 -1
  35. package/pn-market-web-components/{p-c9e9854e.entry.js → p-68139d23.entry.js} +1 -1
  36. package/pn-market-web-components/p-88ab0d91.system.entry.js +1 -0
  37. package/pn-market-web-components/p-b27c3539.system.entry.js +1 -0
  38. package/pn-market-web-components/p-c2b8aa29.entry.js +1 -0
  39. package/pn-market-web-components/p-d7441208.entry.js +1 -0
  40. package/pn-market-web-components/pn-market-web-components.esm.js +1 -1
  41. package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-login.d.ts +3 -0
  42. package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader-loginmanager.d.ts +8 -3
  43. package/types/components/layout-components/pn-marketweb-siteheader/pn-marketweb-siteheader.d.ts +8 -1
  44. package/types/components/navigation/pn-language-selector/pn-language-selector.d.ts +2 -0
  45. package/types/components.d.ts +20 -0
  46. package/pn-market-web-components/p-2da203c9.system.entry.js +0 -1
  47. package/pn-market-web-components/p-363a27ff.entry.js +0 -1
  48. package/pn-market-web-components/p-582dbd9c.entry.js +0 -1
  49. package/pn-market-web-components/p-6299f92f.system.entry.js +0 -1
  50. package/pn-market-web-components/p-8c072330.entry.js +0 -1
  51. package/pn-market-web-components/p-ecfabe25.system.entry.js +0 -1
@@ -48,7 +48,8 @@ const PrimaryTemplate = ({ ...args }) => {
48
48
  hide-site-selector="false"
49
49
  hide-language-selector="false"
50
50
  hide-search="false"
51
- hide-login="false">
51
+ hide-login="false"
52
+ session-forward="true">
52
53
  </pn-marketweb-siteheader>
53
54
  <div style="height:120vh; margin:2em; max-width:calc(100vw - 1em);background:#ccc;border:1px solid #333;">
54
55
  Content that is higher than 100% viewport height
@@ -61,7 +62,7 @@ export const Primary = PrimaryTemplate.bind({});
61
62
  Primary.args = {
62
63
  market : "se",
63
64
  language: 'sv',
64
- endpoint: 'https://com-preproduction.postnord.com'
65
+ endpoint: 'https://com-integration.postnord.com'
65
66
  };
66
67
 
67
68
 
@@ -74,11 +75,25 @@ const MinimalOptionsTemplate = ({ ...args }) => {
74
75
  `;
75
76
  };
76
77
 
77
-
78
-
79
78
  export const MinimalOptions = MinimalOptionsTemplate.bind({});
80
79
  MinimalOptionsTemplate.args = {
81
80
  market : "",
82
81
  language: '',
83
82
  endpoint: ''
84
83
  };
84
+
85
+ const SPAModeOptionsTemplate = ({ ...args }) => {
86
+ return `
87
+ <div style="background:#ddd;min-height:100vh;">
88
+ <pn-marketweb-siteheader language="sv" spa-mode="true">
89
+ </pn-marketweb-siteheader>
90
+ </div>
91
+ `;
92
+ };
93
+
94
+ export const SPAModeOptions = SPAModeOptionsTemplate.bind({});
95
+ SPAModeOptions.args = {
96
+ market : "",
97
+ language: '',
98
+ endpoint: ''
99
+ };
@@ -1,4 +1,4 @@
1
- import { Component, Prop, h, State, Host, Watch, Element } from "@stencil/core";
1
+ import { Component, Prop, h, State, Host, Watch, Element, Event } from "@stencil/core";
2
2
  import { translations } from "./translations";
3
3
  export class PnlanguageSelector {
4
4
  constructor() {
@@ -41,6 +41,7 @@ export class PnlanguageSelector {
41
41
  onSetCurrentLanguage(option) {
42
42
  this.value = option.code;
43
43
  this.selectedLanguageName = option.name;
44
+ this.setLanguage.emit(this.value);
44
45
  }
45
46
  setTranslations() {
46
47
  if (translations[this.value]) {
@@ -77,7 +78,7 @@ export class PnlanguageSelector {
77
78
  static get properties() { return {
78
79
  "value": {
79
80
  "type": "string",
80
- "mutable": false,
81
+ "mutable": true,
81
82
  "complexType": {
82
83
  "original": "string",
83
84
  "resolved": "string",
@@ -99,6 +100,22 @@ export class PnlanguageSelector {
99
100
  "options": {},
100
101
  "i18n": {}
101
102
  }; }
103
+ static get events() { return [{
104
+ "method": "setLanguage",
105
+ "name": "setLanguage",
106
+ "bubbles": true,
107
+ "cancelable": true,
108
+ "composed": true,
109
+ "docs": {
110
+ "tags": [],
111
+ "text": ""
112
+ },
113
+ "complexType": {
114
+ "original": "any",
115
+ "resolved": "any",
116
+ "references": {}
117
+ }
118
+ }]; }
102
119
  static get elementRef() { return "hostElement"; }
103
120
  static get watchers() { return [{
104
121
  "propName": "value",
@@ -104,6 +104,7 @@ pn-mainnav-level [slot=top] {
104
104
  }
105
105
  [data-menu-currentlevel="2"] pn-mainnav-level [slot=footer] {
106
106
  display: none;
107
+ overscroll-behavior: contain;
107
108
  }
108
109
 
109
110
  .mainnav-level-header {
@@ -1,7 +1,12 @@
1
1
  pn-site-footer-col {
2
- min-width: 25%;
2
+ min-width: 20%;
3
3
  padding: 2.5em 1.5rem 0;
4
4
  }
5
+ @media screen and (min-width: 48em) {
6
+ pn-site-footer-col {
7
+ max-width: 25%;
8
+ }
9
+ }
5
10
  pn-site-footer-col ul {
6
11
  list-style-type: none;
7
12
  padding: 0;
@@ -31,7 +31,12 @@ pn-site-footer > div {
31
31
  background: #F3F2F2;
32
32
  }
33
33
 
34
+ .pn-sitefooter-top {
35
+ display: flex;
36
+ }
37
+
34
38
  .pn-sitefooter-cols {
39
+ align-self: center;
35
40
  display: flex;
36
41
  flex-flow: row wrap;
37
42
  margin: 0 auto;
@@ -85,3 +85,81 @@ export const Primary = Template.bind({});
85
85
  Primary.args = {
86
86
  logoUrl : "https://www.postnord.se"
87
87
  };
88
+
89
+
90
+
91
+ const TemplateNorwegian = ({ ...args }) => {
92
+ return `
93
+ <pn-site-footer url="${args.logoUrl}">
94
+ <pn-site-footer-col>
95
+ <h3>Finn oss</h3>
96
+ <ul></ul>
97
+ <div><a href="https://my.postnord.no/service-points?context=privat"
98
+ title="Søk etter pakkeleveringssted">
99
+ <pn-icon symbol="map-marker" color="blue700" class="pn-icon hydrated"
100
+ innerhtml="<svg viewBox=&quot;0 0 24 24&quot; fill=&quot;none&quot; xmlns=&quot;http://www.w3.org/2000/svg&quot;><path fill-rule=&quot;evenodd&quot; clip-rule=&quot;evenodd&quot; d=&quot;M12 2a8 8 0 00-6.857 12.124l.014.022 4.454 6.586a2.884 2.884 0 004.778 0l4.454-6.586.014-.022A8 8 0 0012 2zm-6 8a6 6 0 1111.156 3.07l-4.424 6.541a.883.883 0 01-1.464 0L6.844 13.07A5.968 5.968 0 016 10zm6-2.5a2.5 2.5 0 100 5 2.5 2.5 0 000-5z&quot; fill=&quot;#005D92&quot;/></svg>">
101
+ <svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
102
+ <path fill-rule="evenodd" clip-rule="evenodd"
103
+ d="M12 2a8 8 0 00-6.857 12.124l.014.022 4.454 6.586a2.884 2.884 0 004.778 0l4.454-6.586.014-.022A8 8 0 0012 2zm-6 8a6 6 0 1111.156 3.07l-4.424 6.541a.883.883 0 01-1.464 0L6.844 13.07A5.968 5.968 0 016 10zm6-2.5a2.5 2.5 0 100 5 2.5 2.5 0 000-5z"
104
+ fill="#005D92"></path>
105
+ </svg></pn-icon>Søk etter pakkeleveringssted
106
+ </a>
107
+ <p>&nbsp;</p>
108
+ <p>Besøksadresse:<br>Alfaset, 3. industrivei 25<br>0668 Oslo</p>
109
+ <p>Postadresse:<br>Postboks 6441 Etterstad<br>0605 Oslo</p>
110
+ </div>
111
+ </pn-site-footer-col>
112
+ <pn-site-footer-col>
113
+ <h3>Om oss</h3>
114
+ <ul>
115
+ <li><a href="/om-oss/jobb" title="Jobb og karriere">Jobb og karriere</a></li>
116
+ <li><a href="/nyheter" title="Nyheter og pressemeldinger">Nyheter og pressemeldinger</a></li>
117
+ <li><a href="/om-oss/avdelinger-og-butikker" title="Avdelinger og PostNord-butikker">Avdelinger og
118
+ PostNord-butikker</a></li>
119
+ <li><a href="/om-oss/samfunnsansvar" title="Samfunnsansvar">Samfunnsansvar</a></li>
120
+ </ul>
121
+ </pn-site-footer-col>
122
+ <pn-site-footer-col>
123
+ <h3>Kontakt oss</h3>
124
+ <ul>
125
+ <li><a href="/om-oss/media" title="Pressekontakter">Pressekontakter</a></li>
126
+ <li><a href="/tjenester-bedrift/tilbud" title="Bli kunde">Bli kunde</a></li>
127
+ </ul>
128
+ </pn-site-footer-col>
129
+ <pn-site-footer-col>
130
+ <h3>Følg oss</h3>
131
+ <ul class="social-media">
132
+ <li><a href="https://www.facebook.com/PostNordNorge" title="Facebook"><svg width="56" height="56"
133
+ viewBox="0 0 56 56" fill="none" xmlns="http://www.w3.org/2000/svg">
134
+ <circle cx="28" cy="28" r="28" fill="#005D92"></circle>
135
+ <path fill-rule="evenodd" clip-rule="evenodd"
136
+ d="M38.6754 16H17.3246C16.593 16 16 16.5929 16 17.3246V38.6754C16 39.407 16.593 40 17.3246 40H28.8191V30.706H25.6915V27.0839H28.8191V24.4127C28.8191 21.3128 30.7124 19.6248 33.4778 19.6248C34.8023 19.6248 35.9409 19.7235 36.2726 19.7675V23.0071L34.3547 23.008C32.8507 23.008 32.5596 23.7226 32.5596 24.7713V27.0839H36.1463L35.6793 30.706H32.5596V40H38.6754C39.407 40 40 39.407 40 38.6754V17.3246C40 16.5929 39.407 16 38.6754 16Z"
137
+ fill="white"></path>
138
+ </svg></a></li>
139
+ <li><a href="https://twitter.com/PostNordNorgeAS" title="Twitter"><svg width="56" height="56"
140
+ viewBox="0 0 56 56" fill="none" xmlns="http://www.w3.org/2000/svg">
141
+ <circle cx="28" cy="28" r="28" fill="#005D92"></circle>
142
+ <path fill-rule="evenodd" clip-rule="evenodd"
143
+ d="M41.3337 19.8587C40.3525 20.2871 39.2981 20.5766 38.1914 20.7068C39.321 20.0402 40.1884 18.9847 40.5969 17.7272C39.5399 18.3443 38.369 18.7925 37.1228 19.0341C36.1248 17.9874 34.7029 17.3333 33.1294 17.3333C30.1079 17.3333 27.6583 19.7446 27.6583 22.7188C27.6583 23.1409 27.7067 23.552 27.8 23.9461C23.253 23.7216 19.2218 21.5775 16.5234 18.3191C16.0525 19.1146 15.7827 20.0397 15.7827 21.0267C15.7827 22.8951 16.7486 24.5436 18.2166 25.5093C17.3197 25.4814 16.4762 25.2391 15.7385 24.8358C15.7381 24.8582 15.7381 24.8808 15.7381 24.9035C15.7381 27.5129 17.6239 29.6896 20.1267 30.1843C19.6676 30.3074 19.1843 30.3732 18.6853 30.3732C18.3328 30.3732 17.99 30.3395 17.656 30.2766C18.3522 32.4163 20.3726 33.9733 22.7667 34.0168C20.8943 35.4612 18.5353 36.3222 15.9721 36.3222C15.5305 36.3222 15.095 36.2968 14.667 36.2471C17.0881 37.7751 19.9639 38.6666 23.0535 38.6666C33.1166 38.6666 38.6195 30.4602 38.6195 23.3433C38.6195 23.1098 38.6142 22.8776 38.6037 22.6466C39.6725 21.8873 40.6002 20.9387 41.3337 19.8587Z"
144
+ fill="white"></path>
145
+ </svg></a></li>
146
+ <li><a href="https://www.linkedin.com/company/postnord-norge" title="LinkedIn "><svg width="56"
147
+ height="56" viewBox="0 0 56 56" fill="none" xmlns="http://www.w3.org/2000/svg">
148
+ <circle cx="28" cy="28" r="28" fill="#005D92"></circle>
149
+ <path
150
+ d="M37.5809 16H18.4191C17.0832 16 16 17.0747 16 18.399V37.601C16 38.9267 17.0832 40 18.4191 40H37.5809C38.9182 40 40 38.9253 40 37.601V18.399C40 17.0747 38.9182 16 37.5809 16ZM23.7013 34.9895H20.4725V24.7229H23.7013V34.9895ZM22.0653 23.4634C21.0462 23.4634 20.3874 22.7487 20.3874 21.8672C20.3874 20.965 21.0672 20.2711 22.1085 20.2711C23.1499 20.2711 23.7864 20.9636 23.8074 21.8672C23.8074 22.7501 23.1485 23.4634 22.0653 23.4634ZM35.4912 34.9895H32.2624V29.3002C32.2624 27.9772 31.7948 27.075 30.6264 27.075C29.7344 27.075 29.204 27.6834 28.9695 28.2711C28.8843 28.4808 28.8634 28.7746 28.8634 29.0685V34.9881H25.6332V27.9979C25.6332 26.7177 25.5913 25.6472 25.5481 24.7229H28.3525L28.5018 26.1507H28.566C28.9904 25.4789 30.0318 24.4925 31.7739 24.4925C33.8984 24.4925 35.4912 25.8996 35.4912 28.9222V34.9895Z"
151
+ fill="white"></path>
152
+ </svg></a></li>
153
+ </ul>
154
+ </pn-site-footer-col>
155
+ <div slot="bottom"><span>PostNord AS</span><span><a href="/cookies" title="PostNords cookiepolicy">PostNords
156
+ cookiepolicy</a><a href="/personvernerklaering"
157
+ title="Personvernerklæring">Personvernerklæring</a></span>
158
+ </div>
159
+ </pn-site-footer>
160
+ `;
161
+ };
162
+ export const Norwegian = TemplateNorwegian.bind({});
163
+ Primary.args = {
164
+ logoUrl : "https://www.postnord.no"
165
+ };
@@ -69,6 +69,7 @@ let PnFilterCheckbox$1 = class extends HTMLElement {
69
69
  let outsideInput = this.hostElement.querySelector("input.hidden-" + this.checkboxid);
70
70
  if (outsideInput) {
71
71
  outsideInput.value = (checkboxInput.checked) ? this.value : "";
72
+ outsideInput.dispatchEvent(new CustomEvent("change", { detail: outsideInput }));
72
73
  }
73
74
  }
74
75
  checkAndSetIndeterminateState() {
@@ -2403,6 +2404,7 @@ let PnlanguageSelector = class extends HTMLElement {
2403
2404
  constructor() {
2404
2405
  super();
2405
2406
  this.__registerHost();
2407
+ this.setLanguage = createEvent(this, "setLanguage", 7);
2406
2408
  /* Current language code */
2407
2409
  this.value = "";
2408
2410
  this.selectedLanguageName = "";
@@ -2442,6 +2444,7 @@ let PnlanguageSelector = class extends HTMLElement {
2442
2444
  onSetCurrentLanguage(option) {
2443
2445
  this.value = option.code;
2444
2446
  this.selectedLanguageName = option.name;
2447
+ this.setLanguage.emit(this.value);
2445
2448
  }
2446
2449
  setTranslations() {
2447
2450
  if (translations$5[this.value]) {
@@ -2613,7 +2616,7 @@ let PnMainnav$1 = class extends HTMLElement {
2613
2616
  static get style() { return pnMainnavCss; }
2614
2617
  };
2615
2618
 
2616
- const pnMainnavLevelCss = "pn-mainnav-level{display:block}pn-mainnav-level[data-level=\"1\"]{width:100%;right:0;overflow-y:scroll;overflow-x:hidden;-ms-flex:1;flex:1}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"1\"]{width:auto;overflow:initial}pn-mainnav-level[data-level=\"1\"]::-webkit-scrollbar{display:none}}pn-mainnav-level[data-level=\"2\"]{position:absolute;top:0;bottom:0;left:0;width:100vw;padding:0;background-color:#FFFFFF;z-index:1;-webkit-transform:translateX(100vw);transform:translateX(100vw);-webkit-transition:-webkit-transform 0.2s 0s;transition:-webkit-transform 0.2s 0s;transition:transform 0.2s 0s;transition:transform 0.2s 0s, -webkit-transform 0.2s 0s;-webkit-transition-property:visibility, -webkit-transform;transition-property:visibility, -webkit-transform;transition-property:transform, visibility;transition-property:transform, visibility, -webkit-transform;overflow:scroll;visibility:hidden}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"]{left:0;top:calc(100% + 1rem);bottom:auto;border-radius:1.6rem;width:auto;padding:1.6rem 1.6rem 0 1.6rem;-webkit-box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);-moz-box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);height:auto;z-index:3;display:none}pn-mainnav-level[data-level=\"2\"][data-menuitem-rightaligned=true]{right:0;left:unset}}@media screen and (max-height: 33.125em){pn-mainnav-level[data-level=\"2\"]{-ms-overflow-style:none;scrollbar-width:none}pn-mainnav-level[data-level=\"2\"]::-webkit-scrollbar{display:none}}pn-mainnav-level[data-level=\"2\"][aria-hidden=false]{-webkit-transform:translateX(0);transform:translateX(0);visibility:visible}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][aria-hidden=false]{display:block;overflow:visible}pn-mainnav-level[data-level=\"2\"][aria-hidden=false]:not([data-level-listcount=\"1\"]){display:grid;grid-template-columns:minmax(12em, 20em) 1fr;grid-template-rows:auto auto;gap:0px 1.6rem;grid-template-areas:\"top top\" \"left right\"}}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][data-level-alignment=left]{right:0;left:unset}}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][data-level-alignment=center]{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}}pn-mainnav-level[data-level=\"2\"] a{color:#005D92;text-decoration:none}pn-mainnav-level [slot=top]{display:-ms-flexbox;display:flex}@media screen and (min-width: 48em){pn-mainnav-level [slot=top]{display:none}}[data-menu-currentlevel=\"2\"] pn-mainnav-level [slot=footer]{display:none}.mainnav-level-header{grid-area:top}.mainnav-level-header>label{position:absolute;width:0.1rem;height:0.1rem;padding:0;margin:-0.1rem;overflow:hidden;clip:rect(0, 0, 0, 0);border:0;white-space:nowrap}.mainnav-level-header>button{display:block;position:relative;border:none;background-color:transparent;color:#005D92;padding:2.4rem 0 2.4rem 6.2rem;width:100%;text-align:left}@media screen and (min-width: 64em){.mainnav-level-header>button{display:none;speak:none}}.mainnav-level-header>button>pn-icon{speak:none;position:absolute;height:2.4rem;width:2.4rem;left:3rem;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}[data-level=\"2\"] .mainnav-level-header>pn-mainnav-link>a{font-size:2.4rem}";
2619
+ const pnMainnavLevelCss = "pn-mainnav-level{display:block}pn-mainnav-level[data-level=\"1\"]{width:100%;right:0;overflow-y:scroll;overflow-x:hidden;-ms-flex:1;flex:1}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"1\"]{width:auto;overflow:initial}pn-mainnav-level[data-level=\"1\"]::-webkit-scrollbar{display:none}}pn-mainnav-level[data-level=\"2\"]{position:absolute;top:0;bottom:0;left:0;width:100vw;padding:0;background-color:#FFFFFF;z-index:1;-webkit-transform:translateX(100vw);transform:translateX(100vw);-webkit-transition:-webkit-transform 0.2s 0s;transition:-webkit-transform 0.2s 0s;transition:transform 0.2s 0s;transition:transform 0.2s 0s, -webkit-transform 0.2s 0s;-webkit-transition-property:visibility, -webkit-transform;transition-property:visibility, -webkit-transform;transition-property:transform, visibility;transition-property:transform, visibility, -webkit-transform;overflow:scroll;visibility:hidden}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"]{left:0;top:calc(100% + 1rem);bottom:auto;border-radius:1.6rem;width:auto;padding:1.6rem 1.6rem 0 1.6rem;-webkit-box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);-moz-box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);box-shadow:0 0.06rem 0.18rem rgba(0, 0, 0, 0.1), 0 0.32rem 0.72rem rgba(0, 0, 0, 0.13);height:auto;z-index:3;display:none}pn-mainnav-level[data-level=\"2\"][data-menuitem-rightaligned=true]{right:0;left:unset}}@media screen and (max-height: 33.125em){pn-mainnav-level[data-level=\"2\"]{-ms-overflow-style:none;scrollbar-width:none}pn-mainnav-level[data-level=\"2\"]::-webkit-scrollbar{display:none}}pn-mainnav-level[data-level=\"2\"][aria-hidden=false]{-webkit-transform:translateX(0);transform:translateX(0);visibility:visible}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][aria-hidden=false]{display:block;overflow:visible}pn-mainnav-level[data-level=\"2\"][aria-hidden=false]:not([data-level-listcount=\"1\"]){display:grid;grid-template-columns:minmax(12em, 20em) 1fr;grid-template-rows:auto auto;gap:0px 1.6rem;grid-template-areas:\"top top\" \"left right\"}}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][data-level-alignment=left]{right:0;left:unset}}@media screen and (min-width: 64em){pn-mainnav-level[data-level=\"2\"][data-level-alignment=center]{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%)}}pn-mainnav-level[data-level=\"2\"] a{color:#005D92;text-decoration:none}pn-mainnav-level [slot=top]{display:-ms-flexbox;display:flex}@media screen and (min-width: 48em){pn-mainnav-level [slot=top]{display:none}}[data-menu-currentlevel=\"2\"] pn-mainnav-level [slot=footer]{display:none;-ms-scroll-chaining:none;overscroll-behavior:contain}.mainnav-level-header{grid-area:top}.mainnav-level-header>label{position:absolute;width:0.1rem;height:0.1rem;padding:0;margin:-0.1rem;overflow:hidden;clip:rect(0, 0, 0, 0);border:0;white-space:nowrap}.mainnav-level-header>button{display:block;position:relative;border:none;background-color:transparent;color:#005D92;padding:2.4rem 0 2.4rem 6.2rem;width:100%;text-align:left}@media screen and (min-width: 64em){.mainnav-level-header>button{display:none;speak:none}}.mainnav-level-header>button>pn-icon{speak:none;position:absolute;height:2.4rem;width:2.4rem;left:3rem;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%)}[data-level=\"2\"] .mainnav-level-header>pn-mainnav-link>a{font-size:2.4rem}";
2617
2620
 
2618
2621
  let PnMainnavLevel$1 = class extends HTMLElement {
2619
2622
  constructor() {
@@ -3162,6 +3165,10 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3162
3165
  this.hideSearch = false;
3163
3166
  /** Hides the login if set to true*/
3164
3167
  this.hideLogin = false;
3168
+ /** Forward session to backend */
3169
+ this.sessionForward = false;
3170
+ /** Event based only language switch */
3171
+ this.spaMode = false;
3165
3172
  this.gotData = false;
3166
3173
  this.fetchingData = false;
3167
3174
  // Menu state
@@ -3202,11 +3209,6 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3202
3209
  this.endpoint = "";
3203
3210
  }
3204
3211
  }
3205
- // TODO
3206
- //* Expose market and language attributes when changed internally
3207
- //* Business logic to select market and language depending on domains / html tag.
3208
- //* Property to stop language change from changeing url, throw an event instead.
3209
- //* Fetch new data when langauge or market is changed
3210
3212
  async init() {
3211
3213
  this.setTranslations();
3212
3214
  await this.fetchData();
@@ -3217,6 +3219,9 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3217
3219
  this.i18n = translations$2[this.language];
3218
3220
  }
3219
3221
  }
3222
+ onLanguageSelectorChange(e) {
3223
+ this.language = e.detail;
3224
+ }
3220
3225
  onLanguageChange() {
3221
3226
  this.setTranslations();
3222
3227
  this.changeLanguage.emit(this.language);
@@ -3236,9 +3241,12 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3236
3241
  const fetchUrl = `${endpointBase}${this.endpointPath}?market=${this.market}&language=${this.language}`;
3237
3242
  const response = await fetch(fetchUrl);
3238
3243
  const data = await response.json();
3239
- this.setStateFromData(data);
3244
+ await this.setStateFromData(data);
3240
3245
  }
3241
3246
  getLanguageVersionUrl(item) {
3247
+ if (this.spaMode) {
3248
+ return null;
3249
+ }
3242
3250
  const alternativeTag = document.querySelector(`link[rel="alternate"][hreflang="${item.twoLetterISOLanguageName}"]`);
3243
3251
  if (alternativeTag) {
3244
3252
  return alternativeTag.getAttribute('href');
@@ -3247,7 +3255,7 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3247
3255
  // Add trailing slash to domain if it's missing
3248
3256
  return siteUrl + ((siteUrl.lastIndexOf("/") !== siteUrl.length - 1) ? "/" : "") + item.twoLetterISOLanguageName;
3249
3257
  }
3250
- setStateFromData(data) {
3258
+ async setStateFromData(data) {
3251
3259
  if (typeof data !== "object") {
3252
3260
  console.warn('Data was not valid', data);
3253
3261
  }
@@ -3271,10 +3279,26 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3271
3279
  // Set language selector
3272
3280
  this.languageSelector = data.languageSelectorViewModel;
3273
3281
  this.loginDialog = data.loginViewModel;
3282
+ await this.spaModeAdjustments();
3274
3283
  this.gotData = true;
3275
3284
  this.fetchingData = true;
3276
3285
  window.setTimeout(() => { this.checkMenuOverflow(); }, 100);
3277
3286
  }
3287
+ async spaModeAdjustments() {
3288
+ if (!this.spaMode) {
3289
+ return;
3290
+ }
3291
+ return;
3292
+ }
3293
+ onLoginStateChange(e) {
3294
+ var _a, _b;
3295
+ if (((_a = e.detail) === null || _a === void 0 ? void 0 : _a.loggedIn) && ((_b = e.detail) === null || _b === void 0 ? void 0 : _b.token) && this.sessionForward) {
3296
+ try {
3297
+ fetch('/api/userprofile/sync?token=' + e.detail.token);
3298
+ }
3299
+ catch (e) { }
3300
+ }
3301
+ }
3278
3302
  promotedItemId(item) {
3279
3303
  return "promo-" + item.linkText.replace(/[^A-Za-z0-9.\\\/]/igm, "");
3280
3304
  }
@@ -3319,7 +3343,7 @@ let PnMarketwebSiteheader$1 = class extends HTMLElement {
3319
3343
  return (h("pn-mainnav-link", { name: childitem.name, href: childitem.href, target: (_a = childitem.linkTarget) !== null && _a !== void 0 ? _a : "_self", linkid: childitem.trackingId }));
3320
3344
  })), (item.promotedMenuItems && item.promotedMenuItems.length > 0) &&
3321
3345
  h("pn-mainnav-list", { heading: item.promotedMenuItemsHeader }, item.promotedMenuItems.map((childitem) => (h("pn-mainnav-link", { href: childitem.href, name: childitem.linkText, target: childitem.openInNewWindow ? "_blank" : "_self", linkid: this.promotedItemId(childitem) })))))));
3322
- })), h("div", { slot: "footer", class: "siteheader-menu-footer" }, (this.gotData && this.loginDialog && !this.hideLogin) && (h("pn-marketweb-siteheader-login", { loginDialog: this.loginDialog, endpoint: this.endpoint, i18n: this.i18n })), (this.gotData && ((_h = this.languageSelector) === null || _h === void 0 ? void 0 : _h.languages)) && !this.hideLanguageSelector &&
3346
+ })), h("div", { slot: "footer", class: "siteheader-menu-footer" }, (this.gotData && this.loginDialog && !this.hideLogin) && (h("pn-marketweb-siteheader-login", { emitEvents: false, loginDialog: this.loginDialog, endpoint: this.endpoint, i18n: this.i18n })), (this.gotData && ((_h = this.languageSelector) === null || _h === void 0 ? void 0 : _h.languages)) && !this.hideLanguageSelector &&
3323
3347
  h("pn-language-selector", { value: this.language }, this.languageSelector.languages.map(language => h("pn-language-selector-option", { name: language.nativeName, code: language.twoLetterISOLanguageName, selected: language.isCurrent, url: this.getLanguageVersionUrl(language) }))), !this.hideSiteSelector &&
3324
3348
  h("pn-site-selector", { language: this.language }, (this.gotData && ((_j = this.siteSelector) === null || _j === void 0 ? void 0 : _j.currentSiteTitle)) &&
3325
3349
  h("pn-site-selector-item", { heading: this.siteSelector.currentSiteTitle, description: this.siteSelector.currentSiteDescription }), (this.gotData && ((_k = this.siteSelector) === null || _k === void 0 ? void 0 : _k.siteSelections)) && this.siteSelector.siteSelections.map((site) => h("pn-site-selector-item", { heading: site.linkText, description: site.linkDescription, url: site.pageLink, newwindow: site.openInNewWindow })))), h("div", { slot: "top", class: "siteheader-menu-top" }, h("pn-marketweb-siteheader-search", { search: this.search, "hide-search": this.hideSearch, i18n: this.i18n }))))), h("pn-marketweb-siteheader-search", { search: this.search, "hide-search": this.hideSearch, "show-only-link": this.minimizeSearch, i18n: this.i18n })))));
@@ -3393,13 +3417,15 @@ class PNLoginManager {
3393
3417
  this.endpoint = options.endpoint ? options.endpoint : `${window.location.protocol}//${window.location.host}`;
3394
3418
  (_a = this.storagePrefix) !== null && _a !== void 0 ? _a : (this.storagePrefix = options.storagePrefix);
3395
3419
  }
3396
- init() {
3397
- this.checkParameters();
3398
- this.checkExpireTime();
3399
- if (this.store.get(this.keys.token) && !this.store.get(this.keys.user)) {
3400
- this.fetchUserInfo();
3420
+ init(checkParameters = true) {
3421
+ if (checkParameters) {
3422
+ this.checkParameters();
3423
+ this.checkExpireTime();
3424
+ if (this.store.get(this.keys.token) && !this.store.get(this.keys.user)) {
3425
+ this.fetchUserInfo();
3426
+ }
3427
+ this.loginStateChange();
3401
3428
  }
3402
- this.loginStateChange();
3403
3429
  }
3404
3430
  isLoggedIn() {
3405
3431
  const isLoggedIn = (this.store.get(this.keys.token) && this.store.get(this.keys.user)) ? true : false;
@@ -3443,10 +3469,11 @@ class PNLoginManager {
3443
3469
  const params = new URLSearchParams(window.location.search);
3444
3470
  if (params.get("oneTimeCode")) {
3445
3471
  const oneTimeCode = params.get("oneTimeCode");
3446
- this.getToken(oneTimeCode);
3447
- const currentHref = window.location.href;
3448
- const paramPrefix = (currentHref.indexOf('?oneTimeCode') !== -1) ? "?" : "&";
3449
- history.replaceState({}, document.querySelector('title').innerText, currentHref.replace(`${paramPrefix}oneTimeCode=${oneTimeCode}`, ''));
3472
+ this.exchangeToken(oneTimeCode).then(() => {
3473
+ const currentHref = window.location.href;
3474
+ const paramPrefix = (currentHref.indexOf('?oneTimeCode') !== -1) ? "?" : "&";
3475
+ history.replaceState({}, document.querySelector('title').innerText, currentHref.replace(`${paramPrefix}oneTimeCode=${oneTimeCode}`, ''));
3476
+ });
3450
3477
  }
3451
3478
  }
3452
3479
  async fetchUserInfo() {
@@ -3482,7 +3509,10 @@ class PNLoginManager {
3482
3509
  this.store.remove(this.keys.expire);
3483
3510
  this.store.remove(this.keys.expireDate);
3484
3511
  }
3485
- async getToken(oneTimeCode) {
3512
+ getToken() {
3513
+ return this.store.get(this.keys.token);
3514
+ }
3515
+ async exchangeToken(oneTimeCode) {
3486
3516
  this.clearUserData();
3487
3517
  const response = await fetch(`${this.getBaseUrl()}${this.endpoints.tokenExchangeEndpoint}?oneTimeCode=${oneTimeCode}`);
3488
3518
  const { token } = await response.json();
@@ -3523,8 +3553,10 @@ let PnMarketwebSiteheaderLogin$1 = class extends HTMLElement {
3523
3553
  constructor() {
3524
3554
  super();
3525
3555
  this.__registerHost();
3556
+ this.loginStateChange = createEvent(this, "loginStateChange", 7);
3526
3557
  /** Specifies which endpoint domain we should load from */
3527
3558
  this.endpoint = "";
3559
+ this.emitEvents = true;
3528
3560
  // Login dialog
3529
3561
  this.loginDialog = null;
3530
3562
  this.loginManager = null;
@@ -3533,12 +3565,13 @@ let PnMarketwebSiteheaderLogin$1 = class extends HTMLElement {
3533
3565
  }
3534
3566
  componentWillLoad() {
3535
3567
  this.loginManager = new PNLoginManager({ endpoint: this.endpoint, eventTarget: this.hostElement });
3568
+ this.hostElement["loginmanager"] = this.loginManager;
3569
+ this.hostElement.addEventListener(this.loginManager.events.loginstatechange, this.onLoginStateChange.bind(this));
3536
3570
  this.init();
3537
3571
  }
3538
3572
  async init() {
3539
3573
  this.toggleButtonText = this.loginDialog.loginMenuLinkText;
3540
- this.hostElement.addEventListener(this.loginManager.events.loginstatechange, this.onLoginStateChange.bind(this));
3541
- this.loginManager.init();
3574
+ this.loginManager.init(this.emitEvents);
3542
3575
  this.setToggleButtonText();
3543
3576
  }
3544
3577
  setToggleButtonText() {
@@ -3556,8 +3589,11 @@ let PnMarketwebSiteheaderLogin$1 = class extends HTMLElement {
3556
3589
  }
3557
3590
  }
3558
3591
  onLoginStateChange(e) {
3559
- this.loggedIn = e.detail;
3560
- this.setToggleButtonText();
3592
+ if (this.loggedIn !== e.detail && this.emitEvents) {
3593
+ this.loggedIn = e.detail;
3594
+ this.loginStateChange.emit({ loggedIn: this.loggedIn, token: this.loginManager.getToken() });
3595
+ this.setToggleButtonText();
3596
+ }
3561
3597
  }
3562
3598
  render() {
3563
3599
  var _a, _b, _c;
@@ -3575,7 +3611,7 @@ let PnMarketwebSiteheaderLogin$1 = class extends HTMLElement {
3575
3611
  :
3576
3612
  h("div", null, h("ul", null, this.loginDialog.loggedInLinks.map((link) => {
3577
3613
  const isLogoutLink = link.href.indexOf('logout');
3578
- const href = (isLogoutLink) ? this.loginManager.getLogoutUrl(link.href.replace('logout', '')) : link.href;
3614
+ const href = (isLogoutLink) ? this.loginManager.getLogoutUrl(link.href.replace('logout', '').replace('http://window.location.href/?', '').replace('https://window.location.href/?', '')) : link.href;
3579
3615
  return (h("li", null, h("a", Object.assign({ href: href }, (link.openInNewWindow && { target: '_blank' })), h("pn-button", { appearance: (link.primaryLinkApperance ? "dark" : "light"), onClick: () => {
3580
3616
  if (isLogoutLink) {
3581
3617
  this.loginManager.clearUserData();
@@ -4124,7 +4160,7 @@ let PnSidenavLink$1 = class extends HTMLElement {
4124
4160
  static get style() { return pnSidenavLinkCss; }
4125
4161
  };
4126
4162
 
4127
- const pnSiteFooterCss = "pn-site-footer{display:block;line-height:1.5}pn-site-footer a{color:#005D92}pn-site-footer a:hover{color:#0D234B;text-decoration:underline}pn-site-footer h3{font-size:2.4rem;margin-bottom:0.5rem;line-height:1.2}pn-site-footer p{font-size:1.6rem}pn-site-footer ul.social-media{display:-ms-flexbox;display:flex;-ms-flex-flow:row;flex-flow:row}pn-site-footer ul.social-media li{margin-right:1.6rem}pn-site-footer>svg{display:block}pn-site-footer>div{background:#F3F2F2}.pn-sitefooter-cols{display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap;margin:0 auto;max-width:90em}.pn-sitefooter-bottom [slot=bottom]{max-width:90em;margin:0 auto;padding:1.6rem 0;display:-ms-flexbox;display:flex;-ms-flex-flow:row;flex-flow:row;-ms-flex-pack:center;justify-content:center;-ms-flex-wrap:wrap;flex-wrap:wrap;border-top:1px solid #D3CECB;border-bottom:1px solid #D3CECB}.pn-sitefooter-bottom [slot=bottom] span,.pn-sitefooter-bottom [slot=bottom] a{line-height:2;margin:0 1.6rem;text-decoration:none}.pn-sitefooter-bottom [slot=bottom] li{line-height:2em;margin:0 1.6rem}.pn-sitefooter-logo{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;padding:3rem}.pn-sitefooter-logo svg{display:block;width:13.3rem;height:2.6rem}";
4163
+ const pnSiteFooterCss = "pn-site-footer{display:block;line-height:1.5}pn-site-footer a{color:#005D92}pn-site-footer a:hover{color:#0D234B;text-decoration:underline}pn-site-footer h3{font-size:2.4rem;margin-bottom:0.5rem;line-height:1.2}pn-site-footer p{font-size:1.6rem}pn-site-footer ul.social-media{display:-ms-flexbox;display:flex;-ms-flex-flow:row;flex-flow:row}pn-site-footer ul.social-media li{margin-right:1.6rem}pn-site-footer>svg{display:block}pn-site-footer>div{background:#F3F2F2}.pn-sitefooter-top{display:-ms-flexbox;display:flex}.pn-sitefooter-cols{-ms-flex-item-align:center;align-self:center;display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap;margin:0 auto;max-width:90em}.pn-sitefooter-bottom [slot=bottom]{max-width:90em;margin:0 auto;padding:1.6rem 0;display:-ms-flexbox;display:flex;-ms-flex-flow:row;flex-flow:row;-ms-flex-pack:center;justify-content:center;-ms-flex-wrap:wrap;flex-wrap:wrap;border-top:1px solid #D3CECB;border-bottom:1px solid #D3CECB}.pn-sitefooter-bottom [slot=bottom] span,.pn-sitefooter-bottom [slot=bottom] a{line-height:2;margin:0 1.6rem;text-decoration:none}.pn-sitefooter-bottom [slot=bottom] li{line-height:2em;margin:0 1.6rem}.pn-sitefooter-logo{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-pack:center;justify-content:center;padding:3rem}.pn-sitefooter-logo svg{display:block;width:13.3rem;height:2.6rem}";
4128
4164
 
4129
4165
  let PnSiteFooter$1 = class extends HTMLElement {
4130
4166
  constructor() {
@@ -4141,7 +4177,7 @@ let PnSiteFooter$1 = class extends HTMLElement {
4141
4177
  static get style() { return pnSiteFooterCss; }
4142
4178
  };
4143
4179
 
4144
- const pnSiteFooterColCss = "pn-site-footer-col{min-width:25%;padding:2.5em 1.5rem 0}pn-site-footer-col ul{list-style-type:none;padding:0;margin:0}pn-site-footer-col li{margin-bottom:1.6rem}pn-site-footer-col a{text-decoration:none;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}pn-site-footer-col p{margin-top:0;margin-bottom:1rem}";
4180
+ const pnSiteFooterColCss = "pn-site-footer-col{min-width:20%;padding:2.5em 1.5rem 0}@media screen and (min-width: 48em){pn-site-footer-col{max-width:25%}}pn-site-footer-col ul{list-style-type:none;padding:0;margin:0}pn-site-footer-col li{margin-bottom:1.6rem}pn-site-footer-col a{text-decoration:none;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}pn-site-footer-col p{margin-top:0;margin-bottom:1rem}";
4145
4181
 
4146
4182
  let PnSiteFooterCol$1 = class extends HTMLElement {
4147
4183
  constructor() {
@@ -4227,15 +4263,15 @@ const PnFilterCheckbox = /*@__PURE__*/proxyCustomElement(PnFilterCheckbox$1, [1,
4227
4263
  const PnFilterSearch = /*@__PURE__*/proxyCustomElement(PnFilterSearch$1, [1,"pn-filter-search",{"disabled":[4],"placeholder":[1],"inputid":[1],"name":[1],"autocomplete":[1],"value":[1],"label":[1],"loading":[4],"button":[1],"light":[4]},[[0,"input","inputHandler"]]]);
4228
4264
  const PnFindServiceAndPrice = /*@__PURE__*/proxyCustomElement(PnfindServiceAndPrice, [0,"pn-find-service-and-price",{"source":[1],"language":[1025],"market":[1025],"filteredItems":[32],"postagetype":[32],"weight":[32],"weightvalue":[32],"deliveryscope":[32],"sourceData":[32]}]);
4229
4265
  const PnFindServiceAndPriceResult = /*@__PURE__*/proxyCustomElement(PnfindServiceAndPriceResult, [0,"pn-find-service-and-price-result",{"item":[1040],"shownitems":[16],"weightText":[32]}]);
4230
- const PnLanguageSelector = /*@__PURE__*/proxyCustomElement(PnlanguageSelector, [4,"pn-language-selector",{"value":[513],"selectedLanguageName":[32],"options":[32],"i18n":[32]}]);
4266
+ const PnLanguageSelector = /*@__PURE__*/proxyCustomElement(PnlanguageSelector, [4,"pn-language-selector",{"value":[1537],"selectedLanguageName":[32],"options":[32],"i18n":[32]}]);
4231
4267
  const PnLanguageSelectorOption = /*@__PURE__*/proxyCustomElement(PnlanguageSelectorOption, [0,"pn-language-selector-option",{"name":[1],"code":[1],"url":[1],"selected":[4],"currentLanguage":[1,"current-language"]}]);
4232
4268
  const PnMainnav = /*@__PURE__*/proxyCustomElement(PnMainnav$1, [4,"pn-mainnav",{"market":[1],"language":[1],"navigationId":[1,"navigation-id"],"openMenu":[1028,"open-menu"],"navLabel":[1,"nav-label"]},[[0,"language","setLanguage"],[0,"market","setMarket"],[0,"menuLanguageChange","onLanguageChange"],[0,"setmenuopenstate","setMenuOpenState"],[0,"openMenuLevelChange","onOpenMenuLevelChange"]]]);
4233
4269
  const PnMainnavLevel = /*@__PURE__*/proxyCustomElement(PnMainnavLevel$1, [4,"pn-mainnav-level",{"level":[32],"levelId":[32],"isOpen":[32],"parentName":[32],"parentHref":[32],"parentLinkId":[32],"listCount":[32],"alignment":[32]}]);
4234
4270
  const PnMainnavLink = /*@__PURE__*/proxyCustomElement(PnMainnavLink$1, [4,"pn-mainnav-link",{"name":[1],"href":[1],"target":[1],"linkid":[1],"levelId":[32],"open":[32],"hasChildren":[32]}]);
4235
4271
  const PnMainnavList = /*@__PURE__*/proxyCustomElement(PnMainnavList$1, [4,"pn-mainnav-list",{"heading":[1],"linkCount":[32]}]);
4236
4272
  const PnMarketwebSitefooter = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheader$2, [0,"pn-marketweb-sitefooter",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"siteDefinition":[32],"footerContent":[32],"i18n":[32],"gotData":[32],"fetchingData":[32]}]);
4237
- const PnMarketwebSiteheader = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheader$1, [4,"pn-marketweb-siteheader",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"hideSiteSelector":[1540,"hide-site-selector"],"hideLanguageSelector":[1540,"hide-language-selector"],"hideSearch":[1540,"hide-search"],"hideLogin":[1540,"hide-login"],"i18n":[32],"gotData":[32],"fetchingData":[32],"menuItems":[32],"siteDefinition":[32],"search":[32],"siteSelector":[32],"languageSelector":[32],"loginDialog":[32],"minimizeSearch":[32]},[[9,"resize","handleResize"]]]);
4238
- const PnMarketwebSiteheaderLogin = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheaderLogin$1, [0,"pn-marketweb-siteheader-login",{"endpoint":[1],"i18n":[8,"i-1-8n"],"loginDialog":[1040],"loginManager":[32],"loggedIn":[32],"toggleButtonText":[32]}]);
4273
+ const PnMarketwebSiteheader = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheader$1, [4,"pn-marketweb-siteheader",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"hideSiteSelector":[1540,"hide-site-selector"],"hideLanguageSelector":[1540,"hide-language-selector"],"hideSearch":[1540,"hide-search"],"hideLogin":[1540,"hide-login"],"sessionForward":[4,"session-forward"],"spaMode":[4,"spa-mode"],"i18n":[32],"gotData":[32],"fetchingData":[32],"menuItems":[32],"siteDefinition":[32],"search":[32],"siteSelector":[32],"languageSelector":[32],"loginDialog":[32],"minimizeSearch":[32]},[[0,"setLanguage","onLanguageSelectorChange"],[0,"loginStateChange","onLoginStateChange"],[9,"resize","handleResize"]]]);
4274
+ const PnMarketwebSiteheaderLogin = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheaderLogin$1, [0,"pn-marketweb-siteheader-login",{"endpoint":[1],"i18n":[8,"i-1-8n"],"emitEvents":[4,"emit-events"],"loginDialog":[1040],"loginManager":[32],"loggedIn":[32],"toggleButtonText":[32]}]);
4239
4275
  const PnMarketwebSiteheaderSearch = /*@__PURE__*/proxyCustomElement(PnMarketwebSiteheaderSearch$1, [0,"pn-marketweb-siteheader-search",{"i18n":[8,"i-1-8n"],"showOnlyLink":[1028,"show-only-link"],"hideSearch":[1028,"hide-search"],"search":[1040]}]);
4240
4276
  const PnProductPricelist = /*@__PURE__*/proxyCustomElement(PnFindProductPricelist, [4,"pn-product-pricelist",{"source":[1],"language":[1025],"market":[1025],"productid":[1],"filteredItems":[32],"sourceData":[32],"gotData":[32],"loading":[32],"postagetype":[32],"weight":[32],"weightvalue":[32]}]);
4241
4277
  const PnProductPricelistResult = /*@__PURE__*/proxyCustomElement(PnFindProductPricelistResult, [0,"pn-product-pricelist-result",{"item":[1040],"shownitems":[16],"weightText":[32]}]);
package/esm/loader.js CHANGED
@@ -10,7 +10,7 @@ const patchEsm = () => {
10
10
  const defineCustomElements = (win, options) => {
11
11
  if (typeof window === 'undefined') return Promise.resolve();
12
12
  return patchEsm().then(() => {
13
- return bootstrapLazy([["pn-marketweb-siteheader",[[4,"pn-marketweb-siteheader",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"hideSiteSelector":[1540,"hide-site-selector"],"hideLanguageSelector":[1540,"hide-language-selector"],"hideSearch":[1540,"hide-search"],"hideLogin":[1540,"hide-login"],"i18n":[32],"gotData":[32],"fetchingData":[32],"menuItems":[32],"siteDefinition":[32],"search":[32],"siteSelector":[32],"languageSelector":[32],"loginDialog":[32],"minimizeSearch":[32]},[[9,"resize","handleResize"]]]]],["pn-find-service-and-price",[[0,"pn-find-service-and-price",{"source":[1],"language":[1025],"market":[1025],"filteredItems":[32],"postagetype":[32],"weight":[32],"weightvalue":[32],"deliveryscope":[32],"sourceData":[32]}]]],["pn-product-pricelist",[[4,"pn-product-pricelist",{"source":[1],"language":[1025],"market":[1025],"productid":[1],"filteredItems":[32],"sourceData":[32],"gotData":[32],"loading":[32],"postagetype":[32],"weight":[32],"weightvalue":[32]}]]],["pn-marketweb-sitefooter",[[0,"pn-marketweb-sitefooter",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"siteDefinition":[32],"footerContent":[32],"i18n":[32],"gotData":[32],"fetchingData":[32]}]]],["pn-filter-checkbox",[[1,"pn-filter-checkbox",{"value":[520],"name":[1],"checkboxid":[1],"disabled":[4],"checked":[4],"indeterminate":[1028]},[[0,"change","handlechange"]]]]],["pn-filter-search",[[1,"pn-filter-search",{"disabled":[4],"placeholder":[1],"inputid":[1],"name":[1],"autocomplete":[1],"value":[1],"label":[1],"loading":[4],"button":[1],"light":[4]},[[0,"input","inputHandler"]]]]],["pn-sidenav",[[4,"pn-sidenav",{"language":[1],"navLabel":[1,"nav-label"],"i18n":[32]},[[0,"language","setLanguage"],[0,"openSubMenuLevelChange","onOpenSubMenuLevelChange"]]]]],["pn-sidenav-level",[[4,"pn-sidenav-level",{"level":[32],"levelId":[32],"isOpen":[32],"parentName":[32],"parentHref":[32],"parentLinkId":[32],"alignment":[32]}]]],["pn-sidenav-link",[[4,"pn-sidenav-link",{"name":[1],"href":[1],"target":[1],"linkid":[1],"icon":[1],"current":[4],"levelId":[32],"open":[32],"hasChildren":[32]}]]],["pn-product-pricelist-result",[[0,"pn-product-pricelist-result",{"item":[1040],"shownitems":[16],"weightText":[32]}]]],["pn-choice-button_2",[[0,"pn-find-service-and-price-result",{"item":[1040],"shownitems":[16],"weightText":[32]}],[4,"pn-choice-button",{"value":[520],"name":[1],"choiceid":[1],"type":[1],"disabled":[4],"checked":[4],"indeterminate":[1028]},[[0,"change","handlechange"]]]]],["pn-site-footer_2",[[4,"pn-site-footer",{"url":[1]}],[4,"pn-site-footer-col"]]],["pn-mainnav-link",[[4,"pn-mainnav-link",{"name":[1],"href":[1],"target":[1],"linkid":[1],"levelId":[32],"open":[32],"hasChildren":[32]}]]],["pn-language-selector_9",[[4,"pn-mainnav-level",{"level":[32],"levelId":[32],"isOpen":[32],"parentName":[32],"parentHref":[32],"parentLinkId":[32],"listCount":[32],"alignment":[32]}],[4,"pn-language-selector",{"value":[513],"selectedLanguageName":[32],"options":[32],"i18n":[32]}],[0,"pn-language-selector-option",{"name":[1],"code":[1],"url":[1],"selected":[4],"currentLanguage":[1,"current-language"]}],[4,"pn-mainnav",{"market":[1],"language":[1],"navigationId":[1,"navigation-id"],"openMenu":[1028,"open-menu"],"navLabel":[1,"nav-label"]},[[0,"language","setLanguage"],[0,"market","setMarket"],[0,"menuLanguageChange","onLanguageChange"],[0,"setmenuopenstate","setMenuOpenState"],[0,"openMenuLevelChange","onOpenMenuLevelChange"]]],[4,"pn-mainnav-list",{"heading":[1],"linkCount":[32]}],[0,"pn-marketweb-siteheader-login",{"endpoint":[1],"i18n":[8,"i-1-8n"],"loginDialog":[1040],"loginManager":[32],"loggedIn":[32],"toggleButtonText":[32]}],[0,"pn-marketweb-siteheader-search",{"i18n":[8,"i-1-8n"],"showOnlyLink":[1028,"show-only-link"],"hideSearch":[1028,"hide-search"],"search":[1040]}],[4,"pn-site-selector",{"buttontext":[1537],"heading":[1537],"language":[1537],"i18n":[32]}],[0,"pn-site-selector-item",{"url":[1],"heading":[1],"description":[1],"newwindow":[4]}]]],["pn-product-tile_3",[[4,"pn-product-tile"],[0,"pn-product-tile-info",{"label":[1],"text":[1],"icon":[1]}],[0,"pn-product-tile-price",{"label":[1],"amount":[1],"currency":[1],"url":[1]}]]]], options);
13
+ return bootstrapLazy([["pn-marketweb-siteheader",[[4,"pn-marketweb-siteheader",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"hideSiteSelector":[1540,"hide-site-selector"],"hideLanguageSelector":[1540,"hide-language-selector"],"hideSearch":[1540,"hide-search"],"hideLogin":[1540,"hide-login"],"sessionForward":[4,"session-forward"],"spaMode":[4,"spa-mode"],"i18n":[32],"gotData":[32],"fetchingData":[32],"menuItems":[32],"siteDefinition":[32],"search":[32],"siteSelector":[32],"languageSelector":[32],"loginDialog":[32],"minimizeSearch":[32]},[[0,"setLanguage","onLanguageSelectorChange"],[0,"loginStateChange","onLoginStateChange"],[9,"resize","handleResize"]]]]],["pn-find-service-and-price",[[0,"pn-find-service-and-price",{"source":[1],"language":[1025],"market":[1025],"filteredItems":[32],"postagetype":[32],"weight":[32],"weightvalue":[32],"deliveryscope":[32],"sourceData":[32]}]]],["pn-product-pricelist",[[4,"pn-product-pricelist",{"source":[1],"language":[1025],"market":[1025],"productid":[1],"filteredItems":[32],"sourceData":[32],"gotData":[32],"loading":[32],"postagetype":[32],"weight":[32],"weightvalue":[32]}]]],["pn-marketweb-sitefooter",[[0,"pn-marketweb-sitefooter",{"market":[1537],"language":[1537],"environment":[1537],"endpoint":[1],"siteDefinition":[32],"footerContent":[32],"i18n":[32],"gotData":[32],"fetchingData":[32]}]]],["pn-filter-checkbox",[[1,"pn-filter-checkbox",{"value":[520],"name":[1],"checkboxid":[1],"disabled":[4],"checked":[4],"indeterminate":[1028]},[[0,"change","handlechange"]]]]],["pn-filter-search",[[1,"pn-filter-search",{"disabled":[4],"placeholder":[1],"inputid":[1],"name":[1],"autocomplete":[1],"value":[1],"label":[1],"loading":[4],"button":[1],"light":[4]},[[0,"input","inputHandler"]]]]],["pn-sidenav",[[4,"pn-sidenav",{"language":[1],"navLabel":[1,"nav-label"],"i18n":[32]},[[0,"language","setLanguage"],[0,"openSubMenuLevelChange","onOpenSubMenuLevelChange"]]]]],["pn-sidenav-level",[[4,"pn-sidenav-level",{"level":[32],"levelId":[32],"isOpen":[32],"parentName":[32],"parentHref":[32],"parentLinkId":[32],"alignment":[32]}]]],["pn-sidenav-link",[[4,"pn-sidenav-link",{"name":[1],"href":[1],"target":[1],"linkid":[1],"icon":[1],"current":[4],"levelId":[32],"open":[32],"hasChildren":[32]}]]],["pn-product-pricelist-result",[[0,"pn-product-pricelist-result",{"item":[1040],"shownitems":[16],"weightText":[32]}]]],["pn-choice-button_2",[[0,"pn-find-service-and-price-result",{"item":[1040],"shownitems":[16],"weightText":[32]}],[4,"pn-choice-button",{"value":[520],"name":[1],"choiceid":[1],"type":[1],"disabled":[4],"checked":[4],"indeterminate":[1028]},[[0,"change","handlechange"]]]]],["pn-site-footer_2",[[4,"pn-site-footer",{"url":[1]}],[4,"pn-site-footer-col"]]],["pn-mainnav-link",[[4,"pn-mainnav-link",{"name":[1],"href":[1],"target":[1],"linkid":[1],"levelId":[32],"open":[32],"hasChildren":[32]}]]],["pn-language-selector_9",[[4,"pn-mainnav-level",{"level":[32],"levelId":[32],"isOpen":[32],"parentName":[32],"parentHref":[32],"parentLinkId":[32],"listCount":[32],"alignment":[32]}],[4,"pn-language-selector",{"value":[1537],"selectedLanguageName":[32],"options":[32],"i18n":[32]}],[0,"pn-language-selector-option",{"name":[1],"code":[1],"url":[1],"selected":[4],"currentLanguage":[1,"current-language"]}],[4,"pn-mainnav",{"market":[1],"language":[1],"navigationId":[1,"navigation-id"],"openMenu":[1028,"open-menu"],"navLabel":[1,"nav-label"]},[[0,"language","setLanguage"],[0,"market","setMarket"],[0,"menuLanguageChange","onLanguageChange"],[0,"setmenuopenstate","setMenuOpenState"],[0,"openMenuLevelChange","onOpenMenuLevelChange"]]],[4,"pn-mainnav-list",{"heading":[1],"linkCount":[32]}],[0,"pn-marketweb-siteheader-login",{"endpoint":[1],"i18n":[8,"i-1-8n"],"emitEvents":[4,"emit-events"],"loginDialog":[1040],"loginManager":[32],"loggedIn":[32],"toggleButtonText":[32]}],[0,"pn-marketweb-siteheader-search",{"i18n":[8,"i-1-8n"],"showOnlyLink":[1028,"show-only-link"],"hideSearch":[1028,"hide-search"],"search":[1040]}],[4,"pn-site-selector",{"buttontext":[1537],"heading":[1537],"language":[1537],"i18n":[32]}],[0,"pn-site-selector-item",{"url":[1],"heading":[1],"description":[1],"newwindow":[4]}]]],["pn-product-tile_3",[[4,"pn-product-tile"],[0,"pn-product-tile-info",{"label":[1],"text":[1],"icon":[1]}],[0,"pn-product-tile-price",{"label":[1],"amount":[1],"currency":[1],"url":[1]}]]]], options);
14
14
  });
15
15
  };
16
16
 
@@ -33,6 +33,7 @@ let PnFilterCheckbox = class {
33
33
  let outsideInput = this.hostElement.querySelector("input.hidden-" + this.checkboxid);
34
34
  if (outsideInput) {
35
35
  outsideInput.value = (checkboxInput.checked) ? this.value : "";
36
+ outsideInput.dispatchEvent(new CustomEvent("change", { detail: outsideInput }));
36
37
  }
37
38
  }
38
39
  checkAndSetIndeterminateState() {