Détail du package

nwb

insin10.3kMIT0.25.2

A toolkit for React, Preact & Inferno apps, React libraries and other npm modules for the web, with no configuration (until you need it)

development, inferno, preact, react

readme

nwb

Linux Travis Windows Appveyor npm package Coveralls

nwb

nwb is a toolkit for:

A zero-config development setup is provided, but nwb also supports configuration and plugin modules which add extra functionality (e.g. Sass support), should you need them

Install

Installing globally provides an nwb command for quick development and working with projects.

npm install -g nwb

Note: if you're using npm 5 and getting an EACCES: permission denied error from nwb's PhantomJS dependency while installing globally, try passing an --unsafe-perm flag:

npm install -g --unsafe-perm nwb

To use nwb's tooling in a project, install it as a devDependency and use nwb commands in package.json "scripts":

npm install --save-dev nwb
{
  "scripts": {
    "start": "nwb serve-react-app",
    "build": "nwb build-react-app"
  }
}

Quick Development

For quick development with React, Inferno, Preact or vanilla JavaScript, use the nwb react, nwb inferno, nwb preact or nwb webcommands.

import React, {Component} from 'react'

export default class App extends Component {
  render() {
    return <h1>Hello world!</h1>
  }
}
$ nwb react run app.js
✔ Installing react and react-dom
Starting Webpack compilation...
Compiled successfully in 5033 ms.

The app is running at http://localhost:3000/
$ nwb react build app.js
✔ Building React app

File size after gzip:

  dist\app.cff417a3.js  46.72 KB

See Quick Development with nwb for a more detailed guide.

React Apps

Use nwb new react-app to create a React app skeleton, preconfigured with npm scripts which use nwb for development:

nwb new react-app my-app
cd my-app/
npm start

Open localhost:3000, start editing the code and changes will be hot-reloaded into the running app.

npm test will run the app's tests and npm run build will create a production build.

See Developing React Apps with nwb for a more detailed guide.

Preact Apps

Use nwb new preact-app to create a Preact app skeleton:

nwb new preact-app my-app

Inferno Apps

Use nwb new inferno-app to create an Inferno app skeleton:

nwb new inferno-app my-app

Vanilla JavaScript Apps

Use nwb new web-app to create a vanilla JavaScript app skeleton:

nwb new web-app my-app

React Components and Libraries

nwb new react-component my-component

cd my-component/

npm start will run a demo app you can use to develop your component or library against.

npm test will run the project's tests and npm run build will create ES5, ES modules and UMD builds for publishing to npm.

See Developing React Components and Libraries with nwb for a more detailed guide.

npm Modules for the Web

nwb new web-module my-module

cd my-module/

npm test will run the project's tests and npm run build will create ES5, ES modules and UMD builds for publishing to npm.

Guides

Documentation

Why use nwb?

Get started quickly. Start developing from a single .js file or generate a project skeleton.

Covers the whole development cycle. Development tools, testing and production builds for projects work out of the box, no configuration required.

Flexible. While everything works out of the box, you can also use an optional configuration file to tweak things to your liking.

Manages key development dependencies and configuration for you. Check out an example of the effect using nwb had on the amount of devDependencies and configuration to be managed in a real project it was dropped into.

MIT Licensed

Cover image created by GeorgioWan

Operating system icons created with Icons8

changelog

0.25.2 / 2020-05-20

Fixed

  • Bumped Node.js version in templates.

0.25.1 / 2020-05-20

Changed

  • Don't include docs/ in the npm package.

0.25.0 / 2020-05-20

Breaking Changes

  • Node.js 8 is no longer supported; Node.js 10.13.0 is now the minimum required version, as per many of nwb's dependencies.

Browser Support

Configuration

  • Deprecated using a string for webpack.autoprefixer config to configure supported browsers - this will no longer do anything and should be moved to the new browsers config.
  • Removed support for babel.stage and webpack.uglify config deprecated in nwb v0.24.0.
  • copy-webpack-plugin v6.0.0 has breaking changes to its options which you should read if you're using webpack.copy config.

    In particular, the ignore option in a copy pattern must now be put inside the new globOptions option.

Dependencies

Added

