|
|
|
<template>
|
|
|
|
<div>
|
|
|
|
<el-row :gutter="20">
|
|
|
|
<el-col :span="24">
|
|
|
|
<el-card shadow="hover" class="mgb20">
|
|
|
|
<div class="flex-between">
|
|
|
|
<div class="per_title" v-preventReClick @click="goback()">
|
|
|
|
<i class="el-icon-arrow-left"></i>
|
|
|
|
<span class="per_back">返回</span>
|
|
|
|
<span class="per_school" v-text="form.courseId != '' ? '编辑课程' : '新建课程'"></span>
|
|
|
|
</div>
|
|
|
|
<el-button type="primary" size="small" round class="mag" v-preventReClick @click="saveAdd('form')">确定</el-button>
|
|
|
|
</div>
|
|
|
|
</el-card>
|
|
|
|
|
|
|
|
<el-card shadow="hover" class="mgb20 ">
|
|
|
|
<div class="flex-center mgb20">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>课程信息</span>
|
|
|
|
</div>
|
|
|
|
<div class="border-b-dashed"></div>
|
|
|
|
|
|
|
|
<div>
|
|
|
|
<el-form :model="form" :rules="rules" ref="form" label-width="80px">
|
|
|
|
<el-col :span="6" :offset="5">
|
|
|
|
<el-form-item label="课程名称" prop="courseName">
|
|
|
|
<el-input placeholder="请输入课程名称" v-model="form.courseName" @change="changeName"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="学科类别" prop="disciplineId">
|
|
|
|
<el-select v-model="form.disciplineId" clearable placeholder="请选择学科类别"
|
|
|
|
@change="getProfessionalClass()" @clear="clearsubjectType()">
|
|
|
|
<el-option v-for="(item,index) in subjectList" :key="index" :label="item.disciplineName" :value="item.disciplineId"></el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="专业" prop="professionalId">
|
|
|
|
<el-select v-model="form.professionalId" clearable placeholder="请选择专业"
|
|
|
|
:disabled="form.professionalClassId ? false : true">
|
|
|
|
<el-option v-for="(item,index) in ProfessionalList" :key="index" :label="item.professionalName" :value="item.professionalId"></el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="市场价格" prop="marketPrice">
|
|
|
|
<el-input placeholder="请输入市场价格" v-model="form.marketPrice">
|
|
|
|
<template slot="append">万元/年</template>
|
|
|
|
</el-input>
|
|
|
|
</el-form-item>
|
|
|
|
</el-col>
|
|
|
|
|
|
|
|
<el-col :span="6" :offset="2">
|
|
|
|
<el-form-item label="预计课时" prop="courseHours">
|
|
|
|
<el-select v-model="form.courseHours" clearable placeholder="请选择预计课时">
|
|
|
|
<el-option v-for="(item,index) in hoursList" :key="index" :label="item.name" :value="item.value"></el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="专业类" prop="professionalClassId">
|
|
|
|
<el-select v-model="form.professionalClassId" clearable placeholder="请选择专业类"
|
|
|
|
:disabled="form.disciplineId ? false : true" @change="getProfessional()" @clear="clearProfessionalClass()">
|
|
|
|
<el-option v-for="(item,index) in ProfessionalClassList" :key="index" :label="item.professionalClassName" :value="item.professionalClassId"></el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
|
|
|
|
<el-form-item label="预计课时">
|
|
|
|
<el-select v-model="form.courseType" clearable placeholder="请选择课程类别">
|
|
|
|
<el-option v-for="(item,index) in CourseTypeList" :key="index" :label="item.name" :value="item.value"></el-option>
|
|
|
|
</el-select>
|
|
|
|
</el-form-item>
|
|
|
|
</el-col>
|
|
|
|
|
|
|
|
<el-col :span="14" :offset="5">
|
|
|
|
<el-form-item label="课程简介" prop="courseIntroduction">
|
|
|
|
<el-input type="textarea" :autosize="{ minRows: 4 }" placeholder="请输入课程简介" v-model="form.courseIntroduction"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
<el-form-item label="教学目标" prop="teachingGoal">
|
|
|
|
<el-input type="textarea" :autosize="{ minRows: 4 }" placeholder="请输入教学目标" v-model="form.teachingGoal"></el-input>
|
|
|
|
</el-form-item>
|
|
|
|
</el-col>
|
|
|
|
</el-form>
|
|
|
|
</div>
|
|
|
|
</el-card>
|
|
|
|
|
|
|
|
<el-card shadow="hover" class="mgb20">
|
|
|
|
<div class="mgb20 flex-between">
|
|
|
|
<div class="flex-center ">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>练习配置</span>
|
|
|
|
</div>
|
|
|
|
<el-button @click="curVisible=true" icon="el-icon-plus" circle></el-button>
|
|
|
|
</div>
|
|
|
|
<div class="border-b-dashed"></div>
|
|
|
|
<div>
|
|
|
|
<el-table :data="curData" class="table" stripe header-align="center">
|
|
|
|
<el-table-column type="index" width="100" label="序号" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="name" label="项目名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="appName" label="应用名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="资源配置" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-button @click="EditCur(scope.row)">编辑</el-button>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="展示控制" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-switch
|
|
|
|
v-model="scope.row.contral"
|
|
|
|
:active-value="0"
|
|
|
|
:inactive-value="1">
|
|
|
|
</el-switch>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="添加控制" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-button @click="handleDelete(scope.$index, scope.row)">删除</el-button>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
</div>
|
|
|
|
</el-card>
|
|
|
|
<!-- 考核配置 -->
|
|
|
|
<el-card shadow="hover" class="mgb20">
|
|
|
|
<div class="mgb20 flex-between">
|
|
|
|
<div class="flex-center ">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>考核配置</span>
|
|
|
|
</div>
|
|
|
|
<el-button @click="showAssess=true" icon="el-icon-plus" circle></el-button>
|
|
|
|
</div>
|
|
|
|
<div class="border-b-dashed"></div>
|
|
|
|
<!-- 实训配置 -->
|
|
|
|
<div>
|
|
|
|
<el-table :data="curData" class="table" stripe header-align="center">
|
|
|
|
<el-table-column type="index" width="100" label="序号" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="name" label="项目名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="appName" label="应用名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="资源配置" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-button @click="EditCur(scope.row)">编辑</el-button>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="展示控制" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-switch
|
|
|
|
v-model="scope.row.contral"
|
|
|
|
:active-value="0"
|
|
|
|
:inactive-value="1">
|
|
|
|
</el-switch>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column label="添加控制" align="center">
|
|
|
|
<template slot-scope="scope">
|
|
|
|
<el-button @click="handleDelete(scope.$index, scope.row)">删除</el-button>
|
|
|
|
</template>
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
</div>
|
|
|
|
</el-card>
|
|
|
|
|
|
|
|
<!-- 资源配置 -->
|
|
|
|
<!-- <el-card shadow="hover" class="mgb20">
|
|
|
|
<div class="mgb20 flex-between">
|
|
|
|
<div class="flex-center ">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>资源配置</span>
|
|
|
|
</div>
|
|
|
|
<div class="flex-between">
|
|
|
|
<el-button type="primary" size="small" round class="mag" @click="getConfig">添加章节</el-button>
|
|
|
|
<el-button type="primary" size="small" round class="mag" @click="getConfig">编辑顺序</el-button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="border-b-dashed"></div>
|
|
|
|
</el-card> -->
|
|
|
|
|
|
|
|
<courseconfig></courseconfig>
|
|
|
|
|
|
|
|
</el-col>
|
|
|
|
|
|
|
|
<!-- 应用配置 -->
|
|
|
|
<el-dialog :visible.sync="curVisible" width="50%" center>
|
|
|
|
<div class="flex-between mgb20">
|
|
|
|
<div class="flex-center">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>应用列表</span>
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<el-input placeholder="请输入系统名称" prefix-icon="el-icon-search" v-model="configSearch" clearable></el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<el-table :data="permissionData" class="table" stripe header-align="center" @selection-change="handleSelectionChange">
|
|
|
|
<el-table-column type="selection" width="55" align="center"></el-table-column>
|
|
|
|
<el-table-column type="index" width="100" label="序号" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemName" label="系统名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemAttribution" label="系统类型" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemType" label="系统归属" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemStatus" label="系统状态" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
<el-button @click="curVisible = false">取 消</el-button>
|
|
|
|
<el-button type="primary" v-preventReClick @click="addSystem()">确 定</el-button>
|
|
|
|
</span>
|
|
|
|
</el-dialog>
|
|
|
|
<!-- 考核配置弹框 -->
|
|
|
|
<el-dialog :visible.sync="showAssess" width="50%" center>
|
|
|
|
<div class="flex-between mgb20">
|
|
|
|
<div class="flex-center">
|
|
|
|
<p class="addhr_tag"></p>
|
|
|
|
<span>应用列表</span>
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<el-input placeholder="请输入系统名称" prefix-icon="el-icon-search" v-model="configSearch" clearable></el-input>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<el-table :data="permissionData" class="table" stripe header-align="center" @selection-change="handleSelectionChange">
|
|
|
|
<el-table-column type="selection" width="55" align="center"></el-table-column>
|
|
|
|
<el-table-column type="index" width="100" label="序号" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemName" label="系统名称" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemAttribution" label="系统类型" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemType" label="系统归属" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
<el-table-column prop="systemStatus" label="系统状态" align="center">
|
|
|
|
</el-table-column>
|
|
|
|
</el-table>
|
|
|
|
<span slot="footer" class="dialog-footer">
|
|
|
|
<el-button @click="showAssess = false">取 消</el-button>
|
|
|
|
<el-button type="primary" v-preventReClick >确 定</el-button>
|
|
|
|
</span>
|
|
|
|
</el-dialog>
|
|
|
|
</el-row>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import courseconfig from './courseconfig.vue'
|
|
|
|
export default {
|
|
|
|
components:{
|
|
|
|
courseconfig:courseconfig
|
|
|
|
},
|
|
|
|
data (){
|
|
|
|
return {
|
|
|
|
form: {
|
|
|
|
courseName: '',
|
|
|
|
courseType: '',
|
|
|
|
disciplineId: '',
|
|
|
|
professionalClassId: '',
|
|
|
|
professionalId: '',
|
|
|
|
courseHours: '',
|
|
|
|
marketPrice: '',
|
|
|
|
courseIntroduction: '',
|
|
|
|
teachingGoal: '',
|
|
|
|
courseId : this.$store.state.courseId,
|
|
|
|
systemId: ''
|
|
|
|
},
|
|
|
|
rules: {
|
|
|
|
courseName: [
|
|
|
|
{ required: true, message: '请输入用户姓名', trigger: 'blur' }
|
|
|
|
],
|
|
|
|
disciplineId: [
|
|
|
|
{ required: true, message: '请选择学科类别', trigger: 'change' }
|
|
|
|
],
|
|
|
|
professionalId: [
|
|
|
|
{ required: true, message: '请选择专业', trigger: 'change' }
|
|
|
|
],
|
|
|
|
marketPrice: [
|
|
|
|
{ required: true, message: '请输入市场价格', trigger: 'blur' },
|
|
|
|
{ pattern: /^(([1-9][0-9]*)|(([0]\.\d{1,2}|[1-9][0-9]*\.\d{1,2})))$/, message: '请输入正确金额格式,可保留两位小数' }
|
|
|
|
],
|
|
|
|
courseHours: [
|
|
|
|
{ required: true, message: '请选择预计课时', trigger: 'change' }
|
|
|
|
],
|
|
|
|
professionalClassId: [
|
|
|
|
{ required: true, message: '请选择专业类', trigger: 'change' }
|
|
|
|
],
|
|
|
|
courseType: [
|
|
|
|
{ required: true, message: '请选择课程类别', trigger: 'change' }
|
|
|
|
],
|
|
|
|
courseIntroduction: [
|
|
|
|
{ required: true, message: '请输入课程简介', trigger: 'blur' }
|
|
|
|
],
|
|
|
|
teachingGoal: [
|
|
|
|
{ required: true, message: '请输入教学目标', trigger: 'blur' }
|
|
|
|
]
|
|
|
|
},
|
|
|
|
permissionData: [],
|
|
|
|
curVisible: false,// 联系配置弹框
|
|
|
|
showAssess:false,// 考核配置弹框
|
|
|
|
curData: [
|
|
|
|
{name:'项目名称',appName:'应用',asset:false,switch:false,contral:false}
|
|
|
|
],
|
|
|
|
subjectList: [],
|
|
|
|
ProfessionalClassList: [],
|
|
|
|
ProfessionalList: [],
|
|
|
|
CourseTypeList: [{
|
|
|
|
name: '实训课程',
|
|
|
|
value: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '理论课程',
|
|
|
|
value: 2
|
|
|
|
}],
|
|
|
|
hoursList: [{
|
|
|
|
name: '32课时',
|
|
|
|
value: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '64课时',
|
|
|
|
value: 2
|
|
|
|
}],
|
|
|
|
configSearch: '',
|
|
|
|
multipleSelection: [],
|
|
|
|
NoAdd: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
configSearch(newVal){
|
|
|
|
this.getConfig()
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
// if(this.form.courseId){
|
|
|
|
// let data = {
|
|
|
|
// courseId: this.form.courseId
|
|
|
|
// }
|
|
|
|
// this.$get(this.api.queryCourseDetails,data).then((res) => {
|
|
|
|
// this.form = {
|
|
|
|
// courseName: res.message[0].course.courseName,
|
|
|
|
// courseType: res.message[0].course.courseType,
|
|
|
|
// disciplineId: res.message[0].course.disciplineId,
|
|
|
|
// professionalClassId: res.message[0].course.professionalClassId,
|
|
|
|
// professionalId: res.message[0].course.professionalId,
|
|
|
|
// courseHours: res.message[0].course.courseHours,
|
|
|
|
// marketPrice: res.message[0].course.marketPrice,
|
|
|
|
// courseIntroduction: res.message[0].course.courseIntroduction,
|
|
|
|
// teachingGoal: res.message[0].course.teachingGoal,
|
|
|
|
// courseId : res.message[0].course.courseId,
|
|
|
|
// systemId: res.message[0].course.systemId
|
|
|
|
// }
|
|
|
|
// this.getProfessionalClassData()
|
|
|
|
// this.getProfessionalData()
|
|
|
|
// this.curData = res.message[0].serviceConfigList
|
|
|
|
// // let arr1 = this.curData
|
|
|
|
// // let result1 = arr1.map(e => e.systemId)
|
|
|
|
// // const set = new Set(result1);
|
|
|
|
// // let set1 = [...set].join()
|
|
|
|
// // this.form.systemId = this.form.systemId.concat(set1)
|
|
|
|
// }).catch((res) => {
|
|
|
|
// })
|
|
|
|
// }
|
|
|
|
// this.getSubject()
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
saveAdd(form){
|
|
|
|
this.$refs[form].validate((valid) => {
|
|
|
|
if (valid) {
|
|
|
|
if(this.NoAdd){
|
|
|
|
if(this.curData.length != 0){
|
|
|
|
let data = {
|
|
|
|
course: this.form,
|
|
|
|
serviceConfigList: this.curData
|
|
|
|
}
|
|
|
|
if(this.form.courseId){
|
|
|
|
this.$post(this.api.updateCourse,data).then((res) => {
|
|
|
|
this.$message.success('编辑成功');
|
|
|
|
this.$router.replace('/curriculum')
|
|
|
|
}).catch((res) => {
|
|
|
|
})
|
|
|
|
}else{
|
|
|
|
this.$post(this.api.addCourse,data).then((res) => {
|
|
|
|
this.$message.success('添加成功');
|
|
|
|
this.$router.replace('/curriculum')
|
|
|
|
}).catch((res) => {
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
this.$message.warning('请添加实训配置!');
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
this.$message.warning('该课程已存在');
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
// 获取应用配置
|
|
|
|
getConfig(){
|
|
|
|
let data = {
|
|
|
|
searchContent: this.configSearch,
|
|
|
|
systemId: this.form.systemId
|
|
|
|
}
|
|
|
|
this.$get(this.api.queryAppConfig,data).then((res) => {
|
|
|
|
this.curVisible = true
|
|
|
|
res.message.map(e => {
|
|
|
|
e.systemStatus = this.systemStatus(e.systemStatus)
|
|
|
|
e.systemType = this.systemAttributionStatus(e.systemType)
|
|
|
|
e.systemAttribution = this.systemTypeStatus(e.systemAttribution)
|
|
|
|
})
|
|
|
|
this.permissionData = res.message
|
|
|
|
}).catch((res) => {
|
|
|
|
})
|
|
|
|
},
|
|
|
|
// 获取学科类别
|
|
|
|
getSubject(){
|
|
|
|
this.$get(this.api.queryCourseDiscipline).then(res => {
|
|
|
|
this.subjectList = res.message
|
|
|
|
}).catch(res => {});
|
|
|
|
},
|
|
|
|
// 清空学科类别
|
|
|
|
clearsubjectType(){
|
|
|
|
this.form.professionalClassId = '',
|
|
|
|
this.form.professionalId = ''
|
|
|
|
},
|
|
|
|
// 获取专业类
|
|
|
|
getProfessionalClass(){
|
|
|
|
this.clearsubjectType()
|
|
|
|
this.getProfessionalClassData()
|
|
|
|
},
|
|
|
|
getProfessionalClassData(){
|
|
|
|
let data = {
|
|
|
|
disciplineId: this.form.disciplineId
|
|
|
|
}
|
|
|
|
this.$get(this.api.queryCourseProfessionalClass,data).then(res => {
|
|
|
|
this.ProfessionalClassList = res.message
|
|
|
|
}).catch(res => {});
|
|
|
|
},
|
|
|
|
// 清空专业类
|
|
|
|
clearProfessionalClass(){
|
|
|
|
this.form.professionalId = ''
|
|
|
|
},
|
|
|
|
// 获取专业
|
|
|
|
getProfessional(){
|
|
|
|
this.clearProfessionalClass()
|
|
|
|
this.getProfessionalData()
|
|
|
|
},
|
|
|
|
getProfessionalData(){
|
|
|
|
let data = {
|
|
|
|
professionalClassId: this.form.professionalClassId
|
|
|
|
}
|
|
|
|
this.$get(this.api.queryCourseProfessional,data).then(res => {
|
|
|
|
this.ProfessionalList = res.message
|
|
|
|
}).catch(res => {});
|
|
|
|
},
|
|
|
|
// 多选操作
|
|
|
|
handleSelectionChange(val) {
|
|
|
|
this.multipleSelection = val;
|
|
|
|
},
|
|
|
|
// 绑定实训配置
|
|
|
|
addSystem() {
|
|
|
|
let arr = this.multipleSelection
|
|
|
|
let result = arr.map(e => e.systemId).join()
|
|
|
|
this.form.systemId = this.form.systemId.concat(`,${result}`)
|
|
|
|
if (this.form.systemId.substr(0,1)==','){
|
|
|
|
this.form.systemId = this.form.systemId.substr(1);
|
|
|
|
}
|
|
|
|
this.curVisible = false
|
|
|
|
this.getTrianConfig()
|
|
|
|
},
|
|
|
|
// 查询实训配置
|
|
|
|
getTrianConfig(){
|
|
|
|
let data = {
|
|
|
|
systemId: this.form.systemId
|
|
|
|
}
|
|
|
|
this.$get(this.api.queryTrainingConfig,data).then((res) => {
|
|
|
|
var arritem = {
|
|
|
|
isShow: 0
|
|
|
|
}
|
|
|
|
let arryNew = []
|
|
|
|
res.message.map(item => {
|
|
|
|
arryNew.push(Object.assign({}, item, arritem))
|
|
|
|
})
|
|
|
|
this.curData = arryNew
|
|
|
|
}).catch((res) => {
|
|
|
|
})
|
|
|
|
},
|
|
|
|
// 编辑实训配置
|
|
|
|
EditCur(row){
|
|
|
|
if(this.form.courseId){
|
|
|
|
this.$store.commit("systemData", { system_id : row.projectId});
|
|
|
|
this.$router.push('/addlink');
|
|
|
|
}else{
|
|
|
|
this.$message.warning('请先保存课程再进行编辑项目!');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
handleDelete(index, row){
|
|
|
|
this.$confirm('此操作将删除该项目, 是否继续?', '提示', {
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
type: 'warning'
|
|
|
|
}).then(() => {
|
|
|
|
this.$message.success('删除成功');
|
|
|
|
this.curData.splice(index, 1);
|
|
|
|
let arr1 = this.curData
|
|
|
|
let result1 = arr1.map(e => e.systemId)
|
|
|
|
const set = new Set(result1);
|
|
|
|
let set1 = [...set].join()
|
|
|
|
this.form.systemId = set1
|
|
|
|
}).catch(() => {
|
|
|
|
this.$message.info("已取消删除");
|
|
|
|
});
|
|
|
|
},
|
|
|
|
goback(){
|
|
|
|
this.$router.go(-1)
|
|
|
|
},
|
|
|
|
// 查询课程是否存在
|
|
|
|
changeName(){
|
|
|
|
let data = {
|
|
|
|
courseName: this.form.courseName
|
|
|
|
}
|
|
|
|
this.$get(this.api.queryCourseNameIsExists,data).then((res) => {
|
|
|
|
if(res.message.length != 0){
|
|
|
|
this.$message.warning('该课程已存在');
|
|
|
|
this.NoAdd = false
|
|
|
|
}else{
|
|
|
|
this.NoAdd = true
|
|
|
|
}
|
|
|
|
}).catch((res) => {
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
.border_lf{
|
|
|
|
border-left: 1px dashed #eee;
|
|
|
|
padding: 0 60px;
|
|
|
|
}
|
|
|
|
.border_lf label{
|
|
|
|
width: 120px;
|
|
|
|
}
|
|
|
|
.pad_none{
|
|
|
|
padding: 0 0 0 60px;
|
|
|
|
}
|
|
|
|
.mar_input{
|
|
|
|
margin-right: 80px;
|
|
|
|
}
|
|
|
|
.marb30{
|
|
|
|
margin-bottom: 30px;
|
|
|
|
}
|
|
|
|
.tab_temp label{
|
|
|
|
width: 60px;
|
|
|
|
}
|
|
|
|
.mar10{
|
|
|
|
margin-top: 10px;
|
|
|
|
}
|
|
|
|
.radio_icon{
|
|
|
|
font-size: 26px;
|
|
|
|
color: #9278FF;
|
|
|
|
}
|
|
|
|
.card-curriculum{
|
|
|
|
background: #fff;
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
align-items: center;
|
|
|
|
padding: 10px 120px;
|
|
|
|
}
|
|
|
|
</style>
|