@sbb-esta/lyne-elements-dev 5.0.0-next.1-dev.1777534945 → 5.0.0-next.1-dev.1777543026
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/autocomplete/autocomplete-base-element.js +1 -1
- package/autocomplete/autocomplete.component.js +1 -1
- package/{autocomplete-base-element-CSCv_WVh.js → autocomplete-base-element-BiLyvcN-.js} +1 -1
- package/autocomplete.js +1 -1
- package/autocomplete.pure.js +1 -1
- package/core/styles/mixins/scrollbar.scss +0 -6
- package/core/styles/scrollbar.scss +19 -24
- package/core/styles/styles.js +2 -2
- package/core.css +0 -37
- package/core.js +2 -2
- package/custom-elements.json +66 -16
- package/development/autocomplete/autocomplete-base-element.js +1 -1
- package/development/autocomplete/autocomplete.component.js +1 -1
- package/development/{autocomplete-base-element-Bwkns3IL.js → autocomplete-base-element-BxBpn8_e.js} +2 -2
- package/development/autocomplete.js +1 -1
- package/development/autocomplete.pure.js +1 -1
- package/development/core/styles/styles.d.ts +1 -0
- package/development/core/styles/styles.d.ts.map +1 -1
- package/development/core/styles/styles.js +2 -2
- package/development/core.js +2 -2
- package/development/dialog/dialog-content/dialog-content.component.d.ts +1 -0
- package/development/dialog/dialog-content/dialog-content.component.d.ts.map +1 -1
- package/development/dialog/dialog-content/dialog-content.component.js +1 -1
- package/development/{dialog-content.component-B7Grxjk6.js → dialog-content.component-Bzt-PL6f.js} +10 -3
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/file-selector/common/file-selector-common.d.ts +1 -2
- package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/development/file-selector/common/file-selector-common.js +2 -2
- package/development/file-selector/file-selector/file-selector.component.d.ts +1 -2
- package/development/file-selector/file-selector/file-selector.component.d.ts.map +1 -1
- package/development/file-selector/file-selector/file-selector.component.js +3 -6
- package/development/file-selector/file-selector-dropzone/file-selector-dropzone.component.d.ts.map +1 -1
- package/development/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +1 -1
- package/development/file-selector-common-BH_iIjcB.js +417 -0
- package/development/{file-selector-dropzone.component-DRUUWI1A.js → file-selector-dropzone.component-ZCanLwF-.js} +4 -8
- package/development/file-selector.js +3 -3
- package/development/file-selector.pure.js +3 -3
- package/development/map-container/map-container.component.d.ts.map +1 -1
- package/development/map-container/map-container.component.js +1 -1
- package/development/map-container.component-DoFCVBoh.js +180 -0
- package/development/map-container.js +1 -1
- package/development/map-container.pure.js +1 -1
- package/development/menu/menu/menu.component.d.ts.map +1 -1
- package/development/menu/menu/menu.component.js +1 -1
- package/development/menu.component-CDBUaD8s.js +369 -0
- package/development/menu.js +1 -1
- package/development/menu.pure.js +1 -1
- package/development/navigation/navigation/navigation.component.d.ts.map +1 -1
- package/development/navigation/navigation/navigation.component.js +1 -1
- package/development/navigation/navigation-section/navigation-section.component.d.ts.map +1 -1
- package/development/navigation/navigation-section/navigation-section.component.js +1 -1
- package/development/navigation-section.component-D3_XVwyt.js +350 -0
- package/development/navigation.component-Cco4llBt.js +319 -0
- package/development/navigation.js +2 -2
- package/development/navigation.pure.js +2 -2
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -1
- package/development/overlay.component-DBzb0PdD.js +206 -0
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/development/popover/popover.component.d.ts +1 -0
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +1 -1
- package/development/popover.component-Dj0INQsI.js +564 -0
- package/development/popover.js +1 -1
- package/development/popover.pure.js +1 -1
- package/development/select/select.component.js +1 -1
- package/development/{select.component-C1Xfvvii.js → select.component-D_9pjl7T.js} +2 -2
- package/development/select.js +1 -1
- package/development/select.pure.js +1 -1
- package/development/sidebar/sidebar/sidebar.component.d.ts.map +1 -1
- package/development/sidebar/sidebar/sidebar.component.js +1 -1
- package/development/sidebar.component-CYLbI1Vp.js +356 -0
- package/development/sidebar.js +1 -1
- package/development/sidebar.pure.js +1 -1
- package/development/styles-B_IWjHc5.js +22 -0
- package/development/table/table-wrapper/table-wrapper.component.js +1 -1
- package/development/table-wrapper.component-D8IFPow6.js +119 -0
- package/development/table.js +1 -1
- package/development/table.pure.js +1 -1
- package/dialog/dialog-content/dialog-content.component.js +1 -1
- package/{dialog-content.component-are-UBx3.js → dialog-content.component-iRLHPKPb.js} +7 -2
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/file-selector/common/file-selector-common.js +2 -2
- package/file-selector/file-selector/file-selector.component.js +10 -13
- package/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +1 -1
- package/{file-selector-common-jpJmVqAw.js → file-selector-common-PcqPdsnN.js} +44 -38
- package/{file-selector-dropzone.component-DDRTu6p2.js → file-selector-dropzone.component-2XUfh1NC.js} +20 -24
- package/file-selector.js +5 -5
- package/file-selector.pure.js +4 -4
- package/map-container/map-container.component.js +1 -1
- package/{map-container.component-Btnl3n9d.js → map-container.component-5I5DW5dJ.js} +23 -16
- package/map-container.js +1 -1
- package/map-container.pure.js +1 -1
- package/menu/menu/menu.component.js +1 -1
- package/{menu.component-CpNMheMG.js → menu.component-Bd37u3Ps.js} +26 -22
- package/menu.js +1 -1
- package/menu.pure.js +1 -1
- package/navigation/navigation/navigation.component.js +1 -1
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/{navigation-section.component-219JlVIe.js → navigation-section.component-B_0xi30L.js} +24 -20
- package/{navigation.component-gLrMCbh9.js → navigation.component-CmrLIeDB.js} +24 -20
- package/navigation.js +2 -2
- package/navigation.pure.js +2 -2
- package/off-brand-theme.css +33 -134
- package/overlay/overlay.component.js +1 -1
- package/overlay.component-D2jtCeeb.js +156 -0
- package/overlay.js +1 -1
- package/overlay.pure.js +1 -1
- package/package.json +2 -2
- package/popover/popover.component.js +1 -1
- package/{popover.component-DnY9obd7.js → popover.component-CiMeNnO-.js} +27 -24
- package/popover.js +1 -1
- package/popover.pure.js +1 -1
- package/safety-theme.css +33 -134
- package/scrollbar.css +33 -97
- package/select/select.component.js +1 -1
- package/{select.component-Bhvd_sUV.js → select.component-BXPU7X_X.js} +1 -1
- package/select.js +1 -1
- package/select.pure.js +1 -1
- package/sidebar/sidebar/sidebar.component.js +1 -1
- package/{sidebar.component-Dpf9jZ1P.js → sidebar.component-CeUPJaqy.js} +28 -21
- package/sidebar.js +1 -1
- package/sidebar.pure.js +1 -1
- package/standard-theme.css +33 -134
- package/styles-Cb4jdMeE.js +5 -0
- package/table/table-wrapper/table-wrapper.component.js +1 -1
- package/{table-wrapper.component-DGL8RaxF.js → table-wrapper.component-CZ90q3pY.js} +1 -1
- package/table.js +1 -1
- package/table.pure.js +1 -1
- package/development/file-selector-common-BwkZZzA0.js +0 -409
- package/development/map-container.component-BLF21LG7.js +0 -173
- package/development/menu.component-BpKGNICN.js +0 -365
- package/development/navigation-section.component-DumXFFfg.js +0 -346
- package/development/navigation.component-CpoBEP55.js +0 -315
- package/development/overlay.component-CC_quHYI.js +0 -206
- package/development/popover.component-DT-cfDqo.js +0 -561
- package/development/sidebar.component-DR2JGwnM.js +0 -349
- package/development/styles-6T7UvhxK.js +0 -18
- package/development/table-wrapper.component-CjMOENHV.js +0 -119
- package/overlay.component-B00EoAd5.js +0 -156
- package/styles-D5okOWF1.js +0 -5
|
@@ -0,0 +1,350 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, nothing, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { IS_FOCUSABLE_QUERY, SbbFocusTrapController, SbbLanguageController, SbbMediaMatcherController, SbbMediaQueryBreakpointSmallAndBelow, SbbOpenCloseBaseElement, SbbUpdateSchedulerMixin, boxSizingStyles, forceType, i18nGoBack, idReference, isZeroAnimationDuration, omitEmptyConverter, removeAriaOverlayTriggerProperties, sbbInputModalityDetector, scrollbarStyles, setAriaOverlayTriggerProperties, ɵstateController } from "./core.js";
|
|
5
|
+
import { SbbTransparentButtonElement } from "./button.pure.js";
|
|
6
|
+
//#region src/elements/navigation/navigation-section/navigation-section.scss?inline
|
|
7
|
+
var navigation_section_default = ":host {\n --sbb-navigation-section-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-3x)\n );\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n display: var(--sbb-navigation-section-display, none);\n position: var(--sbb-navigation-section-position);\n grid-column: var(--sbb-navigation-section-column);\n inset-inline-start: 0;\n inset-block-start: 0;\n width: var(--sbb-navigation-section-width);\n height: var(--sbb-navigation-section-height);\n z-index: var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));\n}\n@media (min-width: calc(64rem)) {\n :host {\n --sbb-navigation-section-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n --sbb-navigation-section-width: calc(\n 100% + var(--sbb-layout-base-offset-responsive) + var(--sbb-grid-base-gutter-responsive)\n );\n translate: calc(var(--sbb-grid-base-gutter-responsive) * -1) 0;\n }\n}\n\n:host(:is(:state(state-opened),[state--state-opened])) {\n --sbb-navigation-section-pointer-events: all;\n}\n\n:host(:is(:state(state-opening),[state--state-opening])) {\n --sbb-navigation-section-position: absolute;\n}\n\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-closing),[state--state-closing]))) {\n --sbb-navigation-section-pointer-events: none;\n}\n\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) {\n --sbb-navigation-section-display: block;\n}\n\n::slotted(*) {\n padding-inline-start: var(--sbb-navigation-section-content-padding-inline-start);\n}\n\n::slotted(:is(:state(sbb-button),[state--sbb-button])) {\n grid-column-start: 1;\n}\n\n.sbb-navigation-section__container {\n pointer-events: var(--sbb-navigation-section-pointer-events);\n height: var(--sbb-navigation-section-height);\n}\n\n.sbb-navigation-section {\n display: none;\n border: none;\n margin: 0;\n width: 100%;\n height: 100%;\n color: var(--sbb-navigation-color, var(--sbb-color-1-negative));\n background-color: transparent;\n padding: 0;\n overflow: hidden;\n}\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-navigation-section {\n display: block;\n animation-name: open;\n animation-duration: var(--sbb-navigation-section-animation-duration);\n animation-timing-function: var(--sbb-navigation-section-animation-easing);\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-navigation-section {\n animation-name: close;\n}\n@media (forced-colors: active) {\n .sbb-navigation-section {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n\n.sbb-navigation-section__wrapper {\n height: 100%;\n padding-block: var(--sbb-navigation-section-padding-block);\n outline: none;\n overflow-y: auto;\n}\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-closing),[state--state-closing]))) .sbb-navigation-section__wrapper {\n --sbb-scrollbar-color: transparent;\n scrollbar-color: transparent transparent;\n}\n\n.sbb-navigation-section__header {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--sbb-spacing-fixed-1x);\n margin-block-start: var(--sbb-spacing-responsive-xxl);\n padding-inline-start: var(--sbb-navigation-section-content-padding-inline-start);\n}\n@media (min-width: calc(64rem)) {\n .sbb-navigation-section__header {\n margin-block-start: 0;\n padding-inline-start: 0;\n }\n}\n@media (min-width: calc(90rem)) {\n .sbb-navigation-section__header {\n grid-column: 1/4;\n }\n}\n\n.sbb-navigation-section__back {\n position: absolute;\n translate: calc((100% + var(--sbb-spacing-fixed-1x)) * -1) 0;\n}\n@media (min-width: calc(64rem)) {\n .sbb-navigation-section__back {\n display: none;\n }\n}\n\n.sbb-navigation-section__title {\n font-weight: bold;\n font-size: var(--sbb-navigation-section-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-heading);\n line-height: var(--sbb-typo-line-height-heading);\n}\n\n.sbb-navigation-section__content {\n display: grid;\n grid-template-columns: 1fr;\n gap: var(--sbb-spacing-responsive-l) var(--sbb-grid-base-gutter-responsive);\n padding-inline: var(--sbb-navigation-section-padding-inline);\n}\n@media (min-width: calc(64rem)) {\n .sbb-navigation-section__content {\n opacity: 0;\n translate: 0 var(--sbb-spacing-fixed-3x);\n transition-duration: var(--sbb-navigation-section-animation-duration);\n transition-delay: var(--sbb-navigation-section-animation-duration);\n transition-timing-function: var(--sbb-navigation-section-animation-easing);\n transition-property: opacity, translate;\n }\n :host(:is(:state(state-opened),[state--state-opened])) .sbb-navigation-section__content {\n opacity: 1;\n translate: 0 0;\n }\n}\n@media (min-width: calc(90rem)) {\n .sbb-navigation-section__content {\n grid-template-columns: repeat(3, 1fr);\n }\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-navigation-section__content {\n transition-delay: 0s;\n}\n\n@keyframes open {\n from {\n translate: var(--sbb-navigation-section-translate) 0;\n }\n to {\n translate: 0 0;\n }\n}\n@keyframes close {\n from {\n translate: 0 0;\n }\n to {\n translate: var(--sbb-navigation-section-translate) 0;\n }\n}";
|
|
8
|
+
//#endregion
|
|
9
|
+
//#region src/elements/navigation/navigation-section/navigation-section.component.ts
|
|
10
|
+
/**
|
|
11
|
+
* It can be used as a container for `sbb-navigation-list` within a `sbb-navigation`.
|
|
12
|
+
*
|
|
13
|
+
* @slot - Use the unnamed slot to add content into the `sbb-navigation-section`.
|
|
14
|
+
*/
|
|
15
|
+
var SbbNavigationSectionElement = (() => {
|
|
16
|
+
let _classSuper = SbbUpdateSchedulerMixin(SbbOpenCloseBaseElement);
|
|
17
|
+
let _titleContent_decorators;
|
|
18
|
+
let _titleContent_initializers = [];
|
|
19
|
+
let _titleContent_extraInitializers = [];
|
|
20
|
+
let _trigger_decorators;
|
|
21
|
+
let _trigger_initializers = [];
|
|
22
|
+
let _trigger_extraInitializers = [];
|
|
23
|
+
let _accessibilityLabel_decorators;
|
|
24
|
+
let _accessibilityLabel_initializers = [];
|
|
25
|
+
let _accessibilityLabel_extraInitializers = [];
|
|
26
|
+
let _accessibilityBackLabel_decorators;
|
|
27
|
+
let _accessibilityBackLabel_initializers = [];
|
|
28
|
+
let _accessibilityBackLabel_extraInitializers = [];
|
|
29
|
+
return class SbbNavigationSectionElement extends _classSuper {
|
|
30
|
+
static {
|
|
31
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
32
|
+
_titleContent_decorators = [forceType(), property({
|
|
33
|
+
attribute: "title-content",
|
|
34
|
+
reflect: true,
|
|
35
|
+
converter: omitEmptyConverter
|
|
36
|
+
})];
|
|
37
|
+
_trigger_decorators = [idReference(), property()];
|
|
38
|
+
_accessibilityLabel_decorators = [forceType(), property({ attribute: "accessibility-label" })];
|
|
39
|
+
_accessibilityBackLabel_decorators = [forceType(), property({ attribute: "accessibility-back-label" })];
|
|
40
|
+
__esDecorate(this, null, _titleContent_decorators, {
|
|
41
|
+
kind: "accessor",
|
|
42
|
+
name: "titleContent",
|
|
43
|
+
static: false,
|
|
44
|
+
private: false,
|
|
45
|
+
access: {
|
|
46
|
+
has: (obj) => "titleContent" in obj,
|
|
47
|
+
get: (obj) => obj.titleContent,
|
|
48
|
+
set: (obj, value) => {
|
|
49
|
+
obj.titleContent = value;
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
metadata: _metadata
|
|
53
|
+
}, _titleContent_initializers, _titleContent_extraInitializers);
|
|
54
|
+
__esDecorate(this, null, _trigger_decorators, {
|
|
55
|
+
kind: "accessor",
|
|
56
|
+
name: "trigger",
|
|
57
|
+
static: false,
|
|
58
|
+
private: false,
|
|
59
|
+
access: {
|
|
60
|
+
has: (obj) => "trigger" in obj,
|
|
61
|
+
get: (obj) => obj.trigger,
|
|
62
|
+
set: (obj, value) => {
|
|
63
|
+
obj.trigger = value;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
metadata: _metadata
|
|
67
|
+
}, _trigger_initializers, _trigger_extraInitializers);
|
|
68
|
+
__esDecorate(this, null, _accessibilityLabel_decorators, {
|
|
69
|
+
kind: "accessor",
|
|
70
|
+
name: "accessibilityLabel",
|
|
71
|
+
static: false,
|
|
72
|
+
private: false,
|
|
73
|
+
access: {
|
|
74
|
+
has: (obj) => "accessibilityLabel" in obj,
|
|
75
|
+
get: (obj) => obj.accessibilityLabel,
|
|
76
|
+
set: (obj, value) => {
|
|
77
|
+
obj.accessibilityLabel = value;
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
metadata: _metadata
|
|
81
|
+
}, _accessibilityLabel_initializers, _accessibilityLabel_extraInitializers);
|
|
82
|
+
__esDecorate(this, null, _accessibilityBackLabel_decorators, {
|
|
83
|
+
kind: "accessor",
|
|
84
|
+
name: "accessibilityBackLabel",
|
|
85
|
+
static: false,
|
|
86
|
+
private: false,
|
|
87
|
+
access: {
|
|
88
|
+
has: (obj) => "accessibilityBackLabel" in obj,
|
|
89
|
+
get: (obj) => obj.accessibilityBackLabel,
|
|
90
|
+
set: (obj, value) => {
|
|
91
|
+
obj.accessibilityBackLabel = value;
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
metadata: _metadata
|
|
95
|
+
}, _accessibilityBackLabel_initializers, _accessibilityBackLabel_extraInitializers);
|
|
96
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
97
|
+
enumerable: true,
|
|
98
|
+
configurable: true,
|
|
99
|
+
writable: true,
|
|
100
|
+
value: _metadata
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
static {
|
|
104
|
+
this.elementName = "sbb-navigation-section";
|
|
105
|
+
}
|
|
106
|
+
static {
|
|
107
|
+
this.elementDependencies = [SbbTransparentButtonElement];
|
|
108
|
+
}
|
|
109
|
+
static {
|
|
110
|
+
this.styles = [
|
|
111
|
+
boxSizingStyles,
|
|
112
|
+
scrollbarStyles,
|
|
113
|
+
unsafeCSS(navigation_section_default)
|
|
114
|
+
];
|
|
115
|
+
}
|
|
116
|
+
#titleContent_accessor_storage;
|
|
117
|
+
/**
|
|
118
|
+
* The label to be shown before the action list.
|
|
119
|
+
*/
|
|
120
|
+
get titleContent() {
|
|
121
|
+
return this.#titleContent_accessor_storage;
|
|
122
|
+
}
|
|
123
|
+
set titleContent(value) {
|
|
124
|
+
this.#titleContent_accessor_storage = value;
|
|
125
|
+
}
|
|
126
|
+
#trigger_accessor_storage;
|
|
127
|
+
/**
|
|
128
|
+
* The element that will trigger the navigation section.
|
|
129
|
+
*
|
|
130
|
+
* For attribute usage, provide an id reference.
|
|
131
|
+
*/
|
|
132
|
+
get trigger() {
|
|
133
|
+
return this.#trigger_accessor_storage;
|
|
134
|
+
}
|
|
135
|
+
set trigger(value) {
|
|
136
|
+
this.#trigger_accessor_storage = value;
|
|
137
|
+
}
|
|
138
|
+
#accessibilityLabel_accessor_storage;
|
|
139
|
+
/**
|
|
140
|
+
* This will be forwarded as aria-label to the nav element and is read as a title of the navigation-section.
|
|
141
|
+
*/
|
|
142
|
+
get accessibilityLabel() {
|
|
143
|
+
return this.#accessibilityLabel_accessor_storage;
|
|
144
|
+
}
|
|
145
|
+
set accessibilityLabel(value) {
|
|
146
|
+
this.#accessibilityLabel_accessor_storage = value;
|
|
147
|
+
}
|
|
148
|
+
#accessibilityBackLabel_accessor_storage;
|
|
149
|
+
/**
|
|
150
|
+
* This will be forwarded as aria-label to the back button element.
|
|
151
|
+
*/
|
|
152
|
+
get accessibilityBackLabel() {
|
|
153
|
+
return this.#accessibilityBackLabel_accessor_storage;
|
|
154
|
+
}
|
|
155
|
+
set accessibilityBackLabel(value) {
|
|
156
|
+
this.#accessibilityBackLabel_accessor_storage = value;
|
|
157
|
+
}
|
|
158
|
+
/** The state of the component. */
|
|
159
|
+
set state(state) {
|
|
160
|
+
super.state = state;
|
|
161
|
+
this.internals.ariaHidden = this.state !== "opened" ? "true" : null;
|
|
162
|
+
}
|
|
163
|
+
get state() {
|
|
164
|
+
return super.state;
|
|
165
|
+
}
|
|
166
|
+
constructor() {
|
|
167
|
+
super();
|
|
168
|
+
this.#titleContent_accessor_storage = __runInitializers(this, _titleContent_initializers, "");
|
|
169
|
+
this.#trigger_accessor_storage = (__runInitializers(this, _titleContent_extraInitializers), __runInitializers(this, _trigger_initializers, null));
|
|
170
|
+
this.#accessibilityLabel_accessor_storage = (__runInitializers(this, _trigger_extraInitializers), __runInitializers(this, _accessibilityLabel_initializers, ""));
|
|
171
|
+
this.#accessibilityBackLabel_accessor_storage = (__runInitializers(this, _accessibilityLabel_extraInitializers), __runInitializers(this, _accessibilityBackLabel_initializers, ""));
|
|
172
|
+
this._firstLevelNavigation = (__runInitializers(this, _accessibilityBackLabel_extraInitializers), null);
|
|
173
|
+
this._triggerElement = null;
|
|
174
|
+
this._language = new SbbLanguageController(this);
|
|
175
|
+
this._focusTrapController = new SbbFocusTrapController(this);
|
|
176
|
+
this._lastKeydownEvent = null;
|
|
177
|
+
this._mediaMatcherController = new SbbMediaMatcherController(this, { [SbbMediaQueryBreakpointSmallAndBelow]: (matches) => {
|
|
178
|
+
if (this.state !== "closed") this._setNavigationInert(matches);
|
|
179
|
+
} });
|
|
180
|
+
this._handleNavigationSectionClose = (event) => {
|
|
181
|
+
if (event.composedPath().filter((el) => el instanceof HTMLElement).some((el) => this._isCloseElement(el))) this.close();
|
|
182
|
+
};
|
|
183
|
+
this.addEventListener?.("keydown", (e) => {
|
|
184
|
+
this._lastKeydownEvent = e;
|
|
185
|
+
});
|
|
186
|
+
this.addEventListener?.("focusout", (e) => {
|
|
187
|
+
if (e.relatedTarget instanceof HTMLElement && !this.contains(e.relatedTarget) && sbbInputModalityDetector.mostRecentModality === "keyboard" && this._lastKeydownEvent?.key === "Tab" && this._triggerElement) {
|
|
188
|
+
const navigationElement = this.closest("sbb-navigation");
|
|
189
|
+
const focusableElements = Array.from(navigationElement?.querySelectorAll(IS_FOCUSABLE_QUERY) ?? []).filter((e) => !this.contains(e));
|
|
190
|
+
if (this._lastKeydownEvent.shiftKey || !focusableElements.length) this._triggerElement?.focus();
|
|
191
|
+
else (focusableElements[focusableElements.indexOf(this._triggerElement) + 1] ?? navigationElement.closeButton)?.focus();
|
|
192
|
+
}
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Opens the navigation section on trigger click.
|
|
197
|
+
*/
|
|
198
|
+
open() {
|
|
199
|
+
if (this.state !== "closed" || !this.hasUpdated || !this.dispatchBeforeOpenEvent()) return;
|
|
200
|
+
if (this._isNavigationButton(this._triggerElement)) this._triggerElement?.marker?.select(this._triggerElement);
|
|
201
|
+
this._closePreviousNavigationSection();
|
|
202
|
+
this.state = "opening";
|
|
203
|
+
/** @internal */
|
|
204
|
+
this.dispatchEvent(new Event("ɵnavigationsectionopening"));
|
|
205
|
+
this.startUpdate();
|
|
206
|
+
this.inert = true;
|
|
207
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "true";
|
|
208
|
+
if (this._isZeroAnimationDuration()) this._handleOpening();
|
|
209
|
+
}
|
|
210
|
+
_isZeroAnimationDuration() {
|
|
211
|
+
return isZeroAnimationDuration(this, "--sbb-navigation-section-animation-duration");
|
|
212
|
+
}
|
|
213
|
+
_handleOpening() {
|
|
214
|
+
this.state = "opened";
|
|
215
|
+
this.inert = false;
|
|
216
|
+
this._attachWindowEvents();
|
|
217
|
+
this._setNavigationInert();
|
|
218
|
+
this._focusTrapController.focusInitialElement();
|
|
219
|
+
this._checkActiveAction();
|
|
220
|
+
this.completeUpdate();
|
|
221
|
+
this.dispatchOpenEvent();
|
|
222
|
+
}
|
|
223
|
+
_handleClosing() {
|
|
224
|
+
this.state = "closed";
|
|
225
|
+
this.shadowRoot?.querySelector(".sbb-navigation-section__container")?.scrollTo(0, 0);
|
|
226
|
+
this._windowEventsController?.abort();
|
|
227
|
+
this._resetLists();
|
|
228
|
+
this._setNavigationInert();
|
|
229
|
+
if (this._isBelowLarge() && this._triggerElement) this._triggerElement.focus();
|
|
230
|
+
this.completeUpdate();
|
|
231
|
+
this.dispatchCloseEvent();
|
|
232
|
+
}
|
|
233
|
+
_closePreviousNavigationSection() {
|
|
234
|
+
this._firstLevelNavigation?.activeNavigationSection?.close();
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Closes the navigation section.
|
|
238
|
+
*/
|
|
239
|
+
close() {
|
|
240
|
+
if (this.state !== "opened" || !this.dispatchBeforeCloseEvent()) return;
|
|
241
|
+
/** @internal */
|
|
242
|
+
this.dispatchEvent(new Event("ɵnavigationsectionclosing"));
|
|
243
|
+
this.state = "closing";
|
|
244
|
+
this.startUpdate();
|
|
245
|
+
this.inert = true;
|
|
246
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "false";
|
|
247
|
+
if (this._isZeroAnimationDuration()) this._handleClosing();
|
|
248
|
+
}
|
|
249
|
+
_configureTrigger() {
|
|
250
|
+
if (this.trigger === this._triggerElement) return;
|
|
251
|
+
this._triggerAbortController?.abort();
|
|
252
|
+
removeAriaOverlayTriggerProperties(this._triggerElement);
|
|
253
|
+
this._triggerElement = this.trigger;
|
|
254
|
+
if (!this._triggerElement) return;
|
|
255
|
+
setAriaOverlayTriggerProperties(this, this._triggerElement, "menu", this.state);
|
|
256
|
+
this._triggerAbortController = new AbortController();
|
|
257
|
+
if (this._isNavigationButton(this._triggerElement)) this._triggerElement.connectedSection = this;
|
|
258
|
+
this._triggerElement.addEventListener("click", () => this.open(), { signal: this._triggerAbortController.signal });
|
|
259
|
+
this._firstLevelNavigation = this._triggerElement?.closest?.("sbb-navigation");
|
|
260
|
+
}
|
|
261
|
+
_isNavigationButton(trigger) {
|
|
262
|
+
return trigger?.localName === "sbb-navigation-button";
|
|
263
|
+
}
|
|
264
|
+
_setNavigationInert(isBelowLarge = this._isBelowLarge()) {
|
|
265
|
+
const navigationContent = this._firstLevelNavigation?.navigationContent;
|
|
266
|
+
if (navigationContent) navigationContent.inert = isBelowLarge && this.state !== "closed";
|
|
267
|
+
}
|
|
268
|
+
_onAnimationEnd(event) {
|
|
269
|
+
if (event.animationName === "open" && this.state === "opening") this._handleOpening();
|
|
270
|
+
else if (event.animationName === "close" && this.state === "closing") this._handleClosing();
|
|
271
|
+
}
|
|
272
|
+
_resetLists() {
|
|
273
|
+
Array.from(this.querySelectorAll(":is(:state(section-action),[state--section-action]):is(:state(action-active),[state--action-active])") ?? []).forEach((action) => ɵstateController(action).delete("action-active"));
|
|
274
|
+
}
|
|
275
|
+
_attachWindowEvents() {
|
|
276
|
+
this._windowEventsController = new AbortController();
|
|
277
|
+
window.addEventListener("keydown", (event) => this._onKeydownEvent(event), { signal: this._windowEventsController.signal });
|
|
278
|
+
window.addEventListener("click", this._handleNavigationSectionClose, { signal: this._windowEventsController.signal });
|
|
279
|
+
}
|
|
280
|
+
_isCloseElement(element) {
|
|
281
|
+
return element.nodeName === "A" || !element.hasAttribute("disabled") && (element.hasAttribute("sbb-navigation-close") || element.hasAttribute("sbb-navigation-section-close"));
|
|
282
|
+
}
|
|
283
|
+
_isBelowLarge() {
|
|
284
|
+
return this._mediaMatcherController.matches(SbbMediaQueryBreakpointSmallAndBelow) ?? false;
|
|
285
|
+
}
|
|
286
|
+
_onKeydownEvent(event) {
|
|
287
|
+
if (this.state === "opened" && event.key === "Escape") this.close();
|
|
288
|
+
}
|
|
289
|
+
_checkActiveAction() {
|
|
290
|
+
ɵstateController(this.querySelector(":is(sbb-navigation-button, sbb-navigation-link).sbb-active"))?.toggle("action-active", true);
|
|
291
|
+
}
|
|
292
|
+
connectedCallback() {
|
|
293
|
+
super.connectedCallback();
|
|
294
|
+
this.slot ||= "navigation-section";
|
|
295
|
+
if (this.hasUpdated) this._configureTrigger();
|
|
296
|
+
}
|
|
297
|
+
disconnectedCallback() {
|
|
298
|
+
super.disconnectedCallback();
|
|
299
|
+
this._triggerElement = null;
|
|
300
|
+
this._triggerAbortController?.abort();
|
|
301
|
+
this._windowEventsController?.abort();
|
|
302
|
+
}
|
|
303
|
+
requestUpdate(name, oldValue, options) {
|
|
304
|
+
super.requestUpdate(name, oldValue, options);
|
|
305
|
+
if (!isServer && (!name || name === "trigger") && this.hasUpdated) this._configureTrigger();
|
|
306
|
+
}
|
|
307
|
+
firstUpdated(changedProperties) {
|
|
308
|
+
super.firstUpdated(changedProperties);
|
|
309
|
+
this._configureTrigger();
|
|
310
|
+
}
|
|
311
|
+
render() {
|
|
312
|
+
return html`
|
|
313
|
+
<div class="sbb-navigation-section__container">
|
|
314
|
+
<nav
|
|
315
|
+
@animationend=${this._onAnimationEnd}
|
|
316
|
+
class="sbb-navigation-section"
|
|
317
|
+
aria-labelledby=${!this.accessibilityLabel ? "title" : nothing}
|
|
318
|
+
aria-label=${this.accessibilityLabel ? this.accessibilityLabel : nothing}
|
|
319
|
+
>
|
|
320
|
+
<div class="sbb-navigation-section__wrapper sbb-scrollbar-negative">
|
|
321
|
+
<div class="sbb-navigation-section__content">
|
|
322
|
+
<div class="sbb-navigation-section__header">
|
|
323
|
+
<!-- Back button -->
|
|
324
|
+
<sbb-transparent-button
|
|
325
|
+
id="sbb-navigation-section-back-button"
|
|
326
|
+
class="sbb-navigation-section__back"
|
|
327
|
+
aria-label=${this.accessibilityBackLabel || i18nGoBack[this._language.current]}
|
|
328
|
+
negative
|
|
329
|
+
size="m"
|
|
330
|
+
icon-name="chevron-small-left-small"
|
|
331
|
+
sbb-navigation-section-close
|
|
332
|
+
></sbb-transparent-button>
|
|
333
|
+
|
|
334
|
+
<span class="sbb-navigation-section__title" id="title">
|
|
335
|
+
<slot name="title">${this.titleContent}</slot>
|
|
336
|
+
</span>
|
|
337
|
+
</div>
|
|
338
|
+
<slot></slot>
|
|
339
|
+
</div>
|
|
340
|
+
</div>
|
|
341
|
+
</nav>
|
|
342
|
+
</div>
|
|
343
|
+
`;
|
|
344
|
+
}
|
|
345
|
+
};
|
|
346
|
+
})();
|
|
347
|
+
//#endregion
|
|
348
|
+
export { SbbNavigationSectionElement as t };
|
|
349
|
+
|
|
350
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"navigation-section.component-D3_XVwyt.js","names":[],"sources":["../../../src/elements/navigation/navigation-section/navigation-section.scss?inline","../../../src/elements/navigation/navigation-section/navigation-section.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-navigation-section-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-3x)\n  );\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n\n  // We have to place the styles on the host as it has to be aligned on the grid of the navigation\n  display: var(--sbb-navigation-section-display, none);\n  position: var(--sbb-navigation-section-position);\n  grid-column: var(--sbb-navigation-section-column);\n  inset-inline-start: 0;\n  inset-block-start: 0;\n  width: var(--sbb-navigation-section-width);\n  height: var(--sbb-navigation-section-height);\n  z-index: var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));\n\n  @include sbb.mq($from: large) {\n    --sbb-navigation-section-animation-duration: var(\n      --sbb-disable-animation-duration,\n      var(--sbb-animation-duration-4x)\n    );\n    --sbb-navigation-section-width: calc(\n      100% + var(--sbb-layout-base-offset-responsive) + var(--sbb-grid-base-gutter-responsive)\n    );\n\n    translate: calc(var(--sbb-grid-base-gutter-responsive) * -1) 0;\n  }\n}\n\n:host(:state(state-opened)) {\n  --sbb-navigation-section-pointer-events: all;\n}\n\n:host(:state(state-opening)) {\n  --sbb-navigation-section-position: absolute;\n}\n\n:host(:is(:state(state-opening), :state(state-closing))) {\n  --sbb-navigation-section-pointer-events: none;\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  --sbb-navigation-section-display: block;\n}\n\n::slotted(*) {\n  padding-inline-start: var(--sbb-navigation-section-content-padding-inline-start);\n}\n\n// Always place the sbb-button on a new row\n::slotted(:state(sbb-button)) {\n  grid-column-start: 1;\n}\n\n.sbb-navigation-section__container {\n  pointer-events: var(--sbb-navigation-section-pointer-events);\n  height: var(--sbb-navigation-section-height);\n}\n\n.sbb-navigation-section {\n  display: none;\n  border: none;\n  margin: 0;\n  width: 100%;\n  height: 100%;\n  color: var(--sbb-navigation-color, var(--sbb-color-1-negative));\n  background-color: transparent;\n  padding: 0;\n  overflow: hidden;\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-navigation-section-animation-duration);\n      timing-function: var(--sbb-navigation-section-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    animation-name: close;\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n}\n\n.sbb-navigation-section__wrapper {\n  height: 100%;\n  padding-block: var(--sbb-navigation-section-padding-block);\n  outline: none;\n  overflow-y: auto;\n\n  :host(:is(:state(state-opening), :state(state-closing))) & {\n    --sbb-scrollbar-color: transparent;\n\n    scrollbar-color: transparent transparent;\n  }\n}\n\n.sbb-navigation-section__header {\n  position: relative;\n  display: flex;\n  align-items: center;\n  gap: var(--sbb-spacing-fixed-1x);\n  margin-block-start: var(--sbb-spacing-responsive-xxl);\n  padding-inline-start: var(--sbb-navigation-section-content-padding-inline-start);\n\n  @include sbb.mq($from: large) {\n    margin-block-start: 0;\n    padding-inline-start: 0;\n  }\n\n  @include sbb.mq($from: ultra) {\n    grid-column: 1 / 4;\n  }\n}\n\n.sbb-navigation-section__back {\n  position: absolute;\n  translate: calc((100% + var(--sbb-spacing-fixed-1x)) * -1) 0;\n\n  @include sbb.mq($from: large) {\n    display: none;\n  }\n}\n\n.sbb-navigation-section__title {\n  font-weight: bold;\n  font-size: var(--sbb-navigation-section-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-heading);\n  line-height: var(--sbb-typo-line-height-heading);\n}\n\n.sbb-navigation-section__content {\n  display: grid;\n  grid-template-columns: 1fr;\n  gap: var(--sbb-spacing-responsive-l) var(--sbb-grid-base-gutter-responsive);\n  padding-inline: var(--sbb-navigation-section-padding-inline);\n\n  @include sbb.mq($from: large) {\n    opacity: 0;\n    translate: 0 var(--sbb-spacing-fixed-3x);\n    transition: {\n      duration: var(--sbb-navigation-section-animation-duration);\n      delay: var(--sbb-navigation-section-animation-duration);\n      timing-function: var(--sbb-navigation-section-animation-easing);\n      property: opacity, translate;\n    }\n\n    :host(:state(state-opened)) & {\n      opacity: 1;\n      translate: 0 0;\n    }\n  }\n\n  @include sbb.mq($from: ultra) {\n    grid-template-columns: repeat(3, 1fr);\n  }\n\n  :host(:state(state-closing)) & {\n    transition-delay: 0s;\n  }\n}\n\n@keyframes open {\n  from {\n    translate: var(--sbb-navigation-section-translate) 0;\n  }\n\n  to {\n    translate: 0 0;\n  }\n}\n\n@keyframes close {\n  from {\n    translate: 0 0;\n  }\n\n  to {\n    translate: var(--sbb-navigation-section-translate) 0;\n  }\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbTransparentButtonElement } from '../../button.pure.ts';\nimport {\n  boxSizingStyles,\n  forceType,\n  i18nGoBack,\n  idReference,\n  IS_FOCUSABLE_QUERY,\n  isZeroAnimationDuration,\n  omitEmptyConverter,\n  removeAriaOverlayTriggerProperties,\n  type SbbElementType,\n  SbbFocusTrapController,\n  sbbInputModalityDetector,\n  SbbLanguageController,\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointSmallAndBelow,\n  SbbOpenCloseBaseElement,\n  type SbbOpenedClosedState,\n  SbbUpdateSchedulerMixin,\n  scrollbarStyles,\n  setAriaOverlayTriggerProperties,\n  ɵstateController,\n} from '../../core.ts';\nimport type { SbbNavigationElement } from '../navigation/navigation.component.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-section.scss?inline';\n\n/**\n * It can be used as a container for `sbb-navigation-list` within a `sbb-navigation`.\n *\n * @slot - Use the unnamed slot to add content into the `sbb-navigation-section`.\n */\nexport class SbbNavigationSectionElement extends SbbUpdateSchedulerMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-navigation-section';\n  public static override elementDependencies: SbbElementType[] = [SbbTransparentButtonElement];\n  public static override styles: CSSResultGroup = [\n    boxSizingStyles,\n    scrollbarStyles,\n    unsafeCSS(style),\n  ];\n\n  /**\n   * The label to be shown before the action list.\n   */\n  @forceType()\n  @property({ attribute: 'title-content', reflect: true, converter: omitEmptyConverter })\n  public accessor titleContent: string = '';\n\n  /**\n   * The element that will trigger the navigation section.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /**\n   * This will be forwarded as aria-label to the nav element and is read as a title of the navigation-section.\n   */\n  @forceType()\n  @property({ attribute: 'accessibility-label' })\n  public accessor accessibilityLabel: string = '';\n\n  /**\n   * This will be forwarded as aria-label to the back button element.\n   */\n  @forceType()\n  @property({ attribute: 'accessibility-back-label' })\n  public accessor accessibilityBackLabel: string = '';\n\n  /** The state of the component. */\n  protected override set state(state: SbbOpenedClosedState) {\n    super.state = state;\n    this.internals.ariaHidden = this.state !== 'opened' ? 'true' : null;\n  }\n  protected override get state(): SbbOpenedClosedState {\n    return super.state;\n  }\n\n  private _firstLevelNavigation?: SbbNavigationElement | null = null;\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController!: AbortController;\n  private _windowEventsController!: AbortController;\n  private _language = new SbbLanguageController(this);\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _lastKeydownEvent: KeyboardEvent | null = null;\n  private _mediaMatcherController = new SbbMediaMatcherController(this, {\n    [SbbMediaQueryBreakpointSmallAndBelow]: (matches) => {\n      if (this.state !== 'closed') {\n        this._setNavigationInert(matches);\n      }\n    },\n  });\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.('keydown', (e) => {\n      this._lastKeydownEvent = e;\n    });\n\n    this.addEventListener?.('focusout', (e) => {\n      if (\n        e.relatedTarget instanceof HTMLElement &&\n        !this.contains(e.relatedTarget) &&\n        sbbInputModalityDetector.mostRecentModality === 'keyboard' &&\n        this._lastKeydownEvent?.key === 'Tab' &&\n        this._triggerElement\n      ) {\n        const navigationElement = this.closest<SbbNavigationElement>('sbb-navigation');\n        const focusableElements = Array.from(\n          navigationElement?.querySelectorAll<HTMLElement>(IS_FOCUSABLE_QUERY) ?? [],\n        ).filter((e) => !this.contains(e));\n\n        if (this._lastKeydownEvent.shiftKey || !focusableElements.length) {\n          this._triggerElement?.focus();\n        } else {\n          const triggerIndex = focusableElements.indexOf(this._triggerElement);\n          (focusableElements[triggerIndex + 1] ?? navigationElement!.closeButton)?.focus();\n        }\n      }\n    });\n  }\n\n  /**\n   * Opens the navigation section on trigger click.\n   */\n  public open(): void {\n    if (this.state !== 'closed' || !this.hasUpdated || !this.dispatchBeforeOpenEvent()) {\n      return;\n    }\n\n    if (this._isNavigationButton(this._triggerElement)) {\n      this._triggerElement?.marker?.select(this._triggerElement);\n    }\n\n    this._closePreviousNavigationSection();\n    this.state = 'opening';\n    /** @internal */\n    this.dispatchEvent(new Event('ɵnavigationsectionopening'));\n    this.startUpdate();\n    this.inert = true;\n    if (this._triggerElement) {\n      this._triggerElement.ariaExpanded = 'true';\n    }\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-navigation-section-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this.inert = false;\n    this._attachWindowEvents();\n    this._setNavigationInert();\n    this._focusTrapController.focusInitialElement();\n    this._checkActiveAction();\n    this.completeUpdate();\n    this.dispatchOpenEvent();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.shadowRoot?.querySelector('.sbb-navigation-section__container')?.scrollTo(0, 0);\n    this._windowEventsController?.abort();\n    this._resetLists();\n    this._setNavigationInert();\n    if (this._isBelowLarge() && this._triggerElement) {\n      this._triggerElement.focus();\n    }\n    this.completeUpdate();\n    this.dispatchCloseEvent();\n  }\n\n  private _closePreviousNavigationSection(): void {\n    this._firstLevelNavigation?.activeNavigationSection?.close();\n  }\n\n  /**\n   * Closes the navigation section.\n   */\n  public close(): void {\n    if (this.state !== 'opened' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    /** @internal */\n    this.dispatchEvent(new Event('ɵnavigationsectionclosing'));\n    this.state = 'closing';\n    this.startUpdate();\n    this.inert = true;\n    if (this._triggerElement) {\n      this._triggerElement.ariaExpanded = 'false';\n    }\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  // Check if the trigger is valid and attach click event listeners.\n  private _configureTrigger(): void {\n    if (this.trigger === this._triggerElement) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    removeAriaOverlayTriggerProperties(this._triggerElement);\n    this._triggerElement = this.trigger;\n\n    if (!this._triggerElement) {\n      return;\n    }\n\n    setAriaOverlayTriggerProperties(this, this._triggerElement, 'menu', this.state);\n    this._triggerAbortController = new AbortController();\n    if (this._isNavigationButton(this._triggerElement)) {\n      this._triggerElement.connectedSection = this;\n    }\n    this._triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\n    });\n    this._firstLevelNavigation = this._triggerElement?.closest?.('sbb-navigation');\n  }\n\n  private _isNavigationButton(trigger: HTMLElement | null): trigger is SbbNavigationButtonElement {\n    return trigger?.localName === 'sbb-navigation-button';\n  }\n\n  private _setNavigationInert(isBelowLarge: boolean = this._isBelowLarge()): void {\n    const navigationContent = this._firstLevelNavigation?.navigationContent;\n    if (navigationContent) {\n      navigationContent.inert = isBelowLarge && this.state !== 'closed';\n    }\n  }\n\n  // In rare cases it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _resetLists(): void {\n    Array.from(\n      this.querySelectorAll<SbbNavigationButtonElement | SbbNavigationLinkElement>(\n        ':state(section-action):state(action-active)',\n      ) ?? [],\n    ).forEach((action) => ɵstateController(action).delete('action-active'));\n  }\n\n  private _attachWindowEvents(): void {\n    this._windowEventsController = new AbortController();\n    window.addEventListener('keydown', (event: KeyboardEvent) => this._onKeydownEvent(event), {\n      signal: this._windowEventsController.signal,\n    });\n\n    // Close navigation section on action click or sbb-navigation-section-close click\n    window.addEventListener('click', this._handleNavigationSectionClose, {\n      signal: this._windowEventsController.signal,\n    });\n  }\n\n  // Check if the click was triggered on an element that should close the section.\n  private _handleNavigationSectionClose = (event: Event): void => {\n    if (\n      event\n        .composedPath()\n        .filter((el) => el instanceof HTMLElement)\n        .some((el) => this._isCloseElement(el))\n    ) {\n      this.close();\n    }\n  };\n\n  private _isCloseElement(element: HTMLElement): boolean {\n    return (\n      element.nodeName === 'A' ||\n      (!element.hasAttribute('disabled') &&\n        (element.hasAttribute('sbb-navigation-close') ||\n          element.hasAttribute('sbb-navigation-section-close')))\n    );\n  }\n\n  private _isBelowLarge(): boolean {\n    return this._mediaMatcherController.matches(SbbMediaQueryBreakpointSmallAndBelow) ?? false;\n  }\n\n  // Closes the navigation on \"Esc\" key pressed.\n  private _onKeydownEvent(event: KeyboardEvent): void {\n    if (this.state === 'opened' && event.key === 'Escape') {\n      this.close();\n    }\n  }\n\n  private _checkActiveAction(): void {\n    const element = this.querySelector<SbbNavigationButtonElement | SbbNavigationLinkElement>(\n      ':is(sbb-navigation-button, sbb-navigation-link).sbb-active',\n    );\n    ɵstateController(element)?.toggle('action-active', true);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot ||= 'navigation-section';\n    if (this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n    this._windowEventsController?.abort();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    if (!isServer && (!name || name === 'trigger') && this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._configureTrigger();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-navigation-section__container\">\n        <nav\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-navigation-section\"\n          aria-labelledby=${!this.accessibilityLabel ? 'title' : nothing}\n          aria-label=${this.accessibilityLabel ? this.accessibilityLabel : nothing}\n        >\n          <div class=\"sbb-navigation-section__wrapper sbb-scrollbar-negative\">\n            <div class=\"sbb-navigation-section__content\">\n              <div class=\"sbb-navigation-section__header\">\n                <!-- Back button -->\n                <sbb-transparent-button\n                  id=\"sbb-navigation-section-back-button\"\n                  class=\"sbb-navigation-section__back\"\n                  aria-label=${this.accessibilityBackLabel || i18nGoBack[this._language.current]}\n                  negative\n                  size=\"m\"\n                  icon-name=\"chevron-small-left-small\"\n                  sbb-navigation-section-close\n                ></sbb-transparent-button>\n\n                <span class=\"sbb-navigation-section__title\" id=\"title\">\n                  <slot name=\"title\">${this.titleContent}</slot>\n                </span>\n              </div>\n              <slot></slot>\n            </div>\n          </div>\n        </nav>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-navigation-section': SbbNavigationSectionElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;IC8Ca,qCAA2B;mBAAS,wBAAwB,wBAAwB;;;;;;;;;;;;;cAApF,oCAAoC,YAAgD;;;+BAY9F,WAAW,EACX,SAAS;IAAE,WAAW;IAAiB,SAAS;IAAM,WAAW;IAAoB,CAAC,CAAA;0BAQtF,aAAa,EACb,UAAU,CAAA;qCAMV,WAAW,EACX,SAAS,EAAE,WAAW,uBAAuB,CAAC,CAAA;yCAM9C,WAAW,EACX,SAAS,EAAE,WAAW,4BAA4B,CAAC,CAAA;AAtBpD,gBAAA,MAAA,MAAA,0BAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,kBAAA;KAAA,MAAA,QAAA,IAAgB;KAAY,MAAA,KAAA,UAAA;AAAA,UAAZ,eAAY;;KAAA;IAAA,UAAA;IAAA,EAAA,4BAAA,gCAAA;AAS5B,gBAAA,MAAA,MAAA,qBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,aAAA;KAAA,MAAA,QAAA,IAAgB;KAAO,MAAA,KAAA,UAAA;AAAA,UAAP,UAAO;;KAAA;IAAA,UAAA;IAAA,EAAA,uBAAA,2BAAA;AAOvB,gBAAA,MAAA,MAAA,gCAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,wBAAA;KAAA,MAAA,QAAA,IAAgB;KAAkB,MAAA,KAAA,UAAA;AAAA,UAAlB,qBAAkB;;KAAA;IAAA,UAAA;IAAA,EAAA,kCAAA,sCAAA;AAOlC,gBAAA,MAAA,MAAA,oCAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,4BAAA;KAAA,MAAA,QAAA,IAAgB;KAAsB,MAAA,KAAA,UAAA;AAAA,UAAtB,yBAAsB;;KAAA;IAAA,UAAA;IAAA,EAAA,sCAAA,0CAAA;;;;;;;;;AApCN,QAAA,cAAsB;;;AAC/B,QAAA,sBAAwC,CAAC,4BAA4B;;;AACrE,QAAA,SAAyB;IAC9C;IACA;IACA,UAAU,2BAAA;IACX;;EAOD;;;;EAAA,IAAgB,eAAY;AAAA,UAAA,MAAA;;EAA5B,IAAgB,aAAY,OAAA;AAAA,SAAA,gCAAA;;EAS5B;;;;;;EAAA,IAAgB,UAAO;AAAA,UAAA,MAAA;;EAAvB,IAAgB,QAAO,OAAA;AAAA,SAAA,2BAAA;;EAOvB;;;;EAAA,IAAgB,qBAAkB;AAAA,UAAA,MAAA;;EAAlC,IAAgB,mBAAkB,OAAA;AAAA,SAAA,sCAAA;;EAOlC;;;;EAAA,IAAgB,yBAAsB;AAAA,UAAA,MAAA;;EAAtC,IAAgB,uBAAsB,OAAA;AAAA,SAAA,0CAAA;;;EAGtC,IAAuB,MAAM,OAA2B;AACtD,SAAM,QAAQ;AACd,QAAK,UAAU,aAAa,KAAK,UAAU,WAAW,SAAS;;EAEjE,IAAuB,QAAK;AAC1B,UAAO,MAAM;;EAkBf,cAAA;AACE,UAAO;AAlDO,SAAA,gCAAA,kBAAA,MAAA,4BAAuB,GAAE;AASzB,SAAA,4BAAA,kBAAA,MAAA,gCAAA,EAAA,kBAAA,MAAA,uBAA8B,KAAI;AAOlC,SAAA,uCAAA,kBAAA,MAAA,2BAAA,EAAA,kBAAA,MAAA,kCAA6B,GAAE;AAO/B,SAAA,2CAAA,kBAAA,MAAA,sCAAA,EAAA,kBAAA,MAAA,sCAAiC,GAAE;AAW3C,QAAA,yBAAqB,kBAAA,MAAA,0CAAA,EAAiC;AACtD,QAAA,kBAAsC;AAGtC,QAAA,YAAY,IAAI,sBAAsB,KAAK;AAC3C,QAAA,uBAAuB,IAAI,uBAAuB,KAAK;AACvD,QAAA,oBAA0C;AAC1C,QAAA,0BAA0B,IAAI,0BAA0B,MAAM,GACnE,wCAAwC,YAAW;AAClD,QAAI,KAAK,UAAU,SACjB,MAAK,oBAAoB,QAAQ;MAGtC,CAAC;AAwLM,QAAA,iCAAiC,UAAsB;AAC7D,QACE,MACG,cAAc,CACd,QAAQ,OAAO,cAAc,YAAY,CACzC,MAAM,OAAO,KAAK,gBAAgB,GAAG,CAAC,CAEzC,MAAK,OAAO;;AA1Ld,QAAK,mBAAmB,YAAY,MAAK;AACvC,SAAK,oBAAoB;KACzB;AAEF,QAAK,mBAAmB,aAAa,MAAK;AACxC,QACE,EAAE,yBAAyB,eAC3B,CAAC,KAAK,SAAS,EAAE,cAAc,IAC/B,yBAAyB,uBAAuB,cAChD,KAAK,mBAAmB,QAAQ,SAChC,KAAK,iBACL;KACA,MAAM,oBAAoB,KAAK,QAA8B,iBAAiB;KAC9E,MAAM,oBAAoB,MAAM,KAC9B,mBAAmB,iBAA8B,mBAAmB,IAAI,EAAE,CAC3E,CAAC,QAAQ,MAAM,CAAC,KAAK,SAAS,EAAE,CAAC;AAElC,SAAI,KAAK,kBAAkB,YAAY,CAAC,kBAAkB,OACxD,MAAK,iBAAiB,OAAO;SAG7B,EAAC,kBADoB,kBAAkB,QAAQ,KAAK,gBACjC,GAAe,MAAM,kBAAmB,cAAc,OAAO;;KAGpF;;;;;EAMG,OAAI;AACT,OAAI,KAAK,UAAU,YAAY,CAAC,KAAK,cAAc,CAAC,KAAK,yBAAyB,CAChF;AAGF,OAAI,KAAK,oBAAoB,KAAK,gBAAgB,CAChD,MAAK,iBAAiB,QAAQ,OAAO,KAAK,gBAAgB;AAG5D,QAAK,iCAAiC;AACtC,QAAK,QAAQ;;AAEb,QAAK,cAAc,IAAI,MAAM,4BAA4B,CAAC;AAC1D,QAAK,aAAa;AAClB,QAAK,QAAQ;AACb,OAAI,KAAK,gBACP,MAAK,gBAAgB,eAAe;AAKtC,OAAI,KAAK,0BAA0B,CACjC,MAAK,gBAAgB;;EAIjB,2BAAwB;AAC9B,UAAO,wBAAwB,MAAM,8CAA8C;;EAG7E,iBAAc;AACpB,QAAK,QAAQ;AACb,QAAK,QAAQ;AACb,QAAK,qBAAqB;AAC1B,QAAK,qBAAqB;AAC1B,QAAK,qBAAqB,qBAAqB;AAC/C,QAAK,oBAAoB;AACzB,QAAK,gBAAgB;AACrB,QAAK,mBAAmB;;EAGlB,iBAAc;AACpB,QAAK,QAAQ;AACb,QAAK,YAAY,cAAc,qCAAqC,EAAE,SAAS,GAAG,EAAE;AACpF,QAAK,yBAAyB,OAAO;AACrC,QAAK,aAAa;AAClB,QAAK,qBAAqB;AAC1B,OAAI,KAAK,eAAe,IAAI,KAAK,gBAC/B,MAAK,gBAAgB,OAAO;AAE9B,QAAK,gBAAgB;AACrB,QAAK,oBAAoB;;EAGnB,kCAA+B;AACrC,QAAK,uBAAuB,yBAAyB,OAAO;;;;;EAMvD,QAAK;AACV,OAAI,KAAK,UAAU,YAAY,CAAC,KAAK,0BAA0B,CAC7D;;AAIF,QAAK,cAAc,IAAI,MAAM,4BAA4B,CAAC;AAC1D,QAAK,QAAQ;AACb,QAAK,aAAa;AAClB,QAAK,QAAQ;AACb,OAAI,KAAK,gBACP,MAAK,gBAAgB,eAAe;AAKtC,OAAI,KAAK,0BAA0B,CACjC,MAAK,gBAAgB;;EAKjB,oBAAiB;AACvB,OAAI,KAAK,YAAY,KAAK,gBACxB;AAGF,QAAK,yBAAyB,OAAO;AACrC,sCAAmC,KAAK,gBAAgB;AACxD,QAAK,kBAAkB,KAAK;AAE5B,OAAI,CAAC,KAAK,gBACR;AAGF,mCAAgC,MAAM,KAAK,iBAAiB,QAAQ,KAAK,MAAM;AAC/E,QAAK,0BAA0B,IAAI,iBAAiB;AACpD,OAAI,KAAK,oBAAoB,KAAK,gBAAgB,CAChD,MAAK,gBAAgB,mBAAmB;AAE1C,QAAK,gBAAgB,iBAAiB,eAAe,KAAK,MAAM,EAAE,EAChE,QAAQ,KAAK,wBAAwB,QACtC,CAAC;AACF,QAAK,wBAAwB,KAAK,iBAAiB,UAAU,iBAAiB;;EAGxE,oBAAoB,SAA2B;AACrD,UAAO,SAAS,cAAc;;EAGxB,oBAAoB,eAAwB,KAAK,eAAe,EAAA;GACtE,MAAM,oBAAoB,KAAK,uBAAuB;AACtD,OAAI,kBACF,mBAAkB,QAAQ,gBAAgB,KAAK,UAAU;;EAMrD,gBAAgB,OAAqB;AAC3C,OAAI,MAAM,kBAAkB,UAAU,KAAK,UAAU,UACnD,MAAK,gBAAgB;YACZ,MAAM,kBAAkB,WAAW,KAAK,UAAU,UAC3D,MAAK,gBAAgB;;EAIjB,cAAW;AACjB,SAAM,KACJ,KAAK,iBACH,uGACD,IAAI,EAAE,CACR,CAAC,SAAS,WAAW,iBAAiB,OAAO,CAAC,OAAO,gBAAgB,CAAC;;EAGjE,sBAAmB;AACzB,QAAK,0BAA0B,IAAI,iBAAiB;AACpD,UAAO,iBAAiB,YAAY,UAAyB,KAAK,gBAAgB,MAAM,EAAE,EACxF,QAAQ,KAAK,wBAAwB,QACtC,CAAC;AAGF,UAAO,iBAAiB,SAAS,KAAK,+BAA+B,EACnE,QAAQ,KAAK,wBAAwB,QACtC,CAAC;;EAeI,gBAAgB,SAAoB;AAC1C,UACE,QAAQ,aAAa,OACpB,CAAC,QAAQ,aAAa,WAAW,KAC/B,QAAQ,aAAa,uBAAuB,IAC3C,QAAQ,aAAa,+BAA+B;;EAIpD,gBAAa;AACnB,UAAO,KAAK,wBAAwB,QAAQ,qCAAqC,IAAI;;EAI/E,gBAAgB,OAAoB;AAC1C,OAAI,KAAK,UAAU,YAAY,MAAM,QAAQ,SAC3C,MAAK,OAAO;;EAIR,qBAAkB;AAIxB,oBAHgB,KAAK,cACnB,6DAEe,CAAQ,EAAE,OAAO,iBAAiB,KAAK;;EAG1C,oBAAiB;AAC/B,SAAM,mBAAmB;AACzB,QAAK,SAAS;AACd,OAAI,KAAK,WACP,MAAK,mBAAmB;;EAIZ,uBAAoB;AAClC,SAAM,sBAAsB;AAC5B,QAAK,kBAAkB;AACvB,QAAK,yBAAyB,OAAO;AACrC,QAAK,yBAAyB,OAAO;;EAGvB,cACd,MACA,UACA,SAA6B;AAE7B,SAAM,cAAc,MAAM,UAAU,QAAQ;AAE5C,OAAI,CAAC,aAAa,CAAC,QAAQ,SAAS,cAAc,KAAK,WACrD,MAAK,mBAAmB;;EAIT,aAAa,mBAAuC;AACrE,SAAM,aAAa,kBAAkB;AACrC,QAAK,mBAAmB;;EAGP,SAAM;AACvB,UAAO,IAAI;;;0BAGW,KAAK,gBAAA;;4BAEH,CAAC,KAAK,qBAAqB,UAAU,QAAA;uBAC1C,KAAK,qBAAqB,KAAK,qBAAqB,QAAA;;;;;;;;;+BAS5C,KAAK,0BAA0B,WAAW,KAAK,UAAU,SAAA;;;;;;;;uCAQjD,KAAK,aAAY"}
|