@sbb-esta/lyne-elements-experimental 0.52.0 → 0.52.1

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.
@@ -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-WI2gcVKN.js";
13
+ import { f as format } from "./format-BOXfsJCN.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
@@ -242,8 +242,7 @@ var __decorateClass = (decorators, target, key, kind) => {
242
242
  for (var i = decorators.length - 1, decorator; i >= 0; i--)
243
243
  if (decorator = decorators[i])
244
244
  result = (kind ? decorator(target, key, result) : decorator(result)) || result;
245
- if (kind && result)
246
- __defProp(target, key, result);
245
+ if (kind && result) __defProp(target, key, result);
247
246
  return result;
248
247
  };
249
248
  const renderIconProduct = (icon, name) => {
@@ -343,12 +342,9 @@ const getCus = (trip, currentLanguage) => {
343
342
  return { name: "cancellation", text: tripStatus == null ? void 0 : tripStatus.cancelledText };
344
343
  if (getReachableText(rideLegs))
345
344
  return { name: "missed-connection", text: getReachableText(rideLegs) };
346
- if (tripStatus == null ? void 0 : tripStatus.alternative)
347
- return { name: "alternative", text: tripStatus.alternativeText };
348
- if (getRedirectedText(rideLegs))
349
- return { name: "reroute", text: getRedirectedText(rideLegs) };
350
- if (getUnplannedStop(rideLegs))
351
- return { name: "add-stop", text: getUnplannedStop(rideLegs) };
345
+ if (tripStatus == null ? void 0 : tripStatus.alternative) return { name: "alternative", text: tripStatus.alternativeText };
346
+ if (getRedirectedText(rideLegs)) return { name: "reroute", text: getRedirectedText(rideLegs) };
347
+ if (getUnplannedStop(rideLegs)) return { name: "add-stop", text: getUnplannedStop(rideLegs) };
352
348
  if ((tripStatus == null ? void 0 : tripStatus.delayed) || (tripStatus == null ? void 0 : tripStatus.delayedUnknown))
353
349
  return { name: "delay", text: getDelayText(rideLegs) };
354
350
  if (tripStatus == null ? void 0 : tripStatus.quayChanged) {
@@ -363,8 +359,7 @@ const getCus = (trip, currentLanguage) => {
363
359
  const findAndReplaceNotice = (notices) => {
364
360
  const reservationNotice = ["RR", "RK", "RC", "RL", "RM", "RS", "RU", "XP", "XR", "XT"];
365
361
  return notices.reduce((foundNotice, notice) => {
366
- if (foundNotice)
367
- return foundNotice;
362
+ if (foundNotice) return foundNotice;
368
363
  if (reservationNotice.includes(notice.name)) {
369
364
  return { ...notice, name: "RR" };
370
365
  }
@@ -380,10 +375,8 @@ const filterNotices = (notices) => {
380
375
  const handleNotices = (notices) => {
381
376
  const reservationNotice = findAndReplaceNotice(notices);
382
377
  const filteredNotices = filterNotices(notices);
383
- if (reservationNotice === void 0)
384
- return filteredNotices;
385
- if (!filteredNotices.length)
386
- return [reservationNotice];
378
+ if (reservationNotice === void 0) return filteredNotices;
379
+ if (!filteredNotices.length) return [reservationNotice];
387
380
  if (filteredNotices[0].name === "Z" && filteredNotices[1]) {
388
381
  return [filteredNotices[0], reservationNotice, filteredNotices[1]].concat(
389
382
  filteredNotices.slice(2)
@@ -440,8 +433,7 @@ let SbbTimetableRowElement = class extends LitElement {
440
433
  }
441
434
  _getQuayTypeStrings() {
442
435
  var _a, _b;
443
- if (!((_a = this.trip.summary) == null ? void 0 : _a.product))
444
- return null;
436
+ if (!((_a = this.trip.summary) == null ? void 0 : _a.product)) return null;
445
437
  const quayType = this._getQuayType((_b = this.trip.summary.product) == null ? void 0 : _b.vehicleMode);
446
438
  return {
447
439
  long: quayType == null ? void 0 : quayType.long[this._language.current],
@@ -451,8 +443,7 @@ let SbbTimetableRowElement = class extends LitElement {
451
443
  /** map Quay */
452
444
  _renderQuayType() {
453
445
  var _a;
454
- if (!((_a = this.trip.summary) == null ? void 0 : _a.product))
455
- return void 0;
446
+ if (!((_a = this.trip.summary) == null ? void 0 : _a.product)) return void 0;
456
447
  const quayTypeStrings = this._getQuayTypeStrings();
457
448
  return html`
458
449
  <span class="sbb-timetable__row--quay">
@@ -693,4 +684,4 @@ export {
693
684
  renderStringProduct,
694
685
  sortSituation
695
686
  };
696
- //# 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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"}
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwDa,MAAA,oBAAoB,CAAC,MAAc,SAAiC;AACxE,SAAA;AAAA,qBACY,IAAI;AAAA,2CACkB,IAAI;AAAA;AAE/C;AAEa,MAAA,sBAAsB,CAAC,aAAqB,SAAyC;AAC1F,QAAA,QAAQ,CAAC,KAAK,KAAK,GAAG,EAAE,SAAS,WAAW,IAAI,MAAM;AACrD,SAAA;AAAA,MACH,SAAS,OAAO,cAAc,QAAQ,OAAO,WAAW;AAAA;AAE9D;AAEA,MAAM,mBAAmB,CAAC,SAAiD;;AAClE,UAAA,8CAAM,KAAK,CAAC,QAAQ;;AAAA,YAAAA,OAAAC,MAAA,IAAI,mBAAJ,gBAAAA,IAAoB,sBAApB,gBAAAD,IAAuC;AAAA,SAA3D,mBAA2E,mBAA3E,mBACH,sBADG,mBACgB;AACzB;AAEA,MAAM,eAAe,CAAC,SAAiD;;AAC9D,UAAA,8CAAM,KAAK,CAAC,QAAQ;;AAAA,YAAAA,OAAAC,MAAA,IAAI,mBAAJ,gBAAAA,IAAoB,sBAApB,gBAAAD,IAAuC;AAAA,SAA3D,mBAAuE,mBAAvE,mBACH,sBADG,mBACgB;AACzB;AAEA,MAAM,oBAAoB,CAAC,SAAiD;;AAC1E,UAAO,8CAAM,KAAK,CAAC,QAAA;;AAAQ,YAAC,GAACA,OAAAC,MAAA,IAAI,mBAAJ,gBAAAA,IAAoB,sBAApB,gBAAAD,IAAuC;AAAA,SAA7D,mBACH,mBADG,mBACa,sBADb,mBACgC;AACzC;AAEA,MAAM,mBAAmB,CAAC,SAAiD;;AACzE,UAAO,8CAAM,KAAK,CAAC,QAAA;;AAAQ,YAAC,GAACA,OAAAC,MAAA,IAAI,mBAAJ,gBAAAA,IAAoB,sBAApB,gBAAAD,IAAuC;AAAA,SAA7D,mBACH,mBADG,mBACa,sBADb,mBACgC;AACzC;AAEa,MAAA,gBAAgB,CAAC,eAA6C;;AACzE,QAAM,aAAa;AAAA,IACjB,aAAa;AAAA,IACb,aAAa;AAAA,IACb,OAAO;AAAA,IACP,0BAA0B;AAAA,IAC1B,mBAAmB;AAAA,IACnB,aAAa;AAAA,EAAA;AAGR,UAAA,MAAC,GAAG,UAAU,MAAd,mBAAiB;AAAA,IACtB,CAAC,GAAgB,MAAmB,WAAW,EAAE,KAAM,IAAI,WAAW,EAAE,KAAM;AAAA;AAElF;AAEa,MAAA,aAAa,CAAC,cAAmC;;AAC5D,UAAQ,uCAAW,OAAO;AAAA,IACxB,KAAK;AACI,aAAA;AAAA,QACL,MAAM;AAAA,QACN,QAAM,4CAAW,sBAAX,mBAA8B,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,IAEzF,KAAK;AACI,aAAA;AAAA,QACL,MAAM;AAAA,QACN,OAAM,uCAAW,kBAAkB,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,IAExF,KAAK;AACI,aAAA;AAAA,QACL,MAAM;AAAA,QACN,OAAM,uCAAW,kBAAkB,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,IAExF,KAAK;AACI,aAAA;AAAA,QACL,MAAM;AAAA,QACN,OAAM,uCAAW,kBAAkB,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,IAExF,KAAK;AACI,aAAA;AAAA,QACL,MAAM;AAAA,QACN,OAAM,uCAAW,kBAAkB,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,IAExF;AACS,aAAA;AAAA,QACL,MAAM;AAAA,QACN,OAAM,uCAAW,kBAAkB,UAAS,uCAAW,kBAAkB,GAAG,QAAQ;AAAA,MAAA;AAAA,EAE1F;AACF;AAEa,MAAA,SAAS,CAAC,MAAiB,oBAAoC;AAC1E,QAAM,EAAE,SAAS,SAAS,QAAQ,CAAA;AAClC,QAAM,WAAW,6BAAM,OAAO,CAAC,QAAQ,UAAU,GAAG;AACpD,QAAM,EAAE,WAAA,IAAe,WAAW;AAE9B,OAAA,yCAAY,eAAa,yCAAY;AACvC,WAAO,EAAE,MAAM,gBAAgB,MAAM,yCAAY,cAAc;AACjE,MAAI,iBAAiB,QAAQ;AAC3B,WAAO,EAAE,MAAM,qBAAqB,MAAM,iBAAiB,QAAQ;AACjE,MAAA,yCAAY,YAAoB,QAAA,EAAE,MAAM,eAAe,MAAM,WAAW;AACxE,MAAA,kBAAkB,QAAQ,EAAU,QAAA,EAAE,MAAM,WAAW,MAAM,kBAAkB,QAAQ;AACvF,MAAA,iBAAiB,QAAQ,EAAU,QAAA,EAAE,MAAM,YAAY,MAAM,iBAAiB,QAAQ;AACtF,OAAA,yCAAY,aAAW,yCAAY;AACrC,WAAO,EAAE,MAAM,SAAS,MAAM,aAAa,QAAQ;AACrD,MAAI,yCAAY,aAAa;AACrB,UAAA,YAAY,SAAS,CAAC,EAAE;AACvB,WAAA;AAAA,MACL,MAAM;AAAA,MACN,MAAM,UAAU,cAAc,UAAU,kBAAkB,mBAAmB,eAAe;AAAA,IAAA;AAAA,EAEhG;AAEA,SAAO;AACT;AAEA,MAAM,uBAAuB,CAAC,YAA0C;AAChE,QAAA,oBAAoB,CAAC,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,MAAM,IAAI;AAErF,SAAO,QAAQ,OAAO,CAAC,aAAiC,WAAuC;AAC7F,QAAI,YAAoB,QAAA;AACxB,QAAI,kBAAkB,SAAS,OAAO,IAAI,GAAG;AAC3C,aAAO,EAAE,GAAG,QAAQ,MAAM,KAAK;AAAA,IACjC;AAAA,EAAA,GACC,MAAS;AACd;AAEa,MAAA,gBAAgB,CAAC,YAAgC;AAC5D,QAAM,eAAe,CAAC,KAAK,MAAM,MAAM,MAAM,IAAI;AAEjD,QAAM,eAAe,QAAQ,OAAO,CAAC,QAAQ,UAAU;AAC9C,WAAA,QAAQ,UAAU,CAAC,MAAM,EAAE,SAAS,OAAO,IAAI,MAAM;AAAA,EAAA,CAC7D;AAEM,SAAA,aACJ,OAAO,CAAC,WAAW,aAAa,SAAS,OAAO,IAAI,CAAC,EACrD,KAAK,CAAC,GAAG,MAAM,aAAa,QAAQ,EAAE,IAAI,IAAI,aAAa,QAAQ,EAAE,IAAI,CAAC;AAC/E;AAEa,MAAA,gBAAgB,CAAC,YAAgC;AACtD,QAAA,oBAAoB,qBAAqB,OAAO;AAChD,QAAA,kBAAkB,cAAc,OAAO;AAEzC,MAAA,sBAAsB,OAAkB,QAAA;AAC5C,MAAI,CAAC,gBAAgB,OAAQ,QAAO,CAAC,iBAAiB;AAEtD,MAAI,gBAAgB,CAAC,EAAE,SAAS,OAAO,gBAAgB,CAAC,GAAG;AAClD,WAAA,CAAC,gBAAgB,CAAC,GAAG,mBAAmB,gBAAgB,CAAC,CAAC,EAAE;AAAA,MACjE,gBAAgB,MAAM,CAAC;AAAA,IAAA;AAAA,EAE3B;AAEO,SAAA,CAAC,mBAAmB,GAAG,eAAe;AAC/C;AAMa,IAAA,yBAAN,cAAqC,WAAW;AAAA,EAAhD,cAAA;AAAA,UAAA,GAAA,SAAA;AAoBmD,SAAO,cAAc;AAMpB,SAAO,eAAe;AAsB/E,SAAQ,OAAoB;AAEpB,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAAA,EAAA;AAAA,EARlD,IAAW,IAAI,OAAgC;AAC7C,SAAK,OAAO,mBAAmB,mBAAmB,mBAAmB,YAAY,KAAK,CAAC;AAAA,EACzF;AAAA,EACA,IAAW,MAAY;AACd,WAAA,KAAK,QAAQ,oBAAI;EAC1B;AAAA,EAKmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,aAAa,GAAG;AACxC,2BAAqB,MAAM,QAAQ,CAAC,KAAK,cAAc,aAAa,IAAI;AAAA,IAC1E;AAAA,EACF;AAAA;AAAA,EAGQ,kBAAkC;AACjC,WAAA;AAAA;AAAA,UAED,KAAK,eACH,qEACA,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQjB;AAAA,EAEQ,aAAa,aAA0B;AAC7C,YAAQ,aAAa;AAAA,MACnB,KAAK;AACI,eAAA;AAAA,MACT,KAAK;AACI,eAAA;AAAA,MACT,KAAK;AACI,eAAA;AAAA,MACT,KAAK;AACI,eAAA;AAAA,MACT;AACS,eAAA;AAAA,IACX;AAAA,EACF;AAAA,EAEQ,sBAA8D;;AACpE,QAAI,GAAC,UAAK,KAAK,YAAV,mBAAmB,SAAgB,QAAA;AACxC,UAAM,WAAW,KAAK,cAAa,UAAK,KAAK,QAAQ,YAAlB,mBAA2B,WAAW;AAClE,WAAA;AAAA,MACL,MAAM,qCAAU,KAAK,KAAK,UAAU;AAAA,MACpC,OAAO,qCAAU,MAAM,KAAK,UAAU;AAAA,IAAO;AAAA,EAEjD;AAAA;AAAA,EAGQ,kBAA8C;;AACpD,QAAI,GAAC,UAAK,KAAK,YAAV,mBAAmB,SAAgB,QAAA;AAClC,UAAA,kBAAkB,KAAK;AACtB,WAAA;AAAA;AAAA,+CAEoC,mDAAiB,IAAI;AAAA;AAAA,aAEvD,mDAAiB,KAAK;AAAA;AAAA;AAAA;AAAA,EAIjC;AAAA,EAEQ,cAAc,MAA6D;;AACjF,UAAM,EAAE,WAAA,IAAe,QAAQ;AACzB,UAAA,mBAAmB,cAAc,cAAc,UAAU;AAC/D,UAAM,MAAM,OAAO,MAAM,KAAK,UAAU,OAAO;AAExC,WAAA;AAAA,MACL,OAAK,YAAO,KAAK,GAAG,MAAf,mBAAkB,UAAS,MAAM;AAAA,MACtC,MAAK,yCAAY,UAAS,WAAW,iBAAiB,CAAC,CAAC,IAAI;AAAA,IAAA;AAAA,EAEhE;AAAA,EAEQ,sBAAsB,MAAyB;;AACrD,UAAM,EAAE,SAAS,MAAM,QAAQ,IAAI,QAAQ,CAAA;AACrC,UAAA;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,IACE,WAAW,CAAA;AAET,UAAA,EAAE,wBAAwB,qBAAA,IAAyB;AAAA,MACvD;AAAA,MACA,iBAAiB;AAAA,MACjB,eAAe;AAAA,MACf,KAAK,UAAU;AAAA,IAAA;AAGjB,UAAM,iBAAkC,uCAAW,QAC/C,gCAAgC,UAAU,IAAI,IAC9C;AAEJ,UAAM,eAAgC,mCAAS,QAC3C,gCAAgC,QAAQ,IAAI,IAC5C;AAEE,UAAA,oBAAoB,yBACtB,GAAG,uBAAuB,IAAI,IAAI,uBAAuB,QAAQ,OACjE;AAEE,UAAA,kBAAkB,uBACpB,GAAG,qBAAqB,IAAI,IAAI,qBAAqB,QAAQ,OAC7D;AAEJ,UAAM,oBAAoB,gBACtB,GAAG,cAAc,KAAK,UAAU,OAAO,CAAC,KAAK,OAAO,eAAe,OAAO,CAAC,OAC3E;AAEJ,UAAM,uBAAuB,MAAc;;AACrC,UAAA,EAAC,uCAAW,gBAAe;AACtB,eAAA;AAAA,MACT;AAGM,YAAA,qBAAoB,uCAAW,eAAc,GAAG,QAAQ,KAAK,UAAU,OAAO,CAAC,MAAM;AACpF,aAAA,GAAG,iBAAiB,IACzBC,MAAA,KAAK,0BAAL,gBAAAA,IAA4B,IAC9B,IAAI,uCAAW,aAAa;AAAA,IAAA;AAGxB,UAAA,uBACJ,WAAW,QAAQ,cACf,qBAAqB,QAAQ,YAAY,YAAa,CAAA,KACtD,GAAG,qBAAqB,QAAQ,YAAY,YAAY,CAAC,EAAE,KAAK,UAAU,OAAO,CAAC,OAClF;AAEA,UAAA,sBAAqB,mCAAS,2BAChC,GAAG,QAAQ,uBAAuB,IAAI,QAAQ,QAAQ,EAAE,OACxD;AAEE,UAAA,gBAAgB,GAAG,cAAc,KAAK,UAAU,OAAO,CAAC,IAAI,SAAS;AAErE,UAAA,SAAS,KAAK,cAAc,IAAI;AACtC,UAAM,YAAU,sCAAQ,QAAR,mBAAa,QACzB,GAAG,iBAAiB,KAAK,UAAU,OAAO,CAAC,MAAK,sCAAQ,QAAR,mBAAa,IAAI,OACjE;AACJ,UAAM,YAAU,sCAAQ,QAAR,mBAAa,QACzB,GAAG,iBAAiB,KAAK,UAAU,OAAO,CAAC,MAAK,sCAAQ,QAAR,mBAAa,IAAI,OACjE;AAEJ,UAAM,eAAe,KAAK,WAAW,GAAG,KAAK,SAAS,IAAI,OAAO;AAEjE,UAAM,YAAY,KAAG,UAAK,UAAL,mBAAY,cAAa,eAAe,KAAK,UAAU,OAAO,IAAI,EAAE,MACvF,UAAK,UAAL,mBAAY,WAAQ,UAAK,UAAL,mBAAY,YAC3B,UAAK,UAAL,mBAAY,SAAQ,MAAM,SAAO,UAAK,UAAL,mBAAY,UAAS,MAAM,OAC7D,EACN;AAEA,UAAM,sBACJ,6BAAM,UAAS,IACX,IAAG,6BAAM,UAAS,CAAC,IAAI,uBAAuB,KAAK,UAAU,OAAO,CAAC,OACrE;AAEN,UAAM,kBAAkB,cACpB,GAAG,YAAY,KAAK,UAAU,OAAO,CAAC,KAAK,OAAO,aAAa,OAAO,CAAC,OACvE;AAEJ,QAAI,gBAAwB;AAC5B,QAAI,WAAW;AACb,UAAI,UAAU,cAAc,UAAU,eAAe,WAAW;AAC9D,yBAAiB,GAAG,UAAU,MAAM,KAAK,UAAU,OAAO,CAAC,KAEvD,mBAAc,UAAU,WAAW,YAAY,CAAiB,MAAhE,mBAIE,KAAK,UAAU,QACrB;AAAA,MACF;AACA,UAAI,UAAU,eAAe,UAAU,gBAAgB,WAAW;AAChE,yBAAiB,IAAI,UAAU,OAAO,KAAK,UAAU,OAAO,CAAC,KAEzD,mBAAc,UAAU,YAAY,aAA6B,MAAjE,mBAIE,KAAK,UAAU,QACrB;AAAA,MACF;AAAA,IACF;AAEM,UAAA,aACJ,WACA,cAAc,OAAO,EAAE,YACvB,mBAAc,OAAO,MAArB,mBACI,IAAI,CAAC,QAAQ,UAAU;;AAAA,qBAAQ,OAAKA,MAAA,OAAO,SAAP,gBAAAA,IAAa;AAAA,OAClD,KAAK,SAAQ;AAEZ,UAAA,iBAAiB,aACnB,GAAG,gBAAgB,KAAK,UAAU,OAAO,CAAC,KAAK,UAAU,KACzD;AAEE,UAAA,eACJ,CAAC,CAAC,YAAY,WAAW,IACrB,GAAG,iBAAiB,KAAK,UAAU,OAAO,CAAC,IACzC,eAAe,UAAU,KAAK,UAAU,OAAO,EAAE,IACnD,OACA;AAEN,WAAO,GAAG,iBAAiB,IAAI,iBAAiB,IAAI,qBAAqB,CAAC,IAAI,oBAAoB,IAAI,kBAAkB,IAAI,aAAa,IAAI,OAAO,IAAI,YAAY,IAAI,SAAS,IAC/K,UAAU,KAAK,OACjB,IAAI,eAAe,IAAI,eAAe,IAAI,YAAY,IAAI,kBAAkB,IAAI,aAAa,IAAI,cAAc;AAAA,EACjH;AAAA,EAEmB,SAAyB;;AAC1C,QAAI,KAAK,aAAa;AACpB,aAAO,KAAK;IACd;AAEM,UAAA,EAAE,MAAM,IAAI,SAAS,YAAY,KAAK,QAAQ;AAE9C,UAAA;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,IACE,WAAW,CAAA;AAEf,UAAM,SAAS,KAAK,cAAc,KAAK,IAAI;AAC3C,UAAM,YAAY,CAAC,CAAC,OAAO,OAAO,CAAC,CAAC,OAAO;AAErC,UAAA,mBAAmB,WAAW,cAAc,OAAO;AAEzD,UAAM,cAAc,WAAW,eAAe,UAAU,KAAK,UAAU,OAAO,IAAI;AAE3E,WAAA;AAAA,8BACmB,EAAE;AAAA;AAAA,oBAEZ,KAAK,MAAM;AAAA,4BACL,UAAK,0BAAL,mBAA4B,eAAc,OAAO;AAAA;AAAA,YAE/D,KAAK,kBAAkB,KAAK,kBAAkB,KAAK,sBAAsB,KAAK,IAAI,CAAC;AAAA;AAAA,UAErF,KAAK,eACH,qEACA,OAAO;AAAA,UACT,KAAK,SAAS,CAAC,KAAK,eAClB,6BAA6B,KAAK,MAAM,aAAa,aAAa,OAAO;AAAA,gBACrE,KAAK,MAAM,aACT;AAAA;AAAA,yBAEO,eAAe,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA,6BAG7C,OAAO;AAAA,gBACT,KAAK,MAAM,OAAO,aAAa,KAAK,MAAM,IAAI,YAAY,OAAO;AAAA,gBACjE,KAAK,MAAM,QAAQ,aAAa,KAAK,MAAM,KAAK,YAAY,OAAO;AAAA,iCAEvE,OAAO;AAAA;AAAA;AAAA;AAAA,iBAIH,mCAAS,+BACX;AAAA;AAAA;AAAA,gCAGkB,QAAQ,0BAA0B;AAAA;AAAA;AAAA,oBAG9C,WACF,QAAQ,eACR,qBAAqB,QAAQ,YAAY,YAAa,CAAA,KACtD,qBAAqB,QAAQ,YAAY,YAAY,CAAC,EAAE,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA;AAAA,sBAG3E;AAAA,gBACN,YACD,QAAQ,wBACL,kBAAkB,QAAQ,uBAAuB,QAAQ,IAAI,IAC7D,QAAQ,2BACR,oBAAoB,QAAQ,yBAAyB,mCAAS,IAAI,EAAE;AAAA;AAAA,cAExE,YACE,UAAU,GAAG,cAAc,KAAK,UAAU,OAAO,CAAC,IAAI,SAAS,EAAE,SACjE,OAAO;AAAA;AAAA;AAAA;AAAA,oBAIH,IAAI;AAAA,6BACK,uCAAW,IAAI;AAAA,2BACjB,mCAAS,IAAI;AAAA,6BACX,aAAa;AAAA,2BACf,WAAW;AAAA,iCACL,KAAK,gBAAgB;AAAA,mBACnC,KAAK,GAAG;AAAA;AAAA;AAAA,cAGb,WAAW,KAAK,aAAa,QAAQ,WAAW,MAAK,uCAAW,iBAC9D;AAAA,2BACU,uCAAW,eAAc,qCAAqC,OAAO;AAAA;AAAA;AAAA,sBAGzE,GAAG,cAAc,KAAK,UAAU,OAAO,CAAC,KACxC,uCAAW,eAAc,QAAQ,KAAK,UAAU,OAAO,IAAI,EAC7D,EAAE;AAAA;AAAA;AAAA,oBAGF,KAAK,gBAAA,CAAiB,IAAI,uCAAW,aAAa;AAAA,2BAEtD,OAAO;AAAA,eACR,uCAAW,gBAAc,uCAAW,gBAAe,cACrD,uCAAW,gBAAe,UAAU,gBAAgB,YACjD;AAAA,0CACyB,4CAAW,eAAX,mBAAuB,aAAa;AAAA,2CACnC,4CAAW,gBAAX,mBAAwB,aAAa;AAAA,+CAE/D,OAAO;AAAA,cACR,oBAAoB,iBAAiB,UAAW,KAAK,WACpD;AAAA,oBACI,qDAAkB;AAAA,MAAI,CAAC,QAAQ,UAC/B;;AAAA,uBAAQ,IACJ;AAAA;AAAA;AAAA,mCAGW,UAAQA,MAAA,OAAO,SAAP,gBAAAA,IAAa,cAAa;AAAA;AAAA,kEAEJD,MAAA,OAAO,SAAP,gBAAAA,IAAa,QAAQ;AAAA,iCAE9D;AAAA;AAAA,KACL;AAAA,oBACC,KAAK,WACH;AAAA;AAAA;AAAA,kCAGW,UAAK,aAAL,mBAAe,IAAI;AAAA,wCACb,UAAK,aAAL,mBAAe,IAAI;AAAA;AAAA;AAAA,+BAIpC,OAAO;AAAA,yBAEb,OAAO;AAAA,cACT,YAAY,WAAW,IACrB;AAAA;AAAA,sBAEM,GAAG,iBAAiB,KAAK,UAAU,OAAO,CAAC,IAAI,YAAa,IAAI,EAAE;AAAA;AAAA,6CAE3C,YAAa,KAAK;AAAA,2BAE/C,OAAO;AAAA,cACT,cAAc,OAAO,OAAO,OAAO,OACjC;AAAA,oCACoB,OAAO,OAAO,OAAO,KAAM,IAAI;AAAA,0DACT,OAAO,OAAO,OAAO,KAAM,IAAI;AAAA,2BAEzE,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,EAKrB;AACF;AA5Za,uBACY,SAAyB;AAGb,gBAAA;AAAA,EAAlC,SAAS,EAAE,MAAM,QAAQ;AAAA,GAJf,uBAIwB,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EAAlC,SAAS,EAAE,MAAM,QAAQ;AAAA,GAPf,uBAOwB,WAAA,SAAA,CAAA;AAI5B,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,qBAAqB,SAAS,MAAM,MAAM,SAAS;AAAA,GAV/D,uBAWJ,WAAA,oBAAA,CAAA;AAG4B,gBAAA;AAAA,EAAlC,SAAS,EAAE,MAAM,QAAQ;AAAA,GAdf,uBAcwB,WAAA,YAAA,CAAA;AAM4B,gBAAA;AAAA,EAA9D,SAAS,EAAE,WAAW,gBAAgB,MAAM,SAAS;AAAA,GApB3C,uBAoBoD,WAAA,eAAA,CAAA;AAMC,gBAAA;AAAA,EAA/D,SAAS,EAAE,WAAW,iBAAiB,MAAM,SAAS;AAAA,GA1B5C,uBA0BqD,WAAA,gBAAA,CAAA;AAKX,gBAAA;AAAA,EAApD,SAAS,EAAE,WAAW,qBAAqB;AAAA,GA/BjC,uBA+B0C,WAAA,mBAAA,CAAA;AAI9C,gBAAA;AAAA,EADN,SAAS,EAAE,WAAW,0BAA0B,MAAM,SAAS;AAAA,GAlCrD,uBAmCJ,WAAA,yBAAA,CAAA;AAG6B,gBAAA;AAAA,EAAnC,SAAS,EAAE,MAAM,SAAS;AAAA,GAtChB,uBAsCyB,WAAA,UAAA,CAAA;AAIzB,gBAAA;AAAA,EADV,SAAS;AAAA,GAzCC,uBA0CA,WAAA,OAAA,CAAA;AA1CA,yBAAN,gBAAA;AAAA,EADN,cAAc,mBAAmB;AAAA,GACrB,sBAAA;"}
@@ -334,11 +334,9 @@ function it(t, e) {
334
334
  function ot(t) {
335
335
  return (e, n = {}) => {
336
336
  const r = e.match(t.matchPattern);
337
- if (!r)
338
- return null;
337
+ if (!r) return null;
339
338
  const a = r[0], i = e.match(t.parsePattern);
340
- if (!i)
341
- return null;
339
+ if (!i) return null;
342
340
  let s = t.valueCallback ? t.valueCallback(i[0]) : i[0];
343
341
  s = n.valueCallback ? n.valueCallback(s) : s;
344
342
  const u = e.slice(a.length);
@@ -1110,8 +1108,7 @@ function Et(t) {
1110
1108
  }
1111
1109
  function Ft(t, e, n) {
1112
1110
  const r = qt(t, e, n);
1113
- if (console.warn(r), Tt.includes(t))
1114
- throw new RangeError(r);
1111
+ if (console.warn(r), Tt.includes(t)) throw new RangeError(r);
1115
1112
  }
1116
1113
  function qt(t, e, n) {
1117
1114
  const r = t[0] === "Y" ? "years" : "days of the month";
@@ -1151,8 +1148,7 @@ function Bt(t, e, n) {
1151
1148
  locale: a
1152
1149
  };
1153
1150
  return c.map((m) => {
1154
- if (!m.isToken)
1155
- return m.value;
1151
+ if (!m.isToken) return m.value;
1156
1152
  const h = m.value;
1157
1153
  (Et(h) || Dt(h)) && Ft(h, e, String(t));
1158
1154
  const S = T[h[0]];
@@ -1,5 +1,5 @@
1
- import { SbbDateLike } from '../../elements/core/interfaces/types';
2
- import { SbbTitleLevel } from '../../elements/title.js';
1
+ import { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';
2
+ import { SbbTitleLevel } from '@sbb-esta/lyne-elements/title.js';
3
3
  import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
4
4
  import { Leg } from '../core/timetable.js';
5
5
 
@@ -1,79 +1,79 @@
1
- import { SbbLanguageController as c } from "@sbb-esta/lyne-elements/core/controllers.js";
2
- import { defaultDateAdapter as u } from "@sbb-esta/lyne-elements/core/datetime.js";
3
- import { i18nTripDuration as h } from "@sbb-esta/lyne-elements/core/i18n.js";
4
- import { css as v, LitElement as _, html as s, nothing as n } from "lit";
5
- import { property as b, customElement as f } from "lit/decorators.js";
1
+ import { SbbLanguageController as y } from "@sbb-esta/lyne-elements/core/controllers.js";
2
+ import { defaultDateAdapter as d } from "@sbb-esta/lyne-elements/core/datetime.js";
3
+ import { i18nTripDuration as v } from "@sbb-esta/lyne-elements/core/i18n.js";
4
+ import { css as h, LitElement as f, html as s, nothing as o } from "lit";
5
+ import { property as b, customElement as _ } from "lit/decorators.js";
6
6
  import { durationToTime as g, removeTimezoneFromISOTimeString as $ } from "./core/datetime.js";
7
7
  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
11
  import { i as j } from "./isValid-Df_caLp4.js";
12
- import { f as d } from "./format-CEz7IGRJ.js";
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
- var x = Object.defineProperty, k = Object.getOwnPropertyDescriptor, l = (e, r, o, t) => {
15
- for (var i = t > 1 ? void 0 : t ? k(r, o) : r, m = e.length - 1, p; m >= 0; m--)
16
- (p = e[m]) && (i = (t ? p(r, o, i) : p(i)) || i);
17
- return t && i && x(r, o, i), i;
12
+ import { f as u } from "./format-qHhIvnY8.js";
13
+ const x = h`*,: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
+ var w = Object.defineProperty, k = Object.getOwnPropertyDescriptor, l = (e, t, a, r) => {
15
+ for (var i = r > 1 ? void 0 : r ? k(t, a) : t, m = e.length - 1, p; m >= 0; m--)
16
+ (p = e[m]) && (i = (r ? p(t, a, i) : p(i)) || i);
17
+ return r && i && w(t, a, i), i;
18
18
  };
19
- let a = class extends _ {
19
+ let n = class extends f {
20
20
  constructor() {
21
- super(...arguments), this.headerLevel = "3", this._now = null, this._hasContentSlot = !1, this._language = new c(this);
21
+ super(...arguments), this.headerLevel = "3", this.a = null, this.b = !1, this.c = new y(this);
22
22
  }
23
23
  set now(e) {
24
- this._now = u.getValidDateOrNull(u.deserialize(e));
24
+ this.a = d.getValidDateOrNull(d.deserialize(e));
25
25
  }
26
26
  get now() {
27
- return this._now ?? /* @__PURE__ */ new Date();
27
+ return this.a ?? /* @__PURE__ */ new Date();
28
28
  }
29
29
  connectedCallback() {
30
30
  var e;
31
- super.connectedCallback(), this._hasContentSlot = !!((e = this.querySelector) != null && e.call(this, '[slot="content"]'));
31
+ super.connectedCallback(), this.b = !!((e = this.querySelector) != null && e.call(this, '[slot="content"]'));
32
32
  }
33
33
  /** renders the date of the journey or if it is the current or next day */
34
- _renderJourneyStart(e, r) {
35
- const o = u, t = r ? g(r, this._language.current) : null;
34
+ e(e, t) {
35
+ const a = d, r = t ? g(t, this.c.current) : null;
36
36
  if (j(e))
37
37
  return s`
38
- <time datetime=${d(e, "d") + " " + d(e, "M")}>
39
- ${o.format(e).replace(",", ".")}</time
40
- >${r && r > 0 ? s`,<time>
38
+ <time datetime=${u(e, "d") + " " + u(e, "M")}>
39
+ ${a.format(e).replace(",", ".")}</time
40
+ >${t && t > 0 ? s`,<time>
41
41
  <sbb-screen-reader-only>
42
- ${h[this._language.current]} ${t.long}
42
+ ${v[this.c.current]} ${r.long}
43
43
  </sbb-screen-reader-only>
44
- <span aria-hidden="true">${t.short}</span>
45
- </time>` : n}
44
+ <span aria-hidden="true">${r.short}</span>
45
+ </time>` : o}
46
46
  `;
47
47
  }
48
- _renderJourneyVias(e) {
49
- const r = e.slice(0, 5);
48
+ f(e) {
49
+ const t = e.slice(0, 5);
50
50
  return s`
51
51
  <div class="sbb-journey-summary__via-block">
52
52
  <span class="sbb-journey-summary__via-text">Via</span>
53
- <ul class="sbb-journey-summary__vias" role=${e.length <= 1 ? "presentation" : n}>
54
- ${r.map(
55
- (o, t) => s`<li class="sbb-journey-summary__via">
56
- ${o}${t !== r.length - 1 && t < 4 ? s`<span>,</span>` : n}
53
+ <ul class="sbb-journey-summary__vias" role=${e.length <= 1 ? "presentation" : o}>
54
+ ${t.map(
55
+ (a, r) => s`<li class="sbb-journey-summary__via">
56
+ ${a}${r !== t.length - 1 && r < 4 ? s`<span>,</span>` : o}
57
57
  </li>`
58
58
  )}
59
59
  </ul>
60
60
  </div>
61
61
  `;
62
62
  }
63
- _renderJourneyInformation(e) {
64
- const { vias: r, duration: o, departureWalk: t, departure: i, arrivalWalk: m, arrival: p, legs: y } = e || {};
63
+ d(e) {
64
+ const { vias: t, duration: a, departureWalk: r, departure: i, arrivalWalk: m, arrival: p, legs: c } = e || {};
65
65
  return s`
66
66
  <div>
67
- ${r && r.length > 0 ? this._renderJourneyVias(r) : n}
67
+ ${t && t.length > 0 ? this.f(t) : o}
68
68
  <div class="sbb-journey-summary__date">
69
- ${this._renderJourneyStart($(i), o)}
69
+ ${this.e($(i), a)}
70
70
  </div>
71
71
  <sbb-pearl-chain-time
72
72
  .arrivalTime=${p}
73
73
  .departureTime=${i}
74
- .departureWalk=${t}
74
+ .departureWalk=${r}
75
75
  .arrivalWalk=${m}
76
- .legs=${y}
76
+ .legs=${c}
77
77
  .disableAnimation=${this.disableAnimation}
78
78
  .now=${this.now}
79
79
  ></sbb-pearl-chain-time>
@@ -81,50 +81,50 @@ let a = class extends _ {
81
81
  `;
82
82
  }
83
83
  render() {
84
- const { origin: e, destination: r } = this.trip || {};
84
+ const { origin: e, destination: t } = this.trip || {};
85
85
  return s`
86
86
  <div class="sbb-journey-summary">
87
87
  ${e ? s`<sbb-journey-header
88
88
  size="l"
89
- .level=${this.headerLevel || n}
89
+ .level=${this.headerLevel || o}
90
90
  .origin=${e}
91
- .destination=${r}
92
- .roundTrip=${this.roundTrip ?? n}
93
- ></sbb-journey-header>` : n}
94
- ${this._renderJourneyInformation(this.trip)}
91
+ .destination=${t}
92
+ .roundTrip=${this.roundTrip ?? o}
93
+ ></sbb-journey-header>` : o}
94
+ ${this.d(this.trip)}
95
95
  ${this.tripBack ? s`<div>
96
96
  <sbb-divider class="sbb-journey-summary__divider"></sbb-divider>
97
- ${this._renderJourneyInformation(this.tripBack)}
98
- </div>` : n}
99
- ${this._hasContentSlot ? s` <div class="sbb-journey-summary__slot">
97
+ ${this.d(this.tripBack)}
98
+ </div>` : o}
99
+ ${this.b ? s` <div class="sbb-journey-summary__slot">
100
100
  <slot name="content"></slot>
101
- </div>` : n}
101
+ </div>` : o}
102
102
  </div>
103
103
  `;
104
104
  }
105
105
  };
106
- a.styles = w;
106
+ n.styles = x;
107
107
  l([
108
108
  b({ type: Object })
109
- ], a.prototype, "trip", 2);
109
+ ], n.prototype, "trip", 2);
110
110
  l([
111
111
  b({ attribute: "trip-back", type: Object })
112
- ], a.prototype, "tripBack", 2);
112
+ ], n.prototype, "tripBack", 2);
113
113
  l([
114
114
  b({ attribute: "round-trip", type: Boolean })
115
- ], a.prototype, "roundTrip", 2);
115
+ ], n.prototype, "roundTrip", 2);
116
116
  l([
117
117
  b({ attribute: "header-level" })
118
- ], a.prototype, "headerLevel", 2);
118
+ ], n.prototype, "headerLevel", 2);
119
119
  l([
120
120
  b({ attribute: "disable-animation", type: Boolean })
121
- ], a.prototype, "disableAnimation", 2);
121
+ ], n.prototype, "disableAnimation", 2);
122
122
  l([
123
123
  b()
124
- ], a.prototype, "now", 1);
125
- a = l([
126
- f("sbb-journey-summary")
127
- ], a);
124
+ ], n.prototype, "now", 1);
125
+ n = l([
126
+ _("sbb-journey-summary")
127
+ ], n);
128
128
  export {
129
- a as SbbJourneySummaryElement
129
+ n as SbbJourneySummaryElement
130
130
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-experimental",
3
- "version": "0.52.0",
3
+ "version": "0.52.1",
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": "0.52.0"
14
+ "@sbb-esta/lyne-elements": "0.52.1"
15
15
  },
16
16
  "dependencies": {
17
17
  "lit": "^3.0.0"
@@ -1,4 +1,4 @@
1
- import { SbbDateLike } from '../../elements/core/interfaces/types';
1
+ import { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';
2
2
  import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
3
3
  import { Leg, PtRideLeg } from '../core/timetable.js';
4
4
 
@@ -1,4 +1,4 @@
1
- import { SbbDateLike } from '../../elements/core/interfaces/types';
1
+ import { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';
2
2
  import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
3
3
  import { Leg, PtRideLeg } from '../core/timetable.js';
4
4