添加:用户兑换额度持有信息&用户兑换额度变更记录信息列表查看

This commit is contained in:
wuhui_zzw 2024-01-11 10:32:47 +08:00
parent 8a041093f9
commit 8a9ac0d564
4 changed files with 588 additions and 316 deletions

View File

@ -715,13 +715,30 @@ export function integralOrderDeleteApi(id) {
export function holdIntegralList(data) {
return request.get(`user/integral/hold_list`, data)
}
// 持有积分 - 列表
// 持有积分 - 统计
export function holdIntegralTitleApi(data) {
return request.get(`user/integral/hold_list_title`, data)
}
// 赠送积分 - 列表
export function giveIntegralList(data) {
return request.get(`user/integral/give_list`, data)
}
// 兑换额度 - 顶部统计
export function exchangeQuotaTitle() {
return request.get(`user/exchange_quota/quota_title`)
}
// 兑换额度 - 持有信息列表&变更记录列表
export function exchangeQuotaList(apiName = 'list',data) {
// list=持有信息列表record_list=变更记录列表
return request.get(`user/exchange_quota/quota_${apiName}`,data)
}

View File

@ -1,238 +1,238 @@
import Layout from '@/layout'
import { roterPre } from '@/settings'
import {roterPre} from '@/settings'
const marketingRouter =
{
path: `${roterPre}/marketing`,
name: 'marketing',
meta: {
title: '营销'
},
alwaysShow: true,
component: Layout,
redirect: 'noRedirect',
children: [
{
path: 'coupon',
name: 'Coupon',
meta: {
title: '优惠券',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/coupon/index'),
children: [
{
path: 'list',
name: 'CouponList',
meta: {
title: '优惠劵列表',
noCache: true
},
component: () => import('@/views/marketing/coupon/couponList/index')
},
{
path: 'user',
name: 'CouponUser',
meta: {
title: '会员领取记录',
noCache: true
},
component: () => import('@/views/marketing/coupon/couponUser/index')
}
]
{
path: `${roterPre}/marketing`,
name: 'marketing',
meta: {
title: '营销'
},
{
path: 'platform_coupon',
name: 'Platform_coupon',
meta: {
title: '平台优惠券',
noCache: true
alwaysShow: true,
component: Layout,
redirect: 'noRedirect',
children: [
{
path: 'coupon',
name: 'Coupon',
meta: {
title: '优惠券',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/coupon/index'),
children: [
{
path: 'list',
name: 'CouponList',
meta: {
title: '优惠劵列表',
noCache: true
},
component: () => import('@/views/marketing/coupon/couponList/index')
},
{
path: 'user',
name: 'CouponUser',
meta: {
title: '会员领取记录',
noCache: true
},
component: () => import('@/views/marketing/coupon/couponUser/index')
}
]
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/platformCoupon/index'),
children: [
{
path: 'list',
name: 'PlatformCouponlist',
meta: {
title: '优惠劵列表',
noCache: true
},
component: () => import('@/views/marketing/platformCoupon/couponList/index')
{
path: 'platform_coupon',
name: 'Platform_coupon',
meta: {
title: '平台优惠券',
noCache: true
},
{
path: 'couponRecord',
name: 'CouponRecord',
meta: {
title: '优惠卷领取记录',
noCache: true
redirect: 'noRedirect',
component: () => import('@/views/marketing/platformCoupon/index'),
children: [
{
path: 'list',
name: 'PlatformCouponlist',
meta: {
title: '优惠劵列表',
noCache: true
},
component: () => import('@/views/marketing/platformCoupon/couponList/index')
},
component: () => import('@/views/marketing/platformCoupon/couponRecord/index')
},
{
path: 'creatCoupon/:id?',
name: 'CreatCoupon',
meta: {
title: '添加优惠劵',
noCache: true,
activeMenu: `${roterPre}/marketing/Platform_coupon/list`
{
path: 'couponRecord',
name: 'CouponRecord',
meta: {
title: '优惠卷领取记录',
noCache: true
},
component: () => import('@/views/marketing/platformCoupon/couponRecord/index')
},
component: () => import('@/views/marketing/platformCoupon/couponList/creatCoupon')
},
{
path: 'couponSend',
name: 'CouponSend',
meta: {
title: '优惠券发送记录',
noCache: true
{
path: 'creatCoupon/:id?',
name: 'CreatCoupon',
meta: {
title: '添加优惠劵',
noCache: true,
activeMenu: `${roterPre}/marketing/Platform_coupon/list`
},
component: () => import('@/views/marketing/platformCoupon/couponList/creatCoupon')
},
component: () => import('@/views/marketing/platformCoupon/couponSend/index')
},
{
path: 'instructions',
name: 'Instructions',
meta: {
title: '使用说明',
noCache: true
{
path: 'couponSend',
name: 'CouponSend',
meta: {
title: '优惠券发送记录',
noCache: true
},
component: () => import('@/views/marketing/platformCoupon/couponSend/index')
},
component: () => import('@/views/marketing/platformCoupon/couponInstructions/index')
}
]
},
{
path: 'studio',
name: 'Studio',
meta: {
title: '直播间',
noCache: true
{
path: 'instructions',
name: 'Instructions',
meta: {
title: '使用说明',
noCache: true
},
component: () => import('@/views/marketing/platformCoupon/couponInstructions/index')
}
]
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/studio/index'),
children: [
{
path: 'list',
name: 'StudioList',
meta: {
title: '直播间列表',
noCache: true
},
component: () => import('@/views/marketing/studio/studioList/index')
}
]
},
{
path: 'broadcast',
name: 'Broadcast',
meta: {
title: '直播',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/broadcast/index'),
children: [
{
path: 'list',
name: 'BroadcastList',
meta: {
title: '直播商品列表',
noCache: true
},
component: () => import('@/views/marketing/broadcast/broadcastList/index')
}
]
},
{
path: 'seckill',
name: 'Seckill',
meta: {
title: '秒杀管理',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/seckill/index'),
children: [
{
path: 'seckillConfig',
name: 'SeckillConfig',
meta: {
title: '秒杀配置',
noCache: true
},
component: () => import('@/views/marketing/seckill/seckillConfig/index')
{
path: 'studio',
name: 'Studio',
meta: {
title: '直播间',
noCache: true
},
{
path: 'list',
name: 'SpikeList',
meta: {
title: '秒杀列表',
noCache: true
},
component: () => import('@/views/marketing/seckill/seckillGoods/index.vue')
}
]
},
{
path: 'presell',
name: 'preSell',
meta: {
title: '预售商品管理',
noCache: true
redirect: 'noRedirect',
component: () => import('@/views/marketing/studio/index'),
children: [
{
path: 'list',
name: 'StudioList',
meta: {
title: '直播间列表',
noCache: true
},
component: () => import('@/views/marketing/studio/studioList/index')
}
]
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/seckill/index'),
children: [
{
path: 'list',
name: `preSaleList`,
meta: {
title: '预售商品',
noCache: true
},
component: () => import('@/views/marketing/preSale/index')
{
path: 'broadcast',
name: 'Broadcast',
meta: {
title: '直播',
noCache: true
},
{
path: 'agreement',
name: `preSaleAgreement`,
meta: {
title: '预售协议',
noCache: true
},
component: () => import('@/views/marketing/preSale/agreement')
}
]
},
{
path: 'assist',
name: 'assist',
meta: {
title: '助力活动商品',
noCache: true
redirect: 'noRedirect',
component: () => import('@/views/marketing/broadcast/index'),
children: [
{
path: 'list',
name: 'BroadcastList',
meta: {
title: '直播商品列表',
noCache: true
},
component: () => import('@/views/marketing/broadcast/broadcastList/index')
}
]
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/assist/index'),
children: [
{
path: 'goods_list',
name: `assistProductList`,
meta: {
title: '助力活动商品',
noCache: true
},
component: () => import('@/views/marketing/assist/assist_goods/index')
{
path: 'seckill',
name: 'Seckill',
meta: {
title: '秒杀管理',
noCache: true
},
{
path: 'list',
name: `assist`,
meta: {
title: '助力活动列表',
noCache: true
redirect: 'noRedirect',
component: () => import('@/views/marketing/seckill/index'),
children: [
{
path: 'seckillConfig',
name: 'SeckillConfig',
meta: {
title: '秒杀配置',
noCache: true
},
component: () => import('@/views/marketing/seckill/seckillConfig/index')
},
component: () => import('@/views/marketing/assist/assist_list/index')
{
path: 'list',
name: 'SpikeList',
meta: {
title: '秒杀列表',
noCache: true
},
component: () => import('@/views/marketing/seckill/seckillGoods/index.vue')
}
]
},
{
path: 'presell',
name: 'preSell',
meta: {
title: '预售商品管理',
noCache: true
},
]
},
{
redirect: 'noRedirect',
component: () => import('@/views/marketing/seckill/index'),
children: [
{
path: 'list',
name: `preSaleList`,
meta: {
title: '预售商品',
noCache: true
},
component: () => import('@/views/marketing/preSale/index')
},
{
path: 'agreement',
name: `preSaleAgreement`,
meta: {
title: '预售协议',
noCache: true
},
component: () => import('@/views/marketing/preSale/agreement')
}
]
},
{
path: 'assist',
name: 'assist',
meta: {
title: '助力活动商品',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/assist/index'),
children: [
{
path: 'goods_list',
name: `assistProductList`,
meta: {
title: '助力活动商品',
noCache: true
},
component: () => import('@/views/marketing/assist/assist_goods/index')
},
{
path: 'list',
name: `assist`,
meta: {
title: '助力活动列表',
noCache: true
},
component: () => import('@/views/marketing/assist/assist_list/index')
},
]
},
{
path: 'combination',
name: 'combinAtion',
meta: {
@ -271,99 +271,99 @@ const marketingRouter =
},
]
},
{
path: 'integral',
name: 'Integral',
meta: {
title: '积分',
noCache: true
{
path: 'integral',
name: 'Integral',
meta: {
title: '积分',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/integral/index'),
children: [
{
path: 'config',
name: `integralConfig`,
meta: {
title: '积分配置',
noCache: true
},
component: () => import('@/views/marketing/integral/config/index')
},
{
path: 'log',
name: `integralLog`,
meta: {
title: '积分日志',
noCache: true
},
component: () => import('@/views/marketing/integral/log/index')
},
{
path: 'hold',
name: `integralHold`,
meta: {
title: '持有积分',
noCache: true
},
component: () => import('@/views/marketing/integral/hold/index')
},
{
path: 'classify',
name: `integralClassify`,
meta: {
title: '积分商品分类',
noCache: true
},
component: () => import('@/views/marketing/integral/classify/index')
},
{
path: 'proList',
name: `integralProductList`,
meta: {
title: '积分商品列表',
noCache: true
},
component: () => import('@/views/marketing/integral/productList/index')
},
{
path: 'addProduct/:id?/:edit?',
name: `addIntegralProduct`,
meta: {
title: '添加积分商品',
noCache: true
},
component: () => import('@/views/marketing/integral/addProduct/index')
},
{
path: 'orderList',
name: `IntegralOrderList`,
meta: {
title: '兑换记录',
noCache: true
},
component: () => import('@/views/marketing/integral/orderList/index')
},
{
path: 'sign',
name: `signConfig`,
meta: {
title: '签到配置',
noCache: true
},
component: () => import('@/views/marketing/integral/sign/index')
},
{
path: 'give',
name: `integralGive`,
meta: {
title: '赠送记录',
noCache: true
},
component: () => import('@/views/marketing/integral/give/index')
},
]
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/integral/index'),
children: [
{
path: 'config',
name: `integralConfig`,
meta: {
title: '积分配置',
noCache: true
},
component: () => import('@/views/marketing/integral/config/index')
},
{
path: 'log',
name: `integralLog`,
meta: {
title: '积分日志',
noCache: true
},
component: () => import('@/views/marketing/integral/log/index')
},
{
path: 'hold',
name: `integralHold`,
meta: {
title: '持有积分',
noCache: true
},
component: () => import('@/views/marketing/integral/hold/index')
},
{
path: 'classify',
name: `integralClassify`,
meta: {
title: '积分商品分类',
noCache: true
},
component: () => import('@/views/marketing/integral/classify/index')
},
{
path: 'proList',
name: `integralProductList`,
meta: {
title: '积分商品列表',
noCache: true
},
component: () => import('@/views/marketing/integral/productList/index')
},
{
path: 'addProduct/:id?/:edit?',
name: `addIntegralProduct`,
meta: {
title: '添加积分商品',
noCache: true
},
component: () => import('@/views/marketing/integral/addProduct/index')
},
{
path: 'orderList',
name: `IntegralOrderList`,
meta: {
title: '兑换记录',
noCache: true
},
component: () => import('@/views/marketing/integral/orderList/index')
},
{
path: 'sign',
name: `signConfig`,
meta: {
title: '签到配置',
noCache: true
},
component: () => import('@/views/marketing/integral/sign/index')
},
{
path: 'give',
name: `integralGive`,
meta: {
title: '赠送记录',
noCache: true
},
component: () => import('@/views/marketing/integral/give/index')
},
]
},
{
path: 'discounts',
name: 'discounts',
@ -446,9 +446,37 @@ const marketingRouter =
component: () => import('@/views/marketing/border/borderList/addBorder')
}
]
}
],
},
{
path: 'exchange',
name: 'Exchange',
meta: {
title: '兑换管理',
noCache: true
},
redirect: 'noRedirect',
component: () => import('@/views/marketing/exchange/index'),
children: [
{
path: 'quota',
name: `exchangeQuota`,
meta: {
title: '兑换额度',
noCache: true
},
component: () => import('@/views/marketing/exchange/quota/index')
}
}
]
},
],
}
export default marketingRouter

View File

@ -0,0 +1,3 @@
<template>
<router-view />
</template>

View File

@ -0,0 +1,224 @@
<template>
<div class="divBox">
<el-card class="box-card">
<!--顶部搜索栏-->
<div slot="header" class="clearfix">
<div class="container">
<el-form inline size="small" label-width="80px">
<el-form-item label="搜索:">
<el-input v-model="tableFrom.uid" @keyup.enter.native="getList(1)" placeholder="请输入用户ID" class="selWidth" clearable>
<el-button slot="append" icon="el-icon-search" class="el-button-solt" @click="getList(1)" />
</el-input>
</el-form-item>
<el-form-item class="width100">
</el-form-item>
</el-form>
<cards-data :card-lists="cardLists" />
</div>
</div>
<!--表格信息-->
<el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane label="持有信息" name="list">
<el-table v-loading="listLoading" :data="tableData.data" style="width: 100%" size="mini">
<el-table-column prop="id" label="ID" min-width="50" align="center"/>
<el-table-column label="用户信息" prop="nickname" min-width="150" align="center">
<template slot-scope="scope">
<div class="user-content">
<div class="user-avatar" v-if="scope.row.avatar && scope.row.avatar != 1">
<img :src="scope.row.avatar" />
</div>
<div class="user-info">
<div class="nickname">{{ scope.row.nickname }}</div>
<div class="user-id">ID{{ scope.row.uid }}</div>
</div>
</div>
</template>
</el-table-column>
<el-table-column label="总获得额度" prop="total_quota" min-width="120" align="center"/>
<el-table-column label="已使用额度" prop="use_quota" min-width="120" align="center"/>
<el-table-column label="剩余额度" prop="surplus_quota" min-width="120" align="center"/>
<el-table-column label="冻结额度" prop="freeze_quota" min-width="120" align="center"/>
<el-table-column label="可用额度" prop="number" min-width="120" align="center">
<template slot-scope="scope">
{{ (scope.row.surplus_quota - scope.row.freeze_quota).toFixed(2) }}
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="变更记录" name="record_list">
<el-table v-loading="listLoading" :data="tableData.data" style="width: 100%" size="mini">
<el-table-column prop="id" label="ID" min-width="50" align="center"/>
<el-table-column label="用户信息" prop="nickname" min-width="150" align="center">
<template slot-scope="scope">
<div class="user-content">
<div class="user-avatar" v-if="scope.row.avatar && scope.row.avatar != 1">
<img :src="scope.row.avatar" />
</div>
<div class="user-info">
<div class="nickname">{{ scope.row.nickname }}</div>
<div class="user-id">ID{{ scope.row.uid }}</div>
</div>
</div>
</template>
</el-table-column>
<el-table-column label="变更前数量" prop="change_front" min-width="120" align="center"/>
<el-table-column label="变更数量" prop="change_quantity" min-width="120" align="center"/>
<el-table-column label="变更类型" min-width="120" align="center">
<template slot-scope="scope">
<el-tag v-if="scope.row.change_type == 1" type="success" effect="dark">增加</el-tag>
<el-tag v-else type="danger" effect="dark">减少</el-tag>
</template>
</el-table-column>
<el-table-column label="变更后数量" prop="change_after" min-width="120" align="center"/>
<el-table-column label="变更时间" prop="create_time" min-width="120" align="center"/>
</el-table>
</el-tab-pane>
</el-tabs>
<!--分页-->
<div class="block">
<el-pagination
:page-sizes="[20, 40, 60, 80]"
:page-size="tableFrom.limit"
:current-page="tableFrom.page"
layout="total, sizes, prev, pager, next, jumper"
:total="tableData.total"
@size-change="handleSizeChange"
@current-change="pageChange"
/>
</div>
</el-card>
</div>
</template>
<script>
import {exchangeQuotaTitle, exchangeQuotaList } from '@/api/marketing'
import cardsData from '@/components/cards/index'
export default {
name: "preSaleProductList",
components: { cardsData },
data() {
return {
activeName: 'list',
listLoading: true,
tableData: {
data: [],
total: 0,
},
tableFrom: {
page: 1,
limit: 20,
uid: ''
},
loading: false,
cardLists: [],
};
},
watch: {},
mounted() {
this.getStatistics();
this.getList('');
},
methods: {
//
getStatistics() {
let _this = this;
exchangeQuotaTitle(_this.tableFrom).then((res) => {
this.cardLists = res.data
}).catch((res) => {
this.$message.error(res.message)
})
},
//
getList(num) {
let _this = this;
this.listLoading = true;
this.tableFrom.page = num ? num : this.tableFrom.page;
exchangeQuotaList(_this.activeName,this.tableFrom)
.then((res) => {
this.tableData.data = res.data.list;
this.tableData.total = res.data.count;
this.listLoading = false;
})
.catch((res) => {
this.listLoading = false;
this.$message.error(res.message);
});
},
pageChange(page) {
this.tableFrom.page = page;
this.getList('');
},
handleSizeChange(val) {
this.tableFrom.limit = val;
this.getList('');
},
handleClick(tab, event){
this.tableData = this.$options.data().tableData;
this.tableFrom = this.$options.data().tableFrom;
this.getList(1);
}
},
};
</script>
<style scoped lang="scss">
.selWidth {
width: 350px !important;
}
.seachTiele {
line-height: 35px;
}
.title{
margin-bottom: 16px;
color: #17233d;
font-size: 14px;
font-weight: bold;
}
.scollhide::-webkit-scrollbar {
display: none; /* Chrome Safari */
}
.user-content{
--user-content-height-: 80px;
height: var(--user-content-height-);
width: 100%;
display: inline-flex;
flex-direction: row;
flex-wrap: nowrap;
justify-content: center;
align-items: center;
.user-avatar{
height: var(--user-content-height-);
width: var(--user-content-height-);
display: inline-flex;
flex-direction: row;
flex-wrap: nowrap;
justify-content: center;
align-items: center;
img{
height: 80%!important;
width: 80%!important;
border-radius: 50% !important;
}
}
.user-info{
height: var(--user-content-height-);
display: inline-flex;
flex-direction: column;
flex-wrap: nowrap;
justify-content: center;
align-items: flex-start;
.nickname{
font-size: 15px;
font-weight: bold;
line-height: calc(var(--user-content-height- * 65%));
}
.user-id{
font-size: 13px;
line-height: calc(var(--user-content-height- * 35%));
}
}
}
</style>