@antify/ui-module 1.3.0 → 1.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.
- package/dist/module.json +1 -1
- package/dist/module.mjs +2 -1
- package/dist/runtime/components/AntAccordionItem.vue +17 -14
- package/dist/runtime/components/AntDropdown.vue +6 -6
- package/dist/runtime/components/AntListGroupItem.vue +16 -10
- package/dist/runtime/components/AntModal.vue +10 -9
- package/dist/runtime/components/AntPopover.vue +10 -8
- package/dist/runtime/components/AntTooltip.vue +69 -63
- package/dist/runtime/components/__stories/AntTooltip.stories.d.ts +5 -0
- package/dist/runtime/components/__stories/AntTooltip.stories.mjs +33 -11
- package/dist/runtime/components/buttons/AntActionButton.vue +40 -13
- package/dist/runtime/components/buttons/AntButton.vue +126 -126
- package/dist/runtime/components/buttons/AntCreateButton.vue +21 -8
- package/dist/runtime/components/buttons/AntDeleteButton.vue +30 -8
- package/dist/runtime/components/buttons/AntDuplicateButton.vue +42 -0
- package/dist/runtime/components/buttons/AntSaveAndNewButton.vue +21 -8
- package/dist/runtime/components/buttons/AntSaveButton.vue +20 -8
- package/dist/runtime/components/buttons/__stories/AntActionButton.stories.d.ts +1 -0
- package/dist/runtime/components/buttons/__stories/AntActionButton.stories.mjs +25 -1
- package/dist/runtime/components/buttons/__stories/AntButton.stories.mjs +130 -130
- package/dist/runtime/components/buttons/__stories/AntCreateButton.stories.d.ts +1 -0
- package/dist/runtime/components/buttons/__stories/AntCreateButton.stories.mjs +11 -1
- package/dist/runtime/components/buttons/__stories/AntDeleteButton.stories.d.ts +2 -0
- package/dist/runtime/components/buttons/__stories/AntDeleteButton.stories.mjs +18 -1
- package/dist/runtime/components/buttons/__stories/AntDuplicateButton.stories.d.ts +11 -0
- package/dist/runtime/components/buttons/__stories/AntDuplicateButton.stories.mjs +67 -0
- package/dist/runtime/components/buttons/__stories/AntSaveAndNewButton.stories.d.ts +1 -0
- package/dist/runtime/components/buttons/__stories/AntSaveAndNewButton.stories.mjs +11 -1
- package/dist/runtime/components/buttons/__stories/AntSaveButton.stories.d.ts +1 -0
- package/dist/runtime/components/buttons/__stories/AntSaveButton.stories.mjs +11 -1
- package/dist/runtime/components/crud/AntCrud.vue +13 -10
- package/dist/runtime/components/crud/AntCrudDetail.vue +1 -1
- package/dist/runtime/components/crud/AntCrudDetailActions.vue +10 -3
- package/dist/runtime/components/crud/AntCrudDetailNav.vue +21 -15
- package/dist/runtime/components/crud/AntCrudTableFilter.vue +36 -34
- package/dist/runtime/components/crud/AntCrudTableNav.vue +15 -4
- package/dist/runtime/components/dialogs/AntDialog.vue +7 -7
- package/dist/runtime/components/form/AntCheckboxWidget/AntCheckbox.vue +1 -2
- package/dist/runtime/components/form/AntSelect.vue +57 -53
- package/dist/runtime/components/form/AntSwitch.vue +13 -10
- package/dist/runtime/components/form/AntSwitcher.vue +4 -4
- package/dist/runtime/components/form/AntTextarea.vue +6 -3
- package/dist/runtime/components/form/Elements/AntBaseInput.vue +45 -41
- package/dist/runtime/components/form/Elements/AntDropDown.vue +1 -1
- package/dist/runtime/components/layouts/AntNavLeftLayout.vue +4 -4
- package/dist/runtime/components/table/AntTable.vue +95 -73
- package/dist/runtime/components/table/AntTableSortButton.vue +16 -4
- package/dist/runtime/components/tabs/AntTabItem.vue +7 -4
- package/dist/runtime/tailwind.config.mjs +1 -1
- package/dist/runtime/utils.d.ts +6 -0
- package/dist/runtime/utils.mjs +21 -0
- package/package.json +1 -1
- package/src/runtime/components/AntAccordionItem.vue +17 -14
- package/src/runtime/components/AntDropdown.vue +6 -6
- package/src/runtime/components/AntListGroupItem.vue +16 -10
- package/src/runtime/components/AntModal.vue +10 -9
- package/src/runtime/components/AntPopover.vue +10 -8
- package/src/runtime/components/AntTooltip.vue +69 -63
- package/src/runtime/components/buttons/AntActionButton.vue +40 -13
- package/src/runtime/components/buttons/AntButton.vue +126 -126
- package/src/runtime/components/buttons/AntCreateButton.vue +21 -8
- package/src/runtime/components/buttons/AntDeleteButton.vue +30 -8
- package/src/runtime/components/buttons/AntDuplicateButton.vue +42 -0
- package/src/runtime/components/buttons/AntSaveAndNewButton.vue +21 -8
- package/src/runtime/components/buttons/AntSaveButton.vue +20 -8
- package/src/runtime/components/crud/AntCrud.vue +13 -10
- package/src/runtime/components/crud/AntCrudDetail.vue +1 -1
- package/src/runtime/components/crud/AntCrudDetailActions.vue +10 -3
- package/src/runtime/components/crud/AntCrudDetailNav.vue +21 -15
- package/src/runtime/components/crud/AntCrudTableFilter.vue +36 -34
- package/src/runtime/components/crud/AntCrudTableNav.vue +15 -4
- package/src/runtime/components/dialogs/AntDialog.vue +7 -7
- package/src/runtime/components/form/AntCheckboxWidget/AntCheckbox.vue +1 -2
- package/src/runtime/components/form/AntSelect.vue +57 -53
- package/src/runtime/components/form/AntSwitch.vue +13 -10
- package/src/runtime/components/form/AntSwitcher.vue +4 -4
- package/src/runtime/components/form/AntTextarea.vue +6 -3
- package/src/runtime/components/form/Elements/AntBaseInput.vue +45 -41
- package/src/runtime/components/form/Elements/AntDropDown.vue +1 -1
- package/src/runtime/components/layouts/AntNavLeftLayout.vue +4 -4
- package/src/runtime/components/table/AntTable.vue +95 -73
- package/src/runtime/components/table/AntTableSortButton.vue +16 -4
- package/src/runtime/components/tabs/AntTabItem.vue +7 -4
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -84,7 +84,7 @@ const colors = {
|
|
|
84
84
|
"danger-950": defaultColors.red["950"]
|
|
85
85
|
};
|
|
86
86
|
const fontColors = {
|
|
87
|
-
"for-white-bg-font": colors["neutral-
|
|
87
|
+
"for-white-bg-font": colors["neutral-600"],
|
|
88
88
|
"for-black-bg-font": colors["neutral-100"],
|
|
89
89
|
"neutral-50-font": colors["neutral-600"],
|
|
90
90
|
"neutral-100-font": colors["neutral-600"],
|
|
@@ -329,6 +329,7 @@ const module = defineNuxtModule({
|
|
|
329
329
|
const { resolve } = createResolver(import.meta.url);
|
|
330
330
|
const runtimeDir = resolve("./runtime");
|
|
331
331
|
nuxt.options.build.transpile.push(runtimeDir);
|
|
332
|
+
nuxt.options.alias["#ui-module"] = resolve(runtimeDir, "types");
|
|
332
333
|
addPlugin(resolve(runtimeDir, "plugins/ui-module"));
|
|
333
334
|
addImportsDir(resolve(runtimeDir, "composables"));
|
|
334
335
|
await addComponentsDir({
|
|
@@ -24,21 +24,24 @@ function onClick() {
|
|
|
24
24
|
|
|
25
25
|
<template>
|
|
26
26
|
<div
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
class="p-2.5 select-none cursor-pointer transition-colors"
|
|
28
|
+
:class="{'bg-primary-500 text-primary-500-font': isOpen, 'bg-white text-for-white-bg-font': !isOpen}"
|
|
29
|
+
@click="onClick"
|
|
30
30
|
>
|
|
31
|
-
<slot
|
|
31
|
+
<slot
|
|
32
|
+
name="label"
|
|
33
|
+
v-bind="{ isOpen: isOpen }"
|
|
34
|
+
>
|
|
32
35
|
<div
|
|
33
|
-
|
|
36
|
+
class="hover:text-gray-800 flex justify-between items-center"
|
|
34
37
|
>
|
|
35
38
|
<span class="text-sm font-semibold">
|
|
36
39
|
{{ label }}
|
|
37
40
|
</span>
|
|
38
41
|
|
|
39
42
|
<AntIcon
|
|
40
|
-
|
|
41
|
-
|
|
43
|
+
:icon="isOpen ? faAngleUp : faAngleDown"
|
|
44
|
+
:color="isOpen ? 'text-primary-500-font' : undefined"
|
|
42
45
|
/>
|
|
43
46
|
</div>
|
|
44
47
|
</slot>
|
|
@@ -46,17 +49,17 @@ function onClick() {
|
|
|
46
49
|
|
|
47
50
|
<AntTransitionCollapseHeight>
|
|
48
51
|
<div
|
|
49
|
-
|
|
50
|
-
|
|
52
|
+
v-show="isOpen"
|
|
53
|
+
class="bg-white overflow-hidden -mt-px"
|
|
51
54
|
>
|
|
52
|
-
<
|
|
55
|
+
<Transition name="bounce">
|
|
53
56
|
<div
|
|
54
|
-
|
|
55
|
-
|
|
57
|
+
v-show="isOpen"
|
|
58
|
+
class="p-2.5 bg-white"
|
|
56
59
|
>
|
|
57
|
-
<slot/>
|
|
60
|
+
<slot />
|
|
58
61
|
</div>
|
|
59
|
-
</
|
|
62
|
+
</Transition>
|
|
60
63
|
</div>
|
|
61
64
|
</AntTransitionCollapseHeight>
|
|
62
65
|
</template>
|
|
@@ -52,25 +52,25 @@ function onClickOutside() {
|
|
|
52
52
|
|
|
53
53
|
<template>
|
|
54
54
|
<div
|
|
55
|
+
v-on-click-outside="onClickOutside"
|
|
55
56
|
class="relative inline-flex justify-center items-end z-40"
|
|
56
57
|
data-e2e="dropdown"
|
|
57
|
-
v-on-click-outside="onClickOutside"
|
|
58
58
|
>
|
|
59
|
-
<slot/>
|
|
59
|
+
<slot />
|
|
60
60
|
|
|
61
|
-
<
|
|
61
|
+
<Transition name="bounce">
|
|
62
62
|
<div
|
|
63
63
|
v-if="showDropdown"
|
|
64
64
|
:class="_dropdownClasses"
|
|
65
65
|
>
|
|
66
66
|
<div
|
|
67
|
-
class="shadow-lg border border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative bg-
|
|
67
|
+
class="shadow-lg border border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative bg-white text-for-white-bg-font w-full"
|
|
68
68
|
:class="{'p-2.5': contentPadding}"
|
|
69
69
|
>
|
|
70
|
-
<slot name="content"/>
|
|
70
|
+
<slot name="content" />
|
|
71
71
|
</div>
|
|
72
72
|
</div>
|
|
73
|
-
</
|
|
73
|
+
</Transition>
|
|
74
74
|
</div>
|
|
75
75
|
</template>
|
|
76
76
|
|
|
@@ -21,7 +21,7 @@ const classes = computed(() => {
|
|
|
21
21
|
[ListGroupItemColorType.info]: 'bg-info-500 text-info-500-font',
|
|
22
22
|
[ListGroupItemColorType.neutral700]: 'bg-neutral-700 text-neutral-700-font',
|
|
23
23
|
[ListGroupItemColorType.neutral300]: 'bg-neutral-300 text-neutral-300-font',
|
|
24
|
-
[ListGroupItemColorType.neutral50]: 'bg-
|
|
24
|
+
[ListGroupItemColorType.neutral50]: 'bg-white text-for-white-bg-font',
|
|
25
25
|
[ListGroupItemColorType.primary]: 'bg-primary-500 text-primary-500-font',
|
|
26
26
|
[ListGroupItemColorType.secondary]: 'bg-secondary-500 text-secondary-500-font',
|
|
27
27
|
[ListGroupItemColorType.success]: 'bg-success-500 text-success-500-font',
|
|
@@ -39,7 +39,7 @@ const contentWrapperClasses = computed(() => {
|
|
|
39
39
|
[ListGroupItemColorType.info]: 'text-info-500-font',
|
|
40
40
|
[ListGroupItemColorType.neutral700]: 'text-neutral-700-font',
|
|
41
41
|
[ListGroupItemColorType.neutral300]: 'text-neutral-300-font',
|
|
42
|
-
[ListGroupItemColorType.neutral50]: 'text-
|
|
42
|
+
[ListGroupItemColorType.neutral50]: 'text-for-white-bg-font',
|
|
43
43
|
[ListGroupItemColorType.primary]: 'text-primary-500-font',
|
|
44
44
|
[ListGroupItemColorType.secondary]: 'text-secondary-500-font',
|
|
45
45
|
[ListGroupItemColorType.success]: 'text-success-500-font',
|
|
@@ -60,21 +60,27 @@ onMounted(() => {
|
|
|
60
60
|
|
|
61
61
|
<template>
|
|
62
62
|
<component
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
63
|
+
:is="to !== undefined ? 'router-link' : 'div'"
|
|
64
|
+
:to="to"
|
|
65
|
+
:class="classes"
|
|
66
66
|
>
|
|
67
67
|
<div :class="contentWrapperClasses">
|
|
68
68
|
<div class="flex items-center gap-2.5">
|
|
69
|
-
<slot
|
|
70
|
-
|
|
69
|
+
<slot
|
|
70
|
+
v-if="iconLeft"
|
|
71
|
+
name="icon-left"
|
|
72
|
+
>
|
|
73
|
+
<AntIcon :icon="iconLeft" />
|
|
71
74
|
</slot>
|
|
72
75
|
|
|
73
|
-
<slot/>
|
|
76
|
+
<slot />
|
|
74
77
|
</div>
|
|
75
78
|
|
|
76
|
-
<slot
|
|
77
|
-
|
|
79
|
+
<slot
|
|
80
|
+
v-if="iconRight"
|
|
81
|
+
name="icon-right"
|
|
82
|
+
>
|
|
83
|
+
<AntIcon :icon="iconRight" />
|
|
78
84
|
</slot>
|
|
79
85
|
</div>
|
|
80
86
|
</component>
|
|
@@ -39,21 +39,22 @@ function closeModal() {
|
|
|
39
39
|
</script>
|
|
40
40
|
|
|
41
41
|
<template>
|
|
42
|
-
<
|
|
42
|
+
<Transition name="fade">
|
|
43
43
|
<div
|
|
44
44
|
v-if="openBackground"
|
|
45
45
|
class="absolute inset-0 flex items-center justify-center z-50 cursor-pointer overflow-hidden"
|
|
46
46
|
:class="{'bg-black/50 backdrop-blur-sm': !fullscreen}"
|
|
47
47
|
@click.self="closeModal"
|
|
48
48
|
>
|
|
49
|
-
<
|
|
49
|
+
<Transition :name="!fullscreen ? 'bounce' : 'bounce-slow'">
|
|
50
50
|
<div
|
|
51
51
|
v-if="openModal"
|
|
52
52
|
class="flex flex-col gap-px bg-neutral-300 overflow-hidden cursor-auto"
|
|
53
53
|
:class="{'w-full h-full': fullscreen, 'border border-neutral-300 rounded-md shadow-md': !fullscreen}"
|
|
54
54
|
>
|
|
55
55
|
<div
|
|
56
|
-
class="bg-
|
|
56
|
+
class="bg-white p-2.5 flex items-center justify-between text-for-white-bg-font text-lg font-medium"
|
|
57
|
+
>
|
|
57
58
|
<slot name="title">
|
|
58
59
|
{{ title }}
|
|
59
60
|
</slot>
|
|
@@ -66,20 +67,20 @@ function closeModal() {
|
|
|
66
67
|
/>
|
|
67
68
|
</div>
|
|
68
69
|
|
|
69
|
-
<div class="bg-
|
|
70
|
-
<slot/>
|
|
70
|
+
<div class="bg-white p-2.5 grow overflow-y-auto">
|
|
71
|
+
<slot />
|
|
71
72
|
</div>
|
|
72
73
|
|
|
73
74
|
<div
|
|
74
75
|
v-if="useSlots()['footer'] || false"
|
|
75
|
-
class="bg-
|
|
76
|
+
class="bg-white p-2.5 text-for-white-bg-font"
|
|
76
77
|
>
|
|
77
|
-
<slot name="footer"/>
|
|
78
|
+
<slot name="footer" />
|
|
78
79
|
</div>
|
|
79
80
|
</div>
|
|
80
|
-
</
|
|
81
|
+
</Transition>
|
|
81
82
|
</div>
|
|
82
|
-
</
|
|
83
|
+
</Transition>
|
|
83
84
|
</template>
|
|
84
85
|
|
|
85
86
|
<style scoped>
|
|
@@ -44,9 +44,9 @@ onMounted(() => {
|
|
|
44
44
|
|
|
45
45
|
<template>
|
|
46
46
|
<div class="relative inline-flex justify-center items-end">
|
|
47
|
-
<slot/>
|
|
47
|
+
<slot />
|
|
48
48
|
|
|
49
|
-
<
|
|
49
|
+
<Transition name="bounce">
|
|
50
50
|
<template v-if="showPopover">
|
|
51
51
|
<div :class="_popoverClasses">
|
|
52
52
|
<div class="shadow-lg border-neutral-300 rounded-md text-sm relative inline-flex flex-col relative">
|
|
@@ -66,12 +66,12 @@ onMounted(() => {
|
|
|
66
66
|
>
|
|
67
67
|
<path
|
|
68
68
|
d="M20.3284 1.82843L23.1569 4.65685C24.6571 6.15715 26.692 7 28.8137 7L6.18629 7C8.30802 7 10.3429 6.15715 11.8431 4.65686L14.6716 1.82843C16.2337 0.266331 18.7663 0.266328 20.3284 1.82843Z"
|
|
69
|
-
:class="{'fill-neutral-100': position === Position.bottom, 'fill-
|
|
69
|
+
:class="{'fill-neutral-100': position === Position.bottom, 'fill-white': position === Position.top || position === Position.right || position === Position.left}"
|
|
70
70
|
/>
|
|
71
71
|
|
|
72
72
|
<path
|
|
73
73
|
d="M34.5 7L28.8137 7C26.692 7 24.6571 6.15715 23.1569 4.65685L20.3284 1.82843C18.7663 0.266328 16.2337 0.266331 14.6716 1.82843L11.8431 4.65686C10.3429 6.15715 8.30802 7 6.18629 7L0.5 7L34.5 7Z"
|
|
74
|
-
:class="{'stroke-neutral-100': position === Position.bottom, 'stroke-
|
|
74
|
+
:class="{'stroke-neutral-100': position === Position.bottom, 'stroke-white': position === Position.top || position === Position.right || position === Position.left}"
|
|
75
75
|
/>
|
|
76
76
|
</svg>
|
|
77
77
|
|
|
@@ -92,18 +92,20 @@ onMounted(() => {
|
|
|
92
92
|
</div>
|
|
93
93
|
|
|
94
94
|
<div
|
|
95
|
-
class="border-neutral-300 border-b p-2.5 bg-neutral-100 rounded-t-md border-t border-l border-r text-neutral-100-font font-semibold"
|
|
95
|
+
class="border-neutral-300 border-b p-2.5 bg-neutral-100 rounded-t-md border-t border-l border-r text-neutral-100-font font-semibold"
|
|
96
|
+
>
|
|
96
97
|
{{ title }}
|
|
97
98
|
</div>
|
|
98
99
|
|
|
99
100
|
<div
|
|
100
|
-
class="p-2.5 rounded-b-md text-
|
|
101
|
-
|
|
101
|
+
class="p-2.5 rounded-b-md text-for-white-bg-font border-neutral-300 border-l border-b border-r bg-white"
|
|
102
|
+
>
|
|
103
|
+
<slot name="content" />
|
|
102
104
|
</div>
|
|
103
105
|
</div>
|
|
104
106
|
</div>
|
|
105
107
|
</template>
|
|
106
|
-
</
|
|
108
|
+
</Transition>
|
|
107
109
|
</div>
|
|
108
110
|
</template>
|
|
109
111
|
|
|
@@ -3,78 +3,80 @@ import {computed, onMounted, ref} from 'vue';
|
|
|
3
3
|
import {handleEnumValidation} from '../handler';
|
|
4
4
|
import {InputColorType, Position} from '../enums';
|
|
5
5
|
import {classesToObjectSyntax} from '../utils';
|
|
6
|
+
import {hasSlotContent} from '../utils';
|
|
6
7
|
|
|
7
8
|
const props = withDefaults(defineProps<{
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
position?: Position
|
|
10
|
+
tooltipClasses?: string | Record<string, boolean>
|
|
11
|
+
colorType?: InputColorType
|
|
12
|
+
expanded?: boolean
|
|
12
13
|
}>(), {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
14
|
+
position: Position.left,
|
|
15
|
+
tooltipClasses: '',
|
|
16
|
+
colorType: InputColorType.base,
|
|
17
|
+
expanded: false
|
|
16
18
|
});
|
|
17
19
|
const visible = ref(false);
|
|
18
20
|
const _tooltipClasses = computed(() => ({
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
21
|
+
'absolute w-max inline-flex': true,
|
|
22
|
+
// Position
|
|
23
|
+
'bottom-full pb-3.5': props.position === Position.top,
|
|
24
|
+
'top-full pt-3.5': props.position === Position.bottom,
|
|
25
|
+
'right-full pr-3.5': props.position === Position.left,
|
|
26
|
+
'left-full pl-3.5': props.position === Position.right,
|
|
27
|
+
...classesToObjectSyntax(props.tooltipClasses)
|
|
26
28
|
}));
|
|
27
29
|
const classes = computed(() => ({
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
30
|
+
'z-10 absolute flex': true,
|
|
31
|
+
'top-0 left-0 right-0 -m-[2px] justify-center': props.position === Position.bottom,
|
|
32
|
+
'bottom-0 left-0 right-0 -m-[2px] justify-center': props.position === Position.top,
|
|
33
|
+
'top-0 left-0 bottom-0 -ml-[2.2px] items-center': props.position === Position.right,
|
|
34
|
+
'top-0 right-0 bottom-0 -mr-[2.2px] items-center': props.position === Position.left,
|
|
33
35
|
}));
|
|
34
36
|
const itemContainerClasses = computed(() => ({
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
'relative flex items-center': true,
|
|
38
|
+
'justify-center': props.position === Position.bottom,
|
|
39
|
+
'justify-center rotate-180': props.position === Position.top,
|
|
40
|
+
'justify-center -rotate-90': props.position === Position.right,
|
|
41
|
+
'justify-center rotate-90': props.position === Position.left,
|
|
40
42
|
}));
|
|
41
43
|
const contentClasses = computed(() => {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
44
|
+
const variants: Record<InputColorType, string> = {
|
|
45
|
+
[InputColorType.base]: 'text-for-white-bg-font bg-white border-neutral-300',
|
|
46
|
+
[InputColorType.danger]: 'text-danger-500-font bg-danger-500 border-danger-500',
|
|
47
|
+
[InputColorType.info]: 'text-info-500-font bg-info-500 border-info-500',
|
|
48
|
+
[InputColorType.success]: 'text-success-500-font bg-success-500 border-success-500',
|
|
49
|
+
[InputColorType.warning]: 'text-warning-500-font bg-warning-500 border-warning-500',
|
|
50
|
+
};
|
|
49
51
|
|
|
50
|
-
|
|
52
|
+
return {[variants[props.colorType]]: true};
|
|
51
53
|
});
|
|
52
54
|
const svgPathClasses = computed(() => {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
55
|
+
const variants: Record<InputColorType, string> = {
|
|
56
|
+
[InputColorType.base]: 'fill-white stroke-white',
|
|
57
|
+
[InputColorType.danger]: 'fill-danger-500 stroke-danger-500',
|
|
58
|
+
[InputColorType.info]: 'fill-info-500 stroke-info-500',
|
|
59
|
+
[InputColorType.success]: 'fill-success-500 stroke-success-500',
|
|
60
|
+
[InputColorType.warning]: 'fill-warning-500 stroke-warning-500',
|
|
61
|
+
};
|
|
60
62
|
|
|
61
|
-
|
|
63
|
+
return {[variants[props.colorType]]: true};
|
|
62
64
|
});
|
|
63
65
|
const arrowSvgPathClasses = computed(() => {
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
66
|
+
const variants: Record<InputColorType, string> = {
|
|
67
|
+
[InputColorType.base]: 'stroke-neutral-300',
|
|
68
|
+
[InputColorType.danger]: 'stroke-danger-500',
|
|
69
|
+
[InputColorType.info]: 'stroke-info-500',
|
|
70
|
+
[InputColorType.success]: 'stroke-success-500',
|
|
71
|
+
[InputColorType.warning]: 'stroke-warning-500',
|
|
72
|
+
};
|
|
71
73
|
|
|
72
|
-
|
|
74
|
+
return {[variants[props.colorType]]: true};
|
|
73
75
|
});
|
|
74
76
|
|
|
75
77
|
onMounted(() => {
|
|
76
|
-
|
|
77
|
-
|
|
78
|
+
handleEnumValidation(props.position, Position, 'Position')
|
|
79
|
+
handleEnumValidation(props.colorType, InputColorType, 'colorType')
|
|
78
80
|
});
|
|
79
81
|
|
|
80
82
|
/**
|
|
@@ -84,33 +86,37 @@ onMounted(() => {
|
|
|
84
86
|
const delayVisible = ref(visible.value);
|
|
85
87
|
|
|
86
88
|
function onMouseOver() {
|
|
87
|
-
|
|
89
|
+
delayVisible.value = true;
|
|
88
90
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
91
|
+
setTimeout(() => {
|
|
92
|
+
if (delayVisible.value) {
|
|
93
|
+
visible.value = true
|
|
94
|
+
}
|
|
95
|
+
}, 300)
|
|
94
96
|
}
|
|
95
97
|
|
|
96
98
|
function onMouseLeave() {
|
|
97
|
-
|
|
98
|
-
|
|
99
|
+
delayVisible.value = false
|
|
100
|
+
visible.value = false
|
|
99
101
|
}
|
|
100
102
|
</script>
|
|
101
103
|
|
|
102
104
|
<template>
|
|
103
105
|
<div
|
|
104
|
-
class="relative
|
|
106
|
+
class="relative justify-center items-center"
|
|
107
|
+
:class="{'flex w-full': props.expanded, 'inline-flex': !props.expanded}"
|
|
105
108
|
data-e2e="tooltip"
|
|
106
109
|
@mouseover="onMouseOver"
|
|
107
110
|
@mouseleave="onMouseLeave"
|
|
108
111
|
>
|
|
109
|
-
<slot/>
|
|
112
|
+
<slot />
|
|
110
113
|
|
|
111
|
-
<div
|
|
114
|
+
<div
|
|
115
|
+
v-if="visible && hasSlotContent($slots.content)"
|
|
116
|
+
:class="_tooltipClasses"
|
|
117
|
+
>
|
|
112
118
|
<div
|
|
113
|
-
class="shadow-lg text-sm relative
|
|
119
|
+
class="shadow-lg text-sm relative"
|
|
114
120
|
>
|
|
115
121
|
<div
|
|
116
122
|
:class="classes"
|
|
@@ -157,7 +163,7 @@ function onMouseLeave() {
|
|
|
157
163
|
class="p-2.5 rounded-md border"
|
|
158
164
|
:class="contentClasses"
|
|
159
165
|
>
|
|
160
|
-
<slot name="content"/>
|
|
166
|
+
<slot name="content" />
|
|
161
167
|
</div>
|
|
162
168
|
</div>
|
|
163
169
|
</div>
|
|
@@ -4,3 +4,8 @@ declare const meta: Meta<typeof AntTooltip>;
|
|
|
4
4
|
export default meta;
|
|
5
5
|
type Story = StoryObj<typeof AntTooltip>;
|
|
6
6
|
export declare const Docs: Story;
|
|
7
|
+
/**
|
|
8
|
+
* Make sure, no tooltip get shown if no content is provided.
|
|
9
|
+
*/
|
|
10
|
+
export declare const WithoutContent: Story;
|
|
11
|
+
export declare const Expanded: Story;
|
|
@@ -25,19 +25,41 @@ export const Docs = {
|
|
|
25
25
|
return { args };
|
|
26
26
|
},
|
|
27
27
|
template: `
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
</div>
|
|
38
|
-
`
|
|
28
|
+
<div class="p-32 flex justify-center items-center">
|
|
29
|
+
<AntTooltip v-bind="args">
|
|
30
|
+
<template #content>Lorem ipsum dolor sit amet <br/> foo</template>
|
|
31
|
+
<template #default>
|
|
32
|
+
<AntButton readonly filled expanded>Hover me</AntButton>
|
|
33
|
+
</template>
|
|
34
|
+
</AntTooltip>
|
|
35
|
+
</div>
|
|
36
|
+
`
|
|
39
37
|
}),
|
|
40
38
|
args: {
|
|
41
39
|
position: Position.top
|
|
42
40
|
}
|
|
43
41
|
};
|
|
42
|
+
export const WithoutContent = {
|
|
43
|
+
render: (args) => ({
|
|
44
|
+
components: { AntTooltip, AntButton },
|
|
45
|
+
setup() {
|
|
46
|
+
return { args };
|
|
47
|
+
},
|
|
48
|
+
template: `
|
|
49
|
+
<div class="p-32 flex justify-center items-center">
|
|
50
|
+
<AntTooltip v-bind="args">
|
|
51
|
+
<AntButton readonly filled expanded>Hover me</AntButton>
|
|
52
|
+
|
|
53
|
+
<template #content></template>
|
|
54
|
+
</AntTooltip>
|
|
55
|
+
</div>
|
|
56
|
+
`
|
|
57
|
+
}),
|
|
58
|
+
args: {}
|
|
59
|
+
};
|
|
60
|
+
export const Expanded = {
|
|
61
|
+
render: Docs.render,
|
|
62
|
+
args: {
|
|
63
|
+
expanded: true
|
|
64
|
+
}
|
|
65
|
+
};
|
|
@@ -5,37 +5,64 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import {Grouped} from '../../enums/Grouped.enum';
|
|
7
7
|
import {Size} from '../../enums/Size.enum';
|
|
8
|
-
import {ColorType} from '../../enums/ColorType.enum';
|
|
8
|
+
import {ColorType, InputColorType} from '../../enums/ColorType.enum';
|
|
9
|
+
import {Position} from '../../enums/Position.enum';
|
|
9
10
|
import AntButton from './AntButton.vue';
|
|
11
|
+
import AntTooltip from '../AntTooltip.vue';
|
|
12
|
+
import type {IconDefinition} from '@fortawesome/free-solid-svg-icons';
|
|
10
13
|
|
|
11
14
|
defineEmits(['click', 'blur']);
|
|
12
15
|
withDefaults(
|
|
13
16
|
defineProps<{
|
|
17
|
+
iconLeft?: IconDefinition;
|
|
18
|
+
iconRight?: IconDefinition;
|
|
14
19
|
size?: Size;
|
|
15
20
|
disabled?: boolean;
|
|
16
21
|
grouped?: Grouped;
|
|
17
22
|
colorType?: ColorType;
|
|
18
23
|
skeleton?: boolean;
|
|
19
24
|
expanded?: boolean;
|
|
25
|
+
filled?: boolean;
|
|
26
|
+
hasPermission?: boolean;
|
|
27
|
+
invalidPermissionTooltipPosition?: Position;
|
|
20
28
|
}>(), {
|
|
21
29
|
colorType: ColorType.primary,
|
|
30
|
+
hasPermission: true,
|
|
31
|
+
filled: true
|
|
22
32
|
}
|
|
23
33
|
)
|
|
24
34
|
</script>
|
|
25
35
|
|
|
26
36
|
<template>
|
|
27
|
-
<
|
|
28
|
-
:size="size"
|
|
29
|
-
:disabled="disabled"
|
|
30
|
-
:grouped="grouped"
|
|
31
|
-
:skeleton="skeleton"
|
|
37
|
+
<AntTooltip
|
|
32
38
|
:expanded="expanded"
|
|
33
|
-
:
|
|
34
|
-
|
|
35
|
-
data-e2e="action-button"
|
|
36
|
-
@click="$emit('click')"
|
|
37
|
-
@blur="$emit('blur')"
|
|
39
|
+
:position="invalidPermissionTooltipPosition"
|
|
40
|
+
:color-type="InputColorType.info"
|
|
38
41
|
>
|
|
39
|
-
<slot
|
|
40
|
-
|
|
42
|
+
<slot name="button">
|
|
43
|
+
<AntButton
|
|
44
|
+
:icon-left="iconLeft"
|
|
45
|
+
:icon-right="iconRight"
|
|
46
|
+
:size="size"
|
|
47
|
+
:disabled="disabled || !hasPermission"
|
|
48
|
+
:grouped="grouped"
|
|
49
|
+
:skeleton="skeleton"
|
|
50
|
+
:expanded="expanded"
|
|
51
|
+
:color-type="colorType"
|
|
52
|
+
:filled="filled"
|
|
53
|
+
data-e2e="action-button"
|
|
54
|
+
@click="$emit('click')"
|
|
55
|
+
@blur="$emit('blur')"
|
|
56
|
+
>
|
|
57
|
+
<slot />
|
|
58
|
+
</AntButton>
|
|
59
|
+
</slot>
|
|
60
|
+
|
|
61
|
+
<template
|
|
62
|
+
v-if="!hasPermission && !skeleton"
|
|
63
|
+
#content
|
|
64
|
+
>
|
|
65
|
+
<slot name="invalidPermissionTooltipContent" />
|
|
66
|
+
</template>
|
|
67
|
+
</AntTooltip>
|
|
41
68
|
</template>
|