@sbb-esta/lyne-elements-experimental 0.53.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{constants-ClrwyPF-.js → constants-DSR8hPvP.js} +10 -6
- package/core/datetime.js +65 -72
- package/core/timetable/timetable-helper.d.ts +7 -3
- package/core/timetable/timetable-helper.d.ts.map +1 -1
- package/custom-elements.json +8 -26
- package/development/{constants-D72r1E-c.js → constants-BMGwMkN3.js} +10 -2
- package/development/core/datetime.js +4 -11
- package/development/core/timetable/timetable-helper.d.ts +7 -3
- package/development/core/timetable/timetable-helper.d.ts.map +1 -1
- package/development/differenceInMinutes-DHtPDiUE.js +30 -0
- package/development/{format-BOXfsJCN.js → format-DkbylFCM.js} +3 -3
- package/development/{isValid-YTpbhEHG.js → isValid-BVccOlli.js} +2 -10
- package/development/journey-summary.js +9 -3
- package/development/pearl-chain/pearl-chain.d.ts.map +1 -1
- package/development/pearl-chain/pearl-chain.sample-data.d.ts +21 -3
- package/development/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
- package/development/pearl-chain-time.js +8 -2
- package/development/pearl-chain-vertical-item.js +7 -1
- package/development/pearl-chain-vertical.js +7 -1
- package/development/pearl-chain.js +42 -20
- package/development/teaser-hero.js +7 -1
- package/development/teaser-paid.js +7 -1
- package/development/timetable-duration.js +7 -1
- package/development/timetable-row/timetable-row.d.ts +0 -1
- package/development/timetable-row/timetable-row.d.ts.map +1 -1
- package/development/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
- package/development/timetable-row.js +16 -22
- package/differenceInMinutes-BhHyuJc4.js +28 -0
- package/{format-qHhIvnY8.js → format-fWxoS2xH.js} +2 -2
- package/{isValid-Df_caLp4.js → isValid-DSjxf8eh.js} +9 -13
- package/journey-summary.js +2 -2
- package/package.json +2 -2
- package/pearl-chain/pearl-chain.d.ts.map +1 -1
- package/pearl-chain/pearl-chain.sample-data.d.ts +21 -3
- package/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
- package/pearl-chain-time.js +1 -1
- package/pearl-chain.js +106 -99
- package/timetable-row/timetable-row.d.ts +0 -1
- package/timetable-row/timetable-row.d.ts.map +1 -1
- package/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
- package/timetable-row.js +124 -138
- package/development/differenceInMinutes-D47vcSvy.js +0 -21
- package/differenceInMinutes-CDpgJIgL.js +0 -19
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
|
|
2
2
|
import { defaultDateAdapter } from "@sbb-esta/lyne-elements/core/datetime.js";
|
|
3
3
|
import { setOrRemoveAttribute } from "@sbb-esta/lyne-elements/core/dom.js";
|
|
4
|
-
import { i18nTripQuayChange,
|
|
4
|
+
import { i18nTripQuayChange, i18nFromPlatform, i18nDeparture, i18nMeansOfTransport, i18nDirection, i18nRealTimeInfo, i18nSupersaver, i18nTransferProcedures, i18nArrival, i18nClass, i18nOccupancy, i18nTravelhints, i18nTripDuration, i18nNew } from "@sbb-esta/lyne-elements/core/i18n.js";
|
|
5
5
|
import { css, html, LitElement, nothing } from "lit";
|
|
6
6
|
import { property, customElement } from "lit/decorators.js";
|
|
7
7
|
import { removeTimezoneFromISOTimeString, durationToTime } from "./core/datetime.js";
|
|
@@ -10,7 +10,7 @@ import "@sbb-esta/lyne-elements/card.js";
|
|
|
10
10
|
import "@sbb-esta/lyne-elements/icon.js";
|
|
11
11
|
import "@sbb-esta/lyne-elements/timetable-occupancy.js";
|
|
12
12
|
import "./pearl-chain-time.js";
|
|
13
|
-
import { f as format } from "./format-
|
|
13
|
+
import { f as format } from "./format-DkbylFCM.js";
|
|
14
14
|
const style = css`/**
|
|
15
15
|
* Better font rendering (on OS X)
|
|
16
16
|
* http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
|
|
@@ -25,6 +25,12 @@ const style = css`/**
|
|
|
25
25
|
* }
|
|
26
26
|
*/
|
|
27
27
|
/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
|
|
28
|
+
/*
|
|
29
|
+
* SBB table mixin
|
|
30
|
+
* Notes:
|
|
31
|
+
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
32
|
+
* Therefore, we have to build the grid avoiding double borders.
|
|
33
|
+
*/
|
|
28
34
|
*,
|
|
29
35
|
::before,
|
|
30
36
|
::after {
|
|
@@ -417,27 +423,15 @@ let SbbTimetableRowElement = class extends LitElement {
|
|
|
417
423
|
</sbb-card>
|
|
418
424
|
`;
|
|
419
425
|
}
|
|
420
|
-
_getQuayType(vehicleMode) {
|
|
421
|
-
switch (vehicleMode) {
|
|
422
|
-
case "TRAIN":
|
|
423
|
-
return i18nFromPlatform;
|
|
424
|
-
case "SHIP":
|
|
425
|
-
return i18nFromPier;
|
|
426
|
-
case "TRAMWAY":
|
|
427
|
-
return i18nFromStand;
|
|
428
|
-
case "BUS":
|
|
429
|
-
return i18nFromStand;
|
|
430
|
-
default:
|
|
431
|
-
return void 0;
|
|
432
|
-
}
|
|
433
|
-
}
|
|
434
426
|
_getQuayTypeStrings() {
|
|
435
|
-
var _a, _b;
|
|
427
|
+
var _a, _b, _c;
|
|
436
428
|
if (!((_a = this.trip.summary) == null ? void 0 : _a.product)) return null;
|
|
437
|
-
const
|
|
429
|
+
const rideLegs = (_b = this.trip.legs) == null ? void 0 : _b.filter((leg) => isRideLeg(leg));
|
|
430
|
+
const isShort = ((_c = this.trip.summary.product) == null ? void 0 : _c.vehicleMode) === "TRAIN";
|
|
431
|
+
const short = isShort ? rideLegs[0].serviceJourney.quayTypeShortName || "" : rideLegs[0].serviceJourney.quayTypeName || "";
|
|
438
432
|
return {
|
|
439
|
-
long:
|
|
440
|
-
short
|
|
433
|
+
long: i18nFromPlatform[this._language.current] + " " + short,
|
|
434
|
+
short
|
|
441
435
|
};
|
|
442
436
|
}
|
|
443
437
|
/** map Quay */
|
|
@@ -589,7 +583,7 @@ let SbbTimetableRowElement = class extends LitElement {
|
|
|
589
583
|
.now=${this.now}
|
|
590
584
|
></sbb-pearl-chain-time>
|
|
591
585
|
<div class="sbb-timetable__row-footer" role="gridcell">
|
|
592
|
-
${product &&
|
|
586
|
+
${product && (departure == null ? void 0 : departure.quayFormatted) ? html`<span
|
|
593
587
|
class=${(departure == null ? void 0 : departure.quayChanged) ? `sbb-timetable__row-quay--changed` : nothing}
|
|
594
588
|
>
|
|
595
589
|
<span class="sbb-screen-reader-only">
|
|
@@ -684,4 +678,4 @@ export {
|
|
|
684
678
|
renderStringProduct,
|
|
685
679
|
sortSituation
|
|
686
680
|
};
|
|
687
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"timetable-row.js","sources":["../../../src/elements-experimental/timetable-row/timetable-row.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { setOrRemoveAttribute } from '@sbb-esta/lyne-elements/core/dom.js';\nimport {\n  i18nArrival,\n  i18nClass,\n  i18nDeparture,\n  i18nDirection,\n  i18nFromPier,\n  i18nFromPlatform,\n  i18nFromStand,\n  i18nMeansOfTransport,\n  i18nNew,\n  i18nOccupancy,\n  i18nRealTimeInfo,\n  i18nSupersaver,\n  i18nTransferProcedures,\n  i18nTravelhints,\n  i18nTripDuration,\n  i18nTripQuayChange,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike, SbbOccupancy } from '@sbb-esta/lyne-elements/core/interfaces.js';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { durationToTime, removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { ITripItem, Notice, PtRideLeg, PtSituation } from '../core/timetable.js';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.js';\n\nimport style from './timetable-row.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/card.js';\nimport '@sbb-esta/lyne-elements/icon.js';\nimport '@sbb-esta/lyne-elements/timetable-occupancy.js';\nimport '../pearl-chain-time.js';\n\n/** HimCus interface for mapped icon name and text */\nexport interface HimCus {\n  name: string;\n  text?: string | null;\n}\n\n/** Boarding icon interface for mapped icon name and text */\nexport interface Boarding {\n  name: string;\n  text: string;\n}\n\nexport interface Price {\n  price?: string;\n  text?: string;\n  isDiscount?: boolean;\n}\n\nexport const renderIconProduct = (icon: string, name: string): TemplateResult => {\n  return html`<span class=\"sbb-timetable__row-transport\">\n    <sbb-icon name=${icon}></sbb-icon>\n    <span class=\"sbb-screen-reader-only\">${name}</span>\n  </span>`;\n};\n\nexport const renderStringProduct = (vehicleName: string, line?: string | null): TemplateResult => {\n  const space = ['M', 'B', 'T'].includes(vehicleName) ? ' ' : '';\n  return html`<span class=\"sbb-timetable__row-transportnumber\">\n    ${line !== null ? vehicleName + space + line : vehicleName}\n  </span>`;\n};\n\nconst getReachableText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.reachableText)?.serviceJourney\n    ?.serviceAlteration?.reachableText;\n};\n\nconst getDelayText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.delayText)?.serviceJourney\n    ?.serviceAlteration?.delayText;\n};\n\nconst getRedirectedText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.redirectedText)\n    ?.serviceJourney?.serviceAlteration?.redirectedText;\n};\n\nconst getUnplannedStop = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.unplannedStopPointsText)\n    ?.serviceJourney?.serviceAlteration?.unplannedStopPointsText;\n};\n\nexport const sortSituation = (situations: PtSituation[]): PtSituation[] => {\n  const priorities = {\n    DISTURBANCE: 0,\n    INFORMATION: 1,\n    DELAY: 2,\n    TRAIN_REPLACEMENT_BY_BUS: 3,\n    CONSTRUCTION_SITE: 4,\n    END_MESSAGE: 5,\n  };\n\n  return [...situations]?.sort(\n    (a: PtSituation, b: PtSituation) => priorities[a.cause!] - priorities[b.cause!],\n  );\n};\n\nexport const getHimIcon = (situation: PtSituation): HimCus => {\n  switch (situation?.cause) {\n    case 'DISTURBANCE':\n      return {\n        name: 'disruption',\n        text: situation?.broadcastMessages?.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'INFORMATION':\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'DELAY':\n      return {\n        name: 'delay',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'TRAIN_REPLACEMENT_BY_BUS':\n      return {\n        name: 'replacementbus',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'CONSTRUCTION_SITE':\n      return {\n        name: 'construction',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    default:\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n  }\n};\n\nexport const getCus = (trip: ITripItem, currentLanguage: string): HimCus => {\n  const { summary, legs } = trip || {};\n  const rideLegs = legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n  const { tripStatus } = summary || {};\n\n  if (tripStatus?.cancelled || tripStatus?.partiallyCancelled)\n    return { name: 'cancellation', text: tripStatus?.cancelledText };\n  if (getReachableText(rideLegs))\n    return { name: 'missed-connection', text: getReachableText(rideLegs) };\n  if (tripStatus?.alternative) return { name: 'alternative', text: tripStatus.alternativeText };\n  if (getRedirectedText(rideLegs)) return { name: 'reroute', text: getRedirectedText(rideLegs) };\n  if (getUnplannedStop(rideLegs)) return { name: 'add-stop', text: getUnplannedStop(rideLegs) };\n  if (tripStatus?.delayed || tripStatus?.delayedUnknown)\n    return { name: 'delay', text: getDelayText(rideLegs) };\n  if (tripStatus?.quayChanged) {\n    const departure = rideLegs[0].departure;\n    return {\n      name: 'platform-change',\n      text: departure.quayChanged ? departure.quayChangedText : i18nTripQuayChange[currentLanguage],\n    };\n  }\n\n  return {} as HimCus;\n};\n\nconst findAndReplaceNotice = (notices: Notice[]): Notice | undefined => {\n  const reservationNotice = ['RR', 'RK', 'RC', 'RL', 'RM', 'RS', 'RU', 'XP', 'XR', 'XT'];\n\n  return notices.reduce((foundNotice: Notice | undefined, notice: Notice): Notice | undefined => {\n    if (foundNotice) return foundNotice;\n    if (reservationNotice.includes(notice.name)) {\n      return { ...notice, name: 'RR' } as Notice;\n    }\n  }, undefined);\n};\n\nexport const filterNotices = (notices: Notice[]): Notice[] => {\n  const allowedNames = ['Z', 'SB', 'SZ', 'VR', 'TG'];\n\n  const filterNotice = notices.filter((notice, index) => {\n    return notices.findIndex((n) => n.name === notice.name) === index;\n  });\n\n  return filterNotice\n    .filter((notice) => allowedNames.includes(notice.name))\n    .sort((a, b) => allowedNames.indexOf(a.name) - allowedNames.indexOf(b.name));\n};\n\nexport const handleNotices = (notices: Notice[]): Notice[] => {\n  const reservationNotice = findAndReplaceNotice(notices);\n  const filteredNotices = filterNotices(notices);\n\n  if (reservationNotice === undefined) return filteredNotices;\n  if (!filteredNotices.length) return [reservationNotice];\n\n  if (filteredNotices[0].name === 'Z' && filteredNotices[1]) {\n    return [filteredNotices[0], reservationNotice, filteredNotices[1]].concat(\n      filteredNotices.slice(2),\n    );\n  }\n\n  return [reservationNotice, ...filteredNotices];\n};\n\n/**\n * It displays information about the trip, acting as a container for all the `sbb-timetable-*` components.\n * */\n@customElement('sbb-timetable-row')\nexport class SbbTimetableRowElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** The trip Prop. */\n  @property({ type: Object }) public trip!: ITripItem;\n\n  /** The price Prop, which consists of the data for the badge. */\n  @property({ type: Object }) public price?: Price;\n\n  /** This will be forwarded to the sbb-pearl-chain component - if true the position won't be animated. */\n  @property({ attribute: 'disable-animation', reflect: true, type: Boolean })\n  public disableAnimation?: boolean;\n\n  /** This will be forwarded to the notices section */\n  @property({ type: Object }) public boarding?: Boarding;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @property({ attribute: 'loading-trip', type: Boolean }) public loadingTrip = false;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @property({ attribute: 'loading-price', type: Boolean }) public loadingPrice = false;\n\n  /**\n   * Hidden label for the card action. It overrides the automatically generated accessibility text for the component. Use this prop to provide custom accessibility information for the component.\n   */\n  @property({ attribute: 'card-action-label' }) public cardActionLabel?: string;\n\n  /** This will be forwarded to the sbb-card component as aria-expanded. */\n  @property({ attribute: 'accessibility-expanded', type: Boolean })\n  public accessibilityExpanded?: boolean;\n\n  /** When this prop is true the sbb-card will be in the active state. */\n  @property({ type: Boolean }) public active?: 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 {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('loadingTrip')) {\n      setOrRemoveAttribute(this, 'role', !this.loadingTrip ? 'rowgroup' : null);\n    }\n  }\n\n  /** The skeleton render function for the loading state */\n  private _renderSkeleton(): TemplateResult {\n    return html`\n      <sbb-card size=\"l\" class=\"sbb-loading\">\n        ${this.loadingPrice\n          ? html`<sbb-card-badge class=\"sbb-loading__badge\"></sbb-card-badge>`\n          : nothing}\n        <div class=\"sbb-loading__wrapper\">\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n        </div>\n      </sbb-card>\n    `;\n  }\n\n  private _getQuayType(vehicleMode: string): any {\n    switch (vehicleMode) {\n      case 'TRAIN':\n        return i18nFromPlatform;\n      case 'SHIP':\n        return i18nFromPier;\n      case 'TRAMWAY':\n        return i18nFromStand;\n      case 'BUS':\n        return i18nFromStand;\n      default:\n        return undefined;\n    }\n  }\n\n  private _getQuayTypeStrings(): { long: string; short: string } | null {\n    if (!this.trip.summary?.product) return null;\n    const quayType = this._getQuayType(this.trip.summary.product?.vehicleMode);\n    return {\n      long: quayType?.long[this._language.current],\n      short: quayType?.short[this._language.current],\n    };\n  }\n\n  /** map Quay */\n  private _renderQuayType(): TemplateResult | undefined {\n    if (!this.trip.summary?.product) return undefined;\n    const quayTypeStrings = this._getQuayTypeStrings();\n    return html`\n      <span class=\"sbb-timetable__row--quay\">\n        <span class=\"sbb-screen-reader-only\">${quayTypeStrings?.long}&nbsp;</span>\n        <span class=\"sbb-timetable__row--quay-type\" aria-hidden=\"true\"\n          >${quayTypeStrings?.short}</span\n        >\n      </span>\n    `;\n  }\n\n  private _handleHimCus(trip: ITripItem): { cus: HimCus | null; him: HimCus | null } {\n    const { situations } = trip || {};\n    const sortedSituations = situations && sortSituation(situations);\n    const cus = getCus(trip, this._language.current);\n\n    return {\n      cus: Object.keys(cus)?.length ? cus : null,\n      him: situations?.length ? getHimIcon(sortedSituations[0]) : null,\n    };\n  }\n\n  private _getAccessibilityText(trip: ITripItem): string {\n    const { summary, legs, notices } = trip || {};\n    const {\n      departureWalk,\n      arrivalWalk,\n      departure,\n      arrival,\n      product,\n      direction,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const { departureTimeAttribute, arrivalTimeAttribute } = getDepartureArrivalTimeAttribute(\n      legs,\n      departureWalk || 0,\n      arrivalWalk || 0,\n      this._language.current,\n    );\n\n    const departureTime: Date | undefined = departure?.time\n      ? removeTimezoneFromISOTimeString(departure.time)\n      : undefined;\n\n    const arrivalTime: Date | undefined = arrival?.time\n      ? removeTimezoneFromISOTimeString(arrival.time)\n      : undefined;\n\n    const departureWalkText = departureTimeAttribute\n      ? `${departureTimeAttribute.text} ${departureTimeAttribute.duration}, `\n      : '';\n\n    const arrivalWalkText = arrivalTimeAttribute\n      ? `${arrivalTimeAttribute.text} ${arrivalTimeAttribute.duration}, `\n      : '';\n\n    const departureTimeText = departureTime\n      ? `${i18nDeparture[this._language.current]}: ${format(departureTime, 'HH:mm')}, `\n      : '';\n\n    const getDepartureQuayText = (): string => {\n      if (!departure?.quayFormatted) {\n        return '';\n      }\n\n      // add prefix \"new\" if quay was changed\n      const changedQuayPrefix = departure?.quayChanged ? `${i18nNew[this._language.current]} ` : '';\n      return `${changedQuayPrefix}${\n        this._getQuayTypeStrings()?.long\n      } ${departure?.quayFormatted}, `;\n    };\n\n    const meansOfTransportText =\n      product && product.vehicleMode\n        ? i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n          `${i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}, `\n        : '';\n\n    const vehicleSubModeText = product?.vehicleSubModeShortName\n      ? `${product.vehicleSubModeShortName} ${product.line || ''}, `\n      : '';\n\n    const directionText = `${i18nDirection[this._language.current]} ${direction}, `;\n\n    const himCus = this._handleHimCus(trip);\n    const cusText = himCus?.cus?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.cus?.text}, `\n      : '';\n    const himText = himCus?.him?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.him?.text}, `\n      : '';\n\n    const boardingText = this.boarding ? `${this.boarding.text}, ` : '';\n\n    const priceText = `${this.price?.isDiscount ? i18nSupersaver[this._language.current] : ''} ${\n      this.price?.text && this.price?.price\n        ? (this.price?.text || '') + ' ' + (this.price?.price || '') + ', '\n        : ''\n    }`;\n\n    const transferProcedures =\n      legs?.length > 1\n        ? `${legs?.length - 1} ${i18nTransferProcedures[this._language.current]}, `\n        : '';\n\n    const arrivalTimeText = arrivalTime\n      ? `${i18nArrival[this._language.current]}: ${format(arrivalTime, 'HH:mm')}, `\n      : '';\n\n    let occupancyText: string = '';\n    if (occupancy) {\n      if (occupancy.firstClass && occupancy.firstClass !== 'UNKNOWN') {\n        occupancyText += `${i18nClass.first[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.firstClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n      if (occupancy.secondClass && occupancy.secondClass !== 'UNKNOWN') {\n        occupancyText += ` ${i18nClass.second[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.secondClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n    }\n\n    const attributes =\n      notices &&\n      handleNotices(notices).length &&\n      handleNotices(notices)\n        ?.map((notice, index) => index < 4 && notice.text?.template)\n        .join(', ') + ', ';\n\n    const attributesText = attributes\n      ? `${i18nTravelhints[this._language.current]}: ${attributes}`\n      : '';\n\n    const durationText =\n      !!duration && duration > 0\n        ? `${i18nTripDuration[this._language.current]} ${\n            durationToTime(duration, this._language.current).long\n          }, `\n        : '';\n\n    return `${departureWalkText} ${departureTimeText} ${getDepartureQuayText()} ${meansOfTransportText} ${vehicleSubModeText} ${directionText} ${cusText} ${boardingText} ${priceText} ${\n      cusText ? '' : himText\n    } ${arrivalTimeText} ${arrivalWalkText} ${durationText} ${transferProcedures} ${occupancyText} ${attributesText}`;\n  }\n\n  protected override render(): TemplateResult {\n    if (this.loadingTrip) {\n      return this._renderSkeleton();\n    }\n\n    const { legs, id, notices, summary } = this.trip || {};\n\n    const {\n      product,\n      direction,\n      departureWalk,\n      departure,\n      arrival,\n      arrivalWalk,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const himCus = this._handleHimCus(this.trip);\n    const hasHimCus = !!himCus.cus || !!himCus.him;\n\n    const noticeAttributes = notices && handleNotices(notices);\n\n    const durationObj = duration ? durationToTime(duration, this._language.current) : null;\n\n    return html`\n      <sbb-card size=\"l\" id=${id}>\n        <sbb-card-button\n          ?active=${this.active}\n          aria-expanded=${this.accessibilityExpanded?.toString() ?? nothing}\n        >\n          ${this.cardActionLabel ? this.cardActionLabel : this._getAccessibilityText(this.trip)}\n        </sbb-card-button>\n        ${this.loadingPrice\n          ? html`<sbb-card-badge class=\"sbb-loading__badge\"></sbb-card-badge>`\n          : nothing}\n        ${this.price && !this.loadingPrice\n          ? html`<sbb-card-badge color=${this.price.isDiscount ? 'charcoal' : 'white'}>\n              ${this.price.isDiscount\n                ? html`<span aria-hidden=\"true\">\n                    %<span class=\"sbb-screen-reader-only\"\n                      >${i18nSupersaver[this._language.current]}</span\n                    >\n                  </span>`\n                : nothing}\n              ${this.price.text ? html`<span>${this.price.text}</span>` : nothing}\n              ${this.price.price ? html`<span>${this.price.price}</span>` : nothing}\n            </sbb-card-badge>`\n          : nothing}\n        <div class=\"sbb-timetable__row\" role=\"row\">\n          <div class=\"sbb-timetable__row-header\" role=\"gridcell\">\n            <div class=\"sbb-timetable__row-details\">\n              ${product?.corporateIdentityPictogram &&\n              html`<span class=\"sbb-timetable__row-transport-wrapper\">\n                <sbb-icon\n                  class=\"sbb-timetable__row-transport-icon\"\n                  name=\"picto:${product.corporateIdentityPictogram}\"\n                ></sbb-icon>\n                <span class=\"sbb-screen-reader-only\">\n                  ${product &&\n                  product.vehicleMode &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}\n                  &nbsp;\n                </span>\n              </span>`}\n              ${product &&\n              (product.corporateIdentityIcon\n                ? renderIconProduct(product.corporateIdentityIcon, product.name)\n                : product.vehicleSubModeShortName &&\n                  renderStringProduct(product.vehicleSubModeShortName, product?.line))}\n            </div>\n            ${direction\n              ? html`<p>${`${i18nDirection[this._language.current]} ${direction}`}</p>`\n              : nothing}\n          </div>\n          <sbb-pearl-chain-time\n            role=\"gridcell\"\n            .legs=${legs}\n            .departureTime=${departure?.time}\n            .arrivalTime=${arrival?.time}\n            .departureWalk=${departureWalk}\n            .arrivalWalk=${arrivalWalk}\n            ?disable-animation=${this.disableAnimation}\n            .now=${this.now}\n          ></sbb-pearl-chain-time>\n          <div class=\"sbb-timetable__row-footer\" role=\"gridcell\">\n            ${product && this._getQuayType(product.vehicleMode) && departure?.quayFormatted\n              ? html`<span\n                  class=${departure?.quayChanged ? `sbb-timetable__row-quay--changed` : nothing}\n                >\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nDeparture[this._language.current]} ${\n                      departure?.quayChanged ? i18nNew[this._language.current] : ''\n                    }`}\n                    &nbsp;\n                  </span>\n                  ${this._renderQuayType()} ${departure?.quayFormatted}\n                </span>`\n              : nothing}\n            ${(occupancy?.firstClass && occupancy?.firstClass !== 'UNKNOWN') ||\n            (occupancy?.secondClass && occupancy.secondClass !== 'UNKNOWN')\n              ? html`<sbb-timetable-occupancy\n                  .firstClassOccupancy=${occupancy?.firstClass?.toLowerCase()}\n                  .secondClassOccupancy=${occupancy?.secondClass?.toLowerCase()}\n                ></sbb-timetable-occupancy>`\n              : nothing}\n            ${(noticeAttributes && noticeAttributes.length) || this.boarding\n              ? html`<ul class=\"sbb-timetable__row-hints\" role=\"list\">\n                  ${noticeAttributes?.map((notice, index) =>\n                    index < 4\n                      ? html`<li>\n                          <sbb-icon\n                            class=\"sbb-travel-hints__item\"\n                            name=${'sa-' + notice.name?.toLowerCase()}\n                          ></sbb-icon>\n                          <span class=\"sbb-screen-reader-only\">${notice.text?.template}</span>\n                        </li>`\n                      : nothing,\n                  )}\n                  ${this.boarding\n                    ? html`<li>\n                        <sbb-icon\n                          class=\"sbb-travel-hints__item\"\n                          name=${this.boarding?.name}\n                          aria-label=${this.boarding?.text}\n                          aria-hidden=\"false\"\n                        ></sbb-icon>\n                      </li>`\n                    : nothing}\n                </ul>`\n              : nothing}\n            ${duration && duration > 0\n              ? html`<time>\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nTripDuration[this._language.current]} ${durationObj!.long}`}\n                  </span>\n                  <span aria-hidden=\"true\">${durationObj!.short}</span>\n                </time>`\n              : nothing}\n            ${hasHimCus && (himCus.cus || himCus.him)\n              ? html`<span class=\"sbb-timetable__row-warning\">\n                  <sbb-icon name=${(himCus.cus || himCus.him)!.name}></sbb-icon>\n                  <span class=\"sbb-screen-reader-only\">${(himCus.cus || himCus.him)!.text}</span>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </sbb-card>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-timetable-row': SbbTimetableRowElement;\n  }\n}\n"],"names":["_b","_a"],"mappings":"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"}
|
|
681
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"timetable-row.js","sources":["../../../src/elements-experimental/timetable-row/timetable-row.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { setOrRemoveAttribute } from '@sbb-esta/lyne-elements/core/dom.js';\nimport {\n  i18nArrival,\n  i18nClass,\n  i18nDeparture,\n  i18nDirection,\n  i18nFromPlatform,\n  i18nMeansOfTransport,\n  i18nNew,\n  i18nOccupancy,\n  i18nRealTimeInfo,\n  i18nSupersaver,\n  i18nTransferProcedures,\n  i18nTravelhints,\n  i18nTripDuration,\n  i18nTripQuayChange,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike, SbbOccupancy } from '@sbb-esta/lyne-elements/core/interfaces.js';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { durationToTime, removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { ITripItem, Notice, PtRideLeg, PtSituation } from '../core/timetable.js';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.js';\n\nimport style from './timetable-row.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/card.js';\nimport '@sbb-esta/lyne-elements/icon.js';\nimport '@sbb-esta/lyne-elements/timetable-occupancy.js';\nimport '../pearl-chain-time.js';\n\n/** HimCus interface for mapped icon name and text */\nexport interface HimCus {\n  name: string;\n  text?: string | null;\n}\n\n/** Boarding icon interface for mapped icon name and text */\nexport interface Boarding {\n  name: string;\n  text: string;\n}\n\nexport interface Price {\n  price?: string;\n  text?: string;\n  isDiscount?: boolean;\n}\n\nexport const renderIconProduct = (icon: string, name: string): TemplateResult => {\n  return html`<span class=\"sbb-timetable__row-transport\">\n    <sbb-icon name=${icon}></sbb-icon>\n    <span class=\"sbb-screen-reader-only\">${name}</span>\n  </span>`;\n};\n\nexport const renderStringProduct = (vehicleName: string, line?: string | null): TemplateResult => {\n  const space = ['M', 'B', 'T'].includes(vehicleName) ? ' ' : '';\n  return html`<span class=\"sbb-timetable__row-transportnumber\">\n    ${line !== null ? vehicleName + space + line : vehicleName}\n  </span>`;\n};\n\nconst getReachableText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.reachableText)?.serviceJourney\n    ?.serviceAlteration?.reachableText;\n};\n\nconst getDelayText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.delayText)?.serviceJourney\n    ?.serviceAlteration?.delayText;\n};\n\nconst getRedirectedText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.redirectedText)\n    ?.serviceJourney?.serviceAlteration?.redirectedText;\n};\n\nconst getUnplannedStop = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.unplannedStopPointsText)\n    ?.serviceJourney?.serviceAlteration?.unplannedStopPointsText;\n};\n\nexport const sortSituation = (situations: PtSituation[]): PtSituation[] => {\n  const priorities = {\n    DISTURBANCE: 0,\n    INFORMATION: 1,\n    DELAY: 2,\n    TRAIN_REPLACEMENT_BY_BUS: 3,\n    CONSTRUCTION_SITE: 4,\n    END_MESSAGE: 5,\n  };\n\n  return [...situations]?.sort(\n    (a: PtSituation, b: PtSituation) => priorities[a.cause!] - priorities[b.cause!],\n  );\n};\n\nexport const getHimIcon = (situation: PtSituation): HimCus => {\n  switch (situation?.cause) {\n    case 'DISTURBANCE':\n      return {\n        name: 'disruption',\n        text: situation?.broadcastMessages?.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'INFORMATION':\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'DELAY':\n      return {\n        name: 'delay',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'TRAIN_REPLACEMENT_BY_BUS':\n      return {\n        name: 'replacementbus',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'CONSTRUCTION_SITE':\n      return {\n        name: 'construction',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    default:\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n  }\n};\n\nexport const getCus = (trip: ITripItem, currentLanguage: string): HimCus => {\n  const { summary, legs } = trip || {};\n  const rideLegs = legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n  const { tripStatus } = summary || {};\n\n  if (tripStatus?.cancelled || tripStatus?.partiallyCancelled)\n    return { name: 'cancellation', text: tripStatus?.cancelledText };\n  if (getReachableText(rideLegs))\n    return { name: 'missed-connection', text: getReachableText(rideLegs) };\n  if (tripStatus?.alternative) return { name: 'alternative', text: tripStatus.alternativeText };\n  if (getRedirectedText(rideLegs)) return { name: 'reroute', text: getRedirectedText(rideLegs) };\n  if (getUnplannedStop(rideLegs)) return { name: 'add-stop', text: getUnplannedStop(rideLegs) };\n  if (tripStatus?.delayed || tripStatus?.delayedUnknown)\n    return { name: 'delay', text: getDelayText(rideLegs) };\n  if (tripStatus?.quayChanged) {\n    const departure = rideLegs[0].departure;\n    return {\n      name: 'platform-change',\n      text: departure.quayChanged ? departure.quayChangedText : i18nTripQuayChange[currentLanguage],\n    };\n  }\n\n  return {} as HimCus;\n};\n\nconst findAndReplaceNotice = (notices: Notice[]): Notice | undefined => {\n  const reservationNotice = ['RR', 'RK', 'RC', 'RL', 'RM', 'RS', 'RU', 'XP', 'XR', 'XT'];\n\n  return notices.reduce((foundNotice: Notice | undefined, notice: Notice): Notice | undefined => {\n    if (foundNotice) return foundNotice;\n    if (reservationNotice.includes(notice.name)) {\n      return { ...notice, name: 'RR' } as Notice;\n    }\n  }, undefined);\n};\n\nexport const filterNotices = (notices: Notice[]): Notice[] => {\n  const allowedNames = ['Z', 'SB', 'SZ', 'VR', 'TG'];\n\n  const filterNotice = notices.filter((notice, index) => {\n    return notices.findIndex((n) => n.name === notice.name) === index;\n  });\n\n  return filterNotice\n    .filter((notice) => allowedNames.includes(notice.name))\n    .sort((a, b) => allowedNames.indexOf(a.name) - allowedNames.indexOf(b.name));\n};\n\nexport const handleNotices = (notices: Notice[]): Notice[] => {\n  const reservationNotice = findAndReplaceNotice(notices);\n  const filteredNotices = filterNotices(notices);\n\n  if (reservationNotice === undefined) return filteredNotices;\n  if (!filteredNotices.length) return [reservationNotice];\n\n  if (filteredNotices[0].name === 'Z' && filteredNotices[1]) {\n    return [filteredNotices[0], reservationNotice, filteredNotices[1]].concat(\n      filteredNotices.slice(2),\n    );\n  }\n\n  return [reservationNotice, ...filteredNotices];\n};\n\n/**\n * It displays information about the trip, acting as a container for all the `sbb-timetable-*` components.\n * */\n@customElement('sbb-timetable-row')\nexport class SbbTimetableRowElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** The trip Prop. */\n  @property({ type: Object }) public trip!: ITripItem;\n\n  /** The price Prop, which consists of the data for the badge. */\n  @property({ type: Object }) public price?: Price;\n\n  /** This will be forwarded to the sbb-pearl-chain component - if true the position won't be animated. */\n  @property({ attribute: 'disable-animation', reflect: true, type: Boolean })\n  public disableAnimation?: boolean;\n\n  /** This will be forwarded to the notices section */\n  @property({ type: Object }) public boarding?: Boarding;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @property({ attribute: 'loading-trip', type: Boolean }) public loadingTrip = false;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @property({ attribute: 'loading-price', type: Boolean }) public loadingPrice = false;\n\n  /**\n   * Hidden label for the card action. It overrides the automatically generated accessibility text for the component. Use this prop to provide custom accessibility information for the component.\n   */\n  @property({ attribute: 'card-action-label' }) public cardActionLabel?: string;\n\n  /** This will be forwarded to the sbb-card component as aria-expanded. */\n  @property({ attribute: 'accessibility-expanded', type: Boolean })\n  public accessibilityExpanded?: boolean;\n\n  /** When this prop is true the sbb-card will be in the active state. */\n  @property({ type: Boolean }) public active?: 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 {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('loadingTrip')) {\n      setOrRemoveAttribute(this, 'role', !this.loadingTrip ? 'rowgroup' : null);\n    }\n  }\n\n  /** The skeleton render function for the loading state */\n  private _renderSkeleton(): TemplateResult {\n    return html`\n      <sbb-card size=\"l\" class=\"sbb-loading\">\n        ${this.loadingPrice\n          ? html`<sbb-card-badge class=\"sbb-loading__badge\"></sbb-card-badge>`\n          : nothing}\n        <div class=\"sbb-loading__wrapper\">\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n        </div>\n      </sbb-card>\n    `;\n  }\n\n  private _getQuayTypeStrings(): { long: string; short: string } | null {\n    if (!this.trip.summary?.product) return null;\n    const rideLegs = this.trip.legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n    const isShort = this.trip.summary.product?.vehicleMode === 'TRAIN';\n    const short = isShort\n      ? rideLegs[0].serviceJourney.quayTypeShortName || ''\n      : rideLegs[0].serviceJourney.quayTypeName || '';\n\n    return {\n      long: i18nFromPlatform[this._language.current] + ' ' + short,\n      short,\n    };\n  }\n\n  /** map Quay */\n  private _renderQuayType(): TemplateResult | undefined {\n    if (!this.trip.summary?.product) return undefined;\n    const quayTypeStrings = this._getQuayTypeStrings();\n    return html`\n      <span class=\"sbb-timetable__row--quay\">\n        <span class=\"sbb-screen-reader-only\">${quayTypeStrings?.long}&nbsp;</span>\n        <span class=\"sbb-timetable__row--quay-type\" aria-hidden=\"true\"\n          >${quayTypeStrings?.short}</span\n        >\n      </span>\n    `;\n  }\n\n  private _handleHimCus(trip: ITripItem): { cus: HimCus | null; him: HimCus | null } {\n    const { situations } = trip || {};\n    const sortedSituations = situations && sortSituation(situations);\n    const cus = getCus(trip, this._language.current);\n\n    return {\n      cus: Object.keys(cus)?.length ? cus : null,\n      him: situations?.length ? getHimIcon(sortedSituations[0]) : null,\n    };\n  }\n\n  private _getAccessibilityText(trip: ITripItem): string {\n    const { summary, legs, notices } = trip || {};\n    const {\n      departureWalk,\n      arrivalWalk,\n      departure,\n      arrival,\n      product,\n      direction,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const { departureTimeAttribute, arrivalTimeAttribute } = getDepartureArrivalTimeAttribute(\n      legs,\n      departureWalk || 0,\n      arrivalWalk || 0,\n      this._language.current,\n    );\n\n    const departureTime: Date | undefined = departure?.time\n      ? removeTimezoneFromISOTimeString(departure.time)\n      : undefined;\n\n    const arrivalTime: Date | undefined = arrival?.time\n      ? removeTimezoneFromISOTimeString(arrival.time)\n      : undefined;\n\n    const departureWalkText = departureTimeAttribute\n      ? `${departureTimeAttribute.text} ${departureTimeAttribute.duration}, `\n      : '';\n\n    const arrivalWalkText = arrivalTimeAttribute\n      ? `${arrivalTimeAttribute.text} ${arrivalTimeAttribute.duration}, `\n      : '';\n\n    const departureTimeText = departureTime\n      ? `${i18nDeparture[this._language.current]}: ${format(departureTime, 'HH:mm')}, `\n      : '';\n\n    const getDepartureQuayText = (): string => {\n      if (!departure?.quayFormatted) {\n        return '';\n      }\n\n      // add prefix \"new\" if quay was changed\n      const changedQuayPrefix = departure?.quayChanged ? `${i18nNew[this._language.current]} ` : '';\n      return `${changedQuayPrefix}${\n        this._getQuayTypeStrings()?.long\n      } ${departure?.quayFormatted}, `;\n    };\n\n    const meansOfTransportText =\n      product && product.vehicleMode\n        ? i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n          `${i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}, `\n        : '';\n\n    const vehicleSubModeText = product?.vehicleSubModeShortName\n      ? `${product.vehicleSubModeShortName} ${product.line || ''}, `\n      : '';\n\n    const directionText = `${i18nDirection[this._language.current]} ${direction}, `;\n\n    const himCus = this._handleHimCus(trip);\n    const cusText = himCus?.cus?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.cus?.text}, `\n      : '';\n    const himText = himCus?.him?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.him?.text}, `\n      : '';\n\n    const boardingText = this.boarding ? `${this.boarding.text}, ` : '';\n\n    const priceText = `${this.price?.isDiscount ? i18nSupersaver[this._language.current] : ''} ${\n      this.price?.text && this.price?.price\n        ? (this.price?.text || '') + ' ' + (this.price?.price || '') + ', '\n        : ''\n    }`;\n\n    const transferProcedures =\n      legs?.length > 1\n        ? `${legs?.length - 1} ${i18nTransferProcedures[this._language.current]}, `\n        : '';\n\n    const arrivalTimeText = arrivalTime\n      ? `${i18nArrival[this._language.current]}: ${format(arrivalTime, 'HH:mm')}, `\n      : '';\n\n    let occupancyText: string = '';\n    if (occupancy) {\n      if (occupancy.firstClass && occupancy.firstClass !== 'UNKNOWN') {\n        occupancyText += `${i18nClass.first[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.firstClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n      if (occupancy.secondClass && occupancy.secondClass !== 'UNKNOWN') {\n        occupancyText += ` ${i18nClass.second[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.secondClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n    }\n\n    const attributes =\n      notices &&\n      handleNotices(notices).length &&\n      handleNotices(notices)\n        ?.map((notice, index) => index < 4 && notice.text?.template)\n        .join(', ') + ', ';\n\n    const attributesText = attributes\n      ? `${i18nTravelhints[this._language.current]}: ${attributes}`\n      : '';\n\n    const durationText =\n      !!duration && duration > 0\n        ? `${i18nTripDuration[this._language.current]} ${\n            durationToTime(duration, this._language.current).long\n          }, `\n        : '';\n\n    return `${departureWalkText} ${departureTimeText} ${getDepartureQuayText()} ${meansOfTransportText} ${vehicleSubModeText} ${directionText} ${cusText} ${boardingText} ${priceText} ${\n      cusText ? '' : himText\n    } ${arrivalTimeText} ${arrivalWalkText} ${durationText} ${transferProcedures} ${occupancyText} ${attributesText}`;\n  }\n\n  protected override render(): TemplateResult {\n    if (this.loadingTrip) {\n      return this._renderSkeleton();\n    }\n\n    const { legs, id, notices, summary } = this.trip || {};\n\n    const {\n      product,\n      direction,\n      departureWalk,\n      departure,\n      arrival,\n      arrivalWalk,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const himCus = this._handleHimCus(this.trip);\n    const hasHimCus = !!himCus.cus || !!himCus.him;\n\n    const noticeAttributes = notices && handleNotices(notices);\n\n    const durationObj = duration ? durationToTime(duration, this._language.current) : null;\n\n    return html`\n      <sbb-card size=\"l\" id=${id}>\n        <sbb-card-button\n          ?active=${this.active}\n          aria-expanded=${this.accessibilityExpanded?.toString() ?? nothing}\n        >\n          ${this.cardActionLabel ? this.cardActionLabel : this._getAccessibilityText(this.trip)}\n        </sbb-card-button>\n        ${this.loadingPrice\n          ? html`<sbb-card-badge class=\"sbb-loading__badge\"></sbb-card-badge>`\n          : nothing}\n        ${this.price && !this.loadingPrice\n          ? html`<sbb-card-badge color=${this.price.isDiscount ? 'charcoal' : 'white'}>\n              ${this.price.isDiscount\n                ? html`<span aria-hidden=\"true\">\n                    %<span class=\"sbb-screen-reader-only\"\n                      >${i18nSupersaver[this._language.current]}</span\n                    >\n                  </span>`\n                : nothing}\n              ${this.price.text ? html`<span>${this.price.text}</span>` : nothing}\n              ${this.price.price ? html`<span>${this.price.price}</span>` : nothing}\n            </sbb-card-badge>`\n          : nothing}\n        <div class=\"sbb-timetable__row\" role=\"row\">\n          <div class=\"sbb-timetable__row-header\" role=\"gridcell\">\n            <div class=\"sbb-timetable__row-details\">\n              ${product?.corporateIdentityPictogram &&\n              html`<span class=\"sbb-timetable__row-transport-wrapper\">\n                <sbb-icon\n                  class=\"sbb-timetable__row-transport-icon\"\n                  name=\"picto:${product.corporateIdentityPictogram}\"\n                ></sbb-icon>\n                <span class=\"sbb-screen-reader-only\">\n                  ${product &&\n                  product.vehicleMode &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}\n                  &nbsp;\n                </span>\n              </span>`}\n              ${product &&\n              (product.corporateIdentityIcon\n                ? renderIconProduct(product.corporateIdentityIcon, product.name)\n                : product.vehicleSubModeShortName &&\n                  renderStringProduct(product.vehicleSubModeShortName, product?.line))}\n            </div>\n            ${direction\n              ? html`<p>${`${i18nDirection[this._language.current]} ${direction}`}</p>`\n              : nothing}\n          </div>\n          <sbb-pearl-chain-time\n            role=\"gridcell\"\n            .legs=${legs}\n            .departureTime=${departure?.time}\n            .arrivalTime=${arrival?.time}\n            .departureWalk=${departureWalk}\n            .arrivalWalk=${arrivalWalk}\n            ?disable-animation=${this.disableAnimation}\n            .now=${this.now}\n          ></sbb-pearl-chain-time>\n          <div class=\"sbb-timetable__row-footer\" role=\"gridcell\">\n            ${product && departure?.quayFormatted\n              ? html`<span\n                  class=${departure?.quayChanged ? `sbb-timetable__row-quay--changed` : nothing}\n                >\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nDeparture[this._language.current]} ${\n                      departure?.quayChanged ? i18nNew[this._language.current] : ''\n                    }`}\n                    &nbsp;\n                  </span>\n                  ${this._renderQuayType()} ${departure?.quayFormatted}\n                </span>`\n              : nothing}\n            ${(occupancy?.firstClass && occupancy?.firstClass !== 'UNKNOWN') ||\n            (occupancy?.secondClass && occupancy.secondClass !== 'UNKNOWN')\n              ? html`<sbb-timetable-occupancy\n                  .firstClassOccupancy=${occupancy?.firstClass?.toLowerCase()}\n                  .secondClassOccupancy=${occupancy?.secondClass?.toLowerCase()}\n                ></sbb-timetable-occupancy>`\n              : nothing}\n            ${(noticeAttributes && noticeAttributes.length) || this.boarding\n              ? html`<ul class=\"sbb-timetable__row-hints\" role=\"list\">\n                  ${noticeAttributes?.map((notice, index) =>\n                    index < 4\n                      ? html`<li>\n                          <sbb-icon\n                            class=\"sbb-travel-hints__item\"\n                            name=${'sa-' + notice.name?.toLowerCase()}\n                          ></sbb-icon>\n                          <span class=\"sbb-screen-reader-only\">${notice.text?.template}</span>\n                        </li>`\n                      : nothing,\n                  )}\n                  ${this.boarding\n                    ? html`<li>\n                        <sbb-icon\n                          class=\"sbb-travel-hints__item\"\n                          name=${this.boarding?.name}\n                          aria-label=${this.boarding?.text}\n                          aria-hidden=\"false\"\n                        ></sbb-icon>\n                      </li>`\n                    : nothing}\n                </ul>`\n              : nothing}\n            ${duration && duration > 0\n              ? html`<time>\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nTripDuration[this._language.current]} ${durationObj!.long}`}\n                  </span>\n                  <span aria-hidden=\"true\">${durationObj!.short}</span>\n                </time>`\n              : nothing}\n            ${hasHimCus && (himCus.cus || himCus.him)\n              ? html`<span class=\"sbb-timetable__row-warning\">\n                  <sbb-icon name=${(himCus.cus || himCus.him)!.name}></sbb-icon>\n                  <span class=\"sbb-screen-reader-only\">${(himCus.cus || himCus.him)!.text}</span>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </sbb-card>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-timetable-row': SbbTimetableRowElement;\n  }\n}\n"],"names":["_b","_a"],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { t as u, c as s, b as c } from "./constants-DSR8hPvP.js";
|
|
2
|
+
function i(n, t) {
|
|
3
|
+
const r = +u(n);
|
|
4
|
+
return s(n, r + t);
|
|
5
|
+
}
|
|
6
|
+
function f(n, t) {
|
|
7
|
+
return i(n, t * c);
|
|
8
|
+
}
|
|
9
|
+
function d(n) {
|
|
10
|
+
return (t) => {
|
|
11
|
+
const e = (n ? Math[n] : Math.trunc)(t);
|
|
12
|
+
return e === 0 ? 0 : e;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
function o(n, t) {
|
|
16
|
+
return +u(n) - +u(t);
|
|
17
|
+
}
|
|
18
|
+
function M(n, t, r) {
|
|
19
|
+
const e = o(n, t) / c;
|
|
20
|
+
return d(r == null ? void 0 : r.roundingMethod)(e);
|
|
21
|
+
}
|
|
22
|
+
export {
|
|
23
|
+
f as a,
|
|
24
|
+
i as b,
|
|
25
|
+
o as c,
|
|
26
|
+
M as d,
|
|
27
|
+
d as g
|
|
28
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { t as w, m as q } from "./constants-
|
|
1
|
+
import { d as Q, i as X } from "./isValid-DSjxf8eh.js";
|
|
2
|
+
import { t as w, c as b, m as q } from "./constants-DSR8hPvP.js";
|
|
3
3
|
let L = {};
|
|
4
4
|
function p() {
|
|
5
5
|
return L;
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
import { t as s,
|
|
2
|
-
function
|
|
3
|
-
return e instanceof Date ? new e.constructor(t) : new Date(t);
|
|
4
|
-
}
|
|
5
|
-
function r(e) {
|
|
1
|
+
import { t as s, d as f } from "./constants-DSR8hPvP.js";
|
|
2
|
+
function a(e) {
|
|
6
3
|
const t = s(e);
|
|
7
4
|
return t.setHours(0, 0, 0, 0), t;
|
|
8
5
|
}
|
|
9
|
-
function
|
|
6
|
+
function r(e) {
|
|
10
7
|
const t = s(e), n = new Date(
|
|
11
8
|
Date.UTC(
|
|
12
9
|
t.getFullYear(),
|
|
@@ -20,21 +17,20 @@ function a(e) {
|
|
|
20
17
|
);
|
|
21
18
|
return n.setUTCFullYear(t.getFullYear()), +e - +n;
|
|
22
19
|
}
|
|
23
|
-
function
|
|
24
|
-
const n =
|
|
25
|
-
return Math.round((
|
|
20
|
+
function D(e, t) {
|
|
21
|
+
const n = a(e), o = a(t), i = +n - r(n), c = +o - r(o);
|
|
22
|
+
return Math.round((i - c) / f);
|
|
26
23
|
}
|
|
27
24
|
function u(e) {
|
|
28
25
|
return e instanceof Date || typeof e == "object" && Object.prototype.toString.call(e) === "[object Date]";
|
|
29
26
|
}
|
|
30
|
-
function
|
|
27
|
+
function g(e) {
|
|
31
28
|
if (!u(e) && typeof e != "number")
|
|
32
29
|
return !1;
|
|
33
30
|
const t = s(e);
|
|
34
31
|
return !isNaN(Number(t));
|
|
35
32
|
}
|
|
36
33
|
export {
|
|
37
|
-
D as
|
|
38
|
-
g as
|
|
39
|
-
m as i
|
|
34
|
+
D as d,
|
|
35
|
+
g as i
|
|
40
36
|
};
|
package/journey-summary.js
CHANGED
|
@@ -8,8 +8,8 @@ import "@sbb-esta/lyne-elements/divider.js";
|
|
|
8
8
|
import "@sbb-esta/lyne-elements/screen-reader-only.js";
|
|
9
9
|
import "@sbb-esta/lyne-elements/journey-header.js";
|
|
10
10
|
import "./pearl-chain-time.js";
|
|
11
|
-
import { i as j } from "./isValid-
|
|
12
|
-
import { f as d } from "./format-
|
|
11
|
+
import { i as j } from "./isValid-DSjxf8eh.js";
|
|
12
|
+
import { f as d } from "./format-fWxoS2xH.js";
|
|
13
13
|
const w = v`*,:before,:after{box-sizing:border-box}:host{display:block}.sbb-journey-summary{--sbb-text-font-size: var(--sbb-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);color:var(--sbb-color-iron);display:flex;flex-direction:column}.sbb-journey-summary__via-block{display:flex}.sbb-journey-summary__vias{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;margin-block:0;padding-inline-start:var(--sbb-spacing-fixed-1x)}.sbb-journey-summary__date{margin-block-end:var(--sbb-spacing-fixed-2x)}.sbb-journey-summary__via{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sbb-journey-summary__divider{margin-block:var(--sbb-spacing-fixed-6x)}ul li{list-style:none;display:inline}`;
|
|
14
14
|
var x = Object.defineProperty, k = Object.getOwnPropertyDescriptor, l = (e, r, o, t) => {
|
|
15
15
|
for (var i = t > 1 ? void 0 : t ? k(r, o) : r, m = e.length - 1, p; m >= 0; m--)
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-experimental",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "Lyne Design System",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"design system",
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"type": "module",
|
|
12
12
|
"customElements": "custom-elements.json",
|
|
13
13
|
"peerDependencies": {
|
|
14
|
-
"@sbb-esta/lyne-elements": "
|
|
14
|
+
"@sbb-esta/lyne-elements": "1.2.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;
|
|
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"}
|
|
@@ -14,6 +14,8 @@ export declare const extendedLeg: {
|
|
|
14
14
|
template: string;
|
|
15
15
|
};
|
|
16
16
|
}[];
|
|
17
|
+
quayTypeName: string;
|
|
18
|
+
quayTypeShortName: string;
|
|
17
19
|
serviceAlteration: {
|
|
18
20
|
cancelled: boolean;
|
|
19
21
|
delayText: string;
|
|
@@ -31,6 +33,8 @@ export declare const longFutureLeg: {
|
|
|
31
33
|
time: string;
|
|
32
34
|
};
|
|
33
35
|
serviceJourney: {
|
|
36
|
+
quayTypeName: string;
|
|
37
|
+
quayTypeShortName: string;
|
|
34
38
|
serviceAlteration: {
|
|
35
39
|
cancelled: boolean;
|
|
36
40
|
delayText: string;
|
|
@@ -42,6 +46,10 @@ export declare const longFutureLeg: {
|
|
|
42
46
|
export declare const cancelledLeg: any;
|
|
43
47
|
export declare const progressLeg: any;
|
|
44
48
|
export declare const pastLeg: any;
|
|
49
|
+
export declare const defaultBusLeg: any;
|
|
50
|
+
export declare const pastBusLeg: any;
|
|
51
|
+
export declare const defaultShipLeg: any;
|
|
52
|
+
export declare const defaultTramLeg: any;
|
|
45
53
|
export declare const delayedLeg: {
|
|
46
54
|
__typename: string;
|
|
47
55
|
arrival: {
|
|
@@ -54,6 +62,8 @@ export declare const delayedLeg: {
|
|
|
54
62
|
serviceAlteration: {
|
|
55
63
|
delay: boolean;
|
|
56
64
|
};
|
|
65
|
+
quayTypeName: string;
|
|
66
|
+
quayTypeShortName: string;
|
|
57
67
|
};
|
|
58
68
|
};
|
|
59
69
|
export declare const notReachableLeg: {
|
|
@@ -68,6 +78,8 @@ export declare const notReachableLeg: {
|
|
|
68
78
|
serviceAlteration: {
|
|
69
79
|
reachable: boolean;
|
|
70
80
|
};
|
|
81
|
+
quayTypeName: string;
|
|
82
|
+
quayTypeShortName: string;
|
|
71
83
|
};
|
|
72
84
|
};
|
|
73
85
|
export declare const unplannedStopLeg: {
|
|
@@ -82,6 +94,8 @@ export declare const unplannedStopLeg: {
|
|
|
82
94
|
serviceAlteration: {
|
|
83
95
|
unplannedStopPointsText: string;
|
|
84
96
|
};
|
|
97
|
+
quayTypeName: string;
|
|
98
|
+
quayTypeShortName: string;
|
|
85
99
|
};
|
|
86
100
|
};
|
|
87
101
|
export declare const redirectedOnDepartureLeg: {
|
|
@@ -93,12 +107,14 @@ export declare const redirectedOnDepartureLeg: {
|
|
|
93
107
|
time: string;
|
|
94
108
|
};
|
|
95
109
|
serviceJourney: {
|
|
96
|
-
stopPoints: {
|
|
97
|
-
stopStatus: string;
|
|
98
|
-
}[];
|
|
99
110
|
serviceAlteration: {
|
|
100
111
|
redirectedText: string;
|
|
101
112
|
};
|
|
113
|
+
quayTypeName: string;
|
|
114
|
+
quayTypeShortName: string;
|
|
115
|
+
stopPoints: {
|
|
116
|
+
stopStatus: string;
|
|
117
|
+
}[];
|
|
102
118
|
};
|
|
103
119
|
};
|
|
104
120
|
export declare const redirectedOnArrivalLeg: {
|
|
@@ -116,6 +132,8 @@ export declare const redirectedOnArrivalLeg: {
|
|
|
116
132
|
serviceAlteration: {
|
|
117
133
|
redirectedText: string;
|
|
118
134
|
};
|
|
135
|
+
quayTypeName: string;
|
|
136
|
+
quayTypeShortName: string;
|
|
119
137
|
};
|
|
120
138
|
};
|
|
121
139
|
//# sourceMappingURL=pearl-chain.sample-data.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pearl-chain.sample-data.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain/pearl-chain.sample-data.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pearl-chain.sample-data.d.ts","sourceRoot":"","sources":["../../../src/elements-experimental/pearl-chain/pearl-chain.sample-data.ts"],"names":[],"mappings":"AAoCA,eAAO,MAAM,SAAS,EAAE,GAKvB,CAAC;AAEF,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;CAQvB,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;CAKzB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,GAK1B,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,GAKzB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,GAKrB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,GAG3B,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,GAGxB,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,GAO5B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,GAO5B,CAAC;AAEF,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;CAKtB,CAAC;AAEF,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;CAK3B,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;CAK5B,CAAC;AAEF,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;CAQpC,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;CAKlC,CAAC"}
|
package/pearl-chain-time.js
CHANGED
|
@@ -6,7 +6,7 @@ import { property as n, customElement as x } from "lit/decorators.js";
|
|
|
6
6
|
import { removeTimezoneFromISOTimeString as c } from "./core/datetime.js";
|
|
7
7
|
import { getDepartureArrivalTimeAttribute as w, isRideLeg as $ } from "./core/timetable.js";
|
|
8
8
|
import "./pearl-chain.js";
|
|
9
|
-
import { f as g } from "./format-
|
|
9
|
+
import { f as g } from "./format-fWxoS2xH.js";
|
|
10
10
|
const T = v`*,:before,:after{box-sizing:border-box}:host{--sbb-pearl-chain-time-height: auto;display:block}@media (min-width: 37.5rem){:host{--sbb-pearl-chain-time-height: 1.5625rem}}@media (min-width: 52.5rem){:host{--sbb-pearl-chain-time-height: 1.75rem}}.sbb-pearl-chain__time{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;height:var(--sbb-pearl-chain-time-height)}.sbb-pearl-chain__time-walktime,.sbb-pearl-chain__time-transfer{--sbb-text-font-size: var(--sbb-font-size-text-xxs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);display:inline-flex;align-items:center}.sbb-pearl-chain__time-walktime--left{transform:translate(-.4375rem);margin-inline-end:calc(var(--sbb-spacing-fixed-2x) - .4375rem)}.sbb-pearl-chain__time-walktime--right{margin-inline-start:calc(var(--sbb-spacing-fixed-2x) - .25rem)}.sbb-pearl-chain__time-walktime-prime-symbol{float:right}.sbb-pearl-chain__time-transfer{gap:var(--sbb-spacing-fixed-1x)}.sbb-pearl-chain__time-transfer--departure{margin-inline-end:var(--sbb-spacing-fixed-2x)}.sbb-pearl-chain__time-transfer--arrival{margin-inline-start:calc(var(--sbb-spacing-fixed-2x) - .25rem)}.sbb-pearl-chain__time-chain{flex:1 1 auto;align-self:center;margin-inline:var(--sbb-spacing-fixed-3x)}.sbb-pearl-chain__time-time{--sbb-text-font-size: var(--sbb-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700;color:var(--sbb-color-charcoal)}.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}`;
|
|
11
11
|
var z = Object.defineProperty, A = Object.getOwnPropertyDescriptor, i = (r, a, b, s) => {
|
|
12
12
|
for (var e = s > 1 ? void 0 : s ? A(a, b) : a, l = r.length - 1, o; l >= 0; l--)
|