@proximus/lavender-selectablebox 2.0.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,14 @@
1
+ import { WithExtraAttributes } from '@proximus/lavender-common';
2
+ import '@proximus/lavender-layout';
3
+ export declare class SelectableBox extends WithExtraAttributes {
4
+ protected template(): string;
5
+ constructor();
6
+ connectedCallback(): void;
7
+ static get observedAttributes(): string[];
8
+ attributeChangedCallback(attrName: string, oldValue: string, newValue: string): void;
9
+ get $el(): HTMLElement;
10
+ get inverted(): boolean;
11
+ set inverted(value: boolean);
12
+ get hideFooter(): boolean;
13
+ set hideFooter(value: boolean);
14
+ }
@@ -0,0 +1,39 @@
1
+ import { WithExtraAttributes } from '@proximus/lavender-common';
2
+ import '@proximus/lavender-layout';
3
+ import { SelectableBox } from './SelectableBox';
4
+ import { type Checkbox } from '@proximus/lavender-checkbox';
5
+ export declare class SelectableBoxCheckbox extends WithExtraAttributes {
6
+ protected internals: ElementInternals;
7
+ protected template(): string;
8
+ constructor();
9
+ connectedCallback(): void;
10
+ static get observedAttributes(): string[];
11
+ attributeChangedCallback(attrName: string, oldValue: string, newValue: string): void;
12
+ disconnectedCallback(): void;
13
+ private removeHoverAttribute;
14
+ private setHoverAttribute;
15
+ private setKeypressEvent;
16
+ private setClickEvent;
17
+ toggleFooterVisibility(): void;
18
+ handleDisabledAttributeChange(disabled: boolean): void;
19
+ handleCheckedAttributeChange(newValue: string): void;
20
+ static get formAssociated(): boolean;
21
+ formResetCallback(): void;
22
+ formStateRestoreCallback(state: any): void;
23
+ formData(): FormData;
24
+ get $el(): HTMLElement;
25
+ get $selectableBox(): SelectableBox;
26
+ get $checkbox(): Checkbox;
27
+ get $slotFooter(): HTMLSlotElement;
28
+ get $slottedFooter(): HTMLElement;
29
+ get inverted(): boolean;
30
+ set inverted(value: boolean);
31
+ get checked(): boolean;
32
+ set checked(value: boolean);
33
+ get name(): string;
34
+ set name(value: string);
35
+ get disabled(): boolean;
36
+ set disabled(value: boolean);
37
+ get value(): string;
38
+ set value(value: string);
39
+ }
@@ -0,0 +1,39 @@
1
+ import { WithExtraAttributes } from '@proximus/lavender-common';
2
+ import '@proximus/lavender-layout';
3
+ import { SelectableBox } from './SelectableBox';
4
+ import { type RadioBase } from '@proximus/lavender-radio-group';
5
+ export declare class SelectableBoxRadio extends WithExtraAttributes {
6
+ protected internals: ElementInternals;
7
+ protected template(): string;
8
+ constructor();
9
+ connectedCallback(): void;
10
+ static get observedAttributes(): string[];
11
+ attributeChangedCallback(attrName: string, oldValue: string, newValue: string): void;
12
+ disconnectedCallback(): void;
13
+ private removeHoverAttribute;
14
+ private setHoverAttribute;
15
+ private setKeypressEvent;
16
+ private setClickEvent;
17
+ toggleFooterVisibility(): void;
18
+ handleDisabledAttributeChange(disabled: boolean): void;
19
+ handleCheckedAttributeChange(newValue: string): void;
20
+ static get formAssociated(): boolean;
21
+ formResetCallback(): void;
22
+ formStateRestoreCallback(state: any): void;
23
+ formData(): FormData;
24
+ get $el(): HTMLElement;
25
+ get $selectableBox(): SelectableBox;
26
+ get $radio(): RadioBase;
27
+ get $slotFooter(): HTMLSlotElement;
28
+ get $slottedFooter(): HTMLElement;
29
+ get inverted(): boolean;
30
+ set inverted(value: boolean);
31
+ get checked(): boolean;
32
+ set checked(value: boolean);
33
+ get name(): string;
34
+ set name(value: string);
35
+ get disabled(): boolean;
36
+ set disabled(value: boolean);
37
+ get value(): string;
38
+ set value(value: string);
39
+ }
@@ -0,0 +1,3 @@
1
+ export * from './SelectableBox';
2
+ export * from './SelectableBoxCheckbox';
3
+ export * from './SelectableBoxRadio';
@@ -0,0 +1,1024 @@
1
+ import { WithExtraAttributes as n, AttributeBreakpointHandlerDelegate as f, gapValues as v, checkName as m, backgroundColorValues as k } from "@proximus/lavender-common";
2
+ const A = ':host{display:block}:host([overflow-x="auto"]){margin:calc(calc(var(--px-focus-outline-mobile) + var(--px-focus-offset-mobile)) * -1)}:host([overflow-x="auto"]) .flex-container{padding:calc(var(--px-focus-outline-mobile) + var(--px-focus-offset-mobile))}.flex-container{display:flex;height:100%;width:100%;box-sizing:border-box;flex-direction:var(--flex-direction--mobile-value);gap:var(--flex-gap--mobile-value);flex-wrap:var(--flex-wrap--mobile-value);justify-content:var(--flex-justify-content--mobile-value);align-items:var(--flex-align-items--mobile-value);overflow-x:var(--overflow-x-all)}@media only screen and (max-width: 47.9375em){.flex-container{overflow-x:var(--overflow-x-all-mobile, var(--overflow-x-all));scrollbar-width:none}.flex-container::-webkit-scrollbar{display:none}}@media only screen and (min-width: 48em){.flex-container{flex-direction:var(--flex-direction--tablet-value);gap:var(--flex-gap--tablet-value);flex-wrap:var(--flex-wrap--tablet-value);justify-content:var(--flex-justify-content--tablet-value);align-items:var(--flex-align-items--tablet-value)}:host([overflow-x="auto"]){margin:calc(calc(var(--px-focus-outline-tablet) + var(--px-focus-offset-tablet)) * -1)}:host([overflow-x="auto"]) .flex-container{padding:calc(var(--px-focus-outline-tablet) + var(--px-focus-offset-tablet))}}@media only screen and (min-width: 48em) and (max-width: 64em){.flex-container{overflow-x:var(--overflow-x-all-tablet, var(--overflow-x-all));scrollbar-width:none}.flex-container::-webkit-scrollbar{display:none}}@media only screen and (min-width: 64.0625em){.flex-container{flex-direction:var(--flex-direction--laptop-value);gap:var(--flex-gap--laptop-value);flex-wrap:var(--flex-wrap--laptop-value);justify-content:var(--flex-justify-content--laptop-value);align-items:var(--flex-align-items--laptop-value)}:host([overflow-x="auto"]){margin:calc(calc(var(--px-focus-outline-laptop) + var(--px-focus-offset-laptop)) * -1)}:host([overflow-x="auto"]) .flex-container{padding:calc(var(--px-focus-outline-laptop) + var(--px-focus-offset-laptop))}}@media only screen and (min-width: 64.0625em) and (max-width: 90em){.flex-container{overflow-x:var(--overflow-x-all-laptop, var(--overflow-x-all))}}@media only screen and (min-width: 90.0625em){.flex-container{flex-direction:var(--flex-direction--desktop-value);gap:var(--flex-gap--desktop-value);flex-wrap:var(--flex-wrap--desktop-value);justify-content:var(--flex-justify-content--desktop-value);align-items:var(--flex-align-items--desktop-value);overflow-x:var(--overflow-x-all-desktop, var(--overflow-x-all))}:host([overflow-x="auto"]){margin:calc(calc(var(--px-focus-outline-desktop) + var(--px-focus-offset-desktop)) * -1)}:host([overflow-x="auto"]) .flex-container{padding:calc(var(--px-focus-outline-desktop) + var(--px-focus-offset-desktop))}}', b = new CSSStyleSheet();
3
+ b.replaceSync(A);
4
+ const y = [
5
+ "",
6
+ "default",
7
+ "row",
8
+ "row-reverse",
9
+ "column",
10
+ "column-reverse"
11
+ ], w = [
12
+ "",
13
+ "default",
14
+ "stretch",
15
+ "flex-start",
16
+ "flex-end",
17
+ "center",
18
+ "baseline"
19
+ ], $ = [
20
+ "",
21
+ "default",
22
+ "flex-start",
23
+ "flex-end",
24
+ "center",
25
+ "space-between",
26
+ "space-around",
27
+ "space-evenly"
28
+ ], C = ["", "default", "nowrap", "wrap", "wrap-reverse"], S = ["", "visible", "hidden", "scroll", "auto"];
29
+ class c extends n {
30
+ constructor() {
31
+ super(b), this.overflowXAttributeDelegate = new f(
32
+ this,
33
+ "overflow-x",
34
+ (t) => t,
35
+ "--overflow-x"
36
+ ), this.template = `<div class="flex-container">
37
+ <slot></slot>
38
+ </div>`, this.shadowRoot.innerHTML = this.template;
39
+ }
40
+ connectedCallback() {
41
+ this.hasAttribute("direction") || (this.direction = "row"), this.hasAttribute("gap") || (this.gap = "none"), this.hasAttribute("align-items") || (this.alignItems = "stretch"), this.hasAttribute("justify-content") || (this.justifyContent = "flex-start"), this.hasAttribute("wrap") || (this.wrap = "nowrap"), this.hasAttribute("overflow-x") || this.overflowXAttributeDelegate.init("visible");
42
+ }
43
+ static get observedAttributes() {
44
+ return [
45
+ ...super.observedAttributes,
46
+ "direction",
47
+ "direction--mobile",
48
+ "direction--tablet",
49
+ "direction--laptop",
50
+ "direction--desktop",
51
+ "gap",
52
+ "gap--mobile",
53
+ "gap--tablet",
54
+ "gap--laptop",
55
+ "gap--desktop",
56
+ "justify-content",
57
+ "justify-content--mobile",
58
+ "justify-content--tablet",
59
+ "justify-content--laptop",
60
+ "justify-content--desktop",
61
+ "align-items",
62
+ "align-items--mobile",
63
+ "align-items--tablet",
64
+ "align-items--laptop",
65
+ "align-items--desktop",
66
+ "wrap",
67
+ "wrap--mobile",
68
+ "wrap--tablet",
69
+ "wrap--laptop",
70
+ "wrap--desktop",
71
+ "overflow-x",
72
+ "overflow-x--mobile",
73
+ "overflow-x--tablet",
74
+ "overflow-x--laptop",
75
+ "overflow-x--desktop"
76
+ ];
77
+ }
78
+ attributeChangedCallback(t, e, i) {
79
+ switch (t) {
80
+ case "gap":
81
+ case "gap--mobile":
82
+ case "gap--tablet":
83
+ case "gap--laptop":
84
+ case "gap--desktop":
85
+ this.updateFlexProperties(t, e, i, v);
86
+ break;
87
+ case "justify-content":
88
+ case "justify-content--mobile":
89
+ case "justify-content--tablet":
90
+ case "justify-content--laptop":
91
+ case "justify-content--desktop":
92
+ this.updateFlexProperties(
93
+ t,
94
+ e,
95
+ i,
96
+ $
97
+ );
98
+ break;
99
+ case "align-items":
100
+ case "align-items--mobile":
101
+ case "align-items--tablet":
102
+ case "align-items--laptop":
103
+ case "align-items--desktop":
104
+ this.updateFlexProperties(t, e, i, w);
105
+ break;
106
+ case "wrap":
107
+ case "wrap--mobile":
108
+ case "wrap--tablet":
109
+ case "wrap--laptop":
110
+ case "wrap--desktop":
111
+ this.updateFlexProperties(t, e, i, C);
112
+ break;
113
+ case "direction":
114
+ case "direction--mobile":
115
+ case "direction--tablet":
116
+ case "direction--laptop":
117
+ case "direction--desktop":
118
+ this.updateFlexProperties(t, e, i, y);
119
+ break;
120
+ case "overflow-x":
121
+ case "overflow-x--mobile":
122
+ case "overflow-x--tablet":
123
+ case "overflow-x--laptop":
124
+ case "overflow-x--desktop":
125
+ this.updateOverflowX(t, e, i, S);
126
+ break;
127
+ default:
128
+ super.attributeChangedCallback(t, e, i);
129
+ break;
130
+ }
131
+ }
132
+ updateOverflowX(t, e, i, o) {
133
+ if (!m(o, i)) {
134
+ console.error(`${i} is not an allowed ${t} value`);
135
+ return;
136
+ }
137
+ this.overflowXAttributeDelegate.attributeChangedCallback(
138
+ t,
139
+ e,
140
+ i
141
+ );
142
+ }
143
+ updateFlexProperties(t, e, i, o) {
144
+ this.checkName(o, i) || console.error(`${i} is not a valid value for ${o}`);
145
+ const d = t.indexOf("--") > -1, s = d ? t.split("--")[0] : t, a = [];
146
+ if (!d)
147
+ this.getAttribute(s + "--mobile") || a.push("mobile"), this.getAttribute(s + "--tablet") || a.push("tablet"), this.getAttribute(s + "--laptop") || a.push("laptop"), this.getAttribute(s + "--desktop") || a.push("desktop"), a.forEach((l) => {
148
+ this.updateStyle(s, l, e, o), this.updateStyle(s, l, i, o);
149
+ });
150
+ else {
151
+ const l = t.split("--")[1];
152
+ this.updateStyle(s, l, e, o), this.updateStyle(s, l, i, o);
153
+ }
154
+ }
155
+ updateStyle(t, e, i, o) {
156
+ i && (t === "gap" && o && o.includes(i) ? this.$el.style.setProperty(
157
+ `--flex-${t}--${e}-value`,
158
+ `var(--px-spacing-${i}-${e === "laptop" ? "desktop" : e})`
159
+ ) : this.$el.style.setProperty(
160
+ `--flex-${t}--${e}-value`,
161
+ i
162
+ ));
163
+ }
164
+ get direction() {
165
+ return this.getAttribute("direction");
166
+ }
167
+ set direction(t) {
168
+ this.setAttribute("direction", t);
169
+ }
170
+ get directionMobile() {
171
+ return this.getAttribute("direction--mobile");
172
+ }
173
+ set directionMobile(t) {
174
+ this.setAttribute("direction--mobile", t);
175
+ }
176
+ get directionTablet() {
177
+ return this.getAttribute("direction--tablet");
178
+ }
179
+ set directionTablet(t) {
180
+ this.setAttribute("direction--tablet", t);
181
+ }
182
+ get directionLaptop() {
183
+ return this.getAttribute("direction--laptop");
184
+ }
185
+ set directionLaptop(t) {
186
+ this.setAttribute("direction--laptop", t);
187
+ }
188
+ get directionDesktop() {
189
+ return this.getAttribute("direction--desktop");
190
+ }
191
+ set directionDesktop(t) {
192
+ this.setAttribute("direction--desktop", t);
193
+ }
194
+ get gap() {
195
+ return this.getAttribute("gap");
196
+ }
197
+ set gap(t) {
198
+ this.setAttribute("gap", t);
199
+ }
200
+ get gapMobile() {
201
+ return this.getAttribute("gap--mobile");
202
+ }
203
+ set gapMobile(t) {
204
+ this.setAttribute("gap--mobile", t);
205
+ }
206
+ get gapTablet() {
207
+ return this.getAttribute("gap--tablet");
208
+ }
209
+ set gapTablet(t) {
210
+ this.setAttribute("gap--tablet", t);
211
+ }
212
+ get gapLaptop() {
213
+ return this.getAttribute("gap--laptop");
214
+ }
215
+ set gapLaptop(t) {
216
+ this.setAttribute("gap--laptop", t);
217
+ }
218
+ get gapDesktop() {
219
+ return this.getAttribute("gap--desktop");
220
+ }
221
+ set gapDesktop(t) {
222
+ this.setAttribute("gap--desktop", t);
223
+ }
224
+ get justifyContent() {
225
+ return this.getAttribute("justify-content");
226
+ }
227
+ set justifyContent(t) {
228
+ this.setAttribute("justify-content", t);
229
+ }
230
+ get justifyContentMobile() {
231
+ return this.getAttribute("justify-content--mobile");
232
+ }
233
+ set justifyContentMobile(t) {
234
+ this.setAttribute("justify-content--mobile", t);
235
+ }
236
+ get justifyContentTablet() {
237
+ return this.getAttribute("justify-content--tablet");
238
+ }
239
+ set justifyContentTablet(t) {
240
+ this.setAttribute("justify-content--tablet", t);
241
+ }
242
+ get justifyContentLaptop() {
243
+ return this.getAttribute("justify-content--laptop");
244
+ }
245
+ set justifyContentLaptop(t) {
246
+ this.setAttribute("justify-content--laptop", t);
247
+ }
248
+ get justifyContentDesktop() {
249
+ return this.getAttribute("justify-content--desktop");
250
+ }
251
+ set justifyContentDesktop(t) {
252
+ this.setAttribute("justify-content--desktop", t);
253
+ }
254
+ get alignItems() {
255
+ return this.getAttribute("align-items");
256
+ }
257
+ set alignItems(t) {
258
+ this.setAttribute("align-items", t);
259
+ }
260
+ get alignItemsMobile() {
261
+ return this.getAttribute("align-items--mobile");
262
+ }
263
+ set alignItemsMobile(t) {
264
+ this.setAttribute("align-items--mobile", t);
265
+ }
266
+ get alignItemsTablet() {
267
+ return this.getAttribute("align-items--tablet");
268
+ }
269
+ set alignItemsTablet(t) {
270
+ this.setAttribute("align-items--tablet", t);
271
+ }
272
+ get alignItemsLaptop() {
273
+ return this.getAttribute("align-items--laptop");
274
+ }
275
+ set alignItemsLaptop(t) {
276
+ this.setAttribute("align-items--laptop", t);
277
+ }
278
+ get alignItemsDesktop() {
279
+ return this.getAttribute("align-items--desktop");
280
+ }
281
+ set alignItemsDesktop(t) {
282
+ this.setAttribute("align-items--desktop", t);
283
+ }
284
+ get wrap() {
285
+ return this.getAttribute("wrap");
286
+ }
287
+ set wrap(t) {
288
+ this.setAttribute("wrap", t);
289
+ }
290
+ get wrapMobile() {
291
+ return this.getAttribute("wrap--mobile");
292
+ }
293
+ set wrapMobile(t) {
294
+ this.setAttribute("wrap--mobile", t);
295
+ }
296
+ get wrapTablet() {
297
+ return this.getAttribute("wrap--tablet");
298
+ }
299
+ set wrapTablet(t) {
300
+ this.setAttribute("wrap--tablet", t);
301
+ }
302
+ get wrapLaptop() {
303
+ return this.getAttribute("wrap--laptop");
304
+ }
305
+ set wrapLaptop(t) {
306
+ this.setAttribute("wrap--laptop", t);
307
+ }
308
+ get wrapDesktop() {
309
+ return this.getAttribute("wrap--desktop");
310
+ }
311
+ set wrapDesktop(t) {
312
+ this.setAttribute("wrap--desktop", t);
313
+ }
314
+ get overflowX() {
315
+ return this.getAttribute("overflow-x");
316
+ }
317
+ set overflowX(t) {
318
+ this.setAttribute("overflow-x", t);
319
+ }
320
+ get overflowXMobile() {
321
+ return this.getAttribute("overflow-x--mobile");
322
+ }
323
+ set overflowXMobile(t) {
324
+ this.setAttribute("overflow-x--mobile", t);
325
+ }
326
+ get overflowXTablet() {
327
+ return this.getAttribute("overflow-x--tablet");
328
+ }
329
+ set overflowXTablet(t) {
330
+ this.setAttribute("overflow-x--tablet", t);
331
+ }
332
+ get overflowXLaptop() {
333
+ return this.getAttribute("overflow-x--laptop");
334
+ }
335
+ set overflowXLaptop(t) {
336
+ this.setAttribute("overflow-x--laptop", t);
337
+ }
338
+ get overflowXDesktop() {
339
+ return this.getAttribute("overflow-x--desktop");
340
+ }
341
+ set overflowXDesktop(t) {
342
+ this.setAttribute("overflow-x--desktop", t);
343
+ }
344
+ get $el() {
345
+ return this.shadowRoot.querySelector(".flex-container");
346
+ }
347
+ }
348
+ customElements.get("px-stack") || customElements.define("px-stack", c);
349
+ class _ extends c {
350
+ constructor() {
351
+ super();
352
+ }
353
+ connectedCallback() {
354
+ super.connectedCallback(), this.direction = "column", this.directionMobile = "column", this.directionTablet = "column", this.directionLaptop = "column", this.directionDesktop = "column";
355
+ }
356
+ }
357
+ customElements.get("px-vstack") || customElements.define("px-vstack", _);
358
+ class E extends c {
359
+ constructor() {
360
+ super();
361
+ }
362
+ connectedCallback() {
363
+ super.connectedCallback(), this.direction = "row", this.directionMobile = "row", this.directionTablet = "row", this.directionLaptop = "row", this.directionDesktop = "row";
364
+ }
365
+ }
366
+ customElements.get("px-hstack") || customElements.define("px-hstack", E);
367
+ class L extends HTMLElement {
368
+ constructor() {
369
+ super();
370
+ }
371
+ static get observedAttributes() {
372
+ return ["grow"];
373
+ }
374
+ attributeChangedCallback(t, e, i) {
375
+ t === "grow" && (this.style.flexGrow = i);
376
+ }
377
+ connectedCallback() {
378
+ this.style.flexGrow = this.getAttribute("grow") || "1";
379
+ }
380
+ get grow() {
381
+ return this.getAttribute("grow");
382
+ }
383
+ set grow(t) {
384
+ this.setAttribute("grow", t);
385
+ }
386
+ }
387
+ customElements.get("px-spacer") || customElements.define("px-spacer", L);
388
+ const j = ":host{display:block;box-sizing:border-box}slot[name=body-container]{min-height:100vh}#image-sticky-box{margin-top:-2.5em}", h = new CSSStyleSheet();
389
+ h.replaceSync(j);
390
+ class D extends n {
391
+ constructor() {
392
+ super(h), this.template = (t) => `
393
+ <px-container border-radius="none" padding="none">
394
+ <px-vstack>
395
+ <px-container id="header-container" border-radius="none">
396
+ <px-hstack>
397
+ <px-spacer></px-spacer>
398
+ <px-vstack
399
+ id="header-vstack-container"
400
+ gap="s"
401
+ grow="${this.grow}"
402
+ basis="${this.basis}"
403
+ >
404
+ <slot name="header-container"></slot>
405
+ </px-vstack>
406
+ <px-spacer></px-spacer>
407
+ </px-hstack>
408
+ </px-container>
409
+ <px-container
410
+ id="image-container"
411
+ border-radius="none"
412
+ padding="none"
413
+ padding-top="xl"
414
+ id="image-box"
415
+ background-size="cover"
416
+ background-position="top center"
417
+ padding-bottom="xl"
418
+ border-radius="none"
419
+ bgimg="${this.backgroundImage}"
420
+ >
421
+ <px-hstack>
422
+ <px-spacer></px-spacer>
423
+ <px-vstack grow="${this.grow}" basis="${this.basis}">
424
+ <slot name="image-container"></slot>
425
+ </px-vstack>
426
+ <px-spacer></px-spacer>
427
+ </px-hstack>
428
+ </px-container>
429
+ ${t ? ` <px-hstack>
430
+ <px-spacer></px-spacer>
431
+ <px-container border-radius="none" box-shadow="xl" id="image-sticky-box" border="s" grow="${this.grow}" basis="${this.basis}" border-radius="m">
432
+ <px-vstack gap="s">
433
+ <slot name="image-sticky-container"></slot>
434
+ </px-vstack>
435
+ </px-container>
436
+ <px-spacer></px-spacer>
437
+ </px-hstack>` : ""}
438
+ <px-container
439
+ id="body-container"
440
+ id="main"
441
+ background-color="${this.backgroundColor}"
442
+ padding="none"
443
+ padding-top="xl"
444
+ padding-bottom="xl"
445
+ >
446
+ <px-hstack>
447
+ <px-spacer></px-spacer>
448
+ <px-vstack
449
+ id="body-vstack-container"
450
+ gap="l"
451
+ grow="${this.grow}"
452
+ basis="${this.basis}"
453
+ >
454
+ <slot name="body-container"></slot>
455
+ </px-vstack>
456
+ <px-spacer></px-spacer>
457
+ </px-hstack>
458
+ </px-container>
459
+ <px-container
460
+ id="contact-container"
461
+ border-radius="none"
462
+ id="main"
463
+ background-color="surface-default"
464
+ padding="none"
465
+ padding-top="xl"
466
+ padding-bottom="xl"
467
+ >
468
+ <px-hstack>
469
+ <px-spacer></px-spacer>
470
+ <px-vstack gap="l" grow="${this.grow}" basis="${this.basis}">
471
+ <slot name="contact-container"></slot>
472
+ </px-vstack>
473
+ <px-spacer></px-spacer>
474
+ </px-hstack>
475
+ </px-container>
476
+ <px-container
477
+ id="footer-container"
478
+ background-color="none"
479
+ border-radius="none"
480
+ style="background-color: rgb(108, 66, 156)"
481
+ padding-top="xl"
482
+ padding-bottom="xl"
483
+ >
484
+ <px-hstack>
485
+ <px-spacer></px-spacer>
486
+ <px-vstack gap="l" grow="${this.grow}" basis="${this.basis}">
487
+ <slot name="footer-container"></slot>
488
+ </px-vstack>
489
+ <px-spacer></px-spacer>
490
+ </px-hstack>
491
+ </px-container>
492
+ </px-vstack>
493
+ </px-container>
494
+ `, this.shadowRoot.innerHTML = this.template(!!this.$imageStickySlot);
495
+ }
496
+ static get observedAttributes() {
497
+ return [
498
+ ...super.observedAttributes,
499
+ "background-image",
500
+ "gap",
501
+ "background-color",
502
+ "padding-vertical",
503
+ "padding-horizontal"
504
+ ];
505
+ }
506
+ get $wideImage() {
507
+ return this.shadowRoot.querySelector("#image-box");
508
+ }
509
+ get $bodyVStackContainer() {
510
+ return this.shadowRoot.querySelector("#header-vstack-container");
511
+ }
512
+ get $bodyContainer() {
513
+ return this.shadowRoot.querySelector("#body-container");
514
+ }
515
+ get $contactContainer() {
516
+ return this.shadowRoot.querySelector("#contact-container");
517
+ }
518
+ get $footerContainer() {
519
+ return this.shadowRoot.querySelector("#footer-container");
520
+ }
521
+ get $headerContainer() {
522
+ return this.shadowRoot.querySelector("#header-container");
523
+ }
524
+ get $imageContainer() {
525
+ return this.shadowRoot.querySelector("#image-container");
526
+ }
527
+ get backgroundImage() {
528
+ return this.getAttribute("background-image");
529
+ }
530
+ get $imageStickySlot() {
531
+ return this.querySelector('*[slot="image-sticky-container"]');
532
+ }
533
+ get $main() {
534
+ return this.shadowRoot.querySelector("#main");
535
+ }
536
+ get backgroundColor() {
537
+ return this.getAttribute("background-color") || "none";
538
+ }
539
+ get paddingVertical() {
540
+ return this.getAttribute("padding-vertical");
541
+ }
542
+ get paddingHorizontal() {
543
+ return this.getAttribute("padding-horizontal");
544
+ }
545
+ set paddingVertical(t) {
546
+ this.setAttribute("padding-vertical", t);
547
+ }
548
+ set paddingHorizontal(t) {
549
+ this.setAttribute("padding-horizontal", t);
550
+ }
551
+ get gap() {
552
+ return this.getAttribute("gap");
553
+ }
554
+ connectedCallback() {
555
+ this.handlePaddingVerticalChange(this.paddingVertical), this.handlePaddingHorizontalChange(this.paddingHorizontal);
556
+ }
557
+ attributeChangedCallback(t, e, i) {
558
+ if (e !== i)
559
+ switch (t) {
560
+ case "background-image":
561
+ this.$imageContainer.setAttribute("background-image", i);
562
+ break;
563
+ case "gap":
564
+ this.$bodyVStackContainer.setAttribute("gap", i);
565
+ break;
566
+ case "background-color":
567
+ this.$bodyContainer.setAttribute(
568
+ "background-color",
569
+ k.indexOf(i) > 0 ? i : "none"
570
+ );
571
+ break;
572
+ case "padding-vertical":
573
+ this.handlePaddingVerticalChange(i);
574
+ break;
575
+ case "padding-horizontal":
576
+ this.handlePaddingHorizontalChange(i);
577
+ break;
578
+ default:
579
+ super.attributeChangedCallback(t, e, i);
580
+ }
581
+ }
582
+ handlePaddingVerticalChange(t) {
583
+ this.$headerContainer.setAttribute("padding-top", t), this.$footerContainer.setAttribute("padding-bottom", t);
584
+ }
585
+ handlePaddingHorizontalChange(t) {
586
+ this.$headerContainer.paddingLeft = t, this.$headerContainer.paddingRight = t, this.$bodyContainer.paddingLeft = t, this.$bodyContainer.paddingRight = t, this.$contactContainer.paddingLeft = t, this.$contactContainer.paddingRight = t, this.$footerContainer.paddingLeft = t, this.$footerContainer.paddingRight = t, this.$imageContainer.paddingLeft = t, this.$imageContainer.paddingRight = t;
587
+ }
588
+ }
589
+ customElements.get("px-page") === void 0 && customElements.define("px-page", D);
590
+ const z = ':host{display:block;font-family:var(--px-font-family);font-size:var(--px-font-size-base)}:host *{box-sizing:border-box}.selectable-box{display:flex;flex-direction:column;height:100%}::slotted([slot="media"]){width:100%;height:auto}.info{display:flex;flex-grow:1}.info .info__body{display:flex;flex-direction:column;flex-basis:80%;gap:var(--px-spacing-default-mobile);padding:var(--px-padding-m-mobile);flex-grow:1}.info .info__body .header{display:flex;align-items:center;gap:var(--px-spacing-s-mobile);flex-grow:1}.info .info__body .header .titles{display:flex;flex-direction:column;gap:var(--px-spacing-xs-mobile)}.info .info__body .header .titles ::slotted([slot="title"]){font-size:var(--px-text-size-label-m-mobile);font-weight:var(--px-font-weight-title);line-height:var(--px-line-height-ratio-l);color:var(--px-color-text-neutral-default);flex-grow:1}.info .info__body .header .titles ::slotted([slot="description"]){font-size:var(--px-text-size-label-m-mobile);font-weight:var(--px-font-weight-body);line-height:var(--px-line-height-ratio-l);color:var(--px-color-text-dimmed-default);flex-grow:1}.info .info__body ::slotted([slot="content"]){color:var(--px-color-text-neutral-default)}.info .info__footer{display:flex;align-items:center;padding:var(--px-padding-s-mobile);background:var(--px-color-background-container-default-default);text-align:center}:host([hide-footer]) .info .info__body{flex-basis:auto}:host([hide-footer]) .info__footer{display:none}@media only screen and (min-width: 48em){.info{flex-direction:column}.info .info__body{flex-basis:auto;gap:var(--px-spacing-default-tablet);padding:var(--px-padding-m-tablet)}.info .info__body .header{gap:var(--px-spacing-s-tablet)}.info .info__body .header .titles{gap:var(--px-spacing-xs-tablet)}.info .info__body .header .titles ::slotted([slot="title"]){font-size:var(--px-text-size-label-m-tablet)}.info .info__body .header .titles ::slotted([slot="description"]){font-size:var(--px-text-size-label-m-tablet)}.info .info__footer{justify-content:center;padding:var(--px-padding-s-tablet)}}@media only screen and (min-width: 64.0625em){.info .info__body{gap:var(--px-spacing-default-laptop);padding:var(--px-padding-m-laptop)}.info .info__body .header{gap:var(--px-spacing-s-laptop)}.info .info__body .header .titles{gap:var(--px-spacing-xs-laptop)}.info .info__body .header .titles ::slotted([slot="title"]){font-size:var(--px-text-size-label-m-laptop)}.info .info__body .header .titles ::slotted([slot="description"]){font-size:var(--px-text-size-label-m-laptop)}.info .info__footer{padding:var(--px-padding-s-laptop)}}@media only screen and (min-width: 90.0625em){.info .info__body{gap:var(--px-spacing-default-desktop);padding:var(--px-padding-m-desktop)}.info .info__body .header{gap:var(--px-spacing-s-desktop)}.info .info__body .header .titles{gap:var(--px-spacing-xs-desktop)}.info .info__body .header .titles ::slotted([slot="title"]){font-size:var(--px-text-size-label-m-desktop)}.info .info__body .header .titles ::slotted([slot="description"]){font-size:var(--px-text-size-label-m-desktop)}.info .info__footer{padding:var(--px-padding-s-desktop)}}:host([inverted]) .info .info__body .header .titles ::slotted([slot="title"]){color:var(--px-color-text-neutral-inverted)}:host([inverted]) .info .info__body .header .titles ::slotted([slot="description"]){color:var(--px-color-text-dimmed-inverted)}:host([inverted]) .info .info__body ::slotted([slot="content"]){color:var(--px-color-text-neutral-inverted)}:host([inverted]) .info .info__footer{background:var(--px-color-background-container-default-inverted)}', p = new CSSStyleSheet();
591
+ p.replaceSync(z);
592
+ class R extends n {
593
+ template() {
594
+ return `
595
+ <div class="selectable-box">
596
+ <slot name="media"></slot>
597
+ <div class="info">
598
+ <div class="info__body">
599
+ <div class="header">
600
+ <slot name="action"></slot>
601
+ <slot name="icon"></slot>
602
+ <slot name="logo"></slot>
603
+ <div class="titles">
604
+ <slot name="title"></slot>
605
+ <slot name="description"></slot>
606
+ </div>
607
+ </div>
608
+ <slot name="content"></slot>
609
+ </div>
610
+ <div class="info__footer">
611
+ <slot name="footer"></slot>
612
+ </div>
613
+ </div>
614
+ </div>
615
+ `;
616
+ }
617
+ constructor() {
618
+ super(p), this.shadowRoot.innerHTML = this.template();
619
+ }
620
+ connectedCallback() {
621
+ }
622
+ static get observedAttributes() {
623
+ return [...super.observedAttributes, "inverted", "hide-footer"];
624
+ }
625
+ attributeChangedCallback(t, e, i) {
626
+ if (e !== i)
627
+ switch (t) {
628
+ default:
629
+ super.attributeChangedCallback(t, e, i);
630
+ break;
631
+ }
632
+ }
633
+ get $el() {
634
+ return this.shadowRoot.querySelector(".selectable-box");
635
+ }
636
+ get inverted() {
637
+ return this.hasAttribute("inverted");
638
+ }
639
+ set inverted(t) {
640
+ t ? this.setAttribute("inverted", "") : this.removeAttribute("inverted");
641
+ }
642
+ get hideFooter() {
643
+ return this.hasAttribute("hide-footer");
644
+ }
645
+ set hideFooter(t) {
646
+ t ? this.setAttribute("hide-footer", "") : this.removeAttribute("hide-footer");
647
+ }
648
+ }
649
+ customElements.get("px-selectable-box") || customElements.define("px-selectable-box", R);
650
+ const u = ':host{display:block;outline:none}:host *{box-sizing:border-box}.selectable-box-checkbox,.selectable-box-radio{box-sizing:border-box;height:100%;cursor:default;border-radius:var(--px-radius-main);overflow:hidden;--btn-transition: all .2s ease-in-out 0s;transition:var(--btn-transition);border:var(--px-size-border-m) solid transparent;outline-color:var(--px-color-border-focus-outline-default);outline-width:var(--px-focus-outline-mobile)}.selectable-box-checkbox px-selectable-box,.selectable-box-radio px-selectable-box{height:100%;background-color:var(--px-color-background-container-light-default)}:host(:not([disabled])):host(:hover) .selectable-box-checkbox,:host(:not([disabled])):host(:hover) .selectable-box-radio{border-color:var(--px-color-border-state-hover-default)}:host(:not([disabled])):host(:hover) .selectable-box-checkbox px-selectable-box,:host(:not([disabled])):host(:hover) .selectable-box-radio px-selectable-box{background-color:var( --px-color-background-state-hover-bordered-default )}:host(:not([disabled])):host(:focus-visible) .selectable-box-checkbox,:host(:not([disabled])):host(:focus-visible) .selectable-box-radio{outline-offset:var(--px-focus-offset-mobile);outline-style:solid}:host([checked]) .selectable-box-checkbox,:host([checked]) .selectable-box-radio{border-color:var(--px-color-border-state-active-default)}:host([disabled]) .selectable-box-checkbox,:host([disabled]) .selectable-box-radio{cursor:default;pointer-events:none}:host([disabled]) .selectable-box-checkbox px-selectable-box,:host([disabled]) .selectable-box-radio px-selectable-box{background-color:var(--px-color-background-state-disabled-default)}:host([disabled]) ::slotted([slot="title"]),:host([disabled]) ::slotted([slot="description"]),:host([disabled]) ::slotted([slot="content"]){color:var(--px-color-text-state-disabled-default)}@media only screen and (min-width: 48em){.selectable-box-checkbox,.selectable-box-radio{outline-width:var(--px-focus-outline-tablet)}}@media only screen and (min-width: 64.0625em){.selectable-box-checkbox,.selectable-box-radio{outline-width:var(--px-focus-outline-laptop)}}@media only screen and (min-width: 90.0625em){.selectable-box-checkbox,.selectable-box-radio{outline-width:var(--px-focus-outline-desktop)}}:host([inverted]) .selectable-box-checkbox,:host([inverted]) .selectable-box-radio{outline-color:var(--px-color-border-focus-outline-inverted)}:host([inverted]) .selectable-box-checkbox px-selectable-box,:host([inverted]) .selectable-box-radio px-selectable-box{background-color:var(--px-color-background-container-light-inverted)}:host([inverted]):host(:not([disabled])):host(:hover) .selectable-box-checkbox,:host([inverted]):host(:not([disabled])):host(:hover) .selectable-box-radio{border-color:var(--px-color-border-state-hover-inverted)}:host([inverted]):host(:not([disabled])):host(:hover) .selectable-box-checkbox px-selectable-box,:host([inverted]):host(:not([disabled])):host(:hover) .selectable-box-radio px-selectable-box{background-color:var( --px-color-background-state-hover-bordered-inverted )}:host([inverted]):host([checked]) .selectable-box-checkbox,:host([inverted]):host([checked]) .selectable-box-radio{border-color:var(--px-color-border-state-active-inverted)}:host([inverted]):host([disabled]) .selectable-box-checkbox px-selectable-box,:host([inverted]):host([disabled]) .selectable-box-radio px-selectable-box{background-color:var(--px-color-background-state-disabled-inverted)}:host([inverted]):host([disabled]) ::slotted([slot="title"]),:host([inverted]):host([disabled]) ::slotted([slot="description"]),:host([inverted]):host([disabled]) ::slotted([slot="content"]){color:var(--px-color-text-state-disabled-inverted)}', g = new CSSStyleSheet();
651
+ g.replaceSync(u);
652
+ class F extends n {
653
+ template() {
654
+ return `
655
+ <div class="selectable-box-checkbox">
656
+ <px-selectable-box>
657
+ <slot name="media" slot="media"></slot>
658
+ <px-checkbox
659
+ slot="action" aria-hidden="true" tabindex="-1"
660
+ name="${this.name}"
661
+ value="${this.value}"
662
+ ></px-checkbox>
663
+ <slot name="icon" slot="icon"></slot>
664
+ <slot name="logo" slot="logo"></slot>
665
+ <slot name="title" slot="title"></slot>
666
+ <slot name="description" slot="description"></slot>
667
+ <slot name="content" slot="content"></slot>
668
+ <slot name="footer" slot="footer"></slot>
669
+ </px-selectable-box>
670
+ </div>
671
+ `;
672
+ }
673
+ constructor() {
674
+ var t;
675
+ super(g), this.shadowRoot.innerHTML = this.template(), this.internals = (t = this.attachInternals) == null ? void 0 : t.call(this), this.tabIndex = 0, this.internals && (this.internals.role = "checkbox", this.internals.ariaChecked = `${this.checked}`);
676
+ }
677
+ connectedCallback() {
678
+ this.toggleFooterVisibility(), this.$slotFooter.addEventListener("slotchange", () => {
679
+ this.toggleFooterVisibility();
680
+ }), this.addEventListener("mouseover", () => {
681
+ this.setHoverAttribute();
682
+ }), this.addEventListener("mouseout", () => {
683
+ this.removeHoverAttribute();
684
+ }), this.addEventListener("keypress", (t) => {
685
+ this.setKeypressEvent(t);
686
+ }), this.addEventListener("click", (t) => {
687
+ this.setClickEvent(t);
688
+ }), this.hasAttribute("checked") && (this.checked = !0);
689
+ }
690
+ static get observedAttributes() {
691
+ return [
692
+ ...super.observedAttributes,
693
+ "inverted",
694
+ "name",
695
+ "value",
696
+ "checked",
697
+ "disabled"
698
+ ];
699
+ }
700
+ attributeChangedCallback(t, e, i) {
701
+ if (e !== i)
702
+ switch (t) {
703
+ case "inverted":
704
+ this.inverted ? (this.$selectableBox.setAttribute("inverted", ""), this.$checkbox.setAttribute("inverted", "")) : (this.$selectableBox.removeAttribute("inverted"), this.$checkbox.removeAttribute("inverted"));
705
+ break;
706
+ case "name":
707
+ case "value":
708
+ this.$checkbox && this.$checkbox.setAttribute(t, i);
709
+ break;
710
+ case "disabled":
711
+ this.handleDisabledAttributeChange(i !== null);
712
+ break;
713
+ case "checked":
714
+ this.handleCheckedAttributeChange(i);
715
+ break;
716
+ default:
717
+ super.attributeChangedCallback(t, e, i);
718
+ break;
719
+ }
720
+ }
721
+ disconnectedCallback() {
722
+ this.$slotFooter.removeEventListener(
723
+ "slotchange",
724
+ this.toggleFooterVisibility
725
+ ), this.removeEventListener("mouseover", () => {
726
+ this.setHoverAttribute();
727
+ }), this.removeEventListener("mouseout", () => {
728
+ this.removeHoverAttribute();
729
+ }), this.removeEventListener("keypress", (t) => {
730
+ this.setKeypressEvent(t);
731
+ }), this.removeEventListener("click", (t) => {
732
+ this.setClickEvent(t);
733
+ });
734
+ }
735
+ removeHoverAttribute() {
736
+ this.$checkbox.removeAttribute("hover");
737
+ }
738
+ setHoverAttribute() {
739
+ this.$checkbox.setAttribute("hover", "");
740
+ }
741
+ setKeypressEvent(t) {
742
+ switch (t.stopPropagation(), t.preventDefault(), t.code) {
743
+ case "Space":
744
+ this.click();
745
+ break;
746
+ }
747
+ }
748
+ setClickEvent(t) {
749
+ this.checked = !this.checked, t.stopPropagation(), t.preventDefault();
750
+ }
751
+ toggleFooterVisibility() {
752
+ this.$slottedFooter ? this.$selectableBox.removeAttribute("hide-footer") : this.$selectableBox.setAttribute("hide-footer", "");
753
+ }
754
+ handleDisabledAttributeChange(t) {
755
+ t ? (this.disabled = !0, this.internals && (this.internals.ariaDisabled = "true"), this.$checkbox.setAttribute("disabled", "")) : (this.disabled = !1, this.internals && (this.internals.ariaDisabled = "false"), this.$checkbox.removeAttribute("disabled"));
756
+ }
757
+ handleCheckedAttributeChange(t) {
758
+ var e;
759
+ (e = this.internals) == null || e.setFormValue(this.formData()), t === null ? (this.internals && (this.internals.ariaChecked = "false"), this.checked = !1, this.$checkbox && this.$checkbox.removeAttribute("checked")) : (this.internals && (this.internals.ariaChecked = "true"), this.checked = !0, this.$checkbox && this.$checkbox.setAttribute("checked", ""), this.dispatchEvent(
760
+ new Event("change", {
761
+ bubbles: !0,
762
+ composed: !0
763
+ // Allow the event to pass through shadow DOM boundaries
764
+ })
765
+ ));
766
+ }
767
+ // Form-associated callbacks
768
+ static get formAssociated() {
769
+ return !0;
770
+ }
771
+ // Set default behavior when the element is attached to a form
772
+ formResetCallback() {
773
+ this.checked = !1;
774
+ }
775
+ formStateRestoreCallback(t) {
776
+ this.checked = t;
777
+ }
778
+ formData() {
779
+ if (this.name) {
780
+ const t = new FormData(), e = this.getAttribute("name");
781
+ return e && (this.checked ? t.set(e, this.value) : t.delete(e)), t;
782
+ }
783
+ }
784
+ get $el() {
785
+ return this.shadowRoot.querySelector(
786
+ ".selectable-box-checkbox"
787
+ );
788
+ }
789
+ get $selectableBox() {
790
+ return this.shadowRoot.querySelector("px-selectable-box");
791
+ }
792
+ get $checkbox() {
793
+ return this.shadowRoot.querySelector("px-checkbox");
794
+ }
795
+ get $slotFooter() {
796
+ return this.shadowRoot.querySelector(
797
+ 'slot[name="footer"]'
798
+ );
799
+ }
800
+ get $slottedFooter() {
801
+ return this.querySelector('[slot="footer"]');
802
+ }
803
+ get inverted() {
804
+ return this.hasAttribute("inverted");
805
+ }
806
+ set inverted(t) {
807
+ t ? this.setAttribute("inverted", "") : this.removeAttribute("inverted");
808
+ }
809
+ get checked() {
810
+ return this.hasAttribute("checked");
811
+ }
812
+ set checked(t) {
813
+ t ? this.setAttribute("checked", "") : this.removeAttribute("checked");
814
+ }
815
+ get name() {
816
+ return this.getAttribute("name");
817
+ }
818
+ set name(t) {
819
+ t ? this.setAttribute("name", t) : this.removeAttribute("name");
820
+ }
821
+ get disabled() {
822
+ return this.hasAttribute("disabled");
823
+ }
824
+ set disabled(t) {
825
+ t ? this.setAttribute("disabled", "") : this.removeAttribute("disabled");
826
+ }
827
+ get value() {
828
+ return this.getAttribute("value");
829
+ }
830
+ set value(t) {
831
+ t ? this.setAttribute("value", t) : this.removeAttribute("value");
832
+ }
833
+ }
834
+ customElements.get("px-selectable-box-checkbox") || customElements.define("px-selectable-box-checkbox", F);
835
+ const x = new CSSStyleSheet();
836
+ x.replaceSync(u);
837
+ class H extends n {
838
+ template() {
839
+ return `
840
+ <div class="selectable-box-radio">
841
+ <px-selectable-box>
842
+ <slot name="media" slot="media"></slot>
843
+ <px-radio-base
844
+ slot="action" aria-hidden="true" tabindex="-1"
845
+ name="${this.name}"
846
+ value="${this.value}"
847
+ ></px-radio-base>
848
+ <slot name="icon" slot="icon"></slot>
849
+ <slot name="logo" slot="logo"></slot>
850
+ <slot name="title" slot="title"></slot>
851
+ <slot name="description" slot="description"></slot>
852
+ <slot name="content" slot="content"></slot>
853
+ <slot name="footer" slot="footer"></slot>
854
+ </px-selectable-box>
855
+ </div>
856
+ `;
857
+ }
858
+ constructor() {
859
+ var t, e;
860
+ super(x), this.shadowRoot.innerHTML = this.template(), this.internals = (t = this.attachInternals) == null ? void 0 : t.call(this), this.tabIndex = ((e = this.parentElement) == null ? void 0 : e.firstElementChild) === this ? 0 : -1, this.internals && (this.internals.role = "radio", this.internals.ariaChecked = `${this.checked}`);
861
+ }
862
+ connectedCallback() {
863
+ this.toggleFooterVisibility(), this.$slotFooter.addEventListener("slotchange", () => {
864
+ this.toggleFooterVisibility();
865
+ }), this.addEventListener("mouseover", () => {
866
+ this.setHoverAttribute();
867
+ }), this.addEventListener("mouseout", () => {
868
+ this.removeHoverAttribute();
869
+ }), this.addEventListener("keypress", (t) => {
870
+ this.setKeypressEvent(t);
871
+ }), this.addEventListener("click", (t) => {
872
+ this.setClickEvent(t);
873
+ }), this.hasAttribute("checked") && (this.checked = !0);
874
+ }
875
+ static get observedAttributes() {
876
+ return [
877
+ ...super.observedAttributes,
878
+ "inverted",
879
+ "name",
880
+ "value",
881
+ "checked",
882
+ "disabled"
883
+ ];
884
+ }
885
+ attributeChangedCallback(t, e, i) {
886
+ if (e !== i)
887
+ switch (t) {
888
+ case "inverted":
889
+ this.inverted ? (this.$selectableBox.setAttribute("inverted", ""), this.$radio.setAttribute("inverted", "")) : (this.$selectableBox.removeAttribute("inverted"), this.$radio.removeAttribute("inverted"));
890
+ break;
891
+ case "name":
892
+ case "value":
893
+ this.$radio && this.$radio.setAttribute(t, i);
894
+ break;
895
+ case "disabled":
896
+ this.handleDisabledAttributeChange(i !== null);
897
+ break;
898
+ case "checked":
899
+ this.handleCheckedAttributeChange(i);
900
+ break;
901
+ default:
902
+ super.attributeChangedCallback(t, e, i);
903
+ break;
904
+ }
905
+ }
906
+ disconnectedCallback() {
907
+ this.$slotFooter.removeEventListener(
908
+ "slotchange",
909
+ this.toggleFooterVisibility
910
+ ), this.removeEventListener("mouseover", () => {
911
+ this.setHoverAttribute();
912
+ }), this.removeEventListener("mouseout", () => {
913
+ this.removeHoverAttribute();
914
+ }), this.removeEventListener("keypress", (t) => {
915
+ this.setKeypressEvent(t);
916
+ }), this.removeEventListener("click", (t) => {
917
+ this.setClickEvent(t);
918
+ });
919
+ }
920
+ removeHoverAttribute() {
921
+ this.$radio.removeAttribute("hover");
922
+ }
923
+ setHoverAttribute() {
924
+ this.$radio.setAttribute("hover", "");
925
+ }
926
+ setKeypressEvent(t) {
927
+ switch (t.preventDefault(), t.code) {
928
+ case "Space":
929
+ this.click();
930
+ break;
931
+ }
932
+ }
933
+ setClickEvent(t) {
934
+ this.checked || (this.checked = !0), t.stopPropagation(), t.preventDefault();
935
+ }
936
+ toggleFooterVisibility() {
937
+ this.$slottedFooter ? this.$selectableBox.removeAttribute("hide-footer") : this.$selectableBox.setAttribute("hide-footer", "");
938
+ }
939
+ handleDisabledAttributeChange(t) {
940
+ t ? (this.disabled = !0, this.internals && (this.internals.ariaDisabled = "true"), this.$radio.setAttribute("disabled", "")) : (this.disabled = !1, this.internals && (this.internals.ariaDisabled = "false"), this.$radio.removeAttribute("disabled"));
941
+ }
942
+ handleCheckedAttributeChange(t) {
943
+ var e;
944
+ (e = this.internals) == null || e.setFormValue(this.formData()), t === null ? (this.internals && (this.internals.ariaChecked = "false"), this.setAttribute("tabIndex", "-1"), this.checked = !1, this.$radio && this.$radio.removeAttribute("checked")) : (this.internals && (this.internals.ariaChecked = "true"), this.setAttribute("tabIndex", "0"), this.checked = !0, this.$radio && this.$radio.setAttribute("checked", ""), this.dispatchEvent(
945
+ new Event("change", {
946
+ bubbles: !0,
947
+ composed: !0
948
+ // Allow the event to pass through shadow DOM boundaries
949
+ })
950
+ ));
951
+ }
952
+ // Form-associated callbacks
953
+ static get formAssociated() {
954
+ return !0;
955
+ }
956
+ // Set default behavior when the element is attached to a form
957
+ formResetCallback() {
958
+ this.checked = !1;
959
+ }
960
+ formStateRestoreCallback(t) {
961
+ this.checked = t;
962
+ }
963
+ formData() {
964
+ if (this.name) {
965
+ const t = new FormData(), e = this.getAttribute("name");
966
+ return e && (this.checked ? t.set(e, this.value) : t.delete(e)), t;
967
+ }
968
+ }
969
+ get $el() {
970
+ return this.shadowRoot.querySelector(
971
+ ".selectable-box-radio"
972
+ );
973
+ }
974
+ get $selectableBox() {
975
+ return this.shadowRoot.querySelector("px-selectable-box");
976
+ }
977
+ get $radio() {
978
+ return this.shadowRoot.querySelector("px-radio-base");
979
+ }
980
+ get $slotFooter() {
981
+ return this.shadowRoot.querySelector(
982
+ 'slot[name="footer"]'
983
+ );
984
+ }
985
+ get $slottedFooter() {
986
+ return this.querySelector('[slot="footer"]');
987
+ }
988
+ get inverted() {
989
+ return this.hasAttribute("inverted");
990
+ }
991
+ set inverted(t) {
992
+ t ? this.setAttribute("inverted", "") : this.removeAttribute("inverted");
993
+ }
994
+ get checked() {
995
+ return this.hasAttribute("checked");
996
+ }
997
+ set checked(t) {
998
+ t ? this.setAttribute("checked", "") : this.removeAttribute("checked");
999
+ }
1000
+ get name() {
1001
+ return this.getAttribute("name");
1002
+ }
1003
+ set name(t) {
1004
+ t ? this.setAttribute("name", t) : this.removeAttribute("name");
1005
+ }
1006
+ get disabled() {
1007
+ return this.hasAttribute("disabled");
1008
+ }
1009
+ set disabled(t) {
1010
+ t ? this.setAttribute("disabled", "") : this.removeAttribute("disabled");
1011
+ }
1012
+ get value() {
1013
+ return this.getAttribute("value");
1014
+ }
1015
+ set value(t) {
1016
+ t ? this.setAttribute("value", t) : this.removeAttribute("value");
1017
+ }
1018
+ }
1019
+ customElements.get("px-selectable-box-radio") || customElements.define("px-selectable-box-radio", H);
1020
+ export {
1021
+ R as SelectableBox,
1022
+ F as SelectableBoxCheckbox,
1023
+ H as SelectableBoxRadio
1024
+ };
package/package.json ADDED
@@ -0,0 +1,20 @@
1
+ {
2
+ "name": "@proximus/lavender-selectablebox",
3
+ "version": "2.0.0-alpha.2",
4
+ "description": "",
5
+ "main": "dist/index.es.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist"
9
+ ],
10
+ "type": "module",
11
+ "scripts": {
12
+ "transform-package-json": "node ../../../scripts/tranformPackageJson.js package.json dist/far/away",
13
+ "clean": "rm -rf dist",
14
+ "build": "npm run clean && NODE_ENV=development vite build && tsc && npm run transform-package-json",
15
+ "test": "vitest run --coverage"
16
+ },
17
+ "publishConfig": {
18
+ "access": "public"
19
+ }
20
+ }