@sbb-esta/lyne-elements-experimental 1.8.0 → 1.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/core/timetable/access-leg-helper.d.ts +2 -1
  2. package/core/timetable/access-leg-helper.d.ts.map +1 -1
  3. package/core/timetable.js +111 -76
  4. package/custom-elements.json +44 -0
  5. package/development/core/timetable/access-leg-helper.d.ts +2 -1
  6. package/development/core/timetable/access-leg-helper.d.ts.map +1 -1
  7. package/development/core/timetable.js +57 -22
  8. package/development/journey-summary.js +2 -15
  9. package/development/pearl-chain/pearl-chain.sample-data.d.ts +1 -0
  10. package/development/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
  11. package/development/pearl-chain-time/pearl-chain-time.d.ts +2 -0
  12. package/development/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
  13. package/development/pearl-chain-time.js +20 -20
  14. package/development/pearl-chain-vertical-item.js +2 -15
  15. package/development/pearl-chain-vertical.js +2 -15
  16. package/development/pearl-chain.js +3 -16
  17. package/development/timetable-duration.js +2 -15
  18. package/development/timetable-row/timetable-row.d.ts +7 -0
  19. package/development/timetable-row/timetable-row.d.ts.map +1 -1
  20. package/development/timetable-row/timetable-row.sample-data.d.ts +2 -0
  21. package/development/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
  22. package/development/timetable-row.js +8 -16
  23. package/package.json +2 -2
  24. package/pearl-chain/pearl-chain.sample-data.d.ts +1 -0
  25. package/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
  26. package/pearl-chain-time/pearl-chain-time.d.ts +2 -0
  27. package/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
  28. package/pearl-chain-time.js +37 -33
  29. package/pearl-chain.js +11 -11
  30. package/timetable-row/timetable-row.d.ts +7 -0
  31. package/timetable-row/timetable-row.d.ts.map +1 -1
  32. package/timetable-row/timetable-row.sample-data.d.ts +2 -0
  33. package/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
  34. package/timetable-row.js +40 -35
@@ -10,20 +10,7 @@ import "@sbb-esta/lyne-elements/journey-header.js";
10
10
  import "./pearl-chain-time.js";
11
11
  import { i as isValid } from "./isValid-BVccOlli.js";
12
12
  import { f as format } from "./format-DkbylFCM.js";
