import { useParams } from '@tanstack/react-router'; import type { Workspace } from '@yaakapp-internal/models'; import { atom, useAtomValue } from 'jotai/index'; import { useEffect } from 'react'; import { jotaiStore } from '../routes/__root'; import { useWorkspaces } from './useWorkspaces'; export const activeWorkspaceIdAtom = atom(); export function useActiveWorkspace(): Workspace | null { const workspaceId = useActiveWorkspaceId(); const workspaces = useWorkspaces(); return workspaces.find((w) => w.id === workspaceId) ?? null; } function useActiveWorkspaceId(): string | null { return useAtomValue(activeWorkspaceIdAtom) ?? null; } export function useSubscribeActiveWorkspaceId() { const { workspaceId } = useParams({ strict: false }); useEffect(() => { jotaiStore.set(activeWorkspaceIdAtom, workspaceId); }, [workspaceId]); }