| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  | <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"> | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |             <view class="title">查找手机号|车牌号|车架号</view> | 
					
						
							|  |  |  |  |             <view class="desc">根据手机号查找|车牌号|车架号/建立客户信息</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |           </view> | 
					
						
							|  |  |  |  |           <view class="phoneBody"> | 
					
						
							|  |  |  |  |             <view class="searchBox"> | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |               <input v-model="phone" placeholder="请输入手机号码|车牌号|车架号" type="tel"> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |             </view> | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |             <view class="btn" @click="listUserInfo"> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |               <image class="btnIcon" mode="aspectFit" src="/pages-order/static/search.png"></image> | 
					
						
							|  |  |  |  |               确认查找 | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </view> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2024-11-12 19:14:21 +08:00
										 |  |  |  | <!--        <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>--> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |         <view :class="{ 'none': !carList || carList.length === 0 }" class="card cardInfo carCard"> | 
					
						
							|  |  |  |  |           <template v-if="!carList || carList.length === 0"> | 
					
						
							| 
									
										
										
										
											2024-11-13 15:24:30 +08:00
										 |  |  |  |             <image @click="addCarUserInfo()" class="cardNoneIcon" mode="widthFix" src="/pages-order/static/carNoneIcon.png"></image> | 
					
						
							|  |  |  |  |             <view class="btn" @click="addCarUserInfo()"> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |               <image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image> | 
					
						
							| 
									
										
										
										
											2024-11-13 15:24:30 +08:00
										 |  |  |  |               <text >添加车辆信息</text> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							|  |  |  |  |           <template v-else> | 
					
						
							|  |  |  |  |             <view class="carTitle">车辆信息</view> | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |             <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> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |               </view> | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |             </scroll-view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |             <view class="carDetail"> | 
					
						
							|  |  |  |  |               <view class="carHeader"> | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |                 <image :src="imgUrlPrex + carList[activeCarIndex].logoImg" class="carImage" mode="aspectFill"></image> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                 <view class="carHeaderRight"> | 
					
						
							|  |  |  |  |                   <text class="carNumber">{{ carList[activeCarIndex].licenseNumber }}</text> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |                   <text class="carType">{{ | 
					
						
							|  |  |  |  |                       (carList[activeCarIndex].brandStr == null ? '' : carList[activeCarIndex].brandStr) + ' ' + (carList[activeCarIndex].modelStr == null ? '' : carList[activeCarIndex].modelStr) | 
					
						
							|  |  |  |  |                     }} | 
					
						
							|  |  |  |  |                   </text> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                 </view> | 
					
						
							|  |  |  |  |               </view> | 
					
						
							|  |  |  |  |               <view class="carBody"> | 
					
						
							|  |  |  |  |                 <view style="display: flex;align-items: center"> | 
					
						
							|  |  |  |  |                   <view class="infoItem" style="flex: 1"> | 
					
						
							|  |  |  |  |                     <view class="label">车架号</view> | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |                     <view class="value">{{ carList[activeCarIndex].vin }}</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                   </view> | 
					
						
							|  |  |  |  |                   <view class="infoItem" style="flex: 1"> | 
					
						
							|  |  |  |  |                     <view class="label">发动机号</view> | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |                     <view class="value">{{ carList[activeCarIndex].engineNumber }}</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                   </view> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view style="display: flex;align-items: center"> | 
					
						
							|  |  |  |  |                   <view class="infoItem" style="flex: 1"> | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |                     <view class="label">年检到期时间</view> | 
					
						
							|  |  |  |  |                     <view class="value">{{ carList[activeCarIndex].nextInspectionDate || '未知' }}</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                   </view> | 
					
						
							|  |  |  |  |                   <view class="infoItem" style="flex: 1"> | 
					
						
							|  |  |  |  |                     <view class="label">保险时间</view> | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |                     <view class="value">{{ carList[activeCarIndex].insuranceExpiryDate || '未知' }}</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                   </view> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |                 <view class="infoItem"> | 
					
						
							|  |  |  |  |                   <view class="label">注册日期</view> | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |                   <view class="value">{{ carList[activeCarIndex].carRegisterDate || '未知' }}</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                 </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"> | 
					
						
							| 
									
										
										
										
											2024-11-13 15:24:30 +08:00
										 |  |  |  | <!--              <image mode="aspectFit" src="/pages-order/static/addIcon.png" style="width: 28rpx;height: 28rpx"></image>--> | 
					
						
							|  |  |  |  |               <text >客户信息</text> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |             </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> | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |                   <text class="value">{{ userInfo.cusName }}</text> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                 </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> | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |                   <text class="value">{{ userInfo.phoneNumber }}</text> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |                 </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> | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         <view class="card cardInfo userCard"> | 
					
						
							|  |  |  |  |           <template> | 
					
						
							|  |  |  |  |             <view class="userTitle">工单信息</view> | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |             <view class="userContainer" style="padding-bottom: 20rpx"> | 
					
						
							| 
									
										
										
										
											2024-12-03 11:11:40 +08:00
										 |  |  |  |               <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> | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |               <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> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:54:29 +08:00
										 |  |  |  |               <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> | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |               <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> | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |                 <view class="infoItem" style="flex: 1" v-if="repairTypes && repairTypes.length>0"> | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |                   <text class="label">维修类型</text> | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |                   <picker @change="repairTypeChange" :value="repairTypeIndex" :range="repairTypes" range-key="label" > | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |                     <view class="uni-input">{{ repairTypes[repairTypeIndex].label}}</view> | 
					
						
							|  |  |  |  |                   </picker> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |               </view> | 
					
						
							|  |  |  |  |               <view style="display: flex;align-items: center"> | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |                 <view class="infoItem" style="flex: 1" v-if="partDisposals && partDisposals.length>0"> | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |                   <text class="label">旧件处置方式</text> | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |                   <picker @change="partDisposalChange" :value="partDisposalIndex" :range="partDisposals" range-key="label" > | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |                     <view class="uni-input">{{ partDisposals[partDisposalIndex].label}}</view> | 
					
						
							|  |  |  |  |                   </picker> | 
					
						
							|  |  |  |  |                 </view> | 
					
						
							|  |  |  |  |               </view> | 
					
						
							|  |  |  |  |             </view> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							|  |  |  |  |         </view> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |         <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> | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |       <!-- 普通弹窗---拍照上传 --> | 
					
						
							|  |  |  |  |       <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> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       <view class="footer"> | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |         <view class="btn" @click="submitUpload">创建工单</view> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       </view> | 
					
						
							|  |  |  |  |     </view> | 
					
						
							|  |  |  |  |   </view> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							|  |  |  |  | import VNavigationBar from '@/components/VNavigationBar.vue' | 
					
						
							|  |  |  |  | import ProjectPicker from "@/components/projectPicker.vue"; | 
					
						
							|  |  |  |  | import {bus} from "@/utils/eventBus"; | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  | import request from "@/utils/request"; | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  | import {getToken, setUserInfo, getUserInfo,getStorageWithExpiry,setStorageWithExpiry} from '@/utils/auth.js' | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  | import config from "@/config"; | 
					
						
							|  |  |  |  | import {formatTimestamp, formatTimestampCustom} from "@/utils/utils"; | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  | import upload from "@/utils/upload"; | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  | import {getDictByCode,formatDate} from "@/utils/utils"; | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | export default { | 
					
						
							|  |  |  |  |   components: { | 
					
						
							|  |  |  |  |     ProjectPicker, | 
					
						
							|  |  |  |  |     VNavigationBar, | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |       //上传的图片数组
 | 
					
						
							|  |  |  |  |       fileList: [], | 
					
						
							|  |  |  |  |       sizeType:['compressed'], | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |       repairTypeShow:true, | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       phone: '', | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |       carList: [], | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       activeCarIndex: 0, | 
					
						
							|  |  |  |  |       userInfo: null, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |       selectedProj: [], | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |       typeList: [], | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |       ticketType: '01', | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |       repairTypes:[], | 
					
						
							|  |  |  |  |       repairTypeIndex:0, | 
					
						
							|  |  |  |  |       partDisposals:[], | 
					
						
							|  |  |  |  |       partDisposalIndex:0, | 
					
						
							|  |  |  |  |       formData:{ | 
					
						
							|  |  |  |  |         inTime: null, | 
					
						
							|  |  |  |  |         outTime: null, | 
					
						
							| 
									
										
										
										
											2024-12-03 11:11:40 +08:00
										 |  |  |  |         handleName: null, | 
					
						
							|  |  |  |  |         handleMobile: null, | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |         mileageTraveled:null, | 
					
						
							|  |  |  |  |         threePackUnits:null, | 
					
						
							|  |  |  |  |         insuranceName:null, | 
					
						
							|  |  |  |  |         managerMoney:0.00, | 
					
						
							|  |  |  |  |         rescueMoney:0.00, | 
					
						
							|  |  |  |  |         threePackMoney:0.00, | 
					
						
							|  |  |  |  |         confirmFaultMoney:0.00, | 
					
						
							|  |  |  |  |         partDisposal:null, | 
					
						
							|  |  |  |  |         repairType:null, | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |       options: [ | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |         {label: 'A单', value: '01'}, | 
					
						
							|  |  |  |  |         {label: 'B单', value: '02'} | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |       ], | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |       imgUrlPrex: config.baseImageUrl, | 
					
						
							|  |  |  |  |       ticketNo: '', | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |       //前一个页面传过来的参数
 | 
					
						
							|  |  |  |  |       pageData:{}, | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-12-03 11:11:40 +08:00
										 |  |  |  |   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 | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |   onLoad(data) { | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |     this.pageData = data | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |     this.formData.inTime = formatDate(Date.now()) | 
					
						
							|  |  |  |  |     this.formData.outTime = formatDate(Date.now()) | 
					
						
							| 
									
										
										
										
											2024-12-05 10:54:29 +08:00
										 |  |  |  |     this.formData.maintenanceDate = formatDate(Date.now()) | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |     this.ticketNo = this.createUniqueCodeByHead('GD') | 
					
						
							|  |  |  |  |     if (data.phone) { | 
					
						
							|  |  |  |  |       this.phone = data.phone | 
					
						
							|  |  |  |  |       this.listUserInfo() | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |     this.initDict("repair_type") | 
					
						
							|  |  |  |  |     this.initDict("repair_part_disposal") | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   onShow() { | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |     // 日期选择 事件
 | 
					
						
							|  |  |  |  |     bindDateChange1(e) { | 
					
						
							|  |  |  |  |       this.formData.inTime = e.target.value; // 更新选择的日期到data中的date变量
 | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-05 10:54:29 +08:00
										 |  |  |  |     // 日期选择 事件
 | 
					
						
							|  |  |  |  |     bindDateChange3(e) { | 
					
						
							|  |  |  |  |       this.formData.maintenanceDate = e.target.value; // 更新选择的日期到data中的date变量
 | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     // 日期选择 事件
 | 
					
						
							|  |  |  |  |     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; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |     async initDict(dictCode){ | 
					
						
							|  |  |  |  |       let dictArray = getStorageWithExpiry(dictCode); | 
					
						
							|  |  |  |  |       console.log(dictArray,"partDisposals") | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |       if(null==dictArray || undefined==dictArray){ | 
					
						
							|  |  |  |  |         request({ | 
					
						
							|  |  |  |  |           url: '/admin-api/system/dict-data/type', | 
					
						
							|  |  |  |  |           method: 'get', | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |           params:{type:dictCode} | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |         }).then((res) => { | 
					
						
							|  |  |  |  |           console.log(res) | 
					
						
							|  |  |  |  |           if (res.code == 200) { | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |             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){ | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |             this.repairTypes = dictArray | 
					
						
							|  |  |  |  |             this.buildRepairType() | 
					
						
							| 
									
										
										
										
											2024-11-08 16:38:00 +08:00
										 |  |  |  |           }else{ | 
					
						
							|  |  |  |  |             this.partDisposals = dictArray | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |           } | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  |     buildRepairType(){ | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |       if(this.pageData.repairType){ | 
					
						
							|  |  |  |  |         this.repairTypes.map((item,index)=>{ | 
					
						
							|  |  |  |  |           if(item.value==this.pageData.repairType){ | 
					
						
							|  |  |  |  |             this.repairTypeIndex = index | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |             this.formData.repairType = this.repairTypes[index].value; | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |             return | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:03 +08:00
										 |  |  |  |       }else{ | 
					
						
							|  |  |  |  |         //默认选中第一个
 | 
					
						
							|  |  |  |  |         this.repairTypeIndex = 0 | 
					
						
							|  |  |  |  |         this.formData.repairType = this.repairTypes[0].value; | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |     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) | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |     createUniqueCodeByHead(head = '') { | 
					
						
							|  |  |  |  |       const min = 100; // 最小值
 | 
					
						
							|  |  |  |  |       const max = 999; // 最大值
 | 
					
						
							|  |  |  |  |       return head.toString() + Date.now().toString() + Math.floor(Math.random() * (max - min + 1)) + min; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * 创建工单前上传图片 | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     submitUpload(){ | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |       if (this.userInfo === null || this.carList.length === 0 || this.selectedProj.length === 0) { | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |         uni.showToast({ | 
					
						
							|  |  |  |  |           title: '请完善信息', | 
					
						
							|  |  |  |  |           icon: 'none' | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         return | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |       this.$refs.popup.open("bottom"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     //新增工单
 | 
					
						
							|  |  |  |  |     submit() { | 
					
						
							|  |  |  |  |       let fileStr = this.fileList.map(item=>item.url.replace(config.baseImageUrl,"")).join(",") | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |       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, | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  |         itemList: this.formatItem(this.selectedProj), | 
					
						
							| 
									
										
										
										
											2024-11-05 18:35:24 +08:00
										 |  |  |  |         fileStr:fileStr, | 
					
						
							|  |  |  |  |         ...this.formData, | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-07 14:16:06 +08:00
										 |  |  |  |       if(this.pageData && this.pageData.hasOwnProperty("bookingId")){ | 
					
						
							|  |  |  |  |         data.bookingId = this.pageData.bookingId | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |       uni.navigateTo({ | 
					
						
							| 
									
										
										
										
											2024-10-31 15:20:22 +08:00
										 |  |  |  |         // url: '/pages-repair/signature/signature?data=' + JSON.stringify(data)
 | 
					
						
							|  |  |  |  |         url: '/pages-repair/sign/sign?data=' + JSON.stringify(data) | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |       // 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`
 | 
					
						
							|  |  |  |  |       //   });
 | 
					
						
							|  |  |  |  |       // })
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |     listUserInfo() { | 
					
						
							|  |  |  |  |       this.carList = [] | 
					
						
							|  |  |  |  |       this.userInfo = null | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |       this.activeCarIndex = 0 | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |       if (this.phone != '') { | 
					
						
							|  |  |  |  |         const params = { | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |           phoneOrCar: this.phone | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |         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({ | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |           title: '请输入手机号|车牌号|车架号', | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |           icon: 'none' | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |     // 子表信息预处理
 | 
					
						
							|  |  |  |  |     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; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 16:37:01 +08:00
										 |  |  |  |     getCarList(carId) { | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |       const params = { | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |         userId: this.userInfo.userId, | 
					
						
							|  |  |  |  |         pageNo: 1, | 
					
						
							|  |  |  |  |         pageSize: 100000 | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |       request({ | 
					
						
							|  |  |  |  |         url: '/admin-api/base/carMain/page', | 
					
						
							|  |  |  |  |         method: 'GET', | 
					
						
							|  |  |  |  |         params: params | 
					
						
							|  |  |  |  |       }).then(res => { | 
					
						
							|  |  |  |  |         this.carList = res.data.records | 
					
						
							| 
									
										
										
										
											2024-10-28 16:37:28 +08:00
										 |  |  |  |         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 | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |         //将时间戳转换
 | 
					
						
							|  |  |  |  |         this.carList.forEach(item => { | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |           if (item.nextInspectionDate) { | 
					
						
							|  |  |  |  |             item.nextInspectionDate = formatTimestampCustom(item.nextInspectionDate) | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |           }else { | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |             item.nextInspectionDate = '' | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |           if (item.insuranceExpiryDate) { | 
					
						
							|  |  |  |  |             item.insuranceExpiryDate = formatTimestampCustom(item.insuranceExpiryDate) | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |           }else { | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |             item.insuranceExpiryDate = '' | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |           } | 
					
						
							|  |  |  |  |           if (item.carRegisterDate) { | 
					
						
							|  |  |  |  |             item.carRegisterDate = formatTimestampCustom(item.carRegisterDate) | 
					
						
							|  |  |  |  |           }else { | 
					
						
							|  |  |  |  |             item.carRegisterDate = '' | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |         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 | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-11-13 16:37:01 +08:00
										 |  |  |  |         }else if(carId){ | 
					
						
							|  |  |  |  |           for (let i = 0; i < this.carList.length; i++) { | 
					
						
							|  |  |  |  |             if (carId == this.carList[i].id) { | 
					
						
							|  |  |  |  |               this.activeCarIndex = i | 
					
						
							|  |  |  |  |               break | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-11-06 18:23:38 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-17 21:34:02 +08:00
										 |  |  |  |       }) | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |     editCarInfo(index) { | 
					
						
							|  |  |  |  |       bus.$off('updateCarInfo') | 
					
						
							| 
									
										
										
										
											2024-11-13 16:37:01 +08:00
										 |  |  |  |       bus.$on('updateCarInfo', (carId) => { | 
					
						
							|  |  |  |  |         this.$nextTick(()=>{ | 
					
						
							|  |  |  |  |           //重新查车辆信息
 | 
					
						
							|  |  |  |  |           this.getCarList(carId) | 
					
						
							|  |  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |       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))}` | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-13 15:24:30 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * 添加车辆和客户信息 | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     addCarUserInfo(){ | 
					
						
							| 
									
										
										
										
											2024-11-23 09:58:45 +08:00
										 |  |  |  |       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` | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |     editUserInfo(userInfo) { | 
					
						
							| 
									
										
										
										
											2024-10-30 15:53:34 +08:00
										 |  |  |  |       if (this.phone == '') return uni.showToast({ | 
					
						
							|  |  |  |  |         title: '请先输入手机号,再添加客户', | 
					
						
							|  |  |  |  |         icon: 'none' | 
					
						
							|  |  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       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> | 
					
						
							| 
									
										
										
										
											2024-11-04 14:32:41 +08:00
										 |  |  |  | .popup-content { | 
					
						
							|  |  |  |  | @include flex; | 
					
						
							|  |  |  |  |   align-items: center; | 
					
						
							|  |  |  |  |   justify-content: center; | 
					
						
							|  |  |  |  |   padding: 15px; | 
					
						
							|  |  |  |  |   height: auto; | 
					
						
							|  |  |  |  |   background-color: #fff; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  | .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; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         .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; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       .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; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |   .radio-label { | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |  |     //display: flex;
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  |     margin-bottom: 10rpx; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .radio-label text { | 
					
						
							|  |  |  |  |     margin-left: 10rpx; | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | </style> |