@junte/ui
Version:
Quality Angular UI components kit
150 lines • 17.6 kB
JavaScript
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';
var ChartComponent = /** @class */ (function () {
function ChartComponent(logger) {
var _this = this;
this.logger = logger;
this.host = 'jnt-chart-host';
this.ui = UI;
this._widthMark = 100;
this.heightIndicator = 55;
this.widthPolygon = 50;
this.onChange = function () { return _this.logger.debug('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.debug('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
this.updated = new EventEmitter();
}
ChartComponent_1 = ChartComponent;
Object.defineProperty(ChartComponent.prototype, "widthMark", {
get: function () {
return this._widthMark;
},
set: function (width) {
this._widthMark = Math.min(width, 60);
},
enumerable: true,
configurable: true
});
Object.defineProperty(ChartComponent.prototype, "selected", {
get: function () {
return this._selected;
},
set: function (value) {
var 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);
},
enumerable: true,
configurable: true
});
Object.defineProperty(ChartComponent.prototype, "heightSvg", {
get: function () {
return this.heightIndicator + (this.heightIndicator * this.indicators.length);
},
enumerable: true,
configurable: true
});
ChartComponent.prototype.writeValue = function (value) {
this._selected = value;
};
ChartComponent.prototype.trackByFn = function (index, indicator) {
return indicator.data.id || index;
};
var ChartComponent_1;
ChartComponent.ctorParameters = function () { return [
{ 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(function () { return ChartComponent_1; }),
multi: true
}
]
}),
__metadata("design:paramtypes", [NGXLogger])
], ChartComponent);
return 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"]}