* feat(ui): 完善 UI 布局系统和编辑器可视化工具 * refactor: 移除 ModuleRegistry,统一使用 PluginManager 插件系统 * fix: 修复 CodeQL 警告并提升测试覆盖率 * refactor: 分离运行时入口点,解决 runtime bundle 包含 React 的问题 * fix(ci): 添加 editor-core 和 editor-runtime 到 CI 依赖构建步骤 * docs: 完善 ServiceContainer 文档,新增 Symbol.for 模式和 @InjectProperty 说明 * fix(ci): 修复 type-check 失败问题 * fix(ci): 修复类型检查失败问题 * fix(ci): 修复类型检查失败问题 * fix(ci): behavior-tree 构建添加 @tauri-apps 外部依赖 * fix(ci): behavior-tree 添加 @tauri-apps/plugin-fs 类型依赖 * fix(ci): platform-web 添加缺失的 behavior-tree 依赖 * fix(lint): 移除正则表达式中不必要的转义字符
77 lines
2.1 KiB
TypeScript
77 lines
2.1 KiB
TypeScript
import { useRef, useCallback, useMemo, useEffect, CommandManager } from '@esengine/editor-runtime';
|
|
|
|
/**
|
|
* 撤销/重做功能 Hook
|
|
*/
|
|
export function useCommandHistory() {
|
|
const commandManagerRef = useRef<CommandManager>(new CommandManager());
|
|
|
|
const commandManager = commandManagerRef.current;
|
|
|
|
const canUndo = useCallback(() => {
|
|
return commandManager.canUndo();
|
|
}, [commandManager]);
|
|
|
|
const canRedo = useCallback(() => {
|
|
return commandManager.canRedo();
|
|
}, [commandManager]);
|
|
|
|
const undo = useCallback(() => {
|
|
if (commandManager.canUndo()) {
|
|
commandManager.undo();
|
|
}
|
|
}, [commandManager]);
|
|
|
|
const redo = useCallback(() => {
|
|
if (commandManager.canRedo()) {
|
|
commandManager.redo();
|
|
}
|
|
}, [commandManager]);
|
|
|
|
const getUndoHistory = useCallback(() => {
|
|
return commandManager.getUndoHistory();
|
|
}, [commandManager]);
|
|
|
|
const getRedoHistory = useCallback(() => {
|
|
return commandManager.getRedoHistory();
|
|
}, [commandManager]);
|
|
|
|
const clear = useCallback(() => {
|
|
commandManager.clear();
|
|
}, [commandManager]);
|
|
|
|
// 键盘快捷键
|
|
useEffect(() => {
|
|
const handleKeyDown = (e: KeyboardEvent) => {
|
|
const isMac = navigator.platform.toUpperCase().indexOf('MAC') >= 0;
|
|
const isCtrlOrCmd = isMac ? e.metaKey : e.ctrlKey;
|
|
|
|
if (isCtrlOrCmd && e.key === 'z') {
|
|
e.preventDefault();
|
|
if (e.shiftKey) {
|
|
redo();
|
|
} else {
|
|
undo();
|
|
}
|
|
} else if (isCtrlOrCmd && e.key === 'y') {
|
|
e.preventDefault();
|
|
redo();
|
|
}
|
|
};
|
|
|
|
window.addEventListener('keydown', handleKeyDown);
|
|
return () => window.removeEventListener('keydown', handleKeyDown);
|
|
}, [undo, redo]);
|
|
|
|
return {
|
|
commandManager,
|
|
canUndo: canUndo(),
|
|
canRedo: canRedo(),
|
|
undo,
|
|
redo,
|
|
getUndoHistory,
|
|
getRedoHistory,
|
|
clear
|
|
};
|
|
}
|