@sbb-esta/lyne-elements-experimental 3.0.1 → 3.2.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 +908 -567
- package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
- package/development/seat-reservation/common/mapper/icon-mapper.js +1 -3
- package/development/seat-reservation/common/mapper/mapper.d.ts +4 -3
- package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
- package/development/seat-reservation/common/mapper/mapper.js +6 -4
- package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
- package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +4989 -4
- package/development/seat-reservation/common/svgs.d.ts +0 -1
- package/development/seat-reservation/common/svgs.d.ts.map +1 -1
- package/development/seat-reservation/common/svgs.js +1 -3
- package/development/seat-reservation/common/translations/i18n.js +194 -194
- package/development/seat-reservation/common/types.d.ts +10 -0
- package/development/seat-reservation/common/types.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +38 -12
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +252 -122
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +28 -13
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation.component.js +481 -262
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +17 -10
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +1 -6
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +36 -18
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +3 -1
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +26 -4
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +86 -54
- package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +1 -16
- package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +10 -164
- package/package.json +3 -3
- package/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
- package/seat-reservation/common/mapper/icon-mapper.js +0 -2
- package/seat-reservation/common/mapper/mapper.d.ts +4 -3
- package/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
- package/seat-reservation/common/mapper/mapper.js +16 -14
- package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
- package/seat-reservation/common/mapper/seat-reservation-sample-data.js +4988 -3
- package/seat-reservation/common/svgs.d.ts +0 -1
- package/seat-reservation/common/svgs.d.ts.map +1 -1
- package/seat-reservation/common/svgs.js +4 -11
- package/seat-reservation/common/translations/i18n.js +197 -197
- package/seat-reservation/common/types.d.ts +10 -0
- package/seat-reservation/common/types.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +38 -12
- package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation-base-element.js +208 -134
- package/seat-reservation/seat-reservation/seat-reservation.component.d.ts +28 -13
- package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation/seat-reservation.component.js +290 -298
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +22 -22
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +0 -5
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +37 -37
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +3 -1
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +69 -58
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +28 -27
- package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +1 -16
- package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -1
- package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +14 -101
package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js
CHANGED
|
@@ -16,17 +16,20 @@ const style = css`*,
|
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
:host {
|
|
19
|
-
--sbb-reservation-area-border-radius: var(--sbb-border-width-4x);
|
|
20
|
-
--sbb-reservation-area-rotation: 0;
|
|
19
|
+
--sbb-seat-reservation-area-border-radius: var(--sbb-border-width-4x);
|
|
20
|
+
--sbb-seat-reservation-area-rotation: 0;
|
|
21
21
|
display: flex;
|
|
22
22
|
justify-content: center;
|
|
23
23
|
align-items: center;
|
|
24
|
-
height: calc(var(--sbb-reservation-area-height) * 0.0625rem);
|
|
25
|
-
width: calc(var(--sbb-reservation-area-width) * 0.0625rem);
|
|
24
|
+
height: calc(var(--sbb-seat-reservation-area-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
25
|
+
width: calc(var(--sbb-seat-reservation-area-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
26
26
|
border: var(--sbb-border-width-1x) solid var(--sbb-color-graphite);
|
|
27
|
-
border-radius: var(--sbb-reservation-area-border-radius);
|
|
28
|
-
position:
|
|
29
|
-
|
|
27
|
+
border-radius: var(--sbb-seat-reservation-area-border-radius);
|
|
28
|
+
position: absolute;
|
|
29
|
+
inset-block-start: calc(var(--sbb-seat-reservation-area-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
30
|
+
inset-inline-start: calc(var(--sbb-seat-reservation-area-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
31
|
+
rotate: calc(var(--sbb-seat-reservation-area-rotation) * 1deg);
|
|
32
|
+
line-height: normal;
|
|
30
33
|
background-color: var(--sbb-color-white);
|
|
31
34
|
}
|
|
32
35
|
|
|
@@ -36,18 +39,22 @@ const style = css`*,
|
|
|
36
39
|
|
|
37
40
|
:host([mounting=upper-border]) {
|
|
38
41
|
border-block-start-width: var(--sbb-border-width-2x);
|
|
39
|
-
border-radius: 0 0 var(--sbb-reservation-area-border-radius) var(--sbb-reservation-area-border-radius);
|
|
42
|
+
border-radius: 0 0 var(--sbb-seat-reservation-area-border-radius) var(--sbb-seat-reservation-area-border-radius);
|
|
40
43
|
}
|
|
41
44
|
|
|
42
45
|
:host([mounting=lower-border]) {
|
|
43
46
|
border-block-end-width: var(--sbb-border-width-2x);
|
|
44
|
-
border-radius: var(--sbb-reservation-area-border-radius) var(--sbb-reservation-area-border-radius) 0 0;
|
|
47
|
+
border-radius: var(--sbb-seat-reservation-area-border-radius) var(--sbb-seat-reservation-area-border-radius) 0 0;
|
|
45
48
|
}
|
|
46
49
|
|
|
47
50
|
:host([mounting=upper-to-lower-border]) {
|
|
48
51
|
border-block-start: none;
|
|
49
52
|
border-block-end: none;
|
|
50
53
|
border-radius: 0;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
:host(:hover) {
|
|
57
|
+
cursor: pointer;
|
|
51
58
|
}`;
|
|
52
59
|
let SbbSeatReservationAreaElement = (() => {
|
|
53
60
|
var _mounting_accessor_storage, _background_accessor_storage, _a;
|
|
@@ -105,4 +112,4 @@ let SbbSeatReservationAreaElement = (() => {
|
|
|
105
112
|
export {
|
|
106
113
|
SbbSeatReservationAreaElement
|
|
107
114
|
};
|
|
108
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+
|
|
115
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQVlNLGlDQUE2QixNQUFBOzswQkFEbEMsY0FBYywyQkFBMkIsQ0FBQzs7OztvQkFDQzs7Ozs7OztBQUFSLEVBQUEsbUJBQVEsWUFBVTtBQUFBOztBQU1wRCxxREFBQSxrQkFBQSxNQUFBLHdCQUNFLE1BQU07QUFLUix3REFBQSxrQkFBQSxNQUFBLDJCQUFBLEdBQUEsa0JBQUEsTUFBQSwwQkFBK0MsT0FBTzs7OztJQU50RCxJQUFnQixXQUFRO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUF4QixJQUFnQixTQUFRLE9BQUE7QUFBQSx5QkFBQSw0QkFBQTtBQUFBLElBQUE7QUFBQTtBQUFBLElBTXhCLElBQWdCLGFBQVU7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQTFCLElBQWdCLFdBQVUsT0FBQTtBQUFBLHlCQUFBLDhCQUFBO0FBQUEsSUFBQTtBQUFBLElBRVAsU0FBTTtBQUN2QixhQUFPO0FBQUEsSUFDVDtBQUFBLEtBVkEsNENBTUE7OzRCQVJDLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7OEJBSzNCLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFMNUIsaUJBQUEsSUFBQSxNQUFBLHNCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsWUFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxjQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsVUFBUSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBUixXQUFRO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLHdCQUFBLDJCQUFBO0FBTXhCLGlCQUFBLElBQUEsTUFBQSx3QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGNBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsZ0JBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixZQUFVLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFWLGFBQVU7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsMEJBQUEsNkJBQUE7QUFaNUIsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLE9BRDVDLGtCQUFBLFlBQUEsdUJBQUEsR0FBOEI7OzsifQ==
|
package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-assets.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKhD,OAAO,kCAAkC,CAAC;AAC1C,OAAO,gCAAgC,CAAC;AAUxC;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,GAAI,UAAU,MAAM,KAAG,cAAc,GAAG,IAMtE,CAAC;
|
|
1
|
+
{"version":3,"file":"seat-reservation-assets.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKhD,OAAO,kCAAkC,CAAC;AAC1C,OAAO,gCAAgC,CAAC;AAUxC;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,GAAI,UAAU,MAAM,KAAG,cAAc,GAAG,IAMtE,CAAC;AA8RF,eAAO,MAAM,cAAc,EAAE,cAgB5B,CAAC"}
|
|
@@ -292,11 +292,6 @@ const chassisTable = html`
|
|
|
292
292
|
TODO: check if still in use, may be deleted
|
|
293
293
|
</td>
|
|
294
294
|
</tr>
|
|
295
|
-
<tr>
|
|
296
|
-
<td>${svgImageByOSDMCode("TABLE")}</td>
|
|
297
|
-
<td>Table</td>
|
|
298
|
-
<td>TABLE</td>
|
|
299
|
-
</tr>
|
|
300
295
|
</tbody>
|
|
301
296
|
</table>
|
|
302
297
|
</sbb-table-wrapper>
|
|
@@ -322,4 +317,4 @@ export {
|
|
|
322
317
|
assetsTemplate,
|
|
323
318
|
svgImageByOSDMCode
|
|
324
319
|
};
|
|
325
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-assets.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"sourcesContent":["import { html, type TemplateResult } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\n\nimport { svgs, mapIconToSvg } from '../common.js';\n\nimport '@sbb-esta/lyne-elements/table.js';\nimport '../seat-reservation-graphic.js';\n\nconst svgImage = (src: string): TemplateResult => {\n  return html`\n    <div class=\"story-asset\">\n      <span class=\"story-asset__preview\">${unsafeHTML(src)}</span>\n    </div>\n  `;\n};\n\n/**\n * svgImageByOSDMCode Function returns the corresponding svg image by OSDM Code\n * @param osdmCode\n * @returns The SVG Image as TemplateResult if it matches the OSDM code, or null if it's not found.\n */\nexport const svgImageByOSDMCode = (osdmCode: string): TemplateResult | null => {\n  return mapIconToSvg[osdmCode]?.svg\n    ? svgImage(mapIconToSvg[osdmCode].svg)\n    : mapIconToSvg[osdmCode]?.svgName\n      ? html`<sbb-icon name=\"${mapIconToSvg[osdmCode].svgName}\"></sbb-icon>`\n      : null;\n};\n\nconst interiorTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_FREE')}</td>\n          <td>Place-Bike: Available</td>\n          <td>PLACE_BICYCLE_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_SELECTED')}</td>\n          <td>Place-Bike: Selected</td>\n          <td>PLACE_BICYCLE_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_ALLOCATED')}</td>\n          <td>Place-Bike: Unavailable</td>\n          <td>PLACE_BICYCLE_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_RESTRICTED')}</td>\n          <td>Place-Bike: Not bookable</td>\n          <td>PLACE_BICYCLE_RESTRICTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_FREE')}</td>\n          <td>Place-Seat: Available</td>\n          <td>PLACE_SEAT_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_SELECTED')}</td>\n          <td>Place-Seat: Selected</td>\n          <td>PLACE_SEAT_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_ALLOCATED')}</td>\n          <td>Place-Seat: Unavailable</td>\n          <td>PLACE_SEAT_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_RESTRICTED')}</td>\n          <td>Place-Seat: Not bookable</td>\n          <td>PLACE_SEAT_RESTRICTED</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst layoutItemsTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('ENTRY_EXIT')}</td>\n          <td>Entrance</td>\n          <td>ENTRY_EXIT</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multi Function Area</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_AREA')}</td>\n          <td>Playground</td>\n          <td>PLAYGROUND_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_AREA')}</td>\n          <td>Pram</td>\n          <td>PRAM_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SKI_AREA')}</td>\n          <td>Ski</td>\n          <td>SKI_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('STAIR_AREA')}</td>\n          <td>Stair</td>\n          <td>STAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-Handicap</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WARDROBE_AREA')}</td>\n          <td>Wardrobe</td>\n          <td>WARDROBE_AREA</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst serviceIconTable = html`\n  <sbb-table-wrapper>\n    <table aria-label=\"Available Service Icons\" class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('BISTRO')}</td>\n          <td>Bistro</td>\n          <td>BISTRO</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('BUSINESS')}</td>\n          <td>Business</td>\n          <td>BUSINESS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_ICON')}</td>\n          <td>Family</td>\n          <td>PLAYGROUND_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multifunction</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_ICON')}</td>\n          <td>Pram</td>\n          <td>PRAM_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('RESTAURANT_ICON')}</td>\n          <td>Restaurant</td>\n          <td>RESTAURANT_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SILENCE_AREA_ICON')}</td>\n          <td>Silence</td>\n          <td>SILENCE_AREA_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-PRM</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WHEELCHAIR_ICON')}</td>\n          <td>Wheelchair</td>\n          <td>WHEELCHAIR_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WIFI')}</td>\n          <td>Wifi</td>\n          <td>WIFI</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst chassisTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_TRAIN')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA_FULL_TRAIN</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_BUS')}</td>\n          <td>Driver: Bus</td>\n          <td>DRIVER_AREA_FULL_BUS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_HIGH')}</td>\n          <td>Passage-Compartment: Top</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_HIGH</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE')}</td>\n          <td>Passage-Compartment: Middle</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_LOW')}</td>\n          <td>Passage-Compartment: Bottom</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_LOW</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_PASSAGE')}</td>\n          <td>Passage-Waggon Type: Left</td>\n          <td>COACH_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisPassageWaggonBottomRight)}</td>\n          <td>Passage-Waggon Type: Right</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red));\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_WALL_NO_PASSAGE')}</td>\n          <td>Row-Empty: Top/Left</td>\n          <td>COACH_WALL_NO_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_BORDER_MIDDLE')}</td>\n          <td>Row-Empty: Middle</td>\n          <td>COACH_BORDER_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisSeparator)}</td>\n          <td>Separator</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red))\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TABLE')}</td>\n          <td>Table</td>\n          <td>TABLE</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\n\nexport const assetsTemplate: TemplateResult = html`\n  <style>\n    .story-asset {\n      width: max-content;\n      background-color: var(--sbb-color-white);\n    }\n  </style>\n  <h1>List of all currently available assets.</h1>\n  <h2>Interior</h2>\n  ${interiorTable}\n  <h2>Layout</h2>\n  ${layoutItemsTable}\n  <h2>Service Icons</h2>\n  ${serviceIconTable}\n  <h2>Chassis</h2>\n  ${chassisTable}\n`;\n"],"names":[],"mappings":"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"}
|
|
320
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-assets.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-assets.ts"],"sourcesContent":["import { html, type TemplateResult } from 'lit';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\n\nimport { svgs, mapIconToSvg } from '../common.js';\n\nimport '@sbb-esta/lyne-elements/table.js';\nimport '../seat-reservation-graphic.js';\n\nconst svgImage = (src: string): TemplateResult => {\n  return html`\n    <div class=\"story-asset\">\n      <span class=\"story-asset__preview\">${unsafeHTML(src)}</span>\n    </div>\n  `;\n};\n\n/**\n * svgImageByOSDMCode Function returns the corresponding svg image by OSDM Code\n * @param osdmCode\n * @returns The SVG Image as TemplateResult if it matches the OSDM code, or null if it's not found.\n */\nexport const svgImageByOSDMCode = (osdmCode: string): TemplateResult | null => {\n  return mapIconToSvg[osdmCode]?.svg\n    ? svgImage(mapIconToSvg[osdmCode].svg)\n    : mapIconToSvg[osdmCode]?.svgName\n      ? html`<sbb-icon name=\"${mapIconToSvg[osdmCode].svgName}\"></sbb-icon>`\n      : null;\n};\n\nconst interiorTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_FREE')}</td>\n          <td>Place-Bike: Available</td>\n          <td>PLACE_BICYCLE_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_SELECTED')}</td>\n          <td>Place-Bike: Selected</td>\n          <td>PLACE_BICYCLE_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_ALLOCATED')}</td>\n          <td>Place-Bike: Unavailable</td>\n          <td>PLACE_BICYCLE_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_BICYCLE_RESTRICTED')}</td>\n          <td>Place-Bike: Not bookable</td>\n          <td>PLACE_BICYCLE_RESTRICTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_FREE')}</td>\n          <td>Place-Seat: Available</td>\n          <td>PLACE_SEAT_FREE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_SELECTED')}</td>\n          <td>Place-Seat: Selected</td>\n          <td>PLACE_SEAT_SELECTED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_ALLOCATED')}</td>\n          <td>Place-Seat: Unavailable</td>\n          <td>PLACE_SEAT_ALLOCATED</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLACE_SEAT_RESTRICTED')}</td>\n          <td>Place-Seat: Not bookable</td>\n          <td>PLACE_SEAT_RESTRICTED</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst layoutItemsTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('ENTRY_EXIT')}</td>\n          <td>Entrance</td>\n          <td>ENTRY_EXIT</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multi Function Area</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_AREA')}</td>\n          <td>Playground</td>\n          <td>PLAYGROUND_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_AREA')}</td>\n          <td>Pram</td>\n          <td>PRAM_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SKI_AREA')}</td>\n          <td>Ski</td>\n          <td>SKI_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('STAIR_AREA')}</td>\n          <td>Stair</td>\n          <td>STAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-Handicap</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WARDROBE_AREA')}</td>\n          <td>Wardrobe</td>\n          <td>WARDROBE_AREA</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst serviceIconTable = html`\n  <sbb-table-wrapper>\n    <table aria-label=\"Available Service Icons\" class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('BISTRO')}</td>\n          <td>Bistro</td>\n          <td>BISTRO</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('BUSINESS')}</td>\n          <td>Business</td>\n          <td>BUSINESS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PLAYGROUND_ICON')}</td>\n          <td>Family</td>\n          <td>PLAYGROUND_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('LUGGAGE_AREA')}</td>\n          <td>Luggage</td>\n          <td>LUGGAGE_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('MULTI_FUNCTION_AREA')}</td>\n          <td>Multifunction</td>\n          <td>MULTI_FUNCTION_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('PRAM_ICON')}</td>\n          <td>Pram</td>\n          <td>PRAM_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('EASY_ACCESS_AREA')}</td>\n          <td>Easy Access Area</td>\n          <td>EASY_ACCESS_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('RESTAURANT_ICON')}</td>\n          <td>Restaurant</td>\n          <td>RESTAURANT_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('SILENCE_AREA_ICON')}</td>\n          <td>Silence</td>\n          <td>SILENCE_AREA_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_AREA')}</td>\n          <td>Toilet</td>\n          <td>TOILET_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('TOILET_WHEELCHAIR_AREA')}</td>\n          <td>Toilet-PRM</td>\n          <td>TOILET_WHEELCHAIR_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WHEELCHAIR_ICON')}</td>\n          <td>Wheelchair</td>\n          <td>WHEELCHAIR_ICON</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('WIFI')}</td>\n          <td>Wifi</td>\n          <td>WIFI</td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\nconst chassisTable = html`\n  <sbb-table-wrapper>\n    <table class=\"sbb-table\">\n      <thead>\n        <tr>\n          <th scope=\"col\">SVG</th>\n          <th scope=\"col\">Figma</th>\n          <th scope=\"col\">OSDM Code</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_TRAIN')}</td>\n          <td>Driver: Train</td>\n          <td>DRIVER_AREA_FULL_TRAIN</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('DRIVER_AREA_FULL_BUS')}</td>\n          <td>Driver: Bus</td>\n          <td>DRIVER_AREA_FULL_BUS</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_HIGH')}</td>\n          <td>Passage-Compartment: Top</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_HIGH</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE')}</td>\n          <td>Passage-Compartment: Middle</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COMPARTMENT_PASSAGE_LOW')}</td>\n          <td>Passage-Compartment: Bottom</td>\n          <td>COMPARTMENT_PASSAGE<br />COMPARTMENT_PASSAGE_LOW</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_PASSAGE')}</td>\n          <td>Passage-Waggon Type: Left</td>\n          <td>COACH_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisPassageWaggonBottomRight)}</td>\n          <td>Passage-Waggon Type: Right</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red));\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_WALL_NO_PASSAGE')}</td>\n          <td>Row-Empty: Top/Left</td>\n          <td>COACH_WALL_NO_PASSAGE</td>\n        </tr>\n        <tr>\n          <td>${svgImageByOSDMCode('COACH_BORDER_MIDDLE')}</td>\n          <td>Row-Empty: Middle</td>\n          <td>COACH_BORDER_MIDDLE</td>\n        </tr>\n        <tr>\n          <td>${svgImage(svgs.chassisSeparator)}</td>\n          <td>Separator</td>\n          <td\n            style=\"background: linear-gradient(90deg, var(--sbb-color-white) 5%, var(--sbb-color-red))\"\n          >\n            TODO: check if still in use, may be deleted\n          </td>\n        </tr>\n      </tbody>\n    </table>\n  </sbb-table-wrapper>\n`;\n\nexport const assetsTemplate: TemplateResult = html`\n  <style>\n    .story-asset {\n      width: max-content;\n      background-color: var(--sbb-color-white);\n    }\n  </style>\n  <h1>List of all currently available assets.</h1>\n  <h2>Interior</h2>\n  ${interiorTable}\n  <h2>Layout</h2>\n  ${layoutItemsTable}\n  <h2>Service Icons</h2>\n  ${serviceIconTable}\n  <h2>Chassis</h2>\n  ${chassisTable}\n`;\n"],"names":[],"mappings":";;;;;AAQA,MAAM,WAAW,CAAC,QAA+B;AAC/C,SAAO;AAAA;AAAA,2CAEkC,WAAW,GAAG,CAAC;AAAA;AAAA;AAG1D;AAOO,MAAM,qBAAqB,CAAC,aAA2C;AAC5E,SAAO,aAAa,QAAQ,GAAG,MAC3B,SAAS,aAAa,QAAQ,EAAE,GAAG,IACnC,aAAa,QAAQ,GAAG,UACtB,uBAAuB,aAAa,QAAQ,EAAE,OAAO,kBACrD;AACR;AAEA,MAAM,gBAAgB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAYN,mBAAmB,oBAAoB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKxC,mBAAmB,wBAAwB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK5C,mBAAmB,yBAAyB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK7C,mBAAmB,0BAA0B,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK9C,mBAAmB,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKrC,mBAAmB,qBAAqB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKzC,mBAAmB,sBAAsB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK1C,mBAAmB,uBAAuB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQ3D,MAAM,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAYT,mBAAmB,kBAAkB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKtC,mBAAmB,YAAY,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKhC,mBAAmB,cAAc,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKlC,mBAAmB,qBAAqB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKzC,mBAAmB,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKrC,mBAAmB,WAAW,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK/B,mBAAmB,UAAU,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK9B,mBAAmB,YAAY,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKhC,mBAAmB,aAAa,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKjC,mBAAmB,wBAAwB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK5C,mBAAmB,eAAe,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQnD,MAAM,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAYT,mBAAmB,QAAQ,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK5B,mBAAmB,UAAU,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK9B,mBAAmB,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKrC,mBAAmB,cAAc,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKlC,mBAAmB,qBAAqB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKzC,mBAAmB,WAAW,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK/B,mBAAmB,kBAAkB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKtC,mBAAmB,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKrC,mBAAmB,mBAAmB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKvC,mBAAmB,aAAa,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKjC,mBAAmB,wBAAwB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK5C,mBAAmB,iBAAiB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKrC,mBAAmB,MAAM,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQ1C,MAAM,eAAe;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAYL,mBAAmB,aAAa,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKjC,mBAAmB,wBAAwB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK5C,mBAAmB,sBAAsB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK1C,mBAAmB,0BAA0B,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK9C,mBAAmB,qBAAqB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKzC,mBAAmB,yBAAyB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK7C,mBAAmB,eAAe,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKnC,SAAS,KAAK,+BAA+B,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAS9C,mBAAmB,uBAAuB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAK3C,mBAAmB,qBAAqB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,gBAKzC,SAAS,KAAK,gBAAgB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAaxC,MAAM,iBAAiC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAS1C,aAAa;AAAA;AAAA,IAEb,gBAAgB;AAAA;AAAA,IAEhB,gBAAgB;AAAA;AAAA,IAEhB,YAAY;AAAA;"}
|
package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js
CHANGED
|
@@ -20,23 +20,41 @@ const style = css`*,
|
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
:host {
|
|
23
|
-
--sbb-reservation-graphic-width: 16;
|
|
24
|
-
--sbb-reservation-graphic-height: 16;
|
|
25
|
-
--sbb-reservation-graphic-rotation: 0;
|
|
26
|
-
--sbb-reservation-graphic-inverse-rotation: 0;
|
|
23
|
+
--sbb-seat-reservation-graphic-width: 16;
|
|
24
|
+
--sbb-seat-reservation-graphic-height: 16;
|
|
25
|
+
--sbb-seat-reservation-graphic-rotation: 0;
|
|
26
|
+
--sbb-seat-reservation-graphic-inverse-rotation: 0;
|
|
27
|
+
--sbb-seat-reservation-graphic-position: initial;
|
|
28
|
+
--sbb-seat-reservation-graphic-left: 0;
|
|
29
|
+
--sbb-seat-reservation-graphic-top: 0;
|
|
30
|
+
--sbb-icon-svg-width: calc(
|
|
31
|
+
var(--sbb-seat-reservation-graphic-width) *
|
|
32
|
+
var(--sbb-seat-reservation-one-px-rem, 0.0625rem)
|
|
33
|
+
);
|
|
34
|
+
--sbb-icon-svg-height: calc(
|
|
35
|
+
var(--sbb-seat-reservation-graphic-height) *
|
|
36
|
+
var(--sbb-seat-reservation-one-px-rem, 0.0625rem)
|
|
37
|
+
);
|
|
38
|
+
display: flex;
|
|
39
|
+
justify-content: center;
|
|
40
|
+
align-items: center;
|
|
41
|
+
width: calc(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
42
|
+
height: calc(var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
43
|
+
position: var(--sbb-seat-reservation-graphic-position);
|
|
44
|
+
inset-inline-start: calc(var(--sbb-seat-reservation-graphic-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
45
|
+
inset-block-start: calc(var(--sbb-seat-reservation-graphic-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
|
|
27
46
|
}
|
|
28
47
|
|
|
29
48
|
.sbb-sr-icon,
|
|
30
49
|
.sbb-sr-graphic {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
display: flex;
|
|
34
|
-
justify-content: center;
|
|
35
|
-
align-items: center;
|
|
36
|
-
width: calc(var(--sbb-reservation-graphic-width) * 0.0625rem);
|
|
37
|
-
height: calc(var(--sbb-reservation-graphic-height) * 0.0625rem);
|
|
50
|
+
width: inherit;
|
|
51
|
+
height: inherit;
|
|
38
52
|
transform-origin: center;
|
|
39
|
-
rotate: calc(var(--sbb-reservation-graphic-rotation) * 1deg);
|
|
53
|
+
rotate: calc(var(--sbb-seat-reservation-graphic-rotation) * 1deg);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.sbb-sr-icon:hover {
|
|
57
|
+
cursor: var(--sbb-seat-reservation--cursor-pointer, default);
|
|
40
58
|
}
|
|
41
59
|
|
|
42
60
|
.sbb-sr-icon {
|
|
@@ -49,7 +67,7 @@ const style = css`*,
|
|
|
49
67
|
}
|
|
50
68
|
.sbb-sr-graphic svg .fix-rotation-inverse {
|
|
51
69
|
transform-origin: center;
|
|
52
|
-
rotate: calc(var(--sbb-reservation-graphic-inverse-rotation) * 1deg);
|
|
70
|
+
rotate: calc(var(--sbb-seat-reservation-graphic-inverse-rotation) * 1deg);
|
|
53
71
|
}
|
|
54
72
|
@media (forced-colors: active) {
|
|
55
73
|
.sbb-sr-graphic svg:not(.color-immutable) [fill]:not([fill=none]) {
|
|
@@ -146,16 +164,16 @@ let SbbSeatReservationGraphicElement = (() => {
|
|
|
146
164
|
willUpdate(_changedProperties) {
|
|
147
165
|
super.willUpdate(_changedProperties);
|
|
148
166
|
if (_changedProperties.has("width") && !!this.width) {
|
|
149
|
-
this.style?.setProperty("--sbb-reservation-graphic-width", `${this.width}`);
|
|
167
|
+
this.style?.setProperty("--sbb-seat-reservation-graphic-width", `${this.width}`);
|
|
150
168
|
}
|
|
151
169
|
if (_changedProperties.has("height") && !!this.height) {
|
|
152
|
-
this.style?.setProperty("--sbb-reservation-graphic-height", `${this.height}`);
|
|
170
|
+
this.style?.setProperty("--sbb-seat-reservation-graphic-height", `${this.height}`);
|
|
153
171
|
}
|
|
154
172
|
if (_changedProperties.has("rotation")) {
|
|
155
|
-
this.style?.setProperty("--sbb-reservation-graphic-rotation", `${this.rotation}`);
|
|
173
|
+
this.style?.setProperty("--sbb-seat-reservation-graphic-rotation", `${this.rotation}`);
|
|
156
174
|
}
|
|
157
175
|
if (_changedProperties.has("inverseRotation")) {
|
|
158
|
-
this.style?.setProperty("--sbb-reservation-graphic-inverse-rotation", `${this.inverseRotation}`);
|
|
176
|
+
this.style?.setProperty("--sbb-seat-reservation-graphic-inverse-rotation", `${this.inverseRotation}`);
|
|
159
177
|
}
|
|
160
178
|
}
|
|
161
179
|
render() {
|
|
@@ -220,4 +238,4 @@ let SbbSeatReservationGraphicElement = (() => {
|
|
|
220
238
|
export {
|
|
221
239
|
SbbSeatReservationGraphicElement
|
|
222
240
|
};
|
|
223
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-graphic.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation, mapIconToSvg } from '../common.js';\n\nimport style from './seat-reservation-graphic.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\n/**\n * Output one of the SVG graphics based on its code.\n */\nexport\n@customElement('sbb-seat-reservation-graphic')\nclass SbbSeatReservationGraphicElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Name of the SVG graphic to be displayed. */\n  @forceType()\n  @property({ attribute: 'name' })\n  public accessor name: string = '';\n\n  /** if true, scale the graphic content of the given element non-uniformly if necessary */\n  @forceType()\n  @property({ attribute: 'stretch', type: Boolean })\n  public accessor stretch: boolean = false;\n\n  /** handles the rotation of the SVG graphic */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** Inverse rotation for part of an SVG that can be rotated opposite to the normal rotation */\n  @forceType()\n  @property({ attribute: 'inverse-roration', type: Number })\n  public accessor inverseRotation: number = 0;\n\n  /** width of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = null!;\n\n  /** height of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n    if (_changedProperties.has('width') && !!this.width) {\n      this.style?.setProperty('--sbb-reservation-graphic-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height') && !!this.height) {\n      this.style?.setProperty('--sbb-reservation-graphic-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-reservation-graphic-rotation', `${this.rotation}`);\n    }\n\n    if (_changedProperties.has('inverseRotation')) {\n      this.style?.setProperty(\n        '--sbb-reservation-graphic-inverse-rotation',\n        `${this.inverseRotation}`,\n      );\n    }\n  }\n\n  protected override render(): TemplateResult | null {\n    const svgObj = mapIconToSvg[this.name];\n\n    if (!svgObj?.svg && !svgObj?.svgName) {\n      return null;\n    }\n\n    return html`<span\n      class=\"${classMap({\n        'sbb-sr-icon': !!svgObj.svgName,\n        'sbb-sr-graphic': !!svgObj.svg,\n      })}\"\n    >\n      ${svgObj.svgName\n        ? html` <sbb-icon\n            name=\"${svgObj.svgName || ''}\"\n            aria-hidden=\"false\"\n            aria-label=\"${getI18nSeatReservation(svgObj.svgName, this._language.current)}\"\n          ></sbb-icon>`\n        : html`${this._getSvgElement(svgObj.svg!)}`}\n    </span>`;\n  }\n\n  private _getSvgElement(svg: string): Element | null {\n    const parser = new DOMParser();\n    const svgString = svg || '<svg></svg>';\n    const svgElm = parser.parseFromString(svgString, 'image/svg+xml').firstElementChild;\n    if (this.stretch && svgElm?.nodeName.toLowerCase() === 'svg') {\n      svgElm.setAttribute('preserveAspectRatio', 'none');\n    }\n    return svgElm;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-graphic': SbbSeatReservationGraphicElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
241
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-graphic.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation, mapIconToSvg } from '../common.js';\n\nimport style from './seat-reservation-graphic.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\n/**\n * Output one of the SVG graphics based on its code.\n */\nexport\n@customElement('sbb-seat-reservation-graphic')\nclass SbbSeatReservationGraphicElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Name of the SVG graphic to be displayed. */\n  @forceType()\n  @property({ attribute: 'name' })\n  public accessor name: string = '';\n\n  /** if true, scale the graphic content of the given element non-uniformly if necessary */\n  @forceType()\n  @property({ attribute: 'stretch', type: Boolean })\n  public accessor stretch: boolean = false;\n\n  /** handles the rotation of the SVG graphic */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** Inverse rotation for part of an SVG that can be rotated opposite to the normal rotation */\n  @forceType()\n  @property({ attribute: 'inverse-roration', type: Number })\n  public accessor inverseRotation: number = 0;\n\n  /** width of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = null!;\n\n  /** height of the svg in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = null!;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n    if (_changedProperties.has('width') && !!this.width) {\n      this.style?.setProperty('--sbb-seat-reservation-graphic-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height') && !!this.height) {\n      this.style?.setProperty('--sbb-seat-reservation-graphic-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-seat-reservation-graphic-rotation', `${this.rotation}`);\n    }\n\n    if (_changedProperties.has('inverseRotation')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-graphic-inverse-rotation',\n        `${this.inverseRotation}`,\n      );\n    }\n  }\n\n  protected override render(): TemplateResult | null {\n    const svgObj = mapIconToSvg[this.name];\n\n    if (!svgObj?.svg && !svgObj?.svgName) {\n      return null;\n    }\n\n    return html`<span\n      class=\"${classMap({\n        'sbb-sr-icon': !!svgObj.svgName,\n        'sbb-sr-graphic': !!svgObj.svg,\n      })}\"\n    >\n      ${svgObj.svgName\n        ? html` <sbb-icon\n            name=\"${svgObj.svgName || ''}\"\n            aria-hidden=\"false\"\n            aria-label=\"${getI18nSeatReservation(svgObj.svgName, this._language.current)}\"\n          ></sbb-icon>`\n        : html`${this._getSvgElement(svgObj.svg!)}`}\n    </span>`;\n  }\n\n  private _getSvgElement(svg: string): Element | null {\n    const parser = new DOMParser();\n    const svgString = svg || '<svg></svg>';\n    const svgElm = parser.parseFromString(svgString, 'image/svg+xml').firstElementChild;\n    if (this.stretch && svgElm?.nodeName.toLowerCase() === 'svg') {\n      svgElm.setAttribute('preserveAspectRatio', 'none');\n    }\n    return svgElm;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-graphic': SbbSeatReservationGraphicElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
|
|
2
|
-
import { PlaceTravelClass } from '../common.js';
|
|
2
|
+
import { CoachNumberOfFreePlaces, PlaceTravelClass } from '../common.js';
|
|
3
3
|
export type SelectCoachEventDetails = number;
|
|
4
4
|
/**
|
|
5
5
|
* This component will display the navigation coach item for Seat reservation.
|
|
@@ -17,6 +17,8 @@ export declare class SbbSeatReservationNavigationCoachElement extends LitElement
|
|
|
17
17
|
accessor selected: boolean;
|
|
18
18
|
accessor focused: boolean;
|
|
19
19
|
accessor index: number;
|
|
20
|
+
/** Representation of places available for selecting, counting seat places and bicycle places separetely */
|
|
21
|
+
accessor freePlacesByType: CoachNumberOfFreePlaces;
|
|
20
22
|
/** Travel class of the coach */
|
|
21
23
|
accessor travelClass: PlaceTravelClass[];
|
|
22
24
|
/** If the coach is a driver/restricted area */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,cAAc,EAAW,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC7F,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,cAAc,EAAW,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC7F,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC,OAAO,KAAK,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAI9E,OAAO,+CAA+C,CAAC;AACvD,OAAO,4CAA4C,CAAC;AAIpD,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC;AAE7C;;GAEG;AACH,qBAEM,wCAAyC,SAAQ,UAAU;IAC/D,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX,sEAAsE;IACtE,SAEgB,OAAO,EAAE,MAAM,CAAM;IAErC,2FAA2F;IAC3F,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAG3C,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAG1C,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,SAEgB,KAAK,EAAE,MAAM,CAAK;IAElC,2GAA2G;IAC3G,SACgB,gBAAgB,EAAE,uBAAuB,CAA6B;IAEtF,gCAAgC;IAChC,SACgB,WAAW,EAAE,gBAAgB,EAAE,CAAiB;IAEhE,+CAA+C;IAC/C,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C,kDAAkD;IAClD,SAEgB,KAAK,EAAE,OAAO,CAAS;IAEvC,iDAAiD;IACjD,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC,mCAAmC;IACnC,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,6DAA6D;IAC7D,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAwB5E;;;;;;OAMG;cACgB,MAAM,IAAI,cAAc;IAyB3C,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,kCAAkC;IAmC1C,OAAO,CAAC,gCAAgC;IAYxC;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAgBvB,OAAO,CAAC,2BAA2B;CASpC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uCAAuC,EAAE,wCAAwC,CAAC;KACnF;CACF"}
|
|
@@ -30,6 +30,10 @@ const style = css`*,
|
|
|
30
30
|
--sbb-seat-reservation-navigation-btn-background-color-hover: var(--sbb-color-cloud);
|
|
31
31
|
}
|
|
32
32
|
|
|
33
|
+
:host(.sbb-sr__navigation-coach--hover-scroll) {
|
|
34
|
+
--sbb-seat-reservation-navigation-btn-background-color: var(--sbb-color-cloud);
|
|
35
|
+
}
|
|
36
|
+
|
|
33
37
|
.sbb-sr-navigation__item-coach {
|
|
34
38
|
display: flex;
|
|
35
39
|
flex-direction: column;
|
|
@@ -240,7 +244,7 @@ const style = css`*,
|
|
|
240
244
|
}`;
|
|
241
245
|
const MAX_SERVICE_PROPERTIES = 3;
|
|
242
246
|
let SbbSeatReservationNavigationCoachElement = (() => {
|
|
243
|
-
var _coachId_accessor_storage, _propertyIds_accessor_storage, _selected_accessor_storage, _focused_accessor_storage, _index_accessor_storage, _travelClass_accessor_storage, _driverArea_accessor_storage, _first_accessor_storage, _last_accessor_storage, _disable_accessor_storage, _vertical_accessor_storage, _a;
|
|
247
|
+
var _coachId_accessor_storage, _propertyIds_accessor_storage, _selected_accessor_storage, _focused_accessor_storage, _index_accessor_storage, _freePlacesByType_accessor_storage, _travelClass_accessor_storage, _driverArea_accessor_storage, _first_accessor_storage, _last_accessor_storage, _disable_accessor_storage, _vertical_accessor_storage, _a;
|
|
244
248
|
let _classDecorators = [customElement("sbb-seat-reservation-navigation-coach")];
|
|
245
249
|
let _classDescriptor;
|
|
246
250
|
let _classExtraInitializers = [];
|
|
@@ -261,6 +265,9 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
261
265
|
let _index_decorators;
|
|
262
266
|
let _index_initializers = [];
|
|
263
267
|
let _index_extraInitializers = [];
|
|
268
|
+
let _freePlacesByType_decorators;
|
|
269
|
+
let _freePlacesByType_initializers = [];
|
|
270
|
+
let _freePlacesByType_extraInitializers = [];
|
|
264
271
|
let _travelClass_decorators;
|
|
265
272
|
let _travelClass_initializers = [];
|
|
266
273
|
let _travelClass_extraInitializers = [];
|
|
@@ -287,6 +294,7 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
287
294
|
__privateAdd(this, _selected_accessor_storage);
|
|
288
295
|
__privateAdd(this, _focused_accessor_storage);
|
|
289
296
|
__privateAdd(this, _index_accessor_storage);
|
|
297
|
+
__privateAdd(this, _freePlacesByType_accessor_storage);
|
|
290
298
|
__privateAdd(this, _travelClass_accessor_storage);
|
|
291
299
|
__privateAdd(this, _driverArea_accessor_storage);
|
|
292
300
|
__privateAdd(this, _first_accessor_storage);
|
|
@@ -298,7 +306,8 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
298
306
|
__privateSet(this, _selected_accessor_storage, (__runInitializers(this, _propertyIds_extraInitializers), __runInitializers(this, _selected_initializers, false)));
|
|
299
307
|
__privateSet(this, _focused_accessor_storage, (__runInitializers(this, _selected_extraInitializers), __runInitializers(this, _focused_initializers, false)));
|
|
300
308
|
__privateSet(this, _index_accessor_storage, (__runInitializers(this, _focused_extraInitializers), __runInitializers(this, _index_initializers, 0)));
|
|
301
|
-
__privateSet(this,
|
|
309
|
+
__privateSet(this, _freePlacesByType_accessor_storage, (__runInitializers(this, _index_extraInitializers), __runInitializers(this, _freePlacesByType_initializers, { seats: 0, bicycles: 0 })));
|
|
310
|
+
__privateSet(this, _travelClass_accessor_storage, (__runInitializers(this, _freePlacesByType_extraInitializers), __runInitializers(this, _travelClass_initializers, ["ANY_CLASS"])));
|
|
302
311
|
__privateSet(this, _driverArea_accessor_storage, (__runInitializers(this, _travelClass_extraInitializers), __runInitializers(this, _driverArea_initializers, false)));
|
|
303
312
|
__privateSet(this, _first_accessor_storage, (__runInitializers(this, _driverArea_extraInitializers), __runInitializers(this, _first_initializers, false)));
|
|
304
313
|
__privateSet(this, _last_accessor_storage, (__runInitializers(this, _first_extraInitializers), __runInitializers(this, _last_initializers, false)));
|
|
@@ -340,6 +349,13 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
340
349
|
set index(value) {
|
|
341
350
|
__privateSet(this, _index_accessor_storage, value);
|
|
342
351
|
}
|
|
352
|
+
/** Representation of places available for selecting, counting seat places and bicycle places separetely */
|
|
353
|
+
get freePlacesByType() {
|
|
354
|
+
return __privateGet(this, _freePlacesByType_accessor_storage);
|
|
355
|
+
}
|
|
356
|
+
set freePlacesByType(value) {
|
|
357
|
+
__privateSet(this, _freePlacesByType_accessor_storage, value);
|
|
358
|
+
}
|
|
343
359
|
/** Travel class of the coach */
|
|
344
360
|
get travelClass() {
|
|
345
361
|
return __privateGet(this, _travelClass_accessor_storage);
|
|
@@ -479,6 +495,8 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
479
495
|
const serviceClassLabel = getI18nSeatReservation("NAVIGATE_TO_COACH_SERVICE_CLASS_SUB", this._language.current, [serviceClassTranslation]);
|
|
480
496
|
label = label.concat(serviceClassLabel);
|
|
481
497
|
}
|
|
498
|
+
const freePlacesTxt = getI18nSeatReservation("COACH_AVAILABLE_NUMBER_OF_PLACES", this._language.current, [this.freePlacesByType.seats, this.freePlacesByType.bicycles]);
|
|
499
|
+
label = label.concat(". ").concat(freePlacesTxt);
|
|
482
500
|
return label;
|
|
483
501
|
}
|
|
484
502
|
_getAriaDescriptionCoachServices() {
|
|
@@ -512,13 +530,14 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
512
530
|
return null;
|
|
513
531
|
}
|
|
514
532
|
}
|
|
515
|
-
}, _coachId_accessor_storage = new WeakMap(), _propertyIds_accessor_storage = new WeakMap(), _selected_accessor_storage = new WeakMap(), _focused_accessor_storage = new WeakMap(), _index_accessor_storage = new WeakMap(), _travelClass_accessor_storage = new WeakMap(), _driverArea_accessor_storage = new WeakMap(), _first_accessor_storage = new WeakMap(), _last_accessor_storage = new WeakMap(), _disable_accessor_storage = new WeakMap(), _vertical_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
533
|
+
}, _coachId_accessor_storage = new WeakMap(), _propertyIds_accessor_storage = new WeakMap(), _selected_accessor_storage = new WeakMap(), _focused_accessor_storage = new WeakMap(), _index_accessor_storage = new WeakMap(), _freePlacesByType_accessor_storage = new WeakMap(), _travelClass_accessor_storage = new WeakMap(), _driverArea_accessor_storage = new WeakMap(), _first_accessor_storage = new WeakMap(), _last_accessor_storage = new WeakMap(), _disable_accessor_storage = new WeakMap(), _vertical_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
516
534
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
517
535
|
_coachId_decorators = [forceType(), property({ attribute: "coach-id" })];
|
|
518
536
|
_propertyIds_decorators = [property({ attribute: "property-ids", type: Array })];
|
|
519
537
|
_selected_decorators = [forceType(), property({ type: Boolean })];
|
|
520
538
|
_focused_decorators = [forceType(), property({ type: Boolean })];
|
|
521
539
|
_index_decorators = [forceType(), property({ type: Number })];
|
|
540
|
+
_freePlacesByType_decorators = [property({ attribute: "free-places-by-type", type: Object })];
|
|
522
541
|
_travelClass_decorators = [property({ attribute: "travel-class", type: Array })];
|
|
523
542
|
_driverArea_decorators = [forceType(), property({ attribute: "driver-area", type: Boolean })];
|
|
524
543
|
_first_decorators = [forceType(), property({ type: Boolean })];
|
|
@@ -540,6 +559,9 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
540
559
|
__esDecorate(_a, null, _index_decorators, { kind: "accessor", name: "index", static: false, private: false, access: { has: (obj) => "index" in obj, get: (obj) => obj.index, set: (obj, value) => {
|
|
541
560
|
obj.index = value;
|
|
542
561
|
} }, metadata: _metadata }, _index_initializers, _index_extraInitializers);
|
|
562
|
+
__esDecorate(_a, null, _freePlacesByType_decorators, { kind: "accessor", name: "freePlacesByType", static: false, private: false, access: { has: (obj) => "freePlacesByType" in obj, get: (obj) => obj.freePlacesByType, set: (obj, value) => {
|
|
563
|
+
obj.freePlacesByType = value;
|
|
564
|
+
} }, metadata: _metadata }, _freePlacesByType_initializers, _freePlacesByType_extraInitializers);
|
|
543
565
|
__esDecorate(_a, null, _travelClass_decorators, { kind: "accessor", name: "travelClass", static: false, private: false, access: { has: (obj) => "travelClass" in obj, get: (obj) => obj.travelClass, set: (obj, value) => {
|
|
544
566
|
obj.travelClass = value;
|
|
545
567
|
} }, metadata: _metadata }, _travelClass_initializers, _travelClass_extraInitializers);
|
|
@@ -570,4 +592,4 @@ let SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
570
592
|
export {
|
|
571
593
|
SbbSeatReservationNavigationCoachElement
|
|
572
594
|
};
|
|
573
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.js';\nimport type { PlaceTravelClass } from '../common.js';\n\nimport style from './seat-reservation-navigation-coach.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-navigation-services.js';\n\nconst MAX_SERVICE_PROPERTIES = 3;\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport\n@customElement('sbb-seat-reservation-navigation-coach')\nclass SbbSeatReservationNavigationCoachElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Coach ID, which is used to identify the coach in the navigation */\n  @forceType()\n  @property({ attribute: 'coach-id' })\n  public accessor coachId: string = '';\n\n  /** Coach service property ids, which are used to display the services in the navigation */\n  @property({ attribute: 'property-ids', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /* pre-selected Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /* focus Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  /** Travel class of the coach */\n  @property({ attribute: 'travel-class', type: Array })\n  public accessor travelClass: PlaceTravelClass[] = ['ANY_CLASS'];\n\n  /** If the coach is a driver/restricted area */\n  @forceType()\n  @property({ attribute: 'driver-area', type: Boolean })\n  public accessor driverArea: boolean = false;\n\n  /** If the coach is the first in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor first: boolean = false;\n\n  /** If the coach is the last in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor last: boolean = false;\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor vertical: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        selectedNavButtonElement.focus();\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (focusedNavButtonElement) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a maximum of 3 of the service sign icons (slice(0,3)) regardless of the input from Backend,\n   * otherwise the layout could be destroyed. Furthermore, we have to filter out the value ANY_SEAT,\n   * since this is also passed as a property and does not need to be used here\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    this.propertyIds = this.propertyIds\n      .filter((propertyId) => propertyId !== 'ANY_SEAT')\n      .slice(0, MAX_SERVICE_PROPERTIES);\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.last,\n          'first-coach': this.first,\n          'vertical-coach': this.vertical,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.propertyIds}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n        type=\"button\"\n        ?disabled=\"${this.disable}\"\n        class=\"${classMap({\n          'sbb-sr-navigation__ctrl-button': true,\n          'sbb-sr-navigation-driver-area': this.driverArea,\n        })}\"\n        title=\"${titleDescriptionNavCoachButton}\"\n        aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n        @click=${() => this._selectNavCoach(this.index)}\n      >\n        ${this._getBtnInformation(currServiceClassNumber)}\n      </button>\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\"\n        >${ariaDescriptionCoachServices}</sbb-screen-reader-only\n      >`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.driverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.travelClass?.length > 0 || this.coachId\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachId\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachId}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (this.driverArea) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachId,\n      ]);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [this.coachId]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescrition = null;\n    if (this.propertyIds.length) {\n      ariaDescrition =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescrition += this.propertyIds\n        .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n        .join();\n    }\n    return ariaDescrition;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    if (!this.driverArea) {\n      /**\n       * @type {CustomEvent<SelectCoachEventDetails>}\n       * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n          bubbles: true,\n          composed: true,\n          detail: coachIndex,\n        }),\n      );\n    }\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    if (this.travelClass?.includes('FIRST')) {\n      return 1;\n    } else if (this.travelClass?.includes('SECOND')) {\n      return 2;\n    } else {\n      return null;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeA,MAAM,yBAAyB;IASzB,4CAAwC,MAAA;;0BAD7C,cAAc,uCAAuC,CAAC;;;;oBACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAR,EAAA,mBAAQ,YAAU;AAAA;;AAU/D;AAIA;AAKA;AAKA;AAIA;AAIA;AAKA;AAKA;AAKA;AAKA;AAKA;AA/CgB,yBAAA,2BAAA,kBAAA,MAAA,uBAAkB,EAAE;AAIpB,yBAAA,gCAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,2BAAwB,CAAA,CAAE;AAK1B,yBAAA,6BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAKzB,yBAAA,4BAAA,kBAAA,MAAA,2BAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAIxB,yBAAA,0BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,qBAAgB,CAAC;AAIjB,yBAAA,gCAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,2BAAkC,CAAC,WAAW,CAAC;AAK/C,yBAAA,+BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,0BAAsB,KAAK;AAK3B,yBAAA,0BAAA,kBAAA,MAAA,6BAAA,GAAA,kBAAA,MAAA,qBAAiB,KAAK;AAKtB,yBAAA,yBAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,oBAAgB,KAAK;AAKrB,yBAAA,4BAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAKxB,yBAAA,6BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAEjC,WAAA,mEAAY,IAAI,sBAAsB,IAAI;AAAA,IAoLpD;AAAA;AAAA,IArOE,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAIvB,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA;AAAA,IAKxB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA,IAIvB,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAIrB,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,aAAU;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1B,IAAgB,WAAU,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA,IAK1B,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAKrB,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAKpB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAKvB,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA,IAIL,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAElC,UAAI,kBAAkB,IAAI,UAAU,GAAG;AACrC,cAAM,2BAA2B,KAAK,YAAY,cAChD,iCAAiC;AAEnC,YAAI,KAAK,YAAY,0BAA0B;AAC7C,mCAAyB,MAAA;AAEzB,eAAK,cAAc,IAAI,MAAM,cAAc,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAAA,QAC/E;AAAA,MACF;AAEA,UAAI,kBAAkB,IAAI,SAAS,KAAK,KAAK,SAAS;AACpD,cAAM,0BAA0B,KAAK,YAAY,cAC/C,iCAAiC;AAEnC,YAAI,yBAAyB;AAC3B,kCAAwB,MAAA;AAAA,QAC1B;AAAA,MACF;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASmB,SAAM;AACvB,WAAK,cAAc,KAAK,YACrB,OAAO,CAAC,eAAe,eAAe,UAAU,EAChD,MAAM,GAAG,sBAAsB;AAClC,aAAO;AAAA;AAAA,iBAEM,SAAS;AAAA,QAChB,iCAAiC;AAAA,QACjC,cAAc,KAAK;AAAA,QACnB,eAAe,KAAK;AAAA,QACpB,kBAAkB,KAAK;AAAA,QACvB,2CAA2C,KAAK;AAAA,MAAA,CACjD,CAAC;AAAA;AAAA,UAEA,KAAK,sBAAsB;AAAA,UAC3B,KAAK,aAAa,SAChB;AAAA,2BACe,KAAK,QAAQ;AAAA,8BACV,KAAK,WAAW;AAAA,4DAElC,OAAO;AAAA;AAAA;AAAA,IAGjB;AAAA,IAEQ,uBAAoB;AAC1B,YAAM,yBAAyB,KAAK,4BAAA;AACpC,YAAM,iCACJ,KAAK,mCAAmC,sBAAsB;AAChE,YAAM,+BAA+B,KAAK,iCAAA;AAE1C,aAAO;AAAA;AAAA,qBAEU,KAAK,OAAO;AAAA,iBAChB,SAAS;AAAA,QAChB,kCAAkC;AAAA,QAClC,iCAAiC,KAAK;AAAA,MAAA,CACvC,CAAC;AAAA,iBACO,8BAA8B;AAAA,2DACY,KAAK,KAAK;AAAA,iBACpD,MAAM,KAAK,gBAAgB,KAAK,KAAK,CAAC;AAAA;AAAA,UAE7C,KAAK,mBAAmB,sBAAsB,CAAC;AAAA;AAAA,mEAEU,KAAK,KAAK;AAAA,WAClE,4BAA4B;AAAA;AAAA,IAErC;AAAA,IAEQ,mBAAmB,oBAAiC;AAC1D,UAAI,KAAK,YAAY;AACnB,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,QACH,uBAAuB,IACrB,6DACA,OAAO;AAAA,QACT,KAAK,aAAa,SAAS,KAAK,KAAK,UACnC;AAAA,cACI,KAAK,UACH;AAAA,oBACI,KAAK,OAAO;AAAA,0BAEhB,OAAO;AAAA;AAAA,gBAEP,sBAAsB,OAAO;AAAA;AAAA;AAAA;AAAA,gBAI7B,kBAAkB;AAAA;AAAA,oBAGxB,OAAO;AAAA;AAAA,IAEf;AAAA,IAEQ,mCAAmC,oBAAiC;AAC1E,UAAI,KAAK,YAAY;AACnB,eAAO,uBAAuB,0BAA0B,KAAK,UAAU,SAAS;AAAA,UAC9E,KAAK;AAAA,QAAA,CACN;AAAA,MACH;AAEA,UAAI,QAAQ,uBAAuB,qBAAqB,KAAK,UAAU,SAAS,CAAC,KAAK,OAAO,CAAC;AAG9F,UAAI,oBAAoB;AACtB,cAAM,6BACJ,uBAAuB,IAAI,wBAAwB;AACrD,cAAM,0BAA0B,uBAC9B,4BACA,KAAK,UAAU,OAAO;AAExB,cAAM,oBAAoB,uBACxB,uCACA,KAAK,UAAU,SACf,CAAC,uBAAuB,CAAC;AAE3B,gBAAQ,MAAM,OAAO,iBAAiB;AAAA,MACxC;AAEA,aAAO;AAAA,IACT;AAAA,IAEQ,mCAAgC;AACtC,UAAI,iBAAiB;AACrB,UAAI,KAAK,YAAY,QAAQ;AAC3B,yBACE,uBAAuB,4BAA4B,KAAK,UAAU,OAAO,IAAI;AAC/E,0BAAkB,KAAK,YACpB,IAAI,CAAC,eAAe,uBAAuB,YAAY,KAAK,UAAU,OAAO,CAAC,EAC9E,KAAA;AAAA,MACL;AACA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOQ,gBAAgB,YAAkB;AACxC,UAAI,CAAC,KAAK,YAAY;AAKpB,aAAK,cACH,IAAI,YAAqC,eAAe;AAAA,UACtD,SAAS;AAAA,UACT,UAAU;AAAA,UACV,QAAQ;AAAA,QAAA,CACT,CAAC;AAAA,MAEN;AAAA,IACF;AAAA,IAEQ,8BAA2B;AACjC,UAAI,KAAK,aAAa,SAAS,OAAO,GAAG;AACvC,eAAO;AAAA,MACT,WAAW,KAAK,aAAa,SAAS,QAAQ,GAAG;AAC/C,eAAO;AAAA,MACT,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAAA,KApOA,2CAIA,+CAKA,4CAKA,2CAIA,yCAIA,+CAKA,8CAKA,yCAKA,wCAKA,2CAKA;;2BAjDC,aACA,SAAS,EAAE,WAAW,WAAA,CAAY,CAAC;+BAInC,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;4BAIpD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;2BAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;yBAG3B,aACA,SAAS,EAAE,MAAM,OAAA,CAAQ,CAAC;+BAI1B,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;AAIpD,6BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,eAAe,MAAM,QAAA,CAAS,CAAC;yBAIrD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;wBAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAI3B,0BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,WAAW,MAAM,QAAA,CAAS,CAAC;4BAIjD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AA9C5B,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AAKxB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAIrB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,YAAU,KAAA,CAAA,KAAA,UAAA;AAAA,UAAV,aAAU;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,0BAAA,6BAAA;AAK1B,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAKrB,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AAKpB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAKvB,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AAzD1B,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACyB,GAAA,SAAyB,OACzB,GAAA,SAAS;AAAA,IAC9B,aAAa;AAAA,IACb,YAAY;AAAA,EAAA,GAJV,kBAAA,YAAA,uBAAA,GAAyC;;;"}
|
|
595
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { type CSSResultGroup, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.js';\nimport type { CoachNumberOfFreePlaces, PlaceTravelClass } from '../common.js';\n\nimport style from './seat-reservation-navigation-coach.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '../seat-reservation-navigation-services.js';\n\nconst MAX_SERVICE_PROPERTIES = 3;\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport\n@customElement('sbb-seat-reservation-navigation-coach')\nclass SbbSeatReservationNavigationCoachElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Coach ID, which is used to identify the coach in the navigation */\n  @forceType()\n  @property({ attribute: 'coach-id' })\n  public accessor coachId: string = '';\n\n  /** Coach service property ids, which are used to display the services in the navigation */\n  @property({ attribute: 'property-ids', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /* pre-selected Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /* focus Coach index property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  /** Representation of places available for selecting, counting seat places and bicycle places separetely */\n  @property({ attribute: 'free-places-by-type', type: Object })\n  public accessor freePlacesByType: CoachNumberOfFreePlaces = { seats: 0, bicycles: 0 };\n\n  /** Travel class of the coach */\n  @property({ attribute: 'travel-class', type: Array })\n  public accessor travelClass: PlaceTravelClass[] = ['ANY_CLASS'];\n\n  /** If the coach is a driver/restricted area */\n  @forceType()\n  @property({ attribute: 'driver-area', type: Boolean })\n  public accessor driverArea: boolean = false;\n\n  /** If the coach is the first in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor first: boolean = false;\n\n  /** If the coach is the last in the navigation */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor last: boolean = false;\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor vertical: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        selectedNavButtonElement.focus();\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (focusedNavButtonElement) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a maximum of 3 of the service sign icons (slice(0,3)) regardless of the input from Backend,\n   * otherwise the layout could be destroyed. Furthermore, we have to filter out the value ANY_SEAT,\n   * since this is also passed as a property and does not need to be used here\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    this.propertyIds = this.propertyIds\n      .filter((propertyId) => propertyId !== 'ANY_SEAT')\n      .slice(0, MAX_SERVICE_PROPERTIES);\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.last,\n          'first-coach': this.first,\n          'vertical-coach': this.vertical,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.propertyIds}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n        type=\"button\"\n        ?disabled=\"${this.disable}\"\n        class=\"${classMap({\n          'sbb-sr-navigation__ctrl-button': true,\n          'sbb-sr-navigation-driver-area': this.driverArea,\n        })}\"\n        title=\"${titleDescriptionNavCoachButton}\"\n        aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n        @click=${() => this._selectNavCoach(this.index)}\n      >\n        ${this._getBtnInformation(currServiceClassNumber)}\n      </button>\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\"\n        >${ariaDescriptionCoachServices}</sbb-screen-reader-only\n      >`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.driverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.travelClass?.length > 0 || this.coachId\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachId\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachId}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (this.driverArea) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachId,\n      ]);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [this.coachId]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    // Expands the number of available seats and bicycle spaces as info\n    const freePlacesTxt = getI18nSeatReservation(\n      'COACH_AVAILABLE_NUMBER_OF_PLACES',\n      this._language.current,\n      [this.freePlacesByType.seats, this.freePlacesByType.bicycles],\n    );\n    label = label.concat('. ').concat(freePlacesTxt);\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescrition = null;\n    if (this.propertyIds.length) {\n      ariaDescrition =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescrition += this.propertyIds\n        .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n        .join();\n    }\n    return ariaDescrition;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    if (!this.driverArea) {\n      /**\n       * @type {CustomEvent<SelectCoachEventDetails>}\n       * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n          bubbles: true,\n          composed: true,\n          detail: coachIndex,\n        }),\n      );\n    }\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    if (this.travelClass?.includes('FIRST')) {\n      return 1;\n    } else if (this.travelClass?.includes('SECOND')) {\n      return 2;\n    } else {\n      return null;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeA,MAAM,yBAAyB;IASzB,4CAAwC,MAAA;;0BAD7C,cAAc,uCAAuC,CAAC;;;;oBACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAR,EAAA,mBAAQ,YAAU;AAAA;;AAU/D;AAIA;AAKA;AAKA;AAIA;AAIA;AAIA;AAKA;AAKA;AAKA;AAKA;AAKA;AAnDgB,yBAAA,2BAAA,kBAAA,MAAA,uBAAkB,EAAE;AAIpB,yBAAA,gCAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,2BAAwB,CAAA,CAAE;AAK1B,yBAAA,6BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAKzB,yBAAA,4BAAA,kBAAA,MAAA,2BAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAIxB,yBAAA,0BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,qBAAgB,CAAC;AAIjB,yBAAA,qCAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,gCAA4C,EAAE,OAAO,GAAG,UAAU,GAAG;AAIrE,yBAAA,gCAAA,kBAAA,MAAA,mCAAA,GAAA,kBAAA,MAAA,2BAAkC,CAAC,WAAW,CAAC;AAK/C,yBAAA,+BAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,0BAAsB,KAAK;AAK3B,yBAAA,0BAAA,kBAAA,MAAA,6BAAA,GAAA,kBAAA,MAAA,qBAAiB,KAAK;AAKtB,yBAAA,yBAAA,kBAAA,MAAA,wBAAA,GAAA,kBAAA,MAAA,oBAAgB,KAAK;AAKrB,yBAAA,4BAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,uBAAmB,KAAK;AAKxB,yBAAA,6BAAA,kBAAA,MAAA,0BAAA,GAAA,kBAAA,MAAA,wBAAoB,KAAK;AAEjC,WAAA,mEAAY,IAAI,sBAAsB,IAAI;AAAA,IA2LpD;AAAA;AAAA,IAhPE,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAIvB,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA;AAAA,IAKxB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA,IAIvB,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAIrB,IAAgB,mBAAgB;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAhC,IAAgB,iBAAgB,OAAA;AAAA,yBAAA,oCAAA;AAAA,IAAA;AAAA;AAAA,IAIhC,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAK3B,IAAgB,aAAU;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1B,IAAgB,WAAU,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA,IAK1B,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAKrB,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAKpB,IAAgB,UAAO;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAvB,IAAgB,QAAO,OAAA;AAAA,yBAAA,2BAAA;AAAA,IAAA;AAAA;AAAA,IAKvB,IAAgB,WAAQ;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAxB,IAAgB,SAAQ,OAAA;AAAA,yBAAA,4BAAA;AAAA,IAAA;AAAA,IAIL,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAElC,UAAI,kBAAkB,IAAI,UAAU,GAAG;AACrC,cAAM,2BAA2B,KAAK,YAAY,cAChD,iCAAiC;AAEnC,YAAI,KAAK,YAAY,0BAA0B;AAC7C,mCAAyB,MAAA;AAEzB,eAAK,cAAc,IAAI,MAAM,cAAc,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAAA,QAC/E;AAAA,MACF;AAEA,UAAI,kBAAkB,IAAI,SAAS,KAAK,KAAK,SAAS;AACpD,cAAM,0BAA0B,KAAK,YAAY,cAC/C,iCAAiC;AAEnC,YAAI,yBAAyB;AAC3B,kCAAwB,MAAA;AAAA,QAC1B;AAAA,MACF;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASmB,SAAM;AACvB,WAAK,cAAc,KAAK,YACrB,OAAO,CAAC,eAAe,eAAe,UAAU,EAChD,MAAM,GAAG,sBAAsB;AAClC,aAAO;AAAA;AAAA,iBAEM,SAAS;AAAA,QAChB,iCAAiC;AAAA,QACjC,cAAc,KAAK;AAAA,QACnB,eAAe,KAAK;AAAA,QACpB,kBAAkB,KAAK;AAAA,QACvB,2CAA2C,KAAK;AAAA,MAAA,CACjD,CAAC;AAAA;AAAA,UAEA,KAAK,sBAAsB;AAAA,UAC3B,KAAK,aAAa,SAChB;AAAA,2BACe,KAAK,QAAQ;AAAA,8BACV,KAAK,WAAW;AAAA,4DAElC,OAAO;AAAA;AAAA;AAAA,IAGjB;AAAA,IAEQ,uBAAoB;AAC1B,YAAM,yBAAyB,KAAK,4BAAA;AACpC,YAAM,iCACJ,KAAK,mCAAmC,sBAAsB;AAChE,YAAM,+BAA+B,KAAK,iCAAA;AAE1C,aAAO;AAAA;AAAA,qBAEU,KAAK,OAAO;AAAA,iBAChB,SAAS;AAAA,QAChB,kCAAkC;AAAA,QAClC,iCAAiC,KAAK;AAAA,MAAA,CACvC,CAAC;AAAA,iBACO,8BAA8B;AAAA,2DACY,KAAK,KAAK;AAAA,iBACpD,MAAM,KAAK,gBAAgB,KAAK,KAAK,CAAC;AAAA;AAAA,UAE7C,KAAK,mBAAmB,sBAAsB,CAAC;AAAA;AAAA,mEAEU,KAAK,KAAK;AAAA,WAClE,4BAA4B;AAAA;AAAA,IAErC;AAAA,IAEQ,mBAAmB,oBAAiC;AAC1D,UAAI,KAAK,YAAY;AACnB,eAAO;AAAA,MACT;AAEA,aAAO;AAAA,QACH,uBAAuB,IACrB,6DACA,OAAO;AAAA,QACT,KAAK,aAAa,SAAS,KAAK,KAAK,UACnC;AAAA,cACI,KAAK,UACH;AAAA,oBACI,KAAK,OAAO;AAAA,0BAEhB,OAAO;AAAA;AAAA,gBAEP,sBAAsB,OAAO;AAAA;AAAA;AAAA;AAAA,gBAI7B,kBAAkB;AAAA;AAAA,oBAGxB,OAAO;AAAA;AAAA,IAEf;AAAA,IAEQ,mCAAmC,oBAAiC;AAC1E,UAAI,KAAK,YAAY;AACnB,eAAO,uBAAuB,0BAA0B,KAAK,UAAU,SAAS;AAAA,UAC9E,KAAK;AAAA,QAAA,CACN;AAAA,MACH;AAEA,UAAI,QAAQ,uBAAuB,qBAAqB,KAAK,UAAU,SAAS,CAAC,KAAK,OAAO,CAAC;AAG9F,UAAI,oBAAoB;AACtB,cAAM,6BACJ,uBAAuB,IAAI,wBAAwB;AACrD,cAAM,0BAA0B,uBAC9B,4BACA,KAAK,UAAU,OAAO;AAExB,cAAM,oBAAoB,uBACxB,uCACA,KAAK,UAAU,SACf,CAAC,uBAAuB,CAAC;AAE3B,gBAAQ,MAAM,OAAO,iBAAiB;AAAA,MACxC;AAGA,YAAM,gBAAgB,uBACpB,oCACA,KAAK,UAAU,SACf,CAAC,KAAK,iBAAiB,OAAO,KAAK,iBAAiB,QAAQ,CAAC;AAE/D,cAAQ,MAAM,OAAO,IAAI,EAAE,OAAO,aAAa;AAC/C,aAAO;AAAA,IACT;AAAA,IAEQ,mCAAgC;AACtC,UAAI,iBAAiB;AACrB,UAAI,KAAK,YAAY,QAAQ;AAC3B,yBACE,uBAAuB,4BAA4B,KAAK,UAAU,OAAO,IAAI;AAC/E,0BAAkB,KAAK,YACpB,IAAI,CAAC,eAAe,uBAAuB,YAAY,KAAK,UAAU,OAAO,CAAC,EAC9E,KAAA;AAAA,MACL;AACA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOQ,gBAAgB,YAAkB;AACxC,UAAI,CAAC,KAAK,YAAY;AAKpB,aAAK,cACH,IAAI,YAAqC,eAAe;AAAA,UACtD,SAAS;AAAA,UACT,UAAU;AAAA,UACV,QAAQ;AAAA,QAAA,CACT,CAAC;AAAA,MAEN;AAAA,IACF;AAAA,IAEQ,8BAA2B;AACjC,UAAI,KAAK,aAAa,SAAS,OAAO,GAAG;AACvC,eAAO;AAAA,MACT,WAAW,KAAK,aAAa,SAAS,QAAQ,GAAG;AAC/C,eAAO;AAAA,MACT,OAAO;AACL,eAAO;AAAA,MACT;AAAA,IACF;AAAA,KA/OA,2CAIA,+CAKA,4CAKA,2CAIA,yCAIA,oDAIA,+CAKA,8CAKA,yCAKA,wCAKA,2CAKA;;2BArDC,aACA,SAAS,EAAE,WAAW,WAAA,CAAY,CAAC;+BAInC,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;4BAIpD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;2BAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;yBAG3B,aACA,SAAS,EAAE,MAAM,OAAA,CAAQ,CAAC;oCAI1B,SAAS,EAAE,WAAW,uBAAuB,MAAM,OAAA,CAAQ,CAAC;+BAI5D,SAAS,EAAE,WAAW,gBAAgB,MAAM,MAAA,CAAO,CAAC;AAIpD,6BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,eAAe,MAAM,QAAA,CAAS,CAAC;yBAIrD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;wBAI3B,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAI3B,0BAAA,CAAA,UAAA,GACA,SAAS,EAAE,WAAW,WAAW,MAAM,QAAA,CAAS,CAAC;4BAIjD,aACA,SAAS,EAAE,MAAM,QAAA,CAAS,CAAC;AAlD5B,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AAKxB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAIvB,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAIrB,iBAAA,IAAA,MAAA,8BAAA,EAAA,MAAA,YAAA,MAAA,oBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,sBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,kBAAgB,KAAA,CAAA,KAAA,UAAA;AAAA,UAAhB,mBAAgB;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,gCAAA,mCAAA;AAIhC,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAK3B,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,YAAU,KAAA,CAAA,KAAA,UAAA;AAAA,UAAV,aAAU;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,0BAAA,6BAAA;AAK1B,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAKrB,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AAKpB,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,YAAA,MAAA,WAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,aAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,SAAO,KAAA,CAAA,KAAA,UAAA;AAAA,UAAP,UAAO;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,uBAAA,0BAAA;AAKvB,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,YAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,UAAQ,KAAA,CAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,wBAAA,2BAAA;AA7D1B,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACyB,GAAA,SAAyB,OACzB,GAAA,SAAS;AAAA,IAC9B,aAAa;AAAA,IACb,YAAY;AAAA,EAAA,GAJV,kBAAA,YAAA,uBAAA,GAAyC;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-place-control.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAGrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAInG,OAAO,KAAK,EAAkB,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,gCAAgC,CAAC;AAIxC;;GAEG;AACH,qBAEM,qCAAsC,SAAQ,oBAAoB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,qDAAqD;IACrD,SAEgB,SAAS,EAAE,SAAS,CAAU;IAE9C,6DAA6D;IAC7D,SAEgB,KAAK,EAAE,UAAU,CAAU;IAE3C,sEAAsE;IACtE,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,yCAAyC;IACzC,SAEgB,QAAQ,EAAE,MAAM,CAAK;IAErC,kDAAkD;IAClD,SAEgB,KAAK,EAAE,MAAM,CAAM;IAEnC,mDAAmD;IACnD,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,qDAAqD;IACrD,SAEgB,YAAY,EAAE,MAAM,CAAK;IAEzC,8DAA8D;IAC9D,SAEgB,UAAU,EAAE,MAAM,CAAS;IAE3C,kDAAkD;IAClD,SAEgB,YAAY,EAAE,OAAO,CAAS;IAE9C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,MAAM,CAAa;IAE7C,OAAO,CAAC,SAAS,CAAmC;;cAOjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cA4BzD,MAAM,IAAI,cAAc;IAkC3C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,yBAAyB;IAejC,yGAAyG;IACzG,OAAO,CAAC,YAAY;
|
|
1
|
+
{"version":3,"file":"seat-reservation-place-control.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,+CAA+C,CAAC;AAGrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAInG,OAAO,KAAK,EAAkB,UAAU,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,gCAAgC,CAAC;AAIxC;;GAEG;AACH,qBAEM,qCAAsC,SAAQ,oBAAoB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,qDAAqD;IACrD,SAEgB,SAAS,EAAE,SAAS,CAAU;IAE9C,6DAA6D;IAC7D,SAEgB,KAAK,EAAE,UAAU,CAAU;IAE3C,sEAAsE;IACtE,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,yCAAyC;IACzC,SAEgB,QAAQ,EAAE,MAAM,CAAK;IAErC,kDAAkD;IAClD,SAEgB,KAAK,EAAE,MAAM,CAAM;IAEnC,mDAAmD;IACnD,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,qDAAqD;IACrD,SAEgB,YAAY,EAAE,MAAM,CAAK;IAEzC,8DAA8D;IAC9D,SAEgB,UAAU,EAAE,MAAM,CAAS;IAE3C,kDAAkD;IAClD,SAEgB,YAAY,EAAE,OAAO,CAAS;IAE9C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,MAAM,CAAa;IAE7C,OAAO,CAAC,SAAS,CAAmC;;cAOjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cA4BzD,MAAM,IAAI,cAAc;IAkC3C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,yBAAyB;IAejC,yGAAyG;IACzG,OAAO,CAAC,YAAY;CA2BrB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,oCAAoC,EAAE,qCAAqC,CAAC;KAC7E;CACF"}
|