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

compsizer

Package Overview
Dependencies
Maintainers
0
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

compsizer

A tool for analysing the size of component packages in your monorepo.

  • 0.2.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1
decreased by-92.31%
Maintainers
0
Weekly downloads
 
Created
Source

compsizer

compsizer is a tool designed to analyse the size of component bundles in your project. It helps you ensure your component sizes are within acceptable limits by comparing them against baselines and showing size increases across builds. You can also configure gzip and Brotli compression checks.

Features

  • Analyse the size of individual component bundles.
  • Compare sizes against baseline sizes.
  • Warn when size exceeds configured thresholds.
  • Supports gzip and Brotli compression analysis.

Installation

You can install compsizer locally in your project.

Local Installation

npm install compsizer --save-dev

Once installed, you can use the command compsizer in your project.

Usage

You can run the tool from the command line either with the default configuration file or by specifying a custom configuration file.

Default Command

If you use the default configuration file name compsizer.config.json, simply run:

npx compsizer

Custom Configuration

If your configuration file is located elsewhere or has a different name, use:

npx compsizer --config path/to/your-config-file.json

Example in package.json

You can add a script in your package.json for convenience:

{
  "scripts": {
    "analyse-component-bundles": "compsizer --config path/to/your-config-file.json"
  }
}

Then run it via:

npm run analyse-component-bundles

Configuration

You need to create a configuration file (default: compsizer.config.json) that specifies the inclusion/exclusion patterns for files, size limits, and compression options.

Example Configuration (compsizer.config.json)

{
  "exclude": ["src/**/*.test.js"],
  "compression": {
    "gzip": true,
    "brotli": true
  },
  "baselineFile": "baseline.json",
  "components": {
    "Button": {
      "maxSize": "20KB",
      "warnOnIncrease": "5%",
      "include": ["src/components/Button/dist/**/*.js"],
      "exclude": []
    },
    "Modal": {
      "maxSize": "50KB",
      "warnOnIncrease": "10%",
      "include": ["src/components/Modal/dist/**/*.js"],
      "exclude": []
    }
  },
  "defaults": {
    "warnOnIncrease": "5%"
  }
}

Configuration Fields

  • exclude: (array) Glob patterns to exclude certain files from analysis.
  • compression: (object) Specify whether to calculate gzip and Brotli compressed sizes.
    • gzip: (boolean) Set to true to calculate gzip sizes.
    • brotli: (boolean) Set to true to calculate Brotli sizes.
  • baselineFile: (string) Path to the JSON file where the baseline sizes are stored.
  • components: (object) Configuration for each component.
    • maxSize: (string) The maximum allowable size for the component (e.g., 20KB, 500KB).
    • warnOnIncrease: (string) Warn if the size increases by more than the specified percentage.
    • include: (array) Glob patterns specific to the component to include.
    • exclude: (array) Glob patterns specific to the component to exclude. (Overrides the base exclude)
  • defaults: (object) Default settings that apply to all components.
    • warnOnIncrease: (string) Default warning threshold for size increases.

Output

The tool generates a report of the component sizes, whether they exceed limits, and how they compare to baseline sizes. It also updates the baseline file after each run.

Example output:

Component Bundle Sizes Report

Component: Button
Total Size: 19.45 KB
Gzip Size: 5.12 KB
Brotli Size: 4.01 KB
Within max size limit of 20KB
Size increase of 4.8% since last recorded size is within threshold of 5%

Component: Modal
Total Size: 48.78 KB
Gzip Size: 12.34 KB
Brotli Size: 10.24 KB
Within max size limit of 50KB
Size increase of 2.5% since last recorded size is within threshold of 10%

If any component exceeds its size threshold or size increase percentage, the tool will print a warning and exit with a non-zero status code.

License

This project is licensed under the MIT License.

FAQs

Package last updated on 18 Oct 2024

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