572 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			572 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|   | <template> | |||
|  |   <view class="content"> | |||
|  | <!--    <view class="top-heder">--> | |||
|  | <!--      <view class="t-left" @click="getback()">--> | |||
|  | <!--        <uni-icons type="left" size="18"></uni-icons>--> | |||
|  | <!--      </view>--> | |||
|  | <!--      <view class="t-title">--> | |||
|  | <!--        <text>订单详情</text>--> | |||
|  | <!--      </view>--> | |||
|  | <!--      <view class="t-you"></view>--> | |||
|  | <!--    </view>--> | |||
|  |     <headersVue titles="订单详情" style="position: static !important;"> | |||
|  |       <u-icon name="arrow-left" color="#fff" size="18"></u-icon> | |||
|  |     </headersVue> | |||
|  |     <view class="x-box"> | |||
|  |       <view class="box-top"> | |||
|  |         <view style="border-right: 1px solid  #EEEEEE; width: 50%;"> | |||
|  |           <view class="touxiang" v-if="!sureWorker.avatar"> | |||
|  |             <image src="../../static/detection/touxiang.png" mode=""></image> | |||
|  |           </view> | |||
|  |           <view v-else> | |||
|  |             <image :src="sureWorker.avatar" mode=""></image> | |||
|  |           </view> | |||
|  |           <view style="margin-left: 35%;" v-if="sureWorker.nickname" class="h-title">{{ sureWorker.nickname }}</view> | |||
|  |           <view class="sanniu" @click="getWorker()"> | |||
|  |             <text>选择接待员</text> | |||
|  |           </view> | |||
|  |         </view> | |||
|  |         <view style=" width: 50%;"> | |||
|  |           <view class="t-input"> | |||
|  |             <input type="text" v-model="cph" placeholder="请输入车牌号"> | |||
|  |           </view> | |||
|  |           <!-- 	<view class="t-input" @click="show = true"> | |||
|  |             <text style="color: #0D2E8D;">{{lei}}</text> | |||
|  |             </view> --> | |||
|  |         </view> | |||
|  | 
 | |||
|  |       </view> | |||
|  |       <view class="box-dis"> | |||
|  |         <view class="shop-img"> | |||
|  |           <image :src="orderInfo.goodsImage" mode=""></image> | |||
|  |         </view> | |||
|  |         <view class="ds-right"> | |||
|  |           <view class="h-title">{{ orderInfo.goodsTitle }}</view> | |||
|  |           <view class="dis-hui"> | |||
|  |             <text>客户:</text> | |||
|  |             <text>{{ orderInfo.buyUserName ? orderInfo.buyUserName : "" }}</text> | |||
|  |           </view> | |||
|  |           <view class="dis-hui"> | |||
|  |             <text>手机号:</text> | |||
|  |             <text>{{ orderInfo.buyUserPhone }}</text> | |||
|  |           </view> | |||
|  |         </view> | |||
|  |       </view> | |||
|  |     </view> | |||
|  |     <view class="x-box"> | |||
|  |       <view class="h-title">订单详情</view> | |||
|  |       <view class="on-input"> | |||
|  |         <view class="o-left">订单编号:</view> | |||
|  |         <view class="o-right">{{ orderInfo.orderNo }}</view> | |||
|  |       </view> | |||
|  |       <view class="on-input"> | |||
|  |         <view class="o-left">支付时间:</view> | |||
|  |         <view class="o-right">{{ orderInfo.payTime }}</view> | |||
|  |       </view> | |||
|  |       <view class="on-input"> | |||
|  |         <view class="o-left">商品原价:</view> | |||
|  |         <view class="o-right">{{ orderInfo.goodsPrice / 100 }}</view> | |||
|  |       </view> | |||
|  |       <view class="on-input"> | |||
|  |         <view class="o-left">折扣:</view> | |||
|  |         <view class="o-right">{{ orderInfo.reduceMoney / 100 }}</view> | |||
|  |       </view> | |||
|  |       <view class="on-input"> | |||
|  |         <view class="o-left">优惠券减免:</view> | |||
|  |         <view class="o-right">{{ orderInfo.couponDiscount / 100 }}</view> | |||
|  |       </view> | |||
|  |       <view class="bottom-input"> | |||
|  |         <view class="o-left">实付金额:</view> | |||
|  |         <view class="o-zui">{{ (orderInfo.payMoney + orderInfo.balance) / 100 }}</view> | |||
|  |       </view> | |||
|  | 
 | |||
