An ESBuild/TSUP plugin to import files as raw text.
Ideal for scenarios like importing code files for documentation, interactive tools like react-live
, or other text-based use cases.
Star this repository and share it with your friends.
- Import any file (e.g.,
.js
,.ts
,.css
, etc.) as raw text. - Works seamlessly with ESBuild and TSUP.
- Perfect for documentation generators, live code editors, and similar tools.
Using npm:
npm install esbuild-raw-plugin --save-dev
Using yarn:
yarn add esbuild-raw-plugin --dev
Using pnpm:
pnpm add esbuild-raw-plugin --save-dev
Add the plugin to your ESBuild configuration:
import { build } from "esbuild";
import { raw } from "esbuild-raw-plugin";
build({
entryPoints: ["src/index.js"],
bundle: true,
outfile: "out.js",
plugins: [raw()],
});
Add the plugin to your TSUP configuration:
import { defineConfig } from "tsup";
import { raw } from "esbuild-raw-plugin";
export default defineConfig({
entry: ["src/index.ts"],
outDir: "dist",
plugins: [raw()],
});
Add following to your declaration file. If you do not have one, create declarations.d.ts
file and add following.
declare module "*?raw" {
const value: string;
export default value;
}
With the plugin enabled, you can import files as raw text directly:
import myCode from "./example.js?raw";
console.log(myCode);
// Outputs the content of 'example.js' as a string.
With the latest update, you no longer need to specify the file extension explicitly.
import myCode from "./example?raw";
This works seamlessly! Additionally, if you're exporting from files like index.tsx
, index.jsx
, etc., you can simplify imports. For example, if your file path is my-lib/index.ts
, you can import the raw content like this:
import myCode from "./my-lib?raw";
export interface RawPluginOptions {
/**
* Extensions to check in order if the file does not exist.
* If it's a directory, the plugin will look for `dir/index.[ext]`.
* @defaultValue ["tsx", "ts", "jsx", "js", "mjs", "mts", "module.css", "module.scss", "css", "scss"]
*
* You can provide your own extensions to optimize build performance or extend the list based on your use case.
*/
ext?: string[];
}
You can use ?raw
with any file type, including:
.js
,.ts
,.jsx
,.tsx
.css
,.scss
.html
.md
- and more!
import React from "react";
import { LiveProvider, LiveEditor, LiveError, LivePreview } from "react-live";
import exampleCode from "./example.js?raw";
const App = () => (
<LiveProvider code={exampleCode}>
<LiveEditor />
<LiveError />
<LivePreview />
</LiveProvider>
);
export default App;
- Simplifies importing files as raw text for documentation and live previews.
- Seamlessly integrates with modern build tools like ESBuild and TSUP.
- Lightweight and easy to configure.
esbuild
, esbuild-plugin
, tsup-plugin
, raw-text-import
, import-as-text
, file-loader
, react-live
, documentation-tools
, frontend-tooling
Contributions are welcome!
Feel free to open issues or pull requests to improve the plugin.
Let me know if you'd like further tweaks! 🚀
This library is licensed under the MPL-2.0 open-source license.
Please enroll in our courses or sponsor our work.
with 💖 by Mayank Kumar Chaudhari