File size: 649 Bytes
01488bc
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import { forwardRef, useEffect, useMemo } from "react";
import { FluidEffect } from "./FluidEffect";
import type { EffectProps } from "../types";

export const Effect = forwardRef(function Fluid(props: EffectProps, ref) {
  // prevent re-creating the effect on every render
  // eslint-disable-next-line react-hooks/exhaustive-deps
  const effect = useMemo(() => new FluidEffect(props), []);

  useEffect(() => {
    effect.state = { ...props };
    effect.update();
  }, [effect, props]);

  useEffect(() => {
    return () => {
      effect.dispose?.();
    };
  }, [effect]);

  return <primitive ref={ref} object={effect} dispose={null} />;
});