Files
dvcp_v2_wxcp_app/src/components/AiPagePicker.vue

81 lines
2.2 KiB
Vue
Raw Normal View History

2021-12-24 12:05:40 +08:00
<template>
<section class="AiPagePicker">
<div @click="handleJump">
2022-07-20 16:46:10 +08:00
<slot v-if="$scopedSlots.default" :selected="pickList"/>
2021-12-24 12:05:40 +08:00
<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"},
2022-06-15 15:46:31 +08:00
isRequire: {default: 1},
2022-11-17 15:34:48 +08:00
isShowPhone: {default: ''},
2021-12-24 12:05:40 +08:00
selected: {default: () => []},
2022-05-04 19:32:49 +08:00
placeholder: {default: "选择人员"},
2022-06-08 15:33:49 +08:00
ops: {default: () => ({})},
valueObj: Boolean
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"},
2023-03-06 18:16:47 +08:00
gridUser: {url: "/components/pages/selectGridMember", label: "name"},
2022-05-04 19:32:49 +08:00
party: {url: "/components/pages/selectParty", label: "name"},
2022-06-14 11:07:50 +08:00
dept: {url: "/components/pages/selectDept", label: "name"},
2022-05-04 19:32:49 +08:00
custom: {...this.ops}
2021-12-24 12:05:40 +08:00
},
2022-07-20 16:46:10 +08:00
pickList: []
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() {
2022-11-17 15:34:48 +08:00
let {config, nodeKey, valueObj, isRequire, isShowPhone} = this,
2022-06-08 15:33:49 +08:00
selected = (valueObj ? this.value[nodeKey] : 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)
2022-07-20 16:46:10 +08:00
this.pickList = 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-06-08 15:33:49 +08:00
this.$emit("change", valueObj ? data : 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-11-17 15:34:48 +08:00
selected, nodeKey, isRequire, isShowPhone, ...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>