diff --git a/src/views/crm/clue/ClueForm.vue b/src/views/crm/clue/ClueForm.vue index 1b2637c9..efb36045 100644 --- a/src/views/crm/clue/ClueForm.vue +++ b/src/views/crm/clue/ClueForm.vue @@ -10,17 +10,6 @@ <el-form-item label="线索名称" prop="name"> <el-input v-model="formData.name" placeholder="请输入线索名称" /> </el-form-item> - <!-- TODO 芋艿:后续客户的选择 --> - <el-form-item label="客户" prop="customerId"> - <el-select v-model="formData.customerId" clearable placeholder="请选择客户"> - <el-option - v-for="item in customerList" - :key="item.id" - :label="item.name" - :value="item.id" - /> - </el-select> - </el-form-item> <el-form-item label="下次联系时间" prop="contactNextTime"> <el-date-picker v-model="formData.contactNextTime" @@ -38,9 +27,15 @@ <el-form-item label="地址" prop="address"> <el-input v-model="formData.address" placeholder="请输入地址" /> </el-form-item> - <!-- TODO wanwan 负责人选择 --> - <el-form-item label="负责人" prop="ownerUserId"> - <el-input v-model="formData.ownerUserId" placeholder="请输入负责人" /> + <el-form-item v-if="formType === 'create'" label="负责人" prop="userIds" span="24"> + <el-select v-model="formData.ownerUserId"> + <el-option + v-for="item in userOptions" + :key="item.id" + :label="item.nickname" + :value="item.id" + /> + </el-select> </el-form-item> <el-form-item label="备注" prop="remark"> <el-input v-model="formData.remark" placeholder="请输入备注" /> @@ -54,20 +49,20 @@ </template> <script setup lang="ts"> import * as ClueApi from '@/api/crm/clue' -import * as CustomerApi from '@/api/crm/customer' +import {CACHE_KEY, useCache} from "@/hooks/web/useCache"; +import * as UserApi from "@/api/system/user"; const { t } = useI18n() // 国际化 const message = useMessage() // 消息弹窗 const dialogVisible = ref(false) // 弹窗的是否展示 const dialogTitle = ref('') // 弹窗的标题 -const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用 +const formLoading = ref(false) // 表单加载中:1)修改时的数据加载;2)提交的按钮禁用 const formType = ref('') // 表单的类型:create - 新增;update - 修改 -const customerList = ref([]) // 客户列表 +const userOptions = ref<UserApi.UserVO[]>([]) // 用户列表 const formData = ref({ id: undefined, name: undefined, - customerId: undefined, contactNextTime: undefined, telephone: undefined, mobile: undefined, @@ -78,7 +73,7 @@ const formData = ref({ }) const formRules = reactive({ name: [{ required: true, message: '线索名称不能为空', trigger: 'blur' }], - customerId: [{ required: true, message: '客户不能为空', trigger: 'blur' }] + ownerUserId: [{ required: true, message: '负责人不能为空', trigger: 'blur' }] }) const formRef = ref() // 表单 Ref @@ -88,12 +83,6 @@ const open = async (type: string, id?: number) => { dialogTitle.value = t('action.' + type) formType.value = type resetForm() - const customerData = await CustomerApi.getCustomerPage({ - pageNo: 1, - pageSize: 100, - pool: false - }) - customerList.value = customerData.list // 修改时,设置数据 if (id) { formLoading.value = true @@ -103,6 +92,14 @@ const open = async (type: string, id?: number) => { formLoading.value = false } } + // 获得用户列表 + userOptions.value = await UserApi.getSimpleUserList() + // 新建时负责人默认为登录人 + if (formType.value === 'create') { + const { wsCache } = useCache() + const user = wsCache.get(CACHE_KEY.USER).user + formData.value.ownerUserId = user.id + } } defineExpose({ open }) // 提供 open 方法,用于打开弹窗 @@ -137,7 +134,6 @@ const resetForm = () => { formData.value = { id: undefined, name: undefined, - customerId: undefined, contactNextTime: undefined, telephone: undefined, mobile: undefined,