Merge branch 'master' of ssh://gitlab.dongwu-inc.com:10022/BOE/fe-manage

This commit is contained in:
岳佳鑫
2022-11-01 18:12:40 +08:00
13 changed files with 4111 additions and 2953 deletions

View File

@@ -354,6 +354,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -169,6 +169,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -374,6 +374,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -380,6 +380,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -16,56 +16,52 @@
@click="closeDrawer" @click="closeDrawer"
/> />
</div> </div>
<a-form
ref="formRef"
name="custom-validation"
:model="formState"
:rules="rules"
v-bind="layout"
@finish="handleFinish"
@validate="handleValidate"
@finishFailed="handleFinishFailed"
>
<div class="contentMain"> <div class="contentMain">
<div class="main_left"> <div class="main_left">
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">作业名称</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-input <a-form-item has-feedback label="作业名称" name="workName">
v-model:value="inputV1" <a-input v-model:value="formState.workName"
style="width: 424px; height: 32px" style="width: 424px; height: 32px;margin-left: 35px;"
placeholder="请输入作业名称" placeholder="请输入作业名称"
maxlength="20" autocomplete="off" />
/> </a-form-item>
</div> </div>
</div> </div>
<div class="main_item2"> <div class="main_item2">
<div class="signbox"> <a-form-item has-feedback label="作业要求" name="workRequirement">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">作业要求</span>
</div>
<div class="textarea">
<a-textarea <a-textarea
v-model:value="textV1" v-model:value="formState.workRequirement"
placeholder="请输入作业名称" placeholder="请输入作业要求"
autocomplete="off"
allow-clear allow-clear
style="margin-left: 35px"
maxlength="150" maxlength="150"
/> />
</div> </a-form-item>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">提交时间</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="提交时间" name="choosedTime">
<a-range-picker <a-range-picker
style="width: 424px" style="width: 424px;margin-left: 35px;"
v-model:value="choosedTime" v-model:value="formState.choosedTime"
:placeholder="[' 开始时间', ' 结束时间']" :placeholder="[' 开始时间', ' 结束时间']"
/> />
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
@@ -83,7 +79,6 @@
v-model:file-list="fileList" v-model:file-list="fileList"
name="file" name="file"
action="/api/file/upload" action="/api/file/upload"
:headers="headers"
@change="handleChange" @change="handleChange"
> >
<button class="xkbtn">上传附件</button> <button class="xkbtn">上传附件</button>
@@ -100,14 +95,16 @@
</div> </div>
</div> </div>
<div class="main_btns"> <div class="main_btns">
<button class="btn1" @click="closeDrawer">取消</button> <a-button class="btn1" @click="closeDrawer">取消</a-button>
<button class="btn2" @click="addHomework">确定</button> <a-button class="btn2" html-type="submit">确定</a-button>
</div> </div>
</a-form>
</div> </div>
</a-drawer> </a-drawer>
</template> </template>
<script> <script>
import { reactive, toRefs, ref } from "vue"; import { reactive, ref } from "vue";
import {message} from"ant-design-vue"; import {message} from"ant-design-vue";
import {createWorkTask} from "@/api/indexWork" import {createWorkTask} from "@/api/indexWork"
import dayjs from 'dayjs'; import dayjs from 'dayjs';
@@ -139,11 +136,75 @@ export default {
}, },
}, },
setup(props, ctx) { setup(props, ctx) {
const state = reactive({ const formState = reactive({
inputV1: "", workName: '',
textV1:"", workRequirement: '',
choosedTime:[], choosedTime: '',
}); });
const formRef = ref();
let checkWorkName = async (_rule, value) => {
if (!value) {
message.warning("请输入作业名称");
return Promise.reject('请输入作业名称');
}
};
let checkWorkRequirement = async (_rule, value) => {
if (!value) {
message.warning("请输入作业要求");
return Promise.reject('请输入作业要求');
}
};
let checkTime = async (_rule, value) => {
if (!value) {
message.warning("请选择时间");
return Promise.reject('请选择时间');
}
};
const rules = {
workName: [{
required: true,
validator: checkWorkName,
trigger: 'change',
}],
workRequirement: [{
required: true,
validator: checkWorkRequirement,
trigger: 'change',
}],
choosedTime: [{
required: true,
validator: checkTime,
trigger: 'change',
}],
};
// const layout = {
// labelCol: {
// span: 4,
// },
// wrapperCol: {
// span: 14,
// },
// };
const handleFinish = values => {
console.log(values);
addHomework()
};
const handleFinishFailed = errors => {
console.log(errors);
// message.error("handleFinishFailed");
};
const resetForm = () => {
formRef.value.resetFields();
};
const handleValidate = (...args) => {
console.log(args);
};
const handleChange = info => { const handleChange = info => {
if (info.file.status !== 'uploading') { if (info.file.status !== 'uploading') {
console.log(info.file, info.fileList); console.log(info.file, info.fileList);
@@ -158,49 +219,48 @@ export default {
const fileList = ref([]); const fileList = ref([]);
const closeDrawer = () => { const closeDrawer = () => {
resetForm();
ctx.emit("update:addhomeworkVisible", false); ctx.emit("update:addhomeworkVisible", false);
}; };
const afterVisibleChange = (bool) => { const afterVisibleChange = (bool) => {
console.log("state", bool); console.log("state", bool);
}; };
const addHomework = () => { const addHomework = () => {
if(state.choosedTime.length && state.inputV1 && state.textV1){
createWorkTask({ createWorkTask({
"createTime": "", "createTime": "",
"createUser": 0, "createUser": 0,
"submitEndTime": dayjs(state.choosedTime[1]).format("YYYY-MM-DD"), "submitEndTime": dayjs(formState.choosedTime[1]).format("YYYY-MM-DD"),
"submitStartTime": dayjs(state.choosedTime[0]).format("YYYY-MM-DD"), "submitStartTime": dayjs(formState.choosedTime[0]).format("YYYY-MM-DD"),
"updateTime": "", "updateTime": "",
"updateUser": 0, "updateUser": 0,
"workEnclosureAddress": "", "workEnclosureAddress": "",
"workFlag": "", "workFlag": "",
"workId": 0, "workId": 0,
"workName": state.inputV1, "workName": formState.workName,
"workRequirement": state.textV1, "workRequirement": formState.workRequirement,
"workTag": "" "workTag": ""
}).then((res)=>{ }).then((res)=>{
message.success(`添加成功${res}`) message.success(`添加成功${res}`)
ctx.emit("update:addhomeworkVisible", false); closeDrawer();
}).catch((err)=>{ }).catch((err)=>{
message.error(`添加失败${err}`) message.error(`添加失败${err}`)
}) })
} }
else{
message.error(`字段不能为空`)
return 0
}
}
return { return {
...toRefs(state),
afterVisibleChange, afterVisibleChange,
closeDrawer, closeDrawer,
rowSelection, rowSelection,
addHomework, addHomework,
handleChange, handleChange,
fileList, fileList,
headers: { formState,
"token":"123" handleFinish,
}, handleFinishFailed,
resetForm,
handleValidate,
formRef,
// layout,
rules,
}; };
}, },
}; };
@@ -217,6 +277,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;
@@ -313,6 +374,7 @@ export default {
} }
} }
.main_btns { .main_btns {
position: absolute;
height: 72px; height: 72px;
width: 100%; width: 100%;
bottom: 0; bottom: 0;
@@ -344,3 +406,4 @@ export default {
} }
} }
</style> </style>

