@sbb-esta/lyne-elements-experimental 1.13.0 → 1.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/datetime.js +3 -9
- package/core/timetable.js +10 -64
- package/custom-elements.json +90 -40
- package/development/core/datetime.js +4 -10
- package/development/core/timetable.js +11 -65
- package/development/differenceInMinutes-Cmyza6nm.js +1 -1
- package/development/format-DTy5_IOt.js +1 -1
- package/development/isValid-DO_pHwcW.js +1 -1
- package/development/journey-summary/journey-summary.d.ts +6 -6
- package/development/journey-summary/journey-summary.d.ts.map +1 -1
- package/development/journey-summary.js +180 -82
- package/development/pearl-chain/pearl-chain.d.ts +2 -2
- package/development/pearl-chain/pearl-chain.d.ts.map +1 -1
- package/development/pearl-chain-time/pearl-chain-time.d.ts +7 -7
- package/development/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
- package/development/pearl-chain-time.js +176 -68
- package/development/pearl-chain-vertical/pearl-chain-vertical.d.ts.map +1 -1
- package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts +2 -2
- package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts.map +1 -1
- package/development/pearl-chain-vertical-item.js +67 -30
- package/development/pearl-chain-vertical.js +22 -21
- package/development/pearl-chain.js +210 -166
- package/development/timetable-duration/timetable-duration.d.ts +1 -1
- package/development/timetable-duration/timetable-duration.d.ts.map +1 -1
- package/development/timetable-duration.js +72 -45
- package/development/timetable-row/timetable-row.d.ts +10 -10
- package/development/timetable-row/timetable-row.d.ts.map +1 -1
- package/development/timetable-row.js +337 -205
- package/journey-summary/journey-summary.d.ts +6 -6
- package/journey-summary/journey-summary.d.ts.map +1 -1
- package/journey-summary.js +156 -100
- package/package.json +4 -3
- package/pearl-chain/pearl-chain.d.ts +2 -2
- package/pearl-chain/pearl-chain.d.ts.map +1 -1
- package/pearl-chain-time/pearl-chain-time.d.ts +7 -7
- package/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
- package/pearl-chain-time.js +137 -78
- package/pearl-chain-vertical/pearl-chain-vertical.d.ts.map +1 -1
- package/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts +2 -2
- package/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts.map +1 -1
- package/pearl-chain-vertical-item.js +57 -34
- package/pearl-chain-vertical.js +17 -18
- package/pearl-chain.js +156 -131
- package/timetable-duration/timetable-duration.d.ts +1 -1
- package/timetable-duration/timetable-duration.d.ts.map +1 -1
- package/timetable-duration.js +48 -30
- package/timetable-row/timetable-row.d.ts +10 -10
- package/timetable-row/timetable-row.d.ts.map +1 -1
- package/timetable-row.js +331 -267
|
@@ -1,6 +1,15 @@
|
|
|
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";
|
|
1
9
|
import { defaultDateAdapter } from "@sbb-esta/lyne-elements/core/datetime.js";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
10
|
+
import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
|
|
11
|
+
import { css, html, nothing, LitElement } from "lit";
|
|
12
|
+
import { customElement, property } from "lit/decorators.js";
|
|
4
13
|
import { styleMap } from "lit/directives/style-map.js";
|
|
5
14
|
import { removeTimezoneFromISOTimeString } from "./core/datetime.js";
|
|
6
15
|
import { isRideLeg } from "./core/timetable.js";
|
|
@@ -403,203 +412,238 @@ const style = css`*,
|
|
|
403
412
|
white-space: nowrap;
|
|
404
413
|
width: 1px;
|
|
405
414
|
}`;
|
|
406
|
-
|
|
407
|
-
var
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
let
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
415
|
+
let SbbPearlChainElement = (() => {
|
|
416
|
+
var _legs_accessor_storage, _disableAnimation_accessor_storage, _a;
|
|
417
|
+
let _classDecorators = [customElement("sbb-pearl-chain")];
|
|
418
|
+
let _classDescriptor;
|
|
419
|
+
let _classExtraInitializers = [];
|
|
420
|
+
let _classThis;
|
|
421
|
+
let _classSuper = LitElement;
|
|
422
|
+
let _instanceExtraInitializers = [];
|
|
423
|
+
let _legs_decorators;
|
|
424
|
+
let _legs_initializers = [];
|
|
425
|
+
let _legs_extraInitializers = [];
|
|
426
|
+
let _disableAnimation_decorators;
|
|
427
|
+
let _disableAnimation_initializers = [];
|
|
428
|
+
let _disableAnimation_extraInitializers = [];
|
|
429
|
+
let _set_now_decorators;
|
|
430
|
+
_a = class extends _classSuper {
|
|
431
|
+
constructor() {
|
|
432
|
+
super(...arguments);
|
|
433
|
+
__privateAdd(this, _legs_accessor_storage);
|
|
434
|
+
__privateAdd(this, _disableAnimation_accessor_storage);
|
|
435
|
+
__privateSet(this, _legs_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _legs_initializers, [])));
|
|
436
|
+
__privateSet(this, _disableAnimation_accessor_storage, (__runInitializers(this, _legs_extraInitializers), __runInitializers(this, _disableAnimation_initializers, false)));
|
|
437
|
+
this._now = (__runInitializers(this, _disableAnimation_extraInitializers), null);
|
|
438
|
+
}
|
|
439
|
+
/**
|
|
440
|
+
* Define the legs of the pearl-chain.
|
|
441
|
+
* Format:
|
|
442
|
+
* `{"legs": [{"duration": 25}, ...]}`
|
|
443
|
+
* `duration` in minutes. Duration of the leg is relative
|
|
444
|
+
* to the total travel time. Example: departure 16:30, change at 16:40,
|
|
445
|
+
* arrival at 17:00. So the change should have a duration of 33.33%.
|
|
446
|
+
*/
|
|
447
|
+
get legs() {
|
|
448
|
+
return __privateGet(this, _legs_accessor_storage);
|
|
449
|
+
}
|
|
450
|
+
set legs(value) {
|
|
451
|
+
__privateSet(this, _legs_accessor_storage, value);
|
|
452
|
+
}
|
|
453
|
+
/**
|
|
454
|
+
* Per default, the current location has a pulsating animation. You can
|
|
455
|
+
* disable the animation with this property.
|
|
456
|
+
*/
|
|
457
|
+
get disableAnimation() {
|
|
458
|
+
return __privateGet(this, _disableAnimation_accessor_storage);
|
|
459
|
+
}
|
|
460
|
+
set disableAnimation(value) {
|
|
461
|
+
__privateSet(this, _disableAnimation_accessor_storage, value);
|
|
462
|
+
}
|
|
463
|
+
/** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */
|
|
464
|
+
set now(value) {
|
|
465
|
+
this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));
|
|
466
|
+
}
|
|
467
|
+
get now() {
|
|
468
|
+
return this._now;
|
|
469
|
+
}
|
|
470
|
+
_getAllDuration(legs) {
|
|
471
|
+
return legs == null ? void 0 : legs.reduce((sum, leg) => {
|
|
472
|
+
var _a2, _b;
|
|
473
|
+
const arrivalNoTz = removeTimezoneFromISOTimeString((_a2 = leg.arrival) == null ? void 0 : _a2.time);
|
|
474
|
+
const departureNoTz = removeTimezoneFromISOTimeString((_b = leg.departure) == null ? void 0 : _b.time);
|
|
475
|
+
if (arrivalNoTz && departureNoTz) {
|
|
476
|
+
return sum + differenceInMinutes(removeTimezoneFromISOTimeString(leg.arrival.time), removeTimezoneFromISOTimeString(leg.departure.time));
|
|
477
|
+
}
|
|
478
|
+
return sum;
|
|
479
|
+
}, 0);
|
|
480
|
+
}
|
|
481
|
+
_isAllCancelled(legs) {
|
|
482
|
+
return legs == null ? void 0 : legs.every((leg) => {
|
|
483
|
+
var _a2, _b;
|
|
484
|
+
return (_b = (_a2 = leg == null ? void 0 : leg.serviceJourney) == null ? void 0 : _a2.serviceAlteration) == null ? void 0 : _b.cancelled;
|
|
485
|
+
});
|
|
486
|
+
}
|
|
487
|
+
_getRelativeDuration(legs, leg) {
|
|
488
|
+
var _a2, _b;
|
|
489
|
+
const arrivalNoTz = removeTimezoneFromISOTimeString((_a2 = leg.arrival) == null ? void 0 : _a2.time);
|
|
431
490
|
const departureNoTz = removeTimezoneFromISOTimeString((_b = leg.departure) == null ? void 0 : _b.time);
|
|
432
491
|
if (arrivalNoTz && departureNoTz) {
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
}, 0);
|
|
440
|
-
}
|
|
441
|
-
_isAllCancelled(legs) {
|
|
442
|
-
return legs == null ? void 0 : legs.every((leg) => {
|
|
443
|
-
var _a, _b;
|
|
444
|
-
return (_b = (_a = leg == null ? void 0 : leg.serviceJourney) == null ? void 0 : _a.serviceAlteration) == null ? void 0 : _b.cancelled;
|
|
445
|
-
});
|
|
446
|
-
}
|
|
447
|
-
_getRelativeDuration(legs, leg) {
|
|
448
|
-
var _a, _b;
|
|
449
|
-
const arrivalNoTz = removeTimezoneFromISOTimeString((_a = leg.arrival) == null ? void 0 : _a.time);
|
|
450
|
-
const departureNoTz = removeTimezoneFromISOTimeString((_b = leg.departure) == null ? void 0 : _b.time);
|
|
451
|
-
if (arrivalNoTz && departureNoTz) {
|
|
452
|
-
const duration = differenceInMinutes(
|
|
453
|
-
removeTimezoneFromISOTimeString(leg.arrival.time),
|
|
454
|
-
removeTimezoneFromISOTimeString(leg.departure.time)
|
|
455
|
-
);
|
|
456
|
-
const allDurations = this._getAllDuration(legs);
|
|
457
|
-
if (allDurations === 0) {
|
|
458
|
-
return 100;
|
|
492
|
+
const duration = differenceInMinutes(removeTimezoneFromISOTimeString(leg.arrival.time), removeTimezoneFromISOTimeString(leg.departure.time));
|
|
493
|
+
const allDurations = this._getAllDuration(legs);
|
|
494
|
+
if (allDurations === 0) {
|
|
495
|
+
return 100;
|
|
496
|
+
}
|
|
497
|
+
return duration / allDurations * 100;
|
|
459
498
|
}
|
|
460
|
-
return duration / allDurations * 100;
|
|
461
|
-
}
|
|
462
|
-
return 0;
|
|
463
|
-
}
|
|
464
|
-
_getProgress(now, start, end) {
|
|
465
|
-
if (!(start == null ? void 0 : start.time) || !(end == null ? void 0 : end.time)) {
|
|
466
499
|
return 0;
|
|
467
500
|
}
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
if (startWithDelay && isBefore(startWithDelay, now) && endWithDelay && isAfter(endWithDelay, now)) {
|
|
478
|
-
return "progress";
|
|
479
|
-
} else if (endWithDelay && isBefore(endWithDelay, now)) {
|
|
480
|
-
return "past";
|
|
501
|
+
_getProgress(now, start, end) {
|
|
502
|
+
if (!(start == null ? void 0 : start.time) || !(end == null ? void 0 : end.time)) {
|
|
503
|
+
return 0;
|
|
504
|
+
}
|
|
505
|
+
const startWithDelay = addMinutes(start.time, start.delay ?? 0);
|
|
506
|
+
const endWithDelay = addMinutes(end.time, end.delay ?? 0);
|
|
507
|
+
const total = differenceInMinutes(endWithDelay, startWithDelay);
|
|
508
|
+
const progress = differenceInMinutes(now, startWithDelay);
|
|
509
|
+
return total && progress / total * 100;
|
|
481
510
|
}
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
511
|
+
_getStatus(now, start, end) {
|
|
512
|
+
const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);
|
|
513
|
+
const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);
|
|
514
|
+
if (startWithDelay && isBefore(startWithDelay, now) && endWithDelay && isAfter(endWithDelay, now)) {
|
|
515
|
+
return "progress";
|
|
516
|
+
} else if (endWithDelay && isBefore(endWithDelay, now)) {
|
|
517
|
+
return "past";
|
|
518
|
+
}
|
|
519
|
+
return "future";
|
|
520
|
+
}
|
|
521
|
+
_renderPosition(now, start, end) {
|
|
522
|
+
const currentPosition = this._getProgress(now, start, end);
|
|
523
|
+
if (currentPosition < 0 && currentPosition > 100)
|
|
524
|
+
return void 0;
|
|
525
|
+
const statusStyle = () => {
|
|
526
|
+
return {
|
|
527
|
+
"--sbb-pearl-chain-status-position": `${currentPosition}%`,
|
|
528
|
+
...currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}
|
|
529
|
+
};
|
|
491
530
|
};
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
return html`<span
|
|
531
|
+
const animation = this.disableAnimation ? "sbb-pearl-chain__position--no-animation" : "";
|
|
532
|
+
return html`<span
|
|
495
533
|
style=${styleMap(statusStyle())}
|
|
496
534
|
class="sbb-pearl-chain__position ${animation}"
|
|
497
535
|
></span>`;
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
+
}
|
|
537
|
+
render() {
|
|
538
|
+
var _a2, _b, _c, _d, _e;
|
|
539
|
+
const now = this.now ?? /* @__PURE__ */ new Date();
|
|
540
|
+
const rideLegs = (_a2 = this.legs) == null ? void 0 : _a2.filter((leg) => isRideLeg(leg));
|
|
541
|
+
const departureTime = (rideLegs == null ? void 0 : rideLegs.length) && removeTimezoneFromISOTimeString((_c = (_b = rideLegs[0]) == null ? void 0 : _b.departure) == null ? void 0 : _c.time);
|
|
542
|
+
const departureWithDelay = departureTime && {
|
|
543
|
+
time: departureTime,
|
|
544
|
+
delay: rideLegs[0].departure.delay ?? 0
|
|
545
|
+
};
|
|
546
|
+
const arrivalTime = (rideLegs == null ? void 0 : rideLegs.length) && removeTimezoneFromISOTimeString((_d = rideLegs[rideLegs.length - 1].arrival) == null ? void 0 : _d.time);
|
|
547
|
+
const arrivalTimeDelay = arrivalTime && {
|
|
548
|
+
time: arrivalTime,
|
|
549
|
+
delay: ((_e = rideLegs[rideLegs.length - 1]) == null ? void 0 : _e.arrival.delay) ?? 0
|
|
550
|
+
};
|
|
551
|
+
const departureNotServiced = (() => {
|
|
552
|
+
var _a3, _b2, _c2, _d2;
|
|
553
|
+
return rideLegs && ((_b2 = (_a3 = rideLegs[0]) == null ? void 0 : _a3.serviceJourney) == null ? void 0 : _b2.stopPoints) && ((_d2 = (_c2 = rideLegs[0]) == null ? void 0 : _c2.serviceJourney) == null ? void 0 : _d2.stopPoints[0].stopStatus) === "NOT_SERVICED" ? "sbb-pearl-chain--departure-skipped" : "";
|
|
554
|
+
})();
|
|
555
|
+
const arrivalNotServiced = (() => {
|
|
556
|
+
var _a3;
|
|
557
|
+
const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];
|
|
558
|
+
const stops = lastLeg && ((_a3 = lastLeg.serviceJourney) == null ? void 0 : _a3.stopPoints);
|
|
559
|
+
return stops && stops[stops.length - 1].stopStatus === "NOT_SERVICED" ? "sbb-pearl-chain--arrival-skipped" : "";
|
|
560
|
+
})();
|
|
561
|
+
const departureCancelClass = (() => {
|
|
562
|
+
var _a3, _b2, _c2;
|
|
563
|
+
return rideLegs && ((_c2 = (_b2 = (_a3 = rideLegs[0]) == null ? void 0 : _a3.serviceJourney) == null ? void 0 : _b2.serviceAlteration) == null ? void 0 : _c2.cancelled) ? "sbb-pearl-chain--departure-disruption" : "";
|
|
564
|
+
})();
|
|
565
|
+
const arrivalCancelClass = (() => {
|
|
566
|
+
var _a3, _b2, _c2;
|
|
567
|
+
return rideLegs && ((_c2 = (_b2 = (_a3 = rideLegs[rideLegs.length - 1]) == null ? void 0 : _a3.serviceJourney) == null ? void 0 : _b2.serviceAlteration) == null ? void 0 : _c2.cancelled) ? "sbb-pearl-chain--arrival-disruption" : "";
|
|
568
|
+
})();
|
|
569
|
+
const status = departureWithDelay && arrivalTimeDelay && this._getStatus(now, departureWithDelay, arrivalTimeDelay);
|
|
570
|
+
const statusClassDeparture = rideLegs && status && !departureCancelClass ? "sbb-pearl-chain__bullet--" + status : "";
|
|
571
|
+
const statusClassArrival = rideLegs && status && !arrivalCancelClass ? "sbb-pearl-chain__bullet--" + this._getStatus(now, void 0, arrivalTimeDelay) : "";
|
|
572
|
+
if (this._isAllCancelled(rideLegs)) {
|
|
573
|
+
return html`
|
|
536
574
|
<div class="sbb-pearl-chain">
|
|
537
575
|
<span class="sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption"></span>
|
|
538
576
|
<div class="sbb-pearl-chain__leg sbb-pearl-chain__leg--disruption"></div>
|
|
539
577
|
<span class="sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption"></span>
|
|
540
578
|
</div>
|
|
541
579
|
`;
|
|
542
|
-
|
|
543
|
-
|
|
580
|
+
}
|
|
581
|
+
return html`
|
|
544
582
|
<div class="sbb-pearl-chain">
|
|
545
583
|
<span
|
|
546
584
|
class="sbb-pearl-chain__bullet ${statusClassDeparture} ${departureNotServiced} ${departureCancelClass}"
|
|
547
585
|
></span>
|
|
548
586
|
${rideLegs == null ? void 0 : rideLegs.map((leg, index) => {
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
587
|
+
var _a3, _b2, _c2, _d2, _e2, _f, _g, _h;
|
|
588
|
+
const { stopPoints, serviceAlteration } = (leg == null ? void 0 : leg.serviceJourney) || {};
|
|
589
|
+
const duration = this._getRelativeDuration(rideLegs, leg);
|
|
590
|
+
const departure = removeTimezoneFromISOTimeString((_a3 = leg.departure) == null ? void 0 : _a3.time);
|
|
591
|
+
const arrival = removeTimezoneFromISOTimeString((_b2 = leg.arrival) == null ? void 0 : _b2.time);
|
|
592
|
+
const isArrivalNotServiced = stopPoints && ((_c2 = stopPoints[stopPoints.length - 1]) == null ? void 0 : _c2.stopStatus) === "NOT_SERVICED";
|
|
593
|
+
const isArrivalPlanned = stopPoints && ((_d2 = stopPoints[stopPoints.length - 1]) == null ? void 0 : _d2.stopStatus) === "PLANNED";
|
|
594
|
+
const isDepartureNotServiced = stopPoints && ((_e2 = stopPoints[0]) == null ? void 0 : _e2.stopStatus) === "NOT_SERVICED";
|
|
595
|
+
const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;
|
|
596
|
+
const isBeforeLegArrivalNotServiced = stopPointsBefore && ((_f = stopPointsBefore[stopPointsBefore.length - 1]) == null ? void 0 : _f.stopStatus) === "NOT_SERVICED";
|
|
597
|
+
const skippedLeg = isArrivalNotServiced || isDepartureNotServiced && isArrivalPlanned ? "sbb-pearl-chain__leg--skipped" : "";
|
|
598
|
+
const departureSkippedBullet = isDepartureNotServiced || isBeforeLegArrivalNotServiced ? "sbb-pearl-chain__stop--departure-skipped" : "";
|
|
599
|
+
const cancelled = (serviceAlteration == null ? void 0 : serviceAlteration.cancelled) ? "sbb-pearl-chain__leg--disruption" : "";
|
|
600
|
+
const legDepartureWithDelay = { time: departure, delay: ((_g = leg.departure) == null ? void 0 : _g.delay) ?? 0 };
|
|
601
|
+
const legArrivalWithDelay = { time: arrival, delay: ((_h = leg.arrival) == null ? void 0 : _h.delay) ?? 0 };
|
|
602
|
+
const status2 = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);
|
|
603
|
+
const legStatus = !cancelled && !skippedLeg && "sbb-pearl-chain__leg--" + status2;
|
|
604
|
+
const legStyle = () => {
|
|
605
|
+
return {
|
|
606
|
+
"--sbb-pearl-chain-leg-width": `${duration}%`,
|
|
607
|
+
...status2 === "progress" && !cancelled && !skippedLeg ? {
|
|
608
|
+
"--sbb-pearl-chain-leg-status": `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`
|
|
609
|
+
} : {}
|
|
610
|
+
};
|
|
572
611
|
};
|
|
573
|
-
|
|
574
|
-
return html` <div
|
|
612
|
+
return html` <div
|
|
575
613
|
class="sbb-pearl-chain__leg ${legStatus || ""} ${cancelled} ${skippedLeg}"
|
|
576
614
|
style=${styleMap(legStyle())}
|
|
577
615
|
>
|
|
578
616
|
${index > 0 && index < rideLegs.length ? html`<span class="sbb-pearl-chain__stop ${departureSkippedBullet}"></span>` : nothing}
|
|
579
617
|
${status2 === "progress" && !cancelled && !skippedLeg ? this._renderPosition(now, legDepartureWithDelay, legArrivalWithDelay) : nothing}
|
|
580
618
|
</div>`;
|
|
581
|
-
|
|
619
|
+
})}
|
|
582
620
|
<span
|
|
583
621
|
class="sbb-pearl-chain__bullet ${statusClassArrival} ${arrivalNotServiced} ${arrivalCancelClass}"
|
|
584
622
|
></span>
|
|
585
623
|
</div>
|
|
586
624
|
`;
|
|
587
|
-
|
|
588
|
-
}
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
625
|
+
}
|
|
626
|
+
}, _legs_accessor_storage = new WeakMap(), _disableAnimation_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
627
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
628
|
+
_legs_decorators = [property({ type: Array })];
|
|
629
|
+
_disableAnimation_decorators = [forceType(), property({ attribute: "disable-animation", type: Boolean })];
|
|
630
|
+
_set_now_decorators = [property()];
|
|
631
|
+
__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) => {
|
|
632
|
+
obj.legs = value;
|
|
633
|
+
} }, metadata: _metadata }, _legs_initializers, _legs_extraInitializers);
|
|
634
|
+
__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) => {
|
|
635
|
+
obj.disableAnimation = value;
|
|
636
|
+
} }, metadata: _metadata }, _disableAnimation_initializers, _disableAnimation_extraInitializers);
|
|
637
|
+
__esDecorate(_a, null, _set_now_decorators, { kind: "setter", name: "now", static: false, private: false, access: { has: (obj) => "now" in obj, set: (obj, value) => {
|
|
638
|
+
obj.now = value;
|
|
639
|
+
} }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
640
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
641
|
+
_classThis = _classDescriptor.value;
|
|
642
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
643
|
+
})(), _a.styles = style, __runInitializers(_classThis, _classExtraInitializers), _a;
|
|
644
|
+
return _classThis;
|
|
645
|
+
})();
|
|
602
646
|
export {
|
|
603
647
|
SbbPearlChainElement
|
|
604
648
|
};
|
|
605
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.js","../../../node_modules/date-fns/isBefore.js","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.js\";\n\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * @param date - The date that should be after the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is after the second date\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\nexport function isAfter(date, dateToCompare) {\n  return +toDate(date) > +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * @param date - The date that should be before the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is before the second date\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\nexport function isBefore(date, dateToCompare) {\n  return +toDate(date) < +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\n","import { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { addMinutes, differenceInMinutes, isAfter, isBefore } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain.scss?lit&inline';\n\ntype Status = 'progress' | 'future' | 'past';\ntype Time = {\n  time?: Date;\n  delay: number;\n};\n\n/**\n * It visually displays journey information.\n */\n@customElement('sbb-pearl-chain')\nexport class SbbPearlChainElement 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 legs?: (Leg | PtRideLeg)[];\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\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 | null {\n    return this._now;\n  }\n  private _now: Date | null = null;\n\n  private _getAllDuration(legs: PtRideLeg[]): number {\n    return legs?.reduce((sum: number, leg) => {\n      const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n      const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n      if (arrivalNoTz && departureNoTz) {\n        return (\n          sum +\n          differenceInMinutes(\n            removeTimezoneFromISOTimeString(leg.arrival.time)!,\n            removeTimezoneFromISOTimeString(leg.departure.time)!,\n          )\n        );\n      }\n      return sum;\n    }, 0);\n  }\n\n  private _isAllCancelled(legs: PtRideLeg[]): boolean {\n    return legs?.every((leg) => leg?.serviceJourney?.serviceAlteration?.cancelled);\n  }\n\n  private _getRelativeDuration(legs: PtRideLeg[], leg: PtRideLeg): number {\n    const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n    const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n    if (arrivalNoTz && departureNoTz) {\n      const duration = differenceInMinutes(\n        removeTimezoneFromISOTimeString(leg.arrival.time)!,\n        removeTimezoneFromISOTimeString(leg.departure.time)!,\n      );\n      const allDurations = this._getAllDuration(legs);\n\n      if (allDurations === 0) {\n        return 100;\n      }\n\n      return (duration / allDurations) * 100;\n    }\n    return 0;\n  }\n\n  private _getProgress(now: Date, start?: Time, end?: Time): number {\n    if (!start?.time || !end?.time) {\n      return 0;\n    }\n\n    const startWithDelay = addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = addMinutes(end.time, end.delay ?? 0);\n    const total = differenceInMinutes(endWithDelay, startWithDelay);\n    const progress = differenceInMinutes(now, startWithDelay);\n\n    return total && (progress / total) * 100;\n  }\n\n  private _getStatus(now: Date, start?: Time, end?: Time): Status {\n    const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);\n\n    if (\n      startWithDelay &&\n      isBefore(startWithDelay, now) &&\n      endWithDelay &&\n      isAfter(endWithDelay, now)\n    ) {\n      return 'progress';\n    } else if (endWithDelay && isBefore(endWithDelay, now)) {\n      return 'past';\n    }\n    return 'future';\n  }\n\n  private _renderPosition(now: Date, start?: Time, end?: Time): TemplateResult | undefined {\n    const currentPosition = this._getProgress(now, start, end);\n    if (currentPosition < 0 && currentPosition > 100) return undefined;\n\n    const statusStyle = (): Record<string, string> => {\n      return {\n        '--sbb-pearl-chain-status-position': `${currentPosition}%`,\n        ...(currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}),\n      };\n    };\n\n    const animation = this.disableAnimation ? 'sbb-pearl-chain__position--no-animation' : '';\n\n    return html`<span\n      style=${styleMap(statusStyle())}\n      class=\"sbb-pearl-chain__position ${animation}\"\n    ></span>`;\n  }\n\n  protected override render(): TemplateResult {\n    const now = this.now ?? new Date();\n\n    const rideLegs: PtRideLeg[] = this.legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n\n    const departureTime =\n      rideLegs?.length && removeTimezoneFromISOTimeString(rideLegs[0]?.departure?.time);\n    const departureWithDelay = departureTime && {\n      time: departureTime,\n      delay: rideLegs[0].departure.delay ?? 0,\n    };\n\n    const arrivalTime =\n      rideLegs?.length &&\n      removeTimezoneFromISOTimeString(rideLegs[rideLegs.length - 1].arrival?.time);\n    const arrivalTimeDelay = arrivalTime && {\n      time: arrivalTime,\n      delay: rideLegs[rideLegs.length - 1]?.arrival.delay ?? 0,\n    };\n\n    const departureNotServiced = ((): string => {\n      return rideLegs &&\n        rideLegs[0]?.serviceJourney?.stopPoints &&\n        rideLegs[0]?.serviceJourney?.stopPoints[0].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--departure-skipped'\n        : '';\n    })();\n\n    const arrivalNotServiced = ((): string => {\n      const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];\n      const stops = lastLeg && lastLeg.serviceJourney?.stopPoints;\n\n      return stops && stops[stops.length - 1].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--arrival-skipped'\n        : '';\n    })();\n\n    const departureCancelClass = ((): string => {\n      return rideLegs && rideLegs[0]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--departure-disruption'\n        : '';\n    })();\n\n    const arrivalCancelClass = ((): string => {\n      return rideLegs && rideLegs[rideLegs.length - 1]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--arrival-disruption'\n        : '';\n    })();\n\n    const status =\n      departureWithDelay &&\n      arrivalTimeDelay &&\n      this._getStatus(now, departureWithDelay, arrivalTimeDelay);\n\n    const statusClassDeparture =\n      rideLegs && status && !departureCancelClass ? 'sbb-pearl-chain__bullet--' + status : '';\n\n    const statusClassArrival =\n      rideLegs && status && !arrivalCancelClass\n        ? 'sbb-pearl-chain__bullet--' + this._getStatus(now, undefined, arrivalTimeDelay)\n        : '';\n\n    if (this._isAllCancelled(rideLegs)) {\n      return html`\n        <div class=\"sbb-pearl-chain\">\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n          <div class=\"sbb-pearl-chain__leg sbb-pearl-chain__leg--disruption\"></div>\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n        </div>\n      `;\n    }\n\n    return html`\n      <div class=\"sbb-pearl-chain\">\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassDeparture} ${departureNotServiced} ${departureCancelClass}\"\n        ></span>\n        ${rideLegs?.map((leg: PtRideLeg, index: number) => {\n          const { stopPoints, serviceAlteration } = leg?.serviceJourney || {};\n\n          const duration = this._getRelativeDuration(rideLegs, leg);\n          const departure = removeTimezoneFromISOTimeString(leg.departure?.time);\n          const arrival = removeTimezoneFromISOTimeString(leg.arrival?.time);\n\n          const isArrivalNotServiced =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'NOT_SERVICED';\n          const isArrivalPlanned =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'PLANNED';\n          const isDepartureNotServiced = stopPoints && stopPoints[0]?.stopStatus === 'NOT_SERVICED';\n\n          const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;\n          const isBeforeLegArrivalNotServiced =\n            stopPointsBefore &&\n            stopPointsBefore[stopPointsBefore.length - 1]?.stopStatus === 'NOT_SERVICED';\n\n          const skippedLeg =\n            isArrivalNotServiced || (isDepartureNotServiced && isArrivalPlanned)\n              ? 'sbb-pearl-chain__leg--skipped'\n              : '';\n          const departureSkippedBullet =\n            isDepartureNotServiced || isBeforeLegArrivalNotServiced\n              ? 'sbb-pearl-chain__stop--departure-skipped'\n              : '';\n\n          const cancelled = serviceAlteration?.cancelled ? 'sbb-pearl-chain__leg--disruption' : '';\n\n          const legDepartureWithDelay = { time: departure, delay: leg.departure?.delay ?? 0 };\n          const legArrivalWithDelay = { time: arrival, delay: leg.arrival?.delay ?? 0 };\n          const status = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);\n\n          const legStatus = !cancelled && !skippedLeg && 'sbb-pearl-chain__leg--' + status;\n          const legStyle = (): Record<string, string> => {\n            return {\n              '--sbb-pearl-chain-leg-width': `${duration}%`,\n              ...(status === 'progress' && !cancelled && !skippedLeg\n                ? {\n                    '--sbb-pearl-chain-leg-status': `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`,\n                  }\n                : {}),\n            };\n          };\n\n          return html` <div\n            class=\"sbb-pearl-chain__leg ${legStatus || ''} ${cancelled} ${skippedLeg}\"\n            style=${styleMap(legStyle())}\n          >\n            ${index > 0 && index < rideLegs.length\n              ? html`<span class=\"sbb-pearl-chain__stop ${departureSkippedBullet}\"></span>`\n              : nothing}\n            ${status === 'progress' && !cancelled && !skippedLeg\n              ? this._renderPosition(now, legDepartureWithDelay, legArrivalWithDelay)\n              : nothing}\n          </div>`;\n        })}\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassArrival} ${arrivalNotServiced} ${arrivalCancelClass}\"\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain': SbbPearlChainElement;\n  }\n}\n"],"names":["_b","_a","_d","_c","_e","status"],"mappings":"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","x_google_ignoreList":[0,1]}
|
|
649
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.js","../../../node_modules/date-fns/isBefore.js","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.js\";\n\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * @param date - The date that should be after the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is after the second date\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\nexport function isAfter(date, dateToCompare) {\n  return +toDate(date) > +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.js\";\n\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * @param date - The date that should be before the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is before the second date\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\nexport function isBefore(date, dateToCompare) {\n  return +toDate(date) < +toDate(dateToCompare);\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\n","import { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { addMinutes, differenceInMinutes, isAfter, isBefore } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain.scss?lit&inline';\n\ntype Status = 'progress' | 'future' | 'past';\ntype Time = {\n  time?: Date;\n  delay: number;\n};\n\n/**\n * It visually displays journey information.\n */\nexport\n@customElement('sbb-pearl-chain')\nclass SbbPearlChainElement 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  /**\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  /** 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 | null {\n    return this._now;\n  }\n  private _now: Date | null = null;\n\n  private _getAllDuration(legs: PtRideLeg[]): number {\n    return legs?.reduce((sum: number, leg) => {\n      const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n      const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n      if (arrivalNoTz && departureNoTz) {\n        return (\n          sum +\n          differenceInMinutes(\n            removeTimezoneFromISOTimeString(leg.arrival.time)!,\n            removeTimezoneFromISOTimeString(leg.departure.time)!,\n          )\n        );\n      }\n      return sum;\n    }, 0);\n  }\n\n  private _isAllCancelled(legs: PtRideLeg[]): boolean {\n    return legs?.every((leg) => leg?.serviceJourney?.serviceAlteration?.cancelled);\n  }\n\n  private _getRelativeDuration(legs: PtRideLeg[], leg: PtRideLeg): number {\n    const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n    const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n    if (arrivalNoTz && departureNoTz) {\n      const duration = differenceInMinutes(\n        removeTimezoneFromISOTimeString(leg.arrival.time)!,\n        removeTimezoneFromISOTimeString(leg.departure.time)!,\n      );\n      const allDurations = this._getAllDuration(legs);\n\n      if (allDurations === 0) {\n        return 100;\n      }\n\n      return (duration / allDurations) * 100;\n    }\n    return 0;\n  }\n\n  private _getProgress(now: Date, start?: Time, end?: Time): number {\n    if (!start?.time || !end?.time) {\n      return 0;\n    }\n\n    const startWithDelay = addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = addMinutes(end.time, end.delay ?? 0);\n    const total = differenceInMinutes(endWithDelay, startWithDelay);\n    const progress = differenceInMinutes(now, startWithDelay);\n\n    return total && (progress / total) * 100;\n  }\n\n  private _getStatus(now: Date, start?: Time, end?: Time): Status {\n    const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);\n\n    if (\n      startWithDelay &&\n      isBefore(startWithDelay, now) &&\n      endWithDelay &&\n      isAfter(endWithDelay, now)\n    ) {\n      return 'progress';\n    } else if (endWithDelay && isBefore(endWithDelay, now)) {\n      return 'past';\n    }\n    return 'future';\n  }\n\n  private _renderPosition(now: Date, start?: Time, end?: Time): TemplateResult | undefined {\n    const currentPosition = this._getProgress(now, start, end);\n    if (currentPosition < 0 && currentPosition > 100) return undefined;\n\n    const statusStyle = (): Record<string, string> => {\n      return {\n        '--sbb-pearl-chain-status-position': `${currentPosition}%`,\n        ...(currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}),\n      };\n    };\n\n    const animation = this.disableAnimation ? 'sbb-pearl-chain__position--no-animation' : '';\n\n    return html`<span\n      style=${styleMap(statusStyle())}\n      class=\"sbb-pearl-chain__position ${animation}\"\n    ></span>`;\n  }\n\n  protected override render(): TemplateResult {\n    const now = this.now ?? new Date();\n\n    const rideLegs: PtRideLeg[] = this.legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n\n    const departureTime =\n      rideLegs?.length && removeTimezoneFromISOTimeString(rideLegs[0]?.departure?.time);\n    const departureWithDelay = departureTime && {\n      time: departureTime,\n      delay: rideLegs[0].departure.delay ?? 0,\n    };\n\n    const arrivalTime =\n      rideLegs?.length &&\n      removeTimezoneFromISOTimeString(rideLegs[rideLegs.length - 1].arrival?.time);\n    const arrivalTimeDelay = arrivalTime && {\n      time: arrivalTime,\n      delay: rideLegs[rideLegs.length - 1]?.arrival.delay ?? 0,\n    };\n\n    const departureNotServiced = ((): string => {\n      return rideLegs &&\n        rideLegs[0]?.serviceJourney?.stopPoints &&\n        rideLegs[0]?.serviceJourney?.stopPoints[0].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--departure-skipped'\n        : '';\n    })();\n\n    const arrivalNotServiced = ((): string => {\n      const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];\n      const stops = lastLeg && lastLeg.serviceJourney?.stopPoints;\n\n      return stops && stops[stops.length - 1].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--arrival-skipped'\n        : '';\n    })();\n\n    const departureCancelClass = ((): string => {\n      return rideLegs && rideLegs[0]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--departure-disruption'\n        : '';\n    })();\n\n    const arrivalCancelClass = ((): string => {\n      return rideLegs && rideLegs[rideLegs.length - 1]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--arrival-disruption'\n        : '';\n    })();\n\n    const status =\n      departureWithDelay &&\n      arrivalTimeDelay &&\n      this._getStatus(now, departureWithDelay, arrivalTimeDelay);\n\n    const statusClassDeparture =\n      rideLegs && status && !departureCancelClass ? 'sbb-pearl-chain__bullet--' + status : '';\n\n    const statusClassArrival =\n      rideLegs && status && !arrivalCancelClass\n        ? 'sbb-pearl-chain__bullet--' + this._getStatus(now, undefined, arrivalTimeDelay)\n        : '';\n\n    if (this._isAllCancelled(rideLegs)) {\n      return html`\n        <div class=\"sbb-pearl-chain\">\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n          <div class=\"sbb-pearl-chain__leg sbb-pearl-chain__leg--disruption\"></div>\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n        </div>\n      `;\n    }\n\n    return html`\n      <div class=\"sbb-pearl-chain\">\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassDeparture} ${departureNotServiced} ${departureCancelClass}\"\n        ></span>\n        ${rideLegs?.map((leg: PtRideLeg, index: number) => {\n          const { stopPoints, serviceAlteration } = leg?.serviceJourney || {};\n\n          const duration = this._getRelativeDuration(rideLegs, leg);\n          const departure = removeTimezoneFromISOTimeString(leg.departure?.time);\n          const arrival = removeTimezoneFromISOTimeString(leg.arrival?.time);\n\n          const isArrivalNotServiced =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'NOT_SERVICED';\n          const isArrivalPlanned =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'PLANNED';\n          const isDepartureNotServiced = stopPoints && stopPoints[0]?.stopStatus === 'NOT_SERVICED';\n\n          const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;\n          const isBeforeLegArrivalNotServiced =\n            stopPointsBefore &&\n            stopPointsBefore[stopPointsBefore.length - 1]?.stopStatus === 'NOT_SERVICED';\n\n          const skippedLeg =\n            isArrivalNotServiced || (isDepartureNotServiced && isArrivalPlanned)\n              ? 'sbb-pearl-chain__leg--skipped'\n              : '';\n          const departureSkippedBullet =\n            isDepartureNotServiced || isBeforeLegArrivalNotServiced\n              ? 'sbb-pearl-chain__stop--departure-skipped'\n              : '';\n\n          const cancelled = serviceAlteration?.cancelled ? 'sbb-pearl-chain__leg--disruption' : '';\n\n          const legDepartureWithDelay = { time: departure, delay: leg.departure?.delay ?? 0 };\n          const legArrivalWithDelay = { time: arrival, delay: leg.arrival?.delay ?? 0 };\n          const status = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);\n\n          const legStatus = !cancelled && !skippedLeg && 'sbb-pearl-chain__leg--' + status;\n          const legStyle = (): Record<string, string> => {\n            return {\n              '--sbb-pearl-chain-leg-width': `${duration}%`,\n              ...(status === 'progress' && !cancelled && !skippedLeg\n                ? {\n                    '--sbb-pearl-chain-leg-status': `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`,\n                  }\n                : {}),\n            };\n          };\n\n          return html` <div\n            class=\"sbb-pearl-chain__leg ${legStatus || ''} ${cancelled} ${skippedLeg}\"\n            style=${styleMap(legStyle())}\n          >\n            ${index > 0 && index < rideLegs.length\n              ? html`<span class=\"sbb-pearl-chain__stop ${departureSkippedBullet}\"></span>`\n              : nothing}\n            ${status === 'progress' && !cancelled && !skippedLeg\n              ? this._renderPosition(now, legDepartureWithDelay, legArrivalWithDelay)\n              : nothing}\n          </div>`;\n        })}\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassArrival} ${arrivalNotServiced} ${arrivalCancelClass}\"\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain': SbbPearlChainElement;\n  }\n}\n"],"names":["_a","_b","_d","_c","_e","status"],"mappings":";;;;;;;;;;;;;;;;;AAoBO,SAAS,QAAQ,MAAM,eAAe;AAC3C,SAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,aAAa;AAC9C;ACFO,SAAS,SAAS,MAAM,eAAe;AAC5C,SAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,aAAa;AAC9C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ICIM,wBAAoB,MAAA;;0BADzB,cAAc,iBAAiB,CAAC;;;;oBACE;;;;;;;;;AAAR,EAAA,mBAAQ,YAAU;AAAA;;AAWhB;AAQ3B;AAnBI,yBAAA,yBAAA,kBAAA,MAAA,0BAAA,GAWmE,kBAAA,MAAA,oBAAA,CAAA,CAAE;AAQzD,yBAAA,qCAAA,kBAAA,MAAA,uBAAA,GAAA,kBAAA,MAAA,gCAA4B,KAAK;AAUzC,WAAI,QAAA,kBAAA,MAAA,mCAAA,GAAgB;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAlBD,IAAgB,OAA+B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA/C,IAAgB,KAA+B,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQ1E,IAAgB,mBAAkC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAlD,IAAgB,iBAAkC,OAAA;AAAA,yBAAA,oCAAA;AAAA,IAAA;AAAA;AAAA,IAIlD,IAAW,IAAI,OAA8B;AAC3C,WAAK,OAAO,mBAAmB,mBAAmB,mBAAmB,YAAY,KAAK,CAAC;AAAA,IAAA;AAAA,IAEzF,IAAW,MAAG;AACZ,aAAO,KAAK;AAAA,IAAA;AAAA,IAIN,gBAAgB,MAAiB;AACvC,aAAO,6BAAM,OAAO,CAAC,KAAa,QAAO;;AACvC,cAAM,cAAc,iCAAgCA,MAAA,IAAI,YAAJ,gBAAAA,IAAa,IAAI;AACrE,cAAM,gBAAgB,iCAAgC,SAAI,cAAJ,mBAAe,IAAI;AACzE,YAAI,eAAe,eAAe;AAE9B,iBAAA,MACA,oBACE,gCAAgC,IAAI,QAAQ,IAAI,GAChD,gCAAgC,IAAI,UAAU,IAAI,CAAE;AAAA,QAAA;AAInD,eAAA;AAAA,SACN;AAAA,IAAC;AAAA,IAGE,gBAAgB,MAAiB;AACvC,aAAO,6BAAM,MAAM,CAAC,QAAQ;;AAAA,sBAAAA,MAAA,2BAAK,mBAAL,gBAAAA,IAAqB,sBAArB,mBAAwC;AAAA;AAAA,IAAS;AAAA,IAGvE,qBAAqB,MAAmB,KAAc;;AAC5D,YAAM,cAAc,iCAAgCA,MAAA,IAAI,YAAJ,gBAAAA,IAAa,IAAI;AACrE,YAAM,gBAAgB,iCAAgC,SAAI,cAAJ,mBAAe,IAAI;AACzE,UAAI,eAAe,eAAe;AAC1B,cAAA,WAAW,oBACf,gCAAgC,IAAI,QAAQ,IAAI,GAChD,gCAAgC,IAAI,UAAU,IAAI,CAAE;AAEhD,cAAA,eAAe,KAAK,gBAAgB,IAAI;AAE9C,YAAI,iBAAiB,GAAG;AACf,iBAAA;AAAA,QAAA;AAGT,eAAQ,WAAW,eAAgB;AAAA,MAAA;AAE9B,aAAA;AAAA,IAAA;AAAA,IAGD,aAAa,KAAW,OAAc,KAAU;AACtD,UAAI,EAAC,+BAAO,SAAQ,EAAC,2BAAK,OAAM;AACvB,eAAA;AAAA,MAAA;AAGT,YAAM,iBAAiB,WAAW,MAAM,MAAM,MAAM,SAAS,CAAC;AAC9D,YAAM,eAAe,WAAW,IAAI,MAAM,IAAI,SAAS,CAAC;AAClD,YAAA,QAAQ,oBAAoB,cAAc,cAAc;AACxD,YAAA,WAAW,oBAAoB,KAAK,cAAc;AAEjD,aAAA,SAAU,WAAW,QAAS;AAAA,IAAA;AAAA,IAG/B,WAAW,KAAW,OAAc,KAAU;AAC9C,YAAA,iBAAiB,SAAS,MAAM,QAAQ,WAAW,MAAM,MAAM,MAAM,SAAS,CAAC;AAC/E,YAAA,eAAe,OAAO,IAAI,QAAQ,WAAW,IAAI,MAAM,IAAI,SAAS,CAAC;AAGzE,UAAA,kBACA,SAAS,gBAAgB,GAAG,KAC5B,gBACA,QAAQ,cAAc,GAAG,GACzB;AACO,eAAA;AAAA,MACE,WAAA,gBAAgB,SAAS,cAAc,GAAG,GAAG;AAC/C,eAAA;AAAA,MAAA;AAEF,aAAA;AAAA,IAAA;AAAA,IAGD,gBAAgB,KAAW,OAAc,KAAU;AACzD,YAAM,kBAAkB,KAAK,aAAa,KAAK,OAAO,GAAG;AACrD,UAAA,kBAAkB,KAAK,kBAAkB;AAAY,eAAA;AAEzD,YAAM,cAAc,MAA6B;AACxC,eAAA;AAAA,UACL,qCAAqC,GAAG,eAAe;AAAA,UACvD,GAAI,mBAAmB,KAAK,EAAE,WAAW,oBAAA,IAAwB,CAAA;AAAA;MAErE;AAEM,YAAA,YAAY,KAAK,mBAAmB,4CAA4C;AAE/E,aAAA;AAAA,cACG,SAAS,aAAa,CAAC;AAAA,yCACI,SAAS;AAAA;AAAA,IAAA;AAAA,IAI7B,SAAM;;AACvB,YAAM,MAAM,KAAK,OAAO,oBAAI,KAAI;AAE1B,YAAA,YAAwBA,MAAA,KAAK,SAAL,gBAAAA,IAAW,OAAO,CAAC,QAAQ,UAAU,GAAG;AAEhE,YAAA,iBACJ,qCAAU,WAAU,iCAAgC,oBAAS,CAAC,MAAV,mBAAa,cAAb,mBAAwB,IAAI;AAClF,YAAM,qBAAqB,iBAAiB;AAAA,QAC1C,MAAM;AAAA,QACN,OAAO,SAAS,CAAC,EAAE,UAAU,SAAS;AAAA;AAGlC,YAAA,eACJ,qCAAU,WACV,iCAAgC,cAAS,SAAS,SAAS,CAAC,EAAE,YAA9B,mBAAuC,IAAI;AAC7E,YAAM,mBAAmB,eAAe;AAAA,QACtC,MAAM;AAAA,QACN,SAAO,cAAS,SAAS,SAAS,CAAC,MAA5B,mBAA+B,QAAQ,UAAS;AAAA;AAGzD,YAAM,wBAAwB,MAAa;;AACzC,eAAO,cACLC,OAAAD,MAAA,SAAS,CAAC,MAAV,gBAAAA,IAAa,mBAAb,gBAAAC,IAA6B,iBAC7BC,OAAAC,MAAA,SAAS,CAAC,MAAV,gBAAAA,IAAa,mBAAb,gBAAAD,IAA6B,WAAW,GAAG,gBAAe,iBACxD,uCACA;AAAA,MAAA;AAGN,YAAM,sBAAsB,MAAa;;AACvC,cAAM,UAAU,YAAY,SAAS,SAAS,SAAS,CAAC;AAClD,cAAA,QAAQ,aAAWF,MAAA,QAAQ,mBAAR,gBAAAA,IAAwB;AAE1C,eAAA,SAAS,MAAM,MAAM,SAAS,CAAC,EAAE,eAAe,iBACnD,qCACA;AAAA,MAAA;AAGN,YAAM,wBAAwB,MAAa;;AACzC,eAAO,cAAYG,OAAAF,OAAAD,MAAA,SAAS,CAAC,MAAV,gBAAAA,IAAa,mBAAb,gBAAAC,IAA6B,sBAA7B,gBAAAE,IAAgD,aAC/D,0CACA;AAAA,MAAA;AAGN,YAAM,sBAAsB,MAAa;;AAChC,eAAA,cAAYA,OAAAF,OAAAD,MAAA,SAAS,SAAS,SAAS,CAAC,MAA5B,gBAAAA,IAA+B,mBAA/B,gBAAAC,IAA+C,sBAA/C,gBAAAE,IAAkE,aACjF,wCACA;AAAA,MAAA;AAGN,YAAM,SACJ,sBACA,oBACA,KAAK,WAAW,KAAK,oBAAoB,gBAAgB;AAE3D,YAAM,uBACJ,YAAY,UAAU,CAAC,uBAAuB,8BAA8B,SAAS;AAEjF,YAAA,qBACJ,YAAY,UAAU,CAAC,qBACnB,8BAA8B,KAAK,WAAW,KAAK,QAAW,gBAAgB,IAC9E;AAEF,UAAA,KAAK,gBAAgB,QAAQ,GAAG;AAC3B,eAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAA;AASF,aAAA;AAAA;AAAA;AAAA,2CAGgC,oBAAoB,IAAI,oBAAoB,IAAI,oBAAoB;AAAA;AAAA,UAErG,qCAAU,IAAI,CAAC,KAAgB,UAAiB;;AAChD,cAAM,EAAE,YAAY,kBAAsB,KAAA,2BAAK,mBAAkB,CAAA;AAEjE,cAAM,WAAW,KAAK,qBAAqB,UAAU,GAAG;AACxD,cAAM,YAAY,iCAAgCH,MAAA,IAAI,cAAJ,gBAAAA,IAAe,IAAI;AACrE,cAAM,UAAU,iCAAgCC,MAAA,IAAI,YAAJ,gBAAAA,IAAa,IAAI;AAEjE,cAAM,uBACJ,gBAAcE,MAAA,WAAW,WAAW,SAAS,CAAC,MAAhC,gBAAAA,IAAmC,gBAAe;AAClE,cAAM,mBACJ,gBAAcD,MAAA,WAAW,WAAW,SAAS,CAAC,MAAhC,gBAAAA,IAAmC,gBAAe;AAClE,cAAM,yBAAyB,gBAAcE,MAAA,WAAW,CAAC,MAAZ,gBAAAA,IAAe,gBAAe;AAE3E,cAAM,mBAAmB,QAAQ,KAAK,SAAS,QAAQ,CAAC,EAAE,eAAe;AACzE,cAAM,gCACJ,sBACA,sBAAiB,iBAAiB,SAAS,CAAC,MAA5C,mBAA+C,gBAAe;AAEhE,cAAM,aACJ,wBAAyB,0BAA0B,mBAC/C,kCACA;AACA,cAAA,yBACJ,0BAA0B,gCACtB,6CACA;AAEA,cAAA,aAAY,uDAAmB,aAAY,qCAAqC;AAEhF,cAAA,wBAAwB,EAAE,MAAM,WAAW,SAAO,SAAI,cAAJ,mBAAe,UAAS;AAC1E,cAAA,sBAAsB,EAAE,MAAM,SAAS,SAAO,SAAI,YAAJ,mBAAa,UAAS;AAC1E,cAAMC,UAAS,KAAK,WAAW,KAAK,uBAAuB,mBAAmB;AAE9E,cAAM,YAAY,CAAC,aAAa,CAAC,cAAc,2BAA2BA;AAC1E,cAAM,WAAW,MAA6B;AACrC,iBAAA;AAAA,YACL,+BAA+B,GAAG,QAAQ;AAAA,YAC1C,GAAIA,YAAW,cAAc,CAAC,aAAa,CAAC,aACxC;AAAA,cACE,gCAAgC,GAAG,KAAK,aAAa,KAAK,uBAAuB,mBAAmB,CAAC;AAAA,YAAA,IAEvG,CAAA;AAAA;QAER;AAEO,eAAA;AAAA,0CACyB,aAAa,EAAE,IAAI,SAAS,IAAI,UAAU;AAAA,oBAChE,SAAS,UAAU,CAAC;AAAA;AAAA,cAE1B,QAAQ,KAAK,QAAQ,SAAS,SAC5B,0CAA0C,sBAAsB,cAChE,OAAO;AAAA,cACTA,YAAW,cAAc,CAAC,aAAa,CAAC,aACtC,KAAK,gBAAgB,KAAK,uBAAuB,mBAAmB,IACpE,OAAO;AAAA;AAAA,MAAA,EAEb;AAAA;AAAA,2CAEiC,kBAAkB,IAAI,kBAAkB,IAAI,kBAAkB;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA,KApP5E,wCAQ3B;;AARC,uBAAA,CAAA,SAAS,EAAE,MAAM,MAAO,CAAA,CAAC;AAMzB,mCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,qBAAqB,MAAM,SAAS,CAAC;AAI3D,0BAAA,CAAA,UAAU;AAXgC,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAA,MAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,OAA+B;AAAA,SAAA,UAAA,aAAA,oBAAA,uBAAA;AAQ1D,iBAAA,IAAA,MAAA,8BAAA,EAAA,MAAA,YAAA,MAAA,oBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,sBAAA,KAAA,KAAA,CAAA,QAAA,IAAA,kBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,mBAAkC;AAAA,SAAA,UAAA,aAAA,gCAAA,mCAAA;AAIlD,iBAAA,IAAA,MAAA,qBAAA,EAAA,MAAA,UAAA,MAAA,OAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,SAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,MAEV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAzBH,iBAoQC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAnQwB,GAAM,SAAmB,OAD5C,kBAAoB,YAAA,uBAAA,GAAC;;;","x_google_ignoreList":[0,1]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timetable-duration.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-duration/timetable-duration.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"timetable-duration.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-duration/timetable-duration.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC;;GAEG;AACH,qBAEM,2BAA4B,SAAQ,UAAU;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;OAKG;IACH,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,OAAO,CAAC,SAAS,CAAmC;cAEjC,MAAM,IAAI,cAAc;CAqC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,2BAA2B,CAAC;KACvD;CACF"}
|