2023-09-15 14:24:01 -07:00
|
|
|
/// <reference types="vitest" />
|
2023-09-18 14:37:15 -07:00
|
|
|
import { fileURLToPath, URL } from 'node:url';
|
2023-09-13 10:04:17 -07:00
|
|
|
|
|
|
|
import react from '@vitejs/plugin-react';
|
2023-09-15 21:05:58 -07:00
|
|
|
import { visualizer } from 'rollup-plugin-visualizer';
|
2023-09-13 10:04:17 -07:00
|
|
|
import { defineConfig } from 'vite';
|
|
|
|
import compileTime from 'vite-plugin-compile-time';
|
|
|
|
import { createHtmlPlugin } from 'vite-plugin-html';
|
2023-09-15 12:37:09 -07:00
|
|
|
import { VitePWA } from 'vite-plugin-pwa';
|
2023-09-13 10:04:17 -07:00
|
|
|
import vitePluginRequire from 'vite-plugin-require';
|
|
|
|
import { viteStaticCopy } from 'vite-plugin-static-copy';
|
|
|
|
|
|
|
|
export default defineConfig({
|
2023-09-18 14:07:02 -07:00
|
|
|
root: 'src',
|
2023-09-13 10:04:17 -07:00
|
|
|
build: {
|
|
|
|
// Relative to the root
|
2023-09-18 09:27:19 -07:00
|
|
|
outDir: '../dist',
|
2023-09-13 10:04:17 -07:00
|
|
|
assetsDir: 'packs',
|
2023-09-14 17:04:07 -07:00
|
|
|
assetsInlineLimit: 0,
|
2023-09-14 17:14:16 -07:00
|
|
|
rollupOptions: {
|
|
|
|
output: {
|
|
|
|
assetFileNames: 'packs/assets/[name]-[hash].[ext]',
|
|
|
|
chunkFileNames: 'packs/js/[name]-[hash].js',
|
|
|
|
entryFileNames: 'packs/[name]-[hash].js',
|
|
|
|
},
|
|
|
|
},
|
2023-09-13 10:04:17 -07:00
|
|
|
},
|
2023-09-13 10:24:49 -07:00
|
|
|
server: {
|
|
|
|
port: 3036,
|
|
|
|
},
|
2023-09-13 10:04:17 -07:00
|
|
|
plugins: [
|
|
|
|
// @ts-ignore
|
|
|
|
vitePluginRequire.default(),
|
2023-09-15 12:37:09 -07:00
|
|
|
compileTime(),
|
2023-09-13 10:04:17 -07:00
|
|
|
createHtmlPlugin({
|
|
|
|
template: 'index.html',
|
2023-09-15 20:38:29 -07:00
|
|
|
minify: {
|
|
|
|
collapseWhitespace: true,
|
|
|
|
removeComments: false,
|
|
|
|
},
|
2023-09-13 10:04:17 -07:00
|
|
|
}),
|
|
|
|
react({
|
|
|
|
// Use React plugin in all *.jsx and *.tsx files
|
|
|
|
include: '**/*.{jsx,tsx}',
|
2023-09-13 14:35:41 -07:00
|
|
|
babel: {
|
|
|
|
configFile: './babel.config.cjs',
|
|
|
|
},
|
2023-09-13 10:04:17 -07:00
|
|
|
}),
|
2023-09-15 12:37:09 -07:00
|
|
|
VitePWA({
|
|
|
|
injectRegister: null,
|
|
|
|
strategies: 'injectManifest',
|
|
|
|
injectManifest: {
|
|
|
|
injectionPoint: undefined,
|
|
|
|
plugins: [
|
|
|
|
// @ts-ignore
|
|
|
|
compileTime(),
|
|
|
|
],
|
|
|
|
},
|
|
|
|
manifestFilename: 'manifest.json',
|
|
|
|
manifest: {
|
|
|
|
name: 'Soapbox',
|
|
|
|
short_name: 'Soapbox',
|
|
|
|
description: 'A social media frontend with a focus on custom branding and ease of use.',
|
|
|
|
},
|
2023-09-18 14:37:15 -07:00
|
|
|
srcDir: 'service-worker',
|
2023-09-15 12:37:09 -07:00
|
|
|
filename: 'sw.ts',
|
|
|
|
}),
|
2023-09-13 10:04:17 -07:00
|
|
|
viteStaticCopy({
|
|
|
|
targets: [{
|
|
|
|
src: '../node_modules/twemoji/assets/svg/*',
|
|
|
|
dest: 'packs/emoji/',
|
|
|
|
}],
|
|
|
|
}),
|
2023-09-15 21:05:58 -07:00
|
|
|
visualizer({
|
|
|
|
emitFile: true,
|
|
|
|
filename: 'report.html',
|
|
|
|
title: 'Soapbox Bundle',
|
|
|
|
}),
|
2023-09-13 10:04:17 -07:00
|
|
|
],
|
|
|
|
resolve: {
|
|
|
|
alias: [
|
2023-09-18 14:37:15 -07:00
|
|
|
{ find: 'soapbox', replacement: fileURLToPath(new URL('./src', import.meta.url)) },
|
2023-09-13 10:04:17 -07:00
|
|
|
],
|
|
|
|
},
|
|
|
|
assetsInclude: ['**/*.oga'],
|
2023-09-15 14:24:01 -07:00
|
|
|
test: {
|
|
|
|
globals: true,
|
|
|
|
environment: 'jsdom',
|
2023-09-15 15:19:13 -07:00
|
|
|
cache: {
|
|
|
|
dir: '../node_modules/.vitest',
|
|
|
|
},
|
2023-09-18 14:37:15 -07:00
|
|
|
setupFiles: 'jest/test-setup.ts',
|
2023-09-15 14:24:01 -07:00
|
|
|
},
|
2023-09-13 10:04:17 -07:00
|
|
|
});
|