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.
1033 lines
31 KiB
1033 lines
31 KiB
import { Component, OnInit, ViewChild, Inject } from "@angular/core"; |
|
import { HttpClient } from "@angular/common/http"; |
|
import { |
|
MatTreeFlatDataSource, |
|
MatTreeFlattener, |
|
} from "@angular/material/tree"; |
|
import { MatPaginator } from "@angular/material/paginator"; |
|
import { FlatTreeControl } from "@angular/cdk/tree"; |
|
import { FormControl } from "@angular/forms"; |
|
import { Router, ActivatedRoute } from "@angular/router"; |
|
import { PageEvent } from "@angular/material/paginator"; |
|
import { |
|
MatDialogRef, |
|
MatDialog, |
|
MAT_DIALOG_DATA, |
|
} from "@angular/material/dialog"; |
|
import { MatSnackBar, MatSnackBarConfig } from "@angular/material/snack-bar"; |
|
import { TreeService } from "../../http-interceptors/tree.service"; |
|
import { MatSort } from "@angular/material/sort"; |
|
import { MatTableDataSource } from "@angular/material/table"; |
|
import { truncateSync } from "fs"; |
|
import { UploadDrillComponent } from "./upload-drill/upload-drill.component"; |
|
|
|
@Component({ |
|
selector: "app-key-unit-management", |
|
templateUrl: "./key-unit-management.component.html", |
|
styleUrls: ["./key-unit-management.component.scss"], |
|
}) |
|
export class KeyUnitManagementComponent implements OnInit { |
|
constructor( |
|
private http: HttpClient, |
|
private router: Router, |
|
private route: ActivatedRoute, |
|
private tree: TreeService, |
|
public dialog: MatDialog, |
|
public snackBar: MatSnackBar |
|
) {} |
|
|
|
pcMore; //pc更多 |
|
pcput = false; //pc收起 |
|
pcfind; //pc查询 |
|
padjt = false; |
|
padMore = true; //pad收缩控制 |
|
padput = false; //pad收起按钮 |
|
imgsrcopen = "../../../assets/images/routdown2.png"; |
|
imgsrcdown = "../../../assets/images/routup2.png"; |
|
pcInfo() { |
|
this.pcMore = !this.pcMore; |
|
this.pcput = !this.pcput; |
|
} |
|
padInfo() { |
|
this.padMore = !this.padMore; |
|
this.padput = !this.padput; |
|
} |
|
private _transformer = (node, level: number) => { |
|
//初始化tree |
|
return { |
|
expandable: !!node.children && node.children.length > 0, |
|
name: node.name, |
|
level: level, |
|
id: node.id, |
|
parentId: node.parentId, |
|
children: node.children, |
|
}; |
|
}; |
|
treeControl = new FlatTreeControl<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); |
|
myControl = new FormControl(); |
|
hasChild = (_: number, node: any) => node.expandable; |
|
|
|
@ViewChild(MatSort) sort: MatSort; |
|
|
|
allunittype: any; //获取所有的单位类型 |
|
|
|
//分页 |
|
@ViewChild(MatPaginator, { static: true }) |
|
pageEvent: PageEvent; |
|
paginator: MatPaginator; |
|
length: any; //共多少条数据 |
|
pageSize: any; //每页条数 |
|
pageSizeOptions: number[] = [10]; //设置每页条数 |
|
PageNumber: any; //第几页 |
|
|
|
displayedColumns: string[] = [ |
|
"checked", |
|
"Follow", |
|
"unitname", |
|
"address", |
|
"jurisdictionsquadron", |
|
"unittype", |
|
"phone", |
|
"operation", |
|
]; |
|
tabledataSource: any; |
|
allorganizations: any; |
|
oldDataSource: any; //原始表格数据 |
|
integrityScoreMin; //下界 |
|
integrityScoreMax; //上界 |
|
//表头排序 |
|
sortData(e) { |
|
let data = this.tabledataSource.filteredData; |
|
//console.log(data.filteredData) |
|
// data.filteredData.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.tabledataSource = new MatTableDataSource(data); |
|
} else if (e.direction == "desc") { |
|
//从大到小排序 |
|
data.sort(function (a, b) { |
|
return b.newTime - a.newTime; |
|
}); |
|
this.tabledataSource = new MatTableDataSource(data); |
|
} else { |
|
//原始数据 |
|
this.tabledataSource = new MatTableDataSource(this.oldDataSource); |
|
} |
|
} |
|
|
|
colorRgb(sColor) { |
|
var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/; |
|
var sColor = sColor.toLowerCase(); |
|
if (sColor && reg.test(sColor)) { |
|
if (sColor.length === 4) { |
|
var sColorNew = "#"; |
|
for (var i = 1; i < 4; i += 1) { |
|
sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1)); |
|
} |
|
sColor = sColorNew; |
|
} |
|
//处理六位的颜色值 |
|
var sColorChange = []; |
|
for (var i = 1; i < 7; i += 2) { |
|
sColorChange.push(parseInt("0x" + sColor.slice(i, i + 2))); |
|
} |
|
return sColorChange; |
|
} else { |
|
return sColor; |
|
} |
|
} |
|
colorHex(rgb) { |
|
var _this = rgb; |
|
var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/; |
|
if (/^(rgb|RGB)/.test(_this)) { |
|
var aColor = _this.replace(/(?:(|)|rgb|RGB)*/g, "").split(","); |
|
var strHex = "#"; |
|
for (var i = 0; i < aColor.length; i++) { |
|
var hex: any = Number(aColor[i]).toString(16); |
|
hex = hex < 10 ? 0 + "" + hex : hex; // 保证每个rgb的值为2位 |
|
if (hex === "0") { |
|
hex += hex; |
|
} |
|
strHex += hex; |
|
} |
|
if (strHex.length !== 7) { |
|
strHex = _this; |
|
} |
|
return strHex; |
|
} else if (reg.test(_this)) { |
|
var aNum = _this.replace(/#/, "").split(""); |
|
if (aNum.length === 6) { |
|
return _this; |
|
} else if (aNum.length === 3) { |
|
var numHex = "#"; |
|
for (var i = 0; i < aNum.length; i += 1) { |
|
numHex += aNum[i] + aNum[i]; |
|
} |
|
return numHex; |
|
} |
|
} else { |
|
return _this; |
|
} |
|
} |
|
gradientColor(startColor, endColor, step) { |
|
let _this = this; |
|
let startRGB = _this.colorRgb(startColor); //转换为rgb数组模式 |
|
let startR = startRGB[0]; |
|
let startG = startRGB[1]; |
|
let startB = startRGB[2]; |
|
|
|
let endRGB = _this.colorRgb(endColor); |
|
let endR = endRGB[0]; |
|
let endG = endRGB[1]; |
|
let endB = endRGB[2]; |
|
|
|
let sR = (endR - startR) / step; //总差值 |
|
let sG = (endG - startG) / step; |
|
let sB = (endB - startB) / step; |
|
|
|
var colorArr = []; |
|
for (var i = 0; i < step; i++) { |
|
//计算每一步的hex值 |
|
var hex = _this.colorHex( |
|
"rgb(" + |
|
parseInt(sR * i + startR) + |
|
"," + |
|
parseInt(sG * i + startG) + |
|
"," + |
|
parseInt(sB * i + startB) + |
|
")" |
|
); |
|
colorArr.push(hex); |
|
} |
|
return colorArr; |
|
} |
|
integrity(width) { |
|
let _this = this; |
|
|
|
let style: any = {}; |
|
style.width = width + "%"; |
|
if (width < 30) { |
|
let colorArr = this.gradientColor("#D50000", "#E53935", 30); |
|
for (let i = 0; i < 30; i++) { |
|
if (i == width) { |
|
style.background = colorArr[i]; |
|
} |
|
} |
|
} |
|
if (width >= 30 && width < 60) { |
|
let colorArr = this.gradientColor("#FF9800", "#E65100", 30); |
|
for (let i = 30; i < 60; i++) { |
|
if (i == width) { |
|
style.background = colorArr[i - 30]; |
|
} |
|
} |
|
} |
|
if (width >= 60) { |
|
let colorArr = this.gradientColor("#81C784", "#2E7D32", 41); |
|
for (let i = 60; i <= 100; i++) { |
|
if (i == width) { |
|
style.background = colorArr[i - 60]; |
|
} |
|
} |
|
} |
|
return style; |
|
} |
|
integrityDetails(width, zong) { |
|
let style: any = {}; |
|
style.width = (width / zong) * 100 + "%"; |
|
return style; |
|
} |
|
//分页事件 |
|
chagePage(e) { |
|
this.PageNumber = e.pageIndex + 1; |
|
this.getAllKeyUnit(); |
|
} |
|
ngOnInit(): void { |
|
// alert(document.documentElement.clientHeight) |
|
this.getunitdata(); |
|
this.getOrganizations(); |
|
this.getUnittype(); |
|
this.getAllKeyUnit(); |
|
if (window.matchMedia("(max-width: 1290px)").matches) { |
|
this.pcMore = false; |
|
this.padMore = true; |
|
this.pcfind = false; |
|
this.padjt = true; |
|
} else { |
|
this.pcfind = true; |
|
this.pcMore = true; |
|
this.padMore = false; |
|
this.padjt = false; |
|
} |
|
} |
|
//获得所有重点单位 |
|
|
|
wanzhengduArr = [ |
|
{ |
|
id: 0, |
|
zong: 94, |
|
details: [ |
|
{ name: "单位信息", score: 5, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 8, totalpoints: 10 }, |
|
{ name: "平面图", score: 8, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 25, totalpoints: 25 }, |
|
{ name: "消防设施", score: 10, totalpoints: 10 }, |
|
{ name: "重点部位", score: 10, totalpoints: 10 }, |
|
{ name: "功能分区", score: 8, totalpoints: 10 }, |
|
{ name: "实景图", score: 10, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 10, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 1, |
|
zong: 82, |
|
details: [ |
|
{ name: "单位信息", score: 5, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 8, totalpoints: 10 }, |
|
{ name: "平面图", score: 8, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 25, totalpoints: 25 }, |
|
{ name: "消防设施", score: 8, totalpoints: 10 }, |
|
{ name: "重点部位", score: 8, totalpoints: 10 }, |
|
{ name: "功能分区", score: 6, totalpoints: 10 }, |
|
{ name: "实景图", score: 8, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 6, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 2, |
|
zong: 72, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 5, totalpoints: 10 }, |
|
{ name: "平面图", score: 8, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 22, totalpoints: 25 }, |
|
{ name: "消防设施", score: 7, totalpoints: 10 }, |
|
{ name: "重点部位", score: 7, totalpoints: 10 }, |
|
{ name: "功能分区", score: 6, totalpoints: 10 }, |
|
{ name: "实景图", score: 8, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 6, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 3, |
|
zong: 61, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 5, totalpoints: 10 }, |
|
{ name: "平面图", score: 7, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 18, totalpoints: 25 }, |
|
{ name: "消防设施", score: 5, totalpoints: 10 }, |
|
{ name: "重点部位", score: 3, totalpoints: 10 }, |
|
{ name: "功能分区", score: 5, totalpoints: 10 }, |
|
{ name: "实景图", score: 8, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 6, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 4, |
|
zong: 60, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 5, totalpoints: 10 }, |
|
{ name: "平面图", score: 6, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 18, totalpoints: 25 }, |
|
{ name: "消防设施", score: 5, totalpoints: 10 }, |
|
{ name: "重点部位", score: 3, totalpoints: 10 }, |
|
{ name: "功能分区", score: 5, totalpoints: 10 }, |
|
{ name: "实景图", score: 8, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 6, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 5, |
|
zong: 53, |
|
details: [ |
|
{ name: "单位信息", score: 5, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 5, totalpoints: 10 }, |
|
{ name: "平面图", score: 5, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 10, totalpoints: 25 }, |
|
{ name: "消防设施", score: 5, totalpoints: 10 }, |
|
{ name: "重点部位", score: 5, totalpoints: 10 }, |
|
{ name: "功能分区", score: 5, totalpoints: 10 }, |
|
{ name: "实景图", score: 7, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 6, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 6, |
|
zong: 45, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 5, totalpoints: 10 }, |
|
{ name: "平面图", score: 5, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 15, totalpoints: 25 }, |
|
{ name: "消防设施", score: 5, totalpoints: 10 }, |
|
{ name: "重点部位", score: 5, totalpoints: 10 }, |
|
{ name: "功能分区", score: 3, totalpoints: 10 }, |
|
{ name: "实景图", score: 5, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 4, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 7, |
|
zong: 30, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 0, totalpoints: 10 }, |
|
{ name: "平面图", score: 4, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 2, totalpoints: 25 }, |
|
{ name: "消防设施", score: 5, totalpoints: 10 }, |
|
{ name: "重点部位", score: 5, totalpoints: 10 }, |
|
{ name: "功能分区", score: 2, totalpoints: 10 }, |
|
{ name: "实景图", score: 6, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 3, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 8, |
|
zong: 20, |
|
details: [ |
|
{ name: "单位信息", score: 3, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 2, totalpoints: 10 }, |
|
{ name: "平面图", score: 0, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 3, totalpoints: 25 }, |
|
{ name: "消防设施", score: 3, totalpoints: 10 }, |
|
{ name: "重点部位", score: 3, totalpoints: 10 }, |
|
{ name: "功能分区", score: 3, totalpoints: 10 }, |
|
{ name: "实景图", score: 2, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 1, totalpoints: 10 }, |
|
], |
|
}, |
|
{ |
|
id: 9, |
|
zong: 13, |
|
details: [ |
|
{ name: "单位信息", score: 5, totalpoints: 5 }, |
|
{ name: "建筑信息", score: 3, totalpoints: 10 }, |
|
{ name: "平面图", score: 0, totalpoints: 10 }, |
|
{ name: "四周毗邻", score: 2, totalpoints: 25 }, |
|
{ name: "消防设施", score: 0, totalpoints: 10 }, |
|
{ name: "重点部位", score: 3, totalpoints: 10 }, |
|
{ name: "功能分区", score: 0, totalpoints: 10 }, |
|
{ name: "实景图", score: 0, totalpoints: 10 }, |
|
{ name: "CAD上传", score: 0, totalpoints: 10 }, |
|
], |
|
}, |
|
]; |
|
|
|
allKeyUnitInfo: any; //所有的重点单位 |
|
IsNewData = ""; //是否是新增或者维护更新 |
|
getAllKeyUnit() { |
|
// console.log(Boolean(Number(this.follow))) |
|
let follow; |
|
if (this.follow == "") { |
|
follow = ""; |
|
} |
|
if (this.follow == "0") { |
|
follow = false; |
|
} |
|
if (this.follow == "1") { |
|
follow = true; |
|
} |
|
|
|
let paramsdata: any = { |
|
Name: this.companyName || "", |
|
OrganizationId: this.jsId || "", |
|
HasChildren: this.jscheck || "", |
|
USCI: this.shehui || "", |
|
IsFollowed: follow, |
|
BuildingTypeId: this.unittype || "", |
|
PageNumber: this.PageNumber || "1", |
|
PageSize: this.pageSizeOptions[0], |
|
Sort: this.integritySort ? "integrityscore" : "", |
|
SortType: this.integritySort || "", |
|
IsNewData: this.IsNewData, |
|
IntegrityScoreMin: this.integrityScoreMin / 100 || 0, |
|
IntegrityScoreMax: this.integrityScoreMax / 100 || 1, |
|
}; |
|
this.http |
|
.get("/api/Companies", { params: paramsdata }) |
|
.subscribe((data: any) => { |
|
console.log(data); |
|
this.length = data.totalCount; |
|
this.allKeyUnitInfo = data; |
|
data.items.forEach((item, index) => { |
|
item.integrity = this.wanzhengduArr[index]; |
|
}); |
|
this.tabledataSource = [...data.items]; |
|
}); |
|
} |
|
//得到当前单位信息 |
|
getunitdata() { |
|
this.http.get("/api/Account/Profiles").subscribe((data: any) => { |
|
this.organizationName = data.organizationName; |
|
}); |
|
} |
|
organizationName: any; //当前单位组织机构名称 |
|
treedata: any; //组织机构树型数据 |
|
newArr: any = []; |
|
newallorganizations: any; //用于存储在原始数据基础上的每个机构增加children字段 |
|
newallorganizations2: any; |
|
//得到当前单位所在组织机构的tree型数据 |
|
getpresentOrganization() { |
|
this.newallorganizations = this.allorganizations; |
|
this.newallorganizations.forEach((item) => { |
|
item.children = []; |
|
this.newallorganizations.forEach((element) => { |
|
if (element.parentId == item.id) { |
|
item.children.push(element); |
|
} |
|
}); |
|
}); |
|
this.http.get("/api/Account/Profiles").subscribe((data: any) => { |
|
this.organizationName = data.organizationName; |
|
if (this.organizationName) { |
|
this.newallorganizations.forEach((item) => { |
|
if (item.name == this.organizationName) { |
|
this.dataSource.data = [item]; |
|
this.newallorganizations2 = [item]; |
|
} |
|
}); |
|
} else { |
|
this.newallorganizations2 = this.treedata; |
|
this.dataSource.data = this.treedata; |
|
} |
|
}); |
|
} |
|
//获得所有组织机构 |
|
getOrganizations() { |
|
this.http.get("/api/Organizations").subscribe((data: any) => { |
|
this.allorganizations = data; |
|
this.treedata = this.tree.toTree(data); |
|
this.getpresentOrganization(); |
|
}); |
|
} |
|
|
|
//获得所有单位类型 |
|
getUnittype() { |
|
this.http.get("/api/BuildingTypes/Simple").subscribe((data) => { |
|
this.allunittype = data; |
|
}); |
|
} |
|
selectedunitArr: any = []; //选中单位的数组 |
|
//勾选框事件 |
|
verifyState; //判断是否可以修改 |
|
checkChange(e, element) { |
|
if (element.contentVerify != null) { |
|
this.verifyState = element.contentVerify.verifyState; |
|
} else { |
|
this.verifyState = null; |
|
} |
|
if (e.checked) { |
|
//this.deleteArr=element |
|
this.deleteAll.push(element); |
|
} else { |
|
for (var i = 0; i < this.deleteAll.length; i++) { |
|
if (this.deleteAll[i].id == element.id) { |
|
this.deleteAll.splice(i, 1); |
|
} |
|
} |
|
} |
|
element.checked = e.checked; |
|
} |
|
deleteArr; //单个删除 |
|
deleteAll = []; //批量删除 |
|
checkClick(element, e) { |
|
if (element.contentVerify != null) { |
|
if ( |
|
element.contentVerify.verifyState == 0 || |
|
element.contentVerify.verifyState == 3 |
|
) { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open("该单位正在审核不能选中", "确定", config); |
|
} |
|
} else { |
|
this.deleteArr = element; |
|
} |
|
} |
|
//编辑单位信息 |
|
editunit() { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
let selectedunitArr = []; |
|
let selectedunitobj = []; |
|
this.allKeyUnitInfo.items.forEach((item) => { |
|
if (item.checked) { |
|
selectedunitArr.push(item.id); |
|
selectedunitobj.push(item); |
|
} |
|
}); |
|
|
|
if (selectedunitArr.length == 0) { |
|
this.snackBar.open("请先选择要修改的单位", "确定", config); |
|
} |
|
if (selectedunitArr.length != 1 && selectedunitArr.length != 0) { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open("只能选择一个单位修改", "确定", config); |
|
} |
|
if (selectedunitArr.length == 1) { |
|
//带着id跳到修改页面 |
|
this.allKeyUnitInfo.items.forEach((item) => { |
|
if (item.id == selectedunitArr[0]) { |
|
let companyName = item.name; |
|
sessionStorage.setItem("companyName", companyName); |
|
sessionStorage.setItem("companyId", item.id); |
|
} |
|
}); |
|
sessionStorage.setItem("editable", "1"); |
|
sessionStorage.setItem( |
|
selectedunitobj[0].id, |
|
JSON.stringify(selectedunitobj[0].companyIntegrityScore) |
|
); |
|
window.open( |
|
`/keyUnit/editplaninfo?id=${selectedunitArr[0]}&usci=${selectedunitobj[0].usci}` |
|
); |
|
} |
|
} |
|
//关注重点单位 |
|
Follow(element) { |
|
// console.log(element) |
|
this.http |
|
.put(`/api/Companies/${element.id}/Follow`, "") |
|
.subscribe((data) => { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open("设为重点单位成功", "确定", config); |
|
this.getAllKeyUnit(); |
|
}); |
|
} |
|
//取消关注 |
|
unFollow(element) { |
|
// console.log(element) |
|
this.http |
|
.put(`/api/Companies/${element.id}/Unfollow`, "") |
|
.subscribe((data) => { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open("设为一般单位成功", "确定", config); |
|
this.getAllKeyUnit(); |
|
}); |
|
} |
|
//删除单位信息 |
|
deleteAudia = []; //批量删除提交数组 |
|
deleteunit() { |
|
var result = confirm("确认要执删除选中单位吗?"); |
|
if (result) { |
|
this.deleteAudia = []; |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
let selectedunitArr = []; |
|
this.allKeyUnitInfo.items.forEach((item) => { |
|
if (item.checked) { |
|
selectedunitArr.push(item.id); |
|
} |
|
}); |
|
|
|
if (selectedunitArr.length == 0) { |
|
this.snackBar.open("请先选择要删除的单位", "确定", config); |
|
return; |
|
} |
|
console.log("删除的单位列表", selectedunitArr); |
|
|
|
let num = 0; |
|
for (let index = 0; index < selectedunitArr.length; index++) { |
|
const element = selectedunitArr[index]; |
|
this.http.delete(`/api/Companies/${element}`).subscribe((data) => { |
|
num++; |
|
if (num === selectedunitArr.length) { |
|
this.snackBar.open("删除成功", "确定", config); |
|
this.getAllKeyUnit(); |
|
} |
|
}); |
|
} |
|
} |
|
} |
|
|
|
//重置 |
|
js: any; //辖区中队输入框 |
|
jsId: any; //辖区中队选择的id |
|
companyName: any; //单位名称 |
|
shehui: any; //统一社会信用代码 |
|
unittype: any; //单位类型 |
|
jscheck: any; //辖区中队包含下级 |
|
OrganizationId; // |
|
follow: any = ""; //是否为关注单位 |
|
integritySort: any; //完整度排序 |
|
reset() { |
|
this.js = ""; //辖区中队输入框 |
|
this.jscheck = ""; //辖区中队包含下级 |
|
this.companyName = ""; //单位名称 |
|
this.shehui = ""; //统一社会信用代码 |
|
this.unittype = ""; //单位类型 |
|
this.jsId = ""; |
|
this.follow = ""; |
|
this.PageNumber = 1; |
|
this.pageEvent.pageIndex = 0; |
|
this.integritySort = ""; |
|
this.integrityScoreMax = undefined; |
|
this.integrityScoreMin = undefined; |
|
this.IsNewData = ""; |
|
|
|
this.getAllKeyUnit(); |
|
} |
|
//编辑单位名称 |
|
editUnitName(element) { |
|
//console.log(element) |
|
const dialogRef = this.dialog.open(upname, { |
|
width: "340px", |
|
height: "280px", |
|
data: element, |
|
}); |
|
dialogRef.afterClosed().subscribe((result) => { |
|
//console.log(result); |
|
if (element) { |
|
element.name = result; |
|
} |
|
}); |
|
} |
|
|
|
//跳转查看基本信息页面 |
|
unitdetails(element) { |
|
// console.log(element) |
|
sessionStorage.setItem("editable", "0"); |
|
sessionStorage.setItem("companyName", element.name); |
|
sessionStorage.setItem("companyId", element.id); |
|
sessionStorage.setItem( |
|
element.id, |
|
JSON.stringify(element.companyIntegrityScore) |
|
); |
|
window.open( |
|
`/keyUnit/viewunitinfo?id=${element.id}&usci=${element.usci}`, |
|
"_blank" |
|
); |
|
} |
|
//提交查询表单 |
|
onSubmit(value) { |
|
this.PageNumber = 1; |
|
this.pageEvent.pageIndex = 0; |
|
this.getAllKeyUnit(); |
|
} |
|
bigclosediv(e) { |
|
this.isorganizationbox = false; |
|
} |
|
stopclose(e) { |
|
e.stopPropagation(); |
|
} |
|
//辖区中队div是否显示 |
|
isorganizationbox: boolean = false; |
|
//点击辖区中队树,将选择的辖区中队添加到变量 |
|
add(node) { |
|
this.isorganizationbox = false; |
|
this.js = node.name; |
|
this.jsId = node.id; |
|
} |
|
//关闭辖区中队隐藏框 |
|
closeorganizationbox() { |
|
this.isorganizationbox = false; |
|
} |
|
//打开辖区中队隐藏框 |
|
openorganizationbox() { |
|
this.isorganizationbox = true; |
|
} |
|
|
|
//关闭出现的组织机构div |
|
closediv() { |
|
this.isorganizationbox = false; |
|
} |
|
|
|
//新增重点单位 |
|
createunit() { |
|
// console.log(this.newallorganizations2) |
|
const dialogRef = this.dialog.open(CreateUnit, { |
|
//调用open方法打开对话框并且携带参数过去 |
|
width: "625px", |
|
data: { |
|
allunittype: this.allunittype, |
|
allorganizations: this.newallorganizations2, |
|
}, |
|
}); |
|
dialogRef.afterClosed().subscribe((data) => { |
|
if (data) { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open("创建成功", "确定", config); |
|
this.getAllKeyUnit(); |
|
sessionStorage.setItem("companyName", data.name); |
|
sessionStorage.setItem("editable", "1"); |
|
sessionStorage.setItem("companyId", data.id); |
|
window.open(`/keyUnit/editplaninfo?id=${data.id}&usci=${data.usci}`); |
|
} |
|
}); |
|
} |
|
//提交审核 |
|
submitAudit(element) { |
|
console.log(element); |
|
let body: any = { |
|
title: element.name, |
|
Operation: element.contentVerify == null && element.isNewData ? 0 : 1, |
|
itemId: element.id, |
|
verifyState: 3, |
|
contentType: 11, |
|
}; |
|
this.http.post(`/api/ContentVerifies`, body).subscribe( |
|
(data) => { |
|
this.getAllKeyUnit(); |
|
}, |
|
(err) => { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open(err, "确定", config); |
|
} |
|
); |
|
} |
|
//撤销审核 |
|
cancelAudit(element) { |
|
this.deleteAll = []; |
|
this.http |
|
.delete(`/api/ContentVerifies/${element.contentVerify.id}`) |
|
.subscribe( |
|
(data) => { |
|
this.getAllKeyUnit(); |
|
}, |
|
(err) => { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open(err, "确定", config); |
|
} |
|
); |
|
} |
|
//审核结果 |
|
auditResult(element) { |
|
const dialogRef = this.dialog.open(companyAuditResult, { |
|
width: "400px", |
|
//height:"300px", |
|
data: { element: element }, |
|
}); |
|
} |
|
|
|
//上传演练记录 |
|
drill(element) { |
|
console.log(element); |
|
const dialogRef = this.dialog.open(UploadDrillComponent, { |
|
width: "700px", |
|
data: { unitInfo: element, isEditMode: true }, |
|
}); |
|
|
|
dialogRef.afterClosed().subscribe((result) => { |
|
console.log("The dialog was closed"); |
|
}); |
|
} |
|
} |
|
|
|
//创建重点单位 |
|
@Component({ |
|
selector: "createunit", |
|
templateUrl: "./createunit.component.html", |
|
styleUrls: ["./key-unit-management.component.scss"], |
|
}) |
|
export class CreateUnit { |
|
myControl = new FormControl(); |
|
private _transformer = (node, level: number) => { |
|
return { |
|
expandable: !!node.children && node.children.length > 0, |
|
name: node.name, |
|
level: level, |
|
id: node.id, |
|
parentId: node.parentId, |
|
enabled: node.enabled, |
|
order: node.order, |
|
}; |
|
}; |
|
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); |
|
constructor( |
|
private http: HttpClient, |
|
public dialogRef: MatDialogRef<CreateUnit>, |
|
@Inject(MAT_DIALOG_DATA) public data, |
|
public snackBar: MatSnackBar, |
|
private tree: TreeService |
|
) {} |
|
hasChild = (_: number, node: any) => node.expandable; |
|
allunittype = this.data.allunittype; |
|
js: any; //所属辖区中队 |
|
jsId: any; //所属辖区中队的id |
|
ngOnInit(): void { |
|
this.dataSource.data = this.data.allorganizations; |
|
} |
|
onNoClick(): void { |
|
this.dialogRef.close(); |
|
} |
|
add(node) { |
|
this.js = node.name; |
|
this.jsId = node.id; |
|
} |
|
onSubmit(value) { |
|
let myDate = new Date(); |
|
let usci = new Date().getTime() + "00000"; |
|
let body = { |
|
id: "", |
|
name: value.name, |
|
usci: value.usci || usci, |
|
contacts: "", |
|
phone: "", |
|
address: "", |
|
imageUrl: "", |
|
location: { |
|
x: 0, |
|
y: 0, |
|
}, |
|
modifiedTime: myDate, |
|
organizationId: this.jsId, |
|
organizationName: this.js, |
|
buildingTypes: [ |
|
{ |
|
id: value.unittype, |
|
name: "", |
|
}, |
|
], |
|
}; |
|
this.http.post("/api/Companies", body).subscribe( |
|
(data) => { |
|
this.dialogRef.close(data); |
|
}, |
|
(err) => { |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
this.snackBar.open(err, "确定", config); |
|
} |
|
); |
|
} |
|
} |
|
|
|
//修改单位名称 |
|
@Component({ |
|
selector: "upname", |
|
templateUrl: "./upname.html", |
|
styleUrls: ["./upname.scss"], |
|
}) |
|
export class upname { |
|
constructor( |
|
private router: Router, |
|
private http: HttpClient, |
|
public dialog: MatDialog, |
|
public snackBar: MatSnackBar, |
|
public dialogRef: MatDialogRef<upname>, |
|
@Inject(MAT_DIALOG_DATA) public data: any |
|
) {} |
|
unitname: string; //修改后的名称 |
|
oldname = this.data.name; //原名 |
|
oldid = this.data.id; |
|
|
|
//取消 |
|
close() { |
|
this.dialogRef.close(this.oldname); |
|
} |
|
//确定 |
|
updateName() { |
|
//console.log(this.unitname) |
|
const config = new MatSnackBarConfig(); |
|
config.verticalPosition = "top"; |
|
config.duration = 3000; |
|
if (this.unitname == "" || this.unitname == undefined) { |
|
this.snackBar.open("请填写新单位名称", "确定", config); |
|
} else if (this.unitname == this.oldname) { |
|
this.snackBar.open("新单位名称不能和旧单位名称一样", "确定", config); |
|
} else { |
|
let paramsdata: any = { |
|
id: this.oldid, |
|
name: this.unitname, |
|
}; |
|
this.http |
|
.put(`/api/Companies/${this.oldid}/UpdateName`, paramsdata) |
|
.subscribe( |
|
(data: any) => { |
|
this.snackBar.open("修改名字成功", "确定", config); |
|
this.dialogRef.close(this.unitname); |
|
}, |
|
(err) => { |
|
this.snackBar.open(err, "确定", config); |
|
this.dialogRef.close(); |
|
} |
|
); |
|
} |
|
} |
|
} |
|
|
|
//查看审核结果 |
|
@Component({ |
|
selector: "resultmeet", |
|
templateUrl: "./resultcompanyPlan.html", |
|
styleUrls: ["./key-unit-management.component.scss"], |
|
}) |
|
export class companyAuditResult { |
|
constructor( |
|
private http: HttpClient, |
|
public dialogRef: MatDialogRef<companyAuditResult>, |
|
@Inject(MAT_DIALOG_DATA) public data, |
|
public snackBar: MatSnackBar |
|
) {} |
|
planName: any = this.data.element.name; |
|
createTime = ""; |
|
organizationName = this.data.element.organizationName; |
|
verifyTime = ""; |
|
remark = ""; |
|
verifyOrganizationName; |
|
verifyState = 100; |
|
ngOnInit(): void { |
|
if (this.data.element.contentVerify != null) { |
|
this.createTime = this.data.element.contentVerify.createTime; |
|
//this.organizationName=this.data.element.organizationName |
|
this.verifyTime = this.data.element.contentVerify.verifyTime; |
|
//this.remark=this.data.element.remark |
|
this.verifyState = this.data.element.contentVerify.verifyState; |
|
this.verifyOrganizationName = |
|
this.data.element.contentVerify.verifyOrganizationName; |
|
this.remark = this.data.element.contentVerify.remark; |
|
} |
|
} |
|
onNoClick(): void { |
|
this.dialogRef.close(); |
|
} |
|
}
|
|
|