UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

99 lines 14.2 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, 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'; let GridFooterCellComponent = class GridFooterCellComponent { constructor(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 ]; } displayedValue(a) { if (a.type != SummaryType.COUNT && this.column.format != '') { return this.state.dataSource.displayedValue(this.column, a.value, null); } return a.value; } canApply(t) { if (t === SummaryType.SUM || t === SummaryType.AVERAGE) { return this.column.type === ColumnType.NUMBER; } return true; } hasAggr(t) { return this._currentSummary != null && this._currentSummary.type === t; } get menuVisible() { return this.menu.visible; } menuClosed(e) { this.elementRef.nativeElement.classList.remove('true-grid-btn-visible'); } menuShow(e) { this.elementRef.nativeElement.classList.add('true-grid-btn-visible'); } setAggr(t) { this.state.setSummary(this.column, t, this._currentSummary); } addAggr(e, t) { this.state.addSummary(this.column, t); } toggleMenu(e, a = null) { let 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}}&nbsp;</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); 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"]}