@sbb-esta/lyne-elements 1.5.0 → 1.6.0
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/alert/alert/alert.d.ts +22 -16
- package/alert/alert/alert.d.ts.map +1 -1
- package/alert/alert-group/alert-group.d.ts +1 -1
- package/alert/alert-group/alert-group.d.ts.map +1 -1
- package/alert/alert-group.js +31 -26
- package/alert/alert.js +45 -37
- package/clock/clock.d.ts.map +1 -1
- package/clock.js +14 -14
- package/core/testing/wait-for-event.d.ts +2 -0
- package/core/testing/wait-for-event.d.ts.map +1 -0
- package/core/testing.d.ts +1 -0
- package/core/testing.d.ts.map +1 -1
- package/core/testing.js +49 -36
- package/custom-elements.json +211 -51
- package/development/alert/alert/alert.d.ts +22 -16
- package/development/alert/alert/alert.d.ts.map +1 -1
- package/development/alert/alert-group/alert-group.d.ts +1 -1
- package/development/alert/alert-group/alert-group.d.ts.map +1 -1
- package/development/alert/alert-group.js +16 -11
- package/development/alert/alert.js +65 -24
- package/development/clock/clock.d.ts.map +1 -1
- package/development/clock.js +3 -2
- package/development/core/testing/wait-for-event.d.ts +2 -0
- package/development/core/testing/wait-for-event.d.ts.map +1 -0
- package/development/core/testing.d.ts +1 -0
- package/development/core/testing.d.ts.map +1 -1
- package/development/core/testing.js +17 -1
- package/development/icon/icon.d.ts +9 -1
- package/development/icon/icon.d.ts.map +1 -1
- package/development/icon.js +16 -2
- package/development/menu/menu/menu.d.ts.map +1 -1
- package/development/menu/menu.js +2 -1
- package/development/navigation/navigation/navigation.d.ts.map +1 -1
- package/development/navigation/navigation.js +2 -1
- package/development/notification/notification.d.ts +4 -4
- package/development/notification.js +1 -1
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay.js +35 -17
- package/development/toggle/toggle.js +1 -1
- package/icon/icon.d.ts +9 -1
- package/icon/icon.d.ts.map +1 -1
- package/icon.js +71 -62
- package/menu/menu/menu.d.ts.map +1 -1
- package/menu/menu.js +3 -3
- package/navigation/navigation/navigation.d.ts.map +1 -1
- package/navigation/navigation.js +4 -4
- package/notification/notification.d.ts +4 -4
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay.js +33 -33
- package/package.json +1 -1
- package/toggle/toggle.js +1 -1
package/development/overlay.js
CHANGED
|
@@ -73,6 +73,7 @@ const _SbbOverlayBaseElement = class _SbbOverlayBaseElement2 extends SbbNegative
|
|
|
73
73
|
this.focusHandler.disconnect();
|
|
74
74
|
this.removeInstanceFromGlobalCollection();
|
|
75
75
|
removeInertMechanism();
|
|
76
|
+
this.scrollHandler.enableScroll();
|
|
76
77
|
}
|
|
77
78
|
attachOpenOverlayEvents() {
|
|
78
79
|
this.openOverlayController = new AbortController();
|
|
@@ -170,8 +171,6 @@ const style = css`/**
|
|
|
170
171
|
);
|
|
171
172
|
--sbb-overlay-animation-easing: ease;
|
|
172
173
|
--sbb-overlay-pointer-events: none;
|
|
173
|
-
--sbb-overlay-content-transition: transform var(--sbb-overlay-animation-duration)
|
|
174
|
-
var(--sbb-overlay-animation-easing);
|
|
175
174
|
display: block;
|
|
176
175
|
position: fixed;
|
|
177
176
|
inset: var(--sbb-overlay-inset);
|
|
@@ -202,14 +201,23 @@ const style = css`/**
|
|
|
202
201
|
.sbb-overlay__container {
|
|
203
202
|
background-color: var(--sbb-overlay-background-color);
|
|
204
203
|
pointer-events: var(--sbb-overlay-pointer-events);
|
|
205
|
-
display:
|
|
204
|
+
display: none;
|
|
206
205
|
align-items: center;
|
|
207
206
|
position: fixed;
|
|
208
207
|
inset: var(--sbb-overlay-inset);
|
|
209
208
|
}
|
|
209
|
+
:host([data-state]:not([data-state=closed])) .sbb-overlay__container {
|
|
210
|
+
display: flex;
|
|
211
|
+
animation-name: open;
|
|
212
|
+
animation-duration: var(--sbb-overlay-animation-duration);
|
|
213
|
+
animation-timing-function: var(--sbb-overlay-animation-easing);
|
|
214
|
+
}
|
|
215
|
+
:host([data-state][data-state=closing]) .sbb-overlay__container {
|
|
216
|
+
pointer-events: none;
|
|
217
|
+
animation-name: close;
|
|
218
|
+
}
|
|
210
219
|
|
|
211
220
|
.sbb-overlay {
|
|
212
|
-
display: none;
|
|
213
221
|
position: absolute;
|
|
214
222
|
inset-inline: 0;
|
|
215
223
|
margin: auto;
|
|
@@ -220,14 +228,12 @@ const style = css`/**
|
|
|
220
228
|
color: var(--sbb-overlay-color);
|
|
221
229
|
}
|
|
222
230
|
:host([data-state]:not([data-state=closed])) .sbb-overlay {
|
|
223
|
-
|
|
224
|
-
animation-name: open;
|
|
231
|
+
animation-name: open-move-in;
|
|
225
232
|
animation-duration: var(--sbb-overlay-animation-duration);
|
|
226
|
-
animation-timing-function:
|
|
233
|
+
animation-timing-function: var(--sbb-overlay-animation-easing);
|
|
227
234
|
}
|
|
228
235
|
:host([data-state][data-state=closing]) .sbb-overlay {
|
|
229
|
-
|
|
230
|
-
animation-name: close;
|
|
236
|
+
animation-name: close-move-out;
|
|
231
237
|
}
|
|
232
238
|
|
|
233
239
|
.sbb-overlay__wrapper {
|
|
@@ -309,20 +315,32 @@ const style = css`/**
|
|
|
309
315
|
@keyframes open {
|
|
310
316
|
from {
|
|
311
317
|
opacity: 0;
|
|
312
|
-
transform: translateY(var(--sbb-spacing-fixed-4x));
|
|
313
318
|
}
|
|
314
319
|
to {
|
|
315
320
|
opacity: 1;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
@keyframes open-move-in {
|
|
324
|
+
from {
|
|
325
|
+
transform: translateY(var(--sbb-spacing-fixed-4x));
|
|
326
|
+
}
|
|
327
|
+
to {
|
|
316
328
|
transform: translateY(0%);
|
|
317
329
|
}
|
|
318
330
|
}
|
|
319
331
|
@keyframes close {
|
|
320
332
|
from {
|
|
321
333
|
opacity: 1;
|
|
322
|
-
transform: translateY(0%);
|
|
323
334
|
}
|
|
324
335
|
to {
|
|
325
336
|
opacity: 0;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
@keyframes close-move-out {
|
|
340
|
+
from {
|
|
341
|
+
transform: translateY(0%);
|
|
342
|
+
}
|
|
343
|
+
to {
|
|
326
344
|
transform: translateY(var(--sbb-spacing-fixed-4x));
|
|
327
345
|
}
|
|
328
346
|
}`;
|
|
@@ -429,11 +447,11 @@ let SbbOverlayElement = class extends SbbOverlayBaseElement {
|
|
|
429
447
|
></${unsafeStatic(TAG_NAME)}>
|
|
430
448
|
`;
|
|
431
449
|
return html`
|
|
432
|
-
<div
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
>
|
|
450
|
+
<div
|
|
451
|
+
class="sbb-overlay__container"
|
|
452
|
+
@animationend=${(event) => this.onOverlayAnimationEnd(event)}
|
|
453
|
+
>
|
|
454
|
+
<div class="sbb-overlay">
|
|
437
455
|
<div
|
|
438
456
|
@click=${(event) => this.closeOnSbbOverlayCloseClick(event)}
|
|
439
457
|
class="sbb-overlay__wrapper"
|
|
@@ -485,4 +503,4 @@ export {
|
|
|
485
503
|
SbbOverlayElement,
|
|
486
504
|
overlayRefs
|
|
487
505
|
};
|
|
488
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay.js","sources":["../../../src/elements/overlay/overlay-base-element.ts","../../../src/elements/overlay/overlay.ts"],"sourcesContent":["import { type PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbFocusHandler } from '../core/a11y.js';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbLanguageController } from '../core/controllers.js';\nimport { hostContext, SbbScrollHandler } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nDialog } from '../core/i18n.js';\nimport type { SbbOverlayCloseEventDetails } from '../core/interfaces.js';\nimport { SbbNegativeMixin } from '../core/mixins.js';\nimport { applyInertMechanism, removeInertMechanism } from '../core/overlay.js';\nimport type { SbbScreenReaderOnlyElement } from '../screen-reader-only.js';\n\n// A global collection of existing overlays.\nexport const overlayRefs: SbbOverlayBaseElement[] = [];\n\nexport abstract class SbbOverlayBaseElement extends SbbNegativeMixin(SbbOpenCloseBaseElement) {\n  /** This will be forwarded as aria-label to the relevant nested element to describe the purpose of the overlay. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  /** Emits whenever the component is closed. */\n  protected override didClose: EventEmitter<SbbOverlayCloseEventDetails> = new EventEmitter(\n    this,\n    SbbOverlayBaseElement.events.didClose,\n  );\n\n  // The last element which had focus before the component was opened.\n  protected lastFocusedElement?: HTMLElement;\n  protected overlayCloseElement?: HTMLElement;\n  protected overlayController!: AbortController;\n  protected openOverlayController!: AbortController;\n  protected focusHandler = new SbbFocusHandler();\n  protected scrollHandler = new SbbScrollHandler();\n  protected returnValue: any;\n  protected ariaLiveRefToggle = false;\n  protected ariaLiveRef!: SbbScreenReaderOnlyElement;\n  protected language = new SbbLanguageController(this);\n\n  protected abstract onOverlayAnimationEnd(event: AnimationEvent): void;\n  protected abstract setOverlayFocus(): void;\n  protected abstract closeAttribute: string;\n\n  /** Closes the component. */\n  public close(result?: any, target?: HTMLElement): any {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    this.returnValue = result;\n    this.overlayCloseElement = target;\n    const eventData: SbbOverlayCloseEventDetails = {\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    };\n\n    if (!this.willClose.emit(eventData)) {\n      return;\n    }\n    this.state = 'closing';\n    this.removeAriaLiveRefContent();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.overlayController?.abort();\n    this.overlayController = new AbortController();\n\n    if (this.state === 'opened') {\n      applyInertMechanism(this);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    this.ariaLiveRef =\n      this.shadowRoot!.querySelector<SbbScreenReaderOnlyElement>('sbb-screen-reader-only')!;\n\n    super.firstUpdated(changedProperties);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.overlayController?.abort();\n    this.openOverlayController?.abort();\n    this.focusHandler.disconnect();\n    this.removeInstanceFromGlobalCollection();\n    removeInertMechanism();\n  }\n\n  protected attachOpenOverlayEvents(): void {\n    this.openOverlayController = new AbortController();\n    // Remove overlay label as soon as it is not needed any more to prevent accessing it with browse mode.\n    window.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => {\n        this.removeAriaLiveRefContent();\n        this.onKeydownEvent(event);\n      },\n      {\n        signal: this.openOverlayController.signal,\n      },\n    );\n    window.addEventListener('click', () => this.removeAriaLiveRefContent(), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  protected onKeydownEvent(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    if (event.key === 'Escape') {\n      overlayRefs[overlayRefs.length - 1].close();\n      return;\n    }\n  }\n\n  protected removeInstanceFromGlobalCollection(): void {\n    overlayRefs.splice(overlayRefs.indexOf(this as SbbOverlayBaseElement), 1);\n  }\n\n  // Close the component on click of any element that has the `closeAttribute` attribute.\n  protected closeOnSbbOverlayCloseClick(event: Event): void {\n    const overlayCloseElement = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .find(\n        (target) => target.hasAttribute(this.closeAttribute) && !target.hasAttribute('disabled'),\n      );\n\n    if (!overlayCloseElement) {\n      return;\n    }\n\n    // Check if the target is a submission element within a form and return the form, if present\n    const closestForm =\n      overlayCloseElement.getAttribute('type') === 'submit'\n        ? (hostContext('form', overlayCloseElement) as HTMLFormElement)\n        : undefined;\n    overlayRefs[overlayRefs.length - 1].close(closestForm, overlayCloseElement);\n  }\n\n  protected removeAriaLiveRefContent(): void {\n    this.ariaLiveRef.textContent = '';\n  }\n\n  protected setAriaLiveRefContent(label?: string): void {\n    this.ariaLiveRefToggle = !this.ariaLiveRefToggle;\n\n    // If the text content remains the same, on VoiceOver the aria-live region is not announced a second time.\n    // In order to support reading on every opening, we toggle an invisible space.\n    this.ariaLiveRef.textContent = `${i18nDialog[this.language.current]}${\n      label ? `, ${label}` : ''\n    }${this.ariaLiveRefToggle ? ' ' : ''}`;\n  }\n}\n","import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { getFirstFocusableElement, setModalityOnNextFocus } from '../core/a11y.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nCloseDialog, i18nGoBack } from '../core/i18n.js';\nimport { applyInertMechanism, removeInertMechanism } from '../core/overlay.js';\n\nimport { overlayRefs, SbbOverlayBaseElement } from './overlay-base-element.js';\nimport style from './overlay.scss?lit&inline';\nimport '../button/secondary-button.js';\nimport '../button/transparent-button.js';\nimport '../container.js';\nimport '../screen-reader-only.js';\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a content for the overlay.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-overlay` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-overlay` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-overlay` begins the closing transition. Can be canceled.\n * @event {CustomEvent<SbbOverlayCloseEventDetails>} didClose - Emits whenever the `sbb-overlay` is closed.\n * @event {CustomEvent<void>} requestBackAction - Emits whenever the back button is clicked.\n * @cssprop [--sbb-overlay-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 */\n@customElement('sbb-overlay')\nexport class SbbOverlayElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  // FIXME using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n    backClick: 'requestBackAction',\n  } as const;\n\n  /**\n   * Whether to allow the overlay content to stretch to full width.\n   * By default, the content has the appropriate page size.\n   */\n  @property({ reflect: true, type: Boolean }) public expanded = false;\n\n  /** Whether a back button is displayed next to the title. */\n  @property({ attribute: 'back-button', type: Boolean }) public backButton = false;\n\n  /** This will be forwarded as aria-label to the close button element. */\n  @property({ attribute: 'accessibility-close-label' }) public accessibilityCloseLabel:\n    | string\n    | undefined;\n\n  /** This will be forwarded as aria-label to the back button element. */\n  @property({ attribute: 'accessibility-back-label' }) public accessibilityBackLabel:\n    | string\n    | undefined;\n\n  protected closeAttribute: string = 'sbb-overlay-close';\n\n  /** Emits whenever the back button is clicked. */\n  private _backClick: EventEmitter<any> = new EventEmitter(\n    this,\n    SbbOverlayElement.events.backClick,\n  );\n  private _overlayContentElement: HTMLElement | null = null;\n\n  /** Opens the component. */\n  public open(): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    this._overlayContentElement = this.shadowRoot?.querySelector(\n      '.sbb-overlay__content',\n    ) as HTMLElement;\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n\n    // Add this overlay to the global collection\n    overlayRefs.push(this as SbbOverlayElement);\n\n    // Disable scrolling for content below the overlay\n    this.scrollHandler.disableScroll();\n  }\n\n  // Wait for overlay transition to complete.\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  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.state = 'opened';\n      this.didOpen.emit();\n      applyInertMechanism(this);\n      this.attachOpenOverlayEvents();\n      this.setOverlayFocus();\n      // Use timeout to read label after focused element\n      setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel));\n      this.focusHandler.trap(this);\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._overlayContentElement?.scrollTo(0, 0);\n      this.state = 'closed';\n      removeInertMechanism();\n      setModalityOnNextFocus(this.lastFocusedElement);\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n      this.openOverlayController?.abort();\n      this.focusHandler.disconnect();\n      this.removeInstanceFromGlobalCollection();\n      // Enable scrolling for content below the overlay if no overlay is open\n      !overlayRefs.length && this.scrollHandler.enableScroll();\n      this.didClose.emit({\n        returnValue: this.returnValue,\n        closeTarget: this.overlayCloseElement,\n      });\n    }\n  }\n\n  // Set focus on the first focusable element.\n  protected setOverlayFocus(): void {\n    const firstFocusable = getFirstFocusableElement(\n      Array.from(this.shadowRoot!.children).filter(\n        (e): e is HTMLElement => e instanceof window.HTMLElement,\n      ),\n    );\n    setModalityOnNextFocus(firstFocusable);\n    firstFocusable?.focus();\n  }\n\n  protected override render(): TemplateResult {\n    const TAG_NAME = this.negative ? 'sbb-transparent-button' : 'sbb-secondary-button';\n\n    /* eslint-disable lit/binding-positions */\n    const closeButton = html`\n      <${unsafeStatic(TAG_NAME)}\n        class=\"sbb-overlay__close\"\n        aria-label=${this.accessibilityCloseLabel || i18nCloseDialog[this.language.current]}\n        ?negative=${this.negative}\n        size=\"m\"\n        type=\"button\"\n        icon-name=\"cross-small\"\n        sbb-overlay-close\n      ></${unsafeStatic(TAG_NAME)}>\n    `;\n\n    const backButton = html`\n      <${unsafeStatic(TAG_NAME)}\n        class=\"sbb-overlay__back\"\n        aria-label=${this.accessibilityBackLabel || i18nGoBack[this.language.current]}\n        ?negative=${this.negative}\n        size=\"m\"\n        type=\"button\"\n        icon-name=\"chevron-small-left-small\"\n        @click=${() => this._backClick.emit()}\n      ></${unsafeStatic(TAG_NAME)}>\n    `;\n    /* eslint-enable lit/binding-positions */\n\n    return html`\n      <div class=\"sbb-overlay__container\">\n        <div\n          @animationend=${(event: AnimationEvent) => this.onOverlayAnimationEnd(event)}\n          class=\"sbb-overlay\"\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-overlay__wrapper\"\n          >\n            <div class=\"sbb-overlay__header\">\n              ${this.backButton ? backButton : nothing} ${closeButton}\n            </div>\n            <div class=\"sbb-overlay__content\">\n              <sbb-container\n                class=\"sbb-overlay__content-container\"\n                ?expanded=${this.expanded}\n                color=\"transparent\"\n              >\n                <slot></slot>\n              </sbb-container>\n            </div>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-overlay': SbbOverlayElement;\n  }\n}\n"],"names":["_SbbOverlayBaseElement","__decorateClass"],"mappings":"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"}
|
|
506
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay.js","sources":["../../../src/elements/overlay/overlay-base-element.ts","../../../src/elements/overlay/overlay.ts"],"sourcesContent":["import { type PropertyValues } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbFocusHandler } from '../core/a11y.js';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbLanguageController } from '../core/controllers.js';\nimport { hostContext, SbbScrollHandler } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nDialog } from '../core/i18n.js';\nimport type { SbbOverlayCloseEventDetails } from '../core/interfaces.js';\nimport { SbbNegativeMixin } from '../core/mixins.js';\nimport { applyInertMechanism, removeInertMechanism } from '../core/overlay.js';\nimport type { SbbScreenReaderOnlyElement } from '../screen-reader-only.js';\n\n// A global collection of existing overlays.\nexport const overlayRefs: SbbOverlayBaseElement[] = [];\n\nexport abstract class SbbOverlayBaseElement extends SbbNegativeMixin(SbbOpenCloseBaseElement) {\n  /** This will be forwarded as aria-label to the relevant nested element to describe the purpose of the overlay. */\n  @property({ attribute: 'accessibility-label' }) public accessibilityLabel: string | undefined;\n\n  /** Emits whenever the component is closed. */\n  protected override didClose: EventEmitter<SbbOverlayCloseEventDetails> = new EventEmitter(\n    this,\n    SbbOverlayBaseElement.events.didClose,\n  );\n\n  // The last element which had focus before the component was opened.\n  protected lastFocusedElement?: HTMLElement;\n  protected overlayCloseElement?: HTMLElement;\n  protected overlayController!: AbortController;\n  protected openOverlayController!: AbortController;\n  protected focusHandler = new SbbFocusHandler();\n  protected scrollHandler = new SbbScrollHandler();\n  protected returnValue: any;\n  protected ariaLiveRefToggle = false;\n  protected ariaLiveRef!: SbbScreenReaderOnlyElement;\n  protected language = new SbbLanguageController(this);\n\n  protected abstract onOverlayAnimationEnd(event: AnimationEvent): void;\n  protected abstract setOverlayFocus(): void;\n  protected abstract closeAttribute: string;\n\n  /** Closes the component. */\n  public close(result?: any, target?: HTMLElement): any {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    this.returnValue = result;\n    this.overlayCloseElement = target;\n    const eventData: SbbOverlayCloseEventDetails = {\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    };\n\n    if (!this.willClose.emit(eventData)) {\n      return;\n    }\n    this.state = 'closing';\n    this.removeAriaLiveRefContent();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.overlayController?.abort();\n    this.overlayController = new AbortController();\n\n    if (this.state === 'opened') {\n      applyInertMechanism(this);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    this.ariaLiveRef =\n      this.shadowRoot!.querySelector<SbbScreenReaderOnlyElement>('sbb-screen-reader-only')!;\n\n    super.firstUpdated(changedProperties);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.overlayController?.abort();\n    this.openOverlayController?.abort();\n    this.focusHandler.disconnect();\n    this.removeInstanceFromGlobalCollection();\n    removeInertMechanism();\n    this.scrollHandler.enableScroll();\n  }\n\n  protected attachOpenOverlayEvents(): void {\n    this.openOverlayController = new AbortController();\n    // Remove overlay label as soon as it is not needed any more to prevent accessing it with browse mode.\n    window.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => {\n        this.removeAriaLiveRefContent();\n        this.onKeydownEvent(event);\n      },\n      {\n        signal: this.openOverlayController.signal,\n      },\n    );\n    window.addEventListener('click', () => this.removeAriaLiveRefContent(), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  protected onKeydownEvent(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    if (event.key === 'Escape') {\n      overlayRefs[overlayRefs.length - 1].close();\n      return;\n    }\n  }\n\n  protected removeInstanceFromGlobalCollection(): void {\n    overlayRefs.splice(overlayRefs.indexOf(this as SbbOverlayBaseElement), 1);\n  }\n\n  // Close the component on click of any element that has the `closeAttribute` attribute.\n  protected closeOnSbbOverlayCloseClick(event: Event): void {\n    const overlayCloseElement = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .find(\n        (target) => target.hasAttribute(this.closeAttribute) && !target.hasAttribute('disabled'),\n      );\n\n    if (!overlayCloseElement) {\n      return;\n    }\n\n    // Check if the target is a submission element within a form and return the form, if present\n    const closestForm =\n      overlayCloseElement.getAttribute('type') === 'submit'\n        ? (hostContext('form', overlayCloseElement) as HTMLFormElement)\n        : undefined;\n    overlayRefs[overlayRefs.length - 1].close(closestForm, overlayCloseElement);\n  }\n\n  protected removeAriaLiveRefContent(): void {\n    this.ariaLiveRef.textContent = '';\n  }\n\n  protected setAriaLiveRefContent(label?: string): void {\n    this.ariaLiveRefToggle = !this.ariaLiveRefToggle;\n\n    // If the text content remains the same, on VoiceOver the aria-live region is not announced a second time.\n    // In order to support reading on every opening, we toggle an invisible space.\n    this.ariaLiveRef.textContent = `${i18nDialog[this.language.current]}${\n      label ? `, ${label}` : ''\n    }${this.ariaLiveRefToggle ? ' ' : ''}`;\n  }\n}\n","import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { getFirstFocusableElement, setModalityOnNextFocus } from '../core/a11y.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nCloseDialog, i18nGoBack } from '../core/i18n.js';\nimport { applyInertMechanism, removeInertMechanism } from '../core/overlay.js';\n\nimport { overlayRefs, SbbOverlayBaseElement } from './overlay-base-element.js';\nimport style from './overlay.scss?lit&inline';\nimport '../button/secondary-button.js';\nimport '../button/transparent-button.js';\nimport '../container.js';\nimport '../screen-reader-only.js';\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a content for the overlay.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-overlay` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-overlay` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-overlay` begins the closing transition. Can be canceled.\n * @event {CustomEvent<SbbOverlayCloseEventDetails>} didClose - Emits whenever the `sbb-overlay` is closed.\n * @event {CustomEvent<void>} requestBackAction - Emits whenever the back button is clicked.\n * @cssprop [--sbb-overlay-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 */\n@customElement('sbb-overlay')\nexport class SbbOverlayElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  // FIXME using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n    backClick: 'requestBackAction',\n  } as const;\n\n  /**\n   * Whether to allow the overlay content to stretch to full width.\n   * By default, the content has the appropriate page size.\n   */\n  @property({ reflect: true, type: Boolean }) public expanded = false;\n\n  /** Whether a back button is displayed next to the title. */\n  @property({ attribute: 'back-button', type: Boolean }) public backButton = false;\n\n  /** This will be forwarded as aria-label to the close button element. */\n  @property({ attribute: 'accessibility-close-label' }) public accessibilityCloseLabel:\n    | string\n    | undefined;\n\n  /** This will be forwarded as aria-label to the back button element. */\n  @property({ attribute: 'accessibility-back-label' }) public accessibilityBackLabel:\n    | string\n    | undefined;\n\n  protected closeAttribute: string = 'sbb-overlay-close';\n\n  /** Emits whenever the back button is clicked. */\n  private _backClick: EventEmitter<any> = new EventEmitter(\n    this,\n    SbbOverlayElement.events.backClick,\n  );\n  private _overlayContentElement: HTMLElement | null = null;\n\n  /** Opens the component. */\n  public open(): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    this._overlayContentElement = this.shadowRoot?.querySelector(\n      '.sbb-overlay__content',\n    ) as HTMLElement;\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n\n    // Add this overlay to the global collection\n    overlayRefs.push(this as SbbOverlayElement);\n\n    // Disable scrolling for content below the overlay\n    this.scrollHandler.disableScroll();\n  }\n\n  // Wait for overlay transition to complete.\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  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.state = 'opened';\n      this.didOpen.emit();\n      applyInertMechanism(this);\n      this.attachOpenOverlayEvents();\n      this.setOverlayFocus();\n      // Use timeout to read label after focused element\n      setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel));\n      this.focusHandler.trap(this);\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._overlayContentElement?.scrollTo(0, 0);\n      this.state = 'closed';\n      removeInertMechanism();\n      setModalityOnNextFocus(this.lastFocusedElement);\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n      this.openOverlayController?.abort();\n      this.focusHandler.disconnect();\n      this.removeInstanceFromGlobalCollection();\n      // Enable scrolling for content below the overlay if no overlay is open\n      !overlayRefs.length && this.scrollHandler.enableScroll();\n      this.didClose.emit({\n        returnValue: this.returnValue,\n        closeTarget: this.overlayCloseElement,\n      });\n    }\n  }\n\n  // Set focus on the first focusable element.\n  protected setOverlayFocus(): void {\n    const firstFocusable = getFirstFocusableElement(\n      Array.from(this.shadowRoot!.children).filter(\n        (e): e is HTMLElement => e instanceof window.HTMLElement,\n      ),\n    );\n    setModalityOnNextFocus(firstFocusable);\n    firstFocusable?.focus();\n  }\n\n  protected override render(): TemplateResult {\n    const TAG_NAME = this.negative ? 'sbb-transparent-button' : 'sbb-secondary-button';\n\n    /* eslint-disable lit/binding-positions */\n    const closeButton = html`\n      <${unsafeStatic(TAG_NAME)}\n        class=\"sbb-overlay__close\"\n        aria-label=${this.accessibilityCloseLabel || i18nCloseDialog[this.language.current]}\n        ?negative=${this.negative}\n        size=\"m\"\n        type=\"button\"\n        icon-name=\"cross-small\"\n        sbb-overlay-close\n      ></${unsafeStatic(TAG_NAME)}>\n    `;\n\n    const backButton = html`\n      <${unsafeStatic(TAG_NAME)}\n        class=\"sbb-overlay__back\"\n        aria-label=${this.accessibilityBackLabel || i18nGoBack[this.language.current]}\n        ?negative=${this.negative}\n        size=\"m\"\n        type=\"button\"\n        icon-name=\"chevron-small-left-small\"\n        @click=${() => this._backClick.emit()}\n      ></${unsafeStatic(TAG_NAME)}>\n    `;\n    /* eslint-enable lit/binding-positions */\n\n    return html`\n      <div\n        class=\"sbb-overlay__container\"\n        @animationend=${(event: AnimationEvent) => this.onOverlayAnimationEnd(event)}\n      >\n        <div class=\"sbb-overlay\">\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-overlay__wrapper\"\n          >\n            <div class=\"sbb-overlay__header\">\n              ${this.backButton ? backButton : nothing} ${closeButton}\n            </div>\n            <div class=\"sbb-overlay__content\">\n              <sbb-container\n                class=\"sbb-overlay__content-container\"\n                ?expanded=${this.expanded}\n                color=\"transparent\"\n              >\n                <slot></slot>\n              </sbb-container>\n            </div>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-overlay': SbbOverlayElement;\n  }\n}\n"],"names":["_SbbOverlayBaseElement","__decorateClass"],"mappings":"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"}
|
package/icon/icon.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PropertyValues } from 'lit';
|
|
1
|
+
import { PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbIconBase } from './icon-base.js';
|
|
3
3
|
|
|
4
4
|
/**
|
|
@@ -12,9 +12,17 @@ export declare class SbbIconElement extends SbbIconBase {
|
|
|
12
12
|
*/
|
|
13
13
|
name: string;
|
|
14
14
|
private _defaultAriaLabel;
|
|
15
|
+
/**
|
|
16
|
+
* The sbb-angular library has a sbb-icon component as well. In order to provide
|
|
17
|
+
* compatibility with it (as some icons are used internally inside the other sbb-angular
|
|
18
|
+
* components) we need to check whether the attribute svgicon is used.
|
|
19
|
+
*/
|
|
20
|
+
private _sbbAngularCompatibility;
|
|
15
21
|
protected fetchSvgIcon(namespace: string, name: string): Promise<string>;
|
|
16
22
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
23
|
+
attributeChangedCallback(name: string, _old: string | null, value: string | null): void;
|
|
17
24
|
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
25
|
+
protected render(): TemplateResult;
|
|
18
26
|
}
|
|
19
27
|
declare global {
|
|
20
28
|
interface HTMLElementTagNameMap {
|
package/icon/icon.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGrE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C;;GAEG;AACH,qBACa,cAAe,SAAQ,WAAW;IAC7C;;;;OAIG;IACiC,IAAI,EAAG,MAAM,CAAC;IAElD,OAAO,CAAC,iBAAiB,CAAM;IAE/B;;;;OAIG;IACM,OAAO,CAAC,wBAAwB,CAAS;cAEzB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;cAiBpE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQ3D,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|
package/icon.js
CHANGED
|
@@ -1,73 +1,73 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { unsafeHTML as
|
|
4
|
-
import { until as
|
|
5
|
-
import { hostAttributes as
|
|
6
|
-
import { readConfig as
|
|
7
|
-
const
|
|
1
|
+
import { isServer as y, css as w, LitElement as N, html as c, nothing as m } from "lit";
|
|
2
|
+
import { state as b, property as h, customElement as A } from "lit/decorators.js";
|
|
3
|
+
import { unsafeHTML as C } from "lit/directives/unsafe-html.js";
|
|
4
|
+
import { until as I } from "lit/directives/until.js";
|
|
5
|
+
import { hostAttributes as $ } from "./core/decorators.js";
|
|
6
|
+
import { readConfig as S } from "./core/config.js";
|
|
7
|
+
const L = (t) => typeof t == "string", _ = (t) => {
|
|
8
8
|
if (t.nodeType === 1) {
|
|
9
9
|
if (t.nodeName.toLowerCase() === "script")
|
|
10
10
|
return !1;
|
|
11
11
|
for (let e = 0; e < t.attributes.length; e++) {
|
|
12
|
-
const
|
|
13
|
-
if (
|
|
12
|
+
const i = t.attributes[e].name;
|
|
13
|
+
if (L(i) && i.toLowerCase().indexOf("on") === 0)
|
|
14
14
|
return !1;
|
|
15
15
|
}
|
|
16
16
|
for (let e = 0; e < t.childNodes.length; e++)
|
|
17
|
-
if (!
|
|
17
|
+
if (!_(t.childNodes[e]))
|
|
18
18
|
return !1;
|
|
19
19
|
}
|
|
20
20
|
return !0;
|
|
21
|
-
}, E = (t, e = !0,
|
|
21
|
+
}, E = (t, e = !0, i = !1) => {
|
|
22
22
|
const r = document.createElement("div");
|
|
23
23
|
r.innerHTML = t;
|
|
24
|
-
for (let
|
|
25
|
-
r.childNodes[
|
|
24
|
+
for (let o = r.childNodes.length - 1; o >= 0; o--)
|
|
25
|
+
r.childNodes[o].nodeName.toLowerCase() !== "svg" && r.removeChild(r.childNodes[o]);
|
|
26
26
|
const s = r.firstElementChild;
|
|
27
|
-
return s && s.nodeName.toLowerCase() === "svg" && (
|
|
28
|
-
},
|
|
29
|
-
var
|
|
30
|
-
const r =
|
|
27
|
+
return s && s.nodeName.toLowerCase() === "svg" && (i && !s.classList.contains("color-immutable") && s.classList.add("color-immutable"), e === !1 || _(s)) ? r.innerHTML : "";
|
|
28
|
+
}, g = "https://icons.app.sbb.ch/", P = (/* @__PURE__ */ new Map()).set("default", `${g}icons/`).set("picto", `${g}picto/`), v = /* @__PURE__ */ new Map(), O = (t, e, i) => {
|
|
29
|
+
var f;
|
|
30
|
+
const r = S().icon ?? {}, s = ((f = r.namespaces) == null ? void 0 : f.get(t)) ?? P.get(t);
|
|
31
31
|
if (s == null)
|
|
32
32
|
throw Error(
|
|
33
33
|
`Unable to find the namespace "${t}". Please register your custom namespace.`
|
|
34
34
|
);
|
|
35
|
-
const
|
|
36
|
-
let a =
|
|
35
|
+
const o = `${s}${e}.svg`;
|
|
36
|
+
let a = v.get(o);
|
|
37
37
|
if (!a)
|
|
38
38
|
if (typeof fetch < "u" && !y)
|
|
39
39
|
a = (r.interceptor ?? ((l) => l.request()))({
|
|
40
40
|
namespace: t,
|
|
41
41
|
name: e,
|
|
42
|
-
url:
|
|
43
|
-
request: () => fetch(
|
|
42
|
+
url: o,
|
|
43
|
+
request: () => fetch(o).then(async (l) => {
|
|
44
44
|
if (!l.ok)
|
|
45
45
|
throw new Error("Failed to load icon " + t + ":" + e);
|
|
46
|
-
return E(await l.text(),
|
|
46
|
+
return E(await l.text(), i);
|
|
47
47
|
}).catch((l) => {
|
|
48
48
|
throw Error(l);
|
|
49
49
|
})
|
|
50
|
-
}),
|
|
50
|
+
}), v.set(o, a);
|
|
51
51
|
else
|
|
52
52
|
return Promise.resolve("");
|
|
53
53
|
return a;
|
|
54
|
-
}, x =
|
|
55
|
-
var z = Object.defineProperty, M = Object.getOwnPropertyDescriptor,
|
|
56
|
-
for (var s = r > 1 ? void 0 : r ? M(e,
|
|
57
|
-
(a = t[
|
|
58
|
-
return r && s && z(e,
|
|
54
|
+
}, x = w`*,:before,:after{box-sizing:border-box}:host{display:inline-block;line-height:0;-webkit-tap-highlight-color:transparent}:host([data-empty]){--sbb-icon-default-dimension: 0}:host([data-empty][data-namespace=default][name$=-small]){--sbb-icon-default-dimension: var(--sbb-size-icon-ui-small)}:host([data-empty][data-namespace=default][name$=-medium]){--sbb-icon-default-dimension: var(--sbb-size-icon-ui-medium)}:host([data-empty][data-namespace=default][name$=-large]){--sbb-icon-default-dimension: var(--sbb-size-icon-ui-large)}svg{width:var(--sbb-icon-svg-width, var(--sbb-icon-default-dimension));height:var(--sbb-icon-svg-height, var(--sbb-icon-default-dimension));stroke:var(--sbb-icon-svg-stroke-color);stroke-width:var(--sbb-icon-svg-stroke-width)}svg:not(.color-immutable) [fill]:not([fill=none]){fill:currentcolor}svg:not(.color-immutable) [stroke]:not([stroke=none]){stroke:currentcolor}svg:not(.color-immutable)>:where(path,polygon,polyline):where(:not([stroke]):not([fill])),svg:not(.color-immutable) :where(:not([stroke]):not([fill])) :where(path,polygon,polyline):where(:not([stroke]):not([fill])){fill:currentcolor}`;
|
|
55
|
+
var z = Object.defineProperty, M = Object.getOwnPropertyDescriptor, d = (t, e, i, r) => {
|
|
56
|
+
for (var s = r > 1 ? void 0 : r ? M(e, i) : e, o = t.length - 1, a; o >= 0; o--)
|
|
57
|
+
(a = t[o]) && (s = (r ? a(e, i, s) : a(s)) || s);
|
|
58
|
+
return r && s && z(e, i, s), s;
|
|
59
59
|
};
|
|
60
|
-
let n = class extends
|
|
60
|
+
let n = class extends N {
|
|
61
61
|
constructor() {
|
|
62
62
|
super(...arguments), this._svgNamespace = n._defaultNamespace, this.noSanitize = !1;
|
|
63
63
|
}
|
|
64
64
|
async loadSvgIcon(t) {
|
|
65
65
|
if (!t)
|
|
66
66
|
return;
|
|
67
|
-
const [e,
|
|
67
|
+
const [e, i] = this._splitIconName(t);
|
|
68
68
|
this._svgNamespace = e, this.setAttribute("data-namespace", this._svgNamespace);
|
|
69
|
-
const r = this.fetchSvgIcon(this._svgNamespace,
|
|
70
|
-
this._svgIcon = r.then((s) =>
|
|
69
|
+
const r = this.fetchSvgIcon(this._svgNamespace, i);
|
|
70
|
+
this._svgIcon = r.then((s) => C(s));
|
|
71
71
|
try {
|
|
72
72
|
this.toggleAttribute("data-empty", !await r);
|
|
73
73
|
} catch {
|
|
@@ -95,7 +95,7 @@ let n = class extends I {
|
|
|
95
95
|
}
|
|
96
96
|
render() {
|
|
97
97
|
return c`<span class="sbb-icon-inner"
|
|
98
|
-
>${
|
|
98
|
+
>${I(
|
|
99
99
|
this._svgIcon,
|
|
100
100
|
// To reserve space, we need an empty svg to apply dimension to.
|
|
101
101
|
c`<svg width="0" height="0"></svg>`
|
|
@@ -105,29 +105,29 @@ let n = class extends I {
|
|
|
105
105
|
};
|
|
106
106
|
n.styles = x;
|
|
107
107
|
n._defaultNamespace = "default";
|
|
108
|
-
|
|
109
|
-
|
|
108
|
+
d([
|
|
109
|
+
b()
|
|
110
110
|
], n.prototype, "_svgNamespace", 2);
|
|
111
|
-
|
|
112
|
-
|
|
111
|
+
d([
|
|
112
|
+
b()
|
|
113
113
|
], n.prototype, "_svgIcon", 2);
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
d([
|
|
115
|
+
h({ attribute: "no-sanitize", type: Boolean })
|
|
116
116
|
], n.prototype, "noSanitize", 2);
|
|
117
|
-
n =
|
|
118
|
-
|
|
117
|
+
n = d([
|
|
118
|
+
$({
|
|
119
119
|
"data-namespace": n._defaultNamespace,
|
|
120
120
|
"data-empty": ""
|
|
121
121
|
})
|
|
122
122
|
], n);
|
|
123
|
-
var U = Object.defineProperty, j = Object.getOwnPropertyDescriptor,
|
|
124
|
-
for (var s = r > 1 ? void 0 : r ? j(e,
|
|
125
|
-
(a = t[
|
|
126
|
-
return r && s && U(e,
|
|
123
|
+
var U = Object.defineProperty, j = Object.getOwnPropertyDescriptor, p = (t, e, i, r) => {
|
|
124
|
+
for (var s = r > 1 ? void 0 : r ? j(e, i) : e, o = t.length - 1, a; o >= 0; o--)
|
|
125
|
+
(a = t[o]) && (s = (r ? a(e, i, s) : a(s)) || s);
|
|
126
|
+
return r && s && U(e, i, s), s;
|
|
127
127
|
};
|
|
128
|
-
let
|
|
128
|
+
let u = class extends n {
|
|
129
129
|
constructor() {
|
|
130
|
-
super(...arguments), this._defaultAriaLabel = "";
|
|
130
|
+
super(...arguments), this._defaultAriaLabel = "", this._sbbAngularCompatibility = !1;
|
|
131
131
|
}
|
|
132
132
|
async fetchSvgIcon(t, e) {
|
|
133
133
|
return this.getAttribute("aria-label") === this._defaultAriaLabel && this.removeAttribute("aria-label"), this._defaultAriaLabel = `Icon ${e.replace(/-/g, " ")}`, this.getAttribute("aria-hidden") === "false" && !this.hasAttribute("aria-label") && e && this.setAttribute("aria-label", this._defaultAriaLabel), super.fetchSvgIcon(t, e);
|
|
@@ -135,40 +135,49 @@ let d = class extends n {
|
|
|
135
135
|
willUpdate(t) {
|
|
136
136
|
super.willUpdate(t), t.has("name") && this.loadSvgIcon(this.name);
|
|
137
137
|
}
|
|
138
|
+
attributeChangedCallback(t, e, i) {
|
|
139
|
+
t === "svgicon" ? this._sbbAngularCompatibility = !!i : super.attributeChangedCallback(t, e, i);
|
|
140
|
+
}
|
|
138
141
|
firstUpdated(t) {
|
|
139
142
|
super.firstUpdated(t), this.hasAttribute("aria-hidden") || this.setAttribute("aria-hidden", "true");
|
|
140
143
|
}
|
|
144
|
+
render() {
|
|
145
|
+
return this._sbbAngularCompatibility ? c`<slot></slot>` : super.render();
|
|
146
|
+
}
|
|
141
147
|
};
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
],
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
],
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
148
|
+
p([
|
|
149
|
+
h({ reflect: !0 })
|
|
150
|
+
], u.prototype, "name", 2);
|
|
151
|
+
p([
|
|
152
|
+
b()
|
|
153
|
+
], u.prototype, "_sbbAngularCompatibility", 2);
|
|
154
|
+
u = p([
|
|
155
|
+
A("sbb-icon")
|
|
156
|
+
], u);
|
|
157
|
+
var k = Object.defineProperty, T = (t, e, i, r) => {
|
|
158
|
+
for (var s = void 0, o = t.length - 1, a; o >= 0; o--)
|
|
159
|
+
(a = t[o]) && (s = a(e, i, s) || s);
|
|
160
|
+
return s && k(e, i, s), s;
|
|
152
161
|
};
|
|
153
162
|
const J = (t) => {
|
|
154
163
|
class e extends t {
|
|
155
164
|
renderIconSlot(r) {
|
|
156
165
|
return c`
|
|
157
166
|
<slot name="icon">
|
|
158
|
-
${this.iconName ? c`<sbb-icon name=${this.iconName} class=${r ||
|
|
167
|
+
${this.iconName ? c`<sbb-icon name=${this.iconName} class=${r || m}></sbb-icon>` : m}
|
|
159
168
|
</slot>
|
|
160
169
|
`;
|
|
161
170
|
}
|
|
162
171
|
}
|
|
163
|
-
return
|
|
164
|
-
|
|
172
|
+
return T([
|
|
173
|
+
h({ attribute: "icon-name", reflect: !0 })
|
|
165
174
|
], e.prototype, "iconName"), e;
|
|
166
175
|
};
|
|
167
176
|
export {
|
|
168
177
|
n as SbbIconBase,
|
|
169
|
-
|
|
178
|
+
u as SbbIconElement,
|
|
170
179
|
J as SbbIconNameMixin,
|
|
171
180
|
O as getSvgContent,
|
|
172
|
-
|
|
181
|
+
_ as isValid,
|
|
173
182
|
E as validateContent
|
|
174
183
|
};
|
package/menu/menu/menu.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/menu/menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAYrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAYtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAkB1D;;;;;;;;;;;GAWG;AACH,qBACa,cAAe,SAAQ,mBAGV;IACxB,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAwC;IAEvF;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;;OAGG;IACyD,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAE5F,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,yBAAyB,CAAkB;IACnD,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAEhD;;OAEG;IACI,IAAI,IAAI,IAAI;IAmBnB;;OAEG;IACI,KAAK,IAAI,IAAI;IAapB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB,OAAO,CAAC,cAAc;YAsBR,eAAe;IAY7B,OAAO,CAAC,2BAA2B;IAWnB,iBAAiB,IAAI,IAAI;IAoBzB,oBAAoB,IAAI,IAAI;
|
|
1
|
+
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/menu/menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAYrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAYtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAkB1D;;;;;;;;;;;GAWG;AACH,qBACa,cAAe,SAAQ,mBAGV;IACxB,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAwC;IAEvF;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;;OAGG;IACyD,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAE5F,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,yBAAyB,CAAkB;IACnD,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAEhD;;OAEG;IACI,IAAI,IAAI,IAAI;IAmBnB;;OAEG;IACI,KAAK,IAAI,IAAI;IAapB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB,OAAO,CAAC,cAAc;YAsBR,eAAe;IAY7B,OAAO,CAAC,2BAA2B;IAWnB,iBAAiB,IAAI,IAAI;IAoBzB,oBAAoB,IAAI,IAAI;IAS5C,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,UAAU;IAsBlB,OAAO,CAAC,mBAAmB;IAwB3B,OAAO,CAAC,+BAA+B;IAQvC,OAAO,CAAC,oBAAoB,CAE1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAMF,OAAO,CAAC,mBAAmB;IA8B3B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,gBAAgB;cAyBL,MAAM,IAAI,cAAc;CAqB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|
package/menu/menu.js
CHANGED
|
@@ -23,7 +23,7 @@ const I = 8, K = [
|
|
|
23
23
|
"SBB-LINK-BUTTON",
|
|
24
24
|
"SBB-BLOCK-LINK-BUTTON"
|
|
25
25
|
];
|
|
26
|
-
let
|
|
26
|
+
let H = 0, r = class extends N(k) {
|
|
27
27
|
constructor() {
|
|
28
28
|
super(...arguments), this.listChildLocalNames = ["sbb-menu-button", "sbb-menu-link"], this._trigger = null, this._triggerElement = null, this._isPointerDownEventOnMenu = !1, this._abort = new C(this), this._focusHandler = new f(), this._scrollHandler = new L(), this._pointerDownListener = (e) => {
|
|
29
29
|
this._isPointerDownEventOnMenu = h(this._menu, e);
|
|
@@ -95,7 +95,7 @@ let D = 0, r = class extends N(k) {
|
|
|
95
95
|
}
|
|
96
96
|
disconnectedCallback() {
|
|
97
97
|
var e, t;
|
|
98
|
-
super.disconnectedCallback(), (e = this._menuController) == null || e.abort(), (t = this._windowEventsController) == null || t.abort(), this._focusHandler.disconnect(), u();
|
|
98
|
+
super.disconnectedCallback(), (e = this._menuController) == null || e.abort(), (t = this._windowEventsController) == null || t.abort(), this._focusHandler.disconnect(), u(), this._scrollHandler.enableScroll();
|
|
99
99
|
}
|
|
100
100
|
_checkListCase(e) {
|
|
101
101
|
var t;
|
|
@@ -106,7 +106,7 @@ let D = 0, r = class extends N(k) {
|
|
|
106
106
|
// Check if the trigger is valid and attach click event listeners.
|
|
107
107
|
_configure(e) {
|
|
108
108
|
var t;
|
|
109
|
-
S(this._triggerElement), e && (this._triggerElement = O(e), this._triggerElement && (this.id = this.id || `sbb-menu-${
|
|
109
|
+
S(this._triggerElement), e && (this._triggerElement = O(e), this._triggerElement && (this.id = this.id || `sbb-menu-${H++}`, B(this._triggerElement, "menu", this.id, this.state), (t = this._menuController) == null || t.abort(), this._menuController = new AbortController(), this._triggerElement.addEventListener("click", () => this.open(), {
|
|
110
110
|
signal: this._menuController.signal
|
|
111
111
|
})));
|
|
112
112
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"navigation.d.ts","sourceRoot":"","sources":["../../../../src/elements/navigation/navigation/navigation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAmBtE,OAAO,oCAAoC,CAAC;;AAW5C;;;;;;;;;;;GAWG;AACH,qBAIa,oBAAqB,SAAQ,yBAAgD;IACxF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;OAEG;IAC0D,uBAAuB,EAChF,MAAM,GACN,SAAS,CAAC;IAEd;;OAEG;IACM,OAAO,CAAC,wBAAwB,CAA4B;IAErE,IAAW,uBAAuB,IAAI,WAAW,GAAG,IAAI,CAEvD;IAED,OAAO,CAAC,WAAW,CAAkB;IACrC,OAAO,CAAC,yBAAyB,CAAe;IAChD,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,qBAAqB,CAAmB;IAChD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,+BAA+B,CAAkB;IACzD,OAAO,CAAC,sBAAsB,CAA8C;IAC5E,OAAO,CAAC,mBAAmB,CAEzB;IACF,OAAO,CAAC,yBAAyB,CAAgE;IAEjG;;OAEG;IACI,IAAI,IAAI,IAAI;IAkBnB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,mBAAmB;IAO3B;;OAEG;IACI,KAAK,IAAI,IAAI;IAcpB,OAAO,CAAC,2BAA2B;IAYnC,OAAO,CAAC,UAAU;IAqBlB,OAAO,CAAC,gBAAgB,CAEtB;IAIF,OAAO,CAAC,eAAe;IA4BvB,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,oBAAoB,CAS1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAGF,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,mBAAmB;IAkBX,iBAAiB,IAAI,IAAI;IAgBzB,oBAAoB,IAAI,IAAI;
|
|
1
|
+
{"version":3,"file":"navigation.d.ts","sourceRoot":"","sources":["../../../../src/elements/navigation/navigation/navigation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAmBtE,OAAO,oCAAoC,CAAC;;AAW5C;;;;;;;;;;;GAWG;AACH,qBAIa,oBAAqB,SAAQ,yBAAgD;IACxF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;OAEG;IAC0D,uBAAuB,EAChF,MAAM,GACN,SAAS,CAAC;IAEd;;OAEG;IACM,OAAO,CAAC,wBAAwB,CAA4B;IAErE,IAAW,uBAAuB,IAAI,WAAW,GAAG,IAAI,CAEvD;IAED,OAAO,CAAC,WAAW,CAAkB;IACrC,OAAO,CAAC,yBAAyB,CAAe;IAChD,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,qBAAqB,CAAmB;IAChD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,+BAA+B,CAAkB;IACzD,OAAO,CAAC,sBAAsB,CAA8C;IAC5E,OAAO,CAAC,mBAAmB,CAEzB;IACF,OAAO,CAAC,yBAAyB,CAAgE;IAEjG;;OAEG;IACI,IAAI,IAAI,IAAI;IAkBnB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,mBAAmB;IAO3B;;OAEG;IACI,KAAK,IAAI,IAAI;IAcpB,OAAO,CAAC,2BAA2B;IAYnC,OAAO,CAAC,UAAU;IAqBlB,OAAO,CAAC,gBAAgB,CAEtB;IAIF,OAAO,CAAC,eAAe;IA4BvB,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,eAAe;IAOvB,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,oBAAoB,CAS1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAGF,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,mBAAmB;IAkBX,iBAAiB,IAAI,IAAI;IAgBzB,oBAAoB,IAAI,IAAI;cAWzB,MAAM,IAAI,cAAc;CAqC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,oBAAoB,CAAC;KACxC;CACF"}
|
package/navigation/navigation.js
CHANGED
|
@@ -12,10 +12,10 @@ import { AgnosticMutationObserver as A, AgnosticResizeObserver as N } from "../c
|
|
|
12
12
|
import { isEventOnElement as l, removeAriaOverlayTriggerAttributes as z, setAriaOverlayTriggerAttributes as T, applyInertMechanism as d, removeInertMechanism as h } from "../core/overlay.js";
|
|
13
13
|
import "../button/transparent-button.js";
|
|
14
14
|
const L = p`*,:before,:after{box-sizing:border-box}:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-zero-time, var(--sbb-animation-duration-3x) );--sbb-navigation-animation-easing: ease-in;--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive);--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-l);--sbb-navigation-padding-block-end: var(--sbb-spacing-responsive-xl);--sbb-navigation-backdrop-visibility: hidden;--sbb-navigation-backdrop-pointer-events: none;--sbb-navigation-backdrop-color: transparent;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-responsive-xxl);--sbb-navigation-inline-start: 0;--sbb-navigation-expanded-width: 100%;--sbb-navigation-inset: 0 auto auto 0;--sbb-navigation-transform: translateX(-100%);--sbb-navigation-content-transform: translateX(0);--sbb-navigation-width: 100%;--sbb-navigation-height: 100vh;display:block;position:fixed;inset:var(--sbb-navigation-inset);z-index:var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index));overflow:hidden;--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}@supports (height: 100dvh){:host{--sbb-navigation-height: 100dvh}}@media (min-width: 52.5rem){:host{--sbb-navigation-grid-column: 1 / 9}}@media (min-width: 64rem){:host{--sbb-navigation-grid-column: 1 / 5;--sbb-navigation-animation-duration: var( --sbb-disable-animation-zero-time, var(--sbb-animation-duration-6x) );--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xl);--sbb-navigation-padding-inline: var(--sbb-layout-base-offset-responsive) 0;--sbb-navigation-list-margin-block-start: var(--sbb-spacing-fixed-1x);--sbb-navigation-inline-start: calc(var(--sbb-layout-base-offset-responsive) * -1);--sbb-navigation-width: calc(100% + var(--sbb-layout-base-offset-responsive))}}@media (min-width: 90rem){:host{--sbb-navigation-grid-column: 1 / 6;--sbb-navigation-padding-block-start: var(--sbb-spacing-responsive-xxl)}}:host([data-state=opened]){--sbb-navigation-animation-easing: ease-out}:host(:is([data-state=opened],[data-state=opening])){--sbb-navigation-backdrop-visibility: visible;--sbb-navigation-backdrop-pointer-events: all;--sbb-navigation-backdrop-color: var(--sbb-color-black-alpha-70)}:host(:not([data-state=closed])){--sbb-navigation-inset: 0;--sbb-navigation-transform: translateX(0)}:host([data-has-navigation-section]){--sbb-navigation-content-transform: translateX(-100%)}@media (min-width: 64rem){:host([data-has-navigation-section]){--sbb-navigation-expanded-width: 100vw;--sbb-navigation-content-transform: translateX(0%)}@supports (height: 100dvw){:host([data-has-navigation-section]){--sbb-navigation-expanded-width: 100dvw}}}:host([data-resize-disable-animation]){--sbb-disable-animation-time: .1ms;--sbb-disable-animation-zero-time: 0s}.sbb-navigation__container{display:grid;gap:var(--sbb-grid-base-gutter-responsive);grid-template-columns:repeat(var(--sbb-grid-base-columns),1fr);padding-inline:0;pointer-events:none;transform:var(--sbb-navigation-transform)}@media (min-width: 64rem){.sbb-navigation__container{padding-inline:var(--sbb-layout-base-offset-responsive)}.sbb-navigation__container:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:background-color,visibility;content:"";visibility:var(--sbb-navigation-backdrop-visibility);pointer-events:var(--sbb-navigation-backdrop-pointer-events);position:fixed;inset:var(--sbb-navigation-inset);background-color:var(--sbb-navigation-backdrop-color)}}.sbb-navigation{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:none;width:var(--sbb-navigation-width);grid-column:var(--sbb-navigation-grid-column);padding:0;margin:0;position:relative;inset-inline-start:var(--sbb-navigation-inline-start);inset-block-start:0;border:none;pointer-events:none;height:var(--sbb-navigation-height);color:var(--sbb-color-white);background-color:var(--sbb-color-midnight)}.sbb-navigation:before{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;content:"";position:absolute;width:var(--sbb-navigation-expanded-width);height:var(--sbb-navigation-height);background:var(--sbb-color-midnight)}:host([data-state]:not([data-state=closed])) .sbb-navigation{display:block;pointer-events:all;animation-name:open;animation-duration:var(--sbb-navigation-animation-duration);animation-timing-function:var(--sbb-navigation-animation-easing)}:host([data-state][data-state=closing]) .sbb-navigation{pointer-events:none;animation-name:close}@media (forced-colors: active){.sbb-navigation{outline:var(--sbb-border-width-1x) solid CanvasText}}.sbb-navigation__wrapper{outline:none}.sbb-navigation__header{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:width;display:flex;justify-content:flex-end;position:absolute;width:var(--sbb-navigation-expanded-width);pointer-events:none;padding:var(--sbb-spacing-responsive-xs);z-index:calc(var(--sbb-navigation-z-index, var(--sbb-overlay-default-z-index)) + 1)}.sbb-navigation__close{pointer-events:all}.sbb-navigation__content{transition-duration:var(--sbb-navigation-animation-duration);transition-timing-function:var(--sbb-navigation-animation-easing);transition-property:transform;--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);display:flex;flex-direction:column;gap:var(--sbb-spacing-responsive-xxl);position:relative;height:var(--sbb-navigation-height);padding-inline:var(--sbb-navigation-padding-inline);padding-block:var(--sbb-navigation-padding-block-start) var(--sbb-navigation-padding-block-end);overflow-y:auto;transform:var(--sbb-navigation-content-transform)}.sbb-navigation__content::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-navigation__content::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-navigation__content::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-navigation__content::-webkit-scrollbar-button,.sbb-navigation__content::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-navigation__content{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}::slotted(:first-child){margin-block-start:var(--sbb-navigation-list-margin-block-start)}@keyframes open{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes close{0%{transform:translate(0)}to{transform:translate(-100%)}}`;
|
|
15
|
-
var
|
|
16
|
-
for (var e = a > 1 ? void 0 : a ?
|
|
15
|
+
var H = Object.defineProperty, B = Object.getOwnPropertyDescriptor, s = (t, i, n, a) => {
|
|
16
|
+
for (var e = a > 1 ? void 0 : a ? B(i, n) : i, r = t.length - 1, b; r >= 0; r--)
|
|
17
17
|
(b = t[r]) && (e = (a ? b(i, n, e) : b(e)) || e);
|
|
18
|
-
return a && e &&
|
|
18
|
+
return a && e && H(i, n, e), e;
|
|
19
19
|
};
|
|
20
20
|
const I = {
|
|
21
21
|
subtree: !0,
|
|
@@ -150,7 +150,7 @@ let o = class extends S(w) {
|
|
|
150
150
|
}
|
|
151
151
|
disconnectedCallback() {
|
|
152
152
|
var t, i;
|
|
153
|
-
super.disconnectedCallback(), (t = this._navigationController) == null || t.abort(), (i = this._windowEventsController) == null || i.abort(), this._focusHandler.disconnect(), this._navigationObserver.disconnect(), this._navigationResizeObserver.disconnect(), h();
|
|
153
|
+
super.disconnectedCallback(), (t = this._navigationController) == null || t.abort(), (i = this._windowEventsController) == null || i.abort(), this._focusHandler.disconnect(), this._navigationObserver.disconnect(), this._navigationResizeObserver.disconnect(), h(), this._scrollHandler.enableScroll();
|
|
154
154
|
}
|
|
155
155
|
render() {
|
|
156
156
|
const t = v`
|
|
@@ -6,10 +6,10 @@ import { SbbTitleLevel } from '../title.js';
|
|
|
6
6
|
*
|
|
7
7
|
* @slot - Use the unnamed slot to add content to the notification message.
|
|
8
8
|
* @slot title - Use this to provide a notification title (optional).
|
|
9
|
-
* @event {CustomEvent<void>} willOpen - Emits
|
|
10
|
-
* @event {CustomEvent<void>} didOpen - Emits
|
|
11
|
-
* @event {CustomEvent<void>} willClose - Emits
|
|
12
|
-
* @event {CustomEvent<void>} didClose - Emits
|
|
9
|
+
* @event {CustomEvent<void>} willOpen - Emits when the opening animation starts.
|
|
10
|
+
* @event {CustomEvent<void>} didOpen - Emits when the opening animation ends.
|
|
11
|
+
* @event {CustomEvent<void>} willClose - Emits when the closing animation starts.
|
|
12
|
+
* @event {CustomEvent<void>} didClose - Emits when the closing animation ends.
|
|
13
13
|
* @cssprop [--sbb-notification-margin=0] - Can be used to modify the margin in order to get a smoother animation.
|
|
14
14
|
* See style section for more information.
|
|
15
15
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAe,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAGzE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAG3E,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAAsB,qBAAsB,SAAQ,0BAAyC;IAC3F,kHAAkH;IAC3D,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,8CAA8C;IAC9C,UAAmB,QAAQ,EAAE,YAAY,CAAC,2BAA2B,CAAC,CAGpE;IAGF,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,SAAS,CAAC,iBAAiB,EAAG,eAAe,CAAC;IAC9C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,YAAY,kBAAyB;IAC/C,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,iBAAiB,UAAS;IACpC,SAAS,CAAC,WAAW,EAAG,0BAA0B,CAAC;IACnD,SAAS,CAAC,QAAQ,wBAAmC;IAErD,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IACrE,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,IAAI;IAC1C,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAE1C,4BAA4B;IACrB,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,GAAG;IAmBrC,iBAAiB,IAAI,IAAI;cAUtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;
|
|
1
|
+
{"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAe,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AAGzE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAG3E,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAAsB,qBAAsB,SAAQ,0BAAyC;IAC3F,kHAAkH;IAC3D,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,8CAA8C;IAC9C,UAAmB,QAAQ,EAAE,YAAY,CAAC,2BAA2B,CAAC,CAGpE;IAGF,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,SAAS,CAAC,iBAAiB,EAAG,eAAe,CAAC;IAC9C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,YAAY,kBAAyB;IAC/C,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,iBAAiB,UAAS;IACpC,SAAS,CAAC,WAAW,EAAG,0BAA0B,CAAC;IACnD,SAAS,CAAC,QAAQ,wBAAmC;IAErD,SAAS,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IACrE,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,IAAI;IAC1C,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAE1C,4BAA4B;IACrB,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,GAAG;IAmBrC,iBAAiB,IAAI,IAAI;cAUtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9D,oBAAoB,IAAI,IAAI;IAU5C,SAAS,CAAC,uBAAuB,IAAI,IAAI;IAkBzC,SAAS,CAAC,cAAc,CAAC,KAAK,EAAE,aAAa,GAAG,IAAI;IAWpD,SAAS,CAAC,kCAAkC,IAAI,IAAI;IAKpD,SAAS,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAoBzD,SAAS,CAAC,wBAAwB,IAAI,IAAI;IAI1C,SAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI;CAStD"}
|