邵佳豪 4 years ago
parent
commit
c6d204bf04
  1. 14
      src/app/ui/plan-template/addKeyname.html
  2. 65
      src/app/ui/plan-template/plan-template.component.html
  3. 7
      src/app/ui/plan-template/plan-template.component.scss
  4. 163
      src/app/ui/plan-template/plan-template.component.ts
  5. 14
      src/app/ui/plan-template/upPlan.html

14
src/app/ui/plan-template/addKeyname.html

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-05-20 16:11:57
* @LastEditors: sueRimn
* @LastEditTime: 2021-05-24 09:52:10
* @LastEditTime: 2021-05-28 16:53:04
-->
<div class="box">
<div class="top">
@ -13,7 +13,7 @@
<div class="queryField">
<label style="margin-right: 10px;">预案名称:</label>
<mat-form-field class="example-full-width">
<input matInput placeholder="请输入预案名称" name="companyName" autocomplete="off" [(ngModel)]="unitname" required>
<input matInput placeholder="请输入预案名称" name="companyName" autocomplete="off" [(ngModel)]="planname" required>
</mat-form-field>
</div>
@ -22,17 +22,17 @@
<label style="margin-right: 10px;">预案级别:</label>
<mat-form-field>
<mat-select placeholder='请选择预案级别' name="level" [(ngModel)]="level" required>
<mat-option value="Ⅲ级">Ⅲ级</mat-option>
<mat-option value="Ⅳ级">Ⅳ级</mat-option>
<mat-option value="Ⅴ级">Ⅴ级</mat-option>
<mat-option value=3>Ⅲ级</mat-option>
<mat-option value=4>Ⅳ级</mat-option>
<mat-option value=5>Ⅴ级</mat-option>
</mat-select>
</mat-form-field>
</div>
<div class="queryField">
<label style="margin-right: 10px;">单位类型:</label>
<mat-form-field>
<mat-select placeholder='请选择单位类型' name="unittype" [(ngModel)]="unittype" required>
<mat-option *ngFor="let unit of allunittype" [value]="unit.id">{{unit.name}}</mat-option>
<mat-select placeholder='请选择单位类型' name="unittype" [(ngModel)]="unitid" id="unit" required>
<mat-option *ngFor="let unit of allunittype" [value]="unit.id" >{{unit.name}}</mat-option>
</mat-select>
</mat-form-field>
</div>

