layui/gulpfile.js

144 lines
3.2 KiB
JavaScript
Raw Normal View History

2016-11-10 02:31:39 +08:00
/**
2016-10-14 16:23:52 +08:00
layui构建
*/
var pkg = require('./package.json');
var gulp = require('gulp');
var uglify = require('gulp-uglify');
var minify = require('gulp-minify-css');
var concat = require('gulp-concat');
var rename = require('gulp-rename');
var header = require('gulp-header');
var del = require('del');
var gulpif = require('gulp-if');
var minimist = require('minimist');
2016-11-30 02:23:57 +08:00
//获取参数
2016-10-14 16:23:52 +08:00
var argv = require('minimist')(process.argv.slice(2), {
default: {
ver: 'all'
}
2016-11-30 02:23:57 +08:00
})
2016-10-14 16:23:52 +08:00
2016-11-30 02:23:57 +08:00
//注释
,note = [
'/** <%= pkg.name %>-v<%= pkg.version %><%= remark %> LGPL License By <%= pkg.homepage %> */\n ;'
,{pkg: pkg, remark: ''}
]
//模块
,mods = 'laytpl,laypage,laydate,jquery,layer,element,upload,form,tree,util,flow,layedit,code'
//任务
,task = {
minjs: function(ver) {
//可指定模块压缩eggulp minjs --mod layer,laytpl
2016-10-14 16:23:52 +08:00
var mod = argv.mod ? function(){
return '(' + argv.mod.replace(/,/g, '|') + ')';
2016-11-30 02:23:57 +08:00
}() : ''
,src = [
2016-10-14 16:23:52 +08:00
'./src/**/*'+ mod +'.js'
2016-10-14 18:22:51 +08:00
,'!./src/lay/all.js'
2016-11-30 02:23:57 +08:00
,'!./src/lay/mod.js'
]
,dir = ver === 'open' ? 'release' : 'build';
//过滤 layim
if(ver === 'open' || argv.open){
src.push('!./src/lay/**/layim.js');
}
return gulp.src(src).pipe(uglify())
.pipe(header.apply(null, note))
.pipe(gulp.dest('./'+ dir));
2016-10-14 16:23:52 +08:00
}
2016-11-30 02:23:57 +08:00
,alljs: function(ver){
var src = ['./src/**/{layui,all,'+ mods +'}.js']
,dir = ver === 'open' ? 'release' : 'build';
return gulp.src(src).pipe(uglify())
.pipe(concat('layui.all.js', {newLine: ''}))
.pipe(header.apply(null, note))
.pipe(gulp.dest('./'+ dir +'/lay/dest/'));
2016-10-14 16:23:52 +08:00
}
2016-11-30 02:23:57 +08:00
,mincss: function(ver){
var src = ['./src/css/**/*.css']
,dir = ver === 'open' ? 'release' : 'build';
if(ver === 'open' || argv.open){
src.push('!./src/css/**/layim.css');
}
return gulp.src(src).pipe(minify({
2016-10-14 16:23:52 +08:00
compatibility: 'ie7'
2016-11-30 02:23:57 +08:00
})).pipe(header.apply(null, note))
.pipe(gulp.dest('./'+ dir +'/css'));
2016-10-14 16:23:52 +08:00
}
2016-11-30 02:23:57 +08:00
,font: function(ver){
var dir = ver === 'open' ? 'release' : 'build';
2016-10-14 16:23:52 +08:00
return gulp.src('./src/font/*')
.pipe(rename({}))
2016-11-30 02:23:57 +08:00
.pipe(gulp.dest('./'+ dir +'/font'));
2016-10-14 16:23:52 +08:00
}
2016-11-30 02:23:57 +08:00
,images: function(ver){
var src = [
'./src/**/*.png'
,'./src/**/*.jpg'
,'./src/**/*.gif'
]
,dir = ver === 'open' ? 'release' : 'build';
if(ver === 'open' || argv.open){
src.push('!./src/**/layim/**/*.*');
}
2016-10-14 16:23:52 +08:00
2016-11-30 02:23:57 +08:00
gulp.src(src).pipe(rename({}))
.pipe(gulp.dest('./'+ dir));
2016-10-14 16:23:52 +08:00
}
};
//清理
gulp.task('clear', function(cb) {
return del(['./build/*'], cb);
});
2016-11-30 02:23:57 +08:00
gulp.task('clearRelease', function(cb) {
return del(['./release/*'], cb);
});
2016-11-10 02:31:39 +08:00
2016-10-14 16:23:52 +08:00
gulp.task('minjs', task.minjs); //压缩js模块
2016-11-10 02:31:39 +08:00
gulp.task('modjs', task.modjs); //打包PC完整模块即各模块的合并
gulp.task('alljs', task.alljs); //打包PC合并版即包含layui.js和所有模块的合并
2016-10-14 16:23:52 +08:00
gulp.task('mincss', task.mincss); //压缩css文件
gulp.task('font', task.font); //复制iconfont文件
gulp.task('images', task.images); //复制组件可能所需的图片
2016-11-30 02:23:57 +08:00
//开源版
gulp.task('default', ['clearRelease'], function(){
for(var key in task){
task[key]('open');
}
});
2016-10-14 16:23:52 +08:00
//完整任务
2016-11-30 02:23:57 +08:00
gulp.task('all', ['clear'], function(){
2016-10-14 16:23:52 +08:00
for(var key in task){
task[key]();
}
});
2016-11-30 02:23:57 +08:00
2016-10-14 16:23:52 +08:00