Rollup plugin for generating an chunk manifest. Inspired by webpack-manifest-plugin
npm install --save-dev rollup-plugin-output-manifest
In your rollup.config.js
import outputManifest from 'rollup-plugin-output-manifest';
// or const outputManifest = require('rollup-plugin-output-manifest').default;
export default {
// ...
plugins: [
// ...
outputManifest(),
],
};
This will generate a manifest.json
file in your root output directory with a mapping of all source file names to their corresponding output file, for example:
{
"index": "index-6492d26f.js"
}
More examples you can look at the index.spec.ts
import outputManifest from 'rollup-plugin-output-manifest';
export default {
// ...
plugins: [
// ...
outputManifest(options),
],
};
The type Bundle
is an union of OutputChunk and OutputAsset
type Bundle = OutputChunk | OutputAsset;
Type: String
Default: manifest.json
The manifest filename in your output directory.
Type: String
Default: ''
The suffix for all keys in the manifest json object.
Type: Boolean
Default: true
,
Set an ext for key which is same as the value in manifest json object. We add this option for support of assets which has different ext than the entry.
Type: Boolean
Default: false
Merge the existing key/value pair in the target manifest file or just override it.
Type: String
Default: outputOptions.dir || path.dirname(outputOptions.file)
A path prefix that will be added to values of the manifest.
Type: String
A suffix that will be added to values of the manifest. Useful for adding a query string, for example.
Type: String
A path prefix for all keys. Useful for including your output path in the manifest.
Type: (bundle: Bundle) => boolean
Filter out chunks.
Type: (bundle: Bundle) => Bundle
Modify chunk details before the manifest is created.
Type: (bundleA: Bundle, bundleB: Bundle) => number
Sort chunk before they are passed to generate
.
Type: (k: string, v: string, opt: OutputManifestParam) => {[k: string]: string}
You can set your own rule to set key/value.
Type: (keyValueDecorator: KeyValueDecorator, seed: object, opt: OutputManifestParam) => (chunks: Bundle[]) => object
Default:
(keyValueDecorator: KeyValueDecorator, seed: object, opt: OutputManifestParam) => (chunks) =>
chunks.reduce((manifest, { name, fileName }) => {
if (name) {
return {
...manifest,
...keyValueDecorator(name, fileName, opt),
};
}
return manifest;
}, seed);
Create the manifest. It can return anything as long as it's serialisable by JSON.stringify
.
By default, Bundle without an name
attribute will be omitted;
Type: (manifest: object) => string
Default: (manifest) => JSON.stringify(manifest, null, 2)
Output manifest file in different format then json (e.g. yaml).
$ git clone https://github.com/shuizhongyueming/rollup-plugin-output-manifest.git
$ cd packages/main
$ yarn install
$ yarn build # for build
$ yarn test # for test
MIT