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

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 (217) hide show
  1. package/fesm2022/ardium-ui-ui.mjs +4123 -2319
  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 +5 -3
  105. package/lib/star/rating-input/rating-input.defaults.d.ts +2 -2
  106. package/lib/tabber/index.d.ts +2 -1
  107. package/lib/tabber/tab/tab.component.d.ts +14 -8
  108. package/lib/tabber/tabber.component.d.ts +25 -9
  109. package/lib/tabber/tabber.defaults.d.ts +1 -0
  110. package/lib/tabber/tabber.directives.d.ts +9 -0
  111. package/lib/tabber/tabber.module.d.ts +3 -2
  112. package/lib/tabber/tabber.types.d.ts +5 -0
  113. package/lib/table/table.component.d.ts +16 -15
  114. package/lib/table-pagination/table-pagination.component.d.ts +4 -3
  115. package/lib/text-list/text-list.component.d.ts +2 -1
  116. package/lib/types/item-storage.types.d.ts +15 -17
  117. package/package.json +1 -1
  118. package/prebuilt-themes/default/buttons/button.css +72 -57
  119. package/prebuilt-themes/default/buttons/button.css.map +1 -1
  120. package/prebuilt-themes/default/buttons/fab.css +65 -51
  121. package/prebuilt-themes/default/buttons/fab.css.map +1 -1
  122. package/prebuilt-themes/default/buttons/icon-button.css +56 -44
  123. package/prebuilt-themes/default/buttons/icon-button.css.map +1 -1
  124. package/prebuilt-themes/default/calendar.css +134 -54
  125. package/prebuilt-themes/default/calendar.css.map +1 -1
  126. package/prebuilt-themes/default/card.css.map +1 -1
  127. package/prebuilt-themes/default/checkbox-list.css +48 -22
  128. package/prebuilt-themes/default/checkbox-list.css.map +1 -1
  129. package/prebuilt-themes/default/checkbox.css +4 -4
  130. package/prebuilt-themes/default/chips.css +18 -13
  131. package/prebuilt-themes/default/chips.css.map +1 -1
  132. package/prebuilt-themes/default/color-display.css +1 -1
  133. package/prebuilt-themes/default/core.css +9 -1
  134. package/prebuilt-themes/default/core.css.map +1 -1
  135. package/prebuilt-themes/default/dropdown-panel.css.map +1 -1
  136. package/prebuilt-themes/default/form-field-frame.css +6 -2
  137. package/prebuilt-themes/default/form-field-frame.css.map +1 -1
  138. package/prebuilt-themes/default/form-field.css +31 -11
  139. package/prebuilt-themes/default/form-field.css.map +1 -1
  140. package/prebuilt-themes/default/inputs/autocomplete-input.css +72 -25
  141. package/prebuilt-themes/default/inputs/autocomplete-input.css.map +1 -1
  142. package/prebuilt-themes/default/inputs/color-input.css +5 -44
  143. package/prebuilt-themes/default/inputs/color-input.css.map +1 -1
  144. package/prebuilt-themes/default/inputs/date-input.css +79 -21
  145. package/prebuilt-themes/default/inputs/date-input.css.map +1 -1
  146. package/prebuilt-themes/default/inputs/digit-input.css +1 -1
  147. package/prebuilt-themes/default/inputs/digit-input.css.map +1 -1
  148. package/prebuilt-themes/default/inputs/file-input.css +112 -62
  149. package/prebuilt-themes/default/inputs/file-input.css.map +1 -1
  150. package/prebuilt-themes/default/inputs/hex-input.css +47 -20
  151. package/prebuilt-themes/default/inputs/hex-input.css.map +1 -1
  152. package/prebuilt-themes/default/inputs/input.css +39 -15
  153. package/prebuilt-themes/default/inputs/input.css.map +1 -1
  154. package/prebuilt-themes/default/inputs/number-input.css +52 -22
  155. package/prebuilt-themes/default/inputs/number-input.css.map +1 -1
  156. package/prebuilt-themes/default/inputs/password-input.css +67 -22
  157. package/prebuilt-themes/default/inputs/password-input.css.map +1 -1
  158. package/prebuilt-themes/default/inputs/search-bar.css +41 -16
  159. package/prebuilt-themes/default/inputs/search-bar.css.map +1 -1
  160. package/prebuilt-themes/default/kbd-shortcut.css +1 -1
  161. package/prebuilt-themes/default/kbd.css +1 -1
  162. package/prebuilt-themes/default/modal.css +2 -1
  163. package/prebuilt-themes/default/modal.css.map +1 -1
  164. package/prebuilt-themes/default/progress-circle.css.map +1 -1
  165. package/prebuilt-themes/default/radio.css +9 -7
  166. package/prebuilt-themes/default/radio.css.map +1 -1
  167. package/prebuilt-themes/default/segment.css +74 -61
  168. package/prebuilt-themes/default/segment.css.map +1 -1
  169. package/prebuilt-themes/default/select.css +91 -44
  170. package/prebuilt-themes/default/select.css.map +1 -1
  171. package/prebuilt-themes/default/slide-toggle.css +4 -4
  172. package/prebuilt-themes/default/slide-toggle.css.map +1 -1
  173. package/prebuilt-themes/default/slider.css +100 -52
  174. package/prebuilt-themes/default/slider.css.map +1 -1
  175. package/prebuilt-themes/default/stars.css +4 -4
  176. package/prebuilt-themes/default/stars.css.map +1 -1
  177. package/prebuilt-themes/default/statebox.css +5 -5
  178. package/prebuilt-themes/default/tabber.css +40 -16
  179. package/prebuilt-themes/default/tabber.css.map +1 -1
  180. package/prebuilt-themes/default/table.css.map +1 -1
  181. package/themes/_variables.scss +2 -1
  182. package/themes/default/_mixins.scss +4 -4
  183. package/themes/default/buttons/_button-mixins.scss +43 -33
  184. package/themes/default/buttons/button.scss +49 -28
  185. package/themes/default/buttons/fab.scss +48 -26
  186. package/themes/default/buttons/icon-button.scss +38 -17
  187. package/themes/default/calendar.scss +146 -55
  188. package/themes/default/checkbox-list.scss +47 -21
  189. package/themes/default/chips.scss +12 -12
  190. package/themes/default/color-display.scss +1 -1
  191. package/themes/default/core.scss +11 -1
  192. package/themes/default/form-field-frame.scss +9 -4
  193. package/themes/default/form-field.scss +23 -9
  194. package/themes/default/inputs/_shared.scss +30 -9
  195. package/themes/default/inputs/autocomplete-input.scss +68 -14
  196. package/themes/default/inputs/color-input.scss +2 -2
  197. package/themes/default/inputs/date-input.scss +54 -5
  198. package/themes/default/inputs/digit-input.scss +1 -1
  199. package/themes/default/inputs/file-input.scss +83 -23
  200. package/themes/default/inputs/hex-input.scss +44 -9
  201. package/themes/default/inputs/input.scss +37 -4
  202. package/themes/default/inputs/number-input.scss +54 -15
  203. package/themes/default/inputs/password-input.scss +70 -15
  204. package/themes/default/inputs/search-bar.scss +39 -5
  205. package/themes/default/kbd-shortcut.scss +1 -1
  206. package/themes/default/kbd.scss +1 -1
  207. package/themes/default/modal.scss +2 -1
  208. package/themes/default/radio.scss +5 -3
  209. package/themes/default/segment.scss +75 -67
  210. package/themes/default/select.scss +96 -42
  211. package/themes/default/slider.scss +100 -65
  212. package/themes/default/statebox.scss +1 -1
  213. package/themes/default/tabber.scss +36 -13
  214. package/lib/tabber/tab/tab.defaults.d.ts +0 -6
  215. package/prebuilt-themes/default/calendar-OLD.css +0 -294
  216. package/prebuilt-themes/default/calendar-OLD.css.map +0 -1
  217. package/themes/default/calendar-OLD.scss +0 -183
