@dolanske/vui 1.0.1 → 1.0.3

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 (194) hide show
  1. package/LICENSE +673 -673
  2. package/README.md +42 -42
  3. package/dist/components/Accordion/Accordion.vue.d.ts +2 -3
  4. package/dist/components/Accordion/AccordionGroup.vue.d.ts +2 -5
  5. package/dist/components/Alert/Alert.vue.d.ts +2 -3
  6. package/dist/components/Avatar/Avatar.vue.d.ts +2 -3
  7. package/dist/components/Badge/Badge.vue.d.ts +2 -3
  8. package/dist/components/Breadcrumbs/BreadcrumbItem.vue.d.ts +2 -3
  9. package/dist/components/Breadcrumbs/Breadcrumbs.vue.d.ts +2 -3
  10. package/dist/components/Button/Button.vue.d.ts +2 -3
  11. package/dist/components/ButtonGroup/ButtonGroup.vue.d.ts +2 -3
  12. package/dist/components/Calendar/Calendar.vue.d.ts +6 -6
  13. package/dist/components/Card/Card.vue.d.ts +3 -4
  14. package/dist/components/Checkbox/Checkbox.vue.d.ts +6 -7
  15. package/dist/components/CopyClipboard/CopyClipboard.vue.d.ts +1 -2
  16. package/dist/components/Divider/Divider.vue.d.ts +2 -3
  17. package/dist/components/Drawer/Drawer.vue.d.ts +5 -6
  18. package/dist/components/Dropdown/Dropdown.vue.d.ts +3 -66
  19. package/dist/components/Dropdown/DropdownItem.vue.d.ts +2 -3
  20. package/dist/components/Dropdown/DropdownTitle.vue.d.ts +6 -6
  21. package/dist/components/Flex/Flex.vue.d.ts +2 -3
  22. package/dist/components/Grid/Grid.vue.d.ts +2 -3
  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 +10 -95
  26. package/dist/components/Input/File.vue.d.ts +3 -4
  27. package/dist/components/Input/Input.vue.d.ts +6 -7
  28. package/dist/components/Input/Password.vue.d.ts +1 -1
  29. package/dist/components/Input/Textarea.vue.d.ts +6 -7
  30. package/dist/components/Kbd/Kbd.vue.d.ts +1 -1
  31. package/dist/components/Kbd/KbdGroup.vue.d.ts +1 -2
  32. package/dist/components/Modal/Confirm.vue.d.ts +5 -6
  33. package/dist/components/Modal/Modal.vue.d.ts +5 -6
  34. package/dist/components/OTP/OTP.vue.d.ts +6 -7
  35. package/dist/components/OTP/OTPItem.vue.d.ts +1 -1
  36. package/dist/components/Pagination/Pagination.vue.d.ts +2 -3
  37. package/dist/components/Popout/Popout.vue.d.ts +2 -3
  38. package/dist/components/Progress/Progress.vue.d.ts +5 -5
  39. package/dist/components/Radio/Radio.vue.d.ts +6 -7
  40. package/dist/components/Radio/RadioGroup.vue.d.ts +6 -7
  41. package/dist/components/Select/Select.vue.d.ts +8 -4
  42. package/dist/components/Sheet/Sheet.vue.d.ts +5 -6
  43. package/dist/components/Sidebar/Sidebar.vue.d.ts +6 -7
  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 +6 -7
  47. package/dist/components/Table/Cell.vue.d.ts +2 -5
  48. package/dist/components/Table/Head.vue.d.ts +2 -3
  49. package/dist/components/Table/Root.vue.d.ts +2 -3
  50. package/dist/components/Table/table.d.ts +2 -2
  51. package/dist/components/Tabs/Tab.vue.d.ts +2 -3
  52. package/dist/components/Tabs/Tabs.vue.d.ts +6 -7
  53. package/dist/components/Toast/toast.d.ts +6 -6
  54. package/dist/components/Tooltip/Tooltip.vue.d.ts +1 -2
  55. package/dist/internal/Backdrop/Backdrop.vue.d.ts +2 -3
  56. package/dist/{vui.css → style.css} +1 -1
  57. package/dist/vui.js +5318 -5449
  58. package/package.json +72 -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 +206 -206
  69. package/src/components/Breadcrumbs/BreadcrumbItem.vue +26 -26
  70. package/src/components/Breadcrumbs/Breadcrumbs.vue +30 -32
  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 +97 -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 +80 -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 +99 -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 +98 -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 +89 -89
  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 +122 -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 +78 -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.scss +1 -1
  178. package/src/index.ts +116 -116
  179. package/src/internal/Backdrop/Backdrop.vue +22 -22
  180. package/src/internal/Backdrop/backdrop.scss +34 -34
  181. package/src/main.ts +5 -5
  182. package/src/shared/helpers.ts +117 -117
  183. package/src/shared/theme.ts +22 -22
  184. package/src/shared/types.ts +29 -29
  185. package/src/style/animation.scss +22 -22
  186. package/src/style/core.scss +125 -125
  187. package/src/style/layout.scss +233 -233
  188. package/src/style/media-query.scss +29 -29
  189. package/src/style/reset.scss +135 -135
  190. package/src/style/text.scss +124 -92
  191. package/src/style/theme.scss +195 -195
  192. package/src/style/tooltip.scss +146 -146
  193. package/src/style/typography.scss +415 -415
  194. package/src/style/utils.scss +36 -36
