-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
62 lines (57 loc) · 1.52 KB
/
vite.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import react from '@vitejs/plugin-react'
import fs from 'fs'
import Handlebars from 'handlebars'
import path from 'path'
import { defineConfig } from 'vite'
const {
version,
homepage,
bugs: { url: issuesUrl },
} = JSON.parse(
fs.readFileSync(path.join(process.cwd(), 'package.json'), 'utf-8'),
)
const { short_name, name, theme_color, background_color } = JSON.parse(
fs.readFileSync(path.join(process.cwd(), 'public', 'manifest.json'), 'utf-8'),
)
process.env.PUBLIC_VERSION = process.env.PUBLIC_VERSION ?? version ?? Date.now()
process.env.PUBLIC_HOMEPAGE = process.env.PUBLIC_HOMEPAGE ?? homepage
process.env.PUBLIC_ISSUES = issuesUrl
process.env.PUBLIC_MANIFEST_SHORT_NAME = short_name
process.env.PUBLIC_MANIFEST_NAME = name
process.env.PUBLIC_MANIFEST_THEME_COLOR = theme_color
process.env.PUBLIC_MANIFEST_BACKGROUND_COLOR = background_color
const replaceInIndex = (data: Record<string, string>) => ({
name: 'replace-in-index',
transformIndexHtml: (source: string): string => {
const template = Handlebars.compile(source)
return template(data)
},
})
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
react(),
replaceInIndex({
name,
shortName: short_name,
themeColor: theme_color,
version,
}),
],
base: `${(process.env.BASE_URL ?? '').replace(/\/+$/, '')}/`,
preview: {
host: 'localhost',
port: 8080,
},
server: {
host: 'localhost',
port: 8080,
},
resolve: {
alias: [{ find: 'app/', replacement: '/src/' }],
},
build: {
outDir: './build',
},
envPrefix: 'PUBLIC_',
})