1070 lines
34 KiB
Vue
1070 lines
34 KiB
Vue
<template>
|
||
<view class="container">
|
||
<view class="containerBody">
|
||
<VNavigationBar background-color="rgba(0,0,0,0)" title="新建工单" title-color="#333"></VNavigationBar>
|
||
<view class="body">
|
||
<view class="card phone">
|
||
<view class="phoneHeader">
|
||
<view class="title">查找手机号|车牌号|车架号</view>
|
||
<view class="desc">根据手机号查找|车牌号|车架号/建立客户信息</view>
|
||
</view>
|
||
<view class="phoneBody">
|
||
<view class="searchBox">
|
||
<input v-model="phone" placeholder="请输入手机号码|车牌号|车架号" type="tel">
|
||
</view>
|
||
<view class="btn" @click="listUserInfo">
|
||
<image class="btnIcon" mode="aspectFit" src="/pages-order/static/search.png"></image>
|
||
确认查找
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- <view class="card" style="padding-bottom: 20rpx">-->
|
||
<!-- <view class="carTitle">单据类型</view>-->
|
||
<!-- <radio-group @change="handleChange" style="padding: 0 20rpx">-->
|
||
<!-- <label v-for="(option, index) in options" :key="index" class="radio-label">-->
|
||
<!-- <radio :value="option.value" :checked="option.value === ticketType"/>-->
|
||
<!-- <text>{{ option.label }}</text>-->
|
||
<!-- </label>-->
|
||
<!-- </radio-group>-->
|
||
<!-- </view>-->
|
||
<view :class="{ 'none': !carList || carList.length === 0 }" class="card cardInfo carCard">
|
||
<template v-if="!carList || carList.length === 0">
|
||
<image @click="addCarUserInfo()" class="cardNoneIcon" mode="widthFix" src="/pages-order/static/carNoneIcon.png"></image>
|
||
<view class="btn" @click="addCarUserInfo()">
|
||
<image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image>
|
||
<text >添加车辆信息</text>
|
||
</view>
|
||
</template>
|
||
<template v-else>
|
||
<view class="carTitle">车辆信息</view>
|
||
<scroll-view scroll-x="true">
|
||
<view class="carListTab">
|
||
<view v-for="(item, index) in carList" :key="index" :class="{'active': activeCarIndex === index}"
|
||
class="carTabItem" @click="() => activeCarIndex = index">
|
||
<image :src="imgUrlPrex + item.logoImg" class="carImage" mode="aspectFit"></image>
|
||
<text>{{ item.licenseNumber }}</text>
|
||
</view>
|
||
<view class="carTabItemNew" @click="editCarInfo()">
|
||
<text>+</text>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
<view class="carDetail">
|
||
<view class="carHeader">
|
||
<image :src="imgUrlPrex + carList[activeCarIndex].logoImg" class="carImage" mode="aspectFill"></image>
|
||
<view class="carHeaderRight">
|
||
<text class="carNumber">{{ carList[activeCarIndex].licenseNumber }}</text>
|
||
<text class="carType">{{
|
||
(carList[activeCarIndex].brandStr == null ? '' : carList[activeCarIndex].brandStr) + ' ' + (carList[activeCarIndex].modelStr == null ? '' : carList[activeCarIndex].modelStr)
|
||
}}
|
||
</text>
|
||
</view>
|
||
</view>
|
||
<view class="carBody">
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<view class="label">车架号</view>
|
||
<view class="value">{{ carList[activeCarIndex].vin }}</view>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<view class="label">发动机号</view>
|
||
<view class="value">{{ carList[activeCarIndex].engineNumber }}</view>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<view class="label">年检到期时间</view>
|
||
<view class="value">{{ carList[activeCarIndex].nextInspectionDate || '未知' }}</view>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<view class="label">保险时间</view>
|
||
<view class="value">{{ carList[activeCarIndex].insuranceExpiryDate || '未知' }}</view>
|
||
</view>
|
||
</view>
|
||
<view class="infoItem">
|
||
<view class="label">注册日期</view>
|
||
<view class="value">{{ carList[activeCarIndex].carRegisterDate || '未知' }}</view>
|
||
</view>
|
||
</view>
|
||
<view class="carFoot">
|
||
<image mode="aspectFit" src="/static/icons/edit.png" style="width: 28rpx;height: 28rpx"></image>
|
||
<text @click="editCarInfo(activeCarIndex)">修改信息</text>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
</view>
|
||
|
||
<view :class="{ 'none': !userInfo }" class="card cardInfo userCard">
|
||
<template v-if="!userInfo">
|
||
<image class="cardNoneIcon" mode="widthFix" src="/pages-order/static/userNone.png"></image>
|
||
<view class="btn">
|
||
<!-- <image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image>-->
|
||
<text >客户信息</text>
|
||
</view>
|
||
</template>
|
||
<template v-else>
|
||
<view class="userTitle">客户信息</view>
|
||
<view class="userContainer">
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">姓名</text>
|
||
<text class="value">{{ userInfo.cusName }}</text>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">性别</text>
|
||
<text class="value">{{ userInfo.sex === '1' ? '女' : '男' }}</text>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">联系方式</text>
|
||
<text class="value">{{ userInfo.phoneNumber }}</text>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">出生年月</text>
|
||
<text class="value">{{ userInfo.birthday }}</text>
|
||
</view>
|
||
</view>
|
||
<view class="infoItem">
|
||
<text class="label">联系地址</text>
|
||
<text class="value">
|
||
{{ userInfo.provinceName }} {{ userInfo.cityName }} {{ userInfo.areaName }} {{ userInfo.address }}
|
||
</text>
|
||
</view>
|
||
</view>
|
||
<view class="userFoot">
|
||
<image mode="aspectFit" src="/static/icons/edit.png" style="width: 28rpx;height: 28rpx"></image>
|
||
<text @click="editUserInfo(userInfo)">修改信息</text>
|
||
</view>
|
||
</template>
|
||
</view>
|
||
|
||
<view class="card cardInfo userCard">
|
||
<template>
|
||
<view class="userTitle">工单信息</view>
|
||
<view class="userContainer" style="padding-bottom: 20rpx">
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">经办人姓名</text>
|
||
<input type="text" style="text-align: left" v-model="formData.handleName" placeholder="请填写经办人姓名"/>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">经办人电话</text>
|
||
<input type="text" style="text-align: left" v-model="formData.handleMobile" placeholder="请填写经办人电话"/>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">进厂时间</text>
|
||
|
||
<picker
|
||
mode="date"
|
||
:value="formData.inTime"
|
||
start="2020-01-01"
|
||
end="2030-12-31"
|
||
@change="bindDateChange1">
|
||
<view style="margin-left: 10rpx">
|
||
{{ formData.inTime}}
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">预计完工</text>
|
||
<picker
|
||
mode="date"
|
||
:value="formData.outTime"
|
||
start="2020-01-01"
|
||
end="2030-12-31"
|
||
@change="bindDateChange2">
|
||
<view style="margin-left: 10rpx">
|
||
{{ formData.outTime}}
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">表显里程</text>
|
||
<input type="text" style="text-align: left" v-model="formData.mileageTraveled" placeholder="请填写表显里程"/>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">三包单位</text>
|
||
<input type="text" style="text-align: left" v-model="formData.threePackUnits" placeholder="请填写三包单位"/>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">最近保养日期</text>
|
||
<picker
|
||
mode="date"
|
||
:value="formData.maintenanceDate"
|
||
start="2020-01-01"
|
||
@change="bindDateChange3">
|
||
<view style="margin-left: 10rpx">
|
||
{{ formData.maintenanceDate}}
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">最近保养公里数</text>
|
||
<input type="text" style="text-align: left" v-model="formData.maintenanceMileage" placeholder="请填写最近保养公里数"/>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">保险名称</text>
|
||
<input type="text" style="text-align: left" v-model="formData.insuranceName" placeholder="请填写保险名称"/>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">管理费</text>
|
||
<input type="text" style="text-align: left" v-model="formData.managerMoney" placeholder="请填写管理费"/>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">救援费</text>
|
||
<input type="text" style="text-align: left" v-model="formData.rescueMoney" placeholder="请填写救援费"/>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">三包费</text>
|
||
<input type="text" style="text-align: left" v-model="formData.threePackMoney" placeholder="请填写救援费"/>
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1">
|
||
<text class="label">定损费</text>
|
||
<input type="text" style="text-align: left" v-model="formData.confirmFaultMoney" placeholder="请填写定损费"/>
|
||
</view>
|
||
<view class="infoItem" style="flex: 1" v-if="repairTypes && repairTypes.length>0">
|
||
<text class="label">维修类型</text>
|
||
<picker @change="repairTypeChange" :value="repairTypeIndex" :range="repairTypes" range-key="label" >
|
||
<view class="uni-input">{{ repairTypes[repairTypeIndex].label}}</view>
|
||
</picker>
|
||
|
||
</view>
|
||
</view>
|
||
<view style="display: flex;align-items: center">
|
||
<view class="infoItem" style="flex: 1" v-if="partDisposals && partDisposals.length>0">
|
||
<text class="label">旧件处置方式</text>
|
||
<picker @change="partDisposalChange" :value="partDisposalIndex" :range="partDisposals" range-key="label" >
|
||
<view class="uni-input">{{ partDisposals[partDisposalIndex].label}}</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
</view>
|
||
|
||
|
||
<view :class="{ 'none': !selectedProj || selectedProj.length === 0 }" class="card cardInfo projCard">
|
||
<template v-if="!selectedProj || selectedProj.length === 0">
|
||
<image class="cardNoneIcon" mode="widthFix" src="/pages-order/static/projectNone.png"></image>
|
||
<view class="btn">
|
||
<image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image>
|
||
<text @click="addProj()">添加维修项目</text>
|
||
</view>
|
||
</template>
|
||
<template v-else>
|
||
<view class="projTitle">维修项目</view>
|
||
<view class="projList">
|
||
<view v-for="item in selectedProj" :key="item.id" class="projItem">
|
||
{{ item.name }}
|
||
</view>
|
||
</view>
|
||
<view class="projFoot">
|
||
<image mode="aspectFit" src="/static/icons/edit.png" style="width: 28rpx;height: 28rpx"></image>
|
||
<text @click="addProj(selectedProj)">修改信息</text>
|
||
</view>
|
||
</template>
|
||
</view>
|
||
|
||
<project-picker ref="proj" @confirm="projConfirm"></project-picker>
|
||
</view>
|
||
<!-- 普通弹窗---拍照上传 -->
|
||
<uni-popup ref="popup" background-color="#fff">
|
||
<view class="popup-content">
|
||
<view class="dl-avatar-box">
|
||
<uni-file-picker :value="fileList" :sizeType="sizeType" @select="afterRead" @delete="deleteFile" limit="9" title="请上传车辆照片(最多选择9张图片)"></uni-file-picker>
|
||
</view>
|
||
<button type="primary" @click="submit">保存</button>
|
||
</view>
|
||
</uni-popup>
|
||
|
||
<view class="footer">
|
||
<view class="btn" @click="submitUpload">创建工单</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import VNavigationBar from '@/components/VNavigationBar.vue'
|
||
import ProjectPicker from "@/components/projectPicker.vue";
|
||
import {bus} from "@/utils/eventBus";
|
||
import request from "@/utils/request";
|
||
import {getToken, setUserInfo, getUserInfo,getStorageWithExpiry,setStorageWithExpiry} from '@/utils/auth.js'
|
||
import config from "@/config";
|
||
import {formatTimestamp, formatTimestampCustom} from "@/utils/utils";
|
||
import upload from "@/utils/upload";
|
||
import {getDictByCode,formatDate} from "@/utils/utils";
|
||
|
||
export default {
|
||
components: {
|
||
ProjectPicker,
|
||
VNavigationBar,
|
||
},
|
||
data() {
|
||
return {
|
||
//上传的图片数组
|
||
fileList: [],
|
||
sizeType:['compressed'],
|
||
repairTypeShow:true,
|
||
phone: '',
|
||
carList: [],
|
||
activeCarIndex: 0,
|
||
userInfo: null,
|
||
selectedProj: [],
|
||
typeList: [],
|
||
ticketType: '01',
|
||
repairTypes:[],
|
||
repairTypeIndex:0,
|
||
partDisposals:[],
|
||
partDisposalIndex:0,
|
||
formData:{
|
||
inTime: null,
|
||
outTime: null,
|
||
handleName: null,
|
||
handleMobile: null,
|
||
mileageTraveled:null,
|
||
threePackUnits:null,
|
||
insuranceName:null,
|
||
managerMoney:0.00,
|
||
rescueMoney:0.00,
|
||
threePackMoney:0.00,
|
||
confirmFaultMoney:0.00,
|
||
partDisposal:null,
|
||
repairType:null,
|
||
},
|
||
options: [
|
||
{label: 'A单', value: '01'},
|
||
{label: 'B单', value: '02'}
|
||
],
|
||
imgUrlPrex: config.baseImageUrl,
|
||
ticketNo: '',
|
||
//前一个页面传过来的参数
|
||
pageData:{},
|
||
}
|
||
},
|
||
watch: {
|
||
'userInfo': {
|
||
handler: function (newVal, oldVal) {
|
||
if(!this.formData.handleName){
|
||
this.formData.handleName = newVal.cusName
|
||
}
|
||
if(!this.formData.handleMobile){
|
||
this.formData.handleMobile = newVal.phoneNumber
|
||
}
|
||
console.log('obj changed:', newVal, oldVal)
|
||
},
|
||
deep: true
|
||
}
|
||
},
|
||
onLoad(data) {
|
||
this.pageData = data
|
||
this.formData.inTime = formatDate(Date.now())
|
||
this.formData.outTime = formatDate(Date.now())
|
||
this.formData.maintenanceDate = formatDate(Date.now())
|
||
this.ticketNo = this.createUniqueCodeByHead('GD')
|
||
if (data.phone) {
|
||
this.phone = data.phone
|
||
this.listUserInfo()
|
||
}
|
||
this.initDict("repair_type")
|
||
this.initDict("repair_part_disposal")
|
||
},
|
||
onShow() {
|
||
},
|
||
methods: {
|
||
|
||
// 日期选择 事件
|
||
bindDateChange1(e) {
|
||
this.formData.inTime = e.target.value; // 更新选择的日期到data中的date变量
|
||
},
|
||
// 日期选择 事件
|
||
bindDateChange3(e) {
|
||
this.formData.maintenanceDate = e.target.value; // 更新选择的日期到data中的date变量
|
||
},
|
||
|
||
// 日期选择 事件
|
||
bindDateChange2(e) {
|
||
this.formData.outTime = e.target.value; // 更新选择的日期到data中的date变量
|
||
},
|
||
|
||
repairTypeChange(event){
|
||
const newIndex = event.detail.value;
|
||
this.repairTypeIndex = newIndex;
|
||
this.formData.repairType = this.repairTypes[newIndex].value;
|
||
},
|
||
partDisposalChange(event){
|
||
const newIndex = event.detail.value;
|
||
this.partDisposalIndex = newIndex;
|
||
this.formData.partDisposal = this.repairTypes[newIndex].value;
|
||
},
|
||
|
||
|
||
async initDict(dictCode){
|
||
let dictArray = getStorageWithExpiry(dictCode);
|
||
console.log(dictArray,"partDisposals")
|
||
if(null==dictArray || undefined==dictArray){
|
||
request({
|
||
url: '/admin-api/system/dict-data/type',
|
||
method: 'get',
|
||
params:{type:dictCode}
|
||
}).then((res) => {
|
||
console.log(res)
|
||
if (res.code == 200) {
|
||
setStorageWithExpiry(dictCode,res.data,3600)
|
||
this.$nextTick(()=>{
|
||
if("repair_type"==dictCode){
|
||
this.repairTypes = res.data
|
||
this.buildRepairType()
|
||
}else{
|
||
this.partDisposals = res.data
|
||
}
|
||
})
|
||
}
|
||
})
|
||
}else{
|
||
this.$nextTick(()=>{
|
||
if("repair_type"==dictCode){
|
||
this.repairTypes = dictArray
|
||
this.buildRepairType()
|
||
}else{
|
||
this.partDisposals = dictArray
|
||
}
|
||
})
|
||
}
|
||
},
|
||
buildRepairType(){
|
||
if(this.pageData.repairType){
|
||
this.repairTypes.map((item,index)=>{
|
||
if(item.value==this.pageData.repairType){
|
||
this.repairTypeIndex = index
|
||
this.formData.repairType = this.repairTypes[index].value;
|
||
return
|
||
}
|
||
})
|
||
}else{
|
||
//默认选中第一个
|
||
this.repairTypeIndex = 0
|
||
this.formData.repairType = this.repairTypes[0].value;
|
||
}
|
||
},
|
||
afterRead(file) {
|
||
for (let i = 0; i < file.tempFilePaths.length; i++) {
|
||
upload({
|
||
url:'/admin-api/infra/file/upload',
|
||
filePath: file.tempFilePaths[i]
|
||
}).then((res)=>{
|
||
this.fileList.push({
|
||
url: config.baseImageUrl+res.data
|
||
})
|
||
console.log(this.fileList)
|
||
})
|
||
}
|
||
},
|
||
|
||
deleteFile(file, index) {
|
||
this.fileList.splice(index, 1);
|
||
},
|
||
|
||
saveWorkingItem(){
|
||
console.log(this.fileList,145)
|
||
},
|
||
|
||
|
||
|
||
createUniqueCodeByHead(head = '') {
|
||
const min = 100; // 最小值
|
||
const max = 999; // 最大值
|
||
return head.toString() + Date.now().toString() + Math.floor(Math.random() * (max - min + 1)) + min;
|
||
},
|
||
|
||
/**
|
||
* 创建工单前上传图片
|
||
*/
|
||
submitUpload(){
|
||
if (this.userInfo === null || this.carList.length === 0 || this.selectedProj.length === 0) {
|
||
uni.showToast({
|
||
title: '请完善信息',
|
||
icon: 'none'
|
||
})
|
||
return
|
||
}
|
||
this.$refs.popup.open("bottom");
|
||
},
|
||
|
||
//新增工单
|
||
submit() {
|
||
let fileStr = this.fileList.map(item=>item.url.replace(config.baseImageUrl,"")).join(",")
|
||
const data = {
|
||
userId: this.userInfo.id,
|
||
ticketNo: this.ticketNo,
|
||
userName: this.userInfo.cusName,
|
||
userMobile: this.userInfo.phoneNumber,
|
||
carId: this.carList[this.activeCarIndex].id,
|
||
carNo: this.carList[this.activeCarIndex].licenseNumber,
|
||
carVin: this.carList[this.activeCarIndex].vin,
|
||
carBrandId: this.carList[this.activeCarIndex].carBrand,
|
||
carBrandName: this.carList[this.activeCarIndex].brandStr,
|
||
carBrandType: this.carList[this.activeCarIndex].brandType,
|
||
adviserId: getUserInfo().id,
|
||
adviserName: getUserInfo().nickname,
|
||
ticketType: this.ticketType,
|
||
itemList: this.formatItem(this.selectedProj),
|
||
fileStr:fileStr,
|
||
...this.formData,
|
||
}
|
||
if(this.pageData && this.pageData.hasOwnProperty("bookingId")){
|
||
data.bookingId = this.pageData.bookingId
|
||
}
|
||
uni.navigateTo({
|
||
// url: '/pages-repair/signature/signature?data=' + JSON.stringify(data)
|
||
url: '/pages-repair/sign/sign?data=' + JSON.stringify(data)
|
||
})
|
||
// request({
|
||
// url: '/admin-api/repair/tickets/create',
|
||
// method: 'POST',
|
||
// data: {
|
||
// userId: this.userInfo.id,
|
||
// ticketNo: this.ticketNo,
|
||
// userName: this.userInfo.cusName,
|
||
// userMobile: this.userInfo.phoneNumber,
|
||
// carId: this.carList[this.activeCarIndex].id,
|
||
// carNo: this.carList[this.activeCarIndex].licenseNumber,
|
||
// carVin: this.carList[this.activeCarIndex].vin,
|
||
// carBrandId: this.carList[this.activeCarIndex].carBrand,
|
||
// carBrandName: this.carList[this.activeCarIndex].brandStr,
|
||
// carBrandType: this.carList[this.activeCarIndex].brandType,
|
||
// adviserId: getUserInfo().id,
|
||
// adviserName: getUserInfo().nickname,
|
||
// ticketType: this.ticketType,
|
||
// itemList: this.formatItem(this.selectedProj)
|
||
// }
|
||
// }).then(res => {
|
||
// uni.showToast({
|
||
// title: '创建成功',
|
||
// icon: 'success'
|
||
// })
|
||
// uni.navigateTo({
|
||
// url: `/pages-order/orderDetail/orderDetail?id=${res.data.id}&isDetail=0`
|
||
// });
|
||
// })
|
||
},
|
||
listUserInfo() {
|
||
this.carList = []
|
||
this.userInfo = null
|
||
this.activeCarIndex = 0
|
||
if (this.phone != '') {
|
||
const params = {
|
||
phoneOrCar: this.phone
|
||
}
|
||
request({
|
||
url: '/admin-api/base/custom/page',
|
||
method: 'GET',
|
||
params: params
|
||
}).then(res => {
|
||
if (res.data.records.length > 0) {
|
||
this.userInfo = res.data.records[0]
|
||
this.getCarList()
|
||
}
|
||
})
|
||
} else {
|
||
uni.showToast({
|
||
title: '请输入手机号|车牌号|车架号',
|
||
icon: 'none'
|
||
})
|
||
}
|
||
},
|
||
// 子表信息预处理
|
||
formatItem(list) {
|
||
if (!(list && list.length > 0)) {
|
||
return []
|
||
}
|
||
return list.map(item => {
|
||
const temp = {
|
||
...item,
|
||
itemName: item.name,
|
||
itemCount: 1,
|
||
itemUnit: item.unit,
|
||
itemPrice: item.price,
|
||
itemMoney: item.price,
|
||
itemTypeId: item.type,
|
||
remark: item.remark,
|
||
itemStatus: item.itemStatus,
|
||
itemType: "01",
|
||
projectId: item.id,
|
||
id: null
|
||
}
|
||
return temp;
|
||
})
|
||
},
|
||
handleChange(event) {
|
||
this.ticketType = event.detail.value;
|
||
},
|
||
|
||
getCarList(carId) {
|
||
const params = {
|
||
userId: this.userInfo.userId,
|
||
pageNo: 1,
|
||
pageSize: 100000
|
||
}
|
||
request({
|
||
url: '/admin-api/base/carMain/page',
|
||
method: 'GET',
|
||
params: params
|
||
}).then(res => {
|
||
this.carList = res.data.records
|
||
for (let i = 0; i < this.carList.length; i++) {
|
||
if (this.carList[i].licenseNumber.toLowerCase() == this.phone.toLowerCase()) {
|
||
this.activeCarIndex = i
|
||
break
|
||
} else if (this.carList[i].vin.toLowerCase() == this.phone.toLowerCase()) {
|
||
this.activeCarIndex = i
|
||
break
|
||
}
|
||
}
|
||
//将时间戳转换
|
||
this.carList.forEach(item => {
|
||
if (item.nextInspectionDate) {
|
||
item.nextInspectionDate = formatTimestampCustom(item.nextInspectionDate)
|
||
}else {
|
||
item.nextInspectionDate = ''
|
||
}
|
||
if (item.insuranceExpiryDate) {
|
||
item.insuranceExpiryDate = formatTimestampCustom(item.insuranceExpiryDate)
|
||
}else {
|
||
item.insuranceExpiryDate = ''
|
||
}
|
||
if (item.carRegisterDate) {
|
||
item.carRegisterDate = formatTimestampCustom(item.carRegisterDate)
|
||
}else {
|
||
item.carRegisterDate = ''
|
||
}
|
||
})
|
||
if (this.pageData.carId) {
|
||
for (let i = 0; i < this.carList.length; i++) {
|
||
if (this.pageData.carId == this.carList[i].id) {
|
||
this.activeCarIndex = i
|
||
break
|
||
}
|
||
}
|
||
}else if(carId){
|
||
for (let i = 0; i < this.carList.length; i++) {
|
||
if (carId == this.carList[i].id) {
|
||
this.activeCarIndex = i
|
||
break
|
||
}
|
||
}
|
||
}
|
||
})
|
||
},
|
||
editCarInfo(index) {
|
||
bus.$off('updateCarInfo')
|
||
bus.$on('updateCarInfo', (carId) => {
|
||
this.$nextTick(()=>{
|
||
//重新查车辆信息
|
||
this.getCarList(carId)
|
||
})
|
||
})
|
||
if (this.userInfo == null) {
|
||
//弹窗提示请选择客户
|
||
uni.showToast({
|
||
title: '请先选择客户',
|
||
icon: 'none'
|
||
})
|
||
} else {
|
||
uni.navigateTo({
|
||
url: `/pages/myCar/carDetail?car=${index >= 0 ? encodeURIComponent(JSON.stringify(this.carList[index])) : ''}&userInfo=${encodeURIComponent(JSON.stringify(this.userInfo))}`
|
||
});
|
||
}
|
||
},
|
||
/**
|
||
* 添加车辆和客户信息
|
||
*/
|
||
addCarUserInfo(){
|
||
if(this.userInfo){
|
||
//已查出客户信息
|
||
uni.navigateTo({
|
||
url: '/pages/myCar/addCarUser?userInfo='+JSON.stringify(this.userInfo)
|
||
})
|
||
}else if(this.phone != ''){
|
||
//输入了内容
|
||
const params = {
|
||
phoneOrCar: this.phone
|
||
}
|
||
request({
|
||
url: '/admin-api/base/custom/page',
|
||
method: 'GET',
|
||
params: params
|
||
}).then(res => {
|
||
if (res.data.records.length > 0) {
|
||
this.userInfo = res.data.records[0]
|
||
//跳转添加客户车辆信息页
|
||
uni.navigateTo({
|
||
url: '/pages/myCar/addCarUser?userInfo='+JSON.stringify(this.userInfo)
|
||
})
|
||
}else{
|
||
//没查出来
|
||
uni.navigateTo({
|
||
url: '/pages/myCar/addCarUser?phoneNum='+this.phone
|
||
})
|
||
}
|
||
})
|
||
}else{
|
||
//没输入,直接加
|
||
uni.navigateTo({
|
||
url: `/pages/myCar/addCarUser`
|
||
})
|
||
}
|
||
},
|
||
editUserInfo(userInfo) {
|
||
if (this.phone == '') return uni.showToast({
|
||
title: '请先输入手机号,再添加客户',
|
||
icon: 'none'
|
||
})
|
||
bus.$off('updateUserInfo')
|
||
bus.$on('updateUserInfo', (userInfo) => {
|
||
this.userInfo = userInfo
|
||
})
|
||
uni.navigateTo({
|
||
url: `/pages/userInfo/editUserInfo?userInfo=${userInfo ? encodeURIComponent(JSON.stringify(userInfo)) : ''}`
|
||
})
|
||
},
|
||
addProj(projList = []) {
|
||
this.$refs.proj.open(projList)
|
||
},
|
||
projConfirm(proj) {
|
||
this.selectedProj = proj
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style lang="less" scoped>
|
||
.popup-content {
|
||
@include flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
padding: 15px;
|
||
height: auto;
|
||
background-color: #fff;
|
||
}
|
||
.container {
|
||
height: 100%;
|
||
background-color: #F3F5F7;
|
||
|
||
.containerBody {
|
||
height: 100%;
|
||
display: flex;
|
||
flex-direction: column;
|
||
background: linear-gradient(180deg, #C1DEFF 0%, rgba(193, 222, 255, 0) 100%);
|
||
background-size: 100% 500rpx;
|
||
background-repeat: no-repeat;
|
||
}
|
||
|
||
.body {
|
||
flex: 1;
|
||
height: 0;
|
||
overflow: auto;
|
||
|
||
.card {
|
||
background: #FFFFFF;
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
margin: 20rpx 32rpx;
|
||
}
|
||
|
||
.phone {
|
||
background: #0174F6;
|
||
|
||
.phoneHeader {
|
||
padding: 20rpx 30rpx;
|
||
|
||
.title {
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
color: #FFFFFF;
|
||
margin-bottom: 10rpx;
|
||
}
|
||
|
||
.desc {
|
||
font-weight: 500;
|
||
font-size: 24rpx;
|
||
color: rgba(255, 255, 255, 0.7);
|
||
}
|
||
}
|
||
|
||
.phoneBody {
|
||
background: #FFFFFF;
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
padding: 0 30rpx;
|
||
|
||
.searchBox {
|
||
padding: 40rpx 0;
|
||
border-bottom: 1rpx solid #EEEEEE;
|
||
}
|
||
|
||
.btn {
|
||
padding: 40rpx 0;
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
column-gap: 10rpx;
|
||
|
||
font-weight: 500;
|
||
font-size: 32rpx;
|
||
color: #0174F6;
|
||
|
||
.btnIcon {
|
||
width: 32rpx;
|
||
height: 32rpx;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
.cardInfo {
|
||
&.none {
|
||
position: relative;
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
|
||
.cardNoneIcon {
|
||
width: 336rpx;
|
||
}
|
||
|
||
.btn {
|
||
position: absolute;
|
||
bottom: 40rpx;
|
||
left: 50%;
|
||
transform: translateX(-50%);
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
column-gap: 10rpx;
|
||
|
||
font-weight: 500;
|
||
font-size: 28rpx;
|
||
color: #0174F6;
|
||
}
|
||
}
|
||
}
|
||
|
||
.projTitle, .userTitle, .carTitle {
|
||
padding: 30rpx;
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
color: #333333;
|
||
}
|
||
|
||
.carCard {
|
||
.carListTab {
|
||
display: flex;
|
||
align-items: center;
|
||
column-gap: 32rpx;
|
||
padding: 0 26rpx 22rpx;
|
||
|
||
.carTabItem {
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
row-gap: 10rpx;
|
||
font-weight: 500;
|
||
font-size: 24rpx;
|
||
color: #333333;
|
||
|
||
&.active {
|
||
.carImage {
|
||
border: 2rpx solid #0174F6;
|
||
}
|
||
|
||
color: #0174F6;
|
||
}
|
||
|
||
.carImage {
|
||
width: 128rpx;
|
||
height: 80rpx;
|
||
background: #F2F2F7;
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
}
|
||
}
|
||
|
||
.carTabItemNew {
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
row-gap: 10rpx;
|
||
font-weight: 500;
|
||
font-size: 24rpx;
|
||
color: #333333;
|
||
border: 2rpx solid #0174F6; /* 默认边框颜色为透明 */
|
||
justify-content: center; /* 垂直居中 */
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
padding: 10rpx; /* 可以根据需要调整内边距 */
|
||
width: 128rpx; /* 与 .carImage 宽度一致 */
|
||
height: 80rpx; /* 与 .carImage 高度一致 */
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
margin-top: -37rpx;
|
||
}
|
||
|
||
}
|
||
|
||
.carDetail {
|
||
background: linear-gradient(180deg, rgba(1, 116, 246, 0.15) 0%, rgba(255, 255, 255, 0) 100%) no-repeat;
|
||
background-size: 100% 184rpx;
|
||
padding: 30rpx 30rpx 0;
|
||
|
||
.carHeader {
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
column-gap: 20rpx;
|
||
|
||
padding-bottom: 30rpx;
|
||
|
||
.carImage {
|
||
width: 192rpx;
|
||
height: 120rpx;
|
||
background: #F2F2F7;
|
||
border-radius: 8rpx 8rpx 8rpx 8rpx;
|
||
}
|
||
|
||
.carHeaderRight {
|
||
display: flex;
|
||
flex-direction: column;
|
||
row-gap: 20rpx;
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
color: #333333;
|
||
|
||
.carType {
|
||
font-weight: 500;
|
||
font-size: 28rpx;
|
||
color: #858BA0;
|
||
}
|
||
}
|
||
}
|
||
|
||
.carBody {
|
||
display: flex;
|
||
flex-direction: column;
|
||
row-gap: 30rpx;
|
||
padding-top: 30rpx;
|
||
border-top: 1rpx solid #DDDDDD;
|
||
}
|
||
|
||
.carFoot {
|
||
|
||
}
|
||
}
|
||
}
|
||
|
||
.projCard {
|
||
.projList {
|
||
padding: 0 30rpx;
|
||
display: flex;
|
||
gap: 20rpx;
|
||
flex-wrap: wrap;
|
||
|
||
.projItem {
|
||
padding: 10rpx 16rpx;
|
||
border-radius: 4rpx 4rpx 4rpx 4rpx;
|
||
border: 2rpx solid #0174F6;
|
||
font-weight: 500;
|
||
font-size: 24rpx;
|
||
color: #0174F6;
|
||
}
|
||
}
|
||
}
|
||
|
||
.userCard {
|
||
.userContainer {
|
||
display: flex;
|
||
flex-direction: column;
|
||
row-gap: 30rpx;
|
||
margin: 0 30rpx;
|
||
}
|
||
}
|
||
|
||
.infoItem {
|
||
display: flex;
|
||
flex-direction: column;
|
||
|
||
.label {
|
||
font-weight: 500;
|
||
font-size: 28rpx;
|
||
color: #858BA0;
|
||
}
|
||
|
||
.value {
|
||
font-weight: 500;
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
}
|
||
}
|
||
|
||
.projFoot, .userFoot, .carFoot {
|
||
padding: 30rpx;
|
||
font-weight: 500;
|
||
font-size: 28rpx;
|
||
color: #0174F6;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
column-gap: 6rpx;
|
||
}
|
||
}
|
||
|
||
.footer {
|
||
height: 136rpx;
|
||
background: #FFFFFF;
|
||
border-radius: 0rpx 0rpx 0rpx 0rpx;
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
|
||
.btn {
|
||
width: 510rpx;
|
||
height: 76rpx;
|
||
background: #0174F6;
|
||
border-radius: 38rpx 38rpx 38rpx 38rpx;
|
||
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
color: #FFFFFF;
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
|
||
}
|
||
}
|
||
|
||
.radio-label {
|
||
//display: flex;
|
||
align-items: center;
|
||
margin-bottom: 10rpx;
|
||
}
|
||
|
||
.radio-label text {
|
||
margin-left: 10rpx;
|
||
}
|
||
|
||
}
|
||
</style>
|