Blame view

components/alert/alert.vue 2.86 KB
9d69bab6   梁灏   add Alert component
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
  <template>
      <div v-if="!closed" :class="wrapClasses" transition="fade">
          <slot name="icon" v-if="showIcon">
              <span :class="iconClasses">
                  <Icon :type="iconType"></Icon>
              </span>
          </slot>
          <span :class="messageClasses"><slot></slot></span>
          <span :class="descClasses" v-el:desc><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>
  </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
              },
          },
          data () {
              return {
                  closed: false,
                  desc: false
              }
          },
          computed: {
              wrapClasses () {
                  return [
                      `${prefixCls}`,
                      `${prefixCls}-${this.type}`,
                      {
                          [`${prefixCls}-with-icon`]: this.showIcon,
                          [`${prefixCls}-with-desc`]: this.desc
                      }
                  ]
              },
              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);
              }
          },
          compiled () {
              this.desc = this.$els.desc.innerHTML != '';
          }
      }
  </script>