@ardium-ui/ui 5.0.0-alpha.4 → 5.0.0-alpha.40

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 (216) hide show
  1. package/fesm2022/ardium-ui-ui.mjs +4120 -2316
  2. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  3. package/lib/_internal/disablable-component.d.ts +2 -1
  4. package/lib/_internal/focusable-component.d.ts +2 -1
  5. package/lib/_internal/form-field-component.d.ts +2 -1
  6. package/lib/_internal/item-storages/dropdown-item-storage.d.ts +16 -18
  7. package/lib/_internal/item-storages/simple-item-storage.d.ts +15 -12
  8. package/lib/_internal/item-storages/simplest-item-storage.d.ts +1 -1
  9. package/lib/_internal/ngmodel-component.d.ts +1 -0
  10. package/lib/_internal/selectable-list-component.d.ts +6 -6
  11. package/lib/_internal/utils/date.utils.d.ts +16 -0
  12. package/lib/badge/badge.directive.d.ts +3 -2
  13. package/lib/buttons/_button-base.d.ts +12 -8
  14. package/lib/buttons/_button-base.defaults.d.ts +3 -2
  15. package/lib/buttons/button/button.component.d.ts +5 -5
  16. package/lib/buttons/button/button.defaults.d.ts +0 -2
  17. package/lib/buttons/button/button.directive.d.ts +17 -0
  18. package/lib/buttons/button/button.module.d.ts +3 -2
  19. package/lib/buttons/button/index.d.ts +1 -0
  20. package/lib/buttons/fab/fab.component.d.ts +3 -1
  21. package/lib/buttons/icon-button/icon-button.component.d.ts +6 -4
  22. package/lib/buttons/icon-button/icon-button.defaults.d.ts +2 -1
  23. package/lib/calendar/abstract-calendar.d.ts +127 -0
  24. package/lib/calendar/calendar.component.d.ts +8 -96
  25. package/lib/calendar/calendar.defaults.d.ts +12 -1
  26. package/lib/calendar/calendar.internal-directives.d.ts +24 -8
  27. package/lib/calendar/calendar.internal-types.d.ts +1 -0
  28. package/lib/calendar/calendar.module.d.ts +4 -9
  29. package/lib/calendar/calendar.types.d.ts +19 -5
  30. package/lib/calendar/index.d.ts +3 -0
  31. package/lib/calendar/range-calendar.component.d.ts +16 -0
  32. package/lib/calendar/range-calendar.directives.d.ts +51 -0
  33. package/lib/calendar/range-calendar.module.d.ts +10 -0
  34. package/lib/calendar/views/calendar-views.module.d.ts +13 -0
  35. package/lib/calendar/views/days-view/days-view.component.d.ts +20 -2
  36. package/lib/calendar/views/days-view/days-view.helpers.d.ts +2 -2
  37. package/lib/calendar/views/months-view/months-view.component.d.ts +15 -3
  38. package/lib/calendar/views/years-view/years-view.component.d.ts +15 -3
  39. package/lib/checkbox-list/checkbox-list.component.d.ts +9 -7
  40. package/lib/checkbox-list/checkbox-list.directives.d.ts +7 -0
  41. package/lib/checkbox-list/checkbox-list.module.d.ts +1 -1
  42. package/lib/chip/chip.component.d.ts +2 -1
  43. package/lib/chip/deletable-chip/deletable-chip.component.d.ts +2 -1
  44. package/lib/chip/selectable-chip/selectable-chip.component.d.ts +3 -2
  45. package/lib/dialog/dialog.component.d.ts +8 -7
  46. package/lib/divider/divider.component.d.ts +2 -1
  47. package/lib/dropdown-panel/dropdown-panel.component.d.ts +2 -1
  48. package/lib/file-inputs/file-input/file-input.component.d.ts +2 -1
  49. package/lib/file-inputs/file-input-base.d.ts +4 -5
  50. package/lib/form-field/error/error.directive.d.ts +3 -2
  51. package/lib/form-field/form-field-base.d.ts +6 -2
  52. package/lib/form-field/form-field-native-inputs.d.ts +3 -2
  53. package/lib/form-field/form-field.component.d.ts +1 -1
  54. package/lib/form-field/form-field.module.d.ts +5 -4
  55. package/lib/form-field/hint/hint.directive.d.ts +3 -2
  56. package/lib/form-field/hint-error/hint-error.component.d.ts +6 -0
  57. package/lib/form-field/hint-error/hint-error.directive.d.ts +9 -0
  58. package/lib/form-field/horizontal-form-field.component.d.ts +1 -1
  59. package/lib/form-field/index.d.ts +4 -0
  60. package/lib/form-field/label/label.component.d.ts +3 -2
  61. package/lib/form-field-frame/form-field-frame.component.d.ts +4 -3
  62. package/lib/icon/icon.component.d.ts +2 -1
  63. package/lib/inputs/_simple-input-base.d.ts +4 -2
  64. package/lib/inputs/autocomplete-input/autocomplete-input.component.d.ts +5 -4
  65. package/lib/inputs/date-input/abstract-date-input.d.ts +112 -0
  66. package/lib/inputs/date-input/date-input.component.d.ts +19 -81
  67. package/lib/inputs/date-input/date-input.defaults.d.ts +21 -3
  68. package/lib/inputs/date-input/{date-input.directive.d.ts → date-input.directives.d.ts} +2 -2
  69. package/lib/inputs/date-input/date-input.module.d.ts +5 -4
  70. package/lib/inputs/date-input/date-input.serializers.d.ts +4 -2
  71. package/lib/inputs/date-input/date-input.types.d.ts +5 -4
  72. package/lib/inputs/date-input/date-range-input.component.d.ts +29 -0
  73. package/lib/inputs/date-input/date-range-input.directives.d.ts +82 -0
  74. package/lib/inputs/date-input/date-range-input.module.d.ts +17 -0
  75. package/lib/inputs/date-input/index.d.ts +7 -1
  76. package/lib/inputs/date-input/multipage-date-range-input.component.d.ts +44 -0
  77. package/lib/inputs/date-input/multipage-date-range-input.directives.d.ts +82 -0
  78. package/lib/inputs/date-input/multipage-date-range-input.module.d.ts +17 -0
  79. package/lib/inputs/digit-input/digit-input.component.d.ts +4 -3
  80. package/lib/inputs/hex-input/hex-input.component.d.ts +5 -3
  81. package/lib/inputs/number-input/number-input.component.d.ts +11 -10
  82. package/lib/inputs/number-input/number-input.defaults.d.ts +1 -0
  83. package/lib/inputs/password-input/password-input.component.d.ts +4 -3
  84. package/lib/kbd/kbd.component.d.ts +2 -1
  85. package/lib/kbd-shortcut/kbd-shortcut.component.d.ts +2 -1
  86. package/lib/modal/modal.component.d.ts +6 -5
  87. package/lib/option/option.component.d.ts +2 -1
  88. package/lib/progress-bar/progress-bar.component.d.ts +4 -3
  89. package/lib/progress-circle/progress-circle.component.d.ts +5 -4
  90. package/lib/segment/segment.component.d.ts +6 -5
  91. package/lib/select/select.component.d.ts +33 -26
  92. package/lib/select/select.defaults.d.ts +7 -0
  93. package/lib/select/select.directive.d.ts +6 -0
  94. package/lib/select/select.module.d.ts +1 -1
  95. package/lib/select/select.types.d.ts +4 -2
  96. package/lib/select/select.utils.d.ts +2 -0
  97. package/lib/slider/abstract-slider.d.ts +35 -29
  98. package/lib/slider/index.d.ts +1 -0
  99. package/lib/slider/range-slider/range-slider.component.d.ts +12 -9
  100. package/lib/slider/range-slider/range-slider.types.d.ts +6 -0
  101. package/lib/slider/slider.component.d.ts +5 -4
  102. package/lib/slider/slider.types.d.ts +3 -3
  103. package/lib/star/rating-display/rating-display.component.d.ts +2 -1
  104. package/lib/star/rating-input/rating-input.component.d.ts +2 -1
  105. package/lib/tabber/index.d.ts +2 -1
  106. package/lib/tabber/tab/tab.component.d.ts +14 -8
  107. package/lib/tabber/tabber.component.d.ts +25 -9
  108. package/lib/tabber/tabber.defaults.d.ts +1 -0
  109. package/lib/tabber/tabber.directives.d.ts +9 -0
  110. package/lib/tabber/tabber.module.d.ts +3 -2
  111. package/lib/tabber/tabber.types.d.ts +5 -0
  112. package/lib/table/table.component.d.ts +16 -15
  113. package/lib/table-pagination/table-pagination.component.d.ts +4 -3
  114. package/lib/text-list/text-list.component.d.ts +2 -1
  115. package/lib/types/item-storage.types.d.ts +15 -17
  116. package/package.json +1 -1
  117. package/prebuilt-themes/default/buttons/button.css +72 -57
  118. package/prebuilt-themes/default/buttons/button.css.map +1 -1
  119. package/prebuilt-themes/default/buttons/fab.css +65 -51
  120. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  121. package/prebuilt-themes/default/buttons/icon-button.css +56 -44
  122. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -1
  123. package/prebuilt-themes/default/calendar.css +134 -54
  124. package/prebuilt-themes/default/calendar.css.map +1 -1
  125. package/prebuilt-themes/default/card.css.map +1 -1
  126. package/prebuilt-themes/default/checkbox-list.css +48 -22
  127. package/prebuilt-themes/default/checkbox-list.css.map +1 -1
  128. package/prebuilt-themes/default/checkbox.css +4 -4
  129. package/prebuilt-themes/default/chips.css +18 -13
  130. package/prebuilt-themes/default/chips.css.map +1 -1
  131. package/prebuilt-themes/default/color-display.css +1 -1
  132. package/prebuilt-themes/default/core.css +9 -1
  133. package/prebuilt-themes/default/core.css.map +1 -1
  134. package/prebuilt-themes/default/dropdown-panel.css.map +1 -1
  135. package/prebuilt-themes/default/form-field-frame.css +6 -2
  136. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  137. package/prebuilt-themes/default/form-field.css +31 -11
  138. package/prebuilt-themes/default/form-field.css.map +1 -1
  139. package/prebuilt-themes/default/inputs/autocomplete-input.css +72 -25
  140. package/prebuilt-themes/default/inputs/autocomplete-input.css.map +1 -1
  141. package/prebuilt-themes/default/inputs/color-input.css +5 -44
  142. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  143. package/prebuilt-themes/default/inputs/date-input.css +79 -21
  144. package/prebuilt-themes/default/inputs/date-input.css.map +1 -1
  145. package/prebuilt-themes/default/inputs/digit-input.css +1 -1
  146. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  147. package/prebuilt-themes/default/inputs/file-input.css +112 -62
  148. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  149. package/prebuilt-themes/default/inputs/hex-input.css +47 -20
  150. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  151. package/prebuilt-themes/default/inputs/input.css +39 -15
  152. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  153. package/prebuilt-themes/default/inputs/number-input.css +52 -22
  154. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  155. package/prebuilt-themes/default/inputs/password-input.css +67 -22
  156. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  157. package/prebuilt-themes/default/inputs/search-bar.css +41 -16
  158. package/prebuilt-themes/default/inputs/search-bar.css.map +1 -1
  159. package/prebuilt-themes/default/kbd-shortcut.css +1 -1
  160. package/prebuilt-themes/default/kbd.css +1 -1
  161. package/prebuilt-themes/default/modal.css +2 -1
  162. package/prebuilt-themes/default/modal.css.map +1 -1
  163. package/prebuilt-themes/default/progress-circle.css.map +1 -1
  164. package/prebuilt-themes/default/radio.css +9 -7
  165. package/prebuilt-themes/default/radio.css.map +1 -1
  166. package/prebuilt-themes/default/segment.css +74 -61
  167. package/prebuilt-themes/default/segment.css.map +1 -1
  168. package/prebuilt-themes/default/select.css +91 -44
  169. package/prebuilt-themes/default/select.css.map +1 -1
  170. package/prebuilt-themes/default/slide-toggle.css +4 -4
  171. package/prebuilt-themes/default/slide-toggle.css.map +1 -1
  172. package/prebuilt-themes/default/slider.css +100 -52
  173. package/prebuilt-themes/default/slider.css.map +1 -1
  174. package/prebuilt-themes/default/stars.css +4 -4
  175. package/prebuilt-themes/default/stars.css.map +1 -1
  176. package/prebuilt-themes/default/statebox.css +5 -5
  177. package/prebuilt-themes/default/tabber.css +40 -16
  178. package/prebuilt-themes/default/tabber.css.map +1 -1
  179. package/prebuilt-themes/default/table.css.map +1 -1
  180. package/themes/_variables.scss +2 -1
  181. package/themes/default/_mixins.scss +4 -4
  182. package/themes/default/buttons/_button-mixins.scss +43 -33
  183. package/themes/default/buttons/button.scss +49 -28
  184. package/themes/default/buttons/fab.scss +48 -26
  185. package/themes/default/buttons/icon-button.scss +38 -17
  186. package/themes/default/calendar.scss +146 -55
  187. package/themes/default/checkbox-list.scss +47 -21
  188. package/themes/default/chips.scss +12 -12
  189. package/themes/default/color-display.scss +1 -1
  190. package/themes/default/core.scss +11 -1
  191. package/themes/default/form-field-frame.scss +9 -4
  192. package/themes/default/form-field.scss +23 -9
  193. package/themes/default/inputs/_shared.scss +30 -9
  194. package/themes/default/inputs/autocomplete-input.scss +68 -14
  195. package/themes/default/inputs/color-input.scss +2 -2
  196. package/themes/default/inputs/date-input.scss +54 -5
  197. package/themes/default/inputs/digit-input.scss +1 -1
  198. package/themes/default/inputs/file-input.scss +83 -23
  199. package/themes/default/inputs/hex-input.scss +44 -9
  200. package/themes/default/inputs/input.scss +37 -4
  201. package/themes/default/inputs/number-input.scss +54 -15
  202. package/themes/default/inputs/password-input.scss +70 -15
  203. package/themes/default/inputs/search-bar.scss +39 -5
  204. package/themes/default/kbd-shortcut.scss +1 -1
  205. package/themes/default/kbd.scss +1 -1
  206. package/themes/default/modal.scss +2 -1
  207. package/themes/default/radio.scss +5 -3
  208. package/themes/default/segment.scss +75 -67
  209. package/themes/default/select.scss +96 -42
  210. package/themes/default/slider.scss +100 -65
  211. package/themes/default/statebox.scss +1 -1
  212. package/themes/default/tabber.scss +36 -13
  213. package/lib/tabber/tab/tab.defaults.d.ts +0 -6
  214. package/prebuilt-themes/default/calendar-OLD.css +0 -294
  215. package/prebuilt-themes/default/calendar-OLD.css.map +0 -1
  216. package/themes/default/calendar-OLD.scss +0 -183
