@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776724490 → 5.0.0-next-dev.1776756036
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/overlay/overlay-trigger-attributes.js +3 -3
- package/core.js +2 -2
- package/custom-elements.json +13 -13
- package/datepicker/datepicker/datepicker.component.js +1 -1
- package/{datepicker.component-BBmEvmW3.js → datepicker.component-CNQGkdr-.js} +11 -11
- package/datepicker.js +1 -1
- package/datepicker.pure.js +1 -1
- package/development/core/overlay/overlay-trigger-attributes.d.ts +4 -4
- package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
- package/development/core/overlay/overlay-trigger-attributes.js +12 -12
- package/development/core.js +2 -2
- package/development/datepicker/datepicker/datepicker.component.d.ts.map +1 -1
- package/development/datepicker/datepicker/datepicker.component.js +1 -1
- package/development/datepicker.component-Chnvwnp7.js +212 -0
- package/development/datepicker.js +1 -1
- package/development/datepicker.pure.js +1 -1
- package/development/dialog/dialog/dialog.component.d.ts +0 -1
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +1 -1
- package/development/{dialog.component-BYVTZAUU.js → dialog.component-B4cZfRCl.js} +1 -6
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/header/header/header.component.d.ts.map +1 -1
- package/development/header/header/header.component.js +1 -1
- package/development/{header.component-Hfgz9sSb.js → header.component-B2T2pmHs.js} +2 -3
- package/development/header.js +1 -1
- package/development/header.pure.js +1 -1
- package/development/menu/common/menu-action-common.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-action-common-CEnwq60Z.js +32 -0
- package/development/menu.component-BM7hhOb4.js +365 -0
- package/development/menu.js +2 -2
- package/development/menu.pure.js +2 -2
- 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-C_9myQKr.js → navigation-section.component-6tqZADWM.js} +6 -8
- package/development/{navigation.component-C8MhqBLY.js → navigation.component-DUy2QGHI.js} +6 -8
- package/development/navigation.js +2 -2
- package/development/navigation.pure.js +2 -2
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +6 -6
- package/development/overlay/overlay.component.d.ts +0 -1
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -1
- package/development/{overlay.component-BuCkqG6Q.js → overlay.component-CA0fWX47.js} +1 -6
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +1 -1
- package/development/popover.component-B1gMzBuv.js +527 -0
- package/development/popover.js +1 -1
- package/development/popover.pure.js +1 -1
- package/development/{step-label.component-CxqPgbzK.js → step-label.component-B7M9Yqyz.js} +1 -3
- package/development/{step.component-B2qbHl0l.js → step.component-CVWxYkrv.js} +1 -3
- package/development/stepper/step/step.component.d.ts.map +1 -1
- package/development/stepper/step/step.component.js +1 -1
- package/development/stepper/step-label/step-label.component.d.ts.map +1 -1
- package/development/stepper/step-label/step-label.component.js +1 -1
- package/development/stepper.js +2 -2
- package/development/stepper.pure.js +2 -2
- package/development/{tab.component-DteuwiHv.js → tab.component-CvzGdR9_.js} +1 -3
- package/development/tabs/tab/tab.component.d.ts.map +1 -1
- package/development/tabs/tab/tab.component.js +1 -1
- package/development/tabs.js +1 -1
- package/development/tabs.pure.js +1 -1
- package/development/tooltip/tooltip.component.d.ts.map +1 -1
- package/development/tooltip/tooltip.component.js +1 -1
- package/development/tooltip.component-lvElko6C.js +369 -0
- package/development/tooltip.js +1 -1
- package/development/tooltip.pure.js +1 -1
- package/dialog/dialog/dialog.component.js +1 -1
- package/{dialog.component-ca14M0hZ.js → dialog.component-DTbAHlVd.js} +7 -10
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/header/header/header.component.js +1 -1
- package/{header.component-BxizSy1O.js → header.component-D-WVEMFn.js} +2 -2
- package/header.js +1 -1
- package/header.pure.js +1 -1
- package/menu/common/menu-action-common.js +1 -1
- package/menu/menu/menu.component.js +1 -1
- package/{menu-action-common-DY4RrfCy.js → menu-action-common-krzD_Ca2.js} +1 -1
- package/{menu.component-XvtyRok7.js → menu.component-i-X_ag2Y.js} +14 -14
- package/menu.js +2 -2
- package/menu.pure.js +2 -2
- package/navigation/navigation/navigation.component.js +1 -1
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/{navigation-section.component-CLcdmPV3.js → navigation-section.component-Db2MWBDn.js} +17 -17
- package/{navigation.component-Cnyb5_4R.js → navigation.component-Bym1kjzt.js} +16 -16
- package/navigation.js +2 -2
- package/navigation.pure.js +2 -2
- package/overlay/overlay-base-element.js +4 -4
- package/overlay/overlay.component.js +1 -1
- package/{overlay.component-OzDUV8t1.js → overlay.component-BydJOM2r.js} +10 -13
- 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-BfSXNxKK.js → popover.component-Dd4rKGml.js} +12 -12
- package/popover.js +1 -1
- package/popover.pure.js +1 -1
- package/{step-label.component-qdfunibJ.js → step-label.component-BXg13qOD.js} +3 -3
- package/{step.component-aBAfTJyO.js → step.component-sQbJslHx.js} +3 -3
- package/stepper/step/step.component.js +1 -1
- package/stepper/step-label/step-label.component.js +1 -1
- package/stepper.js +2 -2
- package/stepper.pure.js +2 -2
- package/{tab.component-DGzqld4u.js → tab.component-D39b0S04.js} +3 -3
- package/tabs/tab/tab.component.js +1 -1
- package/tabs.js +1 -1
- package/tabs.pure.js +1 -1
- package/tooltip/tooltip.component.js +1 -1
- package/{tooltip.component-C5y6zCtF.js → tooltip.component-Do4V1jGd.js} +12 -12
- package/tooltip.js +1 -1
- package/tooltip.pure.js +1 -1
- package/development/datepicker.component-AKlc7SAO.js +0 -214
- package/development/menu-action-common-Crx-dDgH.js +0 -32
- package/development/menu.component-DOv7PKIi.js +0 -367
- package/development/popover.component-B15jFLe9.js +0 -529
- package/development/tooltip.component-BtWTK2R0.js +0 -371
|
@@ -0,0 +1,365 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDarkModeController, SbbEscapableOverlayController, SbbFocusTrapController, SbbInertController, SbbLanguageController, SbbMediaMatcherController, SbbMediaQueryBreakpointSmallAndBelow, SbbOpenCloseBaseElement, SbbScrollHandler, boxSizingStyles, forwardEvent, getElementPosition, getElementPositionHorizontal, getNextElementIndex, i18nGoBack, idReference, interactivityChecker, isArrowKeyOrPageKeysPressed, isEventOnElement, isZeroAnimationDuration, removeAriaOverlayTriggerProperties, setAriaOverlayTriggerProperties, ɵstateController } from "./core.js";
|
|
5
|
+
import { SbbDividerElement } from "./divider.pure.js";
|
|
6
|
+
import { ref } from "lit/directives/ref.js";
|
|
7
|
+
import { SbbMenuButtonElement } from "./menu/menu-button/menu-button.component.js";
|
|
8
|
+
//#region src/elements/menu/menu/menu.scss?inline
|
|
9
|
+
var menu_default = ":host {\n display: contents;\n --sbb-menu-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-6x)\n );\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n --_sbb-menu-inset: 0 auto auto 0;\n --sbb-scrollbar-thumb-width: 0.125rem;\n --sbb-scrollbar-thumb-width-hover: 0.25rem;\n --sbb-scrollbar-width-firefox: thin;\n --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-white) 30%, transparent);\n --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-white) 60%, transparent);\n --sbb-scrollbar-track-color: transparent;\n}\n@media (min-width: calc(64rem)) {\n :host {\n --sbb-menu-back-button-display: none;\n }\n}\n\n:host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-opening),[state--state-opening]))) {\n --sbb-menu-visibility: visible;\n --sbb-menu-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 20%, transparent);\n}\n@media (min-width: calc(64rem)) {\n :host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-opening),[state--state-opening]))) {\n --sbb-menu-backdrop-color: transparent;\n }\n}\n\n:host(:not(:is(:state(nested),[state--nested]))) {\n --sbb-menu-back-button-display: none;\n}\n\n:host(:not(:is(:state(state-closed),[state--state-closed]))) {\n --_sbb-menu-inset: 0;\n}\n\n:host(:is(:state(dark),[state--dark])) {\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);\n --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);\n --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);\n}\n\n@media (max-width: calc(63.9375rem)) {\n :host(:is(:state(skip-animation),[state--skip-animation])) {\n --sbb-menu-animation-duration: 0ms;\n }\n :host(:is(:state(nested-child),[state--nested-child])) {\n --sbb-menu-transform-x: -100%;\n }\n :host(:is(:state(nested),[state--nested]):is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) {\n --sbb-menu-open-animation-name: open-sideways;\n }\n :host(:is(:state(state-closing),[state--state-closing]):is(:state(nested),[state--nested]):not(:is(:state(close-all),[state--close-all]))) {\n --sbb-menu-close-animation-name: close-sideways;\n }\n}\n::slotted(:not(sbb-menu-button, sbb-menu-link, sbb-divider)) {\n display: block;\n padding-inline: var(--sbb-spacing-fixed-5x);\n}\n\nsbb-divider,\n::slotted(sbb-divider) {\n --sbb-divider-color: var(--sbb-background-color-4-inverted);\n margin-block: var(--sbb-spacing-fixed-2x);\n}\n\nsbb-divider,\n#sbb-menu__back-button {\n display: var(--sbb-menu-back-button-display, block);\n}\n\n.sbb-menu__container {\n position: fixed;\n pointer-events: none;\n inset: var(--_sbb-menu-inset);\n height: var(--sbb-menu-container-height);\n z-index: var(--sbb-menu-z-index, var(--sbb-overlay-default-z-index));\n}\n.sbb-menu__container::before {\n content: \"\";\n visibility: var(--sbb-menu-visibility, hidden);\n pointer-events: all;\n position: fixed;\n inset: var(--_sbb-menu-inset);\n height: var(--sbb-menu-container-height);\n background-color: var(--sbb-menu-backdrop-color, transparent);\n transition-duration: var(--sbb-menu-animation-duration);\n transition-timing-function: var(--sbb-menu-animation-easing);\n transition-property: background-color, visibility;\n}\n:host(:is(:state(nested),[state--nested])) .sbb-menu__container::before {\n display: none;\n}\n\n.sbb-menu {\n display: none;\n opacity: 0;\n pointer-events: none;\n max-width: var(--sbb-menu-max-width);\n min-width: var(--sbb-menu-min-width);\n text-align: start;\n position: absolute;\n inset-inline-start: 0;\n inset-block-start: unset;\n inset-block-end: 0;\n inset-inline-end: unset;\n color: var(--sbb-menu-color);\n border: none;\n border-radius: var(--sbb-menu-border-radius) var(--sbb-menu-border-radius) 0 0;\n background-color: var(--sbb-menu-background-color);\n padding: 0;\n overflow: hidden;\n translate: var(--sbb-menu-transform-x, 0) 0;\n transition: translate var(--sbb-menu-animation-duration);\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-menu {\n display: block;\n opacity: 1;\n pointer-events: all;\n animation-name: var(--sbb-menu-open-animation-name, open);\n animation-duration: var(--sbb-menu-animation-duration);\n animation-timing-function: var(--sbb-menu-animation-easing);\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-menu {\n pointer-events: none;\n animation-name: var(--sbb-menu-close-animation-name, close);\n}\n@media (forced-colors: active) {\n .sbb-menu {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n@media (min-width: calc(64rem)) {\n .sbb-menu {\n top: 0;\n bottom: unset;\n left: 0;\n right: unset;\n max-height: fit-content;\n border-radius: var(--sbb-menu-border-radius);\n }\n :host(:not(:is(:state(state-closed),[state--state-closed]))) .sbb-menu {\n top: var(--sbb-menu-position-y, 0);\n left: var(--sbb-menu-position-x, 0);\n max-height: var(--sbb-menu-max-height);\n min-height: var(--sbb-menu-min-height);\n }\n}\n\n.sbb-menu__content {\n --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);\n}\n.sbb-menu__content::-webkit-scrollbar {\n width: var(--sbb-scrollbar-width);\n height: var(--sbb-scrollbar-width);\n background-color: var(--sbb-scrollbar-track-color, transparent);\n}\n.sbb-menu__content::-webkit-scrollbar-corner {\n background-color: var(--sbb-scrollbar-track-color, transparent);\n}\n.sbb-menu__content::-webkit-scrollbar-thumb {\n background-color: var(--sbb-scrollbar-color, currentcolor);\n border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;\n border-radius: var(--sbb-border-radius-4x);\n background-clip: padding-box;\n}\n.sbb-menu__content::-webkit-scrollbar-thumb:hover {\n background-color: var(--sbb-scrollbar-color-hover, currentcolor);\n border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));\n}\n.sbb-menu__content::-webkit-scrollbar-button, .sbb-menu__content::-webkit-scrollbar-corner {\n display: none;\n}\n@supports not selector(::-webkit-scrollbar) {\n .sbb-menu__content {\n scrollbar-width: var(--sbb-scrollbar-width-firefox);\n scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);\n }\n}\n.sbb-menu__content {\n max-height: var(--sbb-menu-max-height);\n padding-block: var(--sbb-spacing-fixed-1x);\n overflow: auto;\n outline: none;\n}\n.sbb-menu__content::after {\n content: \"\";\n display: block;\n height: var(--sbb-spacing-fixed-8x);\n}\n@media (min-width: calc(64rem)) {\n .sbb-menu__content {\n max-height: fit-content;\n }\n :host(:not(:is(:state(state-closed),[state--state-closed]))) .sbb-menu__content {\n max-height: var(--sbb-menu-max-height);\n min-height: var(--sbb-menu-min-height);\n }\n .sbb-menu__content::after {\n display: none;\n }\n}\n\n::slotted(:is(:is(:state(sbb-link),[state--sbb-link]), :is(:state(sbb-button),[state--sbb-button]))) {\n color-scheme: only light;\n}\n\n@keyframes open {\n from {\n opacity: 0;\n translate: 0 var(--sbb-menu-transform-y, 100%);\n }\n to {\n opacity: 1;\n translate: 0 0;\n }\n}\n@keyframes close {\n from {\n opacity: 1;\n translate: 0 0;\n }\n to {\n opacity: 0;\n translate: 0 var(--sbb-menu-transform-y, 100%);\n }\n}\n@keyframes open-sideways {\n from {\n translate: 100% 0;\n }\n to {\n translate: 0 0;\n }\n}\n@keyframes close-sideways {\n from {\n translate: 0 0;\n }\n to {\n translate: 100% 0;\n }\n}";
|
|
10
|
+
//#endregion
|
|
11
|
+
//#region src/elements/menu/menu/menu.component.ts
|
|
12
|
+
var MENU_OFFSET = 8;
|
|
13
|
+
var NESTED_MENU_OFFSET = -4;
|
|
14
|
+
var INTERACTIVE_ELEMENTS = [
|
|
15
|
+
"A",
|
|
16
|
+
"BUTTON",
|
|
17
|
+
"SBB-BUTTON",
|
|
18
|
+
"SBB-BUTTON-LINK",
|
|
19
|
+
"SBB-LINK",
|
|
20
|
+
"SBB-BLOCK-LINK",
|
|
21
|
+
"SBB-LINK-BUTTON",
|
|
22
|
+
"SBB-BLOCK-LINK-BUTTON",
|
|
23
|
+
"SBB-MENU-BUTTON",
|
|
24
|
+
"SBB-MENU-LINK"
|
|
25
|
+
];
|
|
26
|
+
/**
|
|
27
|
+
* It displays a contextual menu with one or more action element.
|
|
28
|
+
*
|
|
29
|
+
* @slot - Use the unnamed slot to add `sbb-menu-button`/`sbb-menu-link` or other elements to the menu.
|
|
30
|
+
* @cssprop [--sbb-menu-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
|
|
31
|
+
* the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
|
|
32
|
+
* component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
|
|
33
|
+
*/
|
|
34
|
+
var SbbMenuElement = (() => {
|
|
35
|
+
let _classSuper = SbbOpenCloseBaseElement;
|
|
36
|
+
let _trigger_decorators;
|
|
37
|
+
let _trigger_initializers = [];
|
|
38
|
+
let _trigger_extraInitializers = [];
|
|
39
|
+
return class SbbMenuElement extends _classSuper {
|
|
40
|
+
static {
|
|
41
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
42
|
+
_trigger_decorators = [idReference(), property()];
|
|
43
|
+
__esDecorate(this, null, _trigger_decorators, {
|
|
44
|
+
kind: "accessor",
|
|
45
|
+
name: "trigger",
|
|
46
|
+
static: false,
|
|
47
|
+
private: false,
|
|
48
|
+
access: {
|
|
49
|
+
has: (obj) => "trigger" in obj,
|
|
50
|
+
get: (obj) => obj.trigger,
|
|
51
|
+
set: (obj, value) => {
|
|
52
|
+
obj.trigger = value;
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
metadata: _metadata
|
|
56
|
+
}, _trigger_initializers, _trigger_extraInitializers);
|
|
57
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
58
|
+
enumerable: true,
|
|
59
|
+
configurable: true,
|
|
60
|
+
writable: true,
|
|
61
|
+
value: _metadata
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
static {
|
|
65
|
+
this.elementName = "sbb-menu";
|
|
66
|
+
}
|
|
67
|
+
static {
|
|
68
|
+
this.elementDependencies = [SbbDividerElement, SbbMenuButtonElement];
|
|
69
|
+
}
|
|
70
|
+
static {
|
|
71
|
+
this.styles = [boxSizingStyles, unsafeCSS(menu_default)];
|
|
72
|
+
}
|
|
73
|
+
static {
|
|
74
|
+
this.role = "menu";
|
|
75
|
+
}
|
|
76
|
+
#trigger_accessor_storage;
|
|
77
|
+
/**
|
|
78
|
+
* The element that will trigger the menu overlay.
|
|
79
|
+
*
|
|
80
|
+
* For attribute usage, provide an id reference.
|
|
81
|
+
*/
|
|
82
|
+
get trigger() {
|
|
83
|
+
return this.#trigger_accessor_storage;
|
|
84
|
+
}
|
|
85
|
+
set trigger(value) {
|
|
86
|
+
this.#trigger_accessor_storage = value;
|
|
87
|
+
}
|
|
88
|
+
constructor() {
|
|
89
|
+
super();
|
|
90
|
+
this.#trigger_accessor_storage = __runInitializers(this, _trigger_initializers, null);
|
|
91
|
+
this._menu = __runInitializers(this, _trigger_extraInitializers);
|
|
92
|
+
this._triggerElement = null;
|
|
93
|
+
this._isPointerDownEventOnMenu = false;
|
|
94
|
+
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
95
|
+
this._focusTrapController = new SbbFocusTrapController(this);
|
|
96
|
+
this._scrollHandler = new SbbScrollHandler();
|
|
97
|
+
this._inertController = new SbbInertController(this);
|
|
98
|
+
this._mobileBreakpoint = SbbMediaQueryBreakpointSmallAndBelow;
|
|
99
|
+
this._mediaMatcher = new SbbMediaMatcherController(this, { [this._mobileBreakpoint]: (matches) => {
|
|
100
|
+
if (matches && (this.state === "opening" || this.state === "opened")) this._scrollHandler.disableScroll();
|
|
101
|
+
else this._scrollHandler.enableScroll();
|
|
102
|
+
} });
|
|
103
|
+
this._darkModeController = new SbbDarkModeController(this, () => this._syncNegative());
|
|
104
|
+
this._language = new SbbLanguageController(this);
|
|
105
|
+
this._nestedMenu = null;
|
|
106
|
+
this._pointerDownListener = (event) => {
|
|
107
|
+
const menu = event.target.closest("sbb-menu");
|
|
108
|
+
this._isPointerDownEventOnMenu = isEventOnElement(this._menu, event) || this._nestedMenus().some((el) => menu === el);
|
|
109
|
+
};
|
|
110
|
+
this._closeOnBackdropClick = (event) => {
|
|
111
|
+
const target = event.target;
|
|
112
|
+
if (!this._isPointerDownEventOnMenu && !isEventOnElement(this._menu, event) && !this._nestedMenus().some((el) => el === target)) this.closeAll();
|
|
113
|
+
};
|
|
114
|
+
this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
|
|
115
|
+
}
|
|
116
|
+
firstUpdated(changedProperties) {
|
|
117
|
+
super.firstUpdated(changedProperties);
|
|
118
|
+
this._configureTrigger();
|
|
119
|
+
}
|
|
120
|
+
escapeStrategy() {
|
|
121
|
+
this.closeAll();
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Opens the menu on trigger click.
|
|
125
|
+
*/
|
|
126
|
+
open() {
|
|
127
|
+
if (this.state === "closing" || this.state === "opened" || !this._menu || !this.dispatchBeforeOpenEvent()) return;
|
|
128
|
+
if (this._isNested()) {
|
|
129
|
+
const parentMenu = this._parentMenu();
|
|
130
|
+
parentMenu.internals.states.add("nested-child");
|
|
131
|
+
if (parentMenu._nestedMenu !== this) parentMenu._nestedMenu?.close();
|
|
132
|
+
parentMenu._nestedMenu = this;
|
|
133
|
+
}
|
|
134
|
+
this.showPopover?.();
|
|
135
|
+
this.state = "opening";
|
|
136
|
+
this._setMenuPosition();
|
|
137
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "true";
|
|
138
|
+
if (this._isMobile()) this._scrollHandler.disableScroll();
|
|
139
|
+
if (this._isZeroAnimationDuration()) this._handleOpening();
|
|
140
|
+
}
|
|
141
|
+
/** Closes the menu and all its nested menus. */
|
|
142
|
+
close() {
|
|
143
|
+
this._close();
|
|
144
|
+
}
|
|
145
|
+
/** Closes the menu and all related menus (nested and parent menus). */
|
|
146
|
+
closeAll() {
|
|
147
|
+
this._mainMenu()._close(true);
|
|
148
|
+
}
|
|
149
|
+
/** @param [closeAll='false'] - If true, it ensures animations are correct by toggling some states when closing all related menus at once. */
|
|
150
|
+
_close(closeAll = false) {
|
|
151
|
+
if (this.state === "opening" && !this._isNested() || !this.dispatchBeforeCloseEvent()) return;
|
|
152
|
+
this._nestedMenu?._close(closeAll);
|
|
153
|
+
if (this._isNested()) {
|
|
154
|
+
const parentMenu = this._parentMenu();
|
|
155
|
+
if (closeAll) {
|
|
156
|
+
this.internals.states.add("close-all");
|
|
157
|
+
parentMenu.internals.states.add("skip-animation");
|
|
158
|
+
} else {
|
|
159
|
+
this.internals.states.delete("close-all");
|
|
160
|
+
parentMenu.internals.states.delete("skip-animation");
|
|
161
|
+
}
|
|
162
|
+
parentMenu.internals.states.delete("nested-child");
|
|
163
|
+
parentMenu._nestedMenu = null;
|
|
164
|
+
}
|
|
165
|
+
this.state = "closing";
|
|
166
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "false";
|
|
167
|
+
if (this._isZeroAnimationDuration()) this._handleClosing();
|
|
168
|
+
}
|
|
169
|
+
_isZeroAnimationDuration() {
|
|
170
|
+
return isZeroAnimationDuration(this, "--sbb-menu-animation-duration");
|
|
171
|
+
}
|
|
172
|
+
_handleOpening() {
|
|
173
|
+
this.state = "opened";
|
|
174
|
+
if (!this._isNested()) this._inertController.activate();
|
|
175
|
+
else this._updateNestedInert();
|
|
176
|
+
this._escapableOverlayController.connect();
|
|
177
|
+
this._focusTrapController.focusInitialElement();
|
|
178
|
+
this._focusTrapController.enabled = true;
|
|
179
|
+
this._attachWindowEvents();
|
|
180
|
+
this.dispatchOpenEvent();
|
|
181
|
+
}
|
|
182
|
+
_handleClosing() {
|
|
183
|
+
this.state = "closed";
|
|
184
|
+
this.internals.states.delete("skip-animation");
|
|
185
|
+
this.internals.states.delete("close-all");
|
|
186
|
+
this.hidePopover?.();
|
|
187
|
+
this._menu?.firstElementChild?.scrollTo(0, 0);
|
|
188
|
+
if (!this._isNested()) this._inertController.deactivate();
|
|
189
|
+
else this._updateNestedInert();
|
|
190
|
+
this._triggerElement?.focus({ preventScroll: ["sbb-header-button", "sbb-header-link"].includes(this._triggerElement.localName) });
|
|
191
|
+
this._escapableOverlayController.disconnect();
|
|
192
|
+
this.dispatchCloseEvent();
|
|
193
|
+
this._windowEventsController?.abort();
|
|
194
|
+
this._focusTrapController.enabled = false;
|
|
195
|
+
this._scrollHandler.enableScroll();
|
|
196
|
+
}
|
|
197
|
+
_handleKeyDown(evt) {
|
|
198
|
+
if (!isArrowKeyOrPageKeysPressed(evt)) return;
|
|
199
|
+
evt.preventDefault();
|
|
200
|
+
const enabledActions = Array.from(this.querySelectorAll("sbb-menu-button, sbb-menu-link")).concat(this.shadowRoot.querySelector("sbb-menu-button")).filter((el) => (!el.disabled || el.disabledInteractive) && interactivityChecker.isVisible(el));
|
|
201
|
+
const current = enabledActions.findIndex((e) => e === evt.target);
|
|
202
|
+
let nextIndex;
|
|
203
|
+
switch (evt.key) {
|
|
204
|
+
case "ArrowUp":
|
|
205
|
+
case "ArrowDown":
|
|
206
|
+
nextIndex = getNextElementIndex(evt, current, enabledActions.length);
|
|
207
|
+
break;
|
|
208
|
+
case "ArrowLeft":
|
|
209
|
+
if (this._isNested()) this.close();
|
|
210
|
+
break;
|
|
211
|
+
case "ArrowRight":
|
|
212
|
+
if (evt.target.matches(":is(:state(sbb-menu-trigger),[state--sbb-menu-trigger])")) evt.target.click();
|
|
213
|
+
break;
|
|
214
|
+
case "PageUp":
|
|
215
|
+
case "Home":
|
|
216
|
+
nextIndex = 0;
|
|
217
|
+
break;
|
|
218
|
+
case "End":
|
|
219
|
+
case "PageDown":
|
|
220
|
+
nextIndex = enabledActions.length - 1;
|
|
221
|
+
break;
|
|
222
|
+
}
|
|
223
|
+
if (nextIndex !== void 0) enabledActions[nextIndex].focus();
|
|
224
|
+
}
|
|
225
|
+
createRenderRoot() {
|
|
226
|
+
const renderRoot = super.createRenderRoot();
|
|
227
|
+
this.shadowRoot?.addEventListener("slotchange", () => this._syncNegative(), { capture: true });
|
|
228
|
+
return renderRoot;
|
|
229
|
+
}
|
|
230
|
+
connectedCallback() {
|
|
231
|
+
this.popover = "manual";
|
|
232
|
+
super.connectedCallback();
|
|
233
|
+
if (this.hasUpdated) this._configureTrigger();
|
|
234
|
+
}
|
|
235
|
+
disconnectedCallback() {
|
|
236
|
+
super.disconnectedCallback();
|
|
237
|
+
this._triggerElement = null;
|
|
238
|
+
this._triggerAbortController?.abort();
|
|
239
|
+
this._windowEventsController?.abort();
|
|
240
|
+
this._scrollHandler.enableScroll();
|
|
241
|
+
}
|
|
242
|
+
requestUpdate(name, oldValue, options) {
|
|
243
|
+
super.requestUpdate(name, oldValue, options);
|
|
244
|
+
if (!isServer && (!name || name === "trigger") && this.hasUpdated) this._configureTrigger();
|
|
245
|
+
}
|
|
246
|
+
_configureTrigger() {
|
|
247
|
+
if (this.trigger === this._triggerElement) return;
|
|
248
|
+
this._triggerAbortController?.abort();
|
|
249
|
+
removeAriaOverlayTriggerProperties(this._triggerElement);
|
|
250
|
+
this._triggerElement = this.trigger;
|
|
251
|
+
if (!this._triggerElement) return;
|
|
252
|
+
setAriaOverlayTriggerProperties(this, this._triggerElement, "menu", this.state);
|
|
253
|
+
this._triggerAbortController = new AbortController();
|
|
254
|
+
this._triggerElement.addEventListener("click", () => this.open(), { signal: this._triggerAbortController.signal });
|
|
255
|
+
this.toggleState("nested", ["sbb-menu-button", "sbb-menu-link"].includes(this._triggerElement.localName));
|
|
256
|
+
ɵstateController(this._triggerElement).add("sbb-menu-trigger");
|
|
257
|
+
}
|
|
258
|
+
_attachWindowEvents() {
|
|
259
|
+
this._windowEventsController = new AbortController();
|
|
260
|
+
document.addEventListener("scroll", () => this._setMenuPosition(), {
|
|
261
|
+
passive: true,
|
|
262
|
+
signal: this._windowEventsController.signal,
|
|
263
|
+
capture: true
|
|
264
|
+
});
|
|
265
|
+
window.addEventListener("resize", () => this._setMenuPosition(), {
|
|
266
|
+
passive: true,
|
|
267
|
+
signal: this._windowEventsController.signal
|
|
268
|
+
});
|
|
269
|
+
if (!this._isNested()) {
|
|
270
|
+
window.addEventListener("pointerdown", this._pointerDownListener, { signal: this._windowEventsController.signal });
|
|
271
|
+
window.addEventListener("pointerup", this._closeOnBackdropClick, { signal: this._windowEventsController.signal });
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
_interactiveElementClick(event) {
|
|
275
|
+
const target = event.target;
|
|
276
|
+
if (INTERACTIVE_ELEMENTS.includes(target.nodeName) && !target.hasAttribute("disabled") && !target.matches(":is(:state(sbb-menu-trigger),[state--sbb-menu-trigger])") && target.id !== "sbb-menu__back-button") this.closeAll();
|
|
277
|
+
}
|
|
278
|
+
/** Converts the linked list into an array of SbbMenuElement. */
|
|
279
|
+
_nestedMenus() {
|
|
280
|
+
const menus = [];
|
|
281
|
+
let current = this._nestedMenu;
|
|
282
|
+
while (current) {
|
|
283
|
+
menus.push(current);
|
|
284
|
+
current = current._nestedMenu;
|
|
285
|
+
}
|
|
286
|
+
return menus;
|
|
287
|
+
}
|
|
288
|
+
_parentMenu() {
|
|
289
|
+
return this._triggerElement?.closest("sbb-menu") ?? null;
|
|
290
|
+
}
|
|
291
|
+
/** The outermost menu. */
|
|
292
|
+
_mainMenu() {
|
|
293
|
+
return this._isNested() ? this._parentMenu()?._mainMenu() ?? this : this;
|
|
294
|
+
}
|
|
295
|
+
_isNested() {
|
|
296
|
+
return !!this._parentMenu();
|
|
297
|
+
}
|
|
298
|
+
_updateNestedInert() {
|
|
299
|
+
this._inertController.restoreAllExempted();
|
|
300
|
+
this._mainMenu()._nestedMenus().forEach((menu) => this._inertController.exempt(menu));
|
|
301
|
+
}
|
|
302
|
+
_handleMouseOver(event) {
|
|
303
|
+
const element = event.target;
|
|
304
|
+
const isMobile = this._isMobile();
|
|
305
|
+
if (!isMobile && this._nestedMenu && !element.classList.contains("sbb-menu__content") && !(element.ariaExpanded === "true")) this._nestedMenu.close();
|
|
306
|
+
if (element.matches(":is(:state(sbb-menu-trigger),[state--sbb-menu-trigger])") && !isMobile) element.click();
|
|
307
|
+
}
|
|
308
|
+
_onMenuAnimationEnd(event) {
|
|
309
|
+
if ((event.animationName === "open" || event.animationName === "open-sideways") && this.state === "opening") this._handleOpening();
|
|
310
|
+
else if ((event.animationName === "close" || event.animationName === "close-sideways") && this.state === "closing") this._handleClosing();
|
|
311
|
+
}
|
|
312
|
+
_setMenuPosition() {
|
|
313
|
+
if (this._isMobile() || !this._menu || !this._triggerElement || this.state === "closing") return;
|
|
314
|
+
const menuPosition = !this._isNested() ? getElementPosition(this.shadowRoot.querySelector(".sbb-menu__content"), this._triggerElement, this.shadowRoot.querySelector(".sbb-menu__container"), { verticalOffset: MENU_OFFSET }) : getElementPositionHorizontal(this.shadowRoot.querySelector(".sbb-menu__content"), this._triggerElement, this.shadowRoot.querySelector(".sbb-menu__container"), {
|
|
315
|
+
horizontalOffset: MENU_OFFSET,
|
|
316
|
+
verticalOffset: NESTED_MENU_OFFSET,
|
|
317
|
+
contentSelector: ".sbb-menu__content"
|
|
318
|
+
});
|
|
319
|
+
this.style.setProperty("--sbb-menu-position-x", `${menuPosition.left}px`);
|
|
320
|
+
this.style.setProperty("--sbb-menu-position-y", `${menuPosition.top}px`);
|
|
321
|
+
this.style.setProperty("--sbb-menu-max-height", menuPosition.maxHeight);
|
|
322
|
+
}
|
|
323
|
+
_syncNegative() {
|
|
324
|
+
this.querySelectorAll(":is(:state(sbb-link),[state--sbb-link]), :is(:state(sbb-button),[state--sbb-button])")?.forEach((el) => {
|
|
325
|
+
customElements.upgrade(el);
|
|
326
|
+
el.negative = !this._darkModeController.matches();
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
_isMobile() {
|
|
330
|
+
return this._mediaMatcher.matches(this._mobileBreakpoint) ?? true;
|
|
331
|
+
}
|
|
332
|
+
render() {
|
|
333
|
+
return html`
|
|
334
|
+
<div class="sbb-menu__container">
|
|
335
|
+
<div
|
|
336
|
+
@animationend=${this._onMenuAnimationEnd}
|
|
337
|
+
@mouseover=${(e) => this._handleMouseOver(e)}
|
|
338
|
+
class="sbb-menu"
|
|
339
|
+
${ref((el) => this._menu = el)}
|
|
340
|
+
>
|
|
341
|
+
<div
|
|
342
|
+
@click=${(event) => this._interactiveElementClick(event)}
|
|
343
|
+
@scroll=${(e) => forwardEvent(e, document)}
|
|
344
|
+
class="sbb-menu__content"
|
|
345
|
+
>
|
|
346
|
+
<slot></slot>
|
|
347
|
+
<sbb-divider></sbb-divider>
|
|
348
|
+
<sbb-menu-button
|
|
349
|
+
id="sbb-menu__back-button"
|
|
350
|
+
@click=${() => this.close()}
|
|
351
|
+
icon-name="chevron-small-left-small"
|
|
352
|
+
>
|
|
353
|
+
${i18nGoBack[this._language.current]}
|
|
354
|
+
</sbb-menu-button>
|
|
355
|
+
</div>
|
|
356
|
+
</div>
|
|
357
|
+
</div>
|
|
358
|
+
`;
|
|
359
|
+
}
|
|
360
|
+
};
|
|
361
|
+
})();
|
|
362
|
+
//#endregion
|
|
363
|
+
export { SbbMenuElement as t };
|
|
364
|
+
|
|
365
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"menu.component-BM7hhOb4.js","names":[],"sources":["../../../src/elements/menu/menu/menu.scss?inline","../../../src/elements/menu/menu/menu.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  // We use this rule to make the inner container element to appear as if it were a\n  // direct child of the host's parent element. This is useful because the host\n  // should be ignored when using CSS grid or similar layout techniques.\n  display: contents;\n\n  --sbb-menu-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n  --_sbb-menu-inset: 0 auto auto 0;\n\n  @include sbb.scrollbar-variables($negative: true);\n\n  @include sbb.mq($from: large) {\n    --sbb-menu-back-button-display: none;\n  }\n}\n\n:host(:is(:state(state-opened), :state(state-opening))) {\n  --sbb-menu-visibility: visible;\n  --sbb-menu-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 20%, transparent);\n\n  @include sbb.mq($from: large) {\n    --sbb-menu-backdrop-color: transparent;\n  }\n}\n\n:host(:not(:state(nested))) {\n  --sbb-menu-back-button-display: none;\n}\n\n:host(:not(:state(state-closed))) {\n  --_sbb-menu-inset: 0;\n}\n\n:host(:state(dark)) {\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);\n\n  // We have to ensure that the scrollbar is visible in dark mode with non-dark mode values.\n  --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);\n  --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);\n}\n\n@include sbb.mq($to: large) {\n  :host(:state(skip-animation)) {\n    --sbb-menu-animation-duration: 0ms;\n  }\n\n  :host(:state(nested-child)) {\n    --sbb-menu-transform-x: -100%;\n  }\n\n  :host(:state(nested):is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n    --sbb-menu-open-animation-name: open-sideways;\n  }\n\n  :host(:state(state-closing):state(nested):not(:state(close-all))) {\n    --sbb-menu-close-animation-name: close-sideways;\n  }\n}\n\n::slotted(:not(sbb-menu-button, sbb-menu-link, sbb-divider)) {\n  display: block;\n  padding-inline: var(--sbb-spacing-fixed-5x);\n}\n\nsbb-divider,\n::slotted(sbb-divider) {\n  --sbb-divider-color: var(--sbb-background-color-4-inverted);\n\n  margin-block: var(--sbb-spacing-fixed-2x);\n}\n\nsbb-divider,\n#sbb-menu__back-button {\n  display: var(--sbb-menu-back-button-display, block);\n}\n\n.sbb-menu__container {\n  position: fixed;\n  pointer-events: none;\n  inset: var(--_sbb-menu-inset);\n  height: var(--sbb-menu-container-height);\n  z-index: var(--sbb-menu-z-index, var(--sbb-overlay-default-z-index));\n\n  // Menu backdrop (only visible on mobile)\n  &::before {\n    content: '';\n    visibility: var(--sbb-menu-visibility, hidden);\n    pointer-events: all;\n    position: fixed;\n    inset: var(--_sbb-menu-inset);\n    height: var(--sbb-menu-container-height);\n    background-color: var(--sbb-menu-backdrop-color, transparent);\n    transition: {\n      duration: var(--sbb-menu-animation-duration);\n      timing-function: var(--sbb-menu-animation-easing);\n      property: background-color, visibility;\n    }\n\n    // Hide the backdrop when in nested state\n    :host(:state(nested)) & {\n      display: none;\n    }\n  }\n}\n\n.sbb-menu {\n  display: none;\n  opacity: 0;\n  pointer-events: none;\n  max-width: var(--sbb-menu-max-width);\n  min-width: var(--sbb-menu-min-width);\n  text-align: start;\n  position: absolute;\n  inset-inline-start: 0;\n  inset-block-start: unset;\n  inset-block-end: 0;\n  inset-inline-end: unset;\n  color: var(--sbb-menu-color);\n  border: none;\n  border-radius: var(--sbb-menu-border-radius) var(--sbb-menu-border-radius) 0 0;\n  background-color: var(--sbb-menu-background-color);\n  padding: 0;\n  overflow: hidden;\n  translate: var(--sbb-menu-transform-x, 0) 0;\n\n  // Used when navigating back from nested menu in mobile view\n  transition: translate var(--sbb-menu-animation-duration);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n    opacity: 1;\n    pointer-events: all;\n\n    animation: {\n      name: var(--sbb-menu-open-animation-name, open);\n      duration: var(--sbb-menu-animation-duration);\n      timing-function: var(--sbb-menu-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation-name: var(--sbb-menu-close-animation-name, close);\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n\n  @include sbb.mq($from: large) {\n    top: 0;\n    bottom: unset;\n    left: 0;\n    right: unset;\n    max-height: fit-content;\n    border-radius: var(--sbb-menu-border-radius);\n\n    :host(:not(:state(state-closed))) & {\n      top: var(--sbb-menu-position-y, 0);\n      left: var(--sbb-menu-position-x, 0);\n      max-height: var(--sbb-menu-max-height);\n      min-height: var(--sbb-menu-min-height);\n    }\n  }\n}\n\n.sbb-menu__content {\n  @include sbb.scrollbar-rules;\n\n  max-height: var(--sbb-menu-max-height);\n  padding-block: var(--sbb-spacing-fixed-1x);\n  overflow: auto;\n  outline: none;\n\n  // Margin bottom in mobile variant\n  &::after {\n    content: '';\n    display: block;\n    height: var(--sbb-spacing-fixed-8x);\n  }\n\n  @include sbb.mq($from: large) {\n    max-height: fit-content;\n\n    :host(:not(:state(state-closed))) & {\n      max-height: var(--sbb-menu-max-height);\n      min-height: var(--sbb-menu-min-height);\n    }\n\n    &::after {\n      display: none;\n    }\n  }\n}\n\n::slotted(:is(:state(sbb-link), :state(sbb-button))) {\n  // As the background turns white, we need to ensure that buttons and links are displayed in positive.\n  color-scheme: only light;\n}\n\n@keyframes open {\n  from {\n    opacity: 0;\n    translate: 0 var(--sbb-menu-transform-y, 100%);\n  }\n\n  to {\n    opacity: 1;\n    translate: 0 0;\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n    translate: 0 0;\n  }\n\n  to {\n    opacity: 0;\n    translate: 0 var(--sbb-menu-transform-y, 100%);\n  }\n}\n\n@keyframes open-sideways {\n  from {\n    translate: 100% 0;\n  }\n\n  to {\n    translate: 0 0;\n  }\n}\n\n@keyframes close-sideways {\n  from {\n    translate: 0 0;\n  }\n\n  to {\n    translate: 100% 0;\n  }\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport {\n  boxSizingStyles,\n  forwardEvent,\n  getElementPosition,\n  getElementPositionHorizontal,\n  getNextElementIndex,\n  i18nGoBack,\n  idReference,\n  interactivityChecker,\n  isArrowKeyOrPageKeysPressed,\n  isEventOnElement,\n  isZeroAnimationDuration,\n  removeAriaOverlayTriggerProperties,\n  SbbDarkModeController,\n  type SbbElementType,\n  SbbEscapableOverlayController,\n  SbbFocusTrapController,\n  SbbInertController,\n  SbbLanguageController,\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointSmallAndBelow,\n  type SbbNegativeMixinType,\n  SbbOpenCloseBaseElement,\n  SbbScrollHandler,\n  setAriaOverlayTriggerProperties,\n  ɵstateController,\n} from '../../core.ts';\nimport { SbbDividerElement } from '../../divider.pure.ts';\nimport { SbbMenuButtonElement } from '../menu-button/menu-button.component.ts';\nimport type { SbbMenuLinkElement } from '../menu-link/menu-link.component.ts';\n\nimport style from './menu.scss?inline';\n\nconst MENU_OFFSET = 8;\nconst NESTED_MENU_OFFSET = -4;\nconst INTERACTIVE_ELEMENTS = [\n  'A',\n  'BUTTON',\n  'SBB-BUTTON',\n  'SBB-BUTTON-LINK',\n  'SBB-LINK',\n  'SBB-BLOCK-LINK',\n  'SBB-LINK-BUTTON',\n  'SBB-BLOCK-LINK-BUTTON',\n  'SBB-MENU-BUTTON',\n  'SBB-MENU-LINK',\n];\n\n/**\n * It displays a contextual menu with one or more action element.\n *\n * @slot - Use the unnamed slot to add `sbb-menu-button`/`sbb-menu-link` or other elements to the menu.\n * @cssprop [--sbb-menu-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 SbbMenuElement extends SbbOpenCloseBaseElement {\n  public static override readonly elementName: string = 'sbb-menu';\n  public static override elementDependencies: SbbElementType[] = [\n    SbbDividerElement,\n    SbbMenuButtonElement,\n  ];\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static override readonly role = 'menu';\n\n  /**\n   * The element that will trigger the menu overlay.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  private _menu!: HTMLDivElement;\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _windowEventsController!: AbortController;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _scrollHandler = new SbbScrollHandler();\n  private _inertController = new SbbInertController(this);\n  private _mobileBreakpoint = SbbMediaQueryBreakpointSmallAndBelow;\n  private _mediaMatcher = new SbbMediaMatcherController(this, {\n    [this._mobileBreakpoint]: (matches) => {\n      if (matches && (this.state === 'opening' || this.state === 'opened')) {\n        this._scrollHandler.disableScroll();\n      } else {\n        this._scrollHandler.enableScroll();\n      }\n    },\n  });\n  private _darkModeController = new SbbDarkModeController(this, () => this._syncNegative());\n  private _language = new SbbLanguageController(this);\n  private _nestedMenu: SbbMenuElement | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._configureTrigger();\n  }\n\n  public override escapeStrategy(): void {\n    this.closeAll();\n  }\n\n  /**\n   * Opens the menu on trigger click.\n   */\n  public open(): void {\n    if (\n      this.state === 'closing' ||\n      this.state === 'opened' ||\n      !this._menu ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    if (this._isNested()) {\n      const parentMenu = this._parentMenu()!;\n      parentMenu.internals.states.add('nested-child');\n\n      // In case we change between arrow key navigation and mouse navigation, it can be that another\n      // nested parent menu is still open. We have to close it.\n      if (parentMenu._nestedMenu !== this) {\n        parentMenu._nestedMenu?.close();\n      }\n      parentMenu._nestedMenu = this;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._setMenuPosition();\n\n    if (this._triggerElement) {\n      this._triggerElement.ariaExpanded = 'true';\n    }\n\n    // From zero to large, disable scroll\n    if (this._isMobile()) {\n      this._scrollHandler.disableScroll();\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  /** Closes the menu and all its nested menus. */\n  public close(): void {\n    this._close();\n  }\n\n  /** Closes the menu and all related menus (nested and parent menus). */\n  public closeAll(): void {\n    this._mainMenu()._close(true);\n  }\n\n  /** @param [closeAll='false'] - If true, it ensures animations are correct by toggling some states when closing all related menus at once. */\n  private _close(closeAll = false): void {\n    if ((this.state === 'opening' && !this._isNested()) || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    // Close nested menus first\n    this._nestedMenu?._close(closeAll);\n\n    if (this._isNested()) {\n      const parentMenu = this._parentMenu()!;\n      if (closeAll) {\n        this.internals.states.add('close-all');\n        parentMenu.internals.states.add('skip-animation');\n      } else {\n        this.internals.states.delete('close-all');\n        parentMenu.internals.states.delete('skip-animation');\n      }\n      parentMenu.internals.states.delete('nested-child');\n      parentMenu._nestedMenu = null;\n    }\n\n    this.state = 'closing';\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-menu-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n\n    if (!this._isNested()) {\n      this._inertController.activate();\n    } else {\n      this._updateNestedInert();\n    }\n    this._escapableOverlayController.connect();\n    this._focusTrapController.focusInitialElement();\n    this._focusTrapController.enabled = true;\n    this._attachWindowEvents();\n    this.dispatchOpenEvent();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.internals.states.delete('skip-animation');\n    this.internals.states.delete('close-all');\n    this.hidePopover?.();\n\n    this._menu?.firstElementChild?.scrollTo(0, 0);\n    if (!this._isNested()) {\n      this._inertController.deactivate();\n    } else {\n      this._updateNestedInert();\n    }\n    // Manually focus last focused element\n    this._triggerElement?.focus({\n      // When inside the sbb-header, we prevent the scroll to avoid the snapping to the top of the page\n      preventScroll: ['sbb-header-button', 'sbb-header-link'].includes(\n        this._triggerElement.localName,\n      ),\n    });\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n    this._windowEventsController?.abort();\n    this._focusTrapController.enabled = false;\n\n    // Starting from breakpoint large, enable scroll\n    this._scrollHandler.enableScroll();\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    if (!isArrowKeyOrPageKeysPressed(evt)) {\n      return;\n    }\n    evt.preventDefault();\n\n    const enabledActions: Element[] = Array.from(\n      this.querySelectorAll<SbbMenuButtonElement | SbbMenuLinkElement>(\n        'sbb-menu-button, sbb-menu-link',\n      ),\n    )\n      .concat(this.shadowRoot!.querySelector('sbb-menu-button')!)\n      .filter(\n        (el) => (!el.disabled || el.disabledInteractive) && interactivityChecker.isVisible(el),\n      );\n    const current = enabledActions.findIndex((e: Element) => e === evt.target);\n\n    let nextIndex;\n    switch (evt.key) {\n      case 'ArrowUp':\n      case 'ArrowDown':\n        nextIndex = getNextElementIndex(evt, current, enabledActions.length);\n        break;\n\n      case 'ArrowLeft':\n        if (this._isNested()) {\n          this.close();\n        }\n        break;\n\n      case 'ArrowRight':\n        if ((evt.target as HTMLElement).matches(':state(sbb-menu-trigger)')) {\n          (evt.target as HTMLElement).click();\n        }\n        break;\n\n      case 'PageUp':\n      case 'Home':\n        nextIndex = 0;\n        break;\n\n      case 'End':\n      case 'PageDown':\n        nextIndex = enabledActions.length - 1;\n        break;\n    }\n\n    if (nextIndex !== undefined) {\n      (enabledActions[nextIndex] as HTMLElement).focus();\n    }\n  }\n\n  // Removes trigger click listener on trigger change.\n  protected override createRenderRoot(): HTMLElement | DocumentFragment {\n    const renderRoot = super.createRenderRoot();\n    // Due to the fact that menu can both be a list and just a container, we need to check its\n    // state before the SbbNamedSlotListMixin handles the slotchange event, in order to avoid\n    // it interpreting the non list case as a list.\n    this.shadowRoot?.addEventListener('slotchange', () => this._syncNegative(), { capture: true });\n    return renderRoot;\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\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    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  // 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    // Consider the menu as nested if the trigger is a menu button or menu link.\n    this.toggleState(\n      'nested',\n      ['sbb-menu-button', 'sbb-menu-link'].includes(this._triggerElement.localName),\n    );\n    ɵstateController(this._triggerElement).add('sbb-menu-trigger');\n  }\n\n  private _attachWindowEvents(): void {\n    this._windowEventsController = new AbortController();\n    document.addEventListener('scroll', () => this._setMenuPosition(), {\n      passive: true,\n      signal: this._windowEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setMenuPosition(), {\n      passive: true,\n      signal: this._windowEventsController.signal,\n    });\n\n    // Only the outermost menu needs to listen to the backdrop clicks\n    if (!this._isNested()) {\n      // Close menu on backdrop click\n      window.addEventListener('pointerdown', this._pointerDownListener, {\n        signal: this._windowEventsController.signal,\n      });\n      window.addEventListener('pointerup', this._closeOnBackdropClick, {\n        signal: this._windowEventsController.signal,\n      });\n    }\n  }\n\n  // Close menu at any click on an interactive element inside the <sbb-menu> that bubbles to the container.\n  private _interactiveElementClick(event: Event): void {\n    const target = event.target as HTMLElement;\n\n    if (\n      INTERACTIVE_ELEMENTS.includes(target.nodeName) &&\n      !target.hasAttribute('disabled') &&\n      !target.matches(':state(sbb-menu-trigger)') &&\n      target.id !== 'sbb-menu__back-button'\n    ) {\n      this.closeAll();\n    }\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    const menu = (event.target as HTMLElement).closest('sbb-menu');\n\n    // The pointer down is on the menu or one of its nested menus.\n    this._isPointerDownEventOnMenu =\n      isEventOnElement(this._menu, event) || this._nestedMenus().some((el) => menu === el);\n  };\n\n  // Close menu on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    const target = event.target as HTMLElement;\n\n    // The backdrop is only listened on the main menu (outermost menu).\n    // To close.\n    // - The pointer down and up need to be outside the menu.\n    // - The target should be not on a nested menu\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._menu, event) &&\n      !this._nestedMenus().some((el) => el === target)\n    ) {\n      this.closeAll();\n    }\n  };\n\n  /** Converts the linked list into an array of SbbMenuElement. */\n  private _nestedMenus(): SbbMenuElement[] {\n    const menus: SbbMenuElement[] = [];\n    let current = this._nestedMenu;\n\n    while (current) {\n      menus.push(current);\n      current = current._nestedMenu;\n    }\n\n    return menus;\n  }\n\n  private _parentMenu(): SbbMenuElement | null {\n    return this._triggerElement?.closest('sbb-menu') ?? null;\n  }\n\n  /** The outermost menu. */\n  private _mainMenu(): SbbMenuElement {\n    return this._isNested() ? (this._parentMenu()?._mainMenu() ?? this) : this;\n  }\n\n  private _isNested(): boolean {\n    return !!this._parentMenu();\n  }\n\n  private _updateNestedInert(): void {\n    this._inertController.restoreAllExempted();\n    this._mainMenu()\n      ._nestedMenus()\n      .forEach((menu) => this._inertController.exempt(menu));\n  }\n\n  // Check if nested menu should be closed.\n  private _handleMouseOver(event: MouseEvent): void {\n    const element = event.target as HTMLElement;\n    const isMobile = this._isMobile();\n\n    // All nested menus should close in desktop mode if the cursor landed on\n    // anything other than the container, the container's scrollbar or the trigger itself\n    if (\n      !isMobile &&\n      this._nestedMenu &&\n      !element.classList.contains('sbb-menu__content') &&\n      !(element.ariaExpanded === 'true')\n    ) {\n      this._nestedMenu.close();\n    }\n\n    if (element.matches(':state(sbb-menu-trigger)') && !isMobile) {\n      element.click();\n    }\n  }\n\n  // Set menu position (x, y) to '0' once the menu is closed and the transition ended to prevent the\n  // viewport from overflowing. And set the focus to the first focusable element once the menu is open.\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 _onMenuAnimationEnd(event: AnimationEvent): void {\n    if (\n      (event.animationName === 'open' || event.animationName === 'open-sideways') &&\n      this.state === 'opening'\n    ) {\n      this._handleOpening();\n    } else if (\n      (event.animationName === 'close' || event.animationName === 'close-sideways') &&\n      this.state === 'closing'\n    ) {\n      this._handleClosing();\n    }\n  }\n\n  // Set menu position and max height if the breakpoint is large-ultra.\n  private _setMenuPosition(): void {\n    // Starting from breakpoint large\n    if (this._isMobile() || !this._menu || !this._triggerElement || this.state === 'closing') {\n      return;\n    }\n\n    const menuPosition = !this._isNested()\n      ? getElementPosition(\n          this.shadowRoot!.querySelector('.sbb-menu__content')!,\n          this._triggerElement,\n          this.shadowRoot!.querySelector('.sbb-menu__container')!,\n          {\n            verticalOffset: MENU_OFFSET,\n          },\n        )\n      : getElementPositionHorizontal(\n          this.shadowRoot!.querySelector('.sbb-menu__content')!,\n          this._triggerElement,\n          this.shadowRoot!.querySelector('.sbb-menu__container')!,\n          {\n            horizontalOffset: MENU_OFFSET,\n            verticalOffset: NESTED_MENU_OFFSET,\n            contentSelector: '.sbb-menu__content',\n          },\n        );\n\n    this.style.setProperty('--sbb-menu-position-x', `${menuPosition.left}px`);\n    this.style.setProperty('--sbb-menu-position-y', `${menuPosition.top}px`);\n    this.style.setProperty('--sbb-menu-max-height', menuPosition.maxHeight);\n  }\n\n  private _syncNegative(): void {\n    // Links and buttons are the most expected contents which have a negative property\n    this.querySelectorAll(':state(sbb-link), :state(sbb-button)')?.forEach((el: Element) => {\n      customElements.upgrade(el);\n      (el as Element & SbbNegativeMixinType).negative = !this._darkModeController.matches();\n    });\n  }\n\n  private _isMobile(): boolean {\n    return this._mediaMatcher.matches(this._mobileBreakpoint) ?? true;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-menu__container\">\n        <div\n          @animationend=${this._onMenuAnimationEnd}\n          @mouseover=${(e: MouseEvent) => this._handleMouseOver(e)}\n          class=\"sbb-menu\"\n          ${ref((el?: Element) => (this._menu = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this._interactiveElementClick(event)}\n            @scroll=${(e: Event) => forwardEvent(e, document)}\n            class=\"sbb-menu__content\"\n          >\n            <slot></slot>\n            <sbb-divider></sbb-divider>\n            <sbb-menu-button\n              id=\"sbb-menu__back-button\"\n              @click=${() => this.close()}\n              icon-name=\"chevron-small-left-small\"\n            >\n              ${i18nGoBack[this._language.current]}\n            </sbb-menu-button>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-menu': SbbMenuElement;\n  }\n}\n"],"mappings":"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"}
|
package/development/menu.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { t as SbbMenuActionCommonElementMixin } from "./menu-action-common-
|
|
1
|
+
import { t as SbbMenuActionCommonElementMixin } from "./menu-action-common-CEnwq60Z.js";
|
|
2
2
|
import { SbbMenuButtonElement } from "./menu/menu-button/menu-button.component.js";
|
|
3
3
|
import { SbbMenuLinkElement } from "./menu/menu-link/menu-link.component.js";
|
|
4
|
-
import { t as SbbMenuElement } from "./menu.component-
|
|
4
|
+
import { t as SbbMenuElement } from "./menu.component-BM7hhOb4.js";
|
|
5
5
|
import "./menu.pure.js";
|
|
6
6
|
//#region src/elements/menu.ts
|
|
7
7
|
/** @entrypoint */
|
package/development/menu.pure.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { t as SbbMenuActionCommonElementMixin } from "./menu-action-common-
|
|
1
|
+
import { t as SbbMenuActionCommonElementMixin } from "./menu-action-common-CEnwq60Z.js";
|
|
2
2
|
import { SbbMenuButtonElement } from "./menu/menu-button/menu-button.component.js";
|
|
3
3
|
import { SbbMenuLinkElement } from "./menu/menu-link/menu-link.component.js";
|
|
4
|
-
import { t as SbbMenuElement } from "./menu.component-
|
|
4
|
+
import { t as SbbMenuElement } from "./menu.component-BM7hhOb4.js";
|
|
5
5
|
export { SbbMenuActionCommonElementMixin, SbbMenuButtonElement, SbbMenuElement, SbbMenuLinkElement };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"navigation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/navigation/navigation/navigation.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAQL,KAAK,cAAc,EAKnB,uBAAuB,EAIxB,MAAM,eAAe,CAAC;AAGvB,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uDAAuD,CAAC;;
|
|
1
|
+
{"version":3,"file":"navigation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/navigation/navigation/navigation.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAQL,KAAK,cAAc,EAKnB,uBAAuB,EAIxB,MAAM,eAAe,CAAC;AAGvB,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uDAAuD,CAAC;;AAMzG;;;;;;;GAOG;AACH,qBAAa,oBAAqB,SAAQ,yBAAgD;IACxF,gBAAgC,WAAW,EAAE,MAAM,CAAoB;IACvE,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAAiC;IAC7F,gBAAgC,IAAI,gBAAgB;IACpD,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD,wEAAwE;IACxE,SAEgB,uBAAuB,EAAE,MAAM,CAAM;IAErD,iDAAiD;IACxC,OAAO,CAAC,QAAQ,CAAC,wBAAwB,CAA4C;IAE9F,qDAAqD;IACrD,IAAW,uBAAuB,IAAI,2BAA2B,GAAG,IAAI,CAEvE;IAED,wCAAwC;IACxC,IAAW,WAAW,IAAI,WAAW,GAAG,IAAI,CAE3C;IAED,8CAA8C;IAC9C,IAAW,iBAAiB,IAAI,WAAW,GAAG,IAAI,CAEjD;IAED,OAAO,CAAC,WAAW,CAAkB;IACrC,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,2BAA2B,CAA2C;IAC9E,OAAO,CAAC,oBAAoB,CAAoC;IAChE,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,+BAA+B,CAAkB;IACzD,OAAO,CAAC,sBAAsB,CAA8C;IAC5E,OAAO,CAAC,yBAAyB,CAG9B;;IA2BH,4BAA4B;IACrB,IAAI,IAAI,IAAI;IAwBnB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,mBAAmB;IAO3B,6BAA6B;IACtB,KAAK,IAAI,IAAI;IAkBpB,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAiBtB,OAAO,CAAC,cAAc;IAatB,OAAO,CAAC,iBAAiB;IAsBzB,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,oBAAoB,CAS1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAEF,OAAO,CAAC,mBAAmB;IAkBX,iBAAiB,IAAI,IAAI;IAQzB,oBAAoB,IAAI,IAAI;IAO5B,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAK3D,MAAM,IAAI,cAAc;CAkC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,oBAAoB,CAAC;KACxC;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationElement } from "../../navigation.component-
|
|
1
|
+
import { t as SbbNavigationElement } from "../../navigation.component-DUy2QGHI.js";
|
|
2
2
|
export { SbbNavigationElement };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"navigation-section.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/navigation/navigation-section/navigation-section.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAInB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EASL,KAAK,cAAc,EAMnB,uBAAuB,EACvB,KAAK,oBAAoB,EAI1B,MAAM,eAAe,CAAC;;
|
|
1
|
+
{"version":3,"file":"navigation-section.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/navigation/navigation-section/navigation-section.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAInB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EASL,KAAK,cAAc,EAMnB,uBAAuB,EACvB,KAAK,oBAAoB,EAI1B,MAAM,eAAe,CAAC;;AAOvB;;;;GAIG;AACH,qBAAa,2BAA4B,SAAQ,gCAAgD;IAC/F,gBAAgC,WAAW,EAAE,MAAM,CAA4B;IAC/E,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAAiC;IAC7F,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF;;OAEG;IACH,SAEgB,YAAY,EAAE,MAAM,CAAM;IAE1C;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD;;OAEG;IACH,SAEgB,kBAAkB,EAAE,MAAM,CAAM;IAEhD;;OAEG;IACH,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD,kCAAkC;IAClC,cAAuB,KAAK,CAAC,KAAK,EAAE,oBAAoB,EAGvD;IACD,cAAuB,KAAK,IAAI,oBAAoB,CAEnD;IAED,OAAO,CAAC,qBAAqB,CAAC,CAAqC;IACnE,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,oBAAoB,CAAoC;IAChE,OAAO,CAAC,iBAAiB,CAA8B;IACvD,OAAO,CAAC,uBAAuB,CAM5B;;IAgCH;;OAEG;IACI,IAAI,IAAI,IAAI;IA0BnB,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAWtB,OAAO,CAAC,cAAc;IAatB,OAAO,CAAC,+BAA+B;IAIvC;;OAEG;IACI,KAAK,IAAI,IAAI;IAsBpB,OAAO,CAAC,iBAAiB;IAwBzB,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,WAAW;IAQnB,OAAO,CAAC,mBAAmB;IAa3B,OAAO,CAAC,6BAA6B,CASnC;IAEF,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,kBAAkB;IAOV,iBAAiB,IAAI,IAAI;IAQzB,oBAAoB,IAAI,IAAI;IAO5B,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAK3D,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,2BAA2B,CAAC;KACvD;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbNavigationSectionElement } from "../../navigation-section.component-
|
|
1
|
+
import { t as SbbNavigationSectionElement } from "../../navigation-section.component-6tqZADWM.js";
|
|
2
2
|
export { SbbNavigationSectionElement };
|