农作物添加联动
parent
f14d499939
commit
34bb3886a8
|
|
@ -8,10 +8,22 @@
|
||||||
@ok="handleSubmit"
|
@ok="handleSubmit"
|
||||||
>
|
>
|
||||||
<BasicForm @register="registerForm">
|
<BasicForm @register="registerForm">
|
||||||
|
<!-- -->
|
||||||
|
<template #category_id="{ model, field }">
|
||||||
|
<Select
|
||||||
|
v-model:value="model[field]"
|
||||||
|
:options="industryData"
|
||||||
|
placeholder="请选择"
|
||||||
|
@select="select"
|
||||||
|
:fieldNames="{ label: 'name', value: 'id' }"
|
||||||
|
></Select>
|
||||||
|
</template>
|
||||||
|
<!-- -->
|
||||||
<template #parent="{ model, field }">
|
<template #parent="{ model, field }">
|
||||||
<TreeSelect
|
<TreeSelect
|
||||||
v-model:value="model[field]"
|
v-model:value="model[field]"
|
||||||
:tree-data="treeData"
|
:tree-data="treeData"
|
||||||
|
treeDefaultExpandAll
|
||||||
placeholder="请选择"
|
placeholder="请选择"
|
||||||
allowClear
|
allowClear
|
||||||
:fieldNames="{ children: 'children', label: 'name', value: 'id' }"
|
:fieldNames="{ children: 'children', label: 'name', value: 'id' }"
|
||||||
|
|
@ -68,17 +80,24 @@
|
||||||
</BasicDrawer>
|
</BasicDrawer>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { getTreeData } from '/@/utils/index'
|
import { getTreeData, jsonString } from '/@/utils/index'
|
||||||
import { ref, computed, unref } from 'vue'
|
import { ref, computed, unref } from 'vue'
|
||||||
import { BasicForm, useForm } from '/@/components/Form/index'
|
import { BasicForm, useForm } from '/@/components/Form/index'
|
||||||
import { accountFormSchema } from './base.data'
|
import { accountFormSchema } from './base.data'
|
||||||
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'
|
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'
|
||||||
import { TreeSelect, Space, FormItem, Input, Button } from 'ant-design-vue'
|
import { TreeSelect, Space, FormItem, Input, Button, Select } from 'ant-design-vue'
|
||||||
import { addcrops, editcrops, getcrops, agriculturalBasicInfo } from '/@/api/sys/user'
|
import {
|
||||||
|
addcrops,
|
||||||
|
editcrops,
|
||||||
|
getcrops,
|
||||||
|
agriculturalBasicInfo,
|
||||||
|
getCropCate,
|
||||||
|
} from '/@/api/sys/user'
|
||||||
import { MinusCircleOutlined, PlusOutlined } from '@ant-design/icons-vue'
|
import { MinusCircleOutlined, PlusOutlined } from '@ant-design/icons-vue'
|
||||||
const emits = defineEmits(['success', 'register'])
|
const emits = defineEmits(['success', 'register'])
|
||||||
const isUpdate = ref(false)
|
const isUpdate = ref(false)
|
||||||
const treeData = ref([])
|
const treeData = ref([])
|
||||||
|
const industryData = ref<any>([])
|
||||||
const getTitle = computed(() => (!isUpdate.value ? '新增农作物' : '编辑农作物'))
|
const getTitle = computed(() => (!isUpdate.value ? '新增农作物' : '编辑农作物'))
|
||||||
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm({
|
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm({
|
||||||
labelWidth: 100,
|
labelWidth: 100,
|
||||||
|
|
@ -89,17 +108,22 @@
|
||||||
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
|
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
|
||||||
resetFields()
|
resetFields()
|
||||||
setDrawerProps({ confirmLoading: false })
|
setDrawerProps({ confirmLoading: false })
|
||||||
if (unref(treeData).length === 0) {
|
if (unref(industryData).length === 0) {
|
||||||
const res = await getcrops({ type: 'all', crop_type: 1 })
|
// 获取产业数据
|
||||||
treeData.value = getTreeData(res.data, 0, 'parent_id', 'id', 'children', 'key', 0)
|
getIndustry()
|
||||||
|
//获取上级数据
|
||||||
|
getTree()
|
||||||
}
|
}
|
||||||
isUpdate.value = data?.isUpdate
|
isUpdate.value = data?.isUpdate
|
||||||
if (unref(isUpdate)) {
|
if (unref(isUpdate)) {
|
||||||
const res = await agriculturalBasicInfo(data.id)
|
const res = await agriculturalBasicInfo(data.id)
|
||||||
|
//获取上级数据
|
||||||
|
await getTree(res?.category?.id ?? null)
|
||||||
|
const arr1 = jsonString(res.extends) ? JSON.parse(res.extends) : res.extends
|
||||||
await setFieldsValue({
|
await setFieldsValue({
|
||||||
...res,
|
...res,
|
||||||
is_end: res.is_end === 1 ? true : false,
|
is_end: res.is_end === 1 ? true : false,
|
||||||
extends: res.extends.length ? res.extends : [{ name: '', unit: '' }],
|
extends: arr1.length ? arr1 : [{ name: '', unit: '' }],
|
||||||
category_id: res?.category?.id,
|
category_id: res?.category?.id,
|
||||||
parent_id: res.parent_id > 0 ? res.parent_id : undefined,
|
parent_id: res.parent_id > 0 ? res.parent_id : undefined,
|
||||||
})
|
})
|
||||||
|
|
@ -109,6 +133,21 @@
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// 获取产业数据
|
||||||
|
const getIndustry = async () => {
|
||||||
|
const res = await getCropCate()
|
||||||
|
industryData.value = res
|
||||||
|
}
|
||||||
|
const select = (e) => {
|
||||||
|
setFieldsValue({ parent_id: undefined })
|
||||||
|
getTree(e)
|
||||||
|
}
|
||||||
|
// 获取上级数据
|
||||||
|
const getTree = async (category = null) => {
|
||||||
|
const res = await getcrops({ type: 'all', crop_type: 1, category })
|
||||||
|
treeData.value = getTreeData(res.data, 0, 'parent_id', 'id', 'children', 'key', 0)
|
||||||
|
}
|
||||||
const handleSubmit = async () => {
|
const handleSubmit = async () => {
|
||||||
try {
|
try {
|
||||||
const values = await validate()
|
const values = await validate()
|
||||||
|
|
|
||||||
|
|
@ -52,14 +52,15 @@ export const accountFormSchema: FormSchema[] = [
|
||||||
label: '产业',
|
label: '产业',
|
||||||
required: true,
|
required: true,
|
||||||
component: 'ApiSelect',
|
component: 'ApiSelect',
|
||||||
componentProps: {
|
slot: 'category_id',
|
||||||
api: async () => {
|
// componentProps: {
|
||||||
const res = await getCropCate()
|
// api: async () => {
|
||||||
return res
|
// const res = await getCropCate()
|
||||||
},
|
// return res
|
||||||
labelField: 'name',
|
// },
|
||||||
valueField: 'id',
|
// labelField: 'name',
|
||||||
},
|
// valueField: 'id',
|
||||||
|
// },
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
field: 'name',
|
field: 'name',
|
||||||
|
|
|
||||||
|
|
@ -8,11 +8,23 @@
|
||||||
@ok="handleSubmit"
|
@ok="handleSubmit"
|
||||||
>
|
>
|
||||||
<BasicForm @register="registerForm">
|
<BasicForm @register="registerForm">
|
||||||
|
<!-- -->
|
||||||
|
<template #category_id="{ model, field }">
|
||||||
|
<Select
|
||||||
|
v-model:value="model[field]"
|
||||||
|
:options="industryData"
|
||||||
|
placeholder="请选择"
|
||||||
|
@select="select"
|
||||||
|
:fieldNames="{ label: 'name', value: 'id' }"
|
||||||
|
></Select>
|
||||||
|
</template>
|
||||||
|
<!-- -->
|
||||||
<template #parent="{ model, field }">
|
<template #parent="{ model, field }">
|
||||||
<TreeSelect
|
<TreeSelect
|
||||||
v-model:value="model[field]"
|
v-model:value="model[field]"
|
||||||
:tree-data="treeData"
|
:tree-data="treeData"
|
||||||
placeholder="请选择"
|
placeholder="请选择"
|
||||||
|
treeDefaultExpandAll
|
||||||
:fieldNames="{ children: 'children', label: 'name', value: 'id' }"
|
:fieldNames="{ children: 'children', label: 'name', value: 'id' }"
|
||||||
></TreeSelect>
|
></TreeSelect>
|
||||||
</template>
|
</template>
|
||||||
|
|
@ -67,17 +79,24 @@
|
||||||
</BasicDrawer>
|
</BasicDrawer>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import { getTreeData } from '/@/utils/index'
|
import { getTreeData, jsonString } from '/@/utils/index'
|
||||||
import { ref, computed, unref } from 'vue'
|
import { ref, computed, unref } from 'vue'
|
||||||
import { BasicForm, useForm } from '/@/components/Form/index'
|
import { BasicForm, useForm } from '/@/components/Form/index'
|
||||||
import { accountFormSchema } from './town.data'
|
import { accountFormSchema } from './town.data'
|
||||||
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'
|
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'
|
||||||
import { TreeSelect, Space, FormItem, Input, Button } from 'ant-design-vue'
|
import { TreeSelect, Space, FormItem, Input, Button, Select } from 'ant-design-vue'
|
||||||
import { addcrops, editcrops, getcrops, agriculturalBasicInfo } from '/@/api/sys/user'
|
import {
|
||||||
|
addcrops,
|
||||||
|
editcrops,
|
||||||
|
getcrops,
|
||||||
|
agriculturalBasicInfo,
|
||||||
|
getCropCate,
|
||||||
|
} from '/@/api/sys/user'
|
||||||
import { MinusCircleOutlined, PlusOutlined } from '@ant-design/icons-vue'
|
import { MinusCircleOutlined, PlusOutlined } from '@ant-design/icons-vue'
|
||||||
const emits = defineEmits(['success', 'register'])
|
const emits = defineEmits(['success', 'register'])
|
||||||
const isUpdate = ref(false)
|
const isUpdate = ref(false)
|
||||||
const treeData = ref([])
|
const treeData = ref([])
|
||||||
|
const industryData = ref<any>([])
|
||||||
const getTitle = computed(() => (!isUpdate.value ? '新增农作物' : '编辑农作物'))
|
const getTitle = computed(() => (!isUpdate.value ? '新增农作物' : '编辑农作物'))
|
||||||
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm({
|
const [registerForm, { resetFields, setFieldsValue, validate }] = useForm({
|
||||||
labelWidth: 100,
|
labelWidth: 100,
|
||||||
|
|
@ -88,17 +107,22 @@
|
||||||
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
|
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
|
||||||
resetFields()
|
resetFields()
|
||||||
setDrawerProps({ confirmLoading: false })
|
setDrawerProps({ confirmLoading: false })
|
||||||
if (unref(treeData).length === 0) {
|
if (unref(industryData).length === 0) {
|
||||||
const res = await getcrops({ type: 'all', crop_type: 2 })
|
// 获取产业数据
|
||||||
treeData.value = getTreeData(res.data, 0, 'parent_id', 'id', 'children', 'key', 0)
|
getIndustry()
|
||||||
|
//获取上级数据
|
||||||
|
getTree()
|
||||||
}
|
}
|
||||||
isUpdate.value = data?.isUpdate
|
isUpdate.value = data?.isUpdate
|
||||||
if (unref(isUpdate)) {
|
if (unref(isUpdate)) {
|
||||||
const res = await agriculturalBasicInfo(data.id)
|
const res = await agriculturalBasicInfo(data.id)
|
||||||
|
//获取上级数据
|
||||||
|
await getTree(res?.category?.id ?? null)
|
||||||
|
const arr1 = jsonString(res.extends) ? JSON.parse(res.extends) : res.extends
|
||||||
await setFieldsValue({
|
await setFieldsValue({
|
||||||
...res,
|
...res,
|
||||||
is_end: res.is_end === 1 ? true : false,
|
is_end: res.is_end === 1 ? true : false,
|
||||||
extends: res.extends.length ? res.extends : [{ name: '', unit: '' }],
|
extends: arr1.length ? arr1 : [{ name: '', unit: '' }],
|
||||||
category_id: res?.category?.id,
|
category_id: res?.category?.id,
|
||||||
parent_id: res.parent_id > 0 ? res.parent_id : undefined,
|
parent_id: res.parent_id > 0 ? res.parent_id : undefined,
|
||||||
})
|
})
|
||||||
|
|
@ -108,6 +132,20 @@
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
// 获取产业数据
|
||||||
|
const getIndustry = async () => {
|
||||||
|
const res = await getCropCate()
|
||||||
|
industryData.value = res
|
||||||
|
}
|
||||||
|
const select = (e) => {
|
||||||
|
setFieldsValue({ parent_id: undefined })
|
||||||
|
getTree(e)
|
||||||
|
}
|
||||||
|
// 获取上级数据
|
||||||
|
const getTree = async (category = null) => {
|
||||||
|
const res = await getcrops({ type: 'all', crop_type: 2, category })
|
||||||
|
treeData.value = getTreeData(res.data, 0, 'parent_id', 'id', 'children', 'key', 0)
|
||||||
|
}
|
||||||
const handleSubmit = async () => {
|
const handleSubmit = async () => {
|
||||||
try {
|
try {
|
||||||
const values = await validate()
|
const values = await validate()
|
||||||
|
|
|
||||||
|
|
@ -52,14 +52,15 @@ export const accountFormSchema: FormSchema[] = [
|
||||||
label: '产业',
|
label: '产业',
|
||||||
required: true,
|
required: true,
|
||||||
component: 'ApiSelect',
|
component: 'ApiSelect',
|
||||||
componentProps: {
|
slot: 'category_id',
|
||||||
api: async () => {
|
// componentProps: {
|
||||||
const res = await getCropCate()
|
// api: async () => {
|
||||||
return res
|
// const res = await getCropCate()
|
||||||
},
|
// return res
|
||||||
labelField: 'name',
|
// },
|
||||||
valueField: 'id',
|
// labelField: 'name',
|
||||||
},
|
// valueField: 'id',
|
||||||
|
// },
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
field: 'name',
|
field: 'name',
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue