mirror of
https://github.com/videojs/video.js.git
synced 2025-02-16 12:23:54 +02:00
Close GH-535: Adding version numbers in build. Minifying CSS..
This commit is contained in:
parent
36c92404c3
commit
0fe7348456
73
Gruntfile.js
73
Gruntfile.js
@ -77,17 +77,8 @@ module.exports = function(grunt) {
|
|||||||
},
|
},
|
||||||
s3: {
|
s3: {
|
||||||
options: s3,
|
options: s3,
|
||||||
prod: {
|
minor: {
|
||||||
// Files to be uploaded.
|
|
||||||
upload: [
|
upload: [
|
||||||
{
|
|
||||||
src: 'dist/cdn/*',
|
|
||||||
dest: 'vjs/'+version.full+'/',
|
|
||||||
rel: 'dist/cdn/',
|
|
||||||
headers: {
|
|
||||||
'Cache-Control': 'public, max-age=31536000'
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
src: 'dist/cdn/*',
|
src: 'dist/cdn/*',
|
||||||
dest: 'vjs/'+version.majorMinor+'/',
|
dest: 'vjs/'+version.majorMinor+'/',
|
||||||
@ -97,6 +88,27 @@ module.exports = function(grunt) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
patch: {
|
||||||
|
upload: [
|
||||||
|
{
|
||||||
|
src: 'dist/cdn/*',
|
||||||
|
dest: 'vjs/'+version.full+'/',
|
||||||
|
rel: 'dist/cdn/',
|
||||||
|
headers: {
|
||||||
|
'Cache-Control': 'public, max-age=31536000'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
cssmin: {
|
||||||
|
minify: {
|
||||||
|
expand: true,
|
||||||
|
cwd: 'build/files/',
|
||||||
|
src: ['video-js.css'],
|
||||||
|
dest: 'build/files/',
|
||||||
|
ext: '.min.css'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -106,6 +118,7 @@ module.exports = function(grunt) {
|
|||||||
grunt.loadNpmTasks('grunt-contrib-watch');
|
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||||
grunt.loadNpmTasks('grunt-contrib-clean');
|
grunt.loadNpmTasks('grunt-contrib-clean');
|
||||||
grunt.loadNpmTasks('grunt-contrib-copy');
|
grunt.loadNpmTasks('grunt-contrib-copy');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-cssmin');
|
||||||
grunt.loadNpmTasks('grunt-s3');
|
grunt.loadNpmTasks('grunt-s3');
|
||||||
grunt.loadNpmTasks('contribflow');
|
grunt.loadNpmTasks('contribflow');
|
||||||
|
|
||||||
@ -133,28 +146,35 @@ module.exports = function(grunt) {
|
|||||||
sourceFiles[i] = sourceFiles[i].replace(/\\/g, '/');
|
sourceFiles[i] = sourceFiles[i].replace(/\\/g, '/');
|
||||||
}
|
}
|
||||||
|
|
||||||
// grunt.file.write('build/files/sourcelist.txt', sourceList.join(','));
|
|
||||||
// Allow time for people to update their index.html before they remove these
|
|
||||||
// grunt.file.write('build/files/sourcelist.js', 'var sourcelist = ["' + sourceFiles.join('","') + '"]');
|
|
||||||
|
|
||||||
// Create a combined sources file. https://github.com/zencoder/video-js/issues/287
|
// Create a combined sources file. https://github.com/zencoder/video-js/issues/287
|
||||||
var combined = '';
|
var combined = '';
|
||||||
sourceFiles.forEach(function(result){
|
sourceFiles.forEach(function(result){
|
||||||
combined += grunt.file.read(result);
|
combined += grunt.file.read(result);
|
||||||
});
|
});
|
||||||
|
// Replace CDN version ref in js. Use major/minor version.
|
||||||
|
combined = combined.replace(/GENERATED_CDN_VSN/g, version.majorMinor);
|
||||||
grunt.file.write('build/files/combined.video.js', combined);
|
grunt.file.write('build/files/combined.video.js', combined);
|
||||||
|
|
||||||
|
// Copy over other files
|
||||||
grunt.file.copy('src/css/video-js.css', 'build/files/video-js.css');
|
grunt.file.copy('src/css/video-js.css', 'build/files/video-js.css');
|
||||||
grunt.file.copy('src/css/video-js.png', 'build/files/video-js.png');
|
grunt.file.copy('src/css/video-js.png', 'build/files/video-js.png');
|
||||||
grunt.file.copy('src/swf/video-js.swf', 'build/files/video-js.swf');
|
grunt.file.copy('src/swf/video-js.swf', 'build/files/video-js.swf');
|
||||||
// grunt.file.copy('src/css/font/', 'build/files/font/');
|
|
||||||
|
|
||||||
|
// Inject version number into css file
|
||||||
|
var css = grunt.file.read('build/files/video-js.css');
|
||||||
|
css = css.replace(/GENERATED_AT_BUILD/g, version.full);
|
||||||
|
grunt.file.write('build/files/video-js.css', css);
|
||||||
|
|
||||||
|
// Copy over font files
|
||||||
grunt.file.recurse('src/css/font', function(absdir, rootdir, subdir, filename) {
|
grunt.file.recurse('src/css/font', function(absdir, rootdir, subdir, filename) {
|
||||||
// Block .DS_Store files
|
// Block .DS_Store files
|
||||||
if ('filename'.substring(0,1) !== '.') {
|
if ('filename'.substring(0,1) !== '.') {
|
||||||
grunt.file.copy(absdir, 'build/files/font/' + filename);
|
grunt.file.copy(absdir, 'build/files/font/' + filename);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Minify CSS
|
||||||
|
grunt.task.run(['cssmin']);
|
||||||
});
|
});
|
||||||
|
|
||||||
grunt.registerMultiTask('minify', 'Minify JS files using Closure Compiler.', function() {
|
grunt.registerMultiTask('minify', 'Minify JS files using Closure Compiler.', function() {
|
||||||
@ -175,24 +195,26 @@ module.exports = function(grunt) {
|
|||||||
filePatterns = filePatterns.concat(this.data.src);
|
filePatterns = filePatterns.concat(this.data.src);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Build closure compiler shell command
|
||||||
var command = 'java -jar build/compiler/compiler.jar'
|
var command = 'java -jar build/compiler/compiler.jar'
|
||||||
+ ' --compilation_level ADVANCED_OPTIMIZATIONS'
|
+ ' --compilation_level ADVANCED_OPTIMIZATIONS'
|
||||||
// + ' --formatting=pretty_print'
|
// + ' --formatting=pretty_print'
|
||||||
+ ' --js_output_file=' + dest
|
+ ' --js_output_file=' + dest
|
||||||
+ ' --create_source_map ' + dest + '.map --source_map_format=V3'
|
+ ' --create_source_map ' + dest + '.map --source_map_format=V3'
|
||||||
+ ' --jscomp_warning=checkTypes --warning_level=VERBOSE'
|
+ ' --jscomp_warning=checkTypes --warning_level=VERBOSE'
|
||||||
+ ' --output_wrapper "/*! ' + pkg.copyright + ' */\n (function() {%output%})();//@ sourceMappingURL=video.js.map"';
|
+ ' --output_wrapper "/*! Video.js v' + version.full + ' ' + pkg.copyright + ' */\n (function() {%output%})();//@ sourceMappingURL=video.js.map"';
|
||||||
|
|
||||||
|
// Add each js file
|
||||||
grunt.file.expand(filePatterns).forEach(function(file){
|
grunt.file.expand(filePatterns).forEach(function(file){
|
||||||
command += ' --js='+file;
|
command += ' --js='+file;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Add externs
|
||||||
externs.forEach(function(extern){
|
externs.forEach(function(extern){
|
||||||
command += ' --externs='+extern;
|
command += ' --externs='+extern;
|
||||||
});
|
});
|
||||||
|
|
||||||
// grunt.log.writeln(command)
|
// Run command
|
||||||
|
|
||||||
exec(command, { maxBuffer: 500*1024 }, function(err, stdout, stderr){
|
exec(command, { maxBuffer: 500*1024 }, function(err, stdout, stderr){
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
@ -211,14 +233,18 @@ module.exports = function(grunt) {
|
|||||||
grunt.registerTask('dist', 'Creating distribution', function(){
|
grunt.registerTask('dist', 'Creating distribution', function(){
|
||||||
var exec = require('child_process').exec;
|
var exec = require('child_process').exec;
|
||||||
var done = this.async();
|
var done = this.async();
|
||||||
|
var css, jsmin, jsdev;
|
||||||
|
|
||||||
|
// Manually copy each source file
|
||||||
grunt.file.copy('build/files/minified.video.js', 'dist/video-js/video.js');
|
grunt.file.copy('build/files/minified.video.js', 'dist/video-js/video.js');
|
||||||
grunt.file.copy('build/files/combined.video.js', 'dist/video-js/video.dev.js');
|
grunt.file.copy('build/files/combined.video.js', 'dist/video-js/video.dev.js');
|
||||||
grunt.file.copy('build/files/video-js.css', 'dist/video-js/video-js.css');
|
grunt.file.copy('build/files/video-js.css', 'dist/video-js/video-js.css');
|
||||||
|
grunt.file.copy('build/files/video-js.min.css', 'dist/video-js/video-js.min.css');
|
||||||
grunt.file.copy('build/files/video-js.swf', 'dist/video-js/video-js.swf');
|
grunt.file.copy('build/files/video-js.swf', 'dist/video-js/video-js.swf');
|
||||||
grunt.file.copy('build/demo-files/demo.html', 'dist/video-js/demo.html');
|
grunt.file.copy('build/demo-files/demo.html', 'dist/video-js/demo.html');
|
||||||
grunt.file.copy('build/demo-files/demo.captions.vtt', 'dist/video-js/demo.captions.vtt');
|
grunt.file.copy('build/demo-files/demo.captions.vtt', 'dist/video-js/demo.captions.vtt');
|
||||||
|
|
||||||
|
// Copy over font files
|
||||||
grunt.file.recurse('build/files/font', function(absdir, rootdir, subdir, filename) {
|
grunt.file.recurse('build/files/font', function(absdir, rootdir, subdir, filename) {
|
||||||
// Block .DS_Store files
|
// Block .DS_Store files
|
||||||
if ('filename'.substring(0,1) !== '.') {
|
if ('filename'.substring(0,1) !== '.') {
|
||||||
@ -227,18 +253,17 @@ module.exports = function(grunt) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// CDN version uses already hosted font files
|
// CDN version uses already hosted font files
|
||||||
// Minified version only
|
// Minified version only, doesn't need demo files
|
||||||
// doesn't need demo files
|
|
||||||
grunt.file.copy('build/files/minified.video.js', 'dist/cdn/video.js');
|
grunt.file.copy('build/files/minified.video.js', 'dist/cdn/video.js');
|
||||||
grunt.file.copy('build/files/video-js.css', 'dist/cdn/video-js.css');
|
grunt.file.copy('build/files/video-js.min.css', 'dist/cdn/video-js.css');
|
||||||
grunt.file.copy('build/files/video-js.swf', 'dist/cdn/video-js.swf');
|
grunt.file.copy('build/files/video-js.swf', 'dist/cdn/video-js.swf');
|
||||||
|
|
||||||
|
// Replace font urls with CDN versions
|
||||||
|
css = grunt.file.read('dist/cdn/video-js.css');
|
||||||
var css = grunt.file.read('dist/cdn/video-js.css');
|
|
||||||
css = css.replace(/font\//g, '../f/1/');
|
css = css.replace(/font\//g, '../f/1/');
|
||||||
grunt.file.write('dist/cdn/video-js.css', css);
|
grunt.file.write('dist/cdn/video-js.css', css);
|
||||||
|
|
||||||
|
// Zip up into video-js-VERSION.zip
|
||||||
exec('cd dist && zip -r video-js-'+version.full+'.zip video-js && cd ..', { maxBuffer: 500*1024 }, function(err, stdout, stderr){
|
exec('cd dist && zip -r video-js-'+version.full+'.zip video-js && cd ..', { maxBuffer: 500*1024 }, function(err, stdout, stderr){
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -30,7 +30,8 @@
|
|||||||
"mocha": "~1.8.1",
|
"mocha": "~1.8.1",
|
||||||
"contribflow": "~0.2.0",
|
"contribflow": "~0.2.0",
|
||||||
"grunt-s3": "~0.2.0-alpha",
|
"grunt-s3": "~0.2.0-alpha",
|
||||||
"semver": "~1.1.4"
|
"semver": "~1.1.4",
|
||||||
|
"grunt-contrib-cssmin": "~0.6.0"
|
||||||
},
|
},
|
||||||
"testling": {
|
"testling": {
|
||||||
"browsers": [
|
"browsers": [
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*!
|
||||||
VideoJS Default Styles (http://videojs.com)
|
Video.js Default Styles (http://videojs.com)
|
||||||
Version GENERATED_AT_BUILD
|
Version GENERATED_AT_BUILD
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ vjs.options = {
|
|||||||
// techOrder: ['flash','html5'],
|
// techOrder: ['flash','html5'],
|
||||||
|
|
||||||
'html5': {},
|
'html5': {},
|
||||||
'flash': { 'swf': vjs.ACCESS_PROTOCOL + 'vjs.zencdn.net/4.0/video-js.swf' },
|
'flash': {},
|
||||||
|
|
||||||
// Default of web browser is 300x150. Should rely on source width/height.
|
// Default of web browser is 300x150. Should rely on source width/height.
|
||||||
'width': 300,
|
'width': 300,
|
||||||
@ -90,14 +90,14 @@ vjs.options = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Set CDN Version of swf
|
||||||
|
// The added (+) blocks the replace from changing this GENERATED_CDN_VSN string
|
||||||
|
if (vjs.CDN_VERSION !== 'GENERATED'+'_CDN_VSN') {
|
||||||
|
videojs.options['flash']['swf'] = vjs.ACCESS_PROTOCOL + 'vjs.zencdn.net/'+vjs.CDN_VERSION+'/video-js.swf';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Global player list
|
* Global player list
|
||||||
* @type {Object}
|
* @type {Object}
|
||||||
*/
|
*/
|
||||||
vjs.players = {};
|
vjs.players = {};
|
||||||
|
|
||||||
|
|
||||||
// Set CDN Version of swf
|
|
||||||
if (vjs.CDN_VERSION != 'GENERATED_CDN_VSN') {
|
|
||||||
videojs.options['flash']['swf'] = vjs.ACCESS_PROTOCOL + 'vjs.zencdn.net/'+vjs.CDN_VERSION+'/video-js.swf';
|
|
||||||
}
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user