@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.
Files changed (51) hide show
  1. package/alert/alert/alert.d.ts +22 -16
  2. package/alert/alert/alert.d.ts.map +1 -1
  3. package/alert/alert-group/alert-group.d.ts +1 -1
  4. package/alert/alert-group/alert-group.d.ts.map +1 -1
  5. package/alert/alert-group.js +31 -26
  6. package/alert/alert.js +45 -37
  7. package/clock/clock.d.ts.map +1 -1
  8. package/clock.js +14 -14
  9. package/core/testing/wait-for-event.d.ts +2 -0
  10. package/core/testing/wait-for-event.d.ts.map +1 -0
  11. package/core/testing.d.ts +1 -0
  12. package/core/testing.d.ts.map +1 -1
  13. package/core/testing.js +49 -36
  14. package/custom-elements.json +211 -51
  15. package/development/alert/alert/alert.d.ts +22 -16
  16. package/development/alert/alert/alert.d.ts.map +1 -1
  17. package/development/alert/alert-group/alert-group.d.ts +1 -1
  18. package/development/alert/alert-group/alert-group.d.ts.map +1 -1
  19. package/development/alert/alert-group.js +16 -11
  20. package/development/alert/alert.js +65 -24
  21. package/development/clock/clock.d.ts.map +1 -1
  22. package/development/clock.js +3 -2
  23. package/development/core/testing/wait-for-event.d.ts +2 -0
  24. package/development/core/testing/wait-for-event.d.ts.map +1 -0
  25. package/development/core/testing.d.ts +1 -0
  26. package/development/core/testing.d.ts.map +1 -1
  27. package/development/core/testing.js +17 -1
  28. package/development/icon/icon.d.ts +9 -1
  29. package/development/icon/icon.d.ts.map +1 -1
  30. package/development/icon.js +16 -2
  31. package/development/menu/menu/menu.d.ts.map +1 -1
  32. package/development/menu/menu.js +2 -1
  33. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  34. package/development/navigation/navigation.js +2 -1
  35. package/development/notification/notification.d.ts +4 -4
  36. package/development/notification.js +1 -1
  37. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  38. package/development/overlay.js +35 -17
  39. package/development/toggle/toggle.js +1 -1
  40. package/icon/icon.d.ts +9 -1
  41. package/icon/icon.d.ts.map +1 -1
  42. package/icon.js +71 -62
  43. package/menu/menu/menu.d.ts.map +1 -1
  44. package/menu/menu.js +3 -3
  45. package/navigation/navigation/navigation.d.ts.map +1 -1
  46. package/navigation/navigation.js +4 -4
  47. package/notification/notification.d.ts +4 -4
  48. package/overlay/overlay-base-element.d.ts.map +1 -1
  49. package/overlay.js +33 -33
  50. package/package.json +1 -1
  51. package/toggle/toggle.js +1 -1
@@ -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: flex;
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
- display: block;
224
- animation-name: open;
231
+ animation-name: open-move-in;
225
232
  animation-duration: var(--sbb-overlay-animation-duration);
226
- animation-timing-function: ease;
233
+ animation-timing-function: var(--sbb-overlay-animation-easing);
227
234
  }
