%PDF- %PDF-
Direktori : /home/medipszd/public_html/bower_components/chart.js/ |
Current File : //home/medipszd/public_html/bower_components/chart.js/gulpfile.js |
var gulp = require('gulp'), concat = require('gulp-concat'), uglify = require('gulp-uglify'), util = require('gulp-util'), jshint = require('gulp-jshint'), size = require('gulp-size'), connect = require('gulp-connect'), replace = require('gulp-replace'), htmlv = require('gulp-html-validator'), inquirer = require('inquirer'), semver = require('semver'), exec = require('child_process').exec, fs = require('fs'), package = require('./package.json'), bower = require('./bower.json'); var srcDir = './src/'; /* * Usage : gulp build --types=Bar,Line,Doughnut * Output: - A built Chart.js file with Core and types Bar, Line and Doughnut concatenated together * - A minified version of this code, in Chart.min.js */ gulp.task('build', function(){ // Default to all of the chart types, with Chart.Core first var srcFiles = [FileName('Core')], isCustom = !!(util.env.types), outputDir = (isCustom) ? 'custom' : '.'; if (isCustom){ util.env.types.split(',').forEach(function(type){ return srcFiles.push(FileName(type))}); } else{ // Seems gulp-concat remove duplicates - nice! // So we can use this to sort out dependency order - aka include Core first! srcFiles.push(srcDir+'*'); } return gulp.src(srcFiles) .pipe(concat('Chart.js')) .pipe(replace('{{ version }}', package.version)) .pipe(gulp.dest(outputDir)) .pipe(uglify({preserveComments:'some'})) .pipe(concat('Chart.min.js')) .pipe(gulp.dest(outputDir)); function FileName(moduleName){ return srcDir+'Chart.'+moduleName+'.js'; }; }); /* * Usage : gulp bump * Prompts: Version increment to bump * Output: - New version number written into package.json & bower.json */ gulp.task('bump', function(complete){ util.log('Current version:', util.colors.cyan(package.version)); var choices = ['major', 'premajor', 'minor', 'preminor', 'patch', 'prepatch', 'prerelease'].map(function(versionType){ return versionType + ' (v' + semver.inc(package.version, versionType) + ')'; }); inquirer.prompt({ type: 'list', name: 'version', message: 'What version update would you like?', choices: choices }, function(res){ var increment = res.version.split(' ')[0], newVersion = semver.inc(package.version, increment); // Set the new versions into the bower/package object package.version = newVersion; bower.version = newVersion; // Write these to their own files, then build the output fs.writeFileSync('package.json', JSON.stringify(package, null, 2)); fs.writeFileSync('bower.json', JSON.stringify(bower, null, 2)); complete(); }); }); gulp.task('release', ['build'], function(){ exec('git tag -a v' + package.version); }); gulp.task('jshint', function(){ return gulp.src(srcDir + '*.js') .pipe(jshint()) .pipe(jshint.reporter('default')); }); gulp.task('valid', function(){ return gulp.src('samples/*.html') .pipe(htmlv()); }); gulp.task('library-size', function(){ return gulp.src('Chart.min.js') .pipe(size({ gzip: true })); }); gulp.task('module-sizes', function(){ return gulp.src(srcDir + '*.js') .pipe(uglify({preserveComments:'some'})) .pipe(size({ showFiles: true, gzip: true })) }); gulp.task('watch', function(){ gulp.watch('./src/*', ['build']); }); gulp.task('test', ['jshint', 'valid']); gulp.task('size', ['library-size', 'module-sizes']); gulp.task('default', ['build', 'watch']); gulp.task('server', function(){ connect.server({ port: 8000 }); }); // Convenience task for opening the project straight from the command line gulp.task('_open', function(){ exec('open http://localhost:8000'); exec('subl .'); }); gulp.task('dev', ['server', 'default']);