mirror of
https://github.com/chinchang/web-maker.git
synced 2025-06-17 13:09:12 +02:00
fix release process
This commit is contained in:
101
gulpfile.js
101
gulpfile.js
@ -2,9 +2,13 @@
|
||||
|
||||
const fs = require('fs');
|
||||
const gulp = require('gulp');
|
||||
const runSequence = require('run-sequence');
|
||||
const useref = require('gulp-useref');
|
||||
const cleanCSS = require('gulp-clean-css');
|
||||
const rename = require("gulp-rename");
|
||||
const babelMinify = require('babel-minify');
|
||||
const child_process = require('child_process');
|
||||
const merge = require('merge-stream');
|
||||
|
||||
function minifyJs(fileName) {
|
||||
const content = fs.readFileSync(fileName, 'utf8');
|
||||
@ -14,47 +18,65 @@ function minifyJs(fileName) {
|
||||
`[${fileName}]: ${content.length}kb -> ${minifiedContent.length}kb`
|
||||
);
|
||||
}
|
||||
gulp.task('copyFiles', [], function() {
|
||||
gulp
|
||||
gulp.task('runWebpack', function () {
|
||||
return child_process.execSync('yarn run build');
|
||||
});
|
||||
|
||||
gulp.task('copyFiles', function () {
|
||||
return merge(
|
||||
gulp
|
||||
.src('src/lib/codemirror/theme/*')
|
||||
.pipe(gulp.dest('app/lib/codemirror/theme'));
|
||||
gulp
|
||||
.pipe(gulp.dest('app/lib/codemirror/theme')),
|
||||
gulp
|
||||
.src('src/lib/codemirror/mode/**/*')
|
||||
.pipe(gulp.dest('app/lib/codemirror/mode'));
|
||||
gulp.src('src/lib/transpilers/*').pipe(gulp.dest('app/lib/transpilers'));
|
||||
gulp.src('src/partials/*').pipe(gulp.dest('app/partials'));
|
||||
gulp.src('src/lib/screenlog.js').pipe(gulp.dest('app/lib'));
|
||||
gulp.src('src/preview.html').pipe(gulp.dest('app'));
|
||||
gulp.src('src/detached-window.js').pipe(gulp.dest('app'));
|
||||
gulp.src('src/icon-48.png').pipe(gulp.dest('app'));
|
||||
gulp.src('src/icon-128.png').pipe(gulp.dest('app'));
|
||||
gulp.src('src/patreon.png').pipe(gulp.dest('app'));
|
||||
gulp
|
||||
.pipe(gulp.dest('app/lib/codemirror/mode')),
|
||||
gulp.src('src/lib/transpilers/*').pipe(gulp.dest('app/lib/transpilers')),
|
||||
gulp.src('src/lib/screenlog.js').pipe(gulp.dest('app/lib')),
|
||||
gulp.src('src/preview.html').pipe(gulp.dest('app')),
|
||||
gulp.src('src/detached-window.js').pipe(gulp.dest('app')),
|
||||
gulp.src('src/icon-48.png').pipe(gulp.dest('app')),
|
||||
gulp.src('src/icon-128.png').pipe(gulp.dest('app')),
|
||||
gulp.src('src/patreon.png').pipe(gulp.dest('app')),
|
||||
gulp.src('build/bundle.*.js').pipe(rename("script.js")).pipe(gulp.dest('app')),
|
||||
gulp.src('build/vendor.*.js').pipe(rename("vendor.js")).pipe(gulp.dest('app')),
|
||||
|
||||
gulp.src('src/lib/codemirror/lib/codemirror.css').pipe(gulp.dest('build/lib/codemirror/lib')),
|
||||
gulp.src('src/lib/codemirror/addon/hint/show-hint.css').pipe(gulp.dest('build/lib/codemirror/addon/hint')),
|
||||
gulp.src('src/lib/codemirror/addon/fold/foldgutter.css').pipe(gulp.dest('build/lib/codemirror/addon/fold')),
|
||||
gulp.src('src/lib/codemirror/addon/dialog/dialog.css').pipe(gulp.dest('build/lib/codemirror/addon/dialog')),
|
||||
gulp.src('src/lib/hint.min.css').pipe(gulp.dest('build/lib')),
|
||||
gulp.src('src/lib/inlet.css').pipe(gulp.dest('build/lib')),
|
||||
gulp.src('src/style.css').pipe(gulp.dest('build')),
|
||||
|
||||
gulp
|
||||
.src([
|
||||
'src/FiraCode.ttf',
|
||||
'src/FixedSys.ttf',
|
||||
'src/Inconsolata.ttf',
|
||||
'src/Monoid.ttf'
|
||||
])
|
||||
.pipe(gulp.dest('app'));
|
||||
.pipe(gulp.dest('app'))
|
||||
);
|
||||
});
|
||||
|
||||
gulp.task('useRef', ['copyFiles'], function() {
|
||||
gulp.task('useRef', function () {
|
||||
return gulp
|
||||
.src('src/index.html')
|
||||
.src('build/index.html')
|
||||
.pipe(useref())
|
||||
.pipe(gulp.dest('app'));
|
||||
});
|
||||
|
||||
gulp.task('minify', ['useRef'], function() {
|
||||
minifyJs('app/script.js');
|
||||
minifyJs('app/vendor.js');
|
||||
gulp.task('minify', function () {
|
||||
// minifyJs('app/script.js');
|
||||
// minifyJs('app/vendor.js');
|
||||
minifyJs('app/lib/screenlog.js');
|
||||
|
||||
gulp
|
||||
.src('app/*.css')
|
||||
.pipe(
|
||||
cleanCSS({ debug: true }, details => {
|
||||
cleanCSS({
|
||||
debug: true
|
||||
}, details => {
|
||||
console.log(`${details.name}: ${details.stats.originalSize}`);
|
||||
console.log(`${details.name}: ${details.stats.minifiedSize}`);
|
||||
})
|
||||
@ -62,13 +84,18 @@ gulp.task('minify', ['useRef'], function() {
|
||||
.pipe(gulp.dest('app'));
|
||||
});
|
||||
|
||||
gulp.task('generate-service-worker', ['minify'], function(callback) {
|
||||
gulp.task('fixIndex', function () {
|
||||
var contents = fs.readFileSync('build/index.html', 'utf8');
|
||||
contents = contents.replace(/\<\!\-\- SCRIPT-TAGS \-\-\>[\S\s]*?\<\!\-\- END-SCRIPT-TAGS \-\-\>/, '<script defer src="vendor.js"></script><script defer src="script.js"></script>');
|
||||
fs.writeFileSync('build/index.html', contents, 'utf8');
|
||||
});
|
||||
|
||||
gulp.task('generate-service-worker', function (callback) {
|
||||
var swPrecache = require('sw-precache');
|
||||
var rootDir = 'app';
|
||||
|
||||
swPrecache.write(
|
||||
`${rootDir}/service-worker.js`,
|
||||
{
|
||||
`${rootDir}/service-worker.js`, {
|
||||
staticFileGlobs: [
|
||||
rootDir + '/**/*.{js,html,css,png,jpg,gif,svg,eot,ttf,woff}'
|
||||
],
|
||||
@ -81,4 +108,28 @@ gulp.task('generate-service-worker', ['minify'], function(callback) {
|
||||
);
|
||||
});
|
||||
|
||||
gulp.task('default', ['generate-service-worker']);
|
||||
gulp.task('cleanup', function () {
|
||||
return child_process.execSync('rm -rf build');
|
||||
});
|
||||
|
||||
gulp.task('release', function (callback) {
|
||||
runSequence(
|
||||
'runWebpack',
|
||||
'copyFiles',
|
||||
'fixIndex',
|
||||
'useRef',
|
||||
'minify',
|
||||
'generate-service-worker',
|
||||
'cleanup',
|
||||
function (error) {
|
||||
if (error) {
|
||||
console.log(error.message);
|
||||
} else {
|
||||
console.log('RELEASE FINISHED SUCCESSFULLY');
|
||||
}
|
||||
callback(error);
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
// gulp.task('default', ['generate-service-worker']);
|
||||
|
Reference in New Issue
Block a user