@dolanske/vui 1.0.4 → 1.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 (195) hide show
  1. package/LICENSE +673 -673
  2. package/README.md +42 -42
  3. package/dist/components/Accordion/Accordion.vue.d.ts +3 -2
  4. package/dist/components/Accordion/AccordionGroup.vue.d.ts +5 -2
  5. package/dist/components/Alert/Alert.vue.d.ts +3 -2
  6. package/dist/components/Avatar/Avatar.vue.d.ts +3 -2
  7. package/dist/components/Badge/Badge.vue.d.ts +3 -2
  8. package/dist/components/Breadcrumbs/BreadcrumbItem.vue.d.ts +3 -2
  9. package/dist/components/Breadcrumbs/Breadcrumbs.vue.d.ts +3 -2
  10. package/dist/components/Button/Button.vue.d.ts +3 -2
  11. package/dist/components/ButtonGroup/ButtonGroup.vue.d.ts +3 -2
  12. package/dist/components/Calendar/Calendar.vue.d.ts +6 -6
  13. package/dist/components/Card/Card.vue.d.ts +4 -3
  14. package/dist/components/Checkbox/Checkbox.vue.d.ts +7 -6
  15. package/dist/components/CopyClipboard/CopyClipboard.vue.d.ts +2 -1
  16. package/dist/components/Divider/Divider.vue.d.ts +3 -2
  17. package/dist/components/Drawer/Drawer.vue.d.ts +10 -9
  18. package/dist/components/Dropdown/Dropdown.vue.d.ts +66 -3
  19. package/dist/components/Dropdown/DropdownItem.vue.d.ts +3 -2
  20. package/dist/components/Dropdown/DropdownTitle.vue.d.ts +6 -6
  21. package/dist/components/Flex/Flex.vue.d.ts +13 -12
  22. package/dist/components/Grid/Grid.vue.d.ts +7 -6
  23. package/dist/components/Input/Color.vue.d.ts +5 -5
  24. package/dist/components/Input/Counter.vue.d.ts +5 -5
  25. package/dist/components/Input/Dropzone.vue.d.ts +95 -10
  26. package/dist/components/Input/File.vue.d.ts +4 -3
  27. package/dist/components/Input/Input.vue.d.ts +7 -6
  28. package/dist/components/Input/Password.vue.d.ts +1 -1
  29. package/dist/components/Input/Textarea.vue.d.ts +7 -6
  30. package/dist/components/Kbd/Kbd.vue.d.ts +1 -1
  31. package/dist/components/Kbd/KbdGroup.vue.d.ts +2 -1
  32. package/dist/components/Modal/Confirm.vue.d.ts +7 -9
  33. package/dist/components/Modal/Modal.vue.d.ts +16 -13
  34. package/dist/components/OTP/OTP.vue.d.ts +7 -6
  35. package/dist/components/OTP/OTPItem.vue.d.ts +1 -1
  36. package/dist/components/Pagination/Pagination.vue.d.ts +3 -2
  37. package/dist/components/Popout/Popout.vue.d.ts +3 -2
  38. package/dist/components/Progress/Progress.vue.d.ts +5 -5
  39. package/dist/components/Radio/Radio.vue.d.ts +7 -6
  40. package/dist/components/Radio/RadioGroup.vue.d.ts +7 -6
  41. package/dist/components/Select/Select.vue.d.ts +4 -8
  42. package/dist/components/Sheet/Sheet.vue.d.ts +22 -13
  43. package/dist/components/Sidebar/Sidebar.vue.d.ts +7 -6
  44. package/dist/components/Skeleton/Skeleton.vue.d.ts +1 -1
  45. package/dist/components/Spinner/Spinner.vue.d.ts +1 -1
  46. package/dist/components/Switch/Switch.vue.d.ts +7 -6
  47. package/dist/components/Table/Cell.vue.d.ts +5 -2
  48. package/dist/components/Table/Head.vue.d.ts +3 -2
  49. package/dist/components/Table/Root.vue.d.ts +3 -2
  50. package/dist/components/Table/table.d.ts +2 -2
  51. package/dist/components/Tabs/Tab.vue.d.ts +3 -2
  52. package/dist/components/Tabs/Tabs.vue.d.ts +7 -6
  53. package/dist/components/Toast/toast.d.ts +6 -6
  54. package/dist/components/Tooltip/Tooltip.vue.d.ts +2 -1
  55. package/dist/internal/Backdrop/Backdrop.vue.d.ts +3 -2
  56. package/dist/vui.css +1 -0
  57. package/dist/vui.js +8090 -7884
  58. package/package.json +73 -72
  59. package/src/App.vue +95 -95
  60. package/src/components/Accordion/Accordion.vue +91 -91
  61. package/src/components/Accordion/AccordionGroup.vue +43 -43
  62. package/src/components/Accordion/accordion.scss +82 -82
  63. package/src/components/Alert/Alert.vue +59 -59
  64. package/src/components/Alert/alert.scss +161 -161
  65. package/src/components/Avatar/Avatar.vue +53 -53
  66. package/src/components/Avatar/avatar.scss +52 -52
  67. package/src/components/Badge/Badge.vue +21 -21
  68. package/src/components/Badge/badge.scss +210 -206
  69. package/src/components/Breadcrumbs/BreadcrumbItem.vue +26 -26
  70. package/src/components/Breadcrumbs/Breadcrumbs.vue +30 -30
  71. package/src/components/Breadcrumbs/breadcrumbs.scss +31 -31
  72. package/src/components/Button/Button.vue +85 -85
  73. package/src/components/Button/button.scss +279 -279
  74. package/src/components/ButtonGroup/ButtonGroup.vue +28 -28
  75. package/src/components/ButtonGroup/button-group.scss +51 -51
  76. package/src/components/Calendar/Calendar.vue +66 -66
  77. package/src/components/Calendar/calendar.scss +83 -83
  78. package/src/components/Card/Card.vue +48 -48
  79. package/src/components/Card/card.scss +53 -53
  80. package/src/components/Checkbox/Checkbox.vue +54 -54
  81. package/src/components/Checkbox/checkbox.scss +80 -80
  82. package/src/components/CopyClipboard/CopyClipboard.vue +91 -91
  83. package/src/components/CopyClipboard/copy-clipboard.scss +25 -25
  84. package/src/components/Divider/Divider.vue +44 -44
  85. package/src/components/Divider/divider.scss +35 -35
  86. package/src/components/Drawer/Drawer.vue +102 -97
  87. package/src/components/Drawer/drawer.scss +37 -37
  88. package/src/components/Dropdown/Dropdown.vue +135 -135
  89. package/src/components/Dropdown/DropdownItem.vue +33 -33
  90. package/src/components/Dropdown/DropdownTitle.vue +14 -14
  91. package/src/components/Dropdown/dropdown-item.scss +84 -84
  92. package/src/components/Dropdown/dropdown.scss +53 -53
  93. package/src/components/Flex/Flex.vue +113 -113
  94. package/src/components/Grid/Grid.vue +79 -80
  95. package/src/components/Input/Color.vue +26 -26
  96. package/src/components/Input/Counter.vue +66 -66
  97. package/src/components/Input/Dropzone.vue +65 -65
  98. package/src/components/Input/File.vue +15 -15
  99. package/src/components/Input/Input.vue +123 -123
  100. package/src/components/Input/Password.vue +35 -35
  101. package/src/components/Input/Textarea.vue +78 -78
  102. package/src/components/Input/input.scss +302 -302
  103. package/src/components/Kbd/Kbd.vue +48 -48
  104. package/src/components/Kbd/KbdGroup.vue +27 -27
  105. package/src/components/Kbd/kbd.scss +19 -19
  106. package/src/components/Modal/Confirm.vue +56 -56
  107. package/src/components/Modal/Modal.vue +103 -99
  108. package/src/components/Modal/modal.scss +54 -54
  109. package/src/components/OTP/OTP.vue +133 -133
  110. package/src/components/OTP/OTPItem.vue +37 -37
  111. package/src/components/OTP/otp.scss +84 -84
  112. package/src/components/Pagination/Pagination.vue +77 -77
  113. package/src/components/Pagination/pagination.ts +78 -78
  114. package/src/components/Popout/Popout.vue +52 -52
  115. package/src/components/Popout/popout.scss +15 -15
  116. package/src/components/Progress/Progress.vue +103 -103
  117. package/src/components/Progress/progress.scss +47 -47
  118. package/src/components/Radio/Radio.vue +38 -38
  119. package/src/components/Radio/RadioGroup.vue +40 -40
  120. package/src/components/Radio/radio.scss +78 -78
  121. package/src/components/Select/Select.vue +211 -211
  122. package/src/components/Select/select.scss +77 -77
  123. package/src/components/Sheet/Sheet.vue +108 -98
  124. package/src/components/Sheet/sheet.scss +69 -69
  125. package/src/components/Sidebar/Sidebar.vue +115 -115
  126. package/src/components/Sidebar/sidebar.scss +124 -124
  127. package/src/components/Skeleton/Skeleton.vue +43 -43
  128. package/src/components/Skeleton/skeleton.scss +14 -14
  129. package/src/components/Spinner/Spinner.vue +42 -42
  130. package/src/components/Spinner/spinner.scss +47 -47
  131. package/src/components/Switch/Switch.vue +31 -31
  132. package/src/components/Switch/switch.scss +93 -93
  133. package/src/components/Table/Cell.vue +23 -23
  134. package/src/components/Table/Head.vue +59 -59
  135. package/src/components/Table/Root.vue +66 -66
  136. package/src/components/Table/SelectAll.vue +23 -23
  137. package/src/components/Table/SelectRow.vue +30 -30
  138. package/src/components/Table/index.ts +7 -7
  139. package/src/components/Table/table.scss +154 -154
  140. package/src/components/Table/table.ts +248 -248
  141. package/src/components/Tabs/Tab.vue +25 -25
  142. package/src/components/Tabs/Tabs.vue +90 -90
  143. package/src/components/Tabs/tabs.scss +87 -87
  144. package/src/components/Toast/Toasts.vue +52 -52
  145. package/src/components/Toast/toast.scss +45 -45
  146. package/src/components/Toast/toast.ts +75 -75
  147. package/src/components/Tooltip/Tooltip.vue +86 -86
  148. package/src/components/Tooltip/tooltip.scss +8 -8
  149. package/src/examples/ExampleAccordions.vue +58 -58
  150. package/src/examples/ExampleAlerts.vue +78 -78
  151. package/src/examples/ExampleAvatars.vue +44 -44
  152. package/src/examples/ExampleBadges.vue +48 -48
  153. package/src/examples/ExampleBreadcrumbs.vue +46 -46
  154. package/src/examples/ExampleButtons.vue +140 -140
  155. package/src/examples/ExampleCalendars.vue +40 -40
  156. package/src/examples/ExampleCards.vue +94 -94
  157. package/src/examples/ExampleCheckboxes.vue +123 -123
  158. package/src/examples/ExampleCopyClipboard.vue +47 -47
  159. package/src/examples/ExampleDividers.vue +39 -39
  160. package/src/examples/ExampleDrawers.vue +67 -67
  161. package/src/examples/ExampleDropdowns.vue +114 -114
  162. package/src/examples/ExampleFlexGrid.vue +124 -122
  163. package/src/examples/ExampleInputs.vue +234 -234
  164. package/src/examples/ExampleKBD.vue +65 -65
  165. package/src/examples/ExampleModals.vue +143 -143
  166. package/src/examples/ExamplePalette.vue +159 -159
  167. package/src/examples/ExamplePopouts.vue +41 -41
  168. package/src/examples/ExampleSheets.vue +77 -77
  169. package/src/examples/ExampleSidebars.vue +270 -270
  170. package/src/examples/ExampleSkeletons.vue +26 -26
  171. package/src/examples/ExampleSpinners.vue +80 -78
  172. package/src/examples/ExampleTables.vue +195 -195
  173. package/src/examples/ExampleTabs.vue +119 -119
  174. package/src/examples/ExampleToasts.vue +96 -96
  175. package/src/examples/ExampleTooltips.vue +70 -70
  176. package/src/examples/shared/ExampleColor.vue +28 -28
  177. package/src/index.ts +116 -116
  178. package/src/internal/Backdrop/Backdrop.vue +22 -22
  179. package/src/internal/Backdrop/backdrop.scss +34 -34
  180. package/src/main.ts +5 -5
  181. package/src/shared/helpers.ts +117 -117
  182. package/src/shared/theme.ts +22 -22
  183. package/src/shared/types.ts +29 -29
  184. package/src/style/animation.scss +22 -22
  185. package/src/style/core.scss +119 -125
  186. package/src/style/layout.scss +207 -233
  187. package/src/style/media-query.scss +29 -29
  188. package/src/style/reset.scss +135 -135
  189. package/src/style/text.scss +137 -124
  190. package/src/style/theme.scss +195 -195
  191. package/src/style/tooltip.scss +146 -146
  192. package/src/style/typography.scss +415 -415
  193. package/src/style/utils.scss +36 -36
  194. package/src/style.scss +1 -1
  195. package/dist/style.css +0 -1
