@kkt/react-library
TypeScript icon, indicating that this package has built-in type declarations

7.5.5 • Public • Published

@kkt/react-library

npm version

Use create-react-app to build react libraries. This gives you ability to reuse most of CRA setup for building your libraries.

Installation

yarn add --dev @kkt/react-library
# or use npm if you don't have yarn yet
npm install --save-dev @kkt/react-library

Usage

In the .kktrc.js or .kktrc.ts you created for kkt add this code:

import path from 'path';
import reactLibrary from '@kkt/react-library';

export default (conf, evn, options) => {
  const pkg = require(path.join(process.cwd(), 'package.json'));

  return reactLibrary(conf, evn, {
    ...options,
    ...pkg,
    // webpack externals options
    dependencies: {
      ...pkg.dependencies,
      "react-refresh": "0"
    }
  });
}

In package.json, add a separate npm script to build library

{
  "scripts": {
    ...
    "bundle": "kkt build --bundle",
    "bundle:min": "kkt build --bundle --mini",
    ...
  }
}

And you can now use CRA to build your library

Configurations

  • name: name of the library / package.
  • module: name of entry file for webpack.
  • main: output file for webpack config.
  • dependencies: list of dependencies to be added as externals to webpack config.

Although you can pass these options via configuration, it is usually recommended to package the package json config as is. For example:

import path from 'path';
import reactLibrary from '@kkt/react-library';

export default (conf, evn, options) => {
  const pkg = require(path.join(process.cwd(), 'package.json'));
  return reactLibrary(conf, evn, {
    ...options,
    ...pkg,
    // webpack externals options
    dependencies: {
      ...pkg.dependencies,
      "react-refresh": "0"
    }
  });
}

License

Licensed under the MIT License

Package Sidebar

Install

npm i @kkt/react-library

Weekly Downloads

3

Version

7.5.5

License

MIT

Unpacked Size

18 kB

Total Files

11

Last publish

Collaborators

  • uiwjs
  • wcjiang