mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 21:05:19 +00:00
feat(core): improve invite link (#9111)
This commit is contained in:
@@ -13,6 +13,7 @@ import {
|
||||
WorkspacePermissionService,
|
||||
} from '@affine/core/modules/permissions';
|
||||
import { WorkspaceQuotaService } from '@affine/core/modules/quota';
|
||||
import { WorkspaceShareSettingService } from '@affine/core/modules/share-setting';
|
||||
import { copyTextToClipboard } from '@affine/core/utils/clipboard';
|
||||
import { emailRegex } from '@affine/core/utils/email-regex';
|
||||
import type { WorkspaceInviteLinkExpireTime } from '@affine/graphql';
|
||||
@@ -49,6 +50,10 @@ export const CloudWorkspaceMembersPanel = ({
|
||||
onChangeSettingState: (settingState: SettingState) => void;
|
||||
isTeam?: boolean;
|
||||
}) => {
|
||||
const workspaceShareSettingService = useService(WorkspaceShareSettingService);
|
||||
const inviteLink = useLiveData(
|
||||
workspaceShareSettingService.sharePreview.inviteLink$
|
||||
);
|
||||
const serverService = useService(ServerService);
|
||||
const hasPaymentFeature = useLiveData(
|
||||
serverService.server.features$.map(f => f?.payment)
|
||||
@@ -90,15 +95,17 @@ export const CloudWorkspaceMembersPanel = ({
|
||||
async (expireTime: WorkspaceInviteLinkExpireTime) => {
|
||||
const { link } =
|
||||
await permissionService.permission.generateInviteLink(expireTime);
|
||||
workspaceShareSettingService.sharePreview.revalidate();
|
||||
return link;
|
||||
},
|
||||
[permissionService.permission]
|
||||
[permissionService.permission, workspaceShareSettingService.sharePreview]
|
||||
);
|
||||
|
||||
const onRevokeInviteLink = useCallback(async () => {
|
||||
const success = await permissionService.permission.revokeInviteLink();
|
||||
workspaceShareSettingService.sharePreview.revalidate();
|
||||
return success;
|
||||
}, [permissionService.permission]);
|
||||
}, [permissionService.permission, workspaceShareSettingService.sharePreview]);
|
||||
|
||||
const onInviteBatchConfirm = useCallback<
|
||||
InviteTeamMemberModalProps['onConfirm']
|
||||
@@ -218,6 +225,7 @@ export const CloudWorkspaceMembersPanel = ({
|
||||
onGenerateInviteLink={onGenerateInviteLink}
|
||||
onRevokeInviteLink={onRevokeInviteLink}
|
||||
importCSV={<ImportCSV onImport={onImportCSV} />}
|
||||
invitationLink={inviteLink}
|
||||
/>
|
||||
)}
|
||||
</>
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
import { DebugLogger } from '@affine/debug';
|
||||
import type { GetWorkspaceConfigQuery } from '@affine/graphql';
|
||||
import type { GetWorkspaceConfigQuery, InviteLink } from '@affine/graphql';
|
||||
import type { WorkspaceService } from '@toeverything/infra';
|
||||
import {
|
||||
backoffRetry,
|
||||
@@ -25,6 +25,7 @@ const logger = new DebugLogger('affine:workspace-permission');
|
||||
export class WorkspaceShareSetting extends Entity {
|
||||
enableAi$ = new LiveData<EnableAi | null>(null);
|
||||
enableUrlPreview$ = new LiveData<EnableUrlPreview | null>(null);
|
||||
inviteLink$ = new LiveData<InviteLink | null>(null);
|
||||
isLoading$ = new LiveData(false);
|
||||
error$ = new LiveData<any>(null);
|
||||
|
||||
@@ -56,6 +57,7 @@ export class WorkspaceShareSetting extends Entity {
|
||||
if (value) {
|
||||
this.enableAi$.next(value.enableAi);
|
||||
this.enableUrlPreview$.next(value.enableUrlPreview);
|
||||
this.inviteLink$.next(value.inviteLink);
|
||||
}
|
||||
return EMPTY;
|
||||
}),
|
||||
|
||||
Reference in New Issue
Block a user