-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathvite.config.js
95 lines (80 loc) · 2.83 KB
/
vite.config.js
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/**
* View your website at your own local server.
* Example: if you're using WP-CLI then the common URL is: http://localhost:8080.
*
* http://localhost:5173 is serving Vite on development. Access this URL will show empty page.
*
*/
import { defineConfig } from "vite";
import { resolve } from 'path';
import { glob } from 'glob';
// import biomePlugin from 'vite-plugin-biome';
// Get the relative path of the vite.config.js file for the alias
const fullPath = import.meta.url.slice(0, import.meta.url.lastIndexOf('/'));
const getWpContentIndex = fullPath.indexOf('wp-content');
const wpContentPath = fullPath.slice(getWpContentIndex);
export default defineConfig({
base: './',
plugins: [
{
handleHotUpdate({ file, server }) {
if (file.endsWith('.php')) {
server.ws.send({ type: 'full-reload', path: '*' });
}
}
}
],
css: {
devSourcemap: true,
},
build: {
// emit manifest so PHP can find the hashed files
manifest: true,
outDir: resolve(__dirname, 'assets/dist/'),
// don't base64 images
assetsInlineLimit: 0,
rollupOptions: {
input: {
'js/main': resolve(__dirname + '/assets/src/js/main.js'),
...(
() => glob
.sync(resolve(__dirname,'assets/src/scss/[!_]*.scss'))
.reduce((entries, filename) => {
const [, name] = filename.match(/([^/]+)\.scss$/)
return { ...entries, [name]: filename }
}, {})
)()
},
output: {
entryFileNames: '[name]-[hash].js',
chunkFileNames: '[name]-[hash].js',
assetFileNames: (assetInfo) => {
let extType = assetInfo.name.split('.');
// group fonts in a folder
if (extType[1] === 'woff' || extType[1] === 'woff2' || extType[1] === 'ttf') {
return 'fonts/[name]-[hash].[ext]';
}
// group images in a folder
if (extType[1] === 'gif' || extType[1] === 'jpg' || extType[1] === 'jpeg' || extType[1] === 'png') {
return 'img/[name]-[hash].[ext]';
}
return'[ext]/[name]-[hash].[ext]';
}
},
},
},
server: {
// required to load scripts from custom host
cors: {
origin: "*"
},
// We need a strict port to match on PHP side.
strictPort: true,
port: 5173,
},
resolve: {
alias: {
'@': process.env.NODE_ENV === 'development' ? resolve(wpContentPath + '/static') : '/static'
}
},
});