forked from firstor/polymer-chat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgulpfile.js
102 lines (81 loc) · 4.33 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';
const del = require('del');
const gulp = require('gulp');
const gulpif = require('gulp-if');
const mergeStream = require('merge-stream');
const polymerBuild = require('polymer-build');
// Here we add tools that will be used to process our source files.
const imagemin = require('gulp-imagemin');
// Additional plugins can be used to optimize your source files after splitting.
// Before using each plugin, install with `npm i --save-dev <package-name>`
const uglify = require('gulp-uglify');
const cssSlam = require('css-slam').gulp;
const htmlMinifier = require('gulp-html-minifier');
// const swPrecacheConfig = require('./sw-precache-config.js');
const polymerJson = require('./polymer.json');
const polymerProject = new polymerBuild.PolymerProject(polymerJson);
const buildDirectory = 'public/components';
/**
* Waits for the given ReadableStream
*/
function waitFor(stream) {
return new Promise((resolve, reject) => {
stream.on('end', resolve);
stream.on('error', reject);
});
}
function build() {
return new Promise((resolve, reject) => { // eslint-disable-line no-unused-vars
// Lets create some inline code splitters in case you need them later in your build.
let sourcesStreamSplitter = new polymerBuild.HtmlSplitter();
let dependenciesStreamSplitter = new polymerBuild.HtmlSplitter();
// Okay, so first thing we do is clear the build directory
console.log(`Deleting ${buildDirectory} directory...`);
del([buildDirectory])
.then(() => {
// Let's start by getting your source files. These are all the files
// in your `src/` directory, or those that match your polymer.json
// "sources" property if you provided one.
let sourcesStream = polymerProject.sources()
// If you want to optimize, minify, compile, or otherwise process
// any of your source code for production, you can do so here before
// merging your sources and dependencies together.
.pipe(gulpif(/\.(png|gif|jpg|svg)$/, imagemin()))
// The `sourcesStreamSplitter` created above can be added here to
// pull any inline styles and scripts out of their HTML files and
// into seperate CSS and JS files in the build stream. Just be sure
// to rejoin those files with the `.rejoin()` method when you're done.
.pipe(sourcesStreamSplitter.split())
.pipe(gulpif(/\.js$/, uglify())) // Install gulp-uglify to use
.pipe(gulpif(/\.css$/, cssSlam())) // Install css-slam to use
.pipe(gulpif(/\.html$/, htmlMinifier())) // Install gulp-html-minifier to use
// Remember, you need to rejoin any split inline code when you're done.
.pipe(sourcesStreamSplitter.rejoin());
// Similarly, you can get your dependencies seperately and perform
// any dependency-only optimizations here as well.
let dependenciesStream = polymerProject.dependencies()
.pipe(dependenciesStreamSplitter.split())
// Add any dependency optimizations here.
.pipe(dependenciesStreamSplitter.rejoin());
// Okay, now let's merge your sources & dependencies together into a single build stream.
let buildStream = mergeStream(sourcesStream, dependenciesStream)
.once('data', () => {
console.log('Analyzing build dependencies...');
});
// If you want bundling, pass the stream to polymerProject.bundler.
// This will bundle dependencies into your fragments so you can lazy
// load them.
buildStream = buildStream.pipe(polymerProject.bundler());
// Okay, time to pipe to the build directory
buildStream = buildStream.pipe(gulp.dest(buildDirectory));
// waitFor the buildStream to complete
return waitFor(buildStream);
})
.then(() => {
// You did it!
console.log('Build complete!');
resolve();
});
});
}
gulp.task('build', build);