From 8d61dc60466e243414d2a05106bf8cf173fb47f0 Mon Sep 17 00:00:00 2001
From: yangan <yangan0921@163.com>
Date: 星期六, 31 八月 2024 13:48:55 +0800
Subject: [PATCH] feat:PVC增加分配数

---
 pages/loadUnload-page/selectTarget/selectTarget.vue |  240 +++++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 156 insertions(+), 84 deletions(-)

diff --git a/pages/loadUnload-page/selectTarget/selectTarget.vue b/pages/loadUnload-page/selectTarget/selectTarget.vue
index b43f71e..7812ede 100644
--- a/pages/loadUnload-page/selectTarget/selectTarget.vue
+++ b/pages/loadUnload-page/selectTarget/selectTarget.vue
@@ -2,7 +2,7 @@
 	<view class="main">
 		<!-- 褰撳墠閫夋嫨浠撳簱 -->
 		<view class="top-tag">
-			<text>鐐瑰嚮鍒囨崲/閫夋嫨浠撳簱</text>
+			<text style="margin-right:20rpx">鐐瑰嚮鍒囨崲/閫夋嫨浠撳簱</text>
 			<u-tag 
 			size='large'
 			icon='map'
@@ -11,6 +11,7 @@
 			></u-tag>
 		</view>
 		<!-- 鐐瑰嚮鏌ョ湅鍘熺洂閽欓晛 -->
+		
 			<view class="self-deliver">
 					<view class="self-deliver_text">
 						鏌ョ湅鍘熺洂閽欓晛缁撴灉
@@ -22,6 +23,11 @@
 							@click="todoDetail"></u-button>
 					</view>
 				</view>
+				<view 
+				v-if="messageObj.carNo"
+			class="notice-bar"><u-notice-bar :text="messageText"
+			 :fontSize="30" :showIcon = 'true'
+			 ></u-notice-bar></view>
 		<!-- <u--form labelPosition="top"
 			labelWidth="20%"
 			:borderBottom="false"
@@ -48,7 +54,7 @@
 				text="鏌ョ湅璇ヤ粨搴撴敹鍙戝崟"
 				@click.stop="formHandle"></u-button>
 		</view> -->
-		<!-- 鐓ゅ満 -->
+		<!-- 鍦哄湴 -->
 		<view class='div-box'>
 				<u-empty mode="data"
 							icon="http://cdn.uviewui.com/uview/empty/data.png"
@@ -73,7 +79,11 @@
 									<view class="third-line_text">瀹㈡埛鍚嶇О:</view>
 									<view>{{ item.customerName }}</view>
 								</view>
-								<view class="third-line"  v-if="item.productName === 'EDC'">
+									<view class="third-line" v-if="/鑱氭隘涔欑儻鏍戣剛/.test(item.productName)">
+									<view class="third-line_text">鍖呰绫诲瀷:</view>
+									<view>{{ proType[item.packingType] }}</view>
+								</view>
+								<view class="third-line"  v-if="item.productName === '浜屾隘涔欑兎(EDC)'">
 									<view class="third-line_text">璐ㄦ鐘舵��:</view>
 									<view> <u-tag :text="checkStatusList[item.checkStatus]" plain > </u-tag></view>
 								</view>
@@ -81,7 +91,7 @@
 							<view class="fourth">
 								<view class="fourth-icon">
 									<view
-										style="width: 24rpx;height: 24rpx;line-height: 24rpx;background: url('https://mx.jzeg.cn:9096/appimg/image/banner/clock.png') no-repeat;background-size: cover">
+										style="width: 24rpx;height: 24rpx;line-height: 24rpx;background: url('https://wrzs.czjlchem.com:9090/appimg/image/banner/clock.png') no-repeat;background-size: cover">
 									</view>
 								</view>
 								<view class="senddate">{{ item.sendDate }}</view>
@@ -89,7 +99,7 @@
 							<view class="fourth">
 								<view class="fourth-icon">
 									<view
