@sbb-esta/lyne-elements 4.10.0 → 4.11.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 (73) hide show
  1. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +1 -1
  2. package/breadcrumb/breadcrumb-group.js +1 -1
  3. package/{breadcrumb-group.component-Cc6CHbVy.js → breadcrumb-group.component-F3-JZkfO.js} +1 -1
  4. package/breadcrumb.js +1 -1
  5. package/breadcrumb.pure.js +1 -1
  6. package/calendar/calendar/calendar.component.js +1 -1
  7. package/calendar/calendar.js +1 -1
  8. package/{calendar.component-DhmaJt2k.js → calendar.component-DjQOyRGl.js} +2 -2
  9. package/calendar.js +1 -1
  10. package/calendar.pure.js +1 -1
  11. package/core/base-elements/element.js +1 -1
  12. package/core/styles/mixins/table.scss +18 -19
  13. package/core/styles/theme.scss +3 -1
  14. package/custom-elements.json +986 -959
  15. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +1 -1
  16. package/development/breadcrumb/breadcrumb-group.js +1 -1
  17. package/development/breadcrumb-group.component-HBWRdDpS.js +195 -0
  18. package/development/breadcrumb.js +1 -1
  19. package/development/breadcrumb.pure.js +1 -1
  20. package/development/core/base-elements/element.d.ts.map +1 -1
  21. package/development/core/base-elements/element.js +2 -5
  22. package/development/dialog/dialog/dialog.component.js +1 -1
  23. package/development/dialog/dialog.js +1 -1
  24. package/development/{dialog.component-TBiL0Sdq.js → dialog.component-DKuR4u-y.js} +2 -2
  25. package/development/dialog.js +1 -1
  26. package/development/dialog.pure.js +1 -1
  27. package/development/expansion-panel/expansion-panel/expansion-panel.component.js +1 -1
  28. package/development/expansion-panel/expansion-panel.js +1 -1
  29. package/development/{expansion-panel.component-PDUmZe7w.js → expansion-panel.component-CV_IuWZA.js} +2 -2
  30. package/development/expansion-panel.js +1 -1
  31. package/development/expansion-panel.pure.js +1 -1
  32. package/development/form-field/form-field/form-field.component.d.ts +6 -0
  33. package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
  34. package/development/form-field/form-field/form-field.component.js +1 -1
  35. package/development/form-field/form-field.js +1 -1
  36. package/development/form-field.component-DfMO_ihX.js +706 -0
  37. package/development/form-field.js +1 -1
  38. package/development/form-field.pure.js +1 -1
  39. package/development/sidebar/sidebar/sidebar.component.d.ts +1 -0
  40. package/development/sidebar/sidebar/sidebar.component.d.ts.map +1 -1
  41. package/development/sidebar/sidebar/sidebar.component.js +1 -1
  42. package/development/sidebar/sidebar.js +1 -1
  43. package/development/{sidebar.component-DvRTyNry.js → sidebar.component-BLqO52nH.js} +8 -1
  44. package/development/sidebar.js +1 -1
  45. package/development/sidebar.pure.js +1 -1
  46. package/dialog/dialog/dialog.component.js +1 -1
  47. package/dialog/dialog.js +1 -1
  48. package/{dialog.component-B3oQbMki.js → dialog.component-Dv5ch5mh.js} +1 -1
  49. package/dialog.js +1 -1
  50. package/dialog.pure.js +1 -1
  51. package/expansion-panel/expansion-panel/expansion-panel.component.js +1 -1
  52. package/expansion-panel/expansion-panel.js +1 -1
  53. package/{expansion-panel.component-BJCjwcoj.js → expansion-panel.component-DBnZ6IgB.js} +1 -1
  54. package/expansion-panel.js +1 -1
  55. package/expansion-panel.pure.js +1 -1
  56. package/form-field/form-field/form-field.component.js +1 -1
  57. package/form-field/form-field.js +1 -1
  58. package/{form-field.component-D50q1wC0.js → form-field.component-Cx5Keg_p.js} +15 -15
  59. package/form-field.js +1 -1
  60. package/form-field.pure.js +1 -1
  61. package/off-brand-theme.css +32 -37
  62. package/package.json +1 -1
  63. package/safety-theme.css +32 -37
  64. package/sidebar/sidebar/sidebar.component.js +1 -1
  65. package/sidebar/sidebar.js +1 -1
  66. package/{sidebar.component-DxOx02l6.js → sidebar.component-Dsx1FAg0.js} +5 -3
  67. package/sidebar.js +1 -1
  68. package/sidebar.pure.js +1 -1
  69. package/standard-theme.css +32 -37
  70. package/table.css +32 -37
  71. package/core/styles/table.scss +0 -156
  72. package/development/breadcrumb-group.component-B3Shlng3.js +0 -195
  73. package/development/form-field.component-BEXX0OcL.js +0 -702
@@ -1,2 +1,2 @@
1
- import { t as SbbBreadcrumbGroupElement } from "../../breadcrumb-group.component-B3Shlng3.js";
1
+ import { t as SbbBreadcrumbGroupElement } from "../../breadcrumb-group.component-HBWRdDpS.js";
2
2
  export { SbbBreadcrumbGroupElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbBreadcrumbGroupElement } from "../breadcrumb-group.component-B3Shlng3.js";
1
+ import { t as SbbBreadcrumbGroupElement } from "../breadcrumb-group.component-HBWRdDpS.js";
2
2
  //#region src/elements/breadcrumb/breadcrumb-group.ts
3
3
  /** @entrypoint */
4
4
  SbbBreadcrumbGroupElement.define();