|  |       <view class="on-input" @click="showLeadMan = true"> | |||
|  |         <view class="o-left"> | |||
|  | <!--          <text style="color: red;font-weight: bold;text-align: center;">*</text>--> | |||
|  |           引车员 | |||
|  |           <text class="xixi">点击选择</text> | |||
|  |         </view> | |||
|  |         <view class="o-right"> | |||
|  |           <input type="text" disabled v-model="leadManName" placeholder="请选择引车员"> | |||
|  |         </view> | |||
|  |       </view> | |||
|  |       <view class="on-input" @click="toSelectProject()"> | |||
|  |         <view class="o-left">检测流程</view> | |||
|  |         <view class="o-right"> | |||
|  |           <input type="textarea" disabled v-model="inspectionWorkNodeStr" placeholder="点击选择检测流程"> | |||
|  |         </view> | |||
|  |       </view> | |||
|  |     </view> | |||
|  |     <view @click="takeOut()" class="annniu"> | |||
|  |       <view class="">开始检测</view> | |||
|  |     </view> | |||
|  |     <u-picker :show="show" :columns="columns" keyName="label" @close="close" @confirm="confirm" @change="change" | |||
|  |               @cancel="cancel"></u-picker> | |||
|  |     <u-popup :show="xling" @close="closexl" :round="10" @open="openxl"> | |||
|  |       <view class="popup-box"> | |||
|  |         <view class="sousuo"> | |||
|  |           <uni-icons type="search" size="22"></uni-icons> | |||
|  |           <input type="text" v-model="searchValue" placeholder="请输入招待员信息"> | |||
|  |           <text @click="getWorker()">搜索</text> | |||
|  |         </view> | |||
|  |         <view class="list-box"> | |||
|  |           <scroll-view class="list_scroll" scroll-y="true"> | |||
|  |             <view class="list-qiu" v-for="(item,index) in workerList" :key="index"> | |||
|  |               <view class="">{{ item.nickname }} | |||
|  |                 <text class="tel">{{ item.mobile }}</text> | |||
|  |               </view> | |||
|  |               <view class="banniu"> | |||
|  |                 <text @click="sureWorkerFun(item)">选择</text> | |||
|  |               </view> | |||
|  |             </view> | |||
|  |           </scroll-view> | |||
|  |         </view> | |||
|  |       </view> | |||
|  |     </u-popup> | |||
|  |     <u-picker :show="showLeadMan" :columns="leadManList" :defaultIndex="defaultIndex" @confirm="confirmLeadMan" | |||
|  |               @cancel="cancelLeadMan" | |||
|  |               keyName="nickname"></u-picker> | |||
|  |   </view> | |||
|  | </template> | |||
|  | 
 | |||
|  | <script> | |||
|  | import config from '@/config' | |||
|  | import request from '../../utils/request'; | |||
|  | import headersVue from "@/components/header/headers.vue"; | |||
|  | 
 | |||
