UNPKG

@senx/warpview

Version:
167 lines 36 kB
/* * 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, Output, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core'; import { GTS } from '../../../model/GTS'; import { Logger } from '../../../utils/logger'; import { GTSLib } from '../../../utils/gts.lib'; import { ColorLib } from '../../../utils/color-lib'; import { Param } from '../../../model/param'; import { Observable } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; /** * */ export class WarpViewChipComponent { constructor(renderer) { this.renderer = renderer; this.param = new Param(); this.options = new Param(); this.warpViewSelectedGTS = new EventEmitter(); // the first character triggers change each filter apply to trigger events. it must be discarded. this._gtsFilter = 'x'; this._debug = false; this._hiddenData = []; this._node = { selected: true, gts: GTS, }; this.LOG = new Logger(WarpViewChipComponent, this.debug); } set debug(debug) { this._debug = debug; this.LOG.setDebug(debug); } get debug() { return this._debug; } set hiddenData(hiddenData) { if (JSON.stringify(hiddenData) !== JSON.stringify(this._hiddenData)) { this._hiddenData = hiddenData; this.LOG.debug(['hiddenData'], hiddenData, this._node, this._node.gts, this._node.gts.c); if (!!this._node && !!this._node.gts && !!this._node.gts.c) { this.setState(this._hiddenData.indexOf(this._node.gts.id) === -1); } } } get hiddenData() { return this._hiddenData; } set gtsFilter(gtsFilter) { this._gtsFilter = gtsFilter; if (this._gtsFilter.slice(1) !== '') { this.setState(new RegExp(this._gtsFilter.slice(1), 'gi').test(GTSLib.serializeGtsMetadata(this._node.gts))); } else { this.setState(true); } } get gtsFilter() { return this._gtsFilter; } ngOnInit() { this._node = { ...this.node, selected: this._hiddenData.indexOf(this.node.gts.id) === -1 }; if (!!this.events) { // this.eventsSubscription = this.events.subscribe(state => this.setState(state)); } } ngOnDestroy() { if (!!this.eventsSubscription) { this.eventsSubscription.unsubscribe(); } } ngAfterViewInit() { if (this.gtsFilter.slice(1) !== '' && new RegExp(this.gtsFilter.slice(1), 'gi').test(GTSLib.serializeGtsMetadata(this._node.gts)) || this.hiddenData.indexOf(this._node.gts.id) > -1) { this.setState(false); } else { this.colorizeChip(); } } colorizeChip() { if (!!this.chip) { if (!!this._node.selected) { const c = ColorLib.getColor(this._node.gts.id, this.options.scheme); const color = (this.param || { datasetColor: c }).datasetColor || c; this.renderer.setStyle(this.chip.nativeElement, 'background-color', color); this.renderer.setStyle(this.chip.nativeElement, 'border-color', color); } else { this.renderer.setStyle(this.chip.nativeElement, 'background-color', 'transparent'); } } } toArray(obj) { if (obj === undefined) { return []; } return Object.keys(obj).map(key => ({ name: key, value: obj[key] })); } switchPlotState(event) { event.preventDefault(); this.setState(!this._node.selected); return false; } setState(state) { if (this._node && this._node.gts) { this.LOG.debug(['switchPlotState'], state, this._node.selected); if (this._node.selected !== state) { this._node.selected = !!state; this.LOG.debug(['switchPlotState'], 'emit'); this.warpViewSelectedGTS.emit(this._node); } this.colorizeChip(); } } identify(index, item) { return index; } } WarpViewChipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: WarpViewChipComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); WarpViewChipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.1", type: WarpViewChipComponent, selector: "warpview-chip", inputs: { node: "node", param: "param", options: "options", events: "events", debug: "debug", hiddenData: "hiddenData", gtsFilter: "gtsFilter" }, outputs: { warpViewSelectedGTS: "warpViewSelectedGTS" }, viewQueries: [{ propertyName: "chip", first: true, predicate: ["chip"], descendants: 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>\n <span (click)=\"switchPlotState($event)\" *ngIf=\"_node && _node.gts && _node.gts.l\">\n <i class=\"normal\" #chip></i>\n <span class=\"gtsInfo\">\n <span class='gts-classname'>&nbsp;{{_node.gts.c}}</span>\n <span class='gts-separator'>&#x007B; </span>\n <span *ngFor=\"let label of toArray(_node.gts.l); index as index; last as last; trackBy:identify\">\n <span class='gts-labelname'>{{label.name}}</span>\n <span class='gts-separator'>=</span>\n <span class='gts-labelvalue'>{{label.value}}</span>\n <span [hidden]=\"last\">, </span>\n </span>\n <span class=\"gts-separator\"> &#x007D; </span>\n <span class='gts-separator'>&#x007B; </span>\n <span *ngFor=\"let label of toArray(_node.gts.a); index as index; last as last; trackBy:identify\">\n <span class='gts-attrname'>{{label.name}}</span>\n <span class='gts-separator'>=</span>\n <span class='gts-attrvalue'>{{label.value}}</span>\n <span [hidden]=\"last\">, </span>\n </span>\n <span class=\"gts-separator\"> &#x007D;</span>\n </span>\n </span>\n</div>\n", styles: [":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 div span{cursor:pointer}:host .normal{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}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], encapsulation: i0.ViewEncapsulation.ShadowDom }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.1", ngImport: i0, type: WarpViewChipComponent, decorators: [{ type: Component, args: [{ selector: 'warpview-chip', encapsulation: ViewEncapsulation.ShadowDom, 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>\n <span (click)=\"switchPlotState($event)\" *ngIf=\"_node && _node.gts && _node.gts.l\">\n <i class=\"normal\" #chip></i>\n <span class=\"gtsInfo\">\n <span class='gts-classname'>&nbsp;{{_node.gts.c}}</span>\n <span class='gts-separator'>&#x007B; </span>\n <span *ngFor=\"let label of toArray(_node.gts.l); index as index; last as last; trackBy:identify\">\n <span class='gts-labelname'>{{label.name}}</span>\n <span class='gts-separator'>=</span>\n <span class='gts-labelvalue'>{{label.value}}</span>\n <span [hidden]=\"last\">, </span>\n </span>\n <span class=\"gts-separator\"> &#x007D; </span>\n <span class='gts-separator'>&#x007B; </span>\n <span *ngFor=\"let label of toArray(_node.gts.a); index as index; last as last; trackBy:identify\">\n <span class='gts-attrname'>{{label.name}}</span>\n <span class='gts-separator'>=</span>\n <span class='gts-attrvalue'>{{label.value}}</span>\n <span [hidden]=\"last\">, </span>\n </span>\n <span class=\"gts-separator\"> &#x007D;</span>\n </span>\n </span>\n</div>\n", styles: [":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 div span{cursor:pointer}:host .normal{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}\n"] }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { chip: [{ type: ViewChild, args: ['chip'] }], node: [{ type: Input, args: ['node'] }], param: [{ type: Input, args: ['param'] }], options: [{ type: Input, args: ['options'] }], events: [{ type: Input }], debug: [{ type: Input, args: ['debug'] }], hiddenData: [{ type: Input, args: ['hiddenData'] }], gtsFilter: [{ type: Input, args: ['gtsFilter'] }], warpViewSelectedGTS: [{ type: Output, args: ['warpViewSelectedGTS'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"warp-view-chip.component.js","sourceRoot":"","sources":["../../../../../../../../projects/warpview-ng/src/lib/elements/warp-view-gts-tree/warp-view-chip/warp-view-chip.component.ts","../../../../../../../../projects/warpview-ng/src/lib/elements/warp-view-gts-tree/warp-view-chip/warp-view-chip.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  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport {GTS} from '../../../model/GTS';\nimport {Logger} from '../../../utils/logger';\nimport {GTSLib} from '../../../utils/gts.lib';\nimport {ColorLib} from '../../../utils/color-lib';\nimport {Param} from '../../../model/param';\nimport {Observable, Subscription} from 'rxjs';\n\n/**\n *\n */\n@Component({\n  selector: 'warpview-chip',\n  templateUrl: './warp-view-chip.component.html',\n  styleUrls: ['./warp-view-chip.component.scss'],\n  encapsulation: ViewEncapsulation.ShadowDom\n})\nexport class WarpViewChipComponent implements OnInit, AfterViewInit, OnDestroy {\n  private eventsSubscription: Subscription;\n\n  @ViewChild('chip') chip: ElementRef;\n\n  @Input('node') node: any;\n  @Input('param') param: Param = new Param();\n  @Input('options') options: Param = new Param();\n  @Input() events: Observable<boolean>;\n\n  @Input('debug') set debug(debug: boolean) {\n    this._debug = debug;\n    this.LOG.setDebug(debug);\n  }\n\n  get debug() {\n    return this._debug;\n  }\n\n  @Input('hiddenData') set hiddenData(hiddenData: number[]) {\n    if (JSON.stringify(hiddenData) !== JSON.stringify(this._hiddenData)) {\n      this._hiddenData = hiddenData;\n      this.LOG.debug(['hiddenData'], hiddenData, this._node, this._node.gts, this._node.gts.c);\n      if (!!this._node && !!this._node.gts && !!this._node.gts.c) {\n        this.setState(this._hiddenData.indexOf(this._node.gts.id) === -1);\n      }\n    }\n  }\n\n  get hiddenData(): number[] {\n    return this._hiddenData;\n  }\n\n  @Input('gtsFilter') set gtsFilter(gtsFilter: string) {\n    this._gtsFilter = gtsFilter;\n    if (this._gtsFilter.slice(1) !== '') {\n      this.setState(new RegExp(this._gtsFilter.slice(1), 'gi').test(GTSLib.serializeGtsMetadata(this._node.gts)));\n    } else {\n      this.setState(true);\n    }\n  }\n\n  get gtsFilter() {\n    return this._gtsFilter;\n  }\n\n  @Output('warpViewSelectedGTS') warpViewSelectedGTS = new EventEmitter<any>();\n\n  private LOG: Logger;\n  // the first character triggers change each filter apply to trigger events. it must be discarded.\n  private _gtsFilter = 'x';\n  private _debug = false;\n  private _hiddenData: number[] = [];\n  _node: any = {\n    selected: true,\n    gts: GTS,\n  };\n\n  constructor(private renderer: Renderer2) {\n    this.LOG = new Logger(WarpViewChipComponent, this.debug);\n  }\n\n  ngOnInit(): void {\n    this._node = {...this.node, selected: this._hiddenData.indexOf(this.node.gts.id) === -1};\n    if (!!this.events) {\n    //  this.eventsSubscription = this.events.subscribe(state => this.setState(state));\n    }\n  }\n\n  ngOnDestroy() {\n    if (!!this.eventsSubscription) {\n      this.eventsSubscription.unsubscribe();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.gtsFilter.slice(1) !== '' && new RegExp(this.gtsFilter.slice(1), 'gi').test(GTSLib.serializeGtsMetadata(this._node.gts))\n      || this.hiddenData.indexOf(this._node.gts.id) > -1) {\n      this.setState(false);\n    } else {\n      this.colorizeChip();\n    }\n  }\n\n  private colorizeChip() {\n    if (!!this.chip) {\n      if (!!this._node.selected) {\n        const c = ColorLib.getColor(this._node.gts.id, this.options.scheme);\n        const color = (this.param || {datasetColor: c}).datasetColor || c;\n        this.renderer.setStyle(this.chip.nativeElement, 'background-color', color);\n        this.renderer.setStyle(this.chip.nativeElement, 'border-color', color);\n      } else {\n        this.renderer.setStyle(this.chip.nativeElement, 'background-color', 'transparent');\n      }\n    }\n  }\n\n  toArray(obj) {\n    if (obj === undefined) {\n      return [];\n    }\n    return Object.keys(obj).map(key => ({name: key, value: obj[key]}));\n  }\n\n  switchPlotState(event: UIEvent) {\n    event.preventDefault();\n    this.setState(!this._node.selected);\n    return false;\n  }\n\n  private setState(state: boolean) {\n    if (this._node && this._node.gts) {\n      this.LOG.debug(['switchPlotState'], state, this._node.selected);\n      if (this._node.selected !== state) {\n        this._node.selected = !!state;\n        this.LOG.debug(['switchPlotState'], 'emit');\n        this.warpViewSelectedGTS.emit(this._node);\n      }\n      this.colorizeChip();\n    }\n  }\n\n  identify(index, item) {\n    return index;\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>\n   <span (click)=\"switchPlotState($event)\" *ngIf=\"_node && _node.gts && _node.gts.l\">\n     <i class=\"normal\" #chip></i>\n     <span class=\"gtsInfo\">\n       <span class='gts-classname'>&nbsp;{{_node.gts.c}}</span>\n       <span class='gts-separator'>&#x007B; </span>\n       <span *ngFor=\"let label of toArray(_node.gts.l); index as index; last as last; trackBy:identify\">\n         <span class='gts-labelname'>{{label.name}}</span>\n         <span class='gts-separator'>=</span>\n         <span class='gts-labelvalue'>{{label.value}}</span>\n         <span [hidden]=\"last\">, </span>\n       </span>\n       <span class=\"gts-separator\"> &#x007D; </span>\n         <span class='gts-separator'>&#x007B; </span>\n         <span *ngFor=\"let label of toArray(_node.gts.a); index as index; last as last; trackBy:identify\">\n           <span class='gts-attrname'>{{label.name}}</span>\n           <span class='gts-separator'>=</span>\n           <span class='gts-attrvalue'>{{label.value}}</span>\n           <span [hidden]=\"last\">, </span>\n         </span>\n       <span class=\"gts-separator\"> &#x007D;</span>\n       </span>\n   </span>\n</div>\n"]}