You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
900 lines
31 KiB
900 lines
31 KiB
<template> |
|
<div ref="main" |
|
class="main" |
|
v-loading="loading"> |
|
<el-form :disabled="isDetail"> |
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<div class="flex-between"> |
|
<el-page-header @back="back" |
|
content="项目配置"></el-page-header> |
|
<div v-if="!isDetail"> |
|
<el-button type="success" |
|
:loading="submiting === 0" |
|
@click="save(0)">保存为草稿</el-button> |
|
<el-button type="primary" |
|
:loading="submiting === 1" |
|
@click="save(1)">确定并发布</el-button> |
|
</div> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<h6 class="p-title">基本信息</h6> |
|
<div> |
|
<el-form label-width="80px" |
|
:disabled="isDetail"> |
|
<div class="flex"> |
|
<el-form-item label="课程"> |
|
<el-cascader v-if="projectManage.founder" |
|
v-model="mallIds" |
|
:options="curs" |
|
:props="{ checkStrictly: true, value: 'id' }" |
|
popper-class="course-cas" |
|
@expand-change="curChange" |
|
@change="curChange"></el-cascader> |
|
|
|
<el-select v-else |
|
v-model="projectManage.systemId" |
|
placeholder="请选择" |
|
@change="systemChange"> |
|
<el-option v-for="item in systemList" |
|
:key="item.id" |
|
:label="item.label" |
|
:value="item.id"></el-option> |
|
</el-select> |
|
</el-form-item> |
|
<el-form-item label="项目名称"> |
|
<el-input v-model.trim="projectManage.projectName" |
|
placeholder="20个字符以内" |
|
@blur="projectNameExistis"></el-input> |
|
</el-form-item> |
|
<el-form-item label="项目用途"> |
|
<el-select v-model="projectManage.permissions" |
|
placeholder="请选择" |
|
@change="permissionChange"> |
|
<el-option label="练习" |
|
:value="0"></el-option> |
|
<el-option label="考核" |
|
:value="1"></el-option> |
|
<el-option label="竞赛" |
|
:value="2"></el-option> |
|
</el-select> |
|
</el-form-item> |
|
</div> |
|
</el-form> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<h6 class="p-title">实验目标</h6> |
|
<div> |
|
<el-form label-width="0"> |
|
<el-form-item> |
|
<quill :border="true" |
|
:readonly="isDetail" |
|
v-model="projectManage.experimentTarget" |
|
:type.sync="projectManage.experimentTargetType" |
|
radio |
|
:minHeight="150" |
|
:height="150" /> |
|
</el-form-item> |
|
</el-form> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<h6 class="p-title">项目背景</h6> |
|
<div> |
|
<el-form label-width="0"> |
|
<el-form-item> |
|
<quill :border="true" |
|
:readonly="isDetail" |
|
v-model="projectManage.experimentDescription" |
|
:type.sync="projectManage.experimentDescriptionType" |
|
radio |
|
:minHeight="150" |
|
:height="150" |
|
:index="1" /> |
|
</el-form-item> |
|
</el-form> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<div class="m-b-20 flex-between"> |
|
<h6 class="p-title" |
|
style="margin-bottom: 0">实验任务</h6> |
|
<div> |
|
<!--<el-button :disabled="isDetail" type="primary" @click="toJudgePoint('home')">进入判分点</el-button>--> |
|
</div> |
|
</div> |
|
<div class="m-b-20 flex-between"> |
|
<div class="flex-center"> |
|
<div class="m-r-20" |
|
style="color: #f00">项目总分值:100分</div> |
|
<!-- <div>权重 <div class="dib"><el-input></el-input></div></div> --> |
|
</div> |
|
<div> |
|
<el-button class="m-r-20" |
|
type="text" |
|
@click="avgDistributionScore">平均分配分值</el-button> |
|
<el-button class="m-r-20" |
|
type="text" |
|
@click="manualDistributionScore">手动分配分值</el-button> |
|
<span>(待分配分值: {{ handDistributionScore }}/100分)</span> |
|
</div> |
|
</div> |
|
<el-button type="primary" |
|
icon="el-icon-plus" |
|
round |
|
@click="handleQueryJudgment" |
|
style="margin-bottom: 10px">判分点</el-button> |
|
<el-button type="primary" |
|
icon="el-icon-delete" |
|
round |
|
@click="batchDeleteProjectJudgment" |
|
style="margin-bottom: 10px">批量删除</el-button> |
|
<div class="draggable"> |
|
<u-table ref="projectJudgementTable" |
|
:data="projectJudgmentData" |
|
class="table" |
|
stripe |
|
header-align="center" |
|
:use-virtual="isLc" |
|
:max-height="600" |
|
:row-height="60" |
|
:border="false" |
|
@selection-change="handleSelectionProjectJudgment" |
|
row-key="judgmentId" |
|
v-loading="listLoading"> |
|
<u-table-column type="selection" |
|
width="55" |
|
align="center"></u-table-column> |
|
<u-table-column prop="sort" |
|
label="序号" |
|
width="80" |
|
align="center"> |
|
<template slot-scope="scope"> |
|
{{ scope.row.sort }} |
|
</template> |
|
</u-table-column> |
|
<u-table-column prop="name" |
|
label="判分指标" |
|
align="center" |
|
show-overflow-tooltip |
|
min-width="140"></u-table-column> |
|
<u-table-column prop="name" |
|
label="判分点名称" |
|
align="center" |
|
show-overflow-tooltip |
|
min-width="140"></u-table-column> |
|
<u-table-column label="实验要求" |
|
align="center" |
|
width="600"> |
|
<template slot-scope="scope"> |
|
<quill :readonly="true" |
|
elseRead="true" |
|
v-model="scope.row.experimentalRequirements" |
|
:index="2" /> |
|
</template> |
|
</u-table-column> |
|
<u-table-column prop="score" |
|
label="分数" |
|
align="center" |
|
width="120"> |
|
<template slot-scope="scope"> |
|
<el-input :key="scope.$index" |
|
type="number" |
|
step="0.1" |
|
v-model.trim="scope.row.score"></el-input> |
|
<!-- |
|
@input="scoreChange(scope.row, scope.$index)" --> |
|
</template> |
|
</u-table-column> |
|
<u-table-column label="操作" |
|
width="100" |
|
align="center"> |
|
<template slot-scope="scope"> |
|
<!--<el-button :disabled="isDetail" type="text" style="margin-right: 10px" @click="toJudgePoint('edit', scope.row)">自定义</el-button>--> |
|
<el-button type="text" |
|
@click="delJudgePoint(scope.$index)">删除</el-button> |
|
</template> |
|
</u-table-column> |
|
</u-table> |
|
</div> |
|
</el-card> |
|
|
|
<el-card shadow="hover" |
|
class="m-b-20"> |
|
<div class="m-b-20 flex-between"> |
|
<h6 class="p-title" |
|
style="margin-bottom: 0">实验提示</h6> |
|
<div> |
|
启用 |
|
<el-switch :active-value="0" |
|
:inactive-value="1" |
|
v-model="projectManage.hintOpen"></el-switch> |
|
</div> |
|
</div> |
|
<div> |
|
<el-form label-width="0"> |
|
<el-form-item prop="tips" |
|
label=""> |
|
<quill :border="true" |
|
:readonly="isDetail" |
|
v-model="projectManage.experimentHint" |
|
:type.sync="projectManage.experimentHintType" |
|
radio |
|
:minHeight="150" |
|
:height="400" |
|
:index="3" /> |
|
</el-form-item> |
|
</el-form> |
|
</div> |
|
</el-card> |
|
</el-form> |
|
|
|
<!--选择判分点对话框--> |
|
<el-dialog title="添加判分点" |
|
:visible.sync="dialogVisible" |
|
width="40%" |
|
:close-on-click-modal="false"> |
|
<div class="text-right m-b-10"> |
|
<div> |
|
<el-input placeholder="请输入需要查找的判分点" |
|
prefix-icon="el-icon-search" |
|
v-model.trim="judgementpointsquery" |
|
clearable></el-input> |
|
</div> |
|
</div> |
|
<u-table v-loading="visibleLoading" |
|
:data="judgementData" |
|
ref="judgementTable" |
|
class="table" |
|
stripe |
|
header-align="center" |
|
use-virtual |
|
:row-height="45" |
|
:max-height="400" |
|
:border="false" |
|
@selection-change="handleSelectionJudgment" |
|
:row-key="rowKey"> |
|
<u-table-column type="selection" |
|
width="55" |
|
align="center" |
|
:reserve-selection="true"></u-table-column> |
|
<u-table-column prop="id" |
|
label="序号" |
|
align="center" |
|
width="100"> |
|
<template slot-scope="scope"> |
|
{{ scope.$index + 1 }} |
|
</template> |
|
</u-table-column> |
|
<u-table-column prop="name" |
|
label="判分点名称" |
|
align="center"></u-table-column> |
|
<u-table-column label="操作" |
|
align="center" |
|
width="100"> |
|
<template slot-scope="scope"> |
|
<el-button size="mini" |
|
@click="toJudgePoint('view', scope.row)">查看</el-button> |
|
</template> |
|
</u-table-column> |
|
</u-table> |
|
<div slot="footer" |
|
class="dialog-footer"> |
|
<el-button @click="dialogVisible = false">取 消</el-button> |
|
<el-button type="primary" |
|
@click="addJudgment">确 定</el-button> |
|
</div> |
|
</el-dialog> |
|
</div> |
|
</template> |
|
|
|
<script> |
|
import Setting from "@/setting"; |
|
import util from "@/libs/util"; |
|
import { mapState, mapActions } from "vuex"; |
|
import quill from "@/components/quill"; |
|
import Sortable from "sortablejs"; |
|
import { UTable, UTableColumn } from 'umy-ui' |
|
import Decimal from 'decimal.js' |
|
import qs from 'qs' |
|
export default { |
|
components: { |
|
quill, |
|
UTable, |
|
UTableColumn |
|
}, |
|
data () { |
|
return { |
|
projectId: this.$route.query.projectId, |
|
founder: this.$route.query.founder, |
|
systemList: [], |
|
mallIds: [], |
|
curs: [], |
|
token: btoa(util.local.get(Setting.tokenKey)), |
|
isDetail: Boolean(this.$route.query.show), |
|
|
|
projectManage: { |
|
founder: 1, // 创建人角色(0、系统 1、老师) |
|
projectName: "", // 项目名称 |
|
permissions: 0, // 项目用途(0、练习 1、考核 2、竞赛) |
|
systemId: this.$store.state.project.lastSystemId, // 系统id |
|
mallId: '', |
|
hintOpen: 0, // 实验提示是否开启(0开启 1不开启 默认0) |
|
experimentHint: "", // 实验提示 |
|
experimentTarget: "", // 实验目标 |
|
experimentDescription: "", // 项目背景 |
|
state: 0, // 状态(0、草稿箱 1、已发布) |
|
isOpen: 0, // 是否开启(0开启 1未开启 默认0) |
|
isDel: 0, // 是否删除(0、未删除 1、已删除 默认0) |
|
experimentTargetType: '0', |
|
experimentDescriptionType: '0', |
|
experimentHintType: '0', |
|
}, |
|
projectJudgmentData: [], //实验任务(项目判分点) |
|
selectedProjectJudgment: [], // 选中的项目判分点 |
|
|
|
dialogVisible: false, // 选择判分点对话框 |
|
judgementpointsquery: "", //条件筛选判分点 |
|
judgementData: [], // 判分点列表数据 |
|
selectedJudgment: [], // 选中的判分点 |
|
rowKey: "", // 判分点行数据的 Key |
|
projectNameRepeat: false, // 项目名称是否重复 |
|
originName: '', |
|
|
|
flag: false, //判分点表格分数是否禁用 |
|
avgValuelist: [], //取得判分点平均分的数组 |
|
|
|
searchTimer: null, |
|
isToPoint: false, // 判断是否是跳转到判分点系统 |
|
visibleLoading: false, // 加载弹框 |
|
listLoading: false,// 列表加载 |
|
submiting: false, // 新增编辑员工防抖标识 |
|
updateTime: 0, |
|
next: null, |
|
backType: false, |
|
loading: false, |
|
}; |
|
}, |
|
computed: { |
|
...mapState("project", [ |
|
"projectFields", "lastSystemId" |
|
]), |
|
handDistributionScore () { |
|
//计算判分点分值,超出100提示, |
|
let score = 0; |
|
this.projectJudgmentData.forEach(e => { |
|
if (e.score && !isNaN(e.score)) score = Decimal(e.score).add(Decimal(score)) |
|
}); |
|
if (isNaN(score)) { |
|
return 0; |
|
} |
|
if (score > 100) { |
|
this.$message.error("分配的数值已超过100"); |
|
} |
|
return score; |
|
}, |
|
// 是否流程点分类 |
|
isLc () { |
|
const systemId = +this.projectManage.systemId |
|
return systemId === 11 || systemId === 12 || systemId === 19 |
|
}, |
|
}, |
|
watch: { |
|
// 监听信息是否有更改,有的话页面离开的时候要询问是否要保存 |
|
projectManage: { |
|
handler () { |
|
this.updateTime++ |
|
}, |
|
deep: true |
|
}, |
|
judgementpointsquery (n) { |
|
clearTimeout(this.searchTimer); |
|
this.searchTimer = setTimeout(() => { |
|
this.handleQueryJudgment(); |
|
}, 500); |
|
} |
|
}, |
|
// 离开的时候判断是否有保存更改的信息,没有则拦截并提示 |
|
beforeRouteLeave (to, from, next) { |
|
if (this.updateTime) { |
|
if (!this.backType) { |
|
this.$confirm(`您所更改的内容未更新,是否更新?`, '提示', { |
|
type: 'warning', |
|
closeOnClickModal: false |
|
}).then(() => { |
|
this.next = next |
|
this.save(this.projectManage.state) |
|
}).catch(() => { |
|
next() |
|
}) |
|
} else { |
|
next() |
|
} |
|
|
|
} else { |
|
next() |
|
} |
|
}, |
|
mounted () { |
|
this.getSystemData(); |
|
if (this.$route.query.projectId) { |
|
this.projectId = this.$route.query.projectId; |
|
this.getInfoData(); |
|
} |
|
// 判断有没有缓存数据 |
|
if (JSON.stringify(this.projectFields) != "{}") { |
|
let { projectManage, projectJudgmentData } = this.projectFields; |
|
this.projectManage = projectManage; |
|
this.projectJudgmentData = projectJudgmentData; |
|
} |
|
this.rowDrop(); |
|
this.$refs.main.scrollTop = 0; |
|
}, |
|
beforeDestroy () { |
|
if (!this.isToPoint) { |
|
this.setProject({}); |
|
} |
|
}, |
|
methods: { |
|
...mapActions("project", [ |
|
"setSystemId", "setProject" |
|
]), |
|
getInfoData () { // 获取详情数据 |
|
this.loading = true |
|
this.$get(`${this.api.getProjectDetail}?projectId=${this.projectId}`).then(res => { |
|
let { projectManage, projectJudgmentVos } = res; |
|
const { mallId, systemId } = projectManage |
|
if (mallId) { |
|
this.mallIds = [mallId] |
|
systemId && this.mallIds.push(systemId) |
|
} |
|
if (!projectManage.experimentDescriptionType) projectManage.experimentDescriptionType = '0' |
|
if (!projectManage.experimentHintType) projectManage.experimentHintType = '0' |
|
if (!projectManage.experimentTargetType) projectManage.experimentTargetType = '0' |
|
this.projectManage = projectManage; |
|
this.originName = projectManage.projectName |
|
this.projectJudgmentData = projectJudgmentVos; |
|
this.projectJudgmentData.forEach((e, i) => { |
|
e.sort = i + 1; |
|
}); |
|
this.loading = false |
|
this.$nextTick(() => { |
|
this.$refs.main.scrollTop = 0; |
|
this.updateTime = 0 |
|
}); |
|
}).catch(err => { |
|
this.loading = false |
|
}); |
|
}, |
|
// 获取系统 |
|
async getSystemData () { |
|
const { data } = await this.$get(this.api.getSystemIdBySchool) |
|
this.systemList = data |
|
const res = await this.$get(this.api.getSchoolEffectiveCourse) |
|
if (res.data.length) { |
|
res.data.map(e => { |
|
e.id = e.mallId |
|
e.label = e.curriculumName |
|
e.children = data.filter(n => e.systemId.split(',').includes(n.id + '')) // 筛选出该课程下的系统 |
|
}) |
|
this.curs = res.data |
|
} |
|
}, |
|
// 课程选择回调 |
|
curChange (val) { |
|
const id = val[0] |
|
if (val.length === 1) { |
|
// 如果选择的是课程,则默认选中下面第一个系统 |
|
this.mallIds = [id, this.curs.find(e => e.id == id).children[0].id] |
|
} |
|
this.projectManage.mallId = id |
|
this.projectManage.systemId = this.mallIds[1] |
|
}, |
|
projectNameExistis () { // 项目管理名称判重 |
|
const { projectName } = this.projectManage |
|
if (this.originName === projectName) { |
|
this.projectNameRepeat = false |
|
} else { |
|
this.$post(this.api.queryNameIsExist, { projectName }).then(res => { |
|
if (res.status === 200) { |
|
this.projectNameRepeat = false |
|
} |
|
}).catch(err => { |
|
this.projectNameRepeat = true |
|
}) |
|
} |
|
}, |
|
systemChange () { // 切换系统 |
|
if (this.projectJudgmentData.length) { |
|
this.$confirm("更换系统会清空实验任务,确认更换?", "提示", { |
|
type: "warning", |
|
closeOnClickModal: false |
|
}).then(() => { |
|
this.projectJudgmentData = []; |
|
this.setSystemId(this.projectManage.systemId); |
|
}).catch(() => { |
|
this.projectManage.systemId = this.lastSystemId; |
|
// console.log(this.lastSystemId, "this.lastSystemId"); |
|
}); |
|
} |
|
}, |
|
// 去除空白标签 |
|
removeTag (val) { |
|
return val.replace('<p><br></p>', '') |
|
}, |
|
judgmentRelease (state) { //判断能否成功发布 |
|
let { |
|
projectName, |
|
experimentTarget, |
|
experimentDescription, |
|
experimentHint, |
|
hintOpen |
|
} = this.projectManage; |
|
if (!projectName) { |
|
util.errorMsg("请输入项目名称"); |
|
return false; |
|
} |
|
if (this.projectNameRepeat) { |
|
util.errorMsg("项目名称重复!"); |
|
return false; |
|
} |
|
if (state) { |
|
if (!experimentTarget || !this.removeTag(experimentTarget)) { |
|
util.errorMsg("请输入实验目标"); |
|
return false; |
|
} |
|
if (!experimentDescription || !this.removeTag(experimentDescription)) { |
|
util.errorMsg("请输入案例描述"); |
|
return false; |
|
} |
|
if (this.projectJudgmentData.length == 0) { |
|
util.errorMsg("请添加判分点"); |
|
return false; |
|
} |
|
if (this.handDistributionScore < 100) { |
|
util.errorMsg("判分点分数未满100"); |
|
return false; |
|
} |
|
if (this.handDistributionScore > 100) { |
|
util.errorMsg("判分点分数已超过100"); |
|
return false; |
|
} |
|
if ((!experimentHint || !this.removeTag(experimentHint)) && hintOpen == 0) { |
|
util.errorMsg("请输入实验提示"); |
|
return false; |
|
} |
|
} |
|
return true; |
|
}, |
|
save (state) { //处理提交 |
|
if (this.submiting === 0 || this.submiting === 1) return false |
|
if (!this.judgmentRelease(state)) { //判断页面是否有没有输入的内容 |
|
return; |
|
} |
|
this.submiting = state |
|
this.setSystemId(this.projectManage.systemId); |
|
this.projectManage.state = state; |
|
let { systemId } = this.projectManage; |
|
if (this.projectId) { |
|
if (systemId == 2 || systemId == 3) { |
|
console.log("系统id:", systemId); |
|
} else { |
|
// 更新 |
|
this.updateProjectJudgment(); |
|
} |
|
} else { |
|
if (systemId == 2 || systemId == 3) { |
|
console.log("系统id:", systemId); |
|
} else { |
|
// 添加 |
|
let tempArr = this.projectJudgmentData.map(i => { |
|
let obj = { |
|
projectId: this.projectId ? this.projectId : "", |
|
judgmentId: i.judgmentId, |
|
score: i.score, |
|
sort: i.sort |
|
}; |
|
return obj; |
|
}); |
|
|
|
let params = { |
|
projectManage: this.projectManage, |
|
projectJudgmentList: tempArr |
|
}; |
|
this.addProject(params); |
|
} |
|
} |
|
}, |
|
updateProject (params) { // 更新项目 |
|
this.$post(this.api[params.projectManage.state ? 'updateProjectManage' : 'editProjectDraft'], params).then(res => { |
|
util.successMsg("更新实验项目成功"); |
|
this.updateTime = 0 |
|
this.next ? this.next() : this.backPage(); |
|
}).catch(err => { |
|
this.submiting = false |
|
}); |
|
}, |
|
addProject (params) { // 添加项目 |
|
this.$post(this.api[params.projectManage.state ? 'addProjectManage' : 'saveProjectDraft'], params).then(res => { |
|
util.successMsg("添加实验项目成功"); |
|
this.updateTime = 0 |
|
this.next ? this.next() : this.$router.back(); |
|
}).catch(err => { |
|
this.submiting = false |
|
}); |
|
}, |
|
manualDistributionScore () { //点击手动分配分值 |
|
|
|
}, |
|
avgDistributionScore () { |
|
//点击平均分配分值 |
|
if (this.projectJudgmentData.length) { |
|
this.$get(this.api.avgValues, { |
|
number: this.projectJudgmentData.length |
|
}).then(res => { |
|
if (res.data) { |
|
this.projectJudgmentData = this.projectJudgmentData.map((item, index) => { |
|
item.score = res.data[index]; |
|
return item; |
|
}); |
|
// this.updateProjectJudgment(); |
|
} |
|
}); |
|
} |
|
}, |
|
scoreChange (row, i) { |
|
row.score = row.score.replace(/[^\d\.]/g, '') |
|
this.projectJudgmentData.splice(i, 1, row); |
|
}, |
|
delJudgePoint (index) { // 删除判分点 |
|
this.$confirm("确定要删除吗?", "提示", { |
|
type: "warning" |
|
}).then(() => { |
|
this.projectJudgmentData.splice(index, 1); |
|
}).catch(() => { |
|
}); |
|
}, |
|
handleSelectionProjectJudgment (val) { |
|
this.selectedProjectJudgment = val; |
|
}, |
|
batchDeleteProjectJudgment () { // 批量删除判分点 |
|
if (this.selectedProjectJudgment.length) { |
|
this.$confirm("确定要删除吗?", "提示", { |
|
type: "warning" |
|
}).then(() => { |
|
let list = this.projectJudgmentData; |
|
let result = []; |
|
list.map(i => { |
|
this.selectedProjectJudgment.find(j => j.judgmentId === i.judgmentId) || result.push(i); |
|
}); |
|
this.projectJudgmentData = result; |
|
}).catch(() => { |
|
}); |
|
} else { |
|
util.errorMsg("请选择判分点"); |
|
} |
|
}, |
|
handleQueryJudgment () { // 查询判分点数据 |
|
let { systemId } = this.projectManage; |
|
this.dialogVisible = true; |
|
this.$nextTick(() => { |
|
this.$refs.judgementTable.clearSelection(); |
|
}); |
|
let params = { |
|
systemId, |
|
name: this.judgementpointsquery |
|
}; |
|
if (systemId == 2 || systemId == 3) { |
|
console.log("系统id:", systemId); |
|
} else if (this.isLc) { |
|
// (流程)交易类 |
|
this.rowKey = "lcId"; |
|
this.getProcessClassData(params); |
|
} else { |
|
// 编程类 |
|
this.rowKey = "bcId"; |
|
this.getProgrammingClassData(params); |
|
} |
|
}, |
|
getProcessClassData (params) { // 获取流程类判分点列表数据 |
|
this.visibleLoading = true; |
|
this.$get(`${this.api.getBcJudgmentPoint}`, params).then(res => { |
|
let list = res.judgmentPoints |
|
let result = []; |
|
list.map(i => { |
|
this.projectJudgmentData.find(j => j.judgmentId === i.judgmentId) || result.push(i); |
|
}); |
|
this.visibleLoading = false; |
|
this.judgementData = result; |
|
}).catch(err => { |
|
this.visibleLoading = false |
|
}); |
|
}, |
|
getProgrammingClassData (params) { // 获取编程类判分点列表数据 |
|
this.visibleLoading = true; |
|
this.$get(this.api.getBcJudgmentPoint, params).then(res => { |
|
let list = res.judgmentPoints |
|
let result = []; |
|
list.map(i => { |
|
this.projectJudgmentData.find(j => j.judgmentId === i.judgmentId) || result.push(i); |
|
}); |
|
this.visibleLoading = false; |
|
this.judgementData = result; |
|
}).catch(err => { |
|
this.visibleLoading = false |
|
}); |
|
}, |
|
handleSelectionJudgment (val) { // 处理多选判分点 |
|
this.selectedJudgment = val; |
|
}, |
|
addJudgment () { // 确认选择判分点 |
|
if (this.selectedJudgment.length) { |
|
this.dialogVisible = false; |
|
let tempArr = this.selectedJudgment.map(i => { |
|
this.$set(i, 'score', 0) |
|
return i; |
|
}); |
|
this.projectJudgmentData = this.projectJudgmentData.concat(tempArr); |
|
this.projectJudgmentData.map((e, i) => { |
|
e.sort = i + 1; |
|
}); |
|
this.$nextTick(() => { |
|
this.$refs.projectJudgementTable.clearSelection(); |
|
}); |
|
} else { |
|
util.errorMsg("请选择判分点"); |
|
} |
|
}, |
|
handleCacheData () { // 处理缓存数据 |
|
this.isToPoint = true; |
|
this.setProject({ projectManage: this.projectManage, projectJudgmentData: this.projectJudgmentData }); |
|
}, |
|
toJudgePoint (type, row) { // 进入判分点系统 |
|
this.handleCacheData(); |
|
let jumpPath = Setting.jumpPath; |
|
let { systemId } = this.projectManage; |
|
let href = ""; |
|
if (type === "view") { |
|
// 查看 |
|
if (systemId == 2) { |
|
console.log(systemId); |
|
} else if (systemId == 3) { |
|
console.log(systemId); |
|
} else if (this.isLc) { |
|
// 交易类判分点(银行综合系统) |
|
href = `${jumpPath}#/Transaction?isView=true&systemId=${systemId}&lcId=${row.judgmentId}&token=${this.token}&referrer=${window.btoa(location.href)}`; |
|
} else { |
|
// 编程类判分点(python子系统) |
|
href = `${jumpPath}#/program?isView=true&systemId=${systemId}&bcId=${row.judgmentId}&token=${this.token}&referrer=${window.btoa(location.href)}`; |
|
} |
|
} else if (type === "edit") { |
|
// 自定义(老师端隐藏此功能) |
|
if (systemId == 2) { |
|
console.log(systemId); |
|
} else if (systemId == 3) { |
|
console.log(systemId); |
|
} else if (this.isLc) { |
|
// 交易类判分点(银行综合系统) |
|
href = `${jumpPath}#/Transaction?isEdit=true&systemId=${systemId}&lcId=${row.judgmentId}&token=${this.token}&referrer=${btoa(location.href)}`; |
|
} else { |
|
// 编程类判分点(python子系统) |
|
href = `${jumpPath}#/program?isEdit=true&systemId=${systemId}&bcId=${row.judgmentId}&token=${this.token}&referrer=${btoa(location.href)}`; |
|
} |
|
} else if (type === "home") { |
|
if (systemId == 2 || systemId == 3) { |
|
console.log(systemId); |
|
} else { |
|
// 进入判分点系统首页(老师端隐藏此功能) |
|
href = `${jumpPath}#/?systemId=${systemId}&token=${this.token}&referrer=${btoa(location.href)}`; |
|
} |
|
} |
|
location.href = href; |
|
}, |
|
permissionChange () { |
|
if (this.projectManage.permissions) { |
|
this.projectManage.hintOpen = 1 |
|
} else { |
|
this.projectManage.hintOpen = 0 |
|
} |
|
}, |
|
// 行拖拽 |
|
rowDrop () { |
|
// 此时找到的元素是要拖拽元素的父容器 |
|
const tbody = document.querySelector(".draggable .el-table__body-wrapper tbody"); |
|
const _this = this; |
|
Sortable.create(tbody, { |
|
// 指定父元素下可被拖拽的子元素 |
|
draggable: ".draggable .el-table__row", |
|
onEnd ({ newIndex, oldIndex }) { |
|
_this.projectJudgmentData.splice(newIndex, 0, _this.projectJudgmentData.splice(oldIndex, 1)[0]); |
|
let newArray = _this.projectJudgmentData.slice(0); |
|
_this.projectJudgmentData = []; |
|
_this.$nextTick(function () { |
|
newArray.forEach((e, i) => { |
|
_this.$set(e, "sort", i + 1);// 不更新 |
|
_this.$set(e, "name", e.name + "?"); |
|
_this.$set(e, "name", e.name.slice(0, e.name.length - 1)); // 不更新的解决方案 |
|
}); |
|
_this.projectJudgmentData = newArray; |
|
}); |
|
} |
|
}); |
|
}, |
|
// 修改判分点中间表 |
|
async updateProjectJudgment () { |
|
let param = this.projectJudgmentData.map((e, i) => { |
|
let obj = { |
|
judgmentId: e.judgmentId, |
|
projectId: this.projectId || "", |
|
score: e.score, |
|
sort: i + 1, |
|
id: e.id |
|
}; |
|
return obj; |
|
}); |
|
await this.$post(`${this.api.updateProjectJudgment}?projectId=${this.projectId}`, param).then(res => { |
|
let tempArr = this.projectJudgmentData.map(i => { |
|
let obj = { |
|
projectId: this.projectId ? this.projectId : "", |
|
judgmentId: i.judgmentId, |
|
score: i.score, |
|
sort: i.sort |
|
}; |
|
return obj; |
|
}); |
|
let params = { |
|
projectManage: this.projectManage, |
|
projectJudgmentList: tempArr |
|
}; |
|
this.updateProject(params); |
|
}).catch(err => { |
|
console.log(err); |
|
}); |
|
}, |
|
// 返回 |
|
back () { |
|
this.backType = true |
|
// 更改了信息才需要提示 |
|
if (this.updateTime) { |
|
this.$confirm('编辑的内容未保存,是否保存?', "提示", { |
|
type: "warning", |
|
closeOnClickModal: false |
|
}).then(() => { |
|
this.save(this.projectManage.state) |
|
}).catch(() => { |
|
this.backPage() |
|
}) |
|
} else { |
|
this.backPage() |
|
} |
|
}, |
|
backPage () { |
|
const { params } = this.$store.state.project |
|
this.$router.push(`/project?${qs.stringify(params.form)}&page=${params.page}`) |
|
}, |
|
} |
|
}; |
|
</script> |
|
|
|
<style lang="scss" scoped> |
|
/deep/ .readonly .ql-toolbar { |
|
height: 0; |
|
padding: 0; |
|
border-bottom: 0; |
|
} |
|
.main { |
|
overflow: auto; |
|
overflow-x: hidden; |
|
height: calc(100vh - 152px); |
|
} |
|
</style> |