tis-cli前端项目快速搭建命令行工具
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.
 
 
 
 
 

69 lines
2.2 KiB

var path = require('path')
var fs = require('fs')
var gulp = require('gulp')
var ora = require('ora')
var nop = require('gulp-nop')
var sass = require('gulp-sass')
var autoprefixer = require('gulp-autoprefixer')
var cssmin = require('gulp-cssmin')
var each = require('gulp-each')
var config = require('./config')
exports.fonts = function (opts) {
var spin = ora(opts.message).start()
var stream = gulp.src(path.resolve(config.themePath, './src/fonts/**'))
.pipe((opts.minimize || config.minimize) ? cssmin({showLog: false}) : nop())
.pipe(gulp.dest(path.resolve(__dirname, '../theme-files' ,opts.out || config.out, './fonts')))
.on('end', function () {
spin.succeed()
})
return stream
}
exports.build = function (opts) {
var spin = ora(opts.message).start()
var stream
var components
var cssFiles = '*'
console.log('config ====>', config);
console.log('opts:', opts);
if (config.components) {
components = config.components.concat(['base'])
cssFiles = '{' + components.join(',') + '}'
}
var varsPath = path.resolve(config.themePath, './src/common/var.scss')
fs.writeFileSync(varsPath, fs.readFileSync(path.resolve(process.cwd(), opts.config || config.config)), 'utf-8')
stream = gulp.src([opts.config || config.config, path.resolve(config.themePath, './src/' + cssFiles + '.scss')])
.pipe(each(function(content, file, callback) {
// console.log('content:', content);
// console.log('file:', file.path);
if (file.path.indexOf('variables.scss') !== -1) {
console.log('遇到变量文件');
callback(null, content);
} else {
if (opts.prefix) {
var newContent = '[data-theme="' + opts.out + '"] { \n' + content + '}';
newContent = newContent + '\n' + content;
callback(null, newContent);
} else {
callback(null, content);
}
}
}))
.pipe(sass.sync())
.pipe(autoprefixer({
browsers: config.browsers,
cascade: false
}))
.pipe((opts.minimize || config.minimize) ? cssmin({showLog: false}) : nop())
.pipe(gulp.dest(path.resolve(__dirname, '../theme-files' , opts.out || config.out)))
.on('end', function () {
spin.succeed()
})
return stream
}