龚焕茏
2024-06-26 a3f19959cbc1ad380ba84e6d8699d3e00afa07a7
feat:考试监控
5个文件已修改
1个文件已添加
217 ■■■■■ 已修改文件
src/api/cheat.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/exam.js 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/router.js 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/education/cheat/list.vue 9 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/exam/exam/ExamManage.vue 7 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/exam/exam/monitor.vue 183 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/api/cheat.js
@@ -3,7 +3,7 @@
export default {
  list: query => post('/api/admin/cheat/list'),
  pageList: query => get('/api/admin/cheat/page', query),
  edit: query => post('/api/admin/cheat/edit', query),
  edit: query => post('/api/admin/cheat', query),
  select: id => post('/api/admin/cheat/select/' + id),
  deletecheat: id => post('/api/admin/cheat/delete/' + id),
  updateStatus: query => post('/api/admin/cheat/status', query),
src/api/exam.js
@@ -75,3 +75,12 @@
    method: 'GET'
  })
}
// 考试监控列表
export const monitorList = (params) => {
  return axios({
    url: '/api/admin/exam/monitor/list',
    method: 'GET',
    params: params
  })
}
src/router.js
@@ -59,6 +59,13 @@
        name: 'MarkPaperDetail',
        meta: { title: '阅卷'},
        hidden: true
      },
      {
        path: '/exam/monitor',
        component: () => import('@/views/exam/exam/monitor'),
        name: 'monitor',
        meta: { title: '监控'},
        hidden: true
      }
    ]
  },
src/views/education/cheat/list.vue
@@ -10,8 +10,8 @@
    </el-form>
    <el-table v-loading="listLoading" :data="tableData" border fit highlight-current-row style="width: 100%">
      <el-table-column align="center" prop="cheatUserName" label="作弊人名称" show-overflow-tooltip />
      <el-table-column align="center" prop="examName" label="考试名称" />
      <el-table-column align="center" prop="cheatUserName" label="姓名" show-overflow-tooltip />
      <el-table-column align="center" prop="examName" label="考试" />
      <el-table-column align="center" prop="createTime" label="作弊时间" />
      <!-- <el-table-column label="操作" align="center">
        <template slot-scope="{row}">
