aboutsummaryrefslogtreecommitdiff
path: root/src/site/components/grid/waterfall/old/waterfall-slot.vue
blob: 07ca26875b3511401b380702a3c90c27e7e76465 (plain) (blame)
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
<template>
  <div class="vue-waterfall-slot" v-show="isShow">
    <slot></slot>
  </div>
</template>

<style>
.vue-waterfall-slot {
  position: absolute;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
</style>

<script>

export default {
  data: () => ({
    isShow: false
  }),
  props: {
    width: {
      required: true,
      validator: (val) => val >= 0
    },
    height: {
      required: true,
      validator: (val) => val >= 0
    },
    order: {
      default: 0
    },
    moveClass: {
      default: ''
    }
  },
  methods: {
    notify () {
      this.$parent.$emit('reflow', this)
    },
    getMeta () {
      return {
        vm: this,
        node: this.$el,
        order: this.order,
        width: this.width,
        height: this.height,
        moveClass: this.moveClass
      }
    }
  },
  created () {
    this.rect = {
      top: 0,
      left: 0,
      width: 0,
      height: 0
    }
    this.$watch(() => (
      this.width,
      this.height
    ), this.notify)
  },
  mounted () {
    this.$parent.$once('reflowed', () => {
      this.isShow = true
    })
    this.notify()
  },
  destroyed () {
    this.notify()
  }
}

</script>