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.
485 lines
11 KiB
485 lines
11 KiB
<template>
|
|
<view>
|
|
<!-- 购买商品列表 -->
|
|
<view class="buy-list">
|
|
<view class="list_top">
|
|
<view class="tip">请选择需要退款的商品</view>
|
|
<view class="checkbox-box" @tap="allSelect">
|
|
<view class="checkbox">
|
|
<view :class="[isAllselected?'on':'']"></view>
|
|
</view>
|
|
<view class="text">全选</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="row" v-for="(row,index) in buylist" :key="index">
|
|
<view class="goods-info">
|
|
<view class="img">
|
|
<image :src="row.img"></image>
|
|
</view>
|
|
<view class="info">
|
|
<view class="title">{{row.mc}}{{row.dw}}</view>
|
|
<view>
|
|
<view class="spec">{{row.gg}} <text style="color: red;">单价:¥{{row.price}}</text></view>
|
|
<view class="foodnum">可退数量:{{row.dinghl}}</view>
|
|
</view>
|
|
<view class="price-number">
|
|
<view class="price">¥{{row.price*row.dinghl|toFixeds}}</view>
|
|
<view class="number">
|
|
退款数
|
|
<view class="input">
|
|
<input type="digit" :disabled="!row.selected" v-model="row.selected==false?'':row.tuiksl" @input="inputchange($event,row.id,index,row.tuiksl,row.price)" />
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="checkbox-box" @tap="selected(index)" >
|
|
<view class="checkbox">
|
|
<view :class="[row.selected?'on':'']"></view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!-- 提示-备注 -->
|
|
<view class="order">
|
|
<view class="row">
|
|
<view class="left">
|
|
退款说明 :
|
|
</view>
|
|
<view class="right">
|
|
<input placeholder="选填,退款备注" v-model="note" />
|
|
</view>
|
|
</view>
|
|
<view class="row">
|
|
<view class="left">
|
|
申请金额 :
|
|
</view>
|
|
<view class="right">
|
|
<input placeholder="申请退款金额" v-model="sqmoney" />
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<!-- 明细 -->
|
|
<view class="detail">
|
|
<view class="row">
|
|
<view class="nominal">
|
|
商品金额
|
|
</view>
|
|
<view class="content">
|
|
¥{{goodsPrice|toFixeds}}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class="blck"></view>
|
|
<view class="footer">
|
|
<view class="settlement">
|
|
<view class="btn" @tap="tosq">提交申请</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
export default {
|
|
data() {
|
|
return {
|
|
buylist:[], //订单列表
|
|
goodsPrice:0, //商品合计价格
|
|
note:'', //备注
|
|
dhid:0,
|
|
sqmoney:0,
|
|
index:0,
|
|
isAllselected:false,
|
|
selectedList:[],
|
|
gids:'',//退款产品的id
|
|
tktype:0,
|
|
tuiksls:'',//退款产品的数量
|
|
};
|
|
},
|
|
onLoad(option) {
|
|
//option为object类型,会序列化上个页面传递的参数
|
|
this.dhid = parseInt(option.dhid);
|
|
this.tktype=option.tktype
|
|
this.index=parseInt(option.index);//当前订单状态
|
|
},
|
|
onShow() {
|
|
//页面显示时,加载订单信息
|
|
this.orderdetail(this.dhid)
|
|
},
|
|
onHide() {
|
|
|
|
},
|
|
filters: {
|
|
toFixeds:function(x) {
|
|
return parseFloat(x).toFixed(2);
|
|
}
|
|
},
|
|
methods: {
|
|
//修改退款数量
|
|
inputchange(even,id,index,tuiksl,dj)
|
|
{
|
|
let inputnum=parseFloat(even.detail.value);
|
|
if(inputnum>this.buylist[index].dinghl)
|
|
{
|
|
inputnum=this.buylist[index].dinghl;
|
|
}else if(inputnum>0){
|
|
inputnum=inputnum;
|
|
}else{
|
|
inputnum='';
|
|
}
|
|
this.buylist[index].tuiksl=inputnum;
|
|
this.sum();
|
|
},
|
|
async orderdetail(id){
|
|
let redata=await this.$api.orderdetail({action:'ordertuikdetail',dhid:id});
|
|
if(redata.code==1){
|
|
this.buylist = redata.data;
|
|
let len = redata.data.length;
|
|
let allmoney=0;
|
|
for(let i=0;i<len;i++){
|
|
this.buylist[i].selected=false;
|
|
allmoney=(Number(allmoney) + Number(this.buylist[i].je))
|
|
}
|
|
this.goodsPrice=allmoney
|
|
}else{
|
|
uni.showToast({
|
|
title:'暂无数据',icon:'none'
|
|
})
|
|
}
|
|
},
|
|
async sqtuik(dhid) {
|
|
let userinfo=uni.getStorageSync('userinfo');
|
|
let reinfo=await this.$api.sqtuik({action:'sqtuik',uid:userinfo.uid,aid:userinfo.aid,
|
|
dhid:dhid,bz:this.note,sqmoney:this.sqmoney,gids:this.gids,isAllselected:this.isAllselected,tktype:this.tktype,tuiksls:this.tuiksls});
|
|
if(reinfo.code==1){
|
|
uni.showToast({
|
|
title:reinfo.msg,icon:'none'
|
|
})
|
|
uni.redirectTo({
|
|
url:"/pages/orderlist/orderlist?state="+this.index
|
|
})
|
|
}else{
|
|
uni.showToast({
|
|
title:reinfo.msg,icon:'none'
|
|
})
|
|
}
|
|
uni.hideLoading();
|
|
|
|
},
|
|
tosq(){
|
|
let t=this;
|
|
// console.log(Number((parseFloat(this.sqmoney*100)/100).toFixed(2))+'---'+Number((parseFloat(this.goodsPrice*100)/100).toFixed(2)))
|
|
//this.sqmoney=parseInt(this.sqmoney).toFixed(2)
|
|
if(Number((parseFloat(this.sqmoney*100)/100).toFixed(2))>Number((parseFloat(this.goodsPrice*100)/100).toFixed(2))){
|
|
uni.showToast({
|
|
title:'申请金额:'+Number((parseFloat(this.sqmoney*100)/100).toFixed(2))+',最多申请'+Number((parseFloat(this.goodsPrice*100)/100).toFixed(2))+'元',icon:'none'
|
|
})
|
|
return false;
|
|
}else if(this.sqmoney<=0){
|
|
uni.showToast({
|
|
title:'请填申请金额',icon:'none'
|
|
})
|
|
return false;
|
|
}else if(this.gids==''){
|
|
uni.showToast({
|
|
title:'请选择商品',icon:'none'
|
|
})
|
|
return false;
|
|
}else if(this.tuiksls==''){
|
|
uni.showToast({
|
|
title:'请选择退款数量',icon:'none'
|
|
})
|
|
return false;
|
|
}
|
|
uni.showModal({
|
|
title: '温馨提示',
|
|
content: '是否申请退款'+t.sqmoney+'元?',
|
|
success: function (res) {
|
|
if (res.confirm) {
|
|
uni.showLoading({
|
|
title:'正在申请...'
|
|
})
|
|
t.sqtuik(t.dhid)
|
|
} else if (res.cancel) {
|
|
console.log(t.gids,'用户点击取消');
|
|
}
|
|
}
|
|
});
|
|
|
|
},
|
|
// 选中商品
|
|
selected(index){
|
|
this.buylist[index].selected = this.buylist[index].selected?false:true;
|
|
let i = this.selectedList.indexOf(this.buylist[index].id);
|
|
i>-1?this.selectedList.splice(i, 1):this.selectedList.push(this.buylist[index].id);
|
|
this.isAllselected = this.selectedList.length == this.buylist.length;
|
|
this.sum();
|
|
},
|
|
//全选
|
|
allSelect(){
|
|
let len = this.buylist.length;
|
|
let arr = [];
|
|
for(let i=0;i<len;i++){
|
|
this.buylist[i].selected = this.isAllselected? false : true;
|
|
arr.push(this.buylist[i].id);
|
|
}
|
|
this.selectedList = this.isAllselected?[]:arr;
|
|
this.isAllselected = this.isAllselected||this.buylist.length==0?false : true;
|
|
this.sum();
|
|
},
|
|
// 合计
|
|
sum(){
|
|
this.sqmoney=0;
|
|
let len = this.buylist.length;
|
|
let gids='';let cpsl='';
|
|
for(let i=0;i<len;i++){
|
|
let tuiksl=this.buylist[i].tuiksl==''?0:this.buylist[i].tuiksl;
|
|
tuiksl=tuiksl==NaN?0:tuiksl;
|
|
if(this.buylist[i].selected && tuiksl>0) {
|
|
|
|
this.sqmoney=parseFloat(this.sqmoney*100)/100+parseFloat((this.buylist[i].price*tuiksl)*100)/100;
|
|
gids+=','+this.buylist[i].id;
|
|
cpsl+=','+tuiksl;
|
|
}
|
|
}
|
|
this.sqmoney=parseFloat(this.sqmoney).toFixed(2)
|
|
gids=gids.substr(1);
|
|
this.gids=gids;
|
|
|
|
this.tuiksls=cpsl.substr(1);
|
|
},
|
|
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
.buy-list{
|
|
width: 86%;
|
|
padding: 10upx 3%;
|
|
margin: 30upx auto 20upx auto;
|
|
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
|
|
border-radius: 20upx;
|
|
.list_top{
|
|
display: flex;
|
|
justify-content: space-between;
|
|
padding: 10upx;
|
|
.tip{
|
|
color: #A2A2A2;
|
|
font-size: 30upx;
|
|
}
|
|
}
|
|
// 选择框样式
|
|
.checkbox-box{
|
|
display: flex;
|
|
align-items: center;
|
|
.checkbox{
|
|
width: 35upx;
|
|
height: 35upx;
|
|
border-radius: 100%;
|
|
border: solid 2upx #f06c7a;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
.on{
|
|
width: 25upx;
|
|
height: 25upx;
|
|
border-radius: 100%;
|
|
background-color: #f06c7a;
|
|
}
|
|
}
|
|
.text{
|
|
font-size: 28upx;
|
|
margin-left: 10upx;
|
|
}
|
|
}
|
|
.row{
|
|
margin: 30upx 0;
|
|
|
|
.goods-info{
|
|
width: 100%;
|
|
display: flex;
|
|
border-bottom: 1upx solid #E0E0E0;
|
|
padding-bottom: 15upx;
|
|
.img{
|
|
width: 22vw;
|
|
height: 22vw;
|
|
border-radius: 10upx;
|
|
overflow: hidden;
|
|
flex-shrink: 0;
|
|
margin-right: 10upx;
|
|
image{
|
|
width: 22vw;
|
|
height: 22vw;
|
|
}
|
|
}
|
|
.info{
|
|
width: 100%;
|
|
height: 22vw;
|
|
overflow: hidden;
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
position: relative;
|
|
.title{
|
|
width: 100%;
|
|
font-size: 28upx;
|
|
display: -webkit-box;
|
|
-webkit-box-orient: vertical;
|
|
-webkit-line-clamp: 2;
|
|
// text-align: justify;
|
|
overflow: hidden;
|
|
}
|
|
.spec{
|
|
font-size: 22upx;
|
|
background-color: #f3f3f3;
|
|
color: #a7a7a7;
|
|
height: 40upx;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 10upx;
|
|
border-radius: 20upx;
|
|
// margin-bottom: 20vw;
|
|
margin-top: 10vm;
|
|
}
|
|
.foodnum{
|
|
font-size: 26upx;
|
|
height: 40upx;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 10upx;
|
|
margin-bottom: 10vw;
|
|
display: block;
|
|
color: #999;
|
|
padding-top: 10rpx;
|
|
}
|
|
.price-number{
|
|
position: absolute;
|
|
width: 100%;
|
|
bottom: 0upx;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: flex-end;
|
|
font-size: 28upx;
|
|
height: 40upx;
|
|
.price{
|
|
color: #f06c7a;
|
|
}
|
|
.number{
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
|
|
}
|
|
}
|
|
.input {
|
|
width: 100upx;
|
|
height: 45upx;
|
|
margin: 0 10upx;
|
|
// background-color: #f3f3f3;
|
|
border-bottom: 1upx #ADADAD solid;
|
|
|
|
input {
|
|
width: 80upx;
|
|
height: 40upx;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
text-align: center;
|
|
font-size: 26upx;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.order{
|
|
width: 86%;
|
|
padding: 10upx 3%;
|
|
margin: 30upx auto 20upx auto;
|
|
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
|
|
border-radius: 20upx;
|
|
.row{
|
|
margin: 20upx 0;
|
|
height: 40upx;
|
|
display: flex;
|
|
.left{
|
|
font-size: 28upx;
|
|
}
|
|
.right{
|
|
margin-left: 40upx;
|
|
font-size: 26upx;
|
|
color: #999;
|
|
input{
|
|
font-size: 26upx;
|
|
color: #999;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.blck{
|
|
width: 100%;
|
|
height: 100upx;
|
|
}
|
|
.footer{
|
|
width: 100%;
|
|
padding: 0 4%;
|
|
background-color: #fbfbfb;
|
|
height: 100upx;
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
align-items: center;
|
|
font-size: 28upx;
|
|
position: fixed;
|
|
bottom: 0upx;
|
|
z-index: 5;
|
|
|
|
.settlement{
|
|
width: 80%;
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
align-items: center;
|
|
.sum{
|
|
width: 50%;
|
|
font-size: 28upx;
|
|
margin-right: 10upx;
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
.money{
|
|
font-weight: 600;
|
|
}
|
|
}
|
|
.btn{
|
|
padding: 0 30upx;
|
|
height: 60upx;
|
|
background-color: #f06c7a;
|
|
color: #fff;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
font-size: 30upx;
|
|
border-radius: 40upx;
|
|
}
|
|
}
|
|
}
|
|
.detail{
|
|
width: 86%;
|
|
padding: 10upx 3%;
|
|
margin: 30upx auto 20upx auto;
|
|
box-shadow: 0upx 5upx 20upx rgba(0,0,0,0.1);
|
|
border-radius: 20upx;
|
|
.row{
|
|
height: 60upx;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
.nominal{
|
|
font-size: 28upx;
|
|
}
|
|
.content{
|
|
font-size: 26upx;
|
|
color: #f06c7a;
|
|
}
|
|
}
|
|
}
|
|
</style>
|