chenjingyu 4 years ago
parent
commit
41ec693e5f
  1. 3
      angular.json
  2. 2
      package.json
  3. 2
      src/app/app-routing.module.ts
  4. 1
      src/app/app.component.ts
  5. 20
      src/app/canvas-share-data.service.ts
  6. 5
      src/app/examiner/create-test-score/addPlanTwo.html
  7. 26
      src/app/examiner/create-test-score/create-test-score.component.html
  8. 738
      src/app/examiner/create-test-score/create-test-score.component.ts
  9. 2
      src/app/examiner/create-test-score/lookTreeNode.html
  10. 7
      src/app/examiner/examiner-index/examiner-index.component.ts
  11. 7
      src/app/examiner/examiner-routing.ts
  12. 2
      src/app/examiner/mark-papers-index/mark-papers-index.component.ts
  13. 1
      src/app/http-interceptors/base-interceptor.ts
  14. 1
      src/app/http-interceptors/cache-token.service.ts
  15. 14
      src/app/navigation/adddatabank.html
  16. 14
      src/app/navigation/editdatabankname.html
  17. 14
      src/app/navigation/navigation.component.html
  18. 70
      src/app/navigation/navigation.component.ts
  19. 6
      src/app/navigation/navigation.module.ts
  20. 45
      src/app/pipes/size.pipe.ts
  21. 12
      src/app/tabbar/tabbar.component.ts
  22. 159
      src/app/ui/all-file/all-file.component.html
  23. 265
      src/app/ui/all-file/all-file.component.scss
  24. 25
      src/app/ui/all-file/all-file.component.spec.ts
  25. 918
      src/app/ui/all-file/all-file.component.ts
  26. 14
      src/app/ui/all-file/folderdalog.html
  27. 12
      src/app/ui/all-file/viewdetails.html
  28. 46
      src/app/ui/collection-tools/collection-tools.component.html
  29. 19
      src/app/ui/collection-tools/collection-tools.component.scss
  30. 420
      src/app/ui/collection-tools/collection-tools.component.ts
  31. 51
      src/app/ui/collection-tools/examinationQuestions.html
  32. 218
      src/app/ui/collection-tools/examinationQuestions.ts
  33. 2
      src/app/ui/collection-tools/panel.scss
  34. 24
      src/app/ui/collection-tools/save.ts
  35. 14
      src/app/ui/collection-tools/uploadDisposalNodes.html
  36. 51
      src/app/ui/collection-tools/uploadQuestions.html
  37. 54
      src/app/ui/create-exam/create-exam.component.html
  38. 52
      src/app/ui/create-exam/create-exam.component.scss
  39. 25
      src/app/ui/create-exam/create-exam.component.spec.ts
  40. 76
      src/app/ui/create-exam/create-exam.component.ts
  41. 34
      src/app/ui/create-exam/createDialog.html
  42. 40
      src/app/ui/eharts-statistics/eharts-statistics.component.html
  43. 50
      src/app/ui/eharts-statistics/eharts-statistics.component.scss
  44. 25
      src/app/ui/eharts-statistics/eharts-statistics.component.spec.ts
  45. 228
      src/app/ui/eharts-statistics/eharts-statistics.component.ts
  46. 1
      src/app/ui/join-exam/join-exam.component.html
  47. 0
      src/app/ui/join-exam/join-exam.component.scss
  48. 25
      src/app/ui/join-exam/join-exam.component.spec.ts
  49. 15
      src/app/ui/join-exam/join-exam.component.ts
  50. 49
      src/app/ui/learning-record-details/learning-record-details.component.html
  51. 57
      src/app/ui/learning-record-details/learning-record-details.component.scss
  52. 188
      src/app/ui/learning-record-details/learning-record-details.component.ts
  53. 1
      src/app/ui/look-over-test/look-over-test.component.html
  54. 0
      src/app/ui/look-over-test/look-over-test.component.scss
  55. 25
      src/app/ui/look-over-test/look-over-test.component.spec.ts
  56. 15
      src/app/ui/look-over-test/look-over-test.component.ts
  57. 1
      src/app/ui/statistic-analysis/statistic-analysis.component.html
  58. 0
      src/app/ui/statistic-analysis/statistic-analysis.component.scss
  59. 25
      src/app/ui/statistic-analysis/statistic-analysis.component.spec.ts
  60. 15
      src/app/ui/statistic-analysis/statistic-analysis.component.ts
  61. 1
      src/app/ui/test-records/test-records.component.html
  62. 0
      src/app/ui/test-records/test-records.component.scss
  63. 25
      src/app/ui/test-records/test-records.component.spec.ts
  64. 15
      src/app/ui/test-records/test-records.component.ts
  65. 20
      src/app/ui/ui-routing.module.ts
  66. 27
      src/app/ui/ui.module.ts
  67. 23
      src/app/ui/upload-files/upload-files.component.html
  68. 72
      src/app/ui/upload-files/upload-files.component.scss
  69. 25
      src/app/ui/upload-files/upload-files.component.spec.ts
  70. 67
      src/app/ui/upload-files/upload-files.component.ts
  71. 64
      src/app/working-area/model/axArrowConnector.ts
  72. 441
      src/app/working-area/model/axImageShape.ts
  73. 27
      src/app/working-area/model/axPreviewImageShape.ts
  74. 110
      src/app/working-area/model/axShape.ts
  75. 6
      src/app/working-area/model/multipointIcon.ts
  76. 8
      src/app/working-area/model/paintModel.ts
  77. 38
      src/app/working-area/model/pipeline.ts
  78. 39
      src/app/working-area/model/polygonIcon.ts
  79. 108
      src/app/working-area/model/putCarArea.ts
  80. 373
      src/app/working-area/model/singlePointIcon.ts
  81. 523
      src/app/working-area/working-area.component.ts
  82. 8
      src/assets/css/ngZorroTree.css
  83. 8
      src/styles.scss

3
angular.json

@ -29,7 +29,8 @@
"src/assets" "src/assets"
], ],
"styles": [ "styles": [
"src/styles.scss" "src/styles.scss",
"node_modules/viewerjs/dist/viewer.css"
], ],
"scripts": [ "scripts": [
"node_modules/echarts/dist/echarts.js", "node_modules/echarts/dist/echarts.js",

2
package.json

@ -38,7 +38,7 @@
"rxjs": "~6.5.4", "rxjs": "~6.5.4",
"swiper": "^5.3.7", "swiper": "^5.3.7",
"tslib": "^1.10.0", "tslib": "^1.10.0",
"viewerjs": "^1.6.2", "viewerjs": "^1.9.0",
"zone.js": "~0.10.2" "zone.js": "~0.10.2"
}, },
"devDependencies": { "devDependencies": {

2
src/app/app-routing.module.ts

@ -21,7 +21,7 @@ const routes: Routes = [
] ]
}, },
{ path:'examiner/create-test-score', component:CreateTestScoreComponent,canActivate: [AuthGuard],}, //创建试卷具体分数页面 { path:'examiner/create-test-score', component:CreateTestScoreComponent,canActivate: [AuthGuard],}, //创建试卷具体分数页面
{ path: 'canvasTool', component:CollectionToolsComponent,canActivate: [AuthGuard], }, //编制工具 { path:'canvasTool', component:CollectionToolsComponent,canActivate: [AuthGuard], }, //编制工具
{ path:'adminLogin', component:LoginComponent}, //管理员登录路由 { path:'adminLogin', component:LoginComponent}, //管理员登录路由
{ path:'login', component:LockscreenComponent}, //教员学员登录路由 { path:'login', component:LockscreenComponent}, //教员学员登录路由

1
src/app/app.component.ts

