Blame view

src/views/test/index.vue 26.1 KB
4c4f7640   梁保满   路由表,路由前端文件
1
  <template>
dbbfc6c5   梁保满   飞书优化及bug
2
    <div ref="main" class="page-container" :class="dialogVisible ? 'active' : ''">
f356590c   阿宝   即时测列表,分析页面
3
4
5
6
7
8
9
      <back-box>
        <template slot="title">
          <span>即时测-数据报表</span>
        </template>
      </back-box>
      <div class="answer-header">
        <div class="sel-box">
533a17d8   梁保满   备题组卷添加批量设置答案
10
11
12
13
14
15
          <el-select
            class="sel"
            v-model="query.classId"
            placeholder="选择班级"
            @change="changeclass"
          >
f356590c   阿宝   即时测列表,分析页面
16
17
18
19
20
21
22
23
24
25
26
27
            <el-option
              v-for="item in classList"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
          <el-select
            v-if="role == 'ROLE_BANZHUREN'"
            class="sel"
            multiple
9309dc5d   梁保满   任课老师接口完成
28
            v-model="query.subjectNames"
45504a95   阿宝   即时测页面,以及小题修改答案
29
            placeholder="选择科目"
dbbfc6c5   梁保满   飞书优化及bug
30
            @change="changeSub"
f356590c   阿宝   即时测列表,分析页面
31
32
33
34
35
36
37
38
39
40
41
42
          >
            <el-option
              v-for="item in subjectList"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
          <el-select
            v-else
            class="sel"
9309dc5d   梁保满   任课老师接口完成
43
            v-model="query.subjectNames"
45504a95   阿宝   即时测页面,以及小题修改答案
44
            placeholder="选择科目"
f356590c   阿宝   即时测列表,分析页面
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
          >
            <el-option
              v-for="item in subjectList"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
          <div class="d1">
            <el-date-picker
              v-model="query.startDay"
              type="date"
              @change="handleChangeTimeStart"
              placeholder="选择日期时间"
              value-format="yyyy-MM-dd"
            >
            </el-date-picker>
            ~
            <el-date-picker
              v-model="query.endDay"
              type="date"
              placeholder="选择日期时间"
              @change="handleChangeTimeEnd"
              value-format="yyyy-MM-dd"
            >
            </el-date-picker>
          </div>
          <p class="p1">
            <span @click="setDate(1)" :class="[date == 1 ? 'active' : '', 's1']"
              >今天</span
            >
            <span @click="setDate(2)" :class="[date == 2 ? 'active' : '', 's1']"
              >本周</span
            >
            <span @click="setDate(3)" :class="[date == 3 ? 'active' : '', 's1']"
              >本月</span
            >
            <span @click="setDate(4)" :class="[date == 4 ? 'active' : '', 's1']"
              >本季度</span
            >
          </p>
          <el-button type="primary" round @click="_QueryData()">筛选</el-button>
        </div>
      </div>
      <div class="table-box">
9309dc5d   梁保满   任课老师接口完成
91
92
93
94
95
        <el-radio-group
          v-model="tabIndex"
          @change="changeTab"
          style="margin-bottom: 20px"
        >
f356590c   阿宝   即时测列表,分析页面
96
          <el-radio-button :label="1">单卷测练报表</el-radio-button>
533a17d8   梁保满   备题组卷添加批量设置答案
97
98
99
100
101
          <el-radio-button
            :label="2"
            v-show="this.query.startDay != this.query.endDay"
            >阶段测练报表</el-radio-button
          >
f356590c   阿宝   即时测列表,分析页面
102
        </el-radio-group>
8ea67428   梁保满   飞书bug
103
        <div v-show="tabIndex == 1" v-loading="loading">
d32e461c   梁保满   备题组卷
104
          <el-table :data="tableData" border style="width: 100%">
f356590c   阿宝   即时测列表,分析页面
105
106
107
            <el-table-column
              prop="title"
              label="试卷名称"
1365ef5e   梁保满   优化
108
              fixed
f356590c   阿宝   即时测列表,分析页面
109
110
111
              align="center"
            ></el-table-column>
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
112
              prop="examPaperScore"
f356590c   阿宝   即时测列表,分析页面
113
114
115
116
              label="卷面分"
              align="center"
              width="100"
            ></el-table-column>
8ea67428   梁保满   飞书bug
117
118
119
120
121
            <el-table-column prop="answeredNum" label="测验人数" align="center"
              ><template slot-scope="scoped">{{
                `${scoped.row.answeredNum}/${scoped.row.classPersonNum}`
              }}</template></el-table-column
            >
f356590c   阿宝   即时测列表,分析页面
122
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
123
              prop="examStartTime"
f356590c   阿宝   即时测列表,分析页面
124
125
126
              label="测验时间"
              align="center"
            ></el-table-column>
