@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.
- package/core/timetable/access-leg-helper.d.ts +2 -1
- package/core/timetable/access-leg-helper.d.ts.map +1 -1
- package/core/timetable.js +111 -76
- package/custom-elements.json +44 -0
- package/development/core/timetable/access-leg-helper.d.ts +2 -1
- package/development/core/timetable/access-leg-helper.d.ts.map +1 -1
- package/development/core/timetable.js +57 -22
- package/development/journey-summary.js +2 -15
- package/development/pearl-chain/pearl-chain.sample-data.d.ts +1 -0
- package/development/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
- package/development/pearl-chain-time/pearl-chain-time.d.ts +2 -0
- package/development/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
- package/development/pearl-chain-time.js +20 -20
- package/development/pearl-chain-vertical-item.js +2 -15
- package/development/pearl-chain-vertical.js +2 -15
- package/development/pearl-chain.js +3 -16
- package/development/timetable-duration.js +2 -15
- package/development/timetable-row/timetable-row.d.ts +7 -0
- package/development/timetable-row/timetable-row.d.ts.map +1 -1
- package/development/timetable-row/timetable-row.sample-data.d.ts +2 -0
- package/development/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
- package/development/timetable-row.js +8 -16
- package/package.json +2 -2
- package/pearl-chain/pearl-chain.sample-data.d.ts +1 -0
- package/pearl-chain/pearl-chain.sample-data.d.ts.map +1 -1
- package/pearl-chain-time/pearl-chain-time.d.ts +2 -0
- package/pearl-chain-time/pearl-chain-time.d.ts.map +1 -1
- package/pearl-chain-time.js +37 -33
- package/pearl-chain.js +11 -11
- package/timetable-row/timetable-row.d.ts +7 -0
- package/timetable-row/timetable-row.d.ts.map +1 -1
- package/timetable-row/timetable-row.sample-data.d.ts +2 -0
- package/timetable-row/timetable-row.sample-data.d.ts.map +1 -1
- 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;
|
|
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
|
|
2
|
-
import { html as
|
|
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
|
|
5
|
-
var
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
(
|
|
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:
|
|
12
|
-
text: ((
|
|
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
|
|
16
|
-
var
|
|
17
|
-
const
|
|
18
|
-
return
|
|
19
|
-
duration: (
|
|
20
|
-
text: ((
|
|
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
|
|
25
|
-
var
|
|
26
|
-
const e =
|
|
27
|
-
(
|
|
28
|
-
)[0] : null,
|
|
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: ((
|
|
31
|
-
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
|
|
36
|
-
var
|
|
37
|
-
const e =
|
|
38
|
-
(
|
|
39
|
-
)[0] : null,
|
|
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: ((
|
|
42
|
-
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
|
|
47
|
-
return
|
|
48
|
-
<span class="sbb-pearl-chain__time-transfer sbb-pearl-chain__time-transfer--${
|
|
49
|
-
<sbb-icon name=${
|
|
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
|
-
${!
|
|
53
|
-
${
|
|
52
|
+
${!r && e ? e === "departure" ? w[n] : T[n] : b}
|
|
53
|
+
${r ? f`<span>${r}</span>` : b}
|
|
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
|
|
63
|
-
return
|
|
64
|
-
<span class="sbb-pearl-chain__time-walktime sbb-pearl-chain__time-walktime--${
|
|
65
|
-
<sbb-icon name
|
|
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">${
|
|
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
|
|
75
|
-
const
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
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
|
|
82
|
-
${
|
|
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
|
-
) :
|
|
110
|
+
) : b}
|
|
91
111
|
`;
|
|
92
112
|
}
|
|
93
|
-
const
|
|
94
|
-
text:
|
|
95
|
-
duration:
|
|
96
|
-
icon: "walk-small"
|
|
97
|
-
} : null,
|
|
98
|
-
function
|
|
99
|
-
return
|
|
100
|
-
${c ?
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
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
|
-
) :
|
|
143
|
+
) : b}
|
|
109
144
|
`;
|
|
110
145
|
}
|
|
111
146
|
return {
|
|
112
147
|
renderDepartureTimeAttribute: L,
|
|
113
|
-
renderArrivalTimeAttribute:
|
|
114
|
-
departureTimeAttribute:
|
|
115
|
-
arrivalTimeAttribute:
|
|
148
|
+
renderArrivalTimeAttribute: Y,
|
|
149
|
+
departureTimeAttribute: D(),
|
|
150
|
+
arrivalTimeAttribute: R()
|
|
116
151
|
};
|
|
117
152
|
}
|
|
118
153
|
export {
|
|
119
|
-
|
|
120
|
-
|
|
154
|
+
v as extractTimeAndStringFromNoticeText,
|
|
155
|
+
I as getDepartureArrivalTimeAttribute,
|
|
121
156
|
_ as isConnectionLeg,
|
|
122
|
-
|
|
157
|
+
$ as isRideLeg
|
|
123
158
|
};
|
package/custom-elements.json
CHANGED
|
@@ -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;
|
|
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
|
|
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(
|
|
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(
|
|
108
|
-
|
|
109
|
-
|
|
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(
|
|
141
|
-
|
|
142
|
-
|
|
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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"}
|