2025-06-19 17:33:18 +08:00

591 lines
15 KiB
TypeScript

// pages/vehicleMaintenance/maintainSend/maintainSend.ts
import { getAction, postAction } from '../../../../api/base';
const dayjs = require('dayjs');
Page({
/**
* 页面的初始数据
*/
data: {
selectProject: null as any, // 项目所选
selectCar: null as any, // 项目所选
selectOption: null as any, // 维修厂所选
projectOptions: [], // 项目数据
options: [] as any, // 维修厂数据
filterOptions: [] as any, // 维修厂过滤后数据
carOptions: [] as any,
filterCarOptions: [] as any, // 过滤后的车辆数据
filterProjectOptions: [] as any, // 过滤后的项目数据
repairPeople: '', // 报修人
phone: '', // 报修人联系电话
classifyOptions: [] as any, // 报修分类数据
selectedClassify: [] as any, // 选择的报修分类
repairContent: '', // 报修内容
uploadUrl: 'api/vehicles/repair/fileUpload', // 上传图片地址
repairImgUrl: '' as any, //报修副屏
contactPhone: '', // 维修厂联系电话
isGuarantee: '0', // 是否质保维修
contact: '', // 联系人
repairTimeShow: false, // 展示报修时间选择框
repairTime: '', // 报修时间
repairTimestamp: new Date().getTime(),
plateNumberShow: false, //展示车牌号选择框
projectShow: false, //展示项目选择框
plateNumberSearchVal: '', // 查找车牌号输入值
projectSearchVal: '', // 查找项目输入值
repairShopShow: false, // 控制维修厂选择弹窗
repairShopSearchVal: '' // 维修厂查询过滤输入值
},
// 选择项目
selectProject(e: any) {
let index = Number(e.detail.value);
this.setData({
selectProject: this.data.projectOptions[index],
projectIndex: index
});
if (this.data.selectProject?.projectId) {
// 获取车辆数据
getAction(
`api/vehicles/repair/queryVehicleInfoByProjectId?projectId=${this.data.selectProject.projectId}`
)
.then((res: any) => {
if (res.code == 200) {
// 清空当前所选的车辆数据
this.setData({
plateNumberIndex: 0,
selectCar: null
});
let data = res.result;
data.unshift({
plateNumber: '请选择车牌号',
id: null
});
this.setData({
carOptions: data
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
})
.catch((err: any) => {
wx.showToast({
title: err.message,
icon: 'none'
});
});
} else {
let data = [
{
plateNumber: '请先选择项目',
id: null
}
];
this.setData({
carOptions: data
});
}
},
// 选择车辆
selectCar(e: any) {
let index = Number(e.detail.value);
this.setData({
selectCar: this.data.carOptions[index],
plateNumberIndex: index
});
},
// 获取维修厂信息
getRepairShop() {
getAction('api/vehicles/repair/getRepairShop')
.then((res: any) => {
if (res.code == 200) {
let data = [] as any;
res.result.forEach((el: any) => {
el.value = el.repairShop;
el.text = el.repairShop_dictText;
});
data = res.result;
this.setData({
options: data,
filterOptions: data
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
})
.catch((err: any) => {
wx.showToast({
title: err.message,
icon: 'none'
});
});
},
// 选着报修分类
selectClassify(e: any) {
let index = null;
this.data.selectedClassify.forEach((item: any, idx: number) => {
if (item == e.currentTarget.dataset.inf.value) index = idx;
});
// 如果已经选择,清除
if (index != null) {
this.data.selectedClassify.splice(index, 1);
let data = this.data.classifyOptions;
data[e.currentTarget.dataset.index].selected = false;
this.setData({
classifyOptions: data
});
}
// 如果没有选择,则添加
else {
this.data.selectedClassify.push(e.currentTarget.dataset.inf.value);
let data = this.data.classifyOptions;
data[e.currentTarget.dataset.index].selected = true;
this.setData({
classifyOptions: data
});
}
},
// 输入报修人
getRepairPeople(e: any) {
this.setData({
repairPeople: e.detail.value
});
},
// 输入联系电话
getPhone(e: any) {
this.setData({
phone: e.detail.value
});
},
// 报修人联系电话
checkPhoneOne() {
let res = this.checkMobilephone(this.data.phone);
if (!res) {
wx.showToast({
title: '报修人联系电话格式不正确',
icon: 'none'
});
return false;
} else return true;
},
// 维修厂联系人电话
checkPhoneTwo() {
let res = this.checkMobilephone(this.data.contactPhone);
if (!res) {
wx.showToast({
title: '维修厂联系人联系电话格式不正确',
icon: 'none'
});
return false;
} else return true;
},
// 手机号校验方法
checkMobilephone(target: any) {
const regex = /^(?:(?:\+|00)86)?1[3-9]\d{9}$/;
if (target == '') {
return true;
} else {
if (!regex.test(target)) {
return false;
} else {
return true;
}
}
},
// 输入报修内容
textareaInput(e: any) {
this.setData({
repairContent: e.detail.value
});
},
// 上传图片回显
returnPic(e: any) {
let list = [] as any;
e.detail.photoList.forEach((item: any) => {
list.push(item.fileUrl);
});
this.setData({
repairImgUrl: list
});
},
// 联系人
getContactPerson(e: any) {
this.setData({
contact: e.detail.value
});
},
// 联系电话
getTel(e: any) {
this.setData({
contactPhone: e.detail.value
});
},
// 提交申请
submit() {
// 联系电话格式校验
let checkPhone1 = this.checkPhoneOne();
let checkPhone2 = this.checkPhoneTwo();
// 校验必填
let checkProject, checkCar, checkClassify, checkTextarea;
this.data.selectProject?.projectId
? (checkProject = true)
: (checkProject = false);
this.data.selectCar?.id ? (checkCar = true) : (checkCar = false);
this.data.selectedClassify.length > 0
? (checkClassify = true)
: (checkClassify = false);
this.data.repairContent ? (checkTextarea = true) : (checkTextarea = false);
if (!checkProject) {
wx.showToast({
title: '请选择所属项目',
icon: 'none'
});
return;
}
if (!checkCar) {
wx.showToast({
title: '请选择所属车辆',
icon: 'none'
});
return;
}
if (!this.data.repairTime) {
wx.showToast({
title: '请选择报修时间',
icon: 'none'
});
return;
}
if (!checkClassify) {
wx.showToast({
title: '请选择报修分类',
icon: 'none'
});
return;
}
if (!checkTextarea) {
wx.showToast({
title: '请填写报修内容',
icon: 'none'
});
return;
}
if (!this.data.selectOption) {
wx.showToast({
title: '请选择维修厂',
icon: 'none'
});
return;
}
if (!checkPhone1 || !checkPhone2) {
return;
}
// 报修信息
let repairInfo = {
projectId: this.data.selectProject?.projectId, //所属项目
plateNumber: this.data.selectCar?.plateNumber, //车牌号
deliveryTime: this.data.selectCar?.deliveryTime, //交车时间
frameNumber: this.data.selectCar?.frameNumber, //车架号
vehicleBrand: this.data.selectCar?.vehicleBrand, //车辆品牌
vehicleModel: this.data.selectCar?.vehicleModel, //车辆型号
vehicleType: this.data.selectCar?.vehicleType, //车辆种类
vinCode: this.data.selectCar?.vinCode, //VIN码
engineNumber: this.data.selectCar?.engineNumber, //发动机码
repairPeople: this.data.repairPeople, //报修人
phone: this.data.phone, //联系电话
repairClass: this.data.selectedClassify.join(','), //报修分类
repairContent: this.data.repairContent, //报修内容
repairImgUrl: this.data.repairImgUrl
? this.data.repairImgUrl.join(',')
: '' //报修图片
};
// 维修厂信息
let repairAssign = {
isGuarantee: this.data.isGuarantee, // 是否质保维修
repairShop: this.data.selectOption.repairShop, //维修厂id
contact: this.data.contact, //联系人
contactPhone: this.data.contactPhone //联系电话
};
let params = {
repairInfo,
repairAssign
};
wx.setStorageSync('paramsInfo', params);
wx.navigateTo({
url: '../dataEntryTwo/dataEntryTwo',
fail: e => {
console.log(e);
}
});
},
// 获取项目数据
getProjects() {
getAction('api/vehicles/repair/queryProjects')
.then((res: any) => {
if (res.code == 200) {
let data = [] as any;
res.result.forEach((el: any) => {
el.value = el.projectId;
el.text = el.projectName;
});
data = res.result;
this.setData({
projectOptions: data,
filterProjectOptions: data
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
})
.catch((err: any) => {
wx.showToast({
title: err.message,
icon: 'none'
});
});
},
// 获取报修分类
getRepairClass() {
getAction('api/vehicles/repair/getRepairClass')
.then((res: any) => {
if (res.code == 200) {
let data = res.result;
data.forEach((item: any) => {
item.selected = false;
});
this.setData({
classifyOptions: data
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
})
.catch((err: any) => {
wx.showToast({
title: err.message,
icon: 'none'
});
});
},
// 是否质保维修状态修改
isGuaranteeChange(event: any) {
this.setData({
isGuarantee: event.detail
});
},
// 展示选择框
pickerChange(event: any) {
//下拉框切换是否展示
let fieldName: any = event.currentTarget.dataset.fieldname;
let data: any = { ...this.data };
data[fieldName] = true;
this.setData(data);
},
// 隐藏展示框
hidePicker() {
this.setData({
repairTimeShow: false,
plateNumberShow: false,
projectShow: false,
repairShopShow: false
});
},
// 选择器点击确认
pickerConfirm(event: any) {
let { fieldname } = event.currentTarget.dataset;
let detail = event.detail;
// 选择报修时间
if (fieldname == 'repairTime') {
this.setData({
repairTime: dayjs(detail).format('YYYY-MM-DD'),
repairTimestamp: detail
});
}
// 选择车牌号
else if (fieldname == 'plateNumber') {
this.setData({
selectCar: event.detail.value
});
}
// 选择项目
else if (fieldname == 'project') {
this.setData({
selectProject: event.detail.value
});
if (event.detail.value.projectId) {
// 获取车辆数据
getAction(
`api/vehicles/repair/queryVehicleInfoByProjectId?projectId=${event.detail.value.projectId}`
)
.then((res: any) => {
if (res.code == 200) {
// 清空当前所选的车辆数据
this.setData({
selectCar: null
});
let data = [] as any;
res.result.forEach((el: any) => {
el.value = el.plateNumber;
el.text = el.plateNumber;
});
data = res.result;
this.setData({
carOptions: data,
filterCarOptions: data
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
})
.catch((err: any) => {
wx.showToast({
title: err.message,
icon: 'none'
});
});
}
}
// 选择维修厂
else if (fieldname == 'repairShop') {
this.setData({
selectOption: detail.value,
contact: detail.value.contact,
contactPhone: detail.value.contactPhone
});
}
this.hidePicker();
},
// 清空数据
resetData(event: any) {
let { fieldname } = event.currentTarget.dataset;
if (fieldname == 'repairPeople') {
this.setData({
repairPeople: ''
});
} else if (fieldname == 'phone') {
this.setData({
phone: ''
});
} else if (fieldname == 'contact') {
this.setData({
contact: ''
});
} else if (fieldname == 'contactPhone') {
this.setData({
contactPhone: ''
});
}
},
// 过滤车牌号
filterPlateNumber(event: any) {
let list = [] as any;
this.data.carOptions.forEach((item: any) => {
if (
item.plateNumber.toLowerCase().indexOf(event.detail.toLowerCase()) >= 0
) {
list.push(item);
}
});
this.setData({
filterCarOptions: list,
plateNumberSearchVal: event.detail
});
},
// 过滤项目
filterProject(event: any) {
let list = [] as any;
this.data.projectOptions.forEach((item: any) => {
if (
item.projectName.toLowerCase().indexOf(event.detail.toLowerCase()) >= 0
) {
list.push(item);
}
});
this.setData({
filterProjectOptions: list,
projectSearchVal: event.detail
});
},
// 过滤维修厂
filterRepairShop(event: any) {
let list = [] as any;
this.data.options.forEach((item: any) => {
if (
item.repairShop_dictText
.toLowerCase()
.indexOf(event.detail.toLowerCase()) >= 0
) {
list.push(item);
}
});
this.setData({
filterOptions: list,
repairShopSearchVal: event.detail
});
},
/**
* 生命周期函数--监听页面加载
*/
onLoad() {},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady() {
this.getProjects();
this.getRepairClass();
this.getRepairShop();
},
/**
* 生命周期函数--监听页面显示
*/
onShow() {
// 不放onReady 是因为有可能切出去然后状态改了得跳转到别的页面
// 默认报修人为当前用户
let userInfo = wx.getStorageSync('userInfo');
this.setData({
repairPeople: userInfo.realname
});
},
/**
* 生命周期函数--监听页面隐藏
*/
onHide() {},
/**
* 生命周期函数--监听页面卸载
*/
onUnload() {},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh() {},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom() {},
/**
* 用户点击右上角分享
*/
onShareAppMessage() {}
});