From 1a0e41182531286dbebe58abcff5e67d25214fbc Mon Sep 17 00:00:00 2001 From: chenjingyu Date: Sun, 20 Dec 2020 10:30:17 +0800 Subject: [PATCH 1/4] =?UTF-8?q?[=E4=BF=AE=E6=94=B9]=E6=B6=88=E9=98=B2?= =?UTF-8?q?=E6=95=91=E6=8F=B4=E7=AB=99=E6=9F=A5=E8=AF=A2=E5=8A=9F=E8=83=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package-lock.json | 16 +- package.json | 10 +- .../examiner-index.component.html | 38 +++-- .../examiner-index.component.scss | 46 ++++++ .../examiner-index.component.ts | 152 ++++++++++++++++-- .../statistic-analysis.component.html | 24 ++- .../statistic-analysis.component.scss | 69 ++++++++ .../statistic-analysis.component.ts | 86 ++++++++++ src/assets/images/examdown.png | Bin 0 -> 1844 bytes src/assets/images/examstatic.png | Bin 0 -> 294 bytes src/assets/images/statictop.png | Bin 0 -> 2808 bytes src/assets/images/upload.png | Bin 0 -> 716 bytes 12 files changed, 404 insertions(+), 37 deletions(-) create mode 100644 src/assets/images/examdown.png create mode 100644 src/assets/images/examstatic.png create mode 100644 src/assets/images/statictop.png create mode 100644 src/assets/images/upload.png diff --git a/package-lock.json b/package-lock.json index 5eccfb3..f568697 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7530,11 +7530,11 @@ } }, "echarts": { - "version": "4.6.0", - "resolved": "https://registry.npm.taobao.org/echarts/download/echarts-4.6.0.tgz?cache=0&sync_timestamp=1577438297540&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fecharts%2Fdownload%2Fecharts-4.6.0.tgz", - "integrity": "sha1-taR6EEbOyTzu75VPnuVHUTQFWOw=", + "version": "4.9.0", + "resolved": "https://registry.npm.taobao.org/echarts/download/echarts-4.9.0.tgz?cache=0&sync_timestamp=1606890707379&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fecharts%2Fdownload%2Fecharts-4.9.0.tgz", + "integrity": "sha1-qbm6oD8Doqcx5jQMVb77V6nhNH0=", "requires": { - "zrender": "4.2.0" + "zrender": "4.3.2" } }, "ee-first": { @@ -11999,7 +11999,7 @@ }, "parse5": { "version": "5.1.1", - "resolved": "https://registry.npm.taobao.org/parse5/download/parse5-5.1.1.tgz?cache=0&sync_timestamp=1595849319979&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fparse5%2Fdownload%2Fparse5-5.1.1.tgz", + "resolved": "https://registry.npm.taobao.org/parse5/download/parse5-5.1.1.tgz", "integrity": "sha1-9o5OW6GFKsLK3AD0VV//bCq7YXg=", "optional": true }, @@ -18471,9 +18471,9 @@ "integrity": "sha1-Z8oISzEW/DP8QENeDV6kCiB+OS4=" }, "zrender": { - "version": "4.2.0", - "resolved": "https://registry.npm.taobao.org/zrender/download/zrender-4.2.0.tgz?cache=0&sync_timestamp=1576159866096&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fzrender%2Fdownload%2Fzrender-4.2.0.tgz", - "integrity": "sha1-0AEwLhVfKN4fn8f81cJUutKEcc8=" + "version": "4.3.2", + "resolved": "https://registry.npm.taobao.org/zrender/download/zrender-4.3.2.tgz?cache=0&sync_timestamp=1605885988121&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fzrender%2Fdownload%2Fzrender-4.3.2.tgz", + "integrity": "sha1-7HQy+UFcgsc1hLa3uMR+GwFiCcY=" } } } diff --git a/package.json b/package.json index 77587c1..42dfacc 100644 --- a/package.json +++ b/package.json @@ -24,21 +24,21 @@ "@angular/router": "~9.0.0", "@types/cesium": "^1.59.5", "angular-calendar": "^0.28.2", + "bson-objectid": "^1.3.1", "cesium": "^1.64.0", "e-ngx-cesium": "^6.3.2", - "echarts": "^4.6.0", + "echarts": "^4.9.0", "firebase": "^7.6.2", "ng-zorro-antd": "^10.2.0", "ng2-file-upload": "^1.4.0", "ngx-echarts": "^4.2.2", "ngx-perfect-scrollbar": "^8.0.0", + "pixi-filters": "^3.1.1", + "pixi.js": "^5.3.2", "rxjs": "~6.5.4", + "swiper": "^5.3.7", "tslib": "^1.10.0", "viewerjs": "^1.6.2", - "swiper": "^5.3.7", - "pixi-filters": "^3.1.1", - "pixi.js": "^5.3.2", - "bson-objectid": "^1.3.1", "zone.js": "~0.10.2" }, "devDependencies": { diff --git a/src/app/examiner/examiner-index/examiner-index.component.html b/src/app/examiner/examiner-index/examiner-index.component.html index 9ee8aae..896fc78 100644 --- a/src/app/examiner/examiner-index/examiner-index.component.html +++ b/src/app/examiner/examiner-index/examiner-index.component.html @@ -4,20 +4,40 @@ * @Author: sueRimn * @Date: 2020-12-11 09:06:03 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-15 14:40:26 + * @LastEditTime: 2020-12-20 09:33:02 -->
-
+
- + + 包含下级 +
+
clear
+ + + +
  • {{node.name}}
  • +
    + + +
  • {{node.name}}
  • +
    +
    +
    {{item.status=="2"?"已结束":item.status=="0"?"未开考":"开考中"}} diff --git a/src/app/examiner/examiner-index/examiner-index.component.scss b/src/app/examiner/examiner-index/examiner-index.component.scss index 389689f..455cdd3 100644 --- a/src/app/examiner/examiner-index/examiner-index.component.scss +++ b/src/app/examiner/examiner-index/examiner-index.component.scss @@ -57,6 +57,52 @@ table { float: right; } } //queryBox + .ordiv{ + position: relative; + .organizationbox{ + button{ + color: #000000; + position: relative; + bottom: 9px; + } + width:450px; + height: 200px; + background: white; + position: absolute; + top: 47px; + left: 105px; + z-index: 999; + border: 1px solid grey; + overflow-y: auto; + li{ + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + } + mat-tree-node{ + cursor: pointer; + white-space:pre; + } + mat-tree-node:hover{ + background: rgba(225, 225, 225, 0.8); + } + .closediv{ + z-index: 100; + position: absolute; + right: 0; + top: 0; + width: 30px; + height: 30px; + cursor: pointer; + line-height: 30px; + text-align: center; + } + .closediv:hover{ + background:rgba(225, 225, 225, 0.8); + } + } + + } } .centertable{ width: 95%; diff --git a/src/app/examiner/examiner-index/examiner-index.component.ts b/src/app/examiner/examiner-index/examiner-index.component.ts index 076bb9d..771db9c 100644 --- a/src/app/examiner/examiner-index/examiner-index.component.ts +++ b/src/app/examiner/examiner-index/examiner-index.component.ts @@ -4,9 +4,9 @@ * @Author: sueRimn * @Date: 2020-12-11 09:06:03 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-15 14:10:50 + * @LastEditTime: 2020-12-20 10:28:13 */ -import { Component, OnInit, ViewChild, Inject } from '@angular/core'; +import { Component, OnInit, ViewChild, Inject,Input } from '@angular/core'; import {HttpClient} from '@angular/common/http' import { MatDialogRef, MatDialog, MAT_DIALOG_DATA } from '@angular/material/dialog'; import { MatPaginator } from '@angular/material/paginator'; @@ -15,7 +15,9 @@ 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'; - +import { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree'; +import { FlatTreeControl } from '@angular/cdk/tree'; +import { TreeService } from '../../http-interceptors/tree.service' @Component({ @@ -25,12 +27,16 @@ import { Router,ActivatedRoute } from '@angular/router'; }) export class ExaminerIndexComponent implements OnInit { - constructor(private router: Router,private activatedRoute: ActivatedRoute,public http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) { } + constructor(private router: Router,private activatedRoute: ActivatedRoute,public http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar,private tree: TreeService) { } //displayedColumns: string[] = ['name', 'organization', 'startTime', 'overTime', 'testState', 'operation']; ngOnInit(): void { + this.getunitdata(); + this.getOrganizations(); + this.getUnittype(); this.getAlltabledate() - this.getHelp() + setInterval(()=>this.getAlltabledate(),60000) + //this.getHelp() } displayedColumns: string[] = ['name','startTime','endTime', 'examzhong','scc']; @@ -38,6 +44,7 @@ export class ExaminerIndexComponent implements OnInit { accound helpName//消防救援对名称 optionId + @ViewChild('son') son; //分页 @ViewChild(MatPaginator, {static: true}) pageEvent: PageEvent; @@ -48,6 +55,85 @@ export class ExaminerIndexComponent implements OnInit { PageNumber:any //第几页 startTime:[] endTime:[] + allorganizations:any + allunittype:any //获取所有的单位类型 + jscheck:any //辖区中队包含下级 + private _transformer = (node, level: number) => { //初始化tree + return { + expandable: !!node.children && node.children.length > 0, + name: node.name, + level: level, + id: node.id, + parentId: node.parentId, + children: node.children + }; + } + treeControl = new FlatTreeControl(node => node.level, node => node.expandable); + treeFlattener = new MatTreeFlattener(this._transformer, node => node.level, node => node.expandable, node => node.children); + dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener); + hasChild = (_: number, node: any) => node.expandable; + + //得到当前单位信息 + getunitdata(){ + this.http.get("/api/ExamAccounts/Profiles").subscribe( + (data:any)=>{ + this.organizationName = data.organizationName + } + ) + } + organizationName:any //当前单位组织机构名称 + treedata:any //组织机构树型数据 + newArr:any = [] + newallorganizations:any //用于存储在原始数据基础上的每个机构增加children字段 + newallorganizations2:any + //得到当前单位所在组织机构的tree型数据 + getpresentOrganization(){ + this.newallorganizations = this.allorganizations + this.newallorganizations.forEach(item => { + item.children = [] + this.newallorganizations.forEach(element => { + if(element.parentId == item.id){ + item.children.push(element) + } + }); + }); + this.http.get("/api/ExamAccounts/Profiles").subscribe( + (data:any)=>{ + this.organizationName = data.organizationName + if(this.organizationName){ + this.newallorganizations.forEach(item => { + if(item.name == this.organizationName){ + this.dataSource.data = [item] + this.newallorganizations2 = [item] + } + }); + }else{ + this.newallorganizations2 = this.treedata + this.dataSource.data = this.treedata + } + } + ) + + } + //获得所有组织机构 + getOrganizations(){ + this.http.get('/api/Organizations').subscribe( + (data:any)=>{ + this.allorganizations = data + this.treedata = this.tree.toTree(data); + this.getpresentOrganization(); + } + ) + } + + //获得所有单位类型 + getUnittype(){ + this.http.get('/api/BuildingTypes/Simple').subscribe( + data=>{ + this.allunittype = data + } + ) + } //获得查询支队信息 help(){ @@ -73,13 +159,15 @@ export class ExaminerIndexComponent implements OnInit { let paramsdata:any = { PageNumber: this.PageNumber || '1', PageSize: this.pageSizeOptions[0], + OrganizationId: this.jsId || '', + HasChildren:this.jscheck || '', Sort: null, SortType: null, } this.http.get("/api/Papers",{params:paramsdata}).subscribe((data:any)=>{ this.tabledataSource=data.items this.length=data.totalCount - console.log(data) + console.log(this.tabledataSource) }) //console.log(this.tabledataSource) } @@ -111,7 +199,7 @@ export class ExaminerIndexComponent implements OnInit { } //查询按钮 findClick(){ - const config = new MatSnackBarConfig(); + /* const config = new MatSnackBarConfig(); config.verticalPosition = 'top'; config.duration = 3000 if(this.accound==undefined){ @@ -122,26 +210,64 @@ export class ExaminerIndexComponent implements OnInit { console.log(data) }) } - console.log(this.accound) + console.log(this.accound) */ + console.log(this.jscheck,this.jsId) + this.PageNumber = 1 + this.pageEvent.pageIndex = 0 + this.getAlltabledate() } //重置按钮 Reset(){ - this.accound=undefined + //this.accound=undefined + this.jsId='' + this.js='' + this.jscheck='' } //删除一套考题 deleteExam(examid){ - const config = new MatSnackBarConfig(); - config.verticalPosition = 'top'; - config.duration = 3000 - this.http.delete(`/api/Papers/${examid}`).subscribe((data:any)=>{ + let isTrue = confirm('您确定要删除吗') + if(isTrue){ + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 3000 + this.http.delete(`/api/Papers/${examid}`).subscribe((data:any)=>{ this.snackBar.open('删除试卷成功','确定',config); this.getAlltabledate() }) + } + } //新增考题跳转 newExamination(){ this.router.navigate(['/home/examiner-new-one']) } + //辖区中队div是否显示 + isorganizationbox:boolean = false + js:any //辖区中队输入框 + jsId:any //辖区中队选择的id + stopclose(e){ + e.stopPropagation(); + } + //点击辖区中队树,将选择的辖区中队添加到变量 + add(node) { + this.isorganizationbox = false + this.js = node.name + this.jsId = node.id + } + //关闭辖区中队隐藏框 + closeorganizationbox() { + this.isorganizationbox = false + } + //打开辖区中队隐藏框 + openorganizationbox() { + this.isorganizationbox = true + + } + + //关闭出现的组织机构div + closediv(){ + this.isorganizationbox = false + } } diff --git a/src/app/examiner/statistic-analysis/statistic-analysis.component.html b/src/app/examiner/statistic-analysis/statistic-analysis.component.html index 6afb4fe..49cc609 100644 --- a/src/app/examiner/statistic-analysis/statistic-analysis.component.html +++ b/src/app/examiner/statistic-analysis/statistic-analysis.component.html @@ -4,6 +4,26 @@ * @Author: sueRimn * @Date: 2020-12-15 14:19:50 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-15 14:32:36 + * @LastEditTime: 2020-12-17 14:30:16 --> -

    统计分析

    +
    +
    +
    +
    +
    +
    + +
    +
    STATISTICS
    +
    消防救援单位信息
    +
    考核统计分析
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    \ No newline at end of file diff --git a/src/app/examiner/statistic-analysis/statistic-analysis.component.scss b/src/app/examiner/statistic-analysis/statistic-analysis.component.scss index e69de29..e836026 100644 --- a/src/app/examiner/statistic-analysis/statistic-analysis.component.scss +++ b/src/app/examiner/statistic-analysis/statistic-analysis.component.scss @@ -0,0 +1,69 @@ +.conter{ + width: 100%; + height: 100%; + overflow: hidden; + background: #F2F5F6; + display: flex; + overflow-y: auto; + .left{ + width: 80%; + height: 60%; + margin: 20px 20px 10px 50px; + background-color: #FFFFFF; + border-radius: 16px ; + #zhidui{ + width: 80%; + height: 50%; + position: absolute; + top: 100px; + //left: 40%; + //top: 45%; + //transform: translate(-50%,-60%); + } + } + .right{ + width: 228px; + height: 60%; + margin: 20px 20px 10px 10px; + background-color: #07CDCF; + border-radius: 16px ; + display: flex; + flex-direction: column; + .rightone{ + //margin-top: 80px; + margin-left: 24px; + color:#FFFFFF; + display: flex; + flex-direction: column; + position: absolute; + top: 110px; + } + .righttwo{ + margin-top: 100px; + margin-left: 24px; + button{ + width: 180px; + height: 44px; + color: #FFFFFF; + background: rgba(255,255,255,0.6); + opacity: 1; + border-radius: 8px; + border: none; + font-size: 18px; + outline: none; + cursor: pointer; + } + .clickButton{ + background-color: #FFFFFF; + color: #07CDCF; + } + } + .rightthree{ + width: 100%; + margin-top: 110px; + img{ + float: right; + } + } + } +} \ No newline at end of file diff --git a/src/app/examiner/statistic-analysis/statistic-analysis.component.ts b/src/app/examiner/statistic-analysis/statistic-analysis.component.ts index c17eb42..6031b46 100644 --- a/src/app/examiner/statistic-analysis/statistic-analysis.component.ts +++ b/src/app/examiner/statistic-analysis/statistic-analysis.component.ts @@ -1,4 +1,14 @@ +/* + * @Descripttion: + * @version: + * @Author: sueRimn + * @Date: 2020-12-15 14:19:50 + * @LastEditors: sueRimn + * @LastEditTime: 2020-12-17 16:02:43 + */ import { Component, OnInit } from '@angular/core'; +//import {EchartsDataService} from '../../echarts-data.service'; +declare var echarts: any; @Component({ selector: 'app-statistic-analysis', @@ -10,6 +20,82 @@ export class StatisticAnalysisComponent implements OnInit { constructor() { } ngOnInit(): void { + window.setTimeout(()=>{ + this.initCharts() + },0) + } + + zhutu//柱状图实例 + zhiNameData =["浦东支队","黄浦支队","徐汇支队","长宁支队","静安支队","普陀支队","虹口支队","杨浦支队","闵行支队","宝山支队","嘉定支队"] + staticExam=false//考试统计 + upStatic=false//发布考试统计 + //考试统计按钮 + staticecam(){ + this.staticExam=true + this.upStatic=false + } + //发布考试按钮 + upexam(){ + this.staticExam=false + this.upStatic=true + } + + initCharts() { + var detailPlanEchart = echarts.init(document.getElementById('zhidui')); + var option = { + xAxis: { + type: 'category', + data: this.zhiNameData, + axisLabel:{ + fontSize:18, + lineHeight:31, + }, + axisLine:{ + show:false + }, + splitLine:{ + show:false + }, + axisTick:{ + show:false + }, + }, + yAxis: { + type: 'value', + axisLabel:{ + fontSize:18, + lineHeight:31 + }, + axisTick:{ + show:false + }, + axisLine:{ + show:false + }, + splitLine:{ + show:true, + lineStyle:{ + opacity:0.2, + type:'dashed' + } + }, + show:true + }, + series: [{ + data: [160, 150,140,130, 120, 100,90, 80, 60, 40,30], + type: 'bar', + showBackground: true, + backgroundStyle: { + color: '#F2F5F6' + }, + itemStyle:{ + color:"#FF8678", + barBorderRadius:12 + }, + barWidth:"24px" + }] + }; + detailPlanEchart.setOption(option); } } diff --git a/src/assets/images/examdown.png b/src/assets/images/examdown.png new file mode 100644 index 0000000000000000000000000000000000000000..3c3cf9d243dc714f6e6f9885f803083f64f4e1d6 GIT binary patch literal 1844 zcmV-42g~@0P)~yB9ONW@ay%+0}Sn*!a8>iC5U+8GiT7%sd_i)6e?dQ!{%KpTp1k_hUV! z6#ec}(~GbP6>xWf@zUBONc0GhDauFCtN@DVzL`BJr92vBnj%pX7SXh?c6Y(?N<1$| zO)}IB(ZbI6#5!YZ`agi0!*(cKraIh`Odgx6s5`i)t1%N8RRg3YxnV)7`Zc z;X?-IPJ>ie&_wN`rbu1ruJU%8;ve^|-3S}L%SY5M<3MPM)de)}t}z$+FJ0uPr2wZ0 zyJ(T!T???~yJ#jFJCg#7g(k*bK46gUOr$Ki%Z;;pen>XoxTu;YW}|P%%DL&)OPYek zK;!Nj(N*t=3C4+GT?91luH}~UUlx(xiOcllub+J(xVvVg^~^r4Coip;ykOP^;qLFp z=q2*wm8%!>@3j4in~wai1xaa5o)#yoE(~%fc%)TnAtMWoUn61!Q<|Jjdi5J$)JhLBR;|L?TD7h%1NLJKSsc$JI%X4L@ws&RM6<;2JNrLI#l53(8LMf z8jm^pcXz1&BC~YVf{mH$&*EmZMG8Wq_bYI0Xy{(=*L?9Ijs^|Q(&AaD&cIQiiQbZ? z33N#o*0}=5f<{Xnv~?CspuoY<#C3dfeh>bx1bTOo#e)ml-L+Rq7ky$$6gUVPcNZ*z z21}&CXlQVL6H&5})kC1sG=ZiIuw)91f+luFe$G*5$!Lk}j)jH^$(+2ba@`C~)G}YN zP9`rkW1x92uEWWzTJoGXK@+5U*4o>W@{6}S|8k$%u^CiB_D4n~C z)B=sJ^^-q?C0C#dni&1nxQwpK!ICRb3yqGM*T#Je1?qZ1?yl`99B~FPb%T3xH>6hO zVJJ`y4X0KC%X11`>eJB8hL&v#?1P34{BUzYfql@(mtj9P;M6rwEEtEBT?*{1X*h)w zXvRQ8(*!qL71&zSMAM{c0}KV~9ATO!NV!abT{R6&6Wr`n-~u$P&V!bH3T%Uh8SQ`Q0EBK)rOQB1)lS1IBTXxGQw;^ zgFgckdlmQ}nz+kA$Dm;-aH#_8(6HbNSgI6QhlaJlRgw{C9UA7F;Gs%^6*RGf@@r0m zsM0KbpaB}4G>#LT9)~&s256Y1tka87Lv!Tr98(Vt)d~zX&22NgSsjajsTCNYq34tu zgSN~M&@g?_rd#UJC60I%G#Cn0DIjRH?UtiNs^lV&6c99WfaM5dC{U$O zfhq+Ajjj>YI1PpZRSF0iu0^hria>(`f<~uyY8nAUfhq+A&0RCQUKN@^C=k6TMuS12 zNdeU~S`xt}>`k)e4lHPN6%WVP=jNa(_ku<@t6Xi0Mc~v52pT3UQzOuxc|oJK!B^U& z5+kbug610*lxHpearp+Cak^!W4*~JMG^=jARP@UP}2@d1hN~vXUQ}-TP+t zLn%eI%?cW=+SBSi3nWy4V;EW`qsZ3;X!vmZ+-57z(4p+>;6O96rM zb1CJ~W`F@22KazyP(XgmA7=L3;KS^KhOru;(ZJo`0;ZJm@G?0#5;i9+0!03bnjSSn i_sr~{T{X+5ME?RPD(|mDvF^U3fN literal 0 HcmV?d00001 diff --git a/src/assets/images/examstatic.png b/src/assets/images/examstatic.png new file mode 100644 index 0000000000000000000000000000000000000000..065dfb02c612ff5a50301c6d63cd4d84f041b797 GIT binary patch literal 294 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 literal 0 HcmV?d00001 diff --git a/src/assets/images/upload.png b/src/assets/images/upload.png new file mode 100644 index 0000000000000000000000000000000000000000..8e934e8548b2e3e17dde17ecb4fdbf1c3631d843 GIT binary patch literal 716 zcmV;-0yF)IP)GD7{;IX+nw2n)#litLqQjzgR`qvVBmm3LeU{5gdlGP9W*E;2r?)_>|ofzn{}#7 zU?`+iOt*yH*>9u{9)di0=ukMi9(L!?_sXp8woY4q$C>B-%`?yY%n(`~DGgm=6pTTD zPlBjI;35-d{ao%%%bDL7DS1;XuAUZ%<{26S_5$Hmg z?_5r5{y4PltloBH6GGhgbDfj_%Sm_S7ZBF`+}|!6z;r?Or37ph!3=s#_Wnv)nR=qyarOU98dl=@SG-Ydo!=|w3)*zoh_ zr6df3=7}-L;3a^132>|1-axAk>W*9haFldMmO=EWd9#_4v>Ev6Z+XL+b|YY5LUHs_ zP-;Ob9tyj2ACfNhk~r=wzB{#u&glSNREMi-h7BSyB4p!7m@n} z%r|4;0vN~qvez90l26_T{8yK3JFT}F1rXM$(LZ21*!J!wp$7u@S~4Yov52E{wH|6k zIVuR#%=ijHi(sy>z#@Rm}zyw7C((@=bo2&du=2VLf~rZ1(o`f&!%5Re7o yQ#EH=8ApBxV_Ffm1TfbOWMGGYl}PbqeNnp$nLuw?ZnLuh0000 Date: Mon, 21 Dec 2020 08:33:01 +0800 Subject: [PATCH 2/4] =?UTF-8?q?=E5=88=A0=E9=99=A4=E6=B5=8B=E8=AF=95?= =?UTF-8?q?=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/app/working-area/working-area.component.ts | 9 --------- 1 file changed, 9 deletions(-) diff --git a/src/app/working-area/working-area.component.ts b/src/app/working-area/working-area.component.ts index 6fcb652..688a14c 100644 --- a/src/app/working-area/working-area.component.ts +++ b/src/app/working-area/working-area.component.ts @@ -397,15 +397,6 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV } this.canvasData.isChange = true; }); - - // todo 创建一个无限大的grid - const cell = new PIXI.Graphics(); - cell.lineStyle(1, 0xff0000); - cell.beginFill(0x0000ff); - cell.drawRect(0, 0, 500, 500); - - cell.endFill(); - this.app.stage.addChild(cell); } /** * 重置画布 From 94a166ab0771b1fb215f8d4939172817f0a9ba24 Mon Sep 17 00:00:00 2001 From: chenjingyu Date: Mon, 21 Dec 2020 08:52:35 +0800 Subject: [PATCH 3/4] =?UTF-8?q?[=E6=96=B0=E5=BB=BA]=E8=80=83=E7=94=9F?= =?UTF-8?q?=E7=9B=AE=E5=BD=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/app/app-routing.module.ts | 9 ++ src/app/app.module.ts | 13 +- src/app/navigation/navigation.component.html | 10 +- .../student-exam-record.component.html | 1 + .../student-exam-record.component.scss | 0 .../student-exam-record.component.spec.ts | 25 ++++ .../student-exam-record.component.ts | 15 +++ .../student-index.component.html | 1 + .../student-index.component.scss | 0 .../student-index.component.spec.ts | 25 ++++ .../student-index/student-index.component.ts | 15 +++ src/app/student/student-routing.module.ts | 24 ++++ src/app/student/student.module.ts | 112 ++++++++++++++++++ src/assets/images/examrecord.png | Bin 0 -> 338 bytes src/assets/images/joinexam.png | Bin 0 -> 519 bytes 15 files changed, 248 insertions(+), 2 deletions(-) create mode 100644 src/app/student/student-exam-record/student-exam-record.component.html create mode 100644 src/app/student/student-exam-record/student-exam-record.component.scss create mode 100644 src/app/student/student-exam-record/student-exam-record.component.spec.ts create mode 100644 src/app/student/student-exam-record/student-exam-record.component.ts create mode 100644 src/app/student/student-index/student-index.component.html create mode 100644 src/app/student/student-index/student-index.component.scss create mode 100644 src/app/student/student-index/student-index.component.spec.ts create mode 100644 src/app/student/student-index/student-index.component.ts create mode 100644 src/app/student/student-routing.module.ts create mode 100644 src/app/student/student.module.ts create mode 100644 src/assets/images/examrecord.png create mode 100644 src/assets/images/joinexam.png diff --git a/src/app/app-routing.module.ts b/src/app/app-routing.module.ts index bd6ecc8..bfe5587 100644 --- a/src/app/app-routing.module.ts +++ b/src/app/app-routing.module.ts @@ -1,3 +1,11 @@ +/* + * @Descripttion: + * @version: + * @Author: sueRimn + * @Date: 2020-12-20 10:30:23 + * @LastEditors: sueRimn + * @LastEditTime: 2020-12-20 15:36:30 + */ import { NgModule } from '@angular/core'; import { Routes, RouterModule } from '@angular/router'; import { LoginComponent } from './pages/login/login.component'; @@ -17,6 +25,7 @@ const routes: Routes = [ path:'home',component:NavigationComponent,canActivate: [AuthGuard],//守卫验证 children:[ {path:'',loadChildren:() => import('./examiner/examiner.module').then(m => m.ExaminerModule)}, + {path:'',loadChildren:() => import('./student/student.module').then(m => m.StudentModule)}, {path:'',loadChildren:() => import('./ui/ui.module').then(m => m.UiModule)} ] }, diff --git a/src/app/app.module.ts b/src/app/app.module.ts index 126f803..9aa784e 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -1,3 +1,11 @@ +/* + * @Descripttion: + * @version: + * @Author: sueRimn + * @Date: 2020-12-12 09:14:54 + * @LastEditors: sueRimn + * @LastEditTime: 2020-12-20 15:34:49 + */ import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppRoutingModule } from './app-routing.module'; @@ -20,7 +28,9 @@ import { ComponentServiceService } from './component-service.service'; import { registerLocaleData } from '@angular/common'; 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: [ @@ -37,7 +47,8 @@ registerLocaleData(zh); PagesModule, FormsModule, HttpClientModule, - ExaminerModule + ExaminerModule, + StudentModule ], providers: [httpInterceptorProviders, CacheTokenService,TreeService,ComponentServiceService], bootstrap: [AppComponent] diff --git a/src/app/navigation/navigation.component.html b/src/app/navigation/navigation.component.html index f389b85..7c6d997 100644 --- a/src/app/navigation/navigation.component.html +++ b/src/app/navigation/navigation.component.html @@ -4,7 +4,7 @@ * @Author: sueRimn * @Date: 2020-12-10 10:21:40 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-15 14:32:13 + * @LastEditTime: 2020-12-20 16:32:02 --> @@ -41,6 +41,14 @@ +
      +
    • + +
    • +
    • + +
    • +
    diff --git a/src/app/student/student-exam-record/student-exam-record.component.html b/src/app/student/student-exam-record/student-exam-record.component.html new file mode 100644 index 0000000..00e0b82 --- /dev/null +++ b/src/app/student/student-exam-record/student-exam-record.component.html @@ -0,0 +1 @@ +

    student-exam-record works!

    diff --git a/src/app/student/student-exam-record/student-exam-record.component.scss b/src/app/student/student-exam-record/student-exam-record.component.scss new file mode 100644 index 0000000..e69de29 diff --git a/src/app/student/student-exam-record/student-exam-record.component.spec.ts b/src/app/student/student-exam-record/student-exam-record.component.spec.ts new file mode 100644 index 0000000..124461f --- /dev/null +++ b/src/app/student/student-exam-record/student-exam-record.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { StudentExamRecordComponent } from './student-exam-record.component'; + +describe('StudentExamRecordComponent', () => { + let component: StudentExamRecordComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ StudentExamRecordComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(StudentExamRecordComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/student/student-exam-record/student-exam-record.component.ts b/src/app/student/student-exam-record/student-exam-record.component.ts new file mode 100644 index 0000000..223b0d7 --- /dev/null +++ b/src/app/student/student-exam-record/student-exam-record.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-student-exam-record', + templateUrl: './student-exam-record.component.html', + styleUrls: ['./student-exam-record.component.scss'] +}) +export class StudentExamRecordComponent implements OnInit { + + constructor() { } + + ngOnInit(): void { + } + +} diff --git a/src/app/student/student-index/student-index.component.html b/src/app/student/student-index/student-index.component.html new file mode 100644 index 0000000..6db07b8 --- /dev/null +++ b/src/app/student/student-index/student-index.component.html @@ -0,0 +1 @@ +

    student-index works!

    diff --git a/src/app/student/student-index/student-index.component.scss b/src/app/student/student-index/student-index.component.scss new file mode 100644 index 0000000..e69de29 diff --git a/src/app/student/student-index/student-index.component.spec.ts b/src/app/student/student-index/student-index.component.spec.ts new file mode 100644 index 0000000..3d9ffad --- /dev/null +++ b/src/app/student/student-index/student-index.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { StudentIndexComponent } from './student-index.component'; + +describe('StudentIndexComponent', () => { + let component: StudentIndexComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ StudentIndexComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(StudentIndexComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/student/student-index/student-index.component.ts b/src/app/student/student-index/student-index.component.ts new file mode 100644 index 0000000..2492f3b --- /dev/null +++ b/src/app/student/student-index/student-index.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-student-index', + templateUrl: './student-index.component.html', + styleUrls: ['./student-index.component.scss'] +}) +export class StudentIndexComponent implements OnInit { + + constructor() { } + + ngOnInit(): void { + } + +} diff --git a/src/app/student/student-routing.module.ts b/src/app/student/student-routing.module.ts new file mode 100644 index 0000000..8e6d8d1 --- /dev/null +++ b/src/app/student/student-routing.module.ts @@ -0,0 +1,24 @@ +/* + * @Descripttion: + * @version: + * @Author: sueRimn + * @Date: 2020-12-20 11:21:49 + * @LastEditors: sueRimn + * @LastEditTime: 2020-12-20 16:31:55 + */ +import { NgModule } from '@angular/core'; +import { Routes, RouterModule } from '@angular/router'; +import { StudentIndexComponent} from './student-index/student-index.component' +import { StudentExamRecordComponent} from './student-exam-record/student-exam-record.component' + + +const routes: Routes = [ + { path: 'student-index', component:StudentIndexComponent }, + { path: 'student-exarecord', component:StudentExamRecordComponent }, +]; + +@NgModule({ + imports: [RouterModule.forChild(routes)], + exports: [RouterModule] +}) +export class StudentRoutingModule { } diff --git a/src/app/student/student.module.ts b/src/app/student/student.module.ts new file mode 100644 index 0000000..71bf87c --- /dev/null +++ b/src/app/student/student.module.ts @@ -0,0 +1,112 @@ +import { NgModule } from '@angular/core'; +import { CommonModule } from '@angular/common'; +import {A11yModule} from '@angular/cdk/a11y'; +import {DragDropModule} from '@angular/cdk/drag-drop'; +import {PortalModule} from '@angular/cdk/portal'; +import {ScrollingModule} from '@angular/cdk/scrolling'; +import {CdkStepperModule} from '@angular/cdk/stepper'; +import {CdkTableModule} from '@angular/cdk/table'; +import {CdkTreeModule} from '@angular/cdk/tree'; +import {MatAutocompleteModule} from '@angular/material/autocomplete'; +import {MatBadgeModule} from '@angular/material/badge'; +import {MatBottomSheetModule} from '@angular/material/bottom-sheet'; +import {MatButtonModule} from '@angular/material/button'; +import {MatButtonToggleModule} from '@angular/material/button-toggle'; +import {MatCardModule} from '@angular/material/card'; +import {MatCheckboxModule} from '@angular/material/checkbox'; +import {MatChipsModule} from '@angular/material/chips'; +import {MatStepperModule} from '@angular/material/stepper'; +import {MatDatepickerModule} from '@angular/material/datepicker'; +import {MatDialogModule} from '@angular/material/dialog'; +import {MatDividerModule} from '@angular/material/divider'; +import {MatExpansionModule} from '@angular/material/expansion'; +import {MatGridListModule} from '@angular/material/grid-list'; +import {MatIconModule} from '@angular/material/icon'; +import {MatInputModule} from '@angular/material/input'; +import {MatListModule} from '@angular/material/list'; +import {MatMenuModule} from '@angular/material/menu'; +import {MatNativeDateModule, MatRippleModule, MatOption} from '@angular/material/core'; +import {MatPaginatorModule} from '@angular/material/paginator'; +import {MatProgressBarModule} from '@angular/material/progress-bar'; +import {MatProgressSpinnerModule} from '@angular/material/progress-spinner'; +import {MatRadioModule} from '@angular/material/radio'; +import {MatSelectModule} from '@angular/material/select'; +import {MatSidenavModule} from '@angular/material/sidenav'; +import {MatSliderModule} from '@angular/material/slider'; +import {MatSlideToggleModule} from '@angular/material/slide-toggle'; +import {MatSnackBarModule} from '@angular/material/snack-bar'; +import {MatSortModule} from '@angular/material/sort'; +import {MatTableModule} from '@angular/material/table'; +import {MatTabsModule} from '@angular/material/tabs'; +import {MatToolbarModule} from '@angular/material/toolbar'; +import {MatTooltipModule} from '@angular/material/tooltip'; +import {MatTreeModule} from '@angular/material/tree'; +import { ReactiveFormsModule, FormsModule } from '@angular/forms'; +import { MatFormFieldModule } from '@angular/material/form-field'; +import { MatPaginatorIntl } from '@angular/material/paginator'; +import { myPaginator } from '../ui/my-paginator'; +import { NavigationModule } from '../navigation/navigation.module'; +import { NzTreeModule } from 'ng-zorro-antd/tree'; +import { NzDatePickerModule } from 'ng-zorro-antd/date-picker'; + +import { StudentRoutingModule } from './student-routing.module'; +import { StudentIndexComponent } from './student-index/student-index.component'; +import { StudentExamRecordComponent } from './student-exam-record/student-exam-record.component'; + + +@NgModule({ + declarations: [StudentIndexComponent, StudentExamRecordComponent], + imports: [ + CommonModule, + StudentRoutingModule, + A11yModule, + CdkStepperModule, + CdkTableModule, + CdkTreeModule, + DragDropModule, + MatAutocompleteModule, + MatBadgeModule, + MatBottomSheetModule, + MatButtonModule, + MatButtonToggleModule, + MatCardModule, + MatCheckboxModule, + MatChipsModule, + MatStepperModule, + MatDatepickerModule, + MatDialogModule, + MatDividerModule, + MatExpansionModule, + MatGridListModule, + MatIconModule, + MatInputModule, + MatListModule, + MatMenuModule, + MatNativeDateModule, + MatPaginatorModule, + MatProgressBarModule, + MatProgressSpinnerModule, + MatRadioModule, + MatRippleModule, + MatSelectModule, + MatSidenavModule, + MatSliderModule, + MatSlideToggleModule, + MatSnackBarModule, + MatSortModule, + MatTableModule, + MatTabsModule, + MatToolbarModule, + MatTooltipModule, + MatTreeModule, + PortalModule, + ScrollingModule, + ReactiveFormsModule, + FormsModule, + NavigationModule, + NzTreeModule, + NzDatePickerModule, + ], + providers: [ { provide: MatPaginatorIntl, useValue: myPaginator() } ] +}) +export class StudentModule { } diff --git a/src/assets/images/examrecord.png b/src/assets/images/examrecord.png new file mode 100644 index 0000000000000000000000000000000000000000..cf55a7d4691b29e3dd8cb5cddec6fb0725fcd726 GIT binary patch literal 338 zcmV-Y0j>UtP)5}{y%sj&1p+Vp zOD2pPH?wY|e>KZL@8f?nZ&qYw`w7?w4uBV6Gw%bRz%g(Kj3o_IU$*yvYe|PS(9S}T zvyyNLvi%5L2IvjgmK5uJq8V^ro9Gtk=M&jB@E+n=5TKf<)#pv_Y z)>5MY8%i3NK#`+Ty-NC63n~%n{a;&aipM%ogmR@M#j{zdzsr&B3*hL7p{mPi{X}fX zLp^J{j4q%mL$R(g_4S@~ literal 0 HcmV?d00001 diff --git a/src/assets/images/joinexam.png b/src/assets/images/joinexam.png new file mode 100644 index 0000000000000000000000000000000000000000..aa1a86246949c08e109d363b6b03d49bb16df83b GIT binary patch literal 519 zcmV+i0{H!jP)O^h_uVr_w?g^8gu#=;W1 zrJxaR80_f0fZ%l&UCsj&4|9;RT?!Q1ya6zk2U<=y5Jf*r zf&aaRe#^XMLU0qd7Tb6z+u7M5Lq;`;sUD1(_4{y-Xd&j}uK^nXhR&7(Z!G`-002ov JPDHLkV1mXu?M46q literal 0 HcmV?d00001 From 62ec0e96936936ae472f670cf6d6e08309dc93fa Mon Sep 17 00:00:00 2001 From: chenjingyu Date: Mon, 21 Dec 2020 11:01:47 +0800 Subject: [PATCH 4/4] =?UTF-8?q?[=E4=BF=AE=E6=94=B9]=E5=AE=8C=E6=88=90?= =?UTF-8?q?=E5=BC=B9=E7=AA=97=E6=94=BE=E5=88=B0=E8=80=83=E5=AE=98=E9=A6=96?= =?UTF-8?q?=E9=A1=B5=E9=9D=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../examiner-index.component.ts | 105 +++++++++++++++++- .../examiner/examiner-index/finishDia.html | 32 ++++++ .../examiner/examiner-index/finishDia.scss | 44 ++++++++ .../examiner-new-one.component.ts | 8 +- src/app/examiner/examiner.module.ts | 3 +- 5 files changed, 186 insertions(+), 6 deletions(-) create mode 100644 src/app/examiner/examiner-index/finishDia.html create mode 100644 src/app/examiner/examiner-index/finishDia.scss diff --git a/src/app/examiner/examiner-index/examiner-index.component.ts b/src/app/examiner/examiner-index/examiner-index.component.ts index 8ba78a1..fee4c15 100644 --- a/src/app/examiner/examiner-index/examiner-index.component.ts +++ b/src/app/examiner/examiner-index/examiner-index.component.ts @@ -4,7 +4,7 @@ * @Author: sueRimn * @Date: 2020-12-11 09:06:03 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-20 10:31:09 + * @LastEditTime: 2020-12-21 10:44:17 */ import { Component, OnInit, ViewChild, Inject,Input } from '@angular/core'; import {HttpClient} from '@angular/common/http' @@ -237,7 +237,11 @@ export class ExaminerIndexComponent implements OnInit { } //新增考题跳转 newExamination(){ - this.router.navigate(['/home/createexam-index/examiner-new-one']) + //this.router.navigate(['/home/createexam-index/examiner-new-one']) + const dialogRef = this.dialog.open(FinishDia, { + width: '650px', + //data: paperDataInfo + }); } //辖区中队div是否显示 isorganizationbox:boolean = false @@ -268,3 +272,100 @@ export class ExaminerIndexComponent implements OnInit { } } + +@Component({ + selector: 'finish-dialog', + templateUrl: 'finishDia.html', + styleUrls: ['finishDia.scss'] +}) +export class FinishDia{ + + constructor(private router:Router,private http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar,public dialogRef: MatDialogRef,@Inject(MAT_DIALOG_DATA) public data: any) {} + ngOnInit(): void { + this.getProfiles() + } + //获取登录账号的个人资料 + Profiles:any + getProfiles(){ + this.http.get('/api/ExamAccounts/Profiles').subscribe(data => { + console.log(data) + this.Profiles = data + }) + } + + + startTime:string//考试开始时间 + endTime:string//考试结束时间 + examName:string//考试名称 + indexid:string//创建考试的id + tabledate + + //弹窗确定点击事件 + onNoClick(): void { + const config = new MatSnackBarConfig(); + config.verticalPosition = 'top'; + config.duration = 3000 + if(this.startTime!=undefined&&this.endTime!=undefined&&this.examName!=undefined){ + if(this.startTime>this.endTime){ + this.snackBar.open('开始时间不能大于结束时间','确定',config); + } + else{ + //截取字符串,得到日期部分"2009-12-02",用split把字符串分隔成数组 + var begin1=this.startTime.substr(0,10).split("-"); + var end1=this.endTime.substr(0,10).split("-"); + //将拆分的数组重新组合,并实例成化新的日期对象 + var date1=new Date(begin1[1] + - + begin1[2] + - + begin1[0]); + var date2=new Date(end1[1] + - + end1[2] + - + end1[0]); + //得到两个日期之间的差值m,以分钟为单位 + var m=Number(Math.abs(Number(date2)-Number(date1))/1000/60); + //小时数和分钟数相加得到总的分钟数 + var min1=parseInt(this.startTime.substr(11,2))*60+parseInt(this.startTime.substr(14,2)); + var min2=parseInt(this.endTime.substr(11,2))*60+parseInt(this.endTime.substr(14,2)); + //两个分钟数相减得到时间部分的差值,以分钟为单位 + var n=min2-min1; + //将日期和时间两个部分计算出来的差值相加,即得到两个时间相减后的分钟数 + var minutes=m+n; + + console.log(this.startTime,this.endTime) + let params = { + id: null, + title: this.examName, + duration: minutes, + modifiedTime: new Date(), + deleted: false, + startTime: this.startTime, + endTime: this.endTime, + organizationId: this.Profiles.organizationId, + creatorId: this.Profiles.id, + paperDataInfo: null + } + console.log(params) + this.http.post('/api/Papers',params).subscribe(data => { + this.snackBar.open('创建成功','确定',config); + this.dialogRef.close(); + //sessionStorage.removeItem("checkedWork") + this.tabledate=data + console.log(this.tabledate) + sessionStorage.setItem("indexId",this.tabledate.id) + this.router.navigate(['/home/createexam-index/examiner-new-one']) //跳转试卷列表页面 + },err => { + this.snackBar.open('创建失败','确定',config); + }) + } + } + else{ + if(this.startTime==undefined) + this.snackBar.open('请输入开始时间','确定',config); + else if(this.endTime==undefined) + this.snackBar.open('请输入结束时间','确定',config); + else if(this.examName==undefined) + this.snackBar.open('请输入试卷名称','确定',config); + } + + } + + + close(){ + this.dialogRef.close(); + } +} diff --git a/src/app/examiner/examiner-index/finishDia.html b/src/app/examiner/examiner-index/finishDia.html new file mode 100644 index 0000000..7cd8b49 --- /dev/null +++ b/src/app/examiner/examiner-index/finishDia.html @@ -0,0 +1,32 @@ + +
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +
    +
    +
    +
    + +
    + +
    + + +
    +
    \ No newline at end of file diff --git a/src/app/examiner/examiner-index/finishDia.scss b/src/app/examiner/examiner-index/finishDia.scss new file mode 100644 index 0000000..93c9f42 --- /dev/null +++ b/src/app/examiner/examiner-index/finishDia.scss @@ -0,0 +1,44 @@ +.box{ + display: flex; + flex-direction: column; + margin-left: 20px; + input{ + width: 260px; + height: 40px; + line-height: 34px; + border-radius: 5px; + padding-left: 5px; + outline: none; + border: 1px solid rgb(226, 211, 211); + } + .diaone{ + display: flex; + flex-direction: column; + + button { + border: none; + color: white; + padding: 5px 25px; + text-align: center; + text-decoration: none; + display: inline-block; + font-size: 16px; + margin: 4px 2px; + cursor: pointer; + border-radius: 8px; + outline:0 none !important; + } + } + .diatwo{ + margin-top: 20px; + display: flex; + flex-direction: row; + .endtime{ + margin-left: 20px; + } + .datepicker{ + height: 44px; + border-radius: 5px; + } + } +} diff --git a/src/app/examiner/examiner-new-one/examiner-new-one.component.ts b/src/app/examiner/examiner-new-one/examiner-new-one.component.ts index 4a1c835..edb165d 100644 --- a/src/app/examiner/examiner-new-one/examiner-new-one.component.ts +++ b/src/app/examiner/examiner-new-one/examiner-new-one.component.ts @@ -4,7 +4,7 @@ * @Author: sueRimn * @Date: 2020-12-11 16:34:26 * @LastEditors: sueRimn - * @LastEditTime: 2020-12-15 13:44:05 + * @LastEditTime: 2020-12-21 10:52:07 */ import { Component, OnInit, ViewChild, Inject } from '@angular/core'; import { HttpClient } from '@angular/common/http' @@ -30,11 +30,13 @@ export class ExaminerNewOneComponent implements OnInit { constructor(private http:HttpClient,private router:Router,private route:ActivatedRoute,private tree: TreeService,public dialog: MatDialog,public snackBar: MatSnackBar) { } ngOnInit(): void { + this.getunitdata(); this.getOrganizations(); this.getUnittype(); this.getAllKeyUnit(); } + indexid=sessionStorage.getItem("indexId") //上个页面传过来的id removeClass=document.getElementsByClassName("mat-form-field-underline") private _transformer = (node, level: number) => { //初始化tree @@ -305,7 +307,7 @@ export class ExaminerNewOneComponent implements OnInit { } ) } - selectedunitArr:any =JSON.parse(sessionStorage.getItem("checkedWork"))||[] //选中单位的数组 + selectedunitArr:any =JSON.parse(sessionStorage.getItem(this.indexid))||[] //选中单位的数组 deleteByid=""//根据id取消选中 //勾选框事件 checkChange(e,element){ @@ -354,7 +356,7 @@ export class ExaminerNewOneComponent implements OnInit { this.snackBar.open('请选择单位','确定',config); } else{ - sessionStorage.setItem("checkedWork",JSON.stringify(this.selectedunitArr) ) + sessionStorage.setItem(this.indexid,JSON.stringify(this.selectedunitArr) ) this.router.navigateByUrl("/examiner/create-test-score") } diff --git a/src/app/examiner/examiner.module.ts b/src/app/examiner/examiner.module.ts index 8fab453..930a949 100644 --- a/src/app/examiner/examiner.module.ts +++ b/src/app/examiner/examiner.module.ts @@ -56,10 +56,11 @@ 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' @NgModule({ - declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog,PlanLevel,MarkPapersIndexComponent, MarkPapersTwoComponent, StatisticAnalysisComponent], + declarations: [CreateTestScoreComponent,AddPlanDialog,AddPlanTwoDialog,LookTreeNodeDialog,ExaminerIndexComponent, ExaminerNewOneComponent,FinishDialog,PlanLevel,MarkPapersIndexComponent, MarkPapersTwoComponent, StatisticAnalysisComponent,FinishDia], imports: [ CommonModule, examinerRoutingModule,