@sbb-esta/lyne-elements-experimental 4.0.0-next → 4.0.0-next.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +233 -5
- package/development/seat-reservation/common/mapper/mapper.d.ts +4 -2
- package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
- package/development/seat-reservation/common/mapper/mapper.js +3 -5
- package/development/seat-reservation/common/types.d.ts +1 -0
- package/development/seat-reservation/common/types.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +26 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +71 -18
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation.component.js +14 -13
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +3 -3
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +1 -2
- package/package.json +2 -2
- package/seat-reservation/common/mapper/mapper.d.ts +4 -2
- package/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
- package/seat-reservation/common/mapper/mapper.js +35 -35
- package/seat-reservation/common/types.d.ts +1 -0
- package/seat-reservation/common/types.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +26 -1
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation-base-element.js +121 -71
- package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation.component.js +91 -90
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +2 -0
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +2 -2
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +13 -13
|
@@ -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":"AAGA,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,6BAA6B,CAAC;AACrC,OAAO,gCAAgC,CAAC;AACxC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yCAAyC,CAAC;AACjD,OAAO,+BAA+B,CAAC;AACvC,OAAO,4CAA4C,CAAC;AAEpD;;;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;IAoD/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAmCtC,OAAO,CAAC,iBAAiB;IAwCzB;;;;;OAKG;IACH,OAAO,CAAC,cAAc;
|
|
1
|
+
{"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAGA,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,6BAA6B,CAAC;AACrC,OAAO,gCAAgC,CAAC;AACxC,OAAO,sCAAsC,CAAC;AAC9C,OAAO,yCAAyC,CAAC;AACjD,OAAO,+BAA+B,CAAC;AACvC,OAAO,4CAA4C,CAAC;AAEpD;;;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;IAoD/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAmCtC,OAAO,CAAC,iBAAiB;IAwCzB;;;;;OAKG;IACH,OAAO,CAAC,cAAc;IAuBtB,OAAO,CAAC,mBAAmB;IAsC3B;;;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;IAatB,OAAO,CAAC,iBAAiB;IAgBzB,OAAO,CAAC,gBAAgB;IASxB;;;;;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"}
|
|
@@ -487,10 +487,10 @@ let SbbSeatReservationElement = (() => {
|
|
|
487
487
|
"sbb-sr__list-decks--gap": this.hasMultipleDecks
|
|
488
488
|
})}"
|
|
489
489
|
>
|
|
490
|
-
${this.seatReservations?.map((seatReservation,
|
|
490
|
+
${this.seatReservations?.map((seatReservation, coachDeckIndex) => {
|
|
491
491
|
return html`<li class="sbb-sr__list-item-deck">
|
|
492
492
|
<ul class="sbb-sr__list-coaches" role="presentation">
|
|
493
|
-
${this._renderCoaches(seatReservation,
|
|
493
|
+
${this._renderCoaches(seatReservation, coachDeckIndex)}
|
|
494
494
|
</ul>
|
|
495
495
|
</li>`;
|
|
496
496
|
})}
|
|
@@ -583,7 +583,7 @@ let SbbSeatReservationElement = (() => {
|
|
|
583
583
|
* @param seatReservation
|
|
584
584
|
* @param deckIndex
|
|
585
585
|
*/
|
|
586
|
-
_renderCoaches(seatReservation,
|
|
586
|
+
_renderCoaches(seatReservation, coachDeckIndex) {
|
|
587
587
|
const coaches = JSON.parse(JSON.stringify(seatReservation?.coachItems));
|
|
588
588
|
if (!coaches) {
|
|
589
589
|
return null;
|
|
@@ -591,12 +591,12 @@ let SbbSeatReservationElement = (() => {
|
|
|
591
591
|
return coaches.map((coachItem, coachIndex) => {
|
|
592
592
|
return html`
|
|
593
593
|
<li class="sbb-sr__item-coach">
|
|
594
|
-
${this._renderCoachElement(coachItem, coachIndex,
|
|
594
|
+
${this._renderCoachElement(coachItem, coachIndex, coachDeckIndex, seatReservation.deckCoachIndex)}
|
|
595
595
|
</li>
|
|
596
596
|
`;
|
|
597
597
|
});
|
|
598
598
|
}
|
|
599
|
-
_renderCoachElement(coachItem, coachIndex, coachDeckIndex) {
|
|
599
|
+
_renderCoachElement(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex) {
|
|
600
600
|
const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);
|
|
601
601
|
const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);
|
|
602
602
|
return html`<sbb-seat-reservation-scoped
|
|
@@ -618,7 +618,7 @@ let SbbSeatReservationElement = (() => {
|
|
|
618
618
|
<caption id="sbb-sr-coach-caption-${coachIndex}" tabindex="-1">
|
|
619
619
|
<sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>
|
|
620
620
|
</caption>
|
|
621
|
-
${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex)}
|
|
621
|
+
${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex)}
|
|
622
622
|
</table>
|
|
623
623
|
</sbb-seat-reservation-scoped>`;
|
|
624
624
|
}
|
|
@@ -650,7 +650,7 @@ let SbbSeatReservationElement = (() => {
|
|
|
650
650
|
></sbb-seat-reservation-graphic>
|
|
651
651
|
`;
|
|
652
652
|
}
|
|
653
|
-
_getRenderedRowPlaces(coach, coachIndex,
|
|
653
|
+
_getRenderedRowPlaces(coach, coachIndex, coachDeckIndex, placeCoachDeckIndex) {
|
|
654
654
|
if (!coach.places) {
|
|
655
655
|
return null;
|
|
656
656
|
}
|
|
@@ -665,18 +665,19 @@ let SbbSeatReservationElement = (() => {
|
|
|
665
665
|
return Object.values(tableRowPlaces).map((rowPlaces, index) => {
|
|
666
666
|
return html`
|
|
667
667
|
<tr id="row-${coachIndex}-${rowPlaces[0].position.y}" data-row-index=${index}>
|
|
668
|
-
${this._getRenderedColumnPlaces(rowPlaces, coachIndex,
|
|
668
|
+
${this._getRenderedColumnPlaces(rowPlaces, coachIndex, coachDeckIndex, placeCoachDeckIndex)}
|
|
669
669
|
</tr>
|
|
670
670
|
`;
|
|
671
671
|
}).flatMap((rowTemplate) => rowTemplate);
|
|
672
672
|
}
|
|
673
|
-
_getRenderedColumnPlaces(places, coachIndex, deckIndex) {
|
|
673
|
+
_getRenderedColumnPlaces(places, coachIndex, deckIndex, placeCoachDeckIndex) {
|
|
674
674
|
places.sort((placeA, placeB) => Number(placeA.position.x) - Number(placeB.position.x));
|
|
675
675
|
return places?.map((place, index) => {
|
|
676
676
|
const calculatedDimension = this.getCalculatedDimension(place.dimension);
|
|
677
677
|
const calculatedPosition = this.getCalculatedPosition(place.position);
|
|
678
678
|
const rotation = place.rotation || 0;
|
|
679
679
|
const textRotation = this.alignVertical ? -90 : 0;
|
|
680
|
+
const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);
|
|
680
681
|
return html`
|
|
681
682
|
<td
|
|
682
683
|
id="cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}"
|
|
@@ -694,13 +695,14 @@ let SbbSeatReservationElement = (() => {
|
|
|
694
695
|
})}
|
|
695
696
|
@selectplace=${(selectPlaceEvent) => this._onSelectPlace(selectPlaceEvent)}
|
|
696
697
|
exportparts="sbb-sr-place-part"
|
|
697
|
-
id
|
|
698
|
+
id=${placeId}
|
|
698
699
|
class="seat-reservation-place-control"
|
|
699
700
|
text=${place.number}
|
|
700
701
|
type=${place.type}
|
|
701
702
|
state=${place.state}
|
|
702
703
|
coach-index=${coachIndex}
|
|
703
|
-
deck-index=${
|
|
704
|
+
deck-index=${placeCoachDeckIndex}
|
|
705
|
+
data-deck-index=${deckIndex}
|
|
704
706
|
.propertyIds=${place.propertyIds}
|
|
705
707
|
.preventClick=${this.preventPlaceClick}
|
|
706
708
|
></sbb-seat-reservation-place-control>
|
|
@@ -834,7 +836,6 @@ let SbbSeatReservationElement = (() => {
|
|
|
834
836
|
this.preventCoachScrollByPlaceClick = true;
|
|
835
837
|
this.isCoachGridFocusable = false;
|
|
836
838
|
if (!this.preventPlaceClick) {
|
|
837
|
-
this.currSelectedDeckIndex = selectedPlace.deckIndex;
|
|
838
839
|
this.updateSelectedSeatReservationPlaces(selectedPlace);
|
|
839
840
|
this.updateCurrentSelectedPlaceInCoach(selectedPlace);
|
|
840
841
|
}
|
|
@@ -928,4 +929,4 @@ let SbbSeatReservationElement = (() => {
|
|
|
928
929
|
export {
|
|
929
930
|
SbbSeatReservationElement
|
|
930
931
|
};
|
|
931
|
-
//# 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 { 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.js';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n  NavigationCoachItem,\n} from '../common.js';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.js';\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 '../seat-reservation-area.js';\nimport '../seat-reservation-graphic.js';\nimport '../seat-reservation-place-control.js';\nimport '../seat-reservation-navigation-coach.js';\nimport '../seat-reservation-scoped.js';\nimport '@sbb-esta/lyne-elements/popover/popover.js';\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__container\">\n        <div class=\"sbb-sr sbb-sr__grid\">\n          <div class=\"sbb-sr-navigation-first-grid\">\n            ${this._renderNavigationControlButton('DIRECTION_LEFT')}\n          </div>\n          <div\n            class=\"sbb-sr__component\"\n            @keydown=${(evt: KeyboardEvent) => this.handleKeyboardEvent(evt)}\n          >\n            <div class=\"sbb-sr-grid-inner\">\n              <div class=\"nav-grid\">${this._renderNavigation()}</div>\n              <div class=\"coaches-grid\">\n                <div class=\"sbb-sr__wrapper-coach-decks\">\n                  <div class=\"sbb-sr__wrapper-deck-labels\">${this._renderDeckLabels()}</div>\n                  <div\n                    id=\"sbb-sr__wrapper-scrollarea\"\n                    class=\"sbb-sr__wrapper\"\n                    @scroll=${() => this.coachAreaScrollend()}\n                  >\n                    <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\" tabindex=\"-1\">\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, index: number) => {\n                            return html`<li class=\"sbb-sr__list-item-deck\">\n                              <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                                ${this._renderCoaches(seatReservation, index)}\n                              </ul>\n                            </li>`;\n                          },\n                        )}\n                      </ul>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n          <div class=\"sbb-sr-navigation-last-grid\">\n            ${this._renderNavigationControlButton('DIRECTION_RIGHT')}\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\n    const btnId = btnDirection == 'DIRECTION_RIGHT' ? 'last-tab-element' : 'first-tab-element';\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 <\n        this.seatReservations[this.currSelectedDeckIndex].coachItems.length - 1\n    ) {\n      btnDisabled = false;\n    }\n\n    return html`<sbb-secondary-button\n      @click=\"${() => this.navigateByDirectionBtn(btnDirection)}\"\n      id=\"${btnId}\"\n      class=\"sbb-sr__navigation-control-button\"\n      size=\"s\"\n      icon-name=\"${btnIcon}\"\n      type=\"button\"\n      aria-label=\"${btnAriaDescription}\"\n      role=\"contentinfo\"\n      .disabledInteractive=\"${btnDisabled || nothing}\"\n    ></sbb-secondary-button>`;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n\n    return html`<div class=\"sbb-sr-navigation-wrapper\">\n      <nav id=\"sbb-sr-navigation\" class=\"sbb-sr-navigation\">\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                class=\"${classMap({\n                  'sbb-sr__navigation-coach--hover-scroll': this.hoveredScrollCoachIndex === index,\n                })}\"\n                index=\"${index}\"\n                coach-id=\"${navigationCoach.id}\"\n                .freePlacesByType=\"${navigationCoach.freePlaces}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\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      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @returns\n   * @param seatReservation\n   * @param deckIndex\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    deckIndex: 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(coachItem, coachIndex, deckIndex)}\n        </li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(\n    coachItem: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: 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      >\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)}\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    deckIndex: number,\n  ): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepair 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(rowPlaces, coachIndex, deckIndex)}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(\n    places: Place[],\n    coachIndex: number,\n    deckIndex: 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\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=\"seat-reservation__place-button-${deckIndex}-${coachIndex}-${place.number}\"\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=${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 chassie 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    if (!this.preventPlaceClick) {\n      // Set current deck index if a places was selected\n      this.currSelectedDeckIndex = selectedPlace.deckIndex;\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    this.isKeyboardNavigation = false;\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    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('sbb-popover[data-state=\"opened\"]')\n      .forEach((popover) => popover.setAttribute('data-state', 'closed'));\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 descriptionAlreayExist = 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 (!descriptionAlreayExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreayExist && 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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"}
|
|
932
|
+
//# 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 { 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.js';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n  NavigationCoachItem,\n} from '../common.js';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.js';\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 '../seat-reservation-area.js';\nimport '../seat-reservation-graphic.js';\nimport '../seat-reservation-place-control.js';\nimport '../seat-reservation-navigation-coach.js';\nimport '../seat-reservation-scoped.js';\nimport '@sbb-esta/lyne-elements/popover/popover.js';\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__container\">\n        <div class=\"sbb-sr sbb-sr__grid\">\n          <div class=\"sbb-sr-navigation-first-grid\">\n            ${this._renderNavigationControlButton('DIRECTION_LEFT')}\n          </div>\n          <div\n            class=\"sbb-sr__component\"\n            @keydown=${(evt: KeyboardEvent) => this.handleKeyboardEvent(evt)}\n          >\n            <div class=\"sbb-sr-grid-inner\">\n              <div class=\"nav-grid\">${this._renderNavigation()}</div>\n              <div class=\"coaches-grid\">\n                <div class=\"sbb-sr__wrapper-coach-decks\">\n                  <div class=\"sbb-sr__wrapper-deck-labels\">${this._renderDeckLabels()}</div>\n                  <div\n                    id=\"sbb-sr__wrapper-scrollarea\"\n                    class=\"sbb-sr__wrapper\"\n                    @scroll=${() => this.coachAreaScrollend()}\n                  >\n                    <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\" tabindex=\"-1\">\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            </div>\n          </div>\n          <div class=\"sbb-sr-navigation-last-grid\">\n            ${this._renderNavigationControlButton('DIRECTION_RIGHT')}\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\n    const btnId = btnDirection == 'DIRECTION_RIGHT' ? 'last-tab-element' : 'first-tab-element';\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 <\n        this.seatReservations[this.currSelectedDeckIndex].coachItems.length - 1\n    ) {\n      btnDisabled = false;\n    }\n\n    return html`<sbb-secondary-button\n      @click=\"${() => this.navigateByDirectionBtn(btnDirection)}\"\n      id=\"${btnId}\"\n      class=\"sbb-sr__navigation-control-button\"\n      size=\"s\"\n      icon-name=\"${btnIcon}\"\n      type=\"button\"\n      aria-label=\"${btnAriaDescription}\"\n      role=\"contentinfo\"\n      .disabledInteractive=\"${btnDisabled || nothing}\"\n    ></sbb-secondary-button>`;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n\n    return html`<div class=\"sbb-sr-navigation-wrapper\">\n      <nav id=\"sbb-sr-navigation\" class=\"sbb-sr-navigation\">\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                class=\"${classMap({\n                  'sbb-sr__navigation-coach--hover-scroll': this.hoveredScrollCoachIndex === index,\n                })}\"\n                index=\"${index}\"\n                coach-id=\"${navigationCoach.id}\"\n                .freePlacesByType=\"${navigationCoach.freePlaces}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\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      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @returns\n   * @param seatReservation\n   * @param deckIndex\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      >\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    // Prepair 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 chassie 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\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    this.isKeyboardNavigation = false;\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    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('sbb-popover[data-state=\"opened\"]')\n      .forEach((popover) => popover.setAttribute('data-state', 'closed'));\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 descriptionAlreayExist = 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 (!descriptionAlreayExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreayExist && 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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"}
|
|
@@ -14,7 +14,9 @@ export declare class SbbSeatReservationNavigationCoachElement extends LitElement
|
|
|
14
14
|
accessor coachId: string;
|
|
15
15
|
/** Coach service property ids, which are used to display the services in the navigation */
|
|
16
16
|
accessor propertyIds: string[];
|
|
17
|
+
/** Pre-selected coach index property */
|
|
17
18
|
accessor selected: boolean;
|
|
19
|
+
/** Focused coach index property */
|
|
18
20
|
accessor focused: boolean;
|
|
19
21
|
accessor index: number;
|
|
20
22
|
/** Representation of places available for selecting, counting seat places and bicycle places separetely */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,cAAc,EAAW,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC7F,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC,OAAO,KAAK,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAI9E,OAAO,+CAA+C,CAAC;AACvD,OAAO,4CAA4C,CAAC;AAEpD,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC;AAE7C;;GAEG;AACH,qBAEM,wCAAyC,SAAQ,UAAU;IAC/D,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;MAGlB;IAEX,sEAAsE;IACtE,SAEgB,OAAO,EAAE,MAAM,CAAM;IAErC,2FAA2F;IAC3F,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;
|
|
1
|
+
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,cAAc,EAAW,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC7F,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC,OAAO,KAAK,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAI9E,OAAO,+CAA+C,CAAC;AACvD,OAAO,4CAA4C,CAAC;AAEpD,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC;AAE7C;;GAEG;AACH,qBAEM,wCAAyC,SAAQ,UAAU;IAC/D,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;MAGlB;IAEX,sEAAsE;IACtE,SAEgB,OAAO,EAAE,MAAM,CAAM;IAErC,2FAA2F;IAC3F,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,mCAAmC;IACnC,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,SAEgB,KAAK,EAAE,MAAM,CAAK;IAElC,2GAA2G;IAC3G,SACgB,gBAAgB,EAAE,uBAAuB,CAA6B;IAEtF,gCAAgC;IAChC,SACgB,WAAW,EAAE,gBAAgB,EAAE,CAAiB;IAEhE,+CAA+C;IAC/C,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C,kDAAkD;IAClD,SAEgB,KAAK,EAAE,OAAO,CAAS;IAEvC,iDAAiD;IACjD,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC,mCAAmC;IACnC,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,6DAA6D;IAC7D,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAwB5E;;;;OAIG;cACgB,MAAM,IAAI,cAAc;IAqB3C,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,kCAAkC;IAmC1C,OAAO,CAAC,gCAAgC;IAYxC;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAgBvB,OAAO,CAAC,2BAA2B;CASpC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uCAAuC,EAAE,wCAAwC,CAAC;KACnF;CACF"}
|
|
@@ -392,14 +392,14 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
392
392
|
set propertyIds(value) {
|
|
393
393
|
__privateSet(this, _propertyIds_accessor_storage, value);
|
|
394
394
|
}
|
|
395
|
-
|
|
395
|
+
/** Pre-selected coach index property */
|
|
396
396
|
get selected() {
|
|
397
397
|
return __privateGet(this, _selected_accessor_storage);
|
|
398
398
|
}
|
|
399
399
|
set selected(value) {
|
|
400
400
|
__privateSet(this, _selected_accessor_storage, value);
|
|
401
401
|
}
|
|
402
|
-
|
|
402
|
+
/** Focused coach index property */
|
|
403
403
|
get focused() {
|
|
404
404
|
return __privateGet(this, _focused_accessor_storage);
|
|
405
405
|
}
|
|
@@ -651,4 +651,4 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
651
651
|
export {
|
|
652
652
|
SbbSeatReservationNavigationCoachElement
|
|
653
653
|
};
|
|
654
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["import { 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, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.js';\nimport type { CoachNumberOfFreePlaces, PlaceTravelClass } from '../common.js';\n\nimport style from './seat-reservation-navigation-coach.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-navigation-services.js';\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport\n@customElement('sbb-seat-reservation-navigation-coach')\nclass SbbSeatReservationNavigationCoachElement extends LitElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Coach ID, which is used to identify the coach in the navigation */\n  @forceType()\n  @property({ attribute: 'coach-id' })\n  public accessor coachId: string = '';\n\n  /** Coach service property ids, which are used to display the services in the navigation */\n  @property({ attribute: 'property-ids', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /* pre-selected Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /* focus Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  /** Representation of places available for selecting, counting seat places and bicycle places separetely */\n  @property({ attribute: 'free-places-by-type', type: Object })\n  public accessor freePlacesByType: CoachNumberOfFreePlaces = { seats: 0, bicycles: 0 };\n\n  /** Travel class of the coach */\n  @property({ attribute: 'travel-class', type: Array })\n  public accessor travelClass: PlaceTravelClass[] = ['ANY_CLASS'];\n\n  /** If the coach is a driver/restricted area */\n  @forceType()\n  @property({ attribute: 'driver-area', type: Boolean })\n  public accessor driverArea: boolean = false;\n\n  /** If the coach is the first in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor first: boolean = false;\n\n  /** If the coach is the last in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor last: boolean = false;\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean, reflect: true, useDefault: true })\n  public accessor vertical: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        selectedNavButtonElement.focus();\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (focusedNavButtonElement) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a list of service icons provided by a caller\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.last,\n          'first-coach': this.first,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.propertyIds}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n        type=\"button\"\n        ?disabled=\"${this.disable}\"\n        class=\"${classMap({\n          'sbb-sr-navigation__ctrl-button': true,\n          'sbb-sr-navigation-driver-area': this.driverArea,\n        })}\"\n        title=\"${titleDescriptionNavCoachButton}\"\n        aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n        @click=${() => this._selectNavCoach(this.index)}\n      >\n        ${this._getBtnInformation(currServiceClassNumber)}\n      </button>\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\"\n        >${ariaDescriptionCoachServices}</sbb-screen-reader-only\n      >`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.driverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.travelClass?.length > 0 || this.coachId\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachId\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachId}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (this.driverArea) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachId,\n      ]);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [this.coachId]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    // Expands the number of available seats and bicycle spaces as info\n    const freePlacesTxt = getI18nSeatReservation(\n      'COACH_AVAILABLE_NUMBER_OF_PLACES',\n      this._language.current,\n      [this.freePlacesByType.seats, this.freePlacesByType.bicycles],\n    );\n    label = label.concat('. ').concat(freePlacesTxt);\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescrition = null;\n    if (this.propertyIds.length) {\n      ariaDescrition =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescrition += this.propertyIds\n        .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n        .join();\n    }\n    return ariaDescrition;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    if (!this.driverArea) {\n      /**\n       * @type {CustomEvent<SelectCoachEventDetails>}\n       * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n          bubbles: true,\n          composed: true,\n          detail: coachIndex,\n        }),\n      );\n    }\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    if (this.travelClass?.includes('FIRST')) {\n      return 1;\n    } else if (this.travelClass?.includes('SECOND')) {\n      return 2;\n    } else {\n      return null;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
654
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["import { 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, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.js';\nimport type { CoachNumberOfFreePlaces, PlaceTravelClass } from '../common.js';\n\nimport style from './seat-reservation-navigation-coach.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-navigation-services.js';\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport\n@customElement('sbb-seat-reservation-navigation-coach')\nclass SbbSeatReservationNavigationCoachElement extends LitElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Coach ID, which is used to identify the coach in the navigation */\n  @forceType()\n  @property({ attribute: 'coach-id' })\n  public accessor coachId: string = '';\n\n  /** Coach service property ids, which are used to display the services in the navigation */\n  @property({ attribute: 'property-ids', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /** Pre-selected coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /** Focused coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  /** Representation of places available for selecting, counting seat places and bicycle places separetely */\n  @property({ attribute: 'free-places-by-type', type: Object })\n  public accessor freePlacesByType: CoachNumberOfFreePlaces = { seats: 0, bicycles: 0 };\n\n  /** Travel class of the coach */\n  @property({ attribute: 'travel-class', type: Array })\n  public accessor travelClass: PlaceTravelClass[] = ['ANY_CLASS'];\n\n  /** If the coach is a driver/restricted area */\n  @forceType()\n  @property({ attribute: 'driver-area', type: Boolean })\n  public accessor driverArea: boolean = false;\n\n  /** If the coach is the first in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor first: boolean = false;\n\n  /** If the coach is the last in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor last: boolean = false;\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean, reflect: true, useDefault: true })\n  public accessor vertical: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        selectedNavButtonElement.focus();\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (focusedNavButtonElement) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a list of service icons provided by a caller\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.last,\n          'first-coach': this.first,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.propertyIds}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n        type=\"button\"\n        ?disabled=\"${this.disable}\"\n        class=\"${classMap({\n          'sbb-sr-navigation__ctrl-button': true,\n          'sbb-sr-navigation-driver-area': this.driverArea,\n        })}\"\n        title=\"${titleDescriptionNavCoachButton}\"\n        aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n        @click=${() => this._selectNavCoach(this.index)}\n      >\n        ${this._getBtnInformation(currServiceClassNumber)}\n      </button>\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\"\n        >${ariaDescriptionCoachServices}</sbb-screen-reader-only\n      >`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.driverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.travelClass?.length > 0 || this.coachId\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachId\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachId}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (this.driverArea) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachId,\n      ]);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [this.coachId]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    // Expands the number of available seats and bicycle spaces as info\n    const freePlacesTxt = getI18nSeatReservation(\n      'COACH_AVAILABLE_NUMBER_OF_PLACES',\n      this._language.current,\n      [this.freePlacesByType.seats, this.freePlacesByType.bicycles],\n    );\n    label = label.concat('. ').concat(freePlacesTxt);\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescrition = null;\n    if (this.propertyIds.length) {\n      ariaDescrition =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescrition += this.propertyIds\n        .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n        .join();\n    }\n    return ariaDescrition;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    if (!this.driverArea) {\n      /**\n       * @type {CustomEvent<SelectCoachEventDetails>}\n       * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n          bubbles: true,\n          composed: true,\n          detail: coachIndex,\n        }),\n      );\n    }\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    if (this.travelClass?.includes('FIRST')) {\n      return 1;\n    } else if (this.travelClass?.includes('SECOND')) {\n      return 2;\n    } else {\n      return null;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAuBM,4CAAwC,MAAA;;0BAD7C,cAAc,uCAAuC,CAAC;;;;oBACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAR,EAAA,mBAAQ,YAAU;AAAA;;AAU/D;AAIA;AAKA;AAKA;AAIA;AAIA;AAIA;AAKA;AAKA;AAKA;AAKA;AAKA;AAnDgB,yBAAA,2BAAA,kBAAA,MAAA,uBAAkB,EAAE;AAIpB,yBAAA,gCAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,2BAAwB,CAAA,CAAE;AAK1B,yBAAA,6BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAKzB,yBAAA,4BAAA,kBAAA,MAAA,2BAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAIxB,yBAAA,0BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,qBAAgB,CAAC;AAIjB,yBAAA,qCAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,gCAA4C,EAAE,OAAO,GAAG,UAAU,GAAG;AAIrE,yBAAA,gCAAA,kBAAA,MAAA,mCAAA,GAAA,kBAAA,MAAA,2BAAkC,CAAC,WAAW,CAAC;AAK/C,yBAAA,+BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,0BAAsB,KAAK;AAK3B,yBAAA,0BAAA,kBAAA,MAAA,6BAAA,GAAA,kBAAA,MAAA,qBAAiB,KAAK;AAKtB,yBAAA,yBAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,oBAAgB,KAAK;AAKrB,yBAAA,4BAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAKxB,yBAAA,6BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAEjC,WAAA,mEAAY,IAAI,sBAAsB,IAAI;AAAA,IAqLpD;AAAA;AAAA,IA1OE,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAIvB,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA;AAAA,IAKxB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA,IAIvB,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAIrB,IAAgB,mBAAgB;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAhC,IAAgB,iBAAgB,OAAA;AAAA,yBAAA,oCAAA;AAAA,IAAA;AAAA;AAAA,IAIhC,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,aAAU;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1B,IAAgB,WAAU,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA,IAK1B,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAKrB,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAKpB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAKvB,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA,IAIL,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAElC,UAAI,kBAAkB,IAAI,UAAU,GAAG;AACrC,cAAM,2BAA2B,KAAK,YAAY,cAChD,iCAAiC;AAEnC,YAAI,KAAK,YAAY,0BAA0B;AAC7C,mCAAyB,MAAA;AAEzB,eAAK,cAAc,IAAI,MAAM,cAAc,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAAA,QAC/E;AAAA,MACF;AAEA,UAAI,kBAAkB,IAAI,SAAS,KAAK,KAAK,SAAS;AACpD,cAAM,0BAA0B,KAAK,YAAY,cAC/C,iCAAiC;AAEnC,YAAI,yBAAyB;AAC3B,kCAAwB,MAAA;AAAA,QAC1B;AAAA,MACF;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOmB,SAAM;AACvB,aAAO;AAAA;AAAA,iBAEM,SAAS;AAAA,QAChB,iCAAiC;AAAA,QACjC,cAAc,KAAK;AAAA,QACnB,eAAe,KAAK;AAAA,QACpB,2CAA2C,KAAK;AAAA,MAAA,CACjD,CAAC;AAAA;AAAA,UAEA,KAAK,sBAAsB;AAAA,UAC3B,KAAK,aAAa,SAChB;AAAA,2BACe,KAAK,QAAQ;AAAA,8BACV,KAAK,WAAW;AAAA,4DAElC,OAAO;AAAA;AAAA;AAAA,IAGjB;AAAA,IAEQ,uBAAoB;AAC1B,YAAM,yBAAyB,KAAK,4BAAA;AACpC,YAAM,iCACJ,KAAK,mCAAmC,sBAAsB;AAChE,YAAM,+BAA+B,KAAK,iCAAA;AAE1C,aAAO;AAAA;AAAA,qBAEU,KAAK,OAAO;AAAA,iBAChB,SAAS;AAAA,QAChB,kCAAkC;AAAA,QAClC,iCAAiC,KAAK;AAAA,MAAA,CACvC,CAAC;AAAA,iBACO,8BAA8B;AAAA,2DACY,KAAK,KAAK;AAAA,iBACpD,MAAM,KAAK,gBAAgB,KAAK,KAAK,CAAC;AAAA;AAAA,UAE7C,KAAK,mBAAmB,sBAAsB,CAAC;AAAA;AAAA,mEAEU,KAAK,KAAK;AAAA,WAClE,4BAA4B;AAAA;AAAA,IAErC;AAAA,IAEQ,mBAAmB,oBAAiC;AAC1D,UAAI,KAAK,YAAY;AACnB,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,QACH,uBAAuB,IACrB,6DACA,OAAO;AAAA,QACT,KAAK,aAAa,SAAS,KAAK,KAAK,UACnC;AAAA,cACI,KAAK,UACH;AAAA,oBACI,KAAK,OAAO;AAAA,0BAEhB,OAAO;AAAA;AAAA,gBAEP,sBAAsB,OAAO;AAAA;AAAA;AAAA;AAAA,gBAI7B,kBAAkB;AAAA;AAAA,oBAGxB,OAAO;AAAA;AAAA,IAEf;AAAA,IAEQ,mCAAmC,oBAAiC;AAC1E,UAAI,KAAK,YAAY;AACnB,eAAO,uBAAuB,0BAA0B,KAAK,UAAU,SAAS;AAAA,UAC9E,KAAK;AAAA,QAAA,CACN;AAAA,MACH;AAEA,UAAI,QAAQ,uBAAuB,qBAAqB,KAAK,UAAU,SAAS,CAAC,KAAK,OAAO,CAAC;AAG9F,UAAI,oBAAoB;AACtB,cAAM,6BACJ,uBAAuB,IAAI,wBAAwB;AACrD,cAAM,0BAA0B,uBAC9B,4BACA,KAAK,UAAU,OAAO;AAExB,cAAM,oBAAoB,uBACxB,uCACA,KAAK,UAAU,SACf,CAAC,uBAAuB,CAAC;AAE3B,gBAAQ,MAAM,OAAO,iBAAiB;AAAA,MACxC;AAGA,YAAM,gBAAgB,uBACpB,oCACA,KAAK,UAAU,SACf,CAAC,KAAK,iBAAiB,OAAO,KAAK,iBAAiB,QAAQ,CAAC;AAE/D,cAAQ,MAAM,OAAO,IAAI,EAAE,OAAO,aAAa;AAC/C,aAAO;AAAA,IACT;AAAA,IAEQ,mCAAgC;AACtC,UAAI,iBAAiB;AACrB,UAAI,KAAK,YAAY,QAAQ;AAC3B,yBACE,uBAAuB,4BAA4B,KAAK,UAAU,OAAO,IAAI;AAC/E,0BAAkB,KAAK,YACpB,IAAI,CAAC,eAAe,uBAAuB,YAAY,KAAK,UAAU,OAAO,CAAC,EAC9E,KAAA;AAAA,MACL;AACA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOQ,gBAAgB,YAAkB;AACxC,UAAI,CAAC,KAAK,YAAY;AAKpB,aAAK,cACH,IAAI,YAAqC,eAAe;AAAA,UACtD,SAAS;AAAA,UACT,UAAU;AAAA,UACV,QAAQ;AAAA,QAAA,CACT,CAAC;AAAA,MAEN;AAAA,IACF;AAAA,IAEQ,8BAA2B;AACjC,UAAI,KAAK,aAAa,SAAS,OAAO,GAAG;AACvC,eAAO;AAAA,MACT,WAAW,KAAK,aAAa,SAAS,QAAQ,GAAG;AAC/C,eAAO;AAAA,MACT,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAAA,KAzOA,2CAIA,+CAKA,4CAKA,2CAIA,yCAIA,oDAIA,+CAKA,8CAKA,yCAKA,wCAKA,2CAKA;;2BArDC,aACA,SAAS,EAAE,WAAW,WAAA,CAAY,CAAC;+BAInC,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;4BAIpD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;2BAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;yBAG3B,aACA,SAAS,EAAE,MAAM,OAAA,CAAQ,CAAC;oCAI1B,SAAS,EAAE,WAAW,uBAAuB,MAAM,OAAA,CAAQ,CAAC;+BAI5D,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;AAIpD,6BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,eAAe,MAAM,QAAA,CAAS,CAAC;yBAIrD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;wBAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAI3B,0BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,WAAW,MAAM,QAAA,CAAS,CAAC;AAIjD,2BAAA,CAAA,aACA,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM,YAAY,KAAA,CAAM,CAAC;AAlD7D,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AAKxB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAIrB,iBAAA,IAAA,MAAA,8BAAA,EAAA,MAAA,YAAA,MAAA,oBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,sBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,kBAAgB,KAAA,CAAA,KAAA,UAAA;AAAA,UAAhB,mBAAgB;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,gCAAA,mCAAA;AAIhC,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,YAAU,KAAA,CAAA,KAAA,UAAA;AAAA,UAAV,aAAU;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,0BAAA,6BAAA;AAK1B,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAKrB,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AAKpB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAKvB,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AA7D1B,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACyB,GAAA,SAAyB,CAAC,iBAAiB,KAAK,GAChD,GAAA,SAAS;AAAA,IAC9B,aAAa;AAAA,IACb,YAAY;AAAA,EAAA,GAJV,kBAAA,YAAA,uBAAA,GAAyC;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-place-control.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAIrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKnG,OAAO,KAAK,EAAkB,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,gCAAgC,CAAC;AAIxC;;GAEG;AACH,qBAEM,qCAAsC,SAAQ,oBAAoB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;MAElB;IAEX,qDAAqD;IACrD,SAEgB,SAAS,EAAE,SAAS,CAAU;IAE9C,6DAA6D;IAC7D,SAEgB,KAAK,EAAE,UAAU,CAAU;IAE3C,sEAAsE;IACtE,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,4DAA4D;IAC5D,SAEgB,SAAS,EAAE,MAAM,CAAS;IAE1C,8DAA8D;IAC9D,SAEgB,UAAU,EAAE,MAAM,CAAS;IAE3C,kDAAkD;IAClD,SAEgB,YAAY,EAAE,OAAO,CAAS;IAE9C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,MAAM,CAAa;IAE7C,OAAO,CAAC,SAAS,CAAmC;;
|
|
1
|
+
{"version":3,"file":"seat-reservation-place-control.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAIrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKnG,OAAO,KAAK,EAAkB,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,gCAAgC,CAAC;AAIxC;;GAEG;AACH,qBAEM,qCAAsC,SAAQ,oBAAoB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;MAElB;IAEX,qDAAqD;IACrD,SAEgB,SAAS,EAAE,SAAS,CAAU;IAE9C,6DAA6D;IAC7D,SAEgB,KAAK,EAAE,UAAU,CAAU;IAE3C,sEAAsE;IACtE,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,4DAA4D;IAC5D,SAEgB,SAAS,EAAE,MAAM,CAAS;IAE1C,8DAA8D;IAC9D,SAEgB,UAAU,EAAE,MAAM,CAAS;IAE3C,kDAAkD;IAClD,SAEgB,YAAY,EAAE,OAAO,CAAS;IAE9C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,MAAM,CAAa;IAE7C,OAAO,CAAC,SAAS,CAAmC;;cAOjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAUzD,MAAM,IAAI,cAAc;IAuC3C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,yBAAyB;IAkBjC,yGAAyG;IACzG,OAAO,CAAC,YAAY;CA4BrB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,oCAAoC,EAAE,qCAAqC,CAAC;KAC7E;CACF"}
|