From 750f856006af98dffb7918ab80fdc689781ea017 Mon Sep 17 00:00:00 2001
From: whycq <913841844@qq.com>
Date: 星期三, 17 一月 2024 16:20:32 +0800
Subject: [PATCH] #

---
 pages/basics/pakin.vue |  224 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 164 insertions(+), 60 deletions(-)

diff --git a/pages/basics/pakin.vue b/pages/basics/pakin.vue
index 093b904..7516a21 100644
--- a/pages/basics/pakin.vue
+++ b/pages/basics/pakin.vue
@@ -32,13 +32,25 @@
 					</view>
 				</view>
 			</view>
-			
+			<view class="square-1">
+				<view class="square-title">
+					<view class="title-sign"><view class="sign"></view></view>
+					<view class="title-text"><text>鏄惁鍖呰</text></view>
+					<radio-group @change="isFrozen">
+						<label>
+							<radio :checked="ck1" style="margin-left: 100rpx;"/><text>鏄�</text>
+						</label>
+						<label>
+							<radio :checked="ck2" style="margin-left: 50rpx;"/><text>鍚�</text>
+						</label>
+					</radio-group>
+				</view>
+			</view>
 			
 			<view class="square-1">
 				<view class="square-title">
 					<view class="title-sign"><view class="sign"></view></view>
 					<view class="title-text"><text>鍟嗗搧鍒楄〃</text></view>
-					<!-- <label v-show="matList.length != 0" style="float: right;margin-right: 20px;margin-top: 13px;"><uni-icons type="trash" size="25" color="#a5a5a5" @click="remove()"></uni-icons></label> -->
 				</view>
 			</view>
 			
@@ -49,14 +61,13 @@
 			<checkbox-group @change="checkbox">
 				<view v-for="(item,index) in matList" :key="index" class="data-list bg-false" :class="'bg-'+item.checked" >
 					<view class="data-list-left">
-						<!-- <view>
-							<checkbox :value="item.id+''" :checked="item.checked" style="display: block;" />
-						</view> -->
 						<view class="matnr"><text style="width: 400rpx;">缂栫爜锛歿{item.matnr}}</text></view>
 						<view><text style="width: 400rpx;">鍝佸悕锛歿{item.maktx}}</text></view>
+						<view><text style="width: 400rpx;">瑙勬牸锛歿{item.specs}}</text></view>
 						<view><text style="width: 400rpx;">鎵瑰彿锛歿{item.batch}}</text></view>
 						<view>
-							<text style="width: 400rpx;">鏁伴噺锛歿{item.anfme}}</text>
+							<text style="width: 400rpx;">澶囨敞锛歿{item.memo}}</text>
+							<text style="width: 400rpx;margin-left: 100rpx">鏁伴噺锛歿{item.anfme}}</text>
 						</view>
 					</view>
 					<view class="data-list-right">
@@ -70,12 +81,6 @@
 		
 		<!-- 搴曢儴鎸夐挳 -->
 		<view class="footer flex justify-around">
-			<!-- <label class="label-btn" style="width: 170rpx;">
-				<checkbox :checked="check" @click="allChecked()">{{checkText}}</checkbox>
-			</label>
-			<label class="label-btn" style="width: 100rpx;">
-				<text  @click="reChecked()">鍙嶉��</text>
-			</label> -->
 			
 			<label class="label-btn" style="width: 150rpx;">
 				<button class="cu-btn" @click="resst()">閲嶇疆</button>
@@ -84,21 +89,26 @@
 				<button class="cu-btn bg-blue " @click="comb()">缁勬墭</button>
 			</label>
 		</view>
-		
 		<!-- 寮圭獥 -->
 		<!-- 淇敼鏁伴噺 -->
-		<uni-popup ref="revise" background-color="#fff" @change="change">
-			<view class="revise-box">
+		<uni-popup ref="revise" >
+			<view class="revise-box ">
 				<view class="revise-box-top">
 					<view class="color-block-blue"></view>
-					<text class="title">缁勬墭鏁伴噺</text>
+					<text class="title">淇敼</text>
 				</view>
