Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/vladimirmikulic/parcel-plugin-custom-dist-structure

🚀 Parcel plugin that allows you to specify a custom dist structure.
https://github.com/vladimirmikulic/parcel-plugin-custom-dist-structure

assets-management javascript parcel parcel-plugin web

Last synced: 20 days ago
JSON representation

🚀 Parcel plugin that allows you to specify a custom dist structure.

Awesome Lists containing this project

README

        

# parcel-plugin-custom-dist-structure

![Version](https://img.shields.io/npm/v/parcel-plugin-custom-dist-structure)
![Downloads](https://img.shields.io/npm/dw/parcel-plugin-custom-dist-structure)
[![License: MIT](https://img.shields.io/badge/license-MIT-yellow.svg)](#)
[![Twitter: VladoDev](https://img.shields.io/twitter/follow/VladoDev.svg?style=social)](https://twitter.com/VladoDev)

> 🚀 Parcel plugin that allows you to specify a custom dist structure.

*This is the plugin for Parcel v1. [@gatsbyjs/parcel-namer-relative-to-cwd](https://www.npmjs.com/package/@gatsbyjs/parcel-namer-relative-to-cwd) can be used for Parcel v2.*

## :package: Installation

```shell
# Installs the plugin and saves it as a development dependency
npm i parcel-plugin-custom-dist-structure --save-dev
```

## :cloud: Usage

After you've installed the plugin, you'll need to specify configuration for it in `package.json`.

The plugin configuration is very simple, but also very flexible.

It will generate the structure you specify in the configuration object while also handle all your imports (css, images, js...) which makes it suitable for all use cases, from simple websites all the way to complex React/Angular/Vue projects.

Example configuration object in `package.json`:

```jsonc
"customDistStructure": {
"config": {
// Output JS files to dist/js folder
".js": "js",
// Output JPG and PNG files to dist/images folder
"images": [
".jpg",
".png"
],
// General idea
".fileExtension": "folder/in/dist",
"folder/in/dist": [ ".file", ".extensions" ]
},
"options": {
// Enable plugin in development mode (default: false)
"development": true
}
}
```

> ⚠️ NOTE: In order for this plugin to work, Parcel needs to be installed as a project dependency (globally installed `parcel` won't work)

## :sparkles: Run tests

The plugin uses [Jest](https://jestjs.io/) for running tests.

Jest will execute all `.test.js` files in the `test` folder.

```sh
npm test
```

## :man: Author

**Vladimir Mikulic**

- Twitter: [@VladoDev](https://twitter.com/VladoDev)
- Github: [@VladimirMikulic](https://github.com/VladimirMikulic)
- LinkedIn: [@vladimirmikulic](https://www.linkedin.com/in/vladimir-mikulic/)

## :handshake: Contributing

Contributions, issues and feature requests are welcome!

## :pencil: License

This project is licensed under [MIT](https://opensource.org/licenses/MIT) license.

## :man_astronaut: Show your support

Give a ⭐️ if this project helped you!