@geoffcox/sterling-svelte 0.0.31 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) hide show
  1. package/@types/clickOutside.d.ts +11 -7
  2. package/Button.svelte +11 -183
  3. package/Button.svelte.d.ts +2 -6
  4. package/Callout.svelte +107 -146
  5. package/Callout.svelte.d.ts +1 -1
  6. package/Checkbox.svelte +15 -177
  7. package/Checkbox.svelte.d.ts +2 -2
  8. package/ColorPicker.svelte +204 -223
  9. package/ColorPicker.svelte.d.ts +1 -2
  10. package/Dialog.svelte +90 -187
  11. package/Dialog.svelte.d.ts +2 -1
  12. package/Dropdown.svelte +52 -220
  13. package/Dropdown.svelte.d.ts +4 -8
  14. package/HexColorSliders.svelte +77 -145
  15. package/HexColorSliders.svelte.d.ts +28 -1
  16. package/HslColorSliders.svelte +99 -179
  17. package/HslColorSliders.svelte.d.ts +28 -1
  18. package/Input.svelte +27 -136
  19. package/Input.svelte.d.ts +2 -3
  20. package/Label.constants.d.ts +1 -0
  21. package/Label.constants.js +1 -0
  22. package/Label.svelte +96 -169
  23. package/Label.svelte.d.ts +6 -1
  24. package/Label.types.d.ts +3 -1
  25. package/Link.svelte +9 -106
  26. package/Link.svelte.d.ts +0 -1
  27. package/List.svelte +142 -230
  28. package/List.svelte.d.ts +2 -3
  29. package/List.types.d.ts +6 -1
  30. package/ListItem.svelte +25 -94
  31. package/ListItem.svelte.d.ts +2 -0
  32. package/Menu.svelte +48 -65
  33. package/Menu.svelte.d.ts +4 -1
  34. package/MenuBar.svelte +84 -86
  35. package/MenuBar.svelte.d.ts +4 -1
  36. package/MenuButton.svelte +66 -73
  37. package/MenuButton.svelte.d.ts +7 -3
  38. package/MenuItem.svelte +256 -288
  39. package/MenuItem.svelte.d.ts +2 -2
  40. package/MenuItemDisplay.svelte +12 -116
  41. package/MenuItemDisplay.svelte.d.ts +21 -7
  42. package/MenuSeparator.svelte +6 -45
  43. package/MenuSeparator.svelte.d.ts +8 -78
  44. package/Popover.constants.d.ts +1 -1
  45. package/Popover.constants.js +1 -1
  46. package/Popover.svelte +66 -80
  47. package/Popover.svelte.d.ts +5 -1
  48. package/Progress.svelte +28 -126
  49. package/Progress.svelte.d.ts +4 -3
  50. package/Radio.svelte +49 -192
  51. package/Radio.svelte.d.ts +2 -2
  52. package/RgbColorSliders.svelte +48 -137
  53. package/RgbColorSliders.svelte.d.ts +5 -5
  54. package/Select.svelte +122 -250
  55. package/Select.svelte.d.ts +6 -2
  56. package/Slider.svelte +90 -259
  57. package/Slider.svelte.d.ts +1 -2
  58. package/Switch.svelte +24 -259
  59. package/Switch.svelte.d.ts +3 -1
  60. package/Tab.svelte +27 -175
  61. package/Tab.svelte.d.ts +6 -4
  62. package/TabList.svelte +146 -171
  63. package/TabList.svelte.d.ts +3 -2
  64. package/TabList.types.d.ts +6 -1
  65. package/TextArea.svelte +32 -129
  66. package/TextArea.svelte.d.ts +1 -1
  67. package/Tooltip.svelte +46 -47
  68. package/Tooltip.svelte.d.ts +8 -3
  69. package/Tree.constants.d.ts +0 -1
  70. package/Tree.constants.js +0 -1
  71. package/Tree.svelte +35 -119
  72. package/Tree.svelte.d.ts +4 -4
  73. package/Tree.types.d.ts +1 -3
  74. package/TreeChevron.svelte +18 -98
  75. package/TreeChevron.svelte.d.ts +1 -0
  76. package/TreeItem.constants.d.ts +1 -0
  77. package/TreeItem.constants.js +1 -0
  78. package/TreeItem.svelte +251 -211
  79. package/TreeItem.svelte.d.ts +7 -3
  80. package/TreeItem.types.d.ts +1 -1
  81. package/TreeItemDisplay.svelte +20 -104
  82. package/TreeItemDisplay.svelte.d.ts +2 -2
  83. package/actions/applyLightDarkMode.d.ts +10 -0
  84. package/actions/applyLightDarkMode.js +36 -0
  85. package/actions/forwardEvents.js +3 -3
  86. package/css/Button.base.css +74 -0
  87. package/css/Button.colorful.css +17 -0
  88. package/css/Button.css +7 -0
  89. package/css/Button.secondary.colorful.css +15 -0
  90. package/css/Button.secondary.css +11 -0
  91. package/css/Button.shapes.css +14 -0
  92. package/css/Button.tool.colorful.css +13 -0
  93. package/css/Button.tool.css +18 -0
  94. package/css/Callout.base.css +43 -0
  95. package/css/Callout.colorful.css +5 -0
  96. package/css/Callout.css +2 -0
  97. package/css/Checkbox.base.css +145 -0
  98. package/css/Checkbox.colorful.css +17 -0
  99. package/css/Checkbox.css +2 -0
  100. package/css/ColorPicker.base.css +23 -0
  101. package/css/ColorPicker.css +1 -0
  102. package/css/Dialog.base.css +116 -0
  103. package/css/Dialog.css +1 -0
  104. package/css/Dropdown.base.css +147 -0
  105. package/css/Dropdown.colorful.css +23 -0
  106. package/css/Dropdown.css +2 -0
  107. package/css/HexColorSliders.base.css +106 -0
  108. package/css/HexColorSliders.css +1 -0
  109. package/css/HslColorSliders.base.css +124 -0
  110. package/css/HslColorSliders.css +1 -0
  111. package/css/Input.base.css +100 -0
  112. package/css/Input.colorful.css +22 -0
  113. package/css/Input.composed.css +8 -0
  114. package/css/Input.css +3 -0
  115. package/css/Label.base.css +119 -0
  116. package/css/Label.boxed.colorful.css +21 -0
  117. package/css/Label.boxed.css +31 -0
  118. package/css/Label.colorful.css +3 -0
  119. package/css/Label.css +4 -0
  120. package/css/Link.base.css +52 -0
  121. package/css/Link.colorful.css +15 -0
  122. package/css/Link.css +6 -0
  123. package/css/Link.ghost.colorful.css +7 -0
  124. package/css/Link.ghost.css +11 -0
  125. package/css/Link.undecorated.colorful.css +6 -0
  126. package/css/Link.undecorated.css +6 -0
  127. package/css/List.base.css +98 -0
  128. package/css/List.css +1 -0
  129. package/css/ListItem.base.css +59 -0
  130. package/css/ListItem.css +1 -0
  131. package/css/Menu.base.css +21 -0
  132. package/css/Menu.css +1 -0
  133. package/css/MenuBar.base.css +9 -0
  134. package/css/MenuBar.css +1 -0
  135. package/css/MenuButton.base.css +13 -0
  136. package/css/MenuButton.css +1 -0
  137. package/css/MenuItem.base.css +48 -0
  138. package/css/MenuItem.css +1 -0
  139. package/css/MenuItemDisplay.base.css +104 -0
  140. package/css/MenuItemDisplay.css +1 -0
  141. package/css/MenuSeparator.base.css +5 -0
  142. package/css/MenuSeparator.css +1 -0
  143. package/css/Popover copy.css +21 -0
  144. package/css/Popover.css +21 -0
  145. package/css/Progress.base.css +99 -0
  146. package/css/Progress.css +1 -0
  147. package/css/Radio.base.css +135 -0
  148. package/css/Radio.colorful.css +18 -0
  149. package/css/Radio.css +2 -0
  150. package/css/RgbColorSliders.base.css +94 -0
  151. package/css/RgbColorSliders.css +1 -0
  152. package/css/Select.base.css +127 -0
  153. package/css/Select.colorful.css +24 -0
  154. package/css/Select.composed.css +12 -0
  155. package/css/Select.css +3 -0
  156. package/css/Slider.base.css +182 -0
  157. package/css/Slider.colorful.css +11 -0
  158. package/css/Slider.composed.css +8 -0
  159. package/css/Slider.css +3 -0
  160. package/css/Switch.base.css +193 -0
  161. package/css/Switch.colorful.css +39 -0
  162. package/css/Switch.css +2 -0
  163. package/css/Tab.base.css +135 -0
  164. package/css/Tab.colorful.css +13 -0
  165. package/css/Tab.css +2 -0
  166. package/css/TabList.base.css +34 -0
  167. package/css/TabList.css +1 -0
  168. package/css/TextArea.base.css +85 -0
  169. package/css/TextArea.colorful.css +17 -0
  170. package/css/TextArea.composed.css +8 -0
  171. package/css/TextArea.css +3 -0
  172. package/css/Tooltip.base.css +6 -0
  173. package/css/Tooltip.css +1 -0
  174. package/css/Tree.base.css +74 -0
  175. package/css/Tree.composed.css +8 -0
  176. package/css/Tree.css +2 -0
  177. package/css/TreeChevron.base.css +86 -0
  178. package/css/TreeChevron.css +1 -0
  179. package/css/TreeItem.base.css +3 -0
  180. package/css/TreeItem.css +1 -0
  181. package/css/TreeItemDisplay.base.css +74 -0
  182. package/css/TreeItemDisplay.colorful.css +9 -0
  183. package/css/TreeItemDisplay.css +1 -0
  184. package/css/dark-mode.css +134 -0
  185. package/css/light-mode.css +134 -0
  186. package/css/sterling.css +37 -0
  187. package/index.d.ts +9 -13
  188. package/index.js +8 -12
  189. package/mediaQueries/prefersColorSchemeDark.d.ts +2 -0
  190. package/mediaQueries/prefersColorSchemeDark.js +10 -0
  191. package/{stores → mediaQueries}/prefersReducedMotion.d.ts +1 -0
  192. package/{stores → mediaQueries}/usingKeyboard.d.ts +1 -0
  193. package/package.json +121 -13
  194. package/Link.constants.d.ts +0 -1
  195. package/Link.constants.js +0 -1
  196. package/Link.types.d.ts +0 -4
  197. package/Link.types.js +0 -1
  198. package/theme/applyDarkTheme.d.ts +0 -7
  199. package/theme/applyDarkTheme.js +0 -11
  200. package/theme/applyLightTheme.d.ts +0 -7
  201. package/theme/applyLightTheme.js +0 -11
  202. package/theme/applyTheme.d.ts +0 -7
  203. package/theme/applyTheme.js +0 -20
  204. package/theme/colors.d.ts +0 -54
  205. package/theme/colors.js +0 -82
  206. package/theme/darkTheme.d.ts +0 -2
  207. package/theme/darkTheme.js +0 -142
  208. package/theme/lightTheme.d.ts +0 -2
  209. package/theme/lightTheme.js +0 -119
  210. package/theme/toggleDarkTheme.d.ts +0 -18
  211. package/theme/toggleDarkTheme.js +0 -53
  212. package/theme/types.d.ts +0 -21
  213. package/theme/types.js +0 -1
  214. /package/{stores → mediaQueries}/prefersReducedMotion.js +0 -0
  215. /package/{stores → mediaQueries}/usingKeyboard.js +0 -0
