@sbb-esta/lyne-elements-experimental 2.10.1 → 3.0.0-next.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.
- package/custom-elements.json +4294 -8
- package/development/journey-summary/journey-summary.component.d.ts +5 -3
- package/development/journey-summary/journey-summary.component.d.ts.map +1 -1
- package/development/journey-summary/journey-summary.component.js +5 -2
- package/development/pearl-chain/pearl-chain.component.d.ts +5 -3
- package/development/pearl-chain/pearl-chain.component.d.ts.map +1 -1
- package/development/pearl-chain/pearl-chain.component.js +5 -2
- package/development/pearl-chain-time/pearl-chain-time.component.d.ts +5 -3
- package/development/pearl-chain-time/pearl-chain-time.component.d.ts.map +1 -1
- package/development/pearl-chain-time/pearl-chain-time.component.js +5 -2
- package/development/seat-reservation/common/mapper/icon-mapper.d.ts +112 -0
- package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -0
- package/development/seat-reservation/common/mapper/icon-mapper.js +72 -0
- package/development/seat-reservation/common/mapper/mapper.d.ts +29 -0
- package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -0
- package/development/seat-reservation/common/mapper/mapper.js +117 -0
- package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +225 -0
- package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -0
- package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +6152 -0
- package/development/seat-reservation/common/mapper.d.ts +3 -0
- package/development/seat-reservation/common/mapper.d.ts.map +1 -0
- package/development/seat-reservation/common/mapper.js +10 -0
- package/development/seat-reservation/common/svgs.d.ts +25 -0
- package/development/seat-reservation/common/svgs.d.ts.map +1 -0
- package/development/seat-reservation/common/svgs.js +48 -0
- package/development/seat-reservation/common/translations/i18n.d.ts +19 -0
- package/development/seat-reservation/common/translations/i18n.d.ts.map +1 -0
- package/development/seat-reservation/common/translations/i18n.js +462 -0
- package/development/seat-reservation/common/translations.d.ts +2 -0
- package/development/seat-reservation/common/translations.d.ts.map +1 -0
- package/development/seat-reservation/common/translations.js +5 -0
- package/development/seat-reservation/common.d.ts +5 -0
- package/development/seat-reservation/common.d.ts.map +1 -0
- package/development/seat-reservation/common.js +18 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +156 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +706 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +29 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +196 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped.d.ts +2 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation/seat-reservation-scoped.js +5 -0
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +62 -0
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation/seat-reservation.component.js +615 -0
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts +18 -0
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +108 -0
- package/development/seat-reservation/seat-reservation-area.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-area.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-area.js +5 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts +9 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +326 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts +29 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +224 -0
- package/development/seat-reservation/seat-reservation-graphic.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-graphic.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-graphic.js +5 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +65 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +576 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.js +5 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +21 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +123 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.js +5 -0
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +53 -0
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +446 -0
- package/development/seat-reservation/seat-reservation-place-control.d.ts +2 -0
- package/development/seat-reservation/seat-reservation-place-control.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation-place-control.js +5 -0
- package/development/seat-reservation/seat-reservation.d.ts +73 -0
- package/development/seat-reservation/seat-reservation.d.ts.map +1 -0
- package/development/seat-reservation/seat-reservation.js +7 -0
- package/development/seat-reservation.d.ts +5 -0
- package/development/seat-reservation.d.ts.map +1 -0
- package/development/seat-reservation.js +7 -0
- package/development/timetable-row/timetable-row.component.d.ts +5 -3
- package/development/timetable-row/timetable-row.component.d.ts.map +1 -1
- package/development/timetable-row/timetable-row.component.js +5 -2
- package/index.d.ts +14 -0
- package/index.js +14 -0
- package/journey-summary/journey-summary.component.d.ts +5 -3
- package/journey-summary/journey-summary.component.d.ts.map +1 -1
- package/journey-summary/journey-summary.component.js +4 -1
- package/package.json +7 -2
- package/pearl-chain/pearl-chain.component.d.ts +5 -3
- package/pearl-chain/pearl-chain.component.d.ts.map +1 -1
- package/pearl-chain/pearl-chain.component.js +4 -1
- package/pearl-chain-time/pearl-chain-time.component.d.ts +5 -3
- package/pearl-chain-time/pearl-chain-time.component.d.ts.map +1 -1
- package/pearl-chain-time/pearl-chain-time.component.js +4 -1
- package/seat-reservation/common/mapper/icon-mapper.d.ts +112 -0
- package/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -0
- package/seat-reservation/common/mapper/icon-mapper.js +71 -0
- package/seat-reservation/common/mapper/mapper.d.ts +29 -0
- package/seat-reservation/common/mapper/mapper.d.ts.map +1 -0
- package/seat-reservation/common/mapper/mapper.js +87 -0
- package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +225 -0
- package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -0
- package/seat-reservation/common/mapper/seat-reservation-sample-data.js +6149 -0
- package/seat-reservation/common/mapper.d.ts +3 -0
- package/seat-reservation/common/mapper.d.ts.map +1 -0
- package/seat-reservation/common/mapper.js +9 -0
- package/seat-reservation/common/svgs.d.ts +25 -0
- package/seat-reservation/common/svgs.d.ts.map +1 -0
- package/seat-reservation/common/svgs.js +250 -0
- package/seat-reservation/common/translations/i18n.d.ts +19 -0
- package/seat-reservation/common/translations/i18n.d.ts.map +1 -0
- package/seat-reservation/common/translations/i18n.js +460 -0
- package/seat-reservation/common/translations.d.ts +2 -0
- package/seat-reservation/common/translations.d.ts.map +1 -0
- package/seat-reservation/common/translations.js +4 -0
- package/seat-reservation/common.d.ts +5 -0
- package/seat-reservation/common.d.ts.map +1 -0
- package/seat-reservation/common.js +17 -0
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +156 -0
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -0
- package/seat-reservation/seat-reservation/seat-reservation-base-element.js +435 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +29 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +107 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped.d.ts +2 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped.d.ts.map +1 -0
- package/seat-reservation/seat-reservation/seat-reservation-scoped.js +4 -0
- package/seat-reservation/seat-reservation/seat-reservation.component.d.ts +62 -0
- package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation/seat-reservation.component.js +404 -0
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts +18 -0
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +49 -0
- package/seat-reservation/seat-reservation-area.d.ts +2 -0
- package/seat-reservation/seat-reservation-area.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-area.js +4 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts +9 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +317 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts +29 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +113 -0
- package/seat-reservation/seat-reservation-graphic.d.ts +2 -0
- package/seat-reservation/seat-reservation-graphic.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-graphic.js +4 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +65 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +248 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts +2 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-coach.js +4 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +21 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +80 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts +2 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-navigation/seat-reservation-navigation-services.js +4 -0
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +53 -0
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +190 -0
- package/seat-reservation/seat-reservation-place-control.d.ts +2 -0
- package/seat-reservation/seat-reservation-place-control.d.ts.map +1 -0
- package/seat-reservation/seat-reservation-place-control.js +4 -0
- package/seat-reservation/seat-reservation.d.ts +73 -0
- package/seat-reservation/seat-reservation.d.ts.map +1 -0
- package/seat-reservation/seat-reservation.js +6 -0
- package/seat-reservation.d.ts +5 -0
- package/seat-reservation.d.ts.map +1 -0
- package/seat-reservation.js +6 -0
- package/timetable-row/timetable-row.component.d.ts +5 -3
- package/timetable-row/timetable-row.component.d.ts.map +1 -1
- package/timetable-row/timetable-row.component.js +4 -1
|
@@ -0,0 +1,706 @@
|
|
|
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 { isArrowKeyOrPageKeysPressed } from "@sbb-esta/lyne-elements/core/a11y.js";
|
|
10
|
+
import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
|
|
11
|
+
import { EventEmitter } from "@sbb-esta/lyne-elements/core/eventing.js";
|
|
12
|
+
import { LitElement } from "lit";
|
|
13
|
+
import { property, state } from "lit/decorators.js";
|
|
14
|
+
import { mapPlaceInfosToPlaceSelection, mapPlaceAndCoachToSeatReservationPlaceSelection, mapCoachInfosToCoachSelection } from "../common/mapper.js";
|
|
15
|
+
var ScrollDirection;
|
|
16
|
+
(function(ScrollDirection2) {
|
|
17
|
+
ScrollDirection2["right"] = "right";
|
|
18
|
+
ScrollDirection2["left"] = "left";
|
|
19
|
+
})(ScrollDirection || (ScrollDirection = {}));
|
|
20
|
+
let SeatReservationBaseElement = (() => {
|
|
21
|
+
var _seatReservation_accessor_storage, _hasNavigation_accessor_storage, _alignVertical_accessor_storage, _baseGridSize_accessor_storage, _height_accessor_storage, _maxReservations_accessor_storage, _preventPlaceClick_accessor_storage, _selectedCoachIndex_accessor_storage, _focusedCoachIndex_accessor_storage, _a;
|
|
22
|
+
let _classSuper = LitElement;
|
|
23
|
+
let _seatReservation_decorators;
|
|
24
|
+
let _seatReservation_initializers = [];
|
|
25
|
+
let _seatReservation_extraInitializers = [];
|
|
26
|
+
let _hasNavigation_decorators;
|
|
27
|
+
let _hasNavigation_initializers = [];
|
|
28
|
+
let _hasNavigation_extraInitializers = [];
|
|
29
|
+
let _alignVertical_decorators;
|
|
30
|
+
let _alignVertical_initializers = [];
|
|
31
|
+
let _alignVertical_extraInitializers = [];
|
|
32
|
+
let _baseGridSize_decorators;
|
|
33
|
+
let _baseGridSize_initializers = [];
|
|
34
|
+
let _baseGridSize_extraInitializers = [];
|
|
35
|
+
let _height_decorators;
|
|
36
|
+
let _height_initializers = [];
|
|
37
|
+
let _height_extraInitializers = [];
|
|
38
|
+
let _maxReservations_decorators;
|
|
39
|
+
let _maxReservations_initializers = [];
|
|
40
|
+
let _maxReservations_extraInitializers = [];
|
|
41
|
+
let _preventPlaceClick_decorators;
|
|
42
|
+
let _preventPlaceClick_initializers = [];
|
|
43
|
+
let _preventPlaceClick_extraInitializers = [];
|
|
44
|
+
let _selectedCoachIndex_decorators;
|
|
45
|
+
let _selectedCoachIndex_initializers = [];
|
|
46
|
+
let _selectedCoachIndex_extraInitializers = [];
|
|
47
|
+
let _focusedCoachIndex_decorators;
|
|
48
|
+
let _focusedCoachIndex_initializers = [];
|
|
49
|
+
let _focusedCoachIndex_extraInitializers = [];
|
|
50
|
+
return _a = class extends _classSuper {
|
|
51
|
+
constructor() {
|
|
52
|
+
super(...arguments);
|
|
53
|
+
__privateAdd(this, _seatReservation_accessor_storage);
|
|
54
|
+
__privateAdd(this, _hasNavigation_accessor_storage);
|
|
55
|
+
__privateAdd(this, _alignVertical_accessor_storage);
|
|
56
|
+
__privateAdd(this, _baseGridSize_accessor_storage);
|
|
57
|
+
__privateAdd(this, _height_accessor_storage);
|
|
58
|
+
__privateAdd(this, _maxReservations_accessor_storage);
|
|
59
|
+
__privateAdd(this, _preventPlaceClick_accessor_storage);
|
|
60
|
+
__privateAdd(this, _selectedCoachIndex_accessor_storage);
|
|
61
|
+
__privateAdd(this, _focusedCoachIndex_accessor_storage);
|
|
62
|
+
__privateSet(this, _seatReservation_accessor_storage, __runInitializers(this, _seatReservation_initializers, null));
|
|
63
|
+
__privateSet(this, _hasNavigation_accessor_storage, (__runInitializers(this, _seatReservation_extraInitializers), __runInitializers(this, _hasNavigation_initializers, true)));
|
|
64
|
+
__privateSet(this, _alignVertical_accessor_storage, (__runInitializers(this, _hasNavigation_extraInitializers), __runInitializers(this, _alignVertical_initializers, false)));
|
|
65
|
+
__privateSet(this, _baseGridSize_accessor_storage, (__runInitializers(this, _alignVertical_extraInitializers), __runInitializers(this, _baseGridSize_initializers, 16)));
|
|
66
|
+
__privateSet(this, _height_accessor_storage, (__runInitializers(this, _baseGridSize_extraInitializers), __runInitializers(this, _height_initializers, null)));
|
|
67
|
+
__privateSet(this, _maxReservations_accessor_storage, (__runInitializers(this, _height_extraInitializers), __runInitializers(this, _maxReservations_initializers, null)));
|
|
68
|
+
__privateSet(this, _preventPlaceClick_accessor_storage, (__runInitializers(this, _maxReservations_extraInitializers), __runInitializers(this, _preventPlaceClick_initializers, false)));
|
|
69
|
+
__privateSet(this, _selectedCoachIndex_accessor_storage, (__runInitializers(this, _preventPlaceClick_extraInitializers), __runInitializers(this, _selectedCoachIndex_initializers, -1)));
|
|
70
|
+
__privateSet(this, _focusedCoachIndex_accessor_storage, (__runInitializers(this, _selectedCoachIndex_extraInitializers), __runInitializers(this, _focusedCoachIndex_initializers, -1)));
|
|
71
|
+
this.selectedPlaces = (__runInitializers(this, _focusedCoachIndex_extraInitializers), new EventEmitter(this, _a.events.selectedPlaces));
|
|
72
|
+
this.selectedCoach = new EventEmitter(this, _a.events.selectedCoach);
|
|
73
|
+
this.coachBorderPadding = 6;
|
|
74
|
+
this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;
|
|
75
|
+
this.currScrollDirection = ScrollDirection.right;
|
|
76
|
+
this.maxCalcCoachsWidth = 0;
|
|
77
|
+
this.scrollCoachsAreaWidth = 0;
|
|
78
|
+
this.triggerCoachPositionsCollection = [];
|
|
79
|
+
this.firstTabElement = null;
|
|
80
|
+
this.lastTabElement = null;
|
|
81
|
+
this.coachScrollArea = null;
|
|
82
|
+
this.currSelectedPlace = null;
|
|
83
|
+
this.currSelectedPlaceElementId = null;
|
|
84
|
+
this.currSelectedCoachIndex = -1;
|
|
85
|
+
this.preventCoachScrollByPlaceClick = false;
|
|
86
|
+
this.selectedSeatReservationPlaces = [];
|
|
87
|
+
this.seatReservationWithoutNavigationHasFocus = false;
|
|
88
|
+
this.isCochGridFocusable = false;
|
|
89
|
+
this.isAutoScrolling = false;
|
|
90
|
+
this.isKeyboardNavigation = false;
|
|
91
|
+
this.keyboardNavigationEvents = {
|
|
92
|
+
ArrowLeft: "ArrowLeft",
|
|
93
|
+
ArrowRight: "ArrowRight",
|
|
94
|
+
ArrowUp: "ArrowUp",
|
|
95
|
+
ArrowDown: "ArrowDown",
|
|
96
|
+
Tab: "Tab",
|
|
97
|
+
Enter: "Enter"
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
/** The seat reservation object which contains all coaches and places */
|
|
101
|
+
get seatReservation() {
|
|
102
|
+
return __privateGet(this, _seatReservation_accessor_storage);
|
|
103
|
+
}
|
|
104
|
+
set seatReservation(value) {
|
|
105
|
+
__privateSet(this, _seatReservation_accessor_storage, value);
|
|
106
|
+
}
|
|
107
|
+
/** The seat resvervation navigation can be toggled by this property */
|
|
108
|
+
get hasNavigation() {
|
|
109
|
+
return __privateGet(this, _hasNavigation_accessor_storage);
|
|
110
|
+
}
|
|
111
|
+
set hasNavigation(value) {
|
|
112
|
+
__privateSet(this, _hasNavigation_accessor_storage, value);
|
|
113
|
+
}
|
|
114
|
+
/** The seat reservation area is aligned vertically */
|
|
115
|
+
get alignVertical() {
|
|
116
|
+
return __privateGet(this, _alignVertical_accessor_storage);
|
|
117
|
+
}
|
|
118
|
+
set alignVertical(value) {
|
|
119
|
+
__privateSet(this, _alignVertical_accessor_storage, value);
|
|
120
|
+
}
|
|
121
|
+
/** The seat reservation area's base grid size */
|
|
122
|
+
get baseGridSize() {
|
|
123
|
+
return __privateGet(this, _baseGridSize_accessor_storage);
|
|
124
|
+
}
|
|
125
|
+
set baseGridSize(value) {
|
|
126
|
+
__privateSet(this, _baseGridSize_accessor_storage, value);
|
|
127
|
+
}
|
|
128
|
+
/** The seat reservation area's width */
|
|
129
|
+
get height() {
|
|
130
|
+
return __privateGet(this, _height_accessor_storage);
|
|
131
|
+
}
|
|
132
|
+
set height(value) {
|
|
133
|
+
__privateSet(this, _height_accessor_storage, value);
|
|
134
|
+
}
|
|
135
|
+
/** Maximal number of possible clickable seats */
|
|
136
|
+
get maxReservations() {
|
|
137
|
+
return __privateGet(this, _maxReservations_accessor_storage);
|
|
138
|
+
}
|
|
139
|
+
set maxReservations(value) {
|
|
140
|
+
__privateSet(this, _maxReservations_accessor_storage, value);
|
|
141
|
+
}
|
|
142
|
+
/** Any click functionality is prevented */
|
|
143
|
+
get preventPlaceClick() {
|
|
144
|
+
return __privateGet(this, _preventPlaceClick_accessor_storage);
|
|
145
|
+
}
|
|
146
|
+
set preventPlaceClick(value) {
|
|
147
|
+
__privateSet(this, _preventPlaceClick_accessor_storage, value);
|
|
148
|
+
}
|
|
149
|
+
get selectedCoachIndex() {
|
|
150
|
+
return __privateGet(this, _selectedCoachIndex_accessor_storage);
|
|
151
|
+
}
|
|
152
|
+
set selectedCoachIndex(value) {
|
|
153
|
+
__privateSet(this, _selectedCoachIndex_accessor_storage, value);
|
|
154
|
+
}
|
|
155
|
+
get focusedCoachIndex() {
|
|
156
|
+
return __privateGet(this, _focusedCoachIndex_accessor_storage);
|
|
157
|
+
}
|
|
158
|
+
set focusedCoachIndex(value) {
|
|
159
|
+
__privateSet(this, _focusedCoachIndex_accessor_storage, value);
|
|
160
|
+
}
|
|
161
|
+
willUpdate(changedProperties) {
|
|
162
|
+
var _a2, _b;
|
|
163
|
+
super.willUpdate(changedProperties);
|
|
164
|
+
if (changedProperties.has("seatReservation")) {
|
|
165
|
+
this._initSeatReservationPlaceSelection();
|
|
166
|
+
}
|
|
167
|
+
if (changedProperties.has("baseGridSize")) {
|
|
168
|
+
this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;
|
|
169
|
+
(_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
|
|
170
|
+
if (this.alignVertical) {
|
|
171
|
+
this._setVerticalAlignmentOffset();
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
if (changedProperties.has("height") && !!this.height) {
|
|
175
|
+
if (this.seatReservation.coachItems.length) {
|
|
176
|
+
this.baseGridSize = this.height / this.seatReservation.coachItems[0].dimension.h;
|
|
177
|
+
this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;
|
|
178
|
+
(_b = this.style) == null ? void 0 : _b.setProperty("--sbb-seat-reservation-grid-size", `${this.baseGridSize}px`);
|
|
179
|
+
if (this.alignVertical) {
|
|
180
|
+
this._setVerticalAlignmentOffset();
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
if (changedProperties.has("alignVertical") && this.alignVertical) {
|
|
185
|
+
this._setVerticalAlignmentOffset();
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
/* Init scroll event handling for coach navigation */
|
|
189
|
+
initNavigationSelectionByScrollEvent() {
|
|
190
|
+
var _a2, _b, _c;
|
|
191
|
+
this.firstTabElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById("first-tab-element");
|
|
192
|
+
this.lastTabElement = (_b = this.shadowRoot) == null ? void 0 : _b.getElementById("last-tab-element");
|
|
193
|
+
this.coachScrollArea = (_c = this.shadowRoot) == null ? void 0 : _c.getElementById("sbb-sr__parent-area");
|
|
194
|
+
if (this.coachScrollArea) {
|
|
195
|
+
let currCalcTriggerPos = 0;
|
|
196
|
+
this.scrollCoachsAreaWidth = this.coachScrollArea.getBoundingClientRect().width;
|
|
197
|
+
this.triggerCoachPositionsCollection = this.seatReservation.coachItems.map((coach) => {
|
|
198
|
+
const startPosX = currCalcTriggerPos;
|
|
199
|
+
const coachWidth = this.getCalculatedDimension(coach.dimension).w;
|
|
200
|
+
currCalcTriggerPos += coachWidth;
|
|
201
|
+
return {
|
|
202
|
+
start: startPosX,
|
|
203
|
+
end: currCalcTriggerPos,
|
|
204
|
+
width: coachWidth
|
|
205
|
+
};
|
|
206
|
+
});
|
|
207
|
+
this.maxCalcCoachsWidth = currCalcTriggerPos;
|
|
208
|
+
this.coachScrollArea.addEventListener("scrollend", () => {
|
|
209
|
+
const findScrollCoachIndex = this.isAutoScrolling ? this.currSelectedCoachIndex : this._getCoachIndexByScrollTriggerPosition();
|
|
210
|
+
if (this._isScrollableToSelectedCoach()) {
|
|
211
|
+
this.currSelectedCoachIndex = findScrollCoachIndex;
|
|
212
|
+
} else {
|
|
213
|
+
this.currSelectedCoachIndex = findScrollCoachIndex < this.currSelectedCoachIndex ? this.currSelectedCoachIndex : findScrollCoachIndex;
|
|
214
|
+
}
|
|
215
|
+
this.preventCoachScrollByPlaceClick = false;
|
|
216
|
+
this.updateCurrentSelectedCoach();
|
|
217
|
+
if (!this.hasNavigation) {
|
|
218
|
+
this.preselectPlaceInCoach();
|
|
219
|
+
this.isAutoScrolling = false;
|
|
220
|
+
}
|
|
221
|
+
});
|
|
222
|
+
if (this.alignVertical) {
|
|
223
|
+
this._setVerticalAlignmentOffset();
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* If no navigation exists (property setting -> hasNavigation) and a table coach gets the focus,
|
|
229
|
+
* the first place in the coach must be automatically preselected to control the place navigation via keyboard
|
|
230
|
+
*
|
|
231
|
+
* @param focusCoachIndex
|
|
232
|
+
*/
|
|
233
|
+
onFocusTableCoachAndPreselectPlace(focusCoachIndex) {
|
|
234
|
+
if (!this.seatReservationWithoutNavigationHasFocus && !this.hasNavigation) {
|
|
235
|
+
this.seatReservationWithoutNavigationHasFocus = true;
|
|
236
|
+
this.currSelectedCoachIndex = focusCoachIndex === 0 ? this.getNextAvailableCoachIndex(-1) : this.getPrevAvailableCoachIndex(focusCoachIndex);
|
|
237
|
+
this.preselectPlaceInCoach();
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Initialisation of Keyboard event handling to navigation between each places inside a selected coach by using [arrow] keys.
|
|
242
|
+
* With the [TAB] key the user navigation goes to the next coach navigation element and the currently selected place is automatically reset.
|
|
243
|
+
*/
|
|
244
|
+
handleKeyboardEvent(event) {
|
|
245
|
+
const pressedKey = event.key;
|
|
246
|
+
if (this.currSelectedPlace) {
|
|
247
|
+
if (event.shiftKey && event.keyCode === 9) {
|
|
248
|
+
this._navigateCoachNavigationByKeyboard("PREV_TAB");
|
|
249
|
+
event.preventDefault();
|
|
250
|
+
return;
|
|
251
|
+
}
|
|
252
|
+
if (pressedKey === this.keyboardNavigationEvents.Tab) {
|
|
253
|
+
this._navigateCoachNavigationByKeyboard("NEXT_TAB");
|
|
254
|
+
event.preventDefault();
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
if (this.currSelectedCoachIndex !== -1 && isArrowKeyOrPageKeysPressed(event)) {
|
|
259
|
+
event.preventDefault();
|
|
260
|
+
switch (pressedKey) {
|
|
261
|
+
case this.keyboardNavigationEvents.ArrowLeft:
|
|
262
|
+
{
|
|
263
|
+
const pressedLeftKeyMapping = this.alignVertical ? this.keyboardNavigationEvents.ArrowDown : pressedKey;
|
|
264
|
+
this._navigateToPlaceByKeyboard(pressedLeftKeyMapping);
|
|
265
|
+
}
|
|
266
|
+
break;
|
|
267
|
+
case this.keyboardNavigationEvents.ArrowRight:
|
|
268
|
+
{
|
|
269
|
+
const pressedRightKeyMapping = this.alignVertical ? this.keyboardNavigationEvents.ArrowUp : pressedKey;
|
|
270
|
+
this._navigateToPlaceByKeyboard(pressedRightKeyMapping);
|
|
271
|
+
}
|
|
272
|
+
break;
|
|
273
|
+
case this.keyboardNavigationEvents.ArrowUp:
|
|
274
|
+
{
|
|
275
|
+
const pressedUpKeyMapping = this.alignVertical ? this.keyboardNavigationEvents.ArrowLeft : pressedKey;
|
|
276
|
+
this._navigateToPlaceByKeyboard(pressedUpKeyMapping);
|
|
277
|
+
}
|
|
278
|
+
break;
|
|
279
|
+
case this.keyboardNavigationEvents.ArrowDown:
|
|
280
|
+
{
|
|
281
|
+
const pressedDownKeyMapping = this.alignVertical ? this.keyboardNavigationEvents.ArrowRight : pressedKey;
|
|
282
|
+
this._navigateToPlaceByKeyboard(pressedDownKeyMapping);
|
|
283
|
+
}
|
|
284
|
+
break;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Selects a place inside the coach if navigated via keyboard,
|
|
290
|
+
* otherwise the coach grid is selected (necessary for ScreenReader)
|
|
291
|
+
*/
|
|
292
|
+
preselectPlaceInCoach() {
|
|
293
|
+
const closestPlace = this._getClosestPlaceByKeyDirection();
|
|
294
|
+
if (closestPlace) {
|
|
295
|
+
this.unfocusPlaceElement();
|
|
296
|
+
}
|
|
297
|
+
if (this.isKeyboardNavigation && this.isAutoScrolling) {
|
|
298
|
+
if (closestPlace) {
|
|
299
|
+
this.focusPlaceElement(closestPlace);
|
|
300
|
+
}
|
|
301
|
+
} else {
|
|
302
|
+
this.currSelectedPlace = closestPlace;
|
|
303
|
+
this._setFocusToSelectedCoachGrid();
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
scrollToSelectedNavCoach(selectedNavCoachIndex) {
|
|
307
|
+
if (selectedNavCoachIndex !== this.currSelectedCoachIndex) {
|
|
308
|
+
this.isAutoScrolling = true;
|
|
309
|
+
this.isCochGridFocusable = true;
|
|
310
|
+
this.currSelectedCoachIndex = selectedNavCoachIndex;
|
|
311
|
+
this._setScrollDirectionByCoachIndex();
|
|
312
|
+
const scrollToCoachPosX = this._getCoachScrollPositionX();
|
|
313
|
+
const isSelectedCoachIndexScrollable = this.selectedCoachIndex !== -1 || this.currSelectedCoachIndex > 0;
|
|
314
|
+
if (isSelectedCoachIndexScrollable && this._isScrollableToSelectedCoach()) {
|
|
315
|
+
this.coachScrollArea.scrollTo({
|
|
316
|
+
top: 0,
|
|
317
|
+
left: scrollToCoachPosX,
|
|
318
|
+
behavior: "smooth"
|
|
319
|
+
});
|
|
320
|
+
} else {
|
|
321
|
+
this.updateCurrentSelectedCoach();
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
/**
|
|
326
|
+
* Sets the new ScrollDirection by the new given target coach index.
|
|
327
|
+
*/
|
|
328
|
+
_setScrollDirectionByCoachIndex() {
|
|
329
|
+
this.currScrollDirection = this.currSelectedCoachIndex > this.selectedCoachIndex ? ScrollDirection.right : ScrollDirection.left;
|
|
330
|
+
}
|
|
331
|
+
/**
|
|
332
|
+
* Returns the scroll start or end position X from the selected coach.
|
|
333
|
+
* In case the user is curretnly navigate throught places by keyboard and goes to previous coach,
|
|
334
|
+
* then we return the end position of the coach to get clostest next scroll position of the next focus place.
|
|
335
|
+
* @returns number
|
|
336
|
+
*/
|
|
337
|
+
_getCoachScrollPositionX() {
|
|
338
|
+
const coachTriggerPoint = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];
|
|
339
|
+
const isFocusPlaceFromPreviousCoachPosition = this.isKeyboardNavigation && this.currScrollDirection === ScrollDirection.left && coachTriggerPoint.width > this.scrollCoachsAreaWidth;
|
|
340
|
+
return isFocusPlaceFromPreviousCoachPosition ? coachTriggerPoint.end - this.scrollCoachsAreaWidth : coachTriggerPoint.start;
|
|
341
|
+
}
|
|
342
|
+
/**
|
|
343
|
+
* Sets the focus on the HTML table (grid) caption element so that the heading is read out when using a ScreenReader.
|
|
344
|
+
*/
|
|
345
|
+
_setFocusToSelectedCoachGrid() {
|
|
346
|
+
var _a2;
|
|
347
|
+
if (this.isCochGridFocusable) {
|
|
348
|
+
this.isCochGridFocusable = false;
|
|
349
|
+
const coachTableCaptionElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelector("#sbb-sr-coach-caption-" + this.currSelectedCoachIndex);
|
|
350
|
+
if (coachTableCaptionElement) {
|
|
351
|
+
coachTableCaptionElement.focus();
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* Returns whether the current scrolled position can be used to scroll to the selected wagon
|
|
357
|
+
* @returns boolean
|
|
358
|
+
*/
|
|
359
|
+
_isScrollableToSelectedCoach() {
|
|
360
|
+
const currScrollPosX = this.coachScrollArea.scrollLeft;
|
|
361
|
+
const coachScrollWindowWidth = this.coachScrollArea.getBoundingClientRect().width;
|
|
362
|
+
const maxScrollWidthArea = this.maxCalcCoachsWidth - coachScrollWindowWidth;
|
|
363
|
+
const currCoachTrigger = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];
|
|
364
|
+
const isScrollPosSameToCurrCoachPos = currScrollPosX === this.triggerCoachPositionsCollection[this.currSelectedCoachIndex].start;
|
|
365
|
+
return (currScrollPosX < maxScrollWidthArea || currScrollPosX > currCoachTrigger.start) && !isScrollPosSameToCurrCoachPos;
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Returns the coach index which is currently visible in the scroll area
|
|
369
|
+
* @returns number
|
|
370
|
+
*/
|
|
371
|
+
_getCoachIndexByScrollTriggerPosition() {
|
|
372
|
+
const scrollOffsetX = this.coachScrollArea.scrollLeft + this.scrollCoachsAreaWidth / 2;
|
|
373
|
+
return this.triggerCoachPositionsCollection.findIndex((coachTrigger) => scrollOffsetX >= coachTrigger.start && scrollOffsetX <= coachTrigger.end);
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* Get the first place of current selected coach by table cell coordinate 0-0 id.
|
|
377
|
+
* @returns Place or null
|
|
378
|
+
*/
|
|
379
|
+
_getFirstPlaceInSelecedCoach() {
|
|
380
|
+
var _a2, _b, _c, _d, _e;
|
|
381
|
+
let firstPlace = null;
|
|
382
|
+
const coach = (_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems[this.currSelectedCoachIndex];
|
|
383
|
+
const firstCellId = "cell-" + this.currSelectedCoachIndex + "-0-0";
|
|
384
|
+
const placeNumber = ((_d = (_c = (_b = this.shadowRoot) == null ? void 0 : _b.querySelector("[cell-id='" + firstCellId + "']")) == null ? void 0 : _c.querySelector("sbb-seat-reservation-place-control")) == null ? void 0 : _d.getAttribute("text")) || null;
|
|
385
|
+
if (coach && placeNumber) {
|
|
386
|
+
firstPlace = ((_e = coach.places) == null ? void 0 : _e.find((place) => place.number === placeNumber)) || null;
|
|
387
|
+
}
|
|
388
|
+
return firstPlace;
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* To get the correct closest place of current pressed key and the current selected place,
|
|
392
|
+
* we have to investigate the coordinates of each place to find the closest place of the currSelectedPlaceElementId.
|
|
393
|
+
* @param pressedKey
|
|
394
|
+
* @returns Place or null
|
|
395
|
+
*/
|
|
396
|
+
_getClosestPlaceByKeyDirection(pressedKey) {
|
|
397
|
+
var _a2, _b, _c, _d, _e;
|
|
398
|
+
const coach = (_a2 = this.seatReservation) == null ? void 0 : _a2.coachItems[this.currSelectedCoachIndex];
|
|
399
|
+
let closestPlace = null;
|
|
400
|
+
if (coach.places) {
|
|
401
|
+
if (!this.currSelectedPlaceElementId) {
|
|
402
|
+
return this._getFirstPlaceInSelecedCoach();
|
|
403
|
+
} else {
|
|
404
|
+
if (this.currSelectedPlace) {
|
|
405
|
+
for (const place of coach.places) {
|
|
406
|
+
if (!pressedKey) {
|
|
407
|
+
if (this.currScrollDirection === ScrollDirection.right && place.position.y === ((_b = this.currSelectedPlace) == null ? void 0 : _b.position.y) && (!closestPlace || place.position.x < closestPlace.position.x)) {
|
|
408
|
+
closestPlace = place;
|
|
409
|
+
} else if (this.currScrollDirection === ScrollDirection.left && place.position.y === ((_c = this.currSelectedPlace) == null ? void 0 : _c.position.y) && (!closestPlace || place.position.x > closestPlace.position.x)) {
|
|
410
|
+
closestPlace = place;
|
|
411
|
+
}
|
|
412
|
+
} else {
|
|
413
|
+
if (place.number !== ((_d = this.currSelectedPlace) == null ? void 0 : _d.number)) {
|
|
414
|
+
if (pressedKey === this.keyboardNavigationEvents.ArrowRight && (place.position.y === this.currSelectedPlace.position.y || place.position.y === this.currSelectedPlace.position.y - 1) && place.position.x > this.currSelectedPlace.position.x && (!closestPlace || place.position.x < closestPlace.position.x)) {
|
|
415
|
+
closestPlace = place;
|
|
416
|
+
} else if (pressedKey === this.keyboardNavigationEvents.ArrowDown && (place.position.x === this.currSelectedPlace.position.x || place.position.x === this.currSelectedPlace.position.x + 1) && place.position.y > this.currSelectedPlace.position.y && (!closestPlace || place.position.y < closestPlace.position.y)) {
|
|
417
|
+
closestPlace = place;
|
|
418
|
+
} else if (pressedKey === this.keyboardNavigationEvents.ArrowLeft && (place.position.y === this.currSelectedPlace.position.y || place.position.y === this.currSelectedPlace.position.y + 1) && place.position.x < this.currSelectedPlace.position.x && (!closestPlace || place.position.x > closestPlace.position.x)) {
|
|
419
|
+
closestPlace = place;
|
|
420
|
+
} else if (pressedKey === this.keyboardNavigationEvents.ArrowUp && (place.position.x === this.currSelectedPlace.position.x || place.position.x === this.currSelectedPlace.position.x - 1) && place.position.y < ((_e = this.currSelectedPlace) == null ? void 0 : _e.position.y) && (!closestPlace || place.position.y > closestPlace.position.y)) {
|
|
421
|
+
closestPlace = place;
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
}
|
|
429
|
+
return closestPlace;
|
|
430
|
+
}
|
|
431
|
+
focusPlaceElement(place, coachIndex) {
|
|
432
|
+
this.unfocusPlaceElement();
|
|
433
|
+
if (place) {
|
|
434
|
+
this.currSelectedPlace = place;
|
|
435
|
+
if (coachIndex) {
|
|
436
|
+
this.currSelectedCoachIndex = coachIndex;
|
|
437
|
+
}
|
|
438
|
+
this._setCurrSelectedPlaceElementId(place);
|
|
439
|
+
const selectedPlaceElement = this._getPlaceHtmlElement();
|
|
440
|
+
if (selectedPlaceElement) {
|
|
441
|
+
selectedPlaceElement.setAttribute("keyfocus", "focus");
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
unfocusPlaceElement() {
|
|
446
|
+
const selectedPlaceElement = this._getPlaceHtmlElement();
|
|
447
|
+
if (selectedPlaceElement) {
|
|
448
|
+
selectedPlaceElement.setAttribute("keyfocus", "unfocus");
|
|
449
|
+
this._setCurrSelectedPlaceElementId(null);
|
|
450
|
+
this.currSelectedPlace = null;
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
getCalculatedDimension(elementDimension, coachDimension, isOriginHeight, isStretchHeight) {
|
|
454
|
+
if (coachDimension && !isOriginHeight) {
|
|
455
|
+
elementDimension.h += this.coachBorderOffset * 2;
|
|
456
|
+
}
|
|
457
|
+
if (isStretchHeight) {
|
|
458
|
+
elementDimension.h += this.coachBorderOffset;
|
|
459
|
+
}
|
|
460
|
+
return {
|
|
461
|
+
w: this.baseGridSize * elementDimension.w,
|
|
462
|
+
h: this.baseGridSize * elementDimension.h
|
|
463
|
+
};
|
|
464
|
+
}
|
|
465
|
+
getCalculatedPosition(elementPosition, elementDimension, coachDimension, isOriginHeight) {
|
|
466
|
+
if (coachDimension && elementDimension) {
|
|
467
|
+
const endPosHeight = isOriginHeight ? coachDimension.h : coachDimension.h + this.coachBorderOffset;
|
|
468
|
+
if (elementPosition.y === 0) {
|
|
469
|
+
elementPosition.y -= this.coachBorderOffset;
|
|
470
|
+
} else if (elementPosition.y + elementDimension.h === endPosHeight) {
|
|
471
|
+
elementPosition.y += this.coachBorderOffset;
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
return {
|
|
475
|
+
x: this.baseGridSize * elementPosition.x,
|
|
476
|
+
y: this.baseGridSize * elementPosition.y,
|
|
477
|
+
z: elementPosition.z
|
|
478
|
+
};
|
|
479
|
+
}
|
|
480
|
+
// Handling for Tab navigation if an place is selected inside the coach.
|
|
481
|
+
// This controls the focused coach from the current selected coach.
|
|
482
|
+
_navigateCoachNavigationByKeyboard(tabDirection) {
|
|
483
|
+
const currFocusIndex = this.focusedCoachIndex === -1 ? this.currSelectedCoachIndex === -1 ? 0 : this.currSelectedCoachIndex : this.focusedCoachIndex;
|
|
484
|
+
const newFocusableIndex = tabDirection === "NEXT_TAB" ? this.getNextAvailableCoachIndex(currFocusIndex) : this.getPrevAvailableCoachIndex(currFocusIndex);
|
|
485
|
+
if (currFocusIndex === newFocusableIndex) {
|
|
486
|
+
this.unfocusPlaceElement();
|
|
487
|
+
this.selectedCoachIndex = -1;
|
|
488
|
+
this.currSelectedCoachIndex = -1;
|
|
489
|
+
this.seatReservationWithoutNavigationHasFocus = false;
|
|
490
|
+
if (tabDirection === "NEXT_TAB")
|
|
491
|
+
this.lastTabElement.focus();
|
|
492
|
+
else
|
|
493
|
+
this.firstTabElement.focus();
|
|
494
|
+
return;
|
|
495
|
+
}
|
|
496
|
+
if (this.hasNavigation) {
|
|
497
|
+
const selectedPlaceElement = this._getPlaceHtmlElement();
|
|
498
|
+
const placeInCoachHasFocus = selectedPlaceElement ? selectedPlaceElement.getAttribute("keyfocus") === "focus" : false;
|
|
499
|
+
if (tabDirection === "PREV_TAB" && this.selectedCoachIndex === currFocusIndex) {
|
|
500
|
+
if (placeInCoachHasFocus) {
|
|
501
|
+
this.focusedCoachIndex = currFocusIndex;
|
|
502
|
+
this.unfocusPlaceElement();
|
|
503
|
+
} else {
|
|
504
|
+
this.focusedCoachIndex = newFocusableIndex;
|
|
505
|
+
}
|
|
506
|
+
} else if (newFocusableIndex !== this.currSelectedCoachIndex) {
|
|
507
|
+
this.focusedCoachIndex = newFocusableIndex;
|
|
508
|
+
} else {
|
|
509
|
+
this.focusedCoachIndex = -1;
|
|
510
|
+
this.selectedCoachIndex = newFocusableIndex;
|
|
511
|
+
if (placeInCoachHasFocus) {
|
|
512
|
+
this.focusPlaceElement(this.currSelectedPlace);
|
|
513
|
+
} else {
|
|
514
|
+
this.isCochGridFocusable = true;
|
|
515
|
+
this._setFocusToSelectedCoachGrid();
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
} else {
|
|
519
|
+
this.scrollToSelectedNavCoach(newFocusableIndex);
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
_navigateToPlaceByKeyboard(pressedKey) {
|
|
523
|
+
this.preventCoachScrollByPlaceClick = false;
|
|
524
|
+
this.isKeyboardNavigation = true;
|
|
525
|
+
if (this.focusedCoachIndex !== -1) {
|
|
526
|
+
this.focusedCoachIndex = -1;
|
|
527
|
+
}
|
|
528
|
+
if (!this.preventPlaceClick) {
|
|
529
|
+
const findClosestPlace = this._getClosestPlaceByKeyDirection(pressedKey);
|
|
530
|
+
if (findClosestPlace) {
|
|
531
|
+
this.focusPlaceElement(findClosestPlace);
|
|
532
|
+
} else {
|
|
533
|
+
if (pressedKey === this.keyboardNavigationEvents.ArrowRight || pressedKey === this.keyboardNavigationEvents.ArrowLeft || this.alignVertical && (pressedKey === this.keyboardNavigationEvents.ArrowUp || pressedKey === this.keyboardNavigationEvents.ArrowDown)) {
|
|
534
|
+
const newSelectedCoachIndex = pressedKey === this.keyboardNavigationEvents.ArrowRight ? this.getNextAvailableCoachIndex() : this.getPrevAvailableCoachIndex();
|
|
535
|
+
this.scrollToSelectedNavCoach(newSelectedCoachIndex);
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
getNextAvailableCoachIndex(currentIndex) {
|
|
541
|
+
const startIndex = currentIndex ?? this.currSelectedCoachIndex;
|
|
542
|
+
return startIndex < this.seatReservation.coachItems.length - 1 ? startIndex + 1 : startIndex;
|
|
543
|
+
}
|
|
544
|
+
getPrevAvailableCoachIndex(currentIndex) {
|
|
545
|
+
const startIndex = currentIndex ?? this.currSelectedCoachIndex;
|
|
546
|
+
return startIndex > 0 ? startIndex - 1 : startIndex;
|
|
547
|
+
}
|
|
548
|
+
updateSelectedSeatReservationPlaces(placeSelection) {
|
|
549
|
+
if (placeSelection.state === "SELECTED") {
|
|
550
|
+
const seatReservationSelection = this._getSeatReservationPlaceSelection(placeSelection);
|
|
551
|
+
if (seatReservationSelection) {
|
|
552
|
+
this.selectedSeatReservationPlaces.push(seatReservationSelection);
|
|
553
|
+
}
|
|
554
|
+
} else {
|
|
555
|
+
this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter((_selectedPlace) => _selectedPlace.id !== placeSelection.id);
|
|
556
|
+
}
|
|
557
|
+
if (this.maxReservations && this.selectedSeatReservationPlaces.length > this.maxReservations) {
|
|
558
|
+
this._resetAllPlaceSelections(placeSelection);
|
|
559
|
+
}
|
|
560
|
+
this.selectedPlaces.emit(this.selectedSeatReservationPlaces);
|
|
561
|
+
}
|
|
562
|
+
updateCurrentSelectedPlaceInCoach(placeSelection) {
|
|
563
|
+
var _a2;
|
|
564
|
+
const coachIndex = placeSelection.coachIndex;
|
|
565
|
+
const place = (_a2 = this.seatReservation.coachItems[coachIndex].places) == null ? void 0 : _a2.find((place2) => place2.number == placeSelection.number);
|
|
566
|
+
if (!place)
|
|
567
|
+
return;
|
|
568
|
+
this.currSelectedCoachIndex = coachIndex;
|
|
569
|
+
this.currSelectedPlace = place;
|
|
570
|
+
if (this.currSelectedCoachIndex !== this.selectedCoachIndex) {
|
|
571
|
+
this.updateCurrentSelectedCoach();
|
|
572
|
+
}
|
|
573
|
+
this._setCurrSelectedPlaceElementId(place);
|
|
574
|
+
}
|
|
575
|
+
updateCurrentSelectedCoach() {
|
|
576
|
+
this.selectedCoachIndex = this.currSelectedCoachIndex;
|
|
577
|
+
this.focusedCoachIndex = -1;
|
|
578
|
+
const coachSelection = this._getSeatReservationCoachSelection(this.selectedCoachIndex);
|
|
579
|
+
if (coachSelection) {
|
|
580
|
+
this.selectedCoach.emit(coachSelection);
|
|
581
|
+
}
|
|
582
|
+
}
|
|
583
|
+
/**
|
|
584
|
+
* Initialization of SeatReservationPlaceSelection Array based on the transferred places
|
|
585
|
+
* that have the state SELECTED within the seatReservation object
|
|
586
|
+
*/
|
|
587
|
+
_initSeatReservationPlaceSelection() {
|
|
588
|
+
this.seatReservation.coachItems.map((coach, coachIndex) => {
|
|
589
|
+
var _a2, _b;
|
|
590
|
+
(_b = (_a2 = coach.places) == null ? void 0 : _a2.filter((place) => place.state === "SELECTED")) == null ? void 0 : _b.forEach((place) => {
|
|
591
|
+
const preselectedPlaceSelection = mapPlaceInfosToPlaceSelection(place, coachIndex);
|
|
592
|
+
const seatReservationPlaceSelection = this._getSeatReservationPlaceSelection(preselectedPlaceSelection);
|
|
593
|
+
if (seatReservationPlaceSelection)
|
|
594
|
+
this.selectedSeatReservationPlaces.push(seatReservationPlaceSelection);
|
|
595
|
+
});
|
|
596
|
+
});
|
|
597
|
+
}
|
|
598
|
+
/**
|
|
599
|
+
* All selected places will be reset or the currentSelectedPlace was given, then we reset all except currentSelectedPlace
|
|
600
|
+
* @param currSelectedPlace
|
|
601
|
+
*/
|
|
602
|
+
_resetAllPlaceSelections(currSelectedPlace) {
|
|
603
|
+
var _a2;
|
|
604
|
+
for (const placeSelection of this.selectedSeatReservationPlaces) {
|
|
605
|
+
if (!currSelectedPlace || currSelectedPlace.id !== placeSelection.id) {
|
|
606
|
+
const placeElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById(placeSelection.id);
|
|
607
|
+
placeElement.setAttribute("state", "FREE");
|
|
608
|
+
}
|
|
609
|
+
}
|
|
610
|
+
if (currSelectedPlace) {
|
|
611
|
+
this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter((_selectedPlace) => _selectedPlace.id === currSelectedPlace.id);
|
|
612
|
+
} else {
|
|
613
|
+
this.selectedSeatReservationPlaces = [];
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
_getSeatReservationPlaceSelection(currSelectedPlace) {
|
|
617
|
+
var _a2;
|
|
618
|
+
const coach = this.seatReservation.coachItems[currSelectedPlace.coachIndex];
|
|
619
|
+
const place = (_a2 = coach.places) == null ? void 0 : _a2.find((place2) => place2.number === currSelectedPlace.number);
|
|
620
|
+
return place ? mapPlaceAndCoachToSeatReservationPlaceSelection(place, coach, currSelectedPlace.coachIndex) : null;
|
|
621
|
+
}
|
|
622
|
+
_getSeatReservationCoachSelection(coachIndex) {
|
|
623
|
+
if (!this.seatReservation.coachItems[coachIndex])
|
|
624
|
+
return null;
|
|
625
|
+
const coach = this.seatReservation.coachItems[coachIndex];
|
|
626
|
+
return mapCoachInfosToCoachSelection(coachIndex, coach);
|
|
627
|
+
}
|
|
628
|
+
_setCurrSelectedPlaceElementId(place) {
|
|
629
|
+
if (place) {
|
|
630
|
+
this.currSelectedPlaceElementId = "seat-reservation__place-button-" + this.currSelectedCoachIndex + "-" + place.number;
|
|
631
|
+
} else {
|
|
632
|
+
this.currSelectedPlaceElementId = null;
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
/**
|
|
636
|
+
* Returns the current selected place HTML element by given placeNumber and coachIndex.
|
|
637
|
+
* If both doesnt exist, we try to return the place HTML element by the _currentSelectedPlaceElementId
|
|
638
|
+
* @param placeNumber optional as string
|
|
639
|
+
* @param coachIndex optional as string
|
|
640
|
+
* @returns HTMLElement or null
|
|
641
|
+
*/
|
|
642
|
+
_getPlaceHtmlElement(placeNumber, coachIndex) {
|
|
643
|
+
var _a2;
|
|
644
|
+
const currCoachIndex = coachIndex ? coachIndex : this.currSelectedCoachIndex;
|
|
645
|
+
const coachPlaceNumberId = placeNumber ? "seat-reservation__place-button-" + currCoachIndex + "-" + placeNumber : this.currSelectedPlaceElementId;
|
|
646
|
+
return coachPlaceNumberId ? ((_a2 = this.shadowRoot) == null ? void 0 : _a2.getElementById(coachPlaceNumberId)) || null : null;
|
|
647
|
+
}
|
|
648
|
+
//Set the vertical offset
|
|
649
|
+
_setVerticalAlignmentOffset() {
|
|
650
|
+
setTimeout(() => {
|
|
651
|
+
var _a2, _b;
|
|
652
|
+
const seatReservationWrapperElement = (_a2 = this.shadowRoot) == null ? void 0 : _a2.querySelector(".sbb-sr__wrapper");
|
|
653
|
+
if (seatReservationWrapperElement) {
|
|
654
|
+
const seatReservationVerticalOffset = seatReservationWrapperElement.getBoundingClientRect().width;
|
|
655
|
+
(_b = this.style) == null ? void 0 : _b.setProperty("--sbb-seat-reservation-vertical-offset", `${seatReservationVerticalOffset}px`);
|
|
656
|
+
}
|
|
657
|
+
});
|
|
658
|
+
}
|
|
659
|
+
}, _seatReservation_accessor_storage = new WeakMap(), _hasNavigation_accessor_storage = new WeakMap(), _alignVertical_accessor_storage = new WeakMap(), _baseGridSize_accessor_storage = new WeakMap(), _height_accessor_storage = new WeakMap(), _maxReservations_accessor_storage = new WeakMap(), _preventPlaceClick_accessor_storage = new WeakMap(), _selectedCoachIndex_accessor_storage = new WeakMap(), _focusedCoachIndex_accessor_storage = new WeakMap(), (() => {
|
|
660
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
661
|
+
_seatReservation_decorators = [property({ attribute: "seat-reservation", type: Object })];
|
|
662
|
+
_hasNavigation_decorators = [forceType(), property({ attribute: "has-navigation", type: Boolean })];
|
|
663
|
+
_alignVertical_decorators = [forceType(), property({ attribute: "align-vertical", type: Boolean })];
|
|
664
|
+
_baseGridSize_decorators = [forceType(), property({ attribute: "base-grid-size", type: Number })];
|
|
665
|
+
_height_decorators = [forceType(), property({ attribute: "height", type: Number })];
|
|
666
|
+
_maxReservations_decorators = [forceType(), property({ attribute: "max-reservations", type: Number })];
|
|
667
|
+
_preventPlaceClick_decorators = [forceType(), property({ attribute: "prevent-place-click", type: Boolean })];
|
|
668
|
+
_selectedCoachIndex_decorators = [state()];
|
|
669
|
+
_focusedCoachIndex_decorators = [state()];
|
|
670
|
+
__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) => {
|
|
671
|
+
obj.seatReservation = value;
|
|
672
|
+
} }, metadata: _metadata }, _seatReservation_initializers, _seatReservation_extraInitializers);
|
|
673
|
+
__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) => {
|
|
674
|
+
obj.hasNavigation = value;
|
|
675
|
+
} }, metadata: _metadata }, _hasNavigation_initializers, _hasNavigation_extraInitializers);
|
|
676
|
+
__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) => {
|
|
677
|
+
obj.alignVertical = value;
|
|
678
|
+
} }, metadata: _metadata }, _alignVertical_initializers, _alignVertical_extraInitializers);
|
|
679
|
+
__esDecorate(_a, null, _baseGridSize_decorators, { kind: "accessor", name: "baseGridSize", static: false, private: false, access: { has: (obj) => "baseGridSize" in obj, get: (obj) => obj.baseGridSize, set: (obj, value) => {
|
|
680
|
+
obj.baseGridSize = value;
|
|
681
|
+
} }, metadata: _metadata }, _baseGridSize_initializers, _baseGridSize_extraInitializers);
|
|
682
|
+
__esDecorate(_a, null, _height_decorators, { kind: "accessor", name: "height", static: false, private: false, access: { has: (obj) => "height" in obj, get: (obj) => obj.height, set: (obj, value) => {
|
|
683
|
+
obj.height = value;
|
|
684
|
+
} }, metadata: _metadata }, _height_initializers, _height_extraInitializers);
|
|
685
|
+
__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) => {
|
|
686
|
+
obj.maxReservations = value;
|
|
687
|
+
} }, metadata: _metadata }, _maxReservations_initializers, _maxReservations_extraInitializers);
|
|
688
|
+
__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) => {
|
|
689
|
+
obj.preventPlaceClick = value;
|
|
690
|
+
} }, metadata: _metadata }, _preventPlaceClick_initializers, _preventPlaceClick_extraInitializers);
|
|
691
|
+
__esDecorate(_a, null, _selectedCoachIndex_decorators, { kind: "accessor", name: "selectedCoachIndex", static: false, private: false, access: { has: (obj) => "selectedCoachIndex" in obj, get: (obj) => obj.selectedCoachIndex, set: (obj, value) => {
|
|
692
|
+
obj.selectedCoachIndex = value;
|
|
693
|
+
} }, metadata: _metadata }, _selectedCoachIndex_initializers, _selectedCoachIndex_extraInitializers);
|
|
694
|
+
__esDecorate(_a, null, _focusedCoachIndex_decorators, { kind: "accessor", name: "focusedCoachIndex", static: false, private: false, access: { has: (obj) => "focusedCoachIndex" in obj, get: (obj) => obj.focusedCoachIndex, set: (obj, value) => {
|
|
695
|
+
obj.focusedCoachIndex = value;
|
|
696
|
+
} }, metadata: _metadata }, _focusedCoachIndex_initializers, _focusedCoachIndex_extraInitializers);
|
|
697
|
+
if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
698
|
+
})(), _a.events = {
|
|
699
|
+
selectedPlaces: "selectedPlaces",
|
|
700
|
+
selectedCoach: "selectedCoach"
|
|
701
|
+
}, _a;
|
|
702
|
+
})();
|
|
703
|
+
export {
|
|
704
|
+
SeatReservationBaseElement
|
|
705
|
+
};
|
|
706
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-base-element.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation-base-element.ts"],"sourcesContent":["import { isArrowKeyOrPageKeysPressed } from '@sbb-esta/lyne-elements/core/a11y.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { EventEmitter } from '@sbb-esta/lyne-elements/core/eventing.js';\nimport { LitElement, type PropertyValues } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport {\n  mapCoachInfosToCoachSelection,\n  mapPlaceAndCoachToSeatReservationPlaceSelection,\n  mapPlaceInfosToPlaceSelection,\n} from '../common/mapper.js';\nimport type { SbbSeatReservationPlaceControlElement } from '../seat-reservation-place-control/seat-reservation-place-control.component.js';\nimport type {\n  CoachItem,\n  ElementDimension,\n  ElementPosition,\n  Place,\n  PlaceSelection,\n  SeatReservation,\n  SeatReservationCoachSelection,\n  SeatReservationPlaceSelection,\n} from '../seat-reservation.js';\n\nimport type { SbbSeatReservationScopedElement } from './seat-reservation-scoped/seat-reservation-scoped.component.js';\n\nenum ScrollDirection {\n  right = 'right',\n  left = 'left',\n}\n\ninterface CoachScrollTriggerPoint {\n  start: number;\n  end: number;\n  width: number;\n}\n\nexport class SeatReservationBaseElement extends LitElement {\n  public static readonly events = {\n    selectedPlaces: 'selectedPlaces',\n    selectedCoach: 'selectedCoach',\n  } as const;\n\n  /** The seat reservation object which contains all coaches and places */\n  @property({ attribute: 'seat-reservation', type: Object })\n  public accessor seatReservation: SeatReservation = null!;\n\n  /** The seat resvervation navigation can be toggled by this property */\n  @forceType()\n  @property({ attribute: 'has-navigation', type: Boolean })\n  public accessor hasNavigation: boolean = true;\n\n  /** The seat reservation area is aligned vertically */\n  @forceType()\n  @property({ attribute: 'align-vertical', type: Boolean })\n  public accessor alignVertical: boolean = false;\n\n  /** The seat reservation area's base grid size */\n  @forceType()\n  @property({ attribute: 'base-grid-size', type: Number })\n  public accessor baseGridSize: number = 16;\n\n  /** The seat reservation area's width */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  /** Maximal number of possible clickable seats */\n  @forceType()\n  @property({ attribute: 'max-reservations', type: Number })\n  public accessor maxReservations: number = null!;\n\n  /** Any click functionality is prevented */\n  @forceType()\n  @property({ attribute: 'prevent-place-click', type: Boolean })\n  public accessor preventPlaceClick: boolean = false;\n\n  @state() protected accessor selectedCoachIndex: number = -1;\n  @state() protected accessor focusedCoachIndex: number = -1;\n\n  /** Emits when a place was selected by user. */\n  protected selectedPlaces: EventEmitter<SeatReservationPlaceSelection[]> = new EventEmitter(\n    this,\n    SeatReservationBaseElement.events.selectedPlaces,\n  );\n\n  /** Emits when a coach was selected by user. */\n  protected selectedCoach: EventEmitter<SeatReservationCoachSelection> = new EventEmitter(\n    this,\n    SeatReservationBaseElement.events.selectedCoach,\n  );\n\n  protected coachBorderPadding = 6;\n  protected coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n  protected currScrollDirection: ScrollDirection = ScrollDirection.right;\n  protected maxCalcCoachsWidth: number = 0;\n  protected scrollCoachsAreaWidth: number = 0;\n  protected triggerCoachPositionsCollection: CoachScrollTriggerPoint[] = [];\n  protected firstTabElement: HTMLElement = null!;\n  protected lastTabElement: HTMLElement = null!;\n  protected coachScrollArea: HTMLElement = null!;\n  protected currSelectedPlace: Place | null = null;\n  protected currSelectedPlaceElementId: string | null = null;\n  protected currSelectedCoachIndex: number = -1;\n  protected preventCoachScrollByPlaceClick: boolean = false;\n  protected selectedSeatReservationPlaces: SeatReservationPlaceSelection[] = [];\n  protected seatReservationWithoutNavigationHasFocus = false;\n  protected isCochGridFocusable = false;\n  protected isAutoScrolling = false;\n  protected isKeyboardNavigation = false;\n  protected keyboardNavigationEvents = {\n    ArrowLeft: 'ArrowLeft',\n    ArrowRight: 'ArrowRight',\n    ArrowUp: 'ArrowUp',\n    ArrowDown: 'ArrowDown',\n    Tab: 'Tab',\n    Enter: 'Enter',\n  } as const;\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('seatReservation')) {\n      this._initSeatReservationPlaceSelection();\n    }\n\n    if (changedProperties.has('baseGridSize')) {\n      this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n      this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n\n    // If the height is used, the baseGridSize must be recalculated\n    if (changedProperties.has('height') && !!this.height) {\n      if (this.seatReservation.coachItems.length) {\n        this.baseGridSize = this.height / this.seatReservation.coachItems[0].dimension.h;\n        this.coachBorderOffset = this.coachBorderPadding / this.baseGridSize;\n        this.style?.setProperty('--sbb-seat-reservation-grid-size', `${this.baseGridSize}px`);\n\n        if (this.alignVertical) {\n          this._setVerticalAlignmentOffset();\n        }\n      }\n    }\n\n    if (changedProperties.has('alignVertical') && this.alignVertical) {\n      this._setVerticalAlignmentOffset();\n    }\n  }\n\n  /* Init scroll event handling for coach navigation */\n  protected initNavigationSelectionByScrollEvent(): void {\n    this.firstTabElement = this.shadowRoot?.getElementById('first-tab-element') as HTMLElement;\n    this.lastTabElement = this.shadowRoot?.getElementById('last-tab-element') as HTMLElement;\n    this.coachScrollArea = this.shadowRoot?.getElementById('sbb-sr__parent-area') as HTMLElement;\n\n    if (this.coachScrollArea) {\n      let currCalcTriggerPos = 0;\n      this.scrollCoachsAreaWidth = this.coachScrollArea.getBoundingClientRect().width;\n\n      // Precalculate trigger scroll position array depends from coach width\n      this.triggerCoachPositionsCollection = this.seatReservation.coachItems.map((coach) => {\n        const startPosX = currCalcTriggerPos;\n        const coachWidth = this.getCalculatedDimension(coach.dimension).w;\n        currCalcTriggerPos += coachWidth;\n        return {\n          start: startPosX,\n          end: currCalcTriggerPos,\n          width: coachWidth,\n        } as CoachScrollTriggerPoint;\n      });\n\n      // Set maximum calculated coach width\n      this.maxCalcCoachsWidth = currCalcTriggerPos;\n\n      // At the end of a scroll Events to a coach, the reached wagon is marked as selected\n      this.coachScrollArea.addEventListener('scrollend', () => {\n        const findScrollCoachIndex = this.isAutoScrolling\n          ? this.currSelectedCoachIndex\n          : this._getCoachIndexByScrollTriggerPosition();\n        if (this._isScrollableToSelectedCoach()) {\n          this.currSelectedCoachIndex = findScrollCoachIndex;\n        } else {\n          this.currSelectedCoachIndex =\n            findScrollCoachIndex < this.currSelectedCoachIndex\n              ? this.currSelectedCoachIndex\n              : findScrollCoachIndex;\n        }\n\n        this.preventCoachScrollByPlaceClick = false;\n        this.updateCurrentSelectedCoach();\n\n        if (!this.hasNavigation) {\n          this.preselectPlaceInCoach();\n          this.isAutoScrolling = false;\n        }\n      });\n\n      // During initialization we check vertical alignment mode. In Vertical mode we have to set the vertical offset manual for the seat reservation area,\n      // becuase we rotate the entire component by 90 degrees and transform the origin point to top left.\n      if (this.alignVertical) {\n        this._setVerticalAlignmentOffset();\n      }\n    }\n  }\n\n  /**\n   * If no navigation exists (property setting -> hasNavigation) and a table coach gets the focus,\n   * the first place in the coach must be automatically preselected to control the place navigation via keyboard\n   *\n   * @param focusCoachIndex\n   */\n  protected onFocusTableCoachAndPreselectPlace(focusCoachIndex: number): void {\n    if (!this.seatReservationWithoutNavigationHasFocus && !this.hasNavigation) {\n      this.seatReservationWithoutNavigationHasFocus = true;\n      this.currSelectedCoachIndex =\n        focusCoachIndex === 0\n          ? this.getNextAvailableCoachIndex(-1)\n          : this.getPrevAvailableCoachIndex(focusCoachIndex);\n      this.preselectPlaceInCoach();\n    }\n  }\n\n  /**\n   * Initialisation of Keyboard event handling to navigation between each places inside a selected coach by using [arrow] keys.\n   * With the [TAB] key the user navigation goes to the next coach navigation element and the currently selected place is automatically reset.\n   */\n  protected handleKeyboardEvent(event: KeyboardEvent): void {\n    const pressedKey = event.key;\n\n    // If any place is selected and TAB Key combination ist pressed,\n    // then we handle the next or previous coach selection\n    if (this.currSelectedPlace) {\n      if (event.shiftKey && event.keyCode === 9) {\n        this._navigateCoachNavigationByKeyboard('PREV_TAB');\n        event.preventDefault();\n        return;\n      }\n\n      if (pressedKey === this.keyboardNavigationEvents.Tab) {\n        this._navigateCoachNavigationByKeyboard('NEXT_TAB');\n        event.preventDefault();\n        return;\n      }\n    }\n\n    // Check if a choach is selected and the arrow key is pressed\n    if (this.currSelectedCoachIndex !== -1 && isArrowKeyOrPageKeysPressed(event)) {\n      event.preventDefault();\n\n      switch (pressedKey) {\n        case this.keyboardNavigationEvents.ArrowLeft:\n          {\n            const pressedLeftKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowDown\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedLeftKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowRight:\n          {\n            const pressedRightKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowUp\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedRightKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowUp:\n          {\n            const pressedUpKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowLeft\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedUpKeyMapping);\n          }\n          break;\n        case this.keyboardNavigationEvents.ArrowDown:\n          {\n            const pressedDownKeyMapping: string = this.alignVertical\n              ? this.keyboardNavigationEvents.ArrowRight\n              : pressedKey;\n            this._navigateToPlaceByKeyboard(pressedDownKeyMapping);\n          }\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  /**\n   * Selects a place inside the coach if navigated via keyboard,\n   * otherwise the coach grid is selected (necessary for ScreenReader)\n   */\n  protected preselectPlaceInCoach(): void {\n    const closestPlace = this._getClosestPlaceByKeyDirection();\n    //If closestPlace exist, we have to unfocus previouse focused place\n    if (closestPlace) {\n      this.unfocusPlaceElement();\n    }\n\n    // Only when keyboard navigation is used and coaches are scrolled by auto scrolling,\n    // then we can set the focus on the first place in the coach.\n    if (this.isKeyboardNavigation && this.isAutoScrolling) {\n      if (closestPlace) {\n        this.focusPlaceElement(closestPlace);\n      }\n    }\n    // In cases where the preselection function is triggered by normal clicking or via screenreader via tab,\n    // we only focus the table without directly focusing the place.\n    else {\n      // We need to set the currSelectedPlace here for further correct functioning navigation via tab.\n      this.currSelectedPlace = closestPlace;\n      this._setFocusToSelectedCoachGrid();\n    }\n  }\n\n  protected scrollToSelectedNavCoach(selectedNavCoachIndex: number): void {\n    if (selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.isAutoScrolling = true;\n      this.isCochGridFocusable = true;\n      this.currSelectedCoachIndex = selectedNavCoachIndex;\n      this._setScrollDirectionByCoachIndex();\n\n      const scrollToCoachPosX = this._getCoachScrollPositionX();\n      const isSelectedCoachIndexScrollable =\n        this.selectedCoachIndex !== -1 || this.currSelectedCoachIndex > 0;\n\n      // Checks whether the current scroll position allows scrolling to the next wagon or not\n      if (isSelectedCoachIndexScrollable && this._isScrollableToSelectedCoach()) {\n        this.coachScrollArea.scrollTo({\n          top: 0,\n          left: scrollToCoachPosX,\n          behavior: 'smooth',\n        });\n      } else {\n        this.updateCurrentSelectedCoach();\n      }\n    }\n  }\n\n  /**\n   * Sets the new ScrollDirection by the new given target coach index.\n   */\n  private _setScrollDirectionByCoachIndex(): void {\n    this.currScrollDirection =\n      this.currSelectedCoachIndex > this.selectedCoachIndex\n        ? ScrollDirection.right\n        : ScrollDirection.left;\n  }\n\n  /**\n   * Returns the scroll start or end position X from the selected coach.\n   * In case the user is curretnly navigate throught places by keyboard and goes to previous coach,\n   * then we return the end position of the coach to get clostest next scroll position of the next focus place.\n   * @returns number\n   */\n  private _getCoachScrollPositionX(): number {\n    const coachTriggerPoint = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isFocusPlaceFromPreviousCoachPosition =\n      this.isKeyboardNavigation &&\n      this.currScrollDirection === ScrollDirection.left &&\n      coachTriggerPoint.width > this.scrollCoachsAreaWidth;\n    return isFocusPlaceFromPreviousCoachPosition\n      ? coachTriggerPoint.end - this.scrollCoachsAreaWidth\n      : coachTriggerPoint.start;\n  }\n\n  /**\n   * Sets the focus on the HTML table (grid) caption element so that the heading is read out when using a ScreenReader.\n   */\n  private _setFocusToSelectedCoachGrid(): void {\n    // When the user performs an action that affects the coach navigation, then the navigated table is focusable.\n    if (this.isCochGridFocusable) {\n      this.isCochGridFocusable = false;\n      const coachTableCaptionElement = this.shadowRoot?.querySelector(\n        '#sbb-sr-coach-caption-' + this.currSelectedCoachIndex,\n      ) as HTMLTableCaptionElement;\n      if (coachTableCaptionElement) {\n        coachTableCaptionElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Returns whether the current scrolled position can be used to scroll to the selected wagon\n   * @returns boolean\n   */\n  private _isScrollableToSelectedCoach(): boolean {\n    const currScrollPosX = this.coachScrollArea.scrollLeft;\n    const coachScrollWindowWidth = this.coachScrollArea.getBoundingClientRect().width;\n    const maxScrollWidthArea = this.maxCalcCoachsWidth - coachScrollWindowWidth;\n    const currCoachTrigger = this.triggerCoachPositionsCollection[this.currSelectedCoachIndex];\n    const isScrollPosSameToCurrCoachPos =\n      currScrollPosX === this.triggerCoachPositionsCollection[this.currSelectedCoachIndex].start;\n\n    return (\n      (currScrollPosX < maxScrollWidthArea || currScrollPosX > currCoachTrigger.start) &&\n      !isScrollPosSameToCurrCoachPos\n    );\n  }\n\n  /**\n   * Returns the coach index which is currently visible in the scroll area\n   * @returns number\n   */\n  private _getCoachIndexByScrollTriggerPosition(): number {\n    const scrollOffsetX = this.coachScrollArea.scrollLeft + this.scrollCoachsAreaWidth / 2;\n    return this.triggerCoachPositionsCollection.findIndex(\n      (coachTrigger) => scrollOffsetX >= coachTrigger.start && scrollOffsetX <= coachTrigger.end,\n    );\n  }\n\n  /**\n   * Get the first place of current selected coach by table cell coordinate 0-0 id.\n   * @returns Place or null\n   */\n  private _getFirstPlaceInSelecedCoach(): Place | null {\n    let firstPlace: Place | null = null;\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    const firstCellId = 'cell-' + this.currSelectedCoachIndex + '-0-0';\n    const placeNumber =\n      this.shadowRoot\n        ?.querySelector<SbbSeatReservationScopedElement>(\"[cell-id='\" + firstCellId + \"']\")\n        ?.querySelector<SbbSeatReservationPlaceControlElement>('sbb-seat-reservation-place-control')\n        ?.getAttribute('text') || null;\n\n    if (coach && placeNumber) {\n      firstPlace = coach.places?.find((place) => place.number === placeNumber) || null;\n    }\n    return firstPlace;\n  }\n\n  /**\n   * To get the correct closest place of current pressed key and the current selected place,\n   * we have to investigate the coordinates of each place to find the closest place of the currSelectedPlaceElementId.\n   * @param pressedKey\n   * @returns Place or null\n   */\n  private _getClosestPlaceByKeyDirection(pressedKey?: string): Place | null {\n    const coach = this.seatReservation?.coachItems[this.currSelectedCoachIndex];\n    let closestPlace = null;\n    if (coach.places) {\n      //If no place set, then wen use initial the left-top place on the coach\n      if (!this.currSelectedPlaceElementId) {\n        return this._getFirstPlaceInSelecedCoach();\n      } else {\n        if (this.currSelectedPlace) {\n          for (const place of coach.places) {\n            // If key pressed, then we try to find the place of the current currScrollDirection\n            if (!pressedKey) {\n              //Find place from the left side of coach by y coordinate. Current currScrollDirection is RIGHT)\n              if (\n                this.currScrollDirection === ScrollDirection.right &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x < closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n              //Find place from the right side of coach by y coordinate. Current currScrollDirection is LEFT\n              else if (\n                this.currScrollDirection === ScrollDirection.left &&\n                place.position.y === this.currSelectedPlace?.position.y &&\n                (!closestPlace || place.position.x > closestPlace.position.x)\n              ) {\n                closestPlace = place;\n              }\n            } else {\n              if (place.number !== this.currSelectedPlace?.number) {\n                //Key [Right] navigation, we check the place coordinates of the x-axis to get the smallest larger x place coordinate of the currently selected place\n                if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowRight &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y - 1) &&\n                  place.position.x > this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x < closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Down] navigation, we check the place coordinates of the y-axis to get the smallest larger y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowDown &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x + 1) &&\n                  place.position.y > this.currSelectedPlace.position.y &&\n                  (!closestPlace || place.position.y < closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Left] navigation, we check the place coordinates of the x-axis to get the greatest smaller x place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowLeft &&\n                  (place.position.y === this.currSelectedPlace.position.y ||\n                    place.position.y === this.currSelectedPlace.position.y + 1) &&\n                  place.position.x < this.currSelectedPlace.position.x &&\n                  (!closestPlace || place.position.x > closestPlace.position.x)\n                ) {\n                  closestPlace = place;\n                }\n                //Key [Up] navigation, we check the place coordinates of the y-axis to get the greatest smaller y place coordinate of the currently selected place\n                else if (\n                  pressedKey === this.keyboardNavigationEvents.ArrowUp &&\n                  (place.position.x === this.currSelectedPlace.position.x ||\n                    place.position.x === this.currSelectedPlace.position.x - 1) &&\n                  place.position.y < this.currSelectedPlace?.position.y &&\n                  (!closestPlace || place.position.y > closestPlace.position.y)\n                ) {\n                  closestPlace = place;\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n    return closestPlace;\n  }\n\n  protected focusPlaceElement(place: Place | null, coachIndex?: number): void {\n    this.unfocusPlaceElement();\n    if (place) {\n      this.currSelectedPlace = place;\n      if (coachIndex) {\n        this.currSelectedCoachIndex = coachIndex;\n      }\n\n      this._setCurrSelectedPlaceElementId(place);\n\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      if (selectedPlaceElement) {\n        selectedPlaceElement.setAttribute('keyfocus', 'focus');\n      }\n    }\n  }\n\n  protected unfocusPlaceElement(): void {\n    const selectedPlaceElement = this._getPlaceHtmlElement();\n    if (selectedPlaceElement) {\n      selectedPlaceElement.setAttribute('keyfocus', 'unfocus');\n      this._setCurrSelectedPlaceElementId(null);\n      this.currSelectedPlace = null;\n    }\n  }\n\n  protected getCalculatedDimension(\n    elementDimension: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n    isStretchHeight?: boolean,\n  ): ElementDimension {\n    if (coachDimension && !isOriginHeight) {\n      elementDimension.h += this.coachBorderOffset * 2;\n    }\n\n    if (isStretchHeight) {\n      elementDimension.h += this.coachBorderOffset;\n    }\n\n    return {\n      w: this.baseGridSize * elementDimension.w,\n      h: this.baseGridSize * elementDimension.h,\n    };\n  }\n\n  protected getCalculatedPosition(\n    elementPosition: ElementPosition,\n    elementDimension?: ElementDimension,\n    coachDimension?: ElementDimension,\n    isOriginHeight?: boolean,\n  ): ElementPosition {\n    if (coachDimension && elementDimension) {\n      const endPosHeight = isOriginHeight\n        ? coachDimension.h\n        : coachDimension.h + this.coachBorderOffset;\n      //If the original element is positioned at the top or bottom of the coach, we need to recalculate the Y coordinate with the additional border padding\n      if (elementPosition.y === 0) {\n        elementPosition.y -= this.coachBorderOffset;\n      } else if (elementPosition.y + elementDimension.h === endPosHeight) {\n        elementPosition.y += this.coachBorderOffset;\n      }\n    }\n\n    return {\n      x: this.baseGridSize * elementPosition.x,\n      y: this.baseGridSize * elementPosition.y,\n      z: elementPosition.z,\n    };\n  }\n\n  // Handling for Tab navigation if an place is selected inside the coach.\n  // This controls the focused coach from the current selected coach.\n  private _navigateCoachNavigationByKeyboard(tabDirection: string): void {\n    const currFocusIndex =\n      this.focusedCoachIndex === -1\n        ? this.currSelectedCoachIndex === -1\n          ? 0\n          : this.currSelectedCoachIndex\n        : this.focusedCoachIndex;\n    //Check next or prev tab is pressed, then we need to find the next available coach index that should receive the focus\n    const newFocusableIndex: number =\n      tabDirection === 'NEXT_TAB'\n        ? this.getNextAvailableCoachIndex(currFocusIndex)\n        : this.getPrevAvailableCoachIndex(currFocusIndex);\n\n    // If the currFocusIndex equals the newFocusableIndex then we have reached the first or last tabable navigation coach Element and we have to the set the focus manual to the firstTabElement or lastTabElement.\n    if (currFocusIndex === newFocusableIndex) {\n      this.unfocusPlaceElement();\n      this.selectedCoachIndex = -1;\n      this.currSelectedCoachIndex = -1;\n      this.seatReservationWithoutNavigationHasFocus = false;\n\n      if (tabDirection === 'NEXT_TAB') this.lastTabElement.focus();\n      else this.firstTabElement.focus();\n\n      return;\n    }\n\n    if (this.hasNavigation) {\n      const selectedPlaceElement = this._getPlaceHtmlElement();\n      const placeInCoachHasFocus = selectedPlaceElement\n        ? selectedPlaceElement.getAttribute('keyfocus') === 'focus'\n        : false;\n\n      // If we tab back (PREV_TAB) and the focus is currently on place,\n      // we remove the selected state from the currently selected navigation coach and only set the focus status to it\n      if (tabDirection === 'PREV_TAB' && this.selectedCoachIndex === currFocusIndex) {\n        if (placeInCoachHasFocus) {\n          this.focusedCoachIndex = currFocusIndex;\n          this.unfocusPlaceElement();\n        } else {\n          this.focusedCoachIndex = newFocusableIndex;\n        }\n      }\n      // Only sets the focus on the new navigation coach\n      else if (newFocusableIndex !== this.currSelectedCoachIndex) {\n        this.focusedCoachIndex = newFocusableIndex;\n      } else {\n        this.focusedCoachIndex = -1;\n        this.selectedCoachIndex = newFocusableIndex;\n        //If any place was focused in coach, so we set focused again\n        if (placeInCoachHasFocus) {\n          this.focusPlaceElement(this.currSelectedPlace);\n        }\n        //If no place was selected, then we select the coach grid\n        else {\n          this.isCochGridFocusable = true;\n          this._setFocusToSelectedCoachGrid();\n        }\n      }\n    }\n    //If no navigation exist, we scroll directly to the next tabable coach\n    else {\n      this.scrollToSelectedNavCoach(newFocusableIndex);\n    }\n  }\n\n  private _navigateToPlaceByKeyboard(pressedKey: string): void {\n    this.preventCoachScrollByPlaceClick = false;\n    this.isKeyboardNavigation = true;\n\n    if (this.focusedCoachIndex !== -1) {\n      this.focusedCoachIndex = -1;\n    }\n\n    if (!this.preventPlaceClick) {\n      const findClosestPlace = this._getClosestPlaceByKeyDirection(pressedKey);\n      if (findClosestPlace) {\n        this.focusPlaceElement(findClosestPlace);\n      }\n      //No clostest place found by key navigation\n      else {\n        if (\n          pressedKey === this.keyboardNavigationEvents.ArrowRight ||\n          pressedKey === this.keyboardNavigationEvents.ArrowLeft ||\n          (this.alignVertical &&\n            (pressedKey === this.keyboardNavigationEvents.ArrowUp ||\n              pressedKey === this.keyboardNavigationEvents.ArrowDown))\n        ) {\n          //Check the current pressed key to get the next available coach index\n          const newSelectedCoachIndex =\n            pressedKey === this.keyboardNavigationEvents.ArrowRight\n              ? this.getNextAvailableCoachIndex()\n              : this.getPrevAvailableCoachIndex();\n\n          this.scrollToSelectedNavCoach(newSelectedCoachIndex);\n        }\n      }\n    }\n  }\n\n  protected getNextAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex < this.seatReservation.coachItems.length - 1 ? startIndex + 1 : startIndex;\n  }\n\n  protected getPrevAvailableCoachIndex(currentIndex?: number): number {\n    const startIndex = currentIndex ?? this.currSelectedCoachIndex;\n    return startIndex > 0 ? startIndex - 1 : startIndex;\n  }\n\n  protected updateSelectedSeatReservationPlaces(placeSelection: PlaceSelection): void {\n    //Add selected place to selectedSeatReservationPlaces\n    if (placeSelection.state === 'SELECTED') {\n      const seatReservationSelection = this._getSeatReservationPlaceSelection(placeSelection);\n      if (seatReservationSelection) {\n        this.selectedSeatReservationPlaces.push(seatReservationSelection);\n      }\n    }\n    //Remove selected place from selectedSeatReservationPlaces\n    else {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id !== placeSelection.id,\n      );\n    }\n\n    //Checks whether maxReservation is activated and the maximum number of selected places is reached\n    if (this.maxReservations && this.selectedSeatReservationPlaces.length > this.maxReservations) {\n      this._resetAllPlaceSelections(placeSelection);\n    }\n\n    //Emits the seat reservation place selection\n    this.selectedPlaces.emit(this.selectedSeatReservationPlaces);\n  }\n\n  protected updateCurrentSelectedPlaceInCoach(placeSelection: PlaceSelection): void {\n    const coachIndex = placeSelection.coachIndex;\n    const place = this.seatReservation.coachItems[coachIndex].places?.find(\n      (place) => place.number == placeSelection.number,\n    );\n\n    if (!place) return;\n    this.currSelectedCoachIndex = coachIndex;\n    this.currSelectedPlace = place;\n    if (this.currSelectedCoachIndex !== this.selectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n    }\n\n    this._setCurrSelectedPlaceElementId(place);\n  }\n\n  protected updateCurrentSelectedCoach(): void {\n    this.selectedCoachIndex = this.currSelectedCoachIndex;\n    this.focusedCoachIndex = -1;\n    const coachSelection = this._getSeatReservationCoachSelection(this.selectedCoachIndex);\n    if (coachSelection) {\n      this.selectedCoach.emit(coachSelection);\n    }\n  }\n\n  /**\n   * Initialization of SeatReservationPlaceSelection Array based on the transferred places\n   * that have the state SELECTED within the seatReservation object\n   */\n  private _initSeatReservationPlaceSelection(): void {\n    this.seatReservation.coachItems.map((coach: CoachItem, coachIndex: number) => {\n      coach.places\n        ?.filter((place) => place.state === 'SELECTED')\n        ?.forEach((place) => {\n          const preselectedPlaceSelection: PlaceSelection = mapPlaceInfosToPlaceSelection(\n            place,\n            coachIndex,\n          );\n          const seatReservationPlaceSelection: SeatReservationPlaceSelection | null =\n            this._getSeatReservationPlaceSelection(preselectedPlaceSelection);\n          if (seatReservationPlaceSelection)\n            this.selectedSeatReservationPlaces.push(seatReservationPlaceSelection);\n        });\n    });\n  }\n\n  /**\n   * All selected places will be reset or the currentSelectedPlace was given, then we reset all except currentSelectedPlace\n   * @param currSelectedPlace\n   */\n  private _resetAllPlaceSelections(currSelectedPlace?: PlaceSelection): void {\n    //Find all places to be needed unselect\n    for (const placeSelection of this.selectedSeatReservationPlaces) {\n      if (!currSelectedPlace || currSelectedPlace.id !== placeSelection.id) {\n        const placeElement = this.shadowRoot?.getElementById(placeSelection.id) as HTMLElement;\n        placeElement.setAttribute('state', 'FREE');\n      }\n    }\n    //Removes all selected places except the currently selected place\n    if (currSelectedPlace) {\n      this.selectedSeatReservationPlaces = this.selectedSeatReservationPlaces.filter(\n        (_selectedPlace) => _selectedPlace.id === currSelectedPlace.id,\n      );\n    } else {\n      this.selectedSeatReservationPlaces = [];\n    }\n  }\n\n  private _getSeatReservationPlaceSelection(\n    currSelectedPlace: PlaceSelection,\n  ): SeatReservationPlaceSelection | null {\n    const coach = this.seatReservation.coachItems[currSelectedPlace.coachIndex];\n    const place = coach.places?.find((place) => place.number === currSelectedPlace.number);\n\n    return place\n      ? mapPlaceAndCoachToSeatReservationPlaceSelection(place, coach, currSelectedPlace.coachIndex)\n      : null;\n  }\n\n  private _getSeatReservationCoachSelection(\n    coachIndex: number,\n  ): SeatReservationCoachSelection | null {\n    if (!this.seatReservation.coachItems[coachIndex]) return null;\n\n    const coach = this.seatReservation.coachItems[coachIndex];\n    return mapCoachInfosToCoachSelection(coachIndex, coach);\n  }\n\n  private _setCurrSelectedPlaceElementId(place: Place | null): void {\n    if (place) {\n      this.currSelectedPlaceElementId =\n        'seat-reservation__place-button-' + this.currSelectedCoachIndex + '-' + place.number;\n    } else {\n      this.currSelectedPlaceElementId = null;\n    }\n  }\n\n  /**\n   * Returns the current selected place HTML element by given placeNumber and coachIndex.\n   * If both doesnt exist, we try to return the place HTML element by the _currentSelectedPlaceElementId\n   * @param placeNumber optional as string\n   * @param coachIndex optional as string\n   * @returns HTMLElement or null\n   */\n  private _getPlaceHtmlElement(placeNumber?: string, coachIndex?: number): HTMLElement | null {\n    const currCoachIndex = coachIndex ? coachIndex : this.currSelectedCoachIndex;\n    const coachPlaceNumberId = placeNumber\n      ? 'seat-reservation__place-button-' + currCoachIndex + '-' + placeNumber\n      : this.currSelectedPlaceElementId;\n    return coachPlaceNumberId ? this.shadowRoot?.getElementById(coachPlaceNumberId) || null : null;\n  }\n\n  //Set the vertical offset\n  private _setVerticalAlignmentOffset(): void {\n    setTimeout(() => {\n      const seatReservationWrapperElement = this.shadowRoot?.querySelector(\n        '.sbb-sr__wrapper',\n      ) as HTMLElement;\n      if (seatReservationWrapperElement) {\n        const seatReservationVerticalOffset =\n          seatReservationWrapperElement.getBoundingClientRect().width;\n        this.style?.setProperty(\n          '--sbb-seat-reservation-vertical-offset',\n          `${seatReservationVerticalOffset}px`,\n        );\n      }\n    });\n  }\n}\n"],"names":["ScrollDirection","SeatReservationBaseElement","_a","place"],"mappings":"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"}
|