@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
@@ -20,50 +20,61 @@ const style = css`*,
20
20
  }
21
21
 
22
22
  :host {
23
- --sbb-reservation-place-control-rotation: 0;
24
- --sbb-reservation-place-control-text-rotation: 0;
25
- --sbb-reservation-place-control-text-size: calc(
23
+ --sbb-seat-reservation-place-control-width: 16;
24
+ --sbb-seat-reservation-place-control-height: 16;
25
+ --sbb-seat-reservation-place-control-top: 0;
26
+ --sbb-seat-reservation-place-control-left: 0;
27
+ --sbb-seat-reservation-place-control-rotation: 0;
28
+ --sbb-seat-reservation-place-control-text-rotation: 0;
29
+ --sbb-seat-reservation-place-control-text-size: calc(
26
30
  var(--sbb-place-control-text-scale-value, 1) * 0.5
27
31
  );
28
- --sbb-reservation-place-control-default-text: var(--sbb-color-black);
29
- --sbb-reservation-place-control-hover-text: var(--sbb-color-iron);
30
- --sbb-reservation-place-control-focus-text: var(--sbb-color-anthracite);
31
- --sbb-reservation-place-control-allocated-text: var(--sbb-color-smoke);
32
- --sbb-reservation-place-control-free-background-default: var(--sbb-color-white);
33
- --sbb-reservation-place-control-free-background-hover: var(--sbb-color-cloud);
34
- --sbb-reservation-place-control-free-background-focus: var(--sbb-color-silver);
35
- --sbb-reservation-place-control-free-backrest-background-default: var(--sbb-color-black);
36
- --sbb-reservation-place-control-free-backrest-background-hover: var(--sbb-color-black);
37
- --sbb-reservation-place-control-free-backrest-background-focus: var(--sbb-color-black);
38
- --sbb-reservation-place-control-selected-background-default: var(--sbb-color-red);
39
- --sbb-reservation-place-control-selected-background-hover: var(--sbb-color-red125);
40
- --sbb-reservation-place-control-selected-background-focus: var(--sbb-color-red150);
41
- --sbb-reservation-place-control-selected-backrest-background-default: var(--sbb-color-red150);
42
- --sbb-reservation-place-control-selected-backrest-background-hover: #7d000f;
43
- --sbb-reservation-place-control-selected-backrest-background-focus: #5a000b;
44
- --sbb-reservation-place-control-allocated-background-default: var(--sbb-color-milk);
32
+ --sbb-seat-reservation-place-control-default-text: var(--sbb-color-black);
33
+ --sbb-seat-reservation-place-control-hover-text: var(--sbb-color-iron);
34
+ --sbb-seat-reservation-place-control-focus-text: var(--sbb-color-anthracite);
35
+ --sbb-seat-reservation-place-control-allocated-text: var(--sbb-color-smoke);
36
+ --sbb-seat-reservation-place-control-free-background-default: var(--sbb-color-white);
37
+ --sbb-seat-reservation-place-control-free-background-hover: var(--sbb-color-cloud);
38
+ --sbb-seat-reservation-place-control-free-background-focus: var(--sbb-color-silver);
39
+ --sbb-seat-reservation-place-control-free-backrest-background-default: var(--sbb-color-black);
40
+ --sbb-seat-reservation-place-control-free-backrest-background-hover: var(--sbb-color-black);
41
+ --sbb-seat-reservation-place-control-free-backrest-background-focus: var(--sbb-color-black);
42
+ --sbb-seat-reservation-place-control-selected-background-default: var(--sbb-color-red);
43
+ --sbb-seat-reservation-place-control-selected-background-hover: var(--sbb-color-red125);
44
+ --sbb-seat-reservation-place-control-selected-background-focus: var(--sbb-color-red150);
45
+ --sbb-seat-reservation-place-control-selected-backrest-background-default: var(
46
+ --sbb-color-red150
47
+ );
48
+ --sbb-seat-reservation-place-control-selected-backrest-background-hover: #7d000f;
49
+ --sbb-seat-reservation-place-control-selected-backrest-background-focus: #5a000b;
50
+ --sbb-seat-reservation-place-control-allocated-background-default: var(--sbb-color-milk);
51
+ width: calc(var(--sbb-seat-reservation-place-control-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
52
+ height: calc(var(--sbb-seat-reservation-place-control-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
53
+ position: absolute;
54
+ inset-block-start: calc(var(--sbb-seat-reservation-place-control-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
55
+ inset-inline-start: calc(var(--sbb-seat-reservation-place-control-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
45
56
  cursor: pointer;
46
57
  }
47
58
 
48
59
  :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
49
- fill: var(--sbb-reservation-place-control-free-background-hover);
60
+ fill: var(--sbb-seat-reservation-place-control-free-background-hover);
50
61
  }
51
62
  :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
52
- fill: var(--sbb-reservation-place-control-free-backrest-background-hover);
63
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-background-hover);
53
64
  }
54
65
  :host(:hover) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
55
- background-color: var(--sbb-reservation-place-control-free-background-hover);
56
- color: var(--sbb-reservation-place-control-free-text);
66
+ background-color: var(--sbb-seat-reservation-place-control-free-background-hover);
67
+ color: var(--sbb-seat-reservation-place-control-free-text);
57
68
  }
58
69
  :host(:hover) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
59
- fill: var(--sbb-reservation-place-control-selected-background-hover);
70
+ fill: var(--sbb-seat-reservation-place-control-selected-background-hover);
60
71
  }
61
72
  :host(:hover) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
62
- fill: var(--sbb-reservation-place-control-selected-backrest-background-hover);
73
+ fill: var(--sbb-seat-reservation-place-control-selected-backrest-background-hover);
63
74
  }
64
75
  :host(:hover) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
65
- background-color: var(--sbb-reservation-place-control-selected-background-hover);
66
- color: var(--sbb-reservation-place-control-selected-text);
76
+ background-color: var(--sbb-seat-reservation-place-control-selected-background-hover);
77
+ color: var(--sbb-seat-reservation-place-control-selected-text);
67
78
  }
68
79
 
69
80
  :host(:focus) {
@@ -71,63 +82,70 @@ const style = css`*,
71
82
  outline: var(--sbb-border-width-2x) solid var(--sbb-color-black);
