2025-04-01 10:38:02 +09:00

21 lines
760 B
TypeScript

import { useMemo } from 'react';
import { useCounter, usePrevious } from 'react-use';
import { DataFrame, compareArrayValues, compareDataFrameStructures } from '@grafana/data';
export function useStructureRev(frames: DataFrame[]) {
const [structureRev, { inc }] = useCounter(1);
const previousFrames = usePrevious(frames);
// We need to increment structureRev when the number of series changes.
// the function passed to useMemo runs during rendering, so when we get a different
// amount of data, structureRev is incremented before we render it
useMemo(() => {
if (previousFrames && !compareArrayValues(frames, previousFrames, compareDataFrameStructures)) {
inc();
}
}, [frames, previousFrames, inc]);
return structureRev;
}