webpack.config.iframe.js 1.65 KB
Newer Older
1
2
3
4
5
6
7
8
9
/**
 * Copyright (c) 2015-present, Facebook, Inc.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 */
'use strict';

const path = require('path');
10
const webpack = require('webpack');
11
12
13
14
15
16
17
18
19
20
21

module.exports = {
  entry: './src/iframeScript.js',
  output: {
    path: path.join(__dirname, './lib'),
    filename: 'iframe-bundle.js',
  },
  module: {
    rules: [
      {
        test: /\.js$/,
Clement Hoang's avatar
Clement Hoang committed
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
        include: [
          path.resolve(__dirname, './src'),
          path.dirname(
            require.resolve('chalk', {
              paths: path.dirname(require.resolve('@babel/code-frame')),
            })
          ),
          path.dirname(
            require.resolve(
              'ansi-styles',
              path.dirname(
                require.resolve('chalk', {
                  paths: path.dirname(require.resolve('@babel/code-frame')),
                })
              )
            )
          ),
        ],
40
41
42
43
        use: 'babel-loader',
      },
    ],
  },
44
45
46
47
48
49
  plugins: [
    new webpack.DefinePlugin({
      // We set process.env.NODE_ENV to 'production' so that React is built
      // in production mode.
      'process.env': { NODE_ENV: '"production"' },
      // This prevents our bundled React from accidentally hijacking devtools.
50
      __REACT_DEVTOOLS_GLOBAL_HOOK__: '({})',
51
52
53
54
55
56
57
58
59
60
61
62
63
64
    }),
    // This code is embedded as a string, so it would never be optimized
    // elsewhere.
    new webpack.optimize.UglifyJsPlugin({
      compress: {
        warnings: false,
        comparisons: false,
      },
      output: {
        comments: false,
        ascii_only: false,
      },
    }),
  ],
65
};