考核考试系统
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

1764 lines
65 KiB

import { Component, OnInit, Inject, ViewChild, ElementRef, Renderer2, ViewContainerRef } from '@angular/core';
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import { MatTreeFlatDataSource, MatTreeFlattener } from '@angular/material/tree';
import { FlatTreeControl } from '@angular/cdk/tree';
import { WorkingAreaComponent } from '../../working-area/working-area.component'
import { CanvasShareDataService, DisposalNodeData } from '../../canvas-share-data.service' //引入服务
import Viewer from 'viewerjs';
import Swiper from 'swiper';
import { saveOneDialogExaminee } from './save';
import { NzFormatBeforeDropEvent, NzFormatEmitEvent, NzTreeComponent } from 'ng-zorro-antd/tree';
import { Observable, of } from 'rxjs';
import { delay } from 'rxjs/operators';
import { windows } from 'src/app/interface';
import { GameMode } from 'src/app/working-area/model/gameMode';
import { ActivatedRoute, Router } from '@angular/router';
import { examinationQuestionsExaminee, uploadDisposalNodesExaminee, uploadQuestionsExaminee } from './examinationQuestions'
import { AxMessageSystem } from 'src/app/working-area/model/axMessageSystem';
@Component({
selector: 'app-collection-tools',
templateUrl: './collection-tools.component.html',
styleUrls: ['./collection-tools.component.scss']
})
export class CollectionToolsExamineeComponent implements OnInit {
@ViewChild('canvas', { static: true }) canvas: WorkingAreaComponent; //父组件中获得子组件的引用
constructor(private http: HttpClient, public dialog: MatDialog, public snackBar: MatSnackBar, private element: ElementRef, public canvasData: CanvasShareDataService, private router: Router, private route: ActivatedRoute) { }
@ViewChild('nzTreeComponent2', { static: false }) nzTreeComponent!: NzTreeComponent;
// 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;
colors = ['#076eec', '#4dd0e1', '#00ee76', '#ffff00', '#eeb422',
'#FF6A6A', '#ff0000', '#ff6eb4', '#00bfff', '#54ff9f',
'#009688', '#836fff', '#ff8c00', '#ee00ee', '#ffa07a',
'#00C500', '#00ffff', '#6495ed', '#ffdAb9', '#AA00FF']
selected = "1" //图标大小选择框
allBuildings //该单位所有建筑
beforeOneCheckedBuilding: any = { name: "总平面图" }; //当前点击选择的建筑
beforeOneCheckedBuildingIsShow: boolean = false; //建筑是否显示
togglebeforeOneCheckedBuilding() { this.beforeOneCheckedBuildingIsShow = !this.beforeOneCheckedBuildingIsShow }
checkedBuildingIndex: number = -1 //当前点击选择的建筑index
isEditPat: boolean = true //当前是否是编辑模式
assetName: String//素材名称
assetWidth: number//素材宽度
assetHeight: number//素材高度
sliderValue: number = 0//角度滑竿的值
sliderValueThickness: number = 0//厚度滑竿的值
isHighLight: boolean = false//是否高亮选择框
PropertyInfos = [] //去除图片链接真正用于循环的内容
imagesArrNum //素材属性图片数量上限
imagesArr = [] //属性中的图片链接集合
clickedIndex //点击图片时的索引值
//传入素材对象,设置右侧属性栏内容
canvasAssetObj //传入的素材属性对象
isImgNumCss = false //控制上传文件input显隐
mySwiper: any //轮播图实例
gallery//viewerJs实例
//设置属性框
setAssetsProperty(obj) {
//初始化viewerJs实例
setTimeout(() => {
obj.PropertyInfos.forEach(item => {
if (item.PropertyType == 4) {
this.gallery = new Viewer(document.getElementById('viewerjs'), {
url: 'data-original'
});
}
})
}, 0);
//从颜色中取出透明度
let color = obj.Color
let strh = color.substring(color.length - 2, color.length)
let opacity = Math.round(parseInt(strh, 16) / 255 * 100)
this.colorDivSliderValue = opacity
this.isShowProperty = true
this.isShowAttribute = false
let _this = this
this.imagesArr = []
this.imagesArrNum = ""
this.canvasAssetObj = obj //将选中素材对象存到本地变量
this.assetName = obj.Name
this.assetWidth = obj.Width
this.assetHeight = obj.Height
this.sliderValue = obj.Angle
this.selectedcolor = obj.Color
this.PropertyInfos = obj.PropertyInfos
this.sliderValueThickness = obj.Thickness
this.PropertyInfos.forEach(item => {
if (item.PropertyType == 3) { //如果是图片链接类型
this.imagesArr.push(item)
}
if (item.PropertyType == 4) {//图片数值上线
this.imagesArrNum = item.PropertyValue
}
})
//如果存在图片则加载轮播图
if (this.imagesArr.length) {
setTimeout(() => {
this.mySwiper = new Swiper('.swiper-container', {
loop: false,
// grabCursor: true,
// 如果需要前进后退按钮
navigation: {
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev',
},
on: {
click: function () {
_this.clickedIndex = this.clickedIndex
},
}
});
}, 0);
}
//判断此时图片数量是否达到上限
if (this.imagesArr.length < this.imagesArrNum) {//如果不超出
this.isImgNumCss = true
} else {
this.isImgNumCss = false
}
}
pattern: boolean = false//默认为基本信息编辑
//左侧div边框宽度调节
leftDivMouseDown(e) {
document.onmousemove = (ev) => {
let bodyWidth = document.body.clientWidth //网页宽度
let maxWidth = bodyWidth - 260 - this.element.nativeElement.querySelector('#rightDiv').clientWidth //最大宽度
if (ev.clientX - 240 >= maxWidth) {
this.element.nativeElement.querySelector('#leftDiv').style.width = maxWidth + 'px'
} else {
this.element.nativeElement.querySelector('#leftDiv').style.width = ev.clientX - 260 + 'px';
}
}
document.onmouseup = () => {
document.onmousemove = null;
document.onmouseup = null;
}
}
//右侧div边框宽度调节
rightDivMouseDown(e) {
document.onmousemove = (ev) => {
let bodyWidth = document.body.clientWidth //网页宽度
let maxWidth = bodyWidth - 240 - this.element.nativeElement.querySelector('#leftDiv').clientWidth //最大宽度
if (bodyWidth - ev.clientX >= maxWidth) {
this.element.nativeElement.querySelector('#rightDiv').style.width = maxWidth + 'px'
} else {
this.element.nativeElement.querySelector('#rightDiv').style.width = bodyWidth - ev.clientX + 'px';
}
}
document.onmouseup = () => {
document.onmousemove = null;
document.onmouseup = null;
}
}
//放大图标
iconScale() {
let number = Number(this.selected)
this.canvas.setIconScale(number)
}
//素材宽度输入框改变
assetWidthIunput() {
this.canvasAssetObj.Width = this.assetWidth
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//素材高度输入框改变
assetHeightIunput() {
this.canvasAssetObj.Height = this.assetHeight
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//素材角度输入框改变
assetAngleIunput() {
this.canvasAssetObj.Angle = this.sliderValue
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//素材厚度输入框改变
assetThicknessIunput() {
this.canvasAssetObj.Thickness = this.sliderValueThickness
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//素材是否高亮改变----->本地操作行为
assetHighLightIunput() {
}
//动态属性素材input框值改变
assetInputChange(i, e) {
let index = this.canvasAssetObj.PropertyInfos.findIndex((item) => {
return i.PropertyName == item.PropertyName
})
this.canvasAssetObj.PropertyInfos[index].PropertyValue = e.target.value
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//动态属性素材布尔值框改变radio
assetRadioChange(i, boolean) {
let index = this.canvasAssetObj.PropertyInfos.findIndex((item) => {
return i.PropertyName == item.PropertyName
})
this.canvasAssetObj.PropertyInfos[index].PropertyValue = boolean
this.canvasData.isChange = true
}
colorIndex//默认素材颜色
selectedcolor//点击选择的颜色
//选择素材颜色
selectcolor(item, key) {
//在当前透明度基础上改变颜色
this.selectedcolor = item + this.selectedcolor.substring(this.selectedcolor.length - 2)
this.canvasAssetObj.Color = this.selectedcolor
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//颜色选择滑竿的值
colorDivSliderValue
colorDivSliderChange() {
let colorOpacity = Math.round(255 * this.colorDivSliderValue * 0.01)
//根据滑竿值改变16进制颜色后两位
function replacepos(text, start, stop, replacetext) {
let mystr = text.substring(0, stop - 1) + replacetext + text.substring(stop + 1);
return mystr;
}
this.selectedcolor = replacepos(this.selectedcolor, 7, 8, colorOpacity.toString(16))
this.canvasAssetObj.Color = this.selectedcolor
this.canvasData.isChange = true
this.canvas.refreshIcon(this.canvasAssetObj.Id)
}
//上传素材图片
selectFile(e) {
let imgFile = e.target.files[0] || null //上传的文件
this.startUploading(imgFile)
}
objectName: any //上传对象名
startUploading(imgFile) {
let _this = this
let file = imgFile || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB一个分片
let companyId = sessionStorage.getItem("companyId")
if (file && fileSize <= shardSize) { //上传文件<=5MB时
let formData = new FormData()
formData.append("file", file)
this.http.post(`api/Objects/WebPlan2D/${companyId}`, formData).subscribe((data: any) => {
this.objectName = data.objectName
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传成功', '确定', config)
//在原始素材对象和需要循环图片的对象中分别push最新上传的图片
let imgObj = {
"Tag": null,
"Order": 0,
"Enabled": false,
"Visible": false,
"Required": false,
"RuleName": null,
"RuleValue": null,
"PhysicalUnit": null,
"PropertyName": "图片",
"PropertyType": 3,
"PropertyValue": "/api/Objects/WebPlan2D/" + this.objectName
}
this.imagesArr.push(imgObj)
this.canvasAssetObj.PropertyInfos.push(imgObj)
setTimeout(() => {
this.mySwiper = new Swiper('.swiper-container', {
loop: false,
// grabCursor: true,
// 如果需要前进后退按钮
navigation: {
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev',
},
on: {
click: function () {
_this.clickedIndex = this.clickedIndex
},
}
});
this.mySwiper.slideTo(this.imagesArr.length - 1)
this.gallery.update()
}, 0);
//判断上传素材属性图片是否超出数量 超出数量则隐藏input框
if (this.imagesArr.length < this.imagesArrNum) {//不超出input才会显示
this.isImgNumCss = true
} else {
this.isImgNumCss = false
}
this.canvasData.isChange = true
})
} else if (file && fileSize > shardSize) { //上传文件>5MB时,分块上传
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传图片文件不允许大于5mb', '确定', config);
}
}
//不能上传图片提示
imgNumBeyond() {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('图片数量已达上限', '确定', config);
}
//删除素材属性图片
deleteImg() {
if (this.imagesArr.length == 0) {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('没有可删除的图片,请先上传', '确定', config)
} else {
// 在素材原始对象中将删除的图片去掉
this.canvasAssetObj.PropertyInfos = [...this.canvasAssetObj.PropertyInfos.filter((item) => {
return item.PropertyValue != this.imagesArr[this.mySwiper.activeIndex].PropertyValue
})]
//在图片循环数组中将图片去掉
this.imagesArr.splice(this.mySwiper.activeIndex, 1);
//更新swiper视图
setTimeout(() => {
this.mySwiper.update();
this.gallery.update()
}, 0);
//将上传的input框显示出来
this.isImgNumCss = true;
//清除图片缓存
if ((<HTMLInputElement>document.getElementById('inputimg'))) {
(<HTMLInputElement>document.getElementById('inputimg')).value = null //清空input框缓存
}
this.canvasData.isChange = true
}
}
//动态属性方向select选择框
direction(i, e) {
let index = this.canvasAssetObj.PropertyInfos.findIndex((item) => {
return i.PropertyName == item.PropertyName
})
this.canvasAssetObj.PropertyInfos[index].PropertyValue = e.target.value
this.canvasData.isChange = true
}
//动态属性供给区域select选择框
supplyArea(i, e) {
let index = this.canvasAssetObj.PropertyInfos.findIndex((item) => {
return i.PropertyName == item.PropertyName
})
this.canvasAssetObj.PropertyInfos[index].PropertyValue = e.target.value
this.canvasData.isChange = true
}
//动态属性供给类型select选择框
supplyType(i, e) {
let index = this.canvasAssetObj.PropertyInfos.findIndex((item) => {
return i.PropertyName == item.PropertyName
})
this.canvasAssetObj.PropertyInfos[index].PropertyValue = e.target.value
this.canvasData.isChange = true
}
isSixShow = true
isSixbtn = true //控制想定作业编辑按钮
isxxx = true //控制查看编辑模式的编辑模式按钮
examMsg = { //单位,考试信息
conpanyName: sessionStorage.getItem('companyName') || '暂无数据', //单位名称
keynote: '', //考试要点
}
async ngOnInit(): Promise<void> {
// this.canvasData.gameMode = GameMode.Assignment
this.getAllLibrary('plan') //获取素材库
this.getAllBuildings() //获取所有建筑
this.getAllFirePlan() //获取当前单位灾情
await this.getPaperPlanData()//获得当前考题题目
let that = this
AxMessageSystem.addListener('selectionChanged', () => {
if (this.canvas.selection.size() == 1) {//如果是单选
console.log('单选', this.canvas.selection.first().assetData)
this.setAssetsProperty(this.canvas.selection.first().assetData)
} else if (this.canvas.selection.size() == 0) {
this.isShowProperty = false
}
}, this)
AxMessageSystem.addListener('imageResize', (eventName, args1) => {
this.assetWidth = args1.Width
this.assetHeight = args1.Height
}, this)
window.setTimeout(() => {
document.getElementById("functionalDomainContent").oncontextmenu = function (event) {
that.selectImageIndex = -1
event.preventDefault();
};
})
this.canvasData.getMessage().subscribe((message: any) => {
if (message == "send a message") {
this.refurbishTreeData()
}
})
}
paperId: any = this.route.snapshot.queryParams.paperId
planData: any //当前考题题目
Facilities: any //当前预案考题所有楼层要考的基本信息素材
//获得单位预案设定
async getPaperPlanData() {
let params = {
paperId: this.paperId
}
await new Promise((resolve, reject) => {
this.http.get(`/api/PaperPlans`, { params: params }).subscribe((data: any) => {
data.forEach(item => {
item.id == this.route.snapshot.queryParams.paperplanId ?
this.planData = item : null
})
let questions = JSON.parse(this.planData.examDisposalNodesData)
this.handleHybridTree(questions, '题目')
this.Facilities = JSON.parse(this.planData.examFacilityAssetsData)
console.log('当前预案设定需要隐藏的基本信息图标', this.Facilities)
resolve(1)
})
})
}
//
/**
* 获得所有素材库
*/
basicAssetLibraries: any = []//基本信息素材库
getAllAssetLibraries(Facilitiesitem) {
console.log('具体到当前楼层需要隐藏的基本信息图标', Facilitiesitem.children)
let arr = []
Facilitiesitem.children.forEach(item => {
arr.push(item.Id)
})
this.canvasData.hiddenBasicInfoFacilities = arr
this.canvas.onExamineeClickFloor()
this.basicAssetLibraries = []
this.http.get('/api/AssetLibraries').subscribe(async (data: any) => {
for (let index = 0; index < data.length; index++) {
const element = data[index];
let params = {
libraryId: element.id,
assetIds: Facilitiesitem.basicAssetsId
}
await new Promise((resolve, reject) => {
this.http.get('/api/Assets', { params: params })
.subscribe((data: any) => {
if (data && data.length != 0) {
data.forEach(item => {
item.tag = 1
})
element.images = data
this.basicAssetLibraries.push(
element
)
}
resolve(1)
})
})
}
this.allLibrary = [...this.originalallLibrary, ...this.basicAssetLibraries]
})
}
ngAfterViewInit(): void {
this.canvasData.gameMode = GameMode.Examinee
this.getSitePlan() //获取总平面图/楼层
// 监听canvas组件新增素材事件
this.canvas.on("createIcon", obj => {
console.log(obj.assetData)
// this.renovateTreeData(false)
})
// 监听canvas组件删除素材事件
this.canvas.on("deleteIcon", obj => {
// this.renovateTreeData(false)
})
}
copyAssetData: any //存储用于复制的素材
basicInfo: boolean = true //基本信息名称显隐
wantToWork: boolean = true //想定作业名称显隐
//点击基本信息名称
basicInfoClick() {
this.basicInfo = !this.basicInfo
this.canvas.setNameVisible(this.basicInfo, 0)
}
//点击想定作业名称
wantToWorkClick() {
this.wantToWork = !this.wantToWork
this.canvas.setNameVisible(this.wantToWork, 1)
}
//保存平面图
saveNum: any = []
async saveSite() {
if (this.selectingSitePlan && this.selectingSitePlan.id) {
let SitePlanData = JSON.parse(JSON.stringify(this.canvasData.examOriginaleveryStoreyData));
console.log('基本信息素材', SitePlanData, this.canvasData.gameMode)
SitePlanData.data = JSON.stringify(SitePlanData.data)
SitePlanData.examinationId = this.route.snapshot.queryParams.examId
SitePlanData.planComponentId = this.route.snapshot.queryParams.planComponentId
//如果是单位 总平面图
if (this.checkedBuildingIndex == -1) {
//保存平面图数据
SitePlanData.sitePlanId = this.selectingSitePlan.id
await new Promise((resolve, reject) => {
this.http.post("/api/ExamSitePlanData", SitePlanData, {
params: {
companyId: this.params.companyId
}
}).subscribe(data => {
console.log('保存基本素材成功')
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存基本素材成功', '确定', config);
resolve(1)
}, err => {
console.log('保存基本素材失败')
resolve(1)
})
})
} else { //如果是建筑
SitePlanData.buildingAreaId = this.selectingSitePlan.id
//建筑平面图数据
await new Promise((resolve, reject) => {
this.http.post("/api/ExamBuildingAreaData", SitePlanData, {
params: {
companyId: this.params.companyId
}
}).subscribe(data => {
console.log('保存基本素材成功')
let config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('保存基本素材成功', '确定', config);
resolve(1)
}, err => {
console.log('保存基本素材失败')
resolve(1)
})
})
}
const dialogRef = this.dialog.open(saveOneDialogExaminee, {
data: {
allDisposalNode: this.canvasData.allDisposalNode,
selectedBuildingData: this.beforeOneCheckedBuilding,
selectedSiteData: this.selectingSitePlan,
siteOrbuilding: this.checkedBuildingIndex,
disasterId: this.allFirePlan[0].id || ''
}
});
dialogRef.afterClosed().subscribe(result => {
console.log('The dialog was closed');
});
} else { //if
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('暂无楼层数据', '确定', config);
}
}
//获得所有的建筑物
getAllBuildings() {
this.http.get("/api/Buildings", {
params: {
companyId: this.params.companyId
}
}).subscribe(data => {
this.allBuildings = data
})
}
//选择建筑
checkedBuilding(item, index) {
if (this.checkedBuildingIndex != index) {
this.beforeOneCheckedBuilding = item
this.checkedBuildingIndex = index
if (index == -1) { //总平面图数据
this.getSitePlan()
} else { //建筑楼层/区域数据
this.getBuildingSitePlan(item)
}
} //if
}
storeyData //将建筑素材和当前楼层素材合二为一
//处理 tree 数据结构
handleTreeData(storeyData) {
//storeyData为当前楼层拥有的消防设施
this.storeyData = storeyData
let data = JSON.parse(JSON.stringify(this.allFireElements)) //所有消防要素模板
let treeData = [] //tree型 处理完成后的数据
this.allFireElements.forEach(element => {
element.key = element.id
element.isTemplate = true //添加模板标识
element.isLook = true //添加是否可见标识
element.name != '其他' ? element.children = [] : null
if (storeyData) {
for (let key in storeyData.data) {
storeyData.data[key].isLookPattern = true
if (element.id == storeyData.data[key].FireElementId) {
storeyData.data[key].isTemplate = false
storeyData.data[key].isLook = true
element.isNewElement = true //该节点children是否存在新添加的真实素材 标识
//定义查看模式下能看到的元素
element.isLookPattern = true
if (element.parentId) {
data.forEach(i => {
if (i.id == element.parentId) {
i.isLookPattern = true
}
})
}
element.children.push(storeyData.data[key])
}
}
}
this.allFireElements.forEach(item => { if (item.parentId == element.id) { element.children.push(item) } });
});
this.allFireElements.forEach(element => {
if (!element.parentId) { treeData.push(element) }
});
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;
}
this.dataSource.data = filterEmpty(treeData)
this.treeControl.expandAll()
}
//点击树节点
clickTreeNode(node) {
if (this.canvasData.originalcompanyBuildingData.data[node.id]) {
this.setAssetsProperty(this.canvasData.originalcompanyBuildingData.data[node.id])
} else if (this.canvasData.originaleveryStoreyData.data[node.id]) {
this.setAssetsProperty(this.canvasData.originaleveryStoreyData.data[node.id])
}
// canvas上的素材高亮
let iconHighLightArr: any = []
if (node.isTemplate) {//如果是模板,则开始向下找
node.children.forEach(item => {
if (item.isTemplate) {//如果子节点依旧是模板,则继续开始向下找
item.children.forEach(i => {
iconHighLightArr.push(i.Id)
})
} else {
iconHighLightArr.push(item.Id)
}
})
} else {
iconHighLightArr.push(node.id)
}
this.canvas.setHighlight(iconHighLightArr)
}
//点击树节点的显示隐藏icon
clickLookItem(node) {
//修改真实素材islook属性
for (let key in this.storeyData.data) {
if (key == node.id) {
this.storeyData.data[key].isLook = !this.storeyData.data[key].isLook
}
}
//所有消防要素模板变化islook值
if (node.isTemplate && node.name == "其他") {
this.allFireElements.forEach(item => {
if (item.name == "其他") {
item.isLook = !item.isLook
}
})
}
if (node.isTemplate) {
this.allFireElements.forEach(item => {
if (item.id == node.id) {
item.isLook = !item.isLook
}
})
}
//子节点跟随父节点的islook变化
if (node.children && node.children.length != 0) {
node.children.forEach(item => {
item.isLook = !node.isLook
if (item.children && item.children.length != 0) {
item.children.forEach(i => {
i.isLook = !node.isLook
})
}
})
}
const nodes = this.treeControl.dataNodes;
const expandNodes = [];
nodes.forEach((item) => {
if (item.expandable && this.treeControl.isExpanded(item)) {
expandNodes.push(item.id);
}
});
this.dataSource.data = [...this.dataSource.data]
let newNodes = this.treeControl.dataNodes;
newNodes = newNodes.filter(n => {
return expandNodes.indexOf(n.id) >= 0;
});
newNodes.forEach(item => {
this.treeControl.expand(item);
});
//canvas上的素材显隐
let iconVisibleArr: any = []
if (node.isTemplate) {//如果是模板,则开始向下找
node.children.forEach(item => {
if (item.isTemplate) {//如果子节点依旧是模板,则继续开始向下找
item.children.forEach(i => {
iconVisibleArr.push(i.Id)
})
} else {
iconVisibleArr.push(item.Id)
}
})
} else {
iconVisibleArr.push(node.id)
}
this.canvas.setIconVisible(iconVisibleArr, !node.isLook)
}
//打开消防设施考题设定
openFireExamination() {
let buildFloorData = {
buildingData: this.beforeOneCheckedBuilding,
floorData: this.selectingSitePlan
}
let data = { oldRealData: this.storeyData, buildFloorData: buildFloorData, Facilities: this.Facilities, allFireElements: this.allFireElements }
let dialogRef = this.dialog.open(examinationQuestionsExaminee, { data });
}
//上传考题
openUploadQuestions() {
let data = { allFireElements: this.allFireElements, Facilities: this.Facilities }
let dialogRef = this.dialog.open(uploadQuestionsExaminee, { data });
}
//封装 刷新 tree 数据
async renovateTreeData(isRefresh: boolean = true) {
this.allFireElements[this.allFireElements.length - 1].children = []
this.beforeOneCheckedBuildingIsShow = false
isRefresh ? this.canvasData.isChange = false : null //服务中 数据是否改动 改为false
isRefresh ? this.isShowProperty = true : null
isRefresh ? this.isShowAttribute = true : null
// this.canvas.allowEdit = false
let beforeOneId = this.selectingSitePlan.id || '' //当前 选中 平面图 楼层/区域 id
let companyBuildingData = JSON.parse(JSON.stringify(this.canvasData.originalcompanyBuildingData || {})) // 当前 单位/建筑 数据
let storeyData = JSON.parse(JSON.stringify(this.canvasData.originaleveryStoreyData || {})) //当前 楼层 数据
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)
//没有匹配全部放入到 其他 数组
if (!noMatch) {
this.allFireElements[this.allFireElements.length - 1].children.push(storeyData.data[key])
}
}
this.handleTreeData(storeyData) //处理tree数据结构
}
//陈鹏飞↓↓↓
//陈鹏飞↓↓↓
//陈鹏飞↓↓↓
params = { companyId: sessionStorage.getItem('companyId') }
allFireElements: any = []; //当前 单位/建筑 下的消防要素
isShowAttribute: boolean = true; //属性栏 是否显示 默认数据
isShowProperty: boolean = false //属性栏 是否有东西
toggleExpandPanel: boolean = false; //左侧可展开面板展开或关闭
toggleExpandPanelRight: boolean = false; //右侧可展开面板展开或关闭
togglePlane: boolean = true; //可展开面板平面图 显隐
toggleMaterialBank: boolean = true; //可展开面板素材库 显隐
toggleHandlePlans: boolean = true; //可展开面板处置预案 显隐
//可展开面板展开或关闭
toggle() {
this.toggleExpandPanel = !this.toggleExpandPanel
}
//可展开面板展开或关闭
toggle2() {
this.toggleExpandPanelRight = !this.toggleExpandPanelRight
}
//可展开面板 平面图 展开或关闭
togglePlanarGraph() {
this.togglePlane = !this.togglePlane
}
//可展开面板 素材库 展开或关闭
toggleMaterial() {
this.toggleMaterialBank = !this.toggleMaterialBank
}
//可展开面板 处置预案 展开或关闭
toggleHandlePlan() {
this.toggleHandlePlans = !this.toggleHandlePlans
}
sitePlanData: any = []; //总平面图 楼层/区域 数据
selectingSitePlan: any; //选中的 平面图 楼层/区域
selectSitePlanIndex: number; //选中的 平面图 楼层/区域 index
//获取总平面图
getSitePlan() {
let fireData = this.getFireElements(sessionStorage.getItem('buildingTypeId')) //获取单位下 消防要素
let planData = this.getSitePlanCompanyData() //获取 单位 数据
this.http.get('/api/SitePlans', { params: this.params }).subscribe(data => {
this.sitePlanData = data
console.log('建筑楼层数据', this.sitePlanData)
this.Facilities ? this.sitePlanData.forEach(item => {
this.Facilities.forEach(i => {
if (item.id == i.key) {
item.isLabel = true
}
})
}) : null
this.selectingSitePlan = this.sitePlanData[0] || {}
this.canvasData.selectStorey = this.sitePlanData[0] || {} //服务中 存一份数据
this.selectSitePlanIndex = 0
Promise.all([fireData, planData]).then((res) => {
this.getSitePlanStorey(this.selectingSitePlan) //获取 平面图 楼层数据
})
})
}
//获取建筑 楼层/区域
getBuildingSitePlan(item) {
let params = { buildingId: item.id }
let fireData = this.getFireElements(item.buildingTypes[0].id || '') //获取建筑下 消防要素
let planData = this.getBuildingData(params) //获取 建筑 数据
this.http.get('/api/BuildingAreas', { params }).subscribe(data => {
this.sitePlanData = data
console.log('预案平台当前有哪些楼层', this.sitePlanData)
this.Facilities ? this.sitePlanData.forEach(item => {
this.Facilities.forEach(i => {
if (item.id == i.key) {
item.isLabel = true
}
})
}) : null
this.selectingSitePlan = this.sitePlanData[0] || {}
this.canvasData.selectStorey = this.sitePlanData[0] || {} //服务中 存一份数据
this.selectSitePlanIndex = 0
Promise.all([fireData, planData]).then((res) => {
this.getBuildingStorey(this.selectingSitePlan) //获取 建筑 楼层数据
})
})
}
//根据单位类型获得所有的消防要素
getFireElements(e) {
let params = { ids: e }
return new Promise((resolve, reject) => {
this.http.get('/api/Companies/FireElements', { params }).subscribe((data: any) => {
this.allFireElements = data //所有消防要素
let other = {
children: [],
computed: true,
id: '',
name: '其他',
order: 999,
parentId: null,
tag: "INPUT",
isLookPattern: true
}
this.allFireElements.push(other)
resolve('success')
})
})
}
//获取 单位 数据
getSitePlanCompanyData() {
return new Promise((resolve, reject) => {
this.http.get('/api/CompanyData', { params: this.params }).subscribe((data: any) => {
this.canvasData.originalcompanyBuildingData = data || {} // 单位原数据
this.canvasData.originalcompanyBuildingData.data ? this.canvasData.originalcompanyBuildingData.data = JSON.parse(this.canvasData.originalcompanyBuildingData.data) : this.canvasData.originalcompanyBuildingData.data = {}
this.canvasData.originalcompanyBuildingData.version ? null : this.canvasData.originalcompanyBuildingData.version = "2.0"
this.canvasData.originalcompanyBuildingData.companyId ? null : this.canvasData.originalcompanyBuildingData.companyId = sessionStorage.getItem('companyId')
resolve('success')
})
})
}
//获取 平面图 楼层数据
getSitePlanStorey(e) {
let params = { sitePlanId: e.id }
this.http.get(`/api/SitePlanData`, { params }).subscribe((data: any) => {
console.log('预案平台楼层原始素材', data)
this.canvasData.originaleveryStoreyData = data || {} // 楼层原数据
this.canvasData.originaleveryStoreyData.data ? this.canvasData.originaleveryStoreyData.data = JSON.parse(this.canvasData.originaleveryStoreyData.data) : this.canvasData.originaleveryStoreyData.data = {}
this.canvasData.originaleveryStoreyData.version ? null : this.canvasData.originaleveryStoreyData.version = "2.0"
this.canvasData.originaleveryStoreyData.sitePlanId ? null : this.canvasData.originaleveryStoreyData.sitePlanId = e.id || null
let examParams = {
sitePlanId: e.id,
examinationId: this.route.snapshot.queryParams.examId,
planComponentId: this.route.snapshot.queryParams.planComponentId
}
this.http.get('/api/ExamSitePlanData', { params: examParams }).subscribe((data2: any) => {
console.log('考生新添加的基本信息素材数据', data2)
this.canvasData.examOriginaleveryStoreyData = data2 || {} // 楼层原数据
this.canvasData.examOriginaleveryStoreyData.data ? this.canvasData.examOriginaleveryStoreyData.data = JSON.parse(this.canvasData.examOriginaleveryStoreyData.data) : this.canvasData.examOriginaleveryStoreyData.data = {}
this.canvasData.examOriginaleveryStoreyData.version ? null : this.canvasData.examOriginaleveryStoreyData.version = "2.0"
this.canvasData.examOriginaleveryStoreyData.buildingAreaId ? null : this.canvasData.examOriginaleveryStoreyData.buildingAreaId = e.id || null
this.renovateTreeData()
if (this.Facilities) {
console.log(1111)
console.log('走这里了')
this.Facilities.forEach((item, key) => {
if (item.key == this.selectingSitePlan.id) {
console.log(333)
//如果当层有需要标记的基本信息素材
this.getAllAssetLibraries(item)
} else {
if (key == this.Facilities.length - 1) {
console.log(444)
this.canvas.onExamineeClickFloor()
}
}
})
} else {
console.log('走这里了')
console.log(2222)
this.canvas.onExamineeClickFloor();
this.allLibrary = this.originalallLibrary
}
})
})
}
//获取 建筑 楼层数据
getBuildingStorey(e) {
let params = { buildingAreaId: e.id }
this.http.get(`/api/BuildingAreaData`, { params }).subscribe((data: any) => {
this.canvasData.originaleveryStoreyData = data || {} // 楼层原数据
this.canvasData.originaleveryStoreyData.data ? this.canvasData.originaleveryStoreyData.data = JSON.parse(this.canvasData.originaleveryStoreyData.data) : this.canvasData.originaleveryStoreyData.data = {}
this.canvasData.originaleveryStoreyData.version ? null : this.canvasData.originaleveryStoreyData.version = "2.0"
this.canvasData.originaleveryStoreyData.buildingAreaId ? null : this.canvasData.originaleveryStoreyData.buildingAreaId = e.id || null
let examParams = {
buildingAreaId: e.id,
examinationId: this.route.snapshot.queryParams.examId,
planComponentId: this.route.snapshot.queryParams.planComponentId
}
this.http.get('/api/ExamBuildingAreaData', { params: examParams }).subscribe((data: any) => {
this.canvasData.examOriginaleveryStoreyData = data || {} // 楼层原数据
this.canvasData.examOriginaleveryStoreyData.data ? this.canvasData.examOriginaleveryStoreyData.data = JSON.parse(this.canvasData.examOriginaleveryStoreyData.data) : this.canvasData.examOriginaleveryStoreyData.data = {}
this.canvasData.examOriginaleveryStoreyData.version ? null : this.canvasData.examOriginaleveryStoreyData.version = "2.0"
this.canvasData.examOriginaleveryStoreyData.buildingAreaId ? null : this.canvasData.examOriginaleveryStoreyData.buildingAreaId = e.id || null
this.renovateTreeData()
if (this.Facilities) {
console.log('走这里了')
this.Facilities.forEach(item => {
if (item.key == this.selectingSitePlan.id) {
this.getAllAssetLibraries(item)
} else {
this.canvas.onExamineeClickFloor()
}
})
} else {
console.log('走这里了')
this.canvas.onExamineeClickFloor(); this.allLibrary = this.originalallLibrary
}
})
})
}
//获取 建筑 数据
getBuildingData(e) {
return new Promise((resolve, reject) => {
this.http.get(`/api/BuildingData`, { params: e }).subscribe((data: any) => {
this.canvasData.originalcompanyBuildingData = data || {} // 建筑原数据
this.canvasData.originalcompanyBuildingData.data ? this.canvasData.originalcompanyBuildingData.data = JSON.parse(this.canvasData.originalcompanyBuildingData.data) : this.canvasData.originalcompanyBuildingData.data = {}
this.canvasData.originalcompanyBuildingData.version ? null : this.canvasData.originalcompanyBuildingData.version = "2.0"
this.canvasData.originalcompanyBuildingData.buildingId ? null : this.canvasData.originalcompanyBuildingData.buildingId = e.buildingId
resolve('success')
})
})
}
//点击选中 平面图 楼层/区域 时
selectSitePlan(item, index) {
if (this.selectSitePlanIndex != index) {
this.canvasData.selectPanelPoint = new DisposalNodeData();
this.selectingSitePlan = item
this.selectSitePlanIndex = index
this.canvasData.selectStorey = item //服务中 存一份数据
if (this.checkedBuildingIndex == -1) { //总平面图时
this.getSitePlanStorey(item) //获取 平面图 楼层数据
} else { //楼层/区域时
this.getBuildingStorey(item) //获取 建筑 楼层数据
}
}
}
//平面图 楼层/区域 上移
moveUp(item, index) {
if (index != 0) {
let replaceIndex = this.sitePlanData[index].order
this.sitePlanData[index].order = this.sitePlanData[index - 1].order
this.sitePlanData[index - 1].order = replaceIndex
if (this.checkedBuildingIndex == -1) { //总平面图
this.http.put(`/api/SitePlans/${this.sitePlanData[index - 1].id}`, this.sitePlanData[index - 1]).subscribe(data => {
this.http.put(`/api/SitePlans/${this.sitePlanData[index].id}`, this.sitePlanData[index]).subscribe(data => {
this.selectSitePlanIndex = this.selectSitePlanIndex - 1
this.renovateSitePlan()
})
})
} else { //楼层/区域
this.http.put(`/api/BuildingAreas/${this.sitePlanData[index - 1].id}`, this.sitePlanData[index - 1], { params: this.params }).subscribe(data => {
this.http.put(`/api/BuildingAreas/${this.sitePlanData[index].id}`, this.sitePlanData[index], { params: this.params }).subscribe(data => {
this.selectSitePlanIndex = this.selectSitePlanIndex - 1
this.renovateBuilding()
})
})
}
} //if index
}
//平面图 楼层/区域 下移
moveDown(item, index) {
if (index != this.sitePlanData.length - 1) {
let replaceIndex = this.sitePlanData[index].order
this.sitePlanData[index].order = this.sitePlanData[index + 1].order
this.sitePlanData[index + 1].order = replaceIndex
if (this.checkedBuildingIndex == -1) { //总平面图
this.http.put(`/api/SitePlans/${this.sitePlanData[index + 1].id}`, this.sitePlanData[index + 1]).subscribe(data => {
this.http.put(`/api/SitePlans/${this.sitePlanData[index].id}`, this.sitePlanData[index]).subscribe(data => {
this.selectSitePlanIndex = this.selectSitePlanIndex + 1
this.renovateSitePlan()
})
})
} else { //楼层/区域
this.http.put(`/api/BuildingAreas/${this.sitePlanData[index + 1].id}`, this.sitePlanData[index + 1], { params: this.params }).subscribe(data => {
this.http.put(`/api/BuildingAreas/${this.sitePlanData[index].id}`, this.sitePlanData[index], { params: this.params }).subscribe(data => {
this.selectSitePlanIndex = this.selectSitePlanIndex + 1
this.renovateBuilding()
})
})
}
} //if index
}
//旋转底图
revolveImg(item) {
item.imageAngle == 270 ? item.imageAngle = 0 : item.imageAngle = item.imageAngle + 90
if (this.checkedBuildingIndex == -1) { //总平面图
this.http.put(`/api/SitePlans/${item.id}`, item).subscribe(data => {
let isSuccess = this.renovateSitePlan()
isSuccess.then(res => {
this.canvas.refreshBackgroundImage()
})
})
} else { //楼层/区域
this.http.put(`/api/BuildingAreas/${item.id}`, item, { params: this.params }).subscribe(data => {
let isSuccess = this.renovateBuilding()
isSuccess.then(res => {
this.canvas.refreshBackgroundImage()
})
})
}
}
//删除 平面图 楼层/区域
deletePlaneData(item) {
const isDelete = confirm('您确定要删除吗');
if (isDelete) {
if (this.checkedBuildingIndex == -1) { //总平面图
let isHave = this.canvasData.allDisposalNode.find(items => { return items.sitePlanId === item.id })
if (isHave == undefined) {
this.http.delete(`/api/SitePlans/${item.id}`).subscribe(data => {
this.deleteShareData(item, -1)
})
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('含有数据节点的楼层不允许删除', '确定', config);
}
} else { //楼层/区域
let isHave = this.canvasData.allDisposalNode.find(items => { return items.buildingAreaId === item.id })
if (isHave == undefined) {
this.http.delete(`/api/BuildingAreas/${item.id}`).subscribe(data => {
this.deleteShareData(item, 1)
})
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('含有数据节点的楼层不允许删除', '确定', config);
}
}
}
}
//删除当前 单位/建筑的 共享数据中 已删除data
deleteShareData(e, isCompany) {
this.sitePlanData.forEach((element, index) => {
if (element.id === e.id) {
this.sitePlanData.splice(index, 1)
return
}
});
let data = this.canvasData.originalcompanyBuildingData;
for (let key in data.data) {
if (data.data[key].FloorId === e.id) { //处理 单位/建筑 数据是否归于当前楼层下
delete data.data[key]
}
}
let newData = JSON.parse(JSON.stringify(this.canvasData.originalcompanyBuildingData));
newData.data = JSON.stringify(newData.data) // 转换JSON 数据格式
this.selectingSitePlan = this.sitePlanData[0] || {}
this.canvasData.selectStorey = this.sitePlanData[0] || {} //服务中 存一份数据
this.selectSitePlanIndex = 0
this.canvasData.isChange = false
if (isCompany === -1) {
this.http.post("/api/CompanyData", newData).subscribe(data => { })
this.getSitePlanStorey(this.selectingSitePlan) //获取 平面图 楼层数据
} else {
this.http.post("/api/BuildingData", newData, { params: this.params }).subscribe(data => { })
this.getBuildingStorey(this.selectingSitePlan) //获取 建筑 楼层数据
}
}
//复制图层 平面图 楼层/区域
duplicateLayer(item) {
if (this.checkedBuildingIndex == -1) { //总平面图
item.id = ""
item.modifiedTime = new Date()
item.name = item.name + '(副本)'
item.order = this.sitePlanData[this.sitePlanData.length - 1].order + 1
this.http.post('/api/SitePlans', item).subscribe((data: any) => {
let newData = {
version: this.canvasData.originaleveryStoreyData.version || "2.0",
id: "",
data: JSON.stringify(JSON.parse(JSON.stringify(this.canvasData.originaleveryStoreyData.data))) || null,
sitePlanId: data.id
}
this.http.post('/api/SitePlanData', newData, { params: this.params }).subscribe(data => {
this.renovateSitePlan()
})
})
} else { //楼层/区域
item.id = ""
item.modifiedTime = new Date()
item.name = item.name + '(副本)'
item.order = this.sitePlanData[this.sitePlanData.length - 1].order + 1
this.http.post('/api/BuildingAreas', item, { params: this.params }).subscribe((data: any) => {
let newData = {
version: this.canvasData.originaleveryStoreyData.version || "2.0",
id: "",
data: JSON.stringify(JSON.parse(JSON.stringify(this.canvasData.originaleveryStoreyData.data))) || null,
buildingAreaId: data.id
}
this.http.post('/api/BuildingAreaData', newData, { params: this.params }).subscribe(data => {
this.renovateBuilding()
})
})
}
}
//平面图 楼层/区域 替换底图
replaceBaseMap(e, item) {
e.stopPropagation();
let file = e.target.files[0] || null //获取上传的文件
let fileSize = file.size || null //上传文件的总大小
let maxSize = 5 * 1024 * 1024 //5MB一个分片
if (file && fileSize <= maxSize) { //上传文件<=5MB时
let formData = new FormData()
formData.append("file", file)
this.http.post(`/api/Objects/WebPlan2D/${sessionStorage.getItem('companyId')}`, formData).subscribe((data: any) => {
this.renovateBaseMap(data.objectName, item)
})
} else {
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传底图需小于5MB', '确定', config);
}
}
//封装 替换底图 function
renovateBaseMap(e, item) {
item.imageUrl = '/api/Objects/WebPlan2D/' + e
if (this.checkedBuildingIndex == -1) { //总平面图
this.http.put(`/api/SitePlans/${item.id}`, item).subscribe(data => {
let isSuccess = this.renovateSitePlan()
isSuccess.then(res => {
this.canvas.refreshBackgroundImage()
})
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传底图成功', '确定', config);
})
} else { //楼层/区域
this.http.put(`/api/BuildingAreas/${item.id}`, item, { params: this.params }).subscribe(data => {
let isSuccess = this.renovateBuilding()
isSuccess.then(res => {
this.canvas.refreshBackgroundImage()
})
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('上传底图成功', '确定', config);
})
}
}
//封装 刷新总平面图 数据
renovateSitePlan() {
return new Promise((resolve, reject) => {
this.http.get('/api/SitePlans', { params: this.params }).subscribe(data => {
this.sitePlanData = data
this.selectingSitePlan = this.sitePlanData[this.selectSitePlanIndex]
this.canvasData.selectStorey = this.sitePlanData[this.selectSitePlanIndex] //服务中 存一份数据
this.canvasData.originaleveryStoreyData.sitePlanId ? null : this.canvasData.originaleveryStoreyData.sitePlanId = this.selectingSitePlan.id || null
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('数据更新成功', '确定', config);
resolve('success')
})
})
}
//封装 刷新 楼层/区域 数据
renovateBuilding() {
let params = {
buildingId: this.beforeOneCheckedBuilding.id
}
return new Promise((resolve, reject) => {
this.http.get('/api/BuildingAreas', { params }).subscribe(data => {
this.sitePlanData = data
this.selectingSitePlan = this.sitePlanData[this.selectSitePlanIndex]
this.canvasData.selectStorey = this.sitePlanData[this.selectSitePlanIndex] //服务中 存一份数据
this.canvasData.originaleveryStoreyData.buildingAreaId ? null : this.canvasData.originaleveryStoreyData.buildingAreaId = this.selectingSitePlan.id || null
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('数据更新成功', '确定', config);
resolve('success')
})
})
}
allLibrary: any = []; //所有素材库 + 素材
originalallLibrary = []; //原始所有素材库 + 素材 备份
selectLibrary: any; //选中的素材库
selectImage: any; //选中的素材库图片
selectImageIndex: number; //选中的素材库图片index
//获取素材库
getAllLibrary(type: string = 'input') {
this.http.get(`/api/AssetLibraries?tag=${type}`).subscribe((data: any) => {
data.forEach(element => {
element.images = []
});
this.originalallLibrary = data
this.allLibrary = data
this.selectImageIndex = -1
})
}
//素材库展开面板展开时
opened(e) {
if (!e.images.length) { //当前素材库没加载素材时
this.http.get(`/api/Assets?libraryId=${e.id}`).subscribe((data: any) => {
e.images = data
})
}
}
//点击选中素材库图片时
selectImg(item, items, index) {
this.selectLibrary = item.name
this.selectImage = items
this.selectImageIndex = index
this.canvasData.selectTemplateData = items
this.canvas.beginPaint()
}
//处置预案
examType = Number(this.route.snapshot.queryParams.openType) // 预案类型 1=已存在/2=自定义
allFirePlan: any = []; //所有灾情
selectDisposalNode: string = ''; //当前点击tree节点 css选中样式
//获取所有灾情
getAllFirePlan() {
let api
this.examType == 1 ? api = '/api/Disasters' : api = '/api/ExamDisasters'
let params = { componentId: this.route.snapshot.queryParams.planComponentId }
this.http.get(api, { params: params }).subscribe((data: any) => {
if (!data.length) { //该 单位没有灾情时
let msg = {
name: '灾情',
modifiedTime: new Date(),
examPlanComponentId: sessionStorage.getItem('planId')
}
this.http.post('/api/ExamDisasters', msg).subscribe(data => {
this.allFirePlan.push(data)
this.getDisposalNode()
})
} else { //单位 有灾情时
this.allFirePlan = data
this.getDisposalNode()
}
})
}
//获取所有处置节点
getDisposalNode() {
let api
api = '/api/ExamDisposalNodes'
this.selectDisposalNode = ''
let params
params = { examDisasterId: this.allFirePlan[0].id || '', disposalNodeType: 1, examinationId: this.route.snapshot.queryParams.examId }
this.http.get(api, { params: params }).subscribe(data => { //处置节点
this.canvasData.allDisposalNode = data
this.handleHybridTree(this.canvasData.allDisposalNode, '答案')
})
}
treeData: any = []; //渲染tree处理完成数据
questionstreeData: any = [];//渲染tree处理完成数据(题目)
defaultExpandedKeys: any = []; //首次渲染 tree展开状态
//处理 节点 Tree数据
handleHybridTree(disposalNodedata, type) {
// this.defaultExpandedKeys = []
let treeData = []
let data = JSON.parse(JSON.stringify(disposalNodedata || []))
data.forEach(element => {
element.title = element.name //name
element.key = element.id //id
element.children = [] //children
if (element.sitePlanId || element.buildingAreaId) { //是数据节点
element.isLeaf = true
element.isDataNode = true
} else { //不是数据节点
element.isLeaf = false
element.isDataNode = false
}
data.forEach(item => {
item.parentId === element.id ? element.children.push(item) : null
})
});
data.forEach(element => {
!element.parentId ? treeData.push(element) : null
})
type == '题目' ? this.questionstreeData = [...treeData] : this.treeData = [...treeData]
}
//刷新 treeData 保存已展开节点
refurbishTreeData() {
let api
api = '/api/ExamDisposalNodes'
this.defaultExpandedKeys = []
let params
params = { examDisasterId: this.allFirePlan[0].id, disposalNodeType: 1, examinationId: this.route.snapshot.queryParams.examId }
this.http.get(api, { params: params }).subscribe(nodeData => { //处置节点
this.canvasData.allDisposalNode = nodeData
let oldTreeData = this.nzTreeComponent.getExpandedNodeList()
oldTreeData.forEach(item => {
this.defaultExpandedKeys.push(item.key)
})
let treeData = []
let data = JSON.parse(JSON.stringify(this.canvasData.allDisposalNode || []))
data.forEach(element => {
element.title = element.name //name
element.key = element.id //id
element.children = [] //children
if (element.sitePlanId || element.buildingAreaId) { //是数据节点
element.isLeaf = true
element.isDataNode = true
} else { //不是数据节点
element.isLeaf = false
element.isDataNode = false
}
data.forEach(item => {
item.parentId === element.id ? element.children.push(item) : null
})
});
data.forEach(element => {
!element.parentId ? treeData.push(element) : null
})
this.treeData = [...treeData]
this.defaultExpandedKeys = [...this.defaultExpandedKeys]
})
}
sitePlanIcon = { fire: 0, force: 0 } // 总平面图 火源/力量 图标 是否展示
//刷新 建筑楼层 匹配 火源/力量 图标
mateFireForce() {
let data = this.canvasData.allNodeMarkers.markers || {}
for (let key in data) { //遍历 火/力量 图标
this.sitePlanData.forEach(element => { //楼层
if (element.id == key) { // 相匹配时
data[key].fireCount != 0 ? element.fire = 1 : element.fire = 0
data[key].forceCount != 0 ? element.force = 1 : element.force = 0
}
});
this.allBuildings.forEach(element => { //建筑
if (element.id == key) { // 相匹配时
data[key].fireCount != 0 ? element.fire = 1 : element.fire = 0
data[key].forceCount != 0 ? element.force = 1 : element.force = 0
}
});
if (this.params.companyId == key) { //总平面图时
data[key].fireCount != 0 ? this.sitePlanIcon.fire = 1 : this.sitePlanIcon.fire = 0
data[key].forceCount != 0 ? this.sitePlanIcon.force = 1 : this.sitePlanIcon.force = 0
}
}
let buildingMSG = this.canvasData.allNodeMarkers.highlightMarkers || {}
for (let key in buildingMSG) {
if (key === this.canvasData.selectPanelPoint.DisposalNodeId) {
for (let keys in buildingMSG[key]) {
this.sitePlanData.forEach(element => { //楼层
if (element.id === keys) {
buildingMSG[key][keys].fireCount != 0 ? element.fire = 2 : null
buildingMSG[key][keys].forceCount != 0 ? element.force = 2 : null
}
});
this.allBuildings.forEach(element => { //建筑
if (element.id === keys) { // 相匹配时
buildingMSG[key][keys].fireCount != 0 ? element.fire = 2 : null
buildingMSG[key][keys].forceCount != 0 ? element.force = 2 : null
}
});
if (this.params.companyId === keys) { //总平面图时
buildingMSG[key][keys].fireCount != 0 ? this.sitePlanIcon.fire = 2 : null
buildingMSG[key][keys].forceCount != 0 ? this.sitePlanIcon.force = 2 : null
}
}
}
}
}
// 切换 基本信息时 刷新 删除 建筑楼层 自定义属性
mateDeleteCustomize() {
this.defaultExpandedKeys = []
this.sitePlanIcon = { fire: 0, force: 0 }
this.sitePlanData.forEach(element => { //楼层
delete element.fire
delete element.force
});
this.allBuildings.forEach(element => { //建筑
delete element.fire
delete element.force
});
}
//选择 考试节点
countValue(e) {
e.stopPropagation()
if (this.canvasData.allDisposalNode.length) {
let data = { treeData: JSON.parse(JSON.stringify(this.treeData)), oldTreeData: JSON.parse(JSON.stringify(this.canvasData.allDisposalNode)) }
let dialogRef = this.dialog.open(uploadDisposalNodesExaminee, { data });
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();
config.verticalPosition = 'top';
config.duration = 3000
this.snackBar.open('暂无处置节点', '确定', config);
}
}
//复制 处置预案 节点
copyPanelPoint(e, item, treeData) {
e.stopPropagation()
if (confirm(`确定要复制 ${item.title} ?`)) {
let params = { id: item.origin.id }
let order
if (item.level == 0) {
treeData.length ? order = treeData[treeData.length - 1].order + 1 : order = 0
} else {
let parent = item.getParentNode() //获取父节点
parent.origin.children.length ? order = parent.origin.children[parent.origin.children.length - 1].order + 1 : order = 0
}
let data = {
name: item.title + '(副本)',
level: item.level,
order: order,
description: '',
disasterId: item.origin.disasterId || '',
parentId: item.origin.parentId || null,
planComponentId: item.origin.planComponentId || '',
}
this.http.post('/api/DisposalNodes/Clone', data, { params: params }).subscribe(data => {
this.refurbishTreeData()
})
} //isTrue
}
//删除 处置预案 节点
deletePanelPoint(e, item) {
e.stopPropagation()
if (confirm(`确定要删除 ${item.name} ?`)) {
this.http.delete(`/api/DisposalNodes/${item.id}`).subscribe(data => {
this.refurbishTreeData()
})
}
}
//点击 处置Tree节点
clickedNodeType: any
selectanelPoint(e, type) {
this.clickedNodeType = type
if (!e.buildingAreaId && !e.sitePlanId) { //当前节点 不是 数据节点 时
let msg = this.canvasData.findDisposalNode(e.id)
this.canvasData.selectPanelPointBaseData = msg
this.selectDisposalNode == msg.id ? this.selectDisposalNode = '' : this.selectDisposalNode = msg.id //选中 节点
} else if (e.buildingAreaId || e.sitePlanId) { //当前节点 是 数据节点 时
let msg = this.canvasData.findDisposalNode(e.parentId)
this.canvasData.selectPanelPointBaseData = msg
this.selectDisposalNode = e.parentId //选中 节点
this.Facilities ? this.sitePlanData.forEach(item => {
this.Facilities.forEach(i => {
if (item.id == i.key) {
item.isLabel = true //标记当层需要标注基本信息素材
}
})
}) : null
if (this.canvasData.selectPanelPoint.DisposalNodeId != e.id) { //选择节点 不是当前节点时
let api
//如果是已存在预案
if (this.examType == 1) {
type == 0 ? api = '/api/DisposalNodeData' : api = '/api/ExamDisposalNodeData'
} else { //如果是自定义预案
api = '/api/ExamDisposalNodeData'
}
let params = { nodeId: e.id }
let parameter = { //查询 节点 对应 建筑/楼层 index,id
buildingIndex: e.sitePlanId ? -1 : this.allBuildings.findIndex(item => { return item.id === e.buildingId }), //总平面图/建筑 index
storeyId: e.sitePlanId ? e.sitePlanId : e.buildingAreaId, //楼层id
}
this.http.get(api, { params: params }).subscribe(data => {
this.canvasData.selectPanelPoint = this.canvasData.deserialize(JSON.stringify(data || new DisposalNodeData())) //选择 当前 节点
this.canvasData.selectPanelPoint.Data = this.canvasData.deserialize(this.canvasData.selectPanelPoint.Data)
// console.log(456,this.canvasData.selectPanelPoint.Data)
this.seekPanelPoint(parameter)
})
} //if
} //else if
}
//查找 数据节点 对应 建筑/楼层
seekPanelPoint(paramsData) {
this.checkedBuildingIndex = paramsData.buildingIndex
if (paramsData.buildingIndex == -1) { //总平面图时
this.beforeOneCheckedBuilding = { name: "总平面图" }
let fireData = this.getFireElements(sessionStorage.getItem('buildingTypeId')) //获取单位下 消防要素
let planData = this.getSitePlanCompanyData() //获取 单位 数据
this.http.get('/api/SitePlans', { params: this.params }).subscribe(data => {
this.sitePlanData = data
let index = this.sitePlanData.findIndex(item => { return item.id === paramsData.storeyId })
this.selectingSitePlan = this.sitePlanData[index] || {}
this.canvasData.selectStorey = this.sitePlanData[index] || {} //服务中 存一份数据
this.selectSitePlanIndex = index
this.Facilities ? this.sitePlanData.forEach(item => {
this.Facilities.forEach(i => {
if (item.id == i.key) {
item.isLabel = true
}
})
}) : null
Promise.all([fireData, planData]).then((res) => {
this.getSitePlanStorey(this.selectingSitePlan) //获取 平面图 楼层数据
})
}) //get
} else { //建筑时
this.beforeOneCheckedBuilding = this.allBuildings[paramsData.buildingIndex]
let params = { buildingId: this.beforeOneCheckedBuilding.id }
let fireData = this.getFireElements(this.beforeOneCheckedBuilding.buildingTypes[0].id || '') //获取建筑下 消防要素
let planData = this.getBuildingData(params) //获取 建筑 数据
this.http.get('/api/BuildingAreas', { params }).subscribe(data => {
this.sitePlanData = data
let index = this.sitePlanData.findIndex(item => { return item.id === paramsData.storeyId })
this.selectingSitePlan = this.sitePlanData[index] || {}
this.canvasData.selectStorey = this.sitePlanData[index] || {} //服务中 存一份数据
this.selectSitePlanIndex = index
this.Facilities ? this.sitePlanData.forEach(item => {
this.Facilities.forEach(i => {
if (item.id == i.key) {
item.isLabel = true
}
})
}) : null
Promise.all([fireData, planData]).then((res) => {
this.getBuildingStorey(this.selectingSitePlan) //获取 建筑 楼层数据
})
}) //get
}
}
}