mirror of
				https://github.com/traefik/traefik.git
				synced 2025-10-25 22:41:12 +02:00 
			
		
		
		
	- clean before build (mode force) - update documentation - update `Makefile` - ordering build
		
			
				
	
	
		
			99 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| var path = require('path');
 | |
| var gulp = require('gulp');
 | |
| var conf = require('./conf');
 | |
| 
 | |
| var $ = require('gulp-load-plugins')({
 | |
|   pattern: ['gulp-*', 'main-bower-files', 'uglify-save-license', 'del']
 | |
| });
 | |
| 
 | |
| gulp.task('partials', function () {
 | |
|   return gulp.src([
 | |
|     path.join(conf.paths.src, '/app/**/*.html'),
 | |
|     path.join(conf.paths.tmp, '/serve/app/**/*.html')
 | |
|   ])
 | |
|     .pipe($.minifyHtml({
 | |
|       empty: true,
 | |
|       spare: true,
 | |
|       quotes: true
 | |
|     }))
 | |
|     .pipe($.angularTemplatecache('templateCacheHtml.js', {
 | |
|       module: 'traefik',
 | |
|       root: 'app'
 | |
|     }))
 | |
|     .pipe(gulp.dest(conf.paths.tmp + '/partials/'));
 | |
| });
 | |
| 
 | |
| gulp.task('html', ['inject', 'partials'], function () {
 | |
|   var partialsInjectFile = gulp.src(path.join(conf.paths.tmp, '/partials/templateCacheHtml.js'), { read: false });
 | |
|   var partialsInjectOptions = {
 | |
|     starttag: '<!-- inject:partials -->',
 | |
|     ignorePath: path.join(conf.paths.tmp, '/partials'),
 | |
|     addRootSlash: false
 | |
|   };
 | |
| 
 | |
|   var htmlFilter = $.filter('*.html', { restore: true });
 | |
|   var jsFilter = $.filter('**/*.js', { restore: true });
 | |
|   var cssFilter = $.filter('**/*.css', { restore: true });
 | |
|   var assets;
 | |
| 
 | |
|   return gulp.src(path.join(conf.paths.tmp, '/serve/*.html'))
 | |
|     .pipe($.inject(partialsInjectFile, partialsInjectOptions))
 | |
|     .pipe(assets = $.useref.assets())
 | |
|     .pipe($.rev())
 | |
|     .pipe(jsFilter)
 | |
|     .pipe($.sourcemaps.init())
 | |
|     .pipe($.ngAnnotate())
 | |
|     .pipe($.uglify({ preserveComments: $.uglifySaveLicense })).on('error', conf.errorHandler('Uglify'))
 | |
|     .pipe($.sourcemaps.write('maps'))
 | |
|     .pipe(jsFilter.restore)
 | |
|     .pipe(cssFilter)
 | |
|     .pipe($.sourcemaps.init())
 | |
|     .pipe($.replace('../../bower_components/bootstrap-sass/assets/fonts/bootstrap/', '../fonts/'))
 | |
|     .pipe($.minifyCss({ processImport: false }))
 | |
|     .pipe($.sourcemaps.write('maps'))
 | |
|     .pipe(cssFilter.restore)
 | |
|     .pipe(assets.restore())
 | |
|     .pipe($.useref())
 | |
|     .pipe($.revReplace())
 | |
|     .pipe(htmlFilter)
 | |
|     .pipe($.minifyHtml({
 | |
|       empty: true,
 | |
|       spare: true,
 | |
|       quotes: true,
 | |
|       conditionals: true
 | |
|     }))
 | |
|     .pipe(htmlFilter.restore)
 | |
|     .pipe(gulp.dest(path.join(conf.paths.dist, '/')))
 | |
|     .pipe($.size({ title: path.join(conf.paths.dist, '/'), showFiles: true }));
 | |
|   });
 | |
| 
 | |
| // Only applies for fonts from bower dependencies
 | |
| // Custom fonts are handled by the "other" task
 | |
| gulp.task('fonts', function () {
 | |
|   return gulp.src($.mainBowerFiles())
 | |
|     .pipe($.filter('**/*.{eot,svg,ttf,woff,woff2}'))
 | |
|     .pipe($.flatten())
 | |
|     .pipe(gulp.dest(path.join(conf.paths.dist, '/fonts/')));
 | |
| });
 | |
| 
 | |
| gulp.task('other', function () {
 | |
|   var fileFilter = $.filter(function (file) {
 | |
|     return file.stat.isFile();
 | |
|   });
 | |
| 
 | |
|   return gulp.src([
 | |
|     path.join(conf.paths.src, '/**/*'),
 | |
|     path.join('!' + conf.paths.src, '/**/*.{html,css,js,scss}')
 | |
|   ])
 | |
|     .pipe(fileFilter)
 | |
|     .pipe(gulp.dest(path.join(conf.paths.dist, '/')));
 | |
| });
 | |
| 
 | |
| gulp.task('clean', function () {
 | |
|   return $.del([path.join(conf.paths.dist, '/**'), '!' + conf.paths.dist, path.join(conf.paths.tmp, '/')], {force: true});
 | |
| });
 | |
| 
 | |
| gulp.task('build', ['html', 'fonts', 'other']);
 |