积分规则

This commit is contained in:
liuye
2024-08-28 17:55:36 +08:00
parent cd314f3da7
commit 494cc25c4d

View File

@@ -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">&nbsp;添加</el-button> <el-button type="primary" icon="iconfont iconAdd" @click="add">&nbsp;添加</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() {