ngx-easy-table
Version:
Angular easy table
2,523 lines (2,475 loc) • 118 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('/common'), require('@angular/core'), require('/cdk/drag-drop'), require('ngx-pagination'), require('rxjs'), require('rxjs/operators'), require('@angular/cdk/scrolling')) :
typeof define === 'function' && define.amd ? define('ngx-easy-table', ['exports', '/common', '@angular/core', '/cdk/drag-drop', 'ngx-pagination', 'rxjs', 'rxjs/operators', '@angular/cdk/scrolling'], factory) :
(global = global || self, factory(global['ngx-easy-table'] = {}, global.ng.common, global.ng.core, global.ng.cdk['drag-drop'], global.ngxPagination, global.rxjs, global.rxjs.operators, global.ng.cdk.scrolling));
}(this, function (exports, common, core, dragDrop, ngxPagination, rxjs, operators, scrolling) { 'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function() {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __rest(s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
}
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}
function __awaiter(thisArg, _arguments, P, generator) {
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
}
function __exportStar(m, exports) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
function __values(o) {
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0;
if (m) return m.call(o);
return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
}
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
function __spreadArrays() {
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
};
function __await(v) {
return this instanceof __await ? (this.v = v, this) : new __await(v);
}
function __asyncGenerator(thisArg, _arguments, generator) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
}
function __asyncDelegator(o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
}
function __asyncValues(o) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
}
function __makeTemplateObject(cooked, raw) {
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
return cooked;
};
function __importStar(mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result.default = mod;
return result;
}
function __importDefault(mod) {
return (mod && mod.__esModule) ? mod : { default: mod };
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
function Columns() { }
if (false) {
/** @type {?} */
Columns.prototype.key;
/** @type {?} */
Columns.prototype.title;
/** @type {?|undefined} */
Columns.prototype.placeholder;
/** @type {?|undefined} */
Columns.prototype.width;
/** @type {?|undefined} */
Columns.prototype.cellTemplate;
/** @type {?|undefined} */
Columns.prototype.orderEnabled;
/** @type {?|undefined} */
Columns.prototype.orderEventOnly;
/** @type {?|undefined} */
Columns.prototype.searchEnabled;
/** @type {?|undefined} */
Columns.prototype.orderBy;
/** @type {?|undefined} */
Columns.prototype.cssClass;
/** @type {?|undefined} */
Columns.prototype.pinned;
/** @type {?|undefined} */
Columns.prototype.headerActionTemplate;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
function Config() { }
if (false) {
/** @type {?} */
Config.prototype.searchEnabled;
/** @type {?} */
Config.prototype.headerEnabled;
/** @type {?} */
Config.prototype.orderEnabled;
/** @type {?|undefined} */
Config.prototype.orderEventOnly;
/** @type {?} */
Config.prototype.paginationEnabled;
/** @type {?|undefined} */
Config.prototype.exportEnabled;
/** @type {?} */
Config.prototype.clickEvent;
/** @type {?} */
Config.prototype.selectRow;
/** @type {?} */
Config.prototype.selectCol;
/** @type {?} */
Config.prototype.selectCell;
/** @type {?} */
Config.prototype.rows;
/** @type {?} */
Config.prototype.additionalActions;
/** @type {?} */
Config.prototype.serverPagination;
/** @type {?} */
Config.prototype.isLoading;
/** @type {?} */
Config.prototype.detailsTemplate;
/** @type {?} */
Config.prototype.groupRows;
/** @type {?} */
Config.prototype.paginationRangeEnabled;
/** @type {?} */
Config.prototype.collapseAllRows;
/** @type {?} */
Config.prototype.checkboxes;
/** @type {?|undefined} */
Config.prototype.radio;
/** @type {?} */
Config.prototype.resizeColumn;
/** @type {?} */
Config.prototype.fixedColumnWidth;
/** @type {?} */
Config.prototype.horizontalScroll;
/** @type {?} */
Config.prototype.draggable;
/** @type {?} */
Config.prototype.logger;
/** @type {?|undefined} */
Config.prototype.showDetailsArrow;
/** @type {?|undefined} */
Config.prototype.showContextMenu;
/** @type {?|undefined} */
Config.prototype.persistState;
/** @type {?|undefined} */
Config.prototype.paginationMaxSize;
/** @type {?|undefined} */
Config.prototype.threeWaySort;
/** @type {?|undefined} */
Config.prototype.columnReorder;
/** @type {?|undefined} */
Config.prototype.rowReorder;
/** @type {?|undefined} */
Config.prototype.infiniteScroll;
/** @type {?|undefined} */
Config.prototype.infiniteScrollThrottleTime;
/** @type {?} */
Config.prototype.tableLayout;
}
/** @enum {string} */
var STYLE = {
TINY: 'tiny',
BIG: 'big',
NORMAL: 'normal',
};
/** @enum {string} */
var THEME = {
LIGHT: 'light',
DARK: 'dark',
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @enum {string} */
var Event = {
onPagination: 'onPagination',
onOrder: 'onOrder',
onGlobalSearch: 'onGlobalSearch',
onSearch: 'onSearch',
onClick: 'onClick',
onDoubleClick: 'onDoubleClick',
onCheckboxSelect: 'onCheckboxSelect',
onRadioSelect: 'onRadioSelect',
onCheckboxToggle: 'onCheckboxToggle',
onSelectAll: 'onSelectAll',
onInfiniteScrollEnd: 'onInfiniteScrollEnd',
onColumnResizeMouseDown: 'onColumnResizeMouseDown',
onColumnResizeMouseUp: 'onColumnResizeMouseUp',
onRowDrop: 'onRowDrop',
onRowCollapsedShow: 'onRowCollapsedShow',
onRowCollapsedHide: 'onRowCollapsedHide',
onRowContextMenu: 'onRowContextMenu',
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
function Pagination() { }
if (false) {
/** @type {?} */
Pagination.prototype.limit;
/** @type {?} */
Pagination.prototype.offset;
/** @type {?} */
Pagination.prototype.count;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @enum {string} */
var API = {
rowContextMenuClicked: 'rowContextMenuClicked',
setInputValue: 'setInputValue',
toolPanelClicked: 'toolPanelClicked',
toggleRowIndex: 'toggleRowIndex',
toggleCheckbox: 'toggleCheckbox',
onGlobalSearch: 'onGlobalSearch',
setPaginationCurrentPage: 'setPaginationCurrentPage',
getPaginationCurrentPage: 'getPaginationCurrentPage',
getPaginationTotalItems: 'getPaginationTotalItems',
getNumberOfRowsPerPage: 'getNumberOfRowsPerPage',
getPaginationLastPage: 'getPaginationLastPage',
setPaginationRange: 'setPaginationRange',
setPaginationPreviousLabel: 'setPaginationPreviousLabel',
setPaginationNextLabel: 'setPaginationNextLabel',
setPaginationDisplayLimit: 'setPaginationDisplayLimit',
setTableClass: 'setTableClass',
setRowClass: 'setRowClass',
setCellClass: 'setCellClass',
setRowStyle: 'setRowStyle',
setCellStyle: 'setCellStyle',
sortBy: 'sortBy',
};
/**
* @record
*/
function RowClass() { }
if (false) {
/** @type {?} */
RowClass.prototype.row;
/** @type {?} */
RowClass.prototype.className;
}
/**
* @record
*/
function CellClass() { }
if (false) {
/** @type {?} */
CellClass.prototype.row;
/** @type {?} */
CellClass.prototype.cell;
/** @type {?} */
CellClass.prototype.className;
}
/**
* @record
*/
function RowStyle() { }
if (false) {
/** @type {?} */
RowStyle.prototype.row;
/** @type {?} */
RowStyle.prototype.attr;
/** @type {?} */
RowStyle.prototype.value;
}
/**
* @record
*/
function CellStyle() { }
if (false) {
/** @type {?} */
CellStyle.prototype.row;
/** @type {?} */
CellStyle.prototype.cell;
/** @type {?} */
CellStyle.prototype.attr;
/** @type {?} */
CellStyle.prototype.value;
}
/**
* @record
*/
function APIDefinition() { }
if (false) {
/**
* @template B
* @param {?} event
* @return {?}
*/
APIDefinition.prototype.apiEvent = function (event) { };
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/** @type {?} */
var DefaultConfig = {
searchEnabled: false,
headerEnabled: true,
orderEnabled: true,
orderEventOnly: false,
paginationEnabled: true,
exportEnabled: false,
clickEvent: true,
selectRow: false,
selectCol: false,
selectCell: false,
rows: 10,
additionalActions: false,
serverPagination: false,
isLoading: false,
detailsTemplate: false,
groupRows: false,
paginationRangeEnabled: true,
collapseAllRows: false,
checkboxes: false,
radio: false,
resizeColumn: false,
fixedColumnWidth: true,
horizontalScroll: false,
draggable: false,
logger: false,
showDetailsArrow: false,
showContextMenu: false,
persistState: false,
paginationMaxSize: 5,
threeWaySort: false,
tableLayout: {
style: STYLE.NORMAL,
theme: THEME.LIGHT,
borderless: false,
hover: true,
striped: false,
},
};
var DefaultConfigService = /** @class */ (function () {
function DefaultConfigService() {
}
DefaultConfigService.config = DefaultConfig;
DefaultConfigService.decorators = [
{ type: core.Injectable }
];
return DefaultConfigService;
}());
if (false) {
/** @type {?} */
DefaultConfigService.config;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
function PaginationRange() { }
if (false) {
/** @type {?} */
PaginationRange.prototype.page;
/** @type {?} */
PaginationRange.prototype.limit;
}
var PaginationComponent = /** @class */ (function () {
function PaginationComponent() {
this.updateRange = new core.EventEmitter();
this.ranges = [5, 10, 25, 50, 100];
this.showRange = false;
this.screenReaderPaginationLabel = 'Pagination';
this.screenReaderPageLabel = 'page';
this.screenReaderCurrentLabel = 'You are on page';
this.previousLabel = '';
this.nextLabel = '';
this.directionLinks = true;
}
/**
* @param {?} targetElement
* @return {?}
*/
PaginationComponent.prototype.onClick = /**
* @param {?} targetElement
* @return {?}
*/
function (targetElement) {
if (this.paginationRange && !this.paginationRange.nativeElement.contains(targetElement)) {
this.showRange = false;
}
};
/**
* @param {?} changes
* @return {?}
*/
PaginationComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var config = changes.config;
if (config && config.currentValue) {
this.selectedLimit = this.config.rows;
}
};
/**
* @param {?} page
* @return {?}
*/
PaginationComponent.prototype.onPageChange = /**
* @param {?} page
* @return {?}
*/
function (page) {
this.updateRange.emit({
page: page,
limit: this.selectedLimit,
});
};
/**
* @param {?} limit
* @param {?} callFromAPI
* @return {?}
*/
PaginationComponent.prototype.changeLimit = /**
* @param {?} limit
* @param {?} callFromAPI
* @return {?}
*/
function (limit, callFromAPI) {
if (!callFromAPI) {
this.showRange = !this.showRange;
}
this.selectedLimit = limit;
this.updateRange.emit({
page: 1,
limit: limit,
});
};
PaginationComponent.decorators = [
{ type: core.Component, args: [{
selector: 'pagination',
template: "<div class=\"ngx-pagination-wrapper\"\n [style.display]=\"config.paginationEnabled ? '' : 'none'\"\n [class.ngx-table__table--dark-pagination-wrapper]=\"config.tableLayout.theme === 'dark'\">\n <div class=\"ngx-pagination-steps\">\n <pagination-template\n #paginationDirective=\"paginationApi\"\n id=\"pagination-controls\"\n [id]=\"id\"\n [class.ngx-table__table--dark-pagination]=\"config.tableLayout.theme === 'dark'\"\n [maxSize]=\"config.paginationMaxSize || 5\"\n (pageChange)=\"onPageChange($event)\">\n <ul class=\"ngx-pagination\"\n role=\"navigation\"\n [attr.aria-label]=\"screenReaderPaginationLabel\"\n [class.responsive]=\"true\">\n <li class=\"pagination-previous\" [class.disabled]=\"paginationDirective.isFirstPage()\" *ngIf=\"directionLinks\">\n <a tabindex=\"0\" *ngIf=\"1 < paginationDirective.getCurrent()\" (keyup.enter)=\"paginationDirective.previous()\"\n (click)=\"paginationDirective.previous()\"\n [attr.aria-label]=\"previousLabel + ' ' + screenReaderPageLabel\">\n {{ previousLabel }} <span class=\"show-for-sr\">{{ screenReaderPageLabel }}</span>\n </a>\n <span *ngIf=\"paginationDirective.isFirstPage()\">\n {{ previousLabel }} <span class=\"show-for-sr\">{{ screenReaderPageLabel }}</span>\n </span>\n </li>\n <li class=\"small-screen\">\n {{ paginationDirective.getCurrent() }} / {{ paginationDirective.getLastPage() }}\n </li>\n <li [class.current]=\"paginationDirective.getCurrent() === page.value\"\n [class.ellipsis]=\"page.label === '...'\"\n *ngFor=\"let page of paginationDirective.pages\">\n <a tabindex=\"0\" (keyup.enter)=\"paginationDirective.setCurrent(page.value)\"\n (click)=\"paginationDirective.setCurrent(page.value)\"\n *ngIf=\"paginationDirective.getCurrent() !== page.value\">\n <span class=\"show-for-sr\">{{ screenReaderPageLabel }} </span>\n <span>{{ page.label }}</span>\n </a>\n <ng-container *ngIf=\"paginationDirective.getCurrent() === page.value\">\n <span class=\"show-for-sr\">{{ screenReaderCurrentLabel }} </span>\n <span>{{ page.label }}</span>\n </ng-container>\n </li>\n <li class=\"pagination-next\" [class.disabled]=\"paginationDirective.isLastPage()\" *ngIf=\"directionLinks\">\n <a tabindex=\"0\" *ngIf=\"!paginationDirective.isLastPage()\" (keyup.enter)=\"paginationDirective.next()\"\n (click)=\"paginationDirective.next()\"\n [attr.aria-label]=\"nextLabel + ' ' + screenReaderPageLabel\">\n {{ nextLabel }} <span class=\"show-for-sr\">{{ screenReaderPageLabel }}</span>\n </a>\n <span *ngIf=\"paginationDirective.isLastPage()\">\n {{ nextLabel }} <span class=\"show-for-sr\">{{ screenReaderPageLabel }}</span>\n </span>\n </li>\n </ul>\n </pagination-template>\n </div>\n <div class=\"ngx-pagination-range\"\n #paginationRange\n [class.ngx-table__table--dark-pagination-range]=\"config.tableLayout.theme === 'dark'\"\n *ngIf=\"config.paginationRangeEnabled\">\n <div class=\"ngx-dropdown ngx-pagination-range-dropdown\"\n id=\"rowAmount\">\n <div class=\"ngx-btn-group\">\n <div class=\"ngx-pagination-range-dropdown-button\"\n (click)=\"showRange = !showRange\">\n {{selectedLimit}} <i class=\"ngx-icon ngx-icon-arrow-down\"></i>\n </div>\n <ul class=\"ngx-menu\" *ngIf=\"showRange\">\n <li class=\"ngx-pagination-range-dropdown-button-item\"\n [class.ngx-pagination-range--selected]=\"limit === selectedLimit\"\n (click)=\"changeLimit(limit, false)\"\n *ngFor=\"let limit of ranges\">\n <span>{{limit}}</span>\n </li>\n </ul>\n </div>\n </div>\n </div>\n</div>\n",
changeDetection: core.ChangeDetectionStrategy.OnPush
}] }
];
PaginationComponent.propDecorators = {
paginationDirective: [{ type: core.ViewChild, args: ['paginationDirective', { static: true },] }],
paginationRange: [{ type: core.ViewChild, args: ['paginationRange', { static: false },] }],
pagination: [{ type: core.Input }],
config: [{ type: core.Input }],
id: [{ type: core.Input }],
updateRange: [{ type: core.Output }],
onClick: [{ type: core.HostListener, args: ['document:click', ['$event.target'],] }]
};
return PaginationComponent;
}());
if (false) {
/** @type {?} */
PaginationComponent.prototype.paginationDirective;
/** @type {?} */
PaginationComponent.prototype.paginationRange;
/** @type {?} */
PaginationComponent.prototype.pagination;
/** @type {?} */
PaginationComponent.prototype.config;
/** @type {?} */
PaginationComponent.prototype.id;
/** @type {?} */
PaginationComponent.prototype.updateRange;
/** @type {?} */
PaginationComponent.prototype.ranges;
/** @type {?} */
PaginationComponent.prototype.selectedLimit;
/** @type {?} */
PaginationComponent.prototype.showRange;
/** @type {?} */
PaginationComponent.prototype.screenReaderPaginationLabel;
/** @type {?} */
PaginationComponent.prototype.screenReaderPageLabel;
/** @type {?} */
PaginationComponent.prototype.screenReaderCurrentLabel;
/** @type {?} */
PaginationComponent.prototype.previousLabel;
/** @type {?} */
PaginationComponent.prototype.nextLabel;
/** @type {?} */
PaginationComponent.prototype.directionLinks;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var GroupRowsService = /** @class */ (function () {
function GroupRowsService() {
}
/**
* @template T
* @param {?} data
* @param {?} groupRowsBy
* @return {?}
*/
GroupRowsService.doGroupRows = /**
* @template T
* @param {?} data
* @param {?} groupRowsBy
* @return {?}
*/
function (data, groupRowsBy) {
/** @type {?} */
var grouped = [];
rxjs.from(data).pipe(operators.groupBy((/**
* @param {?} row
* @return {?}
*/
function (row) { return row[groupRowsBy]; })), operators.flatMap((/**
* @param {?} group
* @return {?}
*/
function (group) { return group.pipe(operators.reduce((/**
* @param {?} acc
* @param {?} curr
* @return {?}
*/
function (acc, curr) { return __spread(acc, [curr]); }), [])); }))).subscribe((/**
* @param {?} row
* @return {?}
*/
function (row) { return grouped.push(row); }));
return grouped;
};
GroupRowsService.decorators = [
{ type: core.Injectable }
];
return GroupRowsService;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/* tslint:disable:no-useless-cast */
var StyleService = /** @class */ (function () {
function StyleService() {
}
/**
* @param {?} val
* @return {?}
*/
StyleService.prototype.setRowClass = /**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var selector = "#table > tbody > tr:nth-child(" + val.row + ")";
/** @type {?} */
var row = (/** @type {?} */ (document.querySelector(selector)));
if (row) {
row.classList.add(val.className);
}
};
/**
* @param {?} val
* @return {?}
*/
StyleService.prototype.setCellClass = /**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var selector = "#table > tbody > tr:nth-child(" + val.row + ") > td:nth-child(" + val.cell + ")";
/** @type {?} */
var cell = (/** @type {?} */ (document.querySelector(selector)));
if (cell) {
cell.classList.add(val.className);
}
};
/**
* @param {?} val
* @return {?}
*/
StyleService.prototype.setRowStyle = /**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var selector = "#table > tbody > tr:nth-child(" + val.row + ")";
/** @type {?} */
var row = (/** @type {?} */ (document.querySelector(selector)));
if (row) {
// tslint:disable-next-line:no-string-literal
row.style[val.attr] = val.value;
}
};
/**
* @param {?} val
* @return {?}
*/
StyleService.prototype.setCellStyle = /**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var selector = "#table > tbody > tr:nth-child(" + val.row + ") > td:nth-child(" + val.cell + ")";
/** @type {?} */
var cell = (/** @type {?} */ (document.querySelector(selector)));
if (cell) {
// tslint:disable-next-line:no-string-literal
cell.style[val.attr] = val.value;
}
};
/**
* @param {?} pinned
* @param {?} column
* @return {?}
*/
StyleService.prototype.pinnedWidth = /**
* @param {?} pinned
* @param {?} column
* @return {?}
*/
function (pinned, column) {
if (pinned) {
return 150 * column + 'px';
}
};
StyleService.decorators = [
{ type: core.Injectable }
];
return StyleService;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
function RowContextMenuPosition() { }
if (false) {
/** @type {?} */
RowContextMenuPosition.prototype.top;
/** @type {?} */
RowContextMenuPosition.prototype.left;
/** @type {?} */
RowContextMenuPosition.prototype.value;
}
var BaseComponent = /** @class */ (function () {
function BaseComponent(cdr, scrollDispatcher, styleService) {
var _this = this;
this.cdr = cdr;
this.scrollDispatcher = scrollDispatcher;
this.styleService = styleService;
this.unsubscribe = new rxjs.Subject();
this.filterCount = -1;
this.filteredCountSubject = new rxjs.Subject();
this.tableClass = null;
this.grouped = [];
this.isSelected = false;
this.page = 1;
this.count = 0;
this.sortState = new Map();
this.sortKey = null;
this.rowContextMenuPosition = {
top: null,
left: null,
value: null,
};
this.sortBy = {
key: '',
order: 'asc',
};
this.selectedDetailsTemplateRowId = new Set();
this.selectedCheckboxes = new Set();
this.loadingHeight = '30px';
this.id = 'table';
this.event = new core.EventEmitter();
this.subscription = this.filteredCountSubject
.pipe(operators.takeUntil(this.unsubscribe))
.subscribe((/**
* @param {?} count
* @return {?}
*/
function (count) {
_this.filterCount = count;
_this.cdr.detectChanges();
}));
}
/**
* @param {?} targetElement
* @return {?}
*/
BaseComponent.prototype.onContextMenuClick = /**
* @param {?} targetElement
* @return {?}
*/
function (targetElement) {
if (this.contextMenu && !this.contextMenu.nativeElement.contains(targetElement)) {
this.rowContextMenuPosition = {
top: null,
left: null,
value: null,
};
}
};
/**
* @return {?}
*/
BaseComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (!this.columns) {
console.error('[columns] property required!');
}
if (this.configuration) {
this.config = this.configuration;
}
else {
this.config = DefaultConfigService.config;
}
this.limit = this.config.rows;
if (this.groupRowsBy) {
this.grouped = GroupRowsService.doGroupRows(this.data, this.groupRowsBy);
}
this.doDecodePersistedState();
};
/**
* @return {?}
*/
BaseComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.unsubscribe.next();
this.unsubscribe.complete();
};
/**
* @return {?}
*/
BaseComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var throttleValue = this.config.infiniteScrollThrottleTime ?
this.config.infiniteScrollThrottleTime :
200;
this.scrollDispatcher.scrolled()
.pipe(operators.takeUntil(this.unsubscribe), operators.throttleTime(throttleValue), operators.filter((/**
* @param {?} event
* @return {?}
*/
function (event) {
return !!event && _this.viewPort && _this.viewPort.getRenderedRange().end === _this.viewPort.getDataLength();
})))
.subscribe((/**
* @return {?}
*/
function () {
_this.emitEvent(Event.onInfiniteScrollEnd, null);
}));
};
/**
* @param {?} changes
* @return {?}
*/
BaseComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var configuration = changes.configuration, data = changes.data, pagination = changes.pagination, groupRowsBy = changes.groupRowsBy;
this.toggleRowIndex = changes.toggleRowIndex;
if (configuration && configuration.currentValue) {
this.config = configuration.currentValue;
}
if (data && data.currentValue) {
this.doApplyData(data);
}
if (pagination && pagination.currentValue) {
var _a = (/** @type {?} */ (pagination.currentValue)), count = _a.count, limit = _a.limit, offset = _a.offset;
this.count = count;
this.limit = limit;
this.page = offset;
}
if (groupRowsBy && groupRowsBy.currentValue) {
this.grouped = GroupRowsService.doGroupRows(this.data, this.groupRowsBy);
}
if (this.toggleRowIndex && this.toggleRowIndex.currentValue) {
/** @type {?} */
var row = this.toggleRowIndex.currentValue;
this.collapseRow(row.index);
}
};
/**
* @param {?} column
* @return {?}
*/
BaseComponent.prototype.orderBy = /**
* @param {?} column
* @return {?}
*/
function (column) {
if (typeof column.orderEnabled !== 'undefined' && !column.orderEnabled) {
return;
}
this.sortKey = column.key;
if (!this.config.orderEnabled || this.sortKey === '') {
return;
}
this.setColumnOrder(this.sortKey);
if (!this.config.orderEventOnly && !column.orderEventOnly) {
this.sortBy.key = this.sortKey;
this.sortBy.order = this.sortState.get(this.sortKey);
}
else {
this.sortBy.key = '';
this.sortBy.order = '';
}
if (!this.config.serverPagination) {
this.data = __spread(this.data);
this.sortBy = __assign({}, this.sortBy);
}
/** @type {?} */
var value = {
key: this.sortKey,
order: this.sortState.get(this.sortKey),
};
this.emitEvent(Event.onOrder, value);
};
/**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.onClick = /**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
function ($event, row, key, colIndex, rowIndex) {
if (this.config.selectRow) {
this.selectedRow = rowIndex;
}
if (this.config.selectCol && colIndex) {
this.selectedCol = colIndex;
}
if (this.config.selectCell && colIndex) {
this.selectedRow = rowIndex;
this.selectedCol = colIndex;
}
if (this.config.clickEvent) {
/** @type {?} */
var value = {
event: $event,
row: row,
key: key,
rowId: rowIndex,
colId: colIndex,
};
this.emitEvent(Event.onClick, value);
}
};
/**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.onDoubleClick = /**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
function ($event, row, key, colIndex, rowIndex) {
/** @type {?} */
var value = {
event: $event,
row: row,
key: key,
rowId: rowIndex,
colId: colIndex,
};
this.emitEvent(Event.onDoubleClick, value);
};
/**
* @param {?} $event
* @param {?} row
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.onCheckboxSelect = /**
* @param {?} $event
* @param {?} row
* @param {?} rowIndex
* @return {?}
*/
function ($event, row, rowIndex) {
/** @type {?} */
var value = {
event: $event,
row: row,
rowId: rowIndex,
};
this.emitEvent(Event.onCheckboxSelect, value);
};
/**
* @param {?} $event
* @param {?} row
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.onRadioSelect = /**
* @param {?} $event
* @param {?} row
* @param {?} rowIndex
* @return {?}
*/
function ($event, row, rowIndex) {
/** @type {?} */
var value = {
event: $event,
row: row,
rowId: rowIndex,
};
this.emitEvent(Event.onRadioSelect, value);
};
/**
* @return {?}
*/
BaseComponent.prototype.onSelectAll = /**
* @return {?}
*/
function () {
this.isSelected = !this.isSelected;
this.emitEvent(Event.onSelectAll, this.isSelected);
};
/**
* @param {?} $event
* @return {?}
*/
BaseComponent.prototype.onSearch = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (!this.config.serverPagination) {
this.term = $event;
}
this.emitEvent(Event.onSearch, $event);
};
/**
* @param {?} value
* @return {?}
*/
BaseComponent.prototype.onGlobalSearch = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (!this.config.serverPagination) {
this.globalSearchTerm = value;
}
this.emitEvent(Event.onGlobalSearch, value);
};
/**
* @param {?} pagination
* @return {?}
*/
BaseComponent.prototype.onPagination = /**
* @param {?} pagination
* @return {?}
*/
function (pagination) {
this.page = pagination.page;
this.limit = pagination.limit;
this.emitEvent(Event.onPagination, pagination);
};
/**
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.toggleCheckbox = /**
* @param {?} rowIndex
* @return {?}
*/
function (rowIndex) {
this.selectedCheckboxes.has(rowIndex) ?
this.selectedCheckboxes.delete(rowIndex) :
this.selectedCheckboxes.add(rowIndex);
};
/**
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.collapseRow = /**
* @param {?} rowIndex
* @return {?}
*/
function (rowIndex) {
if (this.selectedDetailsTemplateRowId.has(rowIndex)) {
this.selectedDetailsTemplateRowId.delete(rowIndex);
this.emitEvent(Event.onRowCollapsedHide, rowIndex);
}
else {
this.selectedDetailsTemplateRowId.add(rowIndex);
this.emitEvent(Event.onRowCollapsedShow, rowIndex);
}
};
/**
* @private
* @return {?}
*/
BaseComponent.prototype.doDecodePersistedState = /**
* @private
* @return {?}
*/
function () {
if (!this.config.persistState) {
return;
}
/** @type {?} */
var pagination = localStorage.getItem(Event.onPagination);
/** @type {?} */
var sort = localStorage.getItem(Event.onOrder);
/** @type {?} */
var search = localStorage.getItem(Event.onSearch);
if (pagination) {
this.onPagination(JSON.parse(pagination));
}
if (sort) {
var _a = JSON.parse(sort), key = _a.key, order = _a.order;
this.bindApi({
type: API.sortBy,
value: { column: key, order: order },
});
}
if (search) {
this.bindApi({
type: API.setInputValue,
value: JSON.parse(search),
});
}
};
/**
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.isRowCollapsed = /**
* @param {?} rowIndex
* @return {?}
*/
function (rowIndex) {
if (this.config.collapseAllRows) {
return true;
}
return this.selectedDetailsTemplateRowId.has(rowIndex);
};
Object.defineProperty(BaseComponent.prototype, "isLoading", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var table = (/** @type {?} */ (document.getElementById(this.id)));
if (table && table.rows && table.rows.length > 3) {
this.getLoadingHeight(table.rows);
}
return this.config.isLoading;
},
enumerable: true,
configurable: true
});
/**
* @param {?} rows
* @return {?}
*/
BaseComponent.prototype.getLoadingHeight = /**
* @param {?} rows
* @return {?}
*/
function (rows) {
/** @type {?} */
var searchEnabled = this.config.searchEnabled ? 1 : 0;
/** @type {?} */
var headerEnabled = this.config.headerEnabled ? 1 : 0;
/** @type {?} */
var borderTrHeight = 1;
/** @type {?} */
var borderDivHeight = 2;
this.loadingHeight = (rows.length - searchEnabled - headerEnabled) * (rows[3].offsetHeight - borderTrHeight) - borderDivHeight + 'px';
};
Object.defineProperty(BaseComponent.prototype, "arrowDefinition", {
get: /**
* @return {?}
*/
function () {
return this.config.showDetailsArrow || typeof this.config.showDetailsArrow === 'undefined';
},
enumerable: true,
configurable: true
});
/**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
BaseComponent.prototype.onRowContextMenu = /**
* @param {?} $event
* @param {?} row
* @param {?} key
* @param {?} colIndex
* @param {?} rowIndex
* @return {?}
*/
function ($event, row, key, colIndex, rowIndex) {
if (!this.config.showContextMenu) {
return;
}
$event.preventDefault();
/** @type {?} */
var value = {
event: $event,
row: row,
key: key,
rowId: rowIndex,
colId: colIndex,
};
this.rowContextMenuPosition = {
top: $event.y - 10 + "px",
left: $event.x - 10 + "px",
value: value,
};
this.emitEvent(Event.onRowContextMenu, value);
};
/**
* @private
* @param {?} data
* @return {?}
*/
BaseComponent.prototype.doApplyData = /**
* @private
* @param {?} data
* @return {?}
*/
function (data) {
/** @type {?} */
var order = this.columns.find((/**
* @param {?} c
* @return {?}
*/
function (c) { return !!c.orderBy; }));
if (order) {
this.sortState.set(this.sortKey, (order.orderBy === 'asc') ? 'desc' : 'asc');
this.orderBy(order);
}
else {
this.data = __spread(data.currentValue);
}
};
/**
* @param {?} event
* @return {?}
*/
BaseComponent.prototype.onDrop = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.emitEvent(Event.onRowDrop, event);
dragDrop.moveItemInArray(this.data, event.previousIndex, event.currentIndex);
};
// DO NOT REMOVE. It is called from parent component. See src/app/demo/api-doc/api-doc.component.ts
// DO NOT REMOVE. It is called from parent component. See src/app/demo/api-doc/api-doc.component.ts
/**
* @param {?} event
* @return {?}
*/
BaseComponent.prototype.apiEvent =
// DO NOT REMOVE. It is called from parent component. See src/app/demo/api-doc/api-doc.component.ts
/**
* @param {?} event
* @return {?}
*/
function (event) {
return this.bindApi(event);
};
// tslint:disable:no-big-function cognitive-complexity
// tslint:disable:no-big-function cognitive-complexity
/**
* @private
* @param {?} event
* @return {?}
*/
BaseComponent.prototype.bindApi =
// tslint:disable:no-big-function cognitive-complexity
/**
* @private
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
switch (event.type) {
case API.rowContextMenuClicked:
this.rowContextMenuPosition = {
top: null,
left: null,
value: null,
};
break;
case API.toolPanelClicked:
// TODO
break;
case API.toggleRowIndex:
this.collapseRow(event.value);
break;
case API.toggleCheckbox:
this.toggleCheckbox(event.value);
break;
case API.setInputValue:
if (this.config.searchEnabled) {
event.value.forEach((/**
* @param {?} input
* @return {?}
*/
function (input) {
/** @type {?} */
var element = ((/** @type {?} */ (document.getElementById("search_" + input.key))));
if (!element) {
console.error("Column '" + input.key + "' not available in the DOM. Have you misspelled a name?");
}
else {
element.value = input.value;
}
}));
}
this.onSearch(event.value);
this.cdr.detectChanges();
break;
case API.onGlobalSearch:
this.onGlobalSearch(event.value);
this.cdr.detectChanges();
break;
case API.setRowClass:
if (Array.isArray(event.value)) {
event.value.forEach((/**
* @param {?} val
* @return {?}
*/
function (val) { return _this.styleService.setRowClass(val); }));
break;
}
this.styleService.setRowClass(event.value);
this.cdr.detectChanges();
break;
case API.setCellClass:
if (Array.isArray(event.value)) {
event.value.forEach((/**
* @param {?} val
* @return {?}
*/
function (val) { return _this.styleService.setCellClass(val); }));
break;
}
this.styleService.setCellClass(event.value);
break;
case API.setRowStyle:
if (Array.isArray(event.value)) {
event.value.forEach((/**
* @param {?} val
* @return {?}
*/
function (val) { return _this.styleService.setRowStyle(val); }));
break;
}
this.styleService.setRowStyle(event.value);
break;
case API.setCellStyle:
if (Array.isArray(event.value)) {
event.value.forEach((/**
* @param {?} val
* @return {?}
*/
function (val) { return _this.styleService.setCellStyle(val); }));
break;
}
this.styleService.setCellStyle(event.value);
break;
case API.setTableClass:
this.tableClass = event.value;
this.cdr.detectChanges();
break;
case API.getPaginationTotalItems:
return this.paginationComponent.paginationDirective.getTotalItems();
case API.getPaginationCurrentPage:
return this.paginationComponent.paginationDirective.getCurrent();
case API.getPaginationLastPage:
return this.paginationComponent.paginationDirective.getLastPage();
case API.getNumberOfRowsPerPage:
return this.paginationComponent.paginationDirective.isLastPage() ?
(this.paginationComponent.paginationDirective.getTotalItems() % this.limit) :
this.limit;
case API.setPaginationCurrentPage:
this.paginationComponent.paginationDirective.setCurrent(event.value);
break;
case API.setPaginationRange:
this.paginationComponent.ranges = event.value;
break;
case API.setPaginationPreviousLabel:
this.paginationComponent.previousLabel = event.value;
break;
case API.setPaginationNextLabel:
this.paginationComponent.nextLabel = event.value;
break;
case API.setPaginationDisplayLimit:
this.paginationComponent.changeLimit(event.value, true);
break;
case API.sortBy:
/** @type {?} */
var column = { title: '', key: event.value.column, orderBy: event.value.order };
this.orderBy(column);
this.cdr.detectChanges();
break;
default:
break;
}
};
/**
* @private
* @param {?} key
* @return {?}
*/
BaseComponent.prototype.setColumnOrder = /**
* @private
* @param {?} key
* @return {?}
*/
function (key) {
switch (this.sortState.get(key)) {
case '':
case undefined:
this.sortState.set(key, 'desc');
break;
case 'asc':
this.config.threeWaySort ?
this.sortState.set(key, '') :
this.sortState.set(key, 'desc');
break;
case 'desc':
this.sortState.set(key, 'asc');
break;
}
if (this.sortState.size > 1) {
/** @type {?} */
var temp = this.sortState.get(key);
this.sortState.clear();
this.sortState.set(key, temp);
}
};
/**
* @param {?} event
* @param {?} value
* @return {?}
*/
BaseComponent.prototype.emitEvent = /**
* @param {?} event
* @param {?} value
* @return {?}
*/
function (event, value) {
this.event.emit({ event: event, value: value });
if (this.config.persistState) {
localStorage.setItem(event, JSON.stringify(value));
}
if (this.config.logger) {
// tslint:disable-next-line:no-console
console.log({ event: event, value: value });
}
};
BaseComponent.decorators = [
{ type: core.Component, args: [{
selector: 'ngx-table',
providers: [
DefaultConfigService,
GroupRowsService,
StyleService,
],
template: "<div class=\"ngx-container\">\n <table [id]=\"id\"\n [ngClass]=\"(tableClass === null || tableClass === '') ? 'ngx-table' : tableClass\"\n [class.ngx-table__table--tiny]=\"config.tableLayout.style === 'tiny'\"\n [class.ngx-table__table--normal]=\"config.tableLayout.style === 'normal'\"\n [class.ngx-table__table--big]=\"config.tableLayout.style === 'big'\"\n [class.ngx-table__table--borderless]=\"config.tableLayout.borderless\"\n [class.ngx-table__table--dark]=\"config.tableLayout.theme === 'dark'\"\n [class.ngx-table__table--hoverable]=\"config.tableLayout.hover\"\n [class.ngx-table__table--striped]=\"config.tableLayout.striped\"\n [class.ngx-table__horizontal-scroll]=\"config.horizontalScroll && !isLoading\">\n <thead\n [class.ngx-infinite-scroll-viewport-thead]=\"config.infiniteScroll\"\n table-thead\n [config]=\"config\"\n [sortKey]=\"sortKey\"\n [sortState]=\"sortState\"\n [selectAllTemplate]=\"selectAllTemplate\"\n [filtersTemplate]=\"filtersTemplate\"\n [additionalActionsTemplate]=\"additionalActionsTemplate\"\n [columns]=\"columns\"\n (selectAll)=\"onSelectAll()\"\n (filter)=\"onSearch($event)\"\n (order)=\"orderBy($event)\"\n (event)=\"emitEvent($event.event, $event.value)\"\n >\n </thead>\n <tbody *ngIf=\"data && !isLoading && !config.rowReorder\">\n <ng-container *ngIf=\"rowTemplate\">\n <ul class=\"ngx-table__table-row-context-menu\"\n [ngStyle]=\"{'position': 'absolute', 'top': rowContextMenuPosition.top, 'left': rowContextMenuPosition.left }\"\n *ngIf=\"rowContextMenuPosition.top\">\n <ng-container\n [ngTemplateOutlet]=\"rowContextMenu\"\n [ngTemplateOutletContext]=\"{ $implicit: rowContextMenuPosition.value}\">\n </ng-container>\n </ul>\n <ng-container *ngIf=\"!config.infiniteScroll\">\n <ng-container *ngFor=\"let row of data | sort:sortBy | search:term:filteredCountSubject | global:globalSearchTerm:filteredCountSubject | paginate: { itemsPerPage: limit, currentPage: page, totalItems: count, id: id };\n let rowIndex = index\">\n <tr\n (click)=\"onClick($event, row, '', null, rowIndex)\"\n #contextMenu\n (contextmenu)=\"onRowContextMenu($event, row, '', null, rowIndex)\"\n (dblclick)=\"onDoubleClick($event, row, '', null, rowIndex)\"\n [class.ngx-table__table-row--selected]=\"rowIndex === selectedRow && !config.selectCell\">\n <ng-container\n [ngTemplateOutlet]=\"rowTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n <td *ngIf=\"config.detailsTemplate\">\n <span class=\"ngx-icon\"\n *ngIf=\"arrowDefinition\"\n [ngClass]=\"isRowCollapsed(rowIndex) ? 'ngx-icon-arrow-down' : 'ngx-icon-arrow-right'\"\n (click)=\"collapseRow(rowIndex)\">\n </span>\n </td>\n </tr>\n <tr\n *ngIf=\"(config.detailsTemplate && selectedDetailsTemplateRowId.has(rowIndex)) || config.collapseAllRows\">\n <td [attr.colspan]=\"columns.length + 1\">\n <ng-container\n [ngTemplateOutlet]=\"detailsTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </ng-container>\n <cdk-virtual-scroll-viewport\n itemSize=\"50\"\n *ngIf=\"config.infiniteScroll\"\n class=\"ngx-infinite-scroll-viewport\">\n <ng-container *cdkVirtualFor=\"let row of data | sort:sortBy | search:term:filteredCountSubject | global:globalSearchTerm:filteredCountSubject;\n let rowIndex = index\">\n <tr\n (click)=\"onClick($event, row, '', null, rowIndex)\"\n #contextMenu\n (contextmenu)=\"onRowContextMenu($event, row, '', null, rowIndex)\"\n (dblclick)=\"onDoubleClick($event, row, '', null, rowIndex)\"\n [class.ngx-table__table-row--selected]=\"rowIndex === selectedRow && !config.selectCell\">\n <ng-container\n [ngTemplateOutlet]=\"rowTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n <td *ngIf=\"config.detailsTemplate\">\n <span class=\"ngx-icon\"\n *ngIf=\"arrowDefinition\"\n [ngClass]=\"isRowCollapsed(rowIndex) ? 'ngx-icon-arrow-down' : 'ngx-icon-arrow-right'\"\n (click)=\"collapseRow(rowIndex)\">\n </span>\n </td>\n </tr>\n <tr\n *ngIf=\"(config.detailsTemplate && selectedDetailsTemplateRowId.has(rowIndex)) || config.collapseAllRows\">\n <td [attr.colspan]=\"columns.length + 1\">\n <ng-container\n [ngTemplateOutlet]=\"detailsTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </cdk-virtual-scroll-viewport>\n </ng-container>\n <ng-container *ngIf=\"!rowTemplate && !config.groupRows\">\n <ul class=\"ngx-table__table-row-context-menu\"\n [ngStyle]=\"{'position': 'absolute', 'top': rowContextMenuPosition.top, 'left': rowContextMenuPosition.left }\"\n *ngIf=\"rowContextMenuPosition.top\">\n <ng-container\n [ngTemplateOutlet]=\"rowContextMenu\"\n [ngTemplateOutletContext]=\"{ $implicit: rowContextMenuPosition.value}\">\n </ng-container>\n </ul>\n <ng-container *ngIf=\"!config.infiniteScroll\">\n <ng-container\n *ngFor=\"let row of data | sort:sortBy | search:term:filteredCountSubject | global:globalSearchTerm:filteredCountSubject | paginate: { itemsPerPage: limit, currentPage: page, totalItems: count, id: id };\n let rowIndex = index\">\n <tr [class.ngx-table__table-row--selected]=\"rowIndex === selectedRow && !config.selectCell\">\n <td *ngIf=\"config.checkboxes\">\n <label class=\"ngx-form-checkbox\">\n <input type=\"checkbox\"\n id=\"checkbox-{{rowIndex}}\"\n [checked]=\"isSelected || selectedCheckboxes.has(rowIndex)\"\n (change)=\"onCheckboxSelect($event, row, rowIndex)\">\n <em class=\"ngx-form-icon\"></em>\n </label>\n </td>\n <td *ngIf=\"config.radio\">\n <label>\n <input type=\"radio\"\n id=\"radio-{{rowIndex}}\"\n name=\"radio\"\n (change)=\"onRadioSelect($event, row, rowIndex)\">\n </label>\n </td>\n <ng-container *ngFor=\"let column of columns; let colIndex = index\">\n <td (click)=\"onClick($event, row, column.key, colIndex, rowIndex)\"\n #contextMenu\n (contextmenu)=\"onRowContextMenu($event, row, column.key, colIndex, rowIndex)\"\n (dblclick)=\"onDoubleClick($event, row, column.key, colIndex, rowIndex)\"\n [class.pinned-left]=\"column.pinned\"\n [ngClass]=\"column.cssClass ? column.cssClass.name : ''\"\n [style.left]=\"styleService.pinnedWidth(column.pinned, colIndex)\"\n [class.ngx-table__table-col--selected]=\"colIndex === selectedCol && !config.selectCell\"\n [class.ngx-table__table-cell--selected]=\"colIndex === selectedCol && rowIndex === selectedRow && !config.selectCol && !config.selectRow\"\n >\n <div *ngIf=\"!column.cellTemplate\">{{ row | render:column.key }}</div>\n <ng-container\n *ngIf=\"column.cellTemplate\"\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowIndex: rowIndex }\">\n </ng-container>\n </td>\n </ng-container>\n <td *ngIf=\"config.additionalActions || config.detailsTemplate\">\n <span class=\"ngx-icon\"\n *ngIf=\"arrowDefinition\"\n [ngClass]=\"isRowCollapsed(rowIndex) ? 'ngx-icon-arrow-down' : 'ngx-icon-arrow-right'\"\n (click)=\"collapseRow(rowIndex)\">\n </span>\n </td>\n </tr>\n <tr\n *ngIf=\"(config.detailsTemplate && selectedDetailsTemplateRowId.has(rowIndex)) || config.collapseAllRows\">\n <td *ngIf=\"config.checkboxes || config.radio\"></td>\n <td [attr.colspan]=\"columns.length + 1\">\n <ng-container\n [ngTemplateOutlet]=\"detailsTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </ng-container>\n <!-- infinite scroll -->\n <cdk-virtual-scroll-viewport\n itemSize=\"50\"\n *ngIf=\"config.infiniteScroll\"\n class=\"ngx-infinite-scroll-viewport\">\n <ng-container\n *cdkVirtualFor=\"let row of data | sort:sortBy | search:term:filteredCountSubject | global:globalSearchTerm:filteredCountSubject;\n let rowIndex = index\">\n <tr [class.ngx-table__table-row--selected]=\"rowIndex === selectedRow && !config.selectCell\">\n <td *ngIf=\"config.checkboxes\">\n <label class=\"ngx-form-checkbox\">\n <input type=\"checkbox\"\n id=\"checkbox-infinite-scroll-{{rowIndex}}\"\n [checked]=\"isSelected || selectedCheckboxes.has(rowIndex)\"\n (change)=\"onCheckboxSelect($event, row, rowIndex)\">\n <em class=\"ngx-form-icon\"></em>\n </label>\n </td>\n <td *ngIf=\"config.radio\">\n <label>\n <input type=\"radio\"\n id=\"radio-infinite-scroll-{{rowIndex}}\"\n name=\"radio\"\n (change)=\"onRadioSelect($event, row, rowIndex)\">\n </label>\n </td>\n <ng-container *ngFor=\"let column of columns; let colIndex = index\">\n <td (click)=\"onClick($event, row, column.key, colIndex, rowIndex)\"\n #contextMenu\n (contextmenu)=\"onRowContextMenu($event, row, column.key, colIndex, rowIndex)\"\n (dblclick)=\"onDoubleClick($event, row, column.key, colIndex, rowIndex)\"\n [class.pinned-left]=\"column.pinned\"\n [ngClass]=\"column.cssClass ? column.cssClass.name : ''\"\n [style.left]=\"styleService.pinnedWidth(column.pinned, colIndex)\"\n [class.ngx-table__table-col--selected]=\"colIndex === selectedCol && !config.selectCell\"\n [class.ngx-table__table-cell--selected]=\"colIndex === selectedCol && rowIndex === selectedRow && !config.selectCol && !config.selectRow\"\n >\n <div *ngIf=\"!column.cellTemplate\">{{ row | render:column.key }}</div>\n <ng-container\n *ngIf=\"column.cellTemplate\"\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, rowIndex: rowIndex }\">\n </ng-container>\n </td>\n </ng-container>\n <td *ngIf=\"config.additionalActions || config.detailsTemplate\">\n <span class=\"ngx-icon\"\n *ngIf=\"arrowDefinition\"\n [ngClass]=\"isRowCollapsed(rowIndex) ? 'ngx-icon-arrow-down' : 'ngx-icon-arrow-right'\"\n (click)=\"collapseRow(rowIndex)\">\n </span>\n </td>\n </tr>\n <tr\n *ngIf=\"(config.detailsTemplate && selectedDetailsTemplateRowId.has(rowIndex)) || config.collapseAllRows\">\n <td *ngIf=\"config.checkboxes || config.radio\"></td>\n <td [attr.colspan]=\"columns.length + 1\">\n <ng-container\n [ngTemplateOutlet]=\"detailsTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: rowIndex }\">\n </ng-container>\n </td>\n </tr>\n </ng-container>\n </cdk-virtual-scroll-viewport>\n </ng-container>\n <ng-container *ngIf=\"!rowTemplate && config.groupRows\">\n <ng-container\n *ngFor=\"let group of grouped | sort:sortBy:config | search:term:filteredCountSubject:config | global:globalSearchTerm:filteredCountSubject | paginate: { itemsPerPage: limit, currentPage: page, totalItems: count, id: id };\n let rowIndex = index\">\n <tr>\n <ng-container *ngIf=\"!groupRowsHeaderTemplate\">\n <td [attr.colspan]=\"columns.length\">\n <div>{{group[0][groupRowsBy]}} ({{group.length}})</div>\n </td>\n </ng-container>\n <ng-container\n *ngIf=\"groupRowsHeaderTemplate\"\n [ngTemplateOutlet]=\"groupRowsHeaderTemplate\"\n [ngTemplateOutletContext]=\"{\n total: group.length,\n key: groupRowsBy,\n value: group[0] ? group[0][groupRowsBy] : '',\n group: group,\n index: rowIndex\n }\">\n </ng-container>\n <td>\n <span class=\"ngx-icon\"\n *ngIf=\"arrowDefinition\"\n [ngClass]=\"isRowCollapsed(rowIndex) ? 'ngx-icon-arrow-down' : 'ngx-icon-arrow-right'\"\n (click)=\"collapseRow(rowIndex)\">\n </span>\n </td>\n </tr>\n <ng-container *ngIf=\"selectedDetailsTemplateRowId.has(rowIndex)\">\n <tr *ngFor=\"let row of group\">\n <td *ngFor=\"let column of columns\">\n {{ row | render:column.key }}\n <!-- TODO allow users to add groupRowsTemplateRef -->\n </td>\n <td></td>\n </tr>\n </ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n <tbody *ngIf=\"data && !config.isLoading && config.rowReorder\"\n class=\"ngx-draggable-row-area\"\n cdkDropList\n (cdkDropListDropped)=\"onDrop($event)\">\n <ng-container *ngIf=\"!rowTemplate && !config.groupRows\">\n <ng-container\n *ngFor=\"let row of data | sort:sortBy | search:term:filteredCountSubject | global:globalSearchTerm:filteredCountSubject | paginate: { itemsPerPage: limit, currentPage: page, totalItems: count, id: id };\n let rowIndex = index\">\n <tr class=\"ngx-draggable-row\" cdkDrag cdkDragLockAxis=\"y\">\n <td *ngIf=\"config.checkboxes\">\n <label class=\"ngx-form-checkbox\">\n <input type=\"checkbox\"\n id=\"checkbox-draggable-{{rowIndex}}\"\n [checked]=\"isSelected || selectedCheckboxes.has(rowIndex)\"\n (change)=\"onCheckboxSelect($event, row, rowIndex)\">\n <em class=\"ngx-form-icon\"></em>\n </label>\n </td>\n <td *ngIf=\"config.radio\">\n <label>\n <input type=\"radio\"\n id=\"radio-draggable-{{rowIndex}}\"\n name=\"radio\"\n (change)=\"onRadioSelect($event, row, rowIndex)\">\n </label>\n </td>\n <ng-container *ngFor=\"let column of columns; let colIndex = index\">\n <td (click)=\"onClick($event, row, column.key, colIndex, rowIndex)\"\n (dblclick)=\"onDoubleClick($event, row, column.key, colIndex, rowIndex)\"\n [class.ngx-table__table-col--selected]=\"colIndex === selectedCol && !config.selectCell\"\n [class.ngx-table__table-cell--selected]=\"colIndex === selectedCol && rowIndex === selectedRow && !config.selectCol && !config.selectRow\"\n >\n <div>{{ row | render:column.key }}</div>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </ng-container>\n </tbody>\n <tbody *ngIf=\"filterCount === 0\">\n <tr class=\"ngx-table__body-empty\">\n <ng-container\n *ngIf=\"noResultsTemplate\"\n [ngTemplateOutlet]=\"noResultsTemplate\">\n </ng-container>\n <td [attr.colspan]=\"columns && columns.length + 1\" *ngIf=\"!noResultsTemplate\">\n <div class=\"ngx-table__table-no-results\">\n No results\n </div>\n </td>\n </tr>\n </tbody>\n <tbody *ngIf=\"isLoading\">\n <tr class=\"ngx-table__body-loading\">\n <ng-container\n *ngIf=\"loadingTemplate\"\n [ngTemplateOutlet]=\"loadingTemplate\">\n </ng-container>\n <td [attr.colspan]=\"columns && columns.length + 1\" *ngIf=\"!loadingTemplate\">\n <div [style.height]=\"loadingHeight\"\n class=\"ngx-table__table-loader-wrapper\">\n <div class=\"ngx-table__table-loader\"></div>\n </div>\n </td>\n </tr>\n </tbody>\n <tfoot *ngIf=\"summaryTemplate\">\n <tr>\n <ng-container\n [ngTemplateOutlet]=\"summaryTemplate\"\n [ngTemplateOutletContext]=\"{ total: data.length, limit: limit, page: page }\">\n </ng-container>\n </tr>\n </tfoot>\n </table>\n <pagination\n [attr.id]=\"'pagination' + id\"\n [id]=\"id\"\n #paginationComponent\n [config]=\"config\"\n [pagination]=\"pagination\"\n (updateRange)=\"onPagination($event)\">\n </pagination>\n</div>\n",
changeDetection: core.ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
BaseComponent.ctorParameters = function () { return [
{ type: core.ChangeDetectorRef },
{ type: scrolling.ScrollDispatcher },
{ type: StyleService }
]; };
BaseComponent.propDecorators = {
configuration: [{ type: core.Input }],
data: [{ type: core.Input }],
pagination: [{ type: core.Input }],
groupRowsBy: [{ type: core.Input }],
id: [{ type: core.Input }],
toggleRowIndex: [{ type: core.Input }],
detailsTemplate: [{ type: core.Input }],
summaryTemplate: [{ type: core.Input }],
groupRowsHeaderTemplate: [{ type: core.Input }],
filtersTemplate: [{ type: core.Input }],
selectAllTemplate: [{ type: core.Input }],
noResultsTemplate: [{ type: core.Input }],
loadingTemplate: [{ type: core.Input }],
additionalActionsTemplate: [{ type: core.Input }],
rowContextMenu: [{ type: core.Input }],
columns: [{ type: core.Input }],
event: [{ type: core.Output }],
rowTemplate: [{ type: core.ContentChild, args: [core.TemplateRef, { static: true },] }],
paginationComponent: [{ type: core.ViewChild, args: ['paginationComponent', { static: false },] }],
contextMenu: [{ type: core.ViewChild, args: ['contextMenu', { static: false },] }],
viewPort: [{ type: core.ViewChild, args: [scrolling.CdkVirtualScrollViewport, { static: false },] }],
onContextMenuClick: [{ type: core.HostListener, args: ['document:click', ['$event.target'],] }]
};
return BaseComponent;
}());
if (false) {
/**
* @type {?}
* @private
*/
BaseComponent.prototype.unsubscribe;
/** @type {?} */
BaseComponent.prototype.selectedRow;
/** @type {?} */
BaseComponent.prototype.selectedCol;
/** @type {?} */
BaseComponent.prototype.term;
/** @type {?} */
BaseComponent.prototype.filterCount;
/** @type {?} */
BaseComponent.prototype.filteredCountSubject;
/** @type {?} */
BaseComponent.prototype.subscription;
/** @type {?} */
BaseComponent.prototype.tableClass;
/** @type {?} */
BaseComponent.prototype.globalSearchTerm;
/** @type {?} */
BaseComponent.prototype.grouped;
/** @type {?} */
BaseComponent.prototype.isSelected;
/** @type {?} */
BaseComponent.prototype.page;
/** @type {?} */
BaseComponent.prototype.count;
/** @type {?} */
BaseComponent.prototype.sortState;
/** @type {?} */
BaseComponent.prototype.sortKey;
/** @type {?} */
BaseComponent.prototype.rowContextMenuPosition;
/** @type {?} */
BaseComponent.prototype.limit;
/** @type {?} */
BaseComponent.prototype.sortBy;
/** @type {?} */
BaseComponent.prototype.selectedDetailsTemplateRowId;
/** @type {?} */
BaseComponent.prototype.selectedCheckboxes;
/** @type {?} */
BaseComponent.prototype.loadingHeight;
/** @type {?} */
BaseComponent.prototype.config;
/** @type {?} */
BaseComponent.prototype.configuration;
/** @type {?} */
BaseComponent.prototype.data;
/** @type {?} */
BaseComponent.prototype.pagination;
/** @type {?} */
BaseComponent.prototype.groupRowsBy;
/** @type {?} */
BaseComponent.prototype.id;
/** @type {?} */
BaseComponent.prototype.toggleRowIndex;
/** @type {?} */
BaseComponent.prototype.detailsTemplate;
/** @type {?} */
BaseComponent.prototype.summaryTemplate;
/** @type {?} */
BaseComponent.prototype.groupRowsHeaderTemplate;
/** @type {?} */
BaseComponent.prototype.filtersTemplate;
/** @type {?} */
BaseComponent.prototype.selectAllTemplate;
/** @type {?} */
BaseComponent.prototype.noResultsTemplate;
/** @type {?} */
BaseComponent.prototype.loadingTemplate;
/** @type {?} */
BaseComponent.prototype.additionalActionsTemplate;
/** @type {?} */
BaseComponent.prototype.rowContextMenu;
/** @type {?} */
BaseComponent.prototype.columns;
/** @type {?} */
BaseComponent.prototype.event;
/** @type {?} */
BaseComponent.prototype.rowTemplate;
/**
* @type {?}
* @private
*/
BaseComponent.prototype.paginationComponent;
/** @type {?} */
BaseComponent.prototype.contextMenu;
/** @type {?} */
BaseComponent.prototype.viewPort;
/**
* @type {?}
* @private
*/
BaseComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
BaseComponent.prototype.scrollDispatcher;
/** @type {?} */
BaseComponent.prototype.styleService;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var HeaderComponent = /** @class */ (function () {
function HeaderComponent() {
this.update = new core.EventEmitter();
}
/**
* @param {?} key
* @return {?}
*/
HeaderComponent.prototype.unifyKey = /**
* @param {?} key
* @return {?}
*/
function (key) {
return key.replace('.', '_');
};
/**
* @param {?} input
* @return {?}
*/
HeaderComponent.prototype.onSearch = /**
* @param {?} input
* @return {?}
*/
function (input) {
this.update.emit([
{ value: input.value, key: this.column.key },
]);
};
HeaderComponent.decorators = [
{ type: core.Component, args: [{
selector: 'table-header',
template: "<label for=\"search_{{ unifyKey(column.key) }}\">\n <input type=\"text\"\n id=\"search_{{ unifyKey(column.key) }}\"\n aria-label=\"Search\"\n placeholder=\"{{ column.placeholder ? column.placeholder : column.title }}\"\n class=\"ngx-table__header-search\"\n #input\n (input)=\"onSearch(input)\"\n >\n</label>\n"
}] }
];
HeaderComponent.propDecorators = {
column: [{ type: core.Input }],
update: [{ type: core.Output }]
};
return HeaderComponent;
}());
if (false) {
/** @type {?} */
HeaderComponent.prototype.column;
/** @type {?} */
HeaderComponent.prototype.update;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var GlobalSearchPipe = /** @class */ (function () {
function GlobalSearchPipe() {
}
/**
* @param {?} array
* @param {?} filter
* @param {?} filteredCountSubject
* @return {?}
*/
GlobalSearchPipe.prototype.transform = /**
* @param {?} array
* @param {?} filter
* @param {?} filteredCountSubject
* @return {?}
*/
function (array, filter, filteredCountSubject) {
filteredCountSubject.next(0);
if (typeof array === 'undefined') {
return;
}
if (typeof filter === 'undefined' || Object.keys(filter).length === 0 || filter === '') {
filteredCountSubject.next(array.length);
return array;
}
/** @type {?} */
var arr = array.filter((/**
* @param {?} row
* @return {?}
*/
function (row) {
/** @type {?} */
var element = JSON.stringify(Object.values(row));
/** @type {?} */
var strings = filter.split(',');
return strings.some((/**
* @param {?} string
* @return {?}
*/
function (string) { return element.toLocaleLowerCase().indexOf(string.trim().toLocaleLowerCase()) > -1; }));
}));
filteredCountSubject.next(arr.length);
return arr;
};
GlobalSearchPipe.decorators = [
{ type: core.Pipe, args: [{
name: 'global',
},] }
];
return GlobalSearchPipe;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var FiltersService = /** @class */ (function () {
function FiltersService() {
}
/**
* @param {?} p
* @param {?} o
* @return {?}
*/
FiltersService.getPath = /**
* @param {?} p
* @param {?} o
* @return {?}
*/
function (p, o) {
// https://github.com/dherges/ng-packagr/issues/696
/* tslint:disable-next-line */
/** @type {?} */
var result = p.reduce((/**
* @param {?} xs
* @param {?} x
* @return {?}
*/
function (xs, x) { return (xs && typeof xs[x] !== 'undefined') ? xs[x] : null; }), o);
return result;
};
FiltersService.decorators = [
{ type: core.Injectable }
];
return FiltersService;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var RenderPipe = /** @class */ (function () {
function RenderPipe() {
}
/**
* @param {?} row
* @param {?} key
* @return {?}
*/
RenderPipe.prototype.transform = /**
* @param {?} row
* @param {?} key
* @return {?}
*/
function (row, key) {
/** @type {?} */
var split = key.split('.');
return FiltersService.getPath(split, row);
};
RenderPipe.decorators = [
{ type: core.Pipe, args: [{
name: 'render',
},] }
];
return RenderPipe;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var SearchPipe = /** @class */ (function () {
function SearchPipe() {
this.filters = {};
}
/**
* @param {?} array
* @param {?} filter
* @param {?} filteredCountSubject
* @param {?=} config
* @return {?}
*/
SearchPipe.prototype.transform = /**
* @param {?} array
* @param {?} filter
* @param {?} filteredCountSubject
* @param {?=} config
* @return {?}
*/
function (array, filter, filteredCountSubject, config) {
var _this = this;
filteredCountSubject.next(0);
if (typeof array === 'undefined') {
return;
}
if (typeof filter === 'undefined') {
filteredCountSubject.next(array.length);
return array;
}
filter.forEach((/**
* @param {?} f
* @return {?}
*/
function (f) {
_this.filters[f.key] = f.value.toString().toLocaleLowerCase();
if (Object.keys(f).length === 0 || f.value === '') {
delete _this.filters[f.key];
}
}));
if (config && config.groupRows) {
return array.map((/**
* @param {?} arr
* @return {?}
*/
function (arr) { return _this.filterGroup(arr, filteredCountSubject); }));
}
return this.filterGroup(array, filteredCountSubject);
};
/**
* @private
* @param {?} array
* @param {?} filteredCountSubject
* @return {?}
*/
SearchPipe.prototype.filterGroup = /**
* @private
* @param {?} array
* @param {?} filteredCountSubject
* @return {?}
*/
function (array, filteredCountSubject) {
var _this = this;
/** @type {?} */
var arr = array.filter((/**
* @param {?} obj
* @return {?}
*/
function (obj) {
return Object.keys(_this.filters).every((/**
* @param {?} c
* @return {?}
*/
function (c) {
/** @type {?} */
var split = c.split('.');
/** @type {?} */
var val = FiltersService.getPath(split, obj);
/** @type {?} */
var element = (typeof val === 'object') ? JSON.stringify(val) : val.toString().toLocaleLowerCase();
/** @type {?} */
var strings = _this.filters[c].split(',');
return strings.some((/**
* @param {?} string
* @return {?}
*/
function (string) { return element.indexOf(string.trim()) > -1; }));
}));
}));
filteredCountSubject.next(arr.length);
return arr;
};
SearchPipe.decorators = [
{ type: core.Pipe, args: [{
name: 'search',
},] }
];
return SearchPipe;
}());
if (false) {
/**
* @type {?}
* @private
*/
SearchPipe.prototype.filters;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var SortPipe = /** @class */ (function () {
function SortPipe() {
this.defaultArray = [];
}
/**
* @private
* @param {?} aV
* @param {?} bV
* @return {?}
*/
SortPipe.isNaN = /**
* @private
* @param {?} aV
* @param {?} bV
* @return {?}
*/
function (aV, bV) {
return (isNaN(parseFloat(aV)) || !isFinite(aV)) || (isNaN(parseFloat(bV)) || !isFinite(bV));
};
/**
* @private
* @param {?} a
* @param {?} b
* @param {?} key
* @return {?}
*/
SortPipe.compare = /**
* @private
* @param {?} a
* @param {?} b
* @param {?} key
* @return {?}
*/
function (a, b, key) {
/** @type {?} */
var split = key.split('.');
/** @type {?} */
var aPath = FiltersService.getPath(split, a);
/** @type {?} */
var bPath = FiltersService.getPath(split, b);
/** @type {?} */
var aValue = (aPath + '').toLowerCase();
/** @type {?} */
var bValue = (bPath + '').toLowerCase();
if (SortPipe.isNaN(aPath, bPath)) {
return aValue.localeCompare(bValue);
}
else {
if (parseFloat(aPath) < parseFloat(bPath)) {
return -1;
}
if (parseFloat(aPath) > parseFloat(bPath)) {
return 1;
}
}
return 0;
};
/**
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
SortPipe.prototype.transform = /**
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
function (array, filter, config) {
if (this.defaultArray.length === 0) {
this.defaultArray = array;
}
if (!filter.key || filter.key === '') {
return array;
}
if (filter.order === '') {
return this.defaultArray;
}
if (filter.order === 'asc') {
return this.sortAsc(array, filter, config);
}
else {
return this.sortDesc(array, filter, config);
}
};
/**
* @private
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
SortPipe.prototype.sortAsc = /**
* @private
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
function (array, filter, config) {
if (config && config.groupRows) {
return array.map((/**
* @param {?} arr
* @return {?}
*/
function (arr) { return arr.sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return SortPipe.compare(a, b, filter.key); })); }));
}
return array.sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return SortPipe.compare(a, b, filter.key); }));
};
/**
* @private
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
SortPipe.prototype.sortDesc = /**
* @private
* @param {?} array
* @param {?} filter
* @param {?=} config
* @return {?}
*/
function (array, filter, config) {
if (config && config.groupRows) {
return array.map((/**
* @param {?} arr
* @return {?}
*/
function (arr) { return arr.sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return SortPipe.compare(b, a, filter.key); })); }));
}
return array.sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return SortPipe.compare(b, a, filter.key); }));
};
SortPipe.decorators = [
{ type: core.Pipe, args: [{
name: 'sort',
},] }
];
return SortPipe;
}());
if (false) {
/**
* @type {?}
* @private
*/
SortPipe.prototype.defaultArray;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var TableTHeadComponent = /** @class */ (function () {
function TableTHeadComponent(styleService) {
this.styleService = styleService;
this.menuActive = false;
this.openedHeaderActionTemplate = null;
this.onSelectAllBinded = this.onSelectAll.bind(this);
this.filter = new core.EventEmitter();
this.order = new core.EventEmitter();
this.selectAll = new core.EventEmitter();
this.event = new core.EventEmitter();
}
/**
* @param {?} targetElement
* @return {?}
*/
TableTHeadComponent.prototype.onClick = /**
* @param {?} targetElement
* @return {?}
*/
function (targetElement) {
if (this.additionalActionMenu && !this.additionalActionMenu.nativeElement.contains(targetElement)) {
this.menuActive = false;
}
};
/**
* @param {?} column
* @return {?}
*/
TableTHeadComponent.prototype.getColumnDefinition = /**
* @param {?} column
* @return {?}
*/
function (column) {
return column.searchEnabled || typeof column.searchEnabled === 'undefined';
};
/**
* @param {?} column
* @return {?}
*/
TableTHeadComponent.prototype.orderBy = /**
* @param {?} column
* @return {?}
*/
function (column) {
this.order.emit(column);
};
/**
* @param {?} column
* @return {?}
*/
TableTHeadComponent.prototype.isOrderEnabled = /**
* @param {?} column
* @return {?}
*/
function (column) {
/** @type {?} */
var columnOrderEnabled = column.orderEnabled === undefined ? true : !!column.orderEnabled;
return this.config.orderEnabled && columnOrderEnabled;
};
/**
* @param {?} event
* @return {?}
*/
TableTHeadComponent.prototype.columnDrop = /**
* @param {?} event
* @return {?}
*/
function (event) {
dragDrop.moveItemInArray(this.columns, event.previousIndex, event.currentIndex);
};
/**
* @param {?} $event
* @return {?}
*/
TableTHeadComponent.prototype.onSearch = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.filter.emit($event);
};
/**
* @param {?} column
* @return {?}
*/
TableTHeadComponent.prototype.getColumnWidth = /**
* @param {?} column
* @return {?}
*/
function (column) {
if (column.width) {
return column.width;
}
return this.config.fixedColumnWidth ? 100 / this.columns.length + '%' : null;
};
/**
* @return {?}
*/
TableTHeadComponent.prototype.onSelectAll = /**
* @return {?}
*/
function () {
this.selectAll.emit();
};
/**
* @param {?} event
* @param {?} th
* @return {?}
*/
TableTHeadComponent.prototype.onMouseDown = /**
* @param {?} event
* @param {?} th
* @return {?}
*/
function (event, th) {
if (!this.config.resizeColumn) {
return;
}
this.th = th;
this.startOffset = th.offsetWidth - event.pageX;
this.event.emit({
event: Event.onColumnResizeMouseDown,
value: event,
});
};
/**
* @param {?} event
* @return {?}
*/
TableTHeadComponent.prototype.onMouseMove = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (!this.config.resizeColumn) {
return;
}
if (this.th && this.th.style) {
this.th.style.width = this.startOffset + event.pageX + 'px';
this.th.style.cursor = 'col-resize';
this.th.style['user-select'] = 'none';
}
};
/**
* @param {?} event
* @return {?}
*/
TableTHeadComponent.prototype.onMouseUp = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (!this.config.resizeColumn) {
return;
}
this.event.emit({
event: Event.onColumnResizeMouseUp,
value: event,
});
this.th.style.cursor = 'default';
this.th = undefined;
};
/**
* @param {?} column
* @return {?}
*/
TableTHeadComponent.prototype.showHeaderActionTemplateMenu = /**
* @param {?} column
* @return {?}
*/
function (column) {
if (!column.headerActionTemplate) {
console.error('Column [headerActionTemplate] property not defined');
}
if (this.openedHeaderActionTemplate === column.key) {
this.openedHeaderActionTemplate = null;
return;
}
this.openedHeaderActionTemplate = column.key;
};
/**
* @return {?}
*/
TableTHeadComponent.prototype.showMenu = /**
* @return {?}
*/
function () {
if (!this.additionalActionsTemplate) {
console.error('[additionalActionsTemplate] property not defined');
}
this.menuActive = !this.menuActive;
};
TableTHeadComponent.decorators = [
{ type: core.Component, args: [{
selector: '[table-thead]',
template: "<tr class=\"ngx-table__header\" *ngIf=\"config.headerEnabled && !config.columnReorder\">\n <th *ngIf=\"config.checkboxes || config.radio\" [style.width]=\"'3%'\">\n <ng-container\n *ngIf=\"selectAllTemplate && config.checkboxes\"\n [ngTemplateOutlet]=\"selectAllTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: onSelectAllBinded }\">\n </ng-container>\n <label class=\"ngx-form-checkbox\"\n for=\"selectAllCheckboxes\"\n *ngIf=\"!selectAllTemplate && config.checkboxes\">\n <input type=\"checkbox\" id=\"selectAllCheckboxes\" (change)=\"onSelectAll()\">\n <em class=\"ngx-form-icon\" id=\"selectAllCheckbox\"></em>\n </label>\n </th>\n <ng-container *ngFor=\"let column of columns; let colIndex = index; let last = last\">\n <th class=\"ngx-table__header-cell\"\n [class.pinned-left]=\"column.pinned\"\n [ngClass]=\"column.cssClass && column.cssClass.includeHeader ? column.cssClass.name : ''\"\n [style.left]=\"styleService.pinnedWidth(column.pinned, colIndex)\"\n #th\n [style.width]=\"getColumnWidth(column)\"\n (mousedown)=\"onMouseDown($event, th)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousemove)=\"onMouseMove($event)\">\n <div (click)=\"orderBy(column)\" style=\"display: inline\" [class.pointer]=\"isOrderEnabled(column)\">\n <div class=\"ngx-table__header-title\">{{ column.title }}<span> </span>\n <em class=\"ngx-icon ngx-icon-pin\" *ngIf=\"column.pinned\"></em>\n <div [style.display]=\"config.orderEnabled ? 'inline' : 'none' \">\n <em *ngIf=\"sortKey === column.key && this.sortState.get(sortKey) === 'asc'\"\n class=\"ngx-icon ngx-icon-arrow-up\">\n </em>\n <em *ngIf=\"sortKey === column.key && this.sortState.get(sortKey) === 'desc'\"\n class=\"ngx-icon ngx-icon-arrow-down\">\n </em>\n </div>\n </div>\n </div>\n <div class=\"ngx-dropdown\"\n *ngIf=\"!!column.headerActionTemplate\">\n <a class=\"ngx-btn ngx-btn-link\" (click)=\"showHeaderActionTemplateMenu(column)\">\n <span class=\"ngx-icon ngx-icon-more\"></span>\n </a>\n <div class=\"ngx-menu ngx-table__table-menu\"\n *ngIf=\"column.key === openedHeaderActionTemplate\">\n <ng-container\n [ngTemplateOutlet]=\"column.headerActionTemplate\">\n </ng-container>\n </div>\n </div>\n <div class=\"ngx-table__column-resizer\" *ngIf=\"config.resizeColumn && !last\"></div>\n </th>\n </ng-container>\n <th *ngIf=\"config.additionalActions || config.detailsTemplate || config.collapseAllRows || config.groupRows\"\n class=\"ngx-table__header-cell-additional-actions\">\n <div class=\"ngx-dropdown\"\n #additionalActionMenu\n *ngIf=\"config.additionalActions\">\n <a class=\"ngx-btn ngx-btn-link\" (click)=\"showMenu()\">\n <span class=\"ngx-icon ngx-icon-menu\"></span>\n </a>\n <ul class=\"ngx-menu ngx-table__table-menu\"\n *ngIf=\"menuActive\">\n <ng-container\n *ngIf=\"additionalActionsTemplate\"\n [ngTemplateOutlet]=\"additionalActionsTemplate\">\n </ng-container>\n </ul>\n </div>\n </th>\n</tr>\n<tr class=\"ngx-table__header ngx-table__header--draggable\"\n *ngIf=\"config.headerEnabled && config.columnReorder\"\n cdkDropList\n cdkDropListOrientation=\"horizontal\"\n (cdkDropListDropped)=\"columnDrop($event)\"\n>\n <th [style.width]=\"'3%'\">\n <ng-container\n *ngIf=\"selectAllTemplate && config.checkboxes\"\n [ngTemplateOutlet]=\"selectAllTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: onSelectAllBinded }\">\n </ng-container>\n <label class=\"ngx-form-checkbox\"\n for=\"selectAllCheckboxes\"\n *ngIf=\"!selectAllTemplate && config.checkboxes\">\n <input type=\"checkbox\" id=\"selectAllCheckboxesDrag\" (change)=\"onSelectAll()\">\n <em class=\"ngx-form-icon\" id=\"selectAllCheckboxDrag\"></em>\n </label>\n </th>\n <ng-container *ngFor=\"let column of columns; let colIndex = index; let last = last\">\n <th class=\"ngx-table__header-cell ngx-table__header-cell--draggable\"\n cdkDragLockAxis=\"x\"\n cdkDrag\n [class.pinned-left]=\"column.pinned\"\n [ngClass]=\"column.cssClass && column.cssClass.includeHeader ? column.cssClass.name : ''\"\n [style.left]=\"styleService.pinnedWidth(column.pinned, colIndex)\"\n #th\n [style.width]=\"getColumnWidth(column)\"\n (mousedown)=\"onMouseDown($event, th)\"\n (mouseup)=\"onMouseUp($event)\"\n (mousemove)=\"onMouseMove($event)\">\n <div (click)=\"orderBy(column)\" style=\"display: inline\"\n cdkDragHandle\n [class.pointer]=\"isOrderEnabled(column)\">\n <div class=\"ngx-table__header-title\">{{ column.title }}<span> </span>\n <em class=\"ngx-icon ngx-icon-pin\" *ngIf=\"column.pinned\"></em>\n <div [style.display]=\"config.orderEnabled ? 'inline' : 'none' \">\n <em *ngIf=\"sortKey === column.key && this.sortState.get(sortKey) === 'asc'\"\n class=\"ngx-icon ngx-icon-arrow-up\">\n </em>\n <em *ngIf=\"sortKey === column.key && this.sortState.get(sortKey) === 'desc'\"\n class=\"ngx-icon ngx-icon-arrow-down\">\n </em>\n </div>\n </div>\n </div>\n <div class=\"ngx-dropdown\"\n *ngIf=\"!!column.headerActionTemplate\">\n <a class=\"ngx-btn ngx-btn-link\" (click)=\"showHeaderActionTemplateMenu(column)\">\n <span class=\"ngx-icon ngx-icon-more\"></span>\n </a>\n <div class=\"ngx-menu ngx-table__table-menu\"\n *ngIf=\"column.key === openedHeaderActionTemplate\">\n <ng-container\n [ngTemplateOutlet]=\"column.headerActionTemplate\">\n </ng-container>\n </div>\n </div>\n <div class=\"ngx-table__column-resizer\" *ngIf=\"config.resizeColumn && !last\"></div>\n </th>\n </ng-container>\n <th *ngIf=\"config.additionalActions || config.detailsTemplate || config.collapseAllRows || config.groupRows\"\n class=\"ngx-table__header-cell-additional-actions\">\n <div class=\"ngx-dropdown\"\n #additionalActionMenu\n *ngIf=\"config.additionalActions\">\n <a class=\"ngx-btn ngx-btn-link\" (click)=\"showMenu()\">\n <span class=\"ngx-icon ngx-icon-menu\"></span>\n </a>\n <ul class=\"ngx-menu ngx-table__table-menu\"\n *ngIf=\"menuActive\">\n <ng-container\n *ngIf=\"additionalActionsTemplate\"\n [ngTemplateOutlet]=\"additionalActionsTemplate\">\n </ng-container>\n </ul>\n </div>\n </th>\n</tr>\n<tr *ngIf=\"config.searchEnabled && !filtersTemplate\"\n class=\"ngx-table__sort-header\">\n <th *ngIf=\"config.checkboxes || config.radio\"></th>\n <ng-container *ngFor=\"let column of columns; let colIndex = index\">\n <th\n [ngClass]=\"column.cssClass && column.cssClass.includeHeader ? column.cssClass.name : ''\"\n [class.pinned-left]=\"column.pinned\"\n [style.left]=\"styleService.pinnedWidth(column.pinned, colIndex)\">\n <table-header\n *ngIf=\"getColumnDefinition(column)\"\n (update)=\"onSearch($event)\"\n [column]=\"column\">\n </table-header>\n </th>\n </ng-container>\n <th *ngIf=\"config.additionalActions || config.detailsTemplate\"></th>\n</tr>\n<ng-container *ngIf=\"filtersTemplate\">\n <tr>\n <ng-container [ngTemplateOutlet]=\"filtersTemplate\">\n </ng-container>\n </tr>\n</ng-container>\n",
providers: [StyleService],
styles: ["\n .cdk-drag-preview {\n text-align: left;\n padding-top: 9px;\n padding-left: 4px;\n color: #50596c;\n border: 1px solid #e7e9ed;\n }\n "]
}] }
];
/** @nocollapse */
TableTHeadComponent.ctorParameters = function () { return [
{ type: StyleService }
]; };
TableTHeadComponent.propDecorators = {
config: [{ type: core.Input }],
columns: [{ type: core.Input }],
sortKey: [{ type: core.Input }],
sortState: [{ type: core.Input }],
selectAllTemplate: [{ type: core.Input }],
filtersTemplate: [{ type: core.Input }],
additionalActionsTemplate: [{ type: core.Input }],
filter: [{ type: core.Output }],
order: [{ type: core.Output }],
selectAll: [{ type: core.Output }],
event: [{ type: core.Output }],
th: [{ type: core.ViewChild, args: ['th', { static: false },] }],
additionalActionMenu: [{ type: core.ViewChild, args: ['additionalActionMenu', { static: false },] }],
onClick: [{ type: core.HostListener, args: ['document:click', ['$event.target'],] }]
};
return TableTHeadComponent;
}());
if (false) {
/** @type {?} */
TableTHeadComponent.prototype.menuActive;
/** @type {?} */
TableTHeadComponent.prototype.openedHeaderActionTemplate;
/** @type {?} */
TableTHeadComponent.prototype.startOffset;
/** @type {?} */
TableTHeadComponent.prototype.onSelectAllBinded;
/** @type {?} */
TableTHeadComponent.prototype.config;
/** @type {?} */
TableTHeadComponent.prototype.columns;
/** @type {?} */
TableTHeadComponent.prototype.sortKey;
/** @type {?} */
TableTHeadComponent.prototype.sortState;
/** @type {?} */
TableTHeadComponent.prototype.selectAllTemplate;
/** @type {?} */
TableTHeadComponent.prototype.filtersTemplate;
/** @type {?} */
TableTHeadComponent.prototype.additionalActionsTemplate;
/** @type {?} */
TableTHeadComponent.prototype.filter;
/** @type {?} */
TableTHeadComponent.prototype.order;
/** @type {?} */
TableTHeadComponent.prototype.selectAll;
/** @type {?} */
TableTHeadComponent.prototype.event;
/**
* @type {?}
* @private
*/
TableTHeadComponent.prototype.th;
/** @type {?} */
TableTHeadComponent.prototype.additionalActionMenu;
/** @type {?} */
TableTHeadComponent.prototype.styleService;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var BaseModule = /** @class */ (function () {
function BaseModule() {
}
BaseModule.decorators = [
{ type: core.NgModule, args: [{
declarations: [
BaseComponent,
HeaderComponent,
PaginationComponent,
TableTHeadComponent,
// Pipes
SearchPipe,
RenderPipe,
GlobalSearchPipe,
SortPipe,
],
imports: [
common.CommonModule,
ngxPagination.NgxPaginationModule,
dragDrop.DragDropModule,
scrolling.ScrollingModule,
],
exports: [BaseComponent],
},] }
];
return BaseModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var TableModule = /** @class */ (function () {
function TableModule() {
}
TableModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
common.CommonModule,
BaseModule,
],
bootstrap: [BaseComponent],
exports: [BaseComponent],
providers: [],
},] }
];
return TableModule;
}());
exports.API = API;
exports.DefaultConfig = DefaultConfig;
exports.Event = Event;
exports.STYLE = STYLE;
exports.THEME = THEME;
exports.TableModule = TableModule;
exports.ɵa = DefaultConfigService;
exports.ɵb = BaseModule;
exports.ɵc = BaseComponent;
exports.ɵd = GroupRowsService;
exports.ɵe = StyleService;
exports.ɵf = HeaderComponent;
exports.ɵg = PaginationComponent;
exports.ɵh = TableTHeadComponent;
exports.ɵi = SearchPipe;
exports.ɵj = RenderPipe;
exports.ɵk = GlobalSearchPipe;
exports.ɵl = SortPipe;
Object.defineProperty(exports, '__esModule', { value: true });
}));
//# sourceMappingURL=ngx-easy-table.umd.js.map