123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- <template>
- <div class="wait-task">
- <div class="part-box part-box-filter">
- <el-form ref="FilterForm" label-position="left" label-width="85px" inline>
- <el-form-item label="考试名称:">
- <el-select
- v-model="filter.examId"
- style="width: 315px;"
- placeholder="请选择"
- clearable
- >
- <el-option
- v-for="item in exams"
- :key="item.id"
- :value="item.id"
- :label="item.name"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label-width="0px">
- <el-button type="primary" icon="icon icon-search" @click="toPage(1)"
- >查询</el-button
- >
- </el-form-item>
- </el-form>
- </div>
- <div class="part-box">
- <el-table
- ref="TableList"
- :data="tasks"
- :row-class-name="tableRowClassName"
- border
- stripe
- >
- <el-table-column prop="examCode" label="考试ID"></el-table-column>
- <el-table-column prop="examName" label="考试名称"></el-table-column>
- <el-table-column prop="courseNameCode" label="科目名称(编码)">
- </el-table-column>
- <el-table-column prop="paperStatus" label="试卷"></el-table-column>
- <el-table-column prop="cardStatus" label="答题卡"></el-table-column>
- <el-table-column prop="endTime" label="任务截止日期"></el-table-column>
- <el-table-column prop="overTime" label="剩余时间"></el-table-column>
- <el-table-column prop="receiveTime" label="接收时间"></el-table-column>
- <el-table-column label="操作" align="center">
- <template slot-scope="scope">
- <el-button
- class="btn-table-icon"
- type="text"
- icon="icon icon-circle-right"
- @click="toDetail(scope.row)"
- title="详情"
- ></el-button>
- </template>
- </el-table-column>
- </el-table>
- <div class="part-page">
- <el-pagination
- background
- layout="prev, pager, next"
- :current-page="current"
- :total="total"
- :page-size="size"
- @current-change="toPage"
- >
- </el-pagination>
- </div>
- </div>
- </div>
- </template>
- <script>
- import { waitTaskListPage, examList } from "../api";
- import { mapActions } from "vuex";
- export default {
- name: "wait-task",
- data() {
- return {
- filter: {
- examId: ""
- },
- current: 1,
- size: this.GLOBAL.pageSize,
- total: 0,
- visible: false,
- exams: [],
- tasks: []
- };
- },
- created() {
- this.init();
- },
- methods: {
- ...mapActions("examCenter", ["updateWaitTaskCount"]),
- init() {
- this.getExamList();
- this.toPage(1);
- },
- async getList() {
- const datas = {
- ...this.filter,
- pageNumber: this.current,
- pageSize: this.size
- };
- const result = await waitTaskListPage(datas);
- const data = result || { records: [], total: 0 };
- this.tasks = data.records;
- this.total = data.total;
- },
- toPage(page) {
- this.current = page;
- this.getList();
- this.updateWaitTaskCount();
- },
- async getExamList() {
- const data = await examList();
- this.exams = data.map(item => {
- return {
- id: item.id,
- name: item.examName
- };
- });
- },
- tableRowClassName({ row }) {
- return row.warning ? "row-danger" : "";
- },
- toDetail(row) {
- this.$router.push({
- name: "WaitTaskDetail",
- params: {
- taskId: row.id
- }
- });
- }
- },
- beforeRouteLeave(to, from, next) {
- if (to.name !== "WaitTaskDetail") {
- this.$destroy();
- }
- next();
- },
- beforeRouteEnter(to, from, next) {
- if (from.name === "WaitTaskDetail") {
- next(vm => vm.$nextTick(() => vm.getList()));
- } else {
- next();
- }
- }
- };
- </script>
|