Agent Skills: Reactive Polling

Poll for changes to any value and trigger React re-renders when it changes.

UncategorizedID: verekia/r3f-gamedev/reactive-polling

Install this agent skill to your local

pnpm dlx add-skill https://github.com/verekia/r3f-gamedev/tree/HEAD/skills/reactive-polling

Skill Files

Browse the full folder contents for reactive-polling.

Download Skill

Loading file tree…

skills/reactive-polling/SKILL.md

Skill Metadata

Name
reactive-polling
Description
Poll for changes to any value and trigger React re-renders when it changes.

Reactive Polling

Poll for changes to any value and trigger React re-renders when it changes.

Technique

Create a useReactive hook that uses useFrame to periodically check a selector function. When the value changes, update React state to trigger a re-render. Throttle with a configurable FPS.

Key Concepts

  • Selector function returns the value to watch
  • Compare with previous value to detect changes
  • Only update state when value actually changes
  • Throttle polling with useFrame's fps option
  • Use sparingly for values that don't change frequently

Usage

const useReactive = <T,>(selector: () => T, fps = 30): T => {
  const [reactiveValue, setReactiveValue] = useState<T>(selector())
  const previousValueRef = useRef(reactiveValue)

  useFrame(
    () => {
      const newValue = selector()
      if (previousValueRef.current !== newValue) {
        previousValueRef.current = newValue
        setReactiveValue(newValue)
      }
    },
    { fps }
  )

  return reactiveValue
}

// Usage
const isAboveZero = useReactive(() => position.y > 0)

This skill is part of verekia's r3f-gamedev.

Reactive Polling Skill | Agent Skills