@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.
- package/custom-elements.json +618 -607
- package/development/dialog/dialog/dialog.component.d.ts +2 -0
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +6 -2
- package/dialog/dialog/dialog.component.d.ts +2 -0
- package/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/dialog/dialog/dialog.component.js +14 -10
- package/package.json +1 -1
|
@@ -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;
|
|
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.
|
|
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;
|
|
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 = (
|
|
2
|
-
throw TypeError(
|
|
1
|
+
var C = (e) => {
|
|
2
|
+
throw TypeError(e);
|
|
3
3
|
};
|
|
4
|
-
var E = (
|
|
5
|
-
var v = (
|
|
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
|
|
8
|
-
import { customElement as
|
|
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
|
|
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
|
|
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.
|
|
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,
|
|
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 {
|