@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,319 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, unsafeCSS } from "lit";
|
|
3
|
+
import { property, state } from "lit/decorators.js";
|
|
4
|
+
import { SbbEscapableOverlayController, SbbFocusTrapController, SbbInertController, SbbLanguageController, SbbOpenCloseBaseElement, SbbScrollHandler, SbbUpdateSchedulerMixin, boxSizingStyles, forceType, i18nCloseNavigation, idReference, isEventOnElement, isZeroAnimationDuration, removeAriaOverlayTriggerProperties, scrollbarStyles, setAriaOverlayTriggerProperties } from "./core.js";
|
|
5
|
+
import { SbbTransparentButtonElement } from "./button.pure.js";
|
|
6
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
7
|
+
import { ref } from "lit/directives/ref.js";
|
|
8
|
+
//#region src/elements/navigation/navigation/navigation.scss?inline
|
|
9
|
+
var navigation_default = ":host {\n --sbb-navigation-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: none;\n position: fixed;\n inset: var(--sbb-navigation-inset);\n z-index: var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));\n overflow: hidden;\n}\n@media (min-width: calc(64rem)) {\n :host {\n --sbb-navigation-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-6x)\n );\n --sbb-navigation-width: calc(100% + var(--sbb-layout-base-offset-responsive));\n }\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 display: block;\n}\n\n:host(:is(:state(state-opened),[state--state-opened])) {\n --sbb-navigation-animation-easing: ease-out;\n}\n\n:host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-opening),[state--state-opening]))) {\n --sbb-navigation-backdrop-visibility: visible;\n --sbb-navigation-backdrop-pointer-events: all;\n}\n\n:host(:not(:is(:state(state-closed),[state--state-closed]))) {\n --sbb-navigation-inset: 0;\n --sbb-navigation-translate: none;\n}\n\n:host(:is(:state(state-closing),[state--state-closing])) {\n --sbb-navigation-backdrop-animation-name: backdrop-close;\n}\n\n:host(:is(:state(has-open-navigation-section),[state--has-open-navigation-section])) {\n --sbb-navigation-content-translate: -100% 0;\n}\n@media (min-width: calc(64rem)) {\n :host(:is(:state(has-open-navigation-section),[state--has-open-navigation-section])) {\n --sbb-navigation-expanded-width: 100dvw;\n --sbb-navigation-content-translate: 0;\n }\n}\n\n:host(:is(:state(resize-disable-animation),[state--resize-disable-animation])) {\n --sbb-disable-animation-duration: 0s;\n}\n\n.sbb-navigation__container {\n display: grid;\n gap: var(--sbb-grid-base-gutter-responsive);\n grid-template-columns: repeat(var(--sbb-grid-base-columns), 1fr);\n padding-inline: 0;\n pointer-events: none;\n translate: var(--sbb-navigation-translate);\n}\n@media (min-width: calc(64rem)) {\n .sbb-navigation__container {\n padding-inline: var(--sbb-layout-base-offset-responsive);\n }\n .sbb-navigation__container::before {\n transition-duration: var(--sbb-navigation-animation-duration);\n transition-timing-function: var(--sbb-navigation-animation-easing);\n transition-property: visibility;\n animation-name: var(--sbb-navigation-backdrop-animation-name);\n animation-duration: var(--sbb-navigation-animation-duration);\n animation-timing-function: var(--sbb-navigation-animation-easing);\n content: \"\";\n visibility: var(--sbb-navigation-backdrop-visibility, hidden);\n pointer-events: var(--sbb-navigation-backdrop-pointer-events, none);\n position: fixed;\n inset: var(--sbb-navigation-inset);\n background-color: var(--sbb-navigation-backdrop-color);\n }\n}\n\n.sbb-navigation {\n transition-duration: var(--sbb-navigation-animation-duration);\n transition-timing-function: var(--sbb-navigation-animation-easing);\n transition-property: width;\n display: none;\n width: var(--sbb-navigation-width);\n grid-column: var(--sbb-navigation-grid-column);\n padding: 0;\n margin: 0;\n position: relative;\n inset-inline-start: var(--sbb-navigation-inline-start, 0);\n inset-block-start: 0;\n border: none;\n pointer-events: none;\n height: var(--sbb-navigation-height);\n color: var(--sbb-navigation-color);\n background-color: var(--sbb-navigation-background-color);\n}\n.sbb-navigation::before {\n transition-duration: var(--sbb-navigation-animation-duration);\n transition-timing-function: var(--sbb-navigation-animation-easing);\n transition-property: width;\n content: \"\";\n position: absolute;\n width: var(--sbb-navigation-expanded-width);\n height: var(--sbb-navigation-height);\n background-color: var(--sbb-navigation-background-color);\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 {\n display: block;\n pointer-events: all;\n animation-name: open;\n animation-duration: var(--sbb-navigation-animation-duration);\n animation-timing-function: var(--sbb-navigation-animation-easing);\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-navigation {\n pointer-events: none;\n animation-name: close;\n}\n@media (forced-colors: active) {\n .sbb-navigation {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n\n.sbb-navigation__wrapper {\n outline: none;\n}\n\n.sbb-navigation__header {\n transition-duration: var(--sbb-navigation-animation-duration);\n transition-timing-function: var(--sbb-navigation-animation-easing);\n transition-property: width;\n display: flex;\n justify-content: flex-end;\n position: absolute;\n width: var(--sbb-navigation-expanded-width);\n pointer-events: none;\n padding: var(--sbb-spacing-responsive-xs);\n z-index: calc(var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index)) + 1);\n}\n\n.sbb-navigation__close {\n pointer-events: all;\n}\n\n.sbb-navigation__content {\n transition-duration: var(--sbb-navigation-animation-duration);\n transition-timing-function: var(--sbb-navigation-animation-easing);\n transition-property: translate;\n display: flex;\n flex-direction: column;\n gap: var(--sbb-navigation-content-gap);\n position: relative;\n height: var(--sbb-navigation-height);\n padding-inline: var(--sbb-navigation-padding-inline);\n padding-block: var(--sbb-navigation-padding-block-start) var(--sbb-navigation-padding-block-end);\n overflow-y: auto;\n translate: var(--sbb-navigation-content-translate);\n}\n\n::slotted(:first-child) {\n margin-block-start: var(--sbb-navigation-list-margin-block-start);\n}\n\n@keyframes open {\n from {\n translate: -100% 0;\n }\n to {\n translate: 0;\n }\n}\n@keyframes close {\n from {\n translate: 0;\n }\n to {\n translate: -100% 0;\n }\n}\n@keyframes backdrop-open {\n from {\n background-color: transparent;\n }\n}\n@keyframes backdrop-close {\n to {\n background-color: transparent;\n }\n}";
|
|
10
|
+
//#endregion
|
|
11
|
+
//#region src/elements/navigation/navigation/navigation.component.ts
|
|
12
|
+
var DEBOUNCE_TIME = 150;
|
|
13
|
+
/**
|
|
14
|
+
* It displays a navigation menu, wrapping one or more `sbb-navigation-*` components.
|
|
15
|
+
*
|
|
16
|
+
* @slot - Use the unnamed slot to add `sbb-navigation-button`/`sbb-navigation-link` elements into the sbb-navigation menu.
|
|
17
|
+
* @cssprop [--sbb-navigation-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
|
|
18
|
+
* the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
|
|
19
|
+
* component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
|
|
20
|
+
*/
|
|
21
|
+
var SbbNavigationElement = (() => {
|
|
22
|
+
let _classSuper = SbbUpdateSchedulerMixin(SbbOpenCloseBaseElement);
|
|
23
|
+
let _trigger_decorators;
|
|
24
|
+
let _trigger_initializers = [];
|
|
25
|
+
let _trigger_extraInitializers = [];
|
|
26
|
+
let _accessibilityCloseLabel_decorators;
|
|
27
|
+
let _accessibilityCloseLabel_initializers = [];
|
|
28
|
+
let _accessibilityCloseLabel_extraInitializers = [];
|
|
29
|
+
let __activeNavigationSection_decorators;
|
|
30
|
+
let __activeNavigationSection_initializers = [];
|
|
31
|
+
let __activeNavigationSection_extraInitializers = [];
|
|
32
|
+
return class SbbNavigationElement extends _classSuper {
|
|
33
|
+
static {
|
|
34
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
35
|
+
_trigger_decorators = [idReference(), property()];
|
|
36
|
+
_accessibilityCloseLabel_decorators = [forceType(), property({ attribute: "accessibility-close-label" })];
|
|
37
|
+
__activeNavigationSection_decorators = [state()];
|
|
38
|
+
__esDecorate(this, null, _trigger_decorators, {
|
|
39
|
+
kind: "accessor",
|
|
40
|
+
name: "trigger",
|
|
41
|
+
static: false,
|
|
42
|
+
private: false,
|
|
43
|
+
access: {
|
|
44
|
+
has: (obj) => "trigger" in obj,
|
|
45
|
+
get: (obj) => obj.trigger,
|
|
46
|
+
set: (obj, value) => {
|
|
47
|
+
obj.trigger = value;
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
metadata: _metadata
|
|
51
|
+
}, _trigger_initializers, _trigger_extraInitializers);
|
|
52
|
+
__esDecorate(this, null, _accessibilityCloseLabel_decorators, {
|
|
53
|
+
kind: "accessor",
|
|
54
|
+
name: "accessibilityCloseLabel",
|
|
55
|
+
static: false,
|
|
56
|
+
private: false,
|
|
57
|
+
access: {
|
|
58
|
+
has: (obj) => "accessibilityCloseLabel" in obj,
|
|
59
|
+
get: (obj) => obj.accessibilityCloseLabel,
|
|
60
|
+
set: (obj, value) => {
|
|
61
|
+
obj.accessibilityCloseLabel = value;
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
metadata: _metadata
|
|
65
|
+
}, _accessibilityCloseLabel_initializers, _accessibilityCloseLabel_extraInitializers);
|
|
66
|
+
__esDecorate(this, null, __activeNavigationSection_decorators, {
|
|
67
|
+
kind: "accessor",
|
|
68
|
+
name: "_activeNavigationSection",
|
|
69
|
+
static: false,
|
|
70
|
+
private: false,
|
|
71
|
+
access: {
|
|
72
|
+
has: (obj) => "_activeNavigationSection" in obj,
|
|
73
|
+
get: (obj) => obj._activeNavigationSection,
|
|
74
|
+
set: (obj, value) => {
|
|
75
|
+
obj._activeNavigationSection = value;
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
metadata: _metadata
|
|
79
|
+
}, __activeNavigationSection_initializers, __activeNavigationSection_extraInitializers);
|
|
80
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
81
|
+
enumerable: true,
|
|
82
|
+
configurable: true,
|
|
83
|
+
writable: true,
|
|
84
|
+
value: _metadata
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
static {
|
|
88
|
+
this.elementName = "sbb-navigation";
|
|
89
|
+
}
|
|
90
|
+
static {
|
|
91
|
+
this.elementDependencies = [SbbTransparentButtonElement];
|
|
92
|
+
}
|
|
93
|
+
static {
|
|
94
|
+
this.role = "navigation";
|
|
95
|
+
}
|
|
96
|
+
static {
|
|
97
|
+
this.styles = [
|
|
98
|
+
boxSizingStyles,
|
|
99
|
+
scrollbarStyles,
|
|
100
|
+
unsafeCSS(navigation_default)
|
|
101
|
+
];
|
|
102
|
+
}
|
|
103
|
+
#trigger_accessor_storage;
|
|
104
|
+
/**
|
|
105
|
+
* The element that will trigger the navigation.
|
|
106
|
+
*
|
|
107
|
+
* For attribute usage, provide an id reference.
|
|
108
|
+
*/
|
|
109
|
+
get trigger() {
|
|
110
|
+
return this.#trigger_accessor_storage;
|
|
111
|
+
}
|
|
112
|
+
set trigger(value) {
|
|
113
|
+
this.#trigger_accessor_storage = value;
|
|
114
|
+
}
|
|
115
|
+
#accessibilityCloseLabel_accessor_storage;
|
|
116
|
+
/** This will be forwarded as aria-label to the close button element. */
|
|
117
|
+
get accessibilityCloseLabel() {
|
|
118
|
+
return this.#accessibilityCloseLabel_accessor_storage;
|
|
119
|
+
}
|
|
120
|
+
set accessibilityCloseLabel(value) {
|
|
121
|
+
this.#accessibilityCloseLabel_accessor_storage = value;
|
|
122
|
+
}
|
|
123
|
+
#_activeNavigationSection_accessor_storage;
|
|
124
|
+
/** Whether a navigation section is displayed. */
|
|
125
|
+
get _activeNavigationSection() {
|
|
126
|
+
return this.#_activeNavigationSection_accessor_storage;
|
|
127
|
+
}
|
|
128
|
+
set _activeNavigationSection(value) {
|
|
129
|
+
this.#_activeNavigationSection_accessor_storage = value;
|
|
130
|
+
}
|
|
131
|
+
/** Returns the active navigation section element. */
|
|
132
|
+
get activeNavigationSection() {
|
|
133
|
+
return this._activeNavigationSection;
|
|
134
|
+
}
|
|
135
|
+
/** Returns the close button element. */
|
|
136
|
+
get closeButton() {
|
|
137
|
+
return this.shadowRoot?.querySelector("#sbb-navigation-close-button") ?? null;
|
|
138
|
+
}
|
|
139
|
+
/** Returns the navigation content element. */
|
|
140
|
+
get navigationContent() {
|
|
141
|
+
return this.shadowRoot?.querySelector(".sbb-navigation__content") ?? null;
|
|
142
|
+
}
|
|
143
|
+
constructor() {
|
|
144
|
+
super();
|
|
145
|
+
this.#trigger_accessor_storage = __runInitializers(this, _trigger_initializers, null);
|
|
146
|
+
this.#accessibilityCloseLabel_accessor_storage = (__runInitializers(this, _trigger_extraInitializers), __runInitializers(this, _accessibilityCloseLabel_initializers, ""));
|
|
147
|
+
this.#_activeNavigationSection_accessor_storage = (__runInitializers(this, _accessibilityCloseLabel_extraInitializers), __runInitializers(this, __activeNavigationSection_initializers, null));
|
|
148
|
+
this._navigation = __runInitializers(this, __activeNavigationSection_extraInitializers);
|
|
149
|
+
this._triggerElement = null;
|
|
150
|
+
this._language = new SbbLanguageController(this);
|
|
151
|
+
this._inertController = new SbbInertController(this);
|
|
152
|
+
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
153
|
+
this._focusTrapController = new SbbFocusTrapController(this);
|
|
154
|
+
this._scrollHandler = new SbbScrollHandler();
|
|
155
|
+
this._isPointerDownEventOnNavigation = false;
|
|
156
|
+
this._resizeObserverTimeout = null;
|
|
157
|
+
this._navigationResizeObserver = new ResizeController(this, {
|
|
158
|
+
skipInitial: true,
|
|
159
|
+
callback: () => this._onNavigationResize()
|
|
160
|
+
});
|
|
161
|
+
this._pointerDownListener = (event) => {
|
|
162
|
+
this._isPointerDownEventOnNavigation = isEventOnElement(this._navigation, event) || isEventOnElement(this.querySelector("sbb-navigation-section:is(:state(state-opened),[state--state-opened])")?.shadowRoot?.querySelector("nav.sbb-navigation-section"), event);
|
|
163
|
+
};
|
|
164
|
+
this._closeOnBackdropClick = (event) => {
|
|
165
|
+
if (!this._isPointerDownEventOnNavigation && !isEventOnElement(this._navigation, event)) this.close();
|
|
166
|
+
};
|
|
167
|
+
this.addEventListener?.("click", (event) => this._handleNavigationClose(event));
|
|
168
|
+
this.addEventListener?.("pointerup", (event) => this._closeOnBackdropClick(event));
|
|
169
|
+
this.addEventListener?.("pointerdown", (event) => this._pointerDownListener(event));
|
|
170
|
+
this.addEventListener?.("ɵnavigationsectionopening", (event) => {
|
|
171
|
+
this._activeNavigationSection = event.target;
|
|
172
|
+
this.toggleState("has-open-navigation-section", !!this._activeNavigationSection);
|
|
173
|
+
}, { capture: true });
|
|
174
|
+
this.addEventListener?.("ɵnavigationsectionclosing", (event) => {
|
|
175
|
+
if (this._activeNavigationSection === event.target) {
|
|
176
|
+
this._activeNavigationSection = null;
|
|
177
|
+
this.internals.states.delete("has-open-navigation-section");
|
|
178
|
+
}
|
|
179
|
+
}, { capture: true });
|
|
180
|
+
}
|
|
181
|
+
/** Opens the navigation. */
|
|
182
|
+
open() {
|
|
183
|
+
if (this.state !== "closed" || !this.hasUpdated || !this.dispatchBeforeOpenEvent()) return;
|
|
184
|
+
this.showPopover?.();
|
|
185
|
+
this.state = "opening";
|
|
186
|
+
this._checkActiveActions();
|
|
187
|
+
this._checkActiveSection();
|
|
188
|
+
this.startUpdate();
|
|
189
|
+
this._scrollHandler.disableScroll();
|
|
190
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "true";
|
|
191
|
+
if (this._isZeroAnimationDuration()) this._handleOpening();
|
|
192
|
+
}
|
|
193
|
+
_checkActiveSection() {
|
|
194
|
+
this.querySelector("sbb-navigation-button.sbb-active")?.connectedSection?.open();
|
|
195
|
+
}
|
|
196
|
+
_checkActiveActions() {
|
|
197
|
+
Array.from(this.querySelectorAll(":is(sbb-navigation-button, sbb-navigation-link).sbb-active"))?.forEach((action) => action.marker?.select(action));
|
|
198
|
+
}
|
|
199
|
+
/** Closes the navigation. */
|
|
200
|
+
close() {
|
|
201
|
+
if (this.state !== "opened" || !this.dispatchBeforeCloseEvent()) return;
|
|
202
|
+
this.state = "closing";
|
|
203
|
+
this.startUpdate();
|
|
204
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "false";
|
|
205
|
+
if (this._isZeroAnimationDuration()) this._handleClosing();
|
|
206
|
+
}
|
|
207
|
+
_isZeroAnimationDuration() {
|
|
208
|
+
return isZeroAnimationDuration(this, "--sbb-navigation-animation-duration");
|
|
209
|
+
}
|
|
210
|
+
_handleClosing() {
|
|
211
|
+
this.state = "closed";
|
|
212
|
+
this.hidePopover?.();
|
|
213
|
+
this.navigationContent?.scrollTo(0, 0);
|
|
214
|
+
this._inertController.deactivate();
|
|
215
|
+
this._triggerElement?.focus();
|
|
216
|
+
this._escapableOverlayController.disconnect();
|
|
217
|
+
this.dispatchCloseEvent();
|
|
218
|
+
this._navigationResizeObserver.unobserve(this);
|
|
219
|
+
this._resetMarkers();
|
|
220
|
+
this._focusTrapController.enabled = false;
|
|
221
|
+
this._scrollHandler.enableScroll();
|
|
222
|
+
this.completeUpdate();
|
|
223
|
+
}
|
|
224
|
+
_handleOpening() {
|
|
225
|
+
this.state = "opened";
|
|
226
|
+
this._navigationResizeObserver.observe(this);
|
|
227
|
+
this._inertController.activate();
|
|
228
|
+
this._escapableOverlayController.connect();
|
|
229
|
+
this._focusTrapController.focusInitialElement();
|
|
230
|
+
this._focusTrapController.enabled = true;
|
|
231
|
+
this.completeUpdate();
|
|
232
|
+
this.dispatchOpenEvent();
|
|
233
|
+
}
|
|
234
|
+
_configureTrigger() {
|
|
235
|
+
if (this.trigger === this._triggerElement) return;
|
|
236
|
+
this._triggerAbortController?.abort();
|
|
237
|
+
removeAriaOverlayTriggerProperties(this._triggerElement);
|
|
238
|
+
this._triggerElement = this.trigger;
|
|
239
|
+
if (!this._triggerElement) return;
|
|
240
|
+
setAriaOverlayTriggerProperties(this, this._triggerElement, "menu", this.state);
|
|
241
|
+
this._triggerAbortController = new AbortController();
|
|
242
|
+
this._triggerElement.addEventListener("click", () => this.open(), { signal: this._triggerAbortController.signal });
|
|
243
|
+
}
|
|
244
|
+
_onAnimationEnd(event) {
|
|
245
|
+
if (event.animationName === "open" && this.state === "opening") this._handleOpening();
|
|
246
|
+
else if (event.animationName === "close" && this.state === "closing") this._handleClosing();
|
|
247
|
+
}
|
|
248
|
+
_resetMarkers() {
|
|
249
|
+
Array.from(this.querySelectorAll(":is(sbb-navigation-button, sbb-navigation-link):is(:state(action-active),[state--action-active]):not(.sbb-active)"))?.forEach((action) => action.marker?.reset());
|
|
250
|
+
}
|
|
251
|
+
_handleNavigationClose(event) {
|
|
252
|
+
if (event.composedPath().filter((el) => el instanceof window.HTMLElement).some((el) => this._isCloseElement(el))) this.close();
|
|
253
|
+
}
|
|
254
|
+
_isCloseElement(element) {
|
|
255
|
+
return element.nodeName === "A" || element.hasAttribute("sbb-navigation-close") && !element.hasAttribute("disabled");
|
|
256
|
+
}
|
|
257
|
+
_onNavigationResize() {
|
|
258
|
+
if (this.state !== "opened") return;
|
|
259
|
+
if (this._resizeObserverTimeout) clearTimeout(this._resizeObserverTimeout);
|
|
260
|
+
this.internals.states.add("resize-disable-animation");
|
|
261
|
+
this._resizeObserverTimeout = setTimeout(() => this.internals.states.delete("resize-disable-animation"), DEBOUNCE_TIME);
|
|
262
|
+
}
|
|
263
|
+
connectedCallback() {
|
|
264
|
+
super.connectedCallback();
|
|
265
|
+
this.popover = "manual";
|
|
266
|
+
if (this.hasUpdated) this._configureTrigger();
|
|
267
|
+
}
|
|
268
|
+
disconnectedCallback() {
|
|
269
|
+
super.disconnectedCallback();
|
|
270
|
+
this._triggerElement = null;
|
|
271
|
+
this._triggerAbortController?.abort();
|
|
272
|
+
this._scrollHandler.enableScroll();
|
|
273
|
+
}
|
|
274
|
+
requestUpdate(name, oldValue, options) {
|
|
275
|
+
super.requestUpdate(name, oldValue, options);
|
|
276
|
+
if (!isServer && (!name || name === "trigger") && this.hasUpdated) this._configureTrigger();
|
|
277
|
+
}
|
|
278
|
+
firstUpdated(changedProperties) {
|
|
279
|
+
super.firstUpdated(changedProperties);
|
|
280
|
+
this._configureTrigger();
|
|
281
|
+
}
|
|
282
|
+
render() {
|
|
283
|
+
const closeButton = html`
|
|
284
|
+
<sbb-transparent-button
|
|
285
|
+
id="sbb-navigation-close-button"
|
|
286
|
+
class="sbb-navigation__close"
|
|
287
|
+
aria-label=${this.accessibilityCloseLabel || i18nCloseNavigation[this._language.current]}
|
|
288
|
+
aria-controls="sbb-navigation-overlay"
|
|
289
|
+
negative
|
|
290
|
+
size="m"
|
|
291
|
+
icon-name="cross-small"
|
|
292
|
+
sbb-navigation-close
|
|
293
|
+
></sbb-transparent-button>
|
|
294
|
+
`;
|
|
295
|
+
return html`
|
|
296
|
+
<div class="sbb-navigation__container">
|
|
297
|
+
<div
|
|
298
|
+
id="sbb-navigation-overlay"
|
|
299
|
+
@animationend=${this._onAnimationEnd}
|
|
300
|
+
class="sbb-navigation"
|
|
301
|
+
${ref((navigationRef) => this._navigation = navigationRef)}
|
|
302
|
+
>
|
|
303
|
+
<div class="sbb-navigation__header">${closeButton}</div>
|
|
304
|
+
<div class="sbb-navigation__wrapper">
|
|
305
|
+
<div class="sbb-navigation__content sbb-scrollbar-negative">
|
|
306
|
+
<slot></slot>
|
|
307
|
+
</div>
|
|
308
|
+
</div>
|
|
309
|
+
</div>
|
|
310
|
+
<slot name="navigation-section"></slot>
|
|
311
|
+
</div>
|
|
312
|
+
`;
|
|
313
|
+
}
|
|
314
|
+
};
|
|
315
|
+
})();
|
|
316
|
+
//#endregion
|
|
317
|
+
export { SbbNavigationElement as t };
|
|
318
|
+
|
|
319
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"navigation.component-Cco4llBt.js","names":[],"sources":["../../../src/elements/navigation/navigation/navigation.scss?inline","../../../src/elements/navigation/navigation/navigation.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n@mixin transition($properties...) {\n  transition: {\n    duration: var(--sbb-navigation-animation-duration);\n    timing-function: var(--sbb-navigation-animation-easing);\n    property: $properties;\n  }\n}\n\n:host {\n  --sbb-navigation-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  display: none;\n  position: fixed;\n  inset: var(--sbb-navigation-inset);\n  z-index: var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));\n  overflow: hidden;\n\n  @include sbb.mq($from: large) {\n    --sbb-navigation-animation-duration: var(\n      --sbb-disable-animation-duration,\n      var(--sbb-animation-duration-6x)\n    );\n    --sbb-navigation-width: calc(100% + var(--sbb-layout-base-offset-responsive));\n  }\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  display: block;\n}\n\n:host(:state(state-opened)) {\n  --sbb-navigation-animation-easing: ease-out;\n}\n\n:host(:is(:state(state-opened), :state(state-opening))) {\n  --sbb-navigation-backdrop-visibility: visible;\n  --sbb-navigation-backdrop-pointer-events: all;\n}\n\n:host(:not(:state(state-closed))) {\n  --sbb-navigation-inset: 0;\n  --sbb-navigation-translate: none;\n}\n\n:host(:state(state-closing)) {\n  --sbb-navigation-backdrop-animation-name: backdrop-close;\n}\n\n:host(:state(has-open-navigation-section)) {\n  --sbb-navigation-content-translate: -100% 0;\n\n  @include sbb.mq($from: 'large') {\n    --sbb-navigation-expanded-width: 100dvw;\n    --sbb-navigation-content-translate: 0;\n  }\n}\n\n:host(:state(resize-disable-animation)) {\n  @include sbb.disable-animation;\n}\n\n.sbb-navigation__container {\n  @include sbb.grid-base;\n\n  padding-inline: 0;\n  pointer-events: none;\n  translate: var(--sbb-navigation-translate);\n\n  @include sbb.mq($from: large) {\n    padding-inline: var(--sbb-layout-base-offset-responsive);\n\n    // Navigation backdrop (not visible on mobile)\n    &::before {\n      @include transition(visibility);\n\n      animation: {\n        name: var(--sbb-navigation-backdrop-animation-name);\n        duration: var(--sbb-navigation-animation-duration);\n        timing-function: var(--sbb-navigation-animation-easing);\n      }\n\n      content: '';\n      visibility: var(--sbb-navigation-backdrop-visibility, hidden);\n      pointer-events: var(--sbb-navigation-backdrop-pointer-events, none);\n      position: fixed;\n      inset: var(--sbb-navigation-inset);\n      background-color: var(--sbb-navigation-backdrop-color);\n    }\n  }\n}\n\n.sbb-navigation {\n  @include transition(width);\n\n  display: none;\n  width: var(--sbb-navigation-width);\n  grid-column: var(--sbb-navigation-grid-column);\n  padding: 0;\n  margin: 0;\n  position: relative;\n  inset-inline-start: var(--sbb-navigation-inline-start, 0);\n  inset-block-start: 0;\n  border: none;\n  pointer-events: none;\n  height: var(--sbb-navigation-height);\n  color: var(--sbb-navigation-color);\n  background-color: var(--sbb-navigation-background-color);\n\n  &::before {\n    @include transition(width);\n\n    content: '';\n    position: absolute;\n    width: var(--sbb-navigation-expanded-width);\n    height: var(--sbb-navigation-height);\n    background-color: var(--sbb-navigation-background-color);\n  }\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n    pointer-events: all;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-navigation-animation-duration);\n      timing-function: var(--sbb-navigation-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\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__wrapper {\n  outline: none;\n}\n\n.sbb-navigation__header {\n  @include transition(width);\n\n  display: flex;\n  justify-content: flex-end;\n  position: absolute;\n  width: var(--sbb-navigation-expanded-width);\n  pointer-events: none;\n  padding: var(--sbb-spacing-responsive-xs);\n  z-index: calc(var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index)) + 1);\n}\n\n.sbb-navigation__close {\n  pointer-events: all;\n}\n\n.sbb-navigation__content {\n  @include transition(translate);\n\n  display: flex;\n  flex-direction: column;\n  gap: var(--sbb-navigation-content-gap);\n  position: relative;\n  height: var(--sbb-navigation-height);\n  padding-inline: var(--sbb-navigation-padding-inline);\n  padding-block: var(--sbb-navigation-padding-block-start) var(--sbb-navigation-padding-block-end);\n  overflow-y: auto;\n  translate: var(--sbb-navigation-content-translate);\n}\n\n::slotted(:first-child) {\n  margin-block-start: var(--sbb-navigation-list-margin-block-start);\n}\n\n@keyframes open {\n  from {\n    translate: -100% 0;\n  }\n\n  to {\n    translate: 0;\n  }\n}\n\n@keyframes close {\n  from {\n    translate: 0;\n  }\n\n  to {\n    translate: -100% 0;\n  }\n}\n\n@keyframes backdrop-open {\n  from {\n    background-color: transparent;\n  }\n}\n\n@keyframes backdrop-close {\n  to {\n    background-color: transparent;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbTransparentButtonElement } from '../../button.pure.ts';\nimport {\n  boxSizingStyles,\n  forceType,\n  i18nCloseNavigation,\n  idReference,\n  isEventOnElement,\n  isZeroAnimationDuration,\n  removeAriaOverlayTriggerProperties,\n  type SbbElementType,\n  SbbEscapableOverlayController,\n  SbbFocusTrapController,\n  SbbInertController,\n  SbbLanguageController,\n  SbbOpenCloseBaseElement,\n  SbbScrollHandler,\n  SbbUpdateSchedulerMixin,\n  scrollbarStyles,\n  setAriaOverlayTriggerProperties,\n} from '../../core.ts';\nimport type { SbbNavigationButtonElement } from '../navigation-button/navigation-button.component.ts';\nimport type { SbbNavigationLinkElement } from '../navigation-link/navigation-link.component.ts';\nimport type { SbbNavigationSectionElement } from '../navigation-section/navigation-section.component.ts';\n\nimport style from './navigation.scss?inline';\n\nconst DEBOUNCE_TIME = 150;\n\n/**\n * It displays a navigation menu, wrapping one or more `sbb-navigation-*` components.\n *\n * @slot - Use the unnamed slot to add `sbb-navigation-button`/`sbb-navigation-link` elements into the sbb-navigation menu.\n * @cssprop [--sbb-navigation-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport class SbbNavigationElement extends SbbUpdateSchedulerMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-navigation';\n  public static override elementDependencies: SbbElementType[] = [SbbTransparentButtonElement];\n  public static override readonly role = 'navigation';\n  public static override styles: CSSResultGroup = [\n    boxSizingStyles,\n    scrollbarStyles,\n    unsafeCSS(style),\n  ];\n\n  /**\n   * The element that will trigger the navigation.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /** This will be forwarded as aria-label to the close button element. */\n  @forceType()\n  @property({ attribute: 'accessibility-close-label' })\n  public accessor accessibilityCloseLabel: string = '';\n\n  /** Whether a navigation section is displayed. */\n  @state() private accessor _activeNavigationSection: SbbNavigationSectionElement | null = null;\n\n  /** Returns the active navigation section element. */\n  public get activeNavigationSection(): SbbNavigationSectionElement | null {\n    return this._activeNavigationSection;\n  }\n\n  /** Returns the close button element. */\n  public get closeButton(): HTMLElement | null {\n    return this.shadowRoot?.querySelector('#sbb-navigation-close-button') ?? null;\n  }\n\n  /** Returns the navigation content element. */\n  public get navigationContent(): HTMLElement | null {\n    return this.shadowRoot?.querySelector('.sbb-navigation__content') ?? null;\n  }\n\n  private _navigation!: HTMLDivElement;\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController!: AbortController;\n  private _language = new SbbLanguageController(this);\n  private _inertController = new SbbInertController(this);\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _scrollHandler = new SbbScrollHandler();\n  private _isPointerDownEventOnNavigation: boolean = false;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _navigationResizeObserver = new ResizeController(this, {\n    skipInitial: true,\n    callback: () => this._onNavigationResize(),\n  });\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (event) => this._handleNavigationClose(event));\n    this.addEventListener?.('pointerup', (event) => this._closeOnBackdropClick(event));\n    this.addEventListener?.('pointerdown', (event) => this._pointerDownListener(event));\n    this.addEventListener?.(\n      'ɵnavigationsectionopening',\n      (event) => {\n        this._activeNavigationSection = event.target as SbbNavigationSectionElement;\n        this.toggleState('has-open-navigation-section', !!this._activeNavigationSection);\n      },\n      { capture: true },\n    );\n    this.addEventListener?.(\n      'ɵnavigationsectionclosing',\n      (event) => {\n        if (this._activeNavigationSection === event.target) {\n          this._activeNavigationSection = null;\n          this.internals.states.delete('has-open-navigation-section');\n        }\n      },\n      { capture: true },\n    );\n  }\n\n  /** Opens the navigation. */\n  public open(): void {\n    if (this.state !== 'closed' || !this.hasUpdated || !this.dispatchBeforeOpenEvent()) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._checkActiveActions();\n    this._checkActiveSection();\n    this.startUpdate();\n\n    // Disable scrolling for content below the navigation\n    this._scrollHandler.disableScroll();\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 _checkActiveSection(): void {\n    const activeAction = this.querySelector(\n      'sbb-navigation-button.sbb-active',\n    ) as SbbNavigationButtonElement;\n    activeAction?.connectedSection?.open();\n  }\n\n  private _checkActiveActions(): void {\n    const activeActions = Array.from(\n      this.querySelectorAll(':is(sbb-navigation-button, sbb-navigation-link).sbb-active'),\n    ) as (SbbNavigationButtonElement | SbbNavigationLinkElement)[];\n    activeActions?.forEach((action) => action.marker?.select(action));\n  }\n\n  /** Closes the navigation. */\n  public close(): void {\n    if (this.state !== 'opened' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this.startUpdate();\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  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-navigation-animation-duration');\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.navigationContent?.scrollTo(0, 0);\n    this._inertController.deactivate();\n    this._triggerElement?.focus();\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n    this._navigationResizeObserver.unobserve(this);\n    this._resetMarkers();\n    this._focusTrapController.enabled = false;\n\n    // Enable scrolling for content below the navigation\n    this._scrollHandler.enableScroll();\n    this.completeUpdate();\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._navigationResizeObserver.observe(this);\n    this._inertController.activate();\n    this._escapableOverlayController.connect();\n    this._focusTrapController.focusInitialElement();\n    this._focusTrapController.enabled = true;\n    this.completeUpdate();\n    this.dispatchOpenEvent();\n  }\n\n  // Removes trigger click listener on trigger change.\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    this._triggerElement.addEventListener('click', () => this.open(), {\n      signal: this._triggerAbortController.signal,\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 _resetMarkers(): void {\n    const activeActions = Array.from(\n      this.querySelectorAll(\n        ':is(sbb-navigation-button, sbb-navigation-link):state(action-active):not(.sbb-active)',\n      ),\n    ) as (SbbNavigationButtonElement | SbbNavigationLinkElement)[];\n    activeActions?.forEach((action) => action.marker?.reset());\n  }\n\n  private _handleNavigationClose(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isCloseElement(el as HTMLElement))) {\n      this.close();\n    }\n  }\n\n  private _isCloseElement(element: HTMLElement): boolean {\n    return (\n      element.nodeName === 'A' ||\n      (element.hasAttribute('sbb-navigation-close') && !element.hasAttribute('disabled'))\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the navigation.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnNavigation =\n      isEventOnElement(this._navigation, event) ||\n      isEventOnElement(\n        this.querySelector('sbb-navigation-section:state(state-opened)')?.shadowRoot?.querySelector(\n          'nav.sbb-navigation-section',\n        ) as HTMLElement,\n        event,\n      );\n  };\n\n  // Close navigation on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (!this._isPointerDownEventOnNavigation && !isEventOnElement(this._navigation, event)) {\n      this.close();\n    }\n  };\n\n  private _onNavigationResize(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    if (this._resizeObserverTimeout) {\n      clearTimeout(this._resizeObserverTimeout);\n    }\n\n    this.internals.states.add('resize-disable-animation');\n\n    // Disable the animation when resizing the navigation to avoid strange height transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('resize-disable-animation'),\n      DEBOUNCE_TIME,\n    );\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.popover = 'manual';\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._scrollHandler.enableScroll();\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    const closeButton = html`\n      <sbb-transparent-button\n        id=\"sbb-navigation-close-button\"\n        class=\"sbb-navigation__close\"\n        aria-label=${this.accessibilityCloseLabel || i18nCloseNavigation[this._language.current]}\n        aria-controls=\"sbb-navigation-overlay\"\n        negative\n        size=\"m\"\n        icon-name=\"cross-small\"\n        sbb-navigation-close\n      ></sbb-transparent-button>\n    `;\n\n    return html`\n      <div class=\"sbb-navigation__container\">\n        <div\n          id=\"sbb-navigation-overlay\"\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-navigation\"\n          ${ref((navigationRef?: Element) => (this._navigation = navigationRef as HTMLDivElement))}\n        >\n          <div class=\"sbb-navigation__header\">${closeButton}</div>\n          <div class=\"sbb-navigation__wrapper\">\n            <div class=\"sbb-navigation__content sbb-scrollbar-negative\">\n              <slot></slot>\n            </div>\n          </div>\n        </div>\n        <slot name=\"navigation-section\"></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-navigation': SbbNavigationElement;\n  }\n}\n"],"mappings":"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"}
|
|
@@ -3,8 +3,8 @@ import { SbbNavigationButtonElement } from "./navigation/navigation-button/navig
|
|
|
3
3
|
import { SbbNavigationLinkElement } from "./navigation/navigation-link/navigation-link.component.js";
|
|
4
4
|
import { t as SbbNavigationListElement } from "./navigation-list.component-DDjMz5TE.js";
|
|
5
5
|
import { t as SbbNavigationMarkerElement } from "./navigation-marker.component-Cd6apD2P.js";
|
|
6
|
-
import { t as SbbNavigationSectionElement } from "./navigation-section.component-
|
|
7
|
-
import { t as SbbNavigationElement } from "./navigation.component-
|
|
6
|
+
import { t as SbbNavigationSectionElement } from "./navigation-section.component-D3_XVwyt.js";
|
|
7
|
+
import { t as SbbNavigationElement } from "./navigation.component-Cco4llBt.js";
|
|
8
8
|
import "./navigation.pure.js";
|
|
9
9
|
//#region src/elements/navigation.ts
|
|
10
10
|
/** @entrypoint */
|
|
@@ -3,6 +3,6 @@ import { SbbNavigationButtonElement } from "./navigation/navigation-button/navig
|
|
|
3
3
|
import { SbbNavigationLinkElement } from "./navigation/navigation-link/navigation-link.component.js";
|
|
4
4
|
import { t as SbbNavigationListElement } from "./navigation-list.component-DDjMz5TE.js";
|
|
5
5
|
import { t as SbbNavigationMarkerElement } from "./navigation-marker.component-Cd6apD2P.js";
|
|
6
|
-
import { t as SbbNavigationSectionElement } from "./navigation-section.component-
|
|
7
|
-
import { t as SbbNavigationElement } from "./navigation.component-
|
|
6
|
+
import { t as SbbNavigationSectionElement } from "./navigation-section.component-D3_XVwyt.js";
|
|
7
|
+
import { t as SbbNavigationElement } from "./navigation.component-Cco4llBt.js";
|
|
8
8
|
export { SbbNavigationActionCommonElementMixin, SbbNavigationButtonElement, SbbNavigationElement, SbbNavigationLinkElement, SbbNavigationListElement, SbbNavigationMarkerElement, SbbNavigationSectionElement };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overlay.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/overlay/overlay.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAO/F,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"overlay.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/overlay/overlay.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAO/F,OAAO,EAKL,KAAK,cAAc,EACnB,KAAK,2BAA2B,EAEjC,MAAM,YAAY,CAAC;AAEpB,OAAO,EAEL,qBAAqB,EAEtB,MAAM,2BAA2B,CAAC;AAGnC;;;;;;;GAOG;AACH,qBAAa,iBAAkB,SAAQ,qBAAqB;IAC1D,gBAAgC,WAAW,EAAE,MAAM,CAAiB;IACpE,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAG1D;IACF,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAGpF,gBAAgC,MAAM;;;;;MAK3B;IAEX;;;OAGG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,wEAAwE;IACxE,SAEgB,uBAAuB,EAAE,MAAM,CAAM;IAErD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAuB;IACvD,OAAO,CAAC,sBAAsB,CAA4B;cAEvC,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAS9E,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;cAUZ,aAAa,IAAI,IAAI;cAwBrB,wBAAwB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO;cAaxE,kBAAkB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO;cAWlE,MAAM,IAAI,cAAc;CAwC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbOverlayElement } from "../overlay.component-
|
|
1
|
+
import { t as SbbOverlayElement } from "../overlay.component-DBzb0PdD.js";
|
|
2
2
|
export { SbbOverlayElement };
|