72bf4547d4
* Clean up workbench and integrate initialization data * Uncomment Electron fill * Run server & client together * Clean up Electron fill & patch * Bind fs methods This makes them usable with the promise form: `promisify(access)(...)`. * Add space between tag and title to browser logger * Add typescript dep to server and default __dirname for path * Serve web files from server * Adjust some dev options * Rework workbench a bit to use a class and catch unexpected errors * No mkdirs for now, fix util fill, use bash with exec * More fills, make general client abstract * More fills * Fix cp.exec * Fix require calls in fs fill being aliased * Create data and storage dir * Implement fs.watch Using exec for now. * Implement storage database fill * Fix os export and homedir * Add comment to use navigator.sendBeacon * Fix fs callbacks (some args are optional) * Make sure data directory exists when passing it back * Update patch * Target es5 * More fills * Add APIs required for bootstrap-fork to function (#15) * Add bootstrap-fork execution * Add createConnection * Bundle bootstrap-fork into cli * Remove .node directory created from spdlog * Fix npm start * Remove unnecessary comment * Add webpack-hot-middleware if CLI env is not set * Add restarting to shared process * Fix starting with yarn
97 lines
2.0 KiB
JavaScript
97 lines
2.0 KiB
JavaScript
const path = require("path");
|
|
const environment = process.env.NODE_ENV || "development";
|
|
const isCi = typeof process.env.CI !== "undefined";
|
|
const HappyPack = require("happypack");
|
|
const webpack = require("webpack");
|
|
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
|
|
|
|
const root = path.join(__dirname, "..");
|
|
|
|
module.exports = (options = {}) => ({
|
|
context: root,
|
|
devtool: "source-map",
|
|
// entry: "./packages/app/src/index.ts",
|
|
mode: isCi ? "production" : "development",
|
|
module: {
|
|
rules: [{
|
|
test: /\.(js)/,
|
|
exclude: /test/,
|
|
}, {
|
|
test: /\.(txt|d\.ts|test.ts|perf.data.js|jxs)/,
|
|
use: [{
|
|
loader: "ignore-loader",
|
|
}],
|
|
}, {
|
|
test: /\.node$/,
|
|
use: "node-loader",
|
|
}, {
|
|
use: [{
|
|
loader: "happypack/loader?id=ts",
|
|
}],
|
|
test: /(^.?|\.[^d]|[^.]d|[^.][^d])\.tsx?$/,
|
|
}, {
|
|
exclude: /test/,
|
|
test: /\.s?css$/,
|
|
// This is required otherwise it'll fail to resolve CSS in common.
|
|
include: root,
|
|
use: [{
|
|
loader: MiniCssExtractPlugin.loader,
|
|
}, {
|
|
loader: "css-loader",
|
|
}, {
|
|
loader: "sass-loader",
|
|
}],
|
|
}, {
|
|
test: /\.(svg|png|ttf|woff|eot)$/,
|
|
use: [{
|
|
loader: "file-loader",
|
|
}],
|
|
}, {
|
|
test: /\.wasm$/,
|
|
type: "javascript/auto",
|
|
}],
|
|
noParse: /\.test\.(j|t)sx?/,
|
|
},
|
|
resolve: {
|
|
alias: {
|
|
"@coder": path.join(root, "packages"),
|
|
},
|
|
extensions: [".js", ".jsx", ".ts", ".tsx", ".json", ".css"],
|
|
mainFiles: [
|
|
"index",
|
|
"src/index",
|
|
],
|
|
},
|
|
resolveLoader: {
|
|
modules: [
|
|
path.join(root, "node_modules"),
|
|
],
|
|
},
|
|
plugins: [
|
|
new HappyPack({
|
|
id: "ts",
|
|
threads: 2,
|
|
loaders: [{
|
|
path: "ts-loader",
|
|
query: {
|
|
happyPackMode: true,
|
|
compilerOptions: options.typescriptCompilerOptions,
|
|
},
|
|
}],
|
|
}),
|
|
new webpack.DefinePlugin({
|
|
"process.env.NODE_ENV": `"${environment}"`,
|
|
}),
|
|
new MiniCssExtractPlugin({
|
|
filename: "[name].css",
|
|
chunkFilename: "[id].css",
|
|
}),
|
|
],
|
|
// target: "web",
|
|
stats: {
|
|
all: false, // Fallback for options not defined.
|
|
errors: true,
|
|
warnings: true,
|
|
},
|
|
});
|