Blame view

src/ui/vant-weapp/popup/index.js 1.9 KB
simon committed
1 2 3 4 5 6 7 8 9 10 11
import { VantComponent } from '../common/component';
import { transition } from '../mixins/transition';
VantComponent({
    classes: [
        'enter-class',
        'enter-active-class',
        'enter-to-class',
        'leave-class',
        'leave-active-class',
        'leave-to-class'
    ],
simon committed
12
    mixins: [transition(false)],
simon committed
13
    props: {
simon committed
14 15 16 17
        round: Boolean,
        closeable: Boolean,
        customStyle: String,
        overlayStyle: String,
simon committed
18 19 20 21 22 23 24 25 26 27 28 29
        transition: {
            type: String,
            observer: 'observeClass'
        },
        zIndex: {
            type: Number,
            value: 100
        },
        overlay: {
            type: Boolean,
            value: true
        },
simon committed
30 31 32 33 34 35 36 37
        closeIcon: {
            type: String,
            value: 'cross'
        },
        closeIconPosition: {
            type: String,
            value: 'top-right'
        },
simon committed
38 39 40 41 42 43 44 45
        closeOnClickOverlay: {
            type: Boolean,
            value: true
        },
        position: {
            type: String,
            value: 'center',
            observer: 'observeClass'
simon committed
46 47 48 49 50 51 52 53
        },
        safeAreaInsetBottom: {
            type: Boolean,
            value: true
        },
        safeAreaInsetTop: {
            type: Boolean,
            value: false
simon committed
54 55 56 57 58 59
        }
    },
    created() {
        this.observeClass();
    },
    methods: {
simon committed
60 61 62
        onClickCloseIcon() {
            this.$emit('close');
        },
simon committed
63 64 65 66 67 68 69 70
        onClickOverlay() {
            this.$emit('click-overlay');
            if (this.data.closeOnClickOverlay) {
                this.$emit('close');
            }
        },
        observeClass() {
            const { transition, position } = this.data;
simon committed
71 72 73
            const updateData = {
                name: transition || position
            };
simon committed
74
            if (transition === 'none') {
simon committed
75
                updateData.duration = 0;
simon committed
76
            }
simon committed
77
            this.setData(updateData);
simon committed
78 79 80
        }
    }
});