feat(component): mobile menu support (#7892)

This commit is contained in:
Cats Juice
2024-08-21 17:05:05 +08:00
committed by GitHub
parent 182b2fd62d
commit 23b0db36b9
57 changed files with 988 additions and 1482 deletions

View File

@@ -20,7 +20,7 @@ const LanguageMenuContent = memo(function LanguageMenuContent() {
title={option.name}
lang={option.tag}
onSelect={() => onLanguageChange(option.tag)}
endFix={(option.Completeness * 100).toFixed(0) + '%'}
suffix={(option.Completeness * 100).toFixed(0) + '%'}
data-selected={selected}
className={styles.menuItem}
>

View File

@@ -1,11 +1,5 @@
import type { MenuItemProps } from '@affine/component';
import {
Input,
MenuIcon,
MenuItem,
MenuSeparator,
Scrollable,
} from '@affine/component';
import { Input, MenuItem, MenuSeparator, Scrollable } from '@affine/component';
import type { PageInfoCustomPropertyMeta } from '@affine/core/modules/properties/services/schema';
import { useI18n } from '@affine/i18n';
import type { KeyboardEventHandler, MouseEventHandler } from 'react';
@@ -61,7 +55,7 @@ export const renderMenuItemOptions = (options: MenuItemOption[]) => {
type={type}
selected={selected}
checked={checked}
preFix={icon ? <MenuIcon>{icon}</MenuIcon> : null}
prefixIcon={icon}
onClick={onClick}
>
{text}

View File

@@ -1,12 +1,5 @@
import type { MenuProps } from '@affine/component';
import {
Button,
IconButton,
Menu,
MenuIcon,
MenuItem,
Tooltip,
} from '@affine/component';
import { Button, IconButton, Menu, MenuItem, Tooltip } from '@affine/component';
import { useCurrentWorkspacePropertiesAdapter } from '@affine/core/hooks/use-affine-adapter';
import { track } from '@affine/core/mixpanel';
import { DocLinksService } from '@affine/core/modules/doc-link';
@@ -346,9 +339,7 @@ export const PagePropertiesSettingsPopup = ({
className={styles.propertySettingRow}
data-testid="page-properties-settings-menu-item"
>
<MenuIcon>
<Icon />
</MenuIcon>
<Icon />
<div
data-testid="page-property-setting-row-name"
className={styles.propertyRowName}

View File

@@ -25,19 +25,11 @@ export const menuTriggerStyle = style({
padding: '4px 10px',
justifyContent: 'space-between',
});
export const menuItemStyle = style({
padding: '4px',
});
export const publicItemRowStyle = style({
display: 'flex',
alignItems: 'center',
justifyContent: 'space-between',
});
export const publicMenuItemPrefixStyle = style({
fontSize: cssVar('fontH5'),
color: cssVarV2('icon/primary'),
marginRight: '8px',
});
export const DoneIconStyle = style({
color: cssVarV2('button/primary'),
fontSize: cssVar('fontH5'),
@@ -66,7 +58,6 @@ export const copyLinkButtonStyle = style({
});
export const copyLinkLabelContainerStyle = style({
width: '100%',
padding: '4px 12px',
borderRight: 'none',
borderTopRightRadius: '0',
borderBottomRightRadius: '0',
@@ -92,18 +83,7 @@ export const copyLinkShortcutStyle = style({
color: cssVarV2('text/pureWhite'),
});
export const copyLinkTriggerStyle = style({
width: '100%',
padding: '4px 12px',
paddingLeft: '4px',
display: 'flex',
border: `1px solid ${cssVarV2('button/innerBlackBorder')}`,
flex: 0,
justifyContent: 'end',
alignItems: 'center',
gap: '4px',
position: 'relative',
backgroundColor: cssVarV2('button/primary'),
color: cssVarV2('button/pureWhiteText'),
padding: '4px 12px 4px 8px',
borderLeft: 'none',
borderTopLeftRadius: '0',
borderBottomLeftRadius: '0',
@@ -111,7 +91,7 @@ export const copyLinkTriggerStyle = style({
backgroundColor: cssVarV2('button/primary'),
color: cssVarV2('button/pureWhiteText'),
},
'::before': {
'::after': {
content: '""',
position: 'absolute',
left: '0',

View File

@@ -207,13 +207,7 @@ export const AFFiNESharePage = (props: ShareMenuProps) => {
}}
items={
<>
<MenuItem
preFix={
<LockIcon className={styles.publicMenuItemPrefixStyle} />
}
onSelect={onClickDisable}
className={styles.menuItemStyle}
>
<MenuItem prefixIcon={<LockIcon />} onSelect={onClickDisable}>
<div className={styles.publicItemRowStyle}>
<div>
{t['com.affine.share-menu.option.link.no-access']()}
@@ -224,10 +218,7 @@ export const AFFiNESharePage = (props: ShareMenuProps) => {
</div>
</MenuItem>
<MenuItem
preFix={
<ViewIcon className={styles.publicMenuItemPrefixStyle} />
}
className={styles.menuItemStyle}
prefixIcon={<ViewIcon />}
onSelect={onClickAnyoneReadOnlyShare}
data-testid="share-link-menu-enable-share"
>
@@ -295,7 +286,6 @@ export const AFFiNESharePage = (props: ShareMenuProps) => {
<span className={styles.copyLinkShortcutStyle}>
{isMac ? '⌘ + ⌥ + C' : 'Ctrl + Shift + C'}
</span>
{t['com.affine.share-menu.copy']()}
</Button>
<Menu
contentOptions={{
@@ -304,42 +294,24 @@ export const AFFiNESharePage = (props: ShareMenuProps) => {
items={
<>
<MenuItem
preFix={
<PageIcon className={styles.publicMenuItemPrefixStyle} />
}
className={styles.menuItemStyle}
prefixIcon={<PageIcon />}
onSelect={onCopyPageLink}
data-testid="share-link-menu-copy-page"
>
{t['com.affine.share-menu.copy.page']()}
</MenuItem>
<MenuItem
preFix={
<EdgelessIcon className={styles.publicMenuItemPrefixStyle} />
}
className={styles.menuItemStyle}
prefixIcon={<EdgelessIcon />}
onSelect={onCopyEdgelessLink}
data-testid="share-link-menu-copy-edgeless"
>
{t['com.affine.share-menu.copy.edgeless']()}
</MenuItem>
<MenuItem
preFix={
<LinkIcon className={styles.publicMenuItemPrefixStyle} />
}
className={styles.menuItemStyle}
onSelect={onCopyBlockLink}
>
<MenuItem prefixIcon={<LinkIcon />} onSelect={onCopyBlockLink}>
{t['com.affine.share-menu.copy.block']()}
</MenuItem>
{currentDocMode === 'edgeless' && (
<MenuItem
preFix={
<LinkIcon className={styles.publicMenuItemPrefixStyle} />
}
className={styles.menuItemStyle}
onSelect={onCopyBlockLink}
>
<MenuItem prefixIcon={<LinkIcon />} onSelect={onCopyBlockLink}>
{t['com.affine.share-menu.copy.frame']()}
</MenuItem>
)}
@@ -347,8 +319,11 @@ export const AFFiNESharePage = (props: ShareMenuProps) => {
}
>
<MenuTrigger
variant="primary"
className={styles.copyLinkTriggerStyle}
data-testid="share-menu-copy-link-button"
suffixStyle={{ width: 20, height: 20 }}
withoutHover
/>
</Menu>
</div>

View File

@@ -1,7 +1,6 @@
import { toast } from '@affine/component';
import {
Menu,
MenuIcon,
MenuItem,
MenuSeparator,
MenuSub,
@@ -13,6 +12,7 @@ import {
import { PageHistoryModal } from '@affine/core/components/affine/page-history-modal';
import { ShareMenuContent } from '@affine/core/components/affine/share-page-modal/share-menu';
import { Export, MoveToTrash } from '@affine/core/components/page-list';
import { IsFavoriteIcon } from '@affine/core/components/pure/icons';
import { useBlockSuiteMetaHelper } from '@affine/core/hooks/affine/use-block-suite-meta-helper';
import { useEnableCloud } from '@affine/core/hooks/affine/use-enable-cloud';
import { useExportPage } from '@affine/core/hooks/affine/use-export-page';
@@ -29,8 +29,6 @@ import {
DuplicateIcon,
EdgelessIcon,
EditIcon,
FavoritedIcon,
FavoriteIcon,
FrameIcon,
HistoryIcon,
ImportIcon,
@@ -157,10 +155,6 @@ export const PageHeaderMenuButton = ({
: t['com.affine.toastMessage.pageMode']()
);
}, [currentMode, editorService, t]);
const menuItemStyle = {
padding: '4px 12px',
transition: 'all 0.3s',
};
const handleMenuOpenChange = useCallback((open: boolean) => {
if (open) {
@@ -225,11 +219,7 @@ export const PageHeaderMenuButton = ({
</div>
}
triggerOptions={{
preFix: (
<MenuIcon>
<ShareIcon />
</MenuIcon>
),
prefixIcon: <ShareIcon />,
}}
subOptions={{
onOpenChange: handleShareMenuOpenChange,
@@ -247,27 +237,17 @@ export const PageHeaderMenuButton = ({
{showResponsiveMenu ? ResponsiveMenuItems : null}
{!isJournal && (
<MenuItem
preFix={
<MenuIcon>
<EditIcon />
</MenuIcon>
}
prefixIcon={<EditIcon />}
data-testid="editor-option-menu-rename"
onSelect={handleRename}
style={menuItemStyle}
>
{t['Rename']()}
</MenuItem>
)}
<MenuItem
preFix={
<MenuIcon>
{currentMode === 'page' ? <EdgelessIcon /> : <PageIcon />}
</MenuIcon>
}
prefixIcon={currentMode === 'page' ? <EdgelessIcon /> : <PageIcon />}
data-testid="editor-option-menu-edgeless"
onSelect={handleSwitchMode}
style={menuItemStyle}
>
{t['Convert to ']()}
{currentMode === 'page'
@@ -277,16 +257,7 @@ export const PageHeaderMenuButton = ({
<MenuItem
data-testid="editor-option-menu-favorite"
onSelect={handleToggleFavorite}
style={menuItemStyle}
preFix={
<MenuIcon>
{favorite ? (
<FavoritedIcon style={{ color: 'var(--affine-primary-color)' }} />
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favorite} />}
>
{favorite
? t['com.affine.favoritePageOperation.remove']()
@@ -294,28 +265,18 @@ export const PageHeaderMenuButton = ({
</MenuItem>
<MenuSeparator />
<MenuItem
preFix={
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
}
prefixIcon={<OpenInNewIcon />}
data-testid="editor-option-menu-open-in-new-tab"
onSelect={handleOpenInNewTab}
style={menuItemStyle}
>
{t['com.affine.workbench.tab.page-menu-open']()}
</MenuItem>
{environment.isDesktop && (
<MenuItem
preFix={
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
}
prefixIcon={<SplitViewIcon />}
data-testid="editor-option-menu-open-in-split-new"
onSelect={handleOpenInSplitView}
style={menuItemStyle}
>
{t['com.affine.workbench.split-view.page-menu-open']()}
</MenuItem>
@@ -325,81 +286,51 @@ export const PageHeaderMenuButton = ({
{runtimeConfig.enableInfoModal && (
<MenuItem
preFix={
<MenuIcon>
<InformationIcon />
</MenuIcon>
}
prefixIcon={<InformationIcon />}
data-testid="editor-option-menu-info"
onSelect={openInfoModal}
style={menuItemStyle}
>
{t['com.affine.page-properties.page-info.view']()}
</MenuItem>
)}
{currentMode === 'page' ? (
<MenuItem
preFix={
<MenuIcon>
<TocIcon />
</MenuIcon>
}
prefixIcon={<TocIcon />}
data-testid="editor-option-toc"
onSelect={openOutlinePanel}
style={menuItemStyle}
>
{t['com.affine.header.option.view-toc']()}
</MenuItem>
) : (
<MenuItem
preFix={
<MenuIcon>
<FrameIcon />
</MenuIcon>
}
prefixIcon={<FrameIcon />}
data-testid="editor-option-frame"
onSelect={openAllFrames}
style={menuItemStyle}
>
{t['com.affine.header.option.view-frame']()}
</MenuItem>
)}
<MenuItem
preFix={
<MenuIcon>
<HistoryIcon />
</MenuIcon>
}
prefixIcon={<HistoryIcon />}
data-testid="editor-option-menu-history"
onSelect={openHistoryModal}
style={menuItemStyle}
>
{t['com.affine.history.view-history-version']()}
</MenuItem>
<MenuSeparator />
{!isJournal && (
<MenuItem
preFix={
<MenuIcon>
<DuplicateIcon />
</MenuIcon>
}
prefixIcon={<DuplicateIcon />}
data-testid="editor-option-menu-duplicate"
onSelect={handleDuplicate}
style={menuItemStyle}
>
{t['com.affine.header.option.duplicate']()}
</MenuItem>
)}
<MenuItem
preFix={
<MenuIcon>
<ImportIcon />
</MenuIcon>
}
prefixIcon={<ImportIcon />}
data-testid="editor-option-menu-import"
onSelect={onImportFile}
style={menuItemStyle}
>
{t['Import']()}
</MenuItem>

View File

@@ -1,10 +1,5 @@
import { Avatar } from '@affine/component/ui/avatar';
import {
Menu,
MenuIcon,
MenuItem,
MenuSeparator,
} from '@affine/component/ui/menu';
import { Menu, MenuItem, MenuSeparator } from '@affine/component/ui/menu';
import { useAsyncCallback } from '@affine/core/hooks/affine-async-hooks';
import { useI18n } from '@affine/i18n';
import { SignOutIcon } from '@blocksuite/icons/rc';
@@ -66,11 +61,7 @@ export const PublishPageUserAvatar = () => {
<UserInfo />
<MenuSeparator />
<MenuItem
preFix={
<MenuIcon>
<SignOutIcon />
</MenuIcon>
}
prefixIcon={<SignOutIcon />}
data-testid="share-page-sign-out-option"
onClick={handleSignOut}
>

View File

@@ -94,7 +94,7 @@ export const PageDisplayMenu = () => {
key={option.value}
onSelect={() => handleSelect(option.value)}
data-active={workspaceProperties.groupBy === option.value}
endFix={
suffixIcon={
workspaceProperties.groupBy === option.value ? (
<DoneIcon fontSize={'20px'} />
) : null

View File

@@ -1,4 +1,4 @@
import { MenuIcon, MenuItem, MenuSeparator } from '@affine/component';
import { MenuItem, MenuSeparator } from '@affine/component';
import type {
Filter,
LiteralValue,
@@ -92,7 +92,7 @@ export const VariableSelect = ({
// .filter(v => !selected.find(filter => filter.left.name === v.name))
.map(v => (
<MenuItem
preFix={<MenuIcon>{variableDefineMap[v.name].icon}</MenuIcon>}
prefixIcon={variableDefineMap[v.name].icon}
key={v.name}
onClick={() => {
onSelect(createDefaultFilter(v, propertiesMeta));

View File

@@ -1,7 +1,6 @@
import {
IconButton,
Menu,
MenuIcon,
MenuItem,
toast,
useConfirmModal,
@@ -20,8 +19,6 @@ import {
DeletePermanentlyIcon,
DuplicateIcon,
EditIcon,
FavoritedIcon,
FavoriteIcon,
FilterIcon,
FilterMinusIcon,
InformationIcon,
@@ -44,6 +41,7 @@ import { useCallback, useState } from 'react';
import type { CollectionService } from '../../modules/collection';
import { InfoModal } from '../affine/page-properties';
import { usePageHelper } from '../blocksuite/block-suite-page-list/utils';
import { IsFavoriteIcon } from '../pure/icons';
import { FavoriteTag } from './components/favorite-tag';
import * as styles from './list.css';
import { DisablePublicSharing, MoveToTrash } from './operation-menu-items';
@@ -164,76 +162,36 @@ export const PageOperationCell = ({
{isInAllowList && (
<MenuItem
onClick={handleRemoveFromAllowList}
preFix={
<MenuIcon>
<FilterMinusIcon />
</MenuIcon>
}
prefixIcon={<FilterMinusIcon />}
>
{t['Remove special filter']()}
</MenuItem>
)}
<MenuItem
onClick={onToggleFavoritePageOption}
preFix={
<MenuIcon>
{favourite ? (
<FavoritedIcon style={{ color: 'var(--affine-primary-color)' }} />
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favourite} />}
>
{favourite
? t['com.affine.favoritePageOperation.remove']()
: t['com.affine.favoritePageOperation.add']()}
</MenuItem>
{runtimeConfig.enableInfoModal ? (
<MenuItem
onClick={onOpenInfoModal}
preFix={
<MenuIcon>
<InformationIcon />
</MenuIcon>
}
>
<MenuItem onClick={onOpenInfoModal} prefixIcon={<InformationIcon />}>
{t['com.affine.page-properties.page-info.view']()}
</MenuItem>
) : null}
<MenuItem
onClick={onOpenInNewTab}
preFix={
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
}
>
<MenuItem onClick={onOpenInNewTab} prefixIcon={<OpenInNewIcon />}>
{t['com.affine.workbench.tab.page-menu-open']()}
</MenuItem>
{environment.isDesktop && enableSplitView ? (
<MenuItem
onClick={onOpenInSplitView}
preFix={
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
}
>
<MenuItem onClick={onOpenInSplitView} prefixIcon={<SplitViewIcon />}>
{t['com.affine.workbench.split-view.page-menu-open']()}
</MenuItem>
) : null}
<MenuItem
preFix={
<MenuIcon>
<DuplicateIcon />
</MenuIcon>
}
onSelect={onDuplicate}
>
<MenuItem prefixIcon={<DuplicateIcon />} onSelect={onDuplicate}>
{t['com.affine.header.option.duplicate']()}
</MenuItem>
@@ -459,17 +417,7 @@ export const CollectionOperationCell = ({
<>
<MenuItem
onClick={onToggleFavoriteCollection}
preFix={
<MenuIcon>
{favourite ? (
<FavoritedIcon
style={{ color: 'var(--affine-primary-color)' }}
/>
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favourite} />}
>
{favourite
? t['com.affine.favoritePageOperation.remove']()
@@ -477,21 +425,13 @@ export const CollectionOperationCell = ({
</MenuItem>
<MenuItem
onClick={onConfirmAddDocToCollection}
preFix={
<MenuIcon>
<PlusIcon />
</MenuIcon>
}
prefixIcon={<PlusIcon />}
>
{t['New Page']()}
</MenuItem>
<MenuItem
onClick={handleDelete}
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
type="danger"
data-testid="delete-collection"
>
@@ -566,11 +506,7 @@ export const TagOperationCell = ({
<Menu
items={
<MenuItem
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
type="danger"
onSelect={handleDelete}
data-testid="delete-tag"

View File

@@ -1,5 +1,5 @@
import type { MenuItemProps } from '@affine/component';
import { MenuIcon, MenuItem } from '@affine/component';
import { MenuItem } from '@affine/component';
import { PublicLinkDisableModal } from '@affine/component/disable-public-link';
import { useI18n } from '@affine/i18n';
import { ShareIcon } from '@blocksuite/icons/rc';
@@ -7,15 +7,7 @@ import { ShareIcon } from '@blocksuite/icons/rc';
export const DisablePublicSharing = (props: MenuItemProps) => {
const t = useI18n();
return (
<MenuItem
type="danger"
preFix={
<MenuIcon>
<ShareIcon />
</MenuIcon>
}
{...props}
>
<MenuItem type="danger" prefixIcon={<ShareIcon />} {...props}>
{t['Disable Public Sharing']()}
</MenuItem>
);

View File

@@ -1,4 +1,4 @@
import { MenuIcon, MenuItem, MenuSub } from '@affine/component';
import { MenuItem, MenuSub } from '@affine/component';
import { track } from '@affine/core/mixpanel';
import { useI18n } from '@affine/i18n';
import {
@@ -40,7 +40,7 @@ export function ExportMenuItem<T>({
data-testid={`export-to-${type}`}
onSelect={onSelect}
block
preFix={<MenuIcon>{icon}</MenuIcon>}
prefixIcon={icon}
>
{label}
</MenuItem>
@@ -127,11 +127,7 @@ export const Export = ({ exportHandler, className, pageMode }: ExportProps) => {
items={items}
triggerOptions={{
className: transitionStyle,
preFix: (
<MenuIcon>
<ExportIcon />
</MenuIcon>
),
prefixIcon: <ExportIcon />,
['data-testid' as string]: 'export-menu',
}}
subOptions={{

View File

@@ -1,5 +1,5 @@
import type { ConfirmModalProps, MenuItemProps } from '@affine/component';
import { ConfirmModal, MenuIcon, MenuItem } from '@affine/component';
import { ConfirmModal, MenuItem } from '@affine/component';
import { useI18n } from '@affine/i18n';
import { DeleteIcon } from '@blocksuite/icons/rc';
@@ -7,15 +7,7 @@ export const MoveToTrash = (props: MenuItemProps) => {
const t = useI18n();
return (
<MenuItem
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
type="danger"
{...props}
>
<MenuItem prefixIcon={<DeleteIcon />} type="danger" {...props}>
{t['com.affine.moveToTrash.title']()}
</MenuItem>
);

View File

@@ -1,5 +1,5 @@
import type { MenuItemProps } from '@affine/component';
import { Menu, MenuIcon, MenuItem } from '@affine/component';
import { Menu, MenuItem } from '@affine/component';
import { useDeleteCollectionInfo } from '@affine/core/hooks/affine/use-delete-collection-info';
import { CompatibleFavoriteItemsAdapter } from '@affine/core/modules/properties';
import { WorkbenchService } from '@affine/core/modules/workbench';
@@ -8,8 +8,6 @@ import { useI18n } from '@affine/i18n';
import {
DeleteIcon,
EditIcon,
FavoritedIcon,
FavoriteIcon,
FilterIcon,
OpenInNewIcon,
PlusIcon,
@@ -25,6 +23,7 @@ import type { PropsWithChildren, ReactElement } from 'react';
import { useCallback, useMemo } from 'react';
import { CollectionService } from '../../../modules/collection';
import { IsFavoriteIcon } from '../../pure/icons';
import * as styles from './collection-operations.css';
import {
useEditCollection,
@@ -127,68 +126,40 @@ export const CollectionOperations = ({
>(
() => [
{
icon: (
<MenuIcon>
<EditIcon />
</MenuIcon>
),
icon: <EditIcon />,
name: t['com.affine.collection.menu.rename'](),
click: showEditName,
},
{
icon: (
<MenuIcon>
<FilterIcon />
</MenuIcon>
),
icon: <FilterIcon />,
name: t['com.affine.collection.menu.edit'](),
click: showEdit,
},
...(onAddDocToCollection
? [
{
icon: (
<MenuIcon>
<PlusIcon />
</MenuIcon>
),
icon: <PlusIcon />,
name: t['New Page'](),
click: onAddDocToCollection,
},
]
: []),
{
icon: (
<MenuIcon>
{favorite ? (
<FavoritedIcon style={{ color: 'var(--affine-primary-color)' }} />
) : (
<FavoriteIcon />
)}
</MenuIcon>
),
icon: <IsFavoriteIcon favorite={favorite} />,
name: favorite
? t['com.affine.favoritePageOperation.remove']()
: t['com.affine.favoritePageOperation.add'](),
click: onToggleFavoritePage,
},
{
icon: (
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
),
icon: <OpenInNewIcon />,
name: t['com.affine.workbench.tab.page-menu-open'](),
click: openCollectionNewTab,
},
...(enableMultiView && environment.isDesktop
? [
{
icon: (
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
),
icon: <SplitViewIcon />,
name: t['com.affine.workbench.split-view.page-menu-open'](),
click: openCollectionSplitView,
},
@@ -198,11 +169,7 @@ export const CollectionOperations = ({
element: <div key="divider" className={styles.divider}></div>,
},
{
icon: (
<MenuIcon>
<DeleteIcon />
</MenuIcon>
),
icon: <DeleteIcon />,
name: t['Delete'](),
click: () => {
service.deleteCollection(deleteInfo, collection.id);
@@ -241,7 +208,7 @@ export const CollectionOperations = ({
data-testid="collection-option"
key={action.name}
type={action.type}
preFix={action.icon}
prefixIcon={action.icon}
onClick={action.click}
>
{action.name}

View File

@@ -0,0 +1,18 @@
import { FavoritedIcon, FavoriteIcon } from '@blocksuite/icons/rc';
import { cssVar } from '@toeverything/theme';
import type { SVGProps } from 'react';
export const IsFavoriteIcon = ({
favorite,
style,
...props
}: { favorite?: boolean } & SVGProps<SVGSVGElement>) => {
return favorite ? (
<FavoritedIcon
style={{ color: cssVar('primaryColor'), ...style }}
{...props}
/>
) : (
<FavoriteIcon style={style} {...props} />
);
};

View File

@@ -1,28 +1 @@
import {
CloudWorkspaceIcon as DefaultCloudWorkspaceIcon,
CollaborationIcon as DefaultJoinedWorkspaceIcon,
LocalDataIcon as DefaultLocalDataIcon,
LocalWorkspaceIcon as DefaultLocalWorkspaceIcon,
PublishIcon as DefaultPublishIcon,
} from '@blocksuite/icons/rc';
// Here are some icons with special color or size
export const JoinedWorkspaceIcon = () => {
return <DefaultJoinedWorkspaceIcon style={{ color: '#FF646B' }} />;
};
export const LocalWorkspaceIcon = () => {
return <DefaultLocalWorkspaceIcon style={{ color: '#FDBD32' }} />;
};
export const CloudWorkspaceIcon = () => {
return <DefaultCloudWorkspaceIcon style={{ color: '#60A5FA' }} />;
};
export const LocalDataIcon = () => {
return <DefaultLocalDataIcon style={{ color: '#62CD80' }} />;
};
export const PublishIcon = () => {
return <DefaultPublishIcon style={{ color: '#8699FF' }} />;
};
export * from './favorite-icon';

View File

@@ -18,7 +18,7 @@ export const AddWorkspace = ({
{environment.isDesktop ? (
<MenuItem
block={true}
preFix={<ImportIcon />}
prefixIcon={<ImportIcon />}
onClick={onAddWorkspace}
data-testid="add-workspace"
className={styles.ItemContainer}
@@ -30,7 +30,7 @@ export const AddWorkspace = ({
) : null}
<MenuItem
block={true}
preFix={<PlusIcon />}
prefixIcon={<PlusIcon />}
onClick={onNewWorkspace}
data-testid="new-workspace"
className={styles.ItemContainer}

View File

@@ -4,7 +4,6 @@ import {
ErrorMessage,
IconButton,
Menu,
MenuIcon,
MenuItem,
type MenuProps,
Skeleton,
@@ -100,22 +99,14 @@ const AccountMenu = () => {
return (
<>
<MenuItem
preFix={
<MenuIcon>
<AccountIcon />
</MenuIcon>
}
prefixIcon={<AccountIcon />}
data-testid="workspace-modal-account-settings-option"
onClick={onOpenAccountSetting}
>
{t['com.affine.workspace.cloud.account.settings']()}
</MenuItem>
<MenuItem
preFix={
<MenuIcon>
<SignOutIcon />
</MenuIcon>
}
prefixIcon={<SignOutIcon />}
data-testid="workspace-modal-sign-out-option"
onClick={onOpenSignOutModal}
>

View File

@@ -2,7 +2,6 @@ import {
AnimatedCollectionsIcon,
type DropTargetDropEvent,
type DropTargetOptions,
MenuIcon,
MenuItem,
toast,
} from '@affine/component';
@@ -320,11 +319,7 @@ const ExplorerCollectionNodeChildren = ({
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<FilterMinusIcon />
</MenuIcon>
}
prefixIcon={<FilterMinusIcon />}
onClick={() => handleRemoveFromAllowList(doc.id)}
>
{t['Remove special filter']()}

View File

@@ -1,10 +1,10 @@
import {
IconButton,
MenuIcon,
MenuItem,
MenuSeparator,
useConfirmModal,
} from '@affine/component';
import { IsFavoriteIcon } from '@affine/core/components/pure/icons';
import { useDeleteCollectionInfo } from '@affine/core/hooks/affine/use-delete-collection-info';
import { track } from '@affine/core/mixpanel';
import { CollectionService } from '@affine/core/modules/collection';
@@ -13,8 +13,6 @@ import { WorkbenchService } from '@affine/core/modules/workbench';
import { useI18n } from '@affine/i18n';
import {
DeleteIcon,
FavoritedIcon,
FavoriteIcon,
FilterIcon,
OpenInNewIcon,
PlusIcon,
@@ -143,14 +141,7 @@ export const useExplorerCollectionNodeOperations = (
{
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<FilterIcon />
</MenuIcon>
}
onClick={handleShowEdit}
>
<MenuItem prefixIcon={<FilterIcon />} onClick={handleShowEdit}>
{t['com.affine.collection.menu.edit']()}
</MenuItem>
),
@@ -159,11 +150,7 @@ export const useExplorerCollectionNodeOperations = (
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<PlusIcon />
</MenuIcon>
}
prefixIcon={<PlusIcon />}
onClick={handleAddDocToCollection}
>
{t['New Page']()}
@@ -174,17 +161,7 @@ export const useExplorerCollectionNodeOperations = (
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
{favorite ? (
<FavoritedIcon
style={{ color: 'var(--affine-primary-color)' }}
/>
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favorite} />}
onClick={handleToggleFavoriteCollection}
>
{favorite
@@ -196,14 +173,7 @@ export const useExplorerCollectionNodeOperations = (
{
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
}
onClick={handleOpenInNewTab}
>
<MenuItem prefixIcon={<OpenInNewIcon />} onClick={handleOpenInNewTab}>
{t['com.affine.workbench.tab.page-menu-open']()}
</MenuItem>
),
@@ -214,11 +184,7 @@ export const useExplorerCollectionNodeOperations = (
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
}
prefixIcon={<SplitViewIcon />}
onClick={handleOpenInSplitView}
>
{t['com.affine.workbench.split-view.page-menu-open']()}
@@ -236,11 +202,7 @@ export const useExplorerCollectionNodeOperations = (
view: (
<MenuItem
type={'danger'}
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
onClick={handleDeleteCollection}
>
{t['Delete']()}

View File

@@ -1,11 +1,11 @@
import {
IconButton,
MenuIcon,
MenuItem,
MenuSeparator,
toast,
useConfirmModal,
} from '@affine/component';
import { IsFavoriteIcon } from '@affine/core/components/pure/icons';
import { useAsyncCallback } from '@affine/core/hooks/affine-async-hooks';
import { track } from '@affine/core/mixpanel';
import { CompatibleFavoriteItemsAdapter } from '@affine/core/modules/properties';
@@ -13,8 +13,6 @@ import { WorkbenchService } from '@affine/core/modules/workbench';
import { useI18n } from '@affine/i18n';
import {
DeleteIcon,
FavoritedIcon,
FavoriteIcon,
InformationIcon,
LinkedPageIcon,
OpenInNewIcon,
@@ -147,11 +145,7 @@ export const useExplorerDocNodeOperations = (
index: 50,
view: (
<MenuItem
preFix={
<MenuIcon>
<InformationIcon />
</MenuIcon>
}
prefixIcon={<InformationIcon />}
onClick={handleOpenInfoModal}
>
{t['com.affine.page-properties.page-info.view']()}
@@ -164,11 +158,7 @@ export const useExplorerDocNodeOperations = (
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<LinkedPageIcon />
</MenuIcon>
}
prefixIcon={<LinkedPageIcon />}
onClick={handleAddLinkedPage}
>
{t['com.affine.page-operation.add-linked-page']()}
@@ -178,14 +168,7 @@ export const useExplorerDocNodeOperations = (
{
index: 99,
view: (
<MenuItem
preFix={
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
}
onClick={handleOpenInNewTab}
>
<MenuItem prefixIcon={<OpenInNewIcon />} onClick={handleOpenInNewTab}>
{t['com.affine.workbench.tab.page-menu-open']()}
</MenuItem>
),
@@ -196,11 +179,7 @@ export const useExplorerDocNodeOperations = (
index: 100,
view: (
<MenuItem
preFix={
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
}
prefixIcon={<SplitViewIcon />}
onClick={handleOpenInSplitView}
>
{t['com.affine.workbench.split-view.page-menu-open']()}
@@ -213,17 +192,7 @@ export const useExplorerDocNodeOperations = (
index: 199,
view: (
<MenuItem
preFix={
<MenuIcon>
{favorite ? (
<FavoritedIcon
style={{ color: 'var(--affine-primary-color)' }}
/>
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favorite} />}
onClick={handleToggleFavoriteDoc}
>
{favorite
@@ -241,11 +210,7 @@ export const useExplorerDocNodeOperations = (
view: (
<MenuItem
type={'danger'}
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
onClick={handleMoveToTrash}
>
{t['com.affine.moveToTrash.title']()}

View File

@@ -4,7 +4,6 @@ import {
type DropTargetDropEvent,
type DropTargetOptions,
IconButton,
MenuIcon,
MenuItem,
MenuSeparator,
MenuSub,
@@ -632,14 +631,7 @@ export const ExplorerFolderNodeFolder = ({
{
index: 100,
view: (
<MenuItem
preFix={
<MenuIcon>
<FolderIcon />
</MenuIcon>
}
onClick={handleCreateSubfolder}
>
<MenuItem prefixIcon={<FolderIcon />} onClick={handleCreateSubfolder}>
{t['com.affine.rootAppSidebar.organize.folder.create-subfolder']()}
</MenuItem>
),
@@ -648,11 +640,7 @@ export const ExplorerFolderNodeFolder = ({
index: 101,
view: (
<MenuItem
preFix={
<MenuIcon>
<PageIcon />
</MenuIcon>
}
prefixIcon={<PageIcon />}
onClick={() => handleAddToFolder('doc')}
>
{t['com.affine.rootAppSidebar.organize.folder.add-docs']()}
@@ -664,31 +652,19 @@ export const ExplorerFolderNodeFolder = ({
view: (
<MenuSub
triggerOptions={{
preFix: (
<MenuIcon>
<PlusThickIcon />
</MenuIcon>
),
prefixIcon: <PlusThickIcon />,
}}
items={
<>
<MenuItem
onClick={() => handleAddToFolder('tag')}
preFix={
<MenuIcon>
<TagsIcon />
</MenuIcon>
}
prefixIcon={<TagsIcon />}
>
{t['com.affine.rootAppSidebar.organize.folder.add-tags']()}
</MenuItem>
<MenuItem
onClick={() => handleAddToFolder('collection')}
preFix={
<MenuIcon>
<AnimatedCollectionsIcon closed={false} />
</MenuIcon>
}
prefixIcon={<AnimatedCollectionsIcon closed={false} />}
>
{t[
'com.affine.rootAppSidebar.organize.folder.add-collections'
@@ -716,11 +692,7 @@ export const ExplorerFolderNodeFolder = ({
view: (
<MenuItem
type={'danger'}
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
onClick={handleDelete}
>
{t['com.affine.rootAppSidebar.organize.delete']()}
@@ -754,11 +726,7 @@ export const ExplorerFolderNodeFolder = ({
view: (
<MenuItem
type={'danger'}
preFix={
<MenuIcon>
<RemoveFolderIcon />
</MenuIcon>
}
prefixIcon={<RemoveFolderIcon />}
data-event-props="$.navigationPanel.organize.deleteOrganizeItem"
data-event-args-type={node.type$.value}
onClick={() => node.delete()}

View File

@@ -1,9 +1,8 @@
import { MenuIcon, MenuItem } from '@affine/component';
import { MenuItem } from '@affine/component';
import { IsFavoriteIcon } from '@affine/core/components/pure/icons';
import { CompatibleFavoriteItemsAdapter } from '@affine/core/modules/properties';
import { useI18n } from '@affine/i18n';
import { FavoritedIcon, FavoriteIcon } from '@blocksuite/icons/rc';
import { useLiveData, useService } from '@toeverything/infra';
import { cssVar } from '@toeverything/theme';
import { useMemo } from 'react';
export const FavoriteFolderOperation = ({ id }: { id: string }) => {
@@ -20,15 +19,7 @@ export const FavoriteFolderOperation = ({ id }: { id: string }) => {
return (
<MenuItem
preFix={
<MenuIcon>
{favorite ? (
<FavoritedIcon style={{ color: cssVar('primaryColor') }} />
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={favorite} />}
onClick={() => compatibleFavoriteItemsAdapter.toggle(id, 'folder')}
>
{favorite

View File

@@ -1,10 +1,5 @@
import {
IconButton,
MenuIcon,
MenuItem,
MenuSeparator,
toast,
} from '@affine/component';
import { IconButton, MenuItem, MenuSeparator, toast } from '@affine/component';
import { IsFavoriteIcon } from '@affine/core/components/pure/icons';
import { track } from '@affine/core/mixpanel';
import { FavoriteService } from '@affine/core/modules/favorite';
import { TagService } from '@affine/core/modules/tag';
@@ -12,8 +7,6 @@ import { WorkbenchService } from '@affine/core/modules/workbench';
import { useI18n } from '@affine/i18n';
import {
DeleteIcon,
FavoritedIcon,
FavoriteIcon,
OpenInNewIcon,
PlusIcon,
SplitViewIcon,
@@ -114,14 +107,7 @@ export const useExplorerTagNodeOperations = (
{
index: 50,
view: (
<MenuItem
preFix={
<MenuIcon>
<OpenInNewIcon />
</MenuIcon>
}
onClick={handleOpenInNewTab}
>
<MenuItem prefixIcon={<OpenInNewIcon />} onClick={handleOpenInNewTab}>
{t['com.affine.workbench.tab.page-menu-open']()}
</MenuItem>
),
@@ -132,11 +118,7 @@ export const useExplorerTagNodeOperations = (
index: 100,
view: (
<MenuItem
preFix={
<MenuIcon>
<SplitViewIcon />
</MenuIcon>
}
prefixIcon={<SplitViewIcon />}
onClick={handleOpenInSplitView}
>
{t['com.affine.workbench.split-view.page-menu-open']()}
@@ -149,17 +131,7 @@ export const useExplorerTagNodeOperations = (
index: 199,
view: (
<MenuItem
preFix={
<MenuIcon>
{favorite ? (
<FavoritedIcon
style={{ color: 'var(--affine-primary-color)' }}
/>
) : (
<FavoriteIcon />
)}
</MenuIcon>
}
prefixIcon={<IsFavoriteIcon favorite={!!favorite} />}
onClick={handleToggleFavoriteTag}
>
{favorite
@@ -177,11 +149,7 @@ export const useExplorerTagNodeOperations = (
view: (
<MenuItem
type={'danger'}
preFix={
<MenuIcon>
<DeleteIcon />
</MenuIcon>
}
prefixIcon={<DeleteIcon />}
onClick={handleMoveToTrash}
>
{t['Delete']()}

View File

@@ -5,7 +5,6 @@ import {
type DropTargetTreeInstruction,
IconButton,
Menu,
MenuIcon,
MenuItem,
useDraggable,
useDropTarget,
@@ -246,11 +245,7 @@ export const ExplorerTreeNode = ({
<MenuItem
key={'explorer-tree-rename'}
type={'default'}
preFix={
<MenuIcon>
<EditIcon />
</MenuIcon>
}
prefixIcon={<EditIcon />}
onClick={() => setRenaming(true)}
>
{t['com.affine.menu.rename']()}

View File

@@ -1,4 +1,4 @@
import { MenuIcon, MenuItem } from '@affine/component';
import { MenuItem } from '@affine/component';
import { useI18n } from '@affine/i18n';
import {
ExpandCloseIcon,
@@ -137,30 +137,21 @@ const SplitViewMenu = ({ view }: { view: View }) => {
const CloseItem =
views.length > 1 ? (
<MenuItem
preFix={<MenuIcon icon={<ExpandCloseIcon />} />}
onClick={handleClose}
>
<MenuItem prefixIcon={<ExpandCloseIcon />} onClick={handleClose}>
{t['com.affine.workbench.split-view-menu.close']()}
</MenuItem>
) : null;
const MoveLeftItem =
viewIndex > 0 && views.length > 1 ? (
<MenuItem
onClick={handleMoveLeft}
preFix={<MenuIcon icon={<MoveToLeftDuotoneIcon />} />}
>
<MenuItem onClick={handleMoveLeft} prefixIcon={<MoveToLeftDuotoneIcon />}>
{t['com.affine.workbench.split-view-menu.move-left']()}
</MenuItem>
) : null;
const FullScreenItem =
views.length > 1 ? (
<MenuItem
onClick={handleCloseOthers}
preFix={<MenuIcon icon={<SoloViewIcon />} />}
>
<MenuItem onClick={handleCloseOthers} prefixIcon={<SoloViewIcon />}>
{t['com.affine.workbench.split-view-menu.keep-this-one']()}
</MenuItem>
) : null;
@@ -169,7 +160,7 @@ const SplitViewMenu = ({ view }: { view: View }) => {
viewIndex < views.length - 1 ? (
<MenuItem
onClick={handleMoveRight}
preFix={<MenuIcon icon={<MoveToRightDuotoneIcon />} />}
prefixIcon={<MoveToRightDuotoneIcon />}
>
{t['com.affine.workbench.split-view-menu.move-right']()}
</MenuItem>