Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/egoist/bundle-require
bundle and `require` a file, the same way Vite loads `vite.config.ts`
https://github.com/egoist/bundle-require
Last synced: about 14 hours ago
JSON representation
bundle and `require` a file, the same way Vite loads `vite.config.ts`
- Host: GitHub
- URL: https://github.com/egoist/bundle-require
- Owner: egoist
- License: mit
- Created: 2021-10-09T13:38:41.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-06-01T11:58:00.000Z (6 months ago)
- Last Synced: 2024-11-06T03:42:31.540Z (8 days ago)
- Language: TypeScript
- Homepage:
- Size: 304 KB
- Stars: 174
- Watchers: 4
- Forks: 16
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
**💛 You can help the author become a full-time open-source maintainer by [sponsoring him on GitHub](https://github.com/sponsors/egoist).**
---
# bundle-require
[![npm version](https://badgen.net/npm/v/bundle-require)](https://npm.im/bundle-require) [![npm downloads](https://badgen.net/npm/dm/bundle-require)](https://npm.im/bundle-require) [![jsDocs.io](https://img.shields.io/badge/jsDocs.io-reference-blue)](https://www.jsdocs.io/package/bundle-require)
## Use Case
Projects like [Vite](https://vitejs.dev) need to load config files provided by the user, but you can't do it with just `require()` because it's not necessarily a CommonJS module, it could also be a `.mjs` or even be written in TypeScript, and that's where the `bundle-require` package comes in, it loads the config file regardless what module format it is.
## How it works
- Bundle your file with esbuild, `node_modules` are excluded because it's problematic to try to bundle it
- `__filename`, `__dirname` and `import.meta.url` are replaced with source file's value instead of the one from the temporary output file
- Output file in `esm` format if possible (for `.ts`, `.js` input files)
- Load output file with `import()` if possible
- Return the loaded module and its dependencies (imported files)## Install
```bash
npm i bundle-require esbuild
````esbuild` is a peer dependency.
## Usage
```ts
import { bundleRequire } from 'bundle-require'const { mod } = await bundleRequire({
filepath: './project/vite.config.ts',
})
```## API
https://www.jsdocs.io/package/bundle-require
## Projects Using bundle-require
Projects that use **bundle-require**:
- [VuePress](https://github.com/vuejs/vuepress): :memo: Minimalistic Vue-powered static site generator.
## Sponsors
[![sponsors](https://sponsors-images.egoist.dev/sponsors.svg)](https://github.com/sponsors/egoist)
## License
MIT © [EGOIST](https://github.com/sponsors/egoist)