-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathgulpfile.js
More file actions
189 lines (170 loc) · 4.56 KB
/
gulpfile.js
File metadata and controls
189 lines (170 loc) · 4.56 KB
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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
const gulp = require('gulp');
const babel = require('gulp-babel');
const sass = require('gulp-sass')(require('sass'));
const rename = require('gulp-rename');
const uglify = require('gulp-uglify');
const concat = require('gulp-concat');
const ts = require('gulp-typescript');
const paths = {
dest: {
lib: 'dist/lib',
esm: 'dist/esm',
dist: 'dist/dist',
css: 'dist/css',
types: 'dist/types',
commonStyles: 'dist/css/components',
},
styles: 'src/styles/index.scss',
commonStyles: 'src/styles/commonStyle/index.scss',
inputComponentStyles: ['src/styles/componentStyle/**.scss', '!src/styles/componentStyle/index.scss'],
scripts: ['./src/**/**.{ts,tsx}', '!./src/components/**/*.stories.{ts,tsx}', '!./src/components/**/__tests__/**', '!./src/styles'],
sdkSrc: 'src/**/*.{ts,tsx,js}',
tsSrc: ['src/components/**/*.{ts,tsx}', '!src/components/**/*.stories.{ts,tsx}', '!src/components/**/__tests__/**']
};
/**
* 编译脚本文件
* @param {string} babelEnv babel环境变量
* @param {string} destDir 目标目录
*/
function compileScripts (babelEnv, destDir) {
const { scripts } = paths;
process.env.BABEL_ENV = babelEnv;
return gulp
.src(scripts)
.pipe(babel({
"presets": [
[
"@babel/preset-react",
{ "runtime": "automatic", "importSource": "@emotion/react" }
]
],
"plugins": ["@emotion/babel-plugin"]
})) // 使用gulp-babel处理
.pipe(gulp.dest(destDir));
}
/**
* 编译cjs
*/
function compileCJS () {
const { dest } = paths;
return compileScripts('cjs', dest.lib);
}
/**
* 编译esm
*/
function compileESM () {
const { dest } = paths;
return compileScripts('esm', dest.esm);
}
/**
* 编译Style
* @param {boolean} isMin 是否压缩
* @param {string} basename 文件名
*/
function compileStyle (isMin, basename) {
if (isMin) {
return gulp.src(paths.styles)
.pipe(sass().on('error', sass.logError))
.pipe(rename(function (path) {
return {
dirname: path.dirname,
basename: basename,
extname: ".css"
};
}))
.pipe(gulp.dest(paths.dest.css))
} else {
return gulp.src(paths.styles)
.pipe(sass({ outputStyle: 'compressed' }).on('error', sass.logError))
.pipe(rename(function (path) {
return {
dirname: path.dirname,
basename: basename,
extname: ".min.css"
};
}))
.pipe(gulp.dest(paths.dest.css))
}
}
/**
* 生成基础样式
*/
function buildBasicStylesMin () {
return compileStyle(true, 'basic')
}
function buildBasicStylesMax () {
return compileStyle(false, 'basic')
}
/**
* 全量加载css
*/
function buildSpeedStylesMin () {
return compileStyle(true, 'speed')
}
function buildSpeedStylesMax () {
return compileStyle(false, 'speed')
}
/**
* 按需加载组件样式
*/
function buildComponentStyle () {
return gulp.src(paths.inputComponentStyles)
.pipe(sass({ outputStyle: 'compressed' }).on('error', sass.logError))
.pipe(rename(function (path) {
return {
dirname: path.dirname,
basename: path.basename,
extname: ".css"
};
}))
.pipe(gulp.dest(paths.dest.commonStyles))
}
/**
* 编译SDK
* @param {string} babelEnv babel环境变量
* @param {string} destDir 目标目录
*/
function compileSDK (babelEnv, destDir) {
process.env.BABEL_ENV = babelEnv;
return gulp.src(paths.sdkSrc)
.pipe(babel({
"presets": [
[
"@babel/preset-react",
{ "runtime": "automatic", "importSource": "@emotion/react" }
]
],
"plugins": ["@emotion/babel-plugin"]
}))
.pipe(concat('speed.min.js'))
.pipe(uglify())
.pipe(gulp.dest(destDir))
}
/**
* SDK
*/
function compressionSdkCJS () {
const { dest } = paths;
return compileSDK('cjs', dest.lib)
}
function compressionSdkESM () {
const { dest } = paths;
return compileSDK('esm', dest.esm)
}
/**
* 编译Type
*/
function buildTypes () {
var tsProject = ts.createProject('tsconfig.json');
return gulp.src(paths.tsSrc)
.pipe(tsProject())
.pipe(gulp.dest(paths.dest.types));
}
// 串行执行编译脚本任务(cjs,esm) 避免环境变量影响
const buildScripts = gulp.series(compileCJS, compileESM);
const buildSDK = gulp.series(compressionSdkCJS, compressionSdkESM);
const buildStyle = gulp.parallel(buildBasicStylesMin, buildBasicStylesMax, buildSpeedStylesMax, buildSpeedStylesMin, buildComponentStyle);
// 整体并行执行任务
const build = gulp.parallel(buildTypes, buildScripts, buildSDK, buildStyle);
exports.build = build;
exports.default = build;