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.
533 lines
12 KiB
533 lines
12 KiB
<template> |
|
<view style="height: 100vh;display: flex;flex-direction: column;" @click="ejectOpen=false"> |
|
<topBar height="343rpx" title="订单列表"> |
|
<view slot="coment"> |
|
<view class="header_seach"> |
|
<view class="header_seach_seach"> |
|
<view class="seach_input"> |
|
<uni-easyinput :candidate='candidate' :ejectOpen='ejectOpen' @ejectFn='ejectFn' |
|
:letfText='letfText' confirmType='search' @confirm='seachFn' |
|
placeholder-style="color:#bbbbbb;font-weight: 100;" v-model="seachValue" |
|
:placeholder="letfText=='订单号'? '订单编号':letfText=='司机'?'司机姓名,手机号码':letfText=='企业'?'企业名称,企业编号':'油站名称'" |
|
@iconClick="onClick"> |
|
</uni-easyinput> |
|
</view> |
|
</view> |
|
<view class="Navigation"> |
|
<view @tap="seleFn(item);seleindex=index" |
|
:class="seleindex==index?'navigation_seleitem':'navigation_item'" |
|
v-for="(item,index) in navigation"> |
|
{{item.text}} |
|
<uni-icons :animation="animationData" class="icoon" v-if="index==0" type="refreshempty" |
|
style="margin-left: 10rpx;" size="15" color="#bbbbbb"></uni-icons> |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
</topBar> |
|
<view style="flex: 1;overflow: hidden;"> |
|
<scroll-view v-if="listData.length!=0" style="height: 100%;" scroll-y="true" @scrolltolower='scrolltolower'> |
|
<view v-for="(item,index) in listData" class="form_body"> |
|
<view @tap="jump(1,item)" class="form_body_item"> |
|
<view class="form_body_item_top"> |
|
<view :style="{backgroundColor:item.payAccountType==0?'#FD9500':'#2866FF' }" |
|
class="form_body_item_top_label">{{item.payAccountType==0?'个人':'企业'}}</view> |
|
<view>{{item.orderSerialNumber}}</view> |
|
</view> |
|
<view style="padding: 0 25rpx; margin-top: 23rpx;"> |
|
<view class="from_body_item_container"> |
|
<view class="flex between"> |
|
<view class="flex"> |
|
<view>{{item.phone}}</view> |
|
<view class="samll_txext" style="margin-left:23rpx;">{{item.userName}}</view> |
|
</view> |
|
<view style="color: ;" |
|
v-if="item.orderWfStatus==0&& String(item.siteName).indexOf('壳牌')!==-1">待核销 |
|
</view> |
|
</view> |
|
<view style="margin-bottom:23rpx ; font-size: 26rpx;" class="text"> |
|
{{item.companyName?item.companyName:'暂无'}} |
|
</view> |
|
<view class="flex between"> |
|
<view class="flex"> |
|
<view class="samll_txext">{{item.siteName}}</view> |
|
</view> |
|
<view style="color: #999999;" class="bgtext">{{item.volume}}L</view> |
|
</view> |
|
<view class="flex between"> |
|
<view class="flex"> |
|
<view class="samll_txext">{{item.oilsCode}} {{item.realPrice}}/L</view> |
|
</view> |
|
<view class="bgtext">¥{{item.payRealAmount}}</view> |
|
</view> |
|
</view> |
|
</view> |
|
<view class="form_body_item_footer"> |
|
<view style="font-size: 22rpx;" class="samll_txext">{{item.createTime}}</view> |
|
<view :style="{fontSize: '24rpx', color:option(item.orderStatus).color }"> |
|
{{option(item.orderStatus).text}}</view> |
|
</view> |
|
</view> |
|
</view> |
|
</scroll-view> |
|
<view v-if="listData.length==0" |
|
style="width: 100vw; height: 100%; display: flex;align-items: center;justify-content: center;"> |
|
<image src="@/static/qx.png" style="width: 536rpx; height: 399rpx;"></image> |
|
</view> |
|
</view> |
|
</view> |
|
</template> |
|
|
|
<script> |
|
import orderList from '@/api/orderList' |
|
export default { |
|
data() { |
|
return { |
|
animation: null, |
|
animationData: null, |
|
listData: [], |
|
letfText: '订单号', |
|
seleindex: 0, |
|
candidate: ['企业', '司机', '订单号', '油站名称'], |
|
ejectOpen: false, |
|
seachValue: '', |
|
navigation: [{ |
|
text: '全部', |
|
index: '' |
|
}, |
|
{ |
|
text: '待核销', |
|
index: 1 |
|
}, |
|
{ |
|
text: '退款', |
|
index: -1 |
|
} |
|
], |
|
getData: { |
|
pageSize: 15, |
|
currentPage: 1, |
|
params: { |
|
id: '', |
|
companyName: '', |
|
userName: '', |
|
orderStatus: '', |
|
orderWfStatus: '', |
|
siteName: '' |
|
} |
|
}, |
|
} |
|
}, |
|
onShow() { |
|
this.getlist() |
|
}, |
|
onLoad() { |
|
this.rotateFn() |
|
}, |
|
methods: { |
|
jump(e, w) { |
|
switch (e) { |
|
|
|
case 1: |
|
uni.navigateTo({ |
|
url: '../orderDetails/orderDetails?jsData=' + JSON.stringify(w) |
|
}) |
|
break; |
|
} |
|
}, |
|
scrolltolower() { |
|
this.getData.currentPage += 1 |
|
this.getlist() |
|
}, |
|
option(e) { |
|
switch (e) { |
|
case 0: |
|
return { |
|
text: '待支付', |
|
color: '#EBC153' |
|
} |
|
break; |
|
case 1: |
|
return { |
|
text: '已支付', |
|
color: '#17A00E' |
|
} |
|
break; |
|
case -1: |
|
return { |
|
text: '支付失败', |
|
color: '#EC4645' |
|
} |
|
break; |
|
case 2: |
|
return { |
|
text: '已取消', |
|
color: '#999999' |
|
} |
|
break; |
|
case 3: |
|
return { |
|
text: '已退款', |
|
color: '#999999' |
|
} |
|
break; |
|
case 4: |
|
return { |
|
text: '退款中', |
|
color: '#EBC153' |
|
} |
|
// return '退款中' |
|
break; |
|
case 5: |
|
return { |
|
text: '退款失败', |
|
color: '#EC4645' |
|
} |
|
// return '退款失败' |
|
break; |
|
} |
|
}, |
|
animationFns() { |
|
console.log('恢复动画') |
|
var animation = uni.createAnimation({ |
|
duration: 0, |
|
timingFunction: 'ease', |
|
}) |
|
this.animation = animation |
|
this.animation.rotate(0).step() |
|
this.animationData = this.animation.export() |
|
}, |
|
rotateFn() { |
|
var animation = uni.createAnimation({ |
|
duration: 1000, |
|
timingFunction: 'ease', |
|
}) |
|
this.animation = animation |
|
this.animation.rotate(360).step() |
|
this.animationData = this.animation.export() |
|
setTimeout(() => { |
|
this.animationFns() |
|
}, 1000) |
|
}, |
|
getlist(e) { |
|
orderList.getByCustomerPage(this.getData).then(res => { |
|
if (res.code !== 20000) return |
|
if (res.data.list.length == 0) { |
|
uni.showToast({ |
|
title: '没有数据了哦', |
|
icon: 'none' |
|
}) |
|
} |
|
if (this.getData.currentPage !== 1) { |
|
this.listData = this.listData.concat(res.data.list); |
|
return |
|
} |
|
this.listData = res.data.list |
|
}) |
|
}, |
|
seleFn(e) { |
|
this.seleindex = e |
|
this.getData.currentPage = 1 |
|
if (e.index == '') { |
|
// this.getData.params.orderWfStatus = '' |
|
switch (this.getData.params.orderStatus) { |
|
case '': |
|
this.getData.params.orderStatus = 0 |
|
this.navigation[0].text = '待支付' |
|
break; |
|
case 0: |
|
this.getData.params.orderStatus = 1 |
|
this.navigation[0].text = '已支付' |
|
break; |
|
case 1: |
|
this.getData.params.orderStatus = -1 |
|
this.navigation[0].text = '支付失败' |
|
break; |
|
case -1: |
|
this.getData.params.orderStatus = '' |
|
this.navigation[0].text = '全部' |
|
break |
|
case 3: |
|
this.getData.params.orderWfStatus = '' |
|
this.getData.params.orderStatus = '' |
|
this.navigation[0].text = '全部' |
|
break |
|
} |
|
if (this.getData.params.orderWfStatus === 0) { |
|
this.getData.params.orderWfStatus = '' |
|
this.getData.params.orderStatus = '' |
|
this.navigation[0].text = '全部' |
|
} |
|
} |
|
if (e.index == 1) { |
|
this.getData.params.orderStatus = '' |
|
this.getData.params.orderWfStatus = 0 |
|
} |
|
if (e.index == -1) { |
|
this.getData.params.orderWfStatus = null |
|
this.getData.params.orderStatus = 3 |
|
} |
|
this.rotateFn() |
|
console.log(this.getData.params, this.navigation[0].text) |
|
this.getlist() |
|
}, |
|
onClick() { |
|
this.ejectOpen = !this.ejectOpen |
|
console.log('点击图标') |
|
}, |
|
seachFn() { |
|
console.log(this.seachValue) |
|
this.getData.params.userName = '' |
|
this.getData.params.id = '' |
|
this.getData.params.companyName = '' |
|
this.getData.params.siteName = '' |
|
if (this.letfText == '企业') { |
|
this.getData.params.companyName = this.seachValue |
|
console.log('现在是企业 companyName', this.letfText, ) |
|
} else if (this.letfText == '订单号') { |
|
this.getData.params.id = this.seachValue |
|
console.log('现在是订单 id', this.letfText, this.getData.params.id, this.getData.params) |
|
} else if (this.letfText == '司机') { |
|
this.getData.params.userName = this.seachValue |
|
console.log('现在是司机 userName', this.letfText, ) |
|
} else { |
|
this.getData.params.siteName = this.seachValue |
|
console.log('现在是其他 siteName', this.letfText, ) |
|
} |
|
this.getData.currentPage = 1 |
|
this.getlist() |
|
}, |
|
ejectFn(e) { |
|
this.letfText = e |
|
if (this.letfText == '企业') { |
|
|
|
} |
|
console.log(e) |
|
}, |
|
} |
|
} |
|
</script> |
|
|
|
<style> |
|
@import url("./index.css"); |
|
|
|
.icoon :active { |
|
color: #007AFF; |
|
} |
|
|
|
.yuan { |
|
width: 13rpx; |
|
height: 13rpx; |
|
background: #E9CF31; |
|
border-radius: 50%; |
|
margin-right: 5rpx; |
|
} |
|
|
|
.large_text { |
|
font-size: 32rpx; |
|
font-family: PingFang SC; |
|
font-weight: bold; |
|
color: #333333; |
|
} |
|
|
|
.company_msg_content { |
|
max-width: 330rpx; |
|
font-size: 28rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
text-align: end; |
|
} |
|
|
|
.examine_popup_body { |
|
padding: 0 47rpx; |
|
margin: 33rpx 0; |
|
} |
|
|
|
.company_msg { |
|
display: flex; |
|
justify-content: space-between; |
|
align-items: baseline; |
|
} |
|
|
|
.bgtext { |
|
|
|
|
|
font-size: 28rpx; |
|
font-family: PingFang SC; |
|
font-weight: bold; |
|
color: #333333; |
|
|
|
} |
|
|
|
.item_price { |
|
font-size: 24rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
} |
|
|
|
.text { |
|
|
|
font-size: 26rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
} |
|
|
|
.samll_txext { |
|
font-size: 24rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #999999; |
|
display: flex; |
|
align-items: center; |
|
|
|
} |
|
|
|
.leftTip { |
|
position: absolute; |
|
top: 0; |
|
left: 0; |
|
height: 100%; |
|
background-color: #E9CF31; |
|
width: 10rpx; |
|
} |
|
|
|
.seach_input { |
|
background-color: #FFFFFF; |
|
border-radius: 12rpx; |
|
flex: 1; |
|
} |
|
|
|
.typeyuan { |
|
background-color: #17A00E; |
|
width: 14rpx; |
|
height: 14rpx; |
|
border-radius: 50px; |
|
margin-right: 6rpx; |
|
} |
|
|
|
.seletypeyuan { |
|
background-color: red; |
|
width: 14rpx; |
|
height: 14rpx; |
|
border-radius: 50px; |
|
margin-right: 6rpx; |
|
} |
|
|
|
.is-input-border { |
|
border: 0px !important; |
|
} |
|
|
|
page { |
|
background-color: #F0F2FF; |
|
} |
|
|
|
.form_body_item { |
|
min-height: 339rpx; |
|
background: #FFFFFF; |
|
box-shadow: 0px 3px 9px 0px rgba(88, 88, 88, 0.2); |
|
border-radius: 12rpx; |
|
font-size: 28rpx; |
|
/* padding: 20rpx; */ |
|
display: flex; |
|
flex-direction: column; |
|
/* padding-bottom: 0; */ |
|
position: relative; |
|
overflow: hidden; |
|
/* padding-top: 0; */ |
|
} |
|
|
|
.form_body { |
|
width: 100vw; |
|
padding: 0 10px; |
|
margin-top: 40rpx; |
|
box-sizing: border-box; |
|
} |
|
|
|
.navigation_seleitem { |
|
width: 150rpx; |
|
height: 59rpx; |
|
background: #F0F2FF; |
|
border-top-left-radius: 11rpx; |
|
border-top-right-radius: 11rpx; |
|
font-size: 26rpx; |
|
color: #333333; |
|
display: flex; |
|
justify-content: center; |
|
align-items: center; |
|
transition: all 0.3s; |
|
position: relative; |
|
bottom: -2px; |
|
} |
|
|
|
.navigation_item { |
|
width: 150rpx; |
|
height: 59rpx; |
|
border-top-left-radius: 11rpx; |
|
border-top-right-radius: 11rpx; |
|
font-size: 26rpx; |
|
color: #F0F2FF; |
|
display: flex; |
|
justify-content: center; |
|
align-items: center; |
|
transition: all 0.3s; |
|
bottom: -2px; |
|
} |
|
|
|
.Navigation { |
|
display: flex; |
|
position: absolute; |
|
bottom: 0px; |
|
transition: all .5s; |
|
} |
|
|
|
.header_seach_butten { |
|
font-size: 24rpx !important; |
|
display: flex !important; |
|
align-items: center !important; |
|
margin: 0 !important; |
|
flex-shrink: 1; |
|
margin-left: 9rpx !important; |
|
background: #FFFFFF !important; |
|
justify-content: center; |
|
} |
|
|
|
.uni-easyinput__content { |
|
height: 80rpx; |
|
} |
|
|
|
.uni-easyinput { |
|
height: 80rpx; |
|
} |
|
|
|
.header_seach_seach { |
|
display: flex; |
|
height: 80rpx; |
|
margin-top: 23rpx; |
|
} |
|
|
|
.header_seach_title { |
|
display: flex; |
|
align-items: center; |
|
} |
|
|
|
.header_seach { |
|
font-size: 26rpx; |
|
padding: 0 10px; |
|
} |
|
|
|
.uni-navbar--border { |
|
border: 0px !important; |
|
} |
|
|
|
.uni-navbar__header-btns-right { |
|
padding-right: 0 !important; |
|
width: 120rpx !important; |
|
} |
|
|
|
.top { |
|
height: var(--status-bar-height); |
|
} |
|
</style>
|
|
|