@sbb-esta/lyne-elements-dev 4.10.0-dev.1775640591 → 4.10.0-dev.1775641359

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.
@@ -120356,6 +120356,11 @@
120356
120356
  "privacy": "private",
120357
120357
  "default": "new SbbEscapableOverlayController(this)"
120358
120358
  },
120359
+ {
120360
+ "kind": "field",
120361
+ "name": "_closeOnNavigation",
120362
+ "privacy": "private"
120363
+ },
120359
120364
  {
120360
120365
  "kind": "method",
120361
120366
  "name": "toggle",
@@ -38,6 +38,7 @@ export declare class SbbSidebarElement extends SbbSidebarElement_base {
38
38
  constructor();
39
39
  connectedCallback(): void;
40
40
  disconnectedCallback(): void;
41
+ private _closeOnNavigation;
41
42
  protected willUpdate(changedProperties: PropertyValues<this>): void;
42
43
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
43
44
  /** Toggles the sidebar visibility. */
@@ -1 +1 @@
1
- {"version":3,"file":"sidebar.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/sidebar/sidebar/sidebar.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAMtE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;;AAItG;;;;;GAKG;AACH,qBAAa,iBAAkB,SAAQ,sBAAkD;IACvF,gBAAgC,WAAW,EAAE,MAAM,CAAiB;IACpE,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,iEAAiE;IACjE,SACgB,KAAK,EAAE,OAAO,GAAG,MAAM,CAAW;IAElD,oDAAoD;IACpD,SAEgB,IAAI,EAAE,MAAM,GAAG,MAAM,CAAU;IAE/C,gDAAgD;IAChD,SAGgB,QAAQ,EAAE,OAAO,GAAG,KAAK,CAAW;IAEpD;;;;OAIG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC;;;;OAIG;IACH,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,8EAA8E;IAC9E,IAAW,SAAS,IAAI,0BAA0B,GAAG,IAAI,CAExD;IACD,OAAO,CAAC,UAAU,CAA2C;IAE7D,OAAO,CAAC,mBAAmB,CAA4B;IACvD,OAAO,CAAC,oBAAoB,CAAoC;IAChE,OAAO,CAAC,2BAA2B,CAA2C;;IAkB9D,iBAAiB,IAAI,IAAI;IAWzB,oBAAoB,IAAI,IAAI;cAMzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAoBzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9E,sCAAsC;IAC/B,MAAM,IAAI,IAAI;IAQrB,yBAAyB;IAClB,IAAI,IAAI,IAAI;IAiCnB,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAYtB,0BAA0B;IACnB,KAAK,IAAI,IAAI;IAwBpB,OAAO,CAAC,cAAc;IAqBtB,OAAO,CAAC,UAAU;IAkBlB,SAAS,CAAC,SAAS,IAAI,IAAI;IAK3B,OAAO,CAAC,mBAAmB;IAyB3B,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,oBAAoB;cAOT,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
1
+ {"version":3,"file":"sidebar.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/sidebar/sidebar/sidebar.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAMtE,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;;AAItG;;;;;GAKG;AACH,qBAAa,iBAAkB,SAAQ,sBAAkD;IACvF,gBAAgC,WAAW,EAAE,MAAM,CAAiB;IACpE,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,iEAAiE;IACjE,SACgB,KAAK,EAAE,OAAO,GAAG,MAAM,CAAW;IAElD,oDAAoD;IACpD,SAEgB,IAAI,EAAE,MAAM,GAAG,MAAM,CAAU;IAE/C,gDAAgD;IAChD,SAGgB,QAAQ,EAAE,OAAO,GAAG,KAAK,CAAW;IAEpD;;;;OAIG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC;;;;OAIG;IACH,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,8EAA8E;IAC9E,IAAW,SAAS,IAAI,0BAA0B,GAAG,IAAI,CAExD;IACD,OAAO,CAAC,UAAU,CAA2C;IAE7D,OAAO,CAAC,mBAAmB,CAA4B;IACvD,OAAO,CAAC,oBAAoB,CAAoC;IAChE,OAAO,CAAC,2BAA2B,CAA2C;;IAkB9D,iBAAiB,IAAI,IAAI;IAmBzB,oBAAoB,IAAI,IAAI;IAc5C,OAAO,CAAC,kBAAkB,CAIxB;cAEiB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAoBzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9E,sCAAsC;IAC/B,MAAM,IAAI,IAAI;IAQrB,yBAAyB;IAClB,IAAI,IAAI,IAAI;IAiCnB,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAYtB,0BAA0B;IACnB,KAAK,IAAI,IAAI;IAwBpB,OAAO,CAAC,cAAc;IAqBtB,OAAO,CAAC,UAAU;IAkBlB,SAAS,CAAC,SAAS,IAAI,IAAI;IAK3B,OAAO,CAAC,mBAAmB;IAyB3B,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,WAAW;IAKnB,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,oBAAoB;cAOT,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbSidebarElement } from "../../sidebar.component-DvRTyNry.js";
1
+ import { t as SbbSidebarElement } from "../../sidebar.component-BLqO52nH.js";
2
2
  export { SbbSidebarElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbSidebarElement } from "../sidebar.component-DvRTyNry.js";
1
+ import { t as SbbSidebarElement } from "../sidebar.component-BLqO52nH.js";
2
2
  //#region src/elements/sidebar/sidebar.ts
3
3
  /** @entrypoint */
4
4
  SbbSidebarElement.define();
@@ -214,6 +214,9 @@ var SbbSidebarElement = (() => {
214
214
  this._lastFocusedElement = null;
215
215
  this._focusTrapController = new SbbFocusTrapController(this);
216
216
  this._escapableOverlayController = new SbbEscapableOverlayController(this);
217
+ this._closeOnNavigation = () => {
218
+ if (this._isModeOver() && this.isOpen) this.close();
219
+ };
217
220
  this.addController(new ResizeController(this, {
218
221
  skipInitial: true,
219
222
  callback: () => this._updateSidebarWidth()
@@ -227,11 +230,15 @@ var SbbSidebarElement = (() => {
227
230
  this._container = this.closest?.("sbb-sidebar-container");
228
231
  this._updateSidebarWidth();
229
232
  if (this.isOpen && this._isModeOver()) this._takeFocus();
233
+ if (!isServer) if (window.navigation) window.navigation.addEventListener("navigate", this._closeOnNavigation);
234
+ else window.addEventListener("popstate", this._closeOnNavigation);
230
235
  }
231
236
  disconnectedCallback() {
232
237
  super.disconnectedCallback();
233
238
  this.container?.style.removeProperty(this._buildCssWidthVar());
234
239
  this._container = null;
240
+ if (!isServer) if (window.navigation) window.navigation.removeEventListener("navigate", this._closeOnNavigation);
241
+ else window.removeEventListener("popstate", this._closeOnNavigation);
235
242
  }
236
243
  willUpdate(changedProperties) {
237
244
  super.willUpdate(changedProperties);
@@ -345,4 +352,4 @@ var SbbSidebarElement = (() => {
345
352
  //#endregion
346
353
  export { SbbSidebarElement as t };
347
354
 
348
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sidebar.component-DvRTyNry.js","names":[],"sources":["../../../src/elements/sidebar/sidebar/sidebar.scss?inline","../../../src/elements/sidebar/sidebar/sidebar.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-link-text-decoration-line: none;\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n  --sbb-sidebar-scrollbar-placeholder-width: var(--sbb-spacing-fixed-3x);\n  --_sbb-sidebar-margin: 0;\n  --_sbb-sidebar-margin-block-start: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-translate-x: -100%;\n  --_sbb-sidebar-z-index: 2;\n  --_sbb-sidebar-padding-inline-end: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-padding-block-start: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-border-radius-start: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-border-radius-end: 0;\n  --_sbb-sidebar-close-button-size: var(--sbb-size-element-xs);\n  --_sbb-sidebar-max-width: calc(100% - 2 * var(--_sbb-sidebar-margin));\n\n  display: block;\n  width: #{sbb.px-to-rem-build(320)};\n\n  // Subtract the width of the scrollbar from the padding (Exclude iOS browsers because they use overlay scrollbars)\n  @supports (scrollbar-gutter: stable) and (not (-webkit-touch-callout: none)) {\n    --_sbb-sidebar-padding-inline-end: calc(\n      var(--sbb-sidebar-padding) - var(--sbb-sidebar-scrollbar-placeholder-width)\n    );\n  }\n}\n\n:host([color='white']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n}\n\n:host([color='milk']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-3);\n}\n\n:host(:is([mode='over'], :state(mode-over-forced):not(:state(mode-over-forced-closing)))) {\n  --_sbb-sidebar-margin: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-border-radius-end: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-z-index: 3;\n}\n\n:host(:is(:dir(rtl), [position='end'])) {\n  --_sbb-sidebar-translate-x: 100%;\n}\n\n:host(:dir(rtl)[position='end']) {\n  --_sbb-sidebar-translate-x: -100%;\n}\n\n.sbb-sidebar {\n  width: inherit;\n  max-width: var(--_sbb-sidebar-max-width);\n  background-color: var(--sbb-sidebar-background-color);\n  display: flex;\n  flex-direction: column;\n  position: absolute;\n  overflow: hidden;\n  inset-block: 0;\n  z-index: var(--_sbb-sidebar-z-index);\n  border-start-start-radius: var(--_sbb-sidebar-border-radius-start);\n  border-start-end-radius: var(--_sbb-sidebar-border-radius-start);\n  border-end-start-radius: var(--_sbb-sidebar-border-radius-end);\n  border-end-end-radius: var(--_sbb-sidebar-border-radius-end);\n  margin: var(--_sbb-sidebar-margin);\n  margin-block-start: var(--_sbb-sidebar-margin-block-start);\n  transition-duration: var(--sbb-sidebar-container-animation-duration);\n  transition-timing-function: var(--sbb-sidebar-container-animation-easing);\n  transition-property: width, translate;\n  translate: none;\n\n  :host([position='end']) & {\n    inset-inline-end: 0;\n  }\n\n  :host(:state(state-closed)) & {\n    // Stops the sidenav from poking out (e.g. with the box shadow) while it's off-screen.\n    // We can't use `display` because it interrupts the transition and `transition-behavior`\n    // isn't available in all browsers.\n    visibility: hidden;\n  }\n\n  :host(:is(:state(state-closing), :state(state-closed))) & {\n    translate: var(--_sbb-sidebar-translate-x) 0;\n  }\n}\n\n.sbb-sidebar-title-section {\n  display: flex;\n  width: 100%;\n  gap: var(--sbb-sidebar-title-gap);\n  background-color: var(--sbb-sidebar-background-color);\n  padding-inline: var(--sbb-sidebar-padding);\n  transition: box-shadow var(--sbb-animation-easing) var(--sbb-sidebar-container-animation-duration);\n  box-shadow: none;\n\n  :host(:state(scrolled)) & {\n    box-shadow: var(--sbb-box-shadow-level-5-soft);\n  }\n}\n\n.sbb-sidebar-content-section {\n  @include sbb.scrollbar;\n\n  padding-block-start: var(--_sbb-sidebar-padding-block-start);\n  padding-inline: var(--sbb-sidebar-padding) var(--_sbb-sidebar-padding-inline-end);\n  overflow-y: auto;\n  flex-grow: 1;\n\n  // If the element is scrollable and has no focusable content, it gets focused.\n  // To adapt to lyne styles we colorize it\n  outline-color: var(--sbb-focus-outline-color);\n\n  @supports (scrollbar-gutter: stable) {\n    scrollbar-gutter: stable;\n  }\n}\n\n::slotted(sbb-sidebar-title) {\n  flex-grow: 1;\n  margin-block: var(--sbb-sidebar-title-padding-block);\n}\n\n::slotted(sbb-sidebar-close-button) {\n  order: 1;\n\n  // Due to design needs, we have to translate the close button to the right\n  margin-inline-end: calc(\n    -1 * (var(--sbb-sidebar-padding) - var(--sbb-sidebar-title-padding-block))\n  );\n  margin-block: var(--sbb-sidebar-title-padding-block);\n  inset-inline-end: var(--sbb-sidebar-padding);\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { eventOptions, property } from 'lit/decorators.js';\n\nimport { SbbFocusTrapController } from '../../core/a11y.ts';\nimport { SbbOpenCloseBaseElement } from '../../core/base-elements.ts';\nimport { SbbEscapableOverlayController } from '../../core/controllers.ts';\nimport { forceType, handleDistinctChange } from '../../core/decorators.ts';\nimport { isZeroAnimationDuration } from '../../core/dom.ts';\nimport { SbbAnimationCompleteMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSidebarContainerElement } from '../sidebar-container/sidebar-container.component.ts';\n\nimport style from './sidebar.scss?inline';\n\n/**\n * This component corresponds to a sidebar that can be opened on the sidebar container.\n *\n * @slot - Use the unnamed slot to slot any content into the sidebar.\n * @slot title - Use the title slot to add an <sbb-title>.\n */\nexport class SbbSidebarElement extends SbbAnimationCompleteMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-sidebar';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Background color of the sidebar. Either `white` or `milk`. */\n  @property({ reflect: true })\n  public accessor color: 'white' | 'milk' = 'white';\n\n  /** Mode of the sidebar; one of 'side' or 'over'. */\n  @forceType((v) => (v === 'over' ? 'over' : 'side'))\n  @property({ reflect: true })\n  public accessor mode: 'side' | 'over' = 'side';\n\n  /** The side that the sidebar is attached to. */\n  @forceType((v) => (v === 'end' ? 'end' : 'start'))\n  @handleDistinctChange((instance, _newValue, oldValue) => instance._updateSidebarWidth(oldValue))\n  @property({ reflect: true })\n  public accessor position: 'start' | 'end' = 'start';\n\n  /**\n   * Whether the sidebar is opened or closed.\n   * Can be used to initially set the opened state, where\n   * the animation will be skipped.\n   */\n  @forceType()\n  @property({ type: Boolean, reflect: true })\n  public accessor opened: boolean = false;\n\n  /**\n   * Whether the sidebar should focus the first focusable element automatically when opened.\n   * Defaults to false in when mode is set to `side`, otherwise defaults to true.\n   * If explicitly enabled, focus will be moved into the sidebar in `side` mode as well.\n   */\n  @forceType()\n  @property({ type: Boolean, attribute: 'focus-on-open' })\n  public accessor focusOnOpen: boolean = false;\n\n  /** Returns the SbbSidebarContainerElement where this sidebar is contained. */\n  public get container(): SbbSidebarContainerElement | null {\n    return this._container;\n  }\n  private _container: SbbSidebarContainerElement | null = null;\n\n  private _lastFocusedElement: HTMLElement | null = null;\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  public constructor() {\n    super();\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._updateSidebarWidth(),\n      }),\n    );\n\n    this.addEventListener?.('click', (e) => {\n      if ((e.target as HTMLElement | undefined)?.localName === 'sbb-sidebar-close-button') {\n        this.close();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this._container = this.closest?.('sbb-sidebar-container');\n    this._updateSidebarWidth();\n\n    if (this.isOpen && this._isModeOver()) {\n      this._takeFocus();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.container?.style.removeProperty(this._buildCssWidthVar());\n    this._container = null;\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('opened')) {\n      if (this.opened) {\n        this.open();\n      } else if (!this.opened) {\n        this.close();\n      }\n    }\n\n    if (changedProperties.has('mode')) {\n      if (this.mode === 'over' && this.isOpen) {\n        this._takeFocus();\n      } else {\n        this.cedeFocus();\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._updateSidebarWidth();\n  }\n\n  /** Toggles the sidebar visibility. */\n  public toggle(): void {\n    if (this.state === 'opening' || this.state === 'opened') {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  /** Opens the sidebar. */\n  public open(): void {\n    if (this.state === 'opening' || this.state === 'opened' || !this.dispatchBeforeOpenEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    if (!isServer && document.activeElement?.localName !== 'body') {\n      this._lastFocusedElement = document.activeElement as HTMLElement;\n    }\n\n    this.opened = true;\n    this.state = 'opening';\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration() || !this.isConnected;\n    const isDuringInitialization = !this.hasUpdated;\n\n    if (!(isDuringInitialization || isZeroAnimationDuration)) {\n      return;\n    }\n    this.internals.states.add('skip-animation');\n\n    // We have to wait for the first update to be completed\n    // in order to have the size of the sidebar ready for the animation.\n    if (isDuringInitialization) {\n      this.updateComplete.then(() => this._handleOpening());\n    } else {\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      this._handleOpening();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-sidebar-container-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n\n    this._takeFocus();\n    this.stopAnimation();\n    this.dispatchOpenEvent();\n  }\n\n  /** Closes the sidebar. */\n  public close(): void {\n    if (this.state === 'closing' || this.state === 'closed' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration();\n\n    if (!this.hasUpdated || isZeroAnimationDuration) {\n      this.internals.states.add('skip-animation');\n    } else {\n      this.state = 'closing';\n    }\n\n    this.opened = false;\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.hasUpdated || isZeroAnimationDuration) {\n      this._handleClosing();\n    }\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n    this.cedeFocus();\n\n    if (!isServer && (this.contains(document.activeElement) || this._isModeOver())) {\n      if (this._lastFocusedElement) {\n        this._lastFocusedElement?.focus();\n      } else {\n        // We don't know where to set the focus, but have to remove it, so we call blur\n        (document.activeElement as HTMLElement).blur();\n      }\n    }\n    this._lastFocusedElement = null;\n\n    this.stopAnimation();\n    this.dispatchCloseEvent();\n  }\n\n  private _takeFocus(): void {\n    // We prevent calling the focus stuff when not needed\n    if (!this.isConnected) {\n      return;\n    }\n    const isModeOver = this._isModeOver();\n\n    if (isModeOver || this.focusOnOpen) {\n      this._focusTrapController.focusInitialElement();\n    }\n\n    if (isModeOver) {\n      this._escapableOverlayController.connect();\n      this._focusTrapController.enabled = true;\n    }\n  }\n\n  // Internal method that we use externally. `protected` preserves type information for type safe access.\n  protected cedeFocus(): void {\n    this._focusTrapController.enabled = false;\n    this._escapableOverlayController.disconnect();\n  }\n\n  private _updateSidebarWidth(oldPosition?: this['position']): void {\n    const container = this.container;\n    if (!container) {\n      return;\n    }\n\n    if (oldPosition) {\n      container.style.removeProperty(this._buildCssWidthVar(oldPosition));\n    }\n\n    const width = this.offsetWidth;\n    if (!width) {\n      return;\n    }\n\n    const newValue = `${width}px`;\n    const actualValue = container.style.getPropertyValue(this._buildCssWidthVar());\n\n    if (actualValue === newValue) {\n      return;\n    }\n\n    container.style.setProperty(this._buildCssWidthVar(), newValue);\n  }\n\n  private _buildCssWidthVar(position = this.position): string {\n    return `--_sbb-sidebar-container-${position}-width`;\n  }\n\n  private _isModeOver(): boolean {\n    // If the minimum space attribute is set, the sidebar should behave like in mode over.\n    return this.mode === 'over' || this.matches(':state(mode-over-forced)');\n  }\n\n  private _onTransitionEnd(event: TransitionEvent): void {\n    // We ensure that we react to the fade in transition on the sbb-sidebar div\n    if (event.propertyName !== 'translate' || event.target !== event.currentTarget) {\n      return;\n    }\n\n    if (this.state === 'opening') {\n      this._handleOpening();\n    } else if (this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  @eventOptions({ passive: true })\n  private _detectScrolledState(): void {\n    this.toggleState(\n      'scrolled',\n      (this.shadowRoot?.querySelector('.sbb-sidebar-content-section')?.scrollTop ?? 0) > 0,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`<div class=\"sbb-sidebar\" @transitionend=${this._onTransitionEnd}>\n      <div class=\"sbb-sidebar-title-section\"><slot name=\"title-section\"></slot></div>\n      <div class=\"sbb-sidebar-content-section\" @scroll=${() => this._detectScrolledState()}>\n        <slot></slot>\n      </div>\n    </div>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-sidebar': SbbSidebarElement;\n  }\n}\n"],"mappings":"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"}
355
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sidebar.component-BLqO52nH.js","names":[],"sources":["../../../src/elements/sidebar/sidebar/sidebar.scss?inline","../../../src/elements/sidebar/sidebar/sidebar.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-link-text-decoration-line: none;\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n  --sbb-sidebar-scrollbar-placeholder-width: var(--sbb-spacing-fixed-3x);\n  --_sbb-sidebar-margin: 0;\n  --_sbb-sidebar-margin-block-start: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-translate-x: -100%;\n  --_sbb-sidebar-z-index: 2;\n  --_sbb-sidebar-padding-inline-end: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-padding-block-start: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-border-radius-start: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-border-radius-end: 0;\n  --_sbb-sidebar-close-button-size: var(--sbb-size-element-xs);\n  --_sbb-sidebar-max-width: calc(100% - 2 * var(--_sbb-sidebar-margin));\n\n  display: block;\n  width: #{sbb.px-to-rem-build(320)};\n\n  // Subtract the width of the scrollbar from the padding (Exclude iOS browsers because they use overlay scrollbars)\n  @supports (scrollbar-gutter: stable) and (not (-webkit-touch-callout: none)) {\n    --_sbb-sidebar-padding-inline-end: calc(\n      var(--sbb-sidebar-padding) - var(--sbb-sidebar-scrollbar-placeholder-width)\n    );\n  }\n}\n\n:host([color='white']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n}\n\n:host([color='milk']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-3);\n}\n\n:host(:is([mode='over'], :state(mode-over-forced):not(:state(mode-over-forced-closing)))) {\n  --_sbb-sidebar-margin: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-border-radius-end: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-z-index: 3;\n}\n\n:host(:is(:dir(rtl), [position='end'])) {\n  --_sbb-sidebar-translate-x: 100%;\n}\n\n:host(:dir(rtl)[position='end']) {\n  --_sbb-sidebar-translate-x: -100%;\n}\n\n.sbb-sidebar {\n  width: inherit;\n  max-width: var(--_sbb-sidebar-max-width);\n  background-color: var(--sbb-sidebar-background-color);\n  display: flex;\n  flex-direction: column;\n  position: absolute;\n  overflow: hidden;\n  inset-block: 0;\n  z-index: var(--_sbb-sidebar-z-index);\n  border-start-start-radius: var(--_sbb-sidebar-border-radius-start);\n  border-start-end-radius: var(--_sbb-sidebar-border-radius-start);\n  border-end-start-radius: var(--_sbb-sidebar-border-radius-end);\n  border-end-end-radius: var(--_sbb-sidebar-border-radius-end);\n  margin: var(--_sbb-sidebar-margin);\n  margin-block-start: var(--_sbb-sidebar-margin-block-start);\n  transition-duration: var(--sbb-sidebar-container-animation-duration);\n  transition-timing-function: var(--sbb-sidebar-container-animation-easing);\n  transition-property: width, translate;\n  translate: none;\n\n  :host([position='end']) & {\n    inset-inline-end: 0;\n  }\n\n  :host(:state(state-closed)) & {\n    // Stops the sidenav from poking out (e.g. with the box shadow) while it's off-screen.\n    // We can't use `display` because it interrupts the transition and `transition-behavior`\n    // isn't available in all browsers.\n    visibility: hidden;\n  }\n\n  :host(:is(:state(state-closing), :state(state-closed))) & {\n    translate: var(--_sbb-sidebar-translate-x) 0;\n  }\n}\n\n.sbb-sidebar-title-section {\n  display: flex;\n  width: 100%;\n  gap: var(--sbb-sidebar-title-gap);\n  background-color: var(--sbb-sidebar-background-color);\n  padding-inline: var(--sbb-sidebar-padding);\n  transition: box-shadow var(--sbb-animation-easing) var(--sbb-sidebar-container-animation-duration);\n  box-shadow: none;\n\n  :host(:state(scrolled)) & {\n    box-shadow: var(--sbb-box-shadow-level-5-soft);\n  }\n}\n\n.sbb-sidebar-content-section {\n  @include sbb.scrollbar;\n\n  padding-block-start: var(--_sbb-sidebar-padding-block-start);\n  padding-inline: var(--sbb-sidebar-padding) var(--_sbb-sidebar-padding-inline-end);\n  overflow-y: auto;\n  flex-grow: 1;\n\n  // If the element is scrollable and has no focusable content, it gets focused.\n  // To adapt to lyne styles we colorize it\n  outline-color: var(--sbb-focus-outline-color);\n\n  @supports (scrollbar-gutter: stable) {\n    scrollbar-gutter: stable;\n  }\n}\n\n::slotted(sbb-sidebar-title) {\n  flex-grow: 1;\n  margin-block: var(--sbb-sidebar-title-padding-block);\n}\n\n::slotted(sbb-sidebar-close-button) {\n  order: 1;\n\n  // Due to design needs, we have to translate the close button to the right\n  margin-inline-end: calc(\n    -1 * (var(--sbb-sidebar-padding) - var(--sbb-sidebar-title-padding-block))\n  );\n  margin-block: var(--sbb-sidebar-title-padding-block);\n  inset-inline-end: var(--sbb-sidebar-padding);\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { eventOptions, property } from 'lit/decorators.js';\n\nimport { SbbFocusTrapController } from '../../core/a11y.ts';\nimport { SbbOpenCloseBaseElement } from '../../core/base-elements.ts';\nimport { SbbEscapableOverlayController } from '../../core/controllers.ts';\nimport { forceType, handleDistinctChange } from '../../core/decorators.ts';\nimport { isZeroAnimationDuration } from '../../core/dom.ts';\nimport { SbbAnimationCompleteMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSidebarContainerElement } from '../sidebar-container/sidebar-container.component.ts';\n\nimport style from './sidebar.scss?inline';\n\n/**\n * This component corresponds to a sidebar that can be opened on the sidebar container.\n *\n * @slot - Use the unnamed slot to slot any content into the sidebar.\n * @slot title - Use the title slot to add an <sbb-title>.\n */\nexport class SbbSidebarElement extends SbbAnimationCompleteMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-sidebar';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Background color of the sidebar. Either `white` or `milk`. */\n  @property({ reflect: true })\n  public accessor color: 'white' | 'milk' = 'white';\n\n  /** Mode of the sidebar; one of 'side' or 'over'. */\n  @forceType((v) => (v === 'over' ? 'over' : 'side'))\n  @property({ reflect: true })\n  public accessor mode: 'side' | 'over' = 'side';\n\n  /** The side that the sidebar is attached to. */\n  @forceType((v) => (v === 'end' ? 'end' : 'start'))\n  @handleDistinctChange((instance, _newValue, oldValue) => instance._updateSidebarWidth(oldValue))\n  @property({ reflect: true })\n  public accessor position: 'start' | 'end' = 'start';\n\n  /**\n   * Whether the sidebar is opened or closed.\n   * Can be used to initially set the opened state, where\n   * the animation will be skipped.\n   */\n  @forceType()\n  @property({ type: Boolean, reflect: true })\n  public accessor opened: boolean = false;\n\n  /**\n   * Whether the sidebar should focus the first focusable element automatically when opened.\n   * Defaults to false in when mode is set to `side`, otherwise defaults to true.\n   * If explicitly enabled, focus will be moved into the sidebar in `side` mode as well.\n   */\n  @forceType()\n  @property({ type: Boolean, attribute: 'focus-on-open' })\n  public accessor focusOnOpen: boolean = false;\n\n  /** Returns the SbbSidebarContainerElement where this sidebar is contained. */\n  public get container(): SbbSidebarContainerElement | null {\n    return this._container;\n  }\n  private _container: SbbSidebarContainerElement | null = null;\n\n  private _lastFocusedElement: HTMLElement | null = null;\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  public constructor() {\n    super();\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._updateSidebarWidth(),\n      }),\n    );\n\n    this.addEventListener?.('click', (e) => {\n      if ((e.target as HTMLElement | undefined)?.localName === 'sbb-sidebar-close-button') {\n        this.close();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this._container = this.closest?.('sbb-sidebar-container');\n    this._updateSidebarWidth();\n\n    if (this.isOpen && this._isModeOver()) {\n      this._takeFocus();\n    }\n\n    if (!isServer) {\n      if (window.navigation) {\n        window.navigation.addEventListener('navigate', this._closeOnNavigation);\n      } else {\n        window.addEventListener('popstate', this._closeOnNavigation);\n      }\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.container?.style.removeProperty(this._buildCssWidthVar());\n    this._container = null;\n\n    if (!isServer) {\n      if (window.navigation) {\n        window.navigation.removeEventListener('navigate', this._closeOnNavigation);\n      } else {\n        window.removeEventListener('popstate', this._closeOnNavigation);\n      }\n    }\n  }\n\n  private _closeOnNavigation = (): void => {\n    if (this._isModeOver() && this.isOpen) {\n      this.close();\n    }\n  };\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('opened')) {\n      if (this.opened) {\n        this.open();\n      } else if (!this.opened) {\n        this.close();\n      }\n    }\n\n    if (changedProperties.has('mode')) {\n      if (this.mode === 'over' && this.isOpen) {\n        this._takeFocus();\n      } else {\n        this.cedeFocus();\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._updateSidebarWidth();\n  }\n\n  /** Toggles the sidebar visibility. */\n  public toggle(): void {\n    if (this.state === 'opening' || this.state === 'opened') {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  /** Opens the sidebar. */\n  public open(): void {\n    if (this.state === 'opening' || this.state === 'opened' || !this.dispatchBeforeOpenEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    if (!isServer && document.activeElement?.localName !== 'body') {\n      this._lastFocusedElement = document.activeElement as HTMLElement;\n    }\n\n    this.opened = true;\n    this.state = 'opening';\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration() || !this.isConnected;\n    const isDuringInitialization = !this.hasUpdated;\n\n    if (!(isDuringInitialization || isZeroAnimationDuration)) {\n      return;\n    }\n    this.internals.states.add('skip-animation');\n\n    // We have to wait for the first update to be completed\n    // in order to have the size of the sidebar ready for the animation.\n    if (isDuringInitialization) {\n      this.updateComplete.then(() => this._handleOpening());\n    } else {\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      this._handleOpening();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-sidebar-container-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n\n    this._takeFocus();\n    this.stopAnimation();\n    this.dispatchOpenEvent();\n  }\n\n  /** Closes the sidebar. */\n  public close(): void {\n    if (this.state === 'closing' || this.state === 'closed' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration();\n\n    if (!this.hasUpdated || isZeroAnimationDuration) {\n      this.internals.states.add('skip-animation');\n    } else {\n      this.state = 'closing';\n    }\n\n    this.opened = false;\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.hasUpdated || isZeroAnimationDuration) {\n      this._handleClosing();\n    }\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n    this.cedeFocus();\n\n    if (!isServer && (this.contains(document.activeElement) || this._isModeOver())) {\n      if (this._lastFocusedElement) {\n        this._lastFocusedElement?.focus();\n      } else {\n        // We don't know where to set the focus, but have to remove it, so we call blur\n        (document.activeElement as HTMLElement).blur();\n      }\n    }\n    this._lastFocusedElement = null;\n\n    this.stopAnimation();\n    this.dispatchCloseEvent();\n  }\n\n  private _takeFocus(): void {\n    // We prevent calling the focus stuff when not needed\n    if (!this.isConnected) {\n      return;\n    }\n    const isModeOver = this._isModeOver();\n\n    if (isModeOver || this.focusOnOpen) {\n      this._focusTrapController.focusInitialElement();\n    }\n\n    if (isModeOver) {\n      this._escapableOverlayController.connect();\n      this._focusTrapController.enabled = true;\n    }\n  }\n\n  // Internal method that we use externally. `protected` preserves type information for type safe access.\n  protected cedeFocus(): void {\n    this._focusTrapController.enabled = false;\n    this._escapableOverlayController.disconnect();\n  }\n\n  private _updateSidebarWidth(oldPosition?: this['position']): void {\n    const container = this.container;\n    if (!container) {\n      return;\n    }\n\n    if (oldPosition) {\n      container.style.removeProperty(this._buildCssWidthVar(oldPosition));\n    }\n\n    const width = this.offsetWidth;\n    if (!width) {\n      return;\n    }\n\n    const newValue = `${width}px`;\n    const actualValue = container.style.getPropertyValue(this._buildCssWidthVar());\n\n    if (actualValue === newValue) {\n      return;\n    }\n\n    container.style.setProperty(this._buildCssWidthVar(), newValue);\n  }\n\n  private _buildCssWidthVar(position = this.position): string {\n    return `--_sbb-sidebar-container-${position}-width`;\n  }\n\n  private _isModeOver(): boolean {\n    // If the minimum space attribute is set, the sidebar should behave like in mode over.\n    return this.mode === 'over' || this.matches(':state(mode-over-forced)');\n  }\n\n  private _onTransitionEnd(event: TransitionEvent): void {\n    // We ensure that we react to the fade in transition on the sbb-sidebar div\n    if (event.propertyName !== 'translate' || event.target !== event.currentTarget) {\n      return;\n    }\n\n    if (this.state === 'opening') {\n      this._handleOpening();\n    } else if (this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  @eventOptions({ passive: true })\n  private _detectScrolledState(): void {\n    this.toggleState(\n      'scrolled',\n      (this.shadowRoot?.querySelector('.sbb-sidebar-content-section')?.scrollTop ?? 0) > 0,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`<div class=\"sbb-sidebar\" @transitionend=${this._onTransitionEnd}>\n      <div class=\"sbb-sidebar-title-section\"><slot name=\"title-section\"></slot></div>\n      <div class=\"sbb-sidebar-content-section\" @scroll=${() => this._detectScrolledState()}>\n        <slot></slot>\n      </div>\n    </div>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-sidebar': SbbSidebarElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;IC4Ba,2BAAiB;mBAAS,0BAA0B,wBAAwB;;;;;;;;;;;;;;;;;;cAA5E,0BAA0B,YAAkD;;;wBAKtF,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;uBAI3B,WAAW,MAAO,MAAM,SAAS,SAAS,OAAQ,EAClD,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;;IAI3B,WAAW,MAAO,MAAM,QAAQ,QAAQ,QAAS;IACjD,sBAAsB,UAAU,WAAW,aAAa,SAAS,oBAAoB,SAAS,CAAC;IAC/F,SAAS,EAAE,SAAS,MAAM,CAAA;IAAC;yBAQ3B,WAAW,EACX,SAAS;IAAE,MAAM;IAAS,SAAS;IAAM,CAAC,CAAA;8BAQ1C,WAAW,EACX,SAAS;IAAE,MAAM;IAAS,WAAW;IAAiB,CAAC,CAAA;uCA6QvD,aAAa,EAAE,SAAS,MAAM,CAAC,CAAA;AAzShC,gBAAA,MAAA,MAAA,mBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,WAAA;KAAA,MAAA,QAAA,IAAgB;KAAK,MAAA,KAAA,UAAA;AAAA,UAAL,QAAK;;KAAA;IAAA,UAAA;IAAA,EAAA,qBAAA,yBAAA;AAKrB,gBAAA,MAAA,MAAA,kBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,UAAA;KAAA,MAAA,QAAA,IAAgB;KAAI,MAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;;KAAA;IAAA,UAAA;IAAA,EAAA,oBAAA,wBAAA;AAMpB,gBAAA,MAAA,MAAA,sBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,cAAA;KAAA,MAAA,QAAA,IAAgB;KAAQ,MAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;;KAAA;IAAA,UAAA;IAAA,EAAA,wBAAA,4BAAA;AASxB,gBAAA,MAAA,MAAA,oBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,YAAA;KAAA,MAAA,QAAA,IAAgB;KAAM,MAAA,KAAA,UAAA;AAAA,UAAN,SAAM;;KAAA;IAAA,UAAA;IAAA,EAAA,sBAAA,0BAAA;AAStB,gBAAA,MAAA,MAAA,yBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,iBAAA;KAAA,MAAA,QAAA,IAAgB;KAAW,MAAA,KAAA,UAAA;AAAA,UAAX,cAAW;;KAAA;IAAA,UAAA;IAAA,EAAA,2BAAA,+BAAA;AA6Q3B,gBAAA,MAAA,MAAA,kCAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,0BAAA;KAAA,MAAA,QAAA,IAAQ;KAAoB;IAAA,UAAA;IAAA,EAAA,MAAA,2BAAA;;;;;;;;;AA/SI,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,gBAAM,CAAC;;EAInF;;EAAA,IAAgB,QAAK;AAAA,UAAA,MAAA;;EAArB,IAAgB,MAAK,OAAA;AAAA,SAAA,yBAAA;;EAKrB;;EAAA,IAAgB,OAAI;AAAA,UAAA,MAAA;;EAApB,IAAgB,KAAI,OAAA;AAAA,SAAA,wBAAA;;EAMpB;;EAAA,IAAgB,WAAQ;AAAA,UAAA,MAAA;;EAAxB,IAAgB,SAAQ,OAAA;AAAA,SAAA,4BAAA;;EASxB;;;;;;EAAA,IAAgB,SAAM;AAAA,UAAA,MAAA;;EAAtB,IAAgB,OAAM,OAAA;AAAA,SAAA,0BAAA;;EAStB;;;;;;EAAA,IAAgB,cAAW;AAAA,UAAA,MAAA;;EAA3B,IAAgB,YAAW,OAAA;AAAA,SAAA,+BAAA;;;EAG3B,IAAW,YAAS;AAClB,UAAO,KAAK;;EAQd,cAAA;AACE,UAAO;AA1CO,SAAA,0BANL,kBAAA,MAAA,2BAAiB,EAAA,kBAAA,MAAA,qBAMc,QAAO;AAKjC,SAAA,yBAAA,kBAAA,MAAA,yBAAA,EAAA,kBAAA,MAAA,oBAAwB,OAAM;AAM9B,SAAA,6BAAA,kBAAA,MAAA,wBAAA,EAAA,kBAAA,MAAA,wBAA4B,QAAO;AASnC,SAAA,2BAAA,kBAAA,MAAA,4BAAA,EAAA,kBAAA,MAAA,sBAAkB,MAAK;AASvB,SAAA,gCAAA,kBAAA,MAAA,0BAAA,EAAA,kBAAA,MAAA,2BAAuB,MAAK;AAMpC,QAAA,cAAU,kBAAA,MAAA,+BAAA,EAAsC;AAEhD,QAAA,sBAA0C;AAC1C,QAAA,uBAAuB,IAAI,uBAAuB,KAAK;AACvD,QAAA,8BAA8B,IAAI,8BAA8B,KAAK;AAmDrE,QAAA,2BAAgC;AACtC,QAAI,KAAK,aAAa,IAAI,KAAK,OAC7B,MAAK,OAAO;;AAjDd,QAAK,cACH,IAAI,iBAAiB,MAAM;IACzB,aAAa;IACb,gBAAgB,KAAK,qBAAA;IACtB,CAAC,CACH;AAED,QAAK,mBAAmB,UAAU,MAAK;AACrC,QAAK,EAAE,QAAoC,cAAc,2BACvD,MAAK,OAAO;KAEd;;EAGY,oBAAiB;AAC/B,SAAM,mBAAmB;AAEzB,QAAK,aAAa,KAAK,UAAU,wBAAwB;AACzD,QAAK,qBAAqB;AAE1B,OAAI,KAAK,UAAU,KAAK,aAAa,CACnC,MAAK,YAAY;AAGnB,OAAI,CAAC,SACH,KAAI,OAAO,WACT,QAAO,WAAW,iBAAiB,YAAY,KAAK,mBAAmB;OAEvE,QAAO,iBAAiB,YAAY,KAAK,mBAAmB;;EAKlD,uBAAoB;AAClC,SAAM,sBAAsB;AAC5B,QAAK,WAAW,MAAM,eAAe,KAAK,mBAAmB,CAAC;AAC9D,QAAK,aAAa;AAElB,OAAI,CAAC,SACH,KAAI,OAAO,WACT,QAAO,WAAW,oBAAoB,YAAY,KAAK,mBAAmB;OAE1E,QAAO,oBAAoB,YAAY,KAAK,mBAAmB;;EAWlD,WAAW,mBAAuC;AACnE,SAAM,WAAW,kBAAkB;AAEnC,OAAI,kBAAkB,IAAI,SAAS;QAC7B,KAAK,OACP,MAAK,MAAM;aACF,CAAC,KAAK,OACf,MAAK,OAAO;;AAIhB,OAAI,kBAAkB,IAAI,OAAO,CAC/B,KAAI,KAAK,SAAS,UAAU,KAAK,OAC/B,MAAK,YAAY;OAEjB,MAAK,WAAW;;EAKH,aAAa,mBAAuC;AACrE,SAAM,aAAa,kBAAkB;AAErC,QAAK,qBAAqB;;;EAIrB,SAAM;AACX,OAAI,KAAK,UAAU,aAAa,KAAK,UAAU,SAC7C,MAAK,OAAO;OAEZ,MAAK,MAAM;;;EAKR,OAAI;AACT,OAAI,KAAK,UAAU,aAAa,KAAK,UAAU,YAAY,CAAC,KAAK,yBAAyB,CACxF;AAGF,QAAK,gBAAgB;AAErB,OAAI,CAAC,YAAY,SAAS,eAAe,cAAc,OACrD,MAAK,sBAAsB,SAAS;AAGtC,QAAK,SAAS;AACd,QAAK,QAAQ;GAEb,MAAM,0BAA0B,KAAK,0BAA0B,IAAI,CAAC,KAAK;GACzE,MAAM,yBAAyB,CAAC,KAAK;AAErC,OAAI,EAAE,0BAA0B,yBAC9B;AAEF,QAAK,UAAU,OAAO,IAAI,iBAAiB;AAI3C,OAAI,uBACF,MAAK,eAAe,WAAW,KAAK,gBAAgB,CAAC;OAIrD,MAAK,gBAAgB;;EAIjB,2BAAwB;AAC9B,UAAO,wBAAwB,MAAM,6CAA6C;;EAG5E,iBAAc;AACpB,QAAK,QAAQ;AAIb,oBAAiB,KAAK,UAAU,OAAO,OAAO,iBAAiB,CAAC;AAEhE,QAAK,YAAY;AACjB,QAAK,eAAe;AACpB,QAAK,mBAAmB;;;EAInB,QAAK;AACV,OAAI,KAAK,UAAU,aAAa,KAAK,UAAU,YAAY,CAAC,KAAK,0BAA0B,CACzF;AAGF,QAAK,gBAAgB;GAErB,MAAM,0BAA0B,KAAK,0BAA0B;AAE/D,OAAI,CAAC,KAAK,cAAc,wBACtB,MAAK,UAAU,OAAO,IAAI,iBAAiB;OAE3C,MAAK,QAAQ;AAGf,QAAK,SAAS;AAId,OAAI,CAAC,KAAK,cAAc,wBACtB,MAAK,gBAAgB;;EAIjB,iBAAc;AACpB,QAAK,QAAQ;AAGb,oBAAiB,KAAK,UAAU,OAAO,OAAO,iBAAiB,CAAC;AAChE,QAAK,WAAW;AAEhB,OAAI,CAAC,aAAa,KAAK,SAAS,SAAS,cAAc,IAAI,KAAK,aAAa,EAC3E,KAAI,KAAK,oBACP,MAAK,qBAAqB,OAAO;OAGhC,UAAS,cAA8B,MAAM;AAGlD,QAAK,sBAAsB;AAE3B,QAAK,eAAe;AACpB,QAAK,oBAAoB;;EAGnB,aAAU;AAEhB,OAAI,CAAC,KAAK,YACR;GAEF,MAAM,aAAa,KAAK,aAAa;AAErC,OAAI,cAAc,KAAK,YACrB,MAAK,qBAAqB,qBAAqB;AAGjD,OAAI,YAAY;AACd,SAAK,4BAA4B,SAAS;AAC1C,SAAK,qBAAqB,UAAU;;;EAK9B,YAAS;AACjB,QAAK,qBAAqB,UAAU;AACpC,QAAK,4BAA4B,YAAY;;EAGvC,oBAAoB,aAA8B;GACxD,MAAM,YAAY,KAAK;AACvB,OAAI,CAAC,UACH;AAGF,OAAI,YACF,WAAU,MAAM,eAAe,KAAK,kBAAkB,YAAY,CAAC;GAGrE,MAAM,QAAQ,KAAK;AACnB,OAAI,CAAC,MACH;GAGF,MAAM,WAAW,GAAG,MAAK;AAGzB,OAFoB,UAAU,MAAM,iBAAiB,KAAK,mBAAmB,CAAC,KAE1D,SAClB;AAGF,aAAU,MAAM,YAAY,KAAK,mBAAmB,EAAE,SAAS;;EAGzD,kBAAkB,WAAW,KAAK,UAAQ;AAChD,UAAO,4BAA4B,SAAQ;;EAGrC,cAAW;AAEjB,UAAO,KAAK,SAAS,UAAU,KAAK,QAAQ,0DAA2B;;EAGjE,iBAAiB,OAAsB;AAE7C,OAAI,MAAM,iBAAiB,eAAe,MAAM,WAAW,MAAM,cAC/D;AAGF,OAAI,KAAK,UAAU,UACjB,MAAK,gBAAgB;YACZ,KAAK,UAAU,UACxB,MAAK,gBAAgB;;EAKjB,uBAAoB;AAC1B,QAAK,YACH,aACC,KAAK,YAAY,cAAc,+BAA+B,EAAE,aAAa,KAAK,EACpF;;EAGgB,SAAM;AACvB,UAAO,IAAI,2CAA2C,KAAK,iBAAgB;;+DAEhB,KAAK,sBAAsB,CAAA"}
@@ -2,7 +2,7 @@ import { t as SbbSidebarCloseButtonElement } from "./sidebar-close-button.compon
2
2
  import { t as SbbSidebarContainerElement } from "./sidebar-container.component-BDSoDAym.js";
3
3
  import { t as SbbSidebarContentElement } from "./sidebar-content.component-JcVKpKbK.js";
4
4
  import { t as SbbSidebarTitleElement } from "./sidebar-title.component-BA_j-Igh.js";
5
- import { t as SbbSidebarElement } from "./sidebar.component-DvRTyNry.js";
5
+ import { t as SbbSidebarElement } from "./sidebar.component-BLqO52nH.js";
6
6
  import "./sidebar.pure.js";
7
7
  //#region src/elements/sidebar.ts
8
8
  /** @entrypoint */
@@ -2,5 +2,5 @@ import { t as SbbSidebarCloseButtonElement } from "./sidebar-close-button.compon
2
2
  import { t as SbbSidebarContainerElement } from "./sidebar-container.component-BDSoDAym.js";
3
3
  import { t as SbbSidebarContentElement } from "./sidebar-content.component-JcVKpKbK.js";
4
4
  import { t as SbbSidebarTitleElement } from "./sidebar-title.component-BA_j-Igh.js";
5
- import { t as SbbSidebarElement } from "./sidebar.component-DvRTyNry.js";
5
+ import { t as SbbSidebarElement } from "./sidebar.component-BLqO52nH.js";
6
6
  export { SbbSidebarCloseButtonElement, SbbSidebarContainerElement, SbbSidebarContentElement, SbbSidebarElement, SbbSidebarTitleElement };
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.10.0-dev.1775640591",
3
+ "version": "4.10.0-dev.1775641359",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/95bc8a82c1d47a81b5ea719a59de5d162e89142b"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/18747eb5dab353848b68cf5e2083a3b165bac848"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../sidebar.component-DxOx02l6.js";
1
+ import { t as e } from "../../sidebar.component-Dsx1FAg0.js";
2
2
  export { e as SbbSidebarElement };
@@ -1,4 +1,4 @@
1
- import { t as e } from "../sidebar.component-DxOx02l6.js";
1
+ import { t as e } from "../sidebar.component-Dsx1FAg0.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/sidebar/sidebar.js' has been deprecated.\nUse either '@sbb-esta/elements/sidebar.js' or '@sbb-esta/elements/sidebar.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbSidebarElement };
@@ -152,7 +152,9 @@ var g = ":host{--sbb-link-text-decoration-line: none;--sbb-sidebar-background-co
152
152
  return this._container;
153
153
  }
154
154
  constructor() {
155
- super(), this.#e = (t(this, v), t(this, b, "white")), this.#t = (t(this, x), t(this, C, "side")), this.#n = (t(this, w), t(this, E, "start")), this.#r = (t(this, D), t(this, k, !1)), this.#i = (t(this, A), t(this, M, !1)), this._container = (t(this, N), null), this._lastFocusedElement = null, this._focusTrapController = new h(this), this._escapableOverlayController = new p(this), this.addController(new m(this, {
155
+ super(), this.#e = (t(this, v), t(this, b, "white")), this.#t = (t(this, x), t(this, C, "side")), this.#n = (t(this, w), t(this, E, "start")), this.#r = (t(this, D), t(this, k, !1)), this.#i = (t(this, A), t(this, M, !1)), this._container = (t(this, N), null), this._lastFocusedElement = null, this._focusTrapController = new h(this), this._escapableOverlayController = new p(this), this._closeOnNavigation = () => {
156
+ this._isModeOver() && this.isOpen && this.close();
157
+ }, this.addController(new m(this, {
156
158
  skipInitial: !0,
157
159
  callback: () => this._updateSidebarWidth()
158
160
  })), this.addEventListener?.("click", (e) => {
@@ -160,10 +162,10 @@ var g = ":host{--sbb-link-text-decoration-line: none;--sbb-sidebar-background-co
160
162
  });
161
163
  }
162
164
  connectedCallback() {
163
- super.connectedCallback(), this._container = this.closest?.("sbb-sidebar-container"), this._updateSidebarWidth(), this.isOpen && this._isModeOver() && this._takeFocus();
165
+ super.connectedCallback(), this._container = this.closest?.("sbb-sidebar-container"), this._updateSidebarWidth(), this.isOpen && this._isModeOver() && this._takeFocus(), r || (window.navigation ? window.navigation.addEventListener("navigate", this._closeOnNavigation) : window.addEventListener("popstate", this._closeOnNavigation));
164
166
  }
165
167
  disconnectedCallback() {
166
- super.disconnectedCallback(), this.container?.style.removeProperty(this._buildCssWidthVar()), this._container = null;
168
+ super.disconnectedCallback(), this.container?.style.removeProperty(this._buildCssWidthVar()), this._container = null, r || (window.navigation ? window.navigation.removeEventListener("navigate", this._closeOnNavigation) : window.removeEventListener("popstate", this._closeOnNavigation));
167
169
  }
168
170
  willUpdate(e) {
169
171
  super.willUpdate(e), e.has("opened") && (this.opened ? this.open() : this.opened || this.close()), e.has("mode") && (this.mode === "over" && this.isOpen ? this._takeFocus() : this.cedeFocus());
package/sidebar.js CHANGED
@@ -2,7 +2,7 @@ import { t as e } from "./sidebar-close-button.component-BEYnX3Hk.js";
2
2
  import { t } from "./sidebar-container.component-BGh7mxq4.js";
3
3
  import { t as n } from "./sidebar-content.component-BEI3kpFh.js";
4
4
  import { t as r } from "./sidebar-title.component-CvKixoOS.js";
5
- import { t as i } from "./sidebar.component-DxOx02l6.js";
5
+ import { t as i } from "./sidebar.component-Dsx1FAg0.js";
6
6
  import "./sidebar.pure.js";
7
7
  i.define(), e.define(), t.define(), n.define(), r.define();
8
8
  //#endregion
package/sidebar.pure.js CHANGED
@@ -2,5 +2,5 @@ import { t as e } from "./sidebar-close-button.component-BEYnX3Hk.js";
2
2
  import { t } from "./sidebar-container.component-BGh7mxq4.js";
3
3
  import { t as n } from "./sidebar-content.component-BEI3kpFh.js";
4
4
  import { t as r } from "./sidebar-title.component-CvKixoOS.js";
5
- import { t as i } from "./sidebar.component-DxOx02l6.js";
5
+ import { t as i } from "./sidebar.component-Dsx1FAg0.js";
6
6
  export { e as SbbSidebarCloseButtonElement, t as SbbSidebarContainerElement, n as SbbSidebarContentElement, i as SbbSidebarElement, r as SbbSidebarTitleElement };