From 222b694609771d3f037b9098270f10d4b78d7b19 Mon Sep 17 00:00:00 2001
From: 沈斌 <bluelazysb@hotmail.com>
Date: Mon, 18 Dec 2017 16:50:17 +0800
Subject: [PATCH] updates

---
 src/app/routes/users/installer/installer.component.ts |   83 +++++++++++++++++++++++++++++++++++++++++
 1 files changed, 82 insertions(+), 1 deletions(-)

diff --git a/src/app/routes/users/installer/installer.component.ts b/src/app/routes/users/installer/installer.component.ts
index 08b11e7..af60ea2 100644
--- a/src/app/routes/users/installer/installer.component.ts
+++ b/src/app/routes/users/installer/installer.component.ts
@@ -1,4 +1,6 @@
 import { Component, OnInit } from '@angular/core';
+import { NzMessageService } from 'ng-zorro-antd';
+import { getInstaller, deleteInstaller } from '../../../../../_mock/installer.service';
 
 @Component({
   selector: 'app-installer',
@@ -7,9 +9,88 @@
 })
 export class InstallerComponent implements OnInit {
 
-  constructor() { }
+  q: any = {
+    pi: 1,
+    ps: 10,
+    sorter: '',
+    u_name: '',
+    u_mobile: ''
+  };
+  data: any[] = [];
+  loading = false;
+  selectedRows: any[] = [];
+  curRows: any[] = [];
+  allChecked = false;
+  indeterminate = false;
+
+  sortMap: any = {};
+  modalVisible = false;
+
+  constructor(public msg: NzMessageService) {}
 
   ngOnInit() {
+    this.getData();
   }
 
+  getData() {
+    this.pageChange(1).then(() => {
+      this.data = getInstaller(this.q);
+    });
+  }
+
+  add() {
+    this.modalVisible = true;
+  }
+
+  save() {
+
+  }
+
+  remove() {
+    this.selectedRows.forEach(i => deleteInstaller(i.name));
+    this.getData();
+  }
+
+  checkAll(value: boolean) {
+    this.curRows.forEach(i => {
+      if (!i.disabled) i.checked = value;
+    });
+    this.refreshStatus();
+  }
+
+  refreshStatus() {
+    const allChecked = this.curRows.every(value => value.disabled || value.checked);
+    const allUnChecked = this.curRows.every(value => value.disabled || !value.checked);
+    this.allChecked = allChecked;
+    this.indeterminate = (!allChecked) && (!allUnChecked);
+    this.selectedRows = this.data.filter(value => value.checked);
+  }
+
+  sort(field: string, value: any) {
+    this.sortMap = {};
+    this.sortMap[field] = value;
+    this.q.sorter = value ? `${field}_${value}` : '';
+    this.getData();
+  }
+
+  dataChange(res: any) {
+    this.curRows = res;
+    this.refreshStatus();
+  }
+
+  pageChange(pi: number): Promise<any> {
+    this.q.pi = pi;
+    this.loading = true;
+    return new Promise((resolve) => {
+      setTimeout(() => {
+        this.loading = false;
+        resolve();
+      }, 500);
+    });
+  }
+
+  reset(ls: any[]) {
+    for (const item of ls) item.value = false;
+    this.getData();
+  }
 }

--
Gitblit v1.8.0