@dolanske/vui 0.3.4 → 0.5.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 (114) hide show
  1. package/LICENSE +673 -673
  2. package/README.md +41 -40
  3. package/dist/components/Dropdown/DropdownItem.vue.d.ts +1 -0
  4. package/dist/components/Flex/Flex.vue.d.ts +3 -1
  5. package/dist/components/Grid/Grid.vue.d.ts +3 -1
  6. package/dist/components/Tabs/Tabs.vue.d.ts +4 -0
  7. package/dist/style.css +1 -1
  8. package/dist/vui.js +1547 -1534
  9. package/package.json +68 -68
  10. package/src/App.vue +176 -175
  11. package/src/components/Accordion/Accordion.vue +91 -91
  12. package/src/components/Accordion/AccordionGroup.vue +43 -43
  13. package/src/components/Accordion/accordion.scss +81 -80
  14. package/src/components/Alert/Alert.vue +53 -53
  15. package/src/components/Alert/alert.scss +80 -80
  16. package/src/components/Avatar/Avatar.vue +50 -50
  17. package/src/components/Avatar/avatar.scss +52 -52
  18. package/src/components/Badge/Badge.vue +21 -21
  19. package/src/components/Badge/badge.scss +89 -89
  20. package/src/components/Breadcrumbs/BreadcrumbItem.vue +26 -26
  21. package/src/components/Breadcrumbs/Breadcrumbs.vue +33 -33
  22. package/src/components/Breadcrumbs/breadcrumbs.scss +30 -30
  23. package/src/components/Button/Button.vue +90 -90
  24. package/src/components/Button/button.scss +178 -176
  25. package/src/components/ButtonGroup/ButtonGroup.vue +25 -25
  26. package/src/components/ButtonGroup/button-group.scss +51 -51
  27. package/src/components/Calendar/Calendar.vue +63 -60
  28. package/src/components/Calendar/calendar.scss +60 -56
  29. package/src/components/Card/Card.vue +48 -48
  30. package/src/components/Card/card.scss +53 -53
  31. package/src/components/Checkbox/Checkbox.vue +51 -52
  32. package/src/components/Checkbox/checkbox.scss +75 -66
  33. package/src/components/CopyClipboard/CopyClipboard.vue +82 -82
  34. package/src/components/CopyClipboard/copy-clipboard.scss +17 -17
  35. package/src/components/Divider/Divider.vue +44 -44
  36. package/src/components/Divider/divider.scss +35 -35
  37. package/src/components/Drawer/Drawer.vue +97 -97
  38. package/src/components/Drawer/drawer.scss +36 -36
  39. package/src/components/Dropdown/Dropdown.vue +111 -111
  40. package/src/components/Dropdown/DropdownItem.vue +33 -29
  41. package/src/components/Dropdown/DropdownTitle.vue +8 -8
  42. package/src/components/Dropdown/dropdown-item.scss +77 -0
  43. package/src/components/Dropdown/dropdown.scss +39 -117
  44. package/src/components/Flex/Flex.vue +113 -106
  45. package/src/components/Grid/Grid.vue +60 -54
  46. package/src/components/Input/Counter.vue +70 -70
  47. package/src/components/Input/Dropzone.vue +65 -65
  48. package/src/components/Input/File.vue +15 -15
  49. package/src/components/Input/Input.vue +121 -121
  50. package/src/components/Input/Password.vue +47 -47
  51. package/src/components/Input/Textarea.vue +76 -76
  52. package/src/components/Input/input.scss +208 -208
  53. package/src/components/Kbd/Kbd.vue +48 -48
  54. package/src/components/Kbd/KbdGroup.vue +31 -31
  55. package/src/components/Kbd/kbd.scss +18 -18
  56. package/src/components/Modal/Confirm.vue +56 -56
  57. package/src/components/Modal/Modal.vue +91 -91
  58. package/src/components/Modal/modal.scss +49 -49
  59. package/src/components/OTP/OTP.vue +133 -133
  60. package/src/components/OTP/OTPItem.vue +37 -37
  61. package/src/components/OTP/otp.scss +83 -83
  62. package/src/components/Pagination/Pagination.vue +74 -74
  63. package/src/components/Pagination/pagination.ts +78 -78
  64. package/src/components/Popout/Popout.vue +42 -42
  65. package/src/components/Popout/popout.scss +8 -8
  66. package/src/components/Progress/Progress.vue +90 -90
  67. package/src/components/Progress/progress.scss +41 -41
  68. package/src/components/Radio/Radio.vue +36 -36
  69. package/src/components/Radio/RadioGroup.vue +40 -40
  70. package/src/components/Radio/radio.scss +68 -59
  71. package/src/components/Select/Select.vue +180 -180
  72. package/src/components/Select/select.scss +44 -44
  73. package/src/components/Sheet/Sheet.vue +92 -92
  74. package/src/components/Sheet/sheet.scss +60 -60
  75. package/src/components/Sidebar/Sidebar.vue +102 -0
  76. package/src/components/Sidebar/sidebar.scss +123 -0
  77. package/src/components/Skeleton/Skeleton.vue +43 -43
  78. package/src/components/Skeleton/skeleton.scss +14 -14
  79. package/src/components/Spinner/Spinner.vue +42 -42
  80. package/src/components/Spinner/spinner.scss +46 -46
  81. package/src/components/Switch/Switch.vue +30 -30
  82. package/src/components/Switch/switch.scss +60 -52
  83. package/src/components/Table/Cell.vue +23 -23
  84. package/src/components/Table/Header.vue +59 -59
  85. package/src/components/Table/Row.vue +9 -9
  86. package/src/components/Table/SelectAll.vue +23 -23
  87. package/src/components/Table/SelectRow.vue +29 -29
  88. package/src/components/Table/Table.vue +66 -66
  89. package/src/components/Table/table.scss +134 -134
  90. package/src/components/Table/table.ts +244 -244
  91. package/src/components/Tabs/Tab.vue +27 -27
  92. package/src/components/Tabs/Tabs.vue +89 -82
  93. package/src/components/Tabs/tabs.scss +80 -79
  94. package/src/components/Toast/Toasts.vue +47 -47
  95. package/src/components/Toast/toast.scss +41 -41
  96. package/src/components/Toast/toast.ts +68 -68
  97. package/src/components/Tooltip/Tooltip.vue +86 -86
  98. package/src/components/Tooltip/tooltip.scss +4 -4
  99. package/src/index.scss +1 -1
  100. package/src/index.ts +119 -119
  101. package/src/internal/Backdrop/Backdrop.vue +22 -22
  102. package/src/internal/Backdrop/backdrop.scss +28 -28
  103. package/src/main.ts +5 -5
  104. package/src/shared/helpers.ts +74 -74
  105. package/src/shared/types.ts +29 -29
  106. package/src/style/animation.scss +21 -21
  107. package/src/style/core.scss +150 -148
  108. package/src/style/layout.scss +168 -136
  109. package/src/style/media-query.scss +29 -29
  110. package/src/style/reset.scss +135 -135
  111. package/src/style/{fonts.scss → text.scss} +74 -53
  112. package/src/style/tooltip.scss +128 -128
  113. package/src/style/typography.scss +338 -338
  114. package/src/style/utils.scss +36 -36