8ea67428   梁保满   飞书bug
127
128
            <el-table-column prop="avgScore" label="班平均分" align="center"
              ><template slot-scope="scoped">{{
533a17d8   梁保满   备题组卷添加批量设置答案
129
130
                (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                  scoped.row.answerNum == 0) &&
255e2506   梁保满   飞书bug及优化
131
                scoped.row.recordStatus == 0
dbbfc6c5   梁保满   飞书优化及bug
132
                  ? "-"
8ea67428   梁保满   飞书bug
133
134
135
136
137
                  : scoped.row.avgScore
              }}</template></el-table-column
            >
            <el-table-column prop="highestScore" label="班最高分" align="center"
              ><template slot-scope="scoped">{{
533a17d8   梁保满   备题组卷添加批量设置答案
138
139
                (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                  scoped.row.answerNum == 0) &&
255e2506   梁保满   飞书bug及优化
140
                scoped.row.recordStatus == 0
dbbfc6c5   梁保满   飞书优化及bug
141
                  ? "-"
8ea67428   梁保满   飞书bug
142
143
144
145
146
                  : scoped.row.highestScore
              }}</template></el-table-column
            >
            <el-table-column prop="lowestScore" label="班最低分" align="center"
              ><template slot-scope="scoped">{{
533a17d8   梁保满   备题组卷添加批量设置答案
147
148
                (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                  scoped.row.answerNum == 0) &&
255e2506   梁保满   飞书bug及优化
149
                scoped.row.recordStatus == 0
dbbfc6c5   梁保满   飞书优化及bug
150
                  ? "-"
8ea67428   梁保满   飞书bug
151
152
153
                  : scoped.row.lowestScore
              }}</template></el-table-column
            >
f356590c   阿宝   即时测列表,分析页面
154
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
155
              prop="excellenRate"
d32e461c   梁保满   备题组卷
156
              label="优秀数(率)"
f356590c   阿宝   即时测列表,分析页面
157
158
              sortable
              align="center"
d32e461c   梁保满   备题组卷
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
              width="110"
              class-name="p0"
              ><template slot-scope="scoped">
                <p
                  v-if="
                    (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                      scoped.row.answerNum == 0) &&
                    scoped.row.arecordStatus == 0
                  "
                >
                  "-"
                </p>
                <template v-else>
                  <p>{{ scoped.row.excellenNum }}</p>
                  <p v-if="scoped.row.excellenNum">
                    {{ `(${scoped.row.excellenRate}%)` }}
                  </p>
                </template>
              </template></el-table-column
f356590c   阿宝   即时测列表,分析页面
178
179
            >
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
180
              prop="goodRate"
d32e461c   梁保满   备题组卷
181
              label="良好数(率)"
f356590c   阿宝   即时测列表,分析页面
182
183
              sortable
              align="center"
d32e461c   梁保满   备题组卷
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
              width="110"
              class-name="p0"
              ><template slot-scope="scoped">
                <p
                  v-if="
                    (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                      scoped.row.answerNum == 0) &&
                    scoped.row.arecordStatus == 0
                  "
                >
                  "-"
                </p>
                <template v-else>
                  <p>{{ scoped.row.goodNum }}</p>
                  <p v-if="scoped.row.goodNum">
                    {{ `(${scoped.row.goodRate}%)` }}
                  </p>
                </template>
8ea67428   梁保满   飞书bug
202
              </template></el-table-column
f356590c   阿宝   即时测列表,分析页面
203
204
            >
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
205
              prop="passRate"
d32e461c   梁保满   备题组卷
206
              label="及格数(率)"
f356590c   阿宝   即时测列表,分析页面
207
208
              sortable
              align="center"
d32e461c   梁保满   备题组卷
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
              width="110"
              class-name="p0"
              ><template slot-scope="scoped">
                <p
                  v-if="
                    (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                      scoped.row.answerNum == 0) &&
                    scoped.row.arecordStatus == 0
                  "
                >
                  "-"
                </p>
                <template v-else>
                  <p>{{ scoped.row.passNum }}</p>
                  <p v-if="scoped.row.passNum">
                    {{ `(${scoped.row.passRate}%)` }}
                  </p>
                </template>
8ea67428   梁保满   飞书bug
227
              </template></el-table-column
f356590c   阿宝   即时测列表,分析页面
228
229
            >
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
230
              prop="failedRate"
d32e461c   梁保满   备题组卷
231
              label="不及格数(率)"
f356590c   阿宝   即时测列表,分析页面
232
233
              sortable
              align="center"
d32e461c   梁保满   备题组卷
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
              width="130"
              class-name="p0"
              ><template slot-scope="scoped">
                <p
                  v-if="
                    (scoped.row.subjectiveScore == scoped.row.examPaperScore ||
                      scoped.row.answerNum == 0) &&
                    scoped.row.arecordStatus == 0
                  "
                >
                  "-"
                </p>
                <template v-else>
                  <p>{{ scoped.row.failedNum }}</p>
                  <p v-if="scoped.row.failedNum">
                    {{ `(${scoped.row.failedRate}%)` }}
                  </p>
                </template>
              </template></el-table-column