13
- const style = css`/**
14
- * Better font rendering (on OS X)
15
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
16
- *
17
- * Usage:
18
- *
19
- * .var_dark_on_light {
20
- * @include font-smoothing;
21
- * }
22
- * .var_light_on_dark {
23
- * @include font-smoothing-reset;
24
- * }
25
- */
26
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
13
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
27
14
  /*
28
15
  * SBB table mixin
29
16
  * Notes:
@@ -212,4 +199,4 @@ SbbJourneySummaryElement = __decorateClass([
212
199
  export {
213
200
  SbbJourneySummaryElement
214
201
  };
215
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"journey-summary.js","sources":["../../../src/elements-experimental/journey-summary/journey-summary.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { i18nTripDuration } from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport type { SbbTitleLevel } from '@sbb-esta/lyne-elements/title.js';\nimport { format, isValid } from 'date-fns';\nimport type { CSSResultGroup, 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 { Leg } from '../core/timetable.js';\n\nimport style from './journey-summary.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/divider.js';\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '@sbb-esta/lyne-elements/journey-header.js';\nimport '../pearl-chain-time.js';\n\nexport interface InterfaceSbbJourneySummaryAttributes {\n  legs: Leg[];\n  vias?: string[];\n  origin: string;\n  destination: string;\n  arrivalWalk?: number;\n  departure: string;\n  arrival: string;\n  departureWalk?: number;\n  duration?: number;\n}\n\n/**\n * It displays journey's information.\n *\n * @slot content - Use this slot to add `sbb-button`s or other interactive elements.\n */\n@customElement('sbb-journey-summary')\nexport class SbbJourneySummaryElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**  The trip prop */\n  @property({ type: Object }) public trip!: InterfaceSbbJourneySummaryAttributes;\n\n  /**  The tripBack prop */\n  @property({ attribute: 'trip-back', type: Object })\n  public tripBack?: InterfaceSbbJourneySummaryAttributes;\n\n  /**\n   * The RoundTrip prop. This prop controls if one or two arrows are displayed in the header.\n   */\n  @property({ attribute: 'round-trip', type: Boolean }) public roundTrip?: boolean;\n\n  /** Heading level of the journey header element (e.g. h1-h6). */\n  @property({ attribute: 'header-level' }) public headerLevel: SbbTitleLevel = '3';\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _hasContentSlot: boolean = false;\n  private _language = new SbbLanguageController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._hasContentSlot = Boolean(this.querySelector?.('[slot=\"content\"]'));\n  }\n\n  /**  renders the date of the journey or if it is the current or next day */\n  private _renderJourneyStart(\n    departureTime: Date | undefined,\n    duration: number | undefined,\n  ): TemplateResult | undefined {\n    const dateAdapter = defaultDateAdapter;\n    const durationObj = duration ? durationToTime(duration, this._language.current) : null;\n\n    if (isValid(departureTime)) {\n      return html`\n        <time datetime=${format(departureTime!, 'd') + ' ' + format(departureTime!, 'M')}>\n          ${dateAdapter.format(departureTime).replace(',', '.')}</time\n        >${duration && duration > 0\n          ? html`,<time>\n                <sbb-screen-reader-only>\n                  ${i18nTripDuration[this._language.current]} ${durationObj!.long}\n                </sbb-screen-reader-only>\n                <span aria-hidden=\"true\">${durationObj!.short}</span>\n              </time>`\n          : nothing}\n      `;\n    }\n    return;\n  }\n\n  private _renderJourneyVias(vias: string[]): TemplateResult {\n    const slicedVias = vias.slice(0, 5);\n    return html`\n      <div class=\"sbb-journey-summary__via-block\">\n        <span class=\"sbb-journey-summary__via-text\">Via</span>\n        <ul class=\"sbb-journey-summary__vias\" role=${vias.length <= 1 ? 'presentation' : nothing}>\n          ${slicedVias.map(\n            (via, index) =>\n              html`<li class=\"sbb-journey-summary__via\">\n                ${via}${index !== slicedVias.length - 1 && index < 4\n                  ? html`<span>,</span>`\n                  : nothing}\n              </li>`,\n          )}\n        </ul>\n      </div>\n    `;\n  }\n\n  private _renderJourneyInformation(trip: InterfaceSbbJourneySummaryAttributes): TemplateResult {\n    const { vias, duration, departureWalk, departure, arrivalWalk, arrival, legs } = trip || {};\n\n    return html`\n      <div>\n        ${vias && vias.length > 0 ? this._renderJourneyVias(vias) : nothing}\n        <div class=\"sbb-journey-summary__date\">\n          ${this._renderJourneyStart(removeTimezoneFromISOTimeString(departure), duration)}\n        </div>\n        <sbb-pearl-chain-time\n          .arrivalTime=${arrival}\n          .departureTime=${departure}\n          .departureWalk=${departureWalk}\n          .arrivalWalk=${arrivalWalk}\n          .legs=${legs}\n          .disableAnimation=${this.disableAnimation}\n          .now=${this.now}\n        ></sbb-pearl-chain-time>\n      </div>\n    `;\n  }\n\n  protected override render(): TemplateResult {\n    const { origin, destination } = this.trip || {};\n    return html`\n      <div class=\"sbb-journey-summary\">\n        ${origin\n          ? html`<sbb-journey-header\n              size=\"l\"\n              .level=${this.headerLevel || nothing}\n              .origin=${origin}\n              .destination=${destination}\n              .roundTrip=${this.roundTrip ?? nothing}\n            ></sbb-journey-header>`\n          : nothing}\n        ${this._renderJourneyInformation(this.trip)}\n        ${this.tripBack\n          ? html`<div>\n              <sbb-divider class=\"sbb-journey-summary__divider\"></sbb-divider>\n              ${this._renderJourneyInformation(this.tripBack)}\n            </div>`\n          : nothing}\n        ${this._hasContentSlot\n          ? html` <div class=\"sbb-journey-summary__slot\">\n              <slot name=\"content\"></slot>\n            </div>`\n          : nothing}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-journey-summary': SbbJourneySummaryElement;\n  }\n}\n"],"names":[],"mappings":"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"}
202
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"journey-summary.js","sources":["../../../src/elements-experimental/journey-summary/journey-summary.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { i18nTripDuration } from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport type { SbbTitleLevel } from '@sbb-esta/lyne-elements/title.js';\nimport { format, isValid } from 'date-fns';\nimport type { CSSResultGroup, 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 { Leg } from '../core/timetable.js';\n\nimport style from './journey-summary.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/divider.js';\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '@sbb-esta/lyne-elements/journey-header.js';\nimport '../pearl-chain-time.js';\n\nexport interface InterfaceSbbJourneySummaryAttributes {\n  legs: Leg[];\n  vias?: string[];\n  origin: string;\n  destination: string;\n  arrivalWalk?: number;\n  departure: string;\n  arrival: string;\n  departureWalk?: number;\n  duration?: number;\n}\n\n/**\n * It displays journey's information.\n *\n * @slot content - Use this slot to add `sbb-button`s or other interactive elements.\n */\n@customElement('sbb-journey-summary')\nexport class SbbJourneySummaryElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**  The trip prop */\n  @property({ type: Object }) public trip!: InterfaceSbbJourneySummaryAttributes;\n\n  /**  The tripBack prop */\n  @property({ attribute: 'trip-back', type: Object })\n  public tripBack?: InterfaceSbbJourneySummaryAttributes;\n\n  /**\n   * The RoundTrip prop. This prop controls if one or two arrows are displayed in the header.\n   */\n  @property({ attribute: 'round-trip', type: Boolean }) public roundTrip?: boolean;\n\n  /** Heading level of the journey header element (e.g. h1-h6). */\n  @property({ attribute: 'header-level' }) public headerLevel: SbbTitleLevel = '3';\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _hasContentSlot: boolean = false;\n  private _language = new SbbLanguageController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._hasContentSlot = Boolean(this.querySelector?.('[slot=\"content\"]'));\n  }\n\n  /**  renders the date of the journey or if it is the current or next day */\n  private _renderJourneyStart(\n    departureTime: Date | undefined,\n    duration: number | undefined,\n  ): TemplateResult | undefined {\n    const dateAdapter = defaultDateAdapter;\n    const durationObj = duration ? durationToTime(duration, this._language.current) : null;\n\n    if (isValid(departureTime)) {\n      return html`\n        <time datetime=${format(departureTime!, 'd') + ' ' + format(departureTime!, 'M')}>\n          ${dateAdapter.format(departureTime).replace(',', '.')}</time\n        >${duration && duration > 0\n          ? html`,<time>\n                <sbb-screen-reader-only>\n                  ${i18nTripDuration[this._language.current]} ${durationObj!.long}\n                </sbb-screen-reader-only>\n                <span aria-hidden=\"true\">${durationObj!.short}</span>\n              </time>`\n          : nothing}\n      `;\n    }\n    return;\n  }\n\n  private _renderJourneyVias(vias: string[]): TemplateResult {\n    const slicedVias = vias.slice(0, 5);\n    return html`\n      <div class=\"sbb-journey-summary__via-block\">\n        <span class=\"sbb-journey-summary__via-text\">Via</span>\n        <ul class=\"sbb-journey-summary__vias\" role=${vias.length <= 1 ? 'presentation' : nothing}>\n          ${slicedVias.map(\n            (via, index) =>\n              html`<li class=\"sbb-journey-summary__via\">\n                ${via}${index !== slicedVias.length - 1 && index < 4\n                  ? html`<span>,</span>`\n                  : nothing}\n              </li>`,\n          )}\n        </ul>\n      </div>\n    `;\n  }\n\n  private _renderJourneyInformation(trip: InterfaceSbbJourneySummaryAttributes): TemplateResult {\n    const { vias, duration, departureWalk, departure, arrivalWalk, arrival, legs } = trip || {};\n\n    return html`\n      <div>\n        ${vias && vias.length > 0 ? this._renderJourneyVias(vias) : nothing}\n        <div class=\"sbb-journey-summary__date\">\n          ${this._renderJourneyStart(removeTimezoneFromISOTimeString(departure), duration)}\n        </div>\n        <sbb-pearl-chain-time\n          .arrivalTime=${arrival}\n          .departureTime=${departure}\n          .departureWalk=${departureWalk}\n          .arrivalWalk=${arrivalWalk}\n          .legs=${legs}\n          .disableAnimation=${this.disableAnimation}\n          .now=${this.now}\n        ></sbb-pearl-chain-time>\n      </div>\n    `;\n  }\n\n  protected override render(): TemplateResult {\n    const { origin, destination } = this.trip || {};\n    return html`\n      <div class=\"sbb-journey-summary\">\n        ${origin\n          ? html`<sbb-journey-header\n              size=\"l\"\n              .level=${this.headerLevel || nothing}\n              .origin=${origin}\n              .destination=${destination}\n              .roundTrip=${this.roundTrip ?? nothing}\n            ></sbb-journey-header>`\n          : nothing}\n        ${this._renderJourneyInformation(this.trip)}\n        ${this.tripBack\n          ? html`<div>\n              <sbb-divider class=\"sbb-journey-summary__divider\"></sbb-divider>\n              ${this._renderJourneyInformation(this.tripBack)}\n            </div>`\n          : nothing}\n        ${this._hasContentSlot\n          ? html` <div class=\"sbb-journey-summary__slot\">\n              <slot name=\"content\"></slot>\n            </div>`\n          : nothing}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-journey-summary': SbbJourneySummaryElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,5 @@
1
1
  export declare const futureLeg: any;
2
+ export declare const connectionLeg: any;
2
3
  export declare const extendedLeg: {
3
4
  __typename: string;
4
5
  arrival: {
@@ -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":"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"}
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,aAAa,EAAE,GA2B3B,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"}
@@ -28,6 +28,8 @@ export declare class SbbPearlChainTimeElement extends LitElement {
28
28
  * disable the animation with this property.
29
29
  */
30
30
  disableAnimation?: boolean;
31
+ /** Optional prop to render wheelchair-small instead of walk-small */
32
+ a11yFootpath?: boolean;
31
33
  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */
32
34
  set now(value: SbbDateLike | undefined);
33
35
  get now(): Date;
@@ -1 +1 @@
1
- {"version":3,"file":"pearl-chain-time.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/pearl-chain-time/pearl-chain-time.ts"],"names":[],"mappings":"AAOA,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;AAIhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAK3D,OAAO,mBAAmB,CAAC;AAE3B;;GAEG;AACH,qBACa,wBAAyB,SAAQ,UAAU;IACtD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,EAAG,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D,sEAAsE;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IAEzE,oEAAoE;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErE,0EAA0E;IACV,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvF,uEAAuE;IACT,WAAW,CAAC,EAAE,MAAM,CAAC;IAEnF;;;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,CAErB;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,SAAS,CAAmC;cAEjC,MAAM,IAAI,cAAc;CAmD5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,wBAAwB,CAAC;KAClD;CACF"}
1
+ {"version":3,"file":"pearl-chain-time.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/pearl-chain-time/pearl-chain-time.ts"],"names":[],"mappings":"AAOA,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;AAIhD,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAK3D,OAAO,mBAAmB,CAAC;AAE3B;;GAEG;AACH,qBACa,wBAAyB,SAAQ,UAAU;IACtD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;;;OAOG;IAC+B,IAAI,EAAG,CAAC,GAAG,GAAG,SAAS,CAAC,EAAE,CAAC;IAE7D,sEAAsE;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IAEzE,oEAAoE;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErE,0EAA0E;IACV,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvF,uEAAuE;IACT,WAAW,CAAC,EAAE,MAAM,CAAC;IAEnF;;;OAGG;IACiE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAE/F,qEAAqE;IACL,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvF,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,CAErB;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,SAAS,CAAmC;cAEjC,MAAM,IAAI,cAAc;CAoD5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,wBAAwB,CAAC;KAClD;CACF"}
@@ -7,20 +7,7 @@ import { removeTimezoneFromISOTimeString } from "./core/datetime.js";
7
7
  import { getDepartureArrivalTimeAttribute, isRideLeg } from "./core/timetable.js";
8
8
  import "./pearl-chain.js";
9
9
  import { f as format } from "./format-DkbylFCM.js";
10
- const style = css`/**
11
- * Better font rendering (on OS X)
12
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
13
- *
14
- * Usage:
15
- *
16
- * .var_dark_on_light {
17
- * @include font-smoothing;
18
- * }
19
- * .var_light_on_dark {
20
- * @include font-smoothing-reset;
21
- * }
22
- */
23
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
10
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
24
11
  /*
25
12
  * SBB table mixin
26
13
  * Notes:
@@ -68,12 +55,21 @@ const style = css`/**
68
55
  align-items: center;
69
56
  }
70
57
 
71
- .sbb-pearl-chain__time-walktime--left {
58
+ .sbb-pearl-chain__time-walktime--walk-small-left {
72
59
  transform: translateX(-0.4375rem);
73
60
  margin-inline-end: calc(var(--sbb-spacing-fixed-2x) - 0.4375rem);
74
61
  }
75
62
 
76
- .sbb-pearl-chain__time-walktime--right {
63
+ .sbb-pearl-chain__time-walktime--walk-small-right {
64
+ margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
65
+ }
66
+
67
+ .sbb-pearl-chain__time-walktime--wheelchair-small-left {
68
+ transform: translateX(-0.375rem);
69
+ margin-inline-end: calc(var(--sbb-spacing-fixed-2x) - 0.4375rem);
70
+ }
71
+
72
+ .sbb-pearl-chain__time-walktime--wheelchair-small-right {
77
73
  margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
78
74
  }
79
75
 
@@ -85,11 +81,11 @@ const style = css`/**
85
81
  gap: var(--sbb-spacing-fixed-1x);
86
82
  }
87
83
 
88
- .sbb-pearl-chain__time-transfer--departure {
84
+ .sbb-pearl-chain__time-transfer--sa-ci-departure {
89
85
  margin-inline-end: var(--sbb-spacing-fixed-2x);
90
86
  }
91
87
 
92
- .sbb-pearl-chain__time-transfer--arrival {
88
+ .sbb-pearl-chain__time-transfer--sa-ci-arrival {
93
89
  margin-inline-start: calc(var(--sbb-spacing-fixed-2x) - 0.25rem);
94
90
  }
95
91
 
@@ -151,7 +147,8 @@ let SbbPearlChainTimeElement = class extends LitElement {
151
147
  this.legs,
152
148
  this.departureWalk || 0,
153
149
  this.arrivalWalk || 0,
154
- this._language.current
150
+ this._language.current,
151
+ this.a11yFootpath
155
152
  );
156
153
  const rideLegs = (_a = this.legs) == null ? void 0 : _a.filter((leg) => isRideLeg(leg));
157
154
  return html`
@@ -202,6 +199,9 @@ __decorateClass([
202
199
  __decorateClass([
203
200
  property({ attribute: "disable-animation", type: Boolean })
204
201
  ], SbbPearlChainTimeElement.prototype, "disableAnimation", 2);
202
+ __decorateClass([
203
+ property({ attribute: "a11y-footpath", type: Boolean })
204
+ ], SbbPearlChainTimeElement.prototype, "a11yFootpath", 2);
205
205
  __decorateClass([
206
206
  property()
207
207
  ], SbbPearlChainTimeElement.prototype, "now", 1);
@@ -211,4 +211,4 @@ SbbPearlChainTimeElement = __decorateClass([
211
211
  export {
212
212
  SbbPearlChainTimeElement
213
213
  };
214
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain-time.js","sources":["../../../src/elements-experimental/pearl-chain-time/pearl-chain-time.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport {\n  i18nArrival,\n  i18nDeparture,\n  i18nTransferProcedures,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain-time.scss?lit&inline';\n\nimport '../pearl-chain.js';\n\n/**\n * Combined with `sbb-pearl-chain`, it displays walk time information.\n */\n@customElement('sbb-pearl-chain-time')\nexport class SbbPearlChainTimeElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * define the legs of the pearl-chain.\n   * Format:\n   * `{\"legs\": [{\"duration\": 25}, ...]}`\n   * `duration` in minutes. Duration of the leg is relative\n   * to the total travel time. Example: departure 16:30, change at 16:40,\n   * arrival at 17:00. So the change should have a duration of 33.33%.\n   */\n  @property({ type: Array }) public legs!: (Leg | PtRideLeg)[];\n\n  /** Prop to render the departure time - will be formatted as \"H:mm\" */\n  @property({ attribute: 'departure-time' }) public departureTime?: string;\n\n  /** Prop to render the arrival time - will be formatted as \"H:mm\" */\n  @property({ attribute: 'arrival-time' }) public arrivalTime?: string;\n\n  /** Optional prop to render the walk time (in minutes) before departure */\n  @property({ attribute: 'departure-walk', type: Number }) public departureWalk?: number;\n\n  /** Optional prop to render the walk time (in minutes) after arrival */\n  @property({ attribute: 'arrival-walk', type: Number }) public arrivalWalk?: number;\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override render(): TemplateResult {\n    const departure: Date | undefined = this.departureTime\n      ? removeTimezoneFromISOTimeString(this.departureTime)\n      : undefined;\n    const arrival: Date | undefined = this.arrivalTime\n      ? removeTimezoneFromISOTimeString(this.arrivalTime)\n      : undefined;\n\n    const { renderDepartureTimeAttribute, renderArrivalTimeAttribute } =\n      getDepartureArrivalTimeAttribute(\n        this.legs,\n        this.departureWalk || 0,\n        this.arrivalWalk || 0,\n        this._language.current,\n      );\n\n    const rideLegs = this.legs?.filter((leg) => isRideLeg(leg));\n    return html`\n      <div class=\"sbb-pearl-chain__time\">\n        ${renderDepartureTimeAttribute()}\n        ${departure\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.departureTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nDeparture[this._language.current]}:&nbsp;</span\n              >\n              ${format(departure, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${rideLegs?.length > 1\n          ? html`<span class=\"sbb-screen-reader-only\" role=\"paragraph\">\n              ${rideLegs?.length - 1} ${i18nTransferProcedures[this._language.current]}\n            </span>`\n          : nothing}\n        <sbb-pearl-chain\n          class=\"sbb-pearl-chain__time-chain\"\n          .legs=${this.legs}\n          .disableAnimation=${this.disableAnimation}\n          .now=${this.now}\n        ></sbb-pearl-chain>\n        ${arrival\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.arrivalTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nArrival[this._language.current]}:&nbsp;</span\n              >\n              ${format(arrival, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${renderArrivalTimeAttribute()}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain-time': SbbPearlChainTimeElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBa,IAAA,2BAAN,cAAuC,WAAW;AAAA,EAAlD,cAAA;AAAA,UAAA,GAAA,SAAA;AAuCL,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,SAAyB;;AAC1C,UAAM,YAA8B,KAAK,gBACrC,gCAAgC,KAAK,aAAa,IAClD;AACJ,UAAM,UAA4B,KAAK,cACnC,gCAAgC,KAAK,WAAW,IAChD;AAEE,UAAA,EAAE,8BAA8B,2BAAA,IACpC;AAAA,MACE,KAAK;AAAA,MACL,KAAK,iBAAiB;AAAA,MACtB,KAAK,eAAe;AAAA,MACpB,KAAK,UAAU;AAAA,IAAA;AAGb,UAAA,YAAW,UAAK,SAAL,mBAAW,OAAO,CAAC,QAAQ,UAAU,GAAG;AAClD,WAAA;AAAA;AAAA,UAED,8BAA8B;AAAA,UAC9B,YACE,yDAAyD,KAAK,aAAc;AAAA;AAAA,mBAErE,cAAc,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA,gBAExC,OAAO,WAAW,OAAO,CAAC;AAAA,uBAE9B,OAAO;AAAA,WACT,qCAAU,UAAS,IACjB;AAAA,iBACI,qCAAU,UAAS,CAAC,IAAI,uBAAuB,KAAK,UAAU,OAAO,CAAC;AAAA,uBAE1E,OAAO;AAAA;AAAA;AAAA,kBAGD,KAAK,IAAI;AAAA,8BACG,KAAK,gBAAgB;AAAA,iBAClC,KAAK,GAAG;AAAA;AAAA,UAEf,UACE,yDAAyD,KAAK,WAAY;AAAA;AAAA,mBAEnE,YAAY,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA,gBAEtC,OAAO,SAAS,OAAO,CAAC;AAAA,uBAE5B,OAAO;AAAA,UACT,4BAA4B;AAAA;AAAA;AAAA,EAGpC;AACF;AA9Fa,yBACY,SAAyB;AAUd,gBAAA;AAAA,EAAjC,SAAS,EAAE,MAAM,OAAO;AAAA,GAXd,yBAWuB,WAAA,QAAA,CAAA;AAGgB,gBAAA;AAAA,EAAjD,SAAS,EAAE,WAAW,kBAAkB;AAAA,GAd9B,yBAcuC,WAAA,iBAAA,CAAA;AAGF,gBAAA;AAAA,EAA/C,SAAS,EAAE,WAAW,gBAAgB;AAAA,GAjB5B,yBAiBqC,WAAA,eAAA,CAAA;AAGgB,gBAAA;AAAA,EAA/D,SAAS,EAAE,WAAW,kBAAkB,MAAM,QAAQ;AAAA,GApB5C,yBAoBqD,WAAA,iBAAA,CAAA;AAGF,gBAAA;AAAA,EAA7D,SAAS,EAAE,WAAW,gBAAgB,MAAM,QAAQ;AAAA,GAvB1C,yBAuBmD,WAAA,eAAA,CAAA;AAMM,gBAAA;AAAA,EAAnE,SAAS,EAAE,WAAW,qBAAqB,MAAM,SAAS;AAAA,GA7BhD,yBA6ByD,WAAA,oBAAA,CAAA;AAIzD,gBAAA;AAAA,EADV,SAAS;AAAA,GAhCC,yBAiCA,WAAA,OAAA,CAAA;AAjCA,2BAAN,gBAAA;AAAA,EADN,cAAc,sBAAsB;AAAA,GACxB,wBAAA;"}
214
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain-time.js","sources":["../../../src/elements-experimental/pearl-chain-time/pearl-chain-time.ts"],"sourcesContent":["import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport {\n  i18nArrival,\n  i18nDeparture,\n  i18nTransferProcedures,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain-time.scss?lit&inline';\n\nimport '../pearl-chain.js';\n\n/**\n * Combined with `sbb-pearl-chain`, it displays walk time information.\n */\n@customElement('sbb-pearl-chain-time')\nexport class SbbPearlChainTimeElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * define the legs of the pearl-chain.\n   * Format:\n   * `{\"legs\": [{\"duration\": 25}, ...]}`\n   * `duration` in minutes. Duration of the leg is relative\n   * to the total travel time. Example: departure 16:30, change at 16:40,\n   * arrival at 17:00. So the change should have a duration of 33.33%.\n   */\n  @property({ type: Array }) public legs!: (Leg | PtRideLeg)[];\n\n  /** Prop to render the departure time - will be formatted as \"H:mm\" */\n  @property({ attribute: 'departure-time' }) public departureTime?: string;\n\n  /** Prop to render the arrival time - will be formatted as \"H:mm\" */\n  @property({ attribute: 'arrival-time' }) public arrivalTime?: string;\n\n  /** Optional prop to render the walk time (in minutes) before departure */\n  @property({ attribute: 'departure-walk', type: Number }) public departureWalk?: number;\n\n  /** Optional prop to render the walk time (in minutes) after arrival */\n  @property({ attribute: 'arrival-walk', type: Number }) public arrivalWalk?: number;\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** Optional prop to render wheelchair-small instead of walk-small */\n  @property({ attribute: 'a11y-footpath', type: Boolean }) public a11yFootpath?: 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 render(): TemplateResult {\n    const departure: Date | undefined = this.departureTime\n      ? removeTimezoneFromISOTimeString(this.departureTime)\n      : undefined;\n    const arrival: Date | undefined = this.arrivalTime\n      ? removeTimezoneFromISOTimeString(this.arrivalTime)\n      : undefined;\n\n    const { renderDepartureTimeAttribute, renderArrivalTimeAttribute } =\n      getDepartureArrivalTimeAttribute(\n        this.legs,\n        this.departureWalk || 0,\n        this.arrivalWalk || 0,\n        this._language.current,\n        this.a11yFootpath,\n      );\n\n    const rideLegs = this.legs?.filter((leg) => isRideLeg(leg));\n    return html`\n      <div class=\"sbb-pearl-chain__time\">\n        ${renderDepartureTimeAttribute()}\n        ${departure\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.departureTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nDeparture[this._language.current]}:&nbsp;</span\n              >\n              ${format(departure, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${rideLegs?.length > 1\n          ? html`<span class=\"sbb-screen-reader-only\" role=\"paragraph\">\n              ${rideLegs?.length - 1} ${i18nTransferProcedures[this._language.current]}\n            </span>`\n          : nothing}\n        <sbb-pearl-chain\n          class=\"sbb-pearl-chain__time-chain\"\n          .legs=${this.legs}\n          .disableAnimation=${this.disableAnimation}\n          .now=${this.now}\n        ></sbb-pearl-chain>\n        ${arrival\n          ? html`<time class=\"sbb-pearl-chain__time-time\" datetime=${this.arrivalTime!}>\n              <span class=\"sbb-screen-reader-only\"\n                >${i18nArrival[this._language.current]}:&nbsp;</span\n              >\n              ${format(arrival, 'HH:mm')}\n            </time>`\n          : nothing}\n        ${renderArrivalTimeAttribute()}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain-time': SbbPearlChainTimeElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBa,IAAA,2BAAN,cAAuC,WAAW;AAAA,EAAlD,cAAA;AAAA,UAAA,GAAA,SAAA;AA0CL,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,SAAyB;;AAC1C,UAAM,YAA8B,KAAK,gBACrC,gCAAgC,KAAK,aAAa,IAClD;AACJ,UAAM,UAA4B,KAAK,cACnC,gCAAgC,KAAK,WAAW,IAChD;AAEE,UAAA,EAAE,8BAA8B,2BAAA,IACpC;AAAA,MACE,KAAK;AAAA,MACL,KAAK,iBAAiB;AAAA,MACtB,KAAK,eAAe;AAAA,MACpB,KAAK,UAAU;AAAA,MACf,KAAK;AAAA,IAAA;AAGH,UAAA,YAAW,UAAK,SAAL,mBAAW,OAAO,CAAC,QAAQ,UAAU,GAAG;AAClD,WAAA;AAAA;AAAA,UAED,8BAA8B;AAAA,UAC9B,YACE,yDAAyD,KAAK,aAAc;AAAA;AAAA,mBAErE,cAAc,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA,gBAExC,OAAO,WAAW,OAAO,CAAC;AAAA,uBAE9B,OAAO;AAAA,WACT,qCAAU,UAAS,IACjB;AAAA,iBACI,qCAAU,UAAS,CAAC,IAAI,uBAAuB,KAAK,UAAU,OAAO,CAAC;AAAA,uBAE1E,OAAO;AAAA;AAAA;AAAA,kBAGD,KAAK,IAAI;AAAA,8BACG,KAAK,gBAAgB;AAAA,iBAClC,KAAK,GAAG;AAAA;AAAA,UAEf,UACE,yDAAyD,KAAK,WAAY;AAAA;AAAA,mBAEnE,YAAY,KAAK,UAAU,OAAO,CAAC;AAAA;AAAA,gBAEtC,OAAO,SAAS,OAAO,CAAC;AAAA,uBAE5B,OAAO;AAAA,UACT,4BAA4B;AAAA;AAAA;AAAA,EAGpC;AACF;AAlGa,yBACY,SAAyB;AAUd,gBAAA;AAAA,EAAjC,SAAS,EAAE,MAAM,OAAO;AAAA,GAXd,yBAWuB,WAAA,QAAA,CAAA;AAGgB,gBAAA;AAAA,EAAjD,SAAS,EAAE,WAAW,kBAAkB;AAAA,GAd9B,yBAcuC,WAAA,iBAAA,CAAA;AAGF,gBAAA;AAAA,EAA/C,SAAS,EAAE,WAAW,gBAAgB;AAAA,GAjB5B,yBAiBqC,WAAA,eAAA,CAAA;AAGgB,gBAAA;AAAA,EAA/D,SAAS,EAAE,WAAW,kBAAkB,MAAM,QAAQ;AAAA,GApB5C,yBAoBqD,WAAA,iBAAA,CAAA;AAGF,gBAAA;AAAA,EAA7D,SAAS,EAAE,WAAW,gBAAgB,MAAM,QAAQ;AAAA,GAvB1C,yBAuBmD,WAAA,eAAA,CAAA;AAMM,gBAAA;AAAA,EAAnE,SAAS,EAAE,WAAW,qBAAqB,MAAM,SAAS;AAAA,GA7BhD,yBA6ByD,WAAA,oBAAA,CAAA;AAGJ,gBAAA;AAAA,EAA/D,SAAS,EAAE,WAAW,iBAAiB,MAAM,SAAS;AAAA,GAhC5C,yBAgCqD,WAAA,gBAAA,CAAA;AAIrD,gBAAA;AAAA,EADV,SAAS;AAAA,GAnCC,yBAoCA,WAAA,OAAA,CAAA;AApCA,2BAAN,gBAAA;AAAA,EADN,cAAc,sBAAsB;AAAA,GACxB,wBAAA;"}
@@ -1,19 +1,6 @@
1
1
  import { css, LitElement, html, nothing } from "lit";
2
2
  import { property, customElement } from "lit/decorators.js";
3
- const style = css`/**
4
- * Better font rendering (on OS X)
5
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
6
- *
7
- * Usage:
8
- *
9
- * .var_dark_on_light {
10
- * @include font-smoothing;
11
- * }
12
- * .var_light_on_dark {
13
- * @include font-smoothing-reset;
14
- * }
15
- */
16
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
3
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
17
4
  /*
18
5
  * SBB table mixin
19
6
  * Notes:
@@ -375,4 +362,4 @@ SbbPearlChainVerticalItemElement = __decorateClass([
375
362
  export {
376
363
  SbbPearlChainVerticalItemElement
377
364
  };
378
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtL3BlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW0udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCwgbm90aGluZyB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS5zY3NzP2xpdCZpbmxpbmUnO1xuXG5leHBvcnQgdHlwZSBMaW5lVHlwZSA9ICdkb3R0ZWQnIHwgJ3N0YW5kYXJkJyB8ICd0aGluJztcblxuZXhwb3J0IHR5cGUgQnVsbGV0VHlwZSA9ICdkZWZhdWx0JyB8ICdwYXN0JyB8ICdpcnJlbGV2YW50JyB8ICdza2lwcGVkJyB8ICdkaXNydXB0aW9uJztcblxuZXhwb3J0IHR5cGUgTGluZUNvbG9yID0gJ2RlZmF1bHQnIHwgJ3Bhc3QnIHwgJ2Rpc3J1cHRpb24nIHwgJ3dhbGsnO1xuXG5leHBvcnQgdHlwZSBCdWxsZXRTaXplID0gJ3N0YXJ0LWVuZCcgfCAnc3RvcCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVhcmxDaGFpblZlcnRpY2FsSXRlbUF0dHJpYnV0ZXMge1xuICBsaW5lVHlwZTogTGluZVR5cGU7XG4gIGxpbmVDb2xvcjogTGluZUNvbG9yO1xuICBidWxsZXRUeXBlPzogQnVsbGV0VHlwZTtcbiAgbWluSGVpZ2h0OiBudW1iZXI7XG4gIGhpZGVMaW5lOiBib29sZWFuO1xuICBidWxsZXRTaXplOiBCdWxsZXRTaXplO1xuICBwb3NpdGlvbj86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBkZXRhaWxzIGFib3V0IGNvbm5lY3Rpb24gYmV0d2VlbiBzdGF0aW9ucy5cbiAqXG4gKiBAc2xvdCBsZWZ0IC0gQ29udGVudCBvZiB0aGUgbGVmdCBzaWRlIG9mIHRoZSBpdGVtXG4gKiBAc2xvdCByaWdodCAtIENvbnRlbnQgb2YgdGhlIHJpZ2h0IHNpZGUgb2YgdGhlIGl0ZW1cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtJylcbmV4cG9ydCBjbGFzcyBTYmJQZWFybENoYWluVmVydGljYWxJdGVtRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogVGhlIHBlYXJsQ2hhaW5WZXJ0aWNhbEl0ZW1BdHRyaWJ1dGVzIFByb3AgZm9yIHN0eWxpbmcgdGhlIGJ1bGxldHMgYW5kIGxpbmUuKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAncGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1hdHRyaWJ1dGVzJywgdHlwZTogT2JqZWN0IH0pXG4gIHB1YmxpYyBwZWFybENoYWluVmVydGljYWxJdGVtQXR0cmlidXRlcyE6IFBlYXJsQ2hhaW5WZXJ0aWNhbEl0ZW1BdHRyaWJ1dGVzO1xuXG4gIC8qKiBJZiB0cnVlLCB0aGUgcG9zaXRpb24gd29uJ3QgYmUgYW5pbWF0ZWQuICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2Rpc2FibGUtYW5pbWF0aW9uJywgcmVmbGVjdDogdHJ1ZSwgdHlwZTogQm9vbGVhbiB9KVxuICBwdWJsaWMgZGlzYWJsZUFuaW1hdGlvbj86IGJvb2xlYW47XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgY29uc3QgeyBidWxsZXRUeXBlLCBsaW5lVHlwZSwgbGluZUNvbG9yLCBoaWRlTGluZSwgbWluSGVpZ2h0LCBidWxsZXRTaXplLCBwb3NpdGlvbiB9ID1cbiAgICAgIHRoaXMucGVhcmxDaGFpblZlcnRpY2FsSXRlbUF0dHJpYnV0ZXMgfHwge307XG5cbiAgICBjb25zdCBidWxsZXRUeXBlQ2xhc3MgPVxuICAgICAgcG9zaXRpb24gJiYgcG9zaXRpb24gPiAwICYmIHBvc2l0aW9uIDw9IDEwMFxuICAgICAgICA/ICdzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS1wYXN0J1xuICAgICAgICA6IGBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS0ke2J1bGxldFR5cGV9YDtcblxuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19jb2x1bW5cIiBzdHlsZT1cImhlaWdodDogJHttaW5IZWlnaHR9cHg7XCI+XG4gICAgICAgIDxzbG90IG5hbWU9XCJsZWZ0XCI+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2XG4gICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgIGNsYXNzPVwic2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW1fX2NvbHVtbiBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fY29sdW1uLS1taWRkbGVcIlxuICAgICAgPlxuICAgICAgICAkeyFoaWRlTGluZVxuICAgICAgICAgID8gaHRtbGA8ZGl2XG4gICAgICAgICAgICAgIHN0eWxlPVwiLS1zYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1sZWctc3RhdHVzOiR7cG9zaXRpb259JTtcIlxuICAgICAgICAgICAgICBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19saW5lIHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19saW5lLS0ke2xpbmVUeXBlfSBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fbGluZS0tJHtsaW5lQ29sb3J9XCJcbiAgICAgICAgICAgID48L2Rpdj5gXG4gICAgICAgICAgOiBub3RoaW5nfVxuICAgICAgICAke2J1bGxldFR5cGVcbiAgICAgICAgICA/IGh0bWxgPGRpdlxuICAgICAgICAgICAgICBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19idWxsZXQgIHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19idWxsZXQtLSR7YnVsbGV0U2l6ZX0gJHtidWxsZXRUeXBlQ2xhc3N9XCJcbiAgICAgICAgICAgID48L2Rpdj5gXG4gICAgICAgICAgOiBub3RoaW5nfVxuICAgICAgICAke3Bvc2l0aW9uICYmIHBvc2l0aW9uID4gMFxuICAgICAgICAgID8gaHRtbGA8ZGl2XG4gICAgICAgICAgICAgIHN0eWxlPVwiLS1zYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1wb3NpdGlvbjoke3Bvc2l0aW9ufSU7XCJcbiAgICAgICAgICAgICAgY2xhc3M9XCJzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS1wb3NpdGlvblwiXG4gICAgICAgICAgICA+PC9kaXY+YFxuICAgICAgICAgIDogbm90aGluZ31cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInJpZ2h0XCI+PC9zbG90PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtJzogU2JiUGVhcmxDaGFpblZlcnRpY2FsSXRlbUVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUErQmEsSUFBQSxtQ0FBTixjQUErQyxXQUFXO0FBQUEsRUFXNUMsU0FBeUI7QUFDcEMsVUFBQSxFQUFFLFlBQVksVUFBVSxXQUFXLFVBQVUsV0FBVyxZQUFZLFNBQVMsSUFDakYsS0FBSyxvQ0FBb0MsQ0FBQTtBQUVyQyxVQUFBLGtCQUNKLFlBQVksV0FBVyxLQUFLLFlBQVksTUFDcEMsZ0RBQ0EsMENBQTBDLFVBQVU7QUFFbkQsV0FBQTtBQUFBLDBFQUMrRCxTQUFTO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsVUFPekUsQ0FBQyxXQUNDO0FBQUEsa0VBQ3NELFFBQVE7QUFBQSxnR0FDc0IsUUFBUSx5Q0FBeUMsU0FBUztBQUFBLHVCQUU5SSxPQUFPO0FBQUEsVUFDVCxhQUNFO0FBQUEscUdBQ3lGLFVBQVUsSUFBSSxlQUFlO0FBQUEsdUJBRXRILE9BQU87QUFBQSxVQUNULFlBQVksV0FBVyxJQUNyQjtBQUFBLGdFQUNvRCxRQUFRO0FBQUE7QUFBQSx1QkFHNUQsT0FBTztBQUFBO0FBQUE7QUFBQTtBQUFBLEVBSWpCO0FBQ0Y7QUFqRGEsaUNBQ1ksU0FBeUI7QUFJekMsZ0JBQUE7QUFBQSxFQUROLFNBQVMsRUFBRSxXQUFXLHdDQUF3QyxNQUFNLFFBQVE7QUFBQSxHQUpsRSxpQ0FLSixXQUFBLG9DQUFBLENBQUE7QUFJQSxnQkFBQTtBQUFBLEVBRE4sU0FBUyxFQUFFLFdBQVcscUJBQXFCLFNBQVMsTUFBTSxNQUFNLFNBQVM7QUFBQSxHQVIvRCxpQ0FTSixXQUFBLG9CQUFBLENBQUE7QUFUSSxtQ0FBTixnQkFBQTtBQUFBLEVBRE4sY0FBYywrQkFBK0I7QUFBQSxHQUNqQyxnQ0FBQTsifQ==
365
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzLWV4cGVyaW1lbnRhbC9wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtL3BlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW0udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCwgbm90aGluZyB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS5zY3NzP2xpdCZpbmxpbmUnO1xuXG5leHBvcnQgdHlwZSBMaW5lVHlwZSA9ICdkb3R0ZWQnIHwgJ3N0YW5kYXJkJyB8ICd0aGluJztcblxuZXhwb3J0IHR5cGUgQnVsbGV0VHlwZSA9ICdkZWZhdWx0JyB8ICdwYXN0JyB8ICdpcnJlbGV2YW50JyB8ICdza2lwcGVkJyB8ICdkaXNydXB0aW9uJztcblxuZXhwb3J0IHR5cGUgTGluZUNvbG9yID0gJ2RlZmF1bHQnIHwgJ3Bhc3QnIHwgJ2Rpc3J1cHRpb24nIHwgJ3dhbGsnO1xuXG5leHBvcnQgdHlwZSBCdWxsZXRTaXplID0gJ3N0YXJ0LWVuZCcgfCAnc3RvcCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVhcmxDaGFpblZlcnRpY2FsSXRlbUF0dHJpYnV0ZXMge1xuICBsaW5lVHlwZTogTGluZVR5cGU7XG4gIGxpbmVDb2xvcjogTGluZUNvbG9yO1xuICBidWxsZXRUeXBlPzogQnVsbGV0VHlwZTtcbiAgbWluSGVpZ2h0OiBudW1iZXI7XG4gIGhpZGVMaW5lOiBib29sZWFuO1xuICBidWxsZXRTaXplOiBCdWxsZXRTaXplO1xuICBwb3NpdGlvbj86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBkZXRhaWxzIGFib3V0IGNvbm5lY3Rpb24gYmV0d2VlbiBzdGF0aW9ucy5cbiAqXG4gKiBAc2xvdCBsZWZ0IC0gQ29udGVudCBvZiB0aGUgbGVmdCBzaWRlIG9mIHRoZSBpdGVtXG4gKiBAc2xvdCByaWdodCAtIENvbnRlbnQgb2YgdGhlIHJpZ2h0IHNpZGUgb2YgdGhlIGl0ZW1cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtJylcbmV4cG9ydCBjbGFzcyBTYmJQZWFybENoYWluVmVydGljYWxJdGVtRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogVGhlIHBlYXJsQ2hhaW5WZXJ0aWNhbEl0ZW1BdHRyaWJ1dGVzIFByb3AgZm9yIHN0eWxpbmcgdGhlIGJ1bGxldHMgYW5kIGxpbmUuKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAncGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1hdHRyaWJ1dGVzJywgdHlwZTogT2JqZWN0IH0pXG4gIHB1YmxpYyBwZWFybENoYWluVmVydGljYWxJdGVtQXR0cmlidXRlcyE6IFBlYXJsQ2hhaW5WZXJ0aWNhbEl0ZW1BdHRyaWJ1dGVzO1xuXG4gIC8qKiBJZiB0cnVlLCB0aGUgcG9zaXRpb24gd29uJ3QgYmUgYW5pbWF0ZWQuICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2Rpc2FibGUtYW5pbWF0aW9uJywgcmVmbGVjdDogdHJ1ZSwgdHlwZTogQm9vbGVhbiB9KVxuICBwdWJsaWMgZGlzYWJsZUFuaW1hdGlvbj86IGJvb2xlYW47XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgY29uc3QgeyBidWxsZXRUeXBlLCBsaW5lVHlwZSwgbGluZUNvbG9yLCBoaWRlTGluZSwgbWluSGVpZ2h0LCBidWxsZXRTaXplLCBwb3NpdGlvbiB9ID1cbiAgICAgIHRoaXMucGVhcmxDaGFpblZlcnRpY2FsSXRlbUF0dHJpYnV0ZXMgfHwge307XG5cbiAgICBjb25zdCBidWxsZXRUeXBlQ2xhc3MgPVxuICAgICAgcG9zaXRpb24gJiYgcG9zaXRpb24gPiAwICYmIHBvc2l0aW9uIDw9IDEwMFxuICAgICAgICA/ICdzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS1wYXN0J1xuICAgICAgICA6IGBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS0ke2J1bGxldFR5cGV9YDtcblxuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19jb2x1bW5cIiBzdHlsZT1cImhlaWdodDogJHttaW5IZWlnaHR9cHg7XCI+XG4gICAgICAgIDxzbG90IG5hbWU9XCJsZWZ0XCI+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2XG4gICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgIGNsYXNzPVwic2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW1fX2NvbHVtbiBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fY29sdW1uLS1taWRkbGVcIlxuICAgICAgPlxuICAgICAgICAkeyFoaWRlTGluZVxuICAgICAgICAgID8gaHRtbGA8ZGl2XG4gICAgICAgICAgICAgIHN0eWxlPVwiLS1zYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1sZWctc3RhdHVzOiR7cG9zaXRpb259JTtcIlxuICAgICAgICAgICAgICBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19saW5lIHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19saW5lLS0ke2xpbmVUeXBlfSBzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fbGluZS0tJHtsaW5lQ29sb3J9XCJcbiAgICAgICAgICAgID48L2Rpdj5gXG4gICAgICAgICAgOiBub3RoaW5nfVxuICAgICAgICAke2J1bGxldFR5cGVcbiAgICAgICAgICA/IGh0bWxgPGRpdlxuICAgICAgICAgICAgICBjbGFzcz1cInNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19idWxsZXQgIHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtX19idWxsZXQtLSR7YnVsbGV0U2l6ZX0gJHtidWxsZXRUeXBlQ2xhc3N9XCJcbiAgICAgICAgICAgID48L2Rpdj5gXG4gICAgICAgICAgOiBub3RoaW5nfVxuICAgICAgICAke3Bvc2l0aW9uICYmIHBvc2l0aW9uID4gMFxuICAgICAgICAgID8gaHRtbGA8ZGl2XG4gICAgICAgICAgICAgIHN0eWxlPVwiLS1zYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbS1wb3NpdGlvbjoke3Bvc2l0aW9ufSU7XCJcbiAgICAgICAgICAgICAgY2xhc3M9XCJzYmItcGVhcmwtY2hhaW4tdmVydGljYWwtaXRlbV9fYnVsbGV0LS1wb3NpdGlvblwiXG4gICAgICAgICAgICA+PC9kaXY+YFxuICAgICAgICAgIDogbm90aGluZ31cbiAgICAgIDwvZGl2PlxuICAgICAgPHNsb3QgbmFtZT1cInJpZ2h0XCI+PC9zbG90PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtJzogU2JiUGVhcmxDaGFpblZlcnRpY2FsSXRlbUVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQStCYSxJQUFBLG1DQUFOLGNBQStDLFdBQVc7QUFBQSxFQVc1QyxTQUF5QjtBQUNwQyxVQUFBLEVBQUUsWUFBWSxVQUFVLFdBQVcsVUFBVSxXQUFXLFlBQVksU0FBUyxJQUNqRixLQUFLLG9DQUFvQyxDQUFBO0FBRXJDLFVBQUEsa0JBQ0osWUFBWSxXQUFXLEtBQUssWUFBWSxNQUNwQyxnREFDQSwwQ0FBMEMsVUFBVTtBQUVuRCxXQUFBO0FBQUEsMEVBQytELFNBQVM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxVQU96RSxDQUFDLFdBQ0M7QUFBQSxrRUFDc0QsUUFBUTtBQUFBLGdHQUNzQixRQUFRLHlDQUF5QyxTQUFTO0FBQUEsdUJBRTlJLE9BQU87QUFBQSxVQUNULGFBQ0U7QUFBQSxxR0FDeUYsVUFBVSxJQUFJLGVBQWU7QUFBQSx1QkFFdEgsT0FBTztBQUFBLFVBQ1QsWUFBWSxXQUFXLElBQ3JCO0FBQUEsZ0VBQ29ELFFBQVE7QUFBQTtBQUFBLHVCQUc1RCxPQUFPO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFJakI7QUFDRjtBQWpEYSxpQ0FDWSxTQUF5QjtBQUl6QyxnQkFBQTtBQUFBLEVBRE4sU0FBUyxFQUFFLFdBQVcsd0NBQXdDLE1BQU0sUUFBUTtBQUFBLEdBSmxFLGlDQUtKLFdBQUEsb0NBQUEsQ0FBQTtBQUlBLGdCQUFBO0FBQUEsRUFETixTQUFTLEVBQUUsV0FBVyxxQkFBcUIsU0FBUyxNQUFNLE1BQU0sU0FBUztBQUFBLEdBUi9ELGlDQVNKLFdBQUEsb0JBQUEsQ0FBQTtBQVRJLG1DQUFOLGdCQUFBO0FBQUEsRUFETixjQUFjLCtCQUErQjtBQUFBLEdBQ2pDLGdDQUFBOyJ9
@@ -1,19 +1,6 @@
1
1
  import { css, LitElement, html } from "lit";
2
2
  import { customElement } from "lit/decorators.js";
3
- const style = css`/**
4
- * Better font rendering (on OS X)
5
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
6
- *
7
- * Usage:
8
- *
9
- * .var_dark_on_light {
10
- * @include font-smoothing;
11
- * }
12
- * .var_light_on_dark {
13
- * @include font-smoothing-reset;
14
- * }
15
- */
16
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
3
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
17
4
  /*
18
5
  * SBB table mixin
19
6
  * Notes:
@@ -61,4 +48,4 @@ SbbPearlChainVerticalElement = __decorateClass([
61
48
  export {
62
49
  SbbPearlChainVerticalElement
63
50
  };
64
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVhcmwtY2hhaW4tdmVydGljYWwuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lbGVtZW50cy1leHBlcmltZW50YWwvcGVhcmwtY2hhaW4tdmVydGljYWwvcGVhcmwtY2hhaW4tdmVydGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9wZWFybC1jaGFpbi12ZXJ0aWNhbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIEl0IGNhbiBiZSB1c2VkIGFzIGEgY29udGFpbmVyIGZvciB0aGUgYHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtYCBjb21wb25lbnQuXG4gKlxuICogQHNsb3QgLSBUaGUgdW5uYW1lZCBzbG90IGlzIHVzZWQgZm9yIHRoZSBgc2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW1gIGNvbXBvbmVudC5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbCcpXG5leHBvcnQgY2xhc3MgU2JiUGVhcmxDaGFpblZlcnRpY2FsRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItcGVhcmwtY2hhaW4tdmVydGljYWxcIj5cbiAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsJzogU2JiUGVhcmxDaGFpblZlcnRpY2FsRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWWEsSUFBQSwrQkFBTixjQUEyQyxXQUFXO0FBQUEsRUFHeEMsU0FBeUI7QUFDbkMsV0FBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFLVDtBQUNGO0FBVmEsNkJBQ1ksU0FBeUI7QUFEckMsK0JBQU4sZ0JBQUE7QUFBQSxFQUROLGNBQWMsMEJBQTBCO0FBQUEsR0FDNUIsNEJBQUE7In0=
51
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVhcmwtY2hhaW4tdmVydGljYWwuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lbGVtZW50cy1leHBlcmltZW50YWwvcGVhcmwtY2hhaW4tdmVydGljYWwvcGVhcmwtY2hhaW4tdmVydGljYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9wZWFybC1jaGFpbi12ZXJ0aWNhbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIEl0IGNhbiBiZSB1c2VkIGFzIGEgY29udGFpbmVyIGZvciB0aGUgYHNiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbC1pdGVtYCBjb21wb25lbnQuXG4gKlxuICogQHNsb3QgLSBUaGUgdW5uYW1lZCBzbG90IGlzIHVzZWQgZm9yIHRoZSBgc2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsLWl0ZW1gIGNvbXBvbmVudC5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1wZWFybC1jaGFpbi12ZXJ0aWNhbCcpXG5leHBvcnQgY2xhc3MgU2JiUGVhcmxDaGFpblZlcnRpY2FsRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItcGVhcmwtY2hhaW4tdmVydGljYWxcIj5cbiAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXBlYXJsLWNoYWluLXZlcnRpY2FsJzogU2JiUGVhcmxDaGFpblZlcnRpY2FsRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFZYSxJQUFBLCtCQUFOLGNBQTJDLFdBQVc7QUFBQSxFQUd4QyxTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQUtUO0FBQ0Y7QUFWYSw2QkFDWSxTQUF5QjtBQURyQywrQkFBTixnQkFBQTtBQUFBLEVBRE4sY0FBYywwQkFBMEI7QUFBQSxHQUM1Qiw0QkFBQTsifQ==
@@ -16,20 +16,7 @@ function isBefore(date, dateToCompare) {
16
16
  const _dateToCompare = toDate(dateToCompare);
17
17
  return +_date < +_dateToCompare;
18
18
  }
19
- const style = css`/**
20
- * Better font rendering (on OS X)
21
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
22
- *
23
- * Usage:
24
- *
25
- * .var_dark_on_light {
26
- * @include font-smoothing;
27
- * }
28
- * .var_light_on_dark {
29
- * @include font-smoothing-reset;
30
- * }
31
- */
32
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
19
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
33
20
  /*
34
21
  * SBB table mixin
35
22
  * Notes:
@@ -44,7 +31,7 @@ const style = css`/**
44
31
 
45
32
  :host {
46
33
  --sbb-pearl-chain-height: var(--sbb-border-width-2x);
47
- --sbb-pearl-chain-spacing-small: var(--sbb-spacing-fixed-1x);
34
+ --sbb-pearl-chain-spacing-small: 0.125rem;
48
35
  --sbb-pearl-chain-color: var(--sbb-pearl-chain-bullet-color);
49
36
  --sbb-pearl-chain-color-disruption: var(--sbb-pearl-chain-bullet-color-disruption);
50
37
  --sbb-pearl-chain-color-past: var(--sbb-pearl-chain-bullet-color-past);
@@ -626,4 +613,4 @@ SbbPearlChainElement = __decorateClass([
626
613
  export {
627
614
  SbbPearlChainElement
628
615
  };
629
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.mjs","../../../node_modules/date-fns/isBefore.mjs","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date that should be after the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is after the second date\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\nexport function isAfter(date, dateToCompare) {\n  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return _date.getTime() > _dateToCompare.getTime();\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date that should be before the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is before the second date\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\nexport function isBefore(date, dateToCompare) {\n  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return +_date < +_dateToCompare;\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\n","import { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { addMinutes, differenceInMinutes, isAfter, isBefore } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain.scss?lit&inline';\n\ntype Status = 'progress' | 'future' | 'past';\ntype Time = {\n  time?: Date;\n  delay: number;\n};\n\n/**\n * It visually displays journey information.\n */\n@customElement('sbb-pearl-chain')\nexport class SbbPearlChainElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define the legs of the pearl-chain.\n   * Format:\n   * `{\"legs\": [{\"duration\": 25}, ...]}`\n   * `duration` in minutes. Duration of the leg is relative\n   * to the total travel time. Example: departure 16:30, change at 16:40,\n   * arrival at 17:00. So the change should have a duration of 33.33%.\n   */\n  @property({ type: Array }) public legs?: (Leg | PtRideLeg)[];\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date | null {\n    return this._now;\n  }\n  private _now: Date | null = null;\n\n  private _getAllDuration(legs: PtRideLeg[]): number {\n    return legs?.reduce((sum: number, leg) => {\n      const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n      const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n      if (arrivalNoTz && departureNoTz) {\n        return (\n          sum +\n          differenceInMinutes(\n            removeTimezoneFromISOTimeString(leg.arrival.time)!,\n            removeTimezoneFromISOTimeString(leg.departure.time)!,\n          )\n        );\n      }\n      return sum;\n    }, 0);\n  }\n\n  private _isAllCancelled(legs: PtRideLeg[]): boolean {\n    return legs?.every((leg) => leg?.serviceJourney?.serviceAlteration?.cancelled);\n  }\n\n  private _getRelativeDuration(legs: PtRideLeg[], leg: PtRideLeg): number {\n    const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n    const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n    if (arrivalNoTz && departureNoTz) {\n      const duration = differenceInMinutes(\n        removeTimezoneFromISOTimeString(leg.arrival.time)!,\n        removeTimezoneFromISOTimeString(leg.departure.time)!,\n      );\n      const allDurations = this._getAllDuration(legs);\n\n      if (allDurations === 0) {\n        return 100;\n      }\n\n      return (duration / allDurations) * 100;\n    }\n    return 0;\n  }\n\n  private _getProgress(now: Date, start?: Time, end?: Time): number {\n    if (!start?.time || !end?.time) {\n      return 0;\n    }\n\n    const startWithDelay = addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = addMinutes(end.time, end.delay ?? 0);\n    const total = differenceInMinutes(endWithDelay, startWithDelay);\n    const progress = differenceInMinutes(now, startWithDelay);\n\n    return total && (progress / total) * 100;\n  }\n\n  private _getStatus(now: Date, start?: Time, end?: Time): Status {\n    const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);\n\n    if (\n      startWithDelay &&\n      isBefore(startWithDelay, now) &&\n      endWithDelay &&\n      isAfter(endWithDelay, now)\n    ) {\n      return 'progress';\n    } else if (endWithDelay && isBefore(endWithDelay, now)) {\n      return 'past';\n    }\n    return 'future';\n  }\n\n  private _renderPosition(now: Date, start?: Time, end?: Time): TemplateResult | undefined {\n    const currentPosition = this._getProgress(now, start, end);\n    if (currentPosition < 0 && currentPosition > 100) return undefined;\n\n    const statusStyle = (): Record<string, string> => {\n      return {\n        '--sbb-pearl-chain-status-position': `${currentPosition}%`,\n        ...(currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}),\n      };\n    };\n\n    const animation = this.disableAnimation ? 'sbb-pearl-chain__position--no-animation' : '';\n\n    return html`<span\n      style=${styleMap(statusStyle())}\n      class=\"sbb-pearl-chain__position ${animation}\"\n    ></span>`;\n  }\n\n  protected override render(): TemplateResult {\n    const now = this.now ?? new Date();\n\n    const rideLegs: PtRideLeg[] = this.legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n\n    const departureTime =\n      rideLegs?.length && removeTimezoneFromISOTimeString(rideLegs[0]?.departure?.time);\n    const departureWithDelay = departureTime && {\n      time: departureTime,\n      delay: rideLegs[0].departure.delay ?? 0,\n    };\n\n    const arrivalTime =\n      rideLegs?.length &&\n      removeTimezoneFromISOTimeString(rideLegs[rideLegs.length - 1].arrival?.time);\n    const arrivalTimeDelay = arrivalTime && {\n      time: arrivalTime,\n      delay: rideLegs[rideLegs.length - 1]?.arrival.delay ?? 0,\n    };\n\n    const departureNotServiced = ((): string => {\n      return rideLegs &&\n        rideLegs[0]?.serviceJourney?.stopPoints &&\n        rideLegs[0]?.serviceJourney?.stopPoints[0].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--departure-skipped'\n        : '';\n    })();\n\n    const arrivalNotServiced = ((): string => {\n      const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];\n      const stops = lastLeg && lastLeg.serviceJourney?.stopPoints;\n\n      return stops && stops[stops.length - 1].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--arrival-skipped'\n        : '';\n    })();\n\n    const departureCancelClass = ((): string => {\n      return rideLegs && rideLegs[0]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--departure-disruption'\n        : '';\n    })();\n\n    const arrivalCancelClass = ((): string => {\n      return rideLegs && rideLegs[rideLegs.length - 1]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--arrival-disruption'\n        : '';\n    })();\n\n    const status =\n      departureWithDelay &&\n      arrivalTimeDelay &&\n      this._getStatus(now, departureWithDelay, arrivalTimeDelay);\n\n    const statusClassDeparture =\n      rideLegs && status && !departureCancelClass ? 'sbb-pearl-chain__bullet--' + status : '';\n\n    const statusClassArrival =\n      rideLegs && status && !arrivalCancelClass\n        ? 'sbb-pearl-chain__bullet--' + this._getStatus(now, undefined, arrivalTimeDelay)\n        : '';\n\n    if (this._isAllCancelled(rideLegs)) {\n      return html`\n        <div class=\"sbb-pearl-chain\">\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n          <div class=\"sbb-pearl-chain__leg sbb-pearl-chain__leg--disruption\"></div>\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n        </div>\n      `;\n    }\n\n    return html`\n      <div class=\"sbb-pearl-chain\">\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassDeparture} ${departureNotServiced} ${departureCancelClass}\"\n        ></span>\n        ${rideLegs?.map((leg: PtRideLeg, index: number) => {\n          const { stopPoints, serviceAlteration } = leg?.serviceJourney || {};\n\n          const duration = this._getRelativeDuration(rideLegs, leg);\n          const departure = removeTimezoneFromISOTimeString(leg.departure?.time);\n          const arrival = removeTimezoneFromISOTimeString(leg.arrival?.time);\n\n          const isArrivalNotServiced =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'NOT_SERVICED';\n          const isArrivalPlanned =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'PLANNED';\n          const isDepartureNotServiced = stopPoints && stopPoints[0]?.stopStatus === 'NOT_SERVICED';\n\n          const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;\n          const isBeforeLegArrivalNotServiced =\n            stopPointsBefore &&\n            stopPointsBefore[stopPointsBefore.length - 1]?.stopStatus === 'NOT_SERVICED';\n\n          const skippedLeg =\n            isArrivalNotServiced || (isDepartureNotServiced && isArrivalPlanned)\n              ? 'sbb-pearl-chain__leg--skipped'\n              : '';\n          const departureSkippedBullet =\n            isDepartureNotServiced || isBeforeLegArrivalNotServiced\n              ? 'sbb-pearl-chain__stop--departure-skipped'\n              : '';\n\n          const cancelled = serviceAlteration?.cancelled ? 'sbb-pearl-chain__leg--disruption' : '';\n\n          const legDepartureWithDelay = { time: departure, delay: leg.departure?.delay ?? 0 };\n          const legArrivalWithDelay = { time: arrival, delay: leg.arrival?.delay ?? 0 };\n          const status = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);\n\n          const legStatus = !cancelled && !skippedLeg && 'sbb-pearl-chain__leg--' + status;\n          const legStyle = (): Record<string, string> => {\n            return {\n              '--sbb-pearl-chain-leg-width': `${duration}%`,\n              ...(status === 'progress' && !cancelled && !skippedLeg\n                ? {\n                    '--sbb-pearl-chain-leg-status': `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`,\n                  }\n                : {}),\n            };\n          };\n\n          return html` <div\n            class=\"sbb-pearl-chain__leg ${legStatus || ''} ${cancelled} ${skippedLeg}\"\n            style=${styleMap(legStyle())}\n          >\n            ${index > 0 && index < rideLegs.length\n              ? html`<span class=\"sbb-pearl-chain__stop ${departureSkippedBullet}\"></span>`\n              : nothing}\n            ${status === 'progress' && !cancelled && !skippedLeg\n              ? this._renderPosition(now, legDepartureWithDelay, legArrivalWithDelay)\n              : nothing}\n          </div>`;\n        })}\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassArrival} ${arrivalNotServiced} ${arrivalCancelClass}\"\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain': SbbPearlChainElement;\n  }\n}\n"],"names":["_b","_a","_d","_c","_e","status"],"mappings":"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","x_google_ignoreList":[0,1]}
616
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"pearl-chain.js","sources":["../../../node_modules/date-fns/isAfter.mjs","../../../node_modules/date-fns/isBefore.mjs","../../../src/elements-experimental/pearl-chain/pearl-chain.ts"],"sourcesContent":["import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isAfter\n * @category Common Helpers\n * @summary Is the first date after the second one?\n *\n * @description\n * Is the first date after the second one?\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date that should be after the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is after the second date\n *\n * @example\n * // Is 10 July 1989 after 11 February 1987?\n * const result = isAfter(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> true\n */\nexport function isAfter(date, dateToCompare) {\n  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return _date.getTime() > _dateToCompare.getTime();\n}\n\n// Fallback for modularized imports:\nexport default isAfter;\n","import { toDate } from \"./toDate.mjs\";\n\n/**\n * @name isBefore\n * @category Common Helpers\n * @summary Is the first date before the second one?\n *\n * @description\n * Is the first date before the second one?\n *\n * @typeParam DateType - The `Date` type, the function operates on. Gets inferred from passed arguments. Allows to use extensions like [`UTCDate`](https://github.com/date-fns/utc).\n *\n * @param date - The date that should be before the other one to return true\n * @param dateToCompare - The date to compare with\n *\n * @returns The first date is before the second date\n *\n * @example\n * // Is 10 July 1989 before 11 February 1987?\n * const result = isBefore(new Date(1989, 6, 10), new Date(1987, 1, 11))\n * //=> false\n */\nexport function isBefore(date, dateToCompare) {\n  const _date = toDate(date);\n  const _dateToCompare = toDate(dateToCompare);\n  return +_date < +_dateToCompare;\n}\n\n// Fallback for modularized imports:\nexport default isBefore;\n","import { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport type { SbbDateLike } from '@sbb-esta/lyne-elements/core/interfaces/types';\nimport { addMinutes, differenceInMinutes, isAfter, isBefore } from 'date-fns';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { removeTimezoneFromISOTimeString } from '../core/datetime.js';\nimport type { Leg, PtRideLeg } from '../core/timetable.js';\nimport { isRideLeg } from '../core/timetable.js';\n\nimport style from './pearl-chain.scss?lit&inline';\n\ntype Status = 'progress' | 'future' | 'past';\ntype Time = {\n  time?: Date;\n  delay: number;\n};\n\n/**\n * It visually displays journey information.\n */\n@customElement('sbb-pearl-chain')\nexport class SbbPearlChainElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Define the legs of the pearl-chain.\n   * Format:\n   * `{\"legs\": [{\"duration\": 25}, ...]}`\n   * `duration` in minutes. Duration of the leg is relative\n   * to the total travel time. Example: departure 16:30, change at 16:40,\n   * arrival at 17:00. So the change should have a duration of 33.33%.\n   */\n  @property({ type: Array }) public legs?: (Leg | PtRideLeg)[];\n\n  /**\n   * Per default, the current location has a pulsating animation. You can\n   * disable the animation with this property.\n   */\n  @property({ attribute: 'disable-animation', type: Boolean }) public disableAnimation?: boolean;\n\n  /** A configured date which acts as the current date instead of the real current date. Recommended for testing purposes. */\n  @property()\n  public set now(value: SbbDateLike | undefined) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date | null {\n    return this._now;\n  }\n  private _now: Date | null = null;\n\n  private _getAllDuration(legs: PtRideLeg[]): number {\n    return legs?.reduce((sum: number, leg) => {\n      const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n      const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n      if (arrivalNoTz && departureNoTz) {\n        return (\n          sum +\n          differenceInMinutes(\n            removeTimezoneFromISOTimeString(leg.arrival.time)!,\n            removeTimezoneFromISOTimeString(leg.departure.time)!,\n          )\n        );\n      }\n      return sum;\n    }, 0);\n  }\n\n  private _isAllCancelled(legs: PtRideLeg[]): boolean {\n    return legs?.every((leg) => leg?.serviceJourney?.serviceAlteration?.cancelled);\n  }\n\n  private _getRelativeDuration(legs: PtRideLeg[], leg: PtRideLeg): number {\n    const arrivalNoTz = removeTimezoneFromISOTimeString(leg.arrival?.time);\n    const departureNoTz = removeTimezoneFromISOTimeString(leg.departure?.time);\n    if (arrivalNoTz && departureNoTz) {\n      const duration = differenceInMinutes(\n        removeTimezoneFromISOTimeString(leg.arrival.time)!,\n        removeTimezoneFromISOTimeString(leg.departure.time)!,\n      );\n      const allDurations = this._getAllDuration(legs);\n\n      if (allDurations === 0) {\n        return 100;\n      }\n\n      return (duration / allDurations) * 100;\n    }\n    return 0;\n  }\n\n  private _getProgress(now: Date, start?: Time, end?: Time): number {\n    if (!start?.time || !end?.time) {\n      return 0;\n    }\n\n    const startWithDelay = addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = addMinutes(end.time, end.delay ?? 0);\n    const total = differenceInMinutes(endWithDelay, startWithDelay);\n    const progress = differenceInMinutes(now, startWithDelay);\n\n    return total && (progress / total) * 100;\n  }\n\n  private _getStatus(now: Date, start?: Time, end?: Time): Status {\n    const startWithDelay = start && start.time && addMinutes(start.time, start.delay ?? 0);\n    const endWithDelay = end && end.time && addMinutes(end.time, end.delay ?? 0);\n\n    if (\n      startWithDelay &&\n      isBefore(startWithDelay, now) &&\n      endWithDelay &&\n      isAfter(endWithDelay, now)\n    ) {\n      return 'progress';\n    } else if (endWithDelay && isBefore(endWithDelay, now)) {\n      return 'past';\n    }\n    return 'future';\n  }\n\n  private _renderPosition(now: Date, start?: Time, end?: Time): TemplateResult | undefined {\n    const currentPosition = this._getProgress(now, start, end);\n    if (currentPosition < 0 && currentPosition > 100) return undefined;\n\n    const statusStyle = (): Record<string, string> => {\n      return {\n        '--sbb-pearl-chain-status-position': `${currentPosition}%`,\n        ...(currentPosition >= 50 ? { transform: `translateX(-100%)` } : {}),\n      };\n    };\n\n    const animation = this.disableAnimation ? 'sbb-pearl-chain__position--no-animation' : '';\n\n    return html`<span\n      style=${styleMap(statusStyle())}\n      class=\"sbb-pearl-chain__position ${animation}\"\n    ></span>`;\n  }\n\n  protected override render(): TemplateResult {\n    const now = this.now ?? new Date();\n\n    const rideLegs: PtRideLeg[] = this.legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n\n    const departureTime =\n      rideLegs?.length && removeTimezoneFromISOTimeString(rideLegs[0]?.departure?.time);\n    const departureWithDelay = departureTime && {\n      time: departureTime,\n      delay: rideLegs[0].departure.delay ?? 0,\n    };\n\n    const arrivalTime =\n      rideLegs?.length &&\n      removeTimezoneFromISOTimeString(rideLegs[rideLegs.length - 1].arrival?.time);\n    const arrivalTimeDelay = arrivalTime && {\n      time: arrivalTime,\n      delay: rideLegs[rideLegs.length - 1]?.arrival.delay ?? 0,\n    };\n\n    const departureNotServiced = ((): string => {\n      return rideLegs &&\n        rideLegs[0]?.serviceJourney?.stopPoints &&\n        rideLegs[0]?.serviceJourney?.stopPoints[0].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--departure-skipped'\n        : '';\n    })();\n\n    const arrivalNotServiced = ((): string => {\n      const lastLeg = rideLegs && rideLegs[rideLegs.length - 1];\n      const stops = lastLeg && lastLeg.serviceJourney?.stopPoints;\n\n      return stops && stops[stops.length - 1].stopStatus === 'NOT_SERVICED'\n        ? 'sbb-pearl-chain--arrival-skipped'\n        : '';\n    })();\n\n    const departureCancelClass = ((): string => {\n      return rideLegs && rideLegs[0]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--departure-disruption'\n        : '';\n    })();\n\n    const arrivalCancelClass = ((): string => {\n      return rideLegs && rideLegs[rideLegs.length - 1]?.serviceJourney?.serviceAlteration?.cancelled\n        ? 'sbb-pearl-chain--arrival-disruption'\n        : '';\n    })();\n\n    const status =\n      departureWithDelay &&\n      arrivalTimeDelay &&\n      this._getStatus(now, departureWithDelay, arrivalTimeDelay);\n\n    const statusClassDeparture =\n      rideLegs && status && !departureCancelClass ? 'sbb-pearl-chain__bullet--' + status : '';\n\n    const statusClassArrival =\n      rideLegs && status && !arrivalCancelClass\n        ? 'sbb-pearl-chain__bullet--' + this._getStatus(now, undefined, arrivalTimeDelay)\n        : '';\n\n    if (this._isAllCancelled(rideLegs)) {\n      return html`\n        <div class=\"sbb-pearl-chain\">\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n          <div class=\"sbb-pearl-chain__leg sbb-pearl-chain__leg--disruption\"></div>\n          <span class=\"sbb-pearl-chain__bullet sbb-pearl-chain--departure-disruption\"></span>\n        </div>\n      `;\n    }\n\n    return html`\n      <div class=\"sbb-pearl-chain\">\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassDeparture} ${departureNotServiced} ${departureCancelClass}\"\n        ></span>\n        ${rideLegs?.map((leg: PtRideLeg, index: number) => {\n          const { stopPoints, serviceAlteration } = leg?.serviceJourney || {};\n\n          const duration = this._getRelativeDuration(rideLegs, leg);\n          const departure = removeTimezoneFromISOTimeString(leg.departure?.time);\n          const arrival = removeTimezoneFromISOTimeString(leg.arrival?.time);\n\n          const isArrivalNotServiced =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'NOT_SERVICED';\n          const isArrivalPlanned =\n            stopPoints && stopPoints[stopPoints.length - 1]?.stopStatus === 'PLANNED';\n          const isDepartureNotServiced = stopPoints && stopPoints[0]?.stopStatus === 'NOT_SERVICED';\n\n          const stopPointsBefore = index > 0 && rideLegs[index - 1].serviceJourney.stopPoints;\n          const isBeforeLegArrivalNotServiced =\n            stopPointsBefore &&\n            stopPointsBefore[stopPointsBefore.length - 1]?.stopStatus === 'NOT_SERVICED';\n\n          const skippedLeg =\n            isArrivalNotServiced || (isDepartureNotServiced && isArrivalPlanned)\n              ? 'sbb-pearl-chain__leg--skipped'\n              : '';\n          const departureSkippedBullet =\n            isDepartureNotServiced || isBeforeLegArrivalNotServiced\n              ? 'sbb-pearl-chain__stop--departure-skipped'\n              : '';\n\n          const cancelled = serviceAlteration?.cancelled ? 'sbb-pearl-chain__leg--disruption' : '';\n\n          const legDepartureWithDelay = { time: departure, delay: leg.departure?.delay ?? 0 };\n          const legArrivalWithDelay = { time: arrival, delay: leg.arrival?.delay ?? 0 };\n          const status = this._getStatus(now, legDepartureWithDelay, legArrivalWithDelay);\n\n          const legStatus = !cancelled && !skippedLeg && 'sbb-pearl-chain__leg--' + status;\n          const legStyle = (): Record<string, string> => {\n            return {\n              '--sbb-pearl-chain-leg-width': `${duration}%`,\n              ...(status === 'progress' && !cancelled && !skippedLeg\n                ? {\n                    '--sbb-pearl-chain-leg-status': `${this._getProgress(now, legDepartureWithDelay, legArrivalWithDelay)}%`,\n                  }\n                : {}),\n            };\n          };\n\n          return html` <div\n            class=\"sbb-pearl-chain__leg ${legStatus || ''} ${cancelled} ${skippedLeg}\"\n            style=${styleMap(legStyle())}\n          >\n            ${index > 0 && index < rideLegs.length\n              ? html`<span class=\"sbb-pearl-chain__stop ${departureSkippedBullet}\"></span>`\n              : nothing}\n            ${status === 'progress' && !cancelled && !skippedLeg\n              ? this._renderPosition(now, legDepartureWithDelay, legArrivalWithDelay)\n              : nothing}\n          </div>`;\n        })}\n        <span\n          class=\"sbb-pearl-chain__bullet ${statusClassArrival} ${arrivalNotServiced} ${arrivalCancelClass}\"\n        ></span>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-pearl-chain': SbbPearlChainElement;\n  }\n}\n"],"names":["_b","_a","_d","_c","_e","status"],"mappings":"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","x_google_ignoreList":[0,1]}
@@ -2,20 +2,7 @@ import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.
2
2
  import { i18nDurationHour, i18nDurationMinute } from "@sbb-esta/lyne-elements/core/i18n.js";