@@ -97,7 +97,6 @@
      })
    },
    edit(row) {
      if (row) {
        cheatApi.select(row.id).then(re => {
          if (re.code === 1) {
            this.form = re.data;
@@ -106,10 +105,6 @@
            this.$message.error(re.message)
          }
        })
      } else {
        this.getItemOrder();
        this.visible = true;
      }
    },
    status(row) {
      let question = {
src/views/exam/exam/ExamManage.vue
@@ -64,7 +64,7 @@
        width="150px"
        prop="createTime"
      ></el-table-column>
      <el-table-column label="操作" fiexd="right" width="210px">
      <el-table-column label="操作" fiexd="right" width="280px">
        <template slot-scope="scope">
          <el-button
            type="primary"
@@ -74,6 +74,7 @@
          </el-button>
          <el-button type="danger" size="small" @click="deleteExam(scope.row.id)">删除</el-button>
          <el-button type="success" size="small" @click="markPaper(scope.row)">阅卷</el-button>
          <el-button type="warning" size="small" @click="monitor(scope.row)">监控</el-button>
        </template>
      </el-table-column>
    </el-table>
@@ -195,6 +196,10 @@
    this.MyExamPaperList()
  },
  methods: {
    // 考试监控列表
    monitor (row) {
      this.$router.push({ path: '/exam/monitor', query: { examId: row.id } })
    },
    markPaper (row) {
      // 跳转阅卷页面
      this.$router.push({ path: '/exam/mark/paper', query: { examName: row.examName, examId: row.id } })
src/views/exam/exam/monitor.vue
New file
@@ -0,0 +1,183 @@
<template>
  <div class="app-container">
    <el-form :model="queryParam" ref="queryForm" :inline="true">
      <el-form-item>
        <el-input v-model="queryParam.keyword" placeholder="请输入名称" clearable></el-input>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="search">查询</el-button>
      </el-form-item>
    </el-form>
    <el-table v-loading="listLoading" :data="tableData" border fit highlight-current-row style="width: 100%">
      <el-table-column align="center" prop="examName" label="考试" />
      <el-table-column align="center" prop="userName" label="姓名" show-overflow-tooltip />
      <el-table-column align="center" prop="createTime" label="开始时间" />
      <el-table-column align="center" prop="doTime" label="耗时(秒)" />
      <el-table-column align="center" prop="status" label="状态" :formatter="statusFormatter" />
      <el-table-column label="操作" align="center">
        <template slot-scope="{row}">
          <el-button size="mini" type="danger" @click="handleNullify(row)">作废</el-button>
          <el-button size="mini" type="primary" @click="edit(row)">收卷</el-button>
          <el-button size="mini" type="success" @click="edit(row)">加时</el-button>
        </template>
      </el-table-column>
    </el-table>
    <pagination v-show="total > 0" :total="total" :page.sync="queryParam.pageIndex" :limit.sync="queryParam.pageSize"
      @pagination="search" />
    <el-dialog :visible.sync="visible" width="400px">
      <el-form :model="form" ref="form" label-width="100px" v-loading="formLoading" :rules="rules">
        <el-form-item label="名称:" prop="name" required>
          <el-input v-model="form.name" maxlength="10" show-word-limit />
        </el-form-item>
        <el-form-item label="排序:" prop="itemOrder" required>
          <el-input-number v-model="form.itemOrder" type="number" :min="1" :max="100" />
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="submitForm">提交</el-button>
          <el-button @click="resetForm">重置</el-button>
        </el-form-item>
      </el-form>
    </el-dialog>
  </div>
</template>
<script>
import { mapGetters, mapState } from 'vuex'
import Pagination from '@/components/Pagination'
import { monitorList } from '@/api/exam'
import cheatApi from '@/api/cheat'
export default {
  components: { Pagination },
  data() {
    return {
      listLoading: true,
      queryParam: {
        examId: '',
        pageIndex: 1,
        pageSize: 10
      },
      formLoading: false,
      total: 0,
      tableData: [],
      form: {
        id: '',
        name: '',
        itemOrder: ''
      },
      visible: false,
      rules: {
        name: [
          { required: true, message: '请输入名称', trigger: 'blur' }
        ],
        itemOrder: [
          { required: true, message: '请输入排序', trigger: 'blur', type: 'number' }
        ]
      },
    };
  },
  created() {
    this.queryParam.examId = this.$route.query.examId;
    this.search()
  },
  methods: {
    handleNullify(row) {
      let cheatObj = { examId: row.examId, cheatUser: row.userId };
      cheatApi.edit(cheatObj).then(res => {
        this.$message.success(res.message);
      })
    },
    statusFormatter(row) {
      if (row.status === 'temp') {
        return '进行中'
      } else if (row.status === 'finish') {
        return '已结束'
      }
    },
    // 获取列表
    search() {
      this.listLoading = true
      monitorList(this.queryParam).then(re => {
        re = re.data
        this.tableData = re.data.records
        this.total = re.data.total
        this.queryParam.pageSize = re.data.size
        this.queryParam.pageIndex = re.data.pages
        this.listLoading = false
      })
    },
    edit(row) {
      cheatApi.select(row.id).then(re => {
        if (re.code === 1) {
          this.form = re.data;
          this.visible = true;
        } else {
          this.$message.error(re.message)
        }
      })
    },
    status(row) {
      let question = {
        id: row.id,
        status: row.status === '禁用' ? '启用' : '禁用'
      }
      cheatApi.updateStatus(question).then(re => {
        if (re.code === 1) {
          this.$message.success(re.message)
          this.search()
        } else {
          this.$message.error(re.message)
        }
      })
    },
    deletecheat(row) {
      let _this = this
      cheatApi.deletecheat(row.id).then(re => {
        if (re.code === 1) {
          _this.search()
          _this.$message.success(re.message)
        } else {
          _this.$message.error(re.message)
        }
      })
    },
    submitForm() {
      let _this = this
      this.$refs.form.validate((valid) => {
        if (valid) {
          this.formLoading = true
          cheatApi.edit(this.form).then(re => {
            if (re.code === 1) {
              _this.$message.success(re.message)
              _this.search()
              _this.formLoading = false
              _this.visible = false
            } else {
              _this.$message.error(re.message)
              _this.formLoading = false
              _this.visible = false
            }
          })
        }
      })
    },
    resetForm() {
      let lastId = this.form.id
      this.$refs['form'].resetFields()
      this.form.id = lastId
    },
  },
  computed: {
    ...mapGetters('enumItem', [
      'enumFormat'
    ]),
    ...mapState('enumItem', {
      levelEnum: state => state.user.levelEnum
    })
  }
}
</script>