@sbb-esta/lyne-elements-experimental 3.6.0 → 3.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/custom-elements.json +155 -19
  2. package/development/journey-summary/journey-summary.component.js +1 -1
  3. package/development/pearl-chain/pearl-chain.component.js +10 -5
  4. package/development/pearl-chain-time/pearl-chain-time.component.js +2 -2
  5. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +9 -4
  6. package/development/seat-reservation/common/mapper/icon-mapper.d.ts +0 -6
  7. package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  8. package/development/seat-reservation/common/mapper/icon-mapper.js +2 -1
  9. package/development/seat-reservation/common/svgs.js +5 -5
  10. package/development/seat-reservation/common/translations/i18n.js +36 -36
  11. package/development/seat-reservation/common/types.d.ts +8 -0
  12. package/development/seat-reservation/common/types.d.ts.map +1 -1
  13. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +24 -6
  14. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  15. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +109 -22
  16. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  17. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +59 -36
  18. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +4 -2
  19. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
  20. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +27 -44
  21. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +2 -1
  22. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +1 -3
  23. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  24. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +54 -10
  25. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -1
  26. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +46 -6
  27. package/development/timetable-duration/timetable-duration.component.js +1 -1
  28. package/development/timetable-row/timetable-row.component.js +8 -8
  29. package/journey-summary/journey-summary.component.js +1 -1
  30. package/package.json +2 -2
  31. package/pearl-chain/pearl-chain.component.js +1 -1
  32. package/pearl-chain-time/pearl-chain-time.component.js +1 -1
  33. package/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +17 -17
  34. package/seat-reservation/common/mapper/icon-mapper.d.ts +0 -6
  35. package/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  36. package/seat-reservation/common/mapper/icon-mapper.js +1 -0
  37. package/seat-reservation/common/svgs.js +10 -10
  38. package/seat-reservation/common/translations/i18n.js +38 -38
  39. package/seat-reservation/common/types.d.ts +8 -0
  40. package/seat-reservation/common/types.d.ts.map +1 -1
  41. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +24 -6
  42. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  43. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +230 -165
  44. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  45. package/seat-reservation/seat-reservation/seat-reservation.component.js +66 -67
  46. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +10 -10
  47. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
  48. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +37 -54
  49. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +5 -5
  50. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +1 -3
  51. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  52. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +91 -93
  53. package/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +22 -22
  54. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +49 -49
  55. package/timetable-duration/timetable-duration.component.js +8 -8
  56. package/timetable-row/timetable-row.component.js +45 -45
@@ -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":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAe1E,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,CAAS;IAEtD,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;cAc3D,MAAM,IAAI,cAAc,GAAG,IAAI;IAKlD,OAAO,CAAC,uCAAuC;IAoD/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAkCtC,OAAO,CAAC,iBAAiB;IA4CzB;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAkBtB,OAAO,CAAC,mBAAmB;IAqC3B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IA4BhC,OAAO,CAAC,qBAAqB;IA8B7B,OAAO,CAAC,wBAAwB;IAoDhC,OAAO,CAAC,6BAA6B;IAgCrC;;;;;;;OAOG;IACH,OAAO,CAAC,yBAAyB;IA2EjC,OAAO,CAAC,4BAA4B;IAuCpC,OAAO,CAAC,2BAA2B;IAwCnC;;;;OAIG;IACH,OAAO,CAAC,cAAc;IActB,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"}
1
+ {"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAEA,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,CAAS;IAEtD,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;IAkCtC,OAAO,CAAC,iBAAiB;IAwCzB;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAkBtB,OAAO,CAAC,mBAAmB;IAqC3B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IA8BhC,OAAO,CAAC,qBAAqB;IA8B7B,OAAO,CAAC,wBAAwB;IAoDhC,OAAO,CAAC,6BAA6B;IAgCrC;;;;;;;OAOG;IACH,OAAO,CAAC,yBAAyB;IA2EjC,OAAO,CAAC,4BAA4B;IAuCpC,OAAO,CAAC,2BAA2B;IAwCnC;;;;OAIG;IACH,OAAO,CAAC,cAAc;IActB,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"}
@@ -28,7 +28,7 @@ const style = css`*,
28
28
  height: inherit;
29
29
  }
30
30
  :host ::part(coach-floor) {
31
- fill: var(--sbb-color-white);
31
+ fill: var(--sbb-background-color-2);
32
32
  }
33
33
  @media (forced-colors: active) {
34
34
  :host ::part(coach-floor) {
@@ -84,7 +84,7 @@ const style = css`*,
84
84
  display: grid;
85
85
  grid-template-columns: 20% 60% 20%;
86
86
  grid-template-rows: auto 1fr;
87
- grid-gap: 0;
87
+ gap: 0;
88
88
  }
89
89
  .sbb-sr__grid .sbb-sr-grid-inner .nav-grid {
90
90
  grid-column: 2/3;
@@ -117,8 +117,16 @@ const style = css`*,
117
117
  --sbb-scrollbar-thumb-width: 0.125rem;
118
118
  --sbb-scrollbar-thumb-width-hover: 0.25rem;
119
119
  --sbb-scrollbar-width-firefox: thin;
120
- --sbb-scrollbar-color: var(--sbb-color-black-alpha-30);
121
- --sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);
120
+ --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
121
+ --sbb-scrollbar-color: light-dark(
122
+ color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
123
+ color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
124
+ );
125
+ --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
126
+ --sbb-scrollbar-color-hover: light-dark(
127
+ color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
128
+ color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
129
+ );
122
130
  --sbb-scrollbar-track-color: transparent;
123
131
  --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
124
132
  }
@@ -150,7 +158,7 @@ const style = css`*,
150
158
  }
151
159
  }
