GitXplorerGitXplorer
x

vite-plugin-commonjs-externals

public
65 stars
8 forks
2 issues

Commits

List of commits on branch master.
Unverified
fa4069110ef4a3fcc6cad79cada207b52289a98d

chore: improve typing

xxiaoxiangmoe committed a year ago
Unverified
dbf62259bd578d8db3a19c6af4ec2f95cff0ea2a

chore: release 0.1.4

xxiaoxiangmoe committed a year ago
Unverified
d52bda88139c558268f8e7973a3003d2b32a9c33

chore: update dependencies

xxiaoxiangmoe committed a year ago
Unverified
a1b7d16db7198e9acd074ab8177a65c74a89fdd5

Added .svelte files to transform list.

ssfjohnson committed a year ago
Unverified
0e8cce05d1d806996439a1c06ff01f3f56a773aa

feat: update bundle and dts generate

xxiaoxiangmoe committed 2 years ago
Verified
f6a71b8044ecfabd4f734cc3527384c8107f7250

refactor: Use tsup to support esm (#7)

ddusionlike committed 2 years ago

README

The README file for this repository.

vite-plugin-commonjs-externals npm

Provides commonjs externals support for Vite.

Description

Prevent bundling of certain esm imported packages and instead retrieve these external dependencies at runtime by commonjs require.

For example:

import commonjsExternals from 'vite-plugin-commonjs-externals';

const externals = ['path', /^electron(\/.+)?$/];

export default {
  optimizeDeps: {
    exclude: externals,
  },
  plugins: commonjsExternals({
    externals,
  }),
};

This will convert it

import fs from 'fs';
import * as path from 'path';
import e1 from 'electron';
import e2, * as e3 from 'electron/main';

console.log({ fs, path, e1, e2, e3 });

to

import * as fs from 'fs';
const path = (() => {
  const mod = require('path');
  return mod?.__esModule
    ? mod
    : Object.assign(Object.create(null), mod, {
        default: mod,
        [Symbol.toStringTag]: 'Module',
      });
})();
const { default: e1 } = (() => {
  const mod = require('electron');
  return mod?.__esModule
    ? mod
    : Object.assign(Object.create(null), mod, {
        default: mod,
        [Symbol.toStringTag]: 'Module',
      });
})();
const e3 = (() => {
  const mod = require('electron/main');
  return mod?.__esModule
    ? mod
    : Object.assign(Object.create(null), mod, {
        default: mod,
        [Symbol.toStringTag]: 'Module',
      });
})();
const { default: e2 } = e3;
console.log({ fs, path, e1, e2, e3 });

React + Electron renderer Config Example

// vite.config.ts
import { defineConfig } from 'vite';
import { escapeRegExp } from 'lodash';
import reactRefresh from '@vitejs/plugin-react-refresh';
import builtinModules from 'builtin-modules';
// For two package.json structure
import pkg from '../the-path-to-main-process-dir/package.json';
// For single package.json structure
import pkg from './package.json';
import commonjsExternals from 'vite-plugin-commonjs-externals';

const commonjsPackages = [
  'electron',
  'electron/main',
  'electron/common',
  'electron/renderer',
  'original-fs',
  ...builtinModules,
  ...Object.keys(pkg.dependencies).map(
    name => new RegExp('^' + escapeRegExp(name) + '(\\/.+)?$')
  ),
] as const;

export default defineConfig({
  optimizeDeps: {
    exclude: commonjsPackages,
  },
  plugins: [reactRefresh(), commonjsExternals({ externals: commonjsPackages })],
});