@sbb-esta/lyne-elements 1.11.3 → 1.12.1
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/_index.scss +1 -1
- package/core/i18n/i18n.d.ts +5 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n.js +85 -55
- package/core/styles/core/functions.scss +1 -1
- package/core/styles/lists.scss +4 -0
- package/core/styles/mixins/helpers.scss +1 -1
- package/core/styles/mixins/lists.scss +128 -77
- package/core/styles/mixins/scrollbar.scss +2 -2
- package/core/styles/mixins/table.scss +4 -6
- package/core/styles/normalize.scss +62 -131
- package/core.css +0 -5
- package/custom-elements.json +781 -77
- package/development/accordion.js +2 -9
- package/development/action-group.js +2 -9
- package/development/alert/alert-group.js +2 -9
- package/development/alert/alert.js +2 -9
- package/development/autocomplete-grid/autocomplete-grid-button.js +2 -9
- package/development/autocomplete-grid/autocomplete-grid-cell.js +2 -9
- package/development/autocomplete-grid/autocomplete-grid-option.js +2 -9
- package/development/autocomplete-grid/autocomplete-grid-row.js +2 -9
- package/development/autocomplete.js +2 -12
- package/development/breadcrumb/breadcrumb-group.js +2 -9
- package/development/breadcrumb/breadcrumb.js +2 -9
- package/development/button/common.js +2 -11
- package/development/button/mini-button-group.js +2 -9
- package/development/button/mini-button.js +2 -9
- package/development/calendar.js +2 -9
- package/development/card/card-badge.js +2 -9
- package/development/card/card.js +2 -9
- package/development/card/common.js +2 -9
- package/development/checkbox/checkbox-group.js +2 -9
- package/development/checkbox/checkbox.js +2 -9
- package/development/checkbox/common.js +1 -8
- package/development/chip.js +2 -9
- package/development/clock.js +2 -9
- package/development/container/container.js +1 -8
- package/development/container/sticky-bar.js +2 -9
- package/development/core/i18n/i18n.d.ts +5 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n.js +36 -1
- package/development/core/mixins.js +2 -9
- package/development/datepicker/datepicker-next-day.js +2 -9
- package/development/datepicker/datepicker-previous-day.js +2 -9
- package/development/datepicker/datepicker-toggle.js +2 -9
- package/development/datepicker/datepicker.js +2 -9
- package/development/dialog/dialog-actions.js +2 -9
- package/development/dialog/dialog-content.js +2 -11
- package/development/dialog/dialog-title.js +2 -9
- package/development/dialog/dialog.js +2 -9
- package/development/divider.js +2 -9
- package/development/expansion-panel/expansion-panel-content.js +2 -9
- package/development/expansion-panel/expansion-panel-header.js +2 -9
- package/development/expansion-panel/expansion-panel.js +2 -9
- package/development/file-selector.js +2 -9
- package/development/flip-card/flip-card-details.js +2 -9
- package/development/flip-card/flip-card-summary.js +2 -9
- package/development/flip-card/flip-card.js +2 -9
- package/development/footer.js +2 -9
- package/development/form-error.js +2 -9
- package/development/form-field/form-field-clear.js +2 -9
- package/development/form-field/form-field.js +1 -12
- package/development/header/common.js +2 -9
- package/development/header/header.js +2 -9
- package/development/icon.js +2 -9
- package/development/image/image.d.ts +1 -0
- package/development/image/image.d.ts.map +1 -1
- package/development/image.js +13 -13
- package/development/journey-header.js +2 -9
- package/development/lead-container.js +2 -9
- package/development/link/common.js +4 -25
- package/development/link-list/common.js +2 -9
- package/development/link-list/link-list-anchor.js +2 -9
- package/development/link-list/link-list.js +2 -9
- package/development/loading-indicator.js +2 -10
- package/development/logo.js +2 -9
- package/development/map-container.js +2 -11
- package/development/menu/common.js +2 -9
- package/development/menu/menu.js +2 -11
- package/development/message.js +2 -9
- package/development/navigation/common.js +2 -9
- package/development/navigation/navigation-list.js +2 -9
- package/development/navigation/navigation-marker.js +2 -9
- package/development/navigation/navigation-section.js +2 -11
- package/development/navigation/navigation.js +2 -11
- package/development/notification.js +2 -10
- package/development/option/optgroup.js +2 -9
- package/development/option/option.js +2 -9
- package/development/overlay.js +2 -11
- package/development/paginator/index.d.ts +2 -0
- package/development/paginator/index.d.ts.map +1 -0
- package/development/paginator/paginator.d.ts +91 -0
- package/development/paginator/paginator.d.ts.map +1 -0
- package/development/paginator.d.ts +2 -0
- package/development/paginator.d.ts.map +1 -0
- package/development/paginator.js +519 -0
- package/development/popover/popover-trigger.js +2 -9
- package/development/popover/popover.js +2 -9
- package/development/radio-button/common.js +2 -9
- package/development/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
- package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/development/radio-button/radio-button-group.js +19 -22
- package/development/radio-button/radio-button.js +2 -9
- package/development/screen-reader-only.js +2 -9
- package/development/select/select.d.ts +6 -0
- package/development/select/select.d.ts.map +1 -1
- package/development/select.js +23 -18
- package/development/selection-expansion-panel.js +2 -9
- package/development/signet.js +2 -9
- package/development/skiplink-list.js +2 -9
- package/development/slider/slider.d.ts +35 -16
- package/development/slider/slider.d.ts.map +1 -1
- package/development/slider.js +102 -88
- package/development/status.js +2 -9
- package/development/stepper/step-label.js +2 -9
- package/development/stepper/step.js +2 -9
- package/development/stepper/stepper.js +2 -9
- package/development/table/table-wrapper.js +2 -11
- package/development/tabs/tab-group.js +2 -9
- package/development/tabs/tab-label.js +2 -9
- package/development/tabs/tab.js +1 -8
- package/development/tag/tag-group.js +2 -9
- package/development/tag/tag.js +2 -9
- package/development/teaser-hero.js +2 -9
- package/development/teaser-product/common.js +2 -9
- package/development/teaser-product/teaser-product.js +2 -9
- package/development/teaser.js +12 -11
- package/development/time-input.js +2 -9
- package/development/timetable-occupancy-icon.js +2 -9
- package/development/timetable-occupancy.js +2 -9
- package/development/title.js +3 -17
- package/development/toast.js +2 -9
- package/development/toggle/toggle-option.js +2 -9
- package/development/toggle/toggle.js +2 -9
- package/development/toggle-check.js +1 -8
- package/development/train/train-blocked-passage.js +2 -9
- package/development/train/train-formation.js +2 -11
- package/development/train/train-wagon.js +2 -9
- package/development/train/train.js +2 -9
- package/development/visual-checkbox.js +2 -9
- package/image/image.d.ts +1 -0
- package/image/image.d.ts.map +1 -1
- package/image.js +7 -7
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/lists.css +97 -38
- package/normalize.css +21 -113
- package/package.json +6 -1
- package/paginator/index.d.ts +2 -0
- package/paginator/index.d.ts.map +1 -0
- package/paginator/paginator.d.ts +91 -0
- package/paginator/paginator.d.ts.map +1 -0
- package/paginator.d.ts +2 -0
- package/paginator.d.ts.map +1 -0
- package/paginator.js +263 -0
- package/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
- package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/radio-button/radio-button-group.js +13 -8
- package/select/select.d.ts +6 -0
- package/select/select.d.ts.map +1 -1
- package/select.js +40 -24
- package/slider/slider.d.ts +35 -16
- package/slider/slider.d.ts.map +1 -1
- package/slider.js +111 -78
- package/standard-theme.css +116 -160
- package/teaser.js +16 -16
package/development/slider.js
CHANGED
|
@@ -4,18 +4,10 @@ import { ref } from "lit/directives/ref.js";
|
|
|
4
4
|
import { styleMap } from "lit/directives/style-map.js";
|
|
5
5
|
import { SbbConnectedAbortController } from "./core/controllers.js";
|
|
6
6
|
import { hostAttributes } from "./core/decorators.js";
|
|
7
|
-
import { setOrRemoveAttribute } from "./core/dom.js";
|
|
8
7
|
import { EventEmitter, forwardEventToHost } from "./core/eventing.js";
|
|
9
|
-
import { SbbDisabledMixin } from "./core/mixins.js";
|
|
8
|
+
import { SbbDisabledMixin, SbbFormAssociatedMixin } from "./core/mixins.js";
|
|
10
9
|
import "./icon.js";
|
|
11
10
|
const style = css`@charset "UTF-8";
|
|
12
|
-
/** This mixin can be used to avoid spacing problems by inserting an invisible space as pseudo element. */
|
|
13
|
-
/*
|
|
14
|
-
* SBB table mixin
|
|
15
|
-
* Notes:
|
|
16
|
-
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
17
|
-
* Therefore, we have to build the grid avoiding double borders.
|
|
18
|
-
*/
|
|
19
11
|
*,
|
|
20
12
|
::before,
|
|
21
13
|
::after {
|
|
@@ -48,7 +40,7 @@ const style = css`@charset "UTF-8";
|
|
|
48
40
|
}
|
|
49
41
|
}
|
|
50
42
|
|
|
51
|
-
:host(
|
|
43
|
+
:host(:disabled) {
|
|
52
44
|
--sbb-slider-icon-color: var(--sbb-color-graphite);
|
|
53
45
|
--sbb-slider-knob-border-color: var(--sbb-color-smoke);
|
|
54
46
|
--sbb-slider-knob-border-size: var(--sbb-border-width-2x);
|
|
@@ -60,13 +52,13 @@ const style = css`@charset "UTF-8";
|
|
|
60
52
|
--sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color);
|
|
61
53
|
}
|
|
62
54
|
|
|
63
|
-
:host(
|
|
55
|
+
:host(:disabled),
|
|
64
56
|
:host([readonly]) {
|
|
65
57
|
--sbb-slider-line-color: var(--sbb-slider-line-disabled-color);
|
|
66
58
|
--sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color);
|
|
67
59
|
}
|
|
68
60
|
@media (forced-colors: active) {
|
|
69
|
-
:host(
|
|
61
|
+
:host(:disabled),
|
|
70
62
|
:host([readonly]) {
|
|
71
63
|
--sbb-slider-icon-color: GrayText;
|
|
72
64
|
--sbb-slider-selected-line-disabled-color: GrayText;
|
|
@@ -146,7 +138,7 @@ const style = css`@charset "UTF-8";
|
|
|
146
138
|
outline: var(--sbb-focus-outline-color) solid var(--sbb-focus-outline-width);
|
|
147
139
|
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
148
140
|
}
|
|
149
|
-
:host(:not(:is(
|
|
141
|
+
:host(:not(:is(:disabled, [readonly]))) .sbb-slider__range-input:active ~ .sbb-slider__knob {
|
|
150
142
|
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
151
143
|
}`;
|
|
152
144
|
var __defProp = Object.defineProperty;
|
|
@@ -159,13 +151,11 @@ var __decorateClass = (decorators, target, key, kind) => {
|
|
|
159
151
|
if (kind && result) __defProp(target, key, result);
|
|
160
152
|
return result;
|
|
161
153
|
};
|
|
162
|
-
let SbbSliderElement = class extends SbbDisabledMixin(LitElement) {
|
|
154
|
+
let SbbSliderElement = class extends SbbDisabledMixin(SbbFormAssociatedMixin(LitElement)) {
|
|
163
155
|
constructor() {
|
|
164
|
-
super(
|
|
165
|
-
this.
|
|
166
|
-
this.
|
|
167
|
-
this.min = "0";
|
|
168
|
-
this.max = "100";
|
|
156
|
+
super();
|
|
157
|
+
this._min = "0";
|
|
158
|
+
this._max = "100";
|
|
169
159
|
this.readonly = false;
|
|
170
160
|
this._valueFraction = 0;
|
|
171
161
|
this._didChange = new EventEmitter(this, SbbSliderElement.events.didChange, {
|
|
@@ -173,96 +163,128 @@ let SbbSliderElement = class extends SbbDisabledMixin(LitElement) {
|
|
|
173
163
|
cancelable: true
|
|
174
164
|
});
|
|
175
165
|
this._abort = new SbbConnectedAbortController(this);
|
|
166
|
+
this.internals.role = "slider";
|
|
167
|
+
}
|
|
168
|
+
set value(value) {
|
|
169
|
+
if (this._isValidNumber(value)) {
|
|
170
|
+
super.value = this._boundBetweenMinMax(value);
|
|
171
|
+
} else {
|
|
172
|
+
super.value = this._getDefaultValue();
|
|
173
|
+
}
|
|
174
|
+
this.internals.ariaValueNow = this.value;
|
|
175
|
+
this._calculateValueFraction();
|
|
176
|
+
}
|
|
177
|
+
get value() {
|
|
178
|
+
return super.value;
|
|
179
|
+
}
|
|
180
|
+
set valueAsNumber(value) {
|
|
181
|
+
this.value = value == null ? void 0 : value.toString();
|
|
182
|
+
}
|
|
183
|
+
get valueAsNumber() {
|
|
184
|
+
return Number(this.value);
|
|
185
|
+
}
|
|
186
|
+
set min(value) {
|
|
187
|
+
if (!this._isValidNumber(value)) {
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
this._min = value;
|
|
191
|
+
this.value = this._boundBetweenMinMax(this.value);
|
|
192
|
+
}
|
|
193
|
+
get min() {
|
|
194
|
+
return this._min;
|
|
195
|
+
}
|
|
196
|
+
set max(value) {
|
|
197
|
+
if (!this._isValidNumber(value)) {
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
this._max = value;
|
|
201
|
+
this.value = this._boundBetweenMinMax(this.value);
|
|
202
|
+
}
|
|
203
|
+
get max() {
|
|
204
|
+
return this._max;
|
|
176
205
|
}
|
|
177
206
|
connectedCallback() {
|
|
178
207
|
super.connectedCallback();
|
|
179
208
|
const signal = this._abort.signal;
|
|
180
209
|
this.addEventListener("keydown", (e) => this._handleKeydown(e), { signal });
|
|
181
|
-
this.
|
|
210
|
+
if (!this.value) {
|
|
211
|
+
this.value = this._getDefaultValue();
|
|
212
|
+
}
|
|
182
213
|
}
|
|
183
214
|
willUpdate(changedProperties) {
|
|
184
215
|
super.willUpdate(changedProperties);
|
|
185
|
-
if (changedProperties.has("value")) {
|
|
186
|
-
this._handleChange(Number(this.value));
|
|
187
|
-
} else if (changedProperties.has("valueAsNumber")) {
|
|
188
|
-
this._handleChange(Number(this.valueAsNumber));
|
|
189
|
-
}
|
|
190
216
|
if (changedProperties.has("min")) {
|
|
191
|
-
|
|
217
|
+
this.internals.ariaValueMin = this.min;
|
|
192
218
|
}
|
|
193
219
|
if (changedProperties.has("max")) {
|
|
194
|
-
|
|
220
|
+
this.internals.ariaValueMax = this.max;
|
|
195
221
|
}
|
|
196
222
|
if (changedProperties.has("readonly")) {
|
|
197
|
-
|
|
198
|
-
}
|
|
199
|
-
if (changedProperties.has("disabled")) {
|
|
200
|
-
if (this.disabled) {
|
|
201
|
-
this.setAttribute("aria-disabled", "true");
|
|
202
|
-
this.removeAttribute("tabindex");
|
|
203
|
-
} else {
|
|
204
|
-
this.removeAttribute("aria-disabled");
|
|
205
|
-
this.setAttribute("tabindex", "0");
|
|
206
|
-
}
|
|
223
|
+
this.internals.ariaReadOnly = Boolean(this.readonly).toString();
|
|
207
224
|
}
|
|
208
225
|
}
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
this.value = newValue.toString();
|
|
216
|
-
this.valueAsNumber = newValue;
|
|
217
|
-
setOrRemoveAttribute(this, "aria-valuenow", this.value || null);
|
|
226
|
+
/**
|
|
227
|
+
* The reset value is the attribute value (the setup value). If not present, calculates the default.
|
|
228
|
+
* @internal
|
|
229
|
+
*/
|
|
230
|
+
formResetCallback() {
|
|
231
|
+
this.value = this.getAttribute("value") ?? this._getDefaultValue();
|
|
218
232
|
}
|
|
219
233
|
/**
|
|
220
|
-
*
|
|
221
|
-
* The first calculation happens in connectedCallback(...), so since `_rangeInput` is not yet available,
|
|
222
|
-
* the `min` and `max` values are used; if `value` is not provided, the default value is halfway between min and max
|
|
223
|
-
* (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value).
|
|
234
|
+
* @internal
|
|
224
235
|
*/
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
236
|
+
formStateRestoreCallback(state2, _reason) {
|
|
237
|
+
this.value = state2;
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* If no value is provided, default is the middle point between min and max
|
|
241
|
+
* (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value)
|
|
242
|
+
*/
|
|
243
|
+
_getDefaultValue() {
|
|
244
|
+
return (+this.min + (+this.max - +this.min) / 2).toString();
|
|
245
|
+
}
|
|
246
|
+
_isValidNumber(value) {
|
|
247
|
+
return !!value && !isNaN(Number(value));
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Restrains the value between the min and max
|
|
251
|
+
*/
|
|
252
|
+
_boundBetweenMinMax(value) {
|
|
253
|
+
return Math.max(+this.min, Math.min(+this.max, +value)).toString();
|
|
254
|
+
}
|
|
255
|
+
_calculateValueFraction() {
|
|
256
|
+
const value = this.valueAsNumber;
|
|
257
|
+
const min = +this.min;
|
|
258
|
+
const max = +this.max;
|
|
235
259
|
const mathFraction = (value - min) / (max - min);
|
|
236
|
-
this._valueFraction = isNaN(mathFraction)
|
|
237
|
-
this._syncValues(value);
|
|
260
|
+
this._valueFraction = isNaN(mathFraction) ? 0 : Math.max(0, Math.min(1, mathFraction));
|
|
238
261
|
}
|
|
239
262
|
async _handleKeydown(event) {
|
|
240
263
|
if (event.key !== "Tab") {
|
|
241
264
|
event.preventDefault();
|
|
242
265
|
}
|
|
243
|
-
if (this.
|
|
266
|
+
if (this.readonly) {
|
|
244
267
|
return;
|
|
245
268
|
}
|
|
246
269
|
if (event.key === "Home") {
|
|
247
|
-
this._rangeInput.value = this.
|
|
270
|
+
this._rangeInput.value = this.min;
|
|
248
271
|
} else if (event.key === "End") {
|
|
249
|
-
this._rangeInput.value = this.
|
|
272
|
+
this._rangeInput.value = this.max;
|
|
250
273
|
} else if (event.key === "ArrowLeft" || event.key === "ArrowDown") {
|
|
251
274
|
this._rangeInput.stepDown();
|
|
252
275
|
} else if (event.key === "ArrowRight" || event.key === "ArrowUp") {
|
|
253
276
|
this._rangeInput.stepUp();
|
|
254
277
|
} else if (event.key === "PageDown") {
|
|
255
|
-
this._rangeInput.stepDown((+this.
|
|
278
|
+
this._rangeInput.stepDown((+this.max - +this.min) / 10);
|
|
256
279
|
} else if (event.key === "PageUp") {
|
|
257
|
-
this._rangeInput.stepUp((+this.
|
|
280
|
+
this._rangeInput.stepUp((+this.max - +this.min) / 10);
|
|
258
281
|
} else {
|
|
259
282
|
return;
|
|
260
283
|
}
|
|
261
|
-
this.
|
|
262
|
-
this.dispatchEvent(
|
|
284
|
+
this._rangeInput.dispatchEvent(
|
|
263
285
|
new InputEvent("input", { bubbles: true, cancelable: true, composed: true })
|
|
264
286
|
);
|
|
265
|
-
this.
|
|
287
|
+
this._rangeInput.dispatchEvent(new Event("change", { bubbles: true }));
|
|
266
288
|
}
|
|
267
289
|
/** Emits the change event. */
|
|
268
290
|
_emitChange(event) {
|
|
@@ -282,16 +304,14 @@ let SbbSliderElement = class extends SbbDisabledMixin(LitElement) {
|
|
|
282
304
|
>
|
|
283
305
|
<input
|
|
284
306
|
tabindex="-1"
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
?disabled=${this.disabled || this.readonly || nothing}
|
|
289
|
-
.valueAsNumber=${this.valueAsNumber || nothing}
|
|
307
|
+
min=${this.min}
|
|
308
|
+
max=${this.max}
|
|
309
|
+
?disabled=${this.disabled || this.formDisabled || this.readonly}
|
|
290
310
|
value=${this.value || nothing}
|
|
291
311
|
class="sbb-slider__range-input"
|
|
292
312
|
type="range"
|
|
293
313
|
@change=${(event) => this._emitChange(event)}
|
|
294
|
-
@input=${() => this.
|
|
314
|
+
@input=${() => this.value = this._rangeInput.value}
|
|
295
315
|
${ref((input) => this._rangeInput = input)}
|
|
296
316
|
/>
|
|
297
317
|
<div class="sbb-slider__line">
|
|
@@ -313,22 +333,16 @@ SbbSliderElement.events = {
|
|
|
313
333
|
};
|
|
314
334
|
__decorateClass([
|
|
315
335
|
property()
|
|
316
|
-
], SbbSliderElement.prototype, "value",
|
|
336
|
+
], SbbSliderElement.prototype, "value", 1);
|
|
317
337
|
__decorateClass([
|
|
318
338
|
property({ attribute: "value-as-number", type: Number })
|
|
319
|
-
], SbbSliderElement.prototype, "valueAsNumber",
|
|
320
|
-
__decorateClass([
|
|
321
|
-
property({ reflect: true })
|
|
322
|
-
], SbbSliderElement.prototype, "name", 2);
|
|
323
|
-
__decorateClass([
|
|
324
|
-
property()
|
|
325
|
-
], SbbSliderElement.prototype, "form", 2);
|
|
339
|
+
], SbbSliderElement.prototype, "valueAsNumber", 1);
|
|
326
340
|
__decorateClass([
|
|
327
341
|
property()
|
|
328
|
-
], SbbSliderElement.prototype, "min",
|
|
342
|
+
], SbbSliderElement.prototype, "min", 1);
|
|
329
343
|
__decorateClass([
|
|
330
344
|
property()
|
|
331
|
-
], SbbSliderElement.prototype, "max",
|
|
345
|
+
], SbbSliderElement.prototype, "max", 1);
|
|
332
346
|
__decorateClass([
|
|
333
347
|
property({ type: Boolean })
|
|
334
348
|
], SbbSliderElement.prototype, "readonly", 2);
|
|
@@ -344,10 +358,10 @@ __decorateClass([
|
|
|
344
358
|
SbbSliderElement = __decorateClass([
|
|
345
359
|
customElement("sbb-slider"),
|
|
346
360
|
hostAttributes({
|
|
347
|
-
|
|
361
|
+
tabindex: "0"
|
|
348
362
|
})
|
|
349
363
|
], SbbSliderElement);
|
|
350
364
|
export {
|
|
351
365
|
SbbSliderElement
|
|
352
366
|
};
|
|
353
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"slider.js","sources":["../../../src/elements/slider/slider.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { SbbConnectedAbortController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { setOrRemoveAttribute } from '../core/dom.js';\nimport { EventEmitter, forwardEventToHost } from '../core/eventing.js';\nimport { SbbDisabledMixin } from '../core/mixins.js';\n\nimport style from './slider.scss?lit&inline';\n\nimport '../icon.js';\n\n/**\n * It displays an input knob that can be moved in a range.\n *\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n */\n@customElement('sbb-slider')\n@hostAttributes({\n  role: 'slider',\n})\nexport class SbbSliderElement extends SbbDisabledMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n  } as const;\n\n  /** Value for the inner HTMLInputElement. */\n  @property() public value?: string = '';\n\n  /** Numeric value for the inner HTMLInputElement. */\n  @property({ attribute: 'value-as-number', type: Number }) public valueAsNumber?: number;\n\n  /** Name of the inner HTMLInputElement. */\n  @property({ reflect: true }) public name?: string = '';\n\n  /** The <form> element to associate the inner HTMLInputElement with. */\n  @property() public form?: string;\n\n  /** Minimum acceptable value for the inner HTMLInputElement. */\n  @property() public min?: string = '0';\n\n  /** Maximum acceptable value for the inner HTMLInputElement. */\n  @property() public max?: string = '100';\n\n  /**\n   * Readonly state for the inner HTMLInputElement.\n   * Since the input range does not allow this attribute, it will be merged with the `disabled` one.\n   */\n  @property({ type: Boolean }) public readonly?: boolean = false;\n\n  /** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */\n  @property({ attribute: 'start-icon' }) public startIcon?: string;\n\n  /** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */\n  @property({ attribute: 'end-icon' }) public endIcon?: string;\n\n  /**\n   * The ratio between the absolute value and the validity interval.\n   * E.g. given `min=0`, `max=100` and `value=50`, then `_valueFraction=0.5`\n   */\n  @state() private _valueFraction = 0;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbSliderElement.events.didChange, {\n    bubbles: true,\n    cancelable: true,\n  });\n\n  /** Reference to the inner HTMLInputElement with type='range'. */\n  private _rangeInput!: HTMLInputElement;\n\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeydown(e), { signal });\n    this._handleChange();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value')) {\n      this._handleChange(Number(this.value));\n    } else if (changedProperties.has('valueAsNumber')) {\n      this._handleChange(Number(this.valueAsNumber));\n    }\n\n    if (changedProperties.has('min')) {\n      setOrRemoveAttribute(this, 'aria-valuemin', this.min ?? null);\n    }\n    if (changedProperties.has('max')) {\n      setOrRemoveAttribute(this, 'aria-valuemax', this.max ?? null);\n    }\n    if (changedProperties.has('readonly')) {\n      setOrRemoveAttribute(this, 'aria-readonly', this.readonly ? 'true' : null);\n    }\n\n    if (changedProperties.has('disabled')) {\n      if (this.disabled) {\n        this.setAttribute('aria-disabled', 'true');\n        this.removeAttribute('tabindex');\n      } else {\n        this.removeAttribute('aria-disabled');\n        this.setAttribute('tabindex', '0');\n      }\n    }\n  }\n\n  private _syncValues(newValue: string | number): void {\n    if (newValue == null) {\n      return;\n    } else if (newValue && typeof newValue !== 'number') {\n      newValue = +newValue;\n    }\n\n    this.value = newValue.toString();\n    this.valueAsNumber = newValue as number;\n    setOrRemoveAttribute(this, 'aria-valuenow', this.value || null);\n  }\n\n  /**\n   * Recalculates the `_valueFraction` on change to correctly display the slider knob and lines.\n   * The first calculation happens in connectedCallback(...), so since `_rangeInput` is not yet available,\n   * the `min` and `max` values are used; if `value` is not provided, the default value is halfway between min and max\n   * (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value).\n   */\n  private _handleChange(value: number = this._rangeInput?.valueAsNumber): void {\n    let min: number, max: number;\n    if (this._rangeInput) {\n      min = +this._rangeInput.min;\n      max = +this._rangeInput.max;\n    } else {\n      min = +(this.min as string);\n      max = +(this.max as string);\n      value =\n        this.value && this.value !== ''\n          ? +this.value\n          : this.valueAsNumber\n            ? this.valueAsNumber\n            : +(this.min as string) + (+(this.max as string) - +(this.min as string)) / 2;\n    }\n    const mathFraction: number = (value - min) / (max - min);\n    this._valueFraction =\n      isNaN(mathFraction) || mathFraction < 0 ? 0 : mathFraction > 1 ? 1 : mathFraction;\n    this._syncValues(value);\n  }\n\n  private async _handleKeydown(event: KeyboardEvent): Promise<void> {\n    if (event.key !== 'Tab') {\n      event.preventDefault();\n    }\n\n    if (this.disabled || this.readonly) {\n      return;\n    }\n\n    if (event.key === 'Home') {\n      this._rangeInput.value = this._rangeInput.min;\n    } else if (event.key === 'End') {\n      this._rangeInput.value = this._rangeInput.max;\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowDown') {\n      this._rangeInput.stepDown();\n    } else if (event.key === 'ArrowRight' || event.key === 'ArrowUp') {\n      this._rangeInput.stepUp();\n    } else if (event.key === 'PageDown') {\n      this._rangeInput.stepDown((+this._rangeInput.max - +this._rangeInput.min) / 10);\n    } else if (event.key === 'PageUp') {\n      this._rangeInput.stepUp((+this._rangeInput.max - +this._rangeInput.min) / 10);\n    } else {\n      return;\n    }\n\n    this._handleChange();\n    this.dispatchEvent(\n      new InputEvent('input', { bubbles: true, cancelable: true, composed: true }),\n    );\n    this._emitChange(new Event('change', { bubbles: true, cancelable: true, composed: true }));\n  }\n\n  /** Emits the change event. */\n  private _emitChange(event: Event): void {\n    forwardEventToHost(event, this);\n    this._didChange.emit();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-slider__height-container\">\n        <div class=\"sbb-slider__wrapper\">\n          <slot name=\"prefix\">\n            ${this.startIcon ? html`<sbb-icon name=\"${this.startIcon}\"></sbb-icon>` : nothing}\n          </slot>\n          <div\n            class=\"sbb-slider__container\"\n            style=${styleMap({ '--sbb-slider-value-fraction': this._valueFraction.toString() })}\n          >\n            <input\n              tabindex=\"-1\"\n              name=${this.name || nothing}\n              min=${this.min || nothing}\n              max=${this.max || nothing}\n              ?disabled=${this.disabled || this.readonly || nothing}\n              .valueAsNumber=${this.valueAsNumber || nothing}\n              value=${this.value || nothing}\n              class=\"sbb-slider__range-input\"\n              type=\"range\"\n              @change=${(event: Event) => this._emitChange(event)}\n              @input=${() => this._handleChange()}\n              ${ref((input?: Element) => (this._rangeInput = input as HTMLInputElement))}\n            />\n            <div class=\"sbb-slider__line\">\n              <div class=\"sbb-slider__selected-line\"></div>\n            </div>\n            <div class=\"sbb-slider__knob\"></div>\n          </div>\n          <slot name=\"suffix\">\n            ${this.endIcon ? html`<sbb-icon name=\"${this.endIcon}\"></sbb-icon>` : nothing}\n          </slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-slider': SbbSliderElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BO,IAAM,mBAAN,cAA+B,iBAAiB,UAAU,EAAE;AAAA,EAA5D,cAAA;AAAA,UAAA,GAAA,SAAA;AAOO,SAAO,QAAiB;AAMP,SAAO,OAAgB;AAMxC,SAAO,MAAe;AAGtB,SAAO,MAAe;AAML,SAAO,WAAqB;AAYhD,SAAQ,iBAAiB;AAKlC,SAAQ,aAA2B,IAAI,aAAa,MAAM,iBAAiB,OAAO,WAAW;AAAA,MAC3F,SAAS;AAAA,MACT,YAAY;AAAA,IAAA,CACb;AAKO,SAAA,SAAS,IAAI,4BAA4B,IAAI;AAAA,EAAA;AAAA,EAErC,oBAA0B;AACxC,UAAM,kBAAkB;AAClB,UAAA,SAAS,KAAK,OAAO;AACtB,SAAA,iBAAiB,WAAW,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,EAAE,OAAA,CAAQ;AAC1E,SAAK,cAAc;AAAA,EACrB;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,OAAO,GAAG;AAClC,WAAK,cAAc,OAAO,KAAK,KAAK,CAAC;AAAA,IAC5B,WAAA,kBAAkB,IAAI,eAAe,GAAG;AACjD,WAAK,cAAc,OAAO,KAAK,aAAa,CAAC;AAAA,IAC/C;AAEI,QAAA,kBAAkB,IAAI,KAAK,GAAG;AAChC,2BAAqB,MAAM,iBAAiB,KAAK,OAAO,IAAI;AAAA,IAC9D;AACI,QAAA,kBAAkB,IAAI,KAAK,GAAG;AAChC,2BAAqB,MAAM,iBAAiB,KAAK,OAAO,IAAI;AAAA,IAC9D;AACI,QAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,2BAAqB,MAAM,iBAAiB,KAAK,WAAW,SAAS,IAAI;AAAA,IAC3E;AAEI,QAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,UAAI,KAAK,UAAU;AACZ,aAAA,aAAa,iBAAiB,MAAM;AACzC,aAAK,gBAAgB,UAAU;AAAA,MAAA,OAC1B;AACL,aAAK,gBAAgB,eAAe;AAC/B,aAAA,aAAa,YAAY,GAAG;AAAA,MACnC;AAAA,IACF;AAAA,EACF;AAAA,EAEQ,YAAY,UAAiC;AACnD,QAAI,YAAY,MAAM;AACpB;AAAA,IACS,WAAA,YAAY,OAAO,aAAa,UAAU;AACnD,iBAAW,CAAC;AAAA,IACd;AAEK,SAAA,QAAQ,SAAS;AACtB,SAAK,gBAAgB;AACrB,yBAAqB,MAAM,iBAAiB,KAAK,SAAS,IAAI;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQQ,cAAc,SAAgB,mBAAK,gBAAL,mBAAkB,kBAAqB;AAC3E,QAAI,KAAa;AACjB,QAAI,KAAK,aAAa;AACd,YAAA,CAAC,KAAK,YAAY;AAClB,YAAA,CAAC,KAAK,YAAY;AAAA,IAAA,OACnB;AACL,YAAM,CAAE,KAAK;AACb,YAAM,CAAE,KAAK;AAEX,cAAA,KAAK,SAAS,KAAK,UAAU,KACzB,CAAC,KAAK,QACN,KAAK,gBACH,KAAK,gBACL,CAAE,KAAK,OAAkB,CAAE,KAAK,MAAiB,CAAE,KAAK,OAAkB;AAAA,IACpF;AACM,UAAA,gBAAwB,QAAQ,QAAQ,MAAM;AAC/C,SAAA,iBACH,MAAM,YAAY,KAAK,eAAe,IAAI,IAAI,eAAe,IAAI,IAAI;AACvE,SAAK,YAAY,KAAK;AAAA,EACxB;AAAA,EAEA,MAAc,eAAe,OAAqC;AAC5D,QAAA,MAAM,QAAQ,OAAO;AACvB,YAAM,eAAe;AAAA,IACvB;AAEI,QAAA,KAAK,YAAY,KAAK,UAAU;AAClC;AAAA,IACF;AAEI,QAAA,MAAM,QAAQ,QAAQ;AACnB,WAAA,YAAY,QAAQ,KAAK,YAAY;AAAA,IAAA,WACjC,MAAM,QAAQ,OAAO;AACzB,WAAA,YAAY,QAAQ,KAAK,YAAY;AAAA,IAAA,WACjC,MAAM,QAAQ,eAAe,MAAM,QAAQ,aAAa;AACjE,WAAK,YAAY;IAAS,WACjB,MAAM,QAAQ,gBAAgB,MAAM,QAAQ,WAAW;AAChE,WAAK,YAAY;IAAO,WACf,MAAM,QAAQ,YAAY;AAC9B,WAAA,YAAY,UAAU,CAAC,KAAK,YAAY,MAAM,CAAC,KAAK,YAAY,OAAO,EAAE;AAAA,IAAA,WACrE,MAAM,QAAQ,UAAU;AAC5B,WAAA,YAAY,QAAQ,CAAC,KAAK,YAAY,MAAM,CAAC,KAAK,YAAY,OAAO,EAAE;AAAA,IAAA,OACvE;AACL;AAAA,IACF;AAEA,SAAK,cAAc;AACd,SAAA;AAAA,MACH,IAAI,WAAW,SAAS,EAAE,SAAS,MAAM,YAAY,MAAM,UAAU,MAAM;AAAA,IAAA;AAE7E,SAAK,YAAY,IAAI,MAAM,UAAU,EAAE,SAAS,MAAM,YAAY,MAAM,UAAU,KAAK,CAAC,CAAC;AAAA,EAC3F;AAAA;AAAA,EAGQ,YAAY,OAAoB;AACtC,uBAAmB,OAAO,IAAI;AAC9B,SAAK,WAAW;EAClB;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA,cAIG,KAAK,YAAY,uBAAuB,KAAK,SAAS,kBAAkB,OAAO;AAAA;AAAA;AAAA;AAAA,oBAIzE,SAAS,EAAE,+BAA+B,KAAK,eAAe,SAAS,EAAA,CAAG,CAAC;AAAA;AAAA;AAAA;AAAA,qBAI1E,KAAK,QAAQ,OAAO;AAAA,oBACrB,KAAK,OAAO,OAAO;AAAA,oBACnB,KAAK,OAAO,OAAO;AAAA,0BACb,KAAK,YAAY,KAAK,YAAY,OAAO;AAAA,+BACpC,KAAK,iBAAiB,OAAO;AAAA,sBACtC,KAAK,SAAS,OAAO;AAAA;AAAA;AAAA,wBAGnB,CAAC,UAAiB,KAAK,YAAY,KAAK,CAAC;AAAA,uBAC1C,MAAM,KAAK,eAAe;AAAA,gBACjC,IAAI,CAAC,UAAqB,KAAK,cAAc,KAA0B,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cAQ1E,KAAK,UAAU,uBAAuB,KAAK,OAAO,kBAAkB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA,EAKvF;AACF;AA9Ma,iBACY,SAAyB;AADrC,iBAEY,SAAS;AAAA,EAC9B,WAAW;AACb;AAGmB,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAPC,iBAOQ,WAAA,SAAA,CAAA;AAG8C,gBAAA;AAAA,EAAhE,SAAS,EAAE,WAAW,mBAAmB,MAAM,QAAQ;AAAA,GAV7C,iBAUsD,WAAA,iBAAA,CAAA;AAG7B,gBAAA;AAAA,EAAnC,SAAS,EAAE,SAAS,MAAM;AAAA,GAbhB,iBAayB,WAAA,QAAA,CAAA;AAGjB,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAhBC,iBAgBQ,WAAA,QAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAnBC,iBAmBQ,WAAA,OAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAtBC,iBAsBQ,WAAA,OAAA,CAAA;AAMiB,gBAAA;AAAA,EAAnC,SAAS,EAAE,MAAM,SAAS;AAAA,GA5BhB,iBA4ByB,WAAA,YAAA,CAAA;AAGU,gBAAA;AAAA,EAA7C,SAAS,EAAE,WAAW,cAAc;AAAA,GA/B1B,iBA+BmC,WAAA,aAAA,CAAA;AAGF,gBAAA;AAAA,EAA3C,SAAS,EAAE,WAAW,YAAY;AAAA,GAlCxB,iBAkCiC,WAAA,WAAA,CAAA;AAM3B,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAxCI,iBAwCM,WAAA,kBAAA,CAAA;AAxCN,mBAAN,gBAAA;AAAA,EAJN,cAAc,YAAY;AAAA,EAC1B,eAAe;AAAA,IACd,MAAM;AAAA,EAAA,CACP;AAAA,GACY,gBAAA;"}
|
|
367
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"slider.js","sources":["../../../src/elements/slider/slider.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport { SbbConnectedAbortController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { EventEmitter, forwardEventToHost } from '../core/eventing.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n} from '../core/mixins.js';\n\nimport style from './slider.scss?lit&inline';\n\nimport '../icon.js';\n\n/**\n * It displays an input knob that can be moved in a range.\n *\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @event {CustomEvent<void>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\n */\n@customElement('sbb-slider')\n@hostAttributes({\n  tabindex: '0',\n})\nexport class SbbSliderElement extends SbbDisabledMixin(SbbFormAssociatedMixin(LitElement)) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n  } as const;\n\n  /**\n   * Value of the form element.\n   * If no value is provided, default is the middle point between min and max.\n   */\n  @property()\n  public override set value(value: string | null) {\n    if (this._isValidNumber(value)) {\n      super.value = this._boundBetweenMinMax(value!);\n    } else {\n      super.value = this._getDefaultValue();\n    }\n    this.internals.ariaValueNow = this.value;\n    this._calculateValueFraction();\n  }\n  public override get value(): string {\n    return super.value!;\n  }\n\n  /** Numeric value for the inner HTMLInputElement. */\n  @property({ attribute: 'value-as-number', type: Number })\n  public set valueAsNumber(value: number) {\n    this.value = value?.toString();\n  }\n  public get valueAsNumber(): number | null {\n    return Number(this.value);\n  }\n\n  /** Minimum acceptable value for the inner HTMLInputElement. */\n  @property()\n  public set min(value: string) {\n    if (!this._isValidNumber(value!)) {\n      return;\n    }\n\n    this._min = value;\n    this.value = this._boundBetweenMinMax(this.value);\n  }\n  public get min(): string {\n    return this._min;\n  }\n  private _min: string = '0';\n\n  /** Maximum acceptable value for the inner HTMLInputElement. */\n  @property()\n  public set max(value: string) {\n    if (!this._isValidNumber(value!)) {\n      return;\n    }\n\n    this._max = value;\n    this.value = this._boundBetweenMinMax(this.value);\n  }\n  public get max(): string {\n    return this._max;\n  }\n  private _max: string = '100';\n\n  /**\n   * Readonly state for the inner HTMLInputElement.\n   * Since the input range does not allow this attribute, it will be merged with the `disabled` one.\n   */\n  @property({ type: Boolean }) public readonly?: boolean = false;\n\n  /** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */\n  @property({ attribute: 'start-icon' }) public startIcon?: string;\n\n  /** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */\n  @property({ attribute: 'end-icon' }) public endIcon?: string;\n\n  /**\n   * The ratio between the absolute value and the validity interval.\n   * E.g. given `min=0`, `max=100` and `value=50`, then `_valueFraction=0.5`\n   */\n  @state() private _valueFraction = 0;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbSliderElement.events.didChange, {\n    bubbles: true,\n    cancelable: true,\n  });\n\n  /** Reference to the inner HTMLInputElement with type='range'. */\n  private _rangeInput!: HTMLInputElement;\n\n  private _abort = new SbbConnectedAbortController(this);\n\n  public constructor() {\n    super();\n    /** @internal */\n    this.internals.role = 'slider';\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeydown(e), { signal });\n\n    if (!this.value) {\n      this.value = this._getDefaultValue();\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('min')) {\n      this.internals.ariaValueMin = this.min;\n    }\n    if (changedProperties.has('max')) {\n      this.internals.ariaValueMax = this.max;\n    }\n    if (changedProperties.has('readonly')) {\n      this.internals.ariaReadOnly = Boolean(this.readonly).toString();\n    }\n  }\n\n  /**\n   * The reset value is the attribute value (the setup value). If not present, calculates the default.\n   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = this.getAttribute('value') ?? this._getDefaultValue();\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    this.value = state as string | null;\n  }\n\n  /**\n   *  If no value is provided, default is the middle point between min and max\n   *  (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value)\n   */\n  private _getDefaultValue(): string {\n    return (+this.min + (+this.max - +this.min) / 2).toString();\n  }\n\n  private _isValidNumber(value: string | null): boolean {\n    return !!value && !isNaN(Number(value));\n  }\n\n  /**\n   * Restrains the value between the min and max\n   */\n  private _boundBetweenMinMax(value: string): string {\n    return Math.max(+this.min, Math.min(+this.max, +value)).toString();\n  }\n\n  private _calculateValueFraction(): void {\n    const value = this.valueAsNumber!;\n    const min = +this.min;\n    const max = +this.max;\n\n    const mathFraction: number = (value - min) / (max - min);\n    this._valueFraction = isNaN(mathFraction) ? 0 : Math.max(0, Math.min(1, mathFraction));\n  }\n\n  private async _handleKeydown(event: KeyboardEvent): Promise<void> {\n    if (event.key !== 'Tab') {\n      event.preventDefault();\n    }\n\n    if (this.readonly) {\n      return;\n    }\n\n    if (event.key === 'Home') {\n      this._rangeInput.value = this.min;\n    } else if (event.key === 'End') {\n      this._rangeInput.value = this.max;\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowDown') {\n      this._rangeInput.stepDown();\n    } else if (event.key === 'ArrowRight' || event.key === 'ArrowUp') {\n      this._rangeInput.stepUp();\n    } else if (event.key === 'PageDown') {\n      this._rangeInput.stepDown((+this.max - +this.min) / 10);\n    } else if (event.key === 'PageUp') {\n      this._rangeInput.stepUp((+this.max - +this.min) / 10);\n    } else {\n      return;\n    }\n\n    // We have to manually fire events because programmatic changes don't trigger them\n    this._rangeInput.dispatchEvent(\n      new InputEvent('input', { bubbles: true, cancelable: true, composed: true }),\n    );\n    this._rangeInput.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  /** Emits the change event. */\n  private _emitChange(event: Event): void {\n    forwardEventToHost(event, this);\n    this._didChange.emit();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-slider__height-container\">\n        <div class=\"sbb-slider__wrapper\">\n          <slot name=\"prefix\">\n            ${this.startIcon ? html`<sbb-icon name=\"${this.startIcon}\"></sbb-icon>` : nothing}\n          </slot>\n          <div\n            class=\"sbb-slider__container\"\n            style=${styleMap({ '--sbb-slider-value-fraction': this._valueFraction.toString() })}\n          >\n            <input\n              tabindex=\"-1\"\n              min=${this.min}\n              max=${this.max}\n              ?disabled=${this.disabled || this.formDisabled || this.readonly}\n              value=${this.value || nothing}\n              class=\"sbb-slider__range-input\"\n              type=\"range\"\n              @change=${(event: Event) => this._emitChange(event)}\n              @input=${() => (this.value = this._rangeInput.value)}\n              ${ref((input?: Element) => (this._rangeInput = input as HTMLInputElement))}\n            />\n            <div class=\"sbb-slider__line\">\n              <div class=\"sbb-slider__selected-line\"></div>\n            </div>\n            <div class=\"sbb-slider__knob\"></div>\n          </div>\n          <slot name=\"suffix\">\n            ${this.endIcon ? html`<sbb-icon name=\"${this.endIcon}\"></sbb-icon>` : nothing}\n          </slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-slider': SbbSliderElement;\n  }\n}\n"],"names":["state"],"mappings":"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"}
|
package/development/status.js
CHANGED
|
@@ -3,14 +3,7 @@ import { property, customElement } from "lit/decorators.js";
|
|
|
3
3
|
import { slotState } from "./core/decorators.js";
|
|
4
4
|
import { SbbIconNameMixin } from "./icon.js";
|
|
5
5
|
import "./title.js";
|
|
6
|
-
const style = css
|
|
7
|
-
/*
|
|
8
|
-
* SBB table mixin
|
|
9
|
-
* Notes:
|
|
10
|
-
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
11
|
-
* Therefore, we have to build the grid avoiding double borders.
|
|
12
|
-
*/
|
|
13
|
-
*,
|
|
6
|
+
const style = css`*,
|
|
14
7
|
::before,
|
|
15
8
|
::after {
|
|
16
9
|
box-sizing: border-box;
|
|
@@ -182,4 +175,4 @@ SbbStatusElement = __decorateClass([
|
|
|
182
175
|
export {
|
|
183
176
|
SbbStatusElement
|
|
184
177
|
};
|
|
185
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvc3RhdHVzL3N0YXR1cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBzbG90U3RhdGUgfSBmcm9tICcuLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uL2ljb24uanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJUaXRsZUxldmVsIH0gZnJvbSAnLi4vdGl0bGUuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGF0dXMuc2Nzcz9saXQmaW5saW5lJztcblxuaW1wb3J0ICcuLi90aXRsZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNiYlN0YXR1c1R5cGUgPVxuICB8ICdpbmZvJ1xuICB8ICdzdWNjZXNzJ1xuICB8ICd3YXJuaW5nJ1xuICB8ICdlcnJvcidcbiAgfCAncGVuZGluZydcbiAgfCAnaW5jb21wbGV0ZSdcbiAgfCAnbm90LXN0YXJ0ZWQnXG4gIHwgJ2luLXByb2dyZXNzJztcblxuLyoqXG4gKiBEaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIncyBhdHRlbnRpb24uXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgc3RhdHVzIG1lc3NhZ2UuXG4gKiBAc2xvdCB0aXRsZSAtIFVzZSB0aGlzIHRvIHByb3ZpZGUgYSB0aXRsZSBmb3IgdGhlIHN0YXR1cyAob3B0aW9uYWwpLlxuICogQHNsb3QgaWNvbiAtIFVzZSB0aGlzIHNsb3QgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgc3RhdHVzIGljb24uXG4gKi9cbkBjdXN0b21FbGVtZW50KCdzYmItc3RhdHVzJylcbkBzbG90U3RhdGUoKVxuZXhwb3J0IGNsYXNzIFNiYlN0YXR1c0VsZW1lbnQgZXh0ZW5kcyBTYmJJY29uTmFtZU1peGluKExpdEVsZW1lbnQpIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfc3RhdHVzVHlwZXM6IE1hcDxTYmJTdGF0dXNUeXBlLCBzdHJpbmc+ID0gbmV3IE1hcChbXG4gICAgWydpbmZvJywgJ2NpcmNsZS1pbmZvcm1hdGlvbi1zbWFsbCddLFxuICAgIFsnc3VjY2VzcycsICdjaXJjbGUtdGljay1zbWFsbCddLFxuICAgIFsnd2FybmluZycsICdjaXJjbGUtZXhjbGFtYXRpb24tcG9pbnQtc21hbGwnXSxcbiAgICBbJ2Vycm9yJywgJ2NpcmNsZS1jcm9zcy1zbWFsbCddLFxuICAgIFsncGVuZGluZycsICdjaXJjbGUtdGhyZWUtZG90cy1zbWFsbCddLFxuICAgIFsnaW5jb21wbGV0ZScsICdjaXJjbGUtZG90dGVkLXBhcnQteC1zbWFsbCddLFxuICAgIFsnbm90LXN0YXJ0ZWQnLCAnY2lyY2xlLWRvdHRlZC1zbWFsbCddLFxuICAgIFsnaW4tcHJvZ3Jlc3MnLCAnY2lyY2xlLWRvdHRlZC1wYXJ0LXNtYWxsJ10sXG4gIF0pO1xuXG4gIC8qKiBUaGUgdHlwZSBvZiB0aGUgc3RhdHVzLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pIHB1YmxpYyB0eXBlOiBTYmJTdGF0dXNUeXBlID0gJ2luZm8nO1xuXG4gIC8qKiBDb250ZW50IG9mIHRpdGxlLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlLCBhdHRyaWJ1dGU6ICd0aXRsZS1jb250ZW50JyB9KSBwdWJsaWMgdGl0bGVDb250ZW50Pzogc3RyaW5nO1xuXG4gIC8qKiBMZXZlbCBvZiB0aXRsZSwgaXQgd2lsbCBiZSByZW5kZXJlZCBhcyBoZWFkaW5nIHRhZyAoZS5nLiBoMykuIERlZmF1bHRzIHRvIGxldmVsIDMuICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ3RpdGxlLWxldmVsJyB9KSBwdWJsaWMgdGl0bGVMZXZlbDogU2JiVGl0bGVMZXZlbCA9ICczJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVySWNvblNsb3QoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPHNsb3QgbmFtZT1cImljb25cIj5cbiAgICAgICAgPHNiYi1pY29uIG5hbWU9JHt0aGlzLmljb25OYW1lID8/IHRoaXMuX3N0YXR1c1R5cGVzLmdldCh0aGlzLnR5cGUpIX0+PC9zYmItaWNvbj5cbiAgICAgIDwvc2xvdD5cbiAgICBgO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXN0YXR1c1wiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGF0dXNfX2ljb25cIj4gJHt0aGlzLnJlbmRlckljb25TbG90KCl9IDwvc3Bhbj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItc3RhdHVzX19jb250ZW50XCI+XG4gICAgICAgICAgPHNiYi10aXRsZSBjbGFzcz1cInNiYi1zdGF0dXNfX3RpdGxlXCIgbGV2ZWw9JHt0aGlzLnRpdGxlTGV2ZWx9IHZpc3VhbC1sZXZlbD1cIjVcIj5cbiAgICAgICAgICAgIDxzbG90IG5hbWU9XCJ0aXRsZVwiPiR7dGhpcy50aXRsZUNvbnRlbnR9PC9zbG90PlxuICAgICAgICAgIDwvc2JiLXRpdGxlPlxuICAgICAgICAgIDxwIGNsYXNzPVwic2JiLXN0YXR1c19fY29udGVudC1zbG90XCI+XG4gICAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgICAgPC9wPlxuICAgICAgICA8L3NwYW4+
|
|
178
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvc3RhdHVzL3N0YXR1cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBzbG90U3RhdGUgfSBmcm9tICcuLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uL2ljb24uanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJUaXRsZUxldmVsIH0gZnJvbSAnLi4vdGl0bGUuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGF0dXMuc2Nzcz9saXQmaW5saW5lJztcblxuaW1wb3J0ICcuLi90aXRsZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNiYlN0YXR1c1R5cGUgPVxuICB8ICdpbmZvJ1xuICB8ICdzdWNjZXNzJ1xuICB8ICd3YXJuaW5nJ1xuICB8ICdlcnJvcidcbiAgfCAncGVuZGluZydcbiAgfCAnaW5jb21wbGV0ZSdcbiAgfCAnbm90LXN0YXJ0ZWQnXG4gIHwgJ2luLXByb2dyZXNzJztcblxuLyoqXG4gKiBEaXNwbGF5cyBhIG1lc3NhZ2UgdG8gdGhlIHVzZXIncyBhdHRlbnRpb24uXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgc3RhdHVzIG1lc3NhZ2UuXG4gKiBAc2xvdCB0aXRsZSAtIFVzZSB0aGlzIHRvIHByb3ZpZGUgYSB0aXRsZSBmb3IgdGhlIHN0YXR1cyAob3B0aW9uYWwpLlxuICogQHNsb3QgaWNvbiAtIFVzZSB0aGlzIHNsb3QgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgc3RhdHVzIGljb24uXG4gKi9cbkBjdXN0b21FbGVtZW50KCdzYmItc3RhdHVzJylcbkBzbG90U3RhdGUoKVxuZXhwb3J0IGNsYXNzIFNiYlN0YXR1c0VsZW1lbnQgZXh0ZW5kcyBTYmJJY29uTmFtZU1peGluKExpdEVsZW1lbnQpIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBfc3RhdHVzVHlwZXM6IE1hcDxTYmJTdGF0dXNUeXBlLCBzdHJpbmc+ID0gbmV3IE1hcChbXG4gICAgWydpbmZvJywgJ2NpcmNsZS1pbmZvcm1hdGlvbi1zbWFsbCddLFxuICAgIFsnc3VjY2VzcycsICdjaXJjbGUtdGljay1zbWFsbCddLFxuICAgIFsnd2FybmluZycsICdjaXJjbGUtZXhjbGFtYXRpb24tcG9pbnQtc21hbGwnXSxcbiAgICBbJ2Vycm9yJywgJ2NpcmNsZS1jcm9zcy1zbWFsbCddLFxuICAgIFsncGVuZGluZycsICdjaXJjbGUtdGhyZWUtZG90cy1zbWFsbCddLFxuICAgIFsnaW5jb21wbGV0ZScsICdjaXJjbGUtZG90dGVkLXBhcnQteC1zbWFsbCddLFxuICAgIFsnbm90LXN0YXJ0ZWQnLCAnY2lyY2xlLWRvdHRlZC1zbWFsbCddLFxuICAgIFsnaW4tcHJvZ3Jlc3MnLCAnY2lyY2xlLWRvdHRlZC1wYXJ0LXNtYWxsJ10sXG4gIF0pO1xuXG4gIC8qKiBUaGUgdHlwZSBvZiB0aGUgc3RhdHVzLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pIHB1YmxpYyB0eXBlOiBTYmJTdGF0dXNUeXBlID0gJ2luZm8nO1xuXG4gIC8qKiBDb250ZW50IG9mIHRpdGxlLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlLCBhdHRyaWJ1dGU6ICd0aXRsZS1jb250ZW50JyB9KSBwdWJsaWMgdGl0bGVDb250ZW50Pzogc3RyaW5nO1xuXG4gIC8qKiBMZXZlbCBvZiB0aXRsZSwgaXQgd2lsbCBiZSByZW5kZXJlZCBhcyBoZWFkaW5nIHRhZyAoZS5nLiBoMykuIERlZmF1bHRzIHRvIGxldmVsIDMuICovXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ3RpdGxlLWxldmVsJyB9KSBwdWJsaWMgdGl0bGVMZXZlbDogU2JiVGl0bGVMZXZlbCA9ICczJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVySWNvblNsb3QoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPHNsb3QgbmFtZT1cImljb25cIj5cbiAgICAgICAgPHNiYi1pY29uIG5hbWU9JHt0aGlzLmljb25OYW1lID8/IHRoaXMuX3N0YXR1c1R5cGVzLmdldCh0aGlzLnR5cGUpIX0+PC9zYmItaWNvbj5cbiAgICAgIDwvc2xvdD5cbiAgICBgO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXN0YXR1c1wiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGF0dXNfX2ljb25cIj4gJHt0aGlzLnJlbmRlckljb25TbG90KCl9IDwvc3Bhbj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItc3RhdHVzX19jb250ZW50XCI+XG4gICAgICAgICAgPHNiYi10aXRsZSBjbGFzcz1cInNiYi1zdGF0dXNfX3RpdGxlXCIgbGV2ZWw9JHt0aGlzLnRpdGxlTGV2ZWx9IHZpc3VhbC1sZXZlbD1cIjVcIj5cbiAgICAgICAgICAgIDxzbG90IG5hbWU9XCJ0aXRsZVwiPiR7dGhpcy50aXRsZUNvbnRlbnR9PC9zbG90PlxuICAgICAgICAgIDwvc2JiLXRpdGxlPlxuICAgICAgICAgIDxwIGNsYXNzPVwic2JiLXN0YXR1c19fY29udGVudC1zbG90XCI+XG4gICAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgICAgPC9wPlxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItc3RhdHVzJzogU2JiU3RhdHVzRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUErQk8sSUFBTSxtQkFBTixjQUErQixpQkFBaUIsVUFBVSxFQUFFO0FBQUEsRUFBNUQsY0FBQTtBQUFBLFVBQUEsR0FBQSxTQUFBO0FBR1ksU0FBQSxtQ0FBK0MsSUFBSTtBQUFBLE1BQ2xFLENBQUMsUUFBUSwwQkFBMEI7QUFBQSxNQUNuQyxDQUFDLFdBQVcsbUJBQW1CO0FBQUEsTUFDL0IsQ0FBQyxXQUFXLGdDQUFnQztBQUFBLE1BQzVDLENBQUMsU0FBUyxvQkFBb0I7QUFBQSxNQUM5QixDQUFDLFdBQVcseUJBQXlCO0FBQUEsTUFDckMsQ0FBQyxjQUFjLDRCQUE0QjtBQUFBLE1BQzNDLENBQUMsZUFBZSxxQkFBcUI7QUFBQSxNQUNyQyxDQUFDLGVBQWUsMEJBQTBCO0FBQUEsSUFBQSxDQUMzQztBQUc0QixTQUFPLE9BQXNCO0FBTWxCLFNBQU8sYUFBNEI7QUFBQSxFQUFBO0FBQUEsRUFFeEQsaUJBQWlDO0FBQzNDLFdBQUE7QUFBQTtBQUFBLHlCQUVjLEtBQUssWUFBWSxLQUFLLGFBQWEsSUFBSSxLQUFLLElBQUksQ0FBRTtBQUFBO0FBQUE7QUFBQSxFQUd6RTtBQUFBLEVBRW1CLFNBQXlCO0FBQ25DLFdBQUE7QUFBQTtBQUFBLDBDQUUrQixLQUFLLGdCQUFnQjtBQUFBO0FBQUEsdURBRVIsS0FBSyxVQUFVO0FBQUEsaUNBQ3JDLEtBQUssWUFBWTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFRaEQ7QUFDRjtBQTlDYSxpQkFDWSxTQUF5QjtBQWNaLGdCQUFBO0FBQUEsRUFBbkMsU0FBUyxFQUFFLFNBQVMsTUFBTTtBQUFBLEdBZmhCLGlCQWV5QixXQUFBLFFBQUEsQ0FBQTtBQUc0QixnQkFBQTtBQUFBLEVBQS9ELFNBQVMsRUFBRSxTQUFTLE1BQU0sV0FBVyxpQkFBaUI7QUFBQSxHQWxCNUMsaUJBa0JxRCxXQUFBLGdCQUFBLENBQUE7QUFHakIsZ0JBQUE7QUFBQSxFQUE5QyxTQUFTLEVBQUUsV0FBVyxlQUFlO0FBQUEsR0FyQjNCLGlCQXFCb0MsV0FBQSxjQUFBLENBQUE7QUFyQnBDLG1CQUFOLGdCQUFBO0FBQUEsRUFGTixjQUFjLFlBQVk7QUFBQSxFQUMxQixVQUFVO0FBQUEsR0FDRSxnQkFBQTsifQ==
|
|
@@ -5,14 +5,7 @@ import { SbbConnectedAbortController } from "../core/controllers.js";
|
|
|
5
5
|
import { hostAttributes } from "../core/decorators.js";
|
|
6
6
|
import { SbbDisabledMixin } from "../core/mixins.js";
|
|
7
7
|
import { SbbIconNameMixin } from "../icon.js";
|
|
8
|
-
const style = css
|
|
9
|
-
/*
|
|
10
|
-
* SBB table mixin
|
|
11
|
-
* Notes:
|
|
12
|
-
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
13
|
-
* Therefore, we have to build the grid avoiding double borders.
|
|
14
|
-
*/
|
|
15
|
-
*,
|
|
8
|
+
const style = css`*,
|
|
16
9
|
::before,
|
|
17
10
|
::after {
|
|
18
11
|
box-sizing: border-box;
|
|
@@ -287,4 +280,4 @@ SbbStepLabelElement = __decorateClass([
|
|
|
287
280
|
export {
|
|
288
281
|
SbbStepLabelElement
|
|
289
282
|
};
|
|
290
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1sYWJlbC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3N0ZXBwZXIvc3RlcC1sYWJlbC9zdGVwLWxhYmVsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgQ1NTUmVzdWx0R3JvdXAsIGh0bWwsIHR5cGUgVGVtcGxhdGVSZXN1bHQsIHR5cGUgUHJvcGVydHlWYWx1ZXMgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgU2JiQnV0dG9uQmFzZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2Jhc2UtZWxlbWVudHMuanMnO1xuaW1wb3J0IHsgU2JiQ29ubmVjdGVkQWJvcnRDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBob3N0QXR0cmlidXRlcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyBTYmJEaXNhYmxlZE1peGluIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uLy4uL2ljb24uanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJTdGVwRWxlbWVudCB9IGZyb20gJy4uL3N0ZXAuanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJTdGVwcGVyRWxlbWVudCB9IGZyb20gJy4uL3N0ZXBwZXIuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGVwLWxhYmVsLnNjc3M/bGl0JmlubGluZSc7XG5cbmxldCBuZXh0SWQgPSAwO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLXN0ZXBwZXJgLCBpdCBkaXNwbGF5cyBhIHN0ZXAncyBsYWJlbC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIHByb3ZpZGUgYSBsYWJlbC5cbiAqIEBzbG90IGljb24gLSBVc2UgdGhpcyB0byBkaXNwbGF5IGFuIGljb24gaW4gdGhlIGxhYmVsIGJ1YmJsZS5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zdGVwLWxhYmVsJylcbkBob3N0QXR0cmlidXRlcyh7XG4gIHNsb3Q6ICdzdGVwLWxhYmVsJyxcbiAgdGFiaW5kZXg6ICctMScsXG4gIHJvbGU6ICd0YWInLFxufSlcbmV4cG9ydCBjbGFzcyBTYmJTdGVwTGFiZWxFbGVtZW50IGV4dGVuZHMgU2JiSWNvbk5hbWVNaXhpbihTYmJEaXNhYmxlZE1peGluKFNiYkJ1dHRvbkJhc2VFbGVtZW50KSkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogQGludGVybmFsICovXG4gIHByaXZhdGUgcmVhZG9ubHkgX2ludGVybmFsczogRWxlbWVudEludGVybmFscyA9IHRoaXMuYXR0YWNoSW50ZXJuYWxzKCk7XG5cbiAgLyoqIFRoZSBzdGVwIGNvbnRyb2xsZWQgYnkgdGhlIGxhYmVsLiAqL1xuICBwdWJsaWMgZ2V0IHN0ZXAoKTogU2JiU3RlcEVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5fc3RlcDtcbiAgfVxuXG4gIHByaXZhdGUgX2Fib3J0ID0gbmV3IFNiYkNvbm5lY3RlZEFib3J0Q29udHJvbGxlcih0aGlzKTtcbiAgcHJpdmF0ZSBfc3RlcHBlcjogU2JiU3RlcHBlckVsZW1lbnQgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBfc3RlcDogU2JiU3RlcEVsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICBwcml2YXRlIF9nZXRTdGVwKCk6IFNiYlN0ZXBFbGVtZW50IHwgbnVsbCB7XG4gICAgbGV0IG5leHRTaWJsaW5nID0gdGhpcy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgd2hpbGUgKG5leHRTaWJsaW5nICYmIG5leHRTaWJsaW5nLmxvY2FsTmFtZSAhPT0gJ3NiYi1zdGVwJykge1xuICAgICAgbmV4dFNpYmxpbmcgPSBuZXh0U2libGluZy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgfVxuICAgIHJldHVybiBuZXh0U2libGluZyBhcyBTYmJTdGVwRWxlbWVudDtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIGNvbnN0IHNpZ25hbCA9IHRoaXMuX2Fib3J0LnNpZ25hbDtcbiAgICB0aGlzLmlkID0gdGhpcy5pZCB8fCBgc2JiLXN0ZXAtbGFiZWwtJHtuZXh0SWQrK31gO1xuICAgIHRoaXMuX2ludGVybmFscy5hcmlhU2VsZWN0ZWQgPSAnZmFsc2UnO1xuICAgIHRoaXMuX3N0ZXBwZXIgPSB0aGlzLmNsb3Nlc3QoJ3NiYi1zdGVwcGVyJyk7XG4gICAgdGhpcy5fc3RlcCA9IHRoaXMuX2dldFN0ZXAoKTtcbiAgICAvLyBUaGUgYGRhdGEtZGlzYWJsZWRgIGF0dHJpYnV0ZSBpcyB1c2VkIHRvIHByZXNlcnZlIHRoZSBpbml0aWFsIGRpc2FibGVkIHN0YXRlIG9mXG4gICAgLy8gc3RlcCBsYWJlbHMgaW4gY2FzZSBvZiBzd2l0Y2hpbmcgZnJvbSBsaW5lYXIgdG8gbm9uLWxpbmVhciBtb2RlLlxuICAgIHRoaXMudG9nZ2xlQXR0cmlidXRlKCdkYXRhLWRpc2FibGVkJywgdGhpcy5oYXNBdHRyaWJ1dGUoJ2Rpc2FibGVkJykpO1xuICAgIHRoaXMuYWRkRXZlbnRMaXN0ZW5lcihcbiAgICAgICdjbGljaycsXG4gICAgICAoKSA9PiB7XG4gICAgICAgIGlmICh0aGlzLl9zdGVwcGVyICYmIHRoaXMuX3N0ZXApIHtcbiAgICAgICAgICB0aGlzLl9zdGVwcGVyLnNlbGVjdGVkID0gdGhpcy5fc3RlcDtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHsgc2lnbmFsIH0sXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcbiAgICBpZiAodGhpcy5zdGVwKSB7XG4gICAgICB0aGlzLnNldEF0dHJpYnV0ZSgnYXJpYS1jb250cm9scycsIHRoaXMuc3RlcC5pZCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNlbGVjdHMgYW5kIGNvbmZpZ3VyZXMgdGhlIHN0ZXAgbGFiZWwuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHVibGljIHNlbGVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYkluZGV4ID0gMDtcbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVNlbGVjdGVkID0gJ3RydWUnO1xuICAgIHRoaXMudG9nZ2xlQXR0cmlidXRlKCdkYXRhLXNlbGVjdGVkJywgdHJ1ZSk7XG4gIH1cblxuICAvKipcbiAgICogRGVzZWxlY3RzIGFuZCBjb25maWd1cmVzIHRoZSBzdGVwIGxhYmVsLlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBkZXNlbGVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYkluZGV4ID0gLTE7XG4gICAgdGhpcy5faW50ZXJuYWxzLmFyaWFTZWxlY3RlZCA9ICdmYWxzZSc7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtc2VsZWN0ZWQnLCBmYWxzZSk7XG4gIH1cblxuICAvKipcbiAgICogQ29uZmlndXJlcyB0aGUgc3RlcCBsYWJlbC5cbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgY29uZmlndXJlKHBvc0luU2V0OiBudW1iZXIsIHNldFNpemU6IG51bWJlciwgc3RlcHBlckxvYWRlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChzdGVwcGVyTG9hZGVkKSB7XG4gICAgICB0aGlzLl9zdGVwID0gdGhpcy5fZ2V0U3RlcCgpO1xuICAgIH1cbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVBvc0luU2V0ID0gYCR7cG9zSW5TZXR9YDtcbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVNldFNpemUgPSBgJHtzZXRTaXplfWA7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RlcC1sYWJlbFwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGVwLWxhYmVsX19wcmVmaXhcIj4ke3RoaXMucmVuZGVySWNvblNsb3QoKX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXN0ZXAtbGFiZWxfX3RleHRcIj48c2xvdD48L3Nsb3Q+PC9zcGFuPlxuICAgICAgPC9kaXY+
|
|
283
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1sYWJlbC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3N0ZXBwZXIvc3RlcC1sYWJlbC9zdGVwLWxhYmVsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgQ1NTUmVzdWx0R3JvdXAsIGh0bWwsIHR5cGUgVGVtcGxhdGVSZXN1bHQsIHR5cGUgUHJvcGVydHlWYWx1ZXMgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgU2JiQnV0dG9uQmFzZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2Jhc2UtZWxlbWVudHMuanMnO1xuaW1wb3J0IHsgU2JiQ29ubmVjdGVkQWJvcnRDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9jb250cm9sbGVycy5qcyc7XG5pbXBvcnQgeyBob3N0QXR0cmlidXRlcyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyBTYmJEaXNhYmxlZE1peGluIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uLy4uL2ljb24uanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJTdGVwRWxlbWVudCB9IGZyb20gJy4uL3N0ZXAuanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJTdGVwcGVyRWxlbWVudCB9IGZyb20gJy4uL3N0ZXBwZXIuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9zdGVwLWxhYmVsLnNjc3M/bGl0JmlubGluZSc7XG5cbmxldCBuZXh0SWQgPSAwO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLXN0ZXBwZXJgLCBpdCBkaXNwbGF5cyBhIHN0ZXAncyBsYWJlbC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIHByb3ZpZGUgYSBsYWJlbC5cbiAqIEBzbG90IGljb24gLSBVc2UgdGhpcyB0byBkaXNwbGF5IGFuIGljb24gaW4gdGhlIGxhYmVsIGJ1YmJsZS5cbiAqL1xuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zdGVwLWxhYmVsJylcbkBob3N0QXR0cmlidXRlcyh7XG4gIHNsb3Q6ICdzdGVwLWxhYmVsJyxcbiAgdGFiaW5kZXg6ICctMScsXG4gIHJvbGU6ICd0YWInLFxufSlcbmV4cG9ydCBjbGFzcyBTYmJTdGVwTGFiZWxFbGVtZW50IGV4dGVuZHMgU2JiSWNvbk5hbWVNaXhpbihTYmJEaXNhYmxlZE1peGluKFNiYkJ1dHRvbkJhc2VFbGVtZW50KSkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogQGludGVybmFsICovXG4gIHByaXZhdGUgcmVhZG9ubHkgX2ludGVybmFsczogRWxlbWVudEludGVybmFscyA9IHRoaXMuYXR0YWNoSW50ZXJuYWxzKCk7XG5cbiAgLyoqIFRoZSBzdGVwIGNvbnRyb2xsZWQgYnkgdGhlIGxhYmVsLiAqL1xuICBwdWJsaWMgZ2V0IHN0ZXAoKTogU2JiU3RlcEVsZW1lbnQgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5fc3RlcDtcbiAgfVxuXG4gIHByaXZhdGUgX2Fib3J0ID0gbmV3IFNiYkNvbm5lY3RlZEFib3J0Q29udHJvbGxlcih0aGlzKTtcbiAgcHJpdmF0ZSBfc3RlcHBlcjogU2JiU3RlcHBlckVsZW1lbnQgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBfc3RlcDogU2JiU3RlcEVsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICBwcml2YXRlIF9nZXRTdGVwKCk6IFNiYlN0ZXBFbGVtZW50IHwgbnVsbCB7XG4gICAgbGV0IG5leHRTaWJsaW5nID0gdGhpcy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgd2hpbGUgKG5leHRTaWJsaW5nICYmIG5leHRTaWJsaW5nLmxvY2FsTmFtZSAhPT0gJ3NiYi1zdGVwJykge1xuICAgICAgbmV4dFNpYmxpbmcgPSBuZXh0U2libGluZy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgfVxuICAgIHJldHVybiBuZXh0U2libGluZyBhcyBTYmJTdGVwRWxlbWVudDtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIGNvbnN0IHNpZ25hbCA9IHRoaXMuX2Fib3J0LnNpZ25hbDtcbiAgICB0aGlzLmlkID0gdGhpcy5pZCB8fCBgc2JiLXN0ZXAtbGFiZWwtJHtuZXh0SWQrK31gO1xuICAgIHRoaXMuX2ludGVybmFscy5hcmlhU2VsZWN0ZWQgPSAnZmFsc2UnO1xuICAgIHRoaXMuX3N0ZXBwZXIgPSB0aGlzLmNsb3Nlc3QoJ3NiYi1zdGVwcGVyJyk7XG4gICAgdGhpcy5fc3RlcCA9IHRoaXMuX2dldFN0ZXAoKTtcbiAgICAvLyBUaGUgYGRhdGEtZGlzYWJsZWRgIGF0dHJpYnV0ZSBpcyB1c2VkIHRvIHByZXNlcnZlIHRoZSBpbml0aWFsIGRpc2FibGVkIHN0YXRlIG9mXG4gICAgLy8gc3RlcCBsYWJlbHMgaW4gY2FzZSBvZiBzd2l0Y2hpbmcgZnJvbSBsaW5lYXIgdG8gbm9uLWxpbmVhciBtb2RlLlxuICAgIHRoaXMudG9nZ2xlQXR0cmlidXRlKCdkYXRhLWRpc2FibGVkJywgdGhpcy5oYXNBdHRyaWJ1dGUoJ2Rpc2FibGVkJykpO1xuICAgIHRoaXMuYWRkRXZlbnRMaXN0ZW5lcihcbiAgICAgICdjbGljaycsXG4gICAgICAoKSA9PiB7XG4gICAgICAgIGlmICh0aGlzLl9zdGVwcGVyICYmIHRoaXMuX3N0ZXApIHtcbiAgICAgICAgICB0aGlzLl9zdGVwcGVyLnNlbGVjdGVkID0gdGhpcy5fc3RlcDtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIHsgc2lnbmFsIH0sXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcbiAgICBpZiAodGhpcy5zdGVwKSB7XG4gICAgICB0aGlzLnNldEF0dHJpYnV0ZSgnYXJpYS1jb250cm9scycsIHRoaXMuc3RlcC5pZCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNlbGVjdHMgYW5kIGNvbmZpZ3VyZXMgdGhlIHN0ZXAgbGFiZWwuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHVibGljIHNlbGVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYkluZGV4ID0gMDtcbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVNlbGVjdGVkID0gJ3RydWUnO1xuICAgIHRoaXMudG9nZ2xlQXR0cmlidXRlKCdkYXRhLXNlbGVjdGVkJywgdHJ1ZSk7XG4gIH1cblxuICAvKipcbiAgICogRGVzZWxlY3RzIGFuZCBjb25maWd1cmVzIHRoZSBzdGVwIGxhYmVsLlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBkZXNlbGVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYkluZGV4ID0gLTE7XG4gICAgdGhpcy5faW50ZXJuYWxzLmFyaWFTZWxlY3RlZCA9ICdmYWxzZSc7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtc2VsZWN0ZWQnLCBmYWxzZSk7XG4gIH1cblxuICAvKipcbiAgICogQ29uZmlndXJlcyB0aGUgc3RlcCBsYWJlbC5cbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgY29uZmlndXJlKHBvc0luU2V0OiBudW1iZXIsIHNldFNpemU6IG51bWJlciwgc3RlcHBlckxvYWRlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChzdGVwcGVyTG9hZGVkKSB7XG4gICAgICB0aGlzLl9zdGVwID0gdGhpcy5fZ2V0U3RlcCgpO1xuICAgIH1cbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVBvc0luU2V0ID0gYCR7cG9zSW5TZXR9YDtcbiAgICB0aGlzLl9pbnRlcm5hbHMuYXJpYVNldFNpemUgPSBgJHtzZXRTaXplfWA7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RlcC1sYWJlbFwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGVwLWxhYmVsX19wcmVmaXhcIj4ke3RoaXMucmVuZGVySWNvblNsb3QoKX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXN0ZXAtbGFiZWxfX3RleHRcIj48c2xvdD48L3Nsb3Q+PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXN0ZXAtbGFiZWwnOiBTYmJTdGVwTGFiZWxFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFhQSxJQUFJLFNBQVM7QUFjTixJQUFNLHNCQUFOLGNBQWtDLGlCQUFpQixpQkFBaUIsb0JBQW9CLENBQUMsRUFBRTtBQUFBLEVBQTNGLGNBQUE7QUFBQSxVQUFBLEdBQUEsU0FBQTtBQUlZLFNBQUEsYUFBK0IsS0FBSztBQU83QyxTQUFBLFNBQVMsSUFBSSw0QkFBNEIsSUFBSTtBQUNyRCxTQUFRLFdBQXFDO0FBQzdDLFNBQVEsUUFBK0I7QUFBQSxFQUFBO0FBQUE7QUFBQSxFQU52QyxJQUFXLE9BQThCO0FBQ3ZDLFdBQU8sS0FBSztBQUFBLEVBQ2Q7QUFBQSxFQU1RLFdBQWtDO0FBQ3hDLFFBQUksY0FBYyxLQUFLO0FBQ2hCLFdBQUEsZUFBZSxZQUFZLGNBQWMsWUFBWTtBQUMxRCxvQkFBYyxZQUFZO0FBQUEsSUFDNUI7QUFDTyxXQUFBO0FBQUEsRUFDVDtBQUFBLEVBRWdCLG9CQUEwQjtBQUN4QyxVQUFNLGtCQUFrQjtBQUNsQixVQUFBLFNBQVMsS0FBSyxPQUFPO0FBQzNCLFNBQUssS0FBSyxLQUFLLE1BQU0sa0JBQWtCLFFBQVE7QUFDL0MsU0FBSyxXQUFXLGVBQWU7QUFDMUIsU0FBQSxXQUFXLEtBQUssUUFBUSxhQUFhO0FBQ3JDLFNBQUEsUUFBUSxLQUFLO0FBR2xCLFNBQUssZ0JBQWdCLGlCQUFpQixLQUFLLGFBQWEsVUFBVSxDQUFDO0FBQzlELFNBQUE7QUFBQSxNQUNIO0FBQUEsTUFDQSxNQUFNO0FBQ0EsWUFBQSxLQUFLLFlBQVksS0FBSyxPQUFPO0FBQzFCLGVBQUEsU0FBUyxXQUFXLEtBQUs7QUFBQSxRQUNoQztBQUFBLE1BQ0Y7QUFBQSxNQUNBLEVBQUUsT0FBTztBQUFBLElBQUE7QUFBQSxFQUViO0FBQUEsRUFFbUIsYUFBYSxtQkFBK0M7QUFDN0UsVUFBTSxhQUFhLGlCQUFpQjtBQUNwQyxRQUFJLEtBQUssTUFBTTtBQUNiLFdBQUssYUFBYSxpQkFBaUIsS0FBSyxLQUFLLEVBQUU7QUFBQSxJQUNqRDtBQUFBLEVBQ0Y7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBTU8sU0FBZTtBQUNwQixTQUFLLFdBQVc7QUFDaEIsU0FBSyxXQUFXLGVBQWU7QUFDMUIsU0FBQSxnQkFBZ0IsaUJBQWlCLElBQUk7QUFBQSxFQUM1QztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFNTyxXQUFpQjtBQUN0QixTQUFLLFdBQVc7QUFDaEIsU0FBSyxXQUFXLGVBQWU7QUFDMUIsU0FBQSxnQkFBZ0IsaUJBQWlCLEtBQUs7QUFBQSxFQUM3QztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFNTyxVQUFVLFVBQWtCLFNBQWlCLGVBQThCO0FBQ2hGLFFBQUksZUFBZTtBQUNaLFdBQUEsUUFBUSxLQUFLO0lBQ3BCO0FBQ0ssU0FBQSxXQUFXLGVBQWUsR0FBRyxRQUFRO0FBQ3JDLFNBQUEsV0FBVyxjQUFjLEdBQUcsT0FBTztBQUFBLEVBQzFDO0FBQUEsRUFFbUIsU0FBeUI7QUFDbkMsV0FBQTtBQUFBO0FBQUEsK0NBRW9DLEtBQUssZ0JBQWdCO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFJbEU7QUFDRjtBQTNGYSxvQkFDWSxTQUF5QjtBQURyQyxzQkFBTixnQkFBQTtBQUFBLEVBTk4sY0FBYyxnQkFBZ0I7QUFBQSxFQUM5QixlQUFlO0FBQUEsSUFDZCxNQUFNO0FBQUEsSUFDTixVQUFVO0FBQUEsSUFDVixNQUFNO0FBQUEsRUFBQSxDQUNQO0FBQUEsR0FDWSxtQkFBQTsifQ==
|
|
@@ -4,14 +4,7 @@ import { customElement } from "lit/decorators.js";
|
|
|
4
4
|
import { SbbConnectedAbortController } from "../core/controllers.js";
|
|
5
5
|
import { hostAttributes } from "../core/decorators.js";
|
|
6
6
|
import { EventEmitter } from "../core/eventing.js";
|
|
7
|
-
const style = css
|
|
8
|
-
/*
|
|
9
|
-
* SBB table mixin
|
|
10
|
-
* Notes:
|
|
11
|
-
* We cannot use \`border-collapse\` because it is not compatible with the \`border-radius\` property.
|
|
12
|
-
* Therefore, we have to build the grid avoiding double borders.
|
|
13
|
-
*/
|
|
14
|
-
*,
|
|
7
|
+
const style = css`*,
|
|
15
8
|
::before,
|
|
16
9
|
::after {
|
|
17
10
|
box-sizing: border-box;
|
|
@@ -217,4 +210,4 @@ SbbStepElement = __decorateClass([
|
|
|
217
210
|
export {
|
|
218
211
|
SbbStepElement
|
|
219
212
|
};
|
|
220
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.js","sources":["../../../../src/elements/stepper/step/step.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type SbbStepValidateEventDetails = {\n  currentIndex?: number;\n  currentStep?: SbbStepElement;\n  nextIndex?: number;\n  nextStep?: SbbStepElement;\n};\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\n@customElement('sbb-step')\n@hostAttributes({\n  slot: 'step',\n  role: 'tabpanel',\n})\nexport class SbbStepElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\n  );\n\n  private _loaded: boolean = false;\n  private _abort = new SbbConnectedAbortController(this);\n  private _stepper: SbbStepperElement | null = null;\n  private _label: SbbStepLabelElement | null = null;\n  private _stepResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onStepElementResize(entries),\n  });\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this._loaded || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._label = this._getStepLabel();\n    }\n    if (this.label) {\n      this.setAttribute('aria-labelledby', this.label.id);\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this._stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this._stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _onStepElementResize(entries: ResizeObserverEntry[]): void {\n    if (!this.hasAttribute('data-selected')) {\n      return;\n    }\n    const contentHeight = Math.floor(entries[0].contentRect.height);\n    this._stepper?.style?.setProperty('--sbb-stepper-content-height', `${contentHeight}px`);\n  }\n\n  private _getStepLabel(): SbbStepLabelElement | null {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    return previousSibling as SbbStepLabelElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.id = this.id || `sbb-step-${nextId++}`;\n    this.addEventListener('click', (e) => this._handleClick(e), { signal });\n    this._stepper = this.closest('sbb-stepper');\n    this._label = this._getStepLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._loaded = true;\n    this._stepResizeObserver.observe(this.shadowRoot!.querySelector('.sbb-step') as HTMLElement);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
213
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.js","sources":["../../../../src/elements/stepper/step/step.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type SbbStepValidateEventDetails = {\n  currentIndex?: number;\n  currentStep?: SbbStepElement;\n  nextIndex?: number;\n  nextStep?: SbbStepElement;\n};\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\n@customElement('sbb-step')\n@hostAttributes({\n  slot: 'step',\n  role: 'tabpanel',\n})\nexport class SbbStepElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\n  );\n\n  private _loaded: boolean = false;\n  private _abort = new SbbConnectedAbortController(this);\n  private _stepper: SbbStepperElement | null = null;\n  private _label: SbbStepLabelElement | null = null;\n  private _stepResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onStepElementResize(entries),\n  });\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this._loaded || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._label = this._getStepLabel();\n    }\n    if (this.label) {\n      this.setAttribute('aria-labelledby', this.label.id);\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this._stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this._stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _onStepElementResize(entries: ResizeObserverEntry[]): void {\n    if (!this.hasAttribute('data-selected')) {\n      return;\n    }\n    const contentHeight = Math.floor(entries[0].contentRect.height);\n    this._stepper?.style?.setProperty('--sbb-stepper-content-height', `${contentHeight}px`);\n  }\n\n  private _getStepLabel(): SbbStepLabelElement | null {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    return previousSibling as SbbStepLabelElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.id = this.id || `sbb-step-${nextId++}`;\n    this.addEventListener('click', (e) => this._handleClick(e), { signal });\n    this._stepper = this.closest('sbb-stepper');\n    this._label = this._getStepLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._loaded = true;\n    this._stepResizeObserver.observe(this.shadowRoot!.querySelector('.sbb-step') as HTMLElement);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|