@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,12 +10,13 @@ interface IAccessAttribute {
10
10
  * @param departureWalk: The walking distance in minutes from the departure point to the first leg.
11
11
  * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.
12
12
  * @param currentLanguage: The current language for localization.
13
+ * @param a11yFootpath: Whether the a11y-icon should be shown.
13
14
  * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.
14
15
  * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.
15
16
  * @returns arrivalTimeAttribute: The access attribute for the arrival time.
16
17
  * @returns departureTimeAttribute: The access attribute for the departure time.
17
18
  */
18
- export declare function getDepartureArrivalTimeAttribute(legs: Leg[], departureWalk: number, arrivalWalk: number, currentLanguage: string): {
19
+ export declare function getDepartureArrivalTimeAttribute(legs: Leg[], departureWalk: number, arrivalWalk: number, currentLanguage: string, a11yFootpath?: boolean): {
19
20
  renderDepartureTimeAttribute: () => TemplateResult;
20
21
  renderArrivalTimeAttribute: () => TemplateResult;
21
22
  departureTimeAttribute: IAccessAttribute | null;
@@ -1 +1 @@
1
- {"version":3,"file":"access-leg-helper.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAQ1C,OAAO,KAAK,EAAE,GAAG,EAA8B,MAAM,2BAA2B,CAAC;AAEjF,OAAO,iCAAiC,CAAC;AAEzC,UAAU,gBAAgB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AA2HD;;;;;;;;;GASG;AACH,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,GAAG,EAAE,EACX,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,eAAe,EAAE,MAAM,GACtB;IACD,4BAA4B,EAAE,MAAM,cAAc,CAAC;IACnD,0BAA0B,EAAE,MAAM,cAAc,CAAC;IACjD,sBAAsB,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAChD,oBAAoB,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAC/C,CAyGA"}
1
+ {"version":3,"file":"access-leg-helper.d.ts","sourceRoot":"","sources":["../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAQ1C,OAAO,KAAK,EAAE,GAAG,EAA8B,MAAM,2BAA2B,CAAC;AAEjF,OAAO,iCAAiC,CAAC;AAEzC,UAAU,gBAAgB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAuID;;;;;;;;;;GAUG;AACH,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,GAAG,EAAE,EACX,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,eAAe,EAAE,MAAM,EACvB,YAAY,CAAC,EAAE,OAAO,GACrB;IACD,4BAA4B,EAAE,MAAM,cAAc,CAAC;IACnD,0BAA0B,EAAE,MAAM,cAAc,CAAC;IACjD,sBAAsB,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAChD,oBAAoB,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAC/C,CAiJA"}
package/core/timetable.js CHANGED
@@ -1,56 +1,56 @@
1
- import { i18nWalkingDistanceDeparture as k, i18nWalkingDistanceArrival as y } from "@sbb-esta/lyne-elements/core/i18n.js";
2
- import { html as b, nothing as m } from "lit";
1
+ import { i18nWalkingDistanceDeparture as w, i18nWalkingDistanceArrival as T } from "@sbb-esta/lyne-elements/core/i18n.js";
2
+ import { html as f, nothing as b } from "lit";
3
3
  import "@sbb-esta/lyne-elements/icon.js";
4
- const x = (t) => (t == null ? void 0 : t.__typename) === "PTRideLeg", _ = (t) => (t == null ? void 0 : t.__typename) === "PTConnectionLeg", A = (t) => {
5
- var n, r, u, s, a, o;
6
- const i = ((n = t == null ? void 0 : t.text) == null ? void 0 : n.template) && t.text.template.indexOf("(") + 1, e = (s = (r = t == null ? void 0 : t.text) == null ? void 0 : r.template) == null ? void 0 : s.substring(
7
- i || 0,
8
- (u = t == null ? void 0 : t.text) == null ? void 0 : u.template.indexOf(")")
4
+ const $ = (t) => (t == null ? void 0 : t.__typename) === "PTRideLeg", _ = (t) => (t == null ? void 0 : t.__typename) === "PTConnectionLeg", v = (t) => {
5
+ var r, e, i, u, a, s;
6
+ const l = ((r = t == null ? void 0 : t.text) == null ? void 0 : r.template) && t.text.template.indexOf("(") + 1, n = (u = (e = t == null ? void 0 : t.text) == null ? void 0 : e.template) == null ? void 0 : u.substring(
7
+ l || 0,
8
+ (i = t == null ? void 0 : t.text) == null ? void 0 : i.template.indexOf(")")
9
9
  );
10
10
  return {
11
- duration: e && +e.substring(0, e.length - 1) || 0,
12
- text: ((o = (a = t == null ? void 0 : t.text) == null ? void 0 : a.template) == null ? void 0 : o.split("(")[0]) || ""
11
+ duration: n && +n.substring(0, n.length - 1) || 0,
12
+ text: ((s = (a = t == null ? void 0 : t.text) == null ? void 0 : a.template) == null ? void 0 : s.split("(")[0]) || ""
13
13
  };
14
14
  };
15
- function w(t, i) {
16
- var r, u;
17
- const e = _(t) ? t : null, n = e ? (r = e == null ? void 0 : e.notices) == null ? void 0 : r.filter((s) => i.includes(s.name))[0] : null;
18
- return n ? {
19
- duration: (e == null ? void 0 : e.duration) || 0,
20
- text: ((u = n == null ? void 0 : n.text) == null ? void 0 : u.template) || "",
15
+ function k(t, l) {
16
+ var e, i;
17
+ const n = _(t) ? t : null, r = n ? (e = n == null ? void 0 : n.notices) == null ? void 0 : e.filter((u) => l.includes(u.name))[0] : null;
18
+ return r ? {
19
+ duration: (n == null ? void 0 : n.duration) || 0,
20
+ text: ((i = r == null ? void 0 : r.text) == null ? void 0 : i.template) || "",
21
21
  icon: "walk-small"
22
22
  } : null;
23
23
  }
24
- function R(t, i) {
25
- var r, u, s;
26
- const e = x(t) ? (u = (r = t == null ? void 0 : t.serviceJourney) == null ? void 0 : r.notices) == null ? void 0 : u.filter(
27
- (a) => ["CI"].includes(a.name)
28
- )[0] : null, n = e && A(e);
24
+ function M(t, l, n, r) {
25
+ var u, a, s;
26
+ const e = $(t) ? (a = (u = t == null ? void 0 : t.serviceJourney) == null ? void 0 : u.notices) == null ? void 0 : a.filter(
27
+ (m) => ["CI"].includes(m.name)
28
+ )[0] : null, i = e && v(e);
29
29
  return e ? {
30
- duration: ((n == null ? void 0 : n.duration) || 0) + (i || 0),
31
- text: (n == null ? void 0 : n.text) || "",
32
- icon: `sa-${(s = e == null ? void 0 : e.name) == null ? void 0 : s.toLowerCase()}`
30
+ duration: ((i == null ? void 0 : i.duration) || 0) + (l || 0),
31
+ text: n ? w[r] : (i == null ? void 0 : i.text) || "",
32
+ icon: n ? "wheelchair-small" : `sa-${(s = e == null ? void 0 : e.name) == null ? void 0 : s.toLowerCase()}`
33
33
  } : null;
34
34
  }
35
- function Y(t, i) {
36
- var r, u, s;
37
- const e = x(t) ? (u = (r = t == null ? void 0 : t.serviceJourney) == null ? void 0 : r.notices) == null ? void 0 : u.filter(
38
- (a) => ["CO"].includes(a.name)
39
- )[0] : null, n = e && A(e);
35
+ function O(t, l, n, r) {
36
+ var u, a, s;
37
+ const e = $(t) ? (a = (u = t == null ? void 0 : t.serviceJourney) == null ? void 0 : u.notices) == null ? void 0 : a.filter(
38
+ (m) => ["CO"].includes(m.name)
39
+ )[0] : null, i = e && v(e);
40
40
  return e ? {
41
- duration: ((n == null ? void 0 : n.duration) || 0) + (i || 0),
42
- text: (n == null ? void 0 : n.text) || "",
43
- icon: `sa-${(s = e == null ? void 0 : e.name) == null ? void 0 : s.toLowerCase()}`
41
+ duration: ((i == null ? void 0 : i.duration) || 0) + (l || 0),
42
+ text: n ? T[r] : (i == null ? void 0 : i.text) || "",
43
+ icon: n ? "wheelchair-small" : `sa-${(s = e == null ? void 0 : e.name) == null ? void 0 : s.toLowerCase()}`
44
44
  } : null;
45
45
  }
46
- function T(t, i, e, n, r) {
47
- return b`
48
- <span class="sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${r}">
49
- <sbb-icon name=${i}></sbb-icon>
46
+ function C(t, l, n, r, e) {
47
+ return f`
48
+ <span class="sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${l}-${e}">
49
+ <sbb-icon name=${l}></sbb-icon>
50
50
  <time datetime=${t + "M"}>
51
51
  <span class="sbb-screen-reader-only">
52
- ${!n && r ? r === "departure" ? k[e] : y[e] : m}
53
- ${n ? b`<span>${n}</span>` : m}&nbsp;
52
+ ${!r && e ? e === "departure" ? w[n] : T[n] : b}
53
+ ${r ? f`<span>${r}</span>` : b}&nbsp;
54
54
  </span>
55
55
  ${t}
56
56
  <span class="sbb-pearl-chain__time-walktime-prime-symbol" aria-hidden="true">'</span>
@@ -59,65 +59,100 @@ function T(t, i, e, n, r) {
59
59
  </span>
60
60
  `;
61
61
  }
62
- function f(t, i, e) {
63
- return b`
64
- <span class="sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${e}">
65
- <sbb-icon name="walk-small"></sbb-icon>
62
+ function p(t, l, n, r) {
63
+ return f`
64
+ <span class="sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${r}-${n}">
65
+ <sbb-icon name=${r}></sbb-icon>
66
66
  <time datetime=${t + "M"}>
67
- <span class="sbb-screen-reader-only">${i}</span>
67
+ <span class="sbb-screen-reader-only">${l}</span>
68
68
  ${t}
69
69
  <span class="sbb-pearl-chain__time-walktime-prime-symbol" aria-hidden="true">'</span>
70
70
  </time>
71
71
  </span>
72
72
  `;
73
73
  }
74
- function E(t, i, e, n) {
75
- const r = t && t.filter((h) => x(h) || _(h))[0], u = ["YM", "YB", "Y", "YT"], s = w(r, u), a = R(r, i), o = i ? {
76
- text: k[n],
77
- duration: i,
78
- icon: "walk-small"
79
- } : null, C = () => s || (o && !a && !s ? o : a || null);
74
+ function I(t, l, n, r, e) {
75
+ const i = t && t.filter((A) => $(A) || _(A))[0], u = ["YM", "YB", "Y", "YT"], a = k(i, u), s = M(
76
+ i,
77
+ l,
78
+ e,
79
+ r
80
+ ), m = l ? {
81
+ text: w[r],
82
+ duration: l,
83
+ icon: e ? "wheelchair-small" : "walk-small"
84
+ } : null, D = () => a || (m && !s && !a ? m : s || null);
80
85
  function L() {
81
- return b`
82
- ${s ? f(s.duration, s.text, "left") : m}
83
- ${o && !a && !s ? f(o.duration, o.text, "left") : m}
84
- ${a ? T(
86
+ return f`
87
+ ${a ? p(
85
88
  a.duration,
86
- a.icon,
87
- n,
88
89
  a.text,
90
+ "left",
91
+ a.icon
92
+ ) : b}
93
+ ${m && !s && !a ? p(
94
+ m.duration,
95
+ m.text,
96
+ "left",
97
+ m.icon
98
+ ) : b}
99
+ ${s ? e ? p(
100
+ s.duration,
101
+ s.text,
102
+ "left",
103
+ s.icon
104
+ ) : C(
105
+ s.duration,
106
+ s.icon,
107
+ r,
108
+ s.text,
89
109
  "departure"
90
- ) : m}
110
+ ) : b}
91
111
  `;
92
112
  }
93
- const $ = t && t[t.length - 1], d = (_($) || x($)) && $, c = d && w(d, u), l = d && Y(d, e), p = e ? {
94
- text: y[n],
95
- duration: e,
96
- icon: "walk-small"
97
- } : null, v = () => c || (p && !l && !c ? p : l || null);
98
- function D() {
99
- return b`
100
- ${c ? f(c.duration, c.text, "right") : m}
101
- ${p && !l && !c ? f(p.duration, p.text, "right") : m}
102
- ${l ? T(
103
- l.duration,
104
- l.icon,
105
- n,
106
- l.text,
113
+ const h = t && t[t.length - 1], x = (_(h) || $(h)) && h, c = x && k(x, u), o = x && O(x, n, e, r), d = n ? {
114
+ text: T[r],
115
+ duration: n,
116
+ icon: e ? "wheelchair-small" : "walk-small"
117
+ } : null, R = () => c || (d && !o && !c ? d : o || null);
118
+ function Y() {
119
+ return f`
120
+ ${c ? p(
121
+ c.duration,
122
+ c.text,
123
+ "right",
124
+ c.icon
125
+ ) : b}
126
+ ${d && !o && !c ? p(
127
+ d.duration,
128
+ d.text,
129
+ "right",
130
+ d.icon
131
+ ) : b}
132
+ ${o ? e ? p(
133
+ o.duration,
134
+ o.text,
135
+ "right",
136
+ o.icon
137
+ ) : C(
138
+ o.duration,
139
+ o.icon,
140
+ r,
141
+ o.text,
107
142
  "arrival"
108
- ) : m}
143
+ ) : b}
109
144
  `;
110
145
  }
111
146
  return {
112
147
  renderDepartureTimeAttribute: L,
113
- renderArrivalTimeAttribute: D,
114
- departureTimeAttribute: C(),
115
- arrivalTimeAttribute: v()
148
+ renderArrivalTimeAttribute: Y,
149
+ departureTimeAttribute: D(),
150
+ arrivalTimeAttribute: R()
116
151
  };
117
152
  }
118
153
  export {
119
- A as extractTimeAndStringFromNoticeText,
120
- E as getDepartureArrivalTimeAttribute,
154
+ v as extractTimeAndStringFromNoticeText,
155
+ I as getDepartureArrivalTimeAttribute,
121
156
  _ as isConnectionLeg,
122
- x as isRideLeg
157
+ $ as isRideLeg
123
158
  };
@@ -312,6 +312,16 @@
312
312
  "description": "Per default, the current location has a pulsating animation. You can\ndisable the animation with this property.",
313
313
  "attribute": "disable-animation"
314
314
  },
315
+ {
316
+ "kind": "field",
317
+ "name": "a11yFootpath",
318
+ "type": {
319
+ "text": "boolean | undefined"
320
+ },
321
+ "privacy": "public",
322
+ "description": "Optional prop to render wheelchair-small instead of walk-small",
323
+ "attribute": "a11y-footpath"
324
+ },
315
325
  {
316
326
  "kind": "field",
317
327
  "name": "now",
@@ -388,6 +398,14 @@
388
398
  "description": "Per default, the current location has a pulsating animation. You can\ndisable the animation with this property.",
389
399
  "fieldName": "disableAnimation"
390
400
  },
401
+ {
402
+ "name": "a11y-footpath",
403
+ "type": {
404
+ "text": "boolean | undefined"
405
+ },
406
+ "description": "Optional prop to render wheelchair-small instead of walk-small",
407
+ "fieldName": "a11yFootpath"
408
+ },
391
409
  {
392
410
  "name": "now",
393
411
  "description": "A configured date which acts as the current date instead of the real current date. Recommended for testing purposes.",
@@ -1073,6 +1091,16 @@
1073
1091
  "description": "The loading state -\nwhen this is true it will be render skeleton with an idling animation",
1074
1092
  "attribute": "loading-trip"
1075
1093
  },
1094
+ {
1095
+ "kind": "field",
1096
+ "name": "a11yFootpath",
1097
+ "type": {
1098
+ "text": "boolean | undefined"
1099
+ },
1100
+ "privacy": "public",
1101
+ "description": "The Footpath attribute for rendering different icons\ntrue: render a11y-icon\nfalse: render walk-icon\ndefault: render walk-icon",
1102
+ "attribute": "a11y-footpath"
1103
+ },
1076
1104
  {
1077
1105
  "kind": "field",
1078
1106
  "name": "loadingPrice",
@@ -1251,6 +1279,14 @@
1251
1279
  "description": "The loading state -\nwhen this is true it will be render skeleton with an idling animation",
1252
1280
  "fieldName": "loadingTrip"
1253
1281
  },
1282
+ {
1283
+ "name": "a11y-footpath",
1284
+ "type": {
1285
+ "text": "boolean | undefined"
1286
+ },
1287
+ "description": "The Footpath attribute for rendering different icons\ntrue: render a11y-icon\nfalse: render walk-icon\ndefault: render walk-icon",
1288
+ "fieldName": "a11yFootpath"
1289
+ },
1254
1290
  {
1255
1291
  "name": "loading-price",
1256
1292
  "type": {
@@ -1487,6 +1523,14 @@
1487
1523
  "text": "string"
1488
1524
  },
1489
1525
  "description": ": The current language for localization."
1526
+ },
1527
+ {
1528
+ "name": "a11yFootpath",
1529
+ "optional": true,
1530
+ "type": {
1531
+ "text": "boolean"
1532
+ },
1533
+ "description": ": Whether the a11y-icon should be shown."
1490
1534
  }
1491
1535
  ]
1492
1536
  },
@@ -10,12 +10,13 @@ interface IAccessAttribute {
10
10
  * @param departureWalk: The walking distance in minutes from the departure point to the first leg.
11
11
  * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.
12
12
  * @param currentLanguage: The current language for localization.
13
+ * @param a11yFootpath: Whether the a11y-icon should be shown.
13
14
  * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.
14
15
  * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.
15
16
  * @returns arrivalTimeAttribute: The access attribute for the arrival time.
16
17
  * @returns departureTimeAttribute: The access attribute for the departure time.
17
18
  */
18
- export declare function getDepartureArrivalTimeAttribute(legs: Leg[], departureWalk: number, arrivalWalk: number, currentLanguage: string): {
19
+ export declare function getDepartureArrivalTimeAttribute(legs: Leg[], departureWalk: number, arrivalWalk: number, currentLanguage: string, a11yFootpath?: boolean): {
19
20
  renderDepartureTimeAttribute: () => TemplateResult;
20
21
  renderArrivalTimeAttribute: () => TemplateResult;
21
22
  departureTimeAttribute: IAccessAttribute | null;
@@ -1 +1 @@
1
- {"version":3,"file":"access-leg-helper.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAQ1C,OAAO,KAAK,EAAE,GAAG,EAA8B,MAAM,2BAA2B,CAAC;AAEjF,OAAO,iCAAiC,CAAC;AAEzC,UAAU,gBAAgB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AA2HD;;;;;;;;;GASG;AACH,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,GAAG,EAAE,EACX,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,eAAe,EAAE,MAAM,GACtB;IACD,4BAA4B,EAAE,MAAM,cAAc,CAAC;IACnD,0BAA0B,EAAE,MAAM,cAAc,CAAC;IACjD,sBAAsB,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAChD,oBAAoB,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAC/C,CAyGA"}
1
+ {"version":3,"file":"access-leg-helper.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAQ1C,OAAO,KAAK,EAAE,GAAG,EAA8B,MAAM,2BAA2B,CAAC;AAEjF,OAAO,iCAAiC,CAAC;AAEzC,UAAU,gBAAgB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAuID;;;;;;;;;;GAUG;AACH,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,GAAG,EAAE,EACX,aAAa,EAAE,MAAM,EACrB,WAAW,EAAE,MAAM,EACnB,eAAe,EAAE,MAAM,EACvB,YAAY,CAAC,EAAE,OAAO,GACrB;IACD,4BAA4B,EAAE,MAAM,cAAc,CAAC;IACnD,0BAA0B,EAAE,MAAM,cAAc,CAAC;IACjD,sBAAsB,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAChD,oBAAoB,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAC/C,CAiJA"}
@@ -29,7 +29,7 @@ function getPTConnectionAttribute(leg, connectionLegNotice) {
29
29
  icon: "walk-small"
30
30
  } : null;
31
31
  }
32
- function getFirstExtendedLegAttribute(leg, departureWalk) {
32
+ function getFirstExtendedLegAttribute(leg, departureWalk, a11yFootpath, currentLanguage) {
33
33
  var _a, _b, _c;
34
34
  const extendedFirstLeg = isRideLeg(leg) ? (_b = (_a = leg == null ? void 0 : leg.serviceJourney) == null ? void 0 : _a.notices) == null ? void 0 : _b.filter(
35
35
  (notice) => ["CI"].includes(notice.name)
@@ -37,11 +37,11 @@ function getFirstExtendedLegAttribute(leg, departureWalk) {
37
37
  const extractTimeAndString = extendedFirstLeg && extractTimeAndStringFromNoticeText(extendedFirstLeg);
38
38
  return extendedFirstLeg ? {
39
39
  duration: ((extractTimeAndString == null ? void 0 : extractTimeAndString.duration) || 0) + (departureWalk || 0),
40
- text: (extractTimeAndString == null ? void 0 : extractTimeAndString.text) || "",
41
- icon: `sa-${(_c = extendedFirstLeg == null ? void 0 : extendedFirstLeg.name) == null ? void 0 : _c.toLowerCase()}`
40
+ text: a11yFootpath ? i18nWalkingDistanceDeparture[currentLanguage] : (extractTimeAndString == null ? void 0 : extractTimeAndString.text) || "",
41
+ icon: a11yFootpath ? "wheelchair-small" : `sa-${(_c = extendedFirstLeg == null ? void 0 : extendedFirstLeg.name) == null ? void 0 : _c.toLowerCase()}`
42
42
  } : null;
43
43
  }
44
- function getLastExtendedLegAttribute(leg, arrivalWalk) {
44
+ function getLastExtendedLegAttribute(leg, arrivalWalk, a11yFootpath, currentLanguage) {
45
45
  var _a, _b, _c;
46
46
  const extendedLastLeg = isRideLeg(leg) ? (_b = (_a = leg == null ? void 0 : leg.serviceJourney) == null ? void 0 : _a.notices) == null ? void 0 : _b.filter(
47
47
  (notice) => ["CO"].includes(notice.name)
@@ -49,13 +49,13 @@ function getLastExtendedLegAttribute(leg, arrivalWalk) {
49
49
  const extractTimeAndString = extendedLastLeg && extractTimeAndStringFromNoticeText(extendedLastLeg);
50
50
  return extendedLastLeg ? {
51
51
  duration: ((extractTimeAndString == null ? void 0 : extractTimeAndString.duration) || 0) + (arrivalWalk || 0),
52
- text: (extractTimeAndString == null ? void 0 : extractTimeAndString.text) || "",
53
- icon: `sa-${(_c = extendedLastLeg == null ? void 0 : extendedLastLeg.name) == null ? void 0 : _c.toLowerCase()}`
52
+ text: a11yFootpath ? i18nWalkingDistanceArrival[currentLanguage] : (extractTimeAndString == null ? void 0 : extractTimeAndString.text) || "",
53
+ icon: a11yFootpath ? "wheelchair-small" : `sa-${(_c = extendedLastLeg == null ? void 0 : extendedLastLeg.name) == null ? void 0 : _c.toLowerCase()}`
54
54
  } : null;
55
55
  }
56
56
  function renderTransferTime(duration, icon, currentLanguage, label, type) {
57
57
  return html`
58
- <span class="sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${type}">
58
+ <span class="sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${icon}-${type}">
59
59
  <sbb-icon name=${icon}></sbb-icon>
60
60
  <time datetime=${duration + "M"}>
61
61
  <span class="sbb-screen-reader-only">
@@ -69,10 +69,10 @@ function renderTransferTime(duration, icon, currentLanguage, label, type) {
69
69
  </span>
70
70
  `;
71
71
  }
72
- function renderWalkTime(duration, label, variant) {
72
+ function renderWalkTime(duration, label, variant, icon) {
73
73
  return html`
74
- <span class="sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${variant}">
75
- <sbb-icon name="walk-small"></sbb-icon>
74
+ <span class="sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${icon}-${variant}">
75
+ <sbb-icon name=${icon}></sbb-icon>
76
76
  <time datetime=${duration + "M"}>
77
77
  <span class="sbb-screen-reader-only">${label}</span>
78
78
  ${duration}
@@ -81,15 +81,20 @@ function renderWalkTime(duration, label, variant) {
81
81
  </span>
82
82
  `;
83
83
  }
84
- function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, currentLanguage) {
84
+ function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, currentLanguage, a11yFootpath) {
85
85
  const connectionRideLeg = legs && legs.filter((leg) => isRideLeg(leg) || isConnectionLeg(leg))[0];
86
86
  const connectionLegNotice = ["YM", "YB", "Y", "YT"];
87
87
  const connectionFirstLeg = getPTConnectionAttribute(connectionRideLeg, connectionLegNotice);
88
- const extendedFirstLeg = getFirstExtendedLegAttribute(connectionRideLeg, departureWalk);
88
+ const extendedFirstLeg = getFirstExtendedLegAttribute(
89
+ connectionRideLeg,
90
+ departureWalk,
91
+ a11yFootpath,
92
+ currentLanguage
93
+ );
89
94
  const departureWalkAttribute = departureWalk ? {
90
95
  text: i18nWalkingDistanceDeparture[currentLanguage],
91
96
  duration: departureWalk,
92
- icon: "walk-small"
97
+ icon: a11yFootpath ? "wheelchair-small" : "walk-small"
93
98
  } : null;
94
99
  const getDepartureType = () => {
95
100
  if (connectionFirstLeg) {
@@ -104,9 +109,24 @@ function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, curr
104
109
  };
105
110
  function renderDepartureTimeAttribute() {
106
111
  return html`
107
- ${connectionFirstLeg ? renderWalkTime(connectionFirstLeg.duration, connectionFirstLeg.text, "left") : nothing}
108
- ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg ? renderWalkTime(departureWalkAttribute.duration, departureWalkAttribute.text, "left") : nothing}
109
- ${extendedFirstLeg ? renderTransferTime(
112
+ ${connectionFirstLeg ? renderWalkTime(
113
+ connectionFirstLeg.duration,
114
+ connectionFirstLeg.text,
115
+ "left",
116
+ connectionFirstLeg.icon
117
+ ) : nothing}
118
+ ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg ? renderWalkTime(
119
+ departureWalkAttribute.duration,
120
+ departureWalkAttribute.text,
121
+ "left",
122
+ departureWalkAttribute.icon
123
+ ) : nothing}
124
+ ${extendedFirstLeg ? a11yFootpath ? renderWalkTime(
125
+ extendedFirstLeg.duration,
126
+ extendedFirstLeg.text,
127
+ "left",
128
+ extendedFirstLeg.icon
129
+ ) : renderTransferTime(
110
130
  extendedFirstLeg.duration,
111
131
  extendedFirstLeg.icon,
112
132
  currentLanguage,
@@ -118,11 +138,11 @@ function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, curr
118
138
  const lastLeg = legs && legs[legs.length - 1];
119
139
  const lastConnectionRideLeg = (isConnectionLeg(lastLeg) || isRideLeg(lastLeg)) && lastLeg;
120
140
  const connectionLastLeg = lastConnectionRideLeg && getPTConnectionAttribute(lastConnectionRideLeg, connectionLegNotice);
121
- const extendedLastLeg = lastConnectionRideLeg && getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk);
141
+ const extendedLastLeg = lastConnectionRideLeg && getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk, a11yFootpath, currentLanguage);
122
142
  const arrivalWalkAttribute = arrivalWalk ? {
123
143
  text: i18nWalkingDistanceArrival[currentLanguage],
124
144
  duration: arrivalWalk,
125
- icon: "walk-small"
145
+ icon: a11yFootpath ? "wheelchair-small" : "walk-small"
126
146
  } : null;
127
147
  const getArrivalType = () => {
128
148
  if (connectionLastLeg) {
@@ -137,9 +157,24 @@ function getDepartureArrivalTimeAttribute(legs, departureWalk, arrivalWalk, curr
137
157
  };
138
158
  function renderArrivalTimeAttribute() {
139
159
  return html`
140
- ${connectionLastLeg ? renderWalkTime(connectionLastLeg.duration, connectionLastLeg.text, "right") : nothing}
141
- ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg ? renderWalkTime(arrivalWalkAttribute.duration, arrivalWalkAttribute.text, "right") : nothing}
142
- ${extendedLastLeg ? renderTransferTime(
160
+ ${connectionLastLeg ? renderWalkTime(
161
+ connectionLastLeg.duration,
162
+ connectionLastLeg.text,
163
+ "right",
164
+ connectionLastLeg.icon
165
+ ) : nothing}
166
+ ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg ? renderWalkTime(
167
+ arrivalWalkAttribute.duration,
168
+ arrivalWalkAttribute.text,
169
+ "right",
170
+ arrivalWalkAttribute.icon
171
+ ) : nothing}
172
+ ${extendedLastLeg ? a11yFootpath ? renderWalkTime(
173
+ extendedLastLeg.duration,
174
+ extendedLastLeg.text,
175
+ "right",
176
+ extendedLastLeg.icon
177
+ ) : renderTransferTime(
143
178
  extendedLastLeg.duration,
144
179
  extendedLastLeg.icon,
145
180
  currentLanguage,
@@ -161,4 +196,4 @@ export {
161
196
  isConnectionLeg,
162
197
  isRideLeg
163
198
  };
164
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"timetable.js","sources":["../../../../src/elements-experimental/core/timetable/timetable-helper.ts","../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\n\nimport type { Leg, Notice } from './timetable-properties.js';\n\nexport const isRideLeg = (leg: any): leg is Extract<Leg, { __typename: 'PTRideLeg' }> => {\n  return leg?.__typename === 'PTRideLeg';\n};\n\nexport const isConnectionLeg = (\n  leg: any,\n): leg is Extract<Leg, { __typename: 'PTConnectionLeg' }> => {\n  return leg?.__typename === 'PTConnectionLeg';\n};\n\nexport const extractTimeAndStringFromNoticeText = (\n  notice?: Notice,\n): { duration: number; text: string } => {\n  const firstIndex = notice?.text?.template && notice.text.template.indexOf('(') + 1;\n  const noticeDuration = notice?.text?.template?.substring(\n    firstIndex || 0,\n    notice?.text?.template.indexOf(')'),\n  );\n\n  return {\n    duration: (noticeDuration && +noticeDuration.substring(0, noticeDuration.length - 1)) || 0,\n    text: notice?.text?.template?.split('(')[0] || '',\n  };\n};\n","// This helper file contains several functions related to accessing attributes for the connections.\n\nimport {\n  i18nWalkingDistanceArrival,\n  i18nWalkingDistanceDeparture,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\n\nimport {\n  extractTimeAndStringFromNoticeText,\n  isConnectionLeg,\n  isRideLeg,\n} from './timetable-helper.js';\nimport type { Leg, PtConnectionLeg, PtRideLeg } from './timetable-properties.js';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\ninterface IAccessAttribute {\n  duration: number;\n  text: string;\n  icon: string;\n}\n\n/**\n * @returns the attribute of a ConnectionLeg\n */\nfunction getPTConnectionAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  connectionLegNotice: string[],\n): IAccessAttribute | null {\n  const connectionFirstLeg = isConnectionLeg(leg) ? (leg as PtConnectionLeg) : null;\n\n  const connectionFirstLegNotice = connectionFirstLeg\n    ? connectionFirstLeg?.notices?.filter((notice) => connectionLegNotice.includes(notice.name))[0]\n    : null;\n\n  return connectionFirstLegNotice\n    ? {\n        duration: connectionFirstLeg?.duration || 0,\n        text: connectionFirstLegNotice?.text?.template || '',\n        icon: 'walk-small',\n      }\n    : null;\n}\n\n/**\n * @returns the extended enter attribute of the PTRideLeg\n */\nfunction getFirstExtendedLegAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  departureWalk: number,\n): IAccessAttribute | null {\n  // Extended enter\n  const extendedFirstLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CI'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedFirstLeg && extractTimeAndStringFromNoticeText(extendedFirstLeg);\n\n  return extendedFirstLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (departureWalk || 0),\n        text: extractTimeAndString?.text || '',\n        icon: `sa-${extendedFirstLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * @returns the extended exit attribute of the PTRideLeg\n */\nfunction getLastExtendedLegAttribute(leg: Leg, arrivalWalk: number): IAccessAttribute | null {\n  // Extended exit\n  const extendedLastLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CO'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedLastLeg && extractTimeAndStringFromNoticeText(extendedLastLeg);\n\n  return extendedLastLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (arrivalWalk || 0),\n        text: extractTimeAndString?.text || '',\n        icon: `sa-${extendedLastLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * renders the extended exit/enter icon with the duration\n */\nfunction renderTransferTime(\n  duration: number | string,\n  icon: string,\n  currentLanguage: string,\n  label?: string,\n  type?: 'departure' | 'arrival',\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${type}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">\n          ${!label && type\n            ? type === 'departure'\n              ? i18nWalkingDistanceDeparture[currentLanguage]\n              : i18nWalkingDistanceArrival[currentLanguage]\n            : nothing}\n          ${label ? html`<span>${label}</span>` : nothing}&nbsp;\n        </span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n        <span class=\"sbb-screen-reader-only\">min</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * renders a walk-time icon with the walk duration\n */\nfunction renderWalkTime(\n  duration: number | string,\n  label: string,\n  variant: 'left' | 'right',\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${variant}\">\n      <sbb-icon name=\"walk-small\"></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">${label}</span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * @param legs: An array of Leg objects representing the journey legs.\n * @param departureWalk: The walking distance in minutes from the departure point to the first leg.\n * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.\n * @param currentLanguage: The current language for localization.\n * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.\n * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.\n * @returns arrivalTimeAttribute: The access attribute for the arrival time.\n * @returns departureTimeAttribute: The access attribute for the departure time.\n */\nexport function getDepartureArrivalTimeAttribute(\n  legs: Leg[],\n  departureWalk: number,\n  arrivalWalk: number,\n  currentLanguage: string,\n): {\n  renderDepartureTimeAttribute: () => TemplateResult;\n  renderArrivalTimeAttribute: () => TemplateResult;\n  departureTimeAttribute: IAccessAttribute | null;\n  arrivalTimeAttribute: IAccessAttribute | null;\n} {\n  const connectionRideLeg =\n    legs &&\n    (legs.filter((leg) => isRideLeg(leg) || isConnectionLeg(leg))[0] as\n      | PtRideLeg\n      | PtConnectionLeg);\n\n  const connectionLegNotice = ['YM', 'YB', 'Y', 'YT'];\n\n  const connectionFirstLeg = getPTConnectionAttribute(connectionRideLeg, connectionLegNotice);\n  const extendedFirstLeg = getFirstExtendedLegAttribute(connectionRideLeg, departureWalk);\n  const departureWalkAttribute = departureWalk\n    ? {\n        text: i18nWalkingDistanceDeparture[currentLanguage],\n        duration: departureWalk,\n        icon: 'walk-small',\n      }\n    : null;\n\n  const getDepartureType = (): IAccessAttribute | null => {\n    if (connectionFirstLeg) {\n      return connectionFirstLeg;\n    } else if (departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg) {\n      return departureWalkAttribute;\n    } else if (extendedFirstLeg) {\n      return extendedFirstLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderDepartureTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionFirstLeg\n        ? renderWalkTime(connectionFirstLeg.duration, connectionFirstLeg.text, 'left')\n        : nothing}\n      ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg\n        ? renderWalkTime(departureWalkAttribute.duration, departureWalkAttribute.text, 'left')\n        : nothing}\n      ${extendedFirstLeg\n        ? renderTransferTime(\n            extendedFirstLeg.duration,\n            extendedFirstLeg.icon,\n            currentLanguage,\n            extendedFirstLeg.text,\n            'departure',\n          )\n        : nothing}\n    `;\n  }\n\n  const lastLeg = legs && legs[legs.length - 1];\n  const lastConnectionRideLeg =\n    (isConnectionLeg(lastLeg) || isRideLeg(lastLeg)) && (lastLeg as PtConnectionLeg | PtRideLeg);\n\n  const connectionLastLeg =\n    lastConnectionRideLeg && getPTConnectionAttribute(lastConnectionRideLeg, connectionLegNotice);\n  const extendedLastLeg =\n    lastConnectionRideLeg && getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk);\n  const arrivalWalkAttribute = arrivalWalk\n    ? {\n        text: i18nWalkingDistanceArrival[currentLanguage],\n        duration: arrivalWalk,\n        icon: 'walk-small',\n      }\n    : null;\n\n  const getArrivalType = (): IAccessAttribute | null => {\n    if (connectionLastLeg) {\n      return connectionLastLeg;\n    } else if (arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg) {\n      return arrivalWalkAttribute;\n    } else if (extendedLastLeg) {\n      return extendedLastLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderArrivalTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionLastLeg\n        ? renderWalkTime(connectionLastLeg.duration, connectionLastLeg.text, 'right')\n        : nothing}\n      ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg\n        ? renderWalkTime(arrivalWalkAttribute.duration, arrivalWalkAttribute.text, 'right')\n        : nothing}\n      ${extendedLastLeg\n        ? renderTransferTime(\n            extendedLastLeg.duration,\n            extendedLastLeg.icon,\n            currentLanguage,\n            extendedLastLeg.text,\n            'arrival',\n          )\n        : nothing}\n    `;\n  }\n\n  return {\n    renderDepartureTimeAttribute,\n    renderArrivalTimeAttribute,\n    departureTimeAttribute: getDepartureType(),\n    arrivalTimeAttribute: getArrivalType(),\n  };\n}\n"],"names":[],"mappings":"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"}
199
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"timetable.js","sources":["../../../../src/elements-experimental/core/timetable/timetable-helper.ts","../../../../src/elements-experimental/core/timetable/access-leg-helper.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\n\nimport type { Leg, Notice } from './timetable-properties.js';\n\nexport const isRideLeg = (leg: any): leg is Extract<Leg, { __typename: 'PTRideLeg' }> => {\n  return leg?.__typename === 'PTRideLeg';\n};\n\nexport const isConnectionLeg = (\n  leg: any,\n): leg is Extract<Leg, { __typename: 'PTConnectionLeg' }> => {\n  return leg?.__typename === 'PTConnectionLeg';\n};\n\nexport const extractTimeAndStringFromNoticeText = (\n  notice?: Notice,\n): { duration: number; text: string } => {\n  const firstIndex = notice?.text?.template && notice.text.template.indexOf('(') + 1;\n  const noticeDuration = notice?.text?.template?.substring(\n    firstIndex || 0,\n    notice?.text?.template.indexOf(')'),\n  );\n\n  return {\n    duration: (noticeDuration && +noticeDuration.substring(0, noticeDuration.length - 1)) || 0,\n    text: notice?.text?.template?.split('(')[0] || '',\n  };\n};\n","// This helper file contains several functions related to accessing attributes for the connections.\n\nimport {\n  i18nWalkingDistanceArrival,\n  i18nWalkingDistanceDeparture,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\n\nimport {\n  extractTimeAndStringFromNoticeText,\n  isConnectionLeg,\n  isRideLeg,\n} from './timetable-helper.js';\nimport type { Leg, PtConnectionLeg, PtRideLeg } from './timetable-properties.js';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\ninterface IAccessAttribute {\n  duration: number;\n  text: string;\n  icon: string;\n}\n\n/**\n * @returns the attribute of a ConnectionLeg\n */\nfunction getPTConnectionAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  connectionLegNotice: string[],\n): IAccessAttribute | null {\n  const connectionFirstLeg = isConnectionLeg(leg) ? (leg as PtConnectionLeg) : null;\n\n  const connectionFirstLegNotice = connectionFirstLeg\n    ? connectionFirstLeg?.notices?.filter((notice) => connectionLegNotice.includes(notice.name))[0]\n    : null;\n\n  return connectionFirstLegNotice\n    ? {\n        duration: connectionFirstLeg?.duration || 0,\n        text: connectionFirstLegNotice?.text?.template || '',\n        icon: 'walk-small',\n      }\n    : null;\n}\n\n/**\n * @returns the extended enter attribute of the PTRideLeg\n */\nfunction getFirstExtendedLegAttribute(\n  leg: PtRideLeg | PtConnectionLeg,\n  departureWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended enter\n  const extendedFirstLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CI'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedFirstLeg && extractTimeAndStringFromNoticeText(extendedFirstLeg);\n\n  return extendedFirstLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (departureWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceDeparture[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedFirstLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * @returns the extended exit attribute of the PTRideLeg\n */\nfunction getLastExtendedLegAttribute(\n  leg: Leg,\n  arrivalWalk: number,\n  a11yFootpath: boolean | undefined,\n  currentLanguage: string,\n): IAccessAttribute | null {\n  // Extended exit\n  const extendedLastLeg = isRideLeg(leg)\n    ? (leg as PtRideLeg)?.serviceJourney?.notices?.filter((notice) =>\n        ['CO'].includes(notice.name),\n      )[0]\n    : null;\n\n  const extractTimeAndString =\n    extendedLastLeg && extractTimeAndStringFromNoticeText(extendedLastLeg);\n\n  return extendedLastLeg\n    ? {\n        duration: (extractTimeAndString?.duration || 0) + (arrivalWalk || 0),\n        text: a11yFootpath\n          ? i18nWalkingDistanceArrival[currentLanguage]\n          : extractTimeAndString?.text || '',\n        icon: a11yFootpath ? 'wheelchair-small' : `sa-${extendedLastLeg?.name?.toLowerCase()}`,\n      }\n    : null;\n}\n\n/**\n * renders the extended exit/enter icon with the duration\n */\nfunction renderTransferTime(\n  duration: number | string,\n  icon: string,\n  currentLanguage: string,\n  label?: string,\n  type?: 'departure' | 'arrival',\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${icon}-${type}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">\n          ${!label && type\n            ? type === 'departure'\n              ? i18nWalkingDistanceDeparture[currentLanguage]\n              : i18nWalkingDistanceArrival[currentLanguage]\n            : nothing}\n          ${label ? html`<span>${label}</span>` : nothing}&nbsp;\n        </span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n        <span class=\"sbb-screen-reader-only\">min</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * renders a walk-time icon with the walk duration\n */\nfunction renderWalkTime(\n  duration: number | string,\n  label: string,\n  variant: 'left' | 'right',\n  icon: string,\n): TemplateResult {\n  return html`\n    <span class=\"sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${icon}-${variant}\">\n      <sbb-icon name=${icon}></sbb-icon>\n      <time datetime=${duration + 'M'}>\n        <span class=\"sbb-screen-reader-only\">${label}</span>\n        ${duration}\n        <span class=\"sbb-pearl-chain__time-walktime-prime-symbol\" aria-hidden=\"true\">'</span>\n      </time>\n    </span>\n  `;\n}\n\n/**\n * @param legs: An array of Leg objects representing the journey legs.\n * @param departureWalk: The walking distance in minutes from the departure point to the first leg.\n * @param arrivalWalk: The walking distance in minutes from the last leg to the arrival point.\n * @param currentLanguage: The current language for localization.\n * @param a11yFootpath: Whether the a11y-icon should be shown.\n * @returns renderDepartureTimeAttribute: A function that renders the element for the departure time attribute.\n * @returns renderArrivalTimeAttribute: A function that renders the element for the arrival time attribute.\n * @returns arrivalTimeAttribute: The access attribute for the arrival time.\n * @returns departureTimeAttribute: The access attribute for the departure time.\n */\nexport function getDepartureArrivalTimeAttribute(\n  legs: Leg[],\n  departureWalk: number,\n  arrivalWalk: number,\n  currentLanguage: string,\n  a11yFootpath?: boolean,\n): {\n  renderDepartureTimeAttribute: () => TemplateResult;\n  renderArrivalTimeAttribute: () => TemplateResult;\n  departureTimeAttribute: IAccessAttribute | null;\n  arrivalTimeAttribute: IAccessAttribute | null;\n} {\n  const connectionRideLeg =\n    legs &&\n    (legs.filter((leg) => isRideLeg(leg) || isConnectionLeg(leg))[0] as\n      | PtRideLeg\n      | PtConnectionLeg);\n\n  const connectionLegNotice = ['YM', 'YB', 'Y', 'YT'];\n\n  const connectionFirstLeg = getPTConnectionAttribute(connectionRideLeg, connectionLegNotice);\n  const extendedFirstLeg = getFirstExtendedLegAttribute(\n    connectionRideLeg,\n    departureWalk,\n    a11yFootpath,\n    currentLanguage,\n  );\n  const departureWalkAttribute = departureWalk\n    ? {\n        text: i18nWalkingDistanceDeparture[currentLanguage],\n        duration: departureWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getDepartureType = (): IAccessAttribute | null => {\n    if (connectionFirstLeg) {\n      return connectionFirstLeg;\n    } else if (departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg) {\n      return departureWalkAttribute;\n    } else if (extendedFirstLeg) {\n      return extendedFirstLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderDepartureTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionFirstLeg\n        ? renderWalkTime(\n            connectionFirstLeg.duration,\n            connectionFirstLeg.text,\n            'left',\n            connectionFirstLeg.icon,\n          )\n        : nothing}\n      ${departureWalkAttribute && !extendedFirstLeg && !connectionFirstLeg\n        ? renderWalkTime(\n            departureWalkAttribute.duration,\n            departureWalkAttribute.text,\n            'left',\n            departureWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedFirstLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.text,\n              'left',\n              extendedFirstLeg.icon,\n            )\n          : renderTransferTime(\n              extendedFirstLeg.duration,\n              extendedFirstLeg.icon,\n              currentLanguage,\n              extendedFirstLeg.text,\n              'departure',\n            )\n        : nothing}\n    `;\n  }\n\n  const lastLeg = legs && legs[legs.length - 1];\n  const lastConnectionRideLeg =\n    (isConnectionLeg(lastLeg) || isRideLeg(lastLeg)) && (lastLeg as PtConnectionLeg | PtRideLeg);\n\n  const connectionLastLeg =\n    lastConnectionRideLeg && getPTConnectionAttribute(lastConnectionRideLeg, connectionLegNotice);\n  const extendedLastLeg =\n    lastConnectionRideLeg &&\n    getLastExtendedLegAttribute(lastConnectionRideLeg, arrivalWalk, a11yFootpath, currentLanguage);\n  const arrivalWalkAttribute = arrivalWalk\n    ? {\n        text: i18nWalkingDistanceArrival[currentLanguage],\n        duration: arrivalWalk,\n        icon: a11yFootpath ? 'wheelchair-small' : 'walk-small',\n      }\n    : null;\n\n  const getArrivalType = (): IAccessAttribute | null => {\n    if (connectionLastLeg) {\n      return connectionLastLeg;\n    } else if (arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg) {\n      return arrivalWalkAttribute;\n    } else if (extendedLastLeg) {\n      return extendedLastLeg;\n    } else {\n      return null;\n    }\n  };\n\n  function renderArrivalTimeAttribute(): TemplateResult {\n    return html`\n      ${connectionLastLeg\n        ? renderWalkTime(\n            connectionLastLeg.duration,\n            connectionLastLeg.text,\n            'right',\n            connectionLastLeg.icon,\n          )\n        : nothing}\n      ${arrivalWalkAttribute && !extendedLastLeg && !connectionLastLeg\n        ? renderWalkTime(\n            arrivalWalkAttribute.duration,\n            arrivalWalkAttribute.text,\n            'right',\n            arrivalWalkAttribute.icon,\n          )\n        : nothing}\n      ${extendedLastLeg\n        ? a11yFootpath\n          ? renderWalkTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.text,\n              'right',\n              extendedLastLeg.icon,\n            )\n          : renderTransferTime(\n              extendedLastLeg.duration,\n              extendedLastLeg.icon,\n              currentLanguage,\n              extendedLastLeg.text,\n              'arrival',\n            )\n        : nothing}\n    `;\n  }\n\n  return {\n    renderDepartureTimeAttribute,\n    renderArrivalTimeAttribute,\n    departureTimeAttribute: getDepartureType(),\n    arrivalTimeAttribute: getArrivalType(),\n  };\n}\n"],"names":[],"mappings":"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"}