Browse Source

[新增]预案模板复制功能

上海一张图
chenjingyu 4 years ago
parent
commit
47bd693002
  1. 16
      src/app/ui/plan-template/Disaster.html
  2. 30
      src/app/ui/plan-template/plan-template.component.html
  3. 52
      src/app/ui/plan-template/plan-template.component.scss
  4. 166
      src/app/ui/plan-template/plan-template.component.ts

16
src/app/ui/plan-template/Disaster.html

@ -4,7 +4,7 @@
* @Author: sueRimn
* @Date: 2021-06-02 15:15:15
* @LastEditors: sueRimn
* @LastEditTime: 2021-06-03 15:26:18
* @LastEditTime: 2021-06-08 10:30:36
-->
<div class="box">
<div class="top">
@ -17,7 +17,7 @@
<mat-option value=1>表格</mat-option>
<mat-option value=2>输入框</mat-option>
<mat-option value=3>文本区域</mat-option>
<mat-option value=5>树状图</mat-option>
<mat-option value=4>树状图</mat-option>
</mat-select>
</mat-form-field>
</div>
@ -27,12 +27,18 @@
<input matInput placeholder="请输入表头名称" [(ngModel)]="headName" autocomplete="off" required>
</mat-form-field>
</div>
<!-- <div class="queryField" *ngIf="level==1||level==2">
<div class="queryField" *ngIf="level==2">
<label style="margin-right: 10px;">列数:</label>
<mat-form-field class="example-full-width">
<input matInput type="number" [(ngModel)]="lieNumber" name="companyNumber" autocomplete="off" required min="1">
<input matInput type="number" [(ngModel)]="lieNumber" autocomplete="off" required min="1">
</mat-form-field>
</div> -->
</div>
<div class="queryField" *ngIf="level==2">
<label style="margin-right: 10px;">行数:</label>
<mat-form-field class="example-full-width">
<input matInput type="number" [(ngModel)]="hNumber" autocomplete="off" required min="1">
</mat-form-field>
</div>
<div class="bottom">
<button mat-raised-button color="primary" (click)='newdisaster()'>确定</button>
<button mat-raised-button style="margin-left: 50px;" (click)='close()'>取消</button>

