3 Комити 5e9b4b964c ... da3c2a889f

Аутор SHA1 Порука Датум
  maotao da3c2a889f Merge branch 'develop' of http://git.dashitech.com/seimin/zy-pc into develop пре 2 недеља
  maotao 9ff8229910 Merge branch 'master' of http://git.dashitech.com/seimin/zy-pc пре 2 недеља
  maotao bae3985797 拉取代码 пре 2 недеља
38 измењених фајлова са 1096 додато и 262 уклоњено
  1. 1 5
      src/app/views/clinical-users-management/clinical-users-management.component.ts
  2. 2 2
      src/app/views/new-statistics/components/query-range/query-range.component.html
  3. 1 1
      src/app/views/new-statistics/components/query-range/query-range.component.ts
  4. 15 1
      src/app/views/new-statistics/components/search-more/search-more.component.html
  5. 29 3
      src/app/views/new-statistics/components/search-more/search-more.component.ts
  6. 14 0
      src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics-routing.module.ts
  7. 74 0
      src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.html
  8. 71 0
      src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.less
  9. 252 0
      src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.ts
  10. 21 0
      src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.module.ts
  11. 8 2
      src/app/views/new-statistics/distribution-inspection-statistics/date-business-statistics/date-business-statistics.component.html
  12. 2 2
      src/app/views/new-statistics/distribution-inspection-statistics/date-business-statistics/date-business-statistics.component.ts
  13. 21 18
      src/app/views/new-statistics/distribution-inspection-statistics/date-quality-control-statistics/date-quality-control-statistics.component.html
  14. 28 16
      src/app/views/new-statistics/distribution-inspection-statistics/department-business-statistics/department-business-statistics.component.html
  15. 55 13
      src/app/views/new-statistics/distribution-inspection-statistics/department-business-statistics/department-business-statistics.component.ts
  16. 31 23
      src/app/views/new-statistics/distribution-inspection-statistics/department-quality-control-statistics/department-quality-control-statistics.component.html
  17. 43 8
      src/app/views/new-statistics/distribution-inspection-statistics/department-quality-control-statistics/department-quality-control-statistics.component.ts
  18. 19 14
      src/app/views/new-statistics/distribution-inspection-statistics/distribution-department-source-statistics/distribution-department-source-statistics.component.html
  19. 43 8
      src/app/views/new-statistics/distribution-inspection-statistics/distribution-department-source-statistics/distribution-department-source-statistics.component.ts
  20. 9 0
      src/app/views/new-statistics/distribution-inspection-statistics/distribution-inspection-statistics-routing.module.ts
  21. 2 1
      src/app/views/new-statistics/distribution-inspection-statistics/distribution-synthesize-statistics/distribution-synthesize-statistics.component.html
  22. 8 2
      src/app/views/new-statistics/distribution-inspection-statistics/user-business-statistics/user-business-statistics.component.html
  23. 2 2
      src/app/views/new-statistics/distribution-inspection-statistics/user-business-statistics/user-business-statistics.component.ts
  24. 21 18
      src/app/views/new-statistics/distribution-inspection-statistics/user-quality-control-statistics/user-quality-control-statistics.component.html
  25. 11 8
      src/app/views/new-statistics/maintenance-statistics/consumable-statistics/consumable-statistics.component.html
  26. 11 6
      src/app/views/new-statistics/maintenance-statistics/department-evaluate-statistics/department-evaluate-statistics.component.html
  27. 60 12
      src/app/views/new-statistics/maintenance-statistics/department-evaluate-statistics/department-evaluate-statistics.component.ts
  28. 18 15
      src/app/views/new-statistics/maintenance-statistics/department-incident-statistics/department-incident-statistics.component.html
  29. 56 11
      src/app/views/new-statistics/maintenance-statistics/department-incident-statistics/department-incident-statistics.component.ts
  30. 12 7
      src/app/views/new-statistics/maintenance-statistics/department-source-statistics/department-source-statistics.component.html
  31. 70 22
      src/app/views/new-statistics/maintenance-statistics/department-source-statistics/department-source-statistics.component.ts
  32. 6 5
      src/app/views/new-statistics/maintenance-statistics/tripartite-company-statistics/tripartite-company-statistics.component.html
  33. 35 9
      src/app/views/new-statistics/maintenance-statistics/tripartite-company-statistics/tripartite-company-statistics.component.ts
  34. 25 22
      src/app/views/new-statistics/maintenance-statistics/user-statistics/user-statistics.component.html
  35. 12 0
      src/app/views/task-type-management/task-type-management.component.html
  36. 4 0
      src/app/views/task-type-management/task-type-management.component.ts
  37. 3 1
      src/app/views/tripartite-company/tripartite-company.component.ts
  38. 1 5
      src/app/views/users-management/users-management.component.ts

+ 1 - 5
src/app/views/clinical-users-management/clinical-users-management.component.ts

@@ -326,7 +326,6 @@ export class ClinicalUsersManagementComponent implements OnInit {
326 326
     });
327 327
     let data = {
328 328
       user: {
329
-				upType: "changeDept",
330 329
         name: that.validateForm.value.name,
331 330
         account: that.validateForm.value.account,
332 331
         gradeId: that.validateForm.value.gradeId,
@@ -348,10 +347,7 @@ export class ClinicalUsersManagementComponent implements OnInit {
348 347
     }
349 348
     if (!that.add) {
350 349
       data.user["id"] = that.coopId;
351
-			data.user.upType = "changeDept";
352
-    }else{
353
-			delete data.user.upType;
354
-		}
350
+    }
355 351
     that.mainService
356 352
       .coopData(that.add ? "addData" : "updData", "user", data)
357 353
       .subscribe((data) => {

+ 2 - 2
src/app/views/new-statistics/components/query-range/query-range.component.html

@@ -42,7 +42,7 @@
42 42
             </nz-select>
43 43
           </nz-form-control>
44 44
         </nz-form-item>
45
-	<!-- 			<nz-form-item class="mb0">
45
+				<nz-form-item class="mb0">
46 46
 				  <nz-form-label [nzSpan]="7" nzRequired nzFor="parent">是否显示父级科室</nz-form-label>
47 47
 				  <nz-form-control [nzSpan]="15" nzErrorTip="请选择是否显示父级科室!">
48 48
 				    <nz-radio-group formControlName="parent">
@@ -50,7 +50,7 @@
50 50
 				      <label nz-radio [nzValue]="0">否</label>
51 51
 				    </nz-radio-group>
52 52
 				  </nz-form-control>
53
-				</nz-form-item> -->
53
+				</nz-form-item>
54 54
       </form>
55 55
     </div>
56 56
     <div class="display_flex justify-content_flex-center">

+ 1 - 1
src/app/views/new-statistics/components/query-range/query-range.component.ts

@@ -40,7 +40,7 @@ export class QueryRangeComponent implements OnInit {
40 40
       hospital: [(this.hospital && (this.queryType == 2 || this.queryType == 3)) ? this.hospital.id : null],
41 41
       duty: [(this.duty && this.queryType == 3) ? this.duty.id : null],
42 42
       dutyOne: [(this.duty && this.queryType == 4) ? this.duty.id : null],
43
-			parent :[this.parent, [Validators.required]]
43
+			parent :[this.parent?1:0, [Validators.required]]
44 44
     });
45 45
   }
46 46
   // 表单提交

+ 15 - 1
src/app/views/new-statistics/components/search-more/search-more.component.html

@@ -1,6 +1,6 @@
1 1
 <div class="save add display_flex align-items_center justify-content_flex-center">
2 2
   <div class="modalBody">
3
-    <div class="title">详细搜索<i class="icon_transport transport-guanbi" (click)="hideModal()"></i>
3
+    <div class="title">更多搜索<i class="icon_transport transport-guanbi" (click)="hideModal()"></i>
4 4
     </div>
5 5
     <div class="content">
6 6
       <form nz-form [formGroup]="validateForm" class="addForm">
@@ -143,6 +143,20 @@
143 143
             </nz-select>
144 144
           </nz-form-control>
145 145
         </nz-form-item>
146
+				
147
+				<nz-form-item [hidden]="!fieldConfig.config.deptType">
148
+				  <nz-form-label [nzSpan]="6" nzFor="deptTypeId">科室类型</nz-form-label>
149
+				  <nz-form-control [nzSpan]="18" nzErrorTip="请选择科室类型!">
150
+				    <nz-select [nzDropdownMatchSelectWidth]="false" nzAllowClear nzShowSearch formControlName="deptTypeId" nzPlaceHolder="请选择科室类型" (nzOpenChange)="openChangeDeptType($event)">
151
+				      <ng-container *ngFor="let option of deptTypeList">
152
+				        <nz-option *ngIf="!isLoading" [nzLabel]="option.name" [nzValue]="option.id"></nz-option>
153
+				      </ng-container>
154
+				      <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
155
+				        <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
156
+				      </nz-option>
157
+				    </nz-select>
158
+				  </nz-form-control>
159
+				</nz-form-item>
146 160
       </form>
147 161
     </div>
148 162
     <div class="display_flex justify-content_flex-center">

+ 29 - 3
src/app/views/new-statistics/components/search-more/search-more.component.ts

@@ -51,7 +51,8 @@ export class SearchMoreComponent implements OnInit {
51 51
     this.floorList = this.fieldConfig.fields.floorDTO ? [this.fieldConfig.fields.floorDTO] : [];
52 52
     this.companyList = this.fieldConfig.fields.companyDTO ? [this.fieldConfig.fields.companyDTO] : [];
53 53
     this.repairDeptList = this.fieldConfig.fields.repairDeptDTO ? [this.fieldConfig.fields.repairDeptDTO] : [];
54
-
54
+		this.deptTypeList = this.fieldConfig.fields.deptTypeDTO ? [this.fieldConfig.fields.deptTypeDTO] : [];
55
+		 
55 56
     this.validateForm = this.fb.group({
56 57
       groupId: [this.fieldConfig.fields.groupId || null],
57 58
       userId: [this.fieldConfig.fields.userId === undefined ? null : this.fieldConfig.fields.userId],
@@ -63,7 +64,8 @@ export class SearchMoreComponent implements OnInit {
63 64
       floorId: [this.fieldConfig.fields.floorId === undefined ? null : this.fieldConfig.fields.floorId],
64 65
       companyId: [this.fieldConfig.fields.companyDTO ? this.fieldConfig.fields.companyDTO.id  : null],
65 66
       repairDeptId: [this.fieldConfig.fields.repairDeptDTO ? this.fieldConfig.fields.repairDeptDTO.id  : null],
66
-    });
67
+			deptTypeId: [this.fieldConfig.fields.deptTypeId || null],
68
+		});
67 69
   }
68 70
   // 表单提交
69 71
   submitForm(): void {
@@ -116,6 +118,11 @@ export class SearchMoreComponent implements OnInit {
116 118
       fields.repairDeptId = this.validateForm.value.repairDeptId;
117 119
       fields.repairDeptDTO = this.repairDeptList.find(item => item.id == this.validateForm.value.repairDeptId);
118 120
     }
121
+		if(this.fieldConfig.config.deptType){
122
+		  fields.deptTypeId = this.validateForm.value.deptTypeId;
123
+		  fields.deptTypeDTO = this.deptTypeList.find(item => item.id == this.validateForm.value.deptTypeId);
124
+		}
125
+		
119 126
     this.submitEvent.emit(fields);
120 127
     this.hideModal();
121 128
   }
@@ -181,7 +188,26 @@ export class SearchMoreComponent implements OnInit {
181 188
     this.validateForm.controls.userId.setValue(null);
182 189
     this.getUserList();
183 190
   }
184
-
191
+	
192
+	// =================科室类型===================
193
+	
194
+	// 科室类型
195
+	openChangeDeptType(flag){
196
+	  flag && this.getDeptTypeList();
197
+	}
198
+	
199
+	// 获取科室类型列表
200
+	deptTypeList:any[] = [];
201
+	getDeptTypeList(keyword?) {
202
+	  this.isLoading = true;
203
+	  this.mainService
204
+	    .getDictionary("list", "dept_type")
205
+	    .subscribe((data) => {
206
+	      this.isLoading = false;
207
+	      this.deptTypeList = data;
208
+	    });
209
+	}
210
+	
185 211
   // =================维修人员===================
186 212
 
187 213
   // 维修人员搜索

+ 14 - 0
src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics-routing.module.ts

@@ -0,0 +1,14 @@
1
+import { NgModule } from '@angular/core';
2
+import { Routes, RouterModule } from '@angular/router';
3
+import { BusinessClassifyStatisticsComponent } from './business-classify-statistics.component';
4
+
5
+
6
+const routes: Routes = [
7
+  { path: '', component: BusinessClassifyStatisticsComponent }
8
+];
9
+
10
+@NgModule({
11
+  imports: [RouterModule.forChild(routes)],
12
+  exports: [RouterModule]
13
+})
14
+export class BusinessClassifyStatisticsRoutingModule { }

+ 74 - 0
src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.html

@@ -0,0 +1,74 @@
1
+<div class="searchDataWrap">
2
+  <div class="searchData">
3
+    <div class="searchDataItem">
4
+      <span class="label">建单时间</span>:
5
+      <nz-range-picker [(ngModel)]="dateRange" [nzAllowClear]="false" (ngModelChange)="changeDate($event)" (nzOnCalendarChange)="onCalendarChangeDate($event)">
6
+      </nz-range-picker>
7
+    </div>
8
+  </div>
9
+  <div class="operation">
10
+    <i class="icon_transport transport-gengduo" nz-tooltip nzTooltipTitle="更多搜索" (click)="showMore()"></i>
11
+    <button nz-button class="btn default" (click)="search()">查询</button>
12
+    <button nz-button class="btn default ml8" (click)="reset()">重置</button>
13
+    <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
14
+  </div>
15
+</div>
16
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.taskTypeDTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.deptDTO">
17
+  <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
18
+  <span>{{fieldConfig.fields.userDTO?.name}}</span>
19
+  <span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
20
+  <span>{{fieldConfig.fields.deptDTO?.dept}}</span>
21
+</div>
22
+<nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
23
+  <thead (nzSortChange)="sort($event)" nzSingleSort>
24
+    <tr>
25
+      <th nzWidth="10%">业务分类名称</th>
26
+      <th nzWidth="10%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
27
+      <th nzWidth="10%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
28
+      <th nzWidth="10%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
29
+			<th nzWidth="10%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
30
+      <th nzWidth="10%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
31
+      <th nzWidth="10%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
32
+      <th nzWidth="10%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
33
+      <th nzWidth="10%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
34
+      <th nzWidth="10%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭工单</th>
35
+    </tr>
36
+  </thead>
37
+  <tbody>
38
+    <tr *ngFor="let data of listOfData">
39
+      <td>{{ data.name }}</td>
40
+      <td>{{ data.totalCount }}</td>
41
+      <td>{{ data.totalGrade }}</td>
42
+			<td>{{ data.totalPrice }}</td>
43
+      <td>{{ data.response_time_num }}</td>
44
+      <td>{{ data.execution_time_num }}</td>
45
+      <td>{{ data.aveper }}</td>
46
+      <td>{{ data.total_time }}</td>
47
+      <td>{{ data.five_count }}</td>
48
+      <td>{{ data.special_close }}</td>
49
+    </tr>
50
+  </tbody>
51
+  <ng-template #footerTpl>
52
+    <table class="footTable">
53
+      <tr *ngFor="let data of listOfDataEnd">
54
+        <td style="width: 10%">{{ data.name }}</td>
55
+        <td style="width: 10%">{{ data.totalCount }}</td>
56
+        <td style="width: 10%">{{ data.totalGrade }}</td>
57
+				<td style="width: 10%">{{ data.totalPrice }}</td>
58
+        <td style="width: 10%">{{ data.response_time_num }}</td>
59
+        <td style="width: 10%">{{ data.execution_time_num }}</td>
60
+        <td style="width: 10%">{{ data.aveper }}</td>
61
+        <td style="width: 10%">{{ data.total_time }}</td>
62
+        <td style="width: 10%">{{ data.five_count }}</td>
63
+        <td style="width: 10%">{{ data.special_close }}</td>
64
+      </tr>
65
+    </table>
66
+  </ng-template>
67
+</nz-table>
68
+<div class="pagination">
69
+  <ng-template #totalTemplate let-total> 共 {{ total }} 条 </ng-template>
70
+  <nz-pagination [(nzPageIndex)]="pageIndex" [(nzTotal)]="listLength" [(nzPageSize)]="pageSize" (nzPageIndexChange)="getList(pageIndex, sortCurrentKey, sortCurrentValue)" (nzPageSizeChange)="getList(pageIndex, sortCurrentKey, sortCurrentValue)" nzShowSizeChanger [nzPageSizeOptions]="[30,50,100,200]" [nzShowTotal]="totalTemplate"></nz-pagination>
71
+</div>
72
+
73
+<!-- 详细搜索 -->
74
+<app-distribution-search-more [fieldConfig]="fieldConfig" *ngIf="showSearchMore" [hosId]="hosId" [queryType]="queryType"  [dutyId]="dutyId"  [parentDutyId]="parentDutyId" (cancelEvent)="cancelEvent()" (submitEvent)="submitEvent($event)"></app-distribution-search-more>

