ngx-easy-table
Version:
Angular easy table
273 lines • 26.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, HostListener, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
import { Event } from '../..';
import { StyleService } from '../../services/style.service';
import { moveItemInArray } from '@angular/cdk/drag-drop';
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 EventEmitter();
this.order = new EventEmitter();
this.selectAll = new EventEmitter();
this.event = new 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) {
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: 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: Input }],
columns: [{ type: Input }],
sortKey: [{ type: Input }],
sortState: [{ type: Input }],
selectAllTemplate: [{ type: Input }],
filtersTemplate: [{ type: Input }],
additionalActionsTemplate: [{ type: Input }],
filter: [{ type: Output }],
order: [{ type: Output }],
selectAll: [{ type: Output }],
event: [{ type: Output }],
th: [{ type: ViewChild, args: ['th', { static: false },] }],
additionalActionMenu: [{ type: ViewChild, args: ['additionalActionMenu', { static: false },] }],
onClick: [{ type: HostListener, args: ['document:click', ['$event.target'],] }]
};
return TableTHeadComponent;
}());
export { 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;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thead.component.js","sourceRoot":"ng://ngx-easy-table/","sources":["lib/components/thead/thead.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { Columns, Config, Event } from '../..';\nimport { StyleService } from '../../services/style.service';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: '[table-thead]',\n  templateUrl: './thead.component.html',\n  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  `],\n  providers: [StyleService],\n})\nexport class TableTHeadComponent {\n  public menuActive = false;\n  public openedHeaderActionTemplate: string | null = null;\n  public startOffset;\n  public onSelectAllBinded = this.onSelectAll.bind(this);\n\n  @Input() config: Config;\n  @Input() columns: Columns[];\n  @Input() sortKey;\n  @Input() sortState;\n  @Input() selectAllTemplate;\n  @Input() filtersTemplate;\n  @Input() additionalActionsTemplate: TemplateRef<void>;\n  @Output() readonly filter = new EventEmitter<Array<{ key: string; value: string }>>();\n  @Output() readonly order = new EventEmitter<Columns>();\n  @Output() readonly selectAll = new EventEmitter<void>();\n  @Output() readonly event = new EventEmitter<{ event: string, value: any }>();\n  @ViewChild('th', { static: false }) private th;\n  @ViewChild('additionalActionMenu', { static: false }) additionalActionMenu;\n  @HostListener('document:click', ['$event.target'])\n  public onClick(targetElement: any): void {\n    if (this.additionalActionMenu && !this.additionalActionMenu.nativeElement.contains(targetElement)) {\n      this.menuActive = false;\n    }\n  }\n\n  constructor(\n    public readonly styleService: StyleService,\n  ) {\n\n  }\n\n  getColumnDefinition(column: Columns): boolean {\n    return column.searchEnabled || typeof column.searchEnabled === 'undefined';\n  }\n\n  orderBy(column: Columns): void {\n    this.order.emit(column);\n  }\n\n  isOrderEnabled(column: Columns): boolean {\n    const columnOrderEnabled = column.orderEnabled === undefined ? true : !!column.orderEnabled;\n    return this.config.orderEnabled && columnOrderEnabled;\n  }\n\n  columnDrop(event: CdkDragDrop<string[]>): void {\n    moveItemInArray(this.columns, event.previousIndex, event.currentIndex);\n  }\n\n  onSearch($event: Array<{ key: string; value: string }>): void {\n    this.filter.emit($event);\n  }\n\n  getColumnWidth(column: any): string | null {\n    if (column.width) {\n      return column.width;\n    }\n    return this.config.fixedColumnWidth ? 100 / this.columns.length + '%' : null;\n  }\n\n  onSelectAll(): void {\n    this.selectAll.emit();\n  }\n\n  onMouseDown(event: MouseEvent, th: HTMLTableHeaderCellElement): void {\n    if (!this.config.resizeColumn) {\n      return;\n    }\n    this.th = th;\n    this.startOffset = th.offsetWidth - event.pageX;\n    this.event.emit({\n      event: Event.onColumnResizeMouseDown,\n      value: event,\n    });\n  }\n\n  onMouseMove(event: MouseEvent): void {\n    if (!this.config.resizeColumn) {\n      return;\n    }\n    if (this.th && this.th.style) {\n      this.th.style.width = this.startOffset + event.pageX + 'px';\n      this.th.style.cursor = 'col-resize';\n      this.th.style['user-select'] = 'none';\n    }\n  }\n\n  onMouseUp(event: MouseEvent): void {\n    if (!this.config.resizeColumn) {\n      return;\n    }\n    this.event.emit({\n      event: Event.onColumnResizeMouseUp,\n      value: event,\n    });\n    this.th.style.cursor = 'default';\n    this.th = undefined;\n  }\n\n  showHeaderActionTemplateMenu(column: Columns): void {\n    if (!column.headerActionTemplate) {\n      console.error('Column [headerActionTemplate] property not defined');\n    }\n    if (this.openedHeaderActionTemplate === column.key) {\n      this.openedHeaderActionTemplate = null;\n      return;\n    }\n    this.openedHeaderActionTemplate = column.key;\n  }\n\n  showMenu(): void {\n    if (!this.additionalActionsTemplate) {\n      console.error('[additionalActionsTemplate] property not defined');\n    }\n    this.menuActive = !this.menuActive;\n  }\n}\n"]}