@@ -0,0 +1,195 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { html, nothing, unsafeCSS } from "lit";
3
+ import { state } from "lit/decorators.js";
4
+ import { SbbElement } from "./core/base-elements.js";
5
+ import { SbbNamedSlotListMixin } from "./core/mixins.js";
6
+ import { boxSizingStyles } from "./core/styles.js";
7
+ import { SbbLanguageController } from "./core/controllers.js";
8
+ import { i18nBreadcrumbEllipsisButtonLabel } from "./core/i18n.js";
9
+ import "./icon.js";
10
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
11
+ import { getNextElementIndex, isArrowKeyPressed, sbbInputModalityDetector } from "./core/a11y.js";
12
+ //#region src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.scss?inline
13
+ var breadcrumb_group_default = ":host {\n display: block;\n min-width: 0;\n}\n\n:host(:is(:state(loaded),[state--loaded])) {\n --sbb-breadcrumb-group-visibility: visible;\n}\n\n:host(:is(:is(:state(state-collapsed),[state--state-collapsed]), :is(:state(state-manually-expanded),[state--state-manually-expanded]))) {\n --sbb-breadcrumb-group-wrap: wrap;\n}\n\n.sbb-breadcrumb-group {\n list-style: none;\n margin: 0;\n padding: 0;\n font-size: inherit;\n display: flex;\n flex-wrap: var(--sbb-breadcrumb-group-wrap);\n column-gap: var(--sbb-spacing-fixed-1x);\n visibility: var(--sbb-breadcrumb-group-visibility);\n}\n\n.sbb-breadcrumb-group__item {\n flex: 0 0 auto;\n display: flex;\n column-gap: var(--sbb-spacing-fixed-1x);\n}\n\n.sbb-breadcrumb-group__divider-icon {\n color: var(--sbb-breadcrumb-group-ellipsis-color);\n}\n\n#sbb-breadcrumb-ellipsis {\n appearance: none;\n box-sizing: border-box;\n margin: 0;\n outline: none;\n border: none;\n border-radius: 0;\n padding: 0;\n background: none;\n -webkit-tap-highlight-color: transparent;\n color: inherit;\n --sbb-text-font-size: var(--sbb-text-font-size-xxs);\n font-family: var(--sbb-typo-font-family);\n font-weight: normal;\n line-height: var(--sbb-typo-line-height-text);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n font-size: var(--sbb-text-font-size);\n line-height: 0;\n letter-spacing: 0.01em;\n width: var(--sbb-size-icon-ui-small);\n height: var(--sbb-size-icon-ui-small);\n border: var(--sbb-breadcrumb-group-ellipsis-border-width) solid var(--sbb-breadcrumb-group-ellipsis-border-color);\n border-radius: 50%;\n padding-block-end: 0.5em;\n cursor: var(--sbb-cursor-pointer);\n color: var(--sbb-breadcrumb-group-ellipsis-color);\n background-color: var(--sbb-breadcrumb-group-ellipsis-background-color);\n overflow: hidden;\n}\n@media (forced-colors: active) {\n #sbb-breadcrumb-ellipsis {\n --sbb-breadcrumb-group-ellipsis-border-width: var(--sbb-border-width-2x);\n --sbb-breadcrumb-group-ellipsis-border-color: CanvasText;\n }\n}\n@media (any-hover: hover) {\n #sbb-breadcrumb-ellipsis:hover {\n --sbb-breadcrumb-group-ellipsis-color: var(--sbb-color-2);\n --sbb-breadcrumb-group-ellipsis-background-color: var(--sbb-background-color-3);\n }\n}\n@media (any-hover: hover) and (forced-colors: active) {\n #sbb-breadcrumb-ellipsis:hover {\n --sbb-breadcrumb-group-ellipsis-border-color: Highlight;\n }\n}\n#sbb-breadcrumb-ellipsis:focus-visible {\n outline-offset: var(--sbb-focus-outline-offset);\n outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);\n}";
14
+ //#endregion
15
+ //#region src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.component.ts
16
+ var MIN_BREADCRUMBS_TO_COLLAPSE = 3;
17
+ /**
18
+ * It can be used as a container for one or more `sbb-breadcrumb` component.
19
+ *
20
+ * @slot - Use the unnamed slot to add `sbb-breadcrumb` elements.
21
+ */
22
+ var SbbBreadcrumbGroupElement = (() => {
23
+ let _classSuper = SbbNamedSlotListMixin(SbbElement);
24
+ let _instanceExtraInitializers = [];
25
+ let _set__state_decorators;
26
+ return class SbbBreadcrumbGroupElement extends _classSuper {
27
+ static {
28
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
29
+ _set__state_decorators = [state()];
30
+ __esDecorate(this, null, _set__state_decorators, {
31
+ kind: "setter",
32
+ name: "_state",
33
+ static: false,
34
+ private: false,
35
+ access: {
36
+ has: (obj) => "_state" in obj,
37
+ set: (obj, value) => {
38
+ obj._state = value;
39
+ }
40
+ },
41
+ metadata: _metadata
42
+ }, null, _instanceExtraInitializers);
43
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
44
+ enumerable: true,
45
+ configurable: true,
46
+ writable: true,
47
+ value: _metadata
48
+ });
49
+ }
50
+ static {
51
+ this.elementName = "sbb-breadcrumb-group";
52
+ }
53
+ static {
54
+ this.role = "navigation";
55
+ }
56
+ static {
57
+ this.styles = [boxSizingStyles, unsafeCSS(breadcrumb_group_default)];
58
+ }
59
+ /** The state of the breadcrumb group. */
60
+ set _state(state) {
61
+ if (this._stateInternal) this.internals.states.delete(`state-${this._stateInternal}`);
62
+ this._stateInternal = state;
63
+ if (this._stateInternal) this.internals.states.add(`state-${this._stateInternal}`);
64
+ }
65
+ get _state() {
66
+ return this._stateInternal;
67
+ }
68
+ constructor() {
69
+ super();
70
+ this.listChildLocalNames = (__runInitializers(this, _instanceExtraInitializers), ["sbb-breadcrumb"]);
71
+ this._stateInternal = null;
72
+ this._resizeObserver = new ResizeController(this, {
73
+ target: null,
74
+ skipInitial: true,
75
+ callback: () => this._evaluateCollapsedState()
76
+ });
77
+ this._language = new SbbLanguageController(this);
78
+ this._markForFocus = false;
79
+ this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
80
+ }
81
+ _handleKeyDown(evt) {
82
+ if (!this.listChildren.length || evt.target !== this && evt.target.parentElement !== this) return;
83
+ if (isArrowKeyPressed(evt)) {
84
+ if (this._state === "collapsed") return this._focusNextCollapsed(evt);
85
+ this._focusNext(evt);
86
+ }
87
+ }
88
+ firstUpdated(changedProperties) {
89
+ super.firstUpdated(changedProperties);
90
+ this._resizeObserver.observe(this);
91
+ this.internals.states.add("loaded");
92
+ }
93
+ willUpdate(changedProperties) {
94
+ super.willUpdate(changedProperties);
95
+ if (changedProperties.has("listChildren")) this._syncBreadcrumbs();
96
+ }
97
+ updated(changedProperties) {
98
+ super.updated(changedProperties);
99
+ if (changedProperties.has("listChildren")) Promise.resolve().then(() => this._evaluateCollapsedState());
100
+ if (this._markForFocus && sbbInputModalityDetector.mostRecentModality === "keyboard") {
101
+ this.listChildren[1]?.focus();
102
+ this._markForFocus = false;
103
+ }
104
+ }
105
+ /** Apply the aria-current attribute to the last sbb-breadcrumb element. */
106
+ _syncBreadcrumbs() {
107
+ this.listChildren.slice(0, -1).filter((c) => c.hasAttribute("accessibility-current")).forEach((c) => c.removeAttribute("accessibility-current"));
108
+ this.listChildren[this.listChildren.length - 1]?.setAttribute("accessibility-current", "page");
109
+ if (this.listChildren.length < MIN_BREADCRUMBS_TO_COLLAPSE) this._state = null;
110
+ }
111
+ /**
112
+ * Sets the focus on the correct element when the ellipsis breadcrumb is displayed and the user is navigating with keyboard's arrows.
113
+ */
114
+ _focusNextCollapsed(evt) {
115
+ const arrayCollapsed = [
116
+ this.listChildren[0],
117
+ this.shadowRoot.querySelector("#sbb-breadcrumb-ellipsis"),
118
+ this.listChildren[this.listChildren.length - 1]
119
+ ];
120
+ this._focusNext(evt, arrayCollapsed);
121
+ }
122
+ _focusNext(evt, breadcrumbs = this.listChildren) {
123
+ breadcrumbs[getNextElementIndex(evt, breadcrumbs.findIndex((e) => e === document.activeElement || e === this.shadowRoot.activeElement), breadcrumbs.length)]?.focus();
124
+ evt.preventDefault();
125
+ }
126
+ /**
127
+ * Note: due to @State annotation on _state, this method triggers a new render; as a consequence, the focus is moved
128
+ * to the `body`, so if the ellipsis element has focus, it's asynchronously forced to the first element.
129
+ */
130
+ _expandBreadcrumbs() {
131
+ this._state = "manually-expanded";
132
+ this._markForFocus = true;
133
+ }
134
+ /** Evaluate if the expanded breadcrumb element fits in page width, otherwise it needs ellipsis */
135
+ _evaluateCollapsedState() {
136
+ if (!this._state && this.scrollWidth > this.offsetWidth && this.listChildren.length >= MIN_BREADCRUMBS_TO_COLLAPSE) {
137
+ this._state = "collapsed";
138
+ this._resizeObserver.hostDisconnected();
139
+ this.removeController(this._resizeObserver);
140
+ }
141
+ }
142
+ _renderCollapsed() {
143
+ return html`
144
+ <li class="sbb-breadcrumb-group__item">
145
+ <slot name="li-0"></slot>
146
+ </li>
147
+ <li class="sbb-breadcrumb-group__item" id="sbb-breadcrumb-group-ellipsis">
148
+ <sbb-icon
149
+ name="chevron-small-right-small"
150
+ class="sbb-breadcrumb-group__divider-icon"
151
+ ></sbb-icon>
152
+ <button
153
+ type="button"
154
+ id="sbb-breadcrumb-ellipsis"
155
+ aria-label=${i18nBreadcrumbEllipsisButtonLabel[this._language.current]}
156
+ aria-expanded="false"
157
+ @click=${() => this._expandBreadcrumbs()}
158
+ >
159
+ ...
160
+ </button>
161
+ </li>
162
+ <li class="sbb-breadcrumb-group__item">
163
+ <sbb-icon
164
+ name="chevron-small-right-small"
165
+ class="sbb-breadcrumb-group__divider-icon"
166
+ ></sbb-icon>
167
+ <slot name=${`li-${this.listChildren.length - 1}`}></slot>
168
+ </li>
169
+ `;
170
+ }
171
+ _renderExpanded() {
172
+ return this.listSlotEntries().map((slot, index, array) => html`
173
+ <li class="sbb-breadcrumb-group__item">
174
+ <slot name=${slot.name}></slot>
175
+ ${index !== array.length - 1 ? html`<sbb-icon
176
+ name="chevron-small-right-small"
177
+ class="sbb-breadcrumb-group__divider-icon"
178
+ ></sbb-icon>` : nothing}
179
+ </li>
180
+ `);
181
+ }
182
+ render() {
183
+ return html`
184
+ <ol class="sbb-breadcrumb-group">
185
+ ${this._state === "collapsed" ? this._renderCollapsed() : this._renderExpanded()}
186
+ </ol>
187
+ ${this.renderHiddenSlot()}
188
+ `;
189
+ }
190
+ };
191
+ })();
192
+ //#endregion
193
+ export { SbbBreadcrumbGroupElement as t };
194
+
195
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"breadcrumb-group.component-HBWRdDpS.js","names":[],"sources":["../../../src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.scss?inline","../../../src/elements/breadcrumb/breadcrumb-group/breadcrumb-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  display: block;\n\n  // Allows size calculation even if in grid or flex context.\n  min-width: 0;\n}\n\n:host(:state(loaded)) {\n  --sbb-breadcrumb-group-visibility: visible;\n}\n\n:host(:is(:state(state-collapsed), :state(state-manually-expanded))) {\n  --sbb-breadcrumb-group-wrap: wrap;\n}\n\n.sbb-breadcrumb-group {\n  @include sbb.list-reset;\n\n  display: flex;\n  flex-wrap: var(--sbb-breadcrumb-group-wrap);\n  column-gap: var(--sbb-spacing-fixed-1x);\n  visibility: var(--sbb-breadcrumb-group-visibility);\n}\n\n.sbb-breadcrumb-group__item {\n  flex: 0 0 auto;\n  display: flex;\n  column-gap: var(--sbb-spacing-fixed-1x);\n}\n\n.sbb-breadcrumb-group__divider-icon {\n  color: var(--sbb-breadcrumb-group-ellipsis-color);\n}\n\n#sbb-breadcrumb-ellipsis {\n  @include sbb.button-reset;\n  @include sbb.text-xxs--regular;\n\n  // line height and letter-spacing needed to match squares drawn in Figma.\n  line-height: 0;\n  letter-spacing: 0.01em;\n  width: var(--sbb-size-icon-ui-small);\n  height: var(--sbb-size-icon-ui-small);\n  border: var(--sbb-breadcrumb-group-ellipsis-border-width) solid\n    var(--sbb-breadcrumb-group-ellipsis-border-color);\n  border-radius: 50%;\n\n  // In order to vertically center ..., we use padding with half the font size.\n  padding-block-end: 0.5em;\n  cursor: var(--sbb-cursor-pointer);\n  color: var(--sbb-breadcrumb-group-ellipsis-color);\n  background-color: var(--sbb-breadcrumb-group-ellipsis-background-color);\n  overflow: hidden;\n\n  @include sbb.if-forced-colors {\n    --sbb-breadcrumb-group-ellipsis-border-width: var(--sbb-border-width-2x);\n    --sbb-breadcrumb-group-ellipsis-border-color: CanvasText;\n  }\n\n  @include sbb.hover-mq($hover: true) {\n    &:hover {\n      --sbb-breadcrumb-group-ellipsis-color: var(--sbb-color-2);\n      --sbb-breadcrumb-group-ellipsis-background-color: var(--sbb-background-color-3);\n\n      @include sbb.if-forced-colors {\n        --sbb-breadcrumb-group-ellipsis-border-color: Highlight;\n      }\n    }\n  }\n\n  &:focus-visible {\n    @include sbb.focus-outline;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport {\n  getNextElementIndex,\n  isArrowKeyPressed,\n  sbbInputModalityDetector,\n} from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { i18nBreadcrumbEllipsisButtonLabel } from '../../core/i18n.ts';\nimport { SbbNamedSlotListMixin, type WithListChildren } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbBreadcrumbElement } from '../breadcrumb/breadcrumb.component.ts';\n\nimport style from './breadcrumb-group.scss?inline';\n\nimport '../../icon.ts';\n\nconst MIN_BREADCRUMBS_TO_COLLAPSE = 3;\n\n/**\n * It can be used as a container for one or more `sbb-breadcrumb` component.\n *\n * @slot - Use the unnamed slot to add `sbb-breadcrumb` elements.\n */\nexport class SbbBreadcrumbGroupElement extends SbbNamedSlotListMixin<\n  SbbBreadcrumbElement,\n  typeof SbbElement\n>(SbbElement) {\n  public static override readonly elementName: string = 'sbb-breadcrumb-group';\n  public static override readonly role = 'navigation';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  protected override readonly listChildLocalNames = ['sbb-breadcrumb'];\n\n  /** The state of the breadcrumb group. */\n  @state()\n  private set _state(state: 'collapsed' | 'manually-expanded' | null) {\n    if (this._stateInternal) {\n      this.internals.states.delete(`state-${this._stateInternal}`);\n    }\n    this._stateInternal = state;\n    if (this._stateInternal) {\n      this.internals.states.add(`state-${this._stateInternal}`);\n    }\n  }\n  private get _state(): 'collapsed' | 'manually-expanded' | null {\n    return this._stateInternal;\n  }\n  private _stateInternal: 'collapsed' | 'manually-expanded' | null = null;\n\n  private _resizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._evaluateCollapsedState(),\n  });\n  private _language = new SbbLanguageController(this);\n  private _markForFocus = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    if (\n      !this.listChildren.length ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      if (this._state === 'collapsed') {\n        return this._focusNextCollapsed(evt);\n      }\n      this._focusNext(evt);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._resizeObserver.observe(this);\n    this.internals.states.add('loaded');\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('listChildren')) {\n      this._syncBreadcrumbs();\n    }\n  }\n\n  protected override updated(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.updated(changedProperties);\n    if (changedProperties.has('listChildren')) {\n      Promise.resolve().then(() => this._evaluateCollapsedState());\n    }\n    if (this._markForFocus && sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n      this.listChildren[1]?.focus();\n\n      // Reset mark for focus\n      this._markForFocus = false;\n    }\n  }\n\n  /** Apply the aria-current attribute to the last sbb-breadcrumb element. */\n  private _syncBreadcrumbs(): void {\n    this.listChildren\n      .slice(0, -1)\n      .filter((c) => c.hasAttribute('accessibility-current'))\n      .forEach((c) => c.removeAttribute('accessibility-current'));\n    this.listChildren[this.listChildren.length - 1]?.setAttribute('accessibility-current', 'page');\n\n    // If it is not expandable, reset state\n    if (this.listChildren.length < MIN_BREADCRUMBS_TO_COLLAPSE) {\n      this._state = null;\n    }\n  }\n\n  /**\n   * Sets the focus on the correct element when the ellipsis breadcrumb is displayed and the user is navigating with keyboard's arrows.\n   */\n  private _focusNextCollapsed(evt: KeyboardEvent): void {\n    const arrayCollapsed: SbbBreadcrumbElement[] = [\n      this.listChildren[0],\n      this.shadowRoot!.querySelector('#sbb-breadcrumb-ellipsis') as SbbBreadcrumbElement,\n      this.listChildren[this.listChildren.length - 1],\n    ];\n    this._focusNext(evt, arrayCollapsed);\n  }\n\n  private _focusNext(\n    evt: KeyboardEvent,\n    breadcrumbs: SbbBreadcrumbElement[] = this.listChildren,\n  ): void {\n    const current: number = breadcrumbs.findIndex(\n      (e) => e === document.activeElement || e === this.shadowRoot!.activeElement,\n    );\n    const nextIndex: number = getNextElementIndex(evt, current, breadcrumbs.length);\n    breadcrumbs[nextIndex]?.focus();\n    evt.preventDefault();\n  }\n\n  /**\n   * Note: due to @State annotation on _state, this method triggers a new render; as a consequence, the focus is moved\n   * to the `body`, so if the ellipsis element has focus, it's asynchronously forced to the first element.\n   */\n  private _expandBreadcrumbs(): void {\n    this._state = 'manually-expanded';\n    this._markForFocus = true;\n  }\n\n  /** Evaluate if the expanded breadcrumb element fits in page width, otherwise it needs ellipsis */\n  private _evaluateCollapsedState(): void {\n    if (\n      !this._state &&\n      this.scrollWidth > this.offsetWidth &&\n      this.listChildren.length >= MIN_BREADCRUMBS_TO_COLLAPSE\n    ) {\n      this._state = 'collapsed';\n      this._resizeObserver.hostDisconnected();\n      this.removeController(this._resizeObserver);\n    }\n  }\n\n  private _renderCollapsed(): TemplateResult {\n    return html`\n      <li class=\"sbb-breadcrumb-group__item\">\n        <slot name=\"li-0\"></slot>\n      </li>\n      <li class=\"sbb-breadcrumb-group__item\" id=\"sbb-breadcrumb-group-ellipsis\">\n        <sbb-icon\n          name=\"chevron-small-right-small\"\n          class=\"sbb-breadcrumb-group__divider-icon\"\n        ></sbb-icon>\n        <button\n          type=\"button\"\n          id=\"sbb-breadcrumb-ellipsis\"\n          aria-label=${i18nBreadcrumbEllipsisButtonLabel[this._language.current]}\n          aria-expanded=\"false\"\n          @click=${() => this._expandBreadcrumbs()}\n        >\n          ...\n        </button>\n      </li>\n      <li class=\"sbb-breadcrumb-group__item\">\n        <sbb-icon\n          name=\"chevron-small-right-small\"\n          class=\"sbb-breadcrumb-group__divider-icon\"\n        ></sbb-icon>\n        <slot name=${`li-${this.listChildren.length - 1}`}></slot>\n      </li>\n    `;\n  }\n\n  private _renderExpanded(): TemplateResult[] {\n    return this.listSlotEntries().map(\n      (slot, index, array) => html`\n        <li class=\"sbb-breadcrumb-group__item\">\n          <slot name=${slot.name}></slot>\n          ${index !== array.length - 1\n            ? html`<sbb-icon\n                name=\"chevron-small-right-small\"\n                class=\"sbb-breadcrumb-group__divider-icon\"\n              ></sbb-icon>`\n            : nothing}\n        </li>\n      `,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <ol class=\"sbb-breadcrumb-group\">\n        ${this._state === 'collapsed' ? this._renderCollapsed() : this._renderExpanded()}\n      </ol>\n      ${this.renderHiddenSlot()}\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-breadcrumb-group': SbbBreadcrumbGroupElement;\n  }\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { t as SbbBreadcrumbGroupElement } from "./breadcrumb-group.component-B3Shlng3.js";
1
+ import { t as SbbBreadcrumbGroupElement } from "./breadcrumb-group.component-HBWRdDpS.js";
2
2
  import { t as SbbBreadcrumbElement } from "./breadcrumb.component-DxSUxLZO.js";
3
3
  import "./breadcrumb.pure.js";
4
4
  //#region src/elements/breadcrumb.ts
@@ -1,3 +1,3 @@
1
- import { t as SbbBreadcrumbGroupElement } from "./breadcrumb-group.component-B3Shlng3.js";
1
+ import { t as SbbBreadcrumbGroupElement } from "./breadcrumb-group.component-HBWRdDpS.js";
2
2
  import { t as SbbBreadcrumbElement } from "./breadcrumb.component-DxSUxLZO.js";
3
3
  export { SbbBreadcrumbElement, SbbBreadcrumbGroupElement };
@@ -1 +1 @@
1
- {"version":3,"file":"element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/base-elements/element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,KAAK,mBAAmB,EAAE,KAAK,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAKpF,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,qBAAsB,SAAQ,kBAAkB;IAC/D,kBAAkB,CAAC,CACjB,IAAI,EAAE,WAAW,EACjB,MAAM,CAAC,EAAE,iBAAiB,EAC1B,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI,CAAC;CACT;;AAED;;GAEG;AAEH,qBAAa,UAAW,SAAQ,eAAuD;IACrF,OAAc,CAAC,eAAe,CAAC,UAAQ;IACvC,gBAAuB,WAAW,EAAE,MAAM,CAAC;IAE3C,OAAO,CAAC,YAAY,CAAC,CAA6B;IAElD;;;;;OAKG;WACW,MAAM,CAAC,qBAAqB,GAAE,qBAAsC,GAAG,IAAI;IAoBzF;;;;;;;OAOG;IACa,aAAa,CAAC,UAAU,EAAE,qBAAqB,GAAG,IAAI;IAKtE;;OAEG;IACa,gBAAgB,CAAC,UAAU,EAAE,qBAAqB,GAAG,IAAI;IAKzE;;;;;;;;;;;;;;;;;;OAkBG;IACa,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,EAC7B,WAAW,CAAC,EAAE,OAAO,EACrB,QAAQ,CAAC,EAAE,OAAO,GACjB,IAAI;CAYR"}
1
+ {"version":3,"file":"element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/base-elements/element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,KAAK,mBAAmB,EAAE,KAAK,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAKpF,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,qBAAsB,SAAQ,kBAAkB;IAC/D,kBAAkB,CAAC,CACjB,IAAI,EAAE,WAAW,EACjB,MAAM,CAAC,EAAE,iBAAiB,EAC1B,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI,CAAC;CACT;;AAED;;GAEG;AAEH,qBAAa,UAAW,SAAQ,eAAuD;IACrF,OAAc,CAAC,eAAe,CAAC,UAAQ;IACvC,gBAAuB,WAAW,EAAE,MAAM,CAAC;IAE3C,OAAO,CAAC,YAAY,CAAC,CAA6B;IAElD;;;;;OAKG;WACW,MAAM,CAAC,qBAAqB,GAAE,qBAAsC,GAAG,IAAI;IAiBzF;;;;;;;OAOG;IACa,aAAa,CAAC,UAAU,EAAE,qBAAqB,GAAG,IAAI;IAKtE;;OAEG;IACa,gBAAgB,CAAC,UAAU,EAAE,qBAAqB,GAAG,IAAI;IAKzE;;;;;;;;;;;;;;;;;;OAkBG;IACa,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,EAC7B,WAAW,CAAC,EAAE,OAAO,EACrB,QAAQ,CAAC,EAAE,OAAO,GACjB,IAAI;CAYR"}
@@ -17,10 +17,7 @@ var SbbElement = class extends SbbHydrationMixin(SbbElementInternalsMixin(LitEle
17
17
  */
18
18
  static define(customElementRegistry = customElements) {
19
19
  if (!this.elementName) throw new Error(`The static property "elementName" is not defined on ${this.name}. Please define it to register the custom element.`);
20
- if (!customElementRegistry.get(this.elementName)) {
21
- customElementRegistry.define(this.elementName, this);
22
- this.finalize();
23
- }
20
+ if (!customElementRegistry.get(this.elementName)) customElementRegistry.define(this.elementName, this);
24
21
  }
25
22
  /**
26
23
  * Registers a `ReactiveController` to participate in the element's reactive
@@ -74,4 +71,4 @@ var SbbElement = class extends SbbHydrationMixin(SbbElementInternalsMixin(LitEle
74
71
  //#endregion
75
72
  export { SbbElement };
76
73
 
77
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29yZS9iYXNlLWVsZW1lbnRzL2VsZW1lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGl0RWxlbWVudCwgdHlwZSBQcm9wZXJ0eURlY2xhcmF0aW9uLCB0eXBlIFJlYWN0aXZlQ29udHJvbGxlciB9IGZyb20gJ2xpdCc7XG5cbmltcG9ydCB7IFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbiB9IGZyb20gJy4uL21peGlucy9lbGVtZW50LWludGVybmFscy1taXhpbi50cyc7XG5pbXBvcnQgeyBTYmJIeWRyYXRpb25NaXhpbiB9IGZyb20gJy4uL21peGlucy9oeWRyYXRpb24tbWl4aW4udHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNiYlByb3BlcnR5VmFsdWVzIHtcbiAgb2xkVmFsdWU/OiB1bmtub3duO1xuICB2YWx1ZT86IHVua25vd247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2JiUmVhY3RpdmVDb250cm9sbGVyIGV4dGVuZHMgUmVhY3RpdmVDb250cm9sbGVyIHtcbiAgaG9zdFByb3BlcnR5VXBkYXRlPyhcbiAgICBuYW1lOiBQcm9wZXJ0eUtleSxcbiAgICB2YWx1ZXM/OiBTYmJQcm9wZXJ0eVZhbHVlcyxcbiAgICBvcHRpb25zPzogUHJvcGVydHlEZWNsYXJhdGlvbixcbiAgKTogdm9pZDtcbn1cblxuLyoqXG4gKiBBIGJhc2UgY2xhc3MgZm9yIGFsbCBTQkIgZWxlbWVudHMuXG4gKi9cbi8vIFRPRE8oYnJlYWtpbmctY2hhbmdlKTogSW5saW5lIGFuZCByZW1vdmUgU2JiRWxlbWVudEludGVybmFsc01peGluIGFuZCBTYmJIeWRyYXRpb25NaXhpbiBhcyBhIGJyZWFraW5nIGNoYW5nZVxuZXhwb3J0IGNsYXNzIFNiYkVsZW1lbnQgZXh0ZW5kcyBTYmJIeWRyYXRpb25NaXhpbihTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4oTGl0RWxlbWVudCkpIHtcbiAgcHVibGljIHN0YXRpYyBbJ18kc2JiRWxlbWVudCQnXSA9IHRydWU7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZztcblxuICBwcml2YXRlIF9jb250cm9sbGVycz86IFNldDxTYmJSZWFjdGl2ZUNvbnRyb2xsZXI+O1xuXG4gIC8qKlxuICAgKiBSZWdpc3RlciB0aGUgY3VzdG9tIGVsZW1lbnQgdG8gdGhlIHNwZWNpZmllZCBDdXN0b21FbGVtZW50UmVnaXN0cnkuXG4gICAqIElmIG5vbmUgaXMgcHJvdmlkZWQsIGRlZmF1bHRzIHRvIHRoZSBnbG9iYWwgYGN1c3RvbUVsZW1lbnRzYCByZWdpc3RyeS5cbiAgICogQHBhcmFtIGN1c3RvbUVsZW1lbnRSZWdpc3RyeSBPcHRpb25hbCBDdXN0b21FbGVtZW50UmVnaXN0cnkgdG8gcmVnaXN0ZXIgdGhpcyBlbGVtZW50IHRvLlxuICAgKiAgIERlZmF1bHRzIHRvIHRoZSBnbG9iYWwgYGN1c3RvbUVsZW1lbnRzYCBpbnN0YW5jZS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZGVmaW5lKGN1c3RvbUVsZW1lbnRSZWdpc3RyeTogQ3VzdG9tRWxlbWVudFJlZ2lzdHJ5ID0gY3VzdG9tRWxlbWVudHMpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuZWxlbWVudE5hbWUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYFRoZSBzdGF0aWMgcHJvcGVydHkgXCJlbGVtZW50TmFtZVwiIGlzIG5vdCBkZWZpbmVkIG9uICR7dGhpcy5uYW1lfS4gUGxlYXNlIGRlZmluZSBpdCB0byByZWdpc3RlciB0aGUgY3VzdG9tIGVsZW1lbnQuYCxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgY29uc3QgZWxlbWVudENsYXNzID0gY3VzdG9tRWxlbWVudFJlZ2lzdHJ5LmdldCh0aGlzLmVsZW1lbnROYW1lKTtcbiAgICBpZiAoIWVsZW1lbnRDbGFzcykge1xuICAgICAgY3VzdG9tRWxlbWVudFJlZ2lzdHJ5LmRlZmluZSh0aGlzLmVsZW1lbnROYW1lLCB0aGlzIGFzIHVua25vd24gYXMgQ3VzdG9tRWxlbWVudENvbnN0cnVjdG9yKTtcbiAgICAgIC8vIE5leHQuanMgcmUtcmVuZGVyaW5nIHNvbWVob3cgZmFpbHMsIGJlY2F1c2UgdGhlIGZpbmFsaXphdGlvbiBjYWxjdWxhdGlvblxuICAgICAgLy8gaXMgYnJva2VuIGluIFNTUi4gV2UgY2FsbCBgZmluYWxpemUoKWAgaGVyZSBleHBsaWNpdGx5IHRvIGF2b2lkIHRoYXQuXG4gICAgICB0aGlzLmZpbmFsaXplKCk7XG4gICAgfSBlbHNlIGlmIChpbXBvcnQubWV0YS5lbnYuREVWICYmIGVsZW1lbnRDbGFzcyAhPT0gdGhpcykge1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICBgVGhlIGN1c3RvbSBlbGVtZW50IHdpdGggbmFtZSBcIiR7dGhpcy5lbGVtZW50TmFtZX1cIiBpcyBhbHJlYWR5IGRlZmluZWQuIFNraXBwaW5nLmAsXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBSZWdpc3RlcnMgYSBgUmVhY3RpdmVDb250cm9sbGVyYCB0byBwYXJ0aWNpcGF0ZSBpbiB0aGUgZWxlbWVudCdzIHJlYWN0aXZlXG4gICAqIHVwZGF0ZSBjeWNsZS4gVGhlIGVsZW1lbnQgYXV0b21hdGljYWxseSBjYWxscyBpbnRvIGFueSByZWdpc3RlcmVkXG4gICAqIGNvbnRyb2xsZXJzIGR1cmluZyBpdHMgbGlmZWN5Y2xlIGNhbGxiYWNrcy5cbiAgICpcbiAgICogSWYgdGhlIGVsZW1lbnQgaXMgY29ubmVjdGVkIHdoZW4gYGFkZENvbnRyb2xsZXIoKWAgaXMgY2FsbGVkLCB0aGVcbiAgICogY29udHJvbGxlcidzIGBob3N0Q29ubmVjdGVkKClgIGNhbGxiYWNrIHdpbGwgYmUgaW1tZWRpYXRlbHkgY2FsbGVkLlxuICAgKi9cbiAgcHVibGljIG92ZXJyaWRlIGFkZENvbnRyb2xsZXIoY29udHJvbGxlcjogU2JiUmVhY3RpdmVDb250cm9sbGVyKTogdm9pZCB7XG4gICAgc3VwZXIuYWRkQ29udHJvbGxlcihjb250cm9sbGVyKTtcbiAgICAodGhpcy5fY29udHJvbGxlcnMgPz89IG5ldyBTZXQoKSkuYWRkKGNvbnRyb2xsZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlbW92ZXMgYSBgUmVhY3RpdmVDb250cm9sbGVyYCBmcm9tIHRoZSBlbGVtZW50LlxuICAgKi9cbiAgcHVibGljIG92ZXJyaWRlIHJlbW92ZUNvbnRyb2xsZXIoY29udHJvbGxlcjogU2JiUmVhY3RpdmVDb250cm9sbGVyKTogdm9pZCB7XG4gICAgc3VwZXIucmVtb3ZlQ29udHJvbGxlcihjb250cm9sbGVyKTtcbiAgICB0aGlzLl9jb250cm9sbGVycz8uZGVsZXRlKGNvbnRyb2xsZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlcXVlc3RzIGFuIHVwZGF0ZSB3aGljaCBpcyBwcm9jZXNzZWQgYXN5bmNocm9ub3VzbHkuIFRoaXMgc2hvdWxkIGJlIGNhbGxlZFxuICAgKiB3aGVuIGFuIGVsZW1lbnQgc2hvdWxkIHVwZGF0ZSBiYXNlZCBvbiBzb21lIHN0YXRlIG5vdCB0cmlnZ2VyZWQgYnkgc2V0dGluZ1xuICAgKiBhIHJlYWN0aXZlIHByb3BlcnR5LiBJbiB0aGlzIGNhc2UsIHBhc3Mgbm8gYXJndW1lbnRzLiBJdCBzaG91bGQgYWxzbyBiZVxuICAgKiBjYWxsZWQgd2hlbiBtYW51YWxseSBpbXBsZW1lbnRpbmcgYSBwcm9wZXJ0eSBzZXR0ZXIuIEluIHRoaXMgY2FzZSwgcGFzcyB0aGVcbiAgICogcHJvcGVydHkgYG5hbWVgIGFuZCBgb2xkVmFsdWVgIHRvIGVuc3VyZSB0aGF0IGFueSBjb25maWd1cmVkIHByb3BlcnR5XG4gICAqIG9wdGlvbnMgYXJlIGhvbm9yZWQuXG4gICAqXG4gICAqIEBwYXJhbSBuYW1lIG5hbWUgb2YgcmVxdWVzdGluZyBwcm9wZXJ0eVxuICAgKiBAcGFyYW0gb2xkVmFsdWUgb2xkIHZhbHVlIG9mIHJlcXVlc3RpbmcgcHJvcGVydHlcbiAgICogQHBhcmFtIG9wdGlvbnMgcHJvcGVydHkgb3B0aW9ucyB0byB1c2UgaW5zdGVhZCBvZiB0aGUgcHJldmlvdXNseVxuICAgKiAgICAgY29uZmlndXJlZCBvcHRpb25zXG4gICAqIEBwYXJhbSB1c2VOZXdWYWx1ZSBpZiB0cnVlLCB0aGUgbmV3VmFsdWUgYXJndW1lbnQgaXMgdXNlZCBpbnN0ZWFkIG9mXG4gICAqICAgICByZWFkaW5nIHRoZSBwcm9wZXJ0eSB2YWx1ZS4gVGhpcyBpcyBpbXBvcnRhbnQgdG8gdXNlIGlmIHRoZSByZWFjdGl2ZVxuICAgKiAgICAgcHJvcGVydHkgaXMgYSBzdGFuZGFyZCBwcml2YXRlIGFjY2Vzc29yLCBhcyBvcHBvc2VkIHRvIGEgcGxhaW5cbiAgICogICAgIHByb3BlcnR5LCBzaW5jZSBwcml2YXRlIG1lbWJlcnMgY2FuJ3QgYmUgZHluYW1pY2FsbHkgcmVhZCBieSBuYW1lLlxuICAgKiBAcGFyYW0gbmV3VmFsdWUgdGhlIG5ldyB2YWx1ZSBvZiB0aGUgcHJvcGVydHkuIFRoaXMgaXMgb25seSB1c2VkIGlmXG4gICAqICAgICBgdXNlTmV3VmFsdWVgIGlzIHRydWUuXG4gICAqL1xuICBwdWJsaWMgb3ZlcnJpZGUgcmVxdWVzdFVwZGF0ZShcbiAgICBuYW1lPzogUHJvcGVydHlLZXksXG4gICAgb2xkVmFsdWU/OiB1bmtub3duLFxuICAgIG9wdGlvbnM/OiBQcm9wZXJ0eURlY2xhcmF0aW9uLFxuICAgIHVzZU5ld1ZhbHVlPzogYm9vbGVhbixcbiAgICBuZXdWYWx1ZT86IHVua25vd24sXG4gICk6IHZvaWQge1xuICAgIHN1cGVyLnJlcXVlc3RVcGRhdGUobmFtZSwgb2xkVmFsdWUsIG9wdGlvbnMsIHVzZU5ld1ZhbHVlLCBuZXdWYWx1ZSk7XG4gICAgaWYgKG5hbWUpIHtcbiAgICAgIGNvbnN0IHZhbHVlczogU2JiUHJvcGVydHlWYWx1ZXMgPSB7XG4gICAgICAgIG9sZFZhbHVlLFxuICAgICAgICB2YWx1ZTogdXNlTmV3VmFsdWUgPyBuZXdWYWx1ZSA6IHRoaXNbbmFtZSBhcyBrZXlvZiB0aGlzXSxcbiAgICAgIH07XG4gICAgICB0aGlzLl9jb250cm9sbGVycz8uZm9yRWFjaCgoY29udHJvbGxlcikgPT5cbiAgICAgICAgY29udHJvbGxlci5ob3N0UHJvcGVydHlVcGRhdGU/LihuYW1lLCB2YWx1ZXMsIG9wdGlvbnMpLFxuICAgICAgKTtcbiAgICB9XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQXNCQSxJQUFhLGFBQWIsY0FBZ0Msa0JBQWtCLHlCQUF5QixXQUFXLENBQUMsQ0FBQTs7QUFDdkUsT0FBQyxtQkFBbUI7Ozs7Ozs7O0NBVzNCLE9BQU8sT0FBTyx3QkFBK0MsZ0JBQWM7QUFDaEYsTUFBSSxDQUFDLEtBQUssWUFDUixPQUFNLElBQUksTUFDUix1REFBdUQsS0FBSyxLQUFJLG9EQUNqRTtBQUlILE1BQUksQ0FEaUIsc0JBQXNCLElBQUksS0FBSyxZQUFZLEVBQzdDO0FBQ2pCLHlCQUFzQixPQUFPLEtBQUssYUFBYSxLQUE0QztBQUczRixRQUFLLFVBQVU7Ozs7Ozs7Ozs7O0NBZ0JILGNBQWMsWUFBaUM7QUFDN0QsUUFBTSxjQUFjLFdBQVc7QUFDL0IsR0FBQyxLQUFLLGlDQUFpQixJQUFJLEtBQUssRUFBRSxJQUFJLFdBQVc7Ozs7O0NBTW5DLGlCQUFpQixZQUFpQztBQUNoRSxRQUFNLGlCQUFpQixXQUFXO0FBQ2xDLE9BQUssY0FBYyxPQUFPLFdBQVc7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQXNCdkIsY0FDZCxNQUNBLFVBQ0EsU0FDQSxhQUNBLFVBQWtCO0FBRWxCLFFBQU0sY0FBYyxNQUFNLFVBQVUsU0FBUyxhQUFhLFNBQVM7QUFDbkUsTUFBSSxNQUFNO0dBQ1IsTUFBTSxTQUE0QjtJQUNoQztJQUNBLE9BQU8sY0FBYyxXQUFXLEtBQUs7SUFDdEM7QUFDRCxRQUFLLGNBQWMsU0FBUyxlQUMxQixXQUFXLHFCQUFxQixNQUFNLFFBQVEsUUFBUSxDQUN2RCJ9
74
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvY29yZS9iYXNlLWVsZW1lbnRzL2VsZW1lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGl0RWxlbWVudCwgdHlwZSBQcm9wZXJ0eURlY2xhcmF0aW9uLCB0eXBlIFJlYWN0aXZlQ29udHJvbGxlciB9IGZyb20gJ2xpdCc7XG5cbmltcG9ydCB7IFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbiB9IGZyb20gJy4uL21peGlucy9lbGVtZW50LWludGVybmFscy1taXhpbi50cyc7XG5pbXBvcnQgeyBTYmJIeWRyYXRpb25NaXhpbiB9IGZyb20gJy4uL21peGlucy9oeWRyYXRpb24tbWl4aW4udHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNiYlByb3BlcnR5VmFsdWVzIHtcbiAgb2xkVmFsdWU/OiB1bmtub3duO1xuICB2YWx1ZT86IHVua25vd247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2JiUmVhY3RpdmVDb250cm9sbGVyIGV4dGVuZHMgUmVhY3RpdmVDb250cm9sbGVyIHtcbiAgaG9zdFByb3BlcnR5VXBkYXRlPyhcbiAgICBuYW1lOiBQcm9wZXJ0eUtleSxcbiAgICB2YWx1ZXM/OiBTYmJQcm9wZXJ0eVZhbHVlcyxcbiAgICBvcHRpb25zPzogUHJvcGVydHlEZWNsYXJhdGlvbixcbiAgKTogdm9pZDtcbn1cblxuLyoqXG4gKiBBIGJhc2UgY2xhc3MgZm9yIGFsbCBTQkIgZWxlbWVudHMuXG4gKi9cbi8vIFRPRE8oYnJlYWtpbmctY2hhbmdlKTogSW5saW5lIGFuZCByZW1vdmUgU2JiRWxlbWVudEludGVybmFsc01peGluIGFuZCBTYmJIeWRyYXRpb25NaXhpbiBhcyBhIGJyZWFraW5nIGNoYW5nZVxuZXhwb3J0IGNsYXNzIFNiYkVsZW1lbnQgZXh0ZW5kcyBTYmJIeWRyYXRpb25NaXhpbihTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4oTGl0RWxlbWVudCkpIHtcbiAgcHVibGljIHN0YXRpYyBbJ18kc2JiRWxlbWVudCQnXSA9IHRydWU7XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZztcblxuICBwcml2YXRlIF9jb250cm9sbGVycz86IFNldDxTYmJSZWFjdGl2ZUNvbnRyb2xsZXI+O1xuXG4gIC8qKlxuICAgKiBSZWdpc3RlciB0aGUgY3VzdG9tIGVsZW1lbnQgdG8gdGhlIHNwZWNpZmllZCBDdXN0b21FbGVtZW50UmVnaXN0cnkuXG4gICAqIElmIG5vbmUgaXMgcHJvdmlkZWQsIGRlZmF1bHRzIHRvIHRoZSBnbG9iYWwgYGN1c3RvbUVsZW1lbnRzYCByZWdpc3RyeS5cbiAgICogQHBhcmFtIGN1c3RvbUVsZW1lbnRSZWdpc3RyeSBPcHRpb25hbCBDdXN0b21FbGVtZW50UmVnaXN0cnkgdG8gcmVnaXN0ZXIgdGhpcyBlbGVtZW50IHRvLlxuICAgKiAgIERlZmF1bHRzIHRvIHRoZSBnbG9iYWwgYGN1c3RvbUVsZW1lbnRzYCBpbnN0YW5jZS5cbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgZGVmaW5lKGN1c3RvbUVsZW1lbnRSZWdpc3RyeTogQ3VzdG9tRWxlbWVudFJlZ2lzdHJ5ID0gY3VzdG9tRWxlbWVudHMpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuZWxlbWVudE5hbWUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYFRoZSBzdGF0aWMgcHJvcGVydHkgXCJlbGVtZW50TmFtZVwiIGlzIG5vdCBkZWZpbmVkIG9uICR7dGhpcy5uYW1lfS4gUGxlYXNlIGRlZmluZSBpdCB0byByZWdpc3RlciB0aGUgY3VzdG9tIGVsZW1lbnQuYCxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgY29uc3QgZWxlbWVudENsYXNzID0gY3VzdG9tRWxlbWVudFJlZ2lzdHJ5LmdldCh0aGlzLmVsZW1lbnROYW1lKTtcbiAgICBpZiAoIWVsZW1lbnRDbGFzcykge1xuICAgICAgY3VzdG9tRWxlbWVudFJlZ2lzdHJ5LmRlZmluZSh0aGlzLmVsZW1lbnROYW1lLCB0aGlzIGFzIHVua25vd24gYXMgQ3VzdG9tRWxlbWVudENvbnN0cnVjdG9yKTtcbiAgICB9IGVsc2UgaWYgKGltcG9ydC5tZXRhLmVudi5ERVYgJiYgZWxlbWVudENsYXNzICE9PSB0aGlzKSB7XG4gICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgIGBUaGUgY3VzdG9tIGVsZW1lbnQgd2l0aCBuYW1lIFwiJHt0aGlzLmVsZW1lbnROYW1lfVwiIGlzIGFscmVhZHkgZGVmaW5lZC4gU2tpcHBpbmcuYCxcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJlZ2lzdGVycyBhIGBSZWFjdGl2ZUNvbnRyb2xsZXJgIHRvIHBhcnRpY2lwYXRlIGluIHRoZSBlbGVtZW50J3MgcmVhY3RpdmVcbiAgICogdXBkYXRlIGN5Y2xlLiBUaGUgZWxlbWVudCBhdXRvbWF0aWNhbGx5IGNhbGxzIGludG8gYW55IHJlZ2lzdGVyZWRcbiAgICogY29udHJvbGxlcnMgZHVyaW5nIGl0cyBsaWZlY3ljbGUgY2FsbGJhY2tzLlxuICAgKlxuICAgKiBJZiB0aGUgZWxlbWVudCBpcyBjb25uZWN0ZWQgd2hlbiBgYWRkQ29udHJvbGxlcigpYCBpcyBjYWxsZWQsIHRoZVxuICAgKiBjb250cm9sbGVyJ3MgYGhvc3RDb25uZWN0ZWQoKWAgY2FsbGJhY2sgd2lsbCBiZSBpbW1lZGlhdGVseSBjYWxsZWQuXG4gICAqL1xuICBwdWJsaWMgb3ZlcnJpZGUgYWRkQ29udHJvbGxlcihjb250cm9sbGVyOiBTYmJSZWFjdGl2ZUNvbnRyb2xsZXIpOiB2b2lkIHtcbiAgICBzdXBlci5hZGRDb250cm9sbGVyKGNvbnRyb2xsZXIpO1xuICAgICh0aGlzLl9jb250cm9sbGVycyA/Pz0gbmV3IFNldCgpKS5hZGQoY29udHJvbGxlcik7XG4gIH1cblxuICAvKipcbiAgICogUmVtb3ZlcyBhIGBSZWFjdGl2ZUNvbnRyb2xsZXJgIGZyb20gdGhlIGVsZW1lbnQuXG4gICAqL1xuICBwdWJsaWMgb3ZlcnJpZGUgcmVtb3ZlQ29udHJvbGxlcihjb250cm9sbGVyOiBTYmJSZWFjdGl2ZUNvbnRyb2xsZXIpOiB2b2lkIHtcbiAgICBzdXBlci5yZW1vdmVDb250cm9sbGVyKGNvbnRyb2xsZXIpO1xuICAgIHRoaXMuX2NvbnRyb2xsZXJzPy5kZWxldGUoY29udHJvbGxlcik7XG4gIH1cblxuICAvKipcbiAgICogUmVxdWVzdHMgYW4gdXBkYXRlIHdoaWNoIGlzIHByb2Nlc3NlZCBhc3luY2hyb25vdXNseS4gVGhpcyBzaG91bGQgYmUgY2FsbGVkXG4gICAqIHdoZW4gYW4gZWxlbWVudCBzaG91bGQgdXBkYXRlIGJhc2VkIG9uIHNvbWUgc3RhdGUgbm90IHRyaWdnZXJlZCBieSBzZXR0aW5nXG4gICAqIGEgcmVhY3RpdmUgcHJvcGVydHkuIEluIHRoaXMgY2FzZSwgcGFzcyBubyBhcmd1bWVudHMuIEl0IHNob3VsZCBhbHNvIGJlXG4gICAqIGNhbGxlZCB3aGVuIG1hbnVhbGx5IGltcGxlbWVudGluZyBhIHByb3BlcnR5IHNldHRlci4gSW4gdGhpcyBjYXNlLCBwYXNzIHRoZVxuICAgKiBwcm9wZXJ0eSBgbmFtZWAgYW5kIGBvbGRWYWx1ZWAgdG8gZW5zdXJlIHRoYXQgYW55IGNvbmZpZ3VyZWQgcHJvcGVydHlcbiAgICogb3B0aW9ucyBhcmUgaG9ub3JlZC5cbiAgICpcbiAgICogQHBhcmFtIG5hbWUgbmFtZSBvZiByZXF1ZXN0aW5nIHByb3BlcnR5XG4gICAqIEBwYXJhbSBvbGRWYWx1ZSBvbGQgdmFsdWUgb2YgcmVxdWVzdGluZyBwcm9wZXJ0eVxuICAgKiBAcGFyYW0gb3B0aW9ucyBwcm9wZXJ0eSBvcHRpb25zIHRvIHVzZSBpbnN0ZWFkIG9mIHRoZSBwcmV2aW91c2x5XG4gICAqICAgICBjb25maWd1cmVkIG9wdGlvbnNcbiAgICogQHBhcmFtIHVzZU5ld1ZhbHVlIGlmIHRydWUsIHRoZSBuZXdWYWx1ZSBhcmd1bWVudCBpcyB1c2VkIGluc3RlYWQgb2ZcbiAgICogICAgIHJlYWRpbmcgdGhlIHByb3BlcnR5IHZhbHVlLiBUaGlzIGlzIGltcG9ydGFudCB0byB1c2UgaWYgdGhlIHJlYWN0aXZlXG4gICAqICAgICBwcm9wZXJ0eSBpcyBhIHN0YW5kYXJkIHByaXZhdGUgYWNjZXNzb3IsIGFzIG9wcG9zZWQgdG8gYSBwbGFpblxuICAgKiAgICAgcHJvcGVydHksIHNpbmNlIHByaXZhdGUgbWVtYmVycyBjYW4ndCBiZSBkeW5hbWljYWxseSByZWFkIGJ5IG5hbWUuXG4gICAqIEBwYXJhbSBuZXdWYWx1ZSB0aGUgbmV3IHZhbHVlIG9mIHRoZSBwcm9wZXJ0eS4gVGhpcyBpcyBvbmx5IHVzZWQgaWZcbiAgICogICAgIGB1c2VOZXdWYWx1ZWAgaXMgdHJ1ZS5cbiAgICovXG4gIHB1YmxpYyBvdmVycmlkZSByZXF1ZXN0VXBkYXRlKFxuICAgIG5hbWU/OiBQcm9wZXJ0eUtleSxcbiAgICBvbGRWYWx1ZT86IHVua25vd24sXG4gICAgb3B0aW9ucz86IFByb3BlcnR5RGVjbGFyYXRpb24sXG4gICAgdXNlTmV3VmFsdWU/OiBib29sZWFuLFxuICAgIG5ld1ZhbHVlPzogdW5rbm93bixcbiAgKTogdm9pZCB7XG4gICAgc3VwZXIucmVxdWVzdFVwZGF0ZShuYW1lLCBvbGRWYWx1ZSwgb3B0aW9ucywgdXNlTmV3VmFsdWUsIG5ld1ZhbHVlKTtcbiAgICBpZiAobmFtZSkge1xuICAgICAgY29uc3QgdmFsdWVzOiBTYmJQcm9wZXJ0eVZhbHVlcyA9IHtcbiAgICAgICAgb2xkVmFsdWUsXG4gICAgICAgIHZhbHVlOiB1c2VOZXdWYWx1ZSA/IG5ld1ZhbHVlIDogdGhpc1tuYW1lIGFzIGtleW9mIHRoaXNdLFxuICAgICAgfTtcbiAgICAgIHRoaXMuX2NvbnRyb2xsZXJzPy5mb3JFYWNoKChjb250cm9sbGVyKSA9PlxuICAgICAgICBjb250cm9sbGVyLmhvc3RQcm9wZXJ0eVVwZGF0ZT8uKG5hbWUsIHZhbHVlcywgb3B0aW9ucyksXG4gICAgICApO1xuICAgIH1cbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBc0JBLElBQWEsYUFBYixjQUFnQyxrQkFBa0IseUJBQXlCLFdBQVcsQ0FBQyxDQUFBOztBQUN2RSxPQUFDLG1CQUFtQjs7Ozs7Ozs7Q0FXM0IsT0FBTyxPQUFPLHdCQUErQyxnQkFBYztBQUNoRixNQUFJLENBQUMsS0FBSyxZQUNSLE9BQU0sSUFBSSxNQUNSLHVEQUF1RCxLQUFLLEtBQUksb0RBQ2pFO0FBSUgsTUFBSSxDQURpQixzQkFBc0IsSUFBSSxLQUFLLFlBQVksQ0FFOUQsdUJBQXNCLE9BQU8sS0FBSyxhQUFhLEtBQTRDOzs7Ozs7Ozs7O0NBZ0IvRSxjQUFjLFlBQWlDO0FBQzdELFFBQU0sY0FBYyxXQUFXO0FBQy9CLEdBQUMsS0FBSyxpQ0FBaUIsSUFBSSxLQUFLLEVBQUUsSUFBSSxXQUFXOzs7OztDQU1uQyxpQkFBaUIsWUFBaUM7QUFDaEUsUUFBTSxpQkFBaUIsV0FBVztBQUNsQyxPQUFLLGNBQWMsT0FBTyxXQUFXOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FzQnZCLGNBQ2QsTUFDQSxVQUNBLFNBQ0EsYUFDQSxVQUFrQjtBQUVsQixRQUFNLGNBQWMsTUFBTSxVQUFVLFNBQVMsYUFBYSxTQUFTO0FBQ25FLE1BQUksTUFBTTtHQUNSLE1BQU0sU0FBNEI7SUFDaEM7SUFDQSxPQUFPLGNBQWMsV0FBVyxLQUFLO0lBQ3RDO0FBQ0QsUUFBSyxjQUFjLFNBQVMsZUFDMUIsV0FBVyxxQkFBcUIsTUFBTSxRQUFRLFFBQVEsQ0FDdkQifQ==
@@ -1,2 +1,2 @@
1
- import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "../../dialog.component-TBiL0Sdq.js";
1
+ import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "../../dialog.component-DKuR4u-y.js";
2
2
  export { SbbDialogCloseEvent, SbbDialogElement, assignDialogResult };
@@ -1,4 +1,4 @@
1
- import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "../dialog.component-TBiL0Sdq.js";
1
+ import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "../dialog.component-DKuR4u-y.js";
2
2
  //#region src/elements/dialog/dialog.ts
3
3
  /** @entrypoint */
4
4
  SbbDialogElement.define();
@@ -129,7 +129,7 @@ var SbbDialogElement = (() => {
129
129
  }
130
130
  /** Announce the accessibility label or dialog title for screen readers. */
131
131
  announceTitle() {
132
- this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.innerText.trim());
132
+ this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.textContent.trim());
133
133
  }
134
134
  isZeroAnimationDuration() {
135
135
  return isZeroAnimationDuration(this, "--sbb-dialog-animation-duration");
@@ -234,4 +234,4 @@ var SbbDialogElement = (() => {
234
234
  //#endregion
235
235
  export { SbbDialogElement as n, assignDialogResult as r, SbbDialogCloseEvent as t };
236
236
 
237
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component-TBiL0Sdq.js","names":[],"sources":["../../../src/elements/dialog/dialog/dialog.scss?inline","../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-dialog-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);\n  --sbb-dialog-shadow-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n\n  display: none;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n  z-index: var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index));\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-max-width: min(\n      calc(100vw - var(--sbb-spacing-fixed-30x) * 2),\n      var(--sbb-dialog-max-width-default)\n    );\n  }\n}\n\n:host(:state(top-shadow)) {\n  --sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow);\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  display: block;\n}\n\n:host(:is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-pointer-events: all;\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-backdrop-visibility: visible;\n    --sbb-dialog-backdrop-pointer-events: all;\n  }\n}\n\n:host([backdrop='translucent']:is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent);\n}\n\n:host([backdrop='opaque']:not([negative]):is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n}\n\n:host(:not([negative])) {\n  --_sbb-dialog-color: var(--sbb-dialog-color);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4);\n  --sbb-dialog-background-color: var(--sbb-background-color-1);\n}\n\n:host([negative]) {\n  --_sbb-dialog-color: var(--sbb-dialog-color-negative);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);\n  --sbb-dialog-background-color: var(--sbb-background-color-1-negative);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:state(bottom-shadow)) {\n  --sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: transparent;\n}\n\n:host(:not(:state(state-closed))) {\n  --sbb-dialog-inset: 0;\n}\n\n.sbb-dialog__container {\n  pointer-events: var(--sbb-dialog-pointer-events);\n  display: flex;\n  align-items: center;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n\n  // Dialog backdrop (not visible on mobile)\n  &::before {\n    content: '';\n    visibility: var(--sbb-dialog-backdrop-visibility);\n    pointer-events: var(--sbb-dialog-backdrop-pointer-events);\n    position: fixed;\n    inset: var(--sbb-dialog-inset);\n    background-color: var(--sbb-dialog-backdrop-color);\n    transition: {\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: var(--sbb-dialog-animation-easing);\n      property: background-color, visibility;\n    }\n  }\n}\n\n.sbb-dialog {\n  display: none;\n  position: absolute;\n  inset-inline: 0;\n  margin: auto;\n  padding: 0;\n  border: none;\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n  color: var(--_sbb-dialog-color);\n  background-color: var(--sbb-dialog-background-color);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: ease;\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation-name: close;\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n\n  @include sbb.mq($from: large) {\n    border-radius: var(--sbb-dialog-border-radius);\n    overflow: hidden;\n    height: auto;\n  }\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n.sbb-dialog__wrapper {\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n:host(:not(:state(has-intermediate-element))) .sbb-dialog__wrapper {\n  display: grid;\n  grid-template:\n    'title close-button' auto\n    'content content' 1fr\n    'actions actions' auto / 1fr auto;\n  gap: 0;\n}\n\n// It is necessary to use animations with keyframes instead of transitions in order not to alter\n// the default `display: block` of the modal otherwise it causes several problems,\n// especially for accessibility.\n@keyframes open {\n  from {\n    opacity: 0;\n    translate: 0 var(--sbb-spacing-fixed-4x);\n  }\n\n  to {\n    opacity: 1;\n    translate: 0;\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n    translate: 0;\n  }\n\n  to {\n    opacity: 0;\n    translate: 0 var(--sbb-spacing-fixed-4x);\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { unsafeCSS, type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { 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.ts';\nimport type { SbbOverlayCloseEventDetails } from '../../core/interfaces/overlay-close-details.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport {\n  overlayRefs,\n  SbbOverlayBaseElement,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?inline';\n\nimport '../../screen-reader-only.ts';\n\nexport {\n  assignOverlayResult as assignDialogResult,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay/overlay-base-element.ts';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\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 class SbbDialogElement extends SbbOverlayBaseElement {\n  public static override readonly elementName: string = 'sbb-dialog';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(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 _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    this.addEventListener('scroll', () => this._updateOverflowState(), {\n      passive: true,\n      capture: true,\n    });\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    const contentElement = this._contentElement();\n\n    contentElement?.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 (contentElement) {\n      this._dialogContentResizeObserver.hostDisconnected();\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.focusTrapController.focusInitialElement();\n    this.focusTrapController.enabled = true;\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n\n    const contentElement = this._contentElement();\n    if (contentElement) {\n      this._dialogContentResizeObserver.observe(contentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // If the component is already open on firstUpdate, announce the title\n    if (this.isOpen) {\n      this.announceTitle();\n    }\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 _handleSlotChange(): void {\n    this._syncTitleNegative();\n    this._detectIntermediateElement();\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  private _detectIntermediateElement(): void {\n    const hasNoExpectedDirectChildren =\n      this.querySelector(\n        ':scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)',\n      ) === null;\n\n    this.toggleState('has-intermediate-element', hasNoExpectedDirectChildren);\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    const contentElement = this._contentElement();\n    this.toggleState('top-shadow', (contentElement?.scrollTop ?? 0) > 0);\n    this.toggleState(\n      'bottom-shadow',\n      (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) <\n        (contentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  private _contentElement(): SbbDialogContentElement | null {\n    return this.querySelector('sbb-dialog-content');\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('beforeclose', {\n        cancelable: true,\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component is closed. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('close', {\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\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            <slot @slotchange=${() => this._handleSlotChange()}></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"],"mappings":"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"}
237
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component-DKuR4u-y.js","names":[],"sources":["../../../src/elements/dialog/dialog/dialog.scss?inline","../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-dialog-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);\n  --sbb-dialog-shadow-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n\n  display: none;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n  z-index: var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index));\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-max-width: min(\n      calc(100vw - var(--sbb-spacing-fixed-30x) * 2),\n      var(--sbb-dialog-max-width-default)\n    );\n  }\n}\n\n:host(:state(top-shadow)) {\n  --sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow);\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  display: block;\n}\n\n:host(:is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-pointer-events: all;\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-backdrop-visibility: visible;\n    --sbb-dialog-backdrop-pointer-events: all;\n  }\n}\n\n:host([backdrop='translucent']:is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent);\n}\n\n:host([backdrop='opaque']:not([negative]):is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n}\n\n:host(:not([negative])) {\n  --_sbb-dialog-color: var(--sbb-dialog-color);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4);\n  --sbb-dialog-background-color: var(--sbb-background-color-1);\n}\n\n:host([negative]) {\n  --_sbb-dialog-color: var(--sbb-dialog-color-negative);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);\n  --sbb-dialog-background-color: var(--sbb-background-color-1-negative);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:state(bottom-shadow)) {\n  --sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: transparent;\n}\n\n:host(:not(:state(state-closed))) {\n  --sbb-dialog-inset: 0;\n}\n\n.sbb-dialog__container {\n  pointer-events: var(--sbb-dialog-pointer-events);\n  display: flex;\n  align-items: center;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n\n  // Dialog backdrop (not visible on mobile)\n  &::before {\n    content: '';\n    visibility: var(--sbb-dialog-backdrop-visibility);\n    pointer-events: var(--sbb-dialog-backdrop-pointer-events);\n    position: fixed;\n    inset: var(--sbb-dialog-inset);\n    background-color: var(--sbb-dialog-backdrop-color);\n    transition: {\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: var(--sbb-dialog-animation-easing);\n      property: background-color, visibility;\n    }\n  }\n}\n\n.sbb-dialog {\n  display: none;\n  position: absolute;\n  inset-inline: 0;\n  margin: auto;\n  padding: 0;\n  border: none;\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n  color: var(--_sbb-dialog-color);\n  background-color: var(--sbb-dialog-background-color);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: ease;\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation-name: close;\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n\n  @include sbb.mq($from: large) {\n    border-radius: var(--sbb-dialog-border-radius);\n    overflow: hidden;\n    height: auto;\n  }\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n.sbb-dialog__wrapper {\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n:host(:not(:state(has-intermediate-element))) .sbb-dialog__wrapper {\n  display: grid;\n  grid-template:\n    'title close-button' auto\n    'content content' 1fr\n    'actions actions' auto / 1fr auto;\n  gap: 0;\n}\n\n// It is necessary to use animations with keyframes instead of transitions in order not to alter\n// the default `display: block` of the modal otherwise it causes several problems,\n// especially for accessibility.\n@keyframes open {\n  from {\n    opacity: 0;\n    translate: 0 var(--sbb-spacing-fixed-4x);\n  }\n\n  to {\n    opacity: 1;\n    translate: 0;\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n    translate: 0;\n  }\n\n  to {\n    opacity: 0;\n    translate: 0 var(--sbb-spacing-fixed-4x);\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { unsafeCSS, type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { 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.ts';\nimport type { SbbOverlayCloseEventDetails } from '../../core/interfaces/overlay-close-details.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport {\n  overlayRefs,\n  SbbOverlayBaseElement,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?inline';\n\nimport '../../screen-reader-only.ts';\n\nexport {\n  assignOverlayResult as assignDialogResult,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay/overlay-base-element.ts';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\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 class SbbDialogElement extends SbbOverlayBaseElement {\n  public static override readonly elementName: string = 'sbb-dialog';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(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 _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    this.addEventListener('scroll', () => this._updateOverflowState(), {\n      passive: true,\n      capture: true,\n    });\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')?.textContent.trim(),\n    );\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    const contentElement = this._contentElement();\n\n    contentElement?.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 (contentElement) {\n      this._dialogContentResizeObserver.hostDisconnected();\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.focusTrapController.focusInitialElement();\n    this.focusTrapController.enabled = true;\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n\n    const contentElement = this._contentElement();\n    if (contentElement) {\n      this._dialogContentResizeObserver.observe(contentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // If the component is already open on firstUpdate, announce the title\n    if (this.isOpen) {\n      this.announceTitle();\n    }\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 _handleSlotChange(): void {\n    this._syncTitleNegative();\n    this._detectIntermediateElement();\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  private _detectIntermediateElement(): void {\n    const hasNoExpectedDirectChildren =\n      this.querySelector(\n        ':scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)',\n      ) === null;\n\n    this.toggleState('has-intermediate-element', hasNoExpectedDirectChildren);\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    const contentElement = this._contentElement();\n    this.toggleState('top-shadow', (contentElement?.scrollTop ?? 0) > 0);\n    this.toggleState(\n      'bottom-shadow',\n      (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) <\n        (contentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  private _contentElement(): SbbDialogContentElement | null {\n    return this.querySelector('sbb-dialog-content');\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('beforeclose', {\n        cancelable: true,\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component is closed. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('close', {\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\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            <slot @slotchange=${() => this._handleSlotChange()}></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"],"mappings":"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"}
@@ -2,7 +2,7 @@ import { t as SbbDialogActionsElement } from "./dialog-actions.component-CegGvLG
2
2
  import { t as SbbDialogCloseButtonElement } from "./dialog-close-button.component-C4P-8J8j.js";
3
3
  import { t as SbbDialogContentElement } from "./dialog-content.component-bm8piC0O.js";
4
4
  import { t as SbbDialogTitleElement } from "./dialog-title.component-CUAbFzCr.js";
5
- import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "./dialog.component-TBiL0Sdq.js";
5
+ import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "./dialog.component-DKuR4u-y.js";
6
6
  import "./dialog.pure.js";
7
7
  //#region src/elements/dialog.ts
8
8
  /** @entrypoint */
@@ -2,5 +2,5 @@ import { t as SbbDialogActionsElement } from "./dialog-actions.component-CegGvLG
2
2
  import { t as SbbDialogCloseButtonElement } from "./dialog-close-button.component-C4P-8J8j.js";
3
3
  import { t as SbbDialogContentElement } from "./dialog-content.component-bm8piC0O.js";
4
4
  import { t as SbbDialogTitleElement } from "./dialog-title.component-CUAbFzCr.js";
5
- import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "./dialog.component-TBiL0Sdq.js";
5
+ import { n as SbbDialogElement, r as assignDialogResult, t as SbbDialogCloseEvent } from "./dialog.component-DKuR4u-y.js";
6
6
  export { SbbDialogActionsElement, SbbDialogCloseButtonElement, SbbDialogCloseEvent, SbbDialogContentElement, SbbDialogElement, SbbDialogTitleElement, assignDialogResult };
@@ -1,2 +1,2 @@
1
- import { t as SbbExpansionPanelElement } from "../../expansion-panel.component-PDUmZe7w.js";
1
+ import { t as SbbExpansionPanelElement } from "../../expansion-panel.component-CV_IuWZA.js";
2
2
  export { SbbExpansionPanelElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbExpansionPanelElement } from "../expansion-panel.component-PDUmZe7w.js";
1
+ import { t as SbbExpansionPanelElement } from "../expansion-panel.component-CV_IuWZA.js";
2
2
  //#region src/elements/expansion-panel/expansion-panel.ts
3
3
  /** @entrypoint */
4
4
  SbbExpansionPanelElement.define();