@sbb-esta/lyne-elements 4.0.2 → 4.0.4
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/_index.scss +1 -1
- package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/autocomplete/autocomplete-base-element.js +11 -6
- package/autocomplete/autocomplete.component.d.ts +2 -0
- package/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/autocomplete/autocomplete.component.js +6 -9
- package/calendar/calendar.component.d.ts +2 -0
- package/calendar/calendar.component.d.ts.map +1 -1
- package/calendar/calendar.component.js +95 -92
- package/core/overlay/overlay-option-panel.js +3 -3
- package/core/styles/core.scss +1 -1
- package/core/styles/mixins/lists.scss +15 -3
- package/core/styles/mixins/overlay.scss +6 -3
- package/core.css +1 -1
- package/custom-elements.json +7404 -7385
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +20 -9
- package/development/autocomplete/autocomplete.component.d.ts +2 -0
- package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/development/autocomplete/autocomplete.component.js +6 -7
- package/development/calendar/calendar.component.d.ts +2 -0
- package/development/calendar/calendar.component.d.ts.map +1 -1
- package/development/calendar/calendar.component.js +40 -33
- package/development/core/overlay/overlay-option-panel.js +2 -2
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +5 -2
- package/development/header/common/header-action-common.js +30 -32
- package/development/notification/notification.component.js +9 -11
- package/development/option/option/option-base-element.js +2 -2
- package/development/overlay/overlay-base-element.d.ts +1 -1
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +12 -1
- package/development/overlay/overlay.component.d.ts +2 -1
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +7 -1
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +8 -2
- package/development/select/select.component.d.ts +3 -1
- package/development/select/select.component.d.ts.map +1 -1
- package/development/select/select.component.js +19 -13
- package/development/tabs/tab/tab.component.js +2 -1
- package/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/dialog/dialog/dialog.component.js +2 -2
- package/header/common/header-action-common.js +20 -20
- package/loading-indicator-circle/loading-indicator-circle.component.js +1 -1
- package/notification/notification.component.js +1 -1
- package/off-brand-theme.css +1 -1
- package/option/option/option-base-element.js +1 -1
- package/overlay/overlay-base-element.d.ts +1 -1
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay/overlay-base-element.js +24 -22
- package/overlay/overlay.component.d.ts +2 -1
- package/overlay/overlay.component.d.ts.map +1 -1
- package/overlay/overlay.component.js +28 -25
- package/package.json +3 -3
- package/popover/popover.component.d.ts.map +1 -1
- package/popover/popover.component.js +3 -3
- package/safety-theme.css +1 -1
- package/select/select.component.d.ts +3 -1
- package/select/select.component.d.ts.map +1 -1
- package/select/select.component.js +10 -7
- package/standard-theme.css +1 -1
- package/tabs/tab/tab.component.js +4 -4
|
@@ -12,7 +12,7 @@ function setOverlayPosition(dialog, originElement, optionContainer, container, e
|
|
|
12
12
|
});
|
|
13
13
|
element.style.setProperty("--sbb-options-panel-position-x", `${panelPosition.left}px`);
|
|
14
14
|
element.style.setProperty("--sbb-options-panel-position-y", `${panelPosition.top}px`);
|
|
15
|
-
element.style.setProperty("--sbb-options-panel-max-height", panelPosition.maxHeight);
|
|
15
|
+
element.style.setProperty("--sbb-options-panel-max-height-calculated", panelPosition.maxHeight);
|
|
16
16
|
const controller = _stateController(element);
|
|
17
17
|
if (panelPosition.alignment.vertical === "above") {
|
|
18
18
|
controller.add("options-panel-position-above");
|
|
@@ -26,4 +26,4 @@ function setOverlayPosition(dialog, originElement, optionContainer, container, e
|
|
|
26
26
|
export {
|
|
27
27
|
setOverlayPosition
|
|
28
28
|
};
|
|
29
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS1vcHRpb24tcGFuZWwuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jb3JlL292ZXJsYXkvb3ZlcmxheS1vcHRpb24tcGFuZWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW5UeXBlLCDJtXN0YXRlQ29udHJvbGxlciB9IGZyb20gJy4uL21peGlucy50cyc7XG5cbmltcG9ydCB7IGdldEVsZW1lbnRQb3NpdGlvbiB9IGZyb20gJy4vcG9zaXRpb24udHMnO1xuXG4vKipcbiAqIFBsYWNlcyB0aGUgb3ZlcmxheSBpbiB0aGUgY29ycmVjdCBwb3NpdGlvbi5cbiAqIEBwYXJhbSBkaWFsb2cgVGhlIHJlZmVyZW5jZSB0byB0aGUgZGlhbG9nIGVsZW1lbnQuXG4gKiBAcGFyYW0gb3JpZ2luRWxlbWVudCBUaGUgcmVmZXJlbmNlIHRvIHRoZSBlbGVtZW50IHRoZSBkaWFsb2cgaXMgYXR0YWNoZWQgdG8uXG4gKiBAcGFyYW0gb3B0aW9uQ29udGFpbmVyIFRoZSByZWZlcmVuY2UgdG8gdGhlIG9wdGlvbiBwYW5lbC5cbiAqIEBwYXJhbSBjb250YWluZXIgVGhlIGVsZW1lbnQgd2hpY2ggaGFzIHRoZSBwb3NpdGlvbjpmaXhlZCBhcHBsaWVkLlxuICogQHBhcmFtIGVsZW1lbnQgVGhlIHJlZmVyZW5jZSB0byB0aGUgY29tcG9uZW50LlxuICogQHBhcmFtIHBvc2l0aW9uIFRoZSBhbGxvd2VkIHBvc2l0aW9uIG9mIHRoZSBvdmVybGF5IHJlbGF0aXZlIHRvIHRoZSBvcmlnaW4uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzZXRPdmVybGF5UG9zaXRpb24oXG4gIGRpYWxvZzogSFRNTEVsZW1lbnQsXG4gIG9yaWdpbkVsZW1lbnQ6IEhUTUxFbGVtZW50LFxuICBvcHRpb25Db250YWluZXI6IEhUTUxFbGVtZW50LFxuICBjb250YWluZXI6IEhUTUxFbGVtZW50LFxuICBlbGVtZW50OiBIVE1MRWxlbWVudCAmIFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpblR5cGUsXG4gIHBvc2l0aW9uOiAnYXV0bycgfCAnYWJvdmUnIHwgJ2JlbG93JyA9ICdhdXRvJyxcbik6IHZvaWQge1xuICBpZiAoIWRpYWxvZyB8fCAhb3JpZ2luRWxlbWVudCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIFNldCB0aGUgd2lkdGggdG8gbWF0Y2ggdGhlIHRyaWdnZXIgZWxlbWVudFxuICBlbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi1vcHRpb25zLXBhbmVsLXdpZHRoJywgYCR7b3JpZ2luRWxlbWVudC5vZmZzZXRXaWR0aH1weGApO1xuXG4gIC8vIFNldCB0aGUgb3JpZ2luIGhlaWdodFxuICBlbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi1vcHRpb25zLXBhbmVsLW9yaWdpbi1oZWlnaHQnLCBgJHtvcmlnaW5FbGVtZW50Lm9mZnNldEhlaWdodH1weGApO1xuXG4gIC8vIENhbGN1bGF0ZSBhbmQgc2V0IHRoZSBwb3NpdGlvblxuICBjb25zdCBwYW5lbFBvc2l0aW9uID0gZ2V0RWxlbWVudFBvc2l0aW9uKG9wdGlvbkNvbnRhaW5lciwgb3JpZ2luRWxlbWVudCwgY29udGFpbmVyLCB7XG4gICAgZm9yY2VCZWxvdzogcG9zaXRpb24gPT09ICdiZWxvdycsXG4gICAgZm9yY2VBYm92ZTogcG9zaXRpb24gPT09ICdhYm92ZScsXG4gIH0pO1xuXG4gIGVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoJy0tc2JiLW9wdGlvbnMtcGFuZWwtcG9zaXRpb24teCcsIGAke3BhbmVsUG9zaXRpb24ubGVmdH1weGApO1xuICBlbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi1vcHRpb25zLXBhbmVsLXBvc2l0aW9uLXknLCBgJHtwYW5lbFBvc2l0aW9uLnRvcH1weGApO1xuICBlbGVtZW50LnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi1vcHRpb25zLXBhbmVsLW1heC1oZWlnaHQtY2FsY3VsYXRlZCcsIHBhbmVsUG9zaXRpb24ubWF4SGVpZ2h0KTtcbiAgY29uc3QgY29udHJvbGxlciA9IMm1c3RhdGVDb250cm9sbGVyKGVsZW1lbnQpO1xuICBpZiAocGFuZWxQb3NpdGlvbi5hbGlnbm1lbnQudmVydGljYWwgPT09ICdhYm92ZScpIHtcbiAgICBjb250cm9sbGVyLmFkZCgnb3B0aW9ucy1wYW5lbC1wb3NpdGlvbi1hYm92ZScpO1xuICAgIGNvbnRyb2xsZXIuZGVsZXRlKCdvcHRpb25zLXBhbmVsLXBvc2l0aW9uLWJlbG93Jyk7XG4gIH0gZWxzZSB7XG4gICAgY29udHJvbGxlci5hZGQoJ29wdGlvbnMtcGFuZWwtcG9zaXRpb24tYmVsb3cnKTtcbiAgICBjb250cm9sbGVyLmRlbGV0ZSgnb3B0aW9ucy1wYW5lbC1wb3NpdGlvbi1hYm92ZScpO1xuICB9XG4gIG9yaWdpbkVsZW1lbnQuc2V0QXR0cmlidXRlKCdkYXRhLW9wdGlvbnMtcGFuZWwtcG9zaXRpb24nLCBwYW5lbFBvc2l0aW9uLmFsaWdubWVudC52ZXJ0aWNhbCk7XG59XG4iXSwibmFtZXMiOlsiybVzdGF0ZUNvbnRyb2xsZXIiXSwibWFwcGluZ3MiOiI7O0FBYU0sU0FBVSxtQkFDZCxRQUNBLGVBQ0EsaUJBQ0EsV0FDQSxTQUNBLFdBQXVDLFFBQU07QUFFN0MsTUFBSSxDQUFDLFVBQVUsQ0FBQyxlQUFlO0FBQzdCO0FBQUEsRUFDRjtBQUdBLFVBQVEsTUFBTSxZQUFZLDZCQUE2QixHQUFHLGNBQWMsV0FBVyxJQUFJO0FBR3ZGLFVBQVEsTUFBTSxZQUFZLHFDQUFxQyxHQUFHLGNBQWMsWUFBWSxJQUFJO0FBR2hHLFFBQU0sZ0JBQWdCLG1CQUFtQixpQkFBaUIsZUFBZSxXQUFXO0FBQUEsSUFDbEYsWUFBWSxhQUFhO0FBQUEsSUFDekIsWUFBWSxhQUFhO0FBQUEsRUFBQSxDQUMxQjtBQUVELFVBQVEsTUFBTSxZQUFZLGtDQUFrQyxHQUFHLGNBQWMsSUFBSSxJQUFJO0FBQ3JGLFVBQVEsTUFBTSxZQUFZLGtDQUFrQyxHQUFHLGNBQWMsR0FBRyxJQUFJO0FBQ3BGLFVBQVEsTUFBTSxZQUFZLDZDQUE2QyxjQUFjLFNBQVM7QUFDOUYsUUFBTSxhQUFhQSxpQkFBaUIsT0FBTztBQUMzQyxNQUFJLGNBQWMsVUFBVSxhQUFhLFNBQVM7QUFDaEQsZUFBVyxJQUFJLDhCQUE4QjtBQUM3QyxlQUFXLE9BQU8sOEJBQThCO0FBQUEsRUFDbEQsT0FBTztBQUNMLGVBQVcsSUFBSSw4QkFBOEI7QUFDN0MsZUFBVyxPQUFPLDhCQUE4QjtBQUFBLEVBQ2xEO0FBQ0EsZ0JBQWMsYUFBYSwrQkFBK0IsY0FBYyxVQUFVLFFBQVE7QUFDNUY7In0=
|
|
@@ -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;AAO1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAKtE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;GAOG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,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,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAahD,iBAAiB,IAAI,IAAI;IAKzC,2EAA2E;IACpE,aAAa,IAAI,IAAI;IAM5B,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA6B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAiBZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,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;AAO1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAKtE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;GAOG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,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,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAahD,iBAAiB,IAAI,IAAI;IAKzC,2EAA2E;IACpE,aAAa,IAAI,IAAI;IAM5B,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA6B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAiBZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAW3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,iBAAiB;IAKzB,OAAO,CAAC,kBAAkB;IAa1B,OAAO,CAAC,0BAA0B;IASlC,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
|
|
@@ -297,8 +297,8 @@ let SbbDialogElement = (() => {
|
|
|
297
297
|
this.escapableOverlayController.connect();
|
|
298
298
|
this.attachOpenOverlayEvents();
|
|
299
299
|
this.focusTrapController.focusInitialElement();
|
|
300
|
-
setTimeout(() => this.announceTitle());
|
|
301
300
|
this.focusTrapController.enabled = true;
|
|
301
|
+
setTimeout(() => this.announceTitle());
|
|
302
302
|
const contentElement = this._contentElement();
|
|
303
303
|
if (contentElement) {
|
|
304
304
|
this._dialogContentResizeObserver.observe(contentElement);
|
|
@@ -307,6 +307,9 @@ let SbbDialogElement = (() => {
|
|
|
307
307
|
}
|
|
308
308
|
firstUpdated(changedProperties) {
|
|
309
309
|
super.firstUpdated(changedProperties);
|
|
310
|
+
if (this.isOpen) {
|
|
311
|
+
this.announceTitle();
|
|
312
|
+
}
|
|
310
313
|
this._syncTitleNegative();
|
|
311
314
|
}
|
|
312
315
|
willUpdate(changedProperties) {
|
|
@@ -379,4 +382,4 @@ let SbbDialogElement = (() => {
|
|
|
379
382
|
export {
|
|
380
383
|
SbbDialogElement
|
|
381
384
|
};
|
|
382
|
-
//# 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, 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 { boxSizingStyles } from '../../core/styles.ts';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.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\n@customElement('sbb-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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.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\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    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  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"],"names":[],"mappings":"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"}
|
|
385
|
+
//# 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, 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 { boxSizingStyles } from '../../core/styles.ts';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.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\n@customElement('sbb-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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.escapableOverlayController.connect();\n    this.attachOpenOverlayEvents();\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  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"],"names":[],"mappings":"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"}
|
|
@@ -130,7 +130,7 @@ const style = css`:host {
|
|
|
130
130
|
.sbb-action-base::after {
|
|
131
131
|
content: "";
|
|
132
132
|
position: absolute;
|
|
133
|
-
border-
|
|
133
|
+
border-block-end: var(--sbb-header-action-active-border-width) solid var(--sbb-header-action-active-border-color);
|
|
134
134
|
inset: auto 0 calc(-1 * var(--sbb-header-action-active-border-width));
|
|
135
135
|
margin-inline: var(--sbb-header-action-active-border-margin-inline);
|
|
136
136
|
scale: var(--sbb-header-action-active-border-scale);
|
|
@@ -176,32 +176,30 @@ const style = css`:host {
|
|
|
176
176
|
display: none;
|
|
177
177
|
}
|
|
178
178
|
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
--
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
--sbb-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
:
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
display: flex;
|
|
200
|
-
}
|
|
179
|
+
:host(:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):not(:is(:state(slotted),[state--slotted]))) {
|
|
180
|
+
--_sbb-header-first-item-padding-shift: calc(
|
|
181
|
+
-0.5 * (var(--sbb-header-action-min-width) - var(--sbb-header-action-icon-dimension))
|
|
182
|
+
);
|
|
183
|
+
--sbb-header-action-padding-inline-zero: 0;
|
|
184
|
+
--sbb-header-action-active-border-margin-inline: calc(
|
|
185
|
+
0.5 * (100% - var(--sbb-size-icon-ui-small))
|
|
186
|
+
);
|
|
187
|
+
}
|
|
188
|
+
:host(:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):not(:is(:state(slotted),[state--slotted]))) .sbb-header-action__text {
|
|
189
|
+
border: 0;
|
|
190
|
+
clip-path: rect(0 0 0 0);
|
|
191
|
+
height: 1px;
|
|
192
|
+
margin: -1px;
|
|
193
|
+
overflow: hidden;
|
|
194
|
+
padding: 0;
|
|
195
|
+
position: absolute;
|
|
196
|
+
white-space: nowrap;
|
|
197
|
+
width: 1px;
|
|
198
|
+
display: flex;
|
|
201
199
|
}
|
|
202
200
|
|
|
203
201
|
@media (max-width: calc(37.4375rem)) {
|
|
204
|
-
:host([expand-from=small]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) {
|
|
202
|
+
:host([expand-from=small]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) {
|
|
205
203
|
--_sbb-header-first-item-padding-shift: calc(
|
|
206
204
|
-0.5 * (var(--sbb-header-action-min-width) - var(--sbb-header-action-icon-dimension))
|
|
207
205
|
);
|
|
@@ -210,7 +208,7 @@ const style = css`:host {
|
|
|
210
208
|
0.5 * (100% - var(--sbb-size-icon-ui-small))
|
|
211
209
|
);
|
|
212
210
|
}
|
|
213
|
-
:host([expand-from=small]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-header-action__text {
|
|
211
|
+
:host([expand-from=small]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) .sbb-header-action__text {
|
|
214
212
|
border: 0;
|
|
215
213
|
clip-path: rect(0 0 0 0);
|
|
216
214
|
height: 1px;
|
|
@@ -225,7 +223,7 @@ const style = css`:host {
|
|
|
225
223
|
}
|
|
226
224
|
|
|
227
225
|
@media (max-width: calc(63.9375rem)) {
|
|
228
|
-
:host([expand-from=large]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) {
|
|
226
|
+
:host([expand-from=large]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) {
|
|
229
227
|
--_sbb-header-first-item-padding-shift: calc(
|
|
230
228
|
-0.5 * (var(--sbb-header-action-min-width) - var(--sbb-header-action-icon-dimension))
|
|
231
229
|
);
|
|
@@ -234,7 +232,7 @@ const style = css`:host {
|
|
|
234
232
|
0.5 * (100% - var(--sbb-size-icon-ui-small))
|
|
235
233
|
);
|
|
236
234
|
}
|
|
237
|
-
:host([expand-from=large]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-header-action__text {
|
|
235
|
+
:host([expand-from=large]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) .sbb-header-action__text {
|
|
238
236
|
border: 0;
|
|
239
237
|
clip-path: rect(0 0 0 0);
|
|
240
238
|
height: 1px;
|
|
@@ -249,7 +247,7 @@ const style = css`:host {
|
|
|
249
247
|
}
|
|
250
248
|
|
|
251
249
|
@media (max-width: calc(89.9375rem)) {
|
|
252
|
-
:host([expand-from=ultra]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) {
|
|
250
|
+
:host([expand-from=ultra]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) {
|
|
253
251
|
--_sbb-header-first-item-padding-shift: calc(
|
|
254
252
|
-0.5 * (var(--sbb-header-action-min-width) - var(--sbb-header-action-icon-dimension))
|
|
255
253
|
);
|
|
@@ -258,7 +256,7 @@ const style = css`:host {
|
|
|
258
256
|
0.5 * (100% - var(--sbb-size-icon-ui-small))
|
|
259
257
|
);
|
|
260
258
|
}
|
|
261
|
-
:host([expand-from=ultra]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-header-action__text {
|
|
259
|
+
:host([expand-from=ultra]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) .sbb-header-action__text {
|
|
262
260
|
border: 0;
|
|
263
261
|
clip-path: rect(0 0 0 0);
|
|
264
262
|
height: 1px;
|
|
@@ -273,7 +271,7 @@ const style = css`:host {
|
|
|
273
271
|
}
|
|
274
272
|
|
|
275
273
|
@media (max-width: calc(98.9375rem)) {
|
|
276
|
-
:host([expand-from=ultra--max-content]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) {
|
|
274
|
+
:host([expand-from=ultra--max-content]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) {
|
|
277
275
|
--_sbb-header-first-item-padding-shift: calc(
|
|
278
276
|
-0.5 * (var(--sbb-header-action-min-width) - var(--sbb-header-action-icon-dimension))
|
|
279
277
|
);
|
|
@@ -282,7 +280,7 @@ const style = css`:host {
|
|
|
282
280
|
0.5 * (100% - var(--sbb-size-icon-ui-small))
|
|
283
281
|
);
|
|
284
282
|
}
|
|
285
|
-
:host([expand-from=ultra--max-content]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-header-action__text {
|
|
283
|
+
:host([expand-from=ultra--max-content]:is(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name])):is(:state(slotted),[state--slotted])) .sbb-header-action__text {
|
|
286
284
|
border: 0;
|
|
287
285
|
clip-path: rect(0 0 0 0);
|
|
288
286
|
height: 1px;
|
|
@@ -349,4 +347,4 @@ const SbbHeaderActionCommonElementMixin = (superClass) => {
|
|
|
349
347
|
export {
|
|
350
348
|
SbbHeaderActionCommonElementMixin
|
|
351
349
|
};
|
|
352
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLWFjdGlvbi1jb21tb24uanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9oZWFkZXIvY29tbW9uL2hlYWRlci1hY3Rpb24tY29tbW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgaHRtbCB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB0eXBlIHsgU2JiQWN0aW9uQmFzZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2Jhc2UtZWxlbWVudHMudHMnO1xuaW1wb3J0IHR5cGUgeyBTYmJIb3Jpem9udGFsRnJvbSB9IGZyb20gJy4uLy4uL2NvcmUvaW50ZXJmYWNlcy50cyc7XG5pbXBvcnQgdHlwZSB7IEFic3RyYWN0Q29uc3RydWN0b3IgfSBmcm9tICcuLi8uLi9jb3JlL21peGlucy50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBTYmJJY29uTmFtZU1peGluIH0gZnJvbSAnLi4vLi4vaWNvbi50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL2hlYWRlci1hY3Rpb24uc2Nzcz9saXQmaW5saW5lJztcblxuZXhwb3J0IGRlY2xhcmUgY2xhc3MgU2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudE1peGluVHlwZSBleHRlbmRzIFNiYkljb25OYW1lTWl4aW4oXG4gIFNiYkFjdGlvbkJhc2VFbGVtZW50LFxuKSB7XG4gIHB1YmxpYyBhY2Nlc3NvciBleHBhbmRGcm9tOiBTYmJIb3Jpem9udGFsRnJvbTtcbn1cblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuZXhwb3J0IGNvbnN0IFNiYkhlYWRlckFjdGlvbkNvbW1vbkVsZW1lbnRNaXhpbiA9IDxcbiAgVCBleHRlbmRzIEFic3RyYWN0Q29uc3RydWN0b3I8U2JiQWN0aW9uQmFzZUVsZW1lbnQ+LFxuPihcbiAgc3VwZXJDbGFzczogVCxcbik6IEFic3RyYWN0Q29uc3RydWN0b3I8U2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudE1peGluVHlwZT4gJiBUID0+IHtcbiAgYWJzdHJhY3QgY2xhc3MgU2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudFxuICAgIGV4dGVuZHMgU2JiSWNvbk5hbWVNaXhpbihzdXBlckNsYXNzKVxuICAgIGltcGxlbWVudHMgUGFydGlhbDxTYmJIZWFkZXJBY3Rpb25Db21tb25FbGVtZW50TWl4aW5UeXBlPlxuICB7XG4gICAgcHVibGljIHN0YXRpYyBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gICAgLyoqXG4gICAgICogVXNlZCB0byBzZXQgdGhlIG1pbmltdW0gYnJlYWtwb2ludCBmcm9tIHdoaWNoIHRoZSB0ZXh0IGlzIGRpc3BsYXllZC5cbiAgICAgKiBFLmcuIGlmIHNldCB0byAnbGFyZ2UnLCB0aGUgdGV4dCB3aWxsIGJlIHZpc2libGUgZm9yIGJyZWFrcG9pbnRzIGxhcmdlIGFuZCB1bHRyYSxcbiAgICAgKiBhbmQgaGlkZGVuIGZvciBhbGwgdGhlIG90aGVycy4gSWdub3JlZCBpZiBubyBpY29uIGlzIHNldC5cbiAgICAgKi9cbiAgICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdleHBhbmQtZnJvbScsIHJlZmxlY3Q6IHRydWUgfSlcbiAgICBwdWJsaWMgYWNjZXNzb3IgZXhwYW5kRnJvbTogU2JiSG9yaXpvbnRhbEZyb20gPSAnbGFyZ2UnO1xuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlclRlbXBsYXRlKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICAgIHJldHVybiBodG1sYFxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1oZWFkZXItYWN0aW9uX193cmFwcGVyXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItaGVhZGVyLWFjdGlvbl9faWNvblwiPiAke3N1cGVyLnJlbmRlckljb25TbG90KCl9IDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1oZWFkZXItYWN0aW9uX190ZXh0XCI+XG4gICAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICA8L3NwYW4+
|
|
350
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLWFjdGlvbi1jb21tb24uanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9oZWFkZXIvY29tbW9uL2hlYWRlci1hY3Rpb24tY29tbW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgaHRtbCB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB0eXBlIHsgU2JiQWN0aW9uQmFzZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2Jhc2UtZWxlbWVudHMudHMnO1xuaW1wb3J0IHR5cGUgeyBTYmJIb3Jpem9udGFsRnJvbSB9IGZyb20gJy4uLy4uL2NvcmUvaW50ZXJmYWNlcy50cyc7XG5pbXBvcnQgdHlwZSB7IEFic3RyYWN0Q29uc3RydWN0b3IgfSBmcm9tICcuLi8uLi9jb3JlL21peGlucy50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBTYmJJY29uTmFtZU1peGluIH0gZnJvbSAnLi4vLi4vaWNvbi50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL2hlYWRlci1hY3Rpb24uc2Nzcz9saXQmaW5saW5lJztcblxuZXhwb3J0IGRlY2xhcmUgY2xhc3MgU2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudE1peGluVHlwZSBleHRlbmRzIFNiYkljb25OYW1lTWl4aW4oXG4gIFNiYkFjdGlvbkJhc2VFbGVtZW50LFxuKSB7XG4gIHB1YmxpYyBhY2Nlc3NvciBleHBhbmRGcm9tOiBTYmJIb3Jpem9udGFsRnJvbTtcbn1cblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuZXhwb3J0IGNvbnN0IFNiYkhlYWRlckFjdGlvbkNvbW1vbkVsZW1lbnRNaXhpbiA9IDxcbiAgVCBleHRlbmRzIEFic3RyYWN0Q29uc3RydWN0b3I8U2JiQWN0aW9uQmFzZUVsZW1lbnQ+LFxuPihcbiAgc3VwZXJDbGFzczogVCxcbik6IEFic3RyYWN0Q29uc3RydWN0b3I8U2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudE1peGluVHlwZT4gJiBUID0+IHtcbiAgYWJzdHJhY3QgY2xhc3MgU2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudFxuICAgIGV4dGVuZHMgU2JiSWNvbk5hbWVNaXhpbihzdXBlckNsYXNzKVxuICAgIGltcGxlbWVudHMgUGFydGlhbDxTYmJIZWFkZXJBY3Rpb25Db21tb25FbGVtZW50TWl4aW5UeXBlPlxuICB7XG4gICAgcHVibGljIHN0YXRpYyBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gICAgLyoqXG4gICAgICogVXNlZCB0byBzZXQgdGhlIG1pbmltdW0gYnJlYWtwb2ludCBmcm9tIHdoaWNoIHRoZSB0ZXh0IGlzIGRpc3BsYXllZC5cbiAgICAgKiBFLmcuIGlmIHNldCB0byAnbGFyZ2UnLCB0aGUgdGV4dCB3aWxsIGJlIHZpc2libGUgZm9yIGJyZWFrcG9pbnRzIGxhcmdlIGFuZCB1bHRyYSxcbiAgICAgKiBhbmQgaGlkZGVuIGZvciBhbGwgdGhlIG90aGVycy4gSWdub3JlZCBpZiBubyBpY29uIGlzIHNldC5cbiAgICAgKi9cbiAgICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdleHBhbmQtZnJvbScsIHJlZmxlY3Q6IHRydWUgfSlcbiAgICBwdWJsaWMgYWNjZXNzb3IgZXhwYW5kRnJvbTogU2JiSG9yaXpvbnRhbEZyb20gPSAnbGFyZ2UnO1xuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlclRlbXBsYXRlKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICAgIHJldHVybiBodG1sYFxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1oZWFkZXItYWN0aW9uX193cmFwcGVyXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItaGVhZGVyLWFjdGlvbl9faWNvblwiPiAke3N1cGVyLnJlbmRlckljb25TbG90KCl9IDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1oZWFkZXItYWN0aW9uX190ZXh0XCI+XG4gICAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICA8L3NwYW4+XG4gICAgICBgO1xuICAgIH1cbiAgfVxuICByZXR1cm4gU2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudCBhcyB1bmtub3duIGFzIEFic3RyYWN0Q29uc3RydWN0b3I8U2JiSGVhZGVyQWN0aW9uQ29tbW9uRWxlbWVudE1peGluVHlwZT4gJlxuICAgIFQ7XG59O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFtQk8sTUFBTSxvQ0FBb0MsQ0FHL0MsZUFDa0U7TUFDbkQsZ0NBQTRCLE1BQUE7O3NCQUNqQyxpQkFBaUIsVUFBVTs7OztBQUR0QixXQUFBLG1CQUNMLFlBQTRCO0FBQUE7O0FBV3BDLHlEQUFBLGtCQUFBLE1BQUEsMEJBQWdELE9BQU87Ozs7Ozs7O01BQXZELElBQWdCLGFBQVU7QUFBQSxlQUFBLG1CQUFBO0FBQUEsTUFBQTtBQUFBLE1BQTFCLElBQWdCLFdBQVUsT0FBQTtBQUFBLDJCQUFBLDhCQUFBO0FBQUEsTUFBQTtBQUFBLE1BRVAsaUJBQWM7QUFDL0IsZUFBTztBQUFBO0FBQUEsbURBRXNDLE1BQU0sZ0JBQWdCO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLE1BTXJFO0FBQUEsT0FYQTs7Z0NBREMsU0FBUyxFQUFFLFdBQVcsZUFBZSxTQUFTLEtBQUEsQ0FBTSxDQUFDO0FBQ3RELG1CQUFBLElBQUEsTUFBQSx3QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGNBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsZ0JBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixZQUFVLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxZQUFWLGFBQVU7QUFBQSxNQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsMEJBQUEsNkJBQUE7O1VBUlosR0FBQSxTQUF5QixDQUFDLGlCQUFpQixLQUFLLEdBSmpEO0FBQUE7QUF5QmYsU0FBTztBQUVUOyJ9
|
|
@@ -31,10 +31,8 @@ const style = css`:host {
|
|
|
31
31
|
--sbb-notification-border-width: var(--sbb-border-width-1x);
|
|
32
32
|
--sbb-notification-border: var(--sbb-notification-border-width) solid
|
|
33
33
|
var(--sbb-notification-type-color);
|
|
34
|
-
--sbb-notification-base-radius: var(--sbb-border-radius-4x);
|
|
35
|
-
--sbb-notification-border-radius: calc(var(--sbb-notification-base-radius) / 2)
|
|
36
|
-
var(--sbb-notification-base-radius) var(--sbb-notification-base-radius)
|
|
37
|
-
calc(var(--sbb-notification-base-radius) / 2);
|
|
34
|
+
--sbb-notification-base-border-radius: var(--sbb-border-radius-4x);
|
|
35
|
+
--sbb-notification-border-radius-start: calc(var(--sbb-notification-base-border-radius) / 2);
|
|
38
36
|
--sbb-notification-animation-duration: var(
|
|
39
37
|
--sbb-disable-animation-duration,
|
|
40
38
|
var(--sbb-animation-duration-4x)
|
|
@@ -107,10 +105,10 @@ const style = css`:host {
|
|
|
107
105
|
|
|
108
106
|
.sbb-notification__wrapper {
|
|
109
107
|
position: relative;
|
|
110
|
-
inset-inline-start: calc(var(--sbb-notification-base-radius) - var(--sbb-notification-border-width));
|
|
111
|
-
width: calc(100% - (var(--sbb-notification-base-radius) - var(--sbb-notification-border-width)));
|
|
108
|
+
inset-inline-start: calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width));
|
|
109
|
+
width: calc(100% - (var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)));
|
|
112
110
|
border: var(--sbb-notification-border);
|
|
113
|
-
border-radius: var(--sbb-notification-border-radius);
|
|
111
|
+
border-radius: var(--sbb-notification-border-radius-start) var(--sbb-notification-base-border-radius) var(--sbb-notification-base-border-radius) var(--sbb-notification-border-radius-start);
|
|
114
112
|
opacity: 0;
|
|
115
113
|
max-height: 0;
|
|
116
114
|
margin: 0;
|
|
@@ -118,10 +116,10 @@ const style = css`:host {
|
|
|
118
116
|
.sbb-notification__wrapper::before {
|
|
119
117
|
content: "";
|
|
120
118
|
position: absolute;
|
|
121
|
-
inset: calc(var(--sbb-notification-border-width) * -1) var(--sbb-notification-base-radius) calc(var(--sbb-notification-border-width) * -1) calc(var(--sbb-notification-base-radius) * -1);
|
|
119
|
+
inset: calc(var(--sbb-notification-border-width) * -1) var(--sbb-notification-base-border-radius) calc(var(--sbb-notification-border-width) * -1) calc(var(--sbb-notification-base-border-radius) * -1);
|
|
122
120
|
background-color: var(--sbb-notification-type-color);
|
|
123
121
|
border: var(--sbb-notification-border);
|
|
124
|
-
border-radius: var(--sbb-notification-base-radius);
|
|
122
|
+
border-radius: var(--sbb-notification-base-border-radius);
|
|
125
123
|
}
|
|
126
124
|
:host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-notification__wrapper {
|
|
127
125
|
opacity: 1;
|
|
@@ -156,7 +154,7 @@ const style = css`:host {
|
|
|
156
154
|
padding-block: var(--sbb-notification-padding-block);
|
|
157
155
|
padding-inline: var(--sbb-notification-padding-inline);
|
|
158
156
|
color: var(--sbb-notification-color);
|
|
159
|
-
border-radius: var(--sbb-notification-border-radius);
|
|
157
|
+
border-radius: var(--sbb-notification-border-radius-start) calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)) calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)) var(--sbb-notification-border-radius-start);
|
|
160
158
|
overflow: hidden;
|
|
161
159
|
background-color: var(--sbb-notification-background-color);
|
|
162
160
|
}
|
|
@@ -501,4 +499,4 @@ let SbbNotificationElement = (() => {
|
|
|
501
499
|
export {
|
|
502
500
|
SbbNotificationElement
|
|
503
501
|
};
|
|
504
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"notification.component.js","sources":["../../../../src/elements/notification/notification.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../core/controllers.ts';\nimport { isLean, isZeroAnimationDuration } from '../core/dom.ts';\nimport { i18nCloseNotification } from '../core/i18n.ts';\nimport type { SbbOpenedClosedState } from '../core/interfaces.ts';\nimport { SbbElementInternalsMixin, SbbReadonlyMixin } from '../core/mixins.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport { SbbIconNameMixin } from '../icon.ts';\nimport type { SbbTitleElement } from '../title.ts';\n\nimport style from './notification.scss?lit&inline';\n\nimport '../button/secondary-button.ts';\nimport '../divider.ts';\n\nconst notificationTypes = new Map([\n  ['info', 'circle-information-small'],\n  ['note', 'circle-information-small'],\n  ['success', 'circle-tick-small'],\n  ['warn', 'circle-exclamation-point-small'],\n  ['error', 'circle-cross-small'],\n]);\n\nconst DEBOUNCE_TIME = 150;\n\n/**\n * It displays messages which require a user's attention without interrupting its tasks.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-notification`. Content should consist of an optional `sbb-title` element and text content.\n * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.\n * @slot icon - Use this slot to display a custom icon by providing an `sbb-icon` component.\n * @cssprop [--sbb-notification-margin=0] - Can be used to modify the margin in order to get a smoother animation.\n * See style section for more information.\n */\nexport\n@customElement('sbb-notification')\nclass SbbNotificationElement extends SbbIconNameMixin(\n  SbbReadonlyMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /** The type of the notification. */\n  @property({ reflect: true }) public accessor type:\n    | 'info'\n    | 'note'\n    | 'success'\n    | 'warn'\n    | 'error' = 'info';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public accessor animation: 'open' | 'close' | 'all' | 'none' = 'all';\n\n  /** The state of the component. */\n  private set _state(state: SbbOpenedClosedState) {\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(): SbbOpenedClosedState {\n    return this._stateInternal;\n  }\n  private _stateInternal!: SbbOpenedClosedState;\n\n  private _notificationElement!: HTMLElement;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _language = new SbbLanguageController(this);\n  private _notificationResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onNotificationResize(),\n  });\n\n  public constructor() {\n    super();\n    this._state = 'closed';\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('size')) {\n      this._configureTitle();\n    }\n  }\n\n  private _open(): void {\n    if (this._state === 'closed') {\n      this._state = 'opening';\n      /** Emits when the opening animation starts. */\n      this.dispatchEvent(new Event('beforeopen'));\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `opened` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleOpening();\n      }\n    }\n  }\n\n  public close(): void {\n    if (this._state === 'opened' && this._dispatchBeforeCloseEvent()) {\n      this._state = 'closing';\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `closed` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleClosing();\n      }\n    }\n  }\n\n  private _dispatchBeforeCloseEvent(): boolean {\n    /** Emits when the closing animation starts. Can be canceled to prevent the component from closing. */\n    return this.dispatchEvent(new Event('beforeclose', { cancelable: true }));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._notificationElement = this.shadowRoot?.querySelector(\n      '.sbb-notification__wrapper',\n    ) as HTMLElement;\n    // We need to wait for the component's `updateComplete` in order to set the correct\n    // height to the notification element.\n    this.updateComplete.then(() => {\n      this._setNotificationHeight();\n      this._open();\n    });\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-notification-animation-duration');\n  }\n\n  private _setNotificationHeight(): void {\n    if (!this._notificationElement?.scrollHeight) {\n      return;\n    }\n    const notificationHeight = `${this._notificationElement.scrollHeight}px`;\n    this.style.setProperty('--sbb-notification-height', notificationHeight);\n  }\n\n  private _onNotificationResize(): void {\n    if (this._state !== 'opened') {\n      return;\n    }\n\n    if (this._resizeObserverTimeout) {\n      clearTimeout(this._resizeObserverTimeout);\n    }\n\n    // Disable the animation when resizing the notification to avoid strange height transition effects.\n    this.internals.states.add('resize-disable-animation');\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('resize-disable-animation'),\n      DEBOUNCE_TIME,\n    );\n\n    // To avoid ResizeObserver loops, we set the height a tick later.\n    setTimeout(() => this._setNotificationHeight());\n  }\n\n  private _onNotificationAnimationEnd(event: AnimationEvent): void {\n    if (this._state === 'opening' && event.animationName === 'open') {\n      this._handleOpening();\n    }\n\n    if (this._state === 'closing' && event.animationName === 'close-height') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this._state = 'opened';\n    this._notificationResizeObserver.observe(this._notificationElement);\n    /** Emits when the opening animation ends. */\n    this.dispatchEvent(new Event('open'));\n  }\n\n  private _handleClosing(): void {\n    this._state = 'closed';\n    /** Emits when the closing animation ends. */\n    this.dispatchEvent(new Event('close'));\n    this._notificationResizeObserver.unobserve(this._notificationElement);\n    setTimeout(() => this.remove());\n  }\n\n  private _handleSlotchange(): void {\n    const title = Array.from(this.children).find((el) => el.localName === 'sbb-title');\n    if (title) {\n      title.slot = 'title';\n    }\n  }\n\n  private _configureTitle(): void {\n    const title = this.querySelector?.<SbbTitleElement>('sbb-title');\n    if (title) {\n      customElements.upgrade(title);\n      title.visualLevel = this.size === 'm' ? '5' : '6';\n    }\n  }\n\n  protected override renderIconName(): string {\n    return super.renderIconName() || notificationTypes.get(this.type)!;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-notification__wrapper\" @animationend=${this._onNotificationAnimationEnd}>\n        <div class=\"sbb-notification\">\n          ${this.renderIconSlot('sbb-notification__icon')}\n          <span class=\"sbb-notification__content\">\n            <slot name=\"title\" @slotchange=${this._configureTitle}></slot>\n            <p class=\"sbb-notification__text\">\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </p>\n          </span>\n\n          ${!this.readOnly\n            ? html`<span class=\"sbb-notification__close-wrapper\">\n                <sbb-divider class=\"sbb-notification__divider\" orientation=\"vertical\"></sbb-divider>\n                <sbb-secondary-button\n                  size=${this.size}\n                  icon-name=\"cross-small\"\n                  @click=${() => this.close()}\n                  aria-label=${i18nCloseNotification[this._language.current]}\n                  class=\"sbb-notification__close\"\n                ></sbb-secondary-button>\n              </span>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-notification': SbbNotificationElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
502
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"notification.component.js","sources":["../../../../src/elements/notification/notification.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../core/controllers.ts';\nimport { isLean, isZeroAnimationDuration } from '../core/dom.ts';\nimport { i18nCloseNotification } from '../core/i18n.ts';\nimport type { SbbOpenedClosedState } from '../core/interfaces.ts';\nimport { SbbElementInternalsMixin, SbbReadonlyMixin } from '../core/mixins.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport { SbbIconNameMixin } from '../icon.ts';\nimport type { SbbTitleElement } from '../title.ts';\n\nimport style from './notification.scss?lit&inline';\n\nimport '../button/secondary-button.ts';\nimport '../divider.ts';\n\nconst notificationTypes = new Map([\n  ['info', 'circle-information-small'],\n  ['note', 'circle-information-small'],\n  ['success', 'circle-tick-small'],\n  ['warn', 'circle-exclamation-point-small'],\n  ['error', 'circle-cross-small'],\n]);\n\nconst DEBOUNCE_TIME = 150;\n\n/**\n * It displays messages which require a user's attention without interrupting its tasks.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-notification`. Content should consist of an optional `sbb-title` element and text content.\n * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.\n * @slot icon - Use this slot to display a custom icon by providing an `sbb-icon` component.\n * @cssprop [--sbb-notification-margin=0] - Can be used to modify the margin in order to get a smoother animation.\n * See style section for more information.\n */\nexport\n@customElement('sbb-notification')\nclass SbbNotificationElement extends SbbIconNameMixin(\n  SbbReadonlyMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /** The type of the notification. */\n  @property({ reflect: true }) public accessor type:\n    | 'info'\n    | 'note'\n    | 'success'\n    | 'warn'\n    | 'error' = 'info';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public accessor animation: 'open' | 'close' | 'all' | 'none' = 'all';\n\n  /** The state of the component. */\n  private set _state(state: SbbOpenedClosedState) {\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(): SbbOpenedClosedState {\n    return this._stateInternal;\n  }\n  private _stateInternal!: SbbOpenedClosedState;\n\n  private _notificationElement!: HTMLElement;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _language = new SbbLanguageController(this);\n  private _notificationResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onNotificationResize(),\n  });\n\n  public constructor() {\n    super();\n    this._state = 'closed';\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('size')) {\n      this._configureTitle();\n    }\n  }\n\n  private _open(): void {\n    if (this._state === 'closed') {\n      this._state = 'opening';\n      /** Emits when the opening animation starts. */\n      this.dispatchEvent(new Event('beforeopen'));\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `opened` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleOpening();\n      }\n    }\n  }\n\n  public close(): void {\n    if (this._state === 'opened' && this._dispatchBeforeCloseEvent()) {\n      this._state = 'closing';\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `closed` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleClosing();\n      }\n    }\n  }\n\n  private _dispatchBeforeCloseEvent(): boolean {\n    /** Emits when the closing animation starts. Can be canceled to prevent the component from closing. */\n    return this.dispatchEvent(new Event('beforeclose', { cancelable: true }));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._notificationElement = this.shadowRoot?.querySelector(\n      '.sbb-notification__wrapper',\n    ) as HTMLElement;\n    // We need to wait for the component's `updateComplete` in order to set the correct\n    // height to the notification element.\n    this.updateComplete.then(() => {\n      this._setNotificationHeight();\n      this._open();\n    });\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-notification-animation-duration');\n  }\n\n  private _setNotificationHeight(): void {\n    if (!this._notificationElement?.scrollHeight) {\n      return;\n    }\n    const notificationHeight = `${this._notificationElement.scrollHeight}px`;\n    this.style.setProperty('--sbb-notification-height', notificationHeight);\n  }\n\n  private _onNotificationResize(): void {\n    if (this._state !== 'opened') {\n      return;\n    }\n\n    if (this._resizeObserverTimeout) {\n      clearTimeout(this._resizeObserverTimeout);\n    }\n\n    // Disable the animation when resizing the notification to avoid strange height transition effects.\n    this.internals.states.add('resize-disable-animation');\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('resize-disable-animation'),\n      DEBOUNCE_TIME,\n    );\n\n    // To avoid ResizeObserver loops, we set the height a tick later.\n    setTimeout(() => this._setNotificationHeight());\n  }\n\n  private _onNotificationAnimationEnd(event: AnimationEvent): void {\n    if (this._state === 'opening' && event.animationName === 'open') {\n      this._handleOpening();\n    }\n\n    if (this._state === 'closing' && event.animationName === 'close-height') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this._state = 'opened';\n    this._notificationResizeObserver.observe(this._notificationElement);\n    /** Emits when the opening animation ends. */\n    this.dispatchEvent(new Event('open'));\n  }\n\n  private _handleClosing(): void {\n    this._state = 'closed';\n    /** Emits when the closing animation ends. */\n    this.dispatchEvent(new Event('close'));\n    this._notificationResizeObserver.unobserve(this._notificationElement);\n    setTimeout(() => this.remove());\n  }\n\n  private _handleSlotchange(): void {\n    const title = Array.from(this.children).find((el) => el.localName === 'sbb-title');\n    if (title) {\n      title.slot = 'title';\n    }\n  }\n\n  private _configureTitle(): void {\n    const title = this.querySelector?.<SbbTitleElement>('sbb-title');\n    if (title) {\n      customElements.upgrade(title);\n      title.visualLevel = this.size === 'm' ? '5' : '6';\n    }\n  }\n\n  protected override renderIconName(): string {\n    return super.renderIconName() || notificationTypes.get(this.type)!;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-notification__wrapper\" @animationend=${this._onNotificationAnimationEnd}>\n        <div class=\"sbb-notification\">\n          ${this.renderIconSlot('sbb-notification__icon')}\n          <span class=\"sbb-notification__content\">\n            <slot name=\"title\" @slotchange=${this._configureTitle}></slot>\n            <p class=\"sbb-notification__text\">\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </p>\n          </span>\n\n          ${!this.readOnly\n            ? html`<span class=\"sbb-notification__close-wrapper\">\n                <sbb-divider class=\"sbb-notification__divider\" orientation=\"vertical\"></sbb-divider>\n                <sbb-secondary-button\n                  size=${this.size}\n                  icon-name=\"cross-small\"\n                  @click=${() => this.close()}\n                  aria-label=${i18nCloseNotification[this._language.current]}\n                  class=\"sbb-notification__close\"\n                ></sbb-secondary-button>\n              </span>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-notification': SbbNotificationElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -203,7 +203,7 @@ let SbbOptionBaseElement = (() => {
|
|
|
203
203
|
this.updateDisableHighlight(true);
|
|
204
204
|
return;
|
|
205
205
|
}
|
|
206
|
-
this.label = labelNodes.map((l) => l.wholeText).filter((l) => l.trim()).join();
|
|
206
|
+
this.label = labelNodes.map((l) => l.wholeText).filter((l) => l.trim()).join("");
|
|
207
207
|
}
|
|
208
208
|
getHighlightedLabel() {
|
|
209
209
|
if (!this._highlightString || !this._highlightString.trim()) {
|
|
@@ -297,4 +297,4 @@ let SbbOptionBaseElement = (() => {
|
|
|
297
297
|
export {
|
|
298
298
|
SbbOptionBaseElement
|
|
299
299
|
};
|
|
300
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport {\n  html,\n  LitElement,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { isAndroid, isBlink, isSafari, setOrRemoveAttribute } from '../../core/dom.ts';\nimport {\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n} from '../../core/mixins.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\n\nimport '../../screen-reader-only.ts';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport abstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(SbbHydrationMixin(LitElement))),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor groupLabel = '';\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: () => {\n          this.handleHighlightState();\n          /** @internal */\n          this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n        },\n      }),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'disabled' || name === 'disabledFromGroup') {\n      this.toggleState('disabled', this.disabled || this.disabledFromGroup);\n      setOrRemoveAttribute(\n        this,\n        'tabindex',\n        isAndroid && !this.disabled && !this.disabledFromGroup ? 0 : null,\n      );\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleState('disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleState('active', value);\n  }\n\n  protected updateAriaDisabled(): void {\n    this.internals.ariaDisabled = this.disabled || this.disabledFromGroup ? 'true' : null;\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.internals.ariaSelected = `${this.selected}`;\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join();\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html`<span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          ${this.renderIcon()}\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this.handleHighlightState}></slot>\n            <span\n              aria-hidden=${\n                /**\n                 * Screen readers with Chromium read the option twice.\n                 * We therefore have to hide the option for the screen readers.\n                 * TODO: Recheck periodically if this is still necessary.\n                 * https://issues.chromium.org/issues/460165741\n                 */\n                isBlink ? 'true' : nothing\n              }\n            >\n              ${this.renderLabel()}\n            </span>\n            ${this._inertAriaGroups && this.groupLabel\n              ? html`<sbb-screen-reader-only> (${this.groupLabel})</sbb-screen-reader-only>`\n              : nothing}\n          </span>\n          ${this.renderTick()}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
300
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport {\n  html,\n  LitElement,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { isAndroid, isBlink, isSafari, setOrRemoveAttribute } from '../../core/dom.ts';\nimport {\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n} from '../../core/mixins.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\n\nimport '../../screen-reader-only.ts';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport abstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(SbbHydrationMixin(LitElement))),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor groupLabel = '';\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: () => {\n          this.handleHighlightState();\n          /** @internal */\n          this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n        },\n      }),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'disabled' || name === 'disabledFromGroup') {\n      this.toggleState('disabled', this.disabled || this.disabledFromGroup);\n      setOrRemoveAttribute(\n        this,\n        'tabindex',\n        isAndroid && !this.disabled && !this.disabledFromGroup ? 0 : null,\n      );\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleState('disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleState('active', value);\n  }\n\n  protected updateAriaDisabled(): void {\n    this.internals.ariaDisabled = this.disabled || this.disabledFromGroup ? 'true' : null;\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.internals.ariaSelected = `${this.selected}`;\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join('');\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html`<span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          ${this.renderIcon()}\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this.handleHighlightState}></slot>\n            <span\n              aria-hidden=${\n                /**\n                 * Screen readers with Chromium read the option twice.\n                 * We therefore have to hide the option for the screen readers.\n                 * TODO: Recheck periodically if this is still necessary.\n                 * https://issues.chromium.org/issues/460165741\n                 */\n                isBlink ? 'true' : nothing\n              }\n            >\n              ${this.renderLabel()}\n            </span>\n            ${this._inertAriaGroups && this.groupLabel\n              ? html`<sbb-screen-reader-only> (${this.groupLabel})</sbb-screen-reader-only>`\n              : nothing}\n          </span>\n          ${this.renderTick()}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -31,7 +31,7 @@ export declare abstract class SbbOverlayBaseElement extends SbbOverlayBaseElemen
|
|
|
31
31
|
protected inertController: SbbInertController;
|
|
32
32
|
protected escapableOverlayController: SbbEscapableOverlayController;
|
|
33
33
|
private _ariaLiveRefToggle;
|
|
34
|
-
private _ariaLiveRef
|
|
34
|
+
private _ariaLiveRef?;
|
|
35
35
|
private _triggerElement;
|
|
36
36
|
private _triggerAbortController;
|
|
37
37
|
protected abstract closeAttribute: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAA6B,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AAC9F,OAAO,EACL,6BAA6B,EAC7B,kBAAkB,EAClB,qBAAqB,EACtB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AASzE,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAAsB,qBAAsB,SAAQ,0BAAyC;IAC3F;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD,kHAAkH;IAClH,SAEgB,kBAAkB,EAAE,MAAM,CAAM;IAEhD;;;;OAIG;IACH,SAEgB,oBAAoB,EAAE,OAAO,CAAS;IAGtD,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,mBAAmB,yBAAoC;IACjE,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,eAAe,qBAAgC;IACzD,SAAS,CAAC,0BAA0B,gCAA2C;IAE/E,OAAO,CAAC,kBAAkB,CAAS;IACnC,OAAO,CAAC,YAAY,
|
|
1
|
+
{"version":3,"file":"overlay-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/overlay/overlay-base-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAA6B,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AAC9F,OAAO,EACL,6BAA6B,EAC7B,kBAAkB,EAClB,qBAAqB,EACtB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,uBAAuB,CAAC;AASzE,eAAO,MAAM,WAAW,EAAE,qBAAqB,EAAO,CAAC;;AAEvD,8BAAsB,qBAAsB,SAAQ,0BAAyC;IAC3F;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD,kHAAkH;IAClH,SAEgB,kBAAkB,EAAE,MAAM,CAAM;IAEhD;;;;OAIG;IACH,SAEgB,oBAAoB,EAAE,OAAO,CAAS;IAGtD,SAAS,CAAC,kBAAkB,CAAC,EAAE,WAAW,CAAC;IAC3C,SAAS,CAAC,mBAAmB,CAAC,EAAE,WAAW,CAAC;IAC5C,SAAS,CAAC,qBAAqB,EAAG,eAAe,CAAC;IAClD,SAAS,CAAC,mBAAmB,yBAAoC;IACjE,SAAS,CAAC,aAAa,mBAA0B;IACjD,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC;IAC3B,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,eAAe,qBAAgC;IACzD,SAAS,CAAC,0BAA0B,gCAA2C;IAE/E,OAAO,CAAC,kBAAkB,CAAS;IACnC,OAAO,CAAC,YAAY,CAAC,CAA6B;IAClD,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,uBAAuB,CAAmB;IAElD,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC;IAC1C,SAAS,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,QAAQ,CAAC,aAAa,IAAI,IAAI;IACxC,SAAS,CAAC,QAAQ,CAAC,aAAa,IAAI,IAAI;IACxC,SAAS,CAAC,QAAQ,CAAC,uBAAuB,IAAI,OAAO;IAErD,2BAA2B;IACpB,IAAI,IAAI,IAAI;IA2BnB,4BAA4B;IACrB,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,GAAG;IA0BrC,iBAAiB,IAAI,IAAI;IASzC,OAAO,CAAC,iBAAiB;cAoBN,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAiB9D,oBAAoB,IAAI,IAAI;IAS5B,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAQP,SAAS,CAAC,uBAAuB,IAAI,IAAI;IAiBzC,SAAS,CAAC,kCAAkC,IAAI,IAAI;IAKpD,SAAS,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IA0BzD,SAAS,CAAC,wBAAwB,IAAI,IAAI;IAO1C,SAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI;IAiBrD,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;cAQzC,wBAAwB,CAAC,MAAM,CAAC,EAAE,2BAA2B,GAAG,OAAO;cAOvE,kBAAkB,CAAC,MAAM,CAAC,EAAE,2BAA2B,GAAG,OAAO;CAIrF"}
|