Are you also fed up with all the module formats hanging around? We've had to work with IIFEs and globals, CommonJS, AMD, UMD, SystemJS etc. Which should you choose for your library to have maximal reach? Why ECMAScript modules, of course! There are excellent transpilers available, like Babel and rollup, which let you target all the other formats.
Just say "Gimme modules!" and we'll deliver them.
Install the package
$ npm install -g gimme-modules
and tell your code to be written in ECMAScript 2015 modules instead!
# !! This example updates the code in-place.
$ gimme-modules --recursive --output src src/index.js
gimme-modules
will crawl your code and try to convert the files in your project to ECMAScript modules, and put them in the src/
directory.
To preview gimme-modules
's output for a single file, like this one:
exports.a = require( './a.js' );
exports.b = require( './b.js' );
pass it as the only argument.
$ gimme-modules lib/index.js
Outputs:
export { default as a } from './a.js';
export { default as b } from './b.js';
Alternatively, you can use the Node API.
var gimme = require( 'gimme-modules' );
// From the given entry point, convert all imported files
// recursively and output to the target directory.
gimme.recursive( 'lib/index.js', 'ecma/' );
// Convert one file and output to the given filename ...
gimme.file( 'src/file.js', 'ecma/file.js' );
// ... or to a Writeable Stream.
gimme.file( 'src/file.js', process.stdout );
// Convert any source string, or ESTree AST.
var result = gimme.source( '...' );
result = gimme.ast( acorn.parse( '...' ) );
// The results have the following properties:
assert.ok( typeof result.code === 'string' );
MIT