Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

rollup-plugin-output-manifest

Package Overview
Dependencies
Maintainers
1
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

rollup-plugin-output-manifest

Rollup plugin for generating an chunk manifest

  • 2.0.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
2.3K
decreased by-43.24%
Maintainers
1
Weekly downloads
 
Created
Source

Rollup Manifest Plugin

Rollup plugin for generating an chunk manifest. Inspired by webpack-manifest-plugin

Install

npm install --save-dev rollup-plugin-output-manifest

Usage

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"
}

API

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;

options.fileName

Type: String

Default: manifest.json

The manifest filename in your output directory.

options.nameSuffix

Type: String

Default: ''

The suffix for all keys in the manifest json object.

options.nameWithExt

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.

options.isMerge

Type: Boolean

Default: false

Merge the existing key/value pair in the target manifest file or just override it.

options.publicPath

Type: String

Default: outputOptions.dir || path.dirname(outputOptions.file)

A path prefix that will be added to values of the manifest.

options.publicSuffix

Type: String

A suffix that will be added to values of the manifest. Useful for adding a query string, for example.

options.basePath

Type: String

A path prefix for all keys. Useful for including your output path in the manifest.

options.filter

Type: (bundle: Bundle) => boolean

Filter out chunks.

options.map

Type: (bundle: Bundle) => Bundle

Modify chunk details before the manifest is created.

options.sort

Type: (bundleA: Bundle, bundleB: Bundle) => number

Sort chunk before they are passed to generate.

options.keyValueDecorator

Type: (k: string, v: string, opt: OutputManifestParam) => {[k: string]: string}

You can set your own rule to set key/value.

options.generate

Type: (keyValueDecorator: KeyValueDecorator, seed: object, opt: OutputManifestParam) => (chunks: Bundle[]) => object

Default:

(keyValueDecorator: KeyValueDecorator, seed: object, opt: OutputManifestParam) => (chunks) =>
  chunks.reduce(
    (manifest, { name, fileName }) => ({
      ...manifest,
      ...keyValueDecorator(name, fileName, opt),
    }),
    seed
  );

Create the manifest. It can return anything as long as it's serialisable by JSON.stringify.

options.serialize

Type: (manifest: object) => string

Default: (manifest) => JSON.stringify(manifest, null, 2)

Output manifest file in different format then json (e.g. yaml).

Contribution

$ git clone https://github.com/shuizhongyueming/rollup-plugin-output-manifest.git

$ cd packages/main

$ yarn install

$ yarn build # for build

$ yarn test # for test

License

MIT

Keywords

FAQs

Package last updated on 29 Apr 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc