• Stars
    star
    1,904
  • Rank 24,362 (Top 0.5 %)
  • Language
    TypeScript
  • License
    MIT License
  • Created about 8 years ago
  • Updated 6 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

📈⚖️ Visuallize your bundle

Rollup Plugin Visualizer

NPM Version Node.js CI

Visualize and analyze your Rollup bundle to see which modules are taking up space.

Screenshots

pic

Installation

npm install --save-dev rollup-plugin-visualizer

or via yarn:

yarn add --dev rollup-plugin-visualizer

Usage

Import

// es
import { visualizer } from "rollup-plugin-visualizer";
// or
// cjs
const { visualizer } = require("rollup-plugin-visualizer");

Usage with rollup (rollup.config.js)

module.exports = {
  plugins: [
    // put it the last one
    visualizer(),
  ],
};

Usage with vite (vite.config.js)

module.exports = {
  plugins: [visualizer()],
};

Usage with vite TypeScript (vite.config.ts)

import { defineConfig, type PluginOption } from 'vite'
export default defineConfig({
  plugins: [visualizer() as PluginOption],
})

Usage with SvelteKit (vite.config.js)

const config = {
  plugins: [
    visualizer({
      emitFile: true,
      filename: "stats.html",
    }),
  ],
};

export default config;

You will find 2/3 files in .svelte-kit/output dir named stats.html (see vite logs for file locations) . You can use this snippet as a starting point and change props/path. You can also generate 3 json files and combine them to one with cli util.

How to use generated files

Blue color used to to mark project-own files. This could be: written by you files or generated by build tool files.

Green color used to mark your dependencies.

Internally it just checks if file id prefix is node_modules.

All charts refresh layout on window resize.

Sunburst

This circular hierarchical diagram can help you find huge pieces of code (aka that one huge thing). If you click on some arc it will increase its and all nested arcs size for better inspection.

Treemap

This rectangular hierarchical diagram can help you find huge pieces. Just look on biggest reclangle. But also it can help you find modules included several times, they will have the same topology and relative size. If you click on reclangle it will increase in size for further inspection.

Network

This digram should help you answer for the question 'why it is included?'. After force layout stabilize all nodes, you can move it back and forth by dragging with your mouse. Gray circles are treeshakened out files.

In real life scenarious, sometimes you will see terribly connected diagrams. There is no 100% working solution for everyone, it is expected you topology will look 'terrible' and not hold on screen. To make it still visually ispectable, first remove all highly connected nodes that you see (typical examples: commonjsHelpers, tslib, react etc, basically if tooltip for the node is not hold on the screen - exclude this node), after layout stabilization you will see, your layout is not that terrible anymore and most of dependencies cluster together. Move layout to find pieces you looked for.

When you click on node it will hightlight nodes that are listed in tooltip (the files that imports current node).

Raw-data

This template produce JSON output with raw data. Normally it should be used with CLI from this plugin.

List

Output yml file with all the data, could be good idea to commit this file to track file changes.

Options

filename (string, default stats.{ext depending template}) - name of the file with diagram to generate

title (string, default Rollup Visualizer) - title tag value

open (boolean, default false) - Open generated file in default user agent

template (string, default treemap) - Which diagram type to use: sunburst, treemap, network, raw-data, list.

gzipSize (boolean, default false) - Collect gzip size from source code and display it at chart.

brotliSize (boolean, default false) - Collect brotli size from source code and display it at chart.

Advanced options (touch only if you really need it):

emitFile (boolean, default false) - Use rollup's emitFile to generate file. Useful if you want to control all output in one place (via rollup output options). This also could be usefull with svelte as it calls vite several times.

sourcemap (boolean, default false) - Use sourcemaps to calculate sizes (e.g. after UglifyJs or Terser). Always add plugin as last option.

projectRoot (string | RegExp, default process.cwd()) - This is some common root(s) path to your files. This is used to cut absolute files paths out.

include (Filter | Filter[], default undefined) - Filter for inclusion

exclude (Filter | Filter[], default undefined) - Filter for exclusion

Filter type is { bundle?: picomatchPattern, file?: picomatchPattern }

Note about include and exclude - If options.include is omitted or has zero length, filter will return true by default. Otherwise, an ID must match one or more of the picomatch patterns, and must not match any of the options.exclude patterns. This entries will not be included in stats at all.

CLI

This plugin provides cli util rollup-plugin-visualizer. Add --help to check actual options. It can be used like:

rollup-plugin-visualizer [OPTIONS] stat1.json stat2.json ../stat3.json

This can be usefull in case you have different config files in the same project and you want to display all of them in the same chart.

Build plugin

For development if you need to build plugin, just exec:

npm run build

Disclaimer about generated files

Generated html files do not and never will contain your source code (contents of files). They can contain only js/html/css code required to build chart (plugin code) and statistical information about your source code.

This statistical information can contain:

  • size of files included in bundle
  • size of files included in source map
  • file's paths
  • files hierarchy (fs tree for your files)

Upgrades

See CHANGELOG.md.

Versioning

  • Plugin backend (one appears in configs) are strictly follows SemVer
  • Plugin frontend (generated file):
    • network, treemap, sunburst can change does not matter of version (colors, texts, visual structure etc)
    • raw-data format follows own version property
    • list follows semver

More Repositories

1

esbuild-visualizer

Create chart of dependencies in your bundle
TypeScript
65
star
2

sharp-phash

sharp based perceptual hash implementation
JavaScript
48
star
3

luna

Git Review Tool. Pages
Scala
39
star
4

mocha-better-spec-reporter

Just a fork of mocha spec reporter, but with small goodies
JavaScript
34
star
5

node-charset-detector

ICU based port of charset detection to javascript
JavaScript
16
star
6

docco

Most advanced fork of original docco - documentaion generator
JavaScript
15
star
7

huzzah

very fast and dead simple hierarchical text logger.
JavaScript
11
star
8

node-detect-encoding

Detect buffer encoding with ICU. NOT SUPPORTED use charset-detector
C++
9
star
9

moco

Small idiomatic model and collection for modern javascript.
JavaScript
7
star
10

rollup-plugin-jst

Compile _.template to javascript code for rollup
JavaScript
5
star
11

keepass.js

KeePass .kdbx file reader/writer and editor
JavaScript
5
star
12

connect-session

Connect.js session managment for Rest Api applications
JavaScript
5
star
13

falsisign

Shell
3
star
14

scala-freemarker

From curcumflex-ftl. With some changes freemarker adoptation to Scala
Scala
3
star
15

lift-jetty-session-clustering

This repo show how to make working embedded jetty instance with mongo db session replication
Scala
2
star
16

browserpipe

Small node.js application as analog for pocket and pinterest
JavaScript
2
star
17

image-optim

Wrapper about commonly known image optimization utilities
JavaScript
2
star
18

keepass-chrome

Small proof of concept extension that loads keepass .kdbx files and allow to get and add passwords
JavaScript
2
star
19

scala-jade

Almost full port of javascript jade to scala
JavaScript
1
star
20

awslogs-stream

Writable stream to push logs to AWS CloudWatch Logs
JavaScript
1
star
21

jshint-nice-reporter

Colored jshint reporter with grouping by files
JavaScript
1
star
22

http-buffer-charset

Help map http (IANA) charsets to node buffer and resolve aliases.
JavaScript
1
star
23

react-circular-slider-svg

Created with CodeSandbox
JavaScript
1
star