@sbb-esta/lyne-elements-experimental 4.7.0 → 4.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (331) hide show
  1. package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +66 -85
  2. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +72 -53
  3. package/autocomplete-grid/autocomplete-grid-button.js +4 -4
  4. package/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.js +2 -25
  5. package/autocomplete-grid/autocomplete-grid-cell.js +4 -4
  6. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +20 -28
  7. package/autocomplete-grid/autocomplete-grid-optgroup.js +4 -4
  8. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +2 -41
  9. package/autocomplete-grid/autocomplete-grid-option.js +4 -5
  10. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -28
  11. package/autocomplete-grid/autocomplete-grid-row.js +4 -4
  12. package/autocomplete-grid/autocomplete-grid.js +4 -4
  13. package/autocomplete-grid-cell.component-Dak9wlBr.js +24 -0
  14. package/autocomplete-grid-option.component-DNRFHOwc.js +37 -0
  15. package/autocomplete-grid-row.component-DBHZQ0GQ.js +27 -0
  16. package/autocomplete-grid.js +10 -15
  17. package/autocomplete-grid.pure.js +7 -0
  18. package/core/datetime/date-helper.js +2 -191
  19. package/core/datetime.js +2 -5
  20. package/core/timetable/access-leg-helper.js +76 -71
  21. package/core/timetable/timetable-helper.js +9 -11
  22. package/core/timetable/timetable-properties.js +0 -1
  23. package/core/timetable.js +3 -7
  24. package/custom-elements.json +457 -368
  25. package/date-helper-CGproP5d.js +185 -0
  26. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +2 -1
  27. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
  28. package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +115 -136
  29. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.d.ts +3 -2
  30. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.d.ts.map +1 -1
  31. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.component.js +92 -71
  32. package/development/autocomplete-grid/autocomplete-grid-button.d.ts +0 -3
  33. package/development/autocomplete-grid/autocomplete-grid-button.d.ts.map +1 -1
  34. package/development/autocomplete-grid/autocomplete-grid-button.js +9 -4
  35. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.d.ts +4 -4
  36. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.d.ts.map +1 -1
  37. package/development/autocomplete-grid/autocomplete-grid-cell/autocomplete-grid-cell.component.js +2 -41
  38. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts +0 -3
  39. package/development/autocomplete-grid/autocomplete-grid-cell.d.ts.map +1 -1
  40. package/development/autocomplete-grid/autocomplete-grid-cell.js +10 -5
  41. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts +3 -2
  42. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.d.ts.map +1 -1
  43. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.component.js +28 -38
  44. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts +0 -3
  45. package/development/autocomplete-grid/autocomplete-grid-optgroup.d.ts.map +1 -1
  46. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +9 -4
  47. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts +1 -0
  48. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.d.ts.map +1 -1
  49. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +2 -121
  50. package/development/autocomplete-grid/autocomplete-grid-option.d.ts +0 -3
  51. package/development/autocomplete-grid/autocomplete-grid-option.d.ts.map +1 -1
  52. package/development/autocomplete-grid/autocomplete-grid-option.js +10 -6
  53. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.d.ts +4 -4
  54. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.d.ts.map +1 -1
  55. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -103
  56. package/development/autocomplete-grid/autocomplete-grid-row.d.ts +0 -3
  57. package/development/autocomplete-grid/autocomplete-grid-row.d.ts.map +1 -1
  58. package/development/autocomplete-grid/autocomplete-grid-row.js +10 -5
  59. package/development/autocomplete-grid/autocomplete-grid.d.ts +0 -3
  60. package/development/autocomplete-grid/autocomplete-grid.d.ts.map +1 -1
  61. package/development/autocomplete-grid/autocomplete-grid.js +9 -4
  62. package/development/autocomplete-grid-cell.component-BBvM4o2H.js +42 -0
  63. package/development/autocomplete-grid-option.component-QzfM5eIE.js +123 -0
  64. package/development/autocomplete-grid-row.component-H8sCTCkT.js +104 -0
  65. package/development/autocomplete-grid.d.ts +1 -9
  66. package/development/autocomplete-grid.d.ts.map +1 -1
  67. package/development/autocomplete-grid.js +17 -14
  68. package/development/autocomplete-grid.pure.d.ts +8 -0
  69. package/development/autocomplete-grid.pure.d.ts.map +1 -0
  70. package/development/autocomplete-grid.pure.js +7 -0
  71. package/development/core/datetime/date-helper.js +2 -285
  72. package/development/core/datetime.d.ts +1 -3
  73. package/development/core/datetime.d.ts.map +1 -1
  74. package/development/core/datetime.js +2 -6
  75. package/development/core/timetable/access-leg-helper.js +104 -82
  76. package/development/core/timetable/timetable-helper.js +16 -17
  77. package/development/core/timetable/timetable-properties.d.ts +30 -30
  78. package/development/core/timetable/timetable-properties.d.ts.map +1 -1
  79. package/development/core/timetable/timetable-properties.js +0 -2
  80. package/development/core/timetable.d.ts +1 -3
  81. package/development/core/timetable.d.ts.map +1 -1
  82. package/development/core/timetable.js +3 -8
  83. package/development/date-helper-8_Y-PuHh.js +520 -0
  84. package/development/differenceInMinutes-DN_1Rk3O.js +110 -0
  85. package/development/format-Bbrn2bgo.js +1848 -0
  86. package/development/isValid-C-HzKv4v.js +178 -0
  87. package/development/journey-summary/journey-summary.component.d.ts +4 -2
  88. package/development/journey-summary/journey-summary.component.d.ts.map +1 -1
  89. package/development/journey-summary/journey-summary.component.js +2 -294
  90. package/development/journey-summary.component-uGhZvA4p.js +385 -0
  91. package/development/journey-summary.d.ts +1 -4
  92. package/development/journey-summary.d.ts.map +1 -1
  93. package/development/journey-summary.js +9 -5
  94. package/development/journey-summary.pure.d.ts +3 -0
  95. package/development/journey-summary.pure.d.ts.map +1 -0
  96. package/development/journey-summary.pure.js +2 -0
  97. package/development/mapper-hWWm7Uke.js +11454 -0
  98. package/development/pearl-chain/pearl-chain.component.d.ts +4 -2
  99. package/development/pearl-chain/pearl-chain.component.d.ts.map +1 -1
  100. package/development/pearl-chain/pearl-chain.component.js +2 -640
  101. package/development/pearl-chain-time/pearl-chain-time.component.d.ts +4 -2
  102. package/development/pearl-chain-time/pearl-chain-time.component.d.ts.map +1 -1
  103. package/development/pearl-chain-time/pearl-chain-time.component.js +2 -312
  104. package/development/pearl-chain-time.component-B8mayTWD.js +415 -0
  105. package/development/pearl-chain-time.d.ts +1 -4
  106. package/development/pearl-chain-time.d.ts.map +1 -1
  107. package/development/pearl-chain-time.js +9 -5
  108. package/development/pearl-chain-time.pure.d.ts +3 -0
  109. package/development/pearl-chain-time.pure.d.ts.map +1 -0
  110. package/development/pearl-chain-time.pure.js +2 -0
  111. package/development/pearl-chain-vertical/pearl-chain-vertical.component.d.ts +4 -2
  112. package/development/pearl-chain-vertical/pearl-chain-vertical.component.d.ts.map +1 -1
  113. package/development/pearl-chain-vertical/pearl-chain-vertical.component.js +2 -40
  114. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.d.ts +4 -2
  115. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.d.ts.map +1 -1
  116. package/development/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +2 -399
  117. package/development/pearl-chain-vertical-item.component-BDzbcIaf.js +435 -0
  118. package/development/pearl-chain-vertical-item.d.ts +1 -4
  119. package/development/pearl-chain-vertical-item.d.ts.map +1 -1
  120. package/development/pearl-chain-vertical-item.js +9 -5
  121. package/development/pearl-chain-vertical-item.pure.d.ts +3 -0
  122. package/development/pearl-chain-vertical-item.pure.d.ts.map +1 -0
  123. package/development/pearl-chain-vertical-item.pure.js +2 -0
  124. package/development/pearl-chain-vertical.component-CswE7b3M.js +39 -0
  125. package/development/pearl-chain-vertical.d.ts +1 -4
  126. package/development/pearl-chain-vertical.d.ts.map +1 -1
  127. package/development/pearl-chain-vertical.js +9 -5
  128. package/development/pearl-chain-vertical.pure.d.ts +3 -0
  129. package/development/pearl-chain-vertical.pure.d.ts.map +1 -0
  130. package/development/pearl-chain-vertical.pure.js +2 -0
  131. package/development/pearl-chain.component-wpsTvoSe.js +704 -0
  132. package/development/pearl-chain.d.ts +1 -4
  133. package/development/pearl-chain.d.ts.map +1 -1
  134. package/development/pearl-chain.js +9 -5
  135. package/development/pearl-chain.pure.d.ts +3 -0
  136. package/development/pearl-chain.pure.d.ts.map +1 -0
  137. package/development/pearl-chain.pure.js +2 -0
  138. package/development/seat-reservation/common/mapper/icon-mapper.d.ts +2 -2
  139. package/development/seat-reservation/common/mapper/icon-mapper.d.ts.map +1 -1
  140. package/development/seat-reservation/common/mapper/icon-mapper.js +168 -71
  141. package/development/seat-reservation/common/mapper/mapper.js +2 -131
  142. package/development/seat-reservation/common/mapper.js +2 -9
  143. package/development/seat-reservation/common/svgs.js +2 -46
  144. package/development/seat-reservation/common/translations/i18n.js +1118 -900
  145. package/development/seat-reservation/common/translations.js +1 -4
  146. package/development/seat-reservation/common/types.d.ts +22 -22
  147. package/development/seat-reservation/common/types.d.ts.map +1 -1
  148. package/development/seat-reservation/common/types.js +0 -2
  149. package/development/seat-reservation/common.d.ts +1 -3
  150. package/development/seat-reservation/common.d.ts.map +1 -1
  151. package/development/seat-reservation/common.js +10 -12
  152. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +4 -3
  153. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
  154. package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +1309 -1231
  155. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +1 -0
  156. package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
  157. package/development/seat-reservation/seat-reservation/seat-reservation.component.js +2 -867
  158. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts +4 -2
  159. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.d.ts.map +1 -1
  160. package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +2 -112
  161. package/development/seat-reservation/seat-reservation-area.d.ts +0 -3
  162. package/development/seat-reservation/seat-reservation-area.d.ts.map +1 -1
  163. package/development/seat-reservation/seat-reservation-area.js +10 -5
  164. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.d.ts.map +1 -1
  165. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +39 -36
  166. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts +4 -2
  167. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.d.ts.map +1 -1
  168. package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +2 -167
  169. package/development/seat-reservation/seat-reservation-graphic.d.ts +0 -3
  170. package/development/seat-reservation/seat-reservation-graphic.d.ts.map +1 -1
  171. package/development/seat-reservation/seat-reservation-graphic.js +10 -5
  172. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts +5 -3
  173. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
  174. package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +2 -718
  175. package/development/seat-reservation/seat-reservation-navigation-coach.d.ts +0 -3
  176. package/development/seat-reservation/seat-reservation-navigation-coach.d.ts.map +1 -1
  177. package/development/seat-reservation/seat-reservation-navigation-coach.js +10 -5
  178. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts +4 -2
  179. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.d.ts.map +1 -1
  180. package/development/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -136
  181. package/development/seat-reservation/seat-reservation-navigation-services.d.ts +0 -3
  182. package/development/seat-reservation/seat-reservation-navigation-services.d.ts.map +1 -1
  183. package/development/seat-reservation/seat-reservation-navigation-services.js +10 -5
  184. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts +2 -1
  185. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.d.ts.map +1 -1
  186. package/development/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +2 -607
  187. package/development/seat-reservation/seat-reservation-place-control.d.ts +0 -3
  188. package/development/seat-reservation/seat-reservation-place-control.d.ts.map +1 -1
  189. package/development/seat-reservation/seat-reservation-place-control.js +10 -5
  190. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts +4 -2
  191. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.d.ts.map +1 -1
  192. package/development/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +2 -34
  193. package/development/seat-reservation/seat-reservation-scoped.d.ts +0 -3
  194. package/development/seat-reservation/seat-reservation-scoped.d.ts.map +1 -1
  195. package/development/seat-reservation/seat-reservation-scoped.js +10 -5
  196. package/development/seat-reservation/seat-reservation.d.ts +0 -3
  197. package/development/seat-reservation/seat-reservation.d.ts.map +1 -1
  198. package/development/seat-reservation/seat-reservation.js +10 -6
  199. package/development/seat-reservation-area.component-ORuli_DC.js +138 -0
  200. package/development/seat-reservation-graphic.component-lZXqHWIz.js +193 -0
  201. package/development/seat-reservation-navigation-coach.component-D2QXTMJJ.js +828 -0
  202. package/development/seat-reservation-navigation-services.component-Bg1adRlU.js +179 -0
  203. package/development/seat-reservation-place-control.component-CwUX-QYO.js +726 -0
  204. package/development/seat-reservation-scoped.component-uLT33P9y.js +31 -0
  205. package/development/seat-reservation.component-MOv5kHDC.js +821 -0
  206. package/development/seat-reservation.d.ts +1 -11
  207. package/development/seat-reservation.d.ts.map +1 -1
  208. package/development/seat-reservation.js +24 -27
  209. package/development/seat-reservation.pure.d.ts +15 -0
  210. package/development/seat-reservation.pure.d.ts.map +1 -0
  211. package/development/seat-reservation.pure.js +15 -0
  212. package/development/svgs-kDpBCto5.js +28 -0
  213. package/development/timetable-duration/timetable-duration.component.d.ts +4 -2
  214. package/development/timetable-duration/timetable-duration.component.d.ts.map +1 -1
  215. package/development/timetable-duration/timetable-duration.component.js +2 -114
  216. package/development/timetable-duration.component-D21SXsQq.js +125 -0
  217. package/development/timetable-duration.d.ts +1 -4
  218. package/development/timetable-duration.d.ts.map +1 -1
  219. package/development/timetable-duration.js +9 -5
  220. package/development/timetable-duration.pure.d.ts +3 -0
  221. package/development/timetable-duration.pure.d.ts.map +1 -0
  222. package/development/timetable-duration.pure.js +2 -0
  223. package/development/timetable-row/timetable-row.component.d.ts +4 -2
  224. package/development/timetable-row/timetable-row.component.d.ts.map +1 -1
  225. package/development/timetable-row/timetable-row.component.js +2 -787
  226. package/development/timetable-row.component-Y5w8vEwP.js +932 -0
  227. package/development/timetable-row.d.ts +1 -4
  228. package/development/timetable-row.d.ts.map +1 -1
  229. package/development/timetable-row.js +9 -12
  230. package/development/timetable-row.pure.d.ts +3 -0
  231. package/development/timetable-row.pure.d.ts.map +1 -0
  232. package/development/timetable-row.pure.js +2 -0
  233. package/development/toDate-Biiv3kyf.js +150 -0
  234. package/differenceInMinutes-Dr9gRqtu.js +27 -0
  235. package/format-CM5exOsN.js +1103 -0
  236. package/index.d.ts +9 -20
  237. package/index.js +9 -20
  238. package/isValid-B9oVW3lA.js +36 -0
  239. package/journey-summary/journey-summary.component.js +2 -193
  240. package/journey-summary.component-Cq_4kaOp.js +264 -0
  241. package/journey-summary.js +6 -4
  242. package/journey-summary.pure.js +2 -0
  243. package/mapper-DkiDDseD.js +11382 -0
  244. package/package.json +47 -2
  245. package/pearl-chain/pearl-chain.component.js +2 -164
  246. package/pearl-chain-time/pearl-chain-time.component.js +2 -156
  247. package/pearl-chain-time.component-DGDW5S1c.js +239 -0
  248. package/pearl-chain-time.js +6 -4
  249. package/pearl-chain-time.pure.js +2 -0
  250. package/pearl-chain-vertical/pearl-chain-vertical.component.js +2 -24
  251. package/pearl-chain-vertical-item/pearl-chain-vertical-item.component.js +2 -76
  252. package/pearl-chain-vertical-item.component-G22bWhLU.js +108 -0
  253. package/pearl-chain-vertical-item.js +6 -4
  254. package/pearl-chain-vertical-item.pure.js +2 -0
  255. package/pearl-chain-vertical.component-CXIDT5RD.js +21 -0
  256. package/pearl-chain-vertical.js +6 -4
  257. package/pearl-chain-vertical.pure.js +2 -0
  258. package/pearl-chain.component-DmjkVIva.js +194 -0
  259. package/pearl-chain.js +6 -4
  260. package/pearl-chain.pure.js +2 -0
  261. package/seat-reservation/common/mapper/icon-mapper.js +71 -71
  262. package/seat-reservation/common/mapper/mapper.js +2 -91
  263. package/seat-reservation/common/mapper.js +3 -9
  264. package/seat-reservation/common/svgs.js +2 -243
  265. package/seat-reservation/common/translations/i18n.js +1084 -891
  266. package/seat-reservation/common/translations.js +2 -4
  267. package/seat-reservation/common/types.js +0 -1
  268. package/seat-reservation/common.js +9 -13
  269. package/seat-reservation/seat-reservation/seat-reservation-base-element.js +834 -809
  270. package/seat-reservation/seat-reservation/seat-reservation.component.js +2 -422
  271. package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +2 -50
  272. package/seat-reservation/seat-reservation-area.js +4 -4
  273. package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +69 -70
  274. package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +2 -73
  275. package/seat-reservation/seat-reservation-graphic.js +4 -4
  276. package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +2 -232
  277. package/seat-reservation/seat-reservation-navigation-coach.js +4 -4
  278. package/seat-reservation/seat-reservation-navigation-services/seat-reservation-navigation-services.component.js +2 -83
  279. package/seat-reservation/seat-reservation-navigation-services.js +4 -4
  280. package/seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js +2 -202
  281. package/seat-reservation/seat-reservation-place-control.js +4 -4
  282. package/seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js +2 -20
  283. package/seat-reservation/seat-reservation-scoped.js +4 -4
  284. package/seat-reservation/seat-reservation.js +5 -6
  285. package/seat-reservation-area.component-COD6CXhP.js +75 -0
  286. package/seat-reservation-graphic.component-BNfU5tQM.js +102 -0
  287. package/seat-reservation-navigation-coach.component-Bh9ILq60.js +333 -0
  288. package/seat-reservation-navigation-services.component-QL0UnilZ.js +127 -0
  289. package/seat-reservation-place-control.component-BfnZUyHv.js +322 -0
  290. package/seat-reservation-scoped.component-CY04BT_4.js +17 -0
  291. package/seat-reservation.component-zrQHTRl3.js +364 -0
  292. package/seat-reservation.js +17 -29
  293. package/seat-reservation.pure.js +15 -0
  294. package/svgs-D5DhLHxC.js +26 -0
  295. package/timetable-duration/timetable-duration.component.js +2 -56
  296. package/timetable-duration.component-DaYoJUGS.js +65 -0
  297. package/timetable-duration.js +6 -4
  298. package/timetable-duration.pure.js +2 -0
  299. package/timetable-row/timetable-row.component.js +2 -426
  300. package/timetable-row.component-BDMAEsbR.js +559 -0
  301. package/timetable-row.js +6 -11
  302. package/timetable-row.pure.js +2 -0
  303. package/toDate-p-Tpkb7t.js +16 -0
  304. package/development/differenceInMinutes-B0dawX-5.js +0 -26
  305. package/development/format-BMkeaqaF.js +0 -1433
  306. package/development/isValid-BYRch7pV.js +0 -53
  307. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.d.ts +0 -69
  308. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.d.ts.map +0 -1
  309. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.js +0 -559
  310. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.d.ts +0 -123
  311. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.d.ts.map +0 -1
  312. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.js +0 -972
  313. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.d.ts +0 -114
  314. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.d.ts.map +0 -1
  315. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.js +0 -20368
  316. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.d.ts +0 -85
  317. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.d.ts.map +0 -1
  318. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.js +0 -1739
  319. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.d.ts +0 -69
  320. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.d.ts.map +0 -1
  321. package/development/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.js +0 -9783
  322. package/development/toDate-BWb6Z1JD.js +0 -24
  323. package/differenceInMinutes-COvvdYsJ.js +0 -23
  324. package/format-CmKROkbc.js +0 -1186
  325. package/isValid-m3_OsPaB.js +0 -45
  326. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-bus.js +0 -558
  327. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-decks.js +0 -970
  328. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-giruno.js +0 -20367
  329. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-others.js +0 -1738
  330. package/seat-reservation/common/mapper/sample-data/seat-reservation-sample-data-train.js +0 -9782
  331. package/toDate-Bw2KTWeq.js +0 -15
