@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,54 +1,54 @@
1
- <script setup lang="ts">
2
- import { Icon } from '@iconify/vue'
3
- import { useId } from 'vue'
4
- import './checkbox.scss'
5
-
6
- interface Props {
7
- label?: string
8
- iconOn?: string
9
- iconOff?: string
10
- disabled?: boolean
11
- checked?: boolean
12
- accent?: boolean
13
- }
14
-
15
- const {
16
- label,
17
- // iconOn = theme.value === 'light' ? 'ph:check-square-fill' : 'ph:check-square',
18
- iconOn = 'ph:check-square-fill',
19
- iconOff = 'ph:square',
20
- disabled,
21
- checked: checkedProp,
22
- accent,
23
- } = defineProps<Props>()
24
- const emit = defineEmits<{
25
- change: [checked: boolean]
26
- }>()
27
- const slots = defineSlots()
28
- const checked = defineModel<boolean>()
29
- const id = useId()
30
- </script>
31
-
32
- <template>
33
- <div class="vui-checkbox" :class="{ disabled: !!disabled, checked, accent }">
34
- <input
35
- :id
36
- v-model="checked"
37
- type="checkbox"
38
- :disabled
39
- :checked="checkedProp"
40
- @change="(e) => {
41
- if (disabled) return
42
- emit('change', (e.target as HTMLInputElement).checked)
43
- }"
44
- >
45
- <label :for="id">
46
- <span class="vui-checkbox-icon">
47
- <Icon :icon="checked ? iconOn : iconOff" />
48
- </span>
49
- <p v-if="label || slots.default" class="vui-checkbox-content">
50
- <slot>{{ label }}</slot>
51
- </p>
52
- </label>
53
- </div>
54
- </template>
1
+ <script setup lang="ts">
2
+ import { Icon } from '@iconify/vue'
3
+ import { useId } from 'vue'
4
+ import './checkbox.scss'
5
+
6
+ interface Props {
7
+ label?: string
8
+ iconOn?: string
9
+ iconOff?: string
10
+ disabled?: boolean
11
+ checked?: boolean
12
+ accent?: boolean
13
+ }
14
+
15
+ const {
16
+ label,
17
+ // iconOn = theme.value === 'light' ? 'ph:check-square-fill' : 'ph:check-square',
18
+ iconOn = 'ph:check-square-fill',
19
+ iconOff = 'ph:square',
20
+ disabled,
21
+ checked: checkedProp,
22
+ accent,
23
+ } = defineProps<Props>()
24
+ const emit = defineEmits<{
25
+ change: [checked: boolean]
26
+ }>()
27
+ const slots = defineSlots()
28
+ const checked = defineModel<boolean>()
29
+ const id = useId()
30
+ </script>
31
+
32
+ <template>
33
+ <div class="vui-checkbox" :class="{ disabled: !!disabled, checked, accent }">
34
+ <input
35
+ :id
36
+ v-model="checked"
37
+ type="checkbox"
38
+ :disabled
39
+ :checked="checkedProp"
40
+ @change="(e) => {
41
+ if (disabled) return
42
+ emit('change', (e.target as HTMLInputElement).checked)
43
+ }"
44
+ >
45
+ <label :for="id">
46
+ <span class="vui-checkbox-icon">
47
+ <Icon :icon="checked ? iconOn : iconOff" />
48
+ </span>
49
+ <p v-if="label || slots.default" class="vui-checkbox-content">
50
+ <slot>{{ label }}</slot>
51
+ </p>
52
+ </label>
53
+ </div>
54
+ </template>
@@ -1,80 +1,80 @@
1
- .vui-checkbox {
2
- --checkbox-size: 24px;
3
-
4
- &.checked {
5
- .vui-checkbox-icon svg {
6
- color: var(--color-text);
7
- }
8
-
9
- &.accent .vui-checkbox-icon svg {
10
- color: var(--color-accent);
11
- }
12
- }
13
-
14
- &.disabled {
15
- .vui-checkbox-icon {
16
- opacity: 0.25;
17
- cursor: not-allowed;
18
- }
19
-
20
- input + label .vui-checkbox-content {
21
- opacity: 0.4;
22
- cursor: not-allowed;
23
- }
24
- }
25
-
26
- .vui-checkbox-icon {
27
- width: var(--checkbox-size);
28
- height: var(--checkbox-size);
29
-
30
- svg {
31
- width: 100%;
32
- height: 100%;
33
- color: var(--color-text);
34
- }
35
- }
36
-
37
- input {
38
- width: 1px;
39
- height: 1px;
40
- position: absolute;
41
- overflow: hidden;
42
- outline: none !important;
43
- opacity: 0;
44
-
45
- &:focus-visible + label .vui-checkbox-icon {
46
- outline: 2px solid var(--color-text);
47
- border-radius: var(--border-radius-s);
48
- cursor: default;
49
- }
50
-
51
- & + label {
52
- display: grid;
53
- grid-template-columns: 20px 1fr;
54
- gap: 10px;
55
- font-size: var(--font-size-m);
56
- color: var(--color-text);
57
- user-select: none;
58
- align-items: baseline;
59
-
60
- .vui-checkbox-content {
61
- display: block;
62
-
63
- &:is(p) {
64
- display: flex;
65
- align-items: center;
66
- min-height: var(--checkbox-size);
67
- font-size: var(--font-size-m);
68
- align-self: flex-start;
69
- // line-height: var(--checkbox-size);
70
- }
71
- }
72
- }
73
- }
74
- }
75
-
76
- :root.light {
77
- .vui-checkbox.checked.accent .vui-checkbox-icon svg {
78
- color: var(--color-accent);
79
- }
80
- }
1
+ .vui-checkbox {
2
+ --checkbox-size: 24px;
3
+
4
+ &.checked {
5
+ .vui-checkbox-icon svg {
6
+ color: var(--color-text);
7
+ }
8
+
9
+ &.accent .vui-checkbox-icon svg {
10
+ color: var(--color-accent);
11
+ }
12
+ }
13
+
14
+ &.disabled {
15
+ .vui-checkbox-icon {
16
+ opacity: 0.25;
17
+ cursor: not-allowed;
18
+ }
19
+
20
+ input + label .vui-checkbox-content {
21
+ opacity: 0.4;
22
+ cursor: not-allowed;
23
+ }
24
+ }
25
+
26
+ .vui-checkbox-icon {
27
+ width: var(--checkbox-size);
28
+ height: var(--checkbox-size);
29
+
30
+ svg {
31
+ width: 100%;
32
+ height: 100%;
33
+ color: var(--color-text);
34
+ }
35
+ }
36
+
37
+ input {
38
+ width: 1px;
39
+ height: 1px;
40
+ position: absolute;
41
+ overflow: hidden;
42
+ outline: none !important;
43
+ opacity: 0;
44
+
45
+ &:focus-visible + label .vui-checkbox-icon {
46
+ outline: 2px solid var(--color-text);
47
+ border-radius: var(--border-radius-s);
48
+ cursor: default;
49
+ }
50
+
51
+ & + label {
52
+ display: grid;
53
+ grid-template-columns: 20px 1fr;
54
+ gap: 10px;
55
+ font-size: var(--font-size-m);
56
+ color: var(--color-text);
57
+ user-select: none;
58
+ align-items: baseline;
59
+
60
+ .vui-checkbox-content {
61
+ display: block;
62
+
63
+ &:is(p) {
64
+ display: flex;
65
+ align-items: center;
66
+ min-height: var(--checkbox-size);
67
+ font-size: var(--font-size-m);
68
+ align-self: flex-start;
69
+ // line-height: var(--checkbox-size);
70
+ }
71
+ }
72
+ }
73
+ }
74
+ }
75
+
76
+ :root.light {
77
+ .vui-checkbox.checked.accent .vui-checkbox-icon svg {
78
+ color: var(--color-accent);
79
+ }
80
+ }
@@ -1,91 +1,91 @@
1
- <script setup lang='ts'>
2
- import { autoUpdate, flip, offset, shift, useFloating } from '@floating-ui/vue'
3
- import { Icon } from '@iconify/vue'
4
- import { useClipboard } from '@vueuse/core'
5
- import { computed, onMounted, useSlots, useTemplateRef } from 'vue'
6
- import { isNil } from '../../shared/helpers'
7
- import Flex from '../Flex/Flex.vue'
8
- import './copy-clipboard.scss'
9
-
10
- interface Props {
11
- /**
12
- * Text to copy
13
- */
14
- text: string
15
- /**
16
- * Wether to show a tooltip after successful copy
17
- */
18
- confirm?: string | boolean
19
- /**
20
- * How long will the copy confirmation tooltip be visible in milliseconds.
21
- */
22
- confirmTime?: number
23
- }
24
-
25
- const {
26
- text,
27
- confirm,
28
- confirmTime,
29
- } = defineProps<Props>()
30
-
31
- const {
32
- copy,
33
- copied,
34
- isSupported,
35
- } = useClipboard({
36
- copiedDuring: confirmTime,
37
- })
38
- const slots = useSlots()
39
-
40
- const parsedConfirm = computed(() => {
41
- if (isNil(confirm))
42
- return false
43
- if (confirm === '')
44
- return true
45
- else return confirm
46
- })
47
-
48
- onMounted(() => {
49
- if (!isSupported.value) {
50
- console.error('Clipboard API is not supported. This component will not work')
51
- }
52
-
53
- if (typeof parsedConfirm.value === 'string' && slots.confirm) {
54
- console.warn('[ClipBoard] You are using the \'confirm\' prop and slot. The slot will take precedence.')
55
- }
56
- })
57
-
58
- const anchorRef = useTemplateRef('anchor')
59
- const tooltipRef = useTemplateRef('tooltip')
60
-
61
- const { floatingStyles } = useFloating(anchorRef, tooltipRef, {
62
- whileElementsMounted: autoUpdate,
63
- transform: false,
64
- placement: 'top',
65
- middleware: [
66
- offset(8),
67
- shift(),
68
- flip(),
69
- ],
70
- })
71
- </script>
72
-
73
- <template>
74
- <div ref="anchor" class="vui-clipboard-copy-wrap" role="button" @click="copy(text)">
75
- <slot :copy :copied />
76
- </div>
77
-
78
- <Transition name="fade-up" mode="in-out">
79
- <div v-if="copied && (!!parsedConfirm || $slots.confirm)" ref="tooltip" class="vui-clipboard-tooltip" :style="floatingStyles">
80
- <slot name="confirm">
81
- <template v-if="typeof parsedConfirm === 'string'">
82
- {{ parsedConfirm }}
83
- </template>
84
- <Flex v-else align-center justify-center>
85
- <Icon width="16" height="16" icon="ph:check-bold" />
86
- Copied to clipboard
87
- </Flex>
88
- </slot>
89
- </div>
90
- </Transition>
91
- </template>
1
+ <script setup lang='ts'>
2
+ import { autoUpdate, flip, offset, shift, useFloating } from '@floating-ui/vue'
3
+ import { Icon } from '@iconify/vue'
4
+ import { useClipboard } from '@vueuse/core'
5
+ import { computed, onMounted, useSlots, useTemplateRef } from 'vue'
6
+ import { isNil } from '../../shared/helpers'
7
+ import Flex from '../Flex/Flex.vue'
8
+ import './copy-clipboard.scss'
9
+
10
+ interface Props {
11
+ /**
12
+ * Text to copy
13
+ */
14
+ text: string
15
+ /**
16
+ * Wether to show a tooltip after successful copy
17
+ */
18
+ confirm?: string | boolean
19
+ /**
20
+ * How long will the copy confirmation tooltip be visible in milliseconds.
21
+ */
22
+ confirmTime?: number
23
+ }
24
+
25
+ const {
26
+ text,
27
+ confirm,
28
+ confirmTime,
29
+ } = defineProps<Props>()
30
+
31
+ const {
32
+ copy,
33
+ copied,
34
+ isSupported,
35
+ } = useClipboard({
36
+ copiedDuring: confirmTime,
37
+ })
38
+ const slots = useSlots()
39
+
40
+ const parsedConfirm = computed(() => {
41
+ if (isNil(confirm))
42
+ return false
43
+ if (confirm === '')
44
+ return true
45
+ else return confirm
46
+ })
47
+
48
+ onMounted(() => {
49
+ if (!isSupported.value) {
50
+ console.error('Clipboard API is not supported. This component will not work')
51
+ }
52
+
53
+ if (typeof parsedConfirm.value === 'string' && slots.confirm) {
54
+ console.warn('[ClipBoard] You are using the \'confirm\' prop and slot. The slot will take precedence.')
55
+ }
56
+ })
57
+
58
+ const anchorRef = useTemplateRef('anchor')
59
+ const tooltipRef = useTemplateRef('tooltip')
60
+
61
+ const { floatingStyles } = useFloating(anchorRef, tooltipRef, {
62
+ whileElementsMounted: autoUpdate,
63
+ transform: false,
64
+ placement: 'top',
65
+ middleware: [
66
+ offset(8),
67
+ shift(),
68
+ flip(),
69
+ ],
70
+ })
71
+ </script>
72
+
73
+ <template>
74
+ <div ref="anchor" class="vui-clipboard-copy-wrap" role="button" @click="copy(text)">
75
+ <slot :copy :copied />
76
+ </div>
77
+
78
+ <Transition name="fade-up" mode="in-out">
79
+ <div v-if="copied && (!!parsedConfirm || $slots.confirm)" ref="tooltip" class="vui-clipboard-tooltip" :style="floatingStyles">
80
+ <slot name="confirm">
81
+ <template v-if="typeof parsedConfirm === 'string'">
82
+ {{ parsedConfirm }}
83
+ </template>
84
+ <Flex v-else y-center x-center>
85
+ <Icon width="16" height="16" icon="ph:check-bold" />
86
+ Copied to clipboard
87
+ </Flex>
88
+ </slot>
89
+ </div>
90
+ </Transition>
91
+ </template>
@@ -1,25 +1,25 @@
1
- .vui-clipboard-copy-wrap {
2
- display: inline-block;
3
- position: relative;
4
- }
5
-
6
- .vui-clipboard-tooltip {
7
- padding: 6px 8px;
8
- border-radius: var(--border-radius-s);
9
- background-color: var(--color-bg-raised);
10
- font-size: var(--font-size-m);
11
- color: var(--color-text);
12
- box-shadow: var(--box-shadow);
13
- z-index: 1000;
14
-
15
- svg path {
16
- color: var(--color-text);
17
- }
18
- }
19
-
20
- :root.light {
21
- .vui-clipboard-tooltip {
22
- background-color: var(--color-bg);
23
- box-shadow: var(--box-shadow-strong);
24
- }
25
- }
1
+ .vui-clipboard-copy-wrap {
2
+ display: inline-block;
3
+ position: relative;
4
+ }
5
+
6
+ .vui-clipboard-tooltip {
7
+ padding: 6px 8px;
8
+ border-radius: var(--border-radius-s);
9
+ background-color: var(--color-bg-raised);
10
+ font-size: var(--font-size-m);
11
+ color: var(--color-text);
12
+ box-shadow: var(--box-shadow);
13
+ z-index: 1000;
14
+
15
+ svg path {
16
+ color: var(--color-text);
17
+ }
18
+ }
19
+
20
+ :root.light {
21
+ .vui-clipboard-tooltip {
22
+ background-color: var(--color-bg);
23
+ box-shadow: var(--box-shadow-strong);
24
+ }
25
+ }
@@ -1,44 +1,44 @@
1
- <script setup lang="ts">
2
- import { computed } from 'vue'
3
- import { formatUnitValue } from '../../shared/helpers'
4
- import './divider.scss'
5
-
6
- interface Props {
7
- thickness?: number
8
- size?: number | string
9
- vertical?: boolean
10
- margin?: string | number
11
- }
12
-
13
- const {
14
- thickness = 1,
15
- size = 32,
16
- vertical,
17
- margin = '0',
18
- } = defineProps<Props>()
19
-
20
- const h = computed(() => formatUnitValue(size))
21
- const w = computed(() => vertical ? h.value : 'initial')
22
- const bW = computed(() => `${thickness}px`)
23
- const m = computed(() => formatUnitValue(margin))
24
- </script>
25
-
26
- <template>
27
- <div
28
- class="vui-divider" :class="{ vertical }" :style="{
29
- margin: m,
30
- width: w,
31
- height: h,
32
- }"
33
- >
34
- <div v-if="$slots.default" class="vui-divider-slot">
35
- <slot />
36
- </div>
37
- </div>
38
- </template>
39
-
40
- <style lang="scss" scoped>
41
- .vui-divider:before {
42
- border-width: v-bind(bW);
43
- }
44
- </style>
1
+ <script setup lang="ts">
2
+ import { computed } from 'vue'
3
+ import { formatUnitValue } from '../../shared/helpers'
4
+ import './divider.scss'
5
+
6
+ interface Props {
7
+ thickness?: number
8
+ size?: number | string
9
+ vertical?: boolean
10
+ margin?: string | number
11
+ }
12
+
13
+ const {
14
+ thickness = 1,
15
+ size = 32,
16
+ vertical,
17
+ margin = '0',
18
+ } = defineProps<Props>()
19
+
20
+ const h = computed(() => formatUnitValue(size))
21
+ const w = computed(() => vertical ? h.value : 'initial')
22
+ const bW = computed(() => `${thickness}px`)
23
+ const m = computed(() => formatUnitValue(margin))
24
+ </script>
25
+
26
+ <template>
27
+ <div
28
+ class="vui-divider" :class="{ vertical }" :style="{
29
+ margin: m,
30
+ width: w,
31
+ height: h,
32
+ }"
33
+ >
34
+ <div v-if="$slots.default" class="vui-divider-slot">
35
+ <slot />
36
+ </div>
37
+ </div>
38
+ </template>
39
+
40
+ <style lang="scss" scoped>
41
+ .vui-divider:before {
42
+ border-width: v-bind(bW);
43
+ }
44
+ </style>
@@ -1,35 +1,35 @@
1
- .vui-divider {
2
- display: flex;
3
- align-items: center;
4
- justify-content: center;
5
- position: relative;
6
- height: 32px;
7
- width: 100%;
8
-
9
- &.vertical:before {
10
- border-bottom: none;
11
- border-right: 1px solid var(--color-border);
12
- transform: translateX(-50%);
13
- width: 1px;
14
- height: 100%;
15
- }
16
-
17
- &:before {
18
- content: '';
19
- display: block;
20
- transform: translateY(-50%);
21
- width: 100%;
22
- border-bottom: 1px solid var(--color-border);
23
- }
24
-
25
- .vui-divider-slot {
26
- position: absolute;
27
- top: 50%;
28
- left: 50%;
29
- transform: translate(-50%, -50%);
30
-
31
- & > *:first-child {
32
- outline: 3px solid var(--color-bg);
33
- }
34
- }
35
- }
1
+ .vui-divider {
2
+ display: flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+ position: relative;
6
+ height: 32px;
7
+ width: 100%;
8
+
9
+ &.vertical:before {
10
+ border-bottom: none;
11
+ border-right: 1px solid var(--color-border);
12
+ transform: translateX(-50%);
13
+ width: 1px;
14
+ height: 100%;
15
+ }
16
+
17
+ &:before {
18
+ content: '';
19
+ display: block;
20
+ transform: translateY(-50%);
21
+ width: 100%;
22
+ border-bottom: 1px solid var(--color-border);
23
+ }
24
+
25
+ .vui-divider-slot {
26
+ position: absolute;
27
+ top: 50%;
28
+ left: 50%;
29
+ transform: translate(-50%, -50%);
30
+
31
+ & > *:first-child {
32
+ outline: 3px solid var(--color-bg);
33
+ }
34
+ }
35
+ }