@sbb-esta/lyne-elements-experimental 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.
Files changed (48) hide show
  1. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +2 -0
  2. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  3. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +12 -15
  4. package/core/datetime/date-helper.js +3 -3
  5. package/custom-elements.json +143 -99
  6. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +2 -0
  7. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  8. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +12 -13
  9. package/development/core/datetime/date-helper.js +3 -3
  10. package/development/{differenceInMinutes-D5Nj8Stc.js → differenceInMinutes-B0dawX-5.js} +2 -2
  11. package/development/{format-BQfaa1ZT.js → format-BMkeaqaF.js} +3 -3
  12. package/development/{isValid-DvieCZVi.js → isValid-BYRch7pV.js} +2 -2
  13. package/development/journey-summary/journey-summary.component.js +2 -2
  14. package/development/pearl-chain/pearl-chain.component.js +2 -2
  15. package/development/pearl-chain-time/pearl-chain-time.component.js +1 -1
  16. package/development/seat-reservation/common/mapper/mapper.d.ts +2 -2
  17. package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  18. package/development/seat-reservation/common/mapper/mapper.js +19 -6
  19. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +122 -0
  20. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  21. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +970 -1
  22. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  23. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +3 -1
  24. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  25. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +26 -24
  26. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +2 -2
  27. package/development/timetable-row/timetable-row.component.js +1 -1
  28. package/development/{toDate-D_Vjps95.js → toDate-BWb6Z1JD.js} +2 -2
  29. package/{differenceInMinutes-CP_C5onR.js → differenceInMinutes-COvvdYsJ.js} +1 -1
  30. package/{format-lqeCzmzS.js → format-CmKROkbc.js} +2 -41
  31. package/{isValid-Ceq2O0NQ.js → isValid-m3_OsPaB.js} +1 -1
  32. package/journey-summary/journey-summary.component.js +2 -2
  33. package/package.json +3 -3
  34. package/pearl-chain/pearl-chain.component.js +2 -2
  35. package/pearl-chain-time/pearl-chain-time.component.js +1 -1
  36. package/seat-reservation/common/mapper/mapper.d.ts +2 -2
  37. package/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  38. package/seat-reservation/common/mapper/mapper.js +41 -38
  39. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +122 -0
  40. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  41. package/seat-reservation/common/mapper/seat-reservation-sample-data.js +968 -1
  42. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  43. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +130 -130
  44. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  45. package/seat-reservation/seat-reservation/seat-reservation.component.js +88 -85
  46. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +1 -1
  47. package/timetable-row/timetable-row.component.js +1 -1
  48. package/{toDate-BCXKL_wM.js → toDate-Bw2KTWeq.js} +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAgB1E,OAAO,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AAGhF,OAAO,mCAAmC,CAAC;AAC3C,OAAO,+CAA+C,CAAC;AACvD,OAAO,oCAAoC,CAAC;AAC5C,OAAO,6BAA6B,CAAC;AACrC,OAAO,gCAAgC,CAAC;AACxC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yCAAyC,CAAC;AACjD,OAAO,+BAA+B,CAAC;AAEvC;;;GAGG;AACH,qBAEM,yBAA0B,SAAQ,0BAA0B;IAChE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,oBAAoB,CAAC,CAAiB;IAE9C,OAAO,CAAC,gBAAgB,CAQtB;IAGF,OAAO,CAAC,2BAA2B,CAAkB;cAElC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAgBzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAS3D,MAAM,IAAI,cAAc,GAAG,IAAI;IAKlD,OAAO,CAAC,uCAAuC;IAuC/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAuCtC,OAAO,CAAC,iBAAiB;IAyCzB;;;;;OAKG;IACH,OAAO,CAAC,cAAc;IAuBtB,OAAO,CAAC,mBAAmB;IAuC3B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IA8BhC,OAAO,CAAC,qBAAqB;IAoC7B,OAAO,CAAC,wBAAwB;IAsDhC,OAAO,CAAC,6BAA6B;IAgCrC;;;;;;;;OAQG;IACH,OAAO,CAAC,yBAAyB;IAgFjC,OAAO,CAAC,4BAA4B;IAuCpC,OAAO,CAAC,2BAA2B;IAwCnC;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,iBAAiB;IAmBzB,OAAO,CAAC,gBAAgB;IAUxB;;;;;OAKG;IACH,OAAO,CAAC,QAAQ;IAWhB;;;OAGG;IACH,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,yBAAyB;IAkCjC,OAAO,CAAC,8BAA8B;CAyBvC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,yBAAyB,CAAC;KACnD;CACF"}
1
+ {"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAiB1E,OAAO,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AAGhF,OAAO,mCAAmC,CAAC;AAC3C,OAAO,+CAA+C,CAAC;AACvD,OAAO,oCAAoC,CAAC;AAC5C,OAAO,6BAA6B,CAAC;AACrC,OAAO,gCAAgC,CAAC;AACxC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yCAAyC,CAAC;AACjD,OAAO,+BAA+B,CAAC;AAEvC;;;GAGG;AACH,qBAEM,yBAA0B,SAAQ,0BAA0B;IAChE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,oBAAoB,CAAC,CAAiB;IAE9C,OAAO,CAAC,gBAAgB,CAQtB;IAGF,OAAO,CAAC,2BAA2B,CAAkB;cAElC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAgBzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAS3D,MAAM,IAAI,cAAc,GAAG,IAAI;IAKlD,OAAO,CAAC,uCAAuC;IAuC/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAuCtC,OAAO,CAAC,iBAAiB;IAyCzB;;;;;OAKG;IACH,OAAO,CAAC,cAAc;IAuBtB,OAAO,CAAC,mBAAmB;IAuC3B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IA8BhC,OAAO,CAAC,qBAAqB;IAoC7B,OAAO,CAAC,wBAAwB;IA4DhC,OAAO,CAAC,6BAA6B;IAgCrC;;;;;;;;OAQG;IACH,OAAO,CAAC,yBAAyB;IAgFjC,OAAO,CAAC,4BAA4B;IAuCpC,OAAO,CAAC,2BAA2B;IAwCnC;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,iBAAiB;IAmBzB,OAAO,CAAC,gBAAgB;IAUxB;;;;;OAKG;IACH,OAAO,CAAC,QAAQ;IAWhB;;;OAGG;IACH,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,yBAAyB;IAkCjC,OAAO,CAAC,8BAA8B;CAyBvC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,yBAAyB,CAAC;KACnD;CACF"}
@@ -4,6 +4,7 @@ import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
4
4
  import { css, html, nothing } from "lit";
5
5
  import { customElement } from "lit/decorators.js";
6
6
  import { classMap } from "lit/directives/class-map.js";
7
+ import { repeat } from "lit/directives/repeat.js";
7
8
  import { styleMap } from "lit/directives/style-map.js";
8
9
  import { getI18nSeatReservation } from "../common.js";
9
10
  import { SeatReservationBaseElement } from "./seat-reservation-base-element.js";
