@sbb-esta/lyne-elements-experimental-dev 4.6.0-dev.1772444909 → 4.6.0-dev.1772446531

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 (57) hide show
  1. package/custom-elements.json +404 -209
  2. package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  3. package/development/seat-reservation/common/mapper/icon-mapper.js +2 -1
  4. package/development/seat-reservation/common/mapper/mapper.js +6 -4
  5. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.d.ts +69 -0
  6. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.d.ts.map +1 -0
  7. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.js +559 -0
  8. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.d.ts +123 -0
  9. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.d.ts.map +1 -0
  10. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.js +972 -0
  11. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.d.ts +114 -0
  12. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.d.ts.map +1 -0
  13. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.js +20368 -0
  14. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.d.ts +85 -0
  15. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.d.ts.map +1 -0
  16. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.js +1739 -0
  17. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.d.ts +69 -0
  18. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.d.ts.map +1 -0
  19. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.js +9783 -0
  20. package/development/seat-reservation/common/svgs.js +7 -7
  21. package/development/seat-reservation/common/translations/i18n.d.ts.map +1 -1
  22. package/development/seat-reservation/common/translations/i18n.js +32 -1
  23. package/development/seat-reservation/common/types.d.ts +8 -3
  24. package/development/seat-reservation/common/types.d.ts.map +1 -1
  25. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +13 -3
  26. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  27. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +68 -15
  28. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +1 -0
  29. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  30. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +64 -29
  31. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +4 -15
  32. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  33. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +75 -155
  34. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +2 -0
  35. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -1
  36. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +21 -5
  37. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +7 -1
  38. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
  39. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +154 -9
  40. package/package.json +2 -2
  41. package/seat-reservation/common/mapper/icon-mapper.js +1 -0
  42. package/seat-reservation/common/mapper/mapper.js +25 -23
  43. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.js +558 -0
  44. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.js +970 -0
  45. package/seat-reservation/common/mapper/{seat-reservation-sample-data.js → sample-data/seat-reservation-sample-data-giruno.js} +3 -11304
  46. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.js +1738 -0
  47. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.js +9782 -0
  48. package/seat-reservation/common/svgs.js +51 -51
  49. package/seat-reservation/common/translations/i18n.js +31 -0
  50. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +128 -88
  51. package/seat-reservation/seat-reservation/seat-reservation.component.js +137 -125
  52. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +141 -186
  53. package/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +54 -44
  54. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +106 -71
  55. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts +0 -372
  56. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.d.ts.map +0 -1
  57. package/development/seat-reservation/common/mapper/seat-reservation-sample-data.js +0 -31673
@@ -36,7 +36,7 @@ const style = css`.sbb-sr-navigation__signs {
36
36
  height: 100%;
37
37
  }`;
