@ardium-ui/ui 5.0.0-alpha.6 → 5.0.0-alpha.61

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