用户编辑和余额增加减

This commit is contained in:
duan 2024-08-20 16:57:26 +08:00
parent c51d5cd064
commit 1fde054290
8 changed files with 273 additions and 56 deletions

View File

@ -144,7 +144,7 @@ export function adget(params) {
*/ */
export function adpost(data) { export function adpost(data) {
return request({ return request({
url: `/api/miniAppPages`, url: `/api/ad`,
method: "post", method: "post",
data data
}); });
@ -155,7 +155,7 @@ export function adpost(data) {
*/ */
export function adput(data) { export function adput(data) {
return request({ return request({
url: '/api/miniAppPages', url: '/api/ad',
method: 'put', method: 'put',
data data
}) })
@ -167,7 +167,7 @@ export function adput(data) {
*/ */
export function addelete(params) { export function addelete(params) {
return request({ return request({
url: "/api/miniAppPages/" + params, url: "/api/ad/" + params,
method: "put", method: "DELETE",
}); });
} }

View File

@ -607,3 +607,28 @@ export function shopStaffDelete(data) {
data data
}); });
} }
//增减余额
export function midfiyAccount(data) {
return request({
url: `/api/tbShopUser/midfiyAccount`,
method: "post",
data
});
}
// 编辑用户
export function tbShopUseredit(data) {
return request({
url: `/api/tbShopUser`,
method: "put",
data
});
}
// 通过活动id获取赠送商品列表
export function activate(id) {
return request({
url: `shop/storage/activate/${id}`,
method: "get"
});
}

View File

@ -10,7 +10,7 @@
<el-form-item label="状态"> <el-form-item label="状态">
<el-select clearable v-model="query.status" placeholder="请选择"> <el-select clearable v-model="query.status" placeholder="请选择">
<el-option label="可见" value="1" /> <el-option label="可见" value="1" />
<el-option label="不可见" value="1" /> <el-option label="不可见" value="2" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@ -20,7 +20,7 @@
</el-form> </el-form>
<!--表格渲染--> <!--表格渲染-->
<el-table ref="table" :data="tableData" style="width: 100%;"> <el-table ref="table" :data="tableData" style="width: 100%;">
<el-table-column prop="name" label="弹窗广告"> <el-table-column label="弹窗广告">
<template v-slot="scope"> <template v-slot="scope">
<img :src="scope.row.imgUrl" style="width: 100px;height: 100px;"> <img :src="scope.row.imgUrl" style="width: 100px;height: 100px;">
</template> </template>
@ -36,7 +36,11 @@
@change="showChange($event, scope.row)"></el-switch> @change="showChange($event, scope.row)"></el-switch>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="path" label="弹窗频率" /> <el-table-column prop="" label="弹窗频率">
<template v-slot="scope">
{{ scope.row.frequency | frequencyFilter }}
</template>
</el-table-column>
<el-table-column prop="createTime" label="创建日期" /> <el-table-column prop="createTime" label="创建日期" />
<el-table-column label="操作" width="200"> <el-table-column label="操作" width="200">
<template v-slot="scope"> <template v-slot="scope">
@ -53,19 +57,40 @@
<el-pagination :total="tableData.length" layout="total, prev, pager, next, jumper"></el-pagination> <el-pagination :total="tableData.length" layout="total, prev, pager, next, jumper"></el-pagination>
</div> --> </div> -->
<!-- 增减余额弹窗 --> <!-- 增减余额弹窗 -->
<el-dialog :title="title + '页面'" :visible.sync="dialogVisible" width="30%"> <el-dialog :title="title + '广告'" :visible.sync="dialogVisible" width="60%">
<el-form ref="form" :model="form" label-width="80px"> <el-form ref="form" :model="form" label-width="120px">
<el-form-item label="页面名称"> <el-form-item label="上传弹窗广告">
<el-input v-model="form.name"></el-input> <el-upload class="upload-demo" :action="qiNiuUploadApi" :headers="headers" :limit="1"
</el-form-item> <el-form-item label=""> :on-remove="removeEvent" :on-success="successEvent" :file-list="fileList">
<el-input v-model="form.path"></el-input> <el-button size="small" type="primary">点击上传</el-button>
<div slot="tip" class="el-upload__tip">建议尺寸520px*680px</div>
</el-upload>
</el-form-item> </el-form-item>
<el-form-item label="状态"> <el-form-item label="圆角设置">
<el-radio-group v-model="form.status"> <el-slider v-model="form.borderRadius"></el-slider>
<el-radio :label="1">可见</el-radio> </el-form-item>
<el-radio :label="2">不可见</el-radio> <el-form-item label="弹窗位置">
<el-radio-group v-model="form.showPosition">
<el-radio label="home">首页</el-radio>
<el-radio label="make_order">点餐页</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="弹窗频率">
<el-radio-group v-model="form.frequency">
<el-radio label="only_one">仅首次打开显示</el-radio>
<el-radio label="every_show">每次打开显示一次</el-radio>
<el-radio label="thirty_day">每30天显示一次</el-radio>
<el-radio label="seven_day">每7天显示一次</el-radio>
<el-radio label="three_day">每3天显示一次</el-radio>
<el-radio label="every_day">每1天显示一次</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="跳转页面">
<el-select v-model="form.linkPath" placeholder="请选择">
<el-option v-for="item in tourl" :key="item.id" :label="item.name" :value="item.path">
</el-option>
</el-select>
</el-form-item>
</el-form> </el-form>
<span slot="footer" class="dialog-footer"> <span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false"> </el-button> <el-button @click="dialogVisible = false"> </el-button>
@ -75,40 +100,98 @@
</div> </div>
</template> </template>
<script> <script>
import { miniAppPagesget } from '@/api/goxcx'
import { getToken } from '@/utils/auth'
import { adget, adpost, adput, addelete } from '@/api/application' import { adget, adpost, adput, addelete } from '@/api/application'
import { mapGetters } from 'vuex'
export default { export default {
computed: {
...mapGetters(['qiNiuUploadApi'])
},
data() { data() {
return { return {
tableData: [], headers: {
Authorization: getToken()
},
tourl: [],
query: { query: {
showPosition: "", status: "" showPosition: "", status: ""
}, },
form: { form: {
name: "", sort: "",
path: "", path: "",
status: 1, status: 1,
shopId: localStorage.getItem("shopId"),
showPosition: 'home',
frequency: "only_one"
}, },
title: '新增', title: '新增',
dialogVisible: false dialogVisible: false,
tableData: [],
fileList: [],
} }
}, },
mounted() { mounted() {
this.getList() this.getList()
//
this.getto()
}, },
watch: { filters: {
'form.type': (n, o) => { frequencyFilter(key) {
if (n == 'img') { let str = ""
switch (key) {
case 'only_one':
str = '仅首次展示'
break;
case 'every_show':
str = '每次打开都展示'
break;
case 'every_day':
str = '每天展示一次'
break;
case 'three_day':
str = '每三天展示一次'
break;
case 'seven_day':
str = '每七天展示一次'
break;
case 'thirty_day':
str = '每30天展示一次'
break;
} }
} return str
},
}, },
methods: { methods: {
showChange() { }, successEvent(file) {
this.fileList = [{ url: file.data[0], name: '图片' }]
},
removeEvent(file) {
//
let index = this.fileList.findIndex(ele => ele.url == file.response.data[0])
this.fileList.splice(index, 1);
},
async showChange(a, d) {
this.form.imgUrl = this.fileList
await adput({
...d,
...this.form
})
this.$message({
message: '成功',
type: 'success'
})
},
async getto() {
let res = await miniAppPagesget()
this.tourl = res
},
async sumbit() { async sumbit() {
this.form.imgUrl = this.fileList[0].url
this.dialogVisible = false this.dialogVisible = false
if (this.title == '新增') { if (this.title == '新增') {
await adpost(this.form) await adpost(this.form)
this.$message({ this.$message({
message: '添加成功', message: '添加成功',
type: 'success' type: 'success'
@ -122,8 +205,14 @@ export default {
}) })
} }
this.form = { this.form = {
status: 1 sort: "",
path: "",
status: 1,
shopId: localStorage.getItem("shopId"),
showPosition: 'home',
frequency: "only_one"
} }
this.fileList = []
this.getList() this.getList()
}, },
// //
@ -131,10 +220,12 @@ export default {
this.title = '编辑' this.title = '编辑'
this.dialogVisible = true this.dialogVisible = true
this.form = item this.form = item
console.log(item.imgUrl, '调试1')
this.fileList = [{ url: item.imgUrl, name: '图片' }]
}, },
// //
async delHandle(pagesId) { async delHandle(adId) {
let res = await addelete(pagesId) let res = await addelete(adId)
this.$message({ this.$message({
message: '删除成功', message: '删除成功',
type: 'success' type: 'success'

View File

@ -129,7 +129,7 @@ export default {
if (valid) { if (valid) {
try { try {
this.form.lpNum = this.profitNumber this.form.lpNum = this.profitNumber
// this.form.stockNumber = this.form.stocktakinNum this.form.balance = this.form.stockNumber
this.loading = true this.loading = true
let res = await tbConCheck(this.form) let res = await tbConCheck(this.form)
console.log(this.form); console.log(this.form);

View File

@ -18,8 +18,9 @@
</el-select> </el-select>
</div> </div>
<div style="width: 300px;"> <div style="width: 300px;">
<el-select clearable v-model="query.sort" placeholder="排序"> <el-select v-model="query.sort" placeholder="排序">
<el-option label="按数量排序" value="1" /> <el-option label="默认排序" value="false" />
<el-option label="库存降序" value="true" />
</el-select> </el-select>
</div> </div>
<el-button type="primary" @click="getTableData">查询</el-button> <el-button type="primary" @click="getTableData">查询</el-button>
@ -160,7 +161,7 @@ export default {
montey: "", montey: "",
categorys: [], categorys: [],
query: { query: {
sort: "", // sort: "false", //
name: '', name: '',
isStock: '', isStock: '',
num: '', num: '',
@ -315,7 +316,7 @@ export default {
isStock: this.query.isStock, isStock: this.query.isStock,
num: this.query.num, num: this.query.num,
categoryId: this.query.categoryId, categoryId: this.query.categoryId,
sort:this.query.sort, sort: this.query.sort,
shopId: localStorage.getItem('shopId') shopId: localStorage.getItem('shopId')
}) })
this.tableData.loading = false this.tableData.loading = false

View File

@ -205,6 +205,8 @@ export default {
this.form.id = null this.form.id = null
this.form.productIds = [] this.form.productIds = []
this.productIds = [] this.productIds = []
this.$emit('success', null)
} }
} }
} }

View File

@ -8,8 +8,8 @@
<el-form-item label="最大金额"> <el-form-item label="最大金额">
<el-input-number v-model="form.maxNum" controls-position="right" :min="1"></el-input-number> <el-input-number v-model="form.maxNum" controls-position="right" :min="1"></el-input-number>
</el-form-item> </el-form-item>
<el-form-item label="赠送数量"> <el-form-item label="赠送金额">
<el-input-number v-model="form.handselNum" controls-position="right" :min="1"></el-input-number> <el-input-number v-model="form.handselNum" controls-position="right" :min="0"></el-input-number>
</el-form-item> </el-form-item>
<!-- <el-form-item label="赠送类型"> <!-- <el-form-item label="赠送类型">
<el-select v-model="form.handselType"> <el-select v-model="form.handselType">
@ -20,6 +20,9 @@
<el-form-item label="状态"> <el-form-item label="状态">
<el-switch v-model="form.isDel" active-value="0" inactive-value="1"></el-switch> <el-switch v-model="form.isDel" active-value="0" inactive-value="1"></el-switch>
</el-form-item> </el-form-item>
<el-form-item label="是否赠送商品">
<el-switch v-model="form.isGiftPro" active-value="1" inactive-value="0"></el-switch>
</el-form-item>
<el-form-item label="赠送商品"> <el-form-item label="赠送商品">
<div> <div>
<el-button type="primary" icon="el-icon-plus" @click="$refs.shopListRef.show([...productIds])"> <el-button type="primary" icon="el-icon-plus" @click="$refs.shopListRef.show([...productIds])">
@ -27,12 +30,14 @@
</el-button> </el-button>
</div> </div>
<div class="shop_list"> <div class="shop_list">
<div class="item_wrap" v-for="(item, index) in productIds" :key="item.id" <div class="item_wrap" v-for="(item, index) in productIds" :key="item.id">
@click="productIds.splice(index, 1)"> <div style="display: flex;align-items: center;margin-top: 6px;">
<div class="item" :data-index="index + 1"> <div class="name">{{ item.name }}</div>
<el-image :src="item.coverImg" style="width: 100%;height: 100%;"></el-image> <el-input style="width: 120px;" v-model="item.num" placeholder='请填写数量'
@input="checkIfNum(item)"></el-input>
<el-button type="text" @click="productIds.splice(index, 1)"
style="margin-left: 20px;">删除</el-button>
</div> </div>
<div class="name">{{ item.name }}</div>
</div> </div>
</div> </div>
</el-form-item> </el-form-item>
@ -49,7 +54,7 @@
<script> <script>
import handselTypes from '../handselTypes' import handselTypes from '../handselTypes'
import { modityActivate } from '@/api/shop' import { modityActivate, activate } from '@/api/shop'
import shopList from '@/components/shopList' import shopList from '@/components/shopList'
export default { export default {
@ -113,12 +118,23 @@ export default {
}) })
return falg return falg
}, },
checkIfNum(item) {
item.num = item.num.toString().replace(/\D/g, '');
},
// //
classifySuccess(e) { classifySuccess(e) {
this.form.config.categoryList = e this.form.config.categoryList = e
}, },
onSubmitHandle() { onSubmitHandle() {
console.log(this.form) // console.log(this.form)
let arr = []
this.productIds.forEach(ele => {
arr.push({
productId: ele.id,
num: ele.num
})
})
this.form.products = arr
this.$refs.form.validate(async valid => { this.$refs.form.validate(async valid => {
if (valid) { if (valid) {
try { try {
@ -140,10 +156,13 @@ export default {
} }
}) })
}, },
show(obj) { async show(obj) {
this.dialogVisible = true this.dialogVisible = true
if (obj && obj.id) { if (obj && obj.id) {
this.form = { ...obj } this.form = { ...obj }
let res = await activate(obj.id)
this.productIds = res
console.log(res, '调试1')
} }
}, },
close() { close() {

View File

@ -90,8 +90,14 @@
</el-table-column> </el-table-column>
<el-table-column label="操作" width="200"> <el-table-column label="操作" width="200">
<template v-slot="scope"> <template v-slot="scope">
<el-button type="text" @click="">编辑</el-button> <el-button type="text" @click="edituser(scope.row)">编辑</el-button>
<el-button type="text" @click="editPop(scope.row)">增减余额</el-button> <el-dropdown size="mini" @command="editPop(scope.row)">
<span class="el-dropdown-link" style="font-size: 12px;"> 更多 </span>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item>增减余额</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
<!-- <el-button type="text" @click="editPop(scope.row)">增减余额</el-button> -->
<!-- <el-button type="text" @click="">历史订单</el-button> <!-- <el-button type="text" @click="">历史订单</el-button>
<el-button type="text" @click="">充值记录</el-button> --> <el-button type="text" @click="">充值记录</el-button> -->
@ -108,7 +114,39 @@
@size-change="sizeChange" @current-change="paginationChange" @size-change="sizeChange" @current-change="paginationChange"
layout="total, sizes, prev, pager, next, jumper"></el-pagination> layout="total, sizes, prev, pager, next, jumper"></el-pagination>
</div> </div>
<!-- 编辑用户 -->
<el-dialog title="编辑" :visible.sync="dialogVisibleedit" width="30%">
<el-form ref="form" :model="userinfos" label-width="80px">
<el-form-item label="生日">
<el-date-picker v-model="userinfos.birthday" type="date" placeholder="选择日期" value-format="yyyy-MM-dd">
</el-date-picker>
</el-form-item>
<el-form-item label="会员名称">
<el-input v-model="userinfos.name"></el-input>
</el-form-item>
<el-form-item label="性别">
<el-radio-group v-model="userinfos.sex">
<el-radio label="1"></el-radio>
<el-radio label="2"></el-radio>
</el-radio-group>
</el-form-item>
<!-- <el-form-item label="状态">
<el-radio-group v-model="userinfos.status">
<el-radio label="1">正常</el-radio>
<el-radio label="0">不可使用</el-radio>
</el-radio-group>
</el-form-item> -->
<el-form-item label="联系电话">
<el-input v-model="userinfos.telephone" @input="checkIfNum"></el-input>
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVisibleedit = false"> </el-button>
<el-button type="primary" @click="sumbituser"> </el-button>
</span>
</el-dialog>
<!-- 增减余额弹窗 --> <!-- 增减余额弹窗 -->
<el-dialog title="增减余额" :visible.sync="dialogVisible" width="30%" :before-close="handleClose"> <el-dialog title="增减余额" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">
<el-form ref="form" :model="userinfo" label-width="80px"> <el-form ref="form" :model="userinfo" label-width="80px">
@ -116,31 +154,31 @@
{{ userinfo.nickName }} {{ userinfo.nickName }}
</el-form-item> </el-form-item>
<el-form-item label="增减"> <el-form-item label="增减">
<el-radio-group v-model="userinfo.IncreaseDeduction"> <el-radio-group v-model="userinfo.operationType">
<el-radio :label="1">增加</el-radio> <el-radio label="in">增加</el-radio>
<el-radio :label="2">备选项</el-radio> <el-radio label="out">扣除</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="余额"> <el-form-item label="余额">
<el-input v-model="userinfo.nickName"></el-input> <el-input v-model="userinfo.amount" @input="checkIfNum"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="类型"> <el-form-item label="类型">
<el-radio-group v-model="userinfo.type"> <el-radio-group v-model="userinfo.type">
<el-radio :label="1">消费</el-radio> <el-radio label="consume">消费</el-radio>
<el-radio :label="2">充值退款</el-radio> <el-radio label="inMoney ">充值退款</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</el-form> </el-form>
<span slot="footer" class="dialog-footer"> <span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false"> </el-button> <el-button @click="dialogVisible = false"> </el-button>
<el-button type="primary" @click="dialogVisible = false"> </el-button> <el-button type="primary" @click="sumbit"> </el-button>
</span> </span>
</el-dialog> </el-dialog>
</div> </div>
</template> </template>
<script> <script>
import { queryAllShopUser, queryAllShopInfo } from "@/api/shop"; import { queryAllShopUser, queryAllShopInfo, midfiyAccount, tbShopUseredit } from "@/api/shop";
import dayjs from "dayjs"; import dayjs from "dayjs";
let cacheData = {}; let cacheData = {};
export default { export default {
@ -163,10 +201,16 @@ export default {
total: 0 total: 0
}, },
dialogVisible: false, dialogVisible: false,
dialogVisibleedit: false,
userinfo: { userinfo: {
nickName: '', nickName: '',
IncreaseDeduction: 1, operationType: 'in',
type: 1 type: 'consume'
},
userinfos: {
levelConsume: "0",
sex: '1',
status: '1'
} }
}; };
}, },
@ -176,17 +220,52 @@ export default {
} }
}, },
mounted() { mounted() {
cacheData = { ...this.query }; cacheData = { ...this.query };
this.getTableData(); this.getTableData();
this.getShopInfo(); this.getShopInfo();
}, },
methods: { methods: {
checkIfNum() {
this.userinfo.amount = this.userinfo.amount.toString().replace(/\D/g, '');
},
handleClose() { handleClose() {
this.userinfo = {} this.userinfo = {}
}, },
async sumbituser() {
let res = await tbShopUseredit({
...this.userinfos,
levelConsume:'0',
shopId: localStorage.getItem("shopId"),
})
this.$message.success('修改成功')
this.dialogVisibleedit = false
this.getTableData();
},
async sumbit() {
let res = await midfiyAccount(this.userinfo)
this.dialogVisible = false
this.$message.success('修改成功')
this.getTableData();
},
editPop(d) { editPop(d) {
this.dialogVisible = true this.dialogVisible = true
this.userinfo.nickName = d.nickName this.userinfo.nickName = d.nickName
this.userinfo.id = d.id
},
edituser(d) {
let obj = { ...d }
if (d.sex == '男') {
obj.sex = '1'
} else {
obj.sex = '2'
}
obj.birthday = d.birthDay
obj.name = d.nickName
console.log(obj, '调试1')
this.userinfos = obj
this.dialogVisibleedit = true
}, },
toPage(type) { toPage(type) {
const pages = { const pages = {