@sbb-esta/lyne-elements-experimental 2.6.0 → 2.7.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 (100) hide show
  1. package/core/datetime/date-helper.js +191 -0
  2. package/core/datetime.d.ts +3 -0
  3. package/core/datetime.d.ts.map +1 -1
  4. package/core/datetime.js +3 -189
  5. package/core/timetable/access-leg-helper.js +94 -0
  6. package/core/timetable/timetable-helper.js +13 -0
  7. package/core/timetable/timetable-properties.js +1 -0
  8. package/core/timetable.d.ts +3 -0
  9. package/core/timetable.d.ts.map +1 -1
  10. package/core/timetable.js +6 -102
  11. package/custom-elements.json +598 -439
  12. package/development/core/datetime/date-helper.js +285 -0
  13. package/development/core/datetime.d.ts +3 -0
  14. package/development/core/datetime.d.ts.map +1 -1
  15. package/development/core/datetime.js +2 -281
  16. package/development/core/timetable/access-leg-helper.js +128 -0
  17. package/development/core/timetable/timetable-helper.js +21 -0
  18. package/development/core/timetable/timetable-properties.js +2 -0
  19. package/development/core/timetable.d.ts +3 -0
  20. package/development/core/timetable.d.ts.map +1 -1
  21. package/development/core/timetable.js +3 -139
  22. package/development/{differenceInMinutes-Cmyza6nm.js → differenceInMinutes-CHSyWiQs.js} +2 -2
  23. package/development/{format-BU7bjY-L.js → format-D0-yhzi4.js} +3 -3
  24. package/development/{isValid-DO_pHwcW.js → isValid-Bo4R7iA7.js} +2 -2
  25. package/development/journey-summary/journey-summary.js +297 -0
  26. package/development/journey-summary.d.ts +3 -0
  27. package/development/journey-summary.d.ts.map +1 -1
  28. package/development/journey-summary.js +2 -294
  29. package/development/pearl-chain/pearl-chain.js +649 -0
  30. package/development/pearl-chain-time/pearl-chain-time.js +315 -0
  31. package/development/pearl-chain-time.d.ts +3 -0
  32. package/development/pearl-chain-time.d.ts.map +1 -1
  33. package/development/pearl-chain-time.js +2 -312
  34. package/development/pearl-chain-vertical/pearl-chain-vertical.js +45 -0
  35. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.js +395 -0
  36. package/development/pearl-chain-vertical-item.d.ts +3 -0
  37. package/development/pearl-chain-vertical-item.d.ts.map +1 -1
  38. package/development/pearl-chain-vertical-item.js +2 -392
  39. package/development/pearl-chain-vertical.d.ts +3 -0
  40. package/development/pearl-chain-vertical.d.ts.map +1 -1
  41. package/development/pearl-chain-vertical.js +2 -42
  42. package/development/pearl-chain.d.ts +3 -0
  43. package/development/pearl-chain.d.ts.map +1 -1
  44. package/development/pearl-chain.js +2 -646
  45. package/development/timetable-duration/timetable-duration.js +119 -0
  46. package/development/timetable-duration.d.ts +3 -0
  47. package/development/timetable-duration.d.ts.map +1 -1
  48. package/development/timetable-duration.js +2 -116
  49. package/development/timetable-row/timetable-row.js +820 -0
  50. package/development/timetable-row.d.ts +3 -0
  51. package/development/timetable-row.d.ts.map +1 -1
  52. package/development/timetable-row.js +2 -810
  53. package/development/{toDate-B6IBgPYH.js → toDate-D_Vjps95.js} +5 -5
  54. package/{differenceInMinutes-BI2zjbtS.js → differenceInMinutes-BMqUZdhj.js} +1 -1
  55. package/{format-CUYwLzoN.js → format-Dg8rkk7h.js} +2 -2
  56. package/index.d.ts +7 -7
  57. package/index.js +7 -7
  58. package/{isValid-mroh13Xp.js → isValid-DJ69OMZJ.js} +6 -6
  59. package/journey-summary/journey-summary.js +190 -0
  60. package/journey-summary.d.ts +3 -0
  61. package/journey-summary.d.ts.map +1 -1
  62. package/journey-summary.js +2 -188
  63. package/package.json +3 -3
  64. package/pearl-chain/pearl-chain.js +177 -0
  65. package/pearl-chain-time/pearl-chain-time.js +153 -0
  66. package/pearl-chain-time.d.ts +3 -0
  67. package/pearl-chain-time.d.ts.map +1 -1
  68. package/pearl-chain-time.js +2 -151
  69. package/pearl-chain-vertical/pearl-chain-vertical.js +23 -0
  70. package/pearl-chain-vertical-item/pearl-chain-vertical-item.js +71 -0
  71. package/pearl-chain-vertical-item.d.ts +3 -0
  72. package/pearl-chain-vertical-item.d.ts.map +1 -1
  73. package/pearl-chain-vertical-item.js +2 -69
  74. package/pearl-chain-vertical.d.ts +3 -0
  75. package/pearl-chain-vertical.d.ts.map +1 -1
  76. package/pearl-chain-vertical.js +2 -21
  77. package/pearl-chain.d.ts +3 -0
  78. package/pearl-chain.d.ts.map +1 -1
  79. package/pearl-chain.js +2 -175
  80. package/timetable-duration/timetable-duration.js +55 -0
  81. package/timetable-duration.d.ts +3 -0
  82. package/timetable-duration.d.ts.map +1 -1
  83. package/timetable-duration.js +2 -53
  84. package/timetable-row/timetable-row.js +462 -0
  85. package/timetable-row.d.ts +3 -0
  86. package/timetable-row.d.ts.map +1 -1
  87. package/timetable-row.js +9 -460
  88. package/{toDate-DQg4ZFnf.js → toDate-BCXKL_wM.js} +4 -4
  89. package/development/pearl-chain/pearl-chain.sample-data.d.ts +0 -141
  90. package/development/pearl-chain/pearl-chain.sample-data.d.ts.map +0 -1
  91. package/development/timetable-duration/timetable-duration.sample-data.d.ts +0 -6
  92. package/development/timetable-duration/timetable-duration.sample-data.d.ts.map +0 -1
  93. package/development/timetable-row/timetable-row.sample-data.d.ts +0 -25
  94. package/development/timetable-row/timetable-row.sample-data.d.ts.map +0 -1
  95. package/pearl-chain/pearl-chain.sample-data.d.ts +0 -141
  96. package/pearl-chain/pearl-chain.sample-data.d.ts.map +0 -1
  97. package/timetable-duration/timetable-duration.sample-data.d.ts +0 -6
  98. package/timetable-duration/timetable-duration.sample-data.d.ts.map +0 -1
  99. package/timetable-row/timetable-row.sample-data.d.ts +0 -25
  100. package/timetable-row/timetable-row.sample-data.d.ts.map +0 -1
