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.
700 lines
17 KiB
700 lines
17 KiB
<template> |
|
<view @click="ejectOpen=false" style="height: 100vh;display: flex;flex-direction: column;"> |
|
<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=='创建人'?'姓名/手机号':'油站名/油站ID'" |
|
@iconClick="onClick"> |
|
</uni-easyinput> |
|
</view> |
|
<button @tap='jump(2)' class="header_seach_butten"> |
|
<uni-icons type="plusempty" size="20" color="#bbbbbb"></uni-icons> |
|
<view>新增</view> |
|
</button> |
|
</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 :refresher-triggered='isShow.refresherTriggered' @refresherrefresh='refresherrefresh' :refresher-enabled='true' v-if="listData.length!=0" style="height: 100%;" scroll-y="true" @scrolltolower='scrolltolower'> |
|
<listItem @tap='isfn(item)' :item="item" v-for="(item,index) in listData" ></listItem> |
|
<!-- <view v-for="(item,index) in listData" class="form_body"> |
|
<view @tap="jump(1,item)" class="form_body_item"> |
|
<view v-if="item.auditMark==0" class="leftTip"></view> |
|
<view class="form_body_item_body"> |
|
<view class="form_body_item_body_header"> |
|
<view class="samll_txext"> |
|
<image style="width: 28rpx; height: 29rpx; margin-right: 4rpx;" |
|
src="@/static/fygs.png"></image> |
|
分油公司 |
|
</view> |
|
<view class="samll_txext"> |
|
<image v-if="item.disTagType=='SUBCOMPANY'" |
|
style="width: 28rpx; height: 29rpx;margin-right: 4rpx;" src="@/static/fygs.png"> |
|
</image> |
|
<image v-if="item.disTagType!='SUBCOMPANY'" |
|
style="width: 28rpx; height: 29rpx;margin-right: 4rpx;" src="@/static/jsf.png"> |
|
</image> |
|
接收方 |
|
</view> |
|
</view> |
|
<view class="form_body_item_body_content" style=""> |
|
<view class=".form_body_item_body_content_left" style=""> |
|
{{item.disCompanyName}} |
|
</view> |
|
<view style="text-align: center;flex: 1;"> |
|
<image v-if="item.disType==1" class="form_body_item_img" style="" |
|
src="@/static/fy.png"></image> |
|
<image v-if="item.disType==-1" class="form_body_item_img" style="" |
|
src="@/static/qh.png"></image> |
|
<view class="item_price" style="font-size: 24rpx;">{{item.disAmount}}元</view> |
|
</view> |
|
<view class="form_body_item_body_content_right" style=""> |
|
<text>{{ item.disTagType=='SUBCOMPANY'?item.companyName?item.companyName:'未设置':item.nickName?item.nickName:'未设置'}}</text> |
|
<view class="compay_tip"> |
|
{{item.disTagType=='ESELF_SUPPORT'?'自营司机':item.disTagType=='OUTSIDE'?'外请司机':'子公司'}} |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
<view class="form_body_item_footer"> |
|
<view>{{item.id}}</view> |
|
<view style="display: flex; align-items: center; "> |
|
<view |
|
:style="{background:item.auditMark==0?'#E9CF31':item.auditMark==1?'#17A00E':'#EC4645'}" |
|
class="yuan"></view> |
|
{{item.auditMark==0?'待审核':item.auditMark==1?'审核成功':'审核失败'}} |
|
</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> |
|
<popup :butten='butten' @confirmFn='confirmFn' @closeFn='closeFn' :show="modifyShow" v-model="isShow.examine"> |
|
<view slot="coment"> |
|
<detailse :details='details'></detailse> |
|
</view> |
|
</popup> |
|
</view> |
|
</template> |
|
|
|
<script> |
|
import priceAdjustmentTask from '@/api/priceAdjustmentTask' |
|
import oilDistribution from '@/api/oilDistribution' |
|
import topBar from '@/components/topbar' |
|
import popup from '@/components/customPopup' |
|
import listItem from '../components/listItem' |
|
import detailse from '../components/details' |
|
export default { |
|
components: { |
|
topBar, |
|
popup, |
|
listItem, |
|
detailse |
|
}, |
|
data() { |
|
return { |
|
butten: { |
|
colse: '撤回', |
|
confirm: '返回', |
|
coloseBg: '#EC4645', |
|
coloseColor: '#FFFFFF', |
|
confirmBg: '', |
|
confirmColor: '' |
|
}, |
|
details:{}, |
|
modifyShow: { |
|
img: false, |
|
footer: true |
|
}, |
|
animationData: null, |
|
seledata: {}, |
|
seachValue: '', |
|
isShow: { |
|
examine: false, |
|
refresherTriggered:false |
|
}, |
|
companyName: '', |
|
ejectOpen: false, |
|
letfText: '油站', |
|
candidate: ['油站', '创建人'], |
|
getData: { |
|
pageSize: 15, |
|
currentPage: 1, |
|
params: { |
|
siteParam: '',//油站筛选条件 |
|
taskExecutStatus: '',//执行状态 |
|
createParam: '',//创建人筛选条件 |
|
effectiveMode: '',// 即时 - 预约 |
|
} |
|
}, |
|
styles: {}, |
|
seleindex: 0, |
|
navigation: [{ |
|
text: '全部', |
|
index: '' |
|
}, |
|
{ |
|
text: '待执行', |
|
index: 0 |
|
}, |
|
{ |
|
text: '已执行', |
|
index: 1 |
|
} |
|
], |
|
listData: [] |
|
} |
|
}, |
|
onPullDownRefresh() { |
|
//下拉的生命周期 |
|
this.getData.currentPage = 1 |
|
this.getList() |
|
console.log('下拉的生命周期') |
|
}, |
|
onLoad() { |
|
let that = this |
|
this.styles = uni.getMenuButtonBoundingClientRect() |
|
uni.$on('company', function(e) { |
|
let routes = getCurrentPages(); |
|
let routerIndex = routes[(routes.length - 2)].$page.fullPath.indexOf('?') != -1 ? |
|
routes[(routes.length - 2)].$page.fullPath.split('?')[0].split('/')[routes[(routes.length - 2)] |
|
.$page.fullPath.split('?')[0].split('/').length - 1] : |
|
routes[(routes.length - 2)].$page.fullPath.split('/')[routes[(routes.length - 2)].$page |
|
.fullPath.split('/').length - 1] |
|
console.log(routes, routerIndex, '获取当前打开过的页面路由数组') |
|
// if (routerIndex !== 'index') return |
|
// if (e) { |
|
// ({ |
|
// id: that.getData.params.companyId, |
|
// name: that.companyName |
|
// } = e); |
|
// console.log(that.getData) |
|
// } else { |
|
// that.getData.params.companyId = '' |
|
// that.companyName = '' |
|
// } |
|
}) |
|
}, |
|
onShow() { |
|
this.getList(); |
|
}, |
|
methods: { |
|
refresherrefresh(e){ |
|
this.getData.currentPage = 1 |
|
this.isShow.refresherTriggered = true |
|
this.getList() |
|
}, |
|
isfn(item){ |
|
this.details=item; |
|
this.butten.coloseBg = Number(this.details.taskExecutStatus) !== 0? '#bbbbbb':'#EC4645' |
|
this.$nextTick(function(){ |
|
this.isShow.examine=true; |
|
}) |
|
}, |
|
closeFn(){ |
|
let that = this |
|
if( Number(this.details.taskExecutStatus) !== 0) return ; |
|
uni.showModal({ |
|
title:'撤回', |
|
content:'是否撤销该调价任务?', |
|
success: function (res) { |
|
if (res.confirm) { |
|
priceAdjustmentTask.thePriceAdjustmentTaskIsWithdrawn(that.details.adjustTaskId).then(res=>{ |
|
if(res.code!==20000) return |
|
that.isShow.examine = false; |
|
// that.getList(); |
|
that.listData.forEach((item,index)=>{ |
|
if(item.adjustTaskId==that.details.adjustTaskId){ |
|
// that.listData.splice(index,1); |
|
item.taskExecutStatus = -2; |
|
} |
|
}) |
|
}) |
|
} else if (res.cancel) { |
|
console.log('用户点击取消'); |
|
} |
|
} |
|
|
|
}) |
|
console.log('关闭') |
|
}, |
|
confirmFn(){ |
|
this.isShow.examine = false |
|
console.log('确定') |
|
}, |
|
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) |
|
}, |
|
// confirmFn() { |
|
// let data = { |
|
// id: this.seledata.id, |
|
// auditMark: 1, |
|
// auditSource: 'OMS-MINIAPP' |
|
// } |
|
// oilDistribution.auditOms(data).then(res => { |
|
// if (res.code !== 20000) return |
|
// uni.showToast({ |
|
// title: '审核成功', |
|
// icon: 'none' |
|
// }) |
|
// this.iShow.examine = false |
|
// this.seledata.auditMark = 1 |
|
// }) |
|
// console.log('确定回掉') |
|
// }, |
|
// closeFn() { |
|
// let data = { |
|
// id: this.seledata.id, |
|
// auditMark: -1, |
|
// auditSource: 'OMS-MINIAPP' |
|
// } |
|
// oilDistribution.auditOms(data).then(res => { |
|
// if (res.code !== 20000) return |
|
// uni.showToast({ |
|
// title: '审核成功', |
|
// icon: 'none' |
|
// }) |
|
// this.iShow.examine = false |
|
// this.seledata.auditMark = -1 |
|
// }) |
|
// console.log('失败回调') |
|
// }, |
|
ejectFn(e) { |
|
this.letfText = e |
|
console.log(e,'----') |
|
}, |
|
scrolltolower() { |
|
this.getData.currentPage += 1 |
|
console.log('触底了') |
|
this.getList() |
|
}, |
|
seachFn() { |
|
if (this.letfText == '油站') { |
|
this.getData.params.createParam = '' |
|
this.getData.params.siteParam = this.seachValue |
|
} else { |
|
this.getData.params.createParam = this.seachValue |
|
this.getData.params.siteParam = '' |
|
} |
|
this.getData.currentPage = 1 |
|
this.getList() |
|
}, |
|
getList() { |
|
priceAdjustmentTask.queryThePriceAdjustmentTaskList(this.getData).then(res => { |
|
this.isShow.refresherTriggered = false |
|
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 |
|
}) |
|
}, |
|
jump(e, item) { |
|
switch (e) { |
|
case -1: |
|
uni.navigateBack() |
|
break; |
|
case 0: |
|
uni.navigateTo({ |
|
url: "../company/company?jsData=" + JSON.stringify(this.companyName) |
|
}) |
|
break; |
|
case 1: |
|
if (item.auditMark == 0) { |
|
this.seledata = item |
|
this.iShow.examine = true |
|
} |
|
break; |
|
case 2: |
|
uni.navigateTo({ |
|
url:'../addTask/addTask' |
|
}) |
|
break; |
|
} |
|
}, |
|
seleFn(e) { |
|
this.getData.currentPage = 1; |
|
if(e.index===''){ |
|
this.getData.params.effectiveMode = this.getData.params.taskExecutStatus===''?this.getData.params.effectiveMode===''?0:this.getData.params.effectiveMode===1?'':1:''; |
|
this.getData.params.taskExecutStatus = '' |
|
}else{ |
|
this.getData.params.taskExecutStatus = e.index; |
|
this.getData.params.effectiveMode = ''; |
|
} |
|
this.navigation[0].text = this.getData.params.effectiveMode===''?'全部':this.getData.params.effectiveMode===0?'即时':'预约'; |
|
this.rotateFn() |
|
// console.log(this.getData.params.effectiveMode,'**********') |
|
// if (e.index == '') { |
|
// switch (this.getData.params.auditMark) { |
|
// case 2: |
|
// this.getData.params.auditMark = 0 |
|
// this.navigation[0].text = '等待' |
|
// break; |
|
// case 0: |
|
// this.getData.params.auditMark = 1 |
|
// this.navigation[0].text = '成功' |
|
// break; |
|
// case 1: |
|
// this.getData.params.auditMark = -1 |
|
// this.navigation[0].text = '失败' |
|
// break |
|
// case -1: |
|
// this.getData.params.auditMark = 2 |
|
// this.navigation[0].text = '全部' |
|
// break; |
|
// } |
|
// if (this.getData.params.disType !== '') { |
|
// this.getData.params.disType = '' |
|
// this.getData.params.auditMark = 2 |
|
// this.navigation[0].text = '全部' |
|
// } |
|
// this.rotateFn() |
|
// } else { |
|
// this.getData.params.auditMark = 2 |
|
// this.navigation[0].text = '全部' |
|
// this.getData.params.disType = e.index |
|
// } |
|
this.getList() |
|
}, |
|
onClick() { |
|
this.ejectOpen = !this.ejectOpen |
|
console.log('点击图标事件') |
|
} |
|
} |
|
} |
|
</script> |
|
|
|
<style> |
|
.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; |
|
} |
|
|
|
.item_price { |
|
font-size: 24rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
} |
|
|
|
.form_body_item_body_content_right { |
|
/* max-width: 215rpx; */ |
|
text-align: -webkit-right; |
|
font-size: 26rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
flex: 1; |
|
} |
|
|
|
.form_body_item_body_content_left { |
|
/* max-width: 215rpx; */ |
|
text-align: left; |
|
font-size: 26rpx; |
|
font-family: PingFang SC; |
|
font-weight: 500; |
|
color: #333333; |
|
flex: 1; |
|
} |
|
|
|
.form_body_item_img { |
|
width: 80rpx; |
|
height: 70rpx; |
|
} |
|
|
|
.form_body_item_body_content { |
|
display: flex; |
|
justify-content: space-between; |
|
width: 100%; |
|
margin-top: 15rpx; |
|
padding-bottom: 14rpx; |
|
} |
|
|
|
.form_body_item_body_header { |
|
display: flex; |
|
justify-content: space-between; |
|
width: 100%; |
|
} |
|
|
|
.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; |
|
} |
|
|
|
.compay_tip { |
|
/* width: 94rpx; */ |
|
/* height: 36rpx; */ |
|
background: #F1F1F1; |
|
margin-top: 18rpx; |
|
color: #BBBBBB; |
|
display: flex; |
|
align-items: center; |
|
justify-content: center; |
|
font-size: 24rpx; |
|
/* margin-bottom: 14rpx; */ |
|
width: 130rpx; |
|
padding: 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_footer { |
|
display: flex; |
|
color: #BBBBBB; |
|
font-size: 22rpx; |
|
justify-content: space-between; |
|
/* margin-top: 15rpx; */ |
|
align-items: center; |
|
flex: 1; |
|
padding: 26rpx 0; |
|
} |
|
|
|
.form_body_item_body { |
|
display: flex; |
|
border-bottom: 1rpx solid #F0F0F0; |
|
/* padding-bottom: 14rpx; */ |
|
flex-wrap: wrap; |
|
} |
|
|
|
.form_body_item { |
|
min-height: 267rpx; |
|
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; |
|
} |
|
|
|
.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; |
|
} |
|
|
|
/* .header { |
|
background-color: #007AFF; |
|
color: white; |
|
min-height: 403rpx; |
|
background-image: url('https://xoi-support.oss-cn-hangzhou.aliyuncs.com/星油admin小程序/sjbj.png'); |
|
background-size: 100% 100%; |
|
position: relative; |
|
} */ |
|
|
|
.uni-navbar__header-btns-right { |
|
padding-right: 0 !important; |
|
width: 120rpx !important; |
|
} |
|
|
|
.top { |
|
height: var(--status-bar-height); |
|
} |
|
</style>
|
|
|