@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.
Files changed (49) hide show
  1. package/core/datetime.js +3 -9
  2. package/core/timetable.js +10 -64
  3. package/custom-elements.json +90 -40
  4. package/development/core/datetime.js +4 -10
  5. package/development/core/timetable.js +11 -65
  6. package/development/differenceInMinutes-Cmyza6nm.js +1 -1
  7. package/development/format-DTy5_IOt.js +1 -1
  8. package/development/isValid-DO_pHwcW.js +1 -1
  9. package/development/journey-summary/journey-summary.d.ts +6 -6
  10. package/development/journey-summary/journey-summary.d.ts.map +1 -1
  11. package/development/journey-summary.js +180 -82
  12. package/development/pearl-chain/pearl-chain.d.ts +2 -2
  13. package/development/pearl-chain/pearl-chain.d.ts.map +1 -1
  14. package/development/pearl-chain-time/pearl-chain-time.d.ts +7 -7
  15. package/development/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
  16. package/development/pearl-chain-time.js +176 -68
  17. package/development/pearl-chain-vertical/pearl-chain-vertical.d.ts.map +1 -1
  18. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts +2 -2
  19. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts.map +1 -1
  20. package/development/pearl-chain-vertical-item.js +67 -30
  21. package/development/pearl-chain-vertical.js +22 -21
  22. package/development/pearl-chain.js +210 -166
  23. package/development/timetable-duration/timetable-duration.d.ts +1 -1
  24. package/development/timetable-duration/timetable-duration.d.ts.map +1 -1
  25. package/development/timetable-duration.js +72 -45
  26. package/development/timetable-row/timetable-row.d.ts +10 -10
  27. package/development/timetable-row/timetable-row.d.ts.map +1 -1
  28. package/development/timetable-row.js +337 -205
  29. package/journey-summary/journey-summary.d.ts +6 -6
  30. package/journey-summary/journey-summary.d.ts.map +1 -1
  31. package/journey-summary.js +156 -100
  32. package/package.json +4 -3
  33. package/pearl-chain/pearl-chain.d.ts +2 -2
  34. package/pearl-chain/pearl-chain.d.ts.map +1 -1
  35. package/pearl-chain-time/pearl-chain-time.d.ts +7 -7
  36. package/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
  37. package/pearl-chain-time.js +137 -78
  38. package/pearl-chain-vertical/pearl-chain-vertical.d.ts.map +1 -1
  39. package/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts +2 -2
  40. package/pearl-chain-vertical-item/pearl-chain-vertical-item.d.ts.map +1 -1
  41. package/pearl-chain-vertical-item.js +57 -34
  42. package/pearl-chain-vertical.js +17 -18
  43. package/pearl-chain.js +156 -131
  44. package/timetable-duration/timetable-duration.d.ts +1 -1
  45. package/timetable-duration/timetable-duration.d.ts.map +1 -1
  46. package/timetable-duration.js +48 -30
  47. package/timetable-row/timetable-row.d.ts +10 -10
  48. package/timetable-row/timetable-row.d.ts.map +1 -1
  49. 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 { css, LitElement, html, nothing } from "lit";