@@ -3,21 +3,52 @@
3
3
  @use './coloring.scss' as CM;
4
4
  @use '../variables' as ARD;
5
5
 
6
- $grid-size: 2.5rem;
6
+ :root {
7
+ --ard-calendar-grid-size: 2.25rem;
8
+ --ard-calendar-grid-gap: 0.25rem;
9
+ --ard-calendar-padding: 0.375rem;
10
+ --ard-calendar-header-padding: 0.375rem 0 0.75rem 0;
11
+ --ard-calendar-weekday-padding: 0 0 0.5rem 0;
12
+ --ard-calendar-weekday-font-size: 0.875rem;
13
+ --ard-calendar-weekday-font-weight: 500;
14
+ --ard-calendar-weekday-color: #{ARD.$text};
15
+ --ard-calendar-floating-month-transform: none;
16
+ --ard-calendar-floating-month-padding: 0 0 0 1rem;
17
+ --ard-calendar-floating-month-font-size: 0.875rem;
18
+ --ard-calendar-floating-month-font-weight: 500;
19
+ --ard-calendar-floating-month-color: #{ARD.$text3};
20
+ --ard-calendar-entry-padding: 0;
21
+ --ard-calendar-entry-font-size: 0.875rem;
22
+ --ard-calendar-entry-font-weight: 400;
23
+ --ard-calendar-entry-border-radius: 9999px;
24
+ --ard-calendar-entry-range-overlay-border-width: 1px;
25
+ --ard-calendar-entry-range-overlay-border-style: dashed;
26
+ --ard-calendar-entry-today-border-color: #{ARD.$detail};
27
+ --ard-calendar-entry-today-selected-border: 2px solid #{ARD.$bg};
28
+ --ard-calendar-entry-highlighted-overlay-opacity: 20%;
29
+ --ard-calendar-entry-selected-overlay-opacity: 100%;
30
+ --ard-calendar-entry-selected-range-overlay-opacity: 12%;
31
+ --ard-calendar-entry-disabled-overlay-opacity: 12%;
32
+ --ard-calendar-entry-disabled-highlighted-overlay-opacity: 15%;
33
+ --ard-calendar-entry-disabled-opacity: 50%;
34
+ }
7
35
 
