Files
mue/vite.config.mjs

156 lines
5.4 KiB
JavaScript

import { defineConfig, loadEnv } from 'vite';
import react from '@vitejs/plugin-react-swc';
import path from 'path';
import fs from 'fs';
import ADMZip from 'adm-zip';
import * as pkg from './package.json';
import progress from 'vite-plugin-progress';
const isProd = process.env.NODE_ENV === 'production';
const prepareBuilds = () => ({
name: 'prepareBuilds',
closeBundle() {
if (isProd) {
console.log('Building extension packages...');
fs.mkdirSync(path.resolve(__dirname, './build'), { recursive: true });
fs.mkdirSync(path.resolve(__dirname, './dist'), { recursive: true });
const distAssetsPath = path.resolve(__dirname, './dist/src/assets');
fs.mkdirSync(distAssetsPath, { recursive: true });
fs.cpSync(path.resolve(__dirname, './src/assets'), distAssetsPath, { recursive: true });
console.log('Building Chrome extension...');
const chromeBuildPath = path.resolve(__dirname, './build/chrome');
fs.mkdirSync(chromeBuildPath, { recursive: true });
fs.copyFileSync(
path.resolve(__dirname, './manifest/chrome.json'),
path.resolve(chromeBuildPath, 'manifest.json'),
);
fs.copyFileSync(
path.resolve(__dirname, './manifest/background.js'),
path.resolve(chromeBuildPath, 'background.js'),
);
fs.cpSync(
path.resolve(__dirname, './manifest/_locales'),
path.resolve(chromeBuildPath, '_locales'),
{ recursive: true },
);
fs.cpSync(path.resolve(__dirname, './dist'), chromeBuildPath, { recursive: true });
fs.cpSync(
path.resolve(__dirname, './src/assets/icons'),
path.resolve(chromeBuildPath, 'icons'),
{ recursive: true },
);
console.log('Building Firefox extension...');
const firefoxBuildPath = path.resolve(__dirname, './build/firefox');
fs.mkdirSync(firefoxBuildPath, { recursive: true });
fs.copyFileSync(
path.resolve(__dirname, './manifest/firefox.json'),
path.resolve(firefoxBuildPath, 'manifest.json'),
);
fs.copyFileSync(
path.resolve(__dirname, './manifest/background.js'),
path.resolve(firefoxBuildPath, 'background.js'),
);
fs.cpSync(path.resolve(__dirname, './dist'), firefoxBuildPath, { recursive: true });
fs.cpSync(
path.resolve(__dirname, './src/assets/icons'),
path.resolve(firefoxBuildPath, 'icons'),
{ recursive: true },
);
console.log('Building Safari extension...');
const safariResourcesPath = path.resolve(__dirname, './safari/Mue Extension/Resources');
fs.mkdirSync(safariResourcesPath, { recursive: true });
fs.copyFileSync(
path.resolve(__dirname, './manifest/background.js'),
path.resolve(safariResourcesPath, 'background.js'),
);
fs.cpSync(path.resolve(__dirname, './dist'), safariResourcesPath, {
recursive: true,
filter: (src) => !src.endsWith('manifest.json'),
});
fs.cpSync(
path.resolve(__dirname, './src/assets/icons'),
path.resolve(safariResourcesPath, 'icons'),
{ recursive: true },
);
fs.cpSync(
path.resolve(__dirname, './manifest/_locales'),
path.resolve(safariResourcesPath, '_locales'),
{ recursive: true },
);
console.log('Creating distribution packages...');
const chromeZip = new ADMZip();
chromeZip.addLocalFolder(chromeBuildPath);
chromeZip.writeZip(path.resolve(__dirname, `./build/chrome-${pkg.version}.zip`));
console.log(`Chrome: chrome-${pkg.version}.zip`);
const firefoxZip = new ADMZip();
firefoxZip.addLocalFolder(firefoxBuildPath);
firefoxZip.writeZip(path.resolve(__dirname, `./build/firefox-${pkg.version}.zip`));
console.log(`Firefox: firefox-${pkg.version}.zip`);
console.log('Build complete!');
}
},
});
export default defineConfig(({ command, mode }) => {
const env = loadEnv(mode, process.cwd(), '');
return {
define: { __APP_ENV__: JSON.stringify(env.APP_ENV) },
plugins: [react(), prepareBuilds(), progress()],
server: { open: true, hmr: { protocol: 'ws', host: 'localhost' } },
build: {
target: 'esnext',
minify: isProd ? 'esbuild' : false,
sourcemap: !isProd,
rollupOptions: {
output: {
manualChunks: {
'vendor-react': ['react', 'react-dom', 'react-modal'],
'vendor-icons': ['react-icons'],
'vendor-dnd': ['@dnd-kit/core', '@dnd-kit/sortable', '@dnd-kit/utilities'],
'vendor-ui': ['react-toastify', '@floating-ui/react-dom'],
'i18n': ['@eartharoid/i18n'],
},
},
},
},
resolve: {
extensions: ['.js', '.jsx'],
alias: {
'@': path.resolve(__dirname, './src'),
i18n: path.resolve(__dirname, './src/i18n'),
components: path.resolve(__dirname, './src/components'),
contexts: path.resolve(__dirname, './src/contexts'),
hooks: path.resolve(__dirname, './src/hooks'),
assets: path.resolve(__dirname, './src/assets'),
config: path.resolve(__dirname, './src/config'),
features: path.resolve(__dirname, './src/features'),
lib: path.resolve(__dirname, './src/lib'),
scss: path.resolve(__dirname, './src/scss'),
translations: path.resolve(__dirname, './src/i18n/locales'),
utils: path.resolve(__dirname, './src/utils'),
},
},
css: { preprocessorOptions: { scss: { api: 'modern-compiler' } } },
};
});