mirror of
https://github.com/Tencent/tmagic-editor.git
synced 2025-04-06 03:57:56 +08:00
77 lines
2.6 KiB
TypeScript
77 lines
2.6 KiB
TypeScript
import * as recast from 'recast';
|
|
|
|
import type App from '../Core';
|
|
import { EntryType } from '../types';
|
|
|
|
export const prepareEntryFile = async (app: App) => {
|
|
const { componentMap = {}, pluginMap = {}, configMap = {}, valueMap = {}, eventMap = {} } = app.moduleMainFilePath;
|
|
const { componentFileAffix, dynamicImport, hooks, useTs } = app.options;
|
|
|
|
let contentMap: Record<string, string> = {
|
|
'comp-entry': generateContent(useTs, EntryType.COMPONENT, componentMap, componentFileAffix),
|
|
'async-comp-entry': generateContent(useTs, EntryType.COMPONENT, componentMap, componentFileAffix, dynamicImport),
|
|
'plugin-entry': generateContent(useTs, EntryType.PLUGIN, pluginMap),
|
|
'async-plugin-entry': generateContent(useTs, EntryType.PLUGIN, pluginMap, '', dynamicImport),
|
|
'config-entry': generateContent(useTs, EntryType.CONFIG, configMap),
|
|
'value-entry': generateContent(useTs, EntryType.VALUE, valueMap),
|
|
'event-entry': generateContent(useTs, EntryType.EVENT, eventMap),
|
|
};
|
|
|
|
if (typeof hooks?.beforeWriteEntry === 'function') {
|
|
contentMap = await hooks.beforeWriteEntry(contentMap, app);
|
|
}
|
|
|
|
Object.keys(contentMap).forEach((file: string) => {
|
|
const fileName = `${file}.${useTs ? 'ts' : 'js'}`;
|
|
app.writeTemp(fileName, contentMap[file]);
|
|
});
|
|
};
|
|
|
|
const generateContent = (
|
|
useTs: boolean,
|
|
type: EntryType,
|
|
map: Record<string, string>,
|
|
componentFileAffix = '',
|
|
dynamicImport = false,
|
|
) => {
|
|
const list: string[] = [];
|
|
const importDeclarations: string[] = [];
|
|
|
|
Object.entries(map).forEach(([key, packagePath]) => {
|
|
const name = makeCamelCase(key);
|
|
if (dynamicImport) {
|
|
list.push(
|
|
`'${key}': () => import('${packagePath}${packagePath.endsWith(componentFileAffix) ? '' : componentFileAffix}')`,
|
|
);
|
|
} else {
|
|
importDeclarations.push(
|
|
`import ${name} from '${packagePath}${packagePath.endsWith(componentFileAffix) ? '' : componentFileAffix}'`,
|
|
);
|
|
list.push(`'${key}': ${name}`);
|
|
}
|
|
});
|
|
|
|
const exportToken = `${type}s`;
|
|
|
|
return prettyCode(`${importDeclarations.join(';')}
|
|
const ${exportToken}${useTs ? ': Record<string, any>' : ''} = {
|
|
${list.join(',')}
|
|
}
|
|
export default ${exportToken};
|
|
`);
|
|
};
|
|
|
|
const prettyCode = (code: string) =>
|
|
recast.prettyPrint(recast.parse(code.replace(/\\/g, '/'), { parser: require('recast/parsers/typescript') }), {
|
|
tabWidth: 2,
|
|
trailingComma: true,
|
|
quote: 'single',
|
|
}).code;
|
|
|
|
const makeCamelCase = function (name: string): string {
|
|
if (typeof name !== 'string') {
|
|
return '';
|
|
}
|
|
return name.replace(/-(\w)/g, ($0, $1) => $1.toUpperCase());
|
|
};
|