72
83
  }
73
84
  :host(:focus) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
74
- fill: var(--sbb-reservation-place-control-free-background-focus);
85
+ fill: var(--sbb-seat-reservation-place-control-free-background-focus);
75
86
  }
76
87
  :host(:focus) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
77
- fill: var(--sbb-reservation-place-control-free-backrest-background-focus);
88
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-background-focus);
78
89
  }
79
90
  :host(:focus) .sbb-sr-place-ctrl--state-free:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
80
- background-color: var(--sbb-reservation-place-control-free-background-focus);
81
- color: var(--sbb-reservation-place-control-free-text);
91
+ background-color: var(--sbb-seat-reservation-place-control-free-background-focus);
92
+ color: var(--sbb-seat-reservation-place-control-free-text);
82
93
  }
83
94
  :host(:focus) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-place) {
84
- fill: var(--sbb-reservation-place-control-selected-background-focus);
95
+ fill: var(--sbb-seat-reservation-place-control-selected-background-focus);
85
96
  }
86
97
  :host(:focus) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) ::part(svg-backrest) {
87
- fill: var(--sbb-reservation-place-control-selected-backrest-background-focus);
98
+ fill: var(--sbb-seat-reservation-place-control-selected-backrest-background-focus);
88
99
  }
89
100
  :host(:focus) .sbb-sr-place-ctrl--state-selected:not(.sbb-reservation-place-control--disabled) .sbb-sr-place-ctrl__text {
90
- background-color: var(--sbb-reservation-place-control-selected-background-focus);
91
- color: var(--sbb-reservation-place-control-selected-text);
101
+ background-color: var(--sbb-seat-reservation-place-control-selected-background-focus);
102
+ color: var(--sbb-seat-reservation-place-control-selected-text);
103
+ }
104
+
105
+ :host(:dir(rtl)) :not(.sbb-sr-place-ctrl--type-bicycle,
106
+ .sbb-sr-place-ctrl--orientation-90,
107
+ .sbb-sr-place-ctrl--orientation-270,
108
+ .sbb-sr-place-ctrl--state-selected) ::part(svg-place) {
109
+ rotate: calc(180 * 1deg);
92
110
  }
93
111
 
