/* * Copyright 2025 coze-dev Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { type FC } from 'react'; import { I18n } from '@coze-arch/i18n'; import { Menu } from '@coze-arch/coze-design'; import { PopInScreen } from '../pop-in-screen'; import { CopyMode } from '../../typings'; interface IProps { left?: number; top?: number; offsetY?: number; offsetX?: number; cancelMenu?: () => void; hasActiveObject?: boolean; copy?: (mode: CopyMode) => void; paste?: (options: { mode?: CopyMode }) => void; disabledPaste?: boolean; moveToFront?: () => void; moveToBackend?: () => void; moveToFrontOne?: () => void; moveToBackendOne?: () => void; isActiveObjectsInBack?: boolean; isActiveObjectsInFront?: boolean; limitRect?: { width?: number; height?: number; }; } export const ContentMenu: FC = props => { const { left = 0, top = 0, offsetX = 0, offsetY = 0, cancelMenu, hasActiveObject, copy, paste, moveToFront, moveToBackend, moveToFrontOne, moveToBackendOne, isActiveObjectsInBack, isActiveObjectsInFront, disabledPaste, limitRect, } = props; const isMac = navigator.platform.toLowerCase().includes('mac'); const ctrlKey = isMac ? '⌘' : 'ctrl'; const menuItems = [ { label: I18n.t('imageflow_canvas_copy'), suffix: `${ctrlKey} + C`, onClick: () => { copy?.(CopyMode.CtrlCV); }, }, { label: I18n.t('imageflow_canvas_paste'), suffix: `${ctrlKey} + V`, onClick: () => { paste?.({ mode: CopyMode.CtrlCV }); }, disabled: disabledPaste, alwaysShow: true, }, { label: I18n.t('Copy'), suffix: `${ctrlKey} + D`, onClick: async () => { await copy?.(CopyMode.CtrlD); paste?.({ mode: CopyMode.CtrlD }); }, }, { key: 'divider1', divider: true, }, { label: I18n.t('imageflow_canvas_top_1'), suffix: ']', onClick: () => { moveToFrontOne?.(); }, disabled: isActiveObjectsInFront, }, { label: I18n.t('imageflow_canvas_down_1'), suffix: '[', onClick: () => { moveToBackendOne?.(); }, disabled: isActiveObjectsInBack, }, { label: I18n.t('imageflow_canvas_to_front'), suffix: `${ctrlKey} + ]`, onClick: () => { moveToFront?.(); }, disabled: isActiveObjectsInFront, }, { label: I18n.t('imageflow_canvas_to_back'), suffix: `${ctrlKey} + [`, onClick: () => { moveToBackend?.(); }, disabled: isActiveObjectsInBack, }, ].filter(item => item.alwaysShow ?? hasActiveObject); return ( { e.stopPropagation(); cancelMenu?.(); }} limitRect={limitRect} > {menuItems.map(d => { if (d.divider) { return ; } return (
{d.label}
{d.suffix}
); })}
); };