@sbb-esta/lyne-elements-experimental 3.1.0 → 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.
Files changed (64) hide show
  1. package/custom-elements.json +908 -567
  2. package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  3. package/development/seat-reservation/common/mapper/icon-mapper.js +1 -3
  4. package/development/seat-reservation/common/mapper/mapper.d.ts +4 -3
  5. package/development/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  6. package/development/seat-reservation/common/mapper/mapper.js +6 -4
  7. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  8. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +4989 -4
  9. package/development/seat-reservation/common/svgs.d.ts +0 -1
  10. package/development/seat-reservation/common/svgs.d.ts.map +1 -1
  11. package/development/seat-reservation/common/svgs.js +1 -3
  12. package/development/seat-reservation/common/translations/i18n.js +194 -194
  13. package/development/seat-reservation/common/types.d.ts +10 -0
  14. package/development/seat-reservation/common/types.d.ts.map +1 -1
  15. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +38 -12
  16. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  17. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +252 -122
  18. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +28 -13
  19. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  20. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +481 -262
  21. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +17 -10
  22. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
  23. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +1 -6
  24. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +36 -18
  25. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +3 -1
  26. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  27. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +26 -4
  28. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
  29. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +86 -54
  30. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +1 -16
  31. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -1
  32. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +10 -164
  33. package/package.json +2 -2
  34. package/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  35. package/seat-reservation/common/mapper/icon-mapper.js +0 -2
  36. package/seat-reservation/common/mapper/mapper.d.ts +4 -3
  37. package/seat-reservation/common/mapper/mapper.d.ts.map +1 -1
  38. package/seat-reservation/common/mapper/mapper.js +16 -14
  39. package/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +1 -1
  40. package/seat-reservation/common/mapper/seat-reservation-sample-data.js +4988 -3
  41. package/seat-reservation/common/svgs.d.ts +0 -1
  42. package/seat-reservation/common/svgs.d.ts.map +1 -1
  43. package/seat-reservation/common/svgs.js +4 -11
  44. package/seat-reservation/common/translations/i18n.js +197 -197
  45. package/seat-reservation/common/types.d.ts +10 -0
  46. package/seat-reservation/common/types.d.ts.map +1 -1
  47. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +38 -12
  48. package/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  49. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +208 -134
  50. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts +28 -13
  51. package/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  52. package/seat-reservation/seat-reservation/seat-reservation.component.js +290 -298
  53. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +22 -22
  54. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
  55. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +0 -5
  56. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +37 -37
  57. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +3 -1
  58. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  59. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +69 -58
  60. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
  61. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +28 -27
  62. package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +1 -16
  63. package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -1
  64. package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +14 -101
