@sbb-esta/lyne-elements 3.4.0 → 3.5.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.
@@ -23,6 +23,8 @@ export declare class SbbDialogElement extends SbbOverlayBaseElement {
23
23
  protected closeTag: string;
24
24
  constructor();
25
25
  connectedCallback(): void;
26
+ /** Announce the accessibility label or dialog title for screen readers. */
27
+ announceTitle(): void;
26
28
  protected isZeroAnimationDuration(): boolean;
27
29
  protected handleClosing(): void;
28
30
  protected handleOpening(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAItE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;GAQG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IAC7B,SAA4D,cAAc,EAAE,OAAO,GAAG,MAAM,CAClF;IAEV,wBAAwB;IACxB,SAAoE,QAAQ,EACxE,QAAQ,GACR,aAAa,CAAY;IAM7B,OAAO,CAAC,4BAA4B,CAIjC;IAEH,OAAO,CAAC,qBAAqB,CAAC,CAAc;IAC5C,OAAO,CAAC,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAShD,iBAAiB,IAAI,IAAI;IAKzC,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA2B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAmBZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,kBAAkB;IAa1B,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,oBAAoB;cAKT,MAAM,IAAI,cAAc;CA6B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
1
+ {"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAItE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;GAQG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IAC7B,SAA4D,cAAc,EAAE,OAAO,GAAG,MAAM,CAClF;IAEV,wBAAwB;IACxB,SAAoE,QAAQ,EACxE,QAAQ,GACR,aAAa,CAAY;IAM7B,OAAO,CAAC,4BAA4B,CAIjC;IAEH,OAAO,CAAC,qBAAqB,CAAC,CAAc;IAC5C,OAAO,CAAC,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAShD,iBAAiB,IAAI,IAAI;IAKzC,2EAA2E;IACpE,aAAa,IAAI,IAAI;IAM5B,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA2B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAeZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,kBAAkB;IAa1B,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,oBAAoB;cAKT,MAAM,IAAI,cAAc;CA6B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
@@ -320,6 +320,10 @@ let SbbDialogElement = (() => {
320
320
  this.id ||= `sbb-dialog-${nextId++}`;
321
321
  super.connectedCallback();
322
322
  }
323
+ /** Announce the accessibility label or dialog title for screen readers. */
324
+ announceTitle() {
325
+ this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.innerText.trim());
326
+ }
323
327
  isZeroAnimationDuration() {
324
328
  return isZeroAnimationDuration(this, "--sbb-dialog-animation-duration");
325
329
  }
@@ -352,7 +356,7 @@ let SbbDialogElement = (() => {
352
356
  this.escapableOverlayController.connect();
353
357
  this.attachOpenOverlayEvents();
354
358
  this.focusTrapController.focusInitialElement();
355
- setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.innerText.trim()));
359
+ setTimeout(() => this.announceTitle());
356
360
  this.focusTrapController.enabled = true;
357
361
  if (this._dialogContentElement) {
358
362
  this._dialogContentResizeObserver.observe(this._dialogContentElement);
@@ -436,4 +440,4 @@ let SbbDialogElement = (() => {
436
440
  export {
437
441
  SbbDialogElement
438
442
  };
439
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component.js","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, eventOptions, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport { isZeroAnimationDuration } from '../../core/dom.js';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.js';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot actions - This slot is used for the actions, the slot is automatically assigned to the `sbb-dialog-actions` element.\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @cssprop [--sbb-dialog-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public accessor backdropAction: 'close' | 'none' =\n    'close';\n\n  /** Backdrop density. */\n  @property({ attribute: 'backdrop', reflect: true }) public accessor backdrop:\n    | 'opaque'\n    | 'translucent' = 'opaque';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._updateOverflowState()),\n  });\n\n  private _dialogContentElement?: HTMLElement;\n  private _dialogElement?: HTMLElement;\n  private _isPointerDownEventOnDialog: boolean = false;\n  protected closeAttribute: string = 'sbb-dialog-close';\n  protected override closeTag: string = 'sbb-dialog-close-button';\n\n  public constructor() {\n    super();\n    // Close dialog on backdrop click\n    this.addEventListener?.('pointerdown', this._pointerDownListener);\n    this.addEventListener?.('pointerup', this._closeOnBackdropClick);\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-dialog-${nextId++}`;\n    super.connectedCallback();\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    this._dialogContentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this.inertController.deactivate();\n    if (!this.skipFocusRestoration) {\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n    }\n    this.openOverlayController?.abort();\n    this.focusTrapController.enabled = false;\n    if (this._dialogContentElement) {\n      this._dialogContentResizeObserver.unobserve(this._dialogContentElement);\n    }\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the dialog if no dialog is open\n    if (!overlayRefs.length) {\n      this.scrollHandler.enableScroll();\n    }\n    this.escapableOverlayController.disconnect();\n    this.dispatchCloseEvent({\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    });\n  }\n\n  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.escapableOverlayController.connect();\n    this.attachOpenOverlayEvents();\n    this.focusTrapController.focusInitialElement();\n    // Use timeout to read label after focused element\n    setTimeout(() =>\n      this.setAriaLiveRefContent(\n        this.accessibilityLabel || this.querySelector('sbb-dialog-title')?.innerText.trim(),\n      ),\n    );\n    this.focusTrapController.enabled = true;\n    if (this._dialogContentElement) {\n      this._dialogContentResizeObserver.observe(this._dialogContentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._syncTitleNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncTitleNegative();\n    }\n  }\n\n  private _syncTitleNegative(): void {\n    const dialogTitle = this.querySelector?.('sbb-dialog-title');\n    const closeButton = this.querySelector?.('sbb-dialog-close-button');\n\n    if (dialogTitle) {\n      dialogTitle.negative = this.negative;\n    }\n\n    if (closeButton) {\n      closeButton.negative = this.negative;\n    }\n  }\n\n  /** Check if the pointerdown event target is triggered on the dialog. */\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog =\n      !!this._dialogElement && event.composedPath().includes(this._dialogElement);\n  };\n\n  /** Close dialog on backdrop click. */\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      this.backdropAction === 'close' &&\n      !this._isPointerDownEventOnDialog &&\n      this._dialogElement &&\n      !event.composedPath().includes(this._dialogElement)\n    ) {\n      this.close();\n    }\n  };\n\n  private _updateOverflowState(): void {\n    this.toggleState(\n      'overflows',\n      (this._dialogContentElement?.scrollTop ?? 0) +\n        (this._dialogContentElement?.offsetHeight ?? 0) <\n        (this._dialogContentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  @eventOptions({ passive: true })\n  private _detectScrolledState(): void {\n    this.toggleState('scrolled', (this._dialogContentElement?.scrollTop ?? 0) > 0);\n    this._updateOverflowState();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${this.onOverlayAnimationEnd}\n          class=\"sbb-dialog\"\n          ${ref((el?: Element) => (this._dialogElement = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <div class=\"sbb-dialog-title-section\">\n              <slot name=\"title-section\" @slotchange=${() => this._syncTitleNegative()}></slot>\n            </div>\n            <div\n              class=\"sbb-dialog-content-container\"\n              @scroll=${() => this._detectScrolledState()}\n              ${ref((el?: Element) => (this._dialogContentElement = el as HTMLDivElement))}\n            >\n              <slot></slot>\n            </div>\n            <slot name=\"actions\"></slot>\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-dialog': SbbDialogElement;\n  }\n}\n"],"names":[],"mappings":"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"}
443
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component.js","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, eventOptions, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport { isZeroAnimationDuration } from '../../core/dom.js';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.js';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot actions - This slot is used for the actions, the slot is automatically assigned to the `sbb-dialog-actions` element.\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @cssprop [--sbb-dialog-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public accessor backdropAction: 'close' | 'none' =\n    'close';\n\n  /** Backdrop density. */\n  @property({ attribute: 'backdrop', reflect: true }) public accessor backdrop:\n    | 'opaque'\n    | 'translucent' = 'opaque';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._updateOverflowState()),\n  });\n\n  private _dialogContentElement?: HTMLElement;\n  private _dialogElement?: HTMLElement;\n  private _isPointerDownEventOnDialog: boolean = false;\n  protected closeAttribute: string = 'sbb-dialog-close';\n  protected override closeTag: string = 'sbb-dialog-close-button';\n\n  public constructor() {\n    super();\n    // Close dialog on backdrop click\n    this.addEventListener?.('pointerdown', this._pointerDownListener);\n    this.addEventListener?.('pointerup', this._closeOnBackdropClick);\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-dialog-${nextId++}`;\n    super.connectedCallback();\n  }\n\n  /** Announce the accessibility label or dialog title for screen readers. */\n  public announceTitle(): void {\n    this.setAriaLiveRefContent(\n      this.accessibilityLabel || this.querySelector('sbb-dialog-title')?.innerText.trim(),\n    );\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    this._dialogContentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this.inertController.deactivate();\n    if (!this.skipFocusRestoration) {\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n    }\n    this.openOverlayController?.abort();\n    this.focusTrapController.enabled = false;\n    if (this._dialogContentElement) {\n      this._dialogContentResizeObserver.unobserve(this._dialogContentElement);\n    }\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the dialog if no dialog is open\n    if (!overlayRefs.length) {\n      this.scrollHandler.enableScroll();\n    }\n    this.escapableOverlayController.disconnect();\n    this.dispatchCloseEvent({\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    });\n  }\n\n  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.escapableOverlayController.connect();\n    this.attachOpenOverlayEvents();\n    this.focusTrapController.focusInitialElement();\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n    this.focusTrapController.enabled = true;\n    if (this._dialogContentElement) {\n      this._dialogContentResizeObserver.observe(this._dialogContentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._syncTitleNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncTitleNegative();\n    }\n  }\n\n  private _syncTitleNegative(): void {\n    const dialogTitle = this.querySelector?.('sbb-dialog-title');\n    const closeButton = this.querySelector?.('sbb-dialog-close-button');\n\n    if (dialogTitle) {\n      dialogTitle.negative = this.negative;\n    }\n\n    if (closeButton) {\n      closeButton.negative = this.negative;\n    }\n  }\n\n  /** Check if the pointerdown event target is triggered on the dialog. */\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog =\n      !!this._dialogElement && event.composedPath().includes(this._dialogElement);\n  };\n\n  /** Close dialog on backdrop click. */\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      this.backdropAction === 'close' &&\n      !this._isPointerDownEventOnDialog &&\n      this._dialogElement &&\n      !event.composedPath().includes(this._dialogElement)\n    ) {\n      this.close();\n    }\n  };\n\n  private _updateOverflowState(): void {\n    this.toggleState(\n      'overflows',\n      (this._dialogContentElement?.scrollTop ?? 0) +\n        (this._dialogContentElement?.offsetHeight ?? 0) <\n        (this._dialogContentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  @eventOptions({ passive: true })\n  private _detectScrolledState(): void {\n    this.toggleState('scrolled', (this._dialogContentElement?.scrollTop ?? 0) > 0);\n    this._updateOverflowState();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${this.onOverlayAnimationEnd}\n          class=\"sbb-dialog\"\n          ${ref((el?: Element) => (this._dialogElement = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <div class=\"sbb-dialog-title-section\">\n              <slot name=\"title-section\" @slotchange=${() => this._syncTitleNegative()}></slot>\n            </div>\n            <div\n              class=\"sbb-dialog-content-container\"\n              @scroll=${() => this._detectScrolledState()}\n              ${ref((el?: Element) => (this._dialogContentElement = el as HTMLDivElement))}\n            >\n              <slot></slot>\n            </div>\n            <slot name=\"actions\"></slot>\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-dialog': SbbDialogElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -23,6 +23,8 @@ export declare class SbbDialogElement extends SbbOverlayBaseElement {
23
23
  protected closeTag: string;
24
24
  constructor();
25
25
  connectedCallback(): void;
26
+ /** Announce the accessibility label or dialog title for screen readers. */
27
+ announceTitle(): void;
26
28
  protected isZeroAnimationDuration(): boolean;
27
29
  protected handleClosing(): void;
28
30
  protected handleOpening(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAItE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;GAQG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IAC7B,SAA4D,cAAc,EAAE,OAAO,GAAG,MAAM,CAClF;IAEV,wBAAwB;IACxB,SAAoE,QAAQ,EACxE,QAAQ,GACR,aAAa,CAAY;IAM7B,OAAO,CAAC,4BAA4B,CAIjC;IAEH,OAAO,CAAC,qBAAqB,CAAC,CAAc;IAC5C,OAAO,CAAC,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAShD,iBAAiB,IAAI,IAAI;IAKzC,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA2B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAmBZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,kBAAkB;IAa1B,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,oBAAoB;cAKT,MAAM,IAAI,cAAc;CA6B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
1
+ {"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAItE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;GAQG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IAC7B,SAA4D,cAAc,EAAE,OAAO,GAAG,MAAM,CAClF;IAEV,wBAAwB;IACxB,SAAoE,QAAQ,EACxE,QAAQ,GACR,aAAa,CAAY;IAM7B,OAAO,CAAC,4BAA4B,CAIjC;IAEH,OAAO,CAAC,qBAAqB,CAAC,CAAc;IAC5C,OAAO,CAAC,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAShD,iBAAiB,IAAI,IAAI;IAKzC,2EAA2E;IACpE,aAAa,IAAI,IAAI;IAM5B,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA2B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAeZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,kBAAkB;IAa1B,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,oBAAoB;cAKT,MAAM,IAAI,cAAc;CA6B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
@@ -1,11 +1,11 @@
1
- var C = (o) => {
2
- throw TypeError(o);
1
+ var C = (e) => {
2
+ throw TypeError(e);
3
3
  };
4
- var E = (o, e, i) => e.has(o) || C("Cannot " + i);
5
- var v = (o, e, i) => (E(o, e, "read from private field"), i ? i.call(o) : e.get(o)), g = (o, e, i) => e.has(o) ? C("Cannot add the same private member more than once") : e instanceof WeakSet ? e.add(o) : e.set(o, i), d = (o, e, i, s) => (E(o, e, "write to private field"), s ? s.call(o, i) : e.set(o, i), i);
4
+ var E = (e, o, i) => o.has(e) || C("Cannot " + i);
5
+ var v = (e, o, i) => (E(e, o, "read from private field"), i ? i.call(e) : o.get(e)), g = (e, o, i) => o.has(e) ? C("Cannot add the same private member more than once") : o instanceof WeakSet ? o.add(e) : o.set(e, i), d = (e, o, i, s) => (E(e, o, "write to private field"), s ? s.call(e, i) : o.set(e, i), i);
6
6
  import { __esDecorate as c, __runInitializers as b } from "tslib";
7
- import { ResizeController as z } from "@lit-labs/observers/resize-controller.js";
8
- import { customElement as T, property as S, eventOptions as A } from "lit/decorators.js";
7
+ import { ResizeController as T } from "@lit-labs/observers/resize-controller.js";
8
+ import { customElement as z, property as S, eventOptions as A } from "lit/decorators.js";
9
9
  import { ref as O } from "lit/directives/ref.js";
10
10
  import { html as D } from "lit/static-html.js";
11
11
  import { isZeroAnimationDuration as I } from "../../core/dom.js";
@@ -15,13 +15,13 @@ import "../../screen-reader-only.js";
15
15
  const P = L`*,:before,:after{box-sizing:border-box}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-dialog-padding-inline: var(--sbb-spacing-fixed-5x);--sbb-dialog-color: var(--sbb-color-black);--sbb-dialog-background-color: var(--sbb-color-white);--sbb-dialog-width: 100%;--sbb-dialog-height: 100%;--sbb-dialog-max-width: 100%;--sbb-dialog-max-width-default: 55.75rem;--sbb-dialog-max-height: 100%;--sbb-dialog-inset: 0 auto auto 0;--sbb-dialog-border-radius: var(--sbb-border-radius-8x);--sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);--sbb-dialog-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-dialog-shadow-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );--sbb-dialog-animation-easing: ease;--sbb-dialog-pointer-events: none;--sbb-dialog-backdrop-visibility: hidden;--sbb-dialog-backdrop-pointer-events: none;--sbb-dialog-backdrop-color: transparent;--sbb-dialog-title-gap: var(--sbb-spacing-fixed-2x);--sbb-dialog-close-button-margin: var(--sbb-spacing-fixed-4x);display:none;position:fixed;inset:var(--sbb-dialog-inset);z-index:var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index))}@media (min-width: 22.5rem){:host{--sbb-dialog-padding-inline: var(--sbb-spacing-fixed-6x)}}@media (min-width: 37.5rem){:host{--sbb-dialog-padding-inline: var(--sbb-spacing-fixed-12x)}}@media (min-width: 52.5rem){:host{--sbb-dialog-padding-inline: var(--sbb-spacing-responsive-s);--sbb-dialog-max-width: min( calc(100vw - var(--sbb-spacing-fixed-30x) * 2), var(--sbb-dialog-max-width-default) );--sbb-dialog-max-height: calc(100vh - var(--sbb-spacing-fixed-16x))}}:host([data-state]:not([data-state=closed])){display:block}:host(:is([data-state=opening],[data-state=opened])){--sbb-dialog-pointer-events: all;--sbb-dialog-backdrop-color: var(--sbb-color-milk)}@media (min-width: 52.5rem){:host(:is([data-state=opening],[data-state=opened])){--sbb-dialog-backdrop-visibility: visible;--sbb-dialog-backdrop-pointer-events: all}}:host([backdrop=translucent]:is([data-state=opening],[data-state=opened])){--sbb-dialog-backdrop-color: var(--sbb-color-black-alpha-50)}:host([negative]){--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);--sbb-dialog-color: var(--sbb-color-white);--sbb-dialog-background-color: var(--sbb-color-midnight);--sbb-dialog-backdrop-color: var(--sbb-color-charcoal)}:host(:not([data-state=closed])){--sbb-dialog-inset: 0}.sbb-dialog__container{pointer-events:var(--sbb-dialog-pointer-events);display:flex;align-items:center;position:fixed;inset:var(--sbb-dialog-inset)}.sbb-dialog__container:before{content:"";visibility:var(--sbb-dialog-backdrop-visibility);pointer-events:var(--sbb-dialog-backdrop-pointer-events);position:fixed;inset:var(--sbb-dialog-inset);background-color:var(--sbb-dialog-backdrop-color);transition-duration:var(--sbb-dialog-animation-duration);transition-timing-function:var(--sbb-dialog-animation-easing);transition-property:background-color,visibility}.sbb-dialog{display:none;position:absolute;inset-inline:0;margin:auto;padding:0;border:none;width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height);color:var(--sbb-dialog-color);background-color:var(--sbb-dialog-background-color)}:host([data-state]:not([data-state=closed])) .sbb-dialog{display:block;animation-name:open;animation-duration:var(--sbb-dialog-animation-duration);animation-timing-function:ease}:host([data-state][data-state=closing]) .sbb-dialog{pointer-events:none;animation-name:close}@media (forced-colors: active){.sbb-dialog{outline:var(--sbb-border-width-1x) solid CanvasText}}@media (min-width: 52.5rem){.sbb-dialog{border-radius:var(--sbb-dialog-border-radius);overflow:hidden;height:auto}}.sbb-dialog__wrapper{display:flex;flex-direction:column;width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height)}.sbb-dialog-title-section{display:flex;width:100%;gap:var(--sbb-dialog-title-gap);background-color:var(--sbb-dialog-background-color);padding-inline:var(--sbb-dialog-padding);transition:box-shadow var(--sbb-animation-easing) var(--sbb-dialog-shadow-animation-duration);box-shadow:none}:host(:not([negative]):is(:state(scrolled),[state--scrolled])) .sbb-dialog-title-section{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-soft-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-soft-1-color)}:host([negative]:is(:state(scrolled),[state--scrolled])) .sbb-dialog-title-section{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-soft-negative-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-soft-negative-1-color)}.sbb-dialog-content-container{--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-dialog-content-container::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-dialog-content-container::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-dialog-content-container::-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-dialog-content-container::-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-dialog-content-container::-webkit-scrollbar-button,.sbb-dialog-content-container::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-dialog-content-container{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-dialog-content-container{overflow:auto}@keyframes open{0%{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}to{opacity:1;translate:0}}@keyframes close{0%{opacity:1;translate:0}to{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}}::slotted(sbb-dialog-title){flex-grow:1;margin-block:var(--sbb-dialog-padding-block)}::slotted(sbb-dialog-close-button){order:1;margin-inline-end:var(--sbb-dialog-close-button-margin);margin-block-start:calc(var(--sbb-dialog-padding-block) + .5 * (var(--sbb-typo-line-height-titles) * var(--_sbb-dialog-title-size, var(--sbb-font-size-title-4)) - var(--sbb-size-element-xs)));inset-inline-end:var(--sbb-dialog-close-button-margin)}`;
16
16
  let q = 0, M = (() => {
17
17
  var r, n, l;
18
- let o = [T("sbb-dialog")], e, i = [], s, p = R, m = [], u, w = [], f = [], k, _ = [], x = [], y;
18
+ let e = [z("sbb-dialog")], o, i = [], s, p = R, m = [], u, w = [], f = [], k, _ = [], x = [], y;
19
19
  return l = class extends p {
20
20
  constructor() {
21
21
  super();
22
22
  g(this, r);
23
23
  g(this, n);
24
- d(this, r, (b(this, m), b(this, w, "close"))), d(this, n, (b(this, f), b(this, _, "opaque"))), this._dialogContentResizeObserver = (b(this, x), new z(this, {
24
+ d(this, r, (b(this, m), b(this, w, "close"))), d(this, n, (b(this, f), b(this, _, "opaque"))), this._dialogContentResizeObserver = (b(this, x), new T(this, {
25
25
  target: null,
26
26
  skipInitial: !0,
27
27
  callback: () => setTimeout(() => this._updateOverflowState())
@@ -48,6 +48,10 @@ let q = 0, M = (() => {
48
48
  connectedCallback() {
49
49
  this.id ||= `sbb-dialog-${q++}`, super.connectedCallback();
50
50
  }
51
+ /** Announce the accessibility label or dialog title for screen readers. */
52
+ announceTitle() {
53
+ this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.innerText.trim());
54
+ }
51
55
  isZeroAnimationDuration() {
52
56
  return I(this, "--sbb-dialog-animation-duration");
53
57
  }
@@ -58,7 +62,7 @@ let q = 0, M = (() => {
58
62
  });
59
63
  }
60
64
  handleOpening() {
61
- this.state = "opened", this.inertController.activate(), this.escapableOverlayController.connect(), this.attachOpenOverlayEvents(), this.focusTrapController.focusInitialElement(), setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.innerText.trim())), this.focusTrapController.enabled = !0, this._dialogContentElement && this._dialogContentResizeObserver.observe(this._dialogContentElement), this.dispatchOpenEvent();
65
+ this.state = "opened", this.inertController.activate(), this.escapableOverlayController.connect(), this.attachOpenOverlayEvents(), this.focusTrapController.focusInitialElement(), setTimeout(() => this.announceTitle()), this.focusTrapController.enabled = !0, this._dialogContentElement && this._dialogContentResizeObserver.observe(this._dialogContentElement), this.dispatchOpenEvent();
62
66
  }
63
67
  firstUpdated(a) {
64
68
  super.firstUpdated(a), this._syncTitleNegative();
@@ -111,7 +115,7 @@ let q = 0, M = (() => {
111
115
  t.backdropAction = h;
112
116
  } }, metadata: a }, w, f), c(l, null, k, { kind: "accessor", name: "backdrop", static: !1, private: !1, access: { has: (t) => "backdrop" in t, get: (t) => t.backdrop, set: (t, h) => {
113
117
  t.backdrop = h;
114
- } }, metadata: a }, _, x), c(l, null, y, { kind: "method", name: "_detectScrolledState", static: !1, private: !1, access: { has: (t) => "_detectScrolledState" in t, get: (t) => t._detectScrolledState }, metadata: a }, null, m), c(null, e = { value: s }, o, { kind: "class", name: s.name, metadata: a }, null, i), s = e.value, a && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
118
+ } }, metadata: a }, _, x), c(l, null, y, { kind: "method", name: "_detectScrolledState", static: !1, private: !1, access: { has: (t) => "_detectScrolledState" in t, get: (t) => t._detectScrolledState }, metadata: a }, null, m), c(null, o = { value: s }, e, { kind: "class", name: s.name, metadata: a }, null, i), s = o.value, a && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: a });
115
119
  })(), l.styles = P, b(s, i), s;
116
120
  })();
117
121
  export {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "3.4.0",
3
+ "version": "3.5.0",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",