f356590c   阿宝   即时测列表,分析页面
253
254
255
            >
            <el-table-column label="操作" align="center">
              <template slot-scope="scoped">
8ea67428   梁保满   飞书bug
256
                <el-tooltip
533a17d8   梁保满   备题组卷添加批量设置答案
257
258
259
260
261
                  v-if="
                    scoped.row.answerNum != 0 ||
                    (scoped.row.recordStatus != 0 &&
                      scoped.row.subjectiveScore == scoped.row.examPaperScore)
                  "
8ea67428   梁保满   飞书bug
262
263
264
265
                  effect="dark"
                  content="详情"
                  placement="top"
                >
f356590c   阿宝   即时测列表,分析页面
266
267
268
269
270
271
272
273
                  <el-button
                    type="primary"
                    circle
                    size="mini"
                    icon="fa fa-arrow-right"
                    @click="linkTo(scoped.row)"
                  ></el-button>
                </el-tooltip>
8ea67428   梁保满   飞书bug
274
                <el-tooltip
533a17d8   梁保满   备题组卷添加批量设置答案
275
276
277
278
                  v-if="
                    scoped.row.answerNum == 0 &&
                    scoped.row.subjectiveScore != scoped.row.examPaperScore
                  "
8ea67428   梁保满   飞书bug
279
                  effect="dark"
255e2506   梁保满   飞书bug及优化
280
                  content="设置答案"
8ea67428   梁保满   飞书bug
281
282
                  placement="top"
                >
f356590c   阿宝   即时测列表,分析页面
283
284
285
286
287
288
289
290
                  <el-button
                    type="primary"
                    circle
                    size="mini"
                    icon="fa fa-file-text"
                    @click="edit(scoped.row)"
                  ></el-button>
                </el-tooltip>
8ea67428   梁保满   飞书bug
291
                <el-tooltip
533a17d8   梁保满   备题组卷添加批量设置答案
292
293
294
295
                  v-if="
                    scoped.row.subjectiveScore == scoped.row.examPaperScore &&
                    scoped.row.recordStatus == 0
                  "
8ea67428   梁保满   飞书bug
296
297
298
299
300
301
302
303
304
305
306
307
                  effect="dark"
                  content="导入主观题"
                  placement="top"
                >
                  <el-button
                    type="primary"
                    circle
                    size="mini"
                    icon="fa fa-cloud"
                    @click="uploadSJ(scoped.row)"
                  ></el-button>
                </el-tooltip>
f356590c   阿宝   即时测列表,分析页面
308
309
310
              </template>
            </el-table-column>
          </el-table>
9309dc5d   梁保满   任课老师接口完成
311
312
313
314
315
316
317
318
319
320
321
322
          <div class="pagination-box">
            <el-pagination
              small=""
              layout="total,prev, pager, next"
              :hide-on-single-page="true"
              :total="total"
              @current-change="changePage"
              :current-page="page"
              :page-size="size"
            >
            </el-pagination>
          </div>
f356590c   阿宝   即时测列表,分析页面
323
        </div>
8ea67428   梁保满   飞书bug
324
325
        <div v-show="tabIndex == 2" v-loading="loading">
          <el-table
255e2506   梁保满   飞书bug及优化
326
            :max-height="tableMaxHeight"
8ea67428   梁保满   飞书bug
327
328
            v-if="role == 'ROLE_JIAOSHI'"
            :data="tableData"
8ea67428   梁保满   飞书bug
329
330
331
            border
            style="width: 100%"
          >
f356590c   阿宝   即时测列表,分析页面
332
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
333
              prop="studentCode"
f356590c   阿宝   即时测列表,分析页面
334
335
336
337
338
              label="学号"
              align="center"
              fixed
            ></el-table-column>
            <el-table-column
9309dc5d   梁保满   任课老师接口完成
339
              prop="studentName"
f356590c   阿宝   即时测列表,分析页面
340
341
342
343
              label="姓名"
              fixed
              align="center"
            ></el-table-column>
f356590c   阿宝   即时测列表,分析页面
344
345
346
347
348
349
350
            <el-table-column
              align="center"
              v-for="(item, index) in answerList"
              :key="index"
              :label="item.title"
            >
              <el-table-column
9309dc5d   梁保满   任课老师接口完成
351
                :prop="'score' + index"
8ea67428   梁保满   飞书bug
352
                :label="index == 0 ? '总分' : '成绩'"
f356590c   阿宝   即时测列表,分析页面
353
                align="center"
d32e461c   梁保满   备题组卷
354
                :class-name="index % 2 == 0 ? 'bg' : ''"
