rsuite 6.0.0 → 6.1.0

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 (299) hide show
  1. package/Accordion/styles/index.scss +3 -0
  2. package/Animation/styles/_animation.scss +95 -0
  3. package/Animation/styles/_bounce.scss +36 -0
  4. package/Animation/styles/_collapse.scss +23 -0
  5. package/Animation/styles/_fade.scss +10 -0
  6. package/Animation/styles/_mixin.scss +15 -0
  7. package/Animation/styles/_slide.scss +34 -0
  8. package/Animation/styles/_variables.scss +4 -0
  9. package/Animation/styles/index.scss +8 -0
  10. package/AutoComplete/styles/index.scss +43 -0
  11. package/Avatar/styles/index.scss +48 -0
  12. package/AvatarGroup/styles/index.scss +27 -0
  13. package/Badge/styles/_variables.scss +48 -0
  14. package/Badge/styles/index.scss +111 -0
  15. package/Box/styles/index.scss +1 -0
  16. package/Breadcrumb/styles/index.scss +50 -0
  17. package/Button/styles/_mixin.scss +83 -0
  18. package/Button/styles/_variables.scss +38 -0
  19. package/Button/styles/index.scss +374 -0
  20. package/ButtonGroup/styles/index.scss +96 -0
  21. package/ButtonToolbar/styles/index.scss +9 -0
  22. package/CHANGELOG.md +31 -0
  23. package/Calendar/styles/_variables.scss +16 -0
  24. package/Calendar/styles/index.scss +673 -0
  25. package/Card/styles/index.scss +63 -0
  26. package/CardGroup/styles/index.scss +10 -0
  27. package/Carousel/styles/index.scss +204 -0
  28. package/CascadeTree/styles/_search.scss +39 -0
  29. package/CascadeTree/styles/index.scss +83 -0
  30. package/Cascader/styles/index.scss +5 -0
  31. package/Center/styles/index.scss +11 -0
  32. package/CheckPicker/styles/index.scss +23 -0
  33. package/CheckTree/styles/_variables.scss +5 -0
  34. package/CheckTree/styles/index.scss +121 -0
  35. package/CheckTreePicker/styles/index.scss +20 -0
  36. package/Checkbox/styles/_mixin.scss +5 -0
  37. package/Checkbox/styles/_variables.scss +4 -0
  38. package/Checkbox/styles/index.scss +158 -0
  39. package/CheckboxGroup/styles/index.scss +14 -0
  40. package/Col/styles/index.scss +2 -0
  41. package/Container/stories/styles.scss +23 -0
  42. package/Container/styles/index.scss +16 -0
  43. package/Content/styles/index.scss +6 -0
  44. package/DateInput/styles/index.scss +1 -0
  45. package/DatePicker/styles/_mixin.scss +10 -0
  46. package/DatePicker/styles/index.scss +171 -0
  47. package/DateRangeInput/styles/index.scss +1 -0
  48. package/DateRangePicker/styles/index.scss +151 -0
  49. package/Divider/styles/index.scss +85 -0
  50. package/Drawer/styles/_mixin.scss +23 -0
  51. package/Drawer/styles/_variables.scss +18 -0
  52. package/Drawer/styles/index.scss +244 -0
  53. package/Dropdown/styles/_mixin.scss +4 -0
  54. package/Dropdown/styles/_variables.scss +12 -0
  55. package/Dropdown/styles/index.scss +334 -0
  56. package/FlexboxGrid/styles/index.scss +82 -0
  57. package/Footer/styles/index.scss +5 -0
  58. package/Form/styles/index.scss +3 -0
  59. package/FormControl/styles/_variables.scss +4 -0
  60. package/FormControl/styles/index.scss +82 -0
  61. package/FormControlLabel/styles/index.scss +7 -0
  62. package/FormErrorMessage/styles/_animation.scss +43 -0
  63. package/FormErrorMessage/styles/_variables.scss +7 -0
  64. package/FormErrorMessage/styles/index.scss +146 -0
  65. package/FormGroup/styles/index.scss +75 -0
  66. package/FormHelpText/styles/index.scss +21 -0
  67. package/FormStack/styles/index.scss +15 -0
  68. package/Grid/styles/_columns.scss +23 -0
  69. package/Grid/styles/_mixin.scss +110 -0
  70. package/Grid/styles/_row.scss +44 -0
  71. package/Grid/styles/_variables.scss +6 -0
  72. package/Grid/styles/index.scss +115 -0
  73. package/Header/styles/index.scss +5 -0
  74. package/Heading/styles/_variables.scss +19 -0
  75. package/Heading/styles/index.scss +42 -0
  76. package/HeadingGroup/styles/index.scss +5 -0
  77. package/Highlight/styles/index.scss +9 -0
  78. package/IconButton/styles/index.scss +90 -0
  79. package/Image/styles/index.scss +36 -0
  80. package/InlineEdit/styles/index.scss +51 -0
  81. package/Input/styles/_mixin.scss +39 -0
  82. package/Input/styles/_variables.scss +27 -0
  83. package/Input/styles/index.scss +23 -0
  84. package/InputGroup/styles/index.scss +264 -0
  85. package/InputNumber/styles/index.scss +1 -0
  86. package/InputPicker/styles/_mixin.scss +7 -0
  87. package/InputPicker/styles/index.scss +64 -0
  88. package/Kbd/styles/_mixin.scss +24 -0
  89. package/Kbd/styles/_variables.scss +13 -0
  90. package/Kbd/styles/index.scss +21 -0
  91. package/Link/styles/index.scss +41 -0
  92. package/List/styles/index.scss +111 -0
  93. package/Loader/styles/_mixin.scss +37 -0
  94. package/Loader/styles/_variables.scss +19 -0
  95. package/Loader/styles/index.scss +120 -0
  96. package/Menu/styles/index.scss +109 -0
  97. package/Message/styles/index.scss +189 -0
  98. package/Modal/styles/_animation.scss +15 -0
  99. package/Modal/styles/_variables.scss +16 -0
  100. package/Modal/styles/index.scss +186 -0
  101. package/MultiCascadeTree/styles/index.scss +35 -0
  102. package/MultiCascader/styles/index.scss +3 -0
  103. package/Nav/styles/index.scss +383 -0
  104. package/Navbar/styles/index.scss +253 -0
  105. package/Notification/styles/index.scss +116 -0
  106. package/NumberInput/styles/_mixin.scss +11 -0
  107. package/NumberInput/styles/index.scss +78 -0
  108. package/Pagination/styles/_pagination-group.scss +52 -0
  109. package/Pagination/styles/index.scss +77 -0
  110. package/Panel/styles/index.scss +122 -0
  111. package/PanelGroup/styles/index.scss +34 -0
  112. package/PasswordInput/styles/index.scss +3 -0
  113. package/PasswordStrengthMeter/styles/index.scss +41 -0
  114. package/PinInput/styles/index.scss +93 -0
  115. package/Placeholder/styles/_mixin.scss +9 -0
  116. package/Placeholder/styles/index.scss +155 -0
  117. package/Popover/styles/index.scss +224 -0
  118. package/Popover/styles/mixins.scss +54 -0
  119. package/Progress/styles/_animation.scss +69 -0
  120. package/Progress/styles/_mixins.scss +6 -0
  121. package/Progress/styles/_progress-line.scss +343 -0
  122. package/Progress/styles/index.scss +3 -0
  123. package/ProgressCircle/styles/index.scss +2 -0
  124. package/ProgressCircle/styles/progress-circle.scss +49 -0
  125. package/Radio/styles/_mixin.scss +5 -0
  126. package/Radio/styles/_variables.scss +5 -0
  127. package/Radio/styles/index.scss +147 -0
  128. package/RadioGroup/styles/_variables.scss +10 -0
  129. package/RadioGroup/styles/index.scss +83 -0
  130. package/RadioTile/styles/index.scss +80 -0
  131. package/RadioTileGroup/styles/index.scss +1 -0
  132. package/RangeSlider/styles/index.scss +4 -0
  133. package/Rate/styles/index.scss +141 -0
  134. package/Row/styles/index.scss +2 -0
  135. package/SegmentedControl/styles/_mixin.scss +7 -0
  136. package/SegmentedControl/styles/_variables.scss +43 -0
  137. package/SegmentedControl/styles/index.scss +147 -0
  138. package/SelectPicker/styles/index.scss +44 -0
  139. package/Sidebar/styles/index.scss +17 -0
  140. package/Sidenav/styles/index.scss +635 -0
  141. package/Sidenav/styles/mixin.scss +23 -0
  142. package/Slider/styles/index.scss +298 -0
  143. package/Stack/styles/_variables.scss +11 -0
  144. package/Stack/styles/index.scss +79 -0
  145. package/Stat/styles/index.scss +126 -0
  146. package/StatGroup/styles/index.scss +10 -0
  147. package/Steps/styles/index.scss +222 -0
  148. package/Table/styles/index.scss +473 -0
  149. package/Table/styles/mixin.scss +8 -0
  150. package/Tabs/styles/index.scss +24 -0
  151. package/Tag/styles/_variables.scss +13 -0
  152. package/Tag/styles/index.scss +62 -0
  153. package/TagGroup/styles/index.scss +14 -0
  154. package/TagInput/styles/index.scss +5 -0
  155. package/TagPicker/styles/index.scss +141 -0
  156. package/Text/styles/index.scss +142 -0
  157. package/Text/styles/variables.scss +9 -0
  158. package/Textarea/styles/index.scss +9 -0
  159. package/TimePicker/styles/index.scss +1 -0
  160. package/TimeRangePicker/styles/index.scss +1 -0
  161. package/Timeline/stories/styles.scss +29 -0
  162. package/Timeline/styles/_mixin.scss +13 -0
  163. package/Timeline/styles/index.scss +187 -0
  164. package/Toggle/styles/index.scss +284 -0
  165. package/Tooltip/styles/index.scss +160 -0
  166. package/Tooltip/styles/mixins.scss +56 -0
  167. package/Tree/styles/_indent-line.scss +8 -0
  168. package/Tree/styles/_toggle.scss +32 -0
  169. package/Tree/styles/_variables.scss +8 -0
  170. package/Tree/styles/index.scss +184 -0
  171. package/TreePicker/styles/index.scss +16 -0
  172. package/Uploader/styles/_mixin.scss +11 -0
  173. package/Uploader/styles/index.scss +491 -0
  174. package/VisuallyHidden/styles/index.scss +11 -0
  175. package/cjs/Breadcrumb/BreadcrumbItem.js +12 -7
  176. package/cjs/Cascader/Cascader.js +1 -1
  177. package/cjs/CheckPicker/CheckPicker.js +1 -1
  178. package/cjs/CheckTree/CheckTree.js +3 -0
  179. package/cjs/CheckTree/CheckTreeView.js +7 -3
  180. package/cjs/CheckTree/hooks/useTreeCheckState.d.ts +1 -0
  181. package/cjs/CheckTree/hooks/useTreeCheckState.js +54 -3
  182. package/cjs/CheckTree/utils.d.ts +9 -2
  183. package/cjs/CheckTree/utils.js +70 -11
  184. package/cjs/CheckTreePicker/CheckTreePicker.js +2 -1
  185. package/cjs/Checkbox/Checkbox.js +2 -1
  186. package/cjs/Checkbox/hooks/useIndeterminateCheckbox.d.ts +19 -0
  187. package/cjs/Checkbox/hooks/useIndeterminateCheckbox.js +32 -0
  188. package/cjs/DateInput/DateInput.js +24 -0
  189. package/cjs/DateInput/hooks/useKeyboardInputEvent.d.ts +2 -1
  190. package/cjs/DateInput/hooks/useKeyboardInputEvent.js +14 -0
  191. package/cjs/DatePicker/DatePicker.js +1 -1
  192. package/cjs/DateRangeInput/DateRangeInput.js +24 -0
  193. package/cjs/DateRangePicker/DateRangePicker.js +1 -1
  194. package/cjs/Form/Form.js +5 -1
  195. package/cjs/InputPicker/InputPicker.js +1 -1
  196. package/cjs/MultiCascader/MultiCascader.js +1 -1
  197. package/cjs/Panel/PanelHeader.d.ts +1 -1
  198. package/cjs/Panel/PanelHeader.js +4 -5
  199. package/cjs/Rate/Rate.d.ts +8 -0
  200. package/cjs/Rate/Rate.js +3 -1
  201. package/cjs/SelectPicker/SelectPicker.js +1 -1
  202. package/cjs/Tree/hooks/useFlattenTree.d.ts +4 -0
  203. package/cjs/Tree/hooks/useFlattenTree.js +22 -1
  204. package/cjs/Tree/hooks/useFocusTree.js +19 -1
  205. package/cjs/Tree/hooks/useVirtualizedTreeData.d.ts +1 -0
  206. package/cjs/Tree/hooks/useVirtualizedTreeData.js +5 -2
  207. package/cjs/Tree/utils/focusableTree.d.ts +8 -0
  208. package/cjs/Tree/utils/focusableTree.js +40 -2
  209. package/cjs/Tree/utils/index.d.ts +1 -1
  210. package/cjs/Tree/utils/index.js +3 -1
  211. package/cjs/TreePicker/TreePicker.js +1 -1
  212. package/cjs/internals/Picker/PickerToggleTrigger.d.ts +2 -0
  213. package/cjs/internals/Picker/PickerToggleTrigger.js +3 -1
  214. package/cjs/internals/Picker/utils.d.ts +2 -0
  215. package/cjs/internals/Picker/utils.js +13 -1
  216. package/cjs/internals/StyledBox/StyledBox.d.ts +1 -1
  217. package/cjs/internals/StyledBox/StyledBox.js +2 -2
  218. package/dist/rsuite.js +40 -29
  219. package/dist/rsuite.js.map +1 -1
  220. package/dist/rsuite.min.js +1 -1
  221. package/dist/rsuite.min.js.map +1 -1
  222. package/esm/Breadcrumb/BreadcrumbItem.js +10 -5
  223. package/esm/Cascader/Cascader.js +1 -1
  224. package/esm/CheckPicker/CheckPicker.js +1 -1
  225. package/esm/CheckTree/CheckTree.js +3 -0
  226. package/esm/CheckTree/CheckTreeView.js +7 -3
  227. package/esm/CheckTree/hooks/useTreeCheckState.d.ts +1 -0
  228. package/esm/CheckTree/hooks/useTreeCheckState.js +55 -4
  229. package/esm/CheckTree/utils.d.ts +9 -2
  230. package/esm/CheckTree/utils.js +71 -12
  231. package/esm/CheckTreePicker/CheckTreePicker.js +2 -1
  232. package/esm/Checkbox/Checkbox.js +3 -2
  233. package/esm/Checkbox/hooks/useIndeterminateCheckbox.d.ts +19 -0
  234. package/esm/Checkbox/hooks/useIndeterminateCheckbox.js +29 -0
  235. package/esm/DateInput/DateInput.js +24 -0
  236. package/esm/DateInput/hooks/useKeyboardInputEvent.d.ts +2 -1
  237. package/esm/DateInput/hooks/useKeyboardInputEvent.js +14 -0
  238. package/esm/DatePicker/DatePicker.js +1 -1
  239. package/esm/DateRangeInput/DateRangeInput.js +24 -0
  240. package/esm/DateRangePicker/DateRangePicker.js +1 -1
  241. package/esm/Form/Form.js +5 -1
  242. package/esm/InputPicker/InputPicker.js +1 -1
  243. package/esm/MultiCascader/MultiCascader.js +1 -1
  244. package/esm/Panel/PanelHeader.d.ts +1 -1
  245. package/esm/Panel/PanelHeader.js +4 -5
  246. package/esm/Rate/Rate.d.ts +8 -0
  247. package/esm/Rate/Rate.js +3 -1
  248. package/esm/SelectPicker/SelectPicker.js +1 -1
  249. package/esm/Tree/hooks/useFlattenTree.d.ts +4 -0
  250. package/esm/Tree/hooks/useFlattenTree.js +22 -1
  251. package/esm/Tree/hooks/useFocusTree.js +20 -2
  252. package/esm/Tree/hooks/useVirtualizedTreeData.d.ts +1 -0
  253. package/esm/Tree/hooks/useVirtualizedTreeData.js +5 -2
  254. package/esm/Tree/utils/focusableTree.d.ts +8 -0
  255. package/esm/Tree/utils/focusableTree.js +36 -0
  256. package/esm/Tree/utils/index.d.ts +1 -1
  257. package/esm/Tree/utils/index.js +1 -1
  258. package/esm/TreePicker/TreePicker.js +1 -1
  259. package/esm/internals/Picker/PickerToggleTrigger.d.ts +2 -0
  260. package/esm/internals/Picker/PickerToggleTrigger.js +3 -1
  261. package/esm/internals/Picker/utils.d.ts +2 -0
  262. package/esm/internals/Picker/utils.js +13 -1
  263. package/esm/internals/StyledBox/StyledBox.d.ts +1 -1
  264. package/esm/internals/StyledBox/StyledBox.js +2 -2
  265. package/internals/Box/styles/index.scss +31 -0
  266. package/internals/Burger/styles/index.scss +72 -0
  267. package/internals/CloseButton/styles/index.scss +14 -0
  268. package/internals/Picker/styles/_mixin.scss +219 -0
  269. package/internals/Picker/styles/_variables.scss +9 -0
  270. package/internals/Picker/styles/index.scss +476 -0
  271. package/internals/Ripple/styles/_mixins.scss +10 -0
  272. package/internals/Ripple/styles/index.scss +40 -0
  273. package/internals/ScrollView/styles/index.scss +77 -0
  274. package/internals/SearchBox/styles/index.scss +7 -0
  275. package/package.json +4 -4
  276. package/styles/_base.scss +37 -0
  277. package/styles/_css-reset.scss +345 -0
  278. package/styles/_themes.scss +132 -0
  279. package/styles/_variables.scss +48 -0
  280. package/styles/color-modes/_dark.scss +458 -0
  281. package/styles/color-modes/_high-contrast.scss +469 -0
  282. package/styles/color-modes/_light.scss +475 -0
  283. package/styles/colors/_colors-base.scss +39 -0
  284. package/styles/colors/_dark.scss +114 -0
  285. package/styles/colors/_high-contrast.scss +114 -0
  286. package/styles/colors/_light.scss +115 -0
  287. package/styles/colors/_palette.scss +413 -0
  288. package/styles/components.scss +114 -0
  289. package/styles/index.scss +2 -0
  290. package/styles/mixins/_color-modes.scss +20 -0
  291. package/styles/mixins/_combobox.scss +6 -0
  292. package/styles/mixins/_hacks.scss +33 -0
  293. package/styles/mixins/_input.scss +30 -0
  294. package/styles/mixins/_listbox.scss +70 -0
  295. package/styles/mixins/_menu.scss +12 -0
  296. package/styles/mixins/_utilities.scss +130 -0
  297. package/toaster/styles/animation.scss +54 -0
  298. package/toaster/styles/index.scss +109 -0
  299. package/useToaster/styles/index.scss +1 -0
