ng-color-scale
Version:
[](https://www.npmjs.com/package/ng-color-scale) [](https://npmjs.org/ng-color-scale)  {
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"]}