+ 71 - 0
src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.less

@@ -0,0 +1,71 @@
1
+@import "../../../../../../src/theme.less";
2
+:host{
3
+  position: absolute;
4
+  top: 0;
5
+  right: 0;
6
+  bottom: 0;
7
+  left: 0;
8
+  ::ng-deep .ant-table-footer{
9
+    padding: 16px 0;
10
+    width: calc(100% - 15px);
11
+    font-weight: bold;
12
+  }
13
+  tr, th{
14
+    text-align: center;
15
+  }
16
+  .searchDataWrap{
17
+    display: flex;
18
+    align-items: center;
19
+    justify-content: space-between;
20
+    .searchData{
21
+      padding: 16px;
22
+      display: flex;
23
+      align-items: center;
24
+      .searchDataItem{
25
+        margin-right: 24px;
26
+        .label{
27
+          font-size: 16px;
28
+        }
29
+        .selectItem{
30
+          width: 224px;
31
+        }
32
+      }
33
+    }
34
+    .operation{
35
+      margin-right: 16px;
36
+      display: flex;
37
+      align-items: center;
38
+      cursor: pointer;
39
+      .icon_transport{
40
+        margin-right: 16px;
41
+        font-size: 24px;
42
+      }
43
+      .btn{
44
+        &.default{
45
+          height: 32px;
46
+          line-height: 32px;
47
+          min-width: 70px;
48
+        }
49
+      }
50
+    }
51
+  }
52
+
53
+  .table{
54
+    margin: 0 8px;
55
+  }
56
+
57
+  .moreFilter{
58
+    margin-bottom: 16px;
59
+    span{
60
+      margin-left: 16px;
61
+      color: @primary-color;
62
+    }
63
+  }
64
+
65
+  .pagination{
66
+    padding: 16px;
67
+    display: flex;
68
+    justify-content: flex-end;
69
+    align-items: center;
70
+  }
71
+}

+ 252 - 0
src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.component.ts

@@ -0,0 +1,252 @@
1
+import { TabService } from './../../services/tab.service';
2
+import { NzMessageService } from 'ng-zorro-antd/message';
3
+import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } from 'date-fns';
4
+import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
5
+import { MainService } from 'src/app/services/main.service';
6
+import { ActivatedRoute } from '@angular/router';
7
+@Component({
8
+  selector: "app-business-classify-statistics",
9
+  templateUrl: "./business-classify-statistics.component.html",
10
+  styleUrls: ["./business-classify-statistics.component.less"],
11
+})
12
+export class BusinessClassifyStatisticsComponent implements OnInit, AfterViewInit {
13
+  constructor(
14
+    private mainService: MainService,
15
+    private message: NzMessageService,
16
+    private route: ActivatedRoute,
17
+    private tabService: TabService,
18
+  ) {}
19
+
20
+  listOfData: any[] = []; //表格数据
21
+  listOfDataEnd: any[] = []; //表格合计
22
+  pageIndex: number = 1; //表格当前页码
23
+  pageSize: number = 30; //表格每页展示条数
24
+  listLength: number = 0; //表格总数据量
25
+
26
+  statisticsTypeId;//统计分类id
27
+
28
+  ngOnInit() {
29
+    this.initSessionData();
30
+    this.getQueryParams();
31
+    this.search();
32
+  }
33
+
34
+  ngAfterViewInit(){
35
+    this.onResize();
36
+  }
37
+
38
+  tableHeight:number = 0;
39
+  @HostListener('window:resize')
40
+  onResize(): void {
41
+    setTimeout(() => {
42
+      this.tableHeight = window.innerHeight - (document.querySelector('.searchDataWrap') as HTMLElement).offsetHeight - 64 - 36 - 48 - 8 - (document.querySelector('.ant-table-header') as HTMLElement).offsetHeight - 55 - this.getMoreFilter + 14;
43
+
44
+    }, 0)
45
+  }
46
+
47
+  getQueryParams(){
48
+    let queryParams = this.tabService.getQueryParams();
49
+    this.tabService.clearQueryParams();
50
+    if(queryParams.dateRange){
51
+      this.dateRange = queryParams.dateRange;
52
+    }
53
+  }
54
+
55
+  get getMoreFilter(){
56
+    let flag = this.fieldConfig.fields.groupDTO || this.fieldConfig.fields.userDTO || this.fieldConfig.fields.taskTypeDTO || this.fieldConfig.fields.buildingDTO || this.fieldConfig.fields.deptDTO;
57
+    return flag ? 37 : 0;
58
+  }
59
+
60
+  // 初始化缓存数据
61
+  queryType:any;
62
+  hosId:any;
63
+  dutyId:any;
64
+  parentDutyId:any;
65
+  initSessionData(){
66
+    let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
67
+    let queryType:any = newStatistics.queryType;
68
+    let hosId:any = newStatistics.hospitalId;
69
+    let dutyId:any = newStatistics.dutyId;
70
+
71
+    queryType = queryType ? +queryType : undefined;
72
+    hosId = hosId ? +hosId : undefined;
73
+    dutyId = dutyId ? +dutyId : undefined;
74
+
75
+    this.queryType = queryType;
76
+    if(queryType == 1){
77
+      this.hosId = undefined;
78
+      this.dutyId = undefined;
79
+      this.parentDutyId = undefined;
80
+    }else if(queryType == 2){
81
+      this.hosId = hosId;
82
+      this.dutyId = undefined;
83
+      this.parentDutyId = undefined;
84
+    }else if(queryType == 3){
85
+      this.hosId = undefined;
86
+      this.dutyId = dutyId;
87
+      this.parentDutyId = undefined;
88
+    }else if(queryType == 4){
89
+      this.hosId = undefined;
90
+      this.dutyId = undefined;
91
+      this.parentDutyId = dutyId;
92
+    }
93
+  }
94
+
95
+  get getHosId(){
96
+    return this.parentDutyId || this.dutyId || this.hosId;
97
+  }
98
+
99
+  // 表格数据
100
+  loading1 = false;
101
+  getList(num?: number, field?: string, sort?: string) {
102
+    if (num !== undefined) {
103
+      this.pageIndex = num;
104
+    }
105
+    let postData:any = {
106
+      idx: this.pageIndex - 1,
107
+      sum: this.pageSize,
108
+      startDate: this.dateRange[0] || undefined,
109
+      endDate: this.dateRange[1] || undefined,
110
+      hosId: this.getHosId,
111
+      groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
112
+      userId: this.fieldConfig.fields.userId || undefined,
113
+      buildingId: this.fieldConfig.fields.buildingId || undefined,
114
+      deptId: this.fieldConfig.fields.deptId || undefined,
115
+    };
116
+    if (field && sort) {
117
+      postData.sort = `${field} ${sort === "ascend" ? `asc` : `desc`}`
118
+    }
119
+    this.loading1 = true;
120
+    this.mainService
121
+      .postCustom("itsm/report", "statisticsDateTransOrderQc", postData)
122
+      .subscribe((result) => {
123
+        this.loading1 = false;
124
+        this.listOfData = result.dataList.filter((v, i) => { return i != result.dataList.length - 1 });
125
+        this.listOfDataEnd = result.dataList.filter((v, i) => { return i == result.dataList.length - 1 });
126
+        this.listLength = result.totalCount;
127
+      });
128
+  }
129
+
130
+  // 列表排序
131
+  sortCurrent:any = {};
132
+  sortCurrentKey: string = "";
133
+  sortCurrentValue: string | null = "";
134
+  sort(e) {
135
+    const { key, value } = e;
136
+    this.sortCurrentKey = key;
137
+    this.sortCurrentValue = value;
138
+    this.getList(this.pageIndex, this.sortCurrentKey, this.sortCurrentValue);
139
+  }
140
+
141
+  // 搜索
142
+  search() {
143
+    this.getList(1, this.sortCurrentKey, this.sortCurrentValue);
144
+  }
145
+
146
+  // 日期选择
147
+  dateRange: any = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')];
148
+  changeDate(result?): void {
149
+    result[0] = format(startOfDay(result[0]), 'yyyy-MM-dd HH:mm:ss');
150
+    result[1] = format(endOfDay(result[1]), 'yyyy-MM-dd HH:mm:ss');
151
+    this.dateRange = result;
152
+  }
153
+
154
+  onCalendarChangeDate(dateArr){
155
+    console.log(dateArr)
156
+    if(dateArr.length == 2){
157
+      this.dateRange = [format(startOfDay(dateArr[0]), 'yyyy-MM-dd HH:mm:ss'), format(endOfDay(dateArr[1]), 'yyyy-MM-dd HH:mm:ss')];
158
+    }
159
+  }
160
+
161
+  // 导出
162
+  excelExportLoading:any = false;
163
+  excelExport(){
164
+    this.excelExportLoading = this.message.loading("导出中..", {
165
+      nzDuration: 0,
166
+    }).messageId;
167
+    let postData:any = {
168
+      startDate: this.dateRange[0] || undefined,
169
+      endDate: this.dateRange[1] || undefined,
170
+      hosId: this.getHosId,
171
+      groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
172
+      userId: this.fieldConfig.fields.userId || undefined,
173
+      buildingId: this.fieldConfig.fields.buildingId || undefined,
174
+      deptId: this.fieldConfig.fields.deptId || undefined,
175
+    };
176
+    if (this.sortCurrentKey && this.sortCurrentValue) {
177
+      postData.sort = `${this.sortCurrentKey} ${this.sortCurrentValue === "ascend" ? `asc` : `desc`}`
178
+    }
179
+    this.mainService
180
+      .postExportCustom("itsm/exportMergeTitle", "statisticsDateTransOrderQc", postData)
181
+      .subscribe((data) => {
182
+        this.message.remove(this.excelExportLoading);
183
+        this.excelExportLoading = false;
184
+        this.message.success('导出成功');
185
+        var file = new Blob([data], {
186
+          type: "application/vnd.ms-excel",
187
+        });
188
+        //trick to download store a file having its URL
189
+        var fileURL = URL.createObjectURL(file);
190
+        var a = document.createElement("a");
191
+        a.href = fileURL;
192
+        a.target = "_blank";
193
+        a.download = `${this.route.parent.routeConfig.data.title}.xls`;
194
+        document.body.appendChild(a);
195
+        a.click();
196
+      },(err) => {
197
+        this.message.remove(this.excelExportLoading);
198
+        this.excelExportLoading = false;
199
+        this.message.error('导出失败');
200
+      });
201
+  }
202
+  // 重置
203
+  reset(){
204
+    this.sortCurrentKey = "";
205
+		this.sortCurrentValue = "";
206
+		this.sortCurrent = {};
207
+    this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
208
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, buildingId: undefined, deptId: undefined};
209
+    this.search();
210
+  }
211
+
212
+  // 防抖
213
+  isLoading = false;
214
+
215
+  openChangeStatisticsType(flag){
216
+    flag && this.getStatisticsTypeList();
217
+  }
218
+
219
+  // 获取统计分类列表
220
+  statisticsTypeList:any[] = [];
221
+  getStatisticsTypeList(keyword?) {
222
+    this.isLoading = true;
223
+    this.mainService
224
+      .getDictionary("list", "statistics_date_type")
225
+      .subscribe((data) => {
226
+        this.isLoading = false;
227
+        this.statisticsTypeList = data;
228
+      });
229
+  }
230
+
231
+  // 详细搜索
232
+  fieldConfig:any = {
233
+    fields: {groupId: undefined, userId: undefined, buildingId: undefined, deptId: undefined},
234
+    config: {groupAndUser: true, building: true, dept: true},
235
+  }
236
+  showSearchMore:boolean = false;
237
+  showMore(){
238
+    this.showSearchMore = true;
239
+  }
240
+
241
+  cancelEvent(){
242
+    this.showSearchMore = false;
243
+  }
244
+
245
+  submitEvent(fields){
246
+    this.showSearchMore = false;
247
+    this.fieldConfig.fields = fields;
248
+    console.log('this.fieldConfig.fields:', this.fieldConfig.fields)
249
+    this.search();
250
+    this.onResize();
251
+  }
252
+}

+ 21 - 0
src/app/views/new-statistics/distribution-inspection-statistics/business-classify-statistics/business-classify-statistics.module.ts

@@ -0,0 +1,21 @@
1
+import { BusinessClassifyStatisticsComponent } from './business-classify-statistics.component';
2
+import { NgModule } from '@angular/core';
3
+import { CommonModule } from '@angular/common';
4
+
5
+import { BusinessClassifyStatisticsRoutingModule } from './business-classify-statistics-routing.module';
6
+import { ShareModule } from 'src/app/share/share.module';
7
+import { DistributionSearchMoreModule } from '../../components/distribution-search-more/distribution-search-more.module';
8
+
9
+
10
+@NgModule({
11
+  declarations: [
12
+    BusinessClassifyStatisticsComponent,
13
+  ],
14
+  imports: [
15
+    CommonModule,
16
+    BusinessClassifyStatisticsRoutingModule,
17
+    ShareModule,
18
+    DistributionSearchMoreModule,
19
+  ]
20
+})
21
+export class BusinessClassifyStatisticsModule { }

+ 8 - 2
src/app/views/new-statistics/distribution-inspection-statistics/date-business-statistics/date-business-statistics.component.html

@@ -20,18 +20,20 @@
20 20
   <span>{{fieldConfig.fields.deptDTO?.dept}}</span>
21 21
 </div>
22 22
 <div class="tableWrap">
23
-  <nz-table class="table" [ngStyle]="{ width: widthConfig.length * 100 + 20 + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
23
+  <nz-table class="table" [ngStyle]="{ width: widthConfig.length * 100 + 100 + 20 + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
24 24
     <thead (nzSortChange)="sort($event)" nzSingleSort>
25 25
       <tr>
26 26
         <th rowspan="2" nzShowSort nzSortKey="date" [(nzSort)]="sortCurrent.date">日期</th>
27 27
         <th rowspan="2" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
28 28
         <th rowspan="2" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">积分总和</th>
29
-        <th colspan="2" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
29
+        <th rowspan="2" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
30
+				<th colspan="3" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
30 31
       </tr>
31 32
       <tr>
32 33
         <ng-container *ngFor="let dictionary of dictionaryList">
33 34
           <th nzShowSort [nzSortKey]="dictionary.value + 'Count'" [(nzSort)]="sortCurrent[dictionary.value + 'Count']">工单量</th>
34 35
           <th nzShowSort [nzSortKey]="dictionary.value + 'Grade'" [(nzSort)]="sortCurrent[dictionary.value + 'Grade']">积分数</th>
36
+					<th nzShowSort [nzSortKey]="dictionary.value + 'Score'" [(nzSort)]="sortCurrent[dictionary.value + 'Score']">费用(元)</th>
35 37
         </ng-container>
36 38
       </tr>
37 39
     </thead>
@@ -40,9 +42,11 @@
40 42
         <td>{{ data.date }}</td>
41 43
         <td>{{ data.totalCount }}</td>
42 44
         <td>{{ data.totalGrade }}</td>
45
+				<td>{{ data.totalPrice }}</td>
43 46
         <ng-container *ngFor="let dictionary of dictionaryList">
44 47
           <td>{{ data[dictionary.value + 'Count'] }}</td>
45 48
           <td>{{ data[dictionary.value + 'Grade'] }}</td>
49
+					<td>{{ data[dictionary.value + 'Score'] }}</td>
46 50
         </ng-container>
