9d69bab6
梁灏
add Alert component
|
1
|
<template>
|
5d122b37
梁灏
support Alert
|
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<transition name="fade">
<div v-if="!closed" :class="wrapClasses">
<span :class="iconClasses" v-if="showIcon">
<slot name="icon">
<Icon :type="iconType"></Icon>
</slot>
</span>
<span :class="messageClasses"><slot></slot></span>
<span :class="descClasses"><slot name="desc"></slot></span>
<a :class="closeClasses" v-if="closable" @click="close">
<slot name="close">
<Icon type="ios-close-empty"></Icon>
</slot>
</a>
</div>
</transition>
|
9d69bab6
梁灏
add Alert component
|
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
</template>
<script>
import Icon from '../icon';
import { oneOf } from '../../utils/assist';
const prefixCls = 'ivu-alert';
export default {
components: { Icon },
props: {
type: {
validator (value) {
return oneOf(value, ['success', 'info', 'warning', 'error']);
},
default: 'info'
},
closable: {
type: Boolean,
default: false
},
showIcon: {
type: Boolean,
default: false
|
e49f7963
梁灏
Alert add banner ...
|
41
42
43
44
|
},
banner: {
type: Boolean,
default: false
|
5d122b37
梁灏
support Alert
|
45
|
}
|
9d69bab6
梁灏
add Alert component
|
46
47
48
49
50
|
},
data () {
return {
closed: false,
desc: false
|
b0893113
jingsam
add eslint
|
51
|
};
|
9d69bab6
梁灏
add Alert component
|
52
53
54
55
56
57
58
59
|
},
computed: {
wrapClasses () {
return [
`${prefixCls}`,
`${prefixCls}-${this.type}`,
{
[`${prefixCls}-with-icon`]: this.showIcon,
|
e49f7963
梁灏
Alert add banner ...
|
60
61
|
[`${prefixCls}-with-desc`]: this.desc,
[`${prefixCls}-with-banner`]: this.banner
|
9d69bab6
梁灏
add Alert component
|
62
|
}
|
b0893113
jingsam
add eslint
|
63
|
];
|
9d69bab6
梁灏
add Alert component
|
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
},
messageClasses () {
return `${prefixCls}-message`;
},
descClasses () {
return `${prefixCls}-desc`;
},
closeClasses () {
return `${prefixCls}-close`;
},
iconClasses () {
return `${prefixCls}-icon`;
},
iconType () {
let type = '';
switch (this.type) {
case 'success':
type = 'checkmark-circled';
break;
case 'info':
type = 'information-circled';
break;
case 'warning':
type = 'android-alert';
break;
case 'error':
type = 'close-circled';
break;
}
return type;
}
},
methods: {
close (e) {
this.closed = true;
this.$emit('on-close', e);
}
},
|
5d122b37
梁灏
support Alert
|
104
105
|
mounted () {
this.desc = this.$slots.desc !== undefined;
|
9d69bab6
梁灏
add Alert component
|
106
|
}
|
b0893113
jingsam
add eslint
|
107
108
|
};
</script>
|