keevo-components 1.8.347 → 1.8.349

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,111 +1,182 @@
1
- import { Component, Input, ViewChild, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, model, Output, ViewChild, ViewContainerRef, } from '@angular/core';
2
2
  import { OrgChart } from 'd3-org-chart';
3
3
  import * as d3 from 'd3';
4
+ import { fromEvent } from 'rxjs';
4
5
  import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common";
6
- import * as i2 from "primeng/tooltip";
6
+ import * as i1 from "../../api/services/orgchart.service";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "primeng/tooltip";
7
9
  export class KvOrgchartComponent {
8
- constructor(renderer) {
9
- this.renderer = renderer;
10
- this.generateTemplate = (data, node, nodes, index) => '';
11
- this.templateFuncion = false;
12
- this.corDeFundo = 'red';
10
+ constructor(cdr, service) {
11
+ this.cdr = cdr;
12
+ this.service = service;
13
+ this.dataSource = model(null);
14
+ //#region Emissores de evento
15
+ this.onNodeClick = new EventEmitter();
16
+ // #endregion
13
17
  this.compact = true;
14
18
  this.mostraMenu = false;
15
19
  }
20
+ //#region Iniciar OrgChart e Atualização de dados
16
21
  ngOnInit() {
22
+ this.iniciarHandlersDeEventos();
17
23
  }
18
24
  ngAfterViewInit() {
19
25
  if (!this.chart) {
20
26
  this.chart = new OrgChart();
21
27
  }
22
- this.updateChart();
28
+ this.iniciarChart();
23
29
  }
24
- ngOnChanges() {
25
- this.updateChart();
26
- }
27
- updateChart() {
28
- if (!this.dataSource) {
29
- return;
30
- }
31
- if (!this.chart) {
30
+ iniciarChart() {
31
+ if (!this.dataSource() || !this.chart) {
32
32
  return;
33
33
  }
34
34
  const chartContainer = this.chartContainer.nativeElement;
35
35
  this.chart
36
+ .createZoom(() => {
37
+ return d3.zoom().filter((e) => {
38
+ const element = e.srcElement;
39
+ if (element.classList.contains('no-zoom')) {
40
+ return false;
41
+ }
42
+ return true;
43
+ });
44
+ })
36
45
  .container(chartContainer)
37
- .data(this.dataSource)
46
+ .data(this.dataSource())
38
47
  .nodeWidth(() => this.config.cardWidht)
39
- .nodeHeight(() => this.config.cardHeight)
48
+ .nodeHeight((d) => {
49
+ return d.data.expanded && this.config.cardExpandedHeight
50
+ ? this.config.cardExpandedHeight
51
+ : this.config.cardHeight;
52
+ })
40
53
  .compact(false)
41
54
  .buttonContent(({ node, state }) => {
42
- return `<div style="color:#FFFFFF; border-radius:100%;font-size:5px;margin:auto auto;background-color:#64748B;">
43
- <span>
44
- ${node.children && node.children.length > 0
55
+ return `<div style="color:#FFFFFF; border-radius:100%;font-size:5px;margin:auto auto;background-color:#64748B;">
56
+ <span>
57
+ ${node.children && node.children.length > 0
45
58
  ? `<i class="material-symbols-outlined">
46
- keyboard_arrow_up
47
- </i>`
59
+ keyboard_arrow_up
60
+ </i>`
48
61
  : `<i class="material-symbols-outlined">
49
- keyboard_arrow_down
50
- </i>`}
51
- </span>
52
- </div>`;
53
- })
54
- .nodeUpdate(function (d) {
62
+ keyboard_arrow_down
63
+ </i>`}
64
+ </span>
65
+ </div>`;
55
66
  })
56
67
  .linkUpdate((node, index, nodes) => {
57
68
  d3.select(nodes[index])
58
69
  .attr('stroke-width', this.config.conectionWidth || '2px')
59
- .style('stroke', this.config.connectionColor || '#d6d6d6').style('backgroundColor', 'red');
70
+ .style('stroke', this.config.connectionColor || '#d6d6d6');
60
71
  })
61
72
  .nodeContent((d) => {
62
- if (!this.templateFuncion) {
63
- if (d.data.template) {
64
- const jsTemplate = this.stringToTemplateLiteral(d.data.template);
65
- var templateConverter = new Function('data', 'return' + jsTemplate);
66
- var x = templateConverter(d.data.data);
67
- }
68
- else {
69
- const jsTemplate = this.stringToTemplateLiteral(this.config.templateItem);
70
- var templateConverter = new Function('data', 'return' + jsTemplate);
71
- var x = templateConverter(d.data.data);
72
- }
73
- }
74
- else {
75
- var x = this.generateTemplate(d);
76
- }
73
+ const node = {
74
+ data: d.data.data,
75
+ children: d.children,
76
+ id: d.data.id,
77
+ parentId: d.data.parentId,
78
+ expanded: d.data.expanded,
79
+ };
80
+ const x = this.renderNodeTemplate(node);
77
81
  return x;
82
+ })
83
+ .nodeUpdate(function (d) {
84
+ d.data.data.config.clicks.forEach((click) => {
85
+ d3.select(this)
86
+ .select(click)
87
+ .on('click', (e, d) => {
88
+ const dados = d;
89
+ const node = {
90
+ data: dados.data.data,
91
+ children: dados.children,
92
+ id: dados.data.id,
93
+ parentId: dados.data.parentId,
94
+ expanded: dados.data.expanded,
95
+ };
96
+ window.dispatchEvent(new CustomEvent('KvOrgChart_NodeClick', {
97
+ detail: {
98
+ node,
99
+ seletor: click,
100
+ },
101
+ }));
102
+ });
103
+ });
78
104
  })
79
105
  .defaultFont('Roboto')
80
106
  .render();
81
107
  this.chart.expandAll();
82
108
  }
83
- stringToTemplateLiteral(string) {
84
- const convertedTemplate = string.replace(/\{\{([^}]*)\}\}/g, '${$1}');
85
- return '`' + convertedTemplate + '`';
109
+ ngOnChanges(changes) {
110
+ if (changes['dataSource']) {
111
+ this.iniciarChart();
112
+ }
113
+ }
114
+ //#endregion
115
+ // #region Renderização de template
116
+ renderNodeTemplate(node) {
117
+ this.viewContainerRef.clear();
118
+ const view = this.viewContainerRef.createEmbeddedView(this.nodeTemplate, {
119
+ node: node,
120
+ });
121
+ this.cdr.detectChanges();
122
+ return view.rootNodes[0].outerHTML;
86
123
  }
87
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
88
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvOrgchartComponent, selector: "kv-orgchart", inputs: { dataSource: "dataSource", config: "config", template: "template", nodeTemplate: "nodeTemplate", generateTemplate: "generateTemplate", templateFuncion: "templateFuncion", corDeFundo: "corDeFundo" }, viewQueries: [{ propertyName: "chartContainer", first: true, predicate: ["chartContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n <div *ngIf=\"mostraMenu\">\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n <!-- <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"compactSwap()\" pTooltip=\"Compactar\">cached</span> -->\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n filter_center_focus\r\n </span>\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n fullscreen\r\n </span>\r\n\r\n </div>\r\n\r\n\r\n </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n", styles: ["#chartContainer{height:100%;overflow:hidden}:host ::ng-deep #chartContainer svg.svg-chart-container{height:100%!important;position:relative;width:100%;top:-56px;z-index:0;background-color:#fff}.div-botoes{z-index:1;width:100%;position:relative}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }] }); }
124
+ iniciarHandlersDeEventos() {
125
+ this.nodeClickSubscription = fromEvent(window, 'KvOrgChart_NodeClick').subscribe((event) => {
126
+ this.emitirClick(event.detail.node, event.detail.seletor);
127
+ });
128
+ this.nodeAddSubscription = this.service.nodeAdd$.subscribe((node) => {
129
+ this.adicionarNode(node);
130
+ });
131
+ this.nodeRemoveSubscription = this.service.nodeRemove$.subscribe((id) => {
132
+ this.removerNode(id);
133
+ });
134
+ }
135
+ ngOnDestroy() {
136
+ this.nodeClickSubscription.unsubscribe();
137
+ this.nodeAddSubscription.unsubscribe();
138
+ this.nodeRemoveSubscription.unsubscribe();
139
+ }
140
+ emitirClick(node, seletorCss) {
141
+ const event = {
142
+ node: node,
143
+ seletorCss: seletorCss ?? '',
144
+ };
145
+ this.onNodeClick.emit(event);
146
+ }
147
+ adicionarNode(node) {
148
+ const arr = [...this.dataSource(), node];
149
+ this.dataSource.set(arr);
150
+ this.iniciarChart();
151
+ }
152
+ removerNode(id) {
153
+ const indPai = this.dataSource().some((x) => x.parentId == id);
154
+ if (indPai) {
155
+ alert('Não é possível remover um nó que possui filhos');
156
+ }
157
+ else {
158
+ const arr = this.dataSource().filter((x) => x.id != id);
159
+ this.dataSource.set(arr);
160
+ this.iniciarChart();
161
+ }
162
+ }
163
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.OrgChartService }], target: i0.ɵɵFactoryTarget.Component }); }
164
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvOrgchartComponent, selector: "kv-orgchart", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: false, isRequired: false, transformFunction: null }, nodeTemplate: { classPropertyName: "nodeTemplate", publicName: "nodeTemplate", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { dataSource: "dataSourceChange", onNodeClick: "onNodeClick" }, viewQueries: [{ propertyName: "chartContainer", first: true, predicate: ["chartContainer"], descendants: true }, { propertyName: "viewContainerRef", first: true, predicate: ["nodeTemplate"], descendants: true, read: ViewContainerRef }], usesOnChanges: true, ngImport: i0, template: "<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n <div *ngIf=\"mostraMenu\">\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n filter_center_focus\r\n </span>\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n fullscreen\r\n </span>\r\n\r\n </div>\r\n\r\n\r\n </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n\r\n<div style=\"display: none;\">\r\n <ng-template #nodeTemplate let-node>\r\n <div class=\"node-content\">\r\n erro\r\n </div>\r\n </ng-template>\r\n</div>\r\n", styles: ["#chartContainer{height:100%;overflow:hidden}:host ::ng-deep #chartContainer svg.svg-chart-container{height:100%!important;position:relative;width:100%;top:-56px;z-index:0;background-color:#fff}.div-botoes{z-index:1;width:100%;position:relative}:host ::ng-deep .p-organizationChart{overflow:hidden}svg{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }] }); }
89
165
  }
90
166
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartComponent, decorators: [{
91
167
  type: Component,
92
- args: [{ selector: 'kv-orgchart', template: "<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n <div *ngIf=\"mostraMenu\">\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n <!-- <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"compactSwap()\" pTooltip=\"Compactar\">cached</span> -->\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n filter_center_focus\r\n </span>\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n fullscreen\r\n </span>\r\n\r\n </div>\r\n\r\n\r\n </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n", styles: ["#chartContainer{height:100%;overflow:hidden}:host ::ng-deep #chartContainer svg.svg-chart-container{height:100%!important;position:relative;width:100%;top:-56px;z-index:0;background-color:#fff}.div-botoes{z-index:1;width:100%;position:relative}\n"] }]
93
- }], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { chartContainer: [{
168
+ args: [{ selector: 'kv-orgchart', template: "<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n <div *ngIf=\"mostraMenu\">\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n filter_center_focus\r\n </span>\r\n\r\n <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n fullscreen\r\n </span>\r\n\r\n </div>\r\n\r\n\r\n </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n rel=\"stylesheet\"\r\n href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n\r\n<div style=\"display: none;\">\r\n <ng-template #nodeTemplate let-node>\r\n <div class=\"node-content\">\r\n erro\r\n </div>\r\n </ng-template>\r\n</div>\r\n", styles: ["#chartContainer{height:100%;overflow:hidden}:host ::ng-deep #chartContainer svg.svg-chart-container{height:100%!important;position:relative;width:100%;top:-56px;z-index:0;background-color:#fff}.div-botoes{z-index:1;width:100%;position:relative}:host ::ng-deep .p-organizationChart{overflow:hidden}svg{width:100%;height:100%}\n"] }]
169
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.OrgChartService }], propDecorators: { config: [{
170
+ type: Input
171
+ }], chartContainer: [{
94
172
  type: ViewChild,
95
173
  args: ['chartContainer']
96
- }], dataSource: [{
97
- type: Input
98
- }], config: [{
99
- type: Input
100
- }], template: [{
101
- type: Input
174
+ }], viewContainerRef: [{
175
+ type: ViewChild,
176
+ args: ['nodeTemplate', { read: ViewContainerRef }]
102
177
  }], nodeTemplate: [{
103
178
  type: Input
104
- }], generateTemplate: [{
105
- type: Input
106
- }], templateFuncion: [{
107
- type: Input
108
- }], corDeFundo: [{
109
- type: Input
179
+ }], onNodeClick: [{
180
+ type: Output
110
181
  }] } });
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-orgchart.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-orgchart/kv-orgchart.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-orgchart/kv-orgchart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnInit,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { OrgChart } from 'd3-org-chart';\r\nimport * as d3 from 'd3';\r\n\r\nimport OrgChartConfig from '../../api/components/chart/orchart.config';\r\nimport OrgChartItem from '../../api/components/chart/orchart.item';\r\n\r\n@Component({\r\n  selector: 'kv-orgchart',\r\n  templateUrl: './kv-orgchart.component.html',\r\n  styleUrls: ['./kv-orgchart.component.scss',],\r\n})\r\nexport class KvOrgchartComponent implements OnInit {\r\n  @ViewChild('chartContainer') chartContainer!: ElementRef;\r\n  chart!: any;\r\n\r\n  @Input() dataSource!: OrgChartItem[];\r\n  @Input() config!: OrgChartConfig;\r\n  @Input() template!: string;\r\n  @Input() nodeTemplate!: TemplateRef<any>;\r\n\r\n  @Input() generateTemplate: Function = (data: any, node: any, nodes: any[], index: number): string => '';\r\n  @Input() templateFuncion: boolean = false;\r\n\r\n  @Input() corDeFundo: string = 'red';\r\n\r\n  compact: boolean = true;\r\n  mostraMenu: boolean = false;\r\n\r\n  constructor(private renderer: Renderer2) { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    if (!this.chart) {\r\n      this.chart = new OrgChart();\r\n    }\r\n    this.updateChart();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.updateChart();\r\n  }\r\n\r\n  updateChart() {\r\n    if (!this.dataSource) {\r\n      return;\r\n    }\r\n    if (!this.chart) {\r\n      return;\r\n    }\r\n\r\n    const chartContainer = this.chartContainer.nativeElement;\r\n    this.chart\r\n      .container(chartContainer)\r\n      .data(this.dataSource)\r\n      .nodeWidth(() => this.config.cardWidht)\r\n      .nodeHeight(() => this.config.cardHeight)\r\n      .compact(false)\r\n      .buttonContent(({ node, state }: { node: any, state: any }) => {\r\n        return `<div style=\"color:#FFFFFF; border-radius:100%;font-size:5px;margin:auto auto;background-color:#64748B;\"> \r\n            <span>\r\n            ${\r\n              node.children && node.children.length > 0\r\n                ? `<i class=\"material-symbols-outlined\">\r\nkeyboard_arrow_up\r\n</i>`\r\n                : `<i class=\"material-symbols-outlined\">\r\nkeyboard_arrow_down\r\n</i>`\r\n            }\r\n            </span>\r\n          </div>`;\r\n    })\r\n      .nodeUpdate(function (d: any) {\r\n      })\r\n      .linkUpdate((node: any, index: any, nodes: any) => {\r\n        d3.select(nodes[index])\r\n          .attr('stroke-width', this.config.conectionWidth || '2px')\r\n          .style('stroke', this.config.connectionColor || '#d6d6d6').style('backgroundColor', 'red')\r\n      })\r\n      .nodeContent((d: any) => {\r\n        if (!this.templateFuncion) {\r\n          if (d.data.template) {\r\n            const jsTemplate = this.stringToTemplateLiteral(d.data.template);\r\n            var templateConverter = new Function('data', 'return' + jsTemplate);\r\n            var x = templateConverter(d.data.data);\r\n          } else {\r\n            const jsTemplate = this.stringToTemplateLiteral(this.config.templateItem);\r\n            var templateConverter = new Function('data', 'return' + jsTemplate);\r\n            var x = templateConverter(d.data.data);\r\n          }\r\n        } else {\r\n          var x = this.generateTemplate(d)\r\n\r\n        }\r\n        return x;\r\n      })\r\n      .defaultFont('Roboto')\r\n      .render()\r\n      this.chart.expandAll()\r\n\r\n  }\r\n\r\n  stringToTemplateLiteral(string: string): string {\r\n    const convertedTemplate = string.replace(\r\n      /\\{\\{([^}]*)\\}\\}/g,\r\n      '${$1}'\r\n    );\r\n\r\n    return '`' + convertedTemplate + '`';\r\n  }\r\n}","<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n  <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n    <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n    (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n    <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n    (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n    <div *ngIf=\"mostraMenu\">\r\n      <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n    <!-- <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"compactSwap()\" pTooltip=\"Compactar\">cached</span> -->\r\n\r\n    <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n      (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n      filter_center_focus\r\n    </span>\r\n\r\n    <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n      (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n      fullscreen\r\n    </span>\r\n\r\n    </div>\r\n\r\n\r\n  </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n"]}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-orgchart.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-orgchart/kv-orgchart.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-orgchart/kv-orgchart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  model,\r\n  Output,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\n\r\nimport { OrgChart } from 'd3-org-chart';\r\nimport * as d3 from 'd3';\r\n\r\nimport OrgChartConfig from '../../api/components/chart/orchart.config';\r\nimport OrgChartNode from '../../api/components/chart/orchartnode';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport { OrgChartService } from '../../api/services/orgchart.service';\r\n\r\n@Component({\r\n  selector: 'kv-orgchart',\r\n  templateUrl: './kv-orgchart.component.html',\r\n  styleUrls: ['./kv-orgchart.component.scss'],\r\n})\r\nexport class KvOrgchartComponent {\r\n  chart!: any;\r\n\r\n  dataSource = model<OrgChartNode[] | null>(null);\r\n\r\n  @Input() config!: OrgChartConfig;\r\n  @ViewChild('chartContainer') chartContainer!: ElementRef;\r\n  @ViewChild('nodeTemplate', { read: ViewContainerRef })\r\n  viewContainerRef!: ViewContainerRef;\r\n  @Input() nodeTemplate!: TemplateRef<any>;\r\n\r\n  //#region Emissores de evento\r\n\r\n  @Output() onNodeClick = new EventEmitter<any>();\r\n\r\n  // #endregion\r\n\r\n  compact: boolean = true;\r\n  mostraMenu: boolean = false;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private service: OrgChartService\r\n  ) {}\r\n\r\n  //#region Iniciar OrgChart e Atualização de dados\r\n  ngOnInit(): void {\r\n    this.iniciarHandlersDeEventos();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    if (!this.chart) {\r\n      this.chart = new OrgChart();\r\n    }\r\n    this.iniciarChart();\r\n  }\r\n\r\n  iniciarChart() {\r\n    if (!this.dataSource() || !this.chart) {\r\n      return;\r\n    }\r\n\r\n    const chartContainer = this.chartContainer.nativeElement;\r\n    this.chart\r\n      .createZoom(() => {\r\n        return d3.zoom().filter((e) => {\r\n          const element: HTMLElement = e.srcElement;\r\n          if (element.classList.contains('no-zoom')) {\r\n            return false;\r\n          }\r\n          return true;\r\n        });\r\n      })\r\n      .container(chartContainer)\r\n      .data(this.dataSource())\r\n      .nodeWidth(() => this.config.cardWidht)\r\n      .nodeHeight((d: any) => {\r\n        return d.data.expanded && this.config.cardExpandedHeight\r\n          ? this.config.cardExpandedHeight\r\n          : this.config.cardHeight;\r\n      })\r\n      .compact(false)\r\n      .buttonContent(({ node, state }: { node: any; state: any }) => {\r\n        return `<div style=\"color:#FFFFFF; border-radius:100%;font-size:5px;margin:auto auto;background-color:#64748B;\">\r\n          <span>\r\n          ${\r\n            node.children && node.children.length > 0\r\n              ? `<i class=\"material-symbols-outlined\">\r\n              keyboard_arrow_up\r\n              </i>`\r\n              : `<i class=\"material-symbols-outlined\">\r\n              keyboard_arrow_down\r\n            </i>`\r\n          }\r\n          </span>\r\n            </div>`;\r\n      })\r\n      .linkUpdate((node: any, index: any, nodes: any) => {\r\n        d3.select(nodes[index])\r\n          .attr('stroke-width', this.config.conectionWidth || '2px')\r\n          .style('stroke', this.config.connectionColor || '#d6d6d6');\r\n      })\r\n      .nodeContent((d: any) => {\r\n        const node: OrgChartNode = {\r\n          data: d.data.data,\r\n          children: d.children,\r\n          id: d.data.id,\r\n          parentId: d.data.parentId,\r\n          expanded: d.data.expanded,\r\n        };\r\n        const x = this.renderNodeTemplate(node);\r\n        return x;\r\n      })\r\n      .nodeUpdate(function (this: any, d: any) {\r\n        d.data.data.config.clicks.forEach((click: any) => {\r\n          d3.select(this)\r\n            .select(click)\r\n            .on('click', (e, d) => {\r\n              const dados: any = d;\r\n              const node: OrgChartNode = {\r\n                data: dados.data.data,\r\n                children: dados.children,\r\n                id: dados.data.id,\r\n                parentId: dados.data.parentId,\r\n                expanded: dados.data.expanded,\r\n              };\r\n\r\n              window.dispatchEvent(\r\n                new CustomEvent('KvOrgChart_NodeClick', {\r\n                  detail: {\r\n                    node,\r\n                    seletor: click,\r\n                  },\r\n                })\r\n              );\r\n            });\r\n        });\r\n      })\r\n      .defaultFont('Roboto')\r\n      .render();\r\n\r\n    this.chart.expandAll();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['dataSource']) {\r\n      this.iniciarChart();\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n  // #region Renderização de template\r\n  renderNodeTemplate(node: OrgChartNode): string {\r\n    this.viewContainerRef.clear();\r\n    const view = this.viewContainerRef.createEmbeddedView(this.nodeTemplate, {\r\n      node: node,\r\n    });\r\n    this.cdr.detectChanges();\r\n    return view.rootNodes[0].outerHTML;\r\n  }\r\n  // #endregion\r\n\r\n  // #region Eventos\r\n  private nodeClickSubscription!: Subscription;\r\n  private nodeAddSubscription!: Subscription;\r\n  private nodeRemoveSubscription!: Subscription;\r\n\r\n  iniciarHandlersDeEventos() {\r\n    this.nodeClickSubscription = fromEvent<CustomEvent>(\r\n      window,\r\n      'KvOrgChart_NodeClick'\r\n    ).subscribe((event: CustomEvent) => {\r\n      this.emitirClick(event.detail.node, event.detail.seletor);\r\n    });\r\n\r\n    this.nodeAddSubscription = this.service.nodeAdd$.subscribe(\r\n      (node: OrgChartNode) => {\r\n        this.adicionarNode(node);\r\n      }\r\n    );\r\n\r\n    this.nodeRemoveSubscription = this.service.nodeRemove$.subscribe(\r\n      (id: number) => {\r\n        this.removerNode(id);\r\n      }\r\n    );\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.nodeClickSubscription.unsubscribe();\r\n    this.nodeAddSubscription.unsubscribe();\r\n    this.nodeRemoveSubscription.unsubscribe();\r\n  }\r\n\r\n  emitirClick(node: Node, seletorCss?: string) {\r\n    const event = {\r\n      node: node,\r\n      seletorCss: seletorCss ?? '',\r\n    };\r\n    this.onNodeClick.emit(event);\r\n  }\r\n  adicionarNode(node: OrgChartNode) {\r\n    const arr = [...this.dataSource()!, node];\r\n    this.dataSource.set(arr);\r\n    this.iniciarChart();\r\n  }\r\n  removerNode(id: number) {\r\n    const indPai = this.dataSource()!.some((x: any) => x.parentId == id);\r\n    if (indPai) {\r\n      alert('Não é possível remover um nó que possui filhos');\r\n    } else {\r\n      const arr = this.dataSource()!.filter((x: any) => x.id != id);\r\n      this.dataSource.set(arr);\r\n      this.iniciarChart();\r\n    }\r\n  }\r\n  // #endregion\r\n}\r\n","<div #chartContainer id=\"chartContainer\" [ngClass]=\"{'backGround': true}\">\r\n\r\n\r\n  <div class=\"div-botoes w-full flex gap-1\" >\r\n\r\n\r\n    <span *ngIf=\"!mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n    (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Expandir menu\">menu</span>\r\n\r\n\r\n\r\n    <span *ngIf=\"mostraMenu\" class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n    (click)=\"mostraMenu = !mostraMenu\" pTooltip=\"Recolher menu\">menu_open</span>\r\n\r\n    <div *ngIf=\"mostraMenu\">\r\n      <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.zoomIn()\" pTooltip=\"Zoom +\">zoom_in</span>\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.zoomOut()\" pTooltip=\"Zoom -\">zoom_out</span>\r\n\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.collapseAll()\" pTooltip=\"Recolher\">expand_less</span>\r\n\r\n    <span class=\"surface-300 shadow-4 p-1 m-2 border-circle material-icons cursor-pointer\"\r\n      (click)=\"chart.expandAll()\" pTooltip=\"Expandir\">expand_more</span>\r\n\r\n\r\n    <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n      (click)=\"chart.fit().render()\" pTooltip=\"Centralizar\">\r\n      filter_center_focus\r\n    </span>\r\n\r\n    <span class=\"material-icons surface-300 shadow-4 p-1 m-2 border-circle cursor-pointer\"\r\n      (click)=\"chart.fullscreen('#chartContainer')\" pTooltip=\"Tela cheia\" >\r\n      fullscreen\r\n    </span>\r\n\r\n    </div>\r\n\r\n\r\n  </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n\r\n<div style=\"display: none;\">\r\n  <ng-template #nodeTemplate let-node>\r\n    <div class=\"node-content\">\r\n      erro\r\n    </div>\r\n  </ng-template>\r\n</div>\r\n"]}
@@ -1,24 +1,35 @@
1
+ import { kvErrorModule } from './../kv-error/kv-error.module';
1
2
  import { NgModule } from '@angular/core';
2
3
  import { CommonModule } from '@angular/common';
3
4
  import { KvOrgchartComponent } from './kv-orgchart.component';
4
- import { PrimeNgModule } from '../../../public-api';
5
+ import { PrimeNgModule } from '../../api/modules/primeng.module';
6
+ import { OrganizationChartModule } from 'primeng/organizationchart';
5
7
  import * as i0 from "@angular/core";
6
8
  export class KvOrgchartModule {
7
9
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
10
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartModule, declarations: [KvOrgchartComponent], imports: [CommonModule,
9
- PrimeNgModule], exports: [KvOrgchartComponent] }); }
11
+ PrimeNgModule,
12
+ kvErrorModule,
13
+ PrimeNgModule,
14
+ OrganizationChartModule], exports: [KvOrgchartComponent] }); }
10
15
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartModule, imports: [CommonModule,
11
- PrimeNgModule] }); }
16
+ PrimeNgModule,
17
+ kvErrorModule,
18
+ PrimeNgModule,
19
+ OrganizationChartModule] }); }
12
20
  }
