@geoffcox/sterling-svelte 0.0.16 → 0.0.18
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/{buttons/Button.svelte → Button.svelte} +27 -27
- package/{inputs/Checkbox.svelte → Checkbox.svelte} +26 -21
- package/{inputs/Checkbox.svelte.d.ts → Checkbox.svelte.d.ts} +2 -1
- package/{surfaces/Dialog.svelte → Dialog.svelte} +34 -21
- package/Field.svelte +257 -0
- package/Field.svelte.d.ts +63 -0
- package/Field.types.d.ts +1 -0
- package/Input.svelte +115 -0
- package/{inputs/Input.svelte.d.ts → Input.svelte.d.ts} +8 -3
- package/Label.svelte +51 -0
- package/Label.svelte.d.ts +41 -0
- package/List.constants.d.ts +1 -0
- package/List.constants.js +1 -0
- package/List.svelte +293 -0
- package/List.svelte.d.ts +63 -0
- package/List.types.d.ts +6 -0
- package/ListItem.svelte +89 -0
- package/ListItem.svelte.d.ts +51 -0
- package/{containers/Menu.svelte → Menu.svelte} +42 -27
- package/{containers/MenuBar.svelte → MenuBar.svelte} +13 -13
- package/{buttons/MenuButton.svelte → MenuButton.svelte} +17 -17
- package/{buttons/MenuButton.svelte.d.ts → MenuButton.svelte.d.ts} +1 -1
- package/{containers/MenuItem.svelte → MenuItem.svelte} +42 -54
- package/{containers/MenuItem.svelte.d.ts → MenuItem.svelte.d.ts} +2 -2
- package/{containers/MenuSeparator.svelte → MenuSeparator.svelte} +2 -2
- package/Menus.types.d.ts +22 -0
- package/{containers/Menus.utils.d.ts → Menus.utils.d.ts} +2 -2
- package/{containers/Menus.utils.js → Menus.utils.js} +6 -6
- package/{display/Progress.svelte → Progress.svelte} +28 -52
- package/{display/Progress.svelte.d.ts → Progress.svelte.d.ts} +1 -3
- package/Progress.types.d.ts +1 -0
- package/{inputs/Radio.svelte → Radio.svelte} +34 -29
- package/{inputs/Radio.svelte.d.ts → Radio.svelte.d.ts} +7 -2
- package/{inputs/Select.svelte → Select.svelte} +112 -130
- package/Select.svelte.d.ts +53 -0
- package/{inputs/Slider.svelte → Slider.svelte} +90 -86
- package/Slider.svelte.d.ts +51 -0
- package/{inputs/Switch.svelte → Switch.svelte} +43 -41
- package/Tab.svelte +181 -0
- package/{containers/Tab.svelte.d.ts → Tab.svelte.d.ts} +12 -15
- package/TabList.svelte +247 -0
- package/{containers/TabList.svelte.d.ts → TabList.svelte.d.ts} +21 -21
- package/TabList.types.d.ts +7 -0
- package/TextArea.svelte +113 -0
- package/{inputs/TextArea.svelte.d.ts → TextArea.svelte.d.ts} +3 -6
- package/TextArea.types.js +1 -0
- package/Tooltip.svelte +182 -0
- package/Tooltip.svelte.d.ts +24 -0
- package/Tooltip.types.d.ts +3 -0
- package/Tooltip.types.js +1 -0
- package/Tree.constants.d.ts +2 -0
- package/Tree.constants.js +2 -0
- package/Tree.svelte +114 -0
- package/Tree.svelte.d.ts +24 -0
- package/Tree.types.d.ts +28 -0
- package/Tree.types.js +1 -0
- package/{containers/TreeChevron.svelte → TreeChevron.svelte} +3 -3
- package/TreeItem.svelte +276 -0
- package/TreeItem.svelte.d.ts +65 -0
- package/{containers/TreeItem.svelte → TreeItemDisplay.svelte} +18 -18
- package/{containers/TreeItem.svelte.d.ts → TreeItemDisplay.svelte.d.ts} +11 -14
- package/{forwardEvents.js → actions/forwardEvents.js} +0 -2
- package/index.d.ts +44 -31
- package/index.js +40 -25
- package/package.json +45 -41
- package/theme/darkTheme.js +73 -74
- package/theme/lightTheme.js +76 -77
- package/containers/List.svelte +0 -249
- package/containers/List.svelte.d.ts +0 -68
- package/containers/ListItem.svelte +0 -48
- package/containers/ListItem.svelte.d.ts +0 -26
- package/containers/Menus.types.d.ts +0 -22
- package/containers/Tab.svelte +0 -327
- package/containers/TabList.svelte +0 -126
- package/containers/Tabs.types.d.ts +0 -12
- package/containers/Tree.constants.d.ts +0 -2
- package/containers/Tree.constants.js +0 -2
- package/containers/Tree.svelte +0 -222
- package/containers/Tree.svelte.d.ts +0 -50
- package/containers/Tree.types.d.ts +0 -47
- package/containers/TreeNode.svelte +0 -266
- package/containers/TreeNode.svelte.d.ts +0 -43
- package/display/Label.svelte +0 -27
- package/display/Label.svelte.d.ts +0 -20
- package/display/Progress.types.d.ts +0 -1
- package/inputs/Input.svelte +0 -129
- package/inputs/Select.svelte.d.ts +0 -62
- package/inputs/Slider.svelte.d.ts +0 -28
- package/inputs/TextArea.svelte +0 -154
- package/surfaces/CloseX.svelte +0 -5
- package/surfaces/CloseX.svelte.d.ts +0 -23
- package/surfaces/Portal.svelte +0 -14
- package/surfaces/Portal.svelte.d.ts +0 -21
- /package/{buttons/Button.svelte.d.ts → Button.svelte.d.ts} +0 -0
- /package/{buttons/Button.types.d.ts → Button.types.d.ts} +0 -0
- /package/{buttons/Button.types.js → Button.types.js} +0 -0
- /package/{surfaces/Dialog.svelte.d.ts → Dialog.svelte.d.ts} +0 -0
- /package/{containers/Menus.types.js → Field.types.js} +0 -0
- /package/{containers/Tabs.types.js → List.types.js} +0 -0
- /package/{containers/Menu.svelte.d.ts → Menu.svelte.d.ts} +0 -0
- /package/{containers/MenuBar.svelte.d.ts → MenuBar.svelte.d.ts} +0 -0
- /package/{containers/MenuItemDisplay.svelte → MenuItemDisplay.svelte} +0 -0
- /package/{containers/MenuItemDisplay.svelte.d.ts → MenuItemDisplay.svelte.d.ts} +0 -0
- /package/{containers/MenuSeparator.svelte.d.ts → MenuSeparator.svelte.d.ts} +0 -0
- /package/{containers/Menus.constants.d.ts → Menus.constants.d.ts} +0 -0
- /package/{containers/Menus.constants.js → Menus.constants.js} +0 -0
- /package/{containers/Tree.types.js → Menus.types.js} +0 -0
- /package/{display/Progress.types.js → Progress.types.js} +0 -0
- /package/{inputs/Switch.svelte.d.ts → Switch.svelte.d.ts} +0 -0
- /package/{containers/Tabs.constants.d.ts → TabList.constants.d.ts} +0 -0
- /package/{containers/Tabs.constants.js → TabList.constants.js} +0 -0
- /package/{inputs/TextArea.types.js → TabList.types.js} +0 -0
- /package/{inputs/TextArea.types.d.ts → TextArea.types.d.ts} +0 -0
- /package/{containers/TreeChevron.svelte.d.ts → TreeChevron.svelte.d.ts} +0 -0
- /package/{clickOutside.d.ts → actions/clickOutside.d.ts} +0 -0
- /package/{clickOutside.js → actions/clickOutside.js} +0 -0
- /package/{forwardEvents.d.ts → actions/forwardEvents.d.ts} +0 -0
- /package/{portal.d.ts → actions/portal.d.ts} +0 -0
- /package/{portal.js → actions/portal.js} +0 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { SvelteComponentTyped } from "svelte";
|
|
2
|
+
declare const __propDef: {
|
|
3
|
+
props: {
|
|
4
|
+
[x: string]: any;
|
|
5
|
+
composed?: boolean | undefined;
|
|
6
|
+
disabled?: boolean | undefined;
|
|
7
|
+
open?: boolean | undefined;
|
|
8
|
+
selectedValue?: string | undefined;
|
|
9
|
+
};
|
|
10
|
+
events: {
|
|
11
|
+
blur: FocusEvent;
|
|
12
|
+
click: MouseEvent;
|
|
13
|
+
copy: ClipboardEvent;
|
|
14
|
+
cut: ClipboardEvent;
|
|
15
|
+
dblclick: MouseEvent;
|
|
16
|
+
focus: FocusEvent;
|
|
17
|
+
focusin: FocusEvent;
|
|
18
|
+
focusout: FocusEvent;
|
|
19
|
+
keydown: KeyboardEvent;
|
|
20
|
+
keypress: KeyboardEvent;
|
|
21
|
+
keyup: KeyboardEvent;
|
|
22
|
+
mousedown: MouseEvent;
|
|
23
|
+
mouseenter: MouseEvent;
|
|
24
|
+
mouseleave: MouseEvent;
|
|
25
|
+
mousemove: MouseEvent;
|
|
26
|
+
mouseover: MouseEvent;
|
|
27
|
+
mouseout: MouseEvent;
|
|
28
|
+
mouseup: MouseEvent;
|
|
29
|
+
wheel: WheelEvent;
|
|
30
|
+
paste: ClipboardEvent;
|
|
31
|
+
select: CustomEvent<any>;
|
|
32
|
+
pending: CustomEvent<any>;
|
|
33
|
+
} & {
|
|
34
|
+
[evt: string]: CustomEvent<any>;
|
|
35
|
+
};
|
|
36
|
+
slots: {
|
|
37
|
+
value: {
|
|
38
|
+
disabled: boolean;
|
|
39
|
+
open: boolean;
|
|
40
|
+
selectedValue: string | undefined;
|
|
41
|
+
};
|
|
42
|
+
button: {
|
|
43
|
+
open: boolean;
|
|
44
|
+
};
|
|
45
|
+
default: {};
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
export type SelectProps = typeof __propDef.props;
|
|
49
|
+
export type SelectEvents = typeof __propDef.events;
|
|
50
|
+
export type SelectSlots = typeof __propDef.slots;
|
|
51
|
+
export default class Select extends SvelteComponentTyped<SelectProps, SelectEvents, SelectSlots> {
|
|
52
|
+
}
|
|
53
|
+
export {};
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
<script>import { createEventDispatcher } from "svelte";
|
|
2
2
|
import { round } from "lodash-es";
|
|
3
|
-
import { v4 as uuid } from "uuid";
|
|
4
|
-
import Label from "../display/Label.svelte";
|
|
5
3
|
export let value = 0;
|
|
6
4
|
export let min = 0;
|
|
7
5
|
export let max = 100;
|
|
@@ -9,7 +7,6 @@ export let step = void 0;
|
|
|
9
7
|
export let precision = 0;
|
|
10
8
|
export let vertical = false;
|
|
11
9
|
export let disabled = false;
|
|
12
|
-
const inputId = uuid();
|
|
13
10
|
let sliderRef;
|
|
14
11
|
const dispatch = createEventDispatcher();
|
|
15
12
|
const raiseChange = (newValue) => {
|
|
@@ -124,59 +121,62 @@ const onKeyDown = (event) => {
|
|
|
124
121
|
<!-- @component
|
|
125
122
|
Slider lets the user chose a value within a min/max range by dragging a thumb button.
|
|
126
123
|
-->
|
|
127
|
-
<div
|
|
128
|
-
{
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
124
|
+
<div
|
|
125
|
+
aria-disabled={disabled}
|
|
126
|
+
aria-valuemin={0}
|
|
127
|
+
aria-valuenow={value}
|
|
128
|
+
aria-valuemax={max}
|
|
129
|
+
class="sterling-slider"
|
|
130
|
+
class:disabled
|
|
131
|
+
class:horizontal={!vertical}
|
|
132
|
+
class:vertical
|
|
133
|
+
role="slider"
|
|
134
|
+
tabindex={!disabled ? 0 : undefined}
|
|
135
|
+
on:blur
|
|
136
|
+
on:click
|
|
137
|
+
on:dblclick
|
|
138
|
+
on:focus
|
|
139
|
+
on:focusin
|
|
140
|
+
on:focusout
|
|
141
|
+
on:keydown
|
|
142
|
+
on:keydown={onKeyDown}
|
|
143
|
+
on:keypress
|
|
144
|
+
on:keyup
|
|
145
|
+
on:mousedown
|
|
146
|
+
on:mouseenter
|
|
147
|
+
on:mouseleave
|
|
148
|
+
on:mousemove
|
|
149
|
+
on:mouseover
|
|
150
|
+
on:mouseout
|
|
151
|
+
on:mouseup
|
|
152
|
+
on:pointercancel
|
|
153
|
+
on:pointerdown
|
|
154
|
+
on:pointerdown={onPointerDown}
|
|
155
|
+
on:pointerenter
|
|
156
|
+
on:pointerleave
|
|
157
|
+
on:pointermove
|
|
158
|
+
on:pointermove={onPointerMove}
|
|
159
|
+
on:pointerover
|
|
160
|
+
on:pointerout
|
|
161
|
+
on:pointerup
|
|
162
|
+
on:pointerup={onPointerUp}
|
|
163
|
+
on:wheel
|
|
164
|
+
{...$$restProps}
|
|
165
|
+
>
|
|
133
166
|
<div
|
|
134
|
-
class="
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
id={inputId}
|
|
139
|
-
role="slider"
|
|
140
|
-
aria-valuemin={0}
|
|
141
|
-
aria-valuenow={value}
|
|
142
|
-
aria-valuemax={max}
|
|
143
|
-
tabindex={!disabled ? 0 : undefined}
|
|
144
|
-
{...$$restProps}
|
|
145
|
-
on:keydown={onKeyDown}
|
|
146
|
-
on:pointerdown={onPointerDown}
|
|
147
|
-
on:pointermove={onPointerMove}
|
|
148
|
-
on:pointerup={onPointerUp}
|
|
167
|
+
class="container"
|
|
168
|
+
bind:this={sliderRef}
|
|
169
|
+
bind:clientWidth={sliderWidth}
|
|
170
|
+
bind:clientHeight={sliderHeight}
|
|
149
171
|
>
|
|
150
|
-
<div
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
bind:clientWidth={sliderWidth}
|
|
154
|
-
bind:clientHeight={sliderHeight}
|
|
155
|
-
>
|
|
156
|
-
<div class="track" />
|
|
157
|
-
<div class="fill" style={vertical ? `height: ${valueOffset}px` : `width: ${valueOffset}px`} />
|
|
158
|
-
<div class="thumb" style={vertical ? `bottom: ${valueOffset}px` : `left: ${valueOffset}px`} />
|
|
159
|
-
</div>
|
|
172
|
+
<div class="track" />
|
|
173
|
+
<div class="fill" style={vertical ? `height: ${valueOffset}px` : `width: ${valueOffset}px`} />
|
|
174
|
+
<div class="thumb" style={vertical ? `bottom: ${valueOffset}px` : `left: ${valueOffset}px`} />
|
|
160
175
|
</div>
|
|
161
176
|
</div>
|
|
162
177
|
|
|
163
178
|
<style>
|
|
164
179
|
.sterling-slider {
|
|
165
|
-
display: grid;
|
|
166
|
-
grid-template-columns: 1fr;
|
|
167
|
-
grid-template-rows: auto 1fr;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
.sterling-slider.vertical {
|
|
171
|
-
justify-items: center;
|
|
172
|
-
height: 100%;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
.sterling-slider > :global(label) {
|
|
176
|
-
font-size: 0.7em;
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
.slider {
|
|
180
180
|
box-sizing: border-box;
|
|
181
181
|
outline: none;
|
|
182
182
|
padding: 0;
|
|
@@ -185,30 +185,34 @@ Slider lets the user chose a value within a min/max range by dragging a thumb bu
|
|
|
185
185
|
transition: background-color 250ms, color 250ms, border-color 250ms;
|
|
186
186
|
}
|
|
187
187
|
|
|
188
|
+
.sterling-slider.vertical {
|
|
189
|
+
height: 100%;
|
|
190
|
+
}
|
|
191
|
+
|
|
188
192
|
.container {
|
|
189
193
|
position: relative;
|
|
190
194
|
}
|
|
191
195
|
|
|
192
196
|
.track {
|
|
193
197
|
position: absolute;
|
|
194
|
-
background: var(--Display__background-color);
|
|
198
|
+
background: var(--stsv-Display__background-color);
|
|
195
199
|
transition: background-color 250ms, color 250ms, border-color 250ms;
|
|
196
200
|
}
|
|
197
201
|
|
|
198
202
|
.fill {
|
|
199
|
-
background: var(--Display__color);
|
|
203
|
+
background: var(--stsv-Display__color);
|
|
200
204
|
position: absolute;
|
|
201
205
|
transition: background-color 250ms, color 250ms, border-color 250ms;
|
|
202
206
|
}
|
|
203
207
|
|
|
204
208
|
.thumb {
|
|
205
|
-
background-color: var(--Button__background-color);
|
|
206
|
-
border-color: var(--Button__border-color);
|
|
209
|
+
background-color: var(--stsv-Button__background-color);
|
|
210
|
+
border-color: var(--stsv-Button__border-color);
|
|
207
211
|
border-radius: 10000px;
|
|
208
|
-
border-style: var(--Button__border-style);
|
|
209
|
-
border-width: var(--Button__border-width);
|
|
212
|
+
border-style: var(--stsv-Button__border-style);
|
|
213
|
+
border-width: var(--stsv-Button__border-width);
|
|
210
214
|
box-sizing: border-box;
|
|
211
|
-
color: var(--Button__color);
|
|
215
|
+
color: var(--stsv-Button__color);
|
|
212
216
|
cursor: pointer;
|
|
213
217
|
display: block;
|
|
214
218
|
font: inherit;
|
|
@@ -224,15 +228,15 @@ Slider lets the user chose a value within a min/max range by dragging a thumb bu
|
|
|
224
228
|
|
|
225
229
|
/* ----- horizontal ----- */
|
|
226
230
|
|
|
227
|
-
.slider.horizontal {
|
|
231
|
+
.sterling-slider.horizontal {
|
|
228
232
|
height: 2em;
|
|
229
233
|
}
|
|
230
234
|
|
|
231
|
-
.slider.horizontal .container {
|
|
235
|
+
.sterling-slider.horizontal .container {
|
|
232
236
|
margin: 0 0.75em;
|
|
233
237
|
}
|
|
234
238
|
|
|
235
|
-
.slider.horizontal .track {
|
|
239
|
+
.sterling-slider.horizontal .track {
|
|
236
240
|
left: 0;
|
|
237
241
|
right: 0;
|
|
238
242
|
top: 50%;
|
|
@@ -240,27 +244,27 @@ Slider lets the user chose a value within a min/max range by dragging a thumb bu
|
|
|
240
244
|
transform: translate(0, -50%);
|
|
241
245
|
}
|
|
242
246
|
|
|
243
|
-
.slider.horizontal .fill {
|
|
247
|
+
.sterling-slider.horizontal .fill {
|
|
244
248
|
height: 3px;
|
|
245
249
|
top: 50%;
|
|
246
250
|
transform: translate(0, -50%);
|
|
247
251
|
}
|
|
248
252
|
|
|
249
|
-
.slider.horizontal .thumb {
|
|
253
|
+
.sterling-slider.horizontal .thumb {
|
|
250
254
|
top: 50%;
|
|
251
255
|
transform: translate(-50%, -50%);
|
|
252
256
|
}
|
|
253
257
|
|
|
254
258
|
/* ----- vertical ----- */
|
|
255
259
|
|
|
256
|
-
.slider.vertical {
|
|
260
|
+
.sterling-slider.vertical {
|
|
257
261
|
width: 2em;
|
|
258
262
|
}
|
|
259
|
-
.slider.vertical .container {
|
|
263
|
+
.sterling-slider.vertical .container {
|
|
260
264
|
margin: 0.75em 0;
|
|
261
265
|
}
|
|
262
266
|
|
|
263
|
-
.slider.vertical .track {
|
|
267
|
+
.sterling-slider.vertical .track {
|
|
264
268
|
bottom: 0;
|
|
265
269
|
left: 50%;
|
|
266
270
|
top: 0;
|
|
@@ -268,14 +272,14 @@ Slider lets the user chose a value within a min/max range by dragging a thumb bu
|
|
|
268
272
|
width: 3px;
|
|
269
273
|
}
|
|
270
274
|
|
|
271
|
-
.slider.vertical .fill {
|
|
275
|
+
.sterling-slider.vertical .fill {
|
|
272
276
|
bottom: 0;
|
|
273
277
|
left: 50%;
|
|
274
278
|
transform: translate(-50%, 0);
|
|
275
279
|
width: 3px;
|
|
276
280
|
}
|
|
277
281
|
|
|
278
|
-
.slider.vertical .thumb {
|
|
282
|
+
.sterling-slider.vertical .thumb {
|
|
279
283
|
left: 50%;
|
|
280
284
|
transform: translate(-50%, 50%);
|
|
281
285
|
}
|
|
@@ -283,45 +287,45 @@ Slider lets the user chose a value within a min/max range by dragging a thumb bu
|
|
|
283
287
|
/* ----- hover ----- */
|
|
284
288
|
|
|
285
289
|
.thumb:hover {
|
|
286
|
-
background-color: var(--Button__background-color--hover);
|
|
287
|
-
border-color: var(--Button__border-color--hover);
|
|
288
|
-
color: var(--Button__color--hover);
|
|
290
|
+
background-color: var(--stsv-Button__background-color--hover);
|
|
291
|
+
border-color: var(--stsv-Button__border-color--hover);
|
|
292
|
+
color: var(--stsv-Button__color--hover);
|
|
289
293
|
}
|
|
290
294
|
|
|
291
295
|
/* ----- active ----- */
|
|
292
296
|
|
|
293
297
|
.thumb:active {
|
|
294
|
-
background-color: var(--Button__background-color--active);
|
|
295
|
-
border-color: var(--Button__border-color--active);
|
|
296
|
-
color: var(--Button__color--active);
|
|
298
|
+
background-color: var(--stsv-Button__background-color--active);
|
|
299
|
+
border-color: var(--stsv-Button__border-color--active);
|
|
300
|
+
color: var(--stsv-Button__color--active);
|
|
297
301
|
}
|
|
298
302
|
|
|
299
303
|
/* ----- focus ----- */
|
|
300
|
-
.slider:focus-visible {
|
|
301
|
-
outline-color: var(--Common__outline-color);
|
|
302
|
-
outline-offset: var(--Common__outline-offset);
|
|
303
|
-
outline-style: var(--Common__outline-style);
|
|
304
|
-
outline-width: var(--Common__outline-width);
|
|
304
|
+
.sterling-slider:focus-visible {
|
|
305
|
+
outline-color: var(--stsv-Common__outline-color);
|
|
306
|
+
outline-offset: var(--stsv-Common__outline-offset);
|
|
307
|
+
outline-style: var(--stsv-Common__outline-style);
|
|
308
|
+
outline-width: var(--stsv-Common__outline-width);
|
|
305
309
|
}
|
|
306
310
|
/* ----- disabled ----- */
|
|
307
311
|
|
|
308
|
-
.slider.disabled .track {
|
|
309
|
-
background: var(--Common__background-color--disabled);
|
|
312
|
+
.sterling-slider.disabled .track {
|
|
313
|
+
background: var(--stsv-Common__background-color--disabled);
|
|
310
314
|
}
|
|
311
315
|
|
|
312
|
-
.slider.disabled .fill {
|
|
313
|
-
background: var(--Common__color--disabled);
|
|
316
|
+
.sterling-slider.disabled .fill {
|
|
317
|
+
background: var(--stsv-Common__color--disabled);
|
|
314
318
|
}
|
|
315
319
|
|
|
316
|
-
.slider.disabled .thumb {
|
|
317
|
-
background-color: var(--Common__background-color--disabled);
|
|
318
|
-
border-color: var(--Common__border-color--disabled);
|
|
319
|
-
color: var(--Common__color--disabled);
|
|
320
|
+
.sterling-slider.disabled .thumb {
|
|
321
|
+
background-color: var(--stsv-Common__background-color--disabled);
|
|
322
|
+
border-color: var(--stsv-Common__border-color--disabled);
|
|
323
|
+
color: var(--stsv-Common__color--disabled);
|
|
320
324
|
cursor: not-allowed;
|
|
321
325
|
}
|
|
322
326
|
|
|
323
327
|
@media (prefers-reduced-motion) {
|
|
324
|
-
.slider,
|
|
328
|
+
.sterling-slider,
|
|
325
329
|
.track,
|
|
326
330
|
.fill,
|
|
327
331
|
.thumb {
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { SvelteComponentTyped } from "svelte";
|
|
2
|
+
declare const __propDef: {
|
|
3
|
+
props: {
|
|
4
|
+
[x: string]: any;
|
|
5
|
+
value?: number | undefined;
|
|
6
|
+
min?: number | undefined;
|
|
7
|
+
max?: number | undefined;
|
|
8
|
+
step?: number | undefined;
|
|
9
|
+
precision?: number | undefined;
|
|
10
|
+
vertical?: boolean | undefined;
|
|
11
|
+
disabled?: boolean | undefined;
|
|
12
|
+
};
|
|
13
|
+
events: {
|
|
14
|
+
blur: FocusEvent;
|
|
15
|
+
click: MouseEvent;
|
|
16
|
+
dblclick: MouseEvent;
|
|
17
|
+
focus: FocusEvent;
|
|
18
|
+
focusin: FocusEvent;
|
|
19
|
+
focusout: FocusEvent;
|
|
20
|
+
keydown: KeyboardEvent;
|
|
21
|
+
keypress: KeyboardEvent;
|
|
22
|
+
keyup: KeyboardEvent;
|
|
23
|
+
mousedown: MouseEvent;
|
|
24
|
+
mouseenter: MouseEvent;
|
|
25
|
+
mouseleave: MouseEvent;
|
|
26
|
+
mousemove: MouseEvent;
|
|
27
|
+
mouseover: MouseEvent;
|
|
28
|
+
mouseout: MouseEvent;
|
|
29
|
+
mouseup: MouseEvent;
|
|
30
|
+
pointercancel: PointerEvent;
|
|
31
|
+
pointerdown: PointerEvent;
|
|
32
|
+
pointerenter: PointerEvent;
|
|
33
|
+
pointerleave: PointerEvent;
|
|
34
|
+
pointermove: PointerEvent;
|
|
35
|
+
pointerover: PointerEvent;
|
|
36
|
+
pointerout: PointerEvent;
|
|
37
|
+
pointerup: PointerEvent;
|
|
38
|
+
wheel: WheelEvent;
|
|
39
|
+
change: CustomEvent<any>;
|
|
40
|
+
} & {
|
|
41
|
+
[evt: string]: CustomEvent<any>;
|
|
42
|
+
};
|
|
43
|
+
slots: {};
|
|
44
|
+
};
|
|
45
|
+
export type SliderProps = typeof __propDef.props;
|
|
46
|
+
export type SliderEvents = typeof __propDef.events;
|
|
47
|
+
export type SliderSlots = typeof __propDef.slots;
|
|
48
|
+
/** Slider lets the user chose a value within a min/max range by dragging a thumb button. */
|
|
49
|
+
export default class Slider extends SvelteComponentTyped<SliderProps, SliderEvents, SliderSlots> {
|
|
50
|
+
}
|
|
51
|
+
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<script>import { v4 as uuid } from "uuid";
|
|
2
|
-
import Label from "
|
|
2
|
+
import Label from "./Label.svelte";
|
|
3
3
|
export let checked = false;
|
|
4
4
|
export let disabled = false;
|
|
5
5
|
export let vertical = false;
|
|
@@ -18,6 +18,8 @@ $:
|
|
|
18
18
|
ratio = vertical ? checked ? 0 : 1 : checked ? 1 : 0;
|
|
19
19
|
$:
|
|
20
20
|
valueOffset = (switchSize - thumbSize) * ratio;
|
|
21
|
+
$:
|
|
22
|
+
console.log({ ratio, valueOffset });
|
|
21
23
|
</script>
|
|
22
24
|
|
|
23
25
|
<!--
|
|
@@ -26,6 +28,9 @@ $:
|
|
|
26
28
|
-->
|
|
27
29
|
<div class="sterling-switch" class:vertical class:disabled>
|
|
28
30
|
<input
|
|
31
|
+
bind:checked
|
|
32
|
+
{disabled}
|
|
33
|
+
id={inputId}
|
|
29
34
|
type="checkbox"
|
|
30
35
|
on:blur
|
|
31
36
|
on:click
|
|
@@ -47,9 +52,6 @@ $:
|
|
|
47
52
|
on:mouseup
|
|
48
53
|
on:toggle
|
|
49
54
|
on:wheel
|
|
50
|
-
bind:checked
|
|
51
|
-
id={inputId}
|
|
52
|
-
{disabled}
|
|
53
55
|
{...$$restProps}
|
|
54
56
|
/>
|
|
55
57
|
<div class="off-label">
|
|
@@ -121,13 +123,13 @@ $:
|
|
|
121
123
|
}
|
|
122
124
|
|
|
123
125
|
.switch {
|
|
124
|
-
background-color: var(--Input__background-color);
|
|
125
|
-
border-color: var(--Input__border-color);
|
|
126
|
+
background-color: var(--stsv-Input__background-color);
|
|
127
|
+
border-color: var(--stsv-Input__border-color);
|
|
126
128
|
border-radius: 10000px;
|
|
127
|
-
border-style: var(--Input__border-style);
|
|
128
|
-
border-width: var(--Input__border-width);
|
|
129
|
+
border-style: var(--stsv-Input__border-style);
|
|
130
|
+
border-width: var(--stsv-Input__border-width);
|
|
129
131
|
box-sizing: border-box;
|
|
130
|
-
color: var(--Input__color);
|
|
132
|
+
color: var(--stsv-Input__color);
|
|
131
133
|
font: inherit;
|
|
132
134
|
pointer-events: none;
|
|
133
135
|
position: relative;
|
|
@@ -136,25 +138,25 @@ $:
|
|
|
136
138
|
}
|
|
137
139
|
|
|
138
140
|
.sterling-switch:hover .switch {
|
|
139
|
-
background-color: var(--Input__background-color--hover);
|
|
140
|
-
border-color: var(--Input__border-color--hover);
|
|
141
|
-
color: var(--Input__color--hover);
|
|
141
|
+
background-color: var(--stsv-Input__background-color--hover);
|
|
142
|
+
border-color: var(--stsv-Input__border-color--hover);
|
|
143
|
+
color: var(--stsv-Input__color--hover);
|
|
142
144
|
}
|
|
143
145
|
|
|
144
146
|
input:focus-visible ~ .switch {
|
|
145
|
-
background-color: var(--Input__background-color--focus);
|
|
146
|
-
border-color: var(--Input__border-color--focus);
|
|
147
|
-
color: var(--Common__color--focux);
|
|
148
|
-
outline-color: var(--Common__outline-color);
|
|
149
|
-
outline-offset: var(--Common__outline-offset);
|
|
150
|
-
outline-style: var(--Common__outline-style);
|
|
151
|
-
outline-width: var(--Common__outline-width);
|
|
147
|
+
background-color: var(--stsv-Input__background-color--focus);
|
|
148
|
+
border-color: var(--stsv-Input__border-color--focus);
|
|
149
|
+
color: var(--stsv-Common__color--focux);
|
|
150
|
+
outline-color: var(--stsv-Common__outline-color);
|
|
151
|
+
outline-offset: var(--stsv-Common__outline-offset);
|
|
152
|
+
outline-style: var(--stsv-Common__outline-style);
|
|
153
|
+
outline-width: var(--stsv-Common__outline-width);
|
|
152
154
|
}
|
|
153
155
|
|
|
154
156
|
.sterling-switch.disabled .switch {
|
|
155
|
-
background-color: var(--
|
|
156
|
-
border-color: var(--
|
|
157
|
-
color: var(--
|
|
157
|
+
background-color: var(--stsv-Common__background-color--disabled);
|
|
158
|
+
border-color: var(--stsv-Common__border-color--disabled);
|
|
159
|
+
color: var(--stsv-Common__color--disabled);
|
|
158
160
|
}
|
|
159
161
|
|
|
160
162
|
.sterling-switch:not(.vertical) .switch {
|
|
@@ -169,17 +171,17 @@ $:
|
|
|
169
171
|
|
|
170
172
|
.off-label,
|
|
171
173
|
.on-label {
|
|
172
|
-
padding-top: var(--Button__border-width);
|
|
174
|
+
padding-top: var(--stsv-Button__border-width);
|
|
173
175
|
}
|
|
174
176
|
|
|
175
177
|
.thumb {
|
|
176
|
-
background-color: var(--Button__background-color);
|
|
177
|
-
border-color: var(--Button__border-color);
|
|
178
|
+
background-color: var(--stsv-Button__background-color);
|
|
179
|
+
border-color: var(--stsv-Button__border-color);
|
|
178
180
|
border-radius: 10000px;
|
|
179
|
-
border-style: var(--Button__border-style);
|
|
180
|
-
border-width: var(--Button__border-width);
|
|
181
|
+
border-style: var(--stsv-Button__border-style);
|
|
182
|
+
border-width: var(--stsv-Button__border-width);
|
|
181
183
|
box-sizing: border-box;
|
|
182
|
-
color: var(--Button__color);
|
|
184
|
+
color: var(--stsv-Button__color);
|
|
183
185
|
cursor: pointer;
|
|
184
186
|
display: block;
|
|
185
187
|
font: inherit;
|
|
@@ -190,30 +192,30 @@ $:
|
|
|
190
192
|
}
|
|
191
193
|
|
|
192
194
|
.sterling-switch:hover .thumb {
|
|
193
|
-
background-color: var(--Button__background-color--hover);
|
|
194
|
-
border-color: var(--Button__border-color--hover);
|
|
195
|
-
color: var(--Button__color--hover);
|
|
195
|
+
background-color: var(--stsv-Button__background-color--hover);
|
|
196
|
+
border-color: var(--stsv-Button__border-color--hover);
|
|
197
|
+
color: var(--stsv-Button__color--hover);
|
|
196
198
|
}
|
|
197
199
|
|
|
198
200
|
.sterling-switch:active .thumb {
|
|
199
|
-
background-color: var(--Button__background-color--active);
|
|
200
|
-
border-color: var(--Button__border-color--active);
|
|
201
|
-
color: var(--Button__color--hover);
|
|
201
|
+
background-color: var(--stsv-Button__background-color--active);
|
|
202
|
+
border-color: var(--stsv-Button__border-color--active);
|
|
203
|
+
color: var(--stsv-Button__color--hover);
|
|
202
204
|
}
|
|
203
205
|
|
|
204
206
|
.sterling-switch.disabled .thumb {
|
|
205
|
-
background-color: var(--
|
|
206
|
-
border-color: var(--
|
|
207
|
-
color: var(--
|
|
207
|
+
background-color: var(--stsv-Common__background-color--disabled);
|
|
208
|
+
border-color: var(--stsv-Common__border-color--disabled);
|
|
209
|
+
color: var(--stsv-Common__color--disabled);
|
|
208
210
|
}
|
|
209
211
|
|
|
210
212
|
.sterling-switch:not(.vertical) .thumb {
|
|
211
|
-
top: calc(-1 * var(--Button__border-width));
|
|
212
|
-
transform: translateX(calc(var(--thumb-offset) - var(--Button__border-width)));
|
|
213
|
+
top: calc(-1 * var(--stsv-Button__border-width));
|
|
214
|
+
transform: translateX(calc(var(--thumb-offset) - var(--stsv-Button__border-width)));
|
|
213
215
|
}
|
|
214
216
|
|
|
215
217
|
.sterling-switch.vertical .thumb {
|
|
216
|
-
left: calc(-1 * var(--Button__border-width));
|
|
217
|
-
transform: translateY(calc(var(--thumb-offset) - var(--Button__border-width)));
|
|
218
|
+
left: calc(-1 * var(--stsv-Button__border-width));
|
|
219
|
+
transform: translateY(calc(var(--thumb-offset) - var(--stsv-Button__border-width)));
|
|
218
220
|
}
|
|
219
221
|
</style>
|