@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1777034920 → 5.0.0-next-dev.1777124912
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/styles/core.scss +24 -0
- package/core.css +66 -0
- package/development/navigation/common/navigation-action-common.js +1 -1
- package/development/navigation/navigation/navigation.component.js +1 -1
- package/development/navigation/navigation-list/navigation-list.component.js +1 -1
- package/development/navigation/navigation-marker/navigation-marker.component.js +1 -1
- package/development/navigation/navigation-section/navigation-section.component.js +1 -1
- package/development/navigation-action-common-BsrmO4QQ.js +92 -0
- package/development/navigation-list.component-CQ4q671G.js +90 -0
- package/development/navigation-marker.component-D7ks8vbC.js +121 -0
- package/development/navigation-section.component-t36xyaq4.js +346 -0
- package/development/navigation.component-Djm0PFOA.js +315 -0
- package/development/navigation.js +5 -5
- package/development/navigation.pure.js +5 -5
- package/navigation/common/navigation-action-common.js +1 -1
- package/navigation/navigation/navigation.component.js +1 -1
- package/navigation/navigation-list/navigation-list.component.js +1 -1
- package/navigation/navigation-marker/navigation-marker.component.js +1 -1
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/navigation-action-common-XvWVU7Zk.js +66 -0
- package/{navigation-list.component-DSJx3LwB.js → navigation-list.component-BX-kv06z.js} +1 -1
- package/{navigation-marker.component-xmkTtMap.js → navigation-marker.component-iSodFQRj.js} +1 -1
- package/{navigation-section.component-CUrICmbc.js → navigation-section.component-K4Pa53K7.js} +1 -1
- package/{navigation.component-CR4vG3vH.js → navigation.component-BFejmwjr.js} +1 -1
- package/navigation.js +5 -5
- package/navigation.pure.js +5 -5
- package/off-brand-theme.css +66 -0
- package/package.json +2 -2
- package/safety-theme.css +66 -0
- package/standard-theme.css +66 -0
- package/development/navigation-action-common-DREsZcc7.js +0 -92
- package/development/navigation-list.component-3kQyQ-yJ.js +0 -90
- package/development/navigation-marker.component-DyWfazQL.js +0 -121
- package/development/navigation-section.component-DyPWGns2.js +0 -346
- package/development/navigation.component-CZ2P2xfh.js +0 -315
- package/navigation-action-common-D3rE0ZNS.js +0 -66
package/core/styles/core.scss
CHANGED
|
@@ -172,6 +172,21 @@ $theme: 'standard' !default;
|
|
|
172
172
|
with (
|
|
173
173
|
$theme: $theme
|
|
174
174
|
);
|
|
175
|
+
@use '../../navigation/navigation/navigation.global' as navigation with (
|
|
176
|
+
$theme: $theme
|
|
177
|
+
);
|
|
178
|
+
@use '../../navigation/common/navigation-action.global' as navigation-action with (
|
|
179
|
+
$theme: $theme
|
|
180
|
+
);
|
|
181
|
+
@use '../../navigation/navigation-list/navigation-list.global' as navigation-list with (
|
|
182
|
+
$theme: $theme
|
|
183
|
+
);
|
|
184
|
+
@use '../../navigation/navigation-marker/navigation-marker.global' as navigation-marker with (
|
|
185
|
+
$theme: $theme
|
|
186
|
+
);
|
|
187
|
+
@use '../../navigation/navigation-section/navigation-section.global' as navigation-section with (
|
|
188
|
+
$theme: $theme
|
|
189
|
+
);
|
|
175
190
|
@use '../../notification/notification.global' as notification with (
|
|
176
191
|
$theme: $theme
|
|
177
192
|
);
|
|
@@ -346,6 +361,11 @@ $theme: 'standard' !default;
|
|
|
346
361
|
@include menu.base;
|
|
347
362
|
@include menu-action.base;
|
|
348
363
|
@include message.base;
|
|
364
|
+
@include navigation.base;
|
|
365
|
+
@include navigation-action.base;
|
|
366
|
+
@include navigation-list.base;
|
|
367
|
+
@include navigation-marker.base;
|
|
368
|
+
@include navigation-section.base;
|
|
349
369
|
@include mini-calendar-day.base;
|
|
350
370
|
@include mini-calendar-month.base;
|
|
351
371
|
@include notification.base;
|
|
@@ -474,6 +494,8 @@ $theme: 'standard' !default;
|
|
|
474
494
|
@include flip-card.base-breakpoint-large;
|
|
475
495
|
@include form-field.base-breakpoint-large;
|
|
476
496
|
@include header.base-breakpoint-large;
|
|
497
|
+
@include navigation.base-breakpoint-large;
|
|
498
|
+
@include navigation-section.base-breakpoint-large;
|
|
477
499
|
@include menu.base-breakpoint-large;
|
|
478
500
|
@include teaser-panel.base-breakpoint-large;
|
|
479
501
|
@include teaser-product-common.base-breakpoint-large;
|
|
@@ -493,6 +515,8 @@ $theme: 'standard' !default;
|
|
|
493
515
|
|
|
494
516
|
@include lead-container.base-breakpoint-ultra;
|
|
495
517
|
@include map-container.base-breakpoint-ultra;
|
|
518
|
+
@include navigation.base-breakpoint-ultra;
|
|
519
|
+
@include navigation-section.base-breakpoint-ultra;
|
|
496
520
|
@include teaser-panel.base-breakpoint-ultra;
|
|
497
521
|
}
|
|
498
522
|
}
|
package/core.css
CHANGED
|
@@ -1555,6 +1555,54 @@ slot[name=error]::slotted(*) {
|
|
|
1555
1555
|
--sbb-message-subtitle-color: var(--sbb-color-granite);
|
|
1556
1556
|
--sbb-message-subtitle-color: light-dark(var(--sbb-color-granite), var(--sbb-color-platinum));
|
|
1557
1557
|
--sbb-message-legend-margin-block: var(--sbb-spacing-responsive-xxxs) 0;
|
|
1558
|
+
--sbb-navigation-grid-column: 1 / -1;
|
|
1559
|
+
--sbb-navigation-animation-easing: ease-in;
|
|
1560
|
+
--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive);
|
|
1561
|
+
--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-l);
|
|
1562
|
+
--sbb-navigation-padding-block-end: var(--sbb-spacing-responsive-xl);
|
|
1563
|
+
--sbb-navigation-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 70%, transparent);
|
|
1564
|
+
--sbb-navigation-backdrop-animation-name: backdrop-open;
|
|
1565
|
+
--sbb-navigation-background-color: var(--sbb-background-color-1-negative);
|
|
1566
|
+
--sbb-navigation-color: var(--sbb-color-1-negative);
|
|
1567
|
+
--sbb-navigation-list-margin-block-start: var(--sbb-spacing-responsive-xxl);
|
|
1568
|
+
--sbb-navigation-expanded-width: 100%;
|
|
1569
|
+
--sbb-navigation-inset: 0 auto auto 0;
|
|
1570
|
+
--sbb-navigation-translate: -100% 0;
|
|
1571
|
+
--sbb-navigation-content-gap: var(--sbb-spacing-responsive-xxl);
|
|
1572
|
+
--sbb-navigation-content-translate: 0;
|
|
1573
|
+
--sbb-navigation-width: 100%;
|
|
1574
|
+
--sbb-navigation-height: 100dvh;
|
|
1575
|
+
--sbb-navigation-action-color: var(--sbb-color-4-negative);
|
|
1576
|
+
--sbb-navigation-action-icon-display: none;
|
|
1577
|
+
--sbb-navigation-action-font-size: var(--sbb-text-font-size-xl);
|
|
1578
|
+
--sbb-navigation-action-letter-spacing: var(--sbb-typo-letter-spacing-heading);
|
|
1579
|
+
--sbb-navigation-action-line-height: var(--sbb-typo-line-height-heading);
|
|
1580
|
+
--sbb-navigation-list-font-size: var(--sbb-text-font-size-xxs);
|
|
1581
|
+
--sbb-navigation-list-gap: var(--sbb-spacing-fixed-2x);
|
|
1582
|
+
--sbb-navigation-list-margin-block: var(--sbb-spacing-fixed-1x);
|
|
1583
|
+
--sbb-navigation-list-padding-block-end: var(--sbb-spacing-fixed-2x);
|
|
1584
|
+
--sbb-navigation-action-gap: var(--sbb-spacing-responsive-xs);
|
|
1585
|
+
--sbb-navigation-marker-position-x: var(--sbb-spacing-fixed-1x);
|
|
1586
|
+
--sbb-navigation-marker-position-y: unset;
|
|
1587
|
+
--sbb-navigation-marker-width: 1.0625rem;
|
|
1588
|
+
--sbb-navigation-marker-border: var(--sbb-border-width-1x);
|
|
1589
|
+
--sbb-navigation-marker-padding-inline-start: var(--sbb-spacing-fixed-6x);
|
|
1590
|
+
--sbb-navigation-marker-typo-line-height: var(--sbb-typo-line-height-heading);
|
|
1591
|
+
--sbb-navigation-margin-inline-start: var(--sbb-spacing-fixed-3x);
|
|
1592
|
+
--sbb-navigation-marker-font-size: var(--sbb-text-font-size-xl);
|
|
1593
|
+
--sbb-navigation-marker-letter-spacing: var(--sbb-typo-letter-spacing-heading);
|
|
1594
|
+
--sbb-navigation-marker-line-height: var(--sbb-typo-line-height-heading);
|
|
1595
|
+
--sbb-navigation-section-column: 1 / -1;
|
|
1596
|
+
--sbb-navigation-section-position: fixed;
|
|
1597
|
+
--sbb-navigation-section-pointer-events: none;
|
|
1598
|
+
--sbb-navigation-section-animation-easing: ease-out;
|
|
1599
|
+
--sbb-navigation-section-padding-inline: var(--sbb-layout-base-offset-responsive);
|
|
1600
|
+
--sbb-navigation-section-padding-block: var(--sbb-spacing-responsive-l);
|
|
1601
|
+
--sbb-navigation-section-translate: 100%;
|
|
1602
|
+
--sbb-navigation-section-content-padding-inline-start: var(--sbb-spacing-fixed-12x);
|
|
1603
|
+
--sbb-navigation-section-width: 100dvw;
|
|
1604
|
+
--sbb-navigation-section-height: 100dvh;
|
|
1605
|
+
--sbb-navigation-section-font-size: var(--sbb-heading-font-size-4);
|
|
1558
1606
|
--sbb-mini-calendar-day-animation-easing: var(--sbb-animation-easing);
|
|
1559
1607
|
--sbb-mini-calendar-day-dimensions: 0.375rem;
|
|
1560
1608
|
--sbb-mini-calendar-day-scale: 1.333;
|
|
@@ -2039,6 +2087,19 @@ slot[name=error]::slotted(*) {
|
|
|
2039
2087
|
--_sbb-form-field-floating-label-transform: 0.65625rem;
|
|
2040
2088
|
--_sbb-form-field-spacer-margin-block-end: calc(-1 * var(--_sbb-form-field-label-to-input-overlapping));
|
|
2041
2089
|
--sbb-header-height: var(--sbb-spacing-fixed-24x);
|
|
2090
|
+
--sbb-navigation-grid-column: 1 / 5;
|
|
2091
|
+
--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xl);
|
|
2092
|
+
--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive) 0;
|
|
2093
|
+
--sbb-navigation-list-margin-block-start: var(--sbb-spacing-fixed-1x);
|
|
2094
|
+
--sbb-navigation-inline-start: calc(var(--sbb-layout-base-offset-responsive) * -1);
|
|
2095
|
+
--sbb-navigation-section-column: 5 / 13;
|
|
2096
|
+
--sbb-navigation-section-padding-block: var(--sbb-spacing-responsive-xl);
|
|
2097
|
+
--sbb-navigation-section-padding-inline: var(--sbb-spacing-fixed-8x)
|
|
2098
|
+
var(--sbb-layout-base-offset-responsive);
|
|
2099
|
+
--sbb-navigation-section-position: relative;
|
|
2100
|
+
--sbb-navigation-section-translate: 0;
|
|
2101
|
+
--sbb-navigation-section-content-padding-inline-start: 0;
|
|
2102
|
+
--sbb-navigation-section-font-size: var(--sbb-heading-font-size-2);
|
|
2042
2103
|
--sbb-menu-max-width: 20rem;
|
|
2043
2104
|
--sbb-menu-min-width: 11.25rem;
|
|
2044
2105
|
--sbb-menu-transform-y: var(--sbb-spacing-fixed-2x);
|
|
@@ -2074,6 +2135,11 @@ slot[name=error]::slotted(*) {
|
|
|
2074
2135
|
--sbb-lead-container-image-ratio: 21 / 9;
|
|
2075
2136
|
--sbb-lead-container-image-border-radius: var(--sbb-lead-container-border-radius);
|
|
2076
2137
|
--sbb-map-container-sidebar-width: 30rem;
|
|
2138
|
+
--sbb-navigation-grid-column: 1 / 6;
|
|
2139
|
+
--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xxl);
|
|
2140
|
+
--sbb-navigation-section-column: 6 / 17;
|
|
2141
|
+
--sbb-navigation-section-padding-block: var(--sbb-spacing-responsive-xxl)
|
|
2142
|
+
var(--sbb-spacing-responsive-l);
|
|
2077
2143
|
--sbb-panel-width: 26.75rem;
|
|
2078
2144
|
--sbb-panel-inner-height: 20.02375rem;
|
|
2079
2145
|
--sbb-panel-triangle-height: 3.956875rem;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationActionCommonElementMixin } from "../../navigation-action-common-
|
|
1
|
+
import { t as SbbNavigationActionCommonElementMixin } from "../../navigation-action-common-BsrmO4QQ.js";
|
|
2
2
|
export { SbbNavigationActionCommonElementMixin };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationElement } from "../../navigation.component-
|
|
1
|
+
import { t as SbbNavigationElement } from "../../navigation.component-Djm0PFOA.js";
|
|
2
2
|
export { SbbNavigationElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationListElement } from "../../navigation-list.component-
|
|
1
|
+
import { t as SbbNavigationListElement } from "../../navigation-list.component-CQ4q671G.js";
|
|
2
2
|
export { SbbNavigationListElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationMarkerElement } from "../../navigation-marker.component-
|
|
1
|
+
import { t as SbbNavigationMarkerElement } from "../../navigation-marker.component-D7ks8vbC.js";
|
|
2
2
|
export { SbbNavigationMarkerElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationSectionElement } from "../../navigation-section.component-
|
|
1
|
+
import { t as SbbNavigationSectionElement } from "../../navigation-section.component-t36xyaq4.js";
|
|
2
2
|
export { SbbNavigationSectionElement };
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { boxSizingStyles } from "./core.js";
|
|
5
|
+
import { html as html$1 } from "lit/static-html.js";
|
|
6
|
+
import { SbbIconElement } from "./icon.pure.js";
|
|
7
|
+
//#region src/elements/navigation/common/navigation-action.scss?inline
|
|
8
|
+
var navigation_action_default = ":host {\n --_sbb-navigation-action-inset-inline-start: calc(\n (var(--sbb-size-icon-ui-small) + var(--sbb-spacing-fixed-1x)) * -1\n );\n --_sbb-navigation-action-inset-block-start: calc(1em * (var(--sbb-typo-line-height-text) / 2));\n --sbb-navigation-action-transition-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-3x)\n );\n display: block;\n outline: none !important;\n}\n\n:host(:is(:state(section-action),[state--section-action]):is(:state(action-active),[state--action-active]).sbb-active) {\n --sbb-navigation-action-icon-display: block;\n}\n\n:host(:is(:state(action-active),[state--action-active])) {\n --sbb-navigation-action-color: var(--sbb-color-5);\n}\n@media (forced-colors: active) {\n :host(:is(:state(action-active),[state--action-active])) {\n --sbb-navigation-action-color: Highlight;\n }\n}\n\nsbb-icon {\n display: var(--sbb-navigation-action-icon-display);\n position: absolute;\n inset-inline-start: var(--_sbb-navigation-action-inset-inline-start);\n inset-block-start: var(--_sbb-navigation-action-inset-block-start);\n translate: 0 -50%;\n}\n\n@media (any-hover: hover) {\n :host(:hover) {\n --sbb-navigation-action-color: var(--sbb-color-5);\n }\n}\n@media (forced-colors: active) {\n :host(:is(:state(button),[state--button])) {\n --sbb-navigation-action-color: ButtonText;\n }\n}\n\n:host([size=l]) {\n --sbb-navigation-action-font-size: var(--sbb-heading-font-size-4);\n --sbb-navigation-action-letter-spacing: var(--sbb-typo-letter-spacing-heading);\n --sbb-navigation-action-line-height: var(--sbb-typo-line-height-heading);\n}\n\n:host([size=m]),\n:host([size=s]) {\n --sbb-navigation-action-line-height: var(--sbb-typo-line-height-text);\n --sbb-navigation-action-letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host([size=m]) {\n --sbb-navigation-action-font-size: var(--sbb-text-font-size-s);\n}\n\n:host([size=s]) {\n --sbb-navigation-action-font-size: var(--sbb-text-font-size-xxs);\n}\n\n:is(.sbb-navigation-button, .sbb-navigation-link) {\n display: flex;\n position: relative;\n color: var(--sbb-navigation-action-color);\n cursor: var(--sbb-cursor-pointer);\n transition: color var(--sbb-navigation-action-transition-duration) ease;\n outline: none;\n text-align: left;\n font-size: var(--sbb-navigation-action-font-size);\n line-height: var(--sbb-navigation-action-line-height);\n letter-spacing: var(--sbb-navigation-action-letter-spacing);\n font-weight: bold;\n hyphens: auto;\n text-decoration: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n@media (forced-colors: active) {\n :is(.sbb-navigation-button, .sbb-navigation-link) {\n transition: none;\n }\n}\n:host(:focus-visible) :is(.sbb-navigation-button, .sbb-navigation-link), :is(.sbb-navigation-button, .sbb-navigation-link):focus-visible {\n outline-offset: var(--sbb-focus-outline-offset);\n outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);\n border-radius: calc(var(--sbb-border-radius-4x) - var(--sbb-focus-outline-offset));\n}";
|
|
9
|
+
//#endregion
|
|
10
|
+
//#region src/elements/navigation/common/navigation-action-common.ts
|
|
11
|
+
var SbbNavigationActionCommonElementMixin = (superClass) => {
|
|
12
|
+
return (() => {
|
|
13
|
+
let _classSuper = superClass;
|
|
14
|
+
let _size_decorators;
|
|
15
|
+
let _size_initializers = [];
|
|
16
|
+
let _size_extraInitializers = [];
|
|
17
|
+
return class SbbNavigationActionCommonElement extends _classSuper {
|
|
18
|
+
static {
|
|
19
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
20
|
+
_size_decorators = [property({ reflect: true })];
|
|
21
|
+
__esDecorate(this, null, _size_decorators, {
|
|
22
|
+
kind: "accessor",
|
|
23
|
+
name: "size",
|
|
24
|
+
static: false,
|
|
25
|
+
private: false,
|
|
26
|
+
access: {
|
|
27
|
+
has: (obj) => "size" in obj,
|
|
28
|
+
get: (obj) => obj.size,
|
|
29
|
+
set: (obj, value) => {
|
|
30
|
+
obj.size = value;
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
metadata: _metadata
|
|
34
|
+
}, _size_initializers, _size_extraInitializers);
|
|
35
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
36
|
+
enumerable: true,
|
|
37
|
+
configurable: true,
|
|
38
|
+
writable: true,
|
|
39
|
+
value: _metadata
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
static {
|
|
43
|
+
this.elementDependencies = [SbbIconElement];
|
|
44
|
+
}
|
|
45
|
+
static {
|
|
46
|
+
this.styles = [boxSizingStyles, unsafeCSS(navigation_action_default)];
|
|
47
|
+
}
|
|
48
|
+
#size_accessor_storage;
|
|
49
|
+
/**
|
|
50
|
+
* Action size variant, either s, m or l.
|
|
51
|
+
*/
|
|
52
|
+
get size() {
|
|
53
|
+
return this.#size_accessor_storage;
|
|
54
|
+
}
|
|
55
|
+
set size(value) {
|
|
56
|
+
this.#size_accessor_storage = value;
|
|
57
|
+
}
|
|
58
|
+
/** The navigation marker in which the action is nested. */
|
|
59
|
+
get marker() {
|
|
60
|
+
return this._navigationMarker;
|
|
61
|
+
}
|
|
62
|
+
/** The section in which the action is nested. */
|
|
63
|
+
get section() {
|
|
64
|
+
return this._navigationSection;
|
|
65
|
+
}
|
|
66
|
+
constructor(...args) {
|
|
67
|
+
super(...args);
|
|
68
|
+
this.#size_accessor_storage = __runInitializers(this, _size_initializers, "l");
|
|
69
|
+
/** The section that is being controlled by the action, if any. */
|
|
70
|
+
this.connectedSection = __runInitializers(this, _size_extraInitializers);
|
|
71
|
+
this._navigationMarker = null;
|
|
72
|
+
this._navigationSection = null;
|
|
73
|
+
this.addEventListener?.("click", () => {
|
|
74
|
+
if (!this.matches(":is(:state(action-active),[state--action-active])") && this._navigationMarker && !this.connectedSection) this.marker?.select(this);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
connectedCallback() {
|
|
78
|
+
super.connectedCallback();
|
|
79
|
+
this._navigationMarker = this.closest("sbb-navigation-marker");
|
|
80
|
+
this._navigationSection = this.closest("sbb-navigation-section");
|
|
81
|
+
this.toggleState("section-action", !!this._navigationSection);
|
|
82
|
+
}
|
|
83
|
+
renderTemplate() {
|
|
84
|
+
return html$1`<sbb-icon name="dash-small"></sbb-icon> <slot></slot>`;
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
})();
|
|
88
|
+
};
|
|
89
|
+
//#endregion
|
|
90
|
+
export { SbbNavigationActionCommonElementMixin as t };
|
|
91
|
+
|
|
92
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"navigation-action-common-BsrmO4QQ.js","names":[],"sources":["../../../src/elements/navigation/common/navigation-action.scss?inline","../../../src/elements/navigation/common/navigation-action-common.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --_sbb-navigation-action-inset-inline-start: calc(\n    (var(--sbb-size-icon-ui-small) + var(--sbb-spacing-fixed-1x)) * -1\n  );\n  --_sbb-navigation-action-inset-block-start: calc(1em * (var(--sbb-typo-line-height-text) / 2));\n  --sbb-navigation-action-transition-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-3x)\n  );\n\n  display: block;\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n}\n\n:host(:state(section-action):state(action-active).sbb-active) {\n  --sbb-navigation-action-icon-display: block;\n}\n\n:host(:state(action-active)) {\n  --sbb-navigation-action-color: var(--sbb-color-5);\n\n  @include sbb.if-forced-colors {\n    --sbb-navigation-action-color: Highlight;\n  }\n}\n\nsbb-icon {\n  display: var(--sbb-navigation-action-icon-display);\n  position: absolute;\n  inset-inline-start: var(--_sbb-navigation-action-inset-inline-start);\n  inset-block-start: var(--_sbb-navigation-action-inset-block-start);\n  translate: 0 -50%;\n}\n\n@include sbb.hover-mq($hover: true) {\n  :host(:hover) {\n    --sbb-navigation-action-color: var(--sbb-color-5);\n  }\n}\n\n:host(:state(button)) {\n  @include sbb.if-forced-colors {\n    --sbb-navigation-action-color: ButtonText;\n  }\n}\n\n:host([size='l']) {\n  --sbb-navigation-action-font-size: var(--sbb-heading-font-size-4);\n  --sbb-navigation-action-letter-spacing: var(--sbb-typo-letter-spacing-heading);\n  --sbb-navigation-action-line-height: var(--sbb-typo-line-height-heading);\n}\n\n:host([size='m']),\n:host([size='s']) {\n  --sbb-navigation-action-line-height: var(--sbb-typo-line-height-text);\n  --sbb-navigation-action-letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host([size='m']) {\n  --sbb-navigation-action-font-size: var(--sbb-text-font-size-s);\n}\n\n:host([size='s']) {\n  --sbb-navigation-action-font-size: var(--sbb-text-font-size-xxs);\n}\n\n:is(.sbb-navigation-button, .sbb-navigation-link) {\n  display: flex;\n  position: relative;\n  color: var(--sbb-navigation-action-color);\n  cursor: var(--sbb-cursor-pointer);\n  transition: color var(--sbb-navigation-action-transition-duration) ease;\n  outline: none;\n  text-align: left;\n  font-size: var(--sbb-navigation-action-font-size);\n  line-height: var(--sbb-navigation-action-line-height);\n  letter-spacing: var(--sbb-navigation-action-letter-spacing);\n  font-weight: bold;\n  hyphens: auto;\n  text-decoration: none;\n  user-select: none;\n  -webkit-tap-highlight-color: transparent;\n\n  @include sbb.if-forced-colors {\n    transition: none;\n  }\n\n  // Handle focus on the host (button variant)\n  :host(:focus-visible) &,\n    // Handle focus on the action (link variant)\n  &:focus-visible {\n    @include sbb.focus-outline;\n\n    border-radius: calc(var(--sbb-border-radius-4x) - var(--sbb-focus-outline-offset));\n  }\n}\n","import { type CSSResultGroup, type TemplateResult, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { html } from 'lit/static-html.js';\n\nimport type {\n  AbstractConstructor,\n  SbbActionBaseElement,\n  SbbElementConstructor,\n  SbbElementType,\n} from '../../core.ts';\nimport { boxSizingStyles } from '../../core.ts';\nimport { SbbIconElement } from '../../icon.pure.ts';\nimport type { SbbNavigationButtonElement } from '../navigation-button/navigation-button.component.ts';\nimport type { SbbNavigationLinkElement } from '../navigation-link/navigation-link.component.ts';\nimport type { SbbNavigationMarkerElement } from '../navigation-marker/navigation-marker.component.ts';\nimport type { SbbNavigationSectionElement } from '../navigation-section/navigation-section.component.ts';\n\nimport style from './navigation-action.scss?inline';\n\nexport type SbbNavigationActionSize = 's' | 'm' | 'l';\n\nexport declare class SbbNavigationActionCommonElementMixinType {\n  public accessor size: SbbNavigationActionSize;\n  public get marker(): SbbNavigationMarkerElement | null;\n  public get section(): SbbNavigationSectionElement | null;\n  public connectedSection: SbbNavigationSectionElement | undefined;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNavigationActionCommonElementMixin = <\n  T extends AbstractConstructor<SbbActionBaseElement> & SbbElementConstructor,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNavigationActionCommonElementMixinType> & T => {\n  abstract class SbbNavigationActionCommonElement\n    extends superClass\n    implements Partial<SbbNavigationActionCommonElementMixinType>\n  {\n    public static override elementDependencies: SbbElementType[] = [SbbIconElement];\n    public static styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n    /**\n     * Action size variant, either s, m or l.\n     */\n    @property({ reflect: true }) public accessor size: SbbNavigationActionSize = 'l';\n\n    /** The section that is being controlled by the action, if any. */\n    public connectedSection?: SbbNavigationSectionElement;\n\n    /** The navigation marker in which the action is nested. */\n    public get marker(): SbbNavigationMarkerElement | null {\n      return this._navigationMarker;\n    }\n\n    /** The section in which the action is nested. */\n    public get section(): SbbNavigationSectionElement | null {\n      return this._navigationSection;\n    }\n\n    private _navigationMarker: SbbNavigationMarkerElement | null = null;\n    private _navigationSection: SbbNavigationSectionElement | null = null;\n\n    protected constructor(...args: any[]) {\n      super(...args);\n      this.addEventListener?.('click', () => {\n        if (\n          !this.matches(':state(action-active)') &&\n          this._navigationMarker &&\n          !this.connectedSection\n        ) {\n          this.marker?.select(\n            this as unknown as SbbNavigationButtonElement | SbbNavigationLinkElement,\n          );\n        }\n      });\n    }\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n\n      // Check if the current element is nested inside a navigation marker.\n      this._navigationMarker = this.closest('sbb-navigation-marker');\n\n      // Check if the current element is nested inside a navigation section.\n      this._navigationSection = this.closest('sbb-navigation-section');\n      this.toggleState('section-action', !!this._navigationSection);\n    }\n\n    protected override renderTemplate(): TemplateResult {\n      return html`<sbb-icon name=\"dash-small\"></sbb-icon> <slot></slot>`;\n    }\n  }\n  return SbbNavigationActionCommonElement as unknown as AbstractConstructor<SbbNavigationActionCommonElementMixinType> &\n    T;\n};\n"],"mappings":";;;;;;;;;;AC6BA,IAAa,yCAGX,eACsE;AA2DtE,eA1D+C;oBACrC;;;;eADK,yCACL,YAAU;;;wBASjB,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;AAAC,iBAAA,MAAA,MAAA,kBAAA;KAAA,MAAA;KAAA,MAAA;KAAA,QAAA;KAAA,SAAA;KAAA,QAAA;MAAA,MAAA,QAAA,UAAA;MAAA,MAAA,QAAA,IAAgB;MAAI,MAAA,KAAA,UAAA;AAAA,WAAJ,OAAI;;MAAA;KAAA,UAAA;KAAA,EAAA,oBAAA,wBAAA;;;;;;;;;AAN1B,SAAA,sBAAwC,CAAC,eAAe;;;AACjE,SAAA,SAAyB,CAAC,iBAAiB,UAAU,0BAAM,CAAC;;GAK7C;;;;GAAA,IAAgB,OAAI;AAAA,WAAA,MAAA;;GAApB,IAAgB,KAAI,OAAA;AAAA,UAAA,wBAAA;;;GAMjD,IAAW,SAAM;AACf,WAAO,KAAK;;;GAId,IAAW,UAAO;AAChB,WAAO,KAAK;;GAMd,YAAsB,GAAG,MAAW;AAClC,UAAM,GAAG,KAAK;AAnB6B,UAAA,wBAAA,kBAAA,MAAA,oBAAgC,IAAG;;AAGzE,SAAA,mBAAgB,kBAAA,MAAA,wBAAA;AAYf,SAAA,oBAAuD;AACvD,SAAA,qBAAyD;AAI/D,SAAK,mBAAmB,eAAc;AACpC,SACE,CAAC,KAAK,QAAQ,oDAAwB,IACtC,KAAK,qBACL,CAAC,KAAK,iBAEN,MAAK,QAAQ,OACX,KACD;MAEH;;GAGY,oBAAiB;AAC/B,UAAM,mBAAmB;AAGzB,SAAK,oBAAoB,KAAK,QAAQ,wBAAwB;AAG9D,SAAK,qBAAqB,KAAK,QAAQ,yBAAyB;AAChE,SAAK,YAAY,kBAAkB,CAAC,CAAC,KAAK,mBAAmB;;GAG5C,iBAAc;AAC/B,WAAO,MAAI;;;KAGR"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbElement, SbbNamedSlotListMixin, boxSizingStyles, forceType, omitEmptyConverter } from "./core.js";
|
|
5
|
+
//#region src/elements/navigation/navigation-list/navigation-list.scss?inline
|
|
6
|
+
var navigation_list_default = ":host {\n display: block;\n}\n\n.sbb-navigation-list__content {\n list-style: none;\n margin: 0;\n padding: 0;\n font-size: inherit;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--sbb-navigation-list-gap);\n margin-block: var(--sbb-navigation-list-margin-block);\n}\n\n.sbb-navigation-list__label {\n display: block;\n color: var(--sbb-color-5);\n padding-block-end: var(--sbb-navigation-list-padding-block-end);\n font-weight: bold;\n font-size: var(--sbb-navigation-list-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n:host(:not(:is(:state(slotted-label),[state--slotted-label]), [label])) .sbb-navigation-list__label {\n display: none;\n}";
|
|
7
|
+
//#endregion
|
|
8
|
+
//#region src/elements/navigation/navigation-list/navigation-list.component.ts
|
|
9
|
+
/**
|
|
10
|
+
* It can be used as a container for one or more `sbb-navigation-button`/`sbb-navigation-link` within a `sbb-navigation-section`.
|
|
11
|
+
*
|
|
12
|
+
* @slot - Use the unnamed slot to add content to the `sbb-navigation-list`.
|
|
13
|
+
* @slot label - Use this to provide a label element.
|
|
14
|
+
*/
|
|
15
|
+
var SbbNavigationListElement = (() => {
|
|
16
|
+
let _classSuper = SbbNamedSlotListMixin(SbbElement);
|
|
17
|
+
let _label_decorators;
|
|
18
|
+
let _label_initializers = [];
|
|
19
|
+
let _label_extraInitializers = [];
|
|
20
|
+
return class SbbNavigationListElement extends _classSuper {
|
|
21
|
+
static {
|
|
22
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
23
|
+
_label_decorators = [forceType(), property({
|
|
24
|
+
reflect: true,
|
|
25
|
+
converter: omitEmptyConverter
|
|
26
|
+
})];
|
|
27
|
+
__esDecorate(this, null, _label_decorators, {
|
|
28
|
+
kind: "accessor",
|
|
29
|
+
name: "label",
|
|
30
|
+
static: false,
|
|
31
|
+
private: false,
|
|
32
|
+
access: {
|
|
33
|
+
has: (obj) => "label" in obj,
|
|
34
|
+
get: (obj) => obj.label,
|
|
35
|
+
set: (obj, value) => {
|
|
36
|
+
obj.label = value;
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
metadata: _metadata
|
|
40
|
+
}, _label_initializers, _label_extraInitializers);
|
|
41
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
42
|
+
enumerable: true,
|
|
43
|
+
configurable: true,
|
|
44
|
+
writable: true,
|
|
45
|
+
value: _metadata
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
static {
|
|
49
|
+
this.elementName = "sbb-navigation-list";
|
|
50
|
+
}
|
|
51
|
+
static {
|
|
52
|
+
this.styles = [boxSizingStyles, unsafeCSS(navigation_list_default)];
|
|
53
|
+
}
|
|
54
|
+
#label_accessor_storage;
|
|
55
|
+
/**
|
|
56
|
+
* The label to be shown before the action list.
|
|
57
|
+
*/
|
|
58
|
+
get label() {
|
|
59
|
+
return this.#label_accessor_storage;
|
|
60
|
+
}
|
|
61
|
+
set label(value) {
|
|
62
|
+
this.#label_accessor_storage = value;
|
|
63
|
+
}
|
|
64
|
+
willUpdate(changedProperties) {
|
|
65
|
+
super.willUpdate(changedProperties);
|
|
66
|
+
if (changedProperties.has("listChildren")) this.listChildren.forEach((c) => c.size = "m");
|
|
67
|
+
}
|
|
68
|
+
render() {
|
|
69
|
+
return html`
|
|
70
|
+
<span class="sbb-navigation-list__label" id="sbb-navigation-link-label-id">
|
|
71
|
+
<slot name="label">${this.label}</slot>
|
|
72
|
+
</span>
|
|
73
|
+
${this.renderList({
|
|
74
|
+
class: "sbb-navigation-list__content",
|
|
75
|
+
ariaLabelledby: "sbb-navigation-link-label-id"
|
|
76
|
+
})}
|
|
77
|
+
`;
|
|
78
|
+
}
|
|
79
|
+
constructor() {
|
|
80
|
+
super(...arguments);
|
|
81
|
+
this.listChildLocalNames = ["sbb-navigation-button", "sbb-navigation-link"];
|
|
82
|
+
this.#label_accessor_storage = __runInitializers(this, _label_initializers, "");
|
|
83
|
+
__runInitializers(this, _label_extraInitializers);
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
})();
|
|
87
|
+
//#endregion
|
|
88
|
+
export { SbbNavigationListElement as t };
|
|
89
|
+
|
|
90
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi1saXN0LmNvbXBvbmVudC1DUTRxNjcxRy5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLWxpc3QvbmF2aWdhdGlvbi1saXN0LnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL25hdmlnYXRpb24vbmF2aWdhdGlvbi1saXN0L25hdmlnYXRpb24tbGlzdC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICBkaXNwbGF5OiBibG9jaztcbn1cblxuLnNiYi1uYXZpZ2F0aW9uLWxpc3RfX2NvbnRlbnQge1xuICBAaW5jbHVkZSBzYmIubGlzdC1yZXNldDtcblxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiB2YXIoLS1zYmItbmF2aWdhdGlvbi1saXN0LWdhcCk7XG4gIG1hcmdpbi1ibG9jazogdmFyKC0tc2JiLW5hdmlnYXRpb24tbGlzdC1tYXJnaW4tYmxvY2spO1xufVxuXG4uc2JiLW5hdmlnYXRpb24tbGlzdF9fbGFiZWwge1xuICBkaXNwbGF5OiBibG9jaztcbiAgY29sb3I6IHZhcigtLXNiYi1jb2xvci01KTtcbiAgcGFkZGluZy1ibG9jay1lbmQ6IHZhcigtLXNiYi1uYXZpZ2F0aW9uLWxpc3QtcGFkZGluZy1ibG9jay1lbmQpO1xuICBmb250LXdlaWdodDogYm9sZDtcbiAgZm9udC1zaXplOiB2YXIoLS1zYmItbmF2aWdhdGlvbi1saXN0LWZvbnQtc2l6ZSk7XG4gIGxldHRlci1zcGFjaW5nOiB2YXIoLS1zYmItdHlwby1sZXR0ZXItc3BhY2luZy10ZXh0KTtcblxuICA6aG9zdCg6bm90KDpzdGF0ZShzbG90dGVkLWxhYmVsKSwgW2xhYmVsXSkpICYge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cbn1cbiIsImltcG9ydCB7XG4gIHR5cGUgQ1NTUmVzdWx0R3JvdXAsXG4gIGh0bWwsXG4gIHR5cGUgUHJvcGVydHlWYWx1ZXMsXG4gIHR5cGUgVGVtcGxhdGVSZXN1bHQsXG4gIHVuc2FmZUNTUyxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQge1xuICBib3hTaXppbmdTdHlsZXMsXG4gIGZvcmNlVHlwZSxcbiAgb21pdEVtcHR5Q29udmVydGVyLFxuICBTYmJFbGVtZW50LFxuICBTYmJOYW1lZFNsb3RMaXN0TWl4aW4sXG4gIHR5cGUgV2l0aExpc3RDaGlsZHJlbixcbn0gZnJvbSAnLi4vLi4vY29yZS50cyc7XG5pbXBvcnQgdHlwZSB7IFNiYk5hdmlnYXRpb25CdXR0b25FbGVtZW50IH0gZnJvbSAnLi4vbmF2aWdhdGlvbi1idXR0b24vbmF2aWdhdGlvbi1idXR0b24uY29tcG9uZW50LnRzJztcbmltcG9ydCB0eXBlIHsgU2JiTmF2aWdhdGlvbkxpbmtFbGVtZW50IH0gZnJvbSAnLi4vbmF2aWdhdGlvbi1saW5rL25hdmlnYXRpb24tbGluay5jb21wb25lbnQudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9uYXZpZ2F0aW9uLWxpc3Quc2Nzcz9pbmxpbmUnO1xuXG4vKipcbiAqIEl0IGNhbiBiZSB1c2VkIGFzIGEgY29udGFpbmVyIGZvciBvbmUgb3IgbW9yZSBgc2JiLW5hdmlnYXRpb24tYnV0dG9uYC9gc2JiLW5hdmlnYXRpb24tbGlua2Agd2l0aGluIGEgYHNiYi1uYXZpZ2F0aW9uLXNlY3Rpb25gLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIGBzYmItbmF2aWdhdGlvbi1saXN0YC5cbiAqIEBzbG90IGxhYmVsIC0gVXNlIHRoaXMgdG8gcHJvdmlkZSBhIGxhYmVsIGVsZW1lbnQuXG4gKi9cbmV4cG9ydCBjbGFzcyBTYmJOYXZpZ2F0aW9uTGlzdEVsZW1lbnQgZXh0ZW5kcyBTYmJOYW1lZFNsb3RMaXN0TWl4aW48XG4gIFNiYk5hdmlnYXRpb25CdXR0b25FbGVtZW50IHwgU2JiTmF2aWdhdGlvbkxpbmtFbGVtZW50LFxuICB0eXBlb2YgU2JiRWxlbWVudFxuPihTYmJFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZyA9ICdzYmItbmF2aWdhdGlvbi1saXN0JztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgdW5zYWZlQ1NTKHN0eWxlKV07XG4gIHByb3RlY3RlZCBvdmVycmlkZSByZWFkb25seSBsaXN0Q2hpbGRMb2NhbE5hbWVzID0gW1xuICAgICdzYmItbmF2aWdhdGlvbi1idXR0b24nLFxuICAgICdzYmItbmF2aWdhdGlvbi1saW5rJyxcbiAgXTtcblxuICAvKipcbiAgICogVGhlIGxhYmVsIHRvIGJlIHNob3duIGJlZm9yZSB0aGUgYWN0aW9uIGxpc3QuXG4gICAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSwgY29udmVydGVyOiBvbWl0RW1wdHlDb252ZXJ0ZXIgfSlcbiAgcHVibGljIGFjY2Vzc29yIGxhYmVsOiBzdHJpbmcgPSAnJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8V2l0aExpc3RDaGlsZHJlbjx0aGlzPj4pOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2xpc3RDaGlsZHJlbicpKSB7XG4gICAgICB0aGlzLmxpc3RDaGlsZHJlbi5mb3JFYWNoKChjKSA9PiAoYy5zaXplID0gJ20nKSk7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8c3BhbiBjbGFzcz1cInNiYi1uYXZpZ2F0aW9uLWxpc3RfX2xhYmVsXCIgaWQ9XCJzYmItbmF2aWdhdGlvbi1saW5rLWxhYmVsLWlkXCI+XG4gICAgICAgIDxzbG90IG5hbWU9XCJsYWJlbFwiPiR7dGhpcy5sYWJlbH08L3Nsb3Q+XG4gICAgICA8L3NwYW4+XG4gICAgICAke3RoaXMucmVuZGVyTGlzdCh7XG4gICAgICAgIGNsYXNzOiAnc2JiLW5hdmlnYXRpb24tbGlzdF9fY29udGVudCcsXG4gICAgICAgIGFyaWFMYWJlbGxlZGJ5OiAnc2JiLW5hdmlnYXRpb24tbGluay1sYWJlbC1pZCcsXG4gICAgICB9KX1cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItbmF2aWdhdGlvbi1saXN0JzogU2JiTmF2aWdhdGlvbkxpc3RFbGVtZW50O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7O0lDNEJhLGtDQUF3QjttQkFBUyxzQkFHNUMsV0FBVzs7OztjQUhBLGlDQUFpQyxZQUdqQzs7O3dCQVdWLFdBQVcsRUFDWCxTQUFTO0lBQUUsU0FBUztJQUFNLFdBQVc7SUFBb0IsQ0FBQyxDQUFBO0FBQzNELGdCQUFBLE1BQUEsTUFBQSxtQkFBQTtJQUFBLE1BQUE7SUFBQSxNQUFBO0lBQUEsUUFBQTtJQUFBLFNBQUE7SUFBQSxRQUFBO0tBQUEsTUFBQSxRQUFBLFdBQUE7S0FBQSxNQUFBLFFBQUEsSUFBZ0I7S0FBSyxNQUFBLEtBQUEsVUFBQTtBQUFBLFVBQUwsUUFBSzs7S0FBQTtJQUFBLFVBQUE7SUFBQSxFQUFBLHFCQUFBLHlCQUFBOzs7Ozs7Ozs7QUFaVyxRQUFBLGNBQXNCOzs7QUFDL0IsUUFBQSxTQUF5QixDQUFDLGlCQUFpQixVQUFVLHdCQUFNLENBQUM7O0VBV25GOzs7O0VBQUEsSUFBZ0IsUUFBSztBQUFBLFVBQUEsTUFBQTs7RUFBckIsSUFBZ0IsTUFBSyxPQUFBO0FBQUEsU0FBQSx5QkFBQTs7RUFFRixXQUFXLG1CQUF5RDtBQUNyRixTQUFNLFdBQVcsa0JBQWtCO0FBRW5DLE9BQUksa0JBQWtCLElBQUksZUFBZSxDQUN2QyxNQUFLLGFBQWEsU0FBUyxNQUFPLEVBQUUsT0FBTyxJQUFLOztFQUlqQyxTQUFNO0FBQ3ZCLFVBQU8sSUFBSTs7NkJBRWMsS0FBSyxNQUFLOztRQUUvQixLQUFLLFdBQVc7SUFDaEIsT0FBTztJQUNQLGdCQUFnQjtJQUNqQixDQUFDLENBQUE7Ozs7O0FBNUJzQixRQUFBLHNCQUFzQixDQUNoRCx5QkFDQSxzQkFDRDtBQU9lLFNBQUEseUJBQUEsa0JBQUEsTUFBQSxxQkFBZ0IsR0FBRSJ9
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbElement, SbbNamedSlotListMixin, boxSizingStyles, ɵstateController } from "./core.js";
|
|
5
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
6
|
+
//#region src/elements/navigation/navigation-marker/navigation-marker.scss?inline
|
|
7
|
+
var navigation_marker_default = ":host {\n --sbb-navigation-marker-margin-block: calc(\n 1em * var(--sbb-navigation-marker-typo-line-height) / 2 - var(--sbb-navigation-marker-border) /\n 2\n );\n display: block;\n}\n\n:host([size=l]) {\n --sbb-navigation-marker-font-size: var(--sbb-heading-font-size-4);\n --sbb-navigation-marker-letter-spacing: var(--sbb-typo-letter-spacing-heading);\n --sbb-navigation-marker-line-height: var(--sbb-typo-line-height-heading);\n}\n\n:host([size=s]) {\n --sbb-navigation-action-gap: var(--sbb-spacing-fixed-2x);\n --sbb-navigation-marker-width: 0.5rem;\n --sbb-navigation-marker-typo-line-height: var(--sbb-typo-line-height-text);\n --sbb-navigation-margin-inline-start: var(--sbb-spacing-fixed-2x);\n --sbb-navigation-marker-position-x: calc(\n var(--sbb-navigation-marker-padding-inline-start) - var(--sbb-spacing-fixed-2x)\n );\n --sbb-navigation-marker-padding-inline-start: calc(\n var(--sbb-spacing-fixed-6x) + var(--sbb-spacing-fixed-1x)\n );\n --sbb-navigation-marker-font-size: var(--sbb-text-font-size-xxs);\n --sbb-navigation-marker-letter-spacing: var(--sbb-typo-letter-spacing-text);\n --sbb-navigation-marker-line-height: var(--sbb-typo-line-height-text);\n}\n\n.sbb-navigation-marker {\n list-style: none;\n margin: 0;\n padding: 0;\n font-size: inherit;\n position: relative;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n gap: var(--sbb-navigation-action-gap);\n padding-inline-start: var(--sbb-navigation-marker-padding-inline-start);\n font-size: var(--sbb-navigation-marker-font-size);\n line-height: var(--sbb-navigation-marker-line-height);\n letter-spacing: var(--sbb-navigation-marker-letter-spacing);\n font-weight: bold;\n}\n.sbb-navigation-marker::before {\n content: \"\";\n position: absolute;\n opacity: 0;\n inset-inline-start: var(--sbb-navigation-marker-position-x);\n inset-block-start: var(--sbb-navigation-marker-position-y);\n width: var(--sbb-navigation-marker-width);\n border-block-start: var(--sbb-navigation-marker-border) solid var(--sbb-color-5);\n margin-block: var(--sbb-navigation-marker-margin-block);\n transition-duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-6x));\n transition-timing-function: ease;\n transition-property: opacity, inset-block-start;\n}\n:host(:is(:state(has-active-action),[state--has-active-action])) .sbb-navigation-marker::before {\n opacity: 1;\n}\n@media (forced-colors: active) {\n .sbb-navigation-marker::before {\n border-color: CanvasText;\n }\n}\n\n::slotted(:is(sbb-navigation-button, sbb-navigation-link)) {\n margin-inline-start: var(--sbb-navigation-margin-inline-start);\n}";
|
|
8
|
+
//#endregion
|
|
9
|
+
//#region src/elements/navigation/navigation-marker/navigation-marker.component.ts
|
|
10
|
+
/**
|
|
11
|
+
* It can be used as a container for one or more `sbb-navigation-button`/`sbb-navigation-link` within a `sbb-navigation`.
|
|
12
|
+
*
|
|
13
|
+
* @slot - Use the unnamed slot to add `sbb-navigation-button`/`sbb-navigation-link` elements into the `sbb-navigation-marker`.
|
|
14
|
+
*/
|
|
15
|
+
var SbbNavigationMarkerElement = (() => {
|
|
16
|
+
let _classSuper = SbbNamedSlotListMixin(SbbElement);
|
|
17
|
+
let _size_decorators;
|
|
18
|
+
let _size_initializers = [];
|
|
19
|
+
let _size_extraInitializers = [];
|
|
20
|
+
return class SbbNavigationMarkerElement extends _classSuper {
|
|
21
|
+
static {
|
|
22
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
23
|
+
_size_decorators = [property({ reflect: true })];
|
|
24
|
+
__esDecorate(this, null, _size_decorators, {
|
|
25
|
+
kind: "accessor",
|
|
26
|
+
name: "size",
|
|
27
|
+
static: false,
|
|
28
|
+
private: false,
|
|
29
|
+
access: {
|
|
30
|
+
has: (obj) => "size" in obj,
|
|
31
|
+
get: (obj) => obj.size,
|
|
32
|
+
set: (obj, value) => {
|
|
33
|
+
obj.size = value;
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
metadata: _metadata
|
|
37
|
+
}, _size_initializers, _size_extraInitializers);
|
|
38
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
39
|
+
enumerable: true,
|
|
40
|
+
configurable: true,
|
|
41
|
+
writable: true,
|
|
42
|
+
value: _metadata
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
static {
|
|
46
|
+
this.elementName = "sbb-navigation-marker";
|
|
47
|
+
}
|
|
48
|
+
static {
|
|
49
|
+
this.styles = [boxSizingStyles, unsafeCSS(navigation_marker_default)];
|
|
50
|
+
}
|
|
51
|
+
#size_accessor_storage;
|
|
52
|
+
/**
|
|
53
|
+
* Marker size variant, either s or l.
|
|
54
|
+
*/
|
|
55
|
+
get size() {
|
|
56
|
+
return this.#size_accessor_storage;
|
|
57
|
+
}
|
|
58
|
+
set size(value) {
|
|
59
|
+
this.#size_accessor_storage = value;
|
|
60
|
+
}
|
|
61
|
+
constructor() {
|
|
62
|
+
super();
|
|
63
|
+
this.listChildLocalNames = ["sbb-navigation-button", "sbb-navigation-link"];
|
|
64
|
+
this.#size_accessor_storage = __runInitializers(this, _size_initializers, "l");
|
|
65
|
+
this._currentActiveAction = __runInitializers(this, _size_extraInitializers);
|
|
66
|
+
this.addController(new ResizeController(this, {
|
|
67
|
+
skipInitial: true,
|
|
68
|
+
callback: () => this._setMarkerPosition()
|
|
69
|
+
}));
|
|
70
|
+
}
|
|
71
|
+
willUpdate(changedProperties) {
|
|
72
|
+
super.willUpdate(changedProperties);
|
|
73
|
+
if (changedProperties.has("size") || changedProperties.has("listChildren")) this._updateMarkerActions();
|
|
74
|
+
this.toggleState("has-active-action", !!this._currentActiveAction);
|
|
75
|
+
}
|
|
76
|
+
_updateMarkerActions() {
|
|
77
|
+
for (const action of this.listChildren) action.size = this.size;
|
|
78
|
+
this._currentActiveAction = this.listChildren.find((action) => action.matches(":is(:state(action-active),[state--action-active])"));
|
|
79
|
+
this._setMarkerPosition();
|
|
80
|
+
}
|
|
81
|
+
connectedCallback() {
|
|
82
|
+
super.connectedCallback();
|
|
83
|
+
this._checkActiveAction();
|
|
84
|
+
}
|
|
85
|
+
_checkActiveAction() {
|
|
86
|
+
const activeAction = this.querySelector(":is(sbb-navigation-button, sbb-navigation-link).sbb-active");
|
|
87
|
+
if (activeAction) this.select(activeAction);
|
|
88
|
+
}
|
|
89
|
+
select(action) {
|
|
90
|
+
if (!action) return;
|
|
91
|
+
this.reset();
|
|
92
|
+
ɵstateController(action).add("action-active");
|
|
93
|
+
this._currentActiveAction = action;
|
|
94
|
+
setTimeout(() => this._setMarkerPosition());
|
|
95
|
+
}
|
|
96
|
+
firstUpdated(changedProperties) {
|
|
97
|
+
super.firstUpdated(changedProperties);
|
|
98
|
+
setTimeout(() => this._setMarkerPosition());
|
|
99
|
+
}
|
|
100
|
+
reset() {
|
|
101
|
+
if (this._currentActiveAction) {
|
|
102
|
+
ɵstateController(this._currentActiveAction).delete("action-active");
|
|
103
|
+
this._currentActiveAction.connectedSection?.close();
|
|
104
|
+
this._currentActiveAction = void 0;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
_setMarkerPosition() {
|
|
108
|
+
if (!this._currentActiveAction) return;
|
|
109
|
+
const index = this.listChildren.indexOf(this._currentActiveAction);
|
|
110
|
+
const value = this.shadowRoot.querySelector(`li:nth-child(${index + 1})`)?.offsetTop;
|
|
111
|
+
if (value != null) this.style?.setProperty("--sbb-navigation-marker-position-y", `${value}px`);
|
|
112
|
+
}
|
|
113
|
+
render() {
|
|
114
|
+
return this.renderList();
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
})();
|
|
118
|
+
//#endregion
|
|
119
|
+
export { SbbNavigationMarkerElement as t };
|
|
120
|
+
|
|
121
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"navigation-marker.component-D7ks8vbC.js","names":[],"sources":["../../../src/elements/navigation/navigation-marker/navigation-marker.scss?inline","../../../src/elements/navigation/navigation-marker/navigation-marker.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-navigation-marker-margin-block: calc(\n    1em * var(--sbb-navigation-marker-typo-line-height) / 2 - var(--sbb-navigation-marker-border) /\n      2\n  );\n\n  display: block;\n}\n\n:host([size='l']) {\n  --sbb-navigation-marker-font-size: var(--sbb-heading-font-size-4);\n  --sbb-navigation-marker-letter-spacing: var(--sbb-typo-letter-spacing-heading);\n  --sbb-navigation-marker-line-height: var(--sbb-typo-line-height-heading);\n}\n\n:host([size='s']) {\n  --sbb-navigation-action-gap: var(--sbb-spacing-fixed-2x);\n  --sbb-navigation-marker-width: #{sbb.px-to-rem-build(8)};\n  --sbb-navigation-marker-typo-line-height: var(--sbb-typo-line-height-text);\n  --sbb-navigation-margin-inline-start: var(--sbb-spacing-fixed-2x);\n  --sbb-navigation-marker-position-x: calc(\n    var(--sbb-navigation-marker-padding-inline-start) - var(--sbb-spacing-fixed-2x)\n  );\n  --sbb-navigation-marker-padding-inline-start: calc(\n    var(--sbb-spacing-fixed-6x) + var(--sbb-spacing-fixed-1x)\n  );\n  --sbb-navigation-marker-font-size: var(--sbb-text-font-size-xxs);\n  --sbb-navigation-marker-letter-spacing: var(--sbb-typo-letter-spacing-text);\n  --sbb-navigation-marker-line-height: var(--sbb-typo-line-height-text);\n}\n\n.sbb-navigation-marker {\n  @include sbb.list-reset;\n\n  position: relative;\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  gap: var(--sbb-navigation-action-gap);\n  padding-inline-start: var(--sbb-navigation-marker-padding-inline-start);\n  font-size: var(--sbb-navigation-marker-font-size);\n  line-height: var(--sbb-navigation-marker-line-height);\n  letter-spacing: var(--sbb-navigation-marker-letter-spacing);\n  font-weight: bold;\n\n  &::before {\n    content: '';\n    position: absolute;\n    opacity: 0;\n    inset-inline-start: var(--sbb-navigation-marker-position-x);\n    inset-block-start: var(--sbb-navigation-marker-position-y);\n    width: var(--sbb-navigation-marker-width);\n    border-block-start: var(--sbb-navigation-marker-border) solid var(--sbb-color-5);\n    margin-block: var(--sbb-navigation-marker-margin-block);\n    transition: {\n      duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-6x));\n      timing-function: ease;\n      property: opacity, inset-block-start;\n    }\n\n    :host(:state(has-active-action)) & {\n      opacity: 1;\n    }\n\n    @include sbb.if-forced-colors {\n      border-color: CanvasText;\n    }\n  }\n}\n\n::slotted(:is(sbb-navigation-button, sbb-navigation-link)) {\n  margin-inline-start: var(--sbb-navigation-margin-inline-start);\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport {\n  boxSizingStyles,\n  SbbElement,\n  SbbNamedSlotListMixin,\n  type WithListChildren,\n  ɵstateController,\n} from '../../core.ts';\nimport type { SbbNavigationButtonElement } from '../navigation-button/navigation-button.component.ts';\nimport type { SbbNavigationLinkElement } from '../navigation-link/navigation-link.component.ts';\n\nimport style from './navigation-marker.scss?inline';\n\n/**\n * It can be used as a container for one or more `sbb-navigation-button`/`sbb-navigation-link` within a `sbb-navigation`.\n *\n * @slot - Use the unnamed slot to add `sbb-navigation-button`/`sbb-navigation-link` elements into the `sbb-navigation-marker`.\n */\nexport class SbbNavigationMarkerElement extends SbbNamedSlotListMixin<\n  SbbNavigationButtonElement | SbbNavigationLinkElement,\n  typeof SbbElement\n>(SbbElement) {\n  public static override readonly elementName: string = 'sbb-navigation-marker';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  protected override readonly listChildLocalNames = [\n    'sbb-navigation-button',\n    'sbb-navigation-link',\n  ];\n\n  /**\n   * Marker size variant, either s or l.\n   */\n  @property({ reflect: true }) public accessor size: 'l' | 's' = 'l';\n\n  private _currentActiveAction?: SbbNavigationButtonElement | SbbNavigationLinkElement;\n\n  public constructor() {\n    super();\n\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._setMarkerPosition(),\n      }),\n    );\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('size') || changedProperties.has('listChildren')) {\n      this._updateMarkerActions();\n    }\n    this.toggleState('has-active-action', !!this._currentActiveAction);\n  }\n\n  private _updateMarkerActions(): void {\n    for (const action of this.listChildren) {\n      action.size = this.size;\n    }\n\n    this._currentActiveAction = this.listChildren.find((action) =>\n      action.matches(':state(action-active)'),\n    );\n    this._setMarkerPosition();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._checkActiveAction();\n  }\n\n  private _checkActiveAction(): void {\n    const activeAction = this.querySelector(\n      ':is(sbb-navigation-button, sbb-navigation-link).sbb-active',\n    ) as SbbNavigationButtonElement | SbbNavigationLinkElement;\n    if (activeAction) {\n      this.select(activeAction);\n    }\n  }\n\n  public select(action: SbbNavigationButtonElement | SbbNavigationLinkElement): void {\n    if (!action) {\n      return;\n    }\n    this.reset();\n    ɵstateController(action).add('action-active');\n    this._currentActiveAction = action;\n    setTimeout(() => this._setMarkerPosition());\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.firstUpdated(changedProperties);\n\n    setTimeout(() => this._setMarkerPosition());\n  }\n\n  public reset(): void {\n    if (this._currentActiveAction) {\n      ɵstateController(this._currentActiveAction).delete('action-active');\n      this._currentActiveAction.connectedSection?.close();\n      this._currentActiveAction = undefined;\n    }\n  }\n\n  private _setMarkerPosition(): void {\n    if (!this._currentActiveAction) {\n      return;\n    }\n\n    const index = this.listChildren.indexOf(this._currentActiveAction)!;\n    const value = this.shadowRoot!.querySelector<HTMLLIElement>(\n      `li:nth-child(${index + 1})`,\n    )?.offsetTop;\n    if (value != null) {\n      this.style?.setProperty('--sbb-navigation-marker-position-y', `${value}px`);\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return this.renderList();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-navigation-marker': SbbNavigationMarkerElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;ICqBa,oCAA0B;mBAAS,sBAG9C,WAAW;;;;cAHA,mCAAmC,YAGnC;;;uBAWV,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;AAAC,gBAAA,MAAA,MAAA,kBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,UAAA;KAAA,MAAA,QAAA,IAAgB;KAAI,MAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;;KAAA;IAAA,UAAA;IAAA,EAAA,oBAAA,wBAAA;;;;;;;;;AAVjB,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,0BAAM,CAAC;;EAStD;;;;EAAA,IAAgB,OAAI;AAAA,UAAA,MAAA;;EAApB,IAAgB,KAAI,OAAA;AAAA,SAAA,wBAAA;;EAIjD,cAAA;AACE,UAAO;AAbmB,QAAA,sBAAsB,CAChD,yBACA,sBACD;AAK4C,SAAA,wBAAA,kBAAA,MAAA,oBAAkB,IAAG;AAE1D,QAAA,uBAAoB,kBAAA,MAAA,wBAAA;AAK1B,QAAK,cACH,IAAI,iBAAiB,MAAM;IACzB,aAAa;IACb,gBAAgB,KAAK,oBAAA;IACtB,CAAC,CACH;;EAGgB,WAAW,mBAAyD;AACrF,SAAM,WAAW,kBAAkB;AAEnC,OAAI,kBAAkB,IAAI,OAAO,IAAI,kBAAkB,IAAI,eAAe,CACxE,MAAK,sBAAsB;AAE7B,QAAK,YAAY,qBAAqB,CAAC,CAAC,KAAK,qBAAqB;;EAG5D,uBAAoB;AAC1B,QAAK,MAAM,UAAU,KAAK,aACxB,QAAO,OAAO,KAAK;AAGrB,QAAK,uBAAuB,KAAK,aAAa,MAAM,WAClD,OAAO,QAAQ,oDAAwB,CACxC;AACD,QAAK,oBAAoB;;EAGX,oBAAiB;AAC/B,SAAM,mBAAmB;AACzB,QAAK,oBAAoB;;EAGnB,qBAAkB;GACxB,MAAM,eAAe,KAAK,cACxB,6DACwD;AAC1D,OAAI,aACF,MAAK,OAAO,aAAa;;EAItB,OAAO,QAA6D;AACzE,OAAI,CAAC,OACH;AAEF,QAAK,OAAO;AACZ,oBAAiB,OAAO,CAAC,IAAI,gBAAgB;AAC7C,QAAK,uBAAuB;AAC5B,oBAAiB,KAAK,oBAAoB,CAAC;;EAG1B,aAAa,mBAAyD;AACvF,SAAM,aAAa,kBAAkB;AAErC,oBAAiB,KAAK,oBAAoB,CAAC;;EAGtC,QAAK;AACV,OAAI,KAAK,sBAAsB;AAC7B,qBAAiB,KAAK,qBAAqB,CAAC,OAAO,gBAAgB;AACnE,SAAK,qBAAqB,kBAAkB,OAAO;AACnD,SAAK,uBAAuB,KAAA;;;EAIxB,qBAAkB;AACxB,OAAI,CAAC,KAAK,qBACR;GAGF,MAAM,QAAQ,KAAK,aAAa,QAAQ,KAAK,qBAAsB;GACnE,MAAM,QAAQ,KAAK,WAAY,cAC7B,gBAAgB,QAAQ,EAAC,GAC1B,EAAE;AACH,OAAI,SAAS,KACX,MAAK,OAAO,YAAY,sCAAsC,GAAG,MAAK,IAAK;;EAI5D,SAAM;AACvB,UAAO,KAAK,YAAY"}
|