30
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-06-03 17:15:15
* @LastEditTime: 2021-06-08 15:52:04
-->
<div class="box">
<div class="boxleft">
@ -24,7 +24,8 @@
</div>
<div class="bodycz">
<span>{{item.planCategory==3?'Ⅲ级':item.planCategory==4?'Ⅳ级':'Ⅴ级'}}</span>
<img [src]="item.buildingTypeId == buildingTypeId&&item.planCategory==planCategory? '../../../assets/images/update.png':'../../../assets/images/updatehui.png'" (click)='upPlan(item,i)'>
<span style="margin-left: 5px;" (click)='upPlan(item,i,"copy")'>复制</span>
<img [src]="item.buildingTypeId == buildingTypeId&&item.planCategory==planCategory? '../../../assets/images/update.png':'../../../assets/images/updatehui.png'" (click)='upPlan(item,i,"edit")'>
<img [src]="item.buildingTypeId == buildingTypeId&&item.planCategory==planCategory? '../../../assets/images/deleteblue.png':'../../../assets/images/deletehui.png'" (click)='deletePlan(item.id,i)'>
</div>
</div>
@ -43,7 +44,7 @@
<div class="rightbody">
<mat-accordion *ngFor="let item of group;let zi=index;TrackBy:trackByFn" multi>
<!-- 基本信息 -->
<mat-expansion-panel [expanded]='groupPanle==true' (opened)='groupPanle=true' *ngIf="item.completed" hideToggle style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;">
<mat-expansion-panel expanded (opened)='groupPanle=true' *ngIf="item.completed" style="box-shadow: 0 0 black;border: 1px solid #EEF1F5;" [disabled]='groupPanle==true'>
<mat-expansion-panel-header collapsedHeight='40px' expandedHeight='40px' class="panelhead">
<mat-panel-title class="paneltitle">
<div class="groupName">
@ -64,7 +65,7 @@
<!--单位概况-->
<div class="accordingin" *ngIf="item.groupName=='单位概况'">
<mat-accordion *ngFor="let element of item.attribute">
<mat-expansion-panel [expanded]='attPanle' *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%;" [disabled]='groupPanle==true'>
<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=='单位概况'">
@ -182,7 +183,7 @@
</div>
<div class="attackRight">
<div class="rightButton">
<button mat-raised-button color="primary" (click)='attackAdd(element.surveyName,i)'><img src="../../../assets/images/addbai.png"> 新增</button>
<button mat-raised-button color="primary" (click)='attackAdd(element.surveyName,i,8)'><img src="../../../assets/images/addbai.png"> 新增</button>
<button mat-raised-button color="#ECF6FF" style="margin-left: 10px;" (click)='delattAndfileOne(item.groupName,element.surveyName,i)'><img src="../../../assets/images/deletehui.png" > 删除</button>
</div>
</div>
@ -200,18 +201,29 @@
<input type="text" placeholder="请输入内容" [(ngModel)]="element.headName">
</div>
<div class="attackleftTable">
<table *ngIf="element.level==1||element.level==2">
<table *ngIf="element.level==1">
<thead>
<th *ngFor="let itemth of element.tableth;let tablethi=index;TrackBy:trackByFn"><input type="text" placeholder="请输入内容" [(ngModel)]="element.tableth[tablethi]"></th>
</thead>
</table>
<textarea *ngIf="element.level==3"></textarea>
<textarea *ngIf="element.level==3" [(ngModel)]="element.tableth"></textarea>
<div class="inputtext" *ngIf="element.level==2">
<div class="inputj" style="height: 100%;width: 100%;" *ngFor="let itemth of element.tableth;let tablethi=index;TrackBy:trackByFn">
<div style="height: 100%;width: 100%;" *ngFor="let itemthj of element.tableth[tablethi];let tablethj=index;TrackBy:trackByFn">
<input type="text" placeholder="请输入内容" style="background-color: #E8E9E9;width: 40%;" [(ngModel)]="itemthj.head">
<input type="text" placeholder="请输入内容" style="width: 60%;" [(ngModel)]="itemthj.body">
</div>
</div>
</div>
<div>
</div>
</div>
</div>
<div class="attackRight">
<div class="rightButton">
<button mat-raised-button color="primary"(click)='attackAdd(item.groupName,attributei)'*ngIf="element.level==1||element.level==2" ><img src="../../../assets/images/addbai.png"> 新增</button>
<button mat-raised-button color="#ECF6FF" style="margin-left: 10px;" ><img src="../../../assets/images/deletehui.png" (click)='delDisaster(attributei)'> 删除</button>
<button mat-raised-button color="primary"(click)='attackAdd(item.groupName,attributei,element.level)'*ngIf="element.level==1" ><img src="../../../assets/images/addbai.png"> 新增</button>
<button mat-raised-button color="#ECF6FF" style="margin-left: 10px;" (click)='delDisaster(attributei)'><img src="../../../assets/images/deletehui.png" > 删除</button>
</div>
</div>
</div>