3
- import { property, customElement } from "lit/decorators.js";
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
- var __defProp = Object.defineProperty;
407
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
408
- var __decorateClass = (decorators, target, key, kind) => {
409
- var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
410
- for (var i = decorators.length - 1, decorator; i >= 0; i--)
411
- if (decorator = decorators[i])
412
- result = (kind ? decorator(target, key, result) : decorator(result)) || result;
413
- if (kind && result) __defProp(target, key, result);
414
- return result;
415
- };
416
- let SbbPearlChainElement = class extends LitElement {
417
- constructor() {
418
- super(...arguments);
419
- this._now = null;
420
- }
421
- set now(value) {
422
- this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));
423
- }
424
- get now() {
425
- return this._now;
426
- }
427
- _getAllDuration(legs) {
428
- return legs == null ? void 0 : legs.reduce((sum, leg) => {
429
- var _a, _b;
430
- const arrivalNoTz = removeTimezoneFromISOTimeString((_a = leg.arrival) == null ? void 0 : _a.time);
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
- return sum + differenceInMinutes(
434
- removeTimezoneFromISOTimeString(leg.arrival.time),
435
- removeTimezoneFromISOTimeString(leg.departure.time)
436
- );
437
- }
438
- return sum;
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
- const startWithDelay = addMinutes(start.time, start.delay ?? 0);
469
- const endWithDelay = addMinutes(end.time, end.delay ?? 0);
470
- const total = differenceInMinutes(endWithDelay, startWithDelay);
471
- const progress = differenceInMinutes(now, startWithDelay);
472
- return total && progress / total * 100;
473
- }
474
- _getStatus(now, start, end) {
475
- const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);
476
- const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);
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
- return "future";
483
- }
484
- _renderPosition(now, start, end) {
485
- const currentPosition = this._getProgress(now, start, end);
486
- if (currentPosition < 0 && currentPosition > 100) return void 0;
487
- const statusStyle = () => {
488
- return {
489
- "--sbb-pearl-chain-status-position": `${currentPosition}%`,
490
- ...currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}
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
- const animation = this.disableAnimation ? "sbb-pearl-chain__position--no-animation" : "";
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
- render() {
500
- var _a, _b, _c, _d, _e;
501
- const now = this.now ?? /* @__PURE__ */ new Date();
502
- const rideLegs = (_a = this.legs) == null ? void 0 : _a.filter((leg) => isRideLeg(leg));
503
- const departureTime = (rideLegs == null ? void 0 : rideLegs.length) && removeTimezoneFromISOTimeString((_c = (_b = rideLegs[0]) == null ? void 0 : _b.departure) == null ? void 0 : _c.time);
504
- const departureWithDelay = departureTime && {
505
- time: departureTime,
506
- delay: rideLegs[0].departure.delay ?? 0
507
- };
508
- const arrivalTime = (rideLegs == null ? void 0 : rideLegs.length) && removeTimezoneFromISOTimeString((_d = rideLegs[rideLegs.length - 1].arrival) == null ? void 0 : _d.time);
509
- const arrivalTimeDelay = arrivalTime && {
510
- time: arrivalTime,
511
- delay: ((_e = rideLegs[rideLegs.length - 1]) == null ? void 0 : _e.arrival.delay) ?? 0
512
- };
513
- const departureNotServiced = (() => {
514
- var _a2, _b2, _c2, _d2;
515
- return rideLegs && ((_b2 = (_a2 = rideLegs[0]) == null ? void 0 : _a2.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" : "";
516
- })();
517
- const arrivalNotServiced = (() => {
518
- var _a2;
519
- const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];
520
- const stops = lastLeg && ((_a2 = lastLeg.serviceJourney) == null ? void 0 : _a2.stopPoints);
521
- return stops && stops[stops.length - 1].stopStatus === "NOT_SERVICED" ? "sbb-pearl-chain--arrival-skipped" : "";
522
- })();
523
- const departureCancelClass = (() => {
524
- var _a2, _b2, _c2;
525
- return rideLegs && ((_c2 = (_b2 = (_a2 = rideLegs[0]) == null ? void 0 : _a2.serviceJourney) == null ? void 0 : _b2.serviceAlteration) == null ? void 0 : _c2.cancelled) ? "sbb-pearl-chain--departure-disruption" : "";
526
- })();
527
- const arrivalCancelClass = (() => {
528
- var _a2, _b2, _c2;
529
- return rideLegs && ((_c2 = (_b2 = (_a2 = rideLegs[rideLegs.length - 1]) == null ? void 0 : _a2.serviceJourney) == null ? void 0 : _b2.serviceAlteration) == null ? void 0 : _c2.cancelled) ? "sbb-pearl-chain--arrival-disruption" : "";
530
- })();
531
- const status = departureWithDelay && arrivalTimeDelay && this._getStatus(now, departureWithDelay, arrivalTimeDelay);
532
- const statusClassDeparture = rideLegs && status && !departureCancelClass ? "sbb-pearl-chain__bullet--" + status : "";
533
- const statusClassArrival = rideLegs && status && !arrivalCancelClass ? "sbb-pearl-chain__bullet--" + this._getStatus(now, void 0, arrivalTimeDelay) : "";
534
- if (this._isAllCancelled(rideLegs)) {
535
- return html`
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
- return html`
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
- var _a2, _b2, _c2, _d2, _e2, _f, _g, _h;
550
- const { stopPoints, serviceAlteration } = (leg == null ? void 0 : leg.serviceJourney) || {};
551
- const duration = this._getRelativeDuration(rideLegs, leg);
552
- const departure = removeTimezoneFromISOTimeString((_a2 = leg.departure) == null ? void 0 : _a2.time);
553
- const arrival = removeTimezoneFromISOTimeString((_b2 = leg.arrival) == null ? void 0 : _b2.time);
554
- const isArrivalNotServiced = stopPoints && ((_c2 = stopPoints[stopPoints.length - 1]) == null ? void 0 : _c2.stopStatus) === "NOT_SERVICED";
555
- const isArrivalPlanned = stopPoints && ((_d2 = stopPoints[stopPoints.length - 1]) == null ? void 0 : _d2.stopStatus) === "PLANNED";
556
- const isDepartureNotServiced = stopPoints && ((_e2 = stopPoints[0]) == null ? void 0 : _e2.stopStatus) === "NOT_SERVICED";
557
- const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;
558
- const isBeforeLegArrivalNotServiced = stopPointsBefore && ((_f = stopPointsBefore[stopPointsBefore.length - 1]) == null ? void 0 : _f.stopStatus) === "NOT_SERVICED";
559
- const skippedLeg = isArrivalNotServiced || isDepartureNotServiced && isArrivalPlanned ? "sbb-pearl-chain__leg--skipped" : "";
560
- const departureSkippedBullet = isDepartureNotServiced || isBeforeLegArrivalNotServiced ? "sbb-pearl-chain__stop--departure-skipped" : "";
561
- const cancelled = (serviceAlteration == null ? void 0 : serviceAlteration.cancelled) ? "sbb-pearl-chain__leg--disruption" : "";
562
- const legDepartureWithDelay = { time: departure, delay: ((_g = leg.departure) == null ? void 0 : _g.delay) ?? 0 };
563
- const legArrivalWithDelay = { time: arrival, delay: ((_h = leg.arrival) == null ? void 0 : _h.delay) ?? 0 };
564
- const status2 = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);
565
- const legStatus = !cancelled && !skippedLeg && "sbb-pearl-chain__leg--" + status2;
566
- const legStyle = () => {
567
- return {
568
- "--sbb-pearl-chain-leg-width": `${duration}%`,
569
- ...status2 === "progress" && !cancelled && !skippedLeg ? {
570
- "--sbb-pearl-chain-leg-status": `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`
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
- SbbPearlChainElement.styles = style;
590
- __decorateClass([
591
- property({ type: Array })
592
- ], SbbPearlChainElement.prototype, "legs", 2);
593
- __decorateClass([
594
- property({ attribute: "disable-animation", type: Boolean })
595
- ], SbbPearlChainElement.prototype, "disableAnimation", 2);
596
- __decorateClass([
597
- property()
598
- ], SbbPearlChainElement.prototype, "now", 1);
599
- SbbPearlChainElement = __decorateClass([
600
- customElement("sbb-pearl-chain")
601
- ], SbbPearlChainElement);
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":"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","x_google_ignoreList":[0,1]}
@@ -10,7 +10,7 @@ export declare class SbbTimetableDurationElement extends LitElement {
10
10
  * individual stories to get an idea of the
11
11
  * structure.
12
12
  */
13
- config: string;
13
+ accessor config: string;
14
14
  private _language;
15
15
  protected render(): TemplateResult;
16
16
  }
@@ -1 +1 @@
1
- {"version":3,"file":"timetable-duration.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-duration/timetable-duration.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAKvC;;GAEG;AACH,qBACa,2BAA4B,SAAQ,UAAU;IACzD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;OAKG;IACgB,MAAM,EAAG,MAAM,CAAC;IAEnC,OAAO,CAAC,SAAS,CAAmC;cAEjC,MAAM,IAAI,cAAc;CAqC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,2BAA2B,CAAC;KACvD;CACF"}
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"}