This bundler aims to solve my personal UMD bundling. It makes it possible to transpile and bundle ES6/ES2017, React, and Preact with ease just by running one command.
Behind the scenes this wrapper uses Webpack and Google Closure Compiler.
$ npm i --save-dev nanon    Usage
      $ nanon entrypoint.js output.bundle.js --name MyLibrary
      $ # Or 
      $ nanon --input entrypoint.js --output output.bundle.js --name MyLibrary
    Options
      --input,       -i         Input ES6/ES2017 entrypoint
      --output,      -o         Output bundle name
      --name,        -n         Library name
      --polyfill,    -p         Should polyfill ES2017 features
      --watch,       -w         Turn on watch mode (webpack --watch)
Instead of using arguments within the CLI, nanon fetches config set in package.json
  "nanon": {
    "input": "index.js",
    "output": "dist/library-name.min.js",
    "name": "MyLibrary"
  },Projects using nanon
$ nanon index.js output.bundle.js --name MyLibrary
$ # Or if you've defined config in package.json
$ nanonNow you can import your code:
CommonJS
const MyLibrary = require('./output.bundle');RequireJS
require(['MyLibrary'], function(MyLibrary) {
    MyLibrary.doSomething();
});Browser
// Available on the window object
// window['MyLibrary']
// window.MyLibrary
MyLibrary.doSomething();Example creating UMD widgets with Preact (same applies for React):
// index.js
import { h, render, Component } from 'preact';
class Clock extends Component {
    constructor() {
        super();
        this.state.time = Date.now();
    }
    componentDidMount() {
        this.timer = setInterval(() => {
            this.setState({ time: Date.now() });
        }, 1000);
    }
    componentWillUnmount() {
        clearInterval(this.timer);
    }
    render(props, state) {
        let time = new Date(state.time).toLocaleTimeString();
        return <span>{ time }</span>;
    }
}
module.exports = function MyClock() {
    render(<Clock />, document.getElementById('clock'));
}$ nanon index.js index.min.js --name=MyClockNow you can include the bundle and use the clock:
<script src="index.min.js"></script>
<div id="clock"></div>
<script>
  MyClock();
</script>- Currently it bundles the react/preact framework. Will make this optional.
- Watch mode is buggy
- Development mode
Contributions are appreciated.
MIT-licensed. See LICENSE.