-				<view class="text-box">
-					<text>鍙粍鏁伴噺锛歿{enableQty}}</text>
+				<view class="" style="position: relative;left: 50px;margin-bottom: 20px;">
+					<text style="display: inline-block;float: left;width: 50px;">鎵瑰彿锛�</text>
+					<input type="text" style="width: 100px;border-bottom: 1px solid #9e9e9e;" v-model="batch">
+				</view>
+				<view class="" style="position: relative;left: 50px;margin-bottom: 20px;">
+					<text style="display: inline-block;float: left;width: 50px;">澶囨敞锛�</text>
+					<input type="text" style="width: 100px;border-bottom: 1px solid #9e9e9e;" v-model="memo">
 				</view>
 				<view class="changeBox">
 					<view class="num-box">
-						<uni-number-box v-model="count" :min="minCount" :max="maxCount" color="#747474"  @change="changeValue"/>
+						<text style="display: inline-block;float: left;width: 50px;">鏁伴噺锛�</text>
+						<uni-number-box :value="count" :max="9999999" color="#747474"  @change="changeValue"/>
 					</view> 
 				</view>
 				<view class="revise-box-buttom">
@@ -113,6 +123,7 @@
 
 <script>
 	import permision from "@/common/permission.js"
+	import loginVue from "../login/login.vue";
 	export default {
 		data() {
 			return {
@@ -134,6 +145,11 @@
 				check:false,
 				checkText:'鍏ㄩ��',
 				checkedData:[],
+				batch:'',
+				memo: '',
+				ck1: true,
+				ck2: false,
+				frozen: 1,
 			}
 		},
 		onShow() {
@@ -152,25 +168,35 @@
 			this.getUrl()
 		},
 		methods: {
+			// 鍖呰
+			isFrozen() {
+				var temp = this.ck1
+				this.ck1 = this.ck2
+				this.ck2 = temp
+				this.frozen = this.ck1
+				if (this.frozen == true) {
+					this.frozen = 1
+				} else {
+					this.frozen = 0
+				}
+				console.log(this.frozen);
+			},
 			// 鑾峰彇url
 			getUrl() {
 				this.commonUrl = this.baseHttp + this.baseIP + ':' +this.basePORT + "/" +this.baseUrl
 			},
 			// barcode input 浜嬩欢
 			barcodeInput() {
-				console.log(1)
 				// 涓嶈缃畾鏃跺櫒 浼氬嚭鐜版壂鍏ョ殑瀛楃涓蹭笉鍏�
 				setTimeout(()=>{
 					var len = this.barcode.length
 					if (len != 8) {
-						uni.showToast({title: '鎵樼洏鐮佹湁璇閲嶈瘯', icon: "none", position: 'top'});
+						uni.showToast({title: '鎵樼洏鐮�'+this.barcode+'鏈夎璇烽噸璇�', icon: "none", position: 'top'});
 						this.barcodeFocuss()
 						return;
 					}
-					if (len == 8) {
-						this.focuss()
-					}
-				},100)
+					this.focuss()
+				},200)
 			},
 			// 鎵樼洏鐮佹湁璇噸缃�
 			barcodeFocuss() {
@@ -195,6 +221,7 @@
 			resst() {
 				this.matList = []
 				this.barcode = ''
+				this.matnr = ''
 				this.barcodeFocuss()
 				uni.vibrateShort();
 			},
@@ -214,14 +241,9 @@
 					this.focus = true;
 				});
 			},
