ftable
Version:
Angular 6/7 Tables
186 lines • 27.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { firstBy } from 'thenby';
import { FTableResult } from '../ftable.model';
import { empty } from 'rxjs';
import { of } from 'rxjs';
export class FTableLocalService {
/**
* @param {?} http
*/
constructor(http) {
this.http = http;
this.data = [];
}
/**
* @param {?} data
* @return {?}
*/
setLocalTableData(data) {
this.mode = '';
this.data = data;
}
/**
* @param {?} id
* @return {?}
*/
get(id) {
// console.log('get');
return this.getRowByColumnNameAndValue('id', id);
}
/**
* @param {?} name
* @param {?} value
* @return {?}
*/
getRowByColumnNameAndValue(name, value) {
// console.log('getRowByColumnNameAndValue'+' '+name+' '+value);
// console.log('getRowByColumnNameAndValue'+' '+name+' '+value);
/** @type {?} */
const result = this.data.filter(x => x[name] == value);
// console.log('getRowByColumnNameAndValue'+' '+name+' '+value);
if (result.length > 0) {
return of(result[0]);
}
return empty();
}
/*
*
*/
/**
* @param {?} id
* @param {?} propertyToChange
* @param {?} fn
* @return {?}
*/
setData(id, propertyToChange, fn) {
/** @type {?} */
var row = this.data.find(d => d['id'] === id);
row[propertyToChange] = fn(row[propertyToChange]);
return of(row);
}
/**
* @param {?} id
* @return {?}
*/
delete(id) {
// cant modify JSON files frontend
/** @type {?} */
var row = this.data.find(d => d['id'] === id);
return of(row);
}
/**
* @param {?} table
* @return {?}
*/
getData(table) {
/** @type {?} */
let data = this.data;
for (let i = 0; i < table.columns.length; i++) {
if (table.columns[i].type === 'checkbox') {
table.columns[i].filterData = Array.from(new Set(data.map(x => x[table.columns[i].name])));
}
}
/** @type {?} */
var totalRows = data.length;
// Generic Search
if (table.dataModifier.search.value) {
table.dataModifier.currentPage = 1;
if (table.columns.length > 0) {
/** @type {?} */
let temp = [];
for (let i = 0; i < table.columns.length; i++) {
if (table.columns[i].name.length > 0) {
temp = temp.concat(data.filter(x => String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) !== -1));
data = data.filter(x => String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) === -1);
}
}
data = temp;
}
}
if (table.dataModifier.filters.length > 0) {
for (let i = 0; i < table.dataModifier.filters.length; i++) {
if (table.dataModifier.filters[i].apply)
data = table.dataModifier.filters[i].apply(data);
}
}
// Column Priority Sorting
if (table.dataModifier.orders.length > 0) {
/** @type {?} */
let sortBy;
for (let i = 0; i < table.dataModifier.orders.length; i++) {
/** @type {?} */
const order = (table.dataModifier.orders[i].direction === 'Desc') ? -1 : 1;
if (i === 0) {
if (typeof data[0][table.dataModifier.orders[i].columnName] === 'string') {
// console.log('String firstBy:' + table.columns[table.orders[i].columnIndex].name);
sortBy = firstBy(table.dataModifier.orders[i].columnName, {
ignoreCase: true,
direction: order
});
}
else if (typeof data[0][table.dataModifier.orders[i].columnName] === 'number') {
sortBy = firstBy(function (v1, v2) {
return v1[table.dataModifier.orders[i].columnName] - v2[table.dataModifier.orders[i].columnName];
}, order);
}
else {
// console.log('otherType sort:' + typeof data[0][table.columns[table.dataModifier.orders[i].columnIndex].name]);
}
}
else {
if (typeof data[0][table.dataModifier.orders[i].columnName] === 'string') {
sortBy = sortBy.thenBy(table.dataModifier.orders[i].columnName, {
ignoreCase: true,
direction: order
});
}
else if (typeof data[0][table.dataModifier.orders[i].columnName] === 'number') {
sortBy = sortBy.thenBy(function (v1, v2) {
return v1[table.dataModifier.orders[i].columnName] - v2[table.dataModifier.orders[i].columnName];
}, order);
}
else {
console.log('otherType sort');
}
}
}
data.sort(sortBy);
}
// console.log('SIZE:' + table.dataModifier.currentPage + ' ' + table.pageSizes[table.pageSizeIndex]);
// this.page = this.data.slice(( this.currentPage - 1) * this.pageSize, this.currentPage * this.pageSize);
/** @type {?} */
var totalRowsAfterModifications = data.length;
/** @type {?} */
var page = data.slice((table.dataModifier.currentPage - 1) * table.pageSizes[table.pageSizeIndex], (table.dataModifier.currentPage * (table.pageSizes[table.pageSizeIndex])));
/** @type {?} */
var result = new FTableResult(page, totalRows, totalRowsAfterModifications, null);
return of(result);
}
}
FTableLocalService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
FTableLocalService.ctorParameters = () => [
{ type: HttpClient }
];
if (false) {
/** @type {?} */
FTableLocalService.prototype.data;
/**
* @type {?}
* @private
*/
FTableLocalService.prototype.mode;
/**
* @type {?}
* @private
*/
FTableLocalService.prototype.http;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ftablelocal.service.js","sourceRoot":"ng://ftable/","sources":["lib/service/ftablelocal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { HttpHeaders} from '@angular/common/http';\n\n// import { BehaviorSubject } from 'rxjs/BehaviorSubject';\nimport {  map } from 'rxjs/operators';\nimport {firstBy} from 'thenby';\nimport {  FTable, FColumn, FSearch, FOrder, FTableResult, FTableDataModifier  } from '../ftable.model';\nimport { FTableBaseService } from './ftablebase.service';\nimport { Observable, empty } from 'rxjs';\nimport { of } from 'rxjs'\n\n\n\n@Injectable()\nexport class FTableLocalService implements FTableBaseService {\n\n    constructor(private http: HttpClient) {\n    }\n\n    public data = [];\n    private mode: string;\n\n    setLocalTableData(data: any[]){\n        this.mode = '';\n        this.data = data;\n    }\n\n\n    get(id:any): Observable<any>{\n        //  console.log('get');\n         return this.getRowByColumnNameAndValue('id',id);\n    }\n \n    getRowByColumnNameAndValue(name: string,value:any): Observable<any>{\n        // console.log('getRowByColumnNameAndValue'+' '+name+' '+value);\n\n        const result = this.data.filter(x => x[name]== value);\n        // console.log('getRowByColumnNameAndValue'+' '+name+' '+value);\n\n        if(result.length > 0){\n           return of(result[0]);\n        }\n        return empty();\n    }\n\n    /*\n    *\n    */\n    setData(id:any,propertyToChange:string,fn: (n:any)=>any):Observable<any>{\n       var row = this.data.find(d=>d['id'] === id);\n       row[propertyToChange] = fn(row[propertyToChange]);\n       return of(row);\n    }\n\n    delete(id:any):Observable<any>{\n        // cant modify JSON files frontend\n         var row = this.data.find(d=>d['id'] === id);\n        return of(row);\n    }\n\n     getData(table: FTable): Observable<FTableResult>  {\n\n      let data = this.data;\n     \n\n      for (let i = 0; i < table.columns.length; i++) {\n        if (table.columns[i].type === 'checkbox') {\n            table.columns[i].filterData = Array.from(new Set(data.map(x => x[table.columns[i].name])))\n        }\n      }\n\n\n\n      var totalRows = data.length;\n      // Generic Search\n      if (table.dataModifier.search.value) {\n        table.dataModifier.currentPage = 1;\n      if (table.columns.length > 0) {\n        let temp = [];\n          for (let i = 0; i < table.columns.length; i++) {\n              if (table.columns[i].name.length > 0) {\n                  temp = temp.concat(data.filter(x => String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) !== -1));\n                  data = data.filter(x => String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) === -1);\n              }\n          }\n\n          data = temp;\n      }\n    }\n\n\n if (table.dataModifier.filters.length > 0) {\n    for (let i = 0; i < table.dataModifier.filters.length; i++) {\n        if(table.dataModifier.filters[i].apply)\n           data = table.dataModifier.filters[i].apply(data);\n    }\n }\n\n \n\n      // Column Priority Sorting\n      if (table.dataModifier.orders.length > 0) {\n          let sortBy;\n          for (let i = 0; i < table.dataModifier.orders.length; i++) {\n              const order = (table.dataModifier.orders[i].direction === 'Desc') ? -1 : 1;\n              if (i === 0) {\n                  if (typeof data[0][table.dataModifier.orders[i].columnName] === 'string') {\n                    //  console.log('String firstBy:' + table.columns[table.orders[i].columnIndex].name);\n                      sortBy = firstBy(table.dataModifier.orders[i].columnName, {\n                          ignoreCase: true,\n                          direction: order\n                      });\n                  } else if (typeof data[0][table.dataModifier.orders[i].columnName] === 'number') {\n                      sortBy = firstBy(function(v1, v2) {\n                          return v1[table.dataModifier.orders[i].columnName] - v2[table.dataModifier.orders[i].columnName];\n                      }, order);\n                  } else {\n                    //   console.log('otherType sort:' + typeof data[0][table.columns[table.dataModifier.orders[i].columnIndex].name]);\n                  }\n              } else {\n                  if (typeof data[0][table.dataModifier.orders[i].columnName] === 'string') {\n                      sortBy = sortBy.thenBy(table.dataModifier.orders[i].columnName, {\n                          ignoreCase: true,\n                          direction: order\n                      });\n                  } else if (typeof data[0][table.dataModifier.orders[i].columnName] === 'number') {\n                      sortBy = sortBy.thenBy(function(v1, v2) {\n                          return v1[table.dataModifier.orders[i].columnName] - v2[table.dataModifier.orders[i].columnName];\n                      }, order);\n                  } else {\n                      console.log('otherType sort');\n                  }\n              }\n          }\n          data.sort(sortBy);\n      }\n\n// console.log('SIZE:' + table.dataModifier.currentPage + ' ' + table.pageSizes[table.pageSizeIndex]);\n// this.page = this.data.slice(( this.currentPage - 1) * this.pageSize,  this.currentPage * this.pageSize);\n\n      var totalRowsAfterModifications = data.length;\n      var page = data.slice((table.dataModifier.currentPage-1) * table.pageSizes[table.pageSizeIndex], (table.dataModifier.currentPage * (table.pageSizes[table.pageSizeIndex])));\n      var result = new FTableResult(page,totalRows,totalRowsAfterModifications,null);\n      return of(result);\n  }\n\n\n\n\n\n\n\n\n\n  \n//     getData1(url: string,\n//             propertyNames: string[],\n//             propertyTypes: string[],\n//             sortStates: { 'propertyName': string , 'order': string}[],\n//             filters:any[],\n//             searchString: string) {\n\n//         console.log(url);\n//         console.log(propertyNames);\n//         console.log(propertyTypes);\n//         console.log(sortStates);\n//         console.log(filters);\n//         console.log(searchString);\n \n//         let data = this.data;\n\n//     // Generic Search\n//     // TODO: Cater for Formatted Datatypes\n//     let temp = [];\n//     if (propertyNames.length > 0)  {\n//     for (let i = 0; i < propertyNames.length; i++) {\n//         if (propertyNames[i].length > 0) {\n//             temp = temp.concat(data.filter(x => String(x[propertyNames[i]]).indexOf(searchString) !== -1));\n//             data = data.filter(x => String(x[propertyNames[i]]).indexOf(searchString) === -1);\n//         }\n//     }\n\n//     data = temp;\n//   }\n\n//   console.log(filters.length);\n//     if (filters.length > 0)  {\n//       temp = [];\n\n//       for (let i = 0; i < filters.length; i++) {\n//         // If string\n//         if(propertyTypes[filters[i].index] == 'string') {\n//             temp = data.filter(x =>\n//                  String(x[propertyNames[filters[i].index]]).toLowerCase().indexOf(filters[i].data.value.toLowerCase()) !== -1);\n//         // If number\n//         } else if(propertyTypes[filters[i].index] == 'number') {\n//           // if both min and max specified\n//           if(filters[i].data.max && filters[i].data.min){\n//             temp = data.filter(x =>\n//                 ((Number(x[propertyNames[filters[i].index]]) >= filters[i].data.min) &&\n//                  (Number(x[propertyNames[filters[i].index]]) <= filters[i].data.max)));\n//           // if max only specified\n//           } else if(filters[i].data.max) {\n//              temp = data.filter(x =>\n//                 Number(x[propertyNames[filters[i].index]]) <= filters[i].data.max);\n//           // if only min specified\n//           } else if(filters[i].data.min) {\n//              temp = data.filter(x =>\n//                 Number(x[propertyNames[filters[i].index]]) >= filters[i].data.min);\n//           // if nothing is specified\n//           } else  {\n//             temp = data;\n//           }\n//         }\n//             data = temp;\n//       }\n//       data = temp;\n//     }\n\n\n//     // Column Priority Sorting\n//     // TODO: Cater for Formatted Datatypes\n//     if (sortStates.length > 0) {\n//         let sortBy;\n//         for (let i = 0; i < sortStates.length; i++) {\n//             const order = (sortStates[i].order === 'Desc') ? -1 : 1;\n//             if (i === 0) {\n//                 if (typeof data[0][sortStates[i].propertyName] === 'string') {\n//                     console.log('String firstBy:' + sortStates[i].propertyName);\n//                     sortBy = firstBy(sortStates[i].propertyName, {\n//                         ignoreCase: true,\n//                         direction: order\n//                     });\n//                 } else if (typeof data[0][sortStates[i].propertyName] === 'number') {\n//                     sortBy = firstBy(function(v1, v2) {\n//                         return v1[sortStates[i].propertyName] - v2[sortStates[i].propertyName];\n//                     }, order);\n//                 } else {\n//                     console.log('otherType sort:' + typeof data[0][sortStates[i].propertyName]);\n//                 }\n//             } else {\n//                 console.log('thenBy:' + sortStates[i].propertyName);\n//                 if (typeof data[0][sortStates[i].propertyName] === 'string') {\n\n//                     sortBy = sortBy.thenBy(sortStates[i].propertyName, {\n//                         ignoreCase: true,\n//                         direction: order\n//                     });\n//                 } else if (typeof data[0][sortStates[i].propertyName] === 'number') {\n//                     sortBy = sortBy.thenBy(function(v1, v2) {\n//                         return v1[sortStates[i].propertyName] - v2[sortStates[i].propertyName];\n//                     }, order);\n//                 } else {\n//                     console.log('otherType sort');\n//                 }\n//             }\n//         }\n//         data.sort(sortBy);\n//     }\n\n\n//   return data;\n//   }\n\n}"]}