@sbb-esta/lyne-elements-dev 4.9.0-dev.1774376412 → 4.9.0-dev.1774507634
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/core/styles/core.scss +5 -0
- package/core.css +23 -0
- package/development/slider/slider.component.js +1 -1
- package/development/slider.component-QzF7A8Yl.js +456 -0
- package/development/slider.js +1 -1
- package/development/slider.pure.js +1 -1
- package/off-brand-theme.css +23 -0
- package/package.json +2 -2
- package/safety-theme.css +23 -0
- package/slider/slider.component.js +1 -1
- package/{slider.component-MdvM78XU.js → slider.component-D-yXlqJY.js} +2 -2
- package/slider.js +1 -1
- package/slider.pure.js +1 -1
- package/standard-theme.css +23 -0
- package/development/slider.component-w_WtVNx-.js +0 -479
package/core/styles/core.scss
CHANGED
|
@@ -194,6 +194,9 @@ $theme: 'standard' !default;
|
|
|
194
194
|
@use '../../signet/signet.global' as signet with (
|
|
195
195
|
$theme: $theme
|
|
196
196
|
);
|
|
197
|
+
@use '../../slider/slider.global' as slider with (
|
|
198
|
+
$theme: $theme
|
|
199
|
+
);
|
|
197
200
|
@use '../../status/status.global' as status with (
|
|
198
201
|
$theme: $theme
|
|
199
202
|
);
|
|
@@ -273,6 +276,7 @@ $theme: 'standard' !default;
|
|
|
273
276
|
@include selection-action-panel.base;
|
|
274
277
|
@include selection-expansion-panel.base;
|
|
275
278
|
@include signet.base;
|
|
279
|
+
@include slider.base;
|
|
276
280
|
@include status.base;
|
|
277
281
|
@include tab-group-common.base;
|
|
278
282
|
@include tab-label-common.base;
|
|
@@ -292,6 +296,7 @@ $theme: 'standard' !default;
|
|
|
292
296
|
@include visual-checkbox.base-forced-colors;
|
|
293
297
|
@include radio-button-common.base-forced-colors;
|
|
294
298
|
@include signet.base-forced-colors;
|
|
299
|
+
@include slider.base-forced-colors;
|
|
295
300
|
}
|
|
296
301
|
|
|
297
302
|
// Train formation
|
package/core.css
CHANGED
|
@@ -1632,6 +1632,27 @@ slot[name=error]::slotted(*) {
|
|
|
1632
1632
|
--sbb-signet-panel-color: var(--sbb-color-brand);
|
|
1633
1633
|
--sbb-signet-icon-color: var(--sbb-color-white);
|
|
1634
1634
|
--sbb-signet-aspect-ratio: 2 / 1;
|
|
1635
|
+
--sbb-slider-line-height: 0.25rem;
|
|
1636
|
+
--sbb-slider-knob-size: 1.75rem;
|
|
1637
|
+
--sbb-slider-knob-size-active: 1.9375rem;
|
|
1638
|
+
--sbb-slider-knob-border-size: 0.1875rem;
|
|
1639
|
+
--sbb-slider-knob-border-style: solid;
|
|
1640
|
+
--sbb-slider-knob-color: var(--sbb-background-color-1);
|
|
1641
|
+
--sbb-slider-knob-border-color: var(--sbb-color-primary);
|
|
1642
|
+
--sbb-slider-icon-color: var(--sbb-color-1);
|
|
1643
|
+
--sbb-slider-selected-line-disabled-color: var(--sbb-color-smoke);
|
|
1644
|
+
--sbb-slider-selected-line-disabled-color: light-dark(
|
|
1645
|
+
var(--sbb-color-smoke),
|
|
1646
|
+
var(--sbb-color-cement)
|
|
1647
|
+
);
|
|
1648
|
+
--sbb-slider-line-color: var(--sbb-border-color-5);
|
|
1649
|
+
--sbb-slider-selected-line-color: var(--sbb-color-primary);
|
|
1650
|
+
--sbb-slider-line-disabled-color: var(--sbb-color-graphite);
|
|
1651
|
+
--sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
|
|
1652
|
+
--sbb-slider-width: 25rem;
|
|
1653
|
+
--sbb-slider-min-width: 9.375rem;
|
|
1654
|
+
--sbb-slider-gap: var(--sbb-spacing-fixed-2x);
|
|
1655
|
+
--sbb-slider-padding-block: 0.125rem;
|
|
1635
1656
|
--sbb-status-color: var(--sbb-color-4);
|
|
1636
1657
|
--sbb-status-gap: var(--sbb-spacing-fixed-1x);
|
|
1637
1658
|
--sbb-status-font-size: var(--sbb-text-font-size-s);
|
|
@@ -1709,6 +1730,8 @@ slot[name=error]::slotted(*) {
|
|
|
1709
1730
|
--sbb-signet-background-color: ButtonText !important;
|
|
1710
1731
|
--sbb-signet-panel-color: ButtonText !important;
|
|
1711
1732
|
--sbb-signet-icon-color: Canvas !important;
|
|
1733
|
+
--sbb-slider-selected-line-color: Highlight;
|
|
1734
|
+
--sbb-slider-line-color: CanvasText;
|
|
1712
1735
|
}
|
|
1713
1736
|
}
|
|
1714
1737
|
:root {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSliderElement } from "../slider.component-
|
|
1
|
+
import { t as SbbSliderElement } from "../slider.component-QzF7A8Yl.js";
|
|
2
2
|
export { SbbSliderElement };
|
|
@@ -0,0 +1,456 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { css, html, nothing } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbElement } from "./core/base-elements.js";
|
|
5
|
+
import { forceType, hostAttributes } from "./core/decorators.js";
|
|
6
|
+
import { SbbDisabledMixin, SbbFormAssociatedMixin, SbbReadonlyMixin } from "./core/mixins.js";
|
|
7
|
+
import { boxSizingStyles } from "./core/styles.js";
|
|
8
|
+
import "./icon.js";
|
|
9
|
+
import { ref } from "lit/directives/ref.js";
|
|
10
|
+
//#region src/elements/slider/slider.scss?lit&inline
|
|
11
|
+
var slider_default = css`@charset "UTF-8";
|
|
12
|
+
:host {
|
|
13
|
+
--_sbb-slider-value-fraction: 0;
|
|
14
|
+
outline: none !important;
|
|
15
|
+
display: inline-block;
|
|
16
|
+
min-width: var(--sbb-slider-min-width);
|
|
17
|
+
width: min(var(--sbb-slider-width), 100%);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
:host(:disabled) {
|
|
21
|
+
--sbb-slider-icon-color: var(--sbb-color-graphite);
|
|
22
|
+
--sbb-slider-icon-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));
|
|
23
|
+
--sbb-slider-knob-border-color: var(--sbb-border-color-5);
|
|
24
|
+
--sbb-slider-knob-border-size: var(--sbb-border-width-2x);
|
|
25
|
+
--sbb-slider-knob-border-style: dashed;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
:host([readonly]) {
|
|
29
|
+
--sbb-slider-icon-color: var(--sbb-color-5);
|
|
30
|
+
--sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
:host(:disabled),
|
|
34
|
+
:host([readonly]) {
|
|
35
|
+
--sbb-slider-line-color: var(--sbb-slider-line-disabled-color);
|
|
36
|
+
--sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color);
|
|
37
|
+
}
|
|
38
|
+
@media (forced-colors: active) {
|
|
39
|
+
:host(:disabled),
|
|
40
|
+
:host([readonly]) {
|
|
41
|
+
--sbb-slider-icon-color: GrayText;
|
|
42
|
+
--sbb-slider-selected-line-disabled-color: GrayText;
|
|
43
|
+
--sbb-slider-line-disabled-color: GrayText;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
.sbb-slider__height-container {
|
|
48
|
+
display: flex;
|
|
49
|
+
flex-direction: column;
|
|
50
|
+
}
|
|
51
|
+
.sbb-slider__height-container::before {
|
|
52
|
+
content: "";
|
|
53
|
+
user-select: none;
|
|
54
|
+
width: 0;
|
|
55
|
+
height: 0;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.sbb-slider__wrapper {
|
|
59
|
+
display: flex;
|
|
60
|
+
gap: var(--sbb-slider-gap);
|
|
61
|
+
padding-block: var(--sbb-slider-padding-block);
|
|
62
|
+
color: var(--sbb-slider-icon-color);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
.sbb-slider__container {
|
|
66
|
+
position: relative;
|
|
67
|
+
min-height: var(--sbb-size-icon-ui-small);
|
|
68
|
+
flex-grow: 1;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.sbb-slider__range-input {
|
|
72
|
+
position: absolute;
|
|
73
|
+
width: 100%;
|
|
74
|
+
inset: 0;
|
|
75
|
+
opacity: 0;
|
|
76
|
+
margin: 0;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.sbb-slider__line {
|
|
80
|
+
position: absolute;
|
|
81
|
+
top: 50%;
|
|
82
|
+
transform: translateY(-50%);
|
|
83
|
+
height: var(--sbb-slider-line-height);
|
|
84
|
+
width: 100%;
|
|
85
|
+
background-color: var(--sbb-slider-line-color);
|
|
86
|
+
border-radius: var(--sbb-slider-line-height);
|
|
87
|
+
overflow: hidden;
|
|
88
|
+
pointer-events: none;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
.sbb-slider__selected-line {
|
|
92
|
+
position: relative;
|
|
93
|
+
height: 100%;
|
|
94
|
+
background-color: var(--sbb-slider-selected-line-color);
|
|
95
|
+
width: calc(var(--_sbb-slider-value-fraction) * 100%);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.sbb-slider__knob {
|
|
99
|
+
position: absolute;
|
|
100
|
+
top: 50%;
|
|
101
|
+
transform: translateY(-50%);
|
|
102
|
+
box-shadow: var(--sbb-box-shadow-level-5-hard);
|
|
103
|
+
width: var(--sbb-slider-knob-size);
|
|
104
|
+
height: var(--sbb-slider-knob-size);
|
|
105
|
+
inset-inline-start: calc(var(--_sbb-slider-value-fraction) * 100% - var(--sbb-slider-knob-size) * var(--_sbb-slider-value-fraction));
|
|
106
|
+
transition-property: width, height;
|
|
107
|
+
transition-duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-1x));
|
|
108
|
+
transition-timing-function: ease-in;
|
|
109
|
+
background-color: var(--sbb-slider-knob-color);
|
|
110
|
+
border: var(--sbb-slider-knob-border-size) var(--sbb-slider-knob-border-style) var(--sbb-slider-knob-border-color);
|
|
111
|
+
border-radius: 50%;
|
|
112
|
+
pointer-events: none;
|
|
113
|
+
}
|
|
114
|
+
:host(:focus-visible) .sbb-slider__knob {
|
|
115
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
116
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
117
|
+
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
118
|
+
}
|
|
119
|
+
:host(:not(:is(:disabled, [readonly]))) .sbb-slider__range-input:active ~ .sbb-slider__knob {
|
|
120
|
+
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
121
|
+
}`;
|
|
122
|
+
//#endregion
|
|
123
|
+
//#region src/elements/slider/slider.component.ts
|
|
124
|
+
/**
|
|
125
|
+
* It displays an input knob that can be moved in a range.
|
|
126
|
+
*
|
|
127
|
+
* @slot prefix - Use this slot to render an icon on the left side of the input.
|
|
128
|
+
* @slot suffix - Use this slot to render an icon on the right side of the input.
|
|
129
|
+
* @event {InputEvent} input - The input event fires when the value has been changed as a direct result of a user action.
|
|
130
|
+
*/
|
|
131
|
+
var SbbSliderElement = (() => {
|
|
132
|
+
let _classDecorators = [hostAttributes({ tabindex: "0" })];
|
|
133
|
+
let _classDescriptor;
|
|
134
|
+
let _classExtraInitializers = [];
|
|
135
|
+
let _classThis;
|
|
136
|
+
let _classSuper = SbbDisabledMixin(SbbReadonlyMixin(SbbFormAssociatedMixin(SbbElement)));
|
|
137
|
+
let _instanceExtraInitializers = [];
|
|
138
|
+
let _set_value_decorators;
|
|
139
|
+
let _set_valueAsNumber_decorators;
|
|
140
|
+
let _set_min_decorators;
|
|
141
|
+
let _set_max_decorators;
|
|
142
|
+
let _startIcon_decorators;
|
|
143
|
+
let _startIcon_initializers = [];
|
|
144
|
+
let _startIcon_extraInitializers = [];
|
|
145
|
+
let _endIcon_decorators;
|
|
146
|
+
let _endIcon_initializers = [];
|
|
147
|
+
let _endIcon_extraInitializers = [];
|
|
148
|
+
var SbbSliderElement = class extends _classSuper {
|
|
149
|
+
static {
|
|
150
|
+
_classThis = this;
|
|
151
|
+
}
|
|
152
|
+
static {
|
|
153
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
154
|
+
_set_value_decorators = [property()];
|
|
155
|
+
_set_valueAsNumber_decorators = [property({
|
|
156
|
+
attribute: "value-as-number",
|
|
157
|
+
type: Number
|
|
158
|
+
})];
|
|
159
|
+
_set_min_decorators = [property()];
|
|
160
|
+
_set_max_decorators = [property()];
|
|
161
|
+
_startIcon_decorators = [forceType(), property({ attribute: "start-icon" })];
|
|
162
|
+
_endIcon_decorators = [forceType(), property({ attribute: "end-icon" })];
|
|
163
|
+
__esDecorate(this, null, _set_value_decorators, {
|
|
164
|
+
kind: "setter",
|
|
165
|
+
name: "value",
|
|
166
|
+
static: false,
|
|
167
|
+
private: false,
|
|
168
|
+
access: {
|
|
169
|
+
has: (obj) => "value" in obj,
|
|
170
|
+
set: (obj, value) => {
|
|
171
|
+
obj.value = value;
|
|
172
|
+
}
|
|
173
|
+
},
|
|
174
|
+
metadata: _metadata
|
|
175
|
+
}, null, _instanceExtraInitializers);
|
|
176
|
+
__esDecorate(this, null, _set_valueAsNumber_decorators, {
|
|
177
|
+
kind: "setter",
|
|
178
|
+
name: "valueAsNumber",
|
|
179
|
+
static: false,
|
|
180
|
+
private: false,
|
|
181
|
+
access: {
|
|
182
|
+
has: (obj) => "valueAsNumber" in obj,
|
|
183
|
+
set: (obj, value) => {
|
|
184
|
+
obj.valueAsNumber = value;
|
|
185
|
+
}
|
|
186
|
+
},
|
|
187
|
+
metadata: _metadata
|
|
188
|
+
}, null, _instanceExtraInitializers);
|
|
189
|
+
__esDecorate(this, null, _set_min_decorators, {
|
|
190
|
+
kind: "setter",
|
|
191
|
+
name: "min",
|
|
192
|
+
static: false,
|
|
193
|
+
private: false,
|
|
194
|
+
access: {
|
|
195
|
+
has: (obj) => "min" in obj,
|
|
196
|
+
set: (obj, value) => {
|
|
197
|
+
obj.min = value;
|
|
198
|
+
}
|
|
199
|
+
},
|
|
200
|
+
metadata: _metadata
|
|
201
|
+
}, null, _instanceExtraInitializers);
|
|
202
|
+
__esDecorate(this, null, _set_max_decorators, {
|
|
203
|
+
kind: "setter",
|
|
204
|
+
name: "max",
|
|
205
|
+
static: false,
|
|
206
|
+
private: false,
|
|
207
|
+
access: {
|
|
208
|
+
has: (obj) => "max" in obj,
|
|
209
|
+
set: (obj, value) => {
|
|
210
|
+
obj.max = value;
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
metadata: _metadata
|
|
214
|
+
}, null, _instanceExtraInitializers);
|
|
215
|
+
__esDecorate(this, null, _startIcon_decorators, {
|
|
216
|
+
kind: "accessor",
|
|
217
|
+
name: "startIcon",
|
|
218
|
+
static: false,
|
|
219
|
+
private: false,
|
|
220
|
+
access: {
|
|
221
|
+
has: (obj) => "startIcon" in obj,
|
|
222
|
+
get: (obj) => obj.startIcon,
|
|
223
|
+
set: (obj, value) => {
|
|
224
|
+
obj.startIcon = value;
|
|
225
|
+
}
|
|
226
|
+
},
|
|
227
|
+
metadata: _metadata
|
|
228
|
+
}, _startIcon_initializers, _startIcon_extraInitializers);
|
|
229
|
+
__esDecorate(this, null, _endIcon_decorators, {
|
|
230
|
+
kind: "accessor",
|
|
231
|
+
name: "endIcon",
|
|
232
|
+
static: false,
|
|
233
|
+
private: false,
|
|
234
|
+
access: {
|
|
235
|
+
has: (obj) => "endIcon" in obj,
|
|
236
|
+
get: (obj) => obj.endIcon,
|
|
237
|
+
set: (obj, value) => {
|
|
238
|
+
obj.endIcon = value;
|
|
239
|
+
}
|
|
240
|
+
},
|
|
241
|
+
metadata: _metadata
|
|
242
|
+
}, _endIcon_initializers, _endIcon_extraInitializers);
|
|
243
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, {
|
|
244
|
+
kind: "class",
|
|
245
|
+
name: _classThis.name,
|
|
246
|
+
metadata: _metadata
|
|
247
|
+
}, null, _classExtraInitializers);
|
|
248
|
+
SbbSliderElement = _classThis = _classDescriptor.value;
|
|
249
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, {
|
|
250
|
+
enumerable: true,
|
|
251
|
+
configurable: true,
|
|
252
|
+
writable: true,
|
|
253
|
+
value: _metadata
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
static {
|
|
257
|
+
this.elementName = "sbb-slider";
|
|
258
|
+
}
|
|
259
|
+
static {
|
|
260
|
+
this.role = "slider";
|
|
261
|
+
}
|
|
262
|
+
static {
|
|
263
|
+
this.styles = [boxSizingStyles, slider_default];
|
|
264
|
+
}
|
|
265
|
+
static {
|
|
266
|
+
this.events = { didChange: "didChange" };
|
|
267
|
+
}
|
|
268
|
+
/**
|
|
269
|
+
* Value of the form element.
|
|
270
|
+
* If no value is provided, default is the middle point between min and max.
|
|
271
|
+
*/
|
|
272
|
+
set value(value) {
|
|
273
|
+
if (this._isValidNumber(value)) this._value = this._boundBetweenMinMax(value);
|
|
274
|
+
else this._value = null;
|
|
275
|
+
this.internals.ariaValueNow = this.value;
|
|
276
|
+
}
|
|
277
|
+
get value() {
|
|
278
|
+
return this._value ?? this._defaultValue();
|
|
279
|
+
}
|
|
280
|
+
/** Numeric value for the inner HTMLInputElement. */
|
|
281
|
+
set valueAsNumber(value) {
|
|
282
|
+
this.value = value?.toString() ?? null;
|
|
283
|
+
}
|
|
284
|
+
get valueAsNumber() {
|
|
285
|
+
return Number(this.value);
|
|
286
|
+
}
|
|
287
|
+
/** Minimum acceptable value for the inner HTMLInputElement. */
|
|
288
|
+
set min(value) {
|
|
289
|
+
if (!this._isValidNumber(value)) return;
|
|
290
|
+
this._min = value;
|
|
291
|
+
this.internals.ariaValueMin = this.min;
|
|
292
|
+
const boundValue = this._boundBetweenMinMax(this.value);
|
|
293
|
+
if (this.value !== boundValue) this.value = boundValue;
|
|
294
|
+
}
|
|
295
|
+
get min() {
|
|
296
|
+
return this._min;
|
|
297
|
+
}
|
|
298
|
+
/** Maximum acceptable value for the inner HTMLInputElement. */
|
|
299
|
+
set max(value) {
|
|
300
|
+
if (!this._isValidNumber(value)) return;
|
|
301
|
+
this._max = value;
|
|
302
|
+
this.internals.ariaValueMax = this.max;
|
|
303
|
+
const boundValue = this._boundBetweenMinMax(this.value);
|
|
304
|
+
if (this.value !== boundValue) this.value = boundValue;
|
|
305
|
+
}
|
|
306
|
+
get max() {
|
|
307
|
+
return this._max;
|
|
308
|
+
}
|
|
309
|
+
#startIcon_accessor_storage;
|
|
310
|
+
/** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */
|
|
311
|
+
get startIcon() {
|
|
312
|
+
return this.#startIcon_accessor_storage;
|
|
313
|
+
}
|
|
314
|
+
set startIcon(value) {
|
|
315
|
+
this.#startIcon_accessor_storage = value;
|
|
316
|
+
}
|
|
317
|
+
#endIcon_accessor_storage;
|
|
318
|
+
/** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */
|
|
319
|
+
get endIcon() {
|
|
320
|
+
return this.#endIcon_accessor_storage;
|
|
321
|
+
}
|
|
322
|
+
set endIcon(value) {
|
|
323
|
+
this.#endIcon_accessor_storage = value;
|
|
324
|
+
}
|
|
325
|
+
/**
|
|
326
|
+
* Form type of element.
|
|
327
|
+
* @default 'range'
|
|
328
|
+
*/
|
|
329
|
+
get type() {
|
|
330
|
+
return "range";
|
|
331
|
+
}
|
|
332
|
+
constructor() {
|
|
333
|
+
super();
|
|
334
|
+
this._value = (__runInitializers(this, _instanceExtraInitializers), null);
|
|
335
|
+
this._min = "0";
|
|
336
|
+
this._max = "100";
|
|
337
|
+
this.#startIcon_accessor_storage = __runInitializers(this, _startIcon_initializers, "");
|
|
338
|
+
this.#endIcon_accessor_storage = (__runInitializers(this, _startIcon_extraInitializers), __runInitializers(this, _endIcon_initializers, ""));
|
|
339
|
+
/** Reference to the inner HTMLInputElement with type='range'. */
|
|
340
|
+
this._rangeInput = __runInitializers(this, _endIcon_extraInitializers);
|
|
341
|
+
this.addEventListener?.("keydown", (e) => this._handleKeydown(e));
|
|
342
|
+
}
|
|
343
|
+
willUpdate(changedProperties) {
|
|
344
|
+
super.willUpdate(changedProperties);
|
|
345
|
+
if (changedProperties.has("readOnly")) this.internals.ariaReadOnly = Boolean(this.readOnly).toString();
|
|
346
|
+
this.style?.setProperty("--_sbb-slider-value-fraction", this._valueFraction().toString());
|
|
347
|
+
}
|
|
348
|
+
/**
|
|
349
|
+
* The reset value is the attribute value (the setup value). If not present, calculates the default.
|
|
350
|
+
* @internal
|
|
351
|
+
*/
|
|
352
|
+
formResetCallback() {
|
|
353
|
+
this.value = this.getAttribute("value") ?? this._defaultValue();
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* @internal
|
|
357
|
+
*/
|
|
358
|
+
formStateRestoreCallback(state, _reason) {
|
|
359
|
+
this.value = state;
|
|
360
|
+
}
|
|
361
|
+
/**
|
|
362
|
+
* If no value is provided, default is the middle point between min and max
|
|
363
|
+
* (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value)
|
|
364
|
+
*/
|
|
365
|
+
_defaultValue() {
|
|
366
|
+
return (+this.min + (+this.max - +this.min) / 2).toString();
|
|
367
|
+
}
|
|
368
|
+
_isValidNumber(value) {
|
|
369
|
+
return !!value && !isNaN(Number(value));
|
|
370
|
+
}
|
|
371
|
+
/**
|
|
372
|
+
* Restrains the value between the min and max
|
|
373
|
+
*/
|
|
374
|
+
_boundBetweenMinMax(value) {
|
|
375
|
+
return Math.max(+this.min, Math.min(+this.max, +value)).toString();
|
|
376
|
+
}
|
|
377
|
+
_valueFraction() {
|
|
378
|
+
const value = this.valueAsNumber;
|
|
379
|
+
const min = +this.min;
|
|
380
|
+
const max = +this.max;
|
|
381
|
+
const mathFraction = (value - min) / (max - min);
|
|
382
|
+
return isNaN(mathFraction) ? 0 : Math.max(0, Math.min(1, mathFraction));
|
|
383
|
+
}
|
|
384
|
+
async _handleKeydown(event) {
|
|
385
|
+
if (event.key !== "Tab") event.preventDefault();
|
|
386
|
+
if (this.readOnly) return;
|
|
387
|
+
if (event.key === "Home") this._rangeInput.value = this.min;
|
|
388
|
+
else if (event.key === "End") this._rangeInput.value = this.max;
|
|
389
|
+
else if (event.key === "ArrowLeft" || event.key === "ArrowDown") this._rangeInput.stepDown();
|
|
390
|
+
else if (event.key === "ArrowRight" || event.key === "ArrowUp") this._rangeInput.stepUp();
|
|
391
|
+
else if (event.key === "PageDown") this._rangeInput.stepDown((+this.max - +this.min) / 10);
|
|
392
|
+
else if (event.key === "PageUp") this._rangeInput.stepUp((+this.max - +this.min) / 10);
|
|
393
|
+
else return;
|
|
394
|
+
this._rangeInput.dispatchEvent(new InputEvent("input", {
|
|
395
|
+
bubbles: true,
|
|
396
|
+
cancelable: true,
|
|
397
|
+
composed: true
|
|
398
|
+
}));
|
|
399
|
+
this._rangeInput.dispatchEvent(new Event("change", { bubbles: true }));
|
|
400
|
+
}
|
|
401
|
+
/** Emits the change event. */
|
|
402
|
+
_dispatchChangeEvent() {
|
|
403
|
+
/**
|
|
404
|
+
* The change event is fired when the user modifies the element's value.
|
|
405
|
+
* Unlike the input event, the change event is not necessarily fired
|
|
406
|
+
* for each alteration to an element's value.
|
|
407
|
+
*/
|
|
408
|
+
this.dispatchEvent(new Event("change", { bubbles: true }));
|
|
409
|
+
/**
|
|
410
|
+
* Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.
|
|
411
|
+
* @deprecated
|
|
412
|
+
*/
|
|
413
|
+
this.dispatchEvent(new Event("didChange", { bubbles: true }));
|
|
414
|
+
}
|
|
415
|
+
render() {
|
|
416
|
+
return html`
|
|
417
|
+
<div class="sbb-slider__height-container">
|
|
418
|
+
<div class="sbb-slider__wrapper">
|
|
419
|
+
<slot name="prefix">
|
|
420
|
+
${this.startIcon ? html`<sbb-icon name="${this.startIcon}"></sbb-icon>` : nothing}
|
|
421
|
+
</slot>
|
|
422
|
+
<div class="sbb-slider__container">
|
|
423
|
+
<input
|
|
424
|
+
tabindex="-1"
|
|
425
|
+
min=${this.min}
|
|
426
|
+
max=${this.max}
|
|
427
|
+
?disabled=${this.disabled || this.formDisabled || this.readOnly}
|
|
428
|
+
value=${this.value || nothing}
|
|
429
|
+
class="sbb-slider__range-input"
|
|
430
|
+
type="range"
|
|
431
|
+
@change=${() => this._dispatchChangeEvent()}
|
|
432
|
+
@input=${() => this.value = this._rangeInput.value}
|
|
433
|
+
${ref((input) => this._rangeInput = input)}
|
|
434
|
+
/>
|
|
435
|
+
<div class="sbb-slider__line">
|
|
436
|
+
<div class="sbb-slider__selected-line"></div>
|
|
437
|
+
</div>
|
|
438
|
+
<div class="sbb-slider__knob"></div>
|
|
439
|
+
</div>
|
|
440
|
+
<slot name="suffix">
|
|
441
|
+
${this.endIcon ? html`<sbb-icon name="${this.endIcon}"></sbb-icon>` : nothing}
|
|
442
|
+
</slot>
|
|
443
|
+
</div>
|
|
444
|
+
</div>
|
|
445
|
+
`;
|
|
446
|
+
}
|
|
447
|
+
static {
|
|
448
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
449
|
+
}
|
|
450
|
+
};
|
|
451
|
+
return _classThis;
|
|
452
|
+
})();
|
|
453
|
+
//#endregion
|
|
454
|
+
export { SbbSliderElement as t };
|
|
455
|
+
|
|
456
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"slider.component-QzF7A8Yl.js","names":[],"sources":["../../../src/elements/slider/slider.scss?lit&inline","../../../src/elements/slider/slider.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  --_sbb-slider-value-fraction: 0;\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n  display: inline-block;\n  min-width: var(--sbb-slider-min-width);\n  width: min(var(--sbb-slider-width), 100%);\n}\n\n:host(:disabled) {\n  --sbb-slider-icon-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));\n  --sbb-slider-knob-border-color: var(--sbb-border-color-5);\n  --sbb-slider-knob-border-size: var(--sbb-border-width-2x);\n  --sbb-slider-knob-border-style: dashed;\n}\n\n:host([readonly]) {\n  --sbb-slider-icon-color: var(--sbb-color-5);\n  --sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color);\n}\n\n:host(:disabled),\n:host([readonly]) {\n  --sbb-slider-line-color: var(--sbb-slider-line-disabled-color);\n  --sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color);\n\n  @include sbb.if-forced-colors {\n    --sbb-slider-icon-color: GrayText;\n    --sbb-slider-selected-line-disabled-color: GrayText;\n    --sbb-slider-line-disabled-color: GrayText;\n  }\n}\n\n.sbb-slider__height-container {\n  display: flex;\n  flex-direction: column;\n\n  @include sbb.zero-width-space;\n}\n\n.sbb-slider__wrapper {\n  display: flex;\n  gap: var(--sbb-slider-gap);\n  padding-block: var(--sbb-slider-padding-block);\n  color: var(--sbb-slider-icon-color);\n}\n\n.sbb-slider__container {\n  position: relative;\n  min-height: var(--sbb-size-icon-ui-small);\n  flex-grow: 1;\n}\n\n.sbb-slider__range-input {\n  position: absolute;\n  width: 100%;\n  inset: 0;\n  opacity: 0;\n  margin: 0;\n}\n\n.sbb-slider__line {\n  @include sbb.absolute-center-y;\n\n  height: var(--sbb-slider-line-height);\n  width: 100%;\n  background-color: var(--sbb-slider-line-color);\n  border-radius: var(--sbb-slider-line-height);\n  overflow: hidden;\n  pointer-events: none;\n}\n\n.sbb-slider__selected-line {\n  position: relative;\n  height: 100%;\n  background-color: var(--sbb-slider-selected-line-color);\n  width: calc(var(--_sbb-slider-value-fraction) * 100%);\n}\n\n.sbb-slider__knob {\n  @include sbb.absolute-center-y;\n\n  box-shadow: var(--sbb-box-shadow-level-5-hard);\n  width: var(--sbb-slider-knob-size);\n  height: var(--sbb-slider-knob-size);\n  inset-inline-start: calc(\n    calc(var(--_sbb-slider-value-fraction) * 100%) - var(--sbb-slider-knob-size) *\n      var(--_sbb-slider-value-fraction)\n  );\n  transition-property: width, height;\n  transition-duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-1x));\n  transition-timing-function: ease-in;\n  background-color: var(--sbb-slider-knob-color);\n  border: var(--sbb-slider-knob-border-size) var(--sbb-slider-knob-border-style)\n    var(--sbb-slider-knob-border-color);\n  border-radius: 50%;\n  pointer-events: none;\n\n  :host(:focus-visible) & {\n    @include sbb.focus-outline;\n\n    --sbb-slider-knob-size: var(--sbb-slider-knob-size-active);\n  }\n\n  // slider knob resize on click (active / focus)\n  :host(:not(:is(:disabled, [readonly]))) .sbb-slider__range-input:active ~ & {\n    --sbb-slider-knob-size: var(--sbb-slider-knob-size-active);\n  }\n}\n","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbElement } from '../core/base-elements.ts';\nimport { forceType, hostAttributes } from '../core/decorators.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n  SbbReadonlyMixin,\n} from '../core/mixins.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\n\nimport style from './slider.scss?lit&inline';\n\nimport '../icon.ts';\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 {InputEvent} input - The input event fires when the value has been changed as a direct result of a user action.\n */\nexport\n@hostAttributes({\n  tabindex: '0',\n})\nclass SbbSliderElement extends SbbDisabledMixin(\n  SbbReadonlyMixin(SbbFormAssociatedMixin(SbbElement)),\n) {\n  public static override readonly elementName: string = 'sbb-slider';\n  public static override readonly role = 'slider';\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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 set value(value: string | null) {\n    if (this._isValidNumber(value)) {\n      this._value = this._boundBetweenMinMax(value);\n    } else {\n      this._value = null;\n    }\n    this.internals.ariaValueNow = this.value;\n  }\n  public get value(): string {\n    return this._value ?? this._defaultValue();\n  }\n  private _value: string | null = null;\n\n  /** Numeric value for the inner HTMLInputElement. */\n  @property({ attribute: 'value-as-number', type: Number })\n  public set valueAsNumber(value: number | null) {\n    this.value = value?.toString() ?? null;\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.internals.ariaValueMin = this.min;\n    const boundValue = this._boundBetweenMinMax(this.value);\n    if (this.value !== boundValue) {\n      this.value = boundValue;\n    }\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.internals.ariaValueMax = this.max;\n    const boundValue = this._boundBetweenMinMax(this.value);\n    if (this.value !== boundValue) {\n      this.value = boundValue;\n    }\n  }\n  public get max(): string {\n    return this._max;\n  }\n  private _max: string = '100';\n\n  /** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */\n  @forceType()\n  @property({ attribute: 'start-icon' })\n  public accessor startIcon: string = '';\n\n  /** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */\n  @forceType()\n  @property({ attribute: 'end-icon' })\n  public accessor endIcon: string = '';\n\n  /**\n   * Form type of element.\n   * @default 'range'\n   */\n  public override get type(): string {\n    return 'range';\n  }\n\n  /** Reference to the inner HTMLInputElement with type='range'. */\n  private _rangeInput!: HTMLInputElement;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeydown(e));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('readOnly')) {\n      this.internals.ariaReadOnly = Boolean(this.readOnly).toString();\n    }\n    this.style?.setProperty('--_sbb-slider-value-fraction', this._valueFraction().toString());\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._defaultValue();\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 _defaultValue(): string {\n    return (+this.min + (+this.max - +this.min) / 2).toString();\n  }\n\n  private _isValidNumber(value: string | null): value is string {\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 _valueFraction(): number {\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    return 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 _dispatchChangeEvent(): void {\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n\n    /**\n     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\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 class=\"sbb-slider__container\">\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=${() => this._dispatchChangeEvent()}\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"],"mappings":"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"}
|
package/development/slider.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbSliderElement } from "./slider.component-
|
|
1
|
+
import { t as SbbSliderElement } from "./slider.component-QzF7A8Yl.js";
|
|
2
2
|
export { SbbSliderElement };
|
package/off-brand-theme.css
CHANGED
|
@@ -1736,6 +1736,27 @@ slot[name=error]::slotted(*) {
|
|
|
1736
1736
|
--sbb-signet-panel-color: var(--sbb-color-brand);
|
|
1737
1737
|
--sbb-signet-icon-color: var(--sbb-color-white);
|
|
1738
1738
|
--sbb-signet-aspect-ratio: 2 / 1;
|
|
1739
|
+
--sbb-slider-line-height: 0.25rem;
|
|
1740
|
+
--sbb-slider-knob-size: 1.75rem;
|
|
1741
|
+
--sbb-slider-knob-size-active: 1.9375rem;
|
|
1742
|
+
--sbb-slider-knob-border-size: 0.1875rem;
|
|
1743
|
+
--sbb-slider-knob-border-style: solid;
|
|
1744
|
+
--sbb-slider-knob-color: var(--sbb-background-color-1);
|
|
1745
|
+
--sbb-slider-knob-border-color: var(--sbb-color-primary);
|
|
1746
|
+
--sbb-slider-icon-color: var(--sbb-color-1);
|
|
1747
|
+
--sbb-slider-selected-line-disabled-color: var(--sbb-color-smoke);
|
|
1748
|
+
--sbb-slider-selected-line-disabled-color: light-dark(
|
|
1749
|
+
var(--sbb-color-smoke),
|
|
1750
|
+
var(--sbb-color-cement)
|
|
1751
|
+
);
|
|
1752
|
+
--sbb-slider-line-color: var(--sbb-border-color-5);
|
|
1753
|
+
--sbb-slider-selected-line-color: var(--sbb-color-primary);
|
|
1754
|
+
--sbb-slider-line-disabled-color: var(--sbb-color-graphite);
|
|
1755
|
+
--sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
|
|
1756
|
+
--sbb-slider-width: 25rem;
|
|
1757
|
+
--sbb-slider-min-width: 9.375rem;
|
|
1758
|
+
--sbb-slider-gap: var(--sbb-spacing-fixed-2x);
|
|
1759
|
+
--sbb-slider-padding-block: 0.125rem;
|
|
1739
1760
|
--sbb-status-color: var(--sbb-color-4);
|
|
1740
1761
|
--sbb-status-gap: var(--sbb-spacing-fixed-1x);
|
|
1741
1762
|
--sbb-status-font-size: var(--sbb-text-font-size-s);
|
|
@@ -1813,6 +1834,8 @@ slot[name=error]::slotted(*) {
|
|
|
1813
1834
|
--sbb-signet-background-color: ButtonText !important;
|
|
1814
1835
|
--sbb-signet-panel-color: ButtonText !important;
|
|
1815
1836
|
--sbb-signet-icon-color: Canvas !important;
|
|
1837
|
+
--sbb-slider-selected-line-color: Highlight;
|
|
1838
|
+
--sbb-slider-line-color: CanvasText;
|
|
1816
1839
|
}
|
|
1817
1840
|
}
|
|
1818
1841
|
:root {
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-dev",
|
|
3
|
-
"version": "4.9.0-dev.
|
|
3
|
+
"version": "4.9.0-dev.1774507634",
|
|
4
4
|
"description": "Lyne Design System",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"design system",
|
|
7
7
|
"web components",
|
|
8
8
|
"lit",
|
|
9
|
-
"https://github.com/sbb-design-systems/lyne-components/commit/
|
|
9
|
+
"https://github.com/sbb-design-systems/lyne-components/commit/e719ede6b528296fc0f36847302124d52a6f5c1c"
|
|
10
10
|
],
|
|
11
11
|
"type": "module",
|
|
12
12
|
"exports": {
|
package/safety-theme.css
CHANGED
|
@@ -1736,6 +1736,27 @@ slot[name=error]::slotted(*) {
|
|
|
1736
1736
|
--sbb-signet-panel-color: var(--sbb-color-brand);
|
|
1737
1737
|
--sbb-signet-icon-color: var(--sbb-color-white);
|
|
1738
1738
|
--sbb-signet-aspect-ratio: 2 / 1;
|
|
1739
|
+
--sbb-slider-line-height: 0.25rem;
|
|
1740
|
+
--sbb-slider-knob-size: 1.75rem;
|
|
1741
|
+
--sbb-slider-knob-size-active: 1.9375rem;
|
|
1742
|
+
--sbb-slider-knob-border-size: 0.1875rem;
|
|
1743
|
+
--sbb-slider-knob-border-style: solid;
|
|
1744
|
+
--sbb-slider-knob-color: var(--sbb-background-color-1);
|
|
1745
|
+
--sbb-slider-knob-border-color: var(--sbb-color-primary);
|
|
1746
|
+
--sbb-slider-icon-color: var(--sbb-color-1);
|
|
1747
|
+
--sbb-slider-selected-line-disabled-color: var(--sbb-color-smoke);
|
|
1748
|
+
--sbb-slider-selected-line-disabled-color: light-dark(
|
|
1749
|
+
var(--sbb-color-smoke),
|
|
1750
|
+
var(--sbb-color-cement)
|
|
1751
|
+
);
|
|
1752
|
+
--sbb-slider-line-color: var(--sbb-border-color-5);
|
|
1753
|
+
--sbb-slider-selected-line-color: var(--sbb-color-primary);
|
|
1754
|
+
--sbb-slider-line-disabled-color: var(--sbb-color-graphite);
|
|
1755
|
+
--sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
|
|
1756
|
+
--sbb-slider-width: 25rem;
|
|
1757
|
+
--sbb-slider-min-width: 9.375rem;
|
|
1758
|
+
--sbb-slider-gap: var(--sbb-spacing-fixed-2x);
|
|
1759
|
+
--sbb-slider-padding-block: 0.125rem;
|
|
1739
1760
|
--sbb-status-color: var(--sbb-color-4);
|
|
1740
1761
|
--sbb-status-gap: var(--sbb-spacing-fixed-1x);
|
|
1741
1762
|
--sbb-status-font-size: var(--sbb-text-font-size-s);
|
|
@@ -1813,6 +1834,8 @@ slot[name=error]::slotted(*) {
|
|
|
1813
1834
|
--sbb-signet-background-color: ButtonText !important;
|
|
1814
1835
|
--sbb-signet-panel-color: ButtonText !important;
|
|
1815
1836
|
--sbb-signet-icon-color: Canvas !important;
|
|
1837
|
+
--sbb-slider-selected-line-color: Highlight;
|
|
1838
|
+
--sbb-slider-line-color: CanvasText;
|
|
1816
1839
|
}
|
|
1817
1840
|
}
|
|
1818
1841
|
:root {
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../slider.component-
|
|
1
|
+
import { t as e } from "../slider.component-D-yXlqJY.js";
|
|
2
2
|
export { e as SbbSliderElement };
|
|
@@ -8,7 +8,7 @@ import { boxSizingStyles as f } from "./core/styles.js";
|
|
|
8
8
|
import "./icon.js";
|
|
9
9
|
import { ref as p } from "lit/directives/ref.js";
|
|
10
10
|
//#region src/elements/slider/slider.scss?lit&inline
|
|
11
|
-
var m = n`@charset "UTF-8";:host{outline:none!important;display:inline-block;min-width:
|
|
11
|
+
var m = n`@charset "UTF-8";:host{--_sbb-slider-value-fraction: 0;outline:none!important;display:inline-block;min-width:var(--sbb-slider-min-width);width:min(var(--sbb-slider-width),100%)}:host(:disabled){--sbb-slider-icon-color: var(--sbb-color-graphite);--sbb-slider-icon-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));--sbb-slider-knob-border-color: var(--sbb-border-color-5);--sbb-slider-knob-border-size: var(--sbb-border-width-2x);--sbb-slider-knob-border-style: dashed}:host([readonly]){--sbb-slider-icon-color: var(--sbb-color-5);--sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color)}:host(:disabled),:host([readonly]){--sbb-slider-line-color: var(--sbb-slider-line-disabled-color);--sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color)}@media(forced-colors:active){:host(:disabled),:host([readonly]){--sbb-slider-icon-color: GrayText;--sbb-slider-selected-line-disabled-color: GrayText;--sbb-slider-line-disabled-color: GrayText}}.sbb-slider__height-container{display:flex;flex-direction:column}.sbb-slider__height-container:before{content:"";-webkit-user-select:none;user-select:none;width:0;height:0}.sbb-slider__wrapper{display:flex;gap:var(--sbb-slider-gap);padding-block:var(--sbb-slider-padding-block);color:var(--sbb-slider-icon-color)}.sbb-slider__container{position:relative;min-height:var(--sbb-size-icon-ui-small);flex-grow:1}.sbb-slider__range-input{position:absolute;width:100%;inset:0;opacity:0;margin:0}.sbb-slider__line{position:absolute;top:50%;transform:translateY(-50%);height:var(--sbb-slider-line-height);width:100%;background-color:var(--sbb-slider-line-color);border-radius:var(--sbb-slider-line-height);overflow:hidden;pointer-events:none}.sbb-slider__selected-line{position:relative;height:100%;background-color:var(--sbb-slider-selected-line-color);width:calc(var(--_sbb-slider-value-fraction) * 100%)}.sbb-slider__knob{position:absolute;top:50%;transform:translateY(-50%);box-shadow:var(--sbb-box-shadow-level-5-hard);width:var(--sbb-slider-knob-size);height:var(--sbb-slider-knob-size);inset-inline-start:calc(var(--_sbb-slider-value-fraction) * 100% - var(--sbb-slider-knob-size) * var(--_sbb-slider-value-fraction));transition-property:width,height;transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-1x));transition-timing-function:ease-in;background-color:var(--sbb-slider-knob-color);border:var(--sbb-slider-knob-border-size) var(--sbb-slider-knob-border-style) var(--sbb-slider-knob-border-color);border-radius:50%;pointer-events:none}:host(:focus-visible) .sbb-slider__knob{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);--sbb-slider-knob-size: var(--sbb-slider-knob-size-active)}:host(:not(:is(:disabled,[readonly]))) .sbb-slider__range-input:active~.sbb-slider__knob{--sbb-slider-knob-size: var(--sbb-slider-knob-size-active)}`, h = (() => {
|
|
12
12
|
let n = [c({ tabindex: "0" })], h, g = [], _, v = l(d(u(o))), y = [], b, x, S, C, w, T = [], E = [], D, O = [], k = [];
|
|
13
13
|
var A = class extends v {
|
|
14
14
|
static {
|
|
@@ -167,7 +167,7 @@ var m = n`@charset "UTF-8";:host{outline:none!important;display:inline-block;min
|
|
|
167
167
|
super(), this._value = (t(this, y), null), this._min = "0", this._max = "100", this.#e = t(this, T, ""), this.#t = (t(this, E), t(this, O, "")), this._rangeInput = t(this, k), this.addEventListener?.("keydown", (e) => this._handleKeydown(e));
|
|
168
168
|
}
|
|
169
169
|
willUpdate(e) {
|
|
170
|
-
super.willUpdate(e), e.has("readOnly") && (this.internals.ariaReadOnly = (!!this.readOnly).toString()), this.style?.setProperty("--
|
|
170
|
+
super.willUpdate(e), e.has("readOnly") && (this.internals.ariaReadOnly = (!!this.readOnly).toString()), this.style?.setProperty("--_sbb-slider-value-fraction", this._valueFraction().toString());
|
|
171
171
|
}
|
|
172
172
|
formResetCallback() {
|
|
173
173
|
this.value = this.getAttribute("value") ?? this._defaultValue();
|
package/slider.js
CHANGED
package/slider.pure.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "./slider.component-
|
|
1
|
+
import { t as e } from "./slider.component-D-yXlqJY.js";
|
|
2
2
|
export { e as SbbSliderElement };
|
package/standard-theme.css
CHANGED
|
@@ -1736,6 +1736,27 @@ slot[name=error]::slotted(*) {
|
|
|
1736
1736
|
--sbb-signet-panel-color: var(--sbb-color-brand);
|
|
1737
1737
|
--sbb-signet-icon-color: var(--sbb-color-white);
|
|
1738
1738
|
--sbb-signet-aspect-ratio: 2 / 1;
|
|
1739
|
+
--sbb-slider-line-height: 0.25rem;
|
|
1740
|
+
--sbb-slider-knob-size: 1.75rem;
|
|
1741
|
+
--sbb-slider-knob-size-active: 1.9375rem;
|
|
1742
|
+
--sbb-slider-knob-border-size: 0.1875rem;
|
|
1743
|
+
--sbb-slider-knob-border-style: solid;
|
|
1744
|
+
--sbb-slider-knob-color: var(--sbb-background-color-1);
|
|
1745
|
+
--sbb-slider-knob-border-color: var(--sbb-color-primary);
|
|
1746
|
+
--sbb-slider-icon-color: var(--sbb-color-1);
|
|
1747
|
+
--sbb-slider-selected-line-disabled-color: var(--sbb-color-smoke);
|
|
1748
|
+
--sbb-slider-selected-line-disabled-color: light-dark(
|
|
1749
|
+
var(--sbb-color-smoke),
|
|
1750
|
+
var(--sbb-color-cement)
|
|
1751
|
+
);
|
|
1752
|
+
--sbb-slider-line-color: var(--sbb-border-color-5);
|
|
1753
|
+
--sbb-slider-selected-line-color: var(--sbb-color-primary);
|
|
1754
|
+
--sbb-slider-line-disabled-color: var(--sbb-color-graphite);
|
|
1755
|
+
--sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
|
|
1756
|
+
--sbb-slider-width: 25rem;
|
|
1757
|
+
--sbb-slider-min-width: 9.375rem;
|
|
1758
|
+
--sbb-slider-gap: var(--sbb-spacing-fixed-2x);
|
|
1759
|
+
--sbb-slider-padding-block: 0.125rem;
|
|
1739
1760
|
--sbb-status-color: var(--sbb-color-4);
|
|
1740
1761
|
--sbb-status-gap: var(--sbb-spacing-fixed-1x);
|
|
1741
1762
|
--sbb-status-font-size: var(--sbb-text-font-size-s);
|
|
@@ -1813,6 +1834,8 @@ slot[name=error]::slotted(*) {
|
|
|
1813
1834
|
--sbb-signet-background-color: ButtonText !important;
|
|
1814
1835
|
--sbb-signet-panel-color: ButtonText !important;
|
|
1815
1836
|
--sbb-signet-icon-color: Canvas !important;
|
|
1837
|
+
--sbb-slider-selected-line-color: Highlight;
|
|
1838
|
+
--sbb-slider-line-color: CanvasText;
|
|
1816
1839
|
}
|
|
1817
1840
|
}
|
|
1818
1841
|
:root {
|
|
@@ -1,479 +0,0 @@
|
|
|
1
|
-
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
-
import { css, html, nothing } from "lit";
|
|
3
|
-
import { property } from "lit/decorators.js";
|
|
4
|
-
import { SbbElement } from "./core/base-elements.js";
|
|
5
|
-
import { forceType, hostAttributes } from "./core/decorators.js";
|
|
6
|
-
import { SbbDisabledMixin, SbbFormAssociatedMixin, SbbReadonlyMixin } from "./core/mixins.js";
|
|
7
|
-
import { boxSizingStyles } from "./core/styles.js";
|
|
8
|
-
import "./icon.js";
|
|
9
|
-
import { ref } from "lit/directives/ref.js";
|
|
10
|
-
//#region src/elements/slider/slider.scss?lit&inline
|
|
11
|
-
var slider_default = css`@charset "UTF-8";
|
|
12
|
-
:host {
|
|
13
|
-
outline: none !important;
|
|
14
|
-
display: inline-block;
|
|
15
|
-
min-width: 9.375rem;
|
|
16
|
-
width: min(25rem, 100%);
|
|
17
|
-
--sbb-slider-line-height: 0.25rem;
|
|
18
|
-
--sbb-slider-value-fraction: 0;
|
|
19
|
-
--sbb-slider-knob-size: 1.75rem;
|
|
20
|
-
--sbb-slider-knob-size-active: 1.9375rem;
|
|
21
|
-
--sbb-slider-knob-border-size: 0.1875rem;
|
|
22
|
-
--sbb-slider-knob-border-style: solid;
|
|
23
|
-
--sbb-slider-knob-color: var(--sbb-background-color-1);
|
|
24
|
-
--sbb-slider-knob-border-color: var(--sbb-color-primary);
|
|
25
|
-
--sbb-slider-icon-color: var(--sbb-color-1);
|
|
26
|
-
--sbb-slider-selected-line-color: var(--sbb-color-primary);
|
|
27
|
-
--sbb-slider-selected-line-disabled-color: var(--sbb-color-smoke);
|
|
28
|
-
--sbb-slider-selected-line-disabled-color: light-dark(
|
|
29
|
-
var(--sbb-color-smoke),
|
|
30
|
-
var(--sbb-color-cement)
|
|
31
|
-
);
|
|
32
|
-
--sbb-slider-line-color: var(--sbb-border-color-5);
|
|
33
|
-
--sbb-slider-line-disabled-color: var(--sbb-color-graphite);
|
|
34
|
-
--sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));
|
|
35
|
-
}
|
|
36
|
-
@media (forced-colors: active) {
|
|
37
|
-
:host {
|
|
38
|
-
--sbb-slider-selected-line-color: Highlight;
|
|
39
|
-
--sbb-slider-line-color: CanvasText;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
:host(:disabled) {
|
|
44
|
-
--sbb-slider-icon-color: var(--sbb-color-graphite);
|
|
45
|
-
--sbb-slider-icon-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));
|
|
46
|
-
--sbb-slider-knob-border-color: var(--sbb-border-color-5);
|
|
47
|
-
--sbb-slider-knob-border-size: var(--sbb-border-width-2x);
|
|
48
|
-
--sbb-slider-knob-border-style: dashed;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
:host([readonly]) {
|
|
52
|
-
--sbb-slider-icon-color: var(--sbb-color-5);
|
|
53
|
-
--sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
:host(:disabled),
|
|
57
|
-
:host([readonly]) {
|
|
58
|
-
--sbb-slider-line-color: var(--sbb-slider-line-disabled-color);
|
|
59
|
-
--sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color);
|
|
60
|
-
}
|
|
61
|
-
@media (forced-colors: active) {
|
|
62
|
-
:host(:disabled),
|
|
63
|
-
:host([readonly]) {
|
|
64
|
-
--sbb-slider-icon-color: GrayText;
|
|
65
|
-
--sbb-slider-selected-line-disabled-color: GrayText;
|
|
66
|
-
--sbb-slider-line-disabled-color: GrayText;
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
.sbb-slider__height-container {
|
|
71
|
-
display: flex;
|
|
72
|
-
flex-direction: column;
|
|
73
|
-
}
|
|
74
|
-
.sbb-slider__height-container::before {
|
|
75
|
-
content: "";
|
|
76
|
-
user-select: none;
|
|
77
|
-
width: 0;
|
|
78
|
-
height: 0;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
.sbb-slider__wrapper {
|
|
82
|
-
display: flex;
|
|
83
|
-
gap: var(--sbb-spacing-fixed-2x);
|
|
84
|
-
padding-block: calc(var(--sbb-spacing-fixed-1x) / 2);
|
|
85
|
-
color: var(--sbb-slider-icon-color);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
.sbb-slider__container {
|
|
89
|
-
position: relative;
|
|
90
|
-
min-height: var(--sbb-size-icon-ui-small);
|
|
91
|
-
flex-grow: 1;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
.sbb-slider__range-input {
|
|
95
|
-
position: absolute;
|
|
96
|
-
width: 100%;
|
|
97
|
-
inset: 0;
|
|
98
|
-
opacity: 0;
|
|
99
|
-
margin: 0;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
.sbb-slider__line {
|
|
103
|
-
position: absolute;
|
|
104
|
-
top: 50%;
|
|
105
|
-
transform: translateY(-50%);
|
|
106
|
-
height: var(--sbb-slider-line-height);
|
|
107
|
-
width: 100%;
|
|
108
|
-
background-color: var(--sbb-slider-line-color);
|
|
109
|
-
border-radius: var(--sbb-slider-line-height);
|
|
110
|
-
overflow: hidden;
|
|
111
|
-
pointer-events: none;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
.sbb-slider__selected-line {
|
|
115
|
-
position: relative;
|
|
116
|
-
height: 100%;
|
|
117
|
-
background-color: var(--sbb-slider-selected-line-color);
|
|
118
|
-
width: calc(var(--sbb-slider-value-fraction) * 100%);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
.sbb-slider__knob {
|
|
122
|
-
position: absolute;
|
|
123
|
-
top: 50%;
|
|
124
|
-
transform: translateY(-50%);
|
|
125
|
-
box-shadow: var(--sbb-box-shadow-level-5-hard);
|
|
126
|
-
width: var(--sbb-slider-knob-size);
|
|
127
|
-
height: var(--sbb-slider-knob-size);
|
|
128
|
-
inset-inline-start: calc(var(--sbb-slider-value-fraction) * 100% - var(--sbb-slider-knob-size) * var(--sbb-slider-value-fraction));
|
|
129
|
-
transition-property: width, height;
|
|
130
|
-
transition-duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-1x));
|
|
131
|
-
transition-timing-function: ease-in;
|
|
132
|
-
background-color: var(--sbb-slider-knob-color);
|
|
133
|
-
border: var(--sbb-slider-knob-border-size) var(--sbb-slider-knob-border-style) var(--sbb-slider-knob-border-color);
|
|
134
|
-
border-radius: 50%;
|
|
135
|
-
pointer-events: none;
|
|
136
|
-
}
|
|
137
|
-
:host(:focus-visible) .sbb-slider__knob {
|
|
138
|
-
outline-offset: var(--sbb-focus-outline-offset);
|
|
139
|
-
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
140
|
-
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
141
|
-
}
|
|
142
|
-
:host(:not(:is(:disabled, [readonly]))) .sbb-slider__range-input:active ~ .sbb-slider__knob {
|
|
143
|
-
--sbb-slider-knob-size: var(--sbb-slider-knob-size-active);
|
|
144
|
-
}`;
|
|
145
|
-
//#endregion
|
|
146
|
-
//#region src/elements/slider/slider.component.ts
|
|
147
|
-
/**
|
|
148
|
-
* It displays an input knob that can be moved in a range.
|
|
149
|
-
*
|
|
150
|
-
* @slot prefix - Use this slot to render an icon on the left side of the input.
|
|
151
|
-
* @slot suffix - Use this slot to render an icon on the right side of the input.
|
|
152
|
-
* @event {InputEvent} input - The input event fires when the value has been changed as a direct result of a user action.
|
|
153
|
-
*/
|
|
154
|
-
var SbbSliderElement = (() => {
|
|
155
|
-
let _classDecorators = [hostAttributes({ tabindex: "0" })];
|
|
156
|
-
let _classDescriptor;
|
|
157
|
-
let _classExtraInitializers = [];
|
|
158
|
-
let _classThis;
|
|
159
|
-
let _classSuper = SbbDisabledMixin(SbbReadonlyMixin(SbbFormAssociatedMixin(SbbElement)));
|
|
160
|
-
let _instanceExtraInitializers = [];
|
|
161
|
-
let _set_value_decorators;
|
|
162
|
-
let _set_valueAsNumber_decorators;
|
|
163
|
-
let _set_min_decorators;
|
|
164
|
-
let _set_max_decorators;
|
|
165
|
-
let _startIcon_decorators;
|
|
166
|
-
let _startIcon_initializers = [];
|
|
167
|
-
let _startIcon_extraInitializers = [];
|
|
168
|
-
let _endIcon_decorators;
|
|
169
|
-
let _endIcon_initializers = [];
|
|
170
|
-
let _endIcon_extraInitializers = [];
|
|
171
|
-
var SbbSliderElement = class extends _classSuper {
|
|
172
|
-
static {
|
|
173
|
-
_classThis = this;
|
|
174
|
-
}
|
|
175
|
-
static {
|
|
176
|
-
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
177
|
-
_set_value_decorators = [property()];
|
|
178
|
-
_set_valueAsNumber_decorators = [property({
|
|
179
|
-
attribute: "value-as-number",
|
|
180
|
-
type: Number
|
|
181
|
-
})];
|
|
182
|
-
_set_min_decorators = [property()];
|
|
183
|
-
_set_max_decorators = [property()];
|
|
184
|
-
_startIcon_decorators = [forceType(), property({ attribute: "start-icon" })];
|
|
185
|
-
_endIcon_decorators = [forceType(), property({ attribute: "end-icon" })];
|
|
186
|
-
__esDecorate(this, null, _set_value_decorators, {
|
|
187
|
-
kind: "setter",
|
|
188
|
-
name: "value",
|
|
189
|
-
static: false,
|
|
190
|
-
private: false,
|
|
191
|
-
access: {
|
|
192
|
-
has: (obj) => "value" in obj,
|
|
193
|
-
set: (obj, value) => {
|
|
194
|
-
obj.value = value;
|
|
195
|
-
}
|
|
196
|
-
},
|
|
197
|
-
metadata: _metadata
|
|
198
|
-
}, null, _instanceExtraInitializers);
|
|
199
|
-
__esDecorate(this, null, _set_valueAsNumber_decorators, {
|
|
200
|
-
kind: "setter",
|
|
201
|
-
name: "valueAsNumber",
|
|
202
|
-
static: false,
|
|
203
|
-
private: false,
|
|
204
|
-
access: {
|
|
205
|
-
has: (obj) => "valueAsNumber" in obj,
|
|
206
|
-
set: (obj, value) => {
|
|
207
|
-
obj.valueAsNumber = value;
|
|
208
|
-
}
|
|
209
|
-
},
|
|
210
|
-
metadata: _metadata
|
|
211
|
-
}, null, _instanceExtraInitializers);
|
|
212
|
-
__esDecorate(this, null, _set_min_decorators, {
|
|
213
|
-
kind: "setter",
|
|
214
|
-
name: "min",
|
|
215
|
-
static: false,
|
|
216
|
-
private: false,
|
|
217
|
-
access: {
|
|
218
|
-
has: (obj) => "min" in obj,
|
|
219
|
-
set: (obj, value) => {
|
|
220
|
-
obj.min = value;
|
|
221
|
-
}
|
|
222
|
-
},
|
|
223
|
-
metadata: _metadata
|
|
224
|
-
}, null, _instanceExtraInitializers);
|
|
225
|
-
__esDecorate(this, null, _set_max_decorators, {
|
|
226
|
-
kind: "setter",
|
|
227
|
-
name: "max",
|
|
228
|
-
static: false,
|
|
229
|
-
private: false,
|
|
230
|
-
access: {
|
|
231
|
-
has: (obj) => "max" in obj,
|
|
232
|
-
set: (obj, value) => {
|
|
233
|
-
obj.max = value;
|
|
234
|
-
}
|
|
235
|
-
},
|
|
236
|
-
metadata: _metadata
|
|
237
|
-
}, null, _instanceExtraInitializers);
|
|
238
|
-
__esDecorate(this, null, _startIcon_decorators, {
|
|
239
|
-
kind: "accessor",
|
|
240
|
-
name: "startIcon",
|
|
241
|
-
static: false,
|
|
242
|
-
private: false,
|
|
243
|
-
access: {
|
|
244
|
-
has: (obj) => "startIcon" in obj,
|
|
245
|
-
get: (obj) => obj.startIcon,
|
|
246
|
-
set: (obj, value) => {
|
|
247
|
-
obj.startIcon = value;
|
|
248
|
-
}
|
|
249
|
-
},
|
|
250
|
-
metadata: _metadata
|
|
251
|
-
}, _startIcon_initializers, _startIcon_extraInitializers);
|
|
252
|
-
__esDecorate(this, null, _endIcon_decorators, {
|
|
253
|
-
kind: "accessor",
|
|
254
|
-
name: "endIcon",
|
|
255
|
-
static: false,
|
|
256
|
-
private: false,
|
|
257
|
-
access: {
|
|
258
|
-
has: (obj) => "endIcon" in obj,
|
|
259
|
-
get: (obj) => obj.endIcon,
|
|
260
|
-
set: (obj, value) => {
|
|
261
|
-
obj.endIcon = value;
|
|
262
|
-
}
|
|
263
|
-
},
|
|
264
|
-
metadata: _metadata
|
|
265
|
-
}, _endIcon_initializers, _endIcon_extraInitializers);
|
|
266
|
-
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, {
|
|
267
|
-
kind: "class",
|
|
268
|
-
name: _classThis.name,
|
|
269
|
-
metadata: _metadata
|
|
270
|
-
}, null, _classExtraInitializers);
|
|
271
|
-
SbbSliderElement = _classThis = _classDescriptor.value;
|
|
272
|
-
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, {
|
|
273
|
-
enumerable: true,
|
|
274
|
-
configurable: true,
|
|
275
|
-
writable: true,
|
|
276
|
-
value: _metadata
|
|
277
|
-
});
|
|
278
|
-
}
|
|
279
|
-
static {
|
|
280
|
-
this.elementName = "sbb-slider";
|
|
281
|
-
}
|
|
282
|
-
static {
|
|
283
|
-
this.role = "slider";
|
|
284
|
-
}
|
|
285
|
-
static {
|
|
286
|
-
this.styles = [boxSizingStyles, slider_default];
|
|
287
|
-
}
|
|
288
|
-
static {
|
|
289
|
-
this.events = { didChange: "didChange" };
|
|
290
|
-
}
|
|
291
|
-
/**
|
|
292
|
-
* Value of the form element.
|
|
293
|
-
* If no value is provided, default is the middle point between min and max.
|
|
294
|
-
*/
|
|
295
|
-
set value(value) {
|
|
296
|
-
if (this._isValidNumber(value)) this._value = this._boundBetweenMinMax(value);
|
|
297
|
-
else this._value = null;
|
|
298
|
-
this.internals.ariaValueNow = this.value;
|
|
299
|
-
}
|
|
300
|
-
get value() {
|
|
301
|
-
return this._value ?? this._defaultValue();
|
|
302
|
-
}
|
|
303
|
-
/** Numeric value for the inner HTMLInputElement. */
|
|
304
|
-
set valueAsNumber(value) {
|
|
305
|
-
this.value = value?.toString() ?? null;
|
|
306
|
-
}
|
|
307
|
-
get valueAsNumber() {
|
|
308
|
-
return Number(this.value);
|
|
309
|
-
}
|
|
310
|
-
/** Minimum acceptable value for the inner HTMLInputElement. */
|
|
311
|
-
set min(value) {
|
|
312
|
-
if (!this._isValidNumber(value)) return;
|
|
313
|
-
this._min = value;
|
|
314
|
-
this.internals.ariaValueMin = this.min;
|
|
315
|
-
const boundValue = this._boundBetweenMinMax(this.value);
|
|
316
|
-
if (this.value !== boundValue) this.value = boundValue;
|
|
317
|
-
}
|
|
318
|
-
get min() {
|
|
319
|
-
return this._min;
|
|
320
|
-
}
|
|
321
|
-
/** Maximum acceptable value for the inner HTMLInputElement. */
|
|
322
|
-
set max(value) {
|
|
323
|
-
if (!this._isValidNumber(value)) return;
|
|
324
|
-
this._max = value;
|
|
325
|
-
this.internals.ariaValueMax = this.max;
|
|
326
|
-
const boundValue = this._boundBetweenMinMax(this.value);
|
|
327
|
-
if (this.value !== boundValue) this.value = boundValue;
|
|
328
|
-
}
|
|
329
|
-
get max() {
|
|
330
|
-
return this._max;
|
|
331
|
-
}
|
|
332
|
-
#startIcon_accessor_storage;
|
|
333
|
-
/** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */
|
|
334
|
-
get startIcon() {
|
|
335
|
-
return this.#startIcon_accessor_storage;
|
|
336
|
-
}
|
|
337
|
-
set startIcon(value) {
|
|
338
|
-
this.#startIcon_accessor_storage = value;
|
|
339
|
-
}
|
|
340
|
-
#endIcon_accessor_storage;
|
|
341
|
-
/** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */
|
|
342
|
-
get endIcon() {
|
|
343
|
-
return this.#endIcon_accessor_storage;
|
|
344
|
-
}
|
|
345
|
-
set endIcon(value) {
|
|
346
|
-
this.#endIcon_accessor_storage = value;
|
|
347
|
-
}
|
|
348
|
-
/**
|
|
349
|
-
* Form type of element.
|
|
350
|
-
* @default 'range'
|
|
351
|
-
*/
|
|
352
|
-
get type() {
|
|
353
|
-
return "range";
|
|
354
|
-
}
|
|
355
|
-
constructor() {
|
|
356
|
-
super();
|
|
357
|
-
this._value = (__runInitializers(this, _instanceExtraInitializers), null);
|
|
358
|
-
this._min = "0";
|
|
359
|
-
this._max = "100";
|
|
360
|
-
this.#startIcon_accessor_storage = __runInitializers(this, _startIcon_initializers, "");
|
|
361
|
-
this.#endIcon_accessor_storage = (__runInitializers(this, _startIcon_extraInitializers), __runInitializers(this, _endIcon_initializers, ""));
|
|
362
|
-
/** Reference to the inner HTMLInputElement with type='range'. */
|
|
363
|
-
this._rangeInput = __runInitializers(this, _endIcon_extraInitializers);
|
|
364
|
-
this.addEventListener?.("keydown", (e) => this._handleKeydown(e));
|
|
365
|
-
}
|
|
366
|
-
willUpdate(changedProperties) {
|
|
367
|
-
super.willUpdate(changedProperties);
|
|
368
|
-
if (changedProperties.has("readOnly")) this.internals.ariaReadOnly = Boolean(this.readOnly).toString();
|
|
369
|
-
this.style?.setProperty("--sbb-slider-value-fraction", this._valueFraction().toString());
|
|
370
|
-
}
|
|
371
|
-
/**
|
|
372
|
-
* The reset value is the attribute value (the setup value). If not present, calculates the default.
|
|
373
|
-
* @internal
|
|
374
|
-
*/
|
|
375
|
-
formResetCallback() {
|
|
376
|
-
this.value = this.getAttribute("value") ?? this._defaultValue();
|
|
377
|
-
}
|
|
378
|
-
/**
|
|
379
|
-
* @internal
|
|
380
|
-
*/
|
|
381
|
-
formStateRestoreCallback(state, _reason) {
|
|
382
|
-
this.value = state;
|
|
383
|
-
}
|
|
384
|
-
/**
|
|
385
|
-
* If no value is provided, default is the middle point between min and max
|
|
386
|
-
* (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value)
|
|
387
|
-
*/
|
|
388
|
-
_defaultValue() {
|
|
389
|
-
return (+this.min + (+this.max - +this.min) / 2).toString();
|
|
390
|
-
}
|
|
391
|
-
_isValidNumber(value) {
|
|
392
|
-
return !!value && !isNaN(Number(value));
|
|
393
|
-
}
|
|
394
|
-
/**
|
|
395
|
-
* Restrains the value between the min and max
|
|
396
|
-
*/
|
|
397
|
-
_boundBetweenMinMax(value) {
|
|
398
|
-
return Math.max(+this.min, Math.min(+this.max, +value)).toString();
|
|
399
|
-
}
|
|
400
|
-
_valueFraction() {
|
|
401
|
-
const value = this.valueAsNumber;
|
|
402
|
-
const min = +this.min;
|
|
403
|
-
const max = +this.max;
|
|
404
|
-
const mathFraction = (value - min) / (max - min);
|
|
405
|
-
return isNaN(mathFraction) ? 0 : Math.max(0, Math.min(1, mathFraction));
|
|
406
|
-
}
|
|
407
|
-
async _handleKeydown(event) {
|
|
408
|
-
if (event.key !== "Tab") event.preventDefault();
|
|
409
|
-
if (this.readOnly) return;
|
|
410
|
-
if (event.key === "Home") this._rangeInput.value = this.min;
|
|
411
|
-
else if (event.key === "End") this._rangeInput.value = this.max;
|
|
412
|
-
else if (event.key === "ArrowLeft" || event.key === "ArrowDown") this._rangeInput.stepDown();
|
|
413
|
-
else if (event.key === "ArrowRight" || event.key === "ArrowUp") this._rangeInput.stepUp();
|
|
414
|
-
else if (event.key === "PageDown") this._rangeInput.stepDown((+this.max - +this.min) / 10);
|
|
415
|
-
else if (event.key === "PageUp") this._rangeInput.stepUp((+this.max - +this.min) / 10);
|
|
416
|
-
else return;
|
|
417
|
-
this._rangeInput.dispatchEvent(new InputEvent("input", {
|
|
418
|
-
bubbles: true,
|
|
419
|
-
cancelable: true,
|
|
420
|
-
composed: true
|
|
421
|
-
}));
|
|
422
|
-
this._rangeInput.dispatchEvent(new Event("change", { bubbles: true }));
|
|
423
|
-
}
|
|
424
|
-
/** Emits the change event. */
|
|
425
|
-
_dispatchChangeEvent() {
|
|
426
|
-
/**
|
|
427
|
-
* The change event is fired when the user modifies the element's value.
|
|
428
|
-
* Unlike the input event, the change event is not necessarily fired
|
|
429
|
-
* for each alteration to an element's value.
|
|
430
|
-
*/
|
|
431
|
-
this.dispatchEvent(new Event("change", { bubbles: true }));
|
|
432
|
-
/**
|
|
433
|
-
* Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.
|
|
434
|
-
* @deprecated
|
|
435
|
-
*/
|
|
436
|
-
this.dispatchEvent(new Event("didChange", { bubbles: true }));
|
|
437
|
-
}
|
|
438
|
-
render() {
|
|
439
|
-
return html`
|
|
440
|
-
<div class="sbb-slider__height-container">
|
|
441
|
-
<div class="sbb-slider__wrapper">
|
|
442
|
-
<slot name="prefix">
|
|
443
|
-
${this.startIcon ? html`<sbb-icon name="${this.startIcon}"></sbb-icon>` : nothing}
|
|
444
|
-
</slot>
|
|
445
|
-
<div class="sbb-slider__container">
|
|
446
|
-
<input
|
|
447
|
-
tabindex="-1"
|
|
448
|
-
min=${this.min}
|
|
449
|
-
max=${this.max}
|
|
450
|
-
?disabled=${this.disabled || this.formDisabled || this.readOnly}
|
|
451
|
-
value=${this.value || nothing}
|
|
452
|
-
class="sbb-slider__range-input"
|
|
453
|
-
type="range"
|
|
454
|
-
@change=${() => this._dispatchChangeEvent()}
|
|
455
|
-
@input=${() => this.value = this._rangeInput.value}
|
|
456
|
-
${ref((input) => this._rangeInput = input)}
|
|
457
|
-
/>
|
|
458
|
-
<div class="sbb-slider__line">
|
|
459
|
-
<div class="sbb-slider__selected-line"></div>
|
|
460
|
-
</div>
|
|
461
|
-
<div class="sbb-slider__knob"></div>
|
|
462
|
-
</div>
|
|
463
|
-
<slot name="suffix">
|
|
464
|
-
${this.endIcon ? html`<sbb-icon name="${this.endIcon}"></sbb-icon>` : nothing}
|
|
465
|
-
</slot>
|
|
466
|
-
</div>
|
|
467
|
-
</div>
|
|
468
|
-
`;
|
|
469
|
-
}
|
|
470
|
-
static {
|
|
471
|
-
__runInitializers(_classThis, _classExtraInitializers);
|
|
472
|
-
}
|
|
473
|
-
};
|
|
474
|
-
return _classThis;
|
|
475
|
-
})();
|
|
476
|
-
//#endregion
|
|
477
|
-
export { SbbSliderElement as t };
|
|
478
|
-
|
|
479
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"slider.component-w_WtVNx-.js","names":[],"sources":["../../../src/elements/slider/slider.scss?lit&inline","../../../src/elements/slider/slider.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n  display: inline-block;\n  min-width: #{sbb.px-to-rem-build(150)};\n  width: min(#{sbb.px-to-rem-build(400)}, 100%);\n\n  --sbb-slider-line-height: #{sbb.px-to-rem-build(4)};\n  --sbb-slider-value-fraction: 0;\n  --sbb-slider-knob-size: #{sbb.px-to-rem-build(28)};\n  --sbb-slider-knob-size-active: #{sbb.px-to-rem-build(31)};\n  --sbb-slider-knob-border-size: #{sbb.px-to-rem-build(3)};\n  --sbb-slider-knob-border-style: solid;\n  --sbb-slider-knob-color: var(--sbb-background-color-1);\n  --sbb-slider-knob-border-color: var(--sbb-color-primary);\n  --sbb-slider-icon-color: var(--sbb-color-1);\n  --sbb-slider-selected-line-color: var(--sbb-color-primary);\n  --sbb-slider-selected-line-disabled-color: light-dark(\n    var(--sbb-color-smoke),\n    var(--sbb-color-cement)\n  );\n  --sbb-slider-line-color: var(--sbb-border-color-5);\n  --sbb-slider-line-disabled-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));\n\n  @include sbb.if-forced-colors {\n    --sbb-slider-selected-line-color: Highlight;\n    --sbb-slider-line-color: CanvasText;\n  }\n}\n\n:host(:disabled) {\n  --sbb-slider-icon-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));\n  --sbb-slider-knob-border-color: var(--sbb-border-color-5);\n  --sbb-slider-knob-border-size: var(--sbb-border-width-2x);\n  --sbb-slider-knob-border-style: dashed;\n}\n\n:host([readonly]) {\n  --sbb-slider-icon-color: var(--sbb-color-5);\n  --sbb-slider-knob-border-color: var(--sbb-slider-selected-line-disabled-color);\n}\n\n:host(:disabled),\n:host([readonly]) {\n  --sbb-slider-line-color: var(--sbb-slider-line-disabled-color);\n  --sbb-slider-selected-line-color: var(--sbb-slider-selected-line-disabled-color);\n\n  @include sbb.if-forced-colors {\n    --sbb-slider-icon-color: GrayText;\n    --sbb-slider-selected-line-disabled-color: GrayText;\n    --sbb-slider-line-disabled-color: GrayText;\n  }\n}\n\n.sbb-slider__height-container {\n  display: flex;\n  flex-direction: column;\n\n  @include sbb.zero-width-space;\n}\n\n.sbb-slider__wrapper {\n  display: flex;\n  gap: var(--sbb-spacing-fixed-2x);\n  padding-block: calc(var(--sbb-spacing-fixed-1x) / 2);\n  color: var(--sbb-slider-icon-color);\n}\n\n.sbb-slider__container {\n  position: relative;\n  min-height: var(--sbb-size-icon-ui-small);\n  flex-grow: 1;\n}\n\n.sbb-slider__range-input {\n  position: absolute;\n  width: 100%;\n  inset: 0;\n  opacity: 0;\n  margin: 0;\n}\n\n.sbb-slider__line {\n  @include sbb.absolute-center-y;\n\n  height: var(--sbb-slider-line-height);\n  width: 100%;\n  background-color: var(--sbb-slider-line-color);\n  border-radius: var(--sbb-slider-line-height);\n  overflow: hidden;\n  pointer-events: none;\n}\n\n.sbb-slider__selected-line {\n  position: relative;\n  height: 100%;\n  background-color: var(--sbb-slider-selected-line-color);\n  width: calc(var(--sbb-slider-value-fraction) * 100%);\n}\n\n.sbb-slider__knob {\n  @include sbb.absolute-center-y;\n\n  box-shadow: var(--sbb-box-shadow-level-5-hard);\n  width: var(--sbb-slider-knob-size);\n  height: var(--sbb-slider-knob-size);\n  inset-inline-start: calc(\n    calc(var(--sbb-slider-value-fraction) * 100%) - var(--sbb-slider-knob-size) *\n      var(--sbb-slider-value-fraction)\n  );\n  transition-property: width, height;\n  transition-duration: var(--sbb-disable-animation-duration, var(--sbb-animation-duration-1x));\n  transition-timing-function: ease-in;\n  background-color: var(--sbb-slider-knob-color);\n  border: var(--sbb-slider-knob-border-size) var(--sbb-slider-knob-border-style)\n    var(--sbb-slider-knob-border-color);\n  border-radius: 50%;\n  pointer-events: none;\n\n  :host(:focus-visible) & {\n    @include sbb.focus-outline;\n\n    --sbb-slider-knob-size: var(--sbb-slider-knob-size-active);\n  }\n\n  // slider knob resize on click (active / focus)\n  :host(:not(:is(:disabled, [readonly]))) .sbb-slider__range-input:active ~ & {\n    --sbb-slider-knob-size: var(--sbb-slider-knob-size-active);\n  }\n}\n","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbElement } from '../core/base-elements.ts';\nimport { forceType, hostAttributes } from '../core/decorators.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n  SbbReadonlyMixin,\n} from '../core/mixins.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\n\nimport style from './slider.scss?lit&inline';\n\nimport '../icon.ts';\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 {InputEvent} input - The input event fires when the value has been changed as a direct result of a user action.\n */\nexport\n@hostAttributes({\n  tabindex: '0',\n})\nclass SbbSliderElement extends SbbDisabledMixin(\n  SbbReadonlyMixin(SbbFormAssociatedMixin(SbbElement)),\n) {\n  public static override readonly elementName: string = 'sbb-slider';\n  public static override readonly role = 'slider';\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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 set value(value: string | null) {\n    if (this._isValidNumber(value)) {\n      this._value = this._boundBetweenMinMax(value);\n    } else {\n      this._value = null;\n    }\n    this.internals.ariaValueNow = this.value;\n  }\n  public get value(): string {\n    return this._value ?? this._defaultValue();\n  }\n  private _value: string | null = null;\n\n  /** Numeric value for the inner HTMLInputElement. */\n  @property({ attribute: 'value-as-number', type: Number })\n  public set valueAsNumber(value: number | null) {\n    this.value = value?.toString() ?? null;\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.internals.ariaValueMin = this.min;\n    const boundValue = this._boundBetweenMinMax(this.value);\n    if (this.value !== boundValue) {\n      this.value = boundValue;\n    }\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.internals.ariaValueMax = this.max;\n    const boundValue = this._boundBetweenMinMax(this.value);\n    if (this.value !== boundValue) {\n      this.value = boundValue;\n    }\n  }\n  public get max(): string {\n    return this._max;\n  }\n  private _max: string = '100';\n\n  /** Name of the icon at component's start, which will be forward to the nested `sbb-icon`. */\n  @forceType()\n  @property({ attribute: 'start-icon' })\n  public accessor startIcon: string = '';\n\n  /** Name of the icon at component's end, which will be forward to the nested `sbb-icon`. */\n  @forceType()\n  @property({ attribute: 'end-icon' })\n  public accessor endIcon: string = '';\n\n  /**\n   * Form type of element.\n   * @default 'range'\n   */\n  public override get type(): string {\n    return 'range';\n  }\n\n  /** Reference to the inner HTMLInputElement with type='range'. */\n  private _rangeInput!: HTMLInputElement;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeydown(e));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('readOnly')) {\n      this.internals.ariaReadOnly = Boolean(this.readOnly).toString();\n    }\n    this.style?.setProperty('--sbb-slider-value-fraction', this._valueFraction().toString());\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._defaultValue();\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 _defaultValue(): string {\n    return (+this.min + (+this.max - +this.min) / 2).toString();\n  }\n\n  private _isValidNumber(value: string | null): value is string {\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 _valueFraction(): number {\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    return 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 _dispatchChangeEvent(): void {\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n\n    /**\n     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\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 class=\"sbb-slider__container\">\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=${() => this._dispatchChangeEvent()}\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"],"mappings":"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"}
|