Files
streamwall/webpack.config.js
2022-06-05 14:19:53 -07:00

124 lines
2.4 KiB
JavaScript

const path = require('path')
const CopyPlugin = require('copy-webpack-plugin')
const baseConfig = ({ babel }) => ({
mode: 'development',
module: {
rules: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: babel,
},
},
{
test: /\.css$/i,
use: ['style-loader', 'css-loader'],
},
{
test: /\.ttf$/,
loader: 'file-loader',
options: {
name: '[name].[ext]',
},
},
{
test: /\.svg$/,
loader: '@svgr/webpack',
options: {
replaceAttrValues: {
'#333': 'currentColor',
'#555': '{props.color}',
},
},
},
],
},
resolve: {
extensions: ['.jsx', '.js'],
alias: {
react: 'preact/compat',
'react-dom': 'preact/compat',
},
},
})
const nodeConfig = {
...baseConfig({
babel: {
presets: [
[
'@babel/preset-env',
{
modules: 'commonjs',
targets: { node: true },
},
],
],
},
}),
target: 'electron-main',
entry: {
index: './src/node/index.js',
},
externals: {
consolidate: 'commonjs consolidate',
fsevents: 'commonjs fsevents',
},
}
const browserConfig = {
...baseConfig({
babel: {
presets: [['@babel/preset-env', { targets: { electron: '11' } }]],
},
}),
devtool: 'cheap-source-map',
target: 'electron-renderer',
entry: {
background: './src/browser/background.js',
overlay: './src/browser/overlay.js',
layerPreload: './src/browser/layerPreload.js',
mediaPreload: './src/browser/mediaPreload.js',
playHLS: './src/browser/playHLS.js',
},
plugins: [
new CopyPlugin({
patterns: [{ from: 'src/browser/*.html', to: '[name].html' }],
}),
],
}
const webConfig = {
...baseConfig({
babel: {
presets: [
[
'@babel/preset-env',
{
modules: 'commonjs',
targets: '> 0.25%, not dead',
},
],
],
},
}),
devtool: 'cheap-source-map',
target: 'web',
entry: {
control: './src/web/control.js',
},
output: {
path: path.resolve(__dirname, 'dist/web'),
},
plugins: [
new CopyPlugin({
patterns: [{ from: 'src/web/*.ejs', to: '[name].ejs' }],
}),
],
}
module.exports = [nodeConfig, browserConfig, webConfig]