Browse Source

Merge branch 'master' of http://39.106.78.171:3000/shaojiahao/Sinopec-Anxin

# Conflicts:
#	src/app/pages/left-domain/left-domain.component.ts
dev
刘向辉 3 years ago
parent
commit
e85872c975
  1. 2
      package.json
  2. 2
      src/app/app-routing.module.ts
  3. 5
      src/app/babylon/controller/inputController.ts
  4. 8
      src/app/babylon/controller/mode-manager.ts
  5. 5
      src/app/babylon/controller/status/status-manager.ts
  6. 1
      src/app/babylon/game.ts
  7. 9
      src/app/babylon/model/data/institution/facility/property-data/in/property-data-sygx.ts
  8. 24
      src/app/babylon/model/data/institution/facility/property-data/in/property-data-yqhsgx.ts
  9. 7
      src/app/babylon/tool/gizmo-tool.ts
  10. 3
      src/app/babylon/view/building-window/building-ui-item.ts
  11. 2
      src/app/babylon/view/building-window/building-window.ts
  12. 46
      src/app/babylon/view/facilityinfoinscene-window/facilityinfoinscene-window.ts
  13. 2
      src/app/pages/criminal-records-admin/criminal-records-admin.component.ts
  14. 27
      src/app/pages/criminal-records/criminal-records.component.html
  15. 101
      src/app/pages/criminal-records/criminal-records.component.scss
  16. 183
      src/app/pages/criminal-records/criminal-records.component.ts
  17. 30
      src/app/pages/home/home.component.html
  18. 45
      src/app/pages/home/home.component.scss
  19. 36
      src/app/pages/home/home.component.ts
  20. 55
      src/app/pages/left-domain/left-domain.component.html
  21. 4
      src/app/pages/left-domain/left-domain.component.scss
  22. 6
      src/app/pages/left-domain/left-domain.component.ts
  23. 6
      src/app/pages/login/login.component.html
  24. 2
      src/app/pages/login/login.component.scss
  25. 28
      src/app/pages/login/login.component.ts
  26. 2
      src/app/pages/oil-station-info/oil-station-info.component.html
  27. 26
      src/app/pages/oil-station-info/oil-station-info.component.ts
  28. 9
      src/app/pages/pages-routing.module.ts
  29. 19
      src/app/pages/pages.module.ts
  30. 128
      src/app/pages/plan-admin/plan-admin.component.html
  31. 137
      src/app/pages/plan-admin/plan-admin.component.scss
  32. 70
      src/app/pages/plan-admin/plan-admin.component.ts
  33. 57
      src/app/pages/plan/plan.component.html
  34. 85
      src/app/pages/plan/plan.component.scss
  35. 37
      src/app/pages/plan/plan.component.ts
  36. 15
      src/app/pages/plan/publicPop.scss
  37. 19
      src/app/pages/today-warning-admin/today-warning-admin.component.html
  38. 3
      src/app/pages/today-warning-admin/today-warning-admin.component.scss
  39. 30
      src/app/pages/today-warning-admin/today-warning-admin.component.ts
  40. 23
      src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.html
  41. 61
      src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.scss
  42. 20
      src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.ts
  43. 18
      src/app/pages/today-warning/today-warning.component.html
  44. 19
      src/app/pages/today-warning/today-warning.component.scss
  45. 78
      src/app/pages/today-warning/today-warning.component.ts
  46. 11
      src/app/system-management/analysis-of-the-host/addhost/addhost.component.html
  47. 3
      src/app/system-management/analysis-of-the-host/addhost/addhost.component.scss
  48. 21
      src/app/system-management/analysis-of-the-host/addhost/addhost.component.ts
  49. 70
      src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.html
  50. 92
      src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.scss
  51. 108
      src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.ts
  52. 1
      src/app/system-management/analysis-of-the-host/edithost/edithost.component.html
  53. 0
      src/app/system-management/analysis-of-the-host/edithost/edithost.component.scss
  54. 15
      src/app/system-management/analysis-of-the-host/edithost/edithost.component.ts
  55. 1
      src/app/system-management/navigation/navigation.component.html
  56. 4
      src/app/system-management/navigation/navigation.component.ts
  57. 4
      src/app/system-management/system-management-routing.module.ts
  58. 7
      src/app/system-management/system-management.module.ts
  59. 4
      src/app/ui/tabbar/tabbar.component.html
  60. 7
      src/app/ui/tabbar/tabbar.component.ts
  61. BIN
      src/assets/images/expand.png
  62. BIN
      src/assets/images/icon/host.png
  63. BIN
      src/assets/images/point.png
  64. BIN
      src/assets/images/stepIcon.png
  65. BIN
      src/assets/images/unexpand.png
  66. BIN
      src/assets/images/uploadImg.png
  67. BIN
      src/assets/images/uploadVideo.png
  68. BIN
      src/assets/images/warningnum.png
  69. 22
      src/styles.scss
  70. 56
      src/theme.less

2
package.json

