index.vue
1.62 KB
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
74
75
76
77
78
79
<template>
<div class="zui-landscape" :class="{ 'is-full': fullScreen }">
<zui-popup
v-model="isLandscapeShow"
:mask-closable="maskClosable"
prevent-scroll
prevent-scroll-exclude=".zui-landscape-content"
:has-mask="!fullScreen && hasMask"
:transition="transition"
@input="$emit('input', false)"
@show="$emit('show')"
@hide="$emit('hide')"
>
<div class="zui-landscape-body" :class="{ scroll }" @click="$_click">
<div class="zui-landscape-content">
<slot></slot>
</div>
<zui-icon class="zui-landscape-close" :class="{ dark: !hasMask || fullScreen }" @click="$_close" :name="fullScreen ? 'close' : 'close'" />
</div>
</zui-popup>
</div>
</template>
<script>
export default {
name: 'Landscape',
props: {
value: {
type: Boolean,
default: false,
},
scroll: {
type: Boolean,
default: false,
},
fullScreen: {
type: Boolean,
default: false,
},
hasMask: {
type: Boolean,
default: true,
},
maskClosable: {
type: Boolean,
default: false,
},
transition: {
type: String,
default() {
return this.fullScreen ? 'zui-fade' : 'zui-punch';
},
},
},
data() {
return {
isLandscapeShow: this.value,
};
},
watch: {
value(val) {
this.isLandscapeShow = val;
},
},
methods: {
// MARK: private methods
$_close() {
this.isLandscapeShow = false;
},
$_click() {
this.$emit('click');
},
},
};
</script>
<style lang="scss">
@import './index.scss';
</style>