| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405 | <!-- 菜单悬浮的原理: 通过给菜单添加position:sticky实现, 用法超简单, 仅APP端的低端机不兼容 https://caniuse.com/#feat=css-sticky --><template>	<view>		<view class="sticky-tabs">			<u-tabs :list="tabs" :is-scroll="true" :current="tabIndex" @change="tabChange" active-color="#000000"				inactive-color="#999999"></u-tabs>		</view>		<!-- 数据列表 -->		<view v-if="goods.length > 0" class="margin-sm bg  padding-tb-sm" v-for="(item,index) in goods" :key='index'			@click="goNav('/my/order/pay?ordersId='+item.ordersId)" style="border-radius: 24rpx;">			<view class="flex justify-between padding-lr-sm ">				<view class="flex align-center">					<image src="../../static/logo.png" style="width: 48rpx;height: 48rpx;border-radius: 50%;">					</image>					<view class="margin-left-xs ">{{item.artificerName}}</view>				</view>				<view class="theme-color" v-if="item.status ==1">待付款</view>				<view class="theme-color" v-if="item.status ==2">待服务</view>				<view class="theme-color" v-if="item.status ==3">待评价</view>				<view class="theme-color" v-if="item.status ==5">已完成</view>				<view class="theme-color" v-if="item.status ==6">服务中</view>				<view class="theme-color" v-if="item.status ==7">技师出发</view>				<view class="theme-color" v-if="item.status ==8">技师到达</view>				<view class="theme-color" v-if="item.status ==4" style="color: #999999;">已取消</view>				<!-- <view class="u-tips-color">{{item.createTime}}</view> -->			</view>			<view class="margin-top-sm" style="width: 100%;height: 1rpx;background: #EEEEEE;"></view>			<view class=" u-flex u-p-t-30 padding-lr-sm">				<view class="u-m-r-10">					<u-avatar						:src="(item.ordersMassageList && item.ordersMassageList.length > 0 && item.ordersMassageList[0].massageType && item.ordersMassageList[0].massageType.massageImg)?item.ordersMassageList[0].massageType.massageImg: '../../static/logo.png'"						mode="square" size="100">					</u-avatar>				</view>				<view class="u-flex-1  margin-left-xs">					<view class="u-font-18  text-bold u-line-1" style="width: 560rpx;">						<view class=" text-lg "							v-if="item.ordersMassageList && item.ordersMassageList.length > 0 && item.ordersMassageList[0].massageType && item.ordersMassageList[0].massageType.title"							style="margin-top: 0rpx;display: inline-block;width: 470rpx; overflow: hidden;white-space: nowrap;text-overflow: ellipsis;">							{{item.ordersMassageList[0].massageType.title}}						</view>					</view>					<view class="u-font-14 margin-top-xs u-tips-color flex justify-between">						预约时间:{{item.serveTime}}					</view>				</view>			</view>			<view class="flex u-p-t-20 justify-between align-center padding-lr-sm">				<view class=" flex-sub ">					实付:<text class="text-df" style="color: #F24E4E;">¥</text><text class="text-xl text-bold"						style="color: #F24E4E;font-size: 40rpx;">{{item.sumMoney}}</text>				</view>				<view class="flex text-right">					<u-button						v-if="(item.status == 1 || item.status == 2 || item.status == 7 || item.status == 8) && yhqxSel != '否'"						:custom-style="customStyle" shape="circle" :plain="true"						@click="cancelOrder(item)">取消订单</u-button>					<u-button v-if="item.status == 1" :custom-style="customStyle1" shape="circle" :plain="true"						@click="goNav('/my/order/pay?ordersId='+item.ordersId)">去支付</u-button>					<u-button v-if="item.status == 2" :custom-style="customStyle1" shape="circle" :plain="true"						@click="goNav('/my/order/pay?ordersId='+item.ordersId)">查看详情</u-button>					<!-- <u-button v-if="item.status == 6" :custom-style="customStyle" shape="circle" :plain="true"							@click="cancel(item)">订单完成</u-button> -->					<!-- <u-button v-if="item.state == 2" :custom-style="customStyle" shape="circle" :plain="true" @click="goNav('/my/order/complain?id='+item.ordersId)" >去投诉</u-button> -->					<u-button v-if="item.status == 3" :custom-style="customStyle1" shape="circle" :plain="true"						@click="goNav('/my/order/feedback?artificerId='+item.artificerId+ '&ordersId='+item.ordersId)">						去评价					</u-button>					<u-button v-if="(item.status == 4 || item.status == 5) && userDeletaSel != '否'"						:custom-style="customStyle" shape="circle" :plain="true" @click="delOrder(item)">删除订单</u-button>				</view>			</view>		</view>		<empty v-if="goods.length == 0"></empty>	</view></template><script>	import MescrollMixin from "@/components/mescroll-uni/components/mescroll-uni/mescroll-mixins.js";	import mescrollBody from "@/components/mescroll-uni/components/mescroll-body/mescroll-body.vue";	import meTabs from "@/components/mescroll-uni/me-tabs/me-tabs.vue";	import empty from '@/components/empty.vue'	export default {		mixins: [MescrollMixin], // 使用mixin		components: {			mescrollBody,			meTabs,			empty		},		data() {			return {				goods: [], // 数据列表				game: [],				tabs: [{					name: '全部',					status: '0'				}, {					name: '待支付',					status: '1'				}, {					name: '待服务',					status: '2'				}, {					name: '技师出发',					status: '7'				}, {					name: '技师到达',					status: '8'				}, {					name: '服务中',					status: '6'				}, {					name: '待评价',					status: '3'				}, {					name: '已取消',					status: '4'				}, {					name: '已完成',					status: '5'				}],				tabIndex: 0, // tab下标				page: 1,				limit: 10,				userId: 0,				status: 1,				nickName: '',				avatar: '',				customStyle: {					color: '#999999',					border: '4rpx solid #999999',					border: "8rpx",					width: '180rpx',					height: '60rpx',					margin: "0 0 0 20rpx",					fontSize: '26rpx'				},				customStyle1: {					color: '#FFFFFF',					backgroundColor: '#FF6E98',					border: "8rpx",					width: '200rpx',					height: '64rpx',					margin: "0 0 0 20rpx",					fontSize: '26rpx'				},				yhqxSel: '否',				userDeletaSel: '否'				// customStyle: {				// 	color: '#1789FD',				// 	backgroundColor: '#1E1F31',				// 	border: "8rpx",				// 	width: '180rpx',				// 	height: '54rpx',				// 	margin: "0 0 0 20rpx"				// }			}		},		onLoad() {			this.userId = uni.getStorageSync('userId')			this.nickName = uni.getStorageSync('nickName')		},		onShow() {			this.userDeletaSel = this.$queue.getData('userDeletaSel');			this.yhqxSel = this.$queue.getData("yhqxSel");			let SelectIndex = this.$queue.getData('SelectIndex');			if (SelectIndex) {				this.tabIndex = SelectIndex;				this.$queue.remove('SelectIndex')			}			let token = this.$queue.getData('token');			if (token) {				uni.showLoading({					title: '加载中...'				})				this.getOrderList()			} else {				uni.navigateTo({					url: '/pages/public/login'				});			}		},		methods: {			//获取列表数据			getOrderList() {				let curTab = this.tabs[this.tabIndex].status				let data = {					status: curTab,					page: this.page,					limit: this.limit				}				this.$Request.get('/app/artificer/selectOrdersList', data).then(res => {					if (res.code == 0) {						uni.hideLoading();						console.log(res)						if (this.page == 1) this.goods = []; //如果是第一页需手动制空列表						this.goods = [...this.goods, ...res.data.list]; //追加新数据						// this.goods.forEach(ret => {						// 	switch (ret.status) {						// 		case '1':						// 			ret.statusName = '待付款'						// 			break;						// 		case '2':						// 			ret.statusName = '进行中'						// 			break;						// 		case '3':						// 			ret.statusName = '已评价'						// 			break;						// 		case '4':						// 			ret.statusName = '已取消'						// 			break;						// 		case '5':						// 			ret.statusName = '已完成'						// 			break;						// 	}						// })					}				}).catch(() => {					//联网失败, 结束加载				});			},			// 切换菜单			tabChange(index) {				uni.showLoading({					title: '加载中...'				})				this.tabIndex = index				// this.goods = []; // 置空列表,显示加载进度条				this.page = 1				this.getOrderList()			},			// 取消订单			cancelOrder(e) {				let contentName = '';				let closeKC = this.$queue.getData('closeKC');				if (e.status == 7 || e.status == 8 && closeKC) {					let money = parseFloat(parseFloat(e.price) * parseFloat(closeKC)).toFixed(2);					contentName = '取消订单将扣除' + money + '元的手续费,并且车费将全部扣除!';				}				let that = this				uni.showModal({					title: '温馨提示',					content: '是否确认取消订单?' + contentName,					success: function(res) {						if (res.confirm) {							let data = {								ordersId: e.ordersId							}							that.$queue.showLoading('取消中...')							that.$Request.post('/app/artificer/deleteOrders', data).then(res => {								uni.hideLoading();								if (res.code == 0) {									that.page = 1									that.getOrderList()								} else {									that.$queue.showToast(res.msg);								}							})						} else if (res.cancel) {							console.log('用户点击取消');						}					}				});			},			/*下拉刷新的回调 */			downCallback() {				// 这里加载你想下拉刷新的数据, 比如刷新轮播数据				// loadSwiper();				// 下拉刷新的回调,默认重置上拉加载列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 )				this.mescroll.resetUpScroll()				this.page = 1;				this.getOrderList();			},			// 完成订单			cancel(e) {				let that = this				uni.showModal({					title: '提示',					content: '确认完成订单吗?',					success: function(res) {						if (res.confirm) {							let data = {								ordersId: e.ordersId,							}							that.$queue.showLoading('提交中...')							that.$Request.post('/app/artificer/accomplishOrders', data).then(res => {								uni.hideLoading();								if (res.code == 0) {									that.page = 1									that.getOrderList()								} else {									that.$queue.showToast(res.msg);								}							})						} else if (res.cancel) {							console.log('用户点击取消');						}					}				});			},			//删除			delOrder(e) {				let that = this				uni.showModal({					title: '提示',					content: '确定删除订单吗?',					success: function(res) {						if (res.confirm) {							let data = {								ordersId: e.ordersId,							}							that.$queue.showLoading('删除中...')							that.$Request.post('/app/artificer/removeOrders', data).then(res => {								uni.hideLoading();								if (res.code == 0) {									that.$queue.showToast('删除成功!');									setTimeout(d => {										that.page = 1										that.getOrderList()									}, 1500)								} else {									that.$queue.showToast(res.msg);								}							})						} else if (res.cancel) {							console.log('用户点击取消');						}					}				});			},			goNav(url) {				uni.navigateTo({					url				})			}		},		onReachBottom: function() {			this.page = this.page + 1;			this.getOrderList();			if (this.totalCount == this.orderList.length) {				uni.showToast({					title: '已经到底了~',					icon: 'none'				})			}		},		onPullDownRefresh: function() {			this.page = 1;			this.getOrderList();			setTimeout(d => {				uni.stopPullDownRefresh();			}, 2000)		},	}</script><style lang="scss">	page {		background: #F5F5F5;	}	.theme-color{		color: $uni-color-primary; 	}	/*	sticky生效条件:	1、父元素不能overflow:hidden或者overflow:auto属性。(mescroll-body设置:sticky="true"即可, mescroll-uni本身没有设置overflow)	2、必须指定top、bottom、left、right4个值之一,否则只会处于相对定位	3、父元素的高度不能低于sticky元素的高度	4、sticky元素仅在其父元素内生效,所以父元素必须是 mescroll	*/	.sticky-tabs {		z-index: 990;		position: sticky;		top: var(--window-top);		// background-color: #fff;	}	// 使用mescroll-uni,则top为0	.mescroll-uni,	/deep/.mescroll-uni {		.sticky-tabs {			top: 0;		}	}	.demo-tip {		padding: 18upx;		font-size: 24upx;		text-align: center;	}	page {		background-color: #F7F7F7;	}	.bg {		background-color: #FFFFFF;	}</style>
 |