积分规则

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">
<ai-search-bar>
<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"
@change="handleTypeSearch" ref="eventTypeSearch"/>
<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 label="规则">
<div>常规</div>
<div>{{form.systemRuleId != '自定义' ? form.ruleType == 1 ? '阶梯' : '常规' : '常规'}}</div>
</el-form-item>
<!-- <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-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-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-radio-group v-model="form.validRangeType">
<el-radio label="0">全局</el-radio>
@@ -150,7 +177,7 @@ export default {
} else {
callback(new Error('请输入积分分值'));
}
}
};
return {
search: {
status: "",
@@ -183,7 +210,6 @@ export default {
);
},
},
{prop: "workHoursLimit", label: "工单处理要求时长", align: "center"},
{slot: "integral", label: "积分分值", align: "center"},
{
prop: "validRangeType",
@@ -210,7 +236,7 @@ export default {
integral: "",
validRangeType: "0",
validRangeData: "",
workHoursLimit: 1
ladderRuleList: []
},
formRules: {
systemRuleId: [
@@ -222,13 +248,13 @@ export default {
scoringCycle: [
{required: true, message: "请选择周期范围", trigger: "change"},
],
workHoursLimit: [
{required: true, message: "请输入工单处理要求时长", trigger: "change"},
],
integral: [{required: true, validator: validcode, trigger: "blur"},],
integral: [{required: true, validator: validcode, trigger: "blur"}],
validRangeType: [
{required: true, message: "请选择有效范围", trigger: "change"},
],
ladderRuleList: [
{required: true, message: "请输入积分值", trigger: "change"},
],
},
rulesOps: [],
rulesProps: {
@@ -252,12 +278,13 @@ export default {
girdNameList: [],
list: [],
isOneAndTen: false,
isWorkOrder: false
isWorkOrder: false,
typeList: []
};
},
created() {
this.$dict.load("integralRuleStatus", "integralRuleRuleType", "integralRuleScoringCycle",
"integralRuleEvent", "integralRuleEventType").then(() => {
"integralRuleEvent", "integralRuleEventType", "qjEACondition").then(() => {
this.getList();
this.getRulesList();
});
@@ -304,6 +331,7 @@ export default {
this.isWorkOrder = false
if(row.parentRuleName == '工单处理') {
this.isWorkOrder = true
this.form.ladderRuleList = JSON.parse(this.form.ladderRule)
}
},
remove(id) {
@@ -334,10 +362,20 @@ export default {
});
},
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) => {
if (valid) {
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;
this.instance
.post(`/app/appintegralrule/addOrUpdate`, formData)
@@ -347,10 +385,12 @@ export default {
`${this.isEdit ? "编辑成功" : "添加成功"}`
);
this.dialog = false;
this.isWorkOrder = false
this.getList();
this.closed();
this.girdInfoList = []
this.girdNameList = []
}
});
} 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) {
this.systemRuleIdList = v
this.search.systemRuleId = v?.[v.length - 1];
@@ -368,37 +422,52 @@ export default {
},
handleTypeForm(v) {
console.log(v)
this.isWorkOrder = false
if (this.dialog) {
if(v[0] == '1' || v[0]== '10') {
this.form.scoringCycle = '0'
this.form.numberLimit = '1'
this.isOneAndTen = true
this.isWorkOrder = false
this.form.ladderRuleList = []
} else if(v[0] == '20') { //工单处理
this.isWorkOrder = true
this.form.ladderRuleList = [{ ge: null, lt: null, integral: null }]
} else {
this.form.scoringCycle = ''
this.form.numberLimit = ''
this.isOneAndTen = false
this.isWorkOrder = false
this.form.ladderRuleList = []
}
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) {
this.$confirm("是否要删除该规则?")
.then(() => {
this.form.ladderRule.splice(i, 1);
this.form.ladderRuleList.splice(i, 1);
})
.catch(() => 0);
},
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() {
this.instance
.post(`/app/appintegralsystemrule/list?current=1&size=3000`)
.then((res) => {
if (res?.data) {
this.typeList = res.data.records
this.rulesOps = this.toTree(res.data.records);
this.rulesOps.push({
ruleName: "自定义",
@@ -462,7 +531,15 @@ export default {
} else {
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: {
isEdit() {