Merge pull request #4 from CarGDev/codex/update-module-federation-plugin-for-vite
Add vite module federation support
This commit is contained in:
@@ -1 +1,6 @@
|
||||
import { defineConfig } from 'vite';\nimport react from '@vitejs/plugin-react';\n\nexport default defineConfig({\n plugins: [react()],\n});
|
||||
import { defineConfig } from 'vite';
|
||||
import react from '@vitejs/plugin-react';
|
||||
|
||||
export default defineConfig({
|
||||
plugins: [react()],
|
||||
});
|
||||
|
||||
@@ -2,6 +2,7 @@ const devDeps = [
|
||||
'pretty-quick',
|
||||
'vite',
|
||||
'@vitejs/plugin-react',
|
||||
'@originjs/vite-plugin-federation',
|
||||
'husky',
|
||||
'dotenv',
|
||||
'@commitlint/config-conventional',
|
||||
|
||||
@@ -10,6 +10,7 @@ const { setupZustand } = require('./zustand');
|
||||
const { setupStyles } = require('./styles');
|
||||
const { setupGit } = require('./gitInit');
|
||||
const { setupTesting } = require('./testing');
|
||||
const { setupModuleFederation } = require('./moduleFederation');
|
||||
const { createAtomicStructure } = require('../templates/atomicStructure');
|
||||
const { updatePackageJson } = require('../templates/packageJson');
|
||||
const { askUserWhereToOpen } = require('../utils/logging');
|
||||
@@ -56,6 +57,9 @@ async function initProject(projectDirectory, userInput, options) {
|
||||
}
|
||||
setupStyles(userInput.styling);
|
||||
setupTesting(userInput.testingFramework);
|
||||
if (userInput.useModuleFederation) {
|
||||
setupModuleFederation();
|
||||
}
|
||||
|
||||
// Create atomic design structure
|
||||
createAtomicStructure();
|
||||
|
||||
31
src/setup/moduleFederation.js
Normal file
31
src/setup/moduleFederation.js
Normal file
@@ -0,0 +1,31 @@
|
||||
const { execSync } = require('child_process');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
const ora = require('ora');
|
||||
|
||||
function setupModuleFederation() {
|
||||
const spinner = ora('🔗 Setting up Module Federation...').start();
|
||||
try {
|
||||
execSync('npm install --save-dev @originjs/vite-plugin-federation', { stdio: 'inherit' });
|
||||
|
||||
const configPath = path.resolve('vite.config.js');
|
||||
let config = fs.readFileSync(configPath, 'utf8');
|
||||
|
||||
if (!config.includes('@originjs/vite-plugin-federation')) {
|
||||
const importLine = "import federation from '@originjs/vite-plugin-federation';\n";
|
||||
config = importLine + config;
|
||||
config = config.replace(/plugins:\s*\[(.*?)\]/s, (match, p1) => {
|
||||
const plugins = p1.trim();
|
||||
return `plugins: [${plugins ? plugins + ', ' : ''}federation({})]`;
|
||||
});
|
||||
fs.writeFileSync(configPath, config);
|
||||
}
|
||||
|
||||
spinner.succeed('🔗 Module Federation configured.');
|
||||
} catch (error) {
|
||||
spinner.fail('❌ Failed to set up Module Federation.');
|
||||
console.error(error);
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = { setupModuleFederation };
|
||||
Reference in New Issue
Block a user