feat: improve provider testing (#1280)

This commit is contained in:
Himself65
2023-03-02 20:00:56 -06:00
committed by GitHub
parent 1e2f91fe21
commit 2a955d1391
11 changed files with 128 additions and 8 deletions

View File

@@ -0,0 +1,3 @@
# `_Debug` Pages
These pages are only available in development mode.

View File

@@ -0,0 +1,70 @@
import { Button, toast } from '@affine/component';
import { DebugLogger } from '@affine/debug';
import { nanoid } from '@blocksuite/store';
import { Typography } from '@mui/material';
import React, { useEffect, useMemo, useState } from 'react';
import { createBroadCastChannelProvider } from '../../blocksuite/providers';
import PageList from '../../components/blocksuite/block-suite-page-list/page-list';
import { StyledPage, StyledWrapper } from '../../layouts/styles';
import { BroadCastChannelProvider } from '../../shared';
import { createEmptyBlockSuiteWorkspace } from '../../utils';
const logger = new DebugLogger('broadcast');
declare global {
// eslint-disable-next-line no-var
var currentBroadCastChannel: BroadCastChannelProvider | undefined;
}
const BroadcastPage: React.FC = () => {
const blockSuiteWorkspace = useMemo(
() => createEmptyBlockSuiteWorkspace('broadcast-test'),
[]
);
const [provider, setProvider] = useState<BroadCastChannelProvider | null>(
null
);
useEffect(() => {
globalThis.currentBlockSuiteWorkspace = blockSuiteWorkspace;
}, [blockSuiteWorkspace]);
useEffect(() => {
const provider = createBroadCastChannelProvider(blockSuiteWorkspace);
setProvider(provider);
globalThis.currentBroadCastChannel = provider;
provider.connect();
return () => {
provider.disconnect();
globalThis.currentBroadCastChannel = undefined;
setProvider(null);
};
}, [blockSuiteWorkspace]);
if (!provider) {
return null;
}
return (
<StyledPage>
<StyledWrapper>
<Typography variant="h5">Broadcast Provider Test</Typography>
<Button
type="primary"
data-testid="create-page"
onClick={() => {
logger.info('create page');
blockSuiteWorkspace.createPage(nanoid());
}}
>
Create Page
</Button>
<PageList
blockSuiteWorkspace={blockSuiteWorkspace}
onClickPage={() => {
toast('do nothing');
}}
/>
</StyledWrapper>
</StyledPage>
);
};
export default BroadcastPage;