Genesis Core
Simplified build tooling for a complected world
Take advantage of the modern JavaScript ecosystem without any of the headache. Genesis Core provides a consistent, simplified interface over powerful build tooling. Configure it once and get to work; you'll enjoy the same experience whether you're building a Single Page Application or distributable NPM package.
Table of Contents
- Features
- Installation
- Usage
Installation
It's recommended to install Genesis Core as a project-level dependency, and not a global depdendency. This will give you the freedom to run multiple projects independently and will provide more fine-grained control over upgrades.
yarn add --dev @technologyadvice/genesis-core
npm install --save-dev @technologyadvice/genesis-core
Targets
Web App
This compiler is still in progress.
NPM Package
This compiler is still in progress.
Usage
Genesis is configured with the same options no matter which API is used.
Configuration
{
entry : string | Array<string>,
templatePath : string,
vendors : Array<string>,
alias : { [key: string]: string },
globals : { [key: string]: any },
sourcemaps : boolean,
verbose : boolean,
transpile : boolean | 'typescript',
}
Command Line Interface
After installing Genesis Core in your project, you can use the gen
binary to run tasks. To do this, configure your package.json
scripts to run gen
commands.
{
"scripts": {
"start": "gen start",
"build": "gen build",
"test": "gen test"
}
}
Once this is done, you can run these just like any other npm command. Note that you can also pass options to the genesis task:
npm start -- --port 3000
Node API
const genesis = require('@technologyadvice/genesis-core')
const compiler = genesis({
})
compiler.build()
.then(() => { })
compiler.start({ host: 'localhost', port: 3000 })
compiler.test({ watch: true })