write-index
creates and writes index.js files in specified directories that imports and exports sibling files in ES6 format.
utils-/
- bar.js
- foo.js
utils-/
- bar.js
- foo.js
- index.js (newly created)
/* utils/index.js contents */
export { default as bar } from './bar.js';
export { default as foo } from './foo.js';
In this example we want to import all files from our utils into the root index.js
-/ (project root)
- index.js
- utils-/
- bar.js
- foo.js
In this case
idx-compose ./utils/ ./
/* ./index.js contents */
export { default as baz } from './utils/baz.js';
export { default as barf } from './utils/barf.js';
npm install write-index
Usage: idx-compose [options] [importFrom] [pathToIndex]
Example: idx-compose -e whatever.js ./utils ./
Creates index.js from sibling files or directory specified
Options:
-v, --version output the current version
-c, --config use config file arguments
- ignores cli arguments in favor of an .idxrc file
-e, --entryFile <name> specify entry file name
- default: "index.js"
-h, --help output usage information
By default we create or update index.js, but you can override this behavior with the -e or --entryFile options
using the commandidx-compose -e <name>.js
This allows you to specifiy multiple directories to update using
idx-compose -c
oridx-compose --config
Note: This ignores any other arguments coming from the cli
- dirs: An array of specified directories to update on command
- pathToIndex - where to create and/or update the index.js files
- importFrom - the directory location we want to import files from
- entryFile: name to call the entryFile if you want to override index.js
{
"dirs": [
{
"pathToIndex": "./",
"importFrom": "./utils"
},
{
"pathToIndex": "./utils",
"importFrom": "./utils"
}
],
"entryFile": "index.js"
}