import { useEffect, useMemo } from 'react'; import { createGlobalState, useEffectOnce } from 'react-use'; import { useActiveWorkspaceId } from './useActiveWorkspaceId'; import { useActiveEnvironmentId } from './useActiveEnvironmentId'; import { useKeyValue } from './useKeyValue'; import { NAMESPACE_GLOBAL, getKeyValue } from '../lib/keyValueStore'; import { useEnvironments } from './useEnvironments'; const useHistoryState = createGlobalState([]); const kvKey = (workspaceId: string) => 'recent_environments::' + workspaceId; const namespace = NAMESPACE_GLOBAL; const defaultValue: string[] = []; export function useRecentEnvironments() { const environments = useEnvironments(); const activeWorkspaceId = useActiveWorkspaceId(); const activeEnvironmentId = useActiveEnvironmentId(); const [history, setHistory] = useHistoryState(); const kv = useKeyValue({ key: kvKey(activeWorkspaceId ?? 'n/a'), namespace, defaultValue, }); // Load local storage state on initial render useEffectOnce(() => { if (kv.value) { setHistory(kv.value); } }); // Update local storage state when history changes useEffect(() => { kv.set(history); // eslint-disable-next-line react-hooks/exhaustive-deps }, [history]); // Set history when active request changes useEffect(() => { setHistory((currentHistory: string[]) => { if (activeEnvironmentId === null) return currentHistory; const withoutCurrentEnvironment = currentHistory.filter((id) => id !== activeEnvironmentId); return [activeEnvironmentId, ...withoutCurrentEnvironment]; }); }, [activeEnvironmentId, setHistory]); const onlyValidIds = useMemo( () => history.filter((id) => environments.some((e) => e.id === id)), [history, environments], ); return onlyValidIds; } export async function getRecentEnvironments(workspaceId: string) { return getKeyValue({ namespace, key: kvKey(workspaceId), fallback: defaultValue, }); }