@sbb-esta/lyne-elements-experimental 2.11.1 → 2.11.2

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 (52) hide show
  1. package/core/datetime/date-helper.js +142 -142
  2. package/core/timetable/access-leg-helper.js +49 -52
  3. package/core/timetable/timetable-helper.js +7 -8
  4. package/development/core/datetime/date-helper.js +10 -10
  5. package/development/core/timetable/access-leg-helper.js +12 -15
  6. package/development/core/timetable/timetable-helper.js +6 -7
  7. package/development/{differenceInMinutes-CHSyWiQs.js → differenceInMinutes-D5Nj8Stc.js} +3 -3
  8. package/development/{format-D0-yhzi4.js → format-BQfaa1ZT.js} +22 -26
  9. package/development/{isValid-Bo4R7iA7.js → isValid-DvieCZVi.js} +3 -3
  10. package/development/journey-summary/journey-summary.component.js +4 -5
  11. package/development/pearl-chain/pearl-chain.component.d.ts.map +1 -1
  12. package/development/pearl-chain/pearl-chain.component.js +28 -39
  13. package/development/pearl-chain-time/pearl-chain-time.component.js +5 -6
  14. package/development/pearl-chain-vertical/pearl-chain-vertical.component.js +1 -1
  15. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +1 -1
  16. package/development/seat-reservation/common/mapper/icon-mapper.js +1 -1
  17. package/development/seat-reservation/common/mapper/mapper.js +14 -16
  18. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +1 -1
  19. package/development/seat-reservation/common/svgs.js +1 -1
  20. package/development/seat-reservation/common/translations/i18n.js +2 -3
  21. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +22 -33
  22. package/development/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +6 -7
  23. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +16 -23
  24. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +1 -1
  25. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +2 -3
  26. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +7 -8
  27. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +7 -11
  28. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -3
  29. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +4 -5
  30. package/development/timetable-duration/timetable-duration.component.js +1 -1
  31. package/development/timetable-row/timetable-row.component.js +58 -89
  32. package/differenceInMinutes-CP_C5onR.js +23 -0
  33. package/{format-Dg8rkk7h.js → format-lqeCzmzS.js} +438 -442
  34. package/isValid-Ceq2O0NQ.js +45 -0
  35. package/journey-summary/journey-summary.component.js +3 -4
  36. package/package.json +2 -2
  37. package/pearl-chain/pearl-chain.component.d.ts.map +1 -1
  38. package/pearl-chain/pearl-chain.component.js +78 -95
  39. package/pearl-chain-time/pearl-chain-time.component.js +44 -45
  40. package/seat-reservation/common/mapper/mapper.js +50 -54
  41. package/seat-reservation/common/translations/i18n.js +5 -6
  42. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +104 -115
  43. package/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +40 -41
  44. package/seat-reservation/seat-reservation/seat-reservation.component.js +78 -87
  45. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +15 -18
  46. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +58 -59
  47. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +71 -75
  48. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +12 -13
  49. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +23 -24
  50. package/timetable-row/timetable-row.component.js +207 -247
  51. package/differenceInMinutes-BMqUZdhj.js +0 -23
  52. package/isValid-DJ69OMZJ.js +0 -45