@@ -1,80 +1,80 @@
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: flex-start;
9
-
10
- svg {
11
- width: 22px;
12
- height: 22px;
13
- }
14
-
15
- .vui-alert-content,
16
- .vui-alert-default-content {
17
- flex: 1;
18
- }
19
-
20
- .vui-alert-default-content {
21
- padding-top: 3px;
22
-
23
- strong {
24
- display: block;
25
- font-size: var(--font-size-m);
26
- font-weight: 550;
27
- margin-bottom: 6px;
28
- }
29
-
30
- p {
31
- font-size: var(--font-size-ms);
32
- color: var(--color-text-light);
33
- font-weight: 350;
34
- }
35
- }
36
-
37
- .vui-alert-content {
38
- font-size: var(--font-size-m);
39
- }
40
-
41
- &.vui-alert-variant-neutral {
42
- border: 1px solid var(--color-border);
43
-
44
- svg path {
45
- color: var(--color-text);
46
- }
47
- }
48
-
49
- &.vui-alert-variant-info {
50
- border: 1px solid var(--color-border-blue);
51
-
52
- svg path {
53
- color: var(--color-text-blue);
54
- }
55
- }
56
-
57
- &.vui-alert-variant-success {
58
- border: 1px solid var(--color-border-green);
59
-
60
- svg path {
61
- color: var(--color-text-green);
62
- }
63
- }
64
-
65
- &.vui-alert-variant-warning {
66
- border: 1px solid var(--color-border-yellow);
67
-
68
- svg path {
69
- color: var(--color-text-yellow);
70
- }
71
- }
72
-
73
- &.vui-alert-variant-danger {
74
- border: 1px solid var(--color-border-red);
75
-
76
- svg path {
77
- color: var(--color-text-red);
78
- }
79
- }
80
- }
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: flex-start;
9
+
10
+ svg {
11
+ width: 22px;
12
+ height: 22px;
13
+ }
14
+
15
+ .vui-alert-content,
16
+ .vui-alert-default-content {
17
+ flex: 1;
18
+ }
19
+
20
+ .vui-alert-default-content {
21
+ padding-top: 3px;
22
+
23
+ strong {
24
+ display: block;
25
+ font-size: var(--font-size-m);
26
+ font-weight: 550;
27
+ margin-bottom: 6px;
28
+ }
29
+
30
+ p {
31
+ font-size: var(--font-size-ms);
32
+ color: var(--color-text-light);
33
+ font-weight: 350;
34
+ }
35
+ }
36
+
37
+ .vui-alert-content {
38
+ font-size: var(--font-size-m);
39
+ }
40
+
41
+ &.vui-alert-variant-neutral {
42
+ border: 1px solid var(--color-border);
43
+
44
+ svg path {
45
+ color: var(--color-text);
46
+ }
47
+ }
48
+
49
+ &.vui-alert-variant-info {
50
+ border: 1px solid var(--color-border-blue);
51
+
52
+ svg path {
53
+ color: var(--color-text-blue);
54
+ }
55
+ }
56
+
57
+ &.vui-alert-variant-success {
58
+ border: 1px solid var(--color-border-green);
59
+
60
+ svg path {
61
+ color: var(--color-text-green);
62
+ }
63
+ }
64
+
65
+ &.vui-alert-variant-warning {
66
+ border: 1px solid var(--color-border-yellow);
67
+
68
+ svg path {
69
+ color: var(--color-text-yellow);
70
+ }
71
+ }
72
+
73
+ &.vui-alert-variant-danger {
74
+ border: 1px solid var(--color-border-red);
75
+
76
+ svg path {
77
+ color: var(--color-text-red);
78
+ }
79
+ }
80
+ }
@@ -1,50 +1,50 @@
1
- <script setup lang="ts">
2
- import type { Sizes } from '../../shared/types'
3
- import { Icon } from '@iconify/vue'
4
- import { ref } from 'vue'
5
- import { formatUnitValue } from '../../shared/helpers'
6
- import { Size } from '../../shared/types'
7
- import './avatar.scss'
8
-
9
- interface Props {
10
- size?: Sizes | number
11
- url?: string
12
- fallback?: string
13
- icon?: string
14
- alt?: string
15
- }
16
-
17
- const {
18
- size = Size.m,
19
- url,
20
- fallback,
21
- alt = 'avatar',
22
- } = defineProps<Props>()
23
-
24
- const showFallback = ref(false)
25
- </script>
26
-
27
- <template>
28
- <div
29
- class="vui-avatar"
30
- :class="[`vui-avatar-size-${typeof size === 'number' ? 'l' : size}`]"
31
- :style="{
32
- ...(typeof size === 'number' && {
33
- '--avatar-size': formatUnitValue(size),
34
- }),
35
- }"
36
- >
37
- <img
38
- v-if="url && !showFallback"
39
- :alt
40
- :src="url"
41
- @error="showFallback = true"
42
- >
43
- <strong v-else>
44
- <template v-if="showFallback">
45
- {{ fallback }}
46
- </template>
47
- <Icon v-else :icon="icon ?? 'ph:user'" />
48
- </strong>
49
- </div>
50
- </template>
1
+ <script setup lang="ts">
2
+ import type { Sizes } from '../../shared/types'
3
+ import { Icon } from '@iconify/vue'
4
+ import { ref } from 'vue'
5
+ import { formatUnitValue } from '../../shared/helpers'
6
+ import { Size } from '../../shared/types'
7
+ import './avatar.scss'
8
+
9
+ interface Props {
10
+ size?: Sizes | number
11
+ url?: string
12
+ fallback?: string
13
+ icon?: string
14
+ alt?: string
15
+ }
16
+
17
+ const {
18
+ size = Size.m,
19
+ url,
20
+ fallback,
21
+ alt = 'avatar',
22
+ } = defineProps<Props>()
23
+
24
+ const showFallback = ref(false)
25
+ </script>
26
+
27
+ <template>
28
+ <div
29
+ class="vui-avatar"
30
+ :class="[`vui-avatar-size-${typeof size === 'number' ? 'l' : size}`]"
31
+ :style="{
32
+ ...(typeof size === 'number' && {
33
+ '--avatar-size': formatUnitValue(size),
34
+ }),
35
+ }"
36
+ >
37
+ <img
38
+ v-if="url && !showFallback"
39
+ :alt
40
+ :src="url"
41
+ @error="showFallback = true"
42
+ >
43
+ <strong v-else>
44
+ <template v-if="showFallback">
45
+ {{ fallback }}
46
+ </template>
47
+ <Icon v-else :icon="icon ?? 'ph:user'" />
48
+ </strong>
49
+ </div>
50
+ </template>
@@ -1,52 +1,52 @@
1
- .vui-avatar {
2
- --avatar-size: 36px;
3
-
4
- &.vui-avatar-size-s {
5
- --avatar-size: 28px;
6
-
7
- strong {
8
- font-size: var(--font-size-xs);
9
- }
10
- }
11
-
12
- &.vui-avatar-size-l {
13
- --avatar-size: 48px;
14
-
15
- strong {
16
- font-size: var(--font-size-l);
17
- }
18
- }
19
-
20
- width: var(--avatar-size);
21
- height: var(--avatar-size);
22
- border-radius: 100%;
23
- display: flex;
24
- align-items: center;
25
- justify-content: center;
26
- overflow: hidden;
27
- background-color: var(--color-bg-raised);
28
- font-weight: 500;
29
-
30
- svg {
31
- color: var(--color-text-light);
32
- font-size: inherit;
33
- }
34
-
35
- strong {
36
- display: block;
37
- font-size: var(--font-size-ms);
38
- line-height: 1;
39
- }
40
-
41
- img {
42
- display: block;
43
- height: 100%;
44
- width: 100%;
45
- object-position: center;
46
- object-fit: cover;
47
- }
48
-
49
- img[src=''] {
50
- display: none;
51
- }
52
- }
1
+ .vui-avatar {
2
+ --avatar-size: 36px;
3
+
4
+ &.vui-avatar-size-s {
5
+ --avatar-size: 28px;
6
+
7
+ strong {
8
+ font-size: var(--font-size-xs);
9
+ }
10
+ }
11
+
12
+ &.vui-avatar-size-l {
13
+ --avatar-size: 48px;
14
+
15
+ strong {
16
+ font-size: var(--font-size-l);
17
+ }
18
+ }
19
+
20
+ width: var(--avatar-size);
21
+ height: var(--avatar-size);
22
+ border-radius: 100%;
23
+ display: flex;
24
+ align-items: center;
25
+ justify-content: center;
26
+ overflow: hidden;
27
+ background-color: var(--color-bg-raised);
28
+ font-weight: 500;
29
+
30
+ svg {
31
+ color: var(--color-text-light);
32
+ font-size: inherit;
33
+ }
34
+
35
+ strong {
36
+ display: block;
37
+ font-size: var(--font-size-ms);
38
+ line-height: 1;
39
+ }
40
+
41
+ img {
42
+ display: block;
43
+ height: 100%;
44
+ width: 100%;
45
+ object-position: center;
46
+ object-fit: cover;
47
+ }
48
+
49
+ img[src=''] {
50
+ display: none;
51
+ }
52
+ }
@@ -1,21 +1,21 @@
1
- <script setup lang="ts">
2
- import './badge.scss'
3
-
4
- interface Props {
5
- variant?: 'neutral' | 'danger' | 'warning' | 'success' | 'info'
6
- outline?: boolean
7
- filled?: boolean
8
- }
9
-
10
- const {
11
- variant = 'neutral',
12
- outline,
13
- filled,
14
- } = defineProps<Props>()
15
- </script>
16
-
17
- <template>
18
- <div class="vui-badge" :class="[{ outline, filled }, `vui-badge-variant-${variant}`]">
19
- <slot />
20
- </div>
21
- </template>
1
+ <script setup lang="ts">
2
+ import './badge.scss'
3
+
4
+ interface Props {
5
+ variant?: 'neutral' | 'danger' | 'warning' | 'success' | 'info'
6
+ outline?: boolean
7
+ filled?: boolean
8
+ }
9
+
10
+ const {
11
+ variant = 'neutral',
12
+ outline,
13
+ filled,
14
+ } = defineProps<Props>()
15
+ </script>
16
+
17
+ <template>
18
+ <div class="vui-badge" :class="[{ outline, filled }, `vui-badge-variant-${variant}`]">
19
+ <slot />
20
+ </div>
21
+ </template>
@@ -1,89 +1,89 @@
1
- .vui-badge {
2
- display: inline-flex;
3
- gap: var(--space-s);
4
- place-items: center;
5
- height: 26px;
6
- padding-inline: var(--space-s);
7
- border-radius: 999px;
8
- font-weight: 300;
9
- font-size: var(--font-size-s);
10
-
11
- &.filled {
12
- font-weight: 500;
13
- }
14
-
15
- &.vui-badge-variant-neutral {
16
- &:not(.outline) {
17
- background-color: var(--color-bg-raised);
18
-
19
- &.filled {
20
- background-color: var(--color-text);
21
- color: var(--color-text-invert);
22
- border-color: transparent;
23
- }
24
- }
25
-
26
- color: var(--color-text);
27
- border: 1px solid var(--color-border);
28
- }
29
-
30
- &.vui-badge-variant-info {
31
- &:not(.outline) {
32
- background-color: var(--color-bg-blue-lowered);
33
-
34
- &.filled {
35
- background-color: var(--color-text-blue);
36
- color: var(--color-text-invert);
37
- border-color: transparent;
38
- }
39
- }
40
-
41
- color: var(--color-text);
42
- border: 1px solid var(--color-border-blue);
43
- }
44
-
45
- &.vui-badge-variant-success {
46
- &:not(.outline) {
47
- background-color: var(--color-bg-green-lowered);
48
-
49
- &.filled {
50
- background-color: var(--color-text-green);
51
- color: var(--color-text-invert);
52
- border-color: transparent;
53
- }
54
- }
55
-
56
- color: var(--color-text);
57
- border: 1px solid var(--color-border-green);
58
- }
59
-
60
- &.vui-badge-variant-warning {
61
- &:not(.outline) {
62
- background-color: var(--color-bg-yellow-lowered);
63
-
64
- &.filled {
65
- background-color: var(--color-text-yellow);
66
- color: var(--color-text-invert);
67
- border-color: transparent;
68
- }
69
- }
70
-
71
- color: var(--color-text);
72
- border: 1px solid var(--color-border-yellow);
73
- }
74
-
75
- &.vui-badge-variant-danger {
76
- &:not(.outline) {
77
- background-color: var(--color-bg-red-lowered);
78
-
79
- &.filled {
80
- background-color: var(--color-text-red);
81
- color: var(--color-text-invert);
82
- border-color: transparent;
83
- }
84
- }
85
-
86
- color: var(--color-text);
87
- border: 1px solid var(--color-border-red);
88
- }
89
- }
1
+ .vui-badge {
2
+ display: inline-flex;
3
+ gap: var(--space-s);
4
+ place-items: center;
5
+ height: 26px;
6
+ padding-inline: var(--space-s);
7
+ border-radius: 999px;
8
+ font-weight: 300;
9
+ font-size: var(--font-size-s);
10
+
11
+ &.filled {
12
+ font-weight: 500;
13
+ }
14
+
15
+ &.vui-badge-variant-neutral {
16
+ &:not(.outline) {
17
+ background-color: var(--color-bg-raised);
18
+
19
+ &.filled {
20
+ background-color: var(--color-text);
21
+ color: var(--color-text-invert);
22
+ border-color: transparent;
23
+ }
24
+ }
25
+
26
+ color: var(--color-text);
27
+ border: 1px solid var(--color-border);
28
+ }
29
+
30
+ &.vui-badge-variant-info {
31
+ &:not(.outline) {
32
+ background-color: var(--color-bg-blue-lowered);
33
+
34
+ &.filled {
35
+ background-color: var(--color-text-blue);
36
+ color: var(--color-text-invert);
37
+ border-color: transparent;
38
+ }
39
+ }
40
+
41
+ color: var(--color-text);
42
+ border: 1px solid var(--color-border-blue);
43
+ }
44
+
45
+ &.vui-badge-variant-success {
46
+ &:not(.outline) {
47
+ background-color: var(--color-bg-green-lowered);
48
+
49
+ &.filled {
50
+ background-color: var(--color-text-green);
51
+ color: var(--color-text-invert);
52
+ border-color: transparent;
53
+ }
54
+ }
55
+
56
+ color: var(--color-text);
57
+ border: 1px solid var(--color-border-green);
58
+ }
59
+
60
+ &.vui-badge-variant-warning {
61
+ &:not(.outline) {
62
+ background-color: var(--color-bg-yellow-lowered);
63
+
64
+ &.filled {
65
+ background-color: var(--color-text-yellow);
66
+ color: var(--color-text-invert);
67
+ border-color: transparent;
68
+ }
69
+ }
70
+
71
+ color: var(--color-text);
72
+ border: 1px solid var(--color-border-yellow);
73
+ }
74
+
75
+ &.vui-badge-variant-danger {
76
+ &:not(.outline) {
77
+ background-color: var(--color-bg-red-lowered);
78
+
79
+ &.filled {
80
+ background-color: var(--color-text-red);
81
+ color: var(--color-text-invert);
82
+ border-color: transparent;
83
+ }
84
+ }
85
+
86
+ color: var(--color-text);
87
+ border: 1px solid var(--color-border-red);
88
+ }
89
+ }
@@ -1,26 +1,26 @@
1
- <script setup lang='ts'>
2
- import '../Button/button.scss'
3
-
4
- export interface BreadcrumbItemProps {
5
- label?: string
6
- path?: string
7
- }
8
-
9
- const props = defineProps<BreadcrumbItemProps>()
10
- </script>
11
-
12
- <template>
13
- <li>
14
- <a v-if="props.path" :href="props.path" class="vui-breadcrumb-link">
15
- <slot>
16
- {{ props.label }}
17
- </slot>
18
- </a>
19
-
20
- <slot v-else>
21
- <span class="vui-breadcrumb-text-simple">
22
- {{ props.label }}
23
- </span>
24
- </slot>
25
- </li>
26
- </template>
1
+ <script setup lang='ts'>
2
+ import '../Button/button.scss'
3
+
4
+ export interface BreadcrumbItemProps {
5
+ label?: string
6
+ path?: string
7
+ }
8
+
9
+ const props = defineProps<BreadcrumbItemProps>()
10
+ </script>
11
+
12
+ <template>
13
+ <li>
14
+ <a v-if="props.path" :href="props.path" class="vui-breadcrumb-link">
15
+ <slot>
16
+ {{ props.label }}
17
+ </slot>
18
+ </a>
19
+
20
+ <slot v-else>
21
+ <span class="vui-breadcrumb-text-simple">
22
+ {{ props.label }}
23
+ </span>
24
+ </slot>
25
+ </li>
26
+ </template>