65
src/app/ui/plan-template/plan-template.component.html

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-05-19 15:50:20
* @LastEditors: sueRimn
* @LastEditTime: 2021-05-26 16:41:51
* @LastEditTime: 2021-05-28 17:07:26
-->
<div class="box">
<div class="boxleft">
@ -18,14 +18,14 @@
</div>
</div>
<div class="leftbox">
<div class="leftbody" [ngClass]="{'selectedTr': item.name == planName}" *ngFor="let item of newleftTabledata;let i=index" (click)='planClick(item)'>
<div class="leftbody" [ngClass]="{'selectedTr': item.unitname == unitName}" *ngFor="let item of newleftTabledata;let i=index" (click)='planClick(item)'>
<div class="bodyname">
<span>{{item.name}}</span>
<span>{{item.unitname}}</span>
</div>
<div class="bodycz">
<span>{{item.level}}</span>
<img [src]="item.name == planName? '../../../assets/images/update.png':'../../../assets/images/updatehui.png'" (click)='upPlan(item,i)'>
<img [src]="item.name == planName? '../../../assets/images/deleteblue.png':'../../../assets/images/deletehui.png'" (click)='deletePlan(i)'>
<span>{{item.level==3?'Ⅲ级':item.level==4?'Ⅳ级':'Ⅴ级'}}</span>
<img [src]="item.unitname == unitName? '../../../assets/images/update.png':'../../../assets/images/updatehui.png'" (click)='upPlan(item,i)'>
<img [src]="item.unitname == unitName? '../../../assets/images/deleteblue.png':'../../../assets/images/deletehui.png'" (click)='deletePlan(i)'>
</div>
</div>
</div>
@ -33,17 +33,17 @@
<div class="boxright">
<div class="righthead">
<div class="rightheadone">
<span>{{planName}}</span>
<span>{{unitName}}</span>
</div>
<div class="rightheadtwo">
<button mat-raised-button color="primary" (click)='addGroupClick()' style="margin-left: 60%;">新增分组</button>
<button mat-raised-button color="primary" style="margin-left: 10px;">保存</button>
<button mat-raised-button color="primary" style="margin-left: 10px;" (click)='save()'>保存</button>
</div>
</div>
<div class="rightbody">
<mat-accordion *ngFor="let item of group" multi>
<!-- 基本信息 -->
<mat-expansion-panel *ngIf="item.completed" expanded style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;">
<mat-expansion-panel [expanded]='groupPanle==true' *ngIf="item.completed" expanded style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;">
<mat-expansion-panel-header collapsedHeight='40px' expandedHeight='40px' class="panelhead">
<mat-panel-title class="paneltitle">
<div class="groupName">
@ -62,53 +62,74 @@
</mat-expansion-panel-header>
<div class="accordingin">
<mat-accordion *ngFor="let element of item.attribute">
<mat-expansion-panel *ngIf="element.completed" expanded style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;height: 100%;">
<mat-expansion-panel [expanded]='attPanle' *ngIf="element.completed" expanded style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;height: 100%;">
<mat-expansion-panel-header collapsedHeight='50px' expandedHeight='50px' class="panelhead" style="background-color: #FFFFFF;">
<mat-panel-title style="font-size: 16px;color:#000000;" class="paneltitle">
<div class="dwgk" *ngIf="item.groupName=='单位概况'">
<div class="attname" *ngIf="item.groupName=='单位概况'">
<span>{{element.surveyName}}</span>
</div>
<div class="caozuo" *ngIf="item.groupName=='单位概况'&&(element.surveyName=='单位基本信息'||element.surveyName=='建筑信息'||element.surveyName=='进攻通道'||element.surveyName=='消防设施')">
<button mat-raised-button color="#ECF6FF"><img src="../../../assets/images/deletehui.png" (click)='delAttribute(element.surveyName)'> 删除</button>
<button mat-raised-button color="primary" style="margin-right: 10px;" (click)='addAttInfo()'><img src="../../../assets/images/addbai.png"> 新增</button>
<div class="caozuo">
<button mat-raised-button color="#ECF6FF" (click)='delAttribute(item.groupName,element.surveyName)'><img src="../../../assets/images/deletehui.png"> 删除</button>
<button mat-raised-button color="primary" style="margin-right: 10px;" (click)='addAttInfo(element.surveyName)'
*ngIf="item.groupName=='单位概况'&&(element.surveyName=='单位基本信息'||element.surveyName=='建筑信息'||element.surveyName=='进攻通道'||element.surveyName=='消防设施')"><img src="../../../assets/images/addbai.png"> 编辑</button>
</div>
</div>
</mat-panel-title>
</mat-expansion-panel-header>
<div class="table">
<table mat-table class="mat-elevation-z8">
<div class="table" *ngIf="item.groupName=='单位概况'&&(element.surveyName=='单位基本信息'||element.surveyName=='建筑信息')">
<!-- <table mat-table [dataSource]='element.attinf' class="mat-elevation-z8">
<ng-container matColumnDef="name">
<th mat-header-cell *matHeaderCellDef style="width: 20%;">名称</th>
<td mat-cell *matCellDef="let element">111</td>
<td mat-cell *matCellDef="let attinf">{{attinf.addAttinfName}}</td>
</ng-container>
<ng-container matColumnDef="level">
<th mat-header-cell *matHeaderCellDef style="width: 20%;">类型</th>
<td mat-cell *matCellDef="let element">111</td>
<td mat-cell *matCellDef="let attinf">{{attinf.level}}</td>
</ng-container>
<ng-container matColumnDef="default">
<th mat-header-cell *matHeaderCellDef style="width: 10%;">默认值</th>
<td mat-cell *matCellDef="let element">111</td>
<td mat-cell *matCellDef="let attinf">{{attinf.default}}</td>
</ng-container>
<ng-container matColumnDef="must">
<th mat-header-cell *matHeaderCellDef style="width: 10%;">必填</th>
<td mat-cell *matCellDef="let element">111</td>
<td mat-cell *matCellDef="let attinf">{{attinf.must}}</td>
</ng-container>
<ng-container matColumnDef="danwei">
<th mat-header-cell *matHeaderCellDef style="width: 10%;">单位</th>
<td mat-cell *matCellDef="let element">111</td>
<td mat-cell *matCellDef="let attinf" >{{attinf.danwei}}</td>
</ng-container>
<ng-container matColumnDef="operation">
<th mat-header-cell *matHeaderCellDef style="width: 20%;">操作</th>
<td mat-cell *matCellDef="let element" style="white-space: nowrap;cursor: pointer;">
<span style="color: red;margin-left: 4px" > 删除</span>
<td mat-cell *matCellDef="let attinf" style="white-space: nowrap;cursor: pointer;">
<span style="color: red;margin-left: 4px"> 删除</span>
</td>
</ng-container>
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
</table> -->
<table cellspacing="0" cellpadding="0">
<thead>
<th style="width: 20%;">名称</th>
<th style="width: 20%;">类型</th>
<th style="width: 10%;">默认值</th>
<th style="width: 10%;">必填</th>
<th style="width: 10%;">单位</th>
<th style="width: 20%;">操作</th>
</thead>
<tbody>
<tr *ngFor="let attinf of element.attinf" >
<td *ngIf="attinf.completed" style="width: 20%;">{{attinf.addAttinfName}}</td>
<td *ngIf="attinf.completed" style="width: 20%;">{{attinf.level}}</td>
<td *ngIf="attinf.completed" style="width: 10%;">{{attinf.default}}</td>
<td *ngIf="attinf.completed" style="width: 10%;">{{attinf.must}}</td>
<td *ngIf="attinf.completed" style="width: 10%;">{{attinf.danwei}}</td>
<td *ngIf="attinf.completed" style="width: 20%;"><span style="color: #FF5D4A;margin-left: 4px"> 删除</span></td>
</tr>
</tbody>
</table>
</div>
</mat-expansion-panel>

