534 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			534 lines
		
	
	
		
			15 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="{ 'none': !carList || carList.length === 0 }" class="card cardInfo carCard">
 | |
|           <template v-if="!carList || carList.length === 0">
 | |
|             <image class="cardNoneIcon" mode="widthFix" src="/pages-order/static/carNoneIcon.png"></image>
 | |
|             <view class="btn">
 | |
|               <image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image>
 | |
|               <text @click="editCarInfo()">添加车辆信息</text>
 | |
|             </view>
 | |
|           </template>
 | |
|           <template v-else>
 | |
|             <view class="carTitle">车辆信息</view>
 | |
|             <view class="carListTab">
 | |
|               <view v-for="(item, index) in carList" :key="index" :class="{'active': activeCarIndex === index}"
 | |
|                     class="carTabItem" @click="() => activeCarIndex = index">
 | |
|                 <image :src="item.carLicenseImg" class="carImage" mode="aspectFit"></image>
 | |
|                 <text>{{ item.licenseNumber }}</text>
 | |
|               </view>
 | |
|             </view>
 | |
|             <view class="carDetail">
 | |
|               <view class="carHeader">
 | |
|                 <image :src="carList[activeCarIndex].carLicenseImg" 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 @click="editUserInfo()">添加客户信息</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="{ '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>
 | |
| 
 | |
|       <view class="footer">
 | |
|         <view class="btn" @click="submit">创建工单</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";
 | |
| 
 | |
| export default {
 | |
|   components: {
 | |
|     ProjectPicker,
 | |
|     VNavigationBar,
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       phone: '',
 | |
|       carList: [],
 | |
|       activeCarIndex: 0,
 | |
|       userInfo: null,
 | |
|       selectedProj: []
 | |
|     }
 | |
|   },
 | |
|   onLoad(data) {
 | |
|   },
 | |
|   methods: {
 | |
|     submit() {
 | |
|       uni.showToast({
 | |
|         title: '创建成功',
 | |
|         icon: 'success'
 | |
|       })
 | |
|       setTimeout(() => {
 | |
|         uni.navigateBack();
 | |
|       }, 600)
 | |
|     },
 | |
|     listUserInfo() {
 | |
|       this.carList = []
 | |
|       this.userInfo = null
 | |
|       console.log("获取用户信息")
 | |
|       const params = {
 | |
|         phoneNumber: this.phone
 | |
|       }
 | |
|       request({
 | |
|         url: '/admin-api/base/custom/page',
 | |
|         method: 'GET',
 | |
|         params: params
 | |
|       }).then(res => {
 | |
|         console.log(res);
 | |
|         if (res.data.records.length > 0) {
 | |
|           this.userInfo = res.data.records[0]
 | |
|           this.getCarList()
 | |
|         }
 | |
|       })
 | |
|     },
 | |
|     getCarList() {
 | |
|       const params = {
 | |
|         userId: this.userInfo.userId
 | |
|       }
 | |
|       request({
 | |
|         url: '/admin-api/base/carMain/page',
 | |
|         method: 'GET',
 | |
|         params: params
 | |
|       }).then(res => {
 | |
|         console.log(res);
 | |
|         this.carList = res.data.records
 | |
|       })
 | |
|     },
 | |
|     editCarInfo(index) {
 | |
|       bus.$off('updateCarInfo')
 | |
|       bus.$on('updateCarInfo', (carInfo) => {
 | |
|         console.log('Car', carInfo)
 | |
|         if (index) {
 | |
|           this.carList[index] = carInfo
 | |
|         } else {
 | |
|           this.carList.push(carInfo)
 | |
|         }
 | |
|       })
 | |
|       uni.navigateTo({
 | |
|         url: `/pages/myCar/carDetail?car=${index >= 0 ? encodeURIComponent(JSON.stringify(this.carList[index])) : ''}`
 | |
|       })
 | |
|     },
 | |
|     editUserInfo(userInfo) {
 | |
|       bus.$off('updateUserInfo')
 | |
|       bus.$on('updateUserInfo', (userInfo) => {
 | |
|         console.log('userInfo', 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>
 | |
| .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;
 | |
|           }
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       .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 {
 | |
|     width: 750rpx;
 | |
|     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;
 | |
| 
 | |
|     }
 | |
|   }
 | |
| 
 | |
| }
 | |
| </style>
 | 
