新增一个渠道管理菜单

This commit is contained in:
邱贞招 2023-12-29 10:37:06 +08:00
parent 552b052ec2
commit b69a81232f
7 changed files with 482 additions and 2 deletions

93
src/api/channel.js Normal file
View File

@ -0,0 +1,93 @@
import request from '@/utils/request';
/**
* 删除渠道表
* @param id
* @constructor
*/
export function DelChannel(id) {
const data = {
id: id,
};
return request({
url: '/admin/channel/delete',
method: 'GET',
params: data,
});
}
/**
* 渠道表详情
* @param id
* @constructor
*/
export function InfoChannel(id) {
const data = {
id: id,
};
return request({
url: '/admin/channel/info',
method: 'get',
params: data,
});
}
/**
* 渠道表列表
* @param pram
* @constructor
*/
export function ListChannel(pram) {
const data = {
productName: pram.productName,
productId: pram.productId,
page: pram.page,
limit: pram.limit,
};
return request({
url: '/admin/channel/list',
method: 'GET',
params: data,
});
}
/**
* 新增渠道表
* @param pram
* @constructor
*/
export function AddChannel(pram) {
const data = {
name: pram.name,
url: pram.url,
price: pram.price,
status: pram.status,
remark: pram.remark,
};
return request({
url: '/admin/channel/save',
method: 'post',
data: data,
});
}
/**
* 更新渠道表
* @param pram
* @constructor
*/
export function UpdateChannel(pram) {
const data = {
name: pram.name,
url: pram.url,
price: pram.price,
status: pram.status,
remark: pram.remark,
};
return request({
url: '/admin/channel/update',
method: 'post',
params: { id: pram.id },
data: data,
});
}

View File

