phanpy/vite.config.js

186 lines
5.1 KiB
JavaScript
Raw Normal View History

import { execSync } from 'child_process';
import fs from 'fs';
import { resolve } from 'path';
2024-07-08 12:40:16 +03:00
2024-08-13 10:26:23 +03:00
import { lingui } from '@lingui/vite-plugin';
2024-07-08 12:40:16 +03:00
import preact from '@preact/preset-vite';
2024-11-12 12:44:20 +03:00
import { SondaRollupPlugin } from 'sonda';
2023-12-25 14:25:48 +03:00
import { uid } from 'uid/single';
import { defineConfig, loadEnv, splitVendorChunkPlugin } from 'vite';
2023-02-28 10:27:42 +03:00
import generateFile from 'vite-plugin-generate-file';
import htmlPlugin from 'vite-plugin-html-config';
import { VitePWA } from 'vite-plugin-pwa';
2023-01-02 10:09:31 +03:00
import removeConsole from 'vite-plugin-remove-console';
import { run } from 'vite-plugin-run';
import { ALL_LOCALES } from './src/locales';
const allowedEnvPrefixes = ['VITE_', 'PHANPY_'];
2023-01-02 09:22:01 +03:00
const { NODE_ENV } = process.env;
2023-05-24 12:18:22 +03:00
const {
PHANPY_WEBSITE: WEBSITE,
2023-12-25 14:25:48 +03:00
PHANPY_CLIENT_NAME: CLIENT_NAME,
PHANPY_APP_ERROR_LOGGING: ERROR_LOGGING,
} = loadEnv('production', process.cwd(), allowedEnvPrefixes);
2022-12-10 12:14:48 +03:00
2023-02-28 10:27:42 +03:00
const now = new Date();
2023-12-25 14:25:48 +03:00
let commitHash;
let fakeCommitHash = false;
2023-12-25 14:25:48 +03:00
try {
commitHash = execSync('git rev-parse --short HEAD').toString().trim();
} catch (error) {
// If error, means git is not installed or not a git repo (could be downloaded instead of git cloned)
// Fallback to random hash which should be different on every build run 🤞
commitHash = uid();
fakeCommitHash = true;
2023-12-25 14:25:48 +03:00
}
const rollbarCode = fs.readFileSync(
resolve(__dirname, './rollbar.js'),
'utf-8',
);
2022-12-10 12:14:48 +03:00
// https://vitejs.dev/config/
export default defineConfig({
2023-08-30 12:46:22 +03:00
base: './',
envPrefix: allowedEnvPrefixes,
2024-03-02 08:53:53 +03:00
appType: 'mpa',
mode: NODE_ENV,
define: {
2023-02-28 10:27:42 +03:00
__BUILD_TIME__: JSON.stringify(now),
__COMMIT_HASH__: JSON.stringify(commitHash),
__FAKE_COMMIT_HASH__: fakeCommitHash,
},
2023-04-06 11:15:19 +03:00
server: {
host: true,
},
2024-02-09 15:07:06 +03:00
css: {
preprocessorMaxWorkers: 1,
},
plugins: [
2024-07-08 12:40:16 +03:00
preact({
// Force use Babel instead of ESBuild due to this change: https://github.com/preactjs/preset-vite/pull/114
// Else, a bug will happen with importing variables from import.meta.env
2024-08-13 10:26:23 +03:00
babel: {
plugins: ['macros'],
},
2024-07-08 12:40:16 +03:00
}),
2024-08-13 10:26:23 +03:00
lingui(),
run({
silent: false,
input: [
{
name: 'messages:extract:clean',
run: ['npm', 'run', 'messages:extract:clean'],
pattern: 'src/**/*.{js,jsx,ts,tsx}',
},
2024-08-27 08:47:21 +03:00
// {
// name: 'update-catalogs',
// run: ['node', 'scripts/catalogs.js'],
// pattern: 'src/locales/*.po',
// },
],
}),
splitVendorChunkPlugin(),
removeConsole({
includes: ['log', 'debug', 'info', 'warn', 'error'],
}),
htmlPlugin({
2023-01-02 09:22:01 +03:00
headScripts: ERROR_LOGGING ? [rollbarCode] : [],
links: [
...ALL_LOCALES.map((lang) => ({
rel: 'alternate',
hreflang: lang,
// *Fully-qualified* URLs
href: `${WEBSITE}/?lang=${lang}`,
})),
// https://developers.google.com/search/docs/specialty/international/localized-versions#xdefault
{
rel: 'alternate',
hreflang: 'x-default',
href: `${WEBSITE}`,
},
],
}),
2023-02-28 10:27:42 +03:00
generateFile([
{
type: 'json',
output: './version.json',
data: {
buildTime: now,
commitHash,
},
},
]),
VitePWA({
manifest: {
name: CLIENT_NAME,
short_name: CLIENT_NAME,
description: 'Minimalistic opinionated Mastodon web client',
2023-12-24 18:43:18 +03:00
// https://github.com/cheeaun/phanpy/issues/231
// 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 14:12:25 +03:00
{
src: 'logo-maskable-512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'maskable',
},
],
2024-03-06 09:25:46 +03:00
categories: ['social', 'news'],
},
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',
},
}),
2024-11-12 12:44:20 +03:00
SondaRollupPlugin({
detailed: true,
brotli: true,
}),
],
build: {
sourcemap: true,
2024-03-24 05:08:09 +03:00
cssCodeSplit: false,
rollupOptions: {
treeshake: false,
input: {
main: resolve(__dirname, 'index.html'),
compose: resolve(__dirname, 'compose/index.html'),
},
output: {
2024-06-10 15:38:41 +03:00
manualChunks: {
// 'intl-segmenter-polyfill': ['@formatjs/intl-segmenter/polyfill'],
'tinyld-light': ['tinyld/light'],
},
chunkFileNames: (chunkInfo) => {
const { facadeModuleId } = chunkInfo;
if (facadeModuleId && facadeModuleId.includes('icon')) {
return 'assets/icons/[name]-[hash].js';
}
2024-08-14 12:17:34 +03:00
if (facadeModuleId && facadeModuleId.includes('locales')) {
return 'assets/locales/[name]-[hash].js';
}
return 'assets/[name]-[hash].js';
},
},
},
},
2022-12-10 12:14:48 +03:00
});