积分规则
This commit is contained in:
@@ -5,7 +5,7 @@
|
|||||||
<template slot="content">
|
<template slot="content">
|
||||||
<ai-search-bar>
|
<ai-search-bar>
|
||||||
<template #left>
|
<template #left>
|
||||||
<el-button type="primary" icon="iconfont iconAdd" @click="dialog = true"> 添加</el-button>
|
<el-button type="primary" icon="iconfont iconAdd" @click="add"> 添加</el-button>
|
||||||
<el-cascader size="small" v-model="systemRuleIdList" :options="rulesOps" placeholder="请选择事件/类型" clearable :props="rulesProps"
|
<el-cascader size="small" v-model="systemRuleIdList" :options="rulesOps" placeholder="请选择事件/类型" clearable :props="rulesProps"
|
||||||
@change="handleTypeSearch" ref="eventTypeSearch"/>
|
@change="handleTypeSearch" ref="eventTypeSearch"/>
|
||||||
<ai-select v-model="search.status" @change="(page.current = 1), getList()" placeholder="请选择状态" :selectList="$dict.getDict('integralRuleStatus')">
|
<ai-select v-model="search.status" @change="(page.current = 1), getList()" placeholder="请选择状态" :selectList="$dict.getDict('integralRuleStatus')">
|
||||||
@@ -47,7 +47,7 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="规则">
|
<el-form-item label="规则">
|
||||||
<div>常规</div>
|
<div>{{form.systemRuleId != '自定义' ? form.ruleType == 1 ? '阶梯' : '常规' : '常规'}}</div>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<!-- <el-form-item label="规则" prop="ruleType" v-if="form.ruleType>-1" required>
|
<!-- <el-form-item label="规则" prop="ruleType" v-if="form.ruleType>-1" required>
|
||||||
@@ -85,15 +85,42 @@
|
|||||||
<el-input type="number" placeholder="请输入,周期范围内,不填写表示不限制" v-model.number="form.numberLimit" clearable :disabled="isOneAndTen"/>
|
<el-input type="number" placeholder="请输入,周期范围内,不填写表示不限制" v-model.number="form.numberLimit" clearable :disabled="isOneAndTen"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="工单处理要求时长" prop="workHoursLimit" v-if="isWorkOrder">
|
|
||||||
<el-input-number v-model="form.workHoursLimit" :min="1" :max="100" label="工作日"></el-input-number>
|
|
||||||
</el-form-item>
|
|
||||||
|
|
||||||
|
|
||||||
<el-form-item label="积分分值" prop="integral">
|
<el-form-item label="积分分值" prop="integral" v-if="!isWorkOrder">
|
||||||
<el-input placeholder="请输入" v-model="form.integral" clearable/>
|
<el-input placeholder="请输入" v-model="form.integral" clearable/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
|
<!-- 工单 -->
|
||||||
|
<el-form-item label="规则明细" prop="ladderRule" v-if="isWorkOrder">
|
||||||
|
<el-row type="flex" justify="space-between">
|
||||||
|
<div>从小到大顺序配置</div>
|
||||||
|
<el-button type="text" icon="iconfont iconAdd" @click="addIntegral">添加</el-button>
|
||||||
|
</el-row>
|
||||||
|
<el-table :data="form.ladderRuleList" size="mini" border stripe>
|
||||||
|
<el-table-column label="工作日区间" align="center" width="400">
|
||||||
|
<template slot-scope="{row}">
|
||||||
|
大于等于
|
||||||
|
<!-- <el-input-number class="tableInput" v-model="row.ge" :min="0" label="请输入" style="margin-right:8px;"></el-input-number> -->
|
||||||
|
<el-input placeholder="请输入" v-model="row.ge" clearable style="margin-right:8px;width:100px;" @keyup.native="row.ge=checkGe(row.ge)"/>
|
||||||
|
小于
|
||||||
|
<el-input placeholder="请输入" v-model="row.lt" clearable @keyup.native="row.lt=checkGe(row.lt)" style="width:100px;"/>
|
||||||
|
<!-- <el-input-number class="tableInput" v-model="row.lt" :min="0" label="请输入"></el-input-number> -->
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="积分" align="center">
|
||||||
|
<template slot-scope="{row}">
|
||||||
|
<el-input class="tableInput" v-model="row.integral" clearable placeholder="请输入" type="number"
|
||||||
|
@keyup.native="row.integral=checkIntegral(row.integral)"/>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="" align="center">
|
||||||
|
<template slot-scope="{ $index }">
|
||||||
|
<el-button type="text" @click="handleDeleteRule($index)">删除</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="有效范围" prop="validRangeType" required>
|
<el-form-item label="有效范围" prop="validRangeType" required>
|
||||||
<el-radio-group v-model="form.validRangeType">
|
<el-radio-group v-model="form.validRangeType">
|
||||||
<el-radio label="0">全局</el-radio>
|
<el-radio label="0">全局</el-radio>
|
||||||
@@ -150,7 +177,7 @@ export default {
|
|||||||
} else {
|
} else {
|
||||||
callback(new Error('请输入积分分值'));
|
callback(new Error('请输入积分分值'));
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
return {
|
return {
|
||||||
search: {
|
search: {
|
||||||
status: "",
|
status: "",
|
||||||
@@ -183,7 +210,6 @@ export default {
|
|||||||
);
|
);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{prop: "workHoursLimit", label: "工单处理要求时长", align: "center"},
|
|
||||||
{slot: "integral", label: "积分分值", align: "center"},
|
{slot: "integral", label: "积分分值", align: "center"},
|
||||||
{
|
{
|
||||||
prop: "validRangeType",
|
prop: "validRangeType",
|
||||||
@@ -210,7 +236,7 @@ export default {
|
|||||||
integral: "",
|
integral: "",
|
||||||
validRangeType: "0",
|
validRangeType: "0",
|
||||||
validRangeData: "",
|
validRangeData: "",
|
||||||
workHoursLimit: 1
|
ladderRuleList: []
|
||||||
},
|
},
|
||||||
formRules: {
|
formRules: {
|
||||||
systemRuleId: [
|
systemRuleId: [
|
||||||
@@ -222,13 +248,13 @@ export default {
|
|||||||
scoringCycle: [
|
scoringCycle: [
|
||||||
{required: true, message: "请选择周期范围", trigger: "change"},
|
{required: true, message: "请选择周期范围", trigger: "change"},
|
||||||
],
|
],
|
||||||
workHoursLimit: [
|
integral: [{required: true, validator: validcode, trigger: "blur"}],
|
||||||
{required: true, message: "请输入工单处理要求时长", trigger: "change"},
|
|
||||||
],
|
|
||||||
integral: [{required: true, validator: validcode, trigger: "blur"},],
|
|
||||||
validRangeType: [
|
validRangeType: [
|
||||||
{required: true, message: "请选择有效范围", trigger: "change"},
|
{required: true, message: "请选择有效范围", trigger: "change"},
|
||||||
],
|
],
|
||||||
|
ladderRuleList: [
|
||||||
|
{required: true, message: "请输入积分值", trigger: "change"},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
rulesOps: [],
|
rulesOps: [],
|
||||||
rulesProps: {
|
rulesProps: {
|
||||||
@@ -252,12 +278,13 @@ export default {
|
|||||||
girdNameList: [],
|
girdNameList: [],
|
||||||
list: [],
|
list: [],
|
||||||
isOneAndTen: false,
|
isOneAndTen: false,
|
||||||
isWorkOrder: false
|
isWorkOrder: false,
|
||||||
|
typeList: []
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.$dict.load("integralRuleStatus", "integralRuleRuleType", "integralRuleScoringCycle",
|
this.$dict.load("integralRuleStatus", "integralRuleRuleType", "integralRuleScoringCycle",
|
||||||
"integralRuleEvent", "integralRuleEventType").then(() => {
|
"integralRuleEvent", "integralRuleEventType", "qjEACondition").then(() => {
|
||||||
this.getList();
|
this.getList();
|
||||||
this.getRulesList();
|
this.getRulesList();
|
||||||
});
|
});
|
||||||
@@ -304,6 +331,7 @@ export default {
|
|||||||
this.isWorkOrder = false
|
this.isWorkOrder = false
|
||||||
if(row.parentRuleName == '工单处理') {
|
if(row.parentRuleName == '工单处理') {
|
||||||
this.isWorkOrder = true
|
this.isWorkOrder = true
|
||||||
|
this.form.ladderRuleList = JSON.parse(this.form.ladderRule)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
remove(id) {
|
remove(id) {
|
||||||
@@ -334,10 +362,20 @@ export default {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
onConfirm() {
|
onConfirm() {
|
||||||
|
var isWork = true
|
||||||
|
this.form.ladderRuleList.map((item) => {
|
||||||
|
if(!item.integral) {
|
||||||
|
isWork = false
|
||||||
|
}
|
||||||
|
})
|
||||||
|
if(!isWork) {
|
||||||
|
return this.$message.error('请输入分值')
|
||||||
|
}
|
||||||
this.$refs.DialogForm.validate((valid) => {
|
this.$refs.DialogForm.validate((valid) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
let formData = this.$copy(this.form);
|
let formData = this.$copy(this.form);
|
||||||
// formData.ladderRule = JSON.stringify(formData.ladderRule)
|
formData.ladderRule = JSON.stringify(formData.ladderRuleList)
|
||||||
|
console.log(formData.ladderRule)
|
||||||
formData.integral = formData.integral || 0;
|
formData.integral = formData.integral || 0;
|
||||||
this.instance
|
this.instance
|
||||||
.post(`/app/appintegralrule/addOrUpdate`, formData)
|
.post(`/app/appintegralrule/addOrUpdate`, formData)
|
||||||
@@ -347,10 +385,12 @@ export default {
|
|||||||
`${this.isEdit ? "编辑成功" : "添加成功"}`
|
`${this.isEdit ? "编辑成功" : "添加成功"}`
|
||||||
);
|
);
|
||||||
this.dialog = false;
|
this.dialog = false;
|
||||||
|
this.isWorkOrder = false
|
||||||
this.getList();
|
this.getList();
|
||||||
this.closed();
|
this.closed();
|
||||||
this.girdInfoList = []
|
this.girdInfoList = []
|
||||||
this.girdNameList = []
|
this.girdNameList = []
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
@@ -358,6 +398,20 @@ export default {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
add() {
|
||||||
|
this.form = {
|
||||||
|
ruleType: "0",
|
||||||
|
systemRuleId: "",
|
||||||
|
ruleName: "",
|
||||||
|
scoringCycle: "",
|
||||||
|
numberLimit: "",
|
||||||
|
integral: "",
|
||||||
|
validRangeType: "0",
|
||||||
|
validRangeData: "",
|
||||||
|
ladderRuleList: []
|
||||||
|
}
|
||||||
|
this.dialog = true
|
||||||
|
},
|
||||||
handleTypeSearch(v) {
|
handleTypeSearch(v) {
|
||||||
this.systemRuleIdList = v
|
this.systemRuleIdList = v
|
||||||
this.search.systemRuleId = v?.[v.length - 1];
|
this.search.systemRuleId = v?.[v.length - 1];
|
||||||
@@ -368,37 +422,52 @@ export default {
|
|||||||
},
|
},
|
||||||
handleTypeForm(v) {
|
handleTypeForm(v) {
|
||||||
console.log(v)
|
console.log(v)
|
||||||
this.isWorkOrder = false
|
|
||||||
if (this.dialog) {
|
if (this.dialog) {
|
||||||
if(v[0] == '1' || v[0]== '10') {
|
if(v[0] == '1' || v[0]== '10') {
|
||||||
this.form.scoringCycle = '0'
|
this.form.scoringCycle = '0'
|
||||||
this.form.numberLimit = '1'
|
this.form.numberLimit = '1'
|
||||||
this.isOneAndTen = true
|
this.isOneAndTen = true
|
||||||
|
this.isWorkOrder = false
|
||||||
|
this.form.ladderRuleList = []
|
||||||
} else if(v[0] == '20') { //工单处理
|
} else if(v[0] == '20') { //工单处理
|
||||||
this.isWorkOrder = true
|
this.isWorkOrder = true
|
||||||
|
this.form.ladderRuleList = [{ ge: null, lt: null, integral: null }]
|
||||||
} else {
|
} else {
|
||||||
this.form.scoringCycle = ''
|
this.form.scoringCycle = ''
|
||||||
this.form.numberLimit = ''
|
this.form.numberLimit = ''
|
||||||
this.isOneAndTen = false
|
this.isOneAndTen = false
|
||||||
|
this.isWorkOrder = false
|
||||||
|
this.form.ladderRuleList = []
|
||||||
}
|
}
|
||||||
this.form.systemRuleId = v?.[v.length - 1];
|
this.form.systemRuleId = v?.[v.length - 1];
|
||||||
|
if(v != '自定义') {
|
||||||
|
this.typeList.map((item) => {
|
||||||
|
if(item.id == v[1]) {
|
||||||
|
this.form.ruleType = item.ruleType
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleDelete(i) {
|
handleDelete(i) {
|
||||||
this.$confirm("是否要删除该规则?")
|
this.$confirm("是否要删除该规则?")
|
||||||
.then(() => {
|
.then(() => {
|
||||||
this.form.ladderRule.splice(i, 1);
|
this.form.ladderRuleList.splice(i, 1);
|
||||||
})
|
})
|
||||||
.catch(() => 0);
|
.catch(() => 0);
|
||||||
},
|
},
|
||||||
checkIntegral(v) {
|
checkIntegral(v) {
|
||||||
return /\.\d{2,}$/.test(v) ? Math.abs(v).toFixed(1) : Math.abs(v);
|
return /^\d+$/.test(v) ? Math.abs(v).toFixed(1) : Math.abs(v);
|
||||||
|
},
|
||||||
|
checkGe(v) {
|
||||||
|
return /\.\d{2,}$/.test(v) ? v : Math.floor(v);
|
||||||
},
|
},
|
||||||
getRulesList() {
|
getRulesList() {
|
||||||
this.instance
|
this.instance
|
||||||
.post(`/app/appintegralsystemrule/list?current=1&size=3000`)
|
.post(`/app/appintegralsystemrule/list?current=1&size=3000`)
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
if (res?.data) {
|
if (res?.data) {
|
||||||
|
this.typeList = res.data.records
|
||||||
this.rulesOps = this.toTree(res.data.records);
|
this.rulesOps = this.toTree(res.data.records);
|
||||||
this.rulesOps.push({
|
this.rulesOps.push({
|
||||||
ruleName: "自定义",
|
ruleName: "自定义",
|
||||||
@@ -462,7 +531,15 @@ export default {
|
|||||||
} else {
|
} else {
|
||||||
delete this.treeSelected[data.id]
|
delete this.treeSelected[data.id]
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
addIntegral() {
|
||||||
|
this.form.ladderRuleList?.push({ ge: null, lt: null, integral: null })
|
||||||
|
},
|
||||||
|
handleDeleteRule(i) {
|
||||||
|
this.$confirm("是否要删除该规则?").then(() => {
|
||||||
|
this.form.ladderRuleList.splice(i, 1)
|
||||||
|
}).catch(() => 0)
|
||||||
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
isEdit() {
|
isEdit() {
|
||||||
|
|||||||
Reference in New Issue
Block a user