bundle

An online tool to quickly bundle & minify your projects, while viewing the ...

README


✨ New ✨ bundlejs.com is the new official domain forbundlejs.


bundle - An online npm package bundle size checker | Product Hunt [![Open In Gitpod](https://gitpod.io/button/open-in-gitpod.svg)](https://gitpod.io/#https://github.com/okikio/bundle/blob/main/README.md)

A small online tool for checking the minified gzip/brotli size of npm packages.

I used monaco-editor for the code-editor, esbuild as bundler and treeshaker respectively, denoflate as a wasm port of gzip, deno\_brotli as a wasm port of brotli, deno\_lz4 as a wasm port of lz4, bytes to convert the compressed size to human readable values, esbuild-visualizer to visualize and analyze your esbuild bundle to see which modules are taking up space, umami for private, publicly available analytics and general usage stats all without cookies, and countapi-js to keep track of the number of page visits, in a private and secure way.
  
This project was greatly influenced by @hardfists neo-tools and @mizchi's uniroll projects.

bundlejs is a quick and easy way to bundle your projects, minify and see it's gzip size. It's an online tool similar to bundlephobia, butbundle does all the bundling locally on you browser and can treeshake and bundle multiple packages (both commonjs and esm) together, all without having to install any npm packages and with typescript support.

The project isn't perfect, and I am still working on an autocomplete, hover intellisence, better mobile support and the high memory usage of esbuild and monaco as well as some edge case packages, e.g. monaco-editor.

If there is something I missed, a mistake, or a feature you would like added please create an issue or a pull request and I'll try to get to it. You can contribute to this project at okikio/bundle.

bundle uses Conventional Commits as the style of commit, and the Commitizen CLI to make commits easier.

You can join the discussion on github discussions.

Some of bundlejs.com's latest features were inspired by egoist/play-esbuild and hyrious/esbuild-repl, check them out they each use esbuild in different ways.


URL Queries & Shareable Links


You can now use search queries in bundle, all you need to do is add this to the url  
?q={packages}&treeshake={methods to treeshake}  

e.g.  
You want react, react-dom, vue, and @okikio/animate, but only want the Animate and toStr methods exported from @okikio/animate.  

You would add this to the url [bundlejs.com/?q=react,react-dom,vue,@okikio/animate&treeshake=[\],[\],[\],[{Animate,toStr}]](https://bundlejs.com/?q=react,react-dom,vue,@okikio/animate&treeshake=[],[],[],[{Animate,toStr}])  

If you only want a couple packages and don't care to treeshake, then all you need is something like this, bundlejs.com?q=react,react-dom,vue,@okikio/animate

There is another way to share a reproduciable bundle, the sharable link. Shareble links look like this /?share=PTAEGEB... with the string value of the input code editor being compressed into a string and placed into the URL.

In order to create a shareble link, you click the Share button, it copies the share url to your clipboard, and from there you can paste where you wish.

If you would like to bundle your code when the share URL is loaded, add bundle to the url, e.g. /?bundle&q=@okikio/animate or /?bundle&share=PTAEGEBs...



Badges


You can also add bundle badges, they look like this,
Open Bundle Open Bundle

All you need to do is to add this to your README.md
  1. ```md
  2. # Light Mode Badge  [![Open Bundle](https://bundlejs.com/badge-light.svg)](https://bundlejs.com/)

  3. # Dark Mode Badge  [![Open Bundle](https://bundlejs.com/badge-dark.svg)](https://bundlejs.com/)
  4. ```

You can use the URL Queries & Shareable Links above, to create unique bundles, when users clicks on the badge.


Backers


Backers are awesome people and organizations who use, enjoy, and donate to the project. The list of backers who love and support this project are,

<!---
-->