mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 12:55:00 +00:00
115 lines
3.3 KiB
TypeScript
115 lines
3.3 KiB
TypeScript
import { useAtom, useAtomValue, useSetAtom } from 'jotai';
|
|
import dynamic from 'next/dynamic';
|
|
import { useRouter } from 'next/router';
|
|
import React, { useCallback } from 'react';
|
|
|
|
import {
|
|
currentWorkspaceIdAtom,
|
|
openCreateWorkspaceModalAtom,
|
|
openWorkspacesModalAtom,
|
|
} from '../atoms';
|
|
import { useCurrentUser } from '../hooks/current/use-current-user';
|
|
import { useWorkspaces, useWorkspacesHelper } from '../hooks/use-workspaces';
|
|
import { apis } from '../shared/apis';
|
|
|
|
const WorkspaceListModal = dynamic(
|
|
async () =>
|
|
(await import('../components/pure/workspace-list-modal')).WorkspaceListModal
|
|
);
|
|
const CreateWorkspaceModal = dynamic(
|
|
async () =>
|
|
(await import('../components/pure/create-workspace-modal'))
|
|
.CreateWorkspaceModal
|
|
);
|
|
|
|
export function Modals() {
|
|
const [openWorkspacesModal, setOpenWorkspacesModal] = useAtom(
|
|
openWorkspacesModalAtom
|
|
);
|
|
const [openCreateWorkspaceModal, setOpenCreateWorkspaceModal] = useAtom(
|
|
openCreateWorkspaceModalAtom
|
|
);
|
|
|
|
const router = useRouter();
|
|
const user = useCurrentUser();
|
|
const workspaces = useWorkspaces();
|
|
const currentWorkspaceId = useAtomValue(currentWorkspaceIdAtom);
|
|
const setCurrentWorkspace = useSetAtom(currentWorkspaceIdAtom);
|
|
const { createLocalWorkspace } = useWorkspacesHelper();
|
|
|
|
return (
|
|
<>
|
|
<WorkspaceListModal
|
|
user={user}
|
|
workspaces={workspaces}
|
|
currentWorkspaceId={currentWorkspaceId}
|
|
open={openWorkspacesModal || workspaces.length === 0}
|
|
onClose={useCallback(() => {
|
|
setOpenWorkspacesModal(false);
|
|
}, [setOpenWorkspacesModal])}
|
|
onClickWorkspace={useCallback(
|
|
workspace => {
|
|
setOpenWorkspacesModal(false);
|
|
setCurrentWorkspace(workspace.id);
|
|
router.push({
|
|
pathname: `/workspace/[workspaceId]/all`,
|
|
query: {
|
|
workspaceId: workspace.id,
|
|
},
|
|
});
|
|
},
|
|
[router, setCurrentWorkspace, setOpenWorkspacesModal]
|
|
)}
|
|
onClickLogin={useCallback(() => {
|
|
apis.signInWithGoogle().then(() => {
|
|
router.reload();
|
|
});
|
|
}, [router])}
|
|
onClickLogout={useCallback(() => {
|
|
apis.auth.clear();
|
|
router.reload();
|
|
}, [router])}
|
|
onCreateWorkspace={useCallback(() => {
|
|
setOpenCreateWorkspaceModal(true);
|
|
}, [setOpenCreateWorkspaceModal])}
|
|
/>
|
|
<CreateWorkspaceModal
|
|
open={openCreateWorkspaceModal}
|
|
onClose={useCallback(() => {
|
|
setOpenCreateWorkspaceModal(false);
|
|
}, [setOpenCreateWorkspaceModal])}
|
|
onCreate={useCallback(
|
|
async name => {
|
|
const id = await createLocalWorkspace(name);
|
|
setOpenCreateWorkspaceModal(false);
|
|
setOpenWorkspacesModal(false);
|
|
return router.push({
|
|
pathname: '/workspace/[workspaceId]/all',
|
|
query: {
|
|
workspaceId: id,
|
|
},
|
|
});
|
|
},
|
|
[
|
|
createLocalWorkspace,
|
|
router,
|
|
setOpenCreateWorkspaceModal,
|
|
setOpenWorkspacesModal,
|
|
]
|
|
)}
|
|
/>
|
|
</>
|
|
);
|
|
}
|
|
|
|
export const ModalProvider: React.FC<React.PropsWithChildren> = ({
|
|
children,
|
|
}) => {
|
|
return (
|
|
<>
|
|
<Modals />
|
|
{children}
|
|
</>
|
|
);
|
|
};
|