@@ -0,0 +1,219 @@
1
+ @use 'sass:map';
2
+ @use '../../../styles/mixins/color-modes';
3
+ @use '../../../Dropdown/styles/mixin' as dropdown;
4
+
5
+ // Picker Menu items common styles
6
+ @mixin picker-listbox-reset {
7
+ overflow-y: auto;
8
+
9
+ ul {
10
+ list-style: none;
11
+ margin: 0;
12
+ padding: 0;
13
+ }
14
+ }
15
+
16
+ // Picker Menu group common styles
17
+ @mixin picker-menu-group-common($prefix) {
18
+ // Set border & padding to menu group if it isn't the first.
19
+ .rs-#{$prefix}-menu-group:not(:first-child) {
20
+ margin-top: var(--rs-picker-group-select-menu-gap);
21
+ border-top: 1px solid var(--rs-divider-border);
22
+ padding-top: var(--rs-picker-group-select-menu-gap);
23
+ }
24
+ }
25
+
26
+ // Group title common styles
27
+ @mixin picker-menu-group-title($prefix) {
28
+ .rs-#{$prefix}-menu-group-title {
29
+ padding-block: var(--rs-picker-item-content-padding-vertical);
30
+ padding-inline: var(--rs-picker-item-content-padding-horizontal);
31
+ padding-inline-end: calc(var(--rs-padding-inline-md) + 20px);
32
+ position: relative;
33
+ cursor: pointer;
34
+ color: var(--rs-text-heading);
35
+
36
+ .rs-#{$prefix}-menu-group-caret {
37
+ display: inline-block;
38
+ margin-inline-start: 2px;
39
+ position: absolute;
40
+ top: var(--rs-padding-block-md);
41
+ inset-inline-end: var(--rs-padding-inline-md);
42
+ color: var(--rs-text-secondary);
43
+ }
44
+ }
45
+ }
46
+
47
+ // Group closed common styles
48
+ @mixin picker-menu-group-closed($prefix) {
49
+ .rs-#{$prefix}-menu-group.folded {
50
+ .rs-#{$prefix}-menu-group-caret {
51
+ transform: rotate(90deg);
52
+ }
53
+ }
54
+ }
55
+
56
+ @mixin picker-item-hover {
57
+ color: var(--rs-text-primary);
58
+ background-color: var(--rs-state-hover-bg);
59
+ }
60
+
61
+ @mixin picker-item-active {
62
+ font-weight: var(--rs-picker-select-menu-item-selected-font-weight);
63
+ }
64
+
65
+ @mixin picker-calendar-cell-content {
66
+ display: inline-block;
67
+ cursor: pointer;
68
+ font-size: var(--rs-calendar-cell-font-size);
69
+ line-height: var(--rs-calendar-cell-line-height);
70
+ padding: var(--rs-calendar-cell-padding);
71
+ border-radius: var(--rs-calendar-border-radius);
72
+
73
+ &:hover {
74
+ background-color: var(--rs-state-hover-bg);
75
+ }
76
+ }
77
+
78
+ @mixin picker-calendar-cell-content-selected {
79
+ color: var(--rs-calendar-date-selected-text);
80
+ background-color: var(--rs-bg-active);
81
+ box-shadow: none;
82
+
83
+ @include color-modes.high-contrast-mode {
84
+ text-decoration: underline;
85
+ }
86
+ }
87
+
88
+ @mixin picker-calendar-title-show {
89
+ color: var(--rs-text-active);
90
+ background: transparent;
91
+ }
92
+
93
+ // Default picker toggle
94
+ @mixin picker-default-toggle {
95
+ [data-appearance='default'] & {
96
+ color: var(--rs-text-primary);
97
+ border-width: var(--rs-picker-toggle-border-width);
98
+ border-color: var(--rs-picker-toggle-border-color);
99
+ border-style: solid;
100
+ }
101
+
102
+ [data-disabled='true'] & {
103
+ cursor: var(--rs-cursor-disabled);
104
+ }
105
+
106
+ [data-appearance='default']:not([data-disabled='true']) {
107
+ &:focus {
108
+ border-color: var(--rs-input-focus-border);
109
+ }
110
+ }
111
+ }
112
+
113
+ // Subtle picker toggle
114
+ @mixin picker-subtle-toggle {
115
+ .rs-picker[data-appearance='subtle'] & {
116
+ --rs-picker-toggle-border-width: 0px;
117
+ @include dropdown.dropdown-toggle;
118
+ }
119
+
120
+ .rs-picker[data-appearance='subtle'][data-disabled='true'] & {
121
+ cursor: var(--rs-cursor-disabled);
122
+
123
+ &:focus,
124
+ &:active {
125
+ background: none;
126
+
127
+ &::after {
128
+ display: none;
129
+ }
130
+ }
131
+ }
132
+ }
133
+
134
+ // Group closed common styles
135
+ @mixin picker-menu-group-closed($prefix) {
136
+ .rs-#{$prefix}-menu-group.folded {
137
+ .rs-#{$prefix}-menu-group-caret {
138
+ transform: rotate(90deg);
139
+ }
140
+ }
141
+ }
142
+
143
+ @mixin picker-item-hover {
144
+ color: var(--rs-text-primary);
145
+ background-color: var(--rs-state-hover-bg);
146
+ }
147
+
148
+ @mixin picker-item-active {
149
+ font-weight: var(--rs-picker-select-menu-item-selected-font-weight);
150
+ }
151
+
152
+ @mixin picker-calendar-cell-content {
153
+ display: inline-block;
154
+ cursor: pointer;
155
+ font-size: var(--rs-calendar-cell-font-size);
156
+ line-height: var(--rs-calendar-cell-line-height);
157
+ padding: var(--rs-calendar-cell-padding);
158
+ border-radius: var(--rs-calendar-border-radius);
159
+
160
+ &:hover {
161
+ background-color: var(--rs-state-hover-bg);
162
+ }
163
+ }
164
+
165
+ @mixin picker-calendar-cell-content-selected {
166
+ color: var(--rs-calendar-date-selected-text);
167
+ background-color: var(--rs-bg-active);
168
+ box-shadow: none;
169
+
170
+ @include color-modes.high-contrast-mode {
171
+ text-decoration: underline;
172
+ }
173
+ }
174
+
175
+ @mixin picker-calendar-title-show {
176
+ color: var(--rs-text-active);
177
+ background: transparent;
178
+ }
179
+
180
+ // Default picker toggle
181
+ @mixin picker-default-toggle {
182
+ [data-appearance='default'] & {
183
+ color: var(--rs-text-primary);
184
+ border-width: var(--rs-picker-toggle-border-width);
185
+ border-color: var(--rs-picker-toggle-border-color);
186
+ border-style: solid;
187
+ }
188
+
189
+ [data-disabled='true'] & {
190
+ cursor: var(--rs-cursor-disabled);
191
+ }
192
+
193
+ [data-appearance='default']:not([data-disabled='true']) {
194
+ &:focus {
195
+ border-color: var(--rs-input-focus-border);
196
+ }
197
+ }
198
+ }
199
+
200
+ // Subtle picker toggle
201
+ @mixin picker-subtle-toggle {
202
+ .rs-picker[data-appearance='subtle'] & {
203
+ --rs-picker-toggle-border-width: 0px;
204
+ @include dropdown.dropdown-toggle;
205
+ }
206
+
207
+ .rs-picker[data-appearance='subtle'][data-disabled='true'] & {
208
+ cursor: var(--rs-cursor-disabled);
209
+
210
+ &:focus,
211
+ &:active {
212
+ background: none;
213
+
214
+ &::after {
215
+ display: none;
216
+ }
217
+ }
218
+ }
219
+ }
@@ -0,0 +1,9 @@
1
+ // Picker variables
2
+ :root {
3
+ --rs-picker-transition: var(--rs-input-transition);
4
+ --rs-picker-select-menu-item-selected-font-weight: bold;
5
+ --rs-picker-group-select-menu-gap: 6px;
6
+ --rs-picker-menu-padding: 12px;
7
+ --rs-picker-item-content-padding-vertical: 8px;
8
+ --rs-picker-item-content-padding-horizontal: var(--rs-picker-menu-padding);
9
+ }
@@ -0,0 +1,476 @@
1
+ @use '../../../styles/themes';
2
+ @use '../../../Button/styles/mixin' as button;
3
+ @use '../../../styles/mixins/listbox';
4
+ @use '../../../styles/mixins/combobox';
5
+ @use '../../../styles/mixins/utilities' as utils;
6
+ @use '../../../styles/mixins/color-modes';
7
+ @use '../../../Stack/styles/index' as stack;
8
+ @use '../../../Loader/styles/index' as loader;
9
+ @use '../../../Input/styles/index' as input;
10
+ @use '../../../InputGroup/styles/index' as input-group;
11
+ @use '../../../Highlight/styles/index' as highlight;
12
+ @use '../../CloseButton/styles/index' as close-button;
13
+ @use './mixin';
14
+ @use './variables';
15
+
16
+ //
17
+ // Pickers
18
+ // --------------------------------------------------
19
+
20
+ // Common styles
21
+ // ----------------------
22
+ .rs-picker {
23
+ --rs-picker-value-count-border-radius: var(--rs-radius-full);
24
+ --rs-picker-value-count-padding: calc(var(--rs-spacing) * 1.5);
25
+ --rs-picker-value-count-margin: var(--rs-spacing);
26
+ --rs-picker-size: 0.875rem;
27
+ --rs-picker-loader-size: 20px;
28
+ --rs-picker-toggle-border-width: 1px;
29
+ --rs-picker-toggle-bg: var(--rs-input-bg);
30
+ --rs-picker-toggle-border-color: var(--rs-border-primary);
31
+
32
+ display: inline-block;
33
+ vertical-align: middle;
34
+ max-width: 100%;
35
+
36
+ &[data-block='true'] {
37
+ display: block;
38
+ width: 100%;
39
+ }
40
+
41
+ &[data-disabled='true'] {
42
+ cursor: not-allowed;
43
+
44
+ .rs-picker-toggle-value,
45
+ .rs-picker-toggle-indicator,
46
+ .rs-picker-tag-list .rs-tag {
47
+ color: var(--rs-text-disabled) !important;
48
+ }
49
+
50
+ .rs-picker-value-count {
51
+ opacity: 0.5;
52
+ }
53
+
54
+ .rs-picker-toggle {
55
+ pointer-events: none;
56
+ }
57
+ }
58
+
59
+ &-toggle &-toggle-placeholder {
60
+ color: var(--rs-text-secondary);
61
+ }
62
+
63
+ &-has-value .rs-btn &-toggle-value,
64
+ &-has-value &-toggle &-toggle-value {
65
+ color: var(--rs-picker-value);
66
+ }
67
+
68
+ &-value-list {
69
+ flex: 0 1 auto;
70
+ @include utils.ellipsis-basic;
71
+ }
72
+
73
+ .rs-picker-value-count {
74
+ margin-inline: var(--rs-picker-value-count-margin);
75
+ background-color: var(--rs-picker-count-bg);
76
+ color: var(--rs-picker-count-text);
77
+ flex-shrink: 0;
78
+ }
79
+
80
+ &-value-separator {
81
+ margin: 0 var(--rs-spacing) 0 0;
82
+ }
83
+
84
+ // Focus state for input/tag picker
85
+ &[data-focus='true'] {
86
+ border-color: var(--rs-input-focus-border);
87
+ }
88
+
89
+ &-toggle[data-active='true'],
90
+ &[data-focus='true'] {
91
+ --rs-picker-toggle-border-color: var(--rs-input-focus-border);
92
+ @include utils.focus-ring;
93
+ }
94
+
95
+ &-label.rs-input-group-addon {
96
+ color: var(--rs-text-primary);
97
+ padding-inline: calc(
98
+ var(--rs-input-group-inside-btn-padding) * 2 - var(--rs-picker-toggle-border-width)
99
+ );
100
+ }
101
+
102
+ &-loader {
103
+ width: var(--rs-picker-loader-size);
104
+ height: var(--rs-picker-loader-size);
105
+ display: flex;
106
+ align-items: center;
107
+ }
108
+
109
+ &-error > .rs-picker-input-group {
110
+ border-color: var(--rs-picker-state-error);
111
+
112
+ &:hover {
113
+ border-color: var(--rs-picker-state-error);
114
+ }
115
+
116
+ &:focus-within {
117
+ border-color: var(--rs-picker-state-error);
118
+ outline: var(--rs-picker-state-error-outline);
119
+ }
120
+ }
121
+ }
122
+
123
+ // Picker Menu
124
+ .rs-picker-popup {
125
+ --rs-picker-popup-none-padding: calc(var(--rs-spacing) * 3);
126
+ --rs-picker-popup-border-radius: var(--rs-radius-md);
127
+ --rs-picker-search-box-padding: calc(var(--rs-spacing) * 1.5) calc(var(--rs-spacing) * 3);
128
+ --rs-picker-popup-z-index: var(--rs-zindex-picker-popup);
129
+ --rs-picker-popup-shadow: var(--rs-shadow-md);
130
+ --rs-picker-popup-position-x: var(--rs-position-x);
131
+ --rs-picker-popup-position-y: var(--rs-position-y);
132
+ --rs-picker-min-width: 0;
133
+
134
+ position: absolute;
135
+ top: var(--rs-picker-popup-position-y);
136
+ left: var(--rs-picker-popup-position-x);
137
+ text-align: start;
138
+ overflow: hidden;
139
+ transition: none;
140
+ display: flex;
141
+ flex-direction: column;
142
+ z-index: var(--rs-picker-popup-z-index);
143
+ border-radius: var(--rs-picker-popup-border-radius);
144
+ background-color: var(--rs-bg-overlay);
145
+ box-shadow: var(--rs-picker-popup-shadow);
146
+ padding-block: var(--rs-picker-popup-border-radius);
147
+ min-width: var(--rs-picker-min-width);
148
+
149
+ @include color-modes.high-contrast-mode {
150
+ border: 1px solid var(--rs-border-primary);
151
+ }
152
+
153
+ // Increase z-index when modal opened.
154
+ .rs-modal-open & {
155
+ --rs-picker-popup-z-index: calc(var(--rs-zindex-modal) + var(--rs-zindex-picker-toggle));
156
+ }
157
+
158
+ // Increase z-index when drawer opened.
159
+ .rs-drawer-open & {
160
+ --rs-picker-popup-z-index: calc(var(--rs-zindex-drawer) + var(--rs-zindex-picker-toggle));
161
+ }
162
+
163
+ &.rs-picker-inline {
164
+ position: relative;
165
+ box-shadow: none;
166
+ }
167
+
168
+ .rs-search-box {
169
+ padding: var(--rs-picker-search-box-padding);
170
+ }
171
+
172
+ .rs-highlight .rs-highlight-mark {
173
+ padding: 0;
174
+ }
175
+
176
+ // Empty listbox
177
+ .rs-picker-none {
178
+ padding: var(--rs-picker-popup-none-padding);
179
+ color: var(--rs-text-secondary);
180
+ cursor: default;
181
+ }
182
+
183
+ .rs-picker-listbox {
184
+ max-height: var(--rs-picker-listbox-max-height);
185
+ }
186
+
187
+ // Responsive popup
188
+ &[data-breakpoint='xs'] {
189
+ min-width: unset;
190
+ width: 100%;
191
+ height: 100%;
192
+ overflow: auto;
193
+
194
+ .rs-picker-listbox {
195
+ height: unset;
196
+ max-height: unset;
197
+ }
198
+
199
+ .rs-tree,
200
+ .rs-check-tree {
201
+ display: flex;
202
+ flex-direction: column;
203
+ &-view {
204
+ max-height: unset;
205
+ flex: 1 1 auto;
206
+ }
207
+ }
208
+
209
+ .rs-calendar-table {
210
+ width: 100%;
211
+ }
212
+
213
+ .rs-picker-box {
214
+ width: 100%;
215
+ height: 100%;
216
+ flex: 1;
217
+ display: flex;
218
+ flex-direction: column;
219
+ }
220
+
221
+ &.rs-picker-popup-date,
222
+ .rs-picker-daterange-panel-only-time {
223
+ .rs-calendar {
224
+ height: 348px;
225
+ }
226
+ }
227
+ }
228
+ }
229
+
230
+ .rs-picker-toggle {
231
+ --rs-badge-one-char-size: 18px;
232
+
233
+ @include mixin.picker-default-toggle;
234
+ @include mixin.picker-subtle-toggle;
235
+
236
+ &-label {
237
+ color: var(--rs-text-secondary);
238
+ }
239
+
240
+ .rs-picker-toggle-stack {
241
+ flex: 1 1 auto;
242
+ gap: calc(var(--rs-spacing) * 2);
243
+ overflow: hidden;
244
+ align-items: center;
245
+ }
246
+
247
+ &-value {
248
+ display: block;
249
+ @include utils.ellipsis;
250
+ }
251
+
252
+ &-textbox {
253
+ position: absolute;
254
+ width: 100%;
255
+ height: 100%;
256
+ inset-inline-start: 0;
257
+ top: 0;
258
+ border: 1px solid #0000;
259
+ padding-inline-start: 10px;
260
+ padding-inline-end: 32px;
261
+ color: var(--rs-text-primary);
262
+ background-color: var(--rs-input-bg);
263
+ outline: none;
264
+
265
+ &:where([readonly]) {
266
+ opacity: 0;
267
+ }
268
+ }
269
+
270
+ &:where([data-size='lg']) &-textbox {
271
+ padding-inline-start: 14px;
272
+ }
273
+
274
+ &:where([data-size='sm']) &-textbox {
275
+ padding-inline-start: 8px;
276
+ }
277
+
278
+ &:where([data-size='xs']) &-textbox {
279
+ padding-inline-start: 6px;
280
+ }
281
+
282
+ .rs-picker[data-appearance='default'],
283
+ & {
284
+ transition: var(--rs-picker-transition);
285
+
286
+ @include color-modes.high-contrast-mode {
287
+ transition: none;
288
+ }
289
+ }
290
+
291
+ .rs-picker[data-appearance='default'] {
292
+ &:focus {
293
+ border-color: var(--rs-input-focus-border);
294
+ }
295
+ }
296
+
297
+ .rs-picker[data-appearance='subtle'] & {
298
+ color: var(--rs-btn-subtle-text);
299
+ background-color: transparent;
300
+
301
+ &:hover {
302
+ color: var(--rs-btn-subtle-hover-text);
303
+ background-color: var(--rs-btn-subtle-hover-bg);
304
+ }
305
+
306
+ transition: none;
307
+
308
+ &[data-active='true'] {
309
+ background-color: var(--rs-btn-subtle-hover-bg);
310
+ color: var(--rs-btn-subtle-hover-text);
311
+ }
312
+ }
313
+
314
+ &[data-size='lg'] {
315
+ --rs-badge-one-char-size: 20px;
316
+ .rs-picker-clean {
317
+ .rs-icon {
318
+ width: 16px;
319
+ height: 16px;
320
+ }
321
+ }
322
+ }
323
+
324
+ &[data-size='md'] {
325
+ --rs-badge-one-char-size: 18px;
326
+ }
327
+
328
+ &[data-size='sm'] {
329
+ --rs-badge-one-char-size: 16px;
330
+ .rs-picker-clean {
331
+ height: 18px;
332
+ }
333
+ }
334
+
335
+ &[data-size='xs'] {
336
+ --rs-badge-one-char-size: 14px;
337
+ .rs-picker-clean {
338
+ height: 18px;
339
+ .rs-icon {
340
+ width: 12px;
341
+ height: 12px;
342
+ }
343
+ }
344
+ }
345
+
346
+ &[data-countable='true'] &-value {
347
+ display: flex;
348
+ align-items: center;
349
+ }
350
+ }
351
+
352
+ .rs-picker-toggle.rs-btn {
353
+ text-align: start;
354
+ display: inline-flex;
355
+ align-items: center;
356
+ justify-content: flex-start;
357
+ padding-inline: calc(var(--rs-btn-padding-inline) - var(--rs-picker-toggle-border-width));
358
+
359
+ [data-block='true'] & {
360
+ display: flex;
361
+ }
362
+ }
363
+
364
+ .rs-picker-toggle-indicator {
365
+ display: inline-flex;
366
+ align-items: center;
367
+
368
+ // Picker clear button
369
+ .rs-picker-clean {
370
+ color: var(--rs-text-secondary);
371
+ transition: 0.2s color linear;
372
+ cursor: pointer;
373
+
374
+ &:hover {
375
+ color: var(--rs-text-primary);
376
+ }
377
+
378
+ &.rs-btn-close {
379
+ padding: 0;
380
+ }
381
+ }
382
+
383
+ // Picker toggle caret
384
+ .rs-picker-caret-icon {
385
+ // Extend Dropdown toggle caret style
386
+ @include combobox.combobox-indicator-icon;
387
+
388
+ font-size: var(--rs-font-size-md);
389
+ color: var(--rs-text-secondary);
390
+ }
391
+ }
392
+
393
+ // Make sure styles the same with <Input>
394
+ .rs-picker[data-appearance='default'],
395
+ .rs-picker-input {
396
+ .rs-btn,
397
+ .rs-picker-toggle {
398
+ background-color: var(--rs-picker-toggle-bg);
399
+ }
400
+
401
+ &[data-disabled='true'] {
402
+ --rs-picker-toggle-bg: var(--rs-input-disabled-bg);
403
+
404
+ .rs-input-group {
405
+ pointer-events: none;
406
+ }
407
+ }
408
+ }
409
+
410
+ // Check Item
411
+ .rs-check-item {
412
+ --rs-checkbox-display: block;
413
+
414
+ &:not(.rs-checkbox-disabled):hover,
415
+ &:focus,
416
+ &#{&}-focus {
417
+ @include listbox.listbox-option-active;
418
+
419
+ @include color-modes.high-contrast-mode {
420
+ .rs-check-tree-node-text-wrapper {
421
+ text-decoration: underline;
422
+ }
423
+ }
424
+ }
425
+
426
+ .rs-checkbox-checker {
427
+ display: flex;
428
+
429
+ > label {
430
+ cursor: pointer;
431
+ width: 100%;
432
+ padding-inline: var(--rs-check-item-padding-inline);
433
+ padding-block: var(--rs-check-item-padding-block);
434
+
435
+ @include color-modes.high-contrast-mode {
436
+ transition: none;
437
+ }
438
+
439
+ &::before {
440
+ background-color: var(--rs-bg-overlay);
441
+
442
+ @include color-modes.high-contrast-mode {
443
+ background: none;
444
+ }
445
+ }
446
+
447
+ &[data-disabled='true'] {
448
+ cursor: not-allowed;
449
+ }
450
+ }
451
+ }
452
+ }
453
+
454
+ .rs-picker-menu-group {
455
+ background-color: var(--rs-listbox-option-group-bg);
456
+ position: sticky;
457
+ top: -1px;
458
+ z-index: 1;
459
+ }
460
+
461
+ .rs-virt-list {
462
+ // Use for single selection
463
+ .rs-picker-select-menu-item,
464
+
465
+ // Use for multiple selection with Checkbox
466
+ .rs-check-item label {
467
+ @include utils.ellipsis-basic;
468
+ }
469
+ }
470
+
471
+ .rs-tree-virt-list {
472
+ // Use for single selection
473
+ .rs-tree-node-label {
474
+ @include utils.ellipsis-basic;
475
+ }
476
+ }
@@ -0,0 +1,10 @@
1
+ @use '../../../styles/mixins/hacks';
2
+
3
+ @mixin with-ripple {
4
+ & {
5
+ position: relative;
6
+ overflow: hidden;
7
+ }
8
+
9
+ @include hacks.safari-border-radius-overflow-hidden;
10
+ }