47 51
       </tr>
48 52
     </tbody>
@@ -52,9 +56,11 @@
52 56
           <td>{{ data.date }}</td>
53 57
           <td>{{ data.totalCount }}</td>
54 58
           <td>{{ data.totalGrade }}</td>
59
+					<td>{{ data.totalPrice }}</td>
55 60
           <ng-container *ngFor="let dictionary of dictionaryList">
56 61
             <td>{{ data[dictionary.value + 'Count'] }}</td>
57 62
             <td>{{ data[dictionary.value + 'Grade'] }}</td>
63
+						<td>{{ data[dictionary.value + 'Score'] }}</td>
58 64
           </ng-container>
59 65
         </tr>
60 66
       </table>

+ 2 - 2
src/app/views/new-statistics/distribution-inspection-statistics/date-business-statistics/date-business-statistics.component.ts

@@ -104,9 +104,9 @@ export class DateBusinessStatisticsComponent implements OnInit, AfterViewInit {
104 104
       let dictionaryList = data || [];
105 105
       dictionaryList = cloneDeep(dictionaryList);
106 106
       let flag = dictionaryList.some((item) => item.value === 'dateOther');
107
-      !flag && dictionaryList.push({id: 0, name: '其他', value: 'dateOther'});
107
+      !flag && dictionaryList.push({id: 0, name: '未知', value: 'dateOther'});
108 108
       this.dictionaryList = dictionaryList;
109
-      this.widthConfig = new Array(this.dictionaryList.length * 2 + 3).fill('100px');
109
+      this.widthConfig = new Array(this.dictionaryList.length * 3 + 3).fill('100px');
110 110
       if (num !== undefined) {
111 111
         this.pageIndex = num;
112 112
       }

+ 21 - 18
src/app/views/new-statistics/distribution-inspection-statistics/date-quality-control-statistics/date-quality-control-statistics.component.html

@@ -34,15 +34,16 @@
34 34
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
35 35
   <thead (nzSortChange)="sort($event)" nzSingleSort>
36 36
     <tr>
37
-      <th nzWidth="12%" nzShowSort nzSortKey="date" [(nzSort)]="sortCurrent.date">日期</th>
38
-      <th nzWidth="11%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
39
-      <th nzWidth="11%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
40
-      <th nzWidth="11%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
41
-      <th nzWidth="11%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
42
-      <th nzWidth="11%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
43
-      <th nzWidth="11%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
44
-      <th nzWidth="11%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
45
-      <th nzWidth="11%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
37
+      <th nzWidth="10%" nzShowSort nzSortKey="date" [(nzSort)]="sortCurrent.date">日期</th>
38
+      <th nzWidth="10%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
39
+      <th nzWidth="10%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
40
+			<th nzWidth="10%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
41
+      <th nzWidth="10%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
42
+      <th nzWidth="10%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
43
+      <th nzWidth="10%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
44
+      <th nzWidth="10%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
45
+      <th nzWidth="10%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
46
+      <th nzWidth="10%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
46 47
     </tr>
47 48
   </thead>
48 49
   <tbody>
@@ -50,6 +51,7 @@
50 51
       <td>{{ data.date }}</td>
51 52
       <td>{{ data.totalCount }}</td>
52 53
       <td>{{ data.totalGrade }}</td>
54
+			<td>{{ data.totalPrice }}</td>
53 55
       <td>{{ data.response_time_num }}</td>
54 56
       <td>{{ data.execution_time_num }}</td>
55 57
       <td>{{ data.aveper }}</td>
@@ -61,15 +63,16 @@
61 63
   <ng-template #footerTpl>
62 64
     <table class="footTable">
63 65
       <tr *ngFor="let data of listOfDataEnd">
64
-        <td style="width: 12%">{{ data.date }}</td>
65
-        <td style="width: 11%">{{ data.totalCount }}</td>
66
-        <td style="width: 11%">{{ data.totalGrade }}</td>
67
-        <td style="width: 11%">{{ data.response_time_num }}</td>
68
-        <td style="width: 11%">{{ data.execution_time_num }}</td>
69
-        <td style="width: 11%">{{ data.aveper }}</td>
70
-        <td style="width: 11%">{{ data.total_time }}</td>
71
-        <td style="width: 11%">{{ data.five_count }}</td>
72
-        <td style="width: 11%">{{ data.special_close }}</td>
66
+        <td style="width: 10%">{{ data.date }}</td>
67
+        <td style="width: 10%">{{ data.totalCount }}</td>
68
+        <td style="width: 10%">{{ data.totalGrade }}</td>
69
+				<td style="width: 10%">{{ data.totalPrice }}</td>
70
+        <td style="width: 10%">{{ data.response_time_num }}</td>
71
+        <td style="width: 10%">{{ data.execution_time_num }}</td>
72
+        <td style="width: 10%">{{ data.aveper }}</td>
73
+        <td style="width: 10%">{{ data.total_time }}</td>
74
+        <td style="width: 10%">{{ data.five_count }}</td>
75
+        <td style="width: 10%">{{ data.special_close }}</td>
73 76
       </tr>
74 77
     </table>
75 78
   </ng-template>

+ 28 - 16
src/app/views/new-statistics/distribution-inspection-statistics/department-business-statistics/department-business-statistics.component.html

@@ -5,17 +5,18 @@
5 5
       <nz-range-picker [(ngModel)]="dateRange" [nzAllowClear]="false" (ngModelChange)="changeDate($event)" (nzOnCalendarChange)="onCalendarChangeDate($event)">
6 6
       </nz-range-picker>
7 7
     </div>
8
-    <div class="searchDataItem">
9
-      <span class="label">楼栋</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzServerSearch nzShowSearch (nzOnSearch)="changeBuildingInp($event)" nzAllowClear nzPlaceHolder="请选择楼栋" [(ngModel)]="buildingId" (nzOpenChange)="openChangeBuilding($event)">
11
-        <ng-container *ngFor="let option of buildingList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.hosName + '-' + option.buildingName" [nzValue]="option.id"></nz-option>
13
-        </ng-container>
14
-        <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15
-          <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
16
-        </nz-option>
17
-      </nz-select>
18
-    </div>
8
+		
9
+		<div class="searchDataItem">
10
+		  <span class="label">科室</span>:
11
+		  <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
12
+		    <ng-container *ngFor="let option of alldepart">
13
+		      <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
14
+		    </ng-container>
15
+		    <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
16
+		      <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
17
+		    </nz-option>
18
+		  </nz-select>
19
+		</div>
19 20
   </div>
20 21
   <div class="operation">
21 22
     <i class="icon_transport transport-gengduo" nz-tooltip nzTooltipTitle="更多搜索" (click)="showMore()"></i>
@@ -24,46 +25,57 @@
24 25
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 26
   </div>
26 27
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO">
28
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.buildingDTO">
28 29
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 30
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
31
+	<span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
30 32
 </div>
31 33
 <div class="tableWrap">
32
-  <nz-table class="table" [ngStyle]="{ width: widthConfig.length * 100 + 50 * 1 + 20 + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
34
+  <nz-table class="table" [ngStyle]="{ width: widthValue + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
33 35
     <thead (nzSortChange)="sort($event)" nzSingleSort>
34 36
       <tr>
37
+				<th rowspan="2" *ngIf="parent==1">父级科室(编码)</th>
35 38
         <th rowspan="2">科室(编码)</th>
36 39
         <th rowspan="2" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
37 40
         <th rowspan="2" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">积分总和</th>
38
-        <th colspan="2" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
41
+        <th rowspan="2" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
42
+				<th colspan="3" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
39 43
       </tr>
40 44
       <tr>
41 45
         <ng-container *ngFor="let dictionary of dictionaryList">
42 46
           <th nzShowSort [nzSortKey]="dictionary.value + 'Count'" [(nzSort)]="sortCurrent[dictionary.value + 'Count']">工单量</th>
43 47
           <th nzShowSort [nzSortKey]="dictionary.value + 'Grade'" [(nzSort)]="sortCurrent[dictionary.value + 'Grade']">积分数</th>
44
-        </ng-container>
48
+					<th nzShowSort [nzSortKey]="dictionary.value + 'Score'" [(nzSort)]="sortCurrent[dictionary.value + 'Score']">费用(元)</th>
49
+				</ng-container>
45 50
       </tr>
46 51
     </thead>
47 52
     <tbody>
48 53
       <tr *ngFor="let data of listOfData">
54
+				<td class="width150" *ngIf="parent==1">{{ data.parentName || '无' }}</td>
49 55
         <td class="width150">{{ data.name }}</td>
50 56
         <td>{{ data.totalCount }}</td>
51 57
         <td>{{ data.totalGrade }}</td>
58
+				<td>{{ data.totalPrice }}</td>
52 59
         <ng-container *ngFor="let dictionary of dictionaryList">
53 60
           <td>{{ data[dictionary.value + 'Count'] }}</td>
54 61
           <td>{{ data[dictionary.value + 'Grade'] }}</td>
62
+					<td>{{ data[dictionary.value + 'Score'] }}</td>
55 63
         </ng-container>
56 64
       </tr>
57 65
     </tbody>
58 66
     <ng-template #footerTpl>
59 67
       <table class="footTable">
60 68
         <tr *ngFor="let data of listOfDataEnd">
61
-          <td class="width150">{{ data.name }}</td>
69
+					<td class="width150" *ngIf="parent==1">{{ data.parentName }}</td>
70
+					<td class="width150" *ngIf="parent==0">{{ data.name }}</td>
71
+					<td class="width150" *ngIf="parent==1"></td>
62 72
           <td>{{ data.totalCount }}</td>
63 73
           <td>{{ data.totalGrade }}</td>
74
+					<td>{{ data.totalPrice }}</td>
64 75
           <ng-container *ngFor="let dictionary of dictionaryList">
65 76
             <td>{{ data[dictionary.value + 'Count'] }}</td>
66 77
             <td>{{ data[dictionary.value + 'Grade'] }}</td>
78
+						<td>{{ data[dictionary.value + 'Score'] }}</td>
67 79
           </ng-container>
68 80
         </tr>
69 81
       </table>

+ 55 - 13
src/app/views/new-statistics/distribution-inspection-statistics/department-business-statistics/department-business-statistics.component.ts

@@ -7,6 +7,8 @@ import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
7 7
 import { MainService } from 'src/app/services/main.service';
8 8
 import { ActivatedRoute } from '@angular/router';
9 9
 import cloneDeep from 'lodash-es/cloneDeep'
10
+import { ToolService } from "../../../../services/tool.service";
11
+
10 12
 @Component({
11 13
   selector: "app-department-business-statistics",
12 14
   templateUrl: "./department-business-statistics.component.html",
@@ -18,6 +20,7 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
18 20
     private message: NzMessageService,
19 21
     private route: ActivatedRoute,
20 22
     private tabService: TabService,
23
+		private tool: ToolService,
21 24
   ) {}
22 25
 
23 26
   listOfData: any[] = []; //表格数据
@@ -28,8 +31,10 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
28 31
   widthConfig: any[] = [];
29 32
 
30 33
   buildingId;//楼栋id
31
-
32
-  searchTimerSubject = new Subject();
34
+	hospital:any;
35
+	deptTypeId;//科室类型id
36
+	deptId;
37
+	searchTimerSubject = new Subject();
33 38
 
34 39
   ngOnInit() {
35 40
     this.searchTimerSubject.pipe(debounceTime(500)).subscribe((v) => {
@@ -38,6 +43,7 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
38 43
     });
39 44
     this.initSessionData();
40 45
     this.getQueryParams();
46
+		this.getDeparts();
41 47
     this.search();
42 48
   }
43 49
 
@@ -72,11 +78,13 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
72 78
   hosId:any;
73 79
   dutyId:any;
74 80
   parentDutyId:any;
81
+  parent:any;
75 82
   initSessionData(){
76 83
     let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
77 84
     let queryType:any = newStatistics.queryType;
78 85
     let hosId:any = newStatistics.hospitalId;
79 86
     let dutyId:any = newStatistics.dutyId;
87
+  	this.parent = newStatistics.parent;
80 88
 
81 89
     queryType = queryType ? +queryType : undefined;
82 90
     hosId = hosId ? +hosId : undefined;
@@ -109,26 +117,34 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
109 117
   // 表格数据
110 118
   loading1 = false;
111 119
   dictionaryList: any[] = [];
120
+	widthValue:any;
112 121
   getList(num?: number, field?: string, sort?: string) {
113 122
     this.mainService.getDictionary('list', 'statistics_date_type').subscribe((data) => {
114 123
       let dictionaryList = data || [];
115 124
       dictionaryList = cloneDeep(dictionaryList);
116 125
       let flag = dictionaryList.some((item) => item.value === 'dateOther');
117
-      !flag && dictionaryList.push({id: 0, name: '其他', value: 'dateOther'});
126
+      !flag && dictionaryList.push({id: 0, name: '未知', value: 'dateOther'});
118 127
       this.dictionaryList = dictionaryList;
119
-      this.widthConfig = new Array(this.dictionaryList.length * 2 + 3).fill('100px').map((v, i) => { return i == 0 ? '150px' : '100px' });;
120
-      if (num !== undefined) {
128
+      this.widthConfig = new Array(this.dictionaryList.length * 3 + 3).fill('100px').map((v, i) => { return (i == 0 || i == 1 && this.parent==1) || (i == 0 && this.parent==0) ? '150px' : '100px' });;
129
+      if(this.parent==1){
130
+				this.widthValue = this.widthConfig.length * 100 + 300 * 1 + 20
131
+			}else{
132
+				this.widthValue = this.widthConfig.length * 100 + 149 * 1 + 20
133
+			}
134
+			if (num !== undefined) {
121 135
         this.pageIndex = num;
122 136
       }
123 137
       let postData:any = {
124 138
         idx: this.pageIndex - 1,
125 139
         sum: this.pageSize,
140
+				showParentDept: this.parent==1 ? 'true' : undefined,
141
+				deptId: this.deptId || undefined,
142
+				buildingId: this.fieldConfig.fields.buildingId || undefined,
126 143
         startDate: this.dateRange[0] || undefined,
127 144
         endDate: this.dateRange[1] || undefined,
128 145
         hosId: this.getHosId,
129 146
         groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
130
-        userId: this.fieldConfig.fields.userId || undefined,
131
-        buildingId: this.buildingId || undefined,
147
+        userId: this.fieldConfig.fields.userId || undefined
132 148
       };
133 149
       if (field && sort) {
134 150
         postData.sort = `${field} ${sort === "ascend" ? `asc` : `desc`}`
@@ -183,12 +199,14 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
183 199
       nzDuration: 0,
184 200
     }).messageId;
185 201
     let postData:any = {
202
+			showParentDept: this.parent==1 ? 'true' : undefined,
203
+			deptId: this.deptId || undefined,
204
+			buildingId: this.fieldConfig.fields.buildingId || undefined,
186 205
       startDate: this.dateRange[0] || undefined,
187 206
       endDate: this.dateRange[1] || undefined,
188 207
       hosId: this.getHosId,
189 208
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
190 209
       userId: this.fieldConfig.fields.userId || undefined,
191
-      buildingId: this.buildingId || undefined,
192 210
     };
193 211
     if (this.sortCurrentKey && this.sortCurrentValue) {
194 212
       postData.sort = `${this.sortCurrentKey} ${this.sortCurrentValue === "ascend" ? `asc` : `desc`}`
@@ -222,8 +240,8 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
222 240
 		this.sortCurrentValue = "";
223 241
 		this.sortCurrent = {};
224 242
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
225
-    this.buildingId = undefined;
226
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined};
243
+    this.deptId = undefined;
244
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, buildingId: undefined};
227 245
     this.search();
228 246
   }
229 247
 
@@ -242,7 +260,31 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
242 260
   openChangeBuilding(flag){
243 261
     flag && this.getBuildingList();
244 262
   }
245
-
263
+	
264
+	// 科室搜索
265
+	changeInp(e) {
266
+	  this.searchTimer(this.getDeparts, e);
267
+	}
268
+	
269
+	// 获取所有科室
270
+	alldepart:any;
271
+	getDeparts(dept?) {
272
+	  let data = {
273
+	    department: {
274
+	      cascadeHosId: this.hospital,
275
+	      dept: dept,
276
+	    },
277
+	    idx: 0,
278
+	    sum: 20,
279
+	  };
280
+	  this.mainService
281
+	    .getFetchDataList("data", "department", data)
282
+	    .subscribe((data) => {
283
+				this.isLoading = false;
284
+	      this.alldepart = data.list;
285
+	    });
286
+	}
287
+	
246 288
   // 获取报修科室列表
247 289
   buildingList:any[] = [];
248 290
   getBuildingList(keyword?) {
@@ -266,8 +308,8 @@ export class DepartmentBusinessStatisticsComponent implements OnInit, AfterViewI
266 308
 
267 309
   // 详细搜索
268 310
   fieldConfig:any = {
269
-    fields: {groupId: undefined, userId: undefined},
270
-    config: {groupAndUser: true},
311
+    fields: {groupId: undefined, userId: undefined, buildingId: undefined},
312
+    config: {groupAndUser: true, building: true},
271 313
   }
272 314
   showSearchMore:boolean = false;
273 315
   showMore(){

+ 31 - 23
src/app/views/new-statistics/distribution-inspection-statistics/department-quality-control-statistics/department-quality-control-statistics.component.html

@@ -6,10 +6,10 @@
6 6
       </nz-range-picker>
7 7
     </div>
8 8
     <div class="searchDataItem">
9
-      <span class="label">楼栋</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzServerSearch nzShowSearch (nzOnSearch)="changeBuildingInp($event)" nzAllowClear nzPlaceHolder="请选择楼栋" [(ngModel)]="buildingId" (nzOpenChange)="openChangeBuilding($event)">
11
-        <ng-container *ngFor="let option of buildingList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.hosName + '-' + option.buildingName" [nzValue]="option.id"></nz-option>
9
+      <span class="label">科室</span>:
10
+      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
11
+        <ng-container *ngFor="let option of alldepart">
12
+          <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
13 13
         </ng-container>
14 14
         <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15 15
           <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
@@ -24,31 +24,36 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.taskTypeDTO || fieldConfig.fields.statisticsTypeDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.taskTypeDTO || fieldConfig.fields.statisticsTypeDTO || fieldConfig.fields.buildingDTO">
28 28
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 29
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
30 30
   <span>{{fieldConfig.fields.statisticsTypeDTO?.name}}</span>
31 31
   <span>{{fieldConfig.fields.taskTypeDTO?.taskName}}</span>
32
+	<span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
32 33
 </div>
33 34
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
34 35
   <thead (nzSortChange)="sort($event)" nzSingleSort>
35 36
     <tr>
36
-      <th nzWidth="12%">科室(编码)</th>
37
-      <th nzWidth="11%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
38
-      <th nzWidth="11%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
39
-      <th nzWidth="11%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
40
-      <th nzWidth="11%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
41
-      <th nzWidth="11%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
42
-      <th nzWidth="11%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
43
-      <th nzWidth="11%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
44
-      <th nzWidth="11%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
37
+			<th nzWidth="9%" *ngIf="parent==1">父级科室(编码)</th>
38
+      <th nzWidth="9%">科室(编码)</th>
39
+      <th nzWidth="9%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
40
+      <th nzWidth="9%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
41
+      <th nzWidth="9%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
42
+			<th nzWidth="9%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
43
+      <th nzWidth="9%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
44
+      <th nzWidth="9%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
45
+      <th nzWidth="9%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
46
+      <th nzWidth="9%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
47
+      <th nzWidth="9%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
45 48
     </tr>
46 49
   </thead>
47 50
   <tbody>
48 51
     <tr *ngFor="let data of listOfData">
52
+			<td *ngIf="parent==1">{{ data.parentName || '无' }}</td>
49 53
       <td>{{ data.name }}</td>
50 54
       <td>{{ data.totalCount }}</td>
51 55
       <td>{{ data.totalGrade }}</td>
56
+			<td>{{ data.totalPrice }}</td>
52 57
       <td>{{ data.response_time_num }}</td>
53 58
       <td>{{ data.execution_time_num }}</td>
54 59
       <td>{{ data.aveper }}</td>
@@ -60,15 +65,18 @@
60 65
   <ng-template #footerTpl>
61 66
     <table class="footTable">
62 67
       <tr *ngFor="let data of listOfDataEnd">
63
-        <td style="width: 12%">{{ data.name }}</td>
64
-        <td style="width: 11%">{{ data.totalCount }}</td>
65
-        <td style="width: 11%">{{ data.totalGrade }}</td>
66
-        <td style="width: 11%">{{ data.response_time_num }}</td>
67
-        <td style="width: 11%">{{ data.execution_time_num }}</td>
68
-        <td style="width: 11%">{{ data.aveper }}</td>
69
-        <td style="width: 11%">{{ data.total_time }}</td>
70
-        <td style="width: 11%">{{ data.five_count }}</td>
71
-        <td style="width: 11%">{{ data.special_close }}</td>
68
+				<td style="width: 9%" *ngIf="parent==1">{{ data.parentName }}</td>
69
+				<td style="width: 9%" *ngIf="parent==0">{{ data.name }}</td>
70
+				<td style="width: 9%" *ngIf="parent==1"></td>
71
+        <td style="width: 9%">{{ data.totalCount }}</td>
72
+        <td style="width: 9%">{{ data.totalGrade }}</td>
73
+				<td style="width: 9%">{{ data.totalPrice }}</td>
74
+        <td style="width: 9%">{{ data.response_time_num }}</td>
75
+        <td style="width: 9%">{{ data.execution_time_num }}</td>
76
+        <td style="width: 9%">{{ data.aveper }}</td>
77
+        <td style="width: 9%">{{ data.total_time }}</td>
78
+        <td style="width: 9%">{{ data.five_count }}</td>
79
+        <td style="width: 9%">{{ data.special_close }}</td>
72 80
       </tr>
73 81
     </table>
74 82
   </ng-template>

+ 43 - 8
src/app/views/new-statistics/distribution-inspection-statistics/department-quality-control-statistics/department-quality-control-statistics.component.ts

@@ -6,6 +6,7 @@ import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } fro
6 6
 import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
7 7
 import { MainService } from 'src/app/services/main.service';
8 8
 import { ActivatedRoute } from '@angular/router';
9
+import { ToolService } from "../../../../services/tool.service";
9 10
 @Component({
10 11
   selector: "app-department-quality-control-statistics",
11 12
   templateUrl: "./department-quality-control-statistics.component.html",
@@ -17,6 +18,7 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
17 18
     private message: NzMessageService,
18 19
     private route: ActivatedRoute,
19 20
     private tabService: TabService,
21
+		private tool: ToolService,
20 22
   ) {}
21 23
 
22 24
   listOfData: any[] = []; //表格数据
@@ -26,7 +28,9 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
26 28
   listLength: number = 0; //表格总数据量
27 29
 
28 30
   buildingId;//楼栋id
29
-
31
+  hospital:any;
32
+  deptTypeId;//科室类型id
33
+  deptId;
30 34
   searchTimerSubject = new Subject();
31 35
 
32 36
   ngOnInit() {
@@ -36,6 +40,7 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
36 40
     });
37 41
     this.initSessionData();
38 42
     this.getQueryParams();
43
+		this.getDeparts();
39 44
     this.search();
40 45
   }
41 46
 
@@ -70,11 +75,13 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
70 75
   hosId:any;
71 76
   dutyId:any;
72 77
   parentDutyId:any;
78
+  parent:any;
73 79
   initSessionData(){
74 80
     let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
75 81
     let queryType:any = newStatistics.queryType;
76 82
     let hosId:any = newStatistics.hospitalId;
77 83
     let dutyId:any = newStatistics.dutyId;
84
+  	this.parent = newStatistics.parent;
78 85
 
79 86
     queryType = queryType ? +queryType : undefined;
80 87
     hosId = hosId ? +hosId : undefined;
@@ -113,10 +120,12 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
113 120
     let postData:any = {
114 121
       idx: this.pageIndex - 1,
115 122
       sum: this.pageSize,
123
+			showParentDept: this.parent==1 ? 'true' : undefined,
124
+			deptId: this.deptId || undefined,
125
+			buildingId: this.fieldConfig.fields.buildingId || undefined,
116 126
       startDate: this.dateRange[0] || undefined,
117 127
       endDate: this.dateRange[1] || undefined,
118 128
       hosId: this.getHosId,
119
-      buildingId: this.buildingId || undefined,
120 129
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
121 130
       userId: this.fieldConfig.fields.userId || undefined,
122 131
       statisticsTypeId: this.fieldConfig.fields.statisticsTypeId || undefined,
@@ -174,10 +183,12 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
174 183
       nzDuration: 0,
175 184
     }).messageId;
176 185
     let postData:any = {
186
+			showParentDept: this.parent==1 ? 'true' : undefined,
187
+			deptId: this.deptId || undefined,
188
+			buildingId: this.fieldConfig.fields.buildingId || undefined,
177 189
       startDate: this.dateRange[0] || undefined,
178 190
       endDate: this.dateRange[1] || undefined,
179 191
       hosId: this.getHosId,
180
-      buildingId: this.buildingId || undefined,
181 192
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
182 193
       userId: this.fieldConfig.fields.userId || undefined,
183 194
       statisticsTypeId: this.fieldConfig.fields.statisticsTypeId || undefined,
@@ -215,8 +226,8 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
215 226
 		this.sortCurrentValue = "";
216 227
 		this.sortCurrent = {};
217 228
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
218
-    this.buildingId = undefined;
219
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined};
229
+    this.deptId = undefined;
230
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined, buildingId: undefined};
220 231
     this.search();
221 232
   }
222 233
 
@@ -235,7 +246,31 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
235 246
   openChangeBuilding(flag){
236 247
     flag && this.getBuildingList();
237 248
   }
238
-
249
+	
250
+	// 科室搜索
251
+	changeInp(e) {
252
+	  this.searchTimer(this.getDeparts, e);
253
+	}
254
+	
255
+	// 获取所有科室
256
+	alldepart:any;
257
+	getDeparts(dept?) {
258
+	  let data = {
259
+	    department: {
260
+	      cascadeHosId: this.hospital,
261
+	      dept: dept,
262
+	    },
263
+	    idx: 0,
264
+	    sum: 20,
265
+	  };
266
+	  this.mainService
267
+	    .getFetchDataList("data", "department", data)
268
+	    .subscribe((data) => {
269
+				this.isLoading = false;
270
+	      this.alldepart = data.list;
271
+	    });
272
+	}
273
+	
239 274
   // 获取报修科室列表
240 275
   buildingList:any[] = [];
241 276
   getBuildingList(keyword?) {
@@ -259,8 +294,8 @@ export class DepartmentQualityControlStatisticsComponent implements OnInit, Afte
259 294
 
260 295
   // 详细搜索
261 296
   fieldConfig:any = {
262
-    fields: {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined},
263
-    config: {groupAndUser: true, statisticsType: true, taskType: true},
297
+    fields: {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined, buildingId: undefined},
298
+    config: {groupAndUser: true, statisticsType: true, taskType: true, building: true},
264 299
   }
265 300
   showSearchMore:boolean = false;
266 301
   showMore(){

+ 19 - 14
src/app/views/new-statistics/distribution-inspection-statistics/distribution-department-source-statistics/distribution-department-source-statistics.component.html

@@ -6,10 +6,10 @@
6 6
       </nz-range-picker>
7 7
     </div>
8 8
     <div class="searchDataItem">
9
-      <span class="label">楼栋</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzServerSearch nzShowSearch (nzOnSearch)="changeBuildingInp($event)" nzAllowClear nzPlaceHolder="请选择楼栋" [(ngModel)]="buildingId" (nzOpenChange)="openChangeBuilding($event)">
11
-        <ng-container *ngFor="let option of buildingList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.hosName + '-' + option.buildingName" [nzValue]="option.id"></nz-option>
9
+      <span class="label">科室</span>:
10
+      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
11
+        <ng-container *ngFor="let option of alldepart">
12
+          <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
13 13
         </ng-container>
14 14
         <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15 15
           <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
@@ -24,24 +24,27 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.taskTypeDTO || fieldConfig.fields.statisticsTypeDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.taskTypeDTO || fieldConfig.fields.statisticsTypeDTO || fieldConfig.fields.buildingDTO">
28 28
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 29
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
30 30
   <span>{{fieldConfig.fields.statisticsTypeDTO?.name}}</span>
31 31
   <span>{{fieldConfig.fields.taskTypeDTO?.taskName}}</span>
32
+	<span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
32 33
 </div>
33 34
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
34 35
   <thead (nzSortChange)="sort($event)" nzSingleSort>
35 36
     <tr>
37
+			<th nzWidth="20%" *ngIf="parent==1">父级科室(编码)</th>
36 38
       <th nzWidth="20%">科室(编码)</th>
37
-      <th nzWidth="20%" nzShowSort nzSortKey="service" [(nzSort)]="sortCurrent.service">服务台建单数</th>
38
-      <th nzWidth="20%" nzShowSort nzSortKey="nurse" [(nzSort)]="sortCurrent.nurse">护士端建单数</th>
39
-      <th nzWidth="20%" nzShowSort nzSortKey="system" [(nzSort)]="sortCurrent.system">系统自动建单数</th>
40
-      <th nzWidth="20%" nzShowSort nzSortKey="wechat" [(nzSort)]="sortCurrent.wechat">微信端建单数量</th>
39
+      <th nzWidth="15%" nzShowSort nzSortKey="service" [(nzSort)]="sortCurrent.service">服务台建单数</th>
40
+      <th nzWidth="15%" nzShowSort nzSortKey="nurse" [(nzSort)]="sortCurrent.nurse">护士端建单数</th>
41
+      <th nzWidth="15%" nzShowSort nzSortKey="system" [(nzSort)]="sortCurrent.system">系统自动建单数</th>
42
+      <th nzWidth="15%" nzShowSort nzSortKey="wechat" [(nzSort)]="sortCurrent.wechat">微信端建单数量</th>
41 43
     </tr>
42 44
   </thead>
43 45
   <tbody>
44 46
     <tr *ngFor="let data of listOfData">
47
+			<td *ngIf="parent==1">{{ data.parentName || '无' }}</td>
45 48
       <td>{{ data.name }}</td>
46 49
       <td>{{ data.service }}</td>
47 50
       <td>{{ data.nurse }}</td>
@@ -52,11 +55,13 @@
52 55
   <ng-template #footerTpl>
53 56
     <table class="footTable">
54 57
       <tr *ngFor="let data of listOfDataEnd">
55
-        <td style="width: 20%">{{ data.name }}</td>
56
-        <td style="width: 20%">{{ data.service }}</td>
57
-        <td style="width: 20%">{{ data.nurse }}</td>
58
-        <td style="width: 20%">{{ data.system }}</td>
59
-        <td style="width: 20%">{{ data.wechat }}</td>
58
+				<td style="width: 20%" *ngIf="parent==1">{{ data.parentName }}</td>
59
+				<td style="width: 20%" *ngIf="parent==0">{{ data.name }}</td>
60
+				<td style="width: 20%" *ngIf="parent==1"></td>
61
+        <td style="width: 15%">{{ data.service }}</td>
62
+        <td style="width: 15%">{{ data.nurse }}</td>
63
+        <td style="width: 15%">{{ data.system }}</td>
64
+        <td style="width: 15%">{{ data.wechat }}</td>
60 65
       </tr>
61 66
     </table>
62 67
   </ng-template>

+ 43 - 8
src/app/views/new-statistics/distribution-inspection-statistics/distribution-department-source-statistics/distribution-department-source-statistics.component.ts

@@ -6,6 +6,7 @@ import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } fro
6 6
 import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
7 7
 import { MainService } from 'src/app/services/main.service';
8 8
 import { ActivatedRoute } from '@angular/router';
9
+import { ToolService } from "../../../../services/tool.service";
9 10
 @Component({
10 11
   selector: "app-distribution-department-source-statistics",
11 12
   templateUrl: "./distribution-department-source-statistics.component.html",
@@ -17,6 +18,7 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
17 18
     private message: NzMessageService,
18 19
     private route: ActivatedRoute,
19 20
     private tabService: TabService,
21
+		private tool: ToolService,
20 22
   ) {}
21 23
 
22 24
   listOfData: any[] = []; //表格数据
@@ -26,7 +28,9 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
26 28
   listLength: number = 0; //表格总数据量
27 29
 
28 30
   buildingId;//楼栋id
29
-
31
+  hospital:any;
32
+  deptTypeId;//科室类型id
33
+  deptId;
30 34
   searchTimerSubject = new Subject();
31 35
 
32 36
   ngOnInit() {
@@ -36,6 +40,7 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
36 40
     });
37 41
     this.initSessionData();
38 42
     this.getQueryParams();
43
+		this.getDeparts();
39 44
     this.search();
40 45
   }
41 46
 
@@ -70,11 +75,13 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
70 75
   hosId:any;
71 76
   dutyId:any;
72 77
   parentDutyId:any;
78
+  parent:any;
73 79
   initSessionData(){
74 80
     let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
75 81
     let queryType:any = newStatistics.queryType;
76 82
     let hosId:any = newStatistics.hospitalId;
77 83
     let dutyId:any = newStatistics.dutyId;
84
+  	this.parent = newStatistics.parent;
78 85
 
79 86
     queryType = queryType ? +queryType : undefined;
80 87
     hosId = hosId ? +hosId : undefined;
@@ -113,10 +120,12 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
113 120
     let postData:any = {
114 121
       idx: this.pageIndex - 1,
115 122
       sum: this.pageSize,
123
+			showParentDept: this.parent==1 ? 'true' : undefined,
124
+			deptId: this.deptId || undefined,
125
+			buildingId: this.fieldConfig.fields.buildingId || undefined,
116 126
       startDate: this.dateRange[0] || undefined,
117 127
       endDate: this.dateRange[1] || undefined,
118 128
       hosId: this.getHosId,
119
-      buildingId: this.buildingId || undefined,
120 129
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
121 130
       userId: this.fieldConfig.fields.userId || undefined,
122 131
       statisticsTypeId: this.fieldConfig.fields.statisticsTypeId || undefined,
@@ -174,10 +183,12 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
174 183
       nzDuration: 0,
175 184
     }).messageId;
176 185
     let postData:any = {
186
+			showParentDept: this.parent==1 ? 'true' : undefined,
187
+			deptId: this.deptId || undefined,
188
+			buildingId: this.fieldConfig.fields.buildingId || undefined,
177 189
       startDate: this.dateRange[0] || undefined,
178 190
       endDate: this.dateRange[1] || undefined,
179 191
       hosId: this.getHosId,
180
-      buildingId: this.buildingId || undefined,
181 192
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
182 193
       userId: this.fieldConfig.fields.userId || undefined,
183 194
       statisticsTypeId: this.fieldConfig.fields.statisticsTypeId || undefined,
@@ -215,8 +226,8 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
215 226
 		this.sortCurrentValue = "";
216 227
 		this.sortCurrent = {};
217 228
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
218
-    this.buildingId = undefined;
219
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined};
229
+		this.deptId = undefined;
230
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined, buildingId: undefined};
220 231
     this.search();
221 232
   }
