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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (293) hide show
  1. package/fesm2022/ardium-ui-ui.mjs +4707 -2272
  2. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  3. package/lib/_internal/boolean-component.d.ts +13 -1
  4. package/lib/_internal/disablable-component.d.ts +2 -1
  5. package/lib/_internal/focusable-component.d.ts +2 -1
  6. package/lib/_internal/form-field-component.d.ts +3 -2
  7. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +19 -19
  8. package/lib/_internal/item-storages/simple-item-storage.d.ts +15 -12
  9. package/lib/_internal/item-storages/simplest-item-storage.d.ts +1 -1
  10. package/lib/_internal/ngmodel-component.d.ts +5 -8
  11. package/lib/_internal/selectable-list-component.d.ts +6 -6
  12. package/lib/_internal/utils/date.utils.d.ts +16 -0
  13. package/lib/badge/badge.directive.d.ts +3 -2
  14. package/lib/breakpoints/breakpoint.service.d.ts +12 -0
  15. package/lib/breakpoints/breakpoint.utils.d.ts +7 -0
  16. package/lib/breakpoints/breakpoints.d.ts +13 -0
  17. package/lib/breakpoints/index.d.ts +2 -0
  18. package/lib/buttons/_button-base.d.ts +12 -8
  19. package/lib/buttons/_button-base.defaults.d.ts +3 -2
  20. package/lib/buttons/button/button.component.d.ts +5 -5
  21. package/lib/buttons/button/button.defaults.d.ts +0 -2
  22. package/lib/buttons/button/button.directive.d.ts +17 -0
  23. package/lib/buttons/button/button.module.d.ts +3 -2
  24. package/lib/buttons/button/index.d.ts +1 -0
  25. package/lib/buttons/fab/fab.component.d.ts +3 -1
  26. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -4
  27. package/lib/buttons/icon-button/icon-button.defaults.d.ts +2 -1
  28. package/lib/calendar/abstract-calendar.d.ts +128 -0
  29. package/lib/calendar/calendar.component.d.ts +8 -96
  30. package/lib/calendar/calendar.defaults.d.ts +16 -1
  31. package/lib/calendar/calendar.internal-directives.d.ts +24 -8
  32. package/lib/calendar/calendar.internal-types.d.ts +1 -0
  33. package/lib/calendar/calendar.module.d.ts +4 -9
  34. package/lib/calendar/calendar.types.d.ts +21 -5
  35. package/lib/calendar/index.d.ts +3 -0
  36. package/lib/calendar/range-calendar.component.d.ts +16 -0
  37. package/lib/calendar/range-calendar.directives.d.ts +51 -0
  38. package/lib/calendar/range-calendar.module.d.ts +10 -0
  39. package/lib/calendar/views/calendar-views.module.d.ts +13 -0
  40. package/lib/calendar/views/days-view/days-view.component.d.ts +20 -2
  41. package/lib/calendar/views/days-view/days-view.helpers.d.ts +2 -2
  42. package/lib/calendar/views/months-view/months-view.component.d.ts +15 -3
  43. package/lib/calendar/views/years-view/years-view.component.d.ts +16 -3
  44. package/lib/checkbox/checkbox.component.d.ts +5 -2
  45. package/lib/checkbox/checkbox.types.d.ts +2 -0
  46. package/lib/checkbox-list/checkbox-list.component.d.ts +9 -7
  47. package/lib/checkbox-list/checkbox-list.directives.d.ts +7 -0
  48. package/lib/checkbox-list/checkbox-list.module.d.ts +1 -1
  49. package/lib/chip/chip.component.d.ts +2 -1
  50. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +2 -1
  51. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +5 -2
  52. package/lib/dialog/dialog.component.d.ts +13 -8
  53. package/lib/dialog/dialog.types.d.ts +1 -0
  54. package/lib/divider/divider.component.d.ts +2 -3
  55. package/lib/divider/divider.defaults.d.ts +5 -0
  56. package/lib/divider/divider.directive.d.ts +18 -0
  57. package/lib/divider/divider.module.d.ts +3 -2
  58. package/lib/divider/divider.types.d.ts +5 -0
  59. package/lib/divider/index.d.ts +2 -0
  60. package/lib/dropdown-panel/dropdown-panel.component.d.ts +2 -1
  61. package/lib/dropdown-panel/dropdown-panel.types.d.ts +1 -1
  62. package/lib/file-inputs/file-input/file-input.component.d.ts +2 -1
  63. package/lib/file-inputs/file-input-base.d.ts +4 -5
  64. package/lib/form-field/auto-error/auto-error.component.d.ts +19 -0
  65. package/lib/form-field/auto-error/auto-error.provider.d.ts +7 -0
  66. package/lib/form-field/error/error.directive.d.ts +3 -2
  67. package/lib/form-field/form-field-base.d.ts +5 -2
  68. package/lib/form-field/form-field-child.token.d.ts +5 -5
  69. package/lib/form-field/form-field-native-inputs.d.ts +6 -11
  70. package/lib/form-field/form-field.component.d.ts +1 -1
  71. package/lib/form-field/form-field.defaults.d.ts +1 -0
  72. package/lib/form-field/form-field.module.d.ts +5 -4
  73. package/lib/form-field/hint/hint.directive.d.ts +3 -2
  74. package/lib/form-field/hint-error/hint-error.directive.d.ts +3 -2
  75. package/lib/form-field/horizontal-form-field.component.d.ts +1 -1
  76. package/lib/form-field/index.d.ts +4 -0
  77. package/lib/form-field/label/label.component.d.ts +3 -2
  78. package/lib/form-field-frame/form-field-frame.component.d.ts +5 -3
  79. package/lib/grid/grid.component.d.ts +51 -0
  80. package/lib/grid/grid.defaults.d.ts +16 -0
  81. package/lib/grid/grid.module.d.ts +7 -0
  82. package/lib/grid/grid.types.d.ts +38 -0
  83. package/lib/grid/grid.utils.d.ts +11 -0
  84. package/lib/grid/index.d.ts +4 -0
  85. package/lib/icon/icon.component.d.ts +2 -1
  86. package/lib/inputs/_simple-input-base.d.ts +6 -3
  87. package/lib/inputs/autocomplete-input/autocomplete-input.component.d.ts +5 -4
  88. package/lib/inputs/date-input/abstract-date-input.d.ts +112 -0
  89. package/lib/inputs/date-input/date-input.component.d.ts +19 -81
  90. package/lib/inputs/date-input/date-input.defaults.d.ts +21 -3
  91. package/lib/inputs/date-input/{date-input.directive.d.ts → date-input.directives.d.ts} +2 -2
  92. package/lib/inputs/date-input/date-input.module.d.ts +5 -4
  93. package/lib/inputs/date-input/date-input.serializers.d.ts +4 -2
  94. package/lib/inputs/date-input/date-input.types.d.ts +5 -4
  95. package/lib/inputs/date-input/date-range-input.component.d.ts +30 -0
  96. package/lib/inputs/date-input/date-range-input.directives.d.ts +82 -0
  97. package/lib/inputs/date-input/date-range-input.module.d.ts +17 -0
  98. package/lib/inputs/date-input/index.d.ts +7 -1
  99. package/lib/inputs/date-input/multipage-date-range-input.component.d.ts +45 -0
  100. package/lib/inputs/date-input/multipage-date-range-input.directives.d.ts +82 -0
  101. package/lib/inputs/date-input/multipage-date-range-input.module.d.ts +17 -0
  102. package/lib/inputs/digit-input/digit-input.component.d.ts +4 -3
  103. package/lib/inputs/hex-input/hex-input.component.d.ts +4 -3
  104. package/lib/inputs/input-utils.d.ts +13 -2
  105. package/lib/inputs/number-input/number-input.component.d.ts +20 -12
  106. package/lib/inputs/number-input/number-input.defaults.d.ts +6 -0
  107. package/lib/inputs/number-input/number-input.directives.d.ts +12 -0
  108. package/lib/inputs/number-input/number-input.module.d.ts +1 -1
  109. package/lib/inputs/number-input/number-input.types.d.ts +6 -0
  110. package/lib/inputs/password-input/password-input.component.d.ts +5 -3
  111. package/lib/kbd/kbd.component.d.ts +2 -1
  112. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +2 -1
  113. package/lib/modal/modal.component.d.ts +9 -6
  114. package/lib/modal/modal.defaults.d.ts +2 -0
  115. package/lib/option/option.component.d.ts +2 -1
  116. package/lib/progress-bar/progress-bar.component.d.ts +4 -3
  117. package/lib/progress-circle/progress-circle.component.d.ts +5 -4
  118. package/lib/search-functions.d.ts +1 -1
  119. package/lib/segment/segment.component.d.ts +6 -5
  120. package/lib/select/select.component.d.ts +40 -30
  121. package/lib/select/select.defaults.d.ts +10 -2
  122. package/lib/select/select.directive.d.ts +6 -0
  123. package/lib/select/select.module.d.ts +1 -1
  124. package/lib/select/select.types.d.ts +6 -2
  125. package/lib/select/select.utils.d.ts +2 -0
  126. package/lib/slide-toggle/slide-toggle.component.d.ts +2 -0
  127. package/lib/slider/abstract-slider.d.ts +35 -29
  128. package/lib/slider/index.d.ts +1 -0
  129. package/lib/slider/range-slider/range-slider.component.d.ts +13 -10
  130. package/lib/slider/range-slider/range-slider.types.d.ts +6 -0
  131. package/lib/slider/slider.component.d.ts +5 -4
  132. package/lib/slider/slider.types.d.ts +3 -3
  133. package/lib/star/rating-display/rating-display.component.d.ts +2 -1
  134. package/lib/star/rating-input/rating-input.component.d.ts +5 -3
  135. package/lib/star/rating-input/rating-input.defaults.d.ts +2 -2
  136. package/lib/star/star-button/star-button.component.d.ts +4 -1
  137. package/lib/star/star-button/star-button.types.d.ts +1 -0
  138. package/lib/tabber/index.d.ts +2 -1
  139. package/lib/tabber/tab/tab.component.d.ts +16 -8
  140. package/lib/tabber/tabber.component.d.ts +25 -9
  141. package/lib/tabber/tabber.defaults.d.ts +2 -0
  142. package/lib/tabber/tabber.directives.d.ts +9 -0
  143. package/lib/tabber/tabber.module.d.ts +3 -2
  144. package/lib/tabber/tabber.types.d.ts +5 -0
  145. package/lib/table/table.component.d.ts +16 -15
  146. package/lib/table-pagination/table-pagination.component.d.ts +4 -3
  147. package/lib/text-list/text-list.component.d.ts +2 -1
  148. package/lib/types/alignment.types.d.ts +7 -1
  149. package/lib/types/item-storage.types.d.ts +17 -18
  150. package/package.json +3 -2
  151. package/prebuilt-themes/default/badge.css +37 -15
  152. package/prebuilt-themes/default/badge.css.map +1 -1
  153. package/prebuilt-themes/default/buttons/button.css +74 -58
  154. package/prebuilt-themes/default/buttons/button.css.map +1 -1
  155. package/prebuilt-themes/default/buttons/fab.css +64 -51
  156. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  157. package/prebuilt-themes/default/buttons/icon-button.css +50 -44
  158. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -1
  159. package/prebuilt-themes/default/calendar.css +131 -55
  160. package/prebuilt-themes/default/calendar.css.map +1 -1
  161. package/prebuilt-themes/default/card.css +56 -24
  162. package/prebuilt-themes/default/card.css.map +1 -1
  163. package/prebuilt-themes/default/checkbox-list.css +48 -22
  164. package/prebuilt-themes/default/checkbox-list.css.map +1 -1
  165. package/prebuilt-themes/default/checkbox.css +31 -58
  166. package/prebuilt-themes/default/checkbox.css.map +1 -1
  167. package/prebuilt-themes/default/chips.css +75 -43
  168. package/prebuilt-themes/default/chips.css.map +1 -1
  169. package/prebuilt-themes/default/color-display.css +15 -8
  170. package/prebuilt-themes/default/color-display.css.map +1 -1
  171. package/prebuilt-themes/default/core.css +21 -1
  172. package/prebuilt-themes/default/core.css.map +1 -1
  173. package/prebuilt-themes/default/dialog.css +7 -2
  174. package/prebuilt-themes/default/dialog.css.map +1 -1
  175. package/prebuilt-themes/default/divider.css +82 -6
  176. package/prebuilt-themes/default/divider.css.map +1 -1
  177. package/prebuilt-themes/default/dropdown-panel.css +16 -8
  178. package/prebuilt-themes/default/dropdown-panel.css.map +1 -1
  179. package/prebuilt-themes/default/file-drop-area.css +81 -35
  180. package/prebuilt-themes/default/file-drop-area.css.map +1 -1
  181. package/prebuilt-themes/default/form-field-frame.css +18 -14
  182. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  183. package/prebuilt-themes/default/form-field.css +62 -29
  184. package/prebuilt-themes/default/form-field.css.map +1 -1
  185. package/prebuilt-themes/default/inputs/autocomplete-input.css +79 -28
  186. package/prebuilt-themes/default/inputs/autocomplete-input.css.map +1 -1
  187. package/prebuilt-themes/default/inputs/color-input.css +5 -44
  188. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  189. package/prebuilt-themes/default/inputs/date-input.css +97 -25
  190. package/prebuilt-themes/default/inputs/date-input.css.map +1 -1
  191. package/prebuilt-themes/default/inputs/digit-input.css +31 -19
  192. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  193. package/prebuilt-themes/default/inputs/file-input.css +117 -62
  194. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  195. package/prebuilt-themes/default/inputs/hex-input.css +55 -23
  196. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  197. package/prebuilt-themes/default/inputs/input.css +47 -18
  198. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  199. package/prebuilt-themes/default/inputs/number-input.css +83 -33
  200. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  201. package/prebuilt-themes/default/inputs/password-input.css +74 -25
  202. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  203. package/prebuilt-themes/default/kbd-shortcut.css +8 -4
  204. package/prebuilt-themes/default/kbd-shortcut.css.map +1 -1
  205. package/prebuilt-themes/default/kbd.css +19 -9
  206. package/prebuilt-themes/default/kbd.css.map +1 -1
  207. package/prebuilt-themes/default/modal.css +46 -22
  208. package/prebuilt-themes/default/modal.css.map +1 -1
  209. package/prebuilt-themes/default/progress-circle.css +13 -7
  210. package/prebuilt-themes/default/progress-circle.css.map +1 -1
  211. package/prebuilt-themes/default/radio.css +46 -28
  212. package/prebuilt-themes/default/radio.css.map +1 -1
  213. package/prebuilt-themes/default/segment.css +71 -61
  214. package/prebuilt-themes/default/segment.css.map +1 -1
  215. package/prebuilt-themes/default/select.css +78 -44
  216. package/prebuilt-themes/default/select.css.map +1 -1
  217. package/prebuilt-themes/default/slide-toggle.css +88 -37
  218. package/prebuilt-themes/default/slide-toggle.css.map +1 -1
  219. package/prebuilt-themes/default/slider.css +93 -52
  220. package/prebuilt-themes/default/slider.css.map +1 -1
  221. package/prebuilt-themes/default/snackbar.css +29 -16
  222. package/prebuilt-themes/default/snackbar.css.map +1 -1
  223. package/prebuilt-themes/default/spinner.css +9 -3
  224. package/prebuilt-themes/default/spinner.css.map +1 -1
  225. package/prebuilt-themes/default/stars.css +42 -20
  226. package/prebuilt-themes/default/stars.css.map +1 -1
  227. package/prebuilt-themes/default/tabber.css +53 -17
  228. package/prebuilt-themes/default/tabber.css.map +1 -1
  229. package/prebuilt-themes/default/table-pagination.css +21 -9
  230. package/prebuilt-themes/default/table-pagination.css.map +1 -1
  231. package/prebuilt-themes/default/table.css +93 -69
  232. package/prebuilt-themes/default/table.css.map +1 -1
  233. package/public-api.d.ts +2 -1
  234. package/themes/_variables.scss +2 -1
  235. package/themes/default/_mixins.scss +5 -5
  236. package/themes/default/badge.scss +48 -15
  237. package/themes/default/buttons/_button-mixins.scss +43 -33
  238. package/themes/default/buttons/button.scss +54 -29
  239. package/themes/default/buttons/fab.scss +47 -26
  240. package/themes/default/buttons/icon-button.scss +40 -17
  241. package/themes/default/calendar.scss +148 -58
  242. package/themes/default/card.scss +68 -24
  243. package/themes/default/checkbox-list.scss +47 -21
  244. package/themes/default/checkbox.scss +30 -59
  245. package/themes/default/chips.scss +71 -40
  246. package/themes/default/color-display.scss +18 -8
  247. package/themes/default/core.scss +24 -1
  248. package/themes/default/dialog.scss +9 -2
  249. package/themes/default/divider.scss +106 -6
  250. package/themes/default/dropdown-panel.scss +21 -8
  251. package/themes/default/file-drop-area.scss +92 -35
  252. package/themes/default/form-field-frame.scss +23 -15
  253. package/themes/default/form-field.scss +64 -28
  254. package/themes/default/inputs/_shared.scss +52 -12
  255. package/themes/default/inputs/autocomplete-input.scss +83 -14
  256. package/themes/default/inputs/color-input.scss +2 -2
  257. package/themes/default/inputs/date-input.scss +74 -6
  258. package/themes/default/inputs/digit-input.scss +42 -20
  259. package/themes/default/inputs/file-input.scss +100 -23
  260. package/themes/default/inputs/hex-input.scss +59 -9
  261. package/themes/default/inputs/input.scss +51 -4
  262. package/themes/default/inputs/number-input.scss +94 -24
  263. package/themes/default/inputs/password-input.scss +84 -15
  264. package/themes/default/kbd-shortcut.scss +10 -4
  265. package/themes/default/kbd.scss +26 -9
  266. package/themes/default/modal.scss +56 -22
  267. package/themes/default/progress-circle.scss +16 -10
  268. package/themes/default/radio.scss +47 -26
  269. package/themes/default/segment.scss +77 -67
  270. package/themes/default/select.scss +98 -42
  271. package/themes/default/slide-toggle.scss +134 -59
  272. package/themes/default/slider.scss +102 -65
  273. package/themes/default/snackbar.scss +32 -14
  274. package/themes/default/spinner.scss +11 -3
  275. package/themes/default/stars.scss +45 -16
  276. package/themes/default/tabber.scss +54 -14
  277. package/themes/default/table-pagination.scss +24 -9
  278. package/themes/default/table.scss +104 -70
  279. package/lib/statebox/index.d.ts +0 -4
  280. package/lib/statebox/statebox.component.d.ts +0 -26
  281. package/lib/statebox/statebox.defaults.d.ts +0 -10
  282. package/lib/statebox/statebox.module.d.ts +0 -8
  283. package/lib/statebox/statebox.types.d.ts +0 -26
  284. package/lib/tabber/tab/tab.defaults.d.ts +0 -6
  285. package/prebuilt-themes/default/calendar-OLD.css +0 -294
  286. package/prebuilt-themes/default/calendar-OLD.css.map +0 -1
  287. package/prebuilt-themes/default/inputs/search-bar.css +0 -118
  288. package/prebuilt-themes/default/inputs/search-bar.css.map +0 -1
  289. package/prebuilt-themes/default/statebox.css +0 -235
  290. package/prebuilt-themes/default/statebox.css.map +0 -1
  291. package/themes/default/calendar-OLD.scss +0 -183
  292. package/themes/default/inputs/search-bar.scss +0 -19
  293. package/themes/default/statebox.scss +0 -109
