webpack-plugin-log-version
v0.6.2
Published
A webpack plugin that prepends a javacript bundle with project version information
Downloads
12
Maintainers
Readme
Webpack Plugin Log Version
A simple plugin for logging your project build version into the browser console. The purpose of the plugin is to help keep track of which version of a bundle is deployed where. This may be useful if you deploy different versions of a project in many places.
Note: This plugin is beta software. Please report bugs and contribute suggestions.
Requirements
- Webpack version 5 or greater
- Git (if using git features)
Usage
This guide assumes you already know how to setup a webpack configuration.
First, install the plugin
npm install -D webpack-plugin-log-version
Import the plugin and add it to your config:
const LogVersionPlugin = require('webpack-plugin-log-version') module.exports = { entry: './src/js/index.js', output: { filename: 'bundle.js', path: path.resolve(__dirname, 'dist') }, module: { rules: [ { test: /\.js$/, exclude: /(node_modules)/, use: { loader: 'babel-loader', options: { presets: ['@babel/preset-env'] } }, } ] }, plugins: [ new LogVersionPlugin() ] }
Run a build of your project and load it in your browser. You should see an output log with the default settings:
Configuration
You may pass in a configuration object into the plugin to customize the output.
The configuration options and their defaults are as follows:
declare type PluginOptions = {
color: string
comment: string
deployedBy: boolean | string,
git: boolean
global: boolean
globalName?: string
log: boolean
name?: string
template?: string
}
color
: Choose a different color for the console.log output. Can be any browser console compatible keyword or HEX value.comment
: Add an optional comment to the end of your logdeployedBy
: Include who built/deployed the bundle. This can be set to a string or true/false. If set totrue
along withgit: true
, the local git configuser.name
is used. Default :false
git
: Enable git features and the project's branch and commit to the log Default:true
global
: Add an object to the global (window) context that contains the log information. Default:false
globalName
: change the key for theglobal
object. Default:package.name
log
: Enable logging the version information in the console: Default:true
name
: Override the default project name for the version log. Default:package.name
template
: Override theconsole.log
template for the version information. Uses EJS. Default: See Source
Template Variables
The plugin uses the following variables if they exist in the template already:
branch
: working directory branchcolor
: log colorcomment
: the optional commentcommit
: the latest commit (HEAD)date
: today's datename
: project nameversion
: project version
You may change up the template or re-arrange the output as you see fit with the plugin's template
option.
Examples
- Omit the console log, but add an object to the window global. Give it an easier name to type:
This will generate:new LogVersionPlugin({ log: false, global: true, globalName: 'myAwesomeLog' })
window.myAwesomeLog = {name: package.name, version: package.version, ...etc}
and prevent logging the version out loud in the console - Override the default template with a simpler log:
Output:new LogVersionPlugin({ git: false, name: 'Example Bundle', template: '<%= name %> - <%= version %> - <%= date %>' })
Example Bundle - 1.2.0 - Wed May 26 2021
- Display the version information in hot pink & add a comment to it
new LogVersionPlugin({ color: 'hotpink', comment: "This bundle is lit! 🔥" })
Getting Help & Contributing
Please leave an issue and explain the problem. Be as detailed as possible. If you wish to contribute feel free to submit pull requests and issues with your features and requests.
If you wish to contribute pull requests, please use the contrib branch