222 233
 
@@ -224,7 +235,31 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
224 235
   changeBuildingInp(e) {
225 236
     this.searchTimer(this.getBuildingList, e);
226 237
   }
227
-
238
+	
239
+	// 科室搜索
240
+	changeInp(e) {
241
+	  this.searchTimer(this.getDeparts, e);
242
+	}
243
+	
244
+	// 获取所有科室
245
+	alldepart:any;
246
+	getDeparts(dept?) {
247
+	  let data = {
248
+	    department: {
249
+	      cascadeHosId: this.hospital,
250
+	      dept: dept,
251
+	    },
252
+	    idx: 0,
253
+	    sum: 20,
254
+	  };
255
+	  this.mainService
256
+	    .getFetchDataList("data", "department", data)
257
+	    .subscribe((data) => {
258
+				this.isLoading = false;
259
+	      this.alldepart = data.list;
260
+	    });
261
+	}
262
+	
228 263
   // 防抖
229 264
   isLoading = false;
230 265
   searchTimer(fun, e) {
@@ -259,8 +294,8 @@ export class DistributionDepartmentSourceStatisticsComponent implements OnInit,
259 294
 
260 295
   // 详细搜索
261 296
   fieldConfig:any = {
262
-    fields: {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined},
263
-    config: {groupAndUser: true, statisticsType: true, taskType: true},
297
+    fields: {groupId: undefined, userId: undefined, statisticsTypeId: undefined, taskTypeId: undefined, buildingId: undefined},
298
+    config: {groupAndUser: true, statisticsType: true, taskType: true, building: true},
264 299
   }
265 300
   showSearchMore:boolean = false;
266 301
   showMore(){

+ 9 - 0
src/app/views/new-statistics/distribution-inspection-statistics/distribution-inspection-statistics-routing.module.ts

@@ -98,6 +98,15 @@ const routes: Routes = [
98 98
           title: '配-来源统计'
99 99
         }
100 100
       },
101
+			{
102
+			  // 业务分类统计
103
+			  path: 'businessClassifyStatistics',
104
+			  loadChildren: () => import('./business-classify-statistics/business-classify-statistics.module').then(m => m.BusinessClassifyStatisticsModule),
105
+			  data: {
106
+			    reuse: true,
107
+			    title: '配-业务分类统计'
108
+			  }
109
+			},
101 110
     ]
