0.1.0 • Published 3 years ago

webpack-merge-json-plugin v0.1.0

Weekly downloads
-
License
MIT
Repository
github
Last release
3 years ago

webpack-merge-json-plugin

Tests License Version Node Version Webpack Version

Webpack plugin to merge multiple json files into one, it's a fork of merge-json-webpack-plugin.

Getting Started

Installation

npm i -D merge-json-webpack-plugin
# or
yarn add --dev merge-json-webpack-plugin

Usage

// webpack.config.js
const MergeJsonPlugin = require('merge-json-webpack-plugin');

module.exports = {
  plugins: [
    new MergeJsonPlugin({
      force: false,
      groups: [
        {
          files: [
            'common-manifest.json',
            'firefox-manifest.json'
          ],
          transform: (outputJson) => outputJson,
          to: 'manifest.json',
        },
        {
          pattern: '*.json', // glob. see https://github.com/mrmlnc/fast-glob
          to: 'merged-[contenthash].json',
        },
      ],
    }),
  ],
};

Options

  • cwdstring - The directory, an absolute path, for resolving files. Defaults to webpack context

  • groupsarray - Files to merge and destination path

    • files[string[]] - Array of files, path resolved relative to cwd.
    • pattern[string[]] or string - [Fast-Glob] pattern matching. The order of merge is not guarenteed.
    • transformfunction - A function to modify the merged json contents. The return json value is written to the output file. If the function returns a promise, it will be awaited.
    • tostring: Destination path to write the files to.
    • globOptionsGlobOptions - Options to foward to fast-glob when glob is used otherwise ignored. See https://github.com/mrmlnc/fast-glob#options-3.
  • minifyboolean - Minify the output json. Enabled by default in production mode.

  • mergeFnfunction - A function used to merge two objects. Defaults to Object.assign.

// webpack.config.js
const MergeJsonPlugin = require('merge-json-webpack-plugin');
const _ = require('loadsh');

const customizer = (objValue, srcValue) => {
  if (_.isArray(objValue)) {
    return objValue.concat(srcValue);
  }
};

const merge = (object, other) => {
  return _.mergeWith(object, other, customizer);
};

module.exports = {
  plugins: [
    new MergeJsonPlugin({
      mergeFn: merge,
    }),
    new MergeJsonPlugin({
      mergeFn: (prev, current) => Object.assign(prev, current),
    }),
  ],
};