180 lines
4.7 KiB
JavaScript
180 lines
4.7 KiB
JavaScript
'use strict'
|
|
|
|
/**
|
|
* FUSEBOX
|
|
*
|
|
* Client & Server compiler / bundler / watcher
|
|
*/
|
|
|
|
const Promise = require('bluebird')
|
|
const autoprefixer = require('autoprefixer')
|
|
const colors = require('colors/safe')
|
|
const fsbx = require('fuse-box')
|
|
const nodemon = require('nodemon')
|
|
const fs = require('fs-extra')
|
|
const yargs = require('yargs')
|
|
const yaml = require('js-yaml')
|
|
const path = require('path')
|
|
|
|
// -------------------------------------------------------
|
|
// PARSE CMD ARGUMENTS
|
|
// -------------------------------------------------------
|
|
|
|
const opts = yargs
|
|
.option('d', {
|
|
alias: 'dev',
|
|
describe: 'Start in Developer mode',
|
|
type: 'boolean'
|
|
})
|
|
.option('b', {
|
|
alias: 'build',
|
|
describe: 'Start in Build mode',
|
|
type: 'boolean'
|
|
})
|
|
.help('h')
|
|
.alias('h', 'help')
|
|
.argv
|
|
|
|
if (opts.dev) {
|
|
console.info(colors.bgWhite.black(' Starting Wiki.js in DEVELOPER mode... '))
|
|
} else if (opts.build) {
|
|
console.info(colors.bgWhite.black(' Starting Wiki.js in BUILD mode... '))
|
|
} else {
|
|
yargs.showHelp()
|
|
process.exit(0)
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// GET CONFIG
|
|
// -------------------------------------------------------
|
|
|
|
try {
|
|
const config = yaml.safeLoad(fs.readFileSync(path.join(process.cwd(), 'dev/config/config.yml'), 'utf8'))
|
|
global.config = config
|
|
} catch (ex) {
|
|
console.error(ex)
|
|
process.exit(1)
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// BUILD VARS
|
|
// -------------------------------------------------------
|
|
|
|
const ALIASES = {
|
|
'brace-ext-modelist': 'brace/ext/modelist.js',
|
|
'simplemde': 'simplemde/dist/simplemde.min.js',
|
|
'vue': (opts.dev) ? 'vue/dist/vue.js' : 'vue/dist/vue.min.js',
|
|
'vue-lodash': 'vue-lodash/dist/vue-lodash.min.js',
|
|
'vue-resource': (opts.dev) ? 'vue-resource/dist/vue-resource.js' : 'vue-resource/dist/vue-resource.es2015.js'
|
|
}
|
|
const SHIMS = {
|
|
diff2html: {
|
|
source: '../../node_modules/diff2html/dist/diff2html.min.js',
|
|
exports: 'Diff2Html'
|
|
},
|
|
diff2htmlui: {
|
|
source: '../../node_modules/diff2html/dist/diff2html-ui.min.js',
|
|
exports: 'Diff2HtmlUI'
|
|
}
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// Tasks
|
|
// -------------------------------------------------------
|
|
|
|
console.info(colors.white('└── ') + colors.green('Running tasks...'))
|
|
let tasks = require('./tasks')
|
|
let tasksToRun = []
|
|
|
|
tasksToRun.push(tasks.cleanFuseboxCache)
|
|
tasksToRun.push(tasks.copySimpleMdeAssets)
|
|
tasksToRun.push(tasks.copyAceModes)
|
|
|
|
if (opts.build) {
|
|
tasksToRun.push(tasks.cleanTestResults)
|
|
tasksToRun.push(tasks.fetchLocalizationResources)
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// FUSEBOX PRODUCER
|
|
// -------------------------------------------------------
|
|
|
|
const babelrc = fs.readJsonSync('.babelrc')
|
|
const scssChain = [
|
|
fsbx.SassPlugin({
|
|
includePaths: ['node_modules'],
|
|
outputStyle: opts.dev ? 'nested' : 'compressed'
|
|
}),
|
|
fsbx.PostCSS([
|
|
autoprefixer({
|
|
remove: false,
|
|
browsers: babelrc.presets[0][1].targets.browsers
|
|
})
|
|
]),
|
|
fsbx.CSSPlugin(opts.dev ? {} : {
|
|
group: 'bundle.css',
|
|
outFile: '../../assets/css/bundle.css',
|
|
inject: false
|
|
})
|
|
]
|
|
|
|
Promise.mapSeries(tasksToRun, fn => fn()).then(() => {
|
|
let fuse = fsbx.FuseBox.init({
|
|
homeDir: '../../client',
|
|
output: '../../assets/js/$name.js',
|
|
alias: ALIASES,
|
|
target: 'browser',
|
|
tsConfig: '../config/tsconfig.json',
|
|
plugins: [
|
|
fsbx.EnvPlugin({ NODE_ENV: (opts.dev) ? 'development' : 'production' }),
|
|
fsbx.VueComponentPlugin({
|
|
script: fsbx.BabelPlugin(babelrc),
|
|
template: fsbx.ConsolidatePlugin({
|
|
engine: 'pug'
|
|
}),
|
|
style: scssChain
|
|
}),
|
|
scssChain,
|
|
fsbx.RawPlugin(['.svg']),
|
|
fsbx.BabelPlugin(babelrc),
|
|
fsbx.JSONPlugin()
|
|
],
|
|
debug: false,
|
|
log: true
|
|
})
|
|
|
|
// -------------------------------------------------------
|
|
// FUSEBOX DEV
|
|
// -------------------------------------------------------
|
|
|
|
if (opts.dev) {
|
|
fuse.dev({
|
|
port: 5555,
|
|
httpServer: false
|
|
})
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// FUSEBOX BUNDLES
|
|
// -------------------------------------------------------
|
|
|
|
if (opts.dev) {
|
|
fuse.bundle('libs').shim(SHIMS).instructions('~ index.js')
|
|
fuse.bundle('app').instructions('!> [index.js]').hmr({ reload: true }).watch()
|
|
} else {
|
|
fuse.bundle('bundle.min.js').shim(SHIMS).instructions('> index.js')
|
|
}
|
|
|
|
// -------------------------------------------------------
|
|
// FUSEBOX RUN
|
|
// -------------------------------------------------------
|
|
|
|
fuse.run().then(() => {
|
|
console.info(colors.green.bold('\nAssets compilation + bundling completed.'))
|
|
return true
|
|
}).catch(err => {
|
|
console.error(colors.red(' X Bundle compilation failed! ' + err.message))
|
|
process.exit(1)
|
|
})
|
|
})
|