forked from pyvec/cz.pycon.org-2018
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
106 lines (87 loc) · 2.92 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
103
104
105
106
var gulp = require('gulp');
var autoprefixer = require('autoprefixer');
var flexbugs = require('postcss-flexbugs-fixes');
var browserSync = require('browser-sync').create();
var clean = require('gulp-clean');
var postcss = require('gulp-postcss');
var sass = require('gulp-sass');
var sourcemaps = require('gulp-sourcemaps');
var cleanCSS = require('gulp-clean-css');
var watch = require('gulp-watch');
var exec = require('child_process').exec;
var plumber = require('gulp-plumber');
/*
* TASKS
*/
// runs django dev server
gulp.task('runserver', function(){
exec('python manage.py runserver --settings=pyconcz_2018.settings.local', function(err, stdout, stderr){
console.log(stdout);
console.log(stderr);
});
});
// delete all previously generated CSS
gulp.task('clean-css', function(){
return gulp.src('./pyconcz_2018/static/css/', { read: false }).pipe(clean());
});
// delete all previously generated images
gulp.task('clean-img', function(){
return gulp.src('./pyconcz_2018/static/img/', { read: false }).pipe(clean());
});
// delete all previously generated JavaScript
gulp.task('clean-js', function(){
return gulp.src('./pyconcz_2018/static/js/', { read: false }).pipe(clean());
});
// copy images
gulp.task('copy-img', ['clean-img'], function(){
return gulp
.src(['./pyconcz_2018/static_src/img/**/*'])
.pipe(gulp.dest('./pyconcz_2018/static/img/'))
.pipe(browserSync.stream());
});
// compile CSS
gulp.task('compile-css', ['clean-css'], function(){
return gulp
.src('./pyconcz_2018/static_src/scss/pyconcz.scss') // scss source
.pipe(plumber())
.pipe(sass())
.pipe(sourcemaps.init()) // sourcemap for developer tools
.pipe(postcss([
autoprefixer({
'browserslist': [
'> 0.2%',
'last 3 versions'
]
}),
flexbugs()
])) // add vendor prefixes, fix flexbox bugs
.pipe(cleanCSS({
compatibility: 'ie9',
roundingPrecision: 4,
advanced: true,
rebase: false,
specialComments: 0,
processImport: false,
inline: ['none']
}))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('./pyconcz_2018/static/css/')) // resulting CSS
.pipe(browserSync.stream()); // tell BrowserSync to inject CSS
});
// Build files and proxy dev server on http://localhost:3000
// Watch for changes in files and do what is neccessary
gulp.task('develop', ['build', 'runserver'], function(){
browserSync.init({
proxy: {
target: 'http://127.0.0.1:8000' // Django is running here
},
open: false,
files: [
'./pyconcz_2018/templates/**/*.html'
]
});
gulp.watch('./pyconcz_2018/static_src/scss/**/*.scss', ['compile-css']); // watcher for SCSS
gulp.watch('./pyconcz_2018/static_src/img/**/*', ['copy-img']); // watcher for images
});
gulp.task('build', ['compile-css', 'copy-img']); // build everything before deployment
gulp.task('default', ['develop']); // just run gulp to start development