Files
dvcp_v2_wxcp_app/src/components/AiPagePicker.vue

74 lines
1.8 KiB
Vue
Raw Normal View History

2021-12-24 12:05:40 +08:00
<template>
<section class="AiPagePicker">
<div @click="handleJump">
<slot v-if="$slots.default"/>
<div v-else v-text="selectedLabel"/>
</div>
</section>
</template>
<script>
2022-02-11 12:05:02 +08:00
import qs from 'query-string'
2021-12-24 12:05:40 +08:00
export default {
name: "AiPagePicker",
model: {
prop: "value",
event: "change"
},
props: {
value: {default: ""},
type: {default: "resident"},
2021-12-24 13:58:43 +08:00
nodeKey: {default: "idNumber"},
2021-12-24 12:05:40 +08:00
selected: {default: () => []},
2022-05-04 19:32:49 +08:00
placeholder: {default: "选择人员"},
ops: {default: () => ({})}
2021-12-24 12:05:40 +08:00
},
data() {
return {
configList: {
2022-02-11 11:20:57 +08:00
resident: {url: "/components/pages/selectResident", label: "name"},
2022-06-01 18:22:19 +08:00
sysUser: {url: "/components/pages/selectSysUser", label: "name"},
2022-04-18 16:47:07 +08:00
gird: {url: "/components/pages/selectGird", label: "girdName"},
2022-05-04 19:32:49 +08:00
party: {url: "/components/pages/selectParty", label: "name"},
custom: {...this.ops}
2021-12-24 12:05:40 +08:00
},
}
},
computed: {
config() {
return this.configList[this.type] || {}
},
selectedLabel() {
let {placeholder, config: {label}} = this
return this.selected?.map(e => e[label])?.toString() || placeholder
}
},
methods: {
handleJump() {
let {config, nodeKey} = this,
selected = this.value || this.selected?.map(e => e[nodeKey])
2022-03-17 16:57:26 +08:00
uni.$once('pagePicker:' + this.type, data => {
2022-05-04 19:32:49 +08:00
console.log('发送', data)
2021-12-24 12:05:40 +08:00
this.$emit("update:selected", data)
2022-02-11 11:20:57 +08:00
this.$emit("select", data)
2022-05-06 19:23:48 +08:00
this.$emit("change", data ? [data].flat()?.map(e => e[nodeKey]) : "")
2021-12-24 12:05:40 +08:00
})
2022-02-11 12:05:02 +08:00
let url = `${config.url}`,
qsstr = qs.stringify({
2022-06-01 18:22:19 +08:00
selected, nodeKey, ...this.$attrs
2022-02-11 12:05:02 +08:00
})
if (!!qsstr) {
url += `?${qsstr}`
}
uni.navigateTo({url})
2021-12-24 12:05:40 +08:00
}
}
}
</script>
<style lang="scss" scoped>
.AiPagePicker {
}
</style>