@sbb-esta/lyne-elements-experimental-dev 4.7.0-dev.1773648109 → 4.7.0-dev.1773670972
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/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +65 -76
- package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +72 -52
- package/autocomplete-grid/autocomplete-grid-button.js +3 -6
- package/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.js +2 -17
- package/autocomplete-grid/autocomplete-grid-cell.js +4 -7
- package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +20 -21
- package/autocomplete-grid/autocomplete-grid-optgroup.js +3 -6
- package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +2 -33
- package/autocomplete-grid/autocomplete-grid-option.js +4 -9
- package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -22
- package/autocomplete-grid/autocomplete-grid-row.js +4 -7
- package/autocomplete-grid/autocomplete-grid.js +3 -6
- package/autocomplete-grid-cell.component-Dak9wlBr.js +24 -0
- package/autocomplete-grid-option.component-DNRFHOwc.js +37 -0
- package/autocomplete-grid-row.component-DBHZQ0GQ.js +27 -0
- package/autocomplete-grid.js +9 -21
- package/autocomplete-grid.pure.js +7 -15
- package/core/datetime/date-helper.js +2 -191
- package/core/datetime.js +2 -5
- package/core/timetable/access-leg-helper.js +76 -71
- package/core/timetable/timetable-helper.js +9 -11
- package/core/timetable/timetable-properties.js +0 -1
- package/core/timetable.js +3 -7
- package/date-helper-CGproP5d.js +185 -0
- package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +114 -122
- package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +92 -70
- package/development/autocomplete-grid/autocomplete-grid-button.js +6 -4
- package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.js +2 -29
- package/development/autocomplete-grid/autocomplete-grid-cell.js +7 -5
- package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +27 -22
- package/development/autocomplete-grid/autocomplete-grid-optgroup.js +6 -4
- package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +2 -109
- package/development/autocomplete-grid/autocomplete-grid-option.js +7 -7
- package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -91
- package/development/autocomplete-grid/autocomplete-grid-row.js +7 -5
- package/development/autocomplete-grid/autocomplete-grid.js +6 -4
- package/development/autocomplete-grid-cell.component-BBvM4o2H.js +42 -0
- package/development/autocomplete-grid-option.component-QzfM5eIE.js +123 -0
- package/development/autocomplete-grid-row.component-H8sCTCkT.js +104 -0
- package/development/autocomplete-grid.js +10 -14
- package/development/autocomplete-grid.pure.js +4 -13
- package/development/core/datetime/date-helper.js +2 -285
- package/development/core/datetime.js +2 -6
- package/development/core/timetable/access-leg-helper.js +104 -82
- package/development/core/timetable/timetable-helper.js +16 -17
- package/development/core/timetable/timetable-properties.js +0 -2
- package/development/core/timetable.js +3 -8
- package/development/date-helper-8_Y-PuHh.js +520 -0
- package/development/differenceInMinutes-DN_1Rk3O.js +110 -0
- package/development/format-Bbrn2bgo.js +1848 -0
- package/development/isValid-C-HzKv4v.js +178 -0
- package/development/journey-summary/journey-summary.component.js +2 -288
- package/development/journey-summary.component-uGhZvA4p.js +385 -0
- package/development/journey-summary.js +8 -5
- package/development/journey-summary.pure.js +2 -5
- package/development/mapper-hWWm7Uke.js +11454 -0
- package/development/pearl-chain/pearl-chain.component.js +2 -634
- package/development/pearl-chain-time/pearl-chain-time.component.js +2 -306
- package/development/pearl-chain-time.component-B8mayTWD.js +415 -0
- package/development/pearl-chain-time.js +8 -5
- package/development/pearl-chain-time.pure.js +2 -5
- package/development/pearl-chain-vertical/pearl-chain-vertical.component.js +2 -28
- package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +2 -393
- package/development/pearl-chain-vertical-item.component-BDzbcIaf.js +435 -0
- package/development/pearl-chain-vertical-item.js +8 -5
- package/development/pearl-chain-vertical-item.pure.js +2 -5
- package/development/pearl-chain-vertical.component-CswE7b3M.js +39 -0
- package/development/pearl-chain-vertical.js +8 -5
- package/development/pearl-chain-vertical.pure.js +2 -5
- package/development/pearl-chain.component-wpsTvoSe.js +704 -0
- package/development/pearl-chain.js +8 -5
- package/development/pearl-chain.pure.js +2 -5
- package/development/seat-reservation/common/mapper/icon-mapper.js +168 -71
- package/development/seat-reservation/common/mapper/mapper.js +2 -11429
- package/development/seat-reservation/common/mapper.js +2 -9
- package/development/seat-reservation/common/svgs.js +2 -46
- package/development/seat-reservation/common/translations/i18n.js +1118 -900
- package/development/seat-reservation/common/translations.js +1 -4
- package/development/seat-reservation/common/types.js +0 -2
- package/development/seat-reservation/common.js +8 -12
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +1307 -1231
- package/development/seat-reservation/seat-reservation/seat-reservation.component.js +2 -862
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +2 -106
- package/development/seat-reservation/seat-reservation-area.js +7 -5
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +35 -34
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +2 -162
- package/development/seat-reservation/seat-reservation-graphic.js +7 -5
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +2 -713
- package/development/seat-reservation/seat-reservation-navigation-coach.js +7 -5
- package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -131
- package/development/seat-reservation/seat-reservation-navigation-services.js +7 -5
- package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +2 -601
- package/development/seat-reservation/seat-reservation-place-control.js +7 -5
- package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +2 -22
- package/development/seat-reservation/seat-reservation-scoped.js +7 -5
- package/development/seat-reservation/seat-reservation.js +7 -6
- package/development/seat-reservation-area.component-ORuli_DC.js +138 -0
- package/development/seat-reservation-graphic.component-lZXqHWIz.js +193 -0
- package/development/seat-reservation-navigation-coach.component-D2QXTMJJ.js +828 -0
- package/development/seat-reservation-navigation-services.component-Bg1adRlU.js +179 -0
- package/development/seat-reservation-place-control.component-CwUX-QYO.js +726 -0
- package/development/seat-reservation-scoped.component-uLT33P9y.js +31 -0
- package/development/seat-reservation.component-MOv5kHDC.js +821 -0
- package/development/seat-reservation.js +16 -29
- package/development/seat-reservation.pure.js +11 -29
- package/development/svgs-kDpBCto5.js +28 -0
- package/development/timetable-duration/timetable-duration.component.js +2 -108
- package/development/timetable-duration.component-D21SXsQq.js +125 -0
- package/development/timetable-duration.js +8 -5
- package/development/timetable-duration.pure.js +2 -5
- package/development/timetable-row/timetable-row.component.js +2 -781
- package/development/timetable-row.component-Y5w8vEwP.js +932 -0
- package/development/timetable-row.js +8 -13
- package/development/timetable-row.pure.js +2 -12
- package/development/toDate-Biiv3kyf.js +150 -0
- package/differenceInMinutes-Dr9gRqtu.js +27 -0
- package/format-CM5exOsN.js +1103 -0
- package/isValid-B9oVW3lA.js +36 -0
- package/journey-summary/journey-summary.component.js +2 -194
- package/journey-summary.component-Cq_4kaOp.js +264 -0
- package/journey-summary.js +5 -4
- package/journey-summary.pure.js +2 -4
- package/mapper-DkiDDseD.js +11382 -0
- package/package.json +2 -2
- package/pearl-chain/pearl-chain.component.js +2 -165
- package/pearl-chain-time/pearl-chain-time.component.js +2 -157
- package/pearl-chain-time.component-DGDW5S1c.js +239 -0
- package/pearl-chain-time.js +5 -4
- package/pearl-chain-time.pure.js +2 -4
- package/pearl-chain-vertical/pearl-chain-vertical.component.js +2 -17
- package/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +2 -77
- package/pearl-chain-vertical-item.component-G22bWhLU.js +108 -0
- package/pearl-chain-vertical-item.js +5 -4
- package/pearl-chain-vertical-item.pure.js +2 -4
- package/pearl-chain-vertical.component-CXIDT5RD.js +21 -0
- package/pearl-chain-vertical.js +5 -4
- package/pearl-chain-vertical.pure.js +2 -4
- package/pearl-chain.component-DmjkVIva.js +194 -0
- package/pearl-chain.js +5 -4
- package/pearl-chain.pure.js +2 -4
- package/seat-reservation/common/mapper/icon-mapper.js +71 -71
- package/seat-reservation/common/mapper/mapper.js +2 -11386
- package/seat-reservation/common/mapper.js +3 -9
- package/seat-reservation/common/svgs.js +2 -242
- package/seat-reservation/common/translations/i18n.js +1084 -891
- package/seat-reservation/common/translations.js +2 -4
- package/seat-reservation/common/types.js +0 -1
- package/seat-reservation/common.js +9 -15
- package/seat-reservation/seat-reservation/seat-reservation-base-element.js +834 -812
- package/seat-reservation/seat-reservation/seat-reservation.component.js +2 -420
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +2 -51
- package/seat-reservation/seat-reservation-area.js +4 -7
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +68 -71
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +2 -75
- package/seat-reservation/seat-reservation-graphic.js +4 -7
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +2 -234
- package/seat-reservation/seat-reservation-navigation-coach.js +4 -7
- package/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -85
- package/seat-reservation/seat-reservation-navigation-services.js +4 -7
- package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +2 -203
- package/seat-reservation/seat-reservation-place-control.js +4 -7
- package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +2 -13
- package/seat-reservation/seat-reservation-scoped.js +4 -7
- package/seat-reservation/seat-reservation.js +5 -9
- package/seat-reservation-area.component-COD6CXhP.js +75 -0
- package/seat-reservation-graphic.component-BNfU5tQM.js +102 -0
- package/seat-reservation-navigation-coach.component-Bh9ILq60.js +333 -0
- package/seat-reservation-navigation-services.component-QL0UnilZ.js +127 -0
- package/seat-reservation-place-control.component-BfnZUyHv.js +322 -0
- package/seat-reservation-scoped.component-CY04BT_4.js +17 -0
- package/seat-reservation.component-zrQHTRl3.js +364 -0
- package/seat-reservation.js +17 -39
- package/seat-reservation.pure.js +15 -32
- package/svgs-D5DhLHxC.js +26 -0
- package/timetable-duration/timetable-duration.component.js +2 -57
- package/timetable-duration.component-DaYoJUGS.js +65 -0
- package/timetable-duration.js +5 -4
- package/timetable-duration.pure.js +2 -4
- package/timetable-row/timetable-row.component.js +2 -427
- package/timetable-row.component-BDMAEsbR.js +559 -0
- package/timetable-row.js +6 -13
- package/timetable-row.pure.js +2 -11
- package/toDate-p-Tpkb7t.js +16 -0
- package/development/differenceInMinutes-B0dawX-5.js +0 -26
- package/development/format-BMkeaqaF.js +0 -1433
- package/development/isValid-BYRch7pV.js +0 -53
- package/development/toDate-BWb6Z1JD.js +0 -24
- package/differenceInMinutes-COvvdYsJ.js +0 -23
- package/format-CmKROkbc.js +0 -1186
- package/isValid-m3_OsPaB.js +0 -45
- package/toDate-Bw2KTWeq.js +0 -15
|
@@ -0,0 +1,932 @@
|
|
|
1
|
+
import { t as format } from "./format-Bbrn2bgo.js";
|
|
2
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
3
|
+
import { SbbElement } from "@sbb-esta/lyne-elements/core/base-elements.js";
|
|
4
|
+
import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
|
|
5
|
+
import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
|
|
6
|
+
import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
|
|
7
|
+
import "@sbb-esta/lyne-elements/icon.js";
|
|
8
|
+
import { css, html, nothing } from "lit";
|
|
9
|
+
import { setOrRemoveAttribute } from "@sbb-esta/lyne-elements/core/dom.js";
|
|
10
|
+
import { defaultDateAdapter } from "@sbb-esta/lyne-elements/core/datetime.js";
|
|
11
|
+
import { i18nArrival, i18nClass, i18nDeparture, i18nDirection, i18nFromPlatform, i18nMeansOfTransport, i18nNew, i18nOccupancy, i18nRealTimeInfo, i18nSupersaver, i18nTransferProcedure, i18nTransferProcedures, i18nTravelhints, i18nTripDuration, i18nTripQuayChange } from "@sbb-esta/lyne-elements/core/i18n.js";
|
|
12
|
+
import { property } from "lit/decorators.js";
|
|
13
|
+
import { durationToTime, removeTimezoneFromISOTimeString } from "./core/datetime.js";
|
|
14
|
+
import "./pearl-chain-time.js";
|
|
15
|
+
import { getDepartureArrivalTimeAttribute, isRideLeg } from "./core/timetable.js";
|
|
16
|
+
import "@sbb-esta/lyne-elements/card.js";
|
|
17
|
+
import "@sbb-esta/lyne-elements/timetable-occupancy.js";
|
|
18
|
+
//#region src/elements-experimental/timetable-row/timetable-row.scss?lit&inline
|
|
19
|
+
var timetable_row_default = css`:host {
|
|
20
|
+
--sbb-timetable-row-gap: var(--sbb-spacing-fixed-2x);
|
|
21
|
+
--sbb-timetable-row-height: 1.5625rem;
|
|
22
|
+
--sbb-timetable-row-height-header: 1.25rem;
|
|
23
|
+
--sbb-timetable-row-height-footer: 1rem;
|
|
24
|
+
--sbb-timetable-row-skeleton-pulse-duration: 1800ms;
|
|
25
|
+
display: block;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
:host([disable-animation]) {
|
|
29
|
+
--sbb-timetable-row-skeleton-pulse-duration: 0;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.sbb-timetable__row-transport-icon {
|
|
33
|
+
--sbb-icon-svg-width: 1.25rem;
|
|
34
|
+
--sbb-icon-svg-height: 1.25rem;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.sbb-travel-hints__item {
|
|
38
|
+
--sbb-icon-svg-height: 0.875rem;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.sbb-screen-reader-only {
|
|
42
|
+
border: 0;
|
|
43
|
+
clip-path: rect(0 0 0 0);
|
|
44
|
+
height: 1px;
|
|
45
|
+
margin: -1px;
|
|
46
|
+
overflow: hidden;
|
|
47
|
+
padding: 0;
|
|
48
|
+
position: absolute;
|
|
49
|
+
white-space: nowrap;
|
|
50
|
+
width: 1px;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
.sbb-timetable__row--quay {
|
|
54
|
+
margin-inline-end: var(--sbb-spacing-fixed-1x);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.sbb-timetable__row--quay-type {
|
|
58
|
+
float: left;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
ul {
|
|
62
|
+
list-style: none;
|
|
63
|
+
margin: 0;
|
|
64
|
+
padding: 0;
|
|
65
|
+
font-size: inherit;
|
|
66
|
+
display: inline-flex;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
li {
|
|
70
|
+
display: inline-flex;
|
|
71
|
+
align-self: center;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.sbb-timetable__row-transport {
|
|
75
|
+
display: inline-flex;
|
|
76
|
+
align-self: center;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.sbb-timetable__row-transportnumber,
|
|
80
|
+
.sbb-timetable__row-time {
|
|
81
|
+
--sbb-text-font-size: var(--sbb-text-font-size-s);
|
|
82
|
+
font-family: var(--sbb-typo-font-family);
|
|
83
|
+
font-weight: normal;
|
|
84
|
+
line-height: var(--sbb-typo-line-height-text);
|
|
85
|
+
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
86
|
+
font-size: var(--sbb-text-font-size);
|
|
87
|
+
font-weight: bold;
|
|
88
|
+
line-height: unset;
|
|
89
|
+
white-space: nowrap;
|
|
90
|
+
align-self: center;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.sbb-timetable__row {
|
|
94
|
+
--sbb-text-font-size: var(--sbb-text-font-size-s);
|
|
95
|
+
font-family: var(--sbb-typo-font-family);
|
|
96
|
+
font-weight: normal;
|
|
97
|
+
line-height: var(--sbb-typo-line-height-text);
|
|
98
|
+
letter-spacing: var(--sbb-typo-letter-spacing-text);
|
|
99
|
+
font-size: var(--sbb-text-font-size);
|
|
100
|
+
display: flex;
|
|
101
|
+
flex-direction: column;
|
|
102
|
+
gap: var(--sbb-timetable-row-gap);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.sbb-timetable__row-header,
|
|
106
|
+
.sbb-timetable__row-footer {
|
|
107
|
+
animation: none;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.sbb-timetable__row-header {
|
|
111
|
+
display: flex;
|
|
112
|
+
gap: var(--sbb-spacing-fixed-2x);
|
|
113
|
+
align-items: center;
|
|
114
|
+
line-height: var(--sbb-timetable-row-height-header);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
.sbb-timetable__row-details,
|
|
118
|
+
.sbb-timetable__row-hints {
|
|
119
|
+
display: inline-flex;
|
|
120
|
+
gap: var(--sbb-spacing-fixed-1x);
|
|
121
|
+
align-items: center;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
.sbb-timetable__row-header p {
|
|
125
|
+
overflow: hidden;
|
|
126
|
+
white-space: nowrap;
|
|
127
|
+
text-overflow: ellipsis;
|
|
128
|
+
margin: 0;
|
|
129
|
+
align-self: center;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
.sbb-timetable__row-footer {
|
|
133
|
+
display: flex;
|
|
134
|
+
flex-wrap: wrap;
|
|
135
|
+
justify-content: space-between;
|
|
136
|
+
align-items: center;
|
|
137
|
+
gap: var(--sbb-spacing-fixed-2x);
|
|
138
|
+
line-height: var(--sbb-timetable-row-height-footer);
|
|
139
|
+
}
|
|
140
|
+
.sbb-timetable__row-footer > span {
|
|
141
|
+
align-self: center;
|
|
142
|
+
}
|
|
143
|
+
.sbb-timetable__row-footer :only-child {
|
|
144
|
+
margin-inline-start: auto;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
.sbb-timetable__row-quay--changed {
|
|
148
|
+
color: var(--sbb-color-primary);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
.sbb-timetable__row-transport-wrapper,
|
|
152
|
+
.sbb-timetable__row-warning {
|
|
153
|
+
display: inline-flex;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
.sbb-loading {
|
|
157
|
+
pointer-events: none;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
.sbb-loading__wrapper {
|
|
161
|
+
display: flex;
|
|
162
|
+
flex-direction: column;
|
|
163
|
+
gap: var(--sbb-spacing-fixed-2x);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
.sbb-loading__row {
|
|
167
|
+
width: 100%;
|
|
168
|
+
border-radius: var(--sbb-border-radius-1x);
|
|
169
|
+
height: var(--sbb-timetable-row-height);
|
|
170
|
+
}
|
|
171
|
+
@media (min-width: calc(64rem)) {
|
|
172
|
+
.sbb-loading__row {
|
|
173
|
+
height: 1.75rem;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
@media (forced-colors: active) {
|
|
177
|
+
.sbb-loading__row {
|
|
178
|
+
border: var(--sbb-border-width-1x) solid ButtonBorder !important;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.sbb-loading__row,
|
|
183
|
+
.sbb-loading__badge {
|
|
184
|
+
background: var(--sbb-background-color-4);
|
|
185
|
+
animation: skeleton-pulse var(--sbb-timetable-row-skeleton-pulse-duration) ease-out infinite;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
.sbb-loading__row:first-of-type {
|
|
189
|
+
height: var(--sbb-timetable-row-height-header);
|
|
190
|
+
width: 50%;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
.sbb-loading__row:last-of-type {
|
|
194
|
+
height: var(--sbb-timetable-row-height-footer);
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
.sbb-loading__badge {
|
|
198
|
+
margin-inline: auto calc(var(--sbb-spacing-fixed-3x) * -1);
|
|
199
|
+
padding-inline-end: var(--sbb-spacing-fixed-6x);
|
|
200
|
+
border-end-start-radius: var(--sbb-card-badge-border-radius);
|
|
201
|
+
transform: var(--sbb-card-badge-skew);
|
|
202
|
+
width: 7.1875rem;
|
|
203
|
+
height: 1.25rem;
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
@keyframes skeleton-pulse {
|
|
207
|
+
0% {
|
|
208
|
+
background: var(--sbb-background-color-4);
|
|
209
|
+
}
|
|
210
|
+
17% {
|
|
211
|
+
background: var(--sbb-background-color-4);
|
|
212
|
+
}
|
|
213
|
+
50% {
|
|
214
|
+
background: var(--sbb-background-color-3);
|
|
215
|
+
}
|
|
216
|
+
67% {
|
|
217
|
+
background: var(--sbb-background-color-3);
|
|
218
|
+
}
|
|
219
|
+
100% {
|
|
220
|
+
background: var(--sbb-background-color-4);
|
|
221
|
+
}
|
|
222
|
+
}`;
|
|
223
|
+
//#endregion
|
|
224
|
+
//#region src/elements-experimental/timetable-row/timetable-row.component.ts
|
|
225
|
+
var renderIconProduct = (icon, name) => {
|
|
226
|
+
return html`<span class="sbb-timetable__row-transport">
|
|
227
|
+
<sbb-icon name=${icon}></sbb-icon>
|
|
228
|
+
<span class="sbb-screen-reader-only">${name}</span>
|
|
229
|
+
</span>`;
|
|
230
|
+
};
|
|
231
|
+
var renderStringProduct = (vehicleName, line) => {
|
|
232
|
+
const space = [
|
|
233
|
+
"M",
|
|
234
|
+
"B",
|
|
235
|
+
"T"
|
|
236
|
+
].includes(vehicleName) ? " " : "";
|
|
237
|
+
return html`<span class="sbb-timetable__row-transportnumber">
|
|
238
|
+
${line !== null ? vehicleName + space + line : vehicleName}
|
|
239
|
+
</span>`;
|
|
240
|
+
};
|
|
241
|
+
var getReachableText = (legs) => {
|
|
242
|
+
return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.reachableText)?.serviceJourney?.serviceAlteration?.reachableText;
|
|
243
|
+
};
|
|
244
|
+
var getDelayText = (legs) => {
|
|
245
|
+
return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.delayText)?.serviceJourney?.serviceAlteration?.delayText;
|
|
246
|
+
};
|
|
247
|
+
var getRedirectedText = (legs) => {
|
|
248
|
+
return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.redirectedText)?.serviceJourney?.serviceAlteration?.redirectedText;
|
|
249
|
+
};
|
|
250
|
+
var getUnplannedStop = (legs) => {
|
|
251
|
+
return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.unplannedStopPointsText)?.serviceJourney?.serviceAlteration?.unplannedStopPointsText;
|
|
252
|
+
};
|
|
253
|
+
var sortSituation = (situations) => {
|
|
254
|
+
const priorities = {
|
|
255
|
+
DISTURBANCE: 0,
|
|
256
|
+
INFORMATION: 1,
|
|
257
|
+
DELAY: 2,
|
|
258
|
+
TRAIN_REPLACEMENT_BY_BUS: 3,
|
|
259
|
+
CONSTRUCTION_SITE: 4,
|
|
260
|
+
END_MESSAGE: 5
|
|
261
|
+
};
|
|
262
|
+
return [...situations]?.sort((a, b) => priorities[a.cause] - priorities[b.cause]);
|
|
263
|
+
};
|
|
264
|
+
var getHimIcon = (situation) => {
|
|
265
|
+
switch (situation?.cause) {
|
|
266
|
+
case "DISTURBANCE": return {
|
|
267
|
+
name: "disruption",
|
|
268
|
+
text: situation?.broadcastMessages?.length ? situation?.broadcastMessages[0].title : ""
|
|
269
|
+
};
|
|
270
|
+
case "INFORMATION": return {
|
|
271
|
+
name: "info",
|
|
272
|
+
text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : ""
|
|
273
|
+
};
|
|
274
|
+
case "DELAY": return {
|
|
275
|
+
name: "delay",
|
|
276
|
+
text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : ""
|
|
277
|
+
};
|
|
278
|
+
case "TRAIN_REPLACEMENT_BY_BUS": return {
|
|
279
|
+
name: "replacementbus",
|
|
280
|
+
text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : ""
|
|
281
|
+
};
|
|
282
|
+
case "CONSTRUCTION_SITE": return {
|
|
283
|
+
name: "construction",
|
|
284
|
+
text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : ""
|
|
285
|
+
};
|
|
286
|
+
default: return {
|
|
287
|
+
name: "info",
|
|
288
|
+
text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : ""
|
|
289
|
+
};
|
|
290
|
+
}
|
|
291
|
+
};
|
|
292
|
+
var getCus = (trip, currentLanguage) => {
|
|
293
|
+
const { summary, legs } = trip || {};
|
|
294
|
+
const rideLegs = legs?.filter((leg) => isRideLeg(leg));
|
|
295
|
+
const { tripStatus } = summary || {};
|
|
296
|
+
if (tripStatus?.cancelled || tripStatus?.partiallyCancelled) return {
|
|
297
|
+
name: "cancellation",
|
|
298
|
+
text: tripStatus?.cancelledText
|
|
299
|
+
};
|
|
300
|
+
if (getReachableText(rideLegs)) return {
|
|
301
|
+
name: "missed-connection",
|
|
302
|
+
text: getReachableText(rideLegs)
|
|
303
|
+
};
|
|
304
|
+
if (tripStatus?.alternative) return {
|
|
305
|
+
name: "alternative",
|
|
306
|
+
text: tripStatus.alternativeText
|
|
307
|
+
};
|
|
308
|
+
if (getRedirectedText(rideLegs)) return {
|
|
309
|
+
name: "reroute",
|
|
310
|
+
text: getRedirectedText(rideLegs)
|
|
311
|
+
};
|
|
312
|
+
if (getUnplannedStop(rideLegs)) return {
|
|
313
|
+
name: "add-stop",
|
|
314
|
+
text: getUnplannedStop(rideLegs)
|
|
315
|
+
};
|
|
316
|
+
if (tripStatus?.delayed || tripStatus?.delayedUnknown) return {
|
|
317
|
+
name: "delay",
|
|
318
|
+
text: getDelayText(rideLegs)
|
|
319
|
+
};
|
|
320
|
+
if (tripStatus?.quayChanged) {
|
|
321
|
+
const departure = rideLegs[0].departure;
|
|
322
|
+
return {
|
|
323
|
+
name: "platform-change",
|
|
324
|
+
text: departure.quayChanged ? departure.quayChangedText : i18nTripQuayChange[currentLanguage]
|
|
325
|
+
};
|
|
326
|
+
}
|
|
327
|
+
return {};
|
|
328
|
+
};
|
|
329
|
+
var findAndReplaceNotice = (notices) => {
|
|
330
|
+
const reservationNotice = [
|
|
331
|
+
"RR",
|
|
332
|
+
"RK",
|
|
333
|
+
"RC",
|
|
334
|
+
"RL",
|
|
335
|
+
"RM",
|
|
336
|
+
"RS",
|
|
337
|
+
"RU",
|
|
338
|
+
"XP",
|
|
339
|
+
"XR",
|
|
340
|
+
"XT"
|
|
341
|
+
];
|
|
342
|
+
return notices.reduce((foundNotice, notice) => {
|
|
343
|
+
if (foundNotice) return foundNotice;
|
|
344
|
+
if (reservationNotice.includes(notice.name)) return {
|
|
345
|
+
...notice,
|
|
346
|
+
name: "RR"
|
|
347
|
+
};
|
|
348
|
+
}, void 0);
|
|
349
|
+
};
|
|
350
|
+
var filterNotices = (notices) => {
|
|
351
|
+
const allowedNames = [
|
|
352
|
+
"Z",
|
|
353
|
+
"SB",
|
|
354
|
+
"SZ",
|
|
355
|
+
"VR",
|
|
356
|
+
"TG"
|
|
357
|
+
];
|
|
358
|
+
return notices.filter((notice, index) => {
|
|
359
|
+
return notices.findIndex((n) => n.name === notice.name) === index;
|
|
360
|
+
}).filter((notice) => allowedNames.includes(notice.name)).sort((a, b) => allowedNames.indexOf(a.name) - allowedNames.indexOf(b.name));
|
|
361
|
+
};
|
|
362
|
+
var handleNotices = (notices) => {
|
|
363
|
+
const reservationNotice = findAndReplaceNotice(notices);
|
|
364
|
+
const filteredNotices = filterNotices(notices);
|
|
365
|
+
if (reservationNotice === void 0) return filteredNotices;
|
|
366
|
+
if (!filteredNotices.length) return [reservationNotice];
|
|
367
|
+
if (filteredNotices[0].name === "Z" && filteredNotices[1]) return [
|
|
368
|
+
filteredNotices[0],
|
|
369
|
+
reservationNotice,
|
|
370
|
+
filteredNotices[1]
|
|
371
|
+
].concat(filteredNotices.slice(2));
|
|
372
|
+
return [reservationNotice, ...filteredNotices];
|
|
373
|
+
};
|
|
374
|
+
/**
|
|
375
|
+
* It displays information about the trip, acting as a container for all the `sbb-timetable-*` components.
|
|
376
|
+
* */
|
|
377
|
+
var SbbTimetableRowElement = (() => {
|
|
378
|
+
let _classSuper = SbbElement;
|
|
379
|
+
let _instanceExtraInitializers = [];
|
|
380
|
+
let _trip_decorators;
|
|
381
|
+
let _trip_initializers = [];
|
|
382
|
+
let _trip_extraInitializers = [];
|
|
383
|
+
let _price_decorators;
|
|
384
|
+
let _price_initializers = [];
|
|
385
|
+
let _price_extraInitializers = [];
|
|
386
|
+
let _disableAnimation_decorators;
|
|
387
|
+
let _disableAnimation_initializers = [];
|
|
388
|
+
let _disableAnimation_extraInitializers = [];
|
|
389
|
+
let _boarding_decorators;
|
|
390
|
+
let _boarding_initializers = [];
|
|
391
|
+
let _boarding_extraInitializers = [];
|
|
392
|
+
let _loadingTrip_decorators;
|
|
393
|
+
let _loadingTrip_initializers = [];
|
|
394
|
+
let _loadingTrip_extraInitializers = [];
|
|
395
|
+
let _a11yFootpath_decorators;
|
|
396
|
+
let _a11yFootpath_initializers = [];
|
|
397
|
+
let _a11yFootpath_extraInitializers = [];
|
|
398
|
+
let _loadingPrice_decorators;
|
|
399
|
+
let _loadingPrice_initializers = [];
|
|
400
|
+
let _loadingPrice_extraInitializers = [];
|
|
401
|
+
let _cardActionLabel_decorators;
|
|
402
|
+
let _cardActionLabel_initializers = [];
|
|
403
|
+
let _cardActionLabel_extraInitializers = [];
|
|
404
|
+
let _accessibilityExpanded_decorators;
|
|
405
|
+
let _accessibilityExpanded_initializers = [];
|
|
406
|
+
let _accessibilityExpanded_extraInitializers = [];
|
|
407
|
+
let _active_decorators;
|
|
408
|
+
let _active_initializers = [];
|
|
409
|
+
let _active_extraInitializers = [];
|
|
410
|
+
let _set_now_decorators;
|
|
411
|
+
return class SbbTimetableRowElement extends _classSuper {
|
|
412
|
+
constructor() {
|
|
413
|
+
super(...arguments);
|
|
414
|
+
this.#trip_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _trip_initializers, null));
|
|
415
|
+
this.#price_accessor_storage = (__runInitializers(this, _trip_extraInitializers), __runInitializers(this, _price_initializers, null));
|
|
416
|
+
this.#disableAnimation_accessor_storage = (__runInitializers(this, _price_extraInitializers), __runInitializers(this, _disableAnimation_initializers, false));
|
|
417
|
+
this.#boarding_accessor_storage = (__runInitializers(this, _disableAnimation_extraInitializers), __runInitializers(this, _boarding_initializers, null));
|
|
418
|
+
this.#loadingTrip_accessor_storage = (__runInitializers(this, _boarding_extraInitializers), __runInitializers(this, _loadingTrip_initializers, false));
|
|
419
|
+
this.#a11yFootpath_accessor_storage = (__runInitializers(this, _loadingTrip_extraInitializers), __runInitializers(this, _a11yFootpath_initializers, false));
|
|
420
|
+
this.#loadingPrice_accessor_storage = (__runInitializers(this, _a11yFootpath_extraInitializers), __runInitializers(this, _loadingPrice_initializers, false));
|
|
421
|
+
this.#cardActionLabel_accessor_storage = (__runInitializers(this, _loadingPrice_extraInitializers), __runInitializers(this, _cardActionLabel_initializers, ""));
|
|
422
|
+
this.#accessibilityExpanded_accessor_storage = (__runInitializers(this, _cardActionLabel_extraInitializers), __runInitializers(this, _accessibilityExpanded_initializers, false));
|
|
423
|
+
this.#active_accessor_storage = (__runInitializers(this, _accessibilityExpanded_extraInitializers), __runInitializers(this, _active_initializers, false));
|
|
424
|
+
this._now = (__runInitializers(this, _active_extraInitializers), null);
|
|
425
|
+
this._language = new SbbLanguageController(this);
|
|
426
|
+
}
|
|
427
|
+
static {
|
|
428
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
429
|
+
_trip_decorators = [property({ type: Object })];
|
|
430
|
+
_price_decorators = [property({ type: Object })];
|
|
431
|
+
_disableAnimation_decorators = [forceType(), property({
|
|
432
|
+
attribute: "disable-animation",
|
|
433
|
+
reflect: true,
|
|
434
|
+
type: Boolean
|
|
435
|
+
})];
|
|
436
|
+
_boarding_decorators = [property({ type: Object })];
|
|
437
|
+
_loadingTrip_decorators = [forceType(), property({
|
|
438
|
+
attribute: "loading-trip",
|
|
439
|
+
type: Boolean
|
|
440
|
+
})];
|
|
441
|
+
_a11yFootpath_decorators = [forceType(), property({
|
|
442
|
+
attribute: "a11y-footpath",
|
|
443
|
+
type: Boolean
|
|
444
|
+
})];
|
|
445
|
+
_loadingPrice_decorators = [forceType(), property({
|
|
446
|
+
attribute: "loading-price",
|
|
447
|
+
type: Boolean
|
|
448
|
+
})];
|
|
449
|
+
_cardActionLabel_decorators = [forceType(), property({ attribute: "card-action-label" })];
|
|
450
|
+
_accessibilityExpanded_decorators = [forceType(), property({
|
|
451
|
+
attribute: "accessibility-expanded",
|
|
452
|
+
type: Boolean
|
|
453
|
+
})];
|
|
454
|
+
_active_decorators = [forceType(), property({ type: Boolean })];
|
|
455
|
+
_set_now_decorators = [property()];
|
|
456
|
+
__esDecorate(this, null, _trip_decorators, {
|
|
457
|
+
kind: "accessor",
|
|
458
|
+
name: "trip",
|
|
459
|
+
static: false,
|
|
460
|
+
private: false,
|
|
461
|
+
access: {
|
|
462
|
+
has: (obj) => "trip" in obj,
|
|
463
|
+
get: (obj) => obj.trip,
|
|
464
|
+
set: (obj, value) => {
|
|
465
|
+
obj.trip = value;
|
|
466
|
+
}
|
|
467
|
+
},
|
|
468
|
+
metadata: _metadata
|
|
469
|
+
}, _trip_initializers, _trip_extraInitializers);
|
|
470
|
+
__esDecorate(this, null, _price_decorators, {
|
|
471
|
+
kind: "accessor",
|
|
472
|
+
name: "price",
|
|
473
|
+
static: false,
|
|
474
|
+
private: false,
|
|
475
|
+
access: {
|
|
476
|
+
has: (obj) => "price" in obj,
|
|
477
|
+
get: (obj) => obj.price,
|
|
478
|
+
set: (obj, value) => {
|
|
479
|
+
obj.price = value;
|
|
480
|
+
}
|
|
481
|
+
},
|
|
482
|
+
metadata: _metadata
|
|
483
|
+
}, _price_initializers, _price_extraInitializers);
|
|
484
|
+
__esDecorate(this, null, _disableAnimation_decorators, {
|
|
485
|
+
kind: "accessor",
|
|
486
|
+
name: "disableAnimation",
|
|
487
|
+
static: false,
|
|
488
|
+
private: false,
|
|
489
|
+
access: {
|
|
490
|
+
has: (obj) => "disableAnimation" in obj,
|
|
491
|
+
get: (obj) => obj.disableAnimation,
|
|
492
|
+
set: (obj, value) => {
|
|
493
|
+
obj.disableAnimation = value;
|
|
494
|
+
}
|
|
495
|
+
},
|
|
496
|
+
metadata: _metadata
|
|
497
|
+
}, _disableAnimation_initializers, _disableAnimation_extraInitializers);
|
|
498
|
+
__esDecorate(this, null, _boarding_decorators, {
|
|
499
|
+
kind: "accessor",
|
|
500
|
+
name: "boarding",
|
|
501
|
+
static: false,
|
|
502
|
+
private: false,
|
|
503
|
+
access: {
|
|
504
|
+
has: (obj) => "boarding" in obj,
|
|
505
|
+
get: (obj) => obj.boarding,
|
|
506
|
+
set: (obj, value) => {
|
|
507
|
+
obj.boarding = value;
|
|
508
|
+
}
|
|
509
|
+
},
|
|
510
|
+
metadata: _metadata
|
|
511
|
+
}, _boarding_initializers, _boarding_extraInitializers);
|
|
512
|
+
__esDecorate(this, null, _loadingTrip_decorators, {
|
|
513
|
+
kind: "accessor",
|
|
514
|
+
name: "loadingTrip",
|
|
515
|
+
static: false,
|
|
516
|
+
private: false,
|
|
517
|
+
access: {
|
|
518
|
+
has: (obj) => "loadingTrip" in obj,
|
|
519
|
+
get: (obj) => obj.loadingTrip,
|
|
520
|
+
set: (obj, value) => {
|
|
521
|
+
obj.loadingTrip = value;
|
|
522
|
+
}
|
|
523
|
+
},
|
|
524
|
+
metadata: _metadata
|
|
525
|
+
}, _loadingTrip_initializers, _loadingTrip_extraInitializers);
|
|
526
|
+
__esDecorate(this, null, _a11yFootpath_decorators, {
|
|
527
|
+
kind: "accessor",
|
|
528
|
+
name: "a11yFootpath",
|
|
529
|
+
static: false,
|
|
530
|
+
private: false,
|
|
531
|
+
access: {
|
|
532
|
+
has: (obj) => "a11yFootpath" in obj,
|
|
533
|
+
get: (obj) => obj.a11yFootpath,
|
|
534
|
+
set: (obj, value) => {
|
|
535
|
+
obj.a11yFootpath = value;
|
|
536
|
+
}
|
|
537
|
+
},
|
|
538
|
+
metadata: _metadata
|
|
539
|
+
}, _a11yFootpath_initializers, _a11yFootpath_extraInitializers);
|
|
540
|
+
__esDecorate(this, null, _loadingPrice_decorators, {
|
|
541
|
+
kind: "accessor",
|
|
542
|
+
name: "loadingPrice",
|
|
543
|
+
static: false,
|
|
544
|
+
private: false,
|
|
545
|
+
access: {
|
|
546
|
+
has: (obj) => "loadingPrice" in obj,
|
|
547
|
+
get: (obj) => obj.loadingPrice,
|
|
548
|
+
set: (obj, value) => {
|
|
549
|
+
obj.loadingPrice = value;
|
|
550
|
+
}
|
|
551
|
+
},
|
|
552
|
+
metadata: _metadata
|
|
553
|
+
}, _loadingPrice_initializers, _loadingPrice_extraInitializers);
|
|
554
|
+
__esDecorate(this, null, _cardActionLabel_decorators, {
|
|
555
|
+
kind: "accessor",
|
|
556
|
+
name: "cardActionLabel",
|
|
557
|
+
static: false,
|
|
558
|
+
private: false,
|
|
559
|
+
access: {
|
|
560
|
+
has: (obj) => "cardActionLabel" in obj,
|
|
561
|
+
get: (obj) => obj.cardActionLabel,
|
|
562
|
+
set: (obj, value) => {
|
|
563
|
+
obj.cardActionLabel = value;
|
|
564
|
+
}
|
|
565
|
+
},
|
|
566
|
+
metadata: _metadata
|
|
567
|
+
}, _cardActionLabel_initializers, _cardActionLabel_extraInitializers);
|
|
568
|
+
__esDecorate(this, null, _accessibilityExpanded_decorators, {
|
|
569
|
+
kind: "accessor",
|
|
570
|
+
name: "accessibilityExpanded",
|
|
571
|
+
static: false,
|
|
572
|
+
private: false,
|
|
573
|
+
access: {
|
|
574
|
+
has: (obj) => "accessibilityExpanded" in obj,
|
|
575
|
+
get: (obj) => obj.accessibilityExpanded,
|
|
576
|
+
set: (obj, value) => {
|
|
577
|
+
obj.accessibilityExpanded = value;
|
|
578
|
+
}
|
|
579
|
+
},
|
|
580
|
+
metadata: _metadata
|
|
581
|
+
}, _accessibilityExpanded_initializers, _accessibilityExpanded_extraInitializers);
|
|
582
|
+
__esDecorate(this, null, _active_decorators, {
|
|
583
|
+
kind: "accessor",
|
|
584
|
+
name: "active",
|
|
585
|
+
static: false,
|
|
586
|
+
private: false,
|
|
587
|
+
access: {
|
|
588
|
+
has: (obj) => "active" in obj,
|
|
589
|
+
get: (obj) => obj.active,
|
|
590
|
+
set: (obj, value) => {
|
|
591
|
+
obj.active = value;
|
|
592
|
+
}
|
|
593
|
+
},
|
|
594
|
+
metadata: _metadata
|
|
595
|
+
}, _active_initializers, _active_extraInitializers);
|
|
596
|
+
__esDecorate(this, null, _set_now_decorators, {
|
|
597
|
+
kind: "setter",
|
|
598
|
+
name: "now",
|
|
599
|
+
static: false,
|
|
600
|
+
private: false,
|
|
601
|
+
access: {
|
|
602
|
+
has: (obj) => "now" in obj,
|
|
603
|
+
set: (obj, value) => {
|
|
604
|
+
obj.now = value;
|
|
605
|
+
}
|
|
606
|
+
},
|
|
607
|
+
metadata: _metadata
|
|
608
|
+
}, null, _instanceExtraInitializers);
|
|
609
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
610
|
+
enumerable: true,
|
|
611
|
+
configurable: true,
|
|
612
|
+
writable: true,
|
|
613
|
+
value: _metadata
|
|
614
|
+
});
|
|
615
|
+
}
|
|
616
|
+
static {
|
|
617
|
+
this.elementName = "sbb-timetable-row";
|
|
618
|
+
}
|
|
619
|
+
static {
|
|
620
|
+
this.styles = [boxSizingStyles, timetable_row_default];
|
|
621
|
+
}
|
|
622
|
+
#trip_accessor_storage;
|
|
623
|
+
/** The trip Prop. */
|
|
624
|
+
get trip() {
|
|
625
|
+
return this.#trip_accessor_storage;
|
|
626
|
+
}
|
|
627
|
+
set trip(value) {
|
|
628
|
+
this.#trip_accessor_storage = value;
|
|
629
|
+
}
|
|
630
|
+
#price_accessor_storage;
|
|
631
|
+
/** The price Prop, which consists of the data for the badge. */
|
|
632
|
+
get price() {
|
|
633
|
+
return this.#price_accessor_storage;
|
|
634
|
+
}
|
|
635
|
+
set price(value) {
|
|
636
|
+
this.#price_accessor_storage = value;
|
|
637
|
+
}
|
|
638
|
+
#disableAnimation_accessor_storage;
|
|
639
|
+
/** This will be forwarded to the sbb-pearl-chain component - if true the position won't be animated. */
|
|
640
|
+
get disableAnimation() {
|
|
641
|
+
return this.#disableAnimation_accessor_storage;
|
|
642
|
+
}
|
|
643
|
+
set disableAnimation(value) {
|
|
644
|
+
this.#disableAnimation_accessor_storage = value;
|
|
645
|
+
}
|
|
646
|
+
#boarding_accessor_storage;
|
|
647
|
+
/** This will be forwarded to the notices section */
|
|
648
|
+
get boarding() {
|
|
649
|
+
return this.#boarding_accessor_storage;
|
|
650
|
+
}
|
|
651
|
+
set boarding(value) {
|
|
652
|
+
this.#boarding_accessor_storage = value;
|
|
653
|
+
}
|
|
654
|
+
#loadingTrip_accessor_storage;
|
|
655
|
+
/**
|
|
656
|
+
* The loading state -
|
|
657
|
+
* when this is true it will be render skeleton with an idling animation
|
|
658
|
+
*/
|
|
659
|
+
get loadingTrip() {
|
|
660
|
+
return this.#loadingTrip_accessor_storage;
|
|
661
|
+
}
|
|
662
|
+
set loadingTrip(value) {
|
|
663
|
+
this.#loadingTrip_accessor_storage = value;
|
|
664
|
+
}
|
|
665
|
+
#a11yFootpath_accessor_storage;
|
|
666
|
+
/**
|
|
667
|
+
* The Footpath attribute for rendering different icons
|
|
668
|
+
* true: render a11y-icon
|
|
669
|
+
* false: render walk-icon
|
|
670
|
+
* default: render walk-icon
|
|
671
|
+
*/
|
|
672
|
+
get a11yFootpath() {
|
|
673
|
+
return this.#a11yFootpath_accessor_storage;
|
|
674
|
+
}
|
|
675
|
+
set a11yFootpath(value) {
|
|
676
|
+
this.#a11yFootpath_accessor_storage = value;
|
|
677
|
+
}
|
|
678
|
+
#loadingPrice_accessor_storage;
|
|
679
|
+
/**
|
|
680
|
+
* The loading state -
|
|
681
|
+
* when this is true it will be render skeleton with an idling animation
|
|
682
|
+
*/
|
|
683
|
+
get loadingPrice() {
|
|
684
|
+
return this.#loadingPrice_accessor_storage;
|
|
685
|
+
}
|
|
686
|
+
set loadingPrice(value) {
|
|
687
|
+
this.#loadingPrice_accessor_storage = value;
|
|
688
|
+
}
|
|
689
|
+
#cardActionLabel_accessor_storage;
|
|
690
|
+
/**
|
|
691
|
+
* Hidden label for the card action. It overrides the automatically generated accessibility text for the component. Use this prop to provide custom accessibility information for the component.
|
|
692
|
+
*/
|
|
693
|
+
get cardActionLabel() {
|
|
694
|
+
return this.#cardActionLabel_accessor_storage;
|
|
695
|
+
}
|
|
696
|
+
set cardActionLabel(value) {
|
|
697
|
+
this.#cardActionLabel_accessor_storage = value;
|
|
698
|
+
}
|
|
699
|
+
#accessibilityExpanded_accessor_storage;
|
|
700
|
+
/** This will be forwarded to the sbb-card component as aria-expanded. */
|
|
701
|
+
get accessibilityExpanded() {
|
|
702
|
+
return this.#accessibilityExpanded_accessor_storage;
|
|
703
|
+
}
|
|
704
|
+
set accessibilityExpanded(value) {
|
|
705
|
+
this.#accessibilityExpanded_accessor_storage = value;
|
|
706
|
+
}
|
|
707
|
+
#active_accessor_storage;
|
|
708
|
+
/** When this prop is true the sbb-card will be in the active state. */
|
|
709
|
+
get active() {
|
|
710
|
+
return this.#active_accessor_storage;
|
|
711
|
+
}
|
|
712
|
+
set active(value) {
|
|
713
|
+
this.#active_accessor_storage = value;
|
|
714
|
+
}
|
|
715
|
+
/**
|
|
716
|
+
* A configured date which acts as the current date instead of the real current date.
|
|
717
|
+
* Only recommended for testing purposes.
|
|
718
|
+
*/
|
|
719
|
+
set now(value) {
|
|
720
|
+
this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));
|
|
721
|
+
}
|
|
722
|
+
get now() {
|
|
723
|
+
return this._now ?? /* @__PURE__ */ new Date();
|
|
724
|
+
}
|
|
725
|
+
willUpdate(changedProperties) {
|
|
726
|
+
super.willUpdate(changedProperties);
|
|
727
|
+
if (changedProperties.has("loadingTrip")) setOrRemoveAttribute(this, "role", !this.loadingTrip ? "rowgroup" : null);
|
|
728
|
+
}
|
|
729
|
+
/** The skeleton render function for the loading state */
|
|
730
|
+
_renderSkeleton() {
|
|
731
|
+
return html`
|
|
732
|
+
<sbb-card class="sbb-loading sbb-card-spacing-4x-xxs">
|
|
733
|
+
${this.loadingPrice ? html`<div class="sbb-loading__badge" slot="badge"></div>` : nothing}
|
|
734
|
+
<div class="sbb-loading__wrapper">
|
|
735
|
+
<div class="sbb-loading__row"></div>
|
|
736
|
+
<div class="sbb-loading__row"></div>
|
|
737
|
+
<div class="sbb-loading__row"></div>
|
|
738
|
+
</div>
|
|
739
|
+
</sbb-card>
|
|
740
|
+
`;
|
|
741
|
+
}
|
|
742
|
+
_getRideLegs() {
|
|
743
|
+
return this.trip?.legs?.filter((leg) => isRideLeg(leg)) ?? [];
|
|
744
|
+
}
|
|
745
|
+
_getQuayTypeStrings() {
|
|
746
|
+
if (!this.trip.summary?.product) return null;
|
|
747
|
+
const rideLegs = this._getRideLegs();
|
|
748
|
+
const short = this.trip.summary.product?.vehicleMode === "TRAIN" ? rideLegs[0].serviceJourney.quayTypeShortName || "" : rideLegs[0].serviceJourney.quayTypeName || "";
|
|
749
|
+
return {
|
|
750
|
+
long: i18nFromPlatform[this._language.current] + " " + short,
|
|
751
|
+
short
|
|
752
|
+
};
|
|
753
|
+
}
|
|
754
|
+
/** map Quay */
|
|
755
|
+
_renderQuayType() {
|
|
756
|
+
if (!this.trip.summary?.product) return void 0;
|
|
757
|
+
const quayTypeStrings = this._getQuayTypeStrings();
|
|
758
|
+
return html`
|
|
759
|
+
<span class="sbb-timetable__row--quay">
|
|
760
|
+
<span class="sbb-screen-reader-only">${quayTypeStrings?.long} </span>
|
|
761
|
+
<span class="sbb-timetable__row--quay-type" aria-hidden="true"
|
|
762
|
+
>${quayTypeStrings?.short}</span
|
|
763
|
+
>
|
|
764
|
+
</span>
|
|
765
|
+
`;
|
|
766
|
+
}
|
|
767
|
+
_handleHimCus(trip) {
|
|
768
|
+
const { situations } = trip || {};
|
|
769
|
+
const sortedSituations = situations && sortSituation(situations);
|
|
770
|
+
const cus = getCus(trip, this._language.current);
|
|
771
|
+
return {
|
|
772
|
+
cus: Object.keys(cus)?.length ? cus : null,
|
|
773
|
+
him: situations?.length ? getHimIcon(sortedSituations[0]) : null
|
|
774
|
+
};
|
|
775
|
+
}
|
|
776
|
+
_getAccessibilityText(trip) {
|
|
777
|
+
const { summary, legs, notices } = trip || {};
|
|
778
|
+
const { departureWalk, arrivalWalk, departure, arrival, product, direction, occupancy, duration } = summary || {};
|
|
779
|
+
const { departureTimeAttribute, arrivalTimeAttribute } = getDepartureArrivalTimeAttribute(legs, departureWalk || 0, arrivalWalk || 0, this._language.current, this.a11yFootpath);
|
|
780
|
+
const rideLegs = this._getRideLegs();
|
|
781
|
+
const departureTime = departure?.time ? removeTimezoneFromISOTimeString(departure.time) : void 0;
|
|
782
|
+
const arrivalTime = arrival?.time ? removeTimezoneFromISOTimeString(arrival.time) : void 0;
|
|
783
|
+
const departureWalkText = departureTimeAttribute ? `${departureTimeAttribute.text} ${departureTimeAttribute.duration}, ` : "";
|
|
784
|
+
const arrivalWalkText = arrivalTimeAttribute ? `${arrivalTimeAttribute.text} ${arrivalTimeAttribute.duration}, ` : "";
|
|
785
|
+
const departureTimeText = departureTime ? `${i18nDeparture[this._language.current]}: ${format(departureTime, "HH:mm")}, ` : "";
|
|
786
|
+
const getDepartureQuayText = () => {
|
|
787
|
+
if (!departure?.quayFormatted) return "";
|
|
788
|
+
return `${departure?.quayChanged ? `${i18nNew[this._language.current]} ` : ""}${this._getQuayTypeStrings()?.long} ${departure?.quayFormatted}, `;
|
|
789
|
+
};
|
|
790
|
+
const meansOfTransportText = product && product.vehicleMode ? i18nMeansOfTransport[product.vehicleMode.toLowerCase()] && `${i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}, ` : "";
|
|
791
|
+
const vehicleSubModeText = product?.vehicleSubModeShortName ? `${product.vehicleSubModeShortName} ${product.line || ""}, ` : "";
|
|
792
|
+
const directionText = `${i18nDirection[this._language.current]} ${direction}, `;
|
|
793
|
+
const himCus = this._handleHimCus(trip);
|
|
794
|
+
const cusText = himCus?.cus?.text ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.cus?.text}, ` : "";
|
|
795
|
+
const himText = himCus?.him?.text ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.him?.text}, ` : "";
|
|
796
|
+
const boardingText = this.boarding ? `${this.boarding.text}, ` : "";
|
|
797
|
+
const priceText = `${this.price?.isDiscount ? i18nSupersaver[this._language.current] : ""} ${this.price?.text && this.price?.price ? (this.price?.text || "") + " " + (this.price?.price || "") + ", " : ""}`;
|
|
798
|
+
const transferProcedures = rideLegs.length > 2 ? `${rideLegs.length - 1} ${i18nTransferProcedures[this._language.current]}, ` : rideLegs.length > 1 ? `${rideLegs.length - 1} ${i18nTransferProcedure[this._language.current]}, ` : "";
|
|
799
|
+
const arrivalTimeText = arrivalTime ? `${i18nArrival[this._language.current]}: ${format(arrivalTime, "HH:mm")}, ` : "";
|
|
800
|
+
let occupancyText = "";
|
|
801
|
+
if (occupancy) {
|
|
802
|
+
if (occupancy.firstClass && occupancy.firstClass !== "UNKNOWN") occupancyText += `${i18nClass.first[this._language.current]} ${i18nOccupancy[occupancy.firstClass.toLowerCase()]?.[this._language.current]}.`;
|
|
803
|
+
if (occupancy.secondClass && occupancy.secondClass !== "UNKNOWN") occupancyText += ` ${i18nClass.second[this._language.current]} ${i18nOccupancy[occupancy.secondClass.toLowerCase()]?.[this._language.current]}.`;
|
|
804
|
+
}
|
|
805
|
+
const attributes = notices && handleNotices(notices).length && handleNotices(notices)?.map((notice, index) => index < 4 && notice.text?.template).join(", ") + ", ";
|
|
806
|
+
const attributesText = attributes ? `${i18nTravelhints[this._language.current]}: ${attributes}` : "";
|
|
807
|
+
const durationText = !!duration && duration > 0 ? `${i18nTripDuration[this._language.current]} ${durationToTime(duration, this._language.current).long}, ` : "";
|
|
808
|
+
return [
|
|
809
|
+
departureWalkText,
|
|
810
|
+
departureTimeText,
|
|
811
|
+
getDepartureQuayText(),
|
|
812
|
+
meansOfTransportText,
|
|
813
|
+
vehicleSubModeText,
|
|
814
|
+
directionText,
|
|
815
|
+
cusText,
|
|
816
|
+
boardingText,
|
|
817
|
+
priceText,
|
|
818
|
+
cusText ? "" : himText,
|
|
819
|
+
arrivalTimeText,
|
|
820
|
+
arrivalWalkText,
|
|
821
|
+
durationText,
|
|
822
|
+
transferProcedures,
|
|
823
|
+
occupancyText,
|
|
824
|
+
attributesText
|
|
825
|
+
].map((e) => e?.trim()).filter((e) => e && e.length > 0).join(" ");
|
|
826
|
+
}
|
|
827
|
+
render() {
|
|
828
|
+
if (this.loadingTrip) return this._renderSkeleton();
|
|
829
|
+
const { legs, id, notices, summary } = this.trip || {};
|
|
830
|
+
const { product, direction, departureWalk, departure, arrival, arrivalWalk, occupancy, duration } = summary || {};
|
|
831
|
+
const himCus = this._handleHimCus(this.trip);
|
|
832
|
+
const hasHimCus = !!himCus.cus || !!himCus.him;
|
|
833
|
+
const noticeAttributes = notices && handleNotices(notices);
|
|
834
|
+
const durationObj = duration ? durationToTime(duration, this._language.current) : null;
|
|
835
|
+
return html`
|
|
836
|
+
<sbb-card class="sbb-card-spacing-4x-xxs" id=${id}>
|
|
837
|
+
<sbb-card-button
|
|
838
|
+
?active=${this.active}
|
|
839
|
+
aria-expanded=${this.accessibilityExpanded ? "true" : nothing}
|
|
840
|
+
>
|
|
841
|
+
${this.cardActionLabel ? this.cardActionLabel : this._getAccessibilityText(this.trip)}
|
|
842
|
+
</sbb-card-button>
|
|
843
|
+
${this.loadingPrice ? html`<div class="sbb-loading__badge" slot="badge"></div>` : nothing}
|
|
844
|
+
${this.price && !this.loadingPrice ? html`<sbb-card-badge color=${this.price.isDiscount ? "charcoal" : "white"}>
|
|
845
|
+
${this.price.isDiscount ? html`<span aria-hidden="true">
|
|
846
|
+
%<span class="sbb-screen-reader-only"
|
|
847
|
+
>${i18nSupersaver[this._language.current]}</span
|
|
848
|
+
>
|
|
849
|
+
</span>` : nothing}
|
|
850
|
+
${this.price.text ? html`<span>${this.price.text}</span>` : nothing}
|
|
851
|
+
${this.price.price ? html`<span>${this.price.price}</span>` : nothing}
|
|
852
|
+
</sbb-card-badge>` : nothing}
|
|
853
|
+
<div class="sbb-timetable__row" role="row">
|
|
854
|
+
<div class="sbb-timetable__row-header" role="gridcell">
|
|
855
|
+
<div class="sbb-timetable__row-details">
|
|
856
|
+
${product?.corporateIdentityPictogram && html`<span class="sbb-timetable__row-transport-wrapper">
|
|
857
|
+
<sbb-icon
|
|
858
|
+
class="sbb-timetable__row-transport-icon"
|
|
859
|
+
name="picto:${product.corporateIdentityPictogram}"
|
|
860
|
+
></sbb-icon>
|
|
861
|
+
<span class="sbb-screen-reader-only">
|
|
862
|
+
${product && product.vehicleMode && i18nMeansOfTransport[product.vehicleMode.toLowerCase()] && i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}
|
|
863
|
+
|
|
864
|
+
</span>
|
|
865
|
+
</span>`}
|
|
866
|
+
${product && (product.corporateIdentityIcon ? renderIconProduct(product.corporateIdentityIcon, product.name) : product.vehicleSubModeShortName && renderStringProduct(product.vehicleSubModeShortName, product?.line))}
|
|
867
|
+
</div>
|
|
868
|
+
${direction ? html`<p>${`${i18nDirection[this._language.current]} ${direction}`}</p>` : nothing}
|
|
869
|
+
</div>
|
|
870
|
+
<sbb-pearl-chain-time
|
|
871
|
+
role="gridcell"
|
|
872
|
+
.legs=${legs}
|
|
873
|
+
.departureTime=${departure?.time}
|
|
874
|
+
.arrivalTime=${arrival?.time}
|
|
875
|
+
.departureWalk=${departureWalk}
|
|
876
|
+
.arrivalWalk=${arrivalWalk}
|
|
877
|
+
?disable-animation=${this.disableAnimation}
|
|
878
|
+
?a11y-footpath=${this.a11yFootpath}
|
|
879
|
+
.now=${this.now}
|
|
880
|
+
></sbb-pearl-chain-time>
|
|
881
|
+
<div class="sbb-timetable__row-footer" role="gridcell">
|
|
882
|
+
${product && departure?.quayFormatted ? html`<span
|
|
883
|
+
class=${departure?.quayChanged ? `sbb-timetable__row-quay--changed` : nothing}
|
|
884
|
+
>
|
|
885
|
+
<span class="sbb-screen-reader-only">
|
|
886
|
+
${`${i18nDeparture[this._language.current]} ${departure?.quayChanged ? i18nNew[this._language.current] : ""}`}
|
|
887
|
+
|
|
888
|
+
</span>
|
|
889
|
+
${this._renderQuayType()} ${departure?.quayFormatted}
|
|
890
|
+
</span>` : nothing}
|
|
891
|
+
${occupancy?.firstClass && occupancy?.firstClass !== "UNKNOWN" || occupancy?.secondClass && occupancy.secondClass !== "UNKNOWN" ? html`<sbb-timetable-occupancy
|
|
892
|
+
.firstClassOccupancy=${occupancy?.firstClass?.toLowerCase()}
|
|
893
|
+
.secondClassOccupancy=${occupancy?.secondClass?.toLowerCase()}
|
|
894
|
+
></sbb-timetable-occupancy>` : nothing}
|
|
895
|
+
${noticeAttributes && noticeAttributes.length || this.boarding ? html`<ul class="sbb-timetable__row-hints" role="list">
|
|
896
|
+
${noticeAttributes?.map((notice, index) => index < 4 ? html`<li>
|
|
897
|
+
<sbb-icon
|
|
898
|
+
class="sbb-travel-hints__item"
|
|
899
|
+
name=${"sa-" + notice.name?.toLowerCase()}
|
|
900
|
+
></sbb-icon>
|
|
901
|
+
<span class="sbb-screen-reader-only">${notice.text?.template}</span>
|
|
902
|
+
</li>` : nothing)}
|
|
903
|
+
${this.boarding ? html`<li>
|
|
904
|
+
<sbb-icon
|
|
905
|
+
class="sbb-travel-hints__item"
|
|
906
|
+
name=${this.boarding?.name}
|
|
907
|
+
aria-label=${this.boarding?.text}
|
|
908
|
+
aria-hidden="false"
|
|
909
|
+
></sbb-icon>
|
|
910
|
+
</li>` : nothing}
|
|
911
|
+
</ul>` : nothing}
|
|
912
|
+
${duration && duration > 0 ? html`<time>
|
|
913
|
+
<span class="sbb-screen-reader-only">
|
|
914
|
+
${`${i18nTripDuration[this._language.current]} ${durationObj.long}`}
|
|
915
|
+
</span>
|
|
916
|
+
<span aria-hidden="true">${durationObj.short}</span>
|
|
917
|
+
</time>` : nothing}
|
|
918
|
+
${hasHimCus && (himCus.cus || himCus.him) ? html`<span class="sbb-timetable__row-warning">
|
|
919
|
+
<sbb-icon name=${(himCus.cus || himCus.him).name}></sbb-icon>
|
|
920
|
+
<span class="sbb-screen-reader-only">${(himCus.cus || himCus.him).text}</span>
|
|
921
|
+
</span>` : nothing}
|
|
922
|
+
</div>
|
|
923
|
+
</div>
|
|
924
|
+
</sbb-card>
|
|
925
|
+
`;
|
|
926
|
+
}
|
|
927
|
+
};
|
|
928
|
+
})();
|
|
929
|
+
//#endregion
|
|
930
|
+
export { handleNotices as a, sortSituation as c, getHimIcon as i, filterNotices as n, renderIconProduct as o, getCus as r, renderStringProduct as s, SbbTimetableRowElement as t };
|
|
931
|
+
|
|
932
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"timetable-row.component-Y5w8vEwP.js","names":[],"sources":["../../../src/elements-experimental/timetable-row/timetable-row.scss?lit&inline","../../../src/elements-experimental/timetable-row/timetable-row.component.ts"],"sourcesContent":["@use '@sbb-esta/lyne-elements/core/styles' as sbb;\n\n:host {\n  --sbb-timetable-row-gap: var(--sbb-spacing-fixed-2x);\n  --sbb-timetable-row-height: #{sbb.px-to-rem-build(25)};\n  --sbb-timetable-row-height-header: #{sbb.px-to-rem-build(20)};\n  --sbb-timetable-row-height-footer: #{sbb.px-to-rem-build(16)};\n  --sbb-timetable-row-skeleton-pulse-duration: 1800ms;\n\n  display: block;\n}\n\n:host([disable-animation]) {\n  --sbb-timetable-row-skeleton-pulse-duration: 0;\n}\n\n// override icons sizes\n.sbb-timetable__row-transport-icon {\n  --sbb-icon-svg-width: #{sbb.px-to-rem-build(20)};\n  --sbb-icon-svg-height: #{sbb.px-to-rem-build(20)};\n}\n\n// override icons sizes\n.sbb-travel-hints__item {\n  --sbb-icon-svg-height: #{sbb.px-to-rem-build(14)};\n}\n\n.sbb-screen-reader-only {\n  @include sbb.screen-reader-only;\n}\n\n.sbb-timetable__row--quay {\n  margin-inline-end: var(--sbb-spacing-fixed-1x);\n}\n\n.sbb-timetable__row--quay-type {\n  float: left;\n}\n\n// resets lists\nul {\n  @include sbb.list-reset;\n\n  display: inline-flex;\n}\n\nli {\n  display: inline-flex;\n  align-self: center;\n}\n\n.sbb-timetable__row-transport {\n  display: inline-flex;\n  align-self: center;\n}\n\n.sbb-timetable__row-transportnumber,\n.sbb-timetable__row-time {\n  @include sbb.text-s--bold;\n\n  line-height: unset;\n  white-space: nowrap;\n  align-self: center;\n}\n\n.sbb-timetable__row {\n  @include sbb.text-s--regular;\n\n  display: flex;\n  flex-direction: column;\n  gap: var(--sbb-timetable-row-gap);\n}\n\n.sbb-timetable__row-header,\n.sbb-timetable__row-footer {\n  // Due to a bug in Safari which displays skeleton animation even on loaded content, we need to manually disable animation.\n  animation: none;\n}\n\n.sbb-timetable__row-header {\n  display: flex;\n  gap: var(--sbb-spacing-fixed-2x);\n  align-items: center;\n  line-height: var(--sbb-timetable-row-height-header);\n}\n\n.sbb-timetable__row-details,\n.sbb-timetable__row-hints {\n  display: inline-flex;\n  gap: var(--sbb-spacing-fixed-1x);\n  align-items: center;\n}\n\n.sbb-timetable__row-header p {\n  @include sbb.ellipsis;\n\n  margin: 0;\n  align-self: center;\n}\n\n.sbb-timetable__row-footer {\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: space-between;\n  align-items: center;\n  gap: var(--sbb-spacing-fixed-2x);\n  line-height: var(--sbb-timetable-row-height-footer);\n\n  > span {\n    align-self: center;\n  }\n\n  :only-child {\n    margin-inline-start: auto;\n  }\n}\n\n.sbb-timetable__row-quay--changed {\n  color: var(--sbb-color-primary);\n}\n\n.sbb-timetable__row-transport-wrapper,\n.sbb-timetable__row-warning {\n  display: inline-flex;\n}\n\n.sbb-loading {\n  pointer-events: none;\n}\n\n.sbb-loading__wrapper {\n  display: flex;\n  flex-direction: column;\n  gap: var(--sbb-spacing-fixed-2x);\n}\n\n.sbb-loading__row {\n  width: 100%;\n  border-radius: var(--sbb-border-radius-1x);\n  height: var(--sbb-timetable-row-height);\n\n  @include sbb.mq($from: large) {\n    height: #{sbb.px-to-rem-build(28)};\n  }\n\n  @include sbb.if-forced-colors {\n    border: var(--sbb-border-width-1x) solid ButtonBorder !important;\n  }\n}\n\n.sbb-loading__row,\n.sbb-loading__badge {\n  background: var(--sbb-background-color-4);\n  animation: skeleton-pulse var(--sbb-timetable-row-skeleton-pulse-duration) ease-out infinite;\n}\n\n.sbb-loading__row:first-of-type {\n  height: var(--sbb-timetable-row-height-header);\n  width: 50%;\n}\n\n.sbb-loading__row:last-of-type {\n  height: var(--sbb-timetable-row-height-footer);\n}\n\n.sbb-loading__badge {\n  margin-inline: auto calc(var(--sbb-spacing-fixed-3x) * -1);\n  padding-inline-end: var(--sbb-spacing-fixed-6x);\n  border-end-start-radius: var(--sbb-card-badge-border-radius);\n  transform: var(--sbb-card-badge-skew);\n  width: #{sbb.px-to-rem-build(115)};\n  height: #{sbb.px-to-rem-build(20)};\n}\n\n@keyframes skeleton-pulse {\n  0% {\n    background: var(--sbb-background-color-4);\n  }\n\n  17% {\n    background: var(--sbb-background-color-4);\n  }\n\n  50% {\n    background: var(--sbb-background-color-3);\n  }\n\n  67% {\n    background: var(--sbb-background-color-3);\n  }\n\n  100% {\n    background: var(--sbb-background-color-4);\n  }\n}\n","import { SbbElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { defaultDateAdapter } from '@sbb-esta/lyne-elements/core/datetime.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { setOrRemoveAttribute } from '@sbb-esta/lyne-elements/core/dom.js';\nimport {\n  i18nArrival,\n  i18nClass,\n  i18nDeparture,\n  i18nDirection,\n  i18nFromPlatform,\n  i18nMeansOfTransport,\n  i18nNew,\n  i18nOccupancy,\n  i18nRealTimeInfo,\n  i18nSupersaver,\n  i18nTransferProcedure,\n  i18nTransferProcedures,\n  i18nTravelhints,\n  i18nTripDuration,\n  i18nTripQuayChange,\n} from '@sbb-esta/lyne-elements/core/i18n.js';\nimport type { SbbOccupancy } from '@sbb-esta/lyne-elements/core/interfaces.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { format } from 'date-fns';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { durationToTime, removeTimezoneFromISOTimeString } from '../core/datetime.ts';\nimport type { ITripItem, Notice, PtRideLeg, PtSituation } from '../core/timetable.ts';\nimport { getDepartureArrivalTimeAttribute, isRideLeg } from '../core/timetable.ts';\n\nimport style from './timetable-row.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/card.js';\nimport '@sbb-esta/lyne-elements/icon.js';\nimport '@sbb-esta/lyne-elements/timetable-occupancy.js';\nimport '../pearl-chain-time.ts';\n\n/** HimCus interface for mapped icon name and text */\nexport interface HimCus {\n  name: string;\n  text?: string | null;\n}\n\n/** Boarding icon interface for mapped icon name and text */\nexport interface Boarding {\n  name: string;\n  text: string;\n}\n\nexport interface Price {\n  price?: string;\n  text?: string;\n  isDiscount?: boolean;\n}\n\nexport const renderIconProduct = (icon: string, name: string): TemplateResult => {\n  return html`<span class=\"sbb-timetable__row-transport\">\n    <sbb-icon name=${icon}></sbb-icon>\n    <span class=\"sbb-screen-reader-only\">${name}</span>\n  </span>`;\n};\n\nexport const renderStringProduct = (vehicleName: string, line?: string | null): TemplateResult => {\n  const space = ['M', 'B', 'T'].includes(vehicleName) ? ' ' : '';\n  return html`<span class=\"sbb-timetable__row-transportnumber\">\n    ${line !== null ? vehicleName + space + line : vehicleName}\n  </span>`;\n};\n\nconst getReachableText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.reachableText)?.serviceJourney\n    ?.serviceAlteration?.reachableText;\n};\n\nconst getDelayText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => leg.serviceJourney?.serviceAlteration?.delayText)?.serviceJourney\n    ?.serviceAlteration?.delayText;\n};\n\nconst getRedirectedText = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.redirectedText)\n    ?.serviceJourney?.serviceAlteration?.redirectedText;\n};\n\nconst getUnplannedStop = (legs: PtRideLeg[]): string | null | undefined => {\n  return legs?.find((leg) => !!leg.serviceJourney?.serviceAlteration?.unplannedStopPointsText)\n    ?.serviceJourney?.serviceAlteration?.unplannedStopPointsText;\n};\n\nexport const sortSituation = (situations: PtSituation[]): PtSituation[] => {\n  const priorities = {\n    DISTURBANCE: 0,\n    INFORMATION: 1,\n    DELAY: 2,\n    TRAIN_REPLACEMENT_BY_BUS: 3,\n    CONSTRUCTION_SITE: 4,\n    END_MESSAGE: 5,\n  };\n\n  return [...situations]?.sort(\n    (a: PtSituation, b: PtSituation) => priorities[a.cause!] - priorities[b.cause!],\n  );\n};\n\nexport const getHimIcon = (situation: PtSituation): HimCus => {\n  switch (situation?.cause) {\n    case 'DISTURBANCE':\n      return {\n        name: 'disruption',\n        text: situation?.broadcastMessages?.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'INFORMATION':\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'DELAY':\n      return {\n        name: 'delay',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'TRAIN_REPLACEMENT_BY_BUS':\n      return {\n        name: 'replacementbus',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    case 'CONSTRUCTION_SITE':\n      return {\n        name: 'construction',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n    default:\n      return {\n        name: 'info',\n        text: situation?.broadcastMessages.length ? situation?.broadcastMessages[0].title : '',\n      };\n  }\n};\n\nexport const getCus = (trip: ITripItem, currentLanguage: string): HimCus => {\n  const { summary, legs } = trip || {};\n  const rideLegs = legs?.filter((leg) => isRideLeg(leg)) as PtRideLeg[];\n  const { tripStatus } = summary || {};\n\n  if (tripStatus?.cancelled || tripStatus?.partiallyCancelled)\n    return { name: 'cancellation', text: tripStatus?.cancelledText };\n  if (getReachableText(rideLegs))\n    return { name: 'missed-connection', text: getReachableText(rideLegs) };\n  if (tripStatus?.alternative) return { name: 'alternative', text: tripStatus.alternativeText };\n  if (getRedirectedText(rideLegs)) return { name: 'reroute', text: getRedirectedText(rideLegs) };\n  if (getUnplannedStop(rideLegs)) return { name: 'add-stop', text: getUnplannedStop(rideLegs) };\n  if (tripStatus?.delayed || tripStatus?.delayedUnknown)\n    return { name: 'delay', text: getDelayText(rideLegs) };\n  if (tripStatus?.quayChanged) {\n    const departure = rideLegs[0].departure;\n    return {\n      name: 'platform-change',\n      text: departure.quayChanged ? departure.quayChangedText : i18nTripQuayChange[currentLanguage],\n    };\n  }\n\n  return {} as HimCus;\n};\n\nconst findAndReplaceNotice = (notices: Notice[]): Notice | undefined => {\n  const reservationNotice = ['RR', 'RK', 'RC', 'RL', 'RM', 'RS', 'RU', 'XP', 'XR', 'XT'];\n\n  return notices.reduce((foundNotice: Notice | undefined, notice: Notice): Notice | undefined => {\n    if (foundNotice) return foundNotice;\n    if (reservationNotice.includes(notice.name)) {\n      return { ...notice, name: 'RR' } as Notice;\n    }\n  }, undefined);\n};\n\nexport const filterNotices = (notices: Notice[]): Notice[] => {\n  const allowedNames = ['Z', 'SB', 'SZ', 'VR', 'TG'];\n\n  const filterNotice = notices.filter((notice, index) => {\n    return notices.findIndex((n) => n.name === notice.name) === index;\n  });\n\n  return filterNotice\n    .filter((notice) => allowedNames.includes(notice.name))\n    .sort((a, b) => allowedNames.indexOf(a.name) - allowedNames.indexOf(b.name));\n};\n\nexport const handleNotices = (notices: Notice[]): Notice[] => {\n  const reservationNotice = findAndReplaceNotice(notices);\n  const filteredNotices = filterNotices(notices);\n\n  if (reservationNotice === undefined) return filteredNotices;\n  if (!filteredNotices.length) return [reservationNotice];\n\n  if (filteredNotices[0].name === 'Z' && filteredNotices[1]) {\n    return [filteredNotices[0], reservationNotice, filteredNotices[1]].concat(\n      filteredNotices.slice(2),\n    );\n  }\n\n  return [reservationNotice, ...filteredNotices];\n};\n\n/**\n * It displays information about the trip, acting as a container for all the `sbb-timetable-*` components.\n * */\nexport class SbbTimetableRowElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-timetable-row';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** The trip Prop. */\n  @property({ type: Object }) public accessor trip: ITripItem = null!;\n\n  /** The price Prop, which consists of the data for the badge. */\n  @property({ type: Object }) public accessor price: Price = null!;\n\n  /** This will be forwarded to the sbb-pearl-chain component - if true the position won't be animated. */\n  @forceType()\n  @property({ attribute: 'disable-animation', reflect: true, type: Boolean })\n  public accessor disableAnimation: boolean = false;\n\n  /** This will be forwarded to the notices section */\n  @property({ type: Object }) public accessor boarding: Boarding = null!;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @forceType()\n  @property({ attribute: 'loading-trip', type: Boolean })\n  public accessor loadingTrip: boolean = false;\n\n  /**\n   * The Footpath attribute for rendering different icons\n   * true: render a11y-icon\n   * false: render walk-icon\n   * default: render walk-icon\n   */\n  @forceType()\n  @property({ attribute: 'a11y-footpath', type: Boolean })\n  public accessor a11yFootpath: boolean = false;\n\n  /**\n   * The loading state -\n   * when this is true it will be render skeleton with an idling animation\n   */\n  @forceType()\n  @property({ attribute: 'loading-price', type: Boolean })\n  public accessor loadingPrice: boolean = false;\n\n  /**\n   * Hidden label for the card action. It overrides the automatically generated accessibility text for the component. Use this prop to provide custom accessibility information for the component.\n   */\n  @forceType()\n  @property({ attribute: 'card-action-label' })\n  public accessor cardActionLabel: string = '';\n\n  /** This will be forwarded to the sbb-card component as aria-expanded. */\n  @forceType()\n  @property({ attribute: 'accessibility-expanded', type: Boolean })\n  public accessor accessibilityExpanded: boolean = false;\n\n  /** When this prop is true the sbb-card will be in the active state. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor active: boolean = false;\n\n  /**\n   * A configured date which acts as the current date instead of the real current date.\n   * Only recommended for testing purposes.\n   */\n  @property()\n  public set now(value: Date | null) {\n    this._now = defaultDateAdapter.getValidDateOrNull(defaultDateAdapter.deserialize(value));\n  }\n  public get now(): Date {\n    return this._now ?? new Date();\n  }\n  private _now: Date | null = null;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('loadingTrip')) {\n      setOrRemoveAttribute(this, 'role', !this.loadingTrip ? 'rowgroup' : null);\n    }\n  }\n\n  /** The skeleton render function for the loading state */\n  private _renderSkeleton(): TemplateResult {\n    return html`\n      <sbb-card class=\"sbb-loading sbb-card-spacing-4x-xxs\">\n        ${this.loadingPrice ? html`<div class=\"sbb-loading__badge\" slot=\"badge\"></div>` : nothing}\n        <div class=\"sbb-loading__wrapper\">\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n          <div class=\"sbb-loading__row\"></div>\n        </div>\n      </sbb-card>\n    `;\n  }\n\n  private _getRideLegs(): PtRideLeg[] {\n    return this.trip?.legs?.filter((leg) => isRideLeg(leg)) ?? [];\n  }\n\n  private _getQuayTypeStrings(): { long: string; short: string } | null {\n    if (!this.trip.summary?.product) return null;\n    const rideLegs = this._getRideLegs();\n    const isShort = this.trip.summary.product?.vehicleMode === 'TRAIN';\n    const short = isShort\n      ? rideLegs[0].serviceJourney.quayTypeShortName || ''\n      : rideLegs[0].serviceJourney.quayTypeName || '';\n\n    return {\n      long: i18nFromPlatform[this._language.current] + ' ' + short,\n      short,\n    };\n  }\n\n  /** map Quay */\n  private _renderQuayType(): TemplateResult | undefined {\n    if (!this.trip.summary?.product) return undefined;\n    const quayTypeStrings = this._getQuayTypeStrings();\n    return html`\n      <span class=\"sbb-timetable__row--quay\">\n        <span class=\"sbb-screen-reader-only\">${quayTypeStrings?.long}&nbsp;</span>\n        <span class=\"sbb-timetable__row--quay-type\" aria-hidden=\"true\"\n          >${quayTypeStrings?.short}</span\n        >\n      </span>\n    `;\n  }\n\n  private _handleHimCus(trip: ITripItem): { cus: HimCus | null; him: HimCus | null } {\n    const { situations } = trip || {};\n    const sortedSituations = situations && sortSituation(situations);\n    const cus = getCus(trip, this._language.current);\n\n    return {\n      cus: Object.keys(cus)?.length ? cus : null,\n      him: situations?.length ? getHimIcon(sortedSituations[0]) : null,\n    };\n  }\n\n  private _getAccessibilityText(trip: ITripItem): string {\n    const { summary, legs, notices } = trip || {};\n    const {\n      departureWalk,\n      arrivalWalk,\n      departure,\n      arrival,\n      product,\n      direction,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const { departureTimeAttribute, arrivalTimeAttribute } = getDepartureArrivalTimeAttribute(\n      legs,\n      departureWalk || 0,\n      arrivalWalk || 0,\n      this._language.current,\n      this.a11yFootpath,\n    );\n\n    const rideLegs = this._getRideLegs();\n\n    const departureTime: Date | undefined = departure?.time\n      ? removeTimezoneFromISOTimeString(departure.time)\n      : undefined;\n\n    const arrivalTime: Date | undefined = arrival?.time\n      ? removeTimezoneFromISOTimeString(arrival.time)\n      : undefined;\n\n    const departureWalkText = departureTimeAttribute\n      ? `${departureTimeAttribute.text} ${departureTimeAttribute.duration}, `\n      : '';\n\n    const arrivalWalkText = arrivalTimeAttribute\n      ? `${arrivalTimeAttribute.text} ${arrivalTimeAttribute.duration}, `\n      : '';\n\n    const departureTimeText = departureTime\n      ? `${i18nDeparture[this._language.current]}: ${format(departureTime, 'HH:mm')}, `\n      : '';\n\n    const getDepartureQuayText = (): string => {\n      if (!departure?.quayFormatted) {\n        return '';\n      }\n\n      // add prefix \"new\" if quay was changed\n      const changedQuayPrefix = departure?.quayChanged ? `${i18nNew[this._language.current]} ` : '';\n      return `${changedQuayPrefix}${\n        this._getQuayTypeStrings()?.long\n      } ${departure?.quayFormatted}, `;\n    };\n\n    const meansOfTransportText =\n      product && product.vehicleMode\n        ? i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n          `${i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}, `\n        : '';\n\n    const vehicleSubModeText = product?.vehicleSubModeShortName\n      ? `${product.vehicleSubModeShortName} ${product.line || ''}, `\n      : '';\n\n    const directionText = `${i18nDirection[this._language.current]} ${direction}, `;\n\n    const himCus = this._handleHimCus(trip);\n    const cusText = himCus?.cus?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.cus?.text}, `\n      : '';\n    const himText = himCus?.him?.text\n      ? `${i18nRealTimeInfo[this._language.current]}: ${himCus?.him?.text}, `\n      : '';\n\n    const boardingText = this.boarding ? `${this.boarding.text}, ` : '';\n\n    const priceText = `${this.price?.isDiscount ? i18nSupersaver[this._language.current] : ''} ${\n      this.price?.text && this.price?.price\n        ? (this.price?.text || '') + ' ' + (this.price?.price || '') + ', '\n        : ''\n    }`;\n\n    const transferProcedures =\n      rideLegs.length > 2\n        ? `${rideLegs.length - 1} ${i18nTransferProcedures[this._language.current]}, `\n        : rideLegs.length > 1\n          ? `${rideLegs.length - 1} ${i18nTransferProcedure[this._language.current]}, `\n          : '';\n\n    const arrivalTimeText = arrivalTime\n      ? `${i18nArrival[this._language.current]}: ${format(arrivalTime, 'HH:mm')}, `\n      : '';\n\n    let occupancyText: string = '';\n    if (occupancy) {\n      if (occupancy.firstClass && occupancy.firstClass !== 'UNKNOWN') {\n        occupancyText += `${i18nClass.first[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.firstClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n      if (occupancy.secondClass && occupancy.secondClass !== 'UNKNOWN') {\n        occupancyText += ` ${i18nClass.second[this._language.current]} ${\n          (\n            i18nOccupancy[occupancy.secondClass.toLowerCase() as SbbOccupancy] as Record<\n              string,\n              string\n            >\n          )?.[this._language.current]\n        }.`;\n      }\n    }\n\n    const attributes =\n      notices &&\n      handleNotices(notices).length &&\n      handleNotices(notices)\n        ?.map((notice, index) => index < 4 && notice.text?.template)\n        .join(', ') + ', ';\n\n    const attributesText = attributes\n      ? `${i18nTravelhints[this._language.current]}: ${attributes}`\n      : '';\n\n    const durationText =\n      !!duration && duration > 0\n        ? `${i18nTripDuration[this._language.current]} ${\n            durationToTime(duration, this._language.current).long\n          }, `\n        : '';\n\n    return [\n      departureWalkText,\n      departureTimeText,\n      getDepartureQuayText(),\n      meansOfTransportText,\n      vehicleSubModeText,\n      directionText,\n      cusText,\n      boardingText,\n      priceText,\n      cusText ? '' : himText,\n      arrivalTimeText,\n      arrivalWalkText,\n      durationText,\n      transferProcedures,\n      occupancyText,\n      attributesText,\n    ]\n      .map((e) => e?.trim())\n      .filter((e) => e && e.length > 0)\n      .join(' ');\n  }\n\n  protected override render(): TemplateResult {\n    if (this.loadingTrip) {\n      return this._renderSkeleton();\n    }\n\n    const { legs, id, notices, summary } = this.trip || {};\n\n    const {\n      product,\n      direction,\n      departureWalk,\n      departure,\n      arrival,\n      arrivalWalk,\n      occupancy,\n      duration,\n    } = summary || {};\n\n    const himCus = this._handleHimCus(this.trip);\n    const hasHimCus = !!himCus.cus || !!himCus.him;\n\n    const noticeAttributes = notices && handleNotices(notices);\n\n    const durationObj = duration ? durationToTime(duration, this._language.current) : null;\n\n    return html`\n      <sbb-card class=\"sbb-card-spacing-4x-xxs\" id=${id}>\n        <sbb-card-button\n          ?active=${this.active}\n          aria-expanded=${this.accessibilityExpanded ? 'true' : nothing}\n        >\n          ${this.cardActionLabel ? this.cardActionLabel : this._getAccessibilityText(this.trip)}\n        </sbb-card-button>\n        ${this.loadingPrice ? html`<div class=\"sbb-loading__badge\" slot=\"badge\"></div>` : nothing}\n        ${this.price && !this.loadingPrice\n          ? html`<sbb-card-badge color=${this.price.isDiscount ? 'charcoal' : 'white'}>\n              ${this.price.isDiscount\n                ? html`<span aria-hidden=\"true\">\n                    %<span class=\"sbb-screen-reader-only\"\n                      >${i18nSupersaver[this._language.current]}</span\n                    >\n                  </span>`\n                : nothing}\n              ${this.price.text ? html`<span>${this.price.text}</span>` : nothing}\n              ${this.price.price ? html`<span>${this.price.price}</span>` : nothing}\n            </sbb-card-badge>`\n          : nothing}\n        <div class=\"sbb-timetable__row\" role=\"row\">\n          <div class=\"sbb-timetable__row-header\" role=\"gridcell\">\n            <div class=\"sbb-timetable__row-details\">\n              ${product?.corporateIdentityPictogram &&\n              html`<span class=\"sbb-timetable__row-transport-wrapper\">\n                <sbb-icon\n                  class=\"sbb-timetable__row-transport-icon\"\n                  name=\"picto:${product.corporateIdentityPictogram}\"\n                ></sbb-icon>\n                <span class=\"sbb-screen-reader-only\">\n                  ${product &&\n                  product.vehicleMode &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()] &&\n                  i18nMeansOfTransport[product.vehicleMode.toLowerCase()][this._language.current]}\n                  &nbsp;\n                </span>\n              </span>`}\n              ${product &&\n              (product.corporateIdentityIcon\n                ? renderIconProduct(product.corporateIdentityIcon, product.name)\n                : product.vehicleSubModeShortName &&\n                  renderStringProduct(product.vehicleSubModeShortName, product?.line))}\n            </div>\n            ${direction\n              ? html`<p>${`${i18nDirection[this._language.current]} ${direction}`}</p>`\n              : nothing}\n          </div>\n          <sbb-pearl-chain-time\n            role=\"gridcell\"\n            .legs=${legs}\n            .departureTime=${departure?.time}\n            .arrivalTime=${arrival?.time}\n            .departureWalk=${departureWalk}\n            .arrivalWalk=${arrivalWalk}\n            ?disable-animation=${this.disableAnimation}\n            ?a11y-footpath=${this.a11yFootpath}\n            .now=${this.now}\n          ></sbb-pearl-chain-time>\n          <div class=\"sbb-timetable__row-footer\" role=\"gridcell\">\n            ${product && departure?.quayFormatted\n              ? html`<span\n                  class=${departure?.quayChanged ? `sbb-timetable__row-quay--changed` : nothing}\n                >\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nDeparture[this._language.current]} ${\n                      departure?.quayChanged ? i18nNew[this._language.current] : ''\n                    }`}\n                    &nbsp;\n                  </span>\n                  ${this._renderQuayType()} ${departure?.quayFormatted}\n                </span>`\n              : nothing}\n            ${(occupancy?.firstClass && occupancy?.firstClass !== 'UNKNOWN') ||\n            (occupancy?.secondClass && occupancy.secondClass !== 'UNKNOWN')\n              ? html`<sbb-timetable-occupancy\n                  .firstClassOccupancy=${occupancy?.firstClass?.toLowerCase()}\n                  .secondClassOccupancy=${occupancy?.secondClass?.toLowerCase()}\n                ></sbb-timetable-occupancy>`\n              : nothing}\n            ${(noticeAttributes && noticeAttributes.length) || this.boarding\n              ? html`<ul class=\"sbb-timetable__row-hints\" role=\"list\">\n                  ${noticeAttributes?.map((notice, index) =>\n                    index < 4\n                      ? html`<li>\n                          <sbb-icon\n                            class=\"sbb-travel-hints__item\"\n                            name=${'sa-' + notice.name?.toLowerCase()}\n                          ></sbb-icon>\n                          <span class=\"sbb-screen-reader-only\">${notice.text?.template}</span>\n                        </li>`\n                      : nothing,\n                  )}\n                  ${this.boarding\n                    ? html`<li>\n                        <sbb-icon\n                          class=\"sbb-travel-hints__item\"\n                          name=${this.boarding?.name}\n                          aria-label=${this.boarding?.text}\n                          aria-hidden=\"false\"\n                        ></sbb-icon>\n                      </li>`\n                    : nothing}\n                </ul>`\n              : nothing}\n            ${duration && duration > 0\n              ? html`<time>\n                  <span class=\"sbb-screen-reader-only\">\n                    ${`${i18nTripDuration[this._language.current]} ${durationObj!.long}`}\n                  </span>\n                  <span aria-hidden=\"true\">${durationObj!.short}</span>\n                </time>`\n              : nothing}\n            ${hasHimCus && (himCus.cus || himCus.him)\n              ? html`<span class=\"sbb-timetable__row-warning\">\n                  <sbb-icon name=${(himCus.cus || himCus.him)!.name}></sbb-icon>\n                  <span class=\"sbb-screen-reader-only\">${(himCus.cus || himCus.him)!.text}</span>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </sbb-card>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-timetable-row': SbbTimetableRowElement;\n  }\n}\n"],"mappings":"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"}
|