View File

@@ -634,6 +634,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -295,6 +295,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -169,6 +169,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -16,154 +16,134 @@
@click="closeDrawer" @click="closeDrawer"
/> />
</div> </div>
<a-form
ref="formRef"
name="custom-validation"
:model="formState"
:rules="rules"
v-bind="layout"
@finish="handleFinish"
@validate="handleValidate"
@finishFailed="handleFinishFailed"
>
<div class="contentMain"> <div class="contentMain">
<div class="main_left"> <div class="main_left">
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">考试名称</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="作业名称" name="examinationName">
<a-input <a-input
v-model:value="inputV1" v-model:value="formState.examinationName"
style="width: 424px; height: 32px" style="width: 424px; height: 32px;margin-left: 35px;"
autocomplete="off"
placeholder="请输入考试名称" placeholder="请输入考试名称"
maxlength="20" maxlength="20"/>
/> </a-form-item>
</div> </div>
</div> </div>
<div class="main_item2"> <div class="main_item2">
<div class="signbox"> <a-form-item has-feedback label="考试说明" name="examinationExplain">
<span style="margin-right: 3px">考试说明</span>
</div>
<div class="textarea">
<a-textarea <a-textarea
v-model:value="testV1" v-model:value="formState.examinationExplain"
placeholder="请输入考试说明" placeholder="请输入考试说明"
allow-clear allow-clear
style="margin-left: 35px;"
maxlength="150" maxlength="150"
/> />
</div> </a-form-item>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">选择考试</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="选择考试" name="choosedTest">
<a-select <a-select
dropdownClassName="dropdown-style" dropdownClassName="dropdown-style"
style="width: 424px" style="width: 424px;margin-left: 35px;"
placeholder="请输入考试名称" placeholder="请输入考试名称"
:options="options1" :options="options1"
v-model:value="choosedTest" v-model:value="formState.choosedTest"
allowClear allowClear
showSearch showSearch
/> />
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">考试时间</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="考试时间" name="choosedTime">
<a-range-picker <a-range-picker
v-model:value="testTime" v-model:value="formState.choosedTime"
style="width: 424px" style="width: 424px;margin-left: 35px;"
:placeholder="[' 开始时间', ' 结束时间']" :placeholder="[' 开始时间', ' 结束时间']"
/> />
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">考试时长</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="考试时长" name="examinationDuration">
<a-input <a-input
v-model:value="inputV2" v-model:value="formState.examinationDuration"
style="width: 388px; height: 32px" style="width: 388px; height: 32px;
margin-left: 35px;"
/> />
<span style="margin-left: 5px">分钟</span> <span style="margin-left: 5px">分钟</span>
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<div class="sign">
<img
src="@/assets/images/coursewareManage/asterisk.png"
alt=""
/>
</div>
<span style="margin-right: 3px">考试限制</span>
</div>
<div class="btnbox"> <div class="btnbox">
<span style="margin-right: 8px">允许重复考试</span> <span style="margin-right: 43px">考试限制</span>
<a-form-item has-feedback label="允许重复考试" name="examinationLimit">
<a-input-number <a-input-number
:min="-1" :precision="0" :min="-1" :precision="0"
v-model:value="inputV3" v-model:value="formState.examinationLimit"
style="width: 88px; height: 32px;border-radius: 8px;overflow: hidden;" style="width: 88px; height: 32px;
border-radius: 8px;overflow: hidden;"
/> />
<span style="margin-left: 8px"></span> <span style="margin-left: 8px"></span>
<span style="margin-left: 24px; color: #999999" <span style="margin-left: 24px; color: #999999"
>-1表示无限制</span >-1表示无限制</span>
> </a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">显示答案</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-radio-group v-model:value="radioV1"> <a-form-item has-feedback label="显示答案" name="showAnswers">
<a-radio-group style="margin-left: 35px;" v-model:value="formState.showAnswers">
<a-radio v-model:checked="checked" :value="1" @click="cloradio1">允许查看</a-radio> <a-radio v-model:checked="checked" :value="1" @click="cloradio1">允许查看</a-radio>
<a-radio v-model:checked="checked" :value="2" @click="cloradio1" <a-radio v-model:checked="checked" :value="2" @click="cloradio1"
>不允许查看</a-radio >不允许查看</a-radio
> >
</a-radio-group> </a-radio-group>
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">显示解析</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-radio-group v-model:value="radioV2"> <a-form-item has-feedback label="显示解析" name="showAnalysis">
<a-radio-group style="margin-left: 35px;" v-model:value="formState.showAnalysis">
<a-radio v-model:checked="checked" :value="1" @click="cloradio2">允许查看</a-radio> <a-radio v-model:checked="checked" :value="1" @click="cloradio2">允许查看</a-radio>
<a-radio v-model:checked="checked" :value="2" @click="cloradio2" <a-radio v-model:checked="checked" :value="2" @click="cloradio2"
>不允许查看</a-radio >不允许查看</a-radio
> >
</a-radio-group> </a-radio-group>
</a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">评分模式</span>
</div>
<div class="btnbox"> <div class="btnbox">
<div class="btnbox"> <a-form-item has-feedback label="评分模式" name="scoringModel">
<a-radio-group v-model:value="radioV3">
<a-radio-group style="margin-left: 35px;" v-model:value="formState.scoringModel">
<a-radio v-model:checked="checked" :value="1" @click="cloradio3" <a-radio v-model:checked="checked" :value="1" @click="cloradio3"
>最高一次</a-radio >最高一次</a-radio
> >
@@ -171,44 +151,47 @@
>最后一次</a-radio >最后一次</a-radio
> >
</a-radio-group> </a-radio-group>
</div> </a-form-item>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">及格线</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-form-item has-feedback label="及格线" name="passLine">
<a-input <a-input
v-model:value="inputV4" v-model:value="formState.passLine"
style="width: 88px; height: 32px" style="width: 88px; height: 32px;margin-left: 35px;"
/> />
</a-form-item>
<span style="margin-left: 8px"></span> <span style="margin-left: 8px"></span>
</div> </div>
</div> </div>
<div class="main_item"> <div class="main_item">
<div class="signbox">
<span style="margin-right: 3px">试题排列</span>
</div>
<div class="btnbox"> <div class="btnbox">
<a-radio-group v-model:value="radioV4"> <a-form-item has-feedback label="作业要求" name="questionArrangement">
<a-radio-group v-model:value="formState.questionArrangement">
<a-radio v-model:checked="checked" :value="1" @click="cloradio4">试题乱序</a-radio> <a-radio v-model:checked="checked" :value="1" @click="cloradio4">试题乱序</a-radio>
<a-radio v-model:checked="checked" :value="2" @click="cloradio4">试题排序</a-radio> <a-radio v-model:checked="checked" :value="2" @click="cloradio4">试题排序</a-radio>
<a-radio v-model:checked="checked" :value="3" @click="cloradio4">全部乱序</a-radio> <a-radio v-model:checked="checked" :value="3" @click="cloradio4">全部乱序</a-radio>
</a-radio-group> </a-radio-group>
</a-form-item>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
<div class="main_btns"> <div class="main_btns">
<button class="btn1" @click="closeDrawer">取消</button> <a-button class="btn1" @click="closeDrawer">取消</a-button>
<button class="btn2" @click="addTest">确定</button> <a-button class="btn2" html-type="submit" >确定</a-button>
</div> </div>
</a-form>
</div> </div>
</a-drawer> </a-drawer>
</template> </template>
<script> <script>
import { reactive, toRefs, ref } from "vue"; import { reactive, ref } from "vue";
import {message} from"ant-design-vue"; import {message} from"ant-design-vue";
import {createExamination} from "@/api/indexExam" import {createExamination} from "@/api/indexExam"
import dayjs from 'dayjs'; import dayjs from 'dayjs';
@@ -239,19 +222,138 @@ export default {
}, },
}, },
setup(props, ctx) { setup(props, ctx) {
const state = reactive({ const formState = reactive({
inputV1: "", examinationName:'',
inputV2: "", examinationDuration:"",
inputV3: "", examinationLimit:"",
inputV4: "60", passLine:60,
testV1: "", examinationEndTime:"",
radioV1: "", examinationExplain:"",
radioV2: "", questionArrangement:1,
radioV3: "", scoringModel:2,
radioV4: "", showAnalysis:2,
choosedTest: "", showAnswers:2,
testTime:"",
}); });
const formRef = ref();
let checkExaminationName = async (_rule, value) => {
if (!value) {
message.warning("请输入考试名称");
return Promise.reject('请输入考试名称');
}
};
let checkExaminationExplain = async (_rule, value) => {
if (!value) {
message.warning("请输入考试说明");
return Promise.reject('请输入考试说明');
}
};
let checkChoosedTest = async (_rule, value) => {
if (!value) {
message.warning("请选择考试");
return Promise.reject('请选择考试');
}
};
let checkChoosedTime = async (_rule, value) => {
if (!value) {
message.warning("请选择时间");
return Promise.reject('请选择时间');
}
};
let checkExaminationDuration = async (_rule, value) => {
if (!value) {
message.warning("请输入考试时长");
return Promise.reject('请输入考试时长');
}
};
let checkLimit = async (_rule, value) => {
if (!value) {
message.warning("请输入考试限制");
return Promise.reject('请输入考试限制');
}
};
let checkShowAnswers = async (_rule, value) => {
if (!value) {
message.warning("请输入作业名称");
return Promise.reject('请输入作业名称');
}
};
let checkShowAnalysis = async (_rule, value) => {
if (!value) {
message.warning("请输入作业名称");
return Promise.reject('请输入作业名称');
}
};
let checkScoringModel = async (_rule, value) => {
if (!value) {
message.warning("请输入作业名称");
return Promise.reject('请输入作业名称');
}
};
let checkPassLine = async (_rule, value) => {
if (!value) {
message.warning("请输入及格线");
return Promise.reject('请输入及格线');
}
};
let checkQuestionArrangement = async (_rule, value) => {
if (!value) {
message.warning("请输入作业名称");
return Promise.reject('请输入作业名称');
}
};
const rules = {
examinationName: [{
required: true,
validator: checkExaminationName,
trigger: 'change',
}],
examinationExplain: [{
validator: checkExaminationExplain,
trigger: 'change',
}],
choosedTest: [{
required: true,
validator: checkChoosedTest,
trigger: 'change',
}],
choosedTime: [{
required: true,
validator: checkChoosedTime,
trigger: 'change',
}],
examinationDuration: [{
required: true,
validator: checkExaminationDuration,
trigger: 'change',
}],
limit: [{
required: true,
validator: checkLimit,
trigger: 'change',
}],
showAnswers: [{
validator: checkShowAnswers,
trigger: 'change',
}],
showAnalysis: [{
validator: checkShowAnalysis,
trigger: 'change',
}],
scoringModel: [{
validator: checkScoringModel,
trigger: 'change',
}],
passLine: [{
required: true,
validator: checkPassLine,
trigger: 'change',
}],
questionArrangement: [{
validator: checkQuestionArrangement,
trigger: 'change',
}],
};
const options1 = ref([ const options1 = ref([
{ {
label:'math', label:'math',
@@ -262,76 +364,82 @@ export default {
value:'eng', value:'eng',
}, },
]) ])
const handleFinish = values => {
console.log(values);
addTest()
};
const handleFinishFailed = errors => {
console.log(errors);
// message.error("handleFinishFailed");
};
const resetForm = () => {
formRef.value.resetFields();
};
const handleValidate = (...args) => {
console.log(args);
};
const closeDrawer = () => { const closeDrawer = () => {
resetForm();
ctx.emit("update:addtestVisible", false); ctx.emit("update:addtestVisible", false);
state.radioV1 = "";
state.radioV2 = "";
state.radioV3 = "";
state.radioV4 = "";
}; };
const addTest = () => { const addTest = () => {
if(state.testTime.length
&& state.inputV1&& state.inputV2&& state.inputV3&& state.inputV4
&& state.radioV1&& state.radioV2&& state.radioV3
){
createExamination({ createExamination({
"createTime": "", "createTime": "",
"createUser": 0, "createUser": 0,
"examinationDuration": state.inputV2, "examinationDuration": formState.examinationDuration,
"examinationEndTime": dayjs(state.testTime[1]).format("YYYY-MM-DD"), "examinationEndTime": dayjs(formState.choosedTime[1]).format("YYYY-MM-DD"),
"examinationExplain": state.testV1, "examinationExplain": formState.examinationExplain,
"examinationFlag": "", "examinationFlag": "",
"examinationId": 0, "examinationId": 0,
"examinationLimit": state.inputV3, "examinationLimit": formState.examinationLimit,
"examinationName": state.inputV1, "examinationName": formState.examinationName,
"examinationPaperId": 0, "examinationPaperId": 0,
"examinationPaperName": state.choosedTest, "examinationPaperName": formState.choosedTest,
"examinationStartTime": dayjs(state.testTime[0]).format("YYYY-MM-DD"), "examinationStartTime": dayjs(formState.choosedTime[0]).format("YYYY-MM-DD"),
"examinationTag": "", "examinationTag": "",
"passLine": state.inputV4, "passLine": formState.passLine,
"questionArrangement": state.radioV4, "questionArrangement": formState.questionArrangement,
"scoringModel": state.radioV3, "scoringModel": formState.scoringModel,
"showAnalysis": state.radioV2, "showAnalysis": formState.showAnalysis,
"showAnswers": state.radioV1, "showAnswers": formState.showAnswers,
"updateTime": "", "updateTime": "",
"updateUser": 0 "updateUser": 0
}).then((res)=>{ }).then((res)=>{
message.success(`添加成功${res}`) message.success(`添加成功${res}`)
ctx.emit("update:addtestVisible", false); closeDrawer();
}).catch((err)=>{ }).catch((err)=>{
message.error(`添加失败${err}`) message.error(`添加失败${err}`)
}) })
}
else{
message.error(`字段不能为空`)
return 0
}
} }
const afterVisibleChange = (bool) => { const afterVisibleChange = (bool) => {
console.log("state", bool); console.log("formState", bool);
}; };
const cloradio1 = (value) => { const cloradio1 = (value) => {
if (value != "") { if (value != "") {
state.radioV1 = ""; formState.showAnswers = "";
} }
} }
const cloradio2 = (value) => { const cloradio2 = (value) => {
if (value != "") { if (value != "") {
state.radioV2 = ""; formState.showAnalysis = "";
} }
} }
const cloradio3 = (value) => { const cloradio3 = (value) => {
if (value != "") { if (value != "") {
state.radioV3 = ""; formState.scoringModel = "";
} }
} }
const cloradio4 = (value) => { const cloradio4 = (value) => {
if (value != "") { if (value != "") {
state.radioV4 = ""; formState.questionArrangement = "";
} }
} }
return { return {
...toRefs(state), formState,
afterVisibleChange, afterVisibleChange,
closeDrawer, closeDrawer,
rowSelection, rowSelection,
@@ -341,6 +449,13 @@ export default {
cloradio4, cloradio4,
addTest, addTest,
options1, options1,
handleFinish,
handleFinishFailed,
resetForm,
handleValidate,
formRef,
// layout,
rules,
}; };
}, },
}; };
@@ -357,6 +472,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -177,6 +177,7 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
flex-shrink: 0;
.headerTitle { .headerTitle {
font-size: 18px; font-size: 18px;
font-weight: 600; font-weight: 600;

View File

@@ -389,7 +389,7 @@ export default {
const errorMsgs = { const errorMsgs = {
"name": "请输入项目名称", "name": "请输入项目名称",
"type": "请选择项目分类", "category": "请选择项目分类",
"picUrl": "请上传项目封面图", "picUrl": "请上传项目封面图",
"beginTime": "请选择项目开始时间", "beginTime": "请选择项目开始时间",
"endTime": "请选择项目结束时间", "endTime": "请选择项目结束时间",
@@ -405,7 +405,7 @@ export default {
const createProject = () => { const createProject = () => {
let obj = { let obj = {
"name": projectName["value"], "name": projectName["value"],
"type": projectType, "category": projectType,
"picUrl": picUrl, "picUrl": picUrl,
"beginTime": beginTime, "beginTime": beginTime,
"endTime": endTime, "endTime": endTime,
@@ -418,9 +418,9 @@ export default {
"systemId": 4, "systemId": 4,
"boeFlag": boeFlag, "boeFlag": boeFlag,
"attach": attach, "attach": attach,
"type": 3,
"templateId": 10, "templateId": 10,
"parentId": 0, "parentId": 0,
"category": 0,
"notice": "", "notice": "",
"noticeFlag": 0, "noticeFlag": 0,
"status": 0 "status": 0
@@ -428,7 +428,7 @@ export default {
console.log('提交的数据格式 %o', obj) console.log('提交的数据格式 %o', obj)
for (let i in errorMsgs) { for (let i in errorMsgs) {
console.log(obj[i]) console.log(obj[i])
if (obj[i] === "") { if (obj[i] === "" || obj[i] === undefined) {
message.destroy() message.destroy()
message.warning(errorMsgs[i]) message.warning(errorMsgs[i])
return return

File diff suppressed because it is too large Load Diff

View File

@@ -542,6 +542,7 @@ import * as apilive from "../../api/indexLiveBroadcast";
import * as apidiscuss from "../../api/indexDiscuss"; import * as apidiscuss from "../../api/indexDiscuss";
import * as apiactivity from "../../api/indexActivity"; import * as apiactivity from "../../api/indexActivity";
import * as apieval from "../../api/indexEval"; import * as apieval from "../../api/indexEval";
import * as apiinvist from "../../api/indexInvist";
const drawercolumns = [ const drawercolumns = [
{ {
title: "项目名称", title: "项目名称",
@@ -857,6 +858,8 @@ export default {
isactive: -1, isactive: -1,
isActive: false, isActive: false,
deleteLiveID: null, //删除直播id deleteLiveID: null, //删除直播id
deleteEvalID: null, //测评
deleteInvistID: null, //评估
deleteDiscussID: null, //删除讨论id deleteDiscussID: null, //删除讨论id
deleteActivityID: null, //删除活动id deleteActivityID: null, //删除活动id
}); });
@@ -983,7 +986,8 @@ export default {
style="color:#4EA6FF;cursor:pointer" style="color:#4EA6FF;cursor:pointer"
onClick={() => { onClick={() => {
showDelete(); showDelete();
{/* deleteEvalText(); */} deleteEvalText();
deleteInvistText();
}} }}
> >
删除 删除
@@ -1066,17 +1070,16 @@ export default {
console.log("删除失败", err); console.log("删除失败", err);
}); });
}; };
//删除评测试 //删除评测试
const deleteEvalText = () => { const deleteEvalText = () => {
let obj = { let obj = {
evaluationId:state.deleteLiveID, evaluationId:state.deleteEvalID,
}; };
apieval apieval
.deleteEvaluationById(obj) .deleteEvaluationById(obj)
.then((res) => { .then((res) => {
console.log("删除成功", res); console.log("删除成功", res);
message.success("删除成功"); message.success("删除成功");
state.deleteModal = false;
//重新获取列表 //重新获取列表
getTask(); getTask();
}) })
@@ -1084,6 +1087,25 @@ export default {
console.log("删除失败", err); console.log("删除失败", err);
}); });
}; };
//删除评估测试
const deleteInvistText = () => {
let obj = {
evaluationId:state.deleteInvistID,
};
apiinvist
.deleteAppraise(obj)
.then((res) => {
console.log("删除成功", res);
message.success("删除成功");
//重新获取列表
getTask();
})
.catch((err) => {
console.log("删除失败", err);
});
};
const onSelectChange = (selectedRowKeys) => { const onSelectChange = (selectedRowKeys) => {
console.log("selectedRowKeys changed: ", selectedRowKeys); console.log("selectedRowKeys changed: ", selectedRowKeys);
state.selectedRowKeys = selectedRowKeys; state.selectedRowKeys = selectedRowKeys;
@@ -1214,6 +1236,7 @@ export default {
deleteDiscuss, deleteDiscuss,
deleteEvalText, deleteEvalText,
deleteActivity, deleteActivity,
deleteInvistText,
}; };
}, },
}; };