7
src/app/ui/plan-template/plan-template.component.scss

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-05-19 15:50:20
* @LastEditors: sueRimn
* @LastEditTime: 2021-05-26 16:38:06
* @LastEditTime: 2021-05-28 13:52:54
*/
.box{
height: 97%;
@ -208,6 +208,11 @@
text-align: center;
background-color: #F7F8FA;
}
td{
height: 40px;
text-align: center;
font-size: 16px;
}
}
}
}

163
src/app/ui/plan-template/plan-template.component.ts

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-05-19 15:50:20
* @LastEditors: sueRimn
* @LastEditTime: 2021-05-26 16:58:15
* @LastEditTime: 2021-05-28 17:11:44
*/
import { Component, Inject, OnInit } from '@angular/core';
import { HttpClient } from '@angular/common/http'
@ -23,11 +23,12 @@ export class PlanTemplateComponent implements OnInit {
ngOnInit(): void {
}
//获取左侧单位信息
groupPanle=true//分组展开
attPanle=true
//获取所有单位信息
newleftTabledata=[
{name:"333",level:'Ⅲ级',unitid: "5e7c49e861550e2754d461ce",group:[]},//{groupName: "单位概况"}
{name:"444",level:'Ⅳ级',unitid: "5e7c49e861550e2754d461ce",group:[]}
{name:"333",level:3,basicCategoryId:"5e7c49e861550e2754d461ce",unitid: "5e7c8ffba3050b1a840ed4b6",unitname:'高层建筑',group:[]},//{groupName: "单位概况"}
{name:"444",level:5,basicCategoryId:"60127efe2757e904e5721d83",unitid: "5e7c9018a3050b1a840ed4b7",unitname:'地下建筑',group:[]}
]
group=[]
getLeftdata(){
@ -57,6 +58,7 @@ export class PlanTemplateComponent implements OnInit {
}
}
}
//console.log(this.newleftTabledata)
});
}
//删除预案
@ -71,26 +73,31 @@ export class PlanTemplateComponent implements OnInit {
upPlan(item,i){
const dialogRef = this.dialog.open(upPlanname, {//调用open方法打开对话框并且携带参数过去
width: '340px',
height:'330px',
height:'380px',
disableClose:true,
data:{item:item}
data:{item:item,plandata:this.newleftTabledata}
});
dialogRef.afterClosed().subscribe(result => {
console.log(result)
if(result!=undefined){
this.newleftTabledata[i].name=result.name
this.newleftTabledata[i].level=result.level
this.newleftTabledata[i].unitid=result.unitid
this.newleftTabledata[i].unitname=result.unitname
}
});
}
//左侧预案模板点击事件
planName
unitName
leftclicki=-1//点了第几个模板
planClick(item){
//console.log(item)
this.planName=item.name
this.unitName=item.unitname
this.newleftTabledata.forEach((value,index,array)=>{
if(array[index].name==this.planName){
if(array[index].unitname==this.unitName){
this.group=array[index].group
this.leftclicki=index
}
})
}
@ -159,6 +166,7 @@ export class PlanTemplateComponent implements OnInit {
}
//新增属性
addAttribute(groupName){
this.groupPanle=true
if(groupName=='单位概况'){
const dialogRef = this.dialog.open(adddwsurvey, {//调用open方法打开对话框并且携带参数过去
width: '240px',
@ -180,30 +188,71 @@ export class PlanTemplateComponent implements OnInit {
}
}
//删除具体属性
delAttribute(surveyName){
delAttribute(groupName,surveyName){
let isTrue = confirm('您确定要删除吗')
if(isTrue){
this.group.forEach((value,index,array)=>{
if (array[index].groupName==groupName) {
array[index].attribute.forEach((element,i) => {
if(element.surveyName==surveyName){
array[index].attribute[i].completed=false
}
});
}
})
}
console.log(this.newleftTabledata)
}
//新增属性信息
addAttInfo(){
danweiInfTable=[]
addAttInfo(surveyName){
this.attPanle=true
const dialogRef = this.dialog.open(addattinf, {//调用open方法打开对话框并且携带参数过去
width: '240px',
height:'400px',
disableClose:true,
data:this.group
data:{group:this.group,surveyName:surveyName}
});
dialogRef.afterClosed().subscribe(result => {
console.log(result)
//console.log(result)
if(result!=undefined){
/* this.group.forEach((value,index,array)=>{
if(array[index].groupName=='单位概况'){
array[index].attribute=result
}
}) */
this.newleftTabledata[this,this.leftclicki].group.forEach((value,index,array)=>{
if(value.groupName=='单位概况'){
array[index].attribute.forEach((element,i,attary) => {
if(element.surveyName==surveyName){
attary[i].attinf=result
}
});
}
})
this.group=this.newleftTabledata[this,this.leftclicki].group
//console.log(this.danweiInfTable)
}
console.log(this.newleftTabledata)
});
}
//保存
save(){
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
let body={
basicCategoryId:this.newleftTabledata[this.leftclicki].basicCategoryId,
buildingTypeId:this.newleftTabledata[this.leftclicki].unitid,
planCategory:Number(this.newleftTabledata[this.leftclicki].level),
data:{}
}
this.http.post("/api/PlanTemplate",body).subscribe((data:any)=>{
this.snackBar.open('创建成功!','确定',config);
console.log(data)
})
}
//单位基本信息和建筑信息表格
displayedColumns: string[] = ['name','level','default','must', 'danwei','operation'];
@ -216,18 +265,20 @@ export class PlanTemplateComponent implements OnInit {
})
export class addPlanname{
constructor(private http: HttpClient,public dialogRef: MatDialogRef<addPlanname>,@Inject(MAT_DIALOG_DATA) public data,public snackBar: MatSnackBar) {}
unitname//预案名称
planname//预案名称
level//预案级别
unittype//单位类型
unitid//单位类型id
unitname//单位类型名称
allunittype//所有单位信息
basicCategoryId
ngOnInit(): void {
this.getUnittype()
}
//获取单位类型
getUnittype(){
this.http.get("/api/BasicCategories").subscribe((data:any)=>{
this.http.get("/api/BuildingTypes").subscribe((data:any)=>{
this.allunittype=data
//console.log(data)
console.log(this.allunittype)
})
}
//取消按钮
@ -235,30 +286,40 @@ export class addPlanname{
this.dialogRef.close();
}
newplan(){
this.unitname=document.getElementById('unit').innerText
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
if(this.unitname==undefined||this.unitname==''){
if(this.planname==undefined||this.planname==''){
this.snackBar.open('请输入预案名称!','确定',config);
}
else if(this.level==undefined||this.level==''){
this.snackBar.open('请输入预案级别!','确定',config);
}else if(this.unittype==undefined||this.unittype==''){
}else if(this.unitid==undefined||this.unitid==''){
this.snackBar.open('请选择单位类型!','确定',config);
}
else{
for(var i=0;i<this.data.plandata.length;i++){
if(this.data.plandata[i].name==this.unitname){
this.snackBar.open('预案名称重复,请重新建立预案模板!','确定',config);
this.unitname==''
if(this.data.plandata[i].unitid==this.unitid&&this.data.plandata[i].level==this.level){
this.snackBar.open('预案模板重复,请重新建立预案模板!','确定',config);
this.planname==''
this.level==''
this.unittype==''
this.unitid==''
this.unitname==''
return
}
}
this.allunittype.forEach(element => {
if(element.id==this.unitid){
this.basicCategoryId=element.basicCategoryId
}
});
let planData={
name:this.unitname,
name:this.planname,
level:this.level,
unitid:this.unittype,
unitid:this.unitid,
unitname:this.unitname,
basicCategoryId:this.basicCategoryId,
group:[]
}
this.dialogRef.close(planData)
@ -273,11 +334,20 @@ export class addPlanname{
})
export class upPlanname{
constructor(private http: HttpClient,public dialogRef: MatDialogRef<addPlanname>,@Inject(MAT_DIALOG_DATA) public data,public snackBar: MatSnackBar) {}
unitname=this.data.item.name//预案名称
name=this.data.item.name//预案名称
level=this.data.item.level//预案级别
unitName=this.data.item.unitname//单位类型
unitid=this.data.item.unitid
allunittype
ngOnInit(): void{
/* this.unitname=this.data.name
this.level=this.data.level */
this.getUnittype()
}
//获取单位类型
getUnittype(){
this.http.get("/api/BuildingTypes").subscribe((data:any)=>{
this.allunittype=data
//console.log(this.allunittype)
})
}
//取消按钮
close(){
@ -285,18 +355,31 @@ export class upPlanname{
}
//确定按钮
upplan(){
this.unitName=document.getElementById('unit').innerText
const config = new MatSnackBarConfig();
config.verticalPosition = 'top';
config.duration = 3000
if(this.unitname==undefined||this.unitname==''){
if(this.name==undefined||this.name==''){
this.snackBar.open('请输入预案名称!','确定',config);
}
else if(this.level==undefined||this.level==''){
this.snackBar.open('请输入预案级别!','确定',config);
}else{
for(var i=0;i<this.data.plandata.length;i++){
if(this.data.plandata[i].unitid==this.unitid&&this.data.plandata[i].level==this.level){
this.snackBar.open('预案模板重复,请重新建立预案模板!','确定',config);
this.name==''
this.level==''
this.unitid==''
this.unitName==''
return
}
}
let planData={
name:this.unitname,
level:this.level
name:this.name,
level:this.level,
unitid:this.unitid,
unitname:this.unitName
}
this.dialogRef.close(planData)
}
@ -383,7 +466,7 @@ export class adddwsurvey{
{surveyName:'功能分区',completed:false},{surveyName:'行车路线',completed:false},{surveyName:'千米水源',completed:false},{surveyName:'实景图',completed:false}
]
ngOnInit(): void{
console.log(this.data)
//console.log(this.data)
this.data.forEach(element => {
if(element.groupName=='单位概况'&&element.attribute!=undefined){
this.addwsurvey=element.attribute
@ -399,7 +482,7 @@ defineClick(){
this.dialogRef.close(this.addwsurvey)
}
}
//编辑属性信息弹窗
//编辑单位概况单位基本信息属性信息弹窗
@Component({
selector: 'addattinf',
templateUrl: './addattinf.html',
@ -416,6 +499,18 @@ export class addattinf{
{addAttinfName:'单位地址',completed:false,level:'单行文本',default:'-',must:'是',danwei:'-'},
{addAttinfName:'单位照片',completed:false,level:'单行文本',default:'-',must:'是',danwei:'-'}
]
ngOnInit(): void{
//console.log(this.data)
this.data.group.forEach(element => {
if(element.groupName=='单位概况'&&element.attribute!=undefined){
element.attribute.forEach(value => {
if(this.data.surveyName=='单位基本信息'&&value.attinf!=undefined){
this.addAttinf=value.attinf
}
});
}
});
}
//取消按钮
close(){
this.dialogRef.close();

14
src/app/ui/plan-template/upPlan.html

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-05-21 10:43:28
* @LastEditors: sueRimn
* @LastEditTime: 2021-05-21 11:05:14
* @LastEditTime: 2021-05-28 10:44:56
-->
<!--
* @Descripttion:
@ -16,12 +16,12 @@
-->
<div class="box">
<div class="top">
<span style="font-size: 20px;">修改预案名称和级别</span>
<span style="font-size: 20px;">修改预案模板</span>
</div>
<div class="queryField">
<label style="margin-right: 10px;">预案名称:</label>
<mat-form-field class="example-full-width">
<input matInput placeholder="请输入预案名称" name="companyName" autocomplete="off" [(ngModel)]="unitname" required>
<input matInput placeholder="请输入预案名称" name="companyName" autocomplete="off" [(ngModel)]="name" required>
</mat-form-field>
</div>
@ -36,6 +36,14 @@
</mat-select>
</mat-form-field>
</div>
<div class="queryField">
<label style="margin-right: 10px;">单位类型:</label>
<mat-form-field>
<mat-select placeholder='请选择单位类型' name="unittype" [(ngModel)]="unitid" id="unit" required>
<mat-option *ngFor="let unit of allunittype" [value]="unit.id" >{{unit.name}}</mat-option>
</mat-select>
</mat-form-field>
</div>
<div class="bottom">
<button mat-raised-button color="primary" (click)='upplan()'>确定</button>
<button mat-raised-button style="margin-left: 50px;" (click)="close()">取消</button>

Loading…
Cancel
Save