import { workspacesAtom } from '@yaakapp-internal/models'; import { useAtomValue } from 'jotai'; import { useEffect, useMemo } from 'react'; import { jotaiStore } from '../lib/jotai'; import { getKeyValue, setKeyValue } from '../lib/keyValueStore'; import { activeWorkspaceIdAtom } from './useActiveWorkspace'; import { useKeyValue } from './useKeyValue'; const kvKey = () => 'recent_workspaces'; const namespace = 'global'; const fallback: string[] = []; export function useRecentWorkspaces() { const workspaces = useAtomValue(workspacesAtom); const { value, isLoading } = useKeyValue({ key: kvKey(), namespace, fallback }); const onlyValidIds = useMemo( () => value?.filter((id) => workspaces.some((w) => w.id === id)) ?? [], [value, workspaces], ); if (isLoading) return null; return onlyValidIds; } export function useSubscribeRecentWorkspaces() { useEffect(() => { const unsub = jotaiStore.sub(activeWorkspaceIdAtom, updateRecentWorkspaces); updateRecentWorkspaces().catch(console.error); // Update when opened in a new window return unsub; }, []); } async function updateRecentWorkspaces() { const activeWorkspaceId = jotaiStore.get(activeWorkspaceIdAtom); if (activeWorkspaceId == null) return; const key = kvKey(); const recentIds = getKeyValue({ namespace, key, fallback }); if (recentIds[0] === activeWorkspaceId) return; // Short-circuit const withoutActiveId = recentIds.filter((id) => id !== activeWorkspaceId); const value = [activeWorkspaceId, ...withoutActiveId]; console.log('Recent workspaces update', activeWorkspaceId); await setKeyValue({ namespace, key, value }); }