-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathvite.config.ts
109 lines (108 loc) · 3.26 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
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueJsx from '@vitejs/plugin-vue-jsx'
import setupNamePlugin from './vite-plugin-setup-name'
import dts from 'vite-plugin-dts'
import { resolve } from 'path'
export default defineConfig({
plugins: [
vue(),
vueJsx(),
setupNamePlugin(),
dts({
skipDiagnostics: true,
staticImport: true,
insertTypesEntry: true,
cleanVueFileName: true,
copyDtsFiles: true,
include: ['./packages/ikui-components'],
outputDir: ['./dist/lib', './dist/es'],
afterBuild: (): void => {
console.log('build complete')
},
}),
],
build: {
target: 'modules',
minify: true,
reportCompressedSize: true,
// outDir: resolve(__dirname, 'dist/es'),
lib: {
entry: resolve(__dirname, 'packages/ikui-components/index.ts'),
name: 'ikunui',
// fileName: (format) => `index.${format}.js`,
// formats: ['esm', 'cjs', 'umd', 'es', 'iife'],
},
// cjs: commonjs module.export require . nodejs使用cjs模块
// amd: define 浏览器使用amd,异步加载模块
// umd: 作为一个兼容模式,兼容amd和cjs,打包后的umd格式会有一个环境判断 (typeof define)
// esm: export import. js推出的新模块化规范ESM具有简单语法、异步加载等以及Tree-shakeable的特点、(nodejs14+也支持)
// iife:一个自动执行的功能,适合作为script标签(es6前无块级作用域时出现)
rollupOptions: {
external: ['vue', 'vue3-popper', '@vueuse/core', 'vanilla-tilt'],
output: [
{
format: 'umd',
name: 'ikunui',
exports: 'named',
sourcemap: false,
dir: 'dist/dist',
entryFileNames: 'index.umd.js',
chunkFileNames: '[name].js',
assetFileNames: '[name].[ext]',
manualChunks: undefined,
inlineDynamicImports: false,
globals: {
vue: 'Vue',
},
},
{
format: 'es',
exports: 'named',
dir: 'dist/es',
sourcemap: false,
entryFileNames: (chunkInfo): string => {
return `${chunkInfo.name.slice(0, chunkInfo.name.lastIndexOf('/') + 1)}index.js`
},
chunkFileNames: '[name].js',
assetFileNames: '[name].[ext]',
inlineDynamicImports: false,
manualChunks: undefined,
preserveModules: true,
generatedCode: {
symbols: true,
},
},
{
format: 'cjs',
exports: 'named',
dir: 'dist/lib',
sourcemap: false,
entryFileNames: (chunkInfo): string => {
return `${chunkInfo.name.slice(0, chunkInfo.name.lastIndexOf('/') + 1)}index.js`
},
chunkFileNames: '[name].js',
assetFileNames: '[name].[ext]',
inlineDynamicImports: false,
manualChunks: undefined,
preserveModules: true,
generatedCode: {
symbols: true,
},
},
],
// globals: {
// vue: 'Vue'
// }
},
},
server: {
port: 9526,
},
test: {
coverage: {
provider: 'istanbul',
reporter: ['text', 'json', 'html'],
},
},
})