@reltio/components 1.4.1844 → 1.4.1846

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.
Files changed (305) hide show
  1. package/cjs/EmptyState/EmptyState.d.ts +1 -0
  2. package/cjs/EmptyState/EmptyState.js +3 -1
  3. package/cjs/features/graph/DataModelGraph/DataModelGraph.d.ts +12 -0
  4. package/cjs/features/graph/DataModelGraph/DataModelGraph.js +28 -0
  5. package/cjs/features/graph/DataModelGraph/DataModelGraph.test.d.ts +1 -0
  6. package/cjs/features/graph/DataModelGraph/DataModelGraph.test.js +63 -0
  7. package/cjs/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.d.ts +11 -0
  8. package/cjs/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.js +21 -0
  9. package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.d.ts +9 -0
  10. package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.js +38 -0
  11. package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.d.ts +1 -0
  12. package/cjs/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.js +74 -0
  13. package/cjs/features/graph/DataModelGraph/hooks/defaultGraph.test-data.d.ts +2 -0
  14. package/cjs/features/graph/DataModelGraph/hooks/defaultGraph.test-data.js +52 -0
  15. package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.d.ts +17 -0
  16. package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.js +139 -0
  17. package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.d.ts +1 -0
  18. package/cjs/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.js +192 -0
  19. package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.d.ts +10 -0
  20. package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.js +171 -0
  21. package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.d.ts +1 -0
  22. package/cjs/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.js +176 -0
  23. package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.d.ts +8 -0
  24. package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.js +36 -0
  25. package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.d.ts +1 -0
  26. package/cjs/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.js +37 -0
  27. package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.d.ts +2 -0
  28. package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.js +41 -0
  29. package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.d.ts +1 -0
  30. package/cjs/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.js +63 -0
  31. package/cjs/features/graph/DataModelGraph/icons/interaction.inline.svg.d.ts +1 -0
  32. package/cjs/features/graph/DataModelGraph/icons/interaction.inline.svg.js +4 -0
  33. package/cjs/features/graph/DataModelGraph/index.d.ts +1 -0
  34. package/cjs/features/graph/DataModelGraph/index.js +5 -0
  35. package/cjs/features/graph/DataModelGraph/styles.d.ts +1 -0
  36. package/cjs/features/graph/DataModelGraph/styles.js +26 -0
  37. package/cjs/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.d.ts +6 -0
  38. package/cjs/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.js +15 -0
  39. package/cjs/features/graph/SigmaCustomRenderersContainer/index.d.ts +1 -0
  40. package/cjs/features/graph/SigmaCustomRenderersContainer/index.js +5 -0
  41. package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.d.ts +9 -0
  42. package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.js +86 -0
  43. package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.d.ts +1 -0
  44. package/cjs/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.js +26 -0
  45. package/cjs/features/graph/SigmaGraphContainer/index.d.ts +1 -0
  46. package/cjs/features/graph/SigmaGraphContainer/index.js +5 -0
  47. package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.d.ts +1 -0
  48. package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.js +40 -0
  49. package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.d.ts +1 -0
  50. package/cjs/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.js +37 -0
  51. package/cjs/features/graph/SigmaGraphResizer/index.d.ts +1 -0
  52. package/cjs/features/graph/SigmaGraphResizer/index.js +5 -0
  53. package/cjs/features/graph/ZoomSlider/ZoomSlider.d.ts +7 -0
  54. package/cjs/features/graph/ZoomSlider/ZoomSlider.js +113 -0
  55. package/cjs/features/graph/ZoomSlider/ZoomSlider.test.d.ts +1 -0
  56. package/cjs/features/graph/ZoomSlider/ZoomSlider.test.js +83 -0
  57. package/cjs/features/graph/ZoomSlider/index.d.ts +1 -0
  58. package/cjs/features/graph/ZoomSlider/index.js +5 -0
  59. package/cjs/features/graph/ZoomSlider/styles.d.ts +1 -0
  60. package/cjs/features/graph/ZoomSlider/styles.js +63 -0
  61. package/cjs/features/graph/contexts/SigmaCustomRenderersContext.d.ts +9 -0
  62. package/cjs/features/graph/contexts/SigmaCustomRenderersContext.js +15 -0
  63. package/cjs/features/graph/hooks/useAnimatedGraphLayout.d.ts +13 -0
  64. package/cjs/features/graph/hooks/useAnimatedGraphLayout.js +35 -0
  65. package/cjs/features/graph/hooks/useCircleLayout.d.ts +9 -0
  66. package/cjs/features/graph/hooks/useCircleLayout.js +50 -0
  67. package/cjs/features/graph/hooks/useLoopRenderer.d.ts +5 -0
  68. package/cjs/features/graph/hooks/useLoopRenderer.js +47 -0
  69. package/cjs/features/graph/hooks/useLoopRenderer.test.d.ts +1 -0
  70. package/cjs/features/graph/hooks/useLoopRenderer.test.js +221 -0
  71. package/cjs/features/graph/hooks/useSigmaCustomRenderers.d.ts +7 -0
  72. package/cjs/features/graph/hooks/useSigmaCustomRenderers.js +95 -0
  73. package/cjs/features/graph/hooks/useSigmaCustomRenderers.test.d.ts +1 -0
  74. package/cjs/features/graph/hooks/useSigmaCustomRenderers.test.js +200 -0
  75. package/cjs/features/graph/index.d.ts +16 -0
  76. package/cjs/features/graph/index.js +34 -0
  77. package/cjs/features/graph/rendering/canvas/hover.d.ts +2 -0
  78. package/cjs/features/graph/rendering/canvas/hover.js +10 -0
  79. package/cjs/features/graph/rendering/canvas/hover.spec.d.ts +1 -0
  80. package/cjs/features/graph/rendering/canvas/hover.spec.js +26 -0
  81. package/cjs/features/graph/rendering/canvas/label.d.ts +7 -0
  82. package/cjs/features/graph/rendering/canvas/label.js +32 -0
  83. package/cjs/features/graph/rendering/canvas/label.spec.d.ts +1 -0
  84. package/cjs/features/graph/rendering/canvas/label.spec.js +81 -0
  85. package/cjs/features/graph/rendering/canvas/labelBackground.d.ts +9 -0
  86. package/cjs/features/graph/rendering/canvas/labelBackground.js +37 -0
  87. package/cjs/features/graph/rendering/canvas/labelBackground.spec.d.ts +1 -0
  88. package/cjs/features/graph/rendering/canvas/labelBackground.spec.js +92 -0
  89. package/cjs/features/graph/rendering/canvas/nodeArc.d.ts +10 -0
  90. package/cjs/features/graph/rendering/canvas/nodeArc.js +33 -0
  91. package/cjs/features/graph/rendering/canvas/selfRelationLoop.d.ts +11 -0
  92. package/cjs/features/graph/rendering/canvas/selfRelationLoop.js +73 -0
  93. package/cjs/features/graph/rendering/canvas/selfRelationLoop.spec.d.ts +1 -0
  94. package/cjs/features/graph/rendering/canvas/selfRelationLoop.spec.js +92 -0
  95. package/cjs/features/graph/rendering/canvas/tooltip.d.ts +2 -0
  96. package/cjs/features/graph/rendering/canvas/tooltip.js +28 -0
  97. package/cjs/features/graph/rendering/canvas/tooltip.spec.d.ts +1 -0
  98. package/cjs/features/graph/rendering/canvas/tooltip.spec.js +32 -0
  99. package/cjs/features/graph/rendering/canvas/utils.d.ts +4 -0
  100. package/cjs/features/graph/rendering/canvas/utils.js +10 -0
  101. package/cjs/features/graph/rendering/canvas/utils.spec.d.ts +1 -0
  102. package/cjs/features/graph/rendering/canvas/utils.spec.js +22 -0
  103. package/cjs/features/graph/rendering/icons/no_photo.inline.svg.d.ts +1 -0
  104. package/cjs/features/graph/rendering/icons/no_photo.inline.svg.js +4 -0
  105. package/cjs/features/graph/rendering/webgl/edge.arrowHead.d.ts +8 -0
  106. package/cjs/features/graph/rendering/webgl/edge.arrowHead.js +84 -0
  107. package/cjs/features/graph/rendering/webgl/edge.clamped.d.ts +29 -0
  108. package/cjs/features/graph/rendering/webgl/edge.clamped.js +176 -0
  109. package/cjs/features/graph/rendering/webgl/edge.dashed.d.ts +23 -0
  110. package/cjs/features/graph/rendering/webgl/edge.dashed.js +162 -0
  111. package/cjs/features/graph/rendering/webgl/edge.reversedArrowHead.d.ts +5 -0
  112. package/cjs/features/graph/rendering/webgl/edge.reversedArrowHead.js +32 -0
  113. package/cjs/features/graph/rendering/webgl/helpers/imageHelper.d.ts +17 -0
  114. package/cjs/features/graph/rendering/webgl/helpers/imageHelper.js +9 -0
  115. package/cjs/features/graph/rendering/webgl/helpers/imageHelper.spec.d.ts +1 -0
  116. package/cjs/features/graph/rendering/webgl/helpers/imageHelper.spec.js +29 -0
  117. package/cjs/features/graph/rendering/webgl/image.d.ts +17 -0
  118. package/cjs/features/graph/rendering/webgl/image.js +115 -0
  119. package/cjs/features/graph/rendering/webgl/node.border.d.ts +11 -0
  120. package/cjs/features/graph/rendering/webgl/node.border.js +79 -0
  121. package/cjs/features/graph/rendering/webgl/node.dashed.border.d.ts +11 -0
  122. package/cjs/features/graph/rendering/webgl/node.dashed.border.js +77 -0
  123. package/cjs/features/graph/rendering/webgl/node.image.d.ts +18 -0
  124. package/cjs/features/graph/rendering/webgl/node.image.js +147 -0
  125. package/cjs/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.d.ts +1 -0
  126. package/cjs/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.js +8 -0
  127. package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.d.ts +1 -0
  128. package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.js +8 -0
  129. package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.d.ts +1 -0
  130. package/cjs/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.js +8 -0
  131. package/cjs/features/graph/rendering/webgl/shaders/node.border.frag.glsl.d.ts +1 -0
  132. package/cjs/features/graph/rendering/webgl/shaders/node.border.frag.glsl.js +9 -0
  133. package/cjs/features/graph/rendering/webgl/shaders/node.border.vert.glsl.d.ts +1 -0
  134. package/cjs/features/graph/rendering/webgl/shaders/node.border.vert.glsl.js +8 -0
  135. package/cjs/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.d.ts +1 -0
  136. package/cjs/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.js +8 -0
  137. package/cjs/features/graph/rendering/webgl/shaders/node.image.frag.glsl.d.ts +1 -0
  138. package/cjs/features/graph/rendering/webgl/shaders/node.image.frag.glsl.js +5 -0
  139. package/cjs/features/graph/rendering/webgl/shaders/node.image.vert.glsl.d.ts +1 -0
  140. package/cjs/features/graph/rendering/webgl/shaders/node.image.vert.glsl.js +8 -0
  141. package/cjs/features/graph/rendering/webgl/shaders/utils.d.ts +1 -0
  142. package/cjs/features/graph/rendering/webgl/shaders/utils.js +4 -0
  143. package/cjs/features/graph/types/graphDataTypes.d.ts +51 -0
  144. package/cjs/features/graph/types/graphDataTypes.js +8 -0
  145. package/cjs/features/graph/types/sigmaCustomRenderersTypes.d.ts +11 -0
  146. package/cjs/features/graph/types/sigmaCustomRenderersTypes.js +2 -0
  147. package/cjs/icons/EmptyLoading.d.ts +3 -0
  148. package/cjs/icons/EmptyLoading.js +150 -0
  149. package/cjs/icons/index.d.ts +1 -0
  150. package/cjs/icons/index.js +4 -2
  151. package/cjs/index.d.ts +1 -0
  152. package/cjs/index.js +2 -0
  153. package/esm/EmptyState/EmptyState.d.ts +1 -0
  154. package/esm/EmptyState/EmptyState.js +3 -1
  155. package/esm/features/graph/DataModelGraph/DataModelGraph.d.ts +12 -0
  156. package/esm/features/graph/DataModelGraph/DataModelGraph.js +21 -0
  157. package/esm/features/graph/DataModelGraph/DataModelGraph.test.d.ts +1 -0
  158. package/esm/features/graph/DataModelGraph/DataModelGraph.test.js +58 -0
  159. package/esm/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.d.ts +11 -0
  160. package/esm/features/graph/DataModelGraph/components/DataModelCircleLayout/DataModelCircleLayuot.js +17 -0
  161. package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.d.ts +9 -0
  162. package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.js +33 -0
  163. package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.d.ts +1 -0
  164. package/esm/features/graph/DataModelGraph/helpers/edgeLabelHelpers.test.js +72 -0
  165. package/esm/features/graph/DataModelGraph/hooks/defaultGraph.test-data.d.ts +2 -0
  166. package/esm/features/graph/DataModelGraph/hooks/defaultGraph.test-data.js +45 -0
  167. package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.d.ts +17 -0
  168. package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.js +135 -0
  169. package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.d.ts +1 -0
  170. package/esm/features/graph/DataModelGraph/hooks/useDataModelGraphAppearance.test.js +190 -0
  171. package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.d.ts +10 -0
  172. package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.js +167 -0
  173. package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.d.ts +1 -0
  174. package/esm/features/graph/DataModelGraph/hooks/useEdgeLabelsRenderer.test.js +174 -0
  175. package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.d.ts +8 -0
  176. package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.js +32 -0
  177. package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.d.ts +1 -0
  178. package/esm/features/graph/DataModelGraph/hooks/useFakeCenterNode.test.js +35 -0
  179. package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.d.ts +2 -0
  180. package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.js +37 -0
  181. package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.d.ts +1 -0
  182. package/esm/features/graph/DataModelGraph/hooks/useSelectedNodeRenderer.test.js +61 -0
  183. package/esm/features/graph/DataModelGraph/icons/interaction.inline.svg.d.ts +1 -0
  184. package/esm/features/graph/DataModelGraph/icons/interaction.inline.svg.js +1 -0
  185. package/esm/features/graph/DataModelGraph/index.d.ts +1 -0
  186. package/esm/features/graph/DataModelGraph/index.js +1 -0
  187. package/esm/features/graph/DataModelGraph/styles.d.ts +1 -0
  188. package/esm/features/graph/DataModelGraph/styles.js +23 -0
  189. package/esm/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.d.ts +6 -0
  190. package/esm/features/graph/SigmaCustomRenderersContainer/SigmaCustomRenderersContainer.js +8 -0
  191. package/esm/features/graph/SigmaCustomRenderersContainer/index.d.ts +1 -0
  192. package/esm/features/graph/SigmaCustomRenderersContainer/index.js +1 -0
  193. package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.d.ts +9 -0
  194. package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.js +56 -0
  195. package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.d.ts +1 -0
  196. package/esm/features/graph/SigmaGraphContainer/SigmaGraphContainer.test.js +21 -0
  197. package/esm/features/graph/SigmaGraphContainer/index.d.ts +1 -0
  198. package/esm/features/graph/SigmaGraphContainer/index.js +1 -0
  199. package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.d.ts +1 -0
  200. package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.js +10 -0
  201. package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.d.ts +1 -0
  202. package/esm/features/graph/SigmaGraphResizer/SigmaGraphResizer.test.js +32 -0
  203. package/esm/features/graph/SigmaGraphResizer/index.d.ts +1 -0
  204. package/esm/features/graph/SigmaGraphResizer/index.js +1 -0
  205. package/esm/features/graph/ZoomSlider/ZoomSlider.d.ts +7 -0
  206. package/esm/features/graph/ZoomSlider/ZoomSlider.js +83 -0
  207. package/esm/features/graph/ZoomSlider/ZoomSlider.test.d.ts +1 -0
  208. package/esm/features/graph/ZoomSlider/ZoomSlider.test.js +78 -0
  209. package/esm/features/graph/ZoomSlider/index.d.ts +1 -0
  210. package/esm/features/graph/ZoomSlider/index.js +1 -0
  211. package/esm/features/graph/ZoomSlider/styles.d.ts +1 -0
  212. package/esm/features/graph/ZoomSlider/styles.js +60 -0
  213. package/esm/features/graph/contexts/SigmaCustomRenderersContext.d.ts +9 -0
  214. package/esm/features/graph/contexts/SigmaCustomRenderersContext.js +11 -0
  215. package/esm/features/graph/hooks/useAnimatedGraphLayout.d.ts +13 -0
  216. package/esm/features/graph/hooks/useAnimatedGraphLayout.js +31 -0
  217. package/esm/features/graph/hooks/useCircleLayout.d.ts +9 -0
  218. package/esm/features/graph/hooks/useCircleLayout.js +43 -0
  219. package/esm/features/graph/hooks/useLoopRenderer.d.ts +5 -0
  220. package/esm/features/graph/hooks/useLoopRenderer.js +43 -0
  221. package/esm/features/graph/hooks/useLoopRenderer.test.d.ts +1 -0
  222. package/esm/features/graph/hooks/useLoopRenderer.test.js +219 -0
  223. package/esm/features/graph/hooks/useSigmaCustomRenderers.d.ts +7 -0
  224. package/esm/features/graph/hooks/useSigmaCustomRenderers.js +91 -0
  225. package/esm/features/graph/hooks/useSigmaCustomRenderers.test.d.ts +1 -0
  226. package/esm/features/graph/hooks/useSigmaCustomRenderers.test.js +198 -0
  227. package/esm/features/graph/index.d.ts +16 -0
  228. package/esm/features/graph/index.js +17 -0
  229. package/esm/features/graph/rendering/canvas/hover.d.ts +2 -0
  230. package/esm/features/graph/rendering/canvas/hover.js +6 -0
  231. package/esm/features/graph/rendering/canvas/hover.spec.d.ts +1 -0
  232. package/esm/features/graph/rendering/canvas/hover.spec.js +24 -0
  233. package/esm/features/graph/rendering/canvas/label.d.ts +7 -0
  234. package/esm/features/graph/rendering/canvas/label.js +28 -0
  235. package/esm/features/graph/rendering/canvas/label.spec.d.ts +1 -0
  236. package/esm/features/graph/rendering/canvas/label.spec.js +79 -0
  237. package/esm/features/graph/rendering/canvas/labelBackground.d.ts +9 -0
  238. package/esm/features/graph/rendering/canvas/labelBackground.js +33 -0
  239. package/esm/features/graph/rendering/canvas/labelBackground.spec.d.ts +1 -0
  240. package/esm/features/graph/rendering/canvas/labelBackground.spec.js +90 -0
  241. package/esm/features/graph/rendering/canvas/nodeArc.d.ts +10 -0
  242. package/esm/features/graph/rendering/canvas/nodeArc.js +27 -0
  243. package/esm/features/graph/rendering/canvas/selfRelationLoop.d.ts +11 -0
  244. package/esm/features/graph/rendering/canvas/selfRelationLoop.js +69 -0
  245. package/esm/features/graph/rendering/canvas/selfRelationLoop.spec.d.ts +1 -0
  246. package/esm/features/graph/rendering/canvas/selfRelationLoop.spec.js +90 -0
  247. package/esm/features/graph/rendering/canvas/tooltip.d.ts +2 -0
  248. package/esm/features/graph/rendering/canvas/tooltip.js +25 -0
  249. package/esm/features/graph/rendering/canvas/tooltip.spec.d.ts +1 -0
  250. package/esm/features/graph/rendering/canvas/tooltip.spec.js +30 -0
  251. package/esm/features/graph/rendering/canvas/utils.d.ts +4 -0
  252. package/esm/features/graph/rendering/canvas/utils.js +6 -0
  253. package/esm/features/graph/rendering/canvas/utils.spec.d.ts +1 -0
  254. package/esm/features/graph/rendering/canvas/utils.spec.js +20 -0
  255. package/esm/features/graph/rendering/icons/no_photo.inline.svg.d.ts +1 -0
  256. package/esm/features/graph/rendering/icons/no_photo.inline.svg.js +1 -0
  257. package/esm/features/graph/rendering/webgl/edge.arrowHead.d.ts +8 -0
  258. package/esm/features/graph/rendering/webgl/edge.arrowHead.js +79 -0
  259. package/esm/features/graph/rendering/webgl/edge.clamped.d.ts +29 -0
  260. package/esm/features/graph/rendering/webgl/edge.clamped.js +171 -0
  261. package/esm/features/graph/rendering/webgl/edge.dashed.d.ts +23 -0
  262. package/esm/features/graph/rendering/webgl/edge.dashed.js +160 -0
  263. package/esm/features/graph/rendering/webgl/edge.reversedArrowHead.d.ts +5 -0
  264. package/esm/features/graph/rendering/webgl/edge.reversedArrowHead.js +27 -0
  265. package/esm/features/graph/rendering/webgl/helpers/imageHelper.d.ts +17 -0
  266. package/esm/features/graph/rendering/webgl/helpers/imageHelper.js +5 -0
  267. package/esm/features/graph/rendering/webgl/helpers/imageHelper.spec.d.ts +1 -0
  268. package/esm/features/graph/rendering/webgl/helpers/imageHelper.spec.js +27 -0
  269. package/esm/features/graph/rendering/webgl/image.d.ts +17 -0
  270. package/esm/features/graph/rendering/webgl/image.js +112 -0
  271. package/esm/features/graph/rendering/webgl/node.border.d.ts +11 -0
  272. package/esm/features/graph/rendering/webgl/node.border.js +76 -0
  273. package/esm/features/graph/rendering/webgl/node.dashed.border.d.ts +11 -0
  274. package/esm/features/graph/rendering/webgl/node.dashed.border.js +74 -0
  275. package/esm/features/graph/rendering/webgl/node.image.d.ts +18 -0
  276. package/esm/features/graph/rendering/webgl/node.image.js +144 -0
  277. package/esm/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.d.ts +1 -0
  278. package/esm/features/graph/rendering/webgl/shaders/edge.clamped.vert.glsl.js +5 -0
  279. package/esm/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.d.ts +1 -0
  280. package/esm/features/graph/rendering/webgl/shaders/edge.dashed.frag.glsl.js +5 -0
  281. package/esm/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.d.ts +1 -0
  282. package/esm/features/graph/rendering/webgl/shaders/edge.dashed.vert.glsl.js +5 -0
  283. package/esm/features/graph/rendering/webgl/shaders/node.border.frag.glsl.d.ts +1 -0
  284. package/esm/features/graph/rendering/webgl/shaders/node.border.frag.glsl.js +6 -0
  285. package/esm/features/graph/rendering/webgl/shaders/node.border.vert.glsl.d.ts +1 -0
  286. package/esm/features/graph/rendering/webgl/shaders/node.border.vert.glsl.js +5 -0
  287. package/esm/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.d.ts +1 -0
  288. package/esm/features/graph/rendering/webgl/shaders/node.dashed.border.frag.glsl.js +5 -0
  289. package/esm/features/graph/rendering/webgl/shaders/node.image.frag.glsl.d.ts +1 -0
  290. package/esm/features/graph/rendering/webgl/shaders/node.image.frag.glsl.js +2 -0
  291. package/esm/features/graph/rendering/webgl/shaders/node.image.vert.glsl.d.ts +1 -0
  292. package/esm/features/graph/rendering/webgl/shaders/node.image.vert.glsl.js +5 -0
  293. package/esm/features/graph/rendering/webgl/shaders/utils.d.ts +1 -0
  294. package/esm/features/graph/rendering/webgl/shaders/utils.js +1 -0
  295. package/esm/features/graph/types/graphDataTypes.d.ts +51 -0
  296. package/esm/features/graph/types/graphDataTypes.js +5 -0
  297. package/esm/features/graph/types/sigmaCustomRenderersTypes.d.ts +11 -0
  298. package/esm/features/graph/types/sigmaCustomRenderersTypes.js +1 -0
  299. package/esm/icons/EmptyLoading.d.ts +3 -0
  300. package/esm/icons/EmptyLoading.js +145 -0
  301. package/esm/icons/index.d.ts +1 -0
  302. package/esm/icons/index.js +1 -0
  303. package/esm/index.d.ts +1 -0
  304. package/esm/index.js +2 -0
  305. package/package.json +7 -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,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 {};
@@ -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,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,2 @@
1
+ import Graph from 'graphology';
2
+ export declare const createDefaultGraph: () => Graph<import("graphology-types").Attributes, import("graphology-types").Attributes, import("graphology-types").Attributes>;
@@ -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;