weg-shared-layout 0.0.13 → 0.0.15

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 (52) hide show
  1. package/dist/cjs/{index-CmiaQ_Dj.js → index-CC8e1qRm.js} +112 -0
  2. package/dist/cjs/loader.cjs.js +2 -2
  3. package/dist/cjs/my-component.cjs.entry.js +1 -1
  4. package/dist/cjs/weg-footer_2.cjs.entry.js +438 -0
  5. package/dist/cjs/weg-shared-layout.cjs.js +2 -2
  6. package/dist/collection/collection-manifest.json +2 -1
  7. package/dist/collection/components/weg-footer/weg-footer.css +62 -32
  8. package/dist/collection/components/weg-footer/weg-footer.js +24 -38
  9. package/dist/collection/components/weg-header/logo-data.js +2 -0
  10. package/dist/collection/components/weg-header/weg-header.cmp.test.js +77 -0
  11. package/dist/collection/components/weg-header/weg-header.css +327 -0
  12. package/dist/collection/components/weg-header/weg-header.js +344 -0
  13. package/dist/collection/styles/shared.css +49 -0
  14. package/dist/collection/types/layout-data.js +1 -0
  15. package/dist/collection/utils/layout.js +33 -0
  16. package/dist/collection/utils/layout.unit.test.js +36 -0
  17. package/dist/components/index.js +1 -1
  18. package/dist/components/my-component.js +1 -1
  19. package/dist/components/p-CtYuWNO6.js +1 -0
  20. package/dist/components/p-DbIEJ3IT.js +1 -0
  21. package/dist/components/weg-footer.js +1 -1
  22. package/dist/components/weg-header.d.ts +11 -0
  23. package/dist/components/weg-header.js +1 -0
  24. package/dist/esm/{index-QiJxC4Ow.js → index-D8pmhPiH.js} +111 -1
  25. package/dist/esm/loader.js +3 -3
  26. package/dist/esm/my-component.entry.js +1 -1
  27. package/dist/esm/weg-footer_2.entry.js +435 -0
  28. package/dist/esm/weg-shared-layout.js +3 -3
  29. package/dist/types/components/weg-footer/weg-footer.d.ts +3 -12
  30. package/dist/types/components/weg-header/logo-data.d.ts +2 -0
  31. package/dist/types/components/weg-header/weg-header.cmp.test.d.ts +1 -0
  32. package/dist/types/components/weg-header/weg-header.d.ts +56 -0
  33. package/dist/types/components.d.ts +58 -2
  34. package/dist/types/types/layout-data.d.ts +42 -0
  35. package/dist/types/utils/layout.d.ts +4 -0
  36. package/dist/types/utils/layout.unit.test.d.ts +1 -0
  37. package/dist/weg-shared-layout/p-D8pmhPiH.js +2 -0
  38. package/dist/weg-shared-layout/{p-d1addb13.entry.js → p-d61033bd.entry.js} +1 -1
  39. package/dist/weg-shared-layout/p-eaf953a4.entry.js +1 -0
  40. package/dist/weg-shared-layout/weg-shared-layout.esm.js +1 -1
  41. package/docs/angular.md +66 -18
  42. package/docs/nextjs.md +145 -111
  43. package/docs/react.md +123 -59
  44. package/docs/vanilla.md +99 -3
  45. package/package.json +15 -10
  46. package/readme.md +43 -4
  47. package/src/assets/dummy-data.json +97 -11
  48. package/dist/cjs/weg-footer.cjs.entry.js +0 -170
  49. package/dist/components/p-BTQYW5OR.js +0 -1
  50. package/dist/esm/weg-footer.entry.js +0 -168
  51. package/dist/weg-shared-layout/p-99843bbd.entry.js +0 -1
  52. package/dist/weg-shared-layout/p-QiJxC4Ow.js +0 -2
@@ -0,0 +1,56 @@
1
+ import { EventEmitter } from '../../stencil-public-runtime';
2
+ import type { LayoutData, LayoutHeaderAuthAction } from '../../types/layout-data';
3
+ export declare class WegHeader {
4
+ /**
5
+ * Layout payload, supplied by the host application.
6
+ *
7
+ * Expected shape:
8
+ * ```json
9
+ * {
10
+ * "header": {
11
+ * "dropdowns": [{ "label": "Find a job", "items": [{ "label": "...", "href": "..." }] }],
12
+ * "links": [{ "label": "Career advice", "href": "/career-advice" }],
13
+ * "signIn": { "label": "Sign in", "href": "/account/login" },
14
+ * "signOut": { "label": "Sign out" }
15
+ * }
16
+ * }
17
+ * ```
18
+ */
19
+ layout?: LayoutData | string;
20
+ /**
21
+ * When true, the auth control shows `header.signOut` instead of `header.signIn`.
22
+ * Set by the host app based on session state.
23
+ */
24
+ signedIn: boolean;
25
+ /**
26
+ * Fired when the user clicks Sign in or Sign out.
27
+ * Call `event.preventDefault()` in the host to handle navigation/logout yourself.
28
+ */
29
+ wegAuthClick: EventEmitter<{
30
+ action: LayoutHeaderAuthAction;
31
+ }>;
32
+ el: HTMLElement;
33
+ private resolved;
34
+ private menuOpen;
35
+ private openDropdown;
36
+ private expandedSection;
37
+ private boundHandleDocumentClick;
38
+ private resolve;
39
+ componentWillLoad(): void;
40
+ connectedCallback(): void;
41
+ disconnectedCallback(): void;
42
+ protected watchLayout(): void;
43
+ handleKeyDown(event: KeyboardEvent): void;
44
+ private handleDocumentClick;
45
+ private toggleDropdown;
46
+ private toggleAccordion;
47
+ private openMenu;
48
+ private closeMenu;
49
+ private getAuthControl;
50
+ private handleAuthClick;
51
+ private renderAuthControl;
52
+ private renderDesktop;
53
+ private renderMobileBar;
54
+ private renderMobileOverlay;
55
+ render(): any;
56
+ }
@@ -5,6 +5,8 @@
5
5
  * It contains typing information for all components that exist in this project.
6
6
  */
7
7
  import { HTMLStencilElement, JSXBase } from "./stencil-public-runtime";
8
+ import { LayoutData, LayoutHeaderAuthAction } from "./types/layout-data";
9
+ export { LayoutData, LayoutHeaderAuthAction } from "./types/layout-data";
8
10
  export namespace Components {
9
11
  interface MyComponent {
10
12
  /**
@@ -22,10 +24,25 @@ export namespace Components {
22
24
  }
23
25
  interface WegFooter {
24
26
  /**
25
- * Layout payload, supplied by the host application. In JS / framework templates, pass the object directly (e.g. Angular `[layout]="layoutData"`, React `layout={layoutData}`, vanilla `el.layout = layoutData`). In plain HTML, pass the same JSON as a string on the `layout` attribute. Expected shape: ```json { "footer": { "social": [{ "platform": "LinkedIn", "href": "https://..." }], "standardLinks": [{ "label": "About Us", "href": "/about" }], "credits": "...", "copyright": "..." } } ```
27
+ * Layout payload, supplied by the host application. In JS / framework templates, pass the object directly (e.g. Angular `[layout]="layoutData"`, React `layout={layoutData}`, vanilla `el.layout = layoutData`). In plain HTML, pass the same JSON as a string on the `layout` attribute. Expected shape: ```json { "footer": { "social": [{ "platform": "LinkedIn", "href": "https://..." }], "columns": [{ "links": [{ "label": "About Us", "href": "/about" }] }], "credits": "...", "copyright": "..." } } ```
26
28
  */
27
29
  "layout"?: LayoutData | string;
28
30
  }
31
+ interface WegHeader {
32
+ /**
33
+ * Layout payload, supplied by the host application. Expected shape: ```json { "header": { "dropdowns": [{ "label": "Find a job", "items": [{ "label": "...", "href": "..." }] }], "links": [{ "label": "Career advice", "href": "/career-advice" }], "signIn": { "label": "Sign in", "href": "/account/login" }, "signOut": { "label": "Sign out" } } } ```
34
+ */
35
+ "layout"?: LayoutData | string;
36
+ /**
37
+ * When true, the auth control shows `header.signOut` instead of `header.signIn`. Set by the host app based on session state.
38
+ * @default false
39
+ */
40
+ "signedIn": boolean;
41
+ }
42
+ }
43
+ export interface WegHeaderCustomEvent<T> extends CustomEvent<T> {
44
+ detail: T;
45
+ target: HTMLWegHeaderElement;
29
46
  }
