소스 검색

售后列表

zhanghui 1 년 전
부모
커밋
3cba30e004
4개의 변경된 파일303개의 추가작업 그리고 223개의 파일을 삭제
  1. 11 0
      api/groupon.js
  2. 49 223
      pages/users/user_return_list/index.vue
  3. 70 0
      pages/users/user_return_list/module/index.rpx.css
  4. 173 0
      pages/users/user_return_list/module/mescrollUni-item.vue

+ 11 - 0
api/groupon.js

@@ -1,6 +1,17 @@
 import request from "@/utils/request.js";
 
 
+//获取用户售后详情
+export function getUserAfterSalesDetail(afterSalesId) {
+    return request.get("/v1/after-sales/user/detail?afterSalesId=" +afterSalesId,null);
+}
+
+
+//获取用户售后列表
+export function getUserAfterSalesList(data) {
+    return request.post("/v1/after-sales/user/list?state="+data.state,data);
+}
+
 //获取售后原因列表
 export function reasonList() {
     return request.get("/v1/after-sales/reason/list",null);

+ 49 - 223
pages/users/user_return_list/index.vue

@@ -1,268 +1,94 @@
 <template>
-	<view :style="colorStyle">
-		<view class="top-tabs">
-			<view class="tabs" :class="{btborder:type === index}" v-for="(item,index) in tabsList" :key="index"
-				@tap="changeTabs(index)">
-				{{item.name}}
-			</view>
+	<view>
+		<view class="tabs">
+			<u-tabs class="defalt-utabs" :is-scroll="false" :list="navigationList" @change="changeNav" lineColor="#B22338" :current="tabIndex"
+					:inactiveStyle="{ color: '#999999' }" :activeStyle="{ color: '#B22338', fontWeight: 'bold' }"
+					keyName="title"></u-tabs>
 		</view>
-		<view class='return-list' v-if="orderList.length">
-			<view class='goodWrapper' v-for="(item,index) in orderList" :key="index"
-				@click='goOrderDetails(item.order_id)'>
-				<view class='iconfont icon-shenqingzhong powder' v-if="item.refund_type==1 ||item.refund_type==2">
-				</view>
-				<view class='iconfont icon-yijujue' v-if="item.refund_type==3"></view>
-				<view class='iconfont icon-daituihuo1 powder' v-if="item.refund_type==4"></view>
-				<view class='iconfont icon-tuikuanzhong powder' v-if="item.refund_type==5"></view>
-				<view class='iconfont icon-yituikuan' v-if="item.refund_type==6"></view>
-				<view class='orderNum'>{{$t(`订单号`)}}:{{item.order_id}}</view>
-				<view class='item acea-row row-between-wrapper' v-for="(items,index) in item.cart_info" :key="index">
-					<view class='pictrue'>
-						<image :src='items.productInfo.attrInfo?items.productInfo.attrInfo.image:items.productInfo.image'>
-						</image>
-					</view>
-					<view class='text'>
-						<view class='acea-row row-between-wrapper'>
-							<view class='name line1'>{{items.productInfo.store_name}}</view>
-							<view class='num'>x {{items.cart_num}}</view>
-						</view>
-						<view class='attr line1' v-if="items.productInfo.attrInfo">{{items.productInfo.attrInfo.suk}}
-						</view>
-						<view class='attr line1' v-else>{{items.productInfo.store_name}}</view>
-						<view class='money'>
-							{{$t(`¥`)}}{{items.productInfo.attrInfo?items.productInfo.attrInfo.price:items.productInfo.price}}</view>
+
+		<view  :style="{ height: height }" class="bord">
+			<swiper :style="{ height: height }" :current="tabIndex" @change="swiperChange">
+				<swiper-item v-for="(tab,index) in navigationList" :key="index">
+					<view>
+						<mescroll-item ref="MescrollItem"  :i="index" :index="tabIndex" :tabs="navigationList" :height="height">
+						</mescroll-item>
 					</view>
-				</view>
-				<view class='totalSum'>{{$t(`共`)}} {{item.refund_num || 0}} {{$t(`件商品,总金额`)}} <text
-						class='font-color price'>{{$t(`¥`)}}{{item.refund_price}}</text></view>
-			</view>
-		</view>
-		<view class='loadingicon acea-row row-center-wrapper' v-if="orderList.length > 0">
-			<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
+				</swiper-item>
+			</swiper>
 		</view>
-		<view v-if="orderList.length == 0  && !loading">
-			<emptyPage :title="$t(`暂无退款订单~`)"></emptyPage>
-		</view>
-		<!-- #ifdef MP -->
-		<!-- <authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize> -->
-		<!-- #endif -->
-		<!-- #ifndef MP -->
-		<home></home>
-		<!-- #endif -->
+
+
 	</view>
 </template>
 
 <script>
-	import home from '@/components/home';
-	import emptyPage from '@/components/emptyPage';
-	import {
-		getNewOrderList
-	} from '@/api/order.js';
+	import MescrollItem from "./module/mescrollUni-item.vue";
+
 	import {
 		toLogin
 	} from '@/libs/login.js';
 	import {
 		mapGetters
 	} from "vuex";
-	// #ifdef MP
-	import authorize from '@/components/Authorize';
-	// #endif
+
 	import colors from '@/mixins/color.js';
 	export default {
 		components: {
-			home,
-			emptyPage,
-			// #ifdef MP
-			authorize
-			// #endif
+			MescrollItem
 		},
 		mixins: [colors],
 		data() {
 			return {
-				type: 0,
-				loading: false,
-				loadend: false,
-				loadTitle: this.$t(`加载更多`), //提示语
-				orderList: [], //订单数组
-				orderStatus: -3, //订单状态
-				page: 1,
-				limit: 20,
-				isAuto: false, //没有授权的不会自动授权
-				isShowAuth: false, //是否隐藏授权
-				tabsList: [{
-					key: 0,
-					name: this.$t(`全部`)
-				},
-				{
-					key: 1,
-					name: this.$t(`申请中`)
-				},
-				// {
-				// 	key: 2,
-				// 	name: '待退货'
-				// }, 
-				// {
-				// 	key: 3,
-				// 	name: '退款中'
-				// }, 
-				{
-					key: 2,
-					name: this.$t(`已退款`)
-				}]
+				height:'',
+
+				navigationList: [{
+					title: '全部',
+					id: '0'
+				}, {
+					title: '申请中',
+					id: '1'
+				},{
+					title: '已退款',
+					id: '2'
+				}],
+
+				tabIndex: 0,
+
+
 			};
 		},
 		computed: mapGetters(['isLogin']),
-		watch: {
-			isLogin: {
-				handler: function(newV, oldV) {
-					if (newV) {
-						this.getOrderList();
-					}
-				},
-				deep: true
-			}
+
+		onShow(){
+			let sysInfo = uni.getSystemInfoSync()
+			this.height= sysInfo.windowHeight -(sysInfo.screenWidth/750) * (100) +'px';
+			console.log(this.height)
 		},
 		onLoad() {
 			if (this.isLogin) {
-				this.getOrderList();
+
 			} else {
 				toLogin();
 			}
 		},
-		/**
-		 * 页面上拉触底事件的处理函数
-		 */
-		onReachBottom: function() {
-			this.getOrderList();
-		},
+
 		methods: {
-			onLoadFun() {
-				this.getOrderList();
-			},
-			// 授权关闭
-			authColse: function(e) {
-				this.isShowAuth = e
+			swiperChange(e) {
+				this.tabIndex = e.detail.current
 			},
-			/**
-			 * 去订单详情
-			 */
-			goOrderDetails: function(order_id) {
-				if (!order_id) return that.$util.Tips({
-					title: that.$t(`缺少订单号无法查看订单详情`)
-				});
-				uni.navigateTo({
-					url: '/pages/goods/order_details/index?order_id=' + order_id + '&isReturen=1'
-				})
-			},
-			changeTabs(index) {
-				this.type = index
-				this.loadend = false;
-				this.page = 1
-				this.limit = 20
-				this.orderList = []
-				this.getOrderList(index)
+
+			changeNav (e) {
+				this.tabIndex = e.index
 			},
-			/**
-			 * 获取订单列表
-			 */
-			getOrderList(type) {
-				let that = this;
-				if (that.loading) return;
-				if (that.loadend) return;
-				that.loading = true;
-				that.loadTitle = "";
-				getNewOrderList({
-					// type: that.orderStatus,
-					page: that.page,
-					limit: that.limit,
-					refund_status: type ? type : that.type
-				}).then(res => {
-					let list = res.data.list || [];
-					let loadend = list.length < that.limit;
-					that.orderList = that.orderList.concat(list);
-					that.$set(that, 'orderList', that.orderList);
-					that.loadend = loadend;
-					that.loading = false;
-					that.loadTitle = loadend ? that.$t(`我也是有底线的`) : that.$t(`加载更多`);
-					that.page = that.page + 1;
-				}).catch(err => {
-					that.loading = false;
-					that.loadTitle = that.$t(`加载更多`);
-				});
-			}
+
 		}
 	}
 </script>
 
 <style lang="scss" scoped>
-	.return-list .goodWrapper {
-		background-color: #fff;
-		margin-top: 13rpx;
-		position: relative;
-	}
 
-	.return-list .goodWrapper .orderNum {
-		padding: 0 30rpx;
-		border-bottom: 1px solid #eee;
-		height: 87rpx;
-		line-height: 87rpx;
-		font-size: 30rpx;
-		color: #282828;
-	}
 
-	.return-list .goodWrapper .item {
-		border-bottom: 0;
-		padding: 30rpx;
-	}
 
-	.return-list .goodWrapper .totalSum {
-		padding: 0 30rpx 32rpx 30rpx;
-		text-align: right;
-		font-size: 26rpx;
-		color: #282828;
-	}
 
-	.return-list .goodWrapper .totalSum .price {
-		font-size: 28rpx;
-		font-weight: bold;
-	}
 
-	.return-list .goodWrapper .iconfont {
-		position: absolute;
-		font-size: 109rpx;
-		top: 7rpx;
-		right: 30rpx;
-		color: #ccc;
-	}
-
-	.return-list .goodWrapper .iconfont.powder {
-		color: var(--view-minorColor);
-	}
-
-	.top-tabs {
-		display: flex;
-		justify-content: space-around;
-		align-items: center;
-		height: 80rpx;
-		background-color: #fff;
-	}
-
-	.top-tabs .tabs {
-		position: relative;
-		height: 100%;
-		padding: 12px 0;
-	}
-
-	.btborder {
-		&::after {
-			position: absolute;
-			content: ' ';
-			width: 39px;
-			height: 2px;
-			background-color: var(--view-theme);
-			bottom: 2px;
-			left: 50%;
-			margin-left: -19px;
-		}
-	}
 </style>

+ 70 - 0
pages/users/user_return_list/module/index.rpx.css

@@ -0,0 +1,70 @@
+.myclient_list{
+    padding: 20rpx 15rpx;
+    background-color: white;
+    margin-top: 15rpx;
+}
+.nl{
+    width: 600rpx;
+    overflow: hidden;
+    text-overflow: ellipsis;
+    display: -webkit-box;
+    -webkit-line-clamp: 1;
+    -webkit-box-orient: vertical;
+}
+
+.status {
+    text-align: right;
+    color: #75BE00;
+}
+.success_status{
+    text-align: right;
+    color: greenyellow;
+}
+
+.time {
+    height: 44rpx;
+    font-size: 24rpx;
+    font-weight: 400;
+    color: #999999;
+    line-height: 44rpx;
+    margin-top: 10rpx;
+}
+
+.time image {
+    width: 24rpx;
+    height: 24rpx;
+    margin-right: 20rpx;
+    margin-top: 10rpx;
+}
+.all-products-item{
+    margin-top: 10rpx;
+}
+.all-products-item 	image {
+    width: 128rpx;
+    height: 128rpx;
+    margin-right: 20rpx;
+    border: 2rpx solid #FFFFFF;
+}
+.all-products-item-content{
+    width: 592rpx;
+}
+.all-products-item-content-t {
+    text-overflow: ellipsis;
+    display: -webkit-box;
+    -webkit-line-clamp: 1;
+    -webkit-box-orient: vertical;
+    font-size: 24rpx;
+    font-weight: 400;
+    color: #333333;
+    line-height: 40rpx;
+    margin-top: 15rpx;
+}
+.all-products-item-content-b{
+    margin-top: 10rpx;
+}
+.count {
+    font-size: 24rpx;
+    font-weight: 400;
+    color: #999999;
+    margin-right: 30rpx;
+}

+ 173 - 0
pages/users/user_return_list/module/mescrollUni-item.vue

@@ -0,0 +1,173 @@
+<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">
+		<!-- 数据列表 -->
+
+		<view class="myclient_list flex-col" v-for="(item,index) in list" :key="index">
+			<view class="flex-col" >
+				<view class="flex-row justify-between">
+					<view class="nl">
+						{{item.mainTitle}}
+					</view>
+
+					<view v-if="item.status === 1" class="success_status">{{item.statusDesc}}</view>
+					<view v-else class="status">{{item.statusDesc}}</view>
+
+				</view>
+				<view class="flex-col">
+
+					<view class="time flex-row">
+						<image referrerpolicy="no-referrer" src="http://www.gzzzyd.com/groupon/home_slices/日期@2x.png" />
+						<text>
+							团购日期: {{item.grouponStartTime}} 至 {{item.grouponEndTime}}
+						</text>
+					</view>
+					<view class="time flex-row">
+						<image referrerpolicy="no-referrer" src="http://www.gzzzyd.com/groupon/home_slices/出厂编号-线@2x.png" />
+						<text>
+							售后编号: {{item.afterSalesNo}}
+						</text>
+					</view>
+				</view>
+			</view>
+
+			<view class="all-products-item flex-row" v-for="(goods,goodsIndex) in item.goodsList" :key="goodsIndex">
+				<image
+						:src="goods.goodsImage"
+						mode="scaleToFill" />
+
+				<view class="all-products-item-content flex-col">
+					<view class="all-products-item-content-t">
+						{{goods.goodsName}}
+					</view>
+					<view class="all-products-item-content-b flex-row justify-between">
+						<view>
+							<text class="red"> ¥{{goods.goodsPrice}}</text>
+						</view>
+						<view>
+							<view class="count"> x {{goods.goodsNum}}</view>
+						</view>
+					</view>
+				</view>
+			</view>
+
+		</view>
+
+	</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 {getUserAfterSalesList} from '@/api/groupon.js'
+	export default {
+		mixins: [MescrollMixin, MescrollMoreItemMixin], // 注意此处还需使用MescrollMoreItemMixin (必须写在MescrollMixin后面)
+		components: {
+		},
+
+		data() {
+			return {
+				downOption: {
+					auto: false // 不自动加载 (mixin已处理第一个tab触发downCallback)
+				},
+				upOption: {
+					auto: false, // 不自动加载
+					// 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:{
+			index(newVal,oldVal){
+				// this.downCallback();
+			}
+		},
+
+		methods: {
+
+			/*下拉刷新的回调 */
+			downCallback() {
+				// 这里加载你想下拉刷新的数据, 比如刷新轮播数据
+				// loadSwiper();
+				// 下拉刷新的回调,默认重置上拉加载列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )
+				this.mescroll.resetUpScroll()
+			},
+			/*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
+			upCallback(page) {
+				//联网加载数据
+				let httpData = {
+					current: page.num,
+					size: 10,
+					state:this.index
+				}
+
+				getUserAfterSalesList(httpData).then((res) => {
+
+					//联网成功的回调,隐藏下拉刷新和上拉加载的状态;
+					this.mescroll.endSuccess(res.data.records.length,res.data.records.length === 10);
+					//设置列表数据
+					if (page.num === 1) this.list = []; //如果是第一页需手动制空列表
+					if (res.data.records.length > 0){
+						this.list = this.list.concat(res.data.records.redias); //追加新数据
+					}
+					console.log("+++++++++++++++++++++",this.list)
+				}).catch((err) => {
+					//联网失败, 结束加载
+					this.mescroll.endErr();
+				})
+
+
+			},
+			//点击空布局按钮的回调
+			emptyClick() {
+				uni.showToast({
+					title: '点击了按钮,具体逻辑自行实现'
+				})
+			},
+			// 搜索
+			doSearch() {
+				this.list = []; // 先清空列表,显示加载进度
+				this.mescroll.resetUpScroll();
+			},
+		}
+	}
+</script>
+
+<style>
+	@import '/static/css/common.css';
+	@import './index.rpx.css';
+</style>