@@ -1,47 +1,47 @@
1
- .vui-spinner {
2
- --spinner-color: var(--color-border-accent);
3
-
4
- aspect-ratio: 1;
5
- border-radius: 50%;
6
- border: 3px solid var(--spinner-color);
7
- animation:
8
- l20-1 0.8s infinite linear alternate,
9
- l20-2 1.6s infinite linear;
10
- }
11
- @keyframes l20-1 {
12
- 0% {
13
- clip-path: polygon(50% 50%, 0 0, 50% 0%, 50% 0%, 50% 0%, 50% 0%, 50% 0%);
14
- }
15
- 12.5% {
16
- clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 0%, 100% 0%, 100% 0%);
17
- }
18
- 25% {
19
- clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 100%, 100% 100%, 100% 100%);
20
- }
21
- 50% {
22
- clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100%);
23
- }
24
- 62.5% {
25
- clip-path: polygon(50% 50%, 100% 0, 100% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100%);
26
- }
27
- 75% {
28
- clip-path: polygon(50% 50%, 100% 100%, 100% 100%, 100% 100%, 100% 100%, 50% 100%, 0% 100%);
29
- }
30
- 100% {
31
- clip-path: polygon(50% 50%, 50% 100%, 50% 100%, 50% 100%, 50% 100%, 50% 100%, 0% 100%);
32
- }
33
- }
34
- @keyframes l20-2 {
35
- 0% {
36
- transform: scaleY(1) rotate(0deg);
37
- }
38
- 49.99% {
39
- transform: scaleY(1) rotate(135deg);
40
- }
41
- 50% {
42
- transform: scaleY(-1) rotate(0deg);
43
- }
44
- 100% {
45
- transform: scaleY(-1) rotate(-135deg);
46
- }
47
- }
1
+ .vui-spinner {
2
+ --spinner-color: var(--color-border-accent);
3
+
4
+ aspect-ratio: 1;
5
+ border-radius: 50%;
6
+ border: 3px solid var(--spinner-color);
7
+ animation:
8
+ l20-1 0.8s infinite linear alternate,
9
+ l20-2 1.6s infinite linear;
10
+ }
11
+ @keyframes l20-1 {
12
+ 0% {
13
+ clip-path: polygon(50% 50%, 0 0, 50% 0%, 50% 0%, 50% 0%, 50% 0%, 50% 0%);
14
+ }
15
+ 12.5% {
16
+ clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 0%, 100% 0%, 100% 0%);
17
+ }
18
+ 25% {
19
+ clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 100%, 100% 100%, 100% 100%);
20
+ }
21
+ 50% {
22
+ clip-path: polygon(50% 50%, 0 0, 50% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100%);
23
+ }
24
+ 62.5% {
25
+ clip-path: polygon(50% 50%, 100% 0, 100% 0%, 100% 0%, 100% 100%, 50% 100%, 0% 100%);
26
+ }
27
+ 75% {
28
+ clip-path: polygon(50% 50%, 100% 100%, 100% 100%, 100% 100%, 100% 100%, 50% 100%, 0% 100%);
29
+ }
30
+ 100% {
31
+ clip-path: polygon(50% 50%, 50% 100%, 50% 100%, 50% 100%, 50% 100%, 50% 100%, 0% 100%);
32
+ }
33
+ }
34
+ @keyframes l20-2 {
35
+ 0% {
36
+ transform: scaleY(1) rotate(0deg);
37
+ }
38
+ 49.99% {
39
+ transform: scaleY(1) rotate(135deg);
40
+ }
41
+ 50% {
42
+ transform: scaleY(-1) rotate(0deg);
43
+ }
44
+ 100% {
45
+ transform: scaleY(-1) rotate(-135deg);
46
+ }
47
+ }
@@ -1,31 +1,31 @@
1
- <script setup lang="ts">
2
- import { useId } from 'vue'
3
- import './switch.scss'
4
-
5
- interface Props {
6
- label?: string
7
- disabled?: boolean
8
- accent?: boolean
9
- }
10
-
11
- const { label, disabled, accent } = defineProps<Props>()
12
- const slots = defineSlots()
13
- const checked = defineModel<boolean>()
14
- const id = useId()
15
- </script>
16
-
17
- <template>
18
- <div class="vui-switch" :class="{ disabled, checked, accent }">
19
- <input :id v-model="checked" type="checkbox" :disabled>
20
- <label :for="id">
21
- <div class="vui-switch-icon">
22
- <span class="vui-switch-indicator" />
23
- </div>
24
-
25
- <p v-if="!slots.default" class="vui-switch-content">{{ label }}</p>
26
- <div v-else class="vui-switch-content">
27
- <slot />
28
- </div>
29
- </label>
30
- </div>
31
- </template>
1
+ <script setup lang="ts">
2
+ import { useId } from 'vue'
3
+ import './switch.scss'
4
+
5
+ interface Props {
6
+ label?: string
7
+ disabled?: boolean
8
+ accent?: boolean
9
+ }
10
+
11
+ const { label, disabled, accent } = defineProps<Props>()
12
+ const slots = defineSlots()
13
+ const checked = defineModel<boolean>()
14
+ const id = useId()
15
+ </script>
16
+
17
+ <template>
18
+ <div class="vui-switch" :class="{ disabled, checked, accent }">
19
+ <input :id v-model="checked" type="checkbox" :disabled>
20
+ <label :for="id">
21
+ <div class="vui-switch-icon">
22
+ <span class="vui-switch-indicator" />
23
+ </div>
24
+
25
+ <p v-if="!slots.default" class="vui-switch-content">{{ label }}</p>
26
+ <div v-else class="vui-switch-content">
27
+ <slot />
28
+ </div>
29
+ </label>
30
+ </div>
31
+ </template>
@@ -1,93 +1,93 @@
1
- .vui-switch {
2
- --switch-size: 24px;
3
-
4
- &.checked {
5
- .vui-switch-icon .vui-switch-indicator {
6
- left: calc(100% - 24px);
7
- background-color: var(--color-text);
8
- }
9
-
10
- &.accent .vui-switch-icon .vui-switch-indicator {
11
- background-color: var(--color-accent);
12
- }
13
- }
14
-
15
- &.disabled {
16
- .vui-switch-icon {
17
- opacity: 0.5;
18
- cursor: not-allowed;
19
- }
20
-
21
- input + label .vui-switch-content {
22
- opacity: 0.5;
23
- cursor: not-allowed;
24
- }
25
- }
26
-
27
- .vui-switch-icon {
28
- width: 44px;
29
- height: var(--switch-size);
30
- border-radius: 22px;
31
- background-color: var(--color-bg-raised);
32
- position: relative;
33
- cursor: default;
34
-
35
- .vui-switch-indicator {
36
- display: block;
37
- position: absolute;
38
- left: 2px;
39
- top: 2px;
40
- width: 20px;
41
- height: 20px;
42
- border-radius: 100%;
43
- background-color: var(--color-text-lighter);
44
- transition: var(--transition);
45
- }
46
- }
47
-
48
- input {
49
- width: 1px;
50
- height: 1px;
51
- position: absolute;
52
- overflow: hidden;
53
- outline: none !important;
54
- opacity: 0;
55
-
56
- &:focus-visible + label .vui-switch-icon {
57
- outline: 2px solid var(--color-text);
58
- }
59
-
60
- & + label {
61
- display: grid;
62
- grid-template-columns: 44px 1fr;
63
- gap: 10px;
64
- font-size: var(--font-size-m);
65
- color: var(--color-text);
66
- user-select: none;
67
-
68
- .vui-switch-content {
69
- display: block;
70
-
71
- &:is(p) {
72
- height: var(--switch-size);
73
- line-height: var(--switch-size);
74
- font-size: var(--font-size-m);
75
- }
76
- }
77
- }
78
- }
79
- }
80
-
81
- :root.light {
82
- .vui-switch .vui-switch-icon .vui-switch-indicator {
83
- background-color: var(--color-bg-lowered);
84
- }
85
-
86
- .vui-switch.checked.accent .vui-switch-icon .vui-switch-indicator {
87
- background-color: var(--color-accent);
88
- }
89
-
90
- .vui-switch.checked .vui-switch-icon .vui-switch-indicator {
91
- background-color: var(--color-text);
92
- }
93
- }
1
+ .vui-switch {
2
+ --switch-size: 24px;
3
+
4
+ &.checked {
5
+ .vui-switch-icon .vui-switch-indicator {
6
+ left: calc(100% - 24px);
7
+ background-color: var(--color-text);
8
+ }
9
+
10
+ &.accent .vui-switch-icon .vui-switch-indicator {
11
+ background-color: var(--color-accent);
12
+ }
13
+ }
14
+
15
+ &.disabled {
16
+ .vui-switch-icon {
17
+ opacity: 0.5;
18
+ cursor: not-allowed;
19
+ }
20
+
21
+ input + label .vui-switch-content {
22
+ opacity: 0.5;
23
+ cursor: not-allowed;
24
+ }
25
+ }
26
+
27
+ .vui-switch-icon {
28
+ width: 44px;
29
+ height: var(--switch-size);
30
+ border-radius: 22px;
31
+ background-color: var(--color-bg-raised);
32
+ position: relative;
33
+ cursor: default;
34
+
35
+ .vui-switch-indicator {
36
+ display: block;
37
+ position: absolute;
38
+ left: 2px;
39
+ top: 2px;
40
+ width: 20px;
41
+ height: 20px;
42
+ border-radius: 100%;
43
+ background-color: var(--color-text-lighter);
44
+ transition: var(--transition);
45
+ }
46
+ }
47
+
48
+ input {
49
+ width: 1px;
50
+ height: 1px;
51
+ position: absolute;
52
+ overflow: hidden;
53
+ outline: none !important;
54
+ opacity: 0;
55
+
56
+ &:focus-visible + label .vui-switch-icon {
57
+ outline: 2px solid var(--color-text);
58
+ }
59
+
60
+ & + label {
61
+ display: grid;
62
+ grid-template-columns: 44px 1fr;
63
+ gap: 10px;
64
+ font-size: var(--font-size-m);
65
+ color: var(--color-text);
66
+ user-select: none;
67
+
68
+ .vui-switch-content {
69
+ display: block;
70
+
71
+ &:is(p) {
72
+ height: var(--switch-size);
73
+ line-height: var(--switch-size);
74
+ font-size: var(--font-size-m);
75
+ }
76
+ }
77
+ }
78
+ }
79
+ }
80
+
81
+ :root.light {
82
+ .vui-switch .vui-switch-icon .vui-switch-indicator {
83
+ background-color: var(--color-bg-lowered);
84
+ }
85
+
86
+ .vui-switch.checked.accent .vui-switch-icon .vui-switch-indicator {
87
+ background-color: var(--color-accent);
88
+ }
89
+
90
+ .vui-switch.checked .vui-switch-icon .vui-switch-indicator {
91
+ background-color: var(--color-text);
92
+ }
93
+ }
@@ -1,23 +1,23 @@
1
- <script setup lang="ts">
2
- import { computed, useSlots, useTemplateRef } from 'vue'
3
-
4
- const slots = useSlots()
5
- const contextRef = useTemplateRef<HTMLTableCellElement>('context')
6
- const computedStyle = computed(() => {
7
- if (!slots.context || !window)
8
- return {}
9
- const width = contextRef.value?.getBoundingClientRect().width ?? 0
10
- return {
11
- paddingRight: `${width}px`,
12
- }
13
- })
14
- </script>
15
-
16
- <template>
17
- <td :style="computedStyle">
18
- <slot />
19
- <div v-if="$slots.context" ref="context" class="vui-cell-context">
20
- <slot name="context" />
21
- </div>
22
- </td>
23
- </template>
1
+ <script setup lang="ts">
2
+ import { computed, useSlots, useTemplateRef } from 'vue'
3
+
4
+ const slots = useSlots()
5
+ const contextRef = useTemplateRef<HTMLTableCellElement>('context')
6
+ const computedStyle = computed(() => {
7
+ if (!slots.context || !window)
8
+ return {}
9
+ const width = contextRef.value?.getBoundingClientRect().width ?? 0
10
+ return {
11
+ paddingRight: `${width}px`,
12
+ }
13
+ })
14
+ </script>
15
+
16
+ <template>
17
+ <td :style="computedStyle">
18
+ <slot />
19
+ <div v-if="$slots.context" ref="context" class="vui-cell-context">
20
+ <slot name="context" />
21
+ </div>
22
+ </td>
23
+ </template>
@@ -1,59 +1,59 @@
1
- <script setup lang="ts">
2
- import type { Header } from './table'
3
- import { computed } from 'vue'
4
- import Button from '../Button/Button.vue'
5
-
6
- interface Props {
7
- /**
8
- * Main header data. This can be empty in case we are just adding an empty
9
- * padder. It is recommended to just use <th> instead, but this shouldn't fail
10
- * anyway
11
- */
12
- header?: Header
13
- /**
14
- * Enable sorting on this column
15
- */
16
- sort?: boolean
17
- }
18
-
19
- const props = defineProps<Props>()
20
-
21
- const sortStateBind = computed(() => {
22
- if (!props.header)
23
- return
24
- switch (props.header.sortKey) {
25
- case 'asc': return {
26
- 'icon': 'ph:sort-ascending',
27
- 'data-title-top': 'Ascending',
28
- }
29
- case 'desc': return {
30
- 'icon': 'ph:sort-descending',
31
- 'data-title-top': 'Descending',
32
- }
33
- default: return {
34
- 'icon': 'ph:arrows-down-up',
35
- 'data-title-top': 'Sort column',
36
- }
37
- }
38
- })
39
- </script>
40
-
41
- <template>
42
- <th>
43
- <div v-if="props.header || $slots.default" class="vui-table-th-content">
44
- <slot>
45
- {{ props.header?.label }}
46
- </slot>
47
- <Button
48
- v-if="props.sort && props.header"
49
- class="vui-table-sort-button"
50
- v-bind="sortStateBind"
51
- size="s"
52
- :plain="!!!props.header.sortKey"
53
- square
54
- variant="gray"
55
- @click="props.header.sortToggle"
56
- />
57
- </div>
58
- </th>
59
- </template>
1
+ <script setup lang="ts">
2
+ import type { Header } from './table'
3
+ import { computed } from 'vue'
4
+ import Button from '../Button/Button.vue'
5
+
6
+ interface Props {
7
+ /**
8
+ * Main header data. This can be empty in case we are just adding an empty
9
+ * padder. It is recommended to just use <th> instead, but this shouldn't fail
10
+ * anyway
11
+ */
12
+ header?: Header
13
+ /**
14
+ * Enable sorting on this column
15
+ */
16
+ sort?: boolean
17
+ }
18
+
19
+ const props = defineProps<Props>()
20
+
21
+ const sortStateBind = computed(() => {
22
+ if (!props.header)
23
+ return
24
+ switch (props.header.sortKey) {
25
+ case 'asc': return {
26
+ 'icon': 'ph:sort-ascending',
27
+ 'data-title-top': 'Ascending',
28
+ }
29
+ case 'desc': return {
30
+ 'icon': 'ph:sort-descending',
31
+ 'data-title-top': 'Descending',
32
+ }
33
+ default: return {
34
+ 'icon': 'ph:arrows-down-up',
35
+ 'data-title-top': 'Sort column',
36
+ }
37
+ }
38
+ })
39
+ </script>
40
+
41
+ <template>
42
+ <th>
43
+ <div v-if="props.header || $slots.default" class="vui-table-th-content">
44
+ <slot>
45
+ {{ props.header?.label }}
46
+ </slot>
47
+ <Button
48
+ v-if="props.sort && props.header"
49
+ class="vui-table-sort-button"
50
+ v-bind="sortStateBind"
51
+ size="s"
52
+ :plain="!!!props.header.sortKey"
53
+ square
54
+ variant="gray"
55
+ @click="props.header.sortToggle"
56
+ />
57
+ </div>
58
+ </th>
59
+ </template>
@@ -1,66 +1,66 @@
1
- <script setup lang='ts'>
2
- import type { TableSelectionProvide } from './table'
3
- import { inject } from 'vue'
4
- import { TableSelectionProvideSymbol } from './table'
5
- import './table.scss'
6
-
7
- interface Props {
8
- /**
9
- * Sets the `table-layout` property
10
- */
11
- fixed?: boolean
12
- /**
13
- * Table cells with content overflowing on new line will be cropped
14
- */
15
- nowrap?: boolean
16
- /**
17
- * Add a visual separator between each row
18
- */
19
- separateRows?: boolean
20
- /**
21
- * Add a visual separator between each cell
22
- */
23
- separateCells?: boolean
24
- /**
25
- * Wrap table with a border
26
- */
27
- outerBorder?: boolean
28
- }
29
-
30
- const {
31
- fixed,
32
- nowrap,
33
- separateRows = true,
34
- separateCells = false,
35
- outerBorder = true,
36
- } = defineProps<Props>()
37
- const selecting = inject(TableSelectionProvideSymbol) as TableSelectionProvide
38
- </script>
39
-
40
- <template>
41
- <div
42
- class="vui-table-container"
43
- :class="{
44
- fixed,
45
- nowrap,
46
- 'selecting': selecting.enabled,
47
- 'separated-rows': separateRows,
48
- 'separated-cells': separateCells,
49
- 'outer-border': outerBorder,
50
- }"
51
- >
52
- <table>
53
- <thead v-if="$slots.header">
54
- <tr>
55
- <slot name="header" />
56
- </tr>
57
- </thead>
58
- <tbody>
59
- <slot name="body" />
60
- </tbody>
61
- </table>
62
- <div v-if="$slots.pagination" class="vui-table-pagination-wrap">
63
- <slot name="pagination" />
64
- </div>
65
- </div>
66
- </template>
1
+ <script setup lang='ts'>
2
+ import type { TableSelectionProvide } from './table'
3
+ import { inject } from 'vue'
4
+ import { TableSelectionProvideSymbol } from './table'
5
+ import './table.scss'
6
+
7
+ interface Props {
8
+ /**
9
+ * Sets the `table-layout` property
10
+ */
11
+ fixed?: boolean
12
+ /**
13
+ * Table cells with content overflowing on new line will be cropped
14
+ */
15
+ nowrap?: boolean
16
+ /**
17
+ * Add a visual separator between each row
18
+ */
19
+ separateRows?: boolean
20
+ /**
21
+ * Add a visual separator between each cell
22
+ */
23
+ separateCells?: boolean
24
+ /**
25
+ * Wrap table with a border
26
+ */
27
+ outerBorder?: boolean
28
+ }
29
+
30
+ const {
31
+ fixed,
32
+ nowrap,
33
+ separateRows = true,
34
+ separateCells = false,
35
+ outerBorder = true,
36
+ } = defineProps<Props>()
37
+ const selecting = inject(TableSelectionProvideSymbol) as TableSelectionProvide
38
+ </script>
39
+
40
+ <template>
41
+ <div
42
+ class="vui-table-container"
43
+ :class="{
44
+ fixed,
45
+ nowrap,
46
+ 'selecting': selecting.enabled,
47
+ 'separated-rows': separateRows,
48
+ 'separated-cells': separateCells,
49
+ 'outer-border': outerBorder,
50
+ }"
51
+ >
52
+ <table>
53
+ <thead v-if="$slots.header">
54
+ <tr>
55
+ <slot name="header" />
56
+ </tr>
57
+ </thead>
58
+ <tbody>
59
+ <slot name="body" />
60
+ </tbody>
61
+ </table>
62
+ <div v-if="$slots.pagination" class="vui-table-pagination-wrap">
63
+ <slot name="pagination" />
64
+ </div>
65
+ </div>
66
+ </template>