|
@@ -0,0 +1,113 @@
|
|
|
+<template>
|
|
|
+ <div class="part-box is-filter">
|
|
|
+ <el-form inline>
|
|
|
+ <el-form-item label="科目">
|
|
|
+ <el-select
|
|
|
+ v-model="searchModel.subject"
|
|
|
+ placeholder="请选择"
|
|
|
+ clearable
|
|
|
+ style="width: 120px"
|
|
|
+ >
|
|
|
+ <el-option label="请选择" value="" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="层次">
|
|
|
+ <el-select
|
|
|
+ v-model="searchModel.level"
|
|
|
+ placeholder="请选择"
|
|
|
+ clearable
|
|
|
+ style="width: 120px"
|
|
|
+ >
|
|
|
+ <el-option label="请选择" value="" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="专业类型">
|
|
|
+ <el-select
|
|
|
+ v-model="searchModel.majorType"
|
|
|
+ placeholder="请选择"
|
|
|
+ clearable
|
|
|
+ style="width: 120px"
|
|
|
+ >
|
|
|
+ <el-option label="请选择" value="" />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item>
|
|
|
+ <el-space wrap>
|
|
|
+ <el-button type="primary" @click="toPage(1)">查询</el-button>
|
|
|
+ <el-button @click="exportData">导出</el-button>
|
|
|
+ </el-space>
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ </div>
|
|
|
+ <div class="part-box">
|
|
|
+ <el-table class="page-table" :data="dataList" :loading="loading">
|
|
|
+ <el-table-column property="name" label="考试名称" min-width="200" />
|
|
|
+ <el-table-column
|
|
|
+ property="totalStudents"
|
|
|
+ label="考生总数"
|
|
|
+ min-width="100"
|
|
|
+ />
|
|
|
+ <el-table-column
|
|
|
+ property="scannedSheets"
|
|
|
+ label="已扫张数"
|
|
|
+ min-width="100"
|
|
|
+ />
|
|
|
+ <el-table-column
|
|
|
+ property="scannedStudents"
|
|
|
+ label="已扫人数"
|
|
|
+ min-width="100"
|
|
|
+ />
|
|
|
+ <el-table-column
|
|
|
+ property="manualAbsent"
|
|
|
+ label="人工指定缺考"
|
|
|
+ min-width="100"
|
|
|
+ />
|
|
|
+ <el-table-column label="进度" width="100">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-progress
|
|
|
+ :percentage="scope.row.progress"
|
|
|
+ :color="getProgressColor(scope.row.progress)"
|
|
|
+ />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ </el-table>
|
|
|
+ <el-pagination
|
|
|
+ v-model:current-page="pagination.pageNumber"
|
|
|
+ v-model:page-size="pagination.pageSize"
|
|
|
+ :layout="pagination.layout"
|
|
|
+ :total="pagination.total"
|
|
|
+ @size-change="pageSizeChange"
|
|
|
+ @current-change="toPage"
|
|
|
+ />
|
|
|
+ </div>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script setup lang="ts">
|
|
|
+ import { reactive } from 'vue';
|
|
|
+ import { getScanCourseList } from '@/api/scan';
|
|
|
+ import { ScanItem, ScanCourseListFilter } from '@/api/types/scan';
|
|
|
+ import useTable from '@/hooks/table';
|
|
|
+
|
|
|
+ defineOptions({
|
|
|
+ name: 'ScanCourseStats',
|
|
|
+ });
|
|
|
+
|
|
|
+ const searchModel = reactive<ScanCourseListFilter>({
|
|
|
+ subject: '',
|
|
|
+ level: '',
|
|
|
+ majorType: '',
|
|
|
+ });
|
|
|
+
|
|
|
+ const { dataList, pagination, loading, toPage, pageSizeChange } =
|
|
|
+ useTable<ScanItem>(getScanCourseList, searchModel, false);
|
|
|
+
|
|
|
+ function getProgressColor(progress: number) {
|
|
|
+ if (progress < 30) return '#f56c6c';
|
|
|
+ if (progress < 70) return '#e6a23c';
|
|
|
+ return '#67c23a';
|
|
|
+ }
|
|
|
+
|
|
|
+ function exportData() {
|
|
|
+ // TODO: 实现导出功能
|
|
|
+ }
|
|
|
+</script>
|