From 79e5bb4cefc9b96f9556c65c3603cb941c14eca5 Mon Sep 17 00:00:00 2001
From: whycq <10027870+whycq@user.noreply.gitee.com>
Date: 星期四, 13 六月 2024 09:58:50 +0800
Subject: [PATCH] #

---
 pages/tzsk/pakin/locPick.vue |  324 ++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 301 insertions(+), 23 deletions(-)

diff --git a/pages/tzsk/pakin/locPick.vue b/pages/tzsk/pakin/locPick.vue
index f25296d..ca7a86f 100644
--- a/pages/tzsk/pakin/locPick.vue
+++ b/pages/tzsk/pakin/locPick.vue
@@ -1,12 +1,84 @@
 <template>
 	<view>
-		<view class="box" v-for="item in 10">
-			<view class="box-left">
-				<text class="text"> 搴撳尯 </text>
+		<view class="container" v-for="(item,i) in tree" :key="i">
+			<view :class="item.key">
+				<view class="title"  >
+					<view  style="width: 50%;">{{item.title}}</view>
+					<view @click="switchbtn(item)">
+						<uni-icons type="top" v-show="item.switch"></uni-icons>
+						<uni-icons type="bottom" v-show="!item.switch"></uni-icons>
+					</view>
+				</view>
+				<view class="name" v-show="item.key == 'user_id'" @click="back()">
+					<view>{{item.title}}</view>
+				</view>
+				<view class="sub1" v-for="sub in item.children" style="margin-left: 1em;" v-show="item.switch">
+					<view :class="sub.key" class="title sub-title"  >
+						<view  @click="chose(sub)">{{sub.title}}</view>
+						<view @click="switchbtn(sub)">
+							<uni-icons type="top" v-show="sub.switch"></uni-icons>
+							<uni-icons type="bottom" v-show="!sub.switch"></uni-icons>
+						</view>
+					</view>
+					
+					<view :class="sub.key" class="name" v-show="sub.key == 'user_id'"  @click="back()">
+						<view>{{sub.title}}</view>
+					</view>
+					
+					<view class="sub2" v-for="it in sub.children" style="margin-left: 1em;" v-show="sub.switch">
+						<!-- <view :class="it.key" class="title sub-title" >{{it.title}}</view> -->
+						<view :class="it.key" class="locarea name"  @click="chose(it)">
+							<view>{{it.title}}</view>
+						</view>
+					</view>
+				</view>
 			</view>
-			<view class="box-right">
-				<text class="text"> {{item}} </text>
+		</view>
+		
+		<view class="pick-list" v-show="pickData != ''">
+			<view class="list-item">
+				<text class="list-title">璁㈠崟鍙凤細</text><text class="val-text">{{pickData.docNum ? pickData.docNum : '--'}}</text>
 			</view>
+			<view class="list-item">
+				<text>搴撲綅鍙凤細</text><text>{{pickData.locNo}}</text>
+			</view>
+			<view class="list-item">
+				<text>鎵樼洏鐮侊細</text><text>{{pickData.zpallet ? pickData.zpallet : '--'}}</text>
+			</view>
+			<view class="list-item">
+				<text>鏂欑鐮侊細</text><text>{{pickData.containerCode ? pickData.containerCode : '--'}}</text>
+			</view>
+			<view class="list-item">
+				<text>閿�鍞鍙凤細</text><text>{{pickData.csocode ? pickData.csocode : '--'}}</text>
+			</view>
+			<view class="list-item">
+				<text>璁㈠崟琛屽彿锛�</text><text>{{pickData.isoseg ? pickData.isoseg : '--'}}</text>
+			</view>
+			<view class="list-item">
+				<text>鐗╂枡鍙凤細</text><text>{{pickData.matnr ? pickData.matnr : '--'}}</text>
+			</view>
+			<view class="list-item">
+				<text>鐗╂枡鍚嶇О锛�</text><text>{{pickData.maktx}}</text>
+			</view>
+			<view class="list-item">
+				<text>鐘舵�侊細</text><text>{{pickData.status$}}</text>
+			</view>
+			<view class="list-item">
+				<text>鏁伴噺锛�</text><text class="val-num">{{pickData.anfme}}</text>
+			</view>
+		</view>
+		
+		<view style="height: 100rpx;"></view>
+		
+		<view class="z-floor" v-show="pickData != ''">
+			<button size="mini" type="primary" @click="picked()">鎷h揣</button>
+		</view>
+		
+		<view>
+			<!-- 鎻愮ず淇℃伅寮圭獥 -->
+			<uni-popup ref="message" type="message">
+				<uni-popup-message :type="msgType1" :message="messageText" :duration="2000"></uni-popup-message>
+			</uni-popup>
 		</view>
 	</view>
 </template>