152
160
  .sbb-sr-navigation {
153
- --sbb-scrollbar-color: var(--sbb-color-white-alpha-0);
161
+ --sbb-scrollbar-color: transparent;
154
162
  display: flex;
155
163
  overflow: scroll hidden;
156
164
  position: relative;
@@ -191,8 +199,16 @@ const style = css`*,
191
199
  --sbb-scrollbar-thumb-width: 0.125rem;
192
200
  --sbb-scrollbar-thumb-width-hover: 0.25rem;
193
201
  --sbb-scrollbar-width-firefox: thin;
194
- --sbb-scrollbar-color: var(--sbb-color-black-alpha-30);
195
- --sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);
202
+ --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
203
+ --sbb-scrollbar-color: light-dark(
204
+ color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
205
+ color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
206
+ );
207
+ --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
208
+ --sbb-scrollbar-color-hover: light-dark(
209
+ color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
210
+ color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
211
+ );
196
212
  --sbb-scrollbar-track-color: transparent;
197
213
  --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
198
214
  }
@@ -346,8 +362,16 @@ const style = css`*,
346
362
  --sbb-scrollbar-thumb-width: 0.125rem;
347
363
  --sbb-scrollbar-thumb-width-hover: 0.25rem;
348
364
  --sbb-scrollbar-width-firefox: thin;
349
- --sbb-scrollbar-color: var(--sbb-color-black-alpha-30);
350
- --sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);
365
+ --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
366
+ --sbb-scrollbar-color: light-dark(
367
+ color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
368
+ color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
369
+ );
370
+ --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
371
+ --sbb-scrollbar-color-hover: light-dark(
372
+ color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
373
+ color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
374
+ );
351
375
  --sbb-scrollbar-track-color: transparent;
352
376
  --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
353
377
  }
