Allows building index.js
or index.ts
files easily.
In any JavaScript or TypeScript file, simply invoke command "Build index" (or press Ctrl+K, I
/ Cmd+K, I
) to create an export listing of all files in the directory.
By default, all files are exported as:
export ${variable} from ${relpath};
E.g. having files fileOne.js
and fileTwo.js
in your directory yields:
export fileOne from './fileOne.js'
export fileTwo from './fileTwo.js'
You can use markers (@index
and /index
) to tell where the index should be built, instead of replacing the entire file:
// This line will remain in the file.
// @index
// ... The index will be (re)placed here.
// /index
// This line will remain in the file.
You can customize the template that is used to build the index lines by specifying these after the @index
marker:
// @index: myCustomExportFunction(${relpath})
Given files fileOne.js
and fileTwo.js
, this will yield:
// @index: myCustomExportFunction(${relpath})
myCustomExportFunction('./fileOne.js')
myCustomExportFunction('./fileTwo.js')
The following placeholders can be used:
${relpath}
: the relative path, excluding extension, to the file to export (e.g.'./fileOne'
)${relpathwithext}
: the relative path, including extension, to the file to export (e.g.'./fileOne.js'
)${name}
: the file name, without extension (e.g.'fileOne'
)${variable}
: the corresponding variable name, derived from the file name but camel cased (e.g.FileOne
)
You can add a regular expression suffix to search and replace.
Given files ParagraphBlock.js
and CallToActionBlock.js
, this will yield:
// @index: export {default as ${variable/Block$//}} from ${relpath}
export {default as Paragraph} from './ParagraphBlock'
export {default as CallToAction} from './CallToActionBlock'
You can add some modifiers to further customize your template. Modifiers are prefixed with a colon (:) and come after an optional regular expression.
Given files ParagraphBlock.js
and CallToActionBlock.js
, this will yield:
export default {
// @index: ${variable/Block$//:kebab:quoted}: require(${relpath}).default,
'call-to-action': require('./CallToActionBlock').default,
'paragraph': require('./ParagraphBlock').default
// /index
}
The following modifiers are available:
lower
:'FileOne' -> 'fileone'
upper
:'FileOne' -> 'FILEONE'
camel
:'FileOne' -> 'fileOne'
pascal
:'fileOne' -> 'FileOne'
kebab
:'FileOne' -> 'file-one'
snake
:'FileOne' -> 'file_one'
dot
:'FileOne' -> 'file.one'
title
:'FileOne' -> 'File One'
quoted
:File'One
->'File\'One'
You can customize quotes using the js-index.quotes
setting.
By default, js-index will look in the same directory as the current (index) file. To read from another directory, specify the directory immediately following the @index
marker in square brackets. The path is relative to the current directory.
Example.
// @index[.]
will read from the current directory. This is the default.// @index[..]
will read from the parent directory.// @index[../../somewhere/else](*.yml)
reads all*.yml
files in the directory found at../../somewhere/else
.
By default, js-index will include all files and directories, except the file being edited.
You can customize this by specifying (RegExp) patterns between parentheses after the @index
marker. You can specify multiple patterns separated by comma's, and they can be prefixed with D:
to target directories only,
or F:
to target files only.
Examples:
// @index(\.yml$)
will only include all*.yml
files (and directories).// @index(D: dirone|dirtwo)
will include only directoriesdirone
anddirtwo
. All files are still included.// @index(D: dirone, F: \.yml$)
only includes directorydirone
and only*.yml
files.
You can make a pattern exclude rather than include an entry by prefixing it with !
.
Examples:
// @index(!\.yml$)
will exclude all*.yml
files (and directories).// @index(D: !dirone|dirtwo)
will exclude directoriesdirone
anddirtwo
. All other directories, and all files are still included.// @index(D: dirone, F: !\.yml$)
only includes directorydirone
and excludes all*.yml
files.
When the first applicable pattern is an inclusion pattern, all other files and/or directories are excluded. Conversely, if the first applicable pattern is an exclusion pattern, all other files and/or are included.
When using both custom patterns and a custom template, use the following notation:
// @index(\.yml$): exportYAML(${relpath})
You can make an index indented by indenting the start marker, e.g.
module.exports = {
// @index: ${variable}: require(${relpath})
// /index
}
Will indent the index entries so that a proper object is created.
You can insert markers to align the entries in the index. The default marker is "|"
but this is customizable in the configuration of this extension.
For example, the vertical bar before require
ensures that the output is aligned:
module.exports = {
// @index: ${variable}: |require(${relpath}),
// /index
}
Turns into something like:
module.exports = {
// @index: ${variable}: |require(${relpath}),
fileOne: require('./fileOne.js'),
fileEleven: require('./fileEleven.js'),
veryLongFileName: require('./veryLongFileName.js'),
// /index
}