38
38
  let SbbSeatReservationNavigationServicesElement = (() => {
39
- var _propertyIds_accessor_storage, _vertical_accessor_storage, _a;
39
+ var _propertyIds_accessor_storage, _vertical_accessor_storage, _showTitleInfo_accessor_storage, _a;
40
40
  let _classDecorators = [customElement("sbb-seat-reservation-navigation-services")];
41
41
  let _classDescriptor;
42
42
  let _classExtraInitializers = [];
@@ -48,14 +48,19 @@ let SbbSeatReservationNavigationServicesElement = (() => {
48
48
  let _vertical_decorators;
49
49
  let _vertical_initializers = [];
50
50
  let _vertical_extraInitializers = [];
51
+ let _showTitleInfo_decorators;
52
+ let _showTitleInfo_initializers = [];
53
+ let _showTitleInfo_extraInitializers = [];
51
54
  _a = class extends _classSuper {
52
55
  constructor() {
53
56
  super(...arguments);
54
57
  __privateAdd(this, _propertyIds_accessor_storage);
55
58
  __privateAdd(this, _vertical_accessor_storage);
59
+ __privateAdd(this, _showTitleInfo_accessor_storage);
56
60
  __privateSet(this, _propertyIds_accessor_storage, __runInitializers(this, _propertyIds_initializers, []));
57
61
  __privateSet(this, _vertical_accessor_storage, (__runInitializers(this, _propertyIds_extraInitializers), __runInitializers(this, _vertical_initializers, false)));
58
- this._language = (__runInitializers(this, _vertical_extraInitializers), new SbbLanguageController(this));
62
+ __privateSet(this, _showTitleInfo_accessor_storage, (__runInitializers(this, _vertical_extraInitializers), __runInitializers(this, _showTitleInfo_initializers, false)));
63
+ this._language = (__runInitializers(this, _showTitleInfo_extraInitializers), new SbbLanguageController(this));
59
64
  }
60
65
  /** Coach service property ids, which are used to display the services in the navigation */
61
66
  get propertyIds() {
@@ -71,6 +76,13 @@ let SbbSeatReservationNavigationServicesElement = (() => {
71
76
  set vertical(value) {
72
77
  __privateSet(this, _vertical_accessor_storage, value);
73
78
  }
79
+ /** Disable the mouse over title information */
80
+ get showTitleInfo() {
81
+ return __privateGet(this, _showTitleInfo_accessor_storage);
82
+ }
83
+ set showTitleInfo(value) {
84
+ __privateSet(this, _showTitleInfo_accessor_storage, value);
85
+ }
74
86
  render() {
75
87
  const serviceLabelDescription = this.propertyIds?.length ? this._getServiceLabelDescription() : null;
76
88
  return html` <div class="sbb-sr-navigation__signs">
@@ -82,7 +94,7 @@ let SbbSeatReservationNavigationServicesElement = (() => {
82
94
  <sbb-seat-reservation-graphic
83
95
  class="auto-width"
84
96
  name=${signIcon ?? nothing}
85
- title=${getI18nSeatReservation(signIcon, this._language.current)}
97
+ title=${this.showTitleInfo ? getI18nSeatReservation(signIcon, this._language.current) : nothing}
86
98
  aria-hidden="true"
87
99
  ></sbb-seat-reservation-graphic>
88
100
  `;
@@ -98,16 +110,20 @@ let SbbSeatReservationNavigationServicesElement = (() => {
98
110
  }
99
111
  return label;
100
112
  }
101
- }, _propertyIds_accessor_storage = new WeakMap(), _vertical_accessor_storage = new WeakMap(), _classThis = _a, (() => {
113
+ }, _propertyIds_accessor_storage = new WeakMap(), _vertical_accessor_storage = new WeakMap(), _showTitleInfo_accessor_storage = new WeakMap(), _classThis = _a, (() => {
102
114
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
103
115
  _propertyIds_decorators = [property({ attribute: "property-ids", type: Array })];
104
116
  _vertical_decorators = [forceType(), property({ type: Boolean, reflect: true, useDefault: true })];
117
+ _showTitleInfo_decorators = [forceType(), property({ type: Boolean })];
105
118
  __esDecorate(_a, null, _propertyIds_decorators, { kind: "accessor", name: "propertyIds", static: false, private: false, access: { has: (obj) => "propertyIds" in obj, get: (obj) => obj.propertyIds, set: (obj, value) => {
106
119
  obj.propertyIds = value;
107
120
  } }, metadata: _metadata }, _propertyIds_initializers, _propertyIds_extraInitializers);
108
121
  __esDecorate(_a, null, _vertical_decorators, { kind: "accessor", name: "vertical", static: false, private: false, access: { has: (obj) => "vertical" in obj, get: (obj) => obj.vertical, set: (obj, value) => {
109
122
  obj.vertical = value;
110
123
  } }, metadata: _metadata }, _vertical_initializers, _vertical_extraInitializers);
124
+ __esDecorate(_a, null, _showTitleInfo_decorators, { kind: "accessor", name: "showTitleInfo", static: false, private: false, access: { has: (obj) => "showTitleInfo" in obj, get: (obj) => obj.showTitleInfo, set: (obj, value) => {
125
+ obj.showTitleInfo = value;
126
+ } }, metadata: _metadata }, _showTitleInfo_initializers, _showTitleInfo_extraInitializers);
111
127
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
112
128
  _classThis = _classDescriptor.value;
113
129
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
@@ -117,4 +133,4 @@ let SbbSeatReservationNavigationServicesElement = (() => {
117
133
  export {
118
134
  SbbSeatReservationNavigationServicesElement
119
135
  };
120
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tbmF2aWdhdGlvbi1zZXJ2aWNlcy9zZWF0LXJlc2VydmF0aW9uLW5hdmlnYXRpb24tc2VydmljZXMuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNiYkxhbmd1YWdlQ29udHJvbGxlciB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvY29udHJvbGxlcnMuanMnO1xuaW1wb3J0IHsgZm9yY2VUeXBlIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvc3R5bGVzLmpzJztcbmltcG9ydCB7IHR5cGUgQ1NTUmVzdWx0R3JvdXAsIG5vdGhpbmcsIHR5cGUgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgZ2V0STE4blNlYXRSZXNlcnZhdGlvbiB9IGZyb20gJy4uL2NvbW1vbi50cyc7XG5cbmltcG9ydCAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvc2NyZWVuLXJlYWRlci1vbmx5LmpzJztcbmltcG9ydCAnLi4vc2VhdC1yZXNlcnZhdGlvbi1ncmFwaGljLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vc2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogQ29tcG9uZW50IGRpc3BsYXlzIHRoZSBhdmFpbGFibGUgc2VydmljZSBpY29ucyBvZiBvbmUgY29hY2guXG4gKlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbk5hdmlnYXRpb25TZXJ2aWNlc0VsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gIC8qKiBDb2FjaCBzZXJ2aWNlIHByb3BlcnR5IGlkcywgd2hpY2ggYXJlIHVzZWQgdG8gZGlzcGxheSB0aGUgc2VydmljZXMgaW4gdGhlIG5hdmlnYXRpb24gKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAncHJvcGVydHktaWRzJywgdHlwZTogQXJyYXkgfSlcbiAgcHVibGljIGFjY2Vzc29yIHByb3BlcnR5SWRzOiBzdHJpbmdbXSA9IFtdO1xuXG4gIC8qKiBJZiB0cnVlLCB0aGUgc2VydmljZSBpY29ucyBhcmUgZGlzcGxheWVkIHZlcnRpY2FsbHkgKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUsIHVzZURlZmF1bHQ6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIHZlcnRpY2FsOiBib29sZWFuID0gZmFsc2U7XG5cbiAgcHJpdmF0ZSBfbGFuZ3VhZ2UgPSBuZXcgU2JiTGFuZ3VhZ2VDb250cm9sbGVyKHRoaXMpO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIGNvbnN0IHNlcnZpY2VMYWJlbERlc2NyaXB0aW9uID0gdGhpcy5wcm9wZXJ0eUlkcz8ubGVuZ3RoXG4gICAgICA/IHRoaXMuX2dldFNlcnZpY2VMYWJlbERlc2NyaXB0aW9uKClcbiAgICAgIDogbnVsbDtcbiAgICByZXR1cm4gaHRtbGAgPGRpdiBjbGFzcz1cInNiYi1zci1uYXZpZ2F0aW9uX19zaWduc1wiPlxuICAgICAgPHNiYi1zY3JlZW4tcmVhZGVyLW9ubHkgJHtzZXJ2aWNlTGFiZWxEZXNjcmlwdGlvbiA/IHNlcnZpY2VMYWJlbERlc2NyaXB0aW9uIDogbm90aGluZ31cbiAgICAgICAgPiR7c2VydmljZUxhYmVsRGVzY3JpcHRpb259PC9zYmItc2NyZWVuLXJlYWRlci1vbmx5XG4gICAgICA+XG4gICAgICAke3RoaXMucHJvcGVydHlJZHM/Lm1hcCgoc2lnbkljb246IHN0cmluZykgPT4ge1xuICAgICAgICByZXR1cm4gaHRtbGBcbiAgICAgICAgICA8c2JiLXNlYXQtcmVzZXJ2YXRpb24tZ3JhcGhpY1xuICAgICAgICAgICAgY2xhc3M9XCJhdXRvLXdpZHRoXCJcbiAgICAgICAgICAgIG5hbWU9JHtzaWduSWNvbiA/PyBub3RoaW5nfVxuICAgICAgICAgICAgdGl0bGU9JHtnZXRJMThuU2VhdFJlc2VydmF0aW9uKHNpZ25JY29uLCB0aGlzLl9sYW5ndWFnZS5jdXJyZW50KX1cbiAgICAgICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgICAgPjwvc2JiLXNlYXQtcmVzZXJ2YXRpb24tZ3JhcGhpYz5cbiAgICAgICAgYDtcbiAgICAgIH0pfVxuICAgIDwvZGl2PmA7XG4gIH1cblxuICAvL0dlbmVyYXRlIHRoZSB0cmFuc2xhdGVkIHNlcnZpY2UgbGFiZWwgZnJvbSB0aGUgYXZhaWxhYmxlIHByb3BlcnRpZXNcbiAgcHJpdmF0ZSBfZ2V0U2VydmljZUxhYmVsRGVzY3JpcHRpb24oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgbGV0IGxhYmVsID0gbnVsbDtcbiAgICBjb25zdCB0cmFuc2xhdGVkU2VydmljZUxhYmVscyA9IHRoaXMucHJvcGVydHlJZHNcbiAgICAgIC5tYXAoKHByb3ApID0+IGdldEkxOG5TZWF0UmVzZXJ2YXRpb24ocHJvcCwgdGhpcy5fbGFuZ3VhZ2UuY3VycmVudCkpXG4gICAgICAuZmlsdGVyKChwcm9wVHJhbnNsYXRpb24pID0+ICEhcHJvcFRyYW5zbGF0aW9uKVxuICAgICAgLmpvaW4oJywgJyk7XG5cbiAgICBpZiAodHJhbnNsYXRlZFNlcnZpY2VMYWJlbHMpIHtcbiAgICAgIGxhYmVsID0gZ2V0STE4blNlYXRSZXNlcnZhdGlvbignQ09BQ0hfQVZBSUxBQkxFX1NFUlZJQ0VTJywgdGhpcy5fbGFuZ3VhZ2UuY3VycmVudClcbiAgICAgICAgLmNvbmNhdCgnOicpXG4gICAgICAgIC5jb25jYXQodHJhbnNsYXRlZFNlcnZpY2VMYWJlbHMpO1xuICAgIH1cbiAgICByZXR1cm4gbGFiZWw7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1zZWF0LXJlc2VydmF0aW9uLW5hdmlnYXRpb24tc2VydmljZXMnOiBTYmJTZWF0UmVzZXJ2YXRpb25OYXZpZ2F0aW9uU2VydmljZXNFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQW9CTSwrQ0FBMkMsTUFBQTs7MEJBRGhELGNBQWMsMENBQTBDLENBQUM7Ozs7b0JBQ0E7Ozs7Ozs7QUFBUixFQUFBLG1CQUFRLFlBQVU7QUFBQTs7QUFLbEU7QUFLQTtBQUxnQix5QkFBQSwrQkFBQSxrQkFBQSxNQUFBLDJCQUF3QixDQUFBLENBQUU7QUFLMUIseUJBQUEsNkJBQUEsa0JBQUEsTUFBQSw4QkFBQSxHQUFBLGtCQUFBLE1BQUEsd0JBQW9CLEtBQUs7QUFFakMsV0FBQSxtRUFBWSxJQUFJLHNCQUFzQixJQUFJO0FBQUEsSUFzQ3BEO0FBQUE7QUFBQSxJQTdDRSxJQUFnQixjQUFXO0FBQUEsYUFB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
136
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9zZWF0LXJlc2VydmF0aW9uL3NlYXQtcmVzZXJ2YXRpb24tbmF2aWdhdGlvbi1zZXJ2aWNlcy9zZWF0LXJlc2VydmF0aW9uLW5hdmlnYXRpb24tc2VydmljZXMuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNiYkxhbmd1YWdlQ29udHJvbGxlciB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvY29udHJvbGxlcnMuanMnO1xuaW1wb3J0IHsgZm9yY2VUeXBlIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvc3R5bGVzLmpzJztcbmltcG9ydCB7IHR5cGUgQ1NTUmVzdWx0R3JvdXAsIG5vdGhpbmcsIHR5cGUgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgZ2V0STE4blNlYXRSZXNlcnZhdGlvbiB9IGZyb20gJy4uL2NvbW1vbi50cyc7XG5cbmltcG9ydCAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvc2NyZWVuLXJlYWRlci1vbmx5LmpzJztcbmltcG9ydCAnLi4vc2VhdC1yZXNlcnZhdGlvbi1ncmFwaGljLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vc2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogQ29tcG9uZW50IGRpc3BsYXlzIHRoZSBhdmFpbGFibGUgc2VydmljZSBpY29ucyBvZiBvbmUgY29hY2guXG4gKlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItc2VhdC1yZXNlcnZhdGlvbi1uYXZpZ2F0aW9uLXNlcnZpY2VzJylcbmNsYXNzIFNiYlNlYXRSZXNlcnZhdGlvbk5hdmlnYXRpb25TZXJ2aWNlc0VsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gIC8qKiBDb2FjaCBzZXJ2aWNlIHByb3BlcnR5IGlkcywgd2hpY2ggYXJlIHVzZWQgdG8gZGlzcGxheSB0aGUgc2VydmljZXMgaW4gdGhlIG5hdmlnYXRpb24gKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAncHJvcGVydHktaWRzJywgdHlwZTogQXJyYXkgfSlcbiAgcHVibGljIGFjY2Vzc29yIHByb3BlcnR5SWRzOiBzdHJpbmdbXSA9IFtdO1xuXG4gIC8qKiBJZiB0cnVlLCB0aGUgc2VydmljZSBpY29ucyBhcmUgZGlzcGxheWVkIHZlcnRpY2FsbHkgKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUsIHVzZURlZmF1bHQ6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIHZlcnRpY2FsOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIERpc2FibGUgdGhlIG1vdXNlIG92ZXIgdGl0bGUgaW5mb3JtYXRpb24gKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4gfSlcbiAgcHVibGljIGFjY2Vzc29yIHNob3dUaXRsZUluZm86IGJvb2xlYW4gPSBmYWxzZTtcblxuICBwcml2YXRlIF9sYW5ndWFnZSA9IG5ldyBTYmJMYW5ndWFnZUNvbnRyb2xsZXIodGhpcyk7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgY29uc3Qgc2VydmljZUxhYmVsRGVzY3JpcHRpb24gPSB0aGlzLnByb3BlcnR5SWRzPy5sZW5ndGhcbiAgICAgID8gdGhpcy5fZ2V0U2VydmljZUxhYmVsRGVzY3JpcHRpb24oKVxuICAgICAgOiBudWxsO1xuICAgIHJldHVybiBodG1sYCA8ZGl2IGNsYXNzPVwic2JiLXNyLW5hdmlnYXRpb25fX3NpZ25zXCI+XG4gICAgICA8c2JiLXNjcmVlbi1yZWFkZXItb25seSAke3NlcnZpY2VMYWJlbERlc2NyaXB0aW9uID8gc2VydmljZUxhYmVsRGVzY3JpcHRpb24gOiBub3RoaW5nfVxuICAgICAgICA+JHtzZXJ2aWNlTGFiZWxEZXNjcmlwdGlvbn08L3NiYi1zY3JlZW4tcmVhZGVyLW9ubHlcbiAgICAgID5cbiAgICAgICR7dGhpcy5wcm9wZXJ0eUlkcz8ubWFwKChzaWduSWNvbjogc3RyaW5nKSA9PiB7XG4gICAgICAgIHJldHVybiBodG1sYFxuICAgICAgICAgIDxzYmItc2VhdC1yZXNlcnZhdGlvbi1ncmFwaGljXG4gICAgICAgICAgICBjbGFzcz1cImF1dG8td2lkdGhcIlxuICAgICAgICAgICAgbmFtZT0ke3NpZ25JY29uID8/IG5vdGhpbmd9XG4gICAgICAgICAgICB0aXRsZT0ke3RoaXMuc2hvd1RpdGxlSW5mb1xuICAgICAgICAgICAgICA/IGdldEkxOG5TZWF0UmVzZXJ2YXRpb24oc2lnbkljb24sIHRoaXMuX2xhbmd1YWdlLmN1cnJlbnQpXG4gICAgICAgICAgICAgIDogbm90aGluZ31cbiAgICAgICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgICAgPjwvc2JiLXNlYXQtcmVzZXJ2YXRpb24tZ3JhcGhpYz5cbiAgICAgICAgYDtcbiAgICAgIH0pfVxuICAgIDwvZGl2PmA7XG4gIH1cblxuICAvL0dlbmVyYXRlIHRoZSB0cmFuc2xhdGVkIHNlcnZpY2UgbGFiZWwgZnJvbSB0aGUgYXZhaWxhYmxlIHByb3BlcnRpZXNcbiAgcHJpdmF0ZSBfZ2V0U2VydmljZUxhYmVsRGVzY3JpcHRpb24oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgbGV0IGxhYmVsID0gbnVsbDtcbiAgICBjb25zdCB0cmFuc2xhdGVkU2VydmljZUxhYmVscyA9IHRoaXMucHJvcGVydHlJZHNcbiAgICAgIC5tYXAoKHByb3ApID0+IGdldEkxOG5TZWF0UmVzZXJ2YXRpb24ocHJvcCwgdGhpcy5fbGFuZ3VhZ2UuY3VycmVudCkpXG4gICAgICAuZmlsdGVyKChwcm9wVHJhbnNsYXRpb24pID0+ICEhcHJvcFRyYW5zbGF0aW9uKVxuICAgICAgLmpvaW4oJywgJyk7XG5cbiAgICBpZiAodHJhbnNsYXRlZFNlcnZpY2VMYWJlbHMpIHtcbiAgICAgIGxhYmVsID0gZ2V0STE4blNlYXRSZXNlcnZhdGlvbignQ09BQ0hfQVZBSUxBQkxFX1NFUlZJQ0VTJywgdGhpcy5fbGFuZ3VhZ2UuY3VycmVudClcbiAgICAgICAgLmNvbmNhdCgnOicpXG4gICAgICAgIC5jb25jYXQodHJhbnNsYXRlZFNlcnZpY2VMYWJlbHMpO1xuICAgIH1cbiAgICByZXR1cm4gbGFiZWw7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1zZWF0LXJlc2VydmF0aW9uLW5hdmlnYXRpb24tc2VydmljZXMnOiBTYmJTZWF0UmVzZXJ2YXRpb25OYXZpZ2F0aW9uU2VydmljZXNFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQW9CTSwrQ0FBMkMsTUFBQTs7MEJBRGhELGNBQWMsMENBQTBDLENBQUM7Ozs7b0JBQ0E7Ozs7Ozs7Ozs7QUFBUixFQUFBLG1CQUFRLFlBQVU7QUFBQTs7QUFLbEU7QUFLQTtBQUtBO0FBVmdCLHlCQUFBLCtCQUFBLGtCQUFBLE1BQUEsMkJBQXdCLENBQUEsQ0FBRTtBQUsxQix5QkFBQSw2QkFBQSxrQkFBQSxNQUFBLDhCQUFBLEdBQUEsa0JBQUEsTUFBQSx3QkFBb0IsS0FBSztBQUt6Qix5QkFBQSxrQ0FBQSxrQkFBQSxNQUFBLDJCQUFBLEdBQUEsa0JBQUEsTUFBQSw2QkFBeUIsS0FBSztBQUV0QyxXQUFBLHdFQUFZLElBQUksc0JBQXNCLElBQUk7QUFBQSxJQXdDcEQ7QUFBQTtBQUFBLElBcERFLElBQWdCLGNBQVc7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQTNCLElBQWdCLFlBQVcsT0FBQTtBQUFBLHlCQUFBLCtCQUFBO0FBQUEsSUFBQTtBQUFBO0FBQUEsSUFLM0IsSUFBZ0IsV0FBUTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBeEIsSUFBZ0IsU0FBUSxPQUFBO0FBQUEseUJBQUEsNEJBQUE7QUFBQSxJQUFBO0FBQUE7QUFBQSxJQUt4QixJQUFnQixnQkFBYTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBN0IsSUFBZ0IsY0FBYSxPQUFBO0FBQUEseUJBQUEsaUNBQUE7QUFBQSxJQUFBO0FBQUEsSUFJVixTQUFNO0FBQ3ZCLFlBQU0sMEJBQTBCLEtBQUssYUFBYSxTQUM5QyxLQUFLLGdDQUNMO0FBQ0osYUFBTztBQUFBLGdDQUNxQiwwQkFBMEIsMEJBQTBCLE9BQU87QUFBQSxXQUNoRix1QkFBdUI7QUFBQTtBQUFBLFFBRTFCLEtBQUssYUFBYSxJQUFJLENBQUMsYUFBb0I7QUFDM0MsZUFBTztBQUFBO0FBQUE7QUFBQSxtQkFHSSxZQUFZLE9BQU87QUFBQSxvQkFDbEIsS0FBSyxnQkFDVCx1QkFBdUIsVUFBVSxLQUFLLFVBQVUsT0FBTyxJQUN2RCxPQUFPO0FBQUE7QUFBQTtBQUFBO0FBQUEsTUFJakIsQ0FBQyxDQUFDO0FBQUE7QUFBQSxJQUVOO0FBQUE7QUFBQSxJQUdRLDhCQUEyQjtBQUNqQyxVQUFJLFFBQVE7QUFDWixZQUFNLDBCQUEwQixLQUFLLFlBQ2xDLElBQUksQ0FBQyxTQUFTLHVCQUF1QixNQUFNLEtBQUssVUFBVSxPQUFPLENBQUMsRUFDbEUsT0FBTyxDQUFDLG9CQUFvQixDQUFDLENBQUMsZUFBZSxFQUM3QyxLQUFLLElBQUk7QUFFWixVQUFJLHlCQUF5QjtBQUMzQixnQkFBUSx1QkFBdUIsNEJBQTRCLEtBQUssVUFBVSxPQUFPLEVBQzlFLE9BQU8sR0FBRyxFQUNWLE9BQU8sdUJBQXVCO0FBQUEsTUFDbkM7QUFDQSxhQUFPO0FBQUEsSUFDVDtBQUFBLEtBbkRBLCtDQUtBLDRDQUtBOzsrQkFYQyxTQUFTLEVBQUUsV0FBVyxnQkFBZ0IsTUFBTSxNQUFBLENBQU8sQ0FBQztBQUlwRCwyQkFBQSxDQUFBLGFBQ0EsU0FBUyxFQUFFLE1BQU0sU0FBUyxTQUFTLE1BQU0sWUFBWSxLQUFBLENBQU0sQ0FBQztpQ0FJNUQsYUFDQSxTQUFTLEVBQUUsTUFBTSxRQUFBLENBQVMsQ0FBQztBQVQ1QixpQkFBQSxJQUFBLE1BQUEseUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxlQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGlCQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsYUFBVyxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBWCxjQUFXO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLDJCQUFBLDhCQUFBO0FBSzNCLGlCQUFBLElBQUEsTUFBQSxzQkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLFlBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsY0FBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLFVBQVEsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQVIsV0FBUTtBQUFBLElBQUEsS0FBQSxVQUFBLFVBQUEsR0FBQSx3QkFBQSwyQkFBQTtBQUt4QixpQkFBQSxJQUFBLE1BQUEsMkJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxpQkFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxtQkFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLGVBQWEsS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQWIsZ0JBQWE7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsNkJBQUEsZ0NBQUE7QUFmL0IsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLENBQUMsaUJBQWlCLEtBQUssR0FEbkUsa0JBQUEsWUFBQSx1QkFBQSxHQUE0Qzs7OyJ9
@@ -1,6 +1,6 @@
1
1
  import { SbbButtonBaseElement } from '@sbb-esta/lyne-elements/core/base-elements.js';
2
2
  import { CSSResultGroup, TemplateResult, PropertyValues } from 'lit';
3
- import { PlaceState, PlaceType } from '../common.ts';
3
+ import { PlaceState, PlaceType, TravelDirection } from '../common.ts';
4
4
  /**
5
5
  * Output the graphic of a seat or a bicycle place as a control element.
6
6
  */
@@ -13,6 +13,8 @@ export declare class SbbSeatReservationPlaceControlElement extends SbbButtonBase
13
13
  accessor placeType: PlaceType;
14
14
  /** state of the place, e.g. 'FREE', 'SELECTED', 'BLOCKED' */
15
15
  accessor state: PlaceState;
16
+ /** direction of a whole train, used to compute an orientation of a place */
17
+ accessor travelDirection: TravelDirection;
16
18
  /** property ids of the place, to display more info about the place */
17
19
  accessor propertyIds: string[];
18
20
  /** label of the place, e.g. '1A', '2B' */
@@ -25,12 +27,16 @@ export declare class SbbSeatReservationPlaceControlElement extends SbbButtonBase
25
27
  accessor preventClick: boolean;
26
28
  /** Set the place focus outline style */
27
29
  accessor keyfocus: string;
30
+ /** Disable the mouse over title information */
31
+ accessor showTitleInfo: boolean;
32
+ private _optionalScreenreaderInfo;
28
33
  private _language;
29
34
  constructor();
30
35
  protected willUpdate(changedProperties: PropertyValues<this>): void;
31
36
  protected render(): TemplateResult;
32
37
  private _getPlaceSvg;
33
38
  private _getTitleDescriptionPlace;
39
+ private _getRelativeTravelDirection;
34
40
  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */
35
41
  private _selectPlace;
36
42
  }
@@ -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;AAIrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKnG,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,CAA4B;IACzE,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,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,4DAA4D;IAC5D,SAEgB,SAAS,EAAE,MAAM,CAAS;IAE1C,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;cAUzD,MAAM,IAAI,cAAc;IAuC3C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,yBAAyB;IAkBjC,yGAAyG;IACzG,OAAO,CAAC,YAAY;CA4BrB;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;AAIrF,OAAO,EAAE,KAAK,cAAc,EAAiB,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKnG,OAAO,KAAK,EAAkB,UAAU,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE3F,OAAO,gCAAgC,CAAC;AASxC;;GAEG;AACH,qBAEM,qCAAsC,SAAQ,oBAAoB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;MAElB;IAEX,qDAAqD;IACrD,SAEgB,SAAS,EAAE,SAAS,CAAU;IAE9C,6DAA6D;IAC7D,SAEgB,KAAK,EAAE,UAAU,CAAU;IAE3C,4EAA4E;IAC5E,SACgB,eAAe,EAAE,eAAe,CAAU;IAE1D,sEAAsE;IACtE,SACgB,WAAW,EAAE,MAAM,EAAE,CAAM;IAE3C,0CAA0C;IAC1C,SAEgB,IAAI,EAAE,MAAM,CAAM;IAElC,4DAA4D;IAC5D,SAEgB,SAAS,EAAE,MAAM,CAAS;IAE1C,8DAA8D;IAC9D,SAEgB,UAAU,EAAE,MAAM,CAAS;IAE3C,kDAAkD;IAClD,SAEgB,YAAY,EAAE,OAAO,CAAS;IAE9C,wCAAwC;IACxC,SAEgB,QAAQ,EAAE,MAAM,CAAa;IAE7C,+CAA+C;IAC/C,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,OAAO,CAAC,yBAAyB,CAAc;IAE/C,OAAO,CAAC,SAAS,CAAmC;;cAOjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAmBzD,MAAM,IAAI,cAAc;IAmD3C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,yBAAyB;IAqBjC,OAAO,CAAC,2BAA2B;IA6BnC,yGAAyG;IACzG,OAAO,CAAC,YAAY;CA4BrB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,oCAAoC,EAAE,qCAAqC,CAAC;KAC7E;CACF"}
@@ -85,6 +85,14 @@ const style = css`:host {
85
85
  var(--sbb-color-milk),
86
86
  var(--sbb-color-midnight)
87
87
  );
88
+ --sbb-seat-reservation-place-control-free-backrest-high-contrast: CanvasText;
89
+ --sbb-seat-reservation-place-control-free-background-high-contrast: Canvas;
90
+ --sbb-seat-reservation-place-control-free-text-high-contrast: ButtonText;
91
+ --sbb-seat-reservation-place-control-free-icon-high-contrast: CanvasText;
92
+ --sbb-seat-reservation-place-control-allocated-backrest-high-contrast: GrayText;
93
+ --sbb-seat-reservation-place-control-allocated-background-high-contrast: Canvas;
94
+ --sbb-seat-reservation-place-control-allocated-text-high-contrast: GrayText;
95
+ --sbb-seat-reservation-place-control-allocated-icon-high-contrast: GrayText;
88
96
  width: calc(var(--sbb-seat-reservation-place-control-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
89
97
  height: calc(var(--sbb-seat-reservation-place-control-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
90
98
  position: absolute;
@@ -104,6 +112,25 @@ const style = css`:host {
104
112
  background-color: var(--sbb-seat-reservation-place-control-free-background-hover);
105
113
  color: var(--sbb-seat-reservation-place-control-free-text);
106
114
  }
115
+ @media (forced-colors: active) {
116
+ :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
117
+ fill: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
118
+ }
119
+ :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
120
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
121
+ }
122
+ :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-icon) {
123
+ fill: var(--sbb-seat-reservation-place-control-free-icon-high-contrast);
124
+ }
125
+ :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-seatline) {
126
+ stroke: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
127
+ }
128
+ :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
129
+ forced-color-adjust: none;
130
+ background-color: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
131
+ color: var(--sbb-seat-reservation-place-control-free-text-high-contrast);
132
+ }
133
+ }
107
134
  :host(:hover) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
108
135
  fill: var(--sbb-seat-reservation-place-control-selected-background-hover);
109
136
  }
@@ -125,6 +152,25 @@ const style = css`:host {
125
152
  background-color: var(--sbb-seat-reservation-place-control-free-background-focus);
126
153
  color: var(--sbb-seat-reservation-place-control-free-text);
127
154
  }
155
+ @media (forced-colors: active) {
156
+ :host(:focus-visible) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
157
+ fill: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
158
+ }
159
+ :host(:focus-visible) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
160
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
161
+ }
162
+ :host(:focus-visible) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-icon) {
163
+ fill: var(--sbb-seat-reservation-place-control-free-icon-high-contrast);
164
+ }
165
+ :host(:focus-visible) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-seatline) {
166
+ stroke: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
167
+ }
168
+ :host(:focus-visible) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
169
+ forced-color-adjust: none;
170
+ background-color: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
171
+ color: var(--sbb-seat-reservation-place-control-free-text-high-contrast);
172
+ }
173
+ }
128
174
 
129
175
  :host(:active) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
130
176
  fill: var(--sbb-seat-reservation-place-control-selected-background-focus);
@@ -159,6 +205,25 @@ const style = css`:host {
159
205
  background-color: var(--sbb-seat-reservation-place-control-free-background-default);
160
206
  color: var(--sbb-seat-reservation-place-control-free-text);
161
207
  }
208
+ @media (forced-colors: active) {
209
+ .sbb-sr-place-ctrl--state-free ::part(svg-place) {
210
+ fill: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
211
+ }
212
+ .sbb-sr-place-ctrl--state-free ::part(svg-backrest) {
213
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
214
+ }
215
+ .sbb-sr-place-ctrl--state-free ::part(svg-icon) {
216
+ fill: var(--sbb-seat-reservation-place-control-free-icon-high-contrast);
217
+ }
218
+ .sbb-sr-place-ctrl--state-free ::part(svg-seatline) {
219
+ stroke: var(--sbb-seat-reservation-place-control-free-backrest-high-contrast);
220
+ }
221
+ .sbb-sr-place-ctrl--state-free .sbb-sr-place-ctrl__text {
222
+ forced-color-adjust: none;
223
+ background-color: var(--sbb-seat-reservation-place-control-free-background-high-contrast);
224
+ color: var(--sbb-seat-reservation-place-control-free-text-high-contrast);
225
+ }
226
+ }
162
227
  .sbb-sr-place-ctrl--state-selected ::part(svg-place) {
163
228
  fill: var(--sbb-seat-reservation-place-control-selected-background-default);
164
229
  }
@@ -179,6 +244,25 @@ const style = css`:host {
179
244
  background-color: var(--sbb-seat-reservation-place-control-allocated-background-default);
180
245
  color: var(--sbb-seat-reservation-place-control-allocated-text);
181
246
  }
247
+ @media (forced-colors: active) {
248
+ .sbb-sr-place-ctrl--state-allocated ::part(svg-place), .sbb-sr-place-ctrl--state-restricted ::part(svg-place) {
249
+ fill: var(--sbb-seat-reservation-place-control-allocated-background-high-contrast);
250
+ }
251
+ .sbb-sr-place-ctrl--state-allocated ::part(svg-backrest), .sbb-sr-place-ctrl--state-restricted ::part(svg-backrest) {
252
+ fill: var(--sbb-seat-reservation-place-control-allocated-backrest-high-contrast);
253
+ }
254
+ .sbb-sr-place-ctrl--state-allocated ::part(svg-icon), .sbb-sr-place-ctrl--state-restricted ::part(svg-icon) {
255
+ fill: var(--sbb-seat-reservation-place-control-allocated-icon-high-contrast);
256
+ }
257
+ .sbb-sr-place-ctrl--state-allocated ::part(svg-seatline), .sbb-sr-place-ctrl--state-restricted ::part(svg-seatline) {
258
+ stroke: var(--sbb-seat-reservation-place-control-allocated-backrest-high-contrast);
259
+ }
260
+ .sbb-sr-place-ctrl--state-allocated .sbb-sr-place-ctrl__text, .sbb-sr-place-ctrl--state-restricted .sbb-sr-place-ctrl__text {
261
+ forced-color-adjust: none;
262
+ background-color: var(--sbb-seat-reservation-place-control-allocated-background-high-contrast);
263
+ color: var(--sbb-seat-reservation-place-control-allocated-text-high-contrast);
264
+ }
265
+ }
182
266
  .sbb-sr-place-ctrl--state-allocated, .sbb-sr-place-ctrl--state-restricted {
183
267
  cursor: not-allowed;
184
268
  }
@@ -230,7 +314,7 @@ const style = css`:host {
230
314
  inset-inline-start: -10%;
231
315
  }`;
232
316
  let SbbSeatReservationPlaceControlElement = (() => {
233
- var _placeType_accessor_storage, _state_accessor_storage, _propertyIds_accessor_storage, _text_accessor_storage, _deckIndex_accessor_storage, _coachIndex_accessor_storage, _preventClick_accessor_storage, _keyfocus_accessor_storage, _a;
317
+ var _placeType_accessor_storage, _state_accessor_storage, _travelDirection_accessor_storage, _propertyIds_accessor_storage, _text_accessor_storage, _deckIndex_accessor_storage, _coachIndex_accessor_storage, _preventClick_accessor_storage, _keyfocus_accessor_storage, _showTitleInfo_accessor_storage, _a;
234
318
  let _classDecorators = [customElement("sbb-seat-reservation-place-control")];
235
319
  let _classDescriptor;
236
320
  let _classExtraInitializers = [];
@@ -242,6 +326,9 @@ let SbbSeatReservationPlaceControlElement = (() => {
242
326
  let _state_decorators;
243
327
  let _state_initializers = [];
244
328
  let _state_extraInitializers = [];
329
+ let _travelDirection_decorators;
330
+ let _travelDirection_initializers = [];
331
+ let _travelDirection_extraInitializers = [];
245
332
  let _propertyIds_decorators;
246
333
  let _propertyIds_initializers = [];
247
334
  let _propertyIds_extraInitializers = [];
@@ -260,26 +347,34 @@ let SbbSeatReservationPlaceControlElement = (() => {
260
347
  let _keyfocus_decorators;
261
348
  let _keyfocus_initializers = [];
262
349
  let _keyfocus_extraInitializers = [];
350
+ let _showTitleInfo_decorators;
351
+ let _showTitleInfo_initializers = [];
352
+ let _showTitleInfo_extraInitializers = [];
263
353
  _a = class extends _classSuper {
264
354
  constructor() {
265
355
  super();
266
356
  __privateAdd(this, _placeType_accessor_storage);
267
357
  __privateAdd(this, _state_accessor_storage);
358
+ __privateAdd(this, _travelDirection_accessor_storage);
268
359
  __privateAdd(this, _propertyIds_accessor_storage);
269
360
  __privateAdd(this, _text_accessor_storage);
270
361
  __privateAdd(this, _deckIndex_accessor_storage);
271
362
  __privateAdd(this, _coachIndex_accessor_storage);
272
363
  __privateAdd(this, _preventClick_accessor_storage);
273
364
  __privateAdd(this, _keyfocus_accessor_storage);
365
+ __privateAdd(this, _showTitleInfo_accessor_storage);
274
366
  __privateSet(this, _placeType_accessor_storage, __runInitializers(this, _placeType_initializers, "SEAT"));
275
367
  __privateSet(this, _state_accessor_storage, (__runInitializers(this, _placeType_extraInitializers), __runInitializers(this, _state_initializers, "FREE")));
276
- __privateSet(this, _propertyIds_accessor_storage, (__runInitializers(this, _state_extraInitializers), __runInitializers(this, _propertyIds_initializers, [])));
368
+ __privateSet(this, _travelDirection_accessor_storage, (__runInitializers(this, _state_extraInitializers), __runInitializers(this, _travelDirection_initializers, "NONE")));
369
+ __privateSet(this, _propertyIds_accessor_storage, (__runInitializers(this, _travelDirection_extraInitializers), __runInitializers(this, _propertyIds_initializers, [])));
277
370
  __privateSet(this, _text_accessor_storage, (__runInitializers(this, _propertyIds_extraInitializers), __runInitializers(this, _text_initializers, "")));
278
371
  __privateSet(this, _deckIndex_accessor_storage, (__runInitializers(this, _text_extraInitializers), __runInitializers(this, _deckIndex_initializers, null)));
279
372
  __privateSet(this, _coachIndex_accessor_storage, (__runInitializers(this, _deckIndex_extraInitializers), __runInitializers(this, _coachIndex_initializers, null)));
280
373
  __privateSet(this, _preventClick_accessor_storage, (__runInitializers(this, _coachIndex_extraInitializers), __runInitializers(this, _preventClick_initializers, false)));
281
374
  __privateSet(this, _keyfocus_accessor_storage, (__runInitializers(this, _preventClick_extraInitializers), __runInitializers(this, _keyfocus_initializers, "unfocus")));
282
- this._language = (__runInitializers(this, _keyfocus_extraInitializers), new SbbLanguageController(this));
375
+ __privateSet(this, _showTitleInfo_accessor_storage, (__runInitializers(this, _keyfocus_extraInitializers), __runInitializers(this, _showTitleInfo_initializers, false)));
376
+ this._optionalScreenreaderInfo = (__runInitializers(this, _showTitleInfo_extraInitializers), "");
377
+ this._language = new SbbLanguageController(this);
283
378
  this.addEventListener("click", () => this._selectPlace());
284
379
  }
285
380
  /** placeType of the place, e.g. 'SEAT', 'BICYCLE' */
@@ -296,6 +391,13 @@ let SbbSeatReservationPlaceControlElement = (() => {
296
391
  set state(value) {
297
392
  __privateSet(this, _state_accessor_storage, value);
298
393
  }
394
+ /** direction of a whole train, used to compute an orientation of a place */
395
+ get travelDirection() {
396
+ return __privateGet(this, _travelDirection_accessor_storage);
397
+ }
398
+ set travelDirection(value) {
399
+ __privateSet(this, _travelDirection_accessor_storage, value);
400
+ }
299
401
  /** property ids of the place, to display more info about the place */
300
402
  get propertyIds() {
301
403
  return __privateGet(this, _propertyIds_accessor_storage);
@@ -338,6 +440,13 @@ let SbbSeatReservationPlaceControlElement = (() => {
338
440
  set keyfocus(value) {
339
441
  __privateSet(this, _keyfocus_accessor_storage, value);
340
442
  }
443
+ /** Disable the mouse over title information */
444
+ get showTitleInfo() {
445
+ return __privateGet(this, _showTitleInfo_accessor_storage);
446
+ }
447
+ set showTitleInfo(value) {
448
+ __privateSet(this, _showTitleInfo_accessor_storage, value);
449
+ }
341
450
  willUpdate(changedProperties) {
342
451
  super.willUpdate(changedProperties);
343
452
  if (changedProperties.has("keyfocus")) {
@@ -345,6 +454,11 @@ let SbbSeatReservationPlaceControlElement = (() => {
345
454
  this.focus();
346
455
  }
347
456
  }
457
+ if (changedProperties.has("showTitleInfo")) {
458
+ if (!this.showTitleInfo) {
459
+ this.title = "";
460
+ }
461
+ }
348
462
  }
349
463
  render() {
350
464
  const name = this._getPlaceSvg(this.placeType, this.state);
@@ -357,7 +471,11 @@ let SbbSeatReservationPlaceControlElement = (() => {
357
471
  const textRotation = this.style?.getPropertyValue("--sbb-seat-reservation-place-control-text-rotation");
358
472
  const inverseRotationPlaceCheckIcon = Number(textRotation) - Number(rotation);
359
473
  const disabledClass = this.preventClick ? "sbb-reservation-place-control--disabled" : null;
360
- this.title = this._getTitleDescriptionPlace();
474
+ if (this.showTitleInfo) {
475
+ this.title = this._getTitleDescriptionPlace(rotation);
476
+ } else {
477
+ this._optionalScreenreaderInfo = this._getTitleDescriptionPlace(rotation);
478
+ }
361
479
  this.tabIndex = -1;
362
480
  return html`
363
481
  <div
@@ -377,6 +495,9 @@ let SbbSeatReservationPlaceControlElement = (() => {
377
495
  <span ${this.text ?? nothing} class="sbb-sr-place-ctrl__text" aria-hidden="true"
378
496
  >${text}</span
379
497
  >
498
+ ${!this.showTitleInfo ? html`<sbb-screen-reader-only id="${this.id}"
499
+ >${this._optionalScreenreaderInfo}</sbb-screen-reader-only
500
+ >` : nothing}
380
501
  </div>
381
502
  `;
382
503
  }
@@ -385,15 +506,31 @@ let SbbSeatReservationPlaceControlElement = (() => {
385
506
  const stateString = state;
386
507
  return `PLACE_${typeString}_${stateString}`;
387
508
  }
388
- _getTitleDescriptionPlace() {
509
+ _getTitleDescriptionPlace(rotation) {
389
510
  const translationKey = "PLACE_CONTROL_" + this.type + "_" + this.state;
390
511
  let description = getI18nSeatReservation(translationKey, this._language.current, [this.text]);
391
- if (this.propertyIds.length) {
512
+ const relativeTravelDirection = this._getRelativeTravelDirection(rotation);
513
+ if (this.propertyIds.length || relativeTravelDirection) {
392
514
  description += ". " + getI18nSeatReservation("PLACE_PROPERTY", this._language.current).concat(": ");
393
- description += this.propertyIds.map((propertyId) => getI18nSeatReservation("PLACE_PROPERTIES." + propertyId, this._language.current)).filter((value) => value).join(", ");
515
+ description += [relativeTravelDirection, ...this.propertyIds].map((propertyId) => getI18nSeatReservation("PLACE_PROPERTIES." + propertyId, this._language.current)).filter((value) => value).join(", ");
394
516
  }
395
517
  return description;
396
518
  }
519
+ _getRelativeTravelDirection(rotationValue) {
520
+ if (!this.travelDirection || this.travelDirection === "NONE" || this.placeType !== "SEAT" || !rotationValue)
521
+ return void 0;
522
+ const rotation = Number(rotationValue);
523
+ if (rotation === 90 || rotation === 270) {
524
+ return "TRAVEL_DIRECTION_TRANSVERSELY";
525
+ }
526
+ const inDirection = rotation === 0 && this.travelDirection === "RIGHT" || rotation === 180 && this.travelDirection === "LEFT";
527
+ if (inDirection) {
528
+ return "TRAVEL_DIRECTION_IN_DIRECTION";
529
+ } else if (rotation === 0 || rotation === 180) {
530
+ return "TRAVEL_DIRECTION_IN_OPPOSITE_DIRECTION";
531
+ }
532
+ return void 0;
533
+ }
397
534
  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */
398
535
  _selectPlace() {
399
536
  const selectable = (this.state === "FREE" || this.state === "SELECTED") && !this.preventClick;
@@ -414,22 +551,27 @@ let SbbSeatReservationPlaceControlElement = (() => {
414
551
  }));
415
552
  }
416
553
  }
417
- }, _placeType_accessor_storage = new WeakMap(), _state_accessor_storage = new WeakMap(), _propertyIds_accessor_storage = new WeakMap(), _text_accessor_storage = new WeakMap(), _deckIndex_accessor_storage = new WeakMap(), _coachIndex_accessor_storage = new WeakMap(), _preventClick_accessor_storage = new WeakMap(), _keyfocus_accessor_storage = new WeakMap(), _classThis = _a, (() => {
554
+ }, _placeType_accessor_storage = new WeakMap(), _state_accessor_storage = new WeakMap(), _travelDirection_accessor_storage = new WeakMap(), _propertyIds_accessor_storage = new WeakMap(), _text_accessor_storage = new WeakMap(), _deckIndex_accessor_storage = new WeakMap(), _coachIndex_accessor_storage = new WeakMap(), _preventClick_accessor_storage = new WeakMap(), _keyfocus_accessor_storage = new WeakMap(), _showTitleInfo_accessor_storage = new WeakMap(), _classThis = _a, (() => {
418
555
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
419
556
  _placeType_decorators = [forceType(), property({ attribute: "type" })];
420
557
  _state_decorators = [forceType(), property({ attribute: "state", reflect: true })];
558
+ _travelDirection_decorators = [property({ attribute: "travel-direction" })];
421
559
  _propertyIds_decorators = [property({ attribute: "propertyIds", type: Array })];
422
560
  _text_decorators = [forceType(), property({ attribute: "text" })];
423
561
  _deckIndex_decorators = [forceType(), property({ attribute: "deck-index", type: Number })];
424
562
  _coachIndex_decorators = [forceType(), property({ attribute: "coach-index", type: Number })];
425
563
  _preventClick_decorators = [forceType(), property({ attribute: "prevent-click", type: Boolean })];
426
564
  _keyfocus_decorators = [forceType(), property({ attribute: "keyfocus" })];
565
+ _showTitleInfo_decorators = [forceType(), property({ type: Boolean, useDefault: true })];
427
566
  __esDecorate(_a, null, _placeType_decorators, { kind: "accessor", name: "placeType", static: false, private: false, access: { has: (obj) => "placeType" in obj, get: (obj) => obj.placeType, set: (obj, value) => {
428
567
  obj.placeType = value;
429
568
  } }, metadata: _metadata }, _placeType_initializers, _placeType_extraInitializers);
430
569
  __esDecorate(_a, null, _state_decorators, { kind: "accessor", name: "state", static: false, private: false, access: { has: (obj) => "state" in obj, get: (obj) => obj.state, set: (obj, value) => {
431
570
  obj.state = value;
432
571
  } }, metadata: _metadata }, _state_initializers, _state_extraInitializers);
572
+ __esDecorate(_a, null, _travelDirection_decorators, { kind: "accessor", name: "travelDirection", static: false, private: false, access: { has: (obj) => "travelDirection" in obj, get: (obj) => obj.travelDirection, set: (obj, value) => {
573
+ obj.travelDirection = value;
574
+ } }, metadata: _metadata }, _travelDirection_initializers, _travelDirection_extraInitializers);
433
575
  __esDecorate(_a, null, _propertyIds_decorators, { kind: "accessor", name: "propertyIds", static: false, private: false, access: { has: (obj) => "propertyIds" in obj, get: (obj) => obj.propertyIds, set: (obj, value) => {
434
576
  obj.propertyIds = value;
435
577
  } }, metadata: _metadata }, _propertyIds_initializers, _propertyIds_extraInitializers);
@@ -448,6 +590,9 @@ let SbbSeatReservationPlaceControlElement = (() => {
448
590
  __esDecorate(_a, null, _keyfocus_decorators, { kind: "accessor", name: "keyfocus", static: false, private: false, access: { has: (obj) => "keyfocus" in obj, get: (obj) => obj.keyfocus, set: (obj, value) => {
449
591
  obj.keyfocus = value;
450
592
  } }, metadata: _metadata }, _keyfocus_initializers, _keyfocus_extraInitializers);
593
+ __esDecorate(_a, null, _showTitleInfo_decorators, { kind: "accessor", name: "showTitleInfo", static: false, private: false, access: { has: (obj) => "showTitleInfo" in obj, get: (obj) => obj.showTitleInfo, set: (obj, value) => {
594
+ obj.showTitleInfo = value;
595
+ } }, metadata: _metadata }, _showTitleInfo_initializers, _showTitleInfo_extraInitializers);
451
596
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
452
597
  _classThis = _classDescriptor.value;
453
598
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
@@ -459,4 +604,4 @@ let SbbSeatReservationPlaceControlElement = (() => {
459
604
  export {
460
605
  SbbSeatReservationPlaceControlElement
461
606
  };
462
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-place-control.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"sourcesContent":["import { SbbButtonBaseElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type { PlaceSelection, PlaceState, PlaceType } from '../common.ts';\n\nimport '../seat-reservation-graphic.ts';\n\nimport style from './seat-reservation-place-control.scss?lit&inline';\n\n/**\n * Output the graphic of a seat or a bicycle place as a control element.\n */\nexport\n@customElement('sbb-seat-reservation-place-control')\nclass SbbSeatReservationPlaceControlElement extends SbbButtonBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectplace: 'selectplace',\n  } as const;\n\n  /** placeType of the place, e.g. 'SEAT', 'BICYCLE' */\n  @forceType()\n  @property({ attribute: 'type' })\n  public accessor placeType: PlaceType = 'SEAT';\n\n  /** state of the place, e.g. 'FREE', 'SELECTED', 'BLOCKED' */\n  @forceType()\n  @property({ attribute: 'state', reflect: true })\n  public accessor state: PlaceState = 'FREE';\n\n  /** property ids of the place, to display more info about the place */\n  @property({ attribute: 'propertyIds', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Deck Index Prop to identifier the right place to deck */\n  @forceType()\n  @property({ attribute: 'deck-index', type: Number })\n  public accessor deckIndex: number = null!;\n\n  /** Coach Index Prop to identifier the right place to coach */\n  @forceType()\n  @property({ attribute: 'coach-index', type: Number })\n  public accessor coachIndex: number = null!;\n\n  /** Prevent click prop prevent any place action */\n  @forceType()\n  @property({ attribute: 'prevent-click', type: Boolean })\n  public accessor preventClick: boolean = false;\n\n  /** Set the place focus outline style */\n  @forceType()\n  @property({ attribute: 'keyfocus' })\n  public accessor keyfocus: string = 'unfocus';\n\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    this.addEventListener('click', () => this._selectPlace());\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('keyfocus')) {\n      if (this.keyfocus === 'focus') {\n        this.focus();\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const name: string = this._getPlaceSvg(this.placeType, this.state);\n    const type: string = this.type.toLowerCase();\n    const state: string = this.state.toLowerCase();\n    const text: string | null = this.text;\n    const width = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-width');\n    const height = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-height');\n    const rotation = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-rotation');\n    const textRotation = this.style?.getPropertyValue(\n      '--sbb-seat-reservation-place-control-text-rotation',\n    );\n    const inverseRotationPlaceCheckIcon = Number(textRotation) - Number(rotation);\n    const disabledClass = this.preventClick ? 'sbb-reservation-place-control--disabled' : null;\n\n    this.title = this._getTitleDescriptionPlace();\n    this.tabIndex = -1;\n\n    return html`\n      <div\n        part=\"sbb-sr-place-part\"\n        class=\"sbb-sr-place-ctrl sbb-sr-place-ctrl--orientation-${rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': width,\n            '--sbb-seat-reservation-graphic-height': height,\n            '--sbb-seat-reservation-graphic-rotation': rotation,\n            '--sbb-seat-reservation-graphic-inverse-rotation': inverseRotationPlaceCheckIcon,\n          })}\n          .name=${name}\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        <span ${this.text ?? nothing} class=\"sbb-sr-place-ctrl__text\" aria-hidden=\"true\"\n          >${text}</span\n        >\n      </div>\n    `;\n  }\n\n  private _getPlaceSvg(type: PlaceType, state: PlaceState): string {\n    const typeString = type as string;\n    const stateString = state as string;\n    return `PLACE_${typeString}_${stateString}`;\n  }\n\n  private _getTitleDescriptionPlace(): string {\n    const translationKey = 'PLACE_CONTROL_' + this.type + '_' + this.state;\n    let description = getI18nSeatReservation(translationKey, this._language.current, [this.text]);\n\n    if (this.propertyIds.length) {\n      description +=\n        '. ' + getI18nSeatReservation('PLACE_PROPERTY', this._language.current).concat(': ');\n      description += this.propertyIds\n        .map((propertyId) =>\n          getI18nSeatReservation('PLACE_PROPERTIES.' + propertyId, this._language.current),\n        )\n        .filter((value) => value)\n        .join(', ');\n    }\n\n    return description;\n  }\n\n  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */\n  private _selectPlace(): void {\n    const selectable = (this.state === 'FREE' || this.state === 'SELECTED') && !this.preventClick;\n\n    if (selectable) {\n      this.state = this.state === 'FREE' ? 'SELECTED' : 'FREE';\n      const placeSelection: PlaceSelection = {\n        id: this.id,\n        deckIndex: this.deckIndex,\n        coachIndex: this.coachIndex,\n        number: this.text,\n        state: this.state,\n        placeType: this.placeType,\n      };\n\n      /**\n       * @type {CustomEvent<PlaceSelection>}\n       * Emits when a place was selected via user interaction and returns a\n       * PlaceSelection object with necessary place information.\n       */\n      this.dispatchEvent(\n        new CustomEvent<PlaceSelection>('selectplace', {\n          detail: placeSelection,\n          bubbles: true,\n          composed: true,\n        }),\n      );\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-place-control': SbbSeatReservationPlaceControlElement;\n  }\n}\n"],"names":[],"mappings":"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"}
607
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-place-control.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.ts"],"sourcesContent":["import { SbbButtonBaseElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common.ts';\nimport type { PlaceSelection, PlaceState, PlaceType, TravelDirection } from '../common.ts';\n\nimport '../seat-reservation-graphic.ts';\n\nimport style from './seat-reservation-place-control.scss?lit&inline';\n\ntype TravelDirectionI18nKey =\n  | 'TRAVEL_DIRECTION_IN_DIRECTION'\n  | 'TRAVEL_DIRECTION_IN_OPPOSITE_DIRECTION'\n  | 'TRAVEL_DIRECTION_TRANSVERSELY';\n\n/**\n * Output the graphic of a seat or a bicycle place as a control element.\n */\nexport\n@customElement('sbb-seat-reservation-place-control')\nclass SbbSeatReservationPlaceControlElement extends SbbButtonBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    selectplace: 'selectplace',\n  } as const;\n\n  /** placeType of the place, e.g. 'SEAT', 'BICYCLE' */\n  @forceType()\n  @property({ attribute: 'type' })\n  public accessor placeType: PlaceType = 'SEAT';\n\n  /** state of the place, e.g. 'FREE', 'SELECTED', 'BLOCKED' */\n  @forceType()\n  @property({ attribute: 'state', reflect: true })\n  public accessor state: PlaceState = 'FREE';\n\n  /** direction of a whole train, used to compute an orientation of a place */\n  @property({ attribute: 'travel-direction' })\n  public accessor travelDirection: TravelDirection = 'NONE';\n\n  /** property ids of the place, to display more info about the place */\n  @property({ attribute: 'propertyIds', type: Array })\n  public accessor propertyIds: string[] = [];\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Deck Index Prop to identifier the right place to deck */\n  @forceType()\n  @property({ attribute: 'deck-index', type: Number })\n  public accessor deckIndex: number = null!;\n\n  /** Coach Index Prop to identifier the right place to coach */\n  @forceType()\n  @property({ attribute: 'coach-index', type: Number })\n  public accessor coachIndex: number = null!;\n\n  /** Prevent click prop prevent any place action */\n  @forceType()\n  @property({ attribute: 'prevent-click', type: Boolean })\n  public accessor preventClick: boolean = false;\n\n  /** Set the place focus outline style */\n  @forceType()\n  @property({ attribute: 'keyfocus' })\n  public accessor keyfocus: string = 'unfocus';\n\n  /** Disable the mouse over title information */\n  @forceType()\n  @property({ type: Boolean, useDefault: true })\n  public accessor showTitleInfo: boolean = false;\n\n  private _optionalScreenreaderInfo: string = '';\n\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    this.addEventListener('click', () => this._selectPlace());\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('keyfocus')) {\n      if (this.keyfocus === 'focus') {\n        this.focus();\n      }\n    }\n\n    // if title was shown once, we cannot unset it completely, but this\n    // behaviour should not happen very often as the title should\n    // not switch from on to off and on again\n    if (changedProperties.has('showTitleInfo')) {\n      if (!this.showTitleInfo) {\n        this.title = '';\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const name: string = this._getPlaceSvg(this.placeType, this.state);\n    const type: string = this.type.toLowerCase();\n    const state: string = this.state.toLowerCase();\n    const text: string | null = this.text;\n    const width = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-width');\n    const height = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-height');\n    const rotation = this.style?.getPropertyValue('--sbb-seat-reservation-place-control-rotation');\n    const textRotation = this.style?.getPropertyValue(\n      '--sbb-seat-reservation-place-control-text-rotation',\n    );\n    const inverseRotationPlaceCheckIcon = Number(textRotation) - Number(rotation);\n    const disabledClass = this.preventClick ? 'sbb-reservation-place-control--disabled' : null;\n\n    // only set title to the SbbButtonBaseElement if requested; otherwise provide the title\n    // information to screen readers via an additional element\n    if (this.showTitleInfo) {\n      this.title = this._getTitleDescriptionPlace(rotation);\n    } else {\n      this._optionalScreenreaderInfo = this._getTitleDescriptionPlace(rotation);\n    }\n\n    this.tabIndex = -1;\n\n    return html`\n      <div\n        part=\"sbb-sr-place-part\"\n        class=\"sbb-sr-place-ctrl sbb-sr-place-ctrl--orientation-${rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': width,\n            '--sbb-seat-reservation-graphic-height': height,\n            '--sbb-seat-reservation-graphic-rotation': rotation,\n            '--sbb-seat-reservation-graphic-inverse-rotation': inverseRotationPlaceCheckIcon,\n          })}\n          .name=${name}\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        <span ${this.text ?? nothing} class=\"sbb-sr-place-ctrl__text\" aria-hidden=\"true\"\n          >${text}</span\n        >\n        ${!this.showTitleInfo\n          ? html`<sbb-screen-reader-only id=\"${this.id}\"\n              >${this._optionalScreenreaderInfo}</sbb-screen-reader-only\n            >`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getPlaceSvg(type: PlaceType, state: PlaceState): string {\n    const typeString = type as string;\n    const stateString = state as string;\n    return `PLACE_${typeString}_${stateString}`;\n  }\n\n  private _getTitleDescriptionPlace(rotation: string | undefined): string {\n    const translationKey = 'PLACE_CONTROL_' + this.type + '_' + this.state;\n    let description = getI18nSeatReservation(translationKey, this._language.current, [this.text]);\n\n    const relativeTravelDirection = this._getRelativeTravelDirection(rotation);\n\n    if (this.propertyIds.length || relativeTravelDirection) {\n      description +=\n        '. ' + getI18nSeatReservation('PLACE_PROPERTY', this._language.current).concat(': ');\n\n      description += [relativeTravelDirection, ...this.propertyIds]\n        .map((propertyId) =>\n          getI18nSeatReservation('PLACE_PROPERTIES.' + propertyId, this._language.current),\n        )\n        .filter((value) => value)\n        .join(', ');\n    }\n\n    return description;\n  }\n\n  private _getRelativeTravelDirection(\n    rotationValue: string | undefined,\n  ): TravelDirectionI18nKey | undefined {\n    if (\n      !this.travelDirection ||\n      this.travelDirection === 'NONE' ||\n      this.placeType !== 'SEAT' ||\n      !rotationValue\n    )\n      return undefined;\n    const rotation = Number(rotationValue);\n\n    if (rotation === 90 || rotation === 270) {\n      return 'TRAVEL_DIRECTION_TRANSVERSELY';\n    }\n\n    const inDirection =\n      (rotation === 0 && this.travelDirection === 'RIGHT') ||\n      (rotation === 180 && this.travelDirection === 'LEFT');\n\n    if (inDirection) {\n      return 'TRAVEL_DIRECTION_IN_DIRECTION';\n    } else if (rotation === 0 || rotation === 180) {\n      return 'TRAVEL_DIRECTION_IN_OPPOSITE_DIRECTION';\n    }\n\n    return undefined;\n  }\n\n  /** If the place selectable, we emit the placeSelection object which contains infos to the place state */\n  private _selectPlace(): void {\n    const selectable = (this.state === 'FREE' || this.state === 'SELECTED') && !this.preventClick;\n\n    if (selectable) {\n      this.state = this.state === 'FREE' ? 'SELECTED' : 'FREE';\n      const placeSelection: PlaceSelection = {\n        id: this.id,\n        deckIndex: this.deckIndex,\n        coachIndex: this.coachIndex,\n        number: this.text,\n        state: this.state,\n        placeType: this.placeType,\n      };\n\n      /**\n       * @type {CustomEvent<PlaceSelection>}\n       * Emits when a place was selected via user interaction and returns a\n       * PlaceSelection object with necessary place information.\n       */\n      this.dispatchEvent(\n        new CustomEvent<PlaceSelection>('selectplace', {\n          detail: placeSelection,\n          bubbles: true,\n          composed: true,\n        }),\n      );\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-place-control': SbbSeatReservationPlaceControlElement;\n  }\n}\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-experimental-dev",
3
- "version": "4.6.0-dev.1772444909",
3
+ "version": "4.6.0-dev.1772446531",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
9
  "storybook",
10
- "https://github.com/sbb-design-systems/lyne-components/commit/c8263d5719390619b06dd5a2930e1d344e219e05"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/dc40a3401287758bc83816bef87b618e8bd06f14"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {
@@ -23,6 +23,7 @@ const E = {
23
23
  DRIVER_AREA: { svg: a.chassisDriverTrain },
24
24
  DRIVER_AREA_BUS: { svg: a.chassisDriverBus },
25
25
  DRIVER_AREA_TRAIN: { svg: a.chassisDriverTrainFull },
26
+ DRIVER_AREA_NO_VERTICAL_WALL: { svg: a.chassisDriverTrain },
26
27
  EASY_ACCESS: { svgName: "sa-em" },
27
28
  EASY_ACCESS_AREA: { svgName: "sa-em" },
28
29
  EASY_ACCESS_ICON: { svgName: "sa-em" },