@reltio/components 1.4.1844 → 1.4.1845
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/cjs/EmptyState/EmptyState.d.ts +1 -0
- package/cjs/EmptyState/EmptyState.js +3 -1
- package/cjs/features/graph/DataModelGraph/DataModelGraph.d.ts +12 -0
- package/cjs/features/graph/DataModelGraph/DataModelGraph.js +28 -0
- package/cjs/features/graph/DataModelGraph/DataModelGraph.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/DataModelGraph.test.js +63 -0
- package/cjs/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.d.ts +11 -0
- package/cjs/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.js +21 -0
- package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.d.ts +9 -0
- package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.js +38 -0
- package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.js +74 -0
- package/cjs/features/graph/DataModelGraph/hooks/defaultGraph.test-data.d.ts +2 -0
- package/cjs/features/graph/DataModelGraph/hooks/defaultGraph.test-data.js +52 -0
- package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.d.ts +17 -0
- package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.js +139 -0
- package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.js +192 -0
- package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.d.ts +10 -0
- package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.js +171 -0
- package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.js +176 -0
- package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.d.ts +8 -0
- package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.js +36 -0
- package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.js +37 -0
- package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.d.ts +2 -0
- package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.js +41 -0
- package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.js +63 -0
- package/cjs/features/graph/DataModelGraph/icons/interaction.inline.svg.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/icons/interaction.inline.svg.js +4 -0
- package/cjs/features/graph/DataModelGraph/index.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/index.js +5 -0
- package/cjs/features/graph/DataModelGraph/styles.d.ts +1 -0
- package/cjs/features/graph/DataModelGraph/styles.js +26 -0
- package/cjs/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.d.ts +6 -0
- package/cjs/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.js +15 -0
- package/cjs/features/graph/SigmaCustomRenderersContainer/index.d.ts +1 -0
- package/cjs/features/graph/SigmaCustomRenderersContainer/index.js +5 -0
- package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.d.ts +9 -0
- package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.js +86 -0
- package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.d.ts +1 -0
- package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.js +26 -0
- package/cjs/features/graph/SigmaGraphContainer/index.d.ts +1 -0
- package/cjs/features/graph/SigmaGraphContainer/index.js +5 -0
- package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.d.ts +1 -0
- package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.js +40 -0
- package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.d.ts +1 -0
- package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.js +37 -0
- package/cjs/features/graph/SigmaGraphResizer/index.d.ts +1 -0
- package/cjs/features/graph/SigmaGraphResizer/index.js +5 -0
- package/cjs/features/graph/ZoomSlider/ZoomSlider.d.ts +7 -0
- package/cjs/features/graph/ZoomSlider/ZoomSlider.js +113 -0
- package/cjs/features/graph/ZoomSlider/ZoomSlider.test.d.ts +1 -0
- package/cjs/features/graph/ZoomSlider/ZoomSlider.test.js +83 -0
- package/cjs/features/graph/ZoomSlider/index.d.ts +1 -0
- package/cjs/features/graph/ZoomSlider/index.js +5 -0
- package/cjs/features/graph/ZoomSlider/styles.d.ts +1 -0
- package/cjs/features/graph/ZoomSlider/styles.js +63 -0
- package/cjs/features/graph/contexts/SigmaCustomRenderersContext.d.ts +9 -0
- package/cjs/features/graph/contexts/SigmaCustomRenderersContext.js +15 -0
- package/cjs/features/graph/hooks/useAnimatedGraphLayout.d.ts +13 -0
- package/cjs/features/graph/hooks/useAnimatedGraphLayout.js +35 -0
- package/cjs/features/graph/hooks/useCircleLayout.d.ts +9 -0
- package/cjs/features/graph/hooks/useCircleLayout.js +50 -0
- package/cjs/features/graph/hooks/useLoopRenderer.d.ts +5 -0
- package/cjs/features/graph/hooks/useLoopRenderer.js +47 -0
- package/cjs/features/graph/hooks/useLoopRenderer.test.d.ts +1 -0
- package/cjs/features/graph/hooks/useLoopRenderer.test.js +221 -0
- package/cjs/features/graph/hooks/useSigmaCustomRenderers.d.ts +7 -0
- package/cjs/features/graph/hooks/useSigmaCustomRenderers.js +95 -0
- package/cjs/features/graph/hooks/useSigmaCustomRenderers.test.d.ts +1 -0
- package/cjs/features/graph/hooks/useSigmaCustomRenderers.test.js +200 -0
- package/cjs/features/graph/index.d.ts +16 -0
- package/cjs/features/graph/index.js +34 -0
- package/cjs/features/graph/rendering/canvas/hover.d.ts +2 -0
- package/cjs/features/graph/rendering/canvas/hover.js +10 -0
- package/cjs/features/graph/rendering/canvas/hover.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/hover.spec.js +26 -0
- package/cjs/features/graph/rendering/canvas/label.d.ts +7 -0
- package/cjs/features/graph/rendering/canvas/label.js +32 -0
- package/cjs/features/graph/rendering/canvas/label.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/label.spec.js +81 -0
- package/cjs/features/graph/rendering/canvas/labelBackground.d.ts +9 -0
- package/cjs/features/graph/rendering/canvas/labelBackground.js +37 -0
- package/cjs/features/graph/rendering/canvas/labelBackground.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/labelBackground.spec.js +92 -0
- package/cjs/features/graph/rendering/canvas/nodeArc.d.ts +10 -0
- package/cjs/features/graph/rendering/canvas/nodeArc.js +33 -0
- package/cjs/features/graph/rendering/canvas/selfRelationLoop.d.ts +11 -0
- package/cjs/features/graph/rendering/canvas/selfRelationLoop.js +73 -0
- package/cjs/features/graph/rendering/canvas/selfRelationLoop.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/selfRelationLoop.spec.js +92 -0
- package/cjs/features/graph/rendering/canvas/tooltip.d.ts +2 -0
- package/cjs/features/graph/rendering/canvas/tooltip.js +28 -0
- package/cjs/features/graph/rendering/canvas/tooltip.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/tooltip.spec.js +32 -0
- package/cjs/features/graph/rendering/canvas/utils.d.ts +4 -0
- package/cjs/features/graph/rendering/canvas/utils.js +10 -0
- package/cjs/features/graph/rendering/canvas/utils.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/canvas/utils.spec.js +22 -0
- package/cjs/features/graph/rendering/icons/no_photo.inline.svg.d.ts +1 -0
- package/cjs/features/graph/rendering/icons/no_photo.inline.svg.js +4 -0
- package/cjs/features/graph/rendering/webgl/edge.arrowHead.d.ts +8 -0
- package/cjs/features/graph/rendering/webgl/edge.arrowHead.js +84 -0
- package/cjs/features/graph/rendering/webgl/edge.clamped.d.ts +29 -0
- package/cjs/features/graph/rendering/webgl/edge.clamped.js +176 -0
- package/cjs/features/graph/rendering/webgl/edge.dashed.d.ts +23 -0
- package/cjs/features/graph/rendering/webgl/edge.dashed.js +162 -0
- package/cjs/features/graph/rendering/webgl/edge.reversedArrowHead.d.ts +5 -0
- package/cjs/features/graph/rendering/webgl/edge.reversedArrowHead.js +32 -0
- package/cjs/features/graph/rendering/webgl/helpers/imageHelper.d.ts +17 -0
- package/cjs/features/graph/rendering/webgl/helpers/imageHelper.js +9 -0
- package/cjs/features/graph/rendering/webgl/helpers/imageHelper.spec.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/helpers/imageHelper.spec.js +29 -0
- package/cjs/features/graph/rendering/webgl/image.d.ts +17 -0
- package/cjs/features/graph/rendering/webgl/image.js +115 -0
- package/cjs/features/graph/rendering/webgl/node.border.d.ts +11 -0
- package/cjs/features/graph/rendering/webgl/node.border.js +79 -0
- package/cjs/features/graph/rendering/webgl/node.dashed.border.d.ts +11 -0
- package/cjs/features/graph/rendering/webgl/node.dashed.border.js +77 -0
- package/cjs/features/graph/rendering/webgl/node.image.d.ts +18 -0
- package/cjs/features/graph/rendering/webgl/node.image.js +147 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.border.frag.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.border.frag.glsl.js +9 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.border.vert.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.border.vert.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.image.frag.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.image.frag.glsl.js +5 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.image.vert.glsl.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/node.image.vert.glsl.js +8 -0
- package/cjs/features/graph/rendering/webgl/shaders/utils.d.ts +1 -0
- package/cjs/features/graph/rendering/webgl/shaders/utils.js +4 -0
- package/cjs/features/graph/types/graphDataTypes.d.ts +51 -0
- package/cjs/features/graph/types/graphDataTypes.js +8 -0
- package/cjs/features/graph/types/sigmaCustomRenderersTypes.d.ts +11 -0
- package/cjs/features/graph/types/sigmaCustomRenderersTypes.js +2 -0
- package/cjs/icons/EmptyLoading.d.ts +3 -0
- package/cjs/icons/EmptyLoading.js +150 -0
- package/cjs/icons/index.d.ts +1 -0
- package/cjs/icons/index.js +4 -2
- package/cjs/index.d.ts +1 -0
- package/cjs/index.js +2 -0
- package/esm/EmptyState/EmptyState.d.ts +1 -0
- package/esm/EmptyState/EmptyState.js +3 -1
- package/esm/features/graph/DataModelGraph/DataModelGraph.d.ts +12 -0
- package/esm/features/graph/DataModelGraph/DataModelGraph.js +21 -0
- package/esm/features/graph/DataModelGraph/DataModelGraph.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/DataModelGraph.test.js +58 -0
- package/esm/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.d.ts +11 -0
- package/esm/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.js +17 -0
- package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.d.ts +9 -0
- package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.js +33 -0
- package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.js +72 -0
- package/esm/features/graph/DataModelGraph/hooks/defaultGraph.test-data.d.ts +2 -0
- package/esm/features/graph/DataModelGraph/hooks/defaultGraph.test-data.js +45 -0
- package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.d.ts +17 -0
- package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.js +135 -0
- package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.js +190 -0
- package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.d.ts +10 -0
- package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.js +167 -0
- package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.js +174 -0
- package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.d.ts +8 -0
- package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.js +32 -0
- package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.js +35 -0
- package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.d.ts +2 -0
- package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.js +37 -0
- package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.js +61 -0
- package/esm/features/graph/DataModelGraph/icons/interaction.inline.svg.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/icons/interaction.inline.svg.js +1 -0
- package/esm/features/graph/DataModelGraph/index.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/index.js +1 -0
- package/esm/features/graph/DataModelGraph/styles.d.ts +1 -0
- package/esm/features/graph/DataModelGraph/styles.js +23 -0
- package/esm/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.d.ts +6 -0
- package/esm/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.js +8 -0
- package/esm/features/graph/SigmaCustomRenderersContainer/index.d.ts +1 -0
- package/esm/features/graph/SigmaCustomRenderersContainer/index.js +1 -0
- package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.d.ts +9 -0
- package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.js +56 -0
- package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.d.ts +1 -0
- package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.js +21 -0
- package/esm/features/graph/SigmaGraphContainer/index.d.ts +1 -0
- package/esm/features/graph/SigmaGraphContainer/index.js +1 -0
- package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.d.ts +1 -0
- package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.js +10 -0
- package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.d.ts +1 -0
- package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.js +32 -0
- package/esm/features/graph/SigmaGraphResizer/index.d.ts +1 -0
- package/esm/features/graph/SigmaGraphResizer/index.js +1 -0
- package/esm/features/graph/ZoomSlider/ZoomSlider.d.ts +7 -0
- package/esm/features/graph/ZoomSlider/ZoomSlider.js +83 -0
- package/esm/features/graph/ZoomSlider/ZoomSlider.test.d.ts +1 -0
- package/esm/features/graph/ZoomSlider/ZoomSlider.test.js +78 -0
- package/esm/features/graph/ZoomSlider/index.d.ts +1 -0
- package/esm/features/graph/ZoomSlider/index.js +1 -0
- package/esm/features/graph/ZoomSlider/styles.d.ts +1 -0
- package/esm/features/graph/ZoomSlider/styles.js +60 -0
- package/esm/features/graph/contexts/SigmaCustomRenderersContext.d.ts +9 -0
- package/esm/features/graph/contexts/SigmaCustomRenderersContext.js +11 -0
- package/esm/features/graph/hooks/useAnimatedGraphLayout.d.ts +13 -0
- package/esm/features/graph/hooks/useAnimatedGraphLayout.js +31 -0
- package/esm/features/graph/hooks/useCircleLayout.d.ts +9 -0
- package/esm/features/graph/hooks/useCircleLayout.js +43 -0
- package/esm/features/graph/hooks/useLoopRenderer.d.ts +5 -0
- package/esm/features/graph/hooks/useLoopRenderer.js +43 -0
- package/esm/features/graph/hooks/useLoopRenderer.test.d.ts +1 -0
- package/esm/features/graph/hooks/useLoopRenderer.test.js +219 -0
- package/esm/features/graph/hooks/useSigmaCustomRenderers.d.ts +7 -0
- package/esm/features/graph/hooks/useSigmaCustomRenderers.js +91 -0
- package/esm/features/graph/hooks/useSigmaCustomRenderers.test.d.ts +1 -0
- package/esm/features/graph/hooks/useSigmaCustomRenderers.test.js +198 -0
- package/esm/features/graph/index.d.ts +16 -0
- package/esm/features/graph/index.js +17 -0
- package/esm/features/graph/rendering/canvas/hover.d.ts +2 -0
- package/esm/features/graph/rendering/canvas/hover.js +6 -0
- package/esm/features/graph/rendering/canvas/hover.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/hover.spec.js +24 -0
- package/esm/features/graph/rendering/canvas/label.d.ts +7 -0
- package/esm/features/graph/rendering/canvas/label.js +28 -0
- package/esm/features/graph/rendering/canvas/label.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/label.spec.js +79 -0
- package/esm/features/graph/rendering/canvas/labelBackground.d.ts +9 -0
- package/esm/features/graph/rendering/canvas/labelBackground.js +33 -0
- package/esm/features/graph/rendering/canvas/labelBackground.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/labelBackground.spec.js +90 -0
- package/esm/features/graph/rendering/canvas/nodeArc.d.ts +10 -0
- package/esm/features/graph/rendering/canvas/nodeArc.js +27 -0
- package/esm/features/graph/rendering/canvas/selfRelationLoop.d.ts +11 -0
- package/esm/features/graph/rendering/canvas/selfRelationLoop.js +69 -0
- package/esm/features/graph/rendering/canvas/selfRelationLoop.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/selfRelationLoop.spec.js +90 -0
- package/esm/features/graph/rendering/canvas/tooltip.d.ts +2 -0
- package/esm/features/graph/rendering/canvas/tooltip.js +25 -0
- package/esm/features/graph/rendering/canvas/tooltip.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/tooltip.spec.js +30 -0
- package/esm/features/graph/rendering/canvas/utils.d.ts +4 -0
- package/esm/features/graph/rendering/canvas/utils.js +6 -0
- package/esm/features/graph/rendering/canvas/utils.spec.d.ts +1 -0
- package/esm/features/graph/rendering/canvas/utils.spec.js +20 -0
- package/esm/features/graph/rendering/icons/no_photo.inline.svg.d.ts +1 -0
- package/esm/features/graph/rendering/icons/no_photo.inline.svg.js +1 -0
- package/esm/features/graph/rendering/webgl/edge.arrowHead.d.ts +8 -0
- package/esm/features/graph/rendering/webgl/edge.arrowHead.js +79 -0
- package/esm/features/graph/rendering/webgl/edge.clamped.d.ts +29 -0
- package/esm/features/graph/rendering/webgl/edge.clamped.js +171 -0
- package/esm/features/graph/rendering/webgl/edge.dashed.d.ts +23 -0
- package/esm/features/graph/rendering/webgl/edge.dashed.js +160 -0
- package/esm/features/graph/rendering/webgl/edge.reversedArrowHead.d.ts +5 -0
- package/esm/features/graph/rendering/webgl/edge.reversedArrowHead.js +27 -0
- package/esm/features/graph/rendering/webgl/helpers/imageHelper.d.ts +17 -0
- package/esm/features/graph/rendering/webgl/helpers/imageHelper.js +5 -0
- package/esm/features/graph/rendering/webgl/helpers/imageHelper.spec.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/helpers/imageHelper.spec.js +27 -0
- package/esm/features/graph/rendering/webgl/image.d.ts +17 -0
- package/esm/features/graph/rendering/webgl/image.js +112 -0
- package/esm/features/graph/rendering/webgl/node.border.d.ts +11 -0
- package/esm/features/graph/rendering/webgl/node.border.js +76 -0
- package/esm/features/graph/rendering/webgl/node.dashed.border.d.ts +11 -0
- package/esm/features/graph/rendering/webgl/node.dashed.border.js +74 -0
- package/esm/features/graph/rendering/webgl/node.image.d.ts +18 -0
- package/esm/features/graph/rendering/webgl/node.image.js +144 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/node.border.frag.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/node.border.frag.glsl.js +6 -0
- package/esm/features/graph/rendering/webgl/shaders/node.border.vert.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/node.border.vert.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/node.image.frag.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/node.image.frag.glsl.js +2 -0
- package/esm/features/graph/rendering/webgl/shaders/node.image.vert.glsl.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/node.image.vert.glsl.js +5 -0
- package/esm/features/graph/rendering/webgl/shaders/utils.d.ts +1 -0
- package/esm/features/graph/rendering/webgl/shaders/utils.js +1 -0
- package/esm/features/graph/types/graphDataTypes.d.ts +51 -0
- package/esm/features/graph/types/graphDataTypes.js +5 -0
- package/esm/features/graph/types/sigmaCustomRenderersTypes.d.ts +11 -0
- package/esm/features/graph/types/sigmaCustomRenderersTypes.js +1 -0
- package/esm/icons/EmptyLoading.d.ts +3 -0
- package/esm/icons/EmptyLoading.js +145 -0
- package/esm/icons/index.d.ts +1 -0
- package/esm/icons/index.js +1 -0
- package/esm/index.d.ts +1 -0
- package/esm/index.js +2 -0
- package/package.json +2 -2
|
@@ -9,6 +9,7 @@ export declare const EMPTY_STATE_ICONS: {
|
|
|
9
9
|
SELECT_ATTRIBUTES: React.FC<React.SVGProps<SVGSVGElement>>;
|
|
10
10
|
NO_DATA: React.FC<React.SVGProps<SVGSVGElement>>;
|
|
11
11
|
ERROR: React.FC<React.SVGProps<SVGSVGElement>>;
|
|
12
|
+
LOADING: React.FC<React.SVGProps<SVGSVGElement>>;
|
|
12
13
|
};
|
|
13
14
|
type Props = {
|
|
14
15
|
variant?: EMPTY_STATE_VARIANTS;
|
|
@@ -14,6 +14,7 @@ var SelectAttributes_1 = __importDefault(require("../icons/SelectAttributes"));
|
|
|
14
14
|
var NoData_1 = __importDefault(require("../icons/NoData"));
|
|
15
15
|
var Error_1 = __importDefault(require("../icons/Error"));
|
|
16
16
|
var styles_1 = require("./styles");
|
|
17
|
+
var EmptyLoading_1 = __importDefault(require("../icons/EmptyLoading"));
|
|
17
18
|
var EMPTY_STATE_VARIANTS;
|
|
18
19
|
(function (EMPTY_STATE_VARIANTS) {
|
|
19
20
|
EMPTY_STATE_VARIANTS["full"] = "full";
|
|
@@ -24,7 +25,8 @@ exports.EMPTY_STATE_ICONS = {
|
|
|
24
25
|
SEARCH_RESULTS: EmptySearchResults_1.default,
|
|
25
26
|
SELECT_ATTRIBUTES: SelectAttributes_1.default,
|
|
26
27
|
NO_DATA: NoData_1.default,
|
|
27
|
-
ERROR: Error_1.default
|
|
28
|
+
ERROR: Error_1.default,
|
|
29
|
+
LOADING: EmptyLoading_1.default
|
|
28
30
|
};
|
|
29
31
|
var EmptyState = function (_a) {
|
|
30
32
|
var _b = _a.variant, variant = _b === void 0 ? EMPTY_STATE_VARIANTS.full : _b, _c = _a.LogoRenderer, LogoRenderer = _c === void 0 ? exports.EMPTY_STATE_ICONS.SEARCH_RESULTS : _c, text = _a.text, secondaryText = _a.secondaryText, buttonTitle = _a.buttonTitle, _d = _a.onClick, onClick = _d === void 0 ? ramda_1.identity : _d, access = _a.access;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import Graph from 'graphology';
|
|
3
|
+
type Props = {
|
|
4
|
+
graph?: Graph;
|
|
5
|
+
children?: React.ReactNode;
|
|
6
|
+
selectedNode?: string;
|
|
7
|
+
onNodeClick: (nodeId: string) => void;
|
|
8
|
+
selectedEdge: string;
|
|
9
|
+
onEdgeLabelClick: (edgeId: string, event: MouseEvent) => void;
|
|
10
|
+
};
|
|
11
|
+
export declare const DataModelGraph: ({ graph, children, selectedNode, onNodeClick, selectedEdge, onEdgeLabelClick }: Props) => JSX.Element;
|
|
12
|
+
export default DataModelGraph;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DataModelGraph = void 0;
|
|
7
|
+
var react_1 = __importDefault(require("react"));
|
|
8
|
+
var SigmaGraphContainer_1 = require("../SigmaGraphContainer/SigmaGraphContainer");
|
|
9
|
+
var DataModelCircleLayuot_1 = require("./components/DataModelCircleLayout/DataModelCircleLayuot");
|
|
10
|
+
var ZoomSlider_1 = require("../ZoomSlider");
|
|
11
|
+
var styles_1 = require("./styles");
|
|
12
|
+
var settings = {
|
|
13
|
+
labelRenderedSizeThreshold: 11,
|
|
14
|
+
zIndex: true
|
|
15
|
+
};
|
|
16
|
+
var DataModelGraph = function (_a) {
|
|
17
|
+
var graph = _a.graph, children = _a.children, selectedNode = _a.selectedNode, onNodeClick = _a.onNodeClick, selectedEdge = _a.selectedEdge, onEdgeLabelClick = _a.onEdgeLabelClick;
|
|
18
|
+
var styles = (0, styles_1.useStyles)();
|
|
19
|
+
return (react_1.default.createElement("div", { className: styles.wrapper },
|
|
20
|
+
react_1.default.createElement("div", { className: styles.graph }, graph && (react_1.default.createElement(SigmaGraphContainer_1.SigmaGraphContainer, { initialSettings: settings },
|
|
21
|
+
react_1.default.createElement(react_1.default.Fragment, null,
|
|
22
|
+
react_1.default.createElement(DataModelCircleLayuot_1.DataModelCircleLayuot, { graph: graph, selectedNode: selectedNode, onNodeClick: onNodeClick, selectedEdge: selectedEdge, onEdgeLabelClick: onEdgeLabelClick }),
|
|
23
|
+
react_1.default.createElement("div", { className: styles.rightBottomControls },
|
|
24
|
+
react_1.default.createElement(ZoomSlider_1.ZoomSlider, { className: styles.zoomSlider, min: 30, max: 300 })))))),
|
|
25
|
+
children));
|
|
26
|
+
};
|
|
27
|
+
exports.DataModelGraph = DataModelGraph;
|
|
28
|
+
exports.default = exports.DataModelGraph;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
var react_1 = __importDefault(require("react"));
|
|
7
|
+
var graphology_1 = __importDefault(require("graphology"));
|
|
8
|
+
var react_2 = require("@testing-library/react");
|
|
9
|
+
var DataModelGraph_1 = require("../DataModelGraph");
|
|
10
|
+
var useDataModelGraphAppearance_1 = require("./hooks/useDataModelGraphAppearance");
|
|
11
|
+
var useFakeCenterNode_1 = require("./hooks/useFakeCenterNode");
|
|
12
|
+
var useCircleLayout_1 = require("../hooks/useCircleLayout");
|
|
13
|
+
jest.mock('@react-sigma/core', function () { return ({
|
|
14
|
+
SigmaContainer: function (_a) {
|
|
15
|
+
var children = _a.children;
|
|
16
|
+
return react_1.default.createElement("div", null, children);
|
|
17
|
+
},
|
|
18
|
+
useSigma: jest.fn().mockReturnValue({
|
|
19
|
+
refresh: jest.fn()
|
|
20
|
+
}),
|
|
21
|
+
useLoadGraph: jest.fn().mockReturnValue(jest.fn())
|
|
22
|
+
}); });
|
|
23
|
+
jest.mock('../hooks/useCircleLayout', function () { return ({
|
|
24
|
+
useCircleLayout: jest.fn()
|
|
25
|
+
}); });
|
|
26
|
+
jest.mock('../hooks/useSigmaCustomRenderers', function () { return ({
|
|
27
|
+
useSigmaCustomRenderers: jest.fn().mockReturnValue({ addRenderers: jest.fn() })
|
|
28
|
+
}); });
|
|
29
|
+
jest.mock('./hooks/useDataModelGraphAppearance', function () { return ({
|
|
30
|
+
useDataModelGraphAppearance: jest.fn()
|
|
31
|
+
}); });
|
|
32
|
+
jest.mock('./hooks/useFakeCenterNode', function () { return ({
|
|
33
|
+
useFakeCenterNode: jest.fn()
|
|
34
|
+
}); });
|
|
35
|
+
jest.mock('../ZoomSlider', function () { return ({
|
|
36
|
+
ZoomSlider: function () { return react_1.default.createElement("div", null, "ZoomSlider"); }
|
|
37
|
+
}); });
|
|
38
|
+
describe('DataModelGraph tests', function () {
|
|
39
|
+
var graph = new graphology_1.default();
|
|
40
|
+
var selectedNode = 'node1';
|
|
41
|
+
var onNodeClick = jest.fn();
|
|
42
|
+
var selectedEdge = 'edge1';
|
|
43
|
+
var onEdgeLabelClick = jest.fn();
|
|
44
|
+
var setUp = function () {
|
|
45
|
+
(0, react_2.render)(react_1.default.createElement(DataModelGraph_1.DataModelGraph, { graph: graph, selectedNode: selectedNode, onNodeClick: onNodeClick, selectedEdge: selectedEdge, onEdgeLabelClick: onEdgeLabelClick }));
|
|
46
|
+
};
|
|
47
|
+
afterEach(function () {
|
|
48
|
+
jest.clearAllMocks();
|
|
49
|
+
});
|
|
50
|
+
it('renders call hooks with correct props', function () {
|
|
51
|
+
setUp();
|
|
52
|
+
expect(useDataModelGraphAppearance_1.useDataModelGraphAppearance).toHaveBeenCalledWith(expect.objectContaining({
|
|
53
|
+
graph: graph,
|
|
54
|
+
selectedNode: selectedNode,
|
|
55
|
+
selectedEdge: selectedEdge,
|
|
56
|
+
onNodeClick: onNodeClick,
|
|
57
|
+
onEdgeLabelClick: onEdgeLabelClick
|
|
58
|
+
}));
|
|
59
|
+
expect(useFakeCenterNode_1.useFakeCenterNode).toHaveBeenCalledWith(expect.objectContaining({ graph: graph, timeout: 3100 }));
|
|
60
|
+
expect(useCircleLayout_1.useCircleLayout).toHaveBeenCalledWith(expect.objectContaining({ graph: graph, animationDuration: 3000 }));
|
|
61
|
+
expect(react_2.screen.getByText('ZoomSlider')).toBeInTheDocument();
|
|
62
|
+
});
|
|
63
|
+
});
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import Graph from 'graphology';
|
|
2
|
+
type Props = {
|
|
3
|
+
graph: Graph;
|
|
4
|
+
selectedNode?: string;
|
|
5
|
+
onNodeClick: (nodeId: string) => void;
|
|
6
|
+
selectedEdge: string;
|
|
7
|
+
onEdgeLabelClick: (edgeId: string, event: MouseEvent) => void;
|
|
8
|
+
};
|
|
9
|
+
export declare const LAYOUT_ANIMATION_DURATION = 3000;
|
|
10
|
+
export declare const DataModelCircleLayuot: ({ graph, selectedNode, onNodeClick, selectedEdge, onEdgeLabelClick }: Props) => any;
|
|
11
|
+
export {};
|
package/cjs/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DataModelCircleLayuot = exports.LAYOUT_ANIMATION_DURATION = void 0;
|
|
4
|
+
var useCircleLayout_1 = require("../../../hooks/useCircleLayout");
|
|
5
|
+
var useFakeCenterNode_1 = require("../../hooks/useFakeCenterNode");
|
|
6
|
+
var useDataModelGraphAppearance_1 = require("../../hooks/useDataModelGraphAppearance");
|
|
7
|
+
exports.LAYOUT_ANIMATION_DURATION = 3000;
|
|
8
|
+
var DataModelCircleLayuot = function (_a) {
|
|
9
|
+
var graph = _a.graph, selectedNode = _a.selectedNode, onNodeClick = _a.onNodeClick, selectedEdge = _a.selectedEdge, onEdgeLabelClick = _a.onEdgeLabelClick;
|
|
10
|
+
(0, useFakeCenterNode_1.useFakeCenterNode)({ graph: graph, timeout: exports.LAYOUT_ANIMATION_DURATION + 100 });
|
|
11
|
+
(0, useCircleLayout_1.useCircleLayout)({ graph: graph, animationDuration: exports.LAYOUT_ANIMATION_DURATION });
|
|
12
|
+
(0, useDataModelGraphAppearance_1.useDataModelGraphAppearance)({
|
|
13
|
+
graph: graph,
|
|
14
|
+
selectedNode: selectedNode,
|
|
15
|
+
selectedEdge: selectedEdge,
|
|
16
|
+
onNodeClick: onNodeClick,
|
|
17
|
+
onEdgeLabelClick: onEdgeLabelClick
|
|
18
|
+
});
|
|
19
|
+
return null;
|
|
20
|
+
};
|
|
21
|
+
exports.DataModelCircleLayuot = DataModelCircleLayuot;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import Sigma from 'sigma/sigma';
|
|
2
|
+
export declare const getBezierCenter: (x1: number, y1: number, x2: number, y2: number, cx1: number, cy1: number, cx2: number, cy2: number) => {
|
|
3
|
+
x: number;
|
|
4
|
+
y: number;
|
|
5
|
+
};
|
|
6
|
+
export declare const getEdgeCenter: (edgeId: string, sourceId: string, targetId: string, sigma: Sigma) => {
|
|
7
|
+
x: any;
|
|
8
|
+
y: any;
|
|
9
|
+
};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getEdgeCenter = exports.getBezierCenter = void 0;
|
|
4
|
+
var selfRelationLoop_1 = require("../../rendering/canvas/selfRelationLoop");
|
|
5
|
+
var getBezierCenter = function (x1, y1, x2, y2, cx1, cy1, cx2, cy2) {
|
|
6
|
+
var t = 0.5;
|
|
7
|
+
var Bt = (1 - t) * (1 - t) * (1 - t);
|
|
8
|
+
var Ct = 3 * ((1 - t) * (1 - t)) * t;
|
|
9
|
+
var Dt = 3 * (1 - t) * (t * t);
|
|
10
|
+
var Et = t * t * t;
|
|
11
|
+
var x = Bt * x1 + Ct * cx1 + Dt * cx2 + Et * x2;
|
|
12
|
+
var y = Bt * y1 + Ct * cy1 + Dt * cy2 + Et * y2;
|
|
13
|
+
return { x: x, y: y };
|
|
14
|
+
};
|
|
15
|
+
exports.getBezierCenter = getBezierCenter;
|
|
16
|
+
var getEdgeCenter = function (edgeId, sourceId, targetId, sigma) {
|
|
17
|
+
var edgeDisplayData = sigma.getEdgeDisplayData(edgeId);
|
|
18
|
+
var sourceDisplayData = sigma.getNodeDisplayData(sourceId);
|
|
19
|
+
var targetDisplayData = sigma.getNodeDisplayData(targetId);
|
|
20
|
+
var sourceCenter = sigma.framedGraphToViewport({
|
|
21
|
+
x: sourceDisplayData.x,
|
|
22
|
+
y: sourceDisplayData.y
|
|
23
|
+
});
|
|
24
|
+
var targetCenter = sigma.framedGraphToViewport({
|
|
25
|
+
x: targetDisplayData.x,
|
|
26
|
+
y: targetDisplayData.y
|
|
27
|
+
});
|
|
28
|
+
var getLoopCenter = function () {
|
|
29
|
+
var _a = (0, selfRelationLoop_1.getSelfLoopControlPoints)(sourceCenter.x, sourceCenter.y, sigma.scaleSize(sourceDisplayData.size) * selfRelationLoop_1.LOOP_SCALE), x1 = _a.x1, y1 = _a.y1, x2 = _a.x2, y2 = _a.y2;
|
|
30
|
+
return (0, exports.getBezierCenter)(sourceCenter.x, sourceCenter.y, sourceCenter.x, sourceCenter.y, x1, y1, x2, y2);
|
|
31
|
+
};
|
|
32
|
+
var loopCenter = edgeDisplayData.loop && getLoopCenter();
|
|
33
|
+
var getEdgeCenter = function (coord) { return sourceCenter[coord] + (targetCenter[coord] - sourceCenter[coord]) / 2; };
|
|
34
|
+
var x = edgeDisplayData.loop ? loopCenter.x : getEdgeCenter('x');
|
|
35
|
+
var y = edgeDisplayData.loop ? loopCenter.y : getEdgeCenter('y');
|
|
36
|
+
return { x: x, y: y };
|
|
37
|
+
};
|
|
38
|
+
exports.getEdgeCenter = getEdgeCenter;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
var edgeLabelHelpers_1 = require("./edgeLabelHelpers");
|
|
4
|
+
describe('getEdgeCenter tests', function () {
|
|
5
|
+
var edgeId = 'edge1';
|
|
6
|
+
var sourceId = 'source1';
|
|
7
|
+
var targetId = 'target1';
|
|
8
|
+
var sigma = {
|
|
9
|
+
getEdgeDisplayData: jest.fn(),
|
|
10
|
+
getNodeDisplayData: jest.fn(),
|
|
11
|
+
framedGraphToViewport: jest.fn(),
|
|
12
|
+
scaleSize: jest.fn(function (x) { return x; })
|
|
13
|
+
};
|
|
14
|
+
afterEach(function () {
|
|
15
|
+
jest.clearAllMocks();
|
|
16
|
+
});
|
|
17
|
+
it('should calculate the regular edge center', function () {
|
|
18
|
+
var edgeDisplayData = {
|
|
19
|
+
loop: false
|
|
20
|
+
};
|
|
21
|
+
var sourceDisplayData = {
|
|
22
|
+
x: 1,
|
|
23
|
+
y: 2,
|
|
24
|
+
size: 10
|
|
25
|
+
};
|
|
26
|
+
var targetDisplayData = {
|
|
27
|
+
x: 3,
|
|
28
|
+
y: 4
|
|
29
|
+
};
|
|
30
|
+
var expectedX = 2;
|
|
31
|
+
var expectedY = 3;
|
|
32
|
+
sigma.getEdgeDisplayData.mockReturnValue(edgeDisplayData);
|
|
33
|
+
sigma.getNodeDisplayData.mockReturnValueOnce(sourceDisplayData);
|
|
34
|
+
sigma.getNodeDisplayData.mockReturnValueOnce(targetDisplayData);
|
|
35
|
+
sigma.framedGraphToViewport.mockImplementation(function (_a) {
|
|
36
|
+
var x = _a.x, y = _a.y;
|
|
37
|
+
return ({ x: x, y: y });
|
|
38
|
+
});
|
|
39
|
+
var result = (0, edgeLabelHelpers_1.getEdgeCenter)(edgeId, sourceId, targetId, sigma);
|
|
40
|
+
expect(result.x).toBe(expectedX);
|
|
41
|
+
expect(result.y).toBe(expectedY);
|
|
42
|
+
expect(sigma.getEdgeDisplayData).toHaveBeenCalledWith(edgeId);
|
|
43
|
+
expect(sigma.getNodeDisplayData).toHaveBeenCalledWith(sourceId);
|
|
44
|
+
expect(sigma.getNodeDisplayData).toHaveBeenCalledWith(targetId);
|
|
45
|
+
expect(sigma.framedGraphToViewport).toHaveBeenCalledWith({ x: 1, y: 2 });
|
|
46
|
+
expect(sigma.framedGraphToViewport).toHaveBeenCalledWith({ x: 3, y: 4 });
|
|
47
|
+
});
|
|
48
|
+
it('should calculate the edge center with loop', function () {
|
|
49
|
+
var edgeDisplayData = {
|
|
50
|
+
loop: true
|
|
51
|
+
};
|
|
52
|
+
var sourceDisplayData = {
|
|
53
|
+
x: 100,
|
|
54
|
+
y: 100,
|
|
55
|
+
size: 10
|
|
56
|
+
};
|
|
57
|
+
var expectedX = 84.25;
|
|
58
|
+
var expectedY = 115.75;
|
|
59
|
+
sigma.getEdgeDisplayData.mockReturnValue(edgeDisplayData);
|
|
60
|
+
sigma.getNodeDisplayData.mockReturnValueOnce(sourceDisplayData);
|
|
61
|
+
sigma.getNodeDisplayData.mockReturnValueOnce(sourceDisplayData);
|
|
62
|
+
sigma.framedGraphToViewport.mockImplementation(function (_a) {
|
|
63
|
+
var x = _a.x, y = _a.y;
|
|
64
|
+
return ({ x: x, y: y });
|
|
65
|
+
});
|
|
66
|
+
var result = (0, edgeLabelHelpers_1.getEdgeCenter)(edgeId, sourceId, sourceId, sigma);
|
|
67
|
+
expect(result.x).toBe(expectedX);
|
|
68
|
+
expect(result.y).toBe(expectedY);
|
|
69
|
+
expect(sigma.getEdgeDisplayData).toHaveBeenCalledWith(edgeId);
|
|
70
|
+
expect(sigma.getNodeDisplayData).toHaveBeenCalledWith(sourceId);
|
|
71
|
+
expect(sigma.framedGraphToViewport).toHaveBeenCalledWith({ x: 100, y: 100 });
|
|
72
|
+
expect(sigma.scaleSize).toHaveBeenCalledWith(sourceDisplayData.size);
|
|
73
|
+
});
|
|
74
|
+
});
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createDefaultGraph = void 0;
|
|
7
|
+
var graphology_1 = __importDefault(require("graphology"));
|
|
8
|
+
var graphDataTypes_1 = require("../../types/graphDataTypes");
|
|
9
|
+
var createDefaultGraph = function () {
|
|
10
|
+
var graph = new graphology_1.default();
|
|
11
|
+
graph.addNode('hcp', {
|
|
12
|
+
nodeType: graphDataTypes_1.DataModelGraphNodeType.entityType,
|
|
13
|
+
label: 'HCP',
|
|
14
|
+
secondaryLabel: '12 attributes',
|
|
15
|
+
image: 'HCP.svg',
|
|
16
|
+
x: 100,
|
|
17
|
+
y: 100
|
|
18
|
+
});
|
|
19
|
+
graph.addNode('hca', {
|
|
20
|
+
nodeType: graphDataTypes_1.DataModelGraphNodeType.entityType,
|
|
21
|
+
label: 'HCA',
|
|
22
|
+
secondaryLabel: '10 attributes',
|
|
23
|
+
image: 'HCA.svg',
|
|
24
|
+
x: 200,
|
|
25
|
+
y: 100
|
|
26
|
+
});
|
|
27
|
+
graph.addNode('gpo', {
|
|
28
|
+
nodeType: graphDataTypes_1.DataModelGraphNodeType.entityType,
|
|
29
|
+
label: 'GPO',
|
|
30
|
+
secondaryLabel: '1 attribute',
|
|
31
|
+
x: 300,
|
|
32
|
+
y: 100
|
|
33
|
+
});
|
|
34
|
+
graph.addNode('prescriptions', {
|
|
35
|
+
nodeType: graphDataTypes_1.DataModelGraphNodeType.interactionType,
|
|
36
|
+
label: 'Prescriptions',
|
|
37
|
+
secondaryLabel: '2 attributes',
|
|
38
|
+
x: 100,
|
|
39
|
+
y: 200
|
|
40
|
+
});
|
|
41
|
+
graph.addEdgeWithKey('hcp->hca', 'hcp', 'hca', {
|
|
42
|
+
label: '1'
|
|
43
|
+
});
|
|
44
|
+
graph.addEdgeWithKey('hca->gpo', 'hca', 'gpo', {
|
|
45
|
+
label: '2'
|
|
46
|
+
});
|
|
47
|
+
graph.addEdgeWithKey('hcp->prescriptions', 'hcp', 'prescriptions', {
|
|
48
|
+
type: 'dashed'
|
|
49
|
+
});
|
|
50
|
+
return graph;
|
|
51
|
+
};
|
|
52
|
+
exports.createDefaultGraph = createDefaultGraph;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import Graph from 'graphology';
|
|
2
|
+
export declare const EDGE_COLOR = "rgba(130, 130, 130, 1)";
|
|
3
|
+
export declare const DASHED_EDGE_COLOR = "rgba(189, 189, 189, 1)";
|
|
4
|
+
export declare const INACTIVE_EDGE_COLOR = "rgba(224, 224, 224, 1)";
|
|
5
|
+
export declare const SELECTED_EDGE_COLOR = "rgba(79, 79, 79, 1)";
|
|
6
|
+
export declare const RELATED_EDGE_COLOR = "rgba(130, 130, 130, 1)";
|
|
7
|
+
export declare const RELATED_DASHED_EDGE_COLOR = "rgba(79, 79, 79, 1)";
|
|
8
|
+
export declare const INACTIVE_LABEL_COLOR = "rgba(0, 0, 0, 0.38)";
|
|
9
|
+
type Props = {
|
|
10
|
+
graph: Graph;
|
|
11
|
+
selectedNode: string;
|
|
12
|
+
selectedEdge: string;
|
|
13
|
+
onNodeClick: (node: string) => void;
|
|
14
|
+
onEdgeLabelClick: (edgeId: string, event: MouseEvent) => void;
|
|
15
|
+
};
|
|
16
|
+
export declare const useDataModelGraphAppearance: ({ graph, selectedNode, selectedEdge, onNodeClick, onEdgeLabelClick }: Props) => void;
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
14
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
15
|
+
if (ar || !(i in from)) {
|
|
16
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
17
|
+
ar[i] = from[i];
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
|
21
|
+
};
|
|
22
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
23
|
+
exports.useDataModelGraphAppearance = exports.INACTIVE_LABEL_COLOR = exports.RELATED_DASHED_EDGE_COLOR = exports.RELATED_EDGE_COLOR = exports.SELECTED_EDGE_COLOR = exports.INACTIVE_EDGE_COLOR = exports.DASHED_EDGE_COLOR = exports.EDGE_COLOR = void 0;
|
|
24
|
+
var react_1 = require("react");
|
|
25
|
+
var core_1 = require("@react-sigma/core");
|
|
26
|
+
var core_2 = require("@react-sigma/core");
|
|
27
|
+
var mdm_sdk_1 = require("@reltio/mdm-sdk");
|
|
28
|
+
var graphDataTypes_1 = require("../../types/graphDataTypes");
|
|
29
|
+
var useLoopRenderer_1 = require("../../hooks/useLoopRenderer");
|
|
30
|
+
var useEdgeLabelsRenderer_1 = require("./useEdgeLabelsRenderer");
|
|
31
|
+
var useSelectedNodeRenderer_1 = require("./useSelectedNodeRenderer");
|
|
32
|
+
var interaction_inline_svg_1 = require("../icons/interaction.inline.svg");
|
|
33
|
+
var DEFAULT_NODE_STYLE = {
|
|
34
|
+
type: 'image',
|
|
35
|
+
size: 28,
|
|
36
|
+
color: 'rgba(55, 71, 79, 1)'
|
|
37
|
+
};
|
|
38
|
+
var DEFAULT_EDGE_STYLE = {
|
|
39
|
+
size: 2
|
|
40
|
+
};
|
|
41
|
+
exports.EDGE_COLOR = 'rgba(130, 130, 130, 1)';
|
|
42
|
+
exports.DASHED_EDGE_COLOR = 'rgba(189, 189, 189, 1)';
|
|
43
|
+
exports.INACTIVE_EDGE_COLOR = 'rgba(224, 224, 224, 1)';
|
|
44
|
+
exports.SELECTED_EDGE_COLOR = 'rgba(79, 79, 79, 1)';
|
|
45
|
+
exports.RELATED_EDGE_COLOR = 'rgba(130, 130, 130, 1)';
|
|
46
|
+
exports.RELATED_DASHED_EDGE_COLOR = 'rgba(79, 79, 79, 1)';
|
|
47
|
+
exports.INACTIVE_LABEL_COLOR = 'rgba(0, 0, 0, 0.38)';
|
|
48
|
+
var useDataModelGraphAppearance = function (_a) {
|
|
49
|
+
var graph = _a.graph, selectedNode = _a.selectedNode, selectedEdge = _a.selectedEdge, onNodeClick = _a.onNodeClick, onEdgeLabelClick = _a.onEdgeLabelClick;
|
|
50
|
+
var sigma = (0, core_2.useSigma)();
|
|
51
|
+
var container = (0, core_1.useSigmaContext)().container;
|
|
52
|
+
var _b = (0, react_1.useState)(null), hoveredNode = _b[0], setHoveredNode = _b[1];
|
|
53
|
+
var registerEvents = (0, core_2.useRegisterEvents)();
|
|
54
|
+
var setSettings = (0, core_2.useSetSettings)();
|
|
55
|
+
(0, useLoopRenderer_1.useLoopRenderer)(graph);
|
|
56
|
+
var hoveredEdge = (0, useEdgeLabelsRenderer_1.useEdgeLabelsRenderer)({ graph: graph, onEdgeLabelClick: onEdgeLabelClick });
|
|
57
|
+
(0, useSelectedNodeRenderer_1.useSelectedNodeRenderer)(graph);
|
|
58
|
+
(0, react_1.useEffect)(function () {
|
|
59
|
+
registerEvents({
|
|
60
|
+
enterNode: function (_a) {
|
|
61
|
+
var node = _a.node;
|
|
62
|
+
setHoveredNode(node);
|
|
63
|
+
},
|
|
64
|
+
leaveNode: function () {
|
|
65
|
+
setHoveredNode(null);
|
|
66
|
+
},
|
|
67
|
+
clickNode: function (_a) {
|
|
68
|
+
var node = _a.node;
|
|
69
|
+
onNodeClick(node);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
}, [sigma, registerEvents, onNodeClick]);
|
|
73
|
+
(0, react_1.useEffect)(function () {
|
|
74
|
+
container.style.cursor = hoveredNode || hoveredEdge ? 'pointer' : 'default';
|
|
75
|
+
}, [container, hoveredNode, hoveredEdge]);
|
|
76
|
+
(0, react_1.useEffect)(function () {
|
|
77
|
+
var graph = sigma.getGraph();
|
|
78
|
+
var selectedNodeNeighbours;
|
|
79
|
+
try {
|
|
80
|
+
selectedNodeNeighbours = graph.neighbors(selectedNode);
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
//do nothing
|
|
84
|
+
}
|
|
85
|
+
setSettings({
|
|
86
|
+
nodeReducer: function (node, data) {
|
|
87
|
+
var isSelectedNode = node === selectedNode;
|
|
88
|
+
var isInactiveNode = (selectedNode &&
|
|
89
|
+
selectedNodeNeighbours &&
|
|
90
|
+
__spreadArray(__spreadArray([], selectedNodeNeighbours, true), [selectedNode], false).every(function (n) { return n !== node; })) ||
|
|
91
|
+
(selectedEdge && !graph.hasExtremity(selectedEdge, node)) ||
|
|
92
|
+
false;
|
|
93
|
+
var newData = __assign(__assign({}, DEFAULT_NODE_STYLE), data);
|
|
94
|
+
if (data.nodeType === graphDataTypes_1.DataModelGraphNodeType.interactionType) {
|
|
95
|
+
newData.hasBorder = true;
|
|
96
|
+
newData.image = (0, mdm_sdk_1.svg2Url)(interaction_inline_svg_1.interactionIcon);
|
|
97
|
+
}
|
|
98
|
+
if (isInactiveNode) {
|
|
99
|
+
newData.inactive = true;
|
|
100
|
+
newData.labelColor = exports.INACTIVE_LABEL_COLOR;
|
|
101
|
+
newData.secondaryLabelColor = exports.INACTIVE_LABEL_COLOR;
|
|
102
|
+
}
|
|
103
|
+
if (isSelectedNode) {
|
|
104
|
+
newData.selected = true;
|
|
105
|
+
newData.zIndex = 100;
|
|
106
|
+
}
|
|
107
|
+
if (hoveredNode !== node && !isSelectedNode) {
|
|
108
|
+
delete newData.secondaryLabel;
|
|
109
|
+
}
|
|
110
|
+
return newData;
|
|
111
|
+
},
|
|
112
|
+
edgeReducer: function (edge, data) {
|
|
113
|
+
var isDashedLine = data.type === 'dashed';
|
|
114
|
+
var newData = __assign(__assign({}, DEFAULT_EDGE_STYLE), data);
|
|
115
|
+
if (selectedEdge === edge) {
|
|
116
|
+
newData.selected = true;
|
|
117
|
+
}
|
|
118
|
+
if (selectedNode) {
|
|
119
|
+
if (graph.hasExtremity(edge, selectedNode)) {
|
|
120
|
+
newData.color = isDashedLine ? exports.RELATED_DASHED_EDGE_COLOR : exports.RELATED_EDGE_COLOR;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
newData.color = exports.INACTIVE_EDGE_COLOR;
|
|
124
|
+
newData.labelColor = exports.INACTIVE_LABEL_COLOR;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else if (selectedEdge) {
|
|
128
|
+
newData.color = edge === selectedEdge ? exports.SELECTED_EDGE_COLOR : exports.INACTIVE_EDGE_COLOR;
|
|
129
|
+
newData.labelColor = edge === selectedEdge ? undefined : exports.INACTIVE_LABEL_COLOR;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
newData.color = isDashedLine ? exports.DASHED_EDGE_COLOR : exports.EDGE_COLOR;
|
|
133
|
+
}
|
|
134
|
+
return newData;
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}, [sigma, setSettings, selectedNode, selectedEdge, hoveredEdge, hoveredNode]);
|
|
138
|
+
};
|
|
139
|
+
exports.useDataModelGraphAppearance = useDataModelGraphAppearance;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|