-
Notifications
You must be signed in to change notification settings - Fork 410
/
Copy pathgulpfile.js
118 lines (106 loc) · 3.23 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
107
108
109
110
111
112
113
114
115
116
117
118
import pkg from 'gulp'
const { src, dest, parallel, series, watch } = pkg
import browserSync from 'browser-sync'
import gulpSass from 'gulp-sass'
import * as dartSass from 'sass'
const sassModule = gulpSass(dartSass)
import postCss from 'gulp-postcss'
import cssnano from 'cssnano'
import concat from 'gulp-concat'
import uglify from 'gulp-uglify'
import rename from 'gulp-rename'
import {deleteAsync} from 'del'
import imageminfn from 'gulp-imagemin'
import cache from 'gulp-cache'
import autoprefixer from 'autoprefixer'
import ftp from 'vinyl-ftp'
import rsyncfn from 'gulp-rsync'
function browsersync() {
browserSync.init({
server: {
baseDir: 'app/',
},
ghostMode: { clicks: false },
notify: false,
online: true,
// tunnel: 'yousutename', // Attempt to use the URL https://yousutename.loca.lt
})
}
function js() {
return src([
'app/libs/jquery/dist/jquery.min.js',
'app/js/common.js', // Всегда в конце
])
.pipe(concat('scripts.min.js'))
.pipe(uglify()) // Минимизировать весь js (на выбор)
.pipe(dest('app/js'))
.pipe(browserSync.stream())
}
function sass() {
return src('app/sass/**/*.sass')
.pipe(sassModule({
'include css': true,
silenceDeprecations: ['legacy-js-api', 'mixed-decls', 'color-functions', 'global-builtin', 'import'],
loadPaths: ['./']
})).on('error', function handleError() { this.emit('end') })
.pipe(postCss([
autoprefixer({ grid: 'autoplace' }),
cssnano({ preset: ['default', { discardComments: { removeAll: true } }] })
]))
.pipe(rename({ suffix: '.min', prefix : '' }))
.pipe(dest('app/css'))
.pipe(browserSync.stream())
}
function imagemin() {
return src(['app/img/**/*'], { encoding: false })
.pipe(imageminfn())
.pipe(dest('dist/img/'))
}
async function removedist() { await deleteAsync('dist/**/*', { force: true }) }
async function clearcache() { cache.clearAll() }
function buildcopy() {
return src([
'app/*.html',
'app/.htaccess',
'{app/js,app/css}/*.min.*',
'app/fonts/**/*'
], { base: 'app/', encoding: false })
.pipe(dest('dist'))
}
function deploy() {
let conn = ftp.create({
host: 'hostname.com',
user: 'username',
password: 'userpassword',
parallel: 10
});
let globs = [
'dist/**',
// 'dist/.htaccess',
]
return src(globs, { buffer: false, encoding: false })
.pipe(conn.dest('/path/to/folder/on/server'))
}
function rsync() {
return src('dist/')
.pipe(rsyncfn({
root: 'dist/',
hostname: '[email protected]',
destination: 'yousite/public_html/',
clean: true, // Mirror copy with file deletion
// include: ['*.htaccess'], // Includes files to deploy
exclude: ['**/Thumbs.db', '**/*.DS_Store'], // Excludes files from deploy
recursive: true,
archive: true,
silent: false,
compress: true
}))
}
function startwatch() {
watch(['app/sass/**/*.sass'], { usePolling: true }, sass)
watch(['libs/**/*.js', 'app/js/common.js'], { usePolling: true }, js)
watch(['app/*.html'], { usePolling: true }).on('change', browserSync.reload)
}
export { js, sass, imagemin, deploy, rsync, clearcache }
export let build = series(removedist, imagemin, js, sass, buildcopy)
export default series(js, sass, parallel(browsersync, startwatch))