-										style="width: 26rpx;height: 26rpx;line-height: 26rpx;background: url('https://mx.jzeg.cn:9096/appimg/image/banner/carnNUm.png') no-repeat;background-size: cover;">
+										style="width: 26rpx;height: 26rpx;line-height: 26rpx;background: url('https://wrzs.czjlchem.com:9090/appimg/image/banner/carnNUm.png') no-repeat;background-size: cover;">
 									</view>
 								</view>
 								<view class="senddate">{{ item.orderCode }}</view>
@@ -98,14 +108,14 @@
 			<uni-table border stripe 
 			emptyText="鏆傛棤鏇村鏁版嵁">
 					<uni-tr>
-						<uni-th width='140'
+						<uni-th width='120'
 						align="center">鎿嶄綔</uni-th>
 					    <uni-th align="center" width='120'>浜у搧</uni-th>
-						<uni-th align="center">浠撳簱</uni-th>
-						<uni-th align="center">鐨噸</uni-th>
-						<uni-th align="center">姣涢噸</uni-th>
-						<uni-th align="center">鍑�閲�</uni-th>
-						<uni-th align="center">鏁伴噺</uni-th>
+						<uni-th align="center" width='200'>浠撳簱</uni-th>
+						<uni-th align="center" width='100'>鐨噸</uni-th>
+						<uni-th align="center" width='100'>姣涢噸</uni-th>
+						<uni-th align="center" width='100'>鍑�閲�</uni-th>
+						<uni-th align="center" width='100'>鏁伴噺</uni-th>
 					    <!-- <uni-th align="center">浠撳簱</uni-th> -->
 						<!-- <uni-th align="center">鐘舵��</uni-th> -->
 						
@@ -115,21 +125,21 @@
 					<view class="btnBox"> 
 						<!--   -->
 						<u-button   text='鏌ョ湅'  @click="viewDetail(subItem)"></u-button>
-						<u-button type='primary' text='纭瑁呭嵏'  v-if="subItem.flag && isBtnShow(subItem)" @click="enterOk(item,subItem)"></u-button>
+						<u-button type='primary' text='纭瑁呭嵏'  v-if="subItem.flag && isBtnShow(item)" @click="enterOk(item,subItem)"></u-button>
 						</view></uni-td>
 						<uni-td align="center">
 							<view>{{ subItem.productName }}</view></uni-td>
 					<uni-td>
-						<view class="name">{{ subItem.bunkerName }}</view>
+						<view>{{ subItem.bunkerName }}</view>
 					</uni-td>
 					<uni-td>
-						<view class="name">{{ subItem.skin }}</view>
+						<view class="name" v-if="subItem.skin">{{ Number(subItem.skin).toFixed(2) || ''  }}</view>
 					</uni-td>
 					<uni-td>
-						<view class="name">{{ subItem.hair }}</view>
+						<view class="name" v-if="subItem.hair"> {{  Number(subItem.hair).toFixed(2) || ''  }}</view>
 					</uni-td>
 						<uni-td>
-						<view class="name">{{ subItem.clean }}</view>
+						<view class="name" v-if="(subItem.clean || (subItem.clean && subItem.clean === 0))">{{ Number(subItem.clean).toFixed(2) || ''}}</view>
 					</uni-td>
 					<uni-td>
 						<view class="name">{{ subItem.productQuantity }}</view>
@@ -162,21 +172,21 @@
 				:showCancelButton="true">
 				<view class="slot-content">
 					鏄惁纭瑁呭嵏锛�
-					<view v-if="isNumOk || isClean">
+					<view v-if="isNumOk || isClean||isFlagNum">
 						<text>浜у搧鍚嶇О锛歿{activeObj.productName}}</text>
 						<view class="queren">
 							<text>璇疯緭鍏�</text>锛�
 							  <u--input
 							     type='digit'
 							     border="bottom"
-								:placeholder="isNumOk ?  '鏁伴噺' :'鎶樺惃'"
+								:placeholder="/鑱氭隘涔欑儻鏍戣剛/.test(activeObj.productName) ? '瀹為檯鍚ㄦ暟' :  isNumOk ?  '鏁伴噺' :'鎶樺惃'"
 								v-model="checkNum"
 							>
 							</u--input>
 							<text> {{isNumOk ? '浠�' : '鍚�' }}</text>
 							</view>
