@unovis/angular 1.4.4 → 1.5.0-beta.0
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.
- package/dist/lib/bundles/unovis-angular.umd.js +30 -6
- package/dist/lib/bundles/unovis-angular.umd.js.map +1 -1
- package/dist/lib/components/graph/graph.component.d.ts +32 -4
- package/dist/lib/containers/single-container/single-container.component.d.ts +17 -4
- package/dist/lib/containers/xy-container/xy-container.component.d.ts +10 -2
- package/dist/lib/esm2015/components/graph/graph.component.js +24 -4
- package/dist/lib/esm2015/containers/single-container/single-container.component.js +8 -4
- package/dist/lib/esm2015/containers/xy-container/xy-container.component.js +1 -1
- package/dist/lib/fesm2015/unovis-angular.js +30 -6
- package/dist/lib/fesm2015/unovis-angular.js.map +1 -1
- package/dist/lib/package.json +2 -2
- package/package.json +2 -2
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { AfterViewInit, SimpleChanges } from '@angular/core';
|
|
2
|
-
import { Graph, GraphConfigInterface, ContainerCore, GraphInputNode, GraphInputLink, VisEventType, VisEventCallback, GraphLayoutType, StringAccessor, GraphForceLayoutSettings, GraphDagreLayoutSetting, GenericAccessor, GraphElkLayoutSettings, NumericAccessor, GraphLinkStyle, GraphLinkArrowStyle, ColorAccessor, BooleanAccessor, GraphCircleLabel, GraphNodeShape, TrimMode,
|
|
2
|
+
import { Graph, GraphConfigInterface, ContainerCore, GraphInputNode, GraphInputLink, VisEventType, VisEventCallback, GraphLayoutType, StringAccessor, GraphForceLayoutSettings, GraphDagreLayoutSetting, GenericAccessor, GraphElkLayoutSettings, NumericAccessor, GraphLinkStyle, GraphLinkArrowStyle, ColorAccessor, BooleanAccessor, GraphCircleLabel, GraphNodeShape, TrimMode, GraphNode, GraphNodeSelectionHighlightMode, GraphPanelConfig, GraphLink } from '@unovis/ts';
|
|
3
|
+
import { Selection } from 'd3-selection';
|
|
3
4
|
import { D3DragEvent } from 'd3-drag';
|
|
4
|
-
import { D3ZoomEvent } from 'd3-zoom';
|
|
5
|
+
import { D3ZoomEvent, ZoomTransform } from 'd3-zoom';
|
|
5
6
|
import { D3BrushEvent } from 'd3-brush';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export declare class VisGraphComponent<N extends GraphInputNode, L extends GraphInputLink> implements GraphConfigInterface<N, L>, AfterViewInit {
|
|
@@ -56,6 +57,10 @@ export declare class VisGraphComponent<N extends GraphInputNode, L extends Graph
|
|
|
56
57
|
zoomScaleExtent?: [number, number];
|
|
57
58
|
/** Disable zooming. Default: `false` */
|
|
58
59
|
disableZoom?: boolean;
|
|
60
|
+
/** Custom Zoom event filter to better control which actions should trigger zooming.
|
|
61
|
+
* Learn more: https://d3js.org/d3-zoom#zoom_filter.
|
|
62
|
+
* Default: `undefined` */
|
|
63
|
+
zoomEventFilter?: (event: PointerEvent) => boolean;
|
|
59
64
|
/** Disable node dragging. Default: `false` */
|
|
60
65
|
disableDrag?: boolean;
|
|
61
66
|
/** Disable brush for multiple node selection. Default: `false` */
|
|
@@ -201,6 +206,23 @@ export declare class VisGraphComponent<N extends GraphInputNode, L extends Graph
|
|
|
201
206
|
nodeExitPosition?: GenericAccessor<[number, number], N> | undefined;
|
|
202
207
|
/** Specify the destination scale for exiting nodes in the range [0,1]. Default: `0.75` */
|
|
203
208
|
nodeExitScale?: NumericAccessor<N> | undefined;
|
|
209
|
+
/** Custom "enter" function for node rendering. Default: `undefined` */
|
|
210
|
+
nodeEnterCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void;
|
|
211
|
+
/** Custom "update" function for node rendering. Default: `undefined` */
|
|
212
|
+
nodeUpdateCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void;
|
|
213
|
+
/** Custom partial "update" function for node rendering which will be triggered after the following events:
|
|
214
|
+
* - Full node update (`nodeUpdateCustomRenderFunction`);
|
|
215
|
+
* - Background click;
|
|
216
|
+
* - Node and Link mouseover and mouseout;
|
|
217
|
+
* - Node brushing,
|
|
218
|
+
* Default: `undefined` */
|
|
219
|
+
nodePartialUpdateCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void;
|
|
220
|
+
/** Custom "exit" function for node rendering. Default: `undefined` */
|
|
221
|
+
nodeExitCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void;
|
|
222
|
+
/** Custom render function that will be called while zooming / panning the graph. Default: `undefined` */
|
|
223
|
+
nodeOnZoomCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, zoomLevel: number) => void;
|
|
224
|
+
/** Define the mode for highlighting selected nodes in the graph. Default: `GraphNodeSelectionHighlightMode.GreyoutNonConnected` */
|
|
225
|
+
nodeSelectionHighlightMode?: GraphNodeSelectionHighlightMode;
|
|
204
226
|
/** Set selected node by unique id. Default: `undefined` */
|
|
205
227
|
selectedNodeId?: number | string;
|
|
206
228
|
/** Set selected nodes by unique id. Default: `undefined` */
|
|
@@ -214,13 +236,19 @@ export declare class VisGraphComponent<N extends GraphInputNode, L extends Graph
|
|
|
214
236
|
/** Graph node drag end callback function. Default: `undefined` */
|
|
215
237
|
onNodeDragEnd?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined;
|
|
216
238
|
/** Zoom event callback. Default: `undefined` */
|
|
217
|
-
onZoom?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined) => void;
|
|
239
|
+
onZoom?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void;
|
|
240
|
+
/** Zoom start event callback. Default: `undefined` */
|
|
241
|
+
onZoomStart?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void;
|
|
242
|
+
/** Zoom end event callback. Default: `undefined` */
|
|
243
|
+
onZoomEnd?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void;
|
|
218
244
|
/** Callback function to be called when the graph layout is calculated. Default: `undefined` */
|
|
219
245
|
onLayoutCalculated?: (n: GraphNode<N, L>[], links: GraphLink<N, L>[]) => void;
|
|
220
246
|
/** Graph node selection brush callback function. Default: `undefined` */
|
|
221
247
|
onNodeSelectionBrush?: (selectedNodes: GraphNode<N, L>[], event: D3BrushEvent<SVGGElement> | undefined) => void;
|
|
222
248
|
/** Graph multiple node drag callback function. Default: `undefined` */
|
|
223
249
|
onNodeSelectionDrag?: (selectedNodes: GraphNode<N, L>[], event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void;
|
|
250
|
+
/** Callback function to be called when the graph rendering is complete. Default: `undefined` */
|
|
251
|
+
onRenderComplete?: (g: Selection<SVGGElement, unknown, null, undefined>, nodes: GraphNode<N, L>[], links: GraphLink<N, L>[], config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number, width: number, height: number) => void;
|
|
224
252
|
data: {
|
|
225
253
|
nodes: N[];
|
|
226
254
|
links?: L[];
|
|
@@ -231,5 +259,5 @@ export declare class VisGraphComponent<N extends GraphInputNode, L extends Graph
|
|
|
231
259
|
ngOnChanges(changes: SimpleChanges): void;
|
|
232
260
|
private getConfig;
|
|
233
261
|
static ɵfac: i0.ɵɵFactoryDeclaration<VisGraphComponent<any, any>, never>;
|
|
234
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<VisGraphComponent<any, any>, "vis-graph", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "zoomScaleExtent": "zoomScaleExtent"; "disableZoom": "disableZoom"; "disableDrag": "disableDrag"; "disableBrush": "disableBrush"; "zoomThrottledUpdateNodeThreshold": "zoomThrottledUpdateNodeThreshold"; "layoutType": "layoutType"; "layoutAutofit": "layoutAutofit"; "layoutAutofitTolerance": "layoutAutofitTolerance"; "layoutNonConnectedAside": "layoutNonConnectedAside"; "layoutNodeGroup": "layoutNodeGroup"; "layoutGroupOrder": "layoutGroupOrder"; "layoutParallelNodesPerColumn": "layoutParallelNodesPerColumn"; "layoutParallelNodeSubGroup": "layoutParallelNodeSubGroup"; "layoutParallelSubGroupsPerRow": "layoutParallelSubGroupsPerRow"; "layoutParallelGroupSpacing": "layoutParallelGroupSpacing"; "layoutParallelSortConnectionsByGroup": "layoutParallelSortConnectionsByGroup"; "forceLayoutSettings": "forceLayoutSettings"; "dagreLayoutSettings": "dagreLayoutSettings"; "layoutElkSettings": "layoutElkSettings"; "layoutElkNodeGroups": "layoutElkNodeGroups"; "linkWidth": "linkWidth"; "linkStyle": "linkStyle"; "linkBandWidth": "linkBandWidth"; "linkArrow": "linkArrow"; "linkStroke": "linkStroke"; "linkDisabled": "linkDisabled"; "linkFlow": "linkFlow"; "linkFlowAnimDuration": "linkFlowAnimDuration"; "linkFlowParticleSize": "linkFlowParticleSize"; "linkLabel": "linkLabel"; "linkLabelShiftFromCenter": "linkLabelShiftFromCenter"; "linkNeighborSpacing": "linkNeighborSpacing"; "linkCurvature": "linkCurvature"; "selectedLinkId": "selectedLinkId"; "nodeSize": "nodeSize"; "nodeStrokeWidth": "nodeStrokeWidth"; "nodeShape": "nodeShape"; "nodeGaugeValue": "nodeGaugeValue"; "nodeGaugeFill": "nodeGaugeFill"; "nodeGaugeAnimDuration": "nodeGaugeAnimDuration"; "nodeIcon": "nodeIcon"; "nodeIconSize": "nodeIconSize"; "nodeLabel": "nodeLabel"; "nodeLabelTrim": "nodeLabelTrim"; "nodeLabelTrimMode": "nodeLabelTrimMode"; "nodeLabelTrimLength": "nodeLabelTrimLength"; "nodeSubLabel": "nodeSubLabel"; "nodeSubLabelTrim": "nodeSubLabelTrim"; "nodeSubLabelTrimMode": "nodeSubLabelTrimMode"; "nodeSubLabelTrimLength": "nodeSubLabelTrimLength"; "nodeSideLabels": "nodeSideLabels"; "nodeBottomIcon": "nodeBottomIcon"; "nodeDisabled": "nodeDisabled"; "nodeFill": "nodeFill"; "nodeStroke": "nodeStroke"; "nodeSort": "nodeSort"; "nodeEnterPosition": "nodeEnterPosition"; "nodeEnterScale": "nodeEnterScale"; "nodeExitPosition": "nodeExitPosition"; "nodeExitScale": "nodeExitScale"; "selectedNodeId": "selectedNodeId"; "selectedNodeIds": "selectedNodeIds"; "panels": "panels"; "onNodeDragStart": "onNodeDragStart"; "onNodeDrag": "onNodeDrag"; "onNodeDragEnd": "onNodeDragEnd"; "onZoom": "onZoom"; "onLayoutCalculated": "onLayoutCalculated"; "onNodeSelectionBrush": "onNodeSelectionBrush"; "onNodeSelectionDrag": "onNodeSelectionDrag"; "data": "data"; }, {}, never, never>;
|
|
262
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<VisGraphComponent<any, any>, "vis-graph", never, { "duration": "duration"; "events": "events"; "attributes": "attributes"; "zoomScaleExtent": "zoomScaleExtent"; "disableZoom": "disableZoom"; "zoomEventFilter": "zoomEventFilter"; "disableDrag": "disableDrag"; "disableBrush": "disableBrush"; "zoomThrottledUpdateNodeThreshold": "zoomThrottledUpdateNodeThreshold"; "layoutType": "layoutType"; "layoutAutofit": "layoutAutofit"; "layoutAutofitTolerance": "layoutAutofitTolerance"; "layoutNonConnectedAside": "layoutNonConnectedAside"; "layoutNodeGroup": "layoutNodeGroup"; "layoutGroupOrder": "layoutGroupOrder"; "layoutParallelNodesPerColumn": "layoutParallelNodesPerColumn"; "layoutParallelNodeSubGroup": "layoutParallelNodeSubGroup"; "layoutParallelSubGroupsPerRow": "layoutParallelSubGroupsPerRow"; "layoutParallelGroupSpacing": "layoutParallelGroupSpacing"; "layoutParallelSortConnectionsByGroup": "layoutParallelSortConnectionsByGroup"; "forceLayoutSettings": "forceLayoutSettings"; "dagreLayoutSettings": "dagreLayoutSettings"; "layoutElkSettings": "layoutElkSettings"; "layoutElkNodeGroups": "layoutElkNodeGroups"; "linkWidth": "linkWidth"; "linkStyle": "linkStyle"; "linkBandWidth": "linkBandWidth"; "linkArrow": "linkArrow"; "linkStroke": "linkStroke"; "linkDisabled": "linkDisabled"; "linkFlow": "linkFlow"; "linkFlowAnimDuration": "linkFlowAnimDuration"; "linkFlowParticleSize": "linkFlowParticleSize"; "linkLabel": "linkLabel"; "linkLabelShiftFromCenter": "linkLabelShiftFromCenter"; "linkNeighborSpacing": "linkNeighborSpacing"; "linkCurvature": "linkCurvature"; "selectedLinkId": "selectedLinkId"; "nodeSize": "nodeSize"; "nodeStrokeWidth": "nodeStrokeWidth"; "nodeShape": "nodeShape"; "nodeGaugeValue": "nodeGaugeValue"; "nodeGaugeFill": "nodeGaugeFill"; "nodeGaugeAnimDuration": "nodeGaugeAnimDuration"; "nodeIcon": "nodeIcon"; "nodeIconSize": "nodeIconSize"; "nodeLabel": "nodeLabel"; "nodeLabelTrim": "nodeLabelTrim"; "nodeLabelTrimMode": "nodeLabelTrimMode"; "nodeLabelTrimLength": "nodeLabelTrimLength"; "nodeSubLabel": "nodeSubLabel"; "nodeSubLabelTrim": "nodeSubLabelTrim"; "nodeSubLabelTrimMode": "nodeSubLabelTrimMode"; "nodeSubLabelTrimLength": "nodeSubLabelTrimLength"; "nodeSideLabels": "nodeSideLabels"; "nodeBottomIcon": "nodeBottomIcon"; "nodeDisabled": "nodeDisabled"; "nodeFill": "nodeFill"; "nodeStroke": "nodeStroke"; "nodeSort": "nodeSort"; "nodeEnterPosition": "nodeEnterPosition"; "nodeEnterScale": "nodeEnterScale"; "nodeExitPosition": "nodeExitPosition"; "nodeExitScale": "nodeExitScale"; "nodeEnterCustomRenderFunction": "nodeEnterCustomRenderFunction"; "nodeUpdateCustomRenderFunction": "nodeUpdateCustomRenderFunction"; "nodePartialUpdateCustomRenderFunction": "nodePartialUpdateCustomRenderFunction"; "nodeExitCustomRenderFunction": "nodeExitCustomRenderFunction"; "nodeOnZoomCustomRenderFunction": "nodeOnZoomCustomRenderFunction"; "nodeSelectionHighlightMode": "nodeSelectionHighlightMode"; "selectedNodeId": "selectedNodeId"; "selectedNodeIds": "selectedNodeIds"; "panels": "panels"; "onNodeDragStart": "onNodeDragStart"; "onNodeDrag": "onNodeDrag"; "onNodeDragEnd": "onNodeDragEnd"; "onZoom": "onZoom"; "onZoomStart": "onZoomStart"; "onZoomEnd": "onZoomEnd"; "onLayoutCalculated": "onLayoutCalculated"; "onNodeSelectionBrush": "onNodeSelectionBrush"; "onNodeSelectionDrag": "onNodeSelectionDrag"; "onRenderComplete": "onRenderComplete"; "data": "data"; }, {}, never, never>;
|
|
235
263
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ElementRef, AfterViewInit, OnDestroy, SimpleChanges } from '@angular/core';
|
|
2
|
-
import { ComponentCore, SingleContainer, SingleContainerConfigInterface, Spacing } from '@unovis/ts';
|
|
2
|
+
import { ComponentCore, SingleContainer, SingleContainerConfigInterface, Spacing, Sizing } from '@unovis/ts';
|
|
3
3
|
import { VisCoreComponent } from '../../core';
|
|
4
4
|
import { VisTooltipComponent } from '../../components/tooltip/tooltip.component';
|
|
5
5
|
import { VisAnnotationsComponent } from '../../components/annotations/annotations.component';
|
|
@@ -9,9 +9,17 @@ export declare class VisSingleContainerComponent<Data = unknown, C extends Compo
|
|
|
9
9
|
visComponent: VisCoreComponent;
|
|
10
10
|
tooltipComponent: VisTooltipComponent;
|
|
11
11
|
annotationsComponent: VisAnnotationsComponent;
|
|
12
|
-
/** Width in pixels
|
|
12
|
+
/** Width in pixels or in CSS units.
|
|
13
|
+
* Percentage units `"%"` are not supported here. If you want to set `width` as a percentage, do it via `style` or `class`
|
|
14
|
+
* of the corresponding DOM element.
|
|
15
|
+
* Default: `undefined`
|
|
16
|
+
*/
|
|
13
17
|
width?: number;
|
|
14
|
-
/** Height in pixels
|
|
18
|
+
/** Height in pixels or in CSS units.
|
|
19
|
+
* Percentage units `"%"` are not supported here. If you want to set `height` as a percentage, do it via `style` or `class`
|
|
20
|
+
* of the corresponding DOM element.
|
|
21
|
+
* Default: `undefined`
|
|
22
|
+
*/
|
|
15
23
|
height?: number;
|
|
16
24
|
/** Margins. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */
|
|
17
25
|
margin?: Spacing;
|
|
@@ -21,6 +29,11 @@ export declare class VisSingleContainerComponent<Data = unknown, C extends Compo
|
|
|
21
29
|
* `aria-label` attribute to the div element containing your chart. Default: `undefined`.
|
|
22
30
|
*/
|
|
23
31
|
ariaLabel?: string | null | undefined;
|
|
32
|
+
/** Custom SVG defs available to all the components within the container. Default: `undefined`. */
|
|
33
|
+
svgDefs?: string;
|
|
34
|
+
/** Defines whether components should fit into the container or the container should expand to fit to the component's size.
|
|
35
|
+
* Works with a limited set of components. Default: `Sizing.Fit` */
|
|
36
|
+
sizing?: Sizing | string;
|
|
24
37
|
/** Data to be passed to the component. Default: `undefined`. */
|
|
25
38
|
data?: Data;
|
|
26
39
|
chart: SingleContainer<Data>;
|
|
@@ -29,5 +42,5 @@ export declare class VisSingleContainerComponent<Data = unknown, C extends Compo
|
|
|
29
42
|
getConfig(): SingleContainerConfigInterface<Data>;
|
|
30
43
|
ngOnDestroy(): void;
|
|
31
44
|
static ɵfac: i0.ɵɵFactoryDeclaration<VisSingleContainerComponent<any, any>, never>;
|
|
32
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<VisSingleContainerComponent<any, any>, "vis-single-container", never, { "width": "width"; "height": "height"; "margin": "margin"; "duration": "duration"; "ariaLabel": "ariaLabel"; "data": "data"; }, {}, ["visComponent", "tooltipComponent", "annotationsComponent"], ["*"]>;
|
|
45
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<VisSingleContainerComponent<any, any>, "vis-single-container", never, { "width": "width"; "height": "height"; "margin": "margin"; "duration": "duration"; "ariaLabel": "ariaLabel"; "svgDefs": "svgDefs"; "sizing": "sizing"; "data": "data"; }, {}, ["visComponent", "tooltipComponent", "annotationsComponent"], ["*"]>;
|
|
33
46
|
}
|
|
@@ -9,9 +9,17 @@ export declare class VisXYContainerComponent<Datum> implements AfterViewInit, Af
|
|
|
9
9
|
visComponents: QueryList<VisXYComponent>;
|
|
10
10
|
tooltipComponent: VisTooltipComponent;
|
|
11
11
|
annotationsComponent: VisAnnotationsComponent;
|
|
12
|
-
/** Width in pixels
|
|
12
|
+
/** Width in pixels or in CSS units.
|
|
13
|
+
* Percentage units `"%"` are not supported here. If you want to set `width` as a percentage, do it via `style` or `class`
|
|
14
|
+
* of the corresponding DOM element.
|
|
15
|
+
* Default: `undefined`
|
|
16
|
+
*/
|
|
13
17
|
width?: number;
|
|
14
|
-
/** Height in pixels
|
|
18
|
+
/** Height in pixels or in CSS units.
|
|
19
|
+
* Percentage units `"%"` are not supported here. If you want to set `height` as a percentage, do it via `style` or `class`
|
|
20
|
+
* of the corresponding DOM element.
|
|
21
|
+
* Default: `undefined`
|
|
22
|
+
*/
|
|
15
23
|
height?: number;
|
|
16
24
|
/** Scale for X dimension, e.g. Scale.scaleLinear(). Default: `Scale.scaleLinear()` */
|
|
17
25
|
xScale?: ContinuousScale;
|
|
@@ -21,8 +21,8 @@ export class VisGraphComponent {
|
|
|
21
21
|
(_c = this.componentContainer) === null || _c === void 0 ? void 0 : _c.render();
|
|
22
22
|
}
|
|
23
23
|
getConfig() {
|
|
24
|
-
const { duration, events, attributes, zoomScaleExtent, disableZoom, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag } = this;
|
|
25
|
-
const config = { duration, events, attributes, zoomScaleExtent, disableZoom, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag };
|
|
24
|
+
const { duration, events, attributes, zoomScaleExtent, disableZoom, zoomEventFilter, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, nodeEnterCustomRenderFunction, nodeUpdateCustomRenderFunction, nodePartialUpdateCustomRenderFunction, nodeExitCustomRenderFunction, nodeOnZoomCustomRenderFunction, nodeSelectionHighlightMode, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onZoomStart, onZoomEnd, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag, onRenderComplete } = this;
|
|
25
|
+
const config = { duration, events, attributes, zoomScaleExtent, disableZoom, zoomEventFilter, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, nodeEnterCustomRenderFunction, nodeUpdateCustomRenderFunction, nodePartialUpdateCustomRenderFunction, nodeExitCustomRenderFunction, nodeOnZoomCustomRenderFunction, nodeSelectionHighlightMode, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onZoomStart, onZoomEnd, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag, onRenderComplete };
|
|
26
26
|
const keys = Object.keys(config);
|
|
27
27
|
keys.forEach(key => { if (config[key] === undefined)
|
|
28
28
|
delete config[key]; });
|
|
@@ -30,7 +30,7 @@ export class VisGraphComponent {
|
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
VisGraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisGraphComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
VisGraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisGraphComponent, selector: "vis-graph", inputs: { duration: "duration", events: "events", attributes: "attributes", zoomScaleExtent: "zoomScaleExtent", disableZoom: "disableZoom", disableDrag: "disableDrag", disableBrush: "disableBrush", zoomThrottledUpdateNodeThreshold: "zoomThrottledUpdateNodeThreshold", layoutType: "layoutType", layoutAutofit: "layoutAutofit", layoutAutofitTolerance: "layoutAutofitTolerance", layoutNonConnectedAside: "layoutNonConnectedAside", layoutNodeGroup: "layoutNodeGroup", layoutGroupOrder: "layoutGroupOrder", layoutParallelNodesPerColumn: "layoutParallelNodesPerColumn", layoutParallelNodeSubGroup: "layoutParallelNodeSubGroup", layoutParallelSubGroupsPerRow: "layoutParallelSubGroupsPerRow", layoutParallelGroupSpacing: "layoutParallelGroupSpacing", layoutParallelSortConnectionsByGroup: "layoutParallelSortConnectionsByGroup", forceLayoutSettings: "forceLayoutSettings", dagreLayoutSettings: "dagreLayoutSettings", layoutElkSettings: "layoutElkSettings", layoutElkNodeGroups: "layoutElkNodeGroups", linkWidth: "linkWidth", linkStyle: "linkStyle", linkBandWidth: "linkBandWidth", linkArrow: "linkArrow", linkStroke: "linkStroke", linkDisabled: "linkDisabled", linkFlow: "linkFlow", linkFlowAnimDuration: "linkFlowAnimDuration", linkFlowParticleSize: "linkFlowParticleSize", linkLabel: "linkLabel", linkLabelShiftFromCenter: "linkLabelShiftFromCenter", linkNeighborSpacing: "linkNeighborSpacing", linkCurvature: "linkCurvature", selectedLinkId: "selectedLinkId", nodeSize: "nodeSize", nodeStrokeWidth: "nodeStrokeWidth", nodeShape: "nodeShape", nodeGaugeValue: "nodeGaugeValue", nodeGaugeFill: "nodeGaugeFill", nodeGaugeAnimDuration: "nodeGaugeAnimDuration", nodeIcon: "nodeIcon", nodeIconSize: "nodeIconSize", nodeLabel: "nodeLabel", nodeLabelTrim: "nodeLabelTrim", nodeLabelTrimMode: "nodeLabelTrimMode", nodeLabelTrimLength: "nodeLabelTrimLength", nodeSubLabel: "nodeSubLabel", nodeSubLabelTrim: "nodeSubLabelTrim", nodeSubLabelTrimMode: "nodeSubLabelTrimMode", nodeSubLabelTrimLength: "nodeSubLabelTrimLength", nodeSideLabels: "nodeSideLabels", nodeBottomIcon: "nodeBottomIcon", nodeDisabled: "nodeDisabled", nodeFill: "nodeFill", nodeStroke: "nodeStroke", nodeSort: "nodeSort", nodeEnterPosition: "nodeEnterPosition", nodeEnterScale: "nodeEnterScale", nodeExitPosition: "nodeExitPosition", nodeExitScale: "nodeExitScale", selectedNodeId: "selectedNodeId", selectedNodeIds: "selectedNodeIds", panels: "panels", onNodeDragStart: "onNodeDragStart", onNodeDrag: "onNodeDrag", onNodeDragEnd: "onNodeDragEnd", onZoom: "onZoom", onLayoutCalculated: "onLayoutCalculated", onNodeSelectionBrush: "onNodeSelectionBrush", onNodeSelectionDrag: "onNodeSelectionDrag", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisGraphComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
33
|
+
VisGraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisGraphComponent, selector: "vis-graph", inputs: { duration: "duration", events: "events", attributes: "attributes", zoomScaleExtent: "zoomScaleExtent", disableZoom: "disableZoom", zoomEventFilter: "zoomEventFilter", disableDrag: "disableDrag", disableBrush: "disableBrush", zoomThrottledUpdateNodeThreshold: "zoomThrottledUpdateNodeThreshold", layoutType: "layoutType", layoutAutofit: "layoutAutofit", layoutAutofitTolerance: "layoutAutofitTolerance", layoutNonConnectedAside: "layoutNonConnectedAside", layoutNodeGroup: "layoutNodeGroup", layoutGroupOrder: "layoutGroupOrder", layoutParallelNodesPerColumn: "layoutParallelNodesPerColumn", layoutParallelNodeSubGroup: "layoutParallelNodeSubGroup", layoutParallelSubGroupsPerRow: "layoutParallelSubGroupsPerRow", layoutParallelGroupSpacing: "layoutParallelGroupSpacing", layoutParallelSortConnectionsByGroup: "layoutParallelSortConnectionsByGroup", forceLayoutSettings: "forceLayoutSettings", dagreLayoutSettings: "dagreLayoutSettings", layoutElkSettings: "layoutElkSettings", layoutElkNodeGroups: "layoutElkNodeGroups", linkWidth: "linkWidth", linkStyle: "linkStyle", linkBandWidth: "linkBandWidth", linkArrow: "linkArrow", linkStroke: "linkStroke", linkDisabled: "linkDisabled", linkFlow: "linkFlow", linkFlowAnimDuration: "linkFlowAnimDuration", linkFlowParticleSize: "linkFlowParticleSize", linkLabel: "linkLabel", linkLabelShiftFromCenter: "linkLabelShiftFromCenter", linkNeighborSpacing: "linkNeighborSpacing", linkCurvature: "linkCurvature", selectedLinkId: "selectedLinkId", nodeSize: "nodeSize", nodeStrokeWidth: "nodeStrokeWidth", nodeShape: "nodeShape", nodeGaugeValue: "nodeGaugeValue", nodeGaugeFill: "nodeGaugeFill", nodeGaugeAnimDuration: "nodeGaugeAnimDuration", nodeIcon: "nodeIcon", nodeIconSize: "nodeIconSize", nodeLabel: "nodeLabel", nodeLabelTrim: "nodeLabelTrim", nodeLabelTrimMode: "nodeLabelTrimMode", nodeLabelTrimLength: "nodeLabelTrimLength", nodeSubLabel: "nodeSubLabel", nodeSubLabelTrim: "nodeSubLabelTrim", nodeSubLabelTrimMode: "nodeSubLabelTrimMode", nodeSubLabelTrimLength: "nodeSubLabelTrimLength", nodeSideLabels: "nodeSideLabels", nodeBottomIcon: "nodeBottomIcon", nodeDisabled: "nodeDisabled", nodeFill: "nodeFill", nodeStroke: "nodeStroke", nodeSort: "nodeSort", nodeEnterPosition: "nodeEnterPosition", nodeEnterScale: "nodeEnterScale", nodeExitPosition: "nodeExitPosition", nodeExitScale: "nodeExitScale", nodeEnterCustomRenderFunction: "nodeEnterCustomRenderFunction", nodeUpdateCustomRenderFunction: "nodeUpdateCustomRenderFunction", nodePartialUpdateCustomRenderFunction: "nodePartialUpdateCustomRenderFunction", nodeExitCustomRenderFunction: "nodeExitCustomRenderFunction", nodeOnZoomCustomRenderFunction: "nodeOnZoomCustomRenderFunction", nodeSelectionHighlightMode: "nodeSelectionHighlightMode", selectedNodeId: "selectedNodeId", selectedNodeIds: "selectedNodeIds", panels: "panels", onNodeDragStart: "onNodeDragStart", onNodeDrag: "onNodeDrag", onNodeDragEnd: "onNodeDragEnd", onZoom: "onZoom", onZoomStart: "onZoomStart", onZoomEnd: "onZoomEnd", onLayoutCalculated: "onLayoutCalculated", onNodeSelectionBrush: "onNodeSelectionBrush", onNodeSelectionDrag: "onNodeSelectionDrag", onRenderComplete: "onRenderComplete", data: "data" }, providers: [{ provide: VisCoreComponent, useExisting: VisGraphComponent }], usesOnChanges: true, ngImport: i0, template: '', isInline: true });
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisGraphComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
36
|
args: [{
|
|
@@ -49,6 +49,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
49
49
|
type: Input
|
|
50
50
|
}], disableZoom: [{
|
|
51
51
|
type: Input
|
|
52
|
+
}], zoomEventFilter: [{
|
|
53
|
+
type: Input
|
|
52
54
|
}], disableDrag: [{
|
|
53
55
|
type: Input
|
|
54
56
|
}], disableBrush: [{
|
|
@@ -165,6 +167,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
165
167
|
type: Input
|
|
166
168
|
}], nodeExitScale: [{
|
|
167
169
|
type: Input
|
|
170
|
+
}], nodeEnterCustomRenderFunction: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], nodeUpdateCustomRenderFunction: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], nodePartialUpdateCustomRenderFunction: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], nodeExitCustomRenderFunction: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], nodeOnZoomCustomRenderFunction: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], nodeSelectionHighlightMode: [{
|
|
181
|
+
type: Input
|
|
168
182
|
}], selectedNodeId: [{
|
|
169
183
|
type: Input
|
|
170
184
|
}], selectedNodeIds: [{
|
|
@@ -179,13 +193,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
179
193
|
type: Input
|
|
180
194
|
}], onZoom: [{
|
|
181
195
|
type: Input
|
|
196
|
+
}], onZoomStart: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], onZoomEnd: [{
|
|
199
|
+
type: Input
|
|
182
200
|
}], onLayoutCalculated: [{
|
|
183
201
|
type: Input
|
|
184
202
|
}], onNodeSelectionBrush: [{
|
|
185
203
|
type: Input
|
|
186
204
|
}], onNodeSelectionDrag: [{
|
|
187
205
|
type: Input
|
|
206
|
+
}], onRenderComplete: [{
|
|
207
|
+
type: Input
|
|
188
208
|
}], data: [{
|
|
189
209
|
type: Input
|
|
190
210
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../src/components/graph/graph.component.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,OAAO,EAAE,SAAS,EAAiB,KAAK,EAAiB,MAAM,eAAe,CAAA;AAC9E,OAAO,EACL,KAAK,GAwBN,MAAM,YAAY,CAAA;AAInB,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;;AAQ7C,MAAM,OAAO,iBAAiB;IAsS5B,eAAe;;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAO,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAElD,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACjC,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;SAClC;IACH,CAAC;IAED,WAAW,CAAE,OAAsB;;QACjC,IAAI,OAAO,CAAC,IAAI,EAAE;YAAE,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;SAAE;QACxD,MAAA,IAAI,CAAC,SAAS,0CAAE,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QAC3C,MAAA,IAAI,CAAC,kBAAkB,0CAAE,MAAM,EAAE,CAAA;IACnC,CAAC;IAEO,SAAS;QACf,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,gCAAgC,EAAE,UAAU,EAAE,aAAa,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,eAAe,EAAE,gBAAgB,EAAE,4BAA4B,EAAE,0BAA0B,EAAE,6BAA6B,EAAE,0BAA0B,EAAE,oCAAoC,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,SAAS,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,aAAa,EAAE,cAAc,EAAE,QAAQ,EAAE,eAAe,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAAE,qBAAqB,EAAE,QAAQ,EAAE,YAAY,EAAE,SAAS,EAAE,aAAa,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,YAAY,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,cAAc,EAAE,cAAc,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,EAAE,cAAc,EAAE,gBAAgB,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,EAAE,eAAe,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAA;QAC/uC,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,gCAAgC,EAAE,UAAU,EAAE,aAAa,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,eAAe,EAAE,gBAAgB,EAAE,4BAA4B,EAAE,0BAA0B,EAAE,6BAA6B,EAAE,0BAA0B,EAAE,oCAAoC,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,SAAS,EAAE,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,SAAS,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,aAAa,EAAE,cAAc,EAAE,QAAQ,EAAE,eAAe,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAAE,qBAAqB,EAAE,QAAQ,EAAE,YAAY,EAAE,SAAS,EAAE,aAAa,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,YAAY,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,cAAc,EAAE,cAAc,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,iBAAiB,EAAE,cAAc,EAAE,gBAAgB,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,EAAE,eAAe,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,CAAA;QACjvC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAyC,CAAA;QACxE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS;YAAE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;QAE1E,OAAO,MAAM,CAAA;IACf,CAAC;;+GA5TU,iBAAiB;mGAAjB,iBAAiB,gpFAFjB,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,iBAAiB,EAAE,CAAC,+CAFhE,EAAE;4FAID,iBAAiB;kBAN7B,SAAS;mBAAC;oBACT,QAAQ,EAAE,WAAW;oBACrB,QAAQ,EAAE,EAAE;oBACZ,gDAAgD;oBAChD,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,mBAAmB,EAAE,CAAC;iBAC3E;8BAGU,QAAQ;sBAAhB,KAAK;gBAmBG,MAAM;sBAAd,KAAK;gBAwBG,UAAU;sBAAlB,KAAK;gBAOG,eAAe;sBAAvB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,gCAAgC;sBAAxC,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAOG,sBAAsB;sBAA9B,KAAK;gBAGG,uBAAuB;sBAA/B,KAAK;gBAKG,eAAe;sBAAvB,KAAK;gBAKG,gBAAgB;sBAAxB,KAAK;gBAMG,4BAA4B;sBAApC,KAAK;gBAKG,0BAA0B;sBAAlC,KAAK;gBAKG,6BAA6B;sBAArC,KAAK;gBAKG,0BAA0B;sBAAlC,KAAK;gBAKG,oCAAoC;sBAA5C,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBAIG,mBAAmB;sBAA3B,KAAK;gBAMG,iBAAiB;sBAAzB,KAAK;gBAKG,mBAAmB;sBAA3B,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,wBAAwB;sBAAhC,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,qBAAqB;sBAA7B,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAGG,sBAAsB;sBAA9B,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,iBAAiB;sBAAzB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,eAAe;sBAAvB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBAGG,oBAAoB;sBAA5B,KAAK;gBAGG,mBAAmB;sBAA3B,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  Graph,\n  GraphConfigInterface,\n  ContainerCore,\n  GraphInputNode,\n  GraphInputLink,\n  VisEventType,\n  VisEventCallback,\n  GraphLayoutType,\n  StringAccessor,\n  GraphForceLayoutSettings,\n  GraphDagreLayoutSetting,\n  GenericAccessor,\n  GraphElkLayoutSettings,\n  NumericAccessor,\n  GraphLinkStyle,\n  GraphLinkArrowStyle,\n  ColorAccessor,\n  BooleanAccessor,\n  GraphCircleLabel,\n  GraphNodeShape,\n  TrimMode,\n  GraphPanelConfig,\n  GraphNode,\n  GraphLink,\n} from '@unovis/ts'\nimport { D3DragEvent } from 'd3-drag'\nimport { D3ZoomEvent } from 'd3-zoom'\nimport { D3BrushEvent } from 'd3-brush'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-graph',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisGraphComponent }],\n})\nexport class VisGraphComponent<N extends GraphInputNode, L extends GraphInputLink> implements GraphConfigInterface<N, L>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** Zoom level constraints. Default: [0.35, 1.25] */\n  @Input() zoomScaleExtent?: [number, number]\n\n  /** Disable zooming. Default: `false` */\n  @Input() disableZoom?: boolean\n\n  /** Disable node dragging. Default: `false` */\n  @Input() disableDrag?: boolean\n\n  /** Disable brush for multiple node selection. Default: `false` */\n  @Input() disableBrush?: boolean\n\n  /** Interval to re-render the graph when zooming. Default: `100` */\n  @Input() zoomThrottledUpdateNodeThreshold?: number\n\n  /** Type of the graph layout. Default: `GraphLayoutType.Force` */\n  @Input() layoutType?: GraphLayoutType | string\n\n  /** Fit the graph to container on data or config updates, or on container resize. Default: `true` */\n  @Input() layoutAutofit?: boolean\n\n  /** Tolerance constant defining whether the graph should be fitted to container\n   * (on data or config update, or container resize) after a zoom / pan interaction or not.\n   * `0` — Stop fitting after any pan or zoom\n   * `Number.POSITIVE_INFINITY` — Always fit\n   * Default: `8.0` */\n  @Input() layoutAutofitTolerance?: number\n\n  /** Place non-connected nodes at the bottom of the graph. Default: `false` */\n  @Input() layoutNonConnectedAside?: boolean\n\n  /** Node group accessor function.\n   * Only for `GraphLayoutType.Parallel`, `GraphLayoutType.ParallelHorizontal` and `GraphLayoutType.Concentric` layouts.\n   * Default: `node => node.group` */\n  @Input() layoutNodeGroup?: StringAccessor<N>\n\n  /** Order of the layout groups.\n   * Only for `GraphLayoutType.Parallel`, `GraphLayoutType.ParallelHorizontal` and `GraphLayoutType.Concentric` layouts.\n   * Default: `[]` */\n  @Input() layoutGroupOrder?: string[]\n\n  /** Sets the number of nodes in a sub-group after which they'll continue on the next column (or row if `layoutType` is\n   * `GraphLayoutType.ParallelHorizontal`).\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `6` */\n  @Input() layoutParallelNodesPerColumn?: number\n\n  /** Node sub-group accessor function.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `node => node.subgroup` */\n  @Input() layoutParallelNodeSubGroup?: StringAccessor<N>\n\n  /** Number of sub-groups per row (or column if `layoutType` is `GraphLayoutType.ParallelHorizontal`) in a group.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `1` */\n  @Input() layoutParallelSubGroupsPerRow?: number\n\n  /** Spacing between groups.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `undefined` */\n  @Input() layoutParallelGroupSpacing?: number\n\n  /** Set a group by name to have priority in sorting the graph links.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `undefined` */\n  @Input() layoutParallelSortConnectionsByGroup?: string\n\n  /** Force Layout settings, see the `d3-force` package for more details */\n  @Input() forceLayoutSettings?: GraphForceLayoutSettings<N, L>\n\n  /** Darge Layout settings, see the `dagrejs` package\n   * for more details: https://github.com/dagrejs/dagre/wiki#configuring-the-layout */\n  @Input() dagreLayoutSettings?: GraphDagreLayoutSetting\n\n  /** ELK layout options, see the `elkjs` package for more details: https://github.com/kieler/elkjs.\n   * If you want to specify custom layout option for each node group, you can provide an accessor function that\n   * receives group name ('root' for the top-level configuration) as the first argument and returns an object containing\n   * layout options. Default: `undefined` */\n  @Input() layoutElkSettings?: GenericAccessor<GraphElkLayoutSettings, string> | undefined\n\n  /** Array of accessor functions to define nested node groups for the ELK Layered layout.\n   * E.g.: `[n => n.group, n => n.subGroup]`.\n   * Default: `undefined` */\n  @Input() layoutElkNodeGroups?: StringAccessor<N>[]\n\n  /** Link width accessor function ot constant value. Default: `1` */\n  @Input() linkWidth?: NumericAccessor<L>\n\n  /** Link style accessor function or constant value. Default: `GraphLinkStyle.Solid` */\n  @Input() linkStyle?: GenericAccessor<GraphLinkStyle, L>\n\n  /** Link band width accessor function or constant value. Default: `0` */\n  @Input() linkBandWidth?: NumericAccessor<L>\n\n  /** Link arrow accessor function or constant value. Default: `undefined` */\n  @Input() linkArrow?: GenericAccessor<GraphLinkArrowStyle | string | boolean, L> | undefined\n\n  /** Link stroke color accessor function or constant value. Default: `undefined` */\n  @Input() linkStroke?: ColorAccessor<L>\n\n  /** Link disabled state accessor function or constant value. Default: `false` */\n  @Input() linkDisabled?: BooleanAccessor<L>\n\n  /** Link flow animation accessor function or constant value. Default: `false` */\n  @Input() linkFlow?: BooleanAccessor<L>\n\n  /** Animation duration of the flow (traffic) circles. Default: `20000` */\n  @Input() linkFlowAnimDuration?: number\n\n  /** Size of the moving particles that represent traffic flow. Default: `2` */\n  @Input() linkFlowParticleSize?: number\n\n  /** Link label accessor function or constant value. Default: `undefined` */\n  @Input() linkLabel?: GenericAccessor<GraphCircleLabel, L> | undefined\n\n  /** Shift label along the link center a little bit to avoid overlap with the link arrow. Default: `true` */\n  @Input() linkLabelShiftFromCenter?: BooleanAccessor<L>\n\n  /** Spacing between neighboring links. Default: `8` */\n  @Input() linkNeighborSpacing?: number\n\n  /** Curvature of the link. Recommended value range: [0:1.5].\n   * `0` - straight line,\n   * `1` - nice curvature,\n   * `1.5` - very curve.\n   * Default: `0` */\n  @Input() linkCurvature?: NumericAccessor<L>\n\n  /** Set selected link by its unique id. Default: `undefined` */\n  @Input() selectedLinkId?: number | string\n\n  /** Node size accessor function or constant value. Default: `30` */\n  @Input() nodeSize?: NumericAccessor<N>\n\n  /** Node stroke width accessor function or constant value. Default: `3` */\n  @Input() nodeStrokeWidth?: NumericAccessor<N>\n\n  /** Node shape accessor function or constant value. Default: `GraphNodeShape.Circle` */\n  @Input() nodeShape?: GenericAccessor<GraphNodeShape | string, N>\n\n  /** Node gauge outline accessor function or constant value in the range [0,100]. Default: `0` */\n  @Input() nodeGaugeValue?: NumericAccessor<N>\n\n  /** Node gauge outline fill color accessor function or constant value. Default: `undefined` */\n  @Input() nodeGaugeFill?: ColorAccessor<N>\n\n  /** Animation duration of the node gauge outline. Default: `1500` */\n  @Input() nodeGaugeAnimDuration?: number\n\n  /** Node central icon accessor function or constant value. Default: `node => node.icon` */\n  @Input() nodeIcon?: StringAccessor<N>\n\n  /** Node central icon size accessor function or constant value. Default: `undefined` */\n  @Input() nodeIconSize?: NumericAccessor<N>\n\n  /** Node label accessor function or constant value. Default: `node => node.label` */\n  @Input() nodeLabel?: StringAccessor<N>\n\n  /** Defines whether to trim the node labels or not. Default: `true` */\n  @Input() nodeLabelTrim?: BooleanAccessor<N>\n\n  /** Node label trimming mode. Default: `TrimMode.Middle` */\n  @Input() nodeLabelTrimMode?: GenericAccessor<TrimMode | string, N>\n\n  /** Node label maximum allowed text length above which the label will be trimmed. Default: `15` */\n  @Input() nodeLabelTrimLength?: NumericAccessor<N>\n\n  /** Node sub-label accessor function or constant value: Default: `''` */\n  @Input() nodeSubLabel?: StringAccessor<N>\n\n  /** Defines whether to trim the node sub-labels or not. Default: `true` */\n  @Input() nodeSubLabelTrim?: BooleanAccessor<N>\n\n  /** Node sub-label trimming mode. Default: `TrimMode.Middle` */\n  @Input() nodeSubLabelTrimMode?: GenericAccessor<TrimMode | string, N>\n\n  /** Node sub-label maximum allowed text length above which the label will be trimmed. Default: `15` */\n  @Input() nodeSubLabelTrimLength?: NumericAccessor<N>\n\n  /** Node circular side labels accessor function. The function should return an array of GraphCircleLabel objects. Default: `undefined` */\n  @Input() nodeSideLabels?: GenericAccessor<GraphCircleLabel[], N>\n\n  /** Node bottom icon accessor function. Default: `undefined` */\n  @Input() nodeBottomIcon?: StringAccessor<N>\n\n  /** Node disabled state accessor function or constant value. Default: `false` */\n  @Input() nodeDisabled?: BooleanAccessor<N>\n\n  /** Node fill color accessor function or constant value. Default: `node => node.fill` */\n  @Input() nodeFill?: ColorAccessor<N>\n\n  /** Node stroke color accessor function or constant value. Default: `node => node.stroke` */\n  @Input() nodeStroke?: ColorAccessor<N>\n\n  /** Sorting function to determine node placement. Default: `undefined` */\n  @Input() nodeSort?: ((a: N, b: N) => number)\n\n  /** Specify the initial position for entering nodes as [x, y]. Default: `undefined` */\n  @Input() nodeEnterPosition?: GenericAccessor<[number, number], N> | undefined\n\n  /** Specify the initial scale for entering nodes in the range [0,1]. Default: `0.75` */\n  @Input() nodeEnterScale?: NumericAccessor<N> | undefined\n\n  /** Specify the destination position for exiting nodes as [x, y]. Default: `undefined` */\n  @Input() nodeExitPosition?: GenericAccessor<[number, number], N> | undefined\n\n  /** Specify the destination scale for exiting nodes in the range [0,1]. Default: `0.75` */\n  @Input() nodeExitScale?: NumericAccessor<N> | undefined\n\n  /** Set selected node by unique id. Default: `undefined` */\n  @Input() selectedNodeId?: number | string\n\n  /** Set selected nodes by unique id. Default: `undefined` */\n  @Input() selectedNodeIds?: number[] | string[]\n\n  /** Panels configuration. An array of `GraphPanelConfig` objects. Default: `[]` */\n  @Input() panels?: GraphPanelConfig[] | undefined\n\n  /** Graph node drag start callback function. Default: `undefined` */\n  @Input() onNodeDragStart?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Graph node drag callback function. Default: `undefined` */\n  @Input() onNodeDrag?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Graph node drag end callback function. Default: `undefined` */\n  @Input() onNodeDragEnd?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Zoom event callback. Default: `undefined` */\n  @Input() onZoom?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined) => void\n\n  /** Callback function to be called when the graph layout is calculated. Default: `undefined` */\n  @Input() onLayoutCalculated?: (n: GraphNode<N, L>[], links: GraphLink<N, L>[]) => void\n\n  /** Graph node selection brush callback function. Default: `undefined` */\n  @Input() onNodeSelectionBrush?: (selectedNodes: GraphNode<N, L>[], event: D3BrushEvent<SVGGElement> | undefined) => void\n\n  /** Graph multiple node drag callback function. Default: `undefined` */\n  @Input() onNodeSelectionDrag?: (selectedNodes: GraphNode<N, L>[], event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void\n  @Input() data: { nodes: N[]; links?: L[] }\n\n  component: Graph<N, L> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Graph<N, L>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): GraphConfigInterface<N, L> {\n    const { duration, events, attributes, zoomScaleExtent, disableZoom, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag } = this\n    const config = { duration, events, attributes, zoomScaleExtent, disableZoom, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag }\n    const keys = Object.keys(config) as (keyof GraphConfigInterface<N, L>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../src/components/graph/graph.component.ts"],"names":[],"mappings":"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","sourcesContent":["// !!! This code was automatically generated. You should not change it !!!\nimport { Component, AfterViewInit, Input, SimpleChanges } from '@angular/core'\nimport {\n  Graph,\n  GraphConfigInterface,\n  ContainerCore,\n  GraphInputNode,\n  GraphInputLink,\n  VisEventType,\n  VisEventCallback,\n  GraphLayoutType,\n  StringAccessor,\n  GraphForceLayoutSettings,\n  GraphDagreLayoutSetting,\n  GenericAccessor,\n  GraphElkLayoutSettings,\n  NumericAccessor,\n  GraphLinkStyle,\n  GraphLinkArrowStyle,\n  ColorAccessor,\n  BooleanAccessor,\n  GraphCircleLabel,\n  GraphNodeShape,\n  TrimMode,\n  GraphNode,\n  GraphNodeSelectionHighlightMode,\n  GraphPanelConfig,\n  GraphLink,\n} from '@unovis/ts'\nimport { Selection } from 'd3-selection'\nimport { D3DragEvent } from 'd3-drag'\nimport { D3ZoomEvent, ZoomTransform } from 'd3-zoom'\nimport { D3BrushEvent } from 'd3-brush'\nimport { VisCoreComponent } from '../../core'\n\n@Component({\n  selector: 'vis-graph',\n  template: '',\n  // eslint-disable-next-line no-use-before-define\n  providers: [{ provide: VisCoreComponent, useExisting: VisGraphComponent }],\n})\nexport class VisGraphComponent<N extends GraphInputNode, L extends GraphInputLink> implements GraphConfigInterface<N, L>, AfterViewInit {\n  /** Animation duration of the data update transitions in milliseconds. Default: `600` */\n  @Input() duration?: number\n\n  /** Events configuration. An object containing properties in the following format:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[eventType]: callbackFunction\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    click: (d) => console.log(\"Clicked Area\", d)\n   *  }\n   * }\n   * ``` */\n  @Input() events?: {\n    [selector: string]: {\n      [eventType in VisEventType]?: VisEventCallback\n    };\n  }\n\n  /** You can set every SVG and HTML visualization object to have a custom DOM attributes, which is useful\n   * when you want to do unit or end-to-end testing. Attributes configuration object has the following structure:\n   *\n   * ```\n   * {\n   * \\[selectorString]: {\n   *     \\[attributeName]: attribute constant value or accessor function\n   *  }\n   * }\n   * ```\n   * e.g.:\n   * ```\n   * {\n   * \\[Area.selectors.area]: {\n   *    \"test-value\": d => d.value\n   *  }\n   * }\n   * ``` */\n  @Input() attributes?: {\n    [selector: string]: {\n      [attr: string]: string | number | boolean | ((datum: any) => string | number | boolean);\n    };\n  }\n\n  /** Zoom level constraints. Default: [0.35, 1.25] */\n  @Input() zoomScaleExtent?: [number, number]\n\n  /** Disable zooming. Default: `false` */\n  @Input() disableZoom?: boolean\n\n  /** Custom Zoom event filter to better control which actions should trigger zooming.\n   * Learn more: https://d3js.org/d3-zoom#zoom_filter.\n   * Default: `undefined` */\n  @Input() zoomEventFilter?: (event: PointerEvent) => boolean\n\n  /** Disable node dragging. Default: `false` */\n  @Input() disableDrag?: boolean\n\n  /** Disable brush for multiple node selection. Default: `false` */\n  @Input() disableBrush?: boolean\n\n  /** Interval to re-render the graph when zooming. Default: `100` */\n  @Input() zoomThrottledUpdateNodeThreshold?: number\n\n  /** Type of the graph layout. Default: `GraphLayoutType.Force` */\n  @Input() layoutType?: GraphLayoutType | string\n\n  /** Fit the graph to container on data or config updates, or on container resize. Default: `true` */\n  @Input() layoutAutofit?: boolean\n\n  /** Tolerance constant defining whether the graph should be fitted to container\n   * (on data or config update, or container resize) after a zoom / pan interaction or not.\n   * `0` — Stop fitting after any pan or zoom\n   * `Number.POSITIVE_INFINITY` — Always fit\n   * Default: `8.0` */\n  @Input() layoutAutofitTolerance?: number\n\n  /** Place non-connected nodes at the bottom of the graph. Default: `false` */\n  @Input() layoutNonConnectedAside?: boolean\n\n  /** Node group accessor function.\n   * Only for `GraphLayoutType.Parallel`, `GraphLayoutType.ParallelHorizontal` and `GraphLayoutType.Concentric` layouts.\n   * Default: `node => node.group` */\n  @Input() layoutNodeGroup?: StringAccessor<N>\n\n  /** Order of the layout groups.\n   * Only for `GraphLayoutType.Parallel`, `GraphLayoutType.ParallelHorizontal` and `GraphLayoutType.Concentric` layouts.\n   * Default: `[]` */\n  @Input() layoutGroupOrder?: string[]\n\n  /** Sets the number of nodes in a sub-group after which they'll continue on the next column (or row if `layoutType` is\n   * `GraphLayoutType.ParallelHorizontal`).\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `6` */\n  @Input() layoutParallelNodesPerColumn?: number\n\n  /** Node sub-group accessor function.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `node => node.subgroup` */\n  @Input() layoutParallelNodeSubGroup?: StringAccessor<N>\n\n  /** Number of sub-groups per row (or column if `layoutType` is `GraphLayoutType.ParallelHorizontal`) in a group.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `1` */\n  @Input() layoutParallelSubGroupsPerRow?: number\n\n  /** Spacing between groups.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `undefined` */\n  @Input() layoutParallelGroupSpacing?: number\n\n  /** Set a group by name to have priority in sorting the graph links.\n   * Only for `GraphLayoutType.Parallel` and `GraphLayoutType.ParallelHorizontal` layouts.\n   * Default: `undefined` */\n  @Input() layoutParallelSortConnectionsByGroup?: string\n\n  /** Force Layout settings, see the `d3-force` package for more details */\n  @Input() forceLayoutSettings?: GraphForceLayoutSettings<N, L>\n\n  /** Darge Layout settings, see the `dagrejs` package\n   * for more details: https://github.com/dagrejs/dagre/wiki#configuring-the-layout */\n  @Input() dagreLayoutSettings?: GraphDagreLayoutSetting\n\n  /** ELK layout options, see the `elkjs` package for more details: https://github.com/kieler/elkjs.\n   * If you want to specify custom layout option for each node group, you can provide an accessor function that\n   * receives group name ('root' for the top-level configuration) as the first argument and returns an object containing\n   * layout options. Default: `undefined` */\n  @Input() layoutElkSettings?: GenericAccessor<GraphElkLayoutSettings, string> | undefined\n\n  /** Array of accessor functions to define nested node groups for the ELK Layered layout.\n   * E.g.: `[n => n.group, n => n.subGroup]`.\n   * Default: `undefined` */\n  @Input() layoutElkNodeGroups?: StringAccessor<N>[]\n\n  /** Link width accessor function ot constant value. Default: `1` */\n  @Input() linkWidth?: NumericAccessor<L>\n\n  /** Link style accessor function or constant value. Default: `GraphLinkStyle.Solid` */\n  @Input() linkStyle?: GenericAccessor<GraphLinkStyle, L>\n\n  /** Link band width accessor function or constant value. Default: `0` */\n  @Input() linkBandWidth?: NumericAccessor<L>\n\n  /** Link arrow accessor function or constant value. Default: `undefined` */\n  @Input() linkArrow?: GenericAccessor<GraphLinkArrowStyle | string | boolean, L> | undefined\n\n  /** Link stroke color accessor function or constant value. Default: `undefined` */\n  @Input() linkStroke?: ColorAccessor<L>\n\n  /** Link disabled state accessor function or constant value. Default: `false` */\n  @Input() linkDisabled?: BooleanAccessor<L>\n\n  /** Link flow animation accessor function or constant value. Default: `false` */\n  @Input() linkFlow?: BooleanAccessor<L>\n\n  /** Animation duration of the flow (traffic) circles. Default: `20000` */\n  @Input() linkFlowAnimDuration?: number\n\n  /** Size of the moving particles that represent traffic flow. Default: `2` */\n  @Input() linkFlowParticleSize?: number\n\n  /** Link label accessor function or constant value. Default: `undefined` */\n  @Input() linkLabel?: GenericAccessor<GraphCircleLabel, L> | undefined\n\n  /** Shift label along the link center a little bit to avoid overlap with the link arrow. Default: `true` */\n  @Input() linkLabelShiftFromCenter?: BooleanAccessor<L>\n\n  /** Spacing between neighboring links. Default: `8` */\n  @Input() linkNeighborSpacing?: number\n\n  /** Curvature of the link. Recommended value range: [0:1.5].\n   * `0` - straight line,\n   * `1` - nice curvature,\n   * `1.5` - very curve.\n   * Default: `0` */\n  @Input() linkCurvature?: NumericAccessor<L>\n\n  /** Set selected link by its unique id. Default: `undefined` */\n  @Input() selectedLinkId?: number | string\n\n  /** Node size accessor function or constant value. Default: `30` */\n  @Input() nodeSize?: NumericAccessor<N>\n\n  /** Node stroke width accessor function or constant value. Default: `3` */\n  @Input() nodeStrokeWidth?: NumericAccessor<N>\n\n  /** Node shape accessor function or constant value. Default: `GraphNodeShape.Circle` */\n  @Input() nodeShape?: GenericAccessor<GraphNodeShape | string, N>\n\n  /** Node gauge outline accessor function or constant value in the range [0,100]. Default: `0` */\n  @Input() nodeGaugeValue?: NumericAccessor<N>\n\n  /** Node gauge outline fill color accessor function or constant value. Default: `undefined` */\n  @Input() nodeGaugeFill?: ColorAccessor<N>\n\n  /** Animation duration of the node gauge outline. Default: `1500` */\n  @Input() nodeGaugeAnimDuration?: number\n\n  /** Node central icon accessor function or constant value. Default: `node => node.icon` */\n  @Input() nodeIcon?: StringAccessor<N>\n\n  /** Node central icon size accessor function or constant value. Default: `undefined` */\n  @Input() nodeIconSize?: NumericAccessor<N>\n\n  /** Node label accessor function or constant value. Default: `node => node.label` */\n  @Input() nodeLabel?: StringAccessor<N>\n\n  /** Defines whether to trim the node labels or not. Default: `true` */\n  @Input() nodeLabelTrim?: BooleanAccessor<N>\n\n  /** Node label trimming mode. Default: `TrimMode.Middle` */\n  @Input() nodeLabelTrimMode?: GenericAccessor<TrimMode | string, N>\n\n  /** Node label maximum allowed text length above which the label will be trimmed. Default: `15` */\n  @Input() nodeLabelTrimLength?: NumericAccessor<N>\n\n  /** Node sub-label accessor function or constant value: Default: `''` */\n  @Input() nodeSubLabel?: StringAccessor<N>\n\n  /** Defines whether to trim the node sub-labels or not. Default: `true` */\n  @Input() nodeSubLabelTrim?: BooleanAccessor<N>\n\n  /** Node sub-label trimming mode. Default: `TrimMode.Middle` */\n  @Input() nodeSubLabelTrimMode?: GenericAccessor<TrimMode | string, N>\n\n  /** Node sub-label maximum allowed text length above which the label will be trimmed. Default: `15` */\n  @Input() nodeSubLabelTrimLength?: NumericAccessor<N>\n\n  /** Node circular side labels accessor function. The function should return an array of GraphCircleLabel objects. Default: `undefined` */\n  @Input() nodeSideLabels?: GenericAccessor<GraphCircleLabel[], N>\n\n  /** Node bottom icon accessor function. Default: `undefined` */\n  @Input() nodeBottomIcon?: StringAccessor<N>\n\n  /** Node disabled state accessor function or constant value. Default: `false` */\n  @Input() nodeDisabled?: BooleanAccessor<N>\n\n  /** Node fill color accessor function or constant value. Default: `node => node.fill` */\n  @Input() nodeFill?: ColorAccessor<N>\n\n  /** Node stroke color accessor function or constant value. Default: `node => node.stroke` */\n  @Input() nodeStroke?: ColorAccessor<N>\n\n  /** Sorting function to determine node placement. Default: `undefined` */\n  @Input() nodeSort?: ((a: N, b: N) => number)\n\n  /** Specify the initial position for entering nodes as [x, y]. Default: `undefined` */\n  @Input() nodeEnterPosition?: GenericAccessor<[number, number], N> | undefined\n\n  /** Specify the initial scale for entering nodes in the range [0,1]. Default: `0.75` */\n  @Input() nodeEnterScale?: NumericAccessor<N> | undefined\n\n  /** Specify the destination position for exiting nodes as [x, y]. Default: `undefined` */\n  @Input() nodeExitPosition?: GenericAccessor<[number, number], N> | undefined\n\n  /** Specify the destination scale for exiting nodes in the range [0,1]. Default: `0.75` */\n  @Input() nodeExitScale?: NumericAccessor<N> | undefined\n\n  /** Custom \"enter\" function for node rendering. Default: `undefined` */\n  @Input() nodeEnterCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void\n\n  /** Custom \"update\" function for node rendering. Default: `undefined` */\n  @Input() nodeUpdateCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void\n\n  /** Custom partial \"update\" function for node rendering which will be triggered after the following events:\n   * - Full node update (`nodeUpdateCustomRenderFunction`);\n   * - Background click;\n   * - Node and Link mouseover and mouseout;\n   * - Node brushing,\n   * Default: `undefined` */\n  @Input() nodePartialUpdateCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void\n\n  /** Custom \"exit\" function for node rendering. Default: `undefined` */\n  @Input() nodeExitCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number) => void\n\n  /** Custom render function that will be called while zooming / panning the graph. Default: `undefined` */\n  @Input() nodeOnZoomCustomRenderFunction?: (datum: GraphNode<N, L>, nodeGroupElementSelection: Selection<SVGGElement, GraphNode<N, L>, null, unknown>, config: GraphConfigInterface<N, L>, zoomLevel: number) => void\n\n  /** Define the mode for highlighting selected nodes in the graph. Default: `GraphNodeSelectionHighlightMode.GreyoutNonConnected` */\n  @Input() nodeSelectionHighlightMode?: GraphNodeSelectionHighlightMode\n\n  /** Set selected node by unique id. Default: `undefined` */\n  @Input() selectedNodeId?: number | string\n\n  /** Set selected nodes by unique id. Default: `undefined` */\n  @Input() selectedNodeIds?: number[] | string[]\n\n  /** Panels configuration. An array of `GraphPanelConfig` objects. Default: `[]` */\n  @Input() panels?: GraphPanelConfig[] | undefined\n\n  /** Graph node drag start callback function. Default: `undefined` */\n  @Input() onNodeDragStart?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Graph node drag callback function. Default: `undefined` */\n  @Input() onNodeDrag?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Graph node drag end callback function. Default: `undefined` */\n  @Input() onNodeDragEnd?: (n: GraphNode<N, L>, event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void | undefined\n\n  /** Zoom event callback. Default: `undefined` */\n  @Input() onZoom?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void\n\n  /** Zoom start event callback. Default: `undefined` */\n  @Input() onZoomStart?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void\n\n  /** Zoom end event callback. Default: `undefined` */\n  @Input() onZoomEnd?: (zoomScale: number, zoomScaleExtent: [number, number], event: D3ZoomEvent<SVGGElement, unknown> | undefined, transform: ZoomTransform) => void\n\n  /** Callback function to be called when the graph layout is calculated. Default: `undefined` */\n  @Input() onLayoutCalculated?: (n: GraphNode<N, L>[], links: GraphLink<N, L>[]) => void\n\n  /** Graph node selection brush callback function. Default: `undefined` */\n  @Input() onNodeSelectionBrush?: (selectedNodes: GraphNode<N, L>[], event: D3BrushEvent<SVGGElement> | undefined) => void\n\n  /** Graph multiple node drag callback function. Default: `undefined` */\n  @Input() onNodeSelectionDrag?: (selectedNodes: GraphNode<N, L>[], event: D3DragEvent<SVGGElement, GraphNode<N, L>, unknown>) => void\n\n  /** Callback function to be called when the graph rendering is complete. Default: `undefined` */\n  @Input() onRenderComplete?: (g: Selection<SVGGElement, unknown, null, undefined>, nodes: GraphNode<N, L>[], links: GraphLink<N, L>[], config: GraphConfigInterface<N, L>, duration: number, zoomLevel: number, width: number, height: number) => void\n  @Input() data: { nodes: N[]; links?: L[] }\n\n  component: Graph<N, L> | undefined\n  public componentContainer: ContainerCore | undefined\n\n  ngAfterViewInit (): void {\n    this.component = new Graph<N, L>(this.getConfig())\n\n    if (this.data) {\n      this.component.setData(this.data)\n      this.componentContainer?.render()\n    }\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    if (changes.data) { this.component?.setData(this.data) }\n    this.component?.setConfig(this.getConfig())\n    this.componentContainer?.render()\n  }\n\n  private getConfig (): GraphConfigInterface<N, L> {\n    const { duration, events, attributes, zoomScaleExtent, disableZoom, zoomEventFilter, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, nodeEnterCustomRenderFunction, nodeUpdateCustomRenderFunction, nodePartialUpdateCustomRenderFunction, nodeExitCustomRenderFunction, nodeOnZoomCustomRenderFunction, nodeSelectionHighlightMode, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onZoomStart, onZoomEnd, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag, onRenderComplete } = this\n    const config = { duration, events, attributes, zoomScaleExtent, disableZoom, zoomEventFilter, disableDrag, disableBrush, zoomThrottledUpdateNodeThreshold, layoutType, layoutAutofit, layoutAutofitTolerance, layoutNonConnectedAside, layoutNodeGroup, layoutGroupOrder, layoutParallelNodesPerColumn, layoutParallelNodeSubGroup, layoutParallelSubGroupsPerRow, layoutParallelGroupSpacing, layoutParallelSortConnectionsByGroup, forceLayoutSettings, dagreLayoutSettings, layoutElkSettings, layoutElkNodeGroups, linkWidth, linkStyle, linkBandWidth, linkArrow, linkStroke, linkDisabled, linkFlow, linkFlowAnimDuration, linkFlowParticleSize, linkLabel, linkLabelShiftFromCenter, linkNeighborSpacing, linkCurvature, selectedLinkId, nodeSize, nodeStrokeWidth, nodeShape, nodeGaugeValue, nodeGaugeFill, nodeGaugeAnimDuration, nodeIcon, nodeIconSize, nodeLabel, nodeLabelTrim, nodeLabelTrimMode, nodeLabelTrimLength, nodeSubLabel, nodeSubLabelTrim, nodeSubLabelTrimMode, nodeSubLabelTrimLength, nodeSideLabels, nodeBottomIcon, nodeDisabled, nodeFill, nodeStroke, nodeSort, nodeEnterPosition, nodeEnterScale, nodeExitPosition, nodeExitScale, nodeEnterCustomRenderFunction, nodeUpdateCustomRenderFunction, nodePartialUpdateCustomRenderFunction, nodeExitCustomRenderFunction, nodeOnZoomCustomRenderFunction, nodeSelectionHighlightMode, selectedNodeId, selectedNodeIds, panels, onNodeDragStart, onNodeDrag, onNodeDragEnd, onZoom, onZoomStart, onZoomEnd, onLayoutCalculated, onNodeSelectionBrush, onNodeSelectionDrag, onRenderComplete }\n    const keys = Object.keys(config) as (keyof GraphConfigInterface<N, L>)[]\n    keys.forEach(key => { if (config[key] === undefined) delete config[key] })\n\n    return config\n  }\n}\n"]}
|
|
@@ -27,18 +27,18 @@ export class VisSingleContainerComponent {
|
|
|
27
27
|
}
|
|
28
28
|
getConfig() {
|
|
29
29
|
var _a, _b, _c;
|
|
30
|
-
const { width, height, duration, margin, ariaLabel } = this;
|
|
30
|
+
const { width, height, duration, margin, ariaLabel, svgDefs, sizing } = this;
|
|
31
31
|
const component = (_a = this.visComponent) === null || _a === void 0 ? void 0 : _a.component;
|
|
32
32
|
const tooltip = (_b = this.tooltipComponent) === null || _b === void 0 ? void 0 : _b.component;
|
|
33
33
|
const annotations = (_c = this.annotationsComponent) === null || _c === void 0 ? void 0 : _c.component;
|
|
34
|
-
return { width, height, duration, margin, component, tooltip, ariaLabel, annotations };
|
|
34
|
+
return { width, height, duration, margin, component, tooltip, ariaLabel, annotations, svgDefs, sizing };
|
|
35
35
|
}
|
|
36
36
|
ngOnDestroy() {
|
|
37
37
|
this.chart.destroy();
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
40
|
VisSingleContainerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
41
|
-
VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
|
|
41
|
+
VisSingleContainerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: VisSingleContainerComponent, selector: "vis-single-container", inputs: { width: "width", height: "height", margin: "margin", duration: "duration", ariaLabel: "ariaLabel", svgDefs: "svgDefs", sizing: "sizing", data: "data" }, queries: [{ propertyName: "visComponent", first: true, predicate: VisCoreComponent, descendants: true }, { propertyName: "tooltipComponent", first: true, predicate: VisTooltipComponent, descendants: true }, { propertyName: "annotationsComponent", first: true, predicate: VisAnnotationsComponent, descendants: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<div #container class="unovis-single-container">
|
|
42
42
|
<ng-content></ng-content>
|
|
43
43
|
</div>`, isInline: true, styles: [".unovis-single-container { width: 100%; height: 100%; position: relative; }"] });
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: VisSingleContainerComponent, decorators: [{
|
|
@@ -72,7 +72,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
72
72
|
type: Input
|
|
73
73
|
}], ariaLabel: [{
|
|
74
74
|
type: Input
|
|
75
|
+
}], svgDefs: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], sizing: [{
|
|
78
|
+
type: Input
|
|
75
79
|
}], data: [{
|
|
76
80
|
type: Input
|
|
77
81
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLWNvbnRhaW5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29udGFpbmVycy9zaW5nbGUtY29udGFpbmVyL3NpbmdsZS1jb250YWluZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUE2QixLQUFLLEVBQTRCLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU5SCxNQUFNO0FBQ04sT0FBTyxFQUFpQixlQUFlLEVBQXlFLE1BQU0sWUFBWSxDQUFBO0FBQ2xJLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLFlBQVksQ0FBQTtBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQTtBQUNoRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxvREFBb0QsQ0FBQTs7QUFTNUYsTUFBTSxPQUFPLDJCQUEyQjtJQVB4QztRQTBCRSxtRUFBbUU7UUFDMUQsV0FBTSxHQUFhLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFBO0tBK0NyRTtJQTlCQyxlQUFlO1FBQ2IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLGVBQWUsQ0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3BHLHVGQUF1RjtRQUN2RixJQUFJLENBQUMsWUFBWSxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUE7SUFDbkQsQ0FBQztJQUVELFdBQVcsQ0FBRSxPQUFzQjs7UUFDakMsaUNBQWlDO1FBQ2pDLElBQUksT0FBTyxDQUFDLElBQUksRUFBRTtZQUNoQixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFBO1lBQ3BDLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQTtTQUNwQjtRQUVELDhCQUE4QjtRQUM5QixNQUFBLElBQUksQ0FBQyxLQUFLLDBDQUFFLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQTtJQUMvQyxDQUFDO0lBRUQsU0FBUzs7UUFDUCxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFBO1FBRTVFLE1BQU0sU0FBUyxHQUFHLE1BQUEsSUFBSSxDQUFDLFlBQVksMENBQUUsU0FBYyxDQUFBO1FBQ25ELE1BQU0sT0FBTyxHQUFHLE1BQUEsSUFBSSxDQUFDLGdCQUFnQiwwQ0FBRSxTQUFvQixDQUFBO1FBQzNELE1BQU0sV0FBVyxHQUFHLE1BQUEsSUFBSSxDQUFDLG9CQUFvQiwwQ0FBRSxTQUF3QixDQUFBO1FBRXZFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsQ0FBQTtJQUN6RyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUE7SUFDdEIsQ0FBQzs7eUhBbEVVLDJCQUEyQjs2R0FBM0IsMkJBQTJCLHdRQUV4QixnQkFBZ0IsbUZBQ2hCLG1CQUFtQix1RkFDbkIsdUJBQXVCLGdMQVQzQjs7U0FFSDs0RkFHSSwyQkFBMkI7a0JBUHZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtvQkFDaEMsUUFBUSxFQUFFOztTQUVIO29CQUNQLE1BQU0sRUFBRSxDQUFDLDZFQUE2RSxDQUFDO2lCQUN4Rjs4QkFFNEMsWUFBWTtzQkFBdEQsU0FBUzt1QkFBQyxXQUFXLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO2dCQUNULFlBQVk7c0JBQTNDLFlBQVk7dUJBQUMsZ0JBQWdCO2dCQUNLLGdCQUFnQjtzQkFBbEQsWUFBWTt1QkFBQyxtQkFBbUI7Z0JBQ00sb0JBQW9CO3NCQUExRCxZQUFZO3VCQUFDLHVCQUF1QjtnQkFPNUIsS0FBSztzQkFBYixLQUFLO2dCQU1HLE1BQU07c0JBQWQsS0FBSztnQkFHRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUcsUUFBUTtzQkFBaEIsS0FBSztnQkFJRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFHRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUcsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYsIEFmdGVyVmlld0luaXQsIElucHV0LCBPbkRlc3Ryb3ksIFNpbXBsZUNoYW5nZXMsIENvbnRlbnRDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbi8vIFZpc1xuaW1wb3J0IHsgQ29tcG9uZW50Q29yZSwgU2luZ2xlQ29udGFpbmVyLCBTaW5nbGVDb250YWluZXJDb25maWdJbnRlcmZhY2UsIFRvb2x0aXAsIFNwYWNpbmcsIEFubm90YXRpb25zLCBTaXppbmcgfSBmcm9tICdAdW5vdmlzL3RzJ1xuaW1wb3J0IHsgVmlzQ29yZUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvcmUnXG5pbXBvcnQgeyBWaXNUb29sdGlwQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy90b29sdGlwL3Rvb2x0aXAuY29tcG9uZW50J1xuaW1wb3J0IHsgVmlzQW5ub3RhdGlvbnNDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL2Fubm90YXRpb25zL2Fubm90YXRpb25zLmNvbXBvbmVudCdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmlzLXNpbmdsZS1jb250YWluZXInLFxuICB0ZW1wbGF0ZTogYDxkaXYgI2NvbnRhaW5lciBjbGFzcz1cInVub3Zpcy1zaW5nbGUtY29udGFpbmVyXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5gLFxuICBzdHlsZXM6IFsnLnVub3Zpcy1zaW5nbGUtY29udGFpbmVyIHsgd2lkdGg6IDEwMCU7IGhlaWdodDogMTAwJTsgcG9zaXRpb246IHJlbGF0aXZlOyB9J10sXG59KVxuZXhwb3J0IGNsYXNzIFZpc1NpbmdsZUNvbnRhaW5lckNvbXBvbmVudDxEYXRhID0gdW5rbm93biwgQyBleHRlbmRzIENvbXBvbmVudENvcmU8RGF0YT4gPSBDb21wb25lbnRDb3JlPERhdGE+PiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gIEBWaWV3Q2hpbGQoJ2NvbnRhaW5lcicsIHsgc3RhdGljOiBmYWxzZSB9KSBjb250YWluZXJSZWY6IEVsZW1lbnRSZWZcbiAgQENvbnRlbnRDaGlsZChWaXNDb3JlQ29tcG9uZW50KSB2aXNDb21wb25lbnQ6IFZpc0NvcmVDb21wb25lbnRcbiAgQENvbnRlbnRDaGlsZChWaXNUb29sdGlwQ29tcG9uZW50KSB0b29sdGlwQ29tcG9uZW50OiBWaXNUb29sdGlwQ29tcG9uZW50XG4gIEBDb250ZW50Q2hpbGQoVmlzQW5ub3RhdGlvbnNDb21wb25lbnQpIGFubm90YXRpb25zQ29tcG9uZW50OiBWaXNBbm5vdGF0aW9uc0NvbXBvbmVudFxuXG4gIC8qKiBXaWR0aCBpbiBwaXhlbHMgb3IgaW4gQ1NTIHVuaXRzLlxuICAgKiBQZXJjZW50YWdlIHVuaXRzIGBcIiVcImAgYXJlIG5vdCBzdXBwb3J0ZWQgaGVyZS4gSWYgeW91IHdhbnQgdG8gc2V0IGB3aWR0aGAgYXMgYSBwZXJjZW50YWdlLCBkbyBpdCB2aWEgYHN0eWxlYCBvciBgY2xhc3NgXG4gICAqIG9mIHRoZSBjb3JyZXNwb25kaW5nIERPTSBlbGVtZW50LlxuICAgKiBEZWZhdWx0OiBgdW5kZWZpbmVkYFxuICAqL1xuICBASW5wdXQoKSB3aWR0aD86IG51bWJlclxuICAvKiogSGVpZ2h0IGluIHBpeGVscyBvciBpbiBDU1MgdW5pdHMuXG4gICAqIFBlcmNlbnRhZ2UgdW5pdHMgYFwiJVwiYCBhcmUgbm90IHN1cHBvcnRlZCBoZXJlLiBJZiB5b3Ugd2FudCB0byBzZXQgYGhlaWdodGAgYXMgYSBwZXJjZW50YWdlLCBkbyBpdCB2aWEgYHN0eWxlYCBvciBgY2xhc3NgXG4gICAqIG9mIHRoZSBjb3JyZXNwb25kaW5nIERPTSBlbGVtZW50LlxuICAgKiBEZWZhdWx0OiBgdW5kZWZpbmVkYFxuICAqL1xuICBASW5wdXQoKSBoZWlnaHQ/OiBudW1iZXJcblxuICAvKiogTWFyZ2lucy4gRGVmYXVsdDogYHsgdG9wOiAwLCBib3R0b206IDAsIGxlZnQ6IDAsIHJpZ2h0OiAwIH1gICovXG4gIEBJbnB1dCgpIG1hcmdpbj86IFNwYWNpbmcgPSB7IHRvcDogMCwgYm90dG9tOiAwLCBsZWZ0OiAwLCByaWdodDogMCB9XG4gIC8qKiBBbmltYXRpb24gZHVyYXRpb24gb2YgYWxsIHRoZSBjb21wb25lbnRzIHdpdGhpbiB0aGUgY29udGFpbmVyLiBEZWZhdWx0OiBgdW5kZWZpbmVkYCAqL1xuICBASW5wdXQoKSBkdXJhdGlvbj86IG51bWJlclxuICAvKiogQWx0ZXJuYXRpdmUgdGV4dCBkZXNjcmlwdGlvbiBvZiB0aGUgY2hhcnQgZm9yIGFjY2Vzc2liaWxpdHkgcHVycG9zZXMuIEl0IHdpbGwgYmUgYXBwbGllZCBhcyBhblxuICAgKiBgYXJpYS1sYWJlbGAgYXR0cmlidXRlIHRvIHRoZSBkaXYgZWxlbWVudCBjb250YWluaW5nIHlvdXIgY2hhcnQuIERlZmF1bHQ6IGB1bmRlZmluZWRgLlxuICAqL1xuICBASW5wdXQoKSBhcmlhTGFiZWw/OiBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkXG4gIC8qKiBDdXN0b20gU1ZHIGRlZnMgYXZhaWxhYmxlIHRvIGFsbCB0aGUgY29tcG9uZW50cyB3aXRoaW4gdGhlIGNvbnRhaW5lci4gRGVmYXVsdDogYHVuZGVmaW5lZGAuICovXG4gIEBJbnB1dCgpIHN2Z0RlZnM/OiBzdHJpbmdcbiAgLyoqIERlZmluZXMgd2hldGhlciBjb21wb25lbnRzIHNob3VsZCBmaXQgaW50byB0aGUgY29udGFpbmVyIG9yIHRoZSBjb250YWluZXIgc2hvdWxkIGV4cGFuZCB0byBmaXQgdG8gdGhlIGNvbXBvbmVudCdzIHNpemUuXG4gICAqIFdvcmtzIHdpdGggYSBsaW1pdGVkIHNldCBvZiBjb21wb25lbnRzLiBEZWZhdWx0OiBgU2l6aW5nLkZpdGAgKi9cbiAgQElucHV0KCkgc2l6aW5nPzogU2l6aW5nIHwgc3RyaW5nXG4gIC8qKiBEYXRhIHRvIGJlIHBhc3NlZCB0byB0aGUgY29tcG9uZW50LiBEZWZhdWx0OiBgdW5kZWZpbmVkYC4gKi9cbiAgQElucHV0KCkgZGF0YT86IERhdGFcblxuICBjaGFydDogU2luZ2xlQ29udGFpbmVyPERhdGE+XG5cbiAgbmdBZnRlclZpZXdJbml0ICgpOiB2b2lkIHtcbiAgICB0aGlzLmNoYXJ0ID0gbmV3IFNpbmdsZUNvbnRhaW5lcjxEYXRhPih0aGlzLmNvbnRhaW5lclJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLmdldENvbmZpZygpLCB0aGlzLmRhdGEpXG4gICAgLy8gV2UgcGFzcyB0aGUgY29udGFpbmVyIGZvciB0aGUgY29tcG9uZW50IHRvIHRyaWdnZXIgcmUtcmVuZGVyIGlmIHRoZSBkYXRhIGhhcyBjaGFuZ2VkXG4gICAgdGhpcy52aXNDb21wb25lbnQuY29tcG9uZW50Q29udGFpbmVyID0gdGhpcy5jaGFydFxuICB9XG5cbiAgbmdPbkNoYW5nZXMgKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAvLyBTZXQgbmV3IERhdGEgd2l0aG91dCByZS1yZW5kZXJcbiAgICBpZiAoY2hhbmdlcy5kYXRhKSB7XG4gICAgICB0aGlzLmNoYXJ0Py5zZXREYXRhKHRoaXMuZGF0YSwgdHJ1ZSlcbiAgICAgIGRlbGV0ZSBjaGFuZ2VzLmRhdGFcbiAgICB9XG5cbiAgICAvLyBVcGRhdGUgQ29udGFpbmVyIGFuZCByZW5kZXJcbiAgICB0aGlzLmNoYXJ0Py51cGRhdGVDb250YWluZXIodGhpcy5nZXRDb25maWcoKSlcbiAgfVxuXG4gIGdldENvbmZpZyAoKTogU2luZ2xlQ29udGFpbmVyQ29uZmlnSW50ZXJmYWNlPERhdGE+IHtcbiAgICBjb25zdCB7IHdpZHRoLCBoZWlnaHQsIGR1cmF0aW9uLCBtYXJnaW4sIGFyaWFMYWJlbCwgc3ZnRGVmcywgc2l6aW5nIH0gPSB0aGlzXG5cbiAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLnZpc0NvbXBvbmVudD8uY29tcG9uZW50IGFzIENcbiAgICBjb25zdCB0b29sdGlwID0gdGhpcy50b29sdGlwQ29tcG9uZW50Py5jb21wb25lbnQgYXMgVG9vbHRpcFxuICAgIGNvbnN0IGFubm90YXRpb25zID0gdGhpcy5hbm5vdGF0aW9uc0NvbXBvbmVudD8uY29tcG9uZW50IGFzIEFubm90YXRpb25zXG5cbiAgICByZXR1cm4geyB3aWR0aCwgaGVpZ2h0LCBkdXJhdGlvbiwgbWFyZ2luLCBjb21wb25lbnQsIHRvb2x0aXAsIGFyaWFMYWJlbCwgYW5ub3RhdGlvbnMsIHN2Z0RlZnMsIHNpemluZyB9XG4gIH1cblxuICBuZ09uRGVzdHJveSAoKTogdm9pZCB7XG4gICAgdGhpcy5jaGFydC5kZXN0cm95KClcbiAgfVxufVxuIl19
|
|
@@ -174,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
174
174
|
}], data: [{
|
|
175
175
|
type: Input
|
|
176
176
|
}] } });
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xy-container.component.js","sourceRoot":"","sources":["../../../../../src/containers/xy-container/xy-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\n\n// Vis\nimport { Annotations, Axis, ContinuousScale, Crosshair, Direction, Spacing, Tooltip, XYContainer, XYContainerConfigInterface } from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\nimport { VisTooltipComponent } from '../../components/tooltip/tooltip.component'\nimport { VisAnnotationsComponent } from '../../components/annotations/annotations.component'\n\n@Component({\n  selector: 'vis-xy-container',\n  template: `<div #container class=\"unovis-xy-container\">\n    <ng-content></ng-content>\n  </div>`,\n  styles: ['.unovis-xy-container { width: 100%; height: 100%; position: relative; }'],\n})\nexport class VisXYContainerComponent<Datum> implements AfterViewInit, AfterContentInit, OnDestroy {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n  @ContentChildren(VisXYComponent) visComponents: QueryList<VisXYComponent>\n  @ContentChild(VisTooltipComponent) tooltipComponent: VisTooltipComponent\n  @ContentChild(VisAnnotationsComponent) annotationsComponent: VisAnnotationsComponent\n\n  /** Width in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() width?: number\n  /** Height in pixels. By default, Container automatically fits to the size of the parent element. Default: `undefined`. */\n  @Input() height?: number\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). Default: `Scale.scaleLinear()` */\n  @Input() xScale?: ContinuousScale\n  /** Scale domain (data extent) for X dimension. By default this value is calculated automatically based on data. */\n  @Input() xDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `xDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() xDomainMinConstraint?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `xDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() xDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the X scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() xRange?: [number, number]\n\n  /** Scale for Y dimension, e.g. Scale.ScaleLinear. Default: `Scale.ScaleLinear()` */\n  @Input() yScale?: ContinuousScale\n  /** Scale domain (data extent) for Y dimension. By default this value is calculated automatically based on data. */\n  @Input() yDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `yDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() yDomainMinConstraint?: [number | undefined, number | undefined] = undefined\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `yDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() yDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the Y scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() yRange?: [number, number]\n  /** Y Axis direction. Default: `Direction.North` */\n  @Input() yDirection?: Direction.South | Direction.North | string = Direction.North\n  /** Prevents the chart domain from being empty (when domain's min and max values are equal).\n   *  That usually happens when all the data values are the same or when there's no data.\n   *  Setting to `true` will automatically extend the domain by `+1` when needed.\n   *  Setting to `null` will extend the domain only when there's no data.\n   *  Setting to `false` will keep the domain as is.\n   *  Default: `null` */\n  @Input() preventEmptyDomain?: boolean | null = null\n\n  /** Animation duration of all the components within the container. Default: `undefined` */\n  @Input() duration?: number = undefined\n  /** Margins. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() margin?: Spacing = { top: 0, bottom: 0, left: 0, right: 0 }\n  /** Padding. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() padding?: Spacing = {}\n  /** Sets the Y scale domain based on the current X scale domain (not the whole dataset). Default: `false` */\n  @Input() scaleByDomain?: boolean\n  /** Enables automatic calculation of chart margins based on the size of the axes. Default: `true` */\n  @Input() autoMargin?: boolean = true\n\n  /** Alternative text description of the chart for accessibility purposes. It will be applied as an\n   * `aria-label` attribute to the div element containing your chart. Default: `undefined`.\n  */\n  @Input() ariaLabel?: string | null | undefined\n\n  /** Data to be passed to all child components. But if `data` is `undefined` it'll to be passed allowing components to\n   * have their individual data. Default: `undefined` */\n  @Input() data?: Datum[] | undefined = undefined\n\n  chart: XYContainer<Datum>\n\n  ngAfterViewInit (): void {\n    this.chart = new XYContainer<Datum>(this.containerRef.nativeElement, this.getConfig(), this.data)\n    this.passContainerReferenceToChildren()\n  }\n\n  ngAfterContentInit (): void {\n    // QueryList does unsubscribe automatically when it gets destroyed\n    this.visComponents.changes.subscribe(() => {\n      this.passContainerReferenceToChildren()\n      this.chart?.updateContainer(this.getConfig())\n    })\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    const preventRender = true\n\n    // Set new Data without re-render\n    if (changes.data) {\n      this.chart?.setData(this.data, preventRender)\n      delete changes.data\n    }\n\n    // Update Container and render\n    this.chart?.updateContainer(this.getConfig())\n  }\n\n  getConfig (): XYContainerConfigInterface<Datum> {\n    const {\n      duration, margin, padding, scaleByDomain, autoMargin, width, height,\n      xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange,\n      yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange,\n      yDirection, ariaLabel,\n    } = this\n    const visComponents = this.visComponents.toArray().map(d => d.component)\n\n    const crosshair = visComponents.find(c => c instanceof Crosshair) as Crosshair<Datum>\n    const tooltip = this.tooltipComponent?.component as Tooltip\n    const xAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'x') as Axis<Datum>\n    const yAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'y') as Axis<Datum>\n    const annotations = this.annotationsComponent?.component as Annotations\n\n    const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis))\n\n    return {\n      components,\n      width,\n      height,\n      duration,\n      margin,\n      padding,\n      xAxis,\n      yAxis,\n      tooltip,\n      crosshair,\n      annotations,\n      scaleByDomain,\n      autoMargin,\n      xScale,\n      xDomain,\n      xDomainMinConstraint,\n      xDomainMaxConstraint,\n      xRange,\n      yScale,\n      yDomain,\n      yDomainMinConstraint,\n      yDomainMaxConstraint,\n      yRange,\n      yDirection,\n      ariaLabel,\n    }\n  }\n\n  passContainerReferenceToChildren (): void {\n    // We set the container for each vis component to trigger chart re-render if the data has changed\n    if (this.chart) this.visComponents.toArray().forEach(c => { c.componentContainer = this.chart })\n  }\n\n  ngOnDestroy (): void {\n    this.chart?.destroy()\n  }\n}\n"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xy-container.component.js","sourceRoot":"","sources":["../../../../../src/containers/xy-container/xy-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  Input,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core'\n\n// Vis\nimport { Annotations, Axis, ContinuousScale, Crosshair, Direction, Spacing, Tooltip, XYContainer, XYContainerConfigInterface } from '@unovis/ts'\nimport { VisXYComponent } from '../../core'\nimport { VisTooltipComponent } from '../../components/tooltip/tooltip.component'\nimport { VisAnnotationsComponent } from '../../components/annotations/annotations.component'\n\n@Component({\n  selector: 'vis-xy-container',\n  template: `<div #container class=\"unovis-xy-container\">\n    <ng-content></ng-content>\n  </div>`,\n  styles: ['.unovis-xy-container { width: 100%; height: 100%; position: relative; }'],\n})\nexport class VisXYContainerComponent<Datum> implements AfterViewInit, AfterContentInit, OnDestroy {\n  @ViewChild('container', { static: false }) containerRef: ElementRef\n  @ContentChildren(VisXYComponent) visComponents: QueryList<VisXYComponent>\n  @ContentChild(VisTooltipComponent) tooltipComponent: VisTooltipComponent\n  @ContentChild(VisAnnotationsComponent) annotationsComponent: VisAnnotationsComponent\n\n  /** Width in pixels or in CSS units.\n   * Percentage units `\"%\"` are not supported here. If you want to set `width` as a percentage, do it via `style` or `class`\n   * of the corresponding DOM element.\n   * Default: `undefined`\n  */\n  @Input() width?: number\n  /** Height in pixels or in CSS units.\n   * Percentage units `\"%\"` are not supported here. If you want to set `height` as a percentage, do it via `style` or `class`\n   * of the corresponding DOM element.\n   * Default: `undefined`\n  */\n  @Input() height?: number\n\n  /** Scale for X dimension, e.g. Scale.scaleLinear(). Default: `Scale.scaleLinear()` */\n  @Input() xScale?: ContinuousScale\n  /** Scale domain (data extent) for X dimension. By default this value is calculated automatically based on data. */\n  @Input() xDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `xDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() xDomainMinConstraint?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the X scale domain. Useful when the data is plotted along the X axis.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `xDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() xDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the X scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() xRange?: [number, number]\n\n  /** Scale for Y dimension, e.g. Scale.ScaleLinear. Default: `Scale.ScaleLinear()` */\n  @Input() yScale?: ContinuousScale\n  /** Scale domain (data extent) for Y dimension. By default this value is calculated automatically based on data. */\n  @Input() yDomain?: [number | undefined, number | undefined]\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data that has negative values. When values are small\n   * (let's say in the range of [-0.01, 0]), you might still want the chart to display some meaningful value range (e.g. [-1, 0]). That can\n   * be achieved by setting `yDomainMinConstraint` to `[undefined, -1]`. In addition to that, if you want to cut off the\n   * values that are too low (let's say lower than -100), you can set the constraint to `[-100, -1]`\n   * Default: `undefined` */\n  @Input() yDomainMinConstraint?: [number | undefined, number | undefined] = undefined\n  /** Constraint the minimum value of the Y scale domain.\n   * For example, imagine that you have a chart with dynamic data. When values are small\n   * (let's say < 0.01), you might still want the chart to display some meaningful value range (e.g. [0, 1]). That can\n   * be achieved by setting `yDomainMaxConstraint` to `[1, undefined]`. In addition to that, if you want to cut off the\n   * values that are too high (let's say higher than 100), you can set the constraint to `[1, 100]`\n   * Default: `undefined` */\n  @Input() yDomainMaxConstraint?: [number | undefined, number | undefined]\n  /** Force set the Y scale range (in the screen space). By default the range is calculated automatically based on the\n   * chart's set up */\n  @Input() yRange?: [number, number]\n  /** Y Axis direction. Default: `Direction.North` */\n  @Input() yDirection?: Direction.South | Direction.North | string = Direction.North\n  /** Prevents the chart domain from being empty (when domain's min and max values are equal).\n   *  That usually happens when all the data values are the same or when there's no data.\n   *  Setting to `true` will automatically extend the domain by `+1` when needed.\n   *  Setting to `null` will extend the domain only when there's no data.\n   *  Setting to `false` will keep the domain as is.\n   *  Default: `null` */\n  @Input() preventEmptyDomain?: boolean | null = null\n\n  /** Animation duration of all the components within the container. Default: `undefined` */\n  @Input() duration?: number = undefined\n  /** Margins. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() margin?: Spacing = { top: 0, bottom: 0, left: 0, right: 0 }\n  /** Padding. Default: `{ top: 0, bottom: 0, left: 0, right: 0 }` */\n  @Input() padding?: Spacing = {}\n  /** Sets the Y scale domain based on the current X scale domain (not the whole dataset). Default: `false` */\n  @Input() scaleByDomain?: boolean\n  /** Enables automatic calculation of chart margins based on the size of the axes. Default: `true` */\n  @Input() autoMargin?: boolean = true\n\n  /** Alternative text description of the chart for accessibility purposes. It will be applied as an\n   * `aria-label` attribute to the div element containing your chart. Default: `undefined`.\n  */\n  @Input() ariaLabel?: string | null | undefined\n\n  /** Data to be passed to all child components. But if `data` is `undefined` it'll to be passed allowing components to\n   * have their individual data. Default: `undefined` */\n  @Input() data?: Datum[] | undefined = undefined\n\n  chart: XYContainer<Datum>\n\n  ngAfterViewInit (): void {\n    this.chart = new XYContainer<Datum>(this.containerRef.nativeElement, this.getConfig(), this.data)\n    this.passContainerReferenceToChildren()\n  }\n\n  ngAfterContentInit (): void {\n    // QueryList does unsubscribe automatically when it gets destroyed\n    this.visComponents.changes.subscribe(() => {\n      this.passContainerReferenceToChildren()\n      this.chart?.updateContainer(this.getConfig())\n    })\n  }\n\n  ngOnChanges (changes: SimpleChanges): void {\n    const preventRender = true\n\n    // Set new Data without re-render\n    if (changes.data) {\n      this.chart?.setData(this.data, preventRender)\n      delete changes.data\n    }\n\n    // Update Container and render\n    this.chart?.updateContainer(this.getConfig())\n  }\n\n  getConfig (): XYContainerConfigInterface<Datum> {\n    const {\n      duration, margin, padding, scaleByDomain, autoMargin, width, height,\n      xScale, xDomain, xDomainMinConstraint, xDomainMaxConstraint, xRange,\n      yScale, yDomain, yDomainMinConstraint, yDomainMaxConstraint, yRange,\n      yDirection, ariaLabel,\n    } = this\n    const visComponents = this.visComponents.toArray().map(d => d.component)\n\n    const crosshair = visComponents.find(c => c instanceof Crosshair) as Crosshair<Datum>\n    const tooltip = this.tooltipComponent?.component as Tooltip\n    const xAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'x') as Axis<Datum>\n    const yAxis = visComponents.find(c => c instanceof Axis && c?.config?.type === 'y') as Axis<Datum>\n    const annotations = this.annotationsComponent?.component as Annotations\n\n    const components = visComponents.filter(c => !(c instanceof Crosshair) && !(c instanceof Tooltip) && !(c instanceof Axis))\n\n    return {\n      components,\n      width,\n      height,\n      duration,\n      margin,\n      padding,\n      xAxis,\n      yAxis,\n      tooltip,\n      crosshair,\n      annotations,\n      scaleByDomain,\n      autoMargin,\n      xScale,\n      xDomain,\n      xDomainMinConstraint,\n      xDomainMaxConstraint,\n      xRange,\n      yScale,\n      yDomain,\n      yDomainMinConstraint,\n      yDomainMaxConstraint,\n      yRange,\n      yDirection,\n      ariaLabel,\n    }\n  }\n\n  passContainerReferenceToChildren (): void {\n    // We set the container for each vis component to trigger chart re-render if the data has changed\n    if (this.chart) this.visComponents.toArray().forEach(c => { c.componentContainer = this.chart })\n  }\n\n  ngOnDestroy (): void {\n    this.chart?.destroy()\n  }\n}\n"]}
|