Blame view

src/components/dropdown/dropdown.vue 2.65 KB
ab8aaf95   梁灏   add Dropdown comp...
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
  <template>
      <div
          :class="[prefixCls]"
          @click="handleClick"
          @mouseenter="handleMouseenter"
          @mouseleave="handleMouseleave"
          v-clickoutside="handleClose">
          <div :class="[prefixCls-rel]" v-el:reference><slot></slot></div>
          <Drop v-show="visible" :placement="placement" transition="slide-up"><slot name="list"></slot></Drop>
      </div>
  </template>
  <script>
      import Drop from '../select/dropdown.vue';
      import clickoutside from '../../directives/clickoutside';
      import { oneOf } from '../../utils/assist';
  
      const prefixCls = 'ivu-dropdown';
  
      export default {
          directives: { clickoutside },
          components: { Drop },
          props: {
              trigger: {
                  validator (value) {
                      return oneOf(value, ['click', 'hover']);
                  },
                  default: 'hover'
              },
              align: {
                  validator (value) {
                      return oneOf(value, ['left', 'center', 'right']);
                  },
                  default: 'center'
              }
          },
          data () {
              return {
                  prefixCls: prefixCls,
                  visible: false
              }
          },
          computed: {
              placement () {
                  return this.align === 'left' ? 'bottom-start' : this.align === 'center' ? 'bottom' : 'bottom-end';
              }
          },
          methods: {
              handleClick () {
                  if (this.trigger !== 'click') {
                      return false;
                  }
                  this.visible = !this.visible;
              },
              handleMouseenter () {
                  if (this.trigger !== 'hover') {
                      return false;
                  }
                  clearTimeout(this.timeout);
                  this.timeout = setTimeout(() => {
                      this.visible = true;
                  }, 250);
              },
              handleMouseleave () {
                  if (this.trigger !== 'hover') {
                      return false;
                  }
                  clearTimeout(this.timeout);
                  this.timeout = setTimeout(() => {
                      this.visible = false;
                  }, 150);
              },
              handleClose () {
                  if (this.trigger !== 'click') {
                      return false;
                  }
                  this.visible = false;
              }
          },
          watch: {
              visible (val) {
                  if (val) {
                      this.$broadcast('on-update-popper');
                  } else {
                      this.$broadcast('on-destroy-popper');
                  }
              }
          }
      }
  </script>