@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,51 +1,51 @@
1
- .vui-button-group {
2
- .vui-button {
3
- z-index: 1;
4
-
5
- &:hover {
6
- z-index: 2;
7
- }
8
-
9
- &:not(:first-child, :last-child) {
10
- border-radius: 0;
11
- }
12
-
13
- &:first-child {
14
- border-top-right-radius: 0;
15
- border-bottom-right-radius: 0;
16
- }
17
-
18
- &:last-child {
19
- border-top-left-radius: 0;
20
- border-bottom-left-radius: 0;
21
- }
22
-
23
- &:not(:last-child) {
24
- margin-right: 0px;
25
- }
26
- }
27
-
28
- &.vertical {
29
- .vui-button {
30
- width: 100%;
31
-
32
- &:not(:first-child, :last-child) {
33
- border-radius: 0;
34
- }
35
-
36
- &:first-child {
37
- border-bottom-left-radius: 0;
38
- border-bottom-right-radius: 0;
39
- }
40
-
41
- &:last-child {
42
- border-top-left-radius: 0;
43
- border-top-right-radius: 0;
44
- }
45
-
46
- &:not(:last-child) {
47
- margin-bottom: 0px;
48
- }
49
- }
50
- }
51
- }
1
+ .vui-button-group {
2
+ .vui-button {
3
+ z-index: 1;
4
+
5
+ &:hover {
6
+ z-index: 2;
7
+ }
8
+
9
+ &:not(:first-child, :last-child) {
10
+ border-radius: 0;
11
+ }
12
+
13
+ &:first-child {
14
+ border-top-right-radius: 0;
15
+ border-bottom-right-radius: 0;
16
+ }
17
+
18
+ &:last-child {
19
+ border-top-left-radius: 0;
20
+ border-bottom-left-radius: 0;
21
+ }
22
+
23
+ &:not(:last-child) {
24
+ margin-right: 0px;
25
+ }
26
+ }
27
+
28
+ &.vertical {
29
+ .vui-button {
30
+ width: 100%;
31
+
32
+ &:not(:first-child, :last-child) {
33
+ border-radius: 0;
34
+ }
35
+
36
+ &:first-child {
37
+ border-bottom-left-radius: 0;
38
+ border-bottom-right-radius: 0;
39
+ }
40
+
41
+ &:last-child {
42
+ border-top-left-radius: 0;
43
+ border-top-right-radius: 0;
44
+ }
45
+
46
+ &:not(:last-child) {
47
+ margin-bottom: 0px;
48
+ }
49
+ }
50
+ }
51
+ }
@@ -1,66 +1,66 @@
1
- <script setup lang='ts'>
2
- import type { VueDatePickerProps } from '@vuepic/vue-datepicker'
3
- import { Icon } from '@iconify/vue'
4
- import VueDatePicker from '@vuepic/vue-datepicker'
5
- import { useAttrs } from 'vue'
6
- import { theme } from '../../shared/theme'
7
- import '@vuepic/vue-datepicker/dist/main.css'
8
- import './calendar.scss'
9
-
10
- const props = withDefaults(defineProps<VueDatePickerProps & {
11
- expand?: boolean
12
- }>(), {
13
- autoApply: true,
14
- autoPosition: true,
15
- format: 'dd/MM/yyyy HH:mm',
16
- monthNameFormat: 'long',
17
- expand: false,
18
- })
19
-
20
- const ICON_SIZE = 18
21
- const attrs = useAttrs()
22
- </script>
23
-
24
- <template>
25
- <VueDatePicker
26
- v-bind="{ ...props, ...attrs }"
27
- class="vui-calendar"
28
- :class="{ 'vui-calendar-inline': props.inline }"
29
- :style="props.expand ?? !$slots.trigger
30
- ? undefined
31
- : { display: 'inline-block', width: 'auto' }
32
- "
33
- :dark="theme === 'dark'"
34
- >
35
- <!-- Icon slots -->
36
- <template #input-icon>
37
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:calendar-blank" />
38
- </template>
39
- <template #calendar-icon>
40
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:calendar-blank" />
41
- </template>
42
- <template #clear-icon>
43
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:x" />
44
- </template>
45
- <template #clock-icon>
46
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:clock" />
47
- </template>
48
- <template #arrow-left>
49
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-left" />
50
- </template>
51
- <template #arrow-right>
52
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-right" />
53
- </template>
54
- <template #arrow-up>
55
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-up" />
56
- </template>
57
- <template #arrow-down>
58
- <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-down" />
59
- </template>
60
-
61
- <!-- Content slots -->
62
- <template v-if="$slots.trigger" #trigger>
63
- <slot name="trigger" />
64
- </template>
65
- </VueDatePicker>
66
- </template>
1
+ <script setup lang='ts'>
2
+ import type { VueDatePickerProps } from '@vuepic/vue-datepicker'
3
+ import { Icon } from '@iconify/vue'
4
+ import VueDatePicker from '@vuepic/vue-datepicker'
5
+ import { useAttrs } from 'vue'
6
+ import { theme } from '../../shared/theme'
7
+ import '@vuepic/vue-datepicker/dist/main.css'
8
+ import './calendar.scss'
9
+
10
+ const props = withDefaults(defineProps<VueDatePickerProps & {
11
+ expand?: boolean
12
+ }>(), {
13
+ autoApply: true,
14
+ autoPosition: true,
15
+ format: 'dd/MM/yyyy HH:mm',
16
+ monthNameFormat: 'long',
17
+ expand: false,
18
+ })
19
+
20
+ const ICON_SIZE = 18
21
+ const attrs = useAttrs()
22
+ </script>
23
+
24
+ <template>
25
+ <VueDatePicker
26
+ v-bind="{ ...props, ...attrs }"
27
+ class="vui-calendar"
28
+ :class="{ 'vui-calendar-inline': props.inline }"
29
+ :style="props.expand ?? !$slots.trigger
30
+ ? undefined
31
+ : { display: 'inline-block', width: 'auto' }
32
+ "
33
+ :dark="theme === 'dark'"
34
+ >
35
+ <!-- Icon slots -->
36
+ <template #input-icon>
37
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:calendar-blank" />
38
+ </template>
39
+ <template #calendar-icon>
40
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:calendar-blank" />
41
+ </template>
42
+ <template #clear-icon>
43
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:x" />
44
+ </template>
45
+ <template #clock-icon>
46
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:clock" />
47
+ </template>
48
+ <template #arrow-left>
49
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-left" />
50
+ </template>
51
+ <template #arrow-right>
52
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-right" />
53
+ </template>
54
+ <template #arrow-up>
55
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-up" />
56
+ </template>
57
+ <template #arrow-down>
58
+ <Icon :width="ICON_SIZE" :height="ICON_SIZE" icon="ph:caret-down" />
59
+ </template>
60
+
61
+ <!-- Content slots -->
62
+ <template v-if="$slots.trigger" #trigger>
63
+ <slot name="trigger" />
64
+ </template>
65
+ </VueDatePicker>
66
+ </template>
@@ -1,83 +1,83 @@
1
- .dp__theme_light,
2
- .dp__theme_dark {
3
- --dp-background-color: var(--color-bg);
4
- --dp-text-color: var(--color-text);
5
- --dp-hover-color: var(--color-button-gray-hover);
6
- --dp-hover-text-color: var(--color-text);
7
- --dp-hover-icon-color: var(--color-text-lighter);
8
- --dp-primary-color: var(--color-accent);
9
- --dp-primary-disabled-color: var(--color-accent-disabled);
10
- --dp-primary-text-color: var(--color-text-invert);
11
- --dp-secondary-color: var(--color-border);
12
- --dp-border-color: var(--color-border);
13
- --dp-menu-border-color: var(--color-border);
14
- --dp-border-color-hover: var(--color-border-strong);
15
- --dp-border-color-focus: var(--color-border-strong);
16
- --dp-disabled-color: var(--color-bg-raised);
17
- --dp-disabled-color-text: var(--color-text-light);
18
- --dp-scroll-bar-background: var(--color-bg-lowered);
19
- --dp-scroll-bar-color: var(--color-border);
20
- --dp-success-color: var(--color-green);
21
- --dp-success-color-disabled: var(--color-green-disabled);
22
- --dp-icon-color: var(--color-text-light);
23
- --dp-danger-color: var(--color-red);
24
- --dp-marker-color: var(--color-red);
25
- --dp-tooltip-color: var(--color-bg-raised);
26
- --dp-highlight-color: var(--color-bg-raised);
27
- --dp-range-between-dates-background-color: var(--dp-hover-color, #484848);
28
- --dp-range-between-dates-text-color: var(--dp-hover-text-color, #fff);
29
- --dp-range-between-border-color: var(--dp-hover-color, #fff);
30
- }
31
-
32
- // TODO: dp theme light
33
-
34
- .dp__theme_light {
35
- --dp-primary-text-color: var(--color-text);
36
- }
37
-
38
- :root {
39
- --dp-font-family: var(--global-font);
40
- --dp-border-radius: var(--border-radius-s);
41
- --dp-cell-border-radius: var(--border-radius-s);
42
- --dp-common-transition: var(--transition);
43
-
44
- --dp-font-size: var(--font-size-m);
45
- --dp-preview-font-size: var(--font-size-s);
46
- --dp-time-font-size: var(--font-size-s);
47
- }
48
-
49
- .vui-calendar-inline {
50
- .dp__outer_menu_wrap {
51
- box-shadow: none;
52
- }
53
-
54
- .dp__menu {
55
- border: none;
56
- }
57
- }
58
-
59
- .dp__overlay_cell_pad {
60
- font-size: var(--font-size-m);
61
- text-transform: capitalize;
62
- font-weight: var(--font-weight-medium);
63
- }
64
-
65
- .dp__main {
66
- font-size: var(--font-size-m);
67
- }
68
-
69
- .dp__outer_menu_wrap {
70
- box-shadow: var(--box-shadow-strong);
71
- }
72
-
73
- .dp__input_icon {
74
- inset-inline-start: 8px;
75
- }
76
-
77
- .dp--clear-btn {
78
- inset-inline-end: 8px;
79
- }
80
-
81
- .dp__input {
82
- height: var(--interactive-el-height);
83
- }
1
+ .dp__theme_light,
2
+ .dp__theme_dark {
3
+ --dp-background-color: var(--color-bg);
4
+ --dp-text-color: var(--color-text);
5
+ --dp-hover-color: var(--color-button-gray-hover);
6
+ --dp-hover-text-color: var(--color-text);
7
+ --dp-hover-icon-color: var(--color-text-lighter);
8
+ --dp-primary-color: var(--color-accent);
9
+ --dp-primary-disabled-color: var(--color-accent-disabled);
10
+ --dp-primary-text-color: var(--color-text-invert);
11
+ --dp-secondary-color: var(--color-border);
12
+ --dp-border-color: var(--color-border);
13
+ --dp-menu-border-color: var(--color-border);
14
+ --dp-border-color-hover: var(--color-border-strong);
15
+ --dp-border-color-focus: var(--color-border-strong);
16
+ --dp-disabled-color: var(--color-bg-raised);
17
+ --dp-disabled-color-text: var(--color-text-light);
18
+ --dp-scroll-bar-background: var(--color-bg-lowered);
19
+ --dp-scroll-bar-color: var(--color-border);
20
+ --dp-success-color: var(--color-green);
21
+ --dp-success-color-disabled: var(--color-green-disabled);
22
+ --dp-icon-color: var(--color-text-light);
23
+ --dp-danger-color: var(--color-red);
24
+ --dp-marker-color: var(--color-red);
25
+ --dp-tooltip-color: var(--color-bg-raised);
26
+ --dp-highlight-color: var(--color-bg-raised);
27
+ --dp-range-between-dates-background-color: var(--dp-hover-color, #484848);
28
+ --dp-range-between-dates-text-color: var(--dp-hover-text-color, #fff);
29
+ --dp-range-between-border-color: var(--dp-hover-color, #fff);
30
+ }
31
+
32
+ // TODO: dp theme light
33
+
34
+ .dp__theme_light {
35
+ --dp-primary-text-color: var(--color-text);
36
+ }
37
+
38
+ :root {
39
+ --dp-font-family: var(--global-font);
40
+ --dp-border-radius: var(--border-radius-s);
41
+ --dp-cell-border-radius: var(--border-radius-s);
42
+ --dp-common-transition: var(--transition);
43
+
44
+ --dp-font-size: var(--font-size-m);
45
+ --dp-preview-font-size: var(--font-size-s);
46
+ --dp-time-font-size: var(--font-size-s);
47
+ }
48
+
49
+ .vui-calendar-inline {
50
+ .dp__outer_menu_wrap {
51
+ box-shadow: none;
52
+ }
53
+
54
+ .dp__menu {
55
+ border: none;
56
+ }
57
+ }
58
+
59
+ .dp__overlay_cell_pad {
60
+ font-size: var(--font-size-m);
61
+ text-transform: capitalize;
62
+ font-weight: var(--font-weight-medium);
63
+ }
64
+
65
+ .dp__main {
66
+ font-size: var(--font-size-m);
67
+ }
68
+
69
+ .dp__outer_menu_wrap {
70
+ box-shadow: var(--box-shadow-strong);
71
+ }
72
+
73
+ .dp__input_icon {
74
+ inset-inline-start: 8px;
75
+ }
76
+
77
+ .dp--clear-btn {
78
+ inset-inline-end: 8px;
79
+ }
80
+
81
+ .dp__input {
82
+ height: var(--interactive-el-height);
83
+ }
@@ -1,48 +1,48 @@
1
- <script setup lang="ts">
2
- import Divider from '../Divider/Divider.vue'
3
- import './card.scss'
4
-
5
- export interface Props {
6
- separators?: boolean
7
- headerSeparator?: boolean
8
- footerSeparator?: boolean
9
- padding?: boolean
10
- }
11
-
12
- const {
13
- padding = true,
14
- separators,
15
- headerSeparator,
16
- footerSeparator,
17
- } = defineProps<Props>()
18
- </script>
19
-
20
- <template>
21
- <div
22
- class="vui-card" :class="{
23
- separators,
24
- 'header-separator': headerSeparator,
25
- 'footer-separator': footerSeparator,
26
- 'no-padding': !padding,
27
- }"
28
- >
29
- <div v-if="$slots.header || $slots['header-end']" class="vui-card-header">
30
- <div>
31
- <slot name="header" />
32
- </div>
33
- <slot name="header-end" />
34
- </div>
35
-
36
- <Divider v-if="(separators || headerSeparator) && ($slots.header || $slots['header-end'])" :size="1" />
37
-
38
- <div v-if="$slots.default" class="vui-card-content">
39
- <slot />
40
- </div>
41
-
42
- <Divider v-if="(separators || footerSeparator) && $slots.footer" :size="1" />
43
-
44
- <div v-if="$slots.footer" class="vui-card-footer">
45
- <slot name="footer" />
46
- </div>
47
- </div>
48
- </template>
1
+ <script setup lang="ts">
2
+ import Divider from '../Divider/Divider.vue'
3
+ import './card.scss'
4
+
5
+ export interface Props {
6
+ separators?: boolean
7
+ headerSeparator?: boolean
8
+ footerSeparator?: boolean
9
+ padding?: boolean
10
+ }
11
+
12
+ const {
13
+ padding = true,
14
+ separators,
15
+ headerSeparator,
16
+ footerSeparator,
17
+ } = defineProps<Props>()
18
+ </script>
19
+
20
+ <template>
21
+ <div
22
+ class="vui-card" :class="{
23
+ separators,
24
+ 'header-separator': headerSeparator,
25
+ 'footer-separator': footerSeparator,
26
+ 'no-padding': !padding,
27
+ }"
28
+ >
29
+ <div v-if="$slots.header || $slots['header-end']" class="vui-card-header">
30
+ <div>
31
+ <slot name="header" />
32
+ </div>
33
+ <slot name="header-end" />
34
+ </div>
35
+
36
+ <Divider v-if="(separators || headerSeparator) && ($slots.header || $slots['header-end'])" :size="1" />
37
+
38
+ <div v-if="$slots.default" class="vui-card-content">
39
+ <slot />
40
+ </div>
41
+
42
+ <Divider v-if="(separators || footerSeparator) && $slots.footer" :size="1" />
43
+
44
+ <div v-if="$slots.footer" class="vui-card-footer">
45
+ <slot name="footer" />
46
+ </div>
47
+ </div>
48
+ </template>
@@ -1,53 +1,53 @@
1
- .vui-card {
2
- background-color: var(--color-bg);
3
- border-radius: var(--border-radius-m);
4
- border: 1px solid var(--color-border);
5
-
6
- &.no-padding {
7
- .vui-card-header,
8
- .vui-card-content,
9
- .vui-card-footer {
10
- padding: 0;
11
- }
12
- }
13
-
14
- &:not(.separators) {
15
- // &:not(.header-separator) .vui-card-content:first-child {
16
- // padding-bottom: var(--space-xs);
17
- // }
18
-
19
- &.header-separator {
20
- .vui-card-content:not(:first-child) {
21
- padding-top: var(--space-m);
22
- // padding-block: var(--space-m);
23
- }
24
- }
25
-
26
- &.footer-separator {
27
- .vui-card-content {
28
- padding-bottom: var(--space-m);
29
- }
30
- }
31
- }
32
-
33
- .vui-card-header {
34
- display: flex;
35
- align-items: center;
36
- justify-content: space-between;
37
- padding: var(--space-s) var(--space-m);
38
- background-color: var(--color-bg);
39
- border-top-left-radius: var(--border-radius-m);
40
- border-top-right-radius: var(--border-radius-m);
41
- }
42
-
43
- .vui-card-content {
44
- padding: var(--space-m);
45
- }
46
-
47
- .vui-card-footer {
48
- padding: var(--space-s) var(--space-m);
49
- background-color: var(--color-bg);
50
- border-bottom-left-radius: var(--border-radius-m);
51
- border-bottom-right-radius: var(--border-radius-m);
52
- }
53
- }
1
+ .vui-card {
2
+ background-color: var(--color-bg);
3
+ border-radius: var(--border-radius-m);
4
+ border: 1px solid var(--color-border);
5
+
6
+ &.no-padding {
7
+ .vui-card-header,
8
+ .vui-card-content,
9
+ .vui-card-footer {
10
+ padding: 0;
11
+ }
12
+ }
13
+
14
+ &:not(.separators) {
15
+ // &:not(.header-separator) .vui-card-content:first-child {
16
+ // padding-bottom: var(--space-xs);
17
+ // }
18
+
19
+ &.header-separator {
20
+ .vui-card-content:not(:first-child) {
21
+ padding-top: var(--space-m);
22
+ // padding-block: var(--space-m);
23
+ }
24
+ }
25
+
26
+ &.footer-separator {
27
+ .vui-card-content {
28
+ padding-bottom: var(--space-m);
29
+ }
30
+ }
31
+ }
32
+
33
+ .vui-card-header {
34
+ display: flex;
35
+ align-items: center;
36
+ justify-content: space-between;
37
+ padding: var(--space-s) var(--space-m);
38
+ background-color: var(--color-bg);
39
+ border-top-left-radius: var(--border-radius-m);
40
+ border-top-right-radius: var(--border-radius-m);
41
+ }
42
+
43
+ .vui-card-content {
44
+ padding: var(--space-m);
45
+ }
46
+
47
+ .vui-card-footer {
48
+ padding: var(--space-s) var(--space-m);
49
+ background-color: var(--color-bg);
50
+ border-bottom-left-radius: var(--border-radius-m);
51
+ border-bottom-right-radius: var(--border-radius-m);
52
+ }
53
+ }