@@ -0,0 +1,315 @@
1
+ var __typeError = (msg) => {
2
+ throw TypeError(msg);
3
+ };
4
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
5
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
6
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
7
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
8
+ import { __runInitializers, __esDecorate } from "tslib";
9
+ import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
10
+ import { defaultDateAdapter } from "@sbb-esta/lyne-elements/core/datetime.js";
11
+ import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
12
+ import { i18nDeparture, i18nTransferProcedures, i18nArrival } from "@sbb-esta/lyne-elements/core/i18n.js";
13
+ import { css, LitElement, nothing, html } from "lit";
14
+ import { customElement, property } from "lit/decorators.js";
15
+ import { removeTimezoneFromISOTimeString } from "../core/datetime.js";
16
+ import { getDepartureArrivalTimeAttribute, isRideLeg } from "../core/timetable.js";
17
+ import "../pearl-chain.js";
18
+ import { f as format } from "../format-D0-yhzi4.js";
19
+ const style = css`*,
20
+ ::before,
21
+ ::after {
22
+ box-sizing: border-box;
23
+ }
24
+
25
+ :host {
26
+ display: block;
27
+ --sbb-pearl-chain-time-height: auto;
28
+ }
29
+ @media (min-width: calc(37.5rem)) {
30
+ :host {
31
+ --sbb-pearl-chain-time-height: 1.5625rem;
32
+ }
33
+ }
34
+ @media (min-width: calc(52.5rem)) {
35
+ :host {
36
+ --sbb-pearl-chain-time-height: 1.75rem;
37
+ }
38
+ }
39
+
40
+ .sbb-pearl-chain__time {
41
+ display: flex;
42
+ flex-wrap: wrap;
43
+ justify-content: space-between;
44
+ align-items: center;
45
+ height: var(--sbb-pearl-chain-time-height);
46
+ }
47
+
48
+ .sbb-pearl-chain__time-walktime,
49
+ .sbb-pearl-chain__time-transfer {
50
+ --sbb-text-font-size: var(--sbb-font-size-text-xxs);
51
+ font-family: var(--sbb-typo-font-family);
52
+ font-weight: normal;
53
+ line-height: var(--sbb-typo-line-height-body-text);
54
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
55
+ font-size: var(--sbb-text-font-size);
56
+ display: inline-flex;
57
+ align-items: center;
58
+ }
59
+
60
+ .sbb-pearl-chain__time-walktime--walk-small-left {
61
+ transform: translateX(-0.4375rem);
62
+ margin-inline-end: calc(var(--sbb-spacing-fixed-2x) - 0.4375rem);
63
+ }
64
+
65
+ .sbb-pearl-chain__time-walktime--walk-small-right {
66
+ margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
67
+ }
68
+
69
+ .sbb-pearl-chain__time-walktime--wheelchair-small-left {
70
+ transform: translateX(-0.375rem);
71
+ margin-inline-end: calc(var(--sbb-spacing-fixed-2x) - 0.4375rem);
72
+ }
73
+
74
+ .sbb-pearl-chain__time-walktime--wheelchair-small-right {
75
+ margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
76
+ }
77
+
78
+ .sbb-pearl-chain__time-walktime-prime-symbol {
79
+ float: right;
80
+ }
81
+
82
+ .sbb-pearl-chain__time-transfer {
83
+ gap: var(--sbb-spacing-fixed-1x);
84
+ }
85
+
86
+ .sbb-pearl-chain__time-transfer--sa-ci-departure {
87
+ margin-inline-end: var(--sbb-spacing-fixed-2x);
88
+ }
89
+
90
+ .sbb-pearl-chain__time-transfer--sa-ci-arrival {
91
+ margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
92
+ }
93
+
94
+ .sbb-pearl-chain__time-chain {
95
+ flex: 1 1 auto;
96
+ align-self: center;
97
+ margin-inline: var(--sbb-spacing-fixed-3x);
98
+ }
99
+
100
+ .sbb-pearl-chain__time-time {
101
+ --sbb-text-font-size: var(--sbb-font-size-text-s);
102
+ font-family: var(--sbb-typo-font-family);
103
+ font-weight: normal;
104
+ line-height: var(--sbb-typo-line-height-body-text);
105
+ letter-spacing: var(--sbb-typo-letter-spacing-body-text);
106
+ font-size: var(--sbb-text-font-size);
107
+ font-weight: bold;
108
+ color: var(--sbb-color-charcoal);
109
+ }
110
+
111
+ .sbb-screen-reader-only {
112
+ border: 0;
113
+ clip: rect(0 0 0 0);
114
+ height: 1px;
115
+ margin: -1px;
116
+ overflow: hidden;
117
+ padding: 0;
118
+ position: absolute;
119
+ white-space: nowrap;
120
+ width: 1px;
121
+ }`;
122
+ let SbbPearlChainTimeElement = (() => {
123
+ var _legs_accessor_storage, _departureTime_accessor_storage, _arrivalTime_accessor_storage, _departureWalk_accessor_storage, _arrivalWalk_accessor_storage, _disableAnimation_accessor_storage, _a11yFootpath_accessor_storage, _a;
124
+ let _classDecorators = [customElement("sbb-pearl-chain-time")];
125
+ let _classDescriptor;
126
+ let _classExtraInitializers = [];
127
+ let _classThis;
128
+ let _classSuper = LitElement;
129
+ let _instanceExtraInitializers = [];
130
+ let _legs_decorators;
131
+ let _legs_initializers = [];
132
+ let _legs_extraInitializers = [];
133
+ let _departureTime_decorators;
134
+ let _departureTime_initializers = [];
135
+ let _departureTime_extraInitializers = [];
136
+ let _arrivalTime_decorators;
137
+ let _arrivalTime_initializers = [];
138
+ let _arrivalTime_extraInitializers = [];
139
+ let _departureWalk_decorators;
140
+ let _departureWalk_initializers = [];
141
+ let _departureWalk_extraInitializers = [];
142
+ let _arrivalWalk_decorators;
143
+ let _arrivalWalk_initializers = [];
144
+ let _arrivalWalk_extraInitializers = [];
145
+ let _disableAnimation_decorators;
146
+ let _disableAnimation_initializers = [];
147
+ let _disableAnimation_extraInitializers = [];
148
+ let _a11yFootpath_decorators;
149
+ let _a11yFootpath_initializers = [];
150
+ let _a11yFootpath_extraInitializers = [];
151
+ let _set_now_decorators;
152
+ _a = class extends _classSuper {
153
+ constructor() {
154
+ super(...arguments);
155
+ __privateAdd(this, _legs_accessor_storage);
156
+ __privateAdd(this, _departureTime_accessor_storage);
157
+ __privateAdd(this, _arrivalTime_accessor_storage);
158
+ __privateAdd(this, _departureWalk_accessor_storage);
159
+ __privateAdd(this, _arrivalWalk_accessor_storage);
160
+ __privateAdd(this, _disableAnimation_accessor_storage);
161
+ __privateAdd(this, _a11yFootpath_accessor_storage);
162
+ __privateSet(this, _legs_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _legs_initializers, [])));
163
+ __privateSet(this, _departureTime_accessor_storage, (__runInitializers(this, _legs_extraInitializers), __runInitializers(this, _departureTime_initializers, "")));
164
+ __privateSet(this, _arrivalTime_accessor_storage, (__runInitializers(this, _departureTime_extraInitializers), __runInitializers(this, _arrivalTime_initializers, "")));
165
+ __privateSet(this, _departureWalk_accessor_storage, (__runInitializers(this, _arrivalTime_extraInitializers), __runInitializers(this, _departureWalk_initializers, NaN)));
166
+ __privateSet(this, _arrivalWalk_accessor_storage, (__runInitializers(this, _departureWalk_extraInitializers), __runInitializers(this, _arrivalWalk_initializers, NaN)));
167
+ __privateSet(this, _disableAnimation_accessor_storage, (__runInitializers(this, _arrivalWalk_extraInitializers), __runInitializers(this, _disableAnimation_initializers, false)));
168
+ __privateSet(this, _a11yFootpath_accessor_storage, (__runInitializers(this, _disableAnimation_extraInitializers), __runInitializers(this, _a11yFootpath_initializers, false)));
169
+ this._now = (__runInitializers(this, _a11yFootpath_extraInitializers), null);
170
+ this._language = new SbbLanguageController(this);
171
+ }
172
+ /**
173
+ * define the legs of the pearl-chain.
174
+ * Format:
175
+ * `{"legs": [{"duration": 25}, ...]}`
176
+ * `duration` in minutes. Duration of the leg is relative
177
+ * to the total travel time. Example: departure 16:30, change at 16:40,
178
+ * arrival at 17:00. So the change should have a duration of 33.33%.
179
+ */
180
+ get legs() {
181
+ return __privateGet(this, _legs_accessor_storage);
182
+ }
183
+ set legs(value) {
184
+ __privateSet(this, _legs_accessor_storage, value);
185
+ }
186
+ /** Prop to render the departure time - will be formatted as "H:mm" */
187
+ get departureTime() {
188
+ return __privateGet(this, _departureTime_accessor_storage);
189
+ }
190
+ set departureTime(value) {
191
+ __privateSet(this, _departureTime_accessor_storage, value);
192
+ }
193
+ /** Prop to render the arrival time - will be formatted as "H:mm" */
194
+ get arrivalTime() {
195
+ return __privateGet(this, _arrivalTime_accessor_storage);
196
+ }
197
+ set arrivalTime(value) {
198
+ __privateSet(this, _arrivalTime_accessor_storage, value);
199
+ }
200
+ /** Optional prop to render the walk time (in minutes) before departure */
201
+ get departureWalk() {
202
+ return __privateGet(this, _departureWalk_accessor_storage);
203
+ }
204
+ set departureWalk(value) {
205
+ __privateSet(this, _departureWalk_accessor_storage, value);
206
+ }
207
+ /** Optional prop to render the walk time (in minutes) after arrival */
208
+ get arrivalWalk() {
209
+ return __privateGet(this, _arrivalWalk_accessor_storage);
210
+ }
211
+ set arrivalWalk(value) {
212
+ __privateSet(this, _arrivalWalk_accessor_storage, value);
213
+ }
214
+ /**
215
+ * Per default, the current location has a pulsating animation. You can
216
+ * disable the animation with this property.
217
+ */
218
+ get disableAnimation() {
219
+ return __privateGet(this, _disableAnimation_accessor_storage);
220
+ }
221
+ set disableAnimation(value) {
222
+ __privateSet(this, _disableAnimation_accessor_storage, value);
223
+ }
224
+ /** Optional prop to render wheelchair-small instead of walk-small */
225
+ get a11yFootpath() {
226
+ return __privateGet(this, _a11yFootpath_accessor_storage);
227
+ }
228
+ set a11yFootpath(value) {
229
+ __privateSet(this, _a11yFootpath_accessor_storage, value);
230
+ }
231
+ /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */
232
+ set now(value) {
233
+ this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));
234
+ }
235
+ get now() {
236
+ return this._now ?? /* @__PURE__ */ new Date();
237
+ }
238
+ render() {
239
+ var _a2;
240
+ const departure = this.departureTime ? removeTimezoneFromISOTimeString(this.departureTime) : void 0;
241
+ const arrival = this.arrivalTime ? removeTimezoneFromISOTimeString(this.arrivalTime) : void 0;
242
+ const { renderDepartureTimeAttribute, renderArrivalTimeAttribute } = getDepartureArrivalTimeAttribute(this.legs, this.departureWalk || 0, this.arrivalWalk || 0, this._language.current, this.a11yFootpath);
243
+ const rideLegs = (_a2 = this.legs) == null ? void 0 : _a2.filter((leg) => isRideLeg(leg));
244
+ return html`
245
+ <div class="sbb-pearl-chain__time">
246
+ ${renderDepartureTimeAttribute()}
247
+ ${departure ? html`<time class="sbb-pearl-chain__time-time" datetime=${this.departureTime}>
248
+ <span class="sbb-screen-reader-only"
249
+ >${i18nDeparture[this._language.current]}:&nbsp;</span
250
+ >
251
+ ${format(departure, "HH:mm")}
252
+ </time>` : nothing}
253
+ ${(rideLegs == null ? void 0 : rideLegs.length) > 1 ? html`<span class="sbb-screen-reader-only" role="paragraph">
254
+ ${(rideLegs == null ? void 0 : rideLegs.length) - 1} ${i18nTransferProcedures[this._language.current]}
255
+ </span>` : nothing}
256
+ <sbb-pearl-chain
257
+ class="sbb-pearl-chain__time-chain"
258
+ .legs=${this.legs}
259
+ .disableAnimation=${this.disableAnimation}
260
+ .now=${this.now}
261
+ ></sbb-pearl-chain>
262
+ ${arrival ? html`<time class="sbb-pearl-chain__time-time" datetime=${this.arrivalTime}>
263
+ <span class="sbb-screen-reader-only"
264
+ >${i18nArrival[this._language.current]}:&nbsp;</span
265
+ >
266
+ ${format(arrival, "HH:mm")}
267
+ </time>` : nothing}
268
+ ${renderArrivalTimeAttribute()}
269
+ </div>
270
+ `;
271
+ }
272
+ }, _legs_accessor_storage = new WeakMap(), _departureTime_accessor_storage = new WeakMap(), _arrivalTime_accessor_storage = new WeakMap(), _departureWalk_accessor_storage = new WeakMap(), _arrivalWalk_accessor_storage = new WeakMap(), _disableAnimation_accessor_storage = new WeakMap(), _a11yFootpath_accessor_storage = new WeakMap(), _classThis = _a, (() => {
273
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
274
+ _legs_decorators = [property({ type: Array })];
275
+ _departureTime_decorators = [forceType(), property({ attribute: "departure-time" })];
276
+ _arrivalTime_decorators = [forceType(), property({ attribute: "arrival-time" })];
277
+ _departureWalk_decorators = [forceType(), property({ attribute: "departure-walk", type: Number })];
278
+ _arrivalWalk_decorators = [forceType(), property({ attribute: "arrival-walk", type: Number })];
279
+ _disableAnimation_decorators = [forceType(), property({ attribute: "disable-animation", type: Boolean })];
280
+ _a11yFootpath_decorators = [forceType(), property({ attribute: "a11y-footpath", type: Boolean })];
281
+ _set_now_decorators = [property()];
282
+ __esDecorate(_a, null, _legs_decorators, { kind: "accessor", name: "legs", static: false, private: false, access: { has: (obj) => "legs" in obj, get: (obj) => obj.legs, set: (obj, value) => {
283
+ obj.legs = value;
284
+ } }, metadata: _metadata }, _legs_initializers, _legs_extraInitializers);
285
+ __esDecorate(_a, null, _departureTime_decorators, { kind: "accessor", name: "departureTime", static: false, private: false, access: { has: (obj) => "departureTime" in obj, get: (obj) => obj.departureTime, set: (obj, value) => {
286
+ obj.departureTime = value;
287
+ } }, metadata: _metadata }, _departureTime_initializers, _departureTime_extraInitializers);
288
+ __esDecorate(_a, null, _arrivalTime_decorators, { kind: "accessor", name: "arrivalTime", static: false, private: false, access: { has: (obj) => "arrivalTime" in obj, get: (obj) => obj.arrivalTime, set: (obj, value) => {
289
+ obj.arrivalTime = value;
290
+ } }, metadata: _metadata }, _arrivalTime_initializers, _arrivalTime_extraInitializers);
291
+ __esDecorate(_a, null, _departureWalk_decorators, { kind: "accessor", name: "departureWalk", static: false, private: false, access: { has: (obj) => "departureWalk" in obj, get: (obj) => obj.departureWalk, set: (obj, value) => {
292
+ obj.departureWalk = value;
293
+ } }, metadata: _metadata }, _departureWalk_initializers, _departureWalk_extraInitializers);
294
+ __esDecorate(_a, null, _arrivalWalk_decorators, { kind: "accessor", name: "arrivalWalk", static: false, private: false, access: { has: (obj) => "arrivalWalk" in obj, get: (obj) => obj.arrivalWalk, set: (obj, value) => {
295
+ obj.arrivalWalk = value;
296
+ } }, metadata: _metadata }, _arrivalWalk_initializers, _arrivalWalk_extraInitializers);
297
+ __esDecorate(_a, null, _disableAnimation_decorators, { kind: "accessor", name: "disableAnimation", static: false, private: false, access: { has: (obj) => "disableAnimation" in obj, get: (obj) => obj.disableAnimation, set: (obj, value) => {
298
+ obj.disableAnimation = value;
299
+ } }, metadata: _metadata }, _disableAnimation_initializers, _disableAnimation_extraInitializers);
300
+ __esDecorate(_a, null, _a11yFootpath_decorators, { kind: "accessor", name: "a11yFootpath", static: false, private: false, access: { has: (obj) => "a11yFootpath" in obj, get: (obj) => obj.a11yFootpath, set: (obj, value) => {
301
+ obj.a11yFootpath = value;
302
+ } }, metadata: _metadata }, _a11yFootpath_initializers, _a11yFootpath_extraInitializers);
303
+ __esDecorate(_a, null, _set_now_decorators, { kind: "setter", name: "now", static: false, private: false, access: { has: (obj) => "now" in obj, set: (obj, value) => {
304
+ obj.now = value;
305
+ } }, metadata: _metadata }, null, _instanceExtraInitializers);
306
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
307
+ _classThis = _classDescriptor.value;
308
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
309
+ })(), _a.styles = style, __runInitializers(_classThis, _classExtraInitializers), _a;
310
+ return _classThis;
311
+ })();
312
+ export {
313
+ SbbPearlChainTimeElement
314
+ };
315
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain-time.js","sources":["../../../../src/elements-experimental/pearl-chain-time/pearl-chain-time.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport {\n  i18nArrival,\n  i18nDeparture,\n  i18nTransferProcedures,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain-time.scss?lit&inline';\n\nimport '../pearl-chain.js';\n\n/**\n * Combined with `sbb-pearl-chain`, it displays walk time information.\n */\nexport\n@customElement('sbb-pearl-chain-time')\nclass SbbPearlChainTimeElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * define the legs of the pearl-chain.\n   * Format:\n   * `{\"legs\": [{\"duration\": 25}, ...]}`\n   * `duration` in minutes. Duration of the leg is relative\n   * to the total travel time. Example: departure 16:30, change at 16:40,\n   * arrival at 17:00. So the change should have a duration of 33.33%.\n   */\n  @property({ type: Array }) public accessor legs: (Leg | PtRideLeg)[] = [];\n\n  /** Prop to render the departure time - will be formatted as \"H:mm\" */\n  @forceType()\n  @property({ attribute: 'departure-time' })\n  public accessor departureTime: string = '';\n\n  /** Prop to render the arrival time - will be formatted as \"H:mm\" */\n  @forceType()\n  @property({ attribute: 'arrival-time' })\n  public accessor arrivalTime: string = '';\n\n  /** Optional prop to render the walk time (in minutes) before departure */\n  @forceType()\n  @property({ attribute: 'departure-walk', type: Number })\n  public accessor departureWalk: number = NaN;\n\n  /** Optional prop to render the walk time (in minutes) after arrival */\n  @forceType()\n  @property({ attribute: 'arrival-walk', type: Number })\n  public accessor arrivalWalk: number = NaN;\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @forceType()\n  @property({ attribute: 'disable-animation', type: Boolean })\n  public accessor disableAnimation: boolean = false;\n\n  /** Optional prop to render wheelchair-small instead of walk-small */\n  @forceType()\n  @property({ attribute: 'a11y-footpath', type: Boolean })\n  public accessor a11yFootpath: boolean = false;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override render(): TemplateResult {\n    const departure: Date | undefined = this.departureTime\n      ? removeTimezoneFromISOTimeString(this.departureTime)\n      : undefined;\n    const arrival: Date | undefined = this.arrivalTime\n      ? removeTimezoneFromISOTimeString(this.arrivalTime)\n      : undefined;\n\n    const { renderDepartureTimeAttribute, renderArrivalTimeAttribute } =\n      getDepartureArrivalTimeAttribute(\n        this.legs,\n        this.departureWalk || 0,\n        this.arrivalWalk || 0,\n        this._language.current,\n        this.a11yFootpath,\n      );\n\n    const rideLegs = this.legs?.filter((leg) => isRideLeg(leg));\n    return html`\n      <div class=\"sbb-pearl-chain__time\">\n        ${renderDepartureTimeAttribute()}\n        ${departure\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.departureTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nDeparture[this._language.current]}:&nbsp;</span\n              >\n              ${format(departure, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${rideLegs?.length > 1\n          ? html`<span class=\"sbb-screen-reader-only\" role=\"paragraph\">\n              ${rideLegs?.length - 1} ${i18nTransferProcedures[this._language.current]}\n            </span>`\n          : nothing}\n        <sbb-pearl-chain\n          class=\"sbb-pearl-chain__time-chain\"\n          .legs=${this.legs}\n          .disableAnimation=${this.disableAnimation}\n          .now=${this.now}\n        ></sbb-pearl-chain>\n        ${arrival\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.arrivalTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nArrival[this._language.current]}:&nbsp;</span\n              >\n              ${format(arrival, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${renderArrivalTimeAttribute()}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain-time': SbbPearlChainTimeElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
@@ -1,2 +1,5 @@
1
+ /**
2
+ * @entrypoint
3
+ */
1
4
  export * from './pearl-chain-time/pearl-chain-time.js';
2
5
  //# sourceMappingURL=pearl-chain-time.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"pearl-chain-time.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain-time.ts"],"names":[],"mappings":"AAAA,cAAc,wCAAwC,CAAC"}
1
+ {"version":3,"file":"pearl-chain-time.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain-time.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,wCAAwC,CAAC"}