@@ -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: inherit;
29
- rotate: calc(var(--sbb-reservation-area-rotation) * 1deg);
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+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBWU0saUNBQTZCLE1BQUE7OzBCQURsQyxjQUFjLDJCQUEyQixDQUFDOzs7O29CQUNDOzs7Ozs7O0FBQVIsRUFBQSxtQkFBUSxZQUFVO0FBQUE7O0FBTXBELHFEQUFBLGtCQUFBLE1BQUEsd0JBQ0UsTUFBTTtBQUtSLHdEQUFBLGtCQUFBLE1BQUEsMkJBQUEsR0FBQSxrQkFBQSxNQUFBLDBCQUErQyxPQUFPOzs7O0lBTnRELElBQWdCLFdBQVE7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXhCLElBQWdCLFNBQVEsT0FBQTtBQUFBLHlCQUFBLDRCQUFBO0FBQUEsSUFBQTtBQUFBO0FBQUEsSUFNeEIsSUFBZ0IsYUFBVTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBMUIsSUFBZ0IsV0FBVSxPQUFBO0FBQUEseUJBQUEsOEJBQUE7QUFBQSxJQUFBO0FBQUEsSUFFUCxTQUFNO0FBQ3ZCLGFBQU87QUFBQSxJQUNUO0FBQUEsS0FWQSw0Q0FNQTs7NEJBUkMsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQzs4QkFLM0IsYUFDQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUw1QixpQkFBQSxJQUFBLE1BQUEsc0JBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxZQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGNBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixVQUFRLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFSLFdBQVE7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsd0JBQUEsMkJBQUE7QUFNeEIsaUJBQUEsSUFBQSxNQUFBLHdCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsY0FBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxnQkFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLFlBQVUsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQVYsYUFBVTtBQUFBLElBQUEsS0FBQSxVQUFBLFVBQUEsR0FBQSwwQkFBQSw2QkFBQTtBQVo1QixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ3lCLEdBQUEsU0FBeUIsT0FENUMsa0JBQUEsWUFBQSx1QkFBQSxHQUE4Qjs7OyJ9
115
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS9zZWF0LXJlc2VydmF0aW9uLWFyZWEuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLWFyZWEuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBNb3VudGluZyBQcm9wICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBtb3VudGluZzogJ2ZyZWUnIHwgJ3VwcGVyLWJvcmRlcicgfCAnbG93ZXItYm9yZGVyJyB8ICd1cHBlci10by1sb3dlci1ib3JkZXInID1cbiAgICAnZnJlZSc7XG5cbiAgLyoqIHRoZSBiYWNrZ3JvdW5kIG9mIHRoZSBhcmVhICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kOiAnbGlnaHQnIHwgJ2RhcmsnID0gJ2xpZ2h0JztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGA8c2xvdD48L3Nsb3Q+YDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYSc6IFNiYlNlYXRSZXNlcnZhdGlvbkFyZWFFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQVlNLGlDQUE2QixNQUFBOzswQkFEbEMsY0FBYywyQkFBMkIsQ0FBQzs7OztvQkFDQzs7Ozs7OztBQUFSLEVBQUEsbUJBQVEsWUFBVTtBQUFBOztBQU1wRCxxREFBQSxrQkFBQSxNQUFBLHdCQUNFLE1BQU07QUFLUix3REFBQSxrQkFBQSxNQUFBLDJCQUFBLEdBQUEsa0JBQUEsTUFBQSwwQkFBK0MsT0FBTzs7OztJQU50RCxJQUFnQixXQUFRO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUF4QixJQUFnQixTQUFRLE9BQUE7QUFBQSx5QkFBQSw0QkFBQTtBQUFBLElBQUE7QUFBQTtBQUFBLElBTXhCLElBQWdCLGFBQVU7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQTFCLElBQWdCLFdBQVUsT0FBQTtBQUFBLHlCQUFBLDhCQUFBO0FBQUEsSUFBQTtBQUFBLElBRVAsU0FBTTtBQUN2QixhQUFPO0FBQUEsSUFDVDtBQUFBLEtBVkEsNENBTUE7OzRCQVJDLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7OEJBSzNCLGFBQ0EsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFMNUIsaUJBQUEsSUFBQSxNQUFBLHNCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsWUFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxjQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsVUFBUSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBUixXQUFRO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLHdCQUFBLDJCQUFBO0FBTXhCLGlCQUFBLElBQUEsTUFBQSx3QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGNBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsZ0JBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixZQUFVLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFWLGFBQVU7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsMEJBQUEsNkJBQUE7QUFaNUIsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLE9BRDVDLGtCQUFBLFlBQUEsdUJBQUEsR0FBOEI7OzsifQ==
@@ -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;AAmSF,eAAO,MAAM,cAAc,EAAE,cAgB5B,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":";;;;;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,gBAS/B,mBAAmB,OAAO,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASpC,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;"}
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":"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"}
@@ -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
- --sbb-icon-svg-width: calc(var(--sbb-reservation-graphic-width) * 0.0625rem);
32
- --sbb-icon-svg-height: calc(var(--sbb-reservation-graphic-height) * 0.0625rem);
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;AAIrD,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,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;IA4B1C,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"}
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, _travelClass_accessor_storage, (__runInitializers(this, _index_extraInitializers), __runInitializers(this, _travelClass_initializers, ["ANY_CLASS"])));
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":"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"}
@@ -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;CA0BrB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,oCAAoC,EAAE,qCAAqC,CAAC;KAC7E;CACF"}
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"}