75 changed files with 4161 additions and 586 deletions
@ -0,0 +1,28 @@
|
||||
<div class="box informTime" id="inform"> |
||||
<div class="tablebox" id="tablebox"> |
||||
<nz-table *ngIf="tableScrollHeight" [nzLoading]="tableSpin" [nzPageSize]='9999' #headerTable [nzData]="list" |
||||
[nzShowPagination]="false" [nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th>审批类型</th> |
||||
<th>是否年检</th> |
||||
<th>年检时间</th> |
||||
<th>操作</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td>{{item.licenseName}}</td> |
||||
<td> |
||||
{{item.isYearlyCheck ? '是' : '否'}} |
||||
</td> |
||||
<td>{{item.yearlyCheckDate | date:"MM/dd"}}</td> |
||||
<td class="operation"> |
||||
<span [ngClass]="{'greyColor': !item.isYearlyCheck}" class="blueColor" (click)="edit(item)">编辑</span> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,15 @@
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
} |
||||
|
||||
.tablebox { |
||||
width: 100%; |
||||
height: 100%; |
||||
|
||||
.operation { |
||||
span { |
||||
margin-right: 6px; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,84 @@
|
||||
import { HttpClient } from '@angular/common/http'; |
||||
import { Component, ElementRef, OnInit, ViewContainerRef } from '@angular/core'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
import { Observable, fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import { EditAnnualInspectionComponent } from './edit-annual-inspection/edit-annual-inspection.component'; |
||||
@Component({ |
||||
selector: 'app-annual-inspection', |
||||
templateUrl: './annual-inspection.component.html', |
||||
styleUrls: ['./annual-inspection.component.scss'] |
||||
}) |
||||
export class AnnualInspectionComponent implements OnInit { |
||||
|
||||
constructor(private modal: NzModalService, private viewContainerRef: ViewContainerRef, private http: HttpClient, private message: NzMessageService, private element: ElementRef) { } |
||||
tableSpin = false |
||||
|
||||
tableScrollHeight |
||||
ngOnInit(): void { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
}); |
||||
this.getAnnualInspectionList() |
||||
} |
||||
|
||||
|
||||
|
||||
list = [] |
||||
totalCount;//列表总数
|
||||
SkipCount: string = '0'; |
||||
MaxResultCount: string = '100'; |
||||
//获取当前油站档案类证照
|
||||
getAnnualInspectionList() { |
||||
this.tableSpin = true |
||||
let data = JSON.parse(sessionStorage.getItem('userdata')); |
||||
let params = { |
||||
OrganizationUnitId: data.organization.id || "", |
||||
IsContainsChildren: "true", |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
} |
||||
this.http.get(`/api/services/app/OrganizationValidityLicenseRule/GetCurOrgYearlyCheckRules`, { params }).subscribe((data: any) => { |
||||
|
||||
this.list = data.result |
||||
this.list = [...this.list] |
||||
this.tableSpin = false |
||||
console.log(data) |
||||
}) |
||||
} |
||||
|
||||
|
||||
edit(item) { |
||||
console.log('item', item) |
||||
if (!item.isYearlyCheck) { |
||||
this.message.create('warning', '不需要年检'); |
||||
return |
||||
} |
||||
|
||||
const modal = this.modal.create({ |
||||
nzContent: EditAnnualInspectionComponent, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: 450, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzComponentParams: { |
||||
data: item |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
nzOnOk: async () => { |
||||
this.getAnnualInspectionList() |
||||
} |
||||
}); |
||||
const instance = modal.getContentComponent(); |
||||
modal.afterClose.subscribe(result => { }); |
||||
} |
||||
} |
@ -0,0 +1,33 @@
|
||||
<div class="box" id="editfilecategory"> |
||||
<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"> |
||||
|
||||
<div class="timebox"> |
||||
<div> |
||||
<p>请选择年检日期</p> |
||||
|
||||
<nz-form-item> |
||||
<nz-form-control> |
||||
<!-- <nz-input-group> |
||||
<input nz-input type="number" formControlName="time1" placeholder="请选择月份" /> |
||||
</nz-input-group> --> |
||||
<nz-date-picker [nzFormat]="dateFormat" style="width: 100%;" formControlName="time"></nz-date-picker> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
<!-- |
||||
<p class="p2">默认时间: 90天</p> --> |
||||
</div> |
||||
</div> |
||||
|
||||
|
||||
<div class="btnbox"> |
||||
<button nz-button type="submit" class="ok" (click)="ok()" [nzLoading]="isLoading">保存</button> |
||||
<button nz-button type="button" class="cancel" (click)="destroyModal()">取消</button> |
||||
</div> |
||||
</form> |
||||
</div> |
@ -0,0 +1,105 @@
|
||||
.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; |
||||
} |
||||
} |
||||
|
||||
|
||||
|
||||
|
||||
p { |
||||
margin-bottom: 0; |
||||
color: #C4E2FC; |
||||
margin: 12px 0; |
||||
} |
||||
|
||||
.p2 { |
||||
margin: 6px 0; |
||||
font-size: 12px; |
||||
color: #C4E2FC; |
||||
} |
||||
|
||||
.form { |
||||
box-sizing: border-box; |
||||
padding: 0 17px; |
||||
|
||||
.timebox { |
||||
display: flex; |
||||
|
||||
div { |
||||
flex: 1; |
||||
display: flex; |
||||
flex-direction: column; |
||||
box-sizing: border-box; |
||||
padding: 0 6px; |
||||
} |
||||
} |
||||
|
||||
.explain { |
||||
box-sizing: border-box; |
||||
padding: 0 6px; |
||||
|
||||
textarea { |
||||
width: 100%; |
||||
height: 100px; |
||||
|
||||
background: rgba(145, 204, 255, 0.16); |
||||
color: #fff; |
||||
} |
||||
} |
||||
|
||||
.btnbox { |
||||
width: 100%; |
||||
margin-top: 24px; |
||||
margin-bottom: 17px; |
||||
display: flex; |
||||
justify-content: flex-end; |
||||
box-sizing: border-box; |
||||
padding: 0 7px; |
||||
|
||||
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; |
||||
} |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,64 @@
|
||||
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'; |
||||
import { ObjectsSimpleService } from 'src/app/service/objectsSimple.service'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
import * as moment from 'moment'; |
||||
|
||||
@Component({ |
||||
selector: 'app-edit-annual-inspection', |
||||
templateUrl: './edit-annual-inspection.component.html', |
||||
styleUrls: ['./edit-annual-inspection.component.scss'] |
||||
}) |
||||
export class EditAnnualInspectionComponent implements OnInit { |
||||
|
||||
|
||||
@Input() data?: any; |
||||
|
||||
validateForm!: FormGroup; |
||||
constructor(private message: NzMessageService, private modal: NzModalRef, private fb: FormBuilder, private http: HttpClient, private objectsSrv: ObjectsSimpleService) { } |
||||
|
||||
|
||||
dataCopy |
||||
ngOnInit(): void { |
||||
this.dataCopy = JSON.parse(JSON.stringify(this.data)) |
||||
this.validateForm = this.fb.group({ |
||||
time: [null, [Validators.required]], |
||||
}); |
||||
|
||||
} |
||||
|
||||
|
||||
destroyModal() { |
||||
this.modal.destroy({ data: 'this the result data' }); |
||||
|
||||
} |
||||
|
||||
|
||||
isLoading = false |
||||
ok() { |
||||
if (this.validateForm.valid) { |
||||
this.isLoading = true |
||||
let body = { |
||||
licenseTypeId: this.dataCopy.licenseTypeId, |
||||
organizationId: JSON.parse(sessionStorage.getItem('userdata')).organization.id, |
||||
yearlyCheckDate: moment(this.validateForm.value.time).format('YYYY-MM-MM')//开业时间格式化
|
||||
} |
||||
this.http.put('/api/services/app/OrganizationValidityLicenseRule/UpdateYearlyCheckDate', body).subscribe((data) => { |
||||
this.message.create('success', '修改成功'); |
||||
this.isLoading = false |
||||
this.modal.triggerOk() |
||||
}, err => { |
||||
this.message.create('error', '修改失败'); |
||||
this.isLoading = false |
||||
}) |
||||
} else { |
||||
this.message.create('warning', '请填写完整!'); |
||||
} |
||||
|
||||
|
||||
} |
||||
|
||||
dateFormat = 'MM/dd'; |
||||
} |
@ -0,0 +1,30 @@
|
||||
<div class="box" id="detailsupdatecategory"> |
||||
<div class="title"> |
||||
<div class="titlecontent"> |
||||
详情 |
||||
</div> |
||||
<i nz-icon nzType="close" nzTheme="outline" (click)="destroyModal()"></i> |
||||
</div> |
||||
|
||||
<div class="content"> |
||||
<p>{{organizationName}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p class="flexp"> |
||||
<span>办理提醒时间:修改时间 {{data.handleRemindDays}}天</span> |
||||
<span>默认时间 {{data.handleRemindDaysDefault}}天</span> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p class="flexp"> |
||||
<span>临期提醒时间:修改时间 {{data.closingRemindDays}}天</span> |
||||
<span>默认时间 {{data.closingRemindDaysDefault}}天</span> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>修改说明:{{data.remark}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>审核状态:{{data.auditStatus | auditStatus}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>驳回说明:{{data.auditLog.rejectReason}}</p> |
||||
</div> |
||||
|
||||
|
||||
</div> |
@ -0,0 +1,65 @@
|
||||
.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; |
||||
} |
||||
} |
||||
|
||||
.content { |
||||
box-sizing: border-box; |
||||
padding: 0 15px; |
||||
max-height: 580px; |
||||
overflow-y: auto; |
||||
|
||||
.circle { |
||||
width: 8px; |
||||
height: 8px; |
||||
background: linear-gradient(180deg, #36A2FF 0%, #FFFFFF 100%); |
||||
opacity: 1; |
||||
} |
||||
|
||||
.recordP { |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
} |
||||
} |
||||
|
||||
p { |
||||
margin-bottom: 0; |
||||
color: #C4E2FC; |
||||
margin: 12px 0; |
||||
|
||||
img { |
||||
width: 88px; |
||||
height: 56px; |
||||
cursor: pointer; |
||||
} |
||||
} |
||||
.flexp{ |
||||
display: flex; |
||||
justify-content: space-between; |
||||
} |
||||
} |
@ -0,0 +1,22 @@
|
||||
import { Component, Input, OnInit } from '@angular/core'; |
||||
import { NzModalRef } from 'ng-zorro-antd/modal'; |
||||
|
||||
@Component({ |
||||
selector: 'app-audit-details-inform-time', |
||||
templateUrl: './audit-details-inform-time.component.html', |
||||
styleUrls: ['./audit-details-inform-time.component.scss'] |
||||
}) |
||||
export class AuditDetailsInformTimeComponent implements OnInit { |
||||
@Input() data?: any; |
||||
constructor(private modal: NzModalRef) { } |
||||
|
||||
|
||||
organizationName |
||||
ngOnInit(): void { |
||||
|
||||
this.organizationName = JSON.parse(sessionStorage.getItem('userdata')).organization.displayName |
||||
} |
||||
destroyModal() { |
||||
this.modal.destroy({ data: 'this the result data' }); |
||||
} |
||||
} |
@ -0,0 +1,46 @@
|
||||
<div class="box informTime" id="inform"> |
||||
<div class="tablebox" id="tablebox"> |
||||
<nz-table *ngIf="tableScrollHeight" [nzLoading]="tableSpin" [nzPageSize]='9999' #headerTable [nzData]="list" |
||||
[nzShowPagination]="false" [nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th rowspan="2" [nzWidth]="'16%'"> |
||||
<span>审批类型</span> |
||||
</th> |
||||
<th colspan="2">办理提醒时间</th> |
||||
<th colspan="2">临期提醒时间</th> |
||||
<th rowspan="2">提交审核时间</th> |
||||
<th rowspan="2">审核状态</th> |
||||
<th rowspan="2">操作</th> |
||||
</tr> |
||||
<tr> |
||||
<th>默认时间</th> |
||||
<th>现用时间</th> |
||||
<th>默认时间</th> |
||||
<th>现用时间</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td> |
||||
{{item.licenseName}} |
||||
</td> |
||||
<td>{{item.handleRemindDaysDefault}}天</td> |
||||
<td>{{item.handleRemindDays}}天</td> |
||||
<td>{{item.closingRemindDaysDefault}}天</td> |
||||
<td>{{item.closingRemindDays}}天</td> |
||||
<td>{{(item.auditLog && item.auditLog.committedTime) ? (item.auditLog.committedTime | date:"yyyy-MM-dd HH:mm:ss") : '/'}}</td> |
||||
<td>{{item.auditStatus | auditStatus}}</td> |
||||
<td class="operation"> |
||||
<span class="blueColor" (click)="edit(item)" |
||||
[ngClass]="{'greyColor': item.auditStatus == 1}">编辑</span> |
||||
<span class="blueColor" (click)="unCommit(item)" |
||||
*ngIf="item.auditStatus == 1">撤销审核</span> |
||||
<span class="blueColor" (click)="details(item)">审核详情</span> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,15 @@
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
} |
||||
|
||||
.tablebox { |
||||
width: 100%; |
||||
height: 100%; |
||||
|
||||
.operation { |
||||
span { |
||||
margin-right: 6px; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,130 @@
|
||||
import { HttpClient } from '@angular/common/http'; |
||||
import { Component, ElementRef, OnInit, ViewContainerRef } from '@angular/core'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
import { Observable, fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import { AuditDetailsInformTimeComponent } from './audit-details-inform-time/audit-details-inform-time.component'; |
||||
import { EditInformTimeComponent } from './edit-inform-time/edit-inform-time.component'; |
||||
// import { AuditDisposeComponent } from './audit-dispose/audit-dispose.component';
|
||||
|
||||
@Component({ |
||||
selector: 'app-audit-inform-time', |
||||
templateUrl: './audit-inform-time.component.html', |
||||
styleUrls: ['./audit-inform-time.component.scss'] |
||||
}) |
||||
export class AuditInformTimeComponent implements OnInit { |
||||
|
||||
constructor(private message: NzMessageService, private http: HttpClient, private element: ElementRef, private modal: NzModalService, private viewContainerRef: ViewContainerRef) { } |
||||
tableSpin = false |
||||
list = [] |
||||
|
||||
tableScrollHeight |
||||
ngOnInit(): void { |
||||
// 页面监听
|
||||
this.tableScrollHeight = '0px' |
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
let tableHeader = this.element.nativeElement.querySelector(`.ant-table-header`).clientHeight |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - tableHeader) + 'px' |
||||
}); |
||||
|
||||
this.getTimeList() |
||||
} |
||||
|
||||
SkipCount: string = '0' |
||||
MaxResultCount: string = '100' |
||||
async getTimeList() { |
||||
let params = { |
||||
OrganizationUnitId: JSON.parse(sessionStorage.getItem('userdata')).organization.id, |
||||
IsContainsChildren: 'true', |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
} |
||||
this.tableSpin = true |
||||
await new Promise((resolve, reject) => { |
||||
this.http.get('/api/services/app/OrganizationValidityLicenseRule/GetCurOrgRules', { |
||||
params: params |
||||
}).subscribe((data: any) => { |
||||
this.list = data.result |
||||
this.list = [...this.list] |
||||
console.log('时间表格', data) |
||||
this.tableSpin = false |
||||
|
||||
setTimeout(() => { |
||||
let tableHeader = this.element.nativeElement.querySelector(`.ant-table-header`).clientHeight |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - tableHeader) + 'px' |
||||
}, 0); |
||||
resolve(data) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
|
||||
edit(item) { |
||||
console.log('item', item) |
||||
if (item.auditStatus == 1) { |
||||
this.message.create('warning', '审核中不允许编辑'); |
||||
return |
||||
} |
||||
|
||||
const modal = this.modal.create({ |
||||
nzContent: EditInformTimeComponent, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: 600, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzComponentParams: { |
||||
data: item |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
nzOnOk: async () => { |
||||
this.getTimeList() |
||||
} |
||||
}); |
||||
const instance = modal.getContentComponent(); |
||||
modal.afterClose.subscribe(result => { }); |
||||
} |
||||
details(item) { |
||||
console.log('item', item) |
||||
const modal = this.modal.create({ |
||||
nzContent: AuditDetailsInformTimeComponent, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: 650, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzComponentParams: { |
||||
data: item |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
nzOnOk: async () => { |
||||
|
||||
} |
||||
}); |
||||
const instance = modal.getContentComponent(); |
||||
modal.afterClose.subscribe(result => { }); |
||||
} |
||||
|
||||
unCommit(item) { |
||||
let params = { |
||||
id: item.id |
||||
} |
||||
this.http.post('/api/services/app/OrganizationValidityLicenseRule/Uncommit', '', { params: params }).subscribe((data) => { |
||||
this.message.create('success', '撤销审核成功'); |
||||
this.getTimeList() |
||||
}, err => { |
||||
this.message.create('error', '撤销审核失败'); |
||||
}) |
||||
} |
||||
} |
@ -0,0 +1,54 @@
|
||||
<div class="box" id="editfilecategory"> |
||||
<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"> |
||||
|
||||
<div class="timebox"> |
||||
<div> |
||||
<p>办理提醒时间</p> |
||||
|
||||
<nz-form-item> |
||||
<nz-form-control> |
||||
<nz-input-group> |
||||
<input nz-input type="number" formControlName="time1" placeholder="请填写时间" /> |
||||
</nz-input-group> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
<p class="p2">默认时间: 90天</p> |
||||
</div> |
||||
<div> |
||||
<p>临期提醒时间</p> |
||||
|
||||
<nz-form-item> |
||||
<nz-form-control> |
||||
<nz-input-group> |
||||
<input nz-input type="number" formControlName="time2" placeholder="请填写时间" /> |
||||
</nz-input-group> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
<p class="p2">默认时间: 30天</p> |
||||
</div> |
||||
</div> |
||||
<div class="explain"> |
||||
<p>修改说明</p> |
||||
|
||||
<nz-form-item> |
||||
<nz-form-control> |
||||
<textarea formControlName="explain"></textarea> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
</div> |
||||
|
||||
|
||||
<div class="btnbox"> |
||||
<button nz-button type="submit" class="ok" (click)="ok()" [nzLoading]="isLoading">提交审核</button> |
||||
<button nz-button type="button" class="cancel" (click)="destroyModal()">取消</button> |
||||
</div> |
||||
</form> |
||||
</div> |
@ -0,0 +1,105 @@
|
||||
.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; |
||||
} |
||||
} |
||||
|
||||
|
||||
|
||||
|
||||
p { |
||||
margin-bottom: 0; |
||||
color: #C4E2FC; |
||||
margin: 12px 0; |
||||
} |
||||
|
||||
.p2 { |
||||
margin: 6px 0; |
||||
font-size: 12px; |
||||
color: #C4E2FC; |
||||
} |
||||
|
||||
.form { |
||||
box-sizing: border-box; |
||||
padding: 0 17px; |
||||
|
||||
.timebox { |
||||
display: flex; |
||||
|
||||
div { |
||||
flex: 1; |
||||
display: flex; |
||||
flex-direction: column; |
||||
box-sizing: border-box; |
||||
padding: 0 6px; |
||||
} |
||||
} |
||||
|
||||
.explain { |
||||
box-sizing: border-box; |
||||
padding: 0 6px; |
||||
|
||||
textarea { |
||||
width: 100%; |
||||
height: 100px; |
||||
|
||||
background: rgba(145, 204, 255, 0.16); |
||||
color: #fff; |
||||
} |
||||
} |
||||
|
||||
.btnbox { |
||||
width: 100%; |
||||
margin-top: 24px; |
||||
margin-bottom: 17px; |
||||
display: flex; |
||||
justify-content: flex-end; |
||||
box-sizing: border-box; |
||||
padding: 0 7px; |
||||
|
||||
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; |
||||
} |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,67 @@
|
||||
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'; |
||||
import { ObjectsSimpleService } from 'src/app/service/objectsSimple.service'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
@Component({ |
||||
selector: 'app-edit-inform-time', |
||||
templateUrl: './edit-inform-time.component.html', |
||||
styleUrls: ['./edit-inform-time.component.scss'] |
||||
}) |
||||
export class EditInformTimeComponent implements OnInit { |
||||
|
||||
@Input() data?: any; |
||||
|
||||
validateForm!: FormGroup; |
||||
constructor(private message: NzMessageService, private modal: NzModalRef, private fb: FormBuilder, private http: HttpClient, private objectsSrv: ObjectsSimpleService) { } |
||||
|
||||
|
||||
dataCopy |
||||
ngOnInit(): void { |
||||
this.dataCopy = JSON.parse(JSON.stringify(this.data)) |
||||
this.validateForm = this.fb.group({ |
||||
time1: [this.dataCopy.handleRemindDays, [Validators.required]], |
||||
time2: [this.dataCopy.closingRemindDays, [Validators.required]], |
||||
explain: [null] |
||||
}); |
||||
|
||||
} |
||||
|
||||
|
||||
destroyModal() { |
||||
this.modal.destroy({ data: 'this the result data' }); |
||||
|
||||
} |
||||
|
||||
|
||||
isLoading = false |
||||
ok() { |
||||
if (this.validateForm.valid) { |
||||
this.isLoading = true |
||||
let body = { |
||||
licenseTypeId: this.dataCopy.licenseTypeId, |
||||
organizationId: this.dataCopy.organizationId, |
||||
handleRemindDays: this.validateForm.value.time1, |
||||
closingRemindDays: this.validateForm.value.time2, |
||||
remark: this.validateForm.value.explain |
||||
} |
||||
console.log(body) |
||||
this.http.put('/api/services/app/OrganizationValidityLicenseRule/UpdateAndCommit', body).subscribe((data) => { |
||||
console.log('提交审核成功') |
||||
this.message.create('success', '提交审核成功'); |
||||
this.isLoading = false |
||||
this.modal.triggerOk() |
||||
}, err => { |
||||
this.message.create('error', '提交审核失败'); |
||||
this.isLoading = false |
||||
}) |
||||
} else { |
||||
this.message.create('warning', '请填写完整!'); |
||||
} |
||||
|
||||
|
||||
} |
||||
|
||||
|
||||
} |
@ -0,0 +1,59 @@
|
||||
<div class="box" id="detailsupdatecategory"> |
||||
<div class="title"> |
||||
<div class="titlecontent"> |
||||
处置 |
||||
</div> |
||||
<i nz-icon nzType="close" nzTheme="outline" (click)="destroyModal()"></i> |
||||
</div> |
||||
|
||||
<div class="content"> |
||||
<p *ngIf="data.auditType != 0 && data.auditType != 1 && data.gasStation">{{data.gasStation.companyName}} - {{data.gasStation.locationName}} - {{data.gasStation.stationName}}</p> |
||||
<div class="cutoffrule" *ngIf="data.auditType != 0 && data.auditType != 1"></div> |
||||
<div *ngIf="data.auditType == 0"><app-gas-base-info [data]="data"></app-gas-base-info></div> |
||||
<div *ngIf="data.auditType == 1"> |
||||
<p> |
||||
办理提醒时间:修改时间 {{data.getData.handleRemindDays}}天 |
||||
<span style="float: right;">默认时间 {{data.getData.handleRemindDaysDefault}}天</span> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
临期提醒时间:修改时间 {{data.getData.closingRemindDays}}天 |
||||
<span style="float: right;">默认时间 {{data.getData.closingRemindDaysDefault}}天</span> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>修改说明: {{data.getData.remark}}</p> |
||||
</div> |
||||
<div *ngIf="data.auditType == 2"> |
||||
<p>证件名称: {{data.getData.licenseTypeName}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>证件编号: {{data.getData.licenseCode || ''}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>证件有效期: <span *ngIf="!data.getData.isLongTerm">{{data.getData.validityStartTime | date:"yyyy/MM/dd"}} - </span>{{data.getData.validityEndTime | date:"yyyy/MM/dd"}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>办理类型: {{getHandleTypes(data.getData.handleTypes)}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>有效期类型: {{data.getData.validityDays || 0}}天</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>是否年检: <span *ngIf="data.getData.isYearlyCheck">是</span><span *ngIf="!data.getData.isYearlyCheck">否</span></p> |
||||
</div> |
||||
<div *ngIf="data.auditType == 3"> |
||||
<p>证件名称: {{data.getData.licenseTypeName}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>有效期类型: <span *ngIf="data.getData.validatyType == 0">不适用</span><span *ngIf="data.getData.validatyType == 1">无</span><span *ngIf="data.getData.validatyType == 2">有</span></p> |
||||
</div> |
||||
<div class="cutoffrule"></div> |
||||
<p [hidden]="data.getData.imageUrl === undefined">证件图片: |
||||
<img *ngIf="data.getData.imageUrl && getFileType(data.getData.imageUrl) == 'img'" [src]="data.getData.imageUrl" (click)="viewImg(data.getData.imageUrl)"> |
||||
<img *ngIf="data.getData.imageUrl && getFileType(data.getData.imageUrl) == 'word'" src="../../../../assets/images/license/word.png" (click)="lookFile(data.getData)"> |
||||
<img *ngIf="data.getData.imageUrl && getFileType(data.getData.imageUrl) == 'pdf'" src="../../../../assets/images/license/pdf.png" (click)="lookFile(data.getData)"> |
||||
<div class="cutoffrule" [hidden]="data.getData.imageUrl === undefined"></div> |
||||
<p>审批意见:</p> |
||||
<textarea style="background: #173350;height: 100px;width: 100%;border-radius: 0;border: 0;color: white;" cols="30" rows="10" [(ngModel)]="textarea"></textarea> |
||||
<div class="btnbox"> |
||||
<button nz-button type="button" class="ok" (click)="ok(true)">通过</button> |
||||
<button nz-button type="button" class="cancel" (click)="ok(false)">驳回</button> |
||||
</div> |
||||
</div> |
||||
|
||||
|
||||
</div> |
@ -0,0 +1,91 @@
|
||||
.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; |
||||
} |
||||
} |
||||
|
||||
.content { |
||||
box-sizing: border-box; |
||||
padding: 0 15px; |
||||
// max-height: 580px; |
||||
// overflow-y: auto; |
||||
|
||||
.circle { |
||||
width: 8px; |
||||
height: 8px; |
||||
background: linear-gradient(180deg, #36A2FF 0%, #FFFFFF 100%); |
||||
opacity: 1; |
||||
} |
||||
|
||||
.recordP { |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
} |
||||
|
||||
.btnbox { |
||||
width: 100%; |
||||
margin: 10px 0; |
||||
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.24); |
||||
} |
||||
|
||||
.cancel { |
||||
border: 1px solid #C4E2FC; |
||||
|
||||
background: rgba(255, 75, 101, 0.24); |
||||
|
||||
color: #C4E2FC; |
||||
// box-shadow: 0 0 3px 0 #fff inset; |
||||
} |
||||
} |
||||
} |
||||
|
||||
p { |
||||
margin-bottom: 0; |
||||
color: #C4E2FC; |
||||
margin: 12px 0; |
||||
|
||||
img { |
||||
width: 88px; |
||||
height: 56px; |
||||
cursor: pointer; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,102 @@
|
||||
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'; |
||||
import { ObjectsSimpleService } from 'src/app/service/objectsSimple.service'; |
||||
import Viewer from 'viewerjs'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
import { handleType, handleTypeList } from 'src/app/pages/license/update-category/edit-update-category/edit-update-category.component'; |
||||
|
||||
|
||||
@Component({ |
||||
selector: 'app-audit-dispose', |
||||
templateUrl: './audit-dispose.component.html', |
||||
styleUrls: ['./audit-dispose.component.scss'] |
||||
}) |
||||
export class AuditDisposeComponent implements OnInit { |
||||
|
||||
@Input() data?: any; |
||||
constructor(private modal: NzModalRef, private message: NzMessageService) { } |
||||
|
||||
textarea: string = ""; //审批意见
|
||||
ngOnInit(): void { |
||||
console.log(this.data) |
||||
} |
||||
|
||||
|
||||
destroyModal() { |
||||
this.modal.destroy(); |
||||
} |
||||
|
||||
isPass: boolean; |
||||
ok(isPass: boolean) { |
||||
this.isPass = isPass; |
||||
this.modal.triggerOk() |
||||
} |
||||
|
||||
//获取办理类型
|
||||
getHandleTypes(handleTypes: any[]):string { |
||||
if (!handleTypes || !handleTypes.length) { |
||||
return |
||||
} |
||||
let names: string[] = [] |
||||
let handleTypeList = JSON.parse(JSON.stringify(handleTypes)); |
||||
let list: handleTypeList[] = new handleType().list; |
||||
handleTypeList.forEach(item=>{ |
||||
list.find(element=>{ |
||||
item == element.value? names.push(element.name) : null |
||||
}) |
||||
}) |
||||
return names.join(',') |
||||
} |
||||
|
||||
//获取文件格式
|
||||
getFileType(name: string):string { |
||||
let suffix |
||||
if (name.substring(name.length-4).includes('png') || name.substring(name.length-4).includes('jpg') || name.substring(name.length-4).includes('jpeg') || name.substring(name.length-4).includes('webp')) { |
||||
suffix = 'img' |
||||
} else if (name.substring(name.length-4).includes('doc') || name.substring(name.length-4).includes('docx')) { |
||||
suffix = 'word' |
||||
} else if (name.substring(name.length-4).includes('pdf')) { |
||||
suffix = 'pdf' |
||||
} |
||||
return suffix |
||||
} |
||||
|
||||
//查看图片
|
||||
viewImg(url) { |
||||
let dom = document.getElementById(`viewerjs`) |
||||
let pObjs = dom.childNodes; |
||||
let node = document.createElement("img") |
||||
node.style.display = "none"; |
||||
node.src = url; |
||||
node.id = 'img' |
||||
dom.appendChild(node) |
||||
setTimeout(() => { |
||||
let viewer = new Viewer(document.getElementById(`viewerjs`), { |
||||
hidden: () => { |
||||
dom.removeChild(pObjs[0]); |
||||
viewer.destroy(); |
||||
} |
||||
}); |
||||
node.click(); |
||||
}, 0); |
||||
} |
||||
|
||||
//查看文件
|
||||
lookFile(item) { |
||||
if (!item.imageUrl) { |
||||
return |
||||
} |
||||
if (this.getFileType(item.imageUrl) == 'word') { |
||||
let arr = item.imageUrl.split('.') |
||||
arr[arr.length - 1] = 'pdf' |
||||
window.open(arr.join('.')) |
||||
} else if (this.getFileType(item.imageUrl) == 'pdf') { |
||||
window.open(item.imageUrl) |
||||
} else { |
||||
this.message.create('warning', '暂不支持查看!'); |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,44 @@
|
||||
<div class="box" id="inform"> |
||||
<div class="tablebox" id="tablebox"> |
||||
<nz-table *ngIf="tableScrollHeight" [nzLoading]="tableSpin" [nzPageSize]='9999' #headerTable [nzData]="list" |
||||
[nzShowPagination]="false" [nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th [nzWidth]="'16%'"> |
||||
<span style="margin-left: 30px;">审批类型</span> |
||||
</th> |
||||
<th>审批信息</th> |
||||
<th>加油站名称</th> |
||||
<th [nzWidth]="'16%'">区域</th> |
||||
<th>省公司</th> |
||||
<th>提交时间</th> |
||||
<th>审批状态</th> |
||||
<th>操作</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td> |
||||
<span style="margin-left: 30px;">{{item.auditTitle || ''}}</span> |
||||
</td> |
||||
<td> |
||||
<span *ngIf="item.auditType == 0">油站信息</span> |
||||
<span *ngIf="item.auditType == 1">更新类证照提醒时间</span> |
||||
<span *ngIf="item.auditType == 2">更新类证照</span> |
||||
<span *ngIf="item.auditType == 3">档案类证照</span> |
||||
</td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.stationName}}</label></td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.locationName}}</label></td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.companyName}}</label></td> |
||||
<td>{{item.committedTime | date:"yyyy/MM/dd"}}</td> |
||||
<td>{{item.auditStatusDesc}}</td> |
||||
<td class="operation"> |
||||
<span class="blueColor" (click)="dispose(item)">处置</span> |
||||
<span class="blueColor" (click)="details(item)">详情</span> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,15 @@
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
} |
||||
|
||||
.tablebox { |
||||
width: 100%; |
||||
height: 100%; |
||||
|
||||
.operation { |
||||
span { |
||||
margin-right: 6px; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,188 @@
|
||||
import { HttpClient } from '@angular/common/http'; |
||||
import { Component, ElementRef, OnInit, ViewContainerRef } from '@angular/core'; |
||||
import { NzMessageService } from 'ng-zorro-antd/message'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
import { Observable, fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import { DetailsFileCategoryComponent } from '../../license/file-category/details-file-category/details-file-category.component'; |
||||
import { DetailsUpdateCategoryComponent } from '../../license/update-category/details-update-category/details-update-category.component'; |
||||
import { AuditDetailsInformTimeComponent } from '../audit-inform-time/audit-details-inform-time/audit-details-inform-time.component'; |
||||
import { GasBaseInfoComponent } from '../gas-base-info/gas-base-info.component'; |
||||
import { AuditDisposeComponent } from './audit-dispose/audit-dispose.component'; |
||||
|
||||
@Component({ |
||||
selector: 'app-audit-ing', |
||||
templateUrl: './audit-ing.component.html', |
||||
styleUrls: ['./audit-ing.component.scss'] |
||||
}) |
||||
export class AuditIngComponent implements OnInit { |
||||
|
||||
constructor(private modal: NzModalService, private viewContainerRef: ViewContainerRef,private http: HttpClient,private message: NzMessageService,private element: ElementRef) { } |
||||
tableSpin = false |
||||
|
||||
tableScrollHeight |
||||
ngOnInit(): void { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
}); |
||||
this.getStationList() |
||||
} |
||||
|
||||
ngAfterViewInit(): void { |
||||
fromEvent(this.element.nativeElement.querySelector(`.ant-table-body`) as HTMLCanvasElement, 'scroll').pipe(debounceTime(100)).subscribe((event: any) => { //监听 DOM 滚动事件
|
||||
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) { |
||||
if (this.totalCount > this.list.length) { |
||||
this.SkipCount = String(Number(this.SkipCount) + 50) |
||||
this.getStationList() |
||||
} |
||||
} |
||||
}); |
||||
} |
||||
|
||||
list = [] |
||||
totalCount;//列表总数
|
||||
SkipCount: string = '0'; |
||||
MaxResultCount: string = '100'; |
||||
//获取当前油站档案类证照
|
||||
getStationList() { |
||||
this.tableSpin = true |
||||
let data = JSON.parse(sessionStorage.getItem('userdata')); |
||||
let params = { |
||||
OrganizationUnitId: data.organization.id || "" , |
||||
IsContainsChildren: "true", |
||||
AuditStatuses: "1", |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
} |
||||
this.http.get(`/api/services/app/ContentAuditLog/GetAuditting`,{params}).subscribe((info: any)=>{ |
||||
info.result.items.forEach(element => { |
||||
element.itemData = JSON.parse(element.itemData) |
||||
}); |
||||
this.list = this.list.concat(info.result.items); |
||||
this.list = [...this.list] |
||||
this.totalCount = info.result.totalCount |
||||
this.tableSpin = false |
||||
console.log(this.list) |
||||
}) |
||||
} |
||||
|
||||
|
||||
|
||||
dispose(item) { |
||||
// if (item.auditStatus != 1) {
|
||||
// return
|
||||
// }
|
||||
this.getData(item).then(res=>{ |
||||
item.getData = res |
||||
const modal = this.modal.create({ |
||||
nzContent: AuditDisposeComponent, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: item.auditType == 0? 700 : 600, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzStyle: { |
||||
'top': '50px', |
||||
}, |
||||
nzComponentParams: { |
||||
data: item |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
nzOnOk: async () => { |
||||
await new Promise(resolve => { |
||||
let url |
||||
if (item.auditType == 0) { |
||||
url = '/api/services/app/GasStation/Audit' |
||||
} else if (item.auditType == 1) { |
||||
url = '/api/services/app/OrganizationValidityLicenseRule/Audit' |
||||
} else if (item.auditType == 2) { |
||||
url = '/api/services/app/StationValidityLicense/Audit' |
||||
} else if (item.auditType) { |
||||
url = '/api/services/app/StationFileLicense/Audit' |
||||
} |
||||
let params = { |
||||
id: item.auditType == 0? item.gasStation.id : item.getData.id, |
||||
remark: instance.textarea |
||||
} |
||||
let body = instance.isPass? 2 : 3; |
||||
this.http.post(url,body,{params}).subscribe(data => { |
||||
resolve(data); |
||||
this.getStationList(); |
||||
this.message.create('success', '审核完成!'); |
||||
return true |
||||
}) |
||||
}) |
||||
} |
||||
}); |
||||
const instance = modal.getContentComponent(); |
||||
modal.afterClose.subscribe(result => { }); |
||||
}) |
||||
} |
||||
|
||||
details(item) { |
||||
let component |
||||
if (item.auditType == 0) { |
||||
component = GasBaseInfoComponent |
||||
} else if (item.auditType == 1) { |
||||
component = AuditDetailsInformTimeComponent |
||||
} else if (item.auditType == 2) { |
||||
component = DetailsUpdateCategoryComponent |
||||
} else if (item.auditType) { |
||||
component = DetailsFileCategoryComponent |
||||
} |
||||
this.getData(item).then(res=>{ |
||||
item.getData = res |
||||
const modal = this.modal.create({ |
||||
nzContent: component, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: item.auditType == 0? 700 : 450, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzStyle: { |
||||
'top': '50px', |
||||
}, |
||||
nzComponentParams: { |
||||
data: item.getData |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
}); |
||||
}) |
||||
} |
||||
|
||||
//获取证照类data
|
||||
getData(item) { |
||||
let url |
||||
if (item.auditType == 0) { //油站基本信息
|
||||
return new Promise((resolve, reject)=>{ |
||||
let organization = { organizationId: item.organizationId } |
||||
resolve(organization) |
||||
}) |
||||
} else if (item.auditType == 1) { |
||||
url = '/api/services/app/OrganizationValidityLicenseRule/Get' |
||||
} else if (item.auditType == 2) { |
||||
url = '/api/services/app/StationValidityLicense/Get' |
||||
} else if (item.auditType) { |
||||
url = '/api/services/app/StationFileLicense/Get' |
||||
} |
||||
return new Promise((resolve, reject)=>{ |
||||
let params = { id: item.itemId } |
||||
this.http.get(url,{params}).subscribe((data: any)=>{ |
||||
resolve(data.result) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
} |
@ -0,0 +1,23 @@
|
||||
<div class="audit" id="audit"> |
||||
<div class="title"> |
||||
<div class="titlebox"> |
||||
<img src="../../../assets/images/logosm.png" alt=""> |
||||
<div class="nav"> |
||||
<div class="navitem"> |
||||
<span *ngFor="let item of navList" [ngClass]="{'grey': selectedItem != item}" |
||||
(click)="selectNav(item)">{{item}}</span> |
||||
<span *ngIf="isLevel == 2" [ngClass]="{'grey': selectedItem != '通知时间'}" |
||||
(click)="selectNav('通知时间')">通知时间</span> |
||||
<span *ngIf="isLevel == 2" [ngClass]="{'grey': selectedItem != '年检设置'}" |
||||
(click)="selectNav('年检设置')">年检设置</span> |
||||
</div> |
||||
</div> |
||||
</div> |
||||
</div> |
||||
<div class="content"> |
||||
<app-audit-ing *ngIf="selectedItem == navList[0]"></app-audit-ing> |
||||
<app-audit-record *ngIf="selectedItem == navList[1]"></app-audit-record> |
||||
<app-audit-inform-time *ngIf="selectedItem == '通知时间'"></app-audit-inform-time> |
||||
<app-annual-inspection *ngIf="selectedItem == '年检设置'"></app-annual-inspection> |
||||
</div> |
||||
</div> |
@ -0,0 +1,76 @@
|
||||
.audit { |
||||
width: 100%; |
||||
height: 100%; |
||||
display: flex; |
||||
flex-direction: column; |
||||
} |
||||
|
||||
.title { |
||||
width: 100%; |
||||
height: 64px; |
||||
box-sizing: border-box; |
||||
padding: 0 28px; |
||||
margin: 13px 0; |
||||
position: relative; |
||||
|
||||
.titlebox { |
||||
width: 100%; |
||||
height: 100%; |
||||
display: flex; |
||||
align-items: center; |
||||
|
||||
img { |
||||
width: 65px; |
||||
height: 65px; |
||||
} |
||||
|
||||
.nav { |
||||
flex: 1; |
||||
height: 48px; |
||||
display: flex; |
||||
align-items: center; |
||||
justify-content: center; |
||||
// background-image: linear-gradient(to right, #002147, #033565, #064e8e, #064e8e, #033565, #002147); |
||||
background: linear-gradient(270deg, rgba(35, 153, 255, 0) 0%, rgba(35, 153, 255, 0.32) 50%, rgba(35, 153, 255, 0) 100%); |
||||
|
||||
.navitem { |
||||
width: 100%; |
||||
height: 32px; |
||||
display: flex; |
||||
align-items: center; |
||||
// background-image: linear-gradient(to right, #002147, #0f5ca0, #1c88e6, #1c88e6, #0f5ca0, #002147); |
||||
background: linear-gradient(270deg, rgba(35, 153, 255, 0) 0%, rgba(35, 153, 255, 0.8) 50%, rgba(35, 153, 255, 0) 100%); |
||||
|
||||
span { |
||||
margin-left: 25px; |
||||
color: #bce0ff; |
||||
font-size: 20px; |
||||
font-family: titlefont; |
||||
cursor: pointer; |
||||
} |
||||
|
||||
span:nth-child(1) { |
||||
margin-left: 12px; |
||||
} |
||||
|
||||
.grey { |
||||
color: #68829F; |
||||
} |
||||
} |
||||
|
||||
} |
||||
} |
||||
|
||||
.packup { |
||||
position: absolute; |
||||
right: 33px; |
||||
top: 16px; |
||||
cursor: pointer; |
||||
} |
||||
} |
||||
|
||||
.content { |
||||
flex: 1; |
||||
box-sizing: border-box; |
||||
padding: 0 40px 20px 40px; |
||||
} |
@ -0,0 +1,25 @@
|
||||
import { Component, OnInit } from '@angular/core'; |
||||
|
||||
@Component({ |
||||
selector: 'app-audit-nav', |
||||
templateUrl: './audit-nav.component.html', |
||||
styleUrls: ['./audit-nav.component.scss'] |
||||
}) |
||||
export class AuditNavComponent implements OnInit { |
||||
|
||||
constructor() { } |
||||
|
||||
|
||||
navList = ['审批', '历史纪录'] |
||||
selectedItem = '审批' |
||||
selectNav(item) { |
||||
this.selectedItem = item |
||||
} |
||||
|
||||
|
||||
isLevel |
||||
ngOnInit(): void { |
||||
this.isLevel = JSON.parse(sessionStorage.getItem('userdata')).organization.level |
||||
} |
||||
|
||||
} |
@ -0,0 +1,127 @@
|
||||
<div class="box" id="inform"> |
||||
<div class="search"> |
||||
<form nz-form [formGroup]="validateForm" class="login-form" (ngSubmit)="submitForm()"> |
||||
<nz-form-item class="searchParams searchParamsLong"> |
||||
<nz-form-control> |
||||
<nz-select nzAllowClear formControlName="type" nzPlaceHolder="审批类型" [nzLoading]="typeLoading"> |
||||
<nz-option *ngFor="let item of typeList" [nzValue]="item.licenseName" |
||||
[nzLabel]="item.licenseName"></nz-option> |
||||
</nz-select> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
<nz-form-item class="searchParams"> |
||||
<nz-form-control> |
||||
<nz-select nzAllowClear formControlName="info" nzPlaceHolder="审批信息"> |
||||
<nz-option nzValue="0" nzLabel="油站信息"></nz-option> |
||||
<nz-option nzValue="1" nzLabel="更新类证照提醒时间"></nz-option> |
||||
<nz-option nzValue="2" nzLabel="更新类证照"></nz-option> |
||||
<nz-option nzValue="3" nzLabel="档案类证照"></nz-option> |
||||
</nz-select> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
<nz-form-item class="searchParams searchParamsLong"> |
||||
<nz-form-control> |
||||
<nz-tree-select [nzAllowClear]="false" [nzDropdownClassName]="'maxHeightTreeSelect'" nzShowSearch |
||||
formControlName="organization" [nzNodes]="nodes" nzPlaceHolder="请选择所属机构" |
||||
[nzExpandedIcon]="multiExpandedIconTpl"> |
||||
</nz-tree-select> |
||||
<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> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
|
||||
<nz-form-item class="searchParams searchParams2"> |
||||
<nz-form-control> |
||||
<nz-range-picker [nzAllowClear]="false" formControlName="datePicker"></nz-range-picker> |
||||
<br /> |
||||
</nz-form-control> |
||||
</nz-form-item> |
||||
|
||||
<nz-form-item class="searchParams"> |
||||
<nz-form-control> |
||||
<nz-select nzAllowClear formControlName="level" nzPlaceHolder="审批级别"> |
||||
<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> |
||||
<nz-form-item class="searchParams"> |
||||
<nz-form-control> |
||||
<nz-select nzAllowClear formControlName="state" nzPlaceHolder="审批状态"> |
||||
<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-option nzValue="5" nzLabel="审核完成"></nz-option> |
||||
</nz-select> |
||||
</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" id="tablebox"> |
||||
<nz-table *ngIf="tableScrollHeight" [nzLoading]="tableSpin" [nzPageSize]='9999' #headerTable [nzData]="list" |
||||
[nzShowPagination]="false" [nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th [nzWidth]="'16%'"> |
||||
<span style="margin-left: 30px;">审批类型</span> |
||||
</th> |
||||
<th>审批信息</th> |
||||
<th>加油站名称</th> |
||||
<th [nzWidth]="'16%'">区域</th> |
||||
<th>省公司</th> |
||||
<th>提交时间</th> |
||||
<th>审批状态</th> |
||||
<th>操作</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td> |
||||
<span style="margin-left: 30px;">{{item.auditTitle || ''}}</span> |
||||
</td> |
||||
<td> |
||||
<span *ngIf="item.auditType == 0">油站信息</span> |
||||
<span *ngIf="item.auditType == 1">更新类证照提醒时间</span> |
||||
<span *ngIf="item.auditType == 2">更新类证照</span> |
||||
<span *ngIf="item.auditType == 3">档案类证照</span> |
||||
</td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.stationName}}</label></td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.locationName}}</label></td> |
||||
<td><label *ngIf="item.gasStation">{{item.gasStation.companyName}}</label></td> |
||||
<td>{{item.committedTime | date:"yyyy/MM/dd"}}</td> |
||||
<td>{{item.auditStatusDesc}}</td> |
||||
<td class="operation"> |
||||
<span class="blueColor" (click)="details(item)">详情</span> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,67 @@
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
} |
||||
|
||||
.search { |
||||
box-sizing: border-box; |
||||
width: 100%; |
||||
height: 32px; |
||||
margin-bottom: 16px; |
||||
|
||||
form { |
||||
width: 100%; |
||||
height: 32px; |
||||
display: flex; |
||||
justify-content: flex-start; |
||||
|
||||
.searchParams, |
||||
.btn { |
||||
margin: 0 3px; |
||||
} |
||||
|
||||
.searchParams { |
||||
// flex: 5; |
||||
width: 150px; |
||||
} |
||||
|
||||
.searchParamsLong { |
||||
width: 250px; |
||||
} |
||||
|
||||
.searchParams2 { |
||||
width: 220px; |
||||
} |
||||
|
||||
.btn { |
||||
// flex: 1; |
||||
} |
||||
|
||||
nz-select { |
||||
color: rgba(145, 204, 255, 0.95); |
||||
} |
||||
|
||||
nz-tree-select { |
||||
color: rgba(145, 204, 255, 0.95); |
||||
} |
||||
|
||||
nz-range-picker { |
||||
background-color: rgba(0, 0, 0, 0); |
||||
width: 100%; |
||||
} |
||||
|
||||
} |
||||
|
||||
|
||||
} |
||||
|
||||
.tablebox { |
||||
width: 100%; |
||||
height: 100%; |
||||
|
||||
.operation { |
||||
span { |
||||
margin-right: 6px; |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,253 @@
|
||||
import { HttpClient } from '@angular/common/http'; |
||||
import { Component, ElementRef, OnInit, ViewContainerRef } from '@angular/core'; |
||||
import { FormBuilder, FormGroup } from '@angular/forms'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
import { Observable, fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import { TreeService } from 'src/app/service/tree.service'; |
||||
import { DetailsFileCategoryComponent } from '../../license/file-category/details-file-category/details-file-category.component'; |
||||
import { DetailsUpdateCategoryComponent } from '../../license/update-category/details-update-category/details-update-category.component'; |
||||
import { AuditDetailsInformTimeComponent } from '../audit-inform-time/audit-details-inform-time/audit-details-inform-time.component'; |
||||
import { GasBaseInfoComponent } from '../gas-base-info/gas-base-info.component'; |
||||
|
||||
@Component({ |
||||
selector: 'app-audit-record', |
||||
templateUrl: './audit-record.component.html', |
||||
styleUrls: ['./audit-record.component.scss'] |
||||
}) |
||||
export class AuditRecordComponent implements OnInit { |
||||
validateForm!: FormGroup; |
||||
constructor(private element: ElementRef, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private toTree: TreeService, private http: HttpClient, private fb: FormBuilder) { } |
||||
|
||||
list = [] |
||||
|
||||
tableScrollHeight |
||||
startdate |
||||
enddate |
||||
async ngOnInit(): Promise<void> { |
||||
this.validateForm = this.fb.group({ |
||||
type: [null], |
||||
info: [null], |
||||
organization: [null], |
||||
datePicker: [null], |
||||
level: [null], |
||||
state: [null], |
||||
}); |
||||
//当前日期
|
||||
let myDate: any = new Date(); |
||||
let nowY = myDate.getFullYear(); |
||||
let nowM = myDate.getMonth() + 1; |
||||
let nowD = myDate.getDate(); |
||||
this.enddate = nowY + "-" + (nowM < 10 ? "0" + nowM : nowM) + "-" + (nowD < 10 ? "0" + nowD : nowD);//当前日期
|
||||
//获取三十天前日期
|
||||
let lw = new Date(myDate - 1000 * 60 * 60 * 24 * 30);//最后一个数字30可改,30天的意思
|
||||
let lastY = lw.getFullYear(); |
||||
let lastM = lw.getMonth() + 1; |
||||
let lastD = lw.getDate(); |
||||
this.startdate = lastY + "-" + (lastM < 10 ? "0" + lastM : lastM) + "-" + (lastD < 10 ? "0" + lastD : lastD);//三十天之前日期
|
||||
|
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
}); |
||||
|
||||
this.getTypeList() |
||||
await this.getAllOrganization() |
||||
this.getRecordList() |
||||
} |
||||
|
||||
submitForm(): void { |
||||
if (this.validateForm.value.datePicker[0].toLocaleDateString) { |
||||
this.validateForm.value.datePicker[0] = this.validateForm.value.datePicker[0].toLocaleDateString() |
||||
} |
||||
if (this.validateForm.value.datePicker[1].toLocaleDateString) { |
||||
this.validateForm.value.datePicker[1] = this.validateForm.value.datePicker[1].toLocaleDateString() |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getRecordList() |
||||
} |
||||
|
||||
resetForm(e: MouseEvent): void { |
||||
e.preventDefault(); |
||||
this.validateForm.reset(); |
||||
this.validateForm.patchValue({ |
||||
organization: JSON.parse(sessionStorage.getItem('userdata')).organization.id, |
||||
datePicker: [this.startdate, this.enddate], |
||||
}); |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getRecordList() |
||||
} |
||||
|
||||
//获取所有组织机构
|
||||
nodes: any = [] |
||||
async getAllOrganization() { |
||||
let OrganizationUnitId = JSON.parse(sessionStorage.getItem('userdata')).organization.id |
||||
let params = { |
||||
OrganizationUnitId: OrganizationUnitId, |
||||
IsContainsChildren: "true" |
||||
} |
||||
await new Promise((resolve, reject) => { |
||||
this.http.get('/api/services/app/Organization/GetAll', { |
||||
params: params |
||||
}).subscribe((data: any) => { |
||||
data.result.items.forEach(element => { |
||||
if (element.id == OrganizationUnitId) { |
||||
element.parentId = null |
||||
} |
||||
element.key = element.id |
||||
element.title = element.displayName |
||||
}); |
||||
this.nodes = [...this.toTree.toTree(data.result.items)] |
||||
this.validateForm.patchValue({ |
||||
organization: JSON.parse(sessionStorage.getItem('userdata')).organization.id, |
||||
datePicker: [this.startdate, this.enddate], |
||||
}); |
||||
resolve(data) |
||||
|
||||
}) |
||||
}) |
||||
|
||||
} |
||||
|
||||
//证照类型
|
||||
typeLoading |
||||
typeList |
||||
getTypeList() { |
||||
this.typeLoading = true |
||||
let promiseArr = [] |
||||
let api = ['/api/services/app/ValidityLicenseType/GetAll', '/api/services/app/FileLicenseType/GetAll'] |
||||
api.forEach(element => { |
||||
promiseArr.push( |
||||
new Promise((resolve, reject) => { |
||||
this.http.get(element, { |
||||
params: { |
||||
SkipCount: '0', |
||||
MaxResultCount: '999' |
||||
} |
||||
}).subscribe({ |
||||
next: (data) => { |
||||
resolve(data) |
||||
}, |
||||
error: err => { |
||||
reject(err) |
||||
} |
||||
}) |
||||
}) |
||||
) |
||||
}); |
||||
|
||||
Promise.all(promiseArr).then((result) => { |
||||
|
||||
let arr = [{ licenseName: '油站信息' }] |
||||
result.forEach(item => { |
||||
arr = arr.concat(item.result.items) |
||||
}); |
||||
this.typeLoading = false |
||||
this.typeList = arr |
||||
}).catch((error) => { |
||||
|
||||
}) |
||||
} |
||||
|
||||
//历史记录列表
|
||||
totalCount//列表总数
|
||||
tableSpin = true |
||||
SkipCount: string = '0' |
||||
MaxResultCount: string = '100' |
||||
getRecordList() { |
||||
this.tableSpin = true |
||||
let params = { |
||||
IsContainsChildren: 'true', |
||||
OrganizationUnitId: this.validateForm.value.organization, |
||||
AuditTitle: this.validateForm.value.type, |
||||
AuditType: this.validateForm.value.info, |
||||
StartTime: this.validateForm.value.datePicker[0], |
||||
EndTime: this.validateForm.value.datePicker[1], |
||||
AuditStatuses: this.validateForm.value.state, |
||||
AuditLevel: this.validateForm.value.level, |
||||
Sorting: null, |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
} |
||||
this.http.get('/api/services/app/ContentAuditLog/GetHistory', {params}).subscribe((data: any) => { |
||||
this.list = this.list.concat(data.result.items); |
||||
this.list = [...this.list] |
||||
this.totalCount = data.result.totalCount |
||||
this.tableSpin = false |
||||
console.log('审核历史纪录', this.list) |
||||
}) |
||||
} |
||||
|
||||
details(item) { |
||||
let component |
||||
if (item.auditType == 0) { |
||||
component = GasBaseInfoComponent |
||||
} else if (item.auditType == 1) { |
||||
component = AuditDetailsInformTimeComponent |
||||
} else if (item.auditType == 2) { |
||||
component = DetailsUpdateCategoryComponent |
||||
} else if (item.auditType) { |
||||
component = DetailsFileCategoryComponent |
||||
} |
||||
this.getData(item).then(res=>{ |
||||
item.getData = res |
||||
const modal = this.modal.create({ |
||||
nzContent: component, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: item.auditType == 0? 700 : 450, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzStyle: { |
||||
'top': '50px', |
||||
}, |
||||
nzComponentParams: { |
||||
data: item.getData |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
}); |
||||
}) |
||||
} |
||||
|
||||
//获取证照类data
|
||||
getData(item) { |
||||
let url |
||||
if (item.auditType == 0) { //油站基本信息
|
||||
return new Promise((resolve, reject)=>{ |
||||
let organization = { organizationId: item.organizationId } |
||||
resolve(organization) |
||||
}) |
||||
} else if (item.auditType == 1) { |
||||
url = '/api/services/app/OrganizationValidityLicenseRule/Get' |
||||
} else if (item.auditType == 2) { |
||||
url = '/api/services/app/StationValidityLicense/Get' |
||||
} else if (item.auditType) { |
||||
url = '/api/services/app/StationFileLicense/Get' |
||||
} |
||||
return new Promise((resolve, reject)=>{ |
||||
let params = { id: item.itemId } |
||||
this.http.get(url,{params}).subscribe((data: any)=>{ |
||||
resolve(data.result) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
ngAfterViewInit(): void { |
||||
fromEvent(this.element.nativeElement.querySelector(`.ant-table-body`) as HTMLCanvasElement, 'scroll').pipe(debounceTime(100)).subscribe((event: any) => { //监听 DOM 滚动事件
|
||||
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) { |
||||
if (this.totalCount > this.list.length) { |
||||
this.SkipCount = String(Number(this.SkipCount) + 50) |
||||
this.getRecordList() |
||||
} |
||||
} |
||||
}); |
||||
} |
||||
} |
@ -0,0 +1,95 @@
|
||||
<div [ngStyle]="{'padding': isDetails? '0 15px' : null}"> |
||||
<div class="title" *ngIf="isDetails"> |
||||
<div class="titlecontent"> |
||||
详情 |
||||
</div> |
||||
<i nz-icon nzType="close" nzTheme="outline" (click)="destroyModal()"></i> |
||||
</div> |
||||
|
||||
<p> |
||||
<label class="marginLeft">站名: {{baseInfo.stationName}}</label> |
||||
<label>开业时间: {{baseInfo.openTime | date:"yyyy/MM/dd"}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">油站类型: <span *ngIf="baseInfo.stationType == 0">自营</span><span *ngIf="baseInfo.stationType == 1">加盟</span><span *ngIf="baseInfo.stationType == 2">其他</span></label> |
||||
<label>车道数量: {{baseInfo.laneCount}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p>地址: {{baseInfo.address}}</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">区域: {{baseInfo.locationName}}</label> |
||||
<label>所属公司: {{baseInfo.companyName}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">联系人: {{baseInfo.leaderName}}</label> |
||||
<label>联系电话: {{baseInfo.leaderContact}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">油站等级: {{baseInfo.stationLevel}}</label> |
||||
<label>经营品种: {{baseInfo.sellVariety}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">油机数量: {{baseInfo.gasStationCount}}</label> |
||||
<label>油罐容积(m³): {{baseInfo.tankVolume}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<div *ngIf="baseInfo.govUnitDetail && baseInfo.govUnitDetail.policeStation"> |
||||
<p> |
||||
<label class="marginLeft">辖区派出所: {{baseInfo.govUnitDetail.policeStation.name}}</label> |
||||
<label>地址: {{baseInfo.govUnitDetail.policeStation.address}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">距离: {{baseInfo.govUnitDetail.policeStation.distance}}</label> |
||||
<label>联系方式: {{baseInfo.govUnitDetail.policeStation.contactInformation}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
</div> |
||||
<div *ngIf="baseInfo.govUnitDetail && baseInfo.govUnitDetail.hospital"> |
||||
<p> |
||||
<label class="marginLeft">辖区医院: {{baseInfo.govUnitDetail.hospital.name}}</label> |
||||
<label>地址: {{baseInfo.govUnitDetail.hospital.address}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">距离: {{baseInfo.govUnitDetail.hospital.distance}}</label> |
||||
<label>联系方式: {{baseInfo.govUnitDetail.hospital.contactInformation}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
</div> |
||||
<div *ngIf="baseInfo.govUnitDetail && baseInfo.govUnitDetail.fireBrigade"> |
||||
<p> |
||||
<label class="marginLeft">辖区消防队: {{baseInfo.govUnitDetail.fireBrigade.name}}</label> |
||||
<label>地址: {{baseInfo.govUnitDetail.fireBrigade.address}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
<p> |
||||
<label class="marginLeft">距离: {{baseInfo.govUnitDetail.fireBrigade.distance}}</label> |
||||
<label>联系方式: {{baseInfo.govUnitDetail.fireBrigade.contactInformation}}</label> |
||||
</p> |
||||
<div class="cutoffrule"></div> |
||||
</div> |
||||
|
||||
<!-- <p class="recordP" *ngIf="isDetails"> |
||||
<span>审核记录</span> |
||||
<span> |
||||
<span style="margin-right: 6px;"> |
||||
审核次数:{{auditList.length}} |
||||
</span> |
||||
<span> |
||||
驳回次数:{{getRejectNum()}} |
||||
</span> |
||||
</span> |
||||
</p> |
||||
<nz-timeline *ngIf="isDetails"> |
||||
<nz-timeline-item *ngFor="let item of auditList"> |
||||
<span style="margin-right: 12px;">{{item.creationTime | date:"yyyy/MM/dd"}}</span> |
||||
<span>{{item.auditStatus | auditStatus}}</span> |
||||
</nz-timeline-item> |
||||
</nz-timeline> --> |
||||
</div> |
@ -0,0 +1,47 @@
|
||||
p { |
||||
margin-bottom: 0; |
||||
color: #C4E2FC; |
||||
margin: 10px 0; |
||||
img { |
||||
width: 88px; |
||||
height: 56px; |
||||
cursor: pointer; |
||||
} |
||||
} |
||||
label{ display: inline-block; vertical-align: middle; } |
||||
.marginLeft { |
||||
width: 55%; |
||||
overflow: hidden; |
||||
} |
||||
.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; |
||||
} |
||||
} |
||||
.recordP{ |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
} |
@ -0,0 +1,64 @@
|
||||
import { HttpClient } from '@angular/common/http'; |
||||
import { Component, Input, OnInit } from '@angular/core'; |
||||
import { NzModalRef } from 'ng-zorro-antd/modal'; |
||||
|
||||
@Component({ |
||||
selector: 'app-gas-base-info', |
||||
templateUrl: './gas-base-info.component.html', |
||||
styleUrls: ['./gas-base-info.component.scss'] |
||||
}) |
||||
export class GasBaseInfoComponent implements OnInit { |
||||
|
||||
constructor(private modal: NzModalRef,private http: HttpClient) { } |
||||
|
||||
@Input() data?: any; |
||||
isDetails: boolean = false; //是否是详情
|
||||
|
||||
ngOnInit(): void { |
||||
if (this.data.id === undefined) { //详情
|
||||
this.isDetails = true |
||||
//this.getAuditLogging()
|
||||
} |
||||
this.getBaseInfo() |
||||
} |
||||
|
||||
baseInfo: any = { |
||||
stationType: null, |
||||
} |
||||
getBaseInfo() { |
||||
let params = { organizationUnitId: this.data.organizationId } |
||||
this.http.get('/api/services/app/GasStation/Get',{params}).subscribe((data: any)=>{ |
||||
data.result.govUnitDetail? data.result.govUnitDetail = JSON.parse(data.result.govUnitDetail) : null; |
||||
this.baseInfo = data.result |
||||
}) |
||||
} |
||||
|
||||
destroyModal() { |
||||
this.modal.destroy({ data: 'this the result data' }); |
||||
} |
||||
|
||||
auditList: any[] = []; |
||||
//获取审核记录
|
||||
getAuditLogging() { |
||||
if (!this.data.organizationId) { |
||||
return |
||||
} |
||||
let params = { orgId: this.data.organizationId } |
||||
this.http.get(`/api/services/app/GasStation/GetAuditted`,{params}).subscribe((data: any)=>{ |
||||
//this.auditList = data.result.actionList || []
|
||||
console.log(data) |
||||
}) |
||||
} |
||||
|
||||
//获取驳回次数
|
||||
getRejectNum(): number { |
||||
let num = 0 |
||||
this.auditList.forEach(item=>{ |
||||
if (item.auditStatus == 3) { |
||||
num = num + 1 |
||||
} |
||||
}) |
||||
return num |
||||
} |
||||
|
||||
} |
@ -0,0 +1,63 @@
|
||||
<div class="box"> |
||||
<div class="search"> |
||||
<div class="legendbox"> |
||||
</div> |
||||
<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="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" id="tablebox"> |
||||
<nz-table [nzLoading]="tableSpin" [nzPageSize]='999' #headerTable [nzData]="list" [nzShowPagination]="false" |
||||
[nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th style="text-align: center">序号</th> |
||||
<th *ngFor="let item of headerTable.data[0]"> |
||||
{{item.name}} |
||||
</th> |
||||
|
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td style="text-align: center">{{key + 1}}</td> |
||||
|
||||
<td *ngFor="let i of item"> |
||||
<ng-container *ngIf="i.value; else elseTemplate"> |
||||
<ng-container *ngIf="i.value.validityType; else elseTemplate"> |
||||
<span> |
||||
{{i.value.validityType}} |
||||
</span> |
||||
</ng-container> |
||||
<ng-template #elseTemplate> |
||||
{{i.value}} |
||||
</ng-template> |
||||
</ng-container> |
||||
<ng-template #elseTemplate> |
||||
/ |
||||
</ng-template> |
||||
|
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,79 @@
|
||||
.search { |
||||
box-sizing: border-box; |
||||
padding-left: 38px; |
||||
padding-right: 35px; |
||||
width: 100%; |
||||
height: 32px; |
||||
margin: 12px 0; |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
|
||||
.legendbox { |
||||
display: flex; |
||||
align-items: center; |
||||
color: #FFFFFF; |
||||
flex: 1; |
||||
|
||||
.legendItem { |
||||
display: flex; |
||||
align-items: center; |
||||
margin-right: 12px; |
||||
|
||||
div { |
||||
width: 8px; |
||||
height: 8px; |
||||
margin-right: 3px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
form { |
||||
flex: 1; |
||||
height: 32px; |
||||
display: flex; |
||||
justify-content: flex-end; |
||||
|
||||
input { |
||||
background: none; |
||||
border: 1px solid #91ccff; |
||||
color: #fff; |
||||
} |
||||
|
||||
.searchParams { |
||||
width: 35%; |
||||
} |
||||
|
||||
.btn { |
||||
margin-left: 16px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
display: flex; |
||||
flex-direction: column; |
||||
} |
||||
|
||||
.tablebox { |
||||
flex: 1; |
||||
display: flex; |
||||
flex-direction: column; |
||||
align-items: center; |
||||
overflow: hidden; |
||||
} |
||||
|
||||
|
||||
.green { |
||||
color: #4BFFD4; |
||||
} |
||||
|
||||
.yellow { |
||||
color: #FFBD4B; |
||||
} |
||||
|
||||
.red { |
||||
color: #FF4B65; |
||||
} |
@ -0,0 +1,184 @@
|
||||
import { Component, OnInit, ViewChild, ElementRef, ViewContainerRef } 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'; |
||||
import { NavChangeService } from 'src/app/service/navChange.service'; |
||||
import { fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import 'linqjs'; |
||||
import { DetailsUpdateCategoryComponent } from '../../license/update-category/details-update-category/details-update-category.component'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
|
||||
@Component({ |
||||
selector: 'app-file-license-list', |
||||
templateUrl: './file-license-list.component.html', |
||||
styleUrls: ['./file-license-list.component.scss'] |
||||
}) |
||||
export class FileLicenseListComponent implements OnInit { |
||||
|
||||
validateForm!: FormGroup; |
||||
constructor(private modal: NzModalService, private viewContainerRef: ViewContainerRef, private element: ElementRef, private navChangeService: NavChangeService, private http: HttpClient, private toTree: TreeService, private fb: FormBuilder, private nzContextMenuService: NzContextMenuService, private router: Router) { } |
||||
|
||||
tableScrollHeight |
||||
|
||||
ngOnInit(): void { |
||||
this.tableScrollHeight = '100px' |
||||
console.log('tableScrollHeight', this.tableScrollHeight) |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
let tableHeader = this.element.nativeElement.querySelector(`.ant-table-header`).clientHeight |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - tableHeader - 30) + 'px' |
||||
}); |
||||
this.validateForm = this.fb.group({ |
||||
name: [null] |
||||
}); |
||||
|
||||
this.tableSpin = true |
||||
} |
||||
ngAfterViewInit(): void { |
||||
|
||||
|
||||
fromEvent(this.element.nativeElement.querySelector(`.ant-table-body`) as HTMLCanvasElement, 'scroll').pipe(debounceTime(100)).subscribe(async (event: any) => { //监听 DOM 滚动事件
|
||||
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) { |
||||
if (this.totalCount > this.list.length) { |
||||
console.log('需要加载数据了', event) |
||||
this.SkipCount = String(Number(this.SkipCount) + 50) |
||||
await this.getStationLicenses() |
||||
} |
||||
} |
||||
}); |
||||
} |
||||
|
||||
submitForm(): void { |
||||
for (const i in this.validateForm.controls) { |
||||
this.validateForm.controls[i].markAsDirty(); |
||||
this.validateForm.controls[i].updateValueAndValidity(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getStationLicenses() |
||||
} |
||||
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(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getStationLicenses() |
||||
} |
||||
|
||||
tableSpin: boolean |
||||
totalCount: any //总数
|
||||
//获取点击组织机构的所有加油站
|
||||
SkipCount: string = '0' |
||||
MaxResultCount: string = '100' |
||||
|
||||
orId |
||||
list: any = [] |
||||
async getStationLicenses() { |
||||
let params = { |
||||
StationName: this.validateForm.value.name, |
||||
OrganizationUnitId: String(sessionStorage.getItem('planAdminOrid')), |
||||
IsContainsChildren: 'true', |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
// Sorting: ' BuildingBasicInfo.Id asc'
|
||||
} |
||||
this.tableSpin = true |
||||
await new Promise((resolve, reject) => { |
||||
this.http.get('/api/services/app/StationFileLicense/GetStationLicenses', { |
||||
params: params |
||||
}).subscribe((data: any) => { |
||||
this.totalCount = data.result.totalCount |
||||
let arr = [] |
||||
data.result.data.forEach(element => { |
||||
let keyArr = Object.keys(element); |
||||
let valueArr = Object.values(element); |
||||
let newElement = (keyArr as any).zip(valueArr, (a, b) => { return { name: a, value: b } }); |
||||
|
||||
//修改排头
|
||||
let newArr = [] |
||||
for (let index = 0; index < newElement.length; index++) { |
||||
const item = newElement[index]; |
||||
if (item.name == '省公司') { |
||||
newArr[0] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
if (item.name == '区域') { |
||||
newArr[1] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
if (item.name == '油站名称') { |
||||
newArr[2] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
} |
||||
let atLastArr = newArr.concat(newElement); |
||||
arr.push(atLastArr) |
||||
|
||||
}); |
||||
|
||||
|
||||
this.list = this.list.concat(arr); |
||||
this.list = [...this.list] |
||||
console.log('证照表格', this.list) |
||||
this.tableSpin = false |
||||
|
||||
setTimeout(() => { |
||||
let tableHeader = this.element.nativeElement.querySelector(`.ant-table-header`).clientHeight |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - tableHeader - 30) + 'px' |
||||
}, 0); |
||||
|
||||
|
||||
|
||||
resolve(data) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
//父组件调用子组件方法
|
||||
public onChildMethod() { |
||||
this.getStationLicenses() |
||||
} |
||||
|
||||
|
||||
lookDetails(i) { |
||||
// console.log(i)
|
||||
// let params = {
|
||||
// Id: i.licenseId
|
||||
// }
|
||||
// this.http.get('/api/services/app/StationValidityLicense/Get', { params: params }).subscribe((data: any) => {
|
||||
// console.log('证照信息', data)
|
||||
// const modal = this.modal.create({
|
||||
// nzContent: DetailsUpdateCategoryComponent,
|
||||
// nzViewContainerRef: this.viewContainerRef,
|
||||
// nzWidth: 450,
|
||||
// nzBodyStyle: {
|
||||
// 'border': '1px solid #91CCFF',
|
||||
// 'border-radius': '0px',
|
||||
// 'padding': '7px',
|
||||
// 'box-shadow': '0 0 8px 0 #fff',
|
||||
// 'background-image': 'linear-gradient(#003665, #000f25)'
|
||||
// },
|
||||
// nzComponentParams: {
|
||||
// data: data.result
|
||||
// },
|
||||
// nzFooter: null,
|
||||
// nzClosable: false,
|
||||
// nzOnOk: async () => {
|
||||
|
||||
// }
|
||||
// });
|
||||
// const instance = modal.getContentComponent();
|
||||
// modal.afterClose.subscribe(result => { });
|
||||
// })
|
||||
|
||||
|
||||
} |
||||
} |
@ -0,0 +1,78 @@
|
||||
<div class="box"> |
||||
<div class="search"> |
||||
<div class="legendbox"></div> |
||||
<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="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" id="tablebox"> |
||||
<nz-table [nzLoading]="tableSpin" [nzPageSize]='999' #headerTable [nzData]="list" [nzShowPagination]="false" |
||||
[nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th [nzWidth]="'20%'"> |
||||
<div |
||||
style="width: 20px;height: 20px;display: inline-block;margin-left: 20px;margin-right: 6px;"> |
||||
|
||||
</div>加油站名称 |
||||
</th> |
||||
<th>区域</th> |
||||
<th>所属公司</th> |
||||
<th style="text-align: center;">联系人</th> |
||||
<th style="text-align: center;">联系电话</th> |
||||
<th style="text-align: center;">油站等级</th> |
||||
<th style="text-align: center;">经营品类</th> |
||||
<th [nzWidth]="'6%'" style="text-align: center;">油机数量</th> |
||||
<th [nzWidth]="'6%'" style="text-align: center;">车道数量</th> |
||||
<th [nzWidth]="'8%'" style="text-align: center;">油罐容积</th> |
||||
<th [nzWidth]="'5%'">操作</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td nzEllipsis [title]="item.stationName"> |
||||
<div |
||||
style="width: 20px;height: 20px;display: inline-block;margin-left: 20px;margin-right: 6px;"> |
||||
<img src="../../../assets/images/3d.png" alt="" *ngIf="item.hasBuildingInfo"> |
||||
</div> |
||||
{{item.stationName}} |
||||
</td> |
||||
<td nzEllipsis [title]="item.locationName">{{item.locationName}}</td> |
||||
<td nzEllipsis [title]="item.companyName">{{item.companyName}}</td> |
||||
<td nzEllipsis [title]="item.leaderName" style="text-align: center;">{{item.leaderName}}</td> |
||||
<td nzEllipsis [title]="item.leaderContact" style="text-align: center;">{{item.leaderContact}}</td> |
||||
<td nzEllipsis [title]="item.stationLevel" style="text-align: center;">{{item.stationLevel}}</td> |
||||
<td nzEllipsis [title]="item.sellVariety" style="text-align: center;">{{item.sellVariety}}</td> |
||||
<td style="text-align: center;">{{item.gasStationCount}}</td> |
||||
<td style="text-align: center;">{{item.laneCount}}</td> |
||||
<td style="text-align: center;"> |
||||
<span>{{item.tankVolume}}</span> |
||||
<span>{{item.tankVolume ? 'm³' : null}}</span> |
||||
</td> |
||||
<td> |
||||
<span class="look" (click)="look(item)" style="cursor:pointer;color: #36A2FF">查看</span> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,66 @@
|
||||
.search { |
||||
box-sizing: border-box; |
||||
padding-left: 38px; |
||||
padding-right: 35px; |
||||
width: 100%; |
||||
height: 32px; |
||||
margin: 12px 0; |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
|
||||
.legendbox { |
||||
display: flex; |
||||
align-items: center; |
||||
color: #FFFFFF; |
||||
flex: 1; |
||||
|
||||
.legendItem { |
||||
display: flex; |
||||
align-items: center; |
||||
margin-right: 12px; |
||||
|
||||
div { |
||||
width: 8px; |
||||
height: 8px; |
||||
margin-right: 3px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
form { |
||||
flex: 1; |
||||
height: 32px; |
||||
display: flex; |
||||
justify-content: flex-end; |
||||
|
||||
input { |
||||
background: none; |
||||
border: 1px solid #91ccff; |
||||
color: #fff; |
||||
} |
||||
|
||||
.searchParams { |
||||
width: 35%; |
||||
} |
||||
|
||||
.btn { |
||||
margin-left: 16px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
display: flex; |
||||
flex-direction: column; |
||||
} |
||||
|
||||
.tablebox { |
||||
flex: 1; |
||||
display: flex; |
||||
flex-direction: column; |
||||
align-items: center; |
||||
overflow: hidden; |
||||
} |
@ -0,0 +1,123 @@
|
||||
import { Component, OnInit, ViewChild, ElementRef } 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'; |
||||
import { NavChangeService } from 'src/app/service/navChange.service'; |
||||
import { fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
|
||||
@Component({ |
||||
selector: 'app-oil-station-list', |
||||
templateUrl: './oil-station-list.component.html', |
||||
styleUrls: ['./oil-station-list.component.scss'] |
||||
}) |
||||
export class OilStationListComponent implements OnInit { |
||||
validateForm!: FormGroup; |
||||
constructor(private element: ElementRef, private navChangeService: NavChangeService, private http: HttpClient, private toTree: TreeService, private fb: FormBuilder, private nzContextMenuService: NzContextMenuService, private router: Router) { } |
||||
|
||||
tableScrollHeight |
||||
|
||||
ngOnInit(): void { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
|
||||
console.log('tableScrollHeight', this.tableScrollHeight) |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
}); |
||||
this.validateForm = this.fb.group({ |
||||
name: [null] |
||||
}); |
||||
|
||||
this.tableSpin = true |
||||
} |
||||
ngAfterViewInit(): void { |
||||
fromEvent(this.element.nativeElement.querySelector(`.ant-table-body`) as HTMLCanvasElement, 'scroll').pipe(debounceTime(100)).subscribe(async (event: any) => { //监听 DOM 滚动事件
|
||||
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) { |
||||
if (this.totalCount > this.list.length) { |
||||
console.log('需要加载数据了', event) |
||||
this.SkipCount = String(Number(this.SkipCount) + 50) |
||||
await this.getGasStation() |
||||
} |
||||
} |
||||
}); |
||||
} |
||||
|
||||
submitForm(): void { |
||||
for (const i in this.validateForm.controls) { |
||||
this.validateForm.controls[i].markAsDirty(); |
||||
this.validateForm.controls[i].updateValueAndValidity(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getGasStation() |
||||
} |
||||
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(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getGasStation() |
||||
} |
||||
|
||||
|
||||
|
||||
look(item) { |
||||
let gastionobj = { |
||||
organization: { |
||||
displayName: item.stationName, |
||||
isGasStation: true, |
||||
id: item.organizationUnitId |
||||
} |
||||
} |
||||
sessionStorage.setItem('userdataOfgasstation', JSON.stringify(gastionobj)) |
||||
this.router.navigate(['/todaywarning/petrolStation']) |
||||
let obj = { |
||||
name: 'oilstation' |
||||
} |
||||
this.navChangeService.sendMessage(obj);//发布一条消息
|
||||
} |
||||
|
||||
tableSpin: boolean |
||||
totalCount: any //总数
|
||||
//获取点击组织机构的所有加油站
|
||||
SkipCount: string = '0' |
||||
MaxResultCount: string = '100' |
||||
|
||||
orId |
||||
list: any = [] |
||||
async getGasStation() { |
||||
let params = { |
||||
StationName: this.validateForm.value.name, |
||||
OrganizationUnitId: String(sessionStorage.getItem('planAdminOrid')), |
||||
IsContainsChildren: 'true', |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
Sorting: ' BuildingBasicInfo.Id asc' |
||||
} |
||||
this.tableSpin = true |
||||
await new Promise((resolve, reject) => { |
||||
this.http.get('/api/services/app/GasStation/GetAll', { |
||||
params: params |
||||
}).subscribe((data: any) => { |
||||
this.totalCount = data.result.totalCount |
||||
this.list = this.list.concat(data.result.items); |
||||
this.list = [...this.list] |
||||
this.tableSpin = false |
||||
resolve(data) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
//父组件调用子组件方法
|
||||
public onChildMethod() { |
||||
this.getGasStation() |
||||
} |
||||
} |
@ -0,0 +1,73 @@
|
||||
<div class="box"> |
||||
<div class="search"> |
||||
<div class="legendbox"> |
||||
<div class="legendItem"> |
||||
<div style="background: #4BFFD4;box-shadow: 0px 2px 6px 1px #4BFFD4;"></div>办理提醒 |
||||
</div> |
||||
<div class="legendItem"> |
||||
<div style="background: #FFBD4B;box-shadow: 0px 2px 6px 1px #FFBD4B;"></div>临期提醒 |
||||
</div> |
||||
<div class="legendItem"> |
||||
<div style="background: #FF4B65;box-shadow: 0px 2px 6px 1px #FF4B65;"></div>逾期提醒 |
||||
</div> |
||||
</div> |
||||
<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="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" id="tablebox"> |
||||
<nz-table [nzLoading]="tableSpin" [nzPageSize]='999' #headerTable [nzData]="list" [nzShowPagination]="false" |
||||
[nzScroll]="{ y:tableScrollHeight }" [nzNoResult]='null' nzTableLayout="fixed"> |
||||
<thead> |
||||
<tr> |
||||
<th style="text-align: center">序号</th> |
||||
<th *ngFor="let item of headerTable.data[0]"> |
||||
{{item.name}} |
||||
</th> |
||||
|
||||
</tr> |
||||
</thead> |
||||
<tbody id="table"> |
||||
<tr *ngFor="let item of headerTable.data;let key = index"> |
||||
<td style="text-align: center">{{key + 1}}</td> |
||||
|
||||
<td *ngFor="let i of item"> |
||||
<ng-container *ngIf="i.value; else elseTemplate"> |
||||
<ng-container *ngIf="i.value.endDate; else elseTemplate"> |
||||
<span (click)="lookDetails(i.value)" style="cursor: pointer;" [ngClass]="{'green': i.value.licenseViolationType == 1,'yellow': i.value.licenseViolationType == 2,'red': i.value.licenseViolationType == 3}"> |
||||
{{i.value.endDate | date:"yyyy-MM-dd"}} |
||||
</span> |
||||
</ng-container> |
||||
<ng-template #elseTemplate> |
||||
{{i.value}} |
||||
</ng-template> |
||||
|
||||
</ng-container> |
||||
<ng-template #elseTemplate> |
||||
/ |
||||
</ng-template> |
||||
|
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</nz-table> |
||||
|
||||
</div> |
||||
</div> |
@ -0,0 +1,79 @@
|
||||
.search { |
||||
box-sizing: border-box; |
||||
padding-left: 38px; |
||||
padding-right: 35px; |
||||
width: 100%; |
||||
height: 32px; |
||||
margin: 12px 0; |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
|
||||
.legendbox { |
||||
display: flex; |
||||
align-items: center; |
||||
color: #FFFFFF; |
||||
flex: 1; |
||||
|
||||
.legendItem { |
||||
display: flex; |
||||
align-items: center; |
||||
margin-right: 12px; |
||||
|
||||
div { |
||||
width: 8px; |
||||
height: 8px; |
||||
margin-right: 3px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
form { |
||||
flex: 1; |
||||
height: 32px; |
||||
display: flex; |
||||
justify-content: flex-end; |
||||
|
||||
input { |
||||
background: none; |
||||
border: 1px solid #91ccff; |
||||
color: #fff; |
||||
} |
||||
|
||||
.searchParams { |
||||
width: 35%; |
||||
} |
||||
|
||||
.btn { |
||||
margin-left: 16px; |
||||
} |
||||
} |
||||
} |
||||
|
||||
.box { |
||||
width: 100%; |
||||
height: 100%; |
||||
display: flex; |
||||
flex-direction: column; |
||||
} |
||||
|
||||
.tablebox { |
||||
flex: 1; |
||||
display: flex; |
||||
flex-direction: column; |
||||
align-items: center; |
||||
overflow: hidden; |
||||
} |
||||
|
||||
|
||||
.green { |
||||
color: #4BFFD4; |
||||
} |
||||
|
||||
.yellow { |
||||
color: #FFBD4B; |
||||
} |
||||
|
||||
.red { |
||||
color: #FF4B65; |
||||
} |
@ -0,0 +1,185 @@
|
||||
import { Component, OnInit, ViewChild, ElementRef, ViewContainerRef } 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'; |
||||
import { NavChangeService } from 'src/app/service/navChange.service'; |
||||
import { fromEvent } from 'rxjs'; |
||||
import { debounceTime } from 'rxjs/operators'; |
||||
import 'linqjs'; |
||||
import { DetailsUpdateCategoryComponent } from '../../license/update-category/details-update-category/details-update-category.component'; |
||||
import { NzModalService } from 'ng-zorro-antd/modal'; |
||||
@Component({ |
||||
selector: 'app-update-license-list', |
||||
templateUrl: './update-license-list.component.html', |
||||
styleUrls: ['./update-license-list.component.scss'] |
||||
}) |
||||
export class UpdateLicenseListComponent implements OnInit { |
||||
|
||||
validateForm!: FormGroup; |
||||
constructor(private modal: NzModalService, private viewContainerRef: ViewContainerRef, private element: ElementRef, private navChangeService: NavChangeService, private http: HttpClient, private toTree: TreeService, private fb: FormBuilder, private nzContextMenuService: NzContextMenuService, private router: Router) { } |
||||
|
||||
tableScrollHeight |
||||
|
||||
ngOnInit(): void { |
||||
|
||||
|
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
|
||||
console.log('tableScrollHeight', this.tableScrollHeight) |
||||
// 页面监听
|
||||
fromEvent(window, 'resize').pipe(debounceTime(100)).subscribe((event) => { |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - 42) + 'px' |
||||
}); |
||||
this.validateForm = this.fb.group({ |
||||
name: [null] |
||||
}); |
||||
|
||||
this.tableSpin = true |
||||
} |
||||
ngAfterViewInit(): void { |
||||
|
||||
|
||||
fromEvent(this.element.nativeElement.querySelector(`.ant-table-body`) as HTMLCanvasElement, 'scroll').pipe(debounceTime(100)).subscribe(async (event: any) => { //监听 DOM 滚动事件
|
||||
if (event.target.scrollHeight - (event.target.scrollTop + event.target.clientHeight) <= 10) { |
||||
if (this.totalCount > this.list.length) { |
||||
console.log('需要加载数据了', event) |
||||
this.SkipCount = String(Number(this.SkipCount) + 50) |
||||
await this.getStationLicenses() |
||||
} |
||||
} |
||||
}); |
||||
} |
||||
|
||||
submitForm(): void { |
||||
for (const i in this.validateForm.controls) { |
||||
this.validateForm.controls[i].markAsDirty(); |
||||
this.validateForm.controls[i].updateValueAndValidity(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getStationLicenses() |
||||
} |
||||
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(); |
||||
} |
||||
this.list = [] |
||||
this.SkipCount = '0' |
||||
this.getStationLicenses() |
||||
} |
||||
|
||||
tableSpin: boolean |
||||
totalCount: any //总数
|
||||
//获取点击组织机构的所有加油站
|
||||
SkipCount: string = '0' |
||||
MaxResultCount: string = '100' |
||||
|
||||
orId |
||||
list: any = [] |
||||
async getStationLicenses() { |
||||
let params = { |
||||
StationName: this.validateForm.value.name, |
||||
OrganizationUnitId: String(sessionStorage.getItem('planAdminOrid')), |
||||
IsContainsChildren: 'true', |
||||
SkipCount: this.SkipCount, |
||||
MaxResultCount: this.MaxResultCount, |
||||
// Sorting: ' BuildingBasicInfo.Id asc'
|
||||
} |
||||
this.tableSpin = true |
||||
await new Promise((resolve, reject) => { |
||||
this.http.get('/api/services/app/StationValidityLicense/GetStationLicenses', { |
||||
params: params |
||||
}).subscribe((data: any) => { |
||||
this.totalCount = data.result.totalCount |
||||
let arr = [] |
||||
data.result.data.forEach(element => { |
||||
let keyArr = Object.keys(element); |
||||
let valueArr = Object.values(element); |
||||
let newElement = (keyArr as any).zip(valueArr, (a, b) => { return { name: a, value: b } }); |
||||
|
||||
//修改排头
|
||||
let newArr = [] |
||||
for (let index = 0; index < newElement.length; index++) { |
||||
const item = newElement[index]; |
||||
if (item.name == '省公司') { |
||||
newArr[0] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
if (item.name == '区域') { |
||||
newArr[1] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
if (item.name == '油站名称') { |
||||
newArr[2] = item |
||||
newElement.splice(index--, 1) |
||||
} |
||||
} |
||||
let atLastArr = newArr.concat(newElement); |
||||
arr.push(atLastArr) |
||||
|
||||
}); |
||||
|
||||
|
||||
this.list = this.list.concat(arr); |
||||
this.list = [...this.list] |
||||
console.log('证照表格', this.list) |
||||
this.tableSpin = false |
||||
|
||||
setTimeout(() => { |
||||
let tableHeader = this.element.nativeElement.querySelector(`.ant-table-header`).clientHeight |
||||
this.tableScrollHeight = (document.getElementById('tablebox').clientHeight - tableHeader - 30) + 'px' |
||||
}, 0); |
||||
|
||||
|
||||
|
||||
resolve(data) |
||||
}) |
||||
}) |
||||
} |
||||
|
||||
//父组件调用子组件方法
|
||||
public onChildMethod() { |
||||
this.getStationLicenses() |
||||
} |
||||
|
||||
|
||||
lookDetails(i) { |
||||
console.log(i) |
||||
let params = { |
||||
Id: i.licenseId |
||||
} |
||||
this.http.get('/api/services/app/StationValidityLicense/Get', { params: params }).subscribe((data:any) => { |
||||
console.log('证照信息', data) |
||||
const modal = this.modal.create({ |
||||
nzContent: DetailsUpdateCategoryComponent, |
||||
nzViewContainerRef: this.viewContainerRef, |
||||
nzWidth: 450, |
||||
nzBodyStyle: { |
||||
'border': '1px solid #91CCFF', |
||||
'border-radius': '0px', |
||||
'padding': '7px', |
||||
'box-shadow': '0 0 8px 0 #fff', |
||||
'background-image': 'linear-gradient(#003665, #000f25)' |
||||
}, |
||||
nzComponentParams: { |
||||
data: data.result |
||||
}, |
||||
nzFooter: null, |
||||
nzClosable: false, |
||||
nzOnOk: async () => { |
||||
|
||||
} |
||||
}); |
||||
const instance = modal.getContentComponent(); |
||||
modal.afterClose.subscribe(result => { }); |
||||
}) |
||||
|
||||
|
||||
} |
||||
} |
@ -0,0 +1,36 @@
|
||||
import { Pipe, PipeTransform } from '@angular/core'; |
||||
|
||||
@Pipe({ name: 'auditStatus' }) |
||||
export class auditStatusPipe implements PipeTransform { |
||||
transform(value: number): string { |
||||
let arr = ['未提交审核', '审核中', '审核通过', '审核驳回', '已撤销审核', '审核完成'] |
||||
return arr[value] |
||||
} |
||||
} |
||||
|
||||
// 通知内容
|
||||
@Pipe({ name: 'notificationContent' }) |
||||
export class notificationContent implements PipeTransform { |
||||
transform(value: number): string { |
||||
let arr = ['有效期', '年检'] |
||||
return arr[value] |
||||
} |
||||
} |
||||
|
||||
// 通知状态
|
||||
@Pipe({ name: 'licenseViolationType' }) |
||||
export class licenseViolationType implements PipeTransform { |
||||
transform(value: number): string { |
||||
let arr = ['无效', '办理提醒', '临期提醒', '逾期报警'] |
||||
return arr[value] |
||||
} |
||||
} |
||||
|
||||
// 处置状态
|
||||
@Pipe({ name: 'handleState' }) |
||||
export class handleState implements PipeTransform { |
||||
transform(value: number): string { |
||||
let arr = ['未启动', '已启动', '已关闭', '已延期'] |
||||
return arr[value] |
||||
} |
||||
} |
Loading…
Reference in new issue