-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathvite.config.esm.ts
86 lines (85 loc) · 2.72 KB
/
vite.config.esm.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
/*
* @Author: jackning [email protected]
* @Date: 2024-12-30 13:05:55
* @LastEditors: jackning [email protected]
* @LastEditTime: 2024-12-30 19:07:42
* @Description: bytedesk.com https://github.com/Bytedesk/bytedesk
* Please be aware of the BSL license restrictions before installing Bytedesk IM –
* selling, reselling, or hosting Bytedesk IM as a service is a breach of the terms and automatically terminates your rights under the license.
* 仅支持企业内部员工自用,严禁私自用于销售、二次销售或者部署SaaS方式销售
* Business Source License 1.1: https://github.com/Bytedesk/bytedesk/blob/main/LICENSE
* contact: [email protected]
* 联系:[email protected]
* Copyright (c) 2024 by bytedesk.com, All Rights Reserved.
*/
import { defineConfig } from 'vite';
import { resolve } from 'path';
import react from '@vitejs/plugin-react';
import vue from '@vitejs/plugin-vue';
import dts from 'vite-plugin-dts';
export default defineConfig({
build: {
outDir: 'dist',
emptyOutDir: false,
lib: {
entry: {
'index': resolve(__dirname, 'src/main.ts'),
'react': resolve(__dirname, 'src/adapters/react.tsx'),
'vue': resolve(__dirname, 'src/adapters/vue.ts'),
'svelte': resolve(__dirname, 'src/adapters/svelte.ts'),
'angular': resolve(__dirname, 'src/adapters/angular.ts'),
'nextjs': resolve(__dirname, 'src/adapters/nextjs.tsx'),
},
formats: ['es']
},
rollupOptions: {
external: [
'react',
'react-dom',
'react/jsx-runtime',
'vue',
'svelte',
'@angular/core',
'@angular/common',
'@angular/platform-browser',
'@angular/platform-browser-dynamic',
'react-intl',
'vue-i18n',
'svelte-i18n',
'next',
],
output: {
format: 'es',
dir: 'dist',
entryFileNames: '[name]/index.js',
chunkFileNames: '[name]-[hash].js',
preserveModules: true,
preserveModulesRoot: 'src',
globals: {
'react': 'React',
'react-dom': 'ReactDOM',
'vue': 'Vue',
'svelte': 'Svelte',
'@angular/core': 'ng.core',
'@angular/common': 'ng.common',
'@angular/platform-browser': 'ng.platformBrowser',
'@angular/platform-browser-dynamic': 'ng.platformBrowserDynamic',
'react-intl': 'ReactIntl',
'vue-i18n': 'VueI18n',
'svelte-i18n': 'SvelteI18n',
'next': 'Next'
}
}
}
},
plugins: [
react(),
vue(),
dts({
insertTypesEntry: true,
include: ['src/**/*.ts', 'src/**/*.tsx', 'src/**/*.vue'],
outDir: 'dist/types',
rollupTypes: true,
})
]
});