|  | export default { | |||
|  |   components: {headersVue}, | |||
|  |   data() { | |||
|  |     return { | |||
|  |       baseUrl: this.$baseUrl, | |||
|  |       show: false, | |||
|  |       xling: false, | |||
|  |       lei: '请选择车辆类型', | |||
|  | 
 | |||
|  |       columns: [], | |||
|  |       workerList: [], | |||
|  |       cph: '', | |||
|  |       orderId: '', | |||
|  |       partnerId: uni.getStorageSync("partnerId"), | |||
|  |       orderInfo: {}, | |||
|  |       searchValue: '', | |||
|  |       inspectionWorkNodeStr: "", | |||
|  |       inspectionWorkNodes: [], | |||
|  |       sureWorker: {}, | |||
|  |       leadManList: [], | |||
|  |       showLeadMan: false, | |||
|  |       defaultIndex: [0], | |||
|  |       isInsert: true, | |||
|  |       leadManName:'', | |||
|  |       leadManId:'', | |||
|  |     } | |||
|  |   }, | |||
|  | 
 | |||
|  |   onLoad(opion) { | |||
|  |     this.orderId = opion.orderId | |||
|  |     this.getindex() | |||
|  |     uni.$on('selectProject', (data) => { | |||
|  |       this.inspectionWorkNodes = data | |||
|  |       for (var i = 0; i < this.inspectionWorkNodes.length; i++) { | |||
|  |         this.inspectionWorkNodeStr = this.inspectionWorkNodeStr + this.inspectionWorkNodes[i].projectName + "  " | |||
|  |         this.inspectionWorkNodes[i].orderNum = i + 1 | |||
|  |       } | |||
|  |     }); | |||
|  |     this.getLeadeMan() | |||
|  |   }, | |||
|  |   methods: { | |||
|  |     async takeOut() { | |||
|  |       if (!this.sureWorker.id) { | |||
|  |         uni.showToast({ | |||
|  |           title: "请选择招待员", | |||
|  |           icon: "error" | |||
|  |         }) | |||
|  |         return | |||
|  |       } | |||
|  |       if (!this.cph) { | |||
|  |         uni.showToast({ | |||
|  |           title: "请输入车牌号", | |||
|  |           icon: "error" | |||
|  |         }) | |||
|  |         return | |||
|  |       } | |||
|  |       if (!this.inspectionWorkNodes.length) { | |||
|  |         uni.showToast({ | |||
|  |           title: "请选择检测流程", | |||
|  |           icon: "error" | |||
|  |         }) | |||
|  |         return | |||
|  |       } | |||
|  |       if (!this.leadManId) { | |||
|  |         uni.showToast({ | |||
|  |           title: "请选择引车员", | |||
|  |           icon: "error" | |||
|  |         }) | |||
|  |         return | |||
|  |       } | |||
|  | 
 | |||
|  |       let res = await request({ | |||
|  |         url: '/partnerOwn/partner/takeOut', | |||
|  |         method: 'post', | |||
|  |         data: { | |||
|  |           partnerId: this.partnerId, | |||
|  |           orderId: this.orderId, | |||
|  |           workId: this.sureWorker.id, | |||
|  |           inspectionWorkNodes: this.inspectionWorkNodes, | |||
|  |           leadManId: this.leadManId, | |||
|  |           carNum: this.cph | |||
|  |         }, | |||
|  |       }) | |||
|  |       if (res.code == 200) { | |||
|  |         uni.showToast({ | |||
|  |           title: "订单正式开始" | |||
|  |         }) | |||
|  |         setTimeout(() => { | |||
|  |           uni.navigateBack() | |||
|  |         }, 1000); | |||
|  |       } else { | |||
|  |         uni.showToast({ | |||
|  |           title: "异常错误", | |||
|  |           icon: "error" | |||
|  |         }) | |||
|  |       } | |||
|  | 
 | |||
|  |     }, | |||
|  |     cancelLeadMan() { | |||
|  |       this.showLeadMan = false | |||
|  |     }, | |||
|  |     confirmLeadMan(e) { | |||
|  |       this.leadManName = e.value[0].nickname | |||
|  |       this.leadManId = e.value[0].id | |||
|  |       this.showLeadMan = false | |||
|  |     }, | |||
|  |     toSelectProject() { | |||
|  |       uni.navigateTo({ | |||
|  |         url: `/pages/index/selectProject?selectProject=${JSON.stringify(this.inspectionWorkNodes)}` | |||
|  |       }) | |||
|  |     }, | |||
|  |     /*获取引车员信息*/ | |||
|  |     getLeadeMan() { | |||
|  |       request({ | |||
|  |         url: '/system/role/getUsersByRoleCode', | |||
|  |         method: 'get', | |||
|  |         params: { | |||
|  |           code: "jcycy" | |||
|  |         } | |||
|  |       }).then(res => { | |||
|  |         this.leadManList.push(res.data) | |||
|  |       }) | |||
|  |     }, | |||
|  |     async sureWorkerFun(data) { | |||
|  |       this.sureWorker = data | |||
|  |       this.xling = false | |||
|  |     }, | |||
|  |     async getWorker() { | |||
|  |       this.xling = true | |||
|  |       let res = await request({ | |||
|  |         url: '/partnerOwn/partner/getWorkList', | |||
|  |         method: 'get', | |||
|  |         params: { | |||
|  |           partnerId: this.partnerId, | |||
|  |           workName: this.searchValue, | |||
|  |           pageNum: 1, | |||
|  |           pageSize: 1000, | |||
|  |         }, | |||
|  |       }) | |||
|  |       this.workerList = res.rows | |||
|  |     }, | |||
|  |     async getindex() { | |||
|  |       let res = await request({ | |||
|  |         url: '/rescue/dict/data/type/inspection_car_type', | |||
|  |         method: 'get', | |||
|  |       }) | |||
|  |       this.columns.push(res.data) | |||
|  |       let orderRes = await request({ | |||
|  |         url: '/partnerOwn/partner/orderDetail', | |||
|  |         method: 'get', | |||
|  |         params: { | |||
|  |           partnerId: this.partnerId, | |||
|  |           orderId: this.orderId | |||
|  |         } | |||
|  |       }) | |||
|  |       this.orderInfo = orderRes.data | |||
|  |       this.cph = orderRes.data.carNum | |||
|  |     }, | |||
|  |     closexl(e) { | |||
|  |       this.xling = false | |||
|  | 
 | |||
|  |     }, | |||
|  |     openxl(e) { | |||
|  |     }, | |||
|  |     close(e) { | |||
|  |     }, | |||
|  |     confirm(e) { | |||
|  |       this.show = false, | |||
|  |           this.lei = e.value[0].label | |||
|  |       this.carType = e.value[0].value | |||
|  |     }, | |||
|  |     change(e) { | |||
|  |     }, | |||
|  |     cancel(e) { | |||
|  |       this.show = false | |||
|  |     }, | |||
|  |   } | |||
|  | } | |||
|  | </script> | |||
|  | 
 | |||
