1.1.4 • Published 3 years ago
@devjaewoo/react-svg-connector v1.1.4
react-svg-connector
React component to draw svg connectors to connect any React components
Forked from tudatn's react-svg-connector: fixed connection position bug
Installation
npm install @devjaewoo/react-svg-connector
or
yarn add @devjaewoo/react-svg-connectorUsage
Component props:
- el1: first React component
- el2: second React component
- shape (optional):'s' | 'narrow-s' | 'line'
- direction (optional):'r2l' | 'l2l' | 'r2r' | 'l2r' |'b2t' | 'b2b' | 't2b' | 't2t'
- roundCorner (optional):true | false
- grid (optional): number of grid, used to calculatestep = distanceX(Y) / grid
- minStep (optional): min value for thestep
- stem(optional): min distance from the start point
- endArrow(optional):true | false
- startArrow(optional):true | false
- arrowSize(optional): arrow size
All svg path props are available. Please run a full example to see all available props.
S shape
narrow-s shape
import Connector from "react-svg-connector";
// if you want to use core connector components
import {
  SConnector,
  LineConnector,
  NarrowSConnector,
} from "react-svg-connector";
const Wrapper = styled.div`
  position: relative;
  height: 100vh;
  overflow: auto;
`;
const Box = styled.div`
  width: 150px;
  height: 50px;
  cursor: pointer;
`;
const Box1 = styled(Box)`
  background-color: green;
  position: absolute;
  top: 200px;
  left: 200px;
`;
const Box2 = styled(Box)`
  background-color: red;
  position: absolute;
  top: 400px;
  left: 500px;
`;
function App() {
  const ref1 = useRef<any>();
  const ref2 = useRef<any>();
  const [draw, redraw] = useState(0);
  useEffect(() => {
    redraw(Math.random());
  }, [ref1, ref2]);
  return (
    <Wrapper>
      <Connector
        el1={ref1.current}
        el2={ref2.current}
        shape="narrow-s"
        direction="r2l" // "l2l", "r2r", "l2l"
        roundCorner={true}
        endArrow={true}
      />
      <Box1 ref={ref1} />
      <Box2 ref={ref2} />
    </Wrapper>
  );
}