mirror of https://github.com/layui/layui
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
4.1 KiB
155 lines
4.1 KiB
const path = require('path'); |
|
const gulp = require('gulp'); |
|
const uglify = require('gulp-uglify'); |
|
const cleanCSS = require('gulp-clean-css'); |
|
const concat = require('gulp-concat'); |
|
const replace = require('gulp-replace'); |
|
const header = require('gulp-header'); |
|
const sourcemaps = require('gulp-sourcemaps'); |
|
const zip = require('gulp-zip'); |
|
const del = require('del'); |
|
const minimist = require('minimist'); |
|
const yargs = require('yargs'); |
|
const pkg = require('./package.json'); |
|
|
|
// 基础配置 |
|
const config = { |
|
// 头部注释 |
|
comment: [ |
|
'/** v<%= pkg.version %> | <%= pkg.license %> Licensed */<%= js %>', |
|
{pkg: pkg, js: ';'} |
|
], |
|
// 全部模块 |
|
modules: 'lay,laytpl,laypage,laydate,jquery,layer,util,dropdown,slider,colorpicker,element,upload,form,table,treeTable,tree,transfer,carousel,rate,flow,code' |
|
}; |
|
|
|
// 获取参数 |
|
const argv = minimist(process.argv.slice(2), { |
|
default: { |
|
version: pkg.version |
|
} |
|
}); |
|
|
|
const rlsFileName = `${pkg.name}-v${pkg.version}`; // 发行文件名 |
|
const rlsDest = `./release/zip/${rlsFileName}/${pkg.name}`; // 发行目标路径 |
|
const rlsDirname = path.dirname(rlsDest); // 发行目录名 |
|
|
|
// 复制目标路径 |
|
const copyDest = argv.dest |
|
? path.join(argv.dest, (argv.vs ? '/' + pkg.version : '')) |
|
: rlsDest; |
|
|
|
// 打包目标路径 |
|
const dest = './dist'; |
|
|
|
// js |
|
const js = () => { |
|
let src = [ |
|
'./src/**/{layui,layui.all,'+ config.modules +'}.js' |
|
]; |
|
return gulp.src(src) |
|
.pipe(sourcemaps.init()) |
|
.pipe(uglify({ |
|
output: { |
|
ascii_only: true // escape Unicode characters in strings and regexps |
|
}, |
|
ie: true |
|
})) |
|
.pipe(concat('layui.js', {newLine: ''})) |
|
.pipe(header.apply(null, config.comment)) |
|
.pipe(sourcemaps.write('.')) |
|
.pipe(gulp.dest(dest)); |
|
}; |
|
|
|
// css |
|
const css = () => { |
|
let src = [ |
|
'./src/css/**/{layui,*}.css' |
|
]; |
|
return gulp.src(src) |
|
.pipe(sourcemaps.init()) |
|
.pipe(cleanCSS({ |
|
compatibility: 'ie8' |
|
})) |
|
.pipe(concat('layui.css', {newLine: ''})) |
|
.pipe(sourcemaps.write('.')) |
|
.pipe(gulp.dest(dest +'/css')); |
|
}; |
|
|
|
// files |
|
const files = () => { |
|
let src = ['./src/**/*.{eot,svg,ttf,woff,woff2,html,json,png,jpg,gif}']; |
|
return gulp.src(src) |
|
.pipe(gulp.dest(dest)); |
|
}; |
|
|
|
// clean |
|
const clean = () => { |
|
return del([dest]); |
|
}; |
|
|
|
// 默认任务 |
|
exports.default = gulp.series(clean, gulp.parallel(js, css, files)); |
|
|
|
// 复制 dist 目录到指定路径 |
|
exports.cp = gulp.series(() => del(copyDest), () => { |
|
const src = `${dest}/**/*`; |
|
|
|
// 复制 css js |
|
gulp.src(`${src}.{css,js}`) |
|
.pipe(replace(/\n\/(\*|\/)\#[\s\S]+$/, '')) // 过滤 css,js 的 map 特定注释 |
|
.pipe(gulp.dest(copyDest)); |
|
|
|
// 复制其他文件 |
|
return gulp.src([ |
|
src, |
|
`!${src}.{css,js,map}` // 过滤 map 文件 |
|
]) |
|
.pipe(replace(/\n\/(\*|\/)\#[\s\S]+$/, '')) // 过滤 css,js 的 map 特定注释 |
|
.pipe(gulp.dest(copyDest)); |
|
}); |
|
|
|
// 发行 |
|
exports.release = gulp.series( |
|
() => del([rlsDirname]), // 清理发行目录 |
|
() => { // 生成说明 |
|
return gulp.src('./release/introduce/**/*') |
|
.pipe(replace(/[^'"]+(\/layui\.css)/, 'layui/css$1')) // 替换 css 引入路径中的本地 path |
|
.pipe(replace(/[^'"]+(\/layui\.js)/, 'layui$1')) // 替换 js 引入路径中的本地 path |
|
.pipe(gulp.dest(rlsDirname)) // 用于本地 |
|
.pipe(gulp.dest('./examples/introduce')); // 用于 Github actions |
|
}, |
|
exports.cp, // 复制 dist 目录文件 |
|
() => { // 生成 ZIP 压缩包 |
|
const base = path.dirname(rlsDirname); |
|
return gulp.src(rlsDirname + '/**/*', { |
|
base: base |
|
}) |
|
.pipe(zip(`${rlsFileName}.zip`)) |
|
.pipe(gulp.dest(base)) |
|
} |
|
); |
|
|
|
// helper |
|
exports.help = () => { |
|
let usage = '\nUsage: gulp [options] tasks'; |
|
let parser = yargs.usage(usage, { |
|
dest: { |
|
type: 'string', |
|
desc: '自定义输出路径' |
|
}, |
|
vs: { |
|
type: 'boolean', |
|
desc: '生成一个带版本号的文件夹' |
|
} |
|
}); |
|
|
|
parser.showHelp(console.log); |
|
console.log([ |
|
'Tasks:', |
|
' default 默认任务', |
|
' release 发行任务', |
|
' cp 将 dist 目录复制一份到参数 --dest 指向的目录' |
|
].join('\n'), '\n\nExamples:\n gulp cp --dest ./v --vs', '\n'); |
|
return gulp.src('./'); |
|
};
|
|
|