package/Select.svelte CHANGED
@@ -1,145 +1,159 @@
1
- <script>import { createEventDispatcher, tick } from "svelte";
2
- import { clickOutside } from "./actions/clickOutside";
3
- import { idGenerator } from "./idGenerator";
4
- import List from "./List.svelte";
5
- import Popover from "./Popover.svelte";
6
- const popupId = idGenerator.nextId("Select-popup");
1
+ <script>import { createEventDispatcher, tick } from 'svelte';
2
+ import { clickOutside } from './actions/clickOutside';
3
+ import { idGenerator } from './idGenerator';
4
+ import List from './List.svelte';
5
+ import Popover from './Popover.svelte';
6
+ const popupId = idGenerator.nextId('Select-popup');
7
+ // ----- Props ----- //
7
8
  export let disabled = false;
8
- export let composed = false;
9
+ /** When true, the select's dropdown is open. */
9
10
  export let open = false;
10
- export let selectedValue = void 0;
11
+ /** The value of the selected item.*/
12
+ export let selectedValue = undefined;
13
+ /** Additional class names to apply. */
14
+ export let variant = '';
15
+ // ----- State ----- //
16
+ // Tracks the previous open state
11
17
  let prevOpen = false;
18
+ // Tracks the pending selected index
12
19
  let pendingSelectedValue = selectedValue;
