mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-21 16:26:58 +08:00
feat: use provied
This commit is contained in:
@@ -14,10 +14,11 @@ interface ModalProps {
|
|||||||
|
|
||||||
export const CreateWorkspaceModal = ({ open, onClose }: ModalProps) => {
|
export const CreateWorkspaceModal = ({ open, onClose }: ModalProps) => {
|
||||||
const [workspaceName, setWorkspaceName] = useState('');
|
const [workspaceName, setWorkspaceName] = useState('');
|
||||||
const { createWorkspace } = useTemporaryHelper();
|
const { createWorkspace, setActiveWorkspace } = useTemporaryHelper();
|
||||||
const handleCreateWorkspace = () => {
|
const handleCreateWorkspace = () => {
|
||||||
const { id } = createWorkspace(workspaceName);
|
const workspace = createWorkspace(workspaceName);
|
||||||
onClose({ workspaceId: id });
|
onClose({ workspaceId: workspace.id });
|
||||||
|
setActiveWorkspace(workspace);
|
||||||
};
|
};
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
|
|||||||
@@ -4,14 +4,9 @@ import {
|
|||||||
StyledPublishExplanation,
|
StyledPublishExplanation,
|
||||||
} from './style';
|
} from './style';
|
||||||
import { DownloadIcon } from '@blocksuite/icons';
|
import { DownloadIcon } from '@blocksuite/icons';
|
||||||
import { useEffect, useState } from 'react';
|
|
||||||
import { Button } from '@/ui/button';
|
import { Button } from '@/ui/button';
|
||||||
import { Menu, MenuItem } from '@/ui/menu';
|
import { Menu, MenuItem } from '@/ui/menu';
|
||||||
import {
|
import { deleteMember, Workspace } from '@/hooks/mock-data/mock';
|
||||||
deleteMember,
|
|
||||||
updateWorkspaceMeta,
|
|
||||||
Workspace,
|
|
||||||
} from '@/hooks/mock-data/mock';
|
|
||||||
import { useTemporaryHelper } from '@/providers/temporary-helper-provider';
|
import { useTemporaryHelper } from '@/providers/temporary-helper-provider';
|
||||||
|
|
||||||
export const SyncPage = ({ workspace }: { workspace: Workspace }) => {
|
export const SyncPage = ({ workspace }: { workspace: Workspace }) => {
|
||||||
@@ -20,18 +15,18 @@ export const SyncPage = ({ workspace }: { workspace: Workspace }) => {
|
|||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<StyledPublishContent>
|
<StyledPublishContent>
|
||||||
{currentWorkspace.type === 'local' ? (
|
{currentWorkspace?.type === 'local' ? (
|
||||||
<>
|
<>
|
||||||
<StyledPublishExplanation>
|
<StyledPublishExplanation>
|
||||||
{workspace.name} is Local Workspace. All data is stored on the
|
{currentWorkspace.name} is Local Workspace. All data is stored on
|
||||||
current device. You can enable AFFiNE Cloud for this workspace to
|
the current device. You can enable AFFiNE Cloud for this workspace
|
||||||
keep data in sync with the cloud.
|
to keep data in sync with the cloud.
|
||||||
</StyledPublishExplanation>
|
</StyledPublishExplanation>
|
||||||
|
|
||||||
<StyledPublishCopyContainer>
|
<StyledPublishCopyContainer>
|
||||||
<Button
|
<Button
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
updateWorkspaceMeta(workspace.id, {
|
updateWorkspaceMeta(currentWorkspace.id, {
|
||||||
type: 'cloud',
|
type: 'cloud',
|
||||||
});
|
});
|
||||||
}}
|
}}
|
||||||
@@ -45,8 +40,8 @@ export const SyncPage = ({ workspace }: { workspace: Workspace }) => {
|
|||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
<StyledPublishExplanation>
|
<StyledPublishExplanation>
|
||||||
<code>{workspace.name}</code> is Cloud Workspace. All data will be
|
<code>{currentWorkspace && currentWorkspace.name}</code> is Cloud
|
||||||
synchronized and saved to the AFFiNE
|
Workspace. All data will be synchronized and saved to the AFFiNE
|
||||||
</StyledPublishExplanation>
|
</StyledPublishExplanation>
|
||||||
<StyledPublishCopyContainer>
|
<StyledPublishCopyContainer>
|
||||||
<Menu
|
<Menu
|
||||||
|
|||||||
@@ -15,12 +15,12 @@ import { WorkspaceDelete } from './delete';
|
|||||||
import { debounce } from '@/utils';
|
import { debounce } from '@/utils';
|
||||||
import { WorkspaceLeave } from './leave';
|
import { WorkspaceLeave } from './leave';
|
||||||
import { Upload } from '@/components/file-upload';
|
import { Upload } from '@/components/file-upload';
|
||||||
import { updateWorkspaceMeta, Workspace } from '@/hooks/mock-data/mock';
|
import { Workspace } from '@/hooks/mock-data/mock';
|
||||||
import { WorkspaceAvatar } from '@/components/workspace-avatar';
|
import { WorkspaceAvatar } from '@/components/workspace-avatar';
|
||||||
import { useTemporaryHelper } from '@/providers/temporary-helper-provider';
|
import { useTemporaryHelper } from '@/providers/temporary-helper-provider';
|
||||||
export const GeneralPage = ({ workspace }: { workspace: Workspace }) => {
|
export const GeneralPage = ({ workspace }: { workspace: Workspace }) => {
|
||||||
const { refreshWorkspacesMeta } = useAppState();
|
const { refreshWorkspacesMeta } = useAppState();
|
||||||
const { currentWorkspace } = useTemporaryHelper();
|
const { updateWorkspaceMeta } = useTemporaryHelper();
|
||||||
const [showDelete, setShowDelete] = useState<boolean>(false);
|
const [showDelete, setShowDelete] = useState<boolean>(false);
|
||||||
const [showLeave, setShowLeave] = useState<boolean>(false);
|
const [showLeave, setShowLeave] = useState<boolean>(false);
|
||||||
const [uploading, setUploading] = useState<boolean>(false);
|
const [uploading, setUploading] = useState<boolean>(false);
|
||||||
@@ -47,7 +47,7 @@ export const GeneralPage = ({ workspace }: { workspace: Workspace }) => {
|
|||||||
setShowLeave(false);
|
setShowLeave(false);
|
||||||
};
|
};
|
||||||
const handleUpdateWorkspaceName = () => {
|
const handleUpdateWorkspaceName = () => {
|
||||||
updateWorkspaceMeta(workspace.id, { name: workspaceName });
|
workspace && updateWorkspaceMeta(workspace.id, { name: workspaceName });
|
||||||
};
|
};
|
||||||
|
|
||||||
const fileChange = async (file: File) => {
|
const fileChange = async (file: File) => {
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ import {
|
|||||||
} from '@blocksuite/icons';
|
} from '@blocksuite/icons';
|
||||||
import { useEffect, useState } from 'react';
|
import { useEffect, useState } from 'react';
|
||||||
import { GeneralPage } from './general';
|
import { GeneralPage } from './general';
|
||||||
import { getActiveWorkspace } from '@/hooks/mock-data/mock';
|
|
||||||
import { MembersPage } from './MembersPage';
|
import { MembersPage } from './MembersPage';
|
||||||
import { PublishPage } from './PublishPage';
|
import { PublishPage } from './PublishPage';
|
||||||
import { SyncPage } from './SyncPage';
|
import { SyncPage } from './SyncPage';
|
||||||
@@ -142,16 +141,16 @@ export const WorkspaceSetting = ({
|
|||||||
</StyledSettingSidebar>
|
</StyledSettingSidebar>
|
||||||
) : null}
|
) : null}
|
||||||
<StyledSettingContent>
|
<StyledSettingContent>
|
||||||
{activeTab === ActiveTab.general && (
|
{activeTab === ActiveTab.general && currentWorkspace && (
|
||||||
<GeneralPage workspace={currentWorkspace} />
|
<GeneralPage workspace={currentWorkspace} />
|
||||||
)}
|
)}
|
||||||
{activeTab === ActiveTab.sync && (
|
{activeTab === ActiveTab.sync && currentWorkspace && (
|
||||||
<SyncPage workspace={currentWorkspace} />
|
<SyncPage workspace={currentWorkspace} />
|
||||||
)}
|
)}
|
||||||
{activeTab === ActiveTab.members && currentWorkspace && (
|
{activeTab === ActiveTab.members && currentWorkspace && (
|
||||||
<MembersPage workspace={currentWorkspace} />
|
<MembersPage workspace={currentWorkspace} />
|
||||||
)}
|
)}
|
||||||
{activeTab === ActiveTab.publish && (
|
{activeTab === ActiveTab.publish && currentWorkspace && (
|
||||||
<PublishPage workspace={currentWorkspace} />
|
<PublishPage workspace={currentWorkspace} />
|
||||||
)}
|
)}
|
||||||
</StyledSettingContent>
|
</StyledSettingContent>
|
||||||
|
|||||||
Reference in New Issue
Block a user