6.1.1 • Published 3 months ago

rollup-plugin-esbuild v6.1.1

Weekly downloads
12,385
License
MIT
Repository
github
Last release
3 months ago

💛 You can help the author become a full-time open-source maintainer by sponsoring him on GitHub.


rollup-plugin-esbuild

npm version npm downloads

esbuild is by far one of the fastest TS/ESNext to ES6 compilers and minifier, this plugin replaces rollup-plugin-typescript2, @rollup/plugin-typescript and rollup-plugin-terser for you.

Install

yarn add esbuild rollup-plugin-esbuild --dev

Usage

In rollup.config.js:

import esbuild from 'rollup-plugin-esbuild'

export default {
  plugins: [
    esbuild({
      // All options are optional
      include: /\.[jt]sx?$/, // default, inferred from `loaders` option
      exclude: /node_modules/, // default
      sourceMap: true, // default
      minify: process.env.NODE_ENV === 'production',
      target: 'es2017', // default, or 'es20XX', 'esnext'
      jsx: 'transform', // default, or 'preserve'
      jsxFactory: 'React.createElement',
      jsxFragment: 'React.Fragment',
      // Like @rollup/plugin-replace
      define: {
        __VERSION__: '"x.y.z"',
      },
      tsconfig: 'tsconfig.json', // default
      // Add extra loaders
      loaders: {
        // Add .json files support
        // require @rollup/plugin-commonjs
        '.json': 'json',
        // Enable JSX in .js files too
        '.js': 'jsx',
      },
    }),
  ],
}
  • include and exclude can be String | RegExp | Array[...String|RegExp], when supplied it will override default values.
  • It uses jsx, jsxDev, jsxFactory, jsxFragmentFactory and target options from your tsconfig.json as default values.

Declaration File

There are serveral ways to generate declaration file:

  • Use tsc with emitDeclarationOnly, the slowest way but you get type checking, it doesn't bundle the .d.ts files.
  • Use rollup-plugin-dts which generates and bundle .d.ts, also does type checking.
  • Use api-extractor by Microsoft, looks quite complex to me so I didn't try it, PR welcome to update this section.

Use with Vue JSX

Use this with rollup-plugin-vue-jsx:

import vueJsx from 'rollup-plugin-vue-jsx-compat'
import esbuild from 'rollup-plugin-esbuild'

export default {
  // ...
  plugins: [
    vueJsx(),
    esbuild({
      jsxFactory: 'vueJsxCompat',
    }),
  ],
}

Standalone Minify Plugin

If you only want to use this plugin to minify your bundle:

import { minify } from 'rollup-plugin-esbuild'

export default {
  plugins: [minify()],
}

Optimizing Deps

You can use this plugin to pre-bundle dependencies using esbuild and inline them in the Rollup-generated bundle:

esbuild({
  optimizeDeps: {
    include: ['vue', 'vue-router'],
  },
})

This eliminates the need of @rollup/plugin-node-modules and @rollup/plugin-commonjs.

Note that this is an experimental features, breaking changes might happen across minor version bump.

TODO: Maybe we can scan Rollup input files to get a list of deps to optimize automatically.

Sponsors

sponsors

License

MIT © EGOIST (Kevin Titor)

@xata.io/cli@real-bird/cdd-wanted@visibly/vui@backstage/cli@uponco/adminvue-cli-plugin-dmapbochi@skulpture/serve@infinitebrahmanuniverse/nolb-rollup-plugin-e@everything-registry/sub-chunk-2680lt-web-framemedusa-admin-fayui-test-v2@egovam/app-cli@egova-mobile/app-clivthree-form-designvue2-componentsvue3-pure-wheelvue-uniframe-data-visualwheel-vue3webloaf-tempwind-ui-1thiggle-api-clienttest-admin-ats-project-builder@exalt/toolchain@fai-hd/hd-sfc-cli@fai-hd/hd-sfc-cli-pre@freshie/plugin.esbuilduscript-buildv3-usehookvscode-scriptsvite-babylonjsvite-plugin-cloudflare-workervite-plugin-md-plusvite-plugin-esbuild-postvite-plugin-mock-linkvd2hc@ittai/buildersveltekit-adapter-versioned-workertcoffe-buildertcoffe-cli@eslinkv/cli@growing-web/esm-pack-core@growing-web/esmpack-builder@indiekit/frontendopenapi-code@dofu/infraoreo-ui-1cloudflare-bundlercnhis-design-build@directus9/extensions-sdk@directus/extensions-sdk@dimensio/extensions-sdkqingt-uidirectus-extension-delete-users-with-filesdingdang-ui-vue3directus-extension-layout-boilerplatedpi-mapratflow-sdk-react-rollupdflex-builddiu-uidisploydocsify-demoreact-spikerollup-library-templaterocomp-sdksims-toolssirocsnowdevspermsuhan-capture-sdk@carv/snowpack-plugin-rollup@ccom-eds-composer/composer@digicube/extensions-sdksveltekit-plugin-versioned-worker@openct/lit-utils@minswap/translucent@misschen/cddpackcom@material-toys/icons-react@lingxiteam/cli@mexican-man/pages-csp-generator@lucide/rollup-plugins@packbag/cli-rollup-plugin-common@monoid-dev/create-ts-app@monots/core@open-pioneer/build-package@mobiuspace/build@mlz/webui-gulp@mobilc/utilsxk5-editor-vue3z-ui-1@fattypanda/rbuilder@gitaflow/extensions-sdk@gridal/react-components@janus-idp/cli@learncard/cli@learncard/create-http-bridge@lunoxjs/build@new-mv-datacore/extensions-sdk
6.1.1

3 months ago

6.1.0

7 months ago

6.0.1

7 months ago

6.0.0

7 months ago

6.0.2

7 months ago

4.10.2

1 year ago

4.10.3

1 year ago

5.0.0

1 year ago

4.10.1

2 years ago

4.10.0

2 years ago

4.9.3

2 years ago

4.9.2

2 years ago

4.9.0

2 years ago

4.9.1

2 years ago

4.8.1

2 years ago

4.8.0

2 years ago

4.8.2

2 years ago

4.7.2

2 years ago

4.7.1

2 years ago

4.7.0

2 years ago

4.6.1

2 years ago

4.6.0

3 years ago

4.5.0

3 years ago

4.4.0

3 years ago

4.3.1

3 years ago

4.3.0

3 years ago

4.2.3

3 years ago

4.2.2

3 years ago

4.1.0

3 years ago

4.2.1

3 years ago

4.2.0

3 years ago

3.0.4

3 years ago

3.0.3

3 years ago

4.0.1

3 years ago

4.0.0

3 years ago

3.0.2

3 years ago

3.0.1

3 years ago

3.0.0

3 years ago

2.6.1

3 years ago

2.6.0

3 years ago

2.5.2

4 years ago

2.5.1

4 years ago

2.5.0

4 years ago

2.4.1

4 years ago

2.4.2

4 years ago

2.4.0

4 years ago

2.3.0

4 years ago

2.2.0

4 years ago

1.5.1

4 years ago

2.1.0

4 years ago

1.5.0

4 years ago

2.0.0

4 years ago

1.4.1

4 years ago

1.4.0

4 years ago

1.3.3

4 years ago

1.2.0

4 years ago

1.1.0

4 years ago

1.3.2

4 years ago

1.3.1

4 years ago

1.3.0

4 years ago

1.2.1

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago