@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
@@ -182,13 +182,12 @@ let SbbSeatReservationElement = (() => {
182
182
  __privateSet(this, _preventPlaceClick_accessor_storage, value);
183
183
  }
184
184
  willUpdate(changedProperties) {
185
- var _a2, _b;
186
185
  super.willUpdate(changedProperties);
187
186
  if (changedProperties.has("hasNavigation")) {
188
187
  if (this.hasNavigation) {
189
- (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelectorAll("table").forEach((table) => table.removeAttribute("tabindex"));
188
+ this.shadowRoot?.querySelectorAll("table").forEach((table) => table.removeAttribute("tabindex"));
190
189
  } else {
191
- (_b = this.shadowRoot) == null ? void 0 : _b.querySelectorAll("table").forEach((table) => table.setAttribute("tabindex", "0"));
190
+ this.shadowRoot?.querySelectorAll("table").forEach((table) => table.setAttribute("tabindex", "0"));
192
191
  }
193
192
  }
194
193
  }
@@ -204,8 +203,7 @@ let SbbSeatReservationElement = (() => {
204
203
  this.initNavigationSelectionByScrollEvent();
205
204
  }
206
205
  _initVehicleSeatReservationConstruction() {
207
- var _a2;
208
- const coachItems = JSON.parse(JSON.stringify((_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems));
206
+ const coachItems = JSON.parse(JSON.stringify(this.seatReservation?.coachItems));
209
207
  const classAlignVertical = this.alignVertical ? "sbb-sr__wrapper--vertical" : "";
210
208
  this._coachesHtmlTemplate = html`
211
209
  <div>
@@ -243,7 +241,6 @@ let SbbSeatReservationElement = (() => {
243
241
  `;
244
242
  }
245
243
  _renderNavigation() {
246
- var _a2;
247
244
  if (!this.hasNavigation) {
248
245
  return null;
249
246
  }
@@ -253,8 +250,7 @@ let SbbSeatReservationElement = (() => {
253
250
  class="sbb-sr-navigation__list-coaches"
254
251
  aria-label="${getI18nSeatReservation("SEAT_RESERVATION_NAVIGATION", this._language.current)}"
255
252
  >
256
- ${(_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems.map((coachItem, index) => {
257
- var _a3, _b;
253
+ ${this.seatReservation?.coachItems.map((coachItem, index) => {
258
254
  return html`<li>
259
255
  <sbb-seat-reservation-navigation-coach
260
256
  @selectCoach=${(event) => this._onSelectNavCoach(event)}
@@ -265,9 +261,9 @@ let SbbSeatReservationElement = (() => {
265
261
  .focused=${this.focusedCoachIndex === index}
266
262
  .propertyIds="${coachItem.propertyIds}"
267
263
  .travelClass="${coachItem.travelClass}"
268
- ?driver-area="${!((_a3 = coachItem.places) == null ? void 0 : _a3.length)}"
264
+ ?driver-area="${!coachItem.places?.length}"
269
265
  ?first="${index === 0}"
270
- ?last="${index === ((_b = this.seatReservation) == null ? void 0 : _b.coachItems.length) - 1}"
266
+ ?last="${index === this.seatReservation?.coachItems.length - 1}"
271
267
  ?vertical="${this.alignVertical}"
272
268
  >
273
269
  </sbb-seat-reservation-navigation-coach>
@@ -319,9 +315,9 @@ let SbbSeatReservationElement = (() => {
319
315
  _getRenderedCoachBorders(coachItem, coachIndex) {
320
316
  const allElements = coachItem.graphicElements;
321
317
  const COACH_PASSAGE_WIDTH = 1;
322
- const driverArea = allElements == null ? void 0 : allElements.find((element) => element.icon === "DRIVER_AREA_FULL");
318
+ const driverArea = allElements?.find((element) => element.icon === "DRIVER_AREA_FULL");
323
319
  const borderWidth = driverArea ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;
324
- const borderOffsetX = coachIndex === 0 && driverArea ? (driverArea == null ? void 0 : driverArea.dimension.w) * this.baseGridSize : this.baseGridSize;
320
+ const borderOffsetX = coachIndex === 0 && driverArea ? driverArea?.dimension.w * this.baseGridSize : this.baseGridSize;
325
321
  return html`
326
322
  <sbb-seat-reservation-scoped
327
323
  scoped-classes="coach-border"
@@ -360,7 +356,7 @@ let SbbSeatReservationElement = (() => {
360
356
  }
361
357
  _getRenderedColumnPlaces(places, coachIndex) {
362
358
  places.sort((placeA, placeB) => Number(placeA.position.x) - Number(placeB.position.x));
363
- return places == null ? void 0 : places.map((place, index) => {
359
+ return places?.map((place, index) => {
364
360
  const calculatedInternalDimension = this.getCalculatedDimension(place.dimension);
365
361
  const calculatedInternalPosition = this.getCalculatedPosition(place.position);
366
362
  const textRotation = this.alignVertical ? -90 : 0;
@@ -399,7 +395,7 @@ let SbbSeatReservationElement = (() => {
399
395
  if (!graphicalElements) {
400
396
  return null;
401
397
  }
402
- return graphicalElements == null ? void 0 : graphicalElements.map((graphicalElement) => {
398
+ return graphicalElements?.map((graphicalElement) => {
403
399
  const icon = graphicalElement.icon ?? "";
404
400
  const elementRotation = graphicalElement.rotation || 0;
405
401
  const isNotFixedRotationGraphicalElement = this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon) === -1;
@@ -411,8 +407,7 @@ let SbbSeatReservationElement = (() => {
411
407
  });
412
408
  }
413
409
  _getRenderElementWithArea(graphicalElement, rotation, coachDimension) {
414
- var _a2;
415
- const isNotTableGraphicTempFix = ((_a2 = graphicalElement.icon) == null ? void 0 : _a2.indexOf("TABLE")) === -1;
410
+ const isNotTableGraphicTempFix = graphicalElement.icon?.indexOf("TABLE") === -1;
416
411
  const areaProperty = graphicalElement.icon && isNotTableGraphicTempFix ? graphicalElement.icon : null;
417
412
  const stretchHeight = areaProperty !== "ENTRY_EXIT";
418
413
  const ariaLabelForArea = graphicalElement.icon ? getI18nSeatReservation(graphicalElement.icon, this._language.current) : nothing;
@@ -458,10 +453,9 @@ let SbbSeatReservationElement = (() => {
458
453
  `;
459
454
  }
460
455
  _getRenderElementWithoutArea(graphicalElement, rotation, coachDimension) {
461
- var _a2;
462
456
  const calculatedDimension = this.getCalculatedDimension(graphicalElement.dimension, coachDimension);
463
457
  const calculatedPosition = this.getCalculatedPosition(graphicalElement.position, graphicalElement.dimension, coachDimension);
464
- const icon = graphicalElement.icon && graphicalElement.icon.indexOf("DRIVER_AREA") === -1 ? graphicalElement.icon : (_a2 = graphicalElement.icon) == null ? void 0 : _a2.concat("_", this.seatReservation.vehicleType);
458
+ const icon = graphicalElement.icon && graphicalElement.icon.indexOf("DRIVER_AREA") === -1 ? graphicalElement.icon : graphicalElement.icon?.concat("_", this.seatReservation.vehicleType);
465
459
  return html`
466
460
  <sbb-seat-reservation-scoped
467
461
  scoped-classes="graphical-element"
@@ -486,7 +480,7 @@ let SbbSeatReservationElement = (() => {
486
480
  if (!serviceElements) {
487
481
  return null;
488
482
  }
489
- return serviceElements == null ? void 0 : serviceElements.map((serviceElement) => {
483
+ return serviceElements?.map((serviceElement) => {
490
484
  const titleDescription = serviceElement.icon ? getI18nSeatReservation(serviceElement.icon, this._language.current) : null;
491
485
  const calculatedcCmpartmentNumberDimension = this.getCalculatedDimension(serviceElement.dimension);
492
486
  const calculatedcCmpartmentNumberPosition = this.getCalculatedPosition(serviceElement.position);
@@ -548,8 +542,7 @@ let SbbSeatReservationElement = (() => {
548
542
  this.isAutoScrolling = false;
549
543
  }
550
544
  _getDescriptionTableCoach(coachItem) {
551
- var _a2;
552
- if (!((_a2 = coachItem.places) == null ? void 0 : _a2.length)) {
545
+ if (!coachItem.places?.length) {
553
546
  return getI18nSeatReservation("COACH_BLOCKED_TABLE_CAPTION", this._language.current, [
554
547
  coachItem.id
555
548
  ]);
@@ -568,7 +561,7 @@ let SbbSeatReservationElement = (() => {
568
561
  }
569
562
  _getTitleDescriptionListString(descriptionsElements) {
570
563
  const uniqueDescriptions = [];
571
- return descriptionsElements == null ? void 0 : descriptionsElements.map((descriptionElement) => {
564
+ return descriptionsElements?.map((descriptionElement) => {
572
565
  const icon = descriptionElement.icon;
573
566
  if (!icon)
574
567
  return null;
@@ -612,4 +605,4 @@ let SbbSeatReservationElement = (() => {
612
605
  export {
613
606
  SbbSeatReservationElement
614
607
  };
615
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { html, nothing } from 'lit';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.js';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n} from '../common.js';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.js';\nimport style from './seat-reservation.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-area.js';\nimport '../seat-reservation-graphic.js';\nimport '../seat-reservation-place-control.js';\nimport '../seat-reservation-navigation/seat-reservation-navigation-coach.js';\nimport './seat-reservation-scoped.js';\n\n/**\n * Describe the purpose of the component with a single short sentence.\n *\n * @event {CustomEvent<SeatReservationSelectedPlacesEventDetails>} selectedPlaces - Emits when a place was selected and returns a Place array with all selected places\n * @event {CustomEvent<SeatReservationCoachSelection>} selectedCoach - Emits when a coach was selected and returns a CoachSelection\n */\nexport\n@customElement('sbb-seat-reservation')\nclass SbbSeatReservationElement extends SeatReservationBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** The seat reservation object which contains all coaches and places */\n  @property({ attribute: 'seat-reservation', type: Object })\n  public override accessor seatReservation: SeatReservation = null!;\n\n  /** The seat reservation navigation can be toggled by this property */\n  @forceType()\n  @property({ attribute: 'has-navigation', type: Boolean })\n  public override accessor hasNavigation: boolean = true;\n\n  /** Controls the visual representation of seat reservation in a horizonal or vertical alignment */\n  @forceType()\n  @property({ attribute: 'align-vertical', type: Boolean })\n  public override accessor alignVertical: boolean = false;\n\n  /** Maximal number of possible clickable seats */\n  @forceType()\n  @property({ attribute: 'max-reservations', type: Number })\n  public override accessor maxReservations: number = null!;\n\n  /** Any click functionality is prevented */\n  @forceType()\n  @property({ attribute: 'prevent-place-click', type: Boolean })\n  public override accessor preventPlaceClick: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n  private _coachesHtmlTemplate?: TemplateResult;\n  // Graphics that should not be rendered with an area\n  private _notAreaElements = [\n    'DRIVER_AREA_FULL',\n    'COACH_PASSAGE',\n    'COACH_WALL_NO_PASSAGE',\n    'COMPARTMENT_PASSAGE',\n    'COMPARTMENT_PASSAGE_HIGH',\n    'COMPARTMENT_PASSAGE_MIDDLE',\n    'COMPARTMENT_PASSAGE_LOW',\n  ];\n  // Area icons that should not be fixed during rotation when vertical mode is selected\n  private _notFixedRotatableAreaIcons = ['ENTRY_EXIT'];\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hasNavigation')) {\n      if (this.hasNavigation) {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.removeAttribute('tabindex'));\n      } else {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.setAttribute('tabindex', '0'));\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._componentSetup();\n  }\n\n  protected override render(): TemplateResult | null {\n    this._initVehicleSeatReservationConstruction();\n    return this._coachesHtmlTemplate || null;\n  }\n\n  private _componentSetup(): void {\n    this.initNavigationSelectionByScrollEvent();\n  }\n\n  private _initVehicleSeatReservationConstruction(): void {\n    const coachItems = JSON.parse(JSON.stringify(this.seatReservation?.coachItems));\n    const classAlignVertical = this.alignVertical ? 'sbb-sr__wrapper--vertical' : '';\n\n    this._coachesHtmlTemplate = html`\n      <div>\n        <sbb-screen-reader-only>\n          <input\n            id=\"first-tab-element\"\n            role=\"contentinfo\"\n            type=\"text\"\n            aria-label=\"${getI18nSeatReservation('SEAT_RESERVATION_BEGIN', this._language.current)}\"\n            readonly\n          />\n        </sbb-screen-reader-only>\n\n        <div @keydown=${(evt: KeyboardEvent) => this.handleKeyboardEvent(evt)}>\n          ${this._renderNavigation()}\n          <div class=\"sbb-sr__wrapper ${classAlignVertical}\">\n            <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\" tabindex=\"-1\">\n              <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                ${this._renderCoaches(coachItems)}\n              </ul>\n            </div>\n          </div>\n        </div>\n\n        <sbb-screen-reader-only>\n          <input\n            id=\"last-tab-element\"\n            role=\"contentinfo\"\n            type=\"text\"\n            aria-label=\"${getI18nSeatReservation('SEAT_RESERVATION_END', this._language.current)}\"\n            readonly\n          />\n        </sbb-screen-reader-only>\n      </div>\n    `;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation) {\n      return null;\n    }\n\n    return html`\n      <nav class=\"${classMap({ 'sbb-sr-navigation--vertical': this.alignVertical })}\">\n        <ul\n          class=\"sbb-sr-navigation__list-coaches\"\n          aria-label=\"${getI18nSeatReservation(\n            'SEAT_RESERVATION_NAVIGATION',\n            this._language.current,\n          )}\"\n        >\n          ${this.seatReservation?.coachItems.map((coachItem: CoachItem, index: number) => {\n            return html`<li>\n              <sbb-seat-reservation-navigation-coach\n                @selectCoach=${(event: CustomEvent) => this._onSelectNavCoach(event)}\n                @focusCoach=${() => this._onFocusNavCoach()}\n                index=\"${index}\"\n                coach-id=\"${coachItem.id}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\n                .propertyIds=\"${coachItem.propertyIds}\"\n                .travelClass=\"${coachItem.travelClass}\"\n                ?driver-area=\"${!coachItem.places?.length}\"\n                ?first=\"${index === 0}\"\n                ?last=\"${index === this.seatReservation?.coachItems.length - 1}\"\n                ?vertical=\"${this.alignVertical}\"\n              >\n              </sbb-seat-reservation-navigation-coach>\n            </li>`;\n          })}\n        </ul>\n      </nav>\n    `;\n  }\n  /**\n   *\n   * @param coaches\n   * @returns\n   */\n  private _renderCoaches(coaches?: CoachItem[]): TemplateResult[] | null {\n    if (!coaches) {\n      return null;\n    }\n    return coaches.map((coachItem: CoachItem, index: number) => {\n      return html`\n        <li class=\"sbb-sr__item-coach\">${this._renderCoachElement(coachItem, index)}</li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(coachItem: CoachItem, index: number): TemplateResult {\n    const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);\n    const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);\n\n    return html` <sbb-seat-reservation-scoped\n      scoped-classes=\"coach-wrapper\"\n      height=\"${calculatedCoachDimension.h}px\"\n      width=\"${calculatedCoachDimension.w}px\"\n    >\n      ${this._getRenderedCoachBorders(coachItem, index)}\n      ${this._getRenderedGraphicalElements(coachItem.graphicElements || [], coachItem.dimension)}\n      ${this._getRenderedServiceElements(coachItem.serviceElements)}\n      <table\n        @focus=${() => this.onFocusTableCoachAndPreselectPlace(index)}\n        id=\"sbb-sr-coach-${index}\"\n        class=\"sbb-sr-coach-wrapper__table\"\n        aria-describedby=\"sbb-sr-coach-caption-${index}\"\n      >\n        <caption id=\"sbb-sr-coach-caption-${index}\" tabindex=\"-1\">\n          <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>\n        </caption>\n        ${this._getRenderedRowPlaces(coachItem, index)}\n      </table>\n    </sbb-seat-reservation-scoped>`;\n  }\n\n  private _getRenderedCoachBorders(coachItem: CoachItem, coachIndex: number): TemplateResult {\n    const allElements = coachItem.graphicElements;\n    const COACH_PASSAGE_WIDTH = 1;\n    const driverArea = allElements?.find(\n      (element: BaseElement) => element.icon === 'DRIVER_AREA_FULL',\n    );\n    const borderWidth = driverArea\n      ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH\n      : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;\n    const borderOffsetX =\n      coachIndex === 0 && driverArea\n        ? driverArea?.dimension.w * this.baseGridSize\n        : this.baseGridSize;\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"coach-border\"\n        inset-block-start=\"${this.coachBorderPadding * -1}px\"\n        inset-inline-start=\"${borderOffsetX}px\"\n      >\n        <sbb-seat-reservation-graphic\n          name=\"COACH_BORDER_MIDDLE\"\n          width=${borderWidth * this.baseGridSize}\n          height=${(coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize}\n          ?stretch=${true}\n          role=\"presentation\"\n        ></sbb-seat-reservation-graphic>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderedRowPlaces(coach: CoachItem, coachIndex: number): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepair rows with the places to render a table\n    const tableRowPlaces: Record<number, Place[]> = {};\n    for (const place of coach.places) {\n      if (!tableRowPlaces[place.position.y]) {\n        tableRowPlaces[place.position.y] = [place];\n      } else {\n        tableRowPlaces[place.position.y].push(place);\n      }\n    }\n\n    return Object.values(tableRowPlaces)\n      .map((rowPlaces: Place[], index) => {\n        return html`\n          <tr id=\"row-${coachIndex}-${rowPlaces[0].position.y}\" data-row-index=${index}>\n            ${this._getRenderedColumnPlaces(rowPlaces, coachIndex)}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(places: Place[], coachIndex: number): TemplateResult[] | null {\n    //Sorts each place by its ascending x coordinate\n    places.sort(\n      (placeA: Place, placeB: Place) => Number(placeA.position.x) - Number(placeB.position.x),\n    );\n\n    return places?.map((place: Place, index: number) => {\n      const calculatedInternalDimension = this.getCalculatedDimension(place.dimension);\n      const calculatedInternalPosition = this.getCalculatedPosition(place.position);\n      const textRotation = this.alignVertical ? -90 : 0;\n\n      return html`\n        <sbb-seat-reservation-scoped\n          scoped-classes=\"graphical-element\"\n          inset-block-start=\"${calculatedInternalPosition.y}px\"\n          inset-inline-start=\"${calculatedInternalPosition.x}px\"\n          width=\"${calculatedInternalDimension.w}px\"\n          height=\"${calculatedInternalDimension.h}px\"\n          z-index=\"${place.position.z}\"\n          cell-id=\"cell-${coachIndex}-${place.position.y}-${index}\"\n        >\n          <sbb-seat-reservation-place-control\n            @selectPlace=${(selectPlaceEvent: CustomEvent) => this._onSelectPlace(selectPlaceEvent)}\n            exportparts=\"sbb-sr-place-part\"\n            id=\"seat-reservation__place-button-${coachIndex}-${place.number}\"\n            class=\"seat-reservation-place-control\"\n            data-cell-id=\"${coachIndex}-${place.position.y}-${index}\"\n            text=${place.number}\n            type=${place.type}\n            state=${place.state}\n            width=${place.dimension.w * this.baseGridSize}\n            height=${place.dimension.h * this.baseGridSize}\n            rotation=${place.rotation ?? nothing}\n            text-rotation=${textRotation}\n            coach-index=${coachIndex}\n            .propertyIds=${place.propertyIds}\n            .preventClick=${this.preventPlaceClick}\n          ></sbb-seat-reservation-place-control>\n        </sbb-seat-reservation-scoped>\n      `;\n    });\n  }\n\n  private _getRenderedGraphicalElements(\n    graphicalElements: BaseElement[],\n    coachDimension: ElementDimension,\n  ): TemplateResult[] | null {\n    if (!graphicalElements) {\n      return null;\n    }\n\n    return graphicalElements?.map((graphicalElement: BaseElement) => {\n      const icon = graphicalElement.icon ?? '';\n      const elementRotation = graphicalElement.rotation || 0;\n      const isNotFixedRotationGraphicalElement =\n        this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon!) === -1;\n      const elementFixedRotation =\n        this.alignVertical && isNotFixedRotationGraphicalElement\n          ? elementRotation - 90\n          : elementRotation;\n\n      //check if the current element is not an area element, since this element is drawn without an area component\n      if (this._notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {\n        return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);\n      }\n      return this._getRenderElementWithArea(graphicalElement, elementFixedRotation, coachDimension);\n    });\n  }\n\n  private _getRenderElementWithArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    // TODO -> isNotTableGraphicTempFix is temp fix to show coach tables as area and not as svg graphic.\n    // The problem here is that when using TABLE svg graphics,\n    // they are displayed distorted due to different heights and widths and this is not visually good.\n    const isNotTableGraphicTempFix = graphicalElement.icon?.indexOf('TABLE') === -1;\n\n    const areaProperty =\n      graphicalElement.icon && isNotTableGraphicTempFix ? graphicalElement.icon : null;\n    const stretchHeight = areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n    );\n\n    let elementMounting = 'free';\n    if (graphicalElement.position.y === this.coachBorderOffset * -1) {\n      elementMounting = 'upper-border';\n    } else if (\n      graphicalElement.position.y + graphicalElement.dimension.h ===\n      coachDimension.h + this.coachBorderOffset\n    ) {\n      elementMounting = 'lower-border';\n    }\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"graphical-element\"\n        inset-block-start=\"${calculatedPosition.y}px\"\n        inset-inline-start=\"${calculatedPosition.x}px\"\n        width=\"${calculatedDimension.w}px\"\n        height=\"${calculatedDimension.h}px\"\n        z-index=\"${graphicalElement.position.z}\"\n      >\n        <sbb-seat-reservation-area\n          style=${styleMap({\n            '--sbb-reservation-area-width': graphicalElement.dimension.w * this.baseGridSize,\n            '--sbb-reservation-area-height': graphicalElement.dimension.h * this.baseGridSize,\n          })}\n          mounting=${elementMounting}\n          background=\"dark\"\n          aria-hidden=\"true\"\n          title=${ariaLabelForArea}\n        >\n          ${areaProperty\n            ? html`\n                <sbb-seat-reservation-graphic\n                  name=${areaProperty}\n                  rotation=${rotation}\n                  width=${this.baseGridSize}\n                  height=${this.baseGridSize}\n                  role=\"img\"\n                  aria-hidden=\"true\"\n                ></sbb-seat-reservation-graphic>\n              `\n            : nothing}\n        </sbb-seat-reservation-area>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderElementWithoutArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n    );\n\n    // If the icon is the driver area, then here concat the vehicle type to get the right vehicle chassie icon\n    const icon =\n      graphicalElement.icon && graphicalElement.icon.indexOf('DRIVER_AREA') === -1\n        ? graphicalElement.icon\n        : graphicalElement.icon?.concat('_', this.seatReservation.vehicleType);\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"graphical-element\"\n        inset-block-start=\"${calculatedPosition.y}px\"\n        inset-inline-start=\"${calculatedPosition.x}px\"\n        width=\"${calculatedDimension.w}px\"\n        height=\"${calculatedDimension.h}px\"\n        z-index=\"${graphicalElement.position.z}\"\n      >\n        <sbb-seat-reservation-graphic\n          name=${icon ?? nothing}\n          width=${graphicalElement.dimension.w * this.baseGridSize}\n          height=${graphicalElement.dimension.h * this.baseGridSize}\n          rotation=${rotation}\n          aria-hidden=\"true\"\n          ?stretch=${true}\n        ></sbb-seat-reservation-graphic>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderedServiceElements(serviceElements?: BaseElement[]): TemplateResult[] | null {\n    if (!serviceElements) {\n      return null;\n    }\n\n    return serviceElements?.map((serviceElement: BaseElement) => {\n      const titleDescription = serviceElement.icon\n        ? getI18nSeatReservation(serviceElement.icon, this._language.current)\n        : null;\n      const calculatedcCmpartmentNumberDimension = this.getCalculatedDimension(\n        serviceElement.dimension,\n      );\n      const calculatedcCmpartmentNumberPosition = this.getCalculatedPosition(\n        serviceElement.position,\n      );\n      const elementRotation = serviceElement.rotation || 0;\n      const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;\n\n      return html`\n        <sbb-seat-reservation-scoped\n          scoped-classes=\"graphical-element\"\n          inset-block-start=\"${calculatedcCmpartmentNumberPosition.y}px\"\n          inset-inline-start=\"${calculatedcCmpartmentNumberPosition.x}px\"\n          width=\"${calculatedcCmpartmentNumberDimension.w}px\"\n          height=\"${calculatedcCmpartmentNumberDimension.h}px\"\n          z-index=\"${serviceElement.position.z}\"\n        >\n          <sbb-seat-reservation-graphic\n            name=${serviceElement.icon ?? nothing}\n            width=${serviceElement.dimension.w * this.baseGridSize}\n            height=${serviceElement.dimension.h * this.baseGridSize}\n            .rotation=${elementFixedRotation}\n            role=\"img\"\n            aria-hidden=\"true\"\n            title=${titleDescription ?? nothing}\n          ></sbb-seat-reservation-graphic>\n        </sbb-seat-reservation-scoped>\n      `;\n    });\n  }\n\n  /**\n   * Manages the selected place event triggered from the place\n   * Each selection emits an array of all selected places\n   * @param selectPlaceEvent\n   */\n  private _onSelectPlace(selectPlaceEvent: CustomEvent): void {\n    const selectedPlace = selectPlaceEvent.detail as PlaceSelection;\n    // We have to set preventCoachScrollByPlaceClick to true, to prevent automatic scrolling to the new focused place\n    this.preventCoachScrollByPlaceClick = true;\n    this.isCoachGridFocusable = false;\n    if (!this.preventPlaceClick) {\n      // Add place to place collection\n      this.updateSelectedSeatReservationPlaces(selectedPlace);\n      this.updateCurrentSelectedPlaceInCoach(selectedPlace);\n    }\n  }\n\n  private _onSelectNavCoach(event: CustomEvent): void {\n    const selectedNavCoachIndex = event.detail as number;\n    this.isKeyboardNavigation = false;\n\n    if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.unfocusPlaceElement();\n      this.scrollToSelectedNavCoach(selectedNavCoachIndex);\n    } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n      this.preselectPlaceInCoach();\n    }\n  }\n\n  private _onFocusNavCoach(): void {\n    if (!this.preventCoachScrollByPlaceClick) {\n      this.preselectPlaceInCoach();\n    } else {\n      this.focusPlaceElement(this.currSelectedPlace);\n    }\n    this.isAutoScrolling = false;\n  }\n\n  private _getDescriptionTableCoach(coachItem: CoachItem): string {\n    if (!coachItem.places?.length) {\n      return getI18nSeatReservation('COACH_BLOCKED_TABLE_CAPTION', this._language.current, [\n        coachItem.id,\n      ]);\n    }\n\n    let tableCoachDescription = '';\n    const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements!);\n    const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements!);\n\n    tableCoachDescription = getI18nSeatReservation('COACH_TABLE_CAPTION', this._language.current, [\n      coachItem.id,\n    ]);\n\n    if (!!areaDescriptions || !!serviceDescriptions) {\n      tableCoachDescription +=\n        '. ' + getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      tableCoachDescription += serviceDescriptions + ', ' + areaDescriptions + '.';\n    }\n    return tableCoachDescription;\n  }\n\n  private _getTitleDescriptionListString(descriptionsElements: BaseElement[]): string {\n    const uniqueDescriptions: string[] = [];\n\n    return descriptionsElements\n      ?.map((descriptionElement) => {\n        const icon = descriptionElement.icon;\n        if (!icon) return null;\n\n        const descriptionAlreayExist = uniqueDescriptions.indexOf(icon) > -1;\n        const translation = getI18nSeatReservation(\n          descriptionElement.icon!,\n          this._language.current,\n        );\n        const isValidDescription =\n          this._notFixedRotatableAreaIcons.indexOf(icon) === -1 &&\n          this._notAreaElements.indexOf(icon) === -1;\n\n        if (!descriptionAlreayExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreayExist && isValidDescription ? translation : null;\n      })\n      .filter((description) => !!description)\n      .join(', ');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation': SbbSeatReservationElement;\n  }\n}\n"],"names":["_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAoCM,6BAAyB,MAAA;;0BAD9B,cAAc,sBAAsB,CAAC;;;;oBACE;;;;;;;;;;;;;;;;AAAR,EAAA,mBAAQ,YAA0B;AAAA;;AAKhE;AAKA;AAKA;AAKA;AAKA;AApByB,yBAAA,mCAAA,kBAAA,MAAA,+BAAmC,IAAK;AAKxC,yBAAA,kCAAA,kBAAA,MAAA,kCAAA,GAAA,kBAAA,MAAA,6BAAyB,IAAI;AAK7B,yBAAA,kCAAA,kBAAA,MAAA,gCAAA,GAAA,kBAAA,MAAA,6BAAyB,KAAK;AAK9B,yBAAA,oCAAA,kBAAA,MAAA,gCAAA,GAAA,kBAAA,MAAA,+BAA0B,IAAK;AAK/B,yBAAA,sCAAA,kBAAA,MAAA,kCAAA,GAAA,kBAAA,MAAA,iCAA6B,KAAK;AAEnD,WAAA,4EAAY,IAAI,sBAAsB,IAAI;AAG1C,WAAA,mBAAmB;AAAA,QACzB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA;AAGM,WAAA,8BAA8B,CAAC,YAAY;AAAA,IAAA;AAAA;AAAA,IAnCnD,IAAyB,kBAAyC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAlE,IAAyB,gBAAyC,OAAA;AAAA,yBAAA,mCAAA;AAAA,IAAA;AAAA;AAAA,IAKlE,IAAyB,gBAA8B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvD,IAAyB,cAA8B,OAAA;AAAA,yBAAA,iCAAA;AAAA,IAAA;AAAA;AAAA,IAKvD,IAAyB,gBAA+B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxD,IAAyB,cAA+B,OAAA;AAAA,yBAAA,iCAAA;AAAA,IAAA;AAAA;AAAA,IAKxD,IAAyB,kBAAgC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAzD,IAAyB,gBAAgC,OAAA;AAAA,yBAAA,mCAAA;AAAA,IAAA;AAAA;AAAA,IAKzD,IAAyB,oBAAmC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA5D,IAAyB,kBAAmC,OAAA;AAAA,yBAAA,qCAAA;AAAA,IAAA;AAAA,IAiBzC,WAAW,mBAAuC;;AACnE,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,eAAe,GAAG;AAC1C,YAAI,KAAK,eAAe;AACjB,WAAAA,MAAA,KAAA,eAAA,gBAAAA,IACD,iBAAiB,SAClB,QAAQ,CAAC,UAAU,MAAM,gBAAgB,UAAU;AAAA,QAAC,OAClD;AACA,qBAAA,eAAA,mBACD,iBAAiB,SAClB,QAAQ,CAAC,UAAU,MAAM,aAAa,YAAY,GAAG;AAAA,QAAC;AAAA,MAC3D;AAAA,IACF;AAAA,IAGiB,aAAa,mBAAuC;AACrE,YAAM,aAAa,iBAAiB;AACpC,WAAK,gBAAe;AAAA,IAAA;AAAA,IAGH,SAAM;AACvB,WAAK,wCAAuC;AAC5C,aAAO,KAAK,wBAAwB;AAAA,IAAA;AAAA,IAG9B,kBAAe;AACrB,WAAK,qCAAoC;AAAA,IAAA;AAAA,IAGnC,0CAAuC;;AACvC,YAAA,aAAa,KAAK,MAAM,KAAK,WAAUA,MAAA,KAAK,oBAAL,gBAAAA,IAAsB,UAAU,CAAC;AACxE,YAAA,qBAAqB,KAAK,gBAAgB,8BAA8B;AAE9E,WAAK,uBAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAON,uBAAuB,0BAA0B,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,wBAK1E,CAAC,QAAuB,KAAK,oBAAoB,GAAG,CAAC;AAAA,YACjE,KAAK,kBAAmB,CAAA;AAAA,wCACI,kBAAkB;AAAA;AAAA;AAAA,kBAGxC,KAAK,eAAe,UAAU,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAWvB,uBAAuB,wBAAwB,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,IAQtF,oBAAiB;;AACnB,UAAA,CAAC,KAAK,eAAe;AAChB,eAAA;AAAA,MAAA;AAGF,aAAA;AAAA,oBACS,SAAS,EAAE,+BAA+B,KAAK,cAAe,CAAA,CAAC;AAAA;AAAA;AAAA,wBAG3D,uBACZ,+BACA,KAAK,UAAU,OAAO,CACvB;AAAA;AAAA,aAECA,MAAA,KAAK,oBAAL,gBAAAA,IAAsB,WAAW,IAAI,CAAC,WAAsB,UAAiB;;AACtE,eAAA;AAAA;AAAA,+BAEY,CAAC,UAAuB,KAAK,kBAAkB,KAAK,CAAC;AAAA,8BACtD,MAAM,KAAK,iBAAkB,CAAA;AAAA,yBAClC,KAAK;AAAA,4BACF,UAAU,EAAE;AAAA,4BACZ,KAAK,uBAAuB,KAAK;AAAA,2BAClC,KAAK,sBAAsB,KAAK;AAAA,gCAC3B,UAAU,WAAW;AAAA,gCACrB,UAAU,WAAW;AAAA,gCACrB,GAACA,MAAA,UAAU,WAAV,gBAAAA,IAAkB,OAAM;AAAA,0BAC/B,UAAU,CAAC;AAAA,yBACZ,YAAU,UAAK,oBAAL,mBAAsB,WAAW,UAAS,CAAC;AAAA,6BACjD,KAAK,aAAa;AAAA;AAAA;AAAA;AAAA,MAAA,EAInC;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUF,eAAe,SAAqB;AAC1C,UAAI,CAAC,SAAS;AACL,eAAA;AAAA,MAAA;AAET,aAAO,QAAQ,IAAI,CAAC,WAAsB,UAAiB;AAClD,eAAA;AAAA,yCAC4B,KAAK,oBAAoB,WAAW,KAAK,CAAC;AAAA;AAAA,MAAA,CAE9E;AAAA,IAAA;AAAA,IAGK,oBAAoB,WAAsB,OAAa;AAC7D,YAAM,2BAA2B,KAAK,uBAAuB,UAAU,SAAS;AAC1E,YAAA,oCAAoC,KAAK,0BAA0B,SAAS;AAE3E,aAAA;AAAA;AAAA,gBAEK,yBAAyB,CAAC;AAAA,eAC3B,yBAAyB,CAAC;AAAA;AAAA,QAEjC,KAAK,yBAAyB,WAAW,KAAK,CAAC;AAAA,QAC/C,KAAK,8BAA8B,UAAU,mBAAmB,CAAI,GAAA,UAAU,SAAS,CAAC;AAAA,QACxF,KAAK,4BAA4B,UAAU,eAAe,CAAC;AAAA;AAAA,iBAElD,MAAM,KAAK,mCAAmC,KAAK,CAAC;AAAA,2BAC1C,KAAK;AAAA;AAAA,iDAEiB,KAAK;AAAA;AAAA,4CAEV,KAAK;AAAA,oCACb,iCAAiC;AAAA;AAAA,UAE3D,KAAK,sBAAsB,WAAW,KAAK,CAAC;AAAA;AAAA;AAAA,IAAA;AAAA,IAK5C,yBAAyB,WAAsB,YAAkB;AACvE,YAAM,cAAc,UAAU;AAC9B,YAAM,sBAAsB;AAC5B,YAAM,aAAa,2CAAa,KAC9B,CAAC,YAAyB,QAAQ,SAAS;AAE7C,YAAM,cAAc,aAChB,UAAU,UAAU,IAAI,WAAW,UAAU,IAAI,sBACjD,UAAU,UAAU,IAAI,sBAAsB;AAC5C,YAAA,gBACJ,eAAe,KAAK,cAChB,yCAAY,UAAU,KAAI,KAAK,eAC/B,KAAK;AAEJ,aAAA;AAAA;AAAA;AAAA,6BAGkB,KAAK,qBAAqB,EAAE;AAAA,8BAC3B,aAAa;AAAA;AAAA;AAAA;AAAA,kBAIzB,cAAc,KAAK,YAAY;AAAA,oBAC7B,UAAU,UAAU,IAAI,KAAK,oBAAoB,KAAK,KAAK,YAAY;AAAA,qBACtE,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,IAOf,sBAAsB,OAAkB,YAAkB;AAC5D,UAAA,CAAC,MAAM,QAAQ;AACV,eAAA;AAAA,MAAA;AAIT,YAAM,iBAA0C,CAAA;AACrC,iBAAA,SAAS,MAAM,QAAQ;AAChC,YAAI,CAAC,eAAe,MAAM,SAAS,CAAC,GAAG;AACrC,yBAAe,MAAM,SAAS,CAAC,IAAI,CAAC,KAAK;AAAA,QAAA,OACpC;AACL,yBAAe,MAAM,SAAS,CAAC,EAAE,KAAK,KAAK;AAAA,QAAA;AAAA,MAC7C;AAGF,aAAO,OAAO,OAAO,cAAc,EAChC,IAAI,CAAC,WAAoB,UAAS;AAC1B,eAAA;AAAA,wBACS,UAAU,IAAI,UAAU,CAAC,EAAE,SAAS,CAAC,oBAAoB,KAAK;AAAA,cACxE,KAAK,yBAAyB,WAAW,UAAU,CAAC;AAAA;AAAA;AAAA,MAG3D,CAAA,EACA,QAAQ,CAAC,gBAAgB,WAAW;AAAA,IAAA;AAAA,IAGjC,yBAAyB,QAAiB,YAAkB;AAElE,aAAO,KACL,CAAC,QAAe,WAAkB,OAAO,OAAO,SAAS,CAAC,IAAI,OAAO,OAAO,SAAS,CAAC,CAAC;AAGzF,aAAO,iCAAQ,IAAI,CAAC,OAAc,UAAiB;AACjD,cAAM,8BAA8B,KAAK,uBAAuB,MAAM,SAAS;AAC/E,cAAM,6BAA6B,KAAK,sBAAsB,MAAM,QAAQ;AACtE,cAAA,eAAe,KAAK,gBAAgB,MAAM;AAEzC,eAAA;AAAA;AAAA;AAAA,+BAGkB,2BAA2B,CAAC;AAAA,gCAC3B,2BAA2B,CAAC;AAAA,mBACzC,4BAA4B,CAAC;AAAA,oBAC5B,4BAA4B,CAAC;AAAA,qBAC5B,MAAM,SAAS,CAAC;AAAA,0BACX,UAAU,IAAI,MAAM,SAAS,CAAC,IAAI,KAAK;AAAA;AAAA;AAAA,2BAGtC,CAAC,qBAAkC,KAAK,eAAe,gBAAgB,CAAC;AAAA;AAAA,iDAElD,UAAU,IAAI,MAAM,MAAM;AAAA;AAAA,4BAE/C,UAAU,IAAI,MAAM,SAAS,CAAC,IAAI,KAAK;AAAA,mBAChD,MAAM,MAAM;AAAA,mBACZ,MAAM,IAAI;AAAA,oBACT,MAAM,KAAK;AAAA,oBACX,MAAM,UAAU,IAAI,KAAK,YAAY;AAAA,qBACpC,MAAM,UAAU,IAAI,KAAK,YAAY;AAAA,uBACnC,MAAM,YAAY,OAAO;AAAA,4BACpB,YAAY;AAAA,0BACd,UAAU;AAAA,2BACT,MAAM,WAAW;AAAA,4BAChB,KAAK,iBAAiB;AAAA;AAAA;AAAA;AAAA,MAAA;AAAA,IAI7C;AAAA,IAGK,8BACN,mBACA,gBAAgC;AAEhC,UAAI,CAAC,mBAAmB;AACf,eAAA;AAAA,MAAA;AAGF,aAAA,uDAAmB,IAAI,CAAC,qBAAiC;AACxD,cAAA,OAAO,iBAAiB,QAAQ;AAChC,cAAA,kBAAkB,iBAAiB,YAAY;AACrD,cAAM,qCACJ,KAAK,4BAA4B,QAAQ,iBAAiB,IAAK,MAAM;AACvE,cAAM,uBACJ,KAAK,iBAAiB,qCAClB,kBAAkB,KAClB;AAGF,YAAA,KAAK,iBAAiB,UAAU,CAAC,mBAAmB,mBAAmB,IAAI,IAAI,IAAI;AACrF,iBAAO,KAAK,6BAA6B,kBAAkB,iBAAiB,cAAc;AAAA,QAAA;AAE5F,eAAO,KAAK,0BAA0B,kBAAkB,sBAAsB,cAAc;AAAA,MAAA;AAAA,IAC7F;AAAA,IAGK,0BACN,kBACA,UACA,gBAAgC;;AAKhC,YAAM,6BAA2BA,MAAA,iBAAiB,SAAjB,gBAAAA,IAAuB,QAAQ,cAAa;AAE7E,YAAM,eACJ,iBAAiB,QAAQ,2BAA2B,iBAAiB,OAAO;AAC9E,YAAM,gBAAgB,iBAAiB;AACjC,YAAA,mBAAmB,iBAAiB,OACtC,uBAAuB,iBAAiB,MAAM,KAAK,UAAU,OAAO,IACpE;AACJ,YAAM,sBAAsB,KAAK,uBAC/B,iBAAiB,WACjB,gBACA,MACA,aAAa;AAET,YAAA,qBAAqB,KAAK,sBAC9B,iBAAiB,UACjB,iBAAiB,WACjB,gBACA,IAAI;AAGN,UAAI,kBAAkB;AACtB,UAAI,iBAAiB,SAAS,MAAM,KAAK,oBAAoB,IAAI;AAC7C,0BAAA;AAAA,MACpB,WACE,iBAAiB,SAAS,IAAI,iBAAiB,UAAU,MACzD,eAAe,IAAI,KAAK,mBACxB;AACkB,0BAAA;AAAA,MAAA;AAGb,aAAA;AAAA;AAAA;AAAA,6BAGkB,mBAAmB,CAAC;AAAA,8BACnB,mBAAmB,CAAC;AAAA,iBACjC,oBAAoB,CAAC;AAAA,kBACpB,oBAAoB,CAAC;AAAA,mBACpB,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA,kBAG5B,SAAS;AAAA,QACf,gCAAgC,iBAAiB,UAAU,IAAI,KAAK;AAAA,QACpE,iCAAiC,iBAAiB,UAAU,IAAI,KAAK;AAAA,MAAA,CACtE,CAAC;AAAA,qBACS,eAAe;AAAA;AAAA;AAAA,kBAGlB,gBAAgB;AAAA;AAAA,YAEtB,eACE;AAAA;AAAA,yBAEW,YAAY;AAAA,6BACR,QAAQ;AAAA,0BACX,KAAK,YAAY;AAAA,2BAChB,KAAK,YAAY;AAAA;AAAA;AAAA;AAAA,kBAK9B,OAAO;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,IAMX,6BACN,kBACA,UACA,gBAAgC;;AAEhC,YAAM,sBAAsB,KAAK,uBAC/B,iBAAiB,WACjB,cAAc;AAEhB,YAAM,qBAAqB,KAAK,sBAC9B,iBAAiB,UACjB,iBAAiB,WACjB,cAAc;AAIhB,YAAM,OACJ,iBAAiB,QAAQ,iBAAiB,KAAK,QAAQ,aAAa,MAAM,KACtE,iBAAiB,QACjBA,MAAA,iBAAiB,SAAjB,gBAAAA,IAAuB,OAAO,KAAK,KAAK,gBAAgB;AAEvD,aAAA;AAAA;AAAA;AAAA,6BAGkB,mBAAmB,CAAC;AAAA,8BACnB,mBAAmB,CAAC;AAAA,iBACjC,oBAAoB,CAAC;AAAA,kBACpB,oBAAoB,CAAC;AAAA,mBACpB,iBAAiB,SAAS,CAAC;AAAA;AAAA;AAAA,iBAG7B,QAAQ,OAAO;AAAA,kBACd,iBAAiB,UAAU,IAAI,KAAK,YAAY;AAAA,mBAC/C,iBAAiB,UAAU,IAAI,KAAK,YAAY;AAAA,qBAC9C,QAAQ;AAAA;AAAA,qBAER,IAAI;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,IAMf,4BAA4B,iBAA+B;AACjE,UAAI,CAAC,iBAAiB;AACb,eAAA;AAAA,MAAA;AAGF,aAAA,mDAAiB,IAAI,CAAC,mBAA+B;AACpD,cAAA,mBAAmB,eAAe,OACpC,uBAAuB,eAAe,MAAM,KAAK,UAAU,OAAO,IAClE;AACJ,cAAM,uCAAuC,KAAK,uBAChD,eAAe,SAAS;AAE1B,cAAM,sCAAsC,KAAK,sBAC/C,eAAe,QAAQ;AAEnB,cAAA,kBAAkB,eAAe,YAAY;AACnD,cAAM,uBAAuB,KAAK,gBAAgB,kBAAkB,KAAK;AAElE,eAAA;AAAA;AAAA;AAAA,+BAGkB,oCAAoC,CAAC;AAAA,gCACpC,oCAAoC,CAAC;AAAA,mBAClD,qCAAqC,CAAC;AAAA,oBACrC,qCAAqC,CAAC;AAAA,qBACrC,eAAe,SAAS,CAAC;AAAA;AAAA;AAAA,mBAG3B,eAAe,QAAQ,OAAO;AAAA,oBAC7B,eAAe,UAAU,IAAI,KAAK,YAAY;AAAA,qBAC7C,eAAe,UAAU,IAAI,KAAK,YAAY;AAAA,wBAC3C,oBAAoB;AAAA;AAAA;AAAA,oBAGxB,oBAAoB,OAAO;AAAA;AAAA;AAAA;AAAA,MAAA;AAAA,IAI1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQK,eAAe,kBAA6B;AAClD,YAAM,gBAAgB,iBAAiB;AAEvC,WAAK,iCAAiC;AACtC,WAAK,uBAAuB;AACxB,UAAA,CAAC,KAAK,mBAAmB;AAE3B,aAAK,oCAAoC,aAAa;AACtD,aAAK,kCAAkC,aAAa;AAAA,MAAA;AAAA,IACtD;AAAA,IAGM,kBAAkB,OAAkB;AAC1C,YAAM,wBAAwB,MAAM;AACpC,WAAK,uBAAuB;AAE5B,UAAI,0BAA0B,QAAQ,0BAA0B,KAAK,wBAAwB;AAC3F,aAAK,oBAAmB;AACxB,aAAK,yBAAyB,qBAAqB;AAAA,MAAA,WAC1C,0BAA0B,KAAK,wBAAwB;AAChE,aAAK,2BAA0B;AAC/B,aAAK,sBAAqB;AAAA,MAAA;AAAA,IAC5B;AAAA,IAGM,mBAAgB;AAClB,UAAA,CAAC,KAAK,gCAAgC;AACxC,aAAK,sBAAqB;AAAA,MAAA,OACrB;AACA,aAAA,kBAAkB,KAAK,iBAAiB;AAAA,MAAA;AAE/C,WAAK,kBAAkB;AAAA,IAAA;AAAA,IAGjB,0BAA0B,WAAoB;;AAChD,UAAA,GAACA,MAAA,UAAU,WAAV,gBAAAA,IAAkB,SAAQ;AAC7B,eAAO,uBAAuB,+BAA+B,KAAK,UAAU,SAAS;AAAA,UACnF,UAAU;AAAA,QAAA,CACX;AAAA,MAAA;AAGH,UAAI,wBAAwB;AAC5B,YAAM,mBAAmB,KAAK,+BAA+B,UAAU,eAAgB;AACvF,YAAM,sBAAsB,KAAK,+BAA+B,UAAU,eAAgB;AAE1F,8BAAwB,uBAAuB,uBAAuB,KAAK,UAAU,SAAS;AAAA,QAC5F,UAAU;AAAA,MAAA,CACX;AAED,UAAI,CAAC,CAAC,oBAAoB,CAAC,CAAC,qBAAqB;AAC/C,iCACE,OAAO,uBAAuB,4BAA4B,KAAK,UAAU,OAAO,IAAI;AAC7D,iCAAA,sBAAsB,OAAO,mBAAmB;AAAA,MAAA;AAEpE,aAAA;AAAA,IAAA;AAAA,IAGD,+BAA+B,sBAAmC;AACxE,YAAM,qBAA+B,CAAA;AAE9B,aAAA,6DACH,IAAI,CAAC,uBAAsB;AAC3B,cAAM,OAAO,mBAAmB;AAChC,YAAI,CAAC;AAAa,iBAAA;AAElB,cAAM,yBAAyB,mBAAmB,QAAQ,IAAI,IAAI;AAClE,cAAM,cAAc,uBAClB,mBAAmB,MACnB,KAAK,UAAU,OAAO;AAElB,cAAA,qBACJ,KAAK,4BAA4B,QAAQ,IAAI,MAAM,MACnD,KAAK,iBAAiB,QAAQ,IAAI,MAAM;AAE1C,YAAI,CAAC,wBAAwB;AACR,6BAAA,KAAK,mBAAmB,IAAK;AAAA,QAAA;AAElD,eAAO,CAAC,CAAC,eAAe,CAAC,0BAA0B,qBAAqB,cAAc;AAAA,MAAA,GAEvF,OAAO,CAAC,gBAAgB,CAAC,CAAC,aAC1B,KAAK;AAAA,IAAI;AAAA,KA3iBd,mDAKA,iDAKA,iDAKA,mDAKA;;mCArBC,SAAS,EAAE,WAAW,oBAAoB,MAAM,OAAA,CAAQ,CAAC;AAIzD,gCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,kBAAkB,MAAM,SAAS,CAAC;AAIxD,gCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,kBAAkB,MAAM,SAAS,CAAC;AAIxD,kCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,oBAAoB,MAAM,QAAQ,CAAC;AAIzD,oCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,uBAAuB,MAAM,SAAS,CAAC;AAnBrC,iBAAA,IAAA,MAAA,6BAAA,EAAA,MAAA,YAAA,MAAA,mBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,qBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,iBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,kBAAyC;AAAA,SAAA,UAAA,aAAA,+BAAA,kCAAA;AAKzC,iBAAA,IAAA,MAAA,2BAAA,EAAA,MAAA,YAAA,MAAA,iBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,mBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,eAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,gBAA8B;AAAA,SAAA,UAAA,aAAA,6BAAA,gCAAA;AAK9B,iBAAA,IAAA,MAAA,2BAAA,EAAA,MAAA,YAAA,MAAA,iBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,mBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,eAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,gBAA+B;AAAA,SAAA,UAAA,aAAA,6BAAA,gCAAA;AAK/B,iBAAA,IAAA,MAAA,6BAAA,EAAA,MAAA,YAAA,MAAA,mBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,qBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,iBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,kBAAgC;AAAA,SAAA,UAAA,aAAA,+BAAA,kCAAA;AAKhC,iBAAA,IAAA,MAAA,+BAAA,EAAA,MAAA,YAAA,MAAA,qBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,uBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,mBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,oBAAmC;AAAA,SAAA,UAAA,aAAA,iCAAA,oCAAA;AAzB9D,iBAkjBC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAjjBwB,GAAM,SAAmB,OAD5C,kBAAyB,YAAA,uBAAA,GAAC;;;"}
608
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { html, nothing } from 'lit';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.js';\nimport type {\n  CoachItem,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n} from '../common.js';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.js';\nimport style from './seat-reservation.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-area.js';\nimport '../seat-reservation-graphic.js';\nimport '../seat-reservation-place-control.js';\nimport '../seat-reservation-navigation/seat-reservation-navigation-coach.js';\nimport './seat-reservation-scoped.js';\n\n/**\n * Describe the purpose of the component with a single short sentence.\n *\n * @event {CustomEvent<SeatReservationSelectedPlacesEventDetails>} selectedPlaces - Emits when a place was selected and returns a Place array with all selected places\n * @event {CustomEvent<SeatReservationCoachSelection>} selectedCoach - Emits when a coach was selected and returns a CoachSelection\n */\nexport\n@customElement('sbb-seat-reservation')\nclass SbbSeatReservationElement extends SeatReservationBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** The seat reservation object which contains all coaches and places */\n  @property({ attribute: 'seat-reservation', type: Object })\n  public override accessor seatReservation: SeatReservation = null!;\n\n  /** The seat reservation navigation can be toggled by this property */\n  @forceType()\n  @property({ attribute: 'has-navigation', type: Boolean })\n  public override accessor hasNavigation: boolean = true;\n\n  /** Controls the visual representation of seat reservation in a horizonal or vertical alignment */\n  @forceType()\n  @property({ attribute: 'align-vertical', type: Boolean })\n  public override accessor alignVertical: boolean = false;\n\n  /** Maximal number of possible clickable seats */\n  @forceType()\n  @property({ attribute: 'max-reservations', type: Number })\n  public override accessor maxReservations: number = null!;\n\n  /** Any click functionality is prevented */\n  @forceType()\n  @property({ attribute: 'prevent-place-click', type: Boolean })\n  public override accessor preventPlaceClick: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n  private _coachesHtmlTemplate?: TemplateResult;\n  // Graphics that should not be rendered with an area\n  private _notAreaElements = [\n    'DRIVER_AREA_FULL',\n    'COACH_PASSAGE',\n    'COACH_WALL_NO_PASSAGE',\n    'COMPARTMENT_PASSAGE',\n    'COMPARTMENT_PASSAGE_HIGH',\n    'COMPARTMENT_PASSAGE_MIDDLE',\n    'COMPARTMENT_PASSAGE_LOW',\n  ];\n  // Area icons that should not be fixed during rotation when vertical mode is selected\n  private _notFixedRotatableAreaIcons = ['ENTRY_EXIT'];\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hasNavigation')) {\n      if (this.hasNavigation) {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.removeAttribute('tabindex'));\n      } else {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.setAttribute('tabindex', '0'));\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._componentSetup();\n  }\n\n  protected override render(): TemplateResult | null {\n    this._initVehicleSeatReservationConstruction();\n    return this._coachesHtmlTemplate || null;\n  }\n\n  private _componentSetup(): void {\n    this.initNavigationSelectionByScrollEvent();\n  }\n\n  private _initVehicleSeatReservationConstruction(): void {\n    const coachItems = JSON.parse(JSON.stringify(this.seatReservation?.coachItems));\n    const classAlignVertical = this.alignVertical ? 'sbb-sr__wrapper--vertical' : '';\n\n    this._coachesHtmlTemplate = html`\n      <div>\n        <sbb-screen-reader-only>\n          <input\n            id=\"first-tab-element\"\n            role=\"contentinfo\"\n            type=\"text\"\n            aria-label=\"${getI18nSeatReservation('SEAT_RESERVATION_BEGIN', this._language.current)}\"\n            readonly\n          />\n        </sbb-screen-reader-only>\n\n        <div @keydown=${(evt: KeyboardEvent) => this.handleKeyboardEvent(evt)}>\n          ${this._renderNavigation()}\n          <div class=\"sbb-sr__wrapper ${classAlignVertical}\">\n            <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\" tabindex=\"-1\">\n              <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                ${this._renderCoaches(coachItems)}\n              </ul>\n            </div>\n          </div>\n        </div>\n\n        <sbb-screen-reader-only>\n          <input\n            id=\"last-tab-element\"\n            role=\"contentinfo\"\n            type=\"text\"\n            aria-label=\"${getI18nSeatReservation('SEAT_RESERVATION_END', this._language.current)}\"\n            readonly\n          />\n        </sbb-screen-reader-only>\n      </div>\n    `;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (!this.hasNavigation) {\n      return null;\n    }\n\n    return html`\n      <nav class=\"${classMap({ 'sbb-sr-navigation--vertical': this.alignVertical })}\">\n        <ul\n          class=\"sbb-sr-navigation__list-coaches\"\n          aria-label=\"${getI18nSeatReservation(\n            'SEAT_RESERVATION_NAVIGATION',\n            this._language.current,\n          )}\"\n        >\n          ${this.seatReservation?.coachItems.map((coachItem: CoachItem, index: number) => {\n            return html`<li>\n              <sbb-seat-reservation-navigation-coach\n                @selectCoach=${(event: CustomEvent) => this._onSelectNavCoach(event)}\n                @focusCoach=${() => this._onFocusNavCoach()}\n                index=\"${index}\"\n                coach-id=\"${coachItem.id}\"\n                .selected=${this.selectedCoachIndex === index}\n                .focused=${this.focusedCoachIndex === index}\n                .propertyIds=\"${coachItem.propertyIds}\"\n                .travelClass=\"${coachItem.travelClass}\"\n                ?driver-area=\"${!coachItem.places?.length}\"\n                ?first=\"${index === 0}\"\n                ?last=\"${index === this.seatReservation?.coachItems.length - 1}\"\n                ?vertical=\"${this.alignVertical}\"\n              >\n              </sbb-seat-reservation-navigation-coach>\n            </li>`;\n          })}\n        </ul>\n      </nav>\n    `;\n  }\n  /**\n   *\n   * @param coaches\n   * @returns\n   */\n  private _renderCoaches(coaches?: CoachItem[]): TemplateResult[] | null {\n    if (!coaches) {\n      return null;\n    }\n    return coaches.map((coachItem: CoachItem, index: number) => {\n      return html`\n        <li class=\"sbb-sr__item-coach\">${this._renderCoachElement(coachItem, index)}</li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(coachItem: CoachItem, index: number): TemplateResult {\n    const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);\n    const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);\n\n    return html` <sbb-seat-reservation-scoped\n      scoped-classes=\"coach-wrapper\"\n      height=\"${calculatedCoachDimension.h}px\"\n      width=\"${calculatedCoachDimension.w}px\"\n    >\n      ${this._getRenderedCoachBorders(coachItem, index)}\n      ${this._getRenderedGraphicalElements(coachItem.graphicElements || [], coachItem.dimension)}\n      ${this._getRenderedServiceElements(coachItem.serviceElements)}\n      <table\n        @focus=${() => this.onFocusTableCoachAndPreselectPlace(index)}\n        id=\"sbb-sr-coach-${index}\"\n        class=\"sbb-sr-coach-wrapper__table\"\n        aria-describedby=\"sbb-sr-coach-caption-${index}\"\n      >\n        <caption id=\"sbb-sr-coach-caption-${index}\" tabindex=\"-1\">\n          <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>\n        </caption>\n        ${this._getRenderedRowPlaces(coachItem, index)}\n      </table>\n    </sbb-seat-reservation-scoped>`;\n  }\n\n  private _getRenderedCoachBorders(coachItem: CoachItem, coachIndex: number): TemplateResult {\n    const allElements = coachItem.graphicElements;\n    const COACH_PASSAGE_WIDTH = 1;\n    const driverArea = allElements?.find(\n      (element: BaseElement) => element.icon === 'DRIVER_AREA_FULL',\n    );\n    const borderWidth = driverArea\n      ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH\n      : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;\n    const borderOffsetX =\n      coachIndex === 0 && driverArea\n        ? driverArea?.dimension.w * this.baseGridSize\n        : this.baseGridSize;\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"coach-border\"\n        inset-block-start=\"${this.coachBorderPadding * -1}px\"\n        inset-inline-start=\"${borderOffsetX}px\"\n      >\n        <sbb-seat-reservation-graphic\n          name=\"COACH_BORDER_MIDDLE\"\n          width=${borderWidth * this.baseGridSize}\n          height=${(coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize}\n          ?stretch=${true}\n          role=\"presentation\"\n        ></sbb-seat-reservation-graphic>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderedRowPlaces(coach: CoachItem, coachIndex: number): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepair rows with the places to render a table\n    const tableRowPlaces: Record<number, Place[]> = {};\n    for (const place of coach.places) {\n      if (!tableRowPlaces[place.position.y]) {\n        tableRowPlaces[place.position.y] = [place];\n      } else {\n        tableRowPlaces[place.position.y].push(place);\n      }\n    }\n\n    return Object.values(tableRowPlaces)\n      .map((rowPlaces: Place[], index) => {\n        return html`\n          <tr id=\"row-${coachIndex}-${rowPlaces[0].position.y}\" data-row-index=${index}>\n            ${this._getRenderedColumnPlaces(rowPlaces, coachIndex)}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(places: Place[], coachIndex: number): TemplateResult[] | null {\n    //Sorts each place by its ascending x coordinate\n    places.sort(\n      (placeA: Place, placeB: Place) => Number(placeA.position.x) - Number(placeB.position.x),\n    );\n\n    return places?.map((place: Place, index: number) => {\n      const calculatedInternalDimension = this.getCalculatedDimension(place.dimension);\n      const calculatedInternalPosition = this.getCalculatedPosition(place.position);\n      const textRotation = this.alignVertical ? -90 : 0;\n\n      return html`\n        <sbb-seat-reservation-scoped\n          scoped-classes=\"graphical-element\"\n          inset-block-start=\"${calculatedInternalPosition.y}px\"\n          inset-inline-start=\"${calculatedInternalPosition.x}px\"\n          width=\"${calculatedInternalDimension.w}px\"\n          height=\"${calculatedInternalDimension.h}px\"\n          z-index=\"${place.position.z}\"\n          cell-id=\"cell-${coachIndex}-${place.position.y}-${index}\"\n        >\n          <sbb-seat-reservation-place-control\n            @selectPlace=${(selectPlaceEvent: CustomEvent) => this._onSelectPlace(selectPlaceEvent)}\n            exportparts=\"sbb-sr-place-part\"\n            id=\"seat-reservation__place-button-${coachIndex}-${place.number}\"\n            class=\"seat-reservation-place-control\"\n            data-cell-id=\"${coachIndex}-${place.position.y}-${index}\"\n            text=${place.number}\n            type=${place.type}\n            state=${place.state}\n            width=${place.dimension.w * this.baseGridSize}\n            height=${place.dimension.h * this.baseGridSize}\n            rotation=${place.rotation ?? nothing}\n            text-rotation=${textRotation}\n            coach-index=${coachIndex}\n            .propertyIds=${place.propertyIds}\n            .preventClick=${this.preventPlaceClick}\n          ></sbb-seat-reservation-place-control>\n        </sbb-seat-reservation-scoped>\n      `;\n    });\n  }\n\n  private _getRenderedGraphicalElements(\n    graphicalElements: BaseElement[],\n    coachDimension: ElementDimension,\n  ): TemplateResult[] | null {\n    if (!graphicalElements) {\n      return null;\n    }\n\n    return graphicalElements?.map((graphicalElement: BaseElement) => {\n      const icon = graphicalElement.icon ?? '';\n      const elementRotation = graphicalElement.rotation || 0;\n      const isNotFixedRotationGraphicalElement =\n        this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon!) === -1;\n      const elementFixedRotation =\n        this.alignVertical && isNotFixedRotationGraphicalElement\n          ? elementRotation - 90\n          : elementRotation;\n\n      //check if the current element is not an area element, since this element is drawn without an area component\n      if (this._notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {\n        return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);\n      }\n      return this._getRenderElementWithArea(graphicalElement, elementFixedRotation, coachDimension);\n    });\n  }\n\n  private _getRenderElementWithArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    // TODO -> isNotTableGraphicTempFix is temp fix to show coach tables as area and not as svg graphic.\n    // The problem here is that when using TABLE svg graphics,\n    // they are displayed distorted due to different heights and widths and this is not visually good.\n    const isNotTableGraphicTempFix = graphicalElement.icon?.indexOf('TABLE') === -1;\n\n    const areaProperty =\n      graphicalElement.icon && isNotTableGraphicTempFix ? graphicalElement.icon : null;\n    const stretchHeight = areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n    );\n\n    let elementMounting = 'free';\n    if (graphicalElement.position.y === this.coachBorderOffset * -1) {\n      elementMounting = 'upper-border';\n    } else if (\n      graphicalElement.position.y + graphicalElement.dimension.h ===\n      coachDimension.h + this.coachBorderOffset\n    ) {\n      elementMounting = 'lower-border';\n    }\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"graphical-element\"\n        inset-block-start=\"${calculatedPosition.y}px\"\n        inset-inline-start=\"${calculatedPosition.x}px\"\n        width=\"${calculatedDimension.w}px\"\n        height=\"${calculatedDimension.h}px\"\n        z-index=\"${graphicalElement.position.z}\"\n      >\n        <sbb-seat-reservation-area\n          style=${styleMap({\n            '--sbb-reservation-area-width': graphicalElement.dimension.w * this.baseGridSize,\n            '--sbb-reservation-area-height': graphicalElement.dimension.h * this.baseGridSize,\n          })}\n          mounting=${elementMounting}\n          background=\"dark\"\n          aria-hidden=\"true\"\n          title=${ariaLabelForArea}\n        >\n          ${areaProperty\n            ? html`\n                <sbb-seat-reservation-graphic\n                  name=${areaProperty}\n                  rotation=${rotation}\n                  width=${this.baseGridSize}\n                  height=${this.baseGridSize}\n                  role=\"img\"\n                  aria-hidden=\"true\"\n                ></sbb-seat-reservation-graphic>\n              `\n            : nothing}\n        </sbb-seat-reservation-area>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderElementWithoutArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n    );\n\n    // If the icon is the driver area, then here concat the vehicle type to get the right vehicle chassie icon\n    const icon =\n      graphicalElement.icon && graphicalElement.icon.indexOf('DRIVER_AREA') === -1\n        ? graphicalElement.icon\n        : graphicalElement.icon?.concat('_', this.seatReservation.vehicleType);\n\n    return html`\n      <sbb-seat-reservation-scoped\n        scoped-classes=\"graphical-element\"\n        inset-block-start=\"${calculatedPosition.y}px\"\n        inset-inline-start=\"${calculatedPosition.x}px\"\n        width=\"${calculatedDimension.w}px\"\n        height=\"${calculatedDimension.h}px\"\n        z-index=\"${graphicalElement.position.z}\"\n      >\n        <sbb-seat-reservation-graphic\n          name=${icon ?? nothing}\n          width=${graphicalElement.dimension.w * this.baseGridSize}\n          height=${graphicalElement.dimension.h * this.baseGridSize}\n          rotation=${rotation}\n          aria-hidden=\"true\"\n          ?stretch=${true}\n        ></sbb-seat-reservation-graphic>\n      </sbb-seat-reservation-scoped>\n    `;\n  }\n\n  private _getRenderedServiceElements(serviceElements?: BaseElement[]): TemplateResult[] | null {\n    if (!serviceElements) {\n      return null;\n    }\n\n    return serviceElements?.map((serviceElement: BaseElement) => {\n      const titleDescription = serviceElement.icon\n        ? getI18nSeatReservation(serviceElement.icon, this._language.current)\n        : null;\n      const calculatedcCmpartmentNumberDimension = this.getCalculatedDimension(\n        serviceElement.dimension,\n      );\n      const calculatedcCmpartmentNumberPosition = this.getCalculatedPosition(\n        serviceElement.position,\n      );\n      const elementRotation = serviceElement.rotation || 0;\n      const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;\n\n      return html`\n        <sbb-seat-reservation-scoped\n          scoped-classes=\"graphical-element\"\n          inset-block-start=\"${calculatedcCmpartmentNumberPosition.y}px\"\n          inset-inline-start=\"${calculatedcCmpartmentNumberPosition.x}px\"\n          width=\"${calculatedcCmpartmentNumberDimension.w}px\"\n          height=\"${calculatedcCmpartmentNumberDimension.h}px\"\n          z-index=\"${serviceElement.position.z}\"\n        >\n          <sbb-seat-reservation-graphic\n            name=${serviceElement.icon ?? nothing}\n            width=${serviceElement.dimension.w * this.baseGridSize}\n            height=${serviceElement.dimension.h * this.baseGridSize}\n            .rotation=${elementFixedRotation}\n            role=\"img\"\n            aria-hidden=\"true\"\n            title=${titleDescription ?? nothing}\n          ></sbb-seat-reservation-graphic>\n        </sbb-seat-reservation-scoped>\n      `;\n    });\n  }\n\n  /**\n   * Manages the selected place event triggered from the place\n   * Each selection emits an array of all selected places\n   * @param selectPlaceEvent\n   */\n  private _onSelectPlace(selectPlaceEvent: CustomEvent): void {\n    const selectedPlace = selectPlaceEvent.detail as PlaceSelection;\n    // We have to set preventCoachScrollByPlaceClick to true, to prevent automatic scrolling to the new focused place\n    this.preventCoachScrollByPlaceClick = true;\n    this.isCoachGridFocusable = false;\n    if (!this.preventPlaceClick) {\n      // Add place to place collection\n      this.updateSelectedSeatReservationPlaces(selectedPlace);\n      this.updateCurrentSelectedPlaceInCoach(selectedPlace);\n    }\n  }\n\n  private _onSelectNavCoach(event: CustomEvent): void {\n    const selectedNavCoachIndex = event.detail as number;\n    this.isKeyboardNavigation = false;\n\n    if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.unfocusPlaceElement();\n      this.scrollToSelectedNavCoach(selectedNavCoachIndex);\n    } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n      this.preselectPlaceInCoach();\n    }\n  }\n\n  private _onFocusNavCoach(): void {\n    if (!this.preventCoachScrollByPlaceClick) {\n      this.preselectPlaceInCoach();\n    } else {\n      this.focusPlaceElement(this.currSelectedPlace);\n    }\n    this.isAutoScrolling = false;\n  }\n\n  private _getDescriptionTableCoach(coachItem: CoachItem): string {\n    if (!coachItem.places?.length) {\n      return getI18nSeatReservation('COACH_BLOCKED_TABLE_CAPTION', this._language.current, [\n        coachItem.id,\n      ]);\n    }\n\n    let tableCoachDescription = '';\n    const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements!);\n    const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements!);\n\n    tableCoachDescription = getI18nSeatReservation('COACH_TABLE_CAPTION', this._language.current, [\n      coachItem.id,\n    ]);\n\n    if (!!areaDescriptions || !!serviceDescriptions) {\n      tableCoachDescription +=\n        '. ' + getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      tableCoachDescription += serviceDescriptions + ', ' + areaDescriptions + '.';\n    }\n    return tableCoachDescription;\n  }\n\n  private _getTitleDescriptionListString(descriptionsElements: BaseElement[]): string {\n    const uniqueDescriptions: string[] = [];\n\n    return descriptionsElements\n      ?.map((descriptionElement) => {\n        const icon = descriptionElement.icon;\n        if (!icon) return null;\n\n        const descriptionAlreayExist = uniqueDescriptions.indexOf(icon) > -1;\n        const translation = getI18nSeatReservation(\n          descriptionElement.icon!,\n          this._language.current,\n        );\n        const isValidDescription =\n          this._notFixedRotatableAreaIcons.indexOf(icon) === -1 &&\n          this._notAreaElements.indexOf(icon) === -1;\n\n        if (!descriptionAlreayExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreayExist && isValidDescription ? translation : null;\n      })\n      .filter((description) => !!description)\n      .join(', ');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation': SbbSeatReservationElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -105,4 +105,4 @@ let SbbSeatReservationAreaElement = (() => {
105
105
  export {
106
106
  SbbSeatReservationAreaElement
107
107
  };
108
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBWU0saUNBQTZCLE1BQUE7OzBCQURsQyxjQUFjLDJCQUEyQixDQUFDOzs7O29CQUNDOzs7Ozs7O0FBQVIsRUFBQSxtQkFBUSxZQUFVO0FBQUE7O0FBTXBELHFEQUFBLGtCQUFBLE1BQUEsd0JBQ0UsTUFBTTtBQUtSLHdEQUFBLGtCQUFBLE1BQUEsMkJBQUEsR0FBQSxrQkFBQSxNQUFBLDBCQUErQyxPQUFPOzs7O0lBTnRELElBQWdCLFdBQ1A7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBRFQsSUFBZ0IsU0FDUCxPQUFBO0FBQUEseUJBQUEsNEJBQUE7QUFBQSxJQUFBO0FBQUE7QUFBQSxJQUtULElBQWdCLGFBQXVDO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUF2RCxJQUFnQixXQUF1QyxPQUFBO0FBQUEseUJBQUEsOEJBQUE7QUFBQSxJQUFBO0FBQUEsSUFFcEMsU0FBTTtBQUNoQixhQUFBO0FBQUEsSUFBQTtBQUFBLEtBVFQsNENBTUE7OzRCQVJDLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7OEJBSzNCLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFMWixpQkFBQSxJQUFBLE1BQUEsc0JBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxZQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGNBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFBLFVBQUEsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQUEsV0FDUDtBQUFBLFNBQUEsVUFBQSxhQUFBLHdCQUFBLDJCQUFBO0FBS08saUJBQUEsSUFBQSxNQUFBLHdCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsY0FBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxnQkFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQUEsWUFBQSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBQSxhQUF1QztBQUFBLFNBQUEsVUFBQSxhQUFBLDBCQUFBLDZCQUFBO0FBWnpELGlCQWlCQyxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBaEJ3QixHQUFNLFNBQW1CLE9BRDVDLGtCQUE2QixZQUFBLHVCQUFBLEdBQUM7OzsifQ==
108
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBWU0saUNBQTZCLE1BQUE7OzBCQURsQyxjQUFjLDJCQUEyQixDQUFDOzs7O29CQUNDOzs7Ozs7O0FBQVIsRUFBQSxtQkFBUSxZQUFVO0FBQUE7O0FBTXBELHFEQUFBLGtCQUFBLE1BQUEsd0JBQ0UsTUFBTTtBQUtSLHdEQUFBLGtCQUFBLE1BQUEsMkJBQUEsR0FBQSxrQkFBQSxNQUFBLDBCQUErQyxPQUFPOzs7O0lBTnRELElBQWdCLFdBQVE7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXhCLElBQWdCLFNBQVEsT0FBQTtBQUFBLHlCQUFBLDRCQUFBO0FBQUEsSUFBQTtBQUFBO0FBQUEsSUFNeEIsSUFBZ0IsYUFBVTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBMUIsSUFBZ0IsV0FBVSxPQUFBO0FBQUEseUJBQUEsOEJBQUE7QUFBQSxJQUFBO0FBQUEsSUFFUCxTQUFNO0FBQ3ZCLGFBQU87QUFBQSxJQUFBO0FBQUEsS0FUVCw0Q0FNQTs7NEJBUkMsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQzs4QkFLM0IsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUw1QixpQkFBQSxJQUFBLE1BQUEsc0JBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxZQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGNBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixVQUFRLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFSLFdBQVE7QUFBQSxJQUFBLEtBQUEsVUFBQSxhQUFBLHdCQUFBLDJCQUFBO0FBTXhCLGlCQUFBLElBQUEsTUFBQSx3QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGNBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsZ0JBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixZQUFVLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFWLGFBQVU7QUFBQSxJQUFBLEtBQUEsVUFBQSxhQUFBLDBCQUFBLDZCQUFBO0FBWjVCLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QixPQUQ1QyxrQkFBQSxZQUFBLHVCQUFBLEdBQThCOzs7In0=
@@ -11,8 +11,7 @@ const svgImage = (src) => {
11
11
  `;
12
12
  };
13
13
  const svgImageByOSDMCode = (osdmCode) => {
14
- var _a, _b;
15
- return ((_a = mapIconToSvg[osdmCode]) == null ? void 0 : _a.svg) ? svgImage(mapIconToSvg[osdmCode].svg) : ((_b = mapIconToSvg[osdmCode]) == null ? void 0 : _b.svgName) ? html`<sbb-icon name="${mapIconToSvg[osdmCode].svgName}"></sbb-icon>` : null;
14
+ return mapIconToSvg[osdmCode]?.svg ? svgImage(mapIconToSvg[osdmCode].svg) : mapIconToSvg[osdmCode]?.svgName ? html`<sbb-icon name="${mapIconToSvg[osdmCode].svgName}"></sbb-icon>` : null;
16
15
  };
17
16
  const interiorTable = html`
18
17
  <sbb-table-wrapper>
@@ -323,4 +322,4 @@ export {
323
322
  assetsTemplate,
324
323
  svgImageByOSDMCode
325
324
  };
326
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-assets.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"sourcesContent":["import { html, type TemplateResult } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\n\nimport { svgs, mapIconToSvg } from '../common.js';\n\nimport '@sbb-esta/lyne-elements/table.js';\nimport '../seat-reservation-graphic.js';\n\nconst svgImage = (src: string): TemplateResult => {\n  return html`\n    <div class=\"story-asset\">\n      <span class=\"story-asset__preview\">${unsafeHTML(src)}</span>\n    </div>\n  `;\n};\n\n/**\n * svgImageByOSDMCode Function returns the corresponding svg image by OSDM Code\n * @param osdmCode\n * @returns The SVG Image as TemplateResult if it matches the OSDM code, or null if it's not found.\n */\nexport const svgImageByOSDMCode = (osdmCode: string): TemplateResult | null => {\n  return mapIconToSvg[osdmCode]?.svg\n    ? svgImage(mapIconToSvg[osdmCode].svg)\n    : mapIconToSvg[osdmCode]?.svgName\n      ? html`<sbb-icon name=\"${mapIconToSvg[osdmCode].svgName}\"></sbb-icon>`\n      : null;\n};\n\nconst interiorTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_FREE')}</td>\n          <td>Place-Bike: Available</td>\n          <td>PLACE_BICYCLE_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_SELECTED')}</td>\n          <td>Place-Bike: Selected</td>\n          <td>PLACE_BICYCLE_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_ALLOCATED')}</td>\n          <td>Place-Bike: Unavailable</td>\n          <td>PLACE_BICYCLE_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_RESTRICTED')}</td>\n          <td>Place-Bike: Not bookable</td>\n          <td>PLACE_BICYCLE_RESTRICTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_FREE')}</td>\n          <td>Place-Seat: Available</td>\n          <td>PLACE_SEAT_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_SELECTED')}</td>\n          <td>Place-Seat: Selected</td>\n          <td>PLACE_SEAT_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_ALLOCATED')}</td>\n          <td>Place-Seat: Unavailable</td>\n          <td>PLACE_SEAT_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_RESTRICTED')}</td>\n          <td>Place-Seat: Not bookable</td>\n          <td>PLACE_SEAT_RESTRICTED</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst layoutItemsTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('ENTRY_EXIT')}</td>\n          <td>Entrance</td>\n          <td>ENTRY_EXIT</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multi Function Area</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_AREA')}</td>\n          <td>Playground</td>\n          <td>PLAYGROUND_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_AREA')}</td>\n          <td>Pram</td>\n          <td>PRAM_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SKI_AREA')}</td>\n          <td>Ski</td>\n          <td>SKI_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('STAIR_AREA')}</td>\n          <td>Stair</td>\n          <td>STAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-Handicap</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WARDROBE_AREA')}</td>\n          <td>Wardrobe</td>\n          <td>WARDROBE_AREA</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst serviceIconTable = html`\n  <sbb-table-wrapper>\n    <table aria-label=\"Available Service Icons\" class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('BISTRO')}</td>\n          <td>Bistro</td>\n          <td>BISTRO</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('BUSINESS')}</td>\n          <td>Business</td>\n          <td>BUSINESS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_ICON')}</td>\n          <td>Family</td>\n          <td>PLAYGROUND_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multifunction</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_ICON')}</td>\n          <td>Pram</td>\n          <td>PRAM_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('RESTAURANT_ICON')}</td>\n          <td>Restaurant</td>\n          <td>RESTAURANT_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SILENCE_AREA_ICON')}</td>\n          <td>Silence</td>\n          <td>SILENCE_AREA_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-PRM</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WHEELCHAIR_ICON')}</td>\n          <td>Wheelchair</td>\n          <td>WHEELCHAIR_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WIFI')}</td>\n          <td>Wifi</td>\n          <td>WIFI</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst chassisTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_TRAIN')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA_FULL_TRAIN</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_BUS')}</td>\n          <td>Driver: Bus</td>\n          <td>DRIVER_AREA_FULL_BUS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_HIGH')}</td>\n          <td>Passage-Compartment: Top</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_HIGH</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE')}</td>\n          <td>Passage-Compartment: Middle</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_LOW')}</td>\n          <td>Passage-Compartment: Bottom</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_LOW</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_PASSAGE')}</td>\n          <td>Passage-Waggon Type: Left</td>\n          <td>COACH_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisPassageWaggonBottomRight)}</td>\n          <td>Passage-Waggon Type: Right</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red));\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_WALL_NO_PASSAGE')}</td>\n          <td>Row-Empty: Top/Left</td>\n          <td>COACH_WALL_NO_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_BORDER_MIDDLE')}</td>\n          <td>Row-Empty: Middle</td>\n          <td>COACH_BORDER_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisSeparator)}</td>\n          <td>Separator</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red))\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TABLE')}</td>\n          <td>Table</td>\n          <td>TABLE</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\n\nexport const assetsTemplate: TemplateResult = html`\n  <style>\n    .story-asset {\n      width: max-content;\n      background-color: var(--sbb-color-white);\n    }\n  </style>\n  <h1>List of all currently available assets.</h1>\n  <h2>Interior</h2>\n  ${interiorTable}\n  <h2>Layout</h2>\n  ${layoutItemsTable}\n  <h2>Service Icons</h2>\n  ${serviceIconTable}\n  <h2>Chassis</h2>\n  ${chassisTable}\n`;\n"],"names":[],"mappings":"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"}
325
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-assets.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"sourcesContent":["import { html, type TemplateResult } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\n\nimport { svgs, mapIconToSvg } from '../common.js';\n\nimport '@sbb-esta/lyne-elements/table.js';\nimport '../seat-reservation-graphic.js';\n\nconst svgImage = (src: string): TemplateResult => {\n  return html`\n    <div class=\"story-asset\">\n      <span class=\"story-asset__preview\">${unsafeHTML(src)}</span>\n    </div>\n  `;\n};\n\n/**\n * svgImageByOSDMCode Function returns the corresponding svg image by OSDM Code\n * @param osdmCode\n * @returns The SVG Image as TemplateResult if it matches the OSDM code, or null if it's not found.\n */\nexport const svgImageByOSDMCode = (osdmCode: string): TemplateResult | null => {\n  return mapIconToSvg[osdmCode]?.svg\n    ? svgImage(mapIconToSvg[osdmCode].svg)\n    : mapIconToSvg[osdmCode]?.svgName\n      ? html`<sbb-icon name=\"${mapIconToSvg[osdmCode].svgName}\"></sbb-icon>`\n      : null;\n};\n\nconst interiorTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_FREE')}</td>\n          <td>Place-Bike: Available</td>\n          <td>PLACE_BICYCLE_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_SELECTED')}</td>\n          <td>Place-Bike: Selected</td>\n          <td>PLACE_BICYCLE_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_ALLOCATED')}</td>\n          <td>Place-Bike: Unavailable</td>\n          <td>PLACE_BICYCLE_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_RESTRICTED')}</td>\n          <td>Place-Bike: Not bookable</td>\n          <td>PLACE_BICYCLE_RESTRICTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_FREE')}</td>\n          <td>Place-Seat: Available</td>\n          <td>PLACE_SEAT_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_SELECTED')}</td>\n          <td>Place-Seat: Selected</td>\n          <td>PLACE_SEAT_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_ALLOCATED')}</td>\n          <td>Place-Seat: Unavailable</td>\n          <td>PLACE_SEAT_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_RESTRICTED')}</td>\n          <td>Place-Seat: Not bookable</td>\n          <td>PLACE_SEAT_RESTRICTED</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst layoutItemsTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('ENTRY_EXIT')}</td>\n          <td>Entrance</td>\n          <td>ENTRY_EXIT</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multi Function Area</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_AREA')}</td>\n          <td>Playground</td>\n          <td>PLAYGROUND_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_AREA')}</td>\n          <td>Pram</td>\n          <td>PRAM_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SKI_AREA')}</td>\n          <td>Ski</td>\n          <td>SKI_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('STAIR_AREA')}</td>\n          <td>Stair</td>\n          <td>STAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-Handicap</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WARDROBE_AREA')}</td>\n          <td>Wardrobe</td>\n          <td>WARDROBE_AREA</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst serviceIconTable = html`\n  <sbb-table-wrapper>\n    <table aria-label=\"Available Service Icons\" class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('BISTRO')}</td>\n          <td>Bistro</td>\n          <td>BISTRO</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('BUSINESS')}</td>\n          <td>Business</td>\n          <td>BUSINESS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_ICON')}</td>\n          <td>Family</td>\n          <td>PLAYGROUND_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multifunction</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_ICON')}</td>\n          <td>Pram</td>\n          <td>PRAM_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('RESTAURANT_ICON')}</td>\n          <td>Restaurant</td>\n          <td>RESTAURANT_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SILENCE_AREA_ICON')}</td>\n          <td>Silence</td>\n          <td>SILENCE_AREA_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-PRM</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WHEELCHAIR_ICON')}</td>\n          <td>Wheelchair</td>\n          <td>WHEELCHAIR_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WIFI')}</td>\n          <td>Wifi</td>\n          <td>WIFI</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst chassisTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_TRAIN')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA_FULL_TRAIN</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_BUS')}</td>\n          <td>Driver: Bus</td>\n          <td>DRIVER_AREA_FULL_BUS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_HIGH')}</td>\n          <td>Passage-Compartment: Top</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_HIGH</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE')}</td>\n          <td>Passage-Compartment: Middle</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_LOW')}</td>\n          <td>Passage-Compartment: Bottom</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_LOW</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_PASSAGE')}</td>\n          <td>Passage-Waggon Type: Left</td>\n          <td>COACH_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisPassageWaggonBottomRight)}</td>\n          <td>Passage-Waggon Type: Right</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red));\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_WALL_NO_PASSAGE')}</td>\n          <td>Row-Empty: Top/Left</td>\n          <td>COACH_WALL_NO_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_BORDER_MIDDLE')}</td>\n          <td>Row-Empty: Middle</td>\n          <td>COACH_BORDER_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisSeparator)}</td>\n          <td>Separator</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red))\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TABLE')}</td>\n          <td>Table</td>\n          <td>TABLE</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\n\nexport const assetsTemplate: TemplateResult = html`\n  <style>\n    .story-asset {\n      width: max-content;\n      background-color: var(--sbb-color-white);\n    }\n  </style>\n  <h1>List of all currently available assets.</h1>\n  <h2>Interior</h2>\n  ${interiorTable}\n  <h2>Layout</h2>\n  ${layoutItemsTable}\n  <h2>Service Icons</h2>\n  ${serviceIconTable}\n  <h2>Chassis</h2>\n  ${chassisTable}\n`;\n"],"names":[],"mappings":"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"}
@@ -144,24 +144,23 @@ let SbbSeatReservationGraphicElement = (() => {
144
144
  __privateSet(this, _height_accessor_storage, value);
145
145
  }
146
146
  willUpdate(_changedProperties) {
147
- var _a2, _b, _c, _d;
148
147
  super.willUpdate(_changedProperties);
149
148
  if (_changedProperties.has("width") && !!this.width) {
150
- (_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-reservation-graphic-width", `${this.width}`);
149
+ this.style?.setProperty("--sbb-reservation-graphic-width", `${this.width}`);
151
150
  }
152
151
  if (_changedProperties.has("height") && !!this.height) {
153
- (_b = this.style) == null ? void 0 : _b.setProperty("--sbb-reservation-graphic-height", `${this.height}`);
152
+ this.style?.setProperty("--sbb-reservation-graphic-height", `${this.height}`);
154
153
  }
155
154
  if (_changedProperties.has("rotation")) {
156
- (_c = this.style) == null ? void 0 : _c.setProperty("--sbb-reservation-graphic-rotation", `${this.rotation}`);
155
+ this.style?.setProperty("--sbb-reservation-graphic-rotation", `${this.rotation}`);
157
156
  }
158
157
  if (_changedProperties.has("inverseRotation")) {
159
- (_d = this.style) == null ? void 0 : _d.setProperty("--sbb-reservation-graphic-inverse-rotation", `${this.inverseRotation}`);
158
+ this.style?.setProperty("--sbb-reservation-graphic-inverse-rotation", `${this.inverseRotation}`);
160
159
  }
161
160
  }
162
161
  render() {
163
162
  const svgObj = mapIconToSvg[this.name];
164
- if (!(svgObj == null ? void 0 : svgObj.svg) && !(svgObj == null ? void 0 : svgObj.svgName)) {
163
+ if (!svgObj?.svg && !svgObj?.svgName) {
165
164
  return null;
166
165
  }
167
166
  return html`<span
@@ -181,7 +180,7 @@ let SbbSeatReservationGraphicElement = (() => {
181
180
  const parser = new DOMParser();
182
181
  const svgString = svg || "<svg></svg>";
183
182
  const svgElm = parser.parseFromString(svgString, "image/svg+xml").firstElementChild;
184
- if (this.stretch && (svgElm == null ? void 0 : svgElm.nodeName.toLowerCase()) === "svg") {
183
+ if (this.stretch && svgElm?.nodeName.toLowerCase() === "svg") {
185
184
  svgElm.setAttribute("preserveAspectRatio", "none");
186
185
  }
187
186
  return svgElm;
@@ -221,4 +220,4 @@ let SbbSeatReservationGraphicElement = (() => {
221
220
  export {
222
221
  SbbSeatReservationGraphicElement
223
222
  };
224
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-graphic.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { 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';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation, mapIconToSvg } from '../common.js';\n\nimport style from './seat-reservation-graphic.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\n/**\n * Output one of the SVG graphics based on its code.\n */\nexport\n@customElement('sbb-seat-reservation-graphic')\nclass SbbSeatReservationGraphicElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Name of the SVG graphic to be displayed. */\n  @forceType()\n  @property({ attribute: 'name' })\n  public accessor name: string = '';\n\n  /** if true, scale the graphic content of the given element non-uniformly if necessary */\n  @forceType()\n  @property({ attribute: 'stretch', type: Boolean })\n  public accessor stretch: boolean = false;\n\n  /** handles the rotation of the SVG graphic */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** Inverse rotation for part of an SVG that can be rotated opposite to the normal rotation */\n  @forceType()\n  @property({ attribute: 'inverse-roration', type: Number })\n  public accessor inverseRotation: number = 0;\n\n  /** width of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = null!;\n\n  /** height of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n    if (_changedProperties.has('width') && !!this.width) {\n      this.style?.setProperty('--sbb-reservation-graphic-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height') && !!this.height) {\n      this.style?.setProperty('--sbb-reservation-graphic-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-reservation-graphic-rotation', `${this.rotation}`);\n    }\n\n    if (_changedProperties.has('inverseRotation')) {\n      this.style?.setProperty(\n        '--sbb-reservation-graphic-inverse-rotation',\n        `${this.inverseRotation}`,\n      );\n    }\n  }\n\n  protected override render(): TemplateResult | null {\n    const svgObj = mapIconToSvg[this.name];\n\n    if (!svgObj?.svg && !svgObj?.svgName) {\n      return null;\n    }\n\n    return html`<span\n      class=\"${classMap({\n        'sbb-sr-icon': !!svgObj.svgName,\n        'sbb-sr-graphic': !!svgObj.svg,\n      })}\"\n    >\n      ${svgObj.svgName\n        ? html` <sbb-icon\n            name=\"${svgObj.svgName || ''}\"\n            aria-hidden=\"false\"\n            aria-label=\"${getI18nSeatReservation(svgObj.svgName, this._language.current)}\"\n          ></sbb-icon>`\n        : html`${this._getSvgElement(svgObj.svg!)}`}\n    </span>`;\n  }\n\n  private _getSvgElement(svg: string): Element | null {\n    const parser = new DOMParser();\n    const svgString = svg || '<svg></svg>';\n    const svgElm = parser.parseFromString(svgString, 'image/svg+xml').firstElementChild;\n    if (this.stretch && svgElm?.nodeName.toLowerCase() === 'svg') {\n      svgElm.setAttribute('preserveAspectRatio', 'none');\n    }\n    return svgElm;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-graphic': SbbSeatReservationGraphicElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
223
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-graphic.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { 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';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation, mapIconToSvg } from '../common.js';\n\nimport style from './seat-reservation-graphic.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\n/**\n * Output one of the SVG graphics based on its code.\n */\nexport\n@customElement('sbb-seat-reservation-graphic')\nclass SbbSeatReservationGraphicElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Name of the SVG graphic to be displayed. */\n  @forceType()\n  @property({ attribute: 'name' })\n  public accessor name: string = '';\n\n  /** if true, scale the graphic content of the given element non-uniformly if necessary */\n  @forceType()\n  @property({ attribute: 'stretch', type: Boolean })\n  public accessor stretch: boolean = false;\n\n  /** handles the rotation of the SVG graphic */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** Inverse rotation for part of an SVG that can be rotated opposite to the normal rotation */\n  @forceType()\n  @property({ attribute: 'inverse-roration', type: Number })\n  public accessor inverseRotation: number = 0;\n\n  /** width of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = null!;\n\n  /** height of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n    if (_changedProperties.has('width') && !!this.width) {\n      this.style?.setProperty('--sbb-reservation-graphic-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height') && !!this.height) {\n      this.style?.setProperty('--sbb-reservation-graphic-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-reservation-graphic-rotation', `${this.rotation}`);\n    }\n\n    if (_changedProperties.has('inverseRotation')) {\n      this.style?.setProperty(\n        '--sbb-reservation-graphic-inverse-rotation',\n        `${this.inverseRotation}`,\n      );\n    }\n  }\n\n  protected override render(): TemplateResult | null {\n    const svgObj = mapIconToSvg[this.name];\n\n    if (!svgObj?.svg && !svgObj?.svgName) {\n      return null;\n    }\n\n    return html`<span\n      class=\"${classMap({\n        'sbb-sr-icon': !!svgObj.svgName,\n        'sbb-sr-graphic': !!svgObj.svg,\n      })}\"\n    >\n      ${svgObj.svgName\n        ? html` <sbb-icon\n            name=\"${svgObj.svgName || ''}\"\n            aria-hidden=\"false\"\n            aria-label=\"${getI18nSeatReservation(svgObj.svgName, this._language.current)}\"\n          ></sbb-icon>`\n        : html`${this._getSvgElement(svgObj.svg!)}`}\n    </span>`;\n  }\n\n  private _getSvgElement(svg: string): Element | null {\n    const parser = new DOMParser();\n    const svgString = svg || '<svg></svg>';\n    const svgElm = parser.parseFromString(svgString, 'image/svg+xml').firstElementChild;\n    if (this.stretch && svgElm?.nodeName.toLowerCase() === 'svg') {\n      svgElm.setAttribute('preserveAspectRatio', 'none');\n    }\n    return svgElm;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-graphic': SbbSeatReservationGraphicElement;\n  }\n}\n"],"names":[],"mappings":"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"}