94
112
  .sbb-sr-place-ctrl {
95
113
  width: max-content;
96
114
  position: relative;
97
- font-size: calc(var(--sbb-reservation-place-control-text-size) * 0.0625rem);
115
+ font-size: calc(var(--sbb-seat-reservation-place-control-text-size) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
98
116
  }
99
117
  .sbb-sr-place-ctrl--state-free ::part(svg-place) {
100
- fill: var(--sbb-reservation-place-control-free-background-default);
118
+ fill: var(--sbb-seat-reservation-place-control-free-background-default);
101
119
  }
102
120
  .sbb-sr-place-ctrl--state-free ::part(svg-backrest) {
103
- fill: var(--sbb-reservation-place-control-free-backrest-background-default);
121
+ fill: var(--sbb-seat-reservation-place-control-free-backrest-background-default);
104
122
  }
105
123
  .sbb-sr-place-ctrl--state-free .sbb-sr-place-ctrl__text {
106
- background-color: var(--sbb-reservation-place-control-free-background-default);
107
- color: var(--sbb-reservation-place-control-free-text);
124
+ background-color: var(--sbb-seat-reservation-place-control-free-background-default);
125
+ color: var(--sbb-seat-reservation-place-control-free-text);
108
126
  }
109
127
  .sbb-sr-place-ctrl--state-selected ::part(svg-place) {
110
- fill: var(--sbb-reservation-place-control-selected-background-default);
128
+ fill: var(--sbb-seat-reservation-place-control-selected-background-default);
111
129
  }
112
130
  .sbb-sr-place-ctrl--state-selected ::part(svg-backrest) {
113
- fill: var(--sbb-reservation-place-control-selected-backrest-background-default);
131
+ fill: var(--sbb-seat-reservation-place-control-selected-backrest-background-default);
114
132
  }
115
133
  .sbb-sr-place-ctrl--state-selected .sbb-sr-place-ctrl__text {
116
- background-color: var(--sbb-reservation-place-control-selected-background-default);
117
- color: var(--sbb-reservation-place-control-selected-text);
134
+ background-color: var(--sbb-seat-reservation-place-control-selected-background-default);
135
+ color: var(--sbb-seat-reservation-place-control-selected-text);
118
136
  }
119
137
  .sbb-sr-place-ctrl--state-allocated, .sbb-sr-place-ctrl--state-restricted {
120
138
  cursor: not-allowed;
121
139
  }
122
140
  .sbb-sr-place-ctrl--state-allocated ::part(svg-place), .sbb-sr-place-ctrl--state-restricted ::part(svg-place) {
123
- fill: var(--sbb-reservation-place-control-allocated-background-default);
141
+ fill: var(--sbb-seat-reservation-place-control-allocated-background-default);
124
142
  }
125
143
  .sbb-sr-place-ctrl--state-allocated ::part(svg-backrest), .sbb-sr-place-ctrl--state-restricted ::part(svg-backrest) {
126
- fill: var(--sbb-reservation-place-control-allocated-backrest-background-default);
144
+ fill: var(--sbb-seat-reservation-place-control-allocated-backrest-background-default);
127
145
  }
128
146
  .sbb-sr-place-ctrl--state-allocated .sbb-sr-place-ctrl__text, .sbb-sr-place-ctrl--state-restricted .sbb-sr-place-ctrl__text {
129
- background-color: var(--sbb-reservation-place-control-allocated-background-default);
130
- color: var(--sbb-reservation-place-control-allocated-text);
147
+ background-color: var(--sbb-seat-reservation-place-control-allocated-background-default);
148
+ color: var(--sbb-seat-reservation-place-control-allocated-text);
131
149
  }
132
150
  .sbb-sr-place-ctrl__text {
133
151
  overflow: hidden;
@@ -135,7 +153,7 @@ const style = css`*,
135
153
  position: absolute;
136
154
  inset-block-start: 50%;
137
155
  translate: -50% -50%;
138
- rotate: calc(var(--sbb-reservation-place-control-text-rotation) * 1deg);
156
+ rotate: calc(var(--sbb-seat-reservation-place-control-text-rotation) * 1deg);
139
157
  font-family: var(--sbb-typo-font-family);
140
158
  font-size: 0.75em;
141
159
  line-height: initial;
@@ -162,6 +180,19 @@ const style = css`*,
162
180
  .sbb-sr-place-ctrl--orientation-270.sbb-sr-place-ctrl--type-seat .sbb-sr-place-ctrl__text {
163
181
  inset-block-start: 52%;
164
182
  inset-inline-start: 52%;
183
+ }
184
+
185
+ :host(:dir(rtl)) .sbb-sr-place-ctrl--orientation-0 .sbb-sr-place-ctrl__text {
186
+ inset-inline-start: 3%;
187
+ }
188
+ :host(:dir(rtl)) .sbb-sr-place-ctrl--orientation-90 .sbb-sr-place-ctrl__text, :host(:dir(rtl)) .sbb-sr-place-ctrl--orientation-180 .sbb-sr-place-ctrl__text {
189
+ inset-inline-start: 10%;
190
+ }
191
+ :host(:dir(rtl)) .sbb-sr-place-ctrl--orientation-270 .sbb-sr-place-ctrl__text {
192
+ inset-inline-start: 5%;
193
+ }
194
+ :host(:dir(rtl)) .sbb-sr-place-ctrl--type-bicycle .sbb-sr-place-ctrl__text {
195
+ inset-inline-start: -10%;
165
196
  }`;
166
197
  let SbbSeatReservationPlaceControlElement = (() => {
167
198
  var _placeType_accessor_storage, _state_accessor_storage, _propertyIds_accessor_storage, _rotation_accessor_storage, _width_accessor_storage, _height_accessor_storage, _text_accessor_storage, _textRotation_accessor_storage, _coachIndex_accessor_storage, _preventClick_accessor_storage, _keyfocus_accessor_storage, _a;
@@ -314,10 +345,10 @@ let SbbSeatReservationPlaceControlElement = (() => {
314
345
  this.style?.setProperty("--sbb-place-control-text-scale-value", `${Math.min(this.width, this.height)}`);
315
346
  }
316
347
  if (changedProperties.has("textRotation")) {
317
- this.style?.setProperty("--sbb-reservation-place-control-text-rotation", `${this.textRotation}`);
348
+ this.style?.setProperty("--sbb-seat-reservation-place-control-text-rotation", `${this.textRotation}`);
318
349
  }
319
350
  if (changedProperties.has("rotation")) {
320
- this.style?.setProperty("--sbb-reservation-place-control-rotation", `${this.rotation}`);
351
+ this.style?.setProperty("--sbb-seat-reservation-place-control-rotation", `${this.rotation}`);
321
352
  }
322
353
  if (changedProperties.has("keyfocus")) {
323
354
  if (this.keyfocus === "focus") {
@@ -378,7 +409,8 @@ let SbbSeatReservationPlaceControlElement = (() => {
378
409
  id: this.id,
379
410
  coachIndex: this.coachIndex,
380
411
  number: this.text,
381
- state: this.state
412
+ state: this.state,
413
+ placeType: this.placeType
382
414
  };
383
415
  this.dispatchEvent(new CustomEvent("selectplace", {
384
416
  detail: placeSelection,
@@ -444,4 +476,4 @@ let SbbSeatReservationPlaceControlElement = (() => {
444
476
  export {
445
477
  SbbSeatReservationPlaceControlElement
446
478
  };
447
- //# 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 { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getI18nSeatReservation } from '../common.js';\nimport type { PlaceSelection, PlaceState, PlaceType } from '../common.js';\n\nimport '../seat-reservation-graphic.js';\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 = 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' })\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  /** rotation in degrees (without unit) */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** width of the place in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = 32;\n\n  /** height of the place in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = 32;\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Rotation of the text in degrees (without unit) */\n  @forceType()\n  @property({ attribute: 'text-rotation' })\n  public accessor textRotation: number = 0;\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('width') || changedProperties.has('height')) {\n      this.style?.setProperty(\n        '--sbb-place-control-text-scale-value',\n        `${Math.min(this.width, this.height)}`,\n      );\n    }\n\n    if (changedProperties.has('textRotation')) {\n      this.style?.setProperty(\n        '--sbb-reservation-place-control-text-rotation',\n        `${this.textRotation}`,\n      );\n    }\n\n    if (changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-reservation-place-control-rotation', `${this.rotation}`);\n    }\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: number = this.width;\n    const height: number = this.height;\n    const inverseRotationPlaceCheckIcon = this.textRotation - this.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-${this\n          .rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          .name=${name}\n          .width=${width}\n          .height=${height}\n          .rotation=${this.rotation}\n          .inverseRotation=${inverseRotationPlaceCheckIcon}\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) => getI18nSeatReservation(propertyId, this._language.current))\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        coachIndex: this.coachIndex,\n        number: this.text,\n        state: this.state,\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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"}
479
+ //# 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 { type CSSResultGroup, html, nothing, type TemplateResult, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getI18nSeatReservation } from '../common.js';\nimport type { PlaceSelection, PlaceState, PlaceType } from '../common.js';\n\nimport '../seat-reservation-graphic.js';\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 = 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' })\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  /** rotation in degrees (without unit) */\n  @forceType()\n  @property({ attribute: 'rotation', type: Number })\n  public accessor rotation: number = 0;\n\n  /** width of the place in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width', type: Number })\n  public accessor width: number = 32;\n\n  /** height of the place in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height', type: Number })\n  public accessor height: number = 32;\n\n  /** label of the place, e.g. '1A', '2B' */\n  @forceType()\n  @property({ attribute: 'text' })\n  public accessor text: string = '';\n\n  /** Rotation of the text in degrees (without unit) */\n  @forceType()\n  @property({ attribute: 'text-rotation' })\n  public accessor textRotation: number = 0;\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('width') || changedProperties.has('height')) {\n      this.style?.setProperty(\n        '--sbb-place-control-text-scale-value',\n        `${Math.min(this.width, this.height)}`,\n      );\n    }\n\n    if (changedProperties.has('textRotation')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-place-control-text-rotation',\n        `${this.textRotation}`,\n      );\n    }\n\n    if (changedProperties.has('rotation')) {\n      this.style?.setProperty('--sbb-seat-reservation-place-control-rotation', `${this.rotation}`);\n    }\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: number = this.width;\n    const height: number = this.height;\n    const inverseRotationPlaceCheckIcon = this.textRotation - this.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-${this\n          .rotation} sbb-sr-place-ctrl--state-${state} sbb-sr-place-ctrl--type-${type} ${disabledClass}\"\n      >\n        <sbb-seat-reservation-graphic\n          .name=${name}\n          .width=${width}\n          .height=${height}\n          .rotation=${this.rotation}\n          .inverseRotation=${inverseRotationPlaceCheckIcon}\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) => getI18nSeatReservation(propertyId, this._language.current))\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        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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"}
@@ -1,24 +1,9 @@
1
- import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
1
+ import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
2
2
  /**
3
3
  * Wrapper class for scoped elements with similar properties to set.
4
4
  */
5
5
  export declare class SbbSeatReservationScopedElement extends LitElement {
6
6
  static styles: CSSResultGroup;
7
- /** Inset block start in pixels (without unit) */
8
- accessor insetBlockStart: string;
9
- /** Inset inline start in pixels (without unit) */
10
- accessor insetInlineStart: string;
11
- /** Width of the scoped element in pixels (without unit) */
12
- accessor width: string;
13
- /** Height of the scoped element in pixels (without unit) */
14
- accessor height: string;
15
- /** Z-index of the scoped element */
16
- accessor zIndex: string;
17
- /** Cell id of the scoped element, if it is used in a table */
18
- accessor cellId: string;
19
- /** Scoped classes for the scoped element */
20
- accessor scopedClasses: string;
21
- protected willUpdate(_changedProperties: PropertyValues): void;
22
7
  protected render(): TemplateResult;
23
8
  }
24
9
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"seat-reservation-scoped.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AACpF,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC;;GAEG;AACH,qBAEM,+BAAgC,SAAQ,UAAU;IACtD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,iDAAiD;IACjD,SAEgB,eAAe,EAAE,MAAM,CAAM;IAE7C,kDAAkD;IAClD,SAEgB,gBAAgB,EAAE,MAAM,CAAM;IAE9C,2DAA2D;IAC3D,SAEgB,KAAK,EAAE,MAAM,CAAM;IAEnC,4DAA4D;IAC5D,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,oCAAoC;IACpC,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,8DAA8D;IAC9D,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,4CAA4C;IAC5C,SAEgB,aAAa,EAAE,MAAM,CAAM;cAExB,UAAU,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;cA8BpD,MAAM,IAAI,cAAc;CAW5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,6BAA6B,EAAE,+BAA+B,CAAC;KAChE;CACF"}
1
+ {"version":3,"file":"seat-reservation-scoped.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC/D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC;;GAEG;AACH,qBAEM,+BAAgC,SAAQ,UAAU;IACtD,OAAuB,MAAM,EAAE,cAAc,CAAS;cAEnC,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,6BAA6B,EAAE,+BAA+B,CAAC;KAChE;CACF"}
@@ -1,14 +1,6 @@
1
- var __typeError = (msg) => {
2
- throw TypeError(msg);
3
- };
4
- var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
5
- var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
6
- var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
7
- var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
8
1
  import { __esDecorate, __runInitializers } from "tslib";
9
- import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
10
2
  import { css, LitElement, html } from "lit";
11
- import { customElement, property } from "lit/decorators.js";
3
+ import { customElement } from "lit/decorators.js";
12
4
  const style = css`*,
13
5
  ::before,
14
6
  ::after {
@@ -16,173 +8,27 @@ const style = css`*,
16
8
  }
17
9
 
18
10
  :host {
11
+ --sbb-seat-reservation-scoped-width: 0;
12
+ --sbb-seat-reservation-scoped-height: 0;
19
13
  display: block;
20
14
  }
21
- :host .coach-border,
22
- :host .coach-wrapper,
23
- :host .graphical-element {
24
- width: var(--sbb-seat-reservation-scoped-width);
25
- height: var(--sbb-seat-reservation-scoped-height);
26
- inset-block-start: var(--sbb-seat-reservation-scoped-inset-block-start);
27
- inset-inline-start: var(--sbb-seat-reservation-scoped-inset-inline-start);
28
- z-index: var(--sbb-seat-reservation-scoped-z-index);
29
- }
30
- :host .coach-border,
31
- :host .graphical-element ::slotted(*),
32
- :host .graphical-element {
33
- position: absolute;
34
- }
35
- :host .coach-border {
36
- z-index: 0;
15
+ :host .scoped-element {
16
+ width: calc(var(--sbb-seat-reservation-scoped-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
17
+ height: calc(var(--sbb-seat-reservation-scoped-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
37
18
  }`;
38
19
  let SbbSeatReservationScopedElement = (() => {
39
- var _insetBlockStart_accessor_storage, _insetInlineStart_accessor_storage, _width_accessor_storage, _height_accessor_storage, _zIndex_accessor_storage, _cellId_accessor_storage, _scopedClasses_accessor_storage, _a;
20
+ var _a;
40
21
  let _classDecorators = [customElement("sbb-seat-reservation-scoped")];
41
22
  let _classDescriptor;
42
23
  let _classExtraInitializers = [];
43
24
  let _classThis;
44
25
  let _classSuper = LitElement;
45
- let _insetBlockStart_decorators;
46
- let _insetBlockStart_initializers = [];
47
- let _insetBlockStart_extraInitializers = [];
48
- let _insetInlineStart_decorators;
49
- let _insetInlineStart_initializers = [];
50
- let _insetInlineStart_extraInitializers = [];
51
- let _width_decorators;
52
- let _width_initializers = [];
53
- let _width_extraInitializers = [];
54
- let _height_decorators;
55
- let _height_initializers = [];
56
- let _height_extraInitializers = [];
57
- let _zIndex_decorators;
58
- let _zIndex_initializers = [];
59
- let _zIndex_extraInitializers = [];
60
- let _cellId_decorators;
61
- let _cellId_initializers = [];
62
- let _cellId_extraInitializers = [];
63
- let _scopedClasses_decorators;
64
- let _scopedClasses_initializers = [];
65
- let _scopedClasses_extraInitializers = [];
66
26
  _a = class extends _classSuper {
67
- constructor() {
68
- super(...arguments);
69
- __privateAdd(this, _insetBlockStart_accessor_storage, __runInitializers(this, _insetBlockStart_initializers, ""));
70
- __privateAdd(this, _insetInlineStart_accessor_storage, (__runInitializers(this, _insetBlockStart_extraInitializers), __runInitializers(this, _insetInlineStart_initializers, "")));
71
- __privateAdd(this, _width_accessor_storage, (__runInitializers(this, _insetInlineStart_extraInitializers), __runInitializers(this, _width_initializers, "")));
72
- __privateAdd(this, _height_accessor_storage, (__runInitializers(this, _width_extraInitializers), __runInitializers(this, _height_initializers, "")));
73
- __privateAdd(this, _zIndex_accessor_storage, (__runInitializers(this, _height_extraInitializers), __runInitializers(this, _zIndex_initializers, "")));
74
- __privateAdd(this, _cellId_accessor_storage, (__runInitializers(this, _zIndex_extraInitializers), __runInitializers(this, _cellId_initializers, "")));
75
- __privateAdd(this, _scopedClasses_accessor_storage, (__runInitializers(this, _cellId_extraInitializers), __runInitializers(this, _scopedClasses_initializers, "")));
76
- __runInitializers(this, _scopedClasses_extraInitializers);
77
- }
78
- /** Inset block start in pixels (without unit) */
79
- get insetBlockStart() {
80
- return __privateGet(this, _insetBlockStart_accessor_storage);
81
- }
82
- set insetBlockStart(value) {
83
- __privateSet(this, _insetBlockStart_accessor_storage, value);
84
- }
85
- /** Inset inline start in pixels (without unit) */
86
- get insetInlineStart() {
87
- return __privateGet(this, _insetInlineStart_accessor_storage);
88
- }
89
- set insetInlineStart(value) {
90
- __privateSet(this, _insetInlineStart_accessor_storage, value);
91
- }
92
- /** Width of the scoped element in pixels (without unit) */
93
- get width() {
94
- return __privateGet(this, _width_accessor_storage);
95
- }
96
- set width(value) {
97
- __privateSet(this, _width_accessor_storage, value);
98
- }
99
- /** Height of the scoped element in pixels (without unit) */
100
- get height() {
101
- return __privateGet(this, _height_accessor_storage);
102
- }
103
- set height(value) {
104
- __privateSet(this, _height_accessor_storage, value);
105
- }
106
- /** Z-index of the scoped element */
107
- get zIndex() {
108
- return __privateGet(this, _zIndex_accessor_storage);
109
- }
110
- set zIndex(value) {
111
- __privateSet(this, _zIndex_accessor_storage, value);
112
- }
113
- /** Cell id of the scoped element, if it is used in a table */
114
- get cellId() {
115
- return __privateGet(this, _cellId_accessor_storage);
116
- }
117
- set cellId(value) {
118
- __privateSet(this, _cellId_accessor_storage, value);
119
- }
120
- /** Scoped classes for the scoped element */
121
- get scopedClasses() {
122
- return __privateGet(this, _scopedClasses_accessor_storage);
123
- }
124
- set scopedClasses(value) {
125
- __privateSet(this, _scopedClasses_accessor_storage, value);
126
- }
127
- willUpdate(_changedProperties) {
128
- super.willUpdate(_changedProperties);
129
- if (_changedProperties.has("width")) {
130
- this.style?.setProperty("--sbb-seat-reservation-scoped-width", `${this.width}`);
131
- }
132
- if (_changedProperties.has("height")) {
133
- this.style?.setProperty("--sbb-seat-reservation-scoped-height", `${this.height}`);
134
- }
135
- if (_changedProperties.has("insetBlockStart")) {
136
- this.style?.setProperty("--sbb-seat-reservation-scoped-inset-block-start", `${this.insetBlockStart}`);
137
- }
138
- if (_changedProperties.has("insetInlineStart")) {
139
- this.style?.setProperty("--sbb-seat-reservation-scoped-inset-inline-start", `${this.insetInlineStart}`);
140
- }
141
- if (_changedProperties.has("zIndex")) {
142
- this.style?.setProperty("--sbb-seat-reservation-scoped-z-index", `${this.zIndex}`);
143
- }
144
- }
145
27
  render() {
146
- if (!this.cellId) {
147
- return html`<div class="${this.scopedClasses}">
148
- <slot></slot>
149
- </div>`;
150
- } else {
151
- return html`<td id="${this.cellId}" class="${this.scopedClasses}">
152
- <slot></slot>
153
- </td>`;
154
- }
28
+ return html`<div class="scoped-element"><slot></slot></div>`;
155
29
  }
156
- }, _insetBlockStart_accessor_storage = new WeakMap(), _insetInlineStart_accessor_storage = new WeakMap(), _width_accessor_storage = new WeakMap(), _height_accessor_storage = new WeakMap(), _zIndex_accessor_storage = new WeakMap(), _cellId_accessor_storage = new WeakMap(), _scopedClasses_accessor_storage = new WeakMap(), _classThis = _a, (() => {
30
+ }, _classThis = _a, (() => {
157
31
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
158
- _insetBlockStart_decorators = [forceType(), property({ attribute: "inset-block-start" })];
159
- _insetInlineStart_decorators = [forceType(), property({ attribute: "inset-inline-start" })];
160
- _width_decorators = [forceType(), property({ attribute: "width" })];
161
- _height_decorators = [forceType(), property({ attribute: "height" })];
162
- _zIndex_decorators = [forceType(), property({ attribute: "z-index" })];
163
- _cellId_decorators = [forceType(), property({ attribute: "cell-id" })];
164
- _scopedClasses_decorators = [forceType(), property({ attribute: "scoped-classes" })];
165
- __esDecorate(_a, null, _insetBlockStart_decorators, { kind: "accessor", name: "insetBlockStart", static: false, private: false, access: { has: (obj) => "insetBlockStart" in obj, get: (obj) => obj.insetBlockStart, set: (obj, value) => {
166
- obj.insetBlockStart = value;
167
- } }, metadata: _metadata }, _insetBlockStart_initializers, _insetBlockStart_extraInitializers);
168
- __esDecorate(_a, null, _insetInlineStart_decorators, { kind: "accessor", name: "insetInlineStart", static: false, private: false, access: { has: (obj) => "insetInlineStart" in obj, get: (obj) => obj.insetInlineStart, set: (obj, value) => {
169
- obj.insetInlineStart = value;
170
- } }, metadata: _metadata }, _insetInlineStart_initializers, _insetInlineStart_extraInitializers);
171
- __esDecorate(_a, null, _width_decorators, { kind: "accessor", name: "width", static: false, private: false, access: { has: (obj) => "width" in obj, get: (obj) => obj.width, set: (obj, value) => {
172
- obj.width = value;
173
- } }, metadata: _metadata }, _width_initializers, _width_extraInitializers);
174
- __esDecorate(_a, null, _height_decorators, { kind: "accessor", name: "height", static: false, private: false, access: { has: (obj) => "height" in obj, get: (obj) => obj.height, set: (obj, value) => {
175
- obj.height = value;
176
- } }, metadata: _metadata }, _height_initializers, _height_extraInitializers);
177
- __esDecorate(_a, null, _zIndex_decorators, { kind: "accessor", name: "zIndex", static: false, private: false, access: { has: (obj) => "zIndex" in obj, get: (obj) => obj.zIndex, set: (obj, value) => {
178
- obj.zIndex = value;
179
- } }, metadata: _metadata }, _zIndex_initializers, _zIndex_extraInitializers);
180
- __esDecorate(_a, null, _cellId_decorators, { kind: "accessor", name: "cellId", static: false, private: false, access: { has: (obj) => "cellId" in obj, get: (obj) => obj.cellId, set: (obj, value) => {
181
- obj.cellId = value;
182
- } }, metadata: _metadata }, _cellId_initializers, _cellId_extraInitializers);
183
- __esDecorate(_a, null, _scopedClasses_decorators, { kind: "accessor", name: "scopedClasses", static: false, private: false, access: { has: (obj) => "scopedClasses" in obj, get: (obj) => obj.scopedClasses, set: (obj, value) => {
184
- obj.scopedClasses = value;
185
- } }, metadata: _metadata }, _scopedClasses_initializers, _scopedClasses_extraInitializers);
186
32
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
187
33
  _classThis = _classDescriptor.value;
188
34
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
@@ -192,4 +38,4 @@ let SbbSeatReservationScopedElement = (() => {
192
38
  export {
193
39
  SbbSeatReservationScopedElement
194
40
  };
195
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-scoped.component.js","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.ts"],"sourcesContent":["import { 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';\n\nimport style from './seat-reservation-scoped.scss?lit&inline';\n\n/**\n * Wrapper class for scoped elements with similar properties to set.\n */\nexport\n@customElement('sbb-seat-reservation-scoped')\nclass SbbSeatReservationScopedElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Inset block start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-block-start' })\n  public accessor insetBlockStart: string = '';\n\n  /** Inset inline start in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'inset-inline-start' })\n  public accessor insetInlineStart: string = '';\n\n  /** Width of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'width' })\n  public accessor width: string = '';\n\n  /** Height of the scoped element in pixels (without unit) */\n  @forceType()\n  @property({ attribute: 'height' })\n  public accessor height: string = '';\n\n  /** Z-index of the scoped element */\n  @forceType()\n  @property({ attribute: 'z-index' })\n  public accessor zIndex: string = '';\n\n  /** Cell id of the scoped element, if it is used in a table */\n  @forceType()\n  @property({ attribute: 'cell-id' })\n  public accessor cellId: string = '';\n\n  /** Scoped classes for the scoped element */\n  @forceType()\n  @property({ attribute: 'scoped-classes' })\n  public accessor scopedClasses: string = '';\n\n  protected override willUpdate(_changedProperties: PropertyValues): void {\n    super.willUpdate(_changedProperties);\n\n    if (_changedProperties.has('width')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-width', `${this.width}`);\n    }\n\n    if (_changedProperties.has('height')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-height', `${this.height}`);\n    }\n\n    if (_changedProperties.has('insetBlockStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-block-start',\n        `${this.insetBlockStart}`,\n      );\n    }\n\n    if (_changedProperties.has('insetInlineStart')) {\n      this.style?.setProperty(\n        '--sbb-seat-reservation-scoped-inset-inline-start',\n        `${this.insetInlineStart}`,\n      );\n    }\n\n    if (_changedProperties.has('zIndex')) {\n      this.style?.setProperty('--sbb-seat-reservation-scoped-z-index', `${this.zIndex}`);\n    }\n  }\n\n  protected override render(): TemplateResult {\n    if (!this.cellId) {\n      return html`<div class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </div>`;\n    } else {\n      return html`<td id=\"${this.cellId}\" class=\"${this.scopedClasses}\">\n        <slot></slot>\n      </td>`;\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-scoped': SbbSeatReservationScopedElement;\n  }\n}\n"],"names":[],"mappings":"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"}
41
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1zY29wZWQuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL3NlYXQtcmVzZXJ2YXRpb24vc2VhdC1yZXNlcnZhdGlvbi1zY29wZWQvc2VhdC1yZXNlcnZhdGlvbi1zY29wZWQuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgQ1NTUmVzdWx0R3JvdXAsIHR5cGUgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zZWF0LXJlc2VydmF0aW9uLXNjb3BlZC5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIFdyYXBwZXIgY2xhc3MgZm9yIHNjb3BlZCBlbGVtZW50cyB3aXRoIHNpbWlsYXIgcHJvcGVydGllcyB0byBzZXQuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zZWF0LXJlc2VydmF0aW9uLXNjb3BlZCcpXG5jbGFzcyBTYmJTZWF0UmVzZXJ2YXRpb25TY29wZWRFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYDxkaXYgY2xhc3M9XCJzY29wZWQtZWxlbWVudFwiPjxzbG90Pjwvc2xvdD48L2Rpdj5gO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItc2VhdC1yZXNlcnZhdGlvbi1zY29wZWQnOiBTYmJTZWF0UmVzZXJ2YXRpb25TY29wZWRFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBV00sbUNBQStCLE1BQUE7OzBCQURwQyxjQUFjLDZCQUE2QixDQUFDOzs7O29CQUNDO0FBQVIsRUFBQSxtQkFBUSxZQUFVO0FBQUEsSUFHbkMsU0FBTTtBQUN2QixhQUFPO0FBQUEsSUFDVDtBQUFBOztBQUxGLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QixPQUQ1QyxrQkFBQSxZQUFBLHVCQUFBLEdBQWdDOzs7In0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-experimental",
3
- "version": "3.1.0",
3
+ "version": "3.2.0",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -11,7 +11,7 @@
11
11
  "type": "module",
12
12
  "customElements": "custom-elements.json",
13
13
  "peerDependencies": {
14
- "@sbb-esta/lyne-elements": "3.1.0"
14
+ "@sbb-esta/lyne-elements": "3.2.0"
15
15
  },
16
16
  "dependencies": {
17
17
  "lit": "^3.3.1",
@@ -1 +1 @@
1
- {"version":3,"file":"icon-mapper.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/common/mapper/icon-mapper.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAkE5D,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqGG"}
1
+ {"version":3,"file":"icon-mapper.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/common/mapper/icon-mapper.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAgE5D,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqGG"}
@@ -53,8 +53,6 @@ const E = {
53
53
  SKI_AREA: { svgName: "sa-sa" },
54
54
  SKI_ICON: { svgName: "sa-sa" },
55
55
  STAIR_AREA: { svgName: "sa-ac" },
56
- TABLE: { svg: a.interiorTable },
57
- TABLE_RESTAURANT: { svg: a.interiorTable },
58
56
  TOILET_AREA: { svgName: "sa-wc" },
59
57
  TOILET_ICON: { svgName: "sa-wc" },
60
58
  TOILET_WHEELCHAIR_AREA: { svgName: "sa-rw" },