feat: 在线考试详情页调整
This commit is contained in:
parent
9a7dea317b
commit
046d544872
|
@ -2914,17 +2914,7 @@ const routes = [
|
||||||
perms: ["train"],
|
perms: ["train"],
|
||||||
},
|
},
|
||||||
component: "edu/train",
|
component: "edu/train",
|
||||||
},
|
}
|
||||||
{
|
|
||||||
name: "examrecord",
|
|
||||||
path: "/edu/examrecord",
|
|
||||||
meta: {
|
|
||||||
title: "考试记录",
|
|
||||||
// icon: "el-icon-notebook",
|
|
||||||
perms: ["examrecord"],
|
|
||||||
},
|
|
||||||
component: "edu/examrecord",
|
|
||||||
},
|
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -40,9 +40,7 @@
|
||||||
width="80"
|
width="80"
|
||||||
>
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-icon v-if="scope.row.can_attend" color="green"
|
<el-tag v-if="scope.row.can_attend" type="success">是</el-tag>
|
||||||
><CircleCheckFilled
|
|
||||||
/></el-icon>
|
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column
|
<el-table-column
|
||||||
|
@ -67,16 +65,14 @@
|
||||||
width="80"
|
width="80"
|
||||||
>
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-icon v-if="scope.row.is_public" color="green"
|
<el-tag v-if="scope.row.is_public" type="success">是</el-tag>
|
||||||
><CircleCheckFilled
|
|
||||||
/></el-icon>
|
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column
|
<el-table-column
|
||||||
label="操作"
|
label="操作"
|
||||||
fixed="right"
|
fixed="right"
|
||||||
align="center"
|
align="center"
|
||||||
width="150"
|
width="160"
|
||||||
>
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-button
|
<el-button
|
||||||
|
@ -92,7 +88,7 @@
|
||||||
size="small"
|
size="small"
|
||||||
@click="row_detail(scope.row)"
|
@click="row_detail(scope.row)"
|
||||||
type="primary"
|
type="primary"
|
||||||
>详情</el-button
|
>答题详情</el-button
|
||||||
>
|
>
|
||||||
<el-popconfirm
|
<el-popconfirm
|
||||||
title="确定删除吗?"
|
title="确定删除吗?"
|
||||||
|
@ -194,11 +190,16 @@
|
||||||
>
|
>
|
||||||
</template>
|
</template>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
|
<el-drawer v-model="drawerVisible" title="考试记录" size="50%">
|
||||||
|
<ExamRecord :exam="examId" v-if="drawerVisible"></ExamRecord>
|
||||||
|
</el-drawer>
|
||||||
</el-container>
|
</el-container>
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
const defaultExam = {chance: 1, is_public:false}
|
const defaultExam = {chance: 1, is_public:false}
|
||||||
|
import ExamRecord from './examrecord.vue';
|
||||||
export default {
|
export default {
|
||||||
|
components: { ExamRecord },
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
paperOptions:[],
|
paperOptions:[],
|
||||||
|
@ -208,6 +209,8 @@ export default {
|
||||||
search: "",
|
search: "",
|
||||||
},
|
},
|
||||||
examForm: Object.assign({}, defaultExam),
|
examForm: Object.assign({}, defaultExam),
|
||||||
|
drawerVisible: false,
|
||||||
|
examId: null
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
|
@ -233,10 +236,12 @@ export default {
|
||||||
this.examDialog = true;
|
this.examDialog = true;
|
||||||
},
|
},
|
||||||
row_detail(row) {
|
row_detail(row) {
|
||||||
this.$router.push({
|
// this.$router.push({
|
||||||
path: "/edu/examrecord/",
|
// path: "/edu/examrecord/",
|
||||||
query: { id: row.id },
|
// query: { id: row.id },
|
||||||
});
|
// });
|
||||||
|
this.examId = row.id;
|
||||||
|
this.drawerVisible = true;
|
||||||
},
|
},
|
||||||
table_del(row) {
|
table_del(row) {
|
||||||
this.$API.edu.exam.delete.req(row.id).then(() => {
|
this.$API.edu.exam.delete.req(row.id).then(() => {
|
||||||
|
|
|
@ -3,9 +3,9 @@
|
||||||
<el-header>
|
<el-header>
|
||||||
<div class="right-panel">
|
<div class="right-panel">
|
||||||
<el-input
|
<el-input
|
||||||
style="margin-right: 5px"
|
style="margin-right: 2px"
|
||||||
v-model="query.search"
|
v-model="query.search"
|
||||||
placeholder="考试名称或用户"
|
placeholder="用户名"
|
||||||
clearable
|
clearable
|
||||||
></el-input>
|
></el-input>
|
||||||
<el-button
|
<el-button
|
||||||
|
@ -20,6 +20,7 @@
|
||||||
ref="table"
|
ref="table"
|
||||||
:apiObj="apiObj"
|
:apiObj="apiObj"
|
||||||
row-key="id"
|
row-key="id"
|
||||||
|
:params="params"
|
||||||
:query="query"
|
:query="query"
|
||||||
>
|
>
|
||||||
<el-table-column
|
<el-table-column
|
||||||
|
@ -83,27 +84,22 @@
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
|
props: {
|
||||||
|
exam: { type: String }
|
||||||
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
paperOptions:[],
|
|
||||||
examDialog: false,
|
examDialog: false,
|
||||||
apiObj: this.$API.edu.examrecord.list,
|
apiObj: this.$API.edu.examrecord.list,
|
||||||
|
params: { exam: this.exam },
|
||||||
query: {
|
query: {
|
||||||
search: "",
|
search: ""
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
this.getPaperOptions();
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getPaperOptions() {
|
|
||||||
this.$API.edu.paper.list.req({
|
|
||||||
page: 0
|
|
||||||
}).then(res => {
|
|
||||||
this.paperOptions = res;
|
|
||||||
});
|
|
||||||
},
|
|
||||||
formatBoolean(row) {
|
formatBoolean(row) {
|
||||||
return row.isTrue ? '是' : '否';
|
return row.isTrue ? '是' : '否';
|
||||||
},
|
},
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
<el-table-column
|
<el-table-column
|
||||||
label="时长(h)"
|
label="时长(h)"
|
||||||
prop="duration"
|
prop="duration"
|
||||||
|
width="80"
|
||||||
></el-table-column>
|
></el-table-column>
|
||||||
<el-table-column
|
<el-table-column
|
||||||
label="开始时间"
|
label="开始时间"
|
||||||
|
@ -57,18 +58,12 @@
|
||||||
label="地点"
|
label="地点"
|
||||||
prop="place"
|
prop="place"
|
||||||
></el-table-column>
|
></el-table-column>
|
||||||
<el-table-column
|
|
||||||
label="内容描述"
|
|
||||||
prop="description"
|
|
||||||
></el-table-column>
|
|
||||||
<el-table-column
|
<el-table-column
|
||||||
label="是否公开"
|
label="是否公开"
|
||||||
width="80"
|
width="80"
|
||||||
>
|
>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<el-icon v-if="scope.row.is_public" color="green"
|
<el-tag v-if="scope.row.is_public" type="success">是</el-tag>
|
||||||
><CircleCheckFilled
|
|
||||||
/></el-icon>
|
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column
|
<el-table-column
|
||||||
|
@ -117,57 +112,16 @@
|
||||||
label-width="100px"
|
label-width="100px"
|
||||||
ref="questioncatForm"
|
ref="questioncatForm"
|
||||||
>
|
>
|
||||||
|
<el-row>
|
||||||
|
<el-col :span="18">
|
||||||
<el-form-item label="培训名称" prop="name" required>
|
<el-form-item label="培训名称" prop="name" required>
|
||||||
<el-input
|
<el-input
|
||||||
v-model="trainForm.name"
|
v-model="trainForm.name"
|
||||||
style="width: 80%;"
|
style="width: 100%;"
|
||||||
></el-input>
|
></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-row>
|
|
||||||
<el-col :span="8">
|
|
||||||
<el-form-item label="开始时间" prop="start_time" required>
|
|
||||||
<el-date-picker
|
|
||||||
v-model="trainForm.start_time"
|
|
||||||
type="datetime"
|
|
||||||
style="width:100%"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="8">
|
<el-col :span="6">
|
||||||
<el-form-item label="结束时间" prop="end_time">
|
|
||||||
<el-date-picker
|
|
||||||
v-model="trainForm.end_time"
|
|
||||||
type="datetime"
|
|
||||||
style="width:100%"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-form-item label="地点" prop="place" required>
|
|
||||||
<el-input
|
|
||||||
v-model="trainForm.place"
|
|
||||||
clearable
|
|
||||||
></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="时长(h)" prop="duration" required>
|
|
||||||
<el-input-number
|
|
||||||
v-model="trainForm.duration"
|
|
||||||
controls-position="right"
|
|
||||||
:step="0.5"
|
|
||||||
step-strictly="true"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="内容描述" prop="description" required>
|
|
||||||
<el-input
|
|
||||||
v-model="trainForm.description"
|
|
||||||
clearable
|
|
||||||
autisize
|
|
||||||
type="textarea"
|
|
||||||
style="width: 240%;"
|
|
||||||
></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-col :span="8">
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="16">
|
|
||||||
<el-form-item label="级别" prop="level" required>
|
<el-form-item label="级别" prop="level" required>
|
||||||
<el-select
|
<el-select
|
||||||
v-model="trainForm.level"
|
v-model="trainForm.level"
|
||||||
|
@ -186,7 +140,43 @@
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="8">
|
<el-col :span="12">
|
||||||
|
<el-form-item label="开始时间" prop="start_time" required>
|
||||||
|
<el-date-picker
|
||||||
|
v-model="trainForm.start_time"
|
||||||
|
type="datetime"
|
||||||
|
style="width:100%"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="结束时间" prop="end_time">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="trainForm.end_time"
|
||||||
|
type="datetime"
|
||||||
|
style="width:100%"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="地点" prop="place" required>
|
||||||
|
<el-input
|
||||||
|
v-model="trainForm.place"
|
||||||
|
clearable
|
||||||
|
></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="6">
|
||||||
|
<el-form-item label="时长(h)" prop="duration" required>
|
||||||
|
<el-input-number
|
||||||
|
v-model="trainForm.duration"
|
||||||
|
controls-position="right"
|
||||||
|
:step="0.5"
|
||||||
|
step-strictly="true"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="6">
|
||||||
<el-form-item
|
<el-form-item
|
||||||
label="是否公开"
|
label="是否公开"
|
||||||
prop="is_public"
|
prop="is_public"
|
||||||
|
@ -195,6 +185,16 @@
|
||||||
<el-switch v-model="trainForm.is_public"/>
|
<el-switch v-model="trainForm.is_public"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="内容描述" prop="description" required>
|
||||||
|
<el-input
|
||||||
|
v-model="trainForm.description"
|
||||||
|
clearable
|
||||||
|
autisize
|
||||||
|
type="textarea"
|
||||||
|
></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
<el-form-item label="附件" prop="files">
|
<el-form-item label="附件" prop="files">
|
||||||
<sc-upload-file
|
<sc-upload-file
|
||||||
:multiple="false"
|
:multiple="false"
|
||||||
|
|
Loading…
Reference in New Issue