@senx/warpview
Version:
WarpView Elements
234 lines • 48 kB
JavaScript
/*
* Copyright 2021 SenX S.A.S.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
import { Component, ElementRef, EventEmitter, Input, NgZone, Output, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';
import { WarpViewComponent } from '../warp-view-component';
import { SizeService } from '../../services/resize.service';
import { Logger } from '../../utils/logger';
import deepEqual from 'deep-equal';
import { ChartLib } from '../../utils/chart-lib';
import { ColorLib } from '../../utils/color-lib';
import * as d3 from 'd3';
import eventDrops from 'event-drops';
import { GTSLib } from '../../utils/gts.lib';
import moment from 'moment-timezone';
import { select } from 'd3-selection';
import * as i0 from "@angular/core";
import * as i1 from "../../services/resize.service";
import * as i2 from "../warp-view-spinner/warp-view-spinner.component";
import * as i3 from "@angular/common";
export class WarpViewEventDropComponent extends WarpViewComponent {
constructor(el, renderer, sizeService, ngZone) {
super(el, renderer, sizeService, ngZone);
this.el = el;
this.renderer = renderer;
this.sizeService = sizeService;
this.ngZone = ngZone;
this.pointHover = new EventEmitter();
this.warpViewChartResize = new EventEmitter();
this.chartDraw = new EventEmitter();
this.boundsDidChange = new EventEmitter();
this.visibility = [];
this.maxTick = Number.MIN_VALUE;
this.minTick = Number.MAX_VALUE;
this.visibleGtsId = [];
this._type = 'drops';
this.eventConf = {
d3,
axis: {
verticalGrid: true,
tickPadding: 6,
},
line: {
height: 20,
},
indicator: false,
label: {
text: row => row.name,
},
metaballs: {
blurDeviation: 7
},
drop: {
radius: 4,
date: d => d.date.toDate(),
color: d => d.color,
onMouseOver: g => {
this.LOG.debug(['onMouseOver'], g);
this.pointHover.emit({
x: d3.event.offsetX,
y: d3.event.offsetY
});
const t = d3.select(this.toolTip.nativeElement);
t.transition()
.duration(200)
.style('opacity', 1)
.style('pointer-events', 'auto');
t.html(`<div class="tooltip-body">
<b class="tooltip-date">${this._options.timeMode === 'timestamp'
? g.date
: (g.date.toISOString() || '')}</b>
<div><i class="chip" style="background-color: ${g.color};border: 2px solid ${g.color};"></i>
${GTSLib.formatLabel(g.name)}: <span class="value">${g.value}</span>
</div></div>`)
.style('left', `${d3.event.offsetX + 10}px`)
.style('top', `${d3.event.offsetY + 10}px`);
},
onMouseOut: () => {
select(this.toolTip.nativeElement)
.transition()
.duration(500)
.style('opacity', 0)
.style('pointer-events', 'none');
},
},
};
this.LOG = new Logger(WarpViewEventDropComponent, this._debug);
}
set type(type) {
this._type = type;
this.drawChart();
}
set hiddenData(hiddenData) {
const previousVisibility = JSON.stringify(this.visibility);
this.LOG.debug(['hiddenData', 'previousVisibility'], previousVisibility);
this._hiddenData = hiddenData;
this.visibility = [];
this.visibleGtsId.forEach(id => this.visibility.push(hiddenData.indexOf(id) < 0 && (id !== -1)));
this.LOG.debug(['hiddenData', 'hiddendygraphfullv'], this.visibility);
const newVisibility = JSON.stringify(this.visibility);
this.LOG.debug(['hiddenData', 'json'], previousVisibility, newVisibility);
if (previousVisibility !== newVisibility) {
this.drawChart();
this.LOG.debug(['hiddendygraphtrig', 'destroy'], 'redraw by visibility change');
}
}
ngOnInit() {
this._options = this._options || this.defOptions;
}
ngOnDestroy() {
if (!!this.elemChart) {
select(this.elemChart.nativeElement).remove();
}
}
update(options, refresh) {
this.LOG.debug(['onOptions', 'before'], this._options, options);
if (!deepEqual(options, this._options)) {
this.LOG.debug(['options', 'changed'], options);
this._options = ChartLib.mergeDeep(this._options, options);
}
this.drawChart();
}
updateBounds(min, max) {
this.LOG.debug(['updateBounds'], min, max, this._options);
this._options.bounds.minDate = min;
this._options.bounds.maxDate = max;
if (this._options.timeMode && this._options.timeMode === 'timestamp') {
this.eventConf['range'] = { start: min, end: max };
}
else {
this.eventConf['range'] = {
start: moment.tz(moment.utc(this.minTick / this.divider), this._options.timeZone).toDate(),
end: moment.tz(moment.utc(this.maxTick / this.divider), this._options.timeZone).toDate(),
};
}
this.eventConf = { ...this.eventConf };
this.LOG.debug(['updateBounds'], this.eventConf);
}
drawChart() {
if (!this.initChart(this.el)) {
return;
}
this.loading = false;
this.LOG.debug(['drawChart', 'plotlyData'], this.plotlyData, this._type);
if (this.elemChart.nativeElement) {
setTimeout(() => select(this.elemChart.nativeElement).data([this.plotlyData]).call(eventDrops(this.eventConf)));
this.loading = false;
this.chartDraw.emit();
}
}
convert(data) {
this.LOG.debug(['convert'], data);
const gtsList = GTSLib.flatDeep(data.data);
const dataList = [];
this.LOG.debug(['convert', 'gtsList'], gtsList);
if (!gtsList || gtsList.length === 0 || gtsList[0].length < 2) {
return;
}
gtsList.forEach((gts, i) => {
const c = ColorLib.getColor(gts.id || i, this._options.scheme);
const color = ((data.params || [])[i] || { datasetColor: c }).datasetColor || c;
const gtsName = GTSLib.serializeGtsMetadata(gts);
const dataSet = { name: '', color, data: [] };
const size = (gts.v || []).length;
for (let v = 0; v < size; v++) {
const point = (gts.v || [])[v];
const ts = point[0];
this.minTick = Math.min(this.minTick, ts);
this.maxTick = Math.max(this.maxTick, ts);
let value = point[point.length - 1];
if (isNaN(value)) {
value = 1;
}
dataSet.data.push({
date: moment.tz(moment.utc(ts / this.divider), this._options.timeZone),
color: ColorLib.transparentize(color),
value,
name: gtsName
});
}
dataList.push(dataSet);
});
this.LOG.debug(['convert', 'dataList'], dataList);
this.eventConf.label['width'] = 0;
this.eventConf['range'] = {
start: moment.tz(moment.utc(this.minTick / this.divider), this._options.timeZone).toDate(),
end: moment.tz(moment.utc(this.maxTick / this.divider), this._options.timeZone).toDate(),
};
return dataList;
}
resize(layout) {
//
}
}
WarpViewEventDropComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: WarpViewEventDropComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.SizeService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
WarpViewEventDropComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: WarpViewEventDropComponent, selector: "warpview-event-drop", inputs: { type: "type", hiddenData: "hiddenData" }, outputs: { pointHover: "pointHover", warpViewChartResize: "warpViewChartResize", chartDraw: "chartDraw", boundsDidChange: "boundsDidChange" }, viewQueries: [{ propertyName: "elemChart", first: true, predicate: ["elemChart"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<!--\n ~ Copyright 2021 SenX S.A.S.\n ~\n ~ Licensed under the Apache License, Version 2.0 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ http://www.apache.org/licenses/LICENSE-2.0\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" BASIS,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n ~\n -->\n\n<div id=\"chartContainer\">\n <warpview-spinner *ngIf=\"loading\" message=\"Parsing data\"></warpview-spinner>\n <div #toolTip class=\"wv-tooltip\"></div>\n <p class=\"noData\" *ngIf=\"noData\">No data to display</p>\n <div #elemChart style=\"width: 100%;height: 100%\"></div>\n</div>\n", styles: ["@import\"~event-drops/dist/style.css\";:root{--warp-view-chart-width: 100%;--warp-view-chart-height: 100%;--warp-view-datagrid-cell-padding: 5px;--warp-view-map-margin: 0;--warp-view-switch-height: 30px;--warp-view-switch-width: 100px;--warp-view-switch-radius: 18px;--warp-view-plot-chart-height: 100%;--warp-view-slider-pointer-size: 65px;--warp-view-resize-handle-height: 10px;--warp-view-tile-width: 100%;--warp-view-tile-height: 100%;--warp-view-font-color: #000000;--warp-view-bar-color: #dc3545;--warp-view-datagrid-odd-bg-color: #ffffff;--warp-view-datagrid-odd-color: #404040;--warp-view-datagrid-even-bg-color: #c0c0c0;--warp-view-datagrid-even-color: #000000;--warp-view-pagination-border-color: #c0c0c0;--warp-view-pagination-bg-color: #ffffff;--warp-view-pagination-active-bg-color: #4CAF50;--warp-view-pagination-active-color: #ffffff;--warp-view-pagination-active-border-color: #4CAF50;--warp-view-pagination-hover-bg-color: #c0c0c0;--warp-view-pagination-hover-color: #000000;--warp-view-pagination-hover-border-color: #c0c0c0;--warp-view-pagination-disabled-color: #c0c0c0;--warp-view-switch-inset-color: #c0c0c0;--warp-view-switch-inset-checked-color: #00cd00;--warp-view-switch-handle-color: radial-gradient(#ffffff 15%, #c0c0c0 100%);--warp-view-switch-handle-checked-color: radial-gradient(#ffffff 15%, #00cd00 100%);--warp-view-resize-handle-color: #c0c0c0;--warp-view-chart-legend-bg: #ffffff;--warp-view-chart-legend-color: #404040;--gts-classname-font-color: #004eff;--gts-labelname-font-color: #19A979;--gts-attrname-font-color: #ED4A7B;--gts-separator-font-color: #a0a0a0;--gts-labelvalue-font-color: #000000;--gts-attrvalue-font-color: #000000;--gts-stack-font-color: #000000;--gts-tree-expanded-icon: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA7klEQVQ4T82TMW7CQBBF/0g+QOpINEkVCmpaLoBm5COk5QYoaeAY3MDSei2LGu4QKakiBA1tCpTK8kS2sLVe2xSh8XSrnf9m/s4s4c6gO/UYGEBEXlT1bK396bFGIjIJguA7iqJLkVNbYOZXItoQ0QHAzBhz9CCFeAVgCeAjy7Jpmqa/NUBEEgDzktqGuOKKO47j+KsGhGH4lOf5HsDIg5ycyqVYVd+steuGheLAzM9EtPMgW1VdVGWJ6N0YU1gpozVGH+K+gy/uBHR1crXUqNzbQXXhduJ69sd7cxOZ+UFVH5Mk+exb+YGt8n9+5h8up1sReYC0WAAAAABJRU5ErkJggg==);--gts-tree-collapsed-icon: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA0UlEQVQ4T6WTUW7CQAxEPQdozxYb9Qb94Aj9gQSoVCp6lMr21doDZFCQiFCU3YDY//d2PeOFPHnwJC+zAlVdA/jp+/6YmZ+1S0qCPxF5HUAAO3fvSpKS4ENEvm6gfUS0c5JiBma2Ibm/QiQPmbmdSqohquoA7GqSxRaapmkBjBkAeHP336t0UWBmHcnb+VcR4XcJpjDJLjPHkS4tleqZubmNiDHU6gumDQDYuvvh7hpV9V9EXgaA5Ka2jbMjmNk7yZOIfEfE8eFVfuSDLda4JDsD3FNdEckTC0YAAAAASUVORK5CYII=);--warp-view-popup-bg-color: #ffffff;--warp-view-popup-border-color: rgba(0, 0, 0, .2);--warp-view-popup-header-bg-color: #c0c0c0;--warp-view-popup-title-color: #404040;--warp-view-popup-close-color: #404040;--warp-view-popup-body-bg-color: #ffffff;--warp-view-popup-body-color: #000000;--warp-view-annotationtooltip-value-font-color: #004eff;--warp-view-annotationtooltip-font-color: #404040;--warp-view-spinner-color: #ff9900;--warp-view-tooltip-bg: #ffffff;--warp-view-tooltip-color: #000000;--warp-slider-connect-color: #ff9900;--warp-slider-handle-bg-color: #ffffff;--warp-slider-handle-color: #004eff;--warp-slider-handle-shadow: inset 0 0 1px #ffffff, inset 0 1px 7px #c0c0c0, 0 3px 6px -3px #a0a0a0}.noData{width:100%;text-align:center;color:var(--warp-view-chart-legend-color);position:relative}.js-plotly-plot .plotly .cursor-ew-resize{cursor:default!important}/*!\n * Copyright 2021 SenX S.A.S.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */.gts-classname{color:var(--gts-classname-font-color)}.gts-labelname{color:var(--gts-labelname-font-color)}.gts-attrname{color:var(--gts-attrname-font-color)}.gts-separator{color:var(--gts-separator-font-color)}.gts-labelvalue{color:var(--gts-labelvalue-font-color);font-style:italic}.gts-attrvalue{color:var(--gts-attrvalue-font-color);font-style:italic}:host,warpview-event-drop,warp-view-event-drop{display:block;height:100%;width:100%}:host text.line-label,:host g.bound text,warpview-event-drop text.line-label,warpview-event-drop g.bound text,warp-view-event-drop text.line-label,warp-view-event-drop g.bound text{fill:var(--warp-view-font-color)!important}:host #chartContainer,warpview-event-drop #chartContainer,warp-view-event-drop #chartContainer{height:100%;width:100%;position:relative}:host div.chart,warpview-event-drop div.chart,warp-view-event-drop div.chart{width:var(--warp-view-chart-width);height:var(--warp-view-chart-height)}:host .wv-tooltip,warpview-event-drop .wv-tooltip,warp-view-event-drop .wv-tooltip{position:absolute;background-color:var(--warp-view-tooltip-bg)!important;color:var(--warp-view-tooltip-color)!important;line-height:1.4rem;padding:10px;border:1px solid grey;border-radius:5px;box-shadow:none;pointer-events:none;font-size:10px;min-width:100px;width:auto;z-index:999;height:auto!important;opacity:0;display:block}:host .wv-tooltip .chip,warpview-event-drop .wv-tooltip .chip,warp-view-event-drop .wv-tooltip .chip{border-radius:50%;background-color:#bbb;display:inline-block;width:5px;height:5px;border:2px solid #454545;margin-top:auto;margin-bottom:auto;vertical-align:middle;cursor:pointer;padding:2px}\n"], components: [{ type: i2.WarpViewSpinnerComponent, selector: "warpview-spinner", inputs: ["message"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: WarpViewEventDropComponent, decorators: [{
type: Component,
args: [{ selector: 'warpview-event-drop', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2021 SenX S.A.S.\n ~\n ~ Licensed under the Apache License, Version 2.0 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ http://www.apache.org/licenses/LICENSE-2.0\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" BASIS,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n ~\n -->\n\n<div id=\"chartContainer\">\n <warpview-spinner *ngIf=\"loading\" message=\"Parsing data\"></warpview-spinner>\n <div #toolTip class=\"wv-tooltip\"></div>\n <p class=\"noData\" *ngIf=\"noData\">No data to display</p>\n <div #elemChart style=\"width: 100%;height: 100%\"></div>\n</div>\n", styles: ["@import\"~event-drops/dist/style.css\";:root{--warp-view-chart-width: 100%;--warp-view-chart-height: 100%;--warp-view-datagrid-cell-padding: 5px;--warp-view-map-margin: 0;--warp-view-switch-height: 30px;--warp-view-switch-width: 100px;--warp-view-switch-radius: 18px;--warp-view-plot-chart-height: 100%;--warp-view-slider-pointer-size: 65px;--warp-view-resize-handle-height: 10px;--warp-view-tile-width: 100%;--warp-view-tile-height: 100%;--warp-view-font-color: #000000;--warp-view-bar-color: #dc3545;--warp-view-datagrid-odd-bg-color: #ffffff;--warp-view-datagrid-odd-color: #404040;--warp-view-datagrid-even-bg-color: #c0c0c0;--warp-view-datagrid-even-color: #000000;--warp-view-pagination-border-color: #c0c0c0;--warp-view-pagination-bg-color: #ffffff;--warp-view-pagination-active-bg-color: #4CAF50;--warp-view-pagination-active-color: #ffffff;--warp-view-pagination-active-border-color: #4CAF50;--warp-view-pagination-hover-bg-color: #c0c0c0;--warp-view-pagination-hover-color: #000000;--warp-view-pagination-hover-border-color: #c0c0c0;--warp-view-pagination-disabled-color: #c0c0c0;--warp-view-switch-inset-color: #c0c0c0;--warp-view-switch-inset-checked-color: #00cd00;--warp-view-switch-handle-color: radial-gradient(#ffffff 15%, #c0c0c0 100%);--warp-view-switch-handle-checked-color: radial-gradient(#ffffff 15%, #00cd00 100%);--warp-view-resize-handle-color: #c0c0c0;--warp-view-chart-legend-bg: #ffffff;--warp-view-chart-legend-color: #404040;--gts-classname-font-color: #004eff;--gts-labelname-font-color: #19A979;--gts-attrname-font-color: #ED4A7B;--gts-separator-font-color: #a0a0a0;--gts-labelvalue-font-color: #000000;--gts-attrvalue-font-color: #000000;--gts-stack-font-color: #000000;--gts-tree-expanded-icon: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA7klEQVQ4T82TMW7CQBBF/0g+QOpINEkVCmpaLoBm5COk5QYoaeAY3MDSei2LGu4QKakiBA1tCpTK8kS2sLVe2xSh8XSrnf9m/s4s4c6gO/UYGEBEXlT1bK396bFGIjIJguA7iqJLkVNbYOZXItoQ0QHAzBhz9CCFeAVgCeAjy7Jpmqa/NUBEEgDzktqGuOKKO47j+KsGhGH4lOf5HsDIg5ycyqVYVd+steuGheLAzM9EtPMgW1VdVGWJ6N0YU1gpozVGH+K+gy/uBHR1crXUqNzbQXXhduJ69sd7cxOZ+UFVH5Mk+exb+YGt8n9+5h8up1sReYC0WAAAAABJRU5ErkJggg==);--gts-tree-collapsed-icon: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA0UlEQVQ4T6WTUW7CQAxEPQdozxYb9Qb94Aj9gQSoVCp6lMr21doDZFCQiFCU3YDY//d2PeOFPHnwJC+zAlVdA/jp+/6YmZ+1S0qCPxF5HUAAO3fvSpKS4ENEvm6gfUS0c5JiBma2Ibm/QiQPmbmdSqohquoA7GqSxRaapmkBjBkAeHP336t0UWBmHcnb+VcR4XcJpjDJLjPHkS4tleqZubmNiDHU6gumDQDYuvvh7hpV9V9EXgaA5Ka2jbMjmNk7yZOIfEfE8eFVfuSDLda4JDsD3FNdEckTC0YAAAAASUVORK5CYII=);--warp-view-popup-bg-color: #ffffff;--warp-view-popup-border-color: rgba(0, 0, 0, .2);--warp-view-popup-header-bg-color: #c0c0c0;--warp-view-popup-title-color: #404040;--warp-view-popup-close-color: #404040;--warp-view-popup-body-bg-color: #ffffff;--warp-view-popup-body-color: #000000;--warp-view-annotationtooltip-value-font-color: #004eff;--warp-view-annotationtooltip-font-color: #404040;--warp-view-spinner-color: #ff9900;--warp-view-tooltip-bg: #ffffff;--warp-view-tooltip-color: #000000;--warp-slider-connect-color: #ff9900;--warp-slider-handle-bg-color: #ffffff;--warp-slider-handle-color: #004eff;--warp-slider-handle-shadow: inset 0 0 1px #ffffff, inset 0 1px 7px #c0c0c0, 0 3px 6px -3px #a0a0a0}.noData{width:100%;text-align:center;color:var(--warp-view-chart-legend-color);position:relative}.js-plotly-plot .plotly .cursor-ew-resize{cursor:default!important}/*!\n * Copyright 2021 SenX S.A.S.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */.gts-classname{color:var(--gts-classname-font-color)}.gts-labelname{color:var(--gts-labelname-font-color)}.gts-attrname{color:var(--gts-attrname-font-color)}.gts-separator{color:var(--gts-separator-font-color)}.gts-labelvalue{color:var(--gts-labelvalue-font-color);font-style:italic}.gts-attrvalue{color:var(--gts-attrvalue-font-color);font-style:italic}:host,warpview-event-drop,warp-view-event-drop{display:block;height:100%;width:100%}:host text.line-label,:host g.bound text,warpview-event-drop text.line-label,warpview-event-drop g.bound text,warp-view-event-drop text.line-label,warp-view-event-drop g.bound text{fill:var(--warp-view-font-color)!important}:host #chartContainer,warpview-event-drop #chartContainer,warp-view-event-drop #chartContainer{height:100%;width:100%;position:relative}:host div.chart,warpview-event-drop div.chart,warp-view-event-drop div.chart{width:var(--warp-view-chart-width);height:var(--warp-view-chart-height)}:host .wv-tooltip,warpview-event-drop .wv-tooltip,warp-view-event-drop .wv-tooltip{position:absolute;background-color:var(--warp-view-tooltip-bg)!important;color:var(--warp-view-tooltip-color)!important;line-height:1.4rem;padding:10px;border:1px solid grey;border-radius:5px;box-shadow:none;pointer-events:none;font-size:10px;min-width:100px;width:auto;z-index:999;height:auto!important;opacity:0;display:block}:host .wv-tooltip .chip,warpview-event-drop .wv-tooltip .chip,warp-view-event-drop .wv-tooltip .chip{border-radius:50%;background-color:#bbb;display:inline-block;width:5px;height:5px;border:2px solid #454545;margin-top:auto;margin-bottom:auto;vertical-align:middle;cursor:pointer;padding:2px}\n"] }]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.SizeService }, { type: i0.NgZone }]; }, propDecorators: { elemChart: [{
type: ViewChild,
args: ['elemChart', { static: true }]
}], type: [{
type: Input,
args: ['type']
}], hiddenData: [{
type: Input,
args: ['hiddenData']
}], pointHover: [{
type: Output,
args: ['pointHover']
}], warpViewChartResize: [{
type: Output,
args: ['warpViewChartResize']
}], chartDraw: [{
type: Output,
args: ['chartDraw']
}], boundsDidChange: [{
type: Output,
args: ['boundsDidChange']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"warp-view-event-drop.component.js","sourceRoot":"","sources":["../../../../../../../projects/warpview-ng/src/lib/elements/warp-view-event-drop/warp-view-event-drop.component.ts","../../../../../../../projects/warpview-ng/src/lib/elements/warp-view-event-drop/warp-view-event-drop.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n *  Copyright 2021  SenX S.A.S.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\");\n *  you may not use this file except in compliance with the License.\n *  You may obtain a copy of the License at\n *\n *    http://www.apache.org/licenses/LICENSE-2.0\n *\n *  Unless required by applicable law or agreed to in writing, software\n *  distributed under the License is distributed on an \"AS IS\" BASIS,\n *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n *  See the License for the specific language governing permissions and\n *  limitations under the License.\n *\n */\n\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {WarpViewComponent} from '../warp-view-component';\nimport {SizeService} from '../../services/resize.service';\nimport {Logger} from '../../utils/logger';\nimport deepEqual from 'deep-equal';\nimport {ChartLib} from '../../utils/chart-lib';\nimport {Param} from '../../model/param';\nimport {DataModel} from '../../model/dataModel';\nimport {ColorLib} from '../../utils/color-lib';\nimport * as d3 from 'd3';\nimport eventDrops from 'event-drops';\nimport {GTSLib} from '../../utils/gts.lib';\nimport moment from 'moment-timezone';\nimport {select} from 'd3-selection';\n\n@Component({\n  selector: 'warpview-event-drop',\n  templateUrl: './warp-view-event-drop.component.html',\n  styleUrls: ['./warp-view-event-drop.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class WarpViewEventDropComponent extends WarpViewComponent implements OnInit, OnDestroy {\n  @ViewChild('elemChart', {static: true}) elemChart: ElementRef;\n\n  @Input('type') set type(type: string) {\n    this._type = type;\n    this.drawChart();\n  }\n\n\n  @Input('hiddenData') set hiddenData(hiddenData: number[]) {\n    const previousVisibility = JSON.stringify(this.visibility);\n    this.LOG.debug(['hiddenData', 'previousVisibility'], previousVisibility);\n    this._hiddenData = hiddenData;\n    this.visibility = [];\n    this.visibleGtsId.forEach(id => this.visibility.push(hiddenData.indexOf(id) < 0 && (id !== -1)));\n    this.LOG.debug(['hiddenData', 'hiddendygraphfullv'], this.visibility);\n    const newVisibility = JSON.stringify(this.visibility);\n    this.LOG.debug(['hiddenData', 'json'], previousVisibility, newVisibility);\n    if (previousVisibility !== newVisibility) {\n      this.drawChart();\n      this.LOG.debug(['hiddendygraphtrig', 'destroy'], 'redraw by visibility change');\n    }\n  }\n\n  @Output('pointHover') pointHover = new EventEmitter<any>();\n  @Output('warpViewChartResize') warpViewChartResize = new EventEmitter<any>();\n  @Output('chartDraw') chartDraw = new EventEmitter<any>();\n  @Output('boundsDidChange') boundsDidChange = new EventEmitter<any>();\n\n  private visibility: boolean[] = [];\n  private maxTick = Number.MIN_VALUE;\n  private minTick = Number.MAX_VALUE;\n  private visibleGtsId = [];\n  protected _type = 'drops';\n  private eventConf = {\n    d3,\n    axis: {\n      verticalGrid: true,\n      tickPadding: 6,\n    },\n    line: {\n      height: 20,\n    },\n    indicator: false,\n    label: {\n      text: row => row.name,\n    },\n    metaballs: {\n      blurDeviation: 7\n    },\n    drop: {\n      radius: 4,\n      date: d => d.date.toDate(),\n      color: d => d.color,\n      onMouseOver: g => {\n        this.LOG.debug(['onMouseOver'], g);\n        this.pointHover.emit({\n          x: d3.event.offsetX,\n          y: d3.event.offsetY\n        });\n        const t = d3.select(this.toolTip.nativeElement);\n        t.transition()\n          .duration(200)\n          .style('opacity', 1)\n          .style('pointer-events', 'auto');\n        t.html(`<div class=\"tooltip-body\">\n<b class=\"tooltip-date\">${this._options.timeMode === 'timestamp'\n          ? g.date\n          : (g.date.toISOString() || '')}</b>\n<div><i class=\"chip\"  style=\"background-color: ${g.color};border: 2px solid ${g.color};\"></i>\n${GTSLib.formatLabel(g.name)}: <span class=\"value\">${g.value}</span>\n</div></div>`\n        )\n          .style('left', `${d3.event.offsetX + 10}px`)\n          .style('top', `${d3.event.offsetY + 10}px`);\n      },\n      onMouseOut: () => {\n        select(this.toolTip.nativeElement)\n          .transition()\n          .duration(500)\n          .style('opacity', 0)\n          .style('pointer-events', 'none');\n      },\n    },\n  };\n\n  constructor(\n    public el: ElementRef,\n    public renderer: Renderer2,\n    public sizeService: SizeService,\n    public ngZone: NgZone\n  ) {\n    super(el, renderer, sizeService, ngZone);\n    this.LOG = new Logger(WarpViewEventDropComponent, this._debug);\n  }\n\n\n  ngOnInit(): void {\n    this._options = this._options || this.defOptions;\n  }\n\n  ngOnDestroy(): void {\n    if (!!this.elemChart) {\n      select(this.elemChart.nativeElement).remove();\n    }\n  }\n\n  update(options, refresh): void {\n    this.LOG.debug(['onOptions', 'before'], this._options, options);\n    if (!deepEqual(options, this._options)) {\n      this.LOG.debug(['options', 'changed'], options);\n      this._options = ChartLib.mergeDeep(this._options, options as Param) as Param;\n    }\n    this.drawChart();\n  }\n\n  updateBounds(min, max) {\n    this.LOG.debug(['updateBounds'], min, max, this._options);\n    this._options.bounds.minDate = min;\n    this._options.bounds.maxDate = max;\n\n    if (this._options.timeMode && this._options.timeMode === 'timestamp') {\n      this.eventConf['range'] = {start: min, end: max};\n    } else {\n      this.eventConf['range'] = {\n        start: moment.tz(moment.utc(this.minTick / this.divider), this._options.timeZone).toDate(),\n        end: moment.tz(moment.utc(this.maxTick / this.divider), this._options.timeZone).toDate(),\n      };\n    }\n    this.eventConf = {...this.eventConf};\n    this.LOG.debug(['updateBounds'], this.eventConf);\n  }\n\n  drawChart() {\n    if (!this.initChart(this.el)) {\n      return;\n    }\n    this.loading = false;\n    this.LOG.debug(['drawChart', 'plotlyData'], this.plotlyData, this._type);\n    if (this.elemChart.nativeElement) {\n      setTimeout(() => select(this.elemChart.nativeElement).data([this.plotlyData]).call(eventDrops(this.eventConf)));\n      this.loading = false;\n      this.chartDraw.emit();\n    }\n  }\n\n  protected convert(data: DataModel): any[] {\n    this.LOG.debug(['convert'], data);\n    const gtsList = GTSLib.flatDeep(data.data as any[]);\n    const dataList = [];\n    this.LOG.debug(['convert', 'gtsList'], gtsList);\n    if (!gtsList || gtsList.length === 0 || gtsList[0].length < 2) {\n      return;\n    }\n    gtsList.forEach((gts, i) => {\n      const c = ColorLib.getColor(gts.id || i, this._options.scheme);\n      const color = ((data.params || [])[i] || {datasetColor: c}).datasetColor || c;\n      const gtsName = GTSLib.serializeGtsMetadata(gts);\n      const dataSet = {name: '', color, data: []};\n      const size = (gts.v || []).length;\n      for (let v = 0; v < size; v++) {\n        const point = (gts.v || [])[v];\n        const ts = point[0];\n        this.minTick = Math.min(this.minTick, ts);\n        this.maxTick = Math.max(this.maxTick, ts);\n        let value = point[point.length - 1];\n        if (isNaN(value)) {\n          value = 1;\n        }\n        dataSet.data.push({\n          date: moment.tz(moment.utc(ts / this.divider), this._options.timeZone),\n          color: ColorLib.transparentize(color),\n          value,\n          name: gtsName\n        });\n      }\n      dataList.push(dataSet);\n    });\n    this.LOG.debug(['convert', 'dataList'], dataList);\n    this.eventConf.label ['width'] = 0;\n    this.eventConf  ['range'] = {\n      start: moment.tz(moment.utc(this.minTick / this.divider), this._options.timeZone).toDate(),\n      end: moment.tz(moment.utc(this.maxTick / this.divider), this._options.timeZone).toDate(),\n    };\n    return dataList;\n  }\n\n  public resize(layout: { width: number; height: any }) {\n    //\n  }\n}\n","<!--\n  ~  Copyright 2021  SenX S.A.S.\n  ~\n  ~  Licensed under the Apache License, Version 2.0 (the \"License\");\n  ~  you may not use this file except in compliance with the License.\n  ~  You may obtain a copy of the License at\n  ~\n  ~    http://www.apache.org/licenses/LICENSE-2.0\n  ~\n  ~  Unless required by applicable law or agreed to in writing, software\n  ~  distributed under the License is distributed on an \"AS IS\" BASIS,\n  ~  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~  See the License for the specific language governing permissions and\n  ~  limitations under the License.\n  ~\n  -->\n\n<div id=\"chartContainer\">\n  <warpview-spinner *ngIf=\"loading\" message=\"Parsing data\"></warpview-spinner>\n  <div #toolTip class=\"wv-tooltip\"></div>\n  <p class=\"noData\" *ngIf=\"noData\">No data to display</p>\n  <div #elemChart style=\"width: 100%;height: 100%\"></div>\n</div>\n"]}