@@ -3,21 +3,54 @@
3
3
  @use './coloring.scss' as CM;
4
4
  @use '../variables' as ARD;
5
5
 
6
- $grid-size: 2.5rem;
6
+ // the variables are commented out intentionally
7
+ // read more in docs/dev/css-variables.md
8
+ :root {
9
+ --ard-calendar-grid-size: 2.25rem;
10
+ --ard-calendar-grid-gap: 0.25rem;
11
+ --ard-calendar-padding: 0.375rem;
12
+ --ard-calendar-header-padding: 0.375rem 0 0.75rem 0;
13
+ --ard-calendar-weekday-padding: 0 0 0.5rem 0;
14
+ --ard-calendar-weekday-font-size: 0.875rem;
15
+ --ard-calendar-weekday-font-weight: 500;
16
+ // --ard-calendar-weekday-color: ;
17
+ --ard-calendar-floating-month-transform: none;
18
+ --ard-calendar-floating-month-padding: 0 0 0 1rem;
19
+ --ard-calendar-floating-month-font-size: 0.875rem;
20
+ --ard-calendar-floating-month-font-weight: 500;
21
+ // --ard-calendar-floating-month-color: ;
22
+ --ard-calendar-entry-padding: 0;
23
+ --ard-calendar-entry-font-size: 0.875rem;
24
+ --ard-calendar-entry-font-weight: 400;
25
+ --ard-calendar-entry-border-radius: 9999px;
26
+ --ard-calendar-entry-range-overlay-border-width: 1px;
27
+ --ard-calendar-entry-range-overlay-border-style: dashed;
28
+ // --ard-calendar-entry-today-border-color: ;
29
+ --ard-calendar-entry-today-selected-border: 2px solid #{ARD.$bg};
30
+ --ard-calendar-entry-highlighted-overlay-opacity: 20%;
31
+ --ard-calendar-entry-selected-overlay-opacity: 100%;
32
+ --ard-calendar-entry-selected-range-overlay-opacity: 12%;
33
+ --ard-calendar-entry-disabled-overlay-opacity: 50%;
34
+ --ard-calendar-entry-disabled-highlighted-overlay-opacity: 15%;
35
+ --ard-calendar-entry-disabled-opacity: 50%;
36
+ }
7
37
 