13
20
  let selectRef;
14
21
  let listRef;
22
+ // ----- Events ----- //
15
23
  const dispatch = createEventDispatcher();
16
24
  const raiseSelect = (value) => {
17
- dispatch("select", { value });
25
+ dispatch('select', { value });
18
26
  };
19
27
  const raisePending = (value) => {
20
- dispatch("pending", { value });
28
+ dispatch('pending', { value });
21
29
  };
30
+ // ----- Reactions ----- //
22
31
  $: {
23
- pendingSelectedValue = selectedValue;
32
+ pendingSelectedValue = selectedValue;
24
33
  }
25
34
  $: {
26
- raiseSelect(selectedValue);
35
+ raiseSelect(selectedValue);
27
36
  }
28
37
  $: {
29
- if (open) {
30
- raisePending(pendingSelectedValue);
31
- }
38
+ if (open) {
39
+ raisePending(pendingSelectedValue);
40
+ }
32
41
  }
33
42
  $: {
34
- if (open && !prevOpen) {
35
- prevOpen = true;
36
- tick().then(() => {
37
- setTimeout(() => {
38
- listRef?.focus();
39
- listRef?.scrollToSelectedItem();
40
- }, 10);
41
- });
42
- } else if (prevOpen) {
43
- prevOpen = false;
44
- tick().then(() => selectRef?.focus());
45
- }
43
+ if (open && !prevOpen) {
44
+ prevOpen = true;
45
+ tick().then(() => {
46
+ setTimeout(() => {
47
+ listRef?.focus();
48
+ listRef?.scrollToSelectedItem();
49
+ }, 10);
50
+ });
51
+ }
52
+ else if (prevOpen) {
53
+ prevOpen = false;
54
+ tick().then(() => selectRef?.focus());
55
+ }
46
56
  }