f356590c   阿宝   即时测列表,分析页面
355
356
              ></el-table-column>
              <el-table-column
9309dc5d   梁保满   任课老师接口完成
357
                :prop="'classRank' + index"
f356590c   阿宝   即时测列表,分析页面
358
359
                label="班名"
                align="center"
d32e461c   梁保满   备题组卷
360
                :class-name="index % 2 == 0 ? 'bg' : ''"
f356590c   阿宝   即时测列表,分析页面
361
362
363
              ></el-table-column>
            </el-table-column>
          </el-table>
255e2506   梁保满   飞书bug及优化
364
          <el-table
255e2506   梁保满   飞书bug及优化
365
366
            v-else
            :data="tableData"
533a17d8   梁保满   备题组卷添加批量设置答案
367
            :max-height="tableMaxHeight"
255e2506   梁保满   飞书bug及优化
368
369
370
            border
            style="width: 100%"
          >
8ea67428   梁保满   飞书bug
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
            <el-table-column
              prop="studentCode"
              label="学号"
              align="center"
              fixed
            ></el-table-column>
            <el-table-column
              prop="studentName"
              label="姓名"
              fixed
              align="center"
            ></el-table-column>
            <el-table-column
              align="center"
              v-for="(item, index) in answerList"
              :key="index"
              :label="item"
            >
              <el-table-column
                :prop="'examCount' + item"
                label="测练数"
                align="center"
d32e461c   梁保满   备题组卷
393
                :class-name="index % 2 == 0 ? 'bg' : ''"
8ea67428   梁保满   飞书bug
394
395
396
397
398
              ></el-table-column>
              <el-table-column
                :prop="'participationCount' + item"
                label="参与数"
                align="center"
d32e461c   梁保满   备题组卷
399
                :class-name="index % 2 == 0 ? 'bg' : ''"
8ea67428   梁保满   飞书bug
400
401
402
403
404
              ></el-table-column>
              <el-table-column
                :prop="'score' + item"
                label="总分"
                align="center"
d32e461c   梁保满   备题组卷
405
                :class-name="index % 2 == 0 ? 'bg' : ''"
8ea67428   梁保满   飞书bug
406
407
408
409
410
              ></el-table-column>
              <el-table-column
                :prop="'classRank' + item"
                label="班名"
                align="center"
d32e461c   梁保满   备题组卷
411
                :class-name="index % 2 == 0 ? 'bg' : ''"
8ea67428   梁保满   飞书bug
412
413
414
              ></el-table-column>
            </el-table-column>
          </el-table>
f356590c   阿宝   即时测列表,分析页面
415
416
        </div>
        <p class="down" v-if="tabIndex == 2">
533a17d8   梁保满   备题组卷添加批量设置答案
417
          <el-button type="primary" plain round icon="fa fa-cloud-download"
f356590c   阿宝   即时测列表,分析页面
418
419
420
421
            >导出报表</el-button
          >
        </p>
      </div>
8ea67428   梁保满   飞书bug
422
      <el-dialog title="导入主观题分数" :visible.sync="diaUp" width="600">
533a17d8   梁保满   备题组卷添加批量设置答案
423
424
425
426
427
428
429
        <up-load
          :url="url"
          :examId="examId"
          @upSuccess="upSuccess"
          fileName="主观题分数"
          v-loading="loadingDown"
        >
8ea67428   梁保满   飞书bug
430
431
432
433
434
435
436
437
438
439
440
441
          <template slot="down">
            <p class="down-txt">
              第一步:下载模板并编辑完成学生分数
              <el-link type="danger" @click="downExcel">模板下载</el-link> 。
            </p>
            <p class="down-txt">第二步:上传完成编辑的模板文件并导入。</p>
          </template>
        </up-load>
        <div class="dialog-footer" slot="footer">
          <el-button @click="diaUp = false">取 消</el-button>
        </div>
      </el-dialog>
aed43d3a   阿宝   即时测修改答案
442
      <div class="edit-dia" v-show="dialogVisible" height="100%">
9309dc5d   梁保满   任课老师接口完成
443
        <editAnswer
8ea67428   梁保满   飞书bug
444
          ref="editAnswer"
9309dc5d   梁保满   任课老师接口完成
445
446
447
448
449
          :title="form.title"
          :score="form.examPaperScore"
          @cancel="cancel"
          @saveSuccess="saveSuccess"
        />
aed43d3a   阿宝   即时测修改答案
450
      </div>
4c4f7640   梁保满   路由表,路由前端文件
451
452
453
454
    </div>
  </template>
  
  <script>
8ea67428   梁保满   飞书bug
455
  import { formatDate, downloadFile } from "utils";
9309dc5d   梁保满   任课老师接口完成
456
  import editAnswer from "./editAnswer.vue";
