Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bluepropane/js-output-file-webpack-plugin
Generates file content based on JS output
https://github.com/bluepropane/js-output-file-webpack-plugin
manifest-json webpack webpack-plugin
Last synced: 13 days ago
JSON representation
Generates file content based on JS output
- Host: GitHub
- URL: https://github.com/bluepropane/js-output-file-webpack-plugin
- Owner: bluepropane
- Created: 2019-06-24T16:14:32.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2021-08-11T03:40:57.000Z (over 3 years ago)
- Last Synced: 2024-11-24T14:34:12.318Z (about 1 month ago)
- Topics: manifest-json, webpack, webpack-plugin
- Language: JavaScript
- Size: 229 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# JS Output to File Webpack Plugin
Lightweight webpack plugin that takes in a JS file and writes its output into a file.
Useful for generating files like [manifest.json](https://developers.google.com/web/fundamentals/web-app-manifest/).
## Installation
```
yarn add --dev js-output-file-webpack-plugin
```or
```
npm i --save-dev js-output-file-webpack-plugin
```## Usage
In `webpack.config.js`:
```js
const JSOutputFilePlugin = require('js-output-file-webpack-plugin');const config = {
context: path.join(__dirname, 'src'),
output: {
path: path.join(__dirname, 'dist')
},
plugins: [
new JSOutputFilePlugin({
source: 'manifest.json.js'
})
]
};module.exports = config;
```In `src/manifest.json.js`:
```js
const pkg = require('./package.json');module.exports = env => {
const manifest = {
name: 'Example manifest',
// use some dynamically generated variables
version: pkg.version,
icons: {
'16': 'icons/icon16.png',
'48': 'icons/icon48.png',
'128': 'icons/icon128.png'
},
background: {
scripts: ['bg.js'],
persistent: false
}
};
// environment specific rendering
if (env === 'development') {
manifest['content_security_policy'] =
"script-src 'self' 'unsafe-eval'; object-src 'self'";
}
return manifest;
};
````JSOutputFilePlugin` will output a file of the same name in output directory, with the `.js` extension stripped.
Running the webpack compiler will yield `dist/manifest.json`:
```json
// Prettified for example purposes.
// Actual JSON output will be minified unless the return value is a string.
{
"name": "Example manifest",
"version": "2.0.1",
"icons": {
"16": "icons/icon16.png",
"48": "icons/icon48.png",
"128": "icons/icon128.png"
},
"background": {
"scripts": [
"bg.js"
],
"persistent": false
},
"content_security_policy": "script-src 'self' 'unsafe-eval'; object-src 'self'"
}
```## License
[MIT](https://choosealicense.com/licenses/mit/)