@@ -555,19 +556,20 @@ let SbbSeatReservationElement = (() => {
555
556
  }
556
557
  _getRenderedColumnPlaces(places, coachIndex, deckIndex, placeCoachDeckIndex) {
557
558
  places.sort((placeA, placeB) => Number(placeA.position.x) - Number(placeB.position.x));
558
- return places?.map((place, index) => {
559
+ const trackPlaceId = coachIndex + "-" + placeCoachDeckIndex;
560
+ return html`${repeat(places, (place) => trackPlaceId + "-" + place.number, (place, index) => {
559
561
  const calculatedDimension = this.getCalculatedDimension(place.dimension);
560
562
  const calculatedPosition = this.getCalculatedPosition(place.position);
561
563
  const rotation = place.rotation || 0;
562
564
  const textRotation = this.alignVertical ? -90 : 0;
563
565
  const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);
564
566
  return html`
565
- <td
566
- id="cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}"
567
- class="graphical-element"
568
- >
569
- <sbb-seat-reservation-place-control
570
- style=${styleMap({
567
+ <td
568
+ id="cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}"
569
+ class="graphical-element"
570
+ >
571
+ <sbb-seat-reservation-place-control
572
+ style=${styleMap({
571
573
  "--sbb-seat-reservation-place-control-text-scale-value": Math.min(calculatedDimension.w, calculatedDimension.h),
572
574
  "--sbb-seat-reservation-place-control-width": calculatedDimension.w,
573
575
  "--sbb-seat-reservation-place-control-height": calculatedDimension.h,
@@ -576,22 +578,22 @@ let SbbSeatReservationElement = (() => {
576
578
  "--sbb-seat-reservation-place-control-rotation": rotation,
577
579
  "--sbb-seat-reservation-place-control-text-rotation": textRotation
578
580
  })}
579
- @selectplace=${(selectPlaceEvent) => this._onSelectPlace(selectPlaceEvent)}
580
- exportparts="sbb-sr-place-part"
581
- id=${placeId}
582
- class="seat-reservation-place-control"
583
- text=${place.number}
584
- type=${place.type}
585
- state=${place.state}
586
- coach-index=${coachIndex}
587
- deck-index=${placeCoachDeckIndex}
588
- data-deck-index=${deckIndex}
589
- .propertyIds=${place.propertyIds}
590
- .preventClick=${this.preventPlaceClick}
591
- ></sbb-seat-reservation-place-control>
592
- </td>
593
- `;
594
- });
581
+ @selectplace=${(selectPlaceEvent) => this._onSelectPlace(selectPlaceEvent)}
582
+ exportparts="sbb-sr-place-part"
583
+ id=${placeId}
584
+ class="seat-reservation-place-control"
585
+ text=${place.number}
586
+ type=${place.type}
587
+ state=${place.state}
588
+ coach-index=${coachIndex}
589
+ deck-index=${placeCoachDeckIndex}
590
+ data-deck-index=${deckIndex}
591
+ .propertyIds=${place.propertyIds}
592
+ .preventClick=${this.preventPlaceClick}
593
+ ></sbb-seat-reservation-place-control>
594
+ </td>
595
+ `;
596
+ })}`;
595
597
  }
596
598
  _getRenderedGraphicalElements(graphicalElements, coachDimension, coachIndex, coachDeckIndex) {
597
599
  if (!graphicalElements)
@@ -818,4 +820,4 @@ let SbbSeatReservationElement = (() => {
818
820
  export {
819
821
  SbbSeatReservationElement
820
822
  };
821
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport type { SbbPopoverElement } from '@sbb-esta/lyne-elements/popover.js';\nimport { html, nothing } from 'lit';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n  NavigationCoachItem,\n} from '../common.ts';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.ts';\nimport style from './seat-reservation.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/button.js';\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '@sbb-esta/lyne-elements/popover.js';\nimport '../seat-reservation-area.ts';\nimport '../seat-reservation-graphic.ts';\nimport '../seat-reservation-place-control.ts';\nimport '../seat-reservation-navigation-coach.ts';\nimport '../seat-reservation-scoped.ts';\n\n/**\n * Main component for the seat reservation.\n *\n */\nexport\n@customElement('sbb-seat-reservation')\nclass SbbSeatReservationElement extends SeatReservationBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  private _language = new SbbLanguageController(this);\n  private _coachesHtmlTemplate?: TemplateResult;\n  // Graphics that should not be rendered with an area\n  private _notAreaElements = [\n    'DRIVER_AREA',\n    'COACH_PASSAGE',\n    'COACH_WALL_NO_PASSAGE',\n    'COMPARTMENT_PASSAGE',\n    'COMPARTMENT_PASSAGE_HIGH',\n    'COMPARTMENT_PASSAGE_MIDDLE',\n    'COMPARTMENT_PASSAGE_LOW',\n  ];\n\n  // Area icons that should not be fixed during rotation when vertical mode is selected\n  private _notFixedRotatableAreaIcons = ['ENTRY_EXIT'];\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hasNavigation')) {\n      if (this.hasNavigation) {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.removeAttribute('tabindex'));\n      } else {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.setAttribute('tabindex', '0'));\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // We need to wait until the first update is complete to init different html element dimensions\n    this.updateComplete.then(() => {\n      this.initNavigationSelectionByScrollEvent();\n    });\n  }\n\n  protected override render(): TemplateResult | null {\n    this._initVehicleSeatReservationConstruction();\n    return this._coachesHtmlTemplate || null;\n  }\n\n  private _initVehicleSeatReservationConstruction(): void {\n    this._coachesHtmlTemplate = html`\n      <div class=\"sbb-sr__component\">\n        ${this._renderNavigation()}\n        <div\n          class=\"sbb-sr__wrapper-coach-decks\"\n          @keydown=${(evt: KeyboardEvent) => this.keyboardSeatmapEventHadling(evt)}\n        >\n          <div class=\"sbb-sr__wrapper-deck-labels\">${this._renderDeckLabels()}</div>\n          <div\n            @scroll=${() => this.coachAreaScrollend()}\n            id=\"sbb-sr__wrapper-scrollarea\"\n            class=\"sbb-sr__wrapper-scrollarea\"\n            tabindex=\"-1\"\n          >\n            <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\">\n              <ul\n                class=\"${classMap({\n                  'sbb-sr__list-decks': true,\n                  'sbb-sr__list-decks--gap': this.hasMultipleDecks,\n                })}\"\n              >\n                ${this.seatReservations?.map(\n                  (seatReservation: SeatReservation, coachDeckIndex: number) => {\n                    return html`<li class=\"sbb-sr__list-item-deck\">\n                      <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                        ${this._renderCoaches(seatReservation, coachDeckIndex)}\n                      </ul>\n                    </li>`;\n                  },\n                )}\n              </ul>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n\n  private _renderDeckLabels(): TemplateResult[] | null {\n    if (!this.hasMultipleDecks) return null;\n\n    return this.seatReservations.map((seatReservation) => {\n      const deckDescription = getI18nSeatReservation(\n        seatReservation.deckCoachLevel,\n        this._language.current,\n      );\n      return html`<b aria-hidden=\"true\">${deckDescription}</b>`;\n    });\n  }\n\n  private _renderNavigationControlButton(btnDirection: string): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n    const btnNavigationDirectionId =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? 'sbb-sr-navigation__wrapper-button-direction--right'\n        : 'sbb-sr-navigation__wrapper-button-direction--left';\n    const btnIcon =\n      btnDirection == 'DIRECTION_RIGHT' ? 'chevron-small-right-small' : 'chevron-small-left-small';\n    const btnAriaDescription =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? getI18nSeatReservation('SEAT_RESERVATION_END', this._language.current)\n        : getI18nSeatReservation('SEAT_RESERVATION_BEGIN', this._language.current);\n    let btnDisabled = true;\n\n    if (btnDirection == 'DIRECTION_LEFT' && this.selectedCoachIndex > 0) {\n      btnDisabled = false;\n    } else if (\n      btnDirection == 'DIRECTION_RIGHT' &&\n      this.selectedCoachIndex < this.coachNavData.length - 1\n    ) {\n      btnDisabled = false;\n    }\n\n    return html`<div class=\"sbb-sr-navigation__wrapper-button-direction\">\n      <sbb-secondary-button\n        @click=\"${() => this.navigateByDirectionBtn(btnDirection)}\"\n        @focus=\"${() => this.onFocusNavDirectionButton()}\"\n        id=\"${btnNavigationDirectionId}\"\n        class=\"sbb-sr__navigation-control-button\"\n        size=\"m\"\n        icon-name=\"${btnIcon}\"\n        type=\"button\"\n        aria-label=\"${btnAriaDescription}\"\n        role=\"button\"\n        .disabledInteractive=\"${btnDisabled || nothing}\"\n      ></sbb-secondary-button>\n    </div>`;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n    return html`<div class=\"sbb-sr-navigation-wrapper\">\n      <nav id=\"sbb-sr-navigation\" class=\"sbb-sr-navigation\">\n        ${this._renderNavigationControlButton('DIRECTION_LEFT')}\n        <ul\n          id=\"sbb-sr__navigation-list-coaches\"\n          class=\"sbb-sr-navigation__list-coaches\"\n          aria-label=\"${getI18nSeatReservation(\n            'SEAT_RESERVATION_NAVIGATION',\n            this._language.current,\n          )}\"\n        >\n          ${this.coachNavData.map((navigationCoach: NavigationCoachItem, index: number) => {\n            return html`<li>\n              <sbb-seat-reservation-navigation-coach\n                @selectcoach=${(event: CustomEvent<number>) => this._onSelectNavCoach(event)}\n                @focuscoach=${() => this._onFocusNavCoach()}\n                @keyup=${(evt: KeyboardEvent) => this.onKeyNavigationNavCoachButton(evt, index)}\n                index=\"${index}\"\n                coach-id=\"${navigationCoach.id}\"\n                .freePlacesByType=\"${navigationCoach.freePlaces}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\n                .hovered=${this.hoveredCoachIndex === index}\n                .nativeFocusActive=${this.hasSeatReservationNativeFocus}\n                .propertyIds=\"${navigationCoach.propertyIds}\"\n                .travelClass=\"${navigationCoach.travelClass}\"\n                ?driver-area=\"${navigationCoach.isDriverArea}\"\n                ?first=\"${navigationCoach?.driverAreaSide?.left}\"\n                ?last=\"${navigationCoach?.driverAreaSide?.right}\"\n                ?vertical=\"${this.alignVertical}\"\n              >\n              </sbb-seat-reservation-navigation-coach>\n            </li>`;\n          })}\n        </ul>\n        ${this._renderNavigationControlButton('DIRECTION_RIGHT')}\n      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @returns\n   * @param seatReservation\n   * @param coachDeckIndex\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    const coaches: CoachItem[] = JSON.parse(JSON.stringify(seatReservation?.coachItems));\n\n    if (!coaches) {\n      return null;\n    }\n    return coaches.map((coachItem: CoachItem, coachIndex: number) => {\n      return html`\n        <li class=\"sbb-sr__item-coach\">\n          ${this._renderCoachElement(\n            coachItem,\n            coachIndex,\n            coachDeckIndex,\n            seatReservation.deckCoachIndex,\n          )}\n        </li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(\n    coachItem: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult {\n    const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);\n    const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);\n\n    return html`<sbb-seat-reservation-scoped\n      style=${styleMap({\n        '--sbb-seat-reservation-scoped-width': calculatedCoachDimension.w,\n        '--sbb-seat-reservation-scoped-height': calculatedCoachDimension.h,\n      })}\n    >\n      ${this._getRenderedCoachBorders(coachItem)}\n      ${this._getRenderedGraphicalElements(\n        coachItem.graphicElements || [],\n        coachItem.dimension,\n        coachIndex,\n        coachDeckIndex,\n      )}\n      ${this._getRenderedServiceElements(coachIndex, coachDeckIndex, coachItem.serviceElements)}\n\n      <table\n        @focus=${() => this.onFocusTableCoachAndPreselectPlace(coachIndex)}\n        id=\"sbb-sr-coach-${coachIndex}\"\n        class=\"sbb-sr-coach-wrapper__table\"\n        aria-describedby=\"sbb-sr-coach-caption-${coachIndex}\"\n        tabindex=\"-1\"\n      >\n        <caption id=\"sbb-sr-coach-caption-${coachIndex}\" tabindex=\"-1\">\n          <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>\n        </caption>\n        ${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex)}\n      </table>\n    </sbb-seat-reservation-scoped>`;\n  }\n\n  /**\n   * @returns Returns the border graphic (COACH_BORDER_MIDDLE) of a coach with calculated border gap and coach width,\n   * depending on whether the coach is with a driver area or without.\n   */\n  private _getRenderedCoachBorders(coachItem: CoachItem): TemplateResult | null {\n    if (!coachItem.graphicElements) return null;\n\n    const COACH_PASSAGE_WIDTH = 1;\n    const allElements = coachItem.graphicElements;\n    const driverArea = allElements?.find((element: BaseElement) => element.icon === 'DRIVER_AREA');\n    const borderWidth = driverArea\n      ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH\n      : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;\n    const borderHeight = (coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize;\n    const borderOffsetX =\n      driverArea && driverArea.position.x === 0\n        ? driverArea?.dimension.w * this.baseGridSize\n        : this.baseGridSize;\n    return html`\n      <sbb-seat-reservation-graphic\n        style=${styleMap({\n          '--sbb-seat-reservation-graphic-width': borderWidth * this.baseGridSize,\n          '--sbb-seat-reservation-graphic-height': borderHeight,\n          '--sbb-seat-reservation-graphic-top': this.coachBorderPadding * -1,\n          '--sbb-seat-reservation-graphic-left': borderOffsetX,\n          '--sbb-seat-reservation-graphic-position': 'absolute',\n        })}\n        name=\"COACH_BORDER_MIDDLE\"\n        ?stretch=${true}\n        role=\"presentation\"\n      ></sbb-seat-reservation-graphic>\n    `;\n  }\n\n  private _getRenderedRowPlaces(\n    coach: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepare rows with the places to render a table\n    const tableRowPlaces: Record<number, Place[]> = {};\n    for (const place of coach.places) {\n      if (!tableRowPlaces[place.position.y]) {\n        tableRowPlaces[place.position.y] = [place];\n      } else {\n        tableRowPlaces[place.position.y].push(place);\n      }\n    }\n\n    return Object.values(tableRowPlaces)\n      .map((rowPlaces: Place[], index) => {\n        return html`\n          <tr id=\"row-${coachIndex}-${rowPlaces[0].position.y}\" data-row-index=${index}>\n            ${this._getRenderedColumnPlaces(\n              rowPlaces,\n              coachIndex,\n              coachDeckIndex,\n              placeCoachDeckIndex,\n            )}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(\n    places: Place[],\n    coachIndex: number,\n    deckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult[] | null {\n    //Sorts each place by its ascending x coordinate\n    places.sort(\n      (placeA: Place, placeB: Place) => Number(placeA.position.x) - Number(placeB.position.x),\n    );\n\n    return places?.map((place: Place, index: number) => {\n      const calculatedDimension = this.getCalculatedDimension(place.dimension);\n      const calculatedPosition = this.getCalculatedPosition(place.position);\n      const rotation = place.rotation || 0;\n      const textRotation = this.alignVertical ? -90 : 0;\n      const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);\n      return html`\n        <td\n          id=\"cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}\"\n          class=\"graphical-element\"\n        >\n          <sbb-seat-reservation-place-control\n            style=${styleMap({\n              '--sbb-seat-reservation-place-control-text-scale-value': Math.min(\n                calculatedDimension.w,\n                calculatedDimension.h,\n              ),\n              '--sbb-seat-reservation-place-control-width': calculatedDimension.w,\n              '--sbb-seat-reservation-place-control-height': calculatedDimension.h,\n              '--sbb-seat-reservation-place-control-top': calculatedPosition.y,\n              '--sbb-seat-reservation-place-control-left': calculatedPosition.x,\n              '--sbb-seat-reservation-place-control-rotation': rotation,\n              '--sbb-seat-reservation-place-control-text-rotation': textRotation,\n            })}\n            @selectplace=${(selectPlaceEvent: CustomEvent<PlaceSelection>) =>\n              this._onSelectPlace(selectPlaceEvent)}\n            exportparts=\"sbb-sr-place-part\"\n            id=${placeId}\n            class=\"seat-reservation-place-control\"\n            text=${place.number}\n            type=${place.type}\n            state=${place.state}\n            coach-index=${coachIndex}\n            deck-index=${placeCoachDeckIndex}\n            data-deck-index=${deckIndex}\n            .propertyIds=${place.propertyIds}\n            .preventClick=${this.preventPlaceClick}\n          ></sbb-seat-reservation-place-control>\n        </td>\n      `;\n    });\n  }\n\n  private _getRenderedGraphicalElements(\n    graphicalElements: BaseElement[],\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!graphicalElements) return null;\n\n    return graphicalElements?.map((graphicalElement: BaseElement) => {\n      const icon = graphicalElement.icon ?? '';\n      const elementRotation = graphicalElement.rotation || 0;\n      const isNotFixedRotationGraphicalElement =\n        this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon!) === -1;\n      const elementFixedRotation =\n        this.alignVertical && isNotFixedRotationGraphicalElement\n          ? elementRotation - 90\n          : elementRotation;\n\n      //check if the current element is not an area element, since this element is drawn without an area component\n      if (this._notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {\n        return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);\n      }\n      return this._getRenderElementWithArea(\n        graphicalElement,\n        elementFixedRotation,\n        coachDimension,\n        coachIndex,\n        coachDeckIndex,\n      );\n    });\n  }\n\n  /**\n   * creates a rendered element with an area component\n   * @param graphicalElement\n   * @param rotation\n   * @param coachDimension\n   * @param coachIndex used to generate a unique id for the popover trigger\n   * @param coachDeckIndex used to generate a unique id\n   * @private\n   */\n  private _getRenderElementWithArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult {\n    // for TABLE, we use the area component itself to display the table instead of the SVG graphic.\n    // Due to different heights and widths, it wouldn't show correctly. To correct this, we would\n    // need difficult calculations for position, rotation and dimension.\n    const isNotTableGraphic = graphicalElement.icon?.indexOf('TABLE') === -1;\n    const areaProperty = graphicalElement.icon && isNotTableGraphic ? graphicalElement.icon : null;\n    const stretchHeight =\n      this.isElementDirectlyOnBorder(graphicalElement, coachDimension) &&\n      areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\n    );\n\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n    );\n\n    //generate unique index number for the trigger element\n    const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n    let elementMounting = 'free';\n\n    if (graphicalElement.position.y === this.coachBorderOffset * -1) {\n      elementMounting = 'upper-border';\n    } else if (\n      graphicalElement.position.y + graphicalElement.dimension.h ===\n      coachDimension.h + this.coachBorderOffset\n    ) {\n      elementMounting = 'lower-border';\n    }\n\n    return html`\n      <sbb-seat-reservation-area\n        id=\"${triggerId}\"\n        class=\"${classMap({ 'sbb-seat-reservation-area--cursor-pointer': areaProperty !== null })}\"\n        style=${styleMap({\n          '--sbb-seat-reservation-area-width': calculatedDimension.w,\n          '--sbb-seat-reservation-area-height': calculatedDimension.h,\n          '--sbb-seat-reservation-area-top': calculatedPosition.y,\n          '--sbb-seat-reservation-area-left': calculatedPosition.x,\n        })}\n        mounting=${elementMounting}\n        background=\"dark\"\n        aria-hidden=\"true\"\n      >\n        ${areaProperty\n          ? html`\n              <sbb-seat-reservation-graphic\n                style=${styleMap({\n                  '--sbb-seat-reservation-graphic-max-width': calculatedDimension.w,\n                  '--sbb-seat-reservation-graphic-height': this.baseGridSize,\n                  '--sbb-seat-reservation-graphic-rotation': rotation,\n                })}\n                name=${areaProperty}\n                role=\"img\"\n                aria-hidden=\"true\"\n                class=\"auto-width\"\n              ></sbb-seat-reservation-graphic>\n            `\n          : nothing}\n      </sbb-seat-reservation-area>\n      ${areaProperty ? this._popover(triggerId, ariaLabelForArea) : nothing}\n    `;\n  }\n\n  private _getRenderElementWithoutArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n    );\n\n    // If the icon is the driver area, then here concat the vehicle type to get the right vehicle chassis icon\n    const icon =\n      graphicalElement.icon && graphicalElement.icon.indexOf('DRIVER_AREA') === -1\n        ? graphicalElement.icon\n        : graphicalElement.icon?.concat(\n            '_',\n            this.seatReservations[this.currSelectedDeckIndex].vehicleType,\n          );\n\n    return html` <sbb-seat-reservation-graphic\n      style=${styleMap({\n        '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n        '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n        '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n        '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n        '--sbb-seat-reservation-graphic-position': 'absolute',\n        '--sbb-seat-reservation-graphic-rotation': rotation,\n      })}\n      name=${icon ?? nothing}\n      aria-hidden=\"true\"\n      ?stretch=${true}\n    ></sbb-seat-reservation-graphic>`;\n  }\n\n  private _getRenderedServiceElements(\n    coachIndex: number,\n    coachDeckIndex: number,\n    serviceElements?: BaseElement[],\n  ): TemplateResult[] | null {\n    if (!serviceElements) return null;\n\n    return serviceElements?.map((serviceElement: BaseElement) => {\n      const titleDescription = serviceElement.icon\n        ? getI18nSeatReservation(serviceElement.icon, this._language.current)\n        : null;\n      const calculatedDimension = this.getCalculatedDimension(serviceElement.dimension);\n      const calculatedPosition = this.getCalculatedPosition(serviceElement.position);\n      const elementRotation = serviceElement.rotation || 0;\n      const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;\n\n      //generate unique index number for the trigger element\n      const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n\n      return html`\n        <sbb-seat-reservation-graphic\n          id=\"${triggerId}\"\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n            '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n            '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n            '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n            '--sbb-seat-reservation-graphic-position': 'absolute',\n            '--sbb-seat-reservation-graphic-rotation': elementFixedRotation,\n          })}\n          class=\"sbb-seat-reservation-graphic--cursor-pointer\"\n          name=${serviceElement.icon ?? nothing}\n          role=\"img\"\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        ${this._popover(triggerId, titleDescription)}\n      `;\n    });\n  }\n\n  /**\n   * Manages the selected place event triggered from the place\n   * Each selection emits an array of all selected places\n   * @param selectPlaceEvent\n   */\n  private _onSelectPlace(selectPlaceEvent: CustomEvent<PlaceSelection>): void {\n    const selectedPlace = selectPlaceEvent.detail;\n    // We have to set preventCoachScrollByPlaceClick to true, to prevent automatic scrolling to the new focused place\n    this.preventCoachScrollByPlaceClick = true;\n    this.isCoachGridFocusable = false;\n    this.focusedCoachIndex = -1;\n    // Check any keyboard event was triggered inside the seat reservation component,\n    // so we can say the native browser focus lies on the component\n    if (!this.hasSeatReservationNativeFocus) {\n      this.hasSeatReservationNativeFocus = true;\n    }\n\n    if (!this.preventPlaceClick) {\n      // Add place to place collection\n      this.updateSelectedSeatReservationPlaces(selectedPlace);\n      this.updateCurrentSelectedPlaceInCoach(selectedPlace);\n    }\n  }\n\n  private _onSelectNavCoach(event: CustomEvent<number>): void {\n    const selectedNavCoachIndex = event.detail;\n\n    this.isKeyboardNavigation = false;\n    this.preventCoachScrollByPlaceClick = false;\n    this.hasSeatReservationNativeFocus = true;\n\n    if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.unfocusPlaceElement();\n      this.scrollToSelectedNavCoach(selectedNavCoachIndex);\n    } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n      this.preselectPlaceInCoach();\n    }\n\n    //close all opened popovers\n    this._closePopover();\n  }\n\n  private _onFocusNavCoach(): void {\n    if (!this.preventCoachScrollByPlaceClick) {\n      this.preselectPlaceInCoach();\n    } else {\n      this.focusPlaceElement(this.currSelectedPlace);\n    }\n\n    this.isAutoScrolling = false;\n  }\n\n  /**\n   * Creates a popover for extra service information\n   * @param triggerId\n   * @param popoverContent\n   * @private\n   */\n  private _popover(\n    triggerId: string,\n    popoverContent: string | null | typeof nothing,\n  ): TemplateResult {\n    return html`\n      <sbb-popover trigger=\"${triggerId}\" hover-trigger=\"\">\n        <p class=\"sbb-text-s sbb-sr-popover\">${popoverContent}</p>\n      </sbb-popover>\n    `;\n  }\n\n  /**\n   * trigger to close all opened popovers (normally only one is opened at a time)\n   * @private\n   */\n  private _closePopover(): void {\n    this.shadowRoot\n      ?.querySelectorAll<SbbPopoverElement>('sbb-popover:state(state-opened)')\n      .forEach((popover) => popover.close());\n  }\n\n  private _getDescriptionTableCoach(coachItem: CoachItem): string {\n    if (!coachItem.places?.length) {\n      return getI18nSeatReservation('COACH_BLOCKED_TABLE_CAPTION', this._language.current, [\n        coachItem.id,\n      ]);\n    }\n\n    let tableCoachDescription: string;\n    const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements!);\n    const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements!);\n\n    tableCoachDescription = getI18nSeatReservation('COACH_TABLE_CAPTION', this._language.current, [\n      coachItem.id,\n    ]);\n\n    if (!this.hasNavigation) {\n      // Expands the number of available seats and bicycle spaces as info\n      const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachItem.places);\n      const freePlacesTxt = getI18nSeatReservation(\n        'COACH_AVAILABLE_NUMBER_OF_PLACES',\n        this._language.current,\n        [freePlaces.seats, freePlaces.bicycles],\n      );\n      tableCoachDescription = tableCoachDescription.concat('. ').concat(freePlacesTxt).concat('. ');\n    }\n\n    if (!!areaDescriptions || !!serviceDescriptions) {\n      tableCoachDescription +=\n        '. ' + getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      tableCoachDescription += serviceDescriptions + ', ' + areaDescriptions + '.';\n    }\n    return tableCoachDescription;\n  }\n\n  private _getTitleDescriptionListString(descriptionsElements: BaseElement[]): string {\n    const uniqueDescriptions: string[] = [];\n\n    return descriptionsElements\n      ?.map((descriptionElement) => {\n        const icon = descriptionElement.icon;\n        if (!icon) return null;\n\n        const descriptionAlreadyExist = uniqueDescriptions.indexOf(icon) > -1;\n        const translation = getI18nSeatReservation(\n          descriptionElement.icon!,\n          this._language.current,\n        );\n        const isValidDescription =\n          this._notFixedRotatableAreaIcons.indexOf(icon) === -1 &&\n          this._notAreaElements.indexOf(icon) === -1;\n\n        if (!descriptionAlreadyExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreadyExist && isValidDescription ? translation : null;\n      })\n      .filter((description) => !!description)\n      .join(', ');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation': SbbSeatReservationElement;\n  }\n}\n"],"names":[],"mappings":"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"}
823
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport type { SbbPopoverElement } from '@sbb-esta/lyne-elements/popover.js';\nimport { html, nothing } from 'lit';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n  NavigationCoachItem,\n} from '../common.ts';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.ts';\nimport style from './seat-reservation.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/button.js';\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '@sbb-esta/lyne-elements/popover.js';\nimport '../seat-reservation-area.ts';\nimport '../seat-reservation-graphic.ts';\nimport '../seat-reservation-place-control.ts';\nimport '../seat-reservation-navigation-coach.ts';\nimport '../seat-reservation-scoped.ts';\n\n/**\n * Main component for the seat reservation.\n *\n */\nexport\n@customElement('sbb-seat-reservation')\nclass SbbSeatReservationElement extends SeatReservationBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  private _language = new SbbLanguageController(this);\n  private _coachesHtmlTemplate?: TemplateResult;\n  // Graphics that should not be rendered with an area\n  private _notAreaElements = [\n    'DRIVER_AREA',\n    'COACH_PASSAGE',\n    'COACH_WALL_NO_PASSAGE',\n    'COMPARTMENT_PASSAGE',\n    'COMPARTMENT_PASSAGE_HIGH',\n    'COMPARTMENT_PASSAGE_MIDDLE',\n    'COMPARTMENT_PASSAGE_LOW',\n  ];\n\n  // Area icons that should not be fixed during rotation when vertical mode is selected\n  private _notFixedRotatableAreaIcons = ['ENTRY_EXIT'];\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hasNavigation')) {\n      if (this.hasNavigation) {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.removeAttribute('tabindex'));\n      } else {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.setAttribute('tabindex', '0'));\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // We need to wait until the first update is complete to init different html element dimensions\n    this.updateComplete.then(() => {\n      this.initNavigationSelectionByScrollEvent();\n    });\n  }\n\n  protected override render(): TemplateResult | null {\n    this._initVehicleSeatReservationConstruction();\n    return this._coachesHtmlTemplate || null;\n  }\n\n  private _initVehicleSeatReservationConstruction(): void {\n    this._coachesHtmlTemplate = html`\n      <div class=\"sbb-sr__component\">\n        ${this._renderNavigation()}\n        <div\n          class=\"sbb-sr__wrapper-coach-decks\"\n          @keydown=${(evt: KeyboardEvent) => this.keyboardSeatmapEventHadling(evt)}\n        >\n          <div class=\"sbb-sr__wrapper-deck-labels\">${this._renderDeckLabels()}</div>\n          <div\n            @scroll=${() => this.coachAreaScrollend()}\n            id=\"sbb-sr__wrapper-scrollarea\"\n            class=\"sbb-sr__wrapper-scrollarea\"\n            tabindex=\"-1\"\n          >\n            <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\">\n              <ul\n                class=\"${classMap({\n                  'sbb-sr__list-decks': true,\n                  'sbb-sr__list-decks--gap': this.hasMultipleDecks,\n                })}\"\n              >\n                ${this.seatReservations?.map(\n                  (seatReservation: SeatReservation, coachDeckIndex: number) => {\n                    return html`<li class=\"sbb-sr__list-item-deck\">\n                      <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                        ${this._renderCoaches(seatReservation, coachDeckIndex)}\n                      </ul>\n                    </li>`;\n                  },\n                )}\n              </ul>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n\n  private _renderDeckLabels(): TemplateResult[] | null {\n    if (!this.hasMultipleDecks) return null;\n\n    return this.seatReservations.map((seatReservation) => {\n      const deckDescription = getI18nSeatReservation(\n        seatReservation.deckCoachLevel,\n        this._language.current,\n      );\n      return html`<b aria-hidden=\"true\">${deckDescription}</b>`;\n    });\n  }\n\n  private _renderNavigationControlButton(btnDirection: string): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n    const btnNavigationDirectionId =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? 'sbb-sr-navigation__wrapper-button-direction--right'\n        : 'sbb-sr-navigation__wrapper-button-direction--left';\n    const btnIcon =\n      btnDirection == 'DIRECTION_RIGHT' ? 'chevron-small-right-small' : 'chevron-small-left-small';\n    const btnAriaDescription =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? getI18nSeatReservation('SEAT_RESERVATION_END', this._language.current)\n        : getI18nSeatReservation('SEAT_RESERVATION_BEGIN', this._language.current);\n    let btnDisabled = true;\n\n    if (btnDirection == 'DIRECTION_LEFT' && this.selectedCoachIndex > 0) {\n      btnDisabled = false;\n    } else if (\n      btnDirection == 'DIRECTION_RIGHT' &&\n      this.selectedCoachIndex < this.coachNavData.length - 1\n    ) {\n      btnDisabled = false;\n    }\n\n    return html`<div class=\"sbb-sr-navigation__wrapper-button-direction\">\n      <sbb-secondary-button\n        @click=\"${() => this.navigateByDirectionBtn(btnDirection)}\"\n        @focus=\"${() => this.onFocusNavDirectionButton()}\"\n        id=\"${btnNavigationDirectionId}\"\n        class=\"sbb-sr__navigation-control-button\"\n        size=\"m\"\n        icon-name=\"${btnIcon}\"\n        type=\"button\"\n        aria-label=\"${btnAriaDescription}\"\n        role=\"button\"\n        .disabledInteractive=\"${btnDisabled || nothing}\"\n      ></sbb-secondary-button>\n    </div>`;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n    return html`<div class=\"sbb-sr-navigation-wrapper\">\n      <nav id=\"sbb-sr-navigation\" class=\"sbb-sr-navigation\">\n        ${this._renderNavigationControlButton('DIRECTION_LEFT')}\n        <ul\n          id=\"sbb-sr__navigation-list-coaches\"\n          class=\"sbb-sr-navigation__list-coaches\"\n          aria-label=\"${getI18nSeatReservation(\n            'SEAT_RESERVATION_NAVIGATION',\n            this._language.current,\n          )}\"\n        >\n          ${this.coachNavData.map((navigationCoach: NavigationCoachItem, index: number) => {\n            return html`<li>\n              <sbb-seat-reservation-navigation-coach\n                @selectcoach=${(event: CustomEvent<number>) => this._onSelectNavCoach(event)}\n                @focuscoach=${() => this._onFocusNavCoach()}\n                @keyup=${(evt: KeyboardEvent) => this.onKeyNavigationNavCoachButton(evt, index)}\n                index=\"${index}\"\n                coach-id=\"${navigationCoach.id}\"\n                .freePlacesByType=\"${navigationCoach.freePlaces}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\n                .hovered=${this.hoveredCoachIndex === index}\n                .nativeFocusActive=${this.hasSeatReservationNativeFocus}\n                .propertyIds=\"${navigationCoach.propertyIds}\"\n                .travelClass=\"${navigationCoach.travelClass}\"\n                ?driver-area=\"${navigationCoach.isDriverArea}\"\n                ?first=\"${navigationCoach?.driverAreaSide?.left}\"\n                ?last=\"${navigationCoach?.driverAreaSide?.right}\"\n                ?vertical=\"${this.alignVertical}\"\n              >\n              </sbb-seat-reservation-navigation-coach>\n            </li>`;\n          })}\n        </ul>\n        ${this._renderNavigationControlButton('DIRECTION_RIGHT')}\n      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @returns\n   * @param seatReservation\n   * @param coachDeckIndex\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    const coaches: CoachItem[] = JSON.parse(JSON.stringify(seatReservation?.coachItems));\n\n    if (!coaches) {\n      return null;\n    }\n    return coaches.map((coachItem: CoachItem, coachIndex: number) => {\n      return html`\n        <li class=\"sbb-sr__item-coach\">\n          ${this._renderCoachElement(\n            coachItem,\n            coachIndex,\n            coachDeckIndex,\n            seatReservation.deckCoachIndex,\n          )}\n        </li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(\n    coachItem: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult {\n    const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);\n    const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);\n\n    return html`<sbb-seat-reservation-scoped\n      style=${styleMap({\n        '--sbb-seat-reservation-scoped-width': calculatedCoachDimension.w,\n        '--sbb-seat-reservation-scoped-height': calculatedCoachDimension.h,\n      })}\n    >\n      ${this._getRenderedCoachBorders(coachItem)}\n      ${this._getRenderedGraphicalElements(\n        coachItem.graphicElements || [],\n        coachItem.dimension,\n        coachIndex,\n        coachDeckIndex,\n      )}\n      ${this._getRenderedServiceElements(coachIndex, coachDeckIndex, coachItem.serviceElements)}\n\n      <table\n        @focus=${() => this.onFocusTableCoachAndPreselectPlace(coachIndex)}\n        id=\"sbb-sr-coach-${coachIndex}\"\n        class=\"sbb-sr-coach-wrapper__table\"\n        aria-describedby=\"sbb-sr-coach-caption-${coachIndex}\"\n        tabindex=\"-1\"\n      >\n        <caption id=\"sbb-sr-coach-caption-${coachIndex}\" tabindex=\"-1\">\n          <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>\n        </caption>\n        ${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex)}\n      </table>\n    </sbb-seat-reservation-scoped>`;\n  }\n\n  /**\n   * @returns Returns the border graphic (COACH_BORDER_MIDDLE) of a coach with calculated border gap and coach width,\n   * depending on whether the coach is with a driver area or without.\n   */\n  private _getRenderedCoachBorders(coachItem: CoachItem): TemplateResult | null {\n    if (!coachItem.graphicElements) return null;\n\n    const COACH_PASSAGE_WIDTH = 1;\n    const allElements = coachItem.graphicElements;\n    const driverArea = allElements?.find((element: BaseElement) => element.icon === 'DRIVER_AREA');\n    const borderWidth = driverArea\n      ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH\n      : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;\n    const borderHeight = (coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize;\n    const borderOffsetX =\n      driverArea && driverArea.position.x === 0\n        ? driverArea?.dimension.w * this.baseGridSize\n        : this.baseGridSize;\n    return html`\n      <sbb-seat-reservation-graphic\n        style=${styleMap({\n          '--sbb-seat-reservation-graphic-width': borderWidth * this.baseGridSize,\n          '--sbb-seat-reservation-graphic-height': borderHeight,\n          '--sbb-seat-reservation-graphic-top': this.coachBorderPadding * -1,\n          '--sbb-seat-reservation-graphic-left': borderOffsetX,\n          '--sbb-seat-reservation-graphic-position': 'absolute',\n        })}\n        name=\"COACH_BORDER_MIDDLE\"\n        ?stretch=${true}\n        role=\"presentation\"\n      ></sbb-seat-reservation-graphic>\n    `;\n  }\n\n  private _getRenderedRowPlaces(\n    coach: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepare rows with the places to render a table\n    const tableRowPlaces: Record<number, Place[]> = {};\n    for (const place of coach.places) {\n      if (!tableRowPlaces[place.position.y]) {\n        tableRowPlaces[place.position.y] = [place];\n      } else {\n        tableRowPlaces[place.position.y].push(place);\n      }\n    }\n\n    return Object.values(tableRowPlaces)\n      .map((rowPlaces: Place[], index) => {\n        return html`\n          <tr id=\"row-${coachIndex}-${rowPlaces[0].position.y}\" data-row-index=${index}>\n            ${this._getRenderedColumnPlaces(\n              rowPlaces,\n              coachIndex,\n              coachDeckIndex,\n              placeCoachDeckIndex,\n            )}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(\n    places: Place[],\n    coachIndex: number,\n    deckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult | null {\n    //Sorts each place by its ascending x coordinate\n    places.sort(\n      (placeA: Place, placeB: Place) => Number(placeA.position.x) - Number(placeB.position.x),\n    );\n\n    // For rendering the places within a td element, here we use repeat directive for better performance for reusing elements (track by id).\n    const trackPlaceId = coachIndex + '-' + placeCoachDeckIndex;\n    return html`${repeat(\n      places,\n      (place) => trackPlaceId + '-' + place.number,\n      (place, index) => {\n        const calculatedDimension = this.getCalculatedDimension(place.dimension);\n        const calculatedPosition = this.getCalculatedPosition(place.position);\n        const rotation = place.rotation || 0;\n        const textRotation = this.alignVertical ? -90 : 0;\n        const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);\n        return html`\n          <td\n            id=\"cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}\"\n            class=\"graphical-element\"\n          >\n            <sbb-seat-reservation-place-control\n              style=${styleMap({\n                '--sbb-seat-reservation-place-control-text-scale-value': Math.min(\n                  calculatedDimension.w,\n                  calculatedDimension.h,\n                ),\n                '--sbb-seat-reservation-place-control-width': calculatedDimension.w,\n                '--sbb-seat-reservation-place-control-height': calculatedDimension.h,\n                '--sbb-seat-reservation-place-control-top': calculatedPosition.y,\n                '--sbb-seat-reservation-place-control-left': calculatedPosition.x,\n                '--sbb-seat-reservation-place-control-rotation': rotation,\n                '--sbb-seat-reservation-place-control-text-rotation': textRotation,\n              })}\n              @selectplace=${(selectPlaceEvent: CustomEvent<PlaceSelection>) =>\n                this._onSelectPlace(selectPlaceEvent)}\n              exportparts=\"sbb-sr-place-part\"\n              id=${placeId}\n              class=\"seat-reservation-place-control\"\n              text=${place.number}\n              type=${place.type}\n              state=${place.state}\n              coach-index=${coachIndex}\n              deck-index=${placeCoachDeckIndex}\n              data-deck-index=${deckIndex}\n              .propertyIds=${place.propertyIds}\n              .preventClick=${this.preventPlaceClick}\n            ></sbb-seat-reservation-place-control>\n          </td>\n        `;\n      },\n    )}`;\n  }\n\n  private _getRenderedGraphicalElements(\n    graphicalElements: BaseElement[],\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!graphicalElements) return null;\n\n    return graphicalElements?.map((graphicalElement: BaseElement) => {\n      const icon = graphicalElement.icon ?? '';\n      const elementRotation = graphicalElement.rotation || 0;\n      const isNotFixedRotationGraphicalElement =\n        this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon!) === -1;\n      const elementFixedRotation =\n        this.alignVertical && isNotFixedRotationGraphicalElement\n          ? elementRotation - 90\n          : elementRotation;\n\n      //check if the current element is not an area element, since this element is drawn without an area component\n      if (this._notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {\n        return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);\n      }\n      return this._getRenderElementWithArea(\n        graphicalElement,\n        elementFixedRotation,\n        coachDimension,\n        coachIndex,\n        coachDeckIndex,\n      );\n    });\n  }\n\n  /**\n   * creates a rendered element with an area component\n   * @param graphicalElement\n   * @param rotation\n   * @param coachDimension\n   * @param coachIndex used to generate a unique id for the popover trigger\n   * @param coachDeckIndex used to generate a unique id\n   * @private\n   */\n  private _getRenderElementWithArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult {\n    // for TABLE, we use the area component itself to display the table instead of the SVG graphic.\n    // Due to different heights and widths, it wouldn't show correctly. To correct this, we would\n    // need difficult calculations for position, rotation and dimension.\n    const isNotTableGraphic = graphicalElement.icon?.indexOf('TABLE') === -1;\n    const areaProperty = graphicalElement.icon && isNotTableGraphic ? graphicalElement.icon : null;\n    const stretchHeight =\n      this.isElementDirectlyOnBorder(graphicalElement, coachDimension) &&\n      areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\n    );\n\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n    );\n\n    //generate unique index number for the trigger element\n    const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n    let elementMounting = 'free';\n\n    if (graphicalElement.position.y === this.coachBorderOffset * -1) {\n      elementMounting = 'upper-border';\n    } else if (\n      graphicalElement.position.y + graphicalElement.dimension.h ===\n      coachDimension.h + this.coachBorderOffset\n    ) {\n      elementMounting = 'lower-border';\n    }\n\n    return html`\n      <sbb-seat-reservation-area\n        id=\"${triggerId}\"\n        class=\"${classMap({ 'sbb-seat-reservation-area--cursor-pointer': areaProperty !== null })}\"\n        style=${styleMap({\n          '--sbb-seat-reservation-area-width': calculatedDimension.w,\n          '--sbb-seat-reservation-area-height': calculatedDimension.h,\n          '--sbb-seat-reservation-area-top': calculatedPosition.y,\n          '--sbb-seat-reservation-area-left': calculatedPosition.x,\n        })}\n        mounting=${elementMounting}\n        background=\"dark\"\n        aria-hidden=\"true\"\n      >\n        ${areaProperty\n          ? html`\n              <sbb-seat-reservation-graphic\n                style=${styleMap({\n                  '--sbb-seat-reservation-graphic-max-width': calculatedDimension.w,\n                  '--sbb-seat-reservation-graphic-height': this.baseGridSize,\n                  '--sbb-seat-reservation-graphic-rotation': rotation,\n                })}\n                name=${areaProperty}\n                role=\"img\"\n                aria-hidden=\"true\"\n                class=\"auto-width\"\n              ></sbb-seat-reservation-graphic>\n            `\n          : nothing}\n      </sbb-seat-reservation-area>\n      ${areaProperty ? this._popover(triggerId, ariaLabelForArea) : nothing}\n    `;\n  }\n\n  private _getRenderElementWithoutArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n    );\n\n    // If the icon is the driver area, then here concat the vehicle type to get the right vehicle chassis icon\n    const icon =\n      graphicalElement.icon && graphicalElement.icon.indexOf('DRIVER_AREA') === -1\n        ? graphicalElement.icon\n        : graphicalElement.icon?.concat(\n            '_',\n            this.seatReservations[this.currSelectedDeckIndex].vehicleType,\n          );\n\n    return html` <sbb-seat-reservation-graphic\n      style=${styleMap({\n        '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n        '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n        '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n        '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n        '--sbb-seat-reservation-graphic-position': 'absolute',\n        '--sbb-seat-reservation-graphic-rotation': rotation,\n      })}\n      name=${icon ?? nothing}\n      aria-hidden=\"true\"\n      ?stretch=${true}\n    ></sbb-seat-reservation-graphic>`;\n  }\n\n  private _getRenderedServiceElements(\n    coachIndex: number,\n    coachDeckIndex: number,\n    serviceElements?: BaseElement[],\n  ): TemplateResult[] | null {\n    if (!serviceElements) return null;\n\n    return serviceElements?.map((serviceElement: BaseElement) => {\n      const titleDescription = serviceElement.icon\n        ? getI18nSeatReservation(serviceElement.icon, this._language.current)\n        : null;\n      const calculatedDimension = this.getCalculatedDimension(serviceElement.dimension);\n      const calculatedPosition = this.getCalculatedPosition(serviceElement.position);\n      const elementRotation = serviceElement.rotation || 0;\n      const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;\n\n      //generate unique index number for the trigger element\n      const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n\n      return html`\n        <sbb-seat-reservation-graphic\n          id=\"${triggerId}\"\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n            '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n            '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n            '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n            '--sbb-seat-reservation-graphic-position': 'absolute',\n            '--sbb-seat-reservation-graphic-rotation': elementFixedRotation,\n          })}\n          class=\"sbb-seat-reservation-graphic--cursor-pointer\"\n          name=${serviceElement.icon ?? nothing}\n          role=\"img\"\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        ${this._popover(triggerId, titleDescription)}\n      `;\n    });\n  }\n\n  /**\n   * Manages the selected place event triggered from the place\n   * Each selection emits an array of all selected places\n   * @param selectPlaceEvent\n   */\n  private _onSelectPlace(selectPlaceEvent: CustomEvent<PlaceSelection>): void {\n    const selectedPlace = selectPlaceEvent.detail;\n    // We have to set preventCoachScrollByPlaceClick to true, to prevent automatic scrolling to the new focused place\n    this.preventCoachScrollByPlaceClick = true;\n    this.isCoachGridFocusable = false;\n    this.focusedCoachIndex = -1;\n    // Check any keyboard event was triggered inside the seat reservation component,\n    // so we can say the native browser focus lies on the component\n    if (!this.hasSeatReservationNativeFocus) {\n      this.hasSeatReservationNativeFocus = true;\n    }\n\n    if (!this.preventPlaceClick) {\n      // Add place to place collection\n      this.updateSelectedSeatReservationPlaces(selectedPlace);\n      this.updateCurrentSelectedPlaceInCoach(selectedPlace);\n    }\n  }\n\n  private _onSelectNavCoach(event: CustomEvent<number>): void {\n    const selectedNavCoachIndex = event.detail;\n\n    this.isKeyboardNavigation = false;\n    this.preventCoachScrollByPlaceClick = false;\n    this.hasSeatReservationNativeFocus = true;\n\n    if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.unfocusPlaceElement();\n      this.scrollToSelectedNavCoach(selectedNavCoachIndex);\n    } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n      this.preselectPlaceInCoach();\n    }\n\n    //close all opened popovers\n    this._closePopover();\n  }\n\n  private _onFocusNavCoach(): void {\n    if (!this.preventCoachScrollByPlaceClick) {\n      this.preselectPlaceInCoach();\n    } else {\n      this.focusPlaceElement(this.currSelectedPlace);\n    }\n\n    this.isAutoScrolling = false;\n  }\n\n  /**\n   * Creates a popover for extra service information\n   * @param triggerId\n   * @param popoverContent\n   * @private\n   */\n  private _popover(\n    triggerId: string,\n    popoverContent: string | null | typeof nothing,\n  ): TemplateResult {\n    return html`\n      <sbb-popover trigger=\"${triggerId}\" hover-trigger=\"\">\n        <p class=\"sbb-text-s sbb-sr-popover\">${popoverContent}</p>\n      </sbb-popover>\n    `;\n  }\n\n  /**\n   * trigger to close all opened popovers (normally only one is opened at a time)\n   * @private\n   */\n  private _closePopover(): void {\n    this.shadowRoot\n      ?.querySelectorAll<SbbPopoverElement>('sbb-popover:state(state-opened)')\n      .forEach((popover) => popover.close());\n  }\n\n  private _getDescriptionTableCoach(coachItem: CoachItem): string {\n    if (!coachItem.places?.length) {\n      return getI18nSeatReservation('COACH_BLOCKED_TABLE_CAPTION', this._language.current, [\n        coachItem.id,\n      ]);\n    }\n\n    let tableCoachDescription: string;\n    const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements!);\n    const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements!);\n\n    tableCoachDescription = getI18nSeatReservation('COACH_TABLE_CAPTION', this._language.current, [\n      coachItem.id,\n    ]);\n\n    if (!this.hasNavigation) {\n      // Expands the number of available seats and bicycle spaces as info\n      const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachItem.places);\n      const freePlacesTxt = getI18nSeatReservation(\n        'COACH_AVAILABLE_NUMBER_OF_PLACES',\n        this._language.current,\n        [freePlaces.seats, freePlaces.bicycles],\n      );\n      tableCoachDescription = tableCoachDescription.concat('. ').concat(freePlacesTxt).concat('. ');\n    }\n\n    if (!!areaDescriptions || !!serviceDescriptions) {\n      tableCoachDescription +=\n        '. ' + getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      tableCoachDescription += serviceDescriptions + ', ' + areaDescriptions + '.';\n    }\n    return tableCoachDescription;\n  }\n\n  private _getTitleDescriptionListString(descriptionsElements: BaseElement[]): string {\n    const uniqueDescriptions: string[] = [];\n\n    return descriptionsElements\n      ?.map((descriptionElement) => {\n        const icon = descriptionElement.icon;\n        if (!icon) return null;\n\n        const descriptionAlreadyExist = uniqueDescriptions.indexOf(icon) > -1;\n        const translation = getI18nSeatReservation(\n          descriptionElement.icon!,\n          this._language.current,\n        );\n        const isValidDescription =\n          this._notFixedRotatableAreaIcons.indexOf(icon) === -1 &&\n          this._notAreaElements.indexOf(icon) === -1;\n\n        if (!descriptionAlreadyExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreadyExist && isValidDescription ? translation : null;\n      })\n      .filter((description) => !!description)\n      .join(', ');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation': SbbSeatReservationElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -417,7 +417,7 @@ let SbbSeatReservationPlaceControlElement = (() => {
417
417
  }, _placeType_accessor_storage = new WeakMap(), _state_accessor_storage = new WeakMap(), _propertyIds_accessor_storage = new WeakMap(), _text_accessor_storage = new WeakMap(), _deckIndex_accessor_storage = new WeakMap(), _coachIndex_accessor_storage = new WeakMap(), _preventClick_accessor_storage = new WeakMap(), _keyfocus_accessor_storage = new WeakMap(), _classThis = _a, (() => {
418
418
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
419
419
  _placeType_decorators = [forceType(), property({ attribute: "type" })];
420
- _state_decorators = [forceType(), property({ attribute: "state" })];
420
+ _state_decorators = [forceType(), property({ attribute: "state", reflect: true })];
421
421
  _propertyIds_decorators = [property({ attribute: "propertyIds", type: Array })];
422
422
  _text_decorators = [forceType(), property({ attribute: "text" })];
423
423
  _deckIndex_decorators = [forceType(), property({ attribute: "deck-index", type: Number })];
@@ -459,4 +459,4 @@ let SbbSeatReservationPlaceControlElement = (() => {
459
459
  export {
460
460
  SbbSeatReservationPlaceControlElement
461
461
  };
462
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-place-control.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"sourcesContent":["import { SbbButtonBaseElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type { PlaceSelection, PlaceState, PlaceType } from '../common.ts';\n\nimport '../seat-reservation-graphic.ts';\n\nimport style from './seat-reservation-place-control.scss?lit&inline';\n\n/**\n * Output the graphic of a seat or a bicycle place as a control element.\n */\nexport\n@customElement('sbb-seat-reservation-place-control')\nclass SbbSeatReservationPlaceControlElement extends SbbButtonBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectplace: 'selectplace',\n  } as const;\n\n  /** placeType of the place, e.g. 'SEAT', 'BICYCLE' */\n  @forceType()\n  @property({ attribute: 'type' })\n  public accessor placeType: PlaceType = 'SEAT';\n\n  /** state of the place, e.g. 'FREE', 'SELECTED', 'BLOCKED' */\n  @forceType()\n  @property({ attribute: 'state' })\n  public accessor state: PlaceState = 'FREE';\n\n  /** property ids of the place, to display more info about the place */\n  @property({ attribute: 'propertyIds', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Deck Index Prop to identifier the right place to deck */\n  @forceType()\n  @property({ attribute: 'deck-index', type: Number })\n  public accessor deckIndex: number = null!;\n\n  /** Coach Index Prop to identifier the right place to coach */\n  @forceType()\n  @property({ attribute: 'coach-index', type: Number })\n  public accessor coachIndex: number = null!;\n\n  /** Prevent click prop prevent any place action */\n  @forceType()\n  @property({ attribute: 'prevent-click', type: Boolean })\n  public accessor preventClick: boolean = false;\n\n  /** Set the place focus outline style */\n  @forceType()\n  @property({ attribute: 'keyfocus' })\n  public accessor keyfocus: string = 'unfocus';\n\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    this.addEventListener('click', () => this._selectPlace());\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('keyfocus')) {\n      if (this.keyfocus === 'focus') {\n        this.focus();\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const name: string = this._getPlaceSvg(this.placeType, this.state);\n    const type: string = this.type.toLowerCase();\n    const state: string = this.state.toLowerCase();\n    const text: string | null = this.text;\n    const width = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-width');\n    const height = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-height');\n    const rotation = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-rotation');\n    const textRotation = this.style?.getPropertyValue(\n      '--sbb-seat-reservation-place-control-text-rotation',\n    );\n    const inverseRotationPlaceCheckIcon = Number(textRotation) - Number(rotation);\n    const disabledClass = this.preventClick ? 'sbb-reservation-place-control--disabled' : null;\n\n    this.title = this._getTitleDescriptionPlace();\n    this.tabIndex = -1;\n\n    return html`\n      <div\n        part=\"sbb-sr-place-part\"\n        class=\"sbb-sr-place-ctrl sbb-sr-place-ctrl--orientation-${rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': width,\n            '--sbb-seat-reservation-graphic-height': height,\n            '--sbb-seat-reservation-graphic-rotation': rotation,\n            '--sbb-seat-reservation-graphic-inverse-rotation': inverseRotationPlaceCheckIcon,\n          })}\n          .name=${name}\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        <span ${this.text ?? nothing} class=\"sbb-sr-place-ctrl__text\" aria-hidden=\"true\"\n          >${text}</span\n        >\n      </div>\n    `;\n  }\n\n  private _getPlaceSvg(type: PlaceType, state: PlaceState): string {\n    const typeString = type as string;\n    const stateString = state as string;\n    return `PLACE_${typeString}_${stateString}`;\n  }\n\n  private _getTitleDescriptionPlace(): string {\n    const translationKey = 'PLACE_CONTROL_' + this.type + '_' + this.state;\n    let description = getI18nSeatReservation(translationKey, this._language.current, [this.text]);\n\n    if (this.propertyIds.length) {\n      description +=\n        '. ' + getI18nSeatReservation('PLACE_PROPERTY', this._language.current).concat(': ');\n      description += this.propertyIds\n        .map((propertyId) =>\n          getI18nSeatReservation('PLACE_PROPERTIES.' + propertyId, this._language.current),\n        )\n        .filter((value) => value)\n        .join(', ');\n    }\n\n    return description;\n  }\n\n  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */\n  private _selectPlace(): void {\n    const selectable = (this.state === 'FREE' || this.state === 'SELECTED') && !this.preventClick;\n\n    if (selectable) {\n      this.state = this.state === 'FREE' ? 'SELECTED' : 'FREE';\n      const placeSelection: PlaceSelection = {\n        id: this.id,\n        deckIndex: this.deckIndex,\n        coachIndex: this.coachIndex,\n        number: this.text,\n        state: this.state,\n        placeType: this.placeType,\n      };\n\n      /**\n       * @type {CustomEvent<PlaceSelection>}\n       * Emits when a place was selected via user interaction and returns a\n       * PlaceSelection object with necessary place information.\n       */\n      this.dispatchEvent(\n        new CustomEvent<PlaceSelection>('selectplace', {\n          detail: placeSelection,\n          bubbles: true,\n          composed: true,\n        }),\n      );\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-place-control': SbbSeatReservationPlaceControlElement;\n  }\n}\n"],"names":[],"mappings":"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"}
462
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-place-control.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"sourcesContent":["import { SbbButtonBaseElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type { PlaceSelection, PlaceState, PlaceType } from '../common.ts';\n\nimport '../seat-reservation-graphic.ts';\n\nimport style from './seat-reservation-place-control.scss?lit&inline';\n\n/**\n * Output the graphic of a seat or a bicycle place as a control element.\n */\nexport\n@customElement('sbb-seat-reservation-place-control')\nclass SbbSeatReservationPlaceControlElement extends SbbButtonBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectplace: 'selectplace',\n  } as const;\n\n  /** placeType of the place, e.g. 'SEAT', 'BICYCLE' */\n  @forceType()\n  @property({ attribute: 'type' })\n  public accessor placeType: PlaceType = 'SEAT';\n\n  /** state of the place, e.g. 'FREE', 'SELECTED', 'BLOCKED' */\n  @forceType()\n  @property({ attribute: 'state', reflect: true })\n  public accessor state: PlaceState = 'FREE';\n\n  /** property ids of the place, to display more info about the place */\n  @property({ attribute: 'propertyIds', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Deck Index Prop to identifier the right place to deck */\n  @forceType()\n  @property({ attribute: 'deck-index', type: Number })\n  public accessor deckIndex: number = null!;\n\n  /** Coach Index Prop to identifier the right place to coach */\n  @forceType()\n  @property({ attribute: 'coach-index', type: Number })\n  public accessor coachIndex: number = null!;\n\n  /** Prevent click prop prevent any place action */\n  @forceType()\n  @property({ attribute: 'prevent-click', type: Boolean })\n  public accessor preventClick: boolean = false;\n\n  /** Set the place focus outline style */\n  @forceType()\n  @property({ attribute: 'keyfocus' })\n  public accessor keyfocus: string = 'unfocus';\n\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    this.addEventListener('click', () => this._selectPlace());\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('keyfocus')) {\n      if (this.keyfocus === 'focus') {\n        this.focus();\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const name: string = this._getPlaceSvg(this.placeType, this.state);\n    const type: string = this.type.toLowerCase();\n    const state: string = this.state.toLowerCase();\n    const text: string | null = this.text;\n    const width = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-width');\n    const height = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-height');\n    const rotation = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-rotation');\n    const textRotation = this.style?.getPropertyValue(\n      '--sbb-seat-reservation-place-control-text-rotation',\n    );\n    const inverseRotationPlaceCheckIcon = Number(textRotation) - Number(rotation);\n    const disabledClass = this.preventClick ? 'sbb-reservation-place-control--disabled' : null;\n\n    this.title = this._getTitleDescriptionPlace();\n    this.tabIndex = -1;\n\n    return html`\n      <div\n        part=\"sbb-sr-place-part\"\n        class=\"sbb-sr-place-ctrl sbb-sr-place-ctrl--orientation-${rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': width,\n            '--sbb-seat-reservation-graphic-height': height,\n            '--sbb-seat-reservation-graphic-rotation': rotation,\n            '--sbb-seat-reservation-graphic-inverse-rotation': inverseRotationPlaceCheckIcon,\n          })}\n          .name=${name}\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        <span ${this.text ?? nothing} class=\"sbb-sr-place-ctrl__text\" aria-hidden=\"true\"\n          >${text}</span\n        >\n      </div>\n    `;\n  }\n\n  private _getPlaceSvg(type: PlaceType, state: PlaceState): string {\n    const typeString = type as string;\n    const stateString = state as string;\n    return `PLACE_${typeString}_${stateString}`;\n  }\n\n  private _getTitleDescriptionPlace(): string {\n    const translationKey = 'PLACE_CONTROL_' + this.type + '_' + this.state;\n    let description = getI18nSeatReservation(translationKey, this._language.current, [this.text]);\n\n    if (this.propertyIds.length) {\n      description +=\n        '. ' + getI18nSeatReservation('PLACE_PROPERTY', this._language.current).concat(': ');\n      description += this.propertyIds\n        .map((propertyId) =>\n          getI18nSeatReservation('PLACE_PROPERTIES.' + propertyId, this._language.current),\n        )\n        .filter((value) => value)\n        .join(', ');\n    }\n\n    return description;\n  }\n\n  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */\n  private _selectPlace(): void {\n    const selectable = (this.state === 'FREE' || this.state === 'SELECTED') && !this.preventClick;\n\n    if (selectable) {\n      this.state = this.state === 'FREE' ? 'SELECTED' : 'FREE';\n      const placeSelection: PlaceSelection = {\n        id: this.id,\n        deckIndex: this.deckIndex,\n        coachIndex: this.coachIndex,\n        number: this.text,\n        state: this.state,\n        placeType: this.placeType,\n      };\n\n      /**\n       * @type {CustomEvent<PlaceSelection>}\n       * Emits when a place was selected via user interaction and returns a\n       * PlaceSelection object with necessary place information.\n       */\n      this.dispatchEvent(\n        new CustomEvent<PlaceSelection>('selectplace', {\n          detail: placeSelection,\n          bubbles: true,\n          composed: true,\n        }),\n      );\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-place-control': SbbSeatReservationPlaceControlElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -20,7 +20,7 @@ import "@sbb-esta/lyne-elements/card.js";
20
20
  import "@sbb-esta/lyne-elements/icon.js";
21
21
  import "@sbb-esta/lyne-elements/timetable-occupancy.js";
22
22
  import "../pearl-chain-time.js";
23
- import { f as format } from "../format-BQfaa1ZT.js";
23
+ import { f as format } from "../format-BMkeaqaF.js";
24
24
  const style = css`:host {
25
25
  --sbb-timetable-row-gap: var(--sbb-spacing-fixed-2x);
26
26
  --sbb-timetable-row-height: 1.5625rem;
@@ -2,7 +2,7 @@ const millisecondsInWeek = 6048e5;
2
2
  const millisecondsInDay = 864e5;
3
3
  const millisecondsInMinute = 6e4;
4
4
  const millisecondsInHour = 36e5;
5
- const constructFromSymbol = Symbol.for("constructDateFrom");
5
+ const constructFromSymbol = /* @__PURE__ */ Symbol.for("constructDateFrom");
6
6
  function constructFrom(date, value) {
7
7
  if (typeof date === "function") return date(value);
8
8
  if (date && typeof date === "object" && constructFromSymbol in date)
@@ -21,4 +21,4 @@ export {
21
21
  millisecondsInMinute as m,
22
22
  toDate as t
23
23
  };
24
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toDate-D_Vjps95.js","sources":["../../../node_modules/date-fns/constants.js","../../../node_modules/date-fns/constructFrom.js","../../../node_modules/date-fns/toDate.js"],"sourcesContent":["/**\n * @module constants\n * @summary Useful constants\n * @description\n * Collection of useful date constants.\n *\n * The constants could be imported from `date-fns/constants`:\n *\n * ```ts\n * import { maxTime, minTime } from \"./constants/date-fns/constants\";\n *\n * function isAllowedTime(time) {\n *   return time <= maxTime && time >= minTime;\n * }\n * ```\n */\n\n/**\n * @constant\n * @name daysInWeek\n * @summary Days in 1 week.\n */\nexport const daysInWeek = 7;\n\n/**\n * @constant\n * @name daysInYear\n * @summary Days in 1 year.\n *\n * @description\n * How many days in a year.\n *\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate<DateType extends Date>(date: DateType): DateType {\n *   return constructFrom(\n *     date, // Use constructor from the given date\n *     date.getTime() // Use the date value to create a new date\n *   );\n * }\n */\nexport function constructFrom(date, value) {\n  if (typeof date === \"function\") return date(value);\n\n  if (date && typeof date === \"object\" && constructFromSymbol in date)\n    return date[constructFromSymbol](value);\n\n  if (date instanceof Date) return new date.constructor(value);\n\n  return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n  // [TODO] Get rid of `toDate` or `constructFrom`?\n  return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n"],"names":[],"mappings":"AA4EY,MAAC,qBAAqB;AAOtB,MAAC,oBAAoB;AAOrB,MAAC,uBAAuB;AAOxB,MAAC,qBAAqB;AAsH3B,MAAM,sBAAsB,OAAO,IAAI,mBAAmB;AClL1D,SAAS,cAAc,MAAM,OAAO;AACzC,MAAI,OAAO,SAAS,WAAY,QAAO,KAAK,KAAK;AAEjD,MAAI,QAAQ,OAAO,SAAS,YAAY,uBAAuB;AAC7D,WAAO,KAAK,mBAAmB,EAAE,KAAK;AAExC,MAAI,gBAAgB,KAAM,QAAO,IAAI,KAAK,YAAY,KAAK;AAE3D,SAAO,IAAI,KAAK,KAAK;AACvB;ACNO,SAAS,OAAO,UAAU,SAAS;AAExC,SAAO,cAAc,WAAW,UAAU,QAAQ;AACpD;","x_google_ignoreList":[0,1,2]}
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toDate-BWb6Z1JD.js","sources":["../../../node_modules/date-fns/constants.js","../../../node_modules/date-fns/constructFrom.js","../../../node_modules/date-fns/toDate.js"],"sourcesContent":["/**\n * @module constants\n * @summary Useful constants\n * @description\n * Collection of useful date constants.\n *\n * The constants could be imported from `date-fns/constants`:\n *\n * ```ts\n * import { maxTime, minTime } from \"./constants/date-fns/constants\";\n *\n * function isAllowedTime(time) {\n *   return time <= maxTime && time >= minTime;\n * }\n * ```\n */\n\n/**\n * @constant\n * @name daysInWeek\n * @summary Days in 1 week.\n */\nexport const daysInWeek = 7;\n\n/**\n * @constant\n * @name daysInYear\n * @summary Days in 1 year.\n *\n * @description\n * How many days in a year.\n *\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occurs every 4 years, except for years that are divisible by 100 and not divisible by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n */\nexport const daysInYear = 365.2425;\n\n/**\n * @constant\n * @name maxTime\n * @summary Maximum allowed time.\n *\n * @example\n * import { maxTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = 8640000000000001 <= maxTime;\n * //=> false\n *\n * new Date(8640000000000001);\n * //=> Invalid Date\n */\nexport const maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * @constant\n * @name minTime\n * @summary Minimum allowed time.\n *\n * @example\n * import { minTime } from \"./constants/date-fns/constants\";\n *\n * const isValid = -8640000000000001 >= minTime;\n * //=> false\n *\n * new Date(-8640000000000001)\n * //=> Invalid Date\n */\nexport const minTime = -maxTime;\n\n/**\n * @constant\n * @name millisecondsInWeek\n * @summary Milliseconds in 1 week.\n */\nexport const millisecondsInWeek = 604800000;\n\n/**\n * @constant\n * @name millisecondsInDay\n * @summary Milliseconds in 1 day.\n */\nexport const millisecondsInDay = 86400000;\n\n/**\n * @constant\n * @name millisecondsInMinute\n * @summary Milliseconds in 1 minute\n */\nexport const millisecondsInMinute = 60000;\n\n/**\n * @constant\n * @name millisecondsInHour\n * @summary Milliseconds in 1 hour\n */\nexport const millisecondsInHour = 3600000;\n\n/**\n * @constant\n * @name millisecondsInSecond\n * @summary Milliseconds in 1 second\n */\nexport const millisecondsInSecond = 1000;\n\n/**\n * @constant\n * @name minutesInYear\n * @summary Minutes in 1 year.\n */\nexport const minutesInYear = 525600;\n\n/**\n * @constant\n * @name minutesInMonth\n * @summary Minutes in 1 month.\n */\nexport const minutesInMonth = 43200;\n\n/**\n * @constant\n * @name minutesInDay\n * @summary Minutes in 1 day.\n */\nexport const minutesInDay = 1440;\n\n/**\n * @constant\n * @name minutesInHour\n * @summary Minutes in 1 hour.\n */\nexport const minutesInHour = 60;\n\n/**\n * @constant\n * @name monthsInQuarter\n * @summary Months in 1 quarter.\n */\nexport const monthsInQuarter = 3;\n\n/**\n * @constant\n * @name monthsInYear\n * @summary Months in 1 year.\n */\nexport const monthsInYear = 12;\n\n/**\n * @constant\n * @name quartersInYear\n * @summary Quarters in 1 year\n */\nexport const quartersInYear = 4;\n\n/**\n * @constant\n * @name secondsInHour\n * @summary Seconds in 1 hour.\n */\nexport const secondsInHour = 3600;\n\n/**\n * @constant\n * @name secondsInMinute\n * @summary Seconds in 1 minute.\n */\nexport const secondsInMinute = 60;\n\n/**\n * @constant\n * @name secondsInDay\n * @summary Seconds in 1 day.\n */\nexport const secondsInDay = secondsInHour * 24;\n\n/**\n * @constant\n * @name secondsInWeek\n * @summary Seconds in 1 week.\n */\nexport const secondsInWeek = secondsInDay * 7;\n\n/**\n * @constant\n * @name secondsInYear\n * @summary Seconds in 1 year.\n */\nexport const secondsInYear = secondsInDay * daysInYear;\n\n/**\n * @constant\n * @name secondsInMonth\n * @summary Seconds in 1 month\n */\nexport const secondsInMonth = secondsInYear / 12;\n\n/**\n * @constant\n * @name secondsInQuarter\n * @summary Seconds in 1 quarter.\n */\nexport const secondsInQuarter = secondsInMonth * 3;\n\n/**\n * @constant\n * @name constructFromSymbol\n * @summary Symbol enabling Date extensions to inherit properties from the reference date.\n *\n * The symbol is used to enable the `constructFrom` function to construct a date\n * using a reference date and a value. It allows to transfer extra properties\n * from the reference date to the new date. It's useful for extensions like\n * [`TZDate`](https://github.com/date-fns/tz) that accept a time zone as\n * a constructor argument.\n */\nexport const constructFromSymbol = Symbol.for(\"constructDateFrom\");\n","import { constructFromSymbol } from \"./constants.js\";\n\n/**\n * @name constructFrom\n * @category Generic Helpers\n * @summary Constructs a date using the reference date and the value\n *\n * @description\n * The function constructs a new date using the constructor from the reference\n * date and the given value. It helps to build generic functions that accept\n * date extensions.\n *\n * It defaults to `Date` if the passed reference date is a number or a string.\n *\n * Starting from v3.7.0, it allows to construct a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The reference date to take constructor from\n * @param value - The value to create the date\n *\n * @returns Date initialized using the given date and value\n *\n * @example\n * import { constructFrom } from \"./constructFrom/date-fns\";\n *\n * // A function that clones a date preserving the original type\n * function cloneDate<DateType extends Date>(date: DateType): DateType {\n *   return constructFrom(\n *     date, // Use constructor from the given date\n *     date.getTime() // Use the date value to create a new date\n *   );\n * }\n */\nexport function constructFrom(date, value) {\n  if (typeof date === \"function\") return date(value);\n\n  if (date && typeof date === \"object\" && constructFromSymbol in date)\n    return date[constructFromSymbol](value);\n\n  if (date instanceof Date) return new date.constructor(value);\n\n  return new Date(value);\n}\n\n// Fallback for modularized imports:\nexport default constructFrom;\n","import { constructFrom } from \"./constructFrom.js\";\n\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * Starting from v3.7.0, it clones a date using `[Symbol.for(\"constructDateFrom\")]`\n * enabling to transfer extra properties from the reference date to the new date.\n * It's useful for extensions like [`TZDate`](https://github.com/date-fns/tz)\n * that accept a time zone as a constructor argument.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n * @typeParam ResultDate - The result `Date` type, it is the type returned from the context function if it is passed, or inferred from the arguments.\n *\n * @param argument - The value to convert\n *\n * @returns The parsed date in the local time zone\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport function toDate(argument, context) {\n  // [TODO] Get rid of `toDate` or `constructFrom`?\n  return constructFrom(context || argument, argument);\n}\n\n// Fallback for modularized imports:\nexport default toDate;\n"],"names":[],"mappings":"AA4EY,MAAC,qBAAqB;AAOtB,MAAC,oBAAoB;AAOrB,MAAC,uBAAuB;AAOxB,MAAC,qBAAqB;AAsH3B,MAAM,sBAAsB,uBAAO,IAAI,mBAAmB;AClL1D,SAAS,cAAc,MAAM,OAAO;AACzC,MAAI,OAAO,SAAS,WAAY,QAAO,KAAK,KAAK;AAEjD,MAAI,QAAQ,OAAO,SAAS,YAAY,uBAAuB;AAC7D,WAAO,KAAK,mBAAmB,EAAE,KAAK;AAExC,MAAI,gBAAgB,KAAM,QAAO,IAAI,KAAK,YAAY,KAAK;AAE3D,SAAO,IAAI,KAAK,KAAK;AACvB;ACNO,SAAS,OAAO,UAAU,SAAS;AAExC,SAAO,cAAc,WAAW,UAAU,QAAQ;AACpD;","x_google_ignoreList":[0,1,2]}
@@ -1,4 +1,4 @@
1
- import { t as r, m as o } from "./toDate-BCXKL_wM.js";
1
+ import { t as r, m as o } from "./toDate-Bw2KTWeq.js";
2
2
  function c(n, e, i) {
3
3
  const t = r(n, i?.in);
4
4
  return t.setTime(t.getTime() + e * o), t;