Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/recursive-beast/rollup-plugin-external-assets
A rollup plugin to make assets external, they will not be added to the bundling pipeline, but they will still be included in the final output.
https://github.com/recursive-beast/rollup-plugin-external-assets
assets external import npm rollup rollup-plugin
Last synced: about 2 months ago
JSON representation
A rollup plugin to make assets external, they will not be added to the bundling pipeline, but they will still be included in the final output.
- Host: GitHub
- URL: https://github.com/recursive-beast/rollup-plugin-external-assets
- Owner: recursive-beast
- License: mit
- Created: 2021-02-16T14:18:28.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-05-13T12:31:47.000Z (8 months ago)
- Last Synced: 2024-05-13T13:53:41.491Z (8 months ago)
- Topics: assets, external, import, npm, rollup, rollup-plugin
- Language: TypeScript
- Homepage:
- Size: 10.6 MB
- Stars: 2
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome - external-assets - Make assets external but include them in the output. (Plugins / Modules)
README
[![npm](https://img.shields.io/npm/dt/rollup-plugin-external-assets)](https://www.npmjs.com/package/rollup-plugin-external-assets)
[![npm](https://img.shields.io/npm/v/rollup-plugin-external-assets)](https://www.npmjs.com/package/rollup-plugin-external-assets)
[![build](https://github.com/recursive-beast/rollup-plugin-external-assets/actions/workflows/build.yml/badge.svg)](https://github.com/recursive-beast/rollup-plugin-external-assets/actions/workflows/build.yml)
[![codecov](https://codecov.io/gh/recursive-beast/rollup-plugin-external-assets/branch/master/graph/badge.svg)](https://codecov.io/gh/recursive-beast/rollup-plugin-external-assets)
[![MIT license](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)# rollup-plugin-external-assets
> A rollup plugin to make assets external,
> they will not be added to the bundling pipeline,
> but they will still be included in the final output.## Installation
Via [npm](https://npmjs.org)
```sh
npm install --save-dev rollup-plugin-external-assets
```Via [yarn](https://yarnpkg.com)
```sh
yarn add -D rollup-plugin-external-assets
```## Usage
Assuming a `src/index.js` exists and contains code like the following:
```js
import logo from "../assets/logo.png";console.log(logo);
```Create a `rollup.config.js` [configuration file](https://www.rollupjs.org/guide/en/#configuration-files) and import the plugin:
```js
import { externalAssets } from "rollup-plugin-external-assets";export default {
input: "src/index.js",
output: {
file: "dist/index.js",
format: "cjs",
},
plugins: [externalAssets("assets/*")],
};
```Then call `rollup` either via the [CLI](https://www.rollupjs.org/guide/en/#command-line-reference) or the [API](https://www.rollupjs.org/guide/en/#javascript-api).
Once the bundle is executed, you end up with a `dist` directory like the following:
![dist directory structure](assets/screenshot.png)
With `dist/index.js` containing:
```js
"use strict";var logo = require("./assets/logo-0c6cee7b.png");
console.log(logo);
```## Options
To tailor the plugin behavior to your needs, you can pass a configuration object as the argument:
`include`
• Type: `string | RegExp | (string | RegExp)[]`
A pattern, or array of patterns, to match files the plugin should operate on.
`exclude`
• Type: `string | RegExp | (string | RegExp)[]`
A pattern, or array of patterns, to match files the plugin should ignore.
`resolve`
• Type: `string`
• Default: `process.cwd()`The value will be used as the base directory for resolving patterns.
## Contributing
### Prerequisites
- [nodejs](https://nodejs.org)
- [npm](https://npmjs.org)### Getting Started
After cloning this repo, ensure dependencies are installed by running:
```sh
npm install
```Then to build the final bundle:
```sh
npm run build
```### Tests
To run tests:
```sh
npm test
```To run tests with coverage report:
```sh
npm run test:coverage
```Coverage report is located in `tests/coverage`.
### Commiting changes
Please follow the [conventional commits](https://www.conventionalcommits.org) specification, because [semantic-release](https://github.com/semantic-release/semantic-release) is used to automate the whole package release workflow including: determining the next version number, generating the release notes and publishing the package.
## License
[MIT](LICENSE)