0.10.0 • Published 18 days ago

rollup-plugin-external-globals v0.10.0

Weekly downloads
4,015
License
MIT
Repository
github
Last release
18 days ago

rollup-plugin-external-globals

test codecov install size

Transform external imports into global variables like Rollup's output.globals option. See rollup/rollup#2374

Installation

npm install -D rollup-plugin-external-globals

Usage

import externalGlobals from "rollup-plugin-external-globals";

export default {
  input: ["entry.js"],
  output: {
    dir: "dist",
    format: "es"
  },
  plugins: [
    externalGlobals({
      jquery: "$"
    })
  ]
};

The above config transforms

import jq from "jquery";

console.log(jq(".test"));

into

console.log($(".test"));

It also transforms dynamic import:

import("jquery")
  .then($ => {
    $ = $.default || $;
    console.log($(".test"));
  });

// transformed
Promise.resolve($)
  .then($ => {
    $ = $.default || $;
    console.log($(".test"));
  });

Note: when using dynamic import, you should notice that in ES module, the resolved object is aways a module namespace, but the global variable might be not.

Note: this plugin only works with import/export syntax. If you are using a module loader transformer e.g. rollup-plugin-commonjs, you have to put this plugin after the transformer plugin.

API

This module exports a single function.

createPlugin

const plugin = createPlugin(
  globals: Object | Function,
  {
    include?: Array,
    exclude?: Array,
    dynamicWrapper?: Function
  } = {}
);

globals is a moduleId/variableName map. For example, to map jquery module to $:

const globals = {
  jquery: "$"
}

or provide a function that takes the moduleId and returns the variableName.

const globals = (id) => {
  if (id === "jquery") {
    return "$";
  }
}

include is an array of glob patterns. If defined, only matched files would be transformed.

exclude is an array of glob patterns. Matched files would not be transformed.

dynamicWrapper is used to specify dynamic imports. Below is the default.

const dynamicWrapper = (id) => {
  return `Promise.resolve(${id})`;
}

Virtual modules are always transformed.

Changelog

  • 0.10.0 (Apr 5, 2024)

    • Add: exports field in package.json to export typescript declaration.
  • 0.9.2 (Jan 21, 2024)

    • Fix: support rollup 4.9.6.
  • 0.9.1 (Nov 19, 2023)

    • Fix: type declaration.
  • 0.9.0 (Oct 28, 2023)

    • Breaking: bump to rollup@4.
  • 0.8.0 (May 12, 2023)

    • Bump dependencies. Update to magic-string@0.30
  • 0.7.2 (mar 9, 2023)

    • Add: typescript declaration.
  • 0.7.0 (Nov 21, 2022)

    • Breaking: bump to rollup@3.
  • 0.6.1 (Oct 21, 2020)

    • Fix: add an extra assignment when exporting globals.
  • 0.6.0 (Aug 14, 2020)

    • Breaking: bump to rollup@2.
  • 0.5.0 (Dec 8, 2019)

    • Add: dynamicWrapper option.
    • Add: now globals can be a function.
    • Bump dependencies/peer dependencies.
  • 0.4.0 (Sep 24, 2019)

    • Add: transform dynamic imports i.e. import("foo") => Promise.resolve(FOO).
  • 0.3.1 (Jun 6, 2019)

    • Fix: all export-from statements are incorrectly transformed.
    • Bump dependencies.
  • 0.3.0 (Mar 25, 2019)

    • Fix: temporary variable name conflicts.
    • Breaking: transform virtual modules. Now the plugin transforms proxy modules generated by commonjs plugin.
    • Bump dependencies.
  • 0.2.1 (Oct 2, 2018)

    • Fix: don't skip export statement.
  • 0.2.0 (Sep 12, 2018)

    • Change: use transform hook.
    • Add: rewrite conflicted variable names.
    • Add: handle export from.
  • 0.1.0 (Aug 5, 2018)

    • Initial release.
vite-plugin-jsdelivrck-cesium-mapkhodroinja-ui-core@infinitebrahmanuniverse/nolb-rollup-plugin-e@zxd2219/vite-plugin-cdn-import@everything-registry/sub-chunk-2680vite-plugin-m3cesiumzbz-mapbox-gl@isygis/roadprofile@itandu/utils@knapsack/build-tools@kokimoki/cli@marsgames/vite-plugin-cdn-import@lokier/cli-wrappers-lego@jbrowse/development-toolsreact-multitouch-gesturesrice-ui2@netless/vite-plugin-cdn-import@newpearl/cli@openk9/plugin-scripts@panels/scripts@noah-i/dev-il@mochsm/test-publish@mochsm/qb-app-cli@mozyun/formily-tplstorybook-builder-wds@qorebase/app-clistitch-component-cli@zzwy/wy-injectfilebrimma-storybook-app@patchcab/corespirokit-native-base@spinnaker/scripts@spirokit/native-base@space8/vite-czm-plugin@banyinbanying/contenteditable@beanbag/frontend-buildkitcnhis-design-buildarnft-threejsxweb_3.0_component_libalipay-scroll@zhcloudtech/vite-plugin-cesium@zfitness/tslib-tpl@zippybee/plugin-cdn-importwordpress-vite-pluginbang-component-cli1997ckf-ui-comp@21torr/fireflybrown-vite-plugin-cesiumweb-custom@steedos-ui/builder-object@sogody/experiment-framework@sogody/scopexjs@sogody/template-framework@web/storybook-buildervideojs-generate-rollup-configvitepluginpluscesiumvite-plugin-inject-externalsvite-plugin-import-cdn-fault-tolerantvite-plugin-cdn-importvite-plugin-cdn-import-1vite-plugin-cdn-import-asyncvite-plugin-cdn-import-relyvite-plugin-cdn-import2vite-plugin-cdn-requirevite-plugin-cesiumvite-plugin-cesium-plusvite-plugin-chainui-algorandvite-plugin-copy-cesiumvite-plugin-copy-configvite-plugin-earthvite-plugin-electron-cesiumvite-plugin-external-cdnvite-plugin-external-globalsvite-plugin-fast-cdn-import@webtides/luna-cli@ttungbmt/module-config@ulu/vite-config-cms-theme@vuetronic/builder@vtj/cli@wpsocio/vite-wp-react@xintao1105/vite-plugin-cesiumvue-testm-ui@sunvcloud/core@tangible/roller@tomjs/vite-plugin-html@tpkg/weber-app-lib@yyznm/user-login-dialog@yyznm/commment-element@coti-cvi/vite-plugin-cdn-import@cromwell/utils@cocoon/rollupgetvoip_renderermixenginemixengine-debugmixengine-plugin-debug@form-creator1/element-plus@formily/templatehalloid-js-sdkhalloid-ts-sdk
0.10.0

18 days ago

0.9.2

3 months ago

0.9.0

6 months ago

0.9.1

5 months ago

0.7.2

1 year ago

0.8.0

12 months ago

0.7.3

1 year ago

0.7.1

1 year ago

0.6.1

4 years ago

0.6.0

4 years ago

0.5.0

4 years ago

0.4.0

5 years ago

0.3.1

5 years ago

0.3.0

5 years ago

0.2.1

6 years ago

0.2.0

6 years ago

0.1.0

6 years ago