@@ -15,37 +87,243 @@
 	export default {
 		data() {
 			return {
-				
+				tree: [],
+				pickList: [],
+				pickData: '',
+				index: 1,
+				len: 5,
+				msgType1: 'success',
+				msgType: 'success',
+				messageText: '',
 			}
 		},
+		onShow() {
+			this.baseUrl = uni.getStorageSync('baseUrl');
+			this.token = uni.getStorageSync('token');
+			this.getNodeTree()
+		},
 		methods: {
+			getNodeTree() {
+				let _this = this
+				uni.request({
+					url: `${_this.baseUrl}/node/tree/auth`,
+					header: {'token': uni.getStorageSync('token')},
+					method: 'POST',
+					success(res) {
+						this.tree = []
+						res = res.data
+						// console.log(res.data[0].children);
+						if (res.data[0].children[0]) {
+							for (let k of res.data[0].children) {
+								// console.log(k);
+								if (k.children && k.children.length > 0) {
+									for (let i of k.children) {
+										i['switch'] = true
+										// console.log(i);
+									}
+								}
+								// console.log(k);
+								k['switch'] = true
+								_this.tree.push(k)
+							}
+							// console.log(_this.tree);
+						} else {
+							this.tree.push(res.data[0])
+						}
+					}
+				})
+			},
+			async getUserTree() {
+				let res = await user.getUserTree()
+				if (res.code === 200) {
+					this.tree = []
+					// console.log(res.data[0]);
+					if (res.data[0].children) {
+						for (let k of res.data[0].children) {
+							
+							if (k.children && k.children.length > 0) {
+								for (let i of k.children) {
+									i['switch'] = true
+									// console.log(i);
+								}
+							}
+							// console.log(k);
+							k['switch'] = true
+							this.tree.push(k)
+						}
+					} else {
+						this.tree.push(res.data[0])
+					}
+				} else if (res.code === 403) {
+					this.backLogin(res)
+				}
+				console.log(this.tree);
+			},
+			switchbtn(item) {
+				// console.log(item);
+				item.switch = item.switch ? false : true
+			},
+			open(e) {
+				// console.log('open', e)
+			},
+			close(e) {
+				// console.log('close', e)
+			},
+			change(e) {
+				// console.log('change', e)
+			},
+			backLogin(res) {
+				uni.showToast({title: res.msg, icon: "none", position: 'top'})
+				setTimeout(() => {
+					uni.reLaunch({
+						url: '../login/login'
+					});
+				}, 1000);
+			},
+			back() {
+				uni.$emit('isRefresh', 1)
+				uni.navigateBack({
+					
+				})
+			},
+			chose(data) {
+				let that = this 
+				uni.request({
+					url: `${that.baseUrl}/node/order/pakout`,
+					header: {'token': uni.getStorageSync('token')},
+					data: {locType: data.title},
+					success(res) {
+						// console.log(res);
+						res = res.data
+						if (res.code === 200 && res.data.length > 0) {
+							that.pickList = res.data
+							that.len = res.data.length
+							that.pickData = res.data[0]
+							that.index = 1
+						} else if (res.data.length == 0) {
+							that.getNodeTree()
+						}
+					}
+				})
+				this.tree = []
+			},
+			picked() {
+				let that = this
+				// console.log(that.len);
+				// console.log(that.index);
+				if (that.len < that.index) {
+					that.pickData = ''
+					that.index = 1
+					that.getNodeTree()
+					return
+				} else {
+					that.pickData.orderNo = that.pickData.docNum
+					uni.request({
+						url: `${that.baseUrl}/mobile/node/pakout`,
+						header: {'token': uni.getStorageSync('token')},
+						data: that.pickData,
+						method: 'POST'
+					}).then((res)=>{
+						res = res.data
+						// console.log(res);
+						if (res.code === 200) {
+							if (that.index == that.len) {
+								that.pickData = ''
+								that.index = 1
+								that.getNodeTree()
+							} else {
+								that.index++
+								that.pickData = that.pickList[that.index]
+							}
+							that.messageText = "鎷h揣鎴愬姛"
+							that.messageToggle('success')
+						}
+					})
+					
+				}
+			},
+			messageToggle(type) {
+				this.msgType1 = type
+				this.$refs.message.open()
+			},
 			
 		}
 	}
 </script>
 
 <style>
-	.box {
-		margin: 16rpx;
+	.container {
+		margin:  16rpx;
+		min-height: 35rpx;
+		background-color: #FFF;
+		padding: 16rpx;
+	}
+	.box1 {
+		background-color: aqua;
+	}
+	.title {
+		box-shadow: -3px 0px 0px #55aaff;
+		padding-left: 5px;
+		font-size: 15px;
+		font-weight: 700;
 		display: flex;
-		align-items: stretch;
-		
+		justify-content: space-between;
+		align-items: center;
 	}
-	.box-left {
-		height: 80rpx;
-		line-height: 80rpx;
-		background-color: #499bff;
-		background-color: #26edcf;
-		color: #F7F6F9;
+	.sub-title {
+		margin: 32rpx 0;
+		box-shadow: -3px 0px 0px #55aa7f;
 	}
-	.box-right {
-		flex: 1;
+	.name {
+		padding: 16rpx;
+		display: flex;
+		justify-content: space-between;
+		align-items: center;
+	}
+	.locarea:active {
+		background-color: #55aa7f;
+	}
+	.pick-list {
+		margin: 8px;
+		background-color: #FFF;
+		min-height: 70rpx;
+		border-radius: 20rpx;
+	}
+	.list-item  {
+		min-height: 70rpx;
 		display: flex;
 		align-items: center;
-		background-color: #fff;
-		color: #808080;
+		padding-left: 32rpx;
 	}
-	.text  {
-		padding: 10rpx 20rpx;
+	.list-item:first-child {
+		padding-top: 8rpx;
 	}
-</style>
+	.list-item:last-child {
+		padding-bottom: 8rpx;
+	}
+	.z-floor {
+		position: fixed;
+		bottom: 0;
+		left: 0;
+		height: 100rpx;
+		width: 100%;
+		background-color: #FFF;
+		display: flex;
+		align-items: center;
+		
+	}
+	.list-title {
+		vertical-align: text-bottom;
+	}
+	.val-text {
+		background-color: #00aeec;
+		padding: 2px 4px;
+		border-radius: 4px;
+		color: #FFF;
+	}
+	.val-num {
+		font-weight: 900;
+		color: #d19a66;
+		font-size: 16px;
+	}
+</style>
\ No newline at end of file

--
Gitblit v1.9.1