ftable
Version:
Angular 6/7 Tables
138 lines • 12 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';
export class FTableComponent {
/**
* @param {?} _ftableService
*/
constructor(_ftableService) {
this._ftableService = _ftableService;
this.page = [];
this.filterResetCount = 0;
}
/**
* @return {?}
*/
ngOnInit() {
this.refreshPage();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.url) {
this.refreshPage();
}
}
/**
* @param {?} pageSizeIndex
* @return {?}
*/
onPageOptionChange(pageSizeIndex) {
this.table.pageSizeIndex = pageSizeIndex;
this.table.dataModifier.pageSize = this.table.pageSizes[pageSizeIndex];
this.refreshPage();
}
/**
* @param {?} pageNumber
* @return {?}
*/
onPagingChange(pageNumber) {
this.table.dataModifier.currentPage = pageNumber;
this.refreshPage();
}
/**
* @param {?} columnName
* @param {?} event
* @return {?}
*/
sortOrder(columnName, event) {
this.table.dataModifier.orders = this.table.dataModifier.orders.filter(x => x.columnName !== columnName);
if (event.state !== '') {
this.table.dataModifier.orders.push(new FOrder(columnName, event.state));
}
this.refreshPage();
}
/**
* @param {?} event
* @return {?}
*/
filter(event) {
this.table.dataModifier.filters = this.table.dataModifier.filters.filter(x => 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 {?}
*/
search(event) {
this.table.dataModifier.search = new FSearch(event.searchString);
this.refreshPage();
}
/**
* @return {?}
*/
refreshPage() {
this._ftableService.getData(this.table)
.subscribe((result) => {
this.table.result = result;
}, error => {
console.log("Error", error);
});
}
/**
* @param {?} idValue
* @param {?} propertyToChange
* @param {?} fn
* @return {?}
*/
changeValue(idValue, propertyToChange, fn) {
this._ftableService.setData(idValue, propertyToChange, fn)
.subscribe((result) => {
this.refreshPage();
}, error => {
console.log("Error", error);
});
}
/**
* @return {?}
*/
resetFilters() {
this.filterChildren.forEach(x => x.reset());
}
}
FTableComponent.propDecorators = {
filterChildren: [{ type: ViewChildren, args: [FFilterComponent,] }]
};
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":"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","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"]}