/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, EventEmitter, Output, HostBinding, HostListener, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core'; import { MouseEvent } from '../../events'; import { SortType } from '../../types/sort.type'; import { SelectionType } from '../../types/selection.type'; import { nextSortDir } from '../../utils/sort'; import { SortDirection } from '../../types/sort-direction.type'; var DataTableHeaderCellComponent = /** @class */ (function () { function DataTableHeaderCellComponent(cd) { this.cd = cd; this.sort = new EventEmitter(); this.select = new EventEmitter(); this.columnContextmenu = new EventEmitter(false); this.sortFn = this.onSort.bind(this); this.selectFn = this.select.emit.bind(this.select); this.cellContext = { column: this.column, sortDir: this.sortDir, sortFn: this.sortFn, allRowsSelected: this.allRowsSelected, selectFn: this.selectFn }; } Object.defineProperty(DataTableHeaderCellComponent.prototype, "allRowsSelected", { get: /** * @return {?} */ function () { return this._allRowsSelected; }, set: /** * @param {?} value * @return {?} */ function (value) { this._allRowsSelected = value; this.cellContext.allRowsSelected = value; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "column", { get: /** * @return {?} */ function () { return this._column; }, set: /** * @param {?} column * @return {?} */ function (column) { this._column = column; this.cellContext.column = column; this.cd.markForCheck(); }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "sorts", { get: /** * @return {?} */ function () { return this._sorts; }, set: /** * @param {?} val * @return {?} */ function (val) { this._sorts = val; this.sortDir = this.calcSortDir(val); this.cellContext.sortDir = this.sortDir; this.sortClass = this.calcSortClass(this.sortDir); this.cd.markForCheck(); }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "columnCssClasses", { get: /** * @return {?} */ function () { var e_1, _a; /** @type {?} */ var cls = 'datatable-header-cell'; if (this.column.sortable) cls += ' sortable'; if (this.column.resizeable) cls += ' resizeable'; if (this.column.headerClass) { if (typeof this.column.headerClass === 'string') { cls += ' ' + this.column.headerClass; } else if (typeof this.column.headerClass === 'function') { /** @type {?} */ var res = this.column.headerClass({ column: this.column }); if (typeof res === 'string') { cls += res; } else if (typeof res === 'object') { /** @type {?} */ var keys = Object.keys(res); try { for (var keys_1 = tslib_1.__values(keys), keys_1_1 = keys_1.next(); !keys_1_1.done; keys_1_1 = keys_1.next()) { var k = keys_1_1.value; if (res[k] === true) cls += " " + k; } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (keys_1_1 && !keys_1_1.done && (_a = keys_1.return)) _a.call(keys_1); } finally { if (e_1) throw e_1.error; } } } } } /** @type {?} */ var sortDir = this.sortDir; if (sortDir) { cls += " sort-active sort-" + sortDir; } return cls; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "name", { get: /** * @return {?} */ function () { // guaranteed to have a value by setColumnDefaults() in column-helper.ts return this.column.headerTemplate === undefined ? this.column.name : undefined; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "minWidth", { get: /** * @return {?} */ function () { return this.column.minWidth; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "maxWidth", { get: /** * @return {?} */ function () { return this.column.maxWidth; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "width", { get: /** * @return {?} */ function () { return this.column.width; }, enumerable: true, configurable: true }); Object.defineProperty(DataTableHeaderCellComponent.prototype, "isCheckboxable", { get: /** * @return {?} */ function () { return this.column.checkboxable && this.column.headerCheckboxable && this.selectionType === SelectionType.checkbox; }, enumerable: true, configurable: true }); /** * @param {?} $event * @return {?} */ DataTableHeaderCellComponent.prototype.onContextmenu = /** * @param {?} $event * @return {?} */ function ($event) { this.columnContextmenu.emit({ event: $event, column: this.column }); }; /** * @param {?} sorts * @return {?} */ DataTableHeaderCellComponent.prototype.calcSortDir = /** * @param {?} sorts * @return {?} */ function (sorts) { var _this = this; if (sorts && this.column) { /** @type {?} */ var sort = sorts.find((/** * @param {?} s * @return {?} */ function (s) { return s.prop === _this.column.prop; })); if (sort) return sort.dir; } }; /** * @return {?} */ DataTableHeaderCellComponent.prototype.onSort = /** * @return {?} */ function () { if (!this.column.sortable) return; /** @type {?} */ var newValue = nextSortDir(this.sortType, this.sortDir); this.sort.emit({ column: this.column, prevValue: this.sortDir, newValue: newValue }); }; /** * @param {?} sortDir * @return {?} */ DataTableHeaderCellComponent.prototype.calcSortClass = /** * @param {?} sortDir * @return {?} */ function (sortDir) { if (sortDir === SortDirection.asc) { return "sort-btn sort-asc " + this.sortAscendingIcon; } else if (sortDir === SortDirection.desc) { return "sort-btn sort-desc " + this.sortDescendingIcon; } else { return "sort-btn"; } }; DataTableHeaderCellComponent.decorators = [ { type: Component, args: [{ selector: 'datatable-header-cell', template: "\n
\n \n \n \n \n \n \n \n \n \n
\n ", host: { class: 'datatable-header-cell' }, changeDetection: ChangeDetectionStrategy.OnPush }] } ]; /** @nocollapse */ DataTableHeaderCellComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef } ]; }; DataTableHeaderCellComponent.propDecorators = { sortType: [{ type: Input }], sortAscendingIcon: [{ type: Input }], sortDescendingIcon: [{ type: Input }], isTarget: [{ type: Input }], targetMarkerTemplate: [{ type: Input }], targetMarkerContext: [{ type: Input }], allRowsSelected: [{ type: Input }], selectionType: [{ type: Input }], column: [{ type: Input }], headerHeight: [{ type: HostBinding, args: ['style.height.px',] }, { type: Input }], sorts: [{ type: Input }], sort: [{ type: Output }], select: [{ type: Output }], columnContextmenu: [{ type: Output }], columnCssClasses: [{ type: HostBinding, args: ['class',] }], name: [{ type: HostBinding, args: ['attr.title',] }], minWidth: [{ type: HostBinding, args: ['style.minWidth.px',] }], maxWidth: [{ type: HostBinding, args: ['style.maxWidth.px',] }], width: [{ type: HostBinding, args: ['style.width.px',] }], onContextmenu: [{ type: HostListener, args: ['contextmenu', ['$event'],] }] }; return DataTableHeaderCellComponent; }()); export { DataTableHeaderCellComponent }; if (false) { /** @type {?} */ DataTableHeaderCellComponent.prototype.sortType; /** @type {?} */ DataTableHeaderCellComponent.prototype.sortAscendingIcon; /** @type {?} */ DataTableHeaderCellComponent.prototype.sortDescendingIcon; /** @type {?} */ DataTableHeaderCellComponent.prototype.isTarget; /** @type {?} */ DataTableHeaderCellComponent.prototype.targetMarkerTemplate; /** @type {?} */ DataTableHeaderCellComponent.prototype.targetMarkerContext; /** @type {?} */ DataTableHeaderCellComponent.prototype._allRowsSelected; /** @type {?} */ DataTableHeaderCellComponent.prototype.selectionType; /** @type {?} */ DataTableHeaderCellComponent.prototype.headerHeight; /** @type {?} */ DataTableHeaderCellComponent.prototype.sort; /** @type {?} */ DataTableHeaderCellComponent.prototype.select; /** @type {?} */ DataTableHeaderCellComponent.prototype.columnContextmenu; /** @type {?} */ DataTableHeaderCellComponent.prototype.sortFn; /** @type {?} */ DataTableHeaderCellComponent.prototype.sortClass; /** @type {?} */ DataTableHeaderCellComponent.prototype.sortDir; /** @type {?} */ DataTableHeaderCellComponent.prototype.selectFn; /** @type {?} */ DataTableHeaderCellComponent.prototype.cellContext; /** * @type {?} * @private */ DataTableHeaderCellComponent.prototype._column; /** * @type {?} * @private */ DataTableHeaderCellComponent.prototype._sorts; /** * @type {?} * @private */ DataTableHeaderCellComponent.prototype.cd; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-cell.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/header/header-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  EventEmitter,\n  Output,\n  HostBinding,\n  HostListener,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef\n} from '@angular/core';\nimport { MouseEvent } from '../../events';\nimport { SortType } from '../../types/sort.type';\nimport { SelectionType } from '../../types/selection.type';\nimport { TableColumn } from '../../types/table-column.type';\nimport { nextSortDir } from '../../utils/sort';\nimport { SortDirection } from '../../types/sort-direction.type';\n\n@Component({\n  selector: 'datatable-header-cell',\n  template: `\n    <div class=\"datatable-header-cell-template-wrap\">\n      <ng-template\n        *ngIf=\"isTarget\"\n        [ngTemplateOutlet]=\"targetMarkerTemplate\"\n        [ngTemplateOutletContext]=\"targetMarkerContext\"\n      >\n      </ng-template>\n      <label *ngIf=\"isCheckboxable\" class=\"datatable-checkbox\">\n        <input type=\"checkbox\" [checked]=\"allRowsSelected\" (change)=\"select.emit(!allRowsSelected)\" />\n      </label>\n      <span *ngIf=\"!column.headerTemplate\" class=\"datatable-header-cell-wrapper\">\n        <span class=\"datatable-header-cell-label draggable\" (click)=\"onSort()\" [innerHTML]=\"name\"> </span>\n      </span>\n      <ng-template\n        *ngIf=\"column.headerTemplate\"\n        [ngTemplateOutlet]=\"column.headerTemplate\"\n        [ngTemplateOutletContext]=\"cellContext\"\n      >\n      </ng-template>\n      <span (click)=\"onSort()\" [class]=\"sortClass\"> </span>\n    </div>\n  `,\n  host: {\n    class: 'datatable-header-cell'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataTableHeaderCellComponent {\n  @Input() sortType: SortType;\n  @Input() sortAscendingIcon: string;\n  @Input() sortDescendingIcon: string;\n\n  @Input() isTarget: boolean;\n  @Input() targetMarkerTemplate: any;\n  @Input() targetMarkerContext: any;\n\n  _allRowsSelected: boolean;\n\n  @Input() set allRowsSelected(value) {\n    this._allRowsSelected = value;\n    this.cellContext.allRowsSelected = value;\n  }\n  get allRowsSelected() {\n    return this._allRowsSelected;\n  }\n\n  @Input() selectionType: SelectionType;\n\n  @Input() set column(column: TableColumn) {\n    this._column = column;\n    this.cellContext.column = column;\n    this.cd.markForCheck();\n  }\n\n  get column(): TableColumn {\n    return this._column;\n  }\n\n  @HostBinding('style.height.px')\n  @Input()\n  headerHeight: number;\n\n  @Input() set sorts(val: any[]) {\n    this._sorts = val;\n    this.sortDir = this.calcSortDir(val);\n    this.cellContext.sortDir = this.sortDir;\n    this.sortClass = this.calcSortClass(this.sortDir);\n    this.cd.markForCheck();\n  }\n\n  get sorts(): any[] {\n    return this._sorts;\n  }\n\n  @Output() sort: EventEmitter<any> = new EventEmitter();\n  @Output() select: EventEmitter<any> = new EventEmitter();\n  @Output() columnContextmenu = new EventEmitter<{ event: MouseEvent; column: any }>(false);\n\n  @HostBinding('class')\n  get columnCssClasses(): any {\n    let cls = 'datatable-header-cell';\n\n    if (this.column.sortable) cls += ' sortable';\n    if (this.column.resizeable) cls += ' resizeable';\n    if (this.column.headerClass) {\n      if (typeof this.column.headerClass === 'string') {\n        cls += ' ' + this.column.headerClass;\n      } else if (typeof this.column.headerClass === 'function') {\n        const res = this.column.headerClass({\n          column: this.column\n        });\n\n        if (typeof res === 'string') {\n          cls += res;\n        } else if (typeof res === 'object') {\n          const keys = Object.keys(res);\n          for (const k of keys) {\n            if (res[k] === true) cls += ` ${k}`;\n          }\n        }\n      }\n    }\n\n    const sortDir = this.sortDir;\n    if (sortDir) {\n      cls += ` sort-active sort-${sortDir}`;\n    }\n\n    return cls;\n  }\n\n  @HostBinding('attr.title')\n  get name(): string {\n    // guaranteed to have a value by setColumnDefaults() in column-helper.ts\n    return this.column.headerTemplate === undefined ? this.column.name : undefined;\n  }\n\n  @HostBinding('style.minWidth.px')\n  get minWidth(): number {\n    return this.column.minWidth;\n  }\n\n  @HostBinding('style.maxWidth.px')\n  get maxWidth(): number {\n    return this.column.maxWidth;\n  }\n\n  @HostBinding('style.width.px')\n  get width(): number {\n    return this.column.width;\n  }\n\n  get isCheckboxable(): boolean {\n    return this.column.checkboxable && this.column.headerCheckboxable && this.selectionType === SelectionType.checkbox;\n  }\n\n  sortFn = this.onSort.bind(this);\n  sortClass: string;\n  sortDir: SortDirection;\n  selectFn = this.select.emit.bind(this.select);\n\n  cellContext: any = {\n    column: this.column,\n    sortDir: this.sortDir,\n    sortFn: this.sortFn,\n    allRowsSelected: this.allRowsSelected,\n    selectFn: this.selectFn\n  };\n\n  private _column: TableColumn;\n  private _sorts: any[];\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  @HostListener('contextmenu', ['$event'])\n  onContextmenu($event: MouseEvent): void {\n    this.columnContextmenu.emit({ event: $event, column: this.column });\n  }\n\n  calcSortDir(sorts: any[]): any {\n    if (sorts && this.column) {\n      const sort = sorts.find((s: any) => {\n        return s.prop === this.column.prop;\n      });\n\n      if (sort) return sort.dir;\n    }\n  }\n\n  onSort(): void {\n    if (!this.column.sortable) return;\n\n    const newValue = nextSortDir(this.sortType, this.sortDir);\n    this.sort.emit({\n      column: this.column,\n      prevValue: this.sortDir,\n      newValue\n    });\n  }\n\n  calcSortClass(sortDir: SortDirection): string {\n    if (sortDir === SortDirection.asc) {\n      return `sort-btn sort-asc ${this.sortAscendingIcon}`;\n    } else if (sortDir === SortDirection.desc) {\n      return `sort-btn sort-desc ${this.sortDescendingIcon}`;\n    } else {\n      return `sort-btn`;\n    }\n  }\n}\n"]}