Browse Source

取货核销

zhanghui 1 year ago
parent
commit
095a3bd32b

+ 18 - 2
api/groupon.js

@@ -1,9 +1,25 @@
 import request from "@/utils/request.js";
 
 
-commitAppoint
 
-// 团长相关履约单列表
+
+
+// 获取核销订单商品
+export function getOrderGoodsList(orderId) {
+    return request.post("/v1/order/getOrderGoodsList?orderId="+orderId);
+}
+
+// 取货核销
+export function getConfirmOrderList(data) {
+    return request.post("/v1/order/getConfirmOrderList",data);
+}
+
+// 取货核销
+export function confirmOrder(pickupCode) {
+    return request.post("/v1/order/confirmOrder?pickupCode="+pickupCode);
+}
+
+// 团长相关履约核销
 export function commitAppoint(id) {
     return request.post("/v1/commitAppoint?appointId="+id);
 }

+ 38 - 35
pages/groupbuying/pickupVerification/index.vue

@@ -8,9 +8,9 @@
 		</view>
 
 		<view class="u-demo-block__content" style="margin-top: 15px;">
-			<u-input placeholder="输入取货码" class="slot-ipt">
+			<u-input placeholder="输入取货码" class="slot-ipt" v-model="pickupCode">
 				<template slot="suffix">
-					<u-button class="slot-btn" @tap="getCode" text="确认核销" type="success" size="mini"></u-button>
+					<u-button class="slot-btn" text="确认核销" type="success" size="mini" @click="confirmOrder"></u-button>
 				</template>
 
 			</u-input>
@@ -21,37 +21,19 @@
 			<view class="title">
 				核销记录
 			</view>
-			<u-cell-group>
 
-				<navigator url="/pages/groupbuying/pickupVerificationr_details/index" hover-class="none">
-					<u-cell isLink>
-
-						<view slot="title" class="u-slot-title">
-							<image src="http://www.gzzzyd.com/groupon/home_slices/看车记录@2x.png" mode=""></image>
-							<text class="u-cell-text">GUUIWU</text>
-						</view>
-
-					</u-cell>
-				</navigator>
-
-				<navigator url="/pages/groupbuying/pickupVerificationr_details/index" hover-class="none">
-					<u-cell isLink>
-
-						<view slot="title" class="u-slot-title">
-							<image src="http://www.gzzzyd.com/groupon/home_slices/看车记录@2x.png" mode=""></image>
-							<text class="u-cell-text">ZIA7DU</text>
-						</view>
-
-					</u-cell>
-				</navigator>
-
-			</u-cell-group>
+			<view>
+				<mescroll-item ref="MescrollItem"  :i="0" :index="0" :height="height">
+				</mescroll-item>
+			</view>
 		</view>
 
 	</view>
 </template>
 
 <script>