@ -28,6 +28,7 @@ export class AppComponent {
sessionStorage.setItem("roleType",data.roleType); sessionStorage.setItem("roleType",data.roleType);
sessionStorage.setItem("token",data.token); sessionStorage.setItem("token",data.token);
sessionStorage.setItem("refreshToken",data.refreshToken); sessionStorage.setItem("refreshToken",data.refreshToken);
sessionStorage.setItem("level",data.level);
this.token.startUp() this.token.startUp()
}) })
} else { } else {

20
src/app/canvas-share-data.service.ts

@ -8,7 +8,6 @@ import { GameMode } from './working-area/model/gameMode';
export class CanvasShareDataService { export class CanvasShareDataService {
constructor() { } constructor() { }
private _sendMessage: ReplaySubject<any> = new ReplaySubject<any>(1); private _sendMessage: ReplaySubject<any> = new ReplaySubject<any>(1);
GameMode: any;
isChange = false; // 数据 是否改动 isChange = false; // 数据 是否改动
@ -82,6 +81,23 @@ export class CanvasShareDataService {
return returnData; return returnData;
} }
} }
/**
*
*/
public updateBuildingData() {
Object.keys(this.originaleveryStoreyData.data).forEach((key) => {
this.originalcompanyBuildingData.data[key] = this.originaleveryStoreyData.data[key];
});
}
/**
*
*/
public deleteBuildingDataByCurrentFloorData():void {
Object.keys(this.originaleveryStoreyData.data).forEach((key) => {
// 删除建筑数据
delete this.originalcompanyBuildingData.data[key];
});
}
/** /**
* *
*/ */
@ -666,7 +682,7 @@ export class AssetData {
/// <summary> /// <summary>
/// 是否来自建筑 /// 是否来自建筑
/// </summary> /// </summary>
public IsFromBuilding: boolean; public IsFromBuilding: boolean;
/// <summary> /// <summary>
/// 渲染方式。 /// 渲染方式。
/// </summary> /// </summary>

5
src/app/examiner/create-test-score/addPlanTwo.html

@ -3,7 +3,7 @@
<div class="title"> <div class="title">
添加预案 添加预案
</div> </div>
<div class="tablebox"> <div *ngIf="dataSource.length != 0" class="tablebox">
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8"> <table mat-table [dataSource]="dataSource" class="mat-elevation-z8">
<!-- Checkbox Column --> <!-- Checkbox Column -->
@ -47,6 +47,9 @@
</table> </table>
</div> </div>
<div *ngIf="dataSource.length == 0">
该单位暂无审核通过的二维预案
</div>
</div> </div>
<div *ngIf="!planType"> <div *ngIf="!planType">
<div class="title"> <div class="title">

26
src/app/examiner/create-test-score/create-test-score.component.html

@ -36,7 +36,7 @@
</div> </div>
</div> </div>
<div class="maincontantbox"> <div class="maincontantbox">
<div class="basicinfodiv" *ngIf="selectedTab == 1"> <div class="basicinfodiv" [hidden]="!(selectedTab == 1)">
<div *ngFor="let unit of unitId;let key = index"> <div *ngFor="let unit of unitId;let key = index">
<div [hidden]="!(key == selectedUnitIndex)"> <div [hidden]="!(key == selectedUnitIndex)">
<!-- 选择的单位名称 --> <!-- 选择的单位名称 -->
@ -49,12 +49,14 @@
基本信息 基本信息
<!-- <span class="colorspan" style="margin-left: 20px;">{{unit.basicInfoScore ? unit.basicInfoScore : 0}}分</span> --> <!-- <span class="colorspan" style="margin-left: 20px;">{{unit.basicInfoScore ? unit.basicInfoScore : 0}}分</span> -->
<span style="margin-left: 20px;"> <span style="margin-left: 20px;">
总分值: <input class="scoreInput" type="number" (click)="stopPropagation($event)" 总分值: <input onchange="if(!value)value=0" class="scoreInput" type="number" (click)="stopPropagation($event)"
[(ngModel)]="unit.basicInfoScore" (input)="sumScore('基本信息',key)"> 分, [(ngModel)]="unit.basicInfoScore" (input)="sumScore('基本信息',key)"> 分,
单项 单项
<span style="color: #FF8678;"> <span style="color: #FF8678;">
{{unit.basicInfoItemScore ? unit.basicInfoItemScore : 0}} {{unit.basicInfoItemScore ? unit.basicInfoItemScore : 0}}
</span> </span>
<span *ngIf="unit.basicInfoSelectedNum">(已选择 {{unit.basicInfoSelectedNum}} 项)</span>
</span> </span>
</mat-panel-title> </mat-panel-title>
</mat-expansion-panel-header> </mat-expansion-panel-header>
@ -97,6 +99,7 @@
单项 <span style="color: #FF8678;"> 单项 <span style="color: #FF8678;">
{{unit.aroundItemScore ? unit.aroundItemScore : 0}} {{unit.aroundItemScore ? unit.aroundItemScore : 0}}
</span> </span>
<span *ngIf="unit.aroundSelectedNum">(已选择 {{unit.aroundSelectedNum}} 项)</span>
</span> </span>
</mat-panel-title> </mat-panel-title>
</mat-expansion-panel-header> </mat-expansion-panel-header>
@ -139,6 +142,7 @@
单项 <span style="color: #FF8678;"> 单项 <span style="color: #FF8678;">
{{unit.keySiteItemScore ? unit.keySiteItemScore : 0}} {{unit.keySiteItemScore ? unit.keySiteItemScore : 0}}
</span> </span>
<span *ngIf="unit.keySiteSelectedNum">(已选择 {{unit.keySiteSelectedNum}} 项)</span>
</span> </span>
</mat-panel-title> </mat-panel-title>
</mat-expansion-panel-header> </mat-expansion-panel-header>
@ -181,6 +185,7 @@
单项 <span style="color: #FF8678;"> 单项 <span style="color: #FF8678;">
{{unit.funDivItemScore ? unit.funDivItemScore : 0}} {{unit.funDivItemScore ? unit.funDivItemScore : 0}}
</span> </span>
<span *ngIf="unit.funDivSelectedNum">(已选择 {{unit.funDivSelectedNum}} 项)</span>
</span> </span>
</mat-panel-title> </mat-panel-title>
</mat-expansion-panel-header> </mat-expansion-panel-header>
@ -223,6 +228,7 @@
单项 <span style="color: #FF8678;"> 单项 <span style="color: #FF8678;">
{{unit.fireFacItemScore ? unit.fireFacItemScore : 0}} {{unit.fireFacItemScore ? unit.fireFacItemScore : 0}}
</span> </span>
<span *ngIf="unit.fireFacSelectedNum">(已选择 {{unit.fireFacSelectedNum}} 项)</span>
</span> </span>
</mat-panel-title> </mat-panel-title>
</mat-expansion-panel-header> </mat-expansion-panel-header>
@ -257,7 +263,7 @@
</div> </div>
</div> </div>
<div class="fightdeploydiv" *ngIf="selectedTab == 2"> <div class="fightdeploydiv" [hidden]="!(selectedTab == 2)">
<div class="addPlan" (click)="addPlan()"> <div class="addPlan" (click)="addPlan()">
<mat-icon style="vertical-align: text-top">add_circle_outline</mat-icon>添加预案 <mat-icon style="vertical-align: text-top">add_circle_outline</mat-icon>添加预案
</div> </div>
@ -272,18 +278,18 @@
<td>设置分数</td> <td>设置分数</td>
<td>操作</td> <td>操作</td>
</tr> </tr>
<tr *ngFor="let item of planDatas"> <tr *ngFor="let item of unitId[selectedUnitIndex].planList">
<td>{{item.name}}</td> <td>{{item.name}}</td>
<td>{{item.or}}</td> <td>{{item.creatorName}}</td>
<td>{{item.time}}</td> <td>{{item.modifiedTime | date:'yyyy-MM-dd'}}</td>
<td>{{item.isOpen}}</td> <td>{{item.openRange}}</td>
<td>{{item.level}}</td> <td>{{item.planLevel | planlevel}}</td>
<td> <td>
<input (input)="planItemScore(item)" type="number" [(ngModel)]="item.score"> <input (input)="planItemScore(item)" type="number" [(ngModel)]="item.score">
</td> </td>
<td> <td>
<span style="color: #07CDCF;">编辑</span> <span style="color: #07CDCF;" (click)="edit(item)">编辑</span>
<span style="color: #FF8678;">删除</span> <span style="color: #FF8678;" (click)="deletePlan(item)">删除</span>
</td> </td>
</tr> </tr>
</table> </table>

738
src/app/examiner/create-test-score/create-test-score.component.ts

@ -20,9 +20,31 @@ export class CreateTestScoreComponent implements OnInit {
constructor(private router:Router,public dialog: MatDialog,private http: HttpClient,public snackBar: MatSnackBar) { } constructor(private router:Router,public dialog: MatDialog,private http: HttpClient,public snackBar: MatSnackBar) { }
selectedTab:number = 1 //选中的选项卡 selectedTab:number = 1 //选中的选项卡
selectTab(index){ selectTab(index){
this.selectedTab = index setTimeout(() => {
this.selectedTab = index
}, 0);
} }
ngOnInit(): void { ngOnInit(): void {
for (let y = 0, length = this.unitId.length; y < length; y++){
let element = this.unitId[y]
element.score = 0
element.basicInfoScore = 0
element.basicInfoItemScore = 0
element.basicInfoNodes = []
element.aroundScore = 0
element.aroundItemScore = 0
element.aroundNodes = []
element.keySiteScore = 0
element.keySiteItemScore = 0
element.keySiteNodes = []
element.funDivScore = 0
element.funDivItemScore = 0
element.funDivNodes = []
element.fireFacScore = 0
element.fireFacItemScore = 0
element.fireFacNodes = []
}
this.getUnitData().then(()=>{ this.getUnitData().then(()=>{
this.getAround().then(()=>{ this.getAround().then(()=>{
this.getKeySite().then(()=>{ this.getKeySite().then(()=>{
@ -32,21 +54,12 @@ export class CreateTestScoreComponent implements OnInit {
}) })
}) })
}) })
// Promise.all([this.getUnitData(),this.getAround(),this.getKeySite(),this.getFunDiv()]).then(()=>{
// this.getFireFac()
// })
} }
//当前选中的单位 //当前选中的单位
selectedUnitIndex = 0 selectedUnitIndex = 0
clickUnitName(key){ clickUnitName(key){
this.selectedUnitIndex = key this.selectedUnitIndex = key
} }
//上个页面传过来的单位数据
// unitId:any = [{name:'最最最最最',id:'5fb76c42919f2b44e464016f'},
// {name:'华南城集团有限公司',id:'5ee19fe06f91049f5e23e937'},
// {name:'贵港油库',id:'5fa35d68f8eb762cb03c662e'}
// ]
unitId:any = JSON.parse(sessionStorage.getItem('checkedWork')) unitId:any = JSON.parse(sessionStorage.getItem('checkedWork'))
//获取单位基本信息 //获取单位基本信息
@ -54,9 +67,7 @@ export class CreateTestScoreComponent implements OnInit {
let that = this let that = this
for (let y = 0, length = this.unitId.length; y < length; y++){ for (let y = 0, length = this.unitId.length; y < length; y++){
let element = this.unitId[y] let element = this.unitId[y]
element.score = 0
element.basicInfoScore = 0
element.basicInfoItemScore = 0
let result1 = await new Promise((resolve, reject) => { let result1 = await new Promise((resolve, reject) => {
this.http.get(`/api/Companies/${element.id}`).subscribe((data:any)=>{ this.http.get(`/api/Companies/${element.id}`).subscribe((data:any)=>{
let unitData = { let unitData = {
@ -85,7 +96,7 @@ export class CreateTestScoreComponent implements OnInit {
name: '单位地址',key: element.id+'单位地址',isLeaf:true,value:data.address name: '单位地址',key: element.id+'单位地址',isLeaf:true,value:data.address
}) : null }) : null
element.basicInfoNodes = []
element.basicInfoNodes.push(unitData) element.basicInfoNodes.push(unitData)
resolve(1) resolve(1)
@ -116,6 +127,7 @@ export class CreateTestScoreComponent implements OnInit {
buildingsData.name = data[i].name buildingsData.name = data[i].name
buildingsData.buildingType = data[i].buildingTypes[0].name buildingsData.buildingType = data[i].buildingTypes[0].name
buildingsData[0].buildingBasicGroups.forEach((y,m) => { buildingsData[0].buildingBasicGroups.forEach((y,m) => {
let propertyInfosArr = [] let propertyInfosArr = []
let tabledata let tabledata
if(y.type == 1){//如果是表格类 if(y.type == 1){//如果是表格类
@ -147,14 +159,38 @@ export class CreateTestScoreComponent implements OnInit {
}) })
y.tabledata = dest y.tabledata = dest
tabledata = dest tabledata = dest
y.tabledata[0].data.forEach((x,key) => { if(y.tabledata[0].propertyName == '罐区'){
if(x.propertyValue){
x.key = (Math.random()*10000000).toString(16).substr(0,4)+(new Date()).getTime()+Math.random().toString().substr(2,5) if(y.tabledata[1].propertyName != '储罐编号'){
x.isLeaf = true let index
x.name = x.propertyValue y.tabledata.forEach((element,key) => {
propertyInfosArr.push(x) if(element.propertyName == '储罐编号'){
index = key
}
})
y.tabledata[1] = y.tabledata.splice(index, 1, y.tabledata[1])[0];
} }
})
y.tabledata[0].data.forEach((x,key) => {
if(x.propertyValue){
x.key = (Math.random()*10000000).toString(16).substr(0,4)+(new Date()).getTime()+Math.random().toString().substr(2,5)
x.isLeaf = true
x.name = x.propertyValue + '-' + y.tabledata[1].data[key].propertyValue
propertyInfosArr.push(x)
}
})
}else{
y.tabledata[0].data.forEach((x,key) => {
if(x.propertyValue){
x.key = (Math.random()*10000000).toString(16).substr(0,4)+(new Date()).getTime()+Math.random().toString().substr(2,5)
x.isLeaf = true
x.name = x.propertyValue
propertyInfosArr.push(x)
}
})
}
}else{ }else{
y.propertyInfos.forEach((x,key) => { y.propertyInfos.forEach((x,key) => {
if(x.propertyValue){ if(x.propertyValue){
@ -191,9 +227,7 @@ export class CreateTestScoreComponent implements OnInit {
let that = this let that = this
for (let y = 0, length = this.unitId.length; y < length; y++){ for (let y = 0, length = this.unitId.length; y < length; y++){
let element = this.unitId[y] let element = this.unitId[y]
element.aroundScore = 0
element.aroundItemScore = 0
element.aroundNodes = []
//获得当前单位的单位毗邻 //获得当前单位的单位毗邻
let id = {companyId:element.id} let id = {companyId:element.id}
let result1 = await new Promise((resolve, reject) => { let result1 = await new Promise((resolve, reject) => {
@ -273,11 +307,8 @@ export class CreateTestScoreComponent implements OnInit {
async getKeySite(){ async getKeySite(){
let that = this let that = this
for (let y = 0, length = this.unitId.length; y < length; y++){ for (let y = 0, length = this.unitId.length; y < length; y++){
console.log("xiba")
let element = this.unitId[y] let element = this.unitId[y]
element.keySiteScore = 0
element.keySiteItemScore = 0
element.keySiteNodes = []
//获得单位重点部位 //获得单位重点部位
let id = {companyId:element.id} let id = {companyId:element.id}
@ -354,9 +385,7 @@ export class CreateTestScoreComponent implements OnInit {
let that = this let that = this
for (let y = 0, length = this.unitId.length; y < length; y++){ for (let y = 0, length = this.unitId.length; y < length; y++){
let element = this.unitId[y] let element = this.unitId[y]
element.funDivScore = 0
element.funDivItemScore = 0
element.funDivNodes = []
let id = {companyId:element.id} let id = {companyId:element.id}
//单位功能分区 //单位功能分区
let result1 = await new Promise((resolve, reject) => { let result1 = await new Promise((resolve, reject) => {
@ -432,9 +461,7 @@ export class CreateTestScoreComponent implements OnInit {
getFireFac(){ getFireFac(){
let that = this let that = this
this.unitId.forEach((element,index) =>{ this.unitId.forEach((element,index) =>{
element.fireFacScore = 0
element.fireFacItemScore = 0
element.fireFacNodes = []
let companyId = element.id let companyId = element.id
//获取单位级别消防设施 //获取单位级别消防设施
this.http.get(`/api/Companies/${companyId}`).subscribe((data:any)=>{ this.http.get(`/api/Companies/${companyId}`).subscribe((data:any)=>{
@ -531,13 +558,6 @@ export class CreateTestScoreComponent implements OnInit {
stopPropagation($event){ stopPropagation($event){
$event.stopPropagation() $event.stopPropagation()
} }
//模拟预案数据
planDatas:any = [
{name:'5楼电路故障灾情扑救',or:'上海总队',time:'2020-09-24',isOpen:'未公开',level:'总队',score:0},
{name:'6楼电路故障灾情扑救',or:'上海总队',time:'2020-09-24',isOpen:'未公开',level:'总队',score:0},
{name:'7楼电路故障灾情扑救',or:'上海总队',time:'2020-09-24',isOpen:'未公开',level:'总队',score:0}
]
defaultCheckedKeys = []; //指定选中复选框的树节点 key值 defaultCheckedKeys = []; //指定选中复选框的树节点 key值
defaultExpandedKeys = []; //展开指定的树节点 key值 defaultExpandedKeys = []; //展开指定的树节点 key值
defaultSelectedKeys = []; //指定选中的树节点 key值 defaultSelectedKeys = []; //指定选中的树节点 key值
@ -550,20 +570,24 @@ export class CreateTestScoreComponent implements OnInit {
calculateScore(key){ calculateScore(key){
//key代表第几个建筑 //key代表第几个建筑
//计算整个单位的总分 //计算整个单位的总分
this.unitId[key].score = this.unitId[key].basicInfoScore + this.unitId[key].aroundScore + this.unitId[key].keySiteScore + this.unitId[key].funDivScore + this.unitId[key].fireFacScore this.unitId[key].score = this.unitId[key].basicInfoScore + this.unitId[key].aroundScore + this.unitId[key].keySiteScore + this.unitId[key].funDivScore + this.unitId[key].fireFacScore
//计算整个试卷的总分
//计算整个试卷的总分 //计算整个试卷的总分
let examScore = 0 let examScore = 0
this.unitId.forEach(element => { this.unitId.forEach(element => {
examScore += element.score examScore += element.score
}) })
let examScore2 = 0 let examScore2 = 0
this.planDatas.forEach(element => { this.unitId.forEach(element => {
examScore2 += Number(element.score) let x = 0
}) if(element.planList){
this.examScore = examScore + examScore2 element.planList.forEach(i => {
x += i.score
})
}
examScore2 += Number(x)
})
this.examScore = examScore + examScore2
} }
//tree的选择事件 //tree的选择事件
@ -582,6 +606,7 @@ export class CreateTestScoreComponent implements OnInit {
}else{ }else{
this.unitId[key].basicInfoItemScore = 0 this.unitId[key].basicInfoItemScore = 0
} }
this.unitId[key].basicInfoSelectedNum = selectedNum.length
} }
if(event.node.origin.type == '四周毗邻' || (event.node.parentNode && event.node.parentNode.origin.type == '四周毗邻')){ if(event.node.origin.type == '四周毗邻' || (event.node.parentNode && event.node.parentNode.origin.type == '四周毗邻')){
let selectedNum = [] let selectedNum = []
@ -595,6 +620,7 @@ export class CreateTestScoreComponent implements OnInit {
}else{ }else{
this.unitId[key].aroundItemScore = 0 this.unitId[key].aroundItemScore = 0
} }
this.unitId[key].aroundSelectedNum = selectedNum.length
} }
if(event.node.origin.type == '重点部位' || (event.node.parentNode && event.node.parentNode.origin.type == '重点部位')){ if(event.node.origin.type == '重点部位' || (event.node.parentNode && event.node.parentNode.origin.type == '重点部位')){
let selectedNum = [] let selectedNum = []
@ -608,6 +634,7 @@ export class CreateTestScoreComponent implements OnInit {
}else{ }else{
this.unitId[key].keySiteItemScore = 0 this.unitId[key].keySiteItemScore = 0
} }
this.unitId[key].keySiteSelectedNum = selectedNum.length
} }
if(event.node.origin.type == '功能分区' || (event.node.parentNode && event.node.parentNode.origin.type == '功能分区')){ if(event.node.origin.type == '功能分区' || (event.node.parentNode && event.node.parentNode.origin.type == '功能分区')){
let selectedNum = [] let selectedNum = []
@ -621,6 +648,7 @@ export class CreateTestScoreComponent implements OnInit {
}else{ }else{
this.unitId[key].funDivItemScore = 0 this.unitId[key].funDivItemScore = 0
} }
this.unitId[key].funDivSelectedNum = selectedNum.length
} }
if(event.node.origin.type == '消防设施' || (event.node.parentNode && event.node.parentNode.origin.type == '消防设施')){ if(event.node.origin.type == '消防设施' || (event.node.parentNode && event.node.parentNode.origin.type == '消防设施')){
let selectedNum = [] let selectedNum = []
@ -634,6 +662,7 @@ export class CreateTestScoreComponent implements OnInit {
}else{ }else{
this.unitId[key].fireFacItemScore = 0 this.unitId[key].fireFacItemScore = 0
} }
this.unitId[key].fireFacSelectedNum = selectedNum.length
} }
} }
@ -721,290 +750,322 @@ export class CreateTestScoreComponent implements OnInit {
}); });
dialogRef.afterClosed().subscribe(result => { dialogRef.afterClosed().subscribe(result => {
console.log('The dialog was closed'); if(result){
if(this.unitId[this.selectedUnitIndex].planList){
this.unitId[this.selectedUnitIndex].planList.push(result)
}else{
this.unitId[this.selectedUnitIndex].planList = []
this.unitId[this.selectedUnitIndex].planList.push(result)
}
}
}); });
} }
//每条预案分数增加在试卷分数 //每条预案分数增加在试卷分数
planItemScore(item){ planItemScore(item){
//计算整个试卷的总分 //计算整个试卷的总分
console.log(item)
let examScore = 0 let examScore = 0
this.unitId.forEach(element => { this.unitId.forEach(element => {
examScore += element.score examScore += element.score
}) })
let examScore2 = 0 let examScore2 = 0
this.planDatas.forEach(element => { this.unitId.forEach(element => {
examScore2 += Number(element.score) let x = 0
if(element.planList){
element.planList.forEach(i => {
x += i.score
})
}
examScore2 += Number(x)
}) })
this.examScore = examScore + examScore2 this.examScore = examScore + examScore2
} }
//编辑每条预案试卷
edit(item){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('暂不能编辑','确定',config);
}
//删除每条预案试卷
deletePlan(item){
this.unitId[this.selectedUnitIndex].planList.forEach((element,key)=>{
if(item == element){
this.unitId[this.selectedUnitIndex].planList.splice(key,1)
}
})
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('删除成功','确定',config);
}
//保存 //保存
save(){ save(){
let copyDatas = JSON.parse(JSON.stringify(this.unitId)) let copyDatas = JSON.parse(JSON.stringify(this.unitId))
//循环每个建筑处理数据筛选出选中数据
//循环每个建筑处理数据筛选出选中数据 copyDatas.forEach(item => {
copyDatas.forEach(item => { //建筑的基本信息模块处理
//建筑的基本信息模块处理 item.basicInfoNodes.forEach((i,key) => {
item.basicInfoNodes.forEach((i,key) => { //如果顶级节点未选中则需要筛除没有选中的数据
//如果顶级节点未选中则需要筛除没有选中的数据 if(!i.checked){
if(!i.checked){ // console.log(i)
// console.log(i) let newArr = []
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
// newArr.length == 0 ? item.basicInfoNodes.splice(key,1) : i.children = newArr
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.basicInfoNodes = item.basicInfoNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
//将children处理成指定形式
if(i.name =='单位信息'){
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.name//题目名称
newChildrenItem.result = element.value//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
}else if(!i.tabledata){
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.propertyName//题目名称
newChildrenItem.result = element.propertyValue//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = element.propertyType//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
}else if(i.tabledata){//如果是表格类
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.propertyValue//题目名称
newChildrenItem.result = element.tag//代表第几行
newChildrenItem.physicalUnit = ''//计量单位
newChildrenItem.propertyType = ''//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
i.tabledata.forEach(element => {
let newData = []
element.data.forEach(ele => {
let newObj:any = {}
newObj.name = ele.propertyName//题目名称
newObj.result = ele.propertyValue//代表第几行
newObj.physicalUnit = ele.physicalUnit//计量单位
newObj.propertyType = ele.propertyType//输入框类型
newObj.tag = ele.tag//第几行
newData.push(newObj)
})
element.data = newData
})
}
delete i.selected
})
//建筑的四周毗邻模块处理
item.aroundNodes.forEach((i,key) => {
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.aroundNodes = item.aroundNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.title//题目名称
newChildrenItem.result = element.name//题目答案
newChildrenItem.physicalUnit = ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
delete i.selected
})
console.log(111,item)
//建筑的重点部位模块处理
item.keySiteNodes ? item.keySiteNodes.forEach((i,key) => {
i.selected ? i.selected = null : null
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.keySiteNodes = item.keySiteNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
i.tabledata = [{propertyName: "重点部位名称",data:[]},
{propertyName: "重点部位所在位置",data:[]},
{propertyName: "建筑结构",data:[]},
{propertyName: "使用性质",data:[]},
{propertyName: "主要危险性",data:[]}]
i.children.forEach(element => { i.children.forEach(element => {
i.tabledata[0].data.push({ element.checked ? newArr.push(element) : null
name: "重点部位名称", })
physicalUnit: '', let discard = []//即将废弃的数组
propertyType: 0, // newArr.length == 0 ? item.basicInfoNodes.splice(key,1) : i.children = newArr
result: element.name, newArr.length == 0 ? discard.push(i) : i.children = newArr
tag: "" item.basicInfoNodes = item.basicInfoNodes.filter(items => {
}) if (!discard.includes(items)) return items;
i.tabledata[1].data.push({
name: "重点部位所在位置",
physicalUnit: '',
propertyType: 0,
result: element.position,
tag: ""
})
i.tabledata[2].data.push({
name: "建筑结构",
physicalUnit: '',
propertyType: 0,
result: element.structure,
tag: ""
})
i.tabledata[3].data.push({
name: "使用性质",
physicalUnit: '',
propertyType: 0,
result: element.nature,
tag: ""
})
i.tabledata[4].data.push({
name: "主要危险性",
physicalUnit: '',
propertyType: 0,
result: element.hazards,
tag: ""
})
}) })
}
//将children处理成指定形式
if(i.name =='单位信息'){
let newChildren = [] let newChildren = []
i.children.forEach((element,index) => { i.children.forEach((element,index) => {
let newChildrenItem:any= {} let newChildrenItem:any= {}
// newChildrenItem.name = element.name//重点部位题目名称
// newChildrenItem.position = element.position//重点部位所在位置
// newChildrenItem.structure = element.structure//重点部位建筑结构
// newChildrenItem.nature = element.nature//重点部位使用性质
// newChildrenItem.hazards = element.hazards//重点部位主要危险性
newChildrenItem.name = element.name//题目名称 newChildrenItem.name = element.name//题目名称
newChildrenItem.result = element.position + element.structure + element.nature + element.hazards//题目答案 newChildrenItem.result = element.value//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位 newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = 0//输入框类型 newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem) newChildren.push(newChildrenItem)
}) })
i.children = newChildren i.children = newChildren
delete i.selected }else if(!i.tabledata){
}) : null
//建筑的功能分区模块处理
item.funDivNodes ? item.funDivNodes.forEach((i,key) => {
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.funDivNodes = item.funDivNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
i.tabledata = [{propertyName: "区域",data:[]},
{propertyName: "面积",data:[]},
{propertyName: "基本情况",data:[]}]
i.children.forEach(element => {
i.tabledata[0].data.push({
name: "区域",
physicalUnit: '',
propertyType: 0,
result: element.region,
tag: ""
})
i.tabledata[1].data.push({
name: "面积",
physicalUnit: '',
propertyType: 0,
result: element.area,
tag: ""
})
i.tabledata[2].data.push({
name: "基本情况",
physicalUnit: '',
propertyType: 0,
result: element.details,
tag: ""
})
})
let newChildren = [] let newChildren = []
i.children.forEach((element,index) => { i.children.forEach((element,index) => {
let newChildrenItem:any= {} let newChildrenItem:any= {}
// newChildrenItem.name = element.region//功能分区题目名称 newChildrenItem.name = element.propertyName//题目名称
// newChildrenItem.area = element.area//功能分区面积 newChildrenItem.result = element.propertyValue//题目答案
// newChildrenItem.details = element.details//功能分区基本情况
newChildrenItem.name = element.region//题目名称
newChildrenItem.result = element.area + element.details//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位 newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = 0//输入框类型 newChildrenItem.propertyType = element.propertyType//输入框类型
newChildren.push(newChildrenItem) newChildren.push(newChildrenItem)
}) })
i.children = newChildren i.children = newChildren
delete i.selected }else if(i.tabledata){//如果是表格类
}) : null
//建筑的数据核验模块处理
item.fireFacNodes ? item.fireFacNodes.forEach((i,key) => {
i.selected ? i.selected = null : null
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.fireFacNodes = item.fireFacNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
let newChildren = [] let newChildren = []
i.children.forEach((element,index) => { i.children.forEach((element,index) => {
let newChildrenItem:any= {} let newChildrenItem:any= {}
newChildrenItem.name = element.name//题目名称 newChildrenItem.name = element.propertyValue//题目名称
newChildrenItem.result = element.total//题目答案 newChildrenItem.result = element.tag//代表第几行
newChildrenItem.physicalUnit = ''//计量单位 newChildrenItem.physicalUnit = ''//计量单位
newChildrenItem.propertyType = 0//输入框类型 newChildrenItem.propertyType = ''//输入框类型
newChildren.push(newChildrenItem) newChildren.push(newChildrenItem)
}) })
i.children = newChildren i.children = newChildren
delete i.selected i.tabledata.forEach(element => {
}) : null let newData = []
}) element.data.forEach(ele => {
let newObj:any = {}
newObj.name = ele.propertyName//题目名称
newObj.result = ele.propertyValue//代表第几行
newObj.physicalUnit = ele.physicalUnit//计量单位
newObj.propertyType = ele.propertyType//输入框类型
newObj.tag = ele.tag//第几行
newData.push(newObj)
})
element.data = newData
})
}
delete i.selected
//循环每个建筑处理数据 })
console.log(copyDatas) //建筑的四周毗邻模块处理
item.aroundNodes.forEach((i,key) => {
let paperDataInfo = [] //如果顶级节点未选中则需要筛除没有选中的数据
copyDatas.forEach((item,key) =>{ if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.aroundNodes = item.aroundNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.title//题目名称
newChildrenItem.result = element.name//题目答案
newChildrenItem.physicalUnit = ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
delete i.selected
})
console.log(111,item)
//建筑的重点部位模块处理
item.keySiteNodes ? item.keySiteNodes.forEach((i,key) => {
i.selected ? i.selected = null : null
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.keySiteNodes = item.keySiteNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
i.tabledata = [{propertyName: "重点部位名称",data:[]},
{propertyName: "重点部位所在位置",data:[]},
{propertyName: "建筑结构",data:[]},
{propertyName: "使用性质",data:[]},
{propertyName: "主要危险性",data:[]}]
i.children.forEach(element => {
i.tabledata[0].data.push({
name: "重点部位名称",
physicalUnit: '',
propertyType: 0,
result: element.name,
tag: ""
})
i.tabledata[1].data.push({
name: "重点部位所在位置",
physicalUnit: '',
propertyType: 0,
result: element.position,
tag: ""
})
i.tabledata[2].data.push({
name: "建筑结构",
physicalUnit: '',
propertyType: 0,
result: element.structure,
tag: ""
})
i.tabledata[3].data.push({
name: "使用性质",
physicalUnit: '',
propertyType: 0,
result: element.nature,
tag: ""
})
i.tabledata[4].data.push({
name: "主要危险性",
physicalUnit: '',
propertyType: 0,
result: element.hazards,
tag: ""
})
})
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
// newChildrenItem.name = element.name//重点部位题目名称
// newChildrenItem.position = element.position//重点部位所在位置
// newChildrenItem.structure = element.structure//重点部位建筑结构
// newChildrenItem.nature = element.nature//重点部位使用性质
// newChildrenItem.hazards = element.hazards//重点部位主要危险性
newChildrenItem.name = element.name//题目名称
newChildrenItem.result = element.position + element.structure + element.nature + element.hazards//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
delete i.selected
}) : null
//建筑的功能分区模块处理
item.funDivNodes ? item.funDivNodes.forEach((i,key) => {
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.funDivNodes = item.funDivNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
i.tabledata = [{propertyName: "区域",data:[]},
{propertyName: "面积",data:[]},
{propertyName: "基本情况",data:[]}]
i.children.forEach(element => {
i.tabledata[0].data.push({
name: "区域",
physicalUnit: '',
propertyType: 0,
result: element.region,
tag: ""
})
i.tabledata[1].data.push({
name: "面积",
physicalUnit: '',
propertyType: 0,
result: element.area,
tag: ""
})
i.tabledata[2].data.push({
name: "基本情况",
physicalUnit: '',
propertyType: 0,
result: element.details,
tag: ""
})
})
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
// newChildrenItem.name = element.region//功能分区题目名称
// newChildrenItem.area = element.area//功能分区面积
// newChildrenItem.details = element.details//功能分区基本情况
newChildrenItem.name = element.region//题目名称
newChildrenItem.result = element.area + element.details//题目答案
newChildrenItem.physicalUnit = element.physicalUnit || ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
delete i.selected
}) : null
//建筑的数据核验模块处理
item.fireFacNodes ? item.fireFacNodes.forEach((i,key) => {
i.selected ? i.selected = null : null
//如果顶级节点未选中则需要筛除没有选中的数据
if(!i.checked){
let newArr = []
i.children.forEach(element => {
element.checked ? newArr.push(element) : null
})
let discard = []//即将废弃的数组
newArr.length == 0 ? discard.push(i) : i.children = newArr
item.fireFacNodes = item.fireFacNodes.filter(items => {
if (!discard.includes(items)) return items;
})
}
let newChildren = []
i.children.forEach((element,index) => {
let newChildrenItem:any= {}
newChildrenItem.name = element.name//题目名称
newChildrenItem.result = element.total//题目答案
newChildrenItem.physicalUnit = ''//计量单位
newChildrenItem.propertyType = 0//输入框类型
newChildren.push(newChildrenItem)
})
i.children = newChildren
delete i.selected
}) : null
})
//将筛选出来的数据变为服务器提交数据
let paperDataInfo = []
copyDatas.forEach((item,key) =>{
paperDataInfo[key] = {} paperDataInfo[key] = {}
paperDataInfo[key].id = null paperDataInfo[key].id = null
paperDataInfo[key].paperId = null paperDataInfo[key].paperId = null
@ -1019,19 +1080,48 @@ export class CreateTestScoreComponent implements OnInit {
paperDataInfo[key].functionalDivisionScore = item.funDivScore paperDataInfo[key].functionalDivisionScore = item.funDivScore
paperDataInfo[key].facilityData = item.fireFacNodes ? JSON.stringify(item.fireFacNodes) : '[]' paperDataInfo[key].facilityData = item.fireFacNodes ? JSON.stringify(item.fireFacNodes) : '[]'
paperDataInfo[key].facilityScore = item.fireFacScore paperDataInfo[key].facilityScore = item.fireFacScore
}) })
console.log(paperDataInfo)
const dialogRef = this.dialog.open(FinishDialog, {
width: '650px',
data: paperDataInfo
});
dialogRef.afterClosed().subscribe(result => { // console.log(123456,paperDataInfo)
console.log('The dialog was closed'); //判断是否存在总分填写后没有勾选 或者勾选了没有填写总分的情况
paperDataInfo.forEach(element => {
//判断存在总分填写后没有勾选题目
if( (element.basicInfoScore != 0 && JSON.parse(element.basicInfoData).length == 0) ||
(element.adjoinScore != 0 && JSON.parse(element.adjoinData).length == 0) ||
(element.importLocationScore != 0 && JSON.parse(element.importLocationData).length == 0) ||
(element.functionalDivisionScore != 0 && JSON.parse(element.functionalDivisionData).length == 0) ||
(element.facilityScore != 0 && JSON.parse(element.facilityData).length == 0) ){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('存在填写过总分,但未勾选题目的分组','确定',config);
return
}else
//勾选了题目存在没有填写总分
if(
(element.basicInfoScore == 0 && JSON.parse(element.basicInfoData).length != 0) ||
(element.adjoinScore == 0 && JSON.parse(element.adjoinData).length != 0) ||
(element.importLocationScore == 0 && JSON.parse(element.importLocationData).length != 0) ||
(element.functionalDivisionScore == 0 && JSON.parse(element.functionalDivisionData).length != 0) ||
(element.facilityScore == 0 && JSON.parse(element.facilityData).length != 0) ){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('存在勾选过题目,但未填写总分的分组','确定',config);
return
}else{
const dialogRef = this.dialog.open(FinishDialog, {
width: '650px',
data: paperDataInfo
});
dialogRef.afterClosed().subscribe(result => {
});
}
});
})
} }
//上一步 //上一步
goBack(){ goBack(){
@ -1069,7 +1159,13 @@ export class AddPlanDialog {
}); });
dialogRef.afterClosed().subscribe(result => { dialogRef.afterClosed().subscribe(result => {
this.dialogRef.close(); if(result){
console.log(1111111,result)
this.dialogRef.close(result);
}else{
this.dialogRef.close();
}
}); });
} }
} }
@ -1105,7 +1201,8 @@ export class AddPlanTwoDialog {
companyId:this.data.companyData.companyData.id companyId:this.data.companyData.companyData.id
}}).subscribe((data:any) => { }}).subscribe((data:any) => {
data.items.forEach(item => { data.items.forEach(item => {
item.planType == 1 ? planArr.push(item) : null //二维预案并且审核通过
(item.planType == 1 && item.auditStatus == 2) ? planArr.push(item) : null
}) })
this.dataSource = planArr this.dataSource = planArr
}) })
@ -1118,32 +1215,37 @@ export class AddPlanTwoDialog {
confirm(){ confirm(){
if(this.planType){//如果选择的是已存在预案 if(this.planType){//如果选择的是已存在预案
if(this.selectedRadioData){ if(this.selectedRadioData){
this.dialogRef.close(); this.dialogRef.close(this.selectedRadioData);
sessionStorage.setItem('companyName',this.data.companyData.companyData.name) sessionStorage.setItem('companyName',this.data.companyData.companyData.name)
sessionStorage.setItem('planId',this.selectedRadioData.id) sessionStorage.setItem('planId',this.selectedRadioData.id)
sessionStorage.setItem('buildingTypeId',this.data.companyData.companyData.buildingTypes[0].id) sessionStorage.setItem('buildingTypeId',this.data.companyData.companyData.buildingTypes[0].id)
sessionStorage.setItem('companyId',this.data.companyData.companyData.id) sessionStorage.setItem('companyId',this.data.companyData.companyData.id)
window.open('/canvasTool') window.open('/canvasTool?openType=1')
}else{ }else{
const config = new MatSnackBarConfig(); if(this.dataSource.length == 0){
config.verticalPosition = 'top'; this.dialogRef.close();
config.duration = 3000 }else{
this.snackBar.open('请选择要添加的预案','确定',config); const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('请选择要添加的预案','确定',config);
}
} }
}else{//如果选择的是自定义预案 }else{//如果选择的是自定义预案
let level = sessionStorage.getItem('level') let level = sessionStorage.getItem('level')
let body = { let body = {
id: "", id: null,
name: this.customPlanName, name: this.customPlanName,
planType:1, planType:1,
planMode: 2, planMode: 2,
planLevel:Number(level), planLevel:Number(level),
url: "", url: null,
attachmentUrls: null attachmentUrls: null
} }
this.http.post("/api/PlanComponents2D",body,{params:{ this.http.post("/api/ExamPlanComponents2D",body,{params:{
companyId : this.data.companyData.companyData.id companyId : this.data.companyData.companyData.id
}}).subscribe((data:any)=>{ }}).subscribe((data:any)=>{
// console.log("创建成功") // console.log("创建成功")
@ -1152,7 +1254,7 @@ export class AddPlanTwoDialog {
sessionStorage.setItem("companyId",this.data.companyData.companyData.id) sessionStorage.setItem("companyId",this.data.companyData.companyData.id)
sessionStorage.setItem("buildingTypeId",this.data.companyData.companyData.buildingTypes[0].id) sessionStorage.setItem("buildingTypeId",this.data.companyData.companyData.buildingTypes[0].id)
sessionStorage.setItem("editable","1") sessionStorage.setItem("editable","1")
window.open('/canvasTool') window.open('/canvasTool?openType=2')
}) })
} }
} }

2
src/app/examiner/create-test-score/lookTreeNode.html

@ -14,7 +14,7 @@
<td *ngFor="let item of data.tabledata">{{item.propertyName}}</td> <td *ngFor="let item of data.tabledata">{{item.propertyName}}</td>
</tr> </tr>
<tr *ngFor="let item of data.tabledata[0].data;let key = index"> <tr *ngFor="let item of data.tabledata[0].data;let key = index">
<td *ngFor="let i of data.tabledata">{{i.data[key]. propertyValue}}</td> <td *ngFor="let i of data.tabledata">{{i.data[key]. propertyValue ? i.data[key]. propertyValue : '无'}}</td>
</tr> </tr>
</table> </table>

7
src/app/examiner/examiner-index/examiner-index.component.ts

@ -4,7 +4,7 @@
* @Author: sueRimn * @Author: sueRimn
* @Date: 2020-12-11 09:06:03 * @Date: 2020-12-11 09:06:03
* @LastEditors: sueRimn * @LastEditors: sueRimn
* @LastEditTime: 2020-12-20 10:28:13 * @LastEditTime: 2020-12-20 10:31:09
*/ */
import { Component, OnInit, ViewChild, Inject,Input } from '@angular/core'; import { Component, OnInit, ViewChild, Inject,Input } from '@angular/core';
import {HttpClient} from '@angular/common/http' import {HttpClient} from '@angular/common/http'
@ -167,9 +167,7 @@ export class ExaminerIndexComponent implements OnInit {
this.http.get("/api/Papers",{params:paramsdata}).subscribe((data:any)=>{ this.http.get("/api/Papers",{params:paramsdata}).subscribe((data:any)=>{
this.tabledataSource=data.items this.tabledataSource=data.items
this.length=data.totalCount this.length=data.totalCount
console.log(this.tabledataSource)
}) })
//console.log(this.tabledataSource)
} }
//获取消防救援对信息 //获取消防救援对信息
getHelp(){ getHelp(){
@ -186,7 +184,6 @@ export class ExaminerIndexComponent implements OnInit {
SortType:'' SortType:''
} }
this.http.get("/api/ExamUsers",{params:paramsdata}).subscribe((data:any)=>{ this.http.get("/api/ExamUsers",{params:paramsdata}).subscribe((data:any)=>{
console.log(data)
this.helpName=data.items this.helpName=data.items
}) })
} }
@ -240,7 +237,7 @@ export class ExaminerIndexComponent implements OnInit {
} }
//新增考题跳转 //新增考题跳转
newExamination(){ newExamination(){
this.router.navigate(['/home/examiner-new-one']) this.router.navigate(['/home/createexam-index/examiner-new-one'])
} }
//辖区中队div是否显示 //辖区中队div是否显示
isorganizationbox:boolean = false isorganizationbox:boolean = false

7
src/app/examiner/examiner-routing.ts

@ -15,14 +15,11 @@ import { MarkPapersTwoComponent } from './mark-papers-two/mark-papers-two.compon
import { StatisticAnalysisComponent } from './statistic-analysis/statistic-analysis.component' import { StatisticAnalysisComponent } from './statistic-analysis/statistic-analysis.component'
const routes: Routes = [ const routes: Routes = [
// { path: '', component:CreateExamComponent }
{ path: 'createexam-index', component:ExaminerIndexComponent }, { path: 'createexam-index', component:ExaminerIndexComponent },
{ path: 'examiner-new-one', component:ExaminerNewOneComponent }, { path: 'createexam-index/examiner-new-one', component:ExaminerNewOneComponent },
{ path: 'mark-papers-index',component:MarkPapersIndexComponent}, { path: 'mark-papers-index',component:MarkPapersIndexComponent},
{ path: 'mark-papers-two',component:MarkPapersTwoComponent}, { path: 'mark-papers-index/mark-papers-two',component:MarkPapersTwoComponent},
{ path: 'statistic-anaily',component:StatisticAnalysisComponent} { path: 'statistic-anaily',component:StatisticAnalysisComponent}
//{ path: 'createexam-index', component:ExaminerIndexComponent },
] ]
@NgModule({ @NgModule({
imports: [RouterModule.forChild(routes)], imports: [RouterModule.forChild(routes)],

2
src/app/examiner/mark-papers-index/mark-papers-index.component.ts

@ -48,7 +48,7 @@ export class MarkPapersIndexComponent implements OnInit {
//点击阅卷跳转 //点击阅卷跳转
markTwo(e){ markTwo(e){
console.log(e) console.log(e)
this.router.navigate(['/home/mark-papers-two'],{queryParams:{'level':e}}) this.router.navigate(['/home/mark-papers-index/mark-papers-two'],{queryParams:{'level':e}})
} }
} }

1
src/app/http-interceptors/base-interceptor.ts

@ -46,6 +46,7 @@ export class BaseInterceptor implements HttpInterceptor {
// 用户认证失败返回登录页 // 用户认证失败返回登录页
if (error.status === 401||error.status === 614) { if (error.status === 401||error.status === 614) {
sessionStorage.clear() sessionStorage.clear()
localStorage.clear()
this.router.navigate(['/login']) this.router.navigate(['/login'])
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
config.verticalPosition = 'top'; config.verticalPosition = 'top';

1
src/app/http-interceptors/cache-token.service.ts

@ -25,6 +25,7 @@ export class CacheTokenService {
sessionStorage.setItem("roleType",data.roleType); sessionStorage.setItem("roleType",data.roleType);
sessionStorage.setItem("token",data.token); sessionStorage.setItem("token",data.token);
sessionStorage.setItem("refreshToken",data.refreshToken); sessionStorage.setItem("refreshToken",data.refreshToken);
sessionStorage.setItem("level",data.level);
}) })
} else { this.delete() } } else { this.delete() }
},18*60*1000) },18*60*1000)

14
src/app/navigation/adddatabank.html

@ -1,14 +0,0 @@
<form (ngSubmit)="onSubmit(form.value)" #form="ngForm" class="example-container">
<mat-form-field>
<input matInput id="name" name="name" type='text'
required
ngModel #name="ngModel" placeholder="请输入资料库名称">
</mat-form-field>
<div class="btn">
<button type="submit" class="savebtn" mat-raised-button color="primary" [disabled]='form.invalid'>确定</button>
<button type="button" mat-button (click)="onNoClick()" mat-raised-button>取消</button>
</div>
</form>

14
src/app/navigation/editdatabankname.html

@ -1,14 +0,0 @@
<form (ngSubmit)="onSubmit(form.value)" #form="ngForm" class="example-container">
<mat-form-field>
<input matInput id="name" name="name" type='text'
required
[(ngModel)]="dataBankName" placeholder="修改资料库名称">
</mat-form-field>
<div class="btn">
<button type="submit" class="savebtn" mat-raised-button color="primary" [disabled]='form.invalid'>确定</button>
<button type="button" mat-button (click)="onNoClick()" mat-raised-button>取消</button>
</div>
</form>

14
src/app/navigation/navigation.component.html

@ -7,7 +7,7 @@
* @LastEditTime: 2020-12-15 14:32:13 * @LastEditTime: 2020-12-15 14:32:13
--> -->
<mat-sidenav-container class="example-container" autosize [class.myapp-dark-theme]="darktheme"> <mat-sidenav-container class="example-container" autosize>
<mat-sidenav #drawer class="example-sidenav" mode="side" opened="true" color="primary" style="overflow-x: hidden;"> <mat-sidenav #drawer class="example-sidenav" mode="side" opened="true" color="primary" style="overflow-x: hidden;">
<div class="backtopleft"> <div class="backtopleft">
<img src="../../assets/images/backleft.png" style="height: 60px;width: 93px;"> <img src="../../assets/images/backleft.png" style="height: 60px;width: 93px;">
@ -22,7 +22,7 @@
</div> </div>
</div> </div>
<div class="navbox"> <div class="navbox">
<ul class="teacher"> <ul class="teacher" *ngIf="roleType == '1'">
<li [routerLink]="['/home/createexam-index']" routerLinkActive="clickStyle"> <li [routerLink]="['/home/createexam-index']" routerLinkActive="clickStyle">
<img src="../../assets/images/found.png" style="background-color: #fff;"><label>创建考试</label> <img src="../../assets/images/found.png" style="background-color: #fff;"><label>创建考试</label>
</li> </li>
@ -33,6 +33,14 @@
<img src="../../assets/images/Statistics.png" style="background-color: #07CDCF;"><label>统计分析</label> <img src="../../assets/images/Statistics.png" style="background-color: #07CDCF;"><label>统计分析</label>
</li> </li>
</ul> </ul>
<ul class="teacher" *ngIf="roleType == '0'">
<li [routerLink]="['/home/teachear']" routerLinkActive="clickStyle">
<label>考官管理</label>
</li>
<li [routerLink]="['/home/examinee']" routerLinkActive="clickStyle">
<label>考生管理</label>
</li>
</ul>
<img style="width: 191px;height: 113px; position: absolute; bottom: 0;" src="../../assets/images/backbottom.png"> <img style="width: 191px;height: 113px; position: absolute; bottom: 0;" src="../../assets/images/backbottom.png">
</div> </div>
@ -40,7 +48,7 @@
<div class="example-sidenav-content"> <div class="example-sidenav-content">
<div style="height: 60px; min-height: 60px;"> <div style="height: 60px; min-height: 60px;">
<app-tabbar (toggleDarkTheme)="switchTheme($event)" (defaulttheme)="defaulttheme()" (redtheme)="redtheme()"></app-tabbar> <app-tabbar></app-tabbar>
</div> </div>
<div style="flex: 1; overflow: hidden;"> <div style="flex: 1; overflow: hidden;">
<router-outlet></router-outlet> <router-outlet></router-outlet>

70
src/app/navigation/navigation.component.ts

@ -5,7 +5,6 @@ import { FormControl } from '@angular/forms';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog'; import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { IsLoginService } from '../is-login.service' import { IsLoginService } from '../is-login.service'
import { AllFileComponent } from '../ui/all-file/all-file.component';
import { ComponentServiceService } from '../component-service.service'; import { ComponentServiceService } from '../component-service.service';
import { Router,ActivatedRoute } from '@angular/router' import { Router,ActivatedRoute } from '@angular/router'
@Component({ @Component({
@ -17,72 +16,7 @@ export class NavigationComponent implements OnInit {
constructor(private router:Router,public emitService: ComponentServiceService,public navmenus:CacheTokenService,private http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar,public islogin:IsLoginService) { } constructor(private router:Router,public emitService: ComponentServiceService,public navmenus:CacheTokenService,private http: HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar,public islogin:IsLoginService) { }
isAdmin:boolean = false roleType = sessionStorage.getItem('roleType')
ngOnInit() { ngOnInit() {}
// if(sessionStorage.getItem("roleType") == "0"){
// this.isAdmin = true
// }
}
darktheme = false;//黑夜主题
switchTheme (dark) { this.darktheme = dark; }
defaulttheme () { this.darktheme = false }
redtheme () { this.darktheme = true}
}
//新增资料库
@Component({
selector: 'adddatabank',
templateUrl: './adddatabank.html',
styleUrls: ['./navigation.component.scss']
})
export class AddDataBank {
myControl = new FormControl();
constructor(private http: HttpClient,public dialogRef: MatDialogRef<AddDataBank>,@Inject(MAT_DIALOG_DATA) public data,public snackBar: MatSnackBar) {}
onNoClick(): void {
this.dialogRef.close();
}
onSubmit(value){
if ( value.name.includes('/') ) {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('名称不允许有特殊字符','确定',config);
} else {
this.dialogRef.close(value);
}
}
} }
//更改资料库名称
@Component({
selector: 'editdatabankname',
templateUrl: './editdatabankname.html',
styleUrls: ['./navigation.component.scss']
})
export class EditDataBankName {
myControl = new FormControl();
constructor(private http: HttpClient,public dialogRef: MatDialogRef<EditDataBankName>,@Inject(MAT_DIALOG_DATA) public data,public snackBar: MatSnackBar) {}
dataBankName:any = this.data.name//要修改的资料库原名称
onNoClick(): void {
this.dialogRef.close();
}
onSubmit(value){
if ( value.name.includes('/') ) {
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('名称不允许有特殊字符','确定',config);
} else {
this.dialogRef.close(value);
}
}
}

6
src/app/navigation/navigation.module.ts

@ -1,6 +1,6 @@
import { NgModule } from '@angular/core'; import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common'; import { CommonModule } from '@angular/common';
import { NavigationComponent, AddDataBank, EditDataBankName } from './navigation.component'; import { NavigationComponent } from './navigation.component';
import { MatIconModule } from '@angular/material/icon'; import { MatIconModule } from '@angular/material/icon';
import { MatSidenavModule } from '@angular/material/sidenav'; import { MatSidenavModule } from '@angular/material/sidenav';
import { RouterModule } from '@angular/router'; import { RouterModule } from '@angular/router';
@ -54,9 +54,7 @@ import {MatTreeModule} from '@angular/material/tree';
@NgModule({ @NgModule({
declarations: [ declarations: [
NavigationComponent, NavigationComponent,
TabbarComponent, TabbarComponent
AddDataBank,
EditDataBankName
], ],
imports: [ imports: [
CommonModule, CommonModule,

45
src/app/pipes/size.pipe.ts

@ -1,49 +1,4 @@
import { Pipe, PipeTransform } from '@angular/core'; import { Pipe, PipeTransform } from '@angular/core';
@Pipe({name: 'size'})
export class SizePipe implements PipeTransform {
transform(byte: number): string {
if(byte < 1048576 && byte != 0){//如果小于1M
let size = byte / 1024
return size.toFixed(1) + 'KB'
}
if(byte >= 1048576 && byte < 1073741824){//如果大于1M 小于1G
let size = byte / 1048576
return size.toFixed(1) + 'MB'
}
if(byte >= 1073741824){//如果大于1G
let size = byte / 1073741824
return size.toFixed(1) + 'GB'
}
if(byte < 1048576 && byte == 0){//如果是文件夹
return '--'
}
}
}
@Pipe({name: 'name'})
export class NamePipe implements PipeTransform {
transform(name: string): string {
let nameArr = name.split("/")
return nameArr[nameArr.length - 1]
}
}
@Pipe({name: 'name2'})
export class NamePipe2 implements PipeTransform {
transform(name: string): string {
let nameArr = name.split("/")
return nameArr[nameArr.length - 2]
}
}
@Pipe({name: 'name3'})
export class NamePipe3 implements PipeTransform {
transform(name: string): string {
if(name.charAt(name.length-1) == "/"){
return name.substr(0, name.length - 1).replace(/\//g,'>').substring(9,name.length)
}else{
return name.replace(/\//g,'>').substring(9,name.length)
}
}
}
@Pipe({name: 'testState'}) @Pipe({name: 'testState'})
export class testState implements PipeTransform { export class testState implements PipeTransform {
transform(name: string): string { transform(name: string): string {

12
src/app/tabbar/tabbar.component.ts

@ -25,16 +25,6 @@ import { MatSnackBarConfig, MatSnackBar } from '@angular/material/snack-bar';
}) })
export class TabbarComponent implements OnInit { export class TabbarComponent implements OnInit {
theme: boolean = true;
@Output()
toggle = new EventEmitter<void>();
@Output()
toggleDarkTheme = new EventEmitter<boolean>();
@Output()
defaulttheme = new EventEmitter<boolean>();
@Output()
redtheme = new EventEmitter<boolean>();
constructor(private http:HttpClient,private router:Router,private route:ActivatedRoute,public token:CacheTokenService,public dialog: MatDialog,public isLogin:IsLoginService,public snackBar: MatSnackBar,) { } constructor(private http:HttpClient,private router:Router,private route:ActivatedRoute,public token:CacheTokenService,public dialog: MatDialog,public isLogin:IsLoginService,public snackBar: MatSnackBar,) { }
ngOnInit() { ngOnInit() {
@ -50,6 +40,7 @@ export class TabbarComponent implements OnInit {
if(out) { if(out) {
this.http.post('/api/ExamAccounts/SignOut',{}).subscribe(data=>{ this.http.post('/api/ExamAccounts/SignOut',{}).subscribe(data=>{
sessionStorage.clear() sessionStorage.clear()
localStorage.clear()
this.token.delete() this.token.delete()
this.router.navigate(['/login']) this.router.navigate(['/login'])
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
@ -57,7 +48,6 @@ export class TabbarComponent implements OnInit {
config.duration = 3000 config.duration = 3000
this.snackBar.open('退出成功','确定',config); this.snackBar.open('退出成功','确定',config);
}) })
localStorage.removeItem("checkedWork")
} //if } //if
} }

159
src/app/ui/all-file/all-file.component.html

@ -1,159 +0,0 @@
<div class="topbox">
<div class="leftbox">
<div class="upload" (mouseenter)="uploadBtnEnter()" (mouseleave)="uploadBtnLeave()" *ngIf="isAdmin">
<div class="btn" style="width: 88px;height: 33px;" >
<mat-icon>backup</mat-icon><span> 上传</span>
<input type="file" (change)='selectFile($event)'>
</div>
<div class="openbtn" style="position: absolute;" *ngIf="isOpenUpload">
<div>
<span>上传文件</span>
<input type="file" (change)='selectFile($event)'>
</div>
<div>
<span>上传文件夹</span>
<input multiple webkitdirectory type="file" (change)='selectFiles($event)'>
</div>
</div>
</div>
<div class="newFile" (click)="createFolder()" *ngIf="isAdmin">
<mat-icon>create_new_folder</mat-icon> <span>新建文件夹</span>
</div>
<div class="newFile" style="width: 88px;" (click)='downLoadFile()'>
<mat-icon>save_alt</mat-icon> <span>下载</span>
</div>
<div class="newFile delete" style="width: 88px;" *ngIf="isAdmin" (click)="deleteFiles()" >
<mat-icon>delete</mat-icon> <span>删除</span>
</div>
<div class="progressBox" *ngIf="uploadisLoading">
<button mat-raised-button style="margin-right: 5px;width: 84px;height: 33px;" (click)="cancel()">取消上传</button>
<span style="font-size: 12px;">上传中...</span>
<mat-progress-bar mode="determinate" [value]="uploadProgress" class="progress"></mat-progress-bar>
</div>
<!-- <div class="progressBox" *ngIf="uploadisLoading2">
<button mat-raised-button style="margin-right: 5px;width: 84px;height: 33px;" (click)="cancel2()">取消上传</button>
<span style="font-size: 12px;">文件夹上传中...(当前上传 {{uploadProgress2}} )</span>
<mat-spinner determinate style="position: absolute;right: 0;right: 260px;bottom: -10px;" diameter=40></mat-spinner>
</div> -->
<div class="progressBox" *ngIf="downloadFile.isDownloading">
<!-- <button mat-raised-button style="margin-right: 5px;" (click)="cancelDowload()">取消下载</button> -->
<span style="font-size: 12px;">下载中...</span>
<mat-progress-bar mode="determinate" [value]="downloadFile.downloadProgress" class="progress" style="left: 52px;top: 13px;"></mat-progress-bar>
</div>
</div>
<!-- <div class="rightbox">
<div class="inputbox">
<input type="text" [(ngModel)]="searchData" (focus)="searchfocus($event)" (blur)="searchblur($event)">
<span class="cancel" *ngIf="isCancel" (click)="cancelbtn()"><mat-icon style="font-size: 16px;">cancel</mat-icon></span>
<span class="search" (click)="search()"><mat-icon>search</mat-icon></span>
</div>
</div> -->
</div>
<div class="titlebox">
<div class="titleleft">
<span class="goBack" (click)='backToTop()' *ngIf="selectedDataBank.includes('/')">返回根目录</span>
&nbsp;
<span class="goBack" (click)='backTominTop()' *ngIf="selectedDataBank.includes('/')">返回上一级</span>
<span style="margin: 0 3px;color: #c5d8f3;">|</span>
<span class="allFile" *ngIf="!selectedDataBank.includes('/')">全部文件</span>
<span style="margin: 0 3px;color: #c5d8f3;"></span>
<span class="allFile">{{selectedDataBank}}</span>
</div>
<div class="titleright">
<span>已全部加载,共 {{fileNum}} 个</span>
</div>
</div>
<div class="mainbox" style="overflow-y: auto;max-height: 80%;width: 100%;">
<table style="width: 100%;" mat-table [dataSource]="dataSource" matSort (matSortChange)="sortData($event)" class="mat-elevation-z8">
<ng-container matColumnDef="select">
<th style="width: 4%;" mat-header-cell *matHeaderCellDef>
<mat-checkbox (change)="$event ? masterToggle() : null"
[checked]="selection.hasValue() && isAllSelected()"
color="primary"
[indeterminate]="selection.hasValue() && !isAllSelected()">
</mat-checkbox>
</th>
<td mat-cell *matCellDef="let row">
<mat-checkbox (click)="clickCheckBox($event)"
color="primary"
(change)="$event ? selection.toggle(row) : null"
[checked]="selection.isSelected(row)">
</mat-checkbox>
</td>
</ng-container>
<ng-container matColumnDef="name">
<th style="width: 63%;" mat-header-cell *matHeaderCellDef> 文件名 </th>
<td mat-cell *matCellDef="let element">
<img *ngIf="element.type == 'pdf'" src="../../../assets/images/pdf.png" alt="">
<img *ngIf="element.type == 'jpeg' || element.type == 'jpg' || element.type == 'png' || element.type == 'gif' || element.type == 'svg'|| element.type == 'webp' || element.type == 'bmp'|| element.type == 'JPG'" src="../../../assets/images/img.png" alt="">
<img *ngIf="element.type == 'doc' || element.type == 'docx'" src="../../../assets/images/word.png" alt="">
<img *ngIf="element.type == 'xlsx'" src="../../../assets/images/excel.png" alt="">
<img *ngIf="element.type == 'zip'" src="../../../assets/images/zip.png" alt="">
<img *ngIf="element.type == 'MP4' || element.type == 'mp4'" src="../../../assets/images/video.png" alt="">
<img *ngIf="element.type == 'txt'" src="../../../assets/images/text.png" alt="">
<img *ngIf="element.type == 'pptx'" src="../../../assets/images/ppt.png" alt="">
<img *ngIf="element.type == 'cad' || element.type == 'CAD'" src="../../../assets/images/cad.png" alt="">
<img *ngIf="element.type == 'avi' || element.type == 'swf'|| element.type == 'mov'" src="../../../assets/images/video.png" alt="">
<img *ngIf="element.type == 'mp3' || element.type == 'aif' || element.type == 'wav' || element.type == 'flac'" src="../../../assets/images/music.png" alt="">
<img *ngIf="element.isDir" src="../../../assets/images/file.png" alt="">
<img *ngIf="element.type == 'gaopenche' || element.type == 'denggao'" src="../../../assets/images/gaopenche.gif" alt="">
<img *ngIf="element.type == 'jiqiren' || element.type == 'konghuqi'" src="../../../assets/images/shebei.jpg" alt="">
<img *ngIf="element.type == 'waifu' || element.type == 'neifu' || element.type == 'gong' || element.type == 'qiu'" src="../../../assets/images/sheshi.jpg" alt="">
<span *ngIf="element.isDir == false" class="filename" (click)="clickName($event,element)">
{{element.key | name}}
</span>
<span *ngIf="element.isDir == true" class="filename" (click)="clickName($event,element)">
{{element.key | name2}}
</span>
<span class="font3d" *ngIf="element.type == 'waifu' || element.type == 'neifu' || element.type == 'gong' || element.type == 'qiu' || element.type == 'gaopenche' || element.type == 'denggao' || element.type == 'jiqiren' || element.type == 'konghuqi'">
&nbsp; 3D &nbsp;
</span>
</td>
</ng-container>
<ng-container matColumnDef="weight">
<th mat-header-cell style="width: 15%;" *matHeaderCellDef> 大小 </th>
<td mat-cell *matCellDef="let element"> {{element.size | size}} </td>
</ng-container>
<ng-container matColumnDef="time">
<th style="width: 18%;" mat-header-cell *matHeaderCellDef mat-sort-header> 修改日期 </th>
<td mat-cell *matCellDef="let element"> {{element.lastModified | date:'yyyy-MM-dd HH:mm:ss'}} </td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"
(click)="clickCheckBoxLi($event,row)">
</tr>
</table>
<div class="nofiles" *ngIf="isNoFileTitle && selectedDataBank.includes('/')">
<span style="font-size: 14px;cursor: default;">您还没上传过文件哦~</span>
</div>
</div>
<div class="openSystem" *ngIf="!selectedDataBank.includes('/') && roleType =='1' " >
<a (click)="openteacher()" [href]='aHrefUnsafeLearnFun()'> <mat-icon style="vertical-align: middle; font-size: 24px;">account_balance</mat-icon> 战术授课<span>进入</span></a>
</div>
<div class="openSystem" *ngIf="!selectedDataBank.includes('/') && roleType == '2' ">
<a (click)="openlearn()" [href]='aHrefUnsafeLearnFun()'> <mat-icon style="vertical-align: middle; font-size: 24px;">account_balance</mat-icon> 战术学习<span>进入</span></a>
</div>
<div class="fixedBox" [hidden]="!uploadisLoading2">
<app-upload-files [thatFile]='this' #child></app-upload-files>
</div>
<ul>
<li *ngFor="let item of checkedAllFiles">{{item.key}}</li>
</ul>

265
src/app/ui/all-file/all-file.component.scss

@ -1,265 +0,0 @@
// @import "//at.alicdn.com/t/font_1863119_sy1f800ck9h.css";
.topbox{
height: 33px;
position: relative;
padding: 11px 10px;
.leftbox{
float: left;
display: flex;
.upload{
margin-left:16px;
background-color: #09AAFF;
border-radius: 4px;
cursor: pointer;
.btn{
position: relative;
color: white;
font-size: 13px;
mat-icon{
position: absolute;
top: 5px;
left: 10px;
}
span{
position: absolute;
left: 41px;
top: 9px;
}
input{
width: 88px;
height: 33px;
opacity: 0;
}
}
.openbtn{
background-color: white;
width: 86px;
text-align: center;
font-size: 12px;
border-radius: 0px 0px 4px 4px;
border: 1px solid #09AAFF;
div{
position: relative;
height: 30px;
line-height: 30px;
color: #09AAFF;
input{
width: 86px;
height: 30px;
opacity: 0;
position: absolute;
left: 0;
top: 0;
}
}
div:hover{
background-color: whitesmoke;
}
}
}
.newFile{
cursor: pointer;
background-color: #fff;
color: #09AAFF;
border: 1px solid #C3EAFF;
border-radius: 4px;
margin-left: 12px;
height: 33px;
line-height: 33px;
font-size: 13px;
position: relative;
width: 130px;
height: 33px;
float: left;
mat-icon{
position: absolute;
top: 5px;
left: 10px;
}
span{
position: absolute;
left: 41px;
}
}
.delete{
color: rgba(245, 59, 59);
border: 0.5px solid rgba(245, 59, 59);
// background-color: red;
// color: white;
}
}
.rightbox{
float: right;
width: 21%;
.inputbox{
float: right;
width: 21%;
min-width: 165px;
max-width: 315px;
height: 30px;
// margin: 12px 8px 12px 0;
position: relative;
right: 100px;
border-radius: 33px;
padding-left: 15px;
padding-right: 54px;
background: #f1f2f4;
border-radius: 33px;
input{
width: 100%;
height: 30px;
background: 0 0;
border: 0;
outline: 0;
line-height: 29px!important;
position: relative;
font-size: 12px;
}
.search{
cursor: pointer;
position: absolute;
right: 5px;
top: 3px;
color: grey;
}
.cancel{
cursor: pointer;
position: absolute;
right: 22px;
top: 5px;
color: #808080;
}
.cancel:hover{
mat-icon{
color: #808090;
;
}
}
}
}
//进度条
.progressBox{
position: absolute;
display: inline-block;
width: 550px;
left: 480px;
}
.progress{
position: absolute;
width: 350px;
top: 18px;
left: 160px;
}
}
.titlebox{
height: 30px;
line-height: 30px;
padding-left: 18px;
padding-right: 18px;
span{
font-size: 12px;
}
.titleleft{
float: left;
.goBack{
color: #09aaff;
}
.goBack:hover{
cursor: pointer;
text-decoration: underline;
}
}
.titleright{
float: right;
}
}
.mainbox{
// overflow-y: auto;
table{
td{
img{
position: relative;
width: 26px;
height: 26px;
top: 6px;
margin-right: 3px;
}
.filename:hover{
cursor: pointer;
color: #09aaff;
}
}
}
}
.btn{
width: 100%;
text-align: center;
button{
margin: 0 5px;
}
}
.font3d{
font-size: 13px;
background-color: #2cbe4e;
display: inline-block;
font-weight: 600;
line-height: 20px;
color: #fff;
text-align: center;
white-space: nowrap;
border-radius: 3px;
box-sizing: border-box;
}
//上传文件夹弹窗
.fixedBox {
position: fixed;
bottom: 3%;
right: 3%;
width: 500px;
}
.nofiles{
background: url("../../../assets/images/nofiles.png") no-repeat scroll center 0 transparent;
padding-top: 150px;
width: 488px;
position: absolute;
left: 50%;
top: 50%;
text-align: center;
margin: -78px 0 0 -244px;
}
.openSystem{
position: relative;
a{
color: rgba(0, 0, 0, 0.87);
font-size: 14px;
display: block;
width: 100%;
height: 48px;
line-height: 48px;
border-bottom: 1px solid rgba(0, 0, 0, 0.12);
padding-left: 4%;
background-color: white;
img{
position: relative;
width: 26px;
height: 26px;
top: 6px;
margin-right: 8px;
}
span{
position: absolute;
right: 31.3%;
line-height: 48px;
font-size: 14px;
}
}
}

25
src/app/ui/all-file/all-file.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { AllFileComponent } from './all-file.component';
describe('AllFileComponent', () => {
let component: AllFileComponent;
let fixture: ComponentFixture<AllFileComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ AllFileComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(AllFileComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

918
src/app/ui/all-file/all-file.component.ts

@ -1,918 +0,0 @@
import { Component, OnInit,ViewChild ,Inject,NgZone } from '@angular/core';
import { SelectionModel } from '@angular/cdk/collections';
import {MatSort} from '@angular/material/sort';
import {MatTableDataSource} from '@angular/material/table';
import { HttpClient,HttpHeaders } from '@angular/common/http';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { IsLoginService } from '../../is-login.service';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import {UploadFilesComponent} from '../upload-files/upload-files.component';
import { ComponentServiceService } from '../../component-service.service';
import { DomSanitizer } from "@angular/platform-browser";
@Component({
selector: 'app-all-file',
templateUrl: './all-file.component.html',
styleUrls: ['./all-file.component.scss'],
})
export class AllFileComponent {
displayedColumns: string[] = ['select', 'name', 'weight', 'time'];
dataSource:any = new MatTableDataSource;
constructor(private sanitizer: DomSanitizer,public emitService: ComponentServiceService,private http: HttpClient,public snackBar: MatSnackBar,public downloadFile:IsLoginService,public dialog: MatDialog,private zone: NgZone) { }
isCancel:boolean = false //搜索框的X是否显示
searchData:any = "搜索您的文件" //搜索框内容
isClickFile:boolean = false //是否点击过文件
isOpenUpload:boolean = false //是否移入上传按钮
isDelete:boolean = false //是否删除按钮
isNoFileTitle:boolean = false //无文件时提示
isAdmin:boolean = false //是否是管理员
selectedDataBank:string = '' //当前需要显示的资料库
fileNum:any = 0 //当前资料库文件数量
selection = new SelectionModel(true, []);
@ViewChild(MatSort) sort: MatSort;
@ViewChild( 'child',{static: false} ) child:UploadFilesComponent //上传文件夹子组件
oldDataSource:any; //原始表格数据
//表头排序
sortData (e) {
let data = this.oldDataSource.concat();
data.forEach(element => {
if(element.key.indexOf(".") != -1){
let typeArr = element.key.split('.')
element.type = typeArr[typeArr.length - 1]
element.newTime = new Date(element.lastModified).getTime()
}
});
if( e.direction=='asc' ) { //从小到大排序
data.sort( function(a,b) {
return a.newTime - b.newTime
} )
this.dataSource = new MatTableDataSource(data);
} else if ( e.direction=='desc' ) {//从大到小排序
data.sort( function(a,b) {
return b.newTime - a.newTime
} )
this.dataSource = new MatTableDataSource(data);
} else { //原始数据
this.dataSource = new MatTableDataSource(this.oldDataSource);
}
}
roleType:any
aHrefUnsafe:any //战术授课a标签 去除unsafe标志
ngOnInit(): void {
this.roleType = sessionStorage.getItem('roleType')
this.dataSource.sort = this.sort;
this.getALLFileList("支队级-主官")
// 接收发射过来的数据
this.emitService.eventEmit.subscribe((value: any) => {
this.getALLFileList(value)
this.selection.clear();
});
if(sessionStorage.getItem("roleType") == "0"){
this.isAdmin = true
}
}
aHrefUnsafeLearnFun(){
this.roleType = sessionStorage.getItem('roleType')
let username = sessionStorage.getItem('username')
let expires = sessionStorage.getItem('expires')
let realName = sessionStorage.getItem('realName')
let roleType = sessionStorage.getItem('roleType')
let token = sessionStorage.getItem('token')
let refreshToken = sessionStorage.getItem('refreshToken')
let aHref = `ax://startup?username=${username}&token=${token}&refreshToken=${refreshToken}&expires=${expires}&realname=${realName}&roleType=${roleType}`
this.aHrefUnsafe = this.sanitizer.bypassSecurityTrustUrl(aHref);
return this.aHrefUnsafe
}
//获得当前资料库的文件列表
getALLFileList(name){
this.selectedDataBank = name
let paramsdata = {
prefix : "allFiles/" + this.selectedDataBank + "/",
delimiter : "/"
}
this.http.get(`/api/Objects/drives`,{
params:paramsdata
}).subscribe((data:any) => {
this.selection.clear()
data.contents.forEach((item)=>{
let typeArr = item.key.split('.')
item.type = typeArr[typeArr.length - 1]
})
if(name.split('/')[1] == "装备"){
data.contents.unshift(
{ key: "装备车辆/高喷车",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "gaopenche"
},
{ key: "装备车辆/登高平台车",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "denggao"
},
{ key: "装备车辆/机器人",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "jiqiren"
},
{ key: "装备车辆/空气呼吸器",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "konghuqi"
}
)
}
if(name.split('/')[1] == "消防设施"){
data.contents.unshift(
{ key: "设备设施/外浮顶罐",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "waifu"
},
{ key: "设备设施/内浮顶罐",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "neifu"
},
{ key: "设备设施/拱顶罐",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "gong"
},
{ key: "设备设施/球罐",
lastModified: null,
eTag: null,
size: 0,
isDir: false,
type: "qiu"
}
)
}
this.oldDataSource = data.contents //保存表格数据
this.dataSource = new MatTableDataSource(data.contents);
this.fileNum = data.contents.length
if(data.contents.length == 0){
this.isNoFileTitle = true
}else{
this.isNoFileTitle = false
}
})
}
//判断是否全部选中
isAllSelected() {
const numSelected = this.selection.selected.length;
const numRows = this.dataSource.data.length;
return numSelected === numRows;
}
//控制全选按钮
masterToggle() {
this.isAllSelected() ? this.selection.clear() : this.dataSource.data.forEach(row => this.selection.select(row));
this.isAllSelected() ? this.isDelete = true : this.isDelete = false;
}
//搜索框获得焦点事件
searchfocus(e){
this.isCancel = true
if(e.target.value == "搜索您的文件"){
e.target.value = ""
}
}
//搜索框失去焦点事件
searchblur(e){
if(e.target.value == ""){
e.target.value = "搜索您的文件"
this.isCancel = false
}
}
//搜索框点击X事件
cancelbtn(){
this.getALLFileList(this.selectedDataBank)
this.searchData = "搜索您的文件"
this.isCancel = false
}
allFiles:any //搜索出来的全部文件
checkedAllFiles:any = []
//点击搜索
search(){
if(this.searchData != "搜索您的文件"){
this.http.get("/api/Objects/drives",{
params:{
prefix : "allFiles",
delimiter : ""
}
}).subscribe((data:any)=>{
this.allFiles = data.contents
this.allFiles.forEach(item=>{
if(item.key.indexOf(this.searchData) != -1){
this.checkedAllFiles.push(item)
}
})
// console.log(888888,data.contents)
},
err=>{
})
}
}
goback:any //记录上一级目录
//点击列表每一条的名字
clickName(e,item){
e.stopPropagation()
if(item.type == "jpg" || item.type == "png" || item.type == "bmp"|| item.type == "gif" || item.type == "jpeg"&& !item.isDir){
const dialogRef = this.dialog.open(ViewDetails, {//调用open方法打开对话框并且携带参数过去
data: {url:item.key,type:"img"}
});
this.downloadFile.handleData(item.key,"查看")
}else if(item.type == "mp4" || item.type == "MP4" && !item.isDir){
const dialogRef = this.dialog.open(ViewDetails, {//调用open方法打开对话框并且携带参数过去
width: '1400px',
height:'800px',
data: {url:item.key,type:"video"}
});
dialogRef.afterClosed().subscribe();
this.downloadFile.handleData(item.key,"查看")
}else if(item.type == "mp3" || item.type == "MP3"&& !item.isDir){
const dialogRef = this.dialog.open(ViewDetails, {//调用open方法打开对话框并且携带参数过去
width: '400px',
height:'108px',
data: {url:item.key,type:"mp3"}
});
dialogRef.afterClosed().subscribe();
this.downloadFile.handleData(item.key,"查看")
}else if(item.type == "pdf" && item.size < 20971520){
window.open("/api/Objects/drives/" + item.key)
this.downloadFile.handleData(item.key,"查看")
}else if(item.type == "pdf" && item.size > 20971520){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('暂不支持在线预览大于20M的pdf文件,请下载查看','确定',config)
}else if(item.type == "gaopenche"){
window.open("3dWidgets/GaoPenChe")
}else if(item.type == "denggao"){
window.open("3dWidgets/denggaoche")
}else if(item.type == "jiqiren"){
window.open("3dWidgets/jiqiren")
}else if(item.type == "konghuqi"){
window.open("3dWidgets/konghuqi")
}else if(item.type == "waifu"){
window.open("3dWidgets/waifudingguan")
}else if(item.type == "neifu"){
window.open("3dWidgets/neifudingguan")
}else if(item.type == "gong"){
window.open("3dWidgets/gongdingguan")
}else if(item.type == "qiu"){
window.open("3dWidgets/qiuguan")
}else if (item.isDir) {
//将allFiles后面的内容截取出来
this.selectedDataBank = item.key.substring(9, item.key.length - 1)
this.getALLFileList(this.selectedDataBank)
}else{
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('该文件类型暂不支持在线查看,请下载查看','确定',config)
}
}
//记录战术授课
openteacher(){
let key = `allFiles/${this.selectedDataBank}/战术授课/`
this.downloadFile.handleData(key,"进入")
}
//记录战术学习
openlearn(){
let key = `allFiles/${this.selectedDataBank}/战术学习/`
this.downloadFile.handleData(key,"进入")
}
//返回上一级目录
backTominTop(){
let topnum = this.gettoplist(this.selectedDataBank)
this.getALLFileList(topnum)
}
//上级目录产生函数
gettoplist(item){
let list = item
let listArr = list.split("/")
let listresult = ""
for(let i = 0;i < listArr.length - 1;i++){
listresult += listArr[i] + "/"
}
let listresult2 = listresult.substring(0, listresult.length - 1)
return listresult2
}
//上传按钮鼠标移入
uploadBtnEnter(){
this.isOpenUpload = true
}
//上传按钮鼠标移出
uploadBtnLeave(){
this.isOpenUpload = false
}
//点击每条的checkbox
clickCheckBox(e){
e.stopPropagation();
setTimeout(() => {
if(this.selection.selected.length != 0){
this.isDelete = true
} else{
this.isDelete = false
}
}, 0);
}
//点击每条的li
clickCheckBoxLi(e,row){
this.selection.toggle(row)
setTimeout(() => {
if(this.selection.selected.length != 0){
this.isDelete = true
} else{
this.isDelete = false
}
}, 0);
}
file:any //需要上传的文件
//input file 选择文件
selectFile (e) {
this.file = e.target.files[0] || null //上传的文件
this.http.get(`/api/ObjectMetadata/drives/${this.selectedDataBank}/${this.file.name}`).subscribe(
data=>{
var r = confirm(`已有同名文件,继续将替换该文件,是否替换?`);
if (r == true) {
this.startUploading()
}
},
err => {
this.startUploading()
}
)
}
fileArr:any
//上传文件夹
async selectFiles (e) {
this.fileArr = e.target.files || null //上传的文件
this.uploadisLoading2 = true
this.child.handleData() //子组件处理数据格式
let _this = this
for (var i = 0;i < this.fileArr.length; i++) {
let f = this.fileArr[i];
let lastIndex = f.webkitRelativePath.lastIndexOf("/")
let url = f.webkitRelativePath.substring(0, lastIndex)
let adddress = this.selectedDataBank + "/" + url
let filesnum = _this.fileArr.length
let result = await new Promise ((result,reject)=>{
this.startUploading2(f,adddress,result,reject,filesnum,this.selectedDataBank)
})
}
}
//上传文件
objectName2:any //上传对象名
uploadisLoading2:boolean = false //上传进度条显示
uploadProgress2:any
uploadId2:any; //上传分块上传事件编号
filesTag2:any = [] //每上传成功一个文件就往里面加一个标识
//e是上传的文件 selectedDataBank是需要上传的地址 包括 XXX资料库 + 文件夹路径
startUploading2 (e,selectedDataBank,result,reject,filesnum,selectedDataBank2) {
let file = e || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
this.uploadisLoading2 = true
this.uploadProgress2 = 0 + "/" + filesnum
this.child.uploading(file) //子组件 当前文件正在上传
if (file && fileSize<=shardSize) { //上传文件<=5MB时
let formData = new FormData()
formData.append("file",file)
this.http.post(`/api/Objects/drives/allFiles/${selectedDataBank2}`,formData).subscribe((data:any)=>{
this.objectName2 = data.objectName
this.filesTag2.push("data")
this.zone.run(() => {
  setTimeout(() => this.uploadProgress2 = this.filesTag2.length + "/" + filesnum, 0);
});
result("成功了")
this.child.endUpload(file) //子组件 当前文件上传成功
if(this.filesTag2.length == filesnum){
this.filesTag2 = [] //清空计数文件夹
this.uploadProgress2 = filesnum + "/" + filesnum
this.uploadisLoading2 = false
this.child.delete() //清空上传文件夹子组件数据
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('文件夹全部上传完毕','确定',config)
// 当全部循环完毕重新加载列表
this.getALLFileList(selectedDataBank2)
}
})
} else if (file && fileSize>shardSize) { //上传文件>5MB时,分块上传
let data = {fileName: file.name}
this.uploadisLoading2 = true
this.http.post(`/api/NewMultipartUpload/drives/allFiles/${selectedDataBank}`,{},{params:data}).subscribe((data:any)=>{ //初始化分段上传
this.objectName2 = data.objectName
this.uploadId2 = data.uploadId
this.subsectionUploading2(e,result,reject,filesnum,selectedDataBank2)
})
}
}
PartNumberETag2:any=[]; //每次返回需要保存的信息
//开始分段上传
async subsectionUploading2 (e,result,reject,filesnum,selectedDataBank2) {
let file = e || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
let allSlice = Math.ceil(fileSize / shardSize) //总文件/5MB===共分多少段
let _result = result
for (let i = 0;i < allSlice;i++) { //循环分段上传
let start = i * shardSize //切割文件开始位置
let end = Math.min(fileSize, start + shardSize); //切割文件结束位置
let formData = new FormData()
formData.append("file",file.slice(start, end))
//同步写法实现异步调用
let result = await new Promise((resolve, reject) => {
// await 需要后面返回一个 promise 对象
this.http.post(`/api/MultipartUpload/drives/${this.objectName2}?uploadId=${this.uploadId2}&partNumber=${i+1}`,formData).subscribe((data:any)=>{
let msg = {
"partNumber":data.partNumber || null,
"eTag": data.eTag || null}
resolve(msg) // 调用 promise 内置方法处理成功
})
});
this.PartNumberETag2.push(result)
if (this.PartNumberETag2.length === allSlice) {
this.endUploading2(e,_result,reject,filesnum,selectedDataBank2)
}
}//for循环
}
//完成分块上传
endUploading2 (e,result,reject,filesnum,selectedDataBank2) {
let data = this.PartNumberETag2
let paramsData = {uploadId:this.uploadId2}
this.http.post(`/api/CompleteMultipartUpload/drives/${this.objectName2}`,data,{params:paramsData}).subscribe(data=>{
this.filesTag2.push("data")
this.zone.run(() => {
  setTimeout(() => this.uploadProgress2 = this.filesTag2.length + "/" + filesnum, 0);
});
result("成功了")
this.child.endUpload(e) //子组件 当前文件上传成功
if(this.filesTag2.length == filesnum){
this.uploadProgress2 = filesnum + "/" + filesnum
this.uploadisLoading2 = false
this.filesTag2 = [] //清空计数文件夹
this.child.delete() //清空上传文件夹子组件数据
this.getALLFileList(selectedDataBank2)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('文件夹全部上传完毕','确定',config)
}
this.PartNumberETag2 =[] //清空保存返回的信息
})
}
//取消分块上传
cancel2 () {
this.http.delete(`/api/MultipartUpload/drives/${this.objectName2}?uploadId=${this.uploadId2}`).subscribe(data=>{
this.uploadisLoading2= false
this.fileArr = {}
this.PartNumberETag2 =[] //清空保存返回的信息
this.filesTag2 = [] //清空计数文件夹
this.child.delete() //清空上传文件夹子组件数据
this.getALLFileList(this.selectedDataBank)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('取消上传成功!','确定',config);
})
}
//新建文件夹
createFolder(){
const dialogRef = this.dialog.open(FolderDialog);
dialogRef.afterClosed().subscribe((data)=>{
if(data){
//创建空文件夹
this.http.post(`/api/Objects/drives/allFiles/${this.selectedDataBank}/${data.name}/`,{}).subscribe(data=>{
this.getALLFileList(this.selectedDataBank)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('新建文件夹成功','确定',config)
})
}
});
}
//返回顶级目录
backToTop () {
if (this.selectedDataBank.includes('/')) {
let arr = this.selectedDataBank.split('/')
this.selectedDataBank = arr[0]
this.getALLFileList(arr[0])
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('目前已是一级目录','确定',config)
}
}
//上传文件
objectName:any //上传对象名
uploadisLoading:boolean = false //上传进度条显示
uploadProgress:any = 0
uploadId:any; //上传分块上传事件编号
startUploading () {
let file = this.file || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
if (file && fileSize<=shardSize) { //上传文件<=5MB时
let formData = new FormData()
formData.append("file",file)
this.http.post(`/api/Objects/drives/allFiles/${this.selectedDataBank}`,formData).subscribe((data:any)=>{
this.objectName = data.objectName
this.getALLFileList(this.selectedDataBank)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传成功','确定',config)
})
} else if (file && fileSize>shardSize) { //上传文件>5MB时,分块上传
let data = {fileName: file.name}
this.uploadisLoading = true
this.http.post(`/api/NewMultipartUpload/drives/allFiles/${this.selectedDataBank}`,{},{params:data}).subscribe((data:any)=>{ //初始化分段上传
this.objectName = data.objectName
this.uploadId = data.uploadId
this.subsectionUploading()
})
}
}
PartNumberETag:any=[]; //每次返回需要保存的信息
//开始分段上传
async subsectionUploading () {
let file = this.file || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
let allSlice = Math.ceil(fileSize / shardSize) //总文件/5MB===共分多少段
for (let i = 0;i < allSlice;i++) { //循环分段上传
let start = i * shardSize //切割文件开始位置
let end = Math.min(fileSize, start + shardSize); //切割文件结束位置
let formData = new FormData()
formData.append("file",file.slice(start, end))
//同步写法实现异步调用
let result = await new Promise((resolve, reject) => {
// await 需要后面返回一个 promise 对象
this.http.post(`/api/MultipartUpload/drives/${this.objectName}?uploadId=${this.uploadId}&partNumber=${i+1}`,formData).subscribe((data:any)=>{
let msg = {
"partNumber":data.partNumber || null,
"eTag": data.eTag || null}
resolve(msg) // 调用 promise 内置方法处理成功
// console.log(2)
})
});
this.PartNumberETag.push(result)
this.uploadProgress = Number((i/allSlice).toFixed(2))*100
if (this.PartNumberETag.length === allSlice) {
this.uploadProgress = 100
this.endUploading()}
}//for循环
}
//完成分块上传
endUploading () {
let data = this.PartNumberETag;
let paramsData = {uploadId:this.uploadId};
this.http.post(`/api/CompleteMultipartUpload/drives/${this.objectName}`,data,{params:paramsData}).subscribe(data=>{
// console.log(3)
this.getALLFileList(this.selectedDataBank);
this.uploadProgress = 0;
this.uploadisLoading = false;
this.PartNumberETag =[]; //清空保存返回的信息
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000;
this.snackBar.open('上传成功','确定',config);
})
}
//取消分块上传
cancel () {
this.http.delete(`/api/MultipartUpload/drives/${this.objectName}?uploadId=${this.uploadId}`).subscribe(data=>{
this.uploadProgress = 0;
this.uploadisLoading = false;
this.PartNumberETag = []; //清空保存返回的信息
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000;
this.snackBar.open('取消上传成功!','确定',config);
})
}
isTrueDelete:any = ['基础知识','装备','技战术','消防设施','资料库']; //匹配内置一级目录 是否被选择删除
// 删除文件
deleteFiles(){
if (this.selection.selected.length != 0) {
let isDelete = confirm('您确定要删除选中文件吗')
let arr = []
if (isDelete) {
let arrList = [] //匹配到 禁止删除的 目录
this.selection.selected.forEach((element)=>{
let data = element.key.split("/");
this.isTrueDelete.forEach(elements => {
if (elements==data[data.length-2] && data.length-2==2 && !data[data.length-1]) {
arrList.push('true')
}
});
})
if (arrList.length) {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('内置文件夹不允许删除','确定',config);
} else {
this.selection.selected.forEach( async (element,index) => {
let result = await new Promise((result,reject)=>{
if(element.isDir){ //如果是文件夹
let paramsdata:any = {
prefix : element.key,
recursive : true
}
this.http.delete(`/api/Objects/drives`,{
params:paramsdata
}).subscribe(data=>{
arr.push("删除成功了")
if (arr.length == this.selection.selected.length) {
this.getALLFileList(this.selectedDataBank)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('删除文件成功','确定',config);
this.selection.clear()
this.isDelete = false
}
result(data)
})
}else{
this.http.delete(`/api/Objects/drives/${element.key}`).subscribe(data=>{
arr.push("删除成功了")
if (arr.length == this.selection.selected.length) {
this.getALLFileList(this.selectedDataBank)
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('删除文件成功','确定',config);
this.selection.clear()
this.isDelete = false
}
result(data)
})
}
})
});
} // if arrList
}
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('请选择要删除的文件','确定',config);
}
}
// deleteFiles(){
// if (this.selection.selected.length == 1) {
// let isDelete = confirm('您确定要删除吗')
// let arr = []
// if (isDelete) {
// let item = this.selection.selected[0]
// if(item.isDir){//如果是文件夹
// let paramsdata:any = {
// prefix : item.key,
// recursive : true
// }
// this.http.delete(`/api/Objects/drives`,{
// params:paramsdata
// }).subscribe(data=>{
// this.getALLFileList(this.selectedDataBank)
// const config = new MatSnackBarConfig();
// config.verticalPosition = 'top';
// config.duration = 3000
// this.snackBar.open('删除文件夹成功','确定',config);
// this.selection.clear()
// this.isDelete = false
// })
// }
// else{
// this.http.delete(`/api/Objects/drives/${item.key}`).subscribe(data=>{
// this.getALLFileList(this.selectedDataBank)
// const config = new MatSnackBarConfig();
// config.verticalPosition = 'top';
// config.duration = 3000
// this.snackBar.open('删除文件成功','确定',config);
// this.selection.clear()
// this.isDelete = false
// })
// }
// }
// }
// if (this.selection.selected.length == 0) {
// const config = new MatSnackBarConfig();
// config.verticalPosition = 'top';
// config.duration = 3000
// this.snackBar.open('请选择要删除的文件','确定',config);
// }
// if (this.selection.selected.length > 1) {
// const config = new MatSnackBarConfig();
// config.verticalPosition = 'top';
// config.duration = 3000
// this.snackBar.open('暂不支持批量删除','确定',config);
// }
// }
//下载↓
selectDownloadFile:any; //选择下载的文件
download:any; //下载文件元数据
downloadisLoading:boolean = false; //进度条loading加载
downloadProgress:number = 0; //进度条进度
downLoadFile(){
if (this.selection.selected.length === 1) {
this.selectDownloadFile = this.selection.selected[0]
if(this.selectDownloadFile.isDir){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('文件夹不支持下载','确定',config)
}else{
this.http.get('/api/ObjectMetadata/drives/' + this.selectDownloadFile.key).subscribe(data=>{
// console.log(123,data)
this.download = data
this.downloadFile.download(this.download)
})
}
} else if (this.selection.selected.length>1) {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('暂时不支持批量下载','确定',config)
} else if (this.selection.selected.length == 0) {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('请选择要下载的文件','确定',config)
}
}
}
//查看图片大图和视频
@Component({
selector: 'viewdetails',
templateUrl: './viewdetails.html',
styleUrls: ['./all-file.component.scss']
})
export class ViewDetails {
// myControl = new FormControl();
//注入MatDialogRef,可以用来关闭对话框
//要访问对话框组件中的数据,必须使用MAT_DIALOG_DATA注入令牌
constructor(private http: HttpClient,public dialogRef: MatDialogRef<ViewDetails>,@Inject(MAT_DIALOG_DATA) public data) {}
Url:string
onNoClick(): void {
this.dialogRef.close();
}
ngOnInit(): void {
this.Url = "/api/Objects/drives/" + this.data.url
}
closeDialog(){
this.dialogRef.close();
}
}
@Component({
selector: 'folderdalog',
templateUrl: './folderdalog.html',
styleUrls: ['./all-file.component.scss']
})
export class FolderDialog {
constructor(private http: HttpClient,public dialogRef: MatDialogRef<FolderDialog>,@Inject(MAT_DIALOG_DATA) public data) {}
newFolderName:string
onNoClick(): void {
this.dialogRef.close();
}
ngOnInit(): void {
var myDate = new Date();
var year = myDate.getFullYear();
var month = myDate.getMonth();
var day = myDate.getDate();
var hour = myDate.getHours(); //获取当前小时数(0-23)
var minutes = myDate.getMinutes(); //获取当前分钟数(0-59)
var seconds = myDate.getSeconds(); //获取当前秒数(0-59)
var data = year + '' + month + day + hour + minutes + seconds
this.newFolderName = "新建文件夹_" + data;
}
onSubmit(value){
this.dialogRef.close(value);
}
}

14
src/app/ui/all-file/folderdalog.html

@ -1,14 +0,0 @@
<form (ngSubmit)="onSubmit(form.value)" #form="ngForm" class="example-container">
<mat-form-field>
<input matInput id="name" name="name" type='text'
required
style="font-size: 12px;"
onfocus="this.select()"
[(ngModel)]="newFolderName" placeholder="创建文件夹">
</mat-form-field>
<div class="btn">
<button type="submit" class="savebtn" mat-raised-button color="primary" [disabled]='form.invalid'>确定</button>
<button type="button" mat-button (click)="onNoClick()" mat-raised-button>取消</button>
</div>
</form>

12
src/app/ui/all-file/viewdetails.html

@ -1,12 +0,0 @@
<div style="position: relative;">
<div style="position: absolute;right: 0;top: 0;cursor: pointer;" (click)="closeDialog()">
<span><mat-icon>clear</mat-icon></span>
</div>
<div class="imgbox" style="text-align: center;">
<img *ngIf="data.type == 'img'" style="max-width: 96%;max-height: 100%;margin-top: 20px;" class="imgitemdefault" [src]="Url">
<video style="margin-top:18px;" autoplay controls *ngIf="data.type == 'video'" [src]="Url"></video>
<audio autoplay controls *ngIf="data.type == 'mp3'" [src]="Url"></audio>
<!-- <pre *ngIf="data.type == 'txt'">{{Url}}</pre> -->
<!-- <iframe *ngIf="data.type == 'txt'" [src]="Url" frameborder="1" width="100%" height="600"></iframe> -->
</div>
</div>

46
src/app/ui/collection-tools/collection-tools.component.html

@ -4,9 +4,8 @@
<div class="headerTitle">{{examMsg.conpanyName}}</div> <div class="headerTitle">{{examMsg.conpanyName}}</div>
<div class="headerCenter"> <input type="text" placeholder="请输入考试要点" [(ngModel)]="examMsg.keynote"> </div> <div class="headerCenter"> <input type="text" placeholder="请输入考试要点" [(ngModel)]="examMsg.keynote"> </div>
<div class="headerRight"> <div class="headerRight">
<label class="fraction">总分<input type="text" [(ngModel)]="examMsg.grade"></label>
<button style="border: 1px solid #07CDCF; border-radius: 5px; margin: 0 15px;" (click)='openFireExamination()'><mat-icon>visibility</mat-icon>消防设施考题设定</button> <button style="border: 1px solid #07CDCF; border-radius: 5px; margin: 0 15px;" (click)='openFireExamination()'><mat-icon>visibility</mat-icon>消防设施考题设定</button>
<button (click)="saveSite()"><mat-icon>description</mat-icon>保存</button> <button (click)="saveSite()" *ngIf="examType != 1"><mat-icon>description</mat-icon>保存</button>
<button (click)="openUploadQuestions()"><mat-icon>open_in_browser</mat-icon>上传</button> <button (click)="openUploadQuestions()"><mat-icon>open_in_browser</mat-icon>上传</button>
</div> </div>
</div> </div>
@ -19,16 +18,19 @@
<!-- H5Canvas --> <!-- H5Canvas -->
<div class="centerBuildingDiv" style="user-select: none;" cdkDrag> <div class="centerBuildingDiv" style="user-select: none;" cdkDrag>
<div class="centerTotal"> <div class="centerTotal">
<div class="centerTotalHeader"><mat-icon cdkDragHandle matTooltip="可移动窗口" matTooltipPosition="above">open_with</mat-icon>建筑总平面图</div> <div class="centerTotalHeader overflowText">
<div class="everyTotal" (click)="checkedBuilding({name:'总平面图'},-1)" [ngClass]="{'buildingbtnchecked': checkedBuildingIndex==-1}">总平面图</div> <mat-icon cdkDragHandle matTooltip="可移动窗口" matTooltipPosition="above">open_with</mat-icon>
<div class="everyTotal overflowText" *ngFor="let item of allBuildings;let key = index" (click)="checkedBuilding(item,key)"[ngClass]="{'buildingbtnchecked': checkedBuildingIndex==key}"> <label (click)='togglebeforeOneCheckedBuilding()'>{{beforeOneCheckedBuilding.name}}</label>
</div>
<div class="everyTotal overflowText" *ngFor="let item of sitePlanData;let key = index"
[ngClass]="{'selectSitePlan': selectSitePlanIndex==key}" (click)='selectSitePlan(item,key)'>
{{item.name}} {{item.name}}
</div> </div>
</div> </div>
<div style="flex: 2%;opacity: 0;"></div> <div style="width: 5px;height: 100%;opacity: 0;" [hidden]="!beforeOneCheckedBuildingIsShow"></div>
<div class="centerTotal"> <div class="centerTotal" [hidden]="!beforeOneCheckedBuildingIsShow">
<div class="everyTotal overflowText" *ngFor="let item of sitePlanData;let key = index" <div class="everyTotal" (click)="checkedBuilding({name:'总平面图'},-1)" [ngClass]="{'buildingbtnchecked': checkedBuildingIndex==-1}">总平面图</div>
[ngClass]="{'isRefugeStorey':item.isRefugeStorey==true,'selectSitePlan': selectSitePlanIndex==key}" (click)='selectSitePlan(item,key)'> <div class="everyTotal overflowText" *ngFor="let item of allBuildings;let key = index" (click)="checkedBuilding(item,key)"[ngClass]="{'buildingbtnchecked': checkedBuildingIndex==key}">
{{item.name}} {{item.name}}
</div> </div>
</div> </div>
@ -41,14 +43,13 @@
<mat-icon *ngIf="toggleHandlePlans">keyboard_arrow_up</mat-icon> <mat-icon *ngIf="toggleHandlePlans">keyboard_arrow_up</mat-icon>
<mat-icon *ngIf="!toggleHandlePlans">keyboard_arrow_down</mat-icon> <mat-icon *ngIf="!toggleHandlePlans">keyboard_arrow_down</mat-icon>
<label class="overflowText" style="font-weight: 550;">处置预案</label> <label class="overflowText" style="font-weight: 550;">处置预案</label>
<!-- <label style="margin-left: 45px;" *ngIf="isEditPattern"> <label style="margin-left: 45px;">
<mat-icon style="color: #c2a40ce8;" title="计算差异" (click)='countValue($event)'>flash_on</mat-icon> <mat-icon title="选择考试节点" (click)='countValue($event)'>dashboard</mat-icon>
<mat-icon style="margin-left: 3px;" title="新建空节点" (click)='addPanelPoint($event,null,treeData)'>add</mat-icon> </label>
</label> -->
</div> </div>
<div [hidden]="!toggleHandlePlans"> <div [hidden]="!toggleHandlePlans">
<nz-tree #nzTreeComponent [nzData]="treeData" nzBlockNode nzDraggable (nzOnDrop)="nzEvent($event)" [nzTreeTemplate]="nzTreeTemplate" [nzBeforeDrop]="beforeDrop" [nzExpandedKeys]="defaultExpandedKeys"></nz-tree> <nz-tree #nzTreeComponent [nzData]="treeData" nzBlockNode [nzTreeTemplate]="nzTreeTemplate" [nzExpandedKeys]="defaultExpandedKeys"></nz-tree>
<ng-template #nzTreeTemplate let-node let-origin="origin"> <ng-template #nzTreeTemplate let-node let-origin="origin">
<div id="terrNodePublic" (click)='selectanelPoint(node.origin)' [ngClass]="{'selectanelPoint': selectDisposalNode==node.origin.id}"> <div id="terrNodePublic" (click)='selectanelPoint(node.origin)' [ngClass]="{'selectanelPoint': selectDisposalNode==node.origin.id}">
<label title="{{node.title}}" class="overflowText textNode">{{node.title}}</label> <label title="{{node.title}}" class="overflowText textNode">{{node.title}}</label>
@ -66,7 +67,7 @@
<!-- 处置预案 --> <!-- 处置预案 -->
<!-- 素材库 --> <!-- 素材库 -->
<div id="materialBank"> <div id="materialBank" *ngIf="examType != 1">
<div class="planarGraphHeader" (click)='toggleMaterial()'> <div class="planarGraphHeader" (click)='toggleMaterial()'>
<mat-icon *ngIf="toggleMaterialBank">keyboard_arrow_up</mat-icon> <mat-icon *ngIf="toggleMaterialBank">keyboard_arrow_up</mat-icon>
<mat-icon *ngIf="!toggleMaterialBank">keyboard_arrow_down</mat-icon> <mat-icon *ngIf="!toggleMaterialBank">keyboard_arrow_down</mat-icon>
@ -101,19 +102,20 @@
<label class="overflowText" style="font-weight: 550;">消防设施</label> <label class="overflowText" style="font-weight: 550;">消防设施</label>
</div> </div>
<div [hidden]="!togglePlane"> <div [hidden]="!togglePlane">
<!-- 消防列表树 --> <!-- 消防列表树 -->
<mat-tree [dataSource]="dataSource" [treeControl]="treeControl" cdkDropList [cdkDropListData]="dataSource" (cdkDropListDropped)="drop($event)"> <mat-tree [dataSource]="dataSource" [treeControl]="treeControl">
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;" matTreeNodePadding cdkTreeNodePaddingIndent='26' (click)="clickTreeNode(node)" class="treeNode"> <mat-tree-node *matTreeNodeDef="let node;" matTreeNodePadding cdkTreeNodePaddingIndent='26' (click)="clickTreeNode(node)" class="treeNode">
<button mat-icon-button disabled></button> <button mat-icon-button disabled></button>
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> <span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}">
{{node.name}} {{node.name}}
</span> </span>
<span *ngIf="node.isTemplate">({{node.children.length}})</span> <span *ngIf="node.isTemplate">({{node.children.length}})</span>
<span class="isLookCss" (click)="clickLookItem(node)"><mat-icon [ngClass]="{'icongray': node.isLook == false}">check_circle_outline</mat-icon></span> <span class="isLookCss" (click)="clickLookItem(node)"><mat-icon [ngClass]="{'icongray': node.isLook == false}">visibility</mat-icon></span>
</mat-tree-node> </mat-tree-node>
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;when: hasChild" matTreeNodePadding (click)="clickTreeNode(node)"class="treeNode" > <mat-tree-node *matTreeNodeDef="let node;when: hasChild" matTreeNodePadding (click)="clickTreeNode(node)"class="treeNode" >
<button mat-icon-button <button mat-icon-button
matTreeNodeToggle matTreeNodeToggle
[attr.aria-label]="'toggle ' + node.name"> [attr.aria-label]="'toggle ' + node.name">
@ -124,8 +126,8 @@
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> <span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}">
{{node.name}} {{node.name}}
</span> </span>
<span *ngIf="node.isTemplate && node.isNewElement">({{node.children.length}})</span> <span *ngIf="node.isTemplate && node.isNewElement">({{node.children.length}})</span>
<span class="isLookCss" (click)="clickLookItem(node)"><mat-icon [ngClass]="{'icongray': node.isLook == false}">check_circle_outline</mat-icon></span> <span class="isLookCss" (click)="clickLookItem(node)"><mat-icon [ngClass]="{'icongray': node.isLook == false}">visibility</mat-icon></span>
</mat-tree-node> </mat-tree-node>
</mat-tree> </mat-tree>

19
src/app/ui/collection-tools/collection-tools.component.scss

@ -1,4 +1,7 @@
@import './panel.scss'; @import './panel.scss';
::-webkit-scrollbar {
display: none; /* Chrome Safari */
}
.content { .content {
width: 100%; width: 100%;
height: 100%; height: 100%;
@ -43,17 +46,10 @@
} }
} }
.headerRight { .headerRight {
width: 450px; width: 350px;
overflow: hidden; overflow: hidden;
box-sizing: border-box; box-sizing: border-box;
padding-left: 10px; padding-left: 10px;
.fraction { font-size: 14px; }
.fraction input {
width: 40px;
height: 24px;
margin: 0 2px;
border-radius: 5px;
}
button { button {
font-size: 14px; font-size: 14px;
color: #07CDCF; color: #07CDCF;
@ -125,10 +121,10 @@
} }
.centerBuildingDiv { .centerBuildingDiv {
position: absolute; position: absolute;
width: 400px; max-width: 400px;
top: 40px; top: 40px;
left: 240px; left: 240px;
z-index: 1111; z-index: 150;
display: flex; display: flex;
} }
.functionalDomainLeft { .functionalDomainLeft {
@ -175,7 +171,7 @@
//中间建筑/楼层 //中间建筑/楼层
.centerTotal { .centerTotal {
flex: 49%; width: 197px;
background-color: #fff; background-color: #fff;
box-shadow: 0px 0px 5px 3px rgb(165, 163, 163); box-shadow: 0px 0px 5px 3px rgb(165, 163, 163);
border-radius: 5px; border-radius: 5px;
@ -357,7 +353,6 @@ input { border: none; outline: none; background-color: #d6dddf; box-sizing: bord
div:focus { div:focus {
outline: none; outline: none;
} }
//没有图片时显示无图片背景图 //没有图片时显示无图片背景图
.noImgCss{ .noImgCss{
background: url(../../../assets/images/noImg.png) no-repeat center center; background: url(../../../assets/images/noImg.png) no-repeat center center;

420
src/app/ui/collection-tools/collection-tools.component.ts

@ -16,7 +16,7 @@ import { delay } from 'rxjs/operators';
import { windows } from 'src/app/interface'; import { windows } from 'src/app/interface';
import { GameMode } from 'src/app/working-area/model/gameMode'; import { GameMode } from 'src/app/working-area/model/gameMode';
import { ActivatedRoute, Router } from '@angular/router'; import { ActivatedRoute, Router } from '@angular/router';
import { examinationQuestions,uploadQuestions } from './examinationQuestions' import { examinationQuestions,uploadDisposalNodes,uploadQuestions } from './examinationQuestions'
@ -59,6 +59,8 @@ export class CollectionToolsComponent implements OnInit {
allBuildings //该单位所有建筑 allBuildings //该单位所有建筑
beforeOneCheckedBuilding:any = {name:"总平面图"}; //当前点击选择的建筑 beforeOneCheckedBuilding:any = {name:"总平面图"}; //当前点击选择的建筑
beforeOneCheckedBuildingIsShow:boolean = false; //建筑是否显示
togglebeforeOneCheckedBuilding () { this.beforeOneCheckedBuildingIsShow = !this.beforeOneCheckedBuildingIsShow }
checkedBuildingIndex:number = -1 //当前点击选择的建筑index checkedBuildingIndex:number = -1 //当前点击选择的建筑index
isEditPat:boolean = true //当前是否是编辑模式 isEditPat:boolean = true //当前是否是编辑模式
@ -150,9 +152,6 @@ export class CollectionToolsComponent implements OnInit {
} }
pattern:boolean = false//默认为基本信息编辑 pattern:boolean = false//默认为基本信息编辑
yyy(){
console.log(this.canvasData.selectPanelPoint)
}
//基本信息编辑模式 //基本信息编辑模式
baseInfo(){ baseInfo(){
if (!this.pattern) { if (!this.pattern) {
@ -629,9 +628,8 @@ export class CollectionToolsComponent implements OnInit {
isSixbtn = true //控制想定作业编辑按钮 isSixbtn = true //控制想定作业编辑按钮
isxxx = true //控制查看编辑模式的编辑模式按钮 isxxx = true //控制查看编辑模式的编辑模式按钮
examMsg = { //单位,考试信息 examMsg = { //单位,考试信息
conpanyName: sessionStorage.getItem('companyName'), //单位名称 conpanyName: sessionStorage.getItem('companyName') || '暂无数据', //单位名称
keynote: '', //考试要点 keynote: '', //考试要点
grade: '', //分数
} }
ngOnInit(): void { ngOnInit(): void {
@ -657,8 +655,6 @@ export class CollectionToolsComponent implements OnInit {
} }
ngAfterViewInit(): void { ngAfterViewInit(): void {
this.getSitePlan() //获取总平面图/楼层 this.getSitePlan() //获取总平面图/楼层
@ -743,247 +739,11 @@ export class CollectionToolsComponent implements OnInit {
let adjoinArr = [] //毗邻数组 let adjoinArr = [] //毗邻数组
if(this.pattern){//如果是基本信息编辑模式 if(this.pattern){//如果是基本信息编辑模式
for (const key in object) { return true
if (object[key].Name == "毗邻") {//如果是相同楼层,则筛选出毗邻
object[key].PropertyInfos.forEach(element => {
if(element.PropertyName == "方向"){
adjoinArr.push(element.PropertyValue)
}
});
}
}
if((new Set(adjoinArr)).size != adjoinArr.length){
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存失败,毗邻存在相同方向','确定',config);
return false
}else{
//如果是单位 总平面图
if(this.checkedBuildingIndex==-1){
//保存平面图数据
this.http.post("/api/SitePlanData",SitePlanData,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('平面图数据保存失败','确定',config);
})
//保存建筑数据
this.http.post("/api/CompanyData",CompanyData,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('单位数据保存失败','确定',config);
})
//批量保存单位毗邻
let CompanyAdjoins = this.canvasData.getCompanyAdjoinInfo()
this.http.post("/api/CompanyAdjoins/Batch",CompanyAdjoins,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('单位毗邻保存失败','确定',config);
})
//批量保存单位重点部位
let CompanyImportantLocations = this.canvasData.getCompanyImportantLocations()
this.http.post("/api/CompanyImportantLocations/Batch",CompanyImportantLocations,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('单位重点部位保存失败','确定',config);
})
//批量保存单位消防设施素材
let CompanyFacilityAssets = this.canvasData.getAllCompanyFacilityAssetInfo()
this.http.post("/api/CompanyFacilityAssets/Batch",CompanyFacilityAssets,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('单位消防设施素材保存失败','确定',config);
})
}else{ //如果是建筑
//建筑平面图数据
this.http.post("/api/BuildingAreaData",SitePlanData,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('平面图数据保存失败','确定',config);
})
//建筑数据
this.http.post("/api/BuildingData",CompanyData,{
params:{
companyId:this.params.companyId
}
}).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('单位数据保存失败','确定',config);
})
//批量保存建筑毗邻
let buildingAdjoins = this.canvasData.getBuildingAdjoinInfo()
this.http.post(`/api/BuildingAdjoins/Batch?companyId=${this.params.companyId}&buildingId=${this.canvasData.selectStorey.buildingId}`,buildingAdjoins).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('建筑毗邻保存失败','确定',config);
})
//批量保存建筑重点部位
let buildingImportantLocations = this.canvasData.getBuildingImportantLocations()
this.http.post(`/api/BuildingImportantLocations/Batch?companyId=${this.params.companyId}&buildingId=${this.canvasData.selectStorey.buildingId}`,buildingImportantLocations).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('建筑重点部位保存失败','确定',config);
})
//批量保存建筑消防设施素材
let buildingFacilityAssets = this.canvasData.getAllBuildingFacilityAssetInfo()
this.http.post(`/api/BuildingFacilityAssets/Batch?companyId=${this.params.companyId}&buildingId=${this.canvasData.selectStorey.buildingId}`,buildingFacilityAssets).subscribe(data => {
this.saveNum.push("1")
if(this.saveNum.length == 5){
this.canvasData.isChange = false
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存成功','确定',config);
}
},err=>{
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.canvasData.isChange = true
this.snackBar.open('建筑消防设施素材保存失败','确定',config);
})
}
}
}else{//如果是想定作业编辑模式 }else{//如果是想定作业编辑模式
const dialogRef = this.dialog.open(saveOneDialog, { const dialogRef = this.dialog.open(saveOneDialog, {
data: {allDisposalNode: this.canvasData.allDisposalNode, data: {
allDisposalNode: this.canvasData.allDisposalNode,
selectedBuildingData:this.beforeOneCheckedBuilding, selectedBuildingData:this.beforeOneCheckedBuilding,
selectedSiteData:this.selectingSitePlan, selectedSiteData:this.selectingSitePlan,
siteOrbuilding:this.checkedBuildingIndex, siteOrbuilding:this.checkedBuildingIndex,
@ -1015,14 +775,6 @@ export class CollectionToolsComponent implements OnInit {
}) })
} }
//拖拽tree
drop(e){
console.log(1111,e)
}
drop2(e){
console.log(222,e)
}
//创建建筑 //创建建筑
createBuilding(){ createBuilding(){
let data = { let data = {
@ -1146,15 +898,17 @@ export class CollectionToolsComponent implements OnInit {
//处理 tree 数据结构 //处理 tree 数据结构
handleTreeData (storeyData) { handleTreeData (storeyData) {
//storeyData为当前楼层拥有的消防设施
this.storeyData = storeyData this.storeyData = storeyData
let data = this.allFireElements //所有消防要素模板 let data = JSON.parse(JSON.stringify(this.allFireElements)) //所有消防要素模板
console.log(data)
let treeData = [] //tree型 处理完成后的数据 let treeData = [] //tree型 处理完成后的数据
data.forEach(element => { data.forEach(element => {
element.key = element.id
element.isTemplate = true //添加模板标识 element.isTemplate = true //添加模板标识
element.isLook = true //添加是否可见标识 element.isLook = true //添加是否可见标识
element.name!='其他'? element.children = [] : null element.name != '其他' ? element.children = [] : null
if(storeyData){ if(storeyData){
for(let key in storeyData.data){ for(let key in storeyData.data){
storeyData.data[key].isLookPattern = true storeyData.data[key].isLookPattern = true
@ -1173,8 +927,6 @@ export class CollectionToolsComponent implements OnInit {
} }
}) })
} }
//
element.children.push(storeyData.data[key]) element.children.push(storeyData.data[key])
} }
} }
@ -1184,20 +936,53 @@ export class CollectionToolsComponent implements OnInit {
data.forEach(element => { data.forEach(element => {
if (!element.parentId) { treeData.push(element) } if (!element.parentId) { treeData.push(element) }
}); });
this.dataSource.data = treeData
function recursionFilterEmpty(originalList, result) {
      for(let i = 0, length = originalList.length; i < length; i++) {
          const item = originalList[i];
          if (item.PropertyInfos) {
              // 最内层
              result.push(item);
          } else if (item.children && item.children.length) {
              const newChildren = [];
              // 递归调用,底层的真实数据会全部 push  newChildren 
              recursionFilterEmpty(item.children, newChildren);
              if (newChildren.length) {
                  // 替换原始数据
                  item.children = newChildren;
                  // 子项有真实的数据,就保留这一项
                  result.push(item);
              } // 如果没有这一项就会被删除
          }
      }
  }
  
  function filterEmpty(listData) {
      const result = [];
      recursionFilterEmpty(listData, result);
      return result;
  }
console.log(filterEmpty(treeData))
this.dataSource.data = filterEmpty(treeData)
this.treeControl.expandAll() this.treeControl.expandAll()
} }
//点击树节点 //点击树节点
clickTreeNode(node){ clickTreeNode(node){
if(this.canvasData.originalcompanyBuildingData.data[node.id]){ if(this.canvasData.originalcompanyBuildingData.data[node.id]){
this.setAssetsProperty(this.canvasData.originalcompanyBuildingData.data[node.id]) this.setAssetsProperty(this.canvasData.originalcompanyBuildingData.data[node.id])
}else if(this.canvasData.originaleveryStoreyData.data[node.id]){ }else if(this.canvasData.originaleveryStoreyData.data[node.id]){
this.setAssetsProperty(this.canvasData.originaleveryStoreyData.data[node.id]) this.setAssetsProperty(this.canvasData.originaleveryStoreyData.data[node.id])
} }
//canvas上的素材高亮 // console.log(node)
// canvas上的素材高亮
let iconHighLightArr:any = [] let iconHighLightArr:any = []
if(node.isTemplate){//如果是模板,则开始向下找 if(node.isTemplate){//如果是模板,则开始向下找
node.children.forEach(item => { node.children.forEach(item => {
@ -1212,10 +997,11 @@ export class CollectionToolsComponent implements OnInit {
}else{ }else{
iconHighLightArr.push(node.id) iconHighLightArr.push(node.id)
} }
// console.log(456,iconHighLightArr)
this.canvas.setHighlight(iconHighLightArr) this.canvas.setHighlight(iconHighLightArr)
} }
//点击节点的显示隐藏icon //点击节点的显示隐藏icon
clickLookItem(node){ clickLookItem(node){
//修改真实素材islook属性 //修改真实素材islook属性
@ -1226,9 +1012,16 @@ export class CollectionToolsComponent implements OnInit {
} }
//所有消防要素模板变化islook值 //所有消防要素模板变化islook值
if(node.isTemplate && node.name == "其他"){
this.allFireElements.forEach(item=>{
if(item.name == "其他"){
item.isLook = !item.isLook
}
})
}
if(node.isTemplate){ if(node.isTemplate){
this.allFireElements.forEach(item=>{ this.allFireElements.forEach(item=>{
if(item.id == node.id || item.name == "其他"){ if(item.id == node.id){
item.isLook = !item.isLook item.isLook = !item.isLook
} }
}) })
@ -1281,39 +1074,22 @@ export class CollectionToolsComponent implements OnInit {
}else{ }else{
iconVisibleArr.push(node.id) iconVisibleArr.push(node.id)
} }
console.log(1,iconVisibleArr)
console.log(2,node.isLook)
this.canvas.setIconVisible(iconVisibleArr,!node.isLook) this.canvas.setIconVisible(iconVisibleArr,!node.isLook)
}
//计算 可视区域内宽度, 是否缩放背景图
backGroundScale () {
// let that = this
// let dad = this.element.nativeElement.querySelector('.functionalDomainContent').clientWidth
// let dadHeight = this.element.nativeElement.querySelector('.functionalDomainContent').clientHeight
// let left = this.element.nativeElement.querySelector('.functionalDomainLeft').clientWidth
// let right = this.element.nativeElement.querySelector('.functionalDomainRight').clientWidth
// let imgWidth = dad - left - right//可视区域内 宽度
// let img = new Image()
// img.src = this.selectingSitePlan.imageUrl;
// img.onload = function(){
// if (img.height > dadHeight && img.width > imgWidth) {
// let width = imgWidth/img.width
// let height = dadHeight/img.height
// that.canvas.setBackgroundScale((width>height? height : width)-0.005)
// return
// } else if (img.height > dadHeight) {
// that.canvas.setBackgroundScale((dadHeight/img.height)-0.005)
// return
// } else if (img.width > imgWidth) {
// that.canvas.setBackgroundScale((imgWidth/img.width)-0.005)
// return
// }
// };
} }
//打开消防设施考题设定 //打开消防设施考题设定
openFireExamination () { openFireExamination () {
console.log(1,this.beforeOneCheckedBuilding)
let treeData = JSON.parse( JSON.stringify(this.dataSource.data) ) let treeData = JSON.parse( JSON.stringify(this.dataSource.data) )
let data = { treeData: treeData } let buildFloorData = {
buildingData:this.beforeOneCheckedBuilding,
floorData:this.selectingSitePlan
}
let data = { treeData: treeData,oldRealData:this.storeyData ,buildFloorData:buildFloorData}
let dialogRef = this.dialog.open(examinationQuestions,{data}); let dialogRef = this.dialog.open(examinationQuestions,{data});
} }
@ -1325,8 +1101,9 @@ export class CollectionToolsComponent implements OnInit {
} }
//封装 刷新 tree 数据 //封装 刷新 tree 数据
async renovateTreeData (isRefresh:boolean = true) { async renovateTreeData (isRefresh:boolean = true) {
this.allFireElements[this.allFireElements.length-1].children = [] this.allFireElements[this.allFireElements.length-1].children = []
this.beforeOneCheckedBuildingIsShow = false
isRefresh? await this.canvas.refresh() : null isRefresh? await this.canvas.refresh() : null
this.canvas.setNameVisible(this.basicInfo,0) this.canvas.setNameVisible(this.basicInfo,0)
this.canvas.setNameVisible(this.wantToWork,1) this.canvas.setNameVisible(this.wantToWork,1)
@ -1338,12 +1115,13 @@ export class CollectionToolsComponent implements OnInit {
let companyBuildingData = JSON.parse(JSON.stringify( this.canvasData.originalcompanyBuildingData || {} )) // 当前 单位/建筑 数据 let companyBuildingData = JSON.parse(JSON.stringify( this.canvasData.originalcompanyBuildingData || {} )) // 当前 单位/建筑 数据
let storeyData = JSON.parse(JSON.stringify( this.canvasData.originaleveryStoreyData || {} )) //当前 楼层 数据 let storeyData = JSON.parse(JSON.stringify( this.canvasData.originaleveryStoreyData || {} )) //当前 楼层 数据
for(let key in companyBuildingData.data){ // for(let key in companyBuildingData.data){
if (companyBuildingData.data[key].FloorId === beforeOneId) { //处理 单位/建筑 数据是否归于当前楼层下 // if (companyBuildingData.data[key].FloorId === beforeOneId) { //处理 单位/建筑 数据是否归于当前楼层下
storeyData.data[key] = companyBuildingData.data[key] // storeyData.data[key] = companyBuildingData.data[key]
} // }
} // }
for(let key in storeyData.data){ //筛选数据 没有匹配全部放入到 其他 数组 for(let key in storeyData.data){ //筛选数据 没有匹配全部放入到 其他 数组
storeyData.data[key].key = storeyData.data[key].Id
let noMatch = this.allFireElements.find( every=> every.id===storeyData.data[key].FireElementId ) let noMatch = this.allFireElements.find( every=> every.id===storeyData.data[key].FireElementId )
if (!noMatch) { if (!noMatch) {
this.allFireElements[this.allFireElements.length-1].children.push(storeyData.data[key]) this.allFireElements[this.allFireElements.length-1].children.push(storeyData.data[key])
@ -1877,20 +1655,23 @@ export class CollectionToolsComponent implements OnInit {
//处置预案 //处置预案
examType = this.route.snapshot.queryParams.openType // 预案类型 1=已存在/2=自定义
allFirePlan:any = []; //所有灾情 allFirePlan:any = []; //所有灾情
selectDisposalNode:string = ''; //当前点击tree节点 css选中样式 selectDisposalNode:string = ''; //当前点击tree节点 css选中样式
//获取所有灾情 //获取所有灾情
getAllFirePlan () { getAllFirePlan () {
let api
this.examType == 1? api='/api/Disasters' : api='/api/ExamDisasters'
let params = {componentId: sessionStorage.getItem('planId')} let params = {componentId: sessionStorage.getItem('planId')}
this.http.get('/api/Disasters',{params:params}).subscribe((data:any)=>{ this.http.get(api,{params:params}).subscribe((data:any)=>{
if (!data.length) { //该 单位没有灾情时 if (!data.length) { //该 单位没有灾情时
let msg = { let msg = {
name: '灾情', name: '灾情',
modifiedTime: new Date(), modifiedTime: new Date(),
planComponentId: sessionStorage.getItem('planId') examPlanComponentId: sessionStorage.getItem('planId')
} }
this.http.post('/api/Disasters',msg).subscribe(data=>{ this.http.post('/api/ExamDisasters',msg).subscribe(data=>{
this.allFirePlan.push(data) this.allFirePlan.push(data)
this.getDisposalNode() this.getDisposalNode()
}) })
@ -1903,13 +1684,11 @@ export class CollectionToolsComponent implements OnInit {
//获取所有处置节点 //获取所有处置节点
getDisposalNode () { getDisposalNode () {
let api
this.examType == 1? api='/api/DisposalNodes' : api='/api/ExamDisposalNodes'
this.selectDisposalNode = '' this.selectDisposalNode = ''
let params = {disasterId: this.allFirePlan[0].id || ''} let params = {disasterId: this.allFirePlan[0].id || ''}
// this.http.get('/api/DisasterData/Markers',{params:params}).subscribe(data=>{ //灾情标签信息 this.http.get(api,{params:params}).subscribe(data=>{ //处置节点
// this.canvasData.allNodeMarkers = data
// this.mateFireForce()
// })
this.http.get('/api/DisposalNodes',{params:params}).subscribe(data=>{ //处置节点
this.canvasData.allDisposalNode = data this.canvasData.allDisposalNode = data
this.handleHybridTree() this.handleHybridTree()
}) })
@ -1947,9 +1726,11 @@ export class CollectionToolsComponent implements OnInit {
//刷新 treeData 保存已展开节点 //刷新 treeData 保存已展开节点
refurbishTreeData () { refurbishTreeData () {
let api
this.examType == 1? api='/api/DisposalNodes' : api='/api/ExamDisposalNodes'
this.defaultExpandedKeys = [] this.defaultExpandedKeys = []
let params = {disasterId: this.allFirePlan[0].id || ''} let params = {disasterId: this.allFirePlan[0].id || ''}
this.http.get('/api/DisposalNodes',{params:params}).subscribe(nodeData=>{ //处置节点 this.http.get(api,{params:params}).subscribe(nodeData=>{ //处置节点
this.canvasData.allDisposalNode = nodeData this.canvasData.allDisposalNode = nodeData
let oldTreeData = this.nzTreeComponent.getExpandedNodeList() let oldTreeData = this.nzTreeComponent.getExpandedNodeList()
oldTreeData.forEach(item=>{ oldTreeData.forEach(item=>{
@ -2043,18 +1824,27 @@ export class CollectionToolsComponent implements OnInit {
}); });
} }
//计算差异 //选择 考试节点
countValue (e) { countValue (e) {
e.stopPropagation() e.stopPropagation()
let params = {disasterId: this.allFirePlan[0].id || ''} if (this.canvasData.allDisposalNode.length) {
this.http.get('/api/DisasterData/Diffs',{params:params}).subscribe(data=>{ let data = {treeData: JSON.parse( JSON.stringify(this.treeData) ), oldTreeData: JSON.parse( JSON.stringify(this.canvasData.allDisposalNode) )}
this.canvasData.allNodeMarkers = data let dialogRef = this.dialog.open(uploadDisposalNodes,{data});
this.mateFireForce() dialogRef.afterClosed().subscribe(data=>{
if (data) {
sessionStorage.setItem('examNodeList',JSON.stringify(data))
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('节点保存成功','确定',config);
}
})
} else {
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
config.verticalPosition = 'top'; config.verticalPosition = 'top';
config.duration = 3000 config.duration = 3000
this.snackBar.open('计算差异完成','确定',config); this.snackBar.open('暂无数据节点','确定',config);
}) }
} }
//新建 处置预案 节点 //新建 处置预案 节点
@ -2144,12 +1934,14 @@ export class CollectionToolsComponent implements OnInit {
this.selectDisposalNode = e.parentId //选中 节点 this.selectDisposalNode = e.parentId //选中 节点
if (this.canvasData.selectPanelPoint.DisposalNodeId != e.id) { //选择节点 不是当前节点时 if (this.canvasData.selectPanelPoint.DisposalNodeId != e.id) { //选择节点 不是当前节点时
let api
this.examType == 1? api='/api/DisposalNodeData' : api='/api/ExamDisposalNodeData'
let params = {nodeId: e.id} let params = {nodeId: e.id}
let parameter = { //查询 节点 对应 建筑/楼层 index,id let parameter = { //查询 节点 对应 建筑/楼层 index,id
buildingIndex: e.sitePlanId? -1 : this.allBuildings.findIndex(item=>{ return item.id===e.buildingId }), //总平面图/建筑 index buildingIndex: e.sitePlanId? -1 : this.allBuildings.findIndex(item=>{ return item.id===e.buildingId }), //总平面图/建筑 index
storeyId: e.sitePlanId? e.sitePlanId : e.buildingAreaId, //楼层id storeyId: e.sitePlanId? e.sitePlanId : e.buildingAreaId, //楼层id
} }
this.http.get('/api/DisposalNodeData',{params:params}).subscribe(data=>{ this.http.get(api,{params:params}).subscribe(data=>{
this.canvasData.selectPanelPoint = this.canvasData.deserialize(JSON.stringify(data || new DisposalNodeData())) //选择 当前 节点 this.canvasData.selectPanelPoint = this.canvasData.deserialize(JSON.stringify(data || new DisposalNodeData())) //选择 当前 节点
this.canvasData.selectPanelPoint.Data = this.canvasData.deserialize(this.canvasData.selectPanelPoint.Data) this.canvasData.selectPanelPoint.Data = this.canvasData.deserialize(this.canvasData.selectPanelPoint.Data)
this.seekPanelPoint(parameter) this.seekPanelPoint(parameter)

51
src/app/ui/collection-tools/examinationQuestions.html

@ -1,33 +1,30 @@
<div style="min-width: 240px;"> <div style="min-width: 240px;" id="nodeTree">
<div style="text-align: center;font-weight: 550;">消防设施考题设定</div> <div style="text-align: center;font-weight: 550;">消防设施考题设定</div>
<div style="max-height: 300px;overflow-y: auto; margin: 25px 0;"> <div style="max-height: 300px;overflow-y: auto; margin: 25px 0;">
<!-- 消防列表树 --> <!-- 消防列表树 -->
<mat-tree [dataSource]="dataSource" [treeControl]="treeControl" cdkDropList [cdkDropListData]="dataSource"> <nz-tree
#nzTreeComponent
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;" matTreeNodePadding cdkTreeNodePaddingIndent='26' class="treeNode"> [nzData]="renderData"
<button mat-icon-button disabled></button> nzCheckable
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> nzMultiple
{{node.name}} [nzCheckedKeys]="defaultCheckedKeys"
</span> [nzExpandedKeys]="defaultExpandedKeys"
<span *ngIf="node.isTemplate">({{node.children.length}})</span> [nzSelectedKeys]="defaultSelectedKeys"
<mat-checkbox style="margin-left: auto;" color=primary></mat-checkbox> (nzClick)="nzEvent($event)"
</mat-tree-node> (nzExpandChange)="nzEvent($event)"
(nzCheckBoxChange)="nzEvent($event)"
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;when: hasChild" matTreeNodePadding class="treeNode" > [nzTreeTemplate]="nzTreeTemplate"
<button mat-icon-button matTreeNodeToggle [attr.aria-label]="'toggle ' + node.name"> >
<mat-icon class="mat-icon-rtl-mirror"> </nz-tree>
{{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}} <ng-template #nzTreeTemplate let-node let-origin="origin">
</mat-icon> <div class="treeNodeTemplate">
</button> <label class="overflowText textNode">{{node.origin.name || node.origin.Name}}</label>
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> </div>
{{node.name}} </ng-template>
</span>
<span *ngIf="node.isTemplate && node.isNewElement">({{node.children.length}})</span>
<mat-checkbox style="margin-left: auto;" color=primary></mat-checkbox>
</mat-tree-node>
</mat-tree>
<!-- 消防列表树 --> <!-- 消防列表树 -->
</div> </div>
<div style="text-align: center;"><button mat-stroked-button style="border: none;background-color: #FF8678;color: #fff;" mat-dialog-close>退出</button></div> <div style="text-align: center;">
<button mat-stroked-button style="margin-right: 15px;border: none;background: #07CDCF;color: #fff;" (click)='submit()'>确定</button>
<button mat-stroked-button style="margin-left: 15px;border: none;background: #dfe0e0;" mat-dialog-close>取消</button>
</div>
</div> </div>

218
src/app/ui/collection-tools/examinationQuestions.ts

@ -1,10 +1,11 @@
import { Component, OnInit, Inject } from '@angular/core'; import { Component, OnInit, Inject, ViewChild } from '@angular/core';
import { HttpClient, HttpHeaders } from '@angular/common/http'; import { HttpClient, HttpHeaders } from '@angular/common/http';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog'; import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar'; import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import {CanvasShareDataService,DisposalNodeData} from '../../canvas-share-data.service' //引入服务 import {CanvasShareDataService,DisposalNodeData} from '../../canvas-share-data.service' //引入服务
import { FlatTreeControl } from '@angular/cdk/tree'; import { FlatTreeControl } from '@angular/cdk/tree';
import { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree'; import { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree';
import { NzFormatBeforeDropEvent, NzFormatEmitEvent,NzTreeComponent } from 'ng-zorro-antd/tree';
@Component({ @Component({
selector: 'dialog-examination-questions', selector: 'dialog-examination-questions',
@ -15,28 +16,118 @@ export class examinationQuestions {
constructor(private http:HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, public dialogRef: MatDialogRef<any>, constructor(private http:HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, public dialogRef: MatDialogRef<any>,
@Inject(MAT_DIALOG_DATA) public data) {} @Inject(MAT_DIALOG_DATA) public data) {}
// tree配置
private _transformer = (node, level: number) => {//要给渲染节点传那些属性参数
return {
expandable: !!node.children && node.children.length > 0,
name: node.name || node.Name,
level: level,
id: node.id || node.Id,
children:node.children,
isTemplate:node.isTemplate,
isNewElement:node.isNewElement,
isLook:node.isLook,
isLookPattern:node.isLookPattern || null
};
}
treeControl = new FlatTreeControl<any>(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;
@ViewChild('nzTreeComponent', { static: false }) nzTreeComponent!: NzTreeComponent;
defaultCheckedKeys = []; //指定选中复选框的树节点 key值
defaultExpandedKeys = []; //展开指定的树节点 key值
defaultSelectedKeys = []; //指定选中的树节点 key值
renderData:any
ngOnInit(): void { ngOnInit(): void {
this.dataSource.data = this.data.treeData this.renderData = this.data.treeData
this.treeControl.expandAll() if(JSON.parse(sessionStorage.getItem('tree型数据')) && JSON.parse(sessionStorage.getItem('tree型数据'))[this.data.buildFloorData.floorData.id]){
// console.log(123,JSON.parse(sessionStorage.getItem('tree型数据'))[this.data.buildFloorData.floorData.id])
this.defaultCheckedKeys = JSON.parse(sessionStorage.getItem('tree型数据'))[this.data.buildFloorData.floorData.id]
}
this.data.treeData.forEach(element => {
if(element.isTemplate){
element.isLeaf = false
}else{
element.isLeaf = true
}
if(element.children && element.children.length != 0){
element.children.forEach(ele => {
if(ele.isTemplate){
ele.isLeaf = false
}else{
ele.isLeaf = true
}
if(ele.children && ele.children.length != 0){
ele.children.forEach(item => {
if(item.isTemplate){
item.isLeaf = false
}else{
item.isLeaf = true
}
});
}})
}
})
}
nzEvent($event){
console.log($event)
}
//提交
submit () {
let oldTreeData = this.nzTreeComponent.getCheckedNodeList()
let alltreedata = JSON.parse(sessionStorage.getItem("tree型数据"))
let keyArr = []
oldTreeData.forEach(element => {
keyArr.push(element.origin.key)
})
if(alltreedata){
//如果已经保存过当前楼层则替换
alltreedata[this.data.buildFloorData.floorData.id] = keyArr
sessionStorage.setItem('tree型数据',JSON.stringify(alltreedata))
}else{
alltreedata = {}
alltreedata[this.data.buildFloorData.floorData.id] = keyArr
sessionStorage.setItem('tree型数据',JSON.stringify(alltreedata))
}
let checkList = [] //只存真实素材
for (const key in this.data.oldRealData.data) {
let element = this.data.oldRealData.data[key]
let isChecked = (this.nzTreeComponent.getTreeNodeByKey(key)).isChecked
isChecked? checkList.push(element) : null
}
//存储真实素材数据
let obj = {
name:this.data.buildFloorData.buildingData.name + '-' + this.data.buildFloorData.floorData.name,
key:this.data.buildFloorData.floorData.id,
children:checkList
}
let data = JSON.parse(sessionStorage.getItem("试卷id"))
if(data && data.length != 0){
console.log(1)
let ind = null
data.forEach((item,index) => {
if(item.key == obj.key){
ind = index + 1
}
})
if(ind){
if(checkList.length != 0){
data[ind - 1].children = checkList
}else{
data.splice(ind - 1,1)
}
}else{
data.push(obj)
}
sessionStorage.setItem("试卷id",JSON.stringify(data))
}else{
console.log(2)
data = []
data[0] = obj
sessionStorage.setItem("试卷id",JSON.stringify(data))
}
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('当层消防设施考题设置完成','确定',config);
// this.dialogRef.close()
} }
} }
@ -50,44 +141,61 @@ export class uploadQuestions {
constructor(private http:HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, public dialogRef: MatDialogRef<any>, constructor(private http:HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, public dialogRef: MatDialogRef<any>,
@Inject(MAT_DIALOG_DATA) public data) {} @Inject(MAT_DIALOG_DATA) public data) {}
// tree配置
private _transformer = (node, level: number) => {//要给渲染节点传那些属性参数 defaultCheckedKeys = []; //指定选中复选框的树节点 key值
return { defaultExpandedKeys = []; //展开指定的树节点 key值
expandable: !!node.children && node.children.length > 0, defaultSelectedKeys = []; //指定选中的树节点 key值
name: node.name || node.Name, renderData:any
level: level,
id: node.id || node.Id,
children:node.children,
isTemplate:node.isTemplate,
isNewElement:node.isNewElement,
isLook:node.isLook,
isLookPattern:node.isLookPattern || null
};
}
treeControl = new FlatTreeControl<any>(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;
ngOnInit(): void { ngOnInit(): void {
this.dataSource.data = this.data.treeData let data = JSON.parse(sessionStorage.getItem("试卷id"))
this.treeControl.expandAll() data.forEach(item => {
item.children.forEach(i => {
i.isLeaf = true
})
})
this.renderData = data
}
nzEvent($event){
console.log($event)
} }
//上传 //上传
submit () { submit () {
if (this.data.question.grade && this.data.question.keynote) { console.log(this.data.question)
const config = new MatSnackBarConfig(); }
config.verticalPosition = 'top';
config.duration = 3000 }
this.snackBar.open('上传成功','确定',config);
this.dialogRef.close() @Component({
} else { selector: 'dialog-disposal-nodes',
const config = new MatSnackBarConfig(); templateUrl: './uploadDisposalNodes.html',
config.verticalPosition = 'top'; styleUrls: ['./collection-tools.component.scss',]
config.duration = 3000 })
this.snackBar.open('请填写必填项','确定',config); export class uploadDisposalNodes {
}
constructor(private http:HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, public dialogRef: MatDialogRef<any>,
@Inject(MAT_DIALOG_DATA) public data) {}
@ViewChild('nzTreeComponent', { static: false }) nzTreeComponent!: NzTreeComponent;
ngOnInit(): void {
this.treeData = [...this.data.treeData]
}
treeData:any = []; //tree
//提交 保存考试节点
submit () {
let checkList = []
this.data.oldTreeData.forEach(element => {
let isChecked = (this.nzTreeComponent.getTreeNodeByKey(element.id)).isChecked
isChecked? checkList.push(element) : null
});
if (checkList.length) {
this.dialogRef.close(checkList);
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('请选择节点','确定',config);
} }
}
} }

2
src/app/ui/collection-tools/panel.scss

@ -13,7 +13,7 @@
flex-direction: row; flex-direction: row;
align-items: center; align-items: center;
padding: 0 24px; padding: 0 24px;
border-radius: 5px; // border-radius: 5px;
font-family: Roboto, "Helvetica Neue", sans-serif; font-family: Roboto, "Helvetica Neue", sans-serif;
font-size: 15px; font-size: 15px;
font-weight: 400; font-weight: 400;

24
src/app/ui/collection-tools/save.ts

@ -82,7 +82,7 @@ export class saveOneDialog {
} }
}) })
}) })
// console.log(this.nodeItem.id)
} }
onNoClick(): void { onNoClick(): void {
this.dialogRef.close(); this.dialogRef.close();
@ -139,15 +139,15 @@ export class saveOneDialog {
if(istrue){//如果该处置节点下已有同名数据节点 则只修改 2个接口 if(istrue){//如果该处置节点下已有同名数据节点 则只修改 2个接口
new Promise((resolve,reject)=>{ new Promise((resolve,reject)=>{
this.http.put(`/api/DisposalNodes/${value.nodeId}`,putdata).subscribe(data => { // this.http.put(`/api/DisposalNodes/${value.nodeId}`,putdata).subscribe(data => {
resolve("更新处置节点成功,将天气 节点详情等信息保存到点击的节点") resolve("更新处置节点成功,将天气 节点详情等信息保存到点击的节点")
}) // })
}).then((values)=>{ }).then((values)=>{
this.canvasData.sendMessage('send a message');//发布一条消息 this.canvasData.sendMessage('send a message');//发布一条消息
// 保存平面图数据到当前节点 // 保存平面图数据到当前节点
let postdata =JSON.parse(JSON.stringify(this.canvasData.selectPanelPoint)) let postdata =JSON.parse(JSON.stringify(this.canvasData.selectPanelPoint))
postdata.Data = JSON.stringify(postdata.Data) postdata.Data = JSON.stringify(postdata.Data)
this.http.post(`/api/DisposalNodeData`,postdata).subscribe(data => { this.http.post(`/api/ExamDisposalNodeData`,postdata).subscribe(data => {
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
config.verticalPosition = 'top'; config.verticalPosition = 'top';
config.duration = 3000 config.duration = 3000
@ -164,14 +164,14 @@ export class saveOneDialog {
}else{//需要3个接口 }else{//需要3个接口
new Promise((resolve,reject)=>{ new Promise((resolve,reject)=>{
this.http.put(`/api/DisposalNodes/${value.nodeId}`,putdata).subscribe(data => { // this.http.put(`/api/DisposalNodes/${value.nodeId}`,putdata).subscribe(data => {
resolve("更新处置节点成功,将天气 节点详情等信息保存到点击的节点") resolve("更新处置节点成功,将天气 节点详情等信息保存到点击的节点")
}) // })
}).then((values)=>{ }).then((values)=>{
console.log(values) console.log(values)
postdata.level = putdata.level + 1 postdata.level = putdata.level + 1
new Promise((resolve,reject) => { new Promise((resolve,reject) => {
this.http.post(`/api/DisposalNodes`,postdata).subscribe(data => { this.http.post(`/api/ExamDisposalNodes`,postdata).subscribe(data => {
resolve(data) resolve(data)
}) })
}).then((data:any)=>{ }).then((data:any)=>{
@ -183,7 +183,7 @@ export class saveOneDialog {
disposalNodeId: data.id, disposalNodeId: data.id,
planComponentId: sessionStorage.getItem("planId"), planComponentId: sessionStorage.getItem("planId"),
} }
this.http.post(`/api/DisposalNodeData`,objData).subscribe(data => { this.http.post(`/api/ExamDisposalNodeData`,objData).subscribe(data => {
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
config.verticalPosition = 'top'; config.verticalPosition = 'top';
config.duration = 3000 config.duration = 3000
@ -255,7 +255,7 @@ export class saveOneDialog {
dispositionNodeData.notes = this.canvasData.selectPanelPointBaseData.notes dispositionNodeData.notes = this.canvasData.selectPanelPointBaseData.notes
//1.先创建一个处置节点 然后 .then 2.创建数据节点到刚创建的处置节点 3.然后拿着创建好的数据节点的id 将平面图data保存 //1.先创建一个处置节点 然后 .then 2.创建数据节点到刚创建的处置节点 3.然后拿着创建好的数据节点的id 将平面图data保存
new Promise((resolve,reject) => { new Promise((resolve,reject) => {
this.http.post("/api/DisposalNodes",dispositionNodeData).subscribe((data:any) => { this.http.post("/api/ExamDisposalNodes",dispositionNodeData).subscribe((data:any) => {
resolve(data.id) resolve(data.id)
}) })
}).then((id) => { }).then((id) => {
@ -264,7 +264,7 @@ export class saveOneDialog {
new Promise((resolve,reject) => { new Promise((resolve,reject) => {
postdata.parentId = id postdata.parentId = id
postdata.level = dispositionNodeData.level + 1 postdata.level = dispositionNodeData.level + 1
this.http.post("/api/DisposalNodes",postdata).subscribe((data:any) => { this.http.post("/api/ExamDisposalNodes",postdata).subscribe((data:any) => {
resolve(data) resolve(data)
}) })
}).then((data:any) => { }).then((data:any) => {
@ -280,7 +280,7 @@ export class saveOneDialog {
planComponentId: sessionStorage.getItem("planId"), planComponentId: sessionStorage.getItem("planId"),
} }
this.http.post(`/api/DisposalNodeData`,objData).subscribe(data => { this.http.post(`/api/ExamDisposalNodeData`,objData).subscribe(data => {
const config = new MatSnackBarConfig(); const config = new MatSnackBarConfig();
config.verticalPosition = 'top'; config.verticalPosition = 'top';
config.duration = 3000 config.duration = 3000

14
src/app/ui/collection-tools/uploadDisposalNodes.html

@ -0,0 +1,14 @@
<div id="disposalNodeTree">
<div style="max-height: 500px;overflow-x: hidden;overflow-y: auto;margin-bottom: 25px;width: 330px;padding-right: 10px;">
<nz-tree #nzTreeComponent [nzData]="treeData" nzCheckable nzMultiple [nzTreeTemplate]="nzTreeTemplate"></nz-tree>
<ng-template #nzTreeTemplate let-node let-origin="origin">
<div id="terrNodePublic">
<label title="{{node.title}}" class="overflowText textNode">{{node.title}}</label>
</div>
</ng-template>
</div>
<div style="text-align: center;">
<button mat-stroked-button style="margin-right: 15px;border: none;background: #07CDCF;color: #fff;" (click)='submit()'>确定</button>
<button mat-stroked-button style="margin-left: 15px;border: none;background: #dfe0e0;" mat-dialog-close>取消</button>
</div>
</div>

51
src/app/ui/collection-tools/uploadQuestions.html

@ -1,41 +1,30 @@
<div style="min-width: 260px;"> <div style="min-width: 260px;" id="uploadfiretree">
<div style="text-align: center;font-weight: 550;">上传</div> <div style="text-align: center;font-weight: 550;">上传</div>
<div style="padding-left: 10px; font-size: 14px; font-weight: 550;margin: 5px 0;">设置分数</div>
<div style="margin-bottom: 25px;">
<input type="text" style="width: 100%;border-radius: 5px;height: 26px;background-color: #dfe0e0;" placeholder="请填写考试分数" [(ngModel)]="data.question.grade">
</div>
<div style="padding-left: 10px; font-size: 14px; font-weight: 550;margin: 5px 0;">考试要点</div> <div style="padding-left: 10px; font-size: 14px; font-weight: 550;margin: 5px 0;">考试要点</div>
<div style="margin-bottom: 25px;"> <div style="margin-bottom: 25px;">
<textarea style="width: 100%;background-color: #dfe0e0;border: none;outline: none;height: 50px;border-radius: 5px;resize: none;" placeholder="请填写考试要点" [(ngModel)]="data.question.keynote"></textarea> <textarea style="width: 100%;background-color: #dfe0e0;border: none;outline: none;height: 50px;border-radius: 5px;resize: none;" placeholder="请填写考试要点" [(ngModel)]="data.question.keynote"></textarea>
</div> </div>
<div style="padding-left: 10px; font-size: 14px; font-weight: 550;margin: 5px 0;">考核消防设施</div> <div style="padding-left: 10px; font-size: 14px; font-weight: 550;margin: 5px 0;">考核消防设施</div>
<div style="max-height: 200px;overflow-y: auto;margin-bottom: 25px;"> <div style="height: 200px;overflow-y: auto;margin-bottom: 25px;">
<!-- 消防列表树 --> <!-- 消防列表树 -->
<mat-tree [dataSource]="dataSource" [treeControl]="treeControl" cdkDropList [cdkDropListData]="dataSource"> <nz-tree
#nzTreeComponent
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;" matTreeNodePadding cdkTreeNodePaddingIndent='26' class="treeNode"> [nzData]="renderData"
<button mat-icon-button disabled></button> nzMultiple
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> [nzCheckedKeys]="defaultCheckedKeys"
{{node.name}} [nzExpandedKeys]="defaultExpandedKeys"
</span> [nzSelectedKeys]="defaultSelectedKeys"
<span *ngIf="node.isTemplate">({{node.children.length}})</span> (nzClick)="nzEvent($event)"
<mat-checkbox style="margin-left: auto;" color=primary></mat-checkbox> (nzExpandChange)="nzEvent($event)"
</mat-tree-node> (nzCheckBoxChange)="nzEvent($event)"
[nzTreeTemplate]="nzTreeTemplate"
<mat-tree-node cdkDrag cdkDragDisabled="false" [ngClass]="{'isLookPattern': !node.isLookPattern}" *matTreeNodeDef="let node;when: hasChild" matTreeNodePadding class="treeNode" > >
<button mat-icon-button matTreeNodeToggle [attr.aria-label]="'toggle ' + node.name"> </nz-tree>
<mat-icon class="mat-icon-rtl-mirror"> <ng-template #nzTreeTemplate let-node let-origin="origin">
{{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}} <div class="treeNodeTemplate">
</mat-icon> <label class="overflowText textNode">{{node.origin.name || node.origin.Name}}</label>
</button> </div>
<span title="{{node.name}}" [ngClass]="{'treeText': !node.isTemplate}"> </ng-template>
{{node.name}}
</span>
<span *ngIf="node.isTemplate && node.isNewElement">({{node.children.length}})</span>
<mat-checkbox style="margin-left: auto;" color=primary></mat-checkbox>
</mat-tree-node>
</mat-tree>
<!-- 消防列表树 --> <!-- 消防列表树 -->
</div> </div>
<div style="text-align: center;"> <div style="text-align: center;">

54
src/app/ui/create-exam/create-exam.component.html

@ -1,54 +0,0 @@
<div class="box">
<div class="createBtn">
<button mat-raised-button color="primary" (click)="createTest()">新增考题</button>
</div>
<div class="tablebox">
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8">
<ng-container matColumnDef="name">
<th mat-header-cell *matHeaderCellDef>试卷名称</th>
<td mat-cell *matCellDef="let element">{{element.name}}</td>
</ng-container>
<!-- Name Column -->
<ng-container matColumnDef="organization">
<th mat-header-cell *matHeaderCellDef>考核中队</th>
<td mat-cell *matCellDef="let element">{{element.organization}}</td>
</ng-container>
<!-- Weight Column -->
<ng-container matColumnDef="startTime">
<th mat-header-cell *matHeaderCellDef>开考时间</th>
<td mat-cell *matCellDef="let element">{{element.startTime}}</td>
</ng-container>
<!-- Symbol Column -->
<ng-container matColumnDef="overTime">
<th mat-header-cell *matHeaderCellDef>结束时间</th>
<td mat-cell *matCellDef="let element">{{element.overTime}}</td>
</ng-container>
<!-- Symbol Column -->
<ng-container matColumnDef="testState">
<th mat-header-cell *matHeaderCellDef>考试状态</th>
<td mat-cell *matCellDef="let element">
<i [ngClass]="{'green': element.testState == '2','red':element.testState == '3'}">
{{element.testState | testState}}
</i>
</td>
</ng-container>
<!-- Symbol Column -->
<ng-container matColumnDef="operation">
<th mat-header-cell *matHeaderCellDef>操作</th>
<td mat-cell *matCellDef="let element">
<span>编辑</span>
<span>详情</span>
<span [ngClass]="{'grey': element.testState == '2' || element.testState == '3'}">删除</span>
</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
</table>
<mat-paginator [pageSize]="10"></mat-paginator>
</div>
</div>

52
src/app/ui/create-exam/create-exam.component.scss

@ -1,52 +0,0 @@
.box{
width:100%;
height: 100%;
margin: 0 auto;
.createBtn{
height: 60px;
line-height: 60px;
margin-bottom: 6px;
margin-left: 20px;
}
.tablebox{
table{
width: 100%;
}
}
}
.mat-header-cell{
text-align: center;
}
.mat-cell{
text-align: center;
span{
color: #0000BF;
margin: 0 3px;
cursor: pointer;
}
span:hover{
text-decoration:underline
}
.grey{
color: grey;
pointer-events: none;
}
.green{
color: #70b603;
}
.red{
color: #d9001b;
}
}
.dialog{
.title{
h1{
font-size: 25px;
font-weight: 900;
text-align: center;
}
}
}

25
src/app/ui/create-exam/create-exam.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { CreateExamComponent } from './create-exam.component';
describe('CreateExamComponent', () => {
let component: CreateExamComponent;
let fixture: ComponentFixture<CreateExamComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ CreateExamComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(CreateExamComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

76
src/app/ui/create-exam/create-exam.component.ts

@ -1,76 +0,0 @@
import { Component, OnInit,Inject } from '@angular/core';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import {FormControl} from '@angular/forms';
const ELEMENT_DATA: any[] = [
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'1'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'1'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'2'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'2'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'2'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'2'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'2'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'3'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'3'},
{name: "富华酒店", organization: '浦东支队', startTime: "2020-09-19 10:00", overTime: '2020-09-19 12:00',testState:'3'},
];
@Component({
selector: 'app-create-exam',
templateUrl: './create-exam.component.html',
styleUrls: ['./create-exam.component.scss']
})
export class CreateExamComponent implements OnInit {
constructor(public dialog: MatDialog,public snackBar: MatSnackBar) { }
displayedColumns: string[] = ['name', 'organization', 'startTime', 'overTime', 'testState', 'operation'];
dataSource = ELEMENT_DATA;
ngOnInit(): void {
}
//新增考题弹出框
createTest(){
const dialogRef = this.dialog.open(CreateDialog, {
data: {}
});
dialogRef.afterClosed().subscribe(
data=>{
if(data){
}
}
);
}
}
// import getISOWeek from 'date-fns/getISOWeek';
//创建组织
@Component({
selector: 'CreateDialog',
templateUrl: './createDialog.html',
styleUrls: ['./create-exam.component.scss']
})
export class CreateDialog {
myControl = new FormControl();
constructor(
public dialogRef: MatDialogRef<CreateDialog>,
@Inject(MAT_DIALOG_DATA) public data,
public snackBar: MatSnackBar) {}
onNoClick(): void {
this.dialogRef.close();
}
onSubmit(value){
}
date = null;
onChange(result: Date[]): void {
console.log('onChange: ', result);
}
// getWeek(result: Date[]): void {
// console.log('week: ', result.map(getISOWeek));
// }
}

34
src/app/ui/create-exam/createDialog.html

@ -1,34 +0,0 @@
<div class="dialog">
<div class="title">
<h1>试卷新增</h1>
</div>
<form (ngSubmit)="onSubmit(form.value)" #form="ngForm" class="example-container">
<div>
<span>试卷名称</span>
<input id="name" name="name" type='text'
required
ngModel #name="ngModel">
</div>
<div>
<span>考核中队</span>
<input id="name" name="name" type='text'
required
ngModel #name="ngModel">
</div>
<div>
<span>考试时间</span>
<!-- <nz-range-picker id="date" name="date" [nzShowTime]="true" [(ngModel)]="date" (ngModelChange)="onChange($event)"></nz-range-picker> -->
</div>
<div class="btn">
<button type="submit" class="savebtn" mat-raised-button color="primary" [disabled]='form.invalid'>确定</button>
<button type="button" mat-button (click)="onNoClick()" mat-raised-button>取消</button>
</div>
</form>
</div>

40
src/app/ui/eharts-statistics/eharts-statistics.component.html

@ -1,40 +0,0 @@
<div class="content">
<div class="header">
<form #form="ngForm">
<div class="queryBox">
<div class="queryField" style="margin-right: 90px;">
<!-- <button type="button" mat-raised-button color="primary" style="margin-right: 10px;" (click)='goBack()'><mat-icon style="vertical-align: middle; font-size: 20px;">reply</mat-icon>返回</button> -->
<button type="button" mat-raised-button color="primary" (click)='queryAll()'>查看全部详情</button>
</div>
<!-- <div class="queryField">
<label style="margin-right: 10px;">开始时间:</label>
<input matInput [matDatepicker]="start" placeholder="请选择开始时间" readonly (dateChange)="startEvent($event)" [formControl]='startTime'>
<mat-datepicker-toggle matSuffix [for]="start"></mat-datepicker-toggle>
<mat-datepicker #start></mat-datepicker>
</div>
<div class="queryField">
<label style="margin-right: 10px;">结束时间:</label>
<input matInput [matDatepicker]="end" placeholder="请选择结束时间" readonly (dateChange)="endEvent($event)" [formControl]='endTime'>
<mat-datepicker-toggle matSuffix [for]="end"></mat-datepicker-toggle>
<mat-datepicker #end></mat-datepicker>
</div> -->
<div class="btnbox" style="margin-left: 90px;">
<button mat-raised-button color="primary" (click)='query()'>查询</button>
<button mat-raised-button style="margin-left: 10px;" type="button" (click)='getList()'>重置</button>
</div>
</div>
</form>
</div>
<div class="center" id="center"></div>
<div class="nofiles" *ngIf="!echartsData.length">
<span style="font-size: 14px;cursor: default;">暂无学习记录~</span>
</div>
</div>

50
src/app/ui/eharts-statistics/eharts-statistics.component.scss

@ -1,50 +0,0 @@
.content{
width: 100%;
height: 93%;
display: flex;
flex-direction: column;
}
.header {
padding: 10px;
box-sizing: border-box;
border-bottom: 1px solid #999;
.queryBox {
box-sizing: border-box;
padding: 5px 15px;
display: flex;
flex-direction: row;
flex-wrap: wrap;
align-items:center;
justify-content:center;
.queryField {
margin: 0 15px;
font-size: 14px;
input {
width: 180px;
height: 22px;
line-height: 22px;
}
}
.btnbox{
float: right;
}
} //queryBox
}
.center {
flex: 1;
box-sizing: border-box;
padding: 10px;
}
.nofiles{
background: url("../../../assets/images/nofiles.png") no-repeat scroll center 0 transparent;
padding-top: 150px;
width: 488px;
position: absolute;
left: 50%;
top: 50%;
text-align: center;
margin: -96px 0 0 -244px;
}

25
src/app/ui/eharts-statistics/eharts-statistics.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { EhartsStatisticsComponent } from './eharts-statistics.component';
describe('EhartsStatisticsComponent', () => {
let component: EhartsStatisticsComponent;
let fixture: ComponentFixture<EhartsStatisticsComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ EhartsStatisticsComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(EhartsStatisticsComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

228
src/app/ui/eharts-statistics/eharts-statistics.component.ts

@ -1,228 +0,0 @@
import { Component, OnInit } from '@angular/core';
import {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from '@angular/material/core';
import {MatDatepickerInputEvent} from '@angular/material/datepicker';
import { HttpClient } from '@angular/common/http';
import { FormControl } from '@angular/forms';
import { MatSnackBarConfig, MatSnackBar } from '@angular/material/snack-bar';
import { ActivatedRoute, Router } from '@angular/router';
declare var echarts : any;
@Component({
selector: 'app-eharts-statistics',
templateUrl: './eharts-statistics.component.html',
styleUrls: ['./eharts-statistics.component.scss'],
})
export class EhartsStatisticsComponent implements OnInit {
constructor(private adapter: DateAdapter<any>,private http:HttpClient,public snackBar: MatSnackBar,private route:ActivatedRoute,private router:Router) { }
ngOnInit(): void {
this.idCard = this.route.snapshot.queryParams.id || ''
this.idName = this.route.snapshot.queryParams.name || ''
this.adapter.setLocale('CH')
this.getList()
}
ngAfterViewInit(): void {
}
startTime:any; //查询开始时间
endTime:any; //查询结束时间
oneMonthDate:number = 30*24*60*60*1000; //一个月的时间戳
echartsData:any = []; //图表数据
idCard:string; //用户身份证
idName:string; //用户姓名
//初始化 + 重置
getList () {
this.startTime = new FormControl( new Date((new Date(new Date().getTime()-this.oneMonthDate)).toLocaleDateString()) )
this.endTime = new FormControl( new Date() )
let msg = {
Name: this.idCard,
// StartTime: new Date(new Date().getTime()-this.oneMonthDate).toLocaleDateString(),
// EndTime: new Date().toLocaleDateString(),
}
this.http.get('/api/StudyRecords/Statistics',{params:msg}).subscribe((data:any)=>{
this.echartsData = data
if (data.length) {
this.handleData(data)
} else { //数据为空时销毁图表
let chartHynyxf = echarts.init(document.getElementById('center'), 'skinUpp');
chartHynyxf.dispose();
}
})
}
//查询
query () {
let msg = {
Name: this.idCard,
StartTime: this.getTime(this.startTime.value), //开始时间
EndTime: this.getTime(this.endTime.value), //结束时间
}
this.http.get('/api/StudyRecords/Statistics',{params:msg}).subscribe((data:any)=>{
this.echartsData = data
if (data.length) {
this.handleData(data)
} else { //数据为空时销毁图表
let chartHynyxf = echarts.init(document.getElementById('center'), 'skinUpp');
chartHynyxf.dispose();
}
})
}
//查询全部详情
queryAll () {
this.router.navigate(['/home/learningrecorddetails'],{queryParams:{'Catalog': '','id':this.idCard}});
}
//返回上一页
goBack () {
history.go(-1)
}
//处理时间 传入 new Date()格式
getTime(date){
let year = date.getFullYear(); //年
let month = date.getMonth() + 1; //月
let day = date.getDate(); //日
let hour = date.getHours() //时
let min = date.getMinutes(); //分
let seconds = date.getSeconds(); //秒
return year+'-'+month+'-'+ day + " "+ hour +':'+ min +':'+ seconds;
}
//选择开始时间
startEvent (e: MatDatepickerInputEvent<Date>) {
let nowTime = new Date()
if (nowTime < e.value) {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('选择时间不能大于现在时间段','确定',config);
this.startTime = new FormControl( new Date(new Date().toLocaleDateString()) )
} else {
this.startTime = new FormControl(e.value)
}
}
//选择结束时间
endEvent (e: MatDatepickerInputEvent<Date>) {
let oneDay:number = 86399000; //一天的毫秒数
let selectDay = (e.value).toLocaleDateString() //选择的年月日
let newDay = (new Date()).toLocaleDateString() //现在的年月日
let nowTime = new Date() //现在的时间
if (nowTime < e.value && selectDay!=newDay) { //选择时间段大于现在时间段时
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('选择时间不能大于现在时间段','确定',config);
this.endTime = new FormControl( new Date() )
} else if (nowTime > e.value && selectDay!=newDay) { //正常情况下 时间+1天
this.endTime = new FormControl( new Date(e.value.getTime()+oneDay) )
} else if ( selectDay == newDay ) { //选择时间段是今天时
this.endTime = new FormControl( new Date() )
}
}
//处理图表数据
handleData (data) {
let postNames = [] //y轴坐标
let catalogs = [] //学习目标
let counts = [] //统计次数
let newData = data.sort( function (a,b) {
return b.count - a.count
} )
newData.forEach(element => {
postNames.push(element.postName ? element.postName : '暂无数据')
catalogs.push(element.catalog ? element.catalog : '暂无数据')
counts.push(element.count ? element.count : 0)
});
this.echartsInit(postNames,catalogs,counts)
}
//图表初始化
echartsInit (postNames,catalogs,counts) {
let that = this
let chartHynyxf = echarts.init(document.getElementById('center'), 'skinUpp');
let option = {
title: {
text: that.idName,
left:45,
top:20
},
tooltip: {
trigger: 'axis',
axisPointer: {type: 'shadow'}
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
xAxis: {
show: false,
type: 'value',
boundaryGap: [0, 0.01]
},
yAxis: {
inverse: true,
"axisLine":{ //y轴
"show":false
},
"axisTick":{ //y轴刻度线
"show":false,
},
"splitLine": { //网格线
"show": false
},
type: 'category',
data: postNames,
max: 15
},
series: [
{
type: 'bar',
data: counts,
barMinWidth: 10, // 最小宽度
barMaxWidth: 30, // 最大宽度
barCategoryGap: 5,
itemStyle:{
normal:{
color:'#40B4E8',
barBorderRadius:[10, 10, 10, 10],
label: {
formatter: function (e) {
return `${catalogs[e.dataIndex]}`+` (统计次数: ${e.value})`
},
show: true,
position: 'insideLeft',
textStyle: { color: '#555'},
fontSize: 14,
fontWeight: 550
},
},
} //itemStyle
},
] //series
};
chartHynyxf.setOption(option);
//柱状图点击事件
chartHynyxf.on('click', function(e) {
that.router.navigate(['/home/learningrecorddetails'],{queryParams:{'Catalog':catalogs[e.dataIndex],'id':that.idCard,'PostName':e.name}});
});
}
}

1
src/app/ui/join-exam/join-exam.component.html

@ -1 +0,0 @@
<p>参加考试!</p>

0
src/app/ui/join-exam/join-exam.component.scss

25
src/app/ui/join-exam/join-exam.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { JoinExamComponent } from './join-exam.component';
describe('JoinExamComponent', () => {
let component: JoinExamComponent;
let fixture: ComponentFixture<JoinExamComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ JoinExamComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(JoinExamComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

15
src/app/ui/join-exam/join-exam.component.ts

@ -1,15 +0,0 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-join-exam',
templateUrl: './join-exam.component.html',
styleUrls: ['./join-exam.component.scss']
})
export class JoinExamComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
}

49
src/app/ui/learning-record-details/learning-record-details.component.html

@ -1,49 +0,0 @@
<div style="height: 100%; width: 100%;">
<div class="topbox">
<div class="backtop">
<button type="button" mat-raised-button color="primary" (click)="backtop()"><mat-icon style="vertical-align: middle;font-size: 20px;">reply</mat-icon>返回</button>
</div>
<div class="datasearch">
<!-- <div class="starttime">
<span>开始时间 :</span>
<input style="width: 220px; height:21px;line-height: 21px;font-size: 15px;" matInput [matDatepicker]="dp" readonly [formControl]="startdate">
<mat-datepicker-toggle matSuffix [for]="dp"></mat-datepicker-toggle>
<mat-datepicker #dp disabled="false"></mat-datepicker>
</div>
<div class="endtime">
<span>结束时间 :</span>
<input style="width: 220px; height:21px;line-height: 21px;font-size: 15px;" matInput [matDatepicker]="dp2" readonly [formControl]="enddate">
<mat-datepicker-toggle matSuffix [for]="dp2"></mat-datepicker-toggle>
<mat-datepicker #dp2 disabled="false"></mat-datepicker>
</div> -->
</div>
<div class="btnbox">
<button type="button" mat-raised-button color="primary" (click)="onSubmit()">查询</button>
<button type="button" mat-raised-button (click)="reset()">重置</button>
</div>
</div>
<mat-divider></mat-divider>
<div class="listbox" [hidden]="noRecord">
<ul>
<li *ngFor="let item of recordList;let key = index">
<p class="timeTitle" *ngIf="key ==0 || item.time != recordList[key - 1].time">{{item.time}}</p>
<span class="listitem">
<span style="margin-right: 5px;">{{item.time2}}</span>
{{item.operation}} : {{item.target | name3}}
</span>
</li>
</ul>
<mat-paginator
[length]="length"
[pageSize]="pageSize"
(page)="chagePage($event)">
</mat-paginator>
</div>
<div class="nofiles" *ngIf="noRecord">
<span style="font-size: 14px;cursor: default;">该时间段未查询到学习记录~</span>
</div>
</div>

57
src/app/ui/learning-record-details/learning-record-details.component.scss

@ -1,57 +0,0 @@
.topbox{
display: flex;
width: 100%;
height:7%;
line-height: 66px;
// border-bottom: 1px solid gray;
justify-content: space-around;
.datasearch{
display: flex;
div{
margin: 0 10px;
span{
margin-right: 5px;
}
mat-form-field{
input{
padding-left: 3px;
}
}
}
}
.btnbox{
button{
margin: 0 10px;
}
}
}
.listbox{
margin-top: 18px;
margin-left: 26%;
height: 84%;
overflow-y: auto;
.timeTitle{
font-weight: 800;
font-size: 18px;
}
.listitem{
margin-left: 80px;
font-size: 16px;
line-height: 30px;
}
}
.mat-paginator {
background-color: hsla(0,0%,100%,0);
padding-right: 10%;
}
.nofiles{
background: url("../../../assets/images/nofiles.png") no-repeat scroll center 0 transparent;
padding-top: 150px;
width: 488px;
position: absolute;
left: 50%;
top: 50%;
text-align: center;
margin: -88px 0 0 -244px;
}

188
src/app/ui/learning-record-details/learning-record-details.component.ts

@ -1,188 +0,0 @@
import { Component, OnInit ,ViewChild} from '@angular/core';
import {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from '@angular/material/core';
import {MatDatepicker} from '@angular/material/datepicker';
import {FormControl} from '@angular/forms';
import {HttpClient} from '@angular/common/http';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { MatPaginator } from '@angular/material/paginator';
import { PageEvent } from '@angular/material/paginator';
import { Router,ActivatedRoute } from '@angular/router'
@Component({
selector: 'app-learning-record-details',
templateUrl: './learning-record-details.component.html',
styleUrls: ['./learning-record-details.component.scss']
})
export class LearningRecordDetailsComponent implements OnInit {
startdate:any //开始时间
enddate:any //结束时间
constructor(private adapter: DateAdapter<any>,private http:HttpClient,public snackBar: MatSnackBar,private router:Router,private route:ActivatedRoute) { }
lastdate:any //上个月日期
startTime:any //开始时间查询条件
endTime:any //结束时间查询条件
Catalog:any = this.route.snapshot.queryParams.Catalog || "" //目录
PageNumber:any = 1//当前页数
id:any = this.route.snapshot.queryParams.id//身份证
PostName:any = this.route.snapshot.queryParams.PostName || "" //传过来的职务名称
recordList:any = false//渲染的100条列表
oneMonthDate:number = 30*24*60*60*1000; //一个月的时间戳
noRecord:boolean
//分页
@ViewChild(MatPaginator, {static: true})
pageEvent: PageEvent;
paginator: MatPaginator;
length:any; //共多少条数据
pageSize:any; //每页条数
// pageSizeOptions: number[] = [10] //设置每页条数
pageNumber:number = 1; //第几页
ngOnInit(): void {
this.adapter.setLocale('CH');
let nowdate = new Date().toLocaleDateString() //本月日期 2020/07/11 形式
this.lastdate = new Date(new Date().getTime()-this.oneMonthDate).toLocaleDateString() //上个月日期 2020/06/11 形式
this.startdate = new FormControl(new Date(this.lastdate)); //日历开始时间显示
this.enddate = new FormControl(new Date()); //日历结束时间显示
this.startTime = this.getTIme(new Date(this.lastdate))
this.endTime = this.getTIme(new Date())
this.getAllStudyRecords()
}
//分页切换
chagePage (e) {
this.pageNumber = e.pageIndex+1
let date:any = new Date()
let data = {
Name : this.id,
StartTime : this.startTime,
EndTime : this.endTime,
Catalog : this.Catalog,
PageNumber : String(this.pageNumber),
PageSize:"100",
PostName : this.PostName
}
this.http.get("/api/StudyRecords",{params:data}).subscribe((data:any) => {
this.recordList = data.items
if(data.items.length == 0){
this.noRecord = true
}else{
this.noRecord = false
}
this.recordList.forEach((item) => {
item.time = item.creationTime.substring(0,10)
item.time2 = item.creationTime.substring(11,16)
})
this.length = data.totalCount
this.pageSize = data.pageSize
})
}
//传入 new Date()格式 将日期变为 年月日时分秒
getTIme(date){
let year = date.getFullYear(); //年
let month = date.getMonth() + 1; //月
let day = date.getDate(); //日
let hour = date.getHours() //时
let min = date.getMinutes(); //分
let seconds = date.getSeconds(); //秒
return year+'-'+month+'-'+ day + " "+ hour +':'+ min +':'+ seconds;
}
//初始获得所有学习记录
getAllStudyRecords(){
let date:any = new Date()
let data = {
Name : this.id,
Catalog : this.Catalog || "",
PageNumber : this.PageNumber,
PageSize:"100",
PostName:this.PostName
}
this.http.get("/api/StudyRecords",{params:data}).subscribe((data:any) => {
this.recordList = data.items
if(data.items.length == 0){
this.noRecord = true
}else{
this.noRecord = false
}
this.recordList.forEach((item) => {
item.time = item.creationTime.substring(0,10)
item.time2 = item.creationTime.substring(11,16)
})
this.length = data.totalCount
this.pageSize = data.pageSize
this.pageEvent.pageIndex = 0
})
}
//返回上一页
backtop(){
history.go(-1)
}
//带查询时间获得所有学习记录
getAllStudyRecords2(){
let date:any = new Date()
let data = {
Name : this.id,
StartTime : this.startTime,
EndTime : this.endTime,
Catalog : this.Catalog || "",
PageNumber : this.PageNumber,
PageSize:"100",
PostName:this.PostName
}
this.http.get("/api/StudyRecords",{params:data}).subscribe((data:any) => {
this.recordList = data.items
if(data.items.length == 0){
this.noRecord = true
}else{
this.noRecord = false
}
this.recordList.forEach((item) => {
item.time = item.creationTime.substring(0,10)
item.time2 = item.creationTime.substring(11,16)
})
this.length = data.totalCount
this.pageSize = data.pageSize
this.pageEvent.pageIndex = 0
})
}
//
//查询
onSubmit(){
if(this.startdate.value > this.enddate.value){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('起始时间大于结束时间','确定',config);
}
if(this.enddate.value.toLocaleDateString() == new Date().toLocaleDateString() || this.enddate.value > new Date()){
this.enddate.value = new Date()
}
if(this.enddate.value < new Date() && this.enddate.value.toLocaleDateString() != new Date().toLocaleDateString()){
this.enddate.value = new Date(this.enddate.value.getTime() + 24*60*60*1000)
}
this.startTime = this.getTIme(this.startdate.value)
this.endTime = this.getTIme(this.enddate.value)
this.getAllStudyRecords2()
}
//重置
reset(){
this.startdate = new FormControl(new Date(this.lastdate)); //日历开始时间显示
this.enddate = new FormControl(new Date()); //日历结束时间显示
this.startTime = this.getTIme(this.startdate.value)
this.endTime = this.getTIme(this.enddate.value)
this.getAllStudyRecords()
}
}

1
src/app/ui/look-over-test/look-over-test.component.html

@ -1 +0,0 @@
<p>阅卷</p>

0
src/app/ui/look-over-test/look-over-test.component.scss

25
src/app/ui/look-over-test/look-over-test.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { LookOverTestComponent } from './look-over-test.component';
describe('LookOverTestComponent', () => {
let component: LookOverTestComponent;
let fixture: ComponentFixture<LookOverTestComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ LookOverTestComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(LookOverTestComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

15
src/app/ui/look-over-test/look-over-test.component.ts

@ -1,15 +0,0 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-look-over-test',
templateUrl: './look-over-test.component.html',
styleUrls: ['./look-over-test.component.scss']
})
export class LookOverTestComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
}

1
src/app/ui/statistic-analysis/statistic-analysis.component.html

@ -1 +0,0 @@
<p>统计分析</p>

0
src/app/ui/statistic-analysis/statistic-analysis.component.scss

25
src/app/ui/statistic-analysis/statistic-analysis.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { StatisticAnalysisComponent } from './statistic-analysis.component';
describe('StatisticAnalysisComponent', () => {
let component: StatisticAnalysisComponent;
let fixture: ComponentFixture<StatisticAnalysisComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ StatisticAnalysisComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(StatisticAnalysisComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

15
src/app/ui/statistic-analysis/statistic-analysis.component.ts

@ -1,15 +0,0 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-statistic-analysis',
templateUrl: './statistic-analysis.component.html',
styleUrls: ['./statistic-analysis.component.scss']
})
export class StatisticAnalysisComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
}

1
src/app/ui/test-records/test-records.component.html

@ -1 +0,0 @@
<p>考试记录!</p>

0
src/app/ui/test-records/test-records.component.scss

25
src/app/ui/test-records/test-records.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { TestRecordsComponent } from './test-records.component';
describe('TestRecordsComponent', () => {
let component: TestRecordsComponent;
let fixture: ComponentFixture<TestRecordsComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ TestRecordsComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(TestRecordsComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

15
src/app/ui/test-records/test-records.component.ts

@ -1,15 +0,0 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-test-records',
templateUrl: './test-records.component.html',
styleUrls: ['./test-records.component.scss']
})
export class TestRecordsComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
}

20
src/app/ui/ui-routing.module.ts

@ -1,25 +1,11 @@
import { Routes, RouterModule } from '@angular/router'; import { Routes, RouterModule } from '@angular/router';
import { NgModule } from '@angular/core'; import { NgModule } from '@angular/core';
import { AllFileComponent } from './all-file/all-file.component';
import { EnterpriseuserComponent } from './enterpriseuser/enterpriseuser.component';
import { TeacherManagementComponent } from './teacherManagement/enterpriseuser.component'; import { TeacherManagementComponent } from './teacherManagement/enterpriseuser.component';
import {EhartsStatisticsComponent} from './eharts-statistics/eharts-statistics.component' import { EnterpriseuserComponent } from './enterpriseuser/enterpriseuser.component';
import { LearningRecordDetailsComponent } from './learning-record-details/learning-record-details.component';
import { CreateExamComponent } from './create-exam/create-exam.component';
import { LookOverTestComponent } from './look-over-test/look-over-test.component';
import { StatisticAnalysisComponent } from './statistic-analysis/statistic-analysis.component';
import { JoinExamComponent } from './join-exam/join-exam.component';
import { TestRecordsComponent } from './test-records/test-records.component';
const routes: Routes = [ const routes: Routes = [
{ path: '', component:CreateExamComponent }, { path: 'teachear', component:TeacherManagementComponent }, //管理员 教员页面
{ path: 'createexam', component:CreateExamComponent }, { path: 'examinee', component:EnterpriseuserComponent }, //管理员 考生页面
{ path: 'looktest', component:LookOverTestComponent },
{ path: 'statisticAnalysis', component:StatisticAnalysisComponent },
{ path: 'joinExam', component:JoinExamComponent },
{ path: 'testRecords', component:TestRecordsComponent },
{ path: 'teachear', component:TeacherManagementComponent }, //管理员 教员页面
{ path: 'examinee', component:EnterpriseuserComponent }, //管理员 考生页面
] ]
@NgModule({ @NgModule({
imports: [RouterModule.forChild(routes)], imports: [RouterModule.forChild(routes)],

27
src/app/ui/ui.module.ts

@ -45,35 +45,25 @@ import { ReactiveFormsModule, FormsModule } from '@angular/forms';
import { MatFormFieldModule } from '@angular/material/form-field'; import { MatFormFieldModule } from '@angular/material/form-field';
import { MatPaginatorIntl } from '@angular/material/paginator'; import { MatPaginatorIntl } from '@angular/material/paginator';
import { ChangepasswordComponent } from './changepassword/changepassword.component'; import { ChangepasswordComponent } from './changepassword/changepassword.component';
import { SizePipe , NamePipe,NamePipe2, NamePipe3, testState} from '../pipes/size.pipe'; import { testState} from '../pipes/size.pipe';
import {ConfirmpswDirective} from './changepassword/equal-validator.directive'; import {ConfirmpswDirective} from './changepassword/equal-validator.directive';
import { FileUploadModule } from 'ng2-file-upload' import { FileUploadModule } from 'ng2-file-upload'
import { AllFileComponent, ViewDetails, FolderDialog } from './all-file/all-file.component';
import { ChangeuserdataComponent } from './changeuserdata/changeuserdata.component'; import { ChangeuserdataComponent } from './changeuserdata/changeuserdata.component';
import { IsLoginService } from '../is-login.service'; import { IsLoginService } from '../is-login.service';
import { UploadFilesComponent } from './upload-files/upload-files.component';
import {AddEnterpriserUser} from './enterpriseuser/addenterpriseuser.component';
import {EnterpriseuserComponent,editenterpriseuser,seeenterpriseuser} from './enterpriseuser/enterpriseuser.component'
import { myPaginator } from "./my-paginator" import { myPaginator } from "./my-paginator"
import { TeacherManagementComponent, editTeacher, seeTeacher } from './teacherManagement/enterpriseuser.component';
import { AddTeacher } from './teacherManagement/addenterpriseuser.component';
import { LearningRecordDetailsComponent } from './learning-record-details/learning-record-details.component';
import {EhartsStatisticsComponent} from './eharts-statistics/eharts-statistics.component';
import { CreateExamComponent, CreateDialog } from './create-exam/create-exam.component';
import { LookOverTestComponent } from './look-over-test/look-over-test.component';
import { StatisticAnalysisComponent } from './statistic-analysis/statistic-analysis.component';
import { JoinExamComponent } from './join-exam/join-exam.component';
import { TestRecordsComponent } from './test-records/test-records.component'
import { NzDatePickerModule } from 'ng-zorro-antd/date-picker'; import { NzDatePickerModule } from 'ng-zorro-antd/date-picker';
import {CollectionToolsComponent,CreateBuilding,EditBuilding,ViewDetailss,} from './collection-tools/collection-tools.component' import {CollectionToolsComponent,CreateBuilding,EditBuilding,ViewDetailss,} from './collection-tools/collection-tools.component'
import {leftFunctionalDomainComponent,editPlaneFigureComponent,addDisposalNodeComponent,editDisposalNodeComponent} from './collection-tools/leftFunctionalDomain' import {leftFunctionalDomainComponent,editPlaneFigureComponent,addDisposalNodeComponent,editDisposalNodeComponent} from './collection-tools/leftFunctionalDomain'
import {saveOneDialog,saveTwoDialog} from './collection-tools/save' import {saveOneDialog,saveTwoDialog} from './collection-tools/save'
import {WorkingAreaComponent} from '../working-area/working-area.component' import {WorkingAreaComponent} from '../working-area/working-area.component'
import { NzTreeModule } from 'ng-zorro-antd/tree'; import { NzTreeModule } from 'ng-zorro-antd/tree';
import { examinationQuestions,uploadQuestions } from './collection-tools/examinationQuestions' import { examinationQuestions,uploadQuestions,uploadDisposalNodes } from './collection-tools/examinationQuestions'
import {AddEnterpriserUser} from './enterpriseuser/addenterpriseuser.component'
import {EnterpriseuserComponent,editenterpriseuser,seeenterpriseuser} from './enterpriseuser/enterpriseuser.component'
import {AddTeacher} from './teacherManagement/addenterpriseuser.component'
import {TeacherManagementComponent,editTeacher,seeTeacher} from './teacherManagement/enterpriseuser.component'
@NgModule({ @NgModule({
declarations: [FolderDialog,ViewDetails,ChangepasswordComponent,SizePipe,NamePipe,NamePipe2,NamePipe3,ConfirmpswDirective, AllFileComponent, ChangeuserdataComponent, UploadFilesComponent,AddEnterpriserUser,EnterpriseuserComponent,editenterpriseuser,seeenterpriseuser,TeacherManagementComponent,editTeacher,AddTeacher,seeTeacher, LearningRecordDetailsComponent, EhartsStatisticsComponent, CreateExamComponent, LookOverTestComponent, StatisticAnalysisComponent, JoinExamComponent, TestRecordsComponent,testState,CreateDialog,CollectionToolsComponent,CreateBuilding,EditBuilding,ViewDetailss,leftFunctionalDomainComponent,editPlaneFigureComponent,addDisposalNodeComponent,editDisposalNodeComponent,saveOneDialog,saveTwoDialog,WorkingAreaComponent,examinationQuestions,uploadQuestions], declarations: [ChangepasswordComponent,ConfirmpswDirective, ChangeuserdataComponent,testState,CollectionToolsComponent,CreateBuilding,EditBuilding,ViewDetailss,leftFunctionalDomainComponent,editPlaneFigureComponent,addDisposalNodeComponent,editDisposalNodeComponent,saveOneDialog,saveTwoDialog,WorkingAreaComponent,examinationQuestions,uploadQuestions,AddEnterpriserUser,EnterpriseuserComponent,editenterpriseuser,seeenterpriseuser,AddTeacher,TeacherManagementComponent,editTeacher,seeTeacher,uploadDisposalNodes],
imports: [ imports: [
NzDatePickerModule, NzDatePickerModule,
CommonModule, CommonModule,
@ -124,9 +114,6 @@ import { examinationQuestions,uploadQuestions } from './collection-tools/examina
FileUploadModule, FileUploadModule,
NzTreeModule NzTreeModule
], ],
exports: [
AllFileComponent
],
providers: [ { provide: MatPaginatorIntl, useValue: myPaginator() } ] providers: [ { provide: MatPaginatorIntl, useValue: myPaginator() } ]
}) })

23
src/app/ui/upload-files/upload-files.component.html

@ -1,23 +0,0 @@
<div class="content">
<div class="header">
<label style="font-size: 14px;">{{thatFile.uploadProgress2}} 上传中...</label>
<button mat-raised-button style="margin-left: 60%;" *ngIf="isShow" (click)='toggle()'><mat-icon>keyboard_arrow_down</mat-icon></button>
<button mat-raised-button style="margin-left: 60%;" *ngIf="!isShow" (click)='toggle()'><mat-icon>keyboard_arrow_up</mat-icon></button>
</div>
<div style="margin-top: 10px; border-top: 1px solid #e2e2e2;" [hidden]="!isShow">
<p class="dataStyle" *ngFor="let item of filesData">
<span class="dataName">{{item.name}}</span>
<span class="dataSize">{{item.size | size}}</span>
<span class="dataState" style="position: relative;">
<label *ngIf="item.state==0">等待中...</label>
<label *ngIf="item.state==1"><mat-spinner diameter=24></mat-spinner></label>
<label *ngIf="item.state==2" style="color: green;"></label>
</span>
<span class="dataState" *ngIf="item.state==1 && item.size > 5242880" style="font-size: 22px; cursor:pointer;" title='取消上传' (click)='cancel()'> × </span>
</p>
</div>
</div>

72
src/app/ui/upload-files/upload-files.component.scss

@ -1,72 +0,0 @@
.content {
width: 100%;
max-height: 250px;
overflow-y: auto;
overflow-x: hidden;
background-color: #fff;
border: 1px solid #e2e2e2;
box-shadow: 0 0 10px #ccc;
border-radius: 10px;
box-sizing: border-box;
padding: 10px;
}
.header {
box-sizing: border-box;
height: 30px;
line-height: 30px;
button {
height: 30px;
line-height: 30px;
}
}
//每一行数据
.dataStyle {
height: 30px;
line-height: 30px;
margin: 5px 0;
box-sizing: border-box;
padding: 0 3px;
span{
display: inline-block;
font-size: 12px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
line-height: 30px;
}
.dataName {
width: 40%;
margin-right: 10px;
}
.dataSize {
width: 20%;
}
.dataState {
width: 15%;
}
}
.dataStyle:hover {
background-color: #e2e2e2;
}
//滚动条样式
.content::-webkit-scrollbar {
/*滚动条整体样式*/
width : 6px; /*高宽分别对应横竖滚动条的尺寸*/
height: 1px;
}
.content::-webkit-scrollbar-thumb {
/*滚动条里面小方块*/
border-radius: 10px;
box-shadow : inset 0 0 5px #999;
background : #535353;
}
.content::-webkit-scrollbar-track {
/*滚动条里面轨道*/
box-shadow : inset 0 0 5px #999;
border-radius: 10px;
background : #ededed;
}

25
src/app/ui/upload-files/upload-files.component.spec.ts

@ -1,25 +0,0 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { UploadFilesComponent } from './upload-files.component';
describe('UploadFilesComponent', () => {
let component: UploadFilesComponent;
let fixture: ComponentFixture<UploadFilesComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ UploadFilesComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(UploadFilesComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});

67
src/app/ui/upload-files/upload-files.component.ts

@ -1,67 +0,0 @@
import { Component, OnInit,Input } from '@angular/core';
@Component({
selector: 'app-upload-files',
templateUrl: './upload-files.component.html',
styleUrls: ['./upload-files.component.scss']
})
export class UploadFilesComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
@Input( ) thatFile:any //父组件
isShow:boolean = true; //弹出框最大/化最小化
filesData:any = []; //上传文件夹数据
//上传文件夹弹窗显隐
toggle () {
this.isShow = !this.isShow
}
//处理数据格式
handleData () {
this.filesData = []
for (let i=0; i<this.thatFile.fileArr.length; i++) {
this.thatFile.fileArr[i].state = 0
this.filesData.push(this.thatFile.fileArr[i])
}
}
//当前上传文件正在上传
uploading (e) {
this.filesData.forEach(element => {
if (element.name == e.name) {
element.state = 1
return
}
});
}
//当前上传文件上传成功
endUpload (e) {
this.filesData.forEach(element => {
if (element.name == e.name) {
element.state = 2
return
}
});
}
//清空数据
delete () {
this.filesData = []
}
//取消上传
cancel () {
this.thatFile.cancel2()
}
}

64
src/app/working-area/model/wallSpace.ts → src/app/working-area/model/axArrowConnector.ts

@ -1,10 +1,11 @@
import { WorkingAreaComponent } from '../working-area.component'; import { WorkingAreaComponent } from '../working-area.component';
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
import { AxShape } from './axShape';
/** /**
* *
*/ */
export class WallSpace extends PIXI.Container { export class AxArrowConnector extends AxShape {
line: PIXI.Graphics; line: PIXI.Graphics;
text: PIXI.Text; text: PIXI.Text;
@ -26,8 +27,9 @@ export class WallSpace extends PIXI.Container {
}); });
pts: PIXI.Point[]; pts: PIXI.Point[];
constructor(public assetData: any, private workingArea: WorkingAreaComponent) { constructor(assetData: any, workingArea: WorkingAreaComponent) {
super(); super(assetData, workingArea);
this.name = assetData.Id;
this.text = new PIXI.Text(this.assetData.Name this.text = new PIXI.Text(this.assetData.Name
+ '\r\n' + '\r\n'
+ this.assetData.PropertyInfos?.find((item: { PropertyName: string; }) => + this.assetData.PropertyInfos?.find((item: { PropertyName: string; }) =>
@ -44,22 +46,26 @@ export class WallSpace extends PIXI.Container {
* *
*/ */
public refresh(c: PIXI.Graphics, pts: PIXI.Point[]): void { public refresh(c: PIXI.Graphics, pts: PIXI.Point[]): void {
if (pts.length < 2) {
return;
}
this.text.position = pts[0];
const strokeWidth = 1; const strokeWidth = 1;
const startWidth = 30 + strokeWidth; const startWidth = 30 + strokeWidth;
const endWidth = 30 + strokeWidth; const endWidth = 30 + strokeWidth;
const edgeWidth = 10; const edgeWidth = this.assetData.Thickness === 0?10:this.assetData.Thickness; // 宽度
const openEnded = false; const openEnded = false;
const markerStart = false; const markerStart = false;// 起始箭头
const markerEnd = true; const markerEnd = false;// 结束箭头
const spacing = (openEnded) ? 0 : 0 + strokeWidth / 2; const spacing = (openEnded) ? 0 : 0 + strokeWidth / 2;
const startSize = 30 + strokeWidth; const startSize = 30 + strokeWidth;
const endSize = 30 + strokeWidth; const endSize = 30 + strokeWidth;
const isRounded = true; const isRounded = true;
const lineColor = 0x000000;
const fillColor: number = this.assetData.Color.substring(0, 7).replace('#', '0x');;
// Base vector (between first points)
const pe = pts[pts.length - 1]; const pe = pts[pts.length - 1];
// Finds first non-overlapping point
let i0 = 1; let i0 = 1;
while (i0 < pts.length - 1 && pts[i0].x === pts[0].x && pts[i0].y === pts[0].y) { while (i0 < pts.length - 1 && pts[i0].x === pts[0].x && pts[i0].y === pts[0].y) {
@ -73,8 +79,6 @@ export class WallSpace extends PIXI.Container {
if (dist === 0) { if (dist === 0) {
return; return;
} }
// Computes the norm and the inverse norm
let nx = dx / dist; let nx = dx / dist;
let nx1 = nx; let nx1 = nx;
let nx2 = nx; let nx2 = nx;
@ -84,7 +88,6 @@ export class WallSpace extends PIXI.Container {
let orthx = edgeWidth * ny; let orthx = edgeWidth * ny;
let orthy = -edgeWidth * nx; let orthy = -edgeWidth * nx;
// Stores the inbound function calls in reverse order in fns
const fns = []; const fns = [];
// if (isRounded) { // if (isRounded) {
@ -96,9 +99,9 @@ export class WallSpace extends PIXI.Container {
// c.lineTextureStyle({ miterLimit: 1.42 }); // c.lineTextureStyle({ miterLimit: 1.42 });
// } // }
// c.lineStyle(1, 0x000000, 1); // c.lineStyle(1, 0x000000, 1);
c.lineTextureStyle({ width: 1, color: 0x00000, join: PIXI.LINE_JOIN.ROUND }); c.clear();
// c.begin(); c.lineTextureStyle({ width: 1, color: lineColor, join: PIXI.LINE_JOIN.ROUND });
c.beginFill(0xffffff); c.beginFill(fillColor);
const startNx = nx; const startNx = nx;
const startNy = ny; const startNy = ny;
@ -125,7 +128,6 @@ export class WallSpace extends PIXI.Container {
let dist1 = 0; let dist1 = 0;
for (let i = 0; i < pts.length - 2; i++) { for (let i = 0; i < pts.length - 2; i++) {
// Work out in which direction the line is bending
const pos = this.relativeCcw(pts[i].x, pts[i].y, pts[i + 1].x, pts[i + 1].y, pts[i + 2].x, pts[i + 2].y); const pos = this.relativeCcw(pts[i].x, pts[i].y, pts[i + 1].x, pts[i + 1].y, pts[i + 2].x, pts[i + 2].y);
dx1 = pts[i + 2].x - pts[i + 1].x; dx1 = pts[i + 2].x - pts[i + 1].x;
@ -140,7 +142,6 @@ export class WallSpace extends PIXI.Container {
const tmp1 = nx * nx1 + ny * ny1; const tmp1 = nx * nx1 + ny * ny1;
const tmp = Math.max(Math.sqrt((tmp1 + 1) / 2), 0.04); const tmp = Math.max(Math.sqrt((tmp1 + 1) / 2), 0.04);
// Work out the normal orthogonal to the line through the control point and the edge sides intersection
nx2 = (nx + nx1); nx2 = (nx + nx1);
ny2 = (ny + ny1); ny2 = (ny + ny1);
@ -150,7 +151,6 @@ export class WallSpace extends PIXI.Container {
nx2 = nx2 / dist2; nx2 = nx2 / dist2;
ny2 = ny2 / dist2; ny2 = ny2 / dist2;
// Higher strokewidths require a larger minimum bend, 0.35 covers all but the most extreme cases
const strokeWidthFactor = Math.max(tmp, Math.min(1 / 200 + 0.04, 0.35)); const strokeWidthFactor = Math.max(tmp, Math.min(1 / 200 + 0.04, 0.35));
const angleFactor = (pos !== 0 && isRounded) ? Math.max(0.1, strokeWidthFactor) : Math.max(tmp, 0.06); const angleFactor = (pos !== 0 && isRounded) ? Math.max(0.1, strokeWidthFactor) : Math.max(tmp, 0.06);
@ -160,8 +160,6 @@ export class WallSpace extends PIXI.Container {
const inY = pts[i + 1].y + nx2 * edgeWidth / 2 / angleFactor; const inY = pts[i + 1].y + nx2 * edgeWidth / 2 / angleFactor;
if (pos === 0 || !isRounded) { if (pos === 0 || !isRounded) {
// If the two segments are aligned, or if we're not drawing curved sections between segments
// just draw straight to the intersection point
c.lineTo(outX, outY); c.lineTo(outX, outY);
((x, y) => { ((x, y) => {
@ -250,10 +248,8 @@ export class WallSpace extends PIXI.Container {
// c.fillAndStroke(); // c.fillAndStroke();
// } // }
// Workaround for shadow on top of base arrow
// c.setShadow(false); // c.setShadow(false);
// Need to redraw the markers without the low miter limit
// c.setMiterLimit(4); // c.setMiterLimit(4);
// if (isRounded) // if (isRounded)
@ -263,8 +259,6 @@ export class WallSpace extends PIXI.Container {
// if (pts.length > 2) // if (pts.length > 2)
// { // {
// // Only to repaint markers if no waypoints
// // Need to redraw the markers without the low miter limit
// c.setMiterLimit(4); // c.setMiterLimit(4);
// if (markerStart && !openEnded) // if (markerStart && !openEnded)
// { // {
@ -283,11 +277,6 @@ export class WallSpace extends PIXI.Container {
// } // }
// } // }
} }
/**
* Function: paintMarker
*
* Paints the marker.
*/
paintMarker(c: PIXI.Graphics, ptX: number, ptY: number, nx: number, ny: number, paintMarker(c: PIXI.Graphics, ptX: number, ptY: number, nx: number, ny: number,
size: number, arrowWidth: number, edgeWidth: number, spacing: number, initialMove: boolean) { size: number, arrowWidth: number, edgeWidth: number, spacing: number, initialMove: boolean) {
const widthArrowRatio = edgeWidth / arrowWidth; const widthArrowRatio = edgeWidth / arrowWidth;
@ -307,21 +296,6 @@ export class WallSpace extends PIXI.Container {
c.lineTo(ptX + orthx / widthArrowRatio + spaceX, ptY + orthy / widthArrowRatio + spaceY); c.lineTo(ptX + orthx / widthArrowRatio + spaceX, ptY + orthy / widthArrowRatio + spaceY);
c.lineTo(ptX + orthx + spaceX, ptY + orthy + spaceY); c.lineTo(ptX + orthx + spaceX, ptY + orthy + spaceY);
} }
/**
* Function: relativeCcw
*
* Returns 1 if the given point on the right side of the segment, 0 if its
* on the segment, and -1 if the point is on the left side of the segment.
*
* Parameters:
*
* x1 - X-coordinate of the startpoint of the segment.
* y1 - Y-coordinate of the startpoint of the segment.
* x2 - X-coordinate of the endpoint of the segment.
* y2 - Y-coordinate of the endpoint of the segment.
* px - X-coordinate of the point.
* py - Y-coordinate of the point.
*/
relativeCcw(x1: number, y1: number, x2: number, y2: number, px: number, py: number) { relativeCcw(x1: number, y1: number, x2: number, y2: number, px: number, py: number) {
x2 -= x1; x2 -= x1;
y2 -= y1; y2 -= y1;
@ -344,4 +318,8 @@ export class WallSpace extends PIXI.Container {
} }
return (ccw < 0.0) ? -1 : ((ccw > 0.0) ? 1 : 0); return (ccw < 0.0) ? -1 : ((ccw > 0.0) ? 1 : 0);
} }
redraw(): void{
this.refresh(this.line, this.assetData.MultiPoint);
}
} }

441
src/app/working-area/model/axImageShape.ts

@ -1,24 +1,443 @@
import { WorkingAreaComponent } from '../working-area.component';
import * as ObjectID from 'bson-objectid';
import { GameMode } from './gameMode';
import { Pipeline } from './pipeline';
import { PaintMode } from './paintModel';
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
import { PropertyInfo } from './PropertyInfo';
import { AxShape } from './axShape';
import { Sprite } from 'pixi.js';
/** /**
* *
* AxImageShape
*/ */
export class AxImageShape extends PIXI.Container { export class AxImageShape extends AxShape {
style = new PIXI.TextStyle({
fontFamily: 'Arial',
fontSize: 18,
fontStyle: 'normal',
fontWeight: 'bold',
fill: ['#000000'],
stroke: '#ffffff',
strokeThickness: 3,
dropShadow: true,
dropShadowColor: '#000000',
dropShadowBlur: 3,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 1,
wordWrap: false,
wordWrapWidth: 100,
});
text = new PIXI.Text(this.assetData.Name
+ '\r\n'
+ this.assetData.PropertyInfos?.find(item => item.PropertyName === '名称/编号')?.PropertyValue, this.style);
/**
*
*/
image: PIXI.Sprite; image: PIXI.Sprite;
selectionBox = new PIXI.Graphics();
connectPointTexture = PIXI.Texture.from('assets/images/handle-secondary.png');
connectPoint: Sprite;
// 可移动的
constructor() { // 可选中的
super();
} // up: PIXI.Sprite;
// down: PIXI.Sprite;
// left: PIXI.Sprite;
// right: PIXI.Sprite;
// upLeft: PIXI.Sprite;
// upRight: PIXI.Sprite;
// downLeft: PIXI.Sprite;
// downRight: PIXI.Sprite;
constructor(assetData: any, workingArea: WorkingAreaComponent) {
super(assetData, workingArea);
this.x = this.assetData.Point.x;
this.y = this.assetData.Point.y;
this.name = this.assetData.Id;
this.image = PIXI.Sprite.from(this.assetData.ImageUrl);
this.image.angle = this.assetData.Angle;
this.image.x = 0;
this.image.y = 0;
this.image.width = this.assetData.Width;
this.image.height = this.assetData.Height;
this.image.alpha = 1;
this.image.anchor.set(0.5);
// this.image.interactive = true;
// this.image.buttonMode = true;
// this.image
// .on('mousedown', event => {
// event.stopPropagation();
// this.workingArea.selection.selectOne(this);
// // this.paintingPipeline(this.x, this.y);
// // 如果链接对象不为空,禁止移动
// if (this.workingArea.allowEdit && this.assetData.GameMode === this.workingArea.canvasData.gameMode) {
// event.currentTarget.parent.data = event.data;
// event.currentTarget.parent.alpha = 0.5;
// event.currentTarget.parent.dragging = true;
// }
// })
// .on('mouseup', event => {
// if (event.currentTarget.parent.dragging) {
// event.currentTarget.parent.alpha = 1;
// event.currentTarget.parent.dragging = false;
// event.currentTarget.parent.data = null;
// }
// })
// .on('mouseupoutside', event => {
// if (event.currentTarget.parent.dragging) {
// event.currentTarget.parent.alpha = 1;
// event.currentTarget.parent.dragging = false;
// event.currentTarget.parent.data = null;
// }
// })
// .on('mousemove', event => {
// if (event.currentTarget.parent.dragging) {
// // // 如果拖动过程中发现父对象不是背景图
// // if (this.parent !== this.workingArea.backgroundImage) {
// // this.setParent(this.workingArea.backgroundImage);
// // if (this.assetData.FixedSize) {
// // const scale = 1 / this.workingArea.backgroundImage.scale.x;
// // this.scale.set(scale);
// // }
// // }
// const newPosition = event.currentTarget.parent.data.getLocalPosition(event.currentTarget.parent.parent);
// event.currentTarget.parent.x = newPosition.x;
// event.currentTarget.parent.y = newPosition.y;
// this.assetData.Point = new PIXI.Point(this.x, this.y);
// this.workingArea.canvasData.isChange = true;
// }
// })
// .on('rightclick', event => {
paintVertexShape(rect: PIXI.Rectangle) { // })
// .on('mouseover', event => {
// event.stopPropagation();
// if (this.workingArea.previewImage !== null
// && this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
// this.workingArea.previewImage.visible = false;
// }
// // if (this.assetData.CanConnect) {
// // this.setSelectionBox(true, this.image);
// // }
// })
// .on('mouseout', event => {
// event.stopPropagation();
// if (this.workingArea.previewImage !== null
// && this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
// this.workingArea.previewImage.visible = true;
// }
// // if (this.assetData.CanConnect) {
// // this.setSelectionBox(false);
// // }
// });
this.text.x = this.image.x;
this.text.y = this.image.y - this.image.height / 2;
this.text.anchor.set(0.5, 1);
} if (this.assetData.GameMode === 2) {
paintBackground(rect: PIXI.Rectangle) { } this.text.visible = false;
}
this.addChild(this.text);
this.addChild(this.image);
this.addChild(this.selectionBox);
if (this.assetData.CanConnect) {
// connectPoint
this.connectPoint = new PIXI.Sprite(this.connectPointTexture);
this.connectPoint.anchor.set(0.5);
this.connectPoint.x = this.image.x;
this.connectPoint.y = this.image.y;
this.addChild(this.connectPoint);
this.connectPoint.interactive = true;
this.connectPoint
.on('mousedown', event => {
event.stopPropagation();
this.paintingPipeline(this.x, this.y);
})
.on('mouseover', event => {
this.setSelectionBox(true, this.connectPoint);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// // up
// this.up = new PIXI.Sprite(this.selectedPointTexture);
// this.up.anchor.set(0.5);
// this.up.x = this.image.x;
// this.up.y = this.image.y - (this.image.height / 2);
// this.addChild(this.up);
// this.up.interactive = true;
// this.up
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.up.x, this.up.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.up);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // down
// this.down = new PIXI.Sprite(this.selectedPointTexture);
// this.down.anchor.set(0.5);
// this.down.x = this.image.x;
// this.down.y = this.image.y + (this.image.height / 2);
// this.addChild(this.down);
// this.down.interactive = true;
// this.down
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.down.x, this.down.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.down);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // left
// this.left = new PIXI.Sprite(this.selectedPointTexture);
// this.left.anchor.set(0.5);
// this.left.x = this.image.x - (this.image.width / 2);
// this.left.y = this.image.y;
// this.addChild(this.left);
// this.left.interactive = true;
// this.left
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.left.x, this.left.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.left);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // right
// this.right = new PIXI.Sprite(this.selectedPointTexture);
// this.right.anchor.set(0.5);
// this.right.x = this.image.x + (this.image.width / 2);
// this.right.y = this.image.y;
// this.addChild(this.right);
// this.right.interactive = true;
// this.right
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.right.x, this.right.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.right);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // up-left
// this.upLeft = new PIXI.Sprite(this.selectedPointTexture);
// this.upLeft.anchor.set(0.5);
// this.upLeft.x = this.image.x - (this.image.width / 2);
// this.upLeft.y = this.image.y - (this.image.height / 2);
// this.addChild(this.upLeft);
// this.upLeft.interactive = true;
// this.upLeft
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.upLeft.x, this.upLeft.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.upLeft);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // up-right
// this.upRight = new PIXI.Sprite(this.selectedPointTexture);
// this.upRight.anchor.set(0.5);
// this.upRight.x = this.image.x + (this.image.width / 2);
// this.upRight.y = this.image.y - (this.image.height / 2);
// this.addChild(this.upRight);
// this.upRight.interactive = true;
// this.upRight
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.upRight.x, this.upRight.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.upRight);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
paintForeground(rect: PIXI.Rectangle) { } // // down-left
// this.downLeft = new PIXI.Sprite(this.selectedPointTexture);
// this.downLeft.anchor.set(0.5);
// this.downLeft.x = this.image.x - (this.image.width / 2);
// this.downLeft.y = this.image.y + (this.image.height / 2);
// this.addChild(this.downLeft);
// this.downLeft.interactive = true;
// this.downLeft
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.downLeft.x, this.downLeft.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.downLeft);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
// // down-right
// this.downRight = new PIXI.Sprite(this.selectedPointTexture);
// this.downRight.anchor.set(0.5);
// this.downRight.x = this.image.x + (this.image.width / 2);
// this.downRight.y = this.image.y + (this.image.height / 2);
// this.addChild(this.downRight);
// this.downRight.interactive = true;
// this.downRight
// .on('mousedown', event => {
// event.stopPropagation();
// const pt = this.toGlobal(new PIXI.Point(this.downRight.x, this.downRight.y));
// const pt2 = this.workingArea.backgroundImage.toLocal(pt);
// this.paintingPipeline(pt2.x, pt2.y);
// })
// .on('mouseover', event => {
// this.setSelectionBox(true, this.downRight);
// })
// .on('mouseout', event => {
// this.setSelectionBox(false);
// });
paintEdgeShape(pts: Array<PIXI.Point>) { } this.showConnectionPoint(false);
}
}
// 设置选择框
public setSelectionBox(b: boolean, sprite?: PIXI.Sprite) {
if (b) {
this.selectionBox.lineStyle(2, 0x00EB00, 1);
this.selectionBox.position = sprite.position;
this.selectionBox.drawRect(- sprite.width / 2, - sprite.height / 2, sprite.width, sprite.height);
// const p0 = new PIXI.Point(- sprite.width / 2, - sprite.height / 2);
// const pe = new PIXI.Point(sprite.width / 2, sprite.height / 2);
// const pw = new PIXI.Point(p0.x + sprite.width, p0.y);
// const ph = new PIXI.Point(p0.x, p0.y + sprite.height);
// this.drawDashedLine(this.selectionBox, p0, pw, 0x1234ff);
// this.drawDashedLine(this.selectionBox, p0, ph, 0x1234ff);
// this.drawDashedLine(this.selectionBox, pe, pw, 0x1234ff);
// this.drawDashedLine(this.selectionBox, pe, ph, 0x1234ff);
} else {
this.selectionBox.clear();
}
}
// 设置名称
public setNameVisible(value: boolean, mode: GameMode) {
if (this.assetData.GameMode === mode) {
this.text.visible = value;
}
}
// 显示连接点
public showConnectionPoint(b: boolean) {
this.connectPoint.visible = b;
// this.up.visible = b;
// this.down.visible = b;
// this.left.visible = b;
// this.right.visible = b;
// this.upLeft.visible = b;
// this.downLeft.visible = b;
// this.upRight.visible = b;
// this.downRight.visible = b;
}
paintingPipeline(x: number, y: number) {
if (this.assetData.CanConnect) {
if (this.workingArea.getPaintMode() === PaintMode.Pipeline) {
if (this.workingArea.paintingPipeline === null) {
this.workingArea.previewLineSegment.visible = true;
this.workingArea.currentClickPoint.position =
new PIXI.Point(this.workingArea.circleShadow.x, this.workingArea.circleShadow.y);
this.workingArea.paintPoints.push(new PIXI.Point(x, y));
const json = JSON.parse(JSON.stringify(this.workingArea.canvasData.selectTemplateData.propertyInfos));
const list = [];
json.forEach(element => {
const property = new PropertyInfo(element);
list.push(property);
});
const tempData = {
TemplateId: this.workingArea.canvasData.selectTemplateData.id,
CanConnect: this.workingArea.canvasData.selectTemplateData.canConnect,
Pipelines: new Array(),
FloorId: this.workingArea.canvasData.selectStorey.id,
Angle: this.workingArea.canvasData.selectTemplateData.angle,
Color: this.workingArea.canvasData.selectTemplateData.color,
Enabled: this.workingArea.canvasData.selectTemplateData.enabled,
FillMode: this.workingArea.canvasData.selectTemplateData.fillMode,
FireElementId: this.workingArea.canvasData.selectTemplateData.fireElementId,
FixedSize: this.workingArea.canvasData.selectTemplateData.fixedSize,
Height : 32,
Width : 32,
Id: ObjectID.default.generate(),
ImageUrl: this.workingArea.canvasData.selectTemplateData.imageUrl,
InteractiveMode: this.workingArea.canvasData.selectTemplateData.interactiveMode,
MultiPoint : JSON.parse(JSON.stringify(this.workingArea.paintPoints)),
Point: new PIXI.Point(0, 0),
Name : this.workingArea.canvasData.selectTemplateData.name,
PropertyInfos: list,
Border : this.workingArea.canvasData.selectTemplateData.border,
DrawMode : this.workingArea.canvasData.selectTemplateData.drawMode,
Thickness : this.workingArea.canvasData.selectTemplateData.thickness,
IsFromBuilding : this.workingArea.canvasData.selectTemplateData.isFromBuilding,
GameMode: this.workingArea.canvasData.gameMode,
LinkedObjects: new Array(this.assetData.Id),
};
this.workingArea.paintingPipeline = new Pipeline(tempData, this.workingArea);
this.assetData.Pipelines.push(this.workingArea.paintingPipeline.assetData.Id);
this.workingArea.emit('createIcon', this.workingArea.paintingPipeline);
} else {
this.workingArea.previewLineSegment.visible = false;
this.workingArea.currentClickPoint.position =
new PIXI.Point(this.workingArea.circleShadow.x, this.workingArea.circleShadow.y);
this.workingArea.paintPoints.push(new PIXI.Point(x, y));
this.workingArea.paintingPipeline.assetData.MultiPoint =
JSON.parse(JSON.stringify(this.workingArea.paintPoints));
this.workingArea.paintingPipeline.assetData.LinkedObjects.push(this.assetData.Id);
this.assetData.Pipelines.push(this.workingArea.paintingPipeline.assetData.Id);
this.workingArea.paintingPipeline.refresh();
this.workingArea.initPipelineData();
}
}
}
}
// 刷新
public refresh() {
if (this.assetData.CanConnect) {
}
this.image.width = this.assetData.Width;
this.image.height = this.assetData.Height;
this.image.angle = this.assetData.Angle;
this.text.text = this.assetData.Name
+ '\r\n'
+ this.assetData.PropertyInfos?.find(item => item.PropertyName === '名称/编号')?.PropertyValue;
this.text.x = this.image.x;
this.text.y = this.image.y - this.image.height / 2;
}
} }

27
src/app/working-area/model/axPreviewImageShape.ts

@ -0,0 +1,27 @@
import { Sprite, Texture } from 'pixi.js';
import { WorkingAreaComponent } from '../working-area.component';
import { AxShape } from './axShape';
export class AxPreviewImageShape extends AxShape {
image: Sprite = null;
/**
*
*/
constructor(workingArea: WorkingAreaComponent) {
super(null, workingArea);
this.image = new Sprite();
this.image.width = 32;
this.image.height = 32;
this.image.anchor.set(0.5);
this.interactive = false;
this.scale.set(1 / this.workingArea.backgroundImage.scale.x);
this.addChild(this.image);
}
/**
*
* @param url
*/
setImageUrl(url: string) {
this.image.texture = Texture.from(url);
}
}

110
src/app/working-area/model/axShape.ts

@ -1,56 +1,76 @@
import { Constructor } from '@angular/material/core/common-behaviors/constructor';
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
// import { Point, Rectangle, Graphics } from 'pixi.js'; import { Point, Rectangle, Graphics, Container } from 'pixi.js';
import { WorkingAreaComponent } from '../working-area.component';
/** /**
* *
*/ */
export class AxShape extends PIXI.Container { export class AxShape extends Container {
assetData: any;
workingArea: WorkingAreaComponent;
// 可以被移动的
moveable = true;
// 可以被选中的
selectable = true;
points: Array<PIXI.Point> = []; constructor(assetData: any, workingArea: WorkingAreaComponent) {
title: string;
titleVisible: boolean;
g: PIXI.Graphics = new PIXI.Graphics();
constructor() {
super(); super();
this.addChild(this.g); this.assetData = assetData;
// this.drawDashedLine(this.g, new Point(0, 0), new Point(0, 200), 0xff0000); this.workingArea = workingArea;
} this.workingArea.backgroundImage.addChild(this);
// /** this.interactive = true;
// * 绘制虚线 this.buttonMode = true;
// * @param g this.on('mousedown', event => {
// * @param p0 console.log(this.assetData);
// * @param pe event.stopPropagation();
// * @param color if (this.selectable) {
// * @param width this.workingArea.selection.selectOne(this);
// * @param dashLen }
// */ if (this.moveable) {
// drawDashedLine(g: Graphics, p0: Point, pe: Point, color: number, width: number = 1, dashLen: number = 5) { event.currentTarget.data = event.data;
// g.lineStyle(width, color); event.currentTarget.alpha = 0.5;
// const len = Math.sqrt(Math.pow(pe.x - p0.x, 2) + Math.pow(pe.y - p0.y, 2)); event.currentTarget.dragging = true;
// // tslint:disable-next-line: no-bitwise
// const num = ~~(len / dashLen);
// for (let i = 0; i < num; i++) {
// const x = p0.x + (pe.x - p0.x) / num * i;
// const y = p0.y + (pe.y - p0.y) / num * i;
// // tslint:disable-next-line: no-bitwise
// i & 1 ? g.lineTo(x, y) : g.moveTo(x, y);
// }
// }
paintVertexShape(rect: PIXI.Rectangle) { event.currentTarget.dragPoint = event.data.getLocalPosition(event.currentTarget.parent);
// this.paintBackground(c, x, y, w, h); event.currentTarget.dragPoint.x -= event.currentTarget.x;
event.currentTarget.dragPoint.y -= event.currentTarget.y;
}
})
.on('mouseup', event => {
if (event.currentTarget.dragging) {
event.currentTarget.alpha = 1;
event.currentTarget.dragging = false;
event.currentTarget.data = null;
}
})
.on('mouseupoutside', event => {
if (event.currentTarget.dragging) {
event.currentTarget.alpha = 1;
event.currentTarget.dragging = false;
event.currentTarget.data = null;
}
})
.on('mousemove', event => {
if (event.currentTarget.dragging) {
const newPosition = event.currentTarget.data.getLocalPosition(event.currentTarget.parent);
event.currentTarget.x = newPosition.x - event.currentTarget.dragPoint.x;
event.currentTarget.y = newPosition.y - event.currentTarget.dragPoint.y;
this.assetData.Point = new PIXI.Point(this.x, this.y);
this.workingArea.canvasData.isChange = true;
}
})
.on('rightclick', event => {
// if (!this.outline || this.style == null || mxUtils.getValue( })
// this.style, mxConstants.STYLE_BACKGROUND_OUTLINE, 0) == 0) .on('mouseover', event => {
// { event.stopPropagation();
// c.setShadow(false); })
// this.paintForeground(c, x, y, w, h); .on('mouseout', event => {
// } event.stopPropagation();
});
}
redraw(): void {
} }
paintBackground(rect: PIXI.Rectangle) { }
paintForeground(rect: PIXI.Rectangle) { }
paintEdgeShape(pts: Array<PIXI.Point>) { }
} }

6
src/app/working-area/model/multipointIcon.ts

@ -165,9 +165,6 @@ export class MultipointIcon extends PIXI.Container {
} }
}) })
.on('rightclick', event => { .on('rightclick', event => {
})
.on('mouseover', event => {
}); });
}); });
// // 缩放 // // 缩放
@ -178,6 +175,7 @@ export class MultipointIcon extends PIXI.Container {
// 添加选中事件 // 添加选中事件
this.iconsTilingSprite.forEach((item, index, array) => { this.iconsTilingSprite.forEach((item, index, array) => {
item.interactive = true; item.interactive = true;
item.buttonMode = true;
item.on('mousedown', event => { item.on('mousedown', event => {
event.stopPropagation(); event.stopPropagation();
this.workingArea.selection.selectOne(this); this.workingArea.selection.selectOne(this);
@ -245,4 +243,4 @@ export class MultipointIcon extends PIXI.Container {
+ '\r\n' + '\r\n'
+ this.assetData.PropertyInfos.find(item => item.PropertyName === '名称/编号')?.PropertyValue; + this.assetData.PropertyInfos.find(item => item.PropertyName === '名称/编号')?.PropertyValue;
} }
} }

8
src/app/working-area/model/paintModel.ts

@ -18,6 +18,10 @@ export enum PaintMode {
* *
*/ */
Pipeline, Pipeline,
/**
*
*/
endPaint,
/** /**
* *
*/ */
@ -26,8 +30,4 @@ export enum PaintMode {
* *
*/ */
Car, Car,
/**
*
*/
endPaint,
} }

38
src/app/working-area/model/pipeline.ts

@ -1,14 +1,16 @@
import { WorkingAreaComponent } from '../working-area.component'; import { WorkingAreaComponent } from '../working-area.component';
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
import { AxShape } from './axShape';
/** /**
* 线 * 线
*/ */
export class Pipeline extends PIXI.Container { export class Pipeline extends AxShape {
public line: PIXI.Graphics = new PIXI.Graphics(); public line: PIXI.Graphics = new PIXI.Graphics();
constructor(public assetData: any, private workingArea: WorkingAreaComponent) { constructor(assetData: any, workingArea: WorkingAreaComponent) {
super(); super(assetData, workingArea);
this.name = this.assetData.Id; this.name = this.assetData.Id;
this.moveable = false;
this.x = this.assetData.Point.x; this.x = this.assetData.Point.x;
this.y = this.assetData.Point.y; this.y = this.assetData.Point.y;
this.workingArea.backgroundImage.addChild(this); this.workingArea.backgroundImage.addChild(this);
@ -269,9 +271,17 @@ export class Pipeline extends PIXI.Container {
// } // }
} }
/** /**
* Function: paintMarker *
* * @param c
* Paints the marker. * @param ptX
* @param ptY
* @param nx
* @param ny
* @param size
* @param arrowWidth
* @param edgeWidth
* @param spacing
* @param initialMove
*/ */
paintMarker(c: PIXI.Graphics, ptX: number, ptY: number, nx: number, ny: number, paintMarker(c: PIXI.Graphics, ptX: number, ptY: number, nx: number, ny: number,
size: number, arrowWidth: number, edgeWidth: number, spacing: number, initialMove: boolean) { size: number, arrowWidth: number, edgeWidth: number, spacing: number, initialMove: boolean) {
@ -292,21 +302,7 @@ export class Pipeline extends PIXI.Container {
c.lineTo(ptX + orthx / widthArrowRatio + spaceX, ptY + orthy / widthArrowRatio + spaceY); c.lineTo(ptX + orthx / widthArrowRatio + spaceX, ptY + orthy / widthArrowRatio + spaceY);
c.lineTo(ptX + orthx + spaceX, ptY + orthy + spaceY); c.lineTo(ptX + orthx + spaceX, ptY + orthy + spaceY);
} }
/**
* Function: relativeCcw
*
* Returns 1 if the given point on the right side of the segment, 0 if its
* on the segment, and -1 if the point is on the left side of the segment.
*
* Parameters:
*
* x1 - X-coordinate of the startpoint of the segment.
* y1 - Y-coordinate of the startpoint of the segment.
* x2 - X-coordinate of the endpoint of the segment.
* y2 - Y-coordinate of the endpoint of the segment.
* px - X-coordinate of the point.
* py - Y-coordinate of the point.
*/
relativeCcw(x1: number, y1: number, x2: number, y2: number, px: number, py: number) { relativeCcw(x1: number, y1: number, x2: number, y2: number, px: number, py: number) {
x2 -= x1; x2 -= x1;
y2 -= y1; y2 -= y1;

39
src/app/working-area/model/polygonIcon.ts

@ -1,6 +1,7 @@
import { WorkingAreaComponent } from '../working-area.component'; import { WorkingAreaComponent } from '../working-area.component';
import { GameMode } from './gameMode'; import { GameMode } from './gameMode';
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
import { PaintMode } from './paintModel';
/** /**
* *
@ -76,6 +77,7 @@ export class PolygonIcon extends PIXI.Container {
// 添加圆点事件 // 添加圆点事件
this.pointsGraphics.forEach((item, index, array) => { this.pointsGraphics.forEach((item, index, array) => {
item.interactive = true; item.interactive = true;
item.buttonMode = true;
item.zIndex = 1; item.zIndex = 1;
item.on('mousedown', event => { item.on('mousedown', event => {
event.stopPropagation(); event.stopPropagation();
@ -123,10 +125,24 @@ export class PolygonIcon extends PIXI.Container {
} }
}) })
.on('rightclick', event => { .on('rightclick', event => {
}); }) .on('mouseover', event => {
event.stopPropagation();
if (this.workingArea.previewImage !== null
&& this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
this.workingArea.previewImage.visible = false;
}
})
.on('mouseout', event => {
event.stopPropagation();
if (this.workingArea.previewImage !== null
&& this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
this.workingArea.previewImage.visible = true;
}
});
}); });
// 添加选中事件 // 添加选中事件
this.polygonGraphics.interactive = true; this.polygonGraphics.interactive = true;
this.polygonGraphics.buttonMode = true;
this.polygonGraphics this.polygonGraphics
.on('mousedown', event => { .on('mousedown', event => {
event.stopPropagation(); event.stopPropagation();
@ -167,12 +183,21 @@ export class PolygonIcon extends PIXI.Container {
}) })
.on('rightclick', event => { .on('rightclick', event => {
// this.workingArea.selection.deselectAll(); // this.workingArea.selection.deselectAll();
})
.on('mouseover', event => {
event.stopPropagation();
if (this.workingArea.previewImage !== null
&& this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
this.workingArea.previewImage.visible = false;
}
})
.on('mouseout', event => {
event.stopPropagation();
if (this.workingArea.previewImage !== null
&& this.workingArea.getPaintMode() === PaintMode.singlePointIcon) {
this.workingArea.previewImage.visible = true;
}
}); });
// // 缩放
// this.workingArea.on('backgroundScale', data => {
// const scale = 1 / data;
// this.text.scale.set(scale);
// });
} }
/** /**
* *
@ -241,4 +266,4 @@ export class PolygonIcon extends PIXI.Container {
this.polygonGraphics.drawPolygon(this.getPoints()); this.polygonGraphics.drawPolygon(this.getPoints());
this.polygonGraphics.endFill(); this.polygonGraphics.endFill();
} }
} }

108
src/app/working-area/model/putCarArea.ts

@ -1,59 +1,59 @@
import { OldFilmFilter } from 'pixi-filters'; // import { OldFilmFilter } from 'pixi-filters';
import { WorkingAreaComponent } from '../working-area.component'; // import { WorkingAreaComponent } from '../working-area.component';
import { PaintMode } from './paintModel'; // import { PaintMode } from './paintModel';
import { SinglePointIcon } from './singlePointIcon'; // import { SinglePointIcon } from './axImageShape';
import * as PIXI from 'pixi.js'; // import * as PIXI from 'pixi.js';
/** // /**
* // * 汽车放置区域
*/ // */
export class PutCarArea extends PIXI.Container { // export class PutCarArea extends PIXI.Container {
public polygonGraphics: PIXI.Graphics = new PIXI.Graphics(); // public polygonGraphics: PIXI.Graphics = new PIXI.Graphics();
constructor(public assetData: any, private workingArea: WorkingAreaComponent) { // constructor(public assetData: any, private workingArea: WorkingAreaComponent) {
super(); // super();
this.name = this.assetData.Id; // this.name = this.assetData.Id;
this.x = this.assetData.Point.x; // this.x = this.assetData.Point.x;
this.y = this.assetData.Point.y; // this.y = this.assetData.Point.y;
this.workingArea.backgroundImage.addChild(this); // this.workingArea.backgroundImage.addChild(this);
this.sortableChildren = true; // this.sortableChildren = true;
// 填充多边形 // // 填充多边形
const color: number = this.assetData.Color.substring(0, 7).replace('#', '0x'); // const color: number = this.assetData.Color.substring(0, 7).replace('#', '0x');
const angle: number = parseInt(this.assetData.Color.substring(7), 16) / 255; // const angle: number = parseInt(this.assetData.Color.substring(7), 16) / 255;
this.polygonGraphics.beginFill(color, angle); // this.polygonGraphics.beginFill(color, angle);
this.polygonGraphics.drawPolygon(this.assetData.MultiPoint); // this.polygonGraphics.drawPolygon(this.assetData.MultiPoint);
this.polygonGraphics.endFill(); // this.polygonGraphics.endFill();
this.addChild(this.polygonGraphics); // this.addChild(this.polygonGraphics);
// 添加选中事件 // // 添加选中事件
this.polygonGraphics.interactive = true; // this.polygonGraphics.interactive = true;
this.polygonGraphics // this.polygonGraphics
.on('pointerdown', (event) => { // .on('pointerdown', (event) => {
if (this.workingArea.getPaintMode() === PaintMode.Car) { // if (this.workingArea.getPaintMode() === PaintMode.Car) {
this.workingArea.selectCar.Point = // this.workingArea.selectCar.Point =
new PIXI.Point(this.workingArea.previewSinglePointIcon.x, this.workingArea.previewSinglePointIcon.y); // new PIXI.Point(this.workingArea.previewSinglePointIcon.x, this.workingArea.previewSinglePointIcon.y);
this.workingArea.selectCar.Angle = this.assetData.Direction; // this.workingArea.selectCar.Angle = this.assetData.Direction;
const car = new SinglePointIcon(this.workingArea.selectCar, this.workingArea); // const car = new SinglePointIcon(this.workingArea.selectCar, this.workingArea);
this.workingArea.setPaintMode(PaintMode.endPaint); // this.workingArea.setPaintMode(PaintMode.endPaint);
} // }
}) // })
.on('pointerup', (event) => { // .on('pointerup', (event) => {
}) // })
.on('pointerupoutside', (event) => { // .on('pointerupoutside', (event) => {
}) // })
.on('pointerover', (event) => { // .on('pointerover', (event) => {
this.workingArea.previewSinglePointIcon.filters = null; // this.workingArea.previewSinglePointIcon.filters = null;
this.workingArea.previewSinglePointIcon.zIndex = this.zIndex + 1; // this.workingArea.previewSinglePointIcon.zIndex = this.zIndex + 1;
// 设置车辆方向 // // 设置车辆方向
this.workingArea.previewSinglePointIcon.angle = this.assetData.Direction; // this.workingArea.previewSinglePointIcon.angle = this.assetData.Direction;
console.log(this.assetData.Name); // console.log(this.assetData.Name);
}) // })
.on('pointerout', (event) => { // .on('pointerout', (event) => {
this.workingArea.previewSinglePointIcon.filters = [ // this.workingArea.previewSinglePointIcon.filters = [
new OldFilmFilter() // new OldFilmFilter()
]; // ];
}); // });
} // }
} // }

373
src/app/working-area/model/singlePointIcon.ts

@ -1,373 +0,0 @@
import { WorkingAreaComponent } from '../working-area.component';
import * as ObjectID from 'bson-objectid';
import { GameMode } from './gameMode';
import { Pipeline } from './pipeline';
import { PaintMode } from './paintModel';
import * as PIXI from 'pixi.js';
import { PropertyInfo } from './PropertyInfo';
import { AxShape } from './axShape';
/**
*
*/
export class SinglePointIcon extends AxShape {
style = new PIXI.TextStyle({
fontFamily: 'Arial',
fontSize: 18,
fontStyle: 'normal',
fontWeight: 'bold',
fill: ['#000000'],
stroke: '#ffffff',
strokeThickness: 3,
dropShadow: true,
dropShadowColor: '#000000',
dropShadowBlur: 3,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 1,
wordWrap: false,
wordWrapWidth: 100,
});
text = new PIXI.Text(this.assetData.Name
+ '\r\n'
+ this.assetData.PropertyInfos?.find(item => item.PropertyName === '名称/编号')?.PropertyValue, this.style);
/**
*
*/
selectedPointTexture = PIXI.Texture.from('assets/images/handle-secondary.png');
image = PIXI.Sprite.from(this.assetData.ImageUrl);
selectionBox = new PIXI.Graphics();
up: PIXI.Sprite;
down: PIXI.Sprite;
left: PIXI.Sprite;
right: PIXI.Sprite;
upLeft: PIXI.Sprite;
upRight: PIXI.Sprite;
downLeft: PIXI.Sprite;
downRight: PIXI.Sprite;
constructor(public assetData: any, private workingArea: WorkingAreaComponent) {
super();
this.workingArea.backgroundImage.addChild(this);
this.x = this.assetData.Point.x;
this.y = this.assetData.Point.y;
this.name = this.assetData.Id;
this.image.angle = this.assetData.Angle;
this.image.x = 0;
this.image.y = 0;
this.image.width = this.assetData.Width;
this.image.height = this.assetData.Height;
console.log(this.getBounds());
this.image.alpha = 1;
this.image.anchor.set(0.5);
this.image.interactive = true;
this.image
.on('mousedown', event => {
event.stopPropagation();
this.workingArea.selection.selectOne(this);
this.paintingPipeline(this.x, this.y);
// 如果链接对象不为空,禁止移动
if (this.workingArea.allowEdit && this.assetData.GameMode === this.workingArea.canvasData.gameMode) {
event.currentTarget.parent.data = event.data;
event.currentTarget.parent.alpha = 0.5;
event.currentTarget.parent.dragging = true;
}
})
.on('mouseup', event => {
if (event.currentTarget.parent.dragging) {
event.currentTarget.parent.alpha = 1;
event.currentTarget.parent.dragging = false;
event.currentTarget.parent.data = null;
}
})
.on('mouseupoutside', event => {
if (event.currentTarget.parent.dragging) {
event.currentTarget.parent.alpha = 1;
event.currentTarget.parent.dragging = false;
event.currentTarget.parent.data = null;
}
})
.on('mousemove', event => {
if (event.currentTarget.parent.dragging) {
// 如果拖动过程中发现父对象不是背景图
if (this.parent !== this.workingArea.backgroundImage) {
this.setParent(this.workingArea.backgroundImage);
if (this.assetData.FixedSize) {
const scale = 1 / this.workingArea.backgroundImage.scale.x;
this.scale.set(scale);
}
}
const newPosition = event.currentTarget.parent.data.getLocalPosition(event.currentTarget.parent.parent);
event.currentTarget.parent.x = newPosition.x;
event.currentTarget.parent.y = newPosition.y;
this.assetData.Point = new PIXI.Point(this.x, this.y);
this.workingArea.canvasData.isChange = true;
}
})
.on('rightclick', event => {
})
.on('mouseover', event => {
// if (this.assetData.CanConnect) {
// this.setSelectionBox(true, this.image);
// }
})
.on('mouseout', event => {
// if (this.assetData.CanConnect) {
// this.setSelectionBox(false);
// }
});
this.text.x = this.image.x;
this.text.y = this.image.y - this.image.height / 2;
this.text.anchor.set(0.5, 1);
if (this.assetData.GameMode === 2) {
this.text.visible = false;
}
this.addChild(this.text);
this.addChild(this.image);
this.addChild(this.selectionBox);
if (this.assetData.CanConnect) {
// up
this.up = new PIXI.Sprite(this.selectedPointTexture);
this.up.anchor.set(0.5);
this.up.x = this.image.x;
this.up.y = this.image.y - (this.image.height / 2);
this.addChild(this.up);
this.up.interactive = true;
this.up
.on('mousedown', event => {
event.stopPropagation();
const pt = this.toGlobal(new PIXI.Point(this.up.x, this.up.y));
const pt2 = this.workingArea.backgroundImage.toLocal(pt);
this.paintingPipeline(pt2.x, pt2.y);
})
.on('mouseover', event => {
this.setSelectionBox(true, this.up);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// down
this.down = new PIXI.Sprite(this.selectedPointTexture);
this.down.anchor.set(0.5);
this.down.x = this.image.x;
this.down.y = this.image.y + (this.image.height / 2);
this.addChild(this.down);
this.down.interactive = true;
this.down
.on('mouseover', event => {
this.setSelectionBox(true, this.down);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// left
this.left = new PIXI.Sprite(this.selectedPointTexture);
this.left.anchor.set(0.5);
this.left.x = this.image.x - (this.image.width / 2);
this.left.y = this.image.y;
this.addChild(this.left);
this.left.interactive = true;
this.left
.on('mouseover', event => {
this.setSelectionBox(true, this.left);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// right
this.right = new PIXI.Sprite(this.selectedPointTexture);
this.right.anchor.set(0.5);
this.right.x = this.image.x + (this.image.width / 2);
this.right.y = this.image.y;
this.addChild(this.right);
this.right.interactive = true;
this.right
.on('mouseover', event => {
this.setSelectionBox(true, this.right);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// up-left
this.upLeft = new PIXI.Sprite(this.selectedPointTexture);
this.upLeft.anchor.set(0.5);
this.upLeft.x = this.image.x - (this.image.width / 2);
this.upLeft.y = this.image.y - (this.image.height / 2);
this.addChild(this.upLeft);
this.upLeft.interactive = true;
this.upLeft
.on('mouseover', event => {
this.setSelectionBox(true, this.upLeft);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// up-right
this.upRight = new PIXI.Sprite(this.selectedPointTexture);
this.upRight.anchor.set(0.5);
this.upRight.x = this.image.x + (this.image.width / 2);
this.upRight.y = this.image.y - (this.image.height / 2);
this.addChild(this.upRight);
this.upRight.interactive = true;
this.upRight
.on('mouseover', event => {
this.setSelectionBox(true, this.upRight);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// down-left
this.downLeft = new PIXI.Sprite(this.selectedPointTexture);
this.downLeft.anchor.set(0.5);
this.downLeft.x = this.image.x - (this.image.width / 2);
this.downLeft.y = this.image.y + (this.image.height / 2);
this.addChild(this.downLeft);
this.downLeft.interactive = true;
this.downLeft
.on('mouseover', event => {
this.setSelectionBox(true, this.downLeft);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
// down-right
this.downRight = new PIXI.Sprite(this.selectedPointTexture);
this.downRight.anchor.set(0.5);
this.downRight.x = this.image.x + (this.image.width / 2);
this.downRight.y = this.image.y + (this.image.height / 2);
this.addChild(this.downRight);
this.downRight.interactive = true;
this.downRight
.on('mouseover', event => {
this.setSelectionBox(true, this.downRight);
})
.on('mouseout', event => {
this.setSelectionBox(false);
});
this.showConnectionPoint(false);
}
}
// 设置选择框
public setSelectionBox(b: boolean, sprite?: PIXI.Sprite) {
if (b) {
this.selectionBox.lineStyle(2, 0x00EB00, 1);
this.selectionBox.position = sprite.position;
this.selectionBox.drawRect(- sprite.width / 2, - sprite.height / 2, sprite.width, sprite.height);
// const p0 = new PIXI.Point(- sprite.width / 2, - sprite.height / 2);
// const pe = new PIXI.Point(sprite.width / 2, sprite.height / 2);
// const pw = new PIXI.Point(p0.x + sprite.width, p0.y);
// const ph = new PIXI.Point(p0.x, p0.y + sprite.height);
// this.drawDashedLine(this.selectionBox, p0, pw, 0x1234ff);
// this.drawDashedLine(this.selectionBox, p0, ph, 0x1234ff);
// this.drawDashedLine(this.selectionBox, pe, pw, 0x1234ff);
// this.drawDashedLine(this.selectionBox, pe, ph, 0x1234ff);
} else {
this.selectionBox.clear();
}
}
// 设置名称
public setNameVisible(value: boolean, mode: GameMode) {
if (this.assetData.GameMode === mode) {
this.text.visible = value;
}
}
// 显示连接点
public showConnectionPoint(b: boolean) {
this.up.visible = b;
this.down.visible = b;
this.left.visible = b;
this.right.visible = b;
this.upLeft.visible = b;
this.downLeft.visible = b;
this.upRight.visible = b;
this.downRight.visible = b;
}
paintingPipeline(x: number, y: number) {
if (this.assetData.CanConnect) {
if (this.workingArea.getPaintMode() === PaintMode.Pipeline) {
if (this.workingArea.paintingPipeline === null) {
this.workingArea.previewLineSegment.visible = true;
this.workingArea.currentClickPoint.position =
new PIXI.Point(this.workingArea.circleShadow.x, this.workingArea.circleShadow.y);
this.workingArea.paintPoints.push(new PIXI.Point(x, y));
// const tempData = {
// Id: ObjectID.default.generate(),
// MultiPoint: JSON.parse(JSON.stringify(this.workingArea.paintPoints)),
// Point: new PIXI.Point(0, 0),
// Name: '管线',
// LinkedObjects: new Array(),
// };
const json = JSON.parse(JSON.stringify(this.workingArea.canvasData.selectTemplateData.propertyInfos));
const list = [];
json.forEach(element => {
const property = new PropertyInfo(element);
list.push(property);
});
const tempData = {
TemplateId: this.workingArea.canvasData.selectTemplateData.id,
CanConnect: this.workingArea.canvasData.selectTemplateData.canConnect,
Pipelines: new Array(),
FloorId: this.workingArea.canvasData.selectStorey.id,
Angle: this.workingArea.canvasData.selectTemplateData.angle,
Color: this.workingArea.canvasData.selectTemplateData.color,
Enabled: this.workingArea.canvasData.selectTemplateData.enabled,
FillMode: this.workingArea.canvasData.selectTemplateData.fillMode,
FireElementId: this.workingArea.canvasData.selectTemplateData.fireElementId,
FixedSize: this.workingArea.canvasData.selectTemplateData.fixedSize,
Height : 32,
Width : 32,
Id: ObjectID.default.generate(),
ImageUrl: this.workingArea.canvasData.selectTemplateData.imageUrl,
InteractiveMode: this.workingArea.canvasData.selectTemplateData.interactiveMode,
MultiPoint : JSON.parse(JSON.stringify(this.workingArea.paintPoints)),
Point: new PIXI.Point(0, 0),
Name : this.workingArea.canvasData.selectTemplateData.name,
PropertyInfos: list,
Border : this.workingArea.canvasData.selectTemplateData.border,
DrawMode : this.workingArea.canvasData.selectTemplateData.drawMode,
Thickness : this.workingArea.canvasData.selectTemplateData.thickness,
IsFromBuilding : this.workingArea.canvasData.selectTemplateData.isFromBuilding,
GameMode: this.workingArea.canvasData.gameMode,
LinkedObjects: new Array(),
};
this.workingArea.paintingPipeline = new Pipeline(tempData, this.workingArea);
// this.workingArea.paintingPipeline.assetData.LinkedObjects.push(this);
// this.assetData.Pipelines.push(this.workingArea.paintingPipeline.Id);
this.workingArea.emit('createIcon', this.workingArea.paintingPipeline);
} else {
this.workingArea.previewLineSegment.visible = false;
this.workingArea.currentClickPoint.position =
new PIXI.Point(this.workingArea.circleShadow.x, this.workingArea.circleShadow.y);
this.workingArea.paintPoints.push(new PIXI.Point(x, y));
this.workingArea.paintingPipeline.assetData.MultiPoint =
JSON.parse(JSON.stringify(this.workingArea.paintPoints));
// this.workingArea.paintingPipeline.assetData.LinkedObjects.push(this);
// this.assetData.Pipelines.push(this.workingArea.paintingPipeline);
this.workingArea.paintingPipeline.refresh();
this.workingArea.initPipelineData();
}
}
}
}
// 刷新
public refresh() {
if (this.assetData.CanConnect) {
}
this.image.width = this.assetData.Width;
this.image.height = this.assetData.Height;
this.image.angle = this.assetData.Angle;
this.text.text = this.assetData.Name
+ '\r\n'
+ this.assetData.PropertyInfos?.find(item => item.PropertyName === '名称/编号')?.PropertyValue;
this.text.x = this.image.x;
this.text.y = this.image.y - this.image.height / 2;
}
}

523
src/app/working-area/working-area.component.ts

@ -2,21 +2,20 @@ import { Component, OnInit, ElementRef, ViewChild, AfterViewInit, Input } from '
import * as PIXI from 'pixi.js'; import * as PIXI from 'pixi.js';
import { EventEmitter } from 'events'; import { EventEmitter } from 'events';
import { EventManager } from '@angular/platform-browser'; import { EventManager } from '@angular/platform-browser';
import { OutlineFilter, OldFilmFilter } from 'pixi-filters'; import { OutlineFilter } from 'pixi-filters';
import { AssetData, CanvasShareDataService, DisposalNodeData, FloorNodeData } from '../canvas-share-data.service'; import { AssetData, CanvasShareDataService, DisposalNodeData, FloorNodeData } from '../canvas-share-data.service';
import * as ObjectID from 'bson-objectid'; import * as ObjectID from 'bson-objectid';
import { Charm } from './charm'; import { Charm } from './charm';
import { SinglePointIcon } from './model/singlePointIcon'; import { AxImageShape } from './model/axImageShape';
import { GameMode } from './model/gameMode'; import { GameMode } from './model/gameMode';
import { MultipointIcon } from './model/multipointIcon'; import { MultipointIcon } from './model/multipointIcon';
import { PolygonIcon } from './model/polygonIcon'; import { PolygonIcon } from './model/polygonIcon';
import { PutCarArea } from './model/putCarArea';
import { Arrows } from './model/arrows';
import { Pipeline } from './model/pipeline'; import { Pipeline } from './model/pipeline';
import { PaintMode } from './model/paintModel'; import { PaintMode } from './model/paintModel';
import { WallSpace } from './model/wallSpace';
import { AxShape } from './model/axShape'; import { AxShape } from './model/axShape';
import { PropertyInfo } from './model/PropertyInfo'; import { PropertyInfo } from './model/PropertyInfo';
import { AxPreviewImageShape } from './model/axPreviewImageShape';
import { AxArrowConnector } from './model/axArrowConnector';
@Component({ @Component({
@ -50,11 +49,11 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
/** /**
* *
*/ */
public backgroundImage: PIXI.Sprite; public backgroundImage: PIXI.Sprite = null;
/** /**
* *
*/ */
public previewSinglePointIcon = new PIXI.Sprite(); public previewImage: AxPreviewImageShape = null;
/** /**
* 线 * 线
*/ */
@ -70,7 +69,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
/** /**
* *
*/ */
private paintMode: PaintMode; private paintMode: PaintMode = PaintMode.endPaint;
/** /**
* *
*/ */
@ -82,20 +81,19 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
/** /**
* *
*/ */
public paintPoints: PIXI.Point[]; public paintPoints: PIXI.Point[] = [];
/** /**
* 线 * 线
*/ */
public paintingPipeline: Pipeline; public paintingPipeline: Pipeline = null;
/**
*
*/
public paintingArrows: Arrows = null;
/** /**
* *
*/ */
public paintingIcon: MultipointIcon; public paintingIcon: MultipointIcon;
public paintingWall: AxShape; /**
*
*/
public paintingShape: AxShape = null;
/** /**
* 线 * 线
*/ */
@ -159,52 +157,33 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
// 按Del键删除选中的图标 // 按Del键删除选中的图标
if (event.keyCode === 46) { if (event.keyCode === 46) {
this.selection.objects.forEach(item => { this.selection.objects.forEach(item => {
delete this.canvasData.originaleveryStoreyData.data[item.assetData.Id]; if (this.allowEdit
this.backgroundImage.removeChild(this.backgroundImage.getChildByName(item.assetData.Id)); && this.canvasData.gameMode === item.assetData.GameMode) {
this.canvasData.isChange = true; switch (this.canvasData.gameMode) {
case 0:
// 删除楼层数据
delete this.canvasData.originaleveryStoreyData.data[item.assetData.Id];
// 删除建筑数据
delete this.canvasData.originalcompanyBuildingData.data[item.assetData.Id];
// 取消渲染
this.backgroundImage.removeChild(this.backgroundImage.getChildByName(item.assetData.Id));
// 数据更改
this.canvasData.isChange = true;
break;
case 1:
delete this.canvasData.selectPanelPoint.Data.DefinedIncrement[item.assetData.Id];
delete this.canvasData.selectPanelPoint.Data.Increment[item.assetData.Id];
delete this.canvasData.selectPanelPoint.Data.Stock[item.assetData.Id];
this.backgroundImage.removeChild(this.backgroundImage.getChildByName(item.assetData.Id));
this.canvasData.isChange = true;
break;
}
}
}); });
this.selection.deselectAll();
this.emit('deleteIcon'); this.emit('deleteIcon');
} }
}); });
// 打印当前工作区信息
this.eventManager.addGlobalEventListener('window', 'keypress', (event: any) => {
// console.log(event.keyCode);
if (event.keyCode === 32) {
switch (this.paintMode) {
case 0:
console.log(`当前的绘制模式是:单点图标`);
break;
case 1:
console.log(`当前的绘制模式是:线段图标`);
break;
case 2:
console.log(`当前的绘制模式是:自定义多边形`);
break;
case 3:
console.log(`当前的绘制模式是:水带多边形`);
break;
case 4:
console.log(`当前的绘制模式是:暂无`);
break;
case 5:
console.log(`当前的绘制模式是:暂无`);
break;
case 6:
console.log(`当前的绘制模式是:结束绘制`);
break;
default:
break;
}
console.log('当前楼层的数据:');
console.log(this.canvasData.originaleveryStoreyData.data);
console.log('绘制中的管线:');
console.log(this.paintingPipeline);
console.log('处置预案数据:');
console.log(this.canvasData.selectPanelPoint.Data);
}
});
} }
/** /**
* *
@ -298,11 +277,18 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.app.ticker.add((delta) => { this.app.ticker.add((delta) => {
this.animator.update(); this.animator.update();
this.mousePosition = this.app.renderer.plugins.interaction.mouse.global; this.mousePosition = this.app.renderer.plugins.interaction.mouse.global;
if (this.backgroundImage !== undefined) { // 预览图片
this.previewSinglePointIcon.position = this.backgroundImage.toLocal(this.mousePosition); if (this.previewImage !== null) {
this.previewImage.position = this.backgroundImage.toLocal(this.mousePosition);
}
if (this.backgroundImage !== null) {
this.circleShadow.position = this.backgroundImage.toLocal(this.mousePosition); this.circleShadow.position = this.backgroundImage.toLocal(this.mousePosition);
this.refreshPreviewLineSegment(this.currentClickPoint.position, this.circleShadow.position); this.refreshPreviewLineSegment(this.currentClickPoint.position, this.circleShadow.position);
} }
/**
*
*/
if (this.rectToolGraphics.visible === true) { if (this.rectToolGraphics.visible === true) {
const init = this.initialScreenMousePos; const init = this.initialScreenMousePos;
@ -311,20 +297,22 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.rectToolGraphics.clear(); this.rectToolGraphics.clear();
this.rectToolGraphics.lineStyle(2, 0x00ff00, 1); this.rectToolGraphics.lineStyle(2, 0x00ff00, 1);
this.rectToolGraphics.beginFill(0xccccf2, 0.25); this.rectToolGraphics.beginFill(0xccccf2, 0.25);
this.rectToolGraphics.drawRect(init.x, init.y, final.x - init.x, final.y - init.y); if (final.x > init.x && final.y > init.y) {
this.rectToolGraphics.drawRect(init.x, init.y, final.x - init.x, final.y - init.y);
} else if (final.x > init.x && final.y < init.y) {
this.rectToolGraphics.drawRect(init.x, final.y, final.x - init.x, init.y - final.y);
} else if (final.x < init.x && final.y > init.y) {
this.rectToolGraphics.drawRect(final.x, init.y, init.x - final.x, final.y - init.y);
} else if (final.x < init.x && final.y < init.y) {
this.rectToolGraphics.drawRect(final.x, final.y, init.x - final.x, init.y - final.y);
}
this.rectToolGraphics.endFill(); this.rectToolGraphics.endFill();
this.rectToolGraphics.closePath();
}
if (this.paintingArrows !== null) {
this.paintingArrows.assetData.pointB = new PIXI.Point(this.circleShadow.position.x, this.circleShadow.position.y);
this.paintingArrows.refresh();
} }
}); });
/** /**
* *
*/ */
this.on('select', obj => { this.on('select', obj => {
// this.moveIconToScreenCenter(obj);
if (this.allowEdit) { if (this.allowEdit) {
if (obj instanceof MultipointIcon) { if (obj instanceof MultipointIcon) {
if (obj.assetData.GameMode === this.canvasData.gameMode) { if (obj.assetData.GameMode === this.canvasData.gameMode) {
@ -353,6 +341,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
if (obj instanceof MultipointIcon) { if (obj instanceof MultipointIcon) {
obj.setPointVisiable(false); obj.setPointVisiable(false);
} else if (obj instanceof PolygonIcon) { } else if (obj instanceof PolygonIcon) {
obj.filters = [];
obj.setPointVisiable(false); obj.setPointVisiable(false);
} else { } else {
obj.filters = []; obj.filters = [];
@ -361,10 +350,12 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
obj.filters = []; obj.filters = [];
} }
}); });
/**
*
*/
this.on('backgroundScale', scale => { this.on('backgroundScale', scale => {
this.previewSinglePointIcon.scale.set((0.5 / scale)); this.backgroundImage?.children.forEach(item => {
this.backgroundImage.children.forEach(item => { if (item instanceof AxImageShape) {
if (item instanceof SinglePointIcon) {
if (item.assetData.FixedSize) { if (item.assetData.FixedSize) {
const data = 1 / scale; const data = 1 / scale;
item.scale.set(data); item.scale.set(data);
@ -378,19 +369,26 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
} else if (item instanceof PolygonIcon) { } else if (item instanceof PolygonIcon) {
const data = 1 / scale; const data = 1 / scale;
item.text.scale.set(data); item.text.scale.set(data);
item.pointsGraphics.forEach(point => {
point.scale.set(data);
});
} else if (item instanceof AxPreviewImageShape) {
const data = 1 / scale;
item.scale.set(data);
} }
}); });
}); });
/**
*
*/
this.on('createIcon', obj => { this.on('createIcon', obj => {
if (obj.assetData.GameMode === GameMode.BasicInformation) { if (obj.assetData.GameMode === GameMode.BasicInformation) {
// if (obj.assetData.IsFromBuilding) { // 添加楼层数据
// this.canvasData.originalcompanyBuildingData.data[obj.assetData.Id] = obj.assetData; this.canvasData.originaleveryStoreyData.data[obj.assetData.Id] = obj.assetData;
// } else { // 添加建筑数据
this.canvasData.originaleveryStoreyData.data[obj.assetData.Id] = obj.assetData; this.canvasData.originalcompanyBuildingData.data[obj.assetData.Id] = obj.assetData;
// }
} else { } else {
// console.log();
if (this.canvasData.selectPanelPoint.Data === undefined if (this.canvasData.selectPanelPoint.Data === undefined
|| this.canvasData.selectPanelPoint.Data === null) { || this.canvasData.selectPanelPoint.Data === null) {
this.canvasData.selectPanelPoint.Data = new FloorNodeData(); this.canvasData.selectPanelPoint.Data = new FloorNodeData();
@ -399,6 +397,15 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
} }
this.canvasData.isChange = true; 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);
} }
/** /**
* *
@ -413,7 +420,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
*/ */
public setNameVisible(value: boolean, mode: GameMode): void { public setNameVisible(value: boolean, mode: GameMode): void {
this.backgroundImage?.children.forEach(item => { this.backgroundImage?.children.forEach(item => {
if (item instanceof SinglePointIcon) { if (item instanceof AxImageShape) {
item.setNameVisible(value, mode); item.setNameVisible(value, mode);
} else if (item instanceof MultipointIcon) { } else if (item instanceof MultipointIcon) {
item.setNameVisible(value, mode); item.setNameVisible(value, mode);
@ -428,12 +435,15 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
*/ */
public refreshIcon(id: string): void { public refreshIcon(id: string): void {
const icon = this.backgroundImage.children.find(item => item.name === id); const icon = this.backgroundImage.children.find(item => item.name === id);
if (icon instanceof SinglePointIcon) { console.log(icon);
if (icon instanceof AxImageShape) {
icon.refresh(); icon.refresh();
} else if (icon instanceof MultipointIcon) { } else if (icon instanceof MultipointIcon) {
icon.refresh(); icon.refresh();
} else if (icon instanceof PolygonIcon) { } else if (icon instanceof PolygonIcon) {
icon.refresh(); icon.refresh();
} else if (icon instanceof AxArrowConnector) {
icon.redraw();
} }
} }
/** /**
@ -442,8 +452,9 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
*/ */
public setIconScale(value: number): void { public setIconScale(value: number): void {
this.backgroundImage.children.forEach(item => { this.backgroundImage.children.forEach(item => {
if (item instanceof SinglePointIcon) { if (item instanceof AxImageShape) {
item.scale.set(value); console.log(item.image.scale);
item.image.scale.set(value);
} else if (item instanceof MultipointIcon) { } else if (item instanceof MultipointIcon) {
} else if (item instanceof PolygonIcon) { } else if (item instanceof PolygonIcon) {
@ -471,46 +482,46 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.setPaintMode(PaintMode.endPaint); this.setPaintMode(PaintMode.endPaint);
this.resetCanvas(); this.resetCanvas();
this.destroyBackgroundImage(); this.destroyBackgroundImage();
await this.createBackgroundImage(this.canvasData.selectStorey.imageUrl); if (!this.canvasData.selectStorey.imageUrl) {
return;
// this.refreshBackgroundImage(); }
// this.versionChecking();
await this.createBackgroundImage(this.canvasData.selectStorey.imageUrl);
this.createFloorShape();
if (this.canvasData.gameMode === GameMode.Assignment) {
this.createWorkNode();
}
this.emit('backgroundScale', this.backgroundImage.scale.x);
}
/**
*
*/
private createFloorShape() {
const floorData = this.canvasData.originaleveryStoreyData.data; const floorData = this.canvasData.originaleveryStoreyData.data;
// const buildingData = this.canvasData.originalcompanyBuildingData.data;
// const floor = this.canvasData.selectStorey;
// // key=>属性名 data[key]=>属性值
Object.keys(floorData).forEach((key) => { Object.keys(floorData).forEach((key) => {
console.log(floorData[key]);
switch (floorData[key].InteractiveMode) { switch (floorData[key].InteractiveMode) {
case 0: case 0:
const singleIcon = new SinglePointIcon(floorData[key], this); const singleIcon = new AxImageShape(floorData[key], this);
singleIcon.moveable = this.allowEdit && this.canvasData.gameMode === singleIcon.assetData.GameMode;
break; break;
case 1: case 1:
const icon = new MultipointIcon(floorData[key], this); const icon = new MultipointIcon(floorData[key], this);
break; break;
case 2: case 2:
const polygonIcon = new PolygonIcon(floorData[key], this); const polygonIcon = new PolygonIcon(floorData[key], this);
break; break;
case 3:
if (floorData[key].Name === '水带') {
const pipeline = new Pipeline(floorData[key], this);
} else {
const wall = new AxArrowConnector(floorData[key], this);
}
break;
} }
}); });
// Object.keys(buildingData).forEach((key) => { }
// if (buildingData[key].FloorId === floor.id) {
// switch (buildingData[key].InteractiveMode) {
// case 0:
// const singleIcon = new SinglePointIcon(buildingData[key], this);
// break;
// case 1:
// const icon = new MultipointIcon(buildingData[key], this);
// break;
// case 2:
// const polygonIcon = new PolygonIcon(buildingData[key], this);
// break;
// }
// }
// });
private createWorkNode() {
// 加载处置节点数据 // 加载处置节点数据
const nodeData = this.canvasData.selectPanelPoint.Data; const nodeData = this.canvasData.selectPanelPoint.Data;
if (nodeData !== undefined && nodeData !== null) { if (nodeData !== undefined && nodeData !== null) {
@ -518,23 +529,22 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
Object.keys(nodeData[key]).forEach((tempKey) => { Object.keys(nodeData[key]).forEach((tempKey) => {
switch (nodeData[key][tempKey].InteractiveMode) { switch (nodeData[key][tempKey].InteractiveMode) {
case 0: case 0:
const singleIcon = new SinglePointIcon(nodeData[key][tempKey], this); const singleIcon = new AxImageShape(nodeData[key][tempKey], this);
singleIcon.moveable = this.allowEdit && this.canvasData.gameMode === singleIcon.assetData.GameMode;
break; break;
case 1: case 1:
if (nodeData[key][tempKey].Name === '水带') {
const pipeline = new Pipeline(nodeData[key][tempKey], this);
} else {
const icon = new MultipointIcon(nodeData[key][tempKey], this); const icon = new MultipointIcon(nodeData[key][tempKey], this);
} break;
break; case 2:
case 2:
const polygonIcon = new PolygonIcon(nodeData[key][tempKey], this); const polygonIcon = new PolygonIcon(nodeData[key][tempKey], this);
break; break;
case 3:
const pipeline = new Pipeline(nodeData[key][tempKey], this);
break;
} }
}); });
}); });
} }
this.emit('backgroundScale', this.backgroundImage.scale.x);
} }
/** /**
* *
@ -614,7 +624,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.backgroundImage.y = this.app.view.height / 2; this.backgroundImage.y = this.app.view.height / 2;
this.backgroundImage.interactive = true; this.backgroundImage.interactive = true;
this.backgroundImage.name = 'background'; this.backgroundImage.name = 'background';
this.backgroundImage.angle = this.canvasData.selectStorey.imageAngle;
// const left = this.init.element.nativeElement.querySelector('.functionalDomainLeft').clientWidth; // const left = this.init.element.nativeElement.querySelector('.functionalDomainLeft').clientWidth;
// const right = this.init.element.nativeElement.querySelector('.functionalDomainRight').clientWidth; // const right = this.init.element.nativeElement.querySelector('.functionalDomainRight').clientWidth;
const imageWidth = this.backgroundImage.texture.width; const imageWidth = this.backgroundImage.texture.width;
@ -667,7 +677,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
ImageUrl: this.canvasData.selectTemplateData.imageUrl, ImageUrl: this.canvasData.selectTemplateData.imageUrl,
InteractiveMode: this.canvasData.selectTemplateData.interactiveMode, InteractiveMode: this.canvasData.selectTemplateData.interactiveMode,
MultiPoint : null, MultiPoint : null,
Point: new PIXI.Point(this.previewSinglePointIcon.x, this.previewSinglePointIcon.y), Point: new PIXI.Point(this.previewImage.x, this.previewImage.y),
Name : this.canvasData.selectTemplateData.name, Name : this.canvasData.selectTemplateData.name,
PropertyInfos: list, PropertyInfos: list,
Border : this.canvasData.selectTemplateData.border, Border : this.canvasData.selectTemplateData.border,
@ -676,7 +686,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
IsFromBuilding : this.canvasData.selectTemplateData.isFromBuilding, IsFromBuilding : this.canvasData.selectTemplateData.isFromBuilding,
GameMode : this.canvasData.gameMode GameMode : this.canvasData.gameMode
}; };
const singleIcon = new SinglePointIcon(assetData, this); const singleIcon = new AxImageShape(assetData, this);
this.emit('createIcon', singleIcon); this.emit('createIcon', singleIcon);
this.emit('backgroundScale', this.backgroundImage.scale.x); this.emit('backgroundScale', this.backgroundImage.scale.x);
break; break;
@ -761,78 +771,60 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
// this.paintingIcon = new PolygonIcon(this.paintPoints, this); // this.paintingIcon = new PolygonIcon(this.paintPoints, this);
break; break;
case PaintMode.Pipeline: case PaintMode.Pipeline:
if (this.canvasData.selectTemplateData.name === '水带') {
if (this.paintingPipeline !== null) { if (this.paintingPipeline !== null) {
this.currentClickPoint.position = new PIXI.Point(this.circleShadow.x, this.circleShadow.y);
this.paintPoints.push(new PIXI.Point(this.circleShadow.x, this.circleShadow.y));
this.paintingPipeline.assetData.MultiPoint = JSON.parse(JSON.stringify(this.paintPoints));
this.paintingPipeline.refresh();
}
} else {
this.previewLineSegment.visible = true;
this.currentClickPoint.position = new PIXI.Point(this.circleShadow.x, this.circleShadow.y); this.currentClickPoint.position = new PIXI.Point(this.circleShadow.x, this.circleShadow.y);
this.paintPoints.push(new PIXI.Point(this.circleShadow.x, this.circleShadow.y)); this.paintPoints.push(new PIXI.Point(this.circleShadow.x, this.circleShadow.y));
this.paintingPipeline.assetData.MultiPoint = JSON.parse(JSON.stringify(this.paintPoints));
this.paintingPipeline.refresh();
}
// this.emit('backgroundScale', this.backgroundImage.scale.x);
break;
case PaintMode.Arrows:
if (this.paintingArrows === null) {
const data = {
Id: ObjectID.default.generate(),
name: 'string',
point: new PIXI.Point(this.circleShadow.x, this.circleShadow.y),
pointA: new PIXI.Point(this.circleShadow.x, this.circleShadow.y),
pointB: new PIXI.Point(this.circleShadow.x, this.circleShadow.y),
source: 'assets/images/进攻方向.png',
};
this.paintingArrows = new Arrows(data, this);
} else {
this.paintingArrows.ready = true;
this.paintingArrows = null;
this.paintMode = PaintMode.endPaint;
}
break;
case PaintMode.Car:
// this.previewLineSegment.visible = true;
// this.currentClickPoint.position = new PIXI.Point(this.circleShadow.x, this.circleShadow.y);
// this.paintPoints.push(new PIXI.Point(this.circleShadow.x, this.circleShadow.y));
// if (this.paintPoints.length >= 2) {
// this.enterPaintEndButton.position = this.circleShadow.position;
// this.enterPaintEndButton.visible = true;
// }
// if (this.paintingWall !== null) {
// this.backgroundImage.removeChild(this.paintingWall);
// }
// const jsonObject1 = JSON.parse(JSON.stringify(this.canvasData.selectTemplateData.propertyInfos));
// const propertyList1 = [];
// jsonObject1.forEach(element => {
// const property = new PropertyInfo(element);
// propertyList1.push(property);
// });
// const assetData11 = {
// TemplateId: this.canvasData.selectTemplateData.id,
// FloorId: this.canvasData.selectStorey.id,
// Angle: this.canvasData.selectTemplateData.angle,
// Color: this.canvasData.selectTemplateData.color,
// Enabled: this.canvasData.selectTemplateData.enabled,
// FillMode: this.canvasData.selectTemplateData.fillMode,
// FireElementId: this.canvasData.selectTemplateData.fireElementId,
// FixedSize: this.canvasData.selectTemplateData.fixedSize,
// Height: 32,
// Width: 32,
// Id: ObjectID.default.generate(),
// ImageUrl: this.canvasData.selectTemplateData.imageUrl,
// InteractiveMode: this.canvasData.selectTemplateData.interactiveMode,
// MultiPoint: JSON.parse(JSON.stringify(this.paintPoints)),
// Point: new PIXI.Point(0, 0),
// Name: this.canvasData.selectTemplateData.name,
// PropertyInfos: propertyList1,
// Border: this.canvasData.selectTemplateData.border,
// DrawMode: this.canvasData.selectTemplateData.drawMode,
// Thickness: this.canvasData.selectTemplateData.thickness,
// IsFromBuilding: this.canvasData.selectTemplateData.isFromBuilding,
// GameMode: this.canvasData.gameMode
// };
// this.paintingWall = new WallSpace(assetData11, this); if (this.paintPoints.length >= 2) {
// this.emit('backgroundScale', this.backgroundImage.scale.x); this.enterPaintEndButton.position = this.circleShadow.position;
this.enterPaintEndButton.visible = true;
}
if (this.paintingShape === null) {
const jsonObject = JSON.parse(JSON.stringify(this.canvasData.selectTemplateData.propertyInfos));
const propertyList = [];
jsonObject.forEach(element => {
const property = new PropertyInfo(element);
propertyList.push(property);
});
const assetData2 = {
TemplateId: this.canvasData.selectTemplateData.id,
FloorId: this.canvasData.selectStorey.id,
Angle: this.canvasData.selectTemplateData.angle,
Color: this.canvasData.selectTemplateData.color,
Enabled: this.canvasData.selectTemplateData.enabled,
FillMode: this.canvasData.selectTemplateData.fillMode,
FireElementId: this.canvasData.selectTemplateData.fireElementId,
FixedSize: this.canvasData.selectTemplateData.fixedSize,
Height: 32,
Width: 32,
Id: ObjectID.default.generate(),
ImageUrl: this.canvasData.selectTemplateData.imageUrl,
InteractiveMode: this.canvasData.selectTemplateData.interactiveMode,
MultiPoint: JSON.parse(JSON.stringify(this.paintPoints)),
Point: new PIXI.Point(0, 0),
Name: this.canvasData.selectTemplateData.name,
PropertyInfos: propertyList,
Border: this.canvasData.selectTemplateData.border,
DrawMode: this.canvasData.selectTemplateData.drawMode,
Thickness: this.canvasData.selectTemplateData.thickness,
IsFromBuilding: this.canvasData.selectTemplateData.isFromBuilding,
GameMode: this.canvasData.gameMode
};
this.paintingShape = new AxArrowConnector(assetData2, this);
} else {
this.paintingShape.assetData.MultiPoint = JSON.parse(JSON.stringify(this.paintPoints));
this.paintingShape.redraw();
}
}
this.emit('backgroundScale', this.backgroundImage.scale.x);
break; break;
} }
} else if (!event.currentTarget.dragging && this.selection.isMultiselection === true) { } else if (!event.currentTarget.dragging && this.selection.isMultiselection === true) {
@ -849,11 +841,15 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
} }
if (this.rectToolGraphics.visible === true) { if (this.rectToolGraphics.visible === true) {
this.backgroundImage.children.forEach(item => { this.backgroundImage.children.forEach(item => {
if (item instanceof SinglePointIcon if ( item instanceof AxImageShape
|| item instanceof MultipointIcon || item instanceof MultipointIcon
|| item instanceof PolygonIcon) { || item instanceof PolygonIcon
if (this.rectToolGraphics.getLocalBounds().contains(item.x, item.y)) { || item instanceof AxArrowConnector) {
this.selection.select(item); // 判断2个矩形是否相交
const rect1 = this.rectToolGraphics.getBounds();
const rect2 = item.getBounds();
if (this.isOverlap(rect1, rect2)) {
this.selection.select(item);
} }
} }
}); });
@ -884,19 +880,38 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.setPaintMode(PaintMode.endPaint); this.setPaintMode(PaintMode.endPaint);
}) })
.on('pointerover', (event) => { .on('pointerover', (event) => {
this.previewSinglePointIcon.filters = null; if (this.previewImage !== null
&& this.paintMode === PaintMode.singlePointIcon) {
this.previewImage.visible = true;
}
}) })
.on('pointerout', (event) => { .on('pointerout', (event) => {
this.previewSinglePointIcon.filters = null; if (this.previewImage !== null
&& this.paintMode === PaintMode.singlePointIcon) {
this.previewImage.visible = false;
}
}); });
this.app.stage.addChild(this.backgroundImage); this.app.stage.addChild(this.backgroundImage);
this.createPreviewSinglePointIcon(); this.createPreviewImage();
this.createPreviewLineSegment(); this.createPreviewLineSegment();
this.createCircleShadow(); this.createCircleShadow();
this.createEnterPaintEndButton(); this.createEnterPaintEndButton();
this.backgroundImage.addChild(this.paintingLine); this.backgroundImage.addChild(this.paintingLine);
} }
public isOverlap(rect1, rect2):boolean {
const l1 = { x: rect1.x, y: rect1.y }
const r1 = { x: rect1.x + rect1.width, y: rect1.y + rect1.height }
const l2 = { x: rect2.x, y: rect2.y }
const r2 = { x: rect2.x + rect2.width, y: rect2.y + rect2.height }
if (
l1.x > r2.x ||
l2.x > r1.x ||
l1.y > r2.y ||
l2.y > r1.y
) return false
return true
}
/** /**
* *
@ -905,9 +920,10 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
if (!this.canvasData.selectStorey.imageUrl) { if (!this.canvasData.selectStorey.imageUrl) {
this.backgroundImage.visible = false; this.backgroundImage.visible = false;
} else { } else {
this.backgroundImage.texture = PIXI.Texture.from(this.canvasData.selectStorey.imageUrl); // this.backgroundImage.texture = PIXI.Texture.from(this.canvasData.selectStorey.imageUrl);
this.backgroundImage.angle = this.canvasData.selectStorey.imageAngle; // this.backgroundImage.angle = this.canvasData.selectStorey.imageAngle;
this.backgroundImage.visible = true; // this.backgroundImage.visible = true;
this.refresh();
} }
} }
/** /**
@ -921,8 +937,8 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
* @param scale * @param scale
*/ */
public setBackgroundScale(scale: number): void { public setBackgroundScale(scale: number): void {
this.backgroundImage.scale.set(scale); this.backgroundImage?.scale.set(scale);
this.emit('backgroundScale', this.backgroundImage.scale.x); this.emit('backgroundScale', this.backgroundImage?.scale.x);
} }
/** /**
* *
@ -934,22 +950,18 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
/** /**
* *
*/ */
private createPreviewSinglePointIcon(): void { private createPreviewImage(): void {
this.previewSinglePointIcon = PIXI.Sprite.from('assets/images/noImg.png'); // if (this.previewSinglePointIcon === null) {
this.previewSinglePointIcon.width = 32; // this.previewSinglePointIcon = PIXI.Sprite.from(this.canvasData.selectTemplateData.imageUrl);
this.previewSinglePointIcon.height = 32; // this.previewSinglePointIcon.width = this.canvasData.selectTemplateData.width;
this.previewSinglePointIcon.alpha = 1; // this.previewSinglePointIcon.height = this.canvasData.selectTemplateData.height;
this.previewSinglePointIcon.anchor.set(0.5); // this.previewSinglePointIcon.anchor.set(0.5);
this.previewSinglePointIcon.visible = false; // this.previewSinglePointIcon.interactive = false;
this.backgroundImage.addChild(this.previewSinglePointIcon); // this.backgroundImage.addChild(this.previewSinglePointIcon);
} // this.previewSinglePointIcon.scale.set(1 / this.backgroundImage.scale.x);
/** // }
* this.previewImage = new AxPreviewImageShape(this);
* @param uri this.previewImage.visible = false;
*/
private changePreviewSinglePointIcon(uri: string): void {
this.previewSinglePointIcon.texture = PIXI.Texture.from(uri);
this.previewSinglePointIcon.visible = true;
} }
/** /**
* 线 * 线
@ -969,7 +981,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
*/ */
private refreshPreviewLineSegment(pointA: PIXI.Point, pointB: PIXI.Point) { private refreshPreviewLineSegment(pointA: PIXI.Point, pointB: PIXI.Point) {
this.previewLineSegment.clear(); this.previewLineSegment.clear();
this.previewLineSegment.lineStyle(1, 0xffd900, 1); this.previewLineSegment.lineStyle(5, 0x00ff00, 1);
this.previewLineSegment.moveTo(pointA.x, pointA.y); this.previewLineSegment.moveTo(pointA.x, pointA.y);
this.previewLineSegment.lineTo(pointB.x, pointB.y ); this.previewLineSegment.lineTo(pointB.x, pointB.y );
} }
@ -986,7 +998,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
} }
showConnectionPoint(b: boolean) { showConnectionPoint(b: boolean) {
this.backgroundImage?.children.forEach(item => { this.backgroundImage?.children.forEach(item => {
if (item instanceof SinglePointIcon) { if (item instanceof AxImageShape) {
if (item.assetData.CanConnect) { if (item.assetData.CanConnect) {
item.showConnectionPoint(b); item.showConnectionPoint(b);
} }
@ -997,27 +1009,9 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
* *
*/ */
public beginPaint() { public beginPaint() {
if (this.canvasData.selectTemplateData.name === '水带') { this.selection.deselectAll();
this.showConnectionPoint(true); this.setPaintMode(PaintMode.endPaint);
this.setPaintMode(PaintMode.Pipeline); this.setPaintMode(this.canvasData.selectTemplateData.interactiveMode);
return;
}
switch (this.canvasData.selectTemplateData.interactiveMode) {
case 0:
this.setPaintMode(PaintMode.singlePointIcon);
break;
case 1:
this.setPaintMode(PaintMode.lineIcon);
break;
case 2:
this.setPaintMode(PaintMode.polygonIcon);
break;
case 3:
if (this.canvasData.selectTemplateData.name) {
this.setPaintMode(PaintMode.Pipeline);
}
break;
}
} }
/** /**
* 线 * 线
@ -1034,18 +1028,14 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
* @param mode * @param mode
*/ */
public setPaintMode(mode: PaintMode) { public setPaintMode(mode: PaintMode) {
if (this.paintMode === mode) { return; } if (this.paintMode === mode) {
this.paintMode = mode; return;
if (this.paintMode !== PaintMode.Pipeline) {
this.showConnectionPoint(false);
} }
this.paintMode = mode;
switch (this.paintMode) { switch (this.paintMode) {
case PaintMode.Pipeline:
break;
case PaintMode.singlePointIcon: case PaintMode.singlePointIcon:
this.previewSinglePointIcon.visible = false; this.previewImage.visible = true;
this.changePreviewSinglePointIcon(this.canvasData.selectTemplateData.imageUrl); this.previewImage.setImageUrl(this.canvasData.selectTemplateData.imageUrl);
break; break;
case PaintMode.lineIcon: case PaintMode.lineIcon:
this.circleShadow.visible = false; this.circleShadow.visible = false;
@ -1054,7 +1044,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
if (this.paintingIcon !== null) { if (this.paintingIcon !== null) {
this.backgroundImage.removeChild(this.paintingIcon); this.backgroundImage.removeChild(this.paintingIcon);
} }
this.previewSinglePointIcon.texture = PIXI.Texture.from(this.canvasData.selectTemplateData.imageUrl); this.previewImage.setImageUrl(this.canvasData.selectTemplateData.imageUrl);
this.circleShadow.visible = true; this.circleShadow.visible = true;
break; break;
case PaintMode.polygonIcon: case PaintMode.polygonIcon:
@ -1065,7 +1055,18 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.paintingLine.clear(); this.paintingLine.clear();
this.circleShadow.visible = true; this.circleShadow.visible = true;
break; break;
case PaintMode.Pipeline:
if (this.canvasData.selectTemplateData.name==='水带') {
this.showConnectionPoint(true);
} else {
}
break;
case PaintMode.endPaint: case PaintMode.endPaint:
this.showConnectionPoint(false);
if (this.previewImage !== null) {
this.previewImage.visible = false;
}
// 重置组件状态 // 重置组件状态
if ( this.paintingIcon !== undefined if ( this.paintingIcon !== undefined
&& this.paintingIcon !== null) { && this.paintingIcon !== null) {
@ -1076,6 +1077,11 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
&& this.paintingPipeline !== null) { && this.paintingPipeline !== null) {
this.backgroundImage.removeChild(this.paintingPipeline); this.backgroundImage.removeChild(this.paintingPipeline);
} }
if (this.paintingShape !== null) {
this.backgroundImage.removeChild(this.paintingShape);
this.paintingShape = null;
}
this.enterPaintEndButton.visible = false;
this.paintingLine.clear(); this.paintingLine.clear();
this.resetData(); this.resetData();
break; break;
@ -1093,10 +1099,6 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
* *
*/ */
public resetData() { public resetData() {
this.previewSinglePointIcon.filters = null;
this.previewSinglePointIcon.visible = false;
this.previewSinglePointIcon.angle = 0;
this.initPipelineData(); this.initPipelineData();
// //
this.circleShadow.visible = false; this.circleShadow.visible = false;
@ -1108,7 +1110,10 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
private enterPaint(): void { private enterPaint(): void {
this.previewLineSegment.visible = false; this.previewLineSegment.visible = false;
this.enterPaintEndButton.visible = false; this.enterPaintEndButton.visible = false;
console.log(this.paintMode);
switch (this.paintMode) { switch (this.paintMode) {
case PaintMode.singlePointIcon:
break;
case PaintMode.lineIcon: case PaintMode.lineIcon:
if (this.paintPoints.length >= 2) { if (this.paintPoints.length >= 2) {
this.emit('createIcon', this.paintingIcon); this.emit('createIcon', this.paintingIcon);
@ -1152,6 +1157,12 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
this.emit('createIcon', polygonIcon); this.emit('createIcon', polygonIcon);
} }
break; break;
case PaintMode.Pipeline:
if (this.canvasData.selectTemplateData.name !== '水带') {
this.emit('createIcon', this.paintingShape);
this.paintingShape = null;
}
break;
} }
this.paintPoints.splice(0, this.paintPoints.length); this.paintPoints.splice(0, this.paintPoints.length);
this.emit('backgroundScale', this.backgroundImage.scale.x); this.emit('backgroundScale', this.backgroundImage.scale.x);
@ -1185,7 +1196,7 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
// } // }
switch (item.InteractiveMode) { switch (item.InteractiveMode) {
case PaintMode.singlePointIcon: case PaintMode.singlePointIcon:
const singleIcon = new SinglePointIcon(newData, this); const singleIcon = new AxImageShape(newData, this);
break; break;
case PaintMode.lineIcon: case PaintMode.lineIcon:
const lineIcon = new MultipointIcon(newData, this); const lineIcon = new MultipointIcon(newData, this);
@ -1193,9 +1204,15 @@ export class WorkingAreaComponent extends EventEmitter implements OnInit, AfterV
case PaintMode.polygonIcon: case PaintMode.polygonIcon:
const polygonIcon = new PolygonIcon(newData, this); const polygonIcon = new PolygonIcon(newData, this);
break; break;
case PaintMode.Pipeline:
if (item.Name !== '水带') {
const wall = new AxArrowConnector(newData, this);
}
break;
} }
this.selection.select(this.backgroundImage.getChildByName(newData.Id)); this.selection.select(this.backgroundImage.getChildByName(newData.Id));
}); });
this.emit('backgroundScale', this.backgroundImage.scale.x);
} }
} }

8
src/assets/css/ngZorroTree.css

@ -344,9 +344,15 @@
text-align: center; text-align: center;
cursor: pointer cursor: pointer
} }
#createtestscore .ant-tree .ant-tree-switcher { #createtestscore,#nodeTree .ant-tree .ant-tree-switcher {
line-height: 22px; line-height: 22px;
} }
#uploadfiretree .ant-tree .ant-tree-switcher {
line-height: 20px;
}
#disposalNodeTree .ant-tree-checkbox {
margin-top: 10px;
}
.ant-tree .ant-tree-switcher .ant-select-tree-switcher-icon, .ant-tree .ant-tree-switcher .ant-select-tree-switcher-icon,
.ant-tree .ant-tree-switcher .ant-tree-switcher-icon { .ant-tree .ant-tree-switcher .ant-tree-switcher-icon {

8
src/styles.scss

@ -98,11 +98,17 @@ table td.mat-footer-cell:last-of-type{
} }
//可展开面板按钮颜色 //可展开面板按钮颜色
#createtestscore{ #createtestscore,#materialBank{
.mat-expansion-indicator::after { .mat-expansion-indicator::after {
color: #333333; color: #333333;
} }
} }
#materialBank{
.mat-expansion-panel-header{
background-color: #d6f4f5
}
}
//弹出框样式取消padding //弹出框样式取消padding
#addPlanTwo,#lookTreeNode{ #addPlanTwo,#lookTreeNode{
padding: 0; padding: 0;

Loading…
Cancel
Save