30
47
  declare global {
31
48
  interface HTMLMyComponentElement extends Components.MyComponent, HTMLStencilElement {
@@ -40,9 +57,27 @@ declare global {
40
57
  prototype: HTMLWegFooterElement;
41
58
  new (): HTMLWegFooterElement;
42
59
  };
60
+ interface HTMLWegHeaderElementEventMap {
61
+ "wegAuthClick": { action: LayoutHeaderAuthAction };
62
+ }
63
+ interface HTMLWegHeaderElement extends Components.WegHeader, HTMLStencilElement {
64
+ addEventListener<K extends keyof HTMLWegHeaderElementEventMap>(type: K, listener: (this: HTMLWegHeaderElement, ev: WegHeaderCustomEvent<HTMLWegHeaderElementEventMap[K]>) => any, options?: boolean | AddEventListenerOptions): void;
65
+ addEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
66
+ addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
67
+ addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
68
+ removeEventListener<K extends keyof HTMLWegHeaderElementEventMap>(type: K, listener: (this: HTMLWegHeaderElement, ev: WegHeaderCustomEvent<HTMLWegHeaderElementEventMap[K]>) => any, options?: boolean | EventListenerOptions): void;
69
+ removeEventListener<K extends keyof DocumentEventMap>(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
70
+ removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
71
+ removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
72
+ }
73
+ var HTMLWegHeaderElement: {
74
+ prototype: HTMLWegHeaderElement;
75
+ new (): HTMLWegHeaderElement;
76
+ };
43
77
  interface HTMLElementTagNameMap {
44
78
  "my-component": HTMLMyComponentElement;
45
79
  "weg-footer": HTMLWegFooterElement;
80
+ "weg-header": HTMLWegHeaderElement;
46
81
  }
47
82
  }
48
83
  declare namespace LocalJSX {
@@ -62,10 +97,25 @@ declare namespace LocalJSX {
62
97
  }
63
98
  interface WegFooter {
64
99
  /**
65
- * Layout payload, supplied by the host application. In JS / framework templates, pass the object directly (e.g. Angular `[layout]="layoutData"`, React `layout={layoutData}`, vanilla `el.layout = layoutData`). In plain HTML, pass the same JSON as a string on the `layout` attribute. Expected shape: ```json { "footer": { "social": [{ "platform": "LinkedIn", "href": "https://..." }], "standardLinks": [{ "label": "About Us", "href": "/about" }], "credits": "...", "copyright": "..." } } ```
100
+ * Layout payload, supplied by the host application. In JS / framework templates, pass the object directly (e.g. Angular `[layout]="layoutData"`, React `layout={layoutData}`, vanilla `el.layout = layoutData`). In plain HTML, pass the same JSON as a string on the `layout` attribute. Expected shape: ```json { "footer": { "social": [{ "platform": "LinkedIn", "href": "https://..." }], "columns": [{ "links": [{ "label": "About Us", "href": "/about" }] }], "credits": "...", "copyright": "..." } } ```
66
101
  */
67
102
  "layout"?: LayoutData | string;
68
103
  }
104
+ interface WegHeader {
105
+ /**
106
+ * Layout payload, supplied by the host application. Expected shape: ```json { "header": { "dropdowns": [{ "label": "Find a job", "items": [{ "label": "...", "href": "..." }] }], "links": [{ "label": "Career advice", "href": "/career-advice" }], "signIn": { "label": "Sign in", "href": "/account/login" }, "signOut": { "label": "Sign out" } } } ```
107
+ */
108
+ "layout"?: LayoutData | string;
109
+ /**
110
+ * Fired when the user clicks Sign in or Sign out. Call `event.preventDefault()` in the host to handle navigation/logout yourself.
111
+ */
112
+ "onWegAuthClick"?: (event: WegHeaderCustomEvent<{ action: LayoutHeaderAuthAction }>) => void;
113
+ /**
114
+ * When true, the auth control shows `header.signOut` instead of `header.signIn`. Set by the host app based on session state.
115
+ * @default false
116
+ */
117
+ "signedIn"?: boolean;
118
+ }
69
119
 
70
120
  interface MyComponentAttributes {
71
121
  "first": string;
@@ -75,10 +125,15 @@ declare namespace LocalJSX {
75
125
  interface WegFooterAttributes {
76
126
  "layout": LayoutData | string;
77
127
  }
128
+ interface WegHeaderAttributes {
129
+ "layout": LayoutData | string;
130
+ "signedIn": boolean;
131
+ }
78
132
 
79
133
  interface IntrinsicElements {
80
134
  "my-component": Omit<MyComponent, keyof MyComponentAttributes> & { [K in keyof MyComponent & keyof MyComponentAttributes]?: MyComponent[K] } & { [K in keyof MyComponent & keyof MyComponentAttributes as `attr:${K}`]?: MyComponentAttributes[K] } & { [K in keyof MyComponent & keyof MyComponentAttributes as `prop:${K}`]?: MyComponent[K] };
81
135
  "weg-footer": Omit<WegFooter, keyof WegFooterAttributes> & { [K in keyof WegFooter & keyof WegFooterAttributes]?: WegFooter[K] } & { [K in keyof WegFooter & keyof WegFooterAttributes as `attr:${K}`]?: WegFooterAttributes[K] } & { [K in keyof WegFooter & keyof WegFooterAttributes as `prop:${K}`]?: WegFooter[K] };
136
+ "weg-header": Omit<WegHeader, keyof WegHeaderAttributes> & { [K in keyof WegHeader & keyof WegHeaderAttributes]?: WegHeader[K] } & { [K in keyof WegHeader & keyof WegHeaderAttributes as `attr:${K}`]?: WegHeaderAttributes[K] } & { [K in keyof WegHeader & keyof WegHeaderAttributes as `prop:${K}`]?: WegHeader[K] };
82
137
  }
83
138
  }
84
139
  export { LocalJSX as JSX };
@@ -87,6 +142,7 @@ declare module "@stencil/core" {
87
142
  interface IntrinsicElements {
88
143
  "my-component": LocalJSX.IntrinsicElements["my-component"] & JSXBase.HTMLAttributes<HTMLMyComponentElement>;
89
144
  "weg-footer": LocalJSX.IntrinsicElements["weg-footer"] & JSXBase.HTMLAttributes<HTMLWegFooterElement>;
145
+ "weg-header": LocalJSX.IntrinsicElements["weg-header"] & JSXBase.HTMLAttributes<HTMLWegHeaderElement>;
90
146
  }
91
147
  }
92
148
  }
@@ -0,0 +1,42 @@
1
+ export type LayoutLink = {
2
+ label: string;
3
+ href: string;
4
+ };
5
+ export type LayoutHeaderLink = LayoutLink;
6
+ export type LayoutHeaderSignOutLink = {
7
+ label: string;
8
+ href?: string;
9
+ };
10
+ export type LayoutHeaderDropdown = {
11
+ label: string;
12
+ items: LayoutHeaderLink[];
13
+ };
14
+ export type LayoutHeaderData = {
15
+ dropdowns?: LayoutHeaderDropdown[];
16
+ links?: LayoutHeaderLink[];
17
+ signIn?: LayoutHeaderLink;
18
+ signOut?: LayoutHeaderSignOutLink;
19
+ };
20
+ export type LayoutHeaderAuthAction = 'sign-in' | 'sign-out';
21
+ export type LayoutFooterLink = LayoutLink;
22
+ export type LayoutFooterColumn = {
23
+ links: LayoutFooterLink[];
24
+ };
25
+ export type LayoutFooterSocialPlatform = 'LinkedIn' | 'Instagram' | 'TikTok' | 'YouTube';
26
+ export type LayoutFooterSocialLink = {
27
+ platform: LayoutFooterSocialPlatform;
28
+ href: string;
29
+ };
30
+ /**
31
+ * Layout payload accepted by `<weg-header>` and `<weg-footer>`.
32
+ * Matches `GET /api/layout` shape from the WEG CMS.
33
+ */
34
+ export type LayoutData = {
35
+ header?: Partial<LayoutHeaderData>;
36
+ footer?: Partial<{
37
+ social: unknown;
38
+ columns: unknown;
39
+ credits: unknown;
40
+ copyright: unknown;
41
+ }>;
42
+ };
@@ -0,0 +1,4 @@
1
+ import type { LayoutLink } from '../types/layout-data';
2
+ export declare function parseJsonProp(value: unknown): unknown;
3
+ export declare function isNonEmptyString(value: unknown): value is string;
4
+ export declare function normalizeLinks(input: unknown): LayoutLink[];
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,2 @@
1
+ function t(t,e,n){const o="undefined"!=typeof HTMLElement?HTMLElement.prototype:null;for(;t&&t!==o;){const o=Object.getOwnPropertyDescriptor(t,e);if(o&&(!n||o.get))return o;t=Object.getPrototypeOf(t)}}var e,n=(e,n)=>{var o;Object.entries(null!=(o=n.o.t)?o:{}).map((([o,[l]])=>{if(31&l||32&l){const l=e[o],i=t(Object.getPrototypeOf(e),o,!0)||Object.getOwnPropertyDescriptor(e,o);i&&Object.defineProperty(e,o,{get(){return i.get.call(this)},set(t){i.set.call(this,t)},configurable:!0,enumerable:!0}),n.l.has(o)?e[o]=n.l.get(o):void 0!==l&&(e[o]=l)}}))},o=t=>{if(t.__stencil__getHostRef)return t.__stencil__getHostRef()},l=(t,e)=>{e&&(t.__stencil__getHostRef=()=>e,e.i=t,512&e.o.u&&n(t,e))},i=(t,e)=>e in t,s=(t,e)=>(0,console.error)(t,e),r=new Map,c=new Map,u="http://www.w3.org/1999/xlink",f="undefined"!=typeof window?window:{},a={u:0,h:"",jmp:t=>t(),raf:t=>requestAnimationFrame(t),ael:(t,e,n,o)=>t.addEventListener(e,n,o),rel:(t,e,n,o)=>t.removeEventListener(e,n,o),ce:(t,e)=>new CustomEvent(t,e)},d=t=>Promise.resolve(t),h=(()=>{try{return!!f.document.adoptedStyleSheets&&(new CSSStyleSheet,"function"==typeof(new CSSStyleSheet).replaceSync)}catch(t){}return!1})(),p=!!h&&(()=>!!f.document&&Object.getOwnPropertyDescriptor(f.document.adoptedStyleSheets,"length").writable)(),m=!1,v=[],y=[],b=(t,e)=>n=>{t.push(n),m||(m=!0,e&&4&a.u?g($):a.raf($))},w=t=>{for(let e=0;e<t.length;e++)try{t[e](performance.now())}catch(t){s(t)}t.length=0},$=()=>{w(v),w(y),(m=v.length>0)&&a.raf($)},g=t=>d().then(t),j=b(y,!0);function O(){const t=this.attachShadow({mode:"open"});void 0===e&&(e=null),e&&(p?t.adoptedStyleSheets.push(e):t.adoptedStyleSheets=[...t.adoptedStyleSheets,e])}function S(t){var e,n,o;return null!=(o=null==(n=null==(e=t.head)?void 0:e.querySelector('meta[name="csp-nonce"]'))?void 0:n.getAttribute("content"))?o:void 0}var k,E=new WeakMap,M=t=>"sc-"+t.p,C=t=>"object"==(t=typeof t)||"function"===t,x=(t,e,...n)=>{let o=null,l=null,i=!1,s=!1;const r=[],c=e=>{for(let n=0;n<e.length;n++)o=e[n],Array.isArray(o)?c(o):null!=o&&"boolean"!=typeof o&&((i="function"!=typeof t&&!C(o))&&(o+=""),i&&s?r[r.length-1].m+=o:r.push(i?L(null,o):o),s=i)};if(c(n),e){e.key&&(l=e.key);{const t=e.className||e.class;t&&(e.class="object"!=typeof t?t:Object.keys(t).filter((e=>t[e])).join(" "))}}if("function"==typeof t)return t(null===e?{}:e,r,D);const u=L(t,null);return u.v=e,r.length>0&&(u.$=r),u.j=l,u},L=(t,e)=>({u:0,O:t,m:null!=e?e:null,S:null,$:null,v:null,j:null}),R={},D={forEach:(t,e)=>t.map(P).forEach(e),map:(t,e)=>t.map(P).map(e).map(T)},P=t=>({vattrs:t.v,vchildren:t.$,vkey:t.j,vname:t.k,vtag:t.O,vtext:t.m}),T=t=>{if("function"==typeof t.vtag){const e={...t.vattrs};return t.vkey&&(e.key=t.vkey),t.vname&&(e.name=t.vname),x(t.vtag,e,...t.vchildren||[])}const e=L(t.vtag,t.vtext);return e.v=t.vattrs,e.$=t.vchildren,e.j=t.vkey,e.k=t.vname,e},A=t=>{if(!t)return;const e=Object.keys(t);if(0===e.length)return;let n=!1;for(const o of e){if(n)break;for(const e of t[o])if("string"==typeof e){n=!0;break}}if(!n)return t;const o={};for(const n of e)o[n]=t[n].map((t=>"string"==typeof t?{[t]:0}:t));return o},H=(t,e)=>null==t||C(t)?t:4&e?"false"!==t&&(""===t||!!t):1&e?t+"":t,N=t=>{var e;return null==(e=o(t))?void 0:e.$hostElement$},U=(t,e)=>{const n=N(t);return{emit:t=>W(n,e,{bubbles:!0,composed:!0,cancelable:!0,detail:t})}},W=(t,e,n)=>{const o=a.ce(e,n);return t.dispatchEvent(o),o},z=(t,e,n,l,s,r)=>{if(n===l)return;let c=i(t,e),d=e.toLowerCase();if("class"===e){const e=t.classList,o=q(n);let i=q(l);e.remove(...o.filter((t=>t&&!i.includes(t)))),e.add(...i.filter((t=>t&&!o.includes(t))))}else if("style"===e){for(const e in n)l&&null!=l[e]||(e.includes("-")?t.style.removeProperty(e):t.style[e]="");for(const e in l)n&&l[e]===n[e]||(e.includes("-")?t.style.setProperty(e,l[e]):t.style[e]=l[e])}else if("key"===e);else if("ref"===e)l&&nt(l,t);else if(c||"o"!==e[0]||"n"!==e[1]){if("a"===e[0]&&e.startsWith("attr:")){const n=e.slice(5);let i;{const e=o(t);if(e&&e.o&&e.o.t){const t=e.o.t[n];t&&t[1]&&(i=t[1])}}return i||(i=n.replace(/([a-z0-9])([A-Z])/g,"$1-$2").toLowerCase()),void(null==l||!1===l?!1===l&&""!==t.getAttribute(i)||t.removeAttribute(i):t.setAttribute(i,!0===l?"":l))}if("p"===e[0]&&e.startsWith("prop:")){const n=e.slice(5);try{t[n]=l}catch(t){}return}{const o=C(l);if((c||o&&null!==l)&&!s)try{if(t.tagName.includes("-"))t[e]!==l&&(t[e]=l);else{const o=null==l?"":l;"list"===e?c=!1:null!=n&&t[e]===o||("function"==typeof t.__lookupSetter__(e)?t[e]=o:t.setAttribute(e,o))}}catch(t){}let i=!1;d!==(d=d.replace(/^xlink\:?/,""))&&(e=d,i=!0),null==l||!1===l?!1===l&&""!==t.getAttribute(e)||(i?t.removeAttributeNS(u,e):t.removeAttribute(e)):(!c||4&r||s)&&!o&&1===t.nodeType&&(l=!0===l?"":l,i?t.setAttributeNS(u,e,l):t.setAttribute(e,l))}}else if(e="-"===e[2]?e.slice(3):i(f,d)?d.slice(2):d[2]+e.slice(3),n||l){const o=e.endsWith(F);e=e.replace(G,""),n&&a.rel(t,e,n,o),l&&a.ael(t,e,l,o)}},V=/\s/,q=t=>("object"==typeof t&&t&&"baseVal"in t&&(t=t.baseVal),t&&"string"==typeof t?t.split(V):[]),F="Capture",G=RegExp(F+"$"),Y=(t,e,n)=>{const o=11===e.S.nodeType&&e.S.host?e.S.host:e.S,l=t&&t.v||{},i=e.v||{};for(const t of Z(Object.keys(l)))t in i||z(o,t,l[t],void 0,n,e.u);for(const t of Z(Object.keys(i)))z(o,t,l[t],i[t],n,e.u)};function Z(t){return t.includes("ref")?[...t.filter((t=>"ref"!==t)),"ref"]:t}var _=!1,B=[],I=[],J=(t,e,n)=>{const o=e.$[n];let l,i,s=0;if(null!=o.m)l=o.S=f.document.createTextNode(o.m);else{if(_||(_="svg"===o.O),!f.document)throw Error("You are trying to render a Stencil component in an environment that doesn't support the DOM.");if(l=o.S=f.document.createElementNS(_?"http://www.w3.org/2000/svg":"http://www.w3.org/1999/xhtml",o.O),_&&"foreignObject"===o.O&&(_=!1),Y(null,o,_),o.$){const e="template"===o.O?l.content:l;for(s=0;s<o.$.length;++s)i=J(t,o,s),i&&e.appendChild(i)}"svg"===o.O?_=!1:"foreignObject"===l.tagName&&(_=!0)}return l["s-hn"]=k,l},K=(t,e,n,o,l,i)=>{let s,r=t;for(r.shadowRoot&&r.tagName===k&&(r=r.shadowRoot),"template"===n.O&&(r=r.content);l<=i;++l)o[l]&&(s=J(null,n,l),s&&(o[l].S=s,ot(r,s,e)))},Q=(t,e,n)=>{for(let o=e;o<=n;++o){const e=t[o];if(e){const t=e.S;et(e),t&&t.remove()}}},X=(t,e,n=!1)=>t.O===e.O&&(n?(n&&!t.j&&e.j&&(t.j=e.j),!0):t.j===e.j),tt=(t,e,n=!1)=>{const o=e.S=t.S,l=t.$,i=e.$,s=e.O,r=e.m;null==r?(Y(t,e,_="svg"===s||"foreignObject"!==s&&_),null!==l&&null!==i?((t,e,n,o,l=!1)=>{let i,s,r=0,c=0,u=0,f=0,a=e.length-1,d=e[0],h=e[a],p=o.length-1,m=o[0],v=o[p];const y="template"===n.O?t.content:t;for(;r<=a&&c<=p;)if(null==d)d=e[++r];else if(null==h)h=e[--a];else if(null==m)m=o[++c];else if(null==v)v=o[--p];else if(X(d,m,l))tt(d,m,l),d=e[++r],m=o[++c];else if(X(h,v,l))tt(h,v,l),h=e[--a],v=o[--p];else if(X(d,v,l))tt(d,v,l),ot(y,d.S,h.S.nextSibling),d=e[++r],v=o[--p];else if(X(h,m,l))tt(h,m,l),ot(y,h.S,d.S),h=e[--a],m=o[++c];else{for(u=-1,f=r;f<=a;++f)if(e[f]&&null!==e[f].j&&e[f].j===m.j){u=f;break}u>=0?(s=e[u],s.O!==m.O?i=J(e&&e[c],n,u):(tt(s,m,l),e[u]=void 0,i=s.S),m=o[++c]):(i=J(e&&e[c],n,c),m=o[++c]),i&&ot(d.S.parentNode,i,d.S)}r>a?K(t,null==o[p+1]?null:o[p+1].S,n,o,c,p):c>p&&Q(e,r,a)})(o,l,e,i,n):null!==i?(null!==t.m&&(o.textContent=""),K(o,null,e,i,0,i.length-1)):!n&&null!==l&&Q(l,0,l.length-1),_&&"svg"===s&&(_=!1)):t.m!==r&&(o.data=r)},et=t=>{t.v&&t.v.ref&&B.push((()=>t.v.ref(null))),t.$&&t.$.map(et)},nt=(t,e)=>{I.push((()=>t(e)))},ot=(t,e,n)=>t.__insertBefore?t.__insertBefore(e,n):null==t?void 0:t.insertBefore(e,n),lt=(t,e)=>{if(e&&!t.M&&e["s-p"]){const n=e["s-p"].push(new Promise((o=>t.M=()=>{e["s-p"].splice(n-1,1),o()})))}},it=(t,e)=>{if(t.u|=16,4&t.u)return void(t.u|=512);lt(t,t.C);const n=()=>st(t,e);if(!e)return j(n);queueMicrotask((()=>{n()}))},st=(t,e)=>{const n=t.$hostElement$,o=t.i;if(!o)throw Error(`Can't render component <${n.tagName.toLowerCase()} /> with invalid Stencil runtime! Make sure this imported component is compiled with a \`externalRuntime: true\` flag. For more information, please refer to https://stenciljs.com/docs/custom-elements#externalruntime`);let l;return e?(t.u|=256,t.L&&(t.L.map((([t,e])=>ht(o,t,e,n))),t.L=void 0),t.R.length&&t.R.forEach((t=>t(n))),l=ht(o,"componentWillLoad",void 0,n)):l=ht(o,"componentWillUpdate",void 0,n),l=rt(l,(()=>ht(o,"componentWillRender",void 0,n))),rt(l,(()=>ut(t,o,e)))},rt=(t,e)=>ct(t)?t.then(e).catch((t=>{console.error(t),e()})):e(),ct=t=>t instanceof Promise||t&&t.then&&"function"==typeof t.then,ut=async(t,e,n)=>{var o;const l=t.$hostElement$,i=l["s-rc"];n&&(t=>{const e=t.o,n=t.$hostElement$,o=e.u,l=((t,e)=>{var n,o,l;const i=M(e),s=c.get(i);if(!f.document)return i;if(t=11===t.nodeType?t:f.document,s)if("string"==typeof s){let l,r=E.get(t=t.head||t);if(r||E.set(t,r=new Set),!r.has(i)){l=f.document.createElement("style"),l.textContent=s;const c=null!=(n=a.D)?n:S(f.document);if(null!=c&&l.setAttribute("nonce",c),!(1&e.u))if("HEAD"===t.nodeName){const e=t.querySelectorAll("link[rel=preconnect]"),n=e.length>0?e[e.length-1].nextSibling:t.querySelector("style");t.insertBefore(l,(null==n?void 0:n.parentNode)===t?n:null)}else if("host"in t)if(h){const e=new(null!=(o=t.defaultView)?o:t.ownerDocument.defaultView).CSSStyleSheet;e.replaceSync(s),p?t.adoptedStyleSheets.unshift(e):t.adoptedStyleSheets=[e,...t.adoptedStyleSheets]}else{const e=t.querySelector("style");e?e.textContent=s+e.textContent:t.prepend(l)}else t.append(l);1&e.u&&t.insertBefore(l,null),4&e.u&&(l.textContent+="slot-fb{display:contents}slot-fb[hidden]{display:none}"),r&&r.add(i)}}else{let e=E.get(t);if(e||E.set(t,e=new Set),!e.has(i)){const n=null!=(l=t.defaultView)?l:t.ownerDocument.defaultView;let o;if(s.constructor===n.CSSStyleSheet)o=s;else{o=new n.CSSStyleSheet;for(let t=0;t<s.cssRules.length;t++)o.insertRule(s.cssRules[t].cssText,t)}p?t.adoptedStyleSheets.push(o):t.adoptedStyleSheets=[...t.adoptedStyleSheets,o],e.add(i)}}return i})(n.shadowRoot?n.shadowRoot:n.getRootNode(),e);10&o&&(n["s-sc"]=l,n.classList.add(l+"-h"))})(t);ft(t,e,l,n),i&&(i.map((t=>t())),l["s-rc"]=void 0);{const e=null!=(o=l["s-p"])?o:[],n=()=>at(t);0===e.length?n():(Promise.all(e).then(n).catch(n),t.u|=4,e.length=0)}},ft=(t,e,n,o)=>{try{e=e.render(),t.u&=-17,t.u|=2,((t,e,n=!1)=>{const o=t.$hostElement$,l=t.o,i=t.P||L(null,null),s=(t=>t&&t.O===R)(e)?e:x(null,null,e);if(k=o.tagName,l.T&&(s.v=s.v||{},l.T.forEach((([t,e])=>{s.v[e]=o[t]}))),n&&s.v)for(const t of Object.keys(s.v))o.hasAttribute(t)&&!["key","ref","style","class"].includes(t)&&(s.v[t]=o[t]);s.O=null,s.u|=4,t.P=s,s.S=i.S=o.shadowRoot||o,tt(i,s,n),B.forEach((t=>t())),B.length=0,I.forEach((t=>t())),I.length=0})(t,e,o)}catch(e){s(e,t.$hostElement$)}return null},at=t=>{const e=t.$hostElement$,n=t.i,o=t.C;ht(n,"componentDidRender",void 0,e),64&t.u?ht(n,"componentDidUpdate",void 0,e):(t.u|=64,pt(e),ht(n,"componentDidLoad",void 0,e),t.A(e),o||dt()),t.M&&(t.M(),t.M=void 0),512&t.u&&g((()=>it(t,!1))),t.u&=-517},dt=()=>{g((()=>W(f,"appload",{detail:{namespace:"weg-shared-layout"}})))},ht=(t,e,n,o)=>{if(t&&t[e])try{return t[e](n)}catch(t){s(t,o)}},pt=t=>t.classList.add("hydrated"),mt=(t,e,n,l)=>{const i=o(t);if(!i)return;if(!i)throw Error(`Couldn't find host element for "${l.p}" as it is unknown to this Stencil runtime. This usually happens when integrating a 3rd party Stencil component with another Stencil component or application. Please reach out to the maintainers of the 3rd party Stencil component or report this on the Stencil Discord server (https://chat.stenciljs.com) or comment on this similar [GitHub issue](https://github.com/stenciljs/core/issues/5457).`);const r=i.$hostElement$,c=i.l.get(e),u=i.u,f=i.i;if(n=H(n,l.t[e][0]),!(8&u&&void 0!==c||n===c||Number.isNaN(c)&&Number.isNaN(n))){if(i.l.set(e,n),l.H){const t=l.H[e];t&&t.map((t=>{try{const[[o,l]]=Object.entries(t);(128&u||1&l)&&(f?f[o](n,c,e):i.R.push((()=>{i.i[o](n,c,e)})))}catch(t){s(t,r)}}))}if(2&u){if(f.componentShouldUpdate&&!1===f.componentShouldUpdate(n,c,e)&&!(16&u))return;16&u||it(i,!1)}}},vt=(e,n,l)=>{var i,s;const r=e.prototype;{e.watchers&&!n.H&&(n.H=A(e.watchers)),e.deserializers&&!n.N&&(n.N=e.deserializers),e.serializers&&!n.U&&(n.U=e.serializers);const c=Object.entries(null!=(i=n.t)?i:{});if(c.map((([e,[i]])=>{if(31&i||2&l&&32&i){const{get:s,set:c}=t(r,e)||{};s&&(n.t[e][0]|=2048),c&&(n.t[e][0]|=4096),(1&l||!s)&&Object.defineProperty(r,e,{get(){{if(!(2048&n.t[e][0]))return((t,e)=>o(this).l.get(e))(0,e);const t=o(this),l=t?t.i:r;if(!l)return;return l[e]}},configurable:!0,enumerable:!0}),Object.defineProperty(r,e,{set(t){const s=o(this);if(s){if(c)return void 0===(32&i?this[e]:s.$hostElement$[e])&&s.l.get(e)&&(t=s.l.get(e)),c.call(this,H(t,i)),void mt(this,e,t=32&i?this[e]:s.$hostElement$[e],n);{if(!(1&l&&4096&n.t[e][0]))return mt(this,e,t,n),void(1&l&&!s.i&&s.R.push((()=>{4096&n.t[e][0]&&s.i[e]!==s.l.get(e)&&(s.i[e]=t)})));const o=()=>{const o=s.i[e];!s.l.get(e)&&o&&s.l.set(e,o),s.i[e]=H(t,i),mt(this,e,s.i[e],n)};s.i?o():s.R.push((()=>{o()}))}}}})}})),1&l){const t=new Map;r.attributeChangedCallback=function(e,l,i){a.jmp((()=>{var s;const u=t.get(e),f=o(this);if(this.hasOwnProperty(u)&&(i=this[u],delete this[u]),r.hasOwnProperty(u)&&"number"==typeof this[u]&&this[u]==i)return;if(null==u){const t=null==f?void 0:f.u;if(f&&t&&!(8&t)&&i!==l){const o=f.i,r=null==(s=n.H)?void 0:s[e];null==r||r.forEach((n=>{const[[s,r]]=Object.entries(n);null!=o[s]&&(128&t||1&r)&&o[s].call(o,i,l,e)}))}return}const a=c.find((([t])=>t===u)),d=a&&4&a[1][0],h=d&&null===i&&void 0===this[u];d&&(i=null!==i&&"false"!==i);const p=Object.getOwnPropertyDescriptor(r,u);h||i==this[u]||p.get&&!p.set||(this[u]=i)}))},e.observedAttributes=Array.from(new Set([...Object.keys(null!=(s=n.H)?s:{}),...c.filter((([t,e])=>31&e[0])).map((([e,o])=>{var l;const i=o[1]||e;return t.set(i,e),512&o[0]&&(null==(l=n.T)||l.push([e,i])),i}))]))}}return e},yt=(t,e)=>{ht(t,"connectedCallback",void 0,e)},bt=(t,e)=>{ht(t,"disconnectedCallback",void 0,e||t)},wt=(t,e={})=>{var n;if(!f.document)return void console.warn("Stencil: No document found. Skipping bootstrapping lazy components.");const l=[],i=e.exclude||[],u=f.customElements,d=f.document.head,p=d.querySelector("meta[charset]"),m=f.document.createElement("style"),v=[];let y,b=!0;if(Object.assign(a,e),a.h=new URL(e.resourcesUrl||"./",f.document.baseURI).href,t.map((t=>{t[1].map((e=>{var n,f;const d={u:e[0],p:e[1],t:e[2],W:e[3]};d.t=e[2],d.W=e[3],d.T=[],d.H=A(e[4]),d.U=null!=(n=e[5])?n:{},d.N=null!=(f=e[6])?f:{};const p=d.p,m=class extends HTMLElement{"s-p";"s-rc";hasRegisteredEventListeners=!1;constructor(t){if(super(t),((t,e)=>{const n={u:0,$hostElement$:t,o:e,l:new Map,V:new Map};n.q=new Promise((t=>n.A=t)),t["s-p"]=[],t["s-rc"]=[],n.R=[];const o=n;t.__stencil__getHostRef=()=>o})(t=this,d),1&d.u)if(t.shadowRoot){if("open"!==t.shadowRoot.mode)throw Error(`Unable to re-use existing shadow root for ${d.p}! Mode is set to ${t.shadowRoot.mode} but Stencil only supports open shadow roots.`)}else O.call(t,d)}connectedCallback(){const t=o(this);t&&(this.hasRegisteredEventListeners||(this.hasRegisteredEventListeners=!0,$t(this,t,d.W)),y&&(clearTimeout(y),y=null),b?v.push(this):a.jmp((()=>(t=>{if(!(1&a.u)){const e=o(t);if(!e)return;const n=e.o,l=()=>{};if(1&e.u)$t(t,e,n.W),(null==e?void 0:e.i)?yt(e.i,t):(null==e?void 0:e.q)&&e.q.then((()=>yt(e.i,t)));else{e.u|=1;{let n=t;for(;n=n.parentNode||n.host;)if(n["s-p"]){lt(e,e.C=n);break}}n.t&&Object.entries(n.t).map((([e,[n]])=>{if(31&n&&Object.prototype.hasOwnProperty.call(t,e)){const n=t[e];delete t[e],t[e]=n}})),(async(t,e,n)=>{let o;try{if(!(32&e.u)){if(e.u|=32,n.F){const l=((t,e)=>{const n=t.p.replace(/-/g,"_"),o=t.F;if(!o)return;const l=r.get(o);return l?l[n]:import(`./${o}.entry.js`).then((t=>(r.set(o,t),t[n])),(t=>{s(t,e.$hostElement$)}))
2
+ /*!__STENCIL_STATIC_IMPORT_SWITCH__*/})(n,e);if(l&&"then"in l){const t=()=>{};o=await l,t()}else o=l;if(!o)throw Error(`Constructor for "${n.p}#${e.G}" was not found`);o.isProxied||(n.H=A(o.watchers),n.U=o.serializers,n.N=o.deserializers,vt(o,n,2),o.isProxied=!0);const i=()=>{};e.u|=8;try{new o(e)}catch(e){s(e,t)}e.u&=-9,e.u|=128,i(),yt(e.i,t)}else o=t.constructor,customElements.whenDefined(t.localName).then((()=>e.u|=128));if(o&&o.style){let t;"string"==typeof o.style&&(t=o.style);const e=M(n);if(!c.has(e)){const o=()=>{};((t,e,n)=>{let o=c.get(t);h&&n?(o=o||new CSSStyleSheet,"string"==typeof o?o=e:o.replaceSync(e)):o=e,c.set(t,o)})(e,t,!!(1&n.u)),o()}}}const l=e.C,i=()=>it(e,!0);l&&l["s-rc"]?l["s-rc"].push(i):i()}catch(n){s(n,t),e.M&&(e.M(),e.M=void 0),e.A&&e.A(t)}})(t,e,n)}l()}})(this))))}disconnectedCallback(){a.jmp((()=>(async t=>{if(!(1&a.u)){const e=o(t);(null==e?void 0:e.Y)&&(e.Y.map((t=>t())),e.Y=void 0),(null==e?void 0:e.i)?bt(e.i,t):(null==e?void 0:e.q)&&e.q.then((()=>bt(e.i,t)))}E.has(t)&&E.delete(t),t.shadowRoot&&E.has(t.shadowRoot)&&E.delete(t.shadowRoot)})(this))),a.raf((()=>{var t;const e=o(this);if(!e)return;const n=v.findIndex((t=>t===this));n>-1&&v.splice(n,1),(null==(t=null==e?void 0:e.P)?void 0:t.S)instanceof Node&&!e.P.S.isConnected&&delete e.P.S}))}componentOnReady(){var t;return null==(t=o(this))?void 0:t.q}};d.F=t[0],i.includes(p)||u.get(p)||(l.push(p),u.define(p,vt(m,d,1)))}))})),l.length>0&&(m.textContent+=l.sort()+"{visibility:hidden}.hydrated{visibility:inherit}",m.innerHTML.length)){m.setAttribute("data-styles","");const t=null!=(n=a.D)?n:S(f.document);null!=t&&m.setAttribute("nonce",t),d.insertBefore(m,p?p.nextSibling:d.firstChild)}b=!1,v.length?v.map((t=>t.connectedCallback())):a.jmp((()=>y=setTimeout(dt,30)))},$t=(t,e,n)=>{n&&f.document&&n.map((([n,o,l])=>{const i=jt(f.document,t,n),s=gt(e,l),r=Ot(n);a.ael(i,o,s,r),(e.Y=e.Y||[]).push((()=>a.rel(i,o,s,r)))}))},gt=(t,e)=>n=>{var o;try{256&t.u?null==(o=t.i)||o[e](n):(t.L=t.L||[]).push([e,n])}catch(e){s(e,t.$hostElement$)}},jt=(t,e,n)=>8&n?f:e,Ot=t=>({passive:!!(1&t),capture:!!(2&t)}),St=t=>a.D=t;export{wt as b,U as c,N as g,x as h,d as p,l as r,St as s}
@@ -1 +1 @@
1
- import{r as t,h as s}from"./p-QiJxC4Ow.js";import{format as r}from"./index.esm.js";const o=class{constructor(s){t(this,s)}first;middle;last;getText(){return r(this.first,this.middle,this.last)}render(){return s("div",{key:"5452c3b9c97f8879dbc26b788d1fa79409846ff0"},"Hello, world! I'm ",this.getText())}};o.style=":host{display:block}";export{o as my_component}
1
+ import{r as t,h as s}from"./p-D8pmhPiH.js";import{format as r}from"./index.esm.js";const o=class{constructor(s){t(this,s)}first;middle;last;getText(){return r(this.first,this.middle,this.last)}render(){return s("div",{key:"5452c3b9c97f8879dbc26b788d1fa79409846ff0"},"Hello, world! I'm ",this.getText())}};o.style=":host{display:block}";export{o as my_component}
@@ -0,0 +1 @@
1
+ import{r as e,h as n,c as t,g as i}from"./p-D8pmhPiH.js";function o(e){if("string"!=typeof e)return e;const n=e.trim();if(n)try{return JSON.parse(n)}catch{return}}function A(e){return"string"==typeof e&&e.trim().length>0}function r(e){if(!Array.isArray(e))return[];const n=[];for(const t of e){if(!t||"object"!=typeof t)continue;const e=t.label,i=t.href;A(e)&&A(i)&&n.push({label:e.trim(),href:i.trim()})}return n}const l={social:[],columns:[],credits:"",copyright:""};function a(e){return/^https?:\/\//.test(e)}function s(e){if(!Array.isArray(e))return[];const n=[];for(const i of e){if(!i||"object"!=typeof i)continue;const e=i.platform,o=i.href;("LinkedIn"===(t=e)||"Instagram"===t||"TikTok"===t||"YouTube"===t)&&A(o)&&n.push({platform:e,href:o.trim()})}var t;return n}function c(e){if(!Array.isArray(e))return[];const n=[];for(const t of e){if(!t||"object"!=typeof t)continue;const e=r(t.links);0!==e.length&&n.push({links:e})}return n}function d(e){return a(e.href)}function f({platform:e}){const t={viewBox:"0 0 48 48",width:48,height:48,fill:"none",xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false"};switch(e){case"LinkedIn":return n("svg",{...t},n("path",{d:"M24 0C37.2548 0 48 10.7452 48 24C48 37.2548 37.2548 48 24 48C10.7452 48 0 37.2548 0 24C0 10.7452 10.7452 0 24 0ZM12.9082 33.4736H17.5889V19.4111H12.9082V33.4736ZM29.0791 19.0811C26.5942 19.0811 25.4815 20.4458 24.8604 21.4033V19.4111H20.1797C20.2412 20.7279 20.1799 33.4203 20.1797 33.4736H24.8604V25.6201C24.8604 25.1998 24.8909 24.7804 25.0146 24.4795C25.3529 23.6399 26.1231 22.7705 27.416 22.7705C29.1103 22.7705 29.7881 24.0605 29.7881 25.9502V33.4736H34.4678V25.4102C34.4677 21.0909 32.1589 19.0811 29.0791 19.0811ZM15.2793 12.6318C13.6783 12.6319 12.6319 13.6818 12.6318 15.0605C12.6318 16.4108 13.6474 17.4912 15.2188 17.4912H15.249C16.8807 17.491 17.8965 16.4107 17.8965 15.0605C17.866 13.6818 16.8804 12.6318 15.2793 12.6318Z",fill:"white"}));case"Instagram":return n("svg",{...t},n("path",{d:"M24 0C37.2548 0 48 10.7452 48 24C48 37.2548 37.2548 48 24 48C10.7452 48 0 37.2548 0 24C0 10.7452 10.7452 0 24 0ZM23.999 11.2002C20.5245 11.2002 20.0877 11.2152 18.7227 11.2773C17.3602 11.3398 16.43 11.5556 15.6162 11.8721C14.7744 12.199 14.06 12.636 13.3486 13.3477C12.6366 14.0591 12.1991 14.7736 11.8711 15.6152C11.5538 16.4293 11.3377 17.3597 11.2764 18.7217C11.2153 20.087 11.2002 20.5238 11.2002 24C11.2002 27.476 11.2155 27.9113 11.2773 29.2764C11.34 30.639 11.5558 31.5699 11.8721 32.3838C12.1993 33.2255 12.636 33.94 13.3477 34.6514C14.0589 35.3634 14.7739 35.801 15.6152 36.1279C16.4295 36.4444 17.3596 36.6602 18.7217 36.7227C20.087 36.7848 20.5233 36.7998 23.999 36.7998C27.4756 36.7998 27.911 36.7848 29.2764 36.7227C30.639 36.6602 31.5704 36.4445 32.3848 36.1279C33.2261 35.801 33.9394 35.3631 34.6504 34.6514C35.3624 33.9399 35.7999 33.2254 36.1279 32.3838C36.4426 31.5697 36.6586 30.6393 36.7227 29.2773C36.784 27.912 36.7998 27.4763 36.7998 24C36.7998 20.5242 36.784 20.0876 36.7227 18.7227C36.6587 17.36 36.4426 16.4291 36.1279 15.6152C35.7999 14.7734 35.3623 14.0591 34.6504 13.3477C33.9385 12.6358 33.2264 12.1987 32.3838 11.8721C31.5678 11.5555 30.6371 11.3397 29.2744 11.2773C27.9093 11.2152 27.4745 11.2002 23.999 11.2002Z",fill:"white"}),n("path",{d:"M22.8525 13.5068C23.1933 13.5063 23.5739 13.5068 24.001 13.5068C27.4186 13.5068 27.8242 13.5197 29.1738 13.5811C30.4214 13.6381 31.0986 13.8463 31.5498 14.0215C32.1471 14.2535 32.5737 14.5305 33.0215 14.9785C33.4695 15.4265 33.746 15.8538 33.9785 16.4512C34.1537 16.9018 34.3631 17.5792 34.4199 18.8271C34.4812 20.1763 34.4941 20.5822 34.4941 23.998C34.4941 27.4134 34.4812 27.819 34.4199 29.168C34.3629 30.4158 34.1537 31.0933 33.9785 31.5439C33.7466 32.1412 33.4693 32.567 33.0215 33.0146C32.5735 33.4627 32.1474 33.7397 31.5498 33.9717C31.0992 34.1477 30.4216 34.356 29.1738 34.4131C27.8245 34.4744 27.4186 34.4883 24.001 34.4883C20.5835 34.4883 20.1783 34.4744 18.8291 34.4131C17.5811 34.3555 16.9036 34.1469 16.4521 33.9717C15.8549 33.7397 15.4284 33.4625 14.9805 33.0146C14.5325 32.5666 14.255 32.1406 14.0225 31.543C13.8473 31.0923 13.6378 30.4148 13.5811 29.167C13.5197 27.8179 13.5078 27.4121 13.5078 23.9941C13.5078 20.5762 13.5197 20.1726 13.5811 18.8232C13.6381 17.5755 13.8473 16.8984 14.0225 16.4473C14.2545 15.8499 14.5325 15.4236 14.9805 14.9756C15.4285 14.5276 15.8549 14.2501 16.4521 14.0176C16.9034 13.8416 17.5811 13.6335 18.8291 13.5762C20.0097 13.5228 20.4674 13.5066 22.8525 13.5039V13.5068ZM24.001 17.4268C20.371 17.427 17.4277 20.3709 17.4277 24.001C17.4279 27.6309 20.3711 30.5721 24.001 30.5723C27.631 30.5723 30.573 27.631 30.5732 24.001C30.5732 20.3708 27.6311 17.4268 24.001 17.4268ZM30.834 15.6318C29.9861 15.632 29.2979 16.3198 29.2979 17.168C29.2979 18.0159 29.9861 18.704 30.834 18.7041C31.682 18.7041 32.3701 18.016 32.3701 17.168C32.37 16.32 31.6819 15.6318 30.834 15.6318Z",fill:"white"}),n("path",{d:"M24.0011 19.7334C26.3574 19.7334 28.2678 21.6436 28.2678 24.0001C28.2678 26.3564 26.3574 28.2668 24.0011 28.2668C21.6445 28.2668 19.7344 26.3564 19.7344 24.0001C19.7344 21.6436 21.6445 19.7334 24.0011 19.7334Z",fill:"white"}));case"TikTok":return n("svg",{...t},n("path",{d:"M24 0C37.2548 0 48 10.7452 48 24C48 37.2548 37.2548 48 24 48C10.7452 48 0 37.2548 0 24C0 10.7452 10.7452 0 24 0ZM25.0273 28.3477C25.0273 30.2955 23.4721 31.8955 21.5361 31.8955C19.6003 31.8954 18.0449 30.2955 18.0449 28.3477C18.045 26.4347 19.5659 24.8693 21.4326 24.7998V20.6953C17.3188 20.7648 14.0001 24.1391 14 28.3477C14 32.5912 17.3883 36 21.5713 36C25.754 35.9998 29.1416 32.5562 29.1416 28.3477V19.9648C30.6627 21.0779 32.5295 21.7396 34.5 21.7744V17.6699C31.4579 17.5656 29.0723 15.0609 29.0723 12H25.0273V28.3477Z",fill:"white"}));case"YouTube":return n("svg",{...t},n("path",{d:"M24 0C37.2548 0 48 10.7452 48 24C48 37.2548 37.2548 48 24 48C10.7452 48 0 37.2548 0 24C0 10.7452 10.7452 0 24 0ZM24 15.2002C24 15.2002 15.9944 15.1997 13.998 15.749C12.8966 16.0513 12.0288 16.9423 11.7344 18.0732C11.1996 20.1231 11.2002 24.4004 11.2002 24.4004C11.2002 24.4472 11.2026 28.6878 11.7344 30.7266C12.0288 31.8575 12.8966 32.7483 13.998 33.0508C15.9944 33.6 24 33.5996 24 33.5996C24 33.5996 32.0057 33.6 34.002 33.0508C35.1033 32.7483 35.9703 31.8575 36.2646 30.7266C36.7966 28.6879 36.7998 24.4472 36.7998 24.4004C36.7998 24.4004 36.7996 20.1231 36.2646 18.0732C35.9703 16.9424 35.1033 16.0513 34.002 15.749C32.0057 15.1997 24 15.2002 24 15.2002Z",fill:"white"}),n("path",{d:"M21.6016 28.7998V20.7998L28.0016 24.8L21.6016 28.7998Z",fill:"white"}))}}const u=class{constructor(n){e(this,n)}layout;resolved=l;resolve(){this.resolved=null!=this.layout?function(e){const n=e&&"object"==typeof e?e:{},t=n.footer&&"object"==typeof n.footer?n.footer:{};return{social:s(t?.social),columns:c(t?.columns),credits:A(t?.credits)?t.credits.trim():"",copyright:A(t?.copyright)?t.copyright.trim():""}}(o(this.layout)):l}componentWillLoad(){this.resolve()}watchLayout(){this.resolve()}renderLegalText(){const{credits:e,copyright:t}=this.resolved;return e||t?n("div",{class:"legal"},e?n("p",{class:"legal__p"},e):null,e&&t?n("p",{class:"legal__p"},String.fromCharCode(8203)):null,t?n("p",{class:"legal__p"},t):null):null}renderSocialLinks(){const e=this.resolved.social;return 0===e.length?null:n("div",{class:"social"},e.map((e=>n("a",{class:"social__link",href:e.href,"aria-label":e.platform,target:a(e.href)?"_blank":void 0,rel:a(e.href)?"noreferrer noopener":void 0},n("span",{class:"social__icon","aria-hidden":"true"},n(f,{platform:e.platform}))))))}renderColumns(){const e=this.resolved.columns;return 0===e.length?null:n("div",{class:"columns"},e.map(((e,t)=>n("div",{class:"columns__col",key:t},t>0?n("div",{class:"columns__divider","aria-hidden":"true"}):null,n("nav",{class:"columns__links","aria-label":`Footer links column ${t+1}`},e.links.map(((e,t)=>n("a",{class:"footer-link",href:e.href,key:t,target:d(e)?"_blank":void 0,rel:d(e)?"noreferrer noopener":void 0},e.label))))))))}render(){return n("footer",{key:"f592a5632d0b39833ac01384f8541082afc36c6b",class:"footer"},n("div",{key:"dca05ec8f8eb48beef27e20305865156b2d2122a",class:"container container--stack"},this.renderSocialLinks(),n("div",{key:"0d73dd8a28f2839e00f4dc23daa0219ac6d83662",class:"standard"},this.renderColumns(),this.renderLegalText())))}static get watchers(){return{layout:[{watchLayout:0}]}}};u.style=":host{display:block;--weg-font-family:ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, 'Apple Color Emoji', 'Segoe UI Emoji';--weg-color-accent:#948eeb}.container{max-width:1024px;margin:0 auto;padding:12px 16px}@media (min-width: 768px){.container{padding:20px 16px}}@media (min-width: 1280px){.container{padding:28px 16px}}.container--stack{display:flex;flex-direction:column;align-items:center;gap:20px}@media (min-width: 768px){.container--stack{gap:36px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.footer{background:#030712;color:#ffffff;font-family:var(--weg-font-family);font-weight:300}.social{display:flex;align-items:center;justify-content:center;gap:16px}@media (min-width: 768px){.social{gap:28px}}.social__link{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:transparent;color:inherit;text-decoration:none;transition:opacity 150ms ease;outline:none}.social__link:hover{opacity:0.9}.social__link:focus-visible{outline:2px solid rgba(255, 255, 255, 0.9);outline-offset:4px}.social__icon{display:inline-flex;width:48px;height:48px}.footer-link{color:#ffffff;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;outline:none}.footer-link:hover{text-decoration-thickness:2px}.footer-link:focus-visible{outline:2px solid rgba(255, 255, 255, 0.9);outline-offset:4px}.legal{width:100%;max-width:860px;text-align:center;font-size:16px;line-height:24px}@media (min-width: 768px){.legal{font-size:18px;line-height:28px}}.legal__p{margin:0}.standard{width:100%;display:flex;flex-direction:column;align-items:center;gap:36px;text-align:center;font-size:16px;line-height:24px}@media (min-width: 768px){.standard{font-size:18px;line-height:28px}}.columns{width:100%;display:grid;gap:28px 16px;grid-template-columns:1fr}@media (min-width: 640px){.columns{grid-template-columns:repeat(2, minmax(0, 1fr))}}@media (min-width: 768px){.columns{display:flex;flex-direction:row;align-items:stretch;justify-content:center;gap:0}}.columns__col{display:flex;flex:1 1 0;min-width:0;align-items:stretch}@media (max-width: 767px){.columns__col{flex-direction:column}}.columns__divider{display:none;width:1px;background:rgba(255, 255, 255, 0.35);align-self:center;min-height:72px;margin:0 12px;flex-shrink:0}@media (min-width: 768px){.columns__divider{display:block}}.columns__links{display:flex;flex-direction:column;align-items:flex-start;gap:12px;flex:1;min-width:0;padding:0 4px;text-align:left}@media (min-width: 768px){.columns__links{padding:0 12px}}";const h={dropdowns:[],links:[],signIn:null,signOut:null};function p(e){if(!Array.isArray(e))return[];const n=[];for(const t of e){if(!t||"object"!=typeof t)continue;const e=t.label,i=r(t.items);A(e)&&0!==i.length&&n.push({label:e.trim(),items:i})}return n}function x(e){if(!e||"object"!=typeof e)return null;const n=e.label,t=e.href;return A(n)&&A(t)?{label:n.trim(),href:t.trim()}:null}function g(e){if(!e||"object"!=typeof e)return null;const n=e.label,t=e.href;return A(n)?{label:n.trim(),href:A(t)?t.trim():void 0}:null}function v(){return n("svg",{viewBox:"0 0 448 512",width:"20",height:"20","aria-hidden":"true",focusable:"false"},n("path",{d:"M304 128a80 80 0 1 0 -160 0 80 80 0 1 0 160 0zM96 128a128 128 0 1 1 256 0A128 128 0 1 1 96 128zM49.3 464l349.5 0c-8.9-63.3-63.3-112-129-112l-91.4 0c-65.7 0-120.1 48.7-129 112zM0 482.3C0 383.8 79.8 304 178.3 304l91.4 0C368.2 304 448 383.8 448 482.3c0 16.4-13.3 29.7-29.7 29.7L29.7 512C13.3 512 0 498.7 0 482.3z",fill:"currentColor"}))}function b(){return n("svg",{viewBox:"0 0 24 24",width:"28",height:"28","aria-hidden":"true",focusable:"false",fill:"none"},n("path",{d:"M4 7h16M4 12h16M4 17h16",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round"}))}function w(){return n("svg",{viewBox:"0 0 24 24",width:"24",height:"24","aria-hidden":"true",focusable:"false",fill:"none"},n("path",{d:"M6 6l12 12M18 6L6 18",stroke:"currentColor","stroke-width":"2","stroke-linecap":"round"}))}function C({expanded:e}){return n("span",{class:"toggle-icon","aria-hidden":"true"},n("svg",{viewBox:"0 0 24 24",width:"14",height:"14",fill:"none"},n("path",e?{d:"M6 12h12",stroke:"currentColor","stroke-width":"2.5","stroke-linecap":"round"}:{d:"M12 6v12M6 12h12",stroke:"currentColor","stroke-width":"2.5","stroke-linecap":"round"})))}function m(){return n("a",{class:"logo-link",href:"/","aria-label":"Home"},n("img",{class:"logo",src:"data:image/png;base64,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",alt:"WEG",width:"225",height:"83"}))}const y=class{constructor(n){e(this,n),this.wegAuthClick=t(this,"wegAuthClick")}layout;signedIn=!1;wegAuthClick;get el(){return i(this)}resolved=h;menuOpen=!1;openDropdown=null;expandedSection=null;boundHandleDocumentClick=this.handleDocumentClick.bind(this);resolve(){this.resolved=null!=this.layout?function(e){const n=e&&"object"==typeof e?e:{},t=n.header&&"object"==typeof n.header?n.header:{};return{dropdowns:p(t.dropdowns),links:r(t.links),signIn:x(t.signIn),signOut:g(t.signOut)}}(o(this.layout)):h}componentWillLoad(){this.resolve()}connectedCallback(){document.addEventListener("click",this.boundHandleDocumentClick)}disconnectedCallback(){document.removeEventListener("click",this.boundHandleDocumentClick)}watchLayout(){this.resolve()}handleKeyDown(e){"Escape"===e.key&&(this.menuOpen=!1,this.openDropdown=null)}handleDocumentClick(e){const n=e.target;n&&this.el.contains(n)||(this.openDropdown=null)}toggleDropdown(e){this.openDropdown=this.openDropdown===e?null:e}toggleAccordion(e){this.expandedSection=this.expandedSection===e?null:e}openMenu(){this.menuOpen=!0,this.expandedSection=null}closeMenu(){this.menuOpen=!1,this.expandedSection=null}getAuthControl(){if(this.signedIn){const e=this.resolved.signOut;return e?{label:e.label,href:e.href,action:"sign-out"}:null}const e=this.resolved.signIn;return e?{label:e.label,href:e.href,action:"sign-in"}:null}handleAuthClick(e,n){const t=this.getAuthControl();if(t)return this.wegAuthClick.emit({action:t.action}).defaultPrevented?(e.preventDefault(),void n?.()):"sign-out"===t.action?(e.preventDefault(),t.href&&window.location.assign(t.href),void n?.()):void n?.()}renderAuthControl(e){const t=this.getAuthControl();if(!t)return null;const i={"sign-in-link":!e.iconOnly,"icon-button":!!e.iconOnly,"auth-button":"sign-out"===t.action&&!t.href,[e.className||""]:!!e.className},o=[n(v,{key:"icon"}),e.iconOnly?null:t.label,e.iconOnly?n("span",{class:"sr-only"},t.label):null];return"sign-out"!==t.action||t.href?n("a",{class:i,href:t.href,"aria-label":t.label,onClick:n=>this.handleAuthClick(n,e.onNavigate)},o):n("button",{type:"button",class:i,"aria-label":t.label,onClick:n=>this.handleAuthClick(n,e.onNavigate)},o)}renderDesktop(){const{dropdowns:e,links:t}=this.resolved;return n("div",{class:"desktop"},n(m,null),n("nav",{class:"desktop-nav","aria-label":"Main"},n("ul",{class:"desktop-nav__list"},e.map((e=>{const t=this.openDropdown===e.label;return n("li",{class:"desktop-nav__item",key:e.label},n("button",{type:"button",class:{"dropdown-trigger":!0,"dropdown-trigger--open":t},"aria-expanded":t?"true":"false","aria-haspopup":"true",onClick:n=>{n.stopPropagation(),this.toggleDropdown(e.label)}},e.label,n(C,{expanded:t})),t?n("div",{class:"dropdown-panel",role:"region","aria-label":e.label},n("div",{class:"dropdown-panel__accent"},n("div",{class:"dropdown-panel__links"},e.items.map((t=>n("a",{class:"dropdown-panel__link",href:t.href,key:`${e.label}:${t.label}`},t.label)))))):null)})),t.map((e=>n("li",{class:"desktop-nav__item",key:e.label},n("a",{class:"nav-link",href:e.href},e.label)))),this.getAuthControl()?n("li",{class:"desktop-nav__item"},this.renderAuthControl({})):null)))}renderMobileBar(){return n("div",{class:"mobile"},n("button",{type:"button",class:"icon-button","aria-label":"Open menu",onClick:()=>this.openMenu()},n(b,null)),n(m,null),this.renderAuthControl({iconOnly:!0}))}renderMobileOverlay(){if(!this.menuOpen)return null;const{dropdowns:e,links:t}=this.resolved;return n("div",{class:"mobile-overlay",role:"dialog","aria-modal":"true","aria-label":"Menu"},n("div",{class:"mobile-overlay__header"},n("button",{type:"button",class:"icon-button","aria-label":"Close menu",onClick:()=>this.closeMenu()},n(w,null)),n("div",{class:"mobile-overlay__logo"},n(m,null)),this.renderAuthControl({iconOnly:!0,onNavigate:()=>this.closeMenu()})),n("nav",{class:"mobile-nav","aria-label":"Main"},e.map((e=>{const t=this.expandedSection===e.label;return n("div",{class:"mobile-nav__section",key:e.label},n("button",{type:"button",class:"mobile-nav__row","aria-expanded":t?"true":"false",onClick:()=>this.toggleAccordion(e.label)},n("span",null,e.label),n(C,{expanded:t})),t?n("div",{class:"mobile-nav__sub"},e.items.map((t=>n("a",{class:"mobile-nav__sub-link",href:t.href,key:`${e.label}:${t.label}`,onClick:()=>this.closeMenu()},t.label)))):null)})),t.map((e=>n("div",{class:"mobile-nav__section",key:e.label},n("a",{class:"mobile-nav__row",href:e.href,onClick:()=>this.closeMenu()},e.label))))))}render(){return n("header",{key:"f16ea624896309add59b6416a69d704a7409dda0",class:"header"},n("div",{key:"4e85f00cb560467ffde9f4f1edd3f1e039978e2c",class:"container"},this.renderDesktop(),this.renderMobileBar()),this.renderMobileOverlay())}static get watchers(){return{layout:[{watchLayout:0}]}}};y.style=":host{display:block;--weg-font-family:ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, 'Apple Color Emoji', 'Segoe UI Emoji';--weg-color-accent:#948eeb}.container{max-width:1024px;margin:0 auto;padding:12px 16px}@media (min-width: 768px){.container{padding:20px 16px}}@media (min-width: 1280px){.container{padding:28px 16px}}.container--stack{display:flex;flex-direction:column;align-items:center;gap:20px}@media (min-width: 768px){.container--stack{gap:36px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border:0}.header{width:100%;border-bottom:2px solid var(--weg-color-accent);background:#ffffff;color:#0f172a;font-family:var(--weg-font-family)}@media (min-width: 768px){.header{border-bottom-width:4px}}.logo-link{display:inline-flex;align-items:center;text-decoration:none;outline:none}.logo-link:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:4px;border-radius:4px}.logo{height:40px;width:auto}@media (min-width: 768px){.logo{height:80px}}.desktop{display:none}@media (min-width: 768px){.desktop{display:flex;width:100%;align-items:center;justify-content:space-between;gap:24px}}.desktop-nav{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:16px}.desktop-nav__list{display:flex;align-items:center;flex-wrap:wrap;gap:16px;list-style:none;margin:0;padding:0}.desktop-nav__item{position:relative}.nav-link{font-weight:600;color:inherit;text-decoration:none;outline:none}.nav-link:hover{opacity:0.85}.nav-link:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:4px;border-radius:4px}.dropdown-trigger{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:none;border-radius:8px;background:transparent;font:inherit;font-weight:600;color:inherit;cursor:pointer;outline:none}.dropdown-trigger:hover{opacity:0.85}.dropdown-trigger:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:2px}.dropdown-trigger--open{background:#f1f5f9}.toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:999px;background:#312e81;color:#ffffff;flex-shrink:0}.dropdown-panel{position:absolute;top:calc(100% + 8px);left:0;z-index:50;min-width:280px;padding:12px 0 12px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;box-shadow:0 4px 16px rgba(15, 23, 42, 0.08)}.dropdown-panel__accent{border-left:4px solid var(--weg-color-accent);padding-left:12px}.dropdown-panel__links{display:flex;flex-direction:column;gap:4px}.dropdown-panel__link{display:block;padding:8px 12px 8px 0;font-weight:600;color:inherit;text-decoration:none;outline:none}.dropdown-panel__link:hover{opacity:0.85}.dropdown-panel__link:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:2px;border-radius:4px}.sign-in-link,.auth-button{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:inherit;text-decoration:none;outline:none}.auth-button{padding:0;border:none;background:transparent;font:inherit;cursor:pointer}.sign-in-link:hover,.auth-button:hover{opacity:0.85}.sign-in-link:focus-visible,.auth-button:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:4px;border-radius:4px}.mobile{display:flex;width:100%;align-items:center;justify-content:space-between;gap:12px}@media (min-width: 768px){.mobile{display:none}}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:8px;background:transparent;color:inherit;cursor:pointer;text-decoration:none;outline:none}.icon-button:hover{background:#f1f5f9}.icon-button:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:2px}.mobile-overlay{position:fixed;inset:0;z-index:100;background:#ffffff;overflow-y:auto}.mobile-overlay__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:2px solid var(--weg-color-accent)}.mobile-overlay__logo{flex:1;display:flex;justify-content:center}.mobile-overlay__logo .logo{height:40px}.mobile-nav{padding:0 16px 24px}.mobile-nav__section{border-bottom:1px solid #d8d4f7}.mobile-nav__row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:16px 0;border:none;background:transparent;font:inherit;font-weight:600;color:inherit;text-align:left;text-decoration:none;cursor:pointer;outline:none}.mobile-nav__row:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:2px;border-radius:4px}.mobile-nav__sub{padding:0 0 12px 0}.mobile-nav__sub-link{display:block;padding:10px 0;font-weight:400;color:inherit;text-decoration:none;outline:none}.mobile-nav__sub-link:focus-visible{outline:2px solid var(--weg-color-accent);outline-offset:2px;border-radius:4px}.mobile-nav__sub-link:hover{opacity:0.85}";export{u as weg_footer,y as weg_header}
@@ -1 +1 @@
1
- import{p as o,b as t}from"./p-QiJxC4Ow.js";export{s as setNonce}from"./p-QiJxC4Ow.js";import{g as a}from"./p-DQuL1Twl.js";(()=>{const t=import.meta.url,a={};return""!==t&&(a.resourcesUrl=new URL(".",t).href),o(a)})().then((async o=>(await a(),t([["p-d1addb13",[[513,"my-component",{first:[1],middle:[1],last:[1]}]]],["p-99843bbd",[[513,"weg-footer",{layout:[1],resolved:[32]},null,{layout:[{watchLayout:0}]}]]]],o))));
1
+ import{p as e,b as o}from"./p-D8pmhPiH.js";export{s as setNonce}from"./p-D8pmhPiH.js";import{g as a}from"./p-DQuL1Twl.js";(()=>{const o=import.meta.url,a={};return""!==o&&(a.resourcesUrl=new URL(".",o).href),e(a)})().then((async e=>(await a(),o([["p-eaf953a4",[[513,"weg-footer",{layout:[1],resolved:[32]},null,{layout:[{watchLayout:0}]}],[513,"weg-header",{layout:[1],signedIn:[516,"signed-in"],resolved:[32],menuOpen:[32],openDropdown:[32],expandedSection:[32]},[[8,"keydown","handleKeyDown"]],{layout:[{watchLayout:0}]}]]],["p-d61033bd",[[513,"my-component",{first:[1],middle:[1],last:[1]}]]]],e))));
package/docs/angular.md CHANGED
@@ -2,6 +2,15 @@
2
2
 
3
3
  Assumes Angular 17+ with **standalone** components (default for `ng new`).
4
4
 
5
+ ## Components
6
+
7
+ | Tag | Import (optional, no loader) |
8
+ | --- | --- |
9
+ | `<weg-header>` | `import 'weg-shared-layout/weg-header';` |
10
+ | `<weg-footer>` | `import 'weg-shared-layout/weg-footer';` |
11
+
12
+ Both accept the same `layout` payload ([`dummy-data.json`](../src/assets/dummy-data.json)). `<weg-header>` also accepts **`signed-in`** and emits **`wegAuthClick`**.
13
+
5
14
  ## 1. Install
6
15
 
7
16
  ```bash
@@ -10,7 +19,7 @@ npm i weg-shared-layout
10
19
 
11
20
  ## 2. Register custom elements (once, before bootstrap)
12
21
 
13
- In `src/main.ts`, call `defineCustomElements()` **before** `bootstrapApplication` so the browser recognises `<weg-footer>`.
22
+ In `src/main.ts`, call `defineCustomElements()` **before** `bootstrapApplication`:
14
23
 
15
24
  ```ts
16
25
  import { bootstrapApplication } from '@angular/platform-browser';
@@ -24,17 +33,22 @@ defineCustomElements();
24
33
  bootstrapApplication(App, appConfig).catch((err) => console.error(err));
25
34
  ```
26
35
 
27
- If `defineCustomElements` is async in your Stencil build, `await` it (or chain `.then()`) before bootstrapping so the custom element is defined before the first render.
36
+ If `defineCustomElements` is async in your Stencil build, `await` it before bootstrapping.
28
37
 
29
- ## 3. Allow custom elements in templates
38
+ **Alternative:** side-effect import only the tags you need (no loader call):
30
39
 
31
- Add `schemas: [CUSTOM_ELEMENTS_SCHEMA]` to every `@Component` whose template uses `<weg-footer>` (it does not cascade from the root through `router-outlet` children).
40
+ ```ts
41
+ import 'weg-shared-layout/weg-header';
42
+ import 'weg-shared-layout/weg-footer';
43
+ ```
32
44
 
33
- ## 4. Pass layout with property binding
45
+ ## 3. Allow custom elements in templates
34
46
 
35
- Use **`[layout]="..."`** so Angular sets the element’s JavaScript `layout` property (Stencil `@Prop()`), not an HTML attribute.
47
+ Add `schemas: [CUSTOM_ELEMENTS_SCHEMA]` to every `@Component` whose template uses `<weg-header>` or `<weg-footer>` (does not cascade through `router-outlet` children).
36
48
 
37
- Example with the bundled sample payload:
49
+ ## 4. Layout shell example
50
+
51
+ Use **`[layout]="..."`** so Angular sets the JavaScript `layout` property, not an HTML attribute.
38
52
 
39
53
  ```ts
40
54
  // src/app/app.ts
@@ -51,35 +65,62 @@ import layoutFixture from 'weg-shared-layout/dummy-data.json';
51
65
  })
52
66
  export class App {
53
67
  protected readonly layoutData = signal(layoutFixture);
68
+ protected readonly signedIn = signal(false);
69
+
70
+ protected onAuthClick(event: Event) {
71
+ const customEvent = event as CustomEvent<{ action: 'sign-in' | 'sign-out' }>;
72
+ customEvent.preventDefault();
73
+
74
+ if (customEvent.detail.action === 'sign-out') {
75
+ // call your logout service
76
+ this.signedIn.set(false);
77
+ return;
78
+ }
79
+
80
+ // navigate to sign-in, e.g. inject Router
81
+ window.location.href = '/account/login';
82
+ }
54
83
  }
55
84
  ```
56
85
 
57
86
  ```html
58
87
  <!-- src/app/app.html -->
88
+ <weg-header
89
+ [layout]="layoutData()"
90
+ [signedIn]="signedIn()"
91
+ (wegAuthClick)="onAuthClick($event)"
92
+ ></weg-header>
93
+
59
94
  <router-outlet />
95
+
60
96
  <weg-footer [layout]="layoutData()"></weg-footer>
61
97
  ```
62
98
 
63
- Enable `resolveJsonModule` in the TypeScript config used by the app (e.g. `tsconfig.app.json`) if you import `dummy-data.json`.
99
+ Enable `resolveJsonModule` in `tsconfig.app.json` if you import `dummy-data.json`.
64
100
 
65
- In production, replace `layoutFixture` with data from your own services; keep the same object shape as `dummy-data.json`.
101
+ In production, replace `layoutFixture` with data from your services; keep the same object shape.
66
102
 
67
- ### Alternative: register only `<weg-footer>`
103
+ ## Header: `signed-in` and `wegAuthClick`
68
104
 
69
- To avoid the full lazy bundle (e.g. simpler bundling with some dev servers), you can side-effect import the custom-elements bundle instead of the loader:
105
+ | Input / output | Binding | Notes |
106
+ | --- | --- | --- |
107
+ | Session state | `[signedIn]="signedIn()"` | When `true`, shows `layout.header.signOut` instead of `signIn` |
108
+ | Auth click | `(wegAuthClick)="onAuthClick($event)"` | `event.detail.action` is `'sign-in'` or `'sign-out'` |
109
+ | Prevent default | `event.preventDefault()` in handler | Stops link navigation / `signOut.href` redirect |
70
110
 
71
- ```ts
72
- import 'weg-shared-layout/weg-footer';
73
- ```
111
+ Logo is bundled in the component — not configurable via `layout`.
112
+
113
+ ## Footer
74
114
 
75
- Then bootstrap as usual (no `defineCustomElements()` call required for that tag).
115
+ `<weg-footer>` only needs `[layout]`. See [`dummy-data.json`](../src/assets/dummy-data.json) for the `footer` shape (social, columns, credits, copyright).
76
116
 
77
117
  ## Troubleshooting
78
118
 
79
119
  | Symptom | Cause / fix |
80
120
  | --- | --- |
81
- | `'weg-footer' is not a known element` | Add `schemas: [CUSTOM_ELEMENTS_SCHEMA]` on the component whose template contains `<weg-footer>`. |
82
- | Footer missing or empty box | `defineCustomElements()` not called before bootstrap (or footer bundle not imported), or `layout` not set / wrong shape — compare with `dummy-data.json`. |
121
+ | `'weg-header'` / `'weg-footer'` is not a known element | Add `CUSTOM_ELEMENTS_SCHEMA` on the component template that uses the tag. |
122
+ | Header/footer empty | `defineCustomElements()` not called before bootstrap, tag bundle not imported, or `layout` not set — compare with `dummy-data.json`. |
123
+ | Auth always shows Sign in | `[signedIn]` not bound or still `false`. |
83
124
  | SSR: `document is not defined` | Guard `defineCustomElements()` with `typeof window !== 'undefined'` or `isPlatformBrowser`. |
84
125
 
85
126
  ## TypeScript typings
@@ -90,4 +131,11 @@ Then bootstrap as usual (no `defineCustomElements()` call required for that tag)
90
131
 
91
132
  ## Legacy `NgModule`
92
133
 
93
- Add `CUSTOM_ELEMENTS_SCHEMA` once on the module that declares components using `<weg-footer>`. `defineCustomElements()` in `main.ts` is still required when using the loader.
134
+ Add `CUSTOM_ELEMENTS_SCHEMA` on the module that declares components using these tags. `defineCustomElements()` in `main.ts` is still required when using the loader.
135
+
136
+ ## See also
137
+
138
+ - **[React SPA](./react.md)**
139
+ - **[Next.js App Router](./nextjs.md)**
140
+ - **[Plain HTML / vanilla JS](./vanilla.md)**
141
+ - **[Package readme](../readme.md)**