@sbb-esta/lyne-elements-experimental 2.10.0 → 2.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/custom-elements.json +4286 -0
  2. package/development/seat-reservation/common/mapper/icon-mapper.d.ts +112 -0
  3. package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -0
  4. package/development/seat-reservation/common/mapper/icon-mapper.js +72 -0
  5. package/development/seat-reservation/common/mapper/mapper.d.ts +29 -0
  6. package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -0
  7. package/development/seat-reservation/common/mapper/mapper.js +117 -0
  8. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +225 -0
  9. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -0
  10. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +6152 -0
  11. package/development/seat-reservation/common/mapper.d.ts +3 -0
  12. package/development/seat-reservation/common/mapper.d.ts.map +1 -0
  13. package/development/seat-reservation/common/mapper.js +10 -0
  14. package/development/seat-reservation/common/svgs.d.ts +25 -0
  15. package/development/seat-reservation/common/svgs.d.ts.map +1 -0
  16. package/development/seat-reservation/common/svgs.js +48 -0
  17. package/development/seat-reservation/common/translations/i18n.d.ts +19 -0
  18. package/development/seat-reservation/common/translations/i18n.d.ts.map +1 -0
  19. package/development/seat-reservation/common/translations/i18n.js +462 -0
  20. package/development/seat-reservation/common/translations.d.ts +2 -0
  21. package/development/seat-reservation/common/translations.d.ts.map +1 -0
  22. package/development/seat-reservation/common/translations.js +5 -0
  23. package/development/seat-reservation/common.d.ts +5 -0
  24. package/development/seat-reservation/common.d.ts.map +1 -0
  25. package/development/seat-reservation/common.js +18 -0
  26. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +156 -0
  27. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -0
  28. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +706 -0
  29. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.d.ts +29 -0
  30. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.d.ts.map +1 -0
  31. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.js +196 -0
  32. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component.d.ts +2 -0
  33. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component.d.ts.map +1 -0
  34. package/development/seat-reservation/seat-reservation/seat-reservation-scoped-component.js +5 -0
  35. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +62 -0
  36. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -0
  37. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +615 -0
  38. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts +18 -0
  39. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts.map +1 -0
  40. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +108 -0
  41. package/development/seat-reservation/seat-reservation-area.d.ts +2 -0
  42. package/development/seat-reservation/seat-reservation-area.d.ts.map +1 -0
  43. package/development/seat-reservation/seat-reservation-area.js +5 -0
  44. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts +9 -0
  45. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -0
  46. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +326 -0
  47. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts +29 -0
  48. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts.map +1 -0
  49. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +224 -0
  50. package/development/seat-reservation/seat-reservation-graphic.d.ts +2 -0
  51. package/development/seat-reservation/seat-reservation-graphic.d.ts.map +1 -0
  52. package/development/seat-reservation/seat-reservation-graphic.js +5 -0
  53. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +65 -0
  54. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -0
  55. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +576 -0
  56. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts +2 -0
  57. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts.map +1 -0
  58. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.js +5 -0
  59. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +21 -0
  60. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -0
  61. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +123 -0
  62. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts +2 -0
  63. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts.map +1 -0
  64. package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.js +5 -0
  65. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +53 -0
  66. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -0
  67. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +446 -0
  68. package/development/seat-reservation/seat-reservation-place-control.d.ts +2 -0
  69. package/development/seat-reservation/seat-reservation-place-control.d.ts.map +1 -0
  70. package/development/seat-reservation/seat-reservation-place-control.js +5 -0
  71. package/development/seat-reservation/seat-reservation.d.ts +73 -0
  72. package/development/seat-reservation/seat-reservation.d.ts.map +1 -0
  73. package/development/seat-reservation/seat-reservation.js +7 -0
  74. package/development/seat-reservation.d.ts +5 -0
  75. package/development/seat-reservation.d.ts.map +1 -0
  76. package/development/seat-reservation.js +7 -0
  77. package/index.d.ts +14 -0
  78. package/index.js +14 -0
  79. package/package.json +7 -2
  80. package/seat-reservation/common/mapper/icon-mapper.d.ts +112 -0
  81. package/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -0
  82. package/seat-reservation/common/mapper/icon-mapper.js +71 -0
  83. package/seat-reservation/common/mapper/mapper.d.ts +29 -0
  84. package/seat-reservation/common/mapper/mapper.d.ts.map +1 -0
  85. package/seat-reservation/common/mapper/mapper.js +87 -0
  86. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +225 -0
  87. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -0
  88. package/seat-reservation/common/mapper/seat-reservation-sample-data.js +6149 -0
  89. package/seat-reservation/common/mapper.d.ts +3 -0
  90. package/seat-reservation/common/mapper.d.ts.map +1 -0
  91. package/seat-reservation/common/mapper.js +9 -0
  92. package/seat-reservation/common/svgs.d.ts +25 -0
  93. package/seat-reservation/common/svgs.d.ts.map +1 -0
  94. package/seat-reservation/common/svgs.js +250 -0
  95. package/seat-reservation/common/translations/i18n.d.ts +19 -0
  96. package/seat-reservation/common/translations/i18n.d.ts.map +1 -0
  97. package/seat-reservation/common/translations/i18n.js +460 -0
  98. package/seat-reservation/common/translations.d.ts +2 -0
  99. package/seat-reservation/common/translations.d.ts.map +1 -0
  100. package/seat-reservation/common/translations.js +4 -0
  101. package/seat-reservation/common.d.ts +5 -0
  102. package/seat-reservation/common.d.ts.map +1 -0
  103. package/seat-reservation/common.js +17 -0
  104. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +156 -0
  105. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -0
  106. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +435 -0
  107. package/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.d.ts +29 -0
  108. package/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.d.ts.map +1 -0
  109. package/seat-reservation/seat-reservation/seat-reservation-scoped-component/seat-reservation-scoped.component.js +107 -0
  110. package/seat-reservation/seat-reservation/seat-reservation-scoped-component.d.ts +2 -0
  111. package/seat-reservation/seat-reservation/seat-reservation-scoped-component.d.ts.map +1 -0
  112. package/seat-reservation/seat-reservation/seat-reservation-scoped-component.js +4 -0
  113. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts +62 -0
  114. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -0
  115. package/seat-reservation/seat-reservation/seat-reservation.component.js +404 -0
  116. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts +18 -0
  117. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts.map +1 -0
  118. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +49 -0
  119. package/seat-reservation/seat-reservation-area.d.ts +2 -0
  120. package/seat-reservation/seat-reservation-area.d.ts.map +1 -0
  121. package/seat-reservation/seat-reservation-area.js +4 -0
  122. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts +9 -0
  123. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -0
  124. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +317 -0
  125. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts +29 -0
  126. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts.map +1 -0
  127. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +113 -0
  128. package/seat-reservation/seat-reservation-graphic.d.ts +2 -0
  129. package/seat-reservation/seat-reservation-graphic.d.ts.map +1 -0
  130. package/seat-reservation/seat-reservation-graphic.js +4 -0
  131. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +65 -0
  132. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -0
  133. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +248 -0
  134. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts +2 -0
  135. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts.map +1 -0
  136. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.js +4 -0
  137. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +21 -0
  138. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -0
  139. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +80 -0
  140. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts +2 -0
  141. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts.map +1 -0
  142. package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.js +4 -0
  143. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +53 -0
  144. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -0
  145. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +190 -0
  146. package/seat-reservation/seat-reservation-place-control.d.ts +2 -0
  147. package/seat-reservation/seat-reservation-place-control.d.ts.map +1 -0
  148. package/seat-reservation/seat-reservation-place-control.js +4 -0
  149. package/seat-reservation/seat-reservation.d.ts +73 -0
  150. package/seat-reservation/seat-reservation.d.ts.map +1 -0
  151. package/seat-reservation/seat-reservation.js +6 -0
  152. package/seat-reservation.d.ts +5 -0
  153. package/seat-reservation.d.ts.map +1 -0
  154. package/seat-reservation.js +6 -0