4c4f7640   梁保满   路由表,路由前端文件
457
  export default {
9309dc5d   梁保满   任课老师接口完成
458
    components: { editAnswer },
f356590c   阿宝   即时测列表,分析页面
459
460
    data() {
      return {
255e2506   梁保满   飞书bug及优化
461
        tableMaxHeight: 300,
f356590c   阿宝   即时测列表,分析页面
462
463
        role: "",
        loading: false,
8ea67428   梁保满   飞书bug
464
        diaUp: false,
533a17d8   梁保满   备题组卷添加批量设置答案
465
        loadingDown: false,
8ea67428   梁保满   飞书bug
466
467
        url: "/api_html/teaching/importSubjectiveScore",
        examId: "",
f356590c   阿宝   即时测列表,分析页面
468
        dialogVisible: false,
9309dc5d   梁保满   任课老师接口完成
469
470
471
472
        form: {
          id: "",
          title: "",
          examPaperScore: "",
aed43d3a   阿宝   即时测修改答案
473
        },
f356590c   阿宝   即时测列表,分析页面
474
475
476
477
        date: "", //今天-昨天-本周
        query: {
          //搜索条件
          classId: "",
9309dc5d   梁保满   任课老师接口完成
478
          subjectNames: "",
f356590c   阿宝   即时测列表,分析页面
479
480
481
482
483
484
485
          startDay: "",
          endDay: "",
          day: "",
        },
        classList: [], //班级
        subjectList: [], //科目
        tabIndex: 1, //选项卡
9309dc5d   梁保满   任课老师接口完成
486
487
488
489
490
        tableData: [],
        answerList: [], //设置多卷内容供tableStage表格数据用
        page: 1,
        size: 20,
        total: 0,
f356590c   阿宝   即时测列表,分析页面
491
492
493
      };
    },
    async created() {
45504a95   阿宝   即时测页面,以及小题修改答案
494
495
496
      this.role = this.$store.getters.info.permissions.find(
        (item) => item.roleName == this.$store.getters.info.showRoleName
      )?.role;
f356590c   阿宝   即时测列表,分析页面
497
498
      await this._QueryClassList();
      await this._QuerySubjectList();
9309dc5d   梁保满   任课老师接口完成
499
      await this.setDate(1);
f356590c   阿宝   即时测列表,分析页面
500
501
502
503
504
505
506
      let startDay = this.query?.startDay;
      if (!startDay) {
        this.query.startDay = new Date();
        this.query.endDay = new Date();
      }
    },
    methods: {
255e2506   梁保满   飞书bug及优化
507
      changeSub(val) {
dbbfc6c5   梁保满   飞书优化及bug
508
509
510
511
512
        let sub;
        if (val && val.length) {
          let leng = val.length - 1;
          sub = val[leng];
        }
255e2506   梁保满   飞书bug及优化
513
        console.log(val);
dbbfc6c5   梁保满   飞书优化及bug
514
515
516
517
        this.query.subjectNames = val.filter((item) => {
          return sub != "全部" ? item != "全部" : item == "全部";
        });
      },
f356590c   阿宝   即时测列表,分析页面
518
519
520
521
522
523
      linkTo(obj) {
        //去详情
        this.$router.push({
          path: "/testAnalysis",
          query: {
            id: obj.id,
9309dc5d   梁保满   任课老师接口完成
524
525
            title: obj.title,
            score: obj.examPaperScore,
f356590c   阿宝   即时测列表,分析页面
526
527
528
          },
        });
      },
8ea67428   梁保满   飞书bug
529
530
531
532
      uploadSJ(obj) {
        this.examId = obj.id;
        this.diaUp = true;
      },
9309dc5d   梁保满   任课老师接口完成
533
534
      cancel() {
        this.dialogVisible = false;
aed43d3a   阿宝   即时测修改答案
535
      },
9309dc5d   梁保满   任课老师接口完成
536
537
538
      saveSuccess() {
        this.dialogVisible = false;
        this._QueryData();
aed43d3a   阿宝   即时测修改答案
539
      },
f356590c   阿宝   即时测列表,分析页面
540
541
542
543
544
545
546
547
548
549
550
551
552
      setDate(index) {
        const that = this;
        this.date = index == this.date ? "" : index;
        let aYear = new Date().getFullYear();
        let aMonth = new Date().getMonth() + 1;
        that.query.day = "";
        that.query.startDay = "";
        that.query.endDay = "";
        switch (index) {
          case 1:
            that.query.day = formatDate(new Date(), "yyyy-MM-dd");
            that.query.startDay = that.query.day;
            that.query.endDay = that.query.day;
d32e461c   梁保满   备题组卷
553
            that.tabIndex = 1;
f356590c   阿宝   即时测列表,分析页面
554
555
556
557
558
559
560
            break;
          case 2:
            let day = new Date().getDay();
            if (day == 0) {
              //中国式星期天是一周的最后一天
              day = 7;
            }
8ea67428   梁保满   飞书bug
561
            day--;
f356590c   阿宝   即时测列表,分析页面
562
563
564
565
566
567
568
569
570
571
            let aTime = new Date().getTime() - 24 * 60 * 60 * 1000 * day;
            that.query.startDay = formatDate(new Date(aTime), "yyyy-MM-dd");
            that.query.endDay = formatDate(new Date(), "yyyy-MM-dd");
            break;
          case 3:
            aMonth = aMonth < 10 ? "0" + aMonth : aMonth;
            that.query.startDay = `${aYear}-${aMonth}-01`;
            that.query.endDay = formatDate(new Date(), "yyyy-MM-dd");
            break;
          case 4:
9309dc5d   梁保满   任课老师接口完成
572
            if (aMonth > 0 && aMonth < 4) {
f356590c   阿宝   即时测列表,分析页面
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
              aMonth = "01";
            } else if (aMonth > 3 && aMonth < 7) {
              aMonth = "04";
            } else if (aMonth > 6 && aMonth < 10) {
              aMonth = "07";
            } else {
              aMonth = "10";
            }
  
            aMonth = aMonth < 10 ? "0" + aMonth : aMonth;
            that.query.startDay = `${aYear}-${aMonth}-01`;
            that.query.endDay = formatDate(new Date(), "yyyy-MM-dd");
            break;
        }
        this.page = 1;
        this._QueryData();
      },
      handleChangeTimeStart(val) {
        this.query.day = "";
        this.date = "";
        if (this.query.endDay) {
          if (new Date(val).getTime() > new Date(this.query.endDay).getTime()) {
            this.$message.error("任务结束时间不能任务开始时间前面,请重新设置");
            this.query.startDay = "";
          }
        }
      },
      handleChangeTimeEnd(val) {
        this.query.day = "";
        this.date = "";
        if (this.query.startDay) {
          if (new Date(val).getTime() < new Date(this.query.startDay).getTime()) {
            this.$message.error("任务结束时间不能任务开始时间前面,请重新设置");
            this.query.endDay = "";
          }
        }
      },
9309dc5d   梁保满   任课老师接口完成
610
611
612
      changePage(page) {
        this.page = page;
        this._QueryData();
aed43d3a   阿宝   即时测修改答案
613
      },
f356590c   阿宝   即时测列表,分析页面
614
      edit(item) {
9309dc5d   梁保满   任课老师接口完成
615
        this.form = { ...item };
8ea67428   梁保满   飞书bug
616
        this.$refs.editAnswer.edit(this.form.id);
f356590c   阿宝   即时测列表,分析页面
617
618
        this.dialogVisible = true;
      },
9309dc5d   梁保满   任课老师接口完成
619
      changeTab() {
255e2506   梁保满   飞书bug及优化
620
        this.tableMaxHeight = this.$refs.main.offsetHeight;
9309dc5d   梁保满   任课老师接口完成
621
622
        this.page = 1;
        this._QueryData();
aed43d3a   阿宝   即时测修改答案
623
      },
533a17d8   梁保满   备题组卷添加批量设置答案
624
625
626
      upSuccess() {
        //导入成功
        this.diaUp = false;
255e2506   梁保满   飞书bug及优化
627
628
        this._QueryData();
      },
533a17d8   梁保满   备题组卷添加批量设置答案
629
630
631
632
      async changeclass() {
        await this._QuerySubjectList();
        this.page = 1;
        this._QueryData();
255e2506   梁保满   飞书bug及优化
633
      },
8ea67428   梁保满   飞书bug
634
      async downExcel() {
533a17d8   梁保满   备题组卷添加批量设置答案
635
        this.loadingDown = true;
8ea67428   梁保满   飞书bug
636
        let data = await this.$request.subjectiveScoreTemplate({
255e2506   梁保满   飞书bug及优化
637
          examId: this.examId,
8ea67428   梁保满   飞书bug
638
        });
533a17d8   梁保满   备题组卷添加批量设置答案
639
        this.loadingDown = false;
8ea67428   梁保满   飞书bug
640
641
642
643
644
645
646
647
648
        if (data && !data.code) {
          let blob = new Blob([data], {
            type: "application/vnd.ms-excel;charset=utf-8",
          });
          downloadFile(`主观题模版.xlsx`, blob);
        } else {
          this.$message.error(data.message);
        }
      },
f356590c   阿宝   即时测列表,分析页面
649
      async changClazz() {
9309dc5d   梁保满   任课老师接口完成
650
        this.page = 1;
f356590c   阿宝   即时测列表,分析页面
651
        await this._QuerySubjectList();
9309dc5d   梁保满   任课老师接口完成
652
        await this._QueryData();
f356590c   阿宝   即时测列表,分析页面
653
654
      },
      async _QueryClassList() {
9309dc5d   梁保满   任课老师接口完成
655
656
657
658
659
        const fetchClassList =
          this.role == "ROLE_BANZHUREN"
            ? this.$request.cTClassList
            : this.$request.tClassList;
        const { data, status, info } = await fetchClassList();
f356590c   阿宝   即时测列表,分析页面
660
661
662
663
        if (status === 0) {
          this.classList = data.list.map((item) => {
            return {
              value: item.classId,
45504a95   阿宝   即时测页面,以及小题修改答案
664
              label: item.className,
f356590c   阿宝   即时测列表,分析页面
665
666
667
668
669
670
671
672
            };
          });
          this.query.classId = this.classList[0]?.value;
        } else {
          this.$message.error(info);
        }
      },
      async _QuerySubjectList() {
9309dc5d   梁保满   任课老师接口完成
673
674
675
676
677
678
        const fetchSubjectList =
          this.role == "ROLE_BANZHUREN"
            ? this.$request.cTSubjectList
            : this.$request.tSubjectList;
  
        const { data, status, info } = await fetchSubjectList({
f356590c   阿宝   即时测列表,分析页面
679
680
681
682
          classId: this.query.classId,
        });
        if (status === 0) {
          this.subjectList =
45504a95   阿宝   即时测页面,以及小题修改答案
683
            data.subjectNames?.map((item) => {
f356590c   阿宝   即时测列表,分析页面
684
              return {
45504a95   阿宝   即时测页面,以及小题修改答案
685
686
                value: item,
                label: item,
f356590c   阿宝   即时测列表,分析页面
687
688
              };
            }) || [];
aed43d3a   阿宝   即时测修改答案
689
          if (this.role == "ROLE_BANZHUREN") {
f356590c   阿宝   即时测列表,分析页面
690
            this.subjectList.unshift({
9309dc5d   梁保满   任课老师接口完成
691
              value: "全部",
f356590c   阿宝   即时测列表,分析页面
692
693
              label: "全部",
            });
9309dc5d   梁保满   任课老师接口完成
694
            this.query.subjectNames.push(this.subjectList[0]?.value);
aed43d3a   阿宝   即时测修改答案
695
          } else {
9309dc5d   梁保满   任课老师接口完成
696
            this.query.subjectNames = this.subjectList[0]?.value;
f356590c   阿宝   即时测列表,分析页面
697
          }
f356590c   阿宝   即时测列表,分析页面
698
699
700
701
702
        } else {
          this.$message.error(info);
        }
      },
      async _QueryData() {
9309dc5d   梁保满   任课老师接口完成
703
704
705
706
707
708
709
710
711
        this.tableData = [];
        if (this.tabIndex == 1) {
          this.examReportList();
        } else {
          this.phaseExamReport();
        }
      },
      //单卷测练
      async examReportList() {
f356590c   阿宝   即时测列表,分析页面
712
        this.loading = true;
f356590c   阿宝   即时测列表,分析页面
713
714
715
716
717
718
        let query = {};
        for (let key in this.query) {
          if (this.query[key] != "") {
            query[key] = this.query[key];
          }
        }
9309dc5d   梁保满   任课老师接口完成
719
720
721
722
        if (this.role != "ROLE_BANZHUREN") {
          query.subjectNames = [query.subjectNames];
        } else {
          if (
8ea67428   梁保满   飞书bug
723
            query["subjectNames"] &&
9309dc5d   梁保满   任课老师接口完成
724
725
726
727
728
729
730
            query["subjectNames"].length == 1 &&
            query["subjectNames"][0] == "全部"
          ) {
            query["subjectNames"] = this.subjectList.map((item) => {
              return item.value;
            });
            query["subjectNames"].shift();
dbbfc6c5   梁保满   飞书优化及bug
731
          }
255e2506   梁保满   飞书bug及优化
732
          if (!query["subjectNames"]) {
dbbfc6c5   梁保满   飞书优化及bug
733
734
            this.$message.warning("请选择科目");
            return;
9309dc5d   梁保满   任课老师接口完成
735
736
737
          }
        }
        const { data, status, info } = await this.$request.examReportList({
f356590c   阿宝   即时测列表,分析页面
738
          ...query,
9309dc5d   梁保满   任课老师接口完成
739
740
          page: this.page,
          size: this.size,
f356590c   阿宝   即时测列表,分析页面
741
742
743
        });
        this.loading = false;
        if (status === 0) {
9309dc5d   梁保满   任课老师接口完成
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
          this.tableData = (data?.list && [...data?.list]) || [];
          this.total = data.count;
        } else {
          this.$message.error(info);
        }
      },
      //多卷测练
      async phaseExamReport() {
        this.loading = true;
        let query = {};
        for (let key in this.query) {
          if (this.query[key] != "") {
            if (key == "subjectNames" && this.role != "ROLE_BANZHUREN") {
              query["subjectName"] = this.query[key];
            } else {
              query[key] = this.query[key];
            }
          }
        }
        if (this.role == "ROLE_BANZHUREN") {
          if (
8ea67428   梁保满   飞书bug
765
766
            query["subjectNames"] &&
            query["subjectNames"]?.length == 1 &&
9309dc5d   梁保满   任课老师接口完成
767
768
769
770
771
            query["subjectNames"][0] == "全部"
          ) {
            query["subjectNames"] = this.subjectList.map((item) => {
              return item.value;
            });
8ea67428   梁保满   飞书bug
772
            query["subjectNames"]?.shift();
9309dc5d   梁保满   任课老师接口完成
773
774
775
776
777
778
779
780
781
782
783
784
          }
        }
        const phaseExamReport =
          this.role == "ROLE_BANZHUREN"
            ? this.$request.cTPhaseExamReport
            : this.$request.phaseExamReport;
        const { data, status, info } = await phaseExamReport({
          ...query,
        });
        this.loading = false;
        if (status === 0) {
          this.total = data.count;
8ea67428   梁保满   飞书bug
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
          if (this.role == "ROLE_BANZHUREN") {
            let subjectName = [];
            this.tableData = data?.list.map((item) => {
              let params = {};
              item.dataList.map((items, index) => {
                if (!subjectName.includes(items.subjectName)) {
                  subjectName.push(items.subjectName);
                }
                params["examCount" + items.subjectName] = items.examCount;
                params["participationCount" + items.subjectName] =
                  items.participationCount;
                params["score" + items.subjectName] = items.score;
                params["classRank" + items.subjectName] = items.classRank;
              });
              return {
                ...item,
                ...params,
              };
            });
            this.answerList = [...subjectName];
          } else {
            let dataIdsList = [],
              dataList = [];
            data?.list.map((item) => {
              item.examList.map((items) => {
9309dc5d   梁保满   任课老师接口完成
810
811
812
813
                if (!dataIdsList.includes(items.title)) {
                  dataIdsList.push(items.title);
                  dataList.push(items);
                }
8ea67428   梁保满   飞书bug
814
              });
9309dc5d   梁保满   任课老师接口完成
815
            });
8ea67428   梁保满   飞书bug
816
817
818
819
820
821
822
            console.log(dataList);
            this.tableData = data?.list.map((item) => {
              let params = {};
              dataIdsList.map((ids, index) => {
                params["score" + index] = "--";
                params["classRank" + index] = "--";
                item.examList.map((items) => {
9309dc5d   梁保满   任课老师接口完成
823
824
825
826
                  if (items.title == ids) {
                    params["score" + index] = items.score;
                    params["classRank" + index] = items.classRank;
                  }
8ea67428   梁保满   飞书bug
827
                });
9309dc5d   梁保满   任课老师接口完成
828
              });
8ea67428   梁保满   飞书bug
829
830
831
832
              return {
                ...item,
                ...params,
              };
9309dc5d   梁保满   任课老师接口完成
833
            });
8ea67428   梁保满   飞书bug
834
835
            this.answerList = dataList;
          }
f356590c   阿宝   即时测列表,分析页面
836
837
838
839
840
841
        } else {
          this.$message.error(info);
        }
      },
    },
  };
