@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
105 lines • 15 kB
JavaScript
import * as tslib_1 from "tslib";
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* @link https://truedirective.com/
* @license MIT
*/
import { Component, Input, ElementRef, ViewChild, ChangeDetectorRef, Inject } from '@angular/core';
import { GridStateService } from './grid-state.service';
import { InternationalizationService } from './internationalization/internationalization.service';
import { ColumnType } from '@true-directive/base';
import { SummaryType } from '@true-directive/base';
import { Column } from '@true-directive/base';
var GridFooterCellComponent = /** @class */ (function () {
function GridFooterCellComponent(state, intl, elementRef, changeDetector) {
this.state = state;
this.intl = intl;
this.elementRef = elementRef;
this.changeDetector = changeDetector;
this._currentSummary = null;
this.summaryTypes = [
SummaryType.SUM, SummaryType.MIN, SummaryType.MAX,
SummaryType.COUNT, SummaryType.AVERAGE
];
}
GridFooterCellComponent.prototype.displayedValue = function (a) {
if (a.type != SummaryType.COUNT && this.column.format != '') {
return this.state.dataSource.displayedValue(this.column, a.value, null);
}
return a.value;
};
GridFooterCellComponent.prototype.canApply = function (t) {
if (t === SummaryType.SUM || t === SummaryType.AVERAGE) {
return this.column.type === ColumnType.NUMBER;
}
return true;
};
GridFooterCellComponent.prototype.hasAggr = function (t) {
return this._currentSummary != null && this._currentSummary.type === t;
};
Object.defineProperty(GridFooterCellComponent.prototype, "menuVisible", {
get: function () {
return this.menu.visible;
},
enumerable: true,
configurable: true
});
GridFooterCellComponent.prototype.menuClosed = function (e) {
this.elementRef.nativeElement.classList.remove('true-grid-btn-visible');
};
GridFooterCellComponent.prototype.menuShow = function (e) {
this.elementRef.nativeElement.classList.add('true-grid-btn-visible');
};
GridFooterCellComponent.prototype.setAggr = function (t) {
this.state.setSummary(this.column, t, this._currentSummary);
};
GridFooterCellComponent.prototype.addAggr = function (e, t) {
this.state.addSummary(this.column, t);
};
GridFooterCellComponent.prototype.toggleMenu = function (e, a) {
if (a === void 0) { a = null; }
var l = e.target.tagName === 'SPAN' ? e.target.parentElement : e.target;
if (l.parentElement !== this.elementRef.nativeElement) {
l = l.parentElement;
}
if (this.menuVisible) {
this.menu.closePopup();
}
else {
this._currentSummary = a;
this.menu.showByTarget(l, this.column.isNumeric ? 'AboveLeft' : 'AboveRight');
this.changeDetector.detectChanges();
}
};
tslib_1.__decorate([
Input('column'),
tslib_1.__metadata("design:type", Column)
], GridFooterCellComponent.prototype, "column", void 0);
tslib_1.__decorate([
ViewChild('btn', { static: false }),
tslib_1.__metadata("design:type", Object)
], GridFooterCellComponent.prototype, "btn", void 0);
tslib_1.__decorate([
ViewChild('menu', { static: false }),
tslib_1.__metadata("design:type", Object)
], GridFooterCellComponent.prototype, "menu", void 0);
GridFooterCellComponent = tslib_1.__decorate([
Component({
selector: 'true-grid-footer-cell',
template: "<div *ngFor=\"let a of column.summaries\"\r\n class=\"true-aggr\"\r\n [style.height.px]=\"state.st.rowHeight\"\r\n (click)=\"toggleMenu($event, a)\">\r\n <div>\r\n <span class=\"true-aggr-caption\">{{a.type.footerText | trueTranslate}} </span>{{displayedValue(a)}}\r\n </div>\r\n</div>\r\n<div\r\n class=\"true-footer-btn-container\"\r\n *ngIf=\"!column.isCheckbox && column.summaries.length === 0\">\r\n <div #btn class=\"true-grid-btn\" (click)=\"toggleMenu($event)\"><span class=\"true-icon-sigma\"></span></div>\r\n</div>\r\n\r\n<true-menu #menu\r\n (show)=\"menuShow($event)\"\r\n (closed)=\"menuClosed($event)\">\r\n <true-menu-item\r\n [hidden]=\"column.summaries.length === 0\"\r\n [true-menu-show]=\"submenu\"\r\n true-divide=\"true\"><span></span>{{'Add' | trueTranslate}}</true-menu-item>\r\n <true-menu-item\r\n *ngFor=\"let t of summaryTypes; let i=index\"\r\n [true-divide]=\"i == 0 && column.summaries.length > 0\"\r\n (itemClick)=\"setAggr(t)\"\r\n [disabled]=\"!canApply(t)\"><span [class.true-icon-ok]=\"hasAggr(t)\"></span>{{t.name | trueTranslate}}</true-menu-item>\r\n <true-menu-item (itemClick)=\"setAggr(null)\" true-divide=\"true\">\r\n <span [class.true-icon-ok]=\"column.summaries.length === 0\"></span>{{'None' | trueTranslate}}</true-menu-item>\r\n</true-menu>\r\n\r\n<true-menu #submenu>\r\n <true-menu-item\r\n *ngFor=\"let t of summaryTypes\"\r\n (itemClick)=\"addAggr($event, t)\"\r\n [disabled]=\"!canApply(t)\"><span></span>{{t.name | trueTranslate}}</true-menu-item>\r\n</true-menu>\r\n",
host: {
'[class.num]': 'column.isNumeric',
'[class.h100]': 'column.summaries.length<=1'
},
styles: [":host{display:block;overflow-x:hidden}.true-aggr{display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;-webkit-box-pack:start;justify-content:flex-start;-webkit-box-align:center;align-items:center}.true-aggr div{white-space:nowrap;overflow-x:hidden;text-overflow:ellipsis}:host.num .true-aggr{-webkit-box-pack:end;justify-content:flex-end}:host.h100{height:100%}:host.h100 .true-aggr{height:100%}.true-footer-btn-container{box-sizing:border-box;height:100%;width:100%;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row}:host:hover .true-footer-btn-container .true-grid-btn{visibility:visible}:host.num .true-footer-btn-container{-webkit-box-pack:end;justify-content:flex-end}"]
}),
tslib_1.__param(0, Inject('gridState')),
tslib_1.__metadata("design:paramtypes", [GridStateService,
InternationalizationService,
ElementRef,
ChangeDetectorRef])
], GridFooterCellComponent);
return GridFooterCellComponent;
}());
export { GridFooterCellComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-footer-cell.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/grid-footer-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         ChangeDetectorRef, Inject,\r\n         EventEmitter } from '@angular/core';\r\n\r\nimport { GridStateService } from './grid-state.service';\r\nimport { InternationalizationService } from './internationalization/internationalization.service';\r\nimport { ColumnType } from '@true-directive/base';\r\nimport { SummaryType, Summary } from '@true-directive/base';\r\nimport { Column } from '@true-directive/base';\r\n\r\n@Component({\r\n  selector: 'true-grid-footer-cell',\r\n  templateUrl: './grid-footer-cell.component.html',\r\n  styleUrls: ['./styles/grid-footer-cell.behavior.scss'],\r\n  host: {\r\n    '[class.num]': 'column.isNumeric',\r\n    '[class.h100]': 'column.summaries.length<=1'\r\n  }\r\n})\r\nexport class GridFooterCellComponent {\r\n\r\n  _currentSummary: Summary = null;\r\n\r\n  readonly summaryTypes = [\r\n    SummaryType.SUM, SummaryType.MIN, SummaryType.MAX,\r\n    SummaryType.COUNT, SummaryType.AVERAGE\r\n  ];\r\n\r\n  public displayedValue(a: Summary): string {\r\n    if (a.type != SummaryType.COUNT && this.column.format != '') {\r\n      return this.state.dataSource.displayedValue(this.column, a.value, null);\r\n    }\r\n    return a.value;\r\n  }\r\n\r\n  public canApply(t: SummaryType): boolean {\r\n    if (t === SummaryType.SUM || t === SummaryType.AVERAGE) {\r\n      return this.column.type === ColumnType.NUMBER;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  public hasAggr(t: SummaryType): boolean {\r\n    return this._currentSummary != null && this._currentSummary.type === t;\r\n  }\r\n\r\n  @Input('column')\r\n  public column: Column;\r\n\r\n  @ViewChild('btn', {static: false})\r\n  btn: any;\r\n\r\n  @ViewChild('menu', {static: false})\r\n  menu: any;\r\n\r\n  get menuVisible() {\r\n    return this.menu.visible;\r\n  }\r\n\r\n  menuClosed(e: any) {\r\n    this.elementRef.nativeElement.classList.remove('true-grid-btn-visible');\r\n  }\r\n\r\n  menuShow(e: any) {\r\n    this.elementRef.nativeElement.classList.add('true-grid-btn-visible');\r\n  }\r\n\r\n  setAggr(t: SummaryType) {\r\n    this.state.setSummary(this.column, t, this._currentSummary);\r\n  }\r\n\r\n  addAggr(e: any, t: SummaryType) {\r\n    this.state.addSummary(this.column, t);\r\n  }\r\n\r\n  toggleMenu(e: any, a: Summary = null) {\r\n\r\n    let l = e.target.tagName === 'SPAN' ? e.target.parentElement : e.target;\r\n    if (l.parentElement !== this.elementRef.nativeElement) {\r\n      l = l.parentElement;\r\n    }\r\n\r\n    if (this.menuVisible) {\r\n      this.menu.closePopup();\r\n    } else {\r\n      this._currentSummary = a;\r\n      this.menu.showByTarget(l, this.column.isNumeric ? 'AboveLeft' : 'AboveRight');\r\n      this.changeDetector.detectChanges();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    @Inject('gridState') public state: GridStateService,\r\n    public intl: InternationalizationService,\r\n    private elementRef: ElementRef,\r\n    private changeDetector: ChangeDetectorRef) { }\r\n}\r\n"]}