feat: 在线考试详情页调整

This commit is contained in:
caoqianming 2025-02-05 17:54:21 +08:00
parent 9a7dea317b
commit 046d544872
4 changed files with 79 additions and 88 deletions

View File

@ -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",
},
], ],
}, },
{ {

View File

@ -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(() => {

View File

@ -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 ? '是' : '否';
}, },

View File

@ -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"