@@ -0,0 +1,615 @@
1
+ var __typeError = (msg) => {
2
+ throw TypeError(msg);
3
+ };
4
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
5
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
6
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
7
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
8
+ import { __runInitializers, __esDecorate } from "tslib";
9
+ import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
10
+ import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
11
+ import { css, html, nothing } from "lit";
12
+ import { customElement, property } from "lit/decorators.js";
13
+ import { classMap } from "lit/directives/class-map.js";
14
+ import { styleMap } from "lit/directives/style-map.js";
15
+ import { getI18nSeatReservation } from "../common.js";
16
+ import { SeatReservationBaseElement } from "./seat-reservation-base-element.js";
17
+ import "@sbb-esta/lyne-elements/screen-reader-only.js";
18
+ import "../seat-reservation-area.js";
19
+ import "../seat-reservation-graphic.js";
20
+ import "../seat-reservation-place-control.js";
21
+ import "../seat-reservation-navigation/seat-reservation-navigation-coach.js";
22
+ import "./seat-reservation-scoped-component/seat-reservation-scoped.component.js";
23
+ const style = css`*,
24
+ ::before,
25
+ ::after {
26
+ box-sizing: border-box;
27
+ }
28
+
29
+ :host {
30
+ --sbb-seat-reservation-grid-size: 16px;
31
+ --sbb-seat-reservation-vertical-offset: 0;
32
+ display: block;
33
+ }
34
+ :host ::part(coach-floor) {
35
+ fill: var(--sbb-color-white);
36
+ }
37
+ @media (forced-colors: active) {
38
+ :host ::part(coach-floor) {
39
+ fill: transparent;
40
+ }
41
+ }
42
+
43
+ .sbb-sr__wrapper--vertical {
44
+ width: fit-content;
45
+ position: relative;
46
+ inset-inline-start: var(--sbb-seat-reservation-vertical-offset);
47
+ rotate: 90deg;
48
+ transform-origin: top left;
49
+ }
50
+
51
+ .sbb-sr__wrapper--vertical .sbb-sr__parent {
52
+ overflow-y: hidden;
53
+ }
54
+
55
+ .sbb-sr__wrapper--vertical .sbb-sr__list-coaches {
56
+ width: 100vw;
57
+ }
58
+
59
+ .sbb-sr-navigation--vertical {
60
+ inset-inline-start: var(--sbb-seat-reservation-vertical-offset);
61
+ margin-inline-start: 1.25rem;
62
+ position: absolute;
63
+ }
64
+ .sbb-sr-navigation--vertical .sbb-sr-navigation__list-coaches {
65
+ flex-direction: column;
66
+ }
67
+
68
+ .sbb-sr-navigation__list-coaches {
69
+ list-style: none;
70
+ margin: 0;
71
+ padding: 0;
72
+ font-size: inherit;
73
+ display: flex;
74
+ justify-content: center;
75
+ flex-wrap: nowrap;
76
+ gap: var(--sbb-spacing-fixed-1x);
77
+ min-height: 3.75rem;
78
+ }
79
+
80
+ .sbb-sr__parent {
81
+ overflow-x: scroll;
82
+ padding: 3rem 0;
83
+ }
84
+
85
+ .sbb-sr__list-coaches {
86
+ display: flex;
87
+ gap: 0.25rem;
88
+ padding: 0;
89
+ margin: 0;
90
+ list-style: none;
91
+ }
92
+
93
+ .sbb-sr__item-coach {
94
+ padding: 0;
95
+ margin: 0;
96
+ position: relative;
97
+ }
98
+
99
+ .sbb-sr-coach-wrapper__table {
100
+ outline: 0;
101
+ }`;
102
+ let SbbSeatReservationElement = (() => {
103
+ var _seatReservation_accessor_storage, _hasNavigation_accessor_storage, _alignVertical_accessor_storage, _maxReservations_accessor_storage, _preventPlaceClick_accessor_storage, _a;
104
+ let _classDecorators = [customElement("sbb-seat-reservation")];
105
+ let _classDescriptor;
106
+ let _classExtraInitializers = [];
107
+ let _classThis;
108
+ let _classSuper = SeatReservationBaseElement;
109
+ let _seatReservation_decorators;
110
+ let _seatReservation_initializers = [];
111
+ let _seatReservation_extraInitializers = [];
112
+ let _hasNavigation_decorators;
113
+ let _hasNavigation_initializers = [];
114
+ let _hasNavigation_extraInitializers = [];
115
+ let _alignVertical_decorators;
116
+ let _alignVertical_initializers = [];
117
+ let _alignVertical_extraInitializers = [];
118
+ let _maxReservations_decorators;
119
+ let _maxReservations_initializers = [];
120
+ let _maxReservations_extraInitializers = [];
121
+ let _preventPlaceClick_decorators;
122
+ let _preventPlaceClick_initializers = [];
123
+ let _preventPlaceClick_extraInitializers = [];
124
+ _a = class extends _classSuper {
125
+ constructor() {
126
+ super(...arguments);
127
+ __privateAdd(this, _seatReservation_accessor_storage);
128
+ __privateAdd(this, _hasNavigation_accessor_storage);
129
+ __privateAdd(this, _alignVertical_accessor_storage);
130
+ __privateAdd(this, _maxReservations_accessor_storage);
131
+ __privateAdd(this, _preventPlaceClick_accessor_storage);
132
+ __privateSet(this, _seatReservation_accessor_storage, __runInitializers(this, _seatReservation_initializers, null));
133
+ __privateSet(this, _hasNavigation_accessor_storage, (__runInitializers(this, _seatReservation_extraInitializers), __runInitializers(this, _hasNavigation_initializers, true)));
134
+ __privateSet(this, _alignVertical_accessor_storage, (__runInitializers(this, _hasNavigation_extraInitializers), __runInitializers(this, _alignVertical_initializers, false)));
135
+ __privateSet(this, _maxReservations_accessor_storage, (__runInitializers(this, _alignVertical_extraInitializers), __runInitializers(this, _maxReservations_initializers, null)));
136
+ __privateSet(this, _preventPlaceClick_accessor_storage, (__runInitializers(this, _maxReservations_extraInitializers), __runInitializers(this, _preventPlaceClick_initializers, false)));
137
+ this._language = (__runInitializers(this, _preventPlaceClick_extraInitializers), new SbbLanguageController(this));
138
+ this._notAreaElements = [
139
+ "DRIVER_AREA_FULL",
140
+ "COACH_PASSAGE",
141
+ "COACH_WALL_NO_PASSAGE",
142
+ "COMPARTMENT_PASSAGE",
143
+ "COMPARTMENT_PASSAGE_HIGH",
144
+ "COMPARTMENT_PASSAGE_MIDDLE",
145
+ "COMPARTMENT_PASSAGE_LOW"
146
+ ];
147
+ this._notFixedRotatableAreaIcons = ["ENTRY_EXIT"];
148
+ }
149
+ /** The seat reservation object which contains all coaches and places */
150
+ get seatReservation() {
151
+ return __privateGet(this, _seatReservation_accessor_storage);
152
+ }
153
+ set seatReservation(value) {
154
+ __privateSet(this, _seatReservation_accessor_storage, value);
155
+ }
156
+ /** The seat resvervation navigation can be toggled by this property */
157
+ get hasNavigation() {
158
+ return __privateGet(this, _hasNavigation_accessor_storage);
159
+ }
160
+ set hasNavigation(value) {
161
+ __privateSet(this, _hasNavigation_accessor_storage, value);
162
+ }
163
+ /** controls the visual represention of seat reservation in a horizonal or vertical alignment */
164
+ get alignVertical() {
165
+ return __privateGet(this, _alignVertical_accessor_storage);
166
+ }
167
+ set alignVertical(value) {
168
+ __privateSet(this, _alignVertical_accessor_storage, value);
169
+ }
170
+ /** Maximal number of possible clickable seats */
171
+ get maxReservations() {
172
+ return __privateGet(this, _maxReservations_accessor_storage);
173
+ }
174
+ set maxReservations(value) {
175
+ __privateSet(this, _maxReservations_accessor_storage, value);
176
+ }
177
+ /** Any click functionality is prevented */
178
+ get preventPlaceClick() {
179
+ return __privateGet(this, _preventPlaceClick_accessor_storage);
180
+ }
181
+ set preventPlaceClick(value) {
182
+ __privateSet(this, _preventPlaceClick_accessor_storage, value);
183
+ }
184
+ willUpdate(changedProperties) {
185
+ var _a2, _b;
186
+ super.willUpdate(changedProperties);
187
+ if (changedProperties.has("hasNavigation")) {
188
+ if (this.hasNavigation) {
189
+ (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelectorAll("table").forEach((table) => table.removeAttribute("tabindex"));
190
+ } else {
191
+ (_b = this.shadowRoot) == null ? void 0 : _b.querySelectorAll("table").forEach((table) => table.setAttribute("tabindex", "0"));
192
+ }
193
+ }
194
+ }
195
+ firstUpdated(changedProperties) {
196
+ super.firstUpdated(changedProperties);
197
+ this._componentSetup();
198
+ }
199
+ render() {
200
+ this._initVehicleSeatReservationConstruction();
201
+ return this._coachesHtmlTemplate || null;
202
+ }
203
+ _componentSetup() {
204
+ this.initNavigationSelectionByScrollEvent();
205
+ }
206
+ _initVehicleSeatReservationConstruction() {
207
+ var _a2;
208
+ const coachItems = JSON.parse(JSON.stringify((_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems));
209
+ const classAlignVertical = this.alignVertical ? "sbb-sr__wrapper--vertical" : "";
210
+ this._coachesHtmlTemplate = html`
211
+ <div>
212
+ <sbb-screen-reader-only>
213
+ <input
214
+ id="first-tab-element"
215
+ role="contentinfo"
216
+ type="text"
217
+ aria-label="${getI18nSeatReservation("SEAT_RESERVATION_BEGIN", this._language.current)}"
218
+ readonly
219
+ />
220
+ </sbb-screen-reader-only>
221
+
222
+ <div @keydown=${(evt) => this.handleKeyboardEvent(evt)}>
223
+ ${this._renderNavigation()}
224
+ <div class="sbb-sr__wrapper ${classAlignVertical}">
225
+ <div id="sbb-sr__parent-area" class="sbb-sr__parent" tabindex="-1">
226
+ <ul class="sbb-sr__list-coaches" role="presentation">
227
+ ${this._renderCoaches(coachItems)}
228
+ </ul>
229
+ </div>
230
+ </div>
231
+ </div>
232
+
233
+ <sbb-screen-reader-only>
234
+ <input
235
+ id="last-tab-element"
236
+ role="contentinfo"
237
+ type="text"
238
+ aria-label="${getI18nSeatReservation("SEAT_RESERVATION_END", this._language.current)}"
239
+ readonly
240
+ />
241
+ </sbb-screen-reader-only>
242
+ </div>
243
+ `;
244
+ }
245
+ _renderNavigation() {
246
+ var _a2;
247
+ if (!this.hasNavigation) {
248
+ return null;
249
+ }
250
+ return html`
251
+ <nav class="${classMap({ "sbb-sr-navigation--vertical": this.alignVertical })}">
252
+ <ul
253
+ class="sbb-sr-navigation__list-coaches"
254
+ aria-label="${getI18nSeatReservation("SEAT_RESERVATION_NAVIGATION", this._language.current)}"
255
+ >
256
+ ${(_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems.map((coachItem, index) => {
257
+ var _a3, _b;
258
+ return html`<li>
259
+ <sbb-seat-reservation-navigation-coach
260
+ @selectCoach=${(event) => this._onSelectNavCoach(event)}
261
+ @focusCoach=${() => this._onFocusNavCoach()}
262
+ index="${index}"
263
+ coach-id="${coachItem.id}"
264
+ .selected=${this.selectedCoachIndex === index}
265
+ .focused=${this.focusedCoachIndex === index}
266
+ .propertyIds="${coachItem.propertyIds}"
267
+ .travelClass="${coachItem.travelClass}"
268
+ ?driver-area="${!((_a3 = coachItem.places) == null ? void 0 : _a3.length)}"
269
+ ?first="${index === 0}"
270
+ ?last="${index === ((_b = this.seatReservation) == null ? void 0 : _b.coachItems.length) - 1}"
271
+ ?vertical="${this.alignVertical}"
272
+ >
273
+ </sbb-seat-reservation-navigation-coach>
274
+ </li>`;
275
+ })}
276
+ </ul>
277
+ </nav>
278
+ `;
279
+ }
280
+ /**
281
+ *
282
+ * @param coaches
283
+ * @returns
284
+ */
285
+ _renderCoaches(coaches) {
286
+ if (!coaches) {
287
+ return null;
288
+ }
289
+ return coaches.map((coachItem, index) => {
290
+ return html`
291
+ <li class="sbb-sr__item-coach">${this._renderCoachElement(coachItem, index)}</li>
292
+ `;
293
+ });
294
+ }
295
+ _renderCoachElement(coachItem, index) {
296
+ const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);
297
+ const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);
298
+ return html` <sbb-seat-reservation-scoped
299
+ scoped-classes="coach-wrapper"
300
+ height="${calculatedCoachDimension.h}px"
301
+ width="${calculatedCoachDimension.w}px"
302
+ >
303
+ ${this._getRenderedCoachBorders(coachItem, index)}
304
+ ${this._getRenderedGraphicalElements(coachItem.graphicElements || [], coachItem.dimension)}
305
+ ${this._getRenderedServiceElements(coachItem.serviceElements)}
306
+ <table
307
+ @focus=${() => this.onFocusTableCoachAndPreselectPlace(index)}
308
+ id="sbb-sr-coach-${index}"
309
+ class="sbb-sr-coach-wrapper__table"
310
+ aria-describedby="sbb-sr-coach-caption-${index}"
311
+ >
312
+ <caption id="sbb-sr-coach-caption-${index}" tabindex="-1">
313
+ <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>
314
+ </caption>
315
+ ${this._getRenderedRowPlaces(coachItem, index)}
316
+ </table>
317
+ </sbb-seat-reservation-scoped>`;
318
+ }
319
+ _getRenderedCoachBorders(coachItem, coachIndex) {
320
+ const allElements = coachItem.graphicElements;
321
+ const COACH_PASSAGE_WIDTH = 1;
322
+ const driverArea = allElements == null ? void 0 : allElements.find((element) => element.icon === "DRIVER_AREA_FULL");
323
+ 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;
325
+ return html`
326
+ <sbb-seat-reservation-scoped
327
+ scoped-classes="coach-border"
328
+ inset-block-start="${this.coachBorderPadding * -1}px"
329
+ inset-inline-start="${borderOffsetX}px"
330
+ >
331
+ <sbb-seat-reservation-graphic
332
+ name="COACH_BORDER_MIDDLE"
333
+ width=${borderWidth * this.baseGridSize}
334
+ height=${(coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize}
335
+ ?stretch=${true}
336
+ role="presentation"
337
+ ></sbb-seat-reservation-graphic>
338
+ </sbb-seat-reservation-scoped>
339
+ `;
340
+ }
341
+ _getRenderedRowPlaces(coach, coachIndex) {
342
+ if (!coach.places) {
343
+ return null;
344
+ }
345
+ const tableRowPlaces = {};
346
+ for (const place of coach.places) {
347
+ if (!tableRowPlaces[place.position.y]) {
348
+ tableRowPlaces[place.position.y] = [place];
349
+ } else {
350
+ tableRowPlaces[place.position.y].push(place);
351
+ }
352
+ }
353
+ return Object.values(tableRowPlaces).map((rowPlaces, index) => {
354
+ return html`
355
+ <tr id="row-${coachIndex}-${rowPlaces[0].position.y}" data-row-index=${index}>
356
+ ${this._getRenderedColumnPlaces(rowPlaces, coachIndex)}
357
+ </tr>
358
+ `;
359
+ }).flatMap((rowTemplate) => rowTemplate);
360
+ }
361
+ _getRenderedColumnPlaces(places, coachIndex) {
362
+ places.sort((placeA, placeB) => Number(placeA.position.x) - Number(placeB.position.x));
363
+ return places == null ? void 0 : places.map((place, index) => {
364
+ const calculatedInternalDimension = this.getCalculatedDimension(place.dimension);
365
+ const calculatedInternalPosition = this.getCalculatedPosition(place.position);
366
+ const textRotation = this.alignVertical ? -90 : 0;
367
+ return html`
368
+ <sbb-seat-reservation-scoped
369
+ scoped-classes="graphical-element"
370
+ inset-block-start="${calculatedInternalPosition.y}px"
371
+ inset-inline-start="${calculatedInternalPosition.x}px"
372
+ width="${calculatedInternalDimension.w}px"
373
+ height="${calculatedInternalDimension.h}px"
374
+ z-index="${place.position.z}"
375
+ cell-id="cell-${coachIndex}-${place.position.y}-${index}"
376
+ >
377
+ <sbb-seat-reservation-place-control
378
+ @selectPlace=${(selectPlaceEvent) => this._onSelectPlace(selectPlaceEvent)}
379
+ exportparts="sbb-sr-place-part"
380
+ id="seat-reservation__place-button-${coachIndex}-${place.number}"
381
+ class="seat-reservation-place-control"
382
+ data-cell-id="${coachIndex}-${place.position.y}-${index}"
383
+ text=${place.number}
384
+ type=${place.type}
385
+ state=${place.state}
386
+ width=${place.dimension.w * this.baseGridSize}
387
+ height=${place.dimension.h * this.baseGridSize}
388
+ rotation=${place.rotation ?? nothing}
389
+ text-rotation=${textRotation}
390
+ coach-index=${coachIndex}
391
+ .propertyIds=${place.propertyIds}
392
+ .preventClick=${this.preventPlaceClick}
393
+ ></sbb-seat-reservation-place-control>
394
+ </sbb-seat-reservation-scoped>
395
+ `;
396
+ });
397
+ }
398
+ _getRenderedGraphicalElements(graphicalElements, coachDimension) {
399
+ if (!graphicalElements) {
400
+ return null;
401
+ }
402
+ return graphicalElements == null ? void 0 : graphicalElements.map((graphicalElement) => {
403
+ const icon = graphicalElement.icon ?? "";
404
+ const elementRotation = graphicalElement.rotation || 0;
405
+ const isNotFixedRotationGraphicalElement = this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon) === -1;
406
+ const elementFixedRotation = this.alignVertical && isNotFixedRotationGraphicalElement ? elementRotation - 90 : elementRotation;
407
+ if (this._notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {
408
+ return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);
409
+ }
410
+ return this._getRenderElementWithArea(graphicalElement, elementFixedRotation, coachDimension);
411
+ });
412
+ }
413
+ _getRenderElementWithArea(graphicalElement, rotation, coachDimension) {
414
+ var _a2;
415
+ const isNotTableGraphicTempFix = ((_a2 = graphicalElement.icon) == null ? void 0 : _a2.indexOf("TABLE")) === -1;
416
+ const areaProperty = graphicalElement.icon && isNotTableGraphicTempFix ? graphicalElement.icon : null;
417
+ const stretchHeight = areaProperty !== "ENTRY_EXIT";
418
+ const ariaLabelForArea = graphicalElement.icon ? getI18nSeatReservation(graphicalElement.icon, this._language.current) : nothing;
419
+ const calculatedDimension = this.getCalculatedDimension(graphicalElement.dimension, coachDimension, true, stretchHeight);
420
+ const calculatedPosition = this.getCalculatedPosition(graphicalElement.position, graphicalElement.dimension, coachDimension, true);
421
+ let elementMounting = "free";
422
+ if (graphicalElement.position.y === this.coachBorderOffset * -1) {
423
+ elementMounting = "upper-border";
424
+ } else if (graphicalElement.position.y + graphicalElement.dimension.h === coachDimension.h + this.coachBorderOffset) {
425
+ elementMounting = "lower-border";
426
+ }
427
+ return html`
428
+ <sbb-seat-reservation-scoped
429
+ scoped-classes="graphical-element"
430
+ inset-block-start="${calculatedPosition.y}px"
431
+ inset-inline-start="${calculatedPosition.x}px"
432
+ width="${calculatedDimension.w}px"
433
+ height="${calculatedDimension.h}px"
434
+ z-index="${graphicalElement.position.z}"
435
+ >
436
+ <sbb-seat-reservation-area
437
+ style=${styleMap({
438
+ "--sbb-reservation-area-width": graphicalElement.dimension.w * this.baseGridSize,
439
+ "--sbb-reservation-area-height": graphicalElement.dimension.h * this.baseGridSize
440
+ })}
441
+ mounting=${elementMounting}
442
+ background="dark"
443
+ aria-hidden="true"
444
+ title=${ariaLabelForArea}
445
+ >
446
+ ${areaProperty ? html`
447
+ <sbb-seat-reservation-graphic
448
+ name=${areaProperty}
449
+ rotation=${rotation}
450
+ width=${this.baseGridSize}
451
+ height=${this.baseGridSize}
452
+ role="img"
453
+ aria-hidden="true"
454
+ ></sbb-seat-reservation-graphic>
455
+ ` : nothing}
456
+ </sbb-seat-reservation-area>
457
+ </sbb-seat-reservation-scoped>
458
+ `;
459
+ }
460
+ _getRenderElementWithoutArea(graphicalElement, rotation, coachDimension) {
461
+ var _a2;
462
+ const calculatedDimension = this.getCalculatedDimension(graphicalElement.dimension, coachDimension);
463
+ 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);
465
+ return html`
466
+ <sbb-seat-reservation-scoped
467
+ scoped-classes="graphical-element"
468
+ inset-block-start="${calculatedPosition.y}px"
469
+ inset-inline-start="${calculatedPosition.x}px"
470
+ width="${calculatedDimension.w}px"
471
+ height="${calculatedDimension.h}px"
472
+ z-index="${graphicalElement.position.z}"
473
+ >
474
+ <sbb-seat-reservation-graphic
475
+ name=${icon ?? nothing}
476
+ width=${graphicalElement.dimension.w * this.baseGridSize}
477
+ height=${graphicalElement.dimension.h * this.baseGridSize}
478
+ rotation=${rotation}
479
+ aria-hidden="true"
480
+ ?stretch=${true}
481
+ ></sbb-seat-reservation-graphic>
482
+ </sbb-seat-reservation-scoped>
483
+ `;
484
+ }
485
+ _getRenderedServiceElements(serviceElements) {
486
+ if (!serviceElements) {
487
+ return null;
488
+ }
489
+ return serviceElements == null ? void 0 : serviceElements.map((serviceElement) => {
490
+ const titleDescription = serviceElement.icon ? getI18nSeatReservation(serviceElement.icon, this._language.current) : null;
491
+ const calculatedcCmpartmentNumberDimension = this.getCalculatedDimension(serviceElement.dimension);
492
+ const calculatedcCmpartmentNumberPosition = this.getCalculatedPosition(serviceElement.position);
493
+ const elementRotation = serviceElement.rotation || 0;
494
+ const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;
495
+ return html`
496
+ <sbb-seat-reservation-scoped
497
+ scoped-classes="graphical-element"
498
+ inset-block-start="${calculatedcCmpartmentNumberPosition.y}px"
499
+ inset-inline-start="${calculatedcCmpartmentNumberPosition.x}px"
500
+ width="${calculatedcCmpartmentNumberDimension.w}px"
501
+ height="${calculatedcCmpartmentNumberDimension.h}px"
502
+ z-index="${serviceElement.position.z}"
503
+ >
504
+ <sbb-seat-reservation-graphic
505
+ name=${serviceElement.icon ?? nothing}
506
+ width=${serviceElement.dimension.w * this.baseGridSize}
507
+ height=${serviceElement.dimension.h * this.baseGridSize}
508
+ .rotation=${elementFixedRotation}
509
+ role="img"
510
+ aria-hidden="true"
511
+ title=${titleDescription ?? nothing}
512
+ ></sbb-seat-reservation-graphic>
513
+ </sbb-seat-reservation-scoped>
514
+ `;
515
+ });
516
+ }
517
+ /**
518
+ * Manages the selected place event triggered from the place
519
+ * Each selection emits an array of all selected places
520
+ * @param selectPlaceEvent
521
+ */
522
+ _onSelectPlace(selectPlaceEvent) {
523
+ const selectedPlace = selectPlaceEvent.detail;
524
+ this.preventCoachScrollByPlaceClick = true;
525
+ this.isCochGridFocusable = false;
526
+ if (!this.preventPlaceClick) {
527
+ this.updateSelectedSeatReservationPlaces(selectedPlace);
528
+ this.updateCurrentSelectedPlaceInCoach(selectedPlace);
529
+ }
530
+ }
531
+ _onSelectNavCoach(event) {
532
+ const selectedNavCoachIndex = event.detail;
533
+ this.isKeyboardNavigation = false;
534
+ if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {
535
+ this.unfocusPlaceElement();
536
+ this.scrollToSelectedNavCoach(selectedNavCoachIndex);
537
+ } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {
538
+ this.updateCurrentSelectedCoach();
539
+ this.preselectPlaceInCoach();
540
+ }
541
+ }
542
+ _onFocusNavCoach() {
543
+ if (!this.preventCoachScrollByPlaceClick) {
544
+ this.preselectPlaceInCoach();
545
+ } else {
546
+ this.focusPlaceElement(this.currSelectedPlace);
547
+ }
548
+ this.isAutoScrolling = false;
549
+ }
550
+ _getDescriptionTableCoach(coachItem) {
551
+ var _a2;
552
+ if (!((_a2 = coachItem.places) == null ? void 0 : _a2.length)) {
553
+ return getI18nSeatReservation("COACH_BLOCKED_TABLE_CAPTION", this._language.current, [
554
+ coachItem.id
555
+ ]);
556
+ }
557
+ let tableCoachDescription = "";
558
+ const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements);
559
+ const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements);
560
+ tableCoachDescription = getI18nSeatReservation("COACH_TABLE_CAPTION", this._language.current, [
561
+ coachItem.id
562
+ ]);
563
+ if (!!areaDescriptions || !!serviceDescriptions) {
564
+ tableCoachDescription += ". " + getI18nSeatReservation("COACH_AVAILABLE_SERVICES", this._language.current) + ": ";
565
+ tableCoachDescription += serviceDescriptions + ", " + areaDescriptions + ".";
566
+ }
567
+ return tableCoachDescription;
568
+ }
569
+ _getTitleDescriptionListString(descriptionsElements) {
570
+ const uniqueDescriptions = [];
571
+ return descriptionsElements == null ? void 0 : descriptionsElements.map((descriptionElement) => {
572
+ const icon = descriptionElement.icon;
573
+ if (!icon)
574
+ return null;
575
+ const descriptionAlreayExist = uniqueDescriptions.indexOf(icon) > -1;
576
+ const translation = getI18nSeatReservation(descriptionElement.icon, this._language.current);
577
+ const isValidDescription = this._notFixedRotatableAreaIcons.indexOf(icon) === -1 && this._notAreaElements.indexOf(icon) === -1;
578
+ if (!descriptionAlreayExist) {
579
+ uniqueDescriptions.push(descriptionElement.icon);
580
+ }
581
+ return !!translation && !descriptionAlreayExist && isValidDescription ? translation : null;
582
+ }).filter((description) => !!description).join(", ");
583
+ }
584
+ }, _seatReservation_accessor_storage = new WeakMap(), _hasNavigation_accessor_storage = new WeakMap(), _alignVertical_accessor_storage = new WeakMap(), _maxReservations_accessor_storage = new WeakMap(), _preventPlaceClick_accessor_storage = new WeakMap(), _classThis = _a, (() => {
585
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
586
+ _seatReservation_decorators = [property({ attribute: "seat-reservation", type: Object })];
587
+ _hasNavigation_decorators = [forceType(), property({ attribute: "has-navigation", type: Boolean })];
588
+ _alignVertical_decorators = [forceType(), property({ attribute: "align-vertical", type: Boolean })];
589
+ _maxReservations_decorators = [forceType(), property({ attribute: "max-reservations", type: Number })];
590
+ _preventPlaceClick_decorators = [forceType(), property({ attribute: "prevent-place-click", type: Boolean })];
591
+ __esDecorate(_a, null, _seatReservation_decorators, { kind: "accessor", name: "seatReservation", static: false, private: false, access: { has: (obj) => "seatReservation" in obj, get: (obj) => obj.seatReservation, set: (obj, value) => {
592
+ obj.seatReservation = value;
593
+ } }, metadata: _metadata }, _seatReservation_initializers, _seatReservation_extraInitializers);
594
+ __esDecorate(_a, null, _hasNavigation_decorators, { kind: "accessor", name: "hasNavigation", static: false, private: false, access: { has: (obj) => "hasNavigation" in obj, get: (obj) => obj.hasNavigation, set: (obj, value) => {
595
+ obj.hasNavigation = value;
596
+ } }, metadata: _metadata }, _hasNavigation_initializers, _hasNavigation_extraInitializers);
597
+ __esDecorate(_a, null, _alignVertical_decorators, { kind: "accessor", name: "alignVertical", static: false, private: false, access: { has: (obj) => "alignVertical" in obj, get: (obj) => obj.alignVertical, set: (obj, value) => {
598
+ obj.alignVertical = value;
599
+ } }, metadata: _metadata }, _alignVertical_initializers, _alignVertical_extraInitializers);
600
+ __esDecorate(_a, null, _maxReservations_decorators, { kind: "accessor", name: "maxReservations", static: false, private: false, access: { has: (obj) => "maxReservations" in obj, get: (obj) => obj.maxReservations, set: (obj, value) => {
601
+ obj.maxReservations = value;
602
+ } }, metadata: _metadata }, _maxReservations_initializers, _maxReservations_extraInitializers);
603
+ __esDecorate(_a, null, _preventPlaceClick_decorators, { kind: "accessor", name: "preventPlaceClick", static: false, private: false, access: { has: (obj) => "preventPlaceClick" in obj, get: (obj) => obj.preventPlaceClick, set: (obj, value) => {
604
+ obj.preventPlaceClick = value;
605
+ } }, metadata: _metadata }, _preventPlaceClick_initializers, _preventPlaceClick_extraInitializers);
606
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
607
+ _classThis = _classDescriptor.value;
608
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
609
+ })(), _a.styles = style, __runInitializers(_classThis, _classExtraInitializers), _a;
610
+ return _classThis;
611
+ })();
612
+ export {
613
+ SbbSeatReservationElement
614
+ };
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 '../seat-reservation.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-component.js';\n\n/**\n * Describe the purpose of the component with a single short sentence.\n *\n * @event {CustomEvent<SeatReservationPlaceSelection>} 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 resvervation 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 represention 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.isCochGridFocusable = 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":"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"}