+	import MescrollItem from "./module/mescrollUni-item.vue";
+	import { confirmOrder} from '@/api/groupon.js'
 import {
 	getUserInfo,
 	userEdit,
@@ -73,6 +55,7 @@ import authorize from '@/components/Authorize';
 import colors from '@/mixins/color.js';
 export default {
 	components: {
+		MescrollItem,
 		// #ifdef APP-PLUS
 		appUpdate,
 		// #endif
@@ -83,6 +66,9 @@ export default {
 	mixins: [colors],
 	data () {
 		return {
+			height:'750rpx',
+			pickupCode:'',
+
 		};
 	},
 	computed: mapGetters(['isLogin']),
@@ -96,6 +82,11 @@ export default {
 			deep: true
 		}
 	},
+	onShow(){
+		let sysInfo = uni.getSystemInfoSync()
+		this.height= sysInfo.windowHeight -(sysInfo.screenWidth/750) * (530) +'px';
+		console.log(this.height)
+	},
 	onLoad () {
 		if (this.isLogin) {
 			this.getUserInfo();
@@ -106,13 +97,22 @@ export default {
 				console.log(inf.version)
 				this.version = inf.version;
 			});
-			// #endif 
+			// #endif
 			this.setLang();
 		} else {
 			toLogin();
 		}
 	},
 	methods: {
+
+		confirmOrder(){
+			confirmOrder(this.pickupCode).then(res =>{
+				uni.$u.toast(res.msg)
+			}).catch(err =>{
+				uni.$u.toast(err)
+			})
+		},
+
 		isNew () {
 			this.$util.Tips({
 				title: this.$t(`当前为最新版本`)
@@ -177,15 +177,15 @@ export default {
 				let files = plus.android.invoke(sdRoot, "listFiles");
 				let len = files.length;
 				for (let i = 0; i < len; i++) {
-					let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径  
+					let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径
 					plus.io.resolveLocalFileSystemURL(filePath, function (entry) {
 						if (entry.isDirectory) {
-							entry.removeRecursively(function (entry) { //递归删除其下的所有文件及子目录  
+							entry.removeRecursively(function (entry) { //递归删除其下的所有文件及子目录
 								uni.showToast({
 									title: that.$t(`缓存清理完成`),
 									duration: 2000
 								});
-								that.formatSize(); // 重新计算缓存  
+								that.formatSize(); // 重新计算缓存
 							}, function (e) {
 								console.log(e.message)
 							});
@@ -194,7 +194,7 @@ export default {
 						}
 					}, function (e) { });
 				}
-			} else { // ios暂时未找到清理缓存的方法,以下是官方提供的方法,但是无效,会报错  
+			} else { // ios暂时未找到清理缓存的方法,以下是官方提供的方法,但是无效,会报错
 				plus.cache.clear(function () {
 					uni.showToast({
 						title: that.$t(`缓存清理完成`),
@@ -258,7 +258,7 @@ export default {
 		},
 		/**
 		 * 退出登录
-		 * 
+		 *
 		 */
 		outLogin: function () {
 			let that = this;
@@ -307,7 +307,7 @@ export default {
 		},
 		/**
 		 * 上传文件
-		 * 
+		 *
 		 */
 		uploadpic: function () {
 			let that = this;
@@ -498,8 +498,8 @@ export default {
 
 .tool_list {
 	.title {
-		padding: 0 40rpx;
-		padding-top: 20rpx;
+		/*padding: 0 40rpx;*/
+		/*padding-top: 20rpx;*/
 		height: 100rpx;
 		font-size: 36rpx;
 		font-weight: bolder;
@@ -539,4 +539,7 @@ export default {
 	background: white;
 	border-radius: 46rpx;
 }
+	.bord{
+		border: 1px solid red;
+	}
 </style>

+ 154 - 0
pages/groupbuying/pickupVerification/module/mescrollUni-item.vue

@@ -0,0 +1,154 @@
+<template>
+	<!--
+    swiper中的transfrom会使fixed失效,此时用height固定高度;
+    swiper中无法触发mescroll-mixins.js的onPageScroll和onReachBottom方法,只能用mescroll-uni,不能用mescroll-body
+    -->
+	<!-- ref动态生成: 字节跳动小程序编辑器不支持一个页面存在相同的ref (如不考虑字节跳动小程序可固定值为 ref="mescrollRef") -->
+	<!-- top的高度等于悬浮菜单tabs的高度 -->
+	<mescroll-uni :ref="'mescrollRef' + i" @init="mescrollInit" :height="height" :down="downOption" @down="downCallback"
+		:up="upOption" @up="upCallback" @emptyclick="emptyClick">
+		<!-- 数据列表 -->
+		<u-cell-group>
+			<view v-for="(item,index) in list" :key="index">
+				<u-cell isLink  >
+					<view slot="title" class="u-slot-title" @click="goDetail(item)" >
+						<image src="http://www.gzzzyd.com/groupon/home_slices/看车记录@2x.png" mode=""></image>
+						<text class="u-cell-text">{{item.pickupCode}}</text>
+					</view>
+				</u-cell>
+			</view>
+		</u-cell-group>
+	</mescroll-uni>
+</template>
+
+<script>
+	import MescrollMixin from "@/uni_modules/mescroll-uni/components/mescroll-uni/mescroll-mixins.js";
+	import MescrollMoreItemMixin from "@/uni_modules/mescroll-uni/components/mescroll-uni/mixins/mescroll-more-item.js";
+	import { getConfirmOrderList} from '@/api/groupon.js'
+	export default {
+		mixins: [MescrollMixin, MescrollMoreItemMixin], // 注意此处还需使用MescrollMoreItemMixin (必须写在MescrollMixin后面)
+		components: {
+		},
+
+		data() {
+			return {
+				downOption: {
+					auto: true // 不自动加载 (mixin已处理第一个tab触发downCallback)
+				},
+				upOption: {
+					auto: true, // 不自动加载
+					// page: {
+					// 	num: 0, // 当前页码,默认0,回调之前会加1,即callback(page)会从1开始
+					// 	size: 10 // 每页数据的数量
+					// },
+					noMoreSize: 4, //如果列表已无数据,可设置列表的总数量要大于半页才显示无更多数据;避免列表数据过少(比如只有一条数据),显示无更多数据会不好看; 默认5
+					empty: {
+						icon: '/static/images/empty.png',
+						tip: '暂无内容', // 提示
+						// btnText: '去看看'
+					},
+					textNoMore: '没有更多了'
+				},
+				list: [],
+			}
+		},
+		props: {
+			i: Number, // 每个tab页的专属下标 (除了支付宝小程序必须在这里定义, 其他平台都可不用写, 因为已在MescrollMoreItemMixin定义)
+			index: { // 当前tab的下标 (除了支付宝小程序必须在这里定义, 其他平台都可不用写, 因为已在MescrollMoreItemMixin定义)
+				type: Number,
+				default () {
+					return 0
+				}
+			},
+
+			tabs: { // 为了请求数据,演示用,可根据自己的项目判断是否要传
+				type: Array,
+				default () {
+					return []
+				}
+			},
+			height: [Number, String], // mescroll的高度
+
+		},
+		watch:{
+
+		},
+
+		methods: {
+			goDetail(item){
+				uni.navigateTo({
+					url:'/pages/groupbuying/pickupVerificationr_details/index?orderId='+item.orderId + '&pickupCode='+item.pickupCode
+				})
+			},
+
+			/*下拉刷新的回调 */
+			downCallback() {
+				// 这里加载你想下拉刷新的数据, 比如刷新轮播数据
+				// loadSwiper();
+				// 下拉刷新的回调,默认重置上拉加载列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )
+				this.mescroll.resetUpScroll()
+			},
+			/*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
+			upCallback(page) {
+				//联网加载数据
+				let httpData = {
+					current: page.num,
+					size: 10,
+				}
+
+				getConfirmOrderList(httpData).then((res) => {
+
+						//联网成功的回调,隐藏下拉刷新和上拉加载的状态;
+						this.mescroll.endSuccess(res.data.length,res.data.length === 10);
+						//设置列表数据
+						if (page.num === 1) this.list = []; //如果是第一页需手动制空列表
+						if (res.data.length > 0){
+							this.list = this.list.concat(res.data); //追加新数据
+						}
+						console.log("+++++++++++++++++++++",this.list)
+					}).catch((err) => {
+						//联网失败, 结束加载
+						this.mescroll.endErr();
+					})
+
+
+
+			},
+			//点击空布局按钮的回调
+			emptyClick() {
+				uni.showToast({
+					title: '点击了按钮,具体逻辑自行实现'
+				})
+			},
+			// 搜索
+			doSearch() {
+				this.list = []; // 先清空列表,显示加载进度
+				this.mescroll.resetUpScroll();
+			},
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+
+	.u-slot-title {
+		line-height: 60rpx;
+
+		font-size: 28rpx;
+		font-weight: 400;
+		color: #333333;
+
+	text {
+		vertical-align: text-bottom;
+	}
+
+	image {
+
+		margin-right: 20rpx;
+		transform: translateY(10rpx);
+		width: 60rpx;
+		height: 60rpx;
+
+	}
+	}
+</style>

+ 27 - 41
pages/groupbuying/pickupVerificationr_details/index.vue

@@ -5,52 +5,36 @@
 				取货码
 			</view>
 			<view class="dt2">
-				GUUIWU
+				{{pickupCode}}
 			</view>
 		</view>
 
 		<view class="all-products-body">
-			<view class="all-products-item" >
-				<image
-					src="https://lanhu-dds-backend.oss-cn-beijing.aliyuncs.com/merge_image/imgs/38e693de009644aa9de2dc6d6f7e747a_mergeImage.png"
-					mode="scaleToFill" />
 
-				<view class="all-products-item-content">
-					<view class="all-products-item-content-t">
-						宫中秘策(GOONGBE)进口儿童韩国进口儿童防晒霜80g
-					</view>
-					<view class="all-products-item-content-b">
-						<view style="display:flex;">
-							<text class="red"> 共2件</text>
-						</view>
-
-					</view>
-				</view>
-			</view>
-			<view class="all-products-item" >
+			<view class="all-products-item" v-for="(item,index) in goodsList" :key="index">
 				<image
 					src="https://lanhu-dds-backend.oss-cn-beijing.aliyuncs.com/merge_image/imgs/38e693de009644aa9de2dc6d6f7e747a_mergeImage.png"
 					mode="scaleToFill" />
 
 				<view class="all-products-item-content">
 					<view class="all-products-item-content-t">
-						宫中秘策(GOONGBE)进口儿童韩国进口儿童防晒霜80g
+						{{item.goodsName}}
 					</view>
 					<view class="all-products-item-content-b">
 						<view style="display:flex;">
-							<text class="red"> 共2件</text>
+							<text class="red"> 共{{item.goodsNum}}件</text>
 						</view>
 
 					</view>
 				</view>
 			</view>
 
-
 		</view>
 	</view>
 </template>
 
 <script>
+	import { getOrderGoodsList} from '@/api/groupon.js'
 import {
 	getUserInfo,
 	userEdit,
@@ -82,6 +66,8 @@ export default {
 	mixins: [colors],
 	data () {
 		return {
+			pickupCode:'',
+			goodsList:[]
 		};
 	},
 	computed: mapGetters(['isLogin']),
@@ -95,23 +81,23 @@ export default {
 			deep: true
 		}
 	},
-	onLoad () {
-		if (this.isLogin) {
-			this.getUserInfo();
-			// #ifdef APP-PLUS
-			this.formatSize()
-			// 获取版本号
-			plus.runtime.getProperty(plus.runtime.appid, (inf) => {
-				console.log(inf.version)
-				this.version = inf.version;
-			});
-			// #endif 
-			this.setLang();
-		} else {
-			toLogin();
+	onLoad (e) {
+		if (e.pickupCode){
+			this.pickupCode=e.pickupCode
 		}
+
+		if (e.orderId){
+			this.getOrderGoodsList(e.orderId)
+		}
+
 	},
 	methods: {
+
+		getOrderGoodsList(){
+			getOrderGoodsList().then(res =>{
+				this.goodsList=res.data
+			})
+		},
 		isNew () {
 			this.$util.Tips({
 				title: this.$t(`当前为最新版本`)
@@ -176,15 +162,15 @@ export default {
 				let files = plus.android.invoke(sdRoot, "listFiles");
 				let len = files.length;
 				for (let i = 0; i < len; i++) {
-					let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径  
+					let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径
 					plus.io.resolveLocalFileSystemURL(filePath, function (entry) {
 						if (entry.isDirectory) {
-							entry.removeRecursively(function (entry) { //递归删除其下的所有文件及子目录  
+							entry.removeRecursively(function (entry) { //递归删除其下的所有文件及子目录
 								uni.showToast({
 									title: that.$t(`缓存清理完成`),
 									duration: 2000
 								});
-								that.formatSize(); // 重新计算缓存  
+								that.formatSize(); // 重新计算缓存
 							}, function (e) {
 								console.log(e.message)
 							});
@@ -193,7 +179,7 @@ export default {
 						}
 					}, function (e) { });
 				}
-			} else { // ios暂时未找到清理缓存的方法,以下是官方提供的方法,但是无效,会报错  
+			} else { // ios暂时未找到清理缓存的方法,以下是官方提供的方法,但是无效,会报错
 				plus.cache.clear(function () {
 					uni.showToast({
 						title: that.$t(`缓存清理完成`),
@@ -257,7 +243,7 @@ export default {
 		},
 		/**
 		 * 退出登录
-		 * 
+		 *
 		 */
 		outLogin: function () {
 			let that = this;
@@ -306,7 +292,7 @@ export default {
 		},
 		/**
 		 * 上传文件
-		 * 
+		 *
 		 */
 		uploadpic: function () {
 			let that = this;