@ardium-ui/ui 5.0.0-alpha.8 → 5.0.0-alpha.81

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 (302) hide show
  1. package/fesm2022/ardium-ui-ui.mjs +5003 -2545
  2. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  3. package/lib/_internal/boolean-component.d.ts +13 -1
  4. package/lib/_internal/disablable-component.d.ts +2 -1
  5. package/lib/_internal/focusable-component.d.ts +2 -1
  6. package/lib/_internal/form-field-component.d.ts +3 -2
  7. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +19 -19
  8. package/lib/_internal/item-storages/simple-item-storage.d.ts +15 -12
  9. package/lib/_internal/item-storages/simplest-item-storage.d.ts +1 -1
  10. package/lib/_internal/ngmodel-component.d.ts +5 -8
  11. package/lib/_internal/selectable-list-component.d.ts +6 -6
  12. package/lib/_internal/utils/date.utils.d.ts +16 -0
  13. package/lib/badge/badge.directive.d.ts +3 -2
  14. package/lib/breakpoints/breakpoint.service.d.ts +12 -0
  15. package/lib/breakpoints/breakpoint.utils.d.ts +7 -0
  16. package/lib/breakpoints/breakpoints.d.ts +13 -0
  17. package/lib/breakpoints/index.d.ts +2 -0
  18. package/lib/buttons/_button-base.d.ts +12 -8
  19. package/lib/buttons/_button-base.defaults.d.ts +3 -2
  20. package/lib/buttons/button/button.component.d.ts +5 -5
  21. package/lib/buttons/button/button.defaults.d.ts +0 -2
  22. package/lib/buttons/button/button.directive.d.ts +17 -0
  23. package/lib/buttons/button/button.module.d.ts +3 -2
  24. package/lib/buttons/button/index.d.ts +1 -0
  25. package/lib/buttons/fab/fab.component.d.ts +3 -1
  26. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -4
  27. package/lib/buttons/icon-button/icon-button.defaults.d.ts +2 -1
  28. package/lib/calendar/abstract-calendar.d.ts +128 -0
  29. package/lib/calendar/calendar.component.d.ts +8 -96
  30. package/lib/calendar/calendar.defaults.d.ts +16 -1
  31. package/lib/calendar/calendar.internal-directives.d.ts +24 -8
  32. package/lib/calendar/calendar.internal-types.d.ts +1 -0
  33. package/lib/calendar/calendar.module.d.ts +4 -9
  34. package/lib/calendar/calendar.types.d.ts +21 -5
  35. package/lib/calendar/index.d.ts +3 -0
  36. package/lib/calendar/range-calendar.component.d.ts +16 -0
  37. package/lib/calendar/range-calendar.directives.d.ts +51 -0
  38. package/lib/calendar/range-calendar.module.d.ts +10 -0
  39. package/lib/calendar/views/calendar-views.module.d.ts +13 -0
  40. package/lib/calendar/views/days-view/days-view.component.d.ts +20 -2
  41. package/lib/calendar/views/days-view/days-view.helpers.d.ts +2 -2
  42. package/lib/calendar/views/months-view/months-view.component.d.ts +15 -3
  43. package/lib/calendar/views/years-view/years-view.component.d.ts +16 -3
  44. package/lib/checkbox/checkbox.component.d.ts +5 -2
  45. package/lib/checkbox/checkbox.types.d.ts +2 -0
  46. package/lib/checkbox-list/checkbox-list.component.d.ts +9 -7
  47. package/lib/checkbox-list/checkbox-list.directives.d.ts +7 -0
  48. package/lib/checkbox-list/checkbox-list.module.d.ts +1 -1
  49. package/lib/chip/chip.component.d.ts +2 -1
  50. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +2 -1
  51. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +5 -2
  52. package/lib/dialog/dialog.component.d.ts +13 -8
  53. package/lib/dialog/dialog.types.d.ts +1 -0
  54. package/lib/divider/divider.component.d.ts +2 -3
  55. package/lib/divider/divider.defaults.d.ts +5 -0
  56. package/lib/divider/divider.directive.d.ts +18 -0
  57. package/lib/divider/divider.module.d.ts +3 -2
  58. package/lib/divider/divider.types.d.ts +5 -0
  59. package/lib/divider/index.d.ts +2 -0
  60. package/lib/dropdown-panel/dropdown-panel.component.d.ts +2 -1
  61. package/lib/dropdown-panel/dropdown-panel.types.d.ts +1 -1
  62. package/lib/file-inputs/file-input/file-input.component.d.ts +2 -1
  63. package/lib/file-inputs/file-input-base.d.ts +4 -5
  64. package/lib/form-field/auto-error/auto-error.component.d.ts +19 -0
  65. package/lib/form-field/auto-error/auto-error.provider.d.ts +7 -0
  66. package/lib/form-field/error/error.directive.d.ts +3 -2
  67. package/lib/form-field/form-field-base.d.ts +5 -2
  68. package/lib/form-field/form-field-child.token.d.ts +5 -5
  69. package/lib/form-field/form-field-native-inputs.d.ts +6 -11
  70. package/lib/form-field/form-field.component.d.ts +1 -1
  71. package/lib/form-field/form-field.defaults.d.ts +1 -0
  72. package/lib/form-field/form-field.module.d.ts +5 -4
  73. package/lib/form-field/hint/hint.directive.d.ts +3 -2
  74. package/lib/form-field/hint-error/hint-error.directive.d.ts +3 -2
  75. package/lib/form-field/horizontal-form-field.component.d.ts +1 -1
  76. package/lib/form-field/index.d.ts +2 -0
  77. package/lib/form-field/label/label.component.d.ts +3 -2
  78. package/lib/form-field-frame/form-field-frame.component.d.ts +5 -3
  79. package/lib/grid/grid.component.d.ts +51 -0
  80. package/lib/grid/grid.defaults.d.ts +16 -0
  81. package/lib/grid/grid.module.d.ts +7 -0
  82. package/lib/grid/grid.types.d.ts +38 -0
  83. package/lib/grid/grid.utils.d.ts +11 -0
  84. package/lib/grid/index.d.ts +4 -0
  85. package/lib/icon/icon.component.d.ts +2 -1
  86. package/lib/inputs/_simple-input-base.d.ts +6 -3
  87. package/lib/inputs/autocomplete-input/autocomplete-input.component.d.ts +5 -4
  88. package/lib/inputs/date-input/abstract-date-input.d.ts +112 -0
  89. package/lib/inputs/date-input/date-input.component.d.ts +19 -81
  90. package/lib/inputs/date-input/date-input.defaults.d.ts +21 -3
  91. package/lib/inputs/date-input/{date-input.directive.d.ts → date-input.directives.d.ts} +2 -2
  92. package/lib/inputs/date-input/date-input.module.d.ts +5 -4
  93. package/lib/inputs/date-input/date-input.serializers.d.ts +4 -2
  94. package/lib/inputs/date-input/date-input.types.d.ts +5 -4
  95. package/lib/inputs/date-input/date-range-input.component.d.ts +30 -0
  96. package/lib/inputs/date-input/date-range-input.directives.d.ts +82 -0
  97. package/lib/inputs/date-input/date-range-input.module.d.ts +17 -0
  98. package/lib/inputs/date-input/index.d.ts +7 -1
  99. package/lib/inputs/date-input/multipage-date-range-input.component.d.ts +45 -0
  100. package/lib/inputs/date-input/multipage-date-range-input.directives.d.ts +82 -0
  101. package/lib/inputs/date-input/multipage-date-range-input.module.d.ts +17 -0
  102. package/lib/inputs/digit-input/digit-input.component.d.ts +4 -3
  103. package/lib/inputs/hex-input/hex-input.component.d.ts +4 -3
  104. package/lib/inputs/input-utils.d.ts +13 -2
  105. package/lib/inputs/number-input/number-input.component.d.ts +20 -12
  106. package/lib/inputs/number-input/number-input.defaults.d.ts +6 -0
  107. package/lib/inputs/number-input/number-input.directives.d.ts +12 -0
  108. package/lib/inputs/number-input/number-input.module.d.ts +1 -1
  109. package/lib/inputs/number-input/number-input.types.d.ts +6 -0
  110. package/lib/inputs/password-input/password-input.component.d.ts +5 -3
  111. package/lib/kbd/kbd.component.d.ts +2 -1
  112. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +2 -1
  113. package/lib/modal/modal.component.d.ts +9 -6
  114. package/lib/modal/modal.defaults.d.ts +2 -0
  115. package/lib/option/option.component.d.ts +2 -1
  116. package/lib/progress-bar/progress-bar.component.d.ts +4 -3
  117. package/lib/progress-circle/progress-circle.component.d.ts +5 -4
  118. package/lib/radio/radio/radio.component.d.ts +8 -3
  119. package/lib/search-functions.d.ts +1 -1
  120. package/lib/segment/segment.component.d.ts +6 -5
  121. package/lib/select/select.component.d.ts +42 -32
  122. package/lib/select/select.defaults.d.ts +10 -2
  123. package/lib/select/select.directive.d.ts +6 -0
  124. package/lib/select/select.module.d.ts +1 -1
  125. package/lib/select/select.types.d.ts +6 -2
  126. package/lib/select/select.utils.d.ts +2 -0
  127. package/lib/slide-toggle/slide-toggle.component.d.ts +2 -0
  128. package/lib/slider/abstract-slider.d.ts +37 -29
  129. package/lib/slider/index.d.ts +1 -0
  130. package/lib/slider/range-slider/range-slider.component.d.ts +12 -9
  131. package/lib/slider/range-slider/range-slider.types.d.ts +6 -0
  132. package/lib/slider/slider.component.d.ts +5 -4
  133. package/lib/slider/slider.types.d.ts +3 -3
  134. package/lib/star/rating-display/rating-display.component.d.ts +2 -1
  135. package/lib/star/rating-input/rating-input.component.d.ts +5 -3
  136. package/lib/star/rating-input/rating-input.defaults.d.ts +2 -2
  137. package/lib/star/star-button/star-button.component.d.ts +4 -1
  138. package/lib/star/star-button/star-button.types.d.ts +1 -0
  139. package/lib/tabber/index.d.ts +2 -1
  140. package/lib/tabber/tab/tab.component.d.ts +16 -8
  141. package/lib/tabber/tabber.component.d.ts +25 -9
  142. package/lib/tabber/tabber.defaults.d.ts +2 -0
  143. package/lib/tabber/tabber.directives.d.ts +9 -0
  144. package/lib/tabber/tabber.module.d.ts +3 -2
  145. package/lib/tabber/tabber.types.d.ts +5 -0
  146. package/lib/table/table.component.d.ts +16 -15
  147. package/lib/table-pagination/table-pagination.component.d.ts +4 -3
  148. package/lib/text-list/text-list.component.d.ts +2 -1
  149. package/lib/types/alignment.types.d.ts +7 -1
  150. package/lib/types/item-storage.types.d.ts +17 -18
  151. package/lib/types/theming.types.d.ts +1 -0
  152. package/package.json +3 -2
  153. package/prebuilt-themes/default/badge.css +234 -205
  154. package/prebuilt-themes/default/badge.css.map +1 -1
  155. package/prebuilt-themes/default/buttons/button.css +324 -301
  156. package/prebuilt-themes/default/buttons/button.css.map +1 -1
  157. package/prebuilt-themes/default/buttons/fab.css +317 -299
  158. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  159. package/prebuilt-themes/default/buttons/icon-button.css +299 -287
  160. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -1
  161. package/prebuilt-themes/default/calendar.css +390 -308
  162. package/prebuilt-themes/default/calendar.css.map +1 -1
  163. package/prebuilt-themes/default/card.css +151 -127
  164. package/prebuilt-themes/default/card.css.map +1 -1
  165. package/prebuilt-themes/default/checkbox-list.css +89 -62
  166. package/prebuilt-themes/default/checkbox-list.css.map +1 -1
  167. package/prebuilt-themes/default/checkbox.css +349 -362
  168. package/prebuilt-themes/default/checkbox.css.map +1 -1
  169. package/prebuilt-themes/default/chips.css +412 -359
  170. package/prebuilt-themes/default/chips.css.map +1 -1
  171. package/prebuilt-themes/default/color-display.css +34 -26
  172. package/prebuilt-themes/default/color-display.css.map +1 -1
  173. package/prebuilt-themes/default/color-picker.css +105 -103
  174. package/prebuilt-themes/default/color-picker.css.map +1 -1
  175. package/prebuilt-themes/default/core.css +108 -86
  176. package/prebuilt-themes/default/core.css.map +1 -1
  177. package/prebuilt-themes/default/dialog.css +19 -15
  178. package/prebuilt-themes/default/dialog.css.map +1 -1
  179. package/prebuilt-themes/default/divider.css +84 -8
  180. package/prebuilt-themes/default/divider.css.map +1 -1
  181. package/prebuilt-themes/default/dropdown-panel.css +42 -34
  182. package/prebuilt-themes/default/dropdown-panel.css.map +1 -1
  183. package/prebuilt-themes/default/file-drop-area.css +329 -276
  184. package/prebuilt-themes/default/file-drop-area.css.map +1 -1
  185. package/prebuilt-themes/default/form-field-frame.css +102 -98
  186. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  187. package/prebuilt-themes/default/form-field.css +148 -118
  188. package/prebuilt-themes/default/form-field.css.map +1 -1
  189. package/prebuilt-themes/default/inputs/autocomplete-input.css +183 -132
  190. package/prebuilt-themes/default/inputs/autocomplete-input.css.map +1 -1
  191. package/prebuilt-themes/default/inputs/color-input.css +99 -137
  192. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  193. package/prebuilt-themes/default/inputs/date-input.css +134 -63
  194. package/prebuilt-themes/default/inputs/date-input.css.map +1 -1
  195. package/prebuilt-themes/default/inputs/digit-input.css +120 -110
  196. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  197. package/prebuilt-themes/default/inputs/file-input.css +385 -325
  198. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  199. package/prebuilt-themes/default/inputs/hex-input.css +150 -117
  200. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  201. package/prebuilt-themes/default/inputs/input.css +137 -107
  202. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  203. package/prebuilt-themes/default/inputs/number-input.css +213 -164
  204. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  205. package/prebuilt-themes/default/inputs/password-input.css +120 -71
  206. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  207. package/prebuilt-themes/default/kbd-shortcut.css +14 -9
  208. package/prebuilt-themes/default/kbd-shortcut.css.map +1 -1
  209. package/prebuilt-themes/default/kbd.css +26 -15
  210. package/prebuilt-themes/default/kbd.css.map +1 -1
  211. package/prebuilt-themes/default/modal.css +96 -71
  212. package/prebuilt-themes/default/modal.css.map +1 -1
  213. package/prebuilt-themes/default/progress-bar.css +250 -228
  214. package/prebuilt-themes/default/progress-bar.css.map +1 -1
  215. package/prebuilt-themes/default/progress-circle.css +178 -164
  216. package/prebuilt-themes/default/progress-circle.css.map +1 -1
  217. package/prebuilt-themes/default/radio.css +246 -223
  218. package/prebuilt-themes/default/radio.css.map +1 -1
  219. package/prebuilt-themes/default/segment.css +432 -414
  220. package/prebuilt-themes/default/segment.css.map +1 -1
  221. package/prebuilt-themes/default/select.css +302 -270
  222. package/prebuilt-themes/default/select.css.map +1 -1
  223. package/prebuilt-themes/default/slide-toggle.css +319 -261
  224. package/prebuilt-themes/default/slide-toggle.css.map +1 -1
  225. package/prebuilt-themes/default/slider.css +399 -351
  226. package/prebuilt-themes/default/slider.css.map +1 -1
  227. package/prebuilt-themes/default/snackbar.css +189 -169
  228. package/prebuilt-themes/default/snackbar.css.map +1 -1
  229. package/prebuilt-themes/default/spinner.css +161 -148
  230. package/prebuilt-themes/default/spinner.css.map +1 -1
  231. package/prebuilt-themes/default/stars.css +271 -246
  232. package/prebuilt-themes/default/stars.css.map +1 -1
  233. package/prebuilt-themes/default/tabber.css +250 -207
  234. package/prebuilt-themes/default/tabber.css.map +1 -1
  235. package/prebuilt-themes/default/table-pagination.css +57 -45
  236. package/prebuilt-themes/default/table-pagination.css.map +1 -1
  237. package/prebuilt-themes/default/table.css +464 -432
  238. package/prebuilt-themes/default/table.css.map +1 -1
  239. package/public-api.d.ts +2 -1
  240. package/themes/_variables.scss +2 -1
  241. package/themes/default/_coloring.scss +7 -0
  242. package/themes/default/_mixins.scss +5 -5
  243. package/themes/default/badge.scss +115 -80
  244. package/themes/default/buttons/_button-mixins.scss +43 -33
  245. package/themes/default/buttons/button.scss +90 -63
  246. package/themes/default/buttons/fab.scss +74 -49
  247. package/themes/default/buttons/icon-button.scss +70 -45
  248. package/themes/default/calendar.scss +257 -163
  249. package/themes/default/card.scss +167 -121
  250. package/themes/default/checkbox-list.scss +90 -62
  251. package/themes/default/checkbox.scss +64 -91
  252. package/themes/default/chips.scss +203 -143
  253. package/themes/default/color-display.scss +40 -28
  254. package/themes/default/color-picker.scss +95 -93
  255. package/themes/default/core.scss +123 -97
  256. package/themes/default/dialog.scss +22 -13
  257. package/themes/default/divider.scss +109 -7
  258. package/themes/default/dropdown-panel.scss +49 -34
  259. package/themes/default/file-drop-area.scss +197 -138
  260. package/themes/default/form-field-frame.scss +73 -63
  261. package/themes/default/form-field.scss +136 -98
  262. package/themes/default/inputs/_shared.scss +52 -12
  263. package/themes/default/inputs/autocomplete-input.scss +102 -31
  264. package/themes/default/inputs/color-input.scss +34 -32
  265. package/themes/default/inputs/date-input.scss +90 -20
  266. package/themes/default/inputs/digit-input.scss +103 -79
  267. package/themes/default/inputs/file-input.scss +160 -81
  268. package/themes/default/inputs/hex-input.scss +68 -16
  269. package/themes/default/inputs/input.scss +55 -6
  270. package/themes/default/inputs/number-input.scss +164 -92
  271. package/themes/default/inputs/password-input.scss +100 -29
  272. package/themes/default/kbd-shortcut.scss +16 -8
  273. package/themes/default/kbd.scss +35 -16
  274. package/themes/default/modal.scss +109 -73
  275. package/themes/default/progress-bar.scss +126 -102
  276. package/themes/default/progress-circle.scss +49 -41
  277. package/themes/default/radio.scss +110 -87
  278. package/themes/default/segment.scss +282 -267
  279. package/themes/default/select.scss +255 -197
  280. package/themes/default/slide-toggle.scss +193 -116
  281. package/themes/default/slider.scss +230 -187
  282. package/themes/default/snackbar.scss +52 -32
  283. package/themes/default/spinner.scss +24 -14
  284. package/themes/default/stars.scss +99 -68
  285. package/themes/default/tabber.scss +109 -67
  286. package/themes/default/table-pagination.scss +60 -44
  287. package/themes/default/table.scss +379 -343
  288. package/lib/statebox/index.d.ts +0 -4
  289. package/lib/statebox/statebox.component.d.ts +0 -26
  290. package/lib/statebox/statebox.defaults.d.ts +0 -10
  291. package/lib/statebox/statebox.module.d.ts +0 -8
  292. package/lib/statebox/statebox.types.d.ts +0 -26
  293. package/lib/tabber/tab/tab.defaults.d.ts +0 -6
  294. package/prebuilt-themes/default/calendar-OLD.css +0 -294
  295. package/prebuilt-themes/default/calendar-OLD.css.map +0 -1
  296. package/prebuilt-themes/default/inputs/search-bar.css +0 -118
  297. package/prebuilt-themes/default/inputs/search-bar.css.map +0 -1
  298. package/prebuilt-themes/default/statebox.css +0 -235
  299. package/prebuilt-themes/default/statebox.css.map +0 -1
  300. package/themes/default/calendar-OLD.scss +0 -183
  301. package/themes/default/inputs/search-bar.scss +0 -19
  302. package/themes/default/statebox.scss +0 -109