-							<!-- pvc 骞朵笖鏄ぇ鍖� -->
-							<view class="pvcBig" v-if="activeObj.productName === 'PVC' && activeObj.packingType === 5">
+							<!-- 鑱氭隘涔欑儻鏍戣剛 骞朵笖鏄ぇ鍖� -->
+							<view class="pvcBig" v-if="activeObj.productName === '鑱氭隘涔欑儻鏍戣剛' && activeObj.packingType === 5">
 								
 							</view>
 							<view v-if="isNumOk && activeObj.productQuantity">褰撳墠鏁伴噺锛歿{activeObj.productQuantity}}浠�</view>
@@ -212,7 +222,7 @@
 							</u-radio-group></view>
 				</view>
 			</u-modal>
-		<!-- 鐓や粨 -->
+		<!-- 浠撳簱 -->
 		<!-- <u-action-sheet :actions="secondClassActionsList"
 			:show="secondClassShow"
 			cancelText='鍙栨秷'
@@ -230,7 +240,7 @@
 </template>
 
 <script>
-	import { BaseUrl } from '@/api/publicInterface.js'
+	import { mapState, mapMutations, mapGetters } from 'vuex';
 	export default {
 		props: {
 			loadUnloadData: {
@@ -247,6 +257,8 @@
 					}else{
 						if(this.errorStatusList.includes(item.status)){
 							return false
+						}else if (item.productName ==='浜屾隘涔欑兎(EDC)' && item.checkStatus !== 7){
+							return false;
 						}else{
 							return true;
 						}
@@ -254,7 +266,16 @@
 					
 				}
 
-			}
+			},
+			messageText(){
+				if(this.messageObj.carNo){
+					return `鏃堕棿:${this.messageObj.now}锛�${this.messageObj.carNo}锛屼骇鍝�${this.messageObj.productNames}鍦�${this.messageObj.bunkerName}鍏ュ満浜嗭紝璇峰強鏃舵鏌ワ紒`
+				}else{
+					return '鏆傛棤娑堟伅'
+				}
+
+			},
+			  ...mapGetters(['websocketData'])
 		
 		},
 		watch: {
@@ -265,15 +286,42 @@
 				},
 				deep: true,
 				immediate: true
+			},
+			//鐩戝惉娑堟伅
+			'websocketData': {
+        handler(v) {
+          console.log(v, '鎺ュ彈鐨剋s鏁版嵁');
+          if(v) {
+            if (v.startsWith('kgTipHead')) {
+				console.log('vvvvv',v.slice(11))
+               let nowWeighObj = JSON.parse(v.slice(11));
+			   console.log(nowWeighObj,'nowWeight');
+			   this.messageObj = nowWeighObj;
+            //   this.messageList = JSON.parse(v.slice(5));
+            //   this.messageList = {
+            //     ...this.messageList,
+            //     title: this.messageList.title.slice(0, 8) + '...',
+            //     content: removeTags(this.messageList.content).trim().slice(0, 8) + '...'
+            //   }
+            //   this.messagePushShow = true;
+            } 
+          }
+        },
+        deep: true,
+        immediate: true
 			}
 		},
 		data() {
 			return {
+				proType:['鏁h','娑叉埃鐡惰','缃愯','PVC25','PVC80','PVC1150','PVc1200'],
 				dataForm: {
 					firstClass: "",
 					secondClass: "",
 					orderType: '',
-					bunkerId:""
+					bunkerIds:""
+				},
+				messageObj:{
+					carNo:'',
 				},
 				isEmptyCar:null, //鏄惁绌鸿溅鍑哄巶
 				checkStatusList:[
@@ -284,10 +332,11 @@
 				typeText:'', // 纭瑁呭嵏涓夌绫诲瀷
 				isNumOk:false, //璁′欢
 				isClean:false, // 鎶樺惃
-				// 鐓ゅ満鎿嶄綔鑿滃崟
+				isFlagNum:false,// PVCV
+				// 鍦哄湴鎿嶄綔鑿滃崟
 				firstClassActionsList: [],
 				firstClassShow: false,
-				// 鐓や粨鎿嶄綔鑿滃崟
+				// 浠撳簱鎿嶄綔鑿滃崟
 				secondClassActionsList: [],
 				secondClassShow: false,
 				coalList: [],
@@ -322,7 +371,7 @@
 			viewDetail(item){
 				//鏌ョ湅鏀跺彂鍗曡鎯�
 				uni.navigateTo({
-					url: `/pages/loadUnload-page/loadUnlaodPageDetail/detail?id=${item.id}&checkId=${item.checkId}`
+					url: `/subPages/loadUnlaodPageDetail/detail?id=${item.id}&checkId=${item.checkId}`
 				});
 			
 			},
@@ -333,7 +382,7 @@
 				})
 			},
 		