-			remove() {
-				// this.matList.splice(index,1)
-				for (var i = 0; i < this.matList.length; i++) {
-					if (this.matList[i].checked == true) {
-						this.matList.splice(i,1)
-					}
-				}
-				this.checkList();
+			// 鍒楄〃鍒犻櫎鎸夐挳
+			remove(item,index) {
+				this.matList.splice(index,1)
 				uni.vibrateShort();
 			},
 			comb() {
@@ -234,6 +256,15 @@
 				if (that.matList.length === 0) {
 					uni.showToast({title: '璇锋坊鍔犲晢鍝佸垪琛�', icon: "none", position: 'top'});
 					return;
+				}
+				for (var i = 0; i < that.matList.length; i++) {
+					if (that.matList[i].anfme == 0 || that.matList[i].anfme == '') {
+						uni.showToast({title: that.matList[i].matnr + '缁勬墭鏁伴噺涓嶈兘涓�0', icon: "none", position: 'top'});
+						return;
+					}
+				}
+				for (var j = 0; j < that.matList.length; j++) {
+					that.matList[j].beBatch = that.frozen
 				}
 				uni.showLoading();
 				uni.request({
@@ -250,6 +281,9 @@
 						uni.hideLoading();
 						var res = result.data
 						if (res.code === 200) {
+							const innerAudioContext = uni.createInnerAudioContext();
+							innerAudioContext.src = '/static/music/pakinOk.mp3';
+							innerAudioContext.play()
 							that.resst();
 							uni.showToast({
 								title: res.msg,
@@ -283,14 +317,32 @@
 					},
 					success: function(res) {
 					    // 閫氳繃eventChannel鍚戣鎵撳紑椤甸潰浼犻�佹暟鎹�   鍚戝彟澶栦竴涓〉闈紶閫掑�肩殑
-					    res.eventChannel.emit('acceptDataFromOpenerPage', {commonUrl:that.commonUrl })
+					    res.eventChannel.emit('commonUrl', {commonUrl:that.commonUrl })
 					},
 					
 				});
 				that.matnr = ''
 			},
 			findMat() {
-				let that = this
+				let that = this 
+				let len = that.matnr.length 
+				let bat = ''
+				let re = /\s+/g
+				that.matnr = that.matnr.replace(/\s+/g,'')
+				if (len == 26 || len == 25 || len == 27 || len == 28) {
+					bat = that.matnr.substring(18,22)
+					that.matnr = that.matnr.substring(3,17)
+				}
+				for (var i = 0; i < that.matList.length; i++) {
+					if (that.matnr == that.matList[i].matnr) {
+						uni.showToast({title: that.matnr + "褰撳墠鐗╂枡鎻愬彇锛岃鍕块噸澶嶆壂鎻�!", icon: "none",position: 'top'})
+						setTimeout(()=>{
+							that.matnr = '';
+							that.focus = true;
+						}, 100);
+						return;
+					}
+				}
 				uni.request({
 				    url: that.commonUrl + '/mat/auth',
 				    data: {
@@ -305,12 +357,14 @@
 						if (res.code === 200 && res.data) {
 							that.matData = res.data
 							that.matnr = ''
+							that.matData['batch'] = bat
 							uni.navigateTo({
 								url: "matQuery",
 								events: {
 								    // 涓烘寚瀹氫簨浠舵坊鍔犱竴涓洃鍚櫒锛岃幏鍙栬鎵撳紑椤甸潰浼犻�佸埌褰撳墠椤甸潰鐨勬暟鎹�
 								    matList: function(data) {
-										that.matList.push(data.data)
+										that.checkMat(data.data)
+										// that.matList.push(data.data)
 									},
 								},
 								success: function(res) {
@@ -318,15 +372,50 @@
 									res.eventChannel.emit('matData', { data: that.matData })
 								},
 							});
+						} else if (res.code == 403) {
+							uni.showToast({title: res.msg, icon: "none", position: 'top'})
+							setTimeout(() => {
+								uni.reLaunch({
+									url: '../login/login'
+								});
+							}, 1000);
+						} else {
+							// setTimeout(()=>{
+							// 	that.matnr = '';
+							// 	that.focus = true;
+							// }, 100);
+							// uni.showToast({title: res.msg, icon: "none",position: 'top'})
 						}
 						
 					}
 				});
-				
 			},
 		
+			// 娣诲姞鍟嗗搧
+			addMat(mat) {
+				this.matList.unshift(mat)
+			},
+			checkMat(mat) {
+				var len = this.matList.length
+				var add = true
+				var date = new Date()
+				var today = date.getFullYear() + '/' + (date.getMonth()+1) + '/' + date.getDate()
+				for (var i = 0; i < len; i++) {
+					if (mat.matnr == this.matList[i].matnr) {
+						uni.showToast({title: mat.matnr + "褰撳墠鐗╂枡鎻愬彇锛岃鍕块噸澶嶆壂鎻�!", icon: "none",position: 'top'})
+						// this.matList[i].anfme += mat.anfme 
+						this.$forceUpdate() // 寮哄埗鍒锋柊
+						add = false
+					}
+				}
+				if (add) {
+					if(mat.batch === '' || mat.batch === null) {
+						// mat.batch = today
+					}
+					this.matList.unshift(mat)
+				}
+			},
 			change(e) {
-				console.log('褰撳墠妯″紡锛�' + e.type + ',鐘舵�侊細' + e.show);
 			},
 			toggle(type) {
 				this.type = type
@@ -355,13 +444,10 @@
 				uni.vibrateShort();
 			},
 			revise(item,index) {
-				var maxCount = this.matList[index].maxCount
-				if (maxCount == undefined ) {
-					this.matList[index]["maxCount"] = item.enableQty
-				} 
-				this.enableQty = item.enableQty
-				this.count = this.minCount
-				this.maxCount = item.maxCount
+				this.count = this.matList[index].anfme
+				this.batch = this.matList[index].batch
+				this.memo = this.matList[index].memo
+				this.cstmr = this.matList[index].cstmr
 				this.rowNum = index
 				this.eject()
 			},
@@ -370,12 +456,16 @@
 				// open 鏂规硶浼犲叆鍙傛暟 绛夊悓鍦� uni-popup 缁勪欢涓婄粦瀹� type灞炴��
 				this.$refs.revise.open(type)
 			},
-			changeValue() {
-				
+			changeValue(value) {
+				this.count = value
 			},
 			confirm() {
 				this.matList[this.rowNum].anfme = this.count
+				this.matList[this.rowNum].batch = this.batch
+				this.matList[this.rowNum].memo = this.memo
+				this.matList[this.rowNum].cstmr = this.cstmr
 				this.$refs.revise.close()
+				this.$forceUpdate() // 寮哄埗鍒锋柊
 			},
 			// 鍒楄〃鍙嶉��
 			reChecked() { 
@@ -420,14 +510,6 @@
 				}
 				uni.vibrateShort();
 			},
-			// 妫�楠屽垪琛ㄩ暱搴� 绛変簬0 鏄剧ず鍏ㄩ��  
-			checkList() {
-				if (this.matList.length == 0) {
-					this.check = false
-					this.checkText = "鍏ㄩ��"
-					return;
-				}
-			}
 		}
 	}
 </script>
