Browse Source

[完善]增加预警处置功能和状态显示;调试接收预警通知信息

dev
邵佳豪 3 years ago
parent
commit
f0d4cbdc8c
  1. 24
      package-lock.json
  2. 15
      src/app/pages/criminal-records-admin/criminal-records-admin.component.html
  3. 2
      src/app/pages/criminal-records-admin/criminal-records-admin.component.ts
  4. 15
      src/app/pages/criminal-records/criminal-records.component.html
  5. 2
      src/app/pages/criminal-records/criminal-records.component.ts
  6. 21
      src/app/pages/disposition/disposition.component.html
  7. 85
      src/app/pages/disposition/disposition.component.scss
  8. 33
      src/app/pages/disposition/disposition.component.ts
  9. 22
      src/app/pages/home/home.component.html
  10. 43
      src/app/pages/home/home.component.ts
  11. 15
      src/app/pages/login/login.component.html
  12. 7
      src/app/pages/login/login.component.ts
  13. 5
      src/app/pages/pages.module.ts
  14. 20
      src/app/pages/plan-admin/plan-admin.component.html
  15. 1
      src/app/pages/plan-admin/plan-admin.component.ts
  16. 5
      src/app/pages/today-warning-admin/today-warning-admin.component.html
  17. 2
      src/app/pages/today-warning-admin/today-warning-admin.component.scss
  18. 62
      src/app/pages/today-warning-admin/today-warning-admin.component.ts
  19. 6
      src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.html
  20. 3
      src/app/pages/today-warning/get-out-of-line-details/get-out-of-line-details.component.ts
  21. 8
      src/app/pages/today-warning/today-warning.component.html
  22. 2
      src/app/pages/today-warning/today-warning.component.scss
  23. 65
      src/app/pages/today-warning/today-warning.component.ts
  24. BIN
      src/assets/images/3d.png
  25. 5
      src/assets/js/abp.signalr-client.js
  26. 4
      src/shared/helpers/SignalRAspNetCoreHelper.ts
  27. 44
      src/theme.less
  28. 8
      tsconfig.json

24
package-lock.json generated

