UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

166 lines 20 kB
import * as tslib_1 from "tslib"; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Component, Input, Output, ElementRef, ViewChild, EventEmitter, Inject } from '@angular/core'; import { BaseComponent } from './base.component'; import { GridStateService } from './grid-state.service'; import { SortType } from '@true-directive/base'; import { Column } from '@true-directive/base'; var GridHeaderCellComponent = /** @class */ (function (_super) { tslib_1.__extends(GridHeaderCellComponent, _super); function GridHeaderCellComponent(state, elementRef) { var _this = _super.call(this) || this; _this.state = state; _this.elementRef = elementRef; _this.toggleCheckColumn = new EventEmitter(); _this.captionMouseDown = new EventEmitter(); _this.captionMouseUp = new EventEmitter(); _this.captionTouchStart = new EventEmitter(); return _this; } // Иконка фильтра // Если фильтр включен, то иконка кнопки показывается всегда и подсвечивается GridHeaderCellComponent.prototype.isFiltered = function () { return this.state.dataSource.getFilter(this.column) != null; }; GridHeaderCellComponent.prototype.setState = function (s) { if (s === 'btn-visible') this.caption.nativeElement.classList.toggle('true-grid-btn-visible', true); }; GridHeaderCellComponent.prototype.removeState = function (s) { if (s === 'btn-visible') this.caption.nativeElement.classList.toggle('true-grid-btn-visible', false); }; GridHeaderCellComponent.prototype.btnIconClass = function () { var classes = ''; if (this.isFiltered()) { classes += this.state.sta.filterBtnIconClass_active; } else { classes += this.state.sta.filterBtnIconClass; } return classes; }; // Отсортирована ли колонка GridHeaderCellComponent.prototype.isSorted = function (col) { return this.sorted !== null; }; Object.defineProperty(GridHeaderCellComponent.prototype, "sorted", { get: function () { var res = this.state.dataSource.sortedByField(this.column.fieldName); return !res ? null : res.sortType; }, enumerable: true, configurable: true }); Object.defineProperty(GridHeaderCellComponent.prototype, "sortedUp", { get: function () { return this.sorted === SortType.ASC; }, enumerable: true, configurable: true }); Object.defineProperty(GridHeaderCellComponent.prototype, "sortedDown", { get: function () { return this.sorted === SortType.DESC; }, enumerable: true, configurable: true }); // Если отсортирован, то как?.. GridHeaderCellComponent.prototype.sortIndicatorClass = function () { if (this.sortedUp) { return this.state.sta.sortedUpIconClass; } if (this.sortedDown) { return this.state.sta.sortedDownIconClass; } return ''; }; GridHeaderCellComponent.prototype.toggleCheck = function (e) { this.toggleCheckColumn.emit(e); e.preventDefault(); }; GridHeaderCellComponent.prototype.headerMouseDown = function (e) { e.stopPropagation(); }; GridHeaderCellComponent.prototype.mouseDown = function (e) { this.captionMouseDown.emit(e); }; GridHeaderCellComponent.prototype.mouseUp = function (e) { this.captionMouseUp.emit(e); }; GridHeaderCellComponent.prototype.touchStart = function (e) { this.captionTouchStart.emit(e); }; GridHeaderCellComponent.prototype.contextMenu = function (e) { this.state.headerContextMenu(e, this.column); }; // Клик по кнопке фильтра GridHeaderCellComponent.prototype.btnTouch = function (e) { this.state.showFilter(e, this.column); e.stopPropagation(); if (e.cancelable) { e.preventDefault(); } }; // Клик по кнопке фильтра GridHeaderCellComponent.prototype.btnClick = function (e) { this.state.showFilter(e, this.column); }; // Прерываем MouseDown, чтобы не произошло сортировки GridHeaderCellComponent.prototype.btnMouseDown = function (e) { e.stopPropagation(); e.preventDefault(); }; GridHeaderCellComponent.prototype.ngAfterContentInit = function () { this.addTouchListeners(this.caption.nativeElement); }; tslib_1.__decorate([ Input('column'), tslib_1.__metadata("design:type", Column) ], GridHeaderCellComponent.prototype, "column", void 0); tslib_1.__decorate([ Output('toggleCheckColumn'), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "toggleCheckColumn", void 0); tslib_1.__decorate([ Output('captionMouseDown'), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "captionMouseDown", void 0); tslib_1.__decorate([ Output('captionMouseUp'), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "captionMouseUp", void 0); tslib_1.__decorate([ Output('captionTouchStart'), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "captionTouchStart", void 0); tslib_1.__decorate([ ViewChild('caption', { static: true }), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "caption", void 0); tslib_1.__decorate([ ViewChild('btn', { static: true }), tslib_1.__metadata("design:type", Object) ], GridHeaderCellComponent.prototype, "btn", void 0); GridHeaderCellComponent = tslib_1.__decorate([ Component({ selector: 'true-grid-header-cell', template: "<div #caption\r\n class=\"true-header-cell__caption\"\r\n [class.true-header-cell__checkbox]=\"column.isCheckbox\"\r\n [class.true-header-cell__filtered]=\"isFiltered()\"\r\n (contextmenu)=\"contextMenu($event)\"\r\n (touchstart)=\"touchStart($event)\"\r\n (mousedown)=\"mouseDown($event)\"\r\n (mouseup)=\"mouseUp($event)\">\r\n\r\n <div *ngIf=\"column.isCheckbox\"\r\n [ngClass]=\"state.settings.headerCheckboxClass(column.isChecked)\"\r\n (click)=\"toggleCheck($event)\"></div>\r\n <div *ngIf=\"isSorted(column)\"\r\n class=\"true-header-cell__sort-indicator\" [ngClass]=\"sortIndicatorClass()\"></div>\r\n <div *ngIf=\"!column.isCheckbox\"\r\n [class.true-header-cell__txt_nowrap]=\"!state.settings.headerWordWrap\"\r\n class=\"true-header-cell__txt\">\r\n {{column.caption | trueTranslate}}\r\n </div>\r\n\r\n <div #btn *ngIf=\"!column.isCheckbox && state.settings.allowFilter && (column.allowFilter || isFiltered())\"\r\n class=\"true-grid-btn\"\r\n (click)=\"btnClick($event)\"\r\n (touchstart)=\"btnTouch($event)\"\r\n (mousedown)=\"btnMouseDown($event)\">\r\n <span [ngClass]=\"btnIconClass()\"></span>\r\n </div>\r\n</div>\r\n", host: { 'class': 'true-header-cell' }, styles: [":host{cursor:default;display:block;height:100%}.true-header-cell__caption{height:100%;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;-webkit-box-pack:center;justify-content:center;-webkit-box-align:stretch;align-items:stretch;overflow-x:hidden}.true-header-cell__caption.true-header-cell__checkbox{-webkit-box-align:center;align-items:center;justify-content:space-around}.true-header-cell__caption .true-header-cell__sort-indicator{text-align:center;-ms-grid-row-align:center;align-self:center}.true-header-cell__caption .true-header-cell__txt{-ms-grid-row-align:center;align-self:center;overflow-x:hidden;-webkit-box-flex:1;flex-grow:1;overflow-y:hidden}.true-header-cell__caption .true-header-cell__txt_nowrap{white-space:nowrap;text-overflow:ellipsis}.true-grid-btn-visible .true-grid-btn,.true-header-cell__caption:hover .true-grid-btn{opacity:.2;visibility:visible}.true-header-cell__filtered .true-grid-btn{visibility:visible!important;opacity:1!important}"] }), tslib_1.__param(0, Inject('gridState')), tslib_1.__metadata("design:paramtypes", [GridStateService, ElementRef]) ], GridHeaderCellComponent); return GridHeaderCellComponent; }(BaseComponent)); export { GridHeaderCellComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-header-cell.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/grid-header-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { NgModule, Component, Input, Output, ElementRef, ViewChild,\r\n         EventEmitter, Inject } from '@angular/core';\r\n\r\nimport { BaseComponent } from './base.component';\r\nimport { GridStateService } from './grid-state.service';\r\nimport { ColumnType, GridPart } from '@true-directive/base';\r\nimport { SortType } from '@true-directive/base';\r\nimport { Column } from '@true-directive/base';\r\n\r\n@Component({\r\n  selector: 'true-grid-header-cell',\r\n  templateUrl: './grid-header-cell.component.html',\r\n  host: {\r\n    'class': 'true-header-cell'\r\n  },\r\n  styleUrls: ['./styles/grid-header-cell.behavior.scss']\r\n})\r\nexport class GridHeaderCellComponent extends BaseComponent {\r\n\r\n  @Input('column')\r\n  public column: Column;\r\n\r\n  @Output('toggleCheckColumn')\r\n  toggleCheckColumn = new EventEmitter<any>();\r\n\r\n  @Output('captionMouseDown')\r\n  captionMouseDown = new EventEmitter<any>();\r\n\r\n  @Output('captionMouseUp')\r\n  captionMouseUp = new EventEmitter<any>();\r\n\r\n  @Output('captionTouchStart')\r\n  captionTouchStart = new EventEmitter<any>();\r\n\r\n  @ViewChild('caption', {static: true})\r\n  caption: any;\r\n\r\n  @ViewChild('btn', {static: true})\r\n  btn: any;\r\n\r\n  // Иконка фильтра\r\n  // Если фильтр включен, то иконка кнопки показывается всегда и подсвечивается\r\n  isFiltered(): boolean {\r\n    return this.state.dataSource.getFilter(this.column) != null;\r\n  }\r\n\r\n  public setState(s: string) {\r\n    if (s === 'btn-visible')\r\n      this.caption.nativeElement.classList.toggle('true-grid-btn-visible', true);\r\n  }\r\n\r\n  public removeState(s: string) {\r\n    if (s === 'btn-visible')\r\n      this.caption.nativeElement.classList.toggle('true-grid-btn-visible', false);\r\n  }\r\n\r\n  btnIconClass() {\r\n    let classes = '';\r\n    if (this.isFiltered()) {\r\n      classes += this.state.sta.filterBtnIconClass_active;\r\n    } else {\r\n      classes += this.state.sta.filterBtnIconClass;\r\n    }\r\n    return classes;\r\n  }\r\n\r\n  // Отсортирована ли колонка\r\n  public isSorted(col: Column): boolean {\r\n    return this.sorted !== null;\r\n  }\r\n\r\n  public get sorted(): SortType {\r\n    const res = this.state.dataSource.sortedByField(this.column.fieldName);\r\n    return !res ? null : res.sortType;\r\n  }\r\n\r\n  public get sortedUp(): boolean {\r\n    return this.sorted === SortType.ASC;\r\n  }\r\n\r\n  public get sortedDown(): boolean {\r\n    return this.sorted === SortType.DESC;\r\n  }\r\n\r\n  // Если отсортирован, то как?..\r\n  sortIndicatorClass() {\r\n\r\n    if (this.sortedUp) {\r\n      return this.state.sta.sortedUpIconClass;\r\n    }\r\n\r\n    if (this.sortedDown) {\r\n      return this.state.sta.sortedDownIconClass;\r\n    }\r\n\r\n    return '';\r\n  }\r\n\r\n  toggleCheck(e: any) {\r\n    this.toggleCheckColumn.emit(e);\r\n    e.preventDefault();\r\n  }\r\n\r\n  headerMouseDown(e: any) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  mouseDown(e: any) {\r\n    this.captionMouseDown.emit(e);\r\n  }\r\n\r\n  mouseUp(e: any) {\r\n    this.captionMouseUp.emit(e);\r\n  }\r\n\r\n  touchStart(e: any) {\r\n    this.captionTouchStart.emit(e);\r\n  }\r\n\r\n  contextMenu(e: any) {\r\n    this.state.headerContextMenu(e, this.column);\r\n  }\r\n\r\n  // Клик по кнопке фильтра\r\n  btnTouch(e: any) {\r\n    this.state.showFilter(e, this.column);\r\n    e.stopPropagation();\r\n    if (e.cancelable) {\r\n      e.preventDefault();\r\n    }\r\n  }\r\n\r\n  // Клик по кнопке фильтра\r\n  btnClick(e: any) {\r\n    this.state.showFilter(e, this.column);\r\n  }\r\n\r\n  // Прерываем MouseDown, чтобы не произошло сортировки\r\n  btnMouseDown(e: any) {\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.addTouchListeners(this.caption.nativeElement);\r\n  }\r\n\r\n  constructor(\r\n    @Inject('gridState') public state: GridStateService,\r\n    public elementRef: ElementRef) {\r\n      super();\r\n    }\r\n}\r\n"]}