fix: 客户人员-多选表单、日期表单问题修复

This commit is contained in:
wangzhuo
2025-09-01 13:46:13 +08:00
parent c10a0be121
commit ca7572c542
5 changed files with 198 additions and 75 deletions

View File

@@ -168,8 +168,8 @@
<uni-forms-item label="爱好" name="hobby" class="uni-forms-item is-direction-top is-top">
<!-- 索引hobbyIndex 范围hobbyList 响应handleHobbyChange-->
<uni-easyinput v-model="formData.hobby" placeholder="请输入爱好" :disabled="!editable"/>
<multipleSelect :multiple="true" :value="hobbyIndex" downInner :options="hobbyList"
@change="handleHobbyChange" :slabel="'name'"
<multipleSelect ref="hobbySelectRef" :multiple="true" downInner :value="hobbyIds" :options="hobbyList"
@change="handleHobbyChange" :slabel="'name'"
></multipleSelect><!--placeholder="请选择爱好标签"-->
</uni-forms-item>
@@ -467,20 +467,29 @@ let handleThinkLevelChange = (e) => {
// 系统推荐等级
let recommendLevel = ref("");
let getRecommendLevel = async () => {
if (formData.value.cusEstate && formData.value.functionalRequirements) {
if (formData.value.cusEstate) {
let {cusEstate, functionalRequirements} = formData.value;
let param = {cusEstate, functionalRequirements};
if (formData.value.salesmanThinkLevel) {
param.personnelLevel = formData.value.salesmanThinkLevel;
}
let res = await getCustomerLevel(param).catch(err => {
let res = await getCustomerLevel(param)
/*.catch(err => {
console.error(err, "客户的系统推荐等级获取失败")
})
if (!res.systemRecommendationLevel) {
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
console.log(formData.value.systemThinkLevel + "???")
})*/
try{
if(res.data.systemRecommendationLevel){
formData.value.systemThinkLevel = res.data.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐";
}
}catch(e){
if (res.systemRecommendationLevel) {
formData.value.systemThinkLevel = res.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
}
}
formData.value.systemThinkLevel = res.systemRecommendationLevel;
} else {
recommendLevel.value = "无公司等级信息,无法推荐等级";
}
@@ -509,8 +518,7 @@ let handleUserTypeChange = (e) => {
// 选择日期
function handleTenureTimeChange(e) {
let {value} = e.detail;
formData.value.tenureTime = value;
formData.value.tenureTime = e;
}
// 需求层次索引
@@ -533,16 +541,16 @@ let handleDevelopChange = e => {
// 选择生日
function handleBirthdayChange(e) {
let{value} = e.detail
formData.value.birthday = value;
formData.value.birthday = e;
}
// 爱好标签索引
let hobbyIndex = reactive([]);
let hobbyIds = ref([]);
let hobbies = ref([]);
// 选择爱好标签
const handleHobbyChange = (item, value) => {
// console.log("爱好", item, value);
hobbyIndex = value;
const handleHobbyChange = (items, ids) => {
hobbyIds.value = [];
hobbies.value = items;
};
// 选择
const handleNativeChange = (e) => {

View File

@@ -1,3 +1,8 @@
<!--
* @author wangzhuo
* @date 2025年9月1日
* @description 编辑客户人员信息
-->
<template>
<view class="con-body">
<view class="con-bg">
@@ -168,8 +173,8 @@
<uni-forms-item label="爱好" name="hobby" class="uni-forms-item is-direction-top is-top">
<!-- 索引hobbyIndex 范围hobbyList 响应handleHobbyChange-->
<uni-easyinput v-model="formData.hobby" placeholder="请输入爱好"/>
<multipleSelect :multiple="true" :value="hobbyIndex" downInner :options="hobbyList"
@change="handleHobbyChange" :slabel="'name'"
<multipleSelect ref="hobbySelectRef" :multiple="true" downInner :value="hobbyIds" :options="hobbyList"
@change="handleHobbyChange" :slabel="'name'"
></multipleSelect><!--placeholder="请选择爱好标签"-->
</uni-forms-item>
@@ -468,20 +473,29 @@ let handleThinkLevelChange = (e) => {
// 系统推荐等级
let recommendLevel = ref("");
let getRecommendLevel = async () => {
if (formData.value.cusEstate && formData.value.functionalRequirements) {
if (formData.value.cusEstate) {
let {cusEstate, functionalRequirements} = formData.value;
let param = {cusEstate, functionalRequirements};
if (formData.value.salesmanThinkLevel) {
param.personnelLevel = formData.value.salesmanThinkLevel;
}
let res = await getCustomerLevel(param).catch(err => {
let res = await getCustomerLevel(param)
/*.catch(err => {
console.error(err, "客户的系统推荐等级获取失败")
})
if (!res.systemRecommendationLevel) {
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
console.log(formData.value.systemThinkLevel + "???")
})*/
try{
if(res.data.systemRecommendationLevel){
formData.value.systemThinkLevel = res.data.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐";
}
}catch(e){
if (res.systemRecommendationLevel) {
formData.value.systemThinkLevel = res.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
}
}
formData.value.systemThinkLevel = res.systemRecommendationLevel;
} else {
recommendLevel.value = "无公司等级信息,无法推荐等级";
}
@@ -510,8 +524,7 @@ let handleUserTypeChange = (e) => {
// 选择日期
function handleTenureTimeChange(e) {
let {value} = e.detail;
formData.value.tenureTime = value;
formData.value.tenureTime = e;
}
// 需求层次索引
@@ -534,17 +547,19 @@ let handleDevelopChange = e => {
// 选择生日
function handleBirthdayChange(e) {
let{value} = e.detail
formData.value.birthday = value;
formData.value.birthday = e;
}
// 爱好标签索引
let hobbyIndex = reactive([]);
let hobbyIds = ref([]);
let hobbies = ref([]);
// 选择爱好标签
const handleHobbyChange = (item, value) => {
// console.log("爱好", item, value);
hobbyIndex = value;
const handleHobbyChange = (items, ids) => {
console.log('选择爱好', items, ids);
hobbyIds.value = [];
hobbies.value = items;
};
// 选择
const handleNativeChange = (e) => {
formData.value.nativec = (e.detail.value.map(item => {
@@ -568,16 +583,16 @@ let handleWorkingStatusChange = e => {
}
let submitForm = async () => {
let hobbyTags = hobbyIndex.map(it => {
let {name} = hobbyList[it];
let hobbyTags = hobbies.value.map(it => {
let {name} = it;
return name;
})
formData.value.iphone = formData.value.mobilePhone; // 特殊处理
const hobbyTagString = hobbyTags.join('');
console.log(hobbyTagString);
if (hobbyTagString || formData.value.hobby) {
formData.value.hobby = formData.value.hobby ? formData.value.hobby + '' + hobbyTagString : hobbyTagString;
formData.value.hobby = hobbyTagString ? (formData.value.hobby ? formData.value.hobby + '' : '') + hobbyTagString : formData.value.hobby;
}
formData.value.iphone = formData.value.mobilePhone; // 特殊处理
// console.log(formData.value, "校验表单数据")
// console.log(recommendLevel);
formData.value.cusName = customerUser.value.cusName;

View File

@@ -21,7 +21,7 @@
<!-- 正文内容 -->
<view class="white-bg">
<view class="form-con">
<view class="form-con" @click="handleBlur">
<uni-forms ref="formRef" :model="formData" :rules="rules" label-width="40%">
<!-- 选择客户 -->
<uni-forms-item label="客户名称" name="cusName" required class="f-c-right">
@@ -178,7 +178,7 @@
<uni-forms-item label="爱好" name="hobby" class="uni-forms-item is-direction-top is-top">
<!-- 索引hobbyIndex 范围hobbyList 响应handleHobbyChange-->
<uni-easyinput v-model="formData.hobby" placeholder="请输入爱好"/>
<multipleSelect :multiple="true" :value="hobbyIndex" downInner :options="hobbyList"
<multipleSelect ref="hobbySelectRef" :multiple="true" downInner :value="hobbyIds" :options="hobbyList"
@change="handleHobbyChange" :slabel="'name'"
></multipleSelect><!--placeholder="请选择爱好标签"-->
@@ -271,7 +271,7 @@
</template>
<script setup>
import {ref, onMounted, computed, reactive} from 'vue'
import {ref, reactive} from 'vue'
import customHeader from '@/components/customHeader.vue'
import multipleSelect from '@/components/multipleSelect.vue'
import {
@@ -284,7 +284,8 @@ import {
} from "./dataMap";
import city from "@/utils/area";
import {getCustomerLevel, saveappCrmCusUserNew} from "@/api/crm/customer/getCustomer";
// 对 multipleSelect 组件的引用
const hobbySelectRef = ref(null);
// 表单引用
const formRef = ref({});
// 表单数据
@@ -412,7 +413,7 @@ let handleCustomerClick = () => {
let {
cusName, // 公司名称
cusEstate, // 等级
cusId,
cusId,
} = data;
customerUser.value.cusName = cusName;
if (!cusEstate) customerUser.value.sysThinkLevel = "该客户暂无等级信息,无法进行系统推荐"
@@ -448,20 +449,29 @@ let handleThinkLevelChange = (e) => {
// 系统推荐等级
let recommendLevel = ref("");
let getRecommendLevel = async () => {
if (formData.value.cusEstate && formData.value.functionalRequirements) {
if (formData.value.cusEstate) {
let {cusEstate, functionalRequirements} = formData.value;
let param = {cusEstate, functionalRequirements};
if (formData.value.salesmanThinkLevel) {
param.personnelLevel = formData.value.salesmanThinkLevel;
}
let res = await getCustomerLevel(param).catch(err => {
let res = await getCustomerLevel(param)
/*.catch(err => {
console.error(err, "客户的系统推荐等级获取失败")
})
if (!res.systemRecommendationLevel) {
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
console.log(formData.value.systemThinkLevel + "???")
})*/
try{
if(res.data.systemRecommendationLevel){
formData.value.systemThinkLevel = res.data.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐";
}
}catch(e){
if (res.systemRecommendationLevel) {
formData.value.systemThinkLevel = res.systemRecommendationLevel;
}else{
recommendLevel.value = "客户无等级信息,暂无法进行等级推荐"
}
}
formData.value.systemThinkLevel = res.systemRecommendationLevel;
} else {
recommendLevel.value = "无公司等级信息,无法推荐等级";
}
@@ -489,9 +499,9 @@ let handleUserTypeChange = (e) => {
}
// 选择日期
function handleTenureTimeChange(e) {
let {value} = e.detail;
formData.value.tenureTime = value;
function handleTenureTimeChange(val) {
console.log(val)
formData.value.tenureTime = val;
}
// 需求层次索引
@@ -513,18 +523,20 @@ let handleDevelopChange = e => {
}
// 选择生日
function handleBirthdayChange(e) {
let{value} = e.detail
formData.value.birthday = value;
function handleBirthdayChange(val) {
formData.value.birthday = val;
}
// 爱好标签索引
let hobbyIndex = reactive([]);
let hobbyIds = ref([]);
let hobbies = ref([]);
// 选择爱好标签
const handleHobbyChange = (item, value) => {
// console.log("爱好", item, value);
hobbyIndex = value;
const handleHobbyChange = (items, ids) => {
console.log('选择爱好', items, ids);
hobbyIds.value = [];
hobbies.value = items;
};
// 选择
const handleNativeChange = (e) => {
formData.value.nativec = (e.detail.value.map(item => {
@@ -546,16 +558,93 @@ let handleWorkingStatusChange = e => {
workingStatusIndex.value = 0;
formData.value.workingStatus = workingStatusList[value].name;
}
let submitForm = async () => {
let hobbyTags = hobbyIndex.map(it => {
let {name} = hobbyList[it];
// 多选组件失去焦点关闭
let handleBlur = () => {
if (hobbySelectRef.value) hobbySelectRef.value.handleBlur();
}
// 提取爱好标签处理逻辑
const processHobbyTags = () => {
let hobbyTags = hobbies.value.map(it => {
let {name} = it;
return name;
})
const hobbyTagString = hobbyTags.join('');
console.log(hobbyTagString);
if (hobbyTagString || formData.value.hobby) {
formData.value.hobby = formData.value.hobby ? formData.value.hobby + '' + hobbyTagString : hobbyTagString;
formData.value.hobby = hobbyTagString ? (formData.value.hobby ? formData.value.hobby + '' : '') + hobbyTagString : formData.value.hobby;
}
};
// 提取表单验证逻辑
const validateForm = async () => {
formData.value.cusName = customerUser.value.cusName;
await formRef.value.validate();
console.log(formData.value, "提交表单数据");
};
// 提取API调用逻辑
const saveCustomerUser = async () => {
uni.showLoading();
try {
const res = await saveappCrmCusUserNew(formData.value);
if(res.code === 200){
uni.showToast({
title: "保存成功"
});
} else {
uni.showToast({
title: "操作失败",
icon: "error"
});
}
setTimeout(() => uni.navigateBack(), 1500);
} catch(err) {
uni.showToast({
icon: 'none',
title: "保存失败"
});
}
finally{
uni.hideLoading()
}
};
// 简化后的 submitForm 方法
let submitForm = async () => {
console.log(formData.value);
try {
if(formData.value.iphone){
formData.value.mobilePhone = formData.value.iphone;
}
// 处理爱好标签
processHobbyTags();
// 表单验证
await validateForm();
// 保存客户人员信息
await saveCustomerUser();
} catch (err) {
uni.showToast({
icon: 'none',
title: '请检查并完善信息'
});
console.warn(err);
}
};
/*let submitForm = async () => {
let hobbyTags = hobbies.value.map(it => {
let {name} = it;
return name;
})
const hobbyTagString = hobbyTags.join('');
console.log(hobbyTagString);
if (hobbyTagString || formData.value.hobby) {
formData.value.hobby = hobbyTagString ? (formData.value.hobby ? formData.value.hobby + '' : '') + hobbyTagString : formData.value.hobby;
}
if(formData.value.iphone){
formData.value.mobilePhone = formData.value.iphone;
}
// console.log(formData.value, "校验表单数据")
// console.log(recommendLevel);
@@ -565,19 +654,19 @@ let submitForm = async () => {
console.log(formData.value, "提交表单数据")
// 请求保存
uni.showLoading()
saveappCrmCusUserNew(formData.value).then(res=>{
saveappCrmCusUserNew(formData.value).then(res => {
uni.hideLoading();
if(res.code === 200){
if (res.code === 200) {
uni.showToast({
title: "保存成功"
})
}else{
} else {
uni.showToast({
title: "操作失败"
})
}
setTimeout(()=>uni.navigateBack(), 1500);
}).catch(err=>{
setTimeout(() => uni.navigateBack(), 1500);
}).catch(() => {
uni.showToast({
icon: 'none',
title: "保存失败"
@@ -593,7 +682,7 @@ let submitForm = async () => {
})
console.warn(err);
}
}
}*/
</script>

View File

@@ -132,9 +132,9 @@ let list = ref([]);
const upOption = ref({
page: {num: 0, size: 10},
noMoreSize: 5,
empty: {
tip: '~ 空空如也 ~',
icon: "../../../../static/images/mescroll-empty.png"
empty: {
tip: '~ 空空如也 ~',
icon: "../../static/images/mescroll-empty.png"
},
textLoading: '加载中...',
textNoMore: '已经到底了'