You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
259 lines
7.6 KiB
259 lines
7.6 KiB
4 months ago
|
<template>
|
||
|
<view class="container" :style="appThemeStyle" style="background: #F8F8F8;">
|
||
|
<mescroll-body ref="mescrollRef" :sticky="true" @init="mescrollInit" :down="{ use: false }" :up="upOption" @up="upCallback">
|
||
|
|
||
|
<!-- tab栏 -->
|
||
|
<u-tabs :list="tabList" :is-scroll="false" :current="curTab" active-color="#786cff" :duration="0.2" @change="onChangeTab" />
|
||
|
<view style="padding: 15rpx 36rpx;">
|
||
|
<u-search bgColor="#fff" placeholder="输入订单编号/收件人名字/电话商品名称" v-model="keyword"></u-search>
|
||
|
</view>
|
||
|
<!-- 列表数据 -->
|
||
|
<view class="widget-list b-f" v-show="list.data.length>0">
|
||
|
<view class="widget__detail" v-for="(item, index) in list.data" :key="index">
|
||
|
<view class="detail__row dis-flex flex-x-between" style="margin-bottom: 18rpx;">
|
||
|
<view class="detail__left f-24">订单号:{{ item.order.order_no }}</view>
|
||
|
<view class="detail__right f-24 c-violet">
|
||
|
{{ item.order.state_text }}
|
||
|
</view>
|
||
|
</view>
|
||
|
|
||
|
<view class="detail__row m-top10 dis-flex flex-x-between" @click="onTargetDetail(goodsItem.goods_id)" v-for="(goodsItem,goodsIndex) in item.goods">
|
||
|
<view class="detail__left dis-flex flex-y-center">
|
||
|
<view class="user-avatar">
|
||
|
<avatar-image :url="goodsItem.goods_image" :width="100" :borderWidth="4" :borderColor="`#fff`" />
|
||
|
</view>
|
||
|
<view class="user-info dis-flex flex-dir-column flex-x-center" style="justify-content: flex-end">
|
||
|
<!-- <view class="user-nickName f-28">
|
||
|
{{ item.user.nick_name }}
|
||
|
</view> -->
|
||
|
<view class="user-time f-24 c-80">x{{ goodsItem.total_num }}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="detail__right dis-flex flex-dir-column flex-x-center flex-y-center">
|
||
|
<view class="detail__money t-r col-m" style="color: #F21A1C;">
|
||
|
<text class="f-26">¥ </text>
|
||
|
<text class="f-28">{{ goodsItem.goods_price }}</text>
|
||
|
</view>
|
||
|
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="dis-flex flex-dir-row flex-x-end flex-y-center">
|
||
|
<view class="detail__time f-22 c-80">
|
||
|
含运费:{{item.order.express_price}}
|
||
|
</view>
|
||
|
<view class="f-28" style="color: #3B3B3B;margin-left: 10rpx;font-weight: 600;">
|
||
|
共计:<text style="color: #F21A1C;">¥{{ item.order.total_price }}</text>
|
||
|
</view>
|
||
|
</view>
|
||
|
|
||
|
<!-- <view class="detail__row m-top10 dis-flex flex-x-between">
|
||
|
<view class="detail__left dis-flex flex-y-center">
|
||
|
<view class="user-avatar">
|
||
|
<avatar-image :url="item.user.avatar_url" :width="100" :borderWidth="4" :borderColor="`#fff`" />
|
||
|
</view>
|
||
|
<view class="user-info dis-flex flex-dir-column flex-x-center">
|
||
|
<view class="user-nickName f-28">{{ item.user.nick_name }}</view>
|
||
|
<view class="user-time f-24 c-80">消费金额:¥{{ item.order_price }}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="detail__right dis-flex flex-dir-column flex-x-center flex-y-center">
|
||
|
<view class="detail__money t-r col-m">
|
||
|
<text class="f-26">+ </text>
|
||
|
<text class="f-28">{{ item.my_money }}</text>
|
||
|
</view>
|
||
|
<view class="detail__time f-22 c-80">{{ item.create_time }}</view>
|
||
|
</view>
|
||
|
</view> -->
|
||
|
</view>
|
||
|
</view>
|
||
|
</mescroll-body>
|
||
|
<addShuiyin />
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import MescrollMixin from '@/uni_modules/mescroll-uni/components/mescroll-uni/mescroll-mixins'
|
||
|
import AvatarImage from '@/components/avatar-image'
|
||
|
import { getEmptyPaginateObj, getMoreListData } from '@/core/app'
|
||
|
import * as Api from '@/api/dealer/order'
|
||
|
import SettingModel from '@/common/model/dealer/Setting'
|
||
|
|
||
|
const pageSize = 15
|
||
|
|
||
|
export default {
|
||
|
components: {
|
||
|
AvatarImage
|
||
|
},
|
||
|
mixins: [MescrollMixin],
|
||
|
data() {
|
||
|
return {
|
||
|
keyword:'',
|
||
|
// 选项卡列表
|
||
|
tabList: [],
|
||
|
// 当前选项
|
||
|
curTab: 0,
|
||
|
// 列表数据
|
||
|
list: getEmptyPaginateObj(),
|
||
|
// 上拉加载配置
|
||
|
upOption: {
|
||
|
// 首次自动执行
|
||
|
auto: true,
|
||
|
// 每页数据的数量; 默认10
|
||
|
page: { size: pageSize },
|
||
|
// 数量要大于12条才显示无更多数据
|
||
|
noMoreSize: 12,
|
||
|
// 空布局
|
||
|
empty: {
|
||
|
tip: '亲,暂无相关数据'
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
|
||
|
/**
|
||
|
* 生命周期函数--监听页面加载
|
||
|
*/
|
||
|
onLoad(options) {
|
||
|
this.getSetting()
|
||
|
},
|
||
|
|
||
|
methods: {
|
||
|
onTargetDetail(goodsId) {
|
||
|
this.$navTo('pages/goods/detail', {
|
||
|
goodsId
|
||
|
})
|
||
|
},
|
||
|
// 获取分销设置
|
||
|
getSetting() {
|
||
|
const app = this
|
||
|
SettingModel.data({keyword:app.keyword})
|
||
|
.then(setting => {
|
||
|
const words = setting.words.order
|
||
|
app.setPageTitle(words.title)
|
||
|
app.setTabList(words.words)
|
||
|
})
|
||
|
},
|
||
|
|
||
|
// 设置页面标题
|
||
|
setPageTitle(title) {
|
||
|
uni.setNavigationBarTitle({
|
||
|
title: title.value
|
||
|
})
|
||
|
},
|
||
|
|
||
|
// 设置选项卡数据
|
||
|
setTabList(words) {
|
||
|
const app = this
|
||
|
app.tabList = [
|
||
|
{ value: -1, name: words.all.value },
|
||
|
{ value: 0, name: words.unsettled.value },
|
||
|
{ value: 1, name: words.settled.value }
|
||
|
]
|
||
|
},
|
||
|
|
||
|
/**
|
||
|
* 上拉加载的回调 (页面初始化时也会执行一次)
|
||
|
* 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10
|
||
|
* @param {Object} page
|
||
|
*/
|
||
|
upCallback(page) {
|
||
|
const app = this
|
||
|
// 设置列表数据
|
||
|
app.getList(page.num)
|
||
|
.then(list => {
|
||
|
const curPageLen = list.data.length
|
||
|
const totalSize = list.data.total
|
||
|
app.mescroll.endBySize(curPageLen, totalSize)
|
||
|
})
|
||
|
.catch(() => app.mescroll.endErr())
|
||
|
},
|
||
|
|
||
|
// 获取提现列表
|
||
|
getList(pageNo = 1) {
|
||
|
const app = this
|
||
|
return new Promise((resolve, reject) => {
|
||
|
Api.list({ settled: app.getTabValue(), page: pageNo })
|
||
|
.then(result => {
|
||
|
// 合并新数据
|
||
|
const newList = result.data.list
|
||
|
app.list.data = getMoreListData(newList, app.list, pageNo)
|
||
|
resolve(newList)
|
||
|
})
|
||
|
})
|
||
|
},
|
||
|
|
||
|
// 获取当前标签项的值
|
||
|
getTabValue() {
|
||
|
const app = this
|
||
|
if (app.tabList.length) {
|
||
|
return app.tabList[app.curTab].value
|
||
|
}
|
||
|
return -1
|
||
|
},
|
||
|
|
||
|
// 切换标签项
|
||
|
onChangeTab(index) {
|
||
|
const app = this
|
||
|
// 设置当前选中的标签
|
||
|
app.curTab = index
|
||
|
// 刷新订单列表
|
||
|
app.onRefreshList()
|
||
|
},
|
||
|
|
||
|
// 刷新列表数据
|
||
|
onRefreshList() {
|
||
|
this.list = getEmptyPaginateObj()
|
||
|
setTimeout(() => {
|
||
|
this.mescroll.resetUpScroll()
|
||
|
}, 120)
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style>
|
||
|
page {
|
||
|
background: #fff;
|
||
|
}
|
||
|
</style>
|
||
|
<style lang="scss" scoped>
|
||
|
.c-violet {
|
||
|
// color: #786cff;
|
||
|
color:#FF6813;
|
||
|
}
|
||
|
|
||
|
.c-80 {
|
||
|
color: #808080;
|
||
|
}
|
||
|
|
||
|
// 订单列表
|
||
|
.widget-list {
|
||
|
padding: 10rpx 20rpx 40rpx 20rpx;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
.widget__detail {
|
||
|
padding: 20rpx 15rpx;
|
||
|
box-sizing: border-box;
|
||
|
font-size: 28rpx;
|
||
|
border-bottom: 1rpx solid #e7e7e7;
|
||
|
|
||
|
.user-avatar {
|
||
|
margin-right: 16rpx;
|
||
|
}
|
||
|
|
||
|
.user-info {
|
||
|
height: 100%;
|
||
|
|
||
|
.user-nickName {
|
||
|
margin-bottom: 8rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.detail__money {
|
||
|
width: 100%;
|
||
|
margin-bottom: 8rpx;
|
||
|
}
|
||
|
}
|
||
|
</style>
|