UNPKG

@junte/ui

Version:

Quality Angular UI components kit

135 lines 16.3 kB
var ChartComponent_1; import { __decorate, __metadata } from "tslib"; import { Component, ContentChildren, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { NGXLogger } from 'ngx-logger'; import { State } from '../../core/enums/state'; import { PropertyApi } from '../../core/decorators/api'; import { UI } from '../../core/enums/ui'; import { isEqual } from '../../core/utils/equal'; import { ChartIndicatorComponent } from './chart-indicator'; let ChartComponent = ChartComponent_1 = class ChartComponent { constructor(logger) { this.logger = logger; this.host = 'jnt-chart-host'; this.ui = UI; this._widthMark = 100; this.heightIndicator = 55; this.widthPolygon = 50; this.onChange = () => this.logger.debug('value accessor is not registered'); this.onTouched = () => this.logger.debug('value accessor is not registered'); this.registerOnChange = fn => this.onChange = fn; this.registerOnTouched = fn => this.onTouched = fn; this.onBlur = () => this.onTouched(); this.updated = new EventEmitter(); } set widthMark(width) { this._widthMark = Math.min(width, 60); } get widthMark() { return this._widthMark; } set selected(value) { let isSame; if (!!this.keyField && !!this._selected && !!value) { isSame = this._selected[this.keyField] === value[this.keyField]; } else { isSame = isEqual(this._selected, value); } this._selected = !isSame ? value : null; this.onChange(!!this._selected ? (!!this.keyField ? this._selected[this.keyField] : this._selected) : null); this.updated.emit(this._selected); } get selected() { return this._selected; } get heightSvg() { return this.heightIndicator + (this.heightIndicator * this.indicators.length); } writeValue(value) { this._selected = value; } trackByFn(index, indicator) { return indicator.data.id || index; } }; ChartComponent.ctorParameters = () => [ { type: NGXLogger } ]; __decorate([ HostBinding('attr.host'), __metadata("design:type", Object) ], ChartComponent.prototype, "host", void 0); __decorate([ Input(), __metadata("design:type", String) ], ChartComponent.prototype, "keyField", void 0); __decorate([ PropertyApi({ description: 'Title of the charts group', type: 'string' }), Input(), __metadata("design:type", String) ], ChartComponent.prototype, "title", void 0); __decorate([ PropertyApi({ description: 'Name of metric for the charts', type: 'string' }), Input(), __metadata("design:type", String) ], ChartComponent.prototype, "metric", void 0); __decorate([ PropertyApi({ description: 'Chart state', path: 'ui.state', options: [State.loading] }), Input(), __metadata("design:type", String) ], ChartComponent.prototype, "state", void 0); __decorate([ ContentChildren(ChartIndicatorComponent), __metadata("design:type", QueryList) ], ChartComponent.prototype, "indicators", void 0); __decorate([ Input(), __metadata("design:type", Object) ], ChartComponent.prototype, "heightIndicator", void 0); __decorate([ Input(), __metadata("design:type", Object) ], ChartComponent.prototype, "widthPolygon", void 0); __decorate([ HostListener('blur'), __metadata("design:type", Object) ], ChartComponent.prototype, "onBlur", void 0); __decorate([ Output('selected'), __metadata("design:type", Object) ], ChartComponent.prototype, "updated", void 0); __decorate([ Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Number]) ], ChartComponent.prototype, "widthMark", null); ChartComponent = ChartComponent_1 = __decorate([ Component({ selector: 'jnt-chart', template: "<div child-of=\"jnt-chart-host\" data-wrapper>\n <table child-of=\"jnt-chart-host\" >\n <thead child-of=\"jnt-chart-host\" >\n <tr child-of=\"jnt-chart-host\" [style.height.px]=\"heightIndicator\" [style.min-height.px]=\"heightIndicator\">\n <th child-of=\"jnt-chart-host\" >\n {{title}}\n </th>\n <th child-of=\"jnt-chart-host\" colspan=\"2\">\n {{metric}}\n </th>\n </tr>\n </thead>\n <tbody child-of=\"jnt-chart-host\" >\n <ng-container *ngIf=\"indicators.length; else loadingTemplate\">\n <tr child-of=\"jnt-chart-host\" *ngFor=\"let indicator of indicators; trackBy: trackByFn\"\n (click)=\"selected = indicator.data\"\n [attr.selected]=\"(!!keyField && !!selected\n ? selected[keyField] === indicator.data[keyField]\n : (selected === indicator.data))\"\n [style.height.px]=\"heightIndicator\"\n [style.max-height.px]=\"heightIndicator\"\n [style.min-height.px]=\"heightIndicator\">\n <td child-of=\"jnt-chart-host\" >\n <ng-container *ngIf=\"indicator.titleTemplate; else indicatorTitle\">\n <div child-of=\"jnt-chart-host\" data-content [style.max-height.px]=\"heightIndicator - 1\">\n <ng-container *ngTemplateOutlet=\"indicator.titleTemplate; context: indicator\"></ng-container>\n </div>\n </ng-container>\n <ng-template #indicatorTitle>\n {{indicator.title}}\n </ng-template>\n </td>\n <td child-of=\"jnt-chart-host\" >\n {{indicator.label}}\n </td>\n <td child-of=\"jnt-chart-host\" [style.background-color]=\"indicator.color | lightenDarken : -20\">\n <span child-of=\"jnt-chart-host\" [style.color]=\"indicator.color | lightenDarken : -20 | textBrightness\">\n {{indicator.value | number: '1.0-0'}}%\n </span>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</div>\n\n<svg child-of=\"jnt-chart-host\" *ngIf=\"indicators.length\"\n [style.min-width]=\"widthMark + widthPolygon\"\n [attr.width]=\"widthMark + widthPolygon\"\n [attr.height]=\"heightSvg\" xmlns=\"http://www.w3.org/2000/svg\">\n\n <ng-container *ngFor=\"let indicator of indicators; trackBy: trackByFn; let i = index; let first = first\">\n <polygon child-of=\"jnt-chart-host\" [attr.points]=\"'0 ' + (first ? heightIndicator : heightIndicator * (i + 1)) + ' ' + widthPolygon + ' ' + (first ? 0 : (i - 1 | sumIndicators: indicators) | percentToNumber: heightSvg) + ' ' + widthPolygon + ' ' + ((i | sumIndicators: indicators) | percentToNumber: heightSvg) + ' 0 ' + heightIndicator * (i + 2)\"\n [attr.fill]=\"indicator.color | lightenDarken: 10\"></polygon>\n <rect child-of=\"jnt-chart-host\" [attr.x]=\"widthPolygon\"\n [attr.y]=\"first ? 0 : (i - 1 | sumIndicators: indicators) | percentToNumber: heightSvg\"\n [attr.width]=\"widthMark\"\n [attr.height]=\"indicator.value | percentToNumber : heightSvg\"\n [attr.fill]=\"indicator.color\">\n </rect>\n </ng-container>\n\n</svg>\n\n<ng-template #loadingTemplate>\n <tr child-of=\"jnt-chart-host\" data-nodata>\n <td child-of=\"jnt-chart-host\" [attr.colspan]=\"3\">\n <jnt-skeleton child-of=\"jnt-chart-host\" *ngIf=\"state === ui.state.loading; else noDataTemplate\" [lines]=\"5\"></jnt-skeleton>\n <ng-template #noDataTemplate>\n <jnt-icon child-of=\"jnt-chart-host\" [icon]=\"ui.icons.neutral\"></jnt-icon>\n </ng-template>\n </td>\n </tr>\n</ng-template>", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => ChartComponent_1), multi: true } ] }), __metadata("design:paramtypes", [NGXLogger]) ], ChartComponent); export { ChartComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/dynamic/chart/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  Output,\n  QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { State } from '../../core/enums/state';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { UI } from '../../core/enums/ui';\nimport { isEqual } from '../../core/utils/equal';\nimport { ChartIndicatorComponent } from './chart-indicator';\n\n@Component({\n  selector: 'jnt-chart',\n  templateUrl: './chart.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ChartComponent),\n      multi: true\n    }\n  ]\n})\nexport class ChartComponent implements ControlValueAccessor {\n\n  @HostBinding('attr.host') readonly host = 'jnt-chart-host';\n\n  ui = UI;\n\n  private _selected: number;\n  private _widthMark = 100;\n\n  @Input() keyField: string;\n\n  @PropertyApi({\n    description: 'Title of the charts group',\n    type: 'string'\n  })\n  @Input()\n  title: string;\n\n  @PropertyApi({\n    description: 'Name of metric for the charts',\n    type: 'string'\n  })\n  @Input()\n  metric: string;\n\n  @PropertyApi({\n    description: 'Chart state',\n    path: 'ui.state',\n    options: [State.loading]\n  })\n  @Input()\n  state: State;\n\n  @ContentChildren(ChartIndicatorComponent)\n  indicators: QueryList<ChartIndicatorComponent>;\n\n  @Input()\n  heightIndicator = 55;\n\n  @Input()\n  widthPolygon = 50;\n\n  onChange: (value: any) => void = () => this.logger.debug('value accessor is not registered');\n  onTouched: () => void = () => this.logger.debug('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  @Output('selected')\n  updated = new EventEmitter<any>();\n\n  @Input()\n  set widthMark(width: number) {\n    this._widthMark = Math.min(width, 60);\n  }\n\n  get widthMark() {\n    return this._widthMark;\n  }\n\n  set selected(value: any) {\n    let isSame: boolean;\n    if (!!this.keyField && !!this._selected && !!value) {\n      isSame = this._selected[this.keyField] === value[this.keyField];\n    } else {\n      isSame = isEqual(this._selected, value);\n    }\n\n    this._selected = !isSame ? value : null;\n    this.onChange(!!this._selected\n      ? (!!this.keyField ? this._selected[this.keyField] : this._selected)\n      : null);\n    this.updated.emit(this._selected);\n  }\n\n  get selected() {\n    return this._selected;\n  }\n\n  get heightSvg() {\n    return this.heightIndicator + (this.heightIndicator * this.indicators.length);\n  }\n\n  constructor(private logger: NGXLogger) {\n  }\n\n  writeValue(value: any): void {\n    this._selected = value;\n  }\n\n  trackByFn(index, indicator) {\n    return indicator.data.id || index;\n  }\n}\n"]}