8
38
  .ard-calendar {
9
39
  @include CM.typeColors();
10
- width: 18.5rem;
40
+ min-width: calc(var(--ard-calendar-grid-size) * 7 + var(--ard-calendar-grid-gap) * 6);
11
41
  user-select: none;
42
+ padding: var(--ard-calendar-padding, 0 0.375rem 0.375rem 0.375rem);
43
+ box-sizing: content-box;
12
44
 
13
45
  //! top toolbar
14
46
  .ard-calendar__top-toolbar {
15
47
  .ard-calendar__calendar-header {
16
- display: flex;
17
- justify-content: space-between;
48
+ display: grid;
49
+ grid-template-columns: 1fr 5fr 1fr;
18
50
  align-items: center;
51
+ justify-items: center;
19
52
  width: 100%;
20
- padding: 0.75rem 0;
53
+ padding: var(--ard-calendar-header-padding, 0.75rem 0);
21
54
 
22
55
  .ard-dropdown-arrow {
23
56
  @include DA.dropdown-arrow();
@@ -32,66 +65,68 @@ $grid-size: 2.5rem;
32
65
  //! weekdays
33
66
  .ard-calendar__weekdays {
34
67
  display: grid;
35
- grid-template-columns: repeat(7, $grid-size);
68
+ grid-template-columns: repeat(7, var(--ard-calendar-grid-size, 2.25rem));
69
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
36
70
  align-items: center;
37
- padding: 0 0.375rem 0.5rem 0.375rem;
71
+ padding: var(--ard-calendar-weekday-padding, 0 0 0.5rem 0);
38
72
 
39
73
  .ard-calendar__weekday {
40
74
  text-align: center;
41
- font-size: 0.875rem;
42
- font-weight: 500;
43
- color: ARD.$text;
75
+ font-size: var(--ard-calendar-weekday-font-size, 0.875rem);
76
+ font-weight: var(--ard-calendar-weekday-font-weight, 500);
77
+ color: var(--ard-calendar-weekday-color, #{ARD.$text});
44
78
  }
45
79
  }
46
80
  //! days grid
47
81
  .ard-calendar__days-grid {
48
- padding: 0.375rem;
49
- padding-top: 0;
82
+ padding: 0;
50
83
  display: grid;
51
- grid-template-columns: repeat(7, $grid-size);
84
+ grid-template-columns: repeat(7, var(--ard-calendar-grid-size));
52
85
  position: relative;
53
86
  outline: none;
87
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
54
88
 
55
89
  > * {
56
- max-width: 100%;
90
+ width: var(--ard-calendar-grid-size);
91
+ max-width: var(--ard-calendar-grid-size);
92
+ height: var(--ard-calendar-grid-size);
93
+ max-height: var(--ard-calendar-grid-size);
57
94
  box-sizing: border-box;
58
- aspect-ratio: 1;
59
95
  }
60
96
  &.ard-reserve-top-row {
61
- padding-top: $grid-size;
97
+ padding-top: calc(var(--ard-calendar-grid-size) + var(--ard-calendar-grid-gap));
62
98
  }
63
99
  .ard-calendar__floating-month {
64
100
  position: absolute;
65
101
  top: 0;
66
102
  left: 0;
103
+ transform: var(--ard-calendar-floating-month-transform, none);
67
104
  width: 100%;
68
105
  box-sizing: border-box;
69
106
  aspect-ratio: 7;
70
- padding-left: 1rem;
107
+ padding: var(--ard-calendar-floating-month-padding, 0 0 0 1rem);
71
108
  display: flex;
72
109
  align-items: center;
73
- font-size: 0.875rem;
74
- font-weight: 500;
75
- color: ARD.$text3;
110
+ font-size: var(--ard-calendar-floating-month-font-size, 0.875rem);
111
+ font-weight: var(--ard-calendar-floating-month-font-weight, 500);
112
+ color: var(--ard-calendar-floating-month-color, #{ARD.$text3});
76
113
  letter-spacing: 0.5px;
77
114
  }
78
115
  }
79
116
  //! years grid
80
117
  .ard-calendar__simple-grid {
81
118
  border-top: 1px solid ARD.$detail-ultralight;
82
- margin-top: 0.25rem;
83
119
  display: grid;
84
120
  grid-template-columns: repeat(4, 1fr);
85
- grid-template-rows: repeat(6, $grid-size);
121
+ grid-template-rows: repeat(6, var(--ard-calendar-grid-size));
86
122
  position: relative;
87
123
  outline: none;
124
+ padding: 0;
125
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
88
126
 
89
127
  > * {
90
128
  max-width: 100%;
91
129
  box-sizing: border-box;
92
- aspect-ratio: 7/4; //it has to be the same height as in the days view
93
- //before it was 7/7 (1) because there are 7 entries in a single row
94
- //now there are 4 entries, and thus 7/4
95
130
  }
96
131
  }
97
132
  //! common in both grids
@@ -99,7 +134,8 @@ $grid-size: 2.5rem;
99
134
  z-index: 1;
100
135
  cursor: pointer;
101
136
  outline: none;
102
- padding: 0.125rem;
137
+ padding: var(--ard-calendar-entry-padding, 0);
138
+ box-sizing: border-box;
103
139
 
104
140
  .ard-calendar__entry-button {
105
141
  width: 100%;
@@ -108,21 +144,33 @@ $grid-size: 2.5rem;
108
144
  display: flex;
109
145
  align-items: center;
110
146
  justify-content: center;
111
- font-size: 0.875rem;
147
+ font-size: var(--ard-calendar-entry-font-size, 0.875rem);
148
+ font-weight: var(--ard-calendar-entry-font-weight, 400);
112
149
  background: transparent;
113
150
  border: 1px solid transparent;
114
- border-radius: 9999px;
151
+ border-radius: var(--ard-calendar-entry-border-radius, 9999px);
115
152
  position: relative;
116
153
  cursor: pointer;
154
+ outline: none;
155
+ box-sizing: border-box;
117
156
 
118
157
  .ard-focus-overlay {
119
158
  @include DM.focus-overlay();
120
159
  z-index: -1;
121
- background: var(--ard-cmpcl--bg-colored);
122
- border: 2px solid transparent;
123
- transition:
124
- border-color 0.1s ease,
125
- opacity 0.1s ease;
160
+ background: var(--ard-cmpcl--overlay);
161
+ transition: border-color 0.1s ease, opacity 0.1s ease;
162
+ }
163
+ .ard-range-overlay {
164
+ @include DM.focus-overlay();
165
+ z-index: -1;
166
+ opacity: 1;
167
+ left: calc(var(--ard-calendar-grid-gap, 0.25rem) / -2 - 1px);
168
+ right: calc(var(--ard-calendar-grid-gap, 0.25rem) / -2 - 1px);
169
+ border: var(--ard-calendar-entry-range-overlay-border-width, 1px)
170
+ var(--ard-calendar-entry-range-overlay-border-style, dashed) transparent;
171
+ background: transparent;
172
+ transition: none;
173
+ border-radius: 0;
126
174
  }
127
175
  }
128
176
  &.ard-calendar__entry-empty {
@@ -130,12 +178,51 @@ $grid-size: 2.5rem;
130
178
  }
131
179
  &.ard-calendar-today {
132
180
  .ard-calendar__entry-button {
133
- border-color: ARD.$detail;
181
+ border-color: var(--ard-calendar-entry-today-border-color, #{ARD.$detail});
182
+ }
183
+ }
184
+ &.ard-calendar__entry-highlighted-in-range {
185
+ .ard-range-overlay {
186
+ opacity: 1;
187
+ border-top-color: var(--ard-cmpcl--bg-colored);
188
+ border-bottom-color: var(--ard-cmpcl--bg-colored);
189
+ }
190
+ &.ard-calendar__entry-selected-start {
191
+ .ard-range-overlay {
192
+ border-left-color: var(--ard-cmpcl--bg-colored);
193
+ }
194
+ }
195
+ &.ard-calendar__entry-selected-end,
196
+ &.ard-calendar__entry-highlighted {
197
+ .ard-range-overlay {
198
+ border-right-color: var(--ard-cmpcl--bg-colored);
199
+ }
134
200
  }
135
201
  }
136
202
  &.ard-calendar__entry-highlighted {
137
203
  .ard-focus-overlay {
138
- opacity: 20%;
204
+ opacity: var(--ard-calendar-entry-highlighted-overlay-opacity, 20%);
205
+ }
206
+ }
207
+ &.ard-calendar__entry-selected-start {
208
+ .ard-range-overlay {
209
+ left: 0;
210
+ border-top-left-radius: var(--ard-calendar-entry-border-radius);
211
+ border-bottom-left-radius: var(--ard-calendar-entry-border-radius);
212
+ }
213
+ }
214
+ &.ard-calendar__entry-selected-end,
215
+ &.ard-calendar__entry-highlighted:not(.ard-calendar__entry-selected-in-range) {
216
+ .ard-range-overlay {
217
+ right: 0;
218
+ border-top-right-radius: var(--ard-calendar-entry-border-radius);
219
+ border-bottom-right-radius: var(--ard-calendar-entry-border-radius);
220
+ }
221
+ }
222
+ &.ard-calendar__entry-selected-in-range {
223
+ .ard-range-overlay {
224
+ opacity: var(--ard-calendar-entry-selected-range-overlay-opacity, 12%);
225
+ background-color: var(--ard-cmpcl--bg-colored);
139
226
  }
140
227
  }
141
228
  &.ard-calendar__entry-selected {
@@ -143,18 +230,19 @@ $grid-size: 2.5rem;
143
230
  color: var(--ard-cmpcl--on-bg-colored);
144
231
  }
145
232
  .ard-focus-overlay {
146
- opacity: 100%;
233
+ opacity: var(--ard-calendar-entry-selected-overlay-opacity, 100%);
234
+ background: var(--ard-cmpcl--bg-colored);
147
235
  }
148
236
 
149
237
  &.ard-calendar-today {
150
238
  .ard-focus-overlay {
151
- border-color: ARD.$bg;
239
+ border: var(--ard-calendar-entry-today-selected-border, 2px solid #{ARD.$bg});
152
240
  }
153
241
  }
154
242
  }
155
243
  &.ard-calendar__entry-disabled {
156
244
  pointer-events: none;
157
- opacity: 50%;
245
+ opacity: var(--ard-calendar-entry-disabled-overlay-opacity, 50%);
158
246
 
159
247
  .ard-calendar__entry-button {
160
248
  cursor: default;
@@ -164,30 +252,32 @@ $grid-size: 2.5rem;
164
252
  }
165
253
  &.ard-calendar__entry-highlighted {
166
254
  .ard-focus-overlay {
167
- opacity: 15%;
255
+ opacity: var(--ard-calendar-entry-disabled-highlighted-overlay-opacity, 15%);
168
256
  }
169
257
  }
170
258
  }
171
259
  }
172
- .ard-calendar__day-labels {
173
- font-size: 0.8125rem;
174
- color: ARD.$text3;
175
- height: 1.25rem;
176
- position: relative;
260
+ .ard-years-view,
261
+ .ard-months-view {
262
+ .ard-calendar__entry {
263
+ .ard-calendar__entry-button {
264
+ .ard-range-overlay {
265
+ left: calc(-var(--ard-calendar-grid-gap) / 2 - 1px);
266
+ right: calc(-var(--ard-calendar-grid-gap) / 2 - 1px);
267
+ border: none;
268
+ }
269
+ }
177
270
 
178
- > * {
179
- display: flex;
180
- align-items: center;
181
- justify-content: center;
182
- aspect-ratio: unset;
183
- }
184
- &::after {
185
- content: '';
186
- position: absolute;
187
- width: 100%;
188
- height: 1px;
189
- background: ARD.$detail-ultralight;
190
- bottom: 0;
271
+ &.ard-calendar__entry-selected-start {
272
+ .ard-range-overlay {
273
+ left: 0;
274
+ }
275
+ }
276
+ &.ard-calendar__entry-selected-end {
277
+ .ard-range-overlay {
278
+ right: 0;
279
+ }
280
+ }
191
281
  }
192
282
  }
193
283
  }
@@ -199,6 +289,6 @@ $grid-size: 2.5rem;
199
289
  }
200
290
  .ard-disabled {
201
291
  .ard-calendar {
202
- opacity: 50%;
292
+ opacity: var(--ard-calendar-entry-disabled-opacity, 50%);
203
293
  }
204
294
  }
@@ -1,9 +1,43 @@
1
1
  @use '../variables' as ARD;
2
2
 
3
+ // the variables are commented out intentionally
4
+ // read more in docs/dev/css-variables.md
5
+ :root {
6
+ // --ard-card-bg: ;
7
+ // --ard-card-rounded-corner-radius: ;
8
+ // --ard-card-border-color: ;
9
+
10
+ --ard-card-content-padding-top: 0;
11
+ --ard-card-content-padding-right: 1em;
12
+ --ard-card-content-padding-bottom: 0;
13
+ --ard-card-content-padding-left: 1em;
14
+
15
+ --ard-card-header-padding-top: 0.5em;
16
+ --ard-card-header-padding-right: 1em;
17
+ --ard-card-header-padding-bottom: 0;
18
+ --ard-card-header-padding-left: 1em;
19
+ --ard-card-header-margin-bottom: 1em;
20
+
21
+ // --ard-card-title-color: ;
22
+ --ard-card-title-font-size: 1.375em;
23
+ --ard-card-title-letter-spacing: 0.0125em;
24
+ --ard-card-title-font-weight: 500;
25
+ --ard-card-title-margin-top: 0;
26
+ // --ard-card-subtitle-color: ;
27
+ --ard-card-subtitle-font-size: 1.375em;
28
+ --ard-card-subtitle-letter-spacing: 0.0125em;
29
+ --ard-card-subtitle-font-weight: 500;
30
+ --ard-card-subtitle-margin-top: 0;
31
+
32
+ --ard-card-avatar-size: 3em;
33
+
34
+ --ard-card-action-buttons-padding: 0.5em;
35
+ }
36
+
3
37
  ard-card,
4
38
  .ard-card {
5
39
  position: relative;
6
- background: ARD.$bg;
40
+ background: var(--ard-card-bg, #{ARD.$bg});
7
41
  box-sizing: border-box;
8
42
  width: 100%;
9
43
  height: max-content;
@@ -11,7 +45,7 @@ ard-card,
11
45
 
12
46
  //! appearances
13
47
  &.ard-appearance-outlined {
14
- border: 1px solid ARD.$border-light;
48
+ border: 1px solid var(--ard-card-border-color, #{ARD.$border-light});
15
49
  }
16
50
  &.ard-appearance-raised {
17
51
  box-shadow: ARD.$card-shadow;
@@ -21,15 +55,18 @@ ard-card,
21
55
  border-radius: 0;
22
56
  }
23
57
  &.ard-variant-rounded {
24
- border-radius: 8px;
58
+ border-radius: var(--ard-card-rounded-corner-radius, var(--ard-rounded-corner-radius, 0.375rem));
25
59
  }
26
60
  }
27
61
  //! header
28
62
  ard-card-header {
29
- padding: 0.5em 1em 0 1em;
63
+ padding-top: var(--ard-card-header-padding-top, var(--ard-card-content-padding-top, 0.5em));
64
+ padding-right: var(--ard-card-header-padding-right, var(--ard-card-content-padding-right, 1em));
65
+ padding-bottom: var(--ard-card-header-padding-bottom, var(--ard-card-content-padding-bottom, 0));
66
+ padding-left: var(--ard-card-header-padding-left, var(--ard-card-content-padding-left, 1em));
30
67
  display: flex;
31
68
  align-items: center;
32
- margin-bottom: 1em;
69
+ margin-bottom: var(--ard-card-header-margin-bottom, 1em);
33
70
  max-width: 100%;
34
71
 
35
72
  .ard-card-header-title-container {
@@ -39,37 +76,41 @@ ard-card-header {
39
76
  }
40
77
 
41
78
  &:first-child {
42
- padding-top: 1em;
79
+ padding-top: var(--ard-card-content-padding-top, 0.5em);
43
80
  }
44
81
  }
45
82
  .ard-card-title,
46
83
  .ard-card-subtitle {
47
- line-height: normal;
48
84
  display: block;
49
85
  margin: 0;
50
- font-weight: 500;
51
86
  }
52
87
  .ard-card-title {
53
- font-size: 1.375em;
54
- letter-spacing: 0.0125em;
55
- color: ARD.$text;
88
+ color: var(--ard-card-title-color, #{ARD.$text});
89
+ font-size: var(--ard-card-title-font-size, 1.375em);
90
+ letter-spacing: var(--ard-card-title-letter-spacing, 0.0125em);
91
+ font-weight: var(--ard-card-title-font-weight, 500);
92
+ margin-top: var(--ard-card-title-margin-top, 0);
56
93
  }
57
94
  .ard-card-subtitle {
58
- font-size: 1em;
59
- letter-spacing: 0.0078125em;
60
- color: ARD.$text3;
61
- margin-top: 0.125rem;
95
+ color: var(--ard-card-subtitle-color, #{ARD.$text3});
96
+ font-size: var(--ard-card-subtitle-font-size, 1.375em);
97
+ letter-spacing: var(--ard-card-subtitle-letter-spacing, 0.0125em);
98
+ font-weight: var(--ard-card-subtitle-font-weight, 500);
99
+ margin-top: var(--ard-card-subtitle-margin-top, 0);
62
100
  }
63
101
  .ard-card-avatar {
64
102
  display: block;
65
- width: 3em;
66
- height: 3em;
103
+ width: var(--ard-card-avatar-size, 3em);
104
+ height: var(--ard-card-avatar-size, 3em);
67
105
  border-radius: 9999px;
68
106
  flex-shrink: 0;
69
107
  object-fit: cover;
70
108
 
71
109
  ~ .ard-card-header-title-container {
72
- padding: 0 1em;
110
+ padding-top: var(--ard-card-content-padding-top, 0);
111
+ padding-right: var(--ard-card-content-padding-right, 1em);
112
+ padding-bottom: var(--ard-card-content-padding-bottom, 0);
113
+ padding-left: var(--ard-card-content-padding-left, 0);
73
114
  }
74
115
  }
75
116
  //! image
@@ -93,20 +134,23 @@ ard-card-header {
93
134
  ard-card,
94
135
  .ard-card {
95
136
  .ard-appearance-outlined .ard-image {
96
- border-bottom: 1px solid ARD.$border-light;
137
+ border-bottom: 1px solid var(--ard-card-border-color, #{ARD.$border-light});
97
138
  }
98
139
  }
99
140
  //! content
100
141
  .ard-card-content {
101
- padding: 0 1em;
142
+ padding-top: var(--ard-card-content-padding-top, var(--ard-card-content-padding, 0));
143
+ padding-right: var(--ard-card-content-padding-right, var(--ard-card-content-padding, 1em));
144
+ padding-bottom: var(--ard-card-content-padding-bottom, var(--ard-card-content-padding, 0));
145
+ padding-left: var(--ard-card-content-padding-left, var(--ard-card-content-padding, 1em));
102
146
  display: block;
103
147
  max-width: 100%;
104
148
 
105
149
  &:first-child {
106
- padding-top: 1em;
150
+ padding-top: var(--ard-card-content-padding-top, var(--ard-card-content-padding, 0));
107
151
  }
108
152
  &:last-child {
109
- padding-bottom: 1em;
153
+ padding-bottom: var(--ard-card-content-padding-bottom, var(--ard-card-content-padding, 0));
110
154
  }
111
155
 
112
156
  > :last-child {
@@ -115,7 +159,7 @@ ard-card,
115
159
  }
116
160
  //! action buttons
117
161
  .ard-card-action-buttons {
118
- padding: 0.5em;
162
+ padding: var(--ard-card-action-buttons-padding, 0.5em);
119
163
  display: flex;
120
164
  flex-direction: row;
121
165
  align-items: center;
@@ -124,7 +168,7 @@ ard-card,
124
168
  &.ard-align-left {
125
169
  justify-content: flex-start;
126
170
  }
127
- &.ard-align-middle {
171
+ &.ard-align-center {
128
172
  justify-content: center;
129
173
  }
130
174
  &.ard-align-right {
@@ -1,22 +1,47 @@
1
1
  @use './mixins' as CM;
2
2
  @use '../variables' as ARD;
3
3
 
4
+ :root {
5
+ --ard-checkbox-list-padding: 0.375rem 0;
6
+ --ard-checkbox-list-item-hover-opacity: 5%;
7
+ --ard-checkbox-list-item-active-opacity: 15%;
8
+ --ard-checkbox-list-item-height: 3rem;
9
+ --ard-checkbox-list-item-height-compact: 2rem;
10
+ --ard-checkbox-list-checkbox-min-width: 1.25rem;
11
+ --ard-checkbox-list-checkbox-padding: 0.625rem;
12
+ --ard-checkbox-list-item-padding: 0 0.5rem 0 0;
13
+ --ard-checkbox-list-gap: 0;
14
+ --ard-checkbox-list-gap-compact: 0;
15
+ --ard-checkbox-list-item-gap: 0.5rem;
16
+ --ard-checkbox-list-item-gap-compact: 0.325rem;
17
+ --ard-checkbox-list-disabled-opacity: 50%;
18
+ }
19
+
4
20
  .ard-checkbox-list {
5
21
  display: flex;
6
22
  flex-direction: column;
23
+ padding: var(--ard-checkbox-list-padding, 0.375rem 0);
24
+ gap: var(--ard-checkbox-list-gap, 0);
7
25
 
8
26
  .ard-checkbox-list__item {
9
27
  display: flex;
10
28
  align-items: center;
11
- gap: 0.5rem;
12
- padding: 0 1rem;
29
+ justify-content: stretch;
30
+ gap: var(--ard-checkbox-list-item-gap, 0.5rem);
31
+ padding: var(--ard-checkbox-list-item-padding, 0 0.5rem 0 0);
13
32
  position: relative;
14
33
  cursor: pointer;
15
- height: 3rem;
34
+ height: max-content;
35
+ min-height: var(--ard-checkbox-list-item-height, 3rem);
16
36
 
17
37
  > label {
18
38
  pointer-events: none;
19
39
  user-select: none;
40
+ flex-grow: 1;
41
+ padding: 0;
42
+ min-height: var(--ard-checkbox-list-item-height, 3rem);
43
+ display: flex;
44
+ align-items: center;
20
45
  }
21
46
  > .ard-focus-overlay {
22
47
  @include CM.focus-overlay();
@@ -24,16 +49,17 @@
24
49
  }
25
50
  &.ard-item-highlighted {
26
51
  > .ard-focus-overlay {
27
- opacity: 5%;
52
+ opacity: var(--ard-checkbox-list-item-hover-opacity, 5%);
28
53
  }
29
54
  }
30
55
  &:active {
31
56
  > .ard-focus-overlay {
32
- opacity: 15%;
57
+ opacity: var(--ard-checkbox-list-item-active-opacity, 15%);
33
58
  }
34
59
  }
35
60
  ard-checkbox {
36
- padding: 0.625rem;
61
+ padding: var(--ard-checkbox-list-checkbox-padding, 0.625rem);
62
+ min-width: var(--ard-checkbox-list-checkbox-min-width, 1.25rem);
37
63
 
38
64
  .ard-checkbox {
39
65
  .ard-focus-overlay {
@@ -45,39 +71,39 @@
45
71
  pointer-events: none;
46
72
 
47
73
  > label {
48
- opacity: 50%;
74
+ opacity: var(--ard-checkbox-list-disabled-opacity, 50%);
49
75
  }
50
76
  }
51
77
  }
52
78
  &.ard-compact {
79
+ gap: var(--ard-checkbox-list-gap-compact, 0);
80
+
53
81
  .ard-checkbox-list__item {
54
- gap: 0.325rem;
55
- height: 2rem;
82
+ gap: var(--ard-checkbox-list-item-gap-compact, 0.325rem);
83
+ height: var(--ard-checkbox-list-item-height-compact, 2rem);
56
84
  }
57
85
  }
58
86
  //! ALIGN TYPES
59
87
  &.ard-align-left-clumped,
60
- &.ard-align-left-split {
61
- .ard-checkbox-list__item {
62
- flex-direction: row;
63
- }
64
- }
65
- &.ard-align-right-clumped,
66
88
  &.ard-align-right-split {
67
89
  .ard-checkbox-list__item {
68
- flex-direction: row-reverse;
90
+ label {
91
+ justify-content: flex-start;
92
+ }
69
93
  }
70
94
  }
71
- &.ard-align-left-clumped,
95
+ &.ard-align-left-split,
72
96
  &.ard-align-right-clumped {
73
97
  .ard-checkbox-list__item {
74
- justify-content: flex-start;
98
+ label {
99
+ justify-content: flex-end;
100
+ }
75
101
  }
76
102
  }
77
- &.ard-align-left-split,
78
- &.ard-align-right-split {
103
+ &.ard-align-right-split,
104
+ &.ard-align-right-clumped {
79
105
  .ard-checkbox-list__item {
80
- justify-content: space-between;
106
+ flex-direction: row-reverse;
81
107
  }
82
108
  }
83
109
  }