-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathamis.config.js
executable file
·135 lines (134 loc) · 4.86 KB
/
amis.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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
'use strict';
const path = require('path');
// 统一路径解析
function resolve(dir) {
return path.resolve(__dirname, dir);
}
// 包括生产和开发的环境配置信息
module.exports = {
settings: {
enableESLint: false, // 调试模式是否开启ESLint,默认开启ESLint检测代码格式
enableESLintFix: false, // 是否自动修正代码格式,默认不自动修正
enableStyleLint: false, // 是否开启StyleLint,默认开启ESLint检测代码格式
enableStyleLintFix: false // 是否需要StyleLint自动修正代码格式
},
webpack: {
resolve: {
// webpack的resolve配置
extensions: ['.js', '.jsx', '.ts', '.tsx', '.vue', '.umd.js', '.min.js', '.json'], // 用于配置webpack在尝试过程中用到的后缀列表
alias: {
'@': resolve('src'),
$function: resolve('src/function'),
$utils: resolve('src/utils'),
},
},
// createDeclaration: true, // 打包时是否创建ts声明文件
ignoreNodeModules: false, // 打包时是否忽略 node_modules
projectDir: ['src', 'editor'],
postCssLoaderOption: {
postcssOptions: {
plugins: [
require('postcss-pxtorem')({
rootValue: 16, // 1rem 等于 16px
propList: ['*'], // 所有属性都转换
}),
],
}
},
// template: resolve('./editor/index.html'), // dev本地调试时需要html模板
},
dev: {
entry: { // 本地编辑器中预览自定义组件
index: [
'./src/react-widget/index.js',
'./src/react-widget/plugin/info-card-plugin.jsx',
'./src/vue-widget/index.js',
'./src/vue-widget/plugin/info-card-plugin.jsx',
'./src/hello-jquery/hello-jquery.jsx',
'./src/hello-jquery/plugin/hello-jquery-plugin.jsx',
],
},
// 用于开启本地调试模式的相关配置信息
NODE_ENV: 'development',
port: 80,
autoOpenBrowser: true,
assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
assetsSubDirectory: '',
hostname: 'localhost',
cssSourceMap: false,
closeHotReload: true, // 是否关闭热更新
},
preview: {
entry: { // 预览自定义组件内容
index: './src/preview.js',
},
// 用于开启本地调试模式的相关配置信息
NODE_ENV: 'development',
port: 80,
autoOpenBrowser: true,
assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
assetsSubDirectory: '',
hostname: 'localhost',
proxyTable: {
'/apiTest': {
target: 'http://api-test.com.cn', // 不支持跨域的接口根地址
ws: true,
changeOrigin: true
}
},
cssSourceMap: true,
closeHotReload: false, // 是否关闭热更新
},
linkDebug: {
entry: { // 外链调试(amis-saas中预览自定义组件)
index: [
'./src/react-widget/index.js',
'./src/react-widget/plugin/info-card-plugin.jsx',
'./src/vue-widget/index.js',
'./src/vue-widget/plugin/info-card-plugin.jsx',
'./src/hello-jquery/hello-jquery.jsx',
'./src/hello-jquery/plugin/hello-jquery-plugin.jsx',
],
},
// 用于开启本地调试模式的相关配置信息
NODE_ENV: 'production',
port: 80,
autoOpenBrowser: false,
closeHtmlWebpackPlugin: true, // 关闭HtmlWebpackPlugin
assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
assetsSubDirectory: '',
hostname: 'localhost',
proxyTable: {
'/apiTest': {
target: 'http://api-test.com.cn', // 不支持跨域的接口根地址
ws: true,
changeOrigin: true
}
},
cssSourceMap: true,
closeHotReload: true, // 是否关闭热更新
},
build2lib: {
entry: {
// 自定义组件入口文件
reactInfoCard: './src/react-widget/index.js',
reactInfoCardPlugin: './src/react-widget/plugin/info-card-plugin.jsx',
infoCard: './src/vue-widget/index.js',
infoCardPlugin: './src/vue-widget/plugin/info-card-plugin.jsx',
helloJquery: './src/hello-jquery/hello-jquery.jsx',
helloJqueryPlugin: './src/hello-jquery/plugin/hello-jquery-plugin.jsx'
},
// 用于构建生产环境代码的相关配置信息
NODE_ENV: 'production', // development / production
libraryName: 'amisWidget', // 构建第三方功能包时最后导出的引用变量名
assetsRoot: resolve('./dist'), // 打包后的文件绝对路径(物理路径)
assetsPublicPath: '/', // 设置静态资源的引用路径(根域名+路径)
assetsSubDirectory: '', // 资源引用二级路径
ignoreNodeModules: true, // 打包时是否忽略 node_modules
allowList: [], // ignoreNodeModules为true时生效
productionSourceMap: false,
productionGzip: false,
productionGzipExtensions: ['js', 'css', 'json'],
bundleAnalyzerReport: false,
}
};