102 111
   }
103 112
 ];

+ 2 - 1
src/app/views/new-statistics/distribution-inspection-statistics/distribution-synthesize-statistics/distribution-synthesize-statistics.component.html

@@ -66,7 +66,8 @@
66 66
     <div class="statistics width-60 mar-right-8">
67 67
 			<div class="statistics-box">
68 68
 				<div class="sign-green"></div>
69
-				<div class="statistics-title">业务分类</div>
69
+				<div class="statistics-title">业务分类top5</div>
70
+				<div class="more" *ngIf="showMore('businessClassifyStatistics')" (click)="toPath('/newStatistics/distributionInspectionStatistics/businessClassifyStatistics')">更多></div>
70 71
 			</div>
71 72
 			<div class="echarts-repairs">
72 73
 				<div echarts class="echarts" [options]='businessOptions'></div>

+ 8 - 2
src/app/views/new-statistics/distribution-inspection-statistics/user-business-statistics/user-business-statistics.component.html

@@ -29,18 +29,20 @@
29 29
   <span>{{fieldConfig.fields.deptDTO?.dept}}</span>
30 30
 </div>
31 31
 <div class="tableWrap">
32
-  <nz-table class="table" [ngStyle]="{ width: widthConfig.length * 100 + 50 * 1 + 20 + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
32
+  <nz-table class="table" [ngStyle]="{ width: widthConfig.length * 100 + 150 * 1 + 20 + 'px' }" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl" [nzWidthConfig]="widthConfig" nzBordered>
33 33
     <thead (nzSortChange)="sort($event)" nzSingleSort>
34 34
       <tr>
35 35
         <th rowspan="2">人员(编码)</th>
36 36
         <th rowspan="2" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
37 37
         <th rowspan="2" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">积分总和</th>
38
-        <th colspan="2" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
38
+        <th rowspan="2" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
39
+				<th colspan="3" *ngFor="let dictionary of dictionaryList">{{dictionary.name}}</th>
39 40
       </tr>
40 41
       <tr>
41 42
         <ng-container *ngFor="let dictionary of dictionaryList">
42 43
           <th nzShowSort [nzSortKey]="dictionary.value + 'Count'" [(nzSort)]="sortCurrent[dictionary.value + 'Count']">工单量</th>
43 44
           <th nzShowSort [nzSortKey]="dictionary.value + 'Grade'" [(nzSort)]="sortCurrent[dictionary.value + 'Grade']">积分数</th>
45
+					<th nzShowSort [nzSortKey]="dictionary.value + 'Score'" [(nzSort)]="sortCurrent[dictionary.value + 'Score']">费用(元)</th>
44 46
         </ng-container>
45 47
       </tr>
46 48
     </thead>
@@ -49,9 +51,11 @@
49 51
         <td class="width150">{{ data.name }}</td>
50 52
         <td>{{ data.totalCount }}</td>
51 53
         <td>{{ data.totalGrade }}</td>
54
+				<td>{{ data.totalPrice }}</td>
52 55
         <ng-container *ngFor="let dictionary of dictionaryList">
53 56
           <td>{{ data[dictionary.value + 'Count'] }}</td>
54 57
           <td>{{ data[dictionary.value + 'Grade'] }}</td>
58
+					<td>{{ data[dictionary.value + 'Score'] }}</td>
55 59
         </ng-container>
56 60
       </tr>
57 61
     </tbody>
@@ -61,9 +65,11 @@
61 65
           <td class="width150">{{ data.name }}</td>
62 66
           <td>{{ data.totalCount }}</td>
63 67
           <td>{{ data.totalGrade }}</td>
68
+					<td>{{ data.totalPrice }}</td>
64 69
           <ng-container *ngFor="let dictionary of dictionaryList">
65 70
             <td>{{ data[dictionary.value + 'Count'] }}</td>
66 71
             <td>{{ data[dictionary.value + 'Grade'] }}</td>
72
+						<td>{{ data[dictionary.value + 'Score'] }}</td>
67 73
           </ng-container>
68 74
         </tr>
69 75
       </table>

+ 2 - 2
src/app/views/new-statistics/distribution-inspection-statistics/user-business-statistics/user-business-statistics.component.ts

@@ -114,9 +114,9 @@ export class UserBusinessStatisticsComponent implements OnInit, AfterViewInit {
114 114
       let dictionaryList = data || [];
115 115
       dictionaryList = cloneDeep(dictionaryList);
116 116
       let flag = dictionaryList.some((item) => item.value === 'dateOther');
117
-      !flag && dictionaryList.push({id: 0, name: '其他', value: 'dateOther'});
117
+      !flag && dictionaryList.push({id: 0, name: '未知', value: 'dateOther'});
118 118
       this.dictionaryList = dictionaryList;
119
-      this.widthConfig = new Array(this.dictionaryList.length * 2 + 3).fill('100px').map((v, i) => { return i == 0 ? '150px' : '100px' });
119
+      this.widthConfig = new Array(this.dictionaryList.length * 3 + 3).fill('100px').map((v, i) => { return i == 0 ? '150px' : '100px' });
120 120
       if (num !== undefined) {
121 121
         this.pageIndex = num;
122 122
       }

+ 21 - 18
src/app/views/new-statistics/distribution-inspection-statistics/user-quality-control-statistics/user-quality-control-statistics.component.html

@@ -31,15 +31,16 @@
31 31
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
32 32
   <thead (nzSortChange)="sort($event)" nzSingleSort>
33 33
     <tr>
34
-      <th nzWidth="12%">人员(编码)</th>
35
-      <th nzWidth="11%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
36
-      <th nzWidth="11%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
37
-      <th nzWidth="11%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
38
-      <th nzWidth="11%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
39
-      <th nzWidth="11%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
40
-      <th nzWidth="11%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
41
-      <th nzWidth="11%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
42
-      <th nzWidth="11%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
34
+      <th nzWidth="10%">人员(编码)</th>
35
+      <th nzWidth="10%" nzShowSort nzSortKey="totalCount" [(nzSort)]="sortCurrent.totalCount">工单数量</th>
36
+      <th nzWidth="10%" nzShowSort nzSortKey="totalGrade" [(nzSort)]="sortCurrent.totalGrade">总积分</th>
37
+      <th nzWidth="10%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用</th>
38
+			<th nzWidth="10%" nzShowSort nzSortKey="response_time_num" [(nzSort)]="sortCurrent.response_time_num">平均响应时间</th>
39
+      <th nzWidth="10%" nzShowSort nzSortKey="execution_time_num" [(nzSort)]="sortCurrent.execution_time_num">平均送达时间</th>
40
+      <th nzWidth="10%" nzShowSort nzSortKey="aveper" [(nzSort)]="sortCurrent.aveper">按时完成达标率</th>
41
+      <th nzWidth="10%" nzShowSort nzSortKey="total_time" [(nzSort)]="sortCurrent.total_time">平均总时间</th>
42
+      <th nzWidth="10%" nzShowSort nzSortKey="five_count" [(nzSort)]="sortCurrent.five_count">五分钟内工单</th>
43
+      <th nzWidth="10%" nzShowSort nzSortKey="special_close" [(nzSort)]="sortCurrent.special_close">特殊关闭数</th>
43 44
     </tr>
44 45
   </thead>
45 46
   <tbody>
@@ -47,6 +48,7 @@
47 48
       <td>{{ data.name }}</td>
48 49
       <td>{{ data.totalCount }}</td>
49 50
       <td>{{ data.totalGrade }}</td>
51
+			<td>{{ data.totalPrice }}</td>
50 52
       <td>{{ data.response_time_num }}</td>
51 53
       <td>{{ data.execution_time_num }}</td>
52 54
       <td>{{ data.aveper }}</td>
@@ -58,15 +60,16 @@
58 60
   <ng-template #footerTpl>
59 61
     <table class="footTable">
60 62
       <tr *ngFor="let data of listOfDataEnd">
61
-        <td style="width: 12%">{{ data.name }}</td>
62
-        <td style="width: 11%">{{ data.totalCount }}</td>
63
-        <td style="width: 11%">{{ data.totalGrade }}</td>
64
-        <td style="width: 11%">{{ data.response_time_num }}</td>
65
-        <td style="width: 11%">{{ data.execution_time_num }}</td>
66
-        <td style="width: 11%">{{ data.aveper }}</td>
67
-        <td style="width: 11%">{{ data.total_time }}</td>
68
-        <td style="width: 11%">{{ data.five_count }}</td>
69
-        <td style="width: 11%">{{ data.special_close }}</td>
63
+        <td style="width: 10%">{{ data.name }}</td>
64
+        <td style="width: 10%">{{ data.totalCount }}</td>
65
+        <td style="width: 10%">{{ data.totalGrade }}</td>
66
+				<td style="width: 10%">{{ data.totalPrice }}</td>
67
+        <td style="width: 10%">{{ data.response_time_num }}</td>
68
+        <td style="width: 10%">{{ data.execution_time_num }}</td>
69
+        <td style="width: 10%">{{ data.aveper }}</td>
70
+        <td style="width: 10%">{{ data.total_time }}</td>
71
+        <td style="width: 10%">{{ data.five_count }}</td>
72
+        <td style="width: 10%">{{ data.special_close }}</td>
70 73
       </tr>
71 74
     </table>
72 75
   </ng-template>

+ 11 - 8
src/app/views/new-statistics/maintenance-statistics/consumable-statistics/consumable-statistics.component.html

@@ -37,10 +37,11 @@
37 37
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
38 38
   <thead (nzSortChange)="sort($event)" nzSingleSort>
39 39
     <tr>
40
-      <th nzWidth="25%">耗材名称(耗材编号)</th>
41
-      <th nzWidth="25%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">含耗材工单总数</th>
42
-      <th nzWidth="25%" nzShowSort nzSortKey="consumableNum" [(nzSort)]="sortCurrent.consumableNum">使用数量</th>
43
-      <th nzWidth="25%" nzShowSort nzSortKey="consumablePrice" [(nzSort)]="sortCurrent.consumablePrice">总费用(元)</th>
40
+      <th nzWidth="20%">耗材名称(耗材编号)</th>
41
+      <th nzWidth="20%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">含耗材工单总数</th>
42
+      <th nzWidth="20%" nzShowSort nzSortKey="consumableNum" [(nzSort)]="sortCurrent.consumableNum">使用数量</th>
43
+      <th nzWidth="20%" nzShowSort nzSortKey="avgPrice" [(nzSort)]="sortCurrent.avgPrice">平均单价</th>
44
+			<th nzWidth="20%" nzShowSort nzSortKey="consumablePrice" [(nzSort)]="sortCurrent.consumablePrice">总费用(元)</th>
44 45
     </tr>
45 46
   </thead>
46 47
   <tbody>
@@ -48,16 +49,18 @@
48 49
       <td>{{ data.consumableName }}<ng-container *ngIf="data.consumableCode">({{ data.consumableCode }})</ng-container></td>
49 50
       <td>{{ data.sum }}</td>
50 51
       <td>{{ data.consumableNum }}</td>
52
+			<td>{{ data.avgPrice }}</td>
51 53
       <td>{{ data.consumablePrice }}</td>
52 54
     </tr>
53 55
   </tbody>
54 56
   <ng-template #footerTpl>
55 57
     <table class="footTable">
56 58
       <tr *ngFor="let data of listOfDataEnd">
57
-        <td style="width: 25%">{{ data.consumableName }}</td>
58
-        <td style="width: 25%">{{ data.sum }}</td>
59
-        <td style="width: 25%">{{ data.consumableNum }}</td>
60
-        <td style="width: 25%">{{ data.consumablePrice }}</td>
59
+        <td style="width: 20%">{{ data.consumableName }}</td>
60
+        <td style="width: 20%">{{ data.sum }}</td>
61
+        <td style="width: 20%">{{ data.consumableNum }}</td>
62
+				<td style="width: 20%">{{ data.avgPrice }}</td>
63
+        <td style="width: 20%">{{ data.consumablePrice }}</td>
61 64
       </tr>
62 65
     </table>
63 66
   </ng-template>

+ 11 - 6
src/app/views/new-statistics/maintenance-statistics/department-evaluate-statistics/department-evaluate-statistics.component.html

@@ -6,10 +6,10 @@
6 6
       </nz-range-picker>
7 7
     </div>
8 8
     <div class="searchDataItem">
9
-      <span class="label">科室类型</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室类型" [(ngModel)]="deptTypeId" (nzOpenChange)="openChangeDeptType($event)">
11
-        <ng-container *ngFor="let option of deptTypeList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.name" [nzValue]="option.id"></nz-option>
9
+      <span class="label">科室</span>:
10
+      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
11
+        <ng-container *ngFor="let option of alldepart">
12
+          <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
13 13
         </ng-container>
14 14
         <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15 15
           <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
@@ -24,7 +24,7 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO || fieldConfig.fields.deptTypeDTO">
28 28
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 29
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
30 30
   <span>{{fieldConfig.fields.category1DTO?.category}}</span>
@@ -32,10 +32,12 @@
32 32
   <span>{{fieldConfig.fields.category3DTO?.category}}</span>
33 33
   <span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
34 34
   <span>{{fieldConfig.fields.floorDTO?.floorName}}</span>
35
+	<span>{{fieldConfig.fields.deptTypeDTO?.name}}</span>
35 36
 </div>
36 37
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
37 38
   <thead (nzSortChange)="sort($event)" nzSingleSort>
38 39
     <tr>
40
+			<th nzWidth="9%" *ngIf="parent==1">父级科室(编码)</th>
39 41
       <th nzWidth="10%">科室名称(编码)</th>
40 42
       <th nzWidth="10%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">工单总数</th>
41 43
       <th nzWidth="10%" nzShowSort nzSortKey="degreeCount" [(nzSort)]="sortCurrent.degreeCount">评价工单数</th>
@@ -50,6 +52,7 @@
50 52
   </thead>
51 53
   <tbody>
52 54
     <tr *ngFor="let data of listOfData">
55
+			<td *ngIf="parent==1">{{ data.parentName || '无' }}<ng-container *ngIf="parent==1 && data.parentName">({{ data.parentCode }})</ng-container></td>
53 56
       <td>{{ data.deptName }}<ng-container *ngIf="data.deptCode">({{ data.deptCode }})</ng-container></td>
54 57
       <td>{{ data.sum }}</td>
55 58
       <td>{{ data.degreeCount }}</td>
@@ -65,7 +68,9 @@
65 68
   <ng-template #footerTpl>
66 69
     <table class="footTable">
67 70
       <tr *ngFor="let data of listOfDataEnd">
68
-        <td style="width: 10%">{{ data.deptCode }}</td>
71
+				<td style="width: 9%" *ngIf="parent==1">{{ data.parentCode }}</td>
72
+				<td style="width: 10%" *ngIf="parent==0">{{ data.deptCode }}</td>
73
+				<td style="width: 10%" *ngIf="parent==1"></td>
69 74
         <td style="width: 10%">{{ data.sum }}</td>
70 75
         <td style="width: 10%">{{ data.degreeCount }}</td>
71 76
         <td style="width: 10%">{{ data.oneStar }}</td>

+ 60 - 12
src/app/views/new-statistics/maintenance-statistics/department-evaluate-statistics/department-evaluate-statistics.component.ts

@@ -4,6 +4,10 @@ import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } fro
4 4
 import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