4c4f7640   梁保满   路由表,路由前端文件
842
843
  </script>
  
9309dc5d   梁保满   任课老师接口完成
844
845
846
847
848
849
850
851
852
853
  <style>
  div::-webkit-scrollbar {
    width: 3px;
    height: 10px;
  }
  div::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background-color: #ccc;
  }
  </style>
f356590c   阿宝   即时测列表,分析页面
854
  <style lang="scss" scoped>
9309dc5d   梁保满   任课老师接口完成
855
856
  .page-container {
    position: relative;
255e2506   梁保满   飞书bug及优化
857
    height: 100%;
9309dc5d   梁保满   任课老师接口完成
858
    &.active {
9309dc5d   梁保满   任课老师接口完成
859
860
861
      overflow: hidden;
    }
  }
f356590c   阿宝   即时测列表,分析页面
862
863
864
865
866
867
868
869
870
871
872
873
  .table-box {
    margin: 0 20px;
    padding: 16px;
    background: #f8f8f8;
    border-radius: 5px;
    :deep(.fa-arrow-right) {
      padding-left: 2px;
    }
    :deep(.fa-file-text) {
      padding-left: 2px;
    }
  }
f356590c   阿宝   即时测列表,分析页面
874
875
876
  .down {
    padding-top: 16px;
  }
aed43d3a   阿宝   即时测修改答案
877
878
879
880
881
882
883
  .edit-dia {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
9309dc5d   梁保满   任课老师接口完成
884
    height: calc(100vh - 70px);
aed43d3a   阿宝   即时测修改答案
885
886
887
    background: #fff;
    overflow-y: auto;
    z-index: 10;
aed43d3a   阿宝   即时测修改答案
888
  }
4c4f7640   梁保满   路由表,路由前端文件
889
  </style>