diff --git a/packages/frontend/core/src/components/app-sidebar/add-page-button/index.tsx b/packages/frontend/core/src/components/app-sidebar/add-page-button/index.tsx
index c8da78a66b..369c623d0f 100644
--- a/packages/frontend/core/src/components/app-sidebar/add-page-button/index.tsx
+++ b/packages/frontend/core/src/components/app-sidebar/add-page-button/index.tsx
@@ -3,11 +3,12 @@ import { useI18n } from '@affine/i18n';
import { PlusIcon } from '@blocksuite/icons/rc';
import clsx from 'clsx';
import type React from 'react';
+import type { MouseEventHandler } from 'react';
import * as styles from './index.css';
interface AddPageButtonProps {
- onClick?: () => void;
+ onClick?: MouseEventHandler;
className?: string;
style?: React.CSSProperties;
}
diff --git a/packages/frontend/core/src/components/blocksuite/block-suite-header/menu/index.tsx b/packages/frontend/core/src/components/blocksuite/block-suite-header/menu/index.tsx
index 8188140d1e..511a0dcfe3 100644
--- a/packages/frontend/core/src/components/blocksuite/block-suite-header/menu/index.tsx
+++ b/packages/frontend/core/src/components/blocksuite/block-suite-header/menu/index.tsx
@@ -19,6 +19,7 @@ import { useExportPage } from '@affine/core/hooks/affine/use-export-page';
import { useTrashModalHelper } from '@affine/core/hooks/affine/use-trash-modal-helper';
import { useAsyncCallback } from '@affine/core/hooks/affine-async-hooks';
import { mixpanel } from '@affine/core/mixpanel';
+import { WorkbenchService } from '@affine/core/modules/workbench';
import { useDetailPageHeaderResponsive } from '@affine/core/pages/workspace/detail-page/use-header-responsive';
import { WorkspaceFlavour } from '@affine/env/workspace';
import { useI18n } from '@affine/i18n';
@@ -31,8 +32,10 @@ import {
HistoryIcon,
ImportIcon,
InformationIcon,
+ OpenInNewIcon,
PageIcon,
ShareIcon,
+ SplitViewIcon,
} from '@blocksuite/icons/rc';
import type { Doc } from '@blocksuite/store';
import {
@@ -73,6 +76,8 @@ export const PageHeaderMenuButton = ({
const isInTrash = useLiveData(doc.meta$.map(m => m.trash));
const currentMode = useLiveData(doc.mode$);
+ const workbench = useService(WorkbenchService).workbench;
+
const { favorite, toggleFavorite } = useFavorite(pageId);
const { duplicate } = useBlockSuiteMetaHelper(docCollection);
@@ -94,6 +99,18 @@ export const PageHeaderMenuButton = ({
setOpenInfoModal(true);
};
+ const handleOpenInNewTab = useCallback(() => {
+ workbench.openDoc(pageId, {
+ at: 'new-tab',
+ });
+ }, [pageId, workbench]);
+
+ const handleOpenInSplitView = useCallback(() => {
+ workbench.openDoc(pageId, {
+ at: 'tail',
+ });
+ }, [pageId, workbench]);
+
const handleOpenTrashModal = useCallback(() => {
setTrashModal({
open: true,
@@ -237,16 +254,35 @@ export const PageHeaderMenuButton = ({
? t['com.affine.favoritePageOperation.remove']()
: t['com.affine.favoritePageOperation.add']()}
- {/* {TODO(@Peng): add tag function support} */}
- {/* }
- data-testid="editor-option-menu-add-tag"
- onClick={() => {}}
+
+ */}
+ {t['com.affine.workbench.tab.page-menu-open']()}
+
+
+
+
+
{runtimeConfig.enableInfoModal && (