5 5
 import { MainService } from 'src/app/services/main.service';
6 6
 import { ActivatedRoute } from '@angular/router';
7
+import { ToolService } from "../../../../services/tool.service";
8
+import { Subject } from "rxjs";
9
+import { debounceTime } from "rxjs/operators";
10
+
7 11
 @Component({
8 12
   selector: "app-department-evaluate-statistics",
9 13
   templateUrl: "./department-evaluate-statistics.component.html",
@@ -15,6 +19,7 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
15 19
     private message: NzMessageService,
16 20
     private route: ActivatedRoute,
17 21
     private tabService: TabService,
22
+		private tool: ToolService,
18 23
   ) {}
19 24
 
20 25
   listOfData: any[] = []; //表格数据
@@ -22,12 +27,20 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
22 27
   pageIndex: number = 1; //表格当前页码
23 28
   pageSize: number = 30; //表格每页展示条数
24 29
   listLength: number = 0; //表格总数据量
25
-
26
-  deptTypeId;//科室类型id
27
-
30
+	hospital:any;
31
+	deptTypeId;//科室类型id
32
+	deptId;
33
+	searchTimerSubject = new Subject();
34
+	
28 35
   ngOnInit() {
36
+		this.hospital = this.tool.getCurrentHospital().id
37
+		this.searchTimerSubject.pipe(debounceTime(500)).subscribe((v) => {
38
+		  let fun = v[0];
39
+		  fun.call(this, v[1]);
40
+		});
29 41
     this.initSessionData();
30 42
     this.getQueryParams();
43
+		this.getDeparts();
31 44
     this.search();
32 45
   }
33 46
 
@@ -62,12 +75,14 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
62 75
   hosId:any;
63 76
   dutyId:any;
64 77
   parentDutyId:any;
78
+	parent:any;
65 79
   initSessionData(){
66 80
     let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
67 81
     let queryType:any = newStatistics.queryType;
68 82
     let hosId:any = newStatistics.hospitalId;
69 83
     let dutyId:any = newStatistics.dutyId;
70
-
84
+		this.parent = newStatistics.parent;
85
+		
71 86
     queryType = queryType ? +queryType : undefined;
72 87
     hosId = hosId ? +hosId : undefined;
73 88
     dutyId = dutyId ? +dutyId : undefined;
@@ -105,12 +120,14 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
105 120
     let postData:any = {
106 121
       idx: this.pageIndex - 1,
107 122
       sum: this.pageSize,
123
+			showParentDept: this.parent==1 ? 'true' : undefined,
108 124
       startDate: this.dateRange[0] || undefined,
109 125
       endDate: this.dateRange[1] || undefined,
110 126
       hosId: this.hosId || undefined,
111 127
       dutyId: this.dutyId || undefined,
128
+      repairDeptId: this.deptId || undefined,
112 129
       parentDutyId: this.parentDutyId || undefined,
113
-      deptTypeId: this.deptTypeId || undefined,
130
+      deptTypeId: this.fieldConfig.fields.deptTypeId || undefined,
114 131
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
115 132
       userId: this.fieldConfig.fields.userId || undefined,
116 133
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -170,12 +187,14 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
170 187
       nzDuration: 0,
171 188
     }).messageId;
172 189
     let postData:any = {
190
+			showParentDept: this.parent==1 ? 'true' : undefined,
173 191
       startDate: this.dateRange[0] || undefined,
174 192
       endDate: this.dateRange[1] || undefined,
175 193
       hosId: this.hosId || undefined,
176 194
       dutyId: this.dutyId || undefined,
177 195
       parentDutyId: this.parentDutyId || undefined,
178
-      deptTypeId: this.deptTypeId || undefined,
196
+      deptTypeId: this.fieldConfig.deptTypeId || undefined,
197
+      repairDeptId: this.deptId || undefined,
179 198
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
180 199
       userId: this.fieldConfig.fields.userId || undefined,
181 200
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -215,17 +234,46 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
215 234
 		this.sortCurrentValue = "";
216 235
 		this.sortCurrent = {};
217 236
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
218
-    this.deptTypeId = undefined;
219
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined};
237
+    this.deptId = undefined;
238
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined};
220 239
     this.search();
221 240
   }
222 241
 
223
-  // 防抖
242
+	// 防抖
224 243
   isLoading = false;
225
-
226 244
   openChangeDeptType(flag){
227 245
     flag && this.getDeptTypeList();
228 246
   }
247
+	
248
+	// 科室搜索
249
+  changeInp(e) {
250
+    this.searchTimer(this.getDeparts, e);
251
+  }
252
+	
253
+	// 边输入边搜索节流阀
254
+	searchTimer(fun, e) {
255
+	  this.isLoading = true;
256
+	  this.searchTimerSubject.next([fun, e]);
257
+	}
258
+	
259
+	// 获取所有科室
260
+	alldepart:any;
261
+	getDeparts(dept?) {
262
+	  let data = {
263
+	    department: {
264
+	      cascadeHosId: this.hospital,
265
+	      dept: dept,
266
+	    },
267
+	    idx: 0,
268
+	    sum: 20,
269
+	  };
270
+	  this.mainService
271
+	    .getFetchDataList("data", "department", data)
272
+	    .subscribe((data) => {
273
+				this.isLoading = false;
274
+	      this.alldepart = data.list;
275
+	    });
276
+	}
229 277
 
230 278
   // 获取科室类型列表
231 279
   deptTypeList:any[] = [];
@@ -241,8 +289,8 @@ export class DepartmentEvaluateStatisticsComponent implements OnInit, AfterViewI
241 289
 
242 290
   // 详细搜索
243 291
   fieldConfig:any = {
244
-    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined},
245
-    config: {groupAndUser: true, category123: true, buildingAndFloor: true},
292
+    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined},
293
+    config: {groupAndUser: true, category123: true, buildingAndFloor: true, deptType: true},
246 294
   }
247 295
   showSearchMore:boolean = false;
248 296
   showMore(){

+ 18 - 15
src/app/views/new-statistics/maintenance-statistics/department-incident-statistics/department-incident-statistics.component.html

@@ -5,17 +5,17 @@
5 5
       <nz-range-picker [(ngModel)]="dateRange" [nzAllowClear]="false" (ngModelChange)="changeDate($event)" (nzOnCalendarChange)="onCalendarChangeDate($event)">
6 6
       </nz-range-picker>
7 7
     </div>
8
-    <div class="searchDataItem">
9
-      <span class="label">科室类型</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室类型" [(ngModel)]="deptTypeId" (nzOpenChange)="openChangeDeptType($event)">
11
-        <ng-container *ngFor="let option of deptTypeList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.name" [nzValue]="option.id"></nz-option>
13
-        </ng-container>
14
-        <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15
-          <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
16
-        </nz-option>
17
-      </nz-select>
18
-    </div>
8
+		<div class="searchDataItem">
9
+		  <span class="label">科室</span>:
10
+		  <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
11
+		    <ng-container *ngFor="let option of alldepart">
12
+		      <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
13
+		    </ng-container>
14
+		    <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15
+		      <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
16
+		    </nz-option>
17
+		  </nz-select>
18
+		</div>
19 19
   </div>
20 20
   <div class="operation">
21 21
     <i class="icon_transport transport-gengduo" nz-tooltip nzTooltipTitle="更多搜索" (click)="showMore()"></i>
@@ -24,7 +24,7 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO || fieldConfig.fields.deptTypeDTO">
28 28
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 29
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
30 30
   <span>{{fieldConfig.fields.category1DTO?.category}}</span>
@@ -32,11 +32,12 @@
32 32
   <span>{{fieldConfig.fields.category3DTO?.category}}</span>
33 33
   <span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
34 34
   <span>{{fieldConfig.fields.floorDTO?.floorName}}</span>
35
+	<span>{{fieldConfig.fields.deptTypeDTO?.name}}</span>
35 36
 </div>
36 37
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
37 38
   <thead (nzSortChange)="sort($event)" nzSingleSort>
38 39
     <tr>
39
-			<!-- <th nzWidth="10%" *ngIf="parent==1">父级科室</th> -->
40
+			<th nzWidth="9%" *ngIf="parent==1">父级科室(编码)</th>
40 41
       <th nzWidth="10%">科室名称(编码)</th>
41 42
       <th nzWidth="9%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">工单总数</th>
42 43
       <th nzWidth="9%" nzShowSort nzSortKey="avgResponseTime" [(nzSort)]="sortCurrent.avgResponseTime">平均接单时长</th>
@@ -52,7 +53,7 @@
52 53
   </thead>
53 54
   <tbody>
54 55
     <tr *ngFor="let data of listOfData">
55
-			<!-- <td *ngIf="parent==1">{{ data.parentName }}</td> -->
56
+			<td *ngIf="parent==1">{{ data.parentName || '无' }}<ng-container *ngIf="parent==1 && data.parentName">({{ data.parentCode }})</ng-container></td>
56 57
       <td>{{ data.deptName }}<ng-container *ngIf="data.deptCode">({{ data.deptCode }})</ng-container></td>
57 58
       <td>{{ data.sum }}</td>
58 59
       <td>{{ data.avgResponseTime }}</td>
@@ -69,7 +70,9 @@
69 70
   <ng-template #footerTpl>
70 71
     <table class="footTable">
71 72
       <tr *ngFor="let data of listOfDataEnd">
72
-        <td style="width: 10%">{{ data.deptCode }}</td>
73
+        <td style="width: 9%" *ngIf="parent==1">{{ data.parentCode }}</td>
74
+				<td style="width: 10%" *ngIf="parent==0">{{ data.deptCode}}</td>
75
+				<td style="width: 10%" *ngIf="parent==1"></td>
73 76
         <td style="width: 9%">{{ data.sum }}</td>
74 77
         <td style="width: 9%">{{ data.avgResponseTime }}</td>
75 78
         <td style="width: 9%">{{ data.avgResolvedTime }}</td>

+ 56 - 11
src/app/views/new-statistics/maintenance-statistics/department-incident-statistics/department-incident-statistics.component.ts

@@ -4,6 +4,10 @@ import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } fro
4 4
 import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
5 5
 import { MainService } from 'src/app/services/main.service';
6 6
 import { ActivatedRoute } from '@angular/router';
7
+import { ToolService } from "../../../../services/tool.service";
8
+import { Subject } from "rxjs";
9
+import { debounceTime } from "rxjs/operators";
10
+
7 11
 @Component({
8 12
   selector: "app-department-incident-statistics",
9 13
   templateUrl: "./department-incident-statistics.component.html",
@@ -15,6 +19,7 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
15 19
     private message: NzMessageService,
16 20
     private route: ActivatedRoute,
17 21
     private tabService: TabService,
22
+		private tool: ToolService,
18 23
   ) {}
19 24
 
20 25
   listOfData: any[] = []; //表格数据
@@ -22,12 +27,20 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
22 27
   pageIndex: number = 1; //表格当前页码
23 28
   pageSize: number = 30; //表格每页展示条数
24 29
   listLength: number = 0; //表格总数据量
25
-
30
+	hospital:any;
26 31
   deptTypeId;//科室类型id
27
-
32
+	deptId;
33
+	searchTimerSubject = new Subject();
34
+	
28 35
   ngOnInit() {
36
+		this.hospital = this.tool.getCurrentHospital().id
37
+		this.searchTimerSubject.pipe(debounceTime(500)).subscribe((v) => {
38
+		  let fun = v[0];
39
+		  fun.call(this, v[1]);
40
+		});
29 41
     this.initSessionData();
30 42
     this.getQueryParams();
43
+		this.getDeparts();
31 44
     this.search();
32 45
   }
33 46
 
@@ -107,13 +120,14 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
107 120
     let postData:any = {
108 121
       idx: this.pageIndex - 1,
109 122
       sum: this.pageSize,
110
-			// showParentDept: this.parent==1 ? 'true' : undefined,
123
+			showParentDept: this.parent==1 ? 'true' : undefined,
111 124
       startDate: this.dateRange[0] || undefined,
112 125
       endDate: this.dateRange[1] || undefined,
113 126
       hosId: this.hosId || undefined,
114 127
       dutyId: this.dutyId || undefined,
128
+			repairDeptId: this.deptId || undefined,
115 129
       parentDutyId: this.parentDutyId || undefined,
116
-      deptTypeId: this.deptTypeId || undefined,
130
+      deptTypeId: this.fieldConfig.fields.deptTypeId || undefined,
117 131
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
118 132
       userId: this.fieldConfig.fields.userId || undefined,
119 133
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -173,12 +187,14 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
173 187
       nzDuration: 0,
174 188
     }).messageId;
