@ardium-ui/ui 5.0.0-alpha.9 → 5.0.0-alpha.90

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