@@ -0,0 +1,821 @@
1
+ import { SeatReservationBaseElement } from "./seat-reservation/seat-reservation/seat-reservation-base-element.js";
2
+ import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
3
+ import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
4
+ import { css, html, isServer, nothing } from "lit";
5
+ import "@sbb-esta/lyne-elements/screen-reader-only.js";
6
+ import { styleMap } from "lit/directives/style-map.js";
7
+ import { SbbSeatReservationAreaElement } from "./seat-reservation/seat-reservation-area/seat-reservation-area.component.js";
8
+ import { classMap } from "lit/directives/class-map.js";
9
+ import { getI18nSeatReservation } from "./seat-reservation/common/translations.js";
10
+ import { SbbSeatReservationGraphicElement } from "./seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js";
11
+ import { repeat } from "lit/directives/repeat.js";
12
+ import { SbbSeatReservationNavigationCoachElement } from "./seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js";
13
+ import { SbbSeatReservationPlaceControlElement } from "./seat-reservation/seat-reservation-place-control/seat-reservation-place-control.component.js";
14
+ import { SbbSeatReservationScopedElement } from "./seat-reservation/seat-reservation-scoped/seat-reservation-scoped.component.js";
15
+ import "@sbb-esta/lyne-elements/button.js";
16
+ import "@sbb-esta/lyne-elements/popover.js";
17
+ //#region src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.scss?lit&inline
18
+ var seat_reservation_default = css`:host {
19
+ --sbb-seat-reservation-grid-size: 16px;
20
+ --sbb-seat-reservation-height: 0;
21
+ --sbb-seat-reservation-decks: 1;
22
+ display: block;
23
+ height: inherit;
24
+ }
25
+ :host ::part(coach-floor) {
26
+ fill: var(--sbb-background-color-2);
27
+ }
28
+ @media (forced-colors: active) {
29
+ :host ::part(coach-floor) {
30
+ fill: transparent;
31
+ }
32
+ }
33
+
34
+ :host(:dir(rtl)) :not(.sbb-sr-place-ctrl--type-bicycle,
35
+ .sbb-sr-place-ctrl--orientation-90,
36
+ .sbb-sr-place-ctrl--orientation-270,
37
+ .sbb-sr-place-ctrl--state-selected) ::part(coach-floor) {
38
+ rotate: calc(180 * 1deg);
39
+ }
40
+
41
+ [popover]:where(sbb-popover) {
42
+ margin: 0;
43
+ padding: 0;
44
+ border: none;
45
+ width: auto;
46
+ height: auto;
47
+ background-color: transparent;
48
+ color: inherit;
49
+ pointer-events: none;
50
+ }
51
+ [popover]:where(sbb-popover) .sbb-sr-popover {
52
+ margin-block: calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
53
+ }
54
+
55
+ :host([align-vertical]) .sbb-sr__component {
56
+ flex-direction: row-reverse;
57
+ justify-content: flex-end;
58
+ gap: calc(22 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
59
+ height: inherit;
60
+ }
61
+ @media (min-width: calc(37.5rem)) {
62
+ :host([align-vertical]) .sbb-sr__component {
63
+ gap: calc(54 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
64
+ }
65
+ }
66
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation,
67
+ :host([align-vertical]) .sbb-sr__component ul.sbb-sr-navigation__list-coaches {
68
+ flex-direction: column;
69
+ }
70
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation {
71
+ padding: calc(16 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) 0;
72
+ }
73
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation .sbb-sr__navigation-control-button {
74
+ left: calc(1 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
75
+ top: 0;
76
+ rotate: 90deg;
77
+ }
78
+ @media (min-width: calc(64rem)) {
79
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation .sbb-sr__navigation-control-button {
80
+ left: calc(-1 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
81
+ }
82
+ }
83
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation ul.sbb-sr-navigation__list-coaches {
84
+ max-width: initial;
85
+ padding: calc(5 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
86
+ overflow: hidden scroll;
87
+ }
88
+ :host([align-vertical]) .sbb-sr__component nav.sbb-sr-navigation ul.sbb-sr-navigation__list-coaches li {
89
+ display: flex;
90
+ }
91
+ :host([align-vertical]) .sbb-sr__wrapper-coach-decks {
92
+ flex-direction: column;
93
+ }
94
+ :host([align-vertical]) .sbb-sr__wrapper-coach-decks .sbb-sr__wrapper-deck-labels {
95
+ flex-direction: column-reverse;
96
+ width: calc((var(--sbb-seat-reservation-height) + 24) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
97
+ height: initial;
98
+ }
99
+ :host([align-vertical]) .sbb-sr__wrapper-coach-decks .sbb-sr__wrapper-deck-labels b {
100
+ inline-size: calc(50% - 16 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
101
+ block-size: calc(20 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
102
+ margin-bottom: calc(16 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
103
+ rotate: initial;
104
+ writing-mode: initial;
105
+ }
106
+ :host([align-vertical]) .sbb-sr__wrapper-scrollarea {
107
+ width: calc((var(--sbb-seat-reservation-height) + 24) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
108
+ height: 100%;
109
+ overflow: hidden scroll;
110
+ }
111
+ :host([align-vertical]) .sbb-sr__wrapper-scrollarea .sbb-sr__parent {
112
+ rotate: 90deg;
113
+ }
114
+ :host([align-vertical]) .sbb-sr-travel-direction-wrapper {
115
+ width: calc(var(--sbb-seat-reservation-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
116
+ margin-block-start: calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
117
+ }
118
+
119
+ .sbb-sr-navigation {
120
+ gap: calc(3 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
121
+ }
122
+
123
+ .sbb-sr-navigation .sbb-sr__navigation-control-button {
124
+ position: relative;
125
+ top: calc(2 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
126
+ }
127
+ @media (min-width: calc(64rem)) {
128
+ .sbb-sr-navigation .sbb-sr__navigation-control-button {
129
+ top: 0;
130
+ }
131
+ }
132
+
133
+ .sbb-sr__component {
134
+ display: flex;
135
+ flex-direction: column;
136
+ gap: calc(64 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem) - 16px);
137
+ }
138
+
139
+ .sbb-sr-travel-direction-wrapper {
140
+ display: flex;
141
+ justify-content: center;
142
+ align-items: center;
143
+ column-gap: calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
144
+ margin-block: calc(8 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
145
+ font-size: var(--sbb-text-font-size-s);
146
+ }
147
+ .sbb-sr-travel-direction-wrapper .sbb-sr__travel-direction--arrow {
148
+ display: flex;
149
+ align-items: center;
150
+ }
151
+
152
+ .sbb-sr-navigation-wrapper {
153
+ display: flex;
154
+ }
155
+
156
+ .sbb-sr-navigation {
157
+ display: flex;
158
+ justify-content: center;
159
+ width: 100%;
160
+ padding-inline: 16px;
161
+ }
162
+
163
+ .sbb-sr-navigation__list-coaches {
164
+ list-style: none;
165
+ margin: 0;
166
+ padding: 0;
167
+ font-size: inherit;
168
+ --sbb-scrollbar-thumb-width: 0.125rem;
169
+ --sbb-scrollbar-thumb-width-hover: 0.25rem;
170
+ --sbb-scrollbar-width-firefox: thin;
171
+ --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
172
+ --sbb-scrollbar-color: light-dark(
173
+ color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
174
+ color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
175
+ );
176
+ --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
177
+ --sbb-scrollbar-color-hover: light-dark(
178
+ color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
179
+ color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
180
+ );
181
+ --sbb-scrollbar-track-color: transparent;
182
+ --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
183
+ }
184
+ .sbb-sr-navigation__list-coaches::-webkit-scrollbar {
185
+ width: var(--sbb-scrollbar-width);
186
+ height: var(--sbb-scrollbar-width);
187
+ background-color: var(--sbb-scrollbar-track-color, transparent);
188
+ }
189
+ .sbb-sr-navigation__list-coaches::-webkit-scrollbar-corner {
190
+ background-color: var(--sbb-scrollbar-track-color, transparent);
191
+ }
192
+ .sbb-sr-navigation__list-coaches::-webkit-scrollbar-thumb {
193
+ background-color: var(--sbb-scrollbar-color, currentcolor);
194
+ border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;
195
+ border-radius: var(--sbb-border-radius-4x);
196
+ background-clip: padding-box;
197
+ }
198
+ .sbb-sr-navigation__list-coaches::-webkit-scrollbar-thumb:hover {
199
+ background-color: var(--sbb-scrollbar-color-hover, currentcolor);
200
+ border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));
201
+ }
202
+ .sbb-sr-navigation__list-coaches::-webkit-scrollbar-button, .sbb-sr-navigation__list-coaches::-webkit-scrollbar-corner {
203
+ display: none;
204
+ }
205
+ @supports not selector(::-webkit-scrollbar) {
206
+ .sbb-sr-navigation__list-coaches {
207
+ scrollbar-width: var(--sbb-scrollbar-width-firefox);
208
+ scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);
209
+ }
210
+ }
211
+ .sbb-sr-navigation__list-coaches {
212
+ display: flex;
213
+ flex-wrap: nowrap;
214
+ gap: calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
215
+ padding: calc(6 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) calc(5 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) 0;
216
+ max-width: 856px;
217
+ --sbb-scrollbar-color: transparent;
218
+ overflow: scroll hidden;
219
+ position: relative;
220
+ }
221
+
222
+ .sbb-sr__wrapper-coach-decks {
223
+ display: flex;
224
+ overflow: hidden;
225
+ height: inherit;
226
+ }
227
+ .sbb-sr__wrapper-coach-decks .sbb-sr__wrapper-deck-labels {
228
+ display: flex;
229
+ justify-content: space-between;
230
+ height: calc(var(--sbb-seat-reservation-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
231
+ writing-mode: vertical-lr;
232
+ }
233
+ .sbb-sr__wrapper-coach-decks .sbb-sr__wrapper-deck-labels b {
234
+ height: calc(50% - 16 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
235
+ width: calc(20 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
236
+ margin-block-end: 16px;
237
+ rotate: 180deg;
238
+ text-align: center;
239
+ line-height: calc(20 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
240
+ }
241
+
242
+ .sbb-sr__wrapper-scrollarea {
243
+ --sbb-scrollbar-thumb-width: 0.125rem;
244
+ --sbb-scrollbar-thumb-width-hover: 0.25rem;
245
+ --sbb-scrollbar-width-firefox: thin;
246
+ --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
247
+ --sbb-scrollbar-color: light-dark(
248
+ color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
249
+ color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
250
+ );
251
+ --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
252
+ --sbb-scrollbar-color-hover: light-dark(
253
+ color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
254
+ color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
255
+ );
256
+ --sbb-scrollbar-track-color: transparent;
257
+ --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
258
+ }
259
+ .sbb-sr__wrapper-scrollarea::-webkit-scrollbar {
260
+ width: var(--sbb-scrollbar-width);
261
+ height: var(--sbb-scrollbar-width);
262
+ background-color: var(--sbb-scrollbar-track-color, transparent);
263
+ }
264
+ .sbb-sr__wrapper-scrollarea::-webkit-scrollbar-corner {
265
+ background-color: var(--sbb-scrollbar-track-color, transparent);
266
+ }
267
+ .sbb-sr__wrapper-scrollarea::-webkit-scrollbar-thumb {
268
+ background-color: var(--sbb-scrollbar-color, currentcolor);
269
+ border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;
270
+ border-radius: var(--sbb-border-radius-4x);
271
+ background-clip: padding-box;
272
+ }
273
+ .sbb-sr__wrapper-scrollarea::-webkit-scrollbar-thumb:hover {
274
+ background-color: var(--sbb-scrollbar-color-hover, currentcolor);
275
+ border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));
276
+ }
277
+ .sbb-sr__wrapper-scrollarea::-webkit-scrollbar-button, .sbb-sr__wrapper-scrollarea::-webkit-scrollbar-corner {
278
+ display: none;
279
+ }
280
+ @supports not selector(::-webkit-scrollbar) {
281
+ .sbb-sr__wrapper-scrollarea {
282
+ scrollbar-width: var(--sbb-scrollbar-width-firefox);
283
+ scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);
284
+ }
285
+ }
286
+ .sbb-sr__wrapper-scrollarea {
287
+ overflow: scroll hidden;
288
+ padding-block: calc(8 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) calc(16 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
289
+ }
290
+ .sbb-sr__wrapper-scrollarea .sbb-sr__parent {
291
+ display: flex;
292
+ flex-direction: column;
293
+ position: relative;
294
+ }
295
+
296
+ .sbb-sr__list-decks {
297
+ list-style: none;
298
+ margin: 0;
299
+ padding: 0;
300
+ font-size: inherit;
301
+ display: flex;
302
+ flex-direction: column;
303
+ }
304
+
305
+ .sbb-sr__list-decks--gap {
306
+ gap: calc(48 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
307
+ }
308
+
309
+ .sbb-sr__list-item-deck {
310
+ position: relative;
311
+ }
312
+
313
+ .sbb-sr__list-coaches {
314
+ list-style: none;
315
+ margin: 0;
316
+ padding: 0;
317
+ font-size: inherit;
318
+ display: flex;
319
+ gap: calc(4 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
320
+ }
321
+
322
+ .sbb-sr__list-decks:has(.sbb-sr-coach-has-overhanging-elements) .sbb-sr__list-coaches {
323
+ gap: calc(8 * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));
324
+ }
325
+
326
+ .sbb-sr__item-coach {
327
+ position: relative;
328
+ }
329
+
330
+ .sbb-sr-coach-wrapper__table {
331
+ outline: 0;
332
+ }`;
333
+ //#endregion
334
+ //#region src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts
335
+ SbbSeatReservationAreaElement.define();
336
+ SbbSeatReservationGraphicElement.define();
337
+ SbbSeatReservationPlaceControlElement.define();
338
+ SbbSeatReservationNavigationCoachElement.define();
339
+ SbbSeatReservationScopedElement.define();
340
+ /**
341
+ * Main component for the seat reservation.
342
+ *
343
+ */
344
+ var SbbSeatReservationElement = class extends SeatReservationBaseElement {
345
+ constructor() {
346
+ super(...arguments);
347
+ this._language = new SbbLanguageController(this);
348
+ this._notFixedRotatableAreaIcons = ["ENTRY_EXIT"];
349
+ }
350
+ static {
351
+ this.elementName = "sbb-seat-reservation";
352
+ }
353
+ static {
354
+ this.styles = [boxSizingStyles, seat_reservation_default];
355
+ }
356
+ willUpdate(changedProperties) {
357
+ super.willUpdate(changedProperties);
358
+ if (changedProperties.has("hasNavigation")) if (this.hasNavigation) this.shadowRoot?.querySelectorAll("table").forEach((table) => table.removeAttribute("tabindex"));
359
+ else this.shadowRoot?.querySelectorAll("table").forEach((table) => table.setAttribute("tabindex", "0"));
360
+ }
361
+ firstUpdated(changedProperties) {
362
+ super.firstUpdated(changedProperties);
363
+ this.updateComplete.then(() => {
364
+ this.initNavigationSelectionByScrollEvent();
365
+ });
366
+ }
367
+ render() {
368
+ this._initVehicleSeatReservationConstruction();
369
+ return this._coachesHtmlTemplate || null;
370
+ }
371
+ _initVehicleSeatReservationConstruction() {
372
+ this._coachesHtmlTemplate = html`
373
+ ${this._renderTravelDirection()}
374
+ <div class="sbb-sr__component">
375
+ ${this._renderNavigation()}
376
+ <div
377
+ class="sbb-sr__wrapper-coach-decks"
378
+ @keydown=${(evt) => this.keyboardSeatmapEventHandling(evt)}
379
+ >
380
+ <div class="sbb-sr__wrapper-deck-labels">${this._renderDeckLabels()}</div>
381
+ <div
382
+ @scroll=${() => this.coachAreaScrollend()}
383
+ id="sbb-sr__wrapper-scrollarea"
384
+ class="sbb-sr__wrapper-scrollarea"
385
+ tabindex="-1"
386
+ >
387
+ <div id="sbb-sr__parent-area" class="sbb-sr__parent">
388
+ <ul
389
+ class="${classMap({
390
+ "sbb-sr__list-decks": true,
391
+ "sbb-sr__list-decks--gap": this.hasMultipleDecks
392
+ })}"
393
+ >
394
+ ${this.seatReservations?.map((seatReservation, coachDeckIndex) => {
395
+ return html`<li class="sbb-sr__list-item-deck">
396
+ <ul class="sbb-sr__list-coaches" role="presentation">
397
+ ${this._renderCoaches(seatReservation, coachDeckIndex)}
398
+ </ul>
399
+ </li>`;
400
+ })}
401
+ </ul>
402
+ </div>
403
+ </div>
404
+ </div>
405
+ </div>
406
+ `;
407
+ }
408
+ _renderDeckLabels() {
409
+ if (!this.hasMultipleDecks) return null;
410
+ return this.seatReservations.map((seatReservation) => {
411
+ return html`<b aria-hidden="true">${getI18nSeatReservation(seatReservation.deckCoachLevel, this._language.current)}</b>`;
412
+ });
413
+ }
414
+ _renderNavigationControlButton(btnDirection) {
415
+ if (!this.hasNavigation || !this.seatReservations) return null;
416
+ const btnNavigationDirectionId = btnDirection == "DIRECTION_RIGHT" ? "sbb-sr-navigation__wrapper-button-direction--right" : "sbb-sr-navigation__wrapper-button-direction--left";
417
+ const btnIcon = btnDirection == "DIRECTION_RIGHT" ? "chevron-small-right-small" : "chevron-small-left-small";
418
+ const btnAriaDescription = btnDirection == "DIRECTION_RIGHT" ? getI18nSeatReservation("SEAT_RESERVATION_END", this._language.current) : getI18nSeatReservation("SEAT_RESERVATION_BEGIN", this._language.current);
419
+ let btnDisabled = true;
420
+ if (btnDirection == "DIRECTION_LEFT" && this.selectedCoachIndex > 0) btnDisabled = false;
421
+ else if (btnDirection == "DIRECTION_RIGHT" && this.selectedCoachIndex < this.coachItemDetailsElements.length - 1) btnDisabled = false;
422
+ return html`<div class="sbb-sr-navigation__wrapper-button-direction">
423
+ <sbb-secondary-button
424
+ @click="${() => this.navigateByDirectionBtn(btnDirection)}"
425
+ @focus="${() => this.onFocusNavDirectionButton()}"
426
+ id="${btnNavigationDirectionId}"
427
+ class="sbb-sr__navigation-control-button"
428
+ size="m"
429
+ icon-name="${btnIcon}"
430
+ type="button"
431
+ aria-label="${btnAriaDescription}"
432
+ role="button"
433
+ .disabledInteractive="${btnDisabled || nothing}"
434
+ .disabled="${btnDisabled || nothing}"
435
+ ></sbb-secondary-button>
436
+ </div>`;
437
+ }
438
+ _renderTravelDirection() {
439
+ if (!this.travelDirection || this.travelDirection === "NONE") return null;
440
+ const labelText = getI18nSeatReservation("SEAT_RESERVATION_TRAVEL_DIRECTION", this._language.current);
441
+ return html`<div class="sbb-sr-travel-direction-wrapper">
442
+ <div class="sbb-sr__travel-direction--arrow">
443
+ <sbb-icon slot="icon" name="${`arrow-${this.alignVertical ? this.travelDirection === "RIGHT" ? "down" : "up" : this.travelDirection === "RIGHT" ? "right" : "left"}-small`}"></sbb-icon>
444
+ </div>
445
+ <div class="sbb-sr__travel-direction--label">${labelText}</div>
446
+ </div>`;
447
+ }
448
+ _renderNavigation() {
449
+ if (isServer || !this.hasNavigation || !this.seatReservations) return null;
450
+ return html`<div class="sbb-sr-navigation-wrapper">
451
+ <nav id="sbb-sr-navigation" class="sbb-sr-navigation">
452
+ ${this._renderNavigationControlButton("DIRECTION_LEFT")}
453
+ <ul
454
+ id="sbb-sr__navigation-list-coaches"
455
+ class="sbb-sr-navigation__list-coaches"
456
+ aria-label="${getI18nSeatReservation("SEAT_RESERVATION_NAVIGATION", this._language.current)}"
457
+ >
458
+ ${this.coachItemDetailsElements.map((coachItemDetails, index) => {
459
+ return html`<li>
460
+ <sbb-seat-reservation-navigation-coach
461
+ @selectcoach=${(event) => this._onSelectNavCoach(event)}
462
+ @focuscoach=${() => this._onFocusNavCoach()}
463
+ @keyup=${(evt) => this.onKeyNavigationNavCoachButton(evt, index)}
464
+ index="${index}"
465
+ .selected=${this.selectedCoachIndex === index}
466
+ .focused=${this.focusedCoachIndex === index}
467
+ .hovered=${this.hoveredCoachIndex === index}
468
+ .nativeFocusActive=${this.hasSeatReservationNativeFocus}
469
+ .coachItemDetails="${coachItemDetails}"
470
+ ?vertical="${this.alignVertical}"
471
+ ?showTitleInfo="${this.showTitleInfo}"
472
+ >
473
+ </sbb-seat-reservation-navigation-coach>
474
+ </li>`;
475
+ })}
476
+ </ul>
477
+ ${this._renderNavigationControlButton("DIRECTION_RIGHT")}
478
+ </nav>
479
+ </div>`;
480
+ }
481
+ /**
482
+ *
483
+ * @returns
484
+ * @param seatReservation
485
+ * @param coachDeckIndex
486
+ */
487
+ _renderCoaches(seatReservation, coachDeckIndex) {
488
+ const coaches = JSON.parse(JSON.stringify(seatReservation?.coachItems));
489
+ if (!coaches || isServer) return null;
490
+ return coaches.map((coachItem, coachIndex) => {
491
+ return html`
492
+ <li class="sbb-sr__item-coach">
493
+ ${this._renderCoachElement(coachItem, coachIndex, coachDeckIndex, seatReservation.deckCoachIndex)}
494
+ </li>
495
+ `;
496
+ });
497
+ }
498
+ _renderCoachElement(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex) {
499
+ const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);
500
+ const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);
501
+ return html`<sbb-seat-reservation-scoped
502
+ style=${styleMap({
503
+ "--sbb-seat-reservation-scoped-width": calculatedCoachDimension.w,
504
+ "--sbb-seat-reservation-scoped-height": calculatedCoachDimension.h
505
+ })}
506
+ >
507
+ ${this._getRenderedCoachBorders(coachItem, coachIndex)}
508
+ ${this._getRenderedGraphicalElements(coachItem.graphicElements || [], coachItem.dimension, coachIndex, coachDeckIndex)}
509
+ ${this._getRenderedServiceElements(coachIndex, coachDeckIndex, coachItem.serviceElements)}
510
+
511
+ <table
512
+ @focus=${() => this.onFocusTableCoachAndPreselectPlace(coachIndex)}
513
+ id="sbb-sr-coach-${coachIndex}"
514
+ class="sbb-sr-coach-wrapper__table"
515
+ aria-describedby="sbb-sr-coach-caption-${coachIndex}"
516
+ tabindex="-1"
517
+ >
518
+ <caption id="sbb-sr-coach-caption-${coachIndex}" tabindex="-1">
519
+ <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>
520
+ </caption>
521
+ ${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex)}
522
+ </table>
523
+ </sbb-seat-reservation-scoped>`;
524
+ }
525
+ /**
526
+ * @returns Returns the border graphic (COACH_BORDER_MIDDLE) of a coach with calculated border gap and coach width,
527
+ * depending on whether the coach is with a driver area or without.
528
+ */
529
+ _getRenderedCoachBorders(coachItem, coachIndex) {
530
+ if (!coachItem.graphicElements) return null;
531
+ const COACH_PASSAGE_WIDTH = 1;
532
+ const driverArea = this.coachItemDetailsElements[coachIndex]?.driverAreaElements?.driverArea;
533
+ const driverAreaNoVerticalWall = this.coachItemDetailsElements[coachIndex]?.driverAreaElements?.driverAreaNoVerticalWall;
534
+ let borderWidth = driverArea ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;
535
+ borderWidth *= this.baseGridSize;
536
+ const borderHeight = (coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize;
537
+ let borderOffsetX = driverArea && driverArea.position.x === 0 ? driverArea?.dimension.w * this.baseGridSize : this.baseGridSize;
538
+ if (driverAreaNoVerticalWall) {
539
+ borderWidth = this.getCalculatedDimension(coachItem.dimension).w - 2 * (driverAreaNoVerticalWall.dimension.w * this.baseGridSize);
540
+ borderOffsetX = driverAreaNoVerticalWall.dimension.w * this.baseGridSize;
541
+ }
542
+ const currentCoachOverlappingInfo = this.overHangingElementInformation.find((el) => el.coachId === coachItem.id);
543
+ if (currentCoachOverlappingInfo?.overhangingPlaces || currentCoachOverlappingInfo?.overhangingGraphicAreas) {
544
+ borderWidth += 2 * this.baseGridSize;
545
+ borderOffsetX = 0;
546
+ }
547
+ return html`
548
+ <sbb-seat-reservation-graphic
549
+ class="${classMap({ "sbb-sr-coach-has-overhanging-elements": currentCoachOverlappingInfo?.overhangingPlaces || currentCoachOverlappingInfo?.overhangingGraphicAreas || false })}"
550
+ style=${styleMap({
551
+ "--sbb-seat-reservation-graphic-width": borderWidth,
552
+ "--sbb-seat-reservation-graphic-height": borderHeight,
553
+ "--sbb-seat-reservation-graphic-top": this.coachBorderPadding * -1,
554
+ "--sbb-seat-reservation-graphic-left": borderOffsetX,
555
+ "--sbb-seat-reservation-graphic-position": "absolute"
556
+ })}
557
+ name="COACH_BORDER_MIDDLE"
558
+ ?stretch=${true}
559
+ role="presentation"
560
+ ></sbb-seat-reservation-graphic>
561
+ `;
562
+ }
563
+ _getRenderedRowPlaces(coach, coachIndex, coachDeckIndex, placeCoachDeckIndex) {
564
+ if (!coach.places) return null;
565
+ const tableRowPlaces = {};
566
+ for (const place of coach.places) if (!tableRowPlaces[place.position.y]) tableRowPlaces[place.position.y] = [place];
567
+ else tableRowPlaces[place.position.y].push(place);
568
+ return Object.values(tableRowPlaces).map((rowPlaces, index) => {
569
+ return html`
570
+ <tr id="row-${coachIndex}-${rowPlaces[0].position.y}" data-row-index=${index}>
571
+ ${this._getRenderedColumnPlaces(rowPlaces, coachIndex, coachDeckIndex, placeCoachDeckIndex)}
572
+ </tr>
573
+ `;
574
+ }).flatMap((rowTemplate) => rowTemplate);
575
+ }
576
+ _getRenderedColumnPlaces(places, coachIndex, deckIndex, placeCoachDeckIndex) {
577
+ places.sort((placeA, placeB) => Number(placeA.position.x) - Number(placeB.position.x));
578
+ const trackPlaceId = coachIndex + "-" + placeCoachDeckIndex;
579
+ return html`${repeat(places, (place) => trackPlaceId + "-" + place.number, (place, index) => {
580
+ const calculatedDimension = this.getCalculatedDimension(place.dimension);
581
+ const calculatedPosition = this.getCalculatedPosition(place.position);
582
+ const rotation = place.rotation || 0;
583
+ const textRotation = this.alignVertical ? -90 : 0;
584
+ const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);
585
+ return html`
586
+ <td
587
+ id="cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}"
588
+ class="graphical-element"
589
+ >
590
+ <sbb-seat-reservation-place-control
591
+ style=${styleMap({
592
+ "--sbb-seat-reservation-place-control-text-scale-value": Math.min(calculatedDimension.w, calculatedDimension.h),
593
+ "--sbb-seat-reservation-place-control-width": calculatedDimension.w,
594
+ "--sbb-seat-reservation-place-control-height": calculatedDimension.h,
595
+ "--sbb-seat-reservation-place-control-top": calculatedPosition.y,
596
+ "--sbb-seat-reservation-place-control-left": calculatedPosition.x,
597
+ "--sbb-seat-reservation-place-control-rotation": rotation,
598
+ "--sbb-seat-reservation-place-control-text-rotation": textRotation
599
+ })}
600
+ @selectplace=${(selectPlaceEvent) => this._onSelectPlace(selectPlaceEvent)}
601
+ exportparts="sbb-sr-place-part"
602
+ id=${placeId}
603
+ class="seat-reservation-place-control"
604
+ text=${place.number}
605
+ type=${place.type}
606
+ state=${place.state}
607
+ travel-direction=${this.travelDirection}
608
+ coach-index=${coachIndex}
609
+ deck-index=${placeCoachDeckIndex}
610
+ data-deck-index=${deckIndex}
611
+ .propertyIds=${place.propertyIds}
612
+ .preventClick=${this.preventPlaceClick}
613
+ ?showTitleInfo="${this.showTitleInfo}"
614
+ ></sbb-seat-reservation-place-control>
615
+ </td>
616
+ `;
617
+ })}`;
618
+ }
619
+ _getRenderedGraphicalElements(graphicalElements, coachDimension, coachIndex, coachDeckIndex) {
620
+ if (!graphicalElements) return null;
621
+ return graphicalElements?.map((graphicalElement) => {
622
+ const icon = graphicalElement.icon ?? "";
623
+ const elementRotation = graphicalElement.rotation || 0;
624
+ const isNotFixedRotationGraphicalElement = this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon) === -1;
625
+ const elementFixedRotation = this.alignVertical && isNotFixedRotationGraphicalElement ? elementRotation - 90 : elementRotation;
626
+ if (this.notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);
627
+ return this._getRenderElementWithArea(graphicalElement, elementFixedRotation, coachDimension, coachIndex, coachDeckIndex);
628
+ });
629
+ }
630
+ /**
631
+ * creates a rendered element with an area component
632
+ * @param graphicalElement
633
+ * @param rotation
634
+ * @param coachDimension
635
+ * @param coachIndex used to generate a unique id for the popover trigger
636
+ * @param coachDeckIndex used to generate a unique id
637
+ * @private
638
+ */
639
+ _getRenderElementWithArea(graphicalElement, rotation, coachDimension, coachIndex, coachDeckIndex) {
640
+ const isNotTableGraphic = graphicalElement.icon?.indexOf("TABLE") === -1;
641
+ const areaProperty = graphicalElement.icon && isNotTableGraphic ? graphicalElement.icon : null;
642
+ const stretchHeight = this.isElementDirectlyOnBorder(graphicalElement, coachDimension) && areaProperty !== "ENTRY_EXIT";
643
+ const ariaLabelForArea = graphicalElement.icon ? getI18nSeatReservation(graphicalElement.icon, this._language.current) : nothing;
644
+ const calculatedDimension = this.getCalculatedDimension(graphicalElement.dimension, coachDimension, true, stretchHeight);
645
+ const calculatedPosition = this.getCalculatedPosition(graphicalElement.position, graphicalElement.dimension, coachDimension, true);
646
+ const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;
647
+ let elementMounting = "free";
648
+ if (graphicalElement.position.y === this.coachBorderOffset * -1) elementMounting = "upper-border";
649
+ else if (graphicalElement.position.y + graphicalElement.dimension.h === coachDimension.h + this.coachBorderOffset) elementMounting = "lower-border";
650
+ if (elementMounting !== "free") {
651
+ calculatedPosition.y += elementMounting === "upper-border" ? 2 : 1;
652
+ calculatedDimension.h -= 3;
653
+ }
654
+ return html`
655
+ <sbb-seat-reservation-area
656
+ id="${triggerId}"
657
+ class="${classMap({ "sbb-seat-reservation-area--cursor-pointer": areaProperty !== null })}"
658
+ style=${styleMap({
659
+ "--sbb-seat-reservation-area-width": calculatedDimension.w,
660
+ "--sbb-seat-reservation-area-height": calculatedDimension.h,
661
+ "--sbb-seat-reservation-area-top": calculatedPosition.y,
662
+ "--sbb-seat-reservation-area-left": calculatedPosition.x
663
+ })}
664
+ mounting=${elementMounting}
665
+ background="dark"
666
+ aria-hidden="true"
667
+ >
668
+ ${areaProperty ? html`
669
+ <sbb-seat-reservation-graphic
670
+ style=${styleMap({
671
+ "--sbb-seat-reservation-graphic-max-width": calculatedDimension.w,
672
+ "--sbb-seat-reservation-graphic-height": this.baseGridSize,
673
+ "--sbb-seat-reservation-graphic-rotation": rotation
674
+ })}
675
+ name=${areaProperty}
676
+ role="img"
677
+ aria-hidden="true"
678
+ class="auto-width"
679
+ ></sbb-seat-reservation-graphic>
680
+ ` : nothing}
681
+ </sbb-seat-reservation-area>
682
+ ${areaProperty ? this._popover(triggerId, ariaLabelForArea) : nothing}
683
+ `;
684
+ }
685
+ _getRenderElementWithoutArea(graphicalElement, rotation, coachDimension) {
686
+ const calculatedDimension = this.getCalculatedDimension(graphicalElement.dimension, coachDimension);
687
+ const calculatedPosition = this.getCalculatedPosition(graphicalElement.position, graphicalElement.dimension, coachDimension);
688
+ const icon = graphicalElement.icon && graphicalElement.icon.endsWith("DRIVER_AREA") ? graphicalElement.icon?.concat("_", this.seatReservations[this.currSelectedDeckIndex].vehicleType) : graphicalElement.icon;
689
+ return html` <sbb-seat-reservation-graphic
690
+ style=${styleMap({
691
+ "--sbb-seat-reservation-graphic-width": calculatedDimension.w,
692
+ "--sbb-seat-reservation-graphic-height": calculatedDimension.h,
693
+ "--sbb-seat-reservation-graphic-top": calculatedPosition.y,
694
+ "--sbb-seat-reservation-graphic-left": calculatedPosition.x,
695
+ "--sbb-seat-reservation-graphic-position": "absolute",
696
+ "--sbb-seat-reservation-graphic-rotation": rotation
697
+ })}
698
+ name=${icon ?? nothing}
699
+ aria-hidden="true"
700
+ ?stretch=${true}
701
+ ></sbb-seat-reservation-graphic>`;
702
+ }
703
+ _getRenderedServiceElements(coachIndex, coachDeckIndex, serviceElements) {
704
+ if (!serviceElements) return null;
705
+ return serviceElements?.map((serviceElement) => {
706
+ const titleDescription = serviceElement.icon ? getI18nSeatReservation(serviceElement.icon, this._language.current) : null;
707
+ const calculatedDimension = this.getCalculatedDimension(serviceElement.dimension);
708
+ const calculatedPosition = this.getCalculatedPosition(serviceElement.position);
709
+ const elementRotation = serviceElement.rotation || 0;
710
+ const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;
711
+ const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;
712
+ return html`
713
+ <sbb-seat-reservation-graphic
714
+ id="${triggerId}"
715
+ style=${styleMap({
716
+ "--sbb-seat-reservation-graphic-width": calculatedDimension.w,
717
+ "--sbb-seat-reservation-graphic-height": calculatedDimension.h,
718
+ "--sbb-seat-reservation-graphic-top": calculatedPosition.y,
719
+ "--sbb-seat-reservation-graphic-left": calculatedPosition.x,
720
+ "--sbb-seat-reservation-graphic-position": "absolute",
721
+ "--sbb-seat-reservation-graphic-rotation": elementFixedRotation
722
+ })}
723
+ class="sbb-seat-reservation-graphic--cursor-pointer"
724
+ name=${serviceElement.icon ?? nothing}
725
+ role="img"
726
+ aria-hidden="true"
727
+ ></sbb-seat-reservation-graphic>
728
+ ${this._popover(triggerId, titleDescription)}
729
+ `;
730
+ });
731
+ }
732
+ /**
733
+ * Manages the selected place event triggered from the place
734
+ * Each selection emits an array of all selected places
735
+ * @param selectPlaceEvent
736
+ */
737
+ _onSelectPlace(selectPlaceEvent) {
738
+ const selectedPlace = selectPlaceEvent.detail;
739
+ this.preventCoachScrollByPlaceClick = true;
740
+ this.isCoachGridFocusable = false;
741
+ this.focusedCoachIndex = -1;
742
+ if (!this.hasSeatReservationNativeFocus) this.hasSeatReservationNativeFocus = true;
743
+ if (!this.preventPlaceClick) {
744
+ this.updateSelectedSeatReservationPlaces(selectedPlace);
745
+ this.updateCurrentSelectedPlaceInCoach(selectedPlace);
746
+ }
747
+ }
748
+ _onSelectNavCoach(event) {
749
+ const selectedNavCoachIndex = event.detail;
750
+ this.isKeyboardNavigation = false;
751
+ this.preventCoachScrollByPlaceClick = false;
752
+ this.hasSeatReservationNativeFocus = true;
753
+ if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {
754
+ this.unfocusPlaceElement();
755
+ this.scrollToSelectedNavCoach(selectedNavCoachIndex);
756
+ } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {
757
+ this.updateCurrentSelectedCoach();
758
+ this.preselectPlaceInCoach();
759
+ }
760
+ this._closePopover();
761
+ }
762
+ _onFocusNavCoach() {
763
+ if (!this.preventCoachScrollByPlaceClick) this.preselectPlaceInCoach();
764
+ else this.focusPlaceElement(this.currSelectedPlace);
765
+ this.isAutoScrolling = false;
766
+ }
767
+ /**
768
+ * Creates a popover for extra service information
769
+ * @param triggerId
770
+ * @param popoverContent
771
+ * @private
772
+ */
773
+ _popover(triggerId, popoverContent) {
774
+ return html`
775
+ <sbb-popover trigger="${triggerId}" hover-trigger="">
776
+ <p class="sbb-text-s sbb-sr-popover">${popoverContent}</p>
777
+ </sbb-popover>
778
+ `;
779
+ }
780
+ /**
781
+ * trigger to close all opened popovers (normally only one is opened at a time)
782
+ * @private
783
+ */
784
+ _closePopover() {
785
+ this.shadowRoot?.querySelectorAll("sbb-popover:is(:state(state-opened),[state--state-opened])").forEach((popover) => popover.close());
786
+ }
787
+ _getDescriptionTableCoach(coachItem) {
788
+ if (coachItem.type === "LOCOMOTIVE_COACH") return getI18nSeatReservation("COACH_LOCOMOTIVE", this._language.current);
789
+ if (!coachItem.places?.length) return getI18nSeatReservation("COACH_BLOCKED_TABLE_CAPTION", this._language.current, [coachItem.id]);
790
+ let tableCoachDescription;
791
+ const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements);
792
+ const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements);
793
+ tableCoachDescription = getI18nSeatReservation("COACH_TABLE_CAPTION", this._language.current, [coachItem.id]);
794
+ if (!this.hasNavigation) {
795
+ const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachItem.places);
796
+ const freePlacesTxt = getI18nSeatReservation("COACH_AVAILABLE_NUMBER_OF_PLACES", this._language.current, [freePlaces.seats, freePlaces.bicycles]);
797
+ tableCoachDescription = tableCoachDescription.concat(". ").concat(freePlacesTxt).concat(". ");
798
+ }
799
+ if (!!areaDescriptions || !!serviceDescriptions) {
800
+ tableCoachDescription += ". " + getI18nSeatReservation("COACH_AVAILABLE_SERVICES", this._language.current) + ": ";
801
+ tableCoachDescription += serviceDescriptions + ", " + areaDescriptions + ".";
802
+ }
803
+ return tableCoachDescription;
804
+ }
805
+ _getTitleDescriptionListString(descriptionsElements) {
806
+ const uniqueDescriptions = [];
807
+ return descriptionsElements?.map((descriptionElement) => {
808
+ const icon = descriptionElement.icon;
809
+ if (!icon) return null;
810
+ const descriptionAlreadyExist = uniqueDescriptions.indexOf(icon) > -1;
811
+ const translation = getI18nSeatReservation(descriptionElement.icon, this._language.current);
812
+ const isValidDescription = this._notFixedRotatableAreaIcons.indexOf(icon) === -1 && this.notAreaElements.indexOf(icon) === -1;
813
+ if (!descriptionAlreadyExist) uniqueDescriptions.push(descriptionElement.icon);
814
+ return !!translation && !descriptionAlreadyExist && isValidDescription ? translation : null;
815
+ }).filter((description) => !!description).join(", ");
816
+ }
817
+ };
818
+ //#endregion
819
+ export { SbbSeatReservationElement as t };
820
+
821
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation.component-MOv5kHDC.js","names":[],"sources":["../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.scss?lit&inline","../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"sourcesContent":["@use '@sbb-esta/lyne-elements/core/styles' as sbb;\n@use '../common/styles/seat-reservation-mixins' as sbb-sr-mixins;\n@use '../common/styles/seat-reservation-functions' as sbb-sr-functions;\n\n// Maximum responsive navigation width, consists of the maximum navigation extent minus 2x nav direction buttons 96px and 8px padding.\n$max-coach-navigation-width: calc(960px - 96px - 8px);\n$scrollbar-height: 16px;\n\n:host {\n  // Note: The use of px is intentional here, because many widths/heights, rotations, scales, etc. depends on this.\n  --sbb-seat-reservation-grid-size: 16px;\n  --sbb-seat-reservation-height: 0;\n  --sbb-seat-reservation-decks: 1;\n\n  display: block;\n  height: inherit;\n\n  ::part(coach-floor) {\n    fill: var(--sbb-background-color-2);\n\n    // In High Contrast Mode we set floor color to transparent\n    @include sbb.if-forced-colors {\n      fill: transparent;\n    }\n  }\n}\n\n// rotates the DOM-part \"coach-floor\" by 180 degrees if the host is in RTL mode.\n@include sbb-sr-mixins.rotate-dom-part(coach-floor);\n\n[popover]:where(sbb-popover) {\n  @include sbb.popover-reset;\n\n  .sbb-sr-popover {\n    margin-block: sbb-sr-functions.sr-px-to-rem(4);\n  }\n}\n\n// START - Vertical mode\n:host([align-vertical]) {\n  $coach-navigation-padding: 5;\n  $coach-scrollbar-width: 24;\n  $coach-grid-width: calc(var(--sbb-seat-reservation-height) + $coach-scrollbar-width);\n\n  .sbb-sr__component {\n    flex-direction: row-reverse;\n    justify-content: flex-end;\n    gap: sbb-sr-functions.sr-px-to-rem(22);\n    height: inherit;\n\n    @include sbb.mq($from: small) {\n      gap: sbb-sr-functions.sr-px-to-rem(54);\n    }\n\n    nav.sbb-sr-navigation,\n    ul.sbb-sr-navigation__list-coaches {\n      flex-direction: column;\n    }\n\n    nav.sbb-sr-navigation {\n      padding: sbb-sr-functions.sr-px-to-rem(16) 0;\n\n      .sbb-sr__navigation-control-button {\n        left: sbb-sr-functions.sr-px-to-rem(1);\n        top: 0;\n        rotate: 90deg;\n\n        @include sbb.mq($from: large) {\n          left: sbb-sr-functions.sr-px-to-rem(-1);\n        }\n      }\n\n      ul.sbb-sr-navigation__list-coaches {\n        max-width: initial;\n\n        // Padding needs to visual focus-visible style for nav button inside overflow content,\n        // otherwise focus-visible style is cutted.\n        padding: sbb-sr-functions.sr-px-to-rem($coach-navigation-padding);\n        overflow: hidden scroll;\n\n        // in vertical mode, the li must be flexed; otherwise it would calculate the wrong height\n        // due to useragent style set to \"list-item\" for display\n        li {\n          display: flex;\n        }\n      }\n    }\n  }\n\n  // VERTICAL MODE - LABELMULTIPLE DECKS - LABELS\n  .sbb-sr__wrapper-coach-decks {\n    flex-direction: column;\n\n    .sbb-sr__wrapper-deck-labels {\n      flex-direction: column-reverse;\n      width: sbb-sr-functions.sr-px-to-rem($coach-grid-width);\n      height: initial;\n\n      b {\n        inline-size: calc(50% - sbb-sr-functions.sr-px-to-rem(16));\n        block-size: sbb-sr-functions.sr-px-to-rem(20);\n        margin-bottom: sbb-sr-functions.sr-px-to-rem(16);\n        rotate: initial;\n        writing-mode: initial;\n      }\n    }\n  }\n\n  // VERTICAL MODE - SEATMAP SCROLL AREA\n  .sbb-sr__wrapper-scrollarea {\n    width: sbb-sr-functions.sr-px-to-rem($coach-grid-width);\n    height: 100%;\n    overflow: hidden scroll;\n\n    .sbb-sr__parent {\n      rotate: 90deg;\n    }\n  }\n\n  // VERTICAL MODE - TRAVEL-DIRECTION\n  .sbb-sr-travel-direction-wrapper {\n    width: sbb-sr-functions.sr-px-to-rem(var(--sbb-seat-reservation-height));\n    margin-block-start: sbb-sr-functions.sr-px-to-rem(4);\n  }\n}\n\n// END - Vertical mode\n\n.sbb-sr-navigation {\n  gap: sbb-sr-functions.sr-px-to-rem(3);\n}\n\n.sbb-sr-navigation .sbb-sr__navigation-control-button {\n  position: relative;\n  top: sbb-sr-functions.sr-px-to-rem(2);\n\n  @include sbb.mq($from: large) {\n    top: 0;\n  }\n}\n\n.sbb-sr__component {\n  display: flex;\n  flex-direction: column;\n  gap: calc(sbb-sr-functions.sr-px-to-rem(64) - $scrollbar-height);\n}\n\n// TRAVEL DIRECTION\n.sbb-sr-travel-direction-wrapper {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  column-gap: sbb-sr-functions.sr-px-to-rem(4);\n  margin-block: sbb-sr-functions.sr-px-to-rem(8) sbb-sr-functions.sr-px-to-rem(4);\n  font-size: var(--sbb-text-font-size-s);\n\n  .sbb-sr__travel-direction--arrow {\n    display: flex;\n    align-items: center;\n  }\n}\n\n// NAVIGATION NEW\n.sbb-sr-navigation-wrapper {\n  display: flex;\n}\n\n.sbb-sr-navigation {\n  display: flex;\n  justify-content: center;\n  width: 100%;\n  padding-inline: 16px;\n}\n\n.sbb-sr-navigation__list-coaches {\n  @include sbb.list-reset;\n  @include sbb.scrollbar;\n\n  display: flex;\n  flex-wrap: nowrap;\n  gap: sbb-sr-functions.sr-px-to-rem(4);\n  padding: sbb-sr-functions.sr-px-to-rem(6) sbb-sr-functions.sr-px-to-rem(5) 0;\n  max-width: $max-coach-navigation-width;\n\n  // Set sbb scrollbar transparent by default\n  --sbb-scrollbar-color: transparent;\n\n  overflow: scroll hidden;\n  position: relative;\n}\n\n// --------------- Seat Reservation Main Navigation - END ----------------\n\n// ------------- Seat Reservation Coaches - START -----------------\n.sbb-sr__wrapper-coach-decks {\n  display: flex;\n  overflow: hidden;\n  height: inherit;\n\n  .sbb-sr__wrapper-deck-labels {\n    display: flex;\n    justify-content: space-between;\n    height: sbb-sr-functions.sr-px-to-rem(var(--sbb-seat-reservation-height));\n    writing-mode: vertical-lr;\n\n    b {\n      height: calc(50% - sbb-sr-functions.sr-px-to-rem(16));\n      width: sbb-sr-functions.sr-px-to-rem(20);\n      margin-block-end: 16px;\n      rotate: 180deg;\n      text-align: center;\n      line-height: sbb-sr-functions.sr-px-to-rem(20);\n    }\n  }\n}\n\n.sbb-sr__wrapper-scrollarea {\n  @include sbb.scrollbar;\n\n  overflow: scroll hidden;\n  padding-block: sbb-sr-functions.sr-px-to-rem(8) sbb-sr-functions.sr-px-to-rem(16);\n\n  .sbb-sr__parent {\n    display: flex;\n    flex-direction: column;\n    position: relative;\n  }\n}\n\n.sbb-sr__list-decks {\n  @include sbb.list-reset;\n\n  display: flex;\n  flex-direction: column;\n}\n\n.sbb-sr__list-decks--gap {\n  gap: sbb-sr-functions.sr-px-to-rem(48);\n}\n\n.sbb-sr__list-item-deck {\n  position: relative;\n}\n\n.sbb-sr__list-coaches {\n  @include sbb.list-reset;\n\n  display: flex;\n  gap: sbb-sr-functions.sr-px-to-rem(4);\n}\n\n// If there are overhanging elements we need to increase the gap between coaches\n.sbb-sr__list-decks:has(.sbb-sr-coach-has-overhanging-elements) .sbb-sr__list-coaches {\n  gap: sbb-sr-functions.sr-px-to-rem(8);\n}\n\n.sbb-sr__item-coach {\n  position: relative;\n}\n\n.sbb-sr-coach-wrapper__table {\n  outline: 0;\n}\n","import { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport type { SbbPopoverElement } from '@sbb-esta/lyne-elements/popover.js';\nimport { html, isServer, nothing } from 'lit';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { repeat } from 'lit/directives/repeat.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.ts';\nimport type {\n  CoachItem,\n  CoachItemDetails,\n  Place,\n  ElementDimension,\n  BaseElement,\n  PlaceSelection,\n  SeatReservation,\n} from '../common/types.ts';\nimport { SbbSeatReservationAreaElement } from '../seat-reservation-area/seat-reservation-area.component.ts';\nimport { SbbSeatReservationGraphicElement } from '../seat-reservation-graphic/seat-reservation-graphic.component.ts';\nimport { SbbSeatReservationNavigationCoachElement } from '../seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts';\nimport { SbbSeatReservationPlaceControlElement } from '../seat-reservation-place-control/seat-reservation-place-control.component.ts';\nimport { SbbSeatReservationScopedElement } from '../seat-reservation-scoped/seat-reservation-scoped.component.ts';\n\nimport { SeatReservationBaseElement } from './seat-reservation-base-element.ts';\nimport style from './seat-reservation.scss?lit&inline';\n\nimport '@sbb-esta/lyne-elements/button.js';\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\nimport '@sbb-esta/lyne-elements/popover.js';\n\nSbbSeatReservationAreaElement.define();\nSbbSeatReservationGraphicElement.define();\nSbbSeatReservationPlaceControlElement.define();\nSbbSeatReservationNavigationCoachElement.define();\nSbbSeatReservationScopedElement.define();\n\n/**\n * Main component for the seat reservation.\n *\n */\nexport class SbbSeatReservationElement extends SeatReservationBaseElement {\n  public static override readonly elementName: string = 'sbb-seat-reservation';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  private _language = new SbbLanguageController(this);\n  private _coachesHtmlTemplate?: TemplateResult;\n\n  // Area icons that should not be fixed during rotation when vertical mode is selected\n  private _notFixedRotatableAreaIcons = ['ENTRY_EXIT'];\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('hasNavigation')) {\n      if (this.hasNavigation) {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.removeAttribute('tabindex'));\n      } else {\n        this.shadowRoot\n          ?.querySelectorAll('table')\n          .forEach((table) => table.setAttribute('tabindex', '0'));\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // We need to wait until the first update is complete to init different HTML element dimensions\n    this.updateComplete.then(() => {\n      this.initNavigationSelectionByScrollEvent();\n    });\n  }\n\n  protected override render(): TemplateResult | null {\n    this._initVehicleSeatReservationConstruction();\n    return this._coachesHtmlTemplate || null;\n  }\n\n  private _initVehicleSeatReservationConstruction(): void {\n    this._coachesHtmlTemplate = html`\n      ${this._renderTravelDirection()}\n      <div class=\"sbb-sr__component\">\n        ${this._renderNavigation()}\n        <div\n          class=\"sbb-sr__wrapper-coach-decks\"\n          @keydown=${(evt: KeyboardEvent) => this.keyboardSeatmapEventHandling(evt)}\n        >\n          <div class=\"sbb-sr__wrapper-deck-labels\">${this._renderDeckLabels()}</div>\n          <div\n            @scroll=${() => this.coachAreaScrollend()}\n            id=\"sbb-sr__wrapper-scrollarea\"\n            class=\"sbb-sr__wrapper-scrollarea\"\n            tabindex=\"-1\"\n          >\n            <div id=\"sbb-sr__parent-area\" class=\"sbb-sr__parent\">\n              <ul\n                class=\"${classMap({\n                  'sbb-sr__list-decks': true,\n                  'sbb-sr__list-decks--gap': this.hasMultipleDecks,\n                })}\"\n              >\n                ${this.seatReservations?.map(\n                  (seatReservation: SeatReservation, coachDeckIndex: number) => {\n                    return html`<li class=\"sbb-sr__list-item-deck\">\n                      <ul class=\"sbb-sr__list-coaches\" role=\"presentation\">\n                        ${this._renderCoaches(seatReservation, coachDeckIndex)}\n                      </ul>\n                    </li>`;\n                  },\n                )}\n              </ul>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n\n  private _renderDeckLabels(): TemplateResult[] | null {\n    if (!this.hasMultipleDecks) return null;\n\n    return this.seatReservations.map((seatReservation) => {\n      const deckDescription = getI18nSeatReservation(\n        seatReservation.deckCoachLevel,\n        this._language.current,\n      );\n      return html`<b aria-hidden=\"true\">${deckDescription}</b>`;\n    });\n  }\n\n  private _renderNavigationControlButton(btnDirection: string): TemplateResult | null {\n    if (!this.hasNavigation || !this.seatReservations) return null;\n    const btnNavigationDirectionId =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? 'sbb-sr-navigation__wrapper-button-direction--right'\n        : 'sbb-sr-navigation__wrapper-button-direction--left';\n    const btnIcon =\n      btnDirection == 'DIRECTION_RIGHT' ? 'chevron-small-right-small' : 'chevron-small-left-small';\n    const btnAriaDescription =\n      btnDirection == 'DIRECTION_RIGHT'\n        ? getI18nSeatReservation('SEAT_RESERVATION_END', this._language.current)\n        : getI18nSeatReservation('SEAT_RESERVATION_BEGIN', this._language.current);\n    let btnDisabled = true;\n\n    if (btnDirection == 'DIRECTION_LEFT' && this.selectedCoachIndex > 0) {\n      btnDisabled = false;\n    } else if (\n      btnDirection == 'DIRECTION_RIGHT' &&\n      this.selectedCoachIndex < this.coachItemDetailsElements.length - 1\n    ) {\n      btnDisabled = false;\n    }\n\n    return html`<div class=\"sbb-sr-navigation__wrapper-button-direction\">\n      <sbb-secondary-button\n        @click=\"${() => this.navigateByDirectionBtn(btnDirection)}\"\n        @focus=\"${() => this.onFocusNavDirectionButton()}\"\n        id=\"${btnNavigationDirectionId}\"\n        class=\"sbb-sr__navigation-control-button\"\n        size=\"m\"\n        icon-name=\"${btnIcon}\"\n        type=\"button\"\n        aria-label=\"${btnAriaDescription}\"\n        role=\"button\"\n        .disabledInteractive=\"${btnDisabled || nothing}\"\n        .disabled=\"${btnDisabled || nothing}\"\n      ></sbb-secondary-button>\n    </div>`;\n  }\n\n  private _renderTravelDirection(): TemplateResult | null {\n    if (!this.travelDirection || this.travelDirection === 'NONE') return null;\n\n    const labelText = getI18nSeatReservation(\n      'SEAT_RESERVATION_TRAVEL_DIRECTION',\n      this._language.current,\n    );\n\n    const arrowDirection = this.alignVertical\n      ? this.travelDirection === 'RIGHT'\n        ? 'down'\n        : 'up'\n      : this.travelDirection === 'RIGHT'\n        ? 'right'\n        : 'left';\n\n    const iconName = `arrow-${arrowDirection}-small`;\n\n    return html`<div class=\"sbb-sr-travel-direction-wrapper\">\n      <div class=\"sbb-sr__travel-direction--arrow\">\n        <sbb-icon slot=\"icon\" name=\"${iconName}\"></sbb-icon>\n      </div>\n      <div class=\"sbb-sr__travel-direction--label\">${labelText}</div>\n    </div>`;\n  }\n\n  private _renderNavigation(): TemplateResult | null {\n    if (isServer || !this.hasNavigation || !this.seatReservations) return null;\n    return html`<div class=\"sbb-sr-navigation-wrapper\">\n      <nav id=\"sbb-sr-navigation\" class=\"sbb-sr-navigation\">\n        ${this._renderNavigationControlButton('DIRECTION_LEFT')}\n        <ul\n          id=\"sbb-sr__navigation-list-coaches\"\n          class=\"sbb-sr-navigation__list-coaches\"\n          aria-label=\"${getI18nSeatReservation(\n            'SEAT_RESERVATION_NAVIGATION',\n            this._language.current,\n          )}\"\n        >\n          ${this.coachItemDetailsElements.map(\n            (coachItemDetails: CoachItemDetails, index: number) => {\n              return html`<li>\n                <sbb-seat-reservation-navigation-coach\n                  @selectcoach=${(event: CustomEvent<number>) => this._onSelectNavCoach(event)}\n                  @focuscoach=${() => this._onFocusNavCoach()}\n                  @keyup=${(evt: KeyboardEvent) => this.onKeyNavigationNavCoachButton(evt, index)}\n                  index=\"${index}\"\n                  .selected=${this.selectedCoachIndex === index}\n                  .focused=${this.focusedCoachIndex === index}\n                  .hovered=${this.hoveredCoachIndex === index}\n                  .nativeFocusActive=${this.hasSeatReservationNativeFocus}\n                  .coachItemDetails=\"${coachItemDetails}\"\n                  ?vertical=\"${this.alignVertical}\"\n                  ?showTitleInfo=\"${this.showTitleInfo}\"\n                >\n                </sbb-seat-reservation-navigation-coach>\n              </li>`;\n            },\n          )}\n        </ul>\n        ${this._renderNavigationControlButton('DIRECTION_RIGHT')}\n      </nav>\n    </div>`;\n  }\n  /**\n   *\n   * @returns\n   * @param seatReservation\n   * @param coachDeckIndex\n   */\n  private _renderCoaches(\n    seatReservation: SeatReservation,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    const coaches: CoachItem[] = JSON.parse(JSON.stringify(seatReservation?.coachItems));\n\n    if (!coaches || isServer) {\n      return null;\n    }\n    return coaches.map((coachItem: CoachItem, coachIndex: number) => {\n      return html`\n        <li class=\"sbb-sr__item-coach\">\n          ${this._renderCoachElement(\n            coachItem,\n            coachIndex,\n            coachDeckIndex,\n            seatReservation.deckCoachIndex,\n          )}\n        </li>\n      `;\n    });\n  }\n\n  private _renderCoachElement(\n    coachItem: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult {\n    const calculatedCoachDimension = this.getCalculatedDimension(coachItem.dimension);\n    const descriptionTableCoachWithServices = this._getDescriptionTableCoach(coachItem);\n\n    return html`<sbb-seat-reservation-scoped\n      style=${styleMap({\n        '--sbb-seat-reservation-scoped-width': calculatedCoachDimension.w,\n        '--sbb-seat-reservation-scoped-height': calculatedCoachDimension.h,\n      })}\n    >\n      ${this._getRenderedCoachBorders(coachItem, coachIndex)}\n      ${this._getRenderedGraphicalElements(\n        coachItem.graphicElements || [],\n        coachItem.dimension,\n        coachIndex,\n        coachDeckIndex,\n      )}\n      ${this._getRenderedServiceElements(coachIndex, coachDeckIndex, coachItem.serviceElements)}\n\n      <table\n        @focus=${() => this.onFocusTableCoachAndPreselectPlace(coachIndex)}\n        id=\"sbb-sr-coach-${coachIndex}\"\n        class=\"sbb-sr-coach-wrapper__table\"\n        aria-describedby=\"sbb-sr-coach-caption-${coachIndex}\"\n        tabindex=\"-1\"\n      >\n        <caption id=\"sbb-sr-coach-caption-${coachIndex}\" tabindex=\"-1\">\n          <sbb-screen-reader-only>${descriptionTableCoachWithServices}</sbb-screen-reader-only>\n        </caption>\n        ${this._getRenderedRowPlaces(coachItem, coachIndex, coachDeckIndex, placeCoachDeckIndex)}\n      </table>\n    </sbb-seat-reservation-scoped>`;\n  }\n\n  /**\n   * @returns Returns the border graphic (COACH_BORDER_MIDDLE) of a coach with calculated border gap and coach width,\n   * depending on whether the coach is with a driver area or without.\n   */\n  private _getRenderedCoachBorders(\n    coachItem: CoachItem,\n    coachIndex: number,\n  ): TemplateResult | null {\n    if (!coachItem.graphicElements) return null;\n\n    const COACH_PASSAGE_WIDTH = 1;\n    const driverArea = this.coachItemDetailsElements[coachIndex]?.driverAreaElements?.driverArea;\n    const driverAreaNoVerticalWall =\n      this.coachItemDetailsElements[coachIndex]?.driverAreaElements?.driverAreaNoVerticalWall;\n\n    let borderWidth = driverArea\n      ? coachItem.dimension.w - driverArea.dimension.w - COACH_PASSAGE_WIDTH\n      : coachItem.dimension.w - COACH_PASSAGE_WIDTH * 2;\n\n    //multiply with base grid size always for all kind of borderWidth\n    borderWidth *= this.baseGridSize;\n\n    const borderHeight = (coachItem.dimension.h + this.coachBorderOffset * 2) * this.baseGridSize;\n    let borderOffsetX =\n      driverArea && driverArea.position.x === 0\n        ? driverArea?.dimension.w * this.baseGridSize\n        : this.baseGridSize;\n\n    //recalculate the border width and offset if there is a driver area without vertical wall on both sides\n    if (driverAreaNoVerticalWall) {\n      const coachWidth = this.getCalculatedDimension(coachItem.dimension).w;\n\n      //recalculated borderWidth = coachWidth - 2 * driver area width, since the driver area is on both sides\n      borderWidth = coachWidth - 2 * (driverAreaNoVerticalWall.dimension.w * this.baseGridSize);\n\n      //recalculated borderOffsetX = driver area width, since the border starts after the driver area on the left side\n      borderOffsetX = driverAreaNoVerticalWall.dimension.w * this.baseGridSize;\n    }\n\n    const currentCoachOverlappingInfo = this.overHangingElementInformation.find(\n      (el) => el.coachId === coachItem.id,\n    );\n\n    // check if there are overhanging places or graphical elements to adjust the border width and offset + gap\n    // We do not differentiate whether there is something to be done on both sides as this would lead to unnecessary\n    // complexity. So if there is something on one side, we just increase the coach-border on both sides.\n    if (\n      currentCoachOverlappingInfo?.overhangingPlaces ||\n      currentCoachOverlappingInfo?.overhangingGraphicAreas\n    ) {\n      borderWidth += 2 * this.baseGridSize; // we increase the width by 2 grid sizes to have enough space for protruded places on both sides\n      borderOffsetX = 0; // we start at 0 to have enough space on the left side as well\n    }\n\n    return html`\n      <sbb-seat-reservation-graphic\n        class=\"${classMap({\n          'sbb-sr-coach-has-overhanging-elements':\n            currentCoachOverlappingInfo?.overhangingPlaces ||\n            currentCoachOverlappingInfo?.overhangingGraphicAreas ||\n            false,\n        })}\"\n        style=${styleMap({\n          '--sbb-seat-reservation-graphic-width': borderWidth,\n          '--sbb-seat-reservation-graphic-height': borderHeight,\n          '--sbb-seat-reservation-graphic-top': this.coachBorderPadding * -1,\n          '--sbb-seat-reservation-graphic-left': borderOffsetX,\n          '--sbb-seat-reservation-graphic-position': 'absolute',\n        })}\n        name=\"COACH_BORDER_MIDDLE\"\n        ?stretch=${true}\n        role=\"presentation\"\n      ></sbb-seat-reservation-graphic>\n    `;\n  }\n\n  private _getRenderedRowPlaces(\n    coach: CoachItem,\n    coachIndex: number,\n    coachDeckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!coach.places) {\n      return null;\n    }\n\n    // Prepare rows with the places to render a table\n    const tableRowPlaces: Record<number, Place[]> = {};\n    for (const place of coach.places) {\n      if (!tableRowPlaces[place.position.y]) {\n        tableRowPlaces[place.position.y] = [place];\n      } else {\n        tableRowPlaces[place.position.y].push(place);\n      }\n    }\n\n    return Object.values(tableRowPlaces)\n      .map((rowPlaces: Place[], index) => {\n        return html`\n          <tr id=\"row-${coachIndex}-${rowPlaces[0].position.y}\" data-row-index=${index}>\n            ${this._getRenderedColumnPlaces(\n              rowPlaces,\n              coachIndex,\n              coachDeckIndex,\n              placeCoachDeckIndex,\n            )}\n          </tr>\n        `;\n      })\n      .flatMap((rowTemplate) => rowTemplate);\n  }\n\n  private _getRenderedColumnPlaces(\n    places: Place[],\n    coachIndex: number,\n    deckIndex: number,\n    placeCoachDeckIndex: number,\n  ): TemplateResult | null {\n    //Sorts each place by its ascending x coordinate\n    places.sort(\n      (placeA: Place, placeB: Place) => Number(placeA.position.x) - Number(placeB.position.x),\n    );\n\n    // For rendering the places within a td element, here we use repeat directive for better performance for reusing elements (track by id).\n    const trackPlaceId = coachIndex + '-' + placeCoachDeckIndex;\n    return html`${repeat(\n      places,\n      (place) => trackPlaceId + '-' + place.number,\n      (place, index) => {\n        const calculatedDimension = this.getCalculatedDimension(place.dimension);\n        const calculatedPosition = this.getCalculatedPosition(place.position);\n        const rotation = place.rotation || 0;\n        const textRotation = this.alignVertical ? -90 : 0;\n        const placeId = this.getPlaceElementId(deckIndex, coachIndex, place.number);\n        return html`\n          <td\n            id=\"cell-${deckIndex}-${coachIndex}-${place.position.y}-${index}\"\n            class=\"graphical-element\"\n          >\n            <sbb-seat-reservation-place-control\n              style=${styleMap({\n                '--sbb-seat-reservation-place-control-text-scale-value': Math.min(\n                  calculatedDimension.w,\n                  calculatedDimension.h,\n                ),\n                '--sbb-seat-reservation-place-control-width': calculatedDimension.w,\n                '--sbb-seat-reservation-place-control-height': calculatedDimension.h,\n                '--sbb-seat-reservation-place-control-top': calculatedPosition.y,\n                '--sbb-seat-reservation-place-control-left': calculatedPosition.x,\n                '--sbb-seat-reservation-place-control-rotation': rotation,\n                '--sbb-seat-reservation-place-control-text-rotation': textRotation,\n              })}\n              @selectplace=${(selectPlaceEvent: CustomEvent<PlaceSelection>) =>\n                this._onSelectPlace(selectPlaceEvent)}\n              exportparts=\"sbb-sr-place-part\"\n              id=${placeId}\n              class=\"seat-reservation-place-control\"\n              text=${place.number}\n              type=${place.type}\n              state=${place.state}\n              travel-direction=${this.travelDirection}\n              coach-index=${coachIndex}\n              deck-index=${placeCoachDeckIndex}\n              data-deck-index=${deckIndex}\n              .propertyIds=${place.propertyIds}\n              .preventClick=${this.preventPlaceClick}\n              ?showTitleInfo=\"${this.showTitleInfo}\"\n            ></sbb-seat-reservation-place-control>\n          </td>\n        `;\n      },\n    )}`;\n  }\n\n  private _getRenderedGraphicalElements(\n    graphicalElements: BaseElement[],\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult[] | null {\n    if (!graphicalElements) return null;\n\n    return graphicalElements?.map((graphicalElement: BaseElement) => {\n      const icon = graphicalElement.icon ?? '';\n      const elementRotation = graphicalElement.rotation || 0;\n      const isNotFixedRotationGraphicalElement =\n        this._notFixedRotatableAreaIcons.indexOf(graphicalElement.icon!) === -1;\n      const elementFixedRotation =\n        this.alignVertical && isNotFixedRotationGraphicalElement\n          ? elementRotation - 90\n          : elementRotation;\n\n      //check if the current element is not an area element, since this element is drawn without an area component\n      if (this.notAreaElements.findIndex((notAreaElement) => notAreaElement === icon) > -1) {\n        return this._getRenderElementWithoutArea(graphicalElement, elementRotation, coachDimension);\n      }\n      return this._getRenderElementWithArea(\n        graphicalElement,\n        elementFixedRotation,\n        coachDimension,\n        coachIndex,\n        coachDeckIndex,\n      );\n    });\n  }\n\n  /**\n   * creates a rendered element with an area component\n   * @param graphicalElement\n   * @param rotation\n   * @param coachDimension\n   * @param coachIndex used to generate a unique id for the popover trigger\n   * @param coachDeckIndex used to generate a unique id\n   * @private\n   */\n  private _getRenderElementWithArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n    coachIndex: number,\n    coachDeckIndex: number,\n  ): TemplateResult {\n    // for TABLE, we use the area component itself to display the table instead of the SVG graphic.\n    // Due to different heights and widths, it wouldn't show correctly. To correct this, we would\n    // need difficult calculations for position, rotation and dimension.\n    const isNotTableGraphic = graphicalElement.icon?.indexOf('TABLE') === -1;\n    const areaProperty = graphicalElement.icon && isNotTableGraphic ? graphicalElement.icon : null;\n    const stretchHeight =\n      this.isElementDirectlyOnBorder(graphicalElement, coachDimension) &&\n      areaProperty !== 'ENTRY_EXIT';\n    const ariaLabelForArea = graphicalElement.icon\n      ? getI18nSeatReservation(graphicalElement.icon, this._language.current)\n      : nothing;\n\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n      stretchHeight,\n    );\n\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n      true,\n    );\n\n    //generate unique index number for the trigger element\n    const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n    let elementMounting = 'free';\n\n    if (graphicalElement.position.y === this.coachBorderOffset * -1) {\n      elementMounting = 'upper-border';\n    } else if (\n      graphicalElement.position.y + graphicalElement.dimension.h ===\n      coachDimension.h + this.coachBorderOffset\n    ) {\n      elementMounting = 'lower-border';\n    }\n\n    // TIMO-45830\n    // If area elements are located at the border of coach,\n    // we have to manually modify the position and height of the area element,\n    // so that we get a gap from the visuel coach border\n    if (elementMounting !== 'free') {\n      calculatedPosition.y += elementMounting === 'upper-border' ? 2 : 1;\n      calculatedDimension.h -= 3;\n    }\n    return html`\n      <sbb-seat-reservation-area\n        id=\"${triggerId}\"\n        class=\"${classMap({ 'sbb-seat-reservation-area--cursor-pointer': areaProperty !== null })}\"\n        style=${styleMap({\n          '--sbb-seat-reservation-area-width': calculatedDimension.w,\n          '--sbb-seat-reservation-area-height': calculatedDimension.h,\n          '--sbb-seat-reservation-area-top': calculatedPosition.y,\n          '--sbb-seat-reservation-area-left': calculatedPosition.x,\n        })}\n        mounting=${elementMounting}\n        background=\"dark\"\n        aria-hidden=\"true\"\n      >\n        ${areaProperty\n          ? html`\n              <sbb-seat-reservation-graphic\n                style=${styleMap({\n                  '--sbb-seat-reservation-graphic-max-width': calculatedDimension.w,\n                  '--sbb-seat-reservation-graphic-height': this.baseGridSize,\n                  '--sbb-seat-reservation-graphic-rotation': rotation,\n                })}\n                name=${areaProperty}\n                role=\"img\"\n                aria-hidden=\"true\"\n                class=\"auto-width\"\n              ></sbb-seat-reservation-graphic>\n            `\n          : nothing}\n      </sbb-seat-reservation-area>\n      ${areaProperty ? this._popover(triggerId, ariaLabelForArea) : nothing}\n    `;\n  }\n\n  private _getRenderElementWithoutArea(\n    graphicalElement: BaseElement,\n    rotation: number,\n    coachDimension: ElementDimension,\n  ): TemplateResult {\n    const calculatedDimension = this.getCalculatedDimension(\n      graphicalElement.dimension,\n      coachDimension,\n    );\n    const calculatedPosition = this.getCalculatedPosition(\n      graphicalElement.position,\n      graphicalElement.dimension,\n      coachDimension,\n    );\n\n    // If the icon is the driver area, then here concat the vehicle type to get the right vehicle chassis icon\n    const icon =\n      graphicalElement.icon && graphicalElement.icon.endsWith('DRIVER_AREA')\n        ? graphicalElement.icon?.concat(\n            '_',\n            this.seatReservations[this.currSelectedDeckIndex].vehicleType,\n          )\n        : graphicalElement.icon;\n\n    return html` <sbb-seat-reservation-graphic\n      style=${styleMap({\n        '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n        '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n        '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n        '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n        '--sbb-seat-reservation-graphic-position': 'absolute',\n        '--sbb-seat-reservation-graphic-rotation': rotation,\n      })}\n      name=${icon ?? nothing}\n      aria-hidden=\"true\"\n      ?stretch=${true}\n    ></sbb-seat-reservation-graphic>`;\n  }\n\n  private _getRenderedServiceElements(\n    coachIndex: number,\n    coachDeckIndex: number,\n    serviceElements?: BaseElement[],\n  ): TemplateResult[] | null {\n    if (!serviceElements) return null;\n\n    return serviceElements?.map((serviceElement: BaseElement) => {\n      const titleDescription = serviceElement.icon\n        ? getI18nSeatReservation(serviceElement.icon, this._language.current)\n        : null;\n      const calculatedDimension = this.getCalculatedDimension(serviceElement.dimension);\n      const calculatedPosition = this.getCalculatedPosition(serviceElement.position);\n      const elementRotation = serviceElement.rotation || 0;\n      const elementFixedRotation = this.alignVertical ? elementRotation - 90 : elementRotation;\n\n      //generate unique index number for the trigger element\n      const triggerId = `popover-trigger-${coachDeckIndex}-${coachIndex}-${calculatedPosition.x}-${calculatedPosition.y}`;\n\n      return html`\n        <sbb-seat-reservation-graphic\n          id=\"${triggerId}\"\n          style=${styleMap({\n            '--sbb-seat-reservation-graphic-width': calculatedDimension.w,\n            '--sbb-seat-reservation-graphic-height': calculatedDimension.h,\n            '--sbb-seat-reservation-graphic-top': calculatedPosition.y,\n            '--sbb-seat-reservation-graphic-left': calculatedPosition.x,\n            '--sbb-seat-reservation-graphic-position': 'absolute',\n            '--sbb-seat-reservation-graphic-rotation': elementFixedRotation,\n          })}\n          class=\"sbb-seat-reservation-graphic--cursor-pointer\"\n          name=${serviceElement.icon ?? nothing}\n          role=\"img\"\n          aria-hidden=\"true\"\n        ></sbb-seat-reservation-graphic>\n        ${this._popover(triggerId, titleDescription)}\n      `;\n    });\n  }\n\n  /**\n   * Manages the selected place event triggered from the place\n   * Each selection emits an array of all selected places\n   * @param selectPlaceEvent\n   */\n  private _onSelectPlace(selectPlaceEvent: CustomEvent<PlaceSelection>): void {\n    const selectedPlace = selectPlaceEvent.detail;\n    // We have to set preventCoachScrollByPlaceClick to true, to prevent automatic scrolling to the new focused place\n    this.preventCoachScrollByPlaceClick = true;\n    this.isCoachGridFocusable = false;\n    this.focusedCoachIndex = -1;\n    // Check any keyboard event was triggered inside the seat reservation component,\n    // so we can say the native browser focus lies on the component\n    if (!this.hasSeatReservationNativeFocus) {\n      this.hasSeatReservationNativeFocus = true;\n    }\n\n    if (!this.preventPlaceClick) {\n      // Add place to place collection\n      this.updateSelectedSeatReservationPlaces(selectedPlace);\n      this.updateCurrentSelectedPlaceInCoach(selectedPlace);\n    }\n  }\n\n  private _onSelectNavCoach(event: CustomEvent<number>): void {\n    const selectedNavCoachIndex = event.detail;\n\n    this.isKeyboardNavigation = false;\n    this.preventCoachScrollByPlaceClick = false;\n    this.hasSeatReservationNativeFocus = true;\n\n    if (selectedNavCoachIndex !== null && selectedNavCoachIndex !== this.currSelectedCoachIndex) {\n      this.unfocusPlaceElement();\n      this.scrollToSelectedNavCoach(selectedNavCoachIndex);\n    } else if (selectedNavCoachIndex === this.currSelectedCoachIndex) {\n      this.updateCurrentSelectedCoach();\n      this.preselectPlaceInCoach();\n    }\n\n    //close all opened popovers\n    this._closePopover();\n  }\n\n  private _onFocusNavCoach(): void {\n    if (!this.preventCoachScrollByPlaceClick) {\n      this.preselectPlaceInCoach();\n    } else {\n      this.focusPlaceElement(this.currSelectedPlace);\n    }\n\n    this.isAutoScrolling = false;\n  }\n\n  /**\n   * Creates a popover for extra service information\n   * @param triggerId\n   * @param popoverContent\n   * @private\n   */\n  private _popover(\n    triggerId: string,\n    popoverContent: string | null | typeof nothing,\n  ): TemplateResult {\n    return html`\n      <sbb-popover trigger=\"${triggerId}\" hover-trigger=\"\">\n        <p class=\"sbb-text-s sbb-sr-popover\">${popoverContent}</p>\n      </sbb-popover>\n    `;\n  }\n\n  /**\n   * trigger to close all opened popovers (normally only one is opened at a time)\n   * @private\n   */\n  private _closePopover(): void {\n    this.shadowRoot\n      ?.querySelectorAll<SbbPopoverElement>('sbb-popover:state(state-opened)')\n      .forEach((popover) => popover.close());\n  }\n\n  private _getDescriptionTableCoach(coachItem: CoachItem): string {\n    //show different table caption for screenreader if it is a locomotive\n    if (coachItem.type === 'LOCOMOTIVE_COACH') {\n      return getI18nSeatReservation('COACH_LOCOMOTIVE', this._language.current);\n    }\n\n    if (!coachItem.places?.length) {\n      return getI18nSeatReservation('COACH_BLOCKED_TABLE_CAPTION', this._language.current, [\n        coachItem.id,\n      ]);\n    }\n\n    let tableCoachDescription: string;\n    const areaDescriptions = this._getTitleDescriptionListString(coachItem.graphicElements!);\n    const serviceDescriptions = this._getTitleDescriptionListString(coachItem.serviceElements!);\n\n    tableCoachDescription = getI18nSeatReservation('COACH_TABLE_CAPTION', this._language.current, [\n      coachItem.id,\n    ]);\n\n    if (!this.hasNavigation) {\n      // Expands the number of available seats and bicycle spaces as info\n      const freePlaces = this.getAvailableFreePlacesNumFromCoach(coachItem.places);\n      const freePlacesTxt = getI18nSeatReservation(\n        'COACH_AVAILABLE_NUMBER_OF_PLACES',\n        this._language.current,\n        [freePlaces.seats, freePlaces.bicycles],\n      );\n      tableCoachDescription = tableCoachDescription.concat('. ').concat(freePlacesTxt).concat('. ');\n    }\n\n    if (!!areaDescriptions || !!serviceDescriptions) {\n      tableCoachDescription +=\n        '. ' + getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      tableCoachDescription += serviceDescriptions + ', ' + areaDescriptions + '.';\n    }\n    return tableCoachDescription;\n  }\n\n  private _getTitleDescriptionListString(descriptionsElements: BaseElement[]): string {\n    const uniqueDescriptions: string[] = [];\n\n    return descriptionsElements\n      ?.map((descriptionElement) => {\n        const icon = descriptionElement.icon;\n        if (!icon) return null;\n\n        const descriptionAlreadyExist = uniqueDescriptions.indexOf(icon) > -1;\n        const translation = getI18nSeatReservation(\n          descriptionElement.icon!,\n          this._language.current,\n        );\n        const isValidDescription =\n          this._notFixedRotatableAreaIcons.indexOf(icon) === -1 &&\n          this.notAreaElements.indexOf(icon) === -1;\n\n        if (!descriptionAlreadyExist) {\n          uniqueDescriptions.push(descriptionElement.icon!);\n        }\n        return !!translation && !descriptionAlreadyExist && isValidDescription ? translation : null;\n      })\n      .filter((description) => !!description)\n      .join(', ');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation': SbbSeatReservationElement;\n  }\n}\n"],"mappings":"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"}