ampcast/webpack.config.js
2023-08-10 15:04:04 +01:00

129 lines
4.5 KiB
JavaScript

const {resolve} = require('path');
const webpack = require('webpack');
const ESLintPlugin = require('eslint-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const devKeys = require('../credentials/keys-dev.json');
const prodKeys = require('../credentials/keys-prod.json');
const packageJson = require('./package.json');
module.exports = (env) => {
const mode = env.mode === 'electron' ? 'production' : env.mode || 'production';
const __dev__ = mode === 'development';
const __electron__ = env.mode === 'electron';
const wwwDir = resolve(__dirname, __dev__ ? 'www-dev' : __electron__ ? 'www-electron' : 'www');
const keys = env.mode === 'production' ? prodKeys : devKeys; // fix electron later
return {
entry: {
'lib/butterchurn': 'butterchurn',
'lib/unidecode': 'unidecode',
'lib/vendors': [
'@ctrl/tinycolor',
'audiomotion-analyzer',
'd3-array',
'd3-interpolate',
'd3-scale',
'detect-browser',
'dexie',
'libs/dialog-polyfill',
'fullscreen-api-polyfill',
'jsfft',
'md5',
'react',
'react-dom',
'react-error-boundary',
'spotify-web-api-js',
'string-score',
'youtube-player',
],
bundle: {
import: './src/index.tsx',
dependOn: ['lib/butterchurn', 'lib/unidecode', 'lib/vendors'],
},
},
output: {
chunkFilename: 'lib/[name].js',
path: wwwDir,
},
optimization: {
runtimeChunk: 'single',
},
module: {
rules: [
{
test: /\.tsx?$/,
use: 'ts-loader',
exclude: /node_modules/,
},
{
test: /\.s?css$/,
use: [
MiniCssExtractPlugin.loader,
{
loader: 'css-loader',
},
{
loader: 'sass-loader',
},
{
loader: 'postcss-loader',
},
],
},
{
test: /\.frag$/,
type: 'asset/source',
},
],
},
plugins: [
new ESLintPlugin({
extensions: ['.tsx', '.ts'],
}),
new MiniCssExtractPlugin({
filename: 'bundle.css',
}),
new webpack.ProvidePlugin({
Buffer: ['buffer', 'Buffer'],
}),
new webpack.ProvidePlugin({
process: 'process/browser',
}),
new webpack.DefinePlugin({
__dev__,
__electron__,
__app_name__: JSON.stringify(packageJson.name),
__app_version__: JSON.stringify(packageJson.version),
__app_contact__: JSON.stringify(packageJson.author.email),
__am_dev_token__: JSON.stringify(keys.am_dev_token),
__lf_api_key__: JSON.stringify(keys.lf_api_key),
__lf_api_secret__: JSON.stringify(keys.lf_api_secret),
__sp_client_id__: JSON.stringify(keys.sp_client_id),
__yt_api_key__: JSON.stringify(keys.yt_api_key),
__yt_client_id__: JSON.stringify(keys.yt_client_id),
}),
new webpack.BannerPlugin({
include: 'lib/vendors',
banner: 'For license information please see dialog-polyfill.js.LICENSE.txt',
}),
],
resolve: {
alias: {
assets: resolve(__dirname, 'src/assets/'),
components: resolve(__dirname, 'src/components/'),
hooks: resolve(__dirname, 'src/hooks/'),
services: resolve(__dirname, 'src/services/'),
styles: resolve(__dirname, 'src/styles/'),
types: resolve(__dirname, 'src/types/'),
utils: resolve(__dirname, 'src/utils/'),
libs: resolve(__dirname, 'libs/'),
},
extensions: ['.tsx', '.ts', '.js'],
},
stats: {
builtAt: true,
},
mode,
};
};