• File: gulpfile.js
  • Full Path: /home/dealkatnwc/www/wp-content/plugins/formcraft3/gulpfile.js
  • Date Modified: 02/11/2019 5:06 PM
  • File size: 2.28 KB
  • MIME-type: text/plain
  • Charset: utf-8
const gulp = require('gulp')
const path = require('path')
const cleanCSS = require('gulp-clean-css')
const uglify = require('gulp-uglify')
const webpack = require('webpack-stream')
const concat = require('gulp-concat')
const less = require('gulp-less')
const del = require('del')
const runSequence = require('run-sequence')

const paths = {
	mainScripts: [
		'./assets/js/form.js',
		'./assets/js/vendor/jquery.mask.js',
		'./assets/js/vendor/jquery.ui.touch-punch.js'
	],
	LESStoCSS: ['./src/less/*.less']
}

const adminScripts = [
	'dashboard',
	'insights',
	'entries',
	'uploads',
	'license',
	'builder'
]


gulp.task('Form.JS', () => {
	return gulp.src('./assets/js/src/form.js')
	.pipe(webpack({
		entry: './assets/js/src/form.js',
		output: {
			path: `${__dirname}/assets/js/`,
			filename: 'form.js'
		},
		module: {
			loaders: [{
				test: /\.js$/,
				include: [path.resolve(__dirname, 'assets/js')],
				loader: 'babel',
				query: { presets: ['es2015'] }
			}]
		}
	}))
	.pipe(gulp.dest('./assets/js/'))
})

gulp.task('mainScripts', () => {
	gulp.src(paths.mainScripts)
	.pipe(concat('form.min.js'))
	.pipe(uglify({ compress:{ properties: false } }))
	.pipe(gulp.dest('./dist/'))
	return del(['./assets/js/form.js'])
})

function doAdminScripts(script) {
	return gulp.src(`./src/js/${script}.js`)
	.pipe(webpack({
		watch: 'true',
		entry: `./src/js/${script}.js`,
		cache : true,
		output: {
			path: `${__dirname}/dist/`,
			filename: `${script}.min.js`
		},
		resolve: {
			extensions: ['', '.js', '.jsx']
		},
		module: {
			loaders: [{
				test: /\.(jsx|js)$/,
				exclude: /(node_modules)/,
				loader: ['babel'],
				query: { presets: ['es2015', 'react'] }
			}]
		}
	}))
	.pipe(uglify({ mangle: false, compress:{ properties: false } }))
	.pipe(gulp.dest('./dist/'))
}

gulp.task('LESStoCSS', () => {
	return gulp.src(paths.LESStoCSS)
	.pipe(less())
	.pipe(cleanCSS({ compatibility: 'ie8' }))
	.pipe(gulp.dest('./dist/'))
})


for (let script of adminScripts) {
	doAdminScripts(`formcraft-${script}`)
}

gulp.watch(['./assets/js/src/form.js', './assets/js/src/helpers.js', './assets/js/src/formcraft.validation.js'], ['scripts'])

gulp.watch('./src/less/*.less', ['LESStoCSS'])
gulp.task('default', ['scripts', 'LESStoCSS'])

gulp.task('scripts', (callback) => {
	runSequence('Form.JS', 'mainScripts', callback)
})