@sbb-esta/lyne-elements 1.4.0 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/alert/alert/alert.d.ts +22 -16
- package/alert/alert/alert.d.ts.map +1 -1
- package/alert/alert-group/alert-group.d.ts +1 -1
- package/alert/alert-group/alert-group.d.ts.map +1 -1
- package/alert/alert-group.js +31 -26
- package/alert/alert.js +45 -37
- package/checkbox/checkbox/checkbox.d.ts +5 -0
- package/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
- package/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/checkbox/checkbox-panel.js +28 -18
- package/checkbox/checkbox.js +26 -15
- package/checkbox/common/checkbox-common.d.ts +1 -3
- package/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/checkbox/common.js +15 -24
- package/clock/clock.d.ts.map +1 -1
- package/clock.js +14 -14
- package/core/i18n/i18n.d.ts +2 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n.js +61 -49
- package/core/mixins/panel-mixin.d.ts +1 -0
- package/core/mixins/panel-mixin.d.ts.map +1 -1
- package/core/testing/wait-for-event.d.ts +2 -0
- package/core/testing/wait-for-event.d.ts.map +1 -0
- package/core/testing.d.ts +1 -0
- package/core/testing.d.ts.map +1 -1
- package/core/testing.js +49 -36
- package/custom-elements.json +701 -193
- package/development/alert/alert/alert.d.ts +22 -16
- package/development/alert/alert/alert.d.ts.map +1 -1
- package/development/alert/alert-group/alert-group.d.ts +1 -1
- package/development/alert/alert-group/alert-group.d.ts.map +1 -1
- package/development/alert/alert-group.js +16 -11
- package/development/alert/alert.js +65 -24
- package/development/checkbox/checkbox/checkbox.d.ts +5 -0
- package/development/checkbox/checkbox/checkbox.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts +5 -0
- package/development/checkbox/checkbox-panel/checkbox-panel.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel.js +13 -2
- package/development/checkbox/checkbox.js +13 -1
- package/development/checkbox/common/checkbox-common.d.ts +1 -3
- package/development/checkbox/common/checkbox-common.d.ts.map +1 -1
- package/development/checkbox/common.js +13 -17
- package/development/clock/clock.d.ts.map +1 -1
- package/development/clock.js +3 -2
- package/development/core/i18n/i18n.d.ts +2 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n.js +15 -1
- package/development/core/mixins/panel-mixin.d.ts +1 -0
- package/development/core/mixins/panel-mixin.d.ts.map +1 -1
- package/development/core/mixins.js +1 -1
- package/development/core/testing/wait-for-event.d.ts +2 -0
- package/development/core/testing/wait-for-event.d.ts.map +1 -0
- package/development/core/testing.d.ts +1 -0
- package/development/core/testing.d.ts.map +1 -1
- package/development/core/testing.js +17 -1
- package/development/flip-card/flip-card/flip-card.d.ts +32 -0
- package/development/flip-card/flip-card/flip-card.d.ts.map +1 -0
- package/development/flip-card/flip-card/index.d.ts +2 -0
- package/development/flip-card/flip-card/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
- package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
- package/development/flip-card/flip-card-details/index.d.ts +2 -0
- package/development/flip-card/flip-card-details/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-details.d.ts +2 -0
- package/development/flip-card/flip-card-details.d.ts.map +1 -0
- package/development/flip-card/flip-card-details.js +105 -0
- package/development/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
- package/development/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary/index.d.ts +2 -0
- package/development/flip-card/flip-card-summary/index.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary.d.ts +2 -0
- package/development/flip-card/flip-card-summary.d.ts.map +1 -0
- package/development/flip-card/flip-card-summary.js +151 -0
- package/development/flip-card/flip-card.d.ts +2 -0
- package/development/flip-card/flip-card.d.ts.map +1 -0
- package/development/flip-card/flip-card.js +187 -0
- package/development/flip-card.d.ts +4 -0
- package/development/flip-card.d.ts.map +1 -0
- package/development/flip-card.js +4 -0
- package/development/icon/icon.d.ts +9 -1
- package/development/icon/icon.d.ts.map +1 -1
- package/development/icon.js +16 -2
- package/development/menu/menu/menu.d.ts.map +1 -1
- package/development/menu/menu.js +2 -1
- package/development/navigation/navigation/navigation.d.ts.map +1 -1
- package/development/navigation/navigation.js +2 -1
- package/development/notification/notification.d.ts +4 -4
- package/development/notification.js +1 -1
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay.js +35 -17
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts +3 -3
- package/development/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/development/radio-button/radio-button-panel.js +1 -1
- package/development/status/status.d.ts +1 -1
- package/development/status/status.d.ts.map +1 -1
- package/development/status.js +39 -2
- package/development/toggle/toggle.js +1 -1
- package/development/visual-checkbox/visual-checkbox.d.ts +3 -0
- package/development/visual-checkbox/visual-checkbox.d.ts.map +1 -1
- package/development/visual-checkbox.js +11 -3
- package/flip-card/flip-card/flip-card.d.ts +32 -0
- package/flip-card/flip-card/flip-card.d.ts.map +1 -0
- package/flip-card/flip-card/index.d.ts +2 -0
- package/flip-card/flip-card/index.d.ts.map +1 -0
- package/flip-card/flip-card-details/flip-card-details.d.ts +22 -0
- package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -0
- package/flip-card/flip-card-details/index.d.ts +2 -0
- package/flip-card/flip-card-details/index.d.ts.map +1 -0
- package/flip-card/flip-card-details.d.ts +2 -0
- package/flip-card/flip-card-details.d.ts.map +1 -0
- package/flip-card/flip-card-details.js +52 -0
- package/flip-card/flip-card-summary/flip-card-summary.d.ts +22 -0
- package/flip-card/flip-card-summary/flip-card-summary.d.ts.map +1 -0
- package/flip-card/flip-card-summary/index.d.ts +2 -0
- package/flip-card/flip-card-summary/index.d.ts.map +1 -0
- package/flip-card/flip-card-summary.d.ts +2 -0
- package/flip-card/flip-card-summary.d.ts.map +1 -0
- package/flip-card/flip-card-summary.js +41 -0
- package/flip-card/flip-card.d.ts +2 -0
- package/flip-card/flip-card.d.ts.map +1 -0
- package/flip-card/flip-card.js +58 -0
- package/flip-card.d.ts +4 -0
- package/flip-card.d.ts.map +1 -0
- package/flip-card.js +3 -0
- package/icon/icon.d.ts +9 -1
- package/icon/icon.d.ts.map +1 -1
- package/icon.js +71 -62
- package/index.d.ts +6 -0
- package/index.js +6 -0
- package/menu/menu/menu.d.ts.map +1 -1
- package/menu/menu.js +3 -3
- package/navigation/navigation/navigation.d.ts.map +1 -1
- package/navigation/navigation.js +4 -4
- package/notification/notification.d.ts +4 -4
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay.js +33 -33
- package/package.json +21 -1
- package/radio-button/radio-button-panel/radio-button-panel.d.ts +3 -3
- package/radio-button/radio-button-panel/radio-button-panel.d.ts.map +1 -1
- package/status/status.d.ts +1 -1
- package/status/status.d.ts.map +1 -1
- package/status.js +17 -13
- package/toggle/toggle.js +1 -1
- package/visual-checkbox/visual-checkbox.d.ts +3 -0
- package/visual-checkbox/visual-checkbox.d.ts.map +1 -1
- package/visual-checkbox.js +23 -20
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { css, LitElement, html } from "lit";
|
|
2
|
+
import { property, customElement } from "lit/decorators.js";
|
|
3
|
+
import { hostAttributes } from "../core/decorators.js";
|
|
4
|
+
const style = css`/**
|
|
5
|
+
* Better font rendering (on OS X)
|
|
6
|
+
* http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
|
|
7
|
+
*
|
|
8
|
+
* Usage:
|
|
9
|
+
*
|
|
10
|
+
* .var_dark_on_light {
|
|
11
|
+
* @include font-smoothing;
|
|
12
|
+
* }
|
|
13
|
+
* .var_light_on_dark {
|
|
14
|
+
* @include font-smoothing-reset;
|
|
15
|
+
* }
|
|
16
|
+
*/
|
|
17
|
+
/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
|
|
18
|
+
/*
|
|
19
|
+
* SBB table mixin
|
|
20
|
+
* Notes:
|
|
21
|
+
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
22
|
+
* Therefore, we have to build the grid avoiding double borders.
|
|
23
|
+
*/
|
|
24
|
+
*,
|
|
25
|
+
::before,
|
|
26
|
+
::after {
|
|
27
|
+
box-sizing: border-box;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
:host {
|
|
31
|
+
--sbb-flip-card-summary-opacity: 1;
|
|
32
|
+
--sbb-flip-card-summary-pointer-events: all;
|
|
33
|
+
display: contents;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.sbb-flip-card-summary {
|
|
37
|
+
display: grid;
|
|
38
|
+
position: absolute;
|
|
39
|
+
pointer-events: var(--sbb-flip-card-summary-pointer-events);
|
|
40
|
+
opacity: var(--sbb-flip-card-summary-opacity);
|
|
41
|
+
border-radius: var(--sbb-flip-card-border-radius);
|
|
42
|
+
overflow: hidden;
|
|
43
|
+
grid-template-columns: 1fr;
|
|
44
|
+
grid-template-rows: auto 1fr;
|
|
45
|
+
width: 100%;
|
|
46
|
+
height: 100%;
|
|
47
|
+
transition: all var(--sbb-flip-card-summary-transition-duration) ease-out;
|
|
48
|
+
transition-delay: var(--sbb-flip-card-summary-transition-delay);
|
|
49
|
+
}
|
|
50
|
+
@media (min-width: calc(37.5rem)) {
|
|
51
|
+
:host([image-alignment=after]) .sbb-flip-card-summary {
|
|
52
|
+
grid-template-columns: repeat(3, 1fr);
|
|
53
|
+
grid-template-rows: 1fr;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
@media (min-width: calc(52.5rem)) {
|
|
57
|
+
:host([image-alignment=after]) .sbb-flip-card-summary {
|
|
58
|
+
grid-template-columns: repeat(2, 1fr);
|
|
59
|
+
grid-template-rows: 1fr;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
::slotted(sbb-title) {
|
|
64
|
+
padding-inline: var(--sbb-spacing-responsive-s);
|
|
65
|
+
padding-block: var(--sbb-spacing-responsive-s) var(--sbb-spacing-responsive-xs);
|
|
66
|
+
margin: 0;
|
|
67
|
+
grid-area: 1/1/2/2;
|
|
68
|
+
}
|
|
69
|
+
@media (min-width: calc(37.5rem)) {
|
|
70
|
+
:host([image-alignment=after]) ::slotted(sbb-title) {
|
|
71
|
+
grid-area: 1/1/2/3;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
@media (min-width: calc(52.5rem)) {
|
|
75
|
+
:host([image-alignment=after]) ::slotted(sbb-title) {
|
|
76
|
+
grid-area: 1/1/2/2;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.sbb-flip-card-summary--image-wrapper {
|
|
81
|
+
max-height: var(--sbb-flip-card-min-height);
|
|
82
|
+
grid-area: 2/1/3/2;
|
|
83
|
+
}
|
|
84
|
+
@media (min-width: calc(37.5rem)) {
|
|
85
|
+
:host([image-alignment=after]) .sbb-flip-card-summary--image-wrapper {
|
|
86
|
+
grid-area: 1/3/2/4;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
@media (min-width: calc(52.5rem)) {
|
|
90
|
+
:host([image-alignment=after]) .sbb-flip-card-summary--image-wrapper {
|
|
91
|
+
grid-area: 1/2/2/3;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
::slotted(img) {
|
|
96
|
+
object-fit: cover;
|
|
97
|
+
width: 100%;
|
|
98
|
+
height: 100%;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
::slotted(sbb-image) {
|
|
102
|
+
width: 100%;
|
|
103
|
+
height: 100%;
|
|
104
|
+
}`;
|
|
105
|
+
var __defProp = Object.defineProperty;
|
|
106
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
107
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
108
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
109
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
110
|
+
if (decorator = decorators[i])
|
|
111
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
112
|
+
if (kind && result) __defProp(target, key, result);
|
|
113
|
+
return result;
|
|
114
|
+
};
|
|
115
|
+
let SbbFlipCardSummaryElement = class extends LitElement {
|
|
116
|
+
constructor() {
|
|
117
|
+
super(...arguments);
|
|
118
|
+
this.imageAlignment = "after";
|
|
119
|
+
}
|
|
120
|
+
willUpdate(_changedProperties) {
|
|
121
|
+
var _a, _b;
|
|
122
|
+
super.willUpdate(_changedProperties);
|
|
123
|
+
if (_changedProperties.has("imageAlignment")) {
|
|
124
|
+
(_b = (_a = this.closest) == null ? void 0 : _a.call(this, "sbb-flip-card")) == null ? void 0 : _b.setAttribute("data-image-alignment", this.imageAlignment);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
render() {
|
|
128
|
+
return html`
|
|
129
|
+
<div class="sbb-flip-card-summary">
|
|
130
|
+
<slot></slot>
|
|
131
|
+
<div class="sbb-flip-card-summary--image-wrapper">
|
|
132
|
+
<slot name="image"></slot>
|
|
133
|
+
</div>
|
|
134
|
+
</div>
|
|
135
|
+
`;
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
SbbFlipCardSummaryElement.styles = style;
|
|
139
|
+
__decorateClass([
|
|
140
|
+
property({ attribute: "image-alignment", reflect: true })
|
|
141
|
+
], SbbFlipCardSummaryElement.prototype, "imageAlignment", 2);
|
|
142
|
+
SbbFlipCardSummaryElement = __decorateClass([
|
|
143
|
+
customElement("sbb-flip-card-summary"),
|
|
144
|
+
hostAttributes({
|
|
145
|
+
slot: "summary"
|
|
146
|
+
})
|
|
147
|
+
], SbbFlipCardSummaryElement);
|
|
148
|
+
export {
|
|
149
|
+
SbbFlipCardSummaryElement
|
|
150
|
+
};
|
|
151
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxpcC1jYXJkLXN1bW1hcnkuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9mbGlwLWNhcmQvZmxpcC1jYXJkLXN1bW1hcnkvZmxpcC1jYXJkLXN1bW1hcnkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgUHJvcGVydHlWYWx1ZXMsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGh0bWwsIExpdEVsZW1lbnQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGhvc3RBdHRyaWJ1dGVzIH0gZnJvbSAnLi4vLi4vY29yZS9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vZmxpcC1jYXJkLXN1bW1hcnkuc2Nzcz9saXQmaW5saW5lJztcblxuZXhwb3J0IHR5cGUgU2JiRmxpcENhcmRJbWFnZUFsaWdubWVudCA9ICdhZnRlcicgfCAnYmVsb3cnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLWZsaXAtY2FyZGAsIGl0IGRpc3BsYXlzIGl0cyBjb250ZW50IHdoZW4gdGhlIGNhcmQgaXMgbm90IGZsaXBwZWQuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBwcm92aWRlIGEgdGl0bGUgZm9yIHRoZSBgc2JiLWZsaXAtY2FyZC1zdW1tYXJ5YC5cbiAqIEBzbG90IGltYWdlIC0gVXNlIHRoaXMgc2xvdCB0byBwcm92aWRlIGFuIGltYWdlIGZvciB0aGUgYHNiYi1mbGlwLWNhcmQtc3VtbWFyeWAuXG4gKi9cbkBjdXN0b21FbGVtZW50KCdzYmItZmxpcC1jYXJkLXN1bW1hcnknKVxuQGhvc3RBdHRyaWJ1dGVzKHtcbiAgc2xvdDogJ3N1bW1hcnknLFxufSlcbmV4cG9ydCBjbGFzcyBTYmJGbGlwQ2FyZFN1bW1hcnlFbGVtZW50IGV4dGVuZHMgTGl0RWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKiBUaGUgcG9zaXRpb24gd2hlcmUgdG8gcmVuZGVyIHRoZSBpbWFnZS4gKi9cbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAnaW1hZ2UtYWxpZ25tZW50JywgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgaW1hZ2VBbGlnbm1lbnQ6IFNiYkZsaXBDYXJkSW1hZ2VBbGlnbm1lbnQgPSAnYWZ0ZXInO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSB3aWxsVXBkYXRlKF9jaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXMpOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKF9jaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoX2NoYW5nZWRQcm9wZXJ0aWVzLmhhcygnaW1hZ2VBbGlnbm1lbnQnKSkge1xuICAgICAgdGhpcy5jbG9zZXN0Py4oJ3NiYi1mbGlwLWNhcmQnKT8uc2V0QXR0cmlidXRlKCdkYXRhLWltYWdlLWFsaWdubWVudCcsIHRoaXMuaW1hZ2VBbGlnbm1lbnQpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1mbGlwLWNhcmQtc3VtbWFyeVwiPlxuICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzYmItZmxpcC1jYXJkLXN1bW1hcnktLWltYWdlLXdyYXBwZXJcIj5cbiAgICAgICAgICA8c2xvdCBuYW1lPVwiaW1hZ2VcIj48L3Nsb3Q+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWZsaXAtY2FyZC1zdW1tYXJ5JzogU2JiRmxpcENhcmRTdW1tYXJ5RWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW9CYSxJQUFBLDRCQUFOLGNBQXdDLFdBQVc7QUFBQSxFQUFuRCxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFLTCxTQUFPLGlCQUE0QztBQUFBLEVBQUE7QUFBQSxFQUVoQyxXQUFXLG9CQUEwQzs7QUFDdEUsVUFBTSxXQUFXLGtCQUFrQjtBQUUvQixRQUFBLG1CQUFtQixJQUFJLGdCQUFnQixHQUFHO0FBQzVDLHVCQUFLLFlBQUwsOEJBQWUscUJBQWYsbUJBQWlDLGFBQWEsd0JBQXdCLEtBQUs7QUFBQSxJQUM3RTtBQUFBLEVBQ0Y7QUFBQSxFQUVtQixTQUF5QjtBQUNuQyxXQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVFUO0FBQ0Y7QUF6QmEsMEJBQ1ksU0FBeUI7QUFJekMsZ0JBQUE7QUFBQSxFQUROLFNBQVMsRUFBRSxXQUFXLG1CQUFtQixTQUFTLE1BQU07QUFBQSxHQUo5QywwQkFLSixXQUFBLGtCQUFBLENBQUE7QUFMSSw0QkFBTixnQkFBQTtBQUFBLEVBSk4sY0FBYyx1QkFBdUI7QUFBQSxFQUNyQyxlQUFlO0FBQUEsSUFDZCxNQUFNO0FBQUEsRUFBQSxDQUNQO0FBQUEsR0FDWSx5QkFBQTsifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flip-card.d.ts","sourceRoot":"","sources":["../../../../src/elements/flip-card/flip-card.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { css, LitElement, html } from "lit";
|
|
2
|
+
import { state, customElement } from "lit/decorators.js";
|
|
3
|
+
import { SbbLanguageController } from "../core/controllers.js";
|
|
4
|
+
import { i18nFlipCard, i18nReverseCard } from "../core/i18n.js";
|
|
5
|
+
import { SbbHydrationMixin } from "../core/mixins.js";
|
|
6
|
+
import "../button/secondary-button.js";
|
|
7
|
+
const style = css`/**
|
|
8
|
+
* Better font rendering (on OS X)
|
|
9
|
+
* http://maximilianhoffmann.com/posts/better-font-rendering-on-osx
|
|
10
|
+
*
|
|
11
|
+
* Usage:
|
|
12
|
+
*
|
|
13
|
+
* .var_dark_on_light {
|
|
14
|
+
* @include font-smoothing;
|
|
15
|
+
* }
|
|
16
|
+
* .var_light_on_dark {
|
|
17
|
+
* @include font-smoothing-reset;
|
|
18
|
+
* }
|
|
19
|
+
*/
|
|
20
|
+
/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
|
|
21
|
+
/*
|
|
22
|
+
* SBB table mixin
|
|
23
|
+
* Notes:
|
|
24
|
+
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
25
|
+
* Therefore, we have to build the grid avoiding double borders.
|
|
26
|
+
*/
|
|
27
|
+
*,
|
|
28
|
+
::before,
|
|
29
|
+
::after {
|
|
30
|
+
box-sizing: border-box;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
:host {
|
|
34
|
+
--sbb-flip-card-background-color: var(--sbb-color-cloud);
|
|
35
|
+
--sbb-flip-card-border-radius: var(--sbb-border-radius-4x);
|
|
36
|
+
--sbb-flip-card-min-height: 17.5rem;
|
|
37
|
+
--sbb-flip-card-details-min-height: var(--sbb-flip-card-min-height);
|
|
38
|
+
--sbb-flip-card-summary-transition-duration: var(--sbb-animation-duration-5x);
|
|
39
|
+
--sbb-flip-card-summary-transition-delay: var(--sbb-animation-duration-2x);
|
|
40
|
+
--sbb-flip-card-details-transition-duration: var(--sbb-animation-duration-4x);
|
|
41
|
+
--sbb-flip-card-details-transition-delay: var(--sbb-disable-animation-zero-time);
|
|
42
|
+
position: relative;
|
|
43
|
+
display: block;
|
|
44
|
+
}
|
|
45
|
+
@media (min-width: calc(52.5rem)) {
|
|
46
|
+
:host {
|
|
47
|
+
--sbb-flip-card-min-height: 20rem;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
:host(:hover) {
|
|
52
|
+
--sbb-flip-card-background-color: var(--sbb-color-cloud-alpha-80);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
:host([data-flipped]) {
|
|
56
|
+
--sbb-flip-card-background-color: var(--sbb-color-midnight);
|
|
57
|
+
--sbb-flip-card-details-transition-duration: var(--sbb-animation-duration-2x);
|
|
58
|
+
--sbb-flip-card-details-transition-delay: var(--sbb-animation-duration-5x);
|
|
59
|
+
--sbb-flip-card-summary-transition-delay: var(--sbb-disable-animation-zero-time);
|
|
60
|
+
--sbb-flip-card-details-min-height: fit-content;
|
|
61
|
+
}
|
|
62
|
+
:host([data-flipped]) ::slotted(sbb-flip-card-summary) {
|
|
63
|
+
--sbb-flip-card-summary-opacity: 0;
|
|
64
|
+
--sbb-flip-card-summary-pointer-events: none;
|
|
65
|
+
}
|
|
66
|
+
:host([data-flipped]) ::slotted(sbb-flip-card-details) {
|
|
67
|
+
--sbb-flip-card-details-opacity: 1;
|
|
68
|
+
--sbb-flip-card-details-translate-y: 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
@media (min-width: calc(37.5rem)) and (max-width: calc(52.4375rem)) {
|
|
72
|
+
:host([data-image-alignment=after]) {
|
|
73
|
+
--sbb-flip-card-min-height: 15rem;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
@media (min-width: calc(80rem)) {
|
|
77
|
+
:host([data-image-alignment=after]) {
|
|
78
|
+
--sbb-flip-card-min-height: 25rem;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
.sbb-flip-card {
|
|
83
|
+
position: relative;
|
|
84
|
+
display: flex;
|
|
85
|
+
height: 100%;
|
|
86
|
+
flex-flow: wrap;
|
|
87
|
+
flex-direction: column;
|
|
88
|
+
gap: var(--sbb-spacing-responsive-xs);
|
|
89
|
+
min-height: var(--sbb-flip-card-min-height);
|
|
90
|
+
background-color: var(--sbb-flip-card-background-color);
|
|
91
|
+
border-radius: var(--sbb-flip-card-border-radius);
|
|
92
|
+
transition: var(--sbb-flip-card-summary-transition-duration) ease-out;
|
|
93
|
+
transition-delay: var(--sbb-flip-card-summary-transition-delay);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.sbb-flip-card--toggle-button {
|
|
97
|
+
position: absolute;
|
|
98
|
+
inset-inline-start: var(--sbb-spacing-responsive-s);
|
|
99
|
+
inset-block-end: var(--sbb-spacing-responsive-s);
|
|
100
|
+
}
|
|
101
|
+
:host([data-flipped]) .sbb-flip-card--toggle-button {
|
|
102
|
+
--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
button {
|
|
106
|
+
-webkit-appearance: none;
|
|
107
|
+
-moz-appearance: none;
|
|
108
|
+
box-sizing: border-box;
|
|
109
|
+
margin: 0;
|
|
110
|
+
outline: none;
|
|
111
|
+
border: none;
|
|
112
|
+
border-radius: 0;
|
|
113
|
+
padding: 0;
|
|
114
|
+
background: none;
|
|
115
|
+
-webkit-tap-highlight-color: transparent;
|
|
116
|
+
color: inherit;
|
|
117
|
+
cursor: pointer;
|
|
118
|
+
position: absolute;
|
|
119
|
+
inset: 0;
|
|
120
|
+
border-radius: var(--sbb-flip-card-border-radius);
|
|
121
|
+
}
|
|
122
|
+
button:not([data-focus-origin=mouse], [data-focus-origin=touch]):focus-visible {
|
|
123
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
124
|
+
outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
|
|
125
|
+
}`;
|
|
126
|
+
var __defProp = Object.defineProperty;
|
|
127
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
128
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
129
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
130
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
131
|
+
if (decorator = decorators[i])
|
|
132
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
133
|
+
if (kind && result) __defProp(target, key, result);
|
|
134
|
+
return result;
|
|
135
|
+
};
|
|
136
|
+
let SbbFlipCardElement = class extends SbbHydrationMixin(LitElement) {
|
|
137
|
+
constructor() {
|
|
138
|
+
super(...arguments);
|
|
139
|
+
this._flipped = false;
|
|
140
|
+
this._language = new SbbLanguageController(this);
|
|
141
|
+
}
|
|
142
|
+
/** Returns the slotted sbb-flip-card-summary. */
|
|
143
|
+
get summary() {
|
|
144
|
+
return this.querySelector("sbb-flip-card-summary");
|
|
145
|
+
}
|
|
146
|
+
/** Returns the slotted sbb-flip-card-details. */
|
|
147
|
+
get details() {
|
|
148
|
+
return this.querySelector("sbb-flip-card-details");
|
|
149
|
+
}
|
|
150
|
+
/** Toggles the state of the sbb-flip-card. */
|
|
151
|
+
toggle() {
|
|
152
|
+
this._flipped = !this._flipped;
|
|
153
|
+
this.toggleAttribute("data-flipped", this._flipped);
|
|
154
|
+
this.summary.inert = this._flipped;
|
|
155
|
+
this.details.inert = !this._flipped;
|
|
156
|
+
}
|
|
157
|
+
render() {
|
|
158
|
+
return html`
|
|
159
|
+
<div class="sbb-flip-card">
|
|
160
|
+
<slot name="summary" @slotchange=${() => this.summary.inert = this._flipped}></slot>
|
|
161
|
+
<button
|
|
162
|
+
@click=${() => this.toggle()}
|
|
163
|
+
aria-label=${!this._flipped ? i18nFlipCard[this._language.current] : i18nReverseCard[this._language.current]}
|
|
164
|
+
aria-expanded=${this._flipped.toString()}
|
|
165
|
+
></button>
|
|
166
|
+
<slot name="details" @slotchange=${() => this.details.inert = !this._flipped}></slot>
|
|
167
|
+
<sbb-secondary-button
|
|
168
|
+
class="sbb-flip-card--toggle-button"
|
|
169
|
+
icon-name=${this._flipped ? "cross-small" : "plus-small"}
|
|
170
|
+
@click=${() => this.toggle()}
|
|
171
|
+
size="s"
|
|
172
|
+
></sbb-secondary-button>
|
|
173
|
+
</div>
|
|
174
|
+
`;
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
SbbFlipCardElement.styles = style;
|
|
178
|
+
__decorateClass([
|
|
179
|
+
state()
|
|
180
|
+
], SbbFlipCardElement.prototype, "_flipped", 2);
|
|
181
|
+
SbbFlipCardElement = __decorateClass([
|
|
182
|
+
customElement("sbb-flip-card")
|
|
183
|
+
], SbbFlipCardElement);
|
|
184
|
+
export {
|
|
185
|
+
SbbFlipCardElement
|
|
186
|
+
};
|
|
187
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxpcC1jYXJkLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZmxpcC1jYXJkL2ZsaXAtY2FyZC9mbGlwLWNhcmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBzdGF0ZSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgU2JiTGFuZ3VhZ2VDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBpMThuRmxpcENhcmQsIGkxOG5SZXZlcnNlQ2FyZCB9IGZyb20gJy4uLy4uL2NvcmUvaTE4bi5qcyc7XG5pbXBvcnQgeyBTYmJIeWRyYXRpb25NaXhpbiB9IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiRmxpcENhcmREZXRhaWxzRWxlbWVudCB9IGZyb20gJy4uL2ZsaXAtY2FyZC1kZXRhaWxzLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiRmxpcENhcmRTdW1tYXJ5RWxlbWVudCB9IGZyb20gJy4uL2ZsaXAtY2FyZC1zdW1tYXJ5LmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vZmxpcC1jYXJkLnNjc3M/bGl0JmlubGluZSc7XG5cbmltcG9ydCAnLi4vLi4vYnV0dG9uL3NlY29uZGFyeS1idXR0b24uanMnO1xuXG4vKipcbiAqIERpc3BsYXlzIGFuIGluZm9ybWF0aXZlIGNhcmQgdGhhdCByZXZlYWxzIG1vcmUgaW5mb3JtYXRpb25zIHVwb24gYmVpbmcgY2xpY2tlZC5cbiAqXG4gKiBAc2xvdCBzdW1tYXJ5IC0gVXNlIHRoaXMgc2xvdCB0byBwcm92aWRlIGEgc2JiLWZsaXAtY2FyZC1zdW1tYXJ5IGNvbXBvbmVudC5cbiAqIEBzbG90IGRldGFpbHMgLSBVc2UgdGhpcyBzbG90IHRvIHByb3ZpZGUgYSBzYmItZmxpcC1jYXJkLWRldGFpbHMgY29tcG9uZW50LlxuICpcbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1mbGlwLWNhcmQnKVxuZXhwb3J0IGNsYXNzIFNiYkZsaXBDYXJkRWxlbWVudCBleHRlbmRzIFNiYkh5ZHJhdGlvbk1peGluKExpdEVsZW1lbnQpIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgLyoqIFJldHVybnMgdGhlIHNsb3R0ZWQgc2JiLWZsaXAtY2FyZC1zdW1tYXJ5LiAqL1xuICBwdWJsaWMgZ2V0IHN1bW1hcnkoKTogU2JiRmxpcENhcmRTdW1tYXJ5RWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMucXVlcnlTZWxlY3Rvcignc2JiLWZsaXAtY2FyZC1zdW1tYXJ5JykhO1xuICB9XG5cbiAgLyoqIFJldHVybnMgdGhlIHNsb3R0ZWQgc2JiLWZsaXAtY2FyZC1kZXRhaWxzLiAqL1xuICBwdWJsaWMgZ2V0IGRldGFpbHMoKTogU2JiRmxpcENhcmREZXRhaWxzRWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMucXVlcnlTZWxlY3Rvcignc2JiLWZsaXAtY2FyZC1kZXRhaWxzJykhO1xuICB9XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGNhcmQgaXMgZmxpcHBlZCBvciBub3QuICovXG4gIEBzdGF0ZSgpIHByaXZhdGUgX2ZsaXBwZWQgPSBmYWxzZTtcblxuICBwcml2YXRlIF9sYW5ndWFnZSA9IG5ldyBTYmJMYW5ndWFnZUNvbnRyb2xsZXIodGhpcyk7XG5cbiAgLyoqIFRvZ2dsZXMgdGhlIHN0YXRlIG9mIHRoZSBzYmItZmxpcC1jYXJkLiAqL1xuICBwdWJsaWMgdG9nZ2xlKCk6IHZvaWQge1xuICAgIHRoaXMuX2ZsaXBwZWQgPSAhdGhpcy5fZmxpcHBlZDtcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1mbGlwcGVkJywgdGhpcy5fZmxpcHBlZCk7XG4gICAgdGhpcy5zdW1tYXJ5LmluZXJ0ID0gdGhpcy5fZmxpcHBlZDtcbiAgICB0aGlzLmRldGFpbHMuaW5lcnQgPSAhdGhpcy5fZmxpcHBlZDtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1mbGlwLWNhcmRcIj5cbiAgICAgICAgPHNsb3QgbmFtZT1cInN1bW1hcnlcIiBAc2xvdGNoYW5nZT0keygpID0+ICh0aGlzLnN1bW1hcnkuaW5lcnQgPSB0aGlzLl9mbGlwcGVkKX0+PC9zbG90PlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgQGNsaWNrPSR7KCkgPT4gdGhpcy50b2dnbGUoKX1cbiAgICAgICAgICBhcmlhLWxhYmVsPSR7IXRoaXMuX2ZsaXBwZWRcbiAgICAgICAgICAgID8gaTE4bkZsaXBDYXJkW3RoaXMuX2xhbmd1YWdlLmN1cnJlbnRdXG4gICAgICAgICAgICA6IGkxOG5SZXZlcnNlQ2FyZFt0aGlzLl9sYW5ndWFnZS5jdXJyZW50XX1cbiAgICAgICAgICBhcmlhLWV4cGFuZGVkPSR7dGhpcy5fZmxpcHBlZC50b1N0cmluZygpfVxuICAgICAgICA+PC9idXR0b24+XG4gICAgICAgIDxzbG90IG5hbWU9XCJkZXRhaWxzXCIgQHNsb3RjaGFuZ2U9JHsoKSA9PiAodGhpcy5kZXRhaWxzLmluZXJ0ID0gIXRoaXMuX2ZsaXBwZWQpfT48L3Nsb3Q+XG4gICAgICAgIDxzYmItc2Vjb25kYXJ5LWJ1dHRvblxuICAgICAgICAgIGNsYXNzPVwic2JiLWZsaXAtY2FyZC0tdG9nZ2xlLWJ1dHRvblwiXG4gICAgICAgICAgaWNvbi1uYW1lPSR7dGhpcy5fZmxpcHBlZCA/ICdjcm9zcy1zbWFsbCcgOiAncGx1cy1zbWFsbCd9XG4gICAgICAgICAgQGNsaWNrPSR7KCkgPT4gdGhpcy50b2dnbGUoKX1cbiAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgID48L3NiYi1zZWNvbmRhcnktYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWZsaXAtY2FyZCc6IFNiYkZsaXBDYXJkRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXNCTyxJQUFNLHFCQUFOLGNBQWlDLGtCQUFrQixVQUFVLEVBQUU7QUFBQSxFQUEvRCxjQUFBO0FBQUEsVUFBQSxHQUFBLFNBQUE7QUFjSSxTQUFRLFdBQVc7QUFFcEIsU0FBQSxZQUFZLElBQUksc0JBQXNCLElBQUk7QUFBQSxFQUFBO0FBQUE7QUFBQSxFQVpsRCxJQUFXLFVBQXFDO0FBQ3ZDLFdBQUEsS0FBSyxjQUFjLHVCQUF1QjtBQUFBLEVBQ25EO0FBQUE7QUFBQSxFQUdBLElBQVcsVUFBcUM7QUFDdkMsV0FBQSxLQUFLLGNBQWMsdUJBQXVCO0FBQUEsRUFDbkQ7QUFBQTtBQUFBLEVBUU8sU0FBZTtBQUNmLFNBQUEsV0FBVyxDQUFDLEtBQUs7QUFDakIsU0FBQSxnQkFBZ0IsZ0JBQWdCLEtBQUssUUFBUTtBQUM3QyxTQUFBLFFBQVEsUUFBUSxLQUFLO0FBQ3JCLFNBQUEsUUFBUSxRQUFRLENBQUMsS0FBSztBQUFBLEVBQzdCO0FBQUEsRUFFbUIsU0FBeUI7QUFDbkMsV0FBQTtBQUFBO0FBQUEsMkNBRWdDLE1BQU8sS0FBSyxRQUFRLFFBQVEsS0FBSyxRQUFTO0FBQUE7QUFBQSxtQkFFbEUsTUFBTSxLQUFLLFFBQVE7QUFBQSx1QkFDZixDQUFDLEtBQUssV0FDZixhQUFhLEtBQUssVUFBVSxPQUFPLElBQ25DLGdCQUFnQixLQUFLLFVBQVUsT0FBTyxDQUFDO0FBQUEsMEJBQzNCLEtBQUssU0FBUyxVQUFVO0FBQUE7QUFBQSwyQ0FFUCxNQUFPLEtBQUssUUFBUSxRQUFRLENBQUMsS0FBSyxRQUFTO0FBQUE7QUFBQTtBQUFBLHNCQUdoRSxLQUFLLFdBQVcsZ0JBQWdCLFlBQVk7QUFBQSxtQkFDL0MsTUFBTSxLQUFLLFFBQVE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBS3BDO0FBQ0Y7QUEvQ2EsbUJBQ1ksU0FBeUI7QUFhL0IsZ0JBQUE7QUFBQSxFQUFoQixNQUFNO0FBQUEsR0FkSSxtQkFjTSxXQUFBLFlBQUEsQ0FBQTtBQWROLHFCQUFOLGdCQUFBO0FBQUEsRUFETixjQUFjLGVBQWU7QUFBQSxHQUNqQixrQkFBQTsifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flip-card.d.ts","sourceRoot":"","sources":["../../../src/elements/flip-card.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,kCAAkC,CAAC;AACjD,cAAc,kCAAkC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from "./flip-card/flip-card.js";
|
|
2
|
+
export * from "./flip-card/flip-card-summary.js";
|
|
3
|
+
export * from "./flip-card/flip-card-details.js";
|
|
4
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxpcC1jYXJkLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OyJ9
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PropertyValues } from 'lit';
|
|
1
|
+
import { PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbIconBase } from './icon-base.js';
|
|
3
3
|
|
|
4
4
|
/**
|
|
@@ -12,9 +12,17 @@ export declare class SbbIconElement extends SbbIconBase {
|
|
|
12
12
|
*/
|
|
13
13
|
name: string;
|
|
14
14
|
private _defaultAriaLabel;
|
|
15
|
+
/**
|
|
16
|
+
* The sbb-angular library has a sbb-icon component as well. In order to provide
|
|
17
|
+
* compatibility with it (as some icons are used internally inside the other sbb-angular
|
|
18
|
+
* components) we need to check whether the attribute svgicon is used.
|
|
19
|
+
*/
|
|
20
|
+
private _sbbAngularCompatibility;
|
|
15
21
|
protected fetchSvgIcon(namespace: string, name: string): Promise<string>;
|
|
16
22
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
23
|
+
attributeChangedCallback(name: string, _old: string | null, value: string | null): void;
|
|
17
24
|
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
25
|
+
protected render(): TemplateResult;
|
|
18
26
|
}
|
|
19
27
|
declare global {
|
|
20
28
|
interface HTMLElementTagNameMap {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"icon.d.ts","sourceRoot":"","sources":["../../../../src/elements/icon/icon.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGrE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C;;GAEG;AACH,qBACa,cAAe,SAAQ,WAAW;IAC7C;;;;OAIG;IACiC,IAAI,EAAG,MAAM,CAAC;IAElD,OAAO,CAAC,iBAAiB,CAAM;IAE/B;;;;OAIG;IACM,OAAO,CAAC,wBAAwB,CAAS;cAEzB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;cAiBpE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQ3D,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|
package/development/icon.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { state, property, customElement } from "lit/decorators.js";
|
|
2
1
|
import { isServer, css, LitElement, html, nothing } from "lit";
|
|
2
|
+
import { state, property, customElement } from "lit/decorators.js";
|
|
3
3
|
import { unsafeHTML } from "lit/directives/unsafe-html.js";
|
|
4
4
|
import { until } from "lit/directives/until.js";
|
|
5
5
|
import { hostAttributes } from "./core/decorators.js";
|
|
@@ -240,6 +240,7 @@ let SbbIconElement = class extends SbbIconBase {
|
|
|
240
240
|
constructor() {
|
|
241
241
|
super(...arguments);
|
|
242
242
|
this._defaultAriaLabel = "";
|
|
243
|
+
this._sbbAngularCompatibility = false;
|
|
243
244
|
}
|
|
244
245
|
async fetchSvgIcon(namespace, name) {
|
|
245
246
|
if (this.getAttribute("aria-label") === this._defaultAriaLabel) {
|
|
@@ -257,16 +258,29 @@ let SbbIconElement = class extends SbbIconBase {
|
|
|
257
258
|
this.loadSvgIcon(this.name);
|
|
258
259
|
}
|
|
259
260
|
}
|
|
261
|
+
attributeChangedCallback(name, _old, value) {
|
|
262
|
+
if (name === "svgicon") {
|
|
263
|
+
this._sbbAngularCompatibility = !!value;
|
|
264
|
+
} else {
|
|
265
|
+
super.attributeChangedCallback(name, _old, value);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
260
268
|
firstUpdated(changedProperties) {
|
|
261
269
|
super.firstUpdated(changedProperties);
|
|
262
270
|
if (!this.hasAttribute("aria-hidden")) {
|
|
263
271
|
this.setAttribute("aria-hidden", "true");
|
|
264
272
|
}
|
|
265
273
|
}
|
|
274
|
+
render() {
|
|
275
|
+
return this._sbbAngularCompatibility ? html`<slot></slot>` : super.render();
|
|
276
|
+
}
|
|
266
277
|
};
|
|
267
278
|
__decorateClass$1([
|
|
268
279
|
property({ reflect: true })
|
|
269
280
|
], SbbIconElement.prototype, "name", 2);
|
|
281
|
+
__decorateClass$1([
|
|
282
|
+
state()
|
|
283
|
+
], SbbIconElement.prototype, "_sbbAngularCompatibility", 2);
|
|
270
284
|
SbbIconElement = __decorateClass$1([
|
|
271
285
|
customElement("sbb-icon")
|
|
272
286
|
], SbbIconElement);
|
|
@@ -302,4 +316,4 @@ export {
|
|
|
302
316
|
isValid,
|
|
303
317
|
validateContent
|
|
304
318
|
};
|
|
305
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"icon.js","sources":["../../../src/elements/icon/icon-validate.ts","../../../src/elements/icon/icon-request.ts","../../../src/elements/icon/icon-base.ts","../../../src/elements/icon/icon.ts","../../../src/elements/icon/icon-name-mixin.ts"],"sourcesContent":["const isStr = (val: any): val is string => typeof val === 'string';\n\n/**\n * Sanitizes the SVG element and all its child nodes.\n * Does not allow `<script>` elements, or any attributes that start with `on`, such as `onclick`.\n */\nexport const isValid = (elm: HTMLElement): boolean => {\n  if (elm.nodeType === 1) {\n    // is an Element node like <div>, <p> or <svg>\n    if (elm.nodeName.toLowerCase() === 'script') {\n      return false;\n    }\n\n    // do not allow attributes starting with `on`\n    for (let i = 0; i < elm.attributes.length; i++) {\n      const val = elm.attributes[i].name;\n      if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {\n        return false;\n      }\n    }\n\n    for (let i = 0; i < elm.childNodes.length; i++) {\n      if (!isValid(elm.childNodes[i] as any)) {\n        return false;\n      }\n    }\n  }\n  return true;\n};\n\n/**\n * Validates the SVG content by checking that it has only one root element `<svg>`,\n * adding the `color-immutable` class if the `colorImmutable` option is set to `true`,\n * and sanitizing the provided content as long as the `sanitize` property is not explicitly set to `false`.\n */\nexport const validateContent = (\n  svgContent: string,\n  sanitize = true,\n  colorImmutable = false,\n): string => {\n  const div = document.createElement('div');\n  div.innerHTML = svgContent;\n\n  for (let i = div.childNodes.length - 1; i >= 0; i--) {\n    if (div.childNodes[i].nodeName.toLowerCase() !== 'svg') {\n      div.removeChild(div.childNodes[i]);\n    }\n  }\n\n  // must only have 1 root element\n  const svgElm = div.firstElementChild;\n\n  if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {\n    if (colorImmutable && !svgElm.classList.contains('color-immutable')) {\n      svgElm.classList.add('color-immutable');\n    }\n\n    // do not sanitize the svg element\n    if (sanitize === false) {\n      return div.innerHTML;\n    }\n\n    // sanitize the svg element\n    if (isValid(svgElm as any)) {\n      return div.innerHTML;\n    }\n  }\n  return '';\n};\n","import { isServer } from 'lit';\n\nimport type { SbbIconConfig } from '../core/config.js';\nimport { readConfig } from '../core/config.js';\n\nimport { validateContent } from './icon-validate.js';\n\nconst iconCdn = 'https://icons.app.sbb.ch/';\n\nconst iconNamespaces = new Map<string, string>()\n  .set('default', `${iconCdn}icons/`)\n  .set('picto', `${iconCdn}picto/`);\nconst requests = new Map<string, Promise<any>>();\n\n/** Fetches icon svg content from providers and asserts only one request per icon is made. */\nexport const getSvgContent = (\n  namespace: string,\n  name: string,\n  sanitize: boolean,\n): Promise<string> => {\n  const config: SbbIconConfig = readConfig().icon ?? {};\n\n  const resolvedNamespace = config.namespaces?.get(namespace) ?? iconNamespaces.get(namespace);\n  if (resolvedNamespace == null) {\n    throw Error(\n      `Unable to find the namespace \"${namespace}\". Please register your custom namespace.`,\n    );\n  }\n  const url = `${resolvedNamespace}${name}.svg`;\n\n  // Check if we already have a request for this url\n  let req = requests.get(url);\n\n  if (!req) {\n    // We cannot support server side rendered icons (yet), as the validation\n    // is done via DOM, which is not available during SSR.\n    if (typeof fetch !== 'undefined' && !isServer) {\n      const interceptor = config.interceptor ?? ((i) => i.request());\n\n      req = interceptor({\n        namespace,\n        name,\n        url,\n        request: () =>\n          fetch(url)\n            .then(async (response) => {\n              if (!response.ok) {\n                throw new Error('Failed to load icon ' + namespace + ':' + name);\n              }\n              return validateContent(await response.text(), sanitize);\n            })\n            .catch((error) => {\n              throw Error(error);\n            }),\n      });\n      // Cache for the same requests\n      requests.set(url, req);\n    } else {\n      // Resolve promise for ssr scenarios\n      return Promise.resolve('');\n    }\n  }\n\n  return req;\n};\n","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport type { DirectiveResult } from 'lit/directive.js';\nimport type { UnsafeHTMLDirective } from 'lit/directives/unsafe-html.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { until } from 'lit/directives/until.js';\n\nimport { hostAttributes } from '../core/decorators.js';\n\nimport { getSvgContent } from './icon-request.js';\nimport style from './icon.scss?lit&inline';\n\n/**\n * @cssprop [--sbb-icon-svg-width=auto] - Can be used to set a custom width.\n * @cssprop [--sbb-icon-svg-height=auto] - Can be used to set a custom height.\n */\n@hostAttributes({\n  'data-namespace': SbbIconBase._defaultNamespace,\n  'data-empty': '',\n})\nexport abstract class SbbIconBase extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  private static readonly _defaultNamespace = 'default';\n\n  @state() private _svgNamespace = SbbIconBase._defaultNamespace;\n\n  /**\n   * The icon svg content rendered on the page: <svg>...</svg>.\n   */\n  @state() private _svgIcon?: Promise<DirectiveResult<typeof UnsafeHTMLDirective>>;\n\n  /**\n   * When set to `true`, SVG content that is HTTP fetched will not be checked\n   * if the response SVG content has any `<script>` elements, or any attributes\n   * that start with `on`, such as `onclick`.\n   * @default false\n   */\n  @property({ attribute: 'no-sanitize', type: Boolean }) public noSanitize = false;\n\n  protected async loadSvgIcon(iconName: string): Promise<void> {\n    if (!iconName) {\n      return;\n    }\n\n    const [namespace, name] = this._splitIconName(iconName);\n    this._svgNamespace = namespace;\n    this.setAttribute('data-namespace', this._svgNamespace);\n\n    const svgIcon = this.fetchSvgIcon(this._svgNamespace, name);\n    this._svgIcon = svgIcon.then((v) => unsafeHTML(v));\n    try {\n      this.toggleAttribute('data-empty', !(await svgIcon));\n    } catch {\n      this.toggleAttribute('data-empty', true);\n    }\n  }\n\n  protected async fetchSvgIcon(namespace: string, name: string): Promise<string> {\n    return await getSvgContent(namespace, name, !this.noSanitize);\n  }\n\n  private _splitIconName(iconName: string): [string, string] {\n    if (!iconName) {\n      return ['', ''];\n    }\n    const parts = iconName.split(':');\n    switch (parts.length) {\n      case 1:\n        // Use default namespace if empty.\n        return [SbbIconBase._defaultNamespace, parts[0]];\n      case 2:\n        return parts as [string, string];\n      default:\n        throw Error(`Invalid icon name: \"${iconName}\"`);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.setAttribute('role', this.getAttribute('role') ?? 'img');\n  }\n\n  protected override render(): TemplateResult {\n    return html`<span class=\"sbb-icon-inner\"\n      >${until(\n        this._svgIcon,\n        // To reserve space, we need an empty svg to apply dimension to.\n        html`<svg width=\"0\" height=\"0\"></svg>`,\n      )}</span\n    >`;\n  }\n}\n","import type { PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbIconBase } from './icon-base.js';\n\n/**\n * It displays an icon loaded from a registered namespace.\n */\n@customElement('sbb-icon')\nexport class SbbIconElement extends SbbIconBase {\n  /**\n   * The provided name consisting of the namespace and the name of the icon.\n   * If the namespace is missing, the default namespace \"sbb\" will be used.\n   * E.g. `name` (will use \"sbb\" as namespace) or `namespace:name`.\n   */\n  @property({ reflect: true }) public name!: string;\n\n  private _defaultAriaLabel = '';\n\n  protected override async fetchSvgIcon(namespace: string, name: string): Promise<string> {\n    // If the icon is changing, and we were using the defaultAriaLabel, reset it\n    if (this.getAttribute('aria-label') === this._defaultAriaLabel) {\n      this.removeAttribute('aria-label');\n    }\n\n    this._defaultAriaLabel = `Icon ${name.replace(/-/g, ' ')}`;\n\n    // generate a default label in case user does not provide their own\n    // and aria-hidden is set to \"false\"\n    if (this.getAttribute('aria-hidden') === 'false' && !this.hasAttribute('aria-label') && name) {\n      this.setAttribute('aria-label', this._defaultAriaLabel);\n    }\n\n    return super.fetchSvgIcon(namespace, name);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('name')) {\n      this.loadSvgIcon(this.name);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    if (!this.hasAttribute('aria-hidden')) {\n      this.setAttribute('aria-hidden', 'true');\n    }\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-icon': SbbIconElement;\n  }\n}\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from '../core/mixins.js';\n\nimport './icon.js';\n\nexport declare class SbbIconNameMixinType {\n  public iconName?: string;\n  protected renderIconSlot(classname?: string): TemplateResult;\n}\n\n/**\n * Enhance your component with an iconName property and provides a template for the icon slot.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbIconNameMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbIconNameMixinType> & T => {\n  abstract class SbbIconNameElement extends superClass implements Partial<SbbIconNameMixinType> {\n    /**\n     * The icon name we want to use, choose from the small icon variants\n     * from the ui-icons category from here\n     * https://icons.app.sbb.ch.\n     */\n    @property({ attribute: 'icon-name', reflect: true }) public iconName?: string;\n\n    protected renderIconSlot(classname?: string): TemplateResult {\n      return html`\n        <slot name=\"icon\">\n          ${this.iconName\n            ? html`<sbb-icon name=${this.iconName} class=${classname || nothing}></sbb-icon>`\n            : nothing}\n        </slot>\n      `;\n    }\n  }\n\n  return SbbIconNameElement as unknown as AbstractConstructor<SbbIconNameMixinType> & T;\n};\n"],"names":["__decorateClass"],"mappings":"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"}
|
|
319
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"icon.js","sources":["../../../src/elements/icon/icon-validate.ts","../../../src/elements/icon/icon-request.ts","../../../src/elements/icon/icon-base.ts","../../../src/elements/icon/icon.ts","../../../src/elements/icon/icon-name-mixin.ts"],"sourcesContent":["const isStr = (val: any): val is string => typeof val === 'string';\n\n/**\n * Sanitizes the SVG element and all its child nodes.\n * Does not allow `<script>` elements, or any attributes that start with `on`, such as `onclick`.\n */\nexport const isValid = (elm: HTMLElement): boolean => {\n  if (elm.nodeType === 1) {\n    // is an Element node like <div>, <p> or <svg>\n    if (elm.nodeName.toLowerCase() === 'script') {\n      return false;\n    }\n\n    // do not allow attributes starting with `on`\n    for (let i = 0; i < elm.attributes.length; i++) {\n      const val = elm.attributes[i].name;\n      if (isStr(val) && val.toLowerCase().indexOf('on') === 0) {\n        return false;\n      }\n    }\n\n    for (let i = 0; i < elm.childNodes.length; i++) {\n      if (!isValid(elm.childNodes[i] as any)) {\n        return false;\n      }\n    }\n  }\n  return true;\n};\n\n/**\n * Validates the SVG content by checking that it has only one root element `<svg>`,\n * adding the `color-immutable` class if the `colorImmutable` option is set to `true`,\n * and sanitizing the provided content as long as the `sanitize` property is not explicitly set to `false`.\n */\nexport const validateContent = (\n  svgContent: string,\n  sanitize = true,\n  colorImmutable = false,\n): string => {\n  const div = document.createElement('div');\n  div.innerHTML = svgContent;\n\n  for (let i = div.childNodes.length - 1; i >= 0; i--) {\n    if (div.childNodes[i].nodeName.toLowerCase() !== 'svg') {\n      div.removeChild(div.childNodes[i]);\n    }\n  }\n\n  // must only have 1 root element\n  const svgElm = div.firstElementChild;\n\n  if (svgElm && svgElm.nodeName.toLowerCase() === 'svg') {\n    if (colorImmutable && !svgElm.classList.contains('color-immutable')) {\n      svgElm.classList.add('color-immutable');\n    }\n\n    // do not sanitize the svg element\n    if (sanitize === false) {\n      return div.innerHTML;\n    }\n\n    // sanitize the svg element\n    if (isValid(svgElm as any)) {\n      return div.innerHTML;\n    }\n  }\n  return '';\n};\n","import { isServer } from 'lit';\n\nimport type { SbbIconConfig } from '../core/config.js';\nimport { readConfig } from '../core/config.js';\n\nimport { validateContent } from './icon-validate.js';\n\nconst iconCdn = 'https://icons.app.sbb.ch/';\n\nconst iconNamespaces = new Map<string, string>()\n  .set('default', `${iconCdn}icons/`)\n  .set('picto', `${iconCdn}picto/`);\nconst requests = new Map<string, Promise<any>>();\n\n/** Fetches icon svg content from providers and asserts only one request per icon is made. */\nexport const getSvgContent = (\n  namespace: string,\n  name: string,\n  sanitize: boolean,\n): Promise<string> => {\n  const config: SbbIconConfig = readConfig().icon ?? {};\n\n  const resolvedNamespace = config.namespaces?.get(namespace) ?? iconNamespaces.get(namespace);\n  if (resolvedNamespace == null) {\n    throw Error(\n      `Unable to find the namespace \"${namespace}\". Please register your custom namespace.`,\n    );\n  }\n  const url = `${resolvedNamespace}${name}.svg`;\n\n  // Check if we already have a request for this url\n  let req = requests.get(url);\n\n  if (!req) {\n    // We cannot support server side rendered icons (yet), as the validation\n    // is done via DOM, which is not available during SSR.\n    if (typeof fetch !== 'undefined' && !isServer) {\n      const interceptor = config.interceptor ?? ((i) => i.request());\n\n      req = interceptor({\n        namespace,\n        name,\n        url,\n        request: () =>\n          fetch(url)\n            .then(async (response) => {\n              if (!response.ok) {\n                throw new Error('Failed to load icon ' + namespace + ':' + name);\n              }\n              return validateContent(await response.text(), sanitize);\n            })\n            .catch((error) => {\n              throw Error(error);\n            }),\n      });\n      // Cache for the same requests\n      requests.set(url, req);\n    } else {\n      // Resolve promise for ssr scenarios\n      return Promise.resolve('');\n    }\n  }\n\n  return req;\n};\n","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport type { DirectiveResult } from 'lit/directive.js';\nimport type { UnsafeHTMLDirective } from 'lit/directives/unsafe-html.js';\nimport { unsafeHTML } from 'lit/directives/unsafe-html.js';\nimport { until } from 'lit/directives/until.js';\n\nimport { hostAttributes } from '../core/decorators.js';\n\nimport { getSvgContent } from './icon-request.js';\nimport style from './icon.scss?lit&inline';\n\n/**\n * @cssprop [--sbb-icon-svg-width=auto] - Can be used to set a custom width.\n * @cssprop [--sbb-icon-svg-height=auto] - Can be used to set a custom height.\n */\n@hostAttributes({\n  'data-namespace': SbbIconBase._defaultNamespace,\n  'data-empty': '',\n})\nexport abstract class SbbIconBase extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  private static readonly _defaultNamespace = 'default';\n\n  @state() private _svgNamespace = SbbIconBase._defaultNamespace;\n\n  /**\n   * The icon svg content rendered on the page: <svg>...</svg>.\n   */\n  @state() private _svgIcon?: Promise<DirectiveResult<typeof UnsafeHTMLDirective>>;\n\n  /**\n   * When set to `true`, SVG content that is HTTP fetched will not be checked\n   * if the response SVG content has any `<script>` elements, or any attributes\n   * that start with `on`, such as `onclick`.\n   * @default false\n   */\n  @property({ attribute: 'no-sanitize', type: Boolean }) public noSanitize = false;\n\n  protected async loadSvgIcon(iconName: string): Promise<void> {\n    if (!iconName) {\n      return;\n    }\n\n    const [namespace, name] = this._splitIconName(iconName);\n    this._svgNamespace = namespace;\n    this.setAttribute('data-namespace', this._svgNamespace);\n\n    const svgIcon = this.fetchSvgIcon(this._svgNamespace, name);\n    this._svgIcon = svgIcon.then((v) => unsafeHTML(v));\n    try {\n      this.toggleAttribute('data-empty', !(await svgIcon));\n    } catch {\n      this.toggleAttribute('data-empty', true);\n    }\n  }\n\n  protected async fetchSvgIcon(namespace: string, name: string): Promise<string> {\n    return await getSvgContent(namespace, name, !this.noSanitize);\n  }\n\n  private _splitIconName(iconName: string): [string, string] {\n    if (!iconName) {\n      return ['', ''];\n    }\n    const parts = iconName.split(':');\n    switch (parts.length) {\n      case 1:\n        // Use default namespace if empty.\n        return [SbbIconBase._defaultNamespace, parts[0]];\n      case 2:\n        return parts as [string, string];\n      default:\n        throw Error(`Invalid icon name: \"${iconName}\"`);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.setAttribute('role', this.getAttribute('role') ?? 'img');\n  }\n\n  protected override render(): TemplateResult {\n    return html`<span class=\"sbb-icon-inner\"\n      >${until(\n        this._svgIcon,\n        // To reserve space, we need an empty svg to apply dimension to.\n        html`<svg width=\"0\" height=\"0\"></svg>`,\n      )}</span\n    >`;\n  }\n}\n","import { html, type PropertyValues, type TemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbIconBase } from './icon-base.js';\n\n/**\n * It displays an icon loaded from a registered namespace.\n */\n@customElement('sbb-icon')\nexport class SbbIconElement extends SbbIconBase {\n  /**\n   * The provided name consisting of the namespace and the name of the icon.\n   * If the namespace is missing, the default namespace \"sbb\" will be used.\n   * E.g. `name` (will use \"sbb\" as namespace) or `namespace:name`.\n   */\n  @property({ reflect: true }) public name!: string;\n\n  private _defaultAriaLabel = '';\n\n  /**\n   * The sbb-angular library has a sbb-icon component as well. In order to provide\n   * compatibility with it (as some icons are used internally inside the other sbb-angular\n   * components) we need to check whether the attribute svgicon is used.\n   */\n  @state() private _sbbAngularCompatibility = false;\n\n  protected override async fetchSvgIcon(namespace: string, name: string): Promise<string> {\n    // If the icon is changing, and we were using the defaultAriaLabel, reset it\n    if (this.getAttribute('aria-label') === this._defaultAriaLabel) {\n      this.removeAttribute('aria-label');\n    }\n\n    this._defaultAriaLabel = `Icon ${name.replace(/-/g, ' ')}`;\n\n    // generate a default label in case user does not provide their own\n    // and aria-hidden is set to \"false\"\n    if (this.getAttribute('aria-hidden') === 'false' && !this.hasAttribute('aria-label') && name) {\n      this.setAttribute('aria-label', this._defaultAriaLabel);\n    }\n\n    return super.fetchSvgIcon(namespace, name);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('name')) {\n      this.loadSvgIcon(this.name);\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    _old: string | null,\n    value: string | null,\n  ): void {\n    if (name === 'svgicon') {\n      this._sbbAngularCompatibility = !!value;\n    } else {\n      super.attributeChangedCallback(name, _old, value);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    if (!this.hasAttribute('aria-hidden')) {\n      this.setAttribute('aria-hidden', 'true');\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return this._sbbAngularCompatibility ? html`<slot></slot>` : super.render();\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-icon': SbbIconElement;\n  }\n}\n","import { html, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from '../core/mixins.js';\n\nimport './icon.js';\n\nexport declare class SbbIconNameMixinType {\n  public iconName?: string;\n  protected renderIconSlot(classname?: string): TemplateResult;\n}\n\n/**\n * Enhance your component with an iconName property and provides a template for the icon slot.\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbIconNameMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbIconNameMixinType> & T => {\n  abstract class SbbIconNameElement extends superClass implements Partial<SbbIconNameMixinType> {\n    /**\n     * The icon name we want to use, choose from the small icon variants\n     * from the ui-icons category from here\n     * https://icons.app.sbb.ch.\n     */\n    @property({ attribute: 'icon-name', reflect: true }) public iconName?: string;\n\n    protected renderIconSlot(classname?: string): TemplateResult {\n      return html`\n        <slot name=\"icon\">\n          ${this.iconName\n            ? html`<sbb-icon name=${this.iconName} class=${classname || nothing}></sbb-icon>`\n            : nothing}\n        </slot>\n      `;\n    }\n  }\n\n  return SbbIconNameElement as unknown as AbstractConstructor<SbbIconNameMixinType> & T;\n};\n"],"names":["__decorateClass"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["../../../../../src/elements/menu/menu/menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAYrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAYtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAkB1D;;;;;;;;;;;GAWG;AACH,qBACa,cAAe,SAAQ,mBAGV;IACxB,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAwC;IAEvF;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;;OAGG;IACyD,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAE5F,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,yBAAyB,CAAkB;IACnD,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAEhD;;OAEG;IACI,IAAI,IAAI,IAAI;IAmBnB;;OAEG;IACI,KAAK,IAAI,IAAI;IAapB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB,OAAO,CAAC,cAAc;YAsBR,eAAe;IAY7B,OAAO,CAAC,2BAA2B;IAWnB,iBAAiB,IAAI,IAAI;IAoBzB,oBAAoB,IAAI,IAAI;
|
|
1
|
+
{"version":3,"file":"menu.d.ts","sourceRoot":"","sources":["../../../../../src/elements/menu/menu/menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAYrE,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAYtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAkB1D;;;;;;;;;;;GAWG;AACH,qBACa,cAAe,SAAQ,mBAGV;IACxB,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,mBAA4B,mBAAmB,WAAwC;IAEvF;;;OAGG;IACH,IACW,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,EAIpD;IACD,IAAW,OAAO,IAAI,MAAM,GAAG,WAAW,GAAG,IAAI,CAEhD;IACD,OAAO,CAAC,QAAQ,CAAqC;IAErD;;;OAGG;IACyD,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAE5F,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,yBAAyB,CAAkB;IACnD,OAAO,CAAC,eAAe,CAAmB;IAC1C,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,aAAa,CAAyB;IAC9C,OAAO,CAAC,cAAc,CAA0B;IAEhD;;OAEG;IACI,IAAI,IAAI,IAAI;IAmBnB;;OAEG;IACI,KAAK,IAAI,IAAI;IAapB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB,OAAO,CAAC,cAAc;YAsBR,eAAe;IAY7B,OAAO,CAAC,2BAA2B;IAWnB,iBAAiB,IAAI,IAAI;IAoBzB,oBAAoB,IAAI,IAAI;IAS5C,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,UAAU;IAsBlB,OAAO,CAAC,mBAAmB;IAwB3B,OAAO,CAAC,+BAA+B;IAQvC,OAAO,CAAC,oBAAoB,CAE1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAMF,OAAO,CAAC,mBAAmB;IA8B3B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,gBAAgB;cAyBL,MAAM,IAAI,cAAc;CAqB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|