Files
zkitter-ui/webpack.ui.config.js
tsukino 3fc97c427b implement zkchat and ipfs integration; update app to use rln proofs (#17)
* finish cover image file upload

* add profile image uploader

* add post editor uploader

* fix url preview

* fix preview scss

* add user auth to upload

* polish webtorrent flows to gracefully shutdown cached client

* update image upload

* add link attach modal

* wip

* add dev ui for chat

* add basic chat ui

* zk chat - dox dm done

* add basic incognito ui

* schema update

* wip

* add group info

* fix anon chat creation

* fix semaphore signal hash

* allow file upload for zk post

* check interep path with new api

* add new incognito badges

* use rln for upload

* add infinite scrolling

* mobile responsiveness

* fix mobile
2022-08-03 18:44:43 +08:00

150 lines
4.1 KiB
JavaScript

const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CopyPlugin = require("copy-webpack-plugin");
const path = require('path');
const isProd = process.env.NODE_ENV === 'production';
const devServerEntries = [
// 'webpack-dev-server/client?http://localhost:8080',
// 'webpack/hot/only-dev-server',
];
const envPlugin = new webpack.EnvironmentPlugin({
'NODE_ENV': '',
'BASE_URL': '',
'WEB3_HTTP_PROVIDER': '',
'ENS_RESOLVER': '',
'INDEXER_API': '',
'ARB_HTTP_PROVIDER': '',
'ARB_REGISTRAR': '',
'ARB_EXPLORER': '',
'GUN_PEERS': [],
});
const rules = [
{
test: /\.node$/,
use: 'node-loader',
},
{
test: /\.tsx?$/,
exclude: /(node_modules|.webpack)/,
use: [
{
loader: 'ts-loader',
options: {
transpileOnly: true,
},
},
],
},
];
const rendererRules = [
{
test: /\.(gif|png|jpe?g|svg)$/i,
use: [
'file-loader',
{
loader: 'image-webpack-loader',
options: {
publicPath: 'assets',
bypassOnDebug: true, // webpack@1.x
disable: true, // webpack@2.x and newer
},
},
],
},
{
test: /\.(s[ac]ss|css)$/i,
use: [
// Creates `style` nodes from JS strings
'style-loader',
// Translates CSS into CommonJS
'css-loader',
// Compiles Sass to CSS
'sass-loader',
],
},
];
module.exports = [
{
target: 'web',
mode: isProd ? 'production' : 'development',
entry: {
app: path.join(__dirname, 'src', 'app.tsx'),
serviceWorker: path.join(__dirname, 'src', 'serviceWorkers', 'index.ts'),
},
// [
// ...(isProd ? [] : devServerEntries),
// `./src/app.tsx`,
// ],
output: {
path: __dirname + '/build',
publicPath: isProd ? '/' : 'http://localhost:8080/',
filename: `[name].js`,
},
devtool: 'source-map',
resolve: {
extensions: ['.ts', '.tsx', '.js', '.jsx', '.png', '.svg'],
modules: [
path.resolve('./node_modules')
],
fallback: {
browserify: require.resolve("browserify"),
stream: require.resolve("stream-browserify"),
path: require.resolve("path-browserify"),
crypto: require.resolve("crypto-browserify"),
os: require.resolve("os-browserify/browser"),
http: require.resolve("stream-http"),
https: require.resolve("https-browserify"),
constants: false,
fs: false,
},
},
module: {
rules: [
...rules,
...rendererRules,
],
},
plugins: [
envPlugin,
new webpack.ProvidePlugin({
Buffer: ["buffer", "Buffer"],
}),
new webpack.ProvidePlugin({
process: "process",
}),
new CopyPlugin([
{
from: "./static/icons/favicon.png",
to: __dirname + '/build/favicon.png',
},
{
from: "./static/manifest.json",
to: __dirname + '/build/manifest.json',
},
]),
new HtmlWebpackPlugin({
template: `./static/index.html`,
filename: `index.html`,
}),
],
devServer: {
historyApiFallback: true,
stats: "minimal",
proxy: {
"/rest": {
target: `http://127.0.0.1:8080`,
secure: true
}
}
},
// optimization: {
// runtimeChunk: 'single'
// },
},
];