@ -4,7 +4,7 @@
"scripts": {
"ng": "ng",
"start": "ng serve --proxy-config proxy.config.json --open --port 4000 ",
"build": "ng build --prod",
"build": "node --max_old_space_size=5048 ./node_modules/@angular/cli/bin/ng build --prod",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"

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

@ -16,7 +16,7 @@ const routes: Routes = [
{ path: 'register', component: RegisterComponent }, //注册页
{
path: '', component: HomeComponent, children: [
{ path: 'home', loadChildren: () => import('./pages/pages.module').then(m => m.PagesModule) }
{ path: '', loadChildren: () => import('./pages/pages.module').then(m => m.PagesModule) }
]
}, //首页
{

5
src/app/babylon/controller/inputController.ts

@ -1304,8 +1304,11 @@ export class Keyboard {
private constructor() {
// 添加快捷键
document.addEventListener('keydown', (e: KeyboardEvent) => {
if (e.key == null) {
return;
}
let key = e.key.toLocaleLowerCase();
console.log(key);
// console.log(key);
if (key == "w" && e.shiftKey) {
this.W = true;
} else if (key == "w") {

8
src/app/babylon/controller/mode-manager.ts

@ -18,17 +18,17 @@ export class ModeManager {
*
* 使 currentMode 访
*/
private static s_currentMode: ModeType = ModeType.Edit;
private static s_currentMode: ModeType = ModeType.Look;
/**
*
*/
public static s_isMakeMode = true;
public static s_isMakeMode = false;
/**
*
*/
public static isDebug = true;
public static isDebug = false;
@ -63,7 +63,7 @@ export class ModeManager {
*/
static set currentMode(modeType: ModeType) {
ModeManager.s_currentMode = modeType;
ModeManager.log("currentMode" + modeType);
}
//封装打印

5
src/app/babylon/controller/status/status-manager.ts

@ -54,6 +54,11 @@ export class StatusManager {
newStatus.onEnter();
return newStatus;
}
static dispose() {
StatusManager.s_allStatus = [];
StatusManager.s_currentStatus = null;
}
}

1
src/app/babylon/game.ts

@ -54,6 +54,7 @@ export class Game {
dispose() {
SceneManager.Instance.dispose();
StatusManager.dispose();
this.scene.dispose()
this.scene = null;
this.engine.dispose();

9
src/app/babylon/model/data/institution/facility/property-data/in/property-data-sygx.ts

@ -4,21 +4,22 @@ import { PropertyData_Base_IMG } from "../base/property-data-base-img";
import { PropertyData_Base } from "../property-data-base";
/**
*
* 线
*/
export class PropertyData_SYGX extends PropertyData_Base_IMG {
constructor(key: string) {
super(key, "", "", "", FacilityType.JY_SYGX);
super(key, "", "", "", FacilityType.JY_SYGX);
this.name = "未命名";
}
clone(key: string) {
let result = new PropertyData_SYGX(key);
result.name = this.name;
result.img = this.img;
result.pos = this.pos;
result.info = this.info,
result.is360 = this.is360;
result.is360 = this.is360;
return result;
}

24
src/app/babylon/model/data/institution/facility/property-data/in/property-data-yqhsgx.ts

@ -4,22 +4,28 @@ import { PropertyData_Base_IMG } from "../base/property-data-base-img";
import { PropertyData_Base } from "../property-data-base";
/**
*
* 线
*/
export class PropertyData_YQHSGX extends PropertyData_Base_IMG {
VRUType: string = ""; //油气回收系统类型
VRUPumpType: string = ""; //油气回收泵类型
constructor(key: string) {
super(key, "", "", "", FacilityType.JY_YQHSGX);
super(key, "", "", "", FacilityType.JY_YQHSGX);
this.name = "未命名";
}
clone(key: string) {
let result = new PropertyData_YQHSGX(key);
result.img = this.img;
result.pos = this.pos;
result.info = this.info,
result.is360 = this.is360;
return result;
let result = new PropertyData_YQHSGX(key);
result.name = this.name;
result.VRUType = this.VRUType;
result.VRUPumpType = this.VRUPumpType;
result.img = this.img;
result.pos = this.pos;
result.info = this.info,
result.is360 = this.is360;
return result;
}
}

7
src/app/babylon/tool/gizmo-tool.ts

@ -83,6 +83,10 @@ export class GizmoTool {
GizmoTool.onTransformUITypeChange(TransformUIType.Hide);
}
static dispose() {
}
static onBeforeRender(
eventData: Scene,
eventState: EventState
@ -195,7 +199,7 @@ export class GizmoTool {
//改变Gizmo目标
static changeGizmoAim(mesh: AbstractMesh, x: boolean = true, y = true, z = true) {
console.trace("改变gizmo");
GizmoTool.s_nowPickAim_mesh = mesh;
GizmoTool.s_gizmoManager.attachToMesh(mesh);
GizmoTool.s_gizmoManager.gizmos.positionGizmo.xGizmo.isEnabled = x;
@ -427,6 +431,7 @@ export class GizmoTool {
if (uiType == TransformUIType.Hide || !ModeManager.s_isMakeMode) { //隐藏选中框
GizmoTool.s_boundingBoxGizmo.attachedMesh = null;
}
}

3
src/app/babylon/view/building-window/building-ui-item.ts

@ -3,6 +3,7 @@
import { AbstractMesh, Mesh, TransformNode } from "@babylonjs/core";
import { ConfigManager } from "../../controller/config-manager";
import { InfoManager } from "../../controller/info-manager";
import { ModeManager, ModeType } from "../../controller/mode-manager";
import { SceneManager } from "../../controller/scene-manager";
import { IndoorStatus } from "../../controller/status/indoor-status";
import { StatusManager } from "../../controller/status/status-manager";
@ -161,7 +162,7 @@ export class BuildingUIItem {
*/
onSelect(select: boolean, animMove = true) {
if (select) {
if (this.buildingInfo.ModelInfo != null && this.buildingInfo.ModelInfo.modelBox != null) {
if (this.buildingInfo.ModelInfo != null && this.buildingInfo.ModelInfo.modelBox != null && ModeManager.currentMode == ModeType.Edit) {
GizmoTool.onPickMeshInfoObservable.notifyObservers(this.buildingInfo.ModelInfo);
//BabylonTool.changeCameraTarget(SceneManager.Instance.defaultCamera, this.buildingInfo.ModelInfo.modelBox, animMove);
}

2
src/app/babylon/view/building-window/building-window.ts

@ -372,7 +372,7 @@ export class BuildingWindow extends UIBase {
}
}
console.log("选中建筑", modelInfo);
// console.log("选中建筑", modelInfo);
this.showJYZModules(JYZInfoMoudleType.AQSS, false);
this.showJYZModules(JYZInfoMoudleType.YQHSGX, false);
this.showJYZModules(JYZInfoMoudleType.YQHSGX, false);

46
src/app/babylon/view/facilityinfoinscene-window/facilityinfoinscene-window.ts

@ -178,31 +178,31 @@ export class FacilityInfoInSceneWindow extends UIBase {
*/
showFacilityByType(facilityType: FacilityType, show: boolean) {
if (ModeManager.currentMode == ModeType.Look) {
for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
if (facilityType == null || facilityType == l_facilityData.facilityType) {
this.facilityInfoUIItemes[i].modelInfo.setEnable(show);
}
else if (show) {
this.facilityInfoUIItemes[i].modelInfo.setEnable(false);
}
}
// for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
// let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
// if (facilityType == null || facilityType == l_facilityData.facilityType) {
// this.facilityInfoUIItemes[i].modelInfo.setIconEnable(show);
// }
// }
}
else {
for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
if (facilityType == null || facilityType == l_facilityData.facilityType) {
this.facilityInfoUIItemes[i].modelInfo.setIconEnable(show);
}
// if (ModeManager.currentMode == ModeType.Look) {
// for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
// let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
// if (facilityType == null || facilityType == l_facilityData.facilityType) {
// this.facilityInfoUIItemes[i].modelInfo.setEnable(show);
// }
// else if (show) {
// this.facilityInfoUIItemes[i].modelInfo.setEnable(false);
// }
// }
// // for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
// // let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
// // if (facilityType == null || facilityType == l_facilityData.facilityType) {
// // this.facilityInfoUIItemes[i].modelInfo.setIconEnable(show);
// // }
// // }
// }
// else {
for (let i = 0; i < this.facilityInfoUIItemes.length; i++) {
let l_facilityData = (this.facilityInfoUIItemes[i].modelInfo.modelData) as ModelData_facility;
if (facilityType == null || facilityType == l_facilityData.facilityType) {
this.facilityInfoUIItemes[i].modelInfo.setIconEnable(show);
}
}
// }
}

2
src/app/pages/criminal-records-admin/criminal-records-admin.component.ts

@ -304,7 +304,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
list: any = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
look() {
this.router.navigate(['home/records/petrolStation'])
this.router.navigate(['/records/petrolStation'])
}

27
src/app/pages/criminal-records/criminal-records.component.html

@ -57,8 +57,29 @@
<app-title [name]="'违规类型统计'"></app-title>
</div>
<div class="chartsbox">
<div class="charts">
<div class="chart">
<div class="leftbox">
<span class="chartname">
<img src="../../../assets/images/flower.png" alt="">
违规事件统计
</span>
<div class="centerContent">
<div class="numname">违规事件总数</div>
<div class="num">206</div>
</div>
<div class="piechart" id="piechart">
</div>
</div>
<div class="rightbox">
<span class="chartname">
<img src="../../../assets/images/flower.png" alt="">
违规趋势
</span>
<div class="barchart" id="barchart">
</div>
</div>
</div>
</div>
@ -102,7 +123,7 @@
加油区2号摄像头
</div>
<div nz-col nzSpan="4">
2021-10-12 09:28:13
2021-10-12 09:28:13
</div>
<div nz-col nzSpan="2">
<span class="look">查看</span>
@ -117,4 +138,4 @@
</div>
</div>
</div>
</div>
</div>

101
src/app/pages/criminal-records/criminal-records.component.scss

@ -10,7 +10,7 @@
padding: 0 36px;
width: 100%;
height: 32px;
margin: 20px 0px;
margin-top: 14px;
form {
width: 100%;
@ -47,7 +47,7 @@
overflow: hidden;
.title {
margin-bottom: 15px;
margin: 13px 0;
width: 100%;
height: 64px;
box-sizing: border-box;
@ -59,10 +59,99 @@
display: flex;
justify-content: center;
.charts {
width: 98%;
height: 300px;
border: 1px solid white;
.chart {
width: 97%;
height: 360px;
border: 0px;
box-shadow: 0 0 26px 0px #1a7fd7 inset;
box-sizing: border-box;
padding: 18px 26px;
display: flex;
div {
display: flex;
flex-direction: column;
span {
font-family: titlefont;
display: flex;
align-items: center;
height: 28px;
color: #bee1ff;
font-size: 16px;
}
div {
flex: 1;
}
.piechart {}
.barchart {
// border: 1px solid rgba(145, 204, 255, 0.95);
}
}
.leftbox {
width: 360px;
position: relative;
.centerContent {
position: absolute;
top: 42%;
left: 11%;
width: 170px;
div {
text-align: center;
}
.numname {
font-family: titlefont;
color: #bee1ff;
}
.num {
color: #FFFFFF;
font-size: 42px;
text-shadow: 0px 0px 16px #3A9AFF;
font-weight: bold;
height: 49px;
line-height: 50px;
}
}
}
.rightbox {
flex: 1;
position: relative;
.btnbox {
position: absolute;
right: 5px;
top: 5px;
display: flex;
flex-direction: row;
z-index: 999;
button {
border: 1px solid #91CCFF;
color: #91CCFF;
border-radius: 0px;
box-shadow: 0 0 5px 0 #2399FF inset;
background: none;
}
.rankingBtn {
margin-right: 16px;
}
.selectedbtn {
background: linear-gradient(180deg, #000D21 0%, #001331 27%, #2399FF 100%);
color: white;
}
}
}
}
}

183
src/app/pages/criminal-records/criminal-records.component.ts

@ -1,5 +1,6 @@
import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import * as echarts from 'echarts';
@Component({
selector: 'app-criminal-records',
templateUrl: './criminal-records.component.html',
@ -8,7 +9,120 @@ import { FormBuilder, FormGroup, Validators } from '@angular/forms';
export class CriminalRecordsComponent implements OnInit {
validateForm!: FormGroup;
constructor(private fb: FormBuilder) { }
mybarChart: any //柱状图
baroption = {
xAxis: {
type: 'category',
data: this.getThirtyDays(),
axisLine: {
show: false,
lineStyle: {
color: '#91CCFF'
}
},
axisTick: {//刻度线
show: false
}
},
yAxis: {
type: 'value',
nameTextStyle: {
color: '#C4E2FC'
},
splitLine: {//分割线
lineStyle: {
color: ['#0f4374'],
width: 2
}
},
axisTick: {//刻度线
show: false
},
axisLine: {//轴线
show: false,
lineStyle: {
color: '#C4E2FC'
}
}
},
series: [
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
type: 'bar',
itemStyle: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0, color: '#23F0FF' // 0% 处的颜色
}, {
offset: 1, color: 'rgba(35, 153, 255, 0.1)' // 100% 处的颜色
}],
global: false // 缺省为 false
}
},
barWidth: '25%'
},
{
data: [120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 120, 200, 150, 80, 70, 110, 130, 100, 101],
type: 'line',
symbol: 'circle',
symbolSize: 8,
itemStyle: {
color: '#fff',
shadowColor: '#fff',
shadowBlur: 10
},
lineStyle: {
color: '#FFCC8A',
width: 1
}
}
],
grid: {
left: '36px',
right: '30px',
bottom: '50px',
top: '45px'
}
};
getThirtyDays() {
//获取当前日期
let myDate = new Date();
var nowY = myDate.getFullYear();
var nowM = myDate.getMonth() + 1;
var nowD = myDate.getDate();
var enddateStr = nowY + "-" + (nowM < 10 ? "0" + nowM : nowM) + "-" + (nowD < 10 ? "0" + nowD : nowD);//当前日期
var enddate = new Date(enddateStr);
//获取三十天前日期
var lw = new Date(new Date().getTime() - 1000 * 60 * 60 * 24 * 30);//最后一个数字30可改,30天的意思
var lastY = lw.getFullYear();
var lastM = lw.getMonth() + 1;
var lastD = lw.getDate();
var startdateStr = lastY + "-" + (lastM < 10 ? "0" + lastM : lastM) + "-" + (lastD < 10 ? "0" + lastD : lastD);//三十天之前日期
var startDate = new Date(startdateStr);
const dateList = []
while (true) {
startDate.setDate(startDate.getDate() + 1)
if (startDate.getTime() <= enddate.getTime()) {
if (startDate.getDate() < 10) {
// startDate.getFullYear() 获取年,此处没加上年份
dateList.push((startDate.getMonth() + 1) + '.0' + startDate.getDate())
} else {
dateList.push((startDate.getMonth() + 1) + '.' + startDate.getDate())
}
} else {
break
}
}
return dateList;
}
ngOnInit(): void {
this.validateForm = this.fb.group({
level: [null],
@ -16,6 +130,75 @@ export class CriminalRecordsComponent implements OnInit {
site: [null],
datePicker: [null]
});
// 基于准备好的dom,初始化echarts实例
let myChart = echarts.init(document.getElementById('piechart'));
let option = {
color: ['#FF4B65', '#23D9FF', '#608AFF', '#B2FF6D', '#FFFF99', '#C4E2FC', '#FF7F00', '#0090FF', '#FFD634', '#105597', '#FF4B65', '#23D9FF', '#71FFF5', '#B2FF6D'],
tooltip: {
trigger: 'item'//触发类型
},
series: [
{
// name: 'Access From',
type: 'pie',
radius: [85, 112],//内半径外,外半径
left: '-30%',
avoidLabelOverlap: false,//防止标签重叠策略
label: {//每一个标签外网延伸的引导说明
show: false,
position: 'outside'
},
labelLine: {//引导线
show: true,
showAbove: true
},
emphasis: {//中间高亮区域
label: {
show: false,
fontSize: '40',
fontWeight: 'bold'
}
},
data: [
{ value: 26, name: '工作人员倚靠加油机或者立柱1' },
{ value: 86, name: '工作人员倚靠加油机或者立柱2' },
{ value: 34, name: '工作人员倚靠加油机或者立柱3' },
{ value: 55, name: '工作人员倚靠加油机或者立柱4' },
{ value: 60, name: '工作人员倚靠加油机或者立柱5' },
{ value: 26, name: '工作人员倚靠加油机或者立柱6' },
{ value: 86, name: '工作人员倚靠加油机或者立柱7' },
{ value: 34, name: '工作人员倚靠加油机或者立柱8' },
{ value: 55, name: '工作人员倚靠加油机或者立柱9' },
{ value: 60, name: '工作人员倚靠加油机或者立柱10' },
{ value: 26, name: '工作人员倚靠加油机或者立柱11' },
{ value: 86, name: '工作人员倚靠加油机或者立柱12' },
{ value: 34, name: '工作人员倚靠加油机或者立柱13' },
{ value: 55, name: '工作人员倚靠加油机或者立柱14' },
{ value: 60, name: '工作人员倚靠加油机或者立柱15' },
{ value: 26, name: '工作人员倚靠加油机或者立柱16' },
{ value: 86, name: '工作人员倚靠加油机或者立柱17' },
{ value: 34, name: '工作人员倚靠加油机或者立柱18' },
{ value: 55, name: '工作人员倚靠加油机或者立柱19' },
{ value: 60, name: '工作人员倚靠加油机或者立柱20' }
],
tooltip: {//鼠标移入提示
position: 'right',
padding: [14, 19],
backgroundColor: 'rgba(28, 129, 218, 0.4)',
textStyle: {
color: '#fff',
fontSize: 12
}
}
}
]
};
// 绘制图表
myChart.setOption(option);
this.mybarChart = echarts.init(document.getElementById('barchart'));
this.mybarChart.setOption(this.baroption);
}
submitForm(): void {
for (const i in this.validateForm.controls) {

30
src/app/pages/home/home.component.html

@ -3,21 +3,33 @@
<app-tabbar></app-tabbar>
</div>
<div class="menu">
<li [routerLink]="['/home/plan']" routerLinkActive="router-link-active">
三维预案
<li *ngIf="!isGasStationNav" [routerLink]="['/plan']" routerLinkActive="router-link-active">
站点预案
</li>
<li [routerLink]="['/home/warning/admin']" routerLinkActive="router-link-active">
<li *ngIf="!isGasStationNav" [routerLink]="['/warning']" routerLinkActive="router-link-active">
今日预警
</li>
<li [routerLink]="['/home/records/admin']" routerLinkActive="router-link-active">
<li *ngIf="!isGasStationNav" [routerLink]="['/records']" routerLinkActive="router-link-active">
违规记录
</li>
<!-- <li [routerLink]="['/home/equipmentInfo']" routerLinkActive="router-link-active">
器材信息
<li *ngIf="isGasStationNav" [routerLink]="['/plan/petrolStation']" routerLinkActive="router-link-active">
三维预案
</li>
<li *ngIf="isGasStationNav" [routerLink]="['/warning/petrolStation']" routerLinkActive="router-link-active">
今日预警
</li>
<li *ngIf="isGasStationNav" [routerLink]="['/records/petrolStation']" routerLinkActive="router-link-active">
违规记录
</li>
<li [routerLink]="['/home/oliStationInfo']" routerLinkActive="router-link-active">
基本信息
</li> -->
<div class="backbtn" *ngIf="isGasStation">
<button nz-button (click)="goback()">返回</button>
</div>
<div class="warningnumber" *ngIf="isWarning">
<img src="../../../assets/images/warningnum.png" alt="">
<span class="num">39</span>
<span class="today">今日违规</span>
</div>
</div>
<div class="content">
<router-outlet></router-outlet>

45
src/app/pages/home/home.component.scss

@ -16,6 +16,7 @@
font-size: 17px;
background: url('../../../assets/images/navbg.png') no-repeat;
background-size: 100% 100%;
position: relative;
li {
width: 10%;
@ -26,6 +27,50 @@
font-family: sybold;
color: #EBFAFF;
}
}
.backbtn {
position: absolute;
right: 26px;
bottom: 6px;
button {
width: 64px;
height: 32px;
background: rgba(0, 129, 255, 0.3);
border: 1px solid #36A2FF;
border-radius: 0px;
color: #91CCFF;
}
}
.warningnumber {
position: absolute;
left: 20px;
top: 0;
display: flex;
align-items: flex-start;
img {
margin-bottom: 30px;
}
.num {
font-size: 50px;
text-shadow: 0px 0px 6px #8df;
color: white;
font-weight: 600;
margin-top: -5px;
}
.today {
font-size: 19px;
font-family: titlefont;
color: #D0EAFF;
margin-top: 11px;
margin-left: 10px;
}
}
.content {

36
src/app/pages/home/home.component.ts

@ -1,5 +1,7 @@
import { Component, OnInit } from '@angular/core';
import { Router, NavigationEnd, ActivatedRoute } from '@angular/router';
import { Title } from '@angular/platform-browser'
import { filter } from 'rxjs/operators';
@Component({
selector: 'app-home',
templateUrl: './home.component.html',
@ -7,9 +9,37 @@ import { Component, OnInit } from '@angular/core';
})
export class HomeComponent implements OnInit {
constructor() { }
constructor(private router: Router) { }
isGasStationNav: boolean
isGasStation: boolean
isWarning: boolean = false//是否是今日预警页面
ngOnInit(): void {
if(sessionStorage.getItem('isGasStation') == 'true'){
this.isGasStationNav = true
}else{
this.isGasStationNav = false
}
this.router.events.pipe(
filter(event => event instanceof NavigationEnd)
).subscribe((event: any) => {
if (event.url.indexOf('warning') != -1) {//控制今日预警左上角数字显示
this.isWarning = true
} else {
this.isWarning = false
}
if (event.url.indexOf('petrolStation') != -1 && sessionStorage.getItem('isGasStation') == 'false') {//控制返回按钮显示
this.isGasStation = true
}else{
this.isGasStation = false
}
});
}
goback(){
history.go(-1)
}
}

55
src/app/pages/left-domain/left-domain.component.html

@ -49,7 +49,7 @@
</div>
<!-- 加油机 -->
<!-- 油罐设备 -->
<div class="publicBox refueller oilTank" *ngIf="beforeFence === 2">
<div class="publicBox refueller" *ngIf="beforeFence === 2">
<div class="interval" *ngFor="let item of FacilityList" (click)="selectFacility(item)">
<!-- 选中样式 -->
<div class="positionLeftTop" *ngIf="selectFacilityId === item.getID()"></div><div class="positionLeftBottom" *ngIf="selectFacilityId === item.getID()"></div>
@ -91,6 +91,59 @@
</ng-template>
</div>
<!-- 消防设施 -->
<!-- 输油管线 -->
<div class="publicBox refueller" *ngIf="beforeFence === 5">
<div class="interval" *ngFor="let item of FacilityList" (click)="selectFacility(item)">
<!-- 选中样式 -->
<div class="positionLeftTop" *ngIf="selectFacilityId === item.getID()"></div><div class="positionLeftBottom" *ngIf="selectFacilityId === item.getID()"></div>
<div class="positionRightTop" *ngIf="selectFacilityId === item.getID()"></div><div class="positionRightBottom" *ngIf="selectFacilityId === item.getID()"></div>
<!-- 选中样式 -->
<p class="title"><input type="text" class="tableInput" [(ngModel)]="item.getPropertyData().name"></p>
<div class="table">
<div class="tableHeader">
<p class="tableImg">图片</p>
</div>
<div class="tableContent">
<p class="tableImg">
<img *ngIf="item.getPropertyData().img" [src]="item.getPropertyData().img">
<a href="javascript:;" class="bottomPlanUpload uploadImgBox" [ngStyle]="{'float': item.getPropertyData().img? 'right' : 'left'}"><input type="file"><i nz-icon nzType="plus" nzTheme="outline"></i></a>
</p>
</div>
</div>
</div>
</div>
<!-- 输油管线 -->
<!-- 油气回收 -->
<div class="publicBox refueller" *ngIf="beforeFence === 6">
<div class="interval" *ngFor="let item of FacilityList" (click)="selectFacility(item)">
<!-- 选中样式 -->
<div class="positionLeftTop" *ngIf="selectFacilityId === item.getID()"></div><div class="positionLeftBottom" *ngIf="selectFacilityId === item.getID()"></div>
<div class="positionRightTop" *ngIf="selectFacilityId === item.getID()"></div><div class="positionRightBottom" *ngIf="selectFacilityId === item.getID()"></div>
<!-- 选中样式 -->
<p class="title"><input type="text" class="tableInput" [(ngModel)]="item.getPropertyData().name"></p>
<div class="table">
<div class="tableHeader">
<p>油气回收系统类型</p>
<p>油气回收泵类型</p>
<p class="tableImg">图片</p>
</div>
<div class="tableContent">
<p style="padding-left: 8px;">
<nz-select class="tableSelect" [nzBorderless]="true" [nzDisabled]="!editModel" [(ngModel)]="item.getPropertyData().VRUType">
<nz-option nzValue="fss" nzLabel="分散式"></nz-option>
<nz-option nzValue="jzs" nzLabel="集中式"></nz-option>
</nz-select>
</p>
<p><input type="text" class="tableInput" [disabled]="!editModel" [(ngModel)]="item.getPropertyData().VRUPumpType"></p>
<p class="tableImg">
<img *ngIf="item.getPropertyData().img" [src]="item.getPropertyData().img">
<a href="javascript:;" class="bottomPlanUpload uploadImgBox" [ngStyle]="{'float': item.getPropertyData().img? 'right' : 'left'}"><input type="file"><i nz-icon nzType="plus" nzTheme="outline"></i></a>
</p>
</div>
</div>
</div>
</div>
<!-- 油气回收 -->
<!-- 处置预案 -->
<div class="publicBox disposalPlan" *ngIf="beforeFence === 7 && allMarkPlanData">
<div class="interval" *ngFor="let item of allMarkPlanData.datas;let key = index;">

4
src/app/pages/left-domain/left-domain.component.scss

@ -58,6 +58,7 @@
border-bottom: none;
display: flex;
p{ height: 32px; line-height: 32px; margin: 0px; }
.tableImg{ height: 120px; line-height: 120px; img{ max-height: 100px; width: auto; }.uploadImgBox{ margin: 35px 0 0 0; width: 50px; height: 50px; line-height: 50px; text-align: center; } }
.tableHeader{
flex: 4;
text-align: right;
@ -71,9 +72,6 @@
}
}
}
// .oilTank{ //油管设备
// }
.fireFacilities{ //消防设施
.treeRow{ width: 100%; display: flex; height: 30px; line-height: 30px; p:first-child{ flex: 1; }; p{ margin: 0; padding: 0; .anticon{ margin-right: 5px; font-size: 16px; } } }
}

6
src/app/pages/left-domain/left-domain.component.ts

@ -15,7 +15,7 @@ import { ModeManager, ModeType } from 'src/app/babylon/controller/mode-manager';
@Component({
selector: 'app-left-domain',
templateUrl: './left-domain.component.html',
styleUrls: ['./left-domain.component.scss']
styleUrls: ['./left-domain.component.scss', '../plan/publicPop.scss']
})
export class LeftDomainComponent implements OnInit {
@ -58,6 +58,10 @@ export class LeftDomainComponent implements OnInit {
item.getType() === "JY_YG" ? list.push(item) : null
} else if (this.beforeFence === 3) { //消防设施
(item.getType()).slice(0, 3) === "XF_" ? list.push(item) : null
} else if (this.beforeFence === 5) { //输油管线
item.getType() === "JY_SYGX" ? list.push(item) : null
} else if (this.beforeFence === 6) { //油气回收
item.getType() === "JY_YQHSGX" ? list.push(item) : null
}
})
this.FacilityList = list

6
src/app/pages/login/login.component.html

@ -20,9 +20,9 @@
<div class="hint">
<span class="forget" (click)="forget()">忘记密码?</span>
</div>
<button nz-button class="login-form-button login-form-margin" [nzType]="'primary'">登录</button>
<button [nzLoading]="isLoading" nz-button class="login-form-button login-form-margin" [nzType]="'primary'">登录</button>
</form>
<p class="role">
<!-- <p class="role">
<a nz-dropdown [nzDropdownMenu]="menu" [nzVisible]="true">
{{selectedRole ? selectedRole : '请选择登录角色'}}
<i nz-icon nzType="down"></i>
@ -32,7 +32,7 @@
<li nz-menu-item (click)="selecteRole(item)" *ngFor="let item of roleList">{{item}}</li>
</ul>
</nz-dropdown-menu>
</p>
</p> -->
<p class="company">北京安信科创软件有限公司提供技术支持和维护</p>
</div>
</div>

2
src/app/pages/login/login.component.scss

@ -27,7 +27,7 @@
.hint {
text-align: right;
margin-bottom: 40px;
margin-bottom: 50px;
.forget{
cursor: pointer;
color: #2399FF;

28
src/app/pages/login/login.component.ts

@ -33,7 +33,7 @@ export class LoginComponent implements OnInit {
toRegister() {
this.router.navigate(['/register'])
}
isLoading = false;
submitForm(): void {
for (const i in this.validateForm.controls) {
this.validateForm.controls[i].markAsDirty();
@ -43,23 +43,33 @@ export class LoginComponent implements OnInit {
this.message.create('error', `请输入账号密码`);
return
}
if (!this.selectedRole) {
this.message.create('error', `请选择登录角色`);
return
}
// if (!this.selectedRole) {
// this.message.create('error', `请选择登录角色`);
// return
// }
this.isLoading = true;
this.http.post('/api/TokenAuth/Authenticate', {
userNameOrEmailAddress: this.validateForm.value.userName,
password: this.validateForm.value.password
}).subscribe(
(data: any) => {
this.message.create('success', `登陆成功`);
sessionStorage.setItem("token", data.result.accessToken);
this.cookieService.set("token", data.result.accessToken, null, '/');
this.cookieService.set("refreshToken", data.result.encryptedAccessToken, null, '/');
this.http.get('/api/services/app/Session/GetCurrentLoginInformations').subscribe((data:any) => {
sessionStorage.setItem('userdata',JSON.stringify(data.result.user))
this.http.get('/api/services/app/Session/GetCurrentLoginInformations').subscribe((data: any) => {
sessionStorage.setItem('userdata', JSON.stringify(data.result.user))
this.isLoading = false;
if (data.result.user.organization.isGasStation) {
sessionStorage.setItem("isGasStation", 'true');
this.router.navigate(['/plan/petrolStation'])
} else {
sessionStorage.setItem("isGasStation", 'false');
this.router.navigate(['/plan'])
}
this.message.create('success', `登陆成功`);
})
this.router.navigate(['/home/plan'])
//调用服务中的function刷新token
// this.token.startUp()
},

2
src/app/pages/oil-station-info/oil-station-info.component.html

@ -205,7 +205,7 @@
</td>
</tr>
</table>
<table class="imgtable">
<table class="imgtable" id="images">
<tr>
<td class="head">营业执照</td>
<td colspan="3" class="imgbox">

26
src/app/pages/oil-station-info/oil-station-info.component.ts

@ -4,6 +4,7 @@ import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { ObjectsSimpleService } from 'src/app/service/objectsSimple.service';
import { NzMessageService } from 'ng-zorro-antd/message';
import * as moment from 'moment';
import Viewer from 'viewerjs';
@Component({
selector: 'app-oil-station-info',
templateUrl: './oil-station-info.component.html',
@ -49,12 +50,15 @@ export class OilStationInfoComponent implements OnInit {
this.getInfo()
}
validityTime: any = []//营业执照有效期
//获取油站信息
gallery
getInfo() {
this.http.get('/api/services/app/GasStation/Get', {
params: {
@ -72,6 +76,14 @@ export class OilStationInfoComponent implements OnInit {
this.validityTime[1] = data.result.validityEndTime
this.validityTime = [...this.validityTime]
console.log(this.validityTime)
setTimeout(() => {
this.gallery = new Viewer(document.getElementById('images'), {
show: () => { // 动态加载图片后,更新实例
this.gallery.update();
},
});
}, 0);
}, err => {
console.log('油站错误信息', err.error.error.message)
})
@ -181,17 +193,25 @@ export class OilStationInfoComponent implements OnInit {
}
//设置文件路径并上传
postFilePath
openFileSelect(file: File, extensionPath: string) {
async openFileSelect(file: File, extensionPath: string) {
this.postFilePath = extensionPath;
let fileSize = file.size || null //上传文件的总大小
let shardSize = 5 * 1024 * 1024 //5MB 超过5MB要分块上传
if (fileSize >= shardSize) // 超过5MB要分块上传
{
this.postFileByMul(file);
await this.postFileByMul(file);
setTimeout(() => {
this.gallery.destroy()
this.gallery = new Viewer(document.getElementById('images'));
}, 0);
}
else //普通上传
{
this.postFile(file);
await this.postFile(file);
setTimeout(() => {
this.gallery.destroy()
this.gallery = new Viewer(document.getElementById('images'));
}, 0);
}
}
//上传文件

9
src/app/pages/pages-routing.module.ts

@ -8,16 +8,17 @@ import { TodayWarningAdminComponent } from './today-warning-admin/today-warning-
import { CriminalRecordsAdminComponent } from './criminal-records-admin/criminal-records-admin.component';
import { OilStationInfoComponent } from './oil-station-info/oil-station-info.component';
import { EquipmentInfoComponent } from './equipment-info/equipment-info.component';
import { PlanAdminComponent } from './plan-admin/plan-admin.component';
const routes: Routes = [
{ path: 'plan', component: PlanComponent , data: { permission: 'xxxx' },canActivate: [AuthGuard]},
{ path: 'plan', component: PlanAdminComponent , data: { permission: 'xxxx' },canActivate: [AuthGuard]},
{ path: 'plan/petrolStation', component: PlanComponent , data: { permission: 'xxxx' },canActivate: [AuthGuard]},
{ path: 'warning', component: TodayWarningAdminComponent },
{ path: 'warning/petrolStation', component: TodayWarningComponent },
{ path: 'warning/admin', component: TodayWarningAdminComponent },
{ path: 'records', component: CriminalRecordsAdminComponent },
{ path: 'records/petrolStation', component: CriminalRecordsComponent },
{ path: 'records/admin', component: CriminalRecordsAdminComponent },
{ path: 'equipmentInfo', component: EquipmentInfoComponent },
{ path: 'oliStationInfo', component: OilStationInfoComponent }
];
@NgModule({

19
src/app/pages/pages.module.ts

@ -30,6 +30,8 @@ import { NzDropDownModule } from 'ng-zorro-antd/dropdown';
import { NzMessageModule } from 'ng-zorro-antd/message';
import { NzSpinModule } from 'ng-zorro-antd/spin';
import { NzTreeModule } from 'ng-zorro-antd/tree';
import { NzCollapseModule } from 'ng-zorro-antd/collapse';
import { NzStepsModule } from 'ng-zorro-antd/steps';
import { TodayWarningAdminComponent } from './today-warning-admin/today-warning-admin.component';
import { CriminalRecordsAdminComponent } from './criminal-records-admin/criminal-records-admin.component';
import { EquipmentInfoComponent } from './equipment-info/equipment-info.component';
@ -37,10 +39,18 @@ import { OilStationInfoComponent } from './oil-station-info/oil-station-info.com
import { LeftDomainComponent } from './left-domain/left-domain.component';
import { AddequipmentComponent } from './equipment-info/addequipment/addequipment.component';
import { EditequipmentComponent } from './equipment-info/editequipment/editequipment.component';
import { NzTreeSelectModule } from 'ng-zorro-antd/tree-select';
import { PlanAdminComponent } from './plan-admin/plan-admin.component';
import { GetOutOfLineDetailsComponent } from './today-warning/get-out-of-line-details/get-out-of-line-details.component';
@NgModule({
declarations: [LoginComponent, RegisterComponent, HomeComponent, PlanComponent, TodayWarningComponent, CriminalRecordsComponent, TodayWarningAdminComponent, CriminalRecordsAdminComponent, LeftDomainComponent, EquipmentInfoComponent, OilStationInfoComponent, AddequipmentComponent, EditequipmentComponent],
declarations: [LoginComponent, RegisterComponent, HomeComponent, PlanComponent, TodayWarningComponent, CriminalRecordsComponent,
TodayWarningAdminComponent, CriminalRecordsAdminComponent, LeftDomainComponent, EquipmentInfoComponent, OilStationInfoComponent,
AddequipmentComponent, EditequipmentComponent,PlanAdminComponent, GetOutOfLineDetailsComponent],
imports: [
PagesRoutingModule,
CommonModule,
@ -67,9 +77,12 @@ import { EditequipmentComponent } from './equipment-info/editequipment/editequip
NzDropDownModule,
NzMessageModule,
NzSpinModule,
NzTreeModule
NzTreeModule,
NzTreeSelectModule,
NzCollapseModule,
NzStepsModule
],
entryComponents: [AddequipmentComponent, EditequipmentComponent],
entryComponents: [AddequipmentComponent, EditequipmentComponent,GetOutOfLineDetailsComponent],
schemas: [CUSTOM_ELEMENTS_SCHEMA]
})

128
src/app/pages/plan-admin/plan-admin.component.html

@ -0,0 +1,128 @@
<!-- <p>站点预案!</p> -->
<div class="stationPlanBox" id="stationPlanBox">
<div class="orbox">
<div class="title">
<app-title [name]="'组织机构'"></app-title>
</div>
<div class="or">
<nz-tree [nzExpandedKeys]="nzExpandedKeys" [nzShowExpand]="false" #nzTreeComponent
[nzExpandAll]="nzExpandAll" nzBlockNode [nzData]="nodes" (nzClick)="activeNode($event)"
[nzTreeTemplate]="nzTreeTemplate"[nzMultiple]="false"></nz-tree>
<ng-template #nzTreeTemplate let-node let-origin="origin">
<ng-container *ngIf="node.origin.parentId == null; else elseTemplate">
<img style="vertical-align: bottom;" src="../../../assets/images/flower.png" alt="">
</ng-container>
<ng-template #elseTemplate>
<img src="../../../assets/images/point.png" alt="">
</ng-template>
<span>{{ node.title }}</span>
<img (click)="expand($event,node)" *ngIf="node.isExpanded && node.children.length != 0 "
src="../../../assets/images/expand.png" alt="">
<img (click)="expand($event,node)" *ngIf="!node.isExpanded && node.children.length != 0"
src="../../../assets/images/unexpand.png" alt="">
</ng-template>
</div>
</div>
<div class="stationList">
<div class="title">
<app-title [name]="'站点管理'"></app-title>
</div>
<div class="search">
<form nz-form [formGroup]="validateForm" class="login-form" (ngSubmit)="submitForm()">
<nz-form-item class="searchParams">
<nz-form-control>
<nz-input-group>
<input required nz-input type="text" formControlName="name" placeholder="请输入名称" />
</nz-input-group>
</nz-form-control>
</nz-form-item>
<nz-form-item class="searchParams">
<nz-form-control>
<nz-input-group>
<input required nz-input type="text" formControlName="linkman" placeholder="请输入联系人" />
</nz-input-group>
</nz-form-control>
</nz-form-item>
<nz-form-item class="searchParams">
<nz-form-control>
<nz-input-group>
<input required nz-input type="text" formControlName="phone" placeholder="请输入电话" />
</nz-input-group>
</nz-form-control>
</nz-form-item>
<nz-form-item class="btn">
<nz-form-control>
<button nz-button type="submit" class="submit"><i nz-icon [nzType]="'search'"></i>查询</button>
</nz-form-control>
</nz-form-item>
<nz-form-item class="btn">
<nz-form-control>
<button nz-button type="button" class="reset" (click)="resetForm($event)"><i nz-icon
[nzType]="'sync'"></i>重置</button>
</nz-form-control>
</nz-form-item>
</form>
</div>
<div class="tablebox">
<div class="table">
<div nz-row class="th">
<div nz-col nzSpan="2" style="text-align: right;box-sizing: border-box;padding-right: 20px;">
</div>
<div nz-col nzSpan="6">
加油站名称
</div>
<div nz-col nzSpan="3">
区域
</div>
<div nz-col nzSpan="4">
所属公司
</div>
<div nz-col nzSpan="3">
联系人
</div>
<div nz-col nzSpan="4">
联系电话
</div>
<div nz-col nzSpan="2">
操作
</div>
</div>
<div class="tbody">
<div nz-row class="tr" *ngFor="let item of list">
<div nz-col nzSpan="2" style="text-align: right;box-sizing: border-box;padding-right: 20px;">
<span class="ziying">自营</span>
</div>
<div nz-col nzSpan="6">
中化山东省淄博市第6加油站
</div>
<div nz-col nzSpan="3">
山东-淄博
</div>
<div nz-col nzSpan="4">
中化某某公司
</div>
<div nz-col nzSpan="3">
张三三
</div>
<div nz-col nzSpan="4">
0566-5897888
</div>
<div nz-col nzSpan="2">
<span class="look" (click)="look()">查看</span>
</div>
</div>
</div>
</div>
<div class="pagination">
<nz-pagination [nzPageIndex]="1" [nzTotal]="85" [nzPageSize]="20" [nzShowTotal]="totalTemplate"
nzShowQuickJumper></nz-pagination>
<ng-template #totalTemplate let-total> 16条/页,共100条 </ng-template>
</div>
</div>
</div>
</div>

137
src/app/pages/plan-admin/plan-admin.component.scss

@ -0,0 +1,137 @@
.stationPlanBox {
width: 100%;
height: 100%;
box-sizing: border-box;
padding: 20px 24px;
display: flex;
}
.title {
width: 100%;
height: 48px;
}
.orbox {
height: 100%;
width: 360px;
margin-right: 40px;
display: flex;
flex-direction: column;
.or {
flex: 1;
overflow-y: auto;
border: 1px solid rgba(54, 162, 255, 0.3);
background: linear-gradient(180deg, rgba(3, 0, 0, 0) 0%, rgba(0, 46, 91, 0.68) 100%);
margin-top: 12px;
box-sizing: border-box;
padding: 18px 12px;
nz-tree {
background: none;
color: #C4E2FC;
}
}
}
.stationList {
flex: 1;
display: flex;
flex-direction: column;
.search {
box-sizing: border-box;
padding-left: 22px;
padding-right: 33px;
width: 100%;
height: 32px;
margin-top: 14px;
margin-bottom: 22px;
form {
width: 100%;
height: 32px;
display: flex;
justify-content: space-around;
input {
background: none;
border: 1px solid #91CCFF;
color: #fff;
}
.searchParams {
width: 28%;
}
.btn {
width: 5%;
}
}
}
.tablebox {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
overflow: hidden;
.table {
color: white;
flex: 1;
width: 96%;
display: flex;
flex-direction: column;
overflow: hidden;
.th {
height: 40px;
line-height: 40px;
background: rgba(35, 153, 255, 0.2);
border: 1px solid rgba(35, 217, 255, 0.4);
box-shadow: 0 0 3px 0 rgba(35, 217, 255, 0.4) inset;
color: #23D9FF;
}
.tbody {
flex: 1;
overflow-y: auto;
.tr {
height: 40px;
line-height: 40px;
border-bottom: 1px solid #0d3761;
div {
color: #91CCFF;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
.look {
color: #36A2FF;
cursor: pointer;
}
}
}
}
}
.pagination {
margin-top: 26px;
display: flex;
align-items: center;
justify-content: center;
}
::-webkit-scrollbar {
width: 0px;
}
}
}

70
src/app/pages/plan-admin/plan-admin.component.ts

@ -0,0 +1,70 @@
import { Component, OnInit, ViewChild } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { TreeService } from 'src/app/service/tree.service';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { NzContextMenuService, NzDropdownMenuComponent } from 'ng-zorro-antd/dropdown';
import { NzFormatEmitEvent, NzTreeComponent, NzTreeNode } from 'ng-zorro-antd/tree';
import { Router } from '@angular/router';
@Component({
selector: 'app-plan-admin',
templateUrl: './plan-admin.component.html',
styleUrls: ['./plan-admin.component.scss']
})
export class PlanAdminComponent implements OnInit {
validateForm!: FormGroup;
@ViewChild('nzTreeComponent', { static: false }) nzTreeComponent!: NzTreeComponent;
constructor(private http: HttpClient, private toTree: TreeService, private fb: FormBuilder, private nzContextMenuService: NzContextMenuService, private router: Router) { }
list: any = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
ngOnInit(): void {
this.validateForm = this.fb.group({
name: [null],
linkman: [null],
phone: [null]
});
this.getAllOrganization()
}
submitForm(): void {
for (const i in this.validateForm.controls) {
this.validateForm.controls[i].markAsDirty();
this.validateForm.controls[i].updateValueAndValidity();
}
}
resetForm(e: MouseEvent): void {
e.preventDefault();
this.validateForm.reset();
for (const key in this.validateForm.controls) {
this.validateForm.controls[key].markAsPristine();
this.validateForm.controls[key].updateValueAndValidity();
}
}
//获取所有组织机构
nodes: any = []
nzExpandAll = false
getAllOrganization() {
this.http.get('/api/services/app/Organization/GetAll').subscribe((data: any) => {
data.result.items.forEach(element => {
element.key = element.id
element.title = element.displayName
});
this.nodes = [...this.toTree.toTree(data.result.items)]
this.nzExpandAll = true
})
}
look() {
this.router.navigate(['/plan/petrolStation'])
}
nzExpandedKeys: any = []
activatedNode?: NzTreeNode;
//点击tree节点
activeNode(data: NzFormatEmitEvent): void {
this.activatedNode = data.node!;
// console.log(data)
}
expand(e, node) {
e.stopPropagation()
node.isExpanded = !node.isExpanded
}
}

57
src/app/pages/plan/plan.component.html

@ -16,7 +16,7 @@
<canvas id="center"></canvas>
<!-- 左侧子组件 -->
<div class="leftChildComponent" *ngIf="isShowChildComponent" [ngStyle]="{ 'left': isShowLeftBuilding? '15%' : null }">
<div class="leftChildComponent" *ngIf="isShowChildComponent && selectFence != 4" [ngStyle]="{ 'left': isShowLeftBuilding? '15%' : null }" [ngClass]="{'publicMoveUp': selectFence === 7}">
<div class="leftChildHeader">
<div><i nz-icon nzType="star" nzTheme="outline"></i></div>
<div>{{allFence[selectFence]}}<i nz-icon nzType="plus-circle" nzTheme="outline" *ngIf="selectFence === 7" (click)="noticeChildComponent(true)"></i><i nz-icon nzType="save" nzTheme="outline" *ngIf="selectFence === 7" (click)="noticeChildComponent(false)"></i></div>
@ -28,7 +28,7 @@
<!-- 左侧建筑栏 -->
<div class="showLeftBuilding" title="显示" *ngIf="!isShowLeftBuilding" (click)="toggleLeftBuilding(true)"><i nz-icon nzType="right" nzTheme="outline"></i></div>
<div class="leftBuilding" [ngClass]="{'isShowLeftBuilding': isShowLeftBuilding === false}">
<div class="leftBuilding" [ngClass]="{'isShowLeftBuilding': isShowLeftBuilding === false, 'publicMoveUp': selectFence === 7}">
<div class="hideLeft"><i nz-icon nzType="close" nzTheme="outline" title="隐藏" (click)="toggleLeftBuilding(false)"></i></div>
<div class="leftHeader">
<h1><label>模型列表</label></h1>
@ -48,12 +48,24 @@
<!-- 左侧建筑栏 -->
<!-- 右侧图标栏 -->
<div class="rightIcons">
<div class="rightIcons" *ngIf="selectFence === 0 || selectFence === 7" [ngClass]="{'publicMoveUp': selectFence === 7}">
<div class="bottomCenter" id="bottomCenter">
<div class="everyIcon" (click)='selectBottomIcon(item)' *ngFor="let item of allFacilityUIItemes" [ngClass]="{'selectLeftIcon': beforeOneIcon == item.getIconID()}">
<img [src]="item.getIconURL()">
<p>{{item.getIconName()}}</p>
</div>
<ng-container *ngIf="selectFence === 0">
<div class="everyIcon" (click)='selectBottomIcon(item)' *ngFor="let item of allFacilityUIItemes" [ngClass]="{'selectLeftIcon': beforeOneIcon == item.getIconID()}">
<img [src]="item.getIconURL()">
<p>{{item.getIconName()}}</p>
</div>
</ng-container>
<ng-container *ngIf="selectFence === 7">
<nz-collapse [nzBordered]="false">
<nz-collapse-panel [nzHeader]="allMarkData.iconsName[key]" [nzActive]="true" *ngFor="let element of allMarkData.icons; let key = index;">
<div class="everyIcon" (click)='selectBottomIcon(item)' *ngFor="let item of element" [ngClass]="{'selectLeftIcon': beforeOneIcon == item.key}">
<img [src]="item.iconURL">
<p>{{item.name}}</p>
</div>
</nz-collapse-panel>
</nz-collapse>
</ng-container>
</div>
</div>
<!-- 右侧图标栏 -->
@ -78,6 +90,37 @@
</div>
<!-- 右上角快捷栏 -->
<!-- 底部处置预案 -->
<div class="bottomPlan" *ngIf="selectFence === 7">
<div class="pulicPlanDiv bottomPlanHeader">
<div class="planHeaderText">
<p>灾情描述</p>
<textarea></textarea>
</div>
<div class="planHeaderImg"><a href="javascript:;" class="bottomPlanUpload"><input type="file"><img src="../../../assets/images/uploadImg.png"></a></div>
<div class="planHeaderVideo"><a href="javascript:;" class="bottomPlanUpload" style="width: 100px;"><input type="file"><img src="../../../assets/images/uploadVideo.png"></a></div>
</div>
<div style="height: 5px;"></div>
<div class="pulicPlanDiv bottomPlanCenter">
<label><button>处置预案</button></label>
<label>
<nz-steps>
<nz-step [nzIcon]="iconTemplate"></nz-step>
<nz-step [nzIcon]="iconTemplate"></nz-step>
<nz-step [nzIcon]="iconTemplate"></nz-step>
<ng-template #iconTemplate><img src="../../../assets/images/stepIcon.png"></ng-template>
</nz-steps>
</label>
<label>
<i nz-icon nzType="backward" nzTheme="outline"></i>
<i nz-icon nzType="pause" nzTheme="outline"></i>
<i nz-icon nzType="border" nzTheme="outline"></i>
<i nz-icon nzType="forward" nzTheme="outline"></i>
</label>
</div>
</div>
<!-- 底部处置预案 -->
<!-- 新增/编辑左侧建筑弹窗 -->
<nz-modal [(nzVisible)]="addBuildingPop || editBuildingPop" nzTitle="创建/编辑建筑" (nzOnCancel)="addBuildingPop = false; editBuildingPop = null;" (nzOnOk)="addModelBuilding(form.value)" [nzOkDisabled]='name.invalid||modelType.invalid'>
<form nz-form #form='ngForm'>

85
src/app/pages/plan/plan.component.scss

@ -180,7 +180,7 @@
//右侧图标栏
.rightIcons{
width: 60px;
width: 100px;
height: 70%;
position: absolute;
top: 0;
@ -188,19 +188,23 @@
right: 1%;
margin: auto;/*这行代码是关键*/
color: #fff;
background: rgba(0,17,33,0.7);
border-radius: 10px;
display: flex;
flex-direction: column;
align-items: center;
background: linear-gradient(360deg, #000D21 0%, rgba(0, 59, 110, 0.8) 100%);
overflow: hidden;
.autoScroll{ width: 30px; text-align: center; }
.bottomCenter::-webkit-scrollbar { display: none; }
.bottomCenter {
scrollbar-width: none; /* firefox */
-ms-overflow-style: none; /* IE 10+ */
overflow-x: hidden;
overflow-y: auto;
}
.bottomCenter{
flex: 1;
width: 100%;
height: 100%;
overflow-x: hidden;
overflow-y: auto;
.everyIcon {
width: 60px;
width: 100px;
height: 58px;
line-height: normal;
text-align: center;
@ -219,7 +223,7 @@
height: 38px;
position: absolute;
right: 1px;
top: 3%;
top: 1%;
display: flex;
>div { height: 38px; border-radius: 5px; }
button {
@ -254,4 +258,67 @@
margin-right: 10px;
}
.selectRightTopFast { border: 1px solid #fff; } //选种样式
}
//左右侧栏 上移
.publicMoveUp{
height: 70%;
top: 10%;
bottom: auto;
}
//底部处置预案
.bottomPlan{
width: 95%;
position: absolute;
left: 0;
right: 0;
bottom: 1%;
margin: auto;/*这行代码是关键*/
color: #fff;
.pulicPlanDiv{ width: 100%; padding: 0 15px; overflow: hidden; background: linear-gradient(360deg, #000D21 0%, rgba(0, 59, 110, 0.8) 100%); }
.bottomPlanHeader{
height: 80px;
display: flex;
align-items: center;
box-shadow: 0px 0px 6px #2399FF;
.planHeaderText{
flex: 1;
font-size: 14px;
p{ margin: 0; height: 20px; line-height: 18px; }
textarea{ width: 100%; height: 50px; background: rgba(145, 204, 255, 0.41); border: 1px solid #91CCFF; padding: 0; resize:none; outline: none; }
}
.planHeaderImg{ width: 100px; height: 100%; text-align: center; }
.planHeaderVideo{ width: 120px; height: 100%; text-align: center; }
}
.bottomPlanCenter{
height: 35px;
line-height: 38px;
display: flex;
overflow: hidden;
label{
display: block;
}
label:first-child{
width: 15%;
height: 100%;
text-align: center;
button {
width: 60%;
height: 30px;
line-height: 30px;
color: #23D9FF;
//padding: 0;
background: rgba(35, 153, 255, 0.41);
border: 1px solid rgba(35, 217, 255, 0.4);
}
}
label:nth-child(2){ flex: 1; overflow: hidden; img{ height: 35px; width: auto; vertical-align: top; } }
label:last-child{
width: 15%;
height: 100%;
text-align: center;
color: #fff;
.anticon{ font-size: 20px; margin: 0 10px; }
}
}
}

37
src/app/pages/plan/plan.component.ts

@ -19,6 +19,9 @@ import { EventManager } from '@angular/platform-browser';
import { NzMessageService } from 'ng-zorro-antd/message';
import { LeftDomainComponent } from '../left-domain/left-domain.component';
import { JYZInfoMoudleType } from 'src/app/babylon/model/data/institution/jyz-show-data';
import { AllMarkData } from 'src/app/babylon/model/data/mark/all-mark-data';
import { MarkData } from 'src/app/babylon/model/data/mark/mark-data';
import { MarkWindow } from 'src/app/babylon/view/mark-window/mark-window';
@ -104,7 +107,7 @@ export class PlanComponent implements OnInit {
let buildingWindow: BuildingWindow = this.beforeOneSatus.buildingWindow;
let fenceType: JYZInfoMoudleType = this.getFenceType(type)
if (this.selectFence != type) {
this.isShowChildComponent && this.leftDomain ? this.leftDomain.initComponent(type) : null; //手动初始化子组件
this.isShowChildComponent && this.leftDomain && type != 4 ? this.leftDomain.initComponent(type) : null; //手动初始化子组件
this.selectFence = type
this.isShowChildComponent = true
buildingWindow.changeJYZInfoModel(fenceType, true)
@ -241,7 +244,8 @@ export class PlanComponent implements OnInit {
}
}
allFacilityUIItemes: FacilityUIItem[] = []; //底部所有 图标
allFacilityUIItemes: FacilityUIItem[] = []; //右侧所有 图标
allMarkData: planIcons = new planIcons(); //右侧处置预案所有 图标
beforeOneIcon: string = null; //当前选择 图标
// 获取 底部图标栏list
@ -251,13 +255,23 @@ export class PlanComponent implements OnInit {
}
//选择底部图标
selectBottomIcon(e: FacilityUIItem) {
if (this.beforeOneIcon != e.getIconID()) {
this.beforeOneIcon = e.getIconID()
e.select()
} else {
this.beforeOneIcon = null
e.unSelect()
selectBottomIcon(e: FacilityUIItem | MarkData) {
if (e instanceof FacilityUIItem) {
if (this.beforeOneIcon != e.getIconID()) {
this.beforeOneIcon = e.getIconID()
e.select()
} else {
this.beforeOneIcon = null
e.unSelect()
}
} else if (e instanceof MarkData) {
if (this.beforeOneIcon != e.key) {
this.beforeOneIcon = e.key
MarkWindow.instance.selectMarkDataPrefab(true, e)
} else {
this.beforeOneIcon = null
MarkWindow.instance.selectMarkDataPrefab(false, e)
}
}
}
@ -355,6 +369,11 @@ export class PlanComponent implements OnInit {
}
// 处置预案 所有图标
export class planIcons {
iconsName: string[] = ["灾情","内部力量","外部力量","其他"]
icons: MarkData[][] = [AllMarkData.CreateAllMarkData().marks_Disaster,AllMarkData.CreateAllMarkData().marks_Inside,AllMarkData.CreateAllMarkData().marks_Outside,AllMarkData.CreateAllMarkData().marks_Other,]
}
//创建/编辑 建筑dataType
export class modelBuilding {
name: string = "";

15
src/app/pages/plan/publicPop.scss

@ -14,9 +14,22 @@
overflow: hidden;
display: inline-block;
}
.uploadBackGround input {
.bottomPlanUpload{
margin-top: 5px;
width: 70px;
height: 70px;
line-height: 65px;
position: relative;
cursor: pointer;
background: rgba(145, 204, 255, 0.41);
border: 1px dashed #91CCFF;
overflow: hidden;
display: inline-block;
}
.uploadBackGround input,.bottomPlanUpload input {
position: absolute;
width: 100%;
height: 100%;
right: 0;
top: 0;
opacity: 0;

19
src/app/pages/today-warning-admin/today-warning-admin.component.html

@ -10,6 +10,7 @@
<nz-option nzValue="1" nzLabel="一级"></nz-option>
<nz-option nzValue="2" nzLabel="二级"></nz-option>
<nz-option nzValue="3" nzLabel="三级"></nz-option>
<nz-option nzValue="4" nzLabel="四级"></nz-option>
</nz-select>
</nz-form-control>
</nz-form-item>
@ -17,20 +18,19 @@
<nz-form-item class="searchParams">
<nz-form-control>
<nz-select id="type" formControlName="type" nzPlaceHolder="请选择预警类型">
<nz-option nzValue="1" nzLabel="一级"></nz-option>
<nz-option nzValue="2" nzLabel="二级"></nz-option>
<nz-option nzValue="3" nzLabel="三级"></nz-option>
<nz-option *ngFor="let item of yujingTypes" [nzValue]="item.id" [nzLabel]="item.violationName"></nz-option>
</nz-select>
</nz-form-control>
</nz-form-item>
<nz-form-item class="searchParams">
<nz-form-control>
<nz-select id="company" formControlName="company" nzPlaceHolder="请选择所属机构">
<nz-option nzValue="1" nzLabel="一级"></nz-option>
<nz-option nzValue="2" nzLabel="二级"></nz-option>
<nz-option nzValue="3" nzLabel="三级"></nz-option>
</nz-select>
<!-- <nz-select id="company" formControlName="company" nzPlaceHolder="请选择所属机构">
</nz-select> -->
<nz-tree-select id="company" formControlName="company" [nzNodes]="nodes" nzPlaceHolder="请选择所属机构">
</nz-tree-select>
</nz-form-control>
</nz-form-item>
<!-- <nz-form-item class="searchParams">
@ -146,8 +146,9 @@
</div>
<div nz-col nzSpan="2">
<button nz-button (click)="look()">查看</button>
<img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt="">
<!-- <img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt=""> -->
</div>
</div>
</div>
</div>

3
src/app/pages/today-warning-admin/today-warning-admin.component.scss

@ -38,6 +38,9 @@
color: rgba(145, 204, 255, 0.95);
;
}
nz-tree-select{
color: rgba(145, 204, 255, 0.95);
}
nz-date-picker {
background-color: rgba(0, 0, 0, 0);

30
src/app/pages/today-warning-admin/today-warning-admin.component.ts

@ -1,6 +1,8 @@
import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { Router } from '@angular/router'
import { Router } from '@angular/router';
import { HttpClient } from '@angular/common/http';
import { TreeService } from 'src/app/service/tree.service';
@Component({
selector: 'app-today-warning-admin',
templateUrl: './today-warning-admin.component.html',
@ -9,7 +11,7 @@ import { Router } from '@angular/router'
export class TodayWarningAdminComponent implements OnInit {
validateForm!: FormGroup;
constructor(private fb: FormBuilder, private router: Router) { }
constructor(private http: HttpClient,private fb: FormBuilder, private router: Router, private toTree: TreeService) { }
ngOnInit(): void {
this.validateForm = this.fb.group({
@ -20,6 +22,28 @@ export class TodayWarningAdminComponent implements OnInit {
site: [null],
datePicker: [null]
});
this.yujingType()
this.getAllOrganization()
}
//预警类型接口
yujingTypes:any //预警接口数据
yujingType(){
this.http.get('/api/services/app/Violation/GetAllList').subscribe((data: any) => {
this.yujingTypes=data.result
}
)
}
//获取所有组织机构
nodes:any = []
getAllOrganization() {
this.http.get('/api/services/app/Organization/GetAll').subscribe((data: any) => {
data.result.items.forEach(element => {
element.key = element.code
element.title = element.displayName
});
this.nodes = [...this.toTree.toTree(data.result.items)]
console.log(this.nodes)
})
}
submitForm(): void {
@ -68,6 +92,6 @@ export class TodayWarningAdminComponent implements OnInit {
}
look() {
this.router.navigate(['home/warning/petrolStation'])
this.router.navigate(['warning/petrolStation'])
}
}

23
src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.html

@ -0,0 +1,23 @@
<!-- <p>get-out-of-line-details works!</p> -->
<div class="box">
<div class="titlebox">
<div class="title">
<div (click)="contentType('img')" [ngClass]="{'selected': selectedType == 'img'}">
违规截图
<div class="border"></div>
</div>
<div (click)="contentType('video')" [ngClass]="{'selected': selectedType == 'video'}">
违规视频
<div class="border"></div>
</div>
</div>
</div>
<div class="content">
<div *ngIf="selectedType == 'img'">
违规截图
</div>
<div *ngIf="selectedType == 'video'">
违规视频
</div>
</div>
</div>

61
src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.scss

@ -0,0 +1,61 @@
.box {
width: 100%;
height: 700px;
color: #fff;
display: flex;
flex-direction: column;
}
.titlebox {
width: 100%;
height: 48px;
background: #041d3c;
display: flex;
align-items: center;
.title {
width: 100%;
height: 32px;
background: linear-gradient(270deg, rgba(35, 153, 255, 0) 0%, rgba(35, 153, 255, 0.57) 50%, rgba(35, 153, 255, 0) 100%);
display: flex;
justify-content: center;
div {
width: 120px;
height: 32px;
text-align: center;
line-height: 32px;
font-family: sybold;
font-size: 16px;
position: relative;
cursor: pointer;
margin: 0 18px;
.border {
position: absolute;
bottom: -7px;
left: -18px;
width: 120px;
height: 4px;
}
}
.selected {
background: linear-gradient(90deg, #1662a9 0%, #25b7d4 50%, #1662a9 100%);
.border {
background: linear-gradient(90deg, rgba(35, 217, 255, 0) 0%, #25b7d4 50%, rgba(35, 217, 255, 0) 100%);
}
}
}
}
.ant-modal-close {
color: #fff;
}
.content {
flex: 1;
box-sizing: border-box;
padding: 18px;
}

20
src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.ts

@ -0,0 +1,20 @@
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-get-out-of-line-details',
templateUrl: './get-out-of-line-details.component.html',
styleUrls: ['./get-out-of-line-details.component.scss']
})
export class GetOutOfLineDetailsComponent implements OnInit {
constructor() { }
ngOnInit(): void {
}
selectedType:string = 'img'
contentType(type){
this.selectedType = type
}
}

18
src/app/pages/today-warning/today-warning.component.html

@ -10,6 +10,7 @@
<nz-option nzValue="1" nzLabel="一级"></nz-option>
<nz-option nzValue="2" nzLabel="二级"></nz-option>
<nz-option nzValue="3" nzLabel="三级"></nz-option>
<nz-option nzValue="4" nzLabel="四级"></nz-option>
</nz-select>
</nz-form-control>
</nz-form-item>
@ -17,9 +18,7 @@
<nz-form-item class="searchParams">
<nz-form-control>
<nz-select id="type" formControlName="type" nzPlaceHolder="请选择预警类型">
<nz-option nzValue="1" nzLabel="一级"></nz-option>
<nz-option nzValue="2" nzLabel="二级"></nz-option>
<nz-option nzValue="3" nzLabel="三级"></nz-option>
<nz-option *ngFor="let item of yujingTypes" [nzValue]="item.id" [nzLabel]="item.violationName"></nz-option>
</nz-select>
</nz-form-control>
</nz-form-item>
@ -55,10 +54,7 @@
</form>
</div>
<!-- <div class="warningnumber">
<span class="num">39</span>
<span class="today">今日违规</span>
</div> -->
<div class="listbox">
<div nz-row class="listitem" *ngFor="let item of list">
<div nz-col nzSpan="3">
@ -89,12 +85,8 @@
</div>
<div nz-col nzSpan="2">
<button nz-button (click)="showModal()">查看</button>
<nz-modal nzWidth="1100" nzWrapClassName="vertical-center-modal" [(nzVisible)]="isVisible"
(nzOnCancel)="handleCancel()" (nzOnOk)="handleOk()" [nzFooter]="null">
</nz-modal>
<img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt="">
<!-- <img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt=""> -->
</div>
</div>
</div>
</div>
</div>

19
src/app/pages/today-warning/today-warning.component.scss

@ -46,24 +46,7 @@
}
}
.warningnumber {
position: absolute;
left: 23px;
top: -60px;
.num {
font-size: 50px;
text-shadow: 0px 0px 6px #8df;
color: white;
font-weight: 600;
}
.today {
font-size: 18px;
font-family: titlefont;
color: #D0EAFF;
}
}
.listbox {
flex: 1;

78
src/app/pages/today-warning/today-warning.component.ts

@ -1,5 +1,9 @@
import { Component, OnInit } from '@angular/core';
import { Component, OnInit, ViewContainerRef } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { HttpClient } from '@angular/common/http';
import { TreeService } from 'src/app/service/tree.service';
import { NzModalService } from 'ng-zorro-antd/modal';
import { GetOutOfLineDetailsComponent } from './get-out-of-line-details/get-out-of-line-details.component';
@Component({
selector: 'app-today-warning',
templateUrl: './today-warning.component.html',
@ -7,7 +11,7 @@ import { FormBuilder, FormGroup, Validators } from '@angular/forms';
})
export class TodayWarningComponent implements OnInit {
validateForm!: FormGroup;
constructor(private fb: FormBuilder) { }
constructor(private http: HttpClient, private fb: FormBuilder, private toTree: TreeService, private modal: NzModalService, private viewContainerRef: ViewContainerRef) { }
ngOnInit(): void {
this.validateForm = this.fb.group({
@ -16,8 +20,20 @@ export class TodayWarningComponent implements OnInit {
site: [null],
datePicker: [null]
});
this.yujingType()
//this.getAllOrganization()
}
//预警类型接口
yujingTypes: any //预警接口数据
yujingType() {
this.http.get('/api/services/app/Violation/GetAllList').subscribe((data: any) => {
this.yujingTypes = data.result
}
)
}
submitForm(): void {
for (const i in this.validateForm.controls) {
this.validateForm.controls[i].markAsDirty();
@ -36,30 +52,44 @@ export class TodayWarningComponent implements OnInit {
}
list: any = [
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:2,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:3,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'},
{level:1,type:'加油区违规',content:'工作人员倚靠加油机或者立柱',site:'加油区2号摄像头',time:'2021-10-12 09:28:13'}
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 2, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 3, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' },
{ level: 1, type: '加油区违规', content: '工作人员倚靠加油机或者立柱', site: '加油区2号摄像头', time: '2021-10-12 09:28:13' }
]
isVisible = false;
showModal(): void {
this.isVisible = true;
}
handleOk(): void {
console.log('Button ok clicked!');
this.isVisible = false;
}
handleCancel(): void {
console.log('Button cancel clicked!');
this.isVisible = false;
const modal = this.modal.create({
nzContent: GetOutOfLineDetailsComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 1200,
nzBodyStyle: {
'border': '1px solid #6d9cc7',
'border-radius': '0px',
'padding': '0px',
'box-shadow': '0 0 8px 0 #fff',
'background': '#000D21',
},
nzComponentParams: {},
nzFooter: null,
nzOnOk: async () => {
}
});
const instance = modal.getContentComponent();
}
}

11
src/app/system-management/analysis-of-the-host/addhost/addhost.component.html

@ -0,0 +1,11 @@
<div class="box">
<form nz-form [formGroup]="validateForm">
<nz-form-item>
<nz-form-control>
<nz-input-group>
<input nz-input type="text" formControlName="ip" placeholder="请输入ip" />
</nz-input-group>
</nz-form-control>
</nz-form-item>
</form>
</div>

3
src/app/system-management/analysis-of-the-host/addhost/addhost.component.scss

@ -0,0 +1,3 @@
.ant-form-item{
margin-bottom: 0;
}

21
src/app/system-management/analysis-of-the-host/addhost/addhost.component.ts

@ -0,0 +1,21 @@
import { Component, OnInit, Input } from '@angular/core';
import { NzModalRef } from 'ng-zorro-antd/modal';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { HttpClient } from '@angular/common/http';
@Component({
selector: 'app-addhost',
templateUrl: './addhost.component.html',
styleUrls: ['./addhost.component.scss']
})
export class AddhostComponent implements OnInit {
validateForm!: FormGroup;
constructor(private modal: NzModalRef, private fb: FormBuilder, private http: HttpClient) { }
ngOnInit(): void {
this.validateForm = this.fb.group({
ip: [null, [Validators.required]]
});
}
}

70
src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.html

@ -0,0 +1,70 @@
<div class="bigbox" id="hostbox">
<div class="orbox">
<div class="topbox">
<div class="lefttop">
<span>组织机构列表</span>
</div>
<div class="righttop">
<nz-input-group nzPrefixIcon="search">
<input type="text" nz-input placeholder="请输入机构名称" [(ngModel)]="searchValue" />
</nz-input-group>
</div>
</div>
<div class="treeTitle">
<span>组织机构</span>
</div>
<div class="treebox">
<nz-tree [nzSearchValue]="searchValue" #nzTreeComponent [nzData]="nodes" [nzExpandAll]="nzExpandAll"
[nzExpandedKeys]="defaultExpandedKeys" [nzSelectedKeys] = 'nzSelectedKeys' (nzClick)="nzClick($event)" [nzTreeTemplate]="nzTreeTemplate"
[nzExpandedIcon]="multiExpandedIconTpl">
</nz-tree>
<ng-template #nzTreeTemplate let-node let-origin="origin">
<div class="nodebox">
<span class="name">{{ node.title }}</span>
</div>
</ng-template>
<ng-template #multiExpandedIconTpl let-node let-origin="origin">
<ng-container *ngIf="node.children.length == 0; else elseTemplate">
</ng-container>
<ng-template #elseTemplate>
<i nz-icon [nzType]="node.isExpanded ? 'caret-down' : 'caret-right'"
class="ant-tree-switcher-line-icon"></i>
</ng-template>
</ng-template>
</div>
</div>
<div class="hostListbox">
<div class="topbox">
<div class="lefttop">
<span>加油站分析主机列表
<span class="yellowspan">(请从左侧选择加油站)</span>
</span>
</div>
<div class="righttop" *ngIf="selectedOilStation">
<button nz-button nzType="primary" (click)="addHost()"><i nz-icon nzType="plus-circle"
nzTheme="outline"></i>新增</button>
</div>
</div>
<div class="tablebox">
<nz-table #basicTable [nzData]="listOfData" [nzShowPagination]='false' [nzPageSize]='16'>
<thead>
<tr>
<th>ip</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<tr *ngFor="let data of basicTable.data">
<td>{{data.ip}}</td>
<td class="operation">
<a (click)="edit(data)">编辑</a>
<a (click)="delete(data)">删除</a>
</td>
</tr>
</tbody>
</nz-table>
</div>
</div>
</div>

92
src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.scss

@ -0,0 +1,92 @@
.bigbox {
width: 100%;
height: 100%;
display: flex;
background: #fff;
box-sizing: border-box;
padding: 20px;
font-size: 15px;
}
.orbox {
width: 375px;
height: 100%;
overflow-y: auto;
display: flex;
flex-direction: column;
}
.topbox {
width: 100%;
height: 36px;
display: flex;
align-items: center;
justify-content: space-between;
.lefttop {
span {
color: #000D21;
margin-right: 16px;
}
.yellowspan {
color: rgb(240, 176, 37);
}
}
.righttop {
height: 36px;
display: flex;
button {
margin-left: 16px;
}
nz-input-group {
height: 32px;
}
}
}
.treeTitle {
width: 100%;
height: 36px;
line-height: 36px;
display: flex;
justify-content: space-between;
color: #000D21;
box-sizing: border-box;
padding-left: 30px;
padding-right: 180px;
background: rgba(145, 204, 255, 0.2);
border: 1px solid rgba(145, 204, 255, 0.2);
}
.treebox {
flex: 1;
overflow-y: auto;
border: 1px solid rgba(145, 204, 255, 0.2);
border-top: 0px;
box-sizing: border-box;
padding: 10px 6px;
tr{
th,td{
text-align: center!important;
}
}
}
.nodebox {
font-size: 15px;
}
.hostListbox {
flex: 1;
margin-left: 26px;
}
.tablebox {
margin-top: 16px;
}

108
src/app/system-management/analysis-of-the-host/analysis-of-the-host.component.ts

@ -0,0 +1,108 @@
import { HttpClient } from '@angular/common/http';
import { Component, OnInit, AfterViewInit, ViewChild, ViewContainerRef } from '@angular/core';
import { TreeService } from 'src/app/service/tree.service';
import { NzFormatEmitEvent, NzTreeComponent, NzTreeNodeOptions } from 'ng-zorro-antd/tree';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { NzModalService } from 'ng-zorro-antd/modal';
import { NzMessageService } from 'ng-zorro-antd/message';
import { AddhostComponent } from './addhost/addhost.component';
@Component({
selector: 'app-analysis-of-the-host',
templateUrl: './analysis-of-the-host.component.html',
styleUrls: ['./analysis-of-the-host.component.scss']
})
export class AnalysisOfTheHostComponent implements OnInit {
constructor(private fb: FormBuilder, private http: HttpClient, private toTree: TreeService, private modal: NzModalService, private message: NzMessageService, private viewContainerRef: ViewContainerRef) { }
ngOnInit(): void {
this.getAllOrganization()
}
//获取所有组织机构
searchValue = '';
nzExpandAll = false;
totalCount: string
getAllOrganization() {
this.http.get('/api/services/app/Organization/GetAll').subscribe((data: any) => {
this.totalCount = data.result.totalCount
data.result.items.forEach(element => {
element.key = element.id
element.title = element.displayName
element.selectable = false
});
this.nodes = [...this.toTree.toTree(data.result.items)]
this.defaultExpandedKeys = [...this.defaultExpandedKeys]
})
}
@ViewChild('nzTreeComponent', { static: false }) nzTreeComponent!: NzTreeComponent;
defaultExpandedKeys = [];
nodes: any[] = []
nzSelectedKeys: any[] = []
selectedOilStation:any
nzClick(event: NzFormatEmitEvent): void {
console.log(event.node.origin);
if(event.node.origin.isGasStation){//如果点击的是加油站才生效
this.nzSelectedKeys[0] = event.node.origin.id
this.nzSelectedKeys = [...this.nzSelectedKeys]
this.selectedOilStation = event.node.origin
this.getHost()
}else{
this.message.info('只有加油站才可以增加主机');
}
}
//获得加油站的主机
getHost(){
}
ngAfterViewInit(): void {
}
//新增分析主机
addHost() {
const modal = this.modal.create({
nzTitle: '新增加油站主机',
nzContent: AddhostComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 288,
nzComponentParams: {},
nzOnOk: async () => {
if (instance.validateForm.valid) {
await new Promise(resolve => {
console.log('表单信息', instance.validateForm)
let body = {
// name: instance.validateForm.value.name,
// DisplayName: instance.validateForm.value.name,
// grantedPermissions: arr
}
this.http.post('/api/services/app/Role/Create', body).subscribe(data => {
resolve(data)
this.message.create('success', '创建成功!');
// this.getAllRoles()
return true
})
})
} else {
this.message.create('warning', '请填写完整!');
return false
}
}
});
const instance = modal.getContentComponent();
}
edit(data) {
}
delete(data) {
}
listOfData: any[] = [];
}

1
src/app/system-management/analysis-of-the-host/edithost/edithost.component.html

@ -0,0 +1 @@
<p>edithost works!</p>

0
src/app/system-management/analysis-of-the-host/edithost/edithost.component.scss

15
src/app/system-management/analysis-of-the-host/edithost/edithost.component.ts

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

1
src/app/system-management/navigation/navigation.component.html

@ -16,6 +16,7 @@
<li [routerLink]="['/system/organization']" routerLinkActive="router-link-active"><img src="../../../assets/images/icon/organization.png" alt="">组织机构管理</li>
<li [routerLink]="['/system/user']" routerLinkActive="router-link-active"><img src="../../../assets/images/icon/user.png" alt="">用户管理</li>
<li [routerLink]="['/system/role']" routerLinkActive="router-link-active"><img src="../../../assets/images/icon/role.png" alt="">角色管理</li>
<li [routerLink]="['/system/host']" routerLinkActive="router-link-active"><img src="../../../assets/images/icon/host.png" alt="">分析主机管理</li>
</ul>
</div>
</nz-sider>

4
src/app/system-management/navigation/navigation.component.ts

@ -13,8 +13,6 @@ export class NavigationComponent implements OnInit {
ngOnInit(): void {
}
signOut() {
// history.go(-1);
// /home/warning/admin
this.router.navigate(['/home/warning/admin'])
this.router.navigate(['/plan'])
}
}

4
src/app/system-management/system-management-routing.module.ts

@ -5,11 +5,13 @@ import { AuthGuard } from '../auth.guard'
import { RoleComponent } from './role/role.component';
import { OrganizationComponent } from './organization/organization.component';
import { UserComponent } from './user/user.component';
import { AnalysisOfTheHostComponent } from './analysis-of-the-host/analysis-of-the-host.component';
const routes: Routes = [
{ path: 'organization', component: OrganizationComponent },
{ path: 'user', component: UserComponent },
{ path: 'role', component: RoleComponent }
{ path: 'role', component: RoleComponent },
{ path: 'host', component: AnalysisOfTheHostComponent }
];
@NgModule({

7
src/app/system-management/system-management.module.ts

@ -27,8 +27,11 @@ import { NzTreeSelectModule } from 'ng-zorro-antd/tree-select';
import { AddorComponent } from './organization/addor/addor.component';
import { EditorComponent } from './organization/editor/editor.component';
import { NzCheckboxModule } from 'ng-zorro-antd/checkbox';
import { AnalysisOfTheHostComponent } from './analysis-of-the-host/analysis-of-the-host.component';
import { AddhostComponent } from './analysis-of-the-host/addhost/addhost.component';
import { EdithostComponent } from './analysis-of-the-host/edithost/edithost.component';
@NgModule({
declarations: [OrganizationComponent, UserComponent, RoleComponent, NavigationComponent, AdduserComponent, EdituserComponent, AddroleComponent, EditroleComponent, AddorComponent, EditorComponent],
declarations: [OrganizationComponent, UserComponent, RoleComponent, NavigationComponent, AdduserComponent, EdituserComponent, AddroleComponent, EditroleComponent, AddorComponent, EditorComponent, AnalysisOfTheHostComponent, AddhostComponent, EdithostComponent],
imports: [
CommonModule,
SystemRoutingModule,
@ -50,7 +53,7 @@ import { NzCheckboxModule } from 'ng-zorro-antd/checkbox';
NzTreeSelectModule,
NzCheckboxModule
],
entryComponents :[AdduserComponent,EdituserComponent,AddroleComponent,EditroleComponent,AddorComponent,EditorComponent]
entryComponents :[AdduserComponent,EdituserComponent,AddroleComponent,EditroleComponent,AddorComponent,EditorComponent,AddhostComponent,EdithostComponent]
})
export class SystemManagementModule { }

4
src/app/ui/tabbar/tabbar.component.html

@ -16,8 +16,8 @@
</a>
<nz-dropdown-menu #menu="nzDropdownMenu">
<ul nz-menu nzSelectable>
<li nz-menu-item (click)="navChange('/home/oliStationInfo')">基本信息</li>
<li nz-menu-item (click)="navChange('/home/equipmentInfo')">器材信息</li>
<li nz-menu-item (click)="navChange('/oliStationInfo')">基本信息</li>
<li nz-menu-item (click)="navChange('/equipmentInfo')">器材信息</li>
<li nz-menu-item (click)="navChange('/system/organization')">系统管理</li>
<li nz-menu-item (click)="signOut()">退出系统</li>
</ul>

7
src/app/ui/tabbar/tabbar.component.ts

@ -21,9 +21,10 @@ export class TabbarComponent implements OnInit {
setInterval(() => {
this.getTime()
}, 1000);
this.http.get('/api/services/app/Session/GetCurrentLoginInformations').subscribe((data: any) => {
this.surname = data.result.user.surname
})
this.surname = JSON.parse(sessionStorage.getItem('userdata')).surname
// this.http.get('/api/services/app/Session/GetCurrentLoginInformations').subscribe((data: any) => {
// this.surname = data.result.user.surname
// })
}
//获得时间

BIN
src/assets/images/expand.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1009 B

BIN
src/assets/images/icon/host.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 359 B

BIN
src/assets/images/point.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 524 B

BIN
src/assets/images/stepIcon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

BIN
src/assets/images/unexpand.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1021 B

BIN
src/assets/images/uploadImg.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

BIN
src/assets/images/uploadVideo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

BIN
src/assets/images/warningnum.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.4 KiB

22
src/styles.scss

@ -104,10 +104,24 @@ h1 {
//三维场景
#threeDimensional {
.ant-tree{ color: #C4E2FC; }
.ant-tree,.ant-tree-node-content-wrapper:hover,.ant-tree-node-content-wrapper.ant-tree-node-selected { background-color: transparent; }
.ant-tree-node-content-wrapper { width: 100%; }
.ant-select-single:not(.ant-select-customize-input) .ant-select-selector { border: none; border-radius: 0px; }
.ant-tree{ color: #C4E2FC; } //tree
.ant-tree,.ant-tree-node-content-wrapper:hover,.ant-tree-node-content-wrapper.ant-tree-node-selected { background-color: transparent; } //tree
.ant-tree-node-content-wrapper { width: 100%; } //tree
.ant-select-single:not(.ant-select-customize-input) .ant-select-selector { border: none; border-radius: 0px; } //select
.ant-collapse,.ant-collapse-item,.ant-collapse-header,.ant-collapse-content{ border-radius: 0px; border: none; } //可展开面板
.ant-collapse-content{ background: rgba(0, 59, 110, 0.9); color: #fff; } //可展开面板
.ant-collapse-content-box{ padding: 0; } //可展开面板
.ant-collapse-header{
padding: 0 0 0 25px;
height: 30px;
line-height: 28px;
background: linear-gradient(360deg, #000D21 0%, rgba(0, 59, 110, 0.8) 100%);
border: 1px solid rgba(35, 217, 255, 0.4);
color: #23D9FF;
.ant-collapse-arrow{ left: 5px; } //可展开面板
}
//滚动条样式
::-webkit-scrollbar {
width: 5px;

56
src/theme.less

@ -5,7 +5,8 @@
//分页器
#recordsboxadmin,
#recordsbox,
#equipmentInfo {
#equipmentInfo,
#stationPlanBox {
.ant-pagination-total-text,
.ant-pagination-options-quick-jumper {
@ -40,6 +41,25 @@
color: #91CCFF;
}
//自营和加盟
.ziying,
.jiameng {
display: inline-block;
width: 36px;
height: 20px;
line-height: 20px;
text-align: center;
background: #2399FF;
opacity: 1;
border-radius: 2px;
color: #fff !important;
font-size: 12px;
}
.jiameng {
background: #FF9963;
}
//接收报警弹出框
.ant-notification {
width: 500px;
@ -133,12 +153,17 @@
//表格
#userBox,
#roleBox {
#roleBox,
#hostbox {
.ant-table-thead>tr>th {
background: rgba(145, 204, 255, 0.15);
}
}
#hostbox{
.ant-table-thead > tr > th,.ant-table-tbody > tr > td{
text-align: center;
}
}
@select-background: transparent;
@border-color-base: #91CCFF;
@ -246,3 +271,28 @@
border: none;
}
}
#stationPlanBox {
.ant-tree .ant-tree-node-content-wrapper:hover ,.ant-tree .ant-tree-node-content-wrapper.ant-tree-node-selected{
background: linear-gradient(90deg, rgba(0, 13, 33, 0) 0%, #2399FF 50%, rgba(0, 13, 33, 0) 100%);
}
.ant-tree .ant-tree-node-content-wrapper{
padding: 2px 20px;
// margin-left: 30px;
}
nz-tree{
nz-tree-node{
margin-left: 20px;
}
nz-tree-node:nth-child(1){
margin-left: 0px;
}
}
}
.ant-modal-close-x{
color: #fff;
}
Loading…
Cancel
Save