228
235
  :host([data-state][data-state=closing]) .sbb-overlay {
229
- pointer-events: none;
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 class="sbb-overlay__container">
433
- <div
434
- @animationend=${(event) => this.onOverlayAnimationEnd(event)}
435
- class="sbb-overlay"
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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"}
@@ -79,7 +79,7 @@ const style = css`/**
79
79
  }
80
80
 
81
81
  :host([size=m]) {
82
- --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-s);
82
+ --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);
83
83
  --sbb-toggle-height: 2.75rem;
84
84
  }
85
85
  @media (min-width: calc(52.5rem)) {
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 {
@@ -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;AAG1C,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;cAEN,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;cAQzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;CAO/E;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
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 { state as v, property as f, customElement as w } from "lit/decorators.js";
2
- import { isServer as y, css as N, LitElement as I, html as c, nothing as p } from "lit";
3
- import { unsafeHTML as $ } from "lit/directives/unsafe-html.js";
4
- import { until as A } from "lit/directives/until.js";
5
- import { hostAttributes as S } from "./core/decorators.js";
6
- import { readConfig as L } from "./core/config.js";
7
- const C = (t) => typeof t == "string", g = (t) => {
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 o = t.attributes[e].name;
13
- if (C(o) && o.toLowerCase().indexOf("on") === 0)
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 (!g(t.childNodes[e]))
17
+ if (!_(t.childNodes[e]))
18
18
  return !1;
19
19
  }
20
20
  return !0;
21
- }, E = (t, e = !0, o = !1) => {
21
+ }, E = (t, e = !0, i = !1) => {
22
22
  const r = document.createElement("div");
23
23
  r.innerHTML = t;
24
- for (let i = r.childNodes.length - 1; i >= 0; i--)
25
- r.childNodes[i].nodeName.toLowerCase() !== "svg" && r.removeChild(r.childNodes[i]);
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" && (o && !s.classList.contains("color-immutable") && s.classList.add("color-immutable"), e === !1 || g(s)) ? r.innerHTML : "";
28
- }, b = "https://icons.app.sbb.ch/", P = (/* @__PURE__ */ new Map()).set("default", `${b}icons/`).set("picto", `${b}picto/`), m = /* @__PURE__ */ new Map(), O = (t, e, o) => {
29
- var h;
30
- const r = L().icon ?? {}, s = ((h = r.namespaces) == null ? void 0 : h.get(t)) ?? P.get(t);
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 i = `${s}${e}.svg`;
36
- let a = m.get(i);
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: i,
43
- request: () => fetch(i).then(async (l) => {
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(), o);
46
+ return E(await l.text(), i);
47
47
  }).catch((l) => {
48
48
  throw Error(l);
49
49
  })
50
- }), m.set(i, a);
50
+ }), v.set(o, a);
51
51
  else
52
52
  return Promise.resolve("");
53
53
  return a;
54
- }, x = N`*,: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, u = (t, e, o, r) => {
56
- for (var s = r > 1 ? void 0 : r ? M(e, o) : e, i = t.length - 1, a; i >= 0; i--)
57
- (a = t[i]) && (s = (r ? a(e, o, s) : a(s)) || s);
58
- return r && s && z(e, o, s), s;
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 I {
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, o] = this._splitIconName(t);
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, o);
70
- this._svgIcon = r.then((s) => $(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
- >${A(
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
- u([
109
- v()
108
+ d([
109
+ b()
110
110
  ], n.prototype, "_svgNamespace", 2);
111
- u([
112
- v()
111
+ d([
112
+ b()
113
113
  ], n.prototype, "_svgIcon", 2);
114
- u([
115
- f({ attribute: "no-sanitize", type: Boolean })
114
+ d([
115
+ h({ attribute: "no-sanitize", type: Boolean })
116
116
  ], n.prototype, "noSanitize", 2);
117
- n = u([
118
- S({
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, _ = (t, e, o, r) => {
124
- for (var s = r > 1 ? void 0 : r ? j(e, o) : e, i = t.length - 1, a; i >= 0; i--)
125
- (a = t[i]) && (s = (r ? a(e, o, s) : a(s)) || s);
126
- return r && s && U(e, o, s), s;
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 d = class extends n {
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
- f({ reflect: !0 })
144
- ], d.prototype, "name", 2);
145
- d = _([
146
- w("sbb-icon")
147
- ], d);
148
- var T = Object.defineProperty, q = (t, e, o, r) => {
149
- for (var s = void 0, i = t.length - 1, a; i >= 0; i--)
150
- (a = t[i]) && (s = a(e, o, s) || s);
151
- return s && T(e, o, s), s;
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 || p}></sbb-icon>` : p}
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 q([
164
- f({ attribute: "icon-name", reflect: !0 })
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
- d as SbbIconElement,
178
+ u as SbbIconElement,
170
179
  J as SbbIconNameMixin,
171
180
  O as getSvgContent,
172
- g as isValid,
181
+ _ as isValid,
173
182
  E as validateContent
174
183
  };
@@ -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;IAQ5C,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"}
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 D = 0, r = class extends N(k) {
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-${D++}`, B(this._triggerElement, "menu", this.id, this.state), (t = this._menuController) == null || t.abort(), this._menuController = new AbortController(), this._triggerElement.addEventListener("click", () => this.open(), {
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;cAUzB,MAAM,IAAI,cAAc;CAqC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,oBAAoB,CAAC;KACxC;CACF"}
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"}
@@ -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 B = Object.defineProperty, H = Object.getOwnPropertyDescriptor, s = (t, i, n, a) => {
16
- for (var e = a > 1 ? void 0 : a ? H(i, n) : i, r = t.length - 1, b; r >= 0; r--)
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 && B(i, n, e), 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 whenever the `sbb-notification` starts the opening transition.
10
- * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-notification` is opened.
11
- * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-notification` begins the closing transition.
12
- * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-notification` is closed.
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;IAS5C,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"}
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"}