ftable
Version:
Angular 6/7 Tables
179 lines • 13.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { FSearch, FOrder, FFilter } from './ftable.model';
import { ViewChildren } from '@angular/core';
import { QueryList } from '@angular/core';
import { FFilterComponent } from './ffilter/ffilter.component';
var FTableComponent = /** @class */ (function () {
function FTableComponent(_ftableService) {
this._ftableService = _ftableService;
this.page = [];
this.filterResetCount = 0;
}
/**
* @return {?}
*/
FTableComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.refreshPage();
};
/**
* @param {?} changes
* @return {?}
*/
FTableComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.url) {
this.refreshPage();
}
};
/**
* @param {?} pageSizeIndex
* @return {?}
*/
FTableComponent.prototype.onPageOptionChange = /**
* @param {?} pageSizeIndex
* @return {?}
*/
function (pageSizeIndex) {
this.table.pageSizeIndex = pageSizeIndex;
this.table.dataModifier.pageSize = this.table.pageSizes[pageSizeIndex];
this.refreshPage();
};
/**
* @param {?} pageNumber
* @return {?}
*/
FTableComponent.prototype.onPagingChange = /**
* @param {?} pageNumber
* @return {?}
*/
function (pageNumber) {
this.table.dataModifier.currentPage = pageNumber;
this.refreshPage();
};
/**
* @param {?} columnName
* @param {?} event
* @return {?}
*/
FTableComponent.prototype.sortOrder = /**
* @param {?} columnName
* @param {?} event
* @return {?}
*/
function (columnName, event) {
this.table.dataModifier.orders = this.table.dataModifier.orders.filter(function (x) { return x.columnName !== columnName; });
if (event.state !== '') {
this.table.dataModifier.orders.push(new FOrder(columnName, event.state));
}
this.refreshPage();
};
/**
* @param {?} event
* @return {?}
*/
FTableComponent.prototype.filter = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.table.dataModifier.filters = this.table.dataModifier.filters.filter(function (x) { return x.columnName !== event.columnName; });
this.table.dataModifier.filters.push(new FFilter(event.columnName, event.type, event.apply));
// If reset count all filter resets and emit one reset event
if (event.apply == null) {
if (++this.filterResetCount == this.table.dataModifier.filters.length) {
this.filterResetCount = 0;
this.refreshPage();
}
}
else {
this.refreshPage();
}
};
/**
* @param {?} event
* @return {?}
*/
FTableComponent.prototype.search = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.table.dataModifier.search = new FSearch(event.searchString);
this.refreshPage();
};
/**
* @return {?}
*/
FTableComponent.prototype.refreshPage = /**
* @return {?}
*/
function () {
var _this = this;
this._ftableService.getData(this.table)
.subscribe(function (result) {
_this.table.result = result;
}, function (error) {
console.log("Error", error);
});
};
/**
* @param {?} idValue
* @param {?} propertyToChange
* @param {?} fn
* @return {?}
*/
FTableComponent.prototype.changeValue = /**
* @param {?} idValue
* @param {?} propertyToChange
* @param {?} fn
* @return {?}
*/
function (idValue, propertyToChange, fn) {
var _this = this;
this._ftableService.setData(idValue, propertyToChange, fn)
.subscribe(function (result) {
_this.refreshPage();
}, function (error) {
console.log("Error", error);
});
};
/**
* @return {?}
*/
FTableComponent.prototype.resetFilters = /**
* @return {?}
*/
function () {
this.filterChildren.forEach(function (x) { return x.reset(); });
};
FTableComponent.propDecorators = {
filterChildren: [{ type: ViewChildren, args: [FFilterComponent,] }]
};
return FTableComponent;
}());
export { FTableComponent };
if (false) {
/** @type {?} */
FTableComponent.prototype.filterChildren;
/** @type {?} */
FTableComponent.prototype.table;
/** @type {?} */
FTableComponent.prototype.page;
/**
* @type {?}
* @private
*/
FTableComponent.prototype.filterResetCount;
/** @type {?} */
FTableComponent.prototype._ftableService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ftable.component.js","sourceRoot":"ng://ftable/","sources":["lib/ftable.component.ts"],"names":[],"mappings":";;;;AACA,OAAO,EAAoB,OAAO,EAAE,MAAM,EAAE,OAAO,EAAG,MAAM,gBAAgB,CAAC;AAK7E,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAE/D;IAQI,yBAAmB,cAAiC;QAAjC,mBAAc,GAAd,cAAc,CAAmB;QAH7C,SAAI,GAAG,EAAE,CAAC;QAmCT,qBAAgB,GAAU,CAAC,CAAC;IA/BpC,CAAC;;;;IAED,kCAAQ;;;IAAR;QACI,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;;IAED,qCAAW;;;;IAAX,UAAY,OAAO;QACf,IAAI,OAAO,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;IACL,CAAC;;;;;IAED,4CAAkB;;;;IAAlB,UAAmB,aAAqB;QACpC,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,aAAa,CAAC;QACzC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACvE,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;;IAED,wCAAc;;;;IAAd,UAAe,UAAkB;QAC7B,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,GAAG,UAAU,CAAC;QACjD,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;;;IAED,mCAAS;;;;;IAAT,UAAU,UAAiB,EAAE,KAAK;QAC9B,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,GAAI,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,KAAK,UAAU,EAA3B,CAA2B,CAAC,CAAC;QAC1G,IAAI,KAAK,CAAC,KAAK,KAAK,EAAE,EAAE;YACpB,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,MAAM,CAAC,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;SAC5E;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;;IAGD,gCAAM;;;;IAAN,UAAO,KAAK;QACR,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU,EAAjC,CAAiC,CAAC,CAAC;QACjH,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,UAAU,EAAC,KAAK,CAAC,IAAI,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3F,4DAA4D;QAC5D,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,EAAC;YACpB,IAAG,EAAE,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,MAAM,EAAC;gBACnE,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;gBAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;aACtB;SACF;aAAI;YACF,IAAI,CAAC,WAAW,EAAE,CAAC;SACrB;IACL,CAAC;;;;;IAED,gCAAM;;;;IAAN,UAAO,KAAK;QACR,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACjE,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;;;;IAED,qCAAW;;;IAAX;QAAA,iBASC;QARI,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;aACvC,SAAS,CACN,UAAC,MAAM;YACF,KAAI,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QAChC,CAAC,EAAE,UAAA,KAAK;YACN,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;IAEX,CAAC;;;;;;;IAED,qCAAW;;;;;;IAAX,UAAY,OAAW,EAAC,gBAAwB,EAAC,EAAO;QAAxD,iBASC;QARG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,OAAO,EAAC,gBAAgB,EAAC,EAAE,CAAC;aACvD,SAAS,CACN,UAAC,MAAM;YACH,KAAI,CAAC,WAAW,EAAE,CAAC;QACvB,CAAC,EAAE,UAAA,KAAK;YACN,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;IAEX,CAAC;;;;IAEM,sCAAY;;;IAAnB;QACI,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,KAAK,EAAE,EAAT,CAAS,CAAC,CAAC;IAChD,CAAC;;iCAlFA,YAAY,SAAC,gBAAgB;;IAoFlC,sBAAC;CAAA,AAtFD,IAsFC;SAtFY,eAAe;;;IAExB,yCAA4E;;IAE5E,gCAAqB;;IACrB,+BAAiB;;;;;IAmCjB,2CAAoC;;IAhCxB,yCAAwC","sourcesContent":["import { FTableBaseService } from './service/ftablebase.service';\r\nimport {  FTable, FColumn, FSearch, FOrder, FFilter  } from './ftable.model';\r\nimport { OnChanges } from '@angular/core';\r\nimport { OnInit } from '@angular/core';\r\n\r\n\r\nimport { ViewChildren } from '@angular/core';\r\nimport { QueryList } from '@angular/core';\r\nimport { FFilterComponent } from './ffilter/ffilter.component';\r\n\r\nexport class FTableComponent implements OnChanges, OnInit {\r\n\r\n    @ViewChildren(FFilterComponent) filterChildren: QueryList<FFilterComponent>;\r\n\r\n    public table: FTable;\r\n    public page = [];\r\n\r\n\r\n    constructor(public _ftableService: FTableBaseService) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.refreshPage();\r\n    }\r\n\r\n    ngOnChanges(changes) {\r\n        if (changes.url) {\r\n            this.refreshPage();\r\n        }\r\n    }\r\n\r\n    onPageOptionChange(pageSizeIndex: number) {\r\n        this.table.pageSizeIndex = pageSizeIndex;\r\n        this.table.dataModifier.pageSize = this.table.pageSizes[pageSizeIndex];\r\n        this.refreshPage();\r\n    }\r\n\r\n    onPagingChange(pageNumber: number) {\r\n        this.table.dataModifier.currentPage = pageNumber;\r\n        this.refreshPage();\r\n    }\r\n\r\n    sortOrder(columnName:string, event) {\r\n        this.table.dataModifier.orders =  this.table.dataModifier.orders.filter(x => x.columnName !== columnName);\r\n        if (event.state !== '') {\r\n            this.table.dataModifier.orders.push(new FOrder(columnName, event.state));\r\n        }\r\n        this.refreshPage();\r\n    }\r\n\r\n    private filterResetCount:number = 0;\r\n    filter(event) {\r\n        this.table.dataModifier.filters = this.table.dataModifier.filters.filter(x => x.columnName !== event.columnName);\r\n        this.table.dataModifier.filters.push(new FFilter(event.columnName,event.type,event.apply));\r\n        // If reset count all filter resets and emit one reset event\r\n        if (event.apply == null){\r\n            if(++this.filterResetCount == this.table.dataModifier.filters.length){\r\n              this.filterResetCount = 0;\r\n              this.refreshPage();\r\n          }\r\n        }else{\r\n           this.refreshPage();\r\n        }\r\n    }\r\n\r\n    search(event) {\r\n        this.table.dataModifier.search = new FSearch(event.searchString);\r\n        this.refreshPage();\r\n    }\r\n\r\n    refreshPage(){\r\n         this._ftableService.getData(this.table)\r\n        .subscribe(\r\n            (result) => {\r\n                 this.table.result = result;\r\n            }, error => {\r\n              console.log(\"Error\", error);\r\n            });\r\n          \r\n    }\r\n\r\n    changeValue(idValue:any,propertyToChange: string,fn: any){\r\n        this._ftableService.setData(idValue,propertyToChange,fn)\r\n        .subscribe(\r\n            (result) => {\r\n                this.refreshPage();\r\n            }, error => {\r\n              console.log(\"Error\", error);\r\n            });\r\n       \r\n    }\r\n    \r\n    public resetFilters() {\r\n        this.filterChildren.forEach(x => x.reset());\r\n    }\r\n\r\n}\r\n"]}