header-cell.component.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Input, EventEmitter, Output, HostBinding, HostListener, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';
  6. import { MouseEvent } from '../../events';
  7. import { SortType } from '../../types/sort.type';
  8. import { SelectionType } from '../../types/selection.type';
  9. import { nextSortDir } from '../../utils/sort';
  10. import { SortDirection } from '../../types/sort-direction.type';
  11. export class DataTableHeaderCellComponent {
  12. /**
  13. * @param {?} cd
  14. */
  15. constructor(cd) {
  16. this.cd = cd;
  17. this.sort = new EventEmitter();
  18. this.select = new EventEmitter();
  19. this.columnContextmenu = new EventEmitter(false);
  20. this.sortFn = this.onSort.bind(this);
  21. this.selectFn = this.select.emit.bind(this.select);
  22. this.cellContext = {
  23. column: this.column,
  24. sortDir: this.sortDir,
  25. sortFn: this.sortFn,
  26. allRowsSelected: this.allRowsSelected,
  27. selectFn: this.selectFn
  28. };
  29. }
  30. /**
  31. * @param {?} value
  32. * @return {?}
  33. */
  34. set allRowsSelected(value) {
  35. this._allRowsSelected = value;
  36. this.cellContext.allRowsSelected = value;
  37. }
  38. /**
  39. * @return {?}
  40. */
  41. get allRowsSelected() {
  42. return this._allRowsSelected;
  43. }
  44. /**
  45. * @param {?} column
  46. * @return {?}
  47. */
  48. set column(column) {
  49. this._column = column;
  50. this.cellContext.column = column;
  51. this.cd.markForCheck();
  52. }
  53. /**
  54. * @return {?}
  55. */
  56. get column() {
  57. return this._column;
  58. }
  59. /**
  60. * @param {?} val
  61. * @return {?}
  62. */
  63. set sorts(val) {
  64. this._sorts = val;
  65. this.sortDir = this.calcSortDir(val);
  66. this.cellContext.sortDir = this.sortDir;
  67. this.sortClass = this.calcSortClass(this.sortDir);
  68. this.cd.markForCheck();
  69. }
  70. /**
  71. * @return {?}
  72. */
  73. get sorts() {
  74. return this._sorts;
  75. }
  76. /**
  77. * @return {?}
  78. */
  79. get columnCssClasses() {
  80. /** @type {?} */
  81. let cls = 'datatable-header-cell';
  82. if (this.column.sortable)
  83. cls += ' sortable';
  84. if (this.column.resizeable)
  85. cls += ' resizeable';
  86. if (this.column.headerClass) {
  87. if (typeof this.column.headerClass === 'string') {
  88. cls += ' ' + this.column.headerClass;
  89. }
  90. else if (typeof this.column.headerClass === 'function') {
  91. /** @type {?} */
  92. const res = this.column.headerClass({
  93. column: this.column
  94. });
  95. if (typeof res === 'string') {
  96. cls += res;
  97. }
  98. else if (typeof res === 'object') {
  99. /** @type {?} */
  100. const keys = Object.keys(res);
  101. for (const k of keys) {
  102. if (res[k] === true)
  103. cls += ` ${k}`;
  104. }
  105. }
  106. }
  107. }
  108. /** @type {?} */
  109. const sortDir = this.sortDir;
  110. if (sortDir) {
  111. cls += ` sort-active sort-${sortDir}`;
  112. }
  113. return cls;
  114. }
  115. /**
  116. * @return {?}
  117. */
  118. get name() {
  119. // guaranteed to have a value by setColumnDefaults() in column-helper.ts
  120. return this.column.headerTemplate === undefined ? this.column.name : undefined;
  121. }
  122. /**
  123. * @return {?}
  124. */
  125. get minWidth() {
  126. return this.column.minWidth;
  127. }
  128. /**
  129. * @return {?}
  130. */
  131. get maxWidth() {
  132. return this.column.maxWidth;
  133. }
  134. /**
  135. * @return {?}
  136. */
  137. get width() {
  138. return this.column.width;
  139. }
  140. /**
  141. * @return {?}
  142. */
  143. get isCheckboxable() {
  144. return this.column.checkboxable && this.column.headerCheckboxable && this.selectionType === SelectionType.checkbox;
  145. }
  146. /**
  147. * @param {?} $event
  148. * @return {?}
  149. */
  150. onContextmenu($event) {
  151. this.columnContextmenu.emit({ event: $event, column: this.column });
  152. }
  153. /**
  154. * @param {?} sorts
  155. * @return {?}
  156. */
  157. calcSortDir(sorts) {
  158. if (sorts && this.column) {
  159. /** @type {?} */
  160. const sort = sorts.find((/**
  161. * @param {?} s
  162. * @return {?}
  163. */
  164. (s) => {
  165. return s.prop === this.column.prop;
  166. }));
  167. if (sort)
  168. return sort.dir;
  169. }
  170. }
  171. /**
  172. * @return {?}
  173. */
  174. onSort() {
  175. if (!this.column.sortable)
  176. return;
  177. /** @type {?} */
  178. const newValue = nextSortDir(this.sortType, this.sortDir);
  179. this.sort.emit({
  180. column: this.column,
  181. prevValue: this.sortDir,
  182. newValue
  183. });
  184. }
  185. /**
  186. * @param {?} sortDir
  187. * @return {?}
  188. */
  189. calcSortClass(sortDir) {
  190. if (sortDir === SortDirection.asc) {
  191. return `sort-btn sort-asc ${this.sortAscendingIcon}`;
  192. }
  193. else if (sortDir === SortDirection.desc) {
  194. return `sort-btn sort-desc ${this.sortDescendingIcon}`;
  195. }
  196. else {
  197. return `sort-btn`;
  198. }
  199. }
  200. }
  201. DataTableHeaderCellComponent.decorators = [
  202. { type: Component, args: [{
  203. selector: 'datatable-header-cell',
  204. template: `
  205. <div class="datatable-header-cell-template-wrap">
  206. <ng-template
  207. *ngIf="isTarget"
  208. [ngTemplateOutlet]="targetMarkerTemplate"
  209. [ngTemplateOutletContext]="targetMarkerContext"
  210. >
  211. </ng-template>
  212. <label *ngIf="isCheckboxable" class="datatable-checkbox">
  213. <input type="checkbox" [checked]="allRowsSelected" (change)="select.emit(!allRowsSelected)" />
  214. </label>
  215. <span *ngIf="!column.headerTemplate" class="datatable-header-cell-wrapper">
  216. <span class="datatable-header-cell-label draggable" (click)="onSort()" [innerHTML]="name"> </span>
  217. </span>
  218. <ng-template
  219. *ngIf="column.headerTemplate"
  220. [ngTemplateOutlet]="column.headerTemplate"
  221. [ngTemplateOutletContext]="cellContext"
  222. >
  223. </ng-template>
  224. <span (click)="onSort()" [class]="sortClass"> </span>
  225. </div>
  226. `,
  227. host: {
  228. class: 'datatable-header-cell'
  229. },
  230. changeDetection: ChangeDetectionStrategy.OnPush
  231. }] }
  232. ];
  233. /** @nocollapse */
  234. DataTableHeaderCellComponent.ctorParameters = () => [
  235. { type: ChangeDetectorRef }
  236. ];
  237. DataTableHeaderCellComponent.propDecorators = {
  238. sortType: [{ type: Input }],
  239. sortAscendingIcon: [{ type: Input }],
  240. sortDescendingIcon: [{ type: Input }],
  241. isTarget: [{ type: Input }],
  242. targetMarkerTemplate: [{ type: Input }],
  243. targetMarkerContext: [{ type: Input }],
  244. allRowsSelected: [{ type: Input }],
  245. selectionType: [{ type: Input }],
  246. column: [{ type: Input }],
  247. headerHeight: [{ type: HostBinding, args: ['style.height.px',] }, { type: Input }],
  248. sorts: [{ type: Input }],
  249. sort: [{ type: Output }],
  250. select: [{ type: Output }],
  251. columnContextmenu: [{ type: Output }],
  252. columnCssClasses: [{ type: HostBinding, args: ['class',] }],
  253. name: [{ type: HostBinding, args: ['attr.title',] }],
  254. minWidth: [{ type: HostBinding, args: ['style.minWidth.px',] }],
  255. maxWidth: [{ type: HostBinding, args: ['style.maxWidth.px',] }],
  256. width: [{ type: HostBinding, args: ['style.width.px',] }],
  257. onContextmenu: [{ type: HostListener, args: ['contextmenu', ['$event'],] }]
  258. };
  259. if (false) {
  260. /** @type {?} */
  261. DataTableHeaderCellComponent.prototype.sortType;
  262. /** @type {?} */
  263. DataTableHeaderCellComponent.prototype.sortAscendingIcon;
  264. /** @type {?} */
  265. DataTableHeaderCellComponent.prototype.sortDescendingIcon;
  266. /** @type {?} */
  267. DataTableHeaderCellComponent.prototype.isTarget;
  268. /** @type {?} */
  269. DataTableHeaderCellComponent.prototype.targetMarkerTemplate;
  270. /** @type {?} */
  271. DataTableHeaderCellComponent.prototype.targetMarkerContext;
  272. /** @type {?} */
  273. DataTableHeaderCellComponent.prototype._allRowsSelected;
  274. /** @type {?} */
  275. DataTableHeaderCellComponent.prototype.selectionType;
  276. /** @type {?} */
  277. DataTableHeaderCellComponent.prototype.headerHeight;
  278. /** @type {?} */
  279. DataTableHeaderCellComponent.prototype.sort;
  280. /** @type {?} */
  281. DataTableHeaderCellComponent.prototype.select;
  282. /** @type {?} */
  283. DataTableHeaderCellComponent.prototype.columnContextmenu;
  284. /** @type {?} */
  285. DataTableHeaderCellComponent.prototype.sortFn;
  286. /** @type {?} */
  287. DataTableHeaderCellComponent.prototype.sortClass;
  288. /** @type {?} */
  289. DataTableHeaderCellComponent.prototype.sortDir;
  290. /** @type {?} */
  291. DataTableHeaderCellComponent.prototype.selectFn;
  292. /** @type {?} */
  293. DataTableHeaderCellComponent.prototype.cellContext;
  294. /**
  295. * @type {?}
  296. * @private
  297. */
  298. DataTableHeaderCellComponent.prototype._column;
  299. /**
  300. * @type {?}
  301. * @private
  302. */
  303. DataTableHeaderCellComponent.prototype._sorts;
  304. /**
  305. * @type {?}
  306. * @private
  307. */
  308. DataTableHeaderCellComponent.prototype.cd;
  309. }
  310. //# 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"]}