mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-05-25 15:03:46 +00:00
Major additions: - Complete Next.js studio application with 1600+ components - Docker support (Dockerfile.combined, docker-compose.yml) - GCP deployment documentation and benchmarks - SQL benchmark scripts for performance testing - Sentry integration for monitoring - Comprehensive test suite and mocks Studio features: - Dashboard and admin interfaces - Data visualization components - Authentication and user management - API integration with RuVector backend - Static data and public assets 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
27 lines
709 B
TypeScript
27 lines
709 B
TypeScript
import { useRef } from 'react'
|
|
|
|
export function useStateTransition<
|
|
State extends { type: string },
|
|
PrevType extends State['type'],
|
|
NewType extends State['type'],
|
|
>(
|
|
state: State,
|
|
prevTest: PrevType,
|
|
newTest: NewType,
|
|
cb: (
|
|
prevState: Extract<State, { type: PrevType }>,
|
|
currState: Extract<State, { type: NewType }>
|
|
) => void
|
|
): void {
|
|
const prevState = useRef(state)
|
|
const savedPrevState = prevState.current
|
|
const shouldRunCallback = savedPrevState.type === prevTest && state.type === newTest
|
|
prevState.current = state
|
|
|
|
if (shouldRunCallback) {
|
|
cb(
|
|
savedPrevState as Extract<State, { type: PrevType }>,
|
|
state as Extract<State, { type: NewType }>
|
|
)
|
|
}
|
|
}
|