@@ -422,9 +446,7 @@ let SbbSeatReservationElement = (() => {
422
446
  firstUpdated(changedProperties) {
423
447
  super.firstUpdated(changedProperties);
424
448
  this.updateComplete.then(() => {
425
- this.initPrepairSeatReservationData();
426
449
  this.initNavigationSelectionByScrollEvent();
427
- this.requestUpdate();
428
450
  });
429
451
  }
430
452
  render() {
@@ -522,29 +544,28 @@ let SbbSeatReservationElement = (() => {
522
544
  class="sbb-sr-navigation__list-coaches"
523
545
  aria-label="${getI18nSeatReservation("SEAT_RESERVATION_NAVIGATION", this._language.current)}"
524
546
  >
525
- ${this.seatReservations[this.currSelectedDeckIndex]?.coachItems.map((coachItem, index) => {
526
- const coachFreePlaces = this.getAvailableFreePlacesNumFromCoach(index);
547
+ ${this.coachNavData.map((navigationCoach, index) => {
527
548
  return html`<li>
528
- <sbb-seat-reservation-navigation-coach
529
- @selectcoach=${(event) => this._onSelectNavCoach(event)}
530
- @focuscoach=${() => this._onFocusNavCoach()}
531
- class="${classMap({
549
+ <sbb-seat-reservation-navigation-coach
550
+ @selectcoach=${(event) => this._onSelectNavCoach(event)}
551
+ @focuscoach=${() => this._onFocusNavCoach()}
552
+ class="${classMap({
532
553
  "sbb-sr__navigation-coach--hover-scroll": this.hoveredScrollCoachIndex === index
533
554
  })}"
534
- index="${index}"
535
- coach-id="${coachItem.id}"
536
- .freePlacesByType="${coachFreePlaces}"
537
- .selected=${this.selectedCoachIndex === index}
538
- .focused=${this.focusedCoachIndex === index}
539
- .propertyIds="${coachItem.propertyIds}"
540
- .travelClass="${coachItem.travelClass}"
541
- ?driver-area="${!coachItem.places?.length}"
542
- ?first="${coachItem?.driverAreaSide?.left}"
543
- ?last="${coachItem?.driverAreaSide?.right}"
544
- ?vertical="${this.alignVertical}"
545
- >
546
- </sbb-seat-reservation-navigation-coach>
547
- </li>`;
555
+ index="${index}"
556
+ coach-id="${navigationCoach.id}"
557
+ .freePlacesByType="${navigationCoach.freePlaces}"
558
+ .selected=${this.selectedCoachIndex === index}
559
+ .focused=${this.focusedCoachIndex === index}
560
+ .propertyIds="${navigationCoach.propertyIds}"
561
+ .travelClass="${navigationCoach.travelClass}"
562
+ ?driver-area="${navigationCoach.isDriverArea}"
563
+ ?first="${navigationCoach?.driverAreaSide?.left}"
564
+ ?last="${navigationCoach?.driverAreaSide?.right}"
565
+ ?vertical="${this.alignVertical}"
566
+ >
567
+ </sbb-seat-reservation-navigation-coach>
568
+ </li>`;
548
569
  })}
549
570
  </ul>
550
571
  </nav>
@@ -570,7 +591,7 @@ let SbbSeatReservationElement = (() => {
570
591
  }
571
592
  _renderCoachElement(coachItem, coachIndex, coachDeckIndex) {
572
593
  const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);
573
- const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem, coachIndex);
594
+ const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);
574
595
  return html`<sbb-seat-reservation-scoped
575
596
  style=${styleMap({
576
597
  "--sbb-seat-reservation-scoped-width": calculatedCoachDimension.w,
@@ -599,6 +620,8 @@ let SbbSeatReservationElement = (() => {
599
620
  * depending on whether the coach is with a driver area or without.
600
621
  */
601
622
  _getRenderedCoachBorders(coachItem) {
623
+ if (!coachItem.graphicElements)
624
+ return null;
602
625
  const COACH_PASSAGE_WIDTH = 1;
603
626
  const allElements = coachItem.graphicElements;
604
627
  const driverArea = allElements?.find((element) => element.icon === "DRIVER_AREA");
@@ -835,7 +858,7 @@ let SbbSeatReservationElement = (() => {
835
858
  */
836
859
  _popover(triggerId, popoverContent) {
837
860
  return html`
838
- <sbb-popover trigger="${triggerId}">
861
+ <sbb-popover trigger="${triggerId}" hover-trigger="">
839
862
  <p class="sbb-text-s sbb-sr-popover">${popoverContent}</p>
840
863
  </sbb-popover>
841
864
  `;
@@ -847,7 +870,7 @@ let SbbSeatReservationElement = (() => {
847
870
  _closePopover() {
848
871
  this.shadowRoot?.querySelectorAll('sbb-popover[data-state="opened"]').forEach((popover) => popover.setAttribute("data-state", "closed"));
849
872
  }
850
- _getDescriptionTableCoach(coachItem, coachIndex) {
873
+ _getDescriptionTableCoach(coachItem) {
851
874
  if (!coachItem.places?.length) {
852
875
  return getI18nSeatReservation("COACH_BLOCKED_TABLE_CAPTION", this._language.current, [
853
876
  coachItem.id
@@ -860,7 +883,7 @@ let SbbSeatReservationElement = (() => {
860
883
  coachItem.id
861
884
  ]);
862
885
  if (!this.hasNavigation) {
863
- const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachIndex);
886
+ const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachItem.places);
864
887
  const freePlacesTxt = getI18nSeatReservation("COACH_AVAILABLE_NUMBER_OF_PLACES", this._language.current, [freePlaces.seats, freePlaces.bicycles]);
865
888
  tableCoachDescription = tableCoachDescription.concat(". ").concat(freePlacesTxt).concat(". ");
866
889
  }
@@ -896,4 +919,4 @@ let SbbSeatReservationElement = (() => {
896
919
  export {
897
920
  SbbSeatReservationElement
898
921
  };
899
- //# 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 { 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} 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 = 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.initPrepairSeatReservationData();\n      this.initNavigationSelectionByScrollEvent();\n\n      // We have to initiate the render process manually so that the prepared data is applied directly\n      // and not only after an interaction with the component itself\n      this.requestUpdate();\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 = btnDirection == 'DIRECTION_RIGHT' ? 'arrow-right-small' : 'arrow-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.seatReservations[this.currSelectedDeckIndex]?.coachItems.map(\n            (coachItem: CoachItem, index: number) => {\n              const coachFreePlaces = this.getAvailableFreePlacesNumFromCoach(index);\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':\n                      this.hoveredScrollCoachIndex === index,\n                  })}\"\n                  index=\"${index}\"\n                  coach-id=\"${coachItem.id}\"\n                  .freePlacesByType=\"${coachFreePlaces}\"\n                  .selected=${this.selectedCoachIndex === index}\n                  .focused=${this.focusedCoachIndex === index}\n                  .propertyIds=\"${coachItem.propertyIds}\"\n                  .travelClass=\"${coachItem.travelClass}\"\n                  ?driver-area=\"${!coachItem.places?.length}\"\n                  ?first=\"${coachItem?.driverAreaSide?.left}\"\n                  ?last=\"${coachItem?.driverAreaSide?.right}\"\n                  ?vertical=\"${this.alignVertical}\"\n                >\n                </sbb-seat-reservation-navigation-coach>\n              </li>`;\n            },\n          )}\n        </ul>\n      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @param coaches\n   * @returns\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    deckIndex: number,\n  ): TemplateResult[] | null {\n    const coaches = 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, coachIndex);\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 {\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   * @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 = areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\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-width': this.baseGridSize,\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              ></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}\">\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, coachIndex: number): 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(coachIndex);\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAmCM,6BAAyB,MAAA;;0BAD9B,cAAc,sBAAsB,CAAC;;;;oBACE;AAAR,EAAA,mBAAQ,YAA0B;AAAA;;AAGxD,WAAA,YAAY,IAAI,sBAAsB,IAAI;AAG1C,WAAA,mBAAmB;AAAA,QACzB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAIM,WAAA,8BAA8B,CAAC,YAAY;AAAA,IAqqBrD;AAAA,IAnqBqB,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAElC,UAAI,kBAAkB,IAAI,eAAe,GAAG;AAC1C,YAAI,KAAK,eAAe;AACtB,eAAK,YACD,iBAAiB,OAAO,EACzB,QAAQ,CAAC,UAAU,MAAM,gBAAgB,UAAU,CAAC;AAAA,QACzD,OAAO;AACL,eAAK,YACD,iBAAiB,OAAO,EACzB,QAAQ,CAAC,UAAU,MAAM,aAAa,YAAY,GAAG,CAAC;AAAA,QAC3D;AAAA,MACF;AAAA,IACF;AAAA,IAEmB,aAAa,mBAAuC;AACrE,YAAM,aAAa,iBAAiB;AAGpC,WAAK,eAAe,KAAK,MAAK;AAC5B,aAAK,+BAAA;AACL,aAAK,qCAAA;AAIL,aAAK,cAAA;AAAA,MACP,CAAC;AAAA,IACH;AAAA,IAEmB,SAAM;AACvB,WAAK,wCAAA;AACL,aAAO,KAAK,wBAAwB;AAAA,IACtC;AAAA,IAEQ,0CAAuC;AAC7C,WAAK,uBAAuB;AAAA;AAAA;AAAA;AAAA,cAIlB,KAAK,+BAA+B,gBAAgB,CAAC;AAAA;AAAA;AAAA;AAAA,uBAI5C,CAAC,QAAuB,KAAK,oBAAoB,GAAG,CAAC;AAAA;AAAA;AAAA,sCAGtC,KAAK,mBAAmB;AAAA;AAAA;AAAA,6DAGD,KAAK,mBAAmB;AAAA;AAAA;AAAA;AAAA,8BAIvD,MAAM,KAAK,mBAAA,CAAoB;AAAA;AAAA;AAAA;AAAA,iCAI5B,SAAS;AAAA,QAChB,sBAAsB;AAAA,QACtB,2BAA2B,KAAK;AAAA,MAAA,CACjC,CAAC;AAAA;AAAA,0BAEA,KAAK,kBAAkB,IACvB,CAAC,iBAAkC,UAAiB;AAClD,eAAO;AAAA;AAAA,kCAED,KAAK,eAAe,iBAAiB,KAAK,CAAC;AAAA;AAAA;AAAA,MAGnD,CAAC,CACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cASX,KAAK,+BAA+B,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAKlE;AAAA,IAEQ,oBAAiB;AACvB,UAAI,CAAC,KAAK;AAAkB,eAAO;AAEnC,aAAO,KAAK,iBAAiB,IAAI,CAAC,oBAAmB;AACnD,cAAM,kBAAkB,uBACtB,gBAAgB,gBAChB,KAAK,UAAU,OAAO;AAExB,eAAO,6BAA6B,eAAe;AAAA,MACrD,CAAC;AAAA,IACH;AAAA,IAEQ,+BAA+B,cAAoB;AACzD,UAAI,CAAC,KAAK,iBAAiB,CAAC,KAAK;AAAkB,eAAO;AAE1D,YAAM,QAAQ,gBAAgB,oBAAoB,qBAAqB;AACvE,YAAM,UAAU,gBAAgB,oBAAoB,sBAAsB;AAC1E,YAAM,qBACJ,gBAAgB,oBACZ,uBAAuB,wBAAwB,KAAK,UAAU,OAAO,IACrE,uBAAuB,0BAA0B,KAAK,UAAU,OAAO;AAC7E,UAAI,cAAc;AAElB,UAAI,gBAAgB,oBAAoB,KAAK,qBAAqB,GAAG;AACnE,sBAAc;AAAA,MAChB,WACE,gBAAgB,qBAChB,KAAK,qBACH,KAAK,iBAAiB,KAAK,qBAAqB,EAAE,WAAW,SAAS,GACxE;AACA,sBAAc;AAAA,MAChB;AAEA,aAAO;AAAA,gBACK,MAAM,KAAK,uBAAuB,YAAY,CAAC;AAAA,YACnD,KAAK;AAAA;AAAA;AAAA,mBAGE,OAAO;AAAA;AAAA,oBAEN,kBAAkB;AAAA;AAAA,8BAER,eAAe,OAAO;AAAA;AAAA,IAElD;AAAA,IAEQ,oBAAiB;AACvB,UAAI,CAAC,KAAK,iBAAiB,CAAC,KAAK;AAAkB,eAAO;AAE1D,aAAO;AAAA;AAAA;AAAA;AAAA;AAAA,wBAKa,uBACZ,+BACA,KAAK,UAAU,OAAO,CACvB;AAAA;AAAA,YAEC,KAAK,iBAAiB,KAAK,qBAAqB,GAAG,WAAW,IAC9D,CAAC,WAAsB,UAAiB;AACtC,cAAM,kBAAkB,KAAK,mCAAmC,KAAK;AACrE,eAAO;AAAA;AAAA,iCAEY,CAAC,UAA+B,KAAK,kBAAkB,KAAK,CAAC;AAAA,gCAC9D,MAAM,KAAK,iBAAA,CAAkB;AAAA,2BAClC,SAAS;AAAA,UAChB,0CACE,KAAK,4BAA4B;AAAA,QAAA,CACpC,CAAC;AAAA,2BACO,KAAK;AAAA,8BACF,UAAU,EAAE;AAAA,uCACH,eAAe;AAAA,8BACxB,KAAK,uBAAuB,KAAK;AAAA,6BAClC,KAAK,sBAAsB,KAAK;AAAA,kCAC3B,UAAU,WAAW;AAAA,kCACrB,UAAU,WAAW;AAAA,kCACrB,CAAC,UAAU,QAAQ,MAAM;AAAA,4BAC/B,WAAW,gBAAgB,IAAI;AAAA,2BAChC,WAAW,gBAAgB,KAAK;AAAA,+BAC5B,KAAK,aAAa;AAAA;AAAA;AAAA;AAAA,MAIrC,CAAC,CACF;AAAA;AAAA;AAAA;AAAA,IAIT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMQ,eACN,iBACA,WAAiB;AAEjB,YAAM,UAAU,KAAK,MAAM,KAAK,UAAU,iBAAiB,UAAU,CAAC;AAEtE,UAAI,CAAC,SAAS;AACZ,eAAO;AAAA,MACT;AACA,aAAO,QAAQ,IAAI,CAAC,WAAsB,eAAsB;AAC9D,eAAO;AAAA;AAAA,YAED,KAAK,oBAAoB,WAAW,YAAY,SAAS,CAAC;AAAA;AAAA;AAAA,MAGlE,CAAC;AAAA,IACH;AAAA,IAEQ,oBACN,WACA,YACA,gBAAsB;AAEtB,YAAM,2BAA2B,KAAK,uBAAuB,UAAU,SAAS;AAChF,YAAM,oCAAoC,KAAK,0BAA0B,WAAW,UAAU;AAE9F,aAAO;AAAA,cACG,SAAS;AAAA,QACf,uCAAuC,yBAAyB;AAAA,QAChE,wCAAwC,yBAAyB;AAAA,MAAA,CAClE,CAAC;AAAA;AAAA,QAEA,KAAK,yBAAyB,SAAS,CAAC;AAAA,QACxC,KAAK,8BACL,UAAU,mBAAmB,CAAA,GAC7B,UAAU,WACV,YACA,cAAc,CACf;AAAA,QACC,KAAK,4BAA4B,YAAY,gBAAgB,UAAU,eAAe,CAAC;AAAA;AAAA;AAAA,iBAG9E,MAAM,KAAK,mCAAmC,UAAU,CAAC;AAAA,2BAC/C,UAAU;AAAA;AAAA,iDAEY,UAAU;AAAA;AAAA,4CAEf,UAAU;AAAA,oCAClB,iCAAiC;AAAA;AAAA,UAE3D,KAAK,sBAAsB,WAAW,YAAY,cAAc,CAAC;AAAA;AAAA;AAAA,IAGzE;AAAA;AAAA;AAAA;AAAA;AAAA,IAMQ,yBAAyB,WAAoB;AACnD,YAAM,sBAAsB;AAC5B,YAAM,cAAc,UAAU;AAC9B,YAAM,aAAa,aAAa,KAAK,CAAC,YAAyB,QAAQ,SAAS,aAAa;AAC7F,YAAM,cAAc,aAChB,UAAU,UAAU,IAAI,WAAW,UAAU,IAAI,sBACjD,UAAU,UAAU,IAAI,sBAAsB;AAClD,YAAM,gBAAgB,UAAU,UAAU,IAAI,KAAK,oBAAoB,KAAK,KAAK;AACjF,YAAM,gBACJ,cAAc,WAAW,SAAS,MAAM,IACpC,YAAY,UAAU,IAAI,KAAK,eAC/B,KAAK;AACX,aAAO;AAAA;AAAA,gBAEK,SAAS;AAAA,QACf,wCAAwC,cAAc,KAAK;AAAA,QAC3D,yCAAyC;AAAA,QACzC,sCAAsC,KAAK,qBAAqB;AAAA,QAChE,uCAAuC;AAAA,QACvC,2CAA2C;AAAA,MAAA,CAC5C,CAAC;AAAA;AAAA,mBAES,IAAI;AAAA;AAAA;AAAA;AAAA,IAIrB;AAAA,IAEQ,sBACN,OACA,YACA,WAAiB;AAEjB,UAAI,CAAC,MAAM,QAAQ;AACjB,eAAO;AAAA,MACT;AAGA,YAAM,iBAA0C,CAAA;AAChD,iBAAW,SAAS,MAAM,QAAQ;AAChC,YAAI,CAAC,eAAe,MAAM,SAAS,CAAC,GAAG;AACrC,yBAAe,MAAM,SAAS,CAAC,IAAI,CAAC,KAAK;AAAA,QAC3C,OAAO;AACL,yBAAe,MAAM,SAAS,CAAC,EAAE,KAAK,KAAK;AAAA,QAC7C;AAAA,MACF;AAEA,aAAO,OAAO,OAAO,cAAc,EAChC,IAAI,CAAC,WAAoB,UAAS;AACjC,eAAO;AAAA,wBACS,UAAU,IAAI,UAAU,CAAC,EAAE,SAAS,CAAC,oBAAoB,KAAK;AAAA,cACxE,KAAK,yBAAyB,WAAW,YAAY,SAAS,CAAC;AAAA;AAAA;AAAA,MAGvE,CAAC,EACA,QAAQ,CAAC,gBAAgB,WAAW;AAAA,IACzC;AAAA,IAEQ,yBACN,QACA,YACA,WAAiB;AAGjB,aAAO,KACL,CAAC,QAAe,WAAkB,OAAO,OAAO,SAAS,CAAC,IAAI,OAAO,OAAO,SAAS,CAAC,CAAC;AAGzF,aAAO,QAAQ,IAAI,CAAC,OAAc,UAAiB;AACjD,cAAM,sBAAsB,KAAK,uBAAuB,MAAM,SAAS;AACvE,cAAM,qBAAqB,KAAK,sBAAsB,MAAM,QAAQ;AACpE,cAAM,WAAW,MAAM,YAAY;AACnC,cAAM,eAAe,KAAK,gBAAgB,MAAM;AAEhD,eAAO;AAAA;AAAA,qBAEQ,SAAS,IAAI,UAAU,IAAI,MAAM,SAAS,CAAC,IAAI,KAAK;AAAA;AAAA;AAAA;AAAA,oBAIrD,SAAS;AAAA,UACf,yDAAyD,KAAK,IAC5D,oBAAoB,GACpB,oBAAoB,CAAC;AAAA,UAEvB,8CAA8C,oBAAoB;AAAA,UAClE,+CAA+C,oBAAoB;AAAA,UACnE,4CAA4C,mBAAmB;AAAA,UAC/D,6CAA6C,mBAAmB;AAAA,UAChE,iDAAiD;AAAA,UACjD,sDAAsD;AAAA,QAAA,CACvD,CAAC;AAAA,2BACa,CAAC,qBACd,KAAK,eAAe,gBAAgB,CAAC;AAAA;AAAA,iDAEF,SAAS,IAAI,UAAU,IAAI,MAAM,MAAM;AAAA;AAAA,mBAErE,MAAM,MAAM;AAAA,mBACZ,MAAM,IAAI;AAAA,oBACT,MAAM,KAAK;AAAA,0BACL,UAAU;AAAA,yBACX,SAAS;AAAA,2BACP,MAAM,WAAW;AAAA,4BAChB,KAAK,iBAAiB;AAAA;AAAA;AAAA;AAAA,MAI9C,CAAC;AAAA,IACH;AAAA,IAEQ,8BACN,mBACA,gBACA,YACA,gBAAsB;AAEtB,UAAI,CAAC;AAAmB,eAAO;AAE/B,aAAO,mBAAmB,IAAI,CAAC,qBAAiC;AAC9D,cAAM,OAAO,iBAAiB,QAAQ;AACtC,cAAM,kBAAkB,iBAAiB,YAAY;AACrD,cAAM,qCACJ,KAAK,4BAA4B,QAAQ,iBAAiB,IAAK,MAAM;AACvE,cAAM,uBACJ,KAAK,iBAAiB,qCAClB,kBAAkB,KAClB;AAGN,YAAI,KAAK,iBAAiB,UAAU,CAAC,mBAAmB,mBAAmB,IAAI,IAAI,IAAI;AACrF,iBAAO,KAAK,6BAA6B,kBAAkB,iBAAiB,cAAc;AAAA,QAC5F;AACA,eAAO,KAAK,0BACV,kBACA,sBACA,gBACA,YACA,cAAc;AAAA,MAElB,CAAC;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUQ,0BACN,kBACA,UACA,gBACA,YACA,gBAAsB;AAKtB,YAAM,oBAAoB,iBAAiB,MAAM,QAAQ,OAAO,MAAM;AACtE,YAAM,eAAe,iBAAiB,QAAQ,oBAAoB,iBAAiB,OAAO;AAC1F,YAAM,gBAAgB,iBAAiB;AACvC,YAAM,mBAAmB,iBAAiB,OACtC,uBAAuB,iBAAiB,MAAM,KAAK,UAAU,OAAO,IACpE;AACJ,YAAM,sBAAsB,KAAK,uBAC/B,iBAAiB,WACjB,gBACA,MACA,aAAa;AAEf,YAAM,qBAAqB,KAAK,sBAC9B,iBAAiB,UACjB,iBAAiB,WACjB,gBACA,IAAI;AAIN,YAAM,YAAY,mBAAmB,cAAc,IAAI,UAAU,IAAI,mBAAmB,CAAC,IAAI,mBAAmB,CAAC;AACjH,UAAI,kBAAkB;AAEtB,UAAI,iBAAiB,SAAS,MAAM,KAAK,oBAAoB,IAAI;AAC/D,0BAAkB;AAAA,MACpB,WACE,iBAAiB,SAAS,IAAI,iBAAiB,UAAU,MACzD,eAAe,IAAI,KAAK,mBACxB;AACA,0BAAkB;AAAA,MACpB;AAEA,aAAO;AAAA;AAAA,cAEG,SAAS;AAAA,iBACN,SAAS,EAAE,6CAA6C,iBAAiB,KAAA,CAAM,CAAC;AAAA,gBACjF,SAAS;AAAA,QACf,qCAAqC,oBAAoB;AAAA,QACzD,sCAAsC,oBAAoB;AAAA,QAC1D,mCAAmC,mBAAmB;AAAA,QACtD,oCAAoC,mBAAmB;AAAA,MAAA,CACxD,CAAC;AAAA,mBACS,eAAe;AAAA;AAAA;AAAA;AAAA,UAIxB,eACE;AAAA;AAAA,wBAEY,SAAS;AAAA,QACf,wCAAwC,KAAK;AAAA,QAC7C,yCAAyC,KAAK;AAAA,QAC9C,2CAA2C;AAAA,MAAA,CAC5C,CAAC;AAAA,uBACK,YAAY;AAAA;AAAA;AAAA;AAAA,gBAKvB,OAAO;AAAA;AAAA,QAEX,eAAe,KAAK,SAAS,WAAW,gBAAgB,IAAI,OAAO;AAAA;AAAA,IAEzE;AAAA,IAEQ,6BACN,kBACA,UACA,gBAAgC;AAEhC,YAAM,sBAAsB,KAAK,uBAC/B,iBAAiB,WACjB,cAAc;AAEhB,YAAM,qBAAqB,KAAK,sBAC9B,iBAAiB,UACjB,iBAAiB,WACjB,cAAc;AAIhB,YAAM,OACJ,iBAAiB,QAAQ,iBAAiB,KAAK,QAAQ,aAAa,MAAM,KACtE,iBAAiB,OACjB,iBAAiB,MAAM,OACrB,KACA,KAAK,iBAAiB,KAAK,qBAAqB,EAAE,WAAW;AAGrE,aAAO;AAAA,cACG,SAAS;AAAA,QACf,wCAAwC,oBAAoB;AAAA,QAC5D,yCAAyC,oBAAoB;AAAA,QAC7D,sCAAsC,mBAAmB;AAAA,QACzD,uCAAuC,mBAAmB;AAAA,QAC1D,2CAA2C;AAAA,QAC3C,2CAA2C;AAAA,MAAA,CAC5C,CAAC;AAAA,aACK,QAAQ,OAAO;AAAA;AAAA,iBAEX,IAAI;AAAA;AAAA,IAEnB;AAAA,IAEQ,4BACN,YACA,gBACA,iBAA+B;AAE/B,UAAI,CAAC;AAAiB,eAAO;AAE7B,aAAO,iBAAiB,IAAI,CAAC,mBAA+B;AAC1D,cAAM,mBAAmB,eAAe,OACpC,uBAAuB,eAAe,MAAM,KAAK,UAAU,OAAO,IAClE;AACJ,cAAM,sBAAsB,KAAK,uBAAuB,eAAe,SAAS;AAChF,cAAM,qBAAqB,KAAK,sBAAsB,eAAe,QAAQ;AAC7E,cAAM,kBAAkB,eAAe,YAAY;AACnD,cAAM,uBAAuB,KAAK,gBAAgB,kBAAkB,KAAK;AAGzE,cAAM,YAAY,mBAAmB,cAAc,IAAI,UAAU,IAAI,mBAAmB,CAAC,IAAI,mBAAmB,CAAC;AAEjH,eAAO;AAAA;AAAA,gBAEG,SAAS;AAAA,kBACP,SAAS;AAAA,UACf,wCAAwC,oBAAoB;AAAA,UAC5D,yCAAyC,oBAAoB;AAAA,UAC7D,sCAAsC,mBAAmB;AAAA,UACzD,uCAAuC,mBAAmB;AAAA,UAC1D,2CAA2C;AAAA,UAC3C,2CAA2C;AAAA,QAAA,CAC5C,CAAC;AAAA;AAAA,iBAEK,eAAe,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA,UAIrC,KAAK,SAAS,WAAW,gBAAgB,CAAC;AAAA;AAAA,MAEhD,CAAC;AAAA,IACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOQ,eAAe,kBAA6C;AAClE,YAAM,gBAAgB,iBAAiB;AAEvC,WAAK,iCAAiC;AACtC,WAAK,uBAAuB;AAC5B,UAAI,CAAC,KAAK,mBAAmB;AAE3B,aAAK,wBAAwB,cAAc;AAE3C,aAAK,oCAAoC,aAAa;AACtD,aAAK,kCAAkC,aAAa;AAAA,MACtD;AAAA,IACF;AAAA,IAEQ,kBAAkB,OAA0B;AAClD,YAAM,wBAAwB,MAAM;AACpC,WAAK,uBAAuB;AAE5B,UAAI,0BAA0B,QAAQ,0BAA0B,KAAK,wBAAwB;AAC3F,aAAK,oBAAA;AACL,aAAK,yBAAyB,qBAAqB;AAAA,MACrD,WAAW,0BAA0B,KAAK,wBAAwB;AAChE,aAAK,2BAAA;AACL,aAAK,sBAAA;AAAA,MACP;AAGA,WAAK,cAAA;AAAA,IACP;AAAA,IAEQ,mBAAgB;AACtB,UAAI,CAAC,KAAK,gCAAgC;AACxC,aAAK,sBAAA;AAAA,MACP,OAAO;AACL,aAAK,kBAAkB,KAAK,iBAAiB;AAAA,MAC/C;AACA,WAAK,kBAAkB;AAAA,IACzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQQ,SACN,WACA,gBAA8C;AAE9C,aAAO;AAAA,8BACmB,SAAS;AAAA,+CACQ,cAAc;AAAA;AAAA;AAAA,IAG3D;AAAA;AAAA;AAAA;AAAA;AAAA,IAMQ,gBAAa;AACnB,WAAK,YACD,iBAAiB,kCAAkC,EACpD,QAAQ,CAAC,YAAY,QAAQ,aAAa,cAAc,QAAQ,CAAC;AAAA,IACtE;AAAA,IAEQ,0BAA0B,WAAsB,YAAkB;AACxE,UAAI,CAAC,UAAU,QAAQ,QAAQ;AAC7B,eAAO,uBAAuB,+BAA+B,KAAK,UAAU,SAAS;AAAA,UACnF,UAAU;AAAA,QAAA,CACX;AAAA,MACH;AAEA,UAAI;AACJ,YAAM,mBAAmB,KAAK,+BAA+B,UAAU,eAAgB;AACvF,YAAM,sBAAsB,KAAK,+BAA+B,UAAU,eAAgB;AAE1F,8BAAwB,uBAAuB,uBAAuB,KAAK,UAAU,SAAS;AAAA,QAC5F,UAAU;AAAA,MAAA,CACX;AAED,UAAI,CAAC,KAAK,eAAe;AAEvB,cAAM,aAAa,KAAK,mCAAmC,UAAU;AACrE,cAAM,gBAAgB,uBACpB,oCACA,KAAK,UAAU,SACf,CAAC,WAAW,OAAO,WAAW,QAAQ,CAAC;AAEzC,gCAAwB,sBAAsB,OAAO,IAAI,EAAE,OAAO,aAAa,EAAE,OAAO,IAAI;AAAA,MAC9F;AAEA,UAAI,CAAC,CAAC,oBAAoB,CAAC,CAAC,qBAAqB;AAC/C,iCACE,OAAO,uBAAuB,4BAA4B,KAAK,UAAU,OAAO,IAAI;AACtF,iCAAyB,sBAAsB,OAAO,mBAAmB;AAAA,MAC3E;AACA,aAAO;AAAA,IACT;AAAA,IAEQ,+BAA+B,sBAAmC;AACxE,YAAM,qBAA+B,CAAA;AAErC,aAAO,sBACH,IAAI,CAAC,uBAAsB;AAC3B,cAAM,OAAO,mBAAmB;AAChC,YAAI,CAAC;AAAM,iBAAO;AAElB,cAAM,yBAAyB,mBAAmB,QAAQ,IAAI,IAAI;AAClE,cAAM,cAAc,uBAClB,mBAAmB,MACnB,KAAK,UAAU,OAAO;AAExB,cAAM,qBACJ,KAAK,4BAA4B,QAAQ,IAAI,MAAM,MACnD,KAAK,iBAAiB,QAAQ,IAAI,MAAM;AAE1C,YAAI,CAAC,wBAAwB;AAC3B,6BAAmB,KAAK,mBAAmB,IAAK;AAAA,QAClD;AACA,eAAO,CAAC,CAAC,eAAe,CAAC,0BAA0B,qBAAqB,cAAc;AAAA,MACxF,CAAC,EACA,OAAO,CAAC,gBAAgB,CAAC,CAAC,WAAW,EACrC,KAAK,IAAI;AAAA,IACd;AAAA;;AArrBF,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACyB,GAAA,SAAyB,OAD5C,kBAAA,YAAA,uBAAA,GAA0B;;;"}
922
+ //# 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 { 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 = 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 = btnDirection == 'DIRECTION_RIGHT' ? 'arrow-right-small' : 'arrow-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   * @param coaches\n   * @returns\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    deckIndex: number,\n  ): TemplateResult[] | null {\n    const coaches = 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   * @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 = areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\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-width': this.baseGridSize,\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              ></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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"}
@@ -24,17 +24,19 @@ const style = css`*,
24
24
  height: calc(var(--sbb-seat-reservation-area-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
25
25
  width: calc(var(--sbb-seat-reservation-area-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
26
26
  border: var(--sbb-border-width-1x) solid var(--sbb-color-graphite);
27
+ border: var(--sbb-border-width-1x) solid light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
27
28
  border-radius: var(--sbb-seat-reservation-area-border-radius);
28
29
  position: absolute;
29
30
  inset-block-start: calc(var(--sbb-seat-reservation-area-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
30
31
  inset-inline-start: calc(var(--sbb-seat-reservation-area-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
31
32
  rotate: calc(var(--sbb-seat-reservation-area-rotation) * 1deg);
32
33
  line-height: normal;
33
- background-color: var(--sbb-color-white);
34
+ background-color: var(--sbb-background-color-2);
34
35
  }
35
36
 
36
37
  :host([background=dark]) {
37
38
  background-color: var(--sbb-color-milk);
39
+ background-color: light-dark(var(--sbb-color-milk), var(--sbb-color-iron));
38
40
  }
39
41
 
40
42
  :host([mounting=upper-border]) {
@@ -112,4 +114,4 @@ let SbbSeatReservationAreaElement = (() => {
112
114
  export {
113
115
  SbbSeatReservationAreaElement
114
116
  };
115
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQVlNLGlDQUE2QixNQUFBOzswQkFEbEMsY0FBYywyQkFBMkIsQ0FBQzs7OztvQkFDQzs7Ozs7OztBQUFSLEVBQUEsbUJBQVEsWUFBVTtBQUFBOztBQU1wRCxxREFBQSxrQkFBQSxNQUFBLHdCQUNFLE1BQU07QUFLUix3REFBQSxrQkFBQSxNQUFBLDJCQUFBLEdBQUEsa0JBQUEsTUFBQSwwQkFBK0MsT0FBTzs7OztJQU50RCxJQUFnQixXQUFRO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUF4QixJQUFnQixTQUFRLE9BQUE7QUFBQSx5QkFBQSw0QkFBQTtBQUFBLElBQUE7QUFBQTtBQUFBLElBTXhCLElBQWdCLGFBQVU7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQTFCLElBQWdCLFdBQVUsT0FBQTtBQUFBLHlCQUFBLDhCQUFBO0FBQUEsSUFBQTtBQUFBLElBRVAsU0FBTTtBQUN2QixhQUFPO0FBQUEsSUFDVDtBQUFBLEtBVkEsNENBTUE7OzRCQVJDLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7OEJBSzNCLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFMNUIsaUJBQUEsSUFBQSxNQUFBLHNCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsWUFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxjQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsVUFBUSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBUixXQUFRO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLHdCQUFBLDJCQUFBO0FBTXhCLGlCQUFBLElBQUEsTUFBQSx3QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGNBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsZ0JBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixZQUFVLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFWLGFBQVU7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsMEJBQUEsNkJBQUE7QUFaNUIsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLE9BRDVDLGtCQUFBLFlBQUEsdUJBQUEsR0FBOEI7OzsifQ==
117
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBWU0saUNBQTZCLE1BQUE7OzBCQURsQyxjQUFjLDJCQUEyQixDQUFDOzs7O29CQUNDOzs7Ozs7O0FBQVIsRUFBQSxtQkFBUSxZQUFVO0FBQUE7O0FBTXBELHFEQUFBLGtCQUFBLE1BQUEsd0JBQ0UsTUFBTTtBQUtSLHdEQUFBLGtCQUFBLE1BQUEsMkJBQUEsR0FBQSxrQkFBQSxNQUFBLDBCQUErQyxPQUFPOzs7O0lBTnRELElBQWdCLFdBQVE7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXhCLElBQWdCLFNBQVEsT0FBQTtBQUFBLHlCQUFBLDRCQUFBO0FBQUEsSUFBQTtBQUFBO0FBQUEsSUFNeEIsSUFBZ0IsYUFBVTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBMUIsSUFBZ0IsV0FBVSxPQUFBO0FBQUEseUJBQUEsOEJBQUE7QUFBQSxJQUFBO0FBQUEsSUFFUCxTQUFNO0FBQ3ZCLGFBQU87QUFBQSxJQUNUO0FBQUEsS0FWQSw0Q0FNQTs7NEJBUkMsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQzs4QkFLM0IsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUw1QixpQkFBQSxJQUFBLE1BQUEsc0JBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxZQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGNBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixVQUFRLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFSLFdBQVE7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsd0JBQUEsMkJBQUE7QUFNeEIsaUJBQUEsSUFBQSxNQUFBLHdCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsY0FBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxnQkFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLFlBQVUsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQVYsYUFBVTtBQUFBLElBQUEsS0FBQSxVQUFBLFVBQUEsR0FBQSwwQkFBQSw2QkFBQTtBQVo1QixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ3lCLEdBQUEsU0FBeUIsT0FENUMsa0JBQUEsWUFBQSx1QkFBQSxHQUE4Qjs7OyJ9
@@ -1 +1 @@
1
- {"version":3,"file":"seat-reservation-assets.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKhD,OAAO,kCAAkC,CAAC;AAC1C,OAAO,gCAAgC,CAAC;AAUxC;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,GAAI,UAAU,MAAM,KAAG,cAAc,GAAG,IAMtE,CAAC;AA8RF,eAAO,MAAM,cAAc,EAAE,cAgB5B,CAAC"}
1
+ {"version":3,"file":"seat-reservation-assets.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKhD,OAAO,kCAAkC,CAAC;AAC1C,OAAO,gCAAgC,CAAC;AACxC,OAAO,6DAA6D,CAAC;AAUrE;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,GAAI,UAAU,MAAM,KAAG,cAAc,GAAG,IAMtE,CAAC;AA4QF,eAAO,MAAM,cAAc,EAAE,cAgB5B,CAAC"}