@@ -435,7 +517,29 @@
 <style>
 	/* @import "../../colorui/main.css";
 	@import "../../colorui/icon.css"; */
-	
+	.revise-box {
+		position: relative;
+		width: 500rpx;
+		height: 500rpx;
+		border-radius: 25px;
+		background-color: #fff;
+		border-radius: 20rpx;
+	}
+	.revise-box-top {
+		width: 400rpx;
+		height: 120rpx;
+		border-radius: 25px;
+	}
+	.changeBox {
+		width: 400rpx;
+		height: 100rpx;
+	}
+	.num-box {
+		margin-left: 100rpx;
+	}
+	.revise-box-buttom{
+		margin-left: 190rpx;
+	}
 	.pak-seach-box {
 		background-color: #FFFFFF;
 		margin: 15rpx 15rpx 0rpx 15rpx;
@@ -532,7 +636,7 @@
 	}
 	.data-list {
 		border-bottom: 1px solid #d8d8d8;
-		height: 180rpx;
+		height: 220rpx;
 		margin: 15rpx;
 		border-radius: 20rpx;
 	}
@@ -540,7 +644,7 @@
 		margin-top: 20rpx;
 	}
 	.data-list:last-child {
-		margin-bottom: 120rpx;
+		margin-bottom: 180rpx;
 	}
 	/* .data-list-left {
 		display: inline-block;
@@ -563,8 +667,8 @@
 	.data-list-right {
 		display: inline-block;
 		float: right;
-		height: 180rpx;
-		line-height: 180rpx;
+		height: 220rpx;
+		line-height: 220rpx;
 	}
 	/* display: inline-block;
 	float: right;

--
Gitblit v1.9.1