oil-station/fuintAdmin/src/views/staffCommission/staffCommission.vue

476 lines
17 KiB
Vue
Raw Normal View History

2023-10-31 18:18:30 +08:00
<template>
<div class="app-container">
<el-card>
2023-11-02 18:38:22 +08:00
<el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane label="油品提成方案" name="oil"></el-tab-pane>
<el-tab-pane label="非油品提成方案" name="nonOil"></el-tab-pane>
</el-tabs>
2023-10-31 18:18:30 +08:00
<el-alert
title="方案说明"
type="info"
2023-11-02 18:38:22 +08:00
description="同一角色组、同一参与油品只能设置一种启用的提成方案">
2023-10-31 18:18:30 +08:00
</el-alert>
<div style="margin-top: 20px">
<el-button
type="primary"
icon="el-icon-plus"
@click="handleAdd"
>新增提成方案</el-button>
<el-table ref="tables" v-loading="loading" :data="list"
@selection-change="handleSelectionChange" :default-sort="defaultSort"
@sort-change="handleSortChange">
<el-table-column label="ID" prop="id" align="center" width="60"/>
<el-table-column label="方案名称" prop="name" align="center"/>
2023-11-02 18:38:22 +08:00
<el-table-column label="员工角色" prop="staffRoleGroup" align="center">
2023-10-31 18:18:30 +08:00
<template slot-scope="scope">
<dict-tag :options="dict.type.role" :value="scope.row.staffRoleGroup"/>
</template>
</el-table-column>
<el-table-column label="提成来源" prop="commissionSource" align="center" />
<el-table-column label="满足条件" prop="meetCondition" align="center">
<template slot-scope="scope">
<span v-if="form.type == 'orderAmount'">
订单金额消费满{{scope.row.meetCondition}}
</span>
<span v-if="form.type == 'payAmount'">
实际金额消费满{{scope.row.meetCondition}}
</span>
<span v-if="form.type == 'refuleNum'">
加油数量消费满{{scope.row.meetCondition}}单位/立方
</span>
</template>
</el-table-column>
<el-table-column label="油品提成" prop="royaltyRate" align="center"/>
2023-11-02 18:38:22 +08:00
<!-- <el-table-column label="生效时间" prop="takeEffect" align="center">-->
<!-- <template slot-scope="scope">-->
<!-- <span>-->
<!-- {{JSON.parse(scope.row.takeEffect)[0]}}{{JSON.parse(scope.row.takeEffect)[1]}}-->
<!-- </span>-->
<!-- </template>-->
<!-- </el-table-column>-->
2023-10-31 18:18:30 +08:00
<el-table-column label="方案状态" align="center" prop="status">
<template slot-scope="scope">
<el-tag v-if="scope.row.status=='qy'">启用</el-tag>
<el-tag type="info" v-if="scope.row.status=='jy'">禁用</el-tag>
<!-- <dict-tag :options="dict.type.zhzt" :value="scope.row.status"/>-->
</template>
</el-table-column>
<el-table-column label="更新时间" align="center" width="160" prop="updateTime">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.updateTime) }}</span>
</template>
</el-table-column>
<el-table-column label="操作" align="center" width="120" fixed='right'>
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
size="mini"
type="text"
2023-11-02 18:38:22 +08:00
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
2023-10-31 18:18:30 +08:00
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.page"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</div>
</el-card>
<!-- 添加或修改对话框 -->
<el-dialog :close-on-click-modal="false" :title="title" width="40%" :visible.sync="open" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="90px">
<el-row>
<el-col :span="24">
<el-form-item label="方案名称" prop="name" style="width: 420px">
<el-input v-model="form.name" placeholder="请输入方案名称" maxlength="30" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24" style="display: flex;margin-bottom: 10px">
<el-form-item label="提成来源" prop="commissionSource" style="width: 420px">
2023-11-02 18:38:22 +08:00
<el-radio-group v-model="form.commissionSource">
<el-radio v-for="dict in dict.type.source" @change="isChange" :label="dict.value">{{ dict.label }}</el-radio>
</el-radio-group>
<!-- <el-radio-group v-model="commissionSource" ref="" @change="getCheckbox">-->
<!-- <el-checkbox-->
<!-- v-for="dict in dict.type.source"-->
<!-- :key="dict.value"-->
<!-- :label="dict.label"-->
<!-- :value="dict.value"-->
<!-- ></el-checkbox>-->
<!-- </el-radio-group>-->
2023-10-31 18:18:30 +08:00
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="角色组" prop="staffRoleGroup">
<el-select v-model="form.staffRoleGroup" placeholder="请选择所属角色">
<el-option
v-for="dict in dict.type.role"
:key="dict.value"
:label="dict.label"
:value="dict.value"
></el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="提成类型" prop="type">
<el-radio-group v-model="form.type">
<el-radio v-for="dict in dict.type.comissionType" :label="dict.value">{{ dict.label }}</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="消费条件" prop="meetCondition">
<el-input v-if="form.type == 'orderAmount'" v-model="form.meetCondition">
<template slot="prepend">订单金额消费满</template>
<template slot="append"></template>
</el-input>
<el-input v-if="form.type == 'payAmount'" v-model="form.meetCondition">
<template slot="prepend">实际金额消费满</template>
<template slot="append"></template>
</el-input>
<el-input v-if="form.type == 'refuleNum'" v-model="form.meetCondition">
<template slot="prepend">加油数量消费满</template>
<template slot="append">单位/立方</template>
</el-input>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item label="油品提成" prop="royaltyRate">
<el-input v-model="form.royaltyRate" placeholder="请输入提成">
<el-select v-model="select" style="width: 70px" slot="append" placeholder="请选择">
<el-option label="元" value="元"></el-option>
<el-option label="%" value="%"></el-option>
</el-select>
</el-input>
</el-form-item>
</el-col>
</el-row>
2023-11-02 18:38:22 +08:00
<!-- <el-row>-->
<!-- <el-col :span="24">-->
<!-- <el-form-item label="生效时间" prop="takeEffect">-->
<!-- <el-date-picker-->
<!-- v-model="form.takeEffect"-->
<!-- type="daterange"-->
<!-- value-format="yyyy-MM-dd HH:mm:ss"-->
<!-- range-separator="至"-->
<!-- start-placeholder="开始日期"-->
<!-- end-placeholder="结束日期">-->
<!-- </el-date-picker>-->
<!-- <div style="font-size: 12px;color: grey">时间范围内的油品交易有效</div>-->
<!-- </el-form-item>-->
<!-- </el-col>-->
<!-- </el-row>-->
2023-10-31 18:18:30 +08:00
<el-row>
<el-col :span="24">
<el-form-item label="方案状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio v-for="dict in dict.type.zhzt" :label="dict.value">{{ dict.label }}</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
</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>
</div>
</template>
<script>
2023-11-02 18:38:22 +08:00
import {
addCommission, delCommission,
getCommission,
listCommission,
queryCommission,
updateCommission
} from "@/api/staffCommission/staffcommission";
2023-10-31 18:18:30 +08:00
export default {
dicts: ['source','role','zhzt','comissionType'],
data(){
return {
2023-11-02 18:38:22 +08:00
changeCom:false,
activeName: 'oil',
2023-10-31 18:18:30 +08:00
select:"元",
commissionSource:[],
// 遮罩层
loading: true,
// 标题
title: "",
// 总条数
total: 0,
// 表格数据
list: [],
// 是否显示修改对话框
open: false,
// 默认排序
defaultSort: {prop: 'updateTime', order: 'descending'},
// 查询参数
queryParams: {
page: 1,
pageSize: 10,
id: '',
name: '',
2023-11-02 18:38:22 +08:00
commissionSource:'油品'
2023-10-31 18:18:30 +08:00
},
// 表单参数
form: {
type:'orderAmount',
status:'qy'
},
// 显示搜索条件
showSearch: true,
// 表单校验
rules: {
name: [
{ required: true, message: "供应商名称不能为空", trigger: "blur" },
],
commissionSource: [
{ required: true, message: "请选择提成来源", trigger: "blur" },
],
staffRoleGroup: [
{ required: true, message: "请选择角色组", trigger: "blur" },
],
type: [
{ required: true, message: "请选择提成类型", trigger: "blur" },
],
meetCondition: [
{ required: true, message: "请填写提成消费条件", trigger: "blur" },
],
royaltyRate: [
{ required: true, message: "请填写油品提成", trigger: "blur" },
],
2023-11-02 18:38:22 +08:00
// takeEffect: [
// { required: true, message: "请选择方案生效时间", trigger: "change" },
// ],
2023-10-31 18:18:30 +08:00
status: [
{ required: true, message: "请选择方案状态", trigger: "blur" },
],
}
}
},
created() {
this.getList();
},
methods:{
2023-11-02 18:38:22 +08:00
// 点击标签页
handleClick(tab, event) {
if (this.activeName == 'oil'){
this.queryParams = {
page: 1,
pageSize: 10,
id: '',
name: '',
commissionSource:'油品'
};
this.getList();
}else {
this.queryParams = {
page: 1,
pageSize: 10,
id: '',
name: '',
commissionSource:'非油品'
};
this.getList();
}
},
2023-10-31 18:18:30 +08:00
getCheckbox(){
this.form.commissionSource = this.commissionSource.toString()
},
// 查询列表
getList() {
this.loading = true;
listCommission(this.queryParams).then(response => {
this.list = response.data.records;
this.total = response.data.total;
this.loading = false;
});
},
// 表单重置
reset() {
this.resetForm("form");
2023-11-02 18:38:22 +08:00
if (this.activeName == 'oil'){
this.form = {
type:'orderAmount',
status:'qy',
commissionSource:'油品'
};
}else {
this.form = {
type:'orderAmount',
status:'qy',
commissionSource:'非油品'
};
2023-10-31 18:18:30 +08:00
}
},
// 新增按钮操作
handleAdd() {
this.reset();
this.open = true;
this.title = "新增提成方案";
},
// 修改按钮操作
handleUpdate(row) {
this.reset();
const id = row.id || this.ids;
getCommission(id).then(response => {
this.form = response.data;
2023-11-02 18:38:22 +08:00
// this.commissionSource = this.form.commissionSource.split(",")
// this.form.takeEffect = JSON.parse(this.form.takeEffect)
2023-10-31 18:18:30 +08:00
this.form.royaltyRate = this.form.royaltyRate.slice(0,this.form.royaltyRate.length-1)
this.open = true;
this.title = "编辑提成方案";
});
},
2023-11-02 18:38:22 +08:00
// 删除按钮操作
handleDelete(row) {
const name = row.name
this.$modal.confirm('确定删除"' + name + '"的提成方案信息?').then(function() {
return delCommission(row.id);
}).then(() => {
this.queryParams.page = 1
2023-10-31 18:18:30 +08:00
this.getList();
2023-11-02 18:38:22 +08:00
this.$modal.msgSuccess("删除成功");
}).catch(() => {});
},
// 判断提成来源是否改变
isChange(){
this.changeCom = true;
},
add0(m){
return m<10?'0'+m:m
2023-10-31 18:18:30 +08:00
},
// 提交按钮
submitForm: function() {
this.$refs["form"].validate(valid => {
if (valid) {
2023-11-02 18:38:22 +08:00
// let date = new Date();
// let year = date.getFullYear()
// let month = date.getMonth()+1
// let day = date.getDate()
// let hour = date.getHours()
// let minutes = date.getMinutes()
// let second = date.getSeconds()
// let now = year+"-"+this.add0(month)+"-"+this.add0(day)+" "+hour+":"+minutes+":"+second
// if(this.form.takeEffect[0] < now && this.form.takeEffect[1] > now){
// this.form.status = 'qy'
// }else {
// this.form.status = 'jy'
// }
// // this.form.commissionSource = this.commissionSource.toString()
// this.form.takeEffect = JSON.stringify(this.form.takeEffect)
2023-10-31 18:18:30 +08:00
if (this.form.id) {
2023-11-02 18:38:22 +08:00
if (this.changeCom){
queryCommission(this.form).then(response => {
if (response.data != null) {
if (this.changeCom) {
this.$modal.msgError("同一个角色组只能对应一个" + this.form.commissionSource + "提成方案")
}else {
this.$modal.msgError("当前时间段已存在相同油品、相同角色组的方案")
}
} else {
this.form.royaltyRate = this.form.royaltyRate + this.select
updateCommission(this.form).then(response => {
this.$modal.msgSuccess("提成方案更新成功");
this.open = false;
this.changeCom = false;
this.getList();
});
}
})
}else {
this.form.royaltyRate = this.form.royaltyRate + this.select
updateCommission(this.form).then(response => {
this.$modal.msgSuccess("提成方案更新成功");
this.open = false;
this.getList();
});
}
2023-10-31 18:18:30 +08:00
} else {
2023-11-02 18:38:22 +08:00
queryCommission(this.form).then(response => {
if (response.data != null){
if (response.data.status == 'qy'){
this.$modal.msgError("同一个角色组只能对应一个"+this.form.commissionSource+"提成方案")
}else {
this.form.royaltyRate = this.form.royaltyRate + this.select
addCommission(this.form).then(response => {
this.$modal.msgSuccess("提成方案新增成功");
this.open = false;
this.getList();
});
}
}else {
this.form.royaltyRate = this.form.royaltyRate + this.select
addCommission(this.form).then(response => {
this.$modal.msgSuccess("提成方案新增成功");
this.open = false;
this.getList();
});
}
})
2023-10-31 18:18:30 +08:00
}
}
});
},
// 取消按钮
cancel() {
this.open = false;
this.reset();
},
// 多选框选中数据
handleSelectionChange(selection) {
this.ids = selection.map(item => item.id)
this.multiple = !selection.length
},
// 排序触发事件
handleSortChange(column, prop, order) {
this.queryParams.orderByColumn = column.prop;
this.queryParams.isAsc = column.order;
this.getList();
},
}
}
</script>
<style lang="scss" scoped>
.app-container{
width: 100%;
height: 100vh;
background: #f6f8f9;
}
</style>