@ -4874,7 +4874,7 @@
},
"ascli": {
"version": "1.0.1",
"resolved": "https://registry.nlark.com/ascli/download/ascli-1.0.1.tgz",
"resolved": "https://registry.npm.taobao.org/ascli/download/ascli-1.0.1.tgz",
"integrity": "sha1-vPpZdKYvGOgcq660lzKrSoj5Brw=",
"requires": {
"colour": "~0.7.1",
@ -5516,7 +5516,7 @@
"dependencies": {
"long": {
"version": "3.2.0",
"resolved": "https://registry.npmmirror.com/long/download/long-3.2.0.tgz?cache=0&sync_timestamp=1635674102680&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2Flong%2Fdownload%2Flong-3.2.0.tgz",
"resolved": "https://registry.npm.taobao.org/long/download/long-3.2.0.tgz",
"integrity": "sha1-2CG3E4yhy1gcFymQ7xTbIAtcR0s="
}
}
@ -5936,7 +5936,7 @@
},
"colour": {
"version": "0.7.1",
"resolved": "https://registry.nlark.com/colour/download/colour-0.7.1.tgz",
"resolved": "https://registry.npm.taobao.org/colour/download/colour-0.7.1.tgz",
"integrity": "sha1-nLFpkX7F0SwHNtPoaFdG3xyt93g="
},
"combined-stream": {
@ -8226,7 +8226,7 @@
},
"grpc": {
"version": "1.24.2",
"resolved": "https://registry.npmmirror.com/grpc/download/grpc-1.24.2.tgz",
"resolved": "https://registry.npm.taobao.org/grpc/download/grpc-1.24.2.tgz",
"integrity": "sha1-dtBHv6ewW2B8u+OruZBl3O/gwJk=",
"requires": {
"@types/bytebuffer": "^5.0.40",
@ -8271,7 +8271,7 @@
},
"camelcase": {
"version": "2.1.1",
"resolved": "https://registry.npmmirror.com/camelcase/download/camelcase-2.1.1.tgz?cache=0&sync_timestamp=1636945122112&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2Fcamelcase%2Fdownload%2Fcamelcase-2.1.1.tgz",
"resolved": "https://registry.npm.taobao.org/camelcase/download/camelcase-2.1.1.tgz",
"integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8="
},
"chownr": {
@ -8280,7 +8280,7 @@
},
"cliui": {
"version": "3.2.0",
"resolved": "https://registry.nlark.com/cliui/download/cliui-3.2.0.tgz",
"resolved": "https://registry.npm.taobao.org/cliui/download/cliui-3.2.0.tgz?cache=0&sync_timestamp=1573943458671&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcliui%2Fdownload%2Fcliui-3.2.0.tgz",
"integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=",
"requires": {
"string-width": "^1.0.1",
@ -8396,7 +8396,7 @@
},
"invert-kv": {
"version": "1.0.0",
"resolved": "https://registry.nlark.com/invert-kv/download/invert-kv-1.0.0.tgz?cache=0&sync_timestamp=1630996775723&other_urls=https%3A%2F%2Fregistry.nlark.com%2Finvert-kv%2Fdownload%2Finvert-kv-1.0.0.tgz",
"resolved": "https://registry.npm.taobao.org/invert-kv/download/invert-kv-1.0.0.tgz",
"integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY="
},
"is-fullwidth-code-point": {
@ -8537,7 +8537,7 @@
},
"os-locale": {
"version": "1.4.0",
"resolved": "https://registry.npmmirror.com/os-locale/download/os-locale-1.4.0.tgz?cache=0&sync_timestamp=1633618260196&other_urls=https%3A%2F%2Fregistry.npmmirror.com%2Fos-locale%2Fdownload%2Fos-locale-1.4.0.tgz",
"resolved": "https://registry.npm.taobao.org/os-locale/download/os-locale-1.4.0.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fos-locale%2Fdownload%2Fos-locale-1.4.0.tgz",
"integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=",
"requires": {
"lcid": "^1.0.0"
@ -8565,7 +8565,7 @@
},
"protobufjs": {
"version": "5.0.3",
"resolved": "https://registry.nlark.com/protobufjs/download/protobufjs-5.0.3.tgz",
"resolved": "https://registry.npm.taobao.org/protobufjs/download/protobufjs-5.0.3.tgz",
"integrity": "sha1-5N/p+2fJCyYw0VhoJJvMSWFGehc=",
"requires": {
"ascli": "~1",
@ -8694,7 +8694,7 @@
},
"yargs": {
"version": "3.32.0",
"resolved": "https://registry.npmmirror.com/yargs/download/yargs-3.32.0.tgz",
"resolved": "https://registry.npm.taobao.org/yargs/download/yargs-3.32.0.tgz?cache=0&sync_timestamp=1577940861093&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fyargs%2Fdownload%2Fyargs-3.32.0.tgz",
"integrity": "sha1-AwiOnr+edWtpdRYR0qXvWRSCyZU=",
"requires": {
"camelcase": "^2.0.1",
@ -10875,7 +10875,7 @@
},
"lodash.clone": {
"version": "4.5.0",
"resolved": "https://registry.nlark.com/lodash.clone/download/lodash.clone-4.5.0.tgz",
"resolved": "https://registry.npm.taobao.org/lodash.clone/download/lodash.clone-4.5.0.tgz",
"integrity": "sha1-GVhwRQ9aExkkeN9Lw9I9LeoZB7Y="
},
"lodash.clonedeep": {
@ -12053,7 +12053,7 @@
},
"optjs": {
"version": "3.2.2",
"resolved": "https://registry.nlark.com/optjs/download/optjs-3.2.2.tgz",
"resolved": "https://registry.npm.taobao.org/optjs/download/optjs-3.2.2.tgz",
"integrity": "sha1-aabOicRCpEQDFBrS+bNwvVu29O4="
},
"ora": {

15
src/app/pages/criminal-records-admin/criminal-records-admin.component.html

@ -110,7 +110,7 @@
<div nz-col nzSpan="3">
预警类型
</div>
<div nz-col nzSpan="4">
<div nz-col nzSpan="3">
所属公司
</div>
<div nz-col nzSpan="2">
@ -119,7 +119,7 @@
<div nz-col nzSpan="1">
</div>
<div nz-col nzSpan="4">
<div nz-col nzSpan="3">
加油站
</div>
<div nz-col nzSpan="3">
@ -128,6 +128,9 @@
<div nz-col nzSpan="3">
预警时间
</div>
<div nz-col nzSpan="2">
状态
</div>
<div nz-col nzSpan="1">
操作
</div>
@ -153,7 +156,7 @@
<div nz-col nzSpan="3">
{{item.violation.violationType}}
</div>
<div nz-col nzSpan="4">
<div nz-col nzSpan="3">
{{item.gasStation.companyName}}
</div>
<div nz-col nzSpan="2">
@ -162,7 +165,7 @@
<div nz-col nzSpan="1" style="text-align: right;box-sizing: border-box;padding-right: 8px;">
<!-- <span class="ziying">自营</span> -->
</div>
<div nz-col nzSpan="4">
<div nz-col nzSpan="3">
{{item.gasStation.stationName}}
</div>
<div nz-col nzSpan="3">
@ -171,6 +174,10 @@
<div nz-col nzSpan="3">
{{item.violateTime | date:"yyyy-MM-dd HH:mm:ss"}}
</div>
<div nz-col nzSpan="2">
<span *ngIf="item.handleTime">已处置</span>
<span *ngIf="!item.handleTime" style="color: #FF4B65;">未处置</span>
</div>
<div nz-col nzSpan="1">
<span class="look" (click)="look(item)">查看</span>
</div>

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

@ -146,7 +146,7 @@ export class CriminalRecordsAdminComponent implements OnInit {
left: '42px',
right: '30px',
bottom: '38px',
top: '60px'
top: '80px'
}
};
baroption2 = {

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

@ -106,10 +106,10 @@
<div nz-col nzSpan="3">
预警级别
</div>
<div nz-col nzSpan="5">
<div nz-col nzSpan="4">
预警类型
</div>
<div nz-col nzSpan="5">
<div nz-col nzSpan="4">
预警信息
</div>
<div nz-col nzSpan="4">
@ -118,6 +118,9 @@
<div nz-col nzSpan="4">
预警时间
</div>
<div nz-col nzSpan="2">
状态
</div>
<div nz-col nzSpan="2">
操作
</div>
@ -140,10 +143,10 @@
<span *ngIf="item.violation.level == 3">Ⅲ级</span>
<span *ngIf="item.violation.level == 4">Ⅳ级</span>
</div>
<div nz-col nzSpan="5">
<div nz-col nzSpan="4">
{{item.violation.violationType}}
</div>
<div nz-col nzSpan="5">
<div nz-col nzSpan="4">
{{item.violation.violationName}}
</div>
<div nz-col nzSpan="4">
@ -152,6 +155,10 @@
<div nz-col nzSpan="4">
{{item.violateTime | date:"yyyy-MM-dd HH:mm:ss"}}
</div>
<div nz-col nzSpan="2">
<span *ngIf="item.handleTime">已处置</span>
<span *ngIf="!item.handleTime" style="color: #FF4B65;">未处置</span>
</div>
<div nz-col nzSpan="2">
<span class="look" (click)="look(item)">查看</span>
</div>

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

@ -143,7 +143,7 @@ export class CriminalRecordsComponent implements OnInit {
left: '42px',
right: '30px',
bottom: '38px',
top: '60px'
top: '80px'
}
};
baroption2 = {

21
src/app/pages/disposition/disposition.component.html

@ -0,0 +1,21 @@
<div class="box" id="addequipment">
<div class="title">
<div class="titlecontent">
处置
</div>
<i nz-icon nzType="close" nzTheme="outline" (click)="destroyModal()"></i>
</div>
<form nz-form [formGroup]="validateForm" class="form">
<p>处置内容</p>
<nz-form-item>
<nz-form-control>
<textarea formControlName="content"></textarea>
</nz-form-control>
</nz-form-item>
<p>处置人: <span>{{peopleName}}</span> </p>
<div class="btnbox">
<button nz-button type="submit" class="ok" (click)="ok()">确定</button>
<button nz-button type="button" class="cancel" (click)="destroyModal()">取消</button>
</div>
</form>
</div>

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

@ -0,0 +1,85 @@
.box {
.title {
font-family: sybold;
width: 100%;
height: 48px;
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;
align-items: center;
position: relative;
.titlecontent {
width: 100%;
height: 32px;
line-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%);
text-align: center;
color: #91CCFF;
font-size: 16px;
}
i {
position: absolute;
right: 12px;
color: #fff;
font-size: 18px;
cursor: pointer;
}
}
.form {
box-sizing: border-box;
padding: 0 17px;
p {
margin-bottom: 0;
color: #C4E2FC;
margin: 16px 0;
}
nz-form-item {
margin-bottom: 0;
textarea {
color: rgba(145, 204, 255, 0.95) !important;
width: 100%;
height: 300px;
background: #173d60;
}
}
nz-date-picker {
background-color: #143c61;
width: 100%;
}
.btnbox {
width: 100%;
margin-top: 24px;
margin-bottom: 17px;
display: flex;
justify-content: flex-end;
button {
border-radius: 0px;
color: #91CCFF;
}
button:nth-child(2) {
margin-left: 16px;
}
.ok {
background: rgba(0, 129, 255, 0.4);
}
.cancel {
border: 1px solid #C4E2FC;
background: #0c1e38;
color: rgba(99, 102, 105, 0.6);
box-shadow: 0 0 3px 0 #fff inset;
}
}
}
}

33
src/app/pages/disposition/disposition.component.ts

@ -0,0 +1,33 @@
import { Component, OnInit } from '@angular/core';
import { NzModalRef } from 'ng-zorro-antd/modal';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
@Component({
selector: 'app-disposition',
templateUrl: './disposition.component.html',
styleUrls: ['./disposition.component.scss']
})
export class DispositionComponent implements OnInit {
validateForm!: FormGroup;
constructor(private modal: NzModalRef, private fb: FormBuilder) { }
peopleName:string
ngOnInit(): void {
if(sessionStorage.getItem('isGasStation') == 'true'){
this.peopleName = JSON.parse(sessionStorage.getItem('userdataOfgasstation')).name
}else{
this.peopleName = JSON.parse(sessionStorage.getItem('userdata')).name
}
this.validateForm = this.fb.group({
content: [null, [Validators.required]]
});
}
destroyModal(){
this.modal.destroy();
}
ok(){
this.modal.triggerOk()
}
}

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

@ -59,4 +59,24 @@
<div class="content">
<router-outlet></router-outlet>
</div>
</div>
</div>
<ng-template #warning let-item="data">
<div class="topbox">
<div>
<img src="../assets/images/AnXinQQ.jpg" alt="">
</div>
<div class="text">
<span class="name">您有一条新的预警提醒!</span>
<span class="details">{{item.id}}</span>
</div>
</div>
<div class="btnbox">
<div class="look">
查看
</div>
<div class="lose" (click)="close(item)">
忽略
</div>
</div>
</ng-template>

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

@ -1,14 +1,14 @@
import { Component, OnInit } from '@angular/core';
import { Component, OnInit, ViewChild, TemplateRef } from '@angular/core';
import { Router, NavigationEnd, ActivatedRoute } from '@angular/router';
import { Title } from '@angular/platform-browser'
import { filter } from 'rxjs/operators';
import { NavChangeService } from 'src/app/service/navChange.service';
import { NavChangeService } from '../../service/navChange.service';
import { CacheTokenService } from '../../service/cache-token.service' //引入服务
import { CookieService } from 'ngx-cookie-service';
import { NzMessageService } from 'ng-zorro-antd/message';
import { SignalRAspNetCoreHelper } from '../../../shared/helpers/SignalRAspNetCoreHelper';
import { NzNotificationService } from 'ng-zorro-antd/notification';
declare var abp: any
@Component({
selector: 'app-home',
@ -16,9 +16,10 @@ import { SignalRAspNetCoreHelper } from '../../../shared/helpers/SignalRAspNetCo
styleUrls: ['./home.component.scss']
})
export class HomeComponent implements OnInit {
@ViewChild('warning', { static: false }) template?: TemplateRef<{}>;
constructor(private router: Router, private navChangeService: NavChangeService, public token: CacheTokenService,
private cookieService: CookieService, private message: NzMessageService) { }
private cookieService: CookieService, private message: NzMessageService, private notificationService: NzNotificationService) { }
isGasStationNav: boolean
isGasStation: boolean
isGasStationBack: boolean
@ -78,13 +79,39 @@ export class HomeComponent implements OnInit {
this.userName = JSON.parse(sessionStorage.getItem('userdata')).userName
}
}
ngAfterViewInit() {
SignalRAspNetCoreHelper.initSignalR();
abp.event.on('abp.notifications.received', function (userNotification) {
console.log('abp.notifications.received成功收到了哈哈哈', userNotification);
abp.event.on('abp.notifications.received', (userNotification) => {
console.log('abp.notifications.received收到通知', userNotification);
this.receiptOfNotification(userNotification)
});
}
messageId=[]
receiptOfNotification(userNotification) {
let obj = {
id:'xxx',
messageId:this.notificationService.template(this.template!, {nzPlacement: 'bottomRight', nzClass: 'receiptOfNotification', nzDuration: 0, nzData: userNotification}).messageId
}
this.messageId.push(obj)
console.log(99999,this.messageId)
}
close(item){
this.messageId.forEach((element)=>{
if(element.id == 'xxx'){
this.notificationService.remove(element.messageId)
}
})
}
ngOnDestroy() {
abp.signalr.disconnect()
}
//获得时间
time: string

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

@ -61,18 +61,3 @@
</div>
<ng-template>
<div class="topbox">
<div>
<img src="../assets/images/AnXinQQ.jpg" alt="">
</div>
<div class="text">
<span>您有一条新的预警提醒!</span>
<span>这是详细描述这是详细描述这是详细描述...</span>
</div>
</div>
<div class="btnbox">
<button class="look" nz-button type="button">查看</button>
<button class="lose" nz-button type="button">忽略</button>
</div>
</ng-template>

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

@ -1,4 +1,4 @@
import { Component, OnInit, AfterViewInit, ViewChild, TemplateRef } from '@angular/core';
import { Component, OnInit } from '@angular/core';
import { HttpClient } from '@angular/common/http'
import { Router, ActivatedRoute } from '@angular/router'
import { CacheTokenService } from '../../service/cache-token.service'//引入服务
@ -18,7 +18,6 @@ declare var abp: any
export class LoginComponent implements OnInit {
validateForm!: FormGroup;
@ViewChild(TemplateRef, { static: false }) template?: TemplateRef<{}>;
constructor(private http: HttpClient, private router: Router, private route: ActivatedRoute, public token: CacheTokenService, private cookieService: CookieService, private fb: FormBuilder, private message: NzMessageService, private notificationService: NzNotificationService) { }
ngOnInit() {
@ -149,10 +148,6 @@ export class LoginComponent implements OnInit {
)
}
receiptOfNotification() {
this.notificationService.template(this.template!, { nzPlacement: 'bottomRight', nzClass: 'receiptOfNotification', nzDuration: 0 });
}
roleList = [
'管理员', '职工'
]

5
src/app/pages/pages.module.ts

@ -48,11 +48,12 @@ 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';
import { NzNotificationModule } from 'ng-zorro-antd/notification';
import { DispositionComponent } from './disposition/disposition.component';
@NgModule({
declarations: [LoginComponent, RegisterComponent, HomeComponent, PlanComponent, TodayWarningComponent, CriminalRecordsComponent,
TodayWarningAdminComponent, CriminalRecordsAdminComponent, LeftDomainComponent, EquipmentInfoComponent, OilStationInfoComponent,
AddequipmentComponent, EditequipmentComponent,PlanAdminComponent, GetOutOfLineDetailsComponent],
AddequipmentComponent, EditequipmentComponent,PlanAdminComponent, GetOutOfLineDetailsComponent, DispositionComponent],
imports: [
@ -92,7 +93,7 @@ import { NzNotificationModule } from 'ng-zorro-antd/notification';
NzNotificationModule,
NzPopconfirmModule
],
entryComponents: [AddequipmentComponent, EditequipmentComponent,GetOutOfLineDetailsComponent],
entryComponents: [AddequipmentComponent, EditequipmentComponent,GetOutOfLineDetailsComponent,DispositionComponent],
schemas: [CUSTOM_ELEMENTS_SCHEMA]
})

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

@ -5,9 +5,9 @@
<app-title [name]="'组织机构'"></app-title>
</div>
<div class="or">
<nz-tree [nzExpandedKeys]="nzExpandedKeys" [nzSelectedKeys]="nzSelectedKeys" [nzShowExpand]="false" #nzTreeComponent [nzExpandAll]="nzExpandAll"
nzBlockNode [nzData]="nodes" (nzClick)="activeNode($event)" [nzTreeTemplate]="nzTreeTemplate"
[nzMultiple]="false"></nz-tree>
<nz-tree [nzExpandedKeys]="nzExpandedKeys" [nzSelectedKeys]="nzSelectedKeys" [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="">
@ -52,10 +52,12 @@
</div>
<div class="tablebox" id="tablebox">
<nz-table [nzPageSize]='999' #headerTable [nzData]="list" [nzShowPagination]="false" [nzScroll]="{ y:tableheight() }">
<nz-table [nzPageSize]='999' #headerTable [nzData]="list" [nzShowPagination]="false"
[nzScroll]="{ y:tableheight() }">
<thead>
<tr>
<th style="text-align: center;">加油站名称</th>
<th></th>
<th>加油站名称</th>
<th>区域</th>
<th>所属公司</th>
<th>联系人</th>
@ -70,7 +72,9 @@
</thead>
<tbody id="table">
<tr *ngFor="let item of headerTable.data;let key = index">
<th style="text-align: center;">{{item.stationName}}</th>
<th style="text-align: right;box-sizing: border-box;padding-right: 8px;"><img
src="../../../assets/images/3d.png" alt="" *ngIf="item.hasBuildingInfo"></th>
<th>{{item.stationName}}</th>
<th>{{item.locationName}}</th>
<th>{{item.companyName}}</th>
<th>{{item.leaderName}}</th>
@ -88,7 +92,7 @@
</nz-table>
<!--
<!--
<div class="pagination">
<nz-pagination [nzPageIndex]="1" [nzTotal]="85" [nzPageSize]="20" [nzShowTotal]="totalTemplate"
nzShowQuickJumper></nz-pagination>
@ -96,4 +100,4 @@
</div> -->
</div>
</div>
</div>
</div>

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

@ -181,7 +181,6 @@ export class PlanAdminComponent implements OnInit {
// this.list = this.list.concat(data.result.items);
this.list = [...data.result.items]
resolve(data)
// console.log(999999, data)
})
})
}

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

@ -164,8 +164,9 @@
{{item.violateTime | date:"yyyy-MM-dd HH:mm:ss"}}
</div>
<div nz-col nzSpan="2">
<button nz-button (click)="look(item)">查看</button>
<!-- <img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt=""> -->
<button nz-button (click)="look(item)" style="margin-right: 16px;">查看</button>
<button *ngIf="!item.handleTime" nz-button (click)="dispose(item)">处置</button>
<span *ngIf="item.handleTime" style="color: #23D9FF;margin-left: 10px;">已处置</span>
</div>
</div>
</div>

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

@ -95,7 +95,7 @@
background: linear-gradient(180deg, rgba(3, 0, 0, 0) 0%, rgba(0, 46, 91, 0.68) 100%);
box-sizing: border-box;
padding-left: 20px;
padding-right: 60px;
div {
font-size: 15px;
text-align: left;

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

@ -2,15 +2,19 @@ import { Component, OnInit, ViewContainerRef } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { Router } from '@angular/router';
import { HttpClient } from '@angular/common/http';
import { TreeService } from 'src/app/service/tree.service';
import { NzModalService } from 'ng-zorro-antd/modal';
import { GetOutOfLineDetailsComponent } from '../today-warning/get-out-of-line-details/get-out-of-line-details.component';
import * as moment from 'moment';
import { NavChangeService } from 'src/app/service/navChange.service';
// import { TreeService } from 'src/app/service/tree.service';
// import { NavChangeService } from 'src/app/service/navChange.service';
import { TreeService } from '../../service/tree.service';
import { NavChangeService } from '../../service/navChange.service';
import 'linqjs';
import { DispositionComponent } from '../disposition/disposition.component';
import { NzMessageService } from 'ng-zorro-antd/message';
@Component({
selector: 'app-today-warning-admin',
@ -20,7 +24,7 @@ import 'linqjs';
export class TodayWarningAdminComponent implements OnInit {
validateForm!: FormGroup;
constructor(private http: HttpClient, private fb: FormBuilder, private router: Router, private toTree: TreeService, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private navChangeService: NavChangeService) { }
constructor(private http: HttpClient, private fb: FormBuilder, private router: Router, private toTree: TreeService, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private navChangeService: NavChangeService, private message: NzMessageService) { }
ngOnInit(): void {
this.validateForm = this.fb.group({
@ -105,6 +109,8 @@ export class TodayWarningAdminComponent implements OnInit {
ViolateArea: this.validateForm.value.area,
organizationUnitId: this.validateForm.value.organization,
ViolateTime: (this.validateForm.value.datePickerEnd && this.validateForm.value.datePickerStart) ? [moment(this.validateForm.value.datePickerStart).format('yyyy-MM-DD HH:mm:ss'), moment(this.validateForm.value.datePickerEnd).format('yyyy-MM-DD HH:mm:ss')] : null,
// ViolateTime: ['2021-10-27', '2021-11-26'],
IsContainsChildren: 'true',
SkipCount: '0',
MaxResultCount: '9999'
}
@ -155,6 +161,12 @@ export class TodayWarningAdminComponent implements OnInit {
look(item) {
let type
if (item.violation.violationType.indexOf('卸油')) {
type = 1
} else {
type = 0
}
const modal = this.modal.create({
nzContent: GetOutOfLineDetailsComponent,
nzViewContainerRef: this.viewContainerRef,
@ -167,7 +179,8 @@ export class TodayWarningAdminComponent implements OnInit {
'background': '#000D21',
},
nzComponentParams: {
data: item
data: item,
type: type
},
nzFooter: null,
nzOnOk: async () => {
@ -176,4 +189,43 @@ export class TodayWarningAdminComponent implements OnInit {
});
const instance = modal.getContentComponent();
}
dispose(item) {
console.log(item)
const modal = this.modal.create({
nzContent: DispositionComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 380,
nzBodyStyle: {
'border': '1px solid #91CCFF',
'border-radius': '0px',
'padding': '7px',
'box-shadow': '0 0 8px 0 #fff',
'background-image': 'linear-gradient(#003665, #000f25)'
},
nzComponentParams: {},
nzFooter: null,
nzClosable: false,
nzOnOk: async () => {
if (instance.validateForm.valid) {
await new Promise(resolve => {
let body = {
id: item.id,
handleRecord: instance.validateForm.value.content
}
this.http.post('/api/services/app/ViolateRecord/HandleViolateRecord', body).subscribe(data => {
resolve(data)
this.message.create('success', '处置成功!');
item.handleTime = new Date()
return true
})
})
} else {
this.message.create('warning', '请填写完整!');
return false
}
},
});
const instance = modal.getContentComponent();
}
}

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

@ -19,7 +19,7 @@
</div>
</div>
<div class="content">
<div *ngIf="data.type == 0 && selectedType == 'img'" class="imgbox">
<div *ngIf="type == 0 && selectedType == 'img'" class="imgbox">
<!-- <div class="imglist">
<span class="imglisttitle">截图列表</span>
<div class="img">
@ -30,10 +30,10 @@
<img [src]="imgUrl" alt="">
</div>
</div>
<div style="width: 100%;height: 100%;" *ngIf="data.type == 0 && selectedType == 'video'" class="vediobox">
<div style="width: 100%;height: 100%;" *ngIf="type == 0 && selectedType == 'video'" class="vediobox">
<video controls style="width: 100%;height: 100%;" [src]="vedioUrl"></video>
</div>
<div *ngIf="data.type != 0" class="oilbox">
<div *ngIf="type != 0" class="oilbox">
<div class="leftbox">
<div class="lefttop">
<div class="title">

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

@ -8,14 +8,13 @@ import Viewer from 'viewerjs'
export class GetOutOfLineDetailsComponent implements OnInit {
@Input() data: any
@Input() type: any
constructor() { }
imgUrl: string
vedioUrl: string
ngOnInit(): void {
this.data.type = 1
this.imgUrl = this.data.violateImage
this.vedioUrl = this.data.violateVideo
}

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

@ -111,11 +111,9 @@
{{item.violateTime | date:"yyyy-MM-dd HH:mm:ss"}}
</div>
<div nz-col nzSpan="2">
<button nz-button (click)="look(item)" style="margin-right: 8px;">查看</button>
<button *ngIf="!item.handleTime" nz-button (click)="disposition(item)">处置</button>
<span *ngIf="item.handleTime" class="dispositioned">已处置</span>
<!-- <img style="margin-left: 24px;cursor: pointer;" src="../../../assets/images/excel.png" alt=""> -->
<button nz-button (click)="look(item)" style="margin-right: 16px;">查看</button>
<button *ngIf="!item.handleTime" nz-button (click)="dispose(item)">处置</button>
<span *ngIf="item.handleTime" style="color: #23D9FF;margin-left: 10px;">已处置</span>
</div>
</div>
</div>

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

@ -88,7 +88,7 @@
margin-bottom: 12px;
background: linear-gradient(180deg, rgba(3, 0, 0, 0) 0%, rgba(0, 46, 91, 0.68) 100%);
box-sizing: border-box;
padding-right: 36px;
padding-right: 60px;
div {
font-size: 15px;
text-align: center;

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

@ -3,9 +3,13 @@ import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { HttpClient } from '@angular/common/http';
import { NzModalService } from 'ng-zorro-antd/modal';
import { GetOutOfLineDetailsComponent } from './get-out-of-line-details/get-out-of-line-details.component';
import { TreeService } from 'src/app/service/tree.service';
import { NavChangeService } from 'src/app/service/navChange.service';
// import { TreeService } from 'src/app/service/tree.service';
// import { NavChangeService } from 'src/app/service/navChange.service';
import { TreeService } from '../../service/tree.service';
import { NavChangeService } from '../../service/navChange.service';
import * as moment from 'moment';
import { DispositionComponent } from '../disposition/disposition.component';
import { NzMessageService } from 'ng-zorro-antd/message';
@Component({
selector: 'app-today-warning',
templateUrl: './today-warning.component.html',
@ -13,7 +17,7 @@ import * as moment from 'moment';
})
export class TodayWarningComponent implements OnInit {
validateForm!: FormGroup;
constructor(private http: HttpClient, private fb: FormBuilder, private toTree: TreeService, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private navChangeService: NavChangeService) { }
constructor(private http: HttpClient, private fb: FormBuilder, private toTree: TreeService, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private navChangeService: NavChangeService, private message: NzMessageService) { }
ngOnInit(): void {
this.validateForm = this.fb.group({
@ -62,6 +66,8 @@ export class TodayWarningComponent implements OnInit {
ViolateArea: this.validateForm.value.area,
organizationUnitId: JSON.parse(sessionStorage.getItem('userdataOfgasstation')).organization.id,
ViolateTime: (this.validateForm.value.datePickerEnd && this.validateForm.value.datePickerStart) ? [moment(this.validateForm.value.datePickerStart).format('yyyy-MM-DD HH:mm:ss'), moment(this.validateForm.value.datePickerEnd).format('yyyy-MM-DD HH:mm:ss')] : null,
// ViolateTime: ['2021-10-27', '2021-11-26'],
IsContainsChildren: 'true',
SkipCount: '0',
MaxResultCount: '9999'
}
@ -107,6 +113,12 @@ export class TodayWarningComponent implements OnInit {
look(item) {
let type
if (item.violation.violationType.indexOf('卸油')) {
type = 1
} else {
type = 0
}
const modal = this.modal.create({
nzContent: GetOutOfLineDetailsComponent,
nzViewContainerRef: this.viewContainerRef,
@ -119,7 +131,8 @@ export class TodayWarningComponent implements OnInit {
'background': '#000D21',
},
nzComponentParams: {
data: item
data: item,
// typy: type
},
nzFooter: null,
nzOnOk: async () => {
@ -129,7 +142,47 @@ export class TodayWarningComponent implements OnInit {
const instance = modal.getContentComponent();
}
disposition(item){
dispose(item) {
console.log(item)
if (item.isEnableHandle) {
const modal = this.modal.create({
nzContent: DispositionComponent,
nzViewContainerRef: this.viewContainerRef,
nzWidth: 380,
nzBodyStyle: {
'border': '1px solid #91CCFF',
'border-radius': '0px',
'padding': '7px',
'box-shadow': '0 0 8px 0 #fff',
'background-image': 'linear-gradient(#003665, #000f25)'
},
nzComponentParams: {},
nzFooter: null,
nzClosable: false,
nzOnOk: async () => {
if (instance.validateForm.valid) {
await new Promise(resolve => {
let body = {
id: item.id,
handleRecord: instance.validateForm.value.content
}
this.http.post('/api/services/app/ViolateRecord/HandleViolateRecord', body).subscribe(data => {
resolve(data)
this.message.create('success', '处置成功!');
item.handleTime = new Date()
return true
})
})
} else {
this.message.create('warning', '请填写完整!');
return false
}
},
});
const instance = modal.getContentComponent();
} else {
this.message.create('warning', '无处置权限!');
}
}
}

BIN
src/assets/images/3d.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 630 B

5
src/assets/js/abp.signalr-client.js

@ -84,7 +84,10 @@ var abp = abp || {};
abp.log.debug(error.message);
});
}
abp.signalr.disconnect = function() {
abp.signalr.autoReconnect = false
abp.signalr.hubs.common.stop()
};
// Starts a connection with transport fallback - if the connection cannot be started using
// the webSockets transport the function will fallback to the serverSentEvents transport and
// if this does not work it will try longPolling. If the connection cannot be started using

4
src/shared/helpers/SignalRAspNetCoreHelper.ts

@ -1,6 +1,6 @@
declare var abp: any
export class SignalRAspNetCoreHelper {
static initSignalR(callback?: () => void): void {
static initSignalR(callback?: () => void): void {
const encryptedAuthToken = sessionStorage.getItem("encryptedAccessToken");
let url = "http://39.106.78.171:8906";
abp.signalr = {

44
src/theme.less

@ -68,7 +68,7 @@
.receiptOfNotification {
height: 160px;
background-color: rgba(1, 13, 27, 0.9);
box-shadow: 0 0 36px 3px #8f1622 inset;
box-shadow: 0 0 28px 3px #8f1622 inset;
display: flex;
flex-direction: column;
padding: 5px;
@ -77,40 +77,48 @@
position: relative;
flex: 1;
display: flex;
align-items: center;
img {
max-width: 64px;
max-height: 64px;
max-width:70px;
max-height: 62px;
}
.text {
display: flex;
flex-direction: column;
color: white;
justify-content: center;
span{
// display: inline-block;
margin: 6px 0;
}
.name{
font-size: 16px;
color: #ffaaaa;
}
.details{
font-size: 14px;
color: white;
}
}
}
.btnbox {
height: 30px;
height: 36px;
line-height: 36px;
display: flex;
justify-content: center;
align-items: center;
margin: 12px 0;
button {
margin: 0 5px;
div{
width: 80px;
height: 32px;
line-height: 32px;
text-align: center;
margin: 0 8px;
color: #FFFFFF;
cursor: pointer;
}
}
button {
width: 64px;
height: 30px;
line-height: 30px;
background-color: rgba(1, 13, 27, 0.9);
color: white;
border: 0px;
}
.look {
box-shadow: 0 0 12px #8f1622 inset;

8
tsconfig.json

@ -31,8 +31,8 @@
"strictInjectionParameters": true,
"enableIvy": false
},
"include": [
"src/**/*.d.ts",
"typings.d.ts"
]
// "include": [
// "src/**/*.d.ts",
// "typings.d.ts"
// ]
}

Loading…
Cancel
Save