From d5fb13fe86c8eeabef50655c675ecd2e871e3289 Mon Sep 17 00:00:00 2001 From: cpf <1105965053@qq.com> Date: Sat, 26 Dec 2020 16:08:41 +0800 Subject: [PATCH 1/3] =?UTF-8?q?[=E5=AE=8C=E5=96=84]=20=E8=80=83=E7=94=9F?= =?UTF-8?q?=E8=80=83=E8=AF=95=E9=A1=B5=E9=9D=A2=E5=AE=8C=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package-lock.json | 86 +++++++----------- package.json | 1 + src/app/app.module.ts | 3 +- .../examination-details.component.html | 33 +++++-- .../examination-details.component.scss | 19 +++- .../examination-details.component.ts | 90 ++++++++++++++++--- src/app/student/student.module.ts | 5 +- 7 files changed, 159 insertions(+), 78 deletions(-) diff --git a/package-lock.json b/package-lock.json index f568697..b980c95 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10532,8 +10532,7 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "aproba": { "version": "1.2.0", @@ -10554,14 +10553,12 @@ "balanced-match": { "version": "1.0.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "brace-expansion": { "version": "1.1.11", "bundled": true, "dev": true, - "optional": true, "requires": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" @@ -10576,20 +10573,17 @@ "code-point-at": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "concat-map": { "version": "0.0.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "console-control-strings": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "core-util-is": { "version": "1.0.2", @@ -10706,8 +10700,7 @@ "inherits": { "version": "2.0.4", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "ini": { "version": "1.3.5", @@ -10719,7 +10712,6 @@ "version": "1.0.0", "bundled": true, "dev": true, - "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -10734,7 +10726,6 @@ "version": "3.0.4", "bundled": true, "dev": true, - "optional": true, "requires": { "brace-expansion": "^1.1.7" } @@ -10742,14 +10733,12 @@ "minimist": { "version": "0.0.8", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "minipass": { "version": "2.9.0", "bundled": true, "dev": true, - "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -10768,7 +10757,6 @@ "version": "0.5.1", "bundled": true, "dev": true, - "optional": true, "requires": { "minimist": "0.0.8" } @@ -10858,8 +10846,7 @@ "number-is-nan": { "version": "1.0.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "object-assign": { "version": "4.1.1", @@ -10871,7 +10858,6 @@ "version": "1.4.0", "bundled": true, "dev": true, - "optional": true, "requires": { "wrappy": "1" } @@ -10957,8 +10943,7 @@ "safe-buffer": { "version": "5.1.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "safer-buffer": { "version": "2.1.2", @@ -10994,7 +10979,6 @@ "version": "1.0.2", "bundled": true, "dev": true, - "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -11014,7 +10998,6 @@ "version": "3.0.1", "bundled": true, "dev": true, - "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -11058,14 +11041,12 @@ "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "yallist": { "version": "3.1.1", "bundled": true, - "dev": true, - "optional": true + "dev": true } } }, @@ -12018,6 +11999,21 @@ "tslib": "^1.9.0" } }, + "ngx-countdown": { + "version": "11.0.1", + "resolved": "https://registry.npm.taobao.org/ngx-countdown/download/ngx-countdown-11.0.1.tgz", + "integrity": "sha1-/k/mciHFbUuk/Obb6cO/KJxTpvA=", + "requires": { + "tslib": "^2.0.0" + }, + "dependencies": { + "tslib": { + "version": "2.0.3", + "resolved": "https://registry.npm.taobao.org/tslib/download/tslib-2.0.3.tgz?cache=0&sync_timestamp=1602286724979&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ftslib%2Fdownload%2Ftslib-2.0.3.tgz", + "integrity": "sha1-jgdBrEX8DCJuWKF7/D5kubxsphw=" + } + } + }, "ngx-echarts": { "version": "4.2.2", "resolved": "https://registry.npm.taobao.org/ngx-echarts/download/ngx-echarts-4.2.2.tgz", @@ -17608,8 +17604,7 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "aproba": { "version": "1.2.0", @@ -17652,8 +17647,7 @@ "code-point-at": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "concat-map": { "version": "0.0.1", @@ -17664,8 +17658,7 @@ "console-control-strings": { "version": "1.1.0", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "core-util-is": { "version": "1.0.2", @@ -17782,8 +17775,7 @@ "inherits": { "version": "2.0.4", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "ini": { "version": "1.3.5", @@ -17795,7 +17787,6 @@ "version": "1.0.0", "bundled": true, "dev": true, - "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -17825,7 +17816,6 @@ "version": "2.9.0", "bundled": true, "dev": true, - "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -17844,7 +17834,6 @@ "version": "0.5.1", "bundled": true, "dev": true, - "optional": true, "requires": { "minimist": "0.0.8" } @@ -17934,8 +17923,7 @@ "number-is-nan": { "version": "1.0.1", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "object-assign": { "version": "4.1.1", @@ -17947,7 +17935,6 @@ "version": "1.4.0", "bundled": true, "dev": true, - "optional": true, "requires": { "wrappy": "1" } @@ -18033,8 +18020,7 @@ "safe-buffer": { "version": "5.1.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "safer-buffer": { "version": "2.1.2", @@ -18070,7 +18056,6 @@ "version": "1.0.2", "bundled": true, "dev": true, - "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -18090,7 +18075,6 @@ "version": "3.0.1", "bundled": true, "dev": true, - "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -18134,14 +18118,12 @@ "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true, - "optional": true + "dev": true }, "yallist": { "version": "3.1.1", "bundled": true, - "dev": true, - "optional": true + "dev": true } } }, diff --git a/package.json b/package.json index 1716269..0479b61 100644 --- a/package.json +++ b/package.json @@ -31,6 +31,7 @@ "firebase": "^7.6.2", "ng-zorro-antd": "^10.2.0", "ng2-file-upload": "^1.4.0", + "ngx-countdown": "^11.0.1", "ngx-echarts": "^4.2.2", "ngx-perfect-scrollbar": "^8.0.0", "pixi-filters": "^3.1.1", diff --git a/src/app/app.module.ts b/src/app/app.module.ts index 9aa784e..70298a2 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -30,7 +30,6 @@ import zh from '@angular/common/locales/zh'; import { ExaminerModule } from './examiner/examiner.module'; import { StudentModule} from './student/student.module' registerLocaleData(zh); -import { from } from 'rxjs'; @NgModule({ declarations: [ @@ -48,7 +47,7 @@ import { from } from 'rxjs'; FormsModule, HttpClientModule, ExaminerModule, - StudentModule + StudentModule, ], providers: [httpInterceptorProviders, CacheTokenService,TreeService,ComponentServiceService], bootstrap: [AppComponent] diff --git a/src/app/student/examination-details/examination-details.component.html b/src/app/student/examination-details/examination-details.component.html index 9ba6542..a758c9a 100644 --- a/src/app/student/examination-details/examination-details.component.html +++ b/src/app/student/examination-details/examination-details.component.html @@ -1,5 +1,6 @@
-
+
alarm
+
@@ -26,12 +27,28 @@ - + - + - +
+
{{item.name}}
+
+
+
{{element.propertyName}}
+ +
+ + +
+
+
+
+ +
+
+
@@ -56,9 +73,9 @@
{{item.name}}
-
{{element.propertyName}}
+
{{element.propertyName}}
- +
@@ -76,9 +93,9 @@
{{item.name}}
-
{{element.propertyName}}
+
{{element.propertyName}}
- +
diff --git a/src/app/student/examination-details/examination-details.component.scss b/src/app/student/examination-details/examination-details.component.scss index a44383a..c8ead11 100644 --- a/src/app/student/examination-details/examination-details.component.scss +++ b/src/app/student/examination-details/examination-details.component.scss @@ -7,6 +7,23 @@ table { text-align: center; border-collapse: collapse; padding:2px;} display: flex; flex-direction: column; box-sizing: border-box; + .countdown { + width: 150px; + height: 30px; + line-height: 30px; + text-align: center; + position: fixed; + z-index: 111; + top: 15px; + left: 50%; + margin-left: -75px; + color: #07CDCF; + font-size: 18px; + .mat-icon { + font-size: 20px; + vertical-align: middle; + } + } .center { flex: 1; overflow: hidden; @@ -161,7 +178,7 @@ input { .tableRow { flex: 1; overflow: hidden; - .tabelHeader { background: #F5FDFE; } + .tabelHeader { background: #F5FDFE; cursor: pointer; } >div { width: 100%; height: 36px; diff --git a/src/app/student/examination-details/examination-details.component.ts b/src/app/student/examination-details/examination-details.component.ts index 2ca888c..de3cf58 100644 --- a/src/app/student/examination-details/examination-details.component.ts +++ b/src/app/student/examination-details/examination-details.component.ts @@ -1,7 +1,7 @@ import { HttpClient } from '@angular/common/http'; import { Component, OnInit } from '@angular/core'; import { MatDialog } from '@angular/material/dialog'; -import { MatSnackBar } from '@angular/material/snack-bar'; +import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; import { ActivatedRoute } from '@angular/router'; import { CanvasShareDataService } from 'src/app/canvas-share-data.service'; @@ -24,11 +24,33 @@ export class ExaminationDetailsComponent implements OnInit { paperCompanyData:any = []; //考生具体考卷 selectPaper:any = {id:null}; //选择当前考卷 selectPaperType:string = '1'; //选择当前考卷内容 基本信息/作战部署 + surplusTime:number = 3600; //考试剩余时间 + + //倒计时 处理时间格式 + formatDate (e) { + let hours = parseInt( (e.date / (1000 * 60 * 60)).toString() ) + var minutes = parseInt( ((e.date % (1000 * 60 * 60)) / (1000 * 60)).toString() ); + var seconds = (e.date % (1000 * 60)) / 1000; + return `${hours} : ${minutes} : ${seconds}` + } + + //基本信息表格 是否展示当前行 + rowIsShow (children,tag) { + let isShow:boolean = false + children.forEach(element => { + element.result == tag? isShow = true : null + }); + return isShow + } //获取考卷 async getTestInfo () { await new Promise((resolve, reject) => { this.http.get(`/api/Papers/${this.paperId}`).subscribe((data:any)=>{ + let now = (new Date()).getTime() + let endTime = (new Date(data.endTime)).getTime() + let surplusTime = Math.floor( (endTime - now) / 1000 ); //考试剩余时间 + surplusTime >=0? this.surplusTime = surplusTime : this.surplusTime = 0 this.paperData = data this.paperData.paperDataInfo.forEach(element => { element.adjoinData? element.adjoinData = JSON.parse(element.adjoinData) : null @@ -39,23 +61,28 @@ export class ExaminationDetailsComponent implements OnInit { }); this.paperCompanyData = JSON.parse( JSON.stringify(data.paperDataInfo) ) //具体考卷 this.selectPaper = this.paperCompanyData[0] || {id:null} //当前选择考卷 - this.handlePaperData() resolve(1) }) }) - - } - - //处理考卷 数据格式 - handlePaperData () { - console.log(this.selectPaper) } //切换 选择考卷 togglePaper (e) { if (this.selectPaper.id != e.id) { this.selectPaper = e - this.handlePaperData() + console.log(this.selectPaper) + } + } + + //考试倒计时 + handleEvent (e) { + if (e.left == 600000) { //距离考试结束 剩余10分钟 + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 5000 + this.snackBar.open('注: 距离考试结束还剩10分钟!','确定',config); + } else if (e.left == 0) {//考试结束 + this.uploadPaper() //交卷 } } @@ -107,18 +134,55 @@ export class ExaminationDetailsComponent implements OnInit { }) //计算总分 this.examScore = examScore + examScore2 - console.log(678,this.paperCompanyData) } //交卷 uploadPaper () { - console.log(this.paperCompanyData) + // let body = { + // id: this.route.snapshot.queryParams.examId, + // // name: null, + // // serverTime: null, + // // startTime: null, + // // endTime: null, + // // deadline: null, + // // isMarked: null, + // // totalScore: null, + // // examineeId: null, + // // examineeName: null, + // // paperId: null, + // // paperEndTime: null, + // examinationDataInfo: [] + // } + // let uploadPaper = JSON.parse( JSON.stringify(this.paperCompanyData) ) + // uploadPaper.forEach(element => { + // delete element.score + // delete element.planScore + // delete element.planList + // delete element.id + // delete element.paperId + // element.examinationId = this.route.snapshot.queryParams.examId + // element.adjoinData = JSON.stringify( element.adjoinData || [] ) + // element.basicInfoData = JSON.stringify( element.basicInfoData || [] ) + // element.facilityData = JSON.stringify( element.facilityData || [] ) + // element.functionalDivisionData = JSON.stringify( element.functionalDivisionData || [] ) + // element.importLocationData = JSON.stringify( element.importLocationData || [] ) + // }); + // console.log(body) + // body.examinationDataInfo = uploadPaper + // this.http.put(`/api/Examinations/UpdateExaminationData/${this.route.snapshot.queryParams.examId}`,body).subscribe(data=>{ + // console.log(data) + // }) + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 3000 + this.snackBar.open('试卷提交成功! 本页面即将关闭','确定',config); + // window.setTimeout(()=>{ + // window.close() + // },10000) } //进入作战部署 考卷 enterExam(item){ - console.log(item) - console.log(this.selectPaper) sessionStorage.setItem('companyName',this.selectPaper.companyInfo.name) sessionStorage.setItem('planId',item.planComponentId) sessionStorage.setItem('buildingTypeId',this.selectPaper.companyInfo.buildingTypes[0].id) diff --git a/src/app/student/student.module.ts b/src/app/student/student.module.ts index a817ae3..8170140 100644 --- a/src/app/student/student.module.ts +++ b/src/app/student/student.module.ts @@ -55,7 +55,7 @@ import { StudentExamRecordComponent } from './student-exam-record/student-exam-r import { ExaminationDetailsComponent } from './examination-details/examination-details.component'; import { PlanLevel } from '../pipes/size.pipe'; import { ExaminerModule } from '../examiner/examiner.module'; - +import { CountdownModule } from 'ngx-countdown'; @NgModule({ declarations: [StudentIndexComponent, StudentExamRecordComponent, ExaminationDetailsComponent], imports: [ @@ -108,7 +108,8 @@ import { ExaminerModule } from '../examiner/examiner.module'; NavigationModule, NzTreeModule, NzDatePickerModule, - ExaminerModule + ExaminerModule, + CountdownModule, ], providers: [ { provide: MatPaginatorIntl, useValue: myPaginator() } ] }) From f733991b19473e21e5179b438498e51dcff89cf8 Mon Sep 17 00:00:00 2001 From: cpf <1105965053@qq.com> Date: Mon, 28 Dec 2020 15:03:07 +0800 Subject: [PATCH 2/3] =?UTF-8?q?[=E5=AE=8C=E5=96=84]=20=E8=80=83=E5=AE=98?= =?UTF-8?q?=E9=98=85=E5=8D=B7=E9=A1=B5=E9=9D=A2=E5=AE=8C=E5=96=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/app/app-routing.module.ts | 10 +- src/app/examiner/examiner.module.ts | 5 +- .../mark-papers-two.component.html | 2 +- .../mark-papers-two.component.ts | 18 +- .../review-files/review-files.component.html | 171 ++++++++++++++++++ .../review-files/review-files.component.scss | 15 ++ .../review-files.component.spec.ts | 25 +++ .../review-files/review-files.component.ts | 82 +++++++++ .../examination-details.component.ts | 71 +++----- 9 files changed, 342 insertions(+), 57 deletions(-) create mode 100644 src/app/examiner/review-files/review-files.component.html create mode 100644 src/app/examiner/review-files/review-files.component.scss create mode 100644 src/app/examiner/review-files/review-files.component.spec.ts create mode 100644 src/app/examiner/review-files/review-files.component.ts diff --git a/src/app/app-routing.module.ts b/src/app/app-routing.module.ts index f0766fe..445207e 100644 --- a/src/app/app-routing.module.ts +++ b/src/app/app-routing.module.ts @@ -18,6 +18,7 @@ import { CreateTestScoreComponent } from './examiner/create-test-score/create-te import { CollectionToolsComponent } from './ui/collection-tools/collection-tools.component'; import { ExaminationDetailsComponent } from './student/examination-details/examination-details.component'; import { CollectionToolsExamineeComponent } from './ui/collection-tools-examinee/collection-tools.component'; +import { ReviewFilesComponent } from './examiner/review-files/review-files.component'; @@ -31,13 +32,14 @@ const routes: Routes = [ {path:'',loadChildren:() => import('./ui/ui.module').then(m => m.UiModule)} ] }, - { path:'examiner/create-test-score', component:CreateTestScoreComponent,canActivate: [AuthGuard],}, //创建试卷具体分数页面 - { path:'canvasTool', component:CollectionToolsComponent,canActivate: [AuthGuard], }, //考官编制工具 - { path:'canvasToolExaminee', component:CollectionToolsExamineeComponent,canActivate: [AuthGuard], }, //考生编制工具 + { path:'examiner/create-test-score', component:CreateTestScoreComponent,canActivate: [AuthGuard],}, //考官 创建考卷 + { path:'canvasTool', component:CollectionToolsComponent,canActivate: [AuthGuard], }, //考官 编制工具 + { path:'reviewFiles', component: ReviewFilesComponent,canActivate: [AuthGuard], }, //考官 阅卷 { path:'examinationDetails', component:ExaminationDetailsComponent,canActivate: [AuthGuard], }, //考生试卷 考试基本信息/作战部署 + { path:'canvasToolExaminee', component:CollectionToolsExamineeComponent,canActivate: [AuthGuard], }, //考生 编制工具 + { path:'adminLogin', component:LoginComponent}, //管理员登录路由 { path:'login', component:LockscreenComponent}, //教员学员登录路由 - ]; @NgModule({ diff --git a/src/app/examiner/examiner.module.ts b/src/app/examiner/examiner.module.ts index 509884b..e6e7c4b 100644 --- a/src/app/examiner/examiner.module.ts +++ b/src/app/examiner/examiner.module.ts @@ -56,11 +56,12 @@ import { PlanLevel } from '../pipes/size.pipe'; import { MarkPapersIndexComponent } from './mark-papers-index/mark-papers-index.component'; import { MarkPapersTwoComponent } from './mark-papers-two/mark-papers-two.component'; import { StatisticAnalysisComponent } from './statistic-analysis/statistic-analysis.component'; -import { FinishDia }from './examiner-index/examiner-index.component' +import { FinishDia }from './examiner-index/examiner-index.component'; +import { ReviewFilesComponent } from './review-files/review-files.component' @NgModule({ - declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog,PlanLevel,MarkPapersIndexComponent, MarkPapersTwoComponent, StatisticAnalysisComponent,FinishDia], + declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog,PlanLevel,MarkPapersIndexComponent, MarkPapersTwoComponent, StatisticAnalysisComponent,FinishDia, ReviewFilesComponent], imports: [ CommonModule, examinerRoutingModule, diff --git a/src/app/examiner/mark-papers-two/mark-papers-two.component.html b/src/app/examiner/mark-papers-two/mark-papers-two.component.html index d3e0535..29f0535 100644 --- a/src/app/examiner/mark-papers-two/mark-papers-two.component.html +++ b/src/app/examiner/mark-papers-two/mark-papers-two.component.html @@ -35,7 +35,7 @@ {{item.isMarked== true?"已阅卷":"未阅卷"}} 90 - 阅卷 + 阅卷 diff --git a/src/app/examiner/mark-papers-two/mark-papers-two.component.ts b/src/app/examiner/mark-papers-two/mark-papers-two.component.ts index b940f09..596233e 100644 --- a/src/app/examiner/mark-papers-two/mark-papers-two.component.ts +++ b/src/app/examiner/mark-papers-two/mark-papers-two.component.ts @@ -15,11 +15,6 @@ import { PageEvent } from '@angular/material/paginator'; import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; import {FormControl} from '@angular/forms'; import { Router,ActivatedRoute } from '@angular/router'; -const ELEMENT_DATA = [ - {name: "张三三", organization: '浦东支队', startTime: "2020-09-19 10:00", mark: '120',testState:'未阅卷'}, - {name: "提亚马特", organization: '黄埔支队', startTime: "2020-09-19 10:00", mark: '100',testState:'已阅卷'}, - {name: "艾泽拉斯", organization: '徐汇支队', startTime: "2020-09-19 10:00", mark: '90',testState:'已阅卷'}, -]; @Component({ selector: 'app-mark-papers-two', @@ -34,15 +29,14 @@ export class MarkPapersTwoComponent implements OnInit { this.activatedRoute.queryParams.subscribe(param=>{ this.headtext=param.level this.getid=param.id - //console.log(headName) }); this.getAlltabledate() } + headtext getid//试卷id dataSource - markName//试卷名称 - markDate//考试日期 + //分页 @ViewChild(MatPaginator, {static: true}) pageEvent: PageEvent; @@ -51,6 +45,7 @@ export class MarkPapersTwoComponent implements OnInit { pageSize:any; //每页条数 pageSizeOptions: number[] = [10] //设置每页条数 PageNumber:any //第几页 + //获取表格信息 getAlltabledate(){ let paramsdata:any = { @@ -63,13 +58,18 @@ export class MarkPapersTwoComponent implements OnInit { this.http.get("/api/Examinations",{params:paramsdata}).subscribe((data:any)=>{ this.dataSource=data.items this.length=data.totalCount - console.log(this.dataSource) }) } + //分页事件 chagePage(e){ this.PageNumber = e.pageIndex+1 this.getAlltabledate() } + //阅卷 + reviewFiles (e) { + window.open(`/reviewFiles?examId=${e.id}`) + } + } diff --git a/src/app/examiner/review-files/review-files.component.html b/src/app/examiner/review-files/review-files.component.html new file mode 100644 index 0000000..3cee59f --- /dev/null +++ b/src/app/examiner/review-files/review-files.component.html @@ -0,0 +1,171 @@ +
+
+
+ +
+
+
单位列表
+
总分: + +
+
+
单位名称
总分
+
+
{{item.companyInfo? item.companyInfo.name:'暂无单位名称'}}
+
{{item.score}}
+
+
+
+
+ + + + +
+
+
+ + + + + + + + + +
+
{{item.name}}
+
+
+
{{element.propertyName}}
+ +
+ + + done +
+
+
+
+ +
+ + done +
+
+
+
+ + + + + + + + +
+
{{item.name}}
+
+ + done +
+
+
+ + + + + + + + +
+
{{item.name}}
+
+
+
{{element.propertyName}}
+
+ + + done +
+
+
+
+
+ + + + + + + + +
+
{{item.name}}
+
+
+
{{element.propertyName}}
+
+ + + done +
+
+
+
+
+ + + + + + + + +
+
{{item.name}}
+
+ + done +
+
+
+ +
+ +
+ +
+
+ + + + + + + + + + + + + + + + + + + +
预案名称添加人修改时间是否公开编制级别设置分数操作
{{item.title}}{{item.creatorName}}{{item.modifiedTime | date:'yyyy-MM-dd'}}{{item.isPublic ? '已公开' : '未公开'}}{{item.planLevel | planlevel}}{{item.score}}分 + 进入 +
+
+
+ +
+
+ +
+
+ diff --git a/src/app/examiner/review-files/review-files.component.scss b/src/app/examiner/review-files/review-files.component.scss new file mode 100644 index 0000000..52c9245 --- /dev/null +++ b/src/app/examiner/review-files/review-files.component.scss @@ -0,0 +1,15 @@ +.mat-icon { + vertical-align: middle; + color: #00CFAC; + margin-left: 5px; +} +.publicTest .publicInput input { width: 48%; } +.headerButton { + margin-left: auto; + margin-right: 25px; + background-color:#00CFAC; + color: #fff; + border-radius: 5px; + border: none; + outline: none; +} \ No newline at end of file diff --git a/src/app/examiner/review-files/review-files.component.spec.ts b/src/app/examiner/review-files/review-files.component.spec.ts new file mode 100644 index 0000000..bd6be98 --- /dev/null +++ b/src/app/examiner/review-files/review-files.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { ReviewFilesComponent } from './review-files.component'; + +describe('ReviewFilesComponent', () => { + let component: ReviewFilesComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ ReviewFilesComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(ReviewFilesComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/examiner/review-files/review-files.component.ts b/src/app/examiner/review-files/review-files.component.ts new file mode 100644 index 0000000..80e249f --- /dev/null +++ b/src/app/examiner/review-files/review-files.component.ts @@ -0,0 +1,82 @@ +import { HttpClient } from '@angular/common/http'; +import { Component, OnInit } from '@angular/core'; +import { MatDialog } from '@angular/material/dialog'; +import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; +import { ActivatedRoute } from '@angular/router'; +import { CanvasShareDataService } from 'src/app/canvas-share-data.service'; + +@Component({ + selector: 'app-review-files', + templateUrl: './review-files.component.html', + styleUrls: ['../../student/examination-details/examination-details.component.scss','./review-files.component.scss'] +}) +export class ReviewFilesComponent implements OnInit { + + constructor(public canvasData:CanvasShareDataService, public http:HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar,public route:ActivatedRoute) { } + + ngOnInit(): void { + this.getTest() + } + + examId:any = this.route.snapshot.queryParams.examId //考卷id + paperData:any //试卷信息 + examScore:number = 0//整个试卷的总分 + paperCompanyData:any = []; //考生具体考卷 + selectPaper:any = {id:null}; //选择当前考卷 + selectPaperType:string = '1'; //选择当前考卷内容 基本信息/作战部署 + + //获取考生试卷 + getTest () { + this.http.get(`/api/Examinations/${this.examId}`).subscribe((data:any)=>{ + this.paperData = data + this.paperData.examinationDataInfo.forEach(element => { + element.adjoinData? element.adjoinData = JSON.parse(element.adjoinData) : null + element.basicInfoData? element.basicInfoData = JSON.parse(element.basicInfoData) : null + element.facilityData? element.facilityData = JSON.parse(element.facilityData) : null + element.functionalDivisionData? element.functionalDivisionData = JSON.parse(element.functionalDivisionData) : null + element.importLocationData? element.importLocationData = JSON.parse(element.importLocationData) : null + element.score = element.adjoinScore + element.basicInfoScore + element.facilityScore + element.functionalDivisionScore + element.importLocationScore + this.examScore = this.examScore + element.score + }); + this.paperCompanyData = JSON.parse( JSON.stringify(data.examinationDataInfo) ) //具体考卷 + this.selectPaper = this.paperCompanyData[0] + }) + } + + //基本信息表格 是否展示当前行 + rowIsShow (children,tag) { + let isShow:boolean = false + children.forEach(element => { + element.result == tag? isShow = true : null + }); + return isShow + } + + //切换 选择考卷 + togglePaper (e) { + if (this.selectPaper.id != e.id) { + this.selectPaper = e + } + } + + //切换 选择考卷内容 + togglePaperType (e) { + if (this.selectPaperType != e) { + this.selectPaperType = e + } + } + + //提交阅卷结果 + submitResult () { + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 5000 + this.snackBar.open('阅卷结果提交成功','确定',config); + } + + //进入作战部署 阅卷 + enterExam(item){ + + } + +} diff --git a/src/app/student/examination-details/examination-details.component.ts b/src/app/student/examination-details/examination-details.component.ts index de3cf58..02ddc1d 100644 --- a/src/app/student/examination-details/examination-details.component.ts +++ b/src/app/student/examination-details/examination-details.component.ts @@ -138,47 +138,36 @@ export class ExaminationDetailsComponent implements OnInit { //交卷 uploadPaper () { - // let body = { - // id: this.route.snapshot.queryParams.examId, - // // name: null, - // // serverTime: null, - // // startTime: null, - // // endTime: null, - // // deadline: null, - // // isMarked: null, - // // totalScore: null, - // // examineeId: null, - // // examineeName: null, - // // paperId: null, - // // paperEndTime: null, - // examinationDataInfo: [] - // } - // let uploadPaper = JSON.parse( JSON.stringify(this.paperCompanyData) ) - // uploadPaper.forEach(element => { - // delete element.score - // delete element.planScore - // delete element.planList - // delete element.id - // delete element.paperId - // element.examinationId = this.route.snapshot.queryParams.examId - // element.adjoinData = JSON.stringify( element.adjoinData || [] ) - // element.basicInfoData = JSON.stringify( element.basicInfoData || [] ) - // element.facilityData = JSON.stringify( element.facilityData || [] ) - // element.functionalDivisionData = JSON.stringify( element.functionalDivisionData || [] ) - // element.importLocationData = JSON.stringify( element.importLocationData || [] ) - // }); - // console.log(body) - // body.examinationDataInfo = uploadPaper - // this.http.put(`/api/Examinations/UpdateExaminationData/${this.route.snapshot.queryParams.examId}`,body).subscribe(data=>{ - // console.log(data) - // }) - const config = new MatSnackBarConfig(); - config.verticalPosition = 'top'; - config.duration = 3000 - this.snackBar.open('试卷提交成功! 本页面即将关闭','确定',config); - // window.setTimeout(()=>{ - // window.close() - // },10000) + let isUpload = confirm('您确定要提交试卷吗') + if (isUpload) { + let body = { + id: this.route.snapshot.queryParams.examId, + examinationDataInfo: [] + } + let uploadPaper = JSON.parse( JSON.stringify(this.paperCompanyData) ) + uploadPaper.forEach(element => { + delete element.score + delete element.planScore + delete element.planList + delete element.id + delete element.paperId + element.examinationId = this.route.snapshot.queryParams.examId + element.adjoinData = JSON.stringify( element.adjoinData || [] ) + element.basicInfoData = JSON.stringify( element.basicInfoData || [] ) + element.facilityData = JSON.stringify( element.facilityData || [] ) + element.functionalDivisionData = JSON.stringify( element.functionalDivisionData || [] ) + element.importLocationData = JSON.stringify( element.importLocationData || [] ) + }); + body.examinationDataInfo = uploadPaper + this.http.put(`/api/Examinations/UpdateExaminationData/${this.route.snapshot.queryParams.examId}`,body).subscribe(data=>{ + this.surplusTime = -1 + window.setTimeout(()=>{ window.close() },8000) //8秒后关闭页面 + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 3000 + this.snackBar.open('试卷提交成功! 本页面即将关闭','确定',config); + }) + } } //进入作战部署 考卷 From 87cabc331606dcc2d090698d1c73dba92fbb34f1 Mon Sep 17 00:00:00 2001 From: chenjingyu Date: Mon, 28 Dec 2020 15:12:24 +0800 Subject: [PATCH 3/3] =?UTF-8?q?[=E4=BF=AE=E6=94=B9]=E8=80=83=E5=AE=98?= =?UTF-8?q?=E9=98=85=E5=8D=B7=E8=80=83=E8=AF=95=E4=BA=BA=E5=90=8D=E5=AD=97?= =?UTF-8?q?=E4=BF=AE=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../examiner/mark-papers-two/mark-papers-two.component.html | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/app/examiner/mark-papers-two/mark-papers-two.component.html b/src/app/examiner/mark-papers-two/mark-papers-two.component.html index 29f0535..33fa3cb 100644 --- a/src/app/examiner/mark-papers-two/mark-papers-two.component.html +++ b/src/app/examiner/mark-papers-two/mark-papers-two.component.html @@ -4,7 +4,7 @@ * @Author: sueRimn * @Date: 2020-12-14 17:21:02 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-25 11:26:01 + * @LastEditTime: 2020-12-28 15:09:51 -->
@@ -29,7 +29,7 @@ - {{item.name}} + {{item.examineeName}} 广西总队 {{item.endTime|date:'yyyy-MM-dd HH:mm'}} {{item.isMarked== true?"已阅卷":"未阅卷"}}