-			// 鑾峰彇鐓ゅ満
+			// 鑾峰彇鍦哄湴
 			getDeptIdFiled() {
 				uni.showLoading({
 					title: "鍔犺浇涓�"
@@ -342,10 +391,18 @@
 					uni.hideLoading()
 					if (res.code === 0) {
 						this.firstClassActionsList = res.data;
+						this.firstClassActionsList.unshift({name:'鍏ㄩ儴',id:res.data.map(item=>item.id).join(',')})
 						if(res.data.length){
-							this.dataForm.bunkerId = res.data[0].id;
-								uni.setStorageSync('bunkerId',res.data[0].id)
-							this.dataForm.firstClass = res.data[0].name;
+							if(!uni.getStorageSync('bunkerIds')){
+								this.dataForm.firstClass = '鍏ㄩ儴'
+								this.dataForm.bunkerIds = res.data.map(item=>item.id).join(',')
+							    uni.setStorageSync('bunkerIds',res.data.map(item=>item.id).join(','))
+							}else{
+								this.dataForm.bunkerIds = uni.getStorageSync('bunkerIds');
+								uni.setStorageSync('bunkerIds',this.dataForm.bunkerIds)
+							}
+						
+						
 							this.getDetailData();
 					
 						}
@@ -353,7 +410,7 @@
 						this.$u.toast('鍔犺浇澶辫触')
 					}
 				}).then(() => {
-					this.getUserInfo()
+				
 				})
 			},
 			firstClassSelect() {
@@ -366,7 +423,7 @@
 				     uni.showLoading({
                     title:'鍔犺浇涓�'
                 })
-					this.$reqGet('getTaskCoalListByBunkerId', { bunkerId:this.dataForm.bunkerId }).then(res => {
+					this.$reqGet('getTaskCoalListByBunkerId', { bunkerIds:this.dataForm.bunkerIds }).then(res => {
 					uni.hideLoading();
 					if (res.code === 0) {
 						this.detailData = res.data.map(item=>{
@@ -389,77 +446,80 @@
 			},
 			firstClassSelectClick(val) {
 				this.dataForm.firstClass = val.name;
-				this.dataForm.bunkerId= val.id;
-				uni.setStorageSync('bunkerId', val.id);
+				this.dataForm.bunkerIds= val.id;
+				uni.removeStorageSync('bunkerIds')
+				uni.setStorageSync('bunkerIds', val.id);
 				this.getDetailData();
 				this.filedId = val.id
 			},
-			formHandle() {
-				if (!this.dataForm.firstClass) return this.$u.toast('璇烽�夋嫨鐓ゅ満鎴栬�呯叅浠�');
-				this.$nextTick(()=>{
- 					uni.navigateTo({
-						url: `/pages/loadUnload-page/loadUnload-detail/loadUnload-detail?bunkerId=${this.dataForm.bunkerId}`
-					})
-				})
+			// formHandle() {
+			// 	if (!this.dataForm.firstClass) return this.$u.toast('璇烽�夋嫨鍦哄湴鎴栬�呬粨搴�');
+			// 	this.$nextTick(()=>{
+ 			// 		uni.navigateTo({
+			// 			url: `/pages/loadUnload-page/loadUnload-detail/loadUnload-detail?bunkerId=${this.dataForm.bunkerId}`
+			// 		})
+			// 	})
 			   
-			},
+			// },
 			change(){
 
 			},
 			close(){
 
 			},
-
-					
-
-			
 			open(){},
 			enterOk(parintItem,item){
 				console.log(parintItem,'priintItem')
-				uni.request({
-					url: `${BaseUrl}/admin/dict/type/tray_weight`,
-					method: 'GET',
-					header: {
-					Authorization: 'Bearer' + ' ' + uni.getStorageSync('token'),
-					clientToc: 'Y',
-					'CLIENT_TOC': 'Y',
-				},
-					success: (res) => {
-						this.pvcWeight = res.data.data.find(item=>item.label === '5') ? Number(res.data.data.find(item=>item.label == '5').value) : '';
+				// uni.request({
+				// 	url: `${BaseUrl}/admin/dict/type/tray_weight`,
+				// 	method: 'GET',
+				// 	header: {
+				// 	Authorization: 'Bearer' + ' ' + uni.getStorageSync('token'),
+				// 	clientToc: 'Y',
+				// 	'CLIENT_TOC': 'Y',
+				// },
+				// 	success: (res) => {
+				// 		this.pvcWeight = res.data.data.find(item=>item.label === '5') ? Number(res.data.data.find(item=>item.label == '5').value) : '';
 						
-					}
-				})
-			//  璁′欢锛�	0 pvc type 
+				// 	}
+				// })
+			//  璁′欢锛�	0 鑱氭隘涔欑儻鏍戣剛 type 
 			//  鎶樺惃: 
 				this.activeObj = item;
 				if( (parintItem.orderType === '澶栬喘' ||parintItem.orderType === '澶栬喘閫�' ) && item.isWeight === 0){
 					this.isNumOk = true;
 					this.isClean = false;
+					this.isFlagNum = false;
 					//鍥炴樉璁℃暟閲�
 				    this.checkNum  = item.productQuantity ? item.productQuantity : '';
 				}else if( parintItem.orderType ==='澶栬喘' &&  item.isWeight === 1){
 					this.isClean = true;
 					this.isNumOk = false;
+				     this.isFlagNum = false;
 				}else{
 					this.isNumOk = false;
 					this.isClean = false;
+				     this.isFlagNum = false;
 				}
-				//pvc
-				 if(parintItem.orderType ==='澶栭攢' && item.productName ==='PVC' && (item.packingType === 3 || item.packingType === 4)){
-					this.isNumOk = true;
+				//鑱氭隘涔欑儻鏍戣剛
+				 if(parintItem.orderType ==='澶栭攢' && (/鑱氭隘涔欑儻鏍戣剛/.test(item.productName) || item.productName === 'PVC')  && (item.packingType === 3 || item.packingType === 4)){
+					this.isNumOk = false;
 					this.isClean  = false;
+				   this.isFlagNum = true;;
 				}
 				//鐡惰娑叉隘鏉′欢
 				//EDC 璐ㄦ瀹屾垚鏂瑰彲纭
 				if(item.packingType === 1){ 
 					this.isNumOk = true;
 					this.isClean = false;
+					 this.isFlagNum = false;
 				}
 				//
 				//pvc澶у寘鑷姩璁$畻鎶樺惃
-				if(item.productName === 'PVC' && item.packingType === 5){
+				if((/鑱氭隘涔欑儻鏍戣剛/.test(item.productName) || item.productName === 'PVC')  && item.packingType === 5){
 					this.isNumOk = true;
 					this.isClean = false;
+					 this.isFlagNum = false;
 				}
 				if(parintItem.orderType === '澶栬喘'){
 					this.isEmptyCar = '1';
@@ -483,15 +543,14 @@
 				    uni.showLoading({
                     title:'鍔犺浇涓�'
                 });
-				if(this.activeObj.productName ==='EDC'){
-					if( this.activeObj.checkStatus !== 7){
-								this.$u.toast(`璇锋鏌ュ綋鍓岴DC璁㈠崟璐ㄦ鐘舵�佸悗鍦ㄧ‘璁よ鍗�!`);
-								return
-					}
+				console.log(this.activeObj,this.activeObj.productName ==='浜屾隘涔欑兎(EDC)' && this.activeObj.checkStatus !== 7,'12313')
+				if(this.activeObj.productName ==='浜屾隘涔欑兎(EDC)' && this.activeObj.checkStatus !== 7){
+					console.log('瑙﹀彂锛屸��13131')
+					this.enterZx = false;
+					this.$u.toast(`璇锋鏌ュ綋鍓嶄簩姘箼鐑�(EDC)DC璁㈠崟璐ㄦ鐘舵�佸悗鍦ㄧ‘璁よ鍗�!`);
 					
 				}else if( this.isEmptyCar === null){
 					this.$u.toast(`璇锋鏌�${this.isNumOk ? '璁′欢鏁伴噺' :'鎶樺惃'}锛屼互鍙婃槸鍚︾┖杞﹀嚭鍘傞」!`);
-					return
 				}else{
 					this.enterZx = false;
 					this.$reqPost('confirmLoadAndUnload',{ 
@@ -499,7 +558,9 @@
 					productQuantity:this.isNumOk ? this.checkNum : '',
 					discount:this.isClean ? this.checkNum : null,
 					isEmptyCar:this.isEmptyCar,
-					isPretendDischar:this.activeObj.isPretendDischar
+					isPretendDischar:this.activeObj.isPretendDischar,
+					realityMeasure:this.isFlagNum ? this.checkNum : null,
+					productId:this.isFlagNum ? this.activeObj.productId : null,
 				 },'json').then(res=>{
 					uni.hideLoading();
 					console.log(res,'rez')
@@ -534,7 +595,7 @@
 			todoDetail(){
 				console.log()
 				uni.navigateTo({
-						url: `/pages/loadUnload-page/checkTestDetails/index`
+						url: `/subPages/checkTestDetails/index`
 					})
 
 			}
@@ -548,18 +609,12 @@
 					uni.hideLoading()
 					if (res.code === 0) {
 						this.firstClassActionsList = res.data;
-						if(res.data.length === 1){
-							this.dataForm.bunkerId = res.data[0].id;
-							uni.setStorageSync('bunkerId', res.data[0].id)
-							this.dataForm.firstClass = res.data[0].name;
 					
-						}
 					} else {
 						this.$u.toast('鍔犺浇澶辫触')
 					}
 				}).then(() => {
 				
-					this.getUserInfo()
 				});
 			
 
@@ -577,16 +632,31 @@
   /deep/ .uni-table{
 	min-width: 0!important;
 	margin-left: 20rpx;
+	width: auto;
   }
 	
 }
+.notice-bar{
+		margin-left: vww(10);
+		margin-bottom: 20rpx;
+		margin-top: 20rpx;
+	
+			width: 98%;
+			.u-notice-bar{
+				border-radius: 20rpx;
+					margin-top: 20rpx;
+					height: 40rpx;
+			}
+}
 		// 鑷富閰嶉��
 			.self-deliver {
-			position: relative;
+				position: relative;
+				text-indent: 20rpx;
 				top: vww(10);
 				width: 95%;
 				height: vww(40);
-				margin: vww(8) 10rpx;
+				margin: vww(13) 10rpx;
+				margin-left: 20rpx;
 				padding: 0 vww(8);
 				background: #ffffff;
 				box-shadow: 0rpx 0rpx 14rpx 0rpx rgba(73, 120, 240, 0.14), 0rpx 7rpx 45rpx 0rpx rgba(73, 120, 240, 0.12);
@@ -599,6 +669,7 @@
 					height: 28px !important;
 					line-height: 40px;
 					padding: 0 12px;
+					text-indent: 0!important;
 					font-size: 28rpx;
 					font-weight: 300;
 					color: #ffffff;
@@ -662,14 +733,15 @@
 		position: relative;
 		top: vww(-160);
 		.top-tag{
-			    width: 33%;
+			    width: 60%;
+				margin-left: 55%;
 				height: 100rpx;
-				margin-left: 65%;
+				margin-left: 50%;
 				display: flex;
 				/* margin-top: 40rpx; */
 				color: #fff;
 				align-items: center;
-				justify-content: space-between;
+				
 					}
 
 					.div-box{
@@ -717,7 +789,7 @@
 					}
 				}
 				.history-information {
-			margin-bottom:50rpx;
+			margin-bottom:30rpx;
 			margin-top: 10rpx;
 			background: #ffffff;
 			border-radius: 20rpx;

--
Gitblit v1.9.1