Compare commits
13 Commits
82d5f5408e
...
2ac2faf592
Author | SHA1 | Date |
---|---|---|
Jruome | 2ac2faf592 | |
Jruome | 6fa7a0103f | |
tangqian | bd806cc2ba | |
tangqian | 5846de1445 | |
tangqian | 18bc18be76 | |
tangqian | 6849a68446 | |
Jruome | acb1e72a57 | |
tangqian | bccc325bda | |
tangqian | 9e1a653dbe | |
tangqian | 714650a275 | |
tangqian | 9bb2ba3740 | |
tangqian | c5c73744f0 | |
tangqian | 8afd5700ab |
|
@ -1,5 +1,13 @@
|
|||
import request from '@/utils/request'
|
||||
|
||||
// 添加备注
|
||||
export function adminRemark(data) {
|
||||
return request({
|
||||
url: '/shop/recharge-order/adminRemark',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 获取商户
|
||||
export function getTenantList(data) {
|
||||
|
|
|
@ -0,0 +1,368 @@
|
|||
<template>
|
||||
<div class="app-container">
|
||||
|
||||
<!-- 搜索工作栏 -->
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="98px">
|
||||
<el-form-item label="订单编号" prop="orderId">
|
||||
<el-input v-model="queryParams.orderId" placeholder="请输入订单号" clearable @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="退款类型" prop="refundType">
|
||||
<el-select v-model="queryParams.refundType" placeholder="请选择退款类型" clearable @keyup.enter.native="handleQuery">
|
||||
<el-option v-for="(item,index) in actionSheetList" :key="index" :value="item.value" :label="item.name"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="申请退款时间" prop="payTime">
|
||||
<el-date-picker v-model="queryParams.payTime" @change="onchangeTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="datetimerange"
|
||||
range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" clearable @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="推广员" prop="nickname">
|
||||
<el-input v-model="queryParams.nickname" placeholder="请输入推广员" clearable @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="商户名称" prop="tenantId">
|
||||
<treeselect style="width: 240px;" v-model="queryParams.tenantId" :options="deptOptions" :show-count="true"
|
||||
placeholder="请选择商户名称" :normalizer="normalizer" @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="会员名称" prop="realName">
|
||||
<el-input v-model="queryParams.realName" placeholder="请输入会员名称" clearable @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="充值号码" prop="userPhone">
|
||||
<el-input v-model="queryParams.userPhone" placeholder="请输入充值号码" clearable @keyup.enter.native="handleQuery"/>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-button type="primary" icon="el-icon-search" @click="handleQuery" >搜索</el-button>
|
||||
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
|
||||
<!-- 操作工具栏 -->
|
||||
<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="['shop:recharge-order:create']">新增</el-button>-->
|
||||
<!-- </el-col>-->
|
||||
<el-col :span="1.5">
|
||||
<el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading"
|
||||
v-hasPermi="['shop:recharge-order-refund:export']">导出</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<!-- 列表 -->
|
||||
<el-table v-loading="loading" :data="list" ref="multipleTable" >
|
||||
<el-table-column label="订单编号" align="center" prop="orderId" />
|
||||
<el-table-column label="商户名称" align="center" prop="tenantName" />
|
||||
<el-table-column label="推广员名称" align="center" prop="parentOrganizationName" >
|
||||
<template v-slot="scope">
|
||||
<span>{{ scope.row.parentOrganizationName }}</span>
|
||||
<span v-if="scope.row.nickname!=='' && scope.row.nickname!==null">-{{ scope.row.nickname }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="会员名称" align="center" prop="realName" />
|
||||
<el-table-column label="充值号码" align="center" prop="userPhone" />
|
||||
<el-table-column label="退款类型" align="center" prop="refundName" />
|
||||
<el-table-column label="退款理由" align="center" prop="memberReason" width="180" show-overflow-tooltip/>
|
||||
<el-table-column label="申请退款时间" align="center" prop="payTime" width="180">
|
||||
<template v-slot="scope">
|
||||
<span>{{ parseTime(scope.row.applyTime) }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="退款完成时间" align="center" prop="payTime" width="180">
|
||||
<template v-slot="scope">
|
||||
<span>{{ parseTime(scope.row.applySucceedTime) }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="备注" align="center" prop="adminReason" width="180" show-overflow-tooltip/>
|
||||
<el-table-column label="操作" align="center" class-name="small-padding" fixed="right" width="80">
|
||||
<template v-slot="scope">
|
||||
<el-button size="mini" type="text" @click="handleAdd(scope.row)" v-hasPermi="['shop:recharge-order:remark']">添加备注</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<!-- 对话框(添加 / 修改) -->
|
||||
<el-dialog title="添加备注" :visible.sync="open" width="500px" v-dialogDrag append-to-body>
|
||||
<el-form ref="form" :model="form" label-width="80px">
|
||||
<el-form-item label="备注" prop="adminReason">
|
||||
<el-input v-model="form.adminReason" placeholder="请输入备注" :autosize="{ minRows: 4}"
|
||||
type="textarea" :rules="[{request:true,message: '请输入备注', trigger: 'blur'}]"/>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||
<el-button @click="cancel">取 消</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
<!-- 分页组件 -->
|
||||
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {
|
||||
createRechargeOrder,
|
||||
updateRechargeOrder,
|
||||
deleteRechargeOrder,
|
||||
getTenantList,
|
||||
updateByIds,
|
||||
getRechargeOrderPage,
|
||||
exportRechargeOrderExcel,
|
||||
refundRechargeOrder,
|
||||
adminRemark
|
||||
} from '@/api/shop/rechargeOrder';
|
||||
import ElementForm from "@/components/bpmnProcessDesigner/package/penal/form/ElementForm.vue";
|
||||
import Treeselect from "@riophae/vue-treeselect";
|
||||
import '@riophae/vue-treeselect/dist/vue-treeselect.css';
|
||||
export default {
|
||||
name: "RechargeOrder",
|
||||
components: {
|
||||
Treeselect,
|
||||
ElementForm
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
actionSheetList: [{
|
||||
name: '对活动理解有误',
|
||||
value: 1,
|
||||
},
|
||||
{
|
||||
name: '同一充值账户',
|
||||
value: 2
|
||||
},
|
||||
{
|
||||
name: '改套餐/转网/销户',
|
||||
value: 3
|
||||
},
|
||||
{
|
||||
name: '下单信息有误',
|
||||
value: 4
|
||||
},
|
||||
{
|
||||
name: '业绩归属错误',
|
||||
value: 5
|
||||
},
|
||||
{
|
||||
name: '重复订单',
|
||||
value: 6
|
||||
},
|
||||
{
|
||||
name: '号码充值失败',
|
||||
value: 7
|
||||
},
|
||||
{
|
||||
name: '等待时间过长',
|
||||
value: 8
|
||||
},
|
||||
{
|
||||
name: '其它原因',
|
||||
value: 9
|
||||
}
|
||||
],
|
||||
deptOptions:[],
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 导出遮罩层
|
||||
exportLoading: false,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 订单列表
|
||||
list: [],
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNo: 1,
|
||||
pageSize: 10,
|
||||
refundStatus:2
|
||||
},
|
||||
// 表单参数
|
||||
form: {},
|
||||
multipleSelection: []
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
this.getTreeselect();
|
||||
},
|
||||
methods: {
|
||||
onchangeTime(value){
|
||||
this.queryParams.startApplyTime = value[0]
|
||||
this.queryParams.endApplyTime = value[1]
|
||||
},
|
||||
/** 查询部门下拉树结构 + 岗位下拉 */
|
||||
getTreeselect() {
|
||||
getTenantList().then(response => {
|
||||
// 处理 deptOptions 参数
|
||||
this.deptOptions = response.data
|
||||
});
|
||||
},
|
||||
// 格式化部门的下拉框
|
||||
normalizer(node) {
|
||||
return {
|
||||
id: node.id,
|
||||
label: node.name,
|
||||
children: node.children
|
||||
}
|
||||
},
|
||||
selectable(row,rowIndex) {
|
||||
if(!row.status){
|
||||
return true; //不禁用
|
||||
}else {
|
||||
return false; //禁用
|
||||
}
|
||||
},
|
||||
async handleGoods(){
|
||||
if(this.multipleSelection.length){
|
||||
await updateByIds({ids:this.multipleSelection,status:true})
|
||||
this.getList();
|
||||
}else {
|
||||
this.$modal.msgWarning("请勾选需要更改发货状态的订单")
|
||||
}
|
||||
},
|
||||
handleSelectionChange(rows) {
|
||||
const arr = rows.filter(({ status }) => !status );
|
||||
if(arr.length){
|
||||
this.multipleSelection = arr.map(({id}) => id)
|
||||
}else {
|
||||
this.multipleSelection = []
|
||||
}
|
||||
},
|
||||
handleReview(row, status){
|
||||
|
||||
},
|
||||
/** 查询列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
// 执行查询
|
||||
getRechargeOrderPage(this.queryParams).then(response => {
|
||||
this.list = response.data.list;
|
||||
this.$nextTick(()=>{
|
||||
this.list.forEach((item) => {
|
||||
item.status && this.$refs.multipleTable.toggleRowSelection(item,true);
|
||||
})
|
||||
})
|
||||
this.total = response.data.total;
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
/** 取消按钮 */
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.reset();
|
||||
},
|
||||
/** 表单重置 */
|
||||
reset() {
|
||||
this.form = {
|
||||
id: undefined,
|
||||
orderId: undefined,
|
||||
uid: undefined,
|
||||
realName: undefined,
|
||||
userPhone: undefined,
|
||||
confirmPhone: undefined,
|
||||
totalNum: undefined,
|
||||
totalPrice: undefined,
|
||||
payPrice: undefined,
|
||||
paid: undefined,
|
||||
payTime: undefined,
|
||||
payEndTime: undefined,
|
||||
payType: undefined,
|
||||
status: undefined,
|
||||
refundStatus: undefined,
|
||||
refundReasonWapImg: undefined,
|
||||
refundReasonWapExplain: undefined,
|
||||
refundReasonWap: undefined,
|
||||
refundReason: undefined,
|
||||
refundReasonTime: undefined,
|
||||
refundPrice: undefined,
|
||||
mark: undefined,
|
||||
remark: undefined,
|
||||
cost: undefined,
|
||||
isChannel: undefined,
|
||||
isRemind: undefined,
|
||||
isSystemDel: undefined,
|
||||
type: undefined,
|
||||
proTotalPrice: undefined,
|
||||
beforePayPrice: undefined,
|
||||
isAlterPrice: undefined,
|
||||
outTradeNo: undefined,
|
||||
paySerialNumber: undefined,
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNo = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.queryParams ={
|
||||
pageNo: 1,
|
||||
pageSize: 10,
|
||||
refundStatus:2
|
||||
};
|
||||
this.handleQuery();
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd(item) {
|
||||
this.reset();
|
||||
this.form.orderId = item.id
|
||||
this.open = true;
|
||||
},
|
||||
/** 退款按钮操作 */
|
||||
handleRefund(row, type) {
|
||||
const id = row.id;
|
||||
this.$modal.confirm('是否退款订单编号为"' + id + '"的数据?').then(function() {
|
||||
return refundRechargeOrder({
|
||||
orderId: id,
|
||||
type: type
|
||||
});
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("发起退款成功");
|
||||
}).catch(() => {});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (!valid) {
|
||||
return;
|
||||
}
|
||||
// 添加的提交
|
||||
adminRemark(this.form).then(response => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const id = row.id;
|
||||
this.$modal.confirm('是否确认删除订单编号为"' + id + '"的数据项?').then(function() {
|
||||
return deleteRechargeOrder(id);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
// 处理查询参数
|
||||
let params = {...this.queryParams};
|
||||
params.pageNo = undefined;
|
||||
params.pageSize = undefined;
|
||||
this.$modal.confirm('是否确认导出所有订单数据项?').then(() => {
|
||||
this.exportLoading = true;
|
||||
return exportRechargeOrderExcel(params);
|
||||
}).then(response => {
|
||||
this.$download.excel(response, '订单.xls');
|
||||
this.exportLoading = false;
|
||||
}).catch(() => {});
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
|
@ -1,7 +1,8 @@
|
|||
<template>
|
||||
<view class="box">
|
||||
<view class="box-seach">
|
||||
<u-search placeholder="按手机号搜索查询" v-model="keyword" border-color="#F94B78" height="70" margin="0 0 35rpx 0" placeholder-color="#9C9C9C" bg-color="#fff" :show-action="false"></u-search>
|
||||
<u-search placeholder="按手机号搜索查询" v-model="keyword" border-color="#F94B78" height="70" margin="0 0 35rpx 0"
|
||||
placeholder-color="#9C9C9C" bg-color="#fff" :show-action="false"></u-search>
|
||||
</view>
|
||||
<view class="list-item" v-for="(item,index) in memberData" :key="index" @click.stop="handleBack(item)">
|
||||
<view class="item-title">
|
||||
|
@ -17,23 +18,106 @@
|
|||
<text>充值档次:{{item.grade}}</text>
|
||||
</view>
|
||||
</view>
|
||||
<u-modal :show="serviceShow" @confirm="confirm" @cancel="serviceShow = false" title="申请退款" show-cancel-button
|
||||
confirm-text="确认退款" cancel-text="取消退款">
|
||||
<view class="slot-content">
|
||||
<u--form :model="form" ref="uForm" :rules="rules" label-width="120">
|
||||
<u-form-item label="退款类型" prop="refundName" @click="show = true;">
|
||||
<u--input v-model="form.refundName" disabled disabledColor="#ffffff" placeholder='请选择退款类型'></u--input>
|
||||
<u-icon slot="right" name="arrow-right"></u-icon>
|
||||
</u-form-item>
|
||||
<u-form-item label="退款理由" prop="memberReason"><u--textarea v-model="form.memberReason" maxlength="100"
|
||||
placeholder='请输入退款理由' count autoHeight /></u-form-item>
|
||||
</u--form>
|
||||
</view>
|
||||
</u-modal>
|
||||
<u-empty v-show="!memberData.length" text="暂无数据" mode="list"></u-empty>
|
||||
<u-navbar autoBack title="购买记录"></u-navbar>
|
||||
<u-action-sheet :show="show" :actions="actionSheetList" title="请选择退款类型" @close="show = false"
|
||||
@select="handleSelect">
|
||||
</u-action-sheet>
|
||||
</view>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {
|
||||
memberOrderInfo,memberApplyRefund,memberOrderInfoByPhone
|
||||
memberOrderInfo,
|
||||
memberApplyRefund,
|
||||
memberOrderInfoByPhone
|
||||
} from '@/api/member.js';
|
||||
import { Debounce } from '@/utils/validate.js'
|
||||
import {
|
||||
Debounce
|
||||
} from '@/utils/validate.js'
|
||||
export default {
|
||||
name: "member_record",
|
||||
data() {
|
||||
return {
|
||||
rules: {
|
||||
refundName: [{
|
||||
required: true,
|
||||
message: '请选择退款类型',
|
||||
// 可以单个或者同时写两个触发验证方式
|
||||
trigger: ['change', 'blur'],
|
||||
}],
|
||||
refundType: [{
|
||||
required: true,
|
||||
message: '请选择退款类型',
|
||||
// 可以单个或者同时写两个触发验证方式
|
||||
trigger: ['change', 'blur'],
|
||||
}],
|
||||
memberReason: [{
|
||||
required: true,
|
||||
message: '请输入退款理由',
|
||||
trigger: ['change', 'blur'],
|
||||
}]
|
||||
},
|
||||
show: false,
|
||||
serviceShow: false,
|
||||
keyword: '',
|
||||
memberData: [],
|
||||
list:['未退款','退款申请中','已退款','退款中']
|
||||
form: {
|
||||
refundName: '',
|
||||
refundType: '',
|
||||
memberReason:''
|
||||
},
|
||||
list: ['未退款', '退款申请中', '已退款', '退款中'],
|
||||
actionSheetList: [{
|
||||
name: '对活动理解有误',
|
||||
value: 1,
|
||||
},
|
||||
{
|
||||
name: '同一充值账户',
|
||||
value: 2
|
||||
},
|
||||
{
|
||||
name: '改套餐/转网/销户',
|
||||
value: 3
|
||||
},
|
||||
{
|
||||
name: '下单信息有误',
|
||||
value: 4
|
||||
},
|
||||
{
|
||||
name: '业绩归属错误',
|
||||
value: 5
|
||||
},
|
||||
{
|
||||
name: '重复订单',
|
||||
value: 6
|
||||
},
|
||||
{
|
||||
name: '号码充值失败',
|
||||
value: 7
|
||||
},
|
||||
{
|
||||
name: '等待时间过长',
|
||||
value: 8
|
||||
},
|
||||
{
|
||||
name: '其它原因',
|
||||
value: 9
|
||||
}
|
||||
],
|
||||
};
|
||||
},
|
||||
async onLoad() {
|
||||
|
@ -49,6 +133,10 @@
|
|||
}, 1000)
|
||||
},
|
||||
methods: {
|
||||
handleSelect(e) {
|
||||
this.form.refundType = e.value
|
||||
this.form.refundName = e.name
|
||||
},
|
||||
handleBack(item) {
|
||||
uni.navigateTo({
|
||||
url: `/pages/member_back/index?userPhone=${item.userPhone}&grade=${item.grade}`
|
||||
|
@ -86,12 +174,24 @@
|
|||
this.memberData = []
|
||||
}
|
||||
},
|
||||
async handleService(item){
|
||||
await memberApplyRefund({orderId:item.id,type:3})
|
||||
async confirm() {
|
||||
this.$refs.uForm.validate().then(async res => {
|
||||
await memberApplyRefund(this.form)
|
||||
this.$util.Tips({
|
||||
title: '申请成功'
|
||||
});
|
||||
this.serviceShow = false
|
||||
await this.getList()
|
||||
}).catch(errors => {
|
||||
uni.$u.toast('校验失败')
|
||||
})
|
||||
},
|
||||
async handleService(item) {
|
||||
this.serviceShow = true
|
||||
this.form = {
|
||||
orderId: item.id,
|
||||
type: 3
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -105,11 +205,14 @@
|
|||
background-size: cover;
|
||||
background-repeat: no-repeat;
|
||||
background-attachment: fixed;
|
||||
|
||||
.u-empty {
|
||||
margin-top: 20% !important;
|
||||
|
||||
::v-deep .u-icon__icon {
|
||||
font-size: 140rpx !important;
|
||||
}
|
||||
|
||||
::v-deep .u-empty__text {
|
||||
font-size: 30rpx !important;
|
||||
}
|
||||
|
@ -123,6 +226,7 @@
|
|||
top: 8%;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.list-item {
|
||||
margin-bottom: 26rpx;
|
||||
padding: 30rpx 16rpx 25rpx 16rpx;
|
||||
|
@ -131,14 +235,17 @@
|
|||
display: flex;
|
||||
flex-direction: column;
|
||||
justify-content: space-between;
|
||||
|
||||
.item-title {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
|
||||
.item-phone {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
font-size: 30rpx;
|
||||
color: #E91D51;
|
||||
|
||||
view {
|
||||
border-radius: 3rpx;
|
||||
margin-right: 10rpx;
|
||||
|
@ -147,6 +254,7 @@
|
|||
background: #E91D51;
|
||||
}
|
||||
}
|
||||
|
||||
button {
|
||||
padding: 6rpx;
|
||||
font-size: 26rpx;
|
||||
|
|
Loading…
Reference in New Issue