@ardium-ui/ui 5.0.0-alpha.7 → 5.0.0-alpha.71

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 (293) hide show
  1. package/fesm2022/ardium-ui-ui.mjs +4707 -2272
  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 +4 -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/search-functions.d.ts +1 -1
  119. package/lib/segment/segment.component.d.ts +6 -5
  120. package/lib/select/select.component.d.ts +40 -30
  121. package/lib/select/select.defaults.d.ts +10 -2
  122. package/lib/select/select.directive.d.ts +6 -0
  123. package/lib/select/select.module.d.ts +1 -1
  124. package/lib/select/select.types.d.ts +6 -2
  125. package/lib/select/select.utils.d.ts +2 -0
  126. package/lib/slide-toggle/slide-toggle.component.d.ts +2 -0
  127. package/lib/slider/abstract-slider.d.ts +35 -29
  128. package/lib/slider/index.d.ts +1 -0
  129. package/lib/slider/range-slider/range-slider.component.d.ts +13 -10
  130. package/lib/slider/range-slider/range-slider.types.d.ts +6 -0
  131. package/lib/slider/slider.component.d.ts +5 -4
  132. package/lib/slider/slider.types.d.ts +3 -3
  133. package/lib/star/rating-display/rating-display.component.d.ts +2 -1
  134. package/lib/star/rating-input/rating-input.component.d.ts +5 -3
  135. package/lib/star/rating-input/rating-input.defaults.d.ts +2 -2
  136. package/lib/star/star-button/star-button.component.d.ts +4 -1
  137. package/lib/star/star-button/star-button.types.d.ts +1 -0
  138. package/lib/tabber/index.d.ts +2 -1
  139. package/lib/tabber/tab/tab.component.d.ts +16 -8
  140. package/lib/tabber/tabber.component.d.ts +25 -9
  141. package/lib/tabber/tabber.defaults.d.ts +2 -0
  142. package/lib/tabber/tabber.directives.d.ts +9 -0
  143. package/lib/tabber/tabber.module.d.ts +3 -2
  144. package/lib/tabber/tabber.types.d.ts +5 -0
  145. package/lib/table/table.component.d.ts +16 -15
  146. package/lib/table-pagination/table-pagination.component.d.ts +4 -3
  147. package/lib/text-list/text-list.component.d.ts +2 -1
  148. package/lib/types/alignment.types.d.ts +7 -1
  149. package/lib/types/item-storage.types.d.ts +17 -18
  150. package/package.json +3 -2
  151. package/prebuilt-themes/default/badge.css +37 -15
  152. package/prebuilt-themes/default/badge.css.map +1 -1
  153. package/prebuilt-themes/default/buttons/button.css +74 -58
  154. package/prebuilt-themes/default/buttons/button.css.map +1 -1
  155. package/prebuilt-themes/default/buttons/fab.css +64 -51
  156. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  157. package/prebuilt-themes/default/buttons/icon-button.css +50 -44
  158. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -1
  159. package/prebuilt-themes/default/calendar.css +131 -55
  160. package/prebuilt-themes/default/calendar.css.map +1 -1
  161. package/prebuilt-themes/default/card.css +56 -24
  162. package/prebuilt-themes/default/card.css.map +1 -1
  163. package/prebuilt-themes/default/checkbox-list.css +48 -22
  164. package/prebuilt-themes/default/checkbox-list.css.map +1 -1
  165. package/prebuilt-themes/default/checkbox.css +31 -58
  166. package/prebuilt-themes/default/checkbox.css.map +1 -1
  167. package/prebuilt-themes/default/chips.css +75 -43
  168. package/prebuilt-themes/default/chips.css.map +1 -1
  169. package/prebuilt-themes/default/color-display.css +15 -8
  170. package/prebuilt-themes/default/color-display.css.map +1 -1
  171. package/prebuilt-themes/default/core.css +21 -1
  172. package/prebuilt-themes/default/core.css.map +1 -1
  173. package/prebuilt-themes/default/dialog.css +7 -2
  174. package/prebuilt-themes/default/dialog.css.map +1 -1
  175. package/prebuilt-themes/default/divider.css +82 -6
  176. package/prebuilt-themes/default/divider.css.map +1 -1
  177. package/prebuilt-themes/default/dropdown-panel.css +16 -8
  178. package/prebuilt-themes/default/dropdown-panel.css.map +1 -1
  179. package/prebuilt-themes/default/file-drop-area.css +81 -35
  180. package/prebuilt-themes/default/file-drop-area.css.map +1 -1
  181. package/prebuilt-themes/default/form-field-frame.css +18 -14
  182. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  183. package/prebuilt-themes/default/form-field.css +62 -29
  184. package/prebuilt-themes/default/form-field.css.map +1 -1
  185. package/prebuilt-themes/default/inputs/autocomplete-input.css +79 -28
  186. package/prebuilt-themes/default/inputs/autocomplete-input.css.map +1 -1
  187. package/prebuilt-themes/default/inputs/color-input.css +5 -44
  188. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  189. package/prebuilt-themes/default/inputs/date-input.css +97 -25
  190. package/prebuilt-themes/default/inputs/date-input.css.map +1 -1
  191. package/prebuilt-themes/default/inputs/digit-input.css +31 -19
  192. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  193. package/prebuilt-themes/default/inputs/file-input.css +117 -62
  194. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  195. package/prebuilt-themes/default/inputs/hex-input.css +55 -23
  196. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  197. package/prebuilt-themes/default/inputs/input.css +47 -18
  198. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  199. package/prebuilt-themes/default/inputs/number-input.css +83 -33
  200. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  201. package/prebuilt-themes/default/inputs/password-input.css +74 -25
  202. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  203. package/prebuilt-themes/default/kbd-shortcut.css +8 -4
  204. package/prebuilt-themes/default/kbd-shortcut.css.map +1 -1
  205. package/prebuilt-themes/default/kbd.css +19 -9
  206. package/prebuilt-themes/default/kbd.css.map +1 -1
  207. package/prebuilt-themes/default/modal.css +46 -22
  208. package/prebuilt-themes/default/modal.css.map +1 -1
  209. package/prebuilt-themes/default/progress-circle.css +13 -7
  210. package/prebuilt-themes/default/progress-circle.css.map +1 -1
  211. package/prebuilt-themes/default/radio.css +46 -28
  212. package/prebuilt-themes/default/radio.css.map +1 -1
  213. package/prebuilt-themes/default/segment.css +71 -61
  214. package/prebuilt-themes/default/segment.css.map +1 -1
  215. package/prebuilt-themes/default/select.css +78 -44
  216. package/prebuilt-themes/default/select.css.map +1 -1
  217. package/prebuilt-themes/default/slide-toggle.css +88 -37
  218. package/prebuilt-themes/default/slide-toggle.css.map +1 -1
  219. package/prebuilt-themes/default/slider.css +93 -52
  220. package/prebuilt-themes/default/slider.css.map +1 -1
  221. package/prebuilt-themes/default/snackbar.css +29 -16
  222. package/prebuilt-themes/default/snackbar.css.map +1 -1
  223. package/prebuilt-themes/default/spinner.css +9 -3
  224. package/prebuilt-themes/default/spinner.css.map +1 -1
  225. package/prebuilt-themes/default/stars.css +42 -20
  226. package/prebuilt-themes/default/stars.css.map +1 -1
  227. package/prebuilt-themes/default/tabber.css +53 -17
  228. package/prebuilt-themes/default/tabber.css.map +1 -1
  229. package/prebuilt-themes/default/table-pagination.css +21 -9
  230. package/prebuilt-themes/default/table-pagination.css.map +1 -1
  231. package/prebuilt-themes/default/table.css +93 -69
  232. package/prebuilt-themes/default/table.css.map +1 -1
  233. package/public-api.d.ts +2 -1
  234. package/themes/_variables.scss +2 -1
  235. package/themes/default/_mixins.scss +5 -5
  236. package/themes/default/badge.scss +48 -15
  237. package/themes/default/buttons/_button-mixins.scss +43 -33
  238. package/themes/default/buttons/button.scss +54 -29
  239. package/themes/default/buttons/fab.scss +47 -26
  240. package/themes/default/buttons/icon-button.scss +40 -17
  241. package/themes/default/calendar.scss +148 -58
  242. package/themes/default/card.scss +68 -24
  243. package/themes/default/checkbox-list.scss +47 -21
  244. package/themes/default/checkbox.scss +30 -59
  245. package/themes/default/chips.scss +71 -40
  246. package/themes/default/color-display.scss +18 -8
  247. package/themes/default/core.scss +24 -1
  248. package/themes/default/dialog.scss +9 -2
  249. package/themes/default/divider.scss +106 -6
  250. package/themes/default/dropdown-panel.scss +21 -8
  251. package/themes/default/file-drop-area.scss +92 -35
  252. package/themes/default/form-field-frame.scss +23 -15
  253. package/themes/default/form-field.scss +64 -28
  254. package/themes/default/inputs/_shared.scss +52 -12
  255. package/themes/default/inputs/autocomplete-input.scss +83 -14
  256. package/themes/default/inputs/color-input.scss +2 -2
  257. package/themes/default/inputs/date-input.scss +74 -6
  258. package/themes/default/inputs/digit-input.scss +42 -20
  259. package/themes/default/inputs/file-input.scss +100 -23
  260. package/themes/default/inputs/hex-input.scss +59 -9
  261. package/themes/default/inputs/input.scss +51 -4
  262. package/themes/default/inputs/number-input.scss +94 -24
  263. package/themes/default/inputs/password-input.scss +84 -15
  264. package/themes/default/kbd-shortcut.scss +10 -4
  265. package/themes/default/kbd.scss +26 -9
  266. package/themes/default/modal.scss +56 -22
  267. package/themes/default/progress-circle.scss +16 -10
  268. package/themes/default/radio.scss +47 -26
  269. package/themes/default/segment.scss +77 -67
  270. package/themes/default/select.scss +98 -42
  271. package/themes/default/slide-toggle.scss +134 -59
  272. package/themes/default/slider.scss +102 -65
  273. package/themes/default/snackbar.scss +32 -14
  274. package/themes/default/spinner.scss +11 -3
  275. package/themes/default/stars.scss +45 -16
  276. package/themes/default/tabber.scss +54 -14
  277. package/themes/default/table-pagination.scss +24 -9
  278. package/themes/default/table.scss +104 -70
  279. package/lib/statebox/index.d.ts +0 -4
  280. package/lib/statebox/statebox.component.d.ts +0 -26
  281. package/lib/statebox/statebox.defaults.d.ts +0 -10
  282. package/lib/statebox/statebox.module.d.ts +0 -8
  283. package/lib/statebox/statebox.types.d.ts +0 -26
  284. package/lib/tabber/tab/tab.defaults.d.ts +0 -6
  285. package/prebuilt-themes/default/calendar-OLD.css +0 -294
  286. package/prebuilt-themes/default/calendar-OLD.css.map +0 -1
  287. package/prebuilt-themes/default/inputs/search-bar.css +0 -118
  288. package/prebuilt-themes/default/inputs/search-bar.css.map +0 -1
  289. package/prebuilt-themes/default/statebox.css +0 -235
  290. package/prebuilt-themes/default/statebox.css.map +0 -1
  291. package/themes/default/calendar-OLD.scss +0 -183
  292. package/themes/default/inputs/search-bar.scss +0 -19
  293. package/themes/default/statebox.scss +0 -109
