mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
361 lines
11 KiB
JavaScript
361 lines
11 KiB
JavaScript
var gulp = require('gulp'),
|
|
babel = require('gulp-babel'),
|
|
diff = require('gulp-diff'),
|
|
notify = require('gulp-notify'),
|
|
postcss = require('gulp-postcss'),
|
|
sass = require('gulp-sass'),
|
|
uglify = require('gulp-uglify'),
|
|
gulpUtil = require('gulp-util'),
|
|
autoprefixer = require('autoprefixer'),
|
|
browserify = require('browserify'),
|
|
babelify = require('babelify'),
|
|
watchify = require('watchify'),
|
|
source = require('vinyl-source-stream'),
|
|
buffer = require('vinyl-buffer'),
|
|
path = require('path'),
|
|
glob = require('glob'),
|
|
eventStream = require('event-stream'),
|
|
semver = require('semver'),
|
|
packageJson = require('./package.json'),
|
|
sprity = require('sprity'),
|
|
gulpif = require('gulp-if'),
|
|
sourcemaps = require('gulp-sourcemaps');
|
|
|
|
var isDev = typeof process.env.npm_config_development !== 'undefined';
|
|
|
|
var PATHS = {
|
|
MODULES: './node_modules',
|
|
ADMIN: './admin',
|
|
ADMIN_IMAGES: './admin/images',
|
|
ADMIN_SCSS: './admin/scss',
|
|
ADMIN_THIRDPARTY: './admin/thirdparty',
|
|
ADMIN_JAVASCRIPT_SRC: './admin/javascript/src',
|
|
ADMIN_JAVASCRIPT_DIST: './admin/javascript/dist',
|
|
FRAMEWORK: '.',
|
|
FRAMEWORK_THIRDPARTY: './thirdparty',
|
|
FRAMEWORK_DEV_INSTALL: './dev/install',
|
|
FRAMEWORK_JAVASCRIPT_SRC: './javascript/src',
|
|
FRAMEWORK_JAVASCRIPT_DIST: './javascript/dist'
|
|
};
|
|
|
|
// Folders which contain both scss and css folders to be compiled
|
|
var rootCompileFolders = [PATHS.FRAMEWORK, PATHS.ADMIN, PATHS.FRAMEWORK_DEV_INSTALL]
|
|
|
|
var browserifyOptions = {
|
|
cache: {},
|
|
packageCache: {},
|
|
poll: true,
|
|
plugin: [watchify]
|
|
};
|
|
|
|
// Used for autoprefixing css properties (same as Bootstrap Aplha.2 defaults)
|
|
var supportedBrowsers = [
|
|
'Chrome >= 35',
|
|
'Firefox >= 31',
|
|
'Edge >= 12',
|
|
'Explorer >= 9',
|
|
'iOS >= 8',
|
|
'Safari >= 8',
|
|
'Android 2.3',
|
|
'Android >= 4',
|
|
'Opera >= 12'
|
|
];
|
|
|
|
var blueimpFileUploadConfig = {
|
|
src: PATHS.MODULES + '/blueimp-file-upload',
|
|
dest: PATHS.FRAMEWORK_THIRDPARTY + '/jquery-fileupload',
|
|
files: [
|
|
'/cors/jquery.postmessage-transport.js',
|
|
'/cors/jquery.xdr-transport.js',
|
|
'/jquery.fileupload-ui.js',
|
|
'/jquery.fileupload.js',
|
|
'/jquery.iframe-transport.js'
|
|
]
|
|
};
|
|
|
|
var blueimpLoadImageConfig = {
|
|
src: PATHS.MODULES + '/blueimp-load-image',
|
|
dest: PATHS.FRAMEWORK_THIRDPARTY + '/javascript-loadimage',
|
|
files: ['/load-image.js']
|
|
};
|
|
|
|
var blueimpTmplConfig = {
|
|
src: PATHS.MODULES + '/blueimp-tmpl',
|
|
dest: PATHS.FRAMEWORK_THIRDPARTY + '/javascript-templates',
|
|
files: ['/tmpl.js']
|
|
};
|
|
|
|
var jquerySizesConfig = {
|
|
src: PATHS.MODULES + '/jquery-sizes',
|
|
dest: PATHS.ADMIN_THIRDPARTY + '/jsizes',
|
|
files: ['/lib/jquery.sizes.js']
|
|
};
|
|
|
|
var tinymceConfig = {
|
|
src: PATHS.MODULES + '/tinymce',
|
|
dest: PATHS.FRAMEWORK_THIRDPARTY + '/tinymce',
|
|
files: [
|
|
'/tinymce.min.js', // Exclude unminified file to keep repository size down
|
|
'/jquery.tinymce.min.js',
|
|
'/themes/**',
|
|
'/skins/**',
|
|
'/plugins/**'
|
|
]
|
|
};
|
|
|
|
/**
|
|
* Copies files from a source directory to a destination directory.
|
|
*
|
|
* @param object libConfig
|
|
* @param string libConfig.src - The source directory
|
|
* @param string libConfig.dest - The destination directory
|
|
* @param array libConfig.files - The list of files to copy from the source to the destination directory
|
|
*/
|
|
function copyFiles(libConfig) {
|
|
libConfig.files.forEach(function (file) {
|
|
var dir = path.parse(file).dir;
|
|
|
|
gulp.src(libConfig.src + file)
|
|
.pipe(gulp.dest(libConfig.dest + dir));
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Diffs files in a source directory against a destination directory.
|
|
*
|
|
* @param object libConfig
|
|
* @param string libConfig.src - The source directory
|
|
* @param string libConfig.dest - The destination directory
|
|
* @param array libConfig.files - The list of files to copy from the source to the destination directory
|
|
*/
|
|
function diffFiles(libConfig) {
|
|
libConfig.files.forEach(function (file) {
|
|
var dir = path.parse(file).dir;
|
|
|
|
gulp.src(libConfig.src + file)
|
|
.pipe(diff(libConfig.dest + dir))
|
|
.pipe(diff.reporter({ fail: true, quiet: true }))
|
|
.on('error', function (error) {
|
|
console.error(new Error('Sanity check failed. \'' + libConfig.dest + file + '\' has been modified.'));
|
|
process.exit(1);
|
|
});
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Transforms the passed JavaScript files to UMD modules.
|
|
*
|
|
* @param array files - The files to transform.
|
|
* @param string dest - The output directory.
|
|
* @return object
|
|
*/
|
|
function transformToUmd(files, dest) {
|
|
return eventStream.merge(files.map(function (file) {
|
|
return gulp.src(file)
|
|
.pipe(babel({
|
|
presets: ['es2015'],
|
|
moduleId: 'ss.' + path.parse(file).name,
|
|
plugins: ['transform-es2015-modules-umd'],
|
|
comments: false
|
|
}))
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>',
|
|
}))
|
|
.pipe(gulp.dest(dest));
|
|
}));
|
|
}
|
|
|
|
// Make sure the version of Node being used is valid.
|
|
if (!semver.satisfies(process.versions.node, packageJson.engines.node)) {
|
|
console.error('Invalid Node.js version. You need to be using ' + packageJson.engines.node + '. If you want to manage multiple Node.js versions try https://github.com/creationix/nvm');
|
|
process.exit(1);
|
|
}
|
|
|
|
if (isDev) {
|
|
browserifyOptions.debug = true;
|
|
}
|
|
|
|
gulp.task('build', ['umd', 'umd-watch', 'bundle']);
|
|
|
|
gulp.task('bundle', ['bundle-lib', 'bundle-leftandmain', 'bundle-react']);
|
|
|
|
gulp.task('bundle-leftandmain', function bundleLeftAndMain() {
|
|
var stream = browserify(Object.assign({}, browserifyOptions, {
|
|
entries: PATHS.ADMIN_JAVASCRIPT_SRC + '/bundles/leftandmain.js'
|
|
}))
|
|
.transform(babelify.configure({
|
|
presets: ['es2015'],
|
|
ignore: /(thirdparty)/,
|
|
comments: false
|
|
}))
|
|
.on('log', function (msg) { gulpUtil.log('Finished bundle-leftandmain.js ' + msg); })
|
|
.on('update', bundleLeftAndMain)
|
|
.external('jQuery')
|
|
.external('i18n')
|
|
.bundle()
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>',
|
|
}))
|
|
.pipe(source('bundle-leftandmain.js'))
|
|
.pipe(buffer());
|
|
|
|
if (!isDev) {
|
|
stream.pipe(uglify());
|
|
}
|
|
|
|
return stream.pipe(gulp.dest(PATHS.ADMIN_JAVASCRIPT_DIST));
|
|
});
|
|
|
|
gulp.task('bundle-lib', function bundleLib() {
|
|
var stream = browserify(Object.assign({}, browserifyOptions, {
|
|
entries: PATHS.ADMIN_JAVASCRIPT_SRC + '/bundles/lib.js'
|
|
}))
|
|
.transform(babelify.configure({
|
|
presets: ['es2015'],
|
|
ignore: /(thirdparty)/,
|
|
comments: false
|
|
}))
|
|
.on('log', function (msg) { gulpUtil.log('Finished bundle-lib.js ' + msg); })
|
|
.on('update', bundleLib)
|
|
.require(PATHS.FRAMEWORK_JAVASCRIPT_SRC + '/jQuery.js', { expose: 'jQuery' })
|
|
.require(PATHS.FRAMEWORK_JAVASCRIPT_SRC + '/i18n.js', { expose: 'i18n' })
|
|
.bundle()
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>',
|
|
}))
|
|
.pipe(source('bundle-lib.js'))
|
|
.pipe(buffer());
|
|
|
|
if (!isDev) {
|
|
stream.pipe(uglify());
|
|
}
|
|
|
|
return stream.pipe(gulp.dest(PATHS.ADMIN_JAVASCRIPT_DIST));
|
|
});
|
|
|
|
gulp.task('bundle-react', function bundleReact() {
|
|
var stream = browserify(Object.assign({}, browserifyOptions))
|
|
.on('log', function (msg) { gulpUtil.log('Finished bundle-react.js ' + msg); })
|
|
.on('update', bundleReact)
|
|
.require('react-addons-test-utils', { expose: 'react-addons-test-utils' })
|
|
.require('react', { expose: 'react' })
|
|
.require('react-dom', { expose: 'react-dom' })
|
|
.require('redux', { expose: 'redux' })
|
|
.require('react-redux', { expose: 'react-redux' })
|
|
.require('redux-thunk', { expose: 'redux-thunk' })
|
|
.require('isomorphic-fetch', { expose: 'isomorphic-fetch' })
|
|
.require(PATHS.ADMIN_JAVASCRIPT_DIST + '/SilverStripeComponent', { expose: 'silverstripe-component' })
|
|
.bundle()
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>',
|
|
}))
|
|
.pipe(source('bundle-react.js'))
|
|
.pipe(buffer());
|
|
|
|
if (typeof process.env.npm_config_development === 'undefined') {
|
|
stream.pipe(uglify());
|
|
}
|
|
|
|
return stream.pipe(gulp.dest(PATHS.ADMIN_JAVASCRIPT_DIST));
|
|
});
|
|
|
|
gulp.task('sanity', function () {
|
|
diffFiles(blueimpFileUploadConfig);
|
|
diffFiles(blueimpLoadImageConfig);
|
|
diffFiles(blueimpTmplConfig);
|
|
diffFiles(jquerySizesConfig);
|
|
diffFiles(tinymceConfig);
|
|
});
|
|
|
|
gulp.task('thirdparty', function () {
|
|
copyFiles(blueimpFileUploadConfig);
|
|
copyFiles(blueimpLoadImageConfig);
|
|
copyFiles(blueimpTmplConfig);
|
|
copyFiles(jquerySizesConfig);
|
|
copyFiles(tinymceConfig);
|
|
|
|
// TODO Remove once all TinyMCE plugins are bundled
|
|
var stream = browserify(Object.assign({}, browserifyOptions, {
|
|
entries: PATHS.FRAMEWORK_THIRDPARTY + '/tinymce_ssbuttons/plugin.js'
|
|
}))
|
|
.transform(babelify.configure({
|
|
presets: ['es2015'],
|
|
comments: false
|
|
}))
|
|
.bundle()
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>',
|
|
}))
|
|
.pipe(source('plugin.min.js'))
|
|
.pipe(buffer());
|
|
|
|
if (!isDev) {
|
|
stream.pipe(uglify());
|
|
}
|
|
|
|
return stream.pipe(gulp.dest(PATHS.FRAMEWORK_THIRDPARTY + '/tinymce_ssbuttons/'));
|
|
});
|
|
|
|
gulp.task('umd', ['umd-admin', 'umd-framework']);
|
|
|
|
gulp.task('umd-admin', function () {
|
|
var files = glob.sync(PATHS.ADMIN_JAVASCRIPT_SRC + '/*.js', { ignore: PATHS.ADMIN_JAVASCRIPT_SRC + '/LeftAndMain.!(Ping).js' });
|
|
|
|
return transformToUmd(files, PATHS.ADMIN_JAVASCRIPT_DIST);
|
|
});
|
|
|
|
gulp.task('umd-framework', function () {
|
|
return transformToUmd(glob.sync(PATHS.FRAMEWORK_JAVASCRIPT_SRC + '/*.js'), PATHS.FRAMEWORK_JAVASCRIPT_DIST);
|
|
});
|
|
|
|
gulp.task('umd-watch', function () {
|
|
gulp.watch(PATHS.ADMIN_JAVASCRIPT_SRC + '/*.js', ['umd-admin']);
|
|
gulp.watch(PATHS.FRAMEWORK_JAVASCRIPT_SRC + '/*.js', ['umd-framework']);
|
|
});
|
|
|
|
/*
|
|
* Takes individual images and compiles them together into sprites
|
|
*/
|
|
gulp.task('sprites', function () {
|
|
return sprity.src({
|
|
src: PATHS.ADMIN_IMAGES + '/sprites/src/**/*.{png,jpg}',
|
|
cssPath: '../images/sprites/dist',
|
|
style: './_spritey.scss',
|
|
processor: 'sass',
|
|
split: true,
|
|
margin: 0
|
|
})
|
|
.pipe(gulpif('*.png', gulp.dest(PATHS.ADMIN_IMAGES + '/sprites/dist'), gulp.dest(PATHS.ADMIN_SCSS)))
|
|
});
|
|
|
|
gulp.task('css', ['compile:css'], function () {
|
|
if (isDev) {
|
|
rootCompileFolders.forEach(function (folder) {
|
|
gulp.watch(folder + '/scss/**/*.scss', ['compile:css']);
|
|
});
|
|
}
|
|
})
|
|
|
|
/*
|
|
* Compiles scss into css
|
|
* Watches for changes if --development flag is given
|
|
*/
|
|
gulp.task('compile:css', function () {
|
|
var outputStyle = isDev ? 'expanded' : 'compressed';
|
|
|
|
var tasks = rootCompileFolders.map(function(folder) {
|
|
return gulp.src(folder + '/scss/**/*.scss')
|
|
.pipe(sourcemaps.init())
|
|
.pipe(sass({ outputStyle: outputStyle })
|
|
.on('error', notify.onError({
|
|
message: 'Error: <%= error.message %>'
|
|
}))
|
|
)
|
|
.pipe(postcss([autoprefixer({ browsers: supportedBrowsers })]))
|
|
.pipe(sourcemaps.write())
|
|
.pipe(gulp.dest(folder + '/css'))
|
|
});
|
|
|
|
return tasks;
|
|
});
|