175 189
     let postData:any = {
190
+			showParentDept: this.parent==1 ? 'true' : undefined,
176 191
       startDate: this.dateRange[0] || undefined,
177 192
       endDate: this.dateRange[1] || undefined,
178 193
       hosId: this.hosId || undefined,
179 194
       dutyId: this.dutyId || undefined,
180 195
       parentDutyId: this.parentDutyId || undefined,
181
-      deptTypeId: this.deptTypeId || undefined,
196
+      deptTypeId: this.fieldConfig.deptTypeId || undefined,
197
+			repairDeptId: this.deptId || undefined,
182 198
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
183 199
       userId: this.fieldConfig.fields.userId || undefined,
184 200
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -218,18 +234,47 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
218 234
 		this.sortCurrentValue = "";
219 235
 		this.sortCurrent = {};
220 236
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
221
-    this.deptTypeId = undefined;
222
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined};
237
+    this.deptId = undefined;
238
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined};
223 239
     this.search();
224 240
   }
225 241
 
226 242
   // 防抖
227 243
   isLoading = false;
228
-
229 244
   openChangeDeptType(flag){
230 245
     flag && this.getDeptTypeList();
231 246
   }
232
-
247
+	
248
+	// 科室搜索
249
+  changeInp(e) {
250
+    this.searchTimer(this.getDeparts, e);
251
+  }
252
+	
253
+	// 边输入边搜索节流阀
254
+	searchTimer(fun, e) {
255
+	  this.isLoading = true;
256
+	  this.searchTimerSubject.next([fun, e]);
257
+	}
258
+	
259
+	// 获取所有科室
260
+	alldepart:any;
261
+	getDeparts(dept?) {
262
+	  let data = {
263
+	    department: {
264
+	      cascadeHosId: this.hospital,
265
+	      dept: dept,
266
+	    },
267
+	    idx: 0,
268
+	    sum: 20,
269
+	  };
270
+	  this.mainService
271
+	    .getFetchDataList("data", "department", data)
272
+	    .subscribe((data) => {
273
+				this.isLoading = false;
274
+	      this.alldepart = data.list;
275
+	    });
276
+	}
277
+	
233 278
   // 获取科室类型列表
234 279
   deptTypeList:any[] = [];
235 280
   getDeptTypeList(keyword?) {
@@ -244,8 +289,8 @@ export class DepartmentIncidentStatisticsComponent implements OnInit, AfterViewI
244 289
 
245 290
   // 详细搜索
246 291
   fieldConfig:any = {
247
-    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined},
248
-    config: {groupAndUser: true, category123: true, buildingAndFloor: true},
292
+    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined},
293
+    config: {groupAndUser: true, category123: true, buildingAndFloor: true, deptType: true},
249 294
   }
250 295
   showSearchMore:boolean = false;
251 296
   showMore(){

+ 12 - 7
src/app/views/new-statistics/maintenance-statistics/department-source-statistics/department-source-statistics.component.html

@@ -6,10 +6,10 @@
6 6
       </nz-range-picker>
7 7
     </div>
8 8
     <div class="searchDataItem">
9
-      <span class="label">科室类型</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室类型" [(ngModel)]="deptTypeId" (nzOpenChange)="openChangeDeptType($event)">
11
-        <ng-container *ngFor="let option of deptTypeList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.name" [nzValue]="option.id"></nz-option>
9
+      <span class="label">科室</span>:
10
+      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzAllowClear nzPlaceHolder="请选择科室" [(ngModel)]="deptId" nzServerSearch nzShowSearch (nzOnSearch)="changeInp($event)">
11
+        <ng-container *ngFor="let option of alldepart">
12
+          <nz-option *ngIf="!isLoading" [nzLabel]="option.dept" [nzValue]="option.id"></nz-option>
13 13
         </ng-container>
14 14
         <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15 15
           <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
@@ -24,7 +24,7 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.groupDTO || fieldConfig.fields.userDTO || fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO || fieldConfig.fields.deptTypeDTO">
28 28
   <span>{{fieldConfig.fields.groupDTO?.groupName}}</span>
29 29
   <span>{{fieldConfig.fields.userDTO?.name}}</span>
30 30
   <span>{{fieldConfig.fields.category1DTO?.category}}</span>
@@ -32,10 +32,12 @@
32 32
   <span>{{fieldConfig.fields.category3DTO?.category}}</span>
33 33
   <span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
34 34
   <span>{{fieldConfig.fields.floorDTO?.floorName}}</span>
35
+	<span>{{fieldConfig.fields.deptTypeDTO?.name}}</span>
35 36
 </div>
36 37
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
37 38
   <thead (nzSortChange)="sort($event)" nzSingleSort>
38 39
     <tr>
40
+			<th nzWidth="10%" *ngIf="parent==1">父级科室(编码)</th>
39 41
       <th nzWidth="20%">科室名称(编码)</th>
40 42
       <th nzWidth="16%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">工单总数</th>
41 43
       <th nzWidth="16%" nzShowSort nzSortKey="phoneCount" [(nzSort)]="sortCurrent.phoneCount">电话报修数</th>
@@ -46,7 +48,8 @@
46 48
   </thead>
47 49
   <tbody>
48 50
     <tr *ngFor="let data of listOfData">
49
-      <td>{{ data.deptName }}<ng-container *ngIf="data.deptCode">({{ data.deptCode }})</ng-container></td>
51
+			<td *ngIf="parent==1">{{ data.parentName || '无' }}<ng-container *ngIf="parent==1 && data.parentName">({{ data.parentCode }})</ng-container></td>
52
+			<td>{{ data.deptName }}<ng-container *ngIf="data.deptCode">({{ data.deptCode }})</ng-container></td>
50 53
       <td>{{ data.sum }}</td>
51 54
       <td>{{ data.phoneCount }}</td>
52 55
       <td>{{ data.wechatCount }}</td>
@@ -57,7 +60,9 @@
57 60
   <ng-template #footerTpl>
58 61
     <table class="footTable">
59 62
       <tr *ngFor="let data of listOfDataEnd">
60
-        <td style="width: 20%">{{ data.deptCode }}</td>
63
+				<td style="width: 10%" *ngIf="parent==1">{{ data.parentCode }}</td>
64
+				<td style="width: 20%" *ngIf="parent==0">{{ data.deptCode }}</td>
65
+				<td style="width: 20%" *ngIf="parent==1"></td>
61 66
         <td style="width: 16%">{{ data.sum }}</td>
62 67
         <td style="width: 16%">{{ data.phoneCount }}</td>
63 68
         <td style="width: 16%">{{ data.wechatCount }}</td>

+ 70 - 22
src/app/views/new-statistics/maintenance-statistics/department-source-statistics/department-source-statistics.component.ts

@@ -4,6 +4,9 @@ import { format, addMonths, startOfMonth, endOfMonth, startOfDay, endOfDay } fro
4 4
 import { Component, OnInit, HostListener, AfterViewInit } from "@angular/core";
5 5
 import { MainService } from 'src/app/services/main.service';
6 6
 import { ActivatedRoute } from '@angular/router';
7
+import { ToolService } from "../../../../services/tool.service";
8
+import { Subject } from "rxjs";
9
+import { debounceTime } from "rxjs/operators";
7 10
 @Component({
8 11
   selector: "app-department-source-statistics",
9 12
   templateUrl: "./department-source-statistics.component.html",
@@ -15,6 +18,7 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
15 18
     private message: NzMessageService,
16 19
     private route: ActivatedRoute,
17 20
     private tabService: TabService,
21
+		private tool: ToolService,
18 22
   ) {}
19 23
 
20 24
   listOfData: any[] = []; //表格数据
@@ -23,12 +27,21 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
23 27
   pageSize: number = 30; //表格每页展示条数
24 28
   listLength: number = 0; //表格总数据量
25 29
 
30
+  hospital:any;
26 31
   deptTypeId;//科室类型id
32
+  deptId;
33
+  searchTimerSubject = new Subject();
27 34
 
28 35
   ngOnInit() {
29
-    this.initSessionData();
30
-    this.getQueryParams();
31
-    this.search();
36
+		this.hospital = this.tool.getCurrentHospital().id
37
+		this.searchTimerSubject.pipe(debounceTime(500)).subscribe((v) => {
38
+		  let fun = v[0];
39
+		  fun.call(this, v[1]);
40
+		});
41
+		this.initSessionData();
42
+		this.getQueryParams();
43
+		this.getDeparts();
44
+		this.search();
32 45
   }
33 46
 
34 47
   ngAfterViewInit(){
@@ -62,11 +75,13 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
62 75
   hosId:any;
63 76
   dutyId:any;
64 77
   parentDutyId:any;
78
+	parent:any;
65 79
   initSessionData(){
66 80
     let newStatistics = JSON.parse(sessionStorage.getItem('newStatistics'));
67 81
     let queryType:any = newStatistics.queryType;
68 82
     let hosId:any = newStatistics.hospitalId;
69 83
     let dutyId:any = newStatistics.dutyId;
84
+		this.parent = newStatistics.parent;
70 85
 
71 86
     queryType = queryType ? +queryType : undefined;
72 87
     hosId = hosId ? +hosId : undefined;
@@ -103,14 +118,16 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
103 118
       this.pageIndex = num;
104 119
     }
105 120
     let postData:any = {
106
-      idx: this.pageIndex - 1,
107
-      sum: this.pageSize,
108
-      startDate: this.dateRange[0] || undefined,
109
-      endDate: this.dateRange[1] || undefined,
110
-      hosId: this.hosId || undefined,
111
-      dutyId: this.dutyId || undefined,
112
-      parentDutyId: this.parentDutyId || undefined,
113
-      deptTypeId: this.deptTypeId || undefined,
121
+			idx: this.pageIndex - 1,
122
+			sum: this.pageSize,
123
+			showParentDept: this.parent==1 ? 'true' : undefined,
124
+			startDate: this.dateRange[0] || undefined,
125
+			endDate: this.dateRange[1] || undefined,
126
+			hosId: this.hosId || undefined,
127
+			dutyId: this.dutyId || undefined,
128
+			repairDeptId: this.deptId || undefined,
129
+			parentDutyId: this.parentDutyId || undefined,
130
+			deptTypeId: this.fieldConfig.fields.deptTypeId || undefined,
114 131
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
115 132
       userId: this.fieldConfig.fields.userId || undefined,
116 133
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -170,12 +187,14 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
170 187
       nzDuration: 0,
171 188
     }).messageId;
172 189
     let postData:any = {
173
-      startDate: this.dateRange[0] || undefined,
174
-      endDate: this.dateRange[1] || undefined,
175
-      hosId: this.hosId || undefined,
176
-      dutyId: this.dutyId || undefined,
177
-      parentDutyId: this.parentDutyId || undefined,
178
-      deptTypeId: this.deptTypeId || undefined,
190
+			showParentDept: this.parent==1 ? 'true' : undefined,
191
+			startDate: this.dateRange[0] || undefined,
192
+			endDate: this.dateRange[1] || undefined,
193
+			hosId: this.hosId || undefined,
194
+			dutyId: this.dutyId || undefined,
195
+			parentDutyId: this.parentDutyId || undefined,
196
+			deptTypeId: this.fieldConfig.deptTypeId || undefined,
197
+			repairDeptId: this.deptId || undefined,
179 198
       groupId: this.fieldConfig.fields.userId ? undefined : (this.fieldConfig.fields.groupId || undefined),
180 199
       userId: this.fieldConfig.fields.userId || undefined,
181 200
       categoryId: this.fieldConfig.fields.categoryId || undefined,
@@ -215,17 +234,46 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
215 234
 		this.sortCurrentValue = "";
216 235
 		this.sortCurrent = {};
217 236
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
218
-    this.deptTypeId = undefined;
219
-    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined};
237
+    this.deptId = undefined;
238
+    this.fieldConfig.fields = {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined};
220 239
     this.search();
221 240
   }
222 241
 
223 242
   // 防抖
224 243
   isLoading = false;
225
-
226 244
   openChangeDeptType(flag){
227 245
     flag && this.getDeptTypeList();
228 246
   }
247
+  
248
+  // 科室搜索
249
+  changeInp(e) {
250
+    this.searchTimer(this.getDeparts, e);
251
+  }
252
+  
253
+  // 边输入边搜索节流阀
254
+  searchTimer(fun, e) {
255
+    this.isLoading = true;
256
+    this.searchTimerSubject.next([fun, e]);
257
+  }
258
+  
259
+  // 获取所有科室
260
+  alldepart:any;
261
+  getDeparts(dept?) {
262
+    let data = {
263
+      department: {
264
+        cascadeHosId: this.hospital,
265
+        dept: dept,
266
+      },
267
+      idx: 0,
268
+      sum: 20,
269
+    };
270
+    this.mainService
271
+      .getFetchDataList("data", "department", data)
272
+      .subscribe((data) => {
273
+  			this.isLoading = false;
274
+        this.alldepart = data.list;
275
+      });
276
+  }
229 277
 
230 278
   // 获取科室类型列表
231 279
   deptTypeList:any[] = [];
@@ -241,8 +289,8 @@ export class DepartmentSourceStatisticsComponent implements OnInit, AfterViewIni
241 289
 
242 290
   // 详细搜索
243 291
   fieldConfig:any = {
244
-    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined},
245
-    config: {groupAndUser: true, category123: true, buildingAndFloor: true},
292
+    fields: {groupId: undefined, userId: undefined, categoryId: undefined, buildingId: undefined, floorId: undefined, deptTypeId: undefined},
293
+    config: {groupAndUser: true, category123: true, buildingAndFloor: true, deptType: true},
246 294
   }
247 295
   showSearchMore:boolean = false;
248 296
   showMore(){

+ 6 - 5
src/app/views/new-statistics/maintenance-statistics/tripartite-company-statistics/tripartite-company-statistics.component.html

@@ -6,10 +6,10 @@
6 6
       </nz-range-picker>
7 7
     </div>
8 8
     <div class="searchDataItem">
9
-      <span class="label">报修科室</span>:
10
-      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzServerSearch nzShowSearch (nzOnSearch)="changeRepairDeptInp($event)" nzAllowClear nzPlaceHolder="请选择报修科室" [(ngModel)]="repairDeptId" (nzOpenChange)="openChangeRepairDept($event)">
11
-        <ng-container *ngFor="let option of repairDeptList">
12
-          <nz-option *ngIf="!isLoading" [nzLabel]="option.hospital.hosName + '-' + option.dept" [nzValue]="option.id"></nz-option>
9
+      <span class="label">三方公司</span>:
10
+      <nz-select class="selectItem" [nzDropdownMatchSelectWidth]="false" nzServerSearch nzShowSearch (nzOnSearch)="changeRepairDeptInp($event)" nzAllowClear nzPlaceHolder="请选择三方公司" [(ngModel)]="companyId" (nzOpenChange)="openChangeRepairDept($event)">
11
+        <ng-container *ngFor="let option of companyList">
12
+          <nz-option *ngIf="!isLoading" [nzLabel]="option.name" [nzValue]="option.id"></nz-option>
13 13
         </ng-container>
14 14
         <nz-option *ngIf="isLoading" nzDisabled nzCustomContent>
15 15
           <i nz-icon nzType="loading" class="loading-icon"></i> 搜索中...
@@ -24,12 +24,13 @@
24 24
     <button nz-button class="btn default ml8" (click)="excelExport()" [nzLoading]="excelExportLoading">导出</button>
25 25
   </div>
26 26
 </div>
27
-<div class="moreFilter" *ngIf="fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO">
27
+<div class="moreFilter" *ngIf="fieldConfig.fields.category1DTO || fieldConfig.fields.category2DTO || fieldConfig.fields.category3DTO || fieldConfig.fields.buildingDTO || fieldConfig.fields.floorDTO || fieldConfig.fields.repairDeptDTO">
28 28
   <span>{{fieldConfig.fields.category1DTO?.category}}</span>
29 29
   <span>{{fieldConfig.fields.category2DTO?.category}}</span>
30 30
   <span>{{fieldConfig.fields.category3DTO?.category}}</span>
31 31
   <span>{{fieldConfig.fields.buildingDTO?.buildingName}}</span>
32 32
   <span>{{fieldConfig.fields.floorDTO?.floorName}}</span>
33
+	<span>{{fieldConfig.fields.repairDeptDTO?.dept}}</span>
33 34
 </div>
34 35
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
35 36
   <thead (nzSortChange)="sort($event)" nzSingleSort>

+ 35 - 9
src/app/views/new-statistics/maintenance-statistics/tripartite-company-statistics/tripartite-company-statistics.component.ts

@@ -112,12 +112,13 @@ export class TripartiteCompanyStatisticsComponent implements OnInit, AfterViewIn
112 112
     let postData:any = {
113 113
       idx: this.pageIndex - 1,
114 114
       sum: this.pageSize,
115
+			companyId: this.companyId,
115 116
       startDate: this.dateRange[0] || undefined,
116 117
       endDate: this.dateRange[1] || undefined,
117 118
       hosId: this.hosId || undefined,
118 119
       dutyId: this.dutyId || undefined,
119 120
       parentDutyId: this.parentDutyId || undefined,
120
-      repairDeptId: this.repairDeptId || undefined,
121
+      repairDeptId: this.fieldConfig.fields.repairDeptId || undefined,
121 122
       categoryId: this.fieldConfig.fields.categoryId || undefined,
122 123
       hierarchy: this.fieldConfig.fields.hierarchy || undefined,
123 124
       buildingId: this.fieldConfig.fields.buildingId || undefined,
@@ -175,12 +176,13 @@ export class TripartiteCompanyStatisticsComponent implements OnInit, AfterViewIn
175 176
       nzDuration: 0,
176 177
     }).messageId;
