Skip to content

Commit e0bc3ea

Browse files
committed
CRM:线索创建时增加负责人选择框
1 parent 3471b5c commit e0bc3ea

File tree

1 file changed

+23
-5
lines changed

1 file changed

+23
-5
lines changed

src/views/crm/clue/ClueForm.vue

Lines changed: 23 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -27,9 +27,15 @@
2727
<el-form-item label="地址" prop="address">
2828
<el-input v-model="formData.address" placeholder="请输入地址" />
2929
</el-form-item>
30-
<!-- TODO wanwan 负责人选择 -->
31-
<el-form-item label="负责人" prop="ownerUserId">
32-
<el-input v-model="formData.ownerUserId" placeholder="请输入负责人" />
30+
<el-form-item v-if="formType === 'create'" label="负责人" prop="userIds" span="24">
31+
<el-select v-model="formData.ownerUserId">
32+
<el-option
33+
v-for="item in userOptions"
34+
:key="item.id"
35+
:label="item.nickname"
36+
:value="item.id"
37+
/>
38+
</el-select>
3339
</el-form-item>
3440
<el-form-item label="备注" prop="remark">
3541
<el-input v-model="formData.remark" placeholder="请输入备注" />
@@ -43,14 +49,17 @@
4349
</template>
4450
<script setup lang="ts">
4551
import * as ClueApi from '@/api/crm/clue'
52+
import {CACHE_KEY, useCache} from "@/hooks/web/useCache";
53+
import * as UserApi from "@/api/system/user";
4654
4755
const { t } = useI18n() // 国际化
4856
const message = useMessage() // 消息弹窗
4957
5058
const dialogVisible = ref(false) // 弹窗的是否展示
5159
const dialogTitle = ref('') // 弹窗的标题
52-
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
60+
const formLoading = ref(false) // 表单加载中:1)修改时的数据加载;2)提交的按钮禁用
5361
const formType = ref('') // 表单的类型:create - 新增;update - 修改
62+
const userOptions = ref<UserApi.UserVO[]>([]) // 用户列表
5463
const formData = ref({
5564
id: undefined,
5665
name: undefined,
@@ -63,7 +72,8 @@ const formData = ref({
6372
remark: undefined
6473
})
6574
const formRules = reactive({
66-
name: [{ required: true, message: '线索名称不能为空', trigger: 'blur' }]
75+
name: [{ required: true, message: '线索名称不能为空', trigger: 'blur' }],
76+
ownerUserId: [{ required: true, message: '负责人不能为空', trigger: 'blur' }]
6777
})
6878
const formRef = ref() // 表单 Ref
6979
@@ -82,6 +92,14 @@ const open = async (type: string, id?: number) => {
8292
formLoading.value = false
8393
}
8494
}
95+
// 获得用户列表
96+
userOptions.value = await UserApi.getSimpleUserList()
97+
// 新建时负责人默认为登录人
98+
if (formType.value === 'create') {
99+
const { wsCache } = useCache()
100+
const user = wsCache.get(CACHE_KEY.USER).user
101+
formData.value.ownerUserId = user.id
102+
}
85103
}
86104
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
87105

0 commit comments

Comments
 (0)