Skip to content

Commit bc934f5

Browse files
YunaiVgitee-org
authored andcommitted
!370 CRM线索
Merge pull request !370 from Minh-X/dev
2 parents 66ff10d + e0bc3ea commit bc934f5

File tree

1 file changed

+22
-26
lines changed

1 file changed

+22
-26
lines changed

src/views/crm/clue/ClueForm.vue

Lines changed: 22 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -10,17 +10,6 @@
1010
<el-form-item label="线索名称" prop="name">
1111
<el-input v-model="formData.name" placeholder="请输入线索名称" />
1212
</el-form-item>
13-
<!-- TODO 芋艿:后续客户的选择 -->
14-
<el-form-item label="客户" prop="customerId">
15-
<el-select v-model="formData.customerId" clearable placeholder="请选择客户">
16-
<el-option
17-
v-for="item in customerList"
18-
:key="item.id"
19-
:label="item.name"
20-
:value="item.id"
21-
/>
22-
</el-select>
23-
</el-form-item>
2413
<el-form-item label="下次联系时间" prop="contactNextTime">
2514
<el-date-picker
2615
v-model="formData.contactNextTime"
@@ -38,9 +27,15 @@
3827
<el-form-item label="地址" prop="address">
3928
<el-input v-model="formData.address" placeholder="请输入地址" />
4029
</el-form-item>
41-
<!-- TODO wanwan 负责人选择 -->
42-
<el-form-item label="负责人" prop="ownerUserId">
43-
<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>
4439
</el-form-item>
4540
<el-form-item label="备注" prop="remark">
4641
<el-input v-model="formData.remark" placeholder="请输入备注" />
@@ -54,20 +49,20 @@
5449
</template>
5550
<script setup lang="ts">
5651
import * as ClueApi from '@/api/crm/clue'
57-
import * as CustomerApi from '@/api/crm/customer'
52+
import {CACHE_KEY, useCache} from "@/hooks/web/useCache";
53+
import * as UserApi from "@/api/system/user";
5854
5955
const { t } = useI18n() // 国际化
6056
const message = useMessage() // 消息弹窗
6157
6258
const dialogVisible = ref(false) // 弹窗的是否展示
6359
const dialogTitle = ref('') // 弹窗的标题
64-
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
60+
const formLoading = ref(false) // 表单加载中:1)修改时的数据加载;2)提交的按钮禁用
6561
const formType = ref('') // 表单的类型:create - 新增;update - 修改
66-
const customerList = ref([]) // 客户列表
62+
const userOptions = ref<UserApi.UserVO[]>([]) // 用户列表
6763
const formData = ref({
6864
id: undefined,
6965
name: undefined,
70-
customerId: undefined,
7166
contactNextTime: undefined,
7267
telephone: undefined,
7368
mobile: undefined,
@@ -78,7 +73,7 @@ const formData = ref({
7873
})
7974
const formRules = reactive({
8075
name: [{ required: true, message: '线索名称不能为空', trigger: 'blur' }],
81-
customerId: [{ required: true, message: '客户不能为空', trigger: 'blur' }]
76+
ownerUserId: [{ required: true, message: '负责人不能为空', trigger: 'blur' }]
8277
})
8378
const formRef = ref() // 表单 Ref
8479
@@ -88,12 +83,6 @@ const open = async (type: string, id?: number) => {
8883
dialogTitle.value = t('action.' + type)
8984
formType.value = type
9085
resetForm()
91-
const customerData = await CustomerApi.getCustomerPage({
92-
pageNo: 1,
93-
pageSize: 100,
94-
pool: false
95-
})
96-
customerList.value = customerData.list
9786
// 修改时,设置数据
9887
if (id) {
9988
formLoading.value = true
@@ -103,6 +92,14 @@ const open = async (type: string, id?: number) => {
10392
formLoading.value = false
10493
}
10594
}
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+
}
106103
}
107104
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
108105
@@ -137,7 +134,6 @@ const resetForm = () => {
137134
formData.value = {
138135
id: undefined,
139136
name: undefined,
140-
customerId: undefined,
141137
contactNextTime: undefined,
142138
telephone: undefined,
143139
mobile: undefined,

0 commit comments

Comments
 (0)