p5.js-web-editor/webpack/config.dev.js

129 lines
2.9 KiB
JavaScript
Raw Normal View History

const webpack = require('webpack');
const path = require('path');
const CopyWebpackPlugin = require('copy-webpack-plugin')
if (process.env.NODE_ENV === 'development') {
require('dotenv').config();
}
2016-05-03 06:09:16 +02:00
// react hmr being fucked up has to do with the multiple entries!!! cool.
module.exports = {
mode: 'development',
devtool: 'cheap-module-eval-source-map',
entry: {
2018-05-03 02:34:03 +02:00
app: [
'core-js/modules/es6.promise',
'core-js/modules/es6.array.iterator',
'webpack-hot-middleware/client',
2018-05-03 02:34:03 +02:00
'react-hot-loader/patch',
'./client/index.jsx',
],
previewScripts: [
path.resolve(__dirname, '../client/utils/previewEntry.js')
]
},
2016-05-03 06:09:16 +02:00
output: {
path: `${__dirname}`,
filename: '[name].js',
publicPath: '/'
2016-05-03 06:09:16 +02:00
},
resolve: {
extensions: ['.js', '.jsx'],
modules: [
'client',
cool to share some of this code between client and server Squashed commit of the following: commit fb5e82cea930b011792983c7d1cc9f6ecacc7dd4 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Wed Nov 16 12:28:10 2016 -0500 add server side rendering, untested commit 5c60fb30c46ea49a8d9a0ecb56f39ec778464a8b Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Tue Nov 15 18:26:06 2016 -0500 add redux-form bandage post react update, should probably update to redux-form 6 at some point commit 057b5871e7137179abc93f7821a9690f0ea52c92 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Tue Nov 15 16:30:09 2016 -0500 remove passing jsFiles and cssFiles to PreviewFrame, fix rendering bug commit 88c56fd36d3a8d88902c79642171988ce37825f2 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Tue Nov 15 16:21:59 2016 -0500 code cleanup, untested commit 82e5dcf8bca461892f1daf06d38f1eaebe72983f Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Tue Nov 15 15:53:50 2016 -0500 update react and react router, fix a few bugs in rendering code, add ability to parse inline js and css commit e02f4b67803ea45328eff4e53659222f3149964c Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Tue Nov 15 14:43:38 2016 -0500 add almost full code to create preview html correctly, untested commit 12f61b2a1aed4607fab24d01572b647ca6210262 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Wed Nov 2 17:09:26 2016 -0400 refactor some of the preview html generation code commit 111825846703d5c8959cb18795a3aadb7ebe505c Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Wed Nov 2 11:06:36 2016 -0400 add comments as plan of action commit 1cc2cf5203674732b4057382f1937de38b687078 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Thu Oct 27 19:34:55 2016 -0400 add href parsing commit e67189298cda9b70645f454ecd541a363980f0e4 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Thu Oct 27 10:48:36 2016 -0400 continue parsing html commit 1458fb940a15a3dc5d74890211a3073e920b84b8 Author: Cassie Tarakajian <ctarakajian@gmail.com> Date: Wed Oct 26 17:40:31 2016 -0400 start to add html parsing
2016-11-16 19:12:36 +01:00
'node_modules'
]
2016-05-03 06:09:16 +02:00
},
plugins: [
2016-06-23 00:36:04 +02:00
new webpack.HotModuleReplacementPlugin(),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify('development')
2016-06-23 00:36:04 +02:00
}
}),
new CopyWebpackPlugin({
patterns: [
{from: path.resolve(__dirname, '../translations/locales') , to: path.resolve(__dirname, 'locales')}
]
}
)
2016-05-03 06:09:16 +02:00
],
module: {
2018-05-03 02:34:03 +02:00
rules: [
2016-05-03 06:09:16 +02:00
{
2016-06-27 23:40:16 +02:00
test: /\.jsx?$/,
2016-05-03 06:09:16 +02:00
exclude: [/node_modules/, /.+\.config.js/],
2018-05-03 02:34:03 +02:00
use: [{
loader: 'babel-loader',
options: {
cacheDirectory: true,
plugins: ['react-hot-loader/babel'],
}
2018-05-03 02:34:03 +02:00
}, {
loader: 'eslint-loader'
}]
2018-05-09 02:57:16 +02:00
// use: {
// loader: 'babel-loader',
// options: {
// cacheDirectory: true,
// plugins: ['react-hot-loader/babel'],
// }
// }
2016-05-03 06:09:16 +02:00
},
2016-05-03 22:13:04 +02:00
{
test: /main\.scss$/,
use: ['style-loader', 'css-loader', 'sass-loader']
2016-05-11 19:19:37 +02:00
},
{
2020-04-30 00:34:37 +02:00
test: /\.(mp3)$/,
use: 'file-loader'
},
{
test: /\.(png)$/,
use: {
loader: 'file-loader',
options: {
name: '[name].[ext]',
outputPath: 'images/'
}
}
2016-08-18 20:22:47 +02:00
},
{
2020-04-30 00:34:37 +02:00
test: /fonts\/.*\.(eot|ttf|woff|woff2)$/,
use: 'file-loader'
2018-05-15 21:10:24 +02:00
},
2020-04-30 00:34:37 +02:00
{
test: /\.svg$/,
oneOf: [
{
resourceQuery: /byUrl/,
use: 'file-loader'
},
{
use: {
loader: '@svgr/webpack',
options: {
svgoConfig: {
plugins: {
removeViewBox: false
}
}
}
}
}
]
},
2018-05-15 21:10:24 +02:00
{
test: /_console-feed.scss/,
use: {
loader: 'sass-extract-loader',
options: {
plugins: [{ plugin: 'sass-extract-js', options: { camelCase: false } }]
}
}
2016-05-03 22:13:04 +02:00
}
2016-05-03 06:09:16 +02:00
],
},
};