@@ -1,279 +1,279 @@
1
- .vui-button {
2
- --button-height: var(--interactive-el-height);
3
- --button-padding: 8px;
4
-
5
- &.disabled {
6
- // color: var(--color-text-lighter) !important;
7
- cursor: not-allowed !important;
8
- filter: saturate(75%) opacity(50%);
9
-
10
- svg path {
11
- color: var(--color-text-light) !important;
12
- }
13
- }
14
-
15
- &.expand {
16
- width: 100%;
17
- }
18
-
19
- &.loading {
20
- .vui-spinner {
21
- opacity: 1;
22
- }
23
-
24
- .vui-button-slot {
25
- opacity: 0;
26
- }
27
- }
28
-
29
- &.icon {
30
- width: var(--button-height);
31
- padding: 0;
32
- }
33
-
34
- .vui-button-slot svg {
35
- display: block;
36
- color: var(--color-text);
37
- width: 17px;
38
- height: 17px;
39
- }
40
-
41
- &.square {
42
- width: var(--button-height);
43
- min-width: var(--button-height);
44
- min-height: var(--button-height);
45
- padding: 0;
46
- }
47
-
48
- &.dashed {
49
- border-style: dashed !important;
50
- }
51
-
52
- svg path {
53
- transition: var(--transition-fast);
54
- }
55
-
56
- height: var(--button-height);
57
- display: flex;
58
- align-items: center;
59
- justify-content: center;
60
- border-radius: var(--border-radius-s);
61
- background: transparent;
62
- padding-inline: var(--button-padding);
63
- font-size: var(--font-size-s);
64
- position: relative;
65
- transition: var(--transition-fast);
66
- border: 1px solid transparent;
67
- background-color: transparent;
68
- color: var(--color-text);
69
-
70
- // Default gray
71
-
72
- .vui-button-slot {
73
- display: flex;
74
- place-items: center;
75
- transition: var(--transition-fast);
76
- opacity: 1;
77
- }
78
-
79
- .vui-button-slot-start,
80
- .vui-button-slot-end {
81
- display: flex;
82
- place-items: center;
83
- }
84
-
85
- .vui-button-slot-start {
86
- margin-right: 6px;
87
- }
88
-
89
- .vui-button-slot-end {
90
- margin-left: 6px;
91
- }
92
-
93
- .vui-spinner {
94
- transition: var(--transition-fast);
95
- opacity: 0;
96
- position: absolute;
97
- pointer-events: none;
98
- }
99
-
100
- // Variants
101
- &.vui-button-variant-danger {
102
- &:not(.plain):not(.outline) {
103
- color: var(--color-text);
104
- background-color: var(--color-bg-red-raised);
105
-
106
- svg,
107
- path {
108
- color: var(--color-text);
109
- }
110
- }
111
-
112
- &.outline {
113
- border-color: var(--color-bg-red-lowered);
114
- }
115
-
116
- &:not(.plain):not(.disabled):not(.plain):hover,
117
- &:hover:not(.disabled) {
118
- background-color: var(--color-bg-red-lowered);
119
- }
120
- }
121
-
122
- &.vui-button-variant-success {
123
- &:not(.plain):not(.outline) {
124
- color: var(--color-text);
125
- background-color: var(--color-bg-green-raised);
126
-
127
- svg,
128
- path {
129
- color: var(--color-text);
130
- }
131
- }
132
-
133
- &.outline {
134
- border-color: var(--color-bg-green-lowered);
135
- }
136
-
137
- &:not(.plain):not(.disabled):not(.plain):hover,
138
- &:hover:not(.disabled) {
139
- background-color: var(--color-bg-green-lowered);
140
- }
141
- }
142
-
143
- &.vui-button-variant-gray {
144
- &:not(.plain):not(.outline) {
145
- color: var(--color-text);
146
- background-color: var(--color-button-gray);
147
-
148
- svg,
149
- path {
150
- color: var(--color-text);
151
- }
152
- }
153
-
154
- &.outline {
155
- border-color: var(--color-button-gray-hover);
156
- }
157
-
158
- &:not(.plain):not(.disabled):not(.plain):hover,
159
- &:hover:not(.disabled) {
160
- background-color: var(--color-button-gray-hover);
161
- }
162
- }
163
-
164
- &.vui-button-variant-fill {
165
- &:not(.plain):not(.outline) {
166
- color: var(--color-text-invert);
167
- background-color: var(--color-button-fill);
168
-
169
- svg,
170
- path {
171
- color: var(--color-text-invert);
172
- }
173
- }
174
-
175
- &.outline {
176
- border-color: var(--color-button-fill-hover);
177
-
178
- &:hover {
179
- color: var(--color-text-invert);
180
-
181
- svg,
182
- path {
183
- color: var(--color-text-invert);
184
- }
185
- }
186
- }
187
-
188
- &:not(.plain):not(.disabled):not(.plain):hover,
189
- &:hover:not(.disabled) {
190
- background-color: var(--color-button-fill-hover);
191
-
192
- &.plain {
193
- color: var(--color-text-invert);
194
-
195
- svg,
196
- path {
197
- color: var(--color-text-invert);
198
- }
199
- }
200
- }
201
- }
202
-
203
- &.vui-button-variant-accent {
204
- &:not(.plain):not(.outline) {
205
- color: var(--color-text);
206
- background-color: var(--color-bg-accent-raised);
207
-
208
- svg,
209
- path {
210
- color: var(--color-text);
211
- }
212
- }
213
-
214
- &.outline {
215
- border-color: var(--color-bg-accent-lowered);
216
- }
217
-
218
- &:not(.plain):not(.disabled):not(.plain):hover,
219
- &:hover:not(.disabled) {
220
- background-color: var(--color-bg-accent-lowered);
221
- }
222
- }
223
-
224
- &.vui-button-variant-link {
225
- color: var(--color-text);
226
- background: transparent;
227
- text-underline-offset: 4px;
228
- cursor: pointer;
229
-
230
- &:not(:disabled).active,
231
- &:not(:disabled):hover {
232
- text-decoration: underline;
233
- }
234
- }
235
- }
236
-
237
- :root.light {
238
- .vui-button {
239
- &.vui-button-variant-danger {
240
- &:not(.plain):not(.outline) {
241
- color: var(--color-text-invert);
242
-
243
- svg,
244
- path {
245
- color: var(--color-text-invert);
246
- }
247
- }
248
-
249
- &.outline:hover {
250
- color: var(--color-text-invert);
251
-
252
- svg,
253
- path {
254
- color: var(--color-text-invert);
255
- }
256
- }
257
- }
258
-
259
- &.vui-button-variant-success {
260
- &:not(.plain):not(.outline) {
261
- color: var(--color-text-invert);
262
-
263
- svg,
264
- path {
265
- color: var(--color-text-invert);
266
- }
267
- }
268
-
269
- &.outline:hover {
270
- color: var(--color-text-invert);
271
-
272
- svg,
273
- path {
274
- color: var(--color-text-invert);
275
- }
276
- }
277
- }
278
- }
279
- }
1
+ .vui-button {
2
+ --button-height: var(--interactive-el-height);
3
+ --button-padding: 8px;
4
+
5
+ &.disabled {
6
+ // color: var(--color-text-lighter) !important;
7
+ cursor: not-allowed !important;
8
+ filter: saturate(75%) opacity(50%);
9
+
10
+ svg path {
11
+ color: var(--color-text-light) !important;
12
+ }
13
+ }
14
+
15
+ &.expand {
16
+ width: 100%;
17
+ }
18
+
19
+ &.loading {
20
+ .vui-spinner {
21
+ opacity: 1;
22
+ }
23
+
24
+ .vui-button-slot {
25
+ opacity: 0;
26
+ }
27
+ }
28
+
29
+ &.icon {
30
+ width: var(--button-height);
31
+ padding: 0;
32
+ }
33
+
34
+ .vui-button-slot svg {
35
+ display: block;
36
+ color: var(--color-text);
37
+ width: 17px;
38
+ height: 17px;
39
+ }
40
+
41
+ &.square {
42
+ width: var(--button-height);
43
+ min-width: var(--button-height);
44
+ min-height: var(--button-height);
45
+ padding: 0;
46
+ }
47
+
48
+ &.dashed {
49
+ border-style: dashed !important;
50
+ }
51
+
52
+ svg path {
53
+ transition: var(--transition-fast);
54
+ }
55
+
56
+ height: var(--button-height);
57
+ display: flex;
58
+ align-items: center;
59
+ justify-content: center;
60
+ border-radius: var(--border-radius-s);
61
+ background: transparent;
62
+ padding-inline: var(--button-padding);
63
+ font-size: var(--font-size-s);
64
+ position: relative;
65
+ transition: var(--transition-fast);
66
+ border: 1px solid transparent;
67
+ background-color: transparent;
68
+ color: var(--color-text);
69
+
70
+ // Default gray
71
+
72
+ .vui-button-slot {
73
+ display: flex;
74
+ place-items: center;
75
+ transition: var(--transition-fast);
76
+ opacity: 1;
77
+ }
78
+
79
+ .vui-button-slot-start,
80
+ .vui-button-slot-end {
81
+ display: flex;
82
+ place-items: center;
83
+ }
84
+
85
+ .vui-button-slot-start {
86
+ margin-right: 6px;
87
+ }
88
+
89
+ .vui-button-slot-end {
90
+ margin-left: 6px;
91
+ }
92
+
93
+ .vui-spinner {
94
+ transition: var(--transition-fast);
95
+ opacity: 0;
96
+ position: absolute;
97
+ pointer-events: none;
98
+ }
99
+
100
+ // Variants
101
+ &.vui-button-variant-danger {
102
+ &:not(.plain):not(.outline) {
103
+ color: var(--color-text);
104
+ background-color: var(--color-bg-red-raised);
105
+
106
+ svg,
107
+ path {
108
+ color: var(--color-text);
109
+ }
110
+ }
111
+
112
+ &.outline {
113
+ border-color: var(--color-bg-red-lowered);
114
+ }
115
+
116
+ &:not(.plain):not(.disabled):not(.plain):hover,
117
+ &:hover:not(.disabled) {
118
+ background-color: var(--color-bg-red-lowered);
119
+ }
120
+ }
121
+
122
+ &.vui-button-variant-success {
123
+ &:not(.plain):not(.outline) {
124
+ color: var(--color-text);
125
+ background-color: var(--color-bg-green-raised);
126
+
127
+ svg,
128
+ path {
129
+ color: var(--color-text);
130
+ }
131
+ }
132
+
133
+ &.outline {
134
+ border-color: var(--color-bg-green-lowered);
135
+ }
136
+
137
+ &:not(.plain):not(.disabled):not(.plain):hover,
138
+ &:hover:not(.disabled) {
139
+ background-color: var(--color-bg-green-lowered);
140
+ }
141
+ }
142
+
143
+ &.vui-button-variant-gray {
144
+ &:not(.plain):not(.outline) {
145
+ color: var(--color-text);
146
+ background-color: var(--color-button-gray);
147
+
148
+ svg,
149
+ path {
150
+ color: var(--color-text);
151
+ }
152
+ }
153
+
154
+ &.outline {
155
+ border-color: var(--color-button-gray-hover);
156
+ }
157
+
158
+ &:not(.plain):not(.disabled):not(.plain):hover,
159
+ &:hover:not(.disabled) {
160
+ background-color: var(--color-button-gray-hover);
161
+ }
162
+ }
163
+
164
+ &.vui-button-variant-fill {
165
+ &:not(.plain):not(.outline) {
166
+ color: var(--color-text-invert);
167
+ background-color: var(--color-button-fill);
168
+
169
+ svg,
170
+ path {
171
+ color: var(--color-text-invert);
172
+ }
173
+ }
174
+
175
+ &.outline {
176
+ border-color: var(--color-button-fill-hover);
177
+
178
+ &:hover {
179
+ color: var(--color-text-invert);
180
+
181
+ svg,
182
+ path {
183
+ color: var(--color-text-invert);
184
+ }
185
+ }
186
+ }
187
+
188
+ &:not(.plain):not(.disabled):not(.plain):hover,
189
+ &:hover:not(.disabled) {
190
+ background-color: var(--color-button-fill-hover);
191
+
192
+ &.plain {
193
+ color: var(--color-text-invert);
194
+
195
+ svg,
196
+ path {
197
+ color: var(--color-text-invert);
198
+ }
199
+ }
200
+ }
201
+ }
202
+
203
+ &.vui-button-variant-accent {
204
+ &:not(.plain):not(.outline) {
205
+ color: var(--color-text);
206
+ background-color: var(--color-bg-accent-raised);
207
+
208
+ svg,
209
+ path {
210
+ color: var(--color-text);
211
+ }
212
+ }
213
+
214
+ &.outline {
215
+ border-color: var(--color-bg-accent-lowered);
216
+ }
217
+
218
+ &:not(.plain):not(.disabled):not(.plain):hover,
219
+ &:hover:not(.disabled) {
220
+ background-color: var(--color-bg-accent-lowered);
221
+ }
222
+ }
223
+
224
+ &.vui-button-variant-link {
225
+ color: var(--color-text);
226
+ background: transparent;
227
+ text-underline-offset: 4px;
228
+ cursor: pointer;
229
+
230
+ &:not(:disabled).active,
231
+ &:not(:disabled):hover {
232
+ text-decoration: underline;
233
+ }
234
+ }
235
+ }
236
+
237
+ :root.light {
238
+ .vui-button {
239
+ &.vui-button-variant-danger {
240
+ &:not(.plain):not(.outline) {
241
+ color: var(--color-text-invert);
242
+
243
+ svg,
244
+ path {
245
+ color: var(--color-text-invert);
246
+ }
247
+ }
248
+
249
+ &.outline:hover {
250
+ color: var(--color-text-invert);
251
+
252
+ svg,
253
+ path {
254
+ color: var(--color-text-invert);
255
+ }
256
+ }
257
+ }
258
+
259
+ &.vui-button-variant-success {
260
+ &:not(.plain):not(.outline) {
261
+ color: var(--color-text-invert);
262
+
263
+ svg,
264
+ path {
265
+ color: var(--color-text-invert);
266
+ }
267
+ }
268
+
269
+ &.outline:hover {
270
+ color: var(--color-text-invert);
271
+
272
+ svg,
273
+ path {
274
+ color: var(--color-text-invert);
275
+ }
276
+ }
277
+ }
278
+ }
279
+ }
@@ -1,28 +1,28 @@
1
- <script setup lang='ts'>
2
- import type { Space } from '../../shared/types'
3
- import Flex from '../Flex/Flex.vue'
4
- import './button-group.scss'
5
-
6
- interface Props {
7
- vertical?: boolean
8
- gap?: Space | number
9
- }
10
-
11
- const {
12
- vertical,
13
- gap = 0,
14
- } = defineProps<Props>()
15
- </script>
16
-
17
- <template>
18
- <Flex
19
- :row="!vertical"
20
- :column="vertical"
21
- class="vui-button-group"
22
- :class="{ vertical }"
23
- :gap
24
- inline
25
- >
26
- <slot />
27
- </Flex>
28
- </template>
1
+ <script setup lang='ts'>
2
+ import type { Space } from '../../shared/types'
3
+ import Flex from '../Flex/Flex.vue'
4
+ import './button-group.scss'
5
+
6
+ interface Props {
7
+ vertical?: boolean
8
+ gap?: Space | number
9
+ }
10
+
11
+ const {
12
+ vertical,
13
+ gap = 0,
14
+ } = defineProps<Props>()
15
+ </script>
16
+
17
+ <template>
18
+ <Flex
19
+ :row="!vertical"
20
+ :column="vertical"
21
+ class="vui-button-group"
22
+ :class="{ vertical }"
23
+ :gap
24
+ inline
25
+ >
26
+ <slot />
27
+ </Flex>
28
+ </template>