Feature/editor optimization (#251)

* refactor: 编辑器/运行时架构拆分与构建系统升级

* feat(core): 层级系统重构与UI变换矩阵修复

* refactor: 移除 ecs-components 聚合包并修复跨包组件查找问题

* fix(physics): 修复跨包组件类引用问题

* feat: 统一运行时架构与浏览器运行支持

* feat(asset): 实现浏览器运行时资产加载系统

* fix: 修复文档、CodeQL安全问题和CI类型检查错误

* fix: 修复文档、CodeQL安全问题和CI类型检查错误

* fix: 修复文档、CodeQL安全问题、CI类型检查和测试错误

* test: 补齐核心模块测试用例,修复CI构建配置

* fix: 修复测试用例中的类型错误和断言问题

* fix: 修复 turbo build:npm 任务的依赖顺序问题

* fix: 修复 CI 构建错误并优化构建性能
This commit is contained in:
YHH
2025-12-01 22:28:51 +08:00
committed by GitHub
parent 189714c727
commit b42a7b4e43
468 changed files with 18301 additions and 9075 deletions

View File

@@ -5,7 +5,7 @@
import type { ServiceContainer } from '@esengine/ecs-framework';
import { createLogger } from '@esengine/ecs-framework';
import type { IPluginLoader, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import type { IPlugin, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import { SettingsRegistry } from '@esengine/editor-core';
import { SettingsService } from '../../services/SettingsService';
@@ -122,7 +122,7 @@ const descriptor: PluginDescriptor = {
]
};
export const EditorAppearancePlugin: IPluginLoader = {
export const EditorAppearancePlugin: IPlugin = {
descriptor,
editorModule: new EditorAppearanceEditorModule()
};

View File

@@ -4,7 +4,7 @@
*/
import type { ServiceContainer } from '@esengine/ecs-framework';
import type { IPluginLoader, IEditorModuleLoader, PluginDescriptor, GizmoProviderRegistration } from '@esengine/editor-core';
import type { IPlugin, IEditorModuleLoader, PluginDescriptor, GizmoProviderRegistration } from '@esengine/editor-core';
import { registerSpriteGizmo } from '../../gizmos';
/**
@@ -44,7 +44,7 @@ const descriptor: PluginDescriptor = {
]
};
export const GizmoPlugin: IPluginLoader = {
export const GizmoPlugin: IPlugin = {
descriptor,
editorModule: new GizmoEditorModule()
};

View File

@@ -5,7 +5,7 @@
import type { ServiceContainer } from '@esengine/ecs-framework';
import { createLogger } from '@esengine/ecs-framework';
import type { IPluginLoader, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import type { IPlugin, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import { SettingsRegistry } from '@esengine/editor-core';
const logger = createLogger('PluginConfigPlugin');
@@ -71,7 +71,7 @@ const descriptor: PluginDescriptor = {
]
};
export const PluginConfigPlugin: IPluginLoader = {
export const PluginConfigPlugin: IPlugin = {
descriptor,
editorModule: new PluginConfigEditorModule()
};

View File

@@ -5,14 +5,12 @@
import type { ServiceContainer } from '@esengine/ecs-framework';
import type {
IPluginLoader,
IPlugin,
IEditorModuleLoader,
PluginDescriptor,
PanelDescriptor,
MenuItemDescriptor
} from '@esengine/editor-core';
import { MessageHub, SettingsRegistry, PanelPosition } from '@esengine/editor-core';
import { ProfilerDockPanel } from '../../components/ProfilerDockPanel';
import { MessageHub, SettingsRegistry } from '@esengine/editor-core';
import { ProfilerService } from '../../services/ProfilerService';
/**
@@ -100,19 +98,6 @@ class ProfilerEditorModule implements IEditorModuleLoader {
delete (window as any).__PROFILER_SERVICE__;
}
getPanels(): PanelDescriptor[] {
return [
{
id: 'profiler-monitor',
title: 'Performance Monitor',
position: PanelPosition.Center,
closable: false,
component: ProfilerDockPanel,
order: 200
}
];
}
getMenuItems(): MenuItemDescriptor[] {
return [
{
@@ -122,14 +107,6 @@ class ProfilerEditorModule implements IEditorModuleLoader {
execute: () => {
this.messageHub?.publish('ui:openWindow', { windowId: 'profiler' });
}
},
{
id: 'window.advancedProfiler',
label: 'Advanced Profiler',
parentId: 'window',
execute: () => {
this.messageHub?.publish('ui:openWindow', { windowId: 'advancedProfiler' });
}
}
];
}
@@ -151,13 +128,12 @@ const descriptor: PluginDescriptor = {
{
name: 'ProfilerEditor',
type: 'editor',
loadingPhase: 'postDefault',
panels: ['profiler-monitor']
loadingPhase: 'postDefault'
}
]
};
export const ProfilerPlugin: IPluginLoader = {
export const ProfilerPlugin: IPlugin = {
descriptor,
editorModule: new ProfilerEditorModule()
};

View File

@@ -8,7 +8,7 @@
import type { ServiceContainer } from '@esengine/ecs-framework';
import { createLogger, Core } from '@esengine/ecs-framework';
import type { IPluginLoader, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import type { IPlugin, IEditorModuleLoader, PluginDescriptor } from '@esengine/editor-core';
import { SettingsRegistry, ProjectService } from '@esengine/editor-core';
import EngineService from '../../services/EngineService';
@@ -167,7 +167,7 @@ const descriptor: PluginDescriptor = {
]
};
export const ProjectSettingsPlugin: IPluginLoader = {
export const ProjectSettingsPlugin: IPlugin = {
descriptor,
editorModule: new ProjectSettingsEditorModule()
};

View File

@@ -6,7 +6,7 @@
import { Core, Entity } from '@esengine/ecs-framework';
import type { ServiceContainer } from '@esengine/ecs-framework';
import type {
IPluginLoader,
IPlugin,
IEditorModuleLoader,
PluginDescriptor,
PanelDescriptor,
@@ -15,7 +15,9 @@ import type {
EntityCreationTemplate
} from '@esengine/editor-core';
import { PanelPosition, EntityStoreService, MessageHub } from '@esengine/editor-core';
import { TransformComponent, SpriteComponent, SpriteAnimatorComponent, CameraComponent } from '@esengine/ecs-components';
import { TransformComponent } from '@esengine/engine-core';
import { SpriteComponent, SpriteAnimatorComponent } from '@esengine/sprite';
import { CameraComponent } from '@esengine/camera';
/**
* Scene Inspector 编辑器模块
@@ -186,14 +188,12 @@ const descriptor: PluginDescriptor = {
{
name: 'SceneInspectorEditor',
type: 'editor',
loadingPhase: 'default',
panels: ['panel-scene-hierarchy', 'panel-entity-inspector'],
inspectors: ['EntityInspector']
loadingPhase: 'default'
}
]
};
export const SceneInspectorPlugin: IPluginLoader = {
export const SceneInspectorPlugin: IPlugin = {
descriptor,
editorModule: new SceneInspectorEditorModule()
};

View File

@@ -9,4 +9,5 @@ export { ProfilerPlugin } from './ProfilerPlugin';
export { EditorAppearancePlugin } from './EditorAppearancePlugin';
export { PluginConfigPlugin } from './PluginConfigPlugin';
export { ProjectSettingsPlugin } from './ProjectSettingsPlugin';
export { BlueprintPlugin } from '@esengine/blueprint/editor';
// TODO: Re-enable when blueprint-editor package is fixed
// export { BlueprintPlugin } from '@esengine/blueprint-editor';