3
3
  import { css, LitElement, html } from "lit";
4
4
  import { property, customElement } from "lit/decorators.js";
5
- const style = css`/**
6
- * Better font rendering (on OS X)
7
- * http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
8
- *
9
- * Usage:
10
- *
11
- * .var_dark_on_light {
12
- * @include font-smoothing;
13
- * }
14
- * .var_light_on_dark {
15
- * @include font-smoothing-reset;
16
- * }
17
- */
18
- /** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
5
+ const style = css`/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
19
6
  /*
20
7
  * SBB table mixin
21
8
  * Notes:
@@ -109,4 +96,4 @@ SbbTimetableDurationElement = __decorateClass([
109
96
  export {
110
97
  SbbTimetableDurationElement
111
98
  };
112
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXRhYmxlLWR1cmF0aW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL3RpbWV0YWJsZS1kdXJhdGlvbi90aW1ldGFibGUtZHVyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2JiTGFuZ3VhZ2VDb250cm9sbGVyIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBpMThuRHVyYXRpb25Ib3VyLCBpMThuRHVyYXRpb25NaW51dGUgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2kxOG4uanMnO1xuaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vdGltZXRhYmxlLWR1cmF0aW9uLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogVXNlZCBpbiBgc2JiLXRpbWV0YWJsZS1yb3dgLCBpdCBkaXNwbGF5cyBpbmZvcm1hdGlvbiBhYm91dCB0aGUgdHJpcCBkdXJhdGlvbi5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi10aW1ldGFibGUtZHVyYXRpb24nKVxuZXhwb3J0IGNsYXNzIFNiYlRpbWV0YWJsZUR1cmF0aW9uRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKipcbiAgICogU3RyaW5naWZpZWQgSlNPTiB3aGljaCBkZWZpbmVzIG1vc3Qgb2YgdGhlXG4gICAqIGNvbnRlbnQgb2YgdGhlIGNvbXBvbmVudC4gUGxlYXNlIGNoZWNrIHRoZVxuICAgKiBpbmRpdmlkdWFsIHN0b3JpZXMgdG8gZ2V0IGFuIGlkZWEgb2YgdGhlXG4gICAqIHN0cnVjdHVyZS5cbiAgICovXG4gIEBwcm9wZXJ0eSgpIHB1YmxpYyBjb25maWchOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSBfbGFuZ3VhZ2UgPSBuZXcgU2JiTGFuZ3VhZ2VDb250cm9sbGVyKHRoaXMpO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIGNvbnN0IGNvbmZpZyA9IEpTT04ucGFyc2UodGhpcy5jb25maWcpO1xuXG4gICAgY29uc3QgaG91cnNMYWJlbFNob3J0ID0gaTE4bkR1cmF0aW9uSG91ci5tdWx0aXBsZS5zaG9ydFt0aGlzLl9sYW5ndWFnZS5jdXJyZW50XTtcbiAgICBjb25zdCBtaW51dGVzTGFiZWxTaG9ydCA9IGkxOG5EdXJhdGlvbk1pbnV0ZS5tdWx0aXBsZS5zaG9ydFt0aGlzLl9sYW5ndWFnZS5jdXJyZW50XTtcblxuICAgIGxldCB2aXN1YWxUZXh0ID0gJyc7XG4gICAgbGV0IGExMXlMYWJlbCA9ICcnO1xuXG4gICAgbGV0IGhvdXJzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uSG91ci5tdWx0aXBsZS5sb25nW3RoaXMuX2xhbmd1YWdlLmN1cnJlbnRdO1xuICAgIGxldCBtaW51dGVzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uTWludXRlLm11bHRpcGxlLmxvbmdbdGhpcy5fbGFuZ3VhZ2UuY3VycmVudF07XG5cbiAgICBpZiAoY29uZmlnLmhvdXJzID09PSAxKSB7XG4gICAgICBob3Vyc0xhYmVsTG9uZyA9IGkxOG5EdXJhdGlvbkhvdXIuc2luZ2xlLmxvbmdbdGhpcy5fbGFuZ3VhZ2UuY3VycmVudF07XG4gICAgfVxuXG4gICAgaWYgKGNvbmZpZy5taW51dGVzID09PSAxKSB7XG4gICAgICBtaW51dGVzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uTWludXRlLnNpbmdsZS5sb25nW3RoaXMuX2xhbmd1YWdlLmN1cnJlbnRdO1xuICAgIH1cblxuICAgIGlmIChjb25maWcuaG91cnMgIT09IDApIHtcbiAgICAgIHZpc3VhbFRleHQgKz0gYCR7Y29uZmlnLmhvdXJzfSAke2hvdXJzTGFiZWxTaG9ydH1gO1xuICAgICAgYTExeUxhYmVsICs9IGAke2NvbmZpZy5ob3Vyc30gJHtob3Vyc0xhYmVsTG9uZ31gO1xuICAgIH1cblxuICAgIHZpc3VhbFRleHQgKz0gYCAke2NvbmZpZy5taW51dGVzfSAke21pbnV0ZXNMYWJlbFNob3J0fWA7XG4gICAgYTExeUxhYmVsICs9IGAgJHtjb25maWcubWludXRlc30gJHttaW51dGVzTGFiZWxMb25nfS5gO1xuXG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8cCBhcmlhLWxhYmVsPSR7YTExeUxhYmVsfSBjbGFzcz1cImR1cmF0aW9uXCIgcm9sZT1cInRleHRcIj5cbiAgICAgICAgPHNwYW4gYXJpYS1oaWRkZW49XCJ0cnVlXCIgY2xhc3M9XCJkdXJhdGlvbl9fdGV4dC0tdmlzdWFsXCIgcm9sZT1cInByZXNlbnRhdGlvblwiPlxuICAgICAgICAgICR7dmlzdWFsVGV4dH1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImR1cmF0aW9uX190ZXh0LS12aXN1YWxseS1oaWRkZW5cIj4ke2ExMXlMYWJlbH08L3NwYW4+XG4gICAgICA8L3A+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXRpbWV0YWJsZS1kdXJhdGlvbic6IFNiYlRpbWV0YWJsZUR1cmF0aW9uRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVlhLElBQUEsOEJBQU4sY0FBMEMsV0FBVztBQUFBLEVBQXJELGNBQUE7QUFBQSxVQUFBLEdBQUEsU0FBQTtBQVdHLFNBQUEsWUFBWSxJQUFJLHNCQUFzQixJQUFJO0FBQUEsRUFBQTtBQUFBLEVBRS9CLFNBQXlCO0FBQzFDLFVBQU0sU0FBUyxLQUFLLE1BQU0sS0FBSyxNQUFNO0FBRXJDLFVBQU0sa0JBQWtCLGlCQUFpQixTQUFTLE1BQU0sS0FBSyxVQUFVLE9BQU87QUFDOUUsVUFBTSxvQkFBb0IsbUJBQW1CLFNBQVMsTUFBTSxLQUFLLFVBQVUsT0FBTztBQUVsRixRQUFJLGFBQWE7QUFDakIsUUFBSSxZQUFZO0FBRWhCLFFBQUksaUJBQWlCLGlCQUFpQixTQUFTLEtBQUssS0FBSyxVQUFVLE9BQU87QUFDMUUsUUFBSSxtQkFBbUIsbUJBQW1CLFNBQVMsS0FBSyxLQUFLLFVBQVUsT0FBTztBQUUxRSxRQUFBLE9BQU8sVUFBVSxHQUFHO0FBQ3RCLHVCQUFpQixpQkFBaUIsT0FBTyxLQUFLLEtBQUssVUFBVSxPQUFPO0FBQUEsSUFDdEU7QUFFSSxRQUFBLE9BQU8sWUFBWSxHQUFHO0FBQ3hCLHlCQUFtQixtQkFBbUIsT0FBTyxLQUFLLEtBQUssVUFBVSxPQUFPO0FBQUEsSUFDMUU7QUFFSSxRQUFBLE9BQU8sVUFBVSxHQUFHO0FBQ3RCLG9CQUFjLEdBQUcsT0FBTyxLQUFLLElBQUksZUFBZTtBQUNoRCxtQkFBYSxHQUFHLE9BQU8sS0FBSyxJQUFJLGNBQWM7QUFBQSxJQUNoRDtBQUVBLGtCQUFjLElBQUksT0FBTyxPQUFPLElBQUksaUJBQWlCO0FBQ3JELGlCQUFhLElBQUksT0FBTyxPQUFPLElBQUksZ0JBQWdCO0FBRTVDLFdBQUE7QUFBQSxzQkFDVyxTQUFTO0FBQUE7QUFBQSxZQUVuQixVQUFVO0FBQUE7QUFBQSx3REFFa0MsU0FBUztBQUFBO0FBQUE7QUFBQSxFQUcvRDtBQUNGO0FBbERhLDRCQUNZLFNBQXlCO0FBUTdCLGdCQUFBO0FBQUEsRUFBbEIsU0FBUztBQUFBLEdBVEMsNEJBU1EsV0FBQSxVQUFBLENBQUE7QUFUUiw4QkFBTixnQkFBQTtBQUFBLEVBRE4sY0FBYyx3QkFBd0I7QUFBQSxHQUMxQiwyQkFBQTsifQ==
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXRhYmxlLWR1cmF0aW9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL3RpbWV0YWJsZS1kdXJhdGlvbi90aW1ldGFibGUtZHVyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2JiTGFuZ3VhZ2VDb250cm9sbGVyIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBpMThuRHVyYXRpb25Ib3VyLCBpMThuRHVyYXRpb25NaW51dGUgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2kxOG4uanMnO1xuaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vdGltZXRhYmxlLWR1cmF0aW9uLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogVXNlZCBpbiBgc2JiLXRpbWV0YWJsZS1yb3dgLCBpdCBkaXNwbGF5cyBpbmZvcm1hdGlvbiBhYm91dCB0aGUgdHJpcCBkdXJhdGlvbi5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi10aW1ldGFibGUtZHVyYXRpb24nKVxuZXhwb3J0IGNsYXNzIFNiYlRpbWV0YWJsZUR1cmF0aW9uRWxlbWVudCBleHRlbmRzIExpdEVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKipcbiAgICogU3RyaW5naWZpZWQgSlNPTiB3aGljaCBkZWZpbmVzIG1vc3Qgb2YgdGhlXG4gICAqIGNvbnRlbnQgb2YgdGhlIGNvbXBvbmVudC4gUGxlYXNlIGNoZWNrIHRoZVxuICAgKiBpbmRpdmlkdWFsIHN0b3JpZXMgdG8gZ2V0IGFuIGlkZWEgb2YgdGhlXG4gICAqIHN0cnVjdHVyZS5cbiAgICovXG4gIEBwcm9wZXJ0eSgpIHB1YmxpYyBjb25maWchOiBzdHJpbmc7XG5cbiAgcHJpdmF0ZSBfbGFuZ3VhZ2UgPSBuZXcgU2JiTGFuZ3VhZ2VDb250cm9sbGVyKHRoaXMpO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIGNvbnN0IGNvbmZpZyA9IEpTT04ucGFyc2UodGhpcy5jb25maWcpO1xuXG4gICAgY29uc3QgaG91cnNMYWJlbFNob3J0ID0gaTE4bkR1cmF0aW9uSG91ci5tdWx0aXBsZS5zaG9ydFt0aGlzLl9sYW5ndWFnZS5jdXJyZW50XTtcbiAgICBjb25zdCBtaW51dGVzTGFiZWxTaG9ydCA9IGkxOG5EdXJhdGlvbk1pbnV0ZS5tdWx0aXBsZS5zaG9ydFt0aGlzLl9sYW5ndWFnZS5jdXJyZW50XTtcblxuICAgIGxldCB2aXN1YWxUZXh0ID0gJyc7XG4gICAgbGV0IGExMXlMYWJlbCA9ICcnO1xuXG4gICAgbGV0IGhvdXJzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uSG91ci5tdWx0aXBsZS5sb25nW3RoaXMuX2xhbmd1YWdlLmN1cnJlbnRdO1xuICAgIGxldCBtaW51dGVzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uTWludXRlLm11bHRpcGxlLmxvbmdbdGhpcy5fbGFuZ3VhZ2UuY3VycmVudF07XG5cbiAgICBpZiAoY29uZmlnLmhvdXJzID09PSAxKSB7XG4gICAgICBob3Vyc0xhYmVsTG9uZyA9IGkxOG5EdXJhdGlvbkhvdXIuc2luZ2xlLmxvbmdbdGhpcy5fbGFuZ3VhZ2UuY3VycmVudF07XG4gICAgfVxuXG4gICAgaWYgKGNvbmZpZy5taW51dGVzID09PSAxKSB7XG4gICAgICBtaW51dGVzTGFiZWxMb25nID0gaTE4bkR1cmF0aW9uTWludXRlLnNpbmdsZS5sb25nW3RoaXMuX2xhbmd1YWdlLmN1cnJlbnRdO1xuICAgIH1cblxuICAgIGlmIChjb25maWcuaG91cnMgIT09IDApIHtcbiAgICAgIHZpc3VhbFRleHQgKz0gYCR7Y29uZmlnLmhvdXJzfSAke2hvdXJzTGFiZWxTaG9ydH1gO1xuICAgICAgYTExeUxhYmVsICs9IGAke2NvbmZpZy5ob3Vyc30gJHtob3Vyc0xhYmVsTG9uZ31gO1xuICAgIH1cblxuICAgIHZpc3VhbFRleHQgKz0gYCAke2NvbmZpZy5taW51dGVzfSAke21pbnV0ZXNMYWJlbFNob3J0fWA7XG4gICAgYTExeUxhYmVsICs9IGAgJHtjb25maWcubWludXRlc30gJHttaW51dGVzTGFiZWxMb25nfS5gO1xuXG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8cCBhcmlhLWxhYmVsPSR7YTExeUxhYmVsfSBjbGFzcz1cImR1cmF0aW9uXCIgcm9sZT1cInRleHRcIj5cbiAgICAgICAgPHNwYW4gYXJpYS1oaWRkZW49XCJ0cnVlXCIgY2xhc3M9XCJkdXJhdGlvbl9fdGV4dC0tdmlzdWFsXCIgcm9sZT1cInByZXNlbnRhdGlvblwiPlxuICAgICAgICAgICR7dmlzdWFsVGV4dH1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImR1cmF0aW9uX190ZXh0LS12aXN1YWxseS1oaWRkZW5cIj4ke2ExMXlMYWJlbH08L3NwYW4+XG4gICAgICA8L3A+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXRpbWV0YWJsZS1kdXJhdGlvbic6IFNiYlRpbWV0YWJsZUR1cmF0aW9uRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBWWEsSUFBQSw4QkFBTixjQUEwQyxXQUFXO0FBQUEsRUFBckQsY0FBQTtBQUFBLFVBQUEsR0FBQSxTQUFBO0FBV0csU0FBQSxZQUFZLElBQUksc0JBQXNCLElBQUk7QUFBQSxFQUFBO0FBQUEsRUFFL0IsU0FBeUI7QUFDMUMsVUFBTSxTQUFTLEtBQUssTUFBTSxLQUFLLE1BQU07QUFFckMsVUFBTSxrQkFBa0IsaUJBQWlCLFNBQVMsTUFBTSxLQUFLLFVBQVUsT0FBTztBQUM5RSxVQUFNLG9CQUFvQixtQkFBbUIsU0FBUyxNQUFNLEtBQUssVUFBVSxPQUFPO0FBRWxGLFFBQUksYUFBYTtBQUNqQixRQUFJLFlBQVk7QUFFaEIsUUFBSSxpQkFBaUIsaUJBQWlCLFNBQVMsS0FBSyxLQUFLLFVBQVUsT0FBTztBQUMxRSxRQUFJLG1CQUFtQixtQkFBbUIsU0FBUyxLQUFLLEtBQUssVUFBVSxPQUFPO0FBRTFFLFFBQUEsT0FBTyxVQUFVLEdBQUc7QUFDdEIsdUJBQWlCLGlCQUFpQixPQUFPLEtBQUssS0FBSyxVQUFVLE9BQU87QUFBQSxJQUN0RTtBQUVJLFFBQUEsT0FBTyxZQUFZLEdBQUc7QUFDeEIseUJBQW1CLG1CQUFtQixPQUFPLEtBQUssS0FBSyxVQUFVLE9BQU87QUFBQSxJQUMxRTtBQUVJLFFBQUEsT0FBTyxVQUFVLEdBQUc7QUFDdEIsb0JBQWMsR0FBRyxPQUFPLEtBQUssSUFBSSxlQUFlO0FBQ2hELG1CQUFhLEdBQUcsT0FBTyxLQUFLLElBQUksY0FBYztBQUFBLElBQ2hEO0FBRUEsa0JBQWMsSUFBSSxPQUFPLE9BQU8sSUFBSSxpQkFBaUI7QUFDckQsaUJBQWEsSUFBSSxPQUFPLE9BQU8sSUFBSSxnQkFBZ0I7QUFFNUMsV0FBQTtBQUFBLHNCQUNXLFNBQVM7QUFBQTtBQUFBLFlBRW5CLFVBQVU7QUFBQTtBQUFBLHdEQUVrQyxTQUFTO0FBQUE7QUFBQTtBQUFBLEVBRy9EO0FBQ0Y7QUFsRGEsNEJBQ1ksU0FBeUI7QUFRN0IsZ0JBQUE7QUFBQSxFQUFsQixTQUFTO0FBQUEsR0FUQyw0QkFTUSxXQUFBLFVBQUEsQ0FBQTtBQVRSLDhCQUFOLGdCQUFBO0FBQUEsRUFETixjQUFjLHdCQUF3QjtBQUFBLEdBQzFCLDJCQUFBOyJ9
@@ -41,6 +41,13 @@ export declare class SbbTimetableRowElement extends LitElement {
41
41
  * when this is true it will be render skeleton with an idling animation
42
42
  */