Dependencies

  • autoprefixer: v9.7.6 → v9.8.0
  • chalk: v3.0.0 → v4.0.0
  • copy-webpack-plugin: v5.1.1 → v6.0.1
  • file-loader: v4.3.0 → v6.0.0
  • fs-extra: v8.1.0 → v9.0.0
  • karma: v4.4.1 → v5.0.9
  • karma-mocha: v1.3.0 → v2.0.1
  • terser-webpack-plugin v2.3.6 → v3.0.1
  • url-loader: v2.3.0→ v4.1.0

0.24.7 / 2020-05-16

Fixed

  • Fixed inclusion of __source and __self debugging information when transpiling JSX in react-component projects by defaulting process.env.NODE_ENV to 'production' when building.

Dependencies

0.24.6 / 2020-05-12

Dependencies

  • @babel/core: v7.90 → v7.9.6
  • @babel/plugin-transform-runtime: v7.9.0 → v7.9.6
  • @babel/preset-env: v7.9.0 → v7.9.6
  • @babel/runtime: v7.9.2 → v7.9.6
  • @pmmmwh/react-refresh-webpack-plugin: v0.2.0 → v0.3.1
  • autoprefixer: v9.7.5 → v9.7.6
  • cross-spawn: v7.0.1 → v7.0.2
  • css-loader: v3.4.2 → v3.5.3
  • html-webpack-plugin: v3.2.0 → v4.3.0
  • karma-coverage: v2.0.1 → v2.0.2
  • mocha: v7.1.1 → v7.1.2
  • ora: v4.0.3 → v4.0.4
  • react-refresh: v0.8.1 → v0.8.2
  • resolve: v1.15.1 → v1.17.0
  • semver: v7.1.3 → v7.3.2
  • style-loader: v1.1.3 → v1.2.1
  • terser-webpack-plugin v2.3.5 → v2.3.6
  • webpack: v4.42.1 → v4.43.0
  • webpack-dev-server: v3.10.3 → v3.11.0

0.24.5 / 2020-03-24

Changed

  • html-webpack-plugin got a major version bump to v4
    • Output HTML is now minified by default - you can disable this by configuring html.minification = false.
    • Chunk sorting was removed, but it seems to work as before for the ordering of the JavaScript files generated by nwb's build.
    • The plugin nwb uses to inline the webpack runtime chunk was rewritten to use v4's new hooks.

Fixed

  • The lang attribute on <html> wasn't getting set to the default 'en' when using the nwb react, nwb preact and nwb inferno quick development commands.

Dependencies

  • @babel/plugin-transform-react-jsx: v7.9.1 → v7.9.4
  • @babel/preset-react: v7.9.1 → v7.9.4
  • @babel/runtime: v7.9.0 → v7.9.2
  • autoprefixer: v9.7.4 → v9.7.5
  • html-webpack-plugin: v3.2.0 → v4.0.1
  • webpack: v4.42.0 → v4.42.1

0.24.4 / 2020-03-21

Added

