1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
| import type { PropType } from 'vue';
|
| import { defineComponent, Transition, TransitionGroup } from 'vue';
| import { getSlot } from '@/utils/helper/tsxHelper';
|
| type Mode = 'in-out' | 'out-in' | 'default' | undefined;
|
| export function createSimpleTransition(name: string, origin = 'top center 0', mode?: Mode) {
| return defineComponent({
| name,
| props: {
| group: {
| type: Boolean as PropType<boolean>,
| default: false,
| },
| mode: {
| type: String as PropType<Mode>,
| default: mode,
| },
| origin: {
| type: String as PropType<string>,
| default: origin,
| },
| },
| setup(props, { slots, attrs }) {
| const onBeforeEnter = (el: Element) => {
| (el as HTMLElement).style.transformOrigin = props.origin;
| };
|
| return () => {
| const Tag = !props.group ? Transition : TransitionGroup;
| return (
| <Tag name={name} mode={props.mode} {...attrs} onBeforeEnter={onBeforeEnter}>
| {() => getSlot(slots)}
| </Tag>
| );
| };
| },
| });
| }
| export function createJavascriptTransition(
| name: string,
| functions: Recordable,
| mode: Mode = 'in-out',
| ) {
| return defineComponent({
| name,
| props: {
| mode: {
| type: String as PropType<Mode>,
| default: mode,
| },
| },
| setup(props, { attrs, slots }) {
| return () => {
| return (
| <Transition
| name={name}
| mode={props.mode}
| {...attrs}
| onBeforeEnter={functions.beforeEnter}
| onEnter={functions.enter}
| onLeave={functions.leave}
| onAfterLeave={functions.afterLeave}
| onLeaveCancelled={functions.afterLeave}
| >
| {() => getSlot(slots)}
| </Transition>
| );
| };
| },
| });
| }
|
|