Skip to content
This repository has been archived by the owner on Mar 10, 2023. It is now read-only.

Commit

Permalink
feat: add jsx plugins
Browse files Browse the repository at this point in the history
  • Loading branch information
Christophe Hurpeau committed Feb 20, 2017
1 parent 7a3fb95 commit 1cb0fbd
Show file tree
Hide file tree
Showing 5 changed files with 14 additions and 8 deletions.
12 changes: 9 additions & 3 deletions config/build/babelrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,11 @@ import pluginNodeEnvInline from 'babel-plugin-transform-node-env-inline';
import pluginMinifyDeadCodeElimination from 'babel-plugin-minify-dead-code-elimination';
import pluginMinifyGuardedExpressions from 'babel-plugin-minify-guarded-expressions';
import pluginDiscardModuleReferences from 'babel-plugin-discard-module-references';
import pluginReactJsxSource from 'babel-plugin-transform-react-jsx-source';
import pluginReactJsxSelf from 'babel-plugin-transform-react-jsx-self';
import { vitaminResolve } from '../utils';

export default env => ({
export default (env, dev) => ({
presets: [
env === 'client' && [preset2015, { modules: false }],
presetReact,
Expand All @@ -24,10 +26,14 @@ export default env => ({
plugins: [
// Make optional the explicit import of React in JSX files
pluginReactRequire,
// Add Object.entries, Object.values and other ES2017 functionalities
// in the client, we prefer solution like https://polyfill.io/v2/docs/, to keep the
// Add Object.entries, Object.values and other ES2017 functionalities.
// In the client, we prefer solution like https://polyfill.io/v2/docs/, to keep the
// bundle size the smallest possible.
env === 'server' && pluginTransformRuntime,
// Adds component stack to warning messages
dev && pluginReactJsxSource,
// Adds __self attribute to JSX which React will use for some warnings
dev && pluginReactJsxSelf,
// replace process.env.NODE_ENV by its current value
pluginNodeEnvInline,
// replace IS_CLIENT and IS_SERVER
Expand Down
2 changes: 1 addition & 1 deletion config/build/webpack.config.client.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export default function clientConfig(options) {
},
module: {
rules: [
createBabelLoader('client'),
createBabelLoader('client', options.dev),
createResolveConfigLoader(),
],
},
Expand Down
4 changes: 2 additions & 2 deletions config/build/webpack.config.common.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,14 @@ const VITAMIN_MODULES_DIRECTORY = vitaminResolve('node_modules');
const VITAMIN_MODULES_EXAMPLES_DIRECTORY = vitaminResolve('examples');
const MODULES_DIRECTORIES = [appResolve('node_modules'), VITAMIN_MODULES_DIRECTORY];

export const createBabelLoader = env => ({
export const createBabelLoader = (env, dev) => ({
test: /\.js(x?)$/,
loader: 'babel-loader',
include: path => !path.includes('node_modules') ||
(path.startsWith(VITAMIN_DIRECTORY)
&& !path.startsWith(VITAMIN_MODULES_DIRECTORY)
&& !path.startsWith(VITAMIN_MODULES_EXAMPLES_DIRECTORY)),
query: babelrc(env),
query: babelrc(env, dev),
});

export const createResolveConfigLoader = () => ({
Expand Down
2 changes: 1 addition & 1 deletion config/build/webpack.config.server.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ export default function serverConfig(options) {

module: {
rules: [
createBabelLoader('server'),
createBabelLoader('server', options.dev),
createResolveConfigLoader(),
],
},
Expand Down
2 changes: 1 addition & 1 deletion config/build/webpack.config.tests.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ export default function testConfig(options) {
},
module: {
loaders: [
createBabelLoader('client'),
createBabelLoader('client', true),
// The following loader will resolve the config to its final value during the build
{
test: vitaminResolve('config/index'),
Expand Down

0 comments on commit 1cb0fbd

Please sign in to comment.