57
+ // ----- Methods ----- //
47
58
  export const blur = () => {
48
- selectRef?.blur();
59
+ selectRef?.blur();
49
60
  };
50
61
  export const click = () => {
51
- selectRef?.click();
62
+ selectRef?.click();
52
63
  };
53
64
  export const focus = (options) => {
54
- selectRef?.focus();
65
+ selectRef?.focus();
55
66
  };
56
67
  export const scrollToSelectedItem = () => {
57
- if (open) {
58
- listRef?.scrollToSelectedItem();
59
- }
68
+ if (open) {
69
+ listRef?.scrollToSelectedItem();
70
+ }
60
71
  };
72
+ // ----- Event Handlers ----- //
61
73
  const onSelectClick = (event) => {
62
- if (!disabled) {
63
- open = !open;
64
- event.preventDefault();
65
- event.stopPropagation();
66
- }
74
+ if (!disabled) {
75
+ open = !open;
76
+ event.preventDefault();
77
+ event.stopPropagation();
78
+ }
67
79
  };
68
80
  const onSelectKeydown = (event) => {
69
- if (!disabled && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {
70
- switch (event.key) {
71
- case " ":
72
- {
73
- if (!open) {
74
- open = true;
75
- }
76
- event.preventDefault();
77
- event.stopPropagation();
78
- return false;
79
- }
80
- break;
81
- case "ArrowUp":
82
- {
83
- if (selectedValue) {
84
- listRef.selectPreviousItem();
85
- } else {
86
- listRef.selectLastItem();
87
- }
88
- event.preventDefault();
89
- event.stopPropagation();
90
- return false;
81
+ if (!disabled && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {
82
+ switch (event.key) {
83
+ case ' ':
84
+ {
85
+ if (!open) {
86
+ open = true;
87
+ }
88
+ event.preventDefault();
89
+ event.stopPropagation();
90
+ return false;
91
+ }
92
+ break;
93
+ case 'ArrowUp':
94
+ {
95
+ if (selectedValue) {
96
+ listRef.selectPreviousItem();
97
+ }
98
+ else {
99
+ listRef.selectLastItem();
100
+ }
101
+ event.preventDefault();
102
+ event.stopPropagation();
103
+ return false;
104
+ }
105
+ break;
106
+ case 'ArrowDown':
107
+ {
108
+ if (selectedValue) {
109
+ listRef.selectNextItem();
110
+ }
111
+ else {
112
+ listRef.selectFirstItem();
113
+ }
114
+ event.preventDefault();
115
+ event.stopPropagation();
116
+ return false;
117
+ }
118
+ break;
91
119
  }
92
- break;
93
- case "ArrowDown":
94
- {
95
- if (selectedValue) {
96
- listRef.selectNextItem();
97
- } else {
98
- listRef.selectFirstItem();
99
- }
100
- event.preventDefault();
101
- event.stopPropagation();
102
- return false;
103
- }
104
- break;
105
120
  }
106
- }
107
121
  };
108
122
  const onListKeydown = (event) => {
109
- if (!disabled && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {
110
- switch (event.key) {
111
- case "Enter":
112
- {
113
- selectedValue = pendingSelectedValue;
114
- open = !open;
115
- event.preventDefault();
116
- event.stopPropagation();
117
- return false;
118
- }
119
- break;
120
- case "Escape":
121
- {
122
- pendingSelectedValue = selectedValue;
123
- open = !open;
124
- event.preventDefault();
125
- event.stopPropagation();
126
- return false;
123
+ if (!disabled && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {
124
+ switch (event.key) {
125
+ case 'Enter':
126
+ {
127
+ selectedValue = pendingSelectedValue;
128
+ open = !open;
129
+ event.preventDefault();
130
+ event.stopPropagation();
131
+ return false;
132
+ }
133
+ break;
134
+ case 'Escape':
135
+ {
136
+ pendingSelectedValue = selectedValue;
137
+ open = !open;
138
+ event.preventDefault();
139
+ event.stopPropagation();
140
+ return false;
141
+ }
142
+ break;
127
143
  }
128
- break;
129
144
  }
130
- }
131
145
  };
132
146
  const onListClick = (event) => {
133
- open = false;
134
- event.preventDefault();
135
- event.stopPropagation();
136
- return false;
147
+ open = false;
148
+ event.preventDefault();
149
+ event.stopPropagation();
150
+ return false;
137
151
  };
138
152
  const onListSelect = (event) => {
139
- pendingSelectedValue = event.detail.value;
140
- if (!open) {
141
- selectedValue = pendingSelectedValue;
142
- }
153
+ pendingSelectedValue = event.detail.value;
154
+ if (!open) {
155
+ selectedValue = pendingSelectedValue;
156
+ }
143
157
  };
144
158
  </script>
145
159
 
@@ -148,8 +162,7 @@ const onListSelect = (event) => {
148
162
  aria-controls={popupId}
149
163
  aria-haspopup="listbox"
150
164
  aria-expanded={open}
151
- class="sterling-select"
152
- class:composed
165
+ class={`sterling-select ${variant}`}
153
166
  class:disabled
154
167
  role="combobox"
155
168
  tabindex="0"
@@ -186,7 +199,7 @@ const onListSelect = (event) => {
186
199
  {...$$restProps}
187
200
  >
188
201
  <div class="value">
189
- <slot name="value" {disabled} {open} {selectedValue}>
202
+ <slot name="value" {disabled} {open} {selectedValue} {variant}>
190
203
  {#if selectedValue}
191
204
  {selectedValue}
192
205
  {:else}
@@ -195,165 +208,24 @@ const onListSelect = (event) => {
195
208
  </slot>
196
209
  </div>
197
210
  <div class="button">
198
- <slot name="button" {disabled} {open} {selectedValue}>
211
+ <slot name="button" {disabled} {open} {selectedValue} {variant}>
199
212
  <div class="chevron" />
200
213
  </slot>
201
214
  </div>
202
215
  <Popover reference={selectRef} bind:open id={popupId} conditionalRender={false}>
203
- <div class="popup-content">
216
+ <div class={`sterling-select-popup-content ${variant}`}>
204
217
  <List
205
218
  bind:this={listRef}
206
- composed
207
219
  {disabled}
208
220
  selectedValue={pendingSelectedValue}
209
221
  on:click={onListClick}
210
222
  on:keydown={onListKeydown}
211
223
  on:select={onListSelect}
212
224
  tabIndex={open ? 0 : -1}
225
+ variant={`composed ${variant}`}
213
226
  >
214
- <slot />
227
+ <slot {variant} />
215
228
  </List>
216
229
  </div>
217
230
  </Popover>
218
231
  </div>
219
-
220
- <style>
221
- .sterling-select {
222
- align-content: center;
223
- align-items: center;
224
- background-color: var(--stsv-input__background-color);
225
- border-color: var(--stsv-input__border-color);
226
- border-radius: var(--stsv-input__border-radius);
227
- border-style: var(--stsv-input__border-style);
228
- border-width: var(--stsv-input__border-width);
229
- color: var(--stsv-input__color);
230
- cursor: pointer;
231
- display: grid;
232
- grid-template-columns: 1fr auto;
233
- grid-template-rows: auto;
234
- outline: none;
235
- padding: 0;
236
- position: relative;
237
- transition: background-color 250ms, color 250ms, border-color 250ms;
238
- }
239
-
240
- .sterling-select:hover {
241
- background-color: var(--stsv-input__background-color--hover);
242
- border-color: var(--stsv-input__border-color--hover);
243
- color: var(--stsv-input__color--hover);
244
- }
245
-
246
- .sterling-select:focus {
247
- background-color: var(--stsv-input__background-color--focus);
248
- border-color: var(--stsv-input__border-color--focus);
249
- color: var(--stsv-input__color--focus);
250
- outline-color: var(--stsv-common__outline-color);
251
- outline-offset: var(--stsv-common__outline-offset);
252
- outline-style: var(--stsv-common__outline-style);
253
- outline-width: var(--stsv-common__outline-width);
254
- }
255
-
256
- .sterling-select.disabled {
257
- cursor: not-allowed;
258
- outline: none;
259
- }
260
-
261
- .sterling-select::after {
262
- background: repeating-linear-gradient(
263
- var(--stsv-common--disabled__stripe-angle),
264
- var(--stsv-common--disabled__stripe-color),
265
- var(--stsv-common--disabled__stripe-color) var(--stsv-common--disabled__stripe-width),
266
- var(--stsv-common--disabled__stripe-color--alt) var(--stsv-common--disabled__stripe-width),
267
- var(--stsv-common--disabled__stripe-color--alt)
268
- calc(2 * var(--stsv-common--disabled__stripe-width))
269
- );
270
- bottom: 0;
271
- content: '';
272
- left: 0;
273
- opacity: 0;
274
- position: absolute;
275
- right: 0;
276
- top: 0;
277
- pointer-events: none;
278
- transition: opacity 250ms;
279
- }
280
-
281
- .sterling-select.disabled::after {
282
- opacity: 1;
283
- }
284
-
285
- .sterling-select.composed,
286
- .sterling-select.composed:hover,
287
- .sterling-select.composed.focus,
288
- .sterling-select.composed.disabled {
289
- background: none;
290
- border: none;
291
- outline: none;
292
- }
293
-
294
- .sterling-select.composed.disabled::after {
295
- opacity: 0;
296
- }
297
-
298
- .value {
299
- padding: 0.5em;
300
- }
301
-
302
- .chevron {
303
- display: block;
304
- position: relative;
305
- border: none;
306
- background: none;
307
- margin: 0;
308
- height: 100%;
309
- width: 32px;
310
- }
311
-
312
- .chevron::after {
313
- position: absolute;
314
- content: '';
315
- top: 50%;
316
- left: 50%;
317
- width: 7px;
318
- height: 7px;
319
- border-right: 3px solid currentColor;
320
- border-top: 3px solid currentColor;
321
- /*
322
- The chevron is a right triangle, rotated to face down.
323
- It should be moved up so it is centered vertically after rotation.
324
- The amount to move is the hypotenuse of the right triangle of the chevron.
325
- For a right triangle with equal a and b where c=1
326
- a^2 + b^2 = c^2
327
- a^2 + a^2 = c^2
328
- 2a^2 = c^2
329
- 2a^2 = 1
330
- a^2 = 0.5
331
- a = sqrt(0.5)
332
- a = 0.707
333
- */
334
- transform: translate(-50%, calc(-50% / 0.707)) rotate(135deg);
335
- transform-origin: 50% 50%;
336
- }
337
-
338
- .popup-content {
339
- background-color: var(--stsv-common__background-color);
340
- border-color: var(--stsv-common__border-color);
341
- border-radius: var(--stsv-common__border-radius);
342
- border-style: var(--stsv-common__border-style);
343
- border-width: var(--stsv-common__border-width);
344
- box-shadow: rgba(0, 0, 0, 0.4) 2px 2px 4px -1px;
345
- padding: 0.25em;
346
- display: grid;
347
- grid-template-columns: 1fr;
348
- grid-template-rows: 1fr;
349
- overflow: hidden;
350
- max-height: 20em;
351
- }
352
-
353
- @media (prefers-reduced-motion) {
354
- .sterling-select,
355
- .sterling-select::after {
356
- transition: none;
357
- }
358
- }
359
- </style>
@@ -3,9 +3,9 @@ declare const __propDef: {
3
3
  props: {
4
4
  [x: string]: any;
5
5
  disabled?: boolean | undefined;
6
- composed?: boolean | undefined;
7
6
  open?: boolean | undefined;
8
7
  selectedValue?: string | undefined;
8
+ variant?: string | undefined;
9
9
  blur?: (() => void) | undefined;
10
10
  click?: (() => void) | undefined;
11
11
  focus?: ((options?: FocusOptions) => void) | undefined;
@@ -48,13 +48,17 @@ declare const __propDef: {
48
48
  disabled: boolean;
49
49
  open: boolean;
50
50
  selectedValue: string | undefined;
51
+ variant: string;
51
52
  };
52
53
  button: {
53
54
  disabled: boolean;
54
55
  open: boolean;
55
56
  selectedValue: string | undefined;
57
+ variant: string;
58
+ };
59
+ default: {
60
+ variant: string;
56
61
  };
57
- default: {};
58
62
  };
59
63
  };
60
64
  export type SelectProps = typeof __propDef.props;