npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

webpkg

v0.6.0

Published

Load your webpack configuration from package.json

Downloads

5

Readme

webpkg 0.6.0

Load your webpack configuration from package.json

npm license travis greenkeeper mind BLOWN

.

The shortest webpack configuration file you've ever seen!

webpack.config.js:

module.exports = require('webpkg')()

.

Installation

npm install --save webpkg

Usage

Create a webpack.config.js in the root of your project and add this code:

module.exports = require('webpkg')()

Now, you can configure webpack from your package.json:

{
  "name": "webpkg-example",
  "version": "1.0.0",
  "main": "./main.js",
  "webpack": {
    "entry": "./main.js"
  }
}

Combine with pkgcfg for creating expressive configurations within JSON:

{
  "name": "webpkg-example",
  "version": "1.0.0",
  "main": "./main.js",
  "webpack": {
    "entry": "{pkg main}"
  }
}

Options

All standard Webpack configuration options are supported.

Configuring a full Webpack project from scratch is a lot of work, so webpkg offers some extra options to help you with this. These options are used in the top level (or levels, see option inheritance) of your webpack configuration:

basecfg

Set this to the name of an (installed) module yielding a webpack configuration when required and it will be used as the base configuration; the other changes you make in package.json will be applied on top of this base configuration.

examples

Given this configuration in ./test/base.js:

module.exports = {
  context: 'base',
  entry: 'base'
}

and this configuration in package.json:

{
  "name": "webpkg-basecfg",
  "version": "1.0.0",
  "webpack": {
    "basecfg": "./test/base",
    "entry": "override",
  }
}

The resulting configuration would be:

{
    "context": "base",
    "entry": "override"
  }
}

Instead of a string with a module name, we can set basecfg to an array of strings with module names:

{
  "name": "webpkg-basecfg",
  "version": "1.0.0",
  "webpack": {
    "basecfg": [
      "./test/base",
      "./test/extend"
    ],
  }
}

All configurations will be applied on top of one another, in the order in which they are listed

extcfg

Set this to the name of an (installed) module yielding a webpack configuration when required and it will be used as an extension to the base configuration; it will first be applied to the base configuration after which the changes you make in package.json will be applied on top of that.

extcfg works in exactly the same way as basecfg. Only when used together does an extra behavior arise: basecfg is applied first and then extcfg is applied on top of that. This is convenient in combination with option inheritance.

plugins

An array of plugin specification strings/objects. The way webpack specifies plugins makes it tricky to specify them in JSON. Most of the plugins are constructor functions that have to be instantiated with new. To help with this, webpkg processes the plugins specified in the plugins, pluginsPre and pluginsPost configuration options.

If the plugin specification is a string, it is assumed to be a module name. Webpkg will require the module and use the default exported object. If it's a function, it will be called with the webpack configuration (including any custom properties) as the first argument and the resulting value will be used.

If the plugin specification is an object, it should contain a single property, the name of which specifies the module to require and the value of which being a nested object. This nested object in turn should contain a single property, the name of which specifies the plugin to import from the module. As a value, this property should have an array. The contents of this array will be passed as arguments to the plugin constructor function.

examples

{
  "plugins": [
    {
      "webpack": {
        "optimize.DedupePlugin": []
      }
    }
  ]
}

is equivalent to

var webpack = require('webpack')
module.exports = {
  plugins: [
    new webpack.optimize.DedupePlugin()
  ]
}

and

{
  "plugins": [
    {
      "webpack": {
        "DefinePlugin": [
          "process.env.NODE_ENV",
          "production"
        ]
      }
    }
  ]
}

is equivalent to

var webpack = require('webpack')
module.exports = {
  plugins: [
    new webpack.DefinePlugin('process.env.NODE_ENV', 'production')
  ]
}

pluginsPre

Allows you to specify plugins that will be prepended before the existing plugins. This is convenient in combination with option inheritance.

pluginsPost

Allows you to specify plugins that will be appended after the existing plugins. This is convenient in combination with option inheritance.

option inheritance

webpkg offers an inheritance strategy for options in package.json that allows us to place shared options in the base config and differing options in extended configs.

environment variables

You can use environment variables to control which set of options will be used. There are two environment variables that webpkg will respond to:

  • WEBPKG: e.g. 'client', 'server', etc
  • NODE_ENV: e.g. 'production', 'development', 'test' etc.

rules

You can use both environment variables at the same time. However, please observe these rules:

  • The names of top-level webpack configuration variables may not be used
  • The names for WEBPKG may not overlap with the names for NODE_ENV
  • When given the choice, webpkg will prioritize WEBPKG over NODE_ENV

examples

Given this configuration in package.json:

{
  "webpack": {
    "entry": "base",

    "production": {
      "entry": "prod",

      "client": {
        "entry": "prod-client"
      },

      "server": {
        "entry": "prod-server"
      }
    },

    "development": {
      "client": {
        "entry": "dev-client"
      },

      "server": {
        "entry": "dev-server"
      }
    },

    "client": {
      "entry": "client"
    }
  }
}

The option entry would yield different values depending on WEBPKG and NODE_ENV:

  • WEBPKG=server, NODE_ENV=development ==> 'dev-server'
  • WEBPKG=server, NODE_ENV=production ==> 'prod-server'
  • WEBPKG=client, NODE_ENV=development ==> 'client'
  • WEBPKG=client, NODE_ENV=production ==> 'client'

In the first two cases, webpkg has no choice but to follow the paths

  • webpack->development->server
  • webpack->production->server

However, for the last two cases, webpkg is given a choice, as webpack has both the properties production/development as well as client. Due to the third rule, webpkg will prioritize the WEBPKG environment variable, so it takes the path

  • webpack->client at which point it can't go deeper.

Running webpack from your NPM scripts

We want to be able to say npm run build-prod or npm run build-dev and have it just work. Here is how we can configure our scripts section to accomplish that:

{
  "scripts": {
    "build-dev": "cross-env NODE_ENV=development webpack",
    "build-prod": "cross-env NODE_ENV=production webpack",
  },
  "webpack": {
    "entry": "common options",

    "development": {
      "entry": "development options"
    },
    "production": {
      "entry": "production options"
    }
  }
}

I recommend using cross-env to set environment variables.

Integration with pkgcfg

Need more dynamic behavior? webpkg uses pkgcfg to load and parse the package.json file, meaning you can use all it's power in your webpack configuration as well.

Add it as an explicit dependency to your project:

npm install --save pkgcfg

Now, you should be able to do things like:

{
  "name": "webpkgcfg-example",
  "version": "1.0.0",
  "webpack": {
    "entry": "./src/{pkg name}",
    "output": {
      "filename": "./bin/{pkg name}-{pkg version}.js"
    }
  }
}

Issues

Add an issue in this project's issue tracker to let me know of any problems you find, or questions you may have.

Copyright

Copyright 2016 by Stijn de Witt. Some rights reserved.

License

Creative Commons Attribution 4.0 (CC-BY-4.0)