177 178
     let postData:any = {
179
+			companyId: this.companyId,
178 180
       startDate: this.dateRange[0] || undefined,
179 181
       endDate: this.dateRange[1] || undefined,
180 182
       hosId: this.hosId || undefined,
181 183
       dutyId: this.dutyId || undefined,
182 184
       parentDutyId: this.parentDutyId || undefined,
183
-      repairDeptId: this.repairDeptId || undefined,
185
+      repairDeptId: this.fieldConfig.fields.repairDeptId || undefined,
184 186
       categoryId: this.fieldConfig.fields.categoryId || undefined,
185 187
       hierarchy: this.fieldConfig.fields.hierarchy || undefined,
186 188
       buildingId: this.fieldConfig.fields.buildingId || undefined,
@@ -218,14 +220,14 @@ export class TripartiteCompanyStatisticsComponent implements OnInit, AfterViewIn
218 220
 		this.sortCurrentValue = "";
219 221
 		this.sortCurrent = {};
220 222
     this.dateRange = [format(startOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss'), format(endOfMonth(addMonths(new Date(), -1)), 'yyyy-MM-dd HH:mm:ss')]
221
-    this.repairDeptId = undefined;
222
-    this.fieldConfig.fields = {categoryId: undefined, buildingId: undefined, floorId: undefined};
223
+    this.companyId = undefined;
224
+    this.fieldConfig.fields = {categoryId: undefined, buildingId: undefined, floorId: undefined, repairDeptId: undefined};
223 225
     this.search();
224 226
   }
225 227
 
226 228
   // 科室搜索
227 229
   changeRepairDeptInp(e) {
228
-    this.searchTimer(this.getRepairDeptList, e);
230
+    this.searchTimer(this.getCompanyList, e);
229 231
   }
230 232
 
231 233
   // 防抖
@@ -236,7 +238,7 @@ export class TripartiteCompanyStatisticsComponent implements OnInit, AfterViewIn
236 238
   }
237 239
 
238 240
   openChangeRepairDept(flag){
239
-    flag && this.getRepairDeptList();
241
+    flag && this.getCompanyList();
240 242
   }
241 243
 
242 244
   // 获取报修科室列表
@@ -259,11 +261,35 @@ export class TripartiteCompanyStatisticsComponent implements OnInit, AfterViewIn
259 261
         this.repairDeptList = data.list;
260 262
       });
261 263
   }
262
-
264
+	
265
+	// 获取三方公司列表
266
+	companyId:any;
267
+	companyList:any[] = [];
268
+	getCompanyList(keyword?){
269
+	  let postData: any = {
270
+	    idx: 0,
271
+	    sum: 20,
272
+	    company: {
273
+	      busiType: { key: "company_busi_type", value: "2" },
274
+	      name: keyword,
275
+	      statisticalHosId: this.getHosId,
276
+	    },
277
+	  };
278
+	  this.isLoading = true;
279
+	  this.mainService.getFetchDataList("simple/data", "company", postData).subscribe(result => {
280
+	    this.isLoading = false;
281
+	    if(result.status == 200){
282
+	      this.companyList = result.list || [];
283
+	    }else{
284
+	      this.companyList = [];
285
+	    }
286
+	  });
287
+	}
288
+	
263 289
   // 详细搜索
264 290
   fieldConfig:any = {
265
-    fields: {categoryId: undefined, buildingId: undefined, floorId: undefined},
266
-    config: {category123: true, buildingAndFloor: true},
291
+    fields: {categoryId: undefined, buildingId: undefined, floorId: undefined, repairDeptId: true},
292
+    config: {category123: true, buildingAndFloor: true, repairDept: true},
267 293
   }
268 294
   showSearchMore:boolean = false;
269 295
   showMore(){

+ 25 - 22
src/app/views/new-statistics/maintenance-statistics/user-statistics/user-statistics.component.html

@@ -34,17 +34,18 @@
34 34
 <nz-table class="table" [nzData]="listOfData" nzSize="middle" [nzShowPagination]="false" [nzLoading]="loading1" [nzScroll]="{ y: tableHeight + 'px' }" [nzFooter]="footerTpl">
35 35
   <thead (nzSortChange)="sort($event)" nzSingleSort>
36 36
     <tr>
37
-      <th nzWidth="10%">人员姓名(工号)</th>
38
-      <th nzWidth="9%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">工单总数</th>
39
-      <th nzWidth="9%" nzShowSort nzSortKey="avgResponseTime" [(nzSort)]="sortCurrent.avgResponseTime">平均接单时长</th>
40
-      <th nzWidth="9%" nzShowSort nzSortKey="avgResolvedTime" [(nzSort)]="sortCurrent.avgResolvedTime">平均解决时长</th>
41
-      <th nzWidth="9%" nzShowSort nzSortKey="resolvedOverNum" [(nzSort)]="sortCurrent.resolvedOverNum">超时单数</th>
42
-      <th nzWidth="9%" nzShowSort nzSortKey="overTimeNum" [(nzSort)]="sortCurrent.overTimeNum">挂起单数</th>
43
-      <th nzWidth="9%" nzShowSort nzSortKey="consumablePrice" [(nzSort)]="sortCurrent.consumablePrice">耗材费用(元)</th>
44
-      <th nzWidth="9%" nzShowSort nzSortKey="workHourPrice" [(nzSort)]="sortCurrent.workHourPrice">工时费用(元)</th>
45
-      <th nzWidth="9%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用(元)</th>
46
-      <th nzWidth="9%" nzShowSort nzSortKey="negativeNum" [(nzSort)]="sortCurrent.negativeNum">差评单数</th>
47
-      <th nzWidth="9%" nzShowSort nzSortKey="favorableRate" [(nzSort)]="sortCurrent.favorableRate">好评率</th>
37
+      <th nzWidth="8%">人员姓名(工号)</th>
38
+      <th nzWidth="8%" nzShowSort nzSortKey="sum" [(nzSort)]="sortCurrent.sum">工单总数</th>
39
+      <th nzWidth="8%" nzShowSort nzSortKey="avgResponseTime" [(nzSort)]="sortCurrent.avgResponseTime">平均接单时长</th>
40
+      <th nzWidth="8%" nzShowSort nzSortKey="avgResolvedTime" [(nzSort)]="sortCurrent.avgResolvedTime">平均解决时长</th>
41
+      <th nzWidth="8%" nzShowSort nzSortKey="resolvedOverNum" [(nzSort)]="sortCurrent.resolvedOverNum">超时单数</th>
42
+      <th nzWidth="8%" nzShowSort nzSortKey="overTimeNum" [(nzSort)]="sortCurrent.overTimeNum">挂起单数</th>
43
+      <th nzWidth="8%" nzShowSort nzSortKey="consumablePrice" [(nzSort)]="sortCurrent.consumablePrice">耗材费用(元)</th>
44
+      <th nzWidth="8%" nzShowSort nzSortKey="workHourPrice" [(nzSort)]="sortCurrent.workHourPrice">工时费用(元)</th>
45
+      <th nzWidth="8%" nzShowSort nzSortKey="totalPrice" [(nzSort)]="sortCurrent.totalPrice">总费用(元)</th>
46
+      <th nzWidth="8%" nzShowSort nzSortKey="totalScore" [(nzSort)]="sortCurrent.totalScore">总积分</th>
47
+			<th nzWidth="8%" nzShowSort nzSortKey="negativeNum" [(nzSort)]="sortCurrent.negativeNum">差评单数</th>
48
+      <th nzWidth="8%" nzShowSort nzSortKey="favorableRate" [(nzSort)]="sortCurrent.favorableRate">好评率</th>
48 49
     </tr>
49 50
   </thead>
50 51
   <tbody>
@@ -58,6 +59,7 @@
58 59
       <td>{{ data.consumablePrice }}</td>
59 60
       <td>{{ data.workHourPrice }}</td>
60 61
       <td>{{ data.totalPrice }}</td>
62
+			<td>{{ data.totalScore }}</td>
61 63
       <td>{{ data.negativeNum }}</td>
62 64
       <td>{{ data.favorableRate }}</td>
63 65
     </tr>
@@ -65,17 +67,18 @@
65 67
   <ng-template #footerTpl>
66 68
     <table class="footTable">
67 69
       <tr *ngFor="let data of listOfDataEnd">
68
-        <td style="width: 10%">{{ data.userName }}</td>
69
-        <td style="width: 9%">{{ data.sum }}</td>
70
-        <td style="width: 9%">{{ data.avgResponseTime }}</td>
71
-        <td style="width: 9%">{{ data.avgResolvedTime }}</td>
72
-        <td style="width: 9%">{{ data.resolvedOverNum }}</td>
73
-        <td style="width: 9%">{{ data.overTimeNum }}</td>
74
-        <td style="width: 9%">{{ data.consumablePrice }}</td>
75
-        <td style="width: 9%">{{ data.workHourPrice }}</td>
76
-        <td style="width: 9%">{{ data.totalPrice }}</td>
77
-        <td style="width: 9%">{{ data.negativeNum }}</td>
78
-        <td style="width: 9%">{{ data.favorableRate }}</td>
70
+        <td style="width: 8%">{{ data.userName }}</td>
71
+        <td style="width: 8%">{{ data.sum }}</td>
72
+        <td style="width: 8%">{{ data.avgResponseTime }}</td>
73
+        <td style="width: 8%">{{ data.avgResolvedTime }}</td>
74
+        <td style="width: 8%">{{ data.resolvedOverNum }}</td>
75
+        <td style="width: 8%">{{ data.overTimeNum }}</td>
76
+        <td style="width: 8%">{{ data.consumablePrice }}</td>
77
+        <td style="width: 8%">{{ data.workHourPrice }}</td>
78
+        <td style="width: 8%">{{ data.totalPrice }}</td>
79
+				<td style="width: 8%">{{ data.totalScore }}</td>
80
+        <td style="width: 8%">{{ data.negativeNum }}</td>
81
+        <td style="width: 8%">{{ data.favorableRate }}</td>
79 82
       </tr>
80 83
     </table>
81 84
   </ng-template>

+ 12 - 0
src/app/views/task-type-management/task-type-management.component.html

@@ -299,6 +299,18 @@
299 299
             <nz-option nzLabel="{{data.name}}" nzValue="{{data.id}}" *ngFor="let data of allStatisticsDateType"></nz-option>
300 300
           </nz-select>
301 301
         </div>
302
+				<div nz-row class="mb8 display_flex align-items_center">
303
+				  <nz-form-label class="label">积分单价</nz-form-label>
304
+					<nz-input-number
305
+						class="flex_1"
306
+						[(ngModel)]="scorePrice"
307
+					 	[nzMin]="0"
308
+						[nzPrecision]="2"
309
+					 	[nzMax]="999999"
310
+					 	[nzStep]="0.1"
311
+					 	[nzPlaceHolder]="'请填写积分单价(保留2位小数)'"
312
+					 ></nz-input-number>
313
+				</div>
302 314
       </div>
303 315
       <!-- 规则信息 -->
304 316
       <div *ngIf="tabModalName=='gzxx'" class="ruleList">

+ 4 - 0
src/app/views/task-type-management/task-type-management.component.ts

@@ -88,6 +88,7 @@ export class TaskTypeManagementComponent implements OnInit {
88 88
   urgeWeight:any; //急单权重
89 89
   commonWeight:any; //普单权重
90 90
   countRemark:string = ''; //统计备注
91
+	scorePrice:any; //积分单价
91 92
   association: any = {
92 93
     id: "",
93 94
     value: "",
@@ -851,6 +852,7 @@ export class TaskTypeManagementComponent implements OnInit {
851 852
     this.urgeWeight = data.urgeWeight;
852 853
     this.commonWeight = data.commonWeight;
853 854
     this.countRemark = data.countRemark || '';
855
+		this.scorePrice = data.scorePrice || '';
854 856
     this.association = {
855 857
       id: data.associationType.id + "",
856 858
       value: data.associationType.value,
@@ -1173,6 +1175,7 @@ export class TaskTypeManagementComponent implements OnInit {
1173 1175
     this.taskData.taskType["urgeWeight"] = this.urgeWeight;
1174 1176
     this.taskData.taskType["commonWeight"] = this.commonWeight;
1175 1177
     this.taskData.taskType["countRemark"] = this.countRemark;
1178
+		this.taskData.taskType["scorePrice"] = this.scorePrice;
1176 1179
     if (this.association.id) {
1177 1180
       this.taskData.taskType["associationType"] = this.association;
1178 1181
     } else {
@@ -1511,6 +1514,7 @@ export class TaskTypeManagementComponent implements OnInit {
1511 1514
     this.urgeWeight = '';
1512 1515
     this.commonWeight = '';
1513 1516
     this.countRemark = '';
1517
+		this.scorePrice = '';
1514 1518
     this.association = {
1515 1519
       id: null,
1516 1520
       value: "",

+ 3 - 1
src/app/views/tripartite-company/tripartite-company.component.ts

@@ -259,7 +259,9 @@ export class TripartiteCompanyComponent implements OnInit {
259 259
     this.add = false;
260 260
     this.modal = true;
261 261
     this.coopData = data;
262
-		this.validateForm.controls.employScope.setValue(data.selectRange.id);
262
+		if(data.selectRange){
263
+			this.validateForm.controls.employScope.setValue(data.selectRange.id);
264
+		}
263 265
     this.validateForm.controls.name.setValue(data.name);
264 266
     this.validateForm.controls.nickName.setValue(data.nickName);
265 267
     this.validateForm.controls.companyTypeIds.setValue(this.companyTypeList.map(v => ({label: v.name, value: v.id, checked: data.companyTypeIds.includes(v.id)})));

+ 1 - 5
src/app/views/users-management/users-management.component.ts

@@ -416,7 +416,6 @@ export class UsersManagementComponent implements OnInit {
416 416
     });
417 417
     let data = {
418 418
       user: {
419
-				upType: "changeDept",
420 419
         name: that.validateForm.value.name,
421 420
         account: that.validateForm.value.account,
422 421
         gradeId: that.validateForm.value.gradeId,
@@ -439,10 +438,7 @@ export class UsersManagementComponent implements OnInit {
439 438
     }
440 439
     if (!that.add) {
441 440
       data.user["id"] = that.coopId;
442
-			data.user.upType = "changeDept"
443
-    }else{
444
-			delete data.user.upType
445
-		}
441
+    }
446 442
     that.mainService
447 443
       .coopData(that.add ? "addData" : "updData", "user", data)
448 444
       .subscribe((data) => {