@sbb-esta/lyne-elements-experimental 1.3.0 → 1.4.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.
@@ -1 +1 @@
1
- {"version":3,"file":"pearl-chain.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEjF,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAKhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAW3D;;GAEG;AACH,qBACa,oBAAqB,SAAQ,UAAU;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D;;;OAGG;IACiE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE/F,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,GAAG,IAAI,CAE5B;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,oBAAoB;IAmB5B,OAAO,CAAC,YAAY;IAapB,OAAO,CAAC,UAAU;IAiBlB,OAAO,CAAC,eAAe;cAmBJ,MAAM,IAAI,cAAc;CAgJ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
1
+ {"version":3,"file":"pearl-chain.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEjF,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAKhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAW3D;;GAEG;AACH,qBACa,oBAAqB,SAAQ,UAAU;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D;;;OAGG;IACiE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE/F,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,GAAG,IAAI,CAE5B;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,oBAAoB;IAmB5B,OAAO,CAAC,YAAY;IAapB,OAAO,CAAC,UAAU;IAiBlB,OAAO,CAAC,eAAe;cAmBJ,MAAM,IAAI,cAAc;CA4I5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
@@ -576,7 +576,7 @@ let SbbPearlChainElement = class extends LitElement {
576
576
  const legDepartureWithDelay = { time: departure, delay: ((_g = leg.departure) == null ? void 0 : _g.delay) ?? 0 };
577
577
  const legArrivalWithDelay = { time: arrival, delay: ((_h = leg.arrival) == null ? void 0 : _h.delay) ?? 0 };
578
578
  const status2 = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);
579
- const legStatus = !cancelled && !skippedLeg && this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay) && "sbb-pearl-chain__leg--" + status2;
579
+ const legStatus = !cancelled && !skippedLeg && "sbb-pearl-chain__leg--" + status2;
580
580
  const legStyle = () => {
581
581
  return {
582
582
  "--sbb-pearl-chain-leg-width": `${duration}%`,
@@ -616,4 +616,4 @@ SbbPearlChainElement = __decorateClass([
616
616
  export {
617
617
  SbbPearlChainElement
618
618
  };
619
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.mjs","../../../node_modules/date-fns/isBefore.mjs","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.mjs\";\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 * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\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  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return _date.getTime() > _dateToCompare.getTime();\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.mjs\";\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 * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\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  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return +_date < +_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 =\n            !cancelled &&\n            !skippedLeg &&\n            this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay) &&\n            '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]}
619
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.mjs","../../../node_modules/date-fns/isBefore.mjs","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.mjs\";\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 * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\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  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return _date.getTime() > _dateToCompare.getTime();\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.mjs\";\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 * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\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  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return +_date < +_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]}
@@ -1,6 +1,6 @@
1
1
  import { ITripItem } from '../core/timetable.js';
2
2
 
3
- type DeepPartial<T> = T extends object ? {
3
+ export type DeepPartial<T> = T extends object ? {
4
4
  [P in keyof T]?: DeepPartial<T[P]>;
5
5
  } : T;
6
6
  export declare const defaultTrip: DeepPartial<ITripItem>;
@@ -20,5 +20,4 @@ export declare const shipTrip: DeepPartial<ITripItem>;
20
20
  export declare const walkTimeTrip: DeepPartial<ITripItem>;
21
21
  export declare const extendedEnterTimeTrip: DeepPartial<ITripItem>;
22
22
  export declare const noticesTrip: DeepPartial<ITripItem>;
23
- export {};
24
23
  //# sourceMappingURL=timetable-row.sample-data.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAgBtD,KAAK,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAClC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}
1
+ {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAgBtD,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GACzC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-experimental",
3
- "version": "1.3.0",
3
+ "version": "1.4.0",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -11,7 +11,7 @@
11
11
  "type": "module",
12
12
  "customElements": "custom-elements.json",
13
13
  "peerDependencies": {
14
- "@sbb-esta/lyne-elements": "1.3.0"
14
+ "@sbb-esta/lyne-elements": "1.4.0"
15
15
  },
16
16
  "dependencies": {
17
17
  "lit": "^3.0.0"
@@ -1 +1 @@
1
- {"version":3,"file":"pearl-chain.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEjF,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAKhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAW3D;;GAEG;AACH,qBACa,oBAAqB,SAAQ,UAAU;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D;;;OAGG;IACiE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE/F,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,GAAG,IAAI,CAE5B;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,oBAAoB;IAmB5B,OAAO,CAAC,YAAY;IAapB,OAAO,CAAC,UAAU;IAiBlB,OAAO,CAAC,eAAe;cAmBJ,MAAM,IAAI,cAAc;CAgJ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
1
+ {"version":3,"file":"pearl-chain.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAEjF,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAKhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAW3D;;GAEG;AACH,qBACa,oBAAqB,SAAQ,UAAU;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D;;;OAGG;IACiE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE/F,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,GAAG,IAAI,CAE5B;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,oBAAoB;IAmB5B,OAAO,CAAC,YAAY;IAapB,OAAO,CAAC,UAAU;IAiBlB,OAAO,CAAC,eAAe;cAmBJ,MAAM,IAAI,cAAc;CA4I5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
package/pearl-chain.js CHANGED
@@ -4,72 +4,72 @@ import { property as C, customElement as ie } from "lit/decorators.js";
4
4
  import { styleMap as Y } from "lit/directives/style-map.js";
5
5
  import { removeTimezoneFromISOTimeString as c } from "./core/datetime.js";
6
6
  import { isRideLeg as se } from "./core/timetable.js";
7
- import { d as f, a as y } from "./differenceInMinutes-BhHyuJc4.js";
8
- import { t as k } from "./constants-DSR8hPvP.js";
9
- function be(a, e) {
10
- const r = k(a), t = k(e);
11
- return r.getTime() > t.getTime();
7
+ import { d as g, a as m } from "./differenceInMinutes-BhHyuJc4.js";
8
+ import { t as f } from "./constants-DSR8hPvP.js";
9
+ function be(r, e) {
10
+ const a = f(r), t = f(e);
11
+ return a.getTime() > t.getTime();
12
12
  }
13
- function F(a, e) {
14
- const r = k(a), t = k(e);
15
- return +r < +t;
13
+ function F(r, e) {
14
+ const a = f(r), t = f(e);
15
+ return +a < +t;
16
16
  }
17
17
  const oe = te`*,:before,:after{box-sizing:border-box}:host{--sbb-pearl-chain-height: var(--sbb-border-width-2x);--sbb-pearl-chain-spacing-small: var(--sbb-spacing-fixed-1x);--sbb-pearl-chain-color: var(--sbb-pearl-chain-bullet-color);--sbb-pearl-chain-color-disruption: var(--sbb-pearl-chain-bullet-color-disruption);--sbb-pearl-chain-color-past: var(--sbb-pearl-chain-bullet-color-past);--sbb-pearl-chain-leg-width: 100%;--sbb-pearl-chain-bullet-size-start-end: .625rem;--sbb-pearl-chain-bullet-size-stop: .5rem;--sbb-pearl-chain-bullet-color: var(--sbb-color-charcoal);--sbb-pearl-chain-bullet-color-past: var(--sbb-color-metal);--sbb-pearl-chain-bullet-color-irrelevant: var(--sbb-color-metal);--sbb-pearl-chain-bullet-color-disruption: var(--sbb-color-red);--sbb-pearl-chain-bullet-border-width: var(--sbb-border-width-2x);--sbb-pearl-chain-bullet-animation-duration: 1.92s;--sbb-pearl-chain-bullet-animation-easing: ease-out;--sbb-pearl-chain-bullet-crossed-width: .88375rem;--sbb-pearl-chain-bullet-crossed-height: .21875rem;--sbb-pearl-chain-bullet-crossed-border-width: .09375rem;display:block}.sbb-pearl-chain{position:relative;display:flex;justify-content:space-between;flex-wrap:nowrap;color:var(--sbb-pearl-chain-color);width:100%;padding-block:calc((var(--sbb-pearl-chain-bullet-size-start-end) - var(--sbb-pearl-chain-height)) / 2);padding-inline-end:var(--sbb-pearl-chain-bullet-size-start-end)}.sbb-pearl-chain__bullet{background:var(--sbb-pearl-chain-bullet-color);color:var(--sbb-pearl-chain-bullet-color);border-color:var(--sbb-pearl-chain-bullet-color);border-radius:100%;min-height:var(--sbb-pearl-chain-bullet-size-start-end);min-width:var(--sbb-pearl-chain-bullet-size-start-end);height:var(--sbb-pearl-chain-bullet-size-start-end);width:var(--sbb-pearl-chain-bullet-size-start-end);content:"";position:absolute;background-color:currentcolor;inset-block-start:0;z-index:3}@media (forced-colors: active){.sbb-pearl-chain__bullet{--sbb-pearl-chain-bullet-color: CanvasText}}.sbb-pearl-chain__bullet:first-of-type{inset-inline-start:0}.sbb-pearl-chain__bullet:last-of-type{inset-inline-end:0}.sbb-pearl-chain__leg{flex-shrink:0;flex-grow:0;position:relative;height:var(--sbb-pearl-chain-height);border-inline-end:var(--sbb-pearl-chain-spacing-small) solid Canvas;background-color:currentcolor;width:var(--sbb-pearl-chain-leg-width);display:flex;align-items:center}@media (forced-colors: active){.sbb-pearl-chain__leg{background-color:CanvasText}.sbb-pearl-chain--past .sbb-pearl-chain__leg{background-color:GrayText}}.sbb-pearl-chain__leg:last-of-type{border:none}.sbb-pearl-chain__stop{background:var(--sbb-pearl-chain-bullet-color);color:var(--sbb-pearl-chain-bullet-color);border-color:var(--sbb-pearl-chain-bullet-color);border-radius:100%;min-height:var(--sbb-pearl-chain-bullet-size-stop);min-width:var(--sbb-pearl-chain-bullet-size-stop);height:var(--sbb-pearl-chain-bullet-size-stop);width:var(--sbb-pearl-chain-bullet-size-stop);border:var(--sbb-pearl-chain-bullet-border-width) solid currentcolor;background:Canvas;position:relative;z-index:2}@media (forced-colors: active){.sbb-pearl-chain__stop{--sbb-pearl-chain-bullet-color: CanvasText}}.sbb-pearl-chain__bullet--future{background:var(--sbb-pearl-chain-bullet-color);color:var(--sbb-pearl-chain-bullet-color);border-color:var(--sbb-pearl-chain-bullet-color);border-radius:100%}@media (forced-colors: active){.sbb-pearl-chain__bullet--future{--sbb-pearl-chain-bullet-color: CanvasText}}.sbb-pearl-chain__leg--past,.sbb-pearl-chain--past,.sbb-pearl-chain__leg--past:after,.sbb-pearl-chain__leg--progress:after,.sbb-pearl-chain__leg--progress .sbb-pearl-chain__stop,.sbb-pearl-chain--progress,.sbb-pearl-chain__bullet--past{--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-past);color:var(--sbb-pearl-chain-color-past)}@media (forced-colors: active){.sbb-pearl-chain__leg--past,.sbb-pearl-chain--past,.sbb-pearl-chain__leg--past:after,.sbb-pearl-chain__leg--progress:after,.sbb-pearl-chain__leg--progress .sbb-pearl-chain__stop,.sbb-pearl-chain--progress,.sbb-pearl-chain__bullet--past{--sbb-pearl-chain-bullet-color: GrayText !important}}@media (forced-colors: active){.sbb-pearl-chain__leg--past,.sbb-pearl-chain--past,.sbb-pearl-chain__leg--past:after,.sbb-pearl-chain__leg--progress:after,.sbb-pearl-chain__leg--progress .sbb-pearl-chain__stop,.sbb-pearl-chain--progress,.sbb-pearl-chain__bullet--past{background-color:GrayText!important}}.sbb-pearl-chain__bullet--progress{--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-past);background:var(--sbb-pearl-chain-bullet-color)}@media (forced-colors: active){.sbb-pearl-chain__bullet--progress{--sbb-pearl-chain-bullet-color: GrayText !important}}.sbb-pearl-chain__bullet--departure-disruption,.sbb-pearl-chain--arrival-disruption,.sbb-pearl-chain--departure-disruption,.sbb-pearl-chain__leg--disruption{--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-disruption);color:var(--sbb-pearl-chain-color-disruption)}@media (forced-colors: active){.sbb-pearl-chain__bullet--departure-disruption,.sbb-pearl-chain--arrival-disruption,.sbb-pearl-chain--departure-disruption,.sbb-pearl-chain__leg--disruption{--sbb-pearl-chain-bullet-color: Highlight}}@media (forced-colors: active){.sbb-pearl-chain__bullet--departure-disruption,.sbb-pearl-chain--arrival-disruption,.sbb-pearl-chain--departure-disruption,.sbb-pearl-chain__leg--disruption{color:Highlight;background:Highlight}}.sbb-pearl-chain__leg--disruption .sbb-pearl-chain__stop{--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-disruption)}@media (forced-colors: active){.sbb-pearl-chain__leg--disruption .sbb-pearl-chain__stop{--sbb-pearl-chain-bullet-color: Highlight}}.sbb-pearl-chain__leg--past .sbb-pearl-chain__stop{--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-past)}@media (forced-colors: active){.sbb-pearl-chain__leg--past .sbb-pearl-chain__stop{--sbb-pearl-chain-bullet-color: GrayText !important}}.sbb-pearl-chain__leg--disruption:after{background-color:unset;background-image:linear-gradient(to right,currentcolor 0%,currentcolor 50%,Canvas 50%);background-repeat:repeat-x;background-size:calc(2 * var(--sbb-pearl-chain-spacing-small)) var(--sbb-pearl-chain-height);inset-inline-end:var(--sbb-pearl-chain-height)}@media (forced-colors: active){.sbb-pearl-chain__leg--disruption:after{background:unset;border-block-start:.0625rem dashed Highlight;transform:translateY(.0625rem)}}.sbb-pearl-chain__leg--skipped{color:var(--sbb-pearl-chain-color-disruption)}.sbb-pearl-chain__leg--skipped:after{background-color:unset;background-image:linear-gradient(to right,currentcolor 0%,currentcolor 50%,Canvas 50%);background-repeat:repeat-x;background-size:calc(2 * var(--sbb-pearl-chain-spacing-small)) var(--sbb-pearl-chain-height);inset-inline-end:var(--sbb-pearl-chain-height)}@media (forced-colors: active){.sbb-pearl-chain__leg--skipped:after{background:unset;border-block-start:.0625rem dashed Highlight;transform:translateY(.0625rem)}}.sbb-pearl-chain__stop--departure-skipped{min-height:var(--sbb-pearl-chain-bullet-size-stop);min-width:var(--sbb-pearl-chain-bullet-size-stop);height:var(--sbb-pearl-chain-bullet-size-stop);width:var(--sbb-pearl-chain-bullet-size-stop);border:var(--sbb-pearl-chain-bullet-border-width) solid currentcolor;background:Canvas}.sbb-pearl-chain__stop--departure-skipped:before{content:"";position:absolute;inset-block-start:50%;inset-inline-start:50%;transform:translate(-50%,-50%) rotate(45deg);border-block-start:var(--sbb-pearl-chain-bullet-crossed-border-width) solid canvas;background:var(--sbb-pearl-chain-bullet-color-disruption);height:var(--sbb-pearl-chain-bullet-crossed-height);width:var(--sbb-pearl-chain-bullet-crossed-width)}@media (forced-colors: active){.sbb-pearl-chain__stop--departure-skipped:before{background:Highlight}}.sbb-pearl-chain--arrival-skipped,.sbb-pearl-chain--departure-skipped{min-height:var(--sbb-pearl-chain-bullet-size-start-end);min-width:var(--sbb-pearl-chain-bullet-size-start-end);height:var(--sbb-pearl-chain-bullet-size-start-end);width:var(--sbb-pearl-chain-bullet-size-start-end);border:var(--sbb-pearl-chain-bullet-border-width) solid currentcolor;background:Canvas}.sbb-pearl-chain--arrival-skipped:before,.sbb-pearl-chain--departure-skipped:before{content:"";position:absolute;inset-block-start:50%;inset-inline-start:50%;transform:translate(-50%,-50%) rotate(45deg);border-block-start:var(--sbb-pearl-chain-bullet-crossed-border-width) solid canvas;background:var(--sbb-pearl-chain-bullet-color-disruption);height:var(--sbb-pearl-chain-bullet-crossed-height);width:var(--sbb-pearl-chain-bullet-crossed-width)}@media (forced-colors: active){.sbb-pearl-chain--arrival-skipped:before,.sbb-pearl-chain--departure-skipped:before{background:Highlight}}.sbb-pearl-chain__leg:after{content:"";position:absolute;inset-block:0;inset-inline-start:0;background-color:currentcolor;border-radius:var(--sbb-pearl-chain-height);z-index:1}@media (forced-colors: active){.sbb-pearl-chain__leg:after{background-color:CanvasText}.sbb-pearl-chain--past .sbb-pearl-chain__leg:after{background-color:GrayText}}.sbb-pearl-chain__leg:last-of-type:after{inset-inline-end:calc(-1 * var(--sbb-pearl-chain-height))}.sbb-pearl-chain__leg--progress:after{background-color:var(--sbb-pearl-chain-color-past);width:var(--sbb-pearl-chain-leg-status)}.sbb-pearl-chain__position{background:var(--sbb-pearl-chain-bullet-color);color:var(--sbb-pearl-chain-bullet-color);border-color:var(--sbb-pearl-chain-bullet-color);border-radius:100%;min-height:var(--sbb-pearl-chain-bullet-size-start-end);min-width:var(--sbb-pearl-chain-bullet-size-start-end);height:var(--sbb-pearl-chain-bullet-size-start-end);width:var(--sbb-pearl-chain-bullet-size-start-end);--sbb-pearl-chain-bullet-color: var(--sbb-pearl-chain-bullet-color-disruption);animation:pearl-chain-bullet-position-pulse var(--sbb-pearl-chain-bullet-animation-duration) var(--sbb-pearl-chain-bullet-animation-easing) infinite;position:absolute;inset-block-start:-200%;z-index:4;inset-inline-start:var(--sbb-pearl-chain-status-position)}@media (forced-colors: active){.sbb-pearl-chain__position{--sbb-pearl-chain-bullet-color: CanvasText}}@media (forced-colors: active){.sbb-pearl-chain__position{--sbb-pearl-chain-bullet-color: Highlight}}@keyframes pearl-chain-bullet-position-pulse{0%{box-shadow:0 0 0 0 var(--sbb-pearl-chain-bullet-color-disruption)}25%{box-shadow:0 0 0 0 var(--sbb-pearl-chain-bullet-color-disruption)}50%{box-shadow:0 0 0 .1875rem var(--sbb-color-red-alpha-20)}to{box-shadow:0 0 0 0 var(--sbb-pearl-chain-bullet-color-disruption)}}.sbb-pearl-chain__position--no-animation{animation:unset}.sbb-screen-reader-only{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}`;
18
- var ne = Object.defineProperty, ce = Object.getOwnPropertyDescriptor, w = (a, e, r, t) => {
19
- for (var l = t > 1 ? void 0 : t ? ce(e, r) : e, b = a.length - 1, n; b >= 0; b--)
20
- (n = a[b]) && (l = (t ? n(e, r, l) : n(l)) || l);
21
- return t && l && ne(e, r, l), l;
18
+ var ne = Object.defineProperty, ce = Object.getOwnPropertyDescriptor, y = (r, e, a, t) => {
19
+ for (var l = t > 1 ? void 0 : t ? ce(e, a) : e, b = r.length - 1, n; b >= 0; b--)
20
+ (n = r[b]) && (l = (t ? n(e, a, l) : n(l)) || l);
21
+ return t && l && ne(e, a, l), l;
22
22
  };
23
23
  let h = class extends le {
24
24
  constructor() {
25
25
  super(...arguments), this._now = null;
26
26
  }
27
- set now(a) {
28
- this._now = j.getValidDateOrNull(j.deserialize(a));
27
+ set now(r) {
28
+ this._now = j.getValidDateOrNull(j.deserialize(r));
29
29
  }
30
30
  get now() {
31
31
  return this._now;
32
32
  }
33
- _getAllDuration(a) {
34
- return a == null ? void 0 : a.reduce((e, r) => {
33
+ _getAllDuration(r) {
34
+ return r == null ? void 0 : r.reduce((e, a) => {
35
35
  var b, n;
36
- const t = c((b = r.arrival) == null ? void 0 : b.time), l = c((n = r.departure) == null ? void 0 : n.time);
37
- return t && l ? e + f(
38
- c(r.arrival.time),
39
- c(r.departure.time)
36
+ const t = c((b = a.arrival) == null ? void 0 : b.time), l = c((n = a.departure) == null ? void 0 : n.time);
37
+ return t && l ? e + g(
38
+ c(a.arrival.time),
39
+ c(a.departure.time)
40
40
  ) : e;
41
41
  }, 0);
42
42
  }
43
- _isAllCancelled(a) {
44
- return a == null ? void 0 : a.every((e) => {
45
- var r, t;
46
- return (t = (r = e == null ? void 0 : e.serviceJourney) == null ? void 0 : r.serviceAlteration) == null ? void 0 : t.cancelled;
43
+ _isAllCancelled(r) {
44
+ return r == null ? void 0 : r.every((e) => {
45
+ var a, t;
46
+ return (t = (a = e == null ? void 0 : e.serviceJourney) == null ? void 0 : a.serviceAlteration) == null ? void 0 : t.cancelled;
47
47
  });
48
48
  }
49
- _getRelativeDuration(a, e) {
49
+ _getRelativeDuration(r, e) {
50
50
  var l, b;
51
- const r = c((l = e.arrival) == null ? void 0 : l.time), t = c((b = e.departure) == null ? void 0 : b.time);
52
- if (r && t) {
53
- const n = f(
51
+ const a = c((l = e.arrival) == null ? void 0 : l.time), t = c((b = e.departure) == null ? void 0 : b.time);
52
+ if (a && t) {
53
+ const n = g(
54
54
  c(e.arrival.time),
55
55
  c(e.departure.time)
56
- ), u = this._getAllDuration(a);
56
+ ), u = this._getAllDuration(r);
57
57
  return u === 0 ? 100 : n / u * 100;
58
58
  }
59
59
  return 0;
60
60
  }
61
- _getProgress(a, e, r) {
62
- if (!(e != null && e.time) || !(r != null && r.time))
61
+ _getProgress(r, e, a) {
62
+ if (!(e != null && e.time) || !(a != null && a.time))
63
63
  return 0;
64
- const t = y(e.time, e.delay ?? 0), l = y(r.time, r.delay ?? 0), b = f(l, t), n = f(a, t);
64
+ const t = m(e.time, e.delay ?? 0), l = m(a.time, a.delay ?? 0), b = g(l, t), n = g(r, t);
65
65
  return b && n / b * 100;
66
66
  }
67
- _getStatus(a, e, r) {
68
- const t = e && e.time && y(e.time, e.delay ?? 0), l = r && r.time && y(r.time, r.delay ?? 0);
69
- return t && F(t, a) && l && be(l, a) ? "progress" : l && F(l, a) ? "past" : "future";
67
+ _getStatus(r, e, a) {
68
+ const t = e && e.time && m(e.time, e.delay ?? 0), l = a && a.time && m(a.time, a.delay ?? 0);
69
+ return t && F(t, r) && l && be(l, r) ? "progress" : l && F(l, r) ? "past" : "future";
70
70
  }
71
- _renderPosition(a, e, r) {
72
- const t = this._getProgress(a, e, r);
71
+ _renderPosition(r, e, a) {
72
+ const t = this._getProgress(r, e, a);
73
73
  if (t < 0 && t > 100) return;
74
74
  const l = () => ({
75
75
  "--sbb-pearl-chain-status-position": `${t}%`,
@@ -82,8 +82,8 @@ let h = class extends le {
82
82
  }
83
83
  render() {
84
84
  var P, $, A, N, E;
85
- const a = this.now ?? /* @__PURE__ */ new Date(), e = (P = this.legs) == null ? void 0 : P.filter((i) => se(i)), r = (e == null ? void 0 : e.length) && c((A = ($ = e[0]) == null ? void 0 : $.departure) == null ? void 0 : A.time), t = r && {
86
- time: r,
85
+ const r = this.now ?? /* @__PURE__ */ new Date(), e = (P = this.legs) == null ? void 0 : P.filter((i) => se(i)), a = (e == null ? void 0 : e.length) && c((A = ($ = e[0]) == null ? void 0 : $.departure) == null ? void 0 : A.time), t = a && {
86
+ time: a,
87
87
  delay: e[0].departure.delay ?? 0
88
88
  }, l = (e == null ? void 0 : e.length) && c((N = e[e.length - 1].arrival) == null ? void 0 : N.time), b = l && {
89
89
  time: l,
@@ -95,13 +95,13 @@ let h = class extends le {
95
95
  var s;
96
96
  const i = e && e[e.length - 1], o = i && ((s = i.serviceJourney) == null ? void 0 : s.stopPoints);
97
97
  return o && o[o.length - 1].stopStatus === "NOT_SERVICED" ? "sbb-pearl-chain--arrival-skipped" : "";
98
- })(), S = (() => {
98
+ })(), D = (() => {
99
99
  var i, o, s;
100
100
  return e && ((s = (o = (i = e[0]) == null ? void 0 : i.serviceJourney) == null ? void 0 : o.serviceAlteration) != null && s.cancelled) ? "sbb-pearl-chain--departure-disruption" : "";
101
- })(), D = (() => {
101
+ })(), S = (() => {
102
102
  var i, o, s;
103
103
  return e && ((s = (o = (i = e[e.length - 1]) == null ? void 0 : i.serviceJourney) == null ? void 0 : o.serviceAlteration) != null && s.cancelled) ? "sbb-pearl-chain--arrival-disruption" : "";
104
- })(), z = t && b && this._getStatus(a, t, b), L = e && z && !S ? "sbb-pearl-chain__bullet--" + z : "", X = e && z && !D ? "sbb-pearl-chain__bullet--" + this._getStatus(a, void 0, b) : "";
104
+ })(), k = t && b && this._getStatus(r, t, b), L = e && k && !D ? "sbb-pearl-chain__bullet--" + k : "", X = e && k && !S ? "sbb-pearl-chain__bullet--" + this._getStatus(r, void 0, b) : "";
105
105
  return this._isAllCancelled(e) ? d`
106
106
  <div class="sbb-pearl-chain">
107
107
  <span class="sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption"></span>
@@ -111,42 +111,42 @@ let h = class extends le {
111
111
  ` : d`
112
112
  <div class="sbb-pearl-chain">
113
113
  <span
114
- class="sbb-pearl-chain__bullet ${L} ${n} ${S}"
114
+ class="sbb-pearl-chain__bullet ${L} ${n} ${D}"
115
115
  ></span>
116
116
  ${e == null ? void 0 : e.map((i, o) => {
117
117
  var H, J, R, I, W, G, V, B;
118
- const { stopPoints: s, serviceAlteration: p } = (i == null ? void 0 : i.serviceJourney) || {}, q = this._getRelativeDuration(e, i), K = c((H = i.departure) == null ? void 0 : H.time), Q = c((J = i.arrival) == null ? void 0 : J.time), U = s && ((R = s[s.length - 1]) == null ? void 0 : R.stopStatus) === "NOT_SERVICED", Z = s && ((I = s[s.length - 1]) == null ? void 0 : I.stopStatus) === "PLANNED", O = s && ((W = s[0]) == null ? void 0 : W.stopStatus) === "NOT_SERVICED", x = o > 0 && e[o - 1].serviceJourney.stopPoints, ee = x && ((G = x[x.length - 1]) == null ? void 0 : G.stopStatus) === "NOT_SERVICED", _ = U || O && Z ? "sbb-pearl-chain__leg--skipped" : "", ae = O || ee ? "sbb-pearl-chain__stop--departure-skipped" : "", v = p != null && p.cancelled ? "sbb-pearl-chain__leg--disruption" : "", g = { time: K, delay: ((V = i.departure) == null ? void 0 : V.delay) ?? 0 }, m = { time: Q, delay: ((B = i.arrival) == null ? void 0 : B.delay) ?? 0 }, T = this._getStatus(a, g, m), re = !v && !_ && this._getStatus(a, g, m) && "sbb-pearl-chain__leg--" + T;
118
+ const { stopPoints: s, serviceAlteration: p } = (i == null ? void 0 : i.serviceJourney) || {}, q = this._getRelativeDuration(e, i), K = c((H = i.departure) == null ? void 0 : H.time), Q = c((J = i.arrival) == null ? void 0 : J.time), U = s && ((R = s[s.length - 1]) == null ? void 0 : R.stopStatus) === "NOT_SERVICED", Z = s && ((I = s[s.length - 1]) == null ? void 0 : I.stopStatus) === "PLANNED", O = s && ((W = s[0]) == null ? void 0 : W.stopStatus) === "NOT_SERVICED", w = o > 0 && e[o - 1].serviceJourney.stopPoints, ee = w && ((G = w[w.length - 1]) == null ? void 0 : G.stopStatus) === "NOT_SERVICED", _ = U || O && Z ? "sbb-pearl-chain__leg--skipped" : "", ae = O || ee ? "sbb-pearl-chain__stop--departure-skipped" : "", v = p != null && p.cancelled ? "sbb-pearl-chain__leg--disruption" : "", z = { time: K, delay: ((V = i.departure) == null ? void 0 : V.delay) ?? 0 }, x = { time: Q, delay: ((B = i.arrival) == null ? void 0 : B.delay) ?? 0 }, T = this._getStatus(r, z, x), re = !v && !_ && "sbb-pearl-chain__leg--" + T;
119
119
  return d` <div
120
120
  class="sbb-pearl-chain__leg ${re || ""} ${v} ${_}"
121
121
  style=${Y({
122
122
  "--sbb-pearl-chain-leg-width": `${q}%`,
123
123
  ...T === "progress" && !v && !_ ? {
124
- "--sbb-pearl-chain-leg-status": `${this._getProgress(a, g, m)}%`
124
+ "--sbb-pearl-chain-leg-status": `${this._getProgress(r, z, x)}%`
125
125
  } : {}
126
126
  })}
127
127
  >
128
128
  ${o > 0 && o < e.length ? d`<span class="sbb-pearl-chain__stop ${ae}"></span>` : M}
129
- ${T === "progress" && !v && !_ ? this._renderPosition(a, g, m) : M}
129
+ ${T === "progress" && !v && !_ ? this._renderPosition(r, z, x) : M}
130
130
  </div>`;
131
131
  })}
132
132
  <span
133
- class="sbb-pearl-chain__bullet ${X} ${u} ${D}"
133
+ class="sbb-pearl-chain__bullet ${X} ${u} ${S}"
134
134
  ></span>
135
135
  </div>
136
136
  `;
137
137
  }
138
138
  };
139
139
  h.styles = oe;
140
- w([
140
+ y([
141
141
  C({ type: Array })
142
142
  ], h.prototype, "legs", 2);
143
- w([
143
+ y([
144
144
  C({ attribute: "disable-animation", type: Boolean })
145
145
  ], h.prototype, "disableAnimation", 2);
146
- w([
146
+ y([
147
147
  C()
148
148
  ], h.prototype, "now", 1);
149
- h = w([
149
+ h = y([
150
150
  ie("sbb-pearl-chain")
151
151
  ], h);
152
152
  export {
@@ -1,6 +1,6 @@
1
1
  import { ITripItem } from '../core/timetable.js';
2
2
 
3
- type DeepPartial<T> = T extends object ? {
3
+ export type DeepPartial<T> = T extends object ? {
4
4
  [P in keyof T]?: DeepPartial<T[P]>;
5
5
  } : T;
6
6
  export declare const defaultTrip: DeepPartial<ITripItem>;
@@ -20,5 +20,4 @@ export declare const shipTrip: DeepPartial<ITripItem>;
20
20
  export declare const walkTimeTrip: DeepPartial<ITripItem>;
21
21
  export declare const extendedEnterTimeTrip: DeepPartial<ITripItem>;
22
22
  export declare const noticesTrip: DeepPartial<ITripItem>;
23
- export {};
24
23
  //# sourceMappingURL=timetable-row.sample-data.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAgBtD,KAAK,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAClC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}
1
+ {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAgBtD,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GACzC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}