jiangping
2023-08-18 6c2d51a68d4dc59415d92fb8f60a16726d62951f
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
102
103
104
105
106
107
108
109
110
111
112
113
<template>
  <el-cascader
    v-if="visible"
    :props="props"
    :placeholder="placeholder"
    v-model="value"
    :clearable="clearable"
    @change="$emit('change')"
    @input="handleInput"
  ></el-cascader>
</template>
 
<script>
import { fetchByParentId } from '@/api/system/location'
 
export default {
  name: 'LocationSelect',
  props: {
    placeholder: {
      default: '请选择地区'
    },
    level: {
      default: 3
    },
    clearable: {
      default: false
    },
    // 省
    provinceId: {},
    // 市
    cityId: {},
    // 区
    areaId: {}
  },
  data () {
    const vm = this
    return {
      // 是否展示,用于重新初始化cascader
      visible: true,
      // 已选值
      value: [],
      // 组件配置
      props: {
        lazy: true,
        lazyLoad (node, resolve) {
          const { level } = node
          fetchByParentId(level === 0 ? -1 : node.value)
            .cache()
            .then(data => {
              resolve(data.map(item => {
                return {
                  label: item.name,
                  value: item.id,
                  leaf: level >= vm.level - 1
                }
              }))
            })
            .catch(e => {
              vm.$tip.apiFailed(e)
            })
        }
      }
    }
  },
  watch: {
    provinceId (newValue) {
      this.value[0] = newValue
      if (this.level === 1) {
        if (newValue == null) {
          this.value = []
        }
        this.__rebuild()
      }
    },
    cityId (newValue) {
      if (this.level >= 2) {
        this.value[1] = newValue
      }
      if (this.level === 2) {
        if (newValue == null) {
          this.value = []
        }
        this.__rebuild()
      }
    },
    areaId (newValue) {
      if (this.level >= 3) {
        this.value[2] = newValue
      }
      if (this.level === 3) {
        if (newValue == null) {
          this.value = []
        }
        this.__rebuild()
      }
    }
  },
  methods: {
    handleInput (values) {
      this.$emit('update:province-id', values[0])
      this.$emit('update:city-id', values[1])
      this.$emit('update:area-id', values[2])
    },
    // 重新初始化cascader
    __rebuild () {
      this.visible = false
      this.$nextTick(() => {
        this.visible = true
      })
    }
  }
}
</script>