UNPKG

ng-color-scale

Version:

[![npm](https://img.shields.io/npm/v/ng-color-scale.svg)](https://www.npmjs.com/package/ng-color-scale) [![npm downloads](https://img.shields.io/npm/dm/ng-color-scale.svg)](https://npmjs.org/ng-color-scale) ![publish](https://github.com/eddrichjanzzen/ng-

222 lines 27.1 kB
import { __decorate } from "tslib"; import { Component, OnChanges, Input, OnInit, ChangeDetectionStrategy, SimpleChanges, ElementRef, HostListener, ViewEncapsulation } from '@angular/core'; import * as d3 from 'd3'; let NgColorScaleComponent = class NgColorScaleComponent { constructor(host) { this.host = host; this.minVal = -1; this.maxVal = 1; this.hideAxis = false; this.colorList = ["#9E0142", "#D53E4F", "#F46D43", "#FDAE61", "#FEE08B", "#FFFFBF", "#E6F598", "#ABDDA4", "#66C2A5", "#6AA84F", "#38761D"]; this._margin = { top: 50, right: 50, bottom: 30, left: 50 }; this._textHeight = 35; this._axisHeight = 45; this._axisOffset = 130; } ngOnChanges() { if (this._chart) { this._createChart(); } } ngOnInit() { this._id = 'id' + (new Date()).getTime(); if (this.data) { this._createChart(); } } _createChart() { d3.select(`#${this._id}`).remove(); this._width = this.host.nativeElement.clientWidth; this._height = this.host.nativeElement.clientHeight; this._barWidth = this._width - (this._margin.left + this._margin.right); this._svg = d3.select(this.host.nativeElement) .append('div') .attr('id', `${this._id}`) .attr('transform', `translate(${this._margin.left}, ${this._margin.top})`) .style('position', 'relative') .append("svg:svg") .attr("width", this._width) .attr("height", this._height); this._chart = this._svg.append('g') .attr('transform', `translate(${this._margin.left}, ${this._margin.top})`); this._xScale = d3.scaleLinear() .domain([this.minVal, this.maxVal]) .range([0, this._barWidth]); this._colors = d3.scaleLinear().domain([this.minVal, this.maxVal]).range(this.colorList); if (!this.hideAxis) { this._drawAxis(); } this._drawLabels(); this._drawcolorBar(); } _drawAxis() { var xAxis = d3.axisBottom(this._xScale) .tickPadding(5) .ticks(5); this._chart.append('g') .attr("class", "axis") .style("font-size", 12) .attr('transform', `translate(0, ${this._axisHeight + 5})`) .call(xAxis); } _drawcolorBar() { var tempColorList = this.colorList; var tempId = `${this._id}-grad`; var grad = this._chart.append('defs') .append('linearGradient') .attr('id', tempId) .attr('x1', '0%') .attr('x2', '100%') .attr('y1', '0%') .attr('y2', '0%'); grad.selectAll('stop') .data(tempColorList) .enter() .append('stop') .style('stop-color', function (d) { return d; }) .attr('offset', function (d, i) { return 100 * (i / (tempColorList.length - 1)) + '%'; }); var gradValue = `url(#${tempId})`; var tipId = this._id; var color_bar = this._chart.append('rect') .attr('class', 'bg-rect') .attr('rx', 5) .attr('ry', 5) .style('opacity', 1) .style('fill', gradValue) .attr('height', 15) .attr('width', this._barWidth) .attr('x', 0) .on("mouseover", function (d) { d3.select(`#${tipId} > div.tip`).transition() .duration(300) .style("opacity", .9); pickerTip.transition() .duration(300) .style("opacity", .9); d3.select(this).transition() .duration(150) .style("opacity", .8); }) .on("mouseout", function (d) { d3.select(`#${tipId} > div.tip`).transition() .duration(500) .style("opacity", 0); pickerTip.transition() .duration(500) .style("opacity", 0.7); d3.select(this).transition() .duration(500) .style("opacity", 1); }); var pickerTip = this._chart.append('rect') .attr('class', 'picker-tip') .attr('rx', 4) .attr('ry', 4) .style('fill', '#333') .style('opacity', 0.7) .attr('height', 25) .attr('width', 10) .attr('y', -5) .attr('x', this._xScale(this.data) - 5); d3.select(`#${this._id}`) .append('div') .attr('class', 'tip') .style('position', 'absolute') .style('border-radius', '10px') .style('background-color', '#e8f2fa') .style('padding', '10px') .style('top', `${-5}px`) .style('opacity', 0) .style('left', `${this._xScale(this.data) + 50}px`) .html(this.data.toFixed(2)); } _drawLabels() { //left label this._chart.append('text') .attr('x', 0) .attr('y', this._textHeight) .attr('text-anchor', 'middle') .attr('font-family', 'Roboto') .attr('font-weight', 200) .attr('class', 'left-label') .text(this.leftLabel); // right label this._chart.append('text') .attr('x', this._barWidth) .attr('y', this._textHeight) .attr('text-anchor', 'middle') .attr('font-family', 'Roboto') .attr('class', 'right-label') .text(this.rightLabel); // middle label this._chart.append('text') .attr('x', this._barWidth / 2) .attr('y', this._textHeight) .attr('font-family', 'Roboto') .attr('text-anchor', 'middle') .attr('class', 'middle-label') .text(this.middleLabel); // display meta d3.select(`#${this._id}`) .append('div') .style('position', 'absolute') .style('font-family', 'Roboto') .style('text-align', 'center') .style('width', '100%') .style('top', `${this._axisOffset}px`) .html(this.displayMeta); } _onResize(event) { this._createChart(); } }; NgColorScaleComponent.ctorParameters = () => [ { type: ElementRef } ]; __decorate([ Input() ], NgColorScaleComponent.prototype, "data", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "leftLabel", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "rightLabel", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "middleLabel", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "minVal", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "maxVal", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "hideAxis", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "colorList", void 0); __decorate([ Input() ], NgColorScaleComponent.prototype, "displayMeta", void 0); __decorate([ HostListener('window:resize', ['$event']) ], NgColorScaleComponent.prototype, "_onResize", null); NgColorScaleComponent = __decorate([ Component({ selector: 'ng-color-scale', template: "", changeDetection: ChangeDetectionStrategy.OnPush, styles: ["@import url(https://fonts.googleapis.com/css?family=Roboto:400,700);:host{width:100%;height:100%;min-height:150px;max-width:1500px;display:block;font-family:Roboto}"] }) ], NgColorScaleComponent); export { NgColorScaleComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-color-scale.component.js","sourceRoot":"ng://ng-color-scale/","sources":["lib/ng-color-scale.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnChanges, Input, OnInit, ChangeDetectionStrategy, SimpleChanges, ElementRef, HostListener, ViewEncapsulation} from '@angular/core';  \nimport * as d3 from 'd3';\n\n@Component({\n  selector: 'ng-color-scale',\n  templateUrl: './ng-color-scale.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  styleUrls: ['./ng-color-scale.component.scss']\n})\nexport class NgColorScaleComponent implements OnChanges {\n\n  @Input() data : number;\n  @Input() leftLabel: string;\n  @Input() rightLabel: string;\n  @Input() middleLabel: string;\n  @Input() minVal: number = -1;\n  @Input() maxVal: number = 1;\n  @Input() hideAxis: boolean = false;\n  @Input() colorList: string[] = [\"#9E0142\", \"#D53E4F\",\n                    \"#F46D43\", \"#FDAE61\",\n                    \"#FEE08B\", \"#FFFFBF\",\n                    \"#E6F598\", \"#ABDDA4\", \n                    \"#66C2A5\", \"#6AA84F\",\n                    \"#38761D\"]\n  @Input() displayMeta: string;\n\n  private _margin = {top: 50, right: 50, bottom: 30, left: 50};  \n  private _svg: any; \n  private _chart: any;\n  private _width: number;\n  private _height:number;\n  private _barWidth: number;\n  private _xScale: any;\n  private _colors: any;\n  private _textHeight = 35;\n  private _axisHeight = 45;\n  private _axisOffset = 130;\n  private _id: any;\n\n  constructor(\n    private host:ElementRef) {}\n\n  ngOnChanges() {\n    if (this._chart) {\n      this._createChart();\n    }\n  }\n\n  ngOnInit(){\n    this._id ='id' + (new Date()).getTime();\n    if(this.data){\n      this._createChart();\n    }\n  }\n\n  private _createChart(){\n    d3.select(`#${this._id}`).remove();  \n    \n    this._width = this.host.nativeElement.clientWidth;\n    this._height = this.host.nativeElement.clientHeight;\n    this._barWidth = this._width - (this._margin.left + this._margin.right)\n\n    this._svg = d3.select(this.host.nativeElement)\n          .append('div')\n          .attr('id', `${this._id}`)\n          .attr('transform', `translate(${this._margin.left}, ${this._margin.top})`)\n          .style('position', 'relative')\n          .append(\"svg:svg\") \n          .attr(\"width\", this._width)\n          .attr(\"height\", this._height)\n\n    this._chart = this._svg.append('g')  \n          .attr('transform', `translate(${this._margin.left}, ${this._margin.top})`);\n\n    this._xScale = d3.scaleLinear()\n        .domain([this.minVal, this.maxVal])\n        .range([0, this._barWidth])\n\n    this._colors = d3.scaleLinear().domain([this.minVal, this.maxVal]).range(<any[]>this.colorList);\n\n    if(!this.hideAxis){\n      this._drawAxis()\n    }\n\n    this._drawLabels();\n    this._drawcolorBar();\n  }\n\n  private _drawAxis(){\n      var xAxis = d3.axisBottom(this._xScale)\n        .tickPadding(5)\n        .ticks(5)\n\n      this._chart.append('g')\n        .attr(\"class\", \"axis\")\n        .style(\"font-size\", 12)\n        .attr('transform', `translate(0, ${this._axisHeight + 5})`)\n        .call(xAxis)\n  }\n\n  private _drawcolorBar(){\n      \n      var tempColorList = this.colorList\n      var tempId = `${this._id}-grad`;\n\n      var grad = this._chart.append('defs')\n        .append('linearGradient')\n        .attr('id', tempId)\n        .attr('x1', '0%')\n        .attr('x2', '100%')\n        .attr('y1', '0%')\n        .attr('y2', '0%');\n\n      grad.selectAll('stop')\n        .data(tempColorList)\n        .enter()\n        .append('stop')\n        .style('stop-color', function(d){ return d; })\n        .attr('offset', function(d,i){\n          return 100 * (i / (tempColorList.length - 1)) + '%';\n        })\n\n      var gradValue = `url(#${tempId})`;\n      var tipId = this._id\n\n      var color_bar = this._chart.append('rect')\n        .attr('class', 'bg-rect')\n        .attr('rx', 5)\n        .attr('ry', 5)\n        .style('opacity', 1)\n        .style('fill', gradValue)\n        .attr('height', 15)\n        .attr('width', this._barWidth)\n        .attr('x', 0)\n        .on(\"mouseover\", function(d) {   \n          d3.select(`#${tipId} > div.tip`).transition()\n            .duration(300)\n            .style(\"opacity\", .9);      \n          \n          pickerTip.transition()\n            .duration(300)    \n            .style(\"opacity\", .9);  \n\n          d3.select(this).transition()    \n            .duration(150)    \n            .style(\"opacity\", .8);      \n        })          \n        .on(\"mouseout\", function(d) {    \n          d3.select(`#${tipId} > div.tip`).transition()    \n              .duration(500)    \n              .style(\"opacity\", 0);\n\n          pickerTip.transition()    \n              .duration(500)    \n              .style(\"opacity\", 0.7);\n\n          d3.select(this).transition()    \n            .duration(500)    \n            .style(\"opacity\", 1);\n        });\n      \n\n      var pickerTip = this._chart.append('rect')\n        .attr('class', 'picker-tip')\n        .attr('rx', 4)\n        .attr('ry', 4)\n        .style('fill', '#333')\n        .style('opacity', 0.7)\n        .attr('height', 25)\n        .attr('width', 10)\n        .attr('y', -5)\n        .attr('x', this._xScale(this.data) -5)\n\n      d3.select(`#${this._id}`)\n        .append('div')\n        .attr('class', 'tip')\n        .style('position','absolute')\n        .style('border-radius', '10px')\n        .style('background-color', '#e8f2fa')\n        .style('padding', '10px')\n        .style('top', `${-5}px`)\n        .style('opacity', 0)\n        .style('left', `${this._xScale(this.data) +50}px`)\n        .html(this.data.toFixed(2))\n\n  }\n\n\n  private _drawLabels(){\n    //left label\n    this._chart.append('text')\n      .attr('x', 0)\n      .attr('y', this._textHeight)\n      .attr('text-anchor', 'middle')\n      .attr('font-family', 'Roboto')\n      .attr('font-weight', 200)\n      .attr('class', 'left-label')\n      .text(this.leftLabel);\n\n    // right label\n    this._chart.append('text')\n      .attr('x', this._barWidth)\n      .attr('y', this._textHeight)\n      .attr('text-anchor', 'middle')\n      .attr('font-family', 'Roboto')\n      .attr('class', 'right-label')\n      .text(this.rightLabel);\n\n    // middle label\n    this._chart.append('text')\n      .attr('x',this._barWidth/2)\n      .attr('y', this._textHeight)\n      .attr('font-family', 'Roboto')\n      .attr('text-anchor', 'middle')\n      .attr('class', 'middle-label')\n      .text(this.middleLabel);\n\n    // display meta\n    d3.select(`#${this._id}`)\n      .append('div')\n      .style('position','absolute')\n      .style('font-family', 'Roboto')\n      .style('text-align', 'center')\n      .style('width', '100%')    \n      .style('top', `${this._axisOffset}px`)\n      .html(this.displayMeta)\n      \n    }\n\n  @HostListener('window:resize', ['$event'])\n  public _onResize(event) {\n    this._createChart();\n  }\n\n\n}\n\n"]}