-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
55 lines (49 loc) · 1.65 KB
/
gulpfile.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
var gulp = require('gulp');
var cleanCSS = require('gulp-clean-css');
var rename = require('gulp-rename');
var header = require('gulp-header');
var sass = require('gulp-sass');
var postCSS = require('gulp-postcss');
var autoprefixer = require('autoprefixer');
var browserSync = require('browser-sync').create();
const FILE_NAME = 'simple-grid';
/**
* 讓發佈的主檔案加上 作者、版本、license 資訊
*/
function getHeader() {
var pkg = require('./package.json');
var template = [
'/**',
' * Simple Grid System v<%= pkg.version %> (https://github.com/VisionYi/simple-grid-system)',
' * Author - <%= pkg.author %>',
' * License - <%= pkg.license %>',
' */',
''
].join('\n');
return header(template, {pkg: pkg});
}
/**
* sass 預處理 + 自動加 CSS prefix + 壓縮最小化 + 加上註解標頭 + 改名稱.min
*/
gulp.task('build', () =>
gulp.src(`./src/${FILE_NAME}.scss`)
.pipe(sass({outputStyle: 'expanded', indentWidth: 2}).on('error', sass.logError))
.pipe(getHeader())
.pipe(gulp.dest('./example'))
.pipe(postCSS([ autoprefixer() ]))
.pipe(gulp.dest('./dist'))
.pipe(cleanCSS())
.pipe(getHeader())
.pipe(rename(`${FILE_NAME}.min.css`))
.pipe(gulp.dest('./dist'))
);
gulp.task('start', ['build'], () => {
/* demo example */
browserSync.init({
server: './',
startPath: 'example/index.html'
});
gulp.watch('./example/**').on('change', browserSync.reload);
// 修改 scss 檔案也會自動重新載入頁面
gulp.watch('./src/*.scss', ['build']).on('change', browserSync.reload);
});