Blame view

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