@ -12,6 +12,7 @@ import Layout from '@/layout';
// import componentsRouter from './modules/components'
import storeRouter from './modules/store';
import orderRouter from './modules/order';
import channelRouter from './modules/channel';
import userRouter from './modules/user';
import distributionRouter from './modules/distribution';
import marketingRouter from './modules/marketing';
@ -56,6 +57,8 @@ export const constantRoutes = [
storeRouter,
// 订单
orderRouter,
//渠道
channelRouter,
// 会员
userRouter,
// 分销

View File

@ -0,0 +1,23 @@
import Layout from '@/layout';
const channelRouter = {
path: '/channel',
component: Layout,
redirect: '/channel/index',
name: 'Channel',
alwaysShow: true,
meta: {
title: '渠道',
icon: 'clipboard',
},
children: [
{
path: 'index',
component: () => import('@/views/channel/index'),
name: 'ChannelIndex',
meta: { title: '渠道' },
},
],
};
export default channelRouter;

View File

@ -0,0 +1,167 @@
<template>
<el-dialog
v-if="dialogVisible"
title="添加渠道"
:visible.sync="dialogVisible"
width="500px"
:before-close="handleClose"
>
<el-form :model="channelInfo" :rules="rules" ref="channelInfo" label-width="100px" class="demo-ruleForm" v-loading="loading">
<el-form-item label="渠道名称" prop="name">
<el-input v-model="channelInfo.name" placeholder="请输入渠道名称"></el-input>
</el-form-item>
<el-form-item label="链接" prop="url">
<el-input v-model="channelInfo.url" placeholder="请输入链接"></el-input>
</el-form-item>
<el-form-item label="单价(元)" >
<el-input-number style="width: 60%"
v-model="channelInfo.price"
:min="0"
:step="0.1"
step-strictly
placeholder="请输入单价"
class="selWidthd mr20"
/>
</el-form-item>
<el-form-item label="开关">
<el-switch
v-model="channelInfo.status"
active-text="打开"
inactive-text="关闭"
:active-value="true"
:inactive-value="false"
/>
</el-form-item>
<el-form-item label="备注:" prop="remark">
<el-input type="textarea" v-model="channelInfo.remark"></el-input>
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="resetForm('channelInfo')"> </el-button>
<el-button
type="primary"
@click="submitForm('formValidate')"
v-hasPermi="['admin:setting:update', 'admin:setting:save']"
> </el-button
>
</span>
</el-dialog>
</template>
<script>
import { AddChannel,UpdateChannel} from '@/api/channel';
import { Debounce } from '@/utils/validate';
const obj = {
name: '',
url: '',
price: '',
status: true,
remark: '',
id: null,
};
export default {
name: 'CreatChannel',
props: {
channelInfo: Object,
},
mounted() {
// console.log("channelInfo===="+JSON.stringify(this.channelInfo));
},
data() {
return {
dialogVisible: false,
formValidate: Object.assign({}, obj),
loading: false,
rules: {
name: [{ required: true, message: '请输入渠道名称', trigger: 'blur' }],
url: [{ required: true, message: '请输入链接', trigger: 'blur' }],
price: [{ type: 'number', message: '单价必须为数字值' }],
},
};
},
methods: {
formatPercentage(value) {
if(value == "0.00" || value == "0.0" || value == "0" || value == 0 || value == null){
return "-";
}else {
return (value * 100).toFixed(2) + '%';
}
},
// info(id) {
// this.loading = true;
// levelInfoApi({ id: id })
// .then((res) => {
// this.formValidate = res;
// this.loading = false;
// })
// .catch(() => {
// this.loading = false;
// });
// },
handleClose() {
this.dialogVisible = false;
// this.user = Object.assign({}, '')
},
submitForm: Debounce(function (formName) {
this.$refs.channelInfo.validate((valid) => {
if (valid) {
this.loading = true;
// debugger
// this.channelInfo.amountComesUp = (this.channelInfo.amountComesUpStr)/100;
// this.channelInfo.downPaymentPercent = (this.channelInfo.downPaymentPercentStr)/100;
console.log("----------- "+JSON.stringify(this.channelInfo));
let data = {
name: this.channelInfo.name,
url: this.channelInfo.url,
price: this.channelInfo.price,
status: this.channelInfo.status,
remark: this.channelInfo.remark,
id: this.channelInfo.id
};
this.channelInfo.id
? UpdateChannel(data)
.then((res) => {
this.$message.success('编辑成功');
this.loading = false;
this.handleClose();
this.formValidate = Object.assign({}, obj);
this.$parent.getList();
})
.catch(() => {
this.loading = false;
})
: AddChannel(this.channelInfo)
.then((res) => {
this.$message.success('添加成功');
this.loading = false;
this.handleClose();
this.formValidate = Object.assign({}, obj);
this.$parent.getList();
})
.catch(() => {
this.loading = false;
this.formValidate = Object.assign({}, obj);
});
} else {
return false;
}
});
}),
resetForm(formName) {
this.dialogVisible = false;
this[formName] = {};
// this.$nextTick(() => {
// this.$refs.formData.resetFields();
// })
},
},
};
</script>
<style scoped>
.el-input-number .el-input-group__append {
padding: 0 12px;
line-height: 36px;
border-left: 1px solid #dcdfe6;
}
</style>

194
src/views/channel/index.vue Normal file
View File

@ -0,0 +1,194 @@
<template>
<div class="divBox">
<el-card class="box-card">
<div slot="header" class="clearfix">
<el-button type="primary" class="mr10" @click="add" size="small" v-hasPermi="['admin:channel:save']"
>添加渠道</el-button>
</div>
<el-table v-loading="listLoading" :data="listData.list" style="width: 100%" size="mini">
<el-table-column prop="id" label="ID" min-width="50" />
<el-table-column prop="name" label="渠道名称" min-width="100" />
<el-table-column prop="url" label="链接" min-width="100" />
<el-table-column prop="status" label="开关" min-width="100" >
<template slot-scope="scope" v-if="checkPermi(['admin:category:update:status'])">
<el-switch
v-model="scope.row.status"
:active-value="true"
:inactive-value="false"
active-text="打开"
inactive-text="关闭"
@change="onchangeIsShow(scope.row)"
/>
</template>
</el-table-column>
<el-table-column prop="price" label="单价(元)" min-width="100" />
<el-table-column label="操作" min-width="120" fixed="right" align="center">
<template slot-scope="scope">
<el-button
type="text"
size="small"
@click="edit(scope.row)"
class="mr10"
v-hasPermi="['admin:channel:update']"
>编辑</el-button>
<el-button
type="text"
size="small"
@click="handleDelete(scope.row.id, scope.$index)"
v-hasPermi="['admin:channel:delete']"
>删除</el-button>
</template>
</el-table-column>
</el-table>
<div class="block mb20">
<el-pagination
:current-page="listPram.page"
:page-sizes="constants.page.limit"
:layout="constants.page.layout"
:total="listData.total"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
</el-card>
<creat-channel ref="grades" :channelInfo="channelInfo"></creat-channel>
</div>
</template>
<script>
import { ListChannel,AddChannel,UpdateChannel,InfoChannel,DelChannel} from '@/api/channel';
import creatChannel from './creatChannel';
import { checkPermi } from '@/utils/permission'; //
export default {
name: 'Channel',
filters: {
typeFilter(status) {
const statusMap = {
wechat: '微信用户',
routine: '小程序你用户',
h5: 'H5用户',
};
return statusMap[status];
},
},
components: { creatChannel },
data() {
return {
listLoading: true,
channelInfo: {},
constants: this.$constants,
listPram: {
productId: null,
productName: null,
page: 1,
limit: this.$constants.page.limit[0],
},
listData: { list: [], total: 0 },
tableData: {
data: [],
total: 0,
},
};
},
mounted() {
this.getList();
},
methods: {
formatPercentage(value) {
if(value == "0.00" || value == "0.0" || value == "0" || value == 0 || value == null){
return "-";
}else {
return (value * 100).toFixed(2) + '%';
}
},
formatNumber(value){
if(value == 0){
return "-";
}else {
return value + "期";
}
},
checkPermi,
seachList() {
this.getList();
},
add() {
this.$refs.grades.dialogVisible = true;
this.channelInfo = {status:true};
},
edit(channelInfo) {
// this.$refs.grades.info(id)
// user.amountComesUpStr = user.amountComesUp*100;
// user.downPaymentPercentStr = user.downPaymentPercent*100;
this.channelInfo = channelInfo;
this.$refs.grades.dialogVisible = true;
},
//
getList() {
this.listLoading = true;
ListChannel(this.listPram)
.then((res) => {
this.listData = res;
this.listLoading = false;
})
.catch(() => {
this.listLoading = false;
});
},
//
handleDelete(id, idx) {
this.$modalSure('删除吗?删除会导致对应渠道数据清空,请谨慎操作!').then(() => {
DelChannel(id).then(() => {
this.$message.success('删除成功');
this.getList();
});
});
},
handleSizeChange(val) {
this.listPram.limit = val;
this.handlerGetListData(this.listPram);
},
handleCurrentChange(val) {
this.listPram.page = val;
this.handlerGetListData(this.listPram);
},
onchangeIsShow(row) {
if (row.isShow == false) {
row.isShow = !row.isShow;
UpdateChannel({ id: row.id, isShow: row.isShow })
.then(() => {
this.$message.success('修改成功');
this.getList();
})
.catch(() => {
row.isShow = !row.isShow;
});
} else {
this.$modalSure('确定修改渠道状态吗?').then(() => {
row.isShow = !row.isShow;
// console.log("row-----------"+JSON.stringify(row))
UpdateChannel(row)
.then(() => {
this.$message.success('修改成功');
this.getList();
})
.catch(() => {
row.isShow = !row.isShow;
});
});
}
},
},
};
</script>
<style scoped lang="scss">
.el-switch.is-disabled {
opacity: 1;
}
::v-deep .el-switch__label {
cursor: pointer !important;
}
</style>

View File

@ -719,7 +719,7 @@ export default {
//
sendOrder(row) {
this.orderDetail = null;
if (row.type === 0) {
if (row.type === 0 || row.type === 2) {
this.$refs.send.modals = true;
//Normal
this.$refs.send.express = this.expressListNormal;

View File

@ -142,7 +142,7 @@ export default {
},
//
handleDelete(id, idx) {
this.$modalSure('删除吗?删除会导致对应用户等级数据清空,请谨慎操作!').then(() => {
this.$modalSure('删除吗?删除会导致对应分期套餐配置数据清空,请谨慎操作!').then(() => {
DelInstallments(id).then(() => {
this.$message.success('删除成功');
this.getList();