init commit
This commit is contained in:
commit
c5d0f2d1b8
9 changed files with 322 additions and 0 deletions
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
node_modules/
|
||||||
|
package-lock.json
|
30
buildConfig.example.json
Normal file
30
buildConfig.example.json
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
{
|
||||||
|
"src": "$dir/src",
|
||||||
|
"out": "$dir/public/out",
|
||||||
|
"js": [
|
||||||
|
{
|
||||||
|
"name": "main",
|
||||||
|
"minify": true,
|
||||||
|
"onlyMinify": true,
|
||||||
|
"input": "$src/js/",
|
||||||
|
"output": "$out/js/",
|
||||||
|
"files": [
|
||||||
|
"app.js"
|
||||||
|
],
|
||||||
|
"compiler": {
|
||||||
|
"compilation_level": "ADVANCED",
|
||||||
|
"warning_level": "VERBOSE",
|
||||||
|
"language_in": "ECMASCRIPT6_STRICT",
|
||||||
|
"language_out": "ECMASCRIPT6_STRICT",
|
||||||
|
"js_output_file": "$name.min.js"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"scss": [
|
||||||
|
{
|
||||||
|
"name": "main",
|
||||||
|
"input": "$src/theme/**/*.scss",
|
||||||
|
"output": "$out/theme/$name"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
17
gulpfile.js
Normal file
17
gulpfile.js
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
const gulp = require('gulp'),
|
||||||
|
config = require('./tools/buildConfig'),
|
||||||
|
smartJS = require('./task/smartjs'),
|
||||||
|
smartCss = require('./task/smartcss');
|
||||||
|
|
||||||
|
config.prepare();
|
||||||
|
smartJS.prepare(config);
|
||||||
|
smartCss.prepare(config);
|
||||||
|
|
||||||
|
gulp.task('watchMe', () => {
|
||||||
|
smartJS.startWatch();
|
||||||
|
smartCss.startWatch();
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('default', gulp.parallel([...smartJS.build(), ...smartCss.build()]));
|
||||||
|
|
||||||
|
gulp.task('watch', gulp.parallel(['watchMe', ...smartJS.build(), ...smartCss.build()]));
|
10
index.js
Normal file
10
index.js
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
const gulp = require('gulp-cli'),
|
||||||
|
shouldWatch = process.argv.length > 2 && process.argv[2] === 'watch';
|
||||||
|
|
||||||
|
gulp()
|
||||||
|
require('./gulpfile')
|
||||||
|
if (shouldWatch) {
|
||||||
|
gulp.series('watchMe')();
|
||||||
|
} else {
|
||||||
|
gulp.series('default')();
|
||||||
|
}
|
27
package.json
Normal file
27
package.json
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
{
|
||||||
|
"name": "v-build",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "A Small Gulp Build System for Dynamic JS and SCSs",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {
|
||||||
|
"build-nm": "./node_modules/gulp-cli/bin/gulp.js",
|
||||||
|
"watch-nm": "./node_modules/gulp-cli/bin/gulp.js watch",
|
||||||
|
"build": "gulp",
|
||||||
|
"watch": "gulp watch"
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"GULP",
|
||||||
|
"JS",
|
||||||
|
"SCSS"
|
||||||
|
],
|
||||||
|
"author": "Maurice Grönwoldt",
|
||||||
|
"license": "GPL-3.0-or-later",
|
||||||
|
"dependencies": {
|
||||||
|
"google-closure-compiler": "^20210202.0.0",
|
||||||
|
"gulp": "^4.0.2",
|
||||||
|
"gulp-clean-css": "^4.3.0",
|
||||||
|
"gulp-cli": "^2.3.0",
|
||||||
|
"gulp-concat": "^2.6.1",
|
||||||
|
"gulp-sass": "^4.1.0"
|
||||||
|
}
|
||||||
|
}
|
55
task/smartcss.js
Normal file
55
task/smartcss.js
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
const gulp = require('gulp'),
|
||||||
|
HelperUnit = require('./../tools/helperUnit'),
|
||||||
|
sass = require('gulp-sass'),
|
||||||
|
clean = require('gulp-clean-css'),
|
||||||
|
path = require('path'),
|
||||||
|
workers = [];
|
||||||
|
|
||||||
|
class SCSSWorker {
|
||||||
|
constructor(config, helper) {
|
||||||
|
this.config = config;
|
||||||
|
this.helper = helper.clone();
|
||||||
|
this.input = this.helper.replaceVariables(this.config.input);
|
||||||
|
this.helper.addConfigItem("$name", this.config.name);
|
||||||
|
this.helper.addConfigItem("$", this.input);
|
||||||
|
this.out = this.helper.replaceVariables(this.config.output);
|
||||||
|
this.watch = this.helper.replaceVariables(this.config.watch || '$/**/*.{scss,sass}');
|
||||||
|
gulp.task(this.taskName, this.work.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
startWatch() {
|
||||||
|
gulp.watch(this.watch, gulp.series(this.taskName))
|
||||||
|
}
|
||||||
|
|
||||||
|
get taskName() {
|
||||||
|
return `scss-${this.config.name || 'unknown'}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
work() {
|
||||||
|
return gulp.src(this.input)
|
||||||
|
.pipe(sass().on('error', sass.logError))
|
||||||
|
.pipe(clean())
|
||||||
|
.pipe(gulp.dest(this.out));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
build: function () {
|
||||||
|
let array = [];
|
||||||
|
for (let worker of workers) {
|
||||||
|
array.push(worker.taskName);
|
||||||
|
}
|
||||||
|
return array;
|
||||||
|
},
|
||||||
|
prepare: function (config) {
|
||||||
|
const scss = config.scss || [];
|
||||||
|
for (let scssItem of scss) {
|
||||||
|
workers.push(new SCSSWorker(scssItem, config.helper));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
startWatch: function () {
|
||||||
|
for (let worker of workers) {
|
||||||
|
worker.startWatch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
98
task/smartjs.js
Normal file
98
task/smartjs.js
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
const closureCompiler = require('google-closure-compiler').gulp(),
|
||||||
|
concat = require('gulp-concat'),
|
||||||
|
gulp = require('gulp'),
|
||||||
|
path = require('path'),
|
||||||
|
workers = [];
|
||||||
|
|
||||||
|
class JSWorker {
|
||||||
|
constructor(config, helper) {
|
||||||
|
this.config = config;
|
||||||
|
this.helper = helper.clone();
|
||||||
|
if (!this.config.name) {
|
||||||
|
throw Error("Found Empty name for JS Job...");
|
||||||
|
}
|
||||||
|
this.validateConfig();
|
||||||
|
this.input = this.helper.replaceVariables(this.config.input);
|
||||||
|
this.helper.addConfigItem("$name", this.config.name);
|
||||||
|
this.helper.addConfigItem("$", this.input);
|
||||||
|
this.getCompilerConfig();
|
||||||
|
this.out = this.helper.replaceVariables(this.config.output);
|
||||||
|
this.watch = this.helper.replaceVariables(this.config.watch || '$/**/*.js');
|
||||||
|
this.prepareFiles(this.config.files)
|
||||||
|
this.path = path.parse(this.out);
|
||||||
|
gulp.task(this.taskName, this.work.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
validateConfig() {
|
||||||
|
let config = this.config;
|
||||||
|
config.onlyMinify = config.onlyMinify || false;
|
||||||
|
config.minify = config.minify || false;
|
||||||
|
if (!this.config.input || !this.config.output || !this.config.files) {
|
||||||
|
throw Error("Invalid Config for: " + this.config.name + ")");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
getCompilerConfig() {
|
||||||
|
this.compiler = {
|
||||||
|
compilation_level: 'SIMPLE',
|
||||||
|
warning_level: 'VERBOSE',
|
||||||
|
language_in: 'ECMASCRIPT6_STRICT',
|
||||||
|
language_out: 'ECMASCRIPT6_STRICT',
|
||||||
|
js_output_file: this.config.name + ".min.js"
|
||||||
|
}
|
||||||
|
if (this.config.compiler) {
|
||||||
|
this.compiler = Object.assign(this.compiler, this.config.compiler);
|
||||||
|
}
|
||||||
|
this.compiler.js_output_file = this.helper.replaceVariables(this.compiler.js_output_file);
|
||||||
|
}
|
||||||
|
|
||||||
|
startWatch() {
|
||||||
|
gulp.watch(this.watch, gulp.series(this.taskName))
|
||||||
|
}
|
||||||
|
|
||||||
|
get taskName() {
|
||||||
|
return `js-${this.config.name}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
prepareFiles(files) {
|
||||||
|
this.files = [];
|
||||||
|
for (const file of files) {
|
||||||
|
this.files.push(this.input + "/" + this.helper.replaceVariables(file));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
work() {
|
||||||
|
let d = gulp.src(this.files)
|
||||||
|
if (!this.config.onlyMinify) {
|
||||||
|
d.pipe(concat(this.config.name + '.js'))
|
||||||
|
.pipe(gulp.dest(this.path.dir));
|
||||||
|
}
|
||||||
|
if (this.config.minify) {
|
||||||
|
d.pipe(closureCompiler(this.compiler)).pipe(gulp.dest(this.path.dir));
|
||||||
|
}
|
||||||
|
return d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
build: function () {
|
||||||
|
let array = [];
|
||||||
|
for (let worker of workers) {
|
||||||
|
array.push(worker.taskName);
|
||||||
|
}
|
||||||
|
return array;
|
||||||
|
},
|
||||||
|
prepare: function (config) {
|
||||||
|
// we load the json and parse it here
|
||||||
|
const js = config.js || [];
|
||||||
|
for (let jsConfig of js) {
|
||||||
|
const worker = new JSWorker(jsConfig, config.helper);
|
||||||
|
workers.push(worker);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
startWatch: function () {
|
||||||
|
for (let worker of workers) {
|
||||||
|
worker.startWatch();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
31
tools/buildConfig.js
Normal file
31
tools/buildConfig.js
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
const fs = require('fs'),
|
||||||
|
HelperUnit = require('./helperUnit'),
|
||||||
|
helper = new HelperUnit(),
|
||||||
|
config = {};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
config: config,
|
||||||
|
helper: helper,
|
||||||
|
prepare: function () {
|
||||||
|
if (!fs.existsSync(__dirname + '/../../buildConfig.json')) {
|
||||||
|
console.error("Cannot find Config JSON");
|
||||||
|
process.exit(40);
|
||||||
|
}
|
||||||
|
const baseDir = __dirname + '/../..';
|
||||||
|
const data = JSON.parse(fs.readFileSync(__dirname + '/../../buildConfig.json').toString());
|
||||||
|
const src = data['src'].replace(/(\$dir)/gm, baseDir);
|
||||||
|
const out = data['out'].replace(/(\$dir)/gm, baseDir);
|
||||||
|
helper.setConfig({
|
||||||
|
$dir: baseDir,
|
||||||
|
$out: out,
|
||||||
|
$src: src,
|
||||||
|
})
|
||||||
|
config.dir = baseDir;
|
||||||
|
config.src = src;
|
||||||
|
config.out = out;
|
||||||
|
config.js = data.js || [];
|
||||||
|
config.scss = data.scss || [];
|
||||||
|
this.js = config.js;
|
||||||
|
this.scss = config.scss;
|
||||||
|
}
|
||||||
|
}
|
52
tools/helperUnit.js
Normal file
52
tools/helperUnit.js
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
let inConfig = {
|
||||||
|
$dir: __dirname,
|
||||||
|
$out: __dirname,
|
||||||
|
$src: __dirname,
|
||||||
|
$: __dirname
|
||||||
|
}
|
||||||
|
|
||||||
|
class HelperUnit {
|
||||||
|
constructor(config = null) {
|
||||||
|
this.config = config || inConfig;
|
||||||
|
this.regEx = {};
|
||||||
|
this.buildRegex();
|
||||||
|
}
|
||||||
|
|
||||||
|
static setGlobalConfig(config) {
|
||||||
|
inConfig = config;
|
||||||
|
}
|
||||||
|
|
||||||
|
addConfigItem(name, value, regexOnly = false) {
|
||||||
|
if (!regexOnly) {
|
||||||
|
this.config[name] = value;
|
||||||
|
}
|
||||||
|
let replace = name.replace("$", "\\$");
|
||||||
|
this.regEx[name] = new RegExp(`(${replace})`, "gm");
|
||||||
|
}
|
||||||
|
|
||||||
|
setConfig(config) {
|
||||||
|
this.config = config;
|
||||||
|
this.buildRegex();
|
||||||
|
}
|
||||||
|
|
||||||
|
buildRegex() {
|
||||||
|
const keys = Object.keys(this.config);
|
||||||
|
this.regEx = {};
|
||||||
|
for (const key of keys) {
|
||||||
|
this.addConfigItem(key, null, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
replaceVariables(string) {
|
||||||
|
const keys = Object.keys(this.config);
|
||||||
|
for (const key of keys) {
|
||||||
|
string = string.replace(this.regEx[key], this.config[key]);
|
||||||
|
}
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
|
||||||
|
clone() {
|
||||||
|
return new HelperUnit(this.config);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports = HelperUnit;
|
Loading…
Reference in a new issue