static-cms/babel.config.js

106 lines
2.5 KiB
JavaScript
Raw Normal View History

const path = require('path');
2018-07-25 19:17:34 -04:00
const isProduction = process.env.NODE_ENV === 'production';
const isTest = process.env.NODE_ENV === 'test';
const presets = () => {
if (isTest) {
return ['@babel/preset-react', '@babel/preset-env'];
2018-07-25 19:17:34 -04:00
}
return [
2018-07-17 19:13:52 -04:00
'@babel/preset-react',
[
'@babel/preset-env',
{
modules: false,
},
],
2018-07-25 19:17:34 -04:00
];
};
const plugins = () => {
const defaultPlugins = [
2018-07-17 19:13:52 -04:00
'lodash',
[
'babel-plugin-transform-builtin-extend',
{
globals: ['Error'],
},
],
2018-07-17 19:13:52 -04:00
'transform-export-extensions',
'@babel/plugin-proposal-class-properties',
'@babel/plugin-proposal-object-rest-spread',
'@babel/plugin-proposal-export-default-from',
[
'module-resolver',
{
root: path.join(__dirname, 'packages/netlify-cms-core/src/components'),
alias: {
coreSrc: path.join(__dirname, 'packages/netlify-cms-core/src'),
Actions: path.join(__dirname, 'packages/netlify-cms-core/src/actions/'),
Constants: path.join(__dirname, 'packages/netlify-cms-core/src/constants/'),
Formats: path.join(__dirname, 'packages/netlify-cms-core/src/formats/'),
Integrations: path.join(__dirname, 'packages/netlify-cms-core/src/integrations/'),
Lib: path.join(__dirname, 'packages/netlify-cms-core/src/lib/'),
Reducers: path.join(__dirname, 'packages/netlify-cms-core/src/reducers/'),
2019-03-18 12:47:58 -07:00
ReduxStore: path.join(__dirname, 'packages/netlify-cms-core/src/redux/'),
Routing: path.join(__dirname, 'packages/netlify-cms-core/src/routing/'),
ValueObjects: path.join(__dirname, 'packages/netlify-cms-core/src/valueObjects/'),
2019-03-18 12:47:58 -07:00
redux: 'redux',
localforage: 'localforage',
},
},
],
2018-07-25 19:17:34 -04:00
];
if (isProduction) {
return [
...defaultPlugins,
[
'emotion',
{
hoist: true,
autoLabel: true,
},
],
];
2018-07-25 19:17:34 -04:00
}
if (isTest) {
return [
...defaultPlugins,
[
'inline-svg',
{
svgo: {
plugins: [{ removeViewBox: false }],
},
2018-07-25 19:17:34 -04:00
},
],
[
'emotion',
{
sourceMap: true,
autoLabel: true,
},
],
2018-07-25 19:17:34 -04:00
];
}
defaultPlugins.push('react-hot-loader/babel');
2018-07-25 19:17:34 -04:00
return [
...defaultPlugins,
[
'emotion',
{
sourceMap: true,
autoLabel: true,
},
],
2018-07-25 19:17:34 -04:00
];
};
module.exports = {
presets: presets(),
plugins: plugins(),
2018-07-17 19:13:52 -04:00
};