@@ -159,14 +159,13 @@ let SeatReservationBaseElement = (() => {
159
159
  __privateSet(this, _focusedCoachIndex_accessor_storage, value);
160
160
  }
161
161
  willUpdate(changedProperties) {
162
- var _a2, _b;
163
162
  super.willUpdate(changedProperties);
164
163
  if (changedProperties.has("seatReservation")) {
165
164
  this._initSeatReservationPlaceSelection();
166
165
  }
167
166
  if (changedProperties.has("baseGridSize")) {
168
167
  this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;
169
- (_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
168
+ this.style?.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
170
169
  if (this.alignVertical) {
171
170
  this._setVerticalAlignmentOffset();
172
171
  }
@@ -175,7 +174,7 @@ let SeatReservationBaseElement = (() => {
175
174
  if (this.seatReservation.coachItems.length) {
176
175
  this.baseGridSize = this.height / this.seatReservation.coachItems[0].dimension.h;
177
176
  this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;
178
- (_b = this.style) == null ? void 0 : _b.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
177
+ this.style?.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
179
178
  if (this.alignVertical) {
180
179
  this._setVerticalAlignmentOffset();
181
180
  }
@@ -187,10 +186,9 @@ let SeatReservationBaseElement = (() => {
187
186
  }
188
187
  /* Init scroll event handling for coach navigation */
189
188
  initNavigationSelectionByScrollEvent() {
190
- var _a2, _b, _c;
191
- this.firstTabElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById("first-tab-element");
192
- this.lastTabElement = (_b = this.shadowRoot) == null ? void 0 : _b.getElementById("last-tab-element");
193
- this.coachScrollArea = (_c = this.shadowRoot) == null ? void 0 : _c.getElementById("sbb-sr__parent-area");
189
+ this.firstTabElement = this.shadowRoot?.getElementById("first-tab-element");
190
+ this.lastTabElement = this.shadowRoot?.getElementById("last-tab-element");
191
+ this.coachScrollArea = this.shadowRoot?.getElementById("sbb-sr__parent-area");
194
192
  if (this.coachScrollArea) {
195
193
  let currCalcTriggerPos = 0;
196
194
  this.scrollCoachsAreaWidth = this.coachScrollArea.getBoundingClientRect().width;
@@ -343,10 +341,9 @@ let SeatReservationBaseElement = (() => {
343
341
  * Sets the focus on the HTML table (grid) caption element so that the heading is read out when using a ScreenReader.
344
342
  */
345
343
  _setFocusToSelectedCoachGrid() {
346
- var _a2;
347
344
  if (this.isCoachGridFocusable) {
348
345
  this.isCoachGridFocusable = false;
349
- const coachTableCaptionElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelector("#sbb-sr-coach-caption-" + this.currSelectedCoachIndex);
346
+ const coachTableCaptionElement = this.shadowRoot?.querySelector("#sbb-sr-coach-caption-" + this.currSelectedCoachIndex);
350
347
  if (coachTableCaptionElement) {
351
348
  coachTableCaptionElement.focus();
352
349
  }
@@ -377,13 +374,12 @@ let SeatReservationBaseElement = (() => {
377
374
  * @returns Place or null
378
375
  */
379
376
  _getFirstPlaceInSelecedCoach() {
380
- var _a2, _b, _c, _d, _e;
381
377
  let firstPlace = null;
382
- const coach = (_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems[this.currSelectedCoachIndex];
378
+ const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];
383
379
  const firstCellId = "cell-" + this.currSelectedCoachIndex + "-0-0";
384
- const placeNumber = ((_d = (_c = (_b = this.shadowRoot) == null ? void 0 : _b.querySelector("[cell-id='" + firstCellId + "']")) == null ? void 0 : _c.querySelector("sbb-seat-reservation-place-control")) == null ? void 0 : _d.getAttribute("text")) || null;
380
+ const placeNumber = this.shadowRoot?.querySelector("[cell-id='" + firstCellId + "']")?.querySelector("sbb-seat-reservation-place-control")?.getAttribute("text") || null;
385
381
  if (coach && placeNumber) {
386
- firstPlace = ((_e = coach.places) == null ? void 0 : _e.find((place) => place.number === placeNumber)) || null;
382
+ firstPlace = coach.places?.find((place) => place.number === placeNumber) || null;
387
383
  }
388
384
  return firstPlace;
389
385
  }
@@ -394,8 +390,7 @@ let SeatReservationBaseElement = (() => {
394
390
  * @returns Place or null
395
391
  */
396
392
  _getClosestPlaceByKeyDirection(pressedKey) {
397
- var _a2, _b, _c, _d, _e;
398
- const coach = (_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems[this.currSelectedCoachIndex];
393
+ const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];
399
394
  let closestPlace = null;
400
395
  if (coach.places) {
401
396
  if (!this.currSelectedPlaceElementId) {
@@ -404,20 +399,20 @@ let SeatReservationBaseElement = (() => {
404
399
  if (this.currSelectedPlace) {
405
400
  for (const place of coach.places) {
406
401
  if (!pressedKey) {
407
- if (this.currScrollDirection === ScrollDirection.right && place.position.y === ((_b = this.currSelectedPlace) == null ? void 0 : _b.position.y) && (!closestPlace || place.position.x < closestPlace.position.x)) {
402
+ if (this.currScrollDirection === ScrollDirection.right && place.position.y === this.currSelectedPlace?.position.y && (!closestPlace || place.position.x < closestPlace.position.x)) {
408
403
  closestPlace = place;
409
- } else if (this.currScrollDirection === ScrollDirection.left && place.position.y === ((_c = this.currSelectedPlace) == null ? void 0 : _c.position.y) && (!closestPlace || place.position.x > closestPlace.position.x)) {
404
+ } else if (this.currScrollDirection === ScrollDirection.left && place.position.y === this.currSelectedPlace?.position.y && (!closestPlace || place.position.x > closestPlace.position.x)) {
410
405
  closestPlace = place;
411
406
  }
412
407
  } else {
413
- if (place.number !== ((_d = this.currSelectedPlace) == null ? void 0 : _d.number)) {
408
+ if (place.number !== this.currSelectedPlace?.number) {
414
409
  if (pressedKey === this.keyboardNavigationEvents.ArrowRight && (place.position.y === this.currSelectedPlace.position.y || place.position.y === this.currSelectedPlace.position.y - 1) && place.position.x > this.currSelectedPlace.position.x && (!closestPlace || place.position.x < closestPlace.position.x)) {
415
410
  closestPlace = place;
416
411
  } else if (pressedKey === this.keyboardNavigationEvents.ArrowDown && (place.position.x === this.currSelectedPlace.position.x || place.position.x === this.currSelectedPlace.position.x + 1) && place.position.y > this.currSelectedPlace.position.y && (!closestPlace || place.position.y < closestPlace.position.y)) {
417
412
  closestPlace = place;
418
413
  } else if (pressedKey === this.keyboardNavigationEvents.ArrowLeft && (place.position.y === this.currSelectedPlace.position.y || place.position.y === this.currSelectedPlace.position.y + 1) && place.position.x < this.currSelectedPlace.position.x && (!closestPlace || place.position.x > closestPlace.position.x)) {
419
414
  closestPlace = place;
420
- } else if (pressedKey === this.keyboardNavigationEvents.ArrowUp && (place.position.x === this.currSelectedPlace.position.x || place.position.x === this.currSelectedPlace.position.x - 1) && place.position.y < ((_e = this.currSelectedPlace) == null ? void 0 : _e.position.y) && (!closestPlace || place.position.y > closestPlace.position.y)) {
415
+ } else if (pressedKey === this.keyboardNavigationEvents.ArrowUp && (place.position.x === this.currSelectedPlace.position.x || place.position.x === this.currSelectedPlace.position.x - 1) && place.position.y < this.currSelectedPlace?.position.y && (!closestPlace || place.position.y > closestPlace.position.y)) {
421
416
  closestPlace = place;
422
417
  }
423
418
  }
@@ -560,9 +555,8 @@ let SeatReservationBaseElement = (() => {
560
555
  this.selectedPlaces.emit(this.selectedSeatReservationPlaces);
561
556
  }
562
557
  updateCurrentSelectedPlaceInCoach(placeSelection) {
563
- var _a2;
564
558
  const coachIndex = placeSelection.coachIndex;
565
- const place = (_a2 = this.seatReservation.coachItems[coachIndex].places) == null ? void 0 : _a2.find((place2) => place2.number == placeSelection.number);
559
+ const place = this.seatReservation.coachItems[coachIndex].places?.find((place2) => place2.number == placeSelection.number);
566
560
  if (!place)
567
561
  return;
568
562
  this.currSelectedCoachIndex = coachIndex;
@@ -586,8 +580,7 @@ let SeatReservationBaseElement = (() => {
586
580
  */
587
581
  _initSeatReservationPlaceSelection() {
588
582
  this.seatReservation.coachItems.map((coach, coachIndex) => {
589
- var _a2, _b;
590
- (_b = (_a2 = coach.places) == null ? void 0 : _a2.filter((place) => place.state === "SELECTED")) == null ? void 0 : _b.forEach((place) => {
583
+ coach.places?.filter((place) => place.state === "SELECTED")?.forEach((place) => {
591
584
  const preselectedPlaceSelection = mapPlaceInfosToPlaceSelection(place, coachIndex);
592
585
  const seatReservationPlaceSelection = this._getSeatReservationPlaceSelection(preselectedPlaceSelection);
593
586
  if (seatReservationPlaceSelection)
@@ -600,10 +593,9 @@ let SeatReservationBaseElement = (() => {
600
593
  * @param currSelectedPlace
601
594
  */
602
595
  _resetAllPlaceSelections(currSelectedPlace) {
603
- var _a2;
604
596
  for (const placeSelection of this.selectedSeatReservationPlaces) {
605
597
  if (!currSelectedPlace || currSelectedPlace.id !== placeSelection.id) {
606
- const placeElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById(placeSelection.id);
598
+ const placeElement = this.shadowRoot?.getElementById(placeSelection.id);
607
599
  placeElement.setAttribute("state", "FREE");
608
600
  }
609
601
  }
@@ -614,9 +606,8 @@ let SeatReservationBaseElement = (() => {
614
606
  }
615
607
  }
616
608
  _getSeatReservationPlaceSelection(currSelectedPlace) {
617
- var _a2;
618
609
  const coach = this.seatReservation.coachItems[currSelectedPlace.coachIndex];
619
- const place = (_a2 = coach.places) == null ? void 0 : _a2.find((place2) => place2.number === currSelectedPlace.number);
610
+ const place = coach.places?.find((place2) => place2.number === currSelectedPlace.number);
620
611
  return place ? mapPlaceAndCoachToSeatReservationPlaceSelection(place, coach, currSelectedPlace.coachIndex) : null;
621
612
  }
622
613
  _getSeatReservationCoachSelection(coachIndex) {
@@ -640,19 +631,17 @@ let SeatReservationBaseElement = (() => {
640
631
  * @returns HTMLElement or null
641
632
  */
642
633
  _getPlaceHtmlElement(placeNumber, coachIndex) {
643
- var _a2;
644
634
  const currCoachIndex = coachIndex ? coachIndex : this.currSelectedCoachIndex;
645
635
  const coachPlaceNumberId = placeNumber ? "seat-reservation__place-button-" + currCoachIndex + "-" + placeNumber : this.currSelectedPlaceElementId;
646
- return coachPlaceNumberId ? ((_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById(coachPlaceNumberId)) || null : null;
636
+ return coachPlaceNumberId ? this.shadowRoot?.getElementById(coachPlaceNumberId) || null : null;
647
637
  }
648
638
  //Set the vertical offset
649
639
  _setVerticalAlignmentOffset() {
650
640
  setTimeout(() => {
651
- var _a2, _b;
652
- const seatReservationWrapperElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelector(".sbb-sr__wrapper");
641
+ const seatReservationWrapperElement = this.shadowRoot?.querySelector(".sbb-sr__wrapper");
653
642
  if (seatReservationWrapperElement) {
654
643
  const seatReservationVerticalOffset = seatReservationWrapperElement.getBoundingClientRect().width;
655
- (_b = this.style) == null ? void 0 : _b.setProperty("--sbb-seat-reservation-vertical-offset", `${seatReservationVerticalOffset}px`);
644
+ this.style?.setProperty("--sbb-seat-reservation-vertical-offset", `${seatReservationVerticalOffset}px`);
656
645
  }
657
646
  });
658
647
  }
@@ -703,4 +692,4 @@ let SeatReservationBaseElement = (() => {
703
692
  export {
704
693
  SeatReservationBaseElement
705
694
  };
706
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-base-element.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation-base-element.ts"],"sourcesContent":["import { isArrowKeyOrPageKeysPressed } from '@sbb-esta/lyne-elements/core/a11y.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { EventEmitter } from '@sbb-esta/lyne-elements/core/eventing.js';\nimport { LitElement, type PropertyValues } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport {\n  mapCoachInfosToCoachSelection,\n  mapPlaceAndCoachToSeatReservationPlaceSelection,\n  mapPlaceInfosToPlaceSelection,\n} from '../common/mapper.js';\nimport type {\n  CoachItem,\n  ElementDimension,\n  ElementPosition,\n  Place,\n  PlaceSelection,\n  SeatReservation,\n  SeatReservationCoachSelection,\n  SeatReservationPlaceSelection,\n} from '../common.js';\nimport type { SbbSeatReservationPlaceControlElement } from '../seat-reservation-place-control/seat-reservation-place-control.component.js';\n\nimport type { SbbSeatReservationScopedElement } from './seat-reservation-scoped/seat-reservation-scoped.component.js';\n\nenum ScrollDirection {\n  right = 'right',\n  left = 'left',\n}\n\ninterface CoachScrollTriggerPoint {\n  start: number;\n  end: number;\n  width: number;\n}\n\nexport type SeatReservationSelectedPlacesEventDetails = SeatReservationPlaceSelection[];\n\nexport class SeatReservationBaseElement extends LitElement {\n  public static readonly events = {\n    selectedPlaces: 'selectedPlaces',\n    selectedCoach: 'selectedCoach',\n  } as const;\n\n  /** The seat reservation object which contains all coaches and places */\n  @property({ attribute: 'seat-reservation', type: Object })\n  public accessor seatReservation: SeatReservation = null!;\n\n  /** The seat resvervation navigation can be toggled by this property */\n  @forceType()\n  @property({ attribute: 'has-navigation', type: Boolean })\n  public accessor hasNavigation: boolean = true;\n\n  /** The seat reservation area is aligned vertically */\n  @forceType()\n  @property({ attribute: 'align-vertical', type: Boolean })\n  public accessor alignVertical: boolean = false;\n\n  /** The seat reservation area's base grid size */\n  @forceType()\n  @property({ attribute: 'base-grid-size', type: Number })\n  public accessor baseGridSize: number = 16;\n\n  /** The seat reservation area's width */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  /** Maximal number of possible clickable seats */\n  @forceType()\n  @property({ attribute: 'max-reservations', type: Number })\n  public accessor maxReservations: number = null!;\n\n  /** Any click functionality is prevented */\n  @forceType()\n  @property({ attribute: 'prevent-place-click', type: Boolean })\n  public accessor preventPlaceClick: boolean = false;\n\n  @state() protected accessor selectedCoachIndex: number = -1;\n  @state() protected accessor focusedCoachIndex: number = -1;\n\n  /** Emits when a place was selected by user. */\n  protected selectedPlaces: EventEmitter<SeatReservationSelectedPlacesEventDetails> =\n    new EventEmitter(this, SeatReservationBaseElement.events.selectedPlaces);\n\n  /** Emits when a coach was selected by user. */\n  protected selectedCoach: EventEmitter<SeatReservationCoachSelection> = new EventEmitter(\n    this,\n    SeatReservationBaseElement.events.selectedCoach,\n  );\n\n  protected coachBorderPadding = 6;\n  protected coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n  protected currScrollDirection: ScrollDirection = ScrollDirection.right;\n  protected maxCalcCoachsWidth: number = 0;\n  protected scrollCoachsAreaWidth: number = 0;\n  protected triggerCoachPositionsCollection: CoachScrollTriggerPoint[] = [];\n  protected firstTabElement: HTMLElement = null!;\n  protected lastTabElement: HTMLElement = null!;\n  protected coachScrollArea: HTMLElement = null!;\n  protected currSelectedPlace: Place | null = null;\n  protected currSelectedPlaceElementId: string | null = null;\n  protected currSelectedCoachIndex: number = -1;\n  protected preventCoachScrollByPlaceClick: boolean = false;\n  protected selectedSeatReservationPlaces: SeatReservationPlaceSelection[] = [];\n  protected seatReservationWithoutNavigationHasFocus = false;\n  protected isCoachGridFocusable = false;\n  protected isAutoScrolling = false;\n  protected isKeyboardNavigation = false;\n  protected keyboardNavigationEvents = {\n    ArrowLeft: 'ArrowLeft',\n    ArrowRight: 'ArrowRight',\n    ArrowUp: 'ArrowUp',\n    ArrowDown: 'ArrowDown',\n    Tab: 'Tab',\n    Enter: 'Enter',\n  } as const;\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('seatReservation')) {\n      this._initSeatReservationPlaceSelection();\n    }\n\n    if (changedProperties.has('baseGridSize')) {\n      this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n      this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n\n    // If the height is used, the baseGridSize must be recalculated\n    if (changedProperties.has('height') && !!this.height) {\n      if (this.seatReservation.coachItems.length) {\n        this.baseGridSize = this.height / this.seatReservation.coachItems[0].dimension.h;\n        this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n        this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n        if (this.alignVertical) {\n          this._setVerticalAlignmentOffset();\n        }\n      }\n    }\n\n    if (changedProperties.has('alignVertical') && this.alignVertical) {\n      this._setVerticalAlignmentOffset();\n    }\n  }\n\n  /* Init scroll event handling for coach navigation */\n  protected initNavigationSelectionByScrollEvent(): void {\n    this.firstTabElement = this.shadowRoot?.getElementById('first-tab-element') as HTMLElement;\n    this.lastTabElement = this.shadowRoot?.getElementById('last-tab-element') as HTMLElement;\n    this.coachScrollArea = this.shadowRoot?.getElementById('sbb-sr__parent-area') as HTMLElement;\n\n    if (this.coachScrollArea) {\n      let currCalcTriggerPos = 0;\n      this.scrollCoachsAreaWidth = this.coachScrollArea.getBoundingClientRect().width;\n\n      // Precalculate trigger scroll position array depends from coach width\n      this.triggerCoachPositionsCollection = this.seatReservation.coachItems.map((coach) => {\n        const startPosX = currCalcTriggerPos;\n        const coachWidth = this.getCalculatedDimension(coach.dimension).w;\n        currCalcTriggerPos += coachWidth;\n        return {\n          start: startPosX,\n          end: currCalcTriggerPos,\n          width: coachWidth,\n        } as CoachScrollTriggerPoint;\n      });\n\n      // Set maximum calculated coach width\n      this.maxCalcCoachsWidth = currCalcTriggerPos;\n\n      // At the end of a scroll Events to a coach, the reached wagon is marked as selected\n      this.coachScrollArea.addEventListener('scrollend', () => {\n        const findScrollCoachIndex = this.isAutoScrolling\n          ? this.currSelectedCoachIndex\n          : this._getCoachIndexByScrollTriggerPosition();\n        if (this._isScrollableToSelectedCoach()) {\n          this.currSelectedCoachIndex = findScrollCoachIndex;\n        } else {\n          this.currSelectedCoachIndex =\n            findScrollCoachIndex < this.currSelectedCoachIndex\n              ? this.currSelectedCoachIndex\n              : findScrollCoachIndex;\n        }\n\n        this.preventCoachScrollByPlaceClick = false;\n        this.updateCurrentSelectedCoach();\n\n        if (!this.hasNavigation) {\n          this.preselectPlaceInCoach();\n          this.isAutoScrolling = false;\n        }\n      });\n\n      // During initialization we check vertical alignment mode. In Vertical mode we have to set the vertical offset manual for the seat reservation area,\n      // because we rotate the entire component by 90 degrees and transform the origin point to top left.\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n  }\n\n  /**\n   * If no navigation exists (property setting -> hasNavigation) and a table coach gets the focus,\n   * the first place in the coach must be automatically preselected to control the place navigation via keyboard\n   *\n   * @param focusCoachIndex\n   */\n  protected onFocusTableCoachAndPreselectPlace(focusCoachIndex: number): void {\n    if (!this.seatReservationWithoutNavigationHasFocus && !this.hasNavigation) {\n      this.seatReservationWithoutNavigationHasFocus = true;\n      this.currSelectedCoachIndex =\n        focusCoachIndex === 0\n          ? this.getNextAvailableCoachIndex(-1)\n          : this.getPrevAvailableCoachIndex(focusCoachIndex);\n      this.preselectPlaceInCoach();\n    }\n  }\n\n  /**\n   * Initialisation of Keyboard event handling to navigation between each places inside a selected coach by using [arrow] keys.\n   * With the [TAB] key the user navigation goes to the next coach navigation element and the currently selected place is automatically reset.\n   */\n  protected handleKeyboardEvent(event: KeyboardEvent): void {\n    const pressedKey = event.key;\n\n    // If any place is selected and TAB Key combination ist pressed,\n    // then we handle the next or previous coach selection\n    if (this.currSelectedPlace) {\n      if (event.shiftKey && event.keyCode === 9) {\n        this._navigateCoachNavigationByKeyboard('PREV_TAB');\n        event.preventDefault();\n        return;\n      }\n\n      if (pressedKey === this.keyboardNavigationEvents.Tab) {\n        this._navigateCoachNavigationByKeyboard('NEXT_TAB');\n        event.preventDefault();\n        return;\n      }\n    }\n\n    // Check if a choach is selected and the arrow key is pressed\n    if (this.currSelectedCoachIndex !== -1 && isArrowKeyOrPageKeysPressed(event)) {\n      event.preventDefault();\n\n      switch (pressedKey) {\n        case this.keyboardNavigationEvents.ArrowLeft:\n          {\n            const pressedLeftKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowDown\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedLeftKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowRight:\n          {\n            const pressedRightKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowUp\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedRightKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowUp:\n          {\n            const pressedUpKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowLeft\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedUpKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowDown:\n          {\n            const pressedDownKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowRight\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedDownKeyMapping);\n          }\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  /**\n   * Selects a place inside the coach if navigated via keyboard,\n   * otherwise the coach grid is selected (necessary for ScreenReader)\n   */\n  protected preselectPlaceInCoach(): void {\n    const closestPlace = this._getClosestPlaceByKeyDirection();\n    //If closestPlace exist, we have to unfocus previouse focused place\n    if (closestPlace) {\n      this.unfocusPlaceElement();\n    }\n\n    // Only when keyboard navigation is used and coaches are scrolled by auto scrolling,\n    // then we can set the focus on the first place in the coach.\n    if (this.isKeyboardNavigation && this.isAutoScrolling) {\n      if (closestPlace) {\n        this.focusPlaceElement(closestPlace);\n      }\n    }\n    // In cases where the preselection function is triggered by normal clicking or via screenreader via tab,\n    // we only focus the table without directly focusing the place.\n    else {\n      // We need to set the currSelectedPlace here for further correct functioning navigation via tab.\n      this.currSelectedPlace = closestPlace;\n      this._setFocusToSelectedCoachGrid();\n    }\n  }\n\n  protected scrollToSelectedNavCoach(selectedNavCoachIndex: number): void {\n    if (selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.isAutoScrolling = true;\n      this.isCoachGridFocusable = true;\n      this.currSelectedCoachIndex = selectedNavCoachIndex;\n      this._setScrollDirectionByCoachIndex();\n\n      const scrollToCoachPosX = this._getCoachScrollPositionX();\n      const isSelectedCoachIndexScrollable =\n        this.selectedCoachIndex !== -1 || this.currSelectedCoachIndex > 0;\n\n      // Checks whether the current scroll position allows scrolling to the next wagon or not\n      if (isSelectedCoachIndexScrollable && this._isScrollableToSelectedCoach()) {\n        this.coachScrollArea.scrollTo({\n          top: 0,\n          left: scrollToCoachPosX,\n          behavior: 'smooth',\n        });\n      } else {\n        this.updateCurrentSelectedCoach();\n      }\n    }\n  }\n\n  /**\n   * Sets the new ScrollDirection by the new given target coach index.\n   */\n  private _setScrollDirectionByCoachIndex(): void {\n    this.currScrollDirection =\n      this.currSelectedCoachIndex > this.selectedCoachIndex\n        ? ScrollDirection.right\n        : ScrollDirection.left;\n  }\n\n  /**\n   * Returns the scroll start or end position X from the selected coach.\n   * In case the user is curretnly navigate throught places by keyboard and goes to previous coach,\n   * then we return the end position of the coach to get clostest next scroll position of the next focus place.\n   * @returns number\n   */\n  private _getCoachScrollPositionX(): number {\n    const coachTriggerPoint = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isFocusPlaceFromPreviousCoachPosition =\n      this.isKeyboardNavigation &&\n      this.currScrollDirection === ScrollDirection.left &&\n      coachTriggerPoint.width > this.scrollCoachsAreaWidth;\n    return isFocusPlaceFromPreviousCoachPosition\n      ? coachTriggerPoint.end - this.scrollCoachsAreaWidth\n      : coachTriggerPoint.start;\n  }\n\n  /**\n   * Sets the focus on the HTML table (grid) caption element so that the heading is read out when using a ScreenReader.\n   */\n  private _setFocusToSelectedCoachGrid(): void {\n    // When the user performs an action that affects the coach navigation, then the navigated table is focusable.\n    if (this.isCoachGridFocusable) {\n      this.isCoachGridFocusable = false;\n      const coachTableCaptionElement = this.shadowRoot?.querySelector(\n        '#sbb-sr-coach-caption-' + this.currSelectedCoachIndex,\n      ) as HTMLTableCaptionElement;\n      if (coachTableCaptionElement) {\n        coachTableCaptionElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Returns whether the current scrolled position can be used to scroll to the selected wagon\n   * @returns boolean\n   */\n  private _isScrollableToSelectedCoach(): boolean {\n    const currScrollPosX = this.coachScrollArea.scrollLeft;\n    const coachScrollWindowWidth = this.coachScrollArea.getBoundingClientRect().width;\n    const maxScrollWidthArea = this.maxCalcCoachsWidth - coachScrollWindowWidth;\n    const currCoachTrigger = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isScrollPosSameToCurrCoachPos =\n      currScrollPosX === this.triggerCoachPositionsCollection[this.currSelectedCoachIndex].start;\n\n    return (\n      (currScrollPosX < maxScrollWidthArea || currScrollPosX > currCoachTrigger.start) &&\n      !isScrollPosSameToCurrCoachPos\n    );\n  }\n\n  /**\n   * Returns the coach index which is currently visible in the scroll area\n   * @returns number\n   */\n  private _getCoachIndexByScrollTriggerPosition(): number {\n    const scrollOffsetX = this.coachScrollArea.scrollLeft + this.scrollCoachsAreaWidth / 2;\n    return this.triggerCoachPositionsCollection.findIndex(\n      (coachTrigger) => scrollOffsetX >= coachTrigger.start && scrollOffsetX <= coachTrigger.end,\n    );\n  }\n\n  /**\n   * Get the first place of current selected coach by table cell coordinate 0-0 id.\n   * @returns Place or null\n   */\n  private _getFirstPlaceInSelecedCoach(): Place | null {\n    let firstPlace: Place | null = null;\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    const firstCellId = 'cell-' + this.currSelectedCoachIndex + '-0-0';\n    const placeNumber =\n      this.shadowRoot\n        ?.querySelector<SbbSeatReservationScopedElement>(\"[cell-id='\" + firstCellId + \"']\")\n        ?.querySelector<SbbSeatReservationPlaceControlElement>('sbb-seat-reservation-place-control')\n        ?.getAttribute('text') || null;\n\n    if (coach && placeNumber) {\n      firstPlace = coach.places?.find((place) => place.number === placeNumber) || null;\n    }\n    return firstPlace;\n  }\n\n  /**\n   * To get the correct closest place of current pressed key and the current selected place,\n   * we have to investigate the coordinates of each place to find the closest place of the currSelectedPlaceElementId.\n   * @param pressedKey\n   * @returns Place or null\n   */\n  private _getClosestPlaceByKeyDirection(pressedKey?: string): Place | null {\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    let closestPlace = null;\n    if (coach.places) {\n      //If no place set, then wen use initial the left-top place on the coach\n      if (!this.currSelectedPlaceElementId) {\n        return this._getFirstPlaceInSelecedCoach();\n      } else {\n        if (this.currSelectedPlace) {\n          for (const place of coach.places) {\n            // If key pressed, then we try to find the place of the current currScrollDirection\n            if (!pressedKey) {\n              //Find place from the left side of coach by y coordinate. Current currScrollDirection is RIGHT)\n              if (\n                this.currScrollDirection === ScrollDirection.right &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x < closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n              //Find place from the right side of coach by y coordinate. Current currScrollDirection is LEFT\n              else if (\n                this.currScrollDirection === ScrollDirection.left &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x > closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n            } else {\n              if (place.number !== this.currSelectedPlace?.number) {\n                //Key [Right] navigation, we check the place coordinates of the x-axis to get the smallest larger x place coordinate of the currently selected place\n                if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowRight &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y - 1) &&\n                  place.position.x > this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x < closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Down] navigation, we check the place coordinates of the y-axis to get the smallest larger y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowDown &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x + 1) &&\n                  place.position.y > this.currSelectedPlace.position.y &&\n                  (!closestPlace || place.position.y < closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Left] navigation, we check the place coordinates of the x-axis to get the greatest smaller x place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowLeft &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y + 1) &&\n                  place.position.x < this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x > closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Up] navigation, we check the place coordinates of the y-axis to get the greatest smaller y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowUp &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x - 1) &&\n                  place.position.y < this.currSelectedPlace?.position.y &&\n                  (!closestPlace || place.position.y > closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n    return closestPlace;\n  }\n\n  protected focusPlaceElement(place: Place | null, coachIndex?: number): void {\n    this.unfocusPlaceElement();\n    if (place) {\n      this.currSelectedPlace = place;\n      if (coachIndex) {\n        this.currSelectedCoachIndex = coachIndex;\n      }\n\n      this._setCurrSelectedPlaceElementId(place);\n\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      if (selectedPlaceElement) {\n        selectedPlaceElement.setAttribute('keyfocus', 'focus');\n      }\n    }\n  }\n\n  protected unfocusPlaceElement(): void {\n    const selectedPlaceElement = this._getPlaceHtmlElement();\n    if (selectedPlaceElement) {\n      selectedPlaceElement.setAttribute('keyfocus', 'unfocus');\n      this._setCurrSelectedPlaceElementId(null);\n      this.currSelectedPlace = null;\n    }\n  }\n\n  protected getCalculatedDimension(\n    elementDimension: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n    isStretchHeight?: boolean,\n  ): ElementDimension {\n    if (coachDimension && !isOriginHeight) {\n      elementDimension.h += this.coachBorderOffset * 2;\n    }\n\n    if (isStretchHeight) {\n      elementDimension.h += this.coachBorderOffset;\n    }\n\n    return {\n      w: this.baseGridSize * elementDimension.w,\n      h: this.baseGridSize * elementDimension.h,\n    };\n  }\n\n  protected getCalculatedPosition(\n    elementPosition: ElementPosition,\n    elementDimension?: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n  ): ElementPosition {\n    if (coachDimension && elementDimension) {\n      const endPosHeight = isOriginHeight\n        ? coachDimension.h\n        : coachDimension.h + this.coachBorderOffset;\n      //If the original element is positioned at the top or bottom of the coach, we need to recalculate the Y coordinate with the additional border padding\n      if (elementPosition.y === 0) {\n        elementPosition.y -= this.coachBorderOffset;\n      } else if (elementPosition.y + elementDimension.h === endPosHeight) {\n        elementPosition.y += this.coachBorderOffset;\n      }\n    }\n\n    return {\n      x: this.baseGridSize * elementPosition.x,\n      y: this.baseGridSize * elementPosition.y,\n      z: elementPosition.z,\n    };\n  }\n\n  // Handling for Tab navigation if an place is selected inside the coach.\n  // This controls the focused coach from the current selected coach.\n  private _navigateCoachNavigationByKeyboard(tabDirection: string): void {\n    const currFocusIndex =\n      this.focusedCoachIndex === -1\n        ? this.currSelectedCoachIndex === -1\n          ? 0\n          : this.currSelectedCoachIndex\n        : this.focusedCoachIndex;\n    // Check next or prev tab is pressed, then we need to find the next available coach index that should receive the focus\n    const newFocusableIndex: number =\n      tabDirection === 'NEXT_TAB'\n        ? this.getNextAvailableCoachIndex(currFocusIndex)\n        : this.getPrevAvailableCoachIndex(currFocusIndex);\n\n    // If the currFocusIndex equals the newFocusableIndex then we have reached the first or last tabable navigation coach Element and we have to the set the focus manual to the firstTabElement or lastTabElement.\n    if (currFocusIndex === newFocusableIndex) {\n      this.unfocusPlaceElement();\n      this.selectedCoachIndex = -1;\n      this.currSelectedCoachIndex = -1;\n      this.seatReservationWithoutNavigationHasFocus = false;\n\n      if (tabDirection === 'NEXT_TAB') this.lastTabElement.focus();\n      else this.firstTabElement.focus();\n\n      return;\n    }\n\n    if (this.hasNavigation) {\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      const placeInCoachHasFocus = selectedPlaceElement\n        ? selectedPlaceElement.getAttribute('keyfocus') === 'focus'\n        : false;\n\n      // If we tab back (PREV_TAB) and the focus is currently on place,\n      // we remove the selected state from the currently selected navigation coach and only set the focus status to it\n      if (tabDirection === 'PREV_TAB' && this.selectedCoachIndex === currFocusIndex) {\n        if (placeInCoachHasFocus) {\n          this.focusedCoachIndex = currFocusIndex;\n          this.unfocusPlaceElement();\n        } else {\n          this.focusedCoachIndex = newFocusableIndex;\n        }\n      }\n      // Only sets the focus on the new navigation coach\n      else if (newFocusableIndex !== this.currSelectedCoachIndex) {\n        this.focusedCoachIndex = newFocusableIndex;\n      } else {\n        this.focusedCoachIndex = -1;\n        this.selectedCoachIndex = newFocusableIndex;\n        // If any place was focused in coach, so we set focused again\n        if (placeInCoachHasFocus) {\n          this.focusPlaceElement(this.currSelectedPlace);\n        }\n        // If no place was selected, then we select the coach grid\n        else {\n          this.isCoachGridFocusable = true;\n          this._setFocusToSelectedCoachGrid();\n        }\n      }\n    }\n    // If no navigation exist, we scroll directly to the next tabable coach\n    else {\n      this.scrollToSelectedNavCoach(newFocusableIndex);\n    }\n  }\n\n  private _navigateToPlaceByKeyboard(pressedKey: string): void {\n    this.preventCoachScrollByPlaceClick = false;\n    this.isKeyboardNavigation = true;\n\n    if (this.focusedCoachIndex !== -1) {\n      this.focusedCoachIndex = -1;\n    }\n\n    if (!this.preventPlaceClick) {\n      const findClosestPlace = this._getClosestPlaceByKeyDirection(pressedKey);\n      if (findClosestPlace) {\n        this.focusPlaceElement(findClosestPlace);\n      }\n      // No closest place found by key navigation\n      else {\n        if (\n          pressedKey === this.keyboardNavigationEvents.ArrowRight ||\n          pressedKey === this.keyboardNavigationEvents.ArrowLeft ||\n          (this.alignVertical &&\n            (pressedKey === this.keyboardNavigationEvents.ArrowUp ||\n              pressedKey === this.keyboardNavigationEvents.ArrowDown))\n        ) {\n          // Check the current pressed key to get the next available coach index\n          const newSelectedCoachIndex =\n            pressedKey === this.keyboardNavigationEvents.ArrowRight\n              ? this.getNextAvailableCoachIndex()\n              : this.getPrevAvailableCoachIndex();\n\n          this.scrollToSelectedNavCoach(newSelectedCoachIndex);\n        }\n      }\n    }\n  }\n\n  protected getNextAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex < this.seatReservation.coachItems.length - 1 ? startIndex + 1 : startIndex;\n  }\n\n  protected getPrevAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex > 0 ? startIndex - 1 : startIndex;\n  }\n\n  protected updateSelectedSeatReservationPlaces(placeSelection: PlaceSelection): void {\n    // Add selected place to selectedSeatReservationPlaces\n    if (placeSelection.state === 'SELECTED') {\n      const seatReservationSelection = this._getSeatReservationPlaceSelection(placeSelection);\n      if (seatReservationSelection) {\n        this.selectedSeatReservationPlaces.push(seatReservationSelection);\n      }\n    }\n    // Remove selected place from selectedSeatReservationPlaces\n    else {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id !== placeSelection.id,\n      );\n    }\n\n    // Checks whether maxReservation is activated and the maximum number of selected places is reached\n    if (this.maxReservations && this.selectedSeatReservationPlaces.length > this.maxReservations) {\n      this._resetAllPlaceSelections(placeSelection);\n    }\n\n    // Emits the seat reservation place selection\n    this.selectedPlaces.emit(this.selectedSeatReservationPlaces);\n  }\n\n  protected updateCurrentSelectedPlaceInCoach(placeSelection: PlaceSelection): void {\n    const coachIndex = placeSelection.coachIndex;\n    const place = this.seatReservation.coachItems[coachIndex].places?.find(\n      (place) => place.number == placeSelection.number,\n    );\n\n    if (!place) return;\n    this.currSelectedCoachIndex = coachIndex;\n    this.currSelectedPlace = place;\n    if (this.currSelectedCoachIndex !== this.selectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n    }\n\n    this._setCurrSelectedPlaceElementId(place);\n  }\n\n  protected updateCurrentSelectedCoach(): void {\n    this.selectedCoachIndex = this.currSelectedCoachIndex;\n    this.focusedCoachIndex = -1;\n    const coachSelection = this._getSeatReservationCoachSelection(this.selectedCoachIndex);\n    if (coachSelection) {\n      this.selectedCoach.emit(coachSelection);\n    }\n  }\n\n  /**\n   * Initialization of SeatReservationPlaceSelection Array based on the transferred places\n   * that have the state SELECTED within the seatReservation object\n   */\n  private _initSeatReservationPlaceSelection(): void {\n    this.seatReservation.coachItems.map((coach: CoachItem, coachIndex: number) => {\n      coach.places\n        ?.filter((place) => place.state === 'SELECTED')\n        ?.forEach((place) => {\n          const preselectedPlaceSelection: PlaceSelection = mapPlaceInfosToPlaceSelection(\n            place,\n            coachIndex,\n          );\n          const seatReservationPlaceSelection: SeatReservationPlaceSelection | null =\n            this._getSeatReservationPlaceSelection(preselectedPlaceSelection);\n          if (seatReservationPlaceSelection)\n            this.selectedSeatReservationPlaces.push(seatReservationPlaceSelection);\n        });\n    });\n  }\n\n  /**\n   * All selected places will be reset or the currentSelectedPlace was given, then we reset all except currentSelectedPlace\n   * @param currSelectedPlace\n   */\n  private _resetAllPlaceSelections(currSelectedPlace?: PlaceSelection): void {\n    //Find all places to be needed unselect\n    for (const placeSelection of this.selectedSeatReservationPlaces) {\n      if (!currSelectedPlace || currSelectedPlace.id !== placeSelection.id) {\n        const placeElement = this.shadowRoot?.getElementById(placeSelection.id) as HTMLElement;\n        placeElement.setAttribute('state', 'FREE');\n      }\n    }\n    //Removes all selected places except the currently selected place\n    if (currSelectedPlace) {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id === currSelectedPlace.id,\n      );\n    } else {\n      this.selectedSeatReservationPlaces = [];\n    }\n  }\n\n  private _getSeatReservationPlaceSelection(\n    currSelectedPlace: PlaceSelection,\n  ): SeatReservationPlaceSelection | null {\n    const coach = this.seatReservation.coachItems[currSelectedPlace.coachIndex];\n    const place = coach.places?.find((place) => place.number === currSelectedPlace.number);\n\n    return place\n      ? mapPlaceAndCoachToSeatReservationPlaceSelection(place, coach, currSelectedPlace.coachIndex)\n      : null;\n  }\n\n  private _getSeatReservationCoachSelection(\n    coachIndex: number,\n  ): SeatReservationCoachSelection | null {\n    if (!this.seatReservation.coachItems[coachIndex]) return null;\n\n    const coach = this.seatReservation.coachItems[coachIndex];\n    return mapCoachInfosToCoachSelection(coachIndex, coach);\n  }\n\n  private _setCurrSelectedPlaceElementId(place: Place | null): void {\n    if (place) {\n      this.currSelectedPlaceElementId =\n        'seat-reservation__place-button-' + this.currSelectedCoachIndex + '-' + place.number;\n    } else {\n      this.currSelectedPlaceElementId = null;\n    }\n  }\n\n  /**\n   * Returns the current selected place HTML element by given placeNumber and coachIndex.\n   * If both doesnt exist, we try to return the place HTML element by the _currentSelectedPlaceElementId\n   * @param placeNumber optional as string\n   * @param coachIndex optional as string\n   * @returns HTMLElement or null\n   */\n  private _getPlaceHtmlElement(placeNumber?: string, coachIndex?: number): HTMLElement | null {\n    const currCoachIndex = coachIndex ? coachIndex : this.currSelectedCoachIndex;\n    const coachPlaceNumberId = placeNumber\n      ? 'seat-reservation__place-button-' + currCoachIndex + '-' + placeNumber\n      : this.currSelectedPlaceElementId;\n    return coachPlaceNumberId ? this.shadowRoot?.getElementById(coachPlaceNumberId) || null : null;\n  }\n\n  //Set the vertical offset\n  private _setVerticalAlignmentOffset(): void {\n    setTimeout(() => {\n      const seatReservationWrapperElement = this.shadowRoot?.querySelector(\n        '.sbb-sr__wrapper',\n      ) as HTMLElement;\n      if (seatReservationWrapperElement) {\n        const seatReservationVerticalOffset =\n          seatReservationWrapperElement.getBoundingClientRect().width;\n        this.style?.setProperty(\n          '--sbb-seat-reservation-vertical-offset',\n          `${seatReservationVerticalOffset}px`,\n        );\n      }\n    });\n  }\n}\n"],"names":["ScrollDirection","SeatReservationBaseElement","_a","place"],"mappings":"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"}
695
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-base-element.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation-base-element.ts"],"sourcesContent":["import { isArrowKeyOrPageKeysPressed } from '@sbb-esta/lyne-elements/core/a11y.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { EventEmitter } from '@sbb-esta/lyne-elements/core/eventing.js';\nimport { LitElement, type PropertyValues } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport {\n  mapCoachInfosToCoachSelection,\n  mapPlaceAndCoachToSeatReservationPlaceSelection,\n  mapPlaceInfosToPlaceSelection,\n} from '../common/mapper.js';\nimport type {\n  CoachItem,\n  ElementDimension,\n  ElementPosition,\n  Place,\n  PlaceSelection,\n  SeatReservation,\n  SeatReservationCoachSelection,\n  SeatReservationPlaceSelection,\n} from '../common.js';\nimport type { SbbSeatReservationPlaceControlElement } from '../seat-reservation-place-control/seat-reservation-place-control.component.js';\n\nimport type { SbbSeatReservationScopedElement } from './seat-reservation-scoped/seat-reservation-scoped.component.js';\n\nenum ScrollDirection {\n  right = 'right',\n  left = 'left',\n}\n\ninterface CoachScrollTriggerPoint {\n  start: number;\n  end: number;\n  width: number;\n}\n\nexport type SeatReservationSelectedPlacesEventDetails = SeatReservationPlaceSelection[];\n\nexport class SeatReservationBaseElement extends LitElement {\n  public static readonly events = {\n    selectedPlaces: 'selectedPlaces',\n    selectedCoach: 'selectedCoach',\n  } as const;\n\n  /** The seat reservation object which contains all coaches and places */\n  @property({ attribute: 'seat-reservation', type: Object })\n  public accessor seatReservation: SeatReservation = null!;\n\n  /** The seat resvervation navigation can be toggled by this property */\n  @forceType()\n  @property({ attribute: 'has-navigation', type: Boolean })\n  public accessor hasNavigation: boolean = true;\n\n  /** The seat reservation area is aligned vertically */\n  @forceType()\n  @property({ attribute: 'align-vertical', type: Boolean })\n  public accessor alignVertical: boolean = false;\n\n  /** The seat reservation area's base grid size */\n  @forceType()\n  @property({ attribute: 'base-grid-size', type: Number })\n  public accessor baseGridSize: number = 16;\n\n  /** The seat reservation area's width */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  /** Maximal number of possible clickable seats */\n  @forceType()\n  @property({ attribute: 'max-reservations', type: Number })\n  public accessor maxReservations: number = null!;\n\n  /** Any click functionality is prevented */\n  @forceType()\n  @property({ attribute: 'prevent-place-click', type: Boolean })\n  public accessor preventPlaceClick: boolean = false;\n\n  @state() protected accessor selectedCoachIndex: number = -1;\n  @state() protected accessor focusedCoachIndex: number = -1;\n\n  /** Emits when a place was selected by user. */\n  protected selectedPlaces: EventEmitter<SeatReservationSelectedPlacesEventDetails> =\n    new EventEmitter(this, SeatReservationBaseElement.events.selectedPlaces);\n\n  /** Emits when a coach was selected by user. */\n  protected selectedCoach: EventEmitter<SeatReservationCoachSelection> = new EventEmitter(\n    this,\n    SeatReservationBaseElement.events.selectedCoach,\n  );\n\n  protected coachBorderPadding = 6;\n  protected coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n  protected currScrollDirection: ScrollDirection = ScrollDirection.right;\n  protected maxCalcCoachsWidth: number = 0;\n  protected scrollCoachsAreaWidth: number = 0;\n  protected triggerCoachPositionsCollection: CoachScrollTriggerPoint[] = [];\n  protected firstTabElement: HTMLElement = null!;\n  protected lastTabElement: HTMLElement = null!;\n  protected coachScrollArea: HTMLElement = null!;\n  protected currSelectedPlace: Place | null = null;\n  protected currSelectedPlaceElementId: string | null = null;\n  protected currSelectedCoachIndex: number = -1;\n  protected preventCoachScrollByPlaceClick: boolean = false;\n  protected selectedSeatReservationPlaces: SeatReservationPlaceSelection[] = [];\n  protected seatReservationWithoutNavigationHasFocus = false;\n  protected isCoachGridFocusable = false;\n  protected isAutoScrolling = false;\n  protected isKeyboardNavigation = false;\n  protected keyboardNavigationEvents = {\n    ArrowLeft: 'ArrowLeft',\n    ArrowRight: 'ArrowRight',\n    ArrowUp: 'ArrowUp',\n    ArrowDown: 'ArrowDown',\n    Tab: 'Tab',\n    Enter: 'Enter',\n  } as const;\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('seatReservation')) {\n      this._initSeatReservationPlaceSelection();\n    }\n\n    if (changedProperties.has('baseGridSize')) {\n      this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n      this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n\n    // If the height is used, the baseGridSize must be recalculated\n    if (changedProperties.has('height') && !!this.height) {\n      if (this.seatReservation.coachItems.length) {\n        this.baseGridSize = this.height / this.seatReservation.coachItems[0].dimension.h;\n        this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n        this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n        if (this.alignVertical) {\n          this._setVerticalAlignmentOffset();\n        }\n      }\n    }\n\n    if (changedProperties.has('alignVertical') && this.alignVertical) {\n      this._setVerticalAlignmentOffset();\n    }\n  }\n\n  /* Init scroll event handling for coach navigation */\n  protected initNavigationSelectionByScrollEvent(): void {\n    this.firstTabElement = this.shadowRoot?.getElementById('first-tab-element') as HTMLElement;\n    this.lastTabElement = this.shadowRoot?.getElementById('last-tab-element') as HTMLElement;\n    this.coachScrollArea = this.shadowRoot?.getElementById('sbb-sr__parent-area') as HTMLElement;\n\n    if (this.coachScrollArea) {\n      let currCalcTriggerPos = 0;\n      this.scrollCoachsAreaWidth = this.coachScrollArea.getBoundingClientRect().width;\n\n      // Precalculate trigger scroll position array depends from coach width\n      this.triggerCoachPositionsCollection = this.seatReservation.coachItems.map((coach) => {\n        const startPosX = currCalcTriggerPos;\n        const coachWidth = this.getCalculatedDimension(coach.dimension).w;\n        currCalcTriggerPos += coachWidth;\n        return {\n          start: startPosX,\n          end: currCalcTriggerPos,\n          width: coachWidth,\n        } as CoachScrollTriggerPoint;\n      });\n\n      // Set maximum calculated coach width\n      this.maxCalcCoachsWidth = currCalcTriggerPos;\n\n      // At the end of a scroll Events to a coach, the reached wagon is marked as selected\n      this.coachScrollArea.addEventListener('scrollend', () => {\n        const findScrollCoachIndex = this.isAutoScrolling\n          ? this.currSelectedCoachIndex\n          : this._getCoachIndexByScrollTriggerPosition();\n        if (this._isScrollableToSelectedCoach()) {\n          this.currSelectedCoachIndex = findScrollCoachIndex;\n        } else {\n          this.currSelectedCoachIndex =\n            findScrollCoachIndex < this.currSelectedCoachIndex\n              ? this.currSelectedCoachIndex\n              : findScrollCoachIndex;\n        }\n\n        this.preventCoachScrollByPlaceClick = false;\n        this.updateCurrentSelectedCoach();\n\n        if (!this.hasNavigation) {\n          this.preselectPlaceInCoach();\n          this.isAutoScrolling = false;\n        }\n      });\n\n      // During initialization we check vertical alignment mode. In Vertical mode we have to set the vertical offset manual for the seat reservation area,\n      // because we rotate the entire component by 90 degrees and transform the origin point to top left.\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n  }\n\n  /**\n   * If no navigation exists (property setting -> hasNavigation) and a table coach gets the focus,\n   * the first place in the coach must be automatically preselected to control the place navigation via keyboard\n   *\n   * @param focusCoachIndex\n   */\n  protected onFocusTableCoachAndPreselectPlace(focusCoachIndex: number): void {\n    if (!this.seatReservationWithoutNavigationHasFocus && !this.hasNavigation) {\n      this.seatReservationWithoutNavigationHasFocus = true;\n      this.currSelectedCoachIndex =\n        focusCoachIndex === 0\n          ? this.getNextAvailableCoachIndex(-1)\n          : this.getPrevAvailableCoachIndex(focusCoachIndex);\n      this.preselectPlaceInCoach();\n    }\n  }\n\n  /**\n   * Initialisation of Keyboard event handling to navigation between each places inside a selected coach by using [arrow] keys.\n   * With the [TAB] key the user navigation goes to the next coach navigation element and the currently selected place is automatically reset.\n   */\n  protected handleKeyboardEvent(event: KeyboardEvent): void {\n    const pressedKey = event.key;\n\n    // If any place is selected and TAB Key combination ist pressed,\n    // then we handle the next or previous coach selection\n    if (this.currSelectedPlace) {\n      if (event.shiftKey && event.keyCode === 9) {\n        this._navigateCoachNavigationByKeyboard('PREV_TAB');\n        event.preventDefault();\n        return;\n      }\n\n      if (pressedKey === this.keyboardNavigationEvents.Tab) {\n        this._navigateCoachNavigationByKeyboard('NEXT_TAB');\n        event.preventDefault();\n        return;\n      }\n    }\n\n    // Check if a choach is selected and the arrow key is pressed\n    if (this.currSelectedCoachIndex !== -1 && isArrowKeyOrPageKeysPressed(event)) {\n      event.preventDefault();\n\n      switch (pressedKey) {\n        case this.keyboardNavigationEvents.ArrowLeft:\n          {\n            const pressedLeftKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowDown\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedLeftKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowRight:\n          {\n            const pressedRightKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowUp\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedRightKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowUp:\n          {\n            const pressedUpKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowLeft\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedUpKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowDown:\n          {\n            const pressedDownKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowRight\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedDownKeyMapping);\n          }\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  /**\n   * Selects a place inside the coach if navigated via keyboard,\n   * otherwise the coach grid is selected (necessary for ScreenReader)\n   */\n  protected preselectPlaceInCoach(): void {\n    const closestPlace = this._getClosestPlaceByKeyDirection();\n    //If closestPlace exist, we have to unfocus previouse focused place\n    if (closestPlace) {\n      this.unfocusPlaceElement();\n    }\n\n    // Only when keyboard navigation is used and coaches are scrolled by auto scrolling,\n    // then we can set the focus on the first place in the coach.\n    if (this.isKeyboardNavigation && this.isAutoScrolling) {\n      if (closestPlace) {\n        this.focusPlaceElement(closestPlace);\n      }\n    }\n    // In cases where the preselection function is triggered by normal clicking or via screenreader via tab,\n    // we only focus the table without directly focusing the place.\n    else {\n      // We need to set the currSelectedPlace here for further correct functioning navigation via tab.\n      this.currSelectedPlace = closestPlace;\n      this._setFocusToSelectedCoachGrid();\n    }\n  }\n\n  protected scrollToSelectedNavCoach(selectedNavCoachIndex: number): void {\n    if (selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.isAutoScrolling = true;\n      this.isCoachGridFocusable = true;\n      this.currSelectedCoachIndex = selectedNavCoachIndex;\n      this._setScrollDirectionByCoachIndex();\n\n      const scrollToCoachPosX = this._getCoachScrollPositionX();\n      const isSelectedCoachIndexScrollable =\n        this.selectedCoachIndex !== -1 || this.currSelectedCoachIndex > 0;\n\n      // Checks whether the current scroll position allows scrolling to the next wagon or not\n      if (isSelectedCoachIndexScrollable && this._isScrollableToSelectedCoach()) {\n        this.coachScrollArea.scrollTo({\n          top: 0,\n          left: scrollToCoachPosX,\n          behavior: 'smooth',\n        });\n      } else {\n        this.updateCurrentSelectedCoach();\n      }\n    }\n  }\n\n  /**\n   * Sets the new ScrollDirection by the new given target coach index.\n   */\n  private _setScrollDirectionByCoachIndex(): void {\n    this.currScrollDirection =\n      this.currSelectedCoachIndex > this.selectedCoachIndex\n        ? ScrollDirection.right\n        : ScrollDirection.left;\n  }\n\n  /**\n   * Returns the scroll start or end position X from the selected coach.\n   * In case the user is curretnly navigate throught places by keyboard and goes to previous coach,\n   * then we return the end position of the coach to get clostest next scroll position of the next focus place.\n   * @returns number\n   */\n  private _getCoachScrollPositionX(): number {\n    const coachTriggerPoint = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isFocusPlaceFromPreviousCoachPosition =\n      this.isKeyboardNavigation &&\n      this.currScrollDirection === ScrollDirection.left &&\n      coachTriggerPoint.width > this.scrollCoachsAreaWidth;\n    return isFocusPlaceFromPreviousCoachPosition\n      ? coachTriggerPoint.end - this.scrollCoachsAreaWidth\n      : coachTriggerPoint.start;\n  }\n\n  /**\n   * Sets the focus on the HTML table (grid) caption element so that the heading is read out when using a ScreenReader.\n   */\n  private _setFocusToSelectedCoachGrid(): void {\n    // When the user performs an action that affects the coach navigation, then the navigated table is focusable.\n    if (this.isCoachGridFocusable) {\n      this.isCoachGridFocusable = false;\n      const coachTableCaptionElement = this.shadowRoot?.querySelector(\n        '#sbb-sr-coach-caption-' + this.currSelectedCoachIndex,\n      ) as HTMLTableCaptionElement;\n      if (coachTableCaptionElement) {\n        coachTableCaptionElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Returns whether the current scrolled position can be used to scroll to the selected wagon\n   * @returns boolean\n   */\n  private _isScrollableToSelectedCoach(): boolean {\n    const currScrollPosX = this.coachScrollArea.scrollLeft;\n    const coachScrollWindowWidth = this.coachScrollArea.getBoundingClientRect().width;\n    const maxScrollWidthArea = this.maxCalcCoachsWidth - coachScrollWindowWidth;\n    const currCoachTrigger = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isScrollPosSameToCurrCoachPos =\n      currScrollPosX === this.triggerCoachPositionsCollection[this.currSelectedCoachIndex].start;\n\n    return (\n      (currScrollPosX < maxScrollWidthArea || currScrollPosX > currCoachTrigger.start) &&\n      !isScrollPosSameToCurrCoachPos\n    );\n  }\n\n  /**\n   * Returns the coach index which is currently visible in the scroll area\n   * @returns number\n   */\n  private _getCoachIndexByScrollTriggerPosition(): number {\n    const scrollOffsetX = this.coachScrollArea.scrollLeft + this.scrollCoachsAreaWidth / 2;\n    return this.triggerCoachPositionsCollection.findIndex(\n      (coachTrigger) => scrollOffsetX >= coachTrigger.start && scrollOffsetX <= coachTrigger.end,\n    );\n  }\n\n  /**\n   * Get the first place of current selected coach by table cell coordinate 0-0 id.\n   * @returns Place or null\n   */\n  private _getFirstPlaceInSelecedCoach(): Place | null {\n    let firstPlace: Place | null = null;\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    const firstCellId = 'cell-' + this.currSelectedCoachIndex + '-0-0';\n    const placeNumber =\n      this.shadowRoot\n        ?.querySelector<SbbSeatReservationScopedElement>(\"[cell-id='\" + firstCellId + \"']\")\n        ?.querySelector<SbbSeatReservationPlaceControlElement>('sbb-seat-reservation-place-control')\n        ?.getAttribute('text') || null;\n\n    if (coach && placeNumber) {\n      firstPlace = coach.places?.find((place) => place.number === placeNumber) || null;\n    }\n    return firstPlace;\n  }\n\n  /**\n   * To get the correct closest place of current pressed key and the current selected place,\n   * we have to investigate the coordinates of each place to find the closest place of the currSelectedPlaceElementId.\n   * @param pressedKey\n   * @returns Place or null\n   */\n  private _getClosestPlaceByKeyDirection(pressedKey?: string): Place | null {\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    let closestPlace = null;\n    if (coach.places) {\n      //If no place set, then wen use initial the left-top place on the coach\n      if (!this.currSelectedPlaceElementId) {\n        return this._getFirstPlaceInSelecedCoach();\n      } else {\n        if (this.currSelectedPlace) {\n          for (const place of coach.places) {\n            // If key pressed, then we try to find the place of the current currScrollDirection\n            if (!pressedKey) {\n              //Find place from the left side of coach by y coordinate. Current currScrollDirection is RIGHT)\n              if (\n                this.currScrollDirection === ScrollDirection.right &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x < closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n              //Find place from the right side of coach by y coordinate. Current currScrollDirection is LEFT\n              else if (\n                this.currScrollDirection === ScrollDirection.left &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x > closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n            } else {\n              if (place.number !== this.currSelectedPlace?.number) {\n                //Key [Right] navigation, we check the place coordinates of the x-axis to get the smallest larger x place coordinate of the currently selected place\n                if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowRight &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y - 1) &&\n                  place.position.x > this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x < closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Down] navigation, we check the place coordinates of the y-axis to get the smallest larger y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowDown &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x + 1) &&\n                  place.position.y > this.currSelectedPlace.position.y &&\n                  (!closestPlace || place.position.y < closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Left] navigation, we check the place coordinates of the x-axis to get the greatest smaller x place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowLeft &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y + 1) &&\n                  place.position.x < this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x > closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Up] navigation, we check the place coordinates of the y-axis to get the greatest smaller y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowUp &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x - 1) &&\n                  place.position.y < this.currSelectedPlace?.position.y &&\n                  (!closestPlace || place.position.y > closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n    return closestPlace;\n  }\n\n  protected focusPlaceElement(place: Place | null, coachIndex?: number): void {\n    this.unfocusPlaceElement();\n    if (place) {\n      this.currSelectedPlace = place;\n      if (coachIndex) {\n        this.currSelectedCoachIndex = coachIndex;\n      }\n\n      this._setCurrSelectedPlaceElementId(place);\n\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      if (selectedPlaceElement) {\n        selectedPlaceElement.setAttribute('keyfocus', 'focus');\n      }\n    }\n  }\n\n  protected unfocusPlaceElement(): void {\n    const selectedPlaceElement = this._getPlaceHtmlElement();\n    if (selectedPlaceElement) {\n      selectedPlaceElement.setAttribute('keyfocus', 'unfocus');\n      this._setCurrSelectedPlaceElementId(null);\n      this.currSelectedPlace = null;\n    }\n  }\n\n  protected getCalculatedDimension(\n    elementDimension: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n    isStretchHeight?: boolean,\n  ): ElementDimension {\n    if (coachDimension && !isOriginHeight) {\n      elementDimension.h += this.coachBorderOffset * 2;\n    }\n\n    if (isStretchHeight) {\n      elementDimension.h += this.coachBorderOffset;\n    }\n\n    return {\n      w: this.baseGridSize * elementDimension.w,\n      h: this.baseGridSize * elementDimension.h,\n    };\n  }\n\n  protected getCalculatedPosition(\n    elementPosition: ElementPosition,\n    elementDimension?: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n  ): ElementPosition {\n    if (coachDimension && elementDimension) {\n      const endPosHeight = isOriginHeight\n        ? coachDimension.h\n        : coachDimension.h + this.coachBorderOffset;\n      //If the original element is positioned at the top or bottom of the coach, we need to recalculate the Y coordinate with the additional border padding\n      if (elementPosition.y === 0) {\n        elementPosition.y -= this.coachBorderOffset;\n      } else if (elementPosition.y + elementDimension.h === endPosHeight) {\n        elementPosition.y += this.coachBorderOffset;\n      }\n    }\n\n    return {\n      x: this.baseGridSize * elementPosition.x,\n      y: this.baseGridSize * elementPosition.y,\n      z: elementPosition.z,\n    };\n  }\n\n  // Handling for Tab navigation if an place is selected inside the coach.\n  // This controls the focused coach from the current selected coach.\n  private _navigateCoachNavigationByKeyboard(tabDirection: string): void {\n    const currFocusIndex =\n      this.focusedCoachIndex === -1\n        ? this.currSelectedCoachIndex === -1\n          ? 0\n          : this.currSelectedCoachIndex\n        : this.focusedCoachIndex;\n    // Check next or prev tab is pressed, then we need to find the next available coach index that should receive the focus\n    const newFocusableIndex: number =\n      tabDirection === 'NEXT_TAB'\n        ? this.getNextAvailableCoachIndex(currFocusIndex)\n        : this.getPrevAvailableCoachIndex(currFocusIndex);\n\n    // If the currFocusIndex equals the newFocusableIndex then we have reached the first or last tabable navigation coach Element and we have to the set the focus manual to the firstTabElement or lastTabElement.\n    if (currFocusIndex === newFocusableIndex) {\n      this.unfocusPlaceElement();\n      this.selectedCoachIndex = -1;\n      this.currSelectedCoachIndex = -1;\n      this.seatReservationWithoutNavigationHasFocus = false;\n\n      if (tabDirection === 'NEXT_TAB') this.lastTabElement.focus();\n      else this.firstTabElement.focus();\n\n      return;\n    }\n\n    if (this.hasNavigation) {\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      const placeInCoachHasFocus = selectedPlaceElement\n        ? selectedPlaceElement.getAttribute('keyfocus') === 'focus'\n        : false;\n\n      // If we tab back (PREV_TAB) and the focus is currently on place,\n      // we remove the selected state from the currently selected navigation coach and only set the focus status to it\n      if (tabDirection === 'PREV_TAB' && this.selectedCoachIndex === currFocusIndex) {\n        if (placeInCoachHasFocus) {\n          this.focusedCoachIndex = currFocusIndex;\n          this.unfocusPlaceElement();\n        } else {\n          this.focusedCoachIndex = newFocusableIndex;\n        }\n      }\n      // Only sets the focus on the new navigation coach\n      else if (newFocusableIndex !== this.currSelectedCoachIndex) {\n        this.focusedCoachIndex = newFocusableIndex;\n      } else {\n        this.focusedCoachIndex = -1;\n        this.selectedCoachIndex = newFocusableIndex;\n        // If any place was focused in coach, so we set focused again\n        if (placeInCoachHasFocus) {\n          this.focusPlaceElement(this.currSelectedPlace);\n        }\n        // If no place was selected, then we select the coach grid\n        else {\n          this.isCoachGridFocusable = true;\n          this._setFocusToSelectedCoachGrid();\n        }\n      }\n    }\n    // If no navigation exist, we scroll directly to the next tabable coach\n    else {\n      this.scrollToSelectedNavCoach(newFocusableIndex);\n    }\n  }\n\n  private _navigateToPlaceByKeyboard(pressedKey: string): void {\n    this.preventCoachScrollByPlaceClick = false;\n    this.isKeyboardNavigation = true;\n\n    if (this.focusedCoachIndex !== -1) {\n      this.focusedCoachIndex = -1;\n    }\n\n    if (!this.preventPlaceClick) {\n      const findClosestPlace = this._getClosestPlaceByKeyDirection(pressedKey);\n      if (findClosestPlace) {\n        this.focusPlaceElement(findClosestPlace);\n      }\n      // No closest place found by key navigation\n      else {\n        if (\n          pressedKey === this.keyboardNavigationEvents.ArrowRight ||\n          pressedKey === this.keyboardNavigationEvents.ArrowLeft ||\n          (this.alignVertical &&\n            (pressedKey === this.keyboardNavigationEvents.ArrowUp ||\n              pressedKey === this.keyboardNavigationEvents.ArrowDown))\n        ) {\n          // Check the current pressed key to get the next available coach index\n          const newSelectedCoachIndex =\n            pressedKey === this.keyboardNavigationEvents.ArrowRight\n              ? this.getNextAvailableCoachIndex()\n              : this.getPrevAvailableCoachIndex();\n\n          this.scrollToSelectedNavCoach(newSelectedCoachIndex);\n        }\n      }\n    }\n  }\n\n  protected getNextAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex < this.seatReservation.coachItems.length - 1 ? startIndex + 1 : startIndex;\n  }\n\n  protected getPrevAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex > 0 ? startIndex - 1 : startIndex;\n  }\n\n  protected updateSelectedSeatReservationPlaces(placeSelection: PlaceSelection): void {\n    // Add selected place to selectedSeatReservationPlaces\n    if (placeSelection.state === 'SELECTED') {\n      const seatReservationSelection = this._getSeatReservationPlaceSelection(placeSelection);\n      if (seatReservationSelection) {\n        this.selectedSeatReservationPlaces.push(seatReservationSelection);\n      }\n    }\n    // Remove selected place from selectedSeatReservationPlaces\n    else {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id !== placeSelection.id,\n      );\n    }\n\n    // Checks whether maxReservation is activated and the maximum number of selected places is reached\n    if (this.maxReservations && this.selectedSeatReservationPlaces.length > this.maxReservations) {\n      this._resetAllPlaceSelections(placeSelection);\n    }\n\n    // Emits the seat reservation place selection\n    this.selectedPlaces.emit(this.selectedSeatReservationPlaces);\n  }\n\n  protected updateCurrentSelectedPlaceInCoach(placeSelection: PlaceSelection): void {\n    const coachIndex = placeSelection.coachIndex;\n    const place = this.seatReservation.coachItems[coachIndex].places?.find(\n      (place) => place.number == placeSelection.number,\n    );\n\n    if (!place) return;\n    this.currSelectedCoachIndex = coachIndex;\n    this.currSelectedPlace = place;\n    if (this.currSelectedCoachIndex !== this.selectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n    }\n\n    this._setCurrSelectedPlaceElementId(place);\n  }\n\n  protected updateCurrentSelectedCoach(): void {\n    this.selectedCoachIndex = this.currSelectedCoachIndex;\n    this.focusedCoachIndex = -1;\n    const coachSelection = this._getSeatReservationCoachSelection(this.selectedCoachIndex);\n    if (coachSelection) {\n      this.selectedCoach.emit(coachSelection);\n    }\n  }\n\n  /**\n   * Initialization of SeatReservationPlaceSelection Array based on the transferred places\n   * that have the state SELECTED within the seatReservation object\n   */\n  private _initSeatReservationPlaceSelection(): void {\n    this.seatReservation.coachItems.map((coach: CoachItem, coachIndex: number) => {\n      coach.places\n        ?.filter((place) => place.state === 'SELECTED')\n        ?.forEach((place) => {\n          const preselectedPlaceSelection: PlaceSelection = mapPlaceInfosToPlaceSelection(\n            place,\n            coachIndex,\n          );\n          const seatReservationPlaceSelection: SeatReservationPlaceSelection | null =\n            this._getSeatReservationPlaceSelection(preselectedPlaceSelection);\n          if (seatReservationPlaceSelection)\n            this.selectedSeatReservationPlaces.push(seatReservationPlaceSelection);\n        });\n    });\n  }\n\n  /**\n   * All selected places will be reset or the currentSelectedPlace was given, then we reset all except currentSelectedPlace\n   * @param currSelectedPlace\n   */\n  private _resetAllPlaceSelections(currSelectedPlace?: PlaceSelection): void {\n    //Find all places to be needed unselect\n    for (const placeSelection of this.selectedSeatReservationPlaces) {\n      if (!currSelectedPlace || currSelectedPlace.id !== placeSelection.id) {\n        const placeElement = this.shadowRoot?.getElementById(placeSelection.id) as HTMLElement;\n        placeElement.setAttribute('state', 'FREE');\n      }\n    }\n    //Removes all selected places except the currently selected place\n    if (currSelectedPlace) {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id === currSelectedPlace.id,\n      );\n    } else {\n      this.selectedSeatReservationPlaces = [];\n    }\n  }\n\n  private _getSeatReservationPlaceSelection(\n    currSelectedPlace: PlaceSelection,\n  ): SeatReservationPlaceSelection | null {\n    const coach = this.seatReservation.coachItems[currSelectedPlace.coachIndex];\n    const place = coach.places?.find((place) => place.number === currSelectedPlace.number);\n\n    return place\n      ? mapPlaceAndCoachToSeatReservationPlaceSelection(place, coach, currSelectedPlace.coachIndex)\n      : null;\n  }\n\n  private _getSeatReservationCoachSelection(\n    coachIndex: number,\n  ): SeatReservationCoachSelection | null {\n    if (!this.seatReservation.coachItems[coachIndex]) return null;\n\n    const coach = this.seatReservation.coachItems[coachIndex];\n    return mapCoachInfosToCoachSelection(coachIndex, coach);\n  }\n\n  private _setCurrSelectedPlaceElementId(place: Place | null): void {\n    if (place) {\n      this.currSelectedPlaceElementId =\n        'seat-reservation__place-button-' + this.currSelectedCoachIndex + '-' + place.number;\n    } else {\n      this.currSelectedPlaceElementId = null;\n    }\n  }\n\n  /**\n   * Returns the current selected place HTML element by given placeNumber and coachIndex.\n   * If both doesnt exist, we try to return the place HTML element by the _currentSelectedPlaceElementId\n   * @param placeNumber optional as string\n   * @param coachIndex optional as string\n   * @returns HTMLElement or null\n   */\n  private _getPlaceHtmlElement(placeNumber?: string, coachIndex?: number): HTMLElement | null {\n    const currCoachIndex = coachIndex ? coachIndex : this.currSelectedCoachIndex;\n    const coachPlaceNumberId = placeNumber\n      ? 'seat-reservation__place-button-' + currCoachIndex + '-' + placeNumber\n      : this.currSelectedPlaceElementId;\n    return coachPlaceNumberId ? this.shadowRoot?.getElementById(coachPlaceNumberId) || null : null;\n  }\n\n  //Set the vertical offset\n  private _setVerticalAlignmentOffset(): void {\n    setTimeout(() => {\n      const seatReservationWrapperElement = this.shadowRoot?.querySelector(\n        '.sbb-sr__wrapper',\n      ) as HTMLElement;\n      if (seatReservationWrapperElement) {\n        const seatReservationVerticalOffset =\n          seatReservationWrapperElement.getBoundingClientRect().width;\n        this.style?.setProperty(\n          '--sbb-seat-reservation-vertical-offset',\n          `${seatReservationVerticalOffset}px`,\n        );\n      }\n    });\n  }\n}\n"],"names":["ScrollDirection","SeatReservationBaseElement","place"],"mappings":"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"}
@@ -125,22 +125,21 @@ let SbbSeatReservationScopedElement = (() => {
125
125
  __privateSet(this, _scopedClasses_accessor_storage, value);
126
126
  }
127
127
  willUpdate(_changedProperties) {
128
- var _a2, _b, _c, _d, _e;
129
128
  super.willUpdate(_changedProperties);
130
129
  if (_changedProperties.has("width")) {
131
- (_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-seat-reservation-scoped-width", `${this.width}`);
130
+ this.style?.setProperty("--sbb-seat-reservation-scoped-width", `${this.width}`);
132
131
  }
133
132
  if (_changedProperties.has("height")) {
134
- (_b = this.style) == null ? void 0 : _b.setProperty("--sbb-seat-reservation-scoped-height", `${this.height}`);
133
+ this.style?.setProperty("--sbb-seat-reservation-scoped-height", `${this.height}`);
135
134
  }
136
135
  if (_changedProperties.has("insetBlockStart")) {
137
- (_c = this.style) == null ? void 0 : _c.setProperty("--sbb-seat-reservation-scoped-inset-block-start", `${this.insetBlockStart}`);
136
+ this.style?.setProperty("--sbb-seat-reservation-scoped-inset-block-start", `${this.insetBlockStart}`);
138
137
  }
139
138
  if (_changedProperties.has("insetInlineStart")) {
140
- (_d = this.style) == null ? void 0 : _d.setProperty("--sbb-seat-reservation-scoped-inset-inline-start", `${this.insetInlineStart}`);
139
+ this.style?.setProperty("--sbb-seat-reservation-scoped-inset-inline-start", `${this.insetInlineStart}`);
141
140
  }
142
141
  if (_changedProperties.has("zIndex")) {
143
- (_e = this.style) == null ? void 0 : _e.setProperty("--sbb-seat-reservation-scoped-z-index", `${this.zIndex}`);
142
+ this.style?.setProperty("--sbb-seat-reservation-scoped-z-index", `${this.zIndex}`);
144
143
  }
145
144
  }
146
145
  render() {
@@ -193,4 +192,4 @@ let SbbSeatReservationScopedElement = (() => {
193
192
  export {
194
193
  SbbSeatReservationScopedElement
195
194
  };
196
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-scoped.component.js","sources":["../../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.ts"],"sourcesContent":["import { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport style from './seat-reservation-scoped.scss?lit&inline';\n\n/**\n * Wrapper class for scoped elements with similar properties to set.\n */\nexport\n@customElement('sbb-seat-reservation-scoped')\nclass SbbSeatReservationScopedElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Inset block start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-block-start' })\n  public accessor insetBlockStart: string = '';\n\n  /** Inset inline start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-inline-start' })\n  public accessor insetInlineStart: string = '';\n\n  /** Width of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width' })\n  public accessor width: string = '';\n\n  /** Height of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height' })\n  public accessor height: string = '';\n\n  /** Z-index of the scoped element */\n  @forceType()\n  @property({ attribute: 'z-index' })\n  public accessor zIndex: string = '';\n\n  /** Cell id of the scoped element, if it is used in a table */\n  @forceType()\n  @property({ attribute: 'cell-id' })\n  public accessor cellId: string = '';\n\n  /** Scoped classes for the scoped element */\n  @forceType()\n  @property({ attribute: 'scoped-classes' })\n  public accessor scopedClasses: string = '';\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n\n    if (_changedProperties.has('width')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('insetBlockStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-block-start',\n        `${this.insetBlockStart}`,\n      );\n    }\n\n    if (_changedProperties.has('insetInlineStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-inline-start',\n        `${this.insetInlineStart}`,\n      );\n    }\n\n    if (_changedProperties.has('zIndex')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-z-index', `${this.zIndex}`);\n    }\n  }\n\n  protected override render(): TemplateResult {\n    if (!this.cellId) {\n      return html`<div class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </div>`;\n    } else {\n      return html`<td id=\"${this.cellId}\" class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </td>`;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-scoped': SbbSeatReservationScopedElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
195
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-scoped.component.js","sources":["../../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.ts"],"sourcesContent":["import { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport style from './seat-reservation-scoped.scss?lit&inline';\n\n/**\n * Wrapper class for scoped elements with similar properties to set.\n */\nexport\n@customElement('sbb-seat-reservation-scoped')\nclass SbbSeatReservationScopedElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Inset block start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-block-start' })\n  public accessor insetBlockStart: string = '';\n\n  /** Inset inline start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-inline-start' })\n  public accessor insetInlineStart: string = '';\n\n  /** Width of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width' })\n  public accessor width: string = '';\n\n  /** Height of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height' })\n  public accessor height: string = '';\n\n  /** Z-index of the scoped element */\n  @forceType()\n  @property({ attribute: 'z-index' })\n  public accessor zIndex: string = '';\n\n  /** Cell id of the scoped element, if it is used in a table */\n  @forceType()\n  @property({ attribute: 'cell-id' })\n  public accessor cellId: string = '';\n\n  /** Scoped classes for the scoped element */\n  @forceType()\n  @property({ attribute: 'scoped-classes' })\n  public accessor scopedClasses: string = '';\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n\n    if (_changedProperties.has('width')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('insetBlockStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-block-start',\n        `${this.insetBlockStart}`,\n      );\n    }\n\n    if (_changedProperties.has('insetInlineStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-inline-start',\n        `${this.insetInlineStart}`,\n      );\n    }\n\n    if (_changedProperties.has('zIndex')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-z-index', `${this.zIndex}`);\n    }\n  }\n\n  protected override render(): TemplateResult {\n    if (!this.cellId) {\n      return html`<div class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </div>`;\n    } else {\n      return html`<td id=\"${this.cellId}\" class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </td>`;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-scoped': SbbSeatReservationScopedElement;\n  }\n}\n"],"names":[],"mappings":"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"}