2022-12-10 10:14:48 +01:00
|
|
|
import preact from '@preact/preset-vite';
|
2022-12-15 07:42:34 +01:00
|
|
|
import { execSync } from 'child_process';
|
2022-12-28 06:47:11 +01:00
|
|
|
import fs from 'fs';
|
2022-12-13 13:42:09 +01:00
|
|
|
import { resolve } from 'path';
|
2022-12-22 12:38:02 +01:00
|
|
|
import { defineConfig, loadEnv, splitVendorChunkPlugin } from 'vite';
|
2022-12-28 06:47:11 +01:00
|
|
|
import htmlPlugin from 'vite-plugin-html-config';
|
2022-12-27 13:47:23 +01:00
|
|
|
import VitePluginHtmlEnv from 'vite-plugin-html-env';
|
2022-12-19 07:51:56 +01:00
|
|
|
import { VitePWA } from 'vite-plugin-pwa';
|
|
|
|
|
2022-12-28 06:47:11 +01:00
|
|
|
const {
|
|
|
|
VITE_CLIENT_NAME: CLIENT_NAME,
|
|
|
|
NODE_ENV,
|
|
|
|
VITE_APP_ERROR_LOGGING,
|
|
|
|
} = loadEnv('production', process.cwd());
|
2022-12-10 10:14:48 +01:00
|
|
|
|
2022-12-15 07:42:34 +01:00
|
|
|
const commitHash = execSync('git rev-parse --short HEAD').toString().trim();
|
|
|
|
|
2022-12-28 06:47:11 +01:00
|
|
|
const rollbarCode = fs.readFileSync(
|
|
|
|
resolve(__dirname, './rollbar.js'),
|
|
|
|
'utf-8',
|
|
|
|
);
|
|
|
|
|
2022-12-10 10:14:48 +01:00
|
|
|
// https://vitejs.dev/config/
|
|
|
|
export default defineConfig({
|
2022-12-19 07:51:56 +01:00
|
|
|
mode: NODE_ENV,
|
2022-12-15 07:42:34 +01:00
|
|
|
define: {
|
|
|
|
__BUILD_TIME__: JSON.stringify(Date.now()),
|
|
|
|
__COMMIT_HASH__: JSON.stringify(commitHash),
|
|
|
|
},
|
2022-12-19 07:51:56 +01:00
|
|
|
plugins: [
|
|
|
|
preact(),
|
|
|
|
splitVendorChunkPlugin(),
|
2022-12-27 13:47:23 +01:00
|
|
|
VitePluginHtmlEnv(),
|
2022-12-28 06:47:11 +01:00
|
|
|
htmlPlugin({
|
|
|
|
headScripts: VITE_APP_ERROR_LOGGING ? [rollbarCode] : [],
|
|
|
|
}),
|
2022-12-19 07:51:56 +01:00
|
|
|
VitePWA({
|
|
|
|
manifest: {
|
|
|
|
name: CLIENT_NAME,
|
|
|
|
short_name: CLIENT_NAME,
|
|
|
|
description: 'Minimalistic opinionated Mastodon web client',
|
|
|
|
theme_color: '#ffffff',
|
|
|
|
icons: [
|
|
|
|
{
|
|
|
|
src: 'logo-192.png',
|
|
|
|
sizes: '192x192',
|
|
|
|
type: 'image/png',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
src: 'logo-512.png',
|
|
|
|
sizes: '512x512',
|
|
|
|
type: 'image/png',
|
|
|
|
},
|
2022-12-20 12:12:25 +01:00
|
|
|
{
|
|
|
|
src: 'logo-maskable-512.png',
|
|
|
|
sizes: '512x512',
|
|
|
|
type: 'image/png',
|
|
|
|
purpose: 'maskable',
|
|
|
|
},
|
2022-12-19 07:51:56 +01:00
|
|
|
],
|
|
|
|
},
|
|
|
|
strategies: 'injectManifest',
|
|
|
|
injectRegister: 'inline',
|
|
|
|
injectManifest: {
|
|
|
|
// Prevent "Unable to find a place to inject the manifest" error
|
|
|
|
injectionPoint: undefined,
|
|
|
|
},
|
|
|
|
devOptions: {
|
|
|
|
enabled: NODE_ENV === 'development',
|
|
|
|
type: 'module',
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
],
|
2022-12-13 13:42:09 +01:00
|
|
|
build: {
|
2022-12-15 04:47:11 +01:00
|
|
|
sourcemap: true,
|
2022-12-13 13:42:09 +01:00
|
|
|
rollupOptions: {
|
|
|
|
input: {
|
|
|
|
main: resolve(__dirname, 'index.html'),
|
|
|
|
compose: resolve(__dirname, 'compose/index.html'),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-12-10 10:14:48 +01:00
|
|
|
});
|