@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
@@ -1,45 +1,60 @@
1
1
  @use '../variables' as ARD;
2
2
 
3
- ard-dropdown-panel {
4
- width: 100%;
5
- }
6
- .ard-dropdown-panel-container {
7
- position: relative;
8
- background: ARD.$bg;
9
- margin: 0.375rem 0;
10
- z-index: 5;
11
- width: 100%;
12
- overflow: hidden;
13
- box-sizing: border-box;
14
-
15
- //! variants
16
- &.ard-variant-rounded {
17
- border-radius: 0.5rem;
18
- }
19
- &.ard-variant-sharp {
20
- border-radius: 0;
3
+ @layer ard-ui {
4
+ // the variables are commented out intentionally
5
+ // read more in docs/dev/css-variables.md
6
+ :root {
7
+ // --ard-dropdown-panel-bg: ;
8
+ --ard-dropdown-panel-margin: 0.375rem 0;
9
+ --ard-dropdown-panel-margin-compact: 0.25rem 0;
10
+ --ard-dropdown-panel-z-index: 5;
11
+ --ard-dropdown-panel-rounded-corner-radius: 0.5rem;
12
+ --ard-dropdown-panel-rounded-corner-radius-compact: 0.375rem;
13
+ // --ard-dropdown-panel-border-color: ;
14
+ // --ard-dropdown-panel-shadow: ;
21
15
  }
22
16
 
23
- //! appearances
24
- &.ard-appearance-outlined {
25
- border: 1px solid ARD.$border;
26
- }
27
- &.ard-appearance-raised {
28
- box-shadow: ARD.$box-shadow;
17
+ ard-dropdown-panel {
18
+ width: 100%;
29
19
  }
20
+ .ard-dropdown-panel-container {
21
+ position: relative;
22
+ background: var(--ard-dropdown-panel-bg, #{ARD.$bg});
23
+ margin: var(--ard-dropdown-panel-margin, 0.375rem 0);
24
+ z-index: var(--ard-dropdown-panel-z-index, 5);
25
+ width: 100%;
26
+ overflow: hidden;
27
+ box-sizing: border-box;
30
28
 
31
- //! connected
32
- &.ard-connected {
33
- margin: 0;
34
- border-top: none;
35
- }
29
+ //! variants
30
+ &.ard-variant-rounded {
31
+ border-radius: var(--ard-dropdown-panel-rounded-corner-radius, 0.5rem);
32
+ }
33
+ &.ard-variant-sharp {
34
+ border-radius: 0;
35
+ }
36
36
 
37
- //! compact
38
- &.ard-compact {
39
- margin: 0.25rem 0;
37
+ //! appearances
38
+ &.ard-appearance-outlined {
39
+ border: 1px solid var(--ard-dropdown-panel-border-color, #{ARD.$border});
40
+ }
41
+ &.ard-appearance-raised {
42
+ box-shadow: var(--ard-dropdown-panel-shadow, #{ARD.$box-shadow});
43
+ }
40
44
 
41
- &.ard-variant-rounded {
42
- border-radius: 0.4rem;
45
+ //! connected
46
+ &.ard-connected {
47
+ margin: 0;
48
+ border-top: none;
49
+ }
50
+
51
+ //! compact
52
+ &.ard-compact {
53
+ margin: var(--ard-dropdown-panel-margin-compact, 0.25rem 0);
54
+
55
+ &.ard-variant-rounded {
56
+ border-radius: var(--ard-dropdown-panel-rounded-corner-radius-compact, 0.375rem);
57
+ }
43
58
  }
44
59
  }
45
60
  }
@@ -1,162 +1,221 @@
1
1
  @use './coloring' as CM;
2
2
 
3
- ard-file-drop-area {
4
- display: block;
5
- width: 100%;
6
- max-width: 100%;
7
- height: 100%;
8
- max-height: 100%;
9
- }
10
-
11
- .ard-file-drop-area {
12
- @include CM.typeColors();
13
- width: 100%;
14
- max-width: 100%;
15
- height: 100%;
16
- max-height: 100%;
17
- min-width: 15rem;
18
- min-height: 10rem;
19
- padding: 0.625rem;
20
- box-sizing: border-box;
21
- background: var(--ard-cmpcl--bg-colored-verylight);
22
- display: flex;
3
+ @layer ard-ui {
4
+ // the variables are commented out intentionally
5
+ // read more in docs/dev/css-variables.md
6
+ :root {
7
+ --ard-file-drop-area-min-width: 15rem;
8
+ --ard-file-drop-area-min-height: 10rem;
9
+ --ard-file-drop-area-padding: 0.625rem;
10
+ --ard-file-drop-area-outline-border-width: 2px;
11
+ --ard-file-drop-area-outline-border-style: dashed;
12
+ --ard-file-drop-area-outline-padding: 0.375rem;
13
+ --ard-file-drop-area-content-gap-min: 0.2rem;
14
+ --ard-file-drop-area-content-gap-preferred: 10%;
15
+ --ard-file-drop-area-content-gap-max: 1rem;
16
+ --ard-file-drop-area-icon-font-size: 220%;
17
+ --ard-file-drop-area-drop-text-font-weight: 500;
18
+ --ard-file-drop-area-drop-text-font-size: 105%;
19
+ --ard-file-drop-area-or-text-font-weight: 400;
20
+ --ard-file-drop-area-or-text-font-size: 95%;
21
+ --ard-file-drop-area-dragover-text-font-weight: 500;
22
+ --ard-file-drop-area-dragover-text-font-size: 105%;
23
+ --ard-file-drop-area-dragover-amount-font-weight: 600;
24
+ --ard-file-drop-area-dragover-amount-font-size: 120%;
25
+ --ard-file-drop-area-uploaded-container-gap: 0.75rem;
26
+ --ard-file-drop-area-uploaded-message-font-weight: 500;
27
+ --ard-file-drop-area-uploaded-message-font-size: 105%;
28
+ --ard-file-drop-area-uploaded-amount-font-weight: 600;
29
+ --ard-file-drop-area-uploaded-amount-font-size: 100%;
30
+ --ard-file-drop-area-uploaded-files-gap: 0.45rem;
31
+ --ard-file-drop-area-file-gap: 0.75rem;
32
+ --ard-file-drop-area-file-icon-font-size: 220%;
33
+ --ard-file-drop-area-file-info-gap: 0.5ch;
34
+ --ard-file-drop-area-filename-gap: 0;
35
+ --ard-file-drop-area-filename-name-line-height: 1;
36
+ --ard-file-drop-area-filename-name-height: 1em;
37
+ --ard-file-drop-area-filesize-font-weight: 500;
38
+ --ard-file-drop-area-filesize-font-size: 83%;
39
+ --ard-file-drop-area-filesize-opacity: 60%;
40
+ --ard-file-drop-area-variant-rounded-corner-radius: 0.875rem;
41
+ --ard-file-drop-area-outline-corner-radius: 0.25rem;
42
+ --ard-file-drop-area-font-size-compact: 85%;
43
+ --ard-file-drop-area-min-width-compact: 12rem;
44
+ --ard-file-drop-area-min-height-compact: 8rem;
45
+ --ard-file-drop-area-content-gap-min-compact: 0.1667rem;
46
+ --ard-file-drop-area-content-gap-preferred-compact: 10%;
47
+ --ard-file-drop-area-content-gap-max-compact: 0.75rem;
48
+ }
23
49
 
24
- .ard-file-drop-area-outline {
50
+ ard-file-drop-area {
51
+ display: block;
25
52
  width: 100%;
26
- min-height: 100%;
27
- box-sizing: border-box;
28
- border: 2px dashed var(--ard-cmpcl--border);
29
- padding: 0.375rem;
30
- pointer-events: none;
31
-
32
- * {
33
- pointer-events: none;
34
- user-select: none;
35
- }
36
- }
37
- .ard-file-drop-area-content {
53
+ max-width: 100%;
38
54
  height: 100%;
39
- display: flex;
40
- flex-direction: column;
41
- align-items: center;
42
- justify-content: center;
43
- gap: clamp(0.2rem, 10%, 1rem);
44
- padding: 0.2rem 0;
45
- box-sizing: border-box;
55
+ max-height: 100%;
46
56
  }
47
57
 
48
- //! state-specific styling
49
- //idle
50
- .ard-file-drop-area-icon {
51
- font-size: 220%;
52
- }
53
- .ard-file-drop-area-drop-text {
54
- font-weight: 500;
55
- font-size: 105%;
56
- }
57
- .ard-file-drop-area-or-text {
58
- font-size: 95%;
59
- }
60
- .ard-file-drop-area-browse-button > button {
61
- border: 1px solid var(--ard-cmpcl--border);
62
- pointer-events: all;
63
- }
64
- //dragover
65
- .ard-file-drop-area-dragover-text {
66
- font-weight: 500;
67
- font-size: 105%;
68
- }
69
- .ard-file-drop-area-dragover-amount {
70
- font-weight: 600;
71
- font-size: 120%;
72
- }
73
- //uploaded
74
- .ard-file-drop-area-uploaded-container {
75
- max-height: 100%;
76
- height: 100%;
58
+ .ard-file-drop-area {
59
+ @include CM.typeColors();
77
60
  width: 100%;
78
- display: grid;
79
- grid-template-columns: 1fr;
80
- grid-template-rows: max-content 1fr;
81
- gap: 0.75rem;
82
- justify-items: center;
83
- }
84
- .ard-file-drop-area-uploaded-message {
85
- font-weight: 500;
86
- font-size: 105%;
87
- }
88
- .ard-file-drop-area-uploaded-amount {
89
- font-weight: 600;
90
- }
91
- .ard-file-drop-area-uploaded-files {
92
61
  max-width: 100%;
93
- width: 100%;
94
- display: flex;
95
- flex-direction: column;
96
- align-items: flex-start;
97
- gap: 0.45rem;
98
- overflow: hidden auto;
62
+ height: 100%;
63
+ max-height: 100%;
64
+ min-width: var(--ard-file-drop-area-min-width, 15rem);
65
+ min-height: var(--ard-file-drop-area-min-height, 10rem);
66
+ padding: var(--ard-file-drop-area-padding, 0.625rem);
99
67
  box-sizing: border-box;
68
+ background: var(--ard-cmpcl--bg-colored-verylight);
69
+ display: flex;
100
70
 
101
- .ard-file-drop-area-file {
102
- max-width: 100%;
103
- display: grid;
104
- align-items: center;
105
- grid-template-columns: max-content 1fr;
106
- gap: 0.75rem;
107
- max-height: min-content;
71
+ .ard-file-drop-area-outline {
72
+ width: 100%;
73
+ min-height: 100%;
74
+ box-sizing: border-box;
75
+ border: var(--ard-file-drop-area-outline-border-width, 2px) var(--ard-file-drop-area-outline-border-style, dashed)
76
+ var(--ard-cmpcl--border);
77
+ padding: var(--ard-file-drop-area-outline-padding, 0.375rem);
78
+ pointer-events: none;
108
79
 
109
- ard-icon {
110
- font-size: 220%;
111
- }
112
- .ard-file-drop-area-file-info {
113
- display: flex;
114
- flex-direction: column;
115
- line-height: 1;
116
- gap: 0.5ch;
80
+ * {
81
+ pointer-events: none;
82
+ user-select: none;
117
83
  }
118
- .ard-file-drop-area-filename {
84
+ }
85
+ .ard-file-drop-area-content {
86
+ height: 100%;
87
+ display: flex;
88
+ flex-direction: column;
89
+ align-items: center;
90
+ justify-content: center;
91
+ gap: clamp(
92
+ var(--ard-file-drop-area-content-gap-min, 0.2rem),
93
+ var(--ard-file-drop-area-content-gap-preferred, 10%),
94
+ var(--ard-file-drop-area-content-gap-max, 1rem)
95
+ );
96
+ padding: var(--ard-file-drop-area-content-padding, 0.2rem 0);
97
+ box-sizing: border-box;
98
+ }
99
+
100
+ //! state-specific styling
101
+ //idle
102
+ .ard-file-drop-area-icon {
103
+ font-size: var(--ard-file-drop-area-icon-font-size, 220%);
104
+ }
105
+ .ard-file-drop-area-drop-text {
106
+ font-weight: var(--ard-file-drop-area-drop-text-font-weight, 500);
107
+ font-size: var(--ard-file-drop-area-drop-text-font-size, 105%);
108
+ }
109
+ .ard-file-drop-area-or-text {
110
+ font-weight: var(--ard-file-drop-area-or-text-font-weight, 400);
111
+ font-size: var(--ard-file-drop-area-or-text-font-size, 95%);
112
+ }
113
+ .ard-file-drop-area-browse-button > button {
114
+ border: 1px solid var(--ard-cmpcl--border);
115
+ pointer-events: all;
116
+ }
117
+ //dragover
118
+ .ard-file-drop-area-dragover-text {
119
+ font-weight: var(--ard-file-drop-area-dragover-text-font-weight, 500);
120
+ font-size: var(--ard-file-drop-area-dragover-text-font-size, 105%);
121
+ }
122
+ .ard-file-drop-area-dragover-amount {
123
+ font-weight: var(--ard-file-drop-area-dragover-amount-font-weight, 600);
124
+ font-size: var(--ard-file-drop-area-dragover-amount-font-size, 120%);
125
+ }
126
+ //uploaded
127
+ .ard-file-drop-area-uploaded-container {
128
+ max-height: 100%;
129
+ height: 100%;
130
+ width: 100%;
131
+ display: grid;
132
+ grid-template-columns: 1fr;
133
+ grid-template-rows: max-content 1fr;
134
+ gap: var(--ard-file-drop-area-uploaded-container-gap, 0.75rem);
135
+ justify-items: center;
136
+ }
137
+ .ard-file-drop-area-uploaded-message {
138
+ font-weight: var(--ard-file-drop-area-uploaded-message-font-weight, 500);
139
+ font-size: var(--ard-file-drop-area-uploaded-message-font-size, 105%);
140
+ }
141
+ .ard-file-drop-area-uploaded-amount {
142
+ font-weight: var(--ard-file-drop-area-uploaded-amount-font-weight, 600);
143
+ font-size: var(--ard-file-drop-area-uploaded-amount-font-size, 100%);
144
+ }
145
+ .ard-file-drop-area-uploaded-files {
146
+ max-width: 100%;
147
+ width: 100%;
148
+ display: flex;
149
+ flex-direction: column;
150
+ align-items: flex-start;
151
+ gap: var(--ard-file-drop-area-uploaded-files-gap, 0.45rem);
152
+ overflow: hidden auto;
153
+ box-sizing: border-box;
154
+
155
+ .ard-file-drop-area-file {
119
156
  max-width: 100%;
120
157
  display: grid;
121
- grid-template-columns: 1fr max-content;
122
- gap: 0;
123
- }
124
- .ard-file-drop-area-filename-name {
125
- max-width: 100%;
126
- line-height: 1;
127
- text-overflow: ellipsis;
128
- overflow: hidden;
129
- white-space: nowrap;
130
- height: 1em;
131
- }
132
- .ard-file-drop-area-filesize {
133
- font-weight: 500;
134
- font-size: 83%;
135
- opacity: 60%;
158
+ align-items: center;
159
+ grid-template-columns: max-content 1fr;
160
+ gap: var(--ard-file-drop-area-file-gap, 0.75rem);
161
+ max-height: min-content;
162
+
163
+ ard-icon {
164
+ font-size: var(--ard-file-drop-area-file-icon-font-size, 220%);
165
+ }
166
+ .ard-file-drop-area-file-info {
167
+ display: flex;
168
+ flex-direction: column;
169
+ line-height: 1;
170
+ gap: var(--ard-file-drop-area-file-info-gap, 0.5ch);
171
+ }
172
+ .ard-file-drop-area-filename {
173
+ max-width: 100%;
174
+ display: grid;
175
+ grid-template-columns: 1fr max-content;
176
+ gap: var(--ard-file-drop-area-filename-gap, 0);
177
+ }
178
+ .ard-file-drop-area-filename-name {
179
+ max-width: 100%;
180
+ line-height: var(--ard-file-drop-area-filename-name-line-height, 1);
181
+ text-overflow: ellipsis;
182
+ overflow: hidden;
183
+ white-space: nowrap;
184
+ height: var(--ard-file-drop-area-filename-name-height, 1em);
185
+ }
186
+ .ard-file-drop-area-filesize {
187
+ font-weight: var(--ard-file-drop-area-filesize-font-weight, 500);
188
+ font-size: var(--ard-file-drop-area-filesize-font-size, 83%);
189
+ opacity: var(--ard-file-drop-area-filesize-opacity, 60%);
190
+ }
136
191
  }
137
192
  }
138
- }
139
193
 
140
- //! variant
141
- &.ard-variant-rounded,
142
- &.ard-variant-pill {
143
- border-radius: 0.875rem;
194
+ //! variant
195
+ &.ard-variant-rounded,
196
+ &.ard-variant-pill {
197
+ border-radius: var(--ard-file-drop-area-variant-rounded-corner-radius, 0.875rem);
144
198
 
145
- .ard-file-drop-area-outline {
146
- border-radius: 0.25rem;
199
+ .ard-file-drop-area-outline {
200
+ border-radius: var(--ard-file-drop-area-outline-corner-radius, 0.25rem);
201
+ }
147
202
  }
148
- }
149
- &.ard-variant-sharp {
150
- border-radius: 0;
151
- }
152
- //! compact
153
- &.ard-compact {
154
- font-size: 85%;
155
- min-width: 12rem;
156
- min-height: 8rem;
203
+ &.ard-variant-sharp {
204
+ border-radius: 0;
205
+ }
206
+ //! compact
207
+ &.ard-compact {
208
+ font-size: var(--ard-file-drop-area-font-size-compact, 85%);
209
+ min-width: var(--ard-file-drop-area-min-width-compact, 12rem);
210
+ min-height: var(--ard-file-drop-area-min-height-compact, 8rem);
157
211
 
158
- .ard-file-drop-area-content {
159
- gap: clamp(0.1667rem, 10%, 0.75rem);
212
+ .ard-file-drop-area-content {
213
+ gap: clamp(
214
+ var(--ard-file-drop-area-content-gap-min-compact, 0.1667rem),
215
+ var(--ard-file-drop-area-content-gap-preferred-compact, 10%),
216
+ var(--ard-file-drop-area-content-gap-max-compact, 0.75rem)
217
+ );
218
+ }
160
219
  }
161
220
  }
162
221
  }
@@ -1,81 +1,91 @@
1
1
  @use './mixins' as defaultMixins;
2
2
  @use '../variables' as ARD;
3
3
 
4
- .ard-form-field-frame {
5
- box-sizing: border-box;
6
- min-height: ARD.$form-field-height;
7
- height: max-content;
8
- max-width: 100%;
9
- display: flex;
10
- align-items: center;
11
- justify-content: stretch;
12
- position: relative;
13
- font-size: 1rem;
14
- line-height: 1.25em;
15
- font-family: 'Roboto', sans-serif;
16
-
17
- .ard-form-field-content-container {
18
- flex-grow: 1;
19
- min-height: inherit;
20
-
21
- > * {
22
- min-height: inherit;
23
- }
24
- }
25
- .ard-form-field-prefix-container,
26
- .ard-form-field-suffix-container {
4
+ @layer ard-ui {
5
+ .ard-form-field-frame {
6
+ box-sizing: border-box;
7
+ min-height: ARD.$form-field-height;
27
8
  height: max-content;
28
- max-height: 100%;
9
+ max-width: 100%;
29
10
  display: flex;
30
11
  align-items: center;
31
- }
32
- .ard-form-field-prefix-container {
33
- padding-left: 0.375em;
34
- }
35
- .ard-form-field-suffix-container {
36
- padding-right: 0.375em;
37
- }
12
+ justify-content: stretch;
13
+ position: relative;
14
+ font-family: var(--ard-font-family);
38
15
 
39
- //! compact
40
- &.ard-compact {
41
- min-height: ARD.$form-field-compact-height;
42
- font-size: 0.85rem;
43
- line-height: 1;
44
- }
16
+ .ard-form-field-content-container {
17
+ flex-grow: 1;
18
+ min-height: inherit;
45
19
 
46
- //! appearance & variant
47
- @include defaultMixins.formAppearances();
48
- @include defaultMixins.formVariants();
49
- background: var(--ard-appearance-background);
50
- border: var(--ard-appearance-border);
51
- transition: border-color 0.15s ARD.$timing-fn;
20
+ > * {
21
+ min-height: inherit;
22
+ }
23
+ }
24
+ .ard-form-field-prefix-container,
25
+ .ard-form-field-suffix-container {
26
+ height: max-content;
27
+ max-height: 100%;
28
+ display: flex;
29
+ align-items: center;
30
+ }
31
+ .ard-form-field-prefix-container {
32
+ padding-left: var(--ard-form-field-padding-left, 0.375rem);
33
+ }
34
+ .ard-form-field-suffix-container {
35
+ padding-right: var(--ard-form-field-padding-right, 0.375rem);
36
+ }
52
37
 
53
- .ard-form-field-overlay {
54
- background: ARD.$overlay;
55
- opacity: 0;
56
- transition:
57
- opacity 0.15s ARD.$timing-fn,
58
- background-color 0.15s ARD.$timing-fn;
59
- }
38
+ //! compact
39
+ &.ard-compact {
40
+ min-height: ARD.$form-field-compact-height;
41
+ }
42
+
43
+ //! appearance & variant
44
+ @include defaultMixins.formAppearances();
45
+ @include defaultMixins.formVariants();
46
+ background: var(--ard-appearance-background);
47
+ border: var(--ard-appearance-border);
60
48
 
61
- &:hover {
62
49
  .ard-form-field-overlay {
63
- opacity: 3%;
50
+ background: ARD.$overlay;
51
+ opacity: 0;
64
52
  }
65
- }
66
- &.ard-focused {
67
- .ard-form-field-overlay {
68
- opacity: 6%;
53
+
54
+ &:hover {
55
+ .ard-form-field-overlay {
56
+ opacity: var(--ard-form-field-hover-overlay-opacity, 3%);
57
+ }
58
+ }
59
+ &.ard-focused {
60
+ .ard-form-field-overlay {
61
+ opacity: var(--ard-form-field-focus-overlay-opacity, 6%);
62
+ }
63
+ }
64
+ &.ard-enable-transitions {
65
+ transition: border-color var(--ard-form-field-transitions-duration, 150ms) ARD.$timing-fn;
66
+
67
+ .ard-form-field-overlay {
68
+ transition:
69
+ opacity var(--ard-form-field-transitions-duration, 150ms) ARD.$timing-fn,
70
+ background-color var(--ard-form-field-transitions-duration, 150ms) ARD.$timing-fn;
71
+ }
69
72
  }
70
73
  }
71
- }
72
- .ard-disabled .ard-form-field-frame {
73
- pointer-events: none;
74
- opacity: 50%;
74
+ .ard-disabled .ard-form-field-frame {
75
+ pointer-events: none;
76
+ opacity: var(--ard-form-field-disabled-opacity, 50%);
75
77
 
76
- &.ard-appearance-transparent {
77
- .ard-form-field-overlay {
78
- opacity: 4.5%;
78
+ &.ard-appearance-transparent {
79
+ .ard-form-field-overlay {
80
+ opacity: var(--ard-form-field-disabled-transparent-overlay-opacity, 4.5%);
81
+ }
82
+ }
83
+ }
84
+ .ard-readonly .ard-form-field-frame {
85
+ &:hover {
86
+ .ard-form-field-overlay {
87
+ opacity: 0;
88
+ }
79
89
  }
80
90
  }
81
91
  }