43
43
  loadingTrip: boolean;
44
+ /**
45
+ * The Footpath attribute for rendering different icons
46
+ * true: render a11y-icon
47
+ * false: render walk-icon
48
+ * default: render walk-icon
49
+ */
50
+ a11yFootpath?: boolean;
44
51
  /**
45
52
  * The loading state -
46
53
  * when this is true it will be render skeleton with an idling animation
@@ -1 +1 @@
1
- {"version":3,"file":"timetable-row.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.ts"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAE,WAAW,EAAgB,MAAM,4CAA4C,CAAC;AAE5F,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAIhD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAa,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAKtF,OAAO,iCAAiC,CAAC;AACzC,OAAO,iCAAiC,CAAC;AACzC,OAAO,gDAAgD,CAAC;AACxD,OAAO,wBAAwB,CAAC;AAEhC,qDAAqD;AACrD,MAAM,WAAW,MAAM;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACtB;AAED,4DAA4D;AAC5D,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,KAAK;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,eAAO,MAAM,iBAAiB,SAAU,MAAM,QAAQ,MAAM,KAAG,cAK9D,CAAC;AAEF,eAAO,MAAM,mBAAmB,gBAAiB,MAAM,SAAS,MAAM,GAAG,IAAI,KAAG,cAK/E,CAAC;AAsBF,eAAO,MAAM,aAAa,eAAgB,WAAW,EAAE,KAAG,WAAW,EAapE,CAAC;AAEF,eAAO,MAAM,UAAU,cAAe,WAAW,KAAG,MAiCnD,CAAC;AAEF,eAAO,MAAM,MAAM,SAAU,SAAS,mBAAmB,MAAM,KAAG,MAuBjE,CAAC;AAaF,eAAO,MAAM,aAAa,YAAa,MAAM,EAAE,KAAG,MAAM,EAUvD,CAAC;AAEF,eAAO,MAAM,aAAa,YAAa,MAAM,EAAE,KAAG,MAAM,EAcvD,CAAC;AAEF;;KAEK;AACL,qBACa,sBAAuB,SAAQ,UAAU;IACpD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,qBAAqB;IACc,IAAI,EAAG,SAAS,CAAC;IAEpD,gEAAgE;IAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;IAEjD,wGAAwG;IAEjG,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAElC,oDAAoD;IACjB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IAEvD;;;OAGG;IAC4D,WAAW,UAAS;IAEnF;;;OAGG;IAC6D,YAAY,UAAS;IAErF;;OAEG;IACkD,eAAe,CAAC,EAAE,MAAM,CAAC;IAE9E,yEAAyE;IAElE,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAEvC,uEAAuE;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;IAErD,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,CAErB;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,yDAAyD;IACzD,OAAO,CAAC,eAAe;IAevB,OAAO,CAAC,mBAAmB;IAc3B,eAAe;IACf,OAAO,CAAC,eAAe;IAavB,OAAO,CAAC,aAAa;IAWrB,OAAO,CAAC,qBAAqB;cAwIV,MAAM,IAAI,cAAc;CAuJ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
1
+ {"version":3,"file":"timetable-row.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.ts"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAE,WAAW,EAAgB,MAAM,4CAA4C,CAAC;AAE5F,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAIhD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAa,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAKtF,OAAO,iCAAiC,CAAC;AACzC,OAAO,iCAAiC,CAAC;AACzC,OAAO,gDAAgD,CAAC;AACxD,OAAO,wBAAwB,CAAC;AAEhC,qDAAqD;AACrD,MAAM,WAAW,MAAM;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACtB;AAED,4DAA4D;AAC5D,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,KAAK;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,eAAO,MAAM,iBAAiB,SAAU,MAAM,QAAQ,MAAM,KAAG,cAK9D,CAAC;AAEF,eAAO,MAAM,mBAAmB,gBAAiB,MAAM,SAAS,MAAM,GAAG,IAAI,KAAG,cAK/E,CAAC;AAsBF,eAAO,MAAM,aAAa,eAAgB,WAAW,EAAE,KAAG,WAAW,EAapE,CAAC;AAEF,eAAO,MAAM,UAAU,cAAe,WAAW,KAAG,MAiCnD,CAAC;AAEF,eAAO,MAAM,MAAM,SAAU,SAAS,mBAAmB,MAAM,KAAG,MAuBjE,CAAC;AAaF,eAAO,MAAM,aAAa,YAAa,MAAM,EAAE,KAAG,MAAM,EAUvD,CAAC;AAEF,eAAO,MAAM,aAAa,YAAa,MAAM,EAAE,KAAG,MAAM,EAcvD,CAAC;AAEF;;KAEK;AACL,qBACa,sBAAuB,SAAQ,UAAU;IACpD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,qBAAqB;IACc,IAAI,EAAG,SAAS,CAAC;IAEpD,gEAAgE;IAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;IAEjD,wGAAwG;IAEjG,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAElC,oDAAoD;IACjB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IAEvD;;;OAGG;IAC4D,WAAW,UAAS;IAEnF;;;;;OAKG;IAC6D,YAAY,CAAC,EAAE,OAAO,CAAC;IAEvF;;;OAGG;IAC6D,YAAY,UAAS;IAErF;;OAEG;IACkD,eAAe,CAAC,EAAE,MAAM,CAAC;IAE9E,yEAAyE;IAElE,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAEvC,uEAAuE;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;IAErD,2HAA2H;IAC3H,IACW,GAAG,CAAC,KAAK,EAAE,WAAW,GAAG,SAAS,EAE5C;IACD,IAAW,GAAG,IAAI,IAAI,CAErB;IACD,OAAO,CAAC,IAAI,CAAqB;IAEjC,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,yDAAyD;IACzD,OAAO,CAAC,eAAe;IAevB,OAAO,CAAC,mBAAmB;IAc3B,eAAe;IACf,OAAO,CAAC,eAAe;IAavB,OAAO,CAAC,aAAa;IAWrB,OAAO,CAAC,qBAAqB;cAyIV,MAAM,IAAI,cAAc;CAwJ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
@@ -3,6 +3,7 @@ export type DeepPartial<T> = T extends object ? {
3
3
  [P in keyof T]?: DeepPartial<T[P]>;
4
4
  } : T;
5
5
  export declare const defaultTrip: DeepPartial<ITripItem>;
6
+ export declare const connectionTrip: DeepPartial<ITripItem>;
6
7
  export declare const cancelledTrip: DeepPartial<ITripItem>;
7
8
  export declare const progressTrip: DeepPartial<ITripItem>;
8
9
  export declare const partiallyCancelled: DeepPartial<ITripItem>;
@@ -17,6 +18,7 @@ export declare const trainTrip: DeepPartial<ITripItem>;
17
18
  export declare const busTrip: DeepPartial<ITripItem>;
18
19
  export declare const shipTrip: DeepPartial<ITripItem>;
19
20
  export declare const walkTimeTrip: DeepPartial<ITripItem>;
21
+ export declare const a11yFootpathTrip: DeepPartial<ITripItem>;
20
22
  export declare const extendedEnterTimeTrip: DeepPartial<ITripItem>;
21
23
  export declare const noticesTrip: DeepPartial<ITripItem>;
22
24
  //# sourceMappingURL=timetable-row.sample-data.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAgBtD,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GACzC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}
1
+ {"version":3,"file":"timetable-row.sample-data.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/timetable-row/timetable-row.sample-data.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAiBtD,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GACzC;KACG,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;CACnC,GACD,CAAC,CAAC;AAEN,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAoB9C,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CAGjD,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,SAAS,CA2BhD,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CAoB/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAAC,SAAS,CAuBrD,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAwB3C,CAAC;AAEF,eAAO,MAAM,0BAA0B,EAAE,WAAW,CAAC,SAAS,CAkB7D,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,WAAW,CAAC,SAAS,CAkBzD,CAAC;AAEF,eAAO,MAAM,wBAAwB,EAAE,WAAW,CAAC,SAAS,CAkB3D,CAAC;AAEF,eAAO,MAAM,6BAA6B,EAAE,WAAW,CAAC,SAAS,CAkBhE,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,WAAW,CAAC,SAAS,CA+DlD,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,WAAW,CAAC,SAAS,CA8CjD,CAAC;AAEF,eAAO,MAAM,SAAS,EAAE,WAAW,CAAC,SAAS,CA8B5C,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,SAAS,CA8B1C,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,WAAW,CAAC,SAAS,CAuB3C,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,CAAC,SAAS,CA0J/C,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,WAAW,CAAC,SAAS,CAAuB,CAAC;AAE5E,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,SAAS,CA4BxD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,CAAC,SAAS,CAsF9C,CAAC"}