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.

498 lines
10 KiB

4 months ago
<template>
<!-- 发票管理模块 -->
<view :style="colorStyle">
<view class="acea-row nav">
<view class="acea-row row-center-wrapper" :class="{ on: nav === 1 }" @click="navTab(1)">发票记录</view>
<view class="acea-row row-center-wrapper" :class="{ on: nav === 2 }" @click="navTab(2)">抬头管理</view>
</view>
<view class="nav-placeholder"></view>
<view v-show="nav === 1" class="record-wrapper">
<view v-for="item in orderList" :key="item.id" class="item">
<view class="item-hd acea-row row-between-wrapper">
<view>订单号{{ item.order.order_id }}</view>
<view class="status">{{ item.is_invoice ? '已开票' : '未开票' }}</view>
</view>
<view class="item-cart acea-row">
<image :src="item.order.cartInfo[0].productInfo.image" class="image"></image>
<view class="text">{{ item.order.cartInfo[0].productInfo.store_name + item.order.cartInfo[0].productInfo.attrInfo.suk || '' }}</view>
</view>
<view class="item-bd acea-row row-middle">
<view class="text">
<view class="">电子{{ item.type == 1 ? '普通' : '专用' }}发票-{{ item.header_type == 1 ? '个人' : '企业' }}</view>
<view class="info">商家退款审核中请您耐心等待</view>
</view>
<BaseMoney :money="item.order.pay_price" symbolSize="20" integerSize="36" decimalSize="20" color="#333333" weight></BaseMoney>
</view>
<view class="item-ft acea-row row-right">
<navigator class="link" :url="`/pages/users/user_invoice_order/index?order_id=${item.order.order_id}`">查看详情</navigator>
</view>
</view>
<view class="px-20 mt-20" v-show="!orderList.length">
<emptyPage title="暂无发票信息" src="/statics/images/noInvoice.gif"></emptyPage>
</view>
</view>
<view v-show="nav === 2">
<view v-if="invoiceList.length" class="list">
<template v-for="item in invoiceList">
<view v-if="item.type === 1 || item.type === 2 && specialInvoice" :key="item.id" class="item">
<view class="item-hd">{{ item.type == 1 ? '普通' : '专用' }}发票抬头-{{ item.header_type == 1 ? '个人' : '企业' }}</view>
<tui-swipe-action :operateWidth="60">
<template v-slot:content>
<view class="item-bd acea-row row-middle">
<view class="item-text">
<view class="name-wrap acea-row row-middle">
<view class="name">{{ item.name }}</view>
<view v-if="item.is_default" class="badge acea-row row-middle">默认</view>
</view>
<view v-if="item.header_type == 1">{{ item.drawer_phone }}</view>
<view v-else>{{ item.duty_number }}</view>
</view>
<view class="edit acea-row row-center-wrapper" @click="editInvoice(item.id)">
<text class="iconfont icon-ic_edit"></text>
</view>
</view>
</template>
<template v-slot:button>
<view class="delete acea-row row-center-wrapper" @click="deleteInvoice(item.id)">删除</view>
</template>
</tui-swipe-action>
</view>
</template>
</view>
<view class="px-20 mt-20" v-show="!invoiceList.length">
<emptyPage title="暂无发票信息" src="/statics/images/noInvoice.gif"></emptyPage>
</view>
<navigator class="add-link" :url="`/pages/users/user_invoice_form/index?specialInvoice=${specialInvoice}`">添加发票抬头</navigator>
</view>
</view>
</template>
<script>
import emptyPage from '@/components/emptyPage.vue';
import {
mapGetters
} from "vuex";
import {
invoiceList,
invoiceDelete,
getUserInfo
} from '@/api/user.js';
import {
orderInvoiceList
} from '@/api/order.js';
import colors from '@/mixins/color.js';
import {
HTTP_REQUEST_URL
} from '@/config/app';
import tuiSwipeAction from '@/components/tui-swipe-action/index.vue';
export default {
components: {
tuiSwipeAction,
emptyPage
},
mixins: [colors],
data() {
return {
orderList: [],
invoiceList: [],
nav: 1, // 1:发票记录 2:抬头管理
page: 1,
limit: 30,
loading: false,
finished: false,
specialInvoice: true,
imgHost: HTTP_REQUEST_URL
};
},
watch: {
nav: {
immediate: true,
handler(value) {
this.page = 1;
switch (value) {
case 1:
this.orderList = [];
this.getOrderList();
break;
case 2:
this.invoiceList = [];
this.getInvoiceList();
break;
}
}
}
},
computed: mapGetters(['isLogin']),
onLoad(option) {
if (option.from === 'invoice_form') {
this.nav = 2;
}
this.getUserInfo();
},
onShow() {
uni.removeStorageSync('form_type_cart');
},
methods: {
getUserInfo() {
getUserInfo().then(res => {
const {
special_invoice
} = res.data;
this.specialInvoice = special_invoice
});
},
// 菜单切换
navTab(nav) {
if (this.nav !== nav) {
this.nav = nav;
}
},
// 记录列表
getOrderList() {
uni.showLoading({
title: '加载中'
});
orderInvoiceList({
page: this.page,
limit: this.limit
}).then(res => {
const {
data
} = res;
uni.hideLoading();
this.orderList = this.orderList.concat(data);
this.finished = data.length < this.limit;
this.page += 1;
}).catch(err => {
uni.showToast({
title: err.msg,
icon: 'none'
});
});
},
// 发票列表
getInvoiceList() {
uni.showLoading({
title: '加载中'
});
invoiceList({
page: this.page,
limit: this.limit
}).then(res => {
const {
data
} = res;
uni.hideLoading();
this.invoiceList = this.invoiceList.concat(data);
this.finished = data.length < this.limit;
this.page += 1;
}).catch(err => {
uni.showToast({
title: err.msg,
icon: 'none'
});
});
},
// 编辑发票
editInvoice(id) {
uni.navigateTo({
url: `/pages/users/user_invoice_form/index?id=${id}`
});
},
// 删除发票
deleteInvoice(id) {
let that = this;
uni.showModal({
content: '删除该发票?',
confirmColor: '#E93323',
success(res) {
if (res.confirm) {
invoiceDelete(id).then(() => {
that.$util.Tips({
title: '删除成功',
icon: 'success'
}, () => {
let index = that.invoiceList.findIndex(value => {
return value.id == id;
});
that.invoiceList.splice(index, 1);
});
}).catch(err => {
return that.$util.Tips({
title: err
});
});
}
}
});
}
}
}
</script>
<style lang="scss" scoped>
.nav {
position: fixed;
top: 0;
left: 0;
z-index: 9;
width: 100%;
height: 90rpx;
// background-color: #FFFFFF;
}
.nav .acea-row {
position: relative;
flex: 1;
font-size: 28rpx;
color: #333333;
&::after {
content: "";
position: absolute;
bottom: 8rpx;
left: 50%;
width: 116rpx;
height: 6rpx;
border-radius: 6rpx;
background-color: transparent;
transform: translateX(-50%);
}
}
.nav .on {
font-weight: 500;
font-size: 30rpx;
color: var(--view-theme);
&::after {
background-color: var(--view-theme);
}
}
.nav-placeholder {
height: 90rpx;
}
.list {
padding: 14rpx 32rpx;
margin-bottom: 140rpx;
}
.list .item {
border-radius: 24rpx;
background-color: #FFFFFF;
overflow: hidden;
}
.list .item~.item {
margin-top: 14rpx;
}
.list .item-hd {
position: relative;
padding: 24rpx;
font-size: 24rpx;
line-height: 34rpx;
color: #333333;
&::after {
content: "";
position: absolute;
right: 24rpx;
bottom: 0;
left: 24rpx;
height: 1px;
background-color: #F5F5F5;
}
}
.list .item-hd .acea-row {
flex: 1;
min-width: 0;
}
.list .item-bd {
padding: 32rpx 24rpx;
}
.list .item-text {
flex: 1;
min-width: 0;
font-size: 24rpx;
line-height: 34rpx;
color: #999999;
}
.list .name-wrap {
display: inline-flex;
max-width: 100%;
margin-bottom: 12rpx;
}
.list .name {
flex: 1;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 500;
font-size: 28rpx;
line-height: 40rpx;
color: #333333;
}
.list .badge {
height: 34rpx;
padding: 0 8rpx;
border-radius: 8rpx;
margin-left: 8rpx;
background-color: #FCEAE9;
font-size: 22rpx;
color: var(--view-theme);
}
.list .edit {
width: 56rpx;
height: 56rpx;
border-radius: 50%;
background-color: #F5F5F5;
.iconfont {
font-size: 32rpx;
color: #333333;
}
}
.list .delete {
width: 120rpx;
height: 100%;
background-color: var(--view-theme);
font-size: 24rpx;
color: #FFFFFF;
}
.list .type.special {
background-color: #FDE9E7;
color: #E93323;
}
.list .cell {
font-size: 26rpx;
color: #666666;
}
.list .cell~.cell {
margin-top: 12rpx;
}
.list .item-ft {
margin-top: 11rpx;
}
.list .btn {
font-size: 26rpx;
color: #282828;
cursor: pointer;
}
.list .btn~.btn {
margin-left: 35rpx;
}
.list .btn .iconfont {
margin-right: 10rpx;
font-size: 24rpx;
color: #000000;
}
.add-link {
position: fixed;
right: 30rpx;
bottom: calc(20rpx + env(safe-area-inset-bottom));
left: 30rpx;
height: 86rpx;
border-radius: 43rpx;
background-color: var(--view-theme);
font-size: 30rpx;
line-height: 86rpx;
text-align: center;
color: #FFFFFF;
.iconfont {
margin-right: 14rpx;
font-size: 28rpx;
}
}
.record-wrapper {
.item {
padding: 32rpx 24rpx;
border-radius: 24rpx;
margin: 20rpx;
background-color: #FFFFFF;
.item-hd {
font-size: 28rpx;
line-height: 40rpx;
color: #333333;
.status {
font-weight: 500;
}
}
.item-cart {
margin-top: 32rpx;
.image {
width: 104rpx;
height: 104rpx;
border-radius: 16rpx;
}
.text {
flex: 1;
padding-left: 20rpx;
font-size: 28rpx;
line-height: 40rpx;
color: #333333;
}
}
.item-bd {
padding: 24rpx;
border-radius: 16rpx;
margin-top: 32rpx;
background-color: #F5F5F5;
font-size: 26rpx;
line-height: 36rpx;
color: #333333;
.text {
flex: 1;
}
.info {
margin-top: 8rpx;
font-size: 24rpx;
line-height: 34rpx;
color: #999999;
}
}
.item-ft {
margin-top: 32rpx;
.link {
height: 56rpx;
padding: 0 24rpx;
border: 1rpx solid #CCCCCC;
border-radius: 56rpx;
font-size: 24rpx;
line-height: 54rpx;
color: #333333;
}
}
}
}
</style>