@@ -3,222 +3,265 @@
3
3
  @use 'sass:math';
4
4
  @use '../variables' as ARD;
5
5
 
6
- .ard-slider-container-master,
7
- .ard-range-slider-container-master {
8
- @include coloringMixins.typeColors();
9
-
10
- position: relative;
11
- font-size: 1rem;
12
- width: 20em;
13
- max-width: 100%;
14
- padding: 0 0.625em;
15
- display: flex;
16
- flex-direction: column;
17
-
18
- color: var(--ard-cmpcl--bg-colored);
19
-
20
- //! compact
21
- &.ard-compact {
22
- font-size: 0.85rem;
23
-
24
- .ard-slider-container > .ard-slider-handle {
25
- font-size: 0.95em;
26
- }
6
+ @layer ard-ui {
7
+ // the variables are commented out intentionally
8
+ // read more in docs/dev/css-variables.md
9
+ :root {
10
+ // --ard-slider-font-size: ;
11
+ // --ard-slider-font-size-compact: ;
12
+ --ard-slider-width: 100%;
13
+ --ard-slider-padding: 0 calc(var(--ard-slider-handle-size, 1.25em) / 2);
14
+ --ard-slider-track-height: 0.25em;
15
+ // --ard-slider-track-color: ;
16
+ --ard-slider-track-opacity: 20%;
17
+ --ard-slider-track-border-radius: 9999px;
18
+ --ard-slider-active-track-height: calc(100% + 0.125em);
19
+ // --ard-slider-active-color: ;
20
+ --ard-slider-active-track-opacity: 100%;
21
+ --ard-slider-value-tick-size: 0.125em;
22
+ --ard-slider-value-tick-opacity: 30%;
23
+ --ard-slider-track-hitbox-size: calc(var(--ard-slider-handle-size, 1.25em) / 2);
24
+ --ard-slider-handle-size: 1.25em;
25
+ // --ard-slider-handle-bg: ;
26
+ --ard-slider-handle-border: none;
27
+ --ard-slider-handle-border-radius: 9999px;
28
+ --ard-slider-handle-hitbox-size: 0.375em;
29
+ --ard-slider-handle-overlay-size: 0.5em;
30
+ --ard-slider-handle-overlay-hover-opacity: 7.5%;
31
+ --ard-slider-handle-overlay-focus-opacity: 15%;
32
+ --ard-slider-handle-overlay-active-opacity: 25%;
33
+ --ard-slider-label-font-size: 0.875rem;
34
+ --ard-slider-label-padding-top: 0.2em;
35
+ // --ard-slider-label-bg: ;
36
+ // --ard-slider-label-color: ;
37
+ --ard-slider-label-height: 2em;
38
+ --ard-slider-label-border: none;
39
+ --ard-slider-label-border-radius: 0.375em;
40
+ --ard-slider-label-padding: 0 0.75em;
41
+ --ard-slider-label-font-weight: 500;
42
+ --ard-slider-label-arrow-size: 0.375em;
43
+ --ard-slider-label-offset: 0.5em;
27
44
  }
28
45
 
29
- //! container
30
- .ard-slider-container {
31
- display: flex;
32
- align-items: center;
46
+ .ard-slider-container-master,
47
+ .ard-range-slider-container-master {
48
+ @include coloringMixins.typeColors();
49
+
33
50
  position: relative;
34
- width: 100%;
35
- height: 1.25em;
36
- cursor: pointer;
37
- }
38
- //! track
39
- .ard-slider-track {
40
- width: 100%;
41
- height: 0.25em;
42
- background: ARD.$bg;
43
-
44
- .ard-slider-track-overlay {
45
- position: absolute;
46
- width: 100%;
47
- height: 100%;
48
- background: currentColor;
49
- opacity: 20%;
50
- border-radius: 9999px;
51
-
52
- &.ard-slider-track-active {
53
- width: 0;
54
- height: calc(100% + 0.125em);
55
- top: math.div(-1em, 16);
56
- opacity: 100%;
57
- transition:
58
- width var(--_ard-slider-transition) ease,
59
- left var(--_ard-slider-transition) ease;
51
+ font-size: var(--ard-slider-font-size, var(--ard-form-field-font-size, 1rem));
52
+ width: var(--ard-slider-width, 100%);
53
+ max-width: 100%;
54
+ padding: var(--ard-slider-padding, 0 calc(var(--ard-slider-handle-size, 1.25em) / 2));
55
+ display: flex;
56
+ flex-direction: column;
57
+
58
+ //! compact
59
+ &.ard-compact {
60
+ font-size: var(--ard-slider-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem));
61
+
62
+ .ard-slider-container > .ard-slider-handle {
63
+ font-size: 0.95em;
60
64
  }
61
65
  }
62
- .ard-hitbox {
63
- position: absolute;
64
- inset: -0.625em;
65
- }
66
- .ard-value-tick-container {
67
- position: absolute;
68
- left: 0.125em;
69
- width: calc(100% - 0.25em);
70
- height: 100%;
71
- }
72
- .ard-value-tick {
73
- top: 50%;
74
- width: 0.125em;
75
- height: 0.125em;
76
- border-radius: 9999px;
77
- background: ARD.$text;
78
- opacity: 30%;
79
- transform: translate(-50%, -50%);
80
- }
81
- }
82
- //! handle
83
- // &.ard-slider-handle-grabbed,
84
- // &.ard-slider-handle-grabbed * {
85
- // cursor: grabbing;
86
- // }
87
- .ard-slider-handle {
88
- font-size: inherit;
89
- top: 0;
90
- width: 1.25em;
91
- height: 1.25em;
92
- color: inherit;
93
- background: currentColor;
94
- border-radius: 9999px;
95
- border: none;
96
- z-index: 1;
97
- outline: none;
98
- cursor: pointer;
99
-
100
- transition:
101
- box-shadow 0.15s ease,
102
- left var(--_ard-slider-transition) ease;
103
- box-shadow: ARD.$simple-shadow;
104
-
105
- // cursor: grab;
106
- // &.ard-grabbed {
107
- // cursor: grabbing;
108
- // }
109
-
110
- .ard-focus-overlay {
111
- @include defaultMixins.focus-overlay(0.5em);
112
- background: currentColor;
113
- }
114
- @include defaultMixins.focus-overlay-scale-addon();
115
66
 
116
- .ard-hitbox {
117
- position: absolute;
118
- inset: math.div(-7em, 16);
119
- border-radius: 9999px;
67
+ //! container
68
+ .ard-slider-container {
69
+ display: flex;
70
+ align-items: center;
71
+ position: relative;
72
+ width: 100%;
73
+ height: var(--ard-slider-handle-size, 1.25em);
74
+ cursor: pointer;
120
75
  }
121
- &:hover {
122
- .ard-focus-overlay {
123
- opacity: 7.5%;
76
+ //! track
77
+ .ard-slider-track {
78
+ width: 100%;
79
+ height: var(--ard-slider-track-height, 0.25em);
80
+ background: ARD.$bg;
81
+
82
+ .ard-slider-track-overlay {
83
+ position: absolute;
84
+ width: 100%;
85
+ height: 100%;
86
+ background: var(--ard-slider-track-color, var(--ard-cmpcl--bg-colored));
87
+ opacity: var(--ard-slider-track-opacity, 20%);
88
+ border-radius: var(--ard-slider-track-border-radius, 9999px);
89
+
90
+ &.ard-slider-track-active {
91
+ width: 0;
92
+ height: var(--ard-slider-active-track-height, calc(100% + 0.125em));
93
+ top: 50%;
94
+ transform: translateY(-50%);
95
+ background: var(--ard-slider-active-color, var(--ard-cmpcl--bg-colored));
96
+ opacity: var(--ard-slider-active-track-opacity, 100%);
97
+ transition:
98
+ width var(--_ard-slider-transition) ease,
99
+ left var(--_ard-slider-transition) ease;
100
+ }
124
101
  }
125
- }
126
- &:focus {
127
- box-shadow: ARD.$simple-shadow2;
128
- .ard-focus-overlay {
129
- opacity: 15%;
102
+ .ard-hitbox {
103
+ position: absolute;
104
+ inset: calc(var(--ard-slider-hitbox-size, calc(var(--ard-slider-handle-size, 1.25em) / 2)) * -1);
105
+ }
106
+ .ard-value-tick-container {
107
+ position: absolute;
108
+ left: var(--ard-slider-value-tick-size, 0.125em);
109
+ width: calc(100% - var(--ard-slider-value-tick-size, 0.125em) * 2);
110
+ height: 100%;
111
+ }
112
+ .ard-value-tick {
113
+ top: 50%;
114
+ width: var(--ard-slider-value-tick-size, 0.125em);
115
+ height: var(--ard-slider-value-tick-size, 0.125em);
116
+ border-radius: 9999px;
117
+ background: ARD.$text;
118
+ opacity: var(--ard-slider-value-tick-opacity, 30%);
119
+ transform: translate(-50%, -50%);
130
120
  }
131
121
  }
132
- &:active,
133
- &.ard-grabbed {
122
+ //! handle
123
+ .ard-slider-handle {
124
+ font-size: inherit;
125
+ top: 0;
126
+ width: var(--ard-slider-handle-size, 1.25em);
127
+ height: var(--ard-slider-handle-size, 1.25em);
128
+ color: inherit;
129
+ background: var(--ard-slider-handle-bg, var(--ard-cmpcl--bg-colored));
130
+ border-radius: var(--ard-slider-handle-border-radius, 9999px);
131
+ border: var(--ard-slider-handle-border, none);
132
+ z-index: 1;
133
+ outline: none;
134
+ cursor: grab;
135
+
136
+ transition:
137
+ box-shadow 0.15s ease,
138
+ left var(--_ard-slider-transition) ease;
139
+ box-shadow: ARD.$simple-shadow;
140
+
134
141
  .ard-focus-overlay {
135
- opacity: 25%;
142
+ @include defaultMixins.focus-overlay(var(--ard-slider-handle-overlay-size, 0.5em));
143
+ background: currentColor;
136
144
  }
137
- }
138
- }
139
- .ard-slider-label-container {
140
- position: relative;
141
- font-size: 0.9em;
142
- padding-top: 0.2em;
143
- left: 2px;
144
- width: calc(100% - 0.25em) !important;
145
+ @include defaultMixins.focus-overlay-scale-addon();
145
146
 
146
- .ard-slider-label {
147
- transform: translateX(-50%);
148
- }
149
- }
150
- //! tooltip
151
- .ard-slider-tooltip-wrapper {
152
- transition: left var(--_ard-slider-transition) ease;
153
- z-index: 2;
154
- }
155
- .ard-slider-tooltip {
156
- --ard-background: #{ARD.$text3};
157
- background: var(--ard-background);
158
- color: ARD.$text2-alt;
159
- font-size: 0.875em;
160
- border-radius: 0.375em;
161
- height: 2em;
162
- padding: 0 0.75em;
163
- display: flex;
164
- align-items: center;
165
- font-weight: 500;
166
- position: relative;
167
- z-index: 2;
168
- user-select: none;
147
+ .ard-hitbox {
148
+ position: absolute;
149
+ inset: calc(var(--ard-slider-handle-hitbox-size, 0.375em) * -1);
150
+ border-radius: calc(var(--ard-slider-handle-border-radius, 9999px) + var(--ard-slider-handle-hitbox-size, 0.375em));
151
+ }
152
+ &:hover {
153
+ .ard-focus-overlay {
154
+ opacity: var(--ard-slider-handle-overlay-hover-opacity, 7.5%);
155
+ }
156
+ }
157
+ &:focus {
158
+ box-shadow: ARD.$simple-shadow2;
169
159
 
170
- transform: scale(0);
171
- transition: transform 0.1s ARD.$timing-fn;
160
+ .ard-focus-overlay {
161
+ opacity: var(--ard-slider-handle-overlay-focus-opacity, 15%);
162
+ }
163
+ }
164
+ &:active,
165
+ &.ard-grabbed {
166
+ .ard-focus-overlay {
167
+ opacity: var(--ard-slider-handle-overlay-active-opacity, 25%);
168
+ }
169
+ }
170
+ }
171
+ .ard-slider-label-container {
172
+ position: relative;
173
+ font-size: var(--ard-slider-label-font-size, 0.9em);
174
+ padding-top: var(--ard-slider-label-padding-top, 0.2em);
175
+ left: 0.125em;
176
+ width: calc(100% - 0.25em) !important;
172
177
 
173
- &::before {
174
- content: '';
175
- position: absolute;
176
- border: 0.375em solid transparent;
177
- left: 50%;
178
+ .ard-slider-label {
179
+ transform: translateX(-50%);
180
+ }
181
+ }
182
+ //! tooltip
183
+ .ard-slider-tooltip-wrapper {
184
+ transition: left var(--_ard-slider-transition) ease;
185
+ z-index: 2;
178
186
  }
179
- }
180
- &.ard-tooltip-top {
181
187
  .ard-slider-tooltip {
182
- bottom: 0.5em;
188
+ background: var(--ard-slider-label-bg, #{ARD.$text3});
189
+ height: var(--ard-slider-label-height, 2em);
190
+ padding: var(--ard-slider-label-padding, 0 0.75em);
191
+ border-radius: var(--ard-slider-label-border-radius, 0.375em);
192
+ color: var(--ard-slider-label-color, #{ARD.$text2-alt});
193
+ font-size: var(--ard-slider-label-font-size, 0.875rem);
194
+ font-weight: var(--ard-slider-label-font-weight, 500);
195
+ white-space: nowrap;
196
+ display: flex;
197
+ align-items: center;
198
+ position: relative;
199
+ z-index: 2;
200
+ user-select: none;
201
+
202
+ transform: scale(0);
203
+ transition: transform 0.1s ARD.$timing-fn;
183
204
 
184
205
  &::before {
185
- bottom: 0;
186
- border-top-color: var(--ard-background);
187
- transform: translate(-50%, 100%);
206
+ content: '';
207
+ position: absolute;
208
+ border: var(--ard-slider-label-arrow-size, 0.375em) solid transparent;
209
+ left: 50%;
188
210
  }
189
211
  }
190
- }
191
- &.ard-tooltip-bottom {
192
- .ard-slider-tooltip {
193
- top: 0.5em;
212
+ &.ard-tooltip-top {
213
+ .ard-slider-tooltip {
214
+ bottom: var(--ard-slider-label-offset, 0.5em);
215
+ transform-origin: center bottom;
194
216
 
195
- &::before {
196
- top: 0;
197
- border-bottom-color: var(--ard-background);
198
- transform: translate(-50%, -100%);
217
+ &::before {
218
+ bottom: 0;
219
+ border-top-color: var(--ard-slider-label-bg);
220
+ transform: translate(-50%, 100%);
221
+ }
199
222
  }
200
223
  }
201
- }
202
- //! showing and hiding tooltip
203
- //show tooltip when handle is hovered or focused
204
- .ard-slider-handle:hover,
205
- .ard-slider-handle:focus {
206
- + .ard-slider-tooltip-wrapper .ard-slider-tooltip {
207
- transform: scale(1);
224
+ &.ard-tooltip-bottom {
225
+ .ard-slider-tooltip {
226
+ top: var(--ard-slider-label-offset, 0.5em);
227
+ transform-origin: center top;
228
+
229
+ &::before {
230
+ top: 0;
231
+ border-bottom-color: var(--ard-slider-label-bg);
232
+ transform: translate(-50%, -100%);
233
+ }
234
+ }
208
235
  }
209
- }
210
- //hide other tooltips when a handle is focused
211
- .ard-slider-container:focus-within {
212
- .ard-slider-handle:not(:focus) {
236
+ //! showing and hiding tooltip
237
+ //show tooltip when handle is hovered or focused
238
+ .ard-slider-handle:hover,
239
+ .ard-slider-handle:focus {
213
240
  + .ard-slider-tooltip-wrapper .ard-slider-tooltip {
214
- transform: scale(0);
241
+ transform: scale(1);
242
+ }
243
+ }
244
+ //hide other tooltips when a handle is focused
245
+ .ard-slider-container:focus-within {
246
+ .ard-slider-handle:not(:focus) {
247
+ + .ard-slider-tooltip-wrapper .ard-slider-tooltip {
248
+ transform: scale(0);
249
+ }
250
+ }
251
+ }
252
+ //make a way to force-show a tooltip
253
+ .ard-slider-handle .ard-slider-tooltip-wrapper {
254
+ .ard-slider-tooltip.ard-tooltip-always {
255
+ transform: scale(1) !important;
215
256
  }
216
257
  }
217
258
  }
218
- //make a way to force-show a tooltip
219
- .ard-slider-handle .ard-slider-tooltip-wrapper.ard-tooltip-always {
220
- .ard-slider-tooltip {
221
- transform: scale(1) !important;
259
+ .ard-body-slider-handle-grabbed {
260
+ cursor: grabbing !important;
261
+
262
+ * {
263
+ cursor: grabbing !important;
264
+ pointer-events: none !important;
222
265
  }
223
266
  }
224
267
  }
@@ -1,48 +1,68 @@
1
1
  @use './coloring' as C;
2
2
  @use '../variables' as ARD;
3
3
 
4
- .ard-snackbar {
5
- @include C.typeColors();
6
- min-width: min(21rem, 90vw);
7
- max-width: min(42rem, 90vw);
8
- min-height: 3rem;
9
- margin: 0.625rem;
10
- position: relative;
11
- display: flex;
12
- justify-content: stretch;
13
- align-items: center;
14
- gap: 0.625rem;
15
- border-radius: 6px;
16
- transform-origin: bottom center;
17
- background-color: ARD.$bg-f-alt;
18
- padding: 0 0.5rem 0 1rem;
19
-
20
- opacity: 100%;
21
- transform: scale(100%);
22
- bottom: 0;
23
- animation: show 150ms ease-out forwards;
24
-
25
- .ard-snackbar-content {
4
+ @layer ard-ui {
5
+ // the variables are commented out intentionally
6
+ // read more in docs/dev/css-variables.md
7
+ :root {
8
+ --ard-snackbar-min-width: min(21rem, 90vw);
9
+ --ard-snackbar-max-width: min(42rem, 90vw);
10
+ --ard-snackbar-min-height: 3rem;
11
+ // --ard-snackbar-background-color: ;
12
+ // --ard-snackbar-content-color: ;
13
+ --ard-snackbar-gap: 0.625rem;
14
+ --ard-snackbar-margin: 0.625rem;
15
+ --ard-snackbar-padding: 0 0.5rem 0 1rem;
16
+ // --ard-snackbar-border-radius: ;
17
+ --ard-snackbar-content-gap: 0.625rem;
18
+ --ard-snackbar-animation-duration: 150ms;
19
+ --ard-snackbar-animation-bottom: -0.375rem;
20
+ --ard-snackbar-animation-scale: 60%;
21
+ }
22
+
23
+ .ard-snackbar {
24
+ @include C.typeColors();
25
+ min-width: var(--ard-snackbar-min-width, min(21rem, 90vw));
26
+ max-width: var(--ard-snackbar-max-width, min(42rem, 90vw));
27
+ min-height: var(--ard-snackbar-min-height, 3rem);
28
+ margin: var(--ard-snackbar-margin, 0.625rem);
29
+ position: relative;
26
30
  display: flex;
27
- gap: 0.625rem;
31
+ justify-content: stretch;
28
32
  align-items: center;
29
- flex-grow: 1;
30
- color: ARD.$text2-alt;
33
+ gap: var(--ard-snackbar-gap, 0.625rem);
34
+ border-radius: var(--ard-snackbar-border-radius, var(--ard-rounded-corner-radius, 0.375rem));
35
+ transform-origin: bottom center;
36
+ background-color: var(--ard-snackbar-background-color, #{ARD.$bg-f-alt});
37
+ padding: var(--ard-snackbar-padding, 0 0.5rem 0 1rem);
38
+
39
+ opacity: 100%;
40
+ transform: scale(100%);
41
+ bottom: 0;
42
+ animation: show var(--ard-snackbar-animation-duration, 150ms) ease-out forwards;
31
43
 
32
- ard-icon {
33
- color: var(--ard-cmpcl--content-light);
44
+ .ard-snackbar-content {
45
+ display: flex;
46
+ gap: var(--ard-snackbar-content-gap, 0.625rem);
47
+ align-items: center;
48
+ flex-grow: 1;
49
+ color: var(--ard-snackbar-content-color, #{ARD.$text2-alt});
50
+
51
+ ard-icon {
52
+ color: var(--ard-cmpcl--content-light);
53
+ }
34
54
  }
35
- }
36
55
 
37
- &.ard-snackbar-closing {
38
- animation: hide 150ms ease-out forwards;
56
+ &.ard-snackbar-closing {
57
+ animation: hide var(--ard-snackbar-animation-duration, 150ms) ease-out forwards;
58
+ }
39
59
  }
40
60
  }
41
61
 
42
62
  @mixin animation {
43
63
  opacity: 0%;
44
- transform: scale(60%);
45
- bottom: -0.375rem;
64
+ transform: scale(var(--ard-snackbar-animation-scale, 60%));
65
+ bottom: var(--ard-snackbar-animation-bottom, -0.375rem);
46
66
  }
47
67
 
48
68
  @keyframes show {
@@ -1,21 +1,31 @@
1
1
  @use './coloring' as CM;
2
2
 
3
- ard-spinner {
4
- display: inline-block;
5
- width: 2rem;
6
- aspect-ratio: 1;
7
- position: relative;
8
- margin: 0.25rem;
9
- }
3
+ @layer ard-ui {
4
+ // the variables are commented out intentionally
5
+ // read more in docs/dev/css-variables.md
6
+ :root {
7
+ --ard-spinner-size: 2rem;
8
+ --ard-spinner-margin: 0.25rem;
9
+ --ard-spinner-duration: 1.4s;
10
+ }
11
+
12
+ ard-spinner {
13
+ display: inline-block;
14
+ width: var(--ard-spinner-size, 2rem);
15
+ aspect-ratio: 1;
16
+ position: relative;
17
+ margin: var(--ard-spinner-margin, 0.25rem);
18
+ }
10
19
 
11
- .ard-spinner {
12
- @include CM.typeColors();
13
- --ard-_spinner-duration: 1.4s;
14
- position: absolute;
20
+ .ard-spinner {
21
+ @include CM.typeColors();
22
+ --ard-_spinner-duration: var(--ard-spinner-duration, 1.4s);
23
+ position: absolute;
15
24
 
16
- scale: 2.3; //magic number
25
+ scale: 2.3; //magic number
17
26
 
18
- > circle {
19
- stroke: var(--ard-cmpcl--content);
27
+ > circle {
28
+ stroke: var(--ard-cmpcl--content);
29
+ }
20
30
  }
21
31
  }