@sbb-esta/lyne-elements-experimental-dev 4.12.0-dev.1777535350 → 4.12.0-dev.1777543950
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +220 -99
- package/development/seat-reservation/common/types.d.ts +3 -4
- package/development/seat-reservation/common/types.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts +38 -7
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation-base-element.js +143 -32
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts +2 -13
- package/development/seat-reservation/seat-reservation/seat-reservation.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation/seat-reservation.component.js +1 -1
- package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +1 -1
- package/development/seat-reservation/seat-reservation-area.js +1 -1
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +1 -1
- package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +1 -1
- package/development/seat-reservation/seat-reservation-graphic.js +1 -1
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.d.ts.map +1 -1
- package/development/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +1 -1
- package/development/seat-reservation/seat-reservation-navigation-coach.js +1 -1
- package/development/seat-reservation/seat-reservation.js +1 -1
- package/development/seat-reservation-area.component-BWdrKqek.js +96 -0
- package/development/seat-reservation-graphic.component-CN5sWn0I.js +129 -0
- package/development/{seat-reservation-navigation-coach.component-CjoDkcVU.js → seat-reservation-navigation-coach.component-tDZkXl-3.js} +3 -3
- package/development/seat-reservation.component-DyB5FVpD.js +464 -0
- package/development/seat-reservation.js +4 -4
- package/development/seat-reservation.pure.js +4 -4
- package/package.json +2 -2
- package/seat-reservation/seat-reservation/seat-reservation-base-element.js +130 -77
- package/seat-reservation/seat-reservation/seat-reservation.component.js +1 -1
- package/seat-reservation/seat-reservation-area/seat-reservation-area.component.js +1 -1
- package/seat-reservation/seat-reservation-area.js +1 -1
- package/seat-reservation/seat-reservation-graphic/seat-reservation-assets.js +1 -1
- package/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js +1 -1
- package/seat-reservation/seat-reservation-graphic.js +1 -1
- package/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.js +1 -1
- package/seat-reservation/seat-reservation-navigation-coach.js +1 -1
- package/seat-reservation/seat-reservation.js +1 -1
- package/{seat-reservation-area.component-CtYawDjE.js → seat-reservation-area.component-B5_N7H_a.js} +1 -1
- package/seat-reservation-graphic.component-Dh1e2Pve.js +102 -0
- package/{seat-reservation-navigation-coach.component-sug9IBTH.js → seat-reservation-navigation-coach.component-BdCUfksf.js} +2 -2
- package/{seat-reservation.component-DajC6fqU.js → seat-reservation.component-DEtsEzex.js} +74 -81
- package/seat-reservation.js +4 -4
- package/seat-reservation.pure.js +4 -4
- package/development/seat-reservation-area.component-DbeuTnXT.js +0 -96
- package/development/seat-reservation-graphic.component-DlrHtlia.js +0 -129
- package/development/seat-reservation.component-DFJVFmrI.js +0 -510
- package/seat-reservation-graphic.component-Cm_pVxaB.js +0 -102
|
@@ -9,7 +9,6 @@ export declare class SbbSeatReservationElement extends SeatReservationBaseElemen
|
|
|
9
9
|
static styles: CSSResultGroup;
|
|
10
10
|
private _language;
|
|
11
11
|
private _coachesHtmlTemplate?;
|
|
12
|
-
private _notFixedRotatableAreaIcons;
|
|
13
12
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
14
13
|
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
15
14
|
protected render(): TemplateResult | null;
|
|
@@ -33,18 +32,8 @@ export declare class SbbSeatReservationElement extends SeatReservationBaseElemen
|
|
|
33
32
|
private _getRenderedCoachBorders;
|
|
34
33
|
private _getRenderedRowPlaces;
|
|
35
34
|
private _getRenderedColumnPlaces;
|
|
36
|
-
private
|
|
37
|
-
|
|
38
|
-
* creates a rendered element with an area component
|
|
39
|
-
* @param graphicalElement
|
|
40
|
-
* @param rotation
|
|
41
|
-
* @param coachDimension
|
|
42
|
-
* @param coachIndex used to generate a unique id for the popover trigger
|
|
43
|
-
* @param coachDeckIndex used to generate a unique id
|
|
44
|
-
* @private
|
|
45
|
-
*/
|
|
46
|
-
private _getRenderElementWithArea;
|
|
47
|
-
private _getRenderElementWithoutArea;
|
|
35
|
+
private _getRenderedCoachElements;
|
|
36
|
+
private _getRenderedAreaElements;
|
|
48
37
|
private _getRenderedServiceElements;
|
|
49
38
|
/**
|
|
50
39
|
* Manages the selected place event triggered from the place
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAGA,OAAO,
|
|
1
|
+
{"version":3,"file":"seat-reservation.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation/seat-reservation.component.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,KAAK,cAAc,EAInB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAoBb,OAAO,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AAGhF,OAAO,mCAAmC,CAAC;AAC3C,OAAO,+CAA+C,CAAC;AACvD,OAAO,oCAAoC,CAAC;AAQ5C;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,0BAA0B;IACvE,gBAAgC,WAAW,EAAE,MAAM,CAA0B;IAC7E,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,oBAAoB,CAAC,CAAiB;cAE3B,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAgBzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAS3D,MAAM,IAAI,cAAc,GAAG,IAAI;IAKlD,OAAO,CAAC,uCAAuC;IAwC/C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,8BAA8B;IAwCtC,OAAO,CAAC,sBAAsB;IA0B9B,OAAO,CAAC,iBAAiB;IAsCzB;;;;;OAKG;IACH,OAAO,CAAC,cAAc;IAuBtB,OAAO,CAAC,mBAAmB;IAmC3B;;;OAGG;IACH,OAAO,CAAC,wBAAwB;IA+BhC,OAAO,CAAC,qBAAqB;IAmC7B,OAAO,CAAC,wBAAwB;IA8DhC,OAAO,CAAC,yBAAyB;IAwBjC,OAAO,CAAC,wBAAwB;IAyDhC,OAAO,CAAC,2BAA2B;IAmCnC;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,iBAAiB;IAmBzB,OAAO,CAAC,gBAAgB;IAUxB;;;;;OAKG;IACH,OAAO,CAAC,QAAQ;IAWhB;;;OAGG;IACH,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,yBAAyB;IAuCjC,OAAO,CAAC,8BAA8B;CAyBvC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,sBAAsB,EAAE,yBAAyB,CAAC;KACnD;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSeatReservationElement } from "../../seat-reservation.component-
|
|
1
|
+
import { t as SbbSeatReservationElement } from "../../seat-reservation.component-DyB5FVpD.js";
|
|
2
2
|
export { SbbSeatReservationElement };
|
package/development/seat-reservation/seat-reservation-area/seat-reservation-area.component.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSeatReservationAreaElement } from "../../seat-reservation-area.component-
|
|
1
|
+
import { t as SbbSeatReservationAreaElement } from "../../seat-reservation-area.component-BWdrKqek.js";
|
|
2
2
|
export { SbbSeatReservationAreaElement };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbSeatReservationAreaElement } from "../seat-reservation-area.component-
|
|
1
|
+
import { t as SbbSeatReservationAreaElement } from "../seat-reservation-area.component-BWdrKqek.js";
|
|
2
2
|
//#region src/elements-experimental/seat-reservation/seat-reservation-area.ts
|
|
3
3
|
/** @entrypoint */
|
|
4
4
|
SbbSeatReservationAreaElement.define();
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbSeatReservationGraphicElement } from "../../seat-reservation-graphic.component-
|
|
1
|
+
import { t as SbbSeatReservationGraphicElement } from "../../seat-reservation-graphic.component-CN5sWn0I.js";
|
|
2
2
|
import { html } from "lit";
|
|
3
3
|
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
4
4
|
import { mapIconToSvg } from "../common/mapper.js";
|
package/development/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSeatReservationGraphicElement } from "../../seat-reservation-graphic.component-
|
|
1
|
+
import { t as SbbSeatReservationGraphicElement } from "../../seat-reservation-graphic.component-CN5sWn0I.js";
|
|
2
2
|
export { SbbSeatReservationGraphicElement };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbSeatReservationGraphicElement } from "../seat-reservation-graphic.component-
|
|
1
|
+
import { t as SbbSeatReservationGraphicElement } from "../seat-reservation-graphic.component-CN5sWn0I.js";
|
|
2
2
|
//#region src/elements-experimental/seat-reservation/seat-reservation-graphic.ts
|
|
3
3
|
/** @entrypoint */
|
|
4
4
|
SbbSeatReservationGraphicElement.define();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+CAA+C,CAAC;AAI3E,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAKb,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAK3D,OAAO,+CAA+C,CAAC;AAIvD,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC;AAE7C;;GAEG;AACH,qBAAa,wCAAyC,SAAQ,UAAU;IACtE,gBAAgC,WAAW,EAAE,MAAM,CAA2C;IAC9F,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;;MAGlB;IAEX,4BAA4B;IAC5B,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,2BAA2B;IAC3B,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,2BAA2B;IAC3B,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,8FAA8F;IAC9F,SAEgB,iBAAiB,EAAE,OAAO,CAAQ;IAElD,SAEgB,KAAK,EAAE,MAAM,CAAK;IAElC,SACgB,gBAAgB,EAAE,gBAAgB,CAAwB;IAE1E,mCAAmC;IACnC,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,6DAA6D;IAC7D,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,+CAA+C;IAC/C,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IA2B5E;;;;OAIG;cACgB,MAAM,IAAI,cAAc;IAwB3C,OAAO,CAAC,oBAAoB;IAyB5B,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,kCAAkC;
|
|
1
|
+
{"version":3,"file":"seat-reservation-navigation-coach.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,+CAA+C,CAAC;AAI3E,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAKb,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAK3D,OAAO,+CAA+C,CAAC;AAIvD,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC;AAE7C;;GAEG;AACH,qBAAa,wCAAyC,SAAQ,UAAU;IACtE,gBAAgC,WAAW,EAAE,MAAM,CAA2C;IAC9F,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;;MAGlB;IAEX,4BAA4B;IAC5B,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,2BAA2B;IAC3B,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,2BAA2B;IAC3B,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,8FAA8F;IAC9F,SAEgB,iBAAiB,EAAE,OAAO,CAAQ;IAElD,SAEgB,KAAK,EAAE,MAAM,CAAK;IAElC,SACgB,gBAAgB,EAAE,gBAAgB,CAAwB;IAE1E,mCAAmC;IACnC,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,6DAA6D;IAC7D,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,+CAA+C;IAC/C,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,OAAO,CAAC,SAAS,CAAmC;cAEjC,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IA2B5E;;;;OAIG;cACgB,MAAM,IAAI,cAAc;IAwB3C,OAAO,CAAC,oBAAoB;IAyB5B,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,kCAAkC;IAyC1C,OAAO,CAAC,gCAAgC;IAaxC;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAcvB,OAAO,CAAC,2BAA2B;CAOpC;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uCAAuC,EAAE,wCAAwC,CAAC;KACnF;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSeatReservationNavigationCoachElement } from "../../seat-reservation-navigation-coach.component-
|
|
1
|
+
import { t as SbbSeatReservationNavigationCoachElement } from "../../seat-reservation-navigation-coach.component-tDZkXl-3.js";
|
|
2
2
|
export { SbbSeatReservationNavigationCoachElement };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbSeatReservationNavigationCoachElement } from "../seat-reservation-navigation-coach.component-
|
|
1
|
+
import { t as SbbSeatReservationNavigationCoachElement } from "../seat-reservation-navigation-coach.component-tDZkXl-3.js";
|
|
2
2
|
//#region src/elements-experimental/seat-reservation/seat-reservation-navigation-coach.ts
|
|
3
3
|
/** @entrypoint */
|
|
4
4
|
SbbSeatReservationNavigationCoachElement.define();
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { SeatReservationBaseElement } from "./seat-reservation/seat-reservation-base-element.js";
|
|
2
|
-
import { t as SbbSeatReservationElement } from "../seat-reservation.component-
|
|
2
|
+
import { t as SbbSeatReservationElement } from "../seat-reservation.component-DyB5FVpD.js";
|
|
3
3
|
//#region src/elements-experimental/seat-reservation/seat-reservation.ts
|
|
4
4
|
/** @entrypoint */
|
|
5
5
|
SbbSeatReservationElement.define();
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { SbbElement } from "@sbb-esta/lyne-elements/core/base-elements.js";
|
|
3
|
+
import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
|
|
4
|
+
import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
|
|
5
|
+
import { html, unsafeCSS } from "lit";
|
|
6
|
+
import { property } from "lit/decorators.js";
|
|
7
|
+
//#region src/elements-experimental/seat-reservation/seat-reservation-area/seat-reservation-area.scss?inline
|
|
8
|
+
var seat_reservation_area_default = ":host {\n --sbb-seat-reservation-area-border-radius: var(--sbb-border-width-4x);\n --sbb-seat-reservation-area-rotation: 0;\n --sbb-seat-reservation-area-z-index: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n height: calc(var(--sbb-seat-reservation-area-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n width: calc(var(--sbb-seat-reservation-area-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n border: var(--sbb-border-width-1x) solid var(--sbb-color-graphite);\n border: var(--sbb-border-width-1x) solid light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n border-radius: var(--sbb-seat-reservation-area-border-radius);\n position: absolute;\n z-index: var(--sbb-seat-reservation-area-z-index);\n inset-block-start: calc(var(--sbb-seat-reservation-area-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n inset-inline-start: calc(var(--sbb-seat-reservation-area-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n rotate: calc(var(--sbb-seat-reservation-area-rotation) * 1deg);\n line-height: normal;\n background-color: var(--sbb-background-color-2);\n}\n\n:host([background=dark]) {\n background-color: var(--sbb-color-milk);\n background-color: light-dark(var(--sbb-color-milk), var(--sbb-color-iron));\n}\n\n:host([mounting=upper-border]) {\n border-block-start-width: 0;\n border-radius: 0 0 var(--sbb-seat-reservation-area-border-radius) var(--sbb-seat-reservation-area-border-radius);\n}\n\n:host([mounting=lower-border]) {\n border-block-end-width: 0;\n border-radius: var(--sbb-seat-reservation-area-border-radius) var(--sbb-seat-reservation-area-border-radius) 0 0;\n}\n\n:host([mounting=upper-to-lower-border]) {\n border-block-start: none;\n border-block-end: none;\n border-radius: 0;\n}\n\n:host(.sbb-seat-reservation-area--cursor-pointer) {\n cursor: var(--sbb-cursor-pointer);\n}";
|
|
9
|
+
//#endregion
|
|
10
|
+
//#region src/elements-experimental/seat-reservation/seat-reservation-area/seat-reservation-area.component.ts
|
|
11
|
+
/**
|
|
12
|
+
* Visualize an area with a special meaning within a wagon.
|
|
13
|
+
*/
|
|
14
|
+
var SbbSeatReservationAreaElement = (() => {
|
|
15
|
+
let _classSuper = SbbElement;
|
|
16
|
+
let _mounting_decorators;
|
|
17
|
+
let _mounting_initializers = [];
|
|
18
|
+
let _mounting_extraInitializers = [];
|
|
19
|
+
let _background_decorators;
|
|
20
|
+
let _background_initializers = [];
|
|
21
|
+
let _background_extraInitializers = [];
|
|
22
|
+
return class SbbSeatReservationAreaElement extends _classSuper {
|
|
23
|
+
static {
|
|
24
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
25
|
+
_mounting_decorators = [forceType(), property({ reflect: true })];
|
|
26
|
+
_background_decorators = [forceType(), property({ reflect: true })];
|
|
27
|
+
__esDecorate(this, null, _mounting_decorators, {
|
|
28
|
+
kind: "accessor",
|
|
29
|
+
name: "mounting",
|
|
30
|
+
static: false,
|
|
31
|
+
private: false,
|
|
32
|
+
access: {
|
|
33
|
+
has: (obj) => "mounting" in obj,
|
|
34
|
+
get: (obj) => obj.mounting,
|
|
35
|
+
set: (obj, value) => {
|
|
36
|
+
obj.mounting = value;
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
metadata: _metadata
|
|
40
|
+
}, _mounting_initializers, _mounting_extraInitializers);
|
|
41
|
+
__esDecorate(this, null, _background_decorators, {
|
|
42
|
+
kind: "accessor",
|
|
43
|
+
name: "background",
|
|
44
|
+
static: false,
|
|
45
|
+
private: false,
|
|
46
|
+
access: {
|
|
47
|
+
has: (obj) => "background" in obj,
|
|
48
|
+
get: (obj) => obj.background,
|
|
49
|
+
set: (obj, value) => {
|
|
50
|
+
obj.background = value;
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
metadata: _metadata
|
|
54
|
+
}, _background_initializers, _background_extraInitializers);
|
|
55
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
56
|
+
enumerable: true,
|
|
57
|
+
configurable: true,
|
|
58
|
+
writable: true,
|
|
59
|
+
value: _metadata
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
static {
|
|
63
|
+
this.elementName = "sbb-seat-reservation-area";
|
|
64
|
+
}
|
|
65
|
+
static {
|
|
66
|
+
this.styles = [boxSizingStyles, unsafeCSS(seat_reservation_area_default)];
|
|
67
|
+
}
|
|
68
|
+
#mounting_accessor_storage = __runInitializers(this, _mounting_initializers, "free");
|
|
69
|
+
/** Mounting Prop */
|
|
70
|
+
get mounting() {
|
|
71
|
+
return this.#mounting_accessor_storage;
|
|
72
|
+
}
|
|
73
|
+
set mounting(value) {
|
|
74
|
+
this.#mounting_accessor_storage = value;
|
|
75
|
+
}
|
|
76
|
+
#background_accessor_storage = (__runInitializers(this, _mounting_extraInitializers), __runInitializers(this, _background_initializers, "light"));
|
|
77
|
+
/** the background of the area */
|
|
78
|
+
get background() {
|
|
79
|
+
return this.#background_accessor_storage;
|
|
80
|
+
}
|
|
81
|
+
set background(value) {
|
|
82
|
+
this.#background_accessor_storage = value;
|
|
83
|
+
}
|
|
84
|
+
render() {
|
|
85
|
+
return html`<slot></slot>`;
|
|
86
|
+
}
|
|
87
|
+
constructor() {
|
|
88
|
+
super(...arguments);
|
|
89
|
+
__runInitializers(this, _background_extraInitializers);
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
})();
|
|
93
|
+
//#endregion
|
|
94
|
+
export { SbbSeatReservationAreaElement as t };
|
|
95
|
+
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC1CV2RyS3Flay5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMtZXhwZXJpbWVudGFsL3NlYXQtcmVzZXJ2YXRpb24vc2VhdC1yZXNlcnZhdGlvbi1hcmVhL3NlYXQtcmVzZXJ2YXRpb24tYXJlYS5zY3NzP2lubGluZSIsIi4uLy4uLy4uL3NyYy9lbGVtZW50cy1leHBlcmltZW50YWwvc2VhdC1yZXNlcnZhdGlvbi9zZWF0LXJlc2VydmF0aW9uLWFyZWEvc2VhdC1yZXNlcnZhdGlvbi1hcmVhLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJAdXNlICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL3N0eWxlcycgYXMgc2JiO1xuXG46aG9zdCB7XG4gIC0tc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYS1ib3JkZXItcmFkaXVzOiB2YXIoLS1zYmItYm9yZGVyLXdpZHRoLTR4KTtcbiAgLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhLXJvdGF0aW9uOiAwO1xuICAtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtei1pbmRleDogMDtcblxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiBjYWxjKFxuICAgIHZhcigtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtaGVpZ2h0KSAqXG4gICAgICB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1vbmUtcHgtcmVtLCAje3NiYi5weC10by1yZW0tYnVpbGQoMSl9KVxuICApO1xuICB3aWR0aDogY2FsYyhcbiAgICB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhLXdpZHRoKSAqXG4gICAgICB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1vbmUtcHgtcmVtLCAje3NiYi5weC10by1yZW0tYnVpbGQoMSl9KVxuICApO1xuICBib3JkZXI6IHZhcigtLXNiYi1ib3JkZXItd2lkdGgtMXgpIHNvbGlkXG4gICAgbGlnaHQtZGFyayh2YXIoLS1zYmItY29sb3ItZ3JhcGhpdGUpLCB2YXIoLS1zYmItY29sb3ItZ3Jhbml0ZSkpO1xuICBib3JkZXItcmFkaXVzOiB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1hcmVhLWJvcmRlci1yYWRpdXMpO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHotaW5kZXg6IHZhcigtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtei1pbmRleCk7XG4gIGluc2V0LWJsb2NrLXN0YXJ0OiBjYWxjKFxuICAgIHZhcigtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtdG9wKSAqXG4gICAgICB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1vbmUtcHgtcmVtLCAje3NiYi5weC10by1yZW0tYnVpbGQoMSl9KVxuICApO1xuICBpbnNldC1pbmxpbmUtc3RhcnQ6IGNhbGMoXG4gICAgdmFyKC0tc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYS1sZWZ0KSAqXG4gICAgICB2YXIoLS1zYmItc2VhdC1yZXNlcnZhdGlvbi1vbmUtcHgtcmVtLCAje3NiYi5weC10by1yZW0tYnVpbGQoMSl9KVxuICApO1xuICByb3RhdGU6IGNhbGModmFyKC0tc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYS1yb3RhdGlvbikgKiAxZGVnKTtcbiAgbGluZS1oZWlnaHQ6IG5vcm1hbDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0tc2JiLWJhY2tncm91bmQtY29sb3ItMik7XG59XG5cbjpob3N0KFtiYWNrZ3JvdW5kPSdkYXJrJ10pIHtcbiAgYmFja2dyb3VuZC1jb2xvcjogbGlnaHQtZGFyayh2YXIoLS1zYmItY29sb3ItbWlsayksIHZhcigtLXNiYi1jb2xvci1pcm9uKSk7XG59XG5cbjpob3N0KFttb3VudGluZz0ndXBwZXItYm9yZGVyJ10pIHtcbiAgLy8gRm9yIGFyZWFzIHRoYXQgYXJlIG1vdW50ZWQgZGlyZWN0bHkgb24gdGhlIGJvcmRlciBvZiBjb2FjaCxcbiAgLy8gd2UgcmVtb3ZlIHRoZSBib3JkZXIgdG9wIGZyb20gdGhlIGVsZW1lbnQgd2hlcmUgaXQgaXMgbW91bnRlZCxcbiAgLy8gYXMgdGhlIGJvcmRlcnMgYXJlIGFscmVhZHkgdmlzdWFsbHkgZGlzcGxheWVkIGJ5IHRoZSBjb2FjaC5cbiAgYm9yZGVyLWJsb2NrLXN0YXJ0LXdpZHRoOiAwO1xuICBib3JkZXItcmFkaXVzOiAwIDAgdmFyKC0tc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYS1ib3JkZXItcmFkaXVzKVxuICAgIHZhcigtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtYm9yZGVyLXJhZGl1cyk7XG59XG5cbjpob3N0KFttb3VudGluZz0nbG93ZXItYm9yZGVyJ10pIHtcbiAgLy8gRm9yIGFyZWFzIHRoYXQgYXJlIG1vdW50ZWQgZGlyZWN0bHkgb24gdGhlIGJvcmRlciBvZiBjb2FjaCxcbiAgLy8gd2UgcmVtb3ZlIHRoZSBib3JkZXIgYm90dG9tIGZyb20gdGhlIGVsZW1lbnQgd2hlcmUgaXQgaXMgbW91bnRlZCxcbiAgLy8gYXMgdGhlIGJvcmRlcnMgYXJlIGFscmVhZHkgdmlzdWFsbHkgZGlzcGxheWVkIGJ5IHRoZSBjb2FjaC5cbiAgYm9yZGVyLWJsb2NrLWVuZC13aWR0aDogMDtcbiAgYm9yZGVyLXJhZGl1czogdmFyKC0tc2JiLXNlYXQtcmVzZXJ2YXRpb24tYXJlYS1ib3JkZXItcmFkaXVzKVxuICAgIHZhcigtLXNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtYm9yZGVyLXJhZGl1cykgMCAwO1xufVxuXG46aG9zdChbbW91bnRpbmc9J3VwcGVyLXRvLWxvd2VyLWJvcmRlciddKSB7XG4gIGJvcmRlci1ibG9jay1zdGFydDogbm9uZTtcbiAgYm9yZGVyLWJsb2NrLWVuZDogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMDtcbn1cblxuLy8gaG92ZXIgc3RhdGUgd2l0aCBwb2ludGVyIGN1cnNvciBmb3Igc2VydmljZSBpY29ucyBhbmQgcG9wb3ZlclxuOmhvc3QoLnNiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEtLWN1cnNvci1wb2ludGVyKSB7XG4gIGN1cnNvcjogdmFyKC0tc2JiLWN1cnNvci1wb2ludGVyKTtcbn1cbiIsImltcG9ydCB7IFNiYkVsZW1lbnQgfSBmcm9tICdAc2JiLWVzdGEvbHluZS1lbGVtZW50cy9jb3JlL2Jhc2UtZWxlbWVudHMuanMnO1xuaW1wb3J0IHsgZm9yY2VUeXBlIH0gZnJvbSAnQHNiYi1lc3RhL2x5bmUtZWxlbWVudHMvY29yZS9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJ0BzYmItZXN0YS9seW5lLWVsZW1lbnRzL2NvcmUvc3R5bGVzLmpzJztcbmltcG9ydCB7IGh0bWwsIHVuc2FmZUNTUywgdHlwZSBDU1NSZXN1bHRHcm91cCwgdHlwZSBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vc2VhdC1yZXNlcnZhdGlvbi1hcmVhLnNjc3M/aW5saW5lJztcblxuLyoqXG4gKiBWaXN1YWxpemUgYW4gYXJlYSB3aXRoIGEgc3BlY2lhbCBtZWFuaW5nIHdpdGhpbiBhIHdhZ29uLlxuICovXG5leHBvcnQgY2xhc3MgU2JiU2VhdFJlc2VydmF0aW9uQXJlYUVsZW1lbnQgZXh0ZW5kcyBTYmJFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByZWFkb25seSBlbGVtZW50TmFtZTogc3RyaW5nID0gJ3NiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEnO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCB1bnNhZmVDU1Moc3R5bGUpXTtcblxuICAvKiogTW91bnRpbmcgUHJvcCAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgYWNjZXNzb3IgbW91bnRpbmc6ICdmcmVlJyB8ICd1cHBlci1ib3JkZXInIHwgJ2xvd2VyLWJvcmRlcicgfCAndXBwZXItdG8tbG93ZXItYm9yZGVyJyA9XG4gICAgJ2ZyZWUnO1xuXG4gIC8qKiB0aGUgYmFja2dyb3VuZCBvZiB0aGUgYXJlYSAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgYWNjZXNzb3IgYmFja2dyb3VuZDogJ2xpZ2h0JyB8ICdkYXJrJyA9ICdsaWdodCc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgPHNsb3Q+PC9zbG90PmA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1zZWF0LXJlc2VydmF0aW9uLWFyZWEnOiBTYmJTZWF0UmVzZXJ2YXRpb25BcmVhRWxlbWVudDtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0lDV2EsdUNBQTZCO21CQUFTOzs7Ozs7O2NBQXRDLHNDQUFzQyxZQUFVOzs7MkJBSzFELFdBQVcsRUFDWCxTQUFTLEVBQUUsU0FBUyxNQUFNLENBQUMsQ0FBQTs2QkFLM0IsV0FBVyxFQUNYLFNBQVMsRUFBRSxTQUFTLE1BQU0sQ0FBQyxDQUFBO0FBTDVCLGdCQUFBLE1BQUEsTUFBQSxzQkFBQTtJQUFBLE1BQUE7SUFBQSxNQUFBO0lBQUEsUUFBQTtJQUFBLFNBQUE7SUFBQSxRQUFBO0tBQUEsTUFBQSxRQUFBLGNBQUE7S0FBQSxNQUFBLFFBQUEsSUFBZ0I7S0FBUSxNQUFBLEtBQUEsVUFBQTtBQUFBLFVBQVIsV0FBUTs7S0FBQTtJQUFBLFVBQUE7SUFBQSxFQUFBLHdCQUFBLDRCQUFBO0FBTXhCLGdCQUFBLE1BQUEsTUFBQSx3QkFBQTtJQUFBLE1BQUE7SUFBQSxNQUFBO0lBQUEsUUFBQTtJQUFBLFNBQUE7SUFBQSxRQUFBO0tBQUEsTUFBQSxRQUFBLGdCQUFBO0tBQUEsTUFBQSxRQUFBLElBQWdCO0tBQVUsTUFBQSxLQUFBLFVBQUE7QUFBQSxVQUFWLGFBQVU7O0tBQUE7SUFBQSxVQUFBO0lBQUEsRUFBQSwwQkFBQSw4QkFBQTs7Ozs7Ozs7O0FBWk0sUUFBQSxjQUFzQjs7O0FBQy9CLFFBQUEsU0FBeUIsQ0FBQyxpQkFBaUIsVUFBVSw4QkFBTSxDQUFDOztFQUtuRiw2QkFBQSxrQkFBQSxNQUFBLHdCQUNFLE9BQU07O0VBRFIsSUFBZ0IsV0FBUTtBQUFBLFVBQUEsTUFBQTs7RUFBeEIsSUFBZ0IsU0FBUSxPQUFBO0FBQUEsU0FBQSw0QkFBQTs7RUFNeEIsZ0NBQUEsa0JBQUEsTUFBQSw0QkFBQSxFQUFBLGtCQUFBLE1BQUEsMEJBQStDLFFBQU87O0VBQXRELElBQWdCLGFBQVU7QUFBQSxVQUFBLE1BQUE7O0VBQTFCLElBQWdCLFdBQVUsT0FBQTtBQUFBLFNBQUEsOEJBQUE7O0VBRVAsU0FBTTtBQUN2QixVQUFPLElBQUkifQ==
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { SbbElement } from "@sbb-esta/lyne-elements/core/base-elements.js";
|
|
3
|
+
import { SbbLanguageController } from "@sbb-esta/lyne-elements/core/controllers.js";
|
|
4
|
+
import { forceType } from "@sbb-esta/lyne-elements/core/decorators.js";
|
|
5
|
+
import { boxSizingStyles } from "@sbb-esta/lyne-elements/core/styles.js";
|
|
6
|
+
import "@sbb-esta/lyne-elements/icon.js";
|
|
7
|
+
import { html, isServer, unsafeCSS } from "lit";
|
|
8
|
+
import { property } from "lit/decorators.js";
|
|
9
|
+
import { mapIconToSvg } from "./seat-reservation/common/mapper.js";
|
|
10
|
+
import { classMap } from "lit/directives/class-map.js";
|
|
11
|
+
import { getI18nSeatReservation } from "./seat-reservation/common/translations.js";
|
|
12
|
+
//#region src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.scss?inline
|
|
13
|
+
var seat_reservation_graphic_default = ":host {\n --sbb-seat-reservation-graphic-max-width: auto;\n --sbb-seat-reservation-graphic-max-height: auto;\n --sbb-seat-reservation-graphic-width: 16;\n --sbb-seat-reservation-graphic-height: 16;\n --sbb-seat-reservation-graphic-rotation: 0;\n --sbb-seat-reservation-graphic-inverse-rotation: 0;\n --sbb-seat-reservation-graphic-padding-percent: 1;\n --sbb-seat-reservation-graphic-position: initial;\n --sbb-seat-reservation-graphic-z-index: 0;\n --sbb-seat-reservation-graphic-left: 0;\n --sbb-seat-reservation-graphic-top: 0;\n --sbb-icon-svg-width: calc(\n var(--sbb-seat-reservation-graphic-width) *\n var(--sbb-seat-reservation-one-px-rem, 0.0625rem)\n );\n --sbb-icon-svg-height: calc(\n var(--sbb-seat-reservation-graphic-height) *\n var(--sbb-seat-reservation-one-px-rem, 0.0625rem)\n );\n display: flex;\n justify-content: center;\n align-items: center;\n width: calc(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n height: calc(var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n position: var(--sbb-seat-reservation-graphic-position);\n z-index: var(--sbb-seat-reservation-graphic-z-index);\n inset-inline-start: calc(var(--sbb-seat-reservation-graphic-left) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n inset-block-start: calc(var(--sbb-seat-reservation-graphic-top) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n}\n\n:host(.auto-width) {\n --sbb-icon-svg-width: auto;\n max-width: calc(var(--sbb-seat-reservation-graphic-max-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem));\n width: auto;\n}\n\n:host(.sbb-sr-graphic__dimension--square-dim) {\n --sbb-icon-svg-width: min(min(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) * var(--sbb-seat-reservation-graphic-padding-percent), min(var(--sbb-seat-reservation-graphic-max-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-max-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)));\n --sbb-icon-svg-height: min(min(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) * var(--sbb-seat-reservation-graphic-padding-percent), min(var(--sbb-seat-reservation-graphic-max-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-max-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)));\n width: min(min(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) * var(--sbb-seat-reservation-graphic-padding-percent), min(var(--sbb-seat-reservation-graphic-max-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-max-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)));\n height: min(min(var(--sbb-seat-reservation-graphic-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)) * var(--sbb-seat-reservation-graphic-padding-percent), min(var(--sbb-seat-reservation-graphic-max-width) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem), var(--sbb-seat-reservation-graphic-max-height) * var(--sbb-seat-reservation-one-px-rem, 0.0625rem)));\n}\n\n:host(.sbb-seat-reservation-graphic--cursor-pointer) {\n cursor: var(--sbb-cursor-pointer);\n}\n\n.sbb-sr-icon,\n.sbb-sr-graphic {\n width: inherit;\n height: inherit;\n transform-origin: center;\n rotate: calc(var(--sbb-seat-reservation-graphic-rotation) * 1deg);\n}\n\n.sbb-sr-icon {\n color: var(--sbb-color-granite);\n color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n}\n\n.sbb-sr-graphic svg {\n width: 100%;\n height: 100%;\n}\n.sbb-sr-graphic svg .fix-rotation-inverse {\n transform-origin: center;\n rotate: calc(var(--sbb-seat-reservation-graphic-inverse-rotation) * 1deg);\n}\n@media (forced-colors: active) {\n .sbb-sr-graphic svg:not(.color-immutable) [fill]:not([fill=none]) {\n fill: currentcolor;\n }\n .sbb-sr-graphic .no-bg {\n fill: transparent;\n }\n}";
|
|
14
|
+
//#endregion
|
|
15
|
+
//#region src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts
|
|
16
|
+
/**
|
|
17
|
+
* Output one of the SVG graphics based on its code.
|
|
18
|
+
*/
|
|
19
|
+
var SbbSeatReservationGraphicElement = (() => {
|
|
20
|
+
let _classSuper = SbbElement;
|
|
21
|
+
let _name_decorators;
|
|
22
|
+
let _name_initializers = [];
|
|
23
|
+
let _name_extraInitializers = [];
|
|
24
|
+
let _stretch_decorators;
|
|
25
|
+
let _stretch_initializers = [];
|
|
26
|
+
let _stretch_extraInitializers = [];
|
|
27
|
+
return class SbbSeatReservationGraphicElement extends _classSuper {
|
|
28
|
+
constructor() {
|
|
29
|
+
super(...arguments);
|
|
30
|
+
this.#name_accessor_storage = __runInitializers(this, _name_initializers, "");
|
|
31
|
+
this.#stretch_accessor_storage = (__runInitializers(this, _name_extraInitializers), __runInitializers(this, _stretch_initializers, false));
|
|
32
|
+
this._language = (__runInitializers(this, _stretch_extraInitializers), new SbbLanguageController(this));
|
|
33
|
+
}
|
|
34
|
+
static {
|
|
35
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
36
|
+
_name_decorators = [forceType(), property({ attribute: "name" })];
|
|
37
|
+
_stretch_decorators = [forceType(), property({
|
|
38
|
+
attribute: "stretch",
|
|
39
|
+
type: Boolean
|
|
40
|
+
})];
|
|
41
|
+
__esDecorate(this, null, _name_decorators, {
|
|
42
|
+
kind: "accessor",
|
|
43
|
+
name: "name",
|
|
44
|
+
static: false,
|
|
45
|
+
private: false,
|
|
46
|
+
access: {
|
|
47
|
+
has: (obj) => "name" in obj,
|
|
48
|
+
get: (obj) => obj.name,
|
|
49
|
+
set: (obj, value) => {
|
|
50
|
+
obj.name = value;
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
metadata: _metadata
|
|
54
|
+
}, _name_initializers, _name_extraInitializers);
|
|
55
|
+
__esDecorate(this, null, _stretch_decorators, {
|
|
56
|
+
kind: "accessor",
|
|
57
|
+
name: "stretch",
|
|
58
|
+
static: false,
|
|
59
|
+
private: false,
|
|
60
|
+
access: {
|
|
61
|
+
has: (obj) => "stretch" in obj,
|
|
62
|
+
get: (obj) => obj.stretch,
|
|
63
|
+
set: (obj, value) => {
|
|
64
|
+
obj.stretch = value;
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
metadata: _metadata
|
|
68
|
+
}, _stretch_initializers, _stretch_extraInitializers);
|
|
69
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
70
|
+
enumerable: true,
|
|
71
|
+
configurable: true,
|
|
72
|
+
writable: true,
|
|
73
|
+
value: _metadata
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
static {
|
|
77
|
+
this.elementName = "sbb-seat-reservation-graphic";
|
|
78
|
+
}
|
|
79
|
+
static {
|
|
80
|
+
this.styles = [boxSizingStyles, unsafeCSS(seat_reservation_graphic_default)];
|
|
81
|
+
}
|
|
82
|
+
#name_accessor_storage;
|
|
83
|
+
/** Name of the SVG graphic to be displayed. */
|
|
84
|
+
get name() {
|
|
85
|
+
return this.#name_accessor_storage;
|
|
86
|
+
}
|
|
87
|
+
set name(value) {
|
|
88
|
+
this.#name_accessor_storage = value;
|
|
89
|
+
}
|
|
90
|
+
#stretch_accessor_storage;
|
|
91
|
+
/** if true, scale the graphic content of the given element non-uniformly if necessary */
|
|
92
|
+
get stretch() {
|
|
93
|
+
return this.#stretch_accessor_storage;
|
|
94
|
+
}
|
|
95
|
+
set stretch(value) {
|
|
96
|
+
this.#stretch_accessor_storage = value;
|
|
97
|
+
}
|
|
98
|
+
render() {
|
|
99
|
+
const svgObj = mapIconToSvg[this.name];
|
|
100
|
+
if (!svgObj?.svg && !svgObj?.svgName) return null;
|
|
101
|
+
return html`<span
|
|
102
|
+
class="${classMap({
|
|
103
|
+
"sbb-sr-icon": !!svgObj.svgName,
|
|
104
|
+
"sbb-sr-graphic": !!svgObj.svg
|
|
105
|
+
})}"
|
|
106
|
+
>
|
|
107
|
+
${svgObj.svgName ? html` <sbb-icon
|
|
108
|
+
name="${svgObj.svgName || ""}"
|
|
109
|
+
aria-hidden="false"
|
|
110
|
+
aria-label="${getI18nSeatReservation(svgObj.svgName, this._language.current)}"
|
|
111
|
+
></sbb-icon>` : html`${this._getSvgElement(svgObj.svg)}`}
|
|
112
|
+
</span>`;
|
|
113
|
+
}
|
|
114
|
+
_getSvgElement(svg) {
|
|
115
|
+
if (!isServer) {
|
|
116
|
+
const parser = new DOMParser();
|
|
117
|
+
const svgString = svg || "<svg></svg>";
|
|
118
|
+
const svgElm = parser.parseFromString(svgString, "image/svg+xml").firstElementChild;
|
|
119
|
+
if (this.stretch && svgElm?.nodeName.toLowerCase() === "svg") svgElm.setAttribute("preserveAspectRatio", "none");
|
|
120
|
+
return svgElm;
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
})();
|
|
126
|
+
//#endregion
|
|
127
|
+
export { SbbSeatReservationGraphicElement as t };
|
|
128
|
+
|
|
129
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-graphic.component-CN5sWn0I.js","names":[],"sources":["../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.scss?inline","../../../src/elements-experimental/seat-reservation/seat-reservation-graphic/seat-reservation-graphic.component.ts"],"sourcesContent":["@use '@sbb-esta/lyne-elements/core/styles' as sbb;\n\n:host {\n  --sbb-seat-reservation-graphic-max-width: auto;\n  --sbb-seat-reservation-graphic-max-height: auto;\n  --sbb-seat-reservation-graphic-width: 16;\n  --sbb-seat-reservation-graphic-height: 16;\n  --sbb-seat-reservation-graphic-rotation: 0;\n  --sbb-seat-reservation-graphic-inverse-rotation: 0;\n  --sbb-seat-reservation-graphic-padding-percent: 1;\n  --sbb-seat-reservation-graphic-position: initial;\n  --sbb-seat-reservation-graphic-z-index: 0;\n  --sbb-seat-reservation-graphic-left: 0;\n  --sbb-seat-reservation-graphic-top: 0;\n  --sbb-icon-svg-width: calc(\n    var(--sbb-seat-reservation-graphic-width) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  --sbb-icon-svg-height: calc(\n    var(--sbb-seat-reservation-graphic-height) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  width: calc(\n    var(--sbb-seat-reservation-graphic-width) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  height: calc(\n    var(--sbb-seat-reservation-graphic-height) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  position: var(--sbb-seat-reservation-graphic-position);\n  z-index: var(--sbb-seat-reservation-graphic-z-index);\n  inset-inline-start: calc(\n    var(--sbb-seat-reservation-graphic-left) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  inset-block-start: calc(\n    var(--sbb-seat-reservation-graphic-top) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n}\n\n// auto-width settings for graphics\n:host(.auto-width) {\n  --sbb-icon-svg-width: auto;\n\n  max-width: calc(\n    var(--sbb-seat-reservation-graphic-max-width) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  width: auto;\n}\n\n// Graphic size for max square dimension\n:host(.sbb-sr-graphic__dimension--square-dim) {\n  $padding-percent: var(--sbb-seat-reservation-graphic-padding-percent);\n  $graphic-max-width: calc(\n    var(--sbb-seat-reservation-graphic-max-width) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  $graphic-max-height: calc(\n    var(--sbb-seat-reservation-graphic-max-height) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  $graphic-width: calc(\n    var(--sbb-seat-reservation-graphic-width) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n  $graphic-height: calc(\n    var(--sbb-seat-reservation-graphic-height) *\n      var(--sbb-seat-reservation-one-px-rem, #{sbb.px-to-rem-build(1)})\n  );\n\n  // calculate max available area dimension\n  $parent-dim: calc(min($graphic-width, $graphic-height) * $padding-percent);\n  $max-parent-dim: min($graphic-max-width, $graphic-max-height);\n  $result-dim: min($parent-dim, $max-parent-dim);\n\n  // Set max dimension for svg icon\n  --sbb-icon-svg-width: #{$result-dim};\n  --sbb-icon-svg-height: #{$result-dim};\n\n  width: #{$result-dim};\n  height: #{$result-dim};\n}\n\n// hover state with pointer cursor for service icons and popover\n:host(.sbb-seat-reservation-graphic--cursor-pointer) {\n  cursor: var(--sbb-cursor-pointer);\n}\n\n.sbb-sr-icon,\n.sbb-sr-graphic {\n  width: inherit;\n  height: inherit;\n  transform-origin: center;\n  rotate: calc(var(--sbb-seat-reservation-graphic-rotation) * 1deg);\n}\n\n.sbb-sr-icon {\n  // override color directly set in the SVG file coming from CDN\n  color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n}\n\n.sbb-sr-graphic {\n  svg {\n    width: clamp(100%, 100%, 100%);\n    height: clamp(100%, 100%, 100%);\n\n    .fix-rotation-inverse {\n      transform-origin: center;\n      rotate: calc(var(--sbb-seat-reservation-graphic-inverse-rotation) * 1deg);\n    }\n  }\n\n  @include sbb.if-forced-colors {\n    svg:not(.color-immutable) {\n      [fill]:not([fill='none']) {\n        fill: currentcolor;\n      }\n    }\n\n    .no-bg {\n      fill: transparent;\n    }\n  }\n}\n","import { SbbElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport { type CSSResultGroup, html, isServer, type TemplateResult, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { mapIconToSvg } from '../common/mapper.ts';\nimport { getI18nSeatReservation } from '../common/translations.ts';\n\nimport style from './seat-reservation-graphic.scss?inline';\n\nimport '@sbb-esta/lyne-elements/icon.js';\n\n/**\n * Output one of the SVG graphics based on its code.\n */\nexport class SbbSeatReservationGraphicElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-seat-reservation-graphic';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Name of the SVG graphic to be displayed. */\n  @forceType()\n  @property({ attribute: 'name' })\n  public accessor name: string = '';\n\n  /** if true, scale the graphic content of the given element non-uniformly if necessary */\n  @forceType()\n  @property({ attribute: 'stretch', type: Boolean })\n  public accessor stretch: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override render(): TemplateResult | null {\n    const svgObj = mapIconToSvg[this.name];\n\n    if (!svgObj?.svg && !svgObj?.svgName) {\n      return null;\n    }\n\n    return html`<span\n      class=\"${classMap({\n        'sbb-sr-icon': !!svgObj.svgName,\n        'sbb-sr-graphic': !!svgObj.svg,\n      })}\"\n    >\n      ${svgObj.svgName\n        ? html` <sbb-icon\n            name=\"${svgObj.svgName || ''}\"\n            aria-hidden=\"false\"\n            aria-label=\"${getI18nSeatReservation(svgObj.svgName, this._language.current)}\"\n          ></sbb-icon>`\n        : html`${this._getSvgElement(svgObj.svg!)}`}\n    </span>`;\n  }\n\n  private _getSvgElement(svg: string): Element | null {\n    if (!isServer) {\n      const parser = new DOMParser();\n      const svgString = svg || '<svg></svg>';\n      const svgElm = parser.parseFromString(svgString, 'image/svg+xml').firstElementChild;\n      if (this.stretch && svgElm?.nodeName.toLowerCase() === 'svg') {\n        svgElm.setAttribute('preserveAspectRatio', 'none');\n      }\n      return svgElm;\n    }\n\n    return null;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-graphic': SbbSeatReservationGraphicElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;ICkBa,0CAAgC;mBAAS;;;;;;;cAAzC,yCAAyC,YAAU;;;AAO9C,SAAA,wBAAA,kBAAA,MAAA,oBAAe,GAAE;AAKjB,SAAA,4BAAA,kBAAA,MAAA,wBAAA,EAAA,kBAAA,MAAA,uBAAmB,MAAK;AAEhC,QAAA,aAAS,kBAAA,MAAA,2BAAA,EAAG,IAAI,sBAAsB,KAAK;;;;uBATlD,WAAW,EACX,SAAS,EAAE,WAAW,QAAQ,CAAC,CAAA;0BAI/B,WAAW,EACX,SAAS;IAAE,WAAW;IAAW,MAAM;IAAS,CAAC,CAAA;AAJlD,gBAAA,MAAA,MAAA,kBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,UAAA;KAAA,MAAA,QAAA,IAAgB;KAAI,MAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;;KAAA;IAAA,UAAA;IAAA,EAAA,oBAAA,wBAAA;AAKpB,gBAAA,MAAA,MAAA,qBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,aAAA;KAAA,MAAA,QAAA,IAAgB;KAAO,MAAA,KAAA,UAAA;AAAA,UAAP,UAAO;;KAAA;IAAA,UAAA;IAAA,EAAA,uBAAA,2BAAA;;;;;;;;;AAXS,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,iCAAM,CAAC;;EAKnF;;EAAA,IAAgB,OAAI;AAAA,UAAA,MAAA;;EAApB,IAAgB,KAAI,OAAA;AAAA,SAAA,wBAAA;;EAKpB;;EAAA,IAAgB,UAAO;AAAA,UAAA,MAAA;;EAAvB,IAAgB,QAAO,OAAA;AAAA,SAAA,2BAAA;;EAIJ,SAAM;GACvB,MAAM,SAAS,aAAa,KAAK;AAEjC,OAAI,CAAC,QAAQ,OAAO,CAAC,QAAQ,QAC3B,QAAO;AAGT,UAAO,IAAI;eACA,SAAS;IAChB,eAAe,CAAC,CAAC,OAAO;IACxB,kBAAkB,CAAC,CAAC,OAAO;IAC5B,CAAC,CAAA;;QAEA,OAAO,UACL,IAAI;oBACM,OAAO,WAAW,GAAE;;0BAEd,uBAAuB,OAAO,SAAS,KAAK,UAAU,QAAQ,CAAA;0BAE9E,IAAI,GAAG,KAAK,eAAe,OAAO,IAAK,GAAA;;;EAIvC,eAAe,KAAW;AAChC,OAAI,CAAC,UAAU;IACb,MAAM,SAAS,IAAI,WAAW;IAC9B,MAAM,YAAY,OAAO;IACzB,MAAM,SAAS,OAAO,gBAAgB,WAAW,gBAAgB,CAAC;AAClE,QAAI,KAAK,WAAW,QAAQ,SAAS,aAAa,KAAK,MACrD,QAAO,aAAa,uBAAuB,OAAO;AAEpD,WAAO;;AAGT,UAAO"}
|
|
@@ -381,8 +381,8 @@ var SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
381
381
|
`;
|
|
382
382
|
}
|
|
383
383
|
_getTitleDescriptionNavCoachButton(serviceClassNumber) {
|
|
384
|
-
if (this.coachItemDetails.isDriverArea && !this.coachItemDetails.
|
|
385
|
-
if (this.coachItemDetails.
|
|
384
|
+
if (this.coachItemDetails.isDriverArea && !this.coachItemDetails.isLocomotive) return getI18nSeatReservation("NAVIGATE_COACH_BLOCKED", this._language.current, [this.coachItemDetails.id]);
|
|
385
|
+
if (this.coachItemDetails.isLocomotive) return getI18nSeatReservation("COACH_LOCOMOTIVE", this._language.current);
|
|
386
386
|
let label = getI18nSeatReservation("NAVIGATE_TO_COACH", this._language.current, [this.coachItemDetails.id]);
|
|
387
387
|
if (serviceClassNumber) {
|
|
388
388
|
const serviceClassTranslation = getI18nSeatReservation(serviceClassNumber === 1 ? "SERVICE_CLASS_FIRST" : "SERVICE_CLASS_SECOND", this._language.current);
|
|
@@ -425,4 +425,4 @@ var SbbSeatReservationNavigationCoachElement = (() => {
|
|
|
425
425
|
//#endregion
|
|
426
426
|
export { SbbSeatReservationNavigationCoachElement as t };
|
|
427
427
|
|
|
428
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component-CjoDkcVU.js","names":[],"sources":["../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.scss?inline","../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["@use '@sbb-esta/lyne-elements/core/styles' as sbb;\n@use '../common/styles/seat-reservation-mixins.scss' as sbb-sr-mixins;\n@use '../common/styles/seat-reservation-functions' as sbb-sr-functions;\n\n$disabled: '[disabled], :disabled';\n\n:host {\n  // fixes the keyboard focus border which was cut off due to missing navigation service icons\n  display: inline-block;\n  min-height: sbb-sr-functions.sr-px-to-rem(\n    44\n  ); // default button height (36px) + 2 * 4px focus outline offset\n\n  --sbb-seat-reservation-navigation-travelclass-spacing: 10;\n  --sbb-seat-reservation-navigation-btn-border-width-default: 1;\n  --sbb-seat-reservation-navigation-btn-border-width: var(\n    --sbb-seat-reservation-navigation-btn-border-width-default\n  );\n  --sbb-seat-reservation-navigation-btn-border-color: light-dark(\n    var(--sbb-color-granite),\n    var(--sbb-color-graphite)\n  );\n  --sbb-seat-reservation-navigation-btn-background-color: light-dark(\n    var(--sbb-color-white),\n    var(--sbb-color-black)\n  );\n\n  // selected state variables\n  --sbb-seat-reservation-navigation-btn-border-width-selected: 2;\n  --sbb-seat-reservation-navigation-btn-background-color-selected: light-dark(\n    var(--sbb-color-milk),\n    var(--sbb-color-iron)\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-selected: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // focus state variables\n  --sbb-seat-reservation-navigation-btn-outline-width-focused: 1;\n  --sbb-seat-reservation-navigation-btn-outline-color-focused: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n  --sbb-seat-reservation-navigation-btn-outline-offset-focused: 4;\n  --sbb-seat-reservation-navigation-btn-background-color-focused: light-dark(\n    var(--sbb-color-white),\n    var(--sbb-color-black)\n  );\n  --sbb-seat-reservation-navigation-btn-border-width-focused: var(\n    --sbb-seat-reservation-navigation-btn-border-width\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-focused: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // hover state variables\n  --sbb-seat-reservation-navigation-btn-border-width-hovered: 2;\n  --sbb-seat-reservation-navigation-btn-background-color-hovered: light-dark(\n    var(--sbb-color-cloud),\n    var(--sbb-color-midnight)\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-hovered: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // disable state variables\n  --sbb-seat-reservation-navigation-btn-background-color-disabled: var(--sbb-background-color-2);\n  --sbb-seat-reservation-navigation-btn-border-color-disabled: light-dark(\n    var(--sbb-color-platinum),\n    var(--sbb-color-iron)\n  );\n}\n\n.sbb-sr-navigation__item-coach {\n  display: flex;\n  flex-direction: column;\n  gap: sbb-sr-functions.sr-px-to-rem(8);\n  width: sbb-sr-functions.sr-px-to-rem(80);\n  list-style-type: none;\n\n  &.first-coach,\n  &.last-coach {\n    .sbb-sr-navigation--first-class {\n      width: calc(100% - sbb-sr-functions.sr-px-to-rem(18));\n    }\n  }\n\n  &.first-coach {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-seat-reservation-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(8, 2, 2, 8);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-inline-start: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n  }\n\n  &.last-coach {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(2, 8, 8, 2);\n    }\n\n    .sbb-sr-navigation__additional-information {\n      padding-inline-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-inline-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n  }\n}\n\n// same for all states\n.sbb-sr-navigation__ctrl-button {\n  @include sbb.button-reset;\n\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  height: sbb-sr-functions.sr-px-to-rem(36);\n  position: relative;\n  background-color: var(--sbb-seat-reservation-navigation-btn-background-color);\n  cursor: var(--sbb-cursor-pointer);\n\n  &.sbb-sr-navigation-driver-area {\n    @include sbb-sr-mixins.visualize-coach-border(8, 8, 8, 8);\n  }\n\n  @include sbb-sr-mixins.visualize-coach-border(2, 2, 2, 2);\n}\n\n.sbb-sr-navigation__item-coach--focused .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('focused');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-metal), var(--sbb-color-storm));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-graphite));\n  }\n}\n\n// selected, i.e. the coach within the train is selected (FIGMA State:Selected)\n.sbb-sr-navigation__item-coach--selected .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-black), var(--sbb-color-white));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-black), var(--sbb-color-white));\n  }\n}\n\n.sbb-sr-navigation__item-coach--hovered .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n}\n\n.sbb-sr-navigation__item-coach--selected.sbb-sr-navigation__item-coach--hovered\n  .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n\n  background-color: var(--sbb-seat-reservation-navigation-btn-background-color-hovered) !important;\n}\n\n// selected AND focus (FIGMA State:Selected + Focused)\n// background-color from selected State has more specificity, so we need to override it here (again)\n.sbb-sr-navigation__item-coach--selected\n  .sbb-sr-navigation__ctrl-button:focus-visible:not(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n}\n\n.sbb-sr-navigation__item-coach--hovered .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n}\n\n// hover (FIGMA State:hover)\n.sbb-sr-navigation__ctrl-button:hover:not(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: var(--sbb-color-smoke);\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-iron), var(--sbb-color-silver));\n  }\n}\n\n// disabled (FIGMA State:disabled)\n.sbb-sr-navigation__ctrl-button:is(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('disabled');\n\n  cursor: unset;\n  pointer-events: unset;\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n  }\n}\n\n.sbb-sr-navigation__additional-information {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  flex: 1;\n  column-gap: sbb-sr-functions.sr-px-to-rem(8);\n  padding-inline: sbb-sr-functions.sr-px-to-rem(16);\n  font-family: var(--sbb-typo-font-family);\n  font-weight: 700;\n  color: light-dark(var(--sbb-color-granite), var(--sbb-color-granite));\n\n  @include sbb.if-forced-colors {\n    color: var(--sbb-color-milk);\n  }\n}\n\n.sbb-sr-navigation__item-coach-number {\n  color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n\n  @include sbb.if-forced-colors {\n    color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n  }\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: var(--sbb-background-color-2-inverted);\n  }\n}\n\n// graphical orientation of FIRST class\n.sbb-sr-navigation--first-class {\n  width: calc(100% - sbb-sr-functions.sr-px-to-rem(8));\n  position: absolute;\n  inset-block-start: sbb-sr-functions.sr-px-to-rem(3);\n  inset-inline-start: sbb-sr-functions.sr-px-to-rem(4);\n\n  // use border instead of height to support force-color modes\n  border: sbb-sr-functions.sr-px-to-rem(1) solid transparent;\n  border-radius: var(--sbb-border-radius-1x);\n  margin: auto;\n  background-color: var(--sbb-color-lemon);\n}\n\n// textual orientation of travel class\n.sbb-sr-navigation__item-coach-travelclass {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: sbb-sr-functions.sr-px-to-rem(20);\n  min-width: sbb-sr-functions.sr-px-to-rem(20);\n  border-radius: var(--sbb-border-radius-1x);\n  text-align: center;\n  background-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n  color: light-dark(var(--sbb-color-white), var(--sbb-color-black));\n\n  @include sbb.if-forced-colors {\n    border: var(--sbb-border-width-1x) solid;\n  }\n}\n\n// ################ VERTICAL MODE settings ################\n:host([vertical]) .sbb-sr-navigation__item-coach {\n  flex-direction: row;\n\n  .sbb-sr-navigation__ctrl-button {\n    flex-direction: row-reverse;\n    height: sbb-sr-functions.sr-px-to-rem(80);\n    min-width: sbb-sr-functions.sr-px-to-rem(36);\n  }\n\n  .sbb-sr-navigation__additional-information {\n    flex-direction: column-reverse;\n    padding-block: sbb-sr-functions.sr-px-to-rem(16);\n    padding-inline-start: unset;\n    padding-inline-end: unset;\n  }\n\n  .sbb-sr-navigation--first-class {\n    height: calc(100% - sbb-sr-functions.sr-px-to-rem(8));\n    width: initial;\n    inset-inline-end: sbb-sr-functions.sr-px-to-rem(3);\n    inset-block-start: sbb-sr-functions.sr-px-to-rem(4);\n    inset-inline-start: initial;\n  }\n\n  &.first-coach,\n  &.last-coach {\n    .sbb-sr-navigation--first-class {\n      height: calc(100% - sbb-sr-functions.sr-px-to-rem(18));\n    }\n  }\n\n  // handle border-radius\n  &.first-coach:not(.last-coach) {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(8, 8, 2, 2);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-block-start: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n      margin-inline-start: initial;\n    }\n  }\n\n  &.last-coach:not(.first-coach) {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(2, 2, 8, 8);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-block-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n      margin-inline-end: initial;\n    }\n  }\n\n  // Driver area\n  .sbb-sr-navigation-driver-area {\n    height: sbb-sr-functions.sr-px-to-rem(80);\n    min-width: sbb-sr-functions.sr-px-to-rem(36);\n  }\n}\n","import { SbbElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.ts';\nimport type { CoachItemDetails } from '../common/types.ts';\nimport { SbbSeatReservationNavigationServicesElement } from '../seat-reservation-navigation-services/seat-reservation-navigation-services.component.ts';\n\nimport style from './seat-reservation-navigation-coach.scss?inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\n\nSbbSeatReservationNavigationServicesElement.define();\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport class SbbSeatReservationNavigationCoachElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-seat-reservation-navigation-coach';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Select coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /** Focus coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  /** Hover coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor hovered: boolean = false;\n\n  /** Native focus for this navigation coach is also set when the focused property is changed */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor nativeFocusActive: boolean = true;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  @property({ attribute: 'coach-item-details', type: Object })\n  public accessor coachItemDetails: CoachItemDetails = <CoachItemDetails>{};\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean, reflect: true, useDefault: true })\n  public accessor vertical: boolean = false;\n\n  /** Disable the mouse over title information */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor showTitleInfo: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        if (this.nativeFocusActive) {\n          selectedNavButtonElement.focus();\n        }\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n\n      if (focusedNavButtonElement && this.nativeFocusActive) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a list of service icons provided by a caller\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.coachItemDetails.driverAreaSide?.right || false,\n          'first-coach': this.coachItemDetails.driverAreaSide?.left || false,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n          'sbb-sr-navigation__item-coach--focused': this.focused,\n          'sbb-sr-navigation__item-coach--hovered': this.hovered,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.coachItemDetails.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.coachItemDetails.propertyIds}\"\n              ?showTitleInfo=\"${this.showTitleInfo}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n      @click=${() => this._selectNavCoach(this.index)}\n      class=\"${classMap({\n        'sbb-sr-navigation__ctrl-button': true,\n        'sbb-sr-navigation-driver-area': this.coachItemDetails.isDriverArea,\n      })}\"\n      ?disabled=\"${this.disable}\"\n      title=\"${this.showTitleInfo ? titleDescriptionNavCoachButton : nothing}\"\n      type=\"button\"\n      aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n    >\n      ${this._getBtnInformation(currServiceClassNumber)}\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\">\n        ${!this.showTitleInfo ? html`<div>${titleDescriptionNavCoachButton}</div>` : nothing}\n        ${ariaDescriptionCoachServices ? html`<div>${ariaDescriptionCoachServices}</div>` : nothing}\n      </sbb-screen-reader-only>\n    </button>`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.coachItemDetails.isDriverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.coachItemDetails.travelClass?.length > 0 || this.coachItemDetails.id\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachItemDetails.id\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachItemDetails.id}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (\n      this.coachItemDetails.isDriverArea &&\n      !this.coachItemDetails.driverAreaElements?.driverAreaNoVerticalWall\n    ) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachItemDetails.id,\n      ]);\n    }\n\n    if (this.coachItemDetails.driverAreaElements?.driverAreaNoVerticalWall) {\n      return getI18nSeatReservation('COACH_LOCOMOTIVE', this._language.current);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [\n      this.coachItemDetails.id,\n    ]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    // Expands the number of available seats and bicycle spaces as info\n    const freePlacesTxt = getI18nSeatReservation(\n      'COACH_AVAILABLE_NUMBER_OF_PLACES',\n      this._language.current,\n      [this.coachItemDetails.freePlaces?.seats, this.coachItemDetails.freePlaces?.bicycles],\n    );\n    label = label.concat('. ').concat(freePlacesTxt);\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescription = null;\n    if (this.coachItemDetails.propertyIds?.length) {\n      ariaDescription =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescription +=\n        this.coachItemDetails.propertyIds\n          .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n          .join() + '.';\n    }\n    return ariaDescription;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    /**\n     * @type {CustomEvent<SelectCoachEventDetails>}\n     * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n     */\n    this.dispatchEvent(\n      new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n        bubbles: true,\n        composed: true,\n        detail: coachIndex,\n      }),\n    );\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    return this.coachItemDetails.travelClass?.includes('FIRST')\n      ? 1\n      : this.coachItemDetails.travelClass?.includes('SECOND')\n        ? 2\n        : null;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"mappings":"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"}
|
|
428
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"seat-reservation-navigation-coach.component-tDZkXl-3.js","names":[],"sources":["../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.scss?inline","../../../src/elements-experimental/seat-reservation/seat-reservation-navigation-coach/seat-reservation-navigation-coach.component.ts"],"sourcesContent":["@use '@sbb-esta/lyne-elements/core/styles' as sbb;\n@use '../common/styles/seat-reservation-mixins.scss' as sbb-sr-mixins;\n@use '../common/styles/seat-reservation-functions' as sbb-sr-functions;\n\n$disabled: '[disabled], :disabled';\n\n:host {\n  // fixes the keyboard focus border which was cut off due to missing navigation service icons\n  display: inline-block;\n  min-height: sbb-sr-functions.sr-px-to-rem(\n    44\n  ); // default button height (36px) + 2 * 4px focus outline offset\n\n  --sbb-seat-reservation-navigation-travelclass-spacing: 10;\n  --sbb-seat-reservation-navigation-btn-border-width-default: 1;\n  --sbb-seat-reservation-navigation-btn-border-width: var(\n    --sbb-seat-reservation-navigation-btn-border-width-default\n  );\n  --sbb-seat-reservation-navigation-btn-border-color: light-dark(\n    var(--sbb-color-granite),\n    var(--sbb-color-graphite)\n  );\n  --sbb-seat-reservation-navigation-btn-background-color: light-dark(\n    var(--sbb-color-white),\n    var(--sbb-color-black)\n  );\n\n  // selected state variables\n  --sbb-seat-reservation-navigation-btn-border-width-selected: 2;\n  --sbb-seat-reservation-navigation-btn-background-color-selected: light-dark(\n    var(--sbb-color-milk),\n    var(--sbb-color-iron)\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-selected: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // focus state variables\n  --sbb-seat-reservation-navigation-btn-outline-width-focused: 1;\n  --sbb-seat-reservation-navigation-btn-outline-color-focused: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n  --sbb-seat-reservation-navigation-btn-outline-offset-focused: 4;\n  --sbb-seat-reservation-navigation-btn-background-color-focused: light-dark(\n    var(--sbb-color-white),\n    var(--sbb-color-black)\n  );\n  --sbb-seat-reservation-navigation-btn-border-width-focused: var(\n    --sbb-seat-reservation-navigation-btn-border-width\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-focused: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // hover state variables\n  --sbb-seat-reservation-navigation-btn-border-width-hovered: 2;\n  --sbb-seat-reservation-navigation-btn-background-color-hovered: light-dark(\n    var(--sbb-color-cloud),\n    var(--sbb-color-midnight)\n  );\n  --sbb-seat-reservation-navigation-btn-border-color-hovered: light-dark(\n    var(--sbb-color-black),\n    var(--sbb-color-white)\n  );\n\n  // disable state variables\n  --sbb-seat-reservation-navigation-btn-background-color-disabled: var(--sbb-background-color-2);\n  --sbb-seat-reservation-navigation-btn-border-color-disabled: light-dark(\n    var(--sbb-color-platinum),\n    var(--sbb-color-iron)\n  );\n}\n\n.sbb-sr-navigation__item-coach {\n  display: flex;\n  flex-direction: column;\n  gap: sbb-sr-functions.sr-px-to-rem(8);\n  width: sbb-sr-functions.sr-px-to-rem(80);\n  list-style-type: none;\n\n  &.first-coach,\n  &.last-coach {\n    .sbb-sr-navigation--first-class {\n      width: calc(100% - sbb-sr-functions.sr-px-to-rem(18));\n    }\n  }\n\n  &.first-coach {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-seat-reservation-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(8, 2, 2, 8);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-inline-start: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n  }\n\n  &.last-coach {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(2, 8, 8, 2);\n    }\n\n    .sbb-sr-navigation__additional-information {\n      padding-inline-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-inline-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n    }\n  }\n}\n\n// same for all states\n.sbb-sr-navigation__ctrl-button {\n  @include sbb.button-reset;\n\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  height: sbb-sr-functions.sr-px-to-rem(36);\n  position: relative;\n  background-color: var(--sbb-seat-reservation-navigation-btn-background-color);\n  cursor: var(--sbb-cursor-pointer);\n\n  &.sbb-sr-navigation-driver-area {\n    @include sbb-sr-mixins.visualize-coach-border(8, 8, 8, 8);\n  }\n\n  @include sbb-sr-mixins.visualize-coach-border(2, 2, 2, 2);\n}\n\n.sbb-sr-navigation__item-coach--focused .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('focused');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-metal), var(--sbb-color-storm));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-graphite));\n  }\n}\n\n// selected, i.e. the coach within the train is selected (FIGMA State:Selected)\n.sbb-sr-navigation__item-coach--selected .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-black), var(--sbb-color-white));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-black), var(--sbb-color-white));\n  }\n}\n\n.sbb-sr-navigation__item-coach--hovered .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n}\n\n.sbb-sr-navigation__item-coach--selected.sbb-sr-navigation__item-coach--hovered\n  .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n\n  background-color: var(--sbb-seat-reservation-navigation-btn-background-color-hovered) !important;\n}\n\n// selected AND focus (FIGMA State:Selected + Focused)\n// background-color from selected State has more specificity, so we need to override it here (again)\n.sbb-sr-navigation__item-coach--selected\n  .sbb-sr-navigation__ctrl-button:focus-visible:not(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('selected');\n}\n\n.sbb-sr-navigation__item-coach--hovered .sbb-sr-navigation__ctrl-button {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n}\n\n// hover (FIGMA State:hover)\n.sbb-sr-navigation__ctrl-button:hover:not(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('hovered');\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: var(--sbb-color-smoke);\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-iron), var(--sbb-color-silver));\n  }\n}\n\n// disabled (FIGMA State:disabled)\n.sbb-sr-navigation__ctrl-button:is(#{$disabled}) {\n  @include sbb-sr-mixins.style-coach-by-state('disabled');\n\n  cursor: unset;\n  pointer-events: unset;\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n  }\n\n  .sbb-sr-navigation__item-coach-number {\n    color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n  }\n}\n\n.sbb-sr-navigation__additional-information {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  flex: 1;\n  column-gap: sbb-sr-functions.sr-px-to-rem(8);\n  padding-inline: sbb-sr-functions.sr-px-to-rem(16);\n  font-family: var(--sbb-typo-font-family);\n  font-weight: 700;\n  color: light-dark(var(--sbb-color-granite), var(--sbb-color-granite));\n\n  @include sbb.if-forced-colors {\n    color: var(--sbb-color-milk);\n  }\n}\n\n.sbb-sr-navigation__item-coach-number {\n  color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n\n  @include sbb.if-forced-colors {\n    color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n  }\n\n  .sbb-sr-navigation__item-coach-travelclass {\n    background-color: var(--sbb-background-color-2-inverted);\n  }\n}\n\n// graphical orientation of FIRST class\n.sbb-sr-navigation--first-class {\n  width: calc(100% - sbb-sr-functions.sr-px-to-rem(8));\n  position: absolute;\n  inset-block-start: sbb-sr-functions.sr-px-to-rem(3);\n  inset-inline-start: sbb-sr-functions.sr-px-to-rem(4);\n\n  // use border instead of height to support force-color modes\n  border: sbb-sr-functions.sr-px-to-rem(1) solid transparent;\n  border-radius: var(--sbb-border-radius-1x);\n  margin: auto;\n  background-color: var(--sbb-color-lemon);\n}\n\n// textual orientation of travel class\n.sbb-sr-navigation__item-coach-travelclass {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: sbb-sr-functions.sr-px-to-rem(20);\n  min-width: sbb-sr-functions.sr-px-to-rem(20);\n  border-radius: var(--sbb-border-radius-1x);\n  text-align: center;\n  background-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n  color: light-dark(var(--sbb-color-white), var(--sbb-color-black));\n\n  @include sbb.if-forced-colors {\n    border: var(--sbb-border-width-1x) solid;\n  }\n}\n\n// ################ VERTICAL MODE settings ################\n:host([vertical]) .sbb-sr-navigation__item-coach {\n  flex-direction: row;\n\n  .sbb-sr-navigation__ctrl-button {\n    flex-direction: row-reverse;\n    height: sbb-sr-functions.sr-px-to-rem(80);\n    min-width: sbb-sr-functions.sr-px-to-rem(36);\n  }\n\n  .sbb-sr-navigation__additional-information {\n    flex-direction: column-reverse;\n    padding-block: sbb-sr-functions.sr-px-to-rem(16);\n    padding-inline-start: unset;\n    padding-inline-end: unset;\n  }\n\n  .sbb-sr-navigation--first-class {\n    height: calc(100% - sbb-sr-functions.sr-px-to-rem(8));\n    width: initial;\n    inset-inline-end: sbb-sr-functions.sr-px-to-rem(3);\n    inset-block-start: sbb-sr-functions.sr-px-to-rem(4);\n    inset-inline-start: initial;\n  }\n\n  &.first-coach,\n  &.last-coach {\n    .sbb-sr-navigation--first-class {\n      height: calc(100% - sbb-sr-functions.sr-px-to-rem(18));\n    }\n  }\n\n  // handle border-radius\n  &.first-coach:not(.last-coach) {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(8, 8, 2, 2);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-block-start: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n      margin-inline-start: initial;\n    }\n  }\n\n  &.last-coach:not(.first-coach) {\n    .sbb-sr-navigation__ctrl-button:not(.sbb-sr-navigation-driver-area) {\n      @include sbb-sr-mixins.visualize-coach-border(2, 2, 8, 8);\n    }\n\n    .sbb-sr-navigation--first-class {\n      margin-block-end: sbb-sr-functions.sr-px-to-rem(\n        var(--sbb-seat-reservation-navigation-travelclass-spacing)\n      );\n      margin-inline-end: initial;\n    }\n  }\n\n  // Driver area\n  .sbb-sr-navigation-driver-area {\n    height: sbb-sr-functions.sr-px-to-rem(80);\n    min-width: sbb-sr-functions.sr-px-to-rem(36);\n  }\n}\n","import { SbbElement } from '@sbb-esta/lyne-elements/core/base-elements.js';\nimport { SbbLanguageController } from '@sbb-esta/lyne-elements/core/controllers.js';\nimport { forceType } from '@sbb-esta/lyne-elements/core/decorators.js';\nimport { boxSizingStyles } from '@sbb-esta/lyne-elements/core/styles.js';\nimport {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { getI18nSeatReservation } from '../common/translations.ts';\nimport type { CoachItemDetails } from '../common/types.ts';\nimport { SbbSeatReservationNavigationServicesElement } from '../seat-reservation-navigation-services/seat-reservation-navigation-services.component.ts';\n\nimport style from './seat-reservation-navigation-coach.scss?inline';\n\nimport '@sbb-esta/lyne-elements/screen-reader-only.js';\n\nSbbSeatReservationNavigationServicesElement.define();\n\nexport type SelectCoachEventDetails = number;\n\n/**\n * This component will display the navigation coach item for Seat reservation.\n */\nexport class SbbSeatReservationNavigationCoachElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-seat-reservation-navigation-coach';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    selectcoach: 'selectcoach',\n    focuscoach: 'focuscoach',\n  } as const;\n\n  /** Select coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor selected: boolean = false;\n\n  /** Focus coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor focused: boolean = false;\n\n  /** Hover coach property */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor hovered: boolean = false;\n\n  /** Native focus for this navigation coach is also set when the focused property is changed */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor nativeFocusActive: boolean = true;\n\n  @forceType()\n  @property({ type: Number })\n  public accessor index: number = 0;\n\n  @property({ attribute: 'coach-item-details', type: Object })\n  public accessor coachItemDetails: CoachItemDetails = <CoachItemDetails>{};\n\n  /** Disable the coach navigation */\n  @forceType()\n  @property({ attribute: 'disable', type: Boolean })\n  public accessor disable: boolean = false;\n\n  /** If the coach navigation should be displayed vertically */\n  @forceType()\n  @property({ type: Boolean, reflect: true, useDefault: true })\n  public accessor vertical: boolean = false;\n\n  /** Disable the mouse over title information */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor showTitleInfo: boolean = false;\n\n  private _language = new SbbLanguageController(this);\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('selected')) {\n      const selectedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n      if (this.selected && selectedNavButtonElement) {\n        if (this.nativeFocusActive) {\n          selectedNavButtonElement.focus();\n        }\n        /** Emits when a nav coach has the focus */\n        this.dispatchEvent(new Event('focuscoach', { bubbles: true, composed: true }));\n      }\n    }\n\n    if (changedProperties.has('focused') && this.focused) {\n      const focusedNavButtonElement = this.shadowRoot?.querySelector(\n        '.sbb-sr-navigation__ctrl-button',\n      ) as HTMLButtonElement;\n\n      if (focusedNavButtonElement && this.nativeFocusActive) {\n        focusedNavButtonElement.focus();\n      }\n    }\n  }\n\n  /**\n   * Render a list of service icons provided by a caller\n   *\n   * @protected\n   */\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"${classMap({\n          'sbb-sr-navigation__item-coach': true,\n          'last-coach': this.coachItemDetails.driverAreaSide?.right || false,\n          'first-coach': this.coachItemDetails.driverAreaSide?.left || false,\n          'sbb-sr-navigation__item-coach--selected': this.selected,\n          'sbb-sr-navigation__item-coach--focused': this.focused,\n          'sbb-sr-navigation__item-coach--hovered': this.hovered,\n        })}\"\n      >\n        ${this._getNavigationButton()}\n        ${this.coachItemDetails.propertyIds?.length\n          ? html`<sbb-seat-reservation-navigation-services\n              ?vertical=\"${this.vertical}\"\n              .propertyIds=\"${this.coachItemDetails.propertyIds}\"\n              ?showTitleInfo=\"${this.showTitleInfo}\"\n            ></sbb-seat-reservation-navigation-services>`\n          : nothing}\n      </div>\n    `;\n  }\n\n  private _getNavigationButton(): TemplateResult | null {\n    const currServiceClassNumber = this._getCoachServiceClassNumber();\n    const titleDescriptionNavCoachButton =\n      this._getTitleDescriptionNavCoachButton(currServiceClassNumber);\n    const ariaDescriptionCoachServices = this._getAriaDescriptionCoachServices();\n\n    return html` <button\n      @click=${() => this._selectNavCoach(this.index)}\n      class=\"${classMap({\n        'sbb-sr-navigation__ctrl-button': true,\n        'sbb-sr-navigation-driver-area': this.coachItemDetails.isDriverArea,\n      })}\"\n      ?disabled=\"${this.disable}\"\n      title=\"${this.showTitleInfo ? titleDescriptionNavCoachButton : nothing}\"\n      type=\"button\"\n      aria-describedby=\"nav-coach-service-descriptions-${this.index}\"\n    >\n      ${this._getBtnInformation(currServiceClassNumber)}\n      <sbb-screen-reader-only id=\"nav-coach-service-descriptions-${this.index}\">\n        ${!this.showTitleInfo ? html`<div>${titleDescriptionNavCoachButton}</div>` : nothing}\n        ${ariaDescriptionCoachServices ? html`<div>${ariaDescriptionCoachServices}</div>` : nothing}\n      </sbb-screen-reader-only>\n    </button>`;\n  }\n\n  private _getBtnInformation(serviceClassNumber: number | null): TemplateResult | null {\n    if (this.coachItemDetails.isDriverArea) {\n      return null;\n    }\n\n    return html`\n      ${serviceClassNumber === 1\n        ? html`<span class=\"sbb-sr-navigation--first-class\"></span>`\n        : nothing}\n      ${this.coachItemDetails.travelClass?.length > 0 || this.coachItemDetails.id\n        ? html`<div class=\"sbb-sr-navigation__additional-information\">\n            ${this.coachItemDetails.id\n              ? html`<div class=\"sbb-sr-navigation__item-coach-number\" aria-hidden=\"true\">\n                  ${this.coachItemDetails.id}\n                </div>`\n              : nothing}\n            <div\n              ${serviceClassNumber ?? nothing}\n              class=\"sbb-sr-navigation__item-coach-travelclass\"\n              aria-hidden=\"true\"\n            >\n              ${serviceClassNumber}\n            </div>\n          </div>`\n        : nothing}\n    `;\n  }\n\n  private _getTitleDescriptionNavCoachButton(serviceClassNumber: number | null): string {\n    if (this.coachItemDetails.isDriverArea && !this.coachItemDetails.isLocomotive) {\n      return getI18nSeatReservation('NAVIGATE_COACH_BLOCKED', this._language.current, [\n        this.coachItemDetails.id,\n      ]);\n    }\n\n    if (this.coachItemDetails.isLocomotive) {\n      return getI18nSeatReservation('COACH_LOCOMOTIVE', this._language.current);\n    }\n\n    let label = getI18nSeatReservation('NAVIGATE_TO_COACH', this._language.current, [\n      this.coachItemDetails.id,\n    ]);\n\n    //If service class exist, then expand label with service class translation\n    if (serviceClassNumber) {\n      const serviceClassTranslationKey =\n        serviceClassNumber === 1 ? 'SERVICE_CLASS_FIRST' : 'SERVICE_CLASS_SECOND';\n      const serviceClassTranslation = getI18nSeatReservation(\n        serviceClassTranslationKey,\n        this._language.current,\n      );\n      const serviceClassLabel = getI18nSeatReservation(\n        'NAVIGATE_TO_COACH_SERVICE_CLASS_SUB',\n        this._language.current,\n        [serviceClassTranslation],\n      );\n      label = label.concat(serviceClassLabel);\n    }\n\n    // Expands the number of available seats and bicycle spaces as info\n    const freePlacesTxt = getI18nSeatReservation(\n      'COACH_AVAILABLE_NUMBER_OF_PLACES',\n      this._language.current,\n      [this.coachItemDetails.freePlaces?.seats, this.coachItemDetails.freePlaces?.bicycles],\n    );\n    label = label.concat('. ').concat(freePlacesTxt);\n    return label;\n  }\n\n  private _getAriaDescriptionCoachServices(): string | null {\n    let ariaDescription = null;\n    if (this.coachItemDetails.propertyIds?.length) {\n      ariaDescription =\n        getI18nSeatReservation('COACH_AVAILABLE_SERVICES', this._language.current) + ': ';\n      ariaDescription +=\n        this.coachItemDetails.propertyIds\n          .map((propertyId) => getI18nSeatReservation(propertyId, this._language.current))\n          .join() + '.';\n    }\n    return ariaDescription;\n  }\n\n  /**\n   * emits the index of the coach array for the main navigation.\n   * @param coachIndex\n   * @private\n   */\n  private _selectNavCoach(coachIndex: number): void {\n    /**\n     * @type {CustomEvent<SelectCoachEventDetails>}\n     * Emits when a coach within the navigation was selected and returns the clicked coach nav index.\n     */\n    this.dispatchEvent(\n      new CustomEvent<SelectCoachEventDetails>('selectcoach', {\n        bubbles: true,\n        composed: true,\n        detail: coachIndex,\n      }),\n    );\n  }\n\n  private _getCoachServiceClassNumber(): number | null {\n    return this.coachItemDetails.travelClass?.includes('FIRST')\n      ? 1\n      : this.coachItemDetails.travelClass?.includes('SECOND')\n        ? 2\n        : null;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-seat-reservation-navigation-coach': SbbSeatReservationNavigationCoachElement;\n  }\n}\n"],"mappings":"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"}
|