* refactor: reorganize package structure and decouple framework packages ## Package Structure Reorganization - Reorganized 55 packages into categorized subdirectories: - packages/framework/ - Generic framework (Laya/Cocos compatible) - packages/engine/ - ESEngine core modules - packages/rendering/ - Rendering modules (WASM dependent) - packages/physics/ - Physics modules - packages/streaming/ - World streaming - packages/network-ext/ - Network extensions - packages/editor/ - Editor framework and plugins - packages/rust/ - Rust WASM engine - packages/tools/ - Build tools and SDK ## Framework Package Decoupling - Decoupled behavior-tree and blueprint packages from ESEngine dependencies - Created abstracted interfaces (IBTAssetManager, IBehaviorTreeAssetContent) - ESEngine-specific code moved to esengine/ subpath exports - Framework packages now usable with Cocos/Laya without ESEngine ## CI Configuration - Updated CI to only type-check and lint framework packages - Added type-check:framework and lint:framework scripts ## Breaking Changes - Package import paths changed due to directory reorganization - ESEngine integrations now use subpath imports (e.g., '@esengine/behavior-tree/esengine') * fix: update es-engine file path after directory reorganization * docs: update README to focus on framework over engine * ci: only build framework packages, remove Rust/WASM dependencies * fix: remove esengine subpath from behavior-tree and blueprint builds ESEngine integration code will only be available in full engine builds. Framework packages are now purely engine-agnostic. * fix: move network-protocols to framework, build both in CI * fix: update workflow paths from packages/core to packages/framework/core * fix: exclude esengine folder from type-check in behavior-tree and blueprint * fix: update network tsconfig references to new paths * fix: add test:ci:framework to only test framework packages in CI * fix: only build core and math npm packages in CI * fix: exclude test files from CodeQL and fix string escaping security issue
88 lines
2.7 KiB
TypeScript
88 lines
2.7 KiB
TypeScript
import { defineConfig } from 'vite';
|
|
import { resolve } from 'path';
|
|
import dts from 'vite-plugin-dts';
|
|
import react from '@vitejs/plugin-react';
|
|
|
|
/**
|
|
* Custom plugin: Convert CSS to self-executing style injection code
|
|
* 自定义插件:将 CSS 转换为自执行的样式注入代码
|
|
*/
|
|
function injectCSSPlugin(): any {
|
|
let cssCounter = 0;
|
|
|
|
return {
|
|
name: 'inject-css-plugin',
|
|
enforce: 'post' as const,
|
|
generateBundle(_options: any, bundle: any) {
|
|
const bundleKeys = Object.keys(bundle);
|
|
|
|
// Find all CSS files (找到所有 CSS 文件)
|
|
const cssFiles = bundleKeys.filter(key => key.endsWith('.css'));
|
|
|
|
for (const cssFile of cssFiles) {
|
|
const cssChunk = bundle[cssFile];
|
|
if (!cssChunk || !cssChunk.source) continue;
|
|
|
|
const cssContent = cssChunk.source;
|
|
const styleId = `esengine-node-editor-style-${cssCounter++}`;
|
|
|
|
// Generate style injection code (生成样式注入代码)
|
|
const injectCode = `(function(){if(typeof document!=='undefined'){var s=document.createElement('style');s.id='${styleId}';if(!document.getElementById(s.id)){s.textContent=${JSON.stringify(cssContent)};document.head.appendChild(s);}}})();`;
|
|
|
|
// Inject into index.js (注入到 index.js)
|
|
for (const jsKey of bundleKeys) {
|
|
if (!jsKey.endsWith('.js')) continue;
|
|
const jsChunk = bundle[jsKey];
|
|
if (!jsChunk || jsChunk.type !== 'chunk' || !jsChunk.code) continue;
|
|
|
|
if (jsKey === 'index.js') {
|
|
jsChunk.code = injectCode + '\n' + jsChunk.code;
|
|
}
|
|
}
|
|
|
|
// Remove standalone CSS file (删除独立的 CSS 文件)
|
|
delete bundle[cssFile];
|
|
}
|
|
}
|
|
};
|
|
}
|
|
|
|
export default defineConfig({
|
|
plugins: [
|
|
react(),
|
|
dts({
|
|
include: ['src'],
|
|
outDir: 'dist',
|
|
rollupTypes: false
|
|
}),
|
|
injectCSSPlugin()
|
|
],
|
|
esbuild: {
|
|
jsx: 'automatic',
|
|
},
|
|
build: {
|
|
lib: {
|
|
entry: {
|
|
index: resolve(__dirname, 'src/index.ts')
|
|
},
|
|
formats: ['es'],
|
|
fileName: (format, entryName) => `${entryName}.js`
|
|
},
|
|
rollupOptions: {
|
|
external: [
|
|
'react',
|
|
'react/jsx-runtime',
|
|
'zustand',
|
|
/^@esengine\//
|
|
],
|
|
output: {
|
|
exports: 'named',
|
|
preserveModules: false
|
|
}
|
|
},
|
|
target: 'es2020',
|
|
minify: false,
|
|
sourcemap: true
|
|
}
|
|
});
|