@ardium-ui/ui 5.0.0-alpha.8 → 5.0.0-alpha.81

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