@dolanske/vui 1.0.4 → 1.1.1

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,82 +1,82 @@
1
- .vui-accordion {
2
- width: 100%;
3
- transition: var(--transition);
4
- border-bottom: 1px solid var(--color-border);
5
- padding-bottom: 0;
6
-
7
- &.is-card {
8
- border: 1px solid var(--color-border);
9
- border-radius: var(--border-radius-m);
10
-
11
- &.open {
12
- padding-bottom: 0;
13
-
14
- .vui-accordion-header {
15
- border-block-width: 1px;
16
- border-bottom-left-radius: 0;
17
- border-bottom-right-radius: 0;
18
- }
19
- }
20
-
21
- .vui-accordion-header {
22
- padding-inline: var(--space-m);
23
- border-bottom: 0px solid var(--color-border);
24
- text-decoration: inherit;
25
- border-radius: var(--border-radius-m);
26
-
27
- &:hover {
28
- text-decoration: inherit;
29
- text-underline-offset: inherit;
30
- background-color: var(--color-button-gray);
31
- }
32
- }
33
-
34
- .vui-accordtion-content-inner {
35
- padding: var(--space-m);
36
- }
37
- }
38
-
39
- &.open {
40
- padding-bottom: var(--space-m);
41
-
42
- .vui-accordion-header svg {
43
- transform: rotate(180deg);
44
- }
45
-
46
- .vui-accordion-content {
47
- visibility: visible;
48
- }
49
- }
50
-
51
- .vui-accordion-header {
52
- display: flex;
53
- width: 100%;
54
- justify-content: space-between;
55
- align-items: center;
56
- padding: var(--space-m) 0;
57
- color: pointer;
58
- font-size: var(--font-size-m);
59
- font-weight: 500;
60
- color: var(--color-text);
61
- border-radius: var(--border-radius-m);
62
-
63
- &:hover {
64
- text-decoration: underline;
65
- text-underline-offset: 4px;
66
- }
67
-
68
- svg {
69
- transition: var(--transition);
70
- color: var(--color-text-light);
71
- }
72
- }
73
-
74
- .vui-accordion-content {
75
- transition: var(--transition-slow);
76
- width: 100%;
77
- max-height: 0;
78
- overflow: hidden;
79
- visibility: hidden;
80
- font-size: var(--font-size-m);
81
- }
82
- }
1
+ .vui-accordion {
2
+ width: 100%;
3
+ transition: var(--transition);
4
+ border-bottom: 1px solid var(--color-border);
5
+ padding-bottom: 0;
6
+
7
+ &.is-card {
8
+ border: 1px solid var(--color-border);
9
+ border-radius: var(--border-radius-m);
10
+
11
+ &.open {
12
+ padding-bottom: 0;
13
+
14
+ .vui-accordion-header {
15
+ border-block-width: 1px;
16
+ border-bottom-left-radius: 0;
17
+ border-bottom-right-radius: 0;
18
+ }
19
+ }
20
+
21
+ .vui-accordion-header {
22
+ padding-inline: var(--space-m);
23
+ border-bottom: 0px solid var(--color-border);
24
+ text-decoration: inherit;
25
+ border-radius: var(--border-radius-m);
26
+
27
+ &:hover {
28
+ text-decoration: inherit;
29
+ text-underline-offset: inherit;
30
+ background-color: var(--color-button-gray);
31
+ }
32
+ }
33
+
34
+ .vui-accordtion-content-inner {
35
+ padding: var(--space-m);
36
+ }
37
+ }
38
+
39
+ &.open {
40
+ padding-bottom: var(--space-m);
41
+
42
+ .vui-accordion-header svg {
43
+ transform: rotate(180deg);
44
+ }
45
+
46
+ .vui-accordion-content {
47
+ visibility: visible;
48
+ }
49
+ }
50
+
51
+ .vui-accordion-header {
52
+ display: flex;
53
+ width: 100%;
54
+ justify-content: space-between;
55
+ align-items: center;
56
+ padding: var(--space-m) 0;
57
+ color: pointer;
58
+ font-size: var(--font-size-m);
59
+ font-weight: 500;
60
+ color: var(--color-text);
61
+ border-radius: var(--border-radius-m);
62
+
63
+ &:hover {
64
+ text-decoration: underline;
65
+ text-underline-offset: 4px;
66
+ }
67
+
68
+ svg {
69
+ transition: var(--transition);
70
+ color: var(--color-text-light);
71
+ }
72
+ }
73
+
74
+ .vui-accordion-content {
75
+ transition: var(--transition-slow);
76
+ width: 100%;
77
+ max-height: 0;
78
+ overflow: hidden;
79
+ visibility: hidden;
80
+ font-size: var(--font-size-m);
81
+ }
82
+ }
@@ -1,59 +1,59 @@
1
- <script setup lang="ts">
2
- import { Icon } from '@iconify/vue'
3
- import { computed } from 'vue'
4
- import './alert.scss'
5
-
6
- interface Props {
7
- variant?: 'neutral' | 'info' | 'success' | 'warning' | 'danger'
8
- /**
9
- * Override the variant's default icon
10
- */
11
- icon?: string
12
- /**
13
- * Setting a title and description will use slightly different styling other
14
- * than slots.
15
- */
16
- title?: string
17
- /**
18
- * Use strong color
19
- */
20
- filled?: boolean
21
- description?: string
22
- }
23
-
24
- const {
25
- icon = 'ph:chat-teardrop',
26
- variant = 'neutral',
27
- title,
28
- description,
29
- filled,
30
- } = defineProps<Props>()
31
-
32
- const actualIcon = computed(() => {
33
- switch (variant) {
34
- case 'info': return 'ph:info'
35
- case 'success': return 'ph:check-circle'
36
- case 'warning': return 'ph:warning'
37
- case 'danger': return 'ph:warning-diamond'
38
- default: return icon
39
- }
40
- })
41
- </script>
42
-
43
- <template>
44
- <div class="vui-alert" :class="[{ filled }, `vui-alert-variant-${variant}`]">
45
- <Icon v-if="actualIcon" class="vui-alert-icon" :icon="actualIcon" />
46
- <div v-if="$slots.default && !title" class="vui-alert-content">
47
- <slot />
48
- </div>
49
- <div v-else class="vui-alert-default-content">
50
- <strong v-if="title">{{ title }}</strong>
51
- <p v-if="description">
52
- {{ description }}
53
- </p>
54
- <slot v-else-if="$slots.default" />
55
- </div>
56
-
57
- <slot name="end" />
58
- </div>
59
- </template>
1
+ <script setup lang="ts">
2
+ import { Icon } from '@iconify/vue'
3
+ import { computed } from 'vue'
4
+ import './alert.scss'
5
+
6
+ interface Props {
7
+ variant?: 'neutral' | 'info' | 'success' | 'warning' | 'danger'
8
+ /**
9
+ * Override the variant's default icon
10
+ */
11
+ icon?: string
12
+ /**
13
+ * Setting a title and description will use slightly different styling other
14
+ * than slots.
15
+ */
16
+ title?: string
17
+ /**
18
+ * Use strong color
19
+ */
20
+ filled?: boolean
21
+ description?: string
22
+ }
23
+
24
+ const {
25
+ icon = 'ph:chat-teardrop',
26
+ variant = 'neutral',
27
+ title,
28
+ description,
29
+ filled,
30
+ } = defineProps<Props>()
31
+
32
+ const actualIcon = computed(() => {
33
+ switch (variant) {
34
+ case 'info': return 'ph:info'
35
+ case 'success': return 'ph:check-circle'
36
+ case 'warning': return 'ph:warning'
37
+ case 'danger': return 'ph:warning-diamond'
38
+ default: return icon
39
+ }
40
+ })
41
+ </script>
42
+
43
+ <template>
44
+ <div class="vui-alert" :class="[{ filled }, `vui-alert-variant-${variant}`]">
45
+ <Icon v-if="actualIcon" class="vui-alert-icon" :icon="actualIcon" />
46
+ <div v-if="$slots.default && !title" class="vui-alert-content">
47
+ <slot />
48
+ </div>
49
+ <div v-else class="vui-alert-default-content">
50
+ <strong v-if="title">{{ title }}</strong>
51
+ <p v-if="description">
52
+ {{ description }}
53
+ </p>
54
+ <slot v-else-if="$slots.default" />
55
+ </div>
56
+
57
+ <slot name="end" />
58
+ </div>
59
+ </template>
@@ -1,161 +1,161 @@
1
- .vui-alert {
2
- display: flex;
3
- gap: var(--space-s);
4
- border-radius: var(--border-radius-m);
5
- padding: var(--space-s);
6
- font-size: var(--font-size-m);
7
- flex-wrap: nowrap;
8
- align-items: center;
9
- border: 1px solid var(--color-border);
10
-
11
- .vui-alert-icon {
12
- width: 22px;
13
- height: 22px;
14
- }
15
-
16
- .vui-alert-content,
17
- .vui-alert-default-content {
18
- flex: 1;
19
- }
20
-
21
- .vui-alert-default-content {
22
- strong {
23
- display: block;
24
- font-size: var(--font-size-m);
25
- margin-bottom: 2px;
26
- }
27
-
28
- p {
29
- font-size: var(--font-size-s);
30
- color: var(--color-text-light);
31
- }
32
- }
33
-
34
- .vui-alert-content {
35
- font-size: var(--font-size-m);
36
- font-weight: 400;
37
- }
38
-
39
- &.filled {
40
- border: none !important;
41
- }
42
-
43
- &.vui-alert-variant-neutral {
44
- .vui-alert-icon path {
45
- color: var(--color-text-light);
46
- }
47
-
48
- &.filled {
49
- background-color: var(--color-bg-raised);
50
- }
51
- }
52
-
53
- &.vui-alert-variant-info {
54
- .vui-alert-icon path {
55
- color: var(--color-text-blue);
56
- }
57
-
58
- &.filled {
59
- background-color: hsla(from var(--color-bg-blue-lowered) h s l / 0.5);
60
- }
61
- }
62
-
63
- &.vui-alert-variant-success {
64
- .vui-alert-icon path {
65
- color: var(--color-text-green);
66
- }
67
-
68
- &.filled {
69
- background-color: hsla(from var(--color-bg-green-lowered) h s l / 0.4);
70
- }
71
- }
72
-
73
- &.vui-alert-variant-warning {
74
- .vui-alert-icon path {
75
- color: var(--color-text-yellow);
76
- }
77
-
78
- &.filled {
79
- background-color: hsla(from var(--color-bg-yellow-lowered) h s l / 0.6);
80
- }
81
- }
82
-
83
- &.vui-alert-variant-danger {
84
- .vui-alert-icon path {
85
- color: var(--color-text-red);
86
- }
87
-
88
- &.filled {
89
- background-color: hsla(from var(--color-bg-red-lowered) h s l / 0.5);
90
- }
91
- }
92
- }
93
-
94
- :root.light {
95
- .vui-alert.filled {
96
- border: none;
97
-
98
- &.vui-alert-variant-neutral {
99
- background-color: var(--color-bg-medium);
100
- }
101
-
102
- &.vui-alert-variant-danger {
103
- background-color: hsla(from var(--color-bg-red-raised) h s l / 0.15);
104
- }
105
-
106
- &.vui-alert-variant-warning {
107
- background-color: hsla(from var(--color-bg-yellow-raised) h s l / 0.2);
108
- }
109
-
110
- &.vui-alert-variant-success {
111
- background-color: hsla(from var(--color-bg-green-raised) h s l / 0.15);
112
- }
113
-
114
- &.vui-alert-variant-info {
115
- background-color: hsla(from var(--color-bg-blue-raised) h s l / 0.15);
116
- }
117
- }
118
-
119
- // .vui-alert.vui-alert-variant-success:not(.filled, .outline) {
120
- // background-color: hsla(from var(--color-text-green) h s l / 0.15);
121
- // }
122
-
123
- // .vui-alert.vui-alert-variant-danger .vui-alert-icon path {
124
- // color: var(--color-border-red);
125
- // }
126
-
127
- // .vui-alert.vui-alert-variant-warning .vui-alert-icon path {
128
- // color: var(--color-border-yellow);
129
- // }
130
-
131
- // .vui-alert.vui-alert-variant-success .vui-alert-icon path {
132
- // color: var(--color-border-green);
133
- // }
134
-
135
- // .vui-alert.vui-alert-variant-info .vui-alert-icon path {
136
- // color: var(--color-border-blue);
137
- // }
138
-
139
- // .vui-alert {
140
- // &.filled {
141
- // &.vui-alert-variant-danger .vui-alert-icon path,
142
- // &.vui-alert-variant-warning .vui-alert-icon path,
143
- // &.vui-alert-variant-success .vui-alert-icon path,
144
- // &.vui-alert-variant-info .vui-alert-icon path {
145
- // color: var(--color-text-light);
146
- // }
147
-
148
- // strong,
149
- // p {
150
- // color: var(--color-text);
151
- // }
152
- // }
153
- // }
154
-
155
- // .vui-alert.filled.vui-alert-variant-danger .vui-alert-icon path,
156
- // .vui-alert.filled.vui-alert-variant-warning .vui-alert-icon path,
157
- // .vui-alert.filled.vui-alert-variant-success .vui-alert-icon path,
158
- // .vui-alert.filled.vui-alert-variant-info .vui-alert-icon path {
159
- // color: var(--color-text-light);
160
- // }
161
- }
1
+ .vui-alert {
2
+ display: flex;
3
+ gap: var(--space-s);
4
+ border-radius: var(--border-radius-m);
5
+ padding: var(--space-s);
6
+ font-size: var(--font-size-m);
7
+ flex-wrap: nowrap;
8
+ align-items: center;
9
+ border: 1px solid var(--color-border);
10
+
11
+ .vui-alert-icon {
12
+ width: 22px;
13
+ height: 22px;
14
+ }
15
+
16
+ .vui-alert-content,
17
+ .vui-alert-default-content {
18
+ flex: 1;
19
+ }
20
+
21
+ .vui-alert-default-content {
22
+ strong {
23
+ display: block;
24
+ font-size: var(--font-size-m);
25
+ margin-bottom: 2px;
26
+ }
27
+
28
+ p {
29
+ font-size: var(--font-size-s);
30
+ color: var(--color-text-light);
31
+ }
32
+ }
33
+
34
+ .vui-alert-content {
35
+ font-size: var(--font-size-m);
36
+ font-weight: 400;
37
+ }
38
+
39
+ &.filled {
40
+ border: none !important;
41
+ }
42
+
43
+ &.vui-alert-variant-neutral {
44
+ .vui-alert-icon path {
45
+ color: var(--color-text-light);
46
+ }
47
+
48
+ &.filled {
49
+ background-color: var(--color-bg-raised);
50
+ }
51
+ }
52
+
53
+ &.vui-alert-variant-info {
54
+ .vui-alert-icon path {
55
+ color: var(--color-text-blue);
56
+ }
57
+
58
+ &.filled {
59
+ background-color: hsla(from var(--color-bg-blue-lowered) h s l / 0.5);
60
+ }
61
+ }
62
+
63
+ &.vui-alert-variant-success {
64
+ .vui-alert-icon path {
65
+ color: var(--color-text-green);
66
+ }
67
+
68
+ &.filled {
69
+ background-color: hsla(from var(--color-bg-green-lowered) h s l / 0.4);
70
+ }
71
+ }
72
+
73
+ &.vui-alert-variant-warning {
74
+ .vui-alert-icon path {
75
+ color: var(--color-text-yellow);
76
+ }
77
+
78
+ &.filled {
79
+ background-color: hsla(from var(--color-bg-yellow-lowered) h s l / 0.6);
80
+ }
81
+ }
82
+
83
+ &.vui-alert-variant-danger {
84
+ .vui-alert-icon path {
85
+ color: var(--color-text-red);
86
+ }
87
+
88
+ &.filled {
89
+ background-color: hsla(from var(--color-bg-red-lowered) h s l / 0.5);
90
+ }
91
+ }
92
+ }
93
+
94
+ :root.light {
95
+ .vui-alert.filled {
96
+ border: none;
97
+
98
+ &.vui-alert-variant-neutral {
99
+ background-color: var(--color-bg-medium);
100
+ }
101
+
102
+ &.vui-alert-variant-danger {
103
+ background-color: hsla(from var(--color-bg-red-raised) h s l / 0.15);
104
+ }
105
+
106
+ &.vui-alert-variant-warning {
107
+ background-color: hsla(from var(--color-bg-yellow-raised) h s l / 0.2);
108
+ }
109
+
110
+ &.vui-alert-variant-success {
111
+ background-color: hsla(from var(--color-bg-green-raised) h s l / 0.15);
112
+ }
113
+
114
+ &.vui-alert-variant-info {
115
+ background-color: hsla(from var(--color-bg-blue-raised) h s l / 0.15);
116
+ }
117
+ }
118
+
119
+ // .vui-alert.vui-alert-variant-success:not(.filled, .outline) {
120
+ // background-color: hsla(from var(--color-text-green) h s l / 0.15);
121
+ // }
122
+
123
+ // .vui-alert.vui-alert-variant-danger .vui-alert-icon path {
124
+ // color: var(--color-border-red);
125
+ // }
126
+
127
+ // .vui-alert.vui-alert-variant-warning .vui-alert-icon path {
128
+ // color: var(--color-border-yellow);
129
+ // }
130
+
131
+ // .vui-alert.vui-alert-variant-success .vui-alert-icon path {
132
+ // color: var(--color-border-green);
133
+ // }
134
+
135
+ // .vui-alert.vui-alert-variant-info .vui-alert-icon path {
136
+ // color: var(--color-border-blue);
137
+ // }
138
+
139
+ // .vui-alert {
140
+ // &.filled {
141
+ // &.vui-alert-variant-danger .vui-alert-icon path,
142
+ // &.vui-alert-variant-warning .vui-alert-icon path,
143
+ // &.vui-alert-variant-success .vui-alert-icon path,
144
+ // &.vui-alert-variant-info .vui-alert-icon path {
145
+ // color: var(--color-text-light);
146
+ // }
147
+
148
+ // strong,
149
+ // p {
150
+ // color: var(--color-text);
151
+ // }
152
+ // }
153
+ // }
154
+
155
+ // .vui-alert.filled.vui-alert-variant-danger .vui-alert-icon path,
156
+ // .vui-alert.filled.vui-alert-variant-warning .vui-alert-icon path,
157
+ // .vui-alert.filled.vui-alert-variant-success .vui-alert-icon path,
158
+ // .vui-alert.filled.vui-alert-variant-info .vui-alert-icon path {
159
+ // color: var(--color-text-light);
160
+ // }
161
+ }