8
36
  .ard-calendar {
9
37
  @include CM.typeColors();
10
- width: 18.5rem;
38
+ min-width: calc(var(--ard-calendar-grid-size) * 7 + var(--ard-calendar-grid-gap) * 6);
11
39
  user-select: none;
40
+ padding: var(--ard-calendar-padding, 0 0.375rem 0.375rem 0.375rem);
41
+ box-sizing: content-box;
12
42
 
13
43
  //! top toolbar
14
44
  .ard-calendar__top-toolbar {
15
45
  .ard-calendar__calendar-header {
16
- display: flex;
17
- justify-content: space-between;
46
+ display: grid;
47
+ grid-template-columns: 1fr 5fr 1fr;
18
48
  align-items: center;
49
+ justify-items: center;
19
50
  width: 100%;
20
- padding: 0.75rem 0;
51
+ padding: var(--ard-calendar-header-padding, 0.75rem 0);
21
52
 
22
53
  .ard-dropdown-arrow {
23
54
  @include DA.dropdown-arrow();
@@ -32,59 +63,64 @@ $grid-size: 2.5rem;
32
63
  //! weekdays
33
64
  .ard-calendar__weekdays {
34
65
  display: grid;
35
- grid-template-columns: repeat(7, $grid-size);
66
+ grid-template-columns: repeat(7, var(--ard-calendar-grid-size, 2.25rem));
67
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
36
68
  align-items: center;
37
- padding: 0 0.375rem 0.5rem 0.375rem;
69
+ padding: var(--ard-calendar-weekday-padding, 0 0 0.5rem 0);
38
70
 
39
71
  .ard-calendar__weekday {
40
72
  text-align: center;
41
- font-size: 0.875rem;
42
- font-weight: 500;
43
- color: ARD.$text;
73
+ font-size: var(--ard-calendar-weekday-font-size, 0.875rem);
74
+ font-weight: var(--ard-calendar-weekday-font-weight, 500);
75
+ color: var(--ard-calendar-weekday-color, #{ARD.$text});
44
76
  }
45
77
  }
46
78
  //! days grid
47
79
  .ard-calendar__days-grid {
48
- padding: 0.375rem;
49
- padding-top: 0;
80
+ padding: 0;
50
81
  display: grid;
51
- grid-template-columns: repeat(7, $grid-size);
82
+ grid-template-columns: repeat(7, var(--ard-calendar-grid-size));
52
83
  position: relative;
53
84
  outline: none;
85
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
54
86
 
55
87
  > * {
56
- max-width: 100%;
88
+ width: var(--ard-calendar-grid-size);
89
+ max-width: var(--ard-calendar-grid-size);
90
+ height: var(--ard-calendar-grid-size);
91
+ max-height: var(--ard-calendar-grid-size);
57
92
  box-sizing: border-box;
58
- aspect-ratio: 1;
59
93
  }
60
94
  &.ard-reserve-top-row {
61
- padding-top: $grid-size;
95
+ padding-top: calc(var(--ard-calendar-grid-size) + var(--ard-calendar-grid-gap));
62
96
  }
63
97
  .ard-calendar__floating-month {
64
98
  position: absolute;
65
99
  top: 0;
66
100
  left: 0;
101
+ transform: var(--ard-calendar-floating-month-transform, none);
67
102
  width: 100%;
68
103
  box-sizing: border-box;
69
104
  aspect-ratio: 7;
70
- padding-left: 1rem;
105
+ padding: var(--ard-calendar-floating-month-padding, 0 0 0 1rem);
71
106
  display: flex;
72
107
  align-items: center;
73
- font-size: 0.875rem;
74
- font-weight: 500;
75
- color: ARD.$text3;
108
+ font-size: var(--ard-calendar-floating-month-font-size, 0.875rem);
109
+ font-weight: var(--ard-calendar-floating-month-font-weight, 500);
110
+ color: var(--ard-calendar-floating-month-color, #{ARD.$text3});
76
111
  letter-spacing: 0.5px;
77
112
  }
78
113
  }
79
114
  //! years grid
80
115
  .ard-calendar__simple-grid {
81
116
  border-top: 1px solid ARD.$detail-ultralight;
82
- margin-top: 0.25rem;
83
117
  display: grid;
84
118
  grid-template-columns: repeat(4, 1fr);
85
- grid-template-rows: repeat(6, $grid-size);
119
+ grid-template-rows: repeat(6, var(--ard-calendar-grid-size));
86
120
  position: relative;
87
121
  outline: none;
122
+ padding: 0;
123
+ gap: var(--ard-calendar-grid-gap, 0.25rem);
88
124
 
89
125
  > * {
90
126
  max-width: 100%;
@@ -99,7 +135,8 @@ $grid-size: 2.5rem;
99
135
  z-index: 1;
100
136
  cursor: pointer;
101
137
  outline: none;
102
- padding: 0.125rem;
138
+ padding: var(--ard-calendar-entry-padding, 0);
139
+ box-sizing: border-box;
103
140
 
104
141
  .ard-calendar__entry-button {
105
142
  width: 100%;
@@ -108,21 +145,33 @@ $grid-size: 2.5rem;
108
145
  display: flex;
109
146
  align-items: center;
110
147
  justify-content: center;
111
- font-size: 0.875rem;
148
+ font-size: var(--ard-calendar-entry-font-size, 0.875rem);
149
+ font-weight: var(--ard-calendar-entry-font-weight, 400);
112
150
  background: transparent;
113
151
  border: 1px solid transparent;
114
- border-radius: 9999px;
152
+ border-radius: var(--ard-calendar-entry-border-radius, 9999px);
115
153
  position: relative;
116
154
  cursor: pointer;
155
+ outline: none;
156
+ box-sizing: border-box;
117
157
 
118
158
  .ard-focus-overlay {
119
159
  @include DM.focus-overlay();
120
160
  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;
161
+ background: var(--ard-cmpcl--overlay);
162
+ transition: border-color 0.1s ease, opacity 0.1s ease;
163
+ }
164
+ .ard-range-overlay {
165
+ @include DM.focus-overlay();
166
+ z-index: -1;
167
+ opacity: 1;
168
+ left: -calc(var(--ard-calendar-grid-gap, 0.25rem) / 2);
169
+ right: -calc(var(--ard-calendar-grid-gap, 0.25rem) / 2);
170
+ border: var(--ard-calendar-entry-range-overlay-border-width, 1px)
171
+ var(--ard-calendar-entry-range-overlay-border-style, dashed) transparent;
172
+ background: transparent;
173
+ transition: none;
174
+ border-radius: 0;
126
175
  }
127
176
  }
128
177
  &.ard-calendar__entry-empty {
@@ -130,12 +179,51 @@ $grid-size: 2.5rem;
130
179
  }
131
180
  &.ard-calendar-today {
132
181
  .ard-calendar__entry-button {
133
- border-color: ARD.$detail;
182
+ border-color: var(--ard-calendar-entry-today-border-color, #{ARD.$detail});
183
+ }
184
+ }
185
+ &.ard-calendar__entry-highlighted-in-range {
186
+ .ard-range-overlay {
187
+ opacity: 1;
188
+ border-top-color: var(--ard-cmpcl--bg-colored);
189
+ border-bottom-color: var(--ard-cmpcl--bg-colored);
190
+ }
191
+ &.ard-calendar__entry-selected-start {
192
+ .ard-range-overlay {
193
+ border-left-color: var(--ard-cmpcl--bg-colored);
194
+ }
195
+ }
196
+ &.ard-calendar__entry-selected-end,
197
+ &.ard-calendar__entry-highlighted {
198
+ .ard-range-overlay {
199
+ border-right-color: var(--ard-cmpcl--bg-colored);
200
+ }
134
201
  }
135
202
  }
136
203
  &.ard-calendar__entry-highlighted {
137
204
  .ard-focus-overlay {
138
- opacity: 20%;
205
+ opacity: var(--ard-calendar-entry-highlighted-overlay-opacity, 20%);
206
+ }
207
+ }
208
+ &.ard-calendar__entry-selected-start {
209
+ .ard-range-overlay {
210
+ left: 0;
211
+ border-top-left-radius: var(--ard-calendar-entry-border-radius);
212
+ border-bottom-left-radius: var(--ard-calendar-entry-border-radius);
213
+ }
214
+ }
215
+ &.ard-calendar__entry-selected-end,
216
+ &.ard-calendar__entry-highlighted:not(.ard-calendar__entry-selected-in-range) {
217
+ .ard-range-overlay {
218
+ right: 0;
219
+ border-top-right-radius: var(--ard-calendar-entry-border-radius);
220
+ border-bottom-right-radius: var(--ard-calendar-entry-border-radius);
221
+ }
222
+ }
223
+ &.ard-calendar__entry-selected-in-range {
224
+ .ard-range-overlay {
225
+ opacity: var(--ard-calendar-entry-selected-range-overlay-opacity, 12%);
226
+ background-color: var(--ard-cmpcl--bg-colored);
139
227
  }
140
228
  }
141
229
  &.ard-calendar__entry-selected {
@@ -143,18 +231,19 @@ $grid-size: 2.5rem;
143
231
  color: var(--ard-cmpcl--on-bg-colored);
144
232
  }
145
233
  .ard-focus-overlay {
146
- opacity: 100%;
234
+ opacity: var(--ard-calendar-entry-selected-overlay-opacity, 100%);
235
+ background: var(--ard-cmpcl--bg-colored);
147
236
  }
148
237
 
149
238
  &.ard-calendar-today {
150
239
  .ard-focus-overlay {
151
- border-color: ARD.$bg;
240
+ border: var(--ard-calendar-entry-today-selected-border, 2px solid #{ARD.$bg});
152
241
  }
153
242
  }
154
243
  }
155
244
  &.ard-calendar__entry-disabled {
156
245
  pointer-events: none;
157
- opacity: 50%;
246
+ opacity: var(--ard-calendar-entry-disabled-overlay-opacity, 50%);
158
247
 
159
248
  .ard-calendar__entry-button {
160
249
  cursor: default;
@@ -164,30 +253,32 @@ $grid-size: 2.5rem;
164
253
  }
165
254
  &.ard-calendar__entry-highlighted {
166
255
  .ard-focus-overlay {
167
- opacity: 15%;
256
+ opacity: var(--ard-calendar-entry-disabled-highlighted-overlay-opacity, 15%);
168
257
  }
169
258
  }
170
259
  }
171
260
  }
172
- .ard-calendar__day-labels {
173
- font-size: 0.8125rem;
174
- color: ARD.$text3;
175
- height: 1.25rem;
176
- position: relative;
261
+ .ard-years-view,
262
+ .ard-months-view {
263
+ .ard-calendar__entry {
264
+ .ard-calendar__entry-button {
265
+ .ard-range-overlay {
266
+ left: calc(-var(--ard-calendar-grid-gap) / 2 - 1px);
267
+ right: calc(-var(--ard-calendar-grid-gap) / 2 - 1px);
268
+ border: none;
269
+ }
270
+ }
177
271
 
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;
272
+ &.ard-calendar__entry-selected-start {
273
+ .ard-range-overlay {
274
+ left: 0;
275
+ }
276
+ }
277
+ &.ard-calendar__entry-selected-end {
278
+ .ard-range-overlay {
279
+ right: 0;
280
+ }
281
+ }
191
282
  }
192
283
  }
193
284
  }
@@ -199,6 +290,6 @@ $grid-size: 2.5rem;
199
290
  }
200
291
  .ard-disabled {
201
292
  .ard-calendar {
202
- opacity: 50%;
293
+ opacity: var(--ard-calendar-entry-disabled-opacity, 50%);
203
294
  }
204
295
  }
@@ -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
  }
@@ -9,7 +9,7 @@
9
9
  @include clearButton.clearButton();
10
10
  @include defaultMixins.formVariants();
11
11
 
12
- font-family: 'Roboto', sans-serif;
12
+ font-family: var(--ard-font-family);
13
13
  color: ARD.$text2;
14
14
  background: ARD.$bg;
15
15
  border-radius: var(--ard-variant-border-radius);
@@ -68,10 +68,7 @@
68
68
  &.ard-chip-selectable {
69
69
  background-color: ARD.$bg-f;
70
70
  color: ARD.$text2;
71
- transition:
72
- color 0.15s ease,
73
- border-color 0.15s ease,
74
- background-color 0.15s ease;
71
+ transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
75
72
 
76
73
  &.ard-chip-selected {
77
74
  color: var(--ard-cmpcl--on-bg-colored);
@@ -88,9 +85,7 @@
88
85
  font-weight: 600;
89
86
 
90
87
  &.ard-chip-selectable {
91
- transition:
92
- color 0.15s ease,
93
- border-color 0.15s ease;
88
+ transition: color 0.15s ease, border-color 0.15s ease;
94
89
 
95
90
  > .ard-focus-overlay {
96
91
  opacity: 0;
@@ -110,19 +105,20 @@
110
105
 
111
106
  &.ard-chip-selected {
112
107
  color: var(--ard-cmpcl--content);
108
+ border-color: var(--ard-cmpcl--content);
113
109
 
114
110
  > .ard-focus-overlay {
115
- opacity: 7.5%;
111
+ opacity: 12%;
116
112
  }
117
113
  &:hover,
118
114
  &:focus {
119
115
  > .ard-focus-overlay {
120
- opacity: 15%;
116
+ opacity: 17%;
121
117
  }
122
118
  }
123
119
  &:active {
124
120
  > .ard-focus-overlay {
125
- opacity: 20%;
121
+ opacity: 22%;
126
122
  }
127
123
  }
128
124
  }
@@ -130,9 +126,13 @@
130
126
  }
131
127
  &.ard-appearance-outlined-strong {
132
128
  > .ard-focus-overlay {
133
- opacity: 7.5%;
129
+ opacity: 12%;
134
130
  background: var(--ard-cmpcl--bg-colored);
135
131
  }
132
+ &.ard-chip-selectable {
133
+ color: var(--ard-text2);
134
+ border: 1px solid var(--ard-detail-light);
135
+ }
136
136
  }
137
137
 
138
138
  //! alignments
@@ -14,7 +14,7 @@
14
14
  }
15
15
 
16
16
  .ard-color-display-label {
17
- font-family: monospace;
17
+ font-family: var(--ard-font-family-mono);
18
18
  font-size: 1.15em;
19
19
  }
20
20
 
@@ -30,16 +30,26 @@
30
30
  --ard-lighten-overlay-light: rgba(255, 255, 255, 5%);
31
31
  --ard-darken-overlay: rgba(0, 0, 0, 12.5%);
32
32
  --ard-darken-overlay-strong: rgba(0, 0, 0, 20%);
33
+ --ard-darken-overlay-medium-strong: rgba(0, 0, 0, 13%);
33
34
  --ard-darken-overlay-medium: rgba(0, 0, 0, 10%);
34
35
  --ard-darken-overlay-light: rgba(0, 0, 0, 5%);
35
36
  --ard-darken-overlay-ultralight: rgba(0, 0, 0, 3%);
36
37
 
38
+ --ard-font-family: 'Roboto', sans-serif;
39
+ --ard-font-family-mono: monospace;
40
+
37
41
  --ard-gold: #ffc107;
38
42
 
39
43
  --ard-clear-button-size: 0.9rem;
40
44
  --ard-dropdown-button-size: 0.4rem;
41
45
  --ard-form-field-height: 2.3125rem;
42
- --ard-form-field-compact-height: 1.6875rem;
46
+ --ard-form-field-height-compact: 1.6875rem;
47
+ --ard-form-field-font-size: 1rem;
48
+ --ard-form-field-font-size-compact: 1rem;
49
+ --ard-form-field-padding: 0 0.375rem;
50
+ --ard-form-field-padding-compact: 0 0.375rem;
51
+
52
+ --ard-rounded-corner-radius: 0.375rem;
43
53
 
44
54
  --ard-primary-50: 234, 235, 243;
45
55
  --ard-primary-100: 159, 167, 228;
@@ -12,7 +12,7 @@
12
12
  position: relative;
13
13
  font-size: 1rem;
14
14
  line-height: 1.25em;
15
- font-family: 'Roboto', sans-serif;
15
+ font-family: var(--ard-font-family);
16
16
 
17
17
  .ard-form-field-content-container {
18
18
  flex-grow: 1;
@@ -53,9 +53,7 @@
53
53
  .ard-form-field-overlay {
54
54
  background: ARD.$overlay;
55
55
  opacity: 0;
56
- transition:
57
- opacity 0.15s ARD.$timing-fn,
58
- background-color 0.15s ARD.$timing-fn;
56
+ transition: opacity 0.15s ARD.$timing-fn, background-color 0.15s ARD.$timing-fn;
59
57
  }
60
58
 
61
59
  &:hover {
@@ -79,3 +77,10 @@
79
77
  }
80
78
  }
81
79
  }
80
+ .ard-readonly .ard-form-field-frame {
81
+ &:hover {
82
+ .ard-form-field-overlay {
83
+ opacity: 0;
84
+ }
85
+ }
86
+ }
@@ -45,32 +45,41 @@ ard-horizontal-form-field {
45
45
  .ard-form-field__hints-right,
46
46
  .ard-form-field__errors-right {
47
47
  > * {
48
- padding-left: 0.25rem;
48
+ padding-left: 0.5rem;
49
49
  }
50
50
  }
51
51
  .ard-hint,
52
52
  .ard-error {
53
53
  font-size: 1em;
54
- line-height: 1.1;
55
- display: block;
56
- height: 1.1em;
54
+ line-height: 1.2;
55
+ display: inline-grid;
56
+ min-height: 1.2em;
57
57
  }
58
58
  .ard-hint {
59
59
  color: ARD.$text2;
60
60
  }
61
- .ard-error {
61
+ .ard-error:not(.ard-hint-error),
62
+ .ard-form-field__errors .ard-hint-error {
62
63
  color: ARD.$danger700;
63
64
  overflow: hidden;
65
+ }
66
+ .ard-error:not(.ard-hint-error) {
64
67
  animation: errorAppear 0.25s ARD.$timing-fn forwards;
65
68
  }
69
+ .ard-form-field__default-hint,
70
+ .ard-form-field__default-error {
71
+ gap: 0.375em;
72
+ }
66
73
 
67
74
  &.ard-form-field__with-error {
68
- .ard-label {
75
+ .ard-label,
76
+ ard-label {
69
77
  color: ARD.$danger700;
70
78
  }
71
79
  }
72
80
  &.ard-form-field__is-success {
73
- .ard-label {
81
+ .ard-label,
82
+ ard-label {
74
83
  color: ARD.$success700;
75
84
  }
76
85
  }
@@ -91,6 +100,7 @@ ard-horizontal-form-field {
91
100
 
92
101
  .ard-form-field__label-container {
93
102
  width: var(--ard-horizontal-form-field-label-width, 12rem);
103
+ min-width: var(--ard-horizontal-form-field-label-width, 12rem);
94
104
  height: ARD.$form-field-height;
95
105
  display: flex;
96
106
  align-items: center;
@@ -107,11 +117,15 @@ ard-horizontal-form-field {
107
117
  }
108
118
  }
109
119
 
120
+ ard-label {
121
+ display: flex;
122
+ }
123
+
110
124
  @keyframes errorAppear {
111
125
  from {
112
- height: 0;
126
+ grid-template-rows: 0fr;
113
127
  }
114
128
  to {
115
- height: 1.1em;
129
+ grid-template-rows: 1fr;
116
130
  }
117
131
  }