robosats/frontend/webpack.config.ts

239 lines
6.6 KiB
TypeScript
Raw Normal View History

import path from 'path';
import { Configuration } from 'webpack';
2024-09-18 11:32:01 +03:00
import FileManagerPlugin from 'filemanager-webpack-plugin';
import HtmlWebpackPlugin from 'html-webpack-plugin';
import { version } from './package.json';
const config: Configuration = {
entry: './src/index.js',
module: {
rules: [
{
test: /\.(ts|js)x?$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env', '@babel/preset-react', '@babel/preset-typescript'],
},
},
},
],
},
2023-12-02 14:31:21 +03:00
experiments: { asyncWebAssembly: true },
resolve: {
extensions: ['.tsx', '.ts', '.jsx', '.js'],
},
};
const configNode: Configuration = {
...config,
output: {
path: path.resolve(__dirname, 'static/frontend'),
filename: `main.v${version}.[contenthash].js`,
clean: true,
2024-09-18 13:51:21 +03:00
publicPath: '/static/frontend/',
},
plugins: [
2024-09-18 11:32:01 +03:00
// Django
new HtmlWebpackPlugin({
2024-09-18 09:37:37 +03:00
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: false,
},
filename: path.resolve(__dirname, 'templates/frontend/basic.html'),
inject: 'body',
2024-09-18 09:37:37 +03:00
robosatsSettings: 'web-basic',
2024-09-18 13:51:21 +03:00
basePath: '/',
}),
new HtmlWebpackPlugin({
2024-09-18 09:37:37 +03:00
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: true,
},
filename: path.resolve(__dirname, 'templates/frontend/pro.html'),
inject: 'body',
2024-09-18 09:37:37 +03:00
robosatsSettings: 'web-pro',
2024-09-18 13:51:21 +03:00
basePath: '/',
}),
2024-09-18 11:32:01 +03:00
// Node App
new HtmlWebpackPlugin({
2024-09-18 09:37:37 +03:00
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: false,
},
filename: path.resolve(__dirname, '../nodeapp/basic.html'),
inject: 'body',
2024-09-18 09:37:37 +03:00
robosatsSettings: 'selfhosted-basic',
2024-09-18 13:51:21 +03:00
basePath: '/',
}),
new HtmlWebpackPlugin({
2024-09-18 09:37:37 +03:00
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: true,
},
filename: path.resolve(__dirname, '../nodeapp/pro.html'),
inject: 'body',
2024-09-18 09:37:37 +03:00
robosatsSettings: 'selfhosted-pro',
2024-09-18 13:51:21 +03:00
basePath: '/',
2024-09-18 09:37:37 +03:00
}),
2024-09-18 11:32:01 +03:00
new FileManagerPlugin({
events: {
onEnd: {
copy: [
{
source: path.resolve(__dirname, 'static'),
destination: path.resolve(__dirname, '../nodeapp/static'),
},
],
2024-09-18 11:14:43 +03:00
},
2024-09-18 11:32:01 +03:00
},
2024-09-18 11:14:43 +03:00
}),
2024-09-18 11:32:01 +03:00
// Desktop App
2024-09-18 09:37:37 +03:00
new HtmlWebpackPlugin({
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: false,
},
filename: path.resolve(__dirname, '../desktopApp/index.html'),
inject: 'body',
robosatsSettings: 'desktop-basic',
2024-09-18 13:51:21 +03:00
basePath: '/',
2024-09-18 09:37:37 +03:00
}),
2024-09-18 11:32:01 +03:00
new FileManagerPlugin({
events: {
onEnd: {
copy: [
{
source: path.resolve(__dirname, 'static'),
destination: path.resolve(__dirname, '../desktopApp/static'),
},
],
2024-09-18 11:14:43 +03:00
},
2024-09-18 11:32:01 +03:00
},
2024-09-18 11:14:43 +03:00
}),
2024-09-18 11:32:01 +03:00
// Web App
2024-09-18 09:52:08 +03:00
new HtmlWebpackPlugin({
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: false,
},
filename: path.resolve(__dirname, '../web/basic.html'),
inject: 'body',
robosatsSettings: 'web-basic',
2024-09-18 13:51:21 +03:00
basePath: '/',
}),
2024-09-18 09:52:08 +03:00
new HtmlWebpackPlugin({
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: true,
},
filename: path.resolve(__dirname, '../web/pro.html'),
inject: 'body',
robosatsSettings: 'web-pro',
2024-09-18 13:51:21 +03:00
basePath: '/',
2024-09-18 09:37:37 +03:00
}),
2024-09-18 11:32:01 +03:00
new FileManagerPlugin({
events: {
onEnd: {
copy: [
{
source: path.resolve(__dirname, 'static'),
destination: path.resolve(__dirname, '../web/static'),
},
],
},
2024-09-18 11:32:01 +03:00
},
}),
],
};
const configMobile: Configuration = {
...config,
module: {
...config.module,
rules: [
...(config?.module?.rules || []),
{
test: path.resolve(__dirname, 'src/i18n/Web.js'),
loader: 'file-replace-loader',
options: {
condition: 'if-replacement-exists',
replacement: path.resolve(__dirname, 'src/i18n/Native.js'),
async: true,
},
},
2023-10-16 22:32:00 +03:00
{
test: path.resolve(__dirname, 'src/geo/Web.js'),
loader: 'file-replace-loader',
options: {
condition: 'if-replacement-exists',
replacement: path.resolve(__dirname, 'src/geo/Native.js'),
async: true,
},
},
2024-04-30 17:01:54 +03:00
{
test: path.resolve(__dirname, 'src/services/Roboidentities/Web.ts'),
loader: 'file-replace-loader',
options: {
condition: 'if-replacement-exists',
replacement: path.resolve(__dirname, 'src/services/Roboidentities/Native.ts'),
async: true,
},
},
{
test: path.resolve(__dirname, 'src/components/RobotAvatar/placeholder.json'),
loader: 'file-replace-loader',
options: {
condition: 'if-replacement-exists',
replacement: path.resolve(
__dirname,
'src/components/RobotAvatar/placeholder_highres.json',
),
async: true,
},
},
],
},
2024-09-18 13:51:21 +03:00
output: {
path: path.resolve(__dirname, '../mobile/html/Web.bundle/static/frontend'),
filename: `main.v${version}.[contenthash].js`,
clean: true,
publicPath: './static/frontend/',
},
plugins: [
new HtmlWebpackPlugin({
2024-09-18 09:37:37 +03:00
template: path.resolve(__dirname, 'templates/frontend/index.ejs'),
templateParameters: {
pro: false,
},
filename: path.resolve(__dirname, '../mobile/html/Web.bundle/index.html'),
inject: 'body',
2024-09-18 09:37:37 +03:00
robosatsSettings: 'mobile-basic',
2024-09-18 13:51:21 +03:00
basePath: './',
}),
2024-09-18 11:32:01 +03:00
new FileManagerPlugin({
events: {
onEnd: {
copy: [
{
source: path.resolve(__dirname, 'static/css'),
2024-09-18 13:51:21 +03:00
destination: path.resolve(__dirname, '../mobile/html/Web.bundle/static/css'),
},
{
source: path.resolve(__dirname, 'static/assets/sounds'),
destination: path.resolve(__dirname, '../mobile/html/Web.bundle/assets/sounds'),
},
{
source: path.resolve(__dirname, 'static/federation'),
destination: path.resolve(__dirname, '../mobile/html/Web.bundle/assets/federation'),
2024-09-18 11:32:01 +03:00
},
],
},
2024-09-18 11:32:01 +03:00
},
}),
],
Refactor and Init RoboSats PRO (#296) commit 9c6d55cfc77d42471da3e865f2729167597868e5 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Thu Oct 20 10:35:49 2022 -0700 Small fixes commit 23d6c00ccb5e78593e768c36b866d02f26031e7b Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Thu Oct 20 06:12:42 2022 -0700 Refactor frontend commit b2c21d4a98c49f6168bc3ff6e6a3d7b9f8943a12 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Wed Oct 19 07:26:00 2022 -0700 Small fixes (more) commit 78a8ab799dc33e8f8b8f14e22e155bbc7104c3a9 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Wed Oct 19 02:11:03 2022 -0700 Try out to revert depth chart commit ef73c980a8cfc4ae760e720e3bca99acc30b7270 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Tue Oct 18 11:43:37 2022 -0700 Small fixes commit fa3e60208f8f292256dd90813e7beff15db3057a Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Tue Oct 18 09:43:03 2022 -0700 Add old UserGen and BottomBar to new main.tsx commit 1e257d1924df20e2fa4feb7f6afce4f31f2a9acc Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Tue Oct 18 04:01:53 2022 -0700 Add Maker and Book page to new main.tsx commit 037d46ceef34df09530e645a2e01c9fbd9b3efd4 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Mon Oct 17 08:54:55 2022 -0700 Add Main component WIP commit e43b274c33a75ab5050be360a3d01f655e1e8142 Author: Reckless_Satoshi <reckless.satoshi@protonmail.com> Date: Mon Oct 17 04:32:43 2022 -0700 App as functional component
2022-10-20 21:06:16 +03:00
};
2024-09-18 09:37:37 +03:00
export default [configNode, configMobile];