@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,90 +1,90 @@
1
- <script setup lang="ts">
2
- import type { VNode } from 'vue'
3
- import type { TabProps } from './Tab.vue'
4
- import { useResizeObserver } from '@vueuse/core'
5
- import { onMounted, useTemplateRef, watch } from 'vue'
6
- import './tabs.scss'
7
-
8
- interface Props {
9
- variant?: 'default' | 'filled'
10
- expand?: boolean
11
- disabled?: boolean
12
- }
13
-
14
- const {
15
- expand,
16
- disabled,
17
- variant = 'default',
18
- } = defineProps<Props>()
19
-
20
- const slots = defineSlots<{
21
- default: () => Array<VNode & { props: TabProps }>
22
- start: unknown
23
- end: unknown
24
- }>()
25
-
26
- const active = defineModel()
27
-
28
- // Underline calculation
29
- const underlineRef = useTemplateRef('underline')
30
- const tabsRef = useTemplateRef('tabs')
31
-
32
- function computeUnderlinePosition() {
33
- if (!window)
34
- return
35
-
36
- if (tabsRef.value && underlineRef.value) {
37
- const activeBounds = tabsRef.value.querySelector('.vui-tab.active')?.getBoundingClientRect()
38
- const parentBounds = tabsRef.value.getBoundingClientRect()
39
- if (!activeBounds || !parentBounds)
40
- return
41
-
42
- underlineRef.value.style.width = `${activeBounds.width}px`
43
- underlineRef.value.style.left = `${activeBounds.left - parentBounds.left}px`
44
- }
45
- }
46
-
47
- onMounted(() => {
48
- useResizeObserver(tabsRef, computeUnderlinePosition)
49
-
50
- watch(
51
- [active, () => expand],
52
- computeUnderlinePosition,
53
- {
54
- immediate: true,
55
- flush: 'post',
56
- },
57
- )
58
- })
59
- </script>
60
-
61
- <template>
62
- <div
63
- ref="tabs"
64
- class="vui-tabs"
65
- role="tablist"
66
- :class="[
67
- { expand, disabled },
68
- variant === 'default'
69
- ? ''
70
- : `vui-tabs-variant-${variant}`,
71
- ]"
72
- >
73
- <slot name="start" />
74
- <Component
75
- :is="vnode"
76
- v-for="vnode of slots.default()"
77
- :key="vnode.props.label"
78
- :class="{ active: vnode.props.label === active }"
79
- @click="active = vnode.props.label"
80
- />
81
- <template v-if="slots.end">
82
- <div v-if="!!!expand" class="flex-1" />
83
- <slot name="end" />
84
- </template>
85
-
86
- <Transition name="fade" appear>
87
- <div ref="underline" class="vui-tab-underline" />
88
- </Transition>
89
- </div>
90
- </template>
1
+ <script setup lang="ts">
2
+ import type { VNode } from 'vue'
3
+ import type { TabProps } from './Tab.vue'
4
+ import { useResizeObserver } from '@vueuse/core'
5
+ import { onMounted, useTemplateRef, watch } from 'vue'
6
+ import './tabs.scss'
7
+
8
+ interface Props {
9
+ variant?: 'default' | 'filled'
10
+ expand?: boolean
11
+ disabled?: boolean
12
+ }
13
+
14
+ const {
15
+ expand,
16
+ disabled,
17
+ variant = 'default',
18
+ } = defineProps<Props>()
19
+
20
+ const slots = defineSlots<{
21
+ default: () => Array<VNode & { props: TabProps }>
22
+ start: unknown
23
+ end: unknown
24
+ }>()
25
+
26
+ const active = defineModel()
27
+
28
+ // Underline calculation
29
+ const underlineRef = useTemplateRef('underline')
30
+ const tabsRef = useTemplateRef('tabs')
31
+
32
+ function computeUnderlinePosition() {
33
+ if (!window)
34
+ return
35
+
36
+ if (tabsRef.value && underlineRef.value) {
37
+ const activeBounds = tabsRef.value.querySelector('.vui-tab.active')?.getBoundingClientRect()
38
+ const parentBounds = tabsRef.value.getBoundingClientRect()
39
+ if (!activeBounds || !parentBounds)
40
+ return
41
+
42
+ underlineRef.value.style.width = `${activeBounds.width}px`
43
+ underlineRef.value.style.left = `${activeBounds.left - parentBounds.left}px`
44
+ }
45
+ }
46
+
47
+ onMounted(() => {
48
+ useResizeObserver(tabsRef, computeUnderlinePosition)
49
+
50
+ watch(
51
+ [active, () => expand],
52
+ computeUnderlinePosition,
53
+ {
54
+ immediate: true,
55
+ flush: 'post',
56
+ },
57
+ )
58
+ })
59
+ </script>
60
+
61
+ <template>
62
+ <div
63
+ ref="tabs"
64
+ class="vui-tabs"
65
+ role="tablist"
66
+ :class="[
67
+ { expand, disabled },
68
+ variant === 'default'
69
+ ? ''
70
+ : `vui-tabs-variant-${variant}`,
71
+ ]"
72
+ >
73
+ <slot name="start" />
74
+ <Component
75
+ :is="vnode"
76
+ v-for="vnode of slots.default()"
77
+ :key="vnode.props.label"
78
+ :class="{ active: vnode.props.label === active }"
79
+ @click="active = vnode.props.label"
80
+ />
81
+ <template v-if="slots.end">
82
+ <div v-if="!!!expand" class="flex-1" />
83
+ <slot name="end" />
84
+ </template>
85
+
86
+ <Transition name="fade" appear>
87
+ <div ref="underline" class="vui-tab-underline" />
88
+ </Transition>
89
+ </div>
90
+ </template>
@@ -1,87 +1,87 @@
1
- .vui-tabs {
2
- display: flex;
3
- width: 100%;
4
- gap: 4px;
5
- align-items: center;
6
- border-bottom: 1px solid var(--color-border);
7
- position: relative;
8
-
9
- &.vui-tabs-variant-filled {
10
- background-color: var(--color-bg-raised);
11
- border-bottom: none;
12
- z-index: 1;
13
- border-radius: var(--border-radius-m);
14
- padding-inline: 4px;
15
-
16
- .vui-tab-underline {
17
- border-bottom: none;
18
- background-color: var(--color-bg-lowered);
19
- top: 4px;
20
- bottom: 4px;
21
- z-index: -1;
22
- border-radius: var(--border-radius-m);
23
- }
24
- }
25
-
26
- &.disabled .vui-tab,
27
- .vui-tab.disabled {
28
- pointer-events: none;
29
- color: var(--color-text-lighter);
30
-
31
- &.active {
32
- color: var(--color-text-lighter) !important;
33
- }
34
- }
35
-
36
- &.disabled {
37
- .vui-tab-underline {
38
- border-color: var(--color-text-lighter);
39
- }
40
- }
41
-
42
- &.expand .vui-tab {
43
- flex: 1;
44
- }
45
-
46
- .vui-tab {
47
- display: flex;
48
- height: 40px;
49
- // place-content: center;
50
- align-items: center;
51
- justify-content: center;
52
- padding: 0 10px;
53
- font-size: var(--font-size-m);
54
- position: relative;
55
- color: var(--color-text-lighter);
56
- font-weight: var(--font-weight-medium);
57
- transition: var(--transition);
58
- cursor: default;
59
- gap: var(--space-xs);
60
- border-radius: var(--border-radius-m);
61
-
62
- svg {
63
- width: 20px;
64
- height: 20px;
65
- color: var(--color-text-light);
66
- }
67
-
68
- &:hover,
69
- &.active {
70
- color: var(--color-text);
71
- }
72
- }
73
-
74
- .vui-tab-underline {
75
- transition: var(--transition);
76
- display: block;
77
- border-bottom: 2px solid var(--color-text);
78
- position: absolute;
79
- bottom: 0;
80
- }
81
- }
82
-
83
- :root.light {
84
- .vui-tabs.vui-tabs-variant-filled {
85
- background-color: var(--color-bg-medium);
86
- }
87
- }
1
+ .vui-tabs {
2
+ display: flex;
3
+ width: 100%;
4
+ gap: 4px;
5
+ align-items: center;
6
+ border-bottom: 1px solid var(--color-border);
7
+ position: relative;
8
+
9
+ &.vui-tabs-variant-filled {
10
+ background-color: var(--color-bg-raised);
11
+ border-bottom: none;
12
+ z-index: 1;
13
+ border-radius: var(--border-radius-m);
14
+ padding-inline: 4px;
15
+
16
+ .vui-tab-underline {
17
+ border-bottom: none;
18
+ background-color: var(--color-bg-lowered);
19
+ top: 4px;
20
+ bottom: 4px;
21
+ z-index: -1;
22
+ border-radius: var(--border-radius-m);
23
+ }
24
+ }
25
+
26
+ &.disabled .vui-tab,
27
+ .vui-tab.disabled {
28
+ pointer-events: none;
29
+ color: var(--color-text-lighter);
30
+
31
+ &.active {
32
+ color: var(--color-text-lighter) !important;
33
+ }
34
+ }
35
+
36
+ &.disabled {
37
+ .vui-tab-underline {
38
+ border-color: var(--color-text-lighter);
39
+ }
40
+ }
41
+
42
+ &.expand .vui-tab {
43
+ flex: 1;
44
+ }
45
+
46
+ .vui-tab {
47
+ display: flex;
48
+ height: 40px;
49
+ // place-content: center;
50
+ align-items: center;
51
+ justify-content: center;
52
+ padding: 0 10px;
53
+ font-size: var(--font-size-m);
54
+ position: relative;
55
+ color: var(--color-text-lighter);
56
+ font-weight: var(--font-weight-medium);
57
+ transition: var(--transition);
58
+ cursor: default;
59
+ gap: var(--space-xs);
60
+ border-radius: var(--border-radius-m);
61
+
62
+ svg {
63
+ width: 20px;
64
+ height: 20px;
65
+ color: var(--color-text-light);
66
+ }
67
+
68
+ &:hover,
69
+ &.active {
70
+ color: var(--color-text);
71
+ }
72
+ }
73
+
74
+ .vui-tab-underline {
75
+ transition: var(--transition);
76
+ display: block;
77
+ border-bottom: 2px solid var(--color-text);
78
+ position: absolute;
79
+ bottom: 0;
80
+ }
81
+ }
82
+
83
+ :root.light {
84
+ .vui-tabs.vui-tabs-variant-filled {
85
+ background-color: var(--color-bg-medium);
86
+ }
87
+ }
@@ -1,52 +1,52 @@
1
- <script setup lang="ts">
2
- import Button from '../Button/Button.vue'
3
- import { toasts } from './toast'
4
- import './toast.scss'
5
- </script>
6
-
7
- <template>
8
- <Teleport to="body">
9
- <div class="vui-toast-wrapper">
10
- <TransitionGroup name="toast" tag="ul" class="vui-toast-list">
11
- <li v-for="[toastId, toast] in toasts" :key="toastId" class="vui-toast-item">
12
- <div class="vui-toast-item-content">
13
- <strong>{{ toast.title }}</strong>
14
- <p v-if="toast.description">
15
- {{ toast.description }}
16
- </p>
17
- <Component
18
- :is="toast.body"
19
- v-if="toast.body"
20
- v-bind="{ data: toast.bodyProps, toastId }"
21
- />
22
- </div>
23
- <Button v-if="toast.action" @click="toast.action.handler(toast.id)">
24
- {{ toast.action.label }}
25
- </Button>
26
- </li>
27
- </TransitionGroup>
28
- </div>
29
- </Teleport>
30
- </template>
31
-
32
- <style scoped>
33
- .toast-move,
34
- .toast-enter-active,
35
- .toast-leave-active {
36
- transition: var(--transition);
37
- }
38
-
39
- .toast-enter-from {
40
- opacity: 0;
41
- transform: translateY(24px) scale(0.95);
42
- }
43
-
44
- .toast-leave-to {
45
- opacity: 0;
46
- transform: translateY(-24px) scale(0.95);
47
- }
48
-
49
- .toast-leave-active {
50
- position: absolute;
51
- }
52
- </style>
1
+ <script setup lang="ts">
2
+ import Button from '../Button/Button.vue'
3
+ import { toasts } from './toast'
4
+ import './toast.scss'
5
+ </script>
6
+
7
+ <template>
8
+ <Teleport to="body">
9
+ <div class="vui-toast-wrapper">
10
+ <TransitionGroup name="toast" tag="ul" class="vui-toast-list">
11
+ <li v-for="[toastId, toast] in toasts" :key="toastId" class="vui-toast-item">
12
+ <div class="vui-toast-item-content">
13
+ <strong>{{ toast.title }}</strong>
14
+ <p v-if="toast.description">
15
+ {{ toast.description }}
16
+ </p>
17
+ <Component
18
+ :is="toast.body"
19
+ v-if="toast.body"
20
+ v-bind="{ data: toast.bodyProps, toastId }"
21
+ />
22
+ </div>
23
+ <Button v-if="toast.action" @click="toast.action.handler(toast.id)">
24
+ {{ toast.action.label }}
25
+ </Button>
26
+ </li>
27
+ </TransitionGroup>
28
+ </div>
29
+ </Teleport>
30
+ </template>
31
+
32
+ <style scoped>
33
+ .toast-move,
34
+ .toast-enter-active,
35
+ .toast-leave-active {
36
+ transition: var(--transition);
37
+ }
38
+
39
+ .toast-enter-from {
40
+ opacity: 0;
41
+ transform: translateY(24px) scale(0.95);
42
+ }
43
+
44
+ .toast-leave-to {
45
+ opacity: 0;
46
+ transform: translateY(-24px) scale(0.95);
47
+ }
48
+
49
+ .toast-leave-active {
50
+ position: absolute;
51
+ }
52
+ </style>
@@ -1,45 +1,45 @@
1
- .vui-toast-wrapper {
2
- position: fixed;
3
- bottom: 32px;
4
- right: 32px;
5
- width: 100%;
6
- max-width: 392px;
7
-
8
- .vui-toast-list {
9
- display: flex;
10
- flex-direction: column;
11
- gap: var(--space-xs);
12
-
13
- .vui-toast-item {
14
- display: flex;
15
- border: 1px solid var(--color-border);
16
- border-radius: var(--border-radius-m);
17
- padding: var(--space-m);
18
- background-color: var(--color-bg-lowered);
19
- width: 100%;
20
- align-items: center;
21
- gap: var(--space-m);
22
- box-shadow: var(--box-shadow);
23
-
24
- .vui-toast-item-content {
25
- flex: 1;
26
-
27
- strong {
28
- color: var(--color-text);
29
- margin-bottom: var(--space-xs);
30
- display: block;
31
- font-size: var(--font-size-m);
32
-
33
- &:only-child {
34
- margin: 0;
35
- }
36
- }
37
-
38
- p {
39
- color: var(--color-text-lighter);
40
- font-size: var(--font-size-s);
41
- }
42
- }
43
- }
44
- }
45
- }
1
+ .vui-toast-wrapper {
2
+ position: fixed;
3
+ bottom: 32px;
4
+ right: 32px;
5
+ width: 100%;
6
+ max-width: 392px;
7
+
8
+ .vui-toast-list {
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: var(--space-xs);
12
+
13
+ .vui-toast-item {
14
+ display: flex;
15
+ border: 1px solid var(--color-border);
16
+ border-radius: var(--border-radius-m);
17
+ padding: var(--space-m);
18
+ background-color: var(--color-bg-lowered);
19
+ width: 100%;
20
+ align-items: center;
21
+ gap: var(--space-m);
22
+ box-shadow: var(--box-shadow);
23
+
24
+ .vui-toast-item-content {
25
+ flex: 1;
26
+
27
+ strong {
28
+ color: var(--color-text);
29
+ margin-bottom: var(--space-xs);
30
+ display: block;
31
+ font-size: var(--font-size-m);
32
+
33
+ &:only-child {
34
+ margin: 0;
35
+ }
36
+ }
37
+
38
+ p {
39
+ color: var(--color-text-lighter);
40
+ font-size: var(--font-size-s);
41
+ }
42
+ }
43
+ }
44
+ }
45
+ }