@@ -2,33 +2,66 @@
2
2
  @use '../mixins' as defaultMixins;
3
3
  @use '../../variables' as ARD;
4
4
 
5
- ard-number-input {
6
- width: 9.5rem;
5
+ :root {
6
+ --ard-number-input-height: var(--ard-form-field-height, 2.3125rem);
7
+ --ard-number-input-height-compact: var(--ard-form-field-height-compact, 1.6875rem);
8
+ --ard-number-input-gap: 0.625rem;
9
+ --ard-number-input-font-size: var(--ard-form-field-font-size, 1rem);
10
+ --ard-number-input-font-size-compact: var(--ard-form-field-font-size-compact, 0.875rem);
11
+ --ard-number-input-line-height: 1.25;
12
+ --ard-number-input-line-height-compact: 1;
13
+ --ard-number-input-font-weight: 400;
14
+ --ard-number-input-padding: var(--ard-form-field-padding, 0 0.375rem);
15
+ --ard-number-input-padding-compact: var(--ard-form-field-padding-compact, 0 0.375rem);
16
+ --ard-number-input-color: #{ARD.$text};
17
+ --ard-number-input-placeholder-color: #{ARD.$text};
18
+ --ard-number-input-placeholder-opacity: 60%;
19
+
20
+ --ard-number-input-width: 9.5rem;
21
+ --ard-number-input-rounded-border-radius: 8px;
22
+ }
7
23
 
8
- &:not(:has(.ard-quick-change-button)) {
9
- width: 6rem;
10
- }
24
+ ard-number-input {
25
+ width: var(--ard-number-input-width, 9.5rem);
11
26
  }
12
27
 
13
28
  .ard-number-input {
14
- @include inputMixin.genericInput();
29
+ @include inputMixin.genericInput(
30
+ var(--ard-number-input-height, var(--ard-form-field-height, 2.3125rem)),
31
+ var(--ard-number-input-height-compact, var(--ard-form-field-height-compact, 1.6875rem)),
32
+ var(--ard-number-input-gap, 0.625rem),
33
+ var(--ard-number-input-font-size, var(--ard-form-field-font-size, 1rem)),
34
+ var(--ard-number-input-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem)),
35
+ var(--ard-number-input-line-height, 1.25),
36
+ var(--ard-number-input-line-height-compact, 1),
37
+ var(--ard-number-input-font-weight, 400),
38
+ var(--ard-number-input-padding, var(--ard-form-field-padding, 0 0.375rem)),
39
+ var(--ard-number-input-padding-compact, var(--ard-form-field-padding-compact, 0 0.375rem)),
40
+ var(--ard-number-input-color, #{ARD.$text}),
41
+ var(--ard-number-input-placeholder-color, #{ARD.$text}),
42
+ var(--ard-number-input-placeholder-opacity, 60%)
43
+ );
15
44
  @include defaultMixins.formAppearances();
16
- min-height: 2.1875rem;
17
- height: 2.1875rem;
45
+ min-height: var(--ard-form-field-height, var(--ard-number-input-height, 2.3125rem));
18
46
  gap: 0;
19
47
  width: 100%;
20
48
 
21
49
  .ard-input-container {
22
50
  height: 100%;
23
51
  max-width: 100%;
52
+ padding: var(--ard-number-input-padding, var(--ard-form-field-padding, 0 0.375rem));
24
53
 
25
54
  & > input {
26
55
  width: 100%;
27
56
  }
28
57
  }
58
+ .ard-placeholder {
59
+ padding: var(--ard-number-input-padding, var(--ard-form-field-padding, 0 0.375rem));
60
+ }
29
61
 
30
62
  .ard-quick-change-button {
31
63
  position: relative;
64
+ min-width: var(--ard-number-input-height, var(--ard-form-field-height, 2.3125rem));
32
65
 
33
66
  .ard-button {
34
67
  height: 100%;
@@ -63,11 +96,11 @@ ard-number-input {
63
96
 
64
97
  //! variants
65
98
  &.ard-variant-rounded {
66
- border-radius: 8px;
99
+ border-radius: var(--ard-number-input-rounded-border-radius, 8px);
67
100
 
68
101
  &.ard-quick-change-false {
69
102
  .ard-input-container {
70
- border-radius: 8px;
103
+ border-radius: var(--ard-number-input-rounded-border-radius, 8px);
71
104
  }
72
105
  }
73
106
  }
@@ -79,8 +112,8 @@ ard-number-input {
79
112
 
80
113
  .ard-button {
81
114
  border-radius: 9999px !important;
82
- height: 30px;
83
- width: 30px;
115
+ width: var(--ard-number-input-height, var(--ard-form-field-height, 2.3125rem));
116
+ height: var(--ard-number-input-height, var(--ard-form-field-height, 2.3125rem));
84
117
  margin: 0 2px;
85
118
  }
86
119
 
@@ -111,9 +144,15 @@ ard-number-input {
111
144
 
112
145
  //! compact
113
146
  &.ard-compact {
114
- min-height: 1.6875rem;
115
- height: 1.6875rem;
116
- font-size: 0.925rem;
147
+ .ard-input-container {
148
+ padding: var(--ard-number-input-padding-compact, var(--ard-form-field-padding-compact, 0 0.375rem));
149
+ }
150
+ .ard-placeholder {
151
+ padding: var(--ard-number-input-padding-compact, var(--ard-form-field-padding-compact, 0 0.375rem));
152
+ }
153
+ .ard-quick-change-button {
154
+ min-width: var(--ard-number-input-height-compact, var(--ard-form-field-height-compact, 1.6875rem));
155
+ }
117
156
  }
118
157
  }
119
158
 
@@ -3,11 +3,57 @@
3
3
  @use '../clear-button' as CB;
4
4
  @use '../../variables' as ARD;
5
5
 
6
+ :root {
7
+ --ard-password-input-height: var(--ard-form-field-height, 2.3125rem);
8
+ --ard-password-input-height-compact: var(--ard-form-field-height-compact, 1.6875rem);
9
+ --ard-password-input-gap: 0.625rem;
10
+ --ard-password-input-font-size: var(--ard-form-field-font-size, 1rem);
11
+ --ard-password-input-font-size-compact: var(--ard-form-field-font-size-compact, 0.875rem);
12
+ --ard-password-input-line-height: 1.25;
13
+ --ard-password-input-line-height-compact: 1;
14
+ --ard-password-input-font-weight: 400;
15
+ --ard-password-input-padding: var(--ard-form-field-padding, 0 0.375rem);
16
+ --ard-password-input-padding-compact: var(--ard-form-field-padding-compact, 0 0.375rem);
17
+ --ard-password-input-color: #{ARD.$text};
18
+ --ard-password-input-placeholder-color: #{ARD.$text};
19
+ --ard-password-input-placeholder-opacity: 60%;
20
+
21
+ --ard-password-input-min-width: 10rem;
22
+ --ard-password-input-max-width: 100%;
23
+ --ard-password-input-disabled-opacity: 50%;
24
+ --ard-password-input-reveal-button-margin: 0.125rem;
25
+ --ard-password-input-reveal-button-font-size: 0.8rem;
26
+ --ard-password-input-reveal-button-height: calc(100% - 0.25rem);
27
+ --ard-password-input-reveal-button-width: unset;
28
+ --ard-password-input-reveal-button-aspect-ratio: 1;
29
+ --ard-password-input-reveal-button-padding: 0;
30
+ --ard-password-input-reveal-button-color: #{ARD.$text};
31
+ --ard-password-input-reveal-button-border-radius: 9999px;
32
+ --ard-password-input-reveal-button-border: none;
33
+ --ard-password-input-reveal-button-background: transparent;
34
+ --ard-password-input-reveal-button-hover-background: rgba(0, 0, 0, 4%);
35
+ --ard-password-input-reveal-button-focus-background: rgba(0, 0, 0, 12%);
36
+ --ard-password-input-reveal-button-active-background: rgba(0, 0, 0, 20%);
37
+ }
38
+
6
39
  .ard-password-input {
7
- @include inputMixin.genericInput();
8
- padding: 0 0.375rem;
9
- min-width: 10rem;
10
- max-width: 100%;
40
+ @include inputMixin.genericInput(
41
+ var(--ard-password-input-height, var(--ard-form-field-height, 2.3125rem)),
42
+ var(--ard-password-input-height-compact, var(--ard-form-field-height-compact, 1.6875rem)),
43
+ var(--ard-password-input-gap, 0.625rem),
44
+ var(--ard-password-input-font-size, var(--ard-form-field-font-size, 1rem)),
45
+ var(--ard-password-input-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem)),
46
+ var(--ard-password-input-line-height, 1.25),
47
+ var(--ard-password-input-line-height-compact, 1),
48
+ var(--ard-password-input-font-weight, 400),
49
+ var(--ard-password-input-padding, var(--ard-form-field-padding, 0 0.375rem)),
50
+ var(--ard-password-input-padding-compact, var(--ard-form-field-padding-compact, 0 0.375rem)),
51
+ var(--ard-password-input-color, #{ARD.$text}),
52
+ var(--ard-password-input-placeholder-color, #{ARD.$text}),
53
+ var(--ard-password-input-placeholder-opacity, 60%)
54
+ );
55
+ min-width: var(--ard-password-input-min-width, 10rem);
56
+ max-width: var(--ard-password-input-max-width, 100%);
11
57
 
12
58
  &.ard-revealable {
13
59
  padding-right: 0;
@@ -17,27 +63,36 @@
17
63
  display: flex;
18
64
  align-items: center;
19
65
  justify-content: center;
20
- padding: 0;
21
- margin: 0.125rem;
22
- height: calc(100% - 0.25rem);
23
- aspect-ratio: 1;
24
- font-size: 0.8rem;
25
- border-radius: 9999px;
26
- border: none;
27
- background: transparent;
66
+ padding: var(--ard-password-input-reveal-button-padding, 0);
67
+ color: var(--ard-password-input-reveal-button-color, #{ARD.$text});
68
+ margin: var(--ard-password-input-reveal-button-margin, 0.125rem);
69
+ height: var(--ard-password-input-reveal-button-height, calc(100% - 0.25rem));
70
+ width: var(--ard-password-input-reveal-button-width, unset);
71
+ aspect-ratio: var(--ard-password-input-reveal-button-aspect-ratio, 1);
72
+ font-size: var(--ard-password-input-reveal-button-font-size, 0.8rem);
73
+ border-radius: var(--ard-password-input-reveal-button-border-radius, 9999px);
74
+ border: var(--ard-password-input-reveal-button-border, none);
75
+ background: var(--ard-password-input-reveal-button-background, transparent);
28
76
  outline: none;
29
77
  cursor: pointer;
30
78
 
31
79
  transition: background-color 0.2s ARD.$timing-fn;
32
80
 
33
81
  &:hover {
34
- background: rgba(0, 0, 0, 4%);
82
+ background: var(--ard-password-input-reveal-button-hover-background, rgba(0, 0, 0, 4%));
35
83
  }
36
84
  &:focus {
37
- background: rgba(0, 0, 0, 12%);
85
+ background: var(--ard-password-input-reveal-button-focus-background, rgba(0, 0, 0, 12%));
38
86
  }
39
87
  &:active {
40
- background: rgba(0, 0, 0, 20%);
88
+ background: var(--ard-password-input-reveal-button-active-background, rgba(0, 0, 0, 20%));
41
89
  }
42
90
  }
43
91
  }
92
+ //! disabled state
93
+ .ard-disabled {
94
+ .ard-password-input {
95
+ pointer-events: none;
96
+ opacity: var(--ard-password-input-disabled-opacity, 50%);
97
+ }
98
+ }
@@ -1,12 +1,46 @@
1
1
  @use './shared' as inputMixin;
2
2
  @use '../mixins' as defaultMixins;
3
3
  @use '../clear-button' as CB;
4
+ @use '../../variables' as ARD;
5
+
6
+ :root {
7
+ --ard-search-bar-height: var(--ard-form-field-height, 2.3125rem);
8
+ --ard-search-bar-height-compact: var(--ard-form-field-height-compact, 1.6875rem);
9
+ --ard-search-bar-gap: 0.625rem;
10
+ --ard-search-bar-font-size: var(--ard-form-field-font-size, 1rem);
11
+ --ard-search-bar-font-size-compact: var(--ard-form-field-font-size-compact, 0.875rem);
12
+ --ard-search-bar-line-height: 1.25;
13
+ --ard-search-bar-line-height-compact: 1;
14
+ --ard-search-bar-font-weight: 400;
15
+ --ard-search-bar-padding: var(--ard-form-field-padding, 0 0.375rem);
16
+ --ard-search-bar-padding-compact: var(--ard-form-field-padding-compact, 0 0.375rem);
17
+ --ard-search-bar-color: #{ARD.$text};
18
+ --ard-search-bar-placeholder-color: #{ARD.$text};
19
+ --ard-search-bar-placeholder-opacity: 60%;
20
+
21
+ --ard-search-bar-min-width: 10rem;
22
+ --ard-search-bar-max-width: 100%;
23
+ --ard-search-bar-disabled-opacity: 50%;
24
+ }
4
25
 
5
26
  .ard-search-bar {
6
- @include inputMixin.genericInput();
7
- padding: 0 0.375rem;
8
- min-width: 10rem;
9
- max-width: 100%;
27
+ @include inputMixin.genericInput(
28
+ var(--ard-search-bar-height, var(--ard-form-field-height, 2.3125rem)),
29
+ var(--ard-search-bar-height-compact, var(--ard-form-field-height-compact, 1.6875rem)),
30
+ var(--ard-search-bar-gap, 0.625rem),
31
+ var(--ard-search-bar-font-size, var(--ard-form-field-font-size, 1rem)),
32
+ var(--ard-search-bar-font-size-compact, var(--ard-form-field-font-size-compact, 0.875rem)),
33
+ var(--ard-search-bar-line-height, 1.25),
34
+ var(--ard-search-bar-line-height-compact, 1),
35
+ var(--ard-search-bar-font-weight, 400),
36
+ var(--ard-search-bar-padding, var(--ard-form-field-padding, 0 0.375rem)),
37
+ var(--ard-search-bar-padding-compact, var(--ard-form-field-padding-compact, 0 0.375rem)),
38
+ var(--ard-search-bar-color, #{ARD.$text}),
39
+ var(--ard-search-bar-placeholder-color, #{ARD.$text}),
40
+ var(--ard-search-bar-placeholder-opacity, 60%)
41
+ );
42
+ min-width: var(--ard-search-bar-min-width, 10rem);
43
+ max-width: var(--ard-search-bar-max-width, 100%);
10
44
 
11
45
  @include CB.clearButton();
12
46
  }
@@ -14,6 +48,6 @@
14
48
  .ard-disabled {
15
49
  .ard-search-bar {
16
50
  pointer-events: none;
17
- opacity: 50%;
51
+ opacity: var(--ard-search-bar-disabled-opacity, 50%);
18
52
  }
19
53
  }
@@ -1,7 +1,7 @@
1
1
  @use '../variables' as ARD;
2
2
 
3
3
  .ard-kbd-shortcut {
4
- font-family: monospace;
4
+ font-family: var(--ard-font-family-mono);
5
5
  color: ARD.$text2;
6
6
 
7
7
  > span {
@@ -2,7 +2,7 @@
2
2
 
3
3
  .ard-kbd {
4
4
  border-radius: 0.2em;
5
- font-family: monospace;
5
+ font-family: var(--ard-font-family-mono);
6
6
  font-size: 0.9em;
7
7
  margin: 0 0.125em;
8
8
  color: ARD.$text2;
@@ -15,8 +15,9 @@
15
15
  .ard-modal-panel {
16
16
  padding: 1.25rem;
17
17
  padding-top: 1rem;
18
- background: ARD.$bg;
19
18
  max-width: calc(100vw - 4rem);
19
+ max-height: calc(100vh - 4rem);
20
+ background: ARD.$bg;
20
21
  position: relative;
21
22
  display: flex;
22
23
  flex-direction: column;
@@ -19,14 +19,16 @@ ard-radio {
19
19
  outline: none;
20
20
  font-size: 1em;
21
21
  display: flex;
22
- gap: 0.375em;
22
+ align-items: center;
23
+ gap: 0.75rem;
23
24
  padding: 0;
24
25
  width: 100%;
25
26
 
26
27
  > .ard-radio-circles {
27
28
  position: relative;
28
29
  width: 1.25em;
29
- height: 1.25em;
30
+ min-width: 1.25em;
31
+ aspect-ratio: 1;
30
32
 
31
33
  > .ard-radio-outer-circle {
32
34
  position: absolute;
@@ -34,7 +36,7 @@ ard-radio {
34
36
  right: 0;
35
37
  top: 0;
36
38
  bottom: 0;
37
- border: 2px solid ARD.$detail;
39
+ border: 0.125em solid ARD.$detail;
38
40
  border-radius: 9999px;
39
41
  transition: border-color 0.2s ARD.$timing-fn;
40
42
  }
@@ -2,18 +2,38 @@
2
2
  @use './coloring' as coloringMixins;
3
3
  @use '../variables' as ARD;
4
4
 
5
+ :root {
6
+ --ard-segment-margin: 0;
7
+ --ard-segment-padding: 0.15rem;
8
+ --ard-segment-option-gap: var(--ard-segment-padding, 0.15rem);
9
+ --ard-segment-font-family: var(--ard-font-family);
10
+ --ard-segment-font-size: 0.875rem;
11
+ --ard-segment-font-size-compact: 0.75rem;
12
+ --ard-segment-rounded-border-radius: 0.5rem;
13
+ --ard-segment-row-height: 2.42em;
14
+ --ard-segment-row-height-compact: 1.85em;
15
+ --ard-segment-option-padding: 0 1em;
16
+ --ard-segment-option-padding-compact: 0 0.5em;
17
+ --ard-segment-option-disabled-opacity: 50%;
18
+ --ard-segment-option-highlighted-bg-opacity: 4%;
19
+ --ard-segment-option-highlighted-filled-bg-opacity: 16%;
20
+ --ard-segment-option-highlighted-keyboard-bg-opacity: 28%;
21
+ --ard-segment-option-active-bg-opacity: 12%;
22
+ --ard-segment-option-active-keyboard-bg-opacity: 34%;
23
+ --ard-segment-option-selected-bg-opacity: 16%;
24
+ --ard-segment-border-color: #{ARD.$border-light};
25
+ }
26
+
5
27
  .ard-segment-container {
6
28
  @include coloringMixins.typeColors();
7
- --ard-_segment-padding: 0.15rem;
8
- padding: var(--ard-_segment-padding);
9
- font-family: 'Roboto', sans-serif;
10
- margin: 2px;
29
+ padding: var(--ard-segment-padding, 0.15rem);
30
+ font-family: var(--ard-segment-font-family, var(--ard-font-family));
31
+ margin: var(--ard-segment-margin, 0);
11
32
  border: 1px solid transparent;
12
- font-weight: 500;
13
33
  width: max-content;
14
34
  height: max-content;
15
- gap: var(--ard-_segment-padding);
16
- overflow: hidden; //hide click indicator overflowing rounded corners on touchscreens
35
+ gap: var(--ard-segment-option-gap, var(--ard-segment-padding, 0.15rem));
36
+ overflow: hidden; // hide click indicator overflowing rounded corners on touchscreens
17
37
 
18
38
  @include defaultMixins.formAppearances();
19
39
  @include defaultMixins.formVariants();
@@ -26,25 +46,21 @@
26
46
 
27
47
  //! row & option styling
28
48
  .ard-segment-row {
29
- gap: var(--ard-_segment-padding);
30
- --ard-_font-size: 0.85em;
31
- height: calc(2.42em + 1px);
32
- font-size: var(--ard-_font-size);
49
+ gap: var(--ard-segment-option-gap, var(--ard-segment-padding, 0.15rem));
50
+ height: calc(var(--ard-segment-row-height, 2.42em) + 1px);
51
+ font-size: var(--ard-segment-font-size, 0.875rem);
33
52
 
34
53
  .ard-segment-option {
35
54
  margin: 0;
36
- padding: 0 1em;
55
+ padding: var(--ard-segment-option-padding, 0 1em);
37
56
  height: 100%;
38
57
  font-size: 1em;
39
- min-width: 2.42em;
58
+ min-width: var(--ard-segment-row-height, 2.42em);
40
59
  border: 1px solid transparent;
41
60
  background: transparent;
42
61
  position: relative;
43
62
  cursor: pointer;
44
- transition:
45
- color 0.1s ARD.$timing-fn,
46
- opacity 0.1s ARD.$timing-fn,
47
- border-color 0.1s ARD.$timing-fn,
63
+ transition: color 0.1s ARD.$timing-fn, opacity 0.1s ARD.$timing-fn, border-color 0.1s ARD.$timing-fn,
48
64
  background-color 0.1s ARD.$timing-fn;
49
65
  outline: none;
50
66
  display: flex;
@@ -56,7 +72,7 @@
56
72
  }
57
73
 
58
74
  &.ard-option-disabled {
59
- opacity: 50%;
75
+ opacity: var(--ard-segment-option-disabled-opacity, 50%);
60
76
  pointer-events: none;
61
77
  }
62
78
 
@@ -76,17 +92,17 @@
76
92
  .ard-segment-option {
77
93
  &.ard-option-highlighted {
78
94
  .ard-focus-overlay {
79
- opacity: 4%;
95
+ opacity: var(--ard-segment-option-highlighted-bg-opacity, 4%);
80
96
  }
81
97
  }
82
98
  &:active {
83
99
  .ard-focus-overlay {
84
- opacity: 12%;
100
+ opacity: var(--ard-segment-option-active-bg-opacity, 12%);
85
101
  }
86
102
  }
87
103
  &.ard-option-selected {
88
104
  .ard-focus-overlay {
89
- opacity: 16%;
105
+ opacity: var(--ard-segment-option-selected-bg-opacity, 16%);
90
106
  }
91
107
  }
92
108
  }
@@ -94,12 +110,12 @@
94
110
  .ard-segment-option {
95
111
  &.ard-option-highlighted {
96
112
  .ard-focus-overlay {
97
- opacity: 28%;
113
+ opacity: var(--ard-segment-option-highlighted-keyboard-bg-opacity, 28%);
98
114
  }
99
115
  }
100
116
  &:active {
101
117
  .ard-focus-overlay {
102
- opacity: 34%;
118
+ opacity: var(--ard-segment-option-active-keyboard-bg-opacity, 34%);
103
119
  }
104
120
  }
105
121
  }
@@ -127,7 +143,7 @@
127
143
  padding: 0;
128
144
 
129
145
  .ard-segment-option {
130
- border: 1px solid ARD.$border-light;
146
+ border: 1px solid var(--ard-segment-border-color, ARD.$border-light);
131
147
 
132
148
  &.ard-option-selected {
133
149
  border-color: var(--ard-cmpcl--content);
@@ -160,43 +176,43 @@
160
176
  &:first-child {
161
177
  .ard-segment-option {
162
178
  &:first-child {
163
- border-top-left-radius: var(--ard-variant-border-radius) !important;
179
+ border-top-left-radius: var(--ard-_variant-border-radius) !important;
164
180
  }
165
181
  &:last-child {
166
- border-top-right-radius: var(--ard-variant-border-radius) !important;
182
+ border-top-right-radius: var(--ard-_variant-border-radius) !important;
167
183
  }
168
184
  &:first-child:last-child {
169
- border-top-right-radius: var(--ard-variant-border-radius) !important;
170
- border-top-left-radius: var(--ard-variant-border-radius) !important;
185
+ border-top-right-radius: var(--ard-_variant-border-radius) !important;
186
+ border-top-left-radius: var(--ard-_variant-border-radius) !important;
171
187
  }
172
188
  }
173
189
  }
174
190
  &:last-child {
175
191
  .ard-segment-option {
176
192
  &:first-child {
177
- border-bottom-left-radius: var(--ard-variant-border-radius) !important;
193
+ border-bottom-left-radius: var(--ard-_variant-border-radius) !important;
178
194
  }
179
195
  &:last-child {
180
- border-bottom-right-radius: var(--ard-variant-border-radius) !important;
196
+ border-bottom-right-radius: var(--ard-_variant-border-radius) !important;
181
197
  }
182
198
  &:first-child:last-child {
183
- border-bottom-right-radius: var(--ard-variant-border-radius) !important;
184
- border-bottom-left-radius: var(--ard-variant-border-radius) !important;
199
+ border-bottom-right-radius: var(--ard-_variant-border-radius) !important;
200
+ border-bottom-left-radius: var(--ard-_variant-border-radius) !important;
185
201
  }
186
202
  }
187
203
  }
188
204
  &:first-child:last-child {
189
205
  .ard-segment-option {
190
206
  &:first-child {
191
- border-top-left-radius: var(--ard-variant-border-radius) !important;
192
- border-bottom-left-radius: var(--ard-variant-border-radius) !important;
207
+ border-top-left-radius: var(--ard-_variant-border-radius) !important;
208
+ border-bottom-left-radius: var(--ard-_variant-border-radius) !important;
193
209
  }
194
210
  &:last-child {
195
- border-top-right-radius: var(--ard-variant-border-radius) !important;
196
- border-bottom-right-radius: var(--ard-variant-border-radius) !important;
211
+ border-top-right-radius: var(--ard-_variant-border-radius) !important;
212
+ border-bottom-right-radius: var(--ard-_variant-border-radius) !important;
197
213
  }
198
214
  &:first-child:last-child {
199
- border-radius: var(--ard-variant-border-radius) !important;
215
+ border-radius: var(--ard-_variant-border-radius) !important;
200
216
  }
201
217
  }
202
218
  }
@@ -233,23 +249,10 @@
233
249
  background: var(--ard-cmpcl--bg);
234
250
  opacity: 15%;
235
251
  }
236
-
237
- .ard-segment-option {
238
- &.ard-option-highlighted {
239
- .ard-focus-overlay {
240
- opacity: 8%;
241
- }
242
- }
243
- &.ard-option-selected {
244
- .ard-focus-overlay {
245
- opacity: 20%;
246
- }
247
- }
248
- }
249
252
  }
250
253
  &.ard-appearance-filled-strong {
251
254
  background: var(--ard-cmpcl--bg);
252
- border-radius: var(--ard-variant-border-radius);
255
+ border-radius: var(--ard-_variant-border-radius);
253
256
 
254
257
  .ard-segment-row {
255
258
  .ard-segment-option {
@@ -260,7 +263,7 @@
260
263
  }
261
264
  &.ard-option-highlighted {
262
265
  .ard-focus-overlay {
263
- opacity: 16%;
266
+ opacity: var(--ard-segment-option-highlighted-filled-bg-opacity, 16%);
264
267
  }
265
268
  }
266
269
  &.ard-option-selected {
@@ -276,48 +279,53 @@
276
279
  }
277
280
 
278
281
  //! variants
282
+ &.ard-variant-rounded,
283
+ &.ard-variant-rounded-connected,
279
284
  &.ard-variant-pill {
280
- border-radius: 16px;
285
+ --ard-_variant-border-radius: var(--ard-segment-rounded-border-radius, 0.5rem);
286
+ border-radius: var(--ard-_variant-border-radius);
281
287
 
282
288
  .ard-segment-row {
283
289
  .ard-segment-option {
284
- border-radius: var(--ard-variant-border-radius);
290
+ border-radius: max(
291
+ 1px,
292
+ calc(var(--ard-_variant-border-radius) - var(--ard-segment-option-gap, var(--ard-segment-padding, 0.15rem)))
293
+ );
285
294
  }
286
295
  }
287
296
  }
288
- &.ard-variant-rounded,
289
- &.ard-variant-rounded-connected {
290
- --ard-variant-border-radius: 8px;
291
- border-radius: var(--ard-variant-border-radius);
297
+ &.ard-variant-pill {
298
+ // TODO fix pill styling
299
+ border-radius: calc(var(--ard-segment-rounded-border-radius, 0.5rem) * 2);
292
300
 
293
301
  .ard-segment-row {
294
302
  .ard-segment-option {
295
- border-radius: max(1px, calc(var(--ard-variant-border-radius) - var(--ard-_segment-padding)));
303
+ border-radius: var(--ard-_variant-border-radius);
296
304
  }
297
305
  }
298
306
  }
299
307
  &.ard-variant-sharp,
300
308
  &.ard-variant-sharp-connected {
301
- border-radius: var(--ard-variant-border-radius);
309
+ border-radius: var(--ard-_variant-border-radius);
302
310
 
303
311
  .ard-segment-row {
304
312
  .ard-segment-option {
305
- border-radius: calc(var(--ard-variant-border-radius));
313
+ border-radius: calc(var(--ard-_variant-border-radius));
306
314
  }
307
315
  }
308
316
  }
309
317
  &.ard-variant-pill-connected.ard-singlerow {
310
- --ard-variant-border-radius: 9999px;
318
+ --ard-_variant-border-radius: 9999px;
311
319
  }
312
320
 
313
321
  //! compact
314
322
  &.ard-compact {
315
323
  .ard-segment-row {
316
- --ard-_font-size: 0.85em;
317
- height: calc(1.85em + 1px);
324
+ height: calc(var(--ard-segment-row-height-compact, 1.85em) + 1px);
325
+ font-size: var(--ard-segment-font-size-compact, 0.75rem);
318
326
 
319
327
  .ard-segment-option {
320
- padding: 0 0.5em;
328
+ padding: var(--ard-segment-option-padding-compact, 1.85em);
321
329
  min-width: 1.85em;
322
330
  }
323
331
  }
@@ -335,7 +343,7 @@
335
343
  //! disabled styling
336
344
  &.ard-disabled {
337
345
  pointer-events: none;
338
- opacity: 50%;
346
+ opacity: var(--ard-segment-option-disabled-opacity, 50%);
339
347
 
340
348
  .ard-focus-overlay {
341
349
  opacity: 10%;
@@ -345,7 +353,7 @@
345
353
  &.ard-color-none {
346
354
  .ard-button-icon,
347
355
  .ard-button-content {
348
- opacity: 60%;
356
+ opacity: calc(var(--ard-segment-option-disabled-opacity, 50%) * 1.2);
349
357
  }
350
358
  .ard-focus-overlay {
351
359
  background: var(--ard-cmpcl--overlay);