Fix: 作业&考试表单修改

This commit is contained in:
王熙东
2022-11-01 17:11:58 +08:00
parent df9fdbbbf3
commit b0fe8b7fa3
2 changed files with 368 additions and 191 deletions

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,
}; };
}, },
}; };
@@ -313,6 +373,7 @@ export default {
} }
} }
.main_btns { .main_btns {
position: absolute;
height: 72px; height: 72px;
width: 100%; width: 100%;
bottom: 0; bottom: 0;
@@ -344,3 +405,4 @@ export default {
} }
} }
</style> </style>

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,
}; };
}, },
}; };