|  | <style scoped lang="scss"> | |||
|  | image { | |||
|  |   width: 100%; | |||
|  |   height: 100%; | |||
|  | } | |||
|  | 
 | |||
|  | .content { | |||
|  |   box-sizing: border-box; | |||
|  |   width: 100%; | |||
|  |   // height: calc(100vh);
 | |||
|  |   background: #F4F4F4; | |||
|  | } | |||
|  | 
 | |||
|  | .top-heder { | |||
|  |   width: 100%; | |||
|  |   // height: 46px;
 | |||
|  |   background: white; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: space-between; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 5px 15px; | |||
|  |   padding-top: 45px; | |||
|  |   padding-bottom: 15px; | |||
|  |   margin-bottom: 10px; | |||
|  | } | |||
|  | 
 | |||
|  | .t-title { | |||
|  |   font-size: 17px; | |||
|  |   font-weight: bold; | |||
|  |   color: #333333; | |||
|  | } | |||
|  | 
 | |||
|  | .t-left { | |||
|  |   width: 10%; | |||
|  | } | |||
|  | 
 | |||
|  | .t-you { | |||
|  |   height: 100%; | |||
|  |   width: 10%; | |||
|  | } | |||
|  | 
 | |||
|  | .x-box { | |||
|  |   width: 95%; | |||
|  |   margin: 10px auto; | |||
|  |   ackground: #FFFFFF; | |||
|  |   border-radius: 8px; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 10px; | |||
|  |   background: white; | |||
|  | } | |||
|  | 
 | |||
|  | .touxiang { | |||
|  |   width: 50px; | |||
|  |   height: 50px; | |||
|  |   border-radius: 50%; | |||
|  |   overflow: hidden; | |||
|  |   margin: 10px auto; | |||
|  | 
 | |||
|  | } | |||
|  | 
 | |||
|  | .sanniu { | |||
|  |   width: 105px; | |||
|  |   height: 35px; | |||
|  |   background: #0174F6; | |||
|  |   border-radius: 50px; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: center; | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #FFFFFF; | |||
|  |   line-height: 15px; | |||
|  |   margin: 0 auto; | |||
|  | } | |||
|  | 
 | |||