13
21
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvOrgchartModule, decorators: [{
14
22
  type: NgModule,
15
23
  args: [{
16
24
  imports: [
17
25
  CommonModule,
18
- PrimeNgModule
26
+ PrimeNgModule,
27
+ kvErrorModule,
28
+ PrimeNgModule,
29
+ OrganizationChartModule
19
30
  ],
20
31
  declarations: [KvOrgchartComponent],
21
32
  exports: [KvOrgchartComponent]
22
33
  }]
23
34
  }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3Ytb3JnY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3Ytb3JnY2hhcnQva3Ytb3JnY2hhcnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7QUFVcEQsTUFBTSxPQUFPLGdCQUFnQjs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBSFosbUJBQW1CLGFBSGhDLFlBQVk7WUFDWixhQUFhLGFBR0wsbUJBQW1COytHQUVsQixnQkFBZ0IsWUFOekIsWUFBWTtZQUNaLGFBQWE7OzJGQUtKLGdCQUFnQjtrQkFSNUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3FCQUNkO29CQUNELFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNuQyxPQUFPLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBLdk9yZ2NoYXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9rdi1vcmdjaGFydC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBQcmltZU5nTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vcHVibGljLWFwaSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFByaW1lTmdNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW0t2T3JnY2hhcnRDb21wb25lbnRdLFxyXG4gIGV4cG9ydHM6IFtLdk9yZ2NoYXJ0Q29tcG9uZW50XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgS3ZPcmdjaGFydE1vZHVsZSB7IH1cclxuIl19
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3Ytb3JnY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3Ytb3JnY2hhcnQva3Ytb3JnY2hhcnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDakUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBYXBFLE1BQU0sT0FBTyxnQkFBZ0I7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQUhaLG1CQUFtQixhQU5oQyxZQUFZO1lBQ1osYUFBYTtZQUNiLGFBQWE7WUFDYixhQUFhO1lBQ2IsdUJBQXVCLGFBR2YsbUJBQW1COytHQUVsQixnQkFBZ0IsWUFUekIsWUFBWTtZQUNaLGFBQWE7WUFDYixhQUFhO1lBQ2IsYUFBYTtZQUNiLHVCQUF1Qjs7MkZBS2QsZ0JBQWdCO2tCQVg1QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixhQUFhO3dCQUNiLHVCQUF1QjtxQkFDeEI7b0JBQ0QsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGt2RXJyb3JNb2R1bGUgfSBmcm9tICcuLy4uL2t2LWVycm9yL2t2LWVycm9yLm1vZHVsZSc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEt2T3JnY2hhcnRDb21wb25lbnQgfSBmcm9tICcuL2t2LW9yZ2NoYXJ0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFByaW1lTmdNb2R1bGUgfSBmcm9tICcuLi8uLi9hcGkvbW9kdWxlcy9wcmltZW5nLm1vZHVsZSc7XHJcbmltcG9ydCB7IE9yZ2FuaXphdGlvbkNoYXJ0TW9kdWxlIH0gZnJvbSAncHJpbWVuZy9vcmdhbml6YXRpb25jaGFydCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFByaW1lTmdNb2R1bGUsXHJcbiAgICBrdkVycm9yTW9kdWxlLFxyXG4gICAgUHJpbWVOZ01vZHVsZSxcclxuICAgIE9yZ2FuaXphdGlvbkNoYXJ0TW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtLdk9yZ2NoYXJ0Q29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbS3ZPcmdjaGFydENvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEt2T3JnY2hhcnRNb2R1bGUgeyB9XHJcbiJdfQ==