@@ -2,32 +2,78 @@
2
2
  @use './mixins' as defaultMixins;
3
3
  @use '../variables' as ARD;
4
4
 
5
+ // the variables are commented out intentionally
6
+ // read more in docs/dev/css-variables.md
7
+ :root {
8
+ // --ard-select-height: ;
9
+ // --ard-select-height-compact: ;
10
+ --ard-select-gap: 0.625rem;
11
+ --ard-select-gap-compact: 0.5rem;
12
+ --ard-select-controls-gap: 0.625rem;
13
+ --ard-select-controls-gap-compact: 0.5rem;
14
+ --ard-select-padding: 0 1em 0 0.375em;
15
+ --ard-select-padding-compact: 0 0.625em 0 0.375em;
16
+
17
+ // --ard-select-font-size: ;
18
+ // --ard-select-font-size-compact: ;
19
+ // --ard-select-text-color: ;
20
+ // --ard-select-placeholder-color: ;
21
+ --ard-select-search-min-width: 10ch;
22
+ // --ard-select-dropdown-arrow-color: ;
23
+ --ard-select-dropdown-arrow-active-transform: rotate(180deg);
24
+ --ard-select-dropdown-arrow-transition: 0.2s ease-in-out;
25
+
26
+ --ard-select-multiselect-padding: 0.25em 0;
27
+ --ard-select-multiselect-chip-gap: 0.375rem;
28
+
29
+ --ard-select-dropdown-width: max-content;
30
+ --ard-select-dropdown-max-width: max(25em, 100%);
31
+ --ard-select-dropdown-min-width: 100%;
32
+ --ard-select-dropdown-max-height: 15em;
33
+ // --ard-select-dropdown-font-size: ;
34
+ // --ard-select-dropdown-font-size-compact: ;
35
+ --ard-select-dropdown-padding: 0.375em 0.625em;
36
+ --ard-select-dropdown-gap: 0;
37
+
38
+ --ard-select-dropdown-optgroup-label-font-size: 0.875em;
39
+ --ard-select-dropdown-optgroup-label-font-weight: 600;
40
+ --ard-select-dropdown-optgroup-label-letter-spacing: 0.25px;
41
+ --ard-select-dropdown-optgroup-label-padding: 0.375em 0.625em 0.0625em 0.625em;
42
+
43
+ --ard-select-dropdown-option-padding: 0.375em 0.625em;
44
+ // --ard-select-dropdown-option-text-color: ;
45
+ // --ard-select-dropdown-option-highlighted-bg: ;
46
+ --ard-select-dropdown-option-selected-font-weight: 500;
47
+ // --ard-select-dropdown-option-selected-bg: ;
48
+ // --ard-select-dropdown-option-selected-highlighted-bg: ;
49
+ --ard-select-dropdown-option-disabled-opacity: 50%;
50
+
51
+ --ard-select-dropdown-add-custom-gap: 0.375rem;
52
+ --ard-select-dropdown-add-custom-label-font-size: 85%;
53
+ }
54
+
5
55
  .ard-select {
6
56
  box-sizing: border-box;
7
57
  width: 100%;
8
- min-height: 100%;
58
+ min-height: var(--ard-select-height, var(--ard-form-field-height, 2.3125rem));
9
59
  display: grid;
10
60
  align-items: center;
11
61
  grid-template-columns: 1fr max-content;
12
- gap: 0.625em;
13
- padding: 0 1em 0 0.375em;
14
- font-family: 'Roboto', sans-serif;
15
- font-size: 1rem;
62
+ gap: var(--ard-select-gap, 0.625rem);
63
+ padding: var(--ard-select-padding, 0 1em 0 0.375em);
64
+ font-family: var(--ard-font-family);
65
+ font-size: var(--ard-select-font-size, var(--ard-form-field-font-size, 1rem));
66
+ color: var(--ard-select-text-color, var(--ard-text, rgba(0, 0, 0, 100%)));
16
67
 
17
68
  @include CB.clearButton();
18
69
 
19
- //! variants
20
- &.ard-variant-pill {
21
- padding-left: 0.8125em;
22
- }
23
-
24
70
  //! value container
25
71
  .ard-select-value-container {
26
72
  position: relative;
27
73
  height: 2em;
28
74
  display: flex;
29
75
  align-items: center;
30
- font-size: 1em;
76
+ font-size: var(--ard-select-font-size, var(--ard-form-field-font-size, 1rem));
31
77
  text-size-adjust: 100%;
32
78
  flex-grow: 1;
33
79
  overflow: hidden;
@@ -35,7 +81,7 @@
35
81
  .ard-placeholder {
36
82
  font: inherit;
37
83
  position: absolute;
38
- color: ARD.$text3;
84
+ color: var(--ard-select-placeholder-color, var(--ard-text3, rgba(0, 0, 0, 75%)));
39
85
  white-space: nowrap;
40
86
  overflow: hidden;
41
87
  text-overflow: ellipsis;
@@ -63,7 +109,7 @@
63
109
  .ard-select-controls {
64
110
  display: flex;
65
111
  align-items: center;
66
- gap: 0.625em;
112
+ gap: var(--ard-select-controls-gap, 0.625rem);
67
113
  width: max-content;
68
114
  }
69
115
  //! single/multiselect
@@ -96,10 +142,10 @@
96
142
  .ard-select-value-container {
97
143
  height: max-content;
98
144
  min-height: 1.5625em;
99
- padding: 0.25em 0;
145
+ padding: var(--ard-select-multiselect-padding, 0.25em 0);
100
146
  box-sizing: border-box;
101
147
  flex-wrap: wrap;
102
- gap: 0.375em;
148
+ gap: var(--ard-select-multiselect-chip-gap, 0.375rem);
103
149
  justify-content: stretch;
104
150
 
105
151
  .ard-chip-wrapper {
@@ -109,10 +155,10 @@
109
155
  .ard-search-input {
110
156
  flex-grow: 1;
111
157
  width: unset !important;
112
- min-width: 10ch;
158
+ min-width: var(--ard-select-search-min-width, 10ch);
113
159
 
114
160
  input {
115
- width: 10ch !important;
161
+ width: var(--ard-select-search-min-width, 10ch) !important;
116
162
  }
117
163
  }
118
164
  .ard-chip-wrapper {
@@ -128,25 +174,31 @@
128
174
  background-color: transparent;
129
175
  border: none;
130
176
  cursor: pointer;
177
+ transition: transform var(--ard-select-dropdown-arrow-transition, 0.2s ease-in-out);
131
178
 
132
179
  .ard-dropdown-arrow {
133
180
  border: calc(ARD.$dropdown-button-size / 2) solid transparent;
134
181
  position: relative;
135
- border-bottom-color: ARD.$detail;
136
- border-right-color: ARD.$detail;
182
+ border-bottom-color: var(--ard-select-dropdown-arrow-color, ARD.$detail);
183
+ border-right-color: var(--ard-select-dropdown-arrow-color, ARD.$detail);
137
184
  transform: rotate(45deg) translate(-17.67771%, -17.67771%);
138
185
  }
139
186
  }
140
- &.ard-dropdown-open .ard-dropdown-arrow {
141
- transform: rotate(45deg) translate(17.67771%, 17.67771%) scaleX(-1) scaleY(-1);
187
+ &.ard-dropdown-open {
188
+ .ard-dropdown-arrow-wrapper {
189
+ transform: var(--ard-select-dropdown-arrow-active-transform, rotate(180deg));
190
+ }
142
191
  }
143
192
 
144
193
  //! compact
145
194
  &.ard-compact {
146
- font-size: 0.85rem;
147
- height: 1.5625rem;
148
- padding-right: 0.625em;
195
+ font-size: var(--ard-select-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem));
196
+ min-height: var(--ard-select-height-compact, var(--ard-form-field-height-compact, 1.6875rem));
197
+ padding: var(--ard-select-padding-compact, 0 0.625em 0 0.375em);
149
198
 
199
+ .ard-select-controls {
200
+ gap: var(--ard-select-controls-gap-compact, 0.5rem);
201
+ }
150
202
  .ard-dropdown-arrow-wrapper .ard-dropdown-arrow {
151
203
  border-width: calc(ARD.$dropdown-button-size / 2.4);
152
204
  }
@@ -156,14 +208,14 @@
156
208
  //! optgroups & options, divider
157
209
  .ard-select-dropdown-panel {
158
210
  right: 0;
159
- width: max-content;
160
- max-width: max(25em, 100%);
161
- min-width: 100%;
162
- font-size: 1rem;
211
+ width: var(--ard-select-dropdown-width, max-content);
212
+ max-width: var(--ard-select-dropdown-max-width, max(25em, 100%));
213
+ min-width: var(--ard-select-dropdown-min-width, 100%);
214
+ font-size: var(--ard-select-dropdown-font-size, var(--ard-form-field-font-size, 1rem));
163
215
 
164
216
  .ard-dropdown-panel-content {
165
- padding: 0.375em 0;
166
- max-height: 15em;
217
+ padding: var(--ard-select-dropdown-padding, 0.375em 0.625em);
218
+ max-height: var(--ard-select-dropdown-max-height, 15em);
167
219
  overflow: hidden auto;
168
220
  }
169
221
  .ard-optgroup {
@@ -176,29 +228,33 @@
176
228
  }
177
229
 
178
230
  .ard-optgroup-label {
179
- font-size: 0.875em;
180
- font-weight: 600;
231
+ font-size: var(--ard-select-dropdown-optgroup-label-font-size, 0.875em);
232
+ font-weight: var(--ard-select-dropdown-optgroup-label-font-weight, 600);
181
233
  letter-spacing: 0.25px;
182
- padding: 0.375em 0.625em 0.0625em 0.625em;
234
+ padding: var(--ard-select-dropdown-optgroup-label-padding, 0.375em 0.625em 0.0625em 0.625em);
183
235
  }
184
236
 
185
237
  .ard-option {
186
- padding: 0.375em 0.625em;
187
- color: ARD.$text2;
238
+ padding: var(--ard-select-dropdown-option-padding, 0.375em 0.625em);
239
+ color: var(--ard-select-dropdown-option-text-color, var(--ard-text2, rgba(0, 0, 0, 87%)));
188
240
  cursor: pointer;
189
241
 
190
242
  &.ard-option-highlighted {
191
- background: ARD.$darken-overlay-light;
243
+ background: var(--ard-select-dropdown-option-highlighted-bg, ARD.$darken-overlay-light);
192
244
  }
193
245
 
194
246
  &.ard-option-selected {
195
- font-weight: 500;
196
- background: ARD.$darken-overlay-medium;
247
+ font-weight: var(--ard-select-dropdown-option-selected-font-weight, 500);
248
+ background: var(--ard-select-dropdown-option-selected-bg, ARD.$darken-overlay-medium);
249
+
250
+ &.ard-option-highlighted {
251
+ background: var(--ard-select-dropdown-option-selected-highlighted-bg, ARD.$darken-overlay-medium-strong);
252
+ }
197
253
  }
198
254
 
199
255
  &.ard-option-disabled {
200
256
  pointer-events: none;
201
- opacity: 50%;
257
+ opacity: var(--ard-select-dropdown-option-disabled-opacity, 50%);
202
258
  }
203
259
  }
204
260
  //divider
@@ -216,16 +272,16 @@
216
272
  .ard-add-custom {
217
273
  display: flex;
218
274
  align-items: flex-end;
219
- gap: 0.375rem;
275
+ gap: var(--ard-select-dropdown-add-custom-gap, 0.375rem);
220
276
 
221
277
  .ard-add-custom-label {
222
- font-size: 85%;
278
+ font-size: var(--ard-select-dropdown-add-custom-label-font-size, 85%);
223
279
  }
224
280
  }
225
281
 
226
282
  //! compact
227
283
  > .ard-compact {
228
- font-size: 0.85rem;
284
+ font-size: var(--ard-select-dropdown-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem));
229
285
  }
230
286
  }
231
287
 
@@ -2,150 +2,225 @@
2
2
  @use './coloring' as coloringMixins;
3
3
  @use '../variables' as ARD;
4
4
 
5
+ // the variables are commented out intentionally
6
+ // read more in docs/dev/css-variables.md
7
+ :root {
8
+ --ard-slide-toggle-height: 1.25em;
9
+ --ard-slide-toggle-hitbox-offset: -4px;
10
+ --ard-slide-toggle-track-width: 2.25em;
11
+ --ard-slide-toggle-track-height: 0.75em;
12
+ --ard-slide-toggle-track-opacity: 20%;
13
+ --ard-slide-toggle-track-selected-opacity: 40%;
14
+ --ard-slide-toggle-track-selected-opacity-no-color: 35%;
15
+ --ard-slide-toggle-handle-size: 1.25em;
16
+ --ard-slide-toggle-handle-icon-size: 0.95em;
17
+ --ard-slide-toggle-border-radius: 9999px;
18
+ --ard-slide-toggle-transition-duration: 0.1s;
19
+ --ard-slide-toggle-box-shadow-transition: 0.28s;
20
+ --ard-slide-toggle-hover-overlay-opacity: 4%;
21
+ --ard-slide-toggle-active-overlay-opacity: 12%;
22
+ --ard-slide-toggle-contained-height: 1.5em;
23
+ --ard-slide-toggle-contained-handle-size: 1.125em;
24
+ --ard-slide-toggle-contained-handle-margin: 0.25em;
25
+ --ard-slide-toggle-contained-border: 1px solid ARD.$detail-ultralight;
26
+ --ard-slide-toggle-disabled-opacity: 60%;
27
+ --ard-slide-toggle-disabled-track-opacity: 20%;
28
+ --ard-slide-toggle-disabled-track-opacity-unselected: 12.5%;
29
+ --ard-slide-toggle-disabled-overlay-opacity: 20%;
30
+ --ard-slide-toggle-disabled-icon-opacity: 60%;
31
+ }
32
+
5
33
  .ard-slide-toggle {
6
34
  @include coloringMixins.typeColors();
35
+
7
36
  position: relative;
8
- height: 1.25em;
37
+ height: var(--ard-slide-toggle-height, 1.25em);
9
38
  font-size: inherit;
10
39
  cursor: pointer;
11
40
  user-select: none;
12
41
  border: none;
13
42
  background: none;
43
+ border-radius: var(--ard-slide-toggle-border-radius, 9999px);
14
44
  padding: 0;
15
45
 
46
+ //! hitbox
16
47
  .ard-hitbox {
17
48
  position: absolute;
18
- left: -4px;
19
- right: -4px;
20
- bottom: -4px;
21
- top: -4px;
49
+ inset: var(--ard-slide-toggle-hitbox-offset, -4px);
22
50
  }
51
+
52
+ //! track
23
53
  .ard-slide-toggle-track {
24
54
  position: relative;
25
- width: 2.25em;
26
- height: 0.75em;
55
+ width: var(--ard-slide-toggle-track-width, 2.25em);
56
+ height: var(--ard-slide-toggle-track-height, 0.75em);
27
57
  font-size: inherit;
28
- border-radius: 999px;
58
+ border-radius: var(--ard-slide-toggle-border-radius, 9999px);
29
59
  overflow: hidden;
30
60
  background: ARD.$bg;
31
61
 
32
62
  .ard-slide-toggle-track-overlay {
33
63
  position: absolute;
34
- left: 0;
35
- right: 0;
36
- bottom: 0;
37
- top: 0;
64
+ inset: 0;
38
65
  background: ARD.$overlay;
39
- opacity: 20%;
66
+ opacity: var(--ard-slide-toggle-track-opacity, 20%);
67
+ transition: opacity var(--ard-slide-toggle-transition-duration, 0.1s) ease;
40
68
  }
41
69
  }
70
+
71
+ //! handle
42
72
  .ard-slide-toggle-handle {
43
- width: 1.25em;
44
- height: 1.25em;
73
+ width: var(--ard-slide-toggle-handle-size, 1.25em);
74
+ height: var(--ard-slide-toggle-handle-size, 1.25em);
45
75
  font-size: inherit;
46
- border-radius: 999px;
76
+ border-radius: var(--ard-slide-toggle-border-radius, 9999px);
47
77
  background: ARD.$bg-f;
48
78
  position: absolute;
49
79
  top: 0;
50
80
  left: 0;
51
81
  box-shadow: ARD.$simple-shadow;
52
82
  overflow: hidden;
53
-
54
83
  transition:
55
- box-shadow 0.28s ARD.$timing-fn,
56
- left 0.1s ease,
57
- background-color 0.1s ease,
58
- transform 0.1s ease;
84
+ box-shadow var(--ard-slide-toggle-box-shadow-transition, 0.28s) ARD.$timing-fn,
85
+ left var(--ard-slide-toggle-transition-duration, 0.1s) ease,
86
+ background-color var(--ard-slide-toggle-transition-duration, 0.1s) ease,
87
+ transform var(--ard-slide-toggle-transition-duration, 0.1s) ease;
59
88
 
60
89
  .ard-focus-overlay {
61
90
  @include defaultMixins.focus-overlay;
62
91
  background: var(--ard-cmpcl--overlay-colored);
63
92
  }
93
+
64
94
  .ard-slide-toggle-icon {
65
95
  @include defaultMixins.icon(0, 600);
66
- font-size: 0.95em;
96
+ font-size: var(--ard-slide-toggle-handle-icon-size, 0.95em);
67
97
  color: ARD.$text;
68
98
  position: absolute;
69
99
  left: 50%;
70
100
  top: 50%;
71
101
  transform: translate(-50%, -50%);
72
- transition: color 0.1s ease;
102
+ transition: color var(--ard-slide-toggle-transition-duration, 0.1s) ease;
73
103
 
74
104
  &.ard-icon-for-selected {
75
105
  display: none;
76
106
  }
77
- &.ard-icon-for-unselected {
78
- display: block;
79
- }
80
107
  }
81
108
  }
109
+
110
+ //! interaction states
82
111
  &:hover,
83
112
  &:focus {
84
113
  .ard-slide-toggle-handle {
85
114
  box-shadow: ARD.$simple-shadow2;
86
115
 
87
116
  .ard-focus-overlay {
88
- opacity: 4%;
117
+ opacity: var(--ard-slide-toggle-hover-overlay-opacity, 4%);
89
118
  }
90
119
  }
91
120
  }
121
+
92
122
  &:active {
93
123
  .ard-slide-toggle-handle {
94
124
  box-shadow: ARD.$simple-shadow3;
95
125
 
96
126
  .ard-focus-overlay {
97
- opacity: 12%;
127
+ opacity: var(--ard-slide-toggle-active-overlay-opacity, 12%);
98
128
  }
99
129
  }
100
130
  }
101
- }
102
- .ard-slide-toggle.ard-slide-toggle-selected {
103
- .ard-slide-toggle-track-overlay {
104
- background: var(--ard-cmpcl--content);
105
- opacity: 40%;
106
- }
107
- .ard-slide-toggle-handle {
108
- left: 100%;
109
- transform: translateX(-100%);
110
- background: var(--ard-cmpcl--bg);
111
131
 
112
- .ard-slide-toggle-icon {
113
- color: var(--ard-cmpcl--on-bg);
132
+ //! selected state
133
+ &.ard-slide-toggle-selected {
134
+ .ard-slide-toggle-track-overlay {
135
+ background: var(--ard-cmpcl--content);
136
+ opacity: var(--ard-slide-toggle-track-selected-opacity, 40%);
137
+ }
114
138
 
115
- &.ard-icon-for-selected {
116
- display: block;
117
- }
118
- &.ard-icon-for-unselected {
119
- display: none;
139
+ .ard-slide-toggle-handle {
140
+ left: 100%;
141
+ transform: translateX(-100%);
142
+ background: var(--ard-cmpcl--bg);
143
+
144
+ .ard-slide-toggle-icon {
145
+ color: var(--ard-cmpcl--on-bg);
146
+
147
+ &.ard-icon-for-selected {
148
+ display: block;
149
+ }
150
+ &.ard-icon-for-unselected {
151
+ display: none;
152
+ }
120
153
  }
121
154
  }
155
+
156
+ &.ard-color-none .ard-slide-toggle-track-overlay {
157
+ opacity: var(--ard-slide-toggle-track-selected-opacity-no-color, 35%);
158
+ }
122
159
  }
123
- //edge case for no coloring
124
- &.ard-color-none {
125
- .ard-slide-toggle-track-overlay {
126
- opacity: 35%;
160
+
161
+ //! contained appearance
162
+ &.ard-appearance-contained {
163
+ height: var(--ard-slide-toggle-contained-height, 1.5em);
164
+
165
+ .ard-slide-toggle-track {
166
+ height: var(--ard-slide-toggle-contained-height, 1.5em);
167
+ background: ARD.$bg-f;
168
+ border: var(--ard-slide-toggle-contained-border, 1px solid ARD.$detail-ultralight);
169
+ box-sizing: border-box;
170
+
171
+ .ard-slide-toggle-track-overlay {
172
+ background: var(--ard-cmpcl--content);
173
+ opacity: 0;
174
+ }
175
+ }
176
+
177
+ .ard-slide-toggle-handle {
178
+ width: var(--ard-slide-toggle-contained-handle-size, 1.125em);
179
+ height: var(--ard-slide-toggle-contained-handle-size, 1.125em);
180
+ background: ARD.$bg;
181
+ border: var(--ard-slide-toggle-contained-border, 1px solid ARD.$detail-ultralight);
182
+ box-shadow: none;
183
+ box-sizing: border-box;
184
+ top: 50%;
185
+ margin: 0 var(--ard-slide-toggle-contained-handle-margin, 0.25em);
186
+ transform: translateX(-1px) translateY(-50%);
187
+ }
188
+
189
+ &.ard-slide-toggle-selected {
190
+ .ard-slide-toggle-track {
191
+ border-color: var(--ard-cmpcl--content);
192
+ }
193
+
194
+ .ard-slide-toggle-track-overlay {
195
+ opacity: 100%;
196
+ }
197
+
198
+ .ard-slide-toggle-handle {
199
+ transform: translateX(calc(-100% - var(--ard-slide-toggle-contained-handle-margin, 0.25em) * 2 + 1px)) translateY(-50%);
200
+ }
127
201
  }
128
202
  }
129
203
  }
204
+
130
205
  //! disabled state
131
206
  .ard-disabled .ard-slide-toggle {
132
207
  pointer-events: none;
133
- opacity: 60%;
208
+ opacity: var(--ard-slide-toggle-disabled-opacity, 60%);
134
209
 
135
210
  .ard-slide-toggle-track-overlay {
136
- opacity: 20%;
211
+ opacity: var(--ard-slide-toggle-disabled-track-opacity, 20%);
137
212
  }
213
+
138
214
  .ard-focus-overlay {
139
- opacity: 20%;
215
+ opacity: var(--ard-slide-toggle-disabled-overlay-opacity, 20%);
140
216
  }
217
+
141
218
  .ard-slide-toggle-icon {
142
- opacity: 60%;
219
+ opacity: var(--ard-slide-toggle-disabled-icon-opacity, 60%);
143
220
  }
144
- //edge case for no coloring and for unselected state
145
- &.ard-color-none,
146
- &:not(.ard-slide-toggle-selected) {
147
- .ard-slide-toggle-track-overlay {
148
- opacity: 12.5%;
149
- }
221
+
222
+ &:not(.ard-slide-toggle-selected) .ard-slide-toggle-track-overlay,
223
+ &.ard-color-none .ard-slide-toggle-track-overlay {
224
+ opacity: var(--ard-slide-toggle-disabled-track-opacity-unselected, 12.5%);
150
225
  }
151
226
  }