52
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-06-03 16:57:21
* @LastEditTime: 2021-06-08 15:03:02
*/
.box{
height: 97%;
@ -72,7 +72,7 @@
cursor: pointer;
.bodyname{
height: 40px;
width: 70%;
width: 60%;
span{
font-size: 16px;
height: 40px;
@ -82,7 +82,7 @@
}
.bodycz{
height: 40px;
width: 30%;
width: 40%;
img{
margin-left: 10px;
cursor: pointer;
@ -148,6 +148,7 @@
width: 100px;
}
.addinfo{
cursor: pointer;
height: 100%;
width: 75px;
margin-left: 75%;
@ -157,6 +158,7 @@
}
}
.delinfo{
cursor: pointer;
height: 100%;
width: 75px;
span{
@ -262,6 +264,24 @@
textarea{
width: 100%;
}
.inputtext{
width: 100%;
height: 100%;
display: flex;
flex-direction: column;
input{
//width: 100%;
height: 40px;
font-size: 16px;
border: none;
outline: none;
}
.inputj{
width: 100%;
height: 100%;
display: flex;
}
}
}
}
.attackRight{
@ -282,4 +302,28 @@
}
::-webkit-scrollbar-thumb {
background-color: #2196f3;
}
}
.example-tree-invisible {
display: none;
}
.example-tree ul,
.example-tree li {
margin-top: 0;
margin-bottom: 0;
list-style-type: none;
}
/*
* This padding sets alignment of the nested nodes.
*/
.example-tree .mat-nested-tree-node div[role=group] {
padding-left: 40px;
}
/*
* Padding for leaf nodes.
* Leaf nodes need to have padding so as to align with other non-leaf nodes
* under the same parent.
*/
.example-tree div[role=group] > .mat-tree-node {
padding-left: 40px;
}

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

@ -4,29 +4,46 @@
* @Author: sueRimn
* @Date: 2021-05-31 10:40:01
* @LastEditors: sueRimn
* @LastEditTime: 2021-06-03 17:08:37
*/
/*
* @Descripttion:
* @version:
* @Author: sueRimn
* @Date: 2021-05-31 10:40:01
* @LastEditors: sueRimn
* @LastEditTime: 2021-06-02 09:22:24
*/
/*
* @Descripttion:
* @version:
* @Author: sueRimn
* @Date: 2021-05-19 15:50:20
* @LastEditors: sueRimn
* @LastEditTime: 2021-06-02 09:18:05
* @LastEditTime: 2021-06-08 15:33:13
*/
import { Component, Inject, OnInit } from '@angular/core';
import { HttpClient } from '@angular/common/http'
import { MatDialogRef, MatDialog, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
import {FlatTreeControl, NestedTreeControl} from '@angular/cdk/tree';
import {MatTreeFlatDataSource, MatTreeFlattener, MatTreeNestedDataSource} from '@angular/material/tree';
interface FoodNode {
name: string;
children?: FoodNode[];
}
const TREE_DATA: FoodNode[] = [
{
name: 'Fruit',
children: [
{name: 'Apple'},
{name: 'Banana'},
{name: 'Fruit loops'},
]
}, {
name: 'Vegetables',
children: [
{
name: 'Green',
children: [
{name: 'Broccoli'},
{name: 'Brussels sprouts'},
]
}, {
name: 'Orange',
children: [
{name: 'Pumpkins'},
{name: 'Carrots'},
]
},
]
},
];
@Component({
selector: 'app-plan-template',
templateUrl: './plan-template.component.html',
@ -34,7 +51,11 @@ import { MatSnackBar, MatSnackBarConfig } from '@angular/material/snack-bar';
})
export class PlanTemplateComponent implements OnInit {
constructor(private http:HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) { }
treeControl = new NestedTreeControl<FoodNode>(node => node.children);
dataSource = new MatTreeNestedDataSource<FoodNode>();
constructor(private http:HttpClient,public dialog: MatDialog,public snackBar: MatSnackBar) {
this.dataSource.data = TREE_DATA;
}
ngOnInit(): void {
this.getLeftdata()
@ -115,7 +136,7 @@ export class PlanTemplateComponent implements OnInit {
}
//修改模板
upPlan(item,i){
upPlan(item,i,operation){
const dialogRef = this.dialog.open(upPlanname, {//调用open方法打开对话框并且携带参数过去
width: '340px',
height:'340px',
@ -125,11 +146,25 @@ export class PlanTemplateComponent implements OnInit {
dialogRef.afterClosed().subscribe(result => {
if(result!=undefined){
//this.newleftTabledata[i].name=result.name
this.newleftTabledata[i].basicCategoryId=result.basicCategoryId
this.newleftTabledata[i].planCategory=result.planCategory
this.newleftTabledata[i].buildingTypeId=result.buildingTypeId
this.newleftTabledata[i].unitname=result.unitname
if(operation=='edit'){
this.newleftTabledata[i].basicCategoryId=result.basicCategoryId
this.newleftTabledata[i].planCategory=result.planCategory
this.newleftTabledata[i].buildingTypeId=result.buildingTypeId
this.newleftTabledata[i].unitname=result.unitname
}else{
let newdata={
basicCategoryId:result.basicCategoryId,
buildingTypeId:result.buildingTypeId,
data:item.data,
planCategory:result.planCategory,
unitname:result.unitname
}
this.newleftTabledata.push(newdata)
this.save()
}
}
console.log(this.newleftTabledata)
});
}
//左侧预案模板点击事件
@ -230,7 +265,7 @@ export class PlanTemplateComponent implements OnInit {
}else if(groupName=='灾情设定'){
const dialogRef = this.dialog.open(disaster, {//调用open方法打开对话框并且携带参数过去
width: '340px',
height:'400px',
height:'450px',
disableClose:true,
data:this.group
});
@ -245,7 +280,14 @@ export class PlanTemplateComponent implements OnInit {
}else{
array[index].attribute.push(result)
}
if(result.level==2){
for(var i=0;i<result.hNumber;i++){
array[index].attribute[array[index].attribute.length-1].tableth.push([{head:'',body:''}])
for(var j=0;j<result.lieNumber-1;j++){
array[index].attribute[array[index].attribute.length-1].tableth[i].push({head:'',body:''})
}
}
}
}
})
}
@ -334,28 +376,31 @@ export class PlanTemplateComponent implements OnInit {
}
//消防设施表格具体属性编辑
fileAdd(facilityItems,filei){
const dialogRef = this.dialog.open(addattinf, {//调用open方法打开对话框并且携带参数过去
width: '240px',
height:'400px',
disableClose:true,
data:{facilityItems:facilityItems}
});
dialogRef.afterClosed().subscribe(result => {
console.log(result)
if(result!=undefined){
this.newleftTabledata[this,this.leftclicki].data.forEach((value,index,array)=>{
if(value.groupName=='单位概况'){
array[index].attribute.forEach((element,i,attary) => {
if(element.surveyName=='消防设施'){
attary[i].attinf[filei].facilityItems=result
}
});
}
})
this.group=this.newleftTabledata[this,this.leftclicki].data
}
console.log(this.newleftTabledata)
});
if(facilityItems.length!=0){
const dialogRef = this.dialog.open(addattinf, {//调用open方法打开对话框并且携带参数过去
width: '240px',
height:'400px',
disableClose:true,
data:{facilityItems:facilityItems}
});
dialogRef.afterClosed().subscribe(result => {
console.log(result)
if(result!=undefined){
this.newleftTabledata[this,this.leftclicki].data.forEach((value,index,array)=>{
if(value.groupName=='单位概况'){
array[index].attribute.forEach((element,i,attary) => {
if(element.surveyName=='消防设施'){
attary[i].attinf[filei].facilityItems=result
}
});
}
})
this.group=this.newleftTabledata[this,this.leftclicki].data
}
console.log(this.newleftTabledata)
});
}
}
//消防设施表格具体属性删除
fileDel(i,f){
@ -368,12 +413,17 @@ export class PlanTemplateComponent implements OnInit {
//进攻通道
//进攻通道,灾情设定增加表格数据
attackAdd(name,i){
attackAdd(name,i,level){
//console.log(name,i)
if(name=='进攻通道'){
this.group[0].attribute[4].attinf[i].tableth.push('')
}else if(name=='灾情设定'){
this.group[1].attribute[i].tableth.push('')
if(level==1){
this.group[1].attribute[i].tableth.push('')
}else if(level==2){
this.group[1].attribute[i].tableth.push({head:'',body:''})
}
}
console.log(this.newleftTabledata)
}
@ -437,6 +487,9 @@ export class PlanTemplateComponent implements OnInit {
}
}
//树形结构
hasChild = (_: number, node: FoodNode) => !!node.children && node.children.length > 0;
//单位基本信息和建筑信息表格
displayedColumns: string[] = ['name','level','default','must', 'danwei','operation'];
@ -591,7 +644,7 @@ export class addGroup{
groupName=[]
ngOnInit(): void{
console.log(this.data)
if(this.data!=null){
if(this.data!=null||this.data.length>0){
this.addgtoup=this.data
}
@ -635,6 +688,7 @@ export class addGroup{
}
this.dialogRef.close(this.addgtoup)
}
}
//单位概况新增弹窗
@Component({
@ -730,9 +784,9 @@ getattinf(){
}else{
this.facilityItems=this.data.facilityItems
console.log(this.facilityItems)
this.facilityItems.forEach(element => {
/* this.facilityItems.forEach(element => {
element.completed=false
});
}); */
}
}
@ -761,6 +815,7 @@ export class disaster{
level//类型
headName//表头名称
lieNumber//列数
hNumber//行数
//取消按钮
close(){
this.dialogRef.close();
@ -778,8 +833,9 @@ export class disaster{
let attrubute={
headName:this.headName,
level:this.level,
tableth:[]
//lieNumber:this.lieNumber,
tableth:this.level==1||this.level==2?[]:this.level==3?'':'',
lieNumber:this.lieNumber,
hNumber:this.hNumber
}
this.dialogRef.close(attrubute);
}

Loading…
Cancel
Save