-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgulpfile.js
102 lines (92 loc) · 2.03 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
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
'use strict';
var del = require('del');
var gulp = require('gulp');
var autoprefixer = require('gulp-autoprefixer');
var sass = require('gulp-sass');
var rename = require('gulp-rename');
var sourcemaps = require('gulp-sourcemaps');
var cssnano = require('gulp-cssnano');
var postcss = require('gulp-postcss');
var stylefmt = require('gulp-stylefmt');
var sorting = require('postcss-sorting');
var torem = require('postcss-pxtorem');
var sortOrder = require('./.postcss-sorting.json');
// Config
var build = {
css: './assets/css',
scss: './src/scss/'
};
var AUTOPREFIXER_BROWSERS = [
'ie >= 11',
'edge >= 12',
'ff >= 38',
'chrome >= 35',
'safari >= 8',
'opera >= 35',
'ios >= 8'
];
gulp.task('css', function () {
var css = gulp
.src(build.scss + '*.scss')
.pipe(sourcemaps.init())
.pipe(sass({
indentType: 'tab',
indentWidth: 1,
outputStyle: 'expanded',
precision: 10,
onError: console.error.bind(console, 'Sass error:')
}))
.pipe(autoprefixer(AUTOPREFIXER_BROWSERS))
.pipe(
postcss([
sorting(sortOrder),
torem({
rootValue: 16,
unitPrecision: 7,
propWhiteList: [
'font',
'font-size',
'margin',
'margin-left',
'margin-right',
'margin-top',
'margin-bottom',
'padding',
'padding-left',
'padding-right',
'padding-top',
'padding-bottom'],
selectorBlackList: [],
replace: true,
mediaQuery: false,
minPixelValue: 0
})
])
)
.pipe(stylefmt())
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest(build.css));
return css;
});
gulp.task('clean', function () {
del(['dist']);
});
gulp.task('minify', ['css'], function () {
var css = gulp
.src(build.css + '/theme.css')
.pipe(sourcemaps.init())
.pipe(cssnano())
.pipe(rename({
suffix: '.min',
extname: '.css'
}))
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest(build.css));
return css;
});
gulp.task('watch', function () {
gulp.watch('src/scss/**/*.scss', ['css', 'minify']);
});
gulp.task('serve', ['watch']);
gulp.task('test', ['css', 'minify']);
gulp.task('default', ['css', 'minify', 'watch']);