mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 21:05:19 +00:00
66 lines
1.6 KiB
TypeScript
66 lines
1.6 KiB
TypeScript
import { TreeView } from '@affine/component';
|
|
import type { PageMeta } from '@blocksuite/store';
|
|
import type { MouseEvent } from 'react';
|
|
import { useCallback } from 'react';
|
|
|
|
import type { PinboardNode } from '../../../hooks/use-pinboard-data';
|
|
import { usePinboardData } from '../../../hooks/use-pinboard-data';
|
|
import { usePinboardHandler } from '../../../hooks/use-pinboard-handler';
|
|
import type { BlockSuiteWorkspace } from '../../../shared';
|
|
import { PinboardRender } from '../../affine/pinboard';
|
|
|
|
export type PinboardProps = {
|
|
blockSuiteWorkspace: BlockSuiteWorkspace;
|
|
openPage: (pageId: string) => void;
|
|
allMetas: PageMeta[];
|
|
};
|
|
|
|
export const Pinboard = ({
|
|
blockSuiteWorkspace,
|
|
openPage,
|
|
allMetas,
|
|
}: PinboardProps) => {
|
|
const handlePinboardClick = useCallback(
|
|
(e: MouseEvent<HTMLDivElement>, node: PinboardNode) => {
|
|
openPage(node.id);
|
|
},
|
|
[openPage]
|
|
);
|
|
const onAdd = useCallback(
|
|
(id: string) => {
|
|
openPage(id);
|
|
},
|
|
[openPage]
|
|
);
|
|
|
|
const { data } = usePinboardData({
|
|
metas: allMetas.filter(meta => !meta.trash),
|
|
pinboardRender: PinboardRender,
|
|
blockSuiteWorkspace: blockSuiteWorkspace,
|
|
onClick: handlePinboardClick,
|
|
showOperationButton: true,
|
|
});
|
|
|
|
const { addPin, deletePin, dropPin } = usePinboardHandler({
|
|
blockSuiteWorkspace: blockSuiteWorkspace,
|
|
metas: allMetas,
|
|
onAdd,
|
|
});
|
|
|
|
if (!data.length) {
|
|
return null;
|
|
}
|
|
return (
|
|
<div data-testid="sidebar-pinboard-container">
|
|
<TreeView
|
|
data={data}
|
|
onAdd={addPin}
|
|
onDelete={deletePin}
|
|
onDrop={dropPin}
|
|
indent={16}
|
|
/>
|
|
</div>
|
|
);
|
|
};
|
|
export default Pinboard;
|