-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathvite.config.ts
69 lines (62 loc) · 1.67 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
63
64
65
66
67
68
69
import vue from '@vitejs/plugin-vue'
import { resolve } from 'path'
import { defineConfig } from 'vite'
const config = {
tool: {
entry: resolve(__dirname, 'resources/js/tool.js'),
name: 'tool',
fileName: () => 'js/tool.js',
formats: ["umd"],
},
package: {
entry: resolve(__dirname, 'resources/js/package.js'),
name: 'package',
fileName: () => 'js/package.js',
formats: ["es"],
}
}
const currentConfig = process.env.LIB_NAME
? config[process.env.LIB_NAME]
: config.tool;
export default defineConfig({
plugins: [vue()],
define: {
"process.env": process.env, // Vite ditched process.env, so we need to pass it in
},
resolve: {
alias: [
{
find: 'laravel-nova',
replacement: resolve(
__dirname,
'vendor/laravel/nova/resources/js/mixins/packages.js'
),
}
]
},
build: {
outDir: resolve(__dirname, "dist"),
emptyOutDir: false,
target: "ES2022",
minify: true,
manifest: true,
lib: {
...currentConfig,
},
rollupOptions: {
input: currentConfig.entry,
external: ["vue", "laravel-nova"],
output: {
globals: {
vue: "Vue",
nova: "Nova",
"laravel-nova": "LaravelNova"
},
assetFileNames: "css/tool.css"
}
},
},
optimizeDeps: {
include: ["vue", "@inertiajs/inertia", "@inertiajs/inertia-vue3", "axios"],
},
});