summaryrefslogtreecommitdiff
path: root/app/components/graph/graph.tsx
blob: 934901fea351c6ba3aeef1b3c2e68e16a2ae1e45 (about) (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import * as React from "react"
import { useState, useEffect, useRef } from "react"
import { StyleProp, TextStyle, View, ViewStyle } from "react-native"
import { observer } from "mobx-react-lite"
import { color, typography } from "../../theme"
import { Text } from "../"
import { flatten } from "ramda"

//import data from "../../data/miserables.json"
//import genRandomTree from "../../data/randomdata";
import rando from "../../data/rando.json"

import { ForceGraph2D, ForceGraph3D, ForceGraphVR, ForceGraphAR } from 'react-force-graph';
import * as d3 from "d3-force";

const CONTAINER: ViewStyle = {
  justifyContent: "center",
}

const TEXT: TextStyle = {
  fontFamily: typography.primary,
  fontSize: 14,
  color: color.primary,
}

export interface GraphProps {
  /**
   * An optional style override useful for padding & margin.
   */
  style?: StyleProp<ViewStyle>
    physics
    gData
}

/**
 * Describe your component here
 */
export const Graph = observer(function Graph(props: GraphProps) {
  const { style, physics, gData } = props
  const styles = flatten([CONTAINER, style])

    const fgRef= useRef();


    const GROUPS: number =12;
    //const gData = genRandomTree(200);

    //const [charge, setCharge] = useState(-30);
    //const [link, setLink] = useState(-30);

    useEffect(()=> {
      const fg = fgRef.current;

        //fg.d3Force('center').strength(0.05);
        fg.d3Force('link').strength(physics.linkStrength);
        fg.d3Force('link').iterations(physics.linkIts);
        physics.collision ? fg.d3Force('collide', d3.forceCollide().radius(20)) : fg.d3Force('collide',null);
        fg.d3Force('charge').strength(physics.charge);
  });

    return (
    <View>
    <ForceGraph2D
      ref={fgRef}
      graphData={rando}
      nodeAutoColorBy={d => d.id%GROUPS}
      linkAutoColorBy={d => rando.nodes[d.source].id%GROUPS}
      linkColor={"#ffffff"}
      linkWidth={2}
      //d3VelocityDecay={visco}
      />
    </View>
  )
})