@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
@@ -1,135 +1,181 @@
1
1
  @use '../variables' as ARD;
2
2
 
3
- ard-card,
4
- .ard-card {
5
- position: relative;
6
- background: ARD.$bg;
7
- box-sizing: border-box;
8
- width: 100%;
9
- height: max-content;
10
- display: block;
3
+ @layer ard-ui {
4
+ // the variables are commented out intentionally
5
+ // read more in docs/dev/css-variables.md
6
+ :root {
7
+ // --ard-card-bg: ;
8
+ // --ard-card-rounded-corner-radius: ;
9
+ // --ard-card-border-color: ;
11
10
 
12
- //! appearances
13
- &.ard-appearance-outlined {
14
- border: 1px solid ARD.$border-light;
15
- }
16
- &.ard-appearance-raised {
17
- box-shadow: ARD.$card-shadow;
18
- }
19
- //! variants
20
- &.ard-variant-sharp {
21
- border-radius: 0;
22
- }
23
- &.ard-variant-rounded {
24
- border-radius: 8px;
11
+ --ard-card-content-padding-top: 0;
12
+ --ard-card-content-padding-right: 1em;
13
+ --ard-card-content-padding-bottom: 0;
14
+ --ard-card-content-padding-left: 1em;
15
+
16
+ --ard-card-header-padding-top: 0.5em;
17
+ --ard-card-header-padding-right: 1em;
18
+ --ard-card-header-padding-bottom: 0;
19
+ --ard-card-header-padding-left: 1em;
20
+ --ard-card-header-margin-bottom: 1em;
21
+
22
+ // --ard-card-title-color: ;
23
+ --ard-card-title-font-size: 1.375em;
24
+ --ard-card-title-letter-spacing: 0.0125em;
25
+ --ard-card-title-font-weight: 500;
26
+ --ard-card-title-margin-top: 0;
27
+ // --ard-card-subtitle-color: ;
28
+ --ard-card-subtitle-font-size: 1.375em;
29
+ --ard-card-subtitle-letter-spacing: 0.0125em;
30
+ --ard-card-subtitle-font-weight: 500;
31
+ --ard-card-subtitle-margin-top: 0;
32
+
33
+ --ard-card-avatar-size: 3em;
34
+
35
+ --ard-card-action-buttons-padding: 0.5em;
25
36
  }
26
- }
27
- //! header
28
- ard-card-header {
29
- padding: 0.5em 1em 0 1em;
30
- display: flex;
31
- align-items: center;
32
- margin-bottom: 1em;
33
- max-width: 100%;
34
37
 
35
- .ard-card-header-title-container {
38
+ ard-card,
39
+ .ard-card {
40
+ position: relative;
41
+ background: var(--ard-card-bg, #{ARD.$bg});
42
+ box-sizing: border-box;
43
+ width: 100%;
44
+ height: max-content;
45
+ display: block;
46
+
47
+ //! appearances
48
+ &.ard-appearance-outlined {
49
+ border: 1px solid var(--ard-card-border-color, #{ARD.$border-light});
50
+ }
51
+ &.ard-appearance-raised {
52
+ box-shadow: ARD.$card-shadow;
53
+ }
54
+ //! variants
55
+ &.ard-variant-sharp {
56
+ border-radius: 0;
57
+ }
58
+ &.ard-variant-rounded {
59
+ border-radius: var(--ard-card-rounded-corner-radius, var(--ard-rounded-corner-radius, 0.375rem));
60
+ }
61
+ }
62
+ //! header
63
+ ard-card-header {
64
+ padding-top: var(--ard-card-header-padding-top, var(--ard-card-content-padding-top, 0.5em));
65
+ padding-right: var(--ard-card-header-padding-right, var(--ard-card-content-padding-right, 1em));
66
+ padding-bottom: var(--ard-card-header-padding-bottom, var(--ard-card-content-padding-bottom, 0));
67
+ padding-left: var(--ard-card-header-padding-left, var(--ard-card-content-padding-left, 1em));
36
68
  display: flex;
37
- flex-direction: column;
38
- justify-content: center;
39
- }
69
+ align-items: center;
70
+ margin-bottom: var(--ard-card-header-margin-bottom, 1em);
71
+ max-width: 100%;
40
72
 
41
- &:first-child {
42
- padding-top: 1em;
43
- }
44
- }
45
- .ard-card-title,
46
- .ard-card-subtitle {
47
- line-height: normal;
48
- display: block;
49
- margin: 0;
50
- font-weight: 500;
51
- }
52
- .ard-card-title {
53
- font-size: 1.375em;
54
- letter-spacing: 0.0125em;
55
- color: ARD.$text;
56
- }
57
- .ard-card-subtitle {
58
- font-size: 1em;
59
- letter-spacing: 0.0078125em;
60
- color: ARD.$text3;
61
- margin-top: 0.125rem;
62
- }
63
- .ard-card-avatar {
64
- display: block;
65
- width: 3em;
66
- height: 3em;
67
- border-radius: 9999px;
68
- flex-shrink: 0;
69
- object-fit: cover;
73
+ .ard-card-header-title-container {
74
+ display: flex;
75
+ flex-direction: column;
76
+ justify-content: center;
77
+ }
70
78
 
71
- ~ .ard-card-header-title-container {
72
- padding: 0 1em;
73
- }
74
- }
75
- //! image
76
- .ard-card-image {
77
- position: relative;
78
- box-sizing: border-box;
79
- background-repeat: no-repeat;
80
- background-position: center;
81
- background-size: cover;
82
- max-width: 100%;
79
+ &:first-child {
80
+ padding-top: var(--ard-card-content-padding-top, 0.5em);
81
+ }
82
+ }
83
+ .ard-card-title,
84
+ .ard-card-subtitle {
85
+ display: block;
86
+ margin: 0;
87
+ }
88
+ .ard-card-title {
89
+ color: var(--ard-card-title-color, #{ARD.$text});
90
+ font-size: var(--ard-card-title-font-size, 1.375em);
91
+ letter-spacing: var(--ard-card-title-letter-spacing, 0.0125em);
92
+ font-weight: var(--ard-card-title-font-weight, 500);
93
+ margin-top: var(--ard-card-title-margin-top, 0);
94
+ }
95
+ .ard-card-subtitle {
96
+ color: var(--ard-card-subtitle-color, #{ARD.$text3});
97
+ font-size: var(--ard-card-subtitle-font-size, 1.375em);
98
+ letter-spacing: var(--ard-card-subtitle-letter-spacing, 0.0125em);
99
+ font-weight: var(--ard-card-subtitle-font-weight, 500);
100
+ margin-top: var(--ard-card-subtitle-margin-top, 0);
101
+ }
102
+ .ard-card-avatar {
103
+ display: block;
104
+ width: var(--ard-card-avatar-size, 3em);
105
+ height: var(--ard-card-avatar-size, 3em);
106
+ border-radius: 9999px;
107
+ flex-shrink: 0;
108
+ object-fit: cover;
83
109
 
84
- &:first-child {
85
- border-top-left-radius: inherit;
86
- border-top-right-radius: inherit;
87
- }
88
- &:last-child {
89
- border-bottom-left-radius: inherit;
90
- border-bottom-right-radius: inherit;
91
- }
92
- }
93
- ard-card,
94
- .ard-card {
95
- .ard-appearance-outlined .ard-image {
96
- border-bottom: 1px solid ARD.$border-light;
97
- }
98
- }
99
- //! content
100
- .ard-card-content {
101
- padding: 0 1em;
102
- display: block;
103
- max-width: 100%;
110
+ ~ .ard-card-header-title-container {
111
+ padding-top: var(--ard-card-content-padding-top, 0);
112
+ padding-right: var(--ard-card-content-padding-right, 1em);
113
+ padding-bottom: var(--ard-card-content-padding-bottom, 0);
114
+ padding-left: var(--ard-card-content-padding-left, 0);
115
+ }
116
+ }
117
+ //! image
118
+ .ard-card-image {
119
+ position: relative;
120
+ box-sizing: border-box;
121
+ background-repeat: no-repeat;
122
+ background-position: center;
123
+ background-size: cover;
124
+ max-width: 100%;
104
125
 
105
- &:first-child {
106
- padding-top: 1em;
107
- }
108
- &:last-child {
109
- padding-bottom: 1em;
110
- }
126
+ &:first-child {
127
+ border-top-left-radius: inherit;
128
+ border-top-right-radius: inherit;
129
+ }
130
+ &:last-child {
131
+ border-bottom-left-radius: inherit;
132
+ border-bottom-right-radius: inherit;
133
+ }
134
+ }
135
+ ard-card,
136
+ .ard-card {
137
+ .ard-appearance-outlined .ard-image {
138
+ border-bottom: 1px solid var(--ard-card-border-color, #{ARD.$border-light});
139
+ }
140
+ }
141
+ //! content
142
+ .ard-card-content {
143
+ padding-top: var(--ard-card-content-padding-top, var(--ard-card-content-padding, 0));
144
+ padding-right: var(--ard-card-content-padding-right, var(--ard-card-content-padding, 1em));
145
+ padding-bottom: var(--ard-card-content-padding-bottom, var(--ard-card-content-padding, 0));
146
+ padding-left: var(--ard-card-content-padding-left, var(--ard-card-content-padding, 1em));
147
+ display: block;
148
+ max-width: 100%;
111
149
 
112
- > :last-child {
113
- margin-bottom: 0;
114
- }
115
- }
116
- //! action buttons
117
- .ard-card-action-buttons {
118
- padding: 0.5em;
119
- display: flex;
120
- flex-direction: row;
121
- align-items: center;
122
- max-width: 100%;
150
+ &:first-child {
151
+ padding-top: var(--ard-card-content-padding-top, var(--ard-card-content-padding, 0));
152
+ }
153
+ &:last-child {
154
+ padding-bottom: var(--ard-card-content-padding-bottom, var(--ard-card-content-padding, 0));
155
+ }
123
156
 
124
- &.ard-align-left {
125
- justify-content: flex-start;
126
- }
127
- &.ard-align-middle {
128
- justify-content: center;
129
- }
130
- &.ard-align-right {
131
- justify-content: flex-end;
157
+ > :last-child {
158
+ margin-bottom: 0;
159
+ }
132
160
  }
161
+ //! action buttons
162
+ .ard-card-action-buttons {
163
+ padding: var(--ard-card-action-buttons-padding, 0.5em);
164
+ display: flex;
165
+ flex-direction: row;
166
+ align-items: center;
167
+ max-width: 100%;
168
+
169
+ &.ard-align-left {
170
+ justify-content: flex-start;
171
+ }
172
+ &.ard-align-center {
173
+ justify-content: center;
174
+ }
175
+ &.ard-align-right {
176
+ justify-content: flex-end;
177
+ }
178
+ }
179
+ //! footer
180
+ //no styling needed
133
181
  }
134
- //! footer
135
- //no styling needed
@@ -1,83 +1,111 @@
1
1
  @use './mixins' as CM;
2
2
  @use '../variables' as ARD;
3
3
 
4
- .ard-checkbox-list {
5
- display: flex;
6
- flex-direction: column;
4
+ @layer ard-ui {
5
+ :root {
6
+ --ard-checkbox-list-padding: 0.375rem 0;
7
+ --ard-checkbox-list-item-hover-opacity: 5%;
8
+ --ard-checkbox-list-item-active-opacity: 15%;
9
+ --ard-checkbox-list-item-height: 3rem;
10
+ --ard-checkbox-list-item-height-compact: 2rem;
11
+ --ard-checkbox-list-checkbox-min-width: 1.25rem;
12
+ --ard-checkbox-list-checkbox-padding: 0.625rem;
13
+ --ard-checkbox-list-item-padding: 0 0.5rem 0 0;
14
+ --ard-checkbox-list-gap: 0;
15
+ --ard-checkbox-list-gap-compact: 0;
16
+ --ard-checkbox-list-item-gap: 0.5rem;
17
+ --ard-checkbox-list-item-gap-compact: 0.325rem;
18
+ --ard-checkbox-list-disabled-opacity: 50%;
19
+ }
7
20
 
8
- .ard-checkbox-list__item {
21
+ .ard-checkbox-list {
9
22
  display: flex;
10
- align-items: center;
11
- gap: 0.5rem;
12
- padding: 0 1rem;
13
- position: relative;
14
- cursor: pointer;
15
- height: 3rem;
23
+ flex-direction: column;
24
+ padding: var(--ard-checkbox-list-padding, 0.375rem 0);
25
+ gap: var(--ard-checkbox-list-gap, 0);
16
26
 
17
- > label {
18
- pointer-events: none;
19
- user-select: none;
20
- }
21
- > .ard-focus-overlay {
22
- @include CM.focus-overlay();
23
- background: ARD.$overlay;
24
- }
25
- &.ard-item-highlighted {
26
- > .ard-focus-overlay {
27
- opacity: 5%;
27
+ .ard-checkbox-list__item {
28
+ display: flex;
29
+ align-items: center;
30
+ justify-content: stretch;
31
+ gap: var(--ard-checkbox-list-item-gap, 0.5rem);
32
+ padding: var(--ard-checkbox-list-item-padding, 0 0.5rem 0 0);
33
+ position: relative;
34
+ cursor: pointer;
35
+ height: max-content;
36
+ min-height: var(--ard-checkbox-list-item-height, 3rem);
37
+
38
+ > label {
39
+ pointer-events: none;
40
+ user-select: none;
41
+ flex-grow: 1;
42
+ padding: 0;
43
+ min-height: var(--ard-checkbox-list-item-height, 3rem);
44
+ display: flex;
45
+ align-items: center;
28
46
  }
29
- }
30
- &:active {
31
47
  > .ard-focus-overlay {
32
- opacity: 15%;
48
+ @include CM.focus-overlay();
49
+ background: ARD.$overlay;
33
50
  }
34
- }
35
- ard-checkbox {
36
- padding: 0.625rem;
51
+ &.ard-item-highlighted {
52
+ > .ard-focus-overlay {
53
+ opacity: var(--ard-checkbox-list-item-hover-opacity, 5%);
54
+ }
55
+ }
56
+ &:active {
57
+ > .ard-focus-overlay {
58
+ opacity: var(--ard-checkbox-list-item-active-opacity, 15%);
59
+ }
60
+ }
61
+ ard-checkbox {
62
+ padding: var(--ard-checkbox-list-checkbox-padding, 0.625rem);
63
+ min-width: var(--ard-checkbox-list-checkbox-min-width, 1.25rem);
37
64
 
38
- .ard-checkbox {
39
- .ard-focus-overlay {
40
- display: none;
65
+ .ard-checkbox {
66
+ .ard-focus-overlay {
67
+ display: none;
68
+ }
41
69
  }
42
70
  }
43
- }
44
- &.ard-item-disabled {
45
- pointer-events: none;
71
+ &.ard-item-disabled {
72
+ pointer-events: none;
46
73
 
47
- > label {
48
- opacity: 50%;
74
+ > label {
75
+ opacity: var(--ard-checkbox-list-disabled-opacity, 50%);
76
+ }
49
77
  }
50
78
  }
51
- }
52
- &.ard-compact {
53
- .ard-checkbox-list__item {
54
- gap: 0.325rem;
55
- height: 2rem;
56
- }
57
- }
58
- //! ALIGN TYPES
59
- &.ard-align-left-clumped,
60
- &.ard-align-left-split {
61
- .ard-checkbox-list__item {
62
- flex-direction: row;
79
+ &.ard-compact {
80
+ gap: var(--ard-checkbox-list-gap-compact, 0);
81
+
82
+ .ard-checkbox-list__item {
83
+ gap: var(--ard-checkbox-list-item-gap-compact, 0.325rem);
84
+ height: var(--ard-checkbox-list-item-height-compact, 2rem);
85
+ }
63
86
  }
64
- }
65
- &.ard-align-right-clumped,
66
- &.ard-align-right-split {
67
- .ard-checkbox-list__item {
68
- flex-direction: row-reverse;
87
+ //! ALIGN TYPES
88
+ &.ard-align-left-clumped,
89
+ &.ard-align-right-split {
90
+ .ard-checkbox-list__item {
91
+ label {
92
+ justify-content: flex-start;
93
+ }
94
+ }
69
95
  }
70
- }
71
- &.ard-align-left-clumped,
72
- &.ard-align-right-clumped {
73
- .ard-checkbox-list__item {
74
- justify-content: flex-start;
96
+ &.ard-align-left-split,
97
+ &.ard-align-right-clumped {
98
+ .ard-checkbox-list__item {
99
+ label {
100
+ justify-content: flex-end;
101
+ }
102
+ }
75
103
  }
76
- }
77
- &.ard-align-left-split,
78
- &.ard-align-right-split {
79
- .ard-checkbox-list__item {
80
- justify-content: space-between;
104
+ &.ard-align-right-split,
105
+ &.ard-align-right-clumped {
106
+ .ard-checkbox-list__item {
107
+ flex-direction: row-reverse;
108
+ }
81
109
  }
82
110
  }
83
111
  }
@@ -2,108 +2,81 @@
2
2
  @use './coloring' as coloringMixins;
3
3
  @use '../variables' as ARD;
4
4
 
5
- .ard-checkbox {
6
- @include coloringMixins.typeColors();
7
- @include coloringMixins.typeColors('unsel-cmpcl');
8
- position: relative;
9
- cursor: pointer;
10
- user-select: none;
11
- width: 1.25em;
12
- height: 1.25em;
13
- display: flex;
14
- justify-content: center;
15
- align-items: center;
16
- border: none;
17
- background: none;
18
- padding: 0;
19
- outline: none;
20
- color: ARD.$text2;
21
-
22
- &.ard-color-currentColor {
23
- color: currentColor;
5
+ @layer ard-ui {
6
+ // the variables are commented out intentionally
7
+ // read more in docs/dev/css-variables.md
8
+ :root {
9
+ --ard-checkbox-size: 1.25em;
10
+ --ard-checkbox-icon-size: 1em;
11
+ --ard-checkbox-icon-size: 1.8em;
12
+ --ard-checkbox-hitbox-offset: -4px;
13
+ --ard-checkbox-overlay-offset: 0.4em;
14
+ --ard-checkbox-unselected-disabled-opacity: 40%;
15
+ --ard-checkbox-indeterminate-disabled-opacity: 50%;
16
+ --ard-checkbox-selected-disabled-opacity: 50%;
17
+ // --ard-checkbox-base-color: ;
24
18
  }
25
19
 
26
- .ard-hitbox {
27
- position: absolute;
28
- left: -4px;
29
- right: -4px;
30
- bottom: -4px;
31
- top: -4px;
32
- }
33
- .ard-focus-overlay {
34
- @include defaultMixins.focus-overlay(0.4em);
35
- border-radius: 999px;
36
- background: currentColor;
37
- }
38
- .ard-checkbox-icon {
39
- position: absolute;
40
- top: 50%;
41
- left: 50%;
42
- transform: translate(-50%, -50%);
43
- height: 1.8em; //the height of the icon
44
- display: none;
45
- opacity: 80%;
46
- transition: opacity 0.2s ARD.$timing-fn;
20
+ .ard-checkbox {
21
+ @include coloringMixins.typeColors();
22
+ @include coloringMixins.typeColors('unsel-cmpcl');
23
+ position: relative;
24
+ cursor: pointer;
25
+ user-select: none;
26
+ width: var(--ard-checkbox-size, 1.25em);
27
+ height: var(--ard-checkbox-size, 1.25em);
28
+ display: flex;
29
+ justify-content: center;
30
+ align-items: center;
31
+ border: none;
32
+ background: none;
33
+ padding: 0;
34
+ outline: none;
35
+ color: var(--ard-checkbox-base-color, #{ARD.$text2});
36
+ font-size: var(--ard-checkbox-icon-size, 1em); // ard-icon component will inherit this font-size to determine its size
47
37
 
48
- &::after {
49
- @include defaultMixins.icon(0, 600);
38
+ &.ard-color-currentColor.ard-state-selected {
39
+ color: currentColor;
50
40
  }
51
- }
52
- .ard-icon-for-selected::after {
53
- @include defaultMixins.icon(1, 500);
54
- content: 'check_box';
55
- }
56
- .ard-icon-for-indeterminate::after {
57
- content: 'indeterminate_check_box';
58
- }
59
- .ard-icon-for-unselected::after {
60
- content: 'check_box_outline_blank';
61
- }
62
-
63
- &.ard-checkbox-selected {
64
- color: var(--ard-unsel-cmpcl--bg-colored);
65
41
 
66
- .ard-checkbox-icon {
67
- opacity: 90%;
68
- }
69
- }
70
- &.ard-checkbox-selected {
71
- .ard-icon-for-selected {
72
- display: block;
73
- }
74
- }
75
- &.ard-checkbox-indeterminate {
76
- .ard-icon-for-indeterminate {
77
- display: block;
42
+ .ard-hitbox {
43
+ position: absolute;
44
+ left: var(--ard-checkbox-hitbox-offset, -4px);
45
+ right: var(--ard-checkbox-hitbox-offset, -4px);
46
+ bottom: var(--ard-checkbox-hitbox-offset, -4px);
47
+ top: var(--ard-checkbox-hitbox-offset, -4px);
78
48
  }
79
- }
80
- &.ard-checkbox-unselected {
81
- .ard-icon-for-unselected {
82
- display: block;
49
+ .ard-focus-overlay {
50
+ @include defaultMixins.focus-overlay(var(--ard-checkbox-overlay-offset, 0.4em));
51
+ border-radius: 9999px;
52
+ background: currentColor;
83
53
  }
84
- }
85
- &:hover,
86
- &:focus {
87
- .ard-checkbox-icon {
88
- opacity: 100%;
54
+
55
+ &.ard-checkbox-selected {
56
+ color: var(--ard-unsel-cmpcl--bg-colored);
89
57
  }
90
- .ard-focus-overlay {
91
- opacity: 10%;
58
+ &:hover,
59
+ &:focus {
60
+ .ard-focus-overlay {
61
+ opacity: 10%;
62
+ }
92
63
  }
93
- }
94
- &:active {
95
- .ard-focus-overlay {
96
- opacity: 20%;
64
+ &:active {
65
+ .ard-focus-overlay {
66
+ opacity: 20%;
67
+ }
97
68
  }
98
69
  }
99
- }
100
- //! disabled state
101
- .ard-disabled .ard-checkbox {
102
- pointer-events: none;
103
- opacity: 40%;
70
+ //! disabled state
71
+ .ard-disabled .ard-checkbox {
72
+ pointer-events: none;
73
+ opacity: var(--ard-checkbox-unselected-disabled-opacity, 40%);
104
74
 
105
- &.ard-checkbox-selected,
106
- &.ard-checkbox-indeterminate {
107
- opacity: 50%;
75
+ &.ard-checkbox-selected {
76
+ opacity: var(--ard-checkbox-selected-disabled-opacity, 50%);
77
+ }
78
+ &.ard-checkbox-indeterminate {
79
+ opacity: var(--ard-checkbox-indeterminate-disabled-opacity, 50%);
80
+ }
108
81
  }
109
82
  }