运营商vip钱包明细

This commit is contained in:
BOOL\25024
2024-03-01 16:49:16 +08:00
parent 6d898a6b54
commit 0a826e44e9
2 changed files with 143 additions and 41 deletions

View File

@@ -139,3 +139,12 @@ export function getMerchantList() {
method: 'get'
})
}
// 查询钱包明细
export function getMemberBalanceChangesV2(data) {
return request({
url: '/uniapp/member/getMemberBalanceChangesV2',
method: 'post',
data: data
});
}

View File

@@ -1,16 +1,15 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch"
label-width="68px">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="会员ID" prop="memberId">
<el-input v-model="queryParams.memberId" placeholder="请输入会员ID" clearable
@keyup.enter.native="handleQuery"/>
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="手机号" prop="mobileNumber">
<el-input v-model="queryParams.mobileNumber" placeholder="请输入手机号" clearable
@keyup.enter.native="handleQuery"/>
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item>
@@ -22,7 +21,7 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
v-hasPermi="['member:merchantVip:add']">开卡
v-hasPermi="['member:merchantVip:add']">开卡
</el-button>
</el-col>
<!--<el-col :span="1.5">
@@ -61,16 +60,16 @@
</el-row>
<el-table v-loading="loading" :data="infoList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center"/>
<el-table-column label="卡号" align="center" prop="walletCode"/>
<el-table-column label="运营商" align="center" prop="merchantName"/>
<el-table-column label="会员id" align="center" prop="memberId"/>
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="卡号" align="center" prop="walletCode" />
<el-table-column label="运营商" align="center" prop="merchantName" />
<el-table-column label="会员id" align="center" prop="memberId" />
<el-table-column label="头像" align="center" prop="avatarUrl">
<template slot-scope="scope">
<!-- <el-image v-if="scope.row.avatarUrl === null" :src="defaultImg" />-->
<el-image style="height: 50px;width: 50px"
:src="scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl"
:preview-src-list='[scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl]'/>
:src="scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl"
:preview-src-list='[scope.row.avatarUrl === null ? defaultImg[0].img : scope.row.avatarUrl]' />
</template>
</el-table-column>
<el-table-column label="昵称" align="center" prop="nickName">
@@ -80,51 +79,53 @@
</router-link>
</template>
</el-table-column>
<el-table-column label="手机号" align="center" prop="mobileNumber"/>
<el-table-column label="本金余额" align="center" prop="principalBalance"/>
<el-table-column label="赠送余额" align="center" prop="giftBalance"/>
<el-table-column label="总余额" align="center" prop="totalAccountAmount"/>
<el-table-column label="备注" align="center" prop="remark"/>
<el-table-column label="手机号" align="center" prop="mobileNumber" />
<el-table-column label="本金余额" align="center" prop="principalBalance" />
<el-table-column label="赠送余额" align="center" prop="giftBalance" />
<el-table-column label="总余额" align="center" prop="totalAccountAmount" />
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdateBalance(scope.row)"
v-hasPermi="['member:merchantVip:update']">充值/扣款
v-hasPermi="['member:merchantVip:update']">充值/扣款
</el-button>
</template>
</el-table-column>
<el-table-column label="查看" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button size="mini" type="text" @click="viewDetails(scope.row)">明细</el-button>
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"/>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
@pagination="getList" />
<!-- 添加或修改会员基础信息对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="createMerchantVip" :rules="rules" label-width="100px">
<el-form-item label="选择运营商">
<el-select v-model="createMerchantVip.targetMerchantId" clearable placeholder="请选择运营商" @change="$forceUpdate()">
<el-option v-for="item in merchantList"
:key="item.merchantId"
:label="item.merchantName"
:value="item.merchantId">
<el-select v-model="createMerchantVip.targetMerchantId" clearable placeholder="请选择运营商"
@change="$forceUpdate()">
<el-option v-for="item in merchantList" :key="item.merchantId" :label="item.merchantName"
:value="item.merchantId">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="手机号码">
<el-input v-model="createMerchantVip.mobileNumber" placeholder="请输入手机号码"/>
<el-input v-model="createMerchantVip.mobileNumber" placeholder="请输入手机号码" />
</el-form-item>
<el-form-item label="操作类型">
<el-radio v-model="createMerchantVip.type" label="1" border>充值</el-radio>
<el-radio v-model="createMerchantVip.type" label="2" border>扣款</el-radio>
</el-form-item>
<el-form-item label="金额" prop="balance">
<el-input-number v-model="createMerchantVip.updatePrincipalBalance" placeholder="请输入金额"
:min="0"
:controls="false" :precision="2"/>
<el-input-number v-model="createMerchantVip.updatePrincipalBalance" placeholder="请输入金额" :min="0"
:controls="false" :precision="2" />
</el-form-item>
<el-form-item label="赠送金" prop="balance">
<el-input-number v-model="createMerchantVip.updateGiftBalance" placeholder="请输入赠送金" :min="0"
:controls="false" :precision="2"/>
:controls="false" :precision="2" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@@ -135,7 +136,7 @@
<!-- 添加或修改会员余额对话框 -->
<el-dialog title="会员充值/扣款" @close="closeUpdateBalance" :visible.sync="openUpdateBalance" width="500px"
append-to-body>
append-to-body>
<p>线下充值本金客户直接在线下付款给商家</p>
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-form-item label="选择运营商">
@@ -146,13 +147,12 @@
<el-radio v-model="type" label="2" border>扣款</el-radio>
</el-form-item>
<el-form-item label="金额" prop="balance">
<el-input-number v-model="updatePrincipalBalance" placeholder="请输入金额" :min="0"
:controls="false"
:precision="2"/>
<el-input-number v-model="updatePrincipalBalance" placeholder="请输入金额" :min="0" :controls="false"
:precision="2" />
</el-form-item>
<el-form-item label="赠送金" prop="balance">
<el-input-number v-model="updateGiftBalance" placeholder="请输入赠送金" :min="0" :controls="false"
:precision="2"/>
:precision="2" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@@ -160,28 +160,67 @@
<el-button @click="resetBalance"> </el-button>
</div>
</el-dialog>
<!-- 明细 -->
<el-dialog title="交易明细" :visible.sync="vehicleDetails" :before-close="closeDetails" width="1200px" append-to-body>
<el-form :model="detailParameters" size="small" :inline="true">
<el-form-item label="选择日期" prop="tradeDate">
<el-date-picker v-model="createTimeRange" type="month" value-format="yyyy-MM" range-separator="-"
placeholder="选择日期">
</el-date-picker>
</el-form-item>
<el-form-item style="margin-left: 10px;">
<el-button type="primary" icon="el-icon-search" size="mini" @click="getDetails">搜索</el-button>
</el-form-item>
<el-col :span="24">
<el-form-item label="充值余额:"> {{ totalRechargeAmount }} </el-form-item>
<el-form-item label="消费金额:" style="padding-left: 50px;">{{ totalConsumption }}</el-form-item>
<el-form-item label="累计充值金额:" style="padding-left: 50px;">{{ accumulatedRechargeAmount }}</el-form-item>
<el-form-item label="累计消费金额:" style="padding-left: 50px;">{{ accumulatedConsumptionAmount
}}</el-form-item>
</el-col>
</el-form>
<el-table :data="detailList" stripe style="width: 100%" v-loading="loadings">
<el-table-column label="后管充值" align="center" prop="amount">
<template slot-scope="scope">
<span v-if="scope.row.subType == '充值'">{{ scope.row.amount }}</span>
</template>
</el-table-column>
<el-table-column label="后管扣款" align="center" prop="amount">
<template slot-scope="scope">
<span v-if="scope.row.subType == '后管扣款'">{{ scope.row.amount }}</span>
</template>
</el-table-column>
<el-table-column label="支付金额" align="center" prop="payAmount" />
<el-table-column label="订单金额" align="center" prop="orderAmount" />
<el-table-column label="已退款" align="center" prop="refundAmount" />
<el-table-column label="时间" align="center" prop="transactionTime" />
</el-table>
<!--分页-->
<pagination v-show="closeTotal > 0" :total="closeTotal" :page.sync="detailParameters.pageNum"
:limit.sync="detailParameters.pageSize" @pagination="getDetails" style="margin-bottom: 20px" />
</el-dialog>
</div>
</template>
<script>
import {
listInfo,
getInfo,
delInfo,
addInfo,
updateInfo,
updateMemberBalance,
getMerchantList, queryMerchantVipList, createMerchantVip,
getMerchantList, queryMerchantVipList, createMerchantVip, getMemberBalanceChangesV2
} from "@/api/member/info";
import { parseTime } from "@/utils/common";
export default {
name: "Info",
dicts: ['member_status'],
data() {
return {
defaultImg: [{img: require('../../../assets/images/headPort.png')}],
defaultImg: [{ img: require('../../../assets/images/headPort.png') }],
// 遮罩层
loading: true,
loadings: true,
// 选中数组
ids: [],
// 非单个禁用
@@ -230,6 +269,21 @@ export default {
updateMerchantVip: {},
forbid: '', //充值/扣款参数
selectedValue: null, // 设置默认选中第一条数据
vehicleDetails: false,
detailList: [],
totalConsumption: 0,
totalRechargeAmount: 0,
accumulatedRechargeAmount: 0,
accumulatedConsumptionAmount: 0,
closeTotal: 0,
detailParameters: {
pageNum: 1,
pageSize: 10,
walletCode: null,
tradeDate: null,
memberId: null
},
createTimeRange: [],
};
},
computed: {
@@ -417,7 +471,46 @@ export default {
this.download('member/info/export', {
...this.queryParams
}, `info_${new Date().getTime()}.xlsx`)
}
}
},
viewDetails(row) {
console.log(row);
this.detailParameters.walletCode = row.walletCode;
this.detailParameters.memberId = row.memberId;
this.detailParameters.tradeDate = parseTime(new Date(), '{y}-{m}'); //设置默认日期
this.createTimeRange = this.detailParameters.tradeDate;
this.vehicleDetails = true;
this.getDetails();
},
closeDetails() {
this.vehicleDetails = false;
this.detailList = [];
this.totalConsumption = 0;
this.totalRechargeAmount = 0;
},
getDetails() {
this.loadings = true;
console.log(this.detailParameters);
getMemberBalanceChangesV2(this.detailParameters).then(response => {
console.log(response);
this.loadings = false;
this.detailList = response.obj.pageResponse.list;
this.totalRechargeAmount = response.obj.totalRechargeAmount;
this.accumulatedRechargeAmount = response.obj.accumulatedRechargeAmount;
this.accumulatedConsumptionAmount = response.obj.accumulatedConsumptionAmount;
this.totalConsumption = response.obj.totalConsumption;
this.closeTotal = response.obj.pageResponse.total;
});
},
},
watch: {
createTimeRange(newValue, oldValue) {
console.log("createTimeRange发生变化", newValue, oldValue);
if (newValue != null && newValue.length > 0) {
this.detailParameters.tradeDate = newValue;
} else {
this.detailParameters.tradeDate = null;
}
},
},
};
</script>