nr-grid
Version:
NR-Grid is basic a datagrid helper that uses Bootstrap and NgbBootstrap and developed for Angular applications.
436 lines • 59.4 kB
JavaScript
import { __decorate } from "tslib";
import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';
import * as _ from 'lodash';
import { Subject } from 'rxjs';
import { debounceTime } from 'rxjs/operators';
import { NgbDate, NgbModal } from '@ng-bootstrap/ng-bootstrap';
import { NRGridColumnType } from './model/column/nr-grid-column-type';
import { FilterType } from './model/filter/filter-type';
import format from 'date-fns/format';
var NRGridComponent = /** @class */ (function () {
function NRGridComponent(modalService, cdr) {
var _this = this;
this.modalService = modalService;
this.cdr = cdr;
this.onPageChanged = new EventEmitter();
this.onEditClicked = new EventEmitter();
this.onDeleteClicked = new EventEmitter();
this.onFilterChanged = new EventEmitter();
this.onOrderChanged = new EventEmitter();
this.onRowClicked = new EventEmitter();
this.onRowValueChanged = new EventEmitter();
this.onCellLinkClicked = new EventEmitter();
this.onLimitChanged = new EventEmitter();
this.onCustomButtonClicked = new EventEmitter();
this.editingRows = {};
this.limitChangeOptions = {
searchable: false,
valueMember: 'id',
displayMember: 'text',
hideLabel: true
};
this.pages = [
{ id: 10, text: '10' },
{ id: 25, text: '25' },
{ id: 50, text: '50' },
{ id: 100, text: '100' },
];
this.ranges = {};
this.filterChanged = new Subject();
this.rowFilterChange = new EventEmitter();
this.dataLoaded = new EventEmitter();
this.order = {};
this.typeheads = [];
this._rangeValue = '';
this.limit = 10;
this.filterChanged.pipe(debounceTime(500)).subscribe(function (val) {
if (_this.go.dataSource) {
_this.go.dataSource.reload();
}
else {
_this.onFilterChanged.emit(_this.rowFilter);
}
});
}
Object.defineProperty(NRGridComponent.prototype, "rowFilter", {
get: function () {
return this._rowFilter;
},
set: function (value) {
this.changePage(1);
this._rowFilter = value;
this.rowFilterChange.emit(this._rowFilter);
},
enumerable: true,
configurable: true
});
NRGridComponent.prototype.changePage = function (page) {
if (this.options) {
this.options.page = page;
}
};
NRGridComponent.prototype.filteredColumns = function () {
var f = _.filter(this.go.columns, function (x) {
return !x.denied;
});
return _.filter(f, function (x) {
return !x.hide;
});
};
NRGridComponent.prototype.dataLoad = function (go) {
var _this = this;
go.loading = true;
if (go.dataSource.usePromise) {
go.dataSource.loader(go.dataSource.parent, this.rowFilter)
.then(function (r) {
go.data = r.data;
go.rowCount = r.rowCount;
go.loading = false;
_this.dataLoaded.emit(true);
if (r.summary) {
go.summary = r.summary;
}
})
.catch(function (e) {
go.loading = false;
console.log('qr-grid-data-load-error', e);
});
}
else {
go.dataSource.loader(this.go.dataSource.parent, this.rowFilter).subscribe(function (r) {
go.data = r.data;
go.rowCount = r.rowCount;
go.loading = false;
_this.dataLoaded.emit(true);
if (r.summary) {
go.summary = r.summary;
}
}, function (err) {
go.loading = false;
console.log('qr-grid-data-load-error', err);
});
}
};
NRGridComponent.prototype.ngOnInit = function () {
var _this = this;
if (!this.rowFilter) {
this.rowFilter = {};
}
if (this.options && !this.options.limit) {
this.options.limit = 10;
}
if (this.options && !this.options.loading) {
this.options.loading = true;
}
if (this.options && this.options.pager === undefined) {
this.options.pager = true;
}
this.go = this.options;
if (!this.go.data) {
this.go.data = [];
}
if (!this.go.page) {
this.go.page = 1;
}
if (!this.go.limit) {
this.go.limit = 10;
}
if (!this.go.rowCount) {
this.go.rowCount = 0;
}
if (!this.go.bootstrapTableClass) {
this.go.bootstrapTableClass = 'table-bordered';
}
this.columns = this.filteredColumns();
this.loadDropdownData();
if (this.go.dataSource) {
this.go.dataSource.reload = function () {
_this.editingRows = {};
return _this.dataLoad(_this.go);
};
if (!this.go.dataSource.manualLoading) {
this.go.dataSource.reload();
}
else {
this.go.loading = false;
}
}
};
NRGridComponent.prototype.loadDropdownData = function () {
var my = this;
_.each(this.go.columns, function (x) {
if (x.dropdownDataService) {
my.loadLookupData(x);
}
});
};
NRGridComponent.prototype.filterChange = function () {
this.changePage(1);
this.filterChanged.next(this.rowFilter);
this.loadDropdownData();
};
NRGridComponent.prototype.pageChange = function (val) {
if (this.go.dataSource) {
this.go.page = val;
this.go.dataSource.reload();
}
this.onPageChanged.emit(val);
};
NRGridComponent.prototype.editClicked = function (rowData) {
this.onEditClicked.emit(_.clone(rowData));
};
NRGridComponent.prototype.checkEditButtonOption = function (rowData) {
if (!this.go.actionButtonsOptions) {
return true;
}
else if (!this.go.actionButtonsOptions.edit) {
return false;
}
if (typeof this.go.actionButtonsOptions.edit == 'boolean') {
return this.go.actionButtonsOptions.edit;
}
else {
return this.go.actionButtonsOptions.edit(rowData);
}
};
NRGridComponent.prototype.checkDeleteButtonOption = function (rowData) {
if (!this.go.actionButtonsOptions) {
return true;
}
else if (!this.go.actionButtonsOptions.delete) {
return false;
}
if (typeof this.go.actionButtonsOptions.delete == 'boolean') {
return this.go.actionButtonsOptions.delete;
}
else {
return this.go.actionButtonsOptions.delete(rowData);
}
};
NRGridComponent.prototype.deleteClicked = function (rowData) {
this.activeDeleteModal = this.modalService.open(this.deleteModal, { centered: true });
this.deleteData = rowData;
};
NRGridComponent.prototype.submitDelete = function () {
this.onDeleteClicked.emit(this.deleteData);
this.activeDeleteModal.close();
};
NRGridComponent.prototype.linkClicked = function (data) {
this.onCellLinkClicked.emit(data);
};
NRGridComponent.prototype.isDefaultCell = function (t) {
return !t || (t == NRGridColumnType.default || t == NRGridColumnType.inlineEditor);
};
NRGridComponent.prototype.isLinkCell = function (t) {
return t === NRGridColumnType.link;
};
NRGridComponent.prototype.toggleOrder = function (column) {
var columnKey = column.orderKey ? column.orderKey : column.name;
if (this.order.column === columnKey) {
this.order.desc = !this.order.desc;
}
else {
this.order.desc = false;
}
this.order.column = columnKey;
this.onOrderChanged.emit(this.order);
};
NRGridComponent.prototype.rowValueChanged = function (e) {
this.onRowValueChanged.emit(e);
};
NRGridComponent.prototype.rowClicked = function (rowData) {
if (this.go.rowClickAction && this.go.rowClickAction.enable) {
this.onRowClicked.emit(rowData);
}
};
NRGridComponent.prototype.isFilterDefault = function (val) {
return val === FilterType.default;
};
NRGridComponent.prototype.isFilterDateRange = function (val) {
return val === FilterType.dateRange;
};
NRGridComponent.prototype.isFilterYesNo = function (val) {
return val == FilterType.yesNoRadio;
};
NRGridComponent.prototype.isFilterTypehead = function (val) {
return val == FilterType.typeHead;
};
NRGridComponent.prototype.isFilterDropdown = function (c) {
return c.filterType == FilterType.dropdown;
};
NRGridComponent.prototype.isFilterNumericRange = function (val) {
return val == FilterType.numericRange;
};
NRGridComponent.prototype.selectTypeheadItem = function ($event, key) {
this.rowFilter[key] = $event.item;
this.filterChange();
};
NRGridComponent.prototype.onDateSelection = function (date, filterKey) {
if (!this.fromDate && !this.toDate) {
this.fromDate = date;
}
else if (this.fromDate && !this.toDate && date.after(this.fromDate)) {
this.toDate = date;
}
else {
this.toDate = null;
this.fromDate = date;
}
if (this.fromDate && this.toDate) {
var bs = this.fromDate;
var be = this.toDate;
var s = new Date(bs.year, bs.month - 1, bs.day);
var e = new Date(be.year, be.month - 1, be.day);
this._rangeValue = format(s, 'dd/MM/yyyy') + ' - ' + format(e, 'dd/MM/yyyy');
this.rangePicker.toggle();
this.rowFilter[filterKey] = s.toISOString() + ',' + e.toISOString();
this.filterChange();
}
};
NRGridComponent.prototype.rangeValue = function () {
return this._rangeValue;
};
NRGridComponent.prototype.isHovered = function (date) {
return this.fromDate && !this.toDate && this.hoveredDate && date.after(this.fromDate) && date.before(this.hoveredDate);
};
NRGridComponent.prototype.isInside = function (date) {
return date.after(this.fromDate) && date.before(this.toDate);
};
NRGridComponent.prototype.isRange = function (date) {
return date.equals(this.fromDate) || date.equals(this.toDate) || this.isInside(date) || this.isHovered(date);
};
NRGridComponent.prototype.getFilterKey = function (c) {
return c.filterKey ? c.filterKey : c.name;
};
NRGridComponent.prototype.rangeChanged = function (c) {
var key = this.getFilterKey(c);
var startKey = key + '___start';
var endKey = key + '___end';
var start = this.ranges[startKey];
var end = this.ranges[endKey];
this.rowFilter[key] = (start ? start : '') + '___' + (end ? end : '');
this.filterChange();
};
NRGridComponent.prototype.limitChanged = function (limit) {
this.limit = Number(limit.value ? limit.value : limit);
if (this.options.dataSource) {
this.options.dataSource.reload();
}
this.onLimitChanged.emit(this.limit);
};
NRGridComponent.prototype.loadLookupData = function (c) {
if (!c.dropdownData) {
c.dropdownDataService.subscribe(function (result) {
c.dropdownData = _.map(result.data, function (x) {
return {
id: x.id,
text: x.name
};
});
});
}
};
NRGridComponent.prototype.customButtonClick = function (button, row) {
this.onCustomButtonClicked.emit({
button: button,
data: row
});
};
NRGridComponent.prototype.inlineEditorOn = function (cr, rowIndex, rowValue) {
if (cr.type == NRGridColumnType.inlineEditor) {
this.editingRows['row-' + rowIndex + '-col-' + cr.name] = {
firstValue: rowValue[cr.name]
};
this.cdr.detectChanges();
var e = document.getElementById('row-' + rowIndex + '-col-' + cr.name);
if (e) {
e.focus();
}
}
};
NRGridComponent.prototype.inlineEditorOff = function (cr, rowIndex, rowValue, toggleEvent, revert) {
if (rowValue === void 0) { rowValue = undefined; }
if (toggleEvent === void 0) { toggleEvent = false; }
if (revert === void 0) { revert = false; }
if (revert) {
rowValue[cr.name] = this.editingRows['row-' + rowIndex + '-col-' + cr.name].firstValue;
}
this.editingRows['row-' + rowIndex + '-col-' + cr.name] = undefined;
if (!revert && toggleEvent) {
this.rowValueChanged({
column: cr,
row: rowValue
});
}
};
NRGridComponent.ctorParameters = function () { return [
{ type: NgbModal },
{ type: ChangeDetectorRef }
]; };
__decorate([
Input()
], NRGridComponent.prototype, "options", void 0);
__decorate([
Input()
], NRGridComponent.prototype, "loading", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onPageChanged", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onEditClicked", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onDeleteClicked", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onFilterChanged", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onOrderChanged", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onRowClicked", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onRowValueChanged", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onCellLinkClicked", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onLimitChanged", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "onCustomButtonClicked", void 0);
__decorate([
ViewChild('deleteModal', { static: false })
], NRGridComponent.prototype, "deleteModal", void 0);
__decorate([
ViewChild('rangePicker', { static: false })
], NRGridComponent.prototype, "rangePicker", void 0);
__decorate([
Input()
], NRGridComponent.prototype, "columnHeaderTemplate", void 0);
__decorate([
Input()
], NRGridComponent.prototype, "footerTemplate", void 0);
__decorate([
Input()
], NRGridComponent.prototype, "rowFilter", null);
__decorate([
Output()
], NRGridComponent.prototype, "rowFilterChange", void 0);
__decorate([
Output()
], NRGridComponent.prototype, "dataLoaded", void 0);
NRGridComponent = __decorate([
Component({
selector: 'nr-grid',
template: "<div class=\"nr-grid\">\n <div class=\"table-responsive\">\n <table class=\"table {{options.bootstrapTableClass}} mb-0\">\n <thead>\n <tr>\n <th *ngFor=\"let c of columns\" class=\"nr-order-trigger\" (click)=\"toggleOrder(c)\"\n [ngClass]=\"{'text-right': c.alignment == 'right' }\"\n [ngStyle]=\"{'width': c.width != undefined ? c.width : 'auto' }\">\n\n <ng-container *ngTemplateOutlet=\"columnHeaderTemplate; context: {column: c}\">\n\n </ng-container>\n <ng-container *ngIf=\"!columnHeaderTemplate\">\n {{c.title}}\n </ng-container>\n <span class=\"nr-grid-orderer\"\n *ngIf=\"order.column === (c.orderKey != null ? c.orderKey : c.name)\">\n <i *ngIf=\"!order.desc\" class=\"fa fa-arrow-up\"></i>\n <i *ngIf=\"order.desc\" class=\"fa fa-arrow-down\"></i>\n </span>\n </th>\n <th *ngIf=\"go.actionButtons\"\n [ngStyle]=\"{'width': (90 + ((go.buttons ? go.buttons.length : 0) * 25)) + 'px' }\"></th>\n </tr>\n <tr class=\"filter-row\" *ngIf=\"go.filterRowEnabled\">\n <td *ngFor=\"let c of columns\">\n <ng-container *ngIf=\"!c.filterDisable\">\n <input *ngIf=\"!c.filterType || isFilterDefault(c.filterType)\" type=\"text\" placeholder=\"Filter\"\n class=\"filter-control\" [(ngModel)]=\"rowFilter[getFilterKey(c)]\"\n (ngModelChange)=\"filterChange()\">\n <input *ngIf=\"isFilterDateRange(c.filterType)\" type=\"text\" class=\"btn-light-disable\"\n ngbDatepicker\n #rangePicker=\"ngbDatepicker\"\n (dateSelect)=\"onDateSelection($event, getFilterKey(c))\"\n [dayTemplate]=\"dayTemplate\"\n [displayMonths]=\"2\" outsideDays=\"visible\" (focus)=\"rangePicker.toggle()\"\n [autoClose]=\"false\"\n placeholder=\"Filter\"\n [value]=\"rangeValue()\"\n class=\"filter-control\">\n <div *ngIf=\"isFilterNumericRange(c.filterType)\" class=\"range-selector\">\n <input type=\"text\" class=\"filter-control\" placeholder=\"Grather\"\n [(ngModel)]=\"ranges[getFilterKey(c) + '___start']\" (ngModelChange)=\"rangeChanged(c)\">\n <input type=\"text\" class=\"filter-control\" placeholder=\"Lower\"\n [(ngModel)]=\"ranges[getFilterKey(c) + '___end']\" (ngModelChange)=\"rangeChanged(c)\">\n </div>\n\n <nr-select *ngIf=\"isFilterDropdown(c)\" [(value)]=\"rowFilter[getFilterKey(c)]\" [options]=\"c.selectOptions\"\n label=\"Select\" (valueChange)=\"filterChange()\"></nr-select>\n <div *ngIf=\"isFilterYesNo(c.filterType)\" class=\"btn-group btn-group-toggle\" ngbRadioGroup\n name=\"radioBasic\"\n [(ngModel)]=\"rowFilter[getFilterKey(c)]\" (ngModelChange)=\"filterChange()\">\n <label ngbButtonLabel class=\"btn-primary btn-xs\">\n <input ngbButton type=\"radio\" [value]=\"true\"> Yes\n </label>\n <label ngbButtonLabel class=\"btn-primary btn-xs\">\n <input ngbButton type=\"radio\" [value]=\"false\"> No\n </label>\n </div>\n </ng-container>\n </td>\n <td *ngIf=\"go.actionButtons\"></td>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let r of go.data; let rowIndex=index;\"\n class=\"data-row\"\n [ngClass]=\"{'nr-row-clickable': go.rowClickAction && go.rowClickAction.enable}\"\n (click)=\"rowClicked(r)\">\n <td *ngFor=\"let cr of columns\"\n [ngClass]=\"{'text-right': cr.alignment == 'right', 'padding-none': editingRows['row-' + rowIndex + '-col-' + cr.name]}\">\n\n <div *ngIf=\"cr.formatter && !isLinkCell(cr.type)\">\n {{r[cr.name]|valueFormat: cr.formatter}}\n </div>\n\n <div class=\"default-view\"\n *ngIf=\"!cr.formatter && isDefaultCell(cr.type) && !editingRows['row-' + rowIndex + '-col-' + cr.name]\"\n [innerHTML]=\"cr.format ? cr.format({row: r, value: r[cr.name], parent: go.parent }) : r[cr.name]\"\n (click)=\"inlineEditorOn(cr, rowIndex, r)\"></div>\n\n <div *ngIf=\"isLinkCell(cr.type)\">\n <a href=\"javascript:void(0)\" (click)=\"linkClicked({row: r, column: cr})\"\n class=\"{{cr.link && cr.link.classes ? cr.link.classes : ''}}\"\n [ngbTooltip]=\"cr.link && cr.link.tooltip ? cr.link.tooltip : ''\">\n <i *ngIf=\"cr.link && cr.link.icon\" class=\"{{cr.link.icon}}\"></i>\n\n <span *ngIf=\"!cr.formatter\"\n [innerHTML]=\"cr.format ? cr.format({row: r, value: r[cr.name], parent: go.parent}) : r[cr.name]\"></span>\n <span *ngIf=\"cr.formatter\">{{r[cr.name]|valueFormat: cr.formatter}}</span>\n </a>\n </div>\n <div *ngIf=\"editingRows['row-' + rowIndex + '-col-' + cr.name]\">\n <div class=\"nr-inline-editor\">\n <input [id]=\"'row-' + rowIndex + '-col-' + cr.name\" type=\"text\" [(ngModel)]=\"r[cr.name]\"/>\n <div class=\"nr-inline-editor-buttons\">\n <button class=\"btn btn-sm btn-primary\" type=\"button\" (click)=\"inlineEditorOff(cr, rowIndex, r, true)\">\n Save\n </button>\n <button class=\"btn btn-sm btn-secondary\" type=\"button\"\n (click)=\"inlineEditorOff(cr, rowIndex, r, false, true)\">Cancel\n </button>\n </div>\n </div>\n </div>\n </td>\n <td class=\"action-buttons-container\" *ngIf=\"go.actionButtons\">\n <ng-container *ngFor=\"let b of go.buttons\">\n <a href=\"javascript:void(0);\" (click)=\"customButtonClick(b, r)\" ngbTooltip=\"{{b.tooltip}}\"\n *ngIf=\"!b.visible || (b.visible && b.visible(r))\">\n <i class=\"{{b.icon}}\"></i>\n </a>\n </ng-container>\n <a href=\"javascript:void(0);\" (click)=\"editClicked(r)\" ngbTooltip=\"Edit\"\n *ngIf=\"!go.actionButtonsOptions || checkEditButtonOption(r)\">\n <i class=\"fa fa-pencil\"></i>\n </a>\n <a href=\"javascript:void(0);\" (click)=\"deleteClicked(r)\" ngbTooltip=\"Delete\"\n *ngIf=\"!go.actionButtonsOptions || checkDeleteButtonOption(r)\">\n <i class=\"fa fa-trash\"></i>\n </a>\n </td>\n </tr>\n <tr *ngIf=\"go.data == undefined || go.data.length == 0\">\n <td [colSpan]=\"columns.length + (go.actionButtons ? 1 : 0)\">\n <div style=\"padding: 20px; text-align: center\">\n No data\n </div>\n </td>\n </tr>\n </tbody>\n <tfoot *ngIf=\"go.summary && !go.hideSummary\">\n <tr>\n <th *ngFor=\"let cr of columns\" [ngClass]=\"{'text-right': cr.alignment == 'right' }\">\n <ng-container *ngIf=\"!cr.hideFromSummary\">\n <div *ngIf=\"cr.formatter\">\n {{go.summary[cr.name]|valueFormat: cr.formatter}}\n </div>\n\n <div *ngIf=\"isDefaultCell(cr.type) && (!cr.formatter)\"\n [innerHTML]=\"cr.format ? cr.format({row: go.summary, value: go.summary[cr.name], parent: go.parent}) : go.summary[cr.name]\"></div>\n\n <div *ngIf=\"isLinkCell(cr.type) && (!cr.formatter)\">\n <a href=\"javascript:void(0)\" (click)=\"linkClicked({row: go.summary, column: cr})\"\n class=\"{{cr.link.classes ? cr.link.classes : ''}}\"\n [ngbTooltip]=\"cr.link && cr.link.tooltip ? cr.link.tooltip : ''\">\n <i *ngIf=\"cr.link.icon\" class=\"{{cr.link.icon}}\"></i>\n <span\n [innerHTML]=\"cr.format ? cr.format({row: go.summary, value: go.summary[cr.name], parent: go.parent}) : go.summary[cr.name]\"></span>\n </a>\n </div>\n </ng-container>\n </th>\n </tr>\n </tfoot>\n </table>\n\n </div>\n <ng-container *ngTemplateOutlet=\"footerTemplate;\">\n\n </ng-container>\n <div class=\"nr-grid-footer row\" *ngIf=\"go.pager\">\n <div class=\"col-md-12\">\n <ngb-pagination class=\"float-right\" [collectionSize]=\"go.rowCount\" [(page)]=\"go.page\" [maxSize]=\"10\"\n [pageSize]=\"go.limit\" (pageChange)=\"pageChange($event)\"></ngb-pagination>\n <div class=\"float-right limit-selector\" style=\"min-width: 150px; width: 150px\">\n <nr-select class=\"float-right\" [data]=\"pages\" [(value)]=\"go.limit\" label=\"Limit\" [options]=\"limitChangeOptions\"\n (valueChange)=\"limitChanged($event)\"></nr-select>\n </div>\n </div>\n </div>\n <div class=\"clearfix\"></div>\n</div>\n<ng-template #deleteModal let-modal>\n <div class=\"modal-header\">\n <h4 class=\"modal-title\" id=\"modal-basic-title\">Delete</h4>\n <button type=\"button\" class=\"close\" aria-label=\"Close\" (click)=\"modal.dismiss('Cross click')\">\n <span aria-hidden=\"true\">×</span>\n </button>\n </div>\n <div class=\"modal-body\">\n Data will be deleted, are you sure?\n </div>\n <div class=\"modal-footer\">\n <button type=\"submit\" class=\"btn btn-success\" (click)=\"submitDelete()\">Delete</button>\n <button type=\"button\" class=\"btn btn-secondary\" (click)=\"modal.dismiss('Cross click')\">Cancel</button>\n </div>\n</ng-template>\n<ng-template #dayTemplate let-date let-focused=\"focused\">\n <span class=\"custom-day\"\n [class.focused]=\"focused\"\n [class.range]=\"isRange(date)\"\n [class.faded]=\"isHovered(date) || isInside(date)\"\n (mouseenter)=\"hoveredDate = date\"\n (mouseleave)=\"hoveredDate = null\">\n {{ date.day }}\n </span>\n</ng-template>\n"
})
], NRGridComponent);
return NRGridComponent;
}());
export { NRGridComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nr-grid.component.js","sourceRoot":"ng://nr-grid/","sources":["lib/nr-grid/nr-grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild} from '@angular/core';\nimport {NRGridButton} from './model/button/nr-grid-button';\nimport {NRGridColumn} from './model/column/nr-grid-column';\nimport * as _ from 'lodash';\nimport {NRGridOptions} from './model/options/nr-grid-options';\nimport {Subject} from 'rxjs';\nimport {debounceTime} from 'rxjs/operators';\nimport {NgbDate, NgbModal} from '@ng-bootstrap/ng-bootstrap';\nimport {NRGridColumnType} from './model/column/nr-grid-column-type';\nimport {FilterType} from './model/filter/filter-type';\nimport format from 'date-fns/format';\nimport {NRSelectOptions} from 'nr-select';\n\n@Component({\n  selector: 'nr-grid',\n  templateUrl: './nr-grid.component.html'\n})\nexport class NRGridComponent implements OnInit {\n\n  activeDeleteModal;\n\n  @Input() options: NRGridOptions;\n  @Input() loading: boolean;\n  @Output() onPageChanged = new EventEmitter<number>();\n  @Output() public onEditClicked = new EventEmitter<any>();\n  @Output() public onDeleteClicked = new EventEmitter<any>();\n  @Output() public onFilterChanged: EventEmitter<any> = new EventEmitter<any>();\n  @Output() public onOrderChanged = new EventEmitter<any>();\n  @Output() public onRowClicked = new EventEmitter<any>();\n  @Output() public onRowValueChanged = new EventEmitter<any>();\n  @Output() public onCellLinkClicked = new EventEmitter<any>();\n  @Output() public onLimitChanged = new EventEmitter<any>();\n  @Output() public onCustomButtonClicked = new EventEmitter<any>();\n\n  @ViewChild('deleteModal', {static: false}) private deleteModal;\n  @ViewChild('rangePicker', {static: false}) private rangePicker;\n\n  @Input() columnHeaderTemplate: TemplateRef<any>;\n  @Input() footerTemplate: TemplateRef<any>;\n\n  columns: NRGridColumn[];\n  editingRows: any = {};\n\n  limitChangeOptions: NRSelectOptions = {\n    searchable: false,\n    valueMember: 'id',\n    displayMember: 'text',\n    hideLabel: true\n  };\n  pages =\n    [\n      {id: 10, text: '10'},\n      {id: 25, text: '25'},\n      {id: 50, text: '50'},\n      {id: 100, text: '100'},\n    ];\n\n  go: NRGridOptions;\n\n  ranges: any = {};\n  filterChanged: Subject<any> = new Subject<any>();\n\n  _rowFilter: any;\n\n  @Input() get rowFilter() {\n    return this._rowFilter;\n  }\n\n  set rowFilter(value) {\n    this.changePage(1);\n    this._rowFilter = value;\n    this.rowFilterChange.emit(this._rowFilter);\n  }\n\n  @Output() rowFilterChange = new EventEmitter<any>();\n  @Output() dataLoaded = new EventEmitter<any>();\n\n  changePage(page) {\n    if (this.options) {\n      this.options.page = page;\n    }\n  }\n\n  order: any = {};\n  deleteData: any;\n\n  constructor(private modalService: NgbModal, private cdr: ChangeDetectorRef) {\n    this.filterChanged.pipe(debounceTime(500)).subscribe(val => {\n      if (this.go.dataSource) {\n        this.go.dataSource.reload();\n      } else {\n        this.onFilterChanged.emit(this.rowFilter);\n      }\n    });\n  }\n\n  filteredColumns(): NRGridColumn[] {\n    const f = _.filter(this.go.columns, (x) => {\n      return !x.denied;\n    });\n    return _.filter(f, (x) => {\n      return !x.hide;\n    });\n  }\n\n  private dataLoad(go: NRGridOptions) {\n    go.loading = true;\n    if (go.dataSource.usePromise) {\n      go.dataSource.loader(go.dataSource.parent, this.rowFilter)\n        .then(r => {\n          go.data = r.data;\n          go.rowCount = r.rowCount;\n          go.loading = false;\n          this.dataLoaded.emit(true);\n          if (r.summary) {\n            go.summary = r.summary;\n          }\n        })\n        .catch(e => {\n          go.loading = false;\n          console.log('qr-grid-data-load-error', e);\n        });\n    } else {\n      go.dataSource.loader(this.go.dataSource.parent, this.rowFilter).subscribe(r => {\n        go.data = r.data;\n        go.rowCount = r.rowCount;\n        go.loading = false;\n        this.dataLoaded.emit(true);\n        if (r.summary) {\n          go.summary = r.summary;\n        }\n      }, err => {\n        go.loading = false;\n        console.log('qr-grid-data-load-error', err);\n      });\n    }\n  }\n\n  ngOnInit() {\n\n    if (!this.rowFilter) {\n      this.rowFilter = {};\n    }\n\n    if (this.options && !this.options.limit) {\n      this.options.limit = 10;\n    }\n\n    if (this.options && !this.options.loading) {\n      this.options.loading = true;\n    }\n\n    if (this.options && this.options.pager === undefined) {\n      this.options.pager = true;\n    }\n\n    this.go = this.options;\n\n    if (!this.go.data) {\n      this