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

600 lines
18 KiB
TypeScript

// packageA/pages/refuelingCharging/RefuelingChargingReporting/RefuelingChargingReporting.ts
import { postAction, getAction, upload } from '../../../../api/base';
const dayjs = require('dayjs');
Page({
/**
* 页面的初始数据
*/
data: {
plateNumberListDefault: [] as any,
plateNumberList: [] as any,
plateNumberPickerIndex: -1,
oilTypeList: [] as any,
oilTypePickerIndex: -1,
showSelect: {
oilTypeSelectShow: false,
recordDateSelectShow: false
} as any,
requireObj: {
// id: '',
plateNumber: '',
oilType: '',
oilCard: '', //油卡
mileage: '', //加油充电时里程
amount: '', //数量
totalPrice: '', //金额
recordDate: '' // 日期
},
// 非必填
validateObj: {
driver: '', // 司机
oilStation: '', // 加油站
oilCardBalance: '', // 油卡余额
remark: '' // 备注
},
params: {
id: '',
sysOrgCode: '', //所属机构
projectId: '', //所属项目
vehicleId: '', //车辆id
vehicleModel: '', //车辆型号
plateNumber: '', //车牌号
vehicleType: '', //车辆种类
driver: '', //驾驶员
oilStation: '', //加油站
oilCardBalance: '', //油卡余额
oilType: '', //油品规格
oilCard: '', //油卡
mileage: '', //加油充电时里程
// "fuelType": "1", //燃料类型
amount: '', //数量
totalPrice: '', //金额
remark: '', //备注
attachmentUrl: '', //附件
recordDate: '' // 日期
} as any,
loading: false,
pvIndex: 0,
searchVal: '',
price: '—', // 单价
fileList: [], // 附件:
uploading: false, // 是否上传中
recordDateTimeTamp: new Date().getTime() // 日期标签
},
selectplateNumber(e: any) {
this.setData({
pvIndex: e.detail.value
});
},
//下拉框相关----------
pickerChange(event: any) {
//下拉框切换是否展示
let fieldName: any = event.currentTarget.dataset.fieldname;
let data: any = { ...this.data };
data.showSelect[fieldName] = true;
this.setData(data);
},
hidePicker() {
let showSelect = this.data.showSelect;
showSelect = {
oilTypeSelectShow: false,
recordDateSelectShow: false
};
this.setData({
showSelect: showSelect
});
},
pickerConfirm(event: any) {
console.log(event);
//下拉框点击确认
let { fieldname, fieldindex } = event.currentTarget.dataset;
let detail = event.detail;
let data: any = { ...this.data };
if (fieldname === 'plateNumber') {
console.log(this.data.pvIndex);
// data.params[fieldname] = this.data.pvIndex;
// data.params[fieldname] = detail.value.value;
// data[fieldindex] = detail.index;
fieldindex = this.data.pvIndex;
// data.params.fuelType = this.data.plateNumberList[fieldindex].fuelType; // 燃料类型
if (this.data.plateNumberList[fieldindex].oilCard)
data.params.oilCard = this.data.plateNumberList[fieldindex].oilCard; //油卡
data.params.sysOrgCode = this.data.plateNumberList[fieldindex].sysOrgCode; //所属机构
data.params.projectId = this.data.plateNumberList[fieldindex].projectId; //所属项目
data.params.vehicleId = this.data.plateNumberList[fieldindex].id; //车辆id
data.params.vehicleModel =
this.data.plateNumberList[fieldindex].vehicleModel; //车辆型号
data.params.plateNumber =
this.data.plateNumberList[fieldindex].plateNumber; //车牌号
data.params.vehicleType =
this.data.plateNumberList[fieldindex].vehicleType; //车辆种类
} else if (fieldname == 'recordDate') {
data.params[fieldname] = dayjs(new Date(detail)).format('YYYY-MM-DD');
data.recordDateTimeTamp = event.detail;
// data.requireObj[fieldname] = '';
} else {
data.params[fieldname] = detail.value.value;
data[fieldindex] = detail.index;
}
if (data.params[fieldname]) {
// delete data.requireObj[fieldname];
data.requireObj[fieldname] = '';
} else {
data.requireObj[fieldname] = '此项为必填项';
}
this.setData(data);
this.hidePicker();
},
// 下拉框相关----------end
// 输入框相关---------------
getInput(e: any) {
console.log(e);
let { fieldname, fieldindex, fieldkey } = e.currentTarget.dataset;
let detail = e.detail;
let data: any = { ...this.data };
if (
fieldname == 'amount' ||
fieldname == 'totalPrice' ||
fieldname == 'mileage' ||
fieldname == 'oilCardBalance'
) {
detail.value = detail.value.replace(/[^\d.]/g, ''); // 只能输入数字和.
detail.value = detail.value.replace(/^\./g, ''); //第一个字符不能是.
detail.value = detail.value.replace(/\.{2,}/g, '.'); // 不能连续输入.
detail.value = detail.value.replace(/(\.\d+)\./g, '$1'); // .后面不能再输入.
detail.value = detail.value.replace(/^0+(\d)/, '$1');
let reg: RegExp = /^\d+(\.\d{1,2})?$/; //小数部分不能大于2位
if (!detail.value && fieldname != 'oilCardBalance') {
data.requireObj[fieldname] = '此项为必填项';
} else if (!detail.value && fieldname == 'oilCardBalance')
data.requireObj[fieldname] = '';
if (detail.value > 999999) {
// data.params[fieldname] = 999999;
if (fieldname == 'oilCardBalance')
data.validateObj[fieldname] = '输入值上限为999999';
else data.requireObj[fieldname] = '输入值上限为999999';
data.params[fieldname] = detail.value;
} else if (!reg.test(detail.value) && detail.value) {
if (fieldname == 'oilCardBalance')
data.validateObj[fieldname] = '输入值最多保留两位小数';
else data.requireObj[fieldname] = '输入值最多保留两位小数';
data.params[fieldname] = detail.value;
} else {
data.params[fieldname] = detail.value;
if (fieldname == 'oilCardBalance') data.validateObj[fieldname] = '';
else data.requireObj[fieldname] = '';
}
if (data.params.amount && data.params.totalPrice) {
// 单价
let price = data.params.totalPrice / data.params.amount;
data.price = Math.floor(price * 100) / 100;
} else {
data.price = '—';
}
} else {
data.params[fieldname] = detail.value;
if (data.params[fieldname]) {
// delete data.requireObj[fieldname];
if (fieldname == 'oilCard')
data.requireObj[fieldname] = this.checkStr(data.params[fieldname]);
else {
if (fieldname == 'remark')
data.validateObj[fieldname] = this.checkStr(
data.params[fieldname],
1000
);
else
data.validateObj[fieldname] = this.checkStr(
data.params[fieldname],
64
);
}
} else {
if (
fieldname == 'driver' ||
fieldname == 'oilStation' ||
fieldname == 'oilCardBalance' ||
fieldname == 'remark'
) {
data.validateObj[fieldname] = '';
} else {
data.requireObj[fieldname] = '此项为必填项';
}
}
}
this.setData(data);
},
clearVal(e: any) {
let { fieldname, fieldindex, fieldkey } = e.currentTarget.dataset;
let data: any = { ...this.data };
if (fieldname == 'projectList') {
data.params.projectList[fieldindex].remark = '';
} else if (fieldname == 'vehicleList') {
data.params[fieldname][fieldindex][fieldkey] = '';
} else {
data.params[fieldname] = '';
}
this.setData(data);
},
// 文件上传
fileAfterRead(event: any) {
const file = event.detail;
let index: any = event.detail.index;
let { list } = event.currentTarget.dataset;
let data: any = this.data;
let option = {
name: 'file',
filePath: event.detail.file.url
};
data[list][index] = {
status: 'uploading',
message: '上传中'
};
data.uploading = true;
this.setData(data);
upload('api/insuranceRecord/upload', option)
.then((res: any) => {
let tempData = JSON.parse(res.data);
if (!tempData.success) {
wx.showToast({
title: tempData.message,
icon: 'none'
});
data[list][index] = {
status: 'failed',
message: '上传失败'
};
data.uploading = false;
this.setData(data);
return;
}
data[list][index] = {
...file,
url: tempData.message,
status: 'done',
message: '上传完成'
};
console.log(data[list]);
data.uploading = false;
// 地址拼接
let attachmentUrl = data.params.attachmentUrl
? data.params.attachmentUrl + ',' + tempData.message
: tempData.message;
data.params.attachmentUrl = attachmentUrl;
this.setData(data);
})
.catch(err => {
data.uploading = false;
});
},
// 删除文件
deleteFile(event: any) {
let { list } = event.currentTarget.dataset;
let data: any = this.data;
let index = event.detail.index;
data[list].splice(index, 1);
data.params.attachmentUrl = data[list]
.map((item: any) => {
return item.url;
})
.join(',');
this.setData(data);
},
// 输入框相关---------------end
// 校验相关-----------------
checkStr(str: any, lenght = 32) {
let returnStr = '';
let spaceRegex = /^\S*$/ as any;
let regex = /[!@#$%^&*?><|\\\\]/ as any;
let tooLong = str.length > lenght;
if (!spaceRegex.test(str)) {
returnStr = '不支持含有空格';
} else if (regex.test(str)) {
returnStr = '不支持特殊字符';
} else if (tooLong) {
returnStr = `输入长度不得超过${lenght}个字符`;
} else {
returnStr = '';
}
return returnStr;
},
// 校验文件
checkFile() {
let { fileList } = this.data;
let result = true;
if (
fileList.some((item: any) => {
return item.status == 'failed';
})
)
result = false;
return result;
},
isStepReady() {
//校验基础信息
let isAllReady = true;
let temp: any = this.data.requireObj;
let validate: any = this.data.validateObj;
let params: any = this.data.params;
for (let key in temp) {
if (key == 'id') {
continue;
}
if (key == 'checkTime') {
let timeRegex =
/^(?:19|20)[0-9][0-9]-(?:(?:0[1-9])|(?:1[0-2]))-(?:(?:[0-2][1-9])|(?:[1-3][0-1])) (?:(?:[0-2][0-3])|(?:[0-1][0-9])):[0-5][0-9]$/ as any;
if (!timeRegex.test(params[key])) {
isAllReady = false;
temp[key] = '请填写正确的时间';
}
// temp[key] = temp[key] ? temp[key] : '请填写正确的时间';
} else if (key == 'amount' || key == 'totalPrice' || key == 'mileage') {
// 判断是否是正整数
let reg: RegExp = /^\d+(\.\d{1,2})?$/; //小数部分不能大于2位
// console.log(!regPos.test(params[key]));
// if (!regPos.test(params[key])) {
// isAllReady = false;
// temp[key] = '输入值为正数且最多保留两位小数';
// }
if (!params[key]) {
isAllReady = false;
temp[key] = '此项为必填项';
} else temp[key] = '';
if (params[key] > 999999) {
isAllReady = false;
temp[key] = '输入值上限为999999';
}
if (!reg.test(params[key]) && params[key]) {
isAllReady = false;
temp[key] = '输入值最多保留两位小数';
}
} else if (!params[key]) {
isAllReady = false;
temp[key] = temp[key] ? temp[key] : '此项为必填项';
} else {
temp[key] = this.checkStr(params[key]);
if (temp[key]) {
isAllReady = false;
}
}
}
// 非必填校验
for (let key in validate) {
if (key == 'oilCardBalance') {
let reg: RegExp = /^\d+(\.\d{1,2})?$/; //小数部分不能大于2位
if (params[key] > 999999) {
isAllReady = false;
validate[key] = '输入值上限为999999';
}
if (!reg.test(params[key]) && params[key]) {
isAllReady = false;
validate[key] = '输入值最多保留两位小数';
}
} else {
if (key == 'remark') validate[key] = this.checkStr(params[key], 1000);
else validate[key] = this.checkStr(params[key], 64);
if (validate[key]) {
isAllReady = false;
}
}
}
this.setData({
requireObj: temp,
validateObj: validate
});
return isAllReady;
},
// 校验相关-----------------end
filterPlateNumberList(e: any) {
let val = e.detail.value;
let arr = [] as any;
if (val) {
if (this.data.plateNumberListDefault.length > 0) {
arr = this.data.plateNumberListDefault.filter(
(item: any) => item.plateNumber.indexOf(val) != -1
);
}
} else {
arr = this.data.plateNumberListDefault;
}
this.setData({
searchVal: val,
plateNumberList: arr
});
},
restorePlateNumberList() {
this.setData({
searchVal: '',
plateNumberList: this.data.plateNumberListDefault
});
},
getplateNumberListByProjectId() {
let userInfo = wx.getStorageSync('userInfo');
console.log(userInfo);
let params = {
projectId: '',
plateNumber: ''
};
getAction('api/vehicle/getVehicleList', params).then((res: any) => {
if (res.code == 200) {
let tmp = [];
this.setData({
plateNumberListDefault: res.result ? res.result : [],
plateNumberList: res.result ? res.result : [],
plateNumberPickerIndex: -1
});
// if (this.data.params.plateNumber != '') {
// let i = res.result.findIndex(
// (x: any) => x.value == this.data.params.plateNumber
// );
// if (i == -1) {
// return;
// }
// this.setData({
// plateNumberPickerIndex: i
// });
// }
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
});
},
// 获取字典相关数据
getDictOptions(dictCode: string) {
getAction('api/sys/dict/getDictItems/' + dictCode).then((res: any) => {
if (res.code == 200) {
if (dictCode == 'oil_type') {
this.setData({
oilTypeList: res.result,
oilTypePickerIndex: -1
});
// if (this.data.params.oilType != '') {
// let i = res.result.findIndex(
// (x: any) => x.value == this.data.params.oilType
// );
// if (i == -1) {
// return;
// }
// this.setData({
// oilTypePickerIndex: i
// });
// }
} else {
}
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
});
},
formSubmit() {
if (this.data.loading) {
wx.showToast({
title: '信息保存中,请勿重复提交',
icon: 'none'
});
return;
}
// 校验文件是否正在上传
if (this.data.uploading) {
wx.showToast({
title: '文件上传中,请稍后',
icon: 'none'
});
return;
}
if (!this.isStepReady()) {
wx.showToast({
title: '请按照要求填写对应信息',
icon: 'none'
});
// 验证是否非空
return;
}
// 验证非必填
// if (this.data.params.remark) {
// let msg = this.checkStr(this.data.params.remark);
// if (msg) {
// if (msg == '输入长度不得超过32个字符') {
// msg =
// this.data.params.remark.length > 200
// ? '输入长度不得超过200个字符'
// : '';
// }
// wx.showToast({
// title: '备注:' + msg,
// icon: 'none'
// });
// return;
// }
// }
// 校验是否有错误文件
if (!this.checkFile()) {
wx.showToast({
title: '请删除错误文件',
icon: 'none'
});
return;
}
wx.showLoading({
title: '保存中'
});
this.setData({
loading: true
});
postAction('api/gis/refuelChargeRecord/add', this.data.params).then(
(res: any) => {
wx.hideLoading();
this.setData({
loading: false
});
if (res.code == 200) {
wx.showToast({
title: '保存成功',
icon: 'success'
});
wx.navigateBack({
delta: 1
});
} else {
wx.showToast({
title: res.message,
icon: 'none'
});
}
}
);
},
/**
* 生命周期函数--监听页面加载
*/
onLoad() {
this.getDictOptions('oil_type');
// 获取车辆下拉
this.getplateNumberListByProjectId();
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady() {},
/**
* 生命周期函数--监听页面显示
*/
onShow() {},
/**
* 生命周期函数--监听页面隐藏
*/
onHide() {},
/**
* 生命周期函数--监听页面卸载
*/
onUnload() {},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh() {},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom() {},
/**
* 用户点击右上角分享
*/
onShareAppMessage() {}
});