UNPKG

ftable

Version:
227 lines 29.1 kB
/** * @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'; var FTableLocalService = /** @class */ (function () { function FTableLocalService(http) { this.http = http; this.data = []; } /** * @param {?} data * @return {?} */ FTableLocalService.prototype.setLocalTableData = /** * @param {?} data * @return {?} */ function (data) { this.mode = ''; this.data = data; }; /** * @param {?} id * @return {?} */ FTableLocalService.prototype.get = /** * @param {?} id * @return {?} */ function (id) { // console.log('get'); return this.getRowByColumnNameAndValue('id', id); }; /** * @param {?} name * @param {?} value * @return {?} */ FTableLocalService.prototype.getRowByColumnNameAndValue = /** * @param {?} name * @param {?} value * @return {?} */ function (name, value) { // console.log('getRowByColumnNameAndValue'+' '+name+' '+value); // console.log('getRowByColumnNameAndValue'+' '+name+' '+value); /** @type {?} */ var result = this.data.filter(function (x) { return 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 {?} */ FTableLocalService.prototype.setData = /* * */ /** * @param {?} id * @param {?} propertyToChange * @param {?} fn * @return {?} */ function (id, propertyToChange, fn) { /** @type {?} */ var row = this.data.find(function (d) { return d['id'] === id; }); row[propertyToChange] = fn(row[propertyToChange]); return of(row); }; /** * @param {?} id * @return {?} */ FTableLocalService.prototype.delete = /** * @param {?} id * @return {?} */ function (id) { // cant modify JSON files frontend /** @type {?} */ var row = this.data.find(function (d) { return d['id'] === id; }); return of(row); }; /** * @param {?} table * @return {?} */ FTableLocalService.prototype.getData = /** * @param {?} table * @return {?} */ function (table) { /** @type {?} */ var data = this.data; var _loop_1 = function (i) { if (table.columns[i].type === 'checkbox') { table.columns[i].filterData = Array.from(new Set(data.map(function (x) { return x[table.columns[i].name]; }))); } }; for (var i = 0; i < table.columns.length; i++) { _loop_1(i); } /** @type {?} */ var totalRows = data.length; // Generic Search if (table.dataModifier.search.value) { table.dataModifier.currentPage = 1; if (table.columns.length > 0) { /** @type {?} */ var temp = []; var _loop_2 = function (i) { if (table.columns[i].name.length > 0) { temp = temp.concat(data.filter(function (x) { return String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) !== -1; })); data = data.filter(function (x) { return String(x[table.columns[i].name]).indexOf(table.dataModifier.search.value) === -1; }); } }; for (var i = 0; i < table.columns.length; i++) { _loop_2(i); } data = temp; } } if (table.dataModifier.filters.length > 0) { for (var 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 {?} */ var sortBy = void 0; var _loop_3 = function (i) { /** @type {?} */ var 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'); } } }; for (var i = 0; i < table.dataModifier.orders.length; i++) { _loop_3(i); } 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 = function () { return [ { type: HttpClient } ]; }; return FTableLocalService; }()); export { FTableLocalService }; 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}"]}