Changed

  • Updated to Babel v7.9.0.
  • Validate that the entry module for quick commands (e.g. nwb react run SomeComponent.js) exists, to avoid a confusing error message [#441]

Dependencies

  • @babel/core: v7.8.7 → v7.9.0
  • @babel/plugin-transform-react-constant-elements: v7.8.3 → v7.9.0
  • @babel/plugin-transform-react-jsx: v7.8.3 → v7.9.1
  • @babel/plugin-transform-runtime: v7.8.3 → v7.9.0
  • @babel/preset-env: v7.8.7 → v7.9.0
  • @babel/preset-react: v7.8.3 → v7.9.1
  • @babel/runtime: v7.8.7 → v7.9.0
  • babel-loader: v8.0.6 → v8.1.0
  • mocha: v7.1.0 → v7.1.1
  • react-refresh: v0.8.0 → v0.8.1

0.24.3 / 2020-03-14

Changed

  • Added a temporary hack to bypass startup info logging Webpack Dev Server currently does even when its quiet option is set.
  • CSS minification hasn't been enabled since nwb v0.23.0 as css-loader v1.0.0 stopped doing it by default - re-enable it using Optimize CSS Assets Webpack Plugin [#467]

Dependencies

  • minimist v1.2.4 → v1.2.5
  • optimize-css-assets-webpack-plugin v5.0.3

0.24.2 / 2020-03-12

Fixed

  • Fixed copying of co-located .test.js/.spec.js files when building a React component or web module by also passing the new --no-copy-ignored flag when calling @babel/cli [#529]

Dependencies

  • inquirer: v7.0.6 → v7.1.0
  • minimist v1.2.0 → v1.2.4 - security fix
  • open: v7.0.2 → v7.0.3

0.24.1 / 2020-03-11

Fixed

  • Fixed serving the demo app for a React component [#542]
  • Fixed Fast Refresh for the default React component demo app by exporting the Demo component in the template.

0.24.0 / 2020-03-08 ♀️

Breaking Changes

  • Node.js 6 is no longer supported; Node.js 8.9.0 is now the minimum required version, as per many of nwb's dependencies.

  • Updated to Babel 7

    • babel.runtime config no longer accepts a String to enable an additional, named feature.

      Pass an Object with plugin options instead.

    • Support for tests in *-test.js files has been removed, as @babel-core no longer supports pattern matching them to ignore them when co-located in src/.

      Rename these to *.test.js instead.

  • Dropped support for the old --no-hmre alias to disable Hot Module Replacement, just use --no-hmr instead.

  • Updated Preact config for Preact X.

  • Dependencies with (documented) breaking changes:

Added

Fixed

  • Fix creation of an extra directory when creating a scoped component's UMD build [#513] [rrapiteanu]

Changed

  • React Refresh Webpack Plugin is now used to enable Fast Refresh for React apps, as babel-plugin-react-transform is deprecated and doesn't support Babel 7.
  • Replaced use of UglifyJsPlugin with TerserWebpackPlugin.
  • React compatibility is now always configured for Preact apps, as preact/compat is now part of the preact module.

Deprecated

  • Deprecated babel.stage config, as Babel's stage-X presets were/are being removed in Babel 7 - if you provide it, nwb will warn you and enable Babel proposal plugins equivalent to the current stage they're at.

    Use babel.proposals config instead if you want to toggle some or all additional proposal plugins on.

  • Deprecated webpack.uglify config, which has been renamed to webpack.terser.

  • Autoprefixer renamed its browsers option to overrideBrowserslist, so you will get deprecation warnings if you were using {browsers: ...} in webpack.autoprefixer config.

Dependencies

  • autoprefixer: v9.0.2 → v9.7.4
  • babel-plugin-add-module-exports: v0.2.1 → v1.0.2
  • babel-plugin-inferno: v5.0.1 → v5.1.0
  • case-sensitive-paths-webpack-plugin: v2.1.2 → v2.3.0
  • chalk: v2.4.1 → v3.0.0
  • copy-webpack-plugin: v4.5.2 → v5.1.1
  • cross-spawn: v6.0.5 → v7.0.1
  • css-loader: v1.0.0 → v3.4.2
  • detect-port: v1.2.3 → v1.3.0
  • figures: v2.0.0 → v3.2.0
  • filesize: v3.6.1 → v6.1.0
  • file-loader: v1.1.11 → v4.3.0
  • fs-extra: v7.0.0 → v8.1.0
  • glob: v7.1.3 → v7.1.6
  • gzip-size: v5.0.0 → v5.1.1
  • inquirer: v6.0.0 → v7.0.6
  • karma: v2.0.0 → v4.4.1
  • karma-chrome-launcher: v2.2.0 → v3.1.0
  • karma-coverage: v1.1.2 → v2.0.1
  • karma-webpack: v3.0.0 → v4.0.2
  • mini-css-extract-plugin v0.4.1 → v0.9.0
  • mocha: v5.2.0 → v7.1.0
  • opn: v5.3.0 → open v7.0.2
  • ora: v3.0.0 → v4.0.3
  • postcss-loader: v2.1.6 → v3.0.0 - dropped Node.js 4 support
  • promise: v8.0.1 → v8.1.0
  • resolve: v1.8.1 → v1.15.1
  • semver: v5.5.1 → v7.1.3
  • style-loader: v0.21.0 → v1.1.3
  • uglifyjs-webpack-plugin v1.2.7 → terser-webpack-plugin v2.3.5
  • url-loader: v1.0.1 → v2.3.0
  • webpack: v4.16.4 → v4.42.0
  • webpack-dev-middleware: v3.1.3 → v3.7.2
  • webpack-dev-server: v3.1.5 → v3.10.3
  • webpack-hot-middleware: v2.22.3 → v2.25.0
  • webpack-merge: v4.1.4 → v4.2.2
  • whatwg-fetch: v2.0.4 → v3.0.0

Older changelogs are available in the CHANGES archive.