|  | .annniu { | |||
|  |   width: 90%; | |||
|  |   height: 45px; | |||
|  |   background: linear-gradient(180deg, #3F61C0 0%, #0174F6 100%); | |||
|  |   border-radius: 50px; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: center; | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #FFFFFF; | |||
|  |   line-height: 15px; | |||
|  |   margin: 15px auto; | |||
|  | } | |||
|  | 
 | |||
|  | .banniu { | |||
|  |   width: 20%; | |||
|  |   height: 30px; | |||
|  |   background: linear-gradient(180deg, #3F61C0 0%, #0174F6 100%); | |||
|  |   border-radius: 50px; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: center; | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #FFFFFF; | |||
|  | } | |||
|  | 
 | |||
|  | .box { | |||
|  | 
 | |||
|  | } | |||
|  | 
 | |||
|  | .box-dis { | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 15px; | |||
|  |   // border-bottom: 1px solid #EEEEEE;
 | |||
|  |   display: flex; | |||
|  | } | |||
|  | 
 | |||
|  | .shop-img { | |||
|  |   width: 80px; | |||
|  |   height: 80px; | |||
|  |   border-radius: 8px; | |||
|  |   overflow: hidden; | |||
|  |   margin-right: 10px; | |||
|  | } | |||
|  | 
 | |||
|  | .dis-hui { | |||
|  |   width: 100%; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #999999; | |||
|  |   margin-bottom: 5px; | |||
|  | } | |||
|  | 
 | |||
|  | .h-title { | |||
|  |   font-size: 16px; | |||
|  |   font-weight: bold; | |||
|  |   color: #333333; | |||
|  |   margin-bottom: 5px; | |||
|  | } | |||
|  | 
 | |||
|  | .box-top { | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 15px; | |||
|  |   border-bottom: 1px solid #EEEEEE; | |||
|  |   width: 100%; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: space-around; | |||
|  | } | |||
|  | 
 | |||
|  | .t-input { | |||
|  |   width: 90%; | |||
|  |   margin: 20px auto; | |||
|  |   border: 1px solid #0174F6; | |||
|  |   border-radius: 6px; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 2px 5px; | |||
|  | 
 | |||
|  | } | |||
|  | 
 | |||
|  | .on-input { | |||
|  |   width: 100%; | |||
|  |   display: flex; | |||
|  |   justify-content: space-between; | |||
|  |   align-items: center; | |||
|  |   margin: 15px auto; | |||
|  | } | |||
|  | 
 | |||
|  | .bottom-input { | |||
|  |   border-top: 1px solid #F4F4F4; | |||
|  |   box-sizing: border-box; | |||
|  |   padding-top: 20px; | |||
|  |   display: flex; | |||
|  |   justify-content: space-between; | |||
|  |   width: 100%; | |||
|  | } | |||
|  | 
 | |||
|  | .o-left { | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #666666; | |||
|  | } | |||
|  | 
 | |||
|  | .o-right { | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #333333; | |||
|  | } | |||
|  | 
 | |||
|  | .o-zui { | |||
|  |   font-size: 20px; | |||
|  |   font-weight: 500; | |||
|  |   color: #333333; | |||
|  | } | |||
|  | 
 | |||
|  | .popup-box { | |||
|  |   overflow: hidden; | |||
|  |   border-radius: 8px; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 15px; | |||
|  |   width: 100%; | |||
|  |   background-color: white; | |||
|  | } | |||
|  | 
 | |||
|  | .sousuo { | |||
|  |   width: 95%; | |||
|  |   margin: 0 auto; | |||
|  |   margin-left: 0px; | |||
|  |   height: 30px; | |||
|  |   background: #F0F0F0; | |||
|  |   border-radius: 50px; | |||
|  |   color: #999999; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 0 10px; | |||
|  |   display: flex; | |||
|  |   align-items: center; | |||
|  |   justify-content: space-between; | |||
|  | 
 | |||
|  |   input { | |||
|  |     width: 80%; | |||
|  |   } | |||
|  | } | |||
|  | 
 | |||
|  | .list-box { | |||
|  |   width: 100%; | |||
|  |   height: 300px; | |||
|  |   overflow: hidden; | |||
|  |   box-sizing: border-box; | |||
|  | 
 | |||
|  | } | |||
|  | 
 | |||
|  | .list_scroll { | |||
|  |   height: 100%; // 需设置高度
 | |||
|  |   display: flex; | |||
|  |   flex-direction: column; | |||
|  | 
 | |||
|  | } | |||
|  | 
 | |||
|  | .list-qiu { | |||
|  |   width: 95%; | |||
|  |   border-bottom: 1px solid #EEEEEE; | |||
|  |   box-sizing: border-box; | |||
|  |   padding: 10px 5px; | |||
|  |   display: flex; | |||
|  |   justify-content: space-between; | |||
|  |   align-items: center; | |||
|  | } | |||
|  | 
 | |||
|  | .tel { | |||
|  |   margin-left: 5px; | |||
|  |   font-size: 15px; | |||
|  |   font-weight: 400; | |||
|  |   color: #666666; | |||
|  | } | |||
|  | </style> |