Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/patrickhulce/generate-export-aliases
Makes requiring files deep in your node module easy and safe from refactoring
https://github.com/patrickhulce/generate-export-aliases
Last synced: 4 months ago
JSON representation
Makes requiring files deep in your node module easy and safe from refactoring
- Host: GitHub
- URL: https://github.com/patrickhulce/generate-export-aliases
- Owner: patrickhulce
- License: mit
- Created: 2016-08-30T19:27:34.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-05-12T22:06:12.000Z (almost 2 years ago)
- Last Synced: 2024-10-19T00:51:27.234Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 662 KB
- Stars: 4
- Watchers: 3
- Forks: 2
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# generate-export-aliases
[data:image/s3,"s3://crabby-images/99e62/99e623259f9e763b6b0ccbb0fa7f4cf360cc4ceb" alt="NPM Package"](https://www.npmjs.com/package/generate-export-aliases)
[data:image/s3,"s3://crabby-images/89f85/89f851559880f22290568a09cac6e9dea3093e8a" alt="Build Status"](https://travis-ci.org/patrickhulce/generate-export-aliases)
[data:image/s3,"s3://crabby-images/a9432/a9432b2b2d878d4f1c628e0789e875830a09d31b" alt="Coverage Status"](https://coveralls.io/github/patrickhulce/generate-export-aliases?branch=master)
[data:image/s3,"s3://crabby-images/a3a68/a3a68cf6effdd60271bb53de8385538cd7ea17c9" alt="Commitizen friendly"](http://commitizen.github.io/cz-cli/)
[data:image/s3,"s3://crabby-images/29abf/29abf2088bc9a79ce800e3e214f7c358c69d07d6" alt="Dependencies"](https://david-dm.org/patrickhulce/generate-export-aliases)Generates additional files to make requiring files deep in your node module easy and safe from refactoring.
## Usage
Save `generate-export-aliases` as a dev dependency in your `package.json`.
```sh
npm i -D generate-export-aliases
```Add a prepublish hook and the exports you wish to alias to the `config` section of your `package.json` under `exportAliases`.
For example, if you wanted to alias the `myHelper.js` file in the following directory structure...#### Example Folder Structure
```
├── LICENSE
├── README.md
├── package.json
├── lib
│ ├── fileA.js
│ ├── fileB.js
│ ├── fileC.js
│ └── shared
│ ├── myHelper.js
│ └── otherHelper.js
```#### `package.json`
```json
{
"name": "my-fantastic-library",
"scripts": {
"prepublish": "generate-export-aliases"
},
"config": {
"exportAliases": {
"exposed-helper": "./lib/shared/myHelper.js"
}
}
}
```#### Requiring Your Alias
```js
const exposedHelper = require('my-fantastic-library/exposed-helper')
const exposedHelperOriginal = require('my-fantastic-library/lib/shared/myHelper.js')
exposedHelper === exposedHelperOriginal // true
```## Inspiration
[lodash](https://github.com/lodash/lodash)'s build process