Skip to content

Commit

Permalink
move to electron-react-boilerplate
Browse files Browse the repository at this point in the history
  • Loading branch information
Ciberusps committed Feb 11, 2022
1 parent 08adad2 commit e261ecf
Show file tree
Hide file tree
Showing 183 changed files with 29,369 additions and 11,716 deletions.
4 changes: 0 additions & 4 deletions .babelrc

This file was deleted.

12 changes: 12 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
root = true

[*]
indent_style = space
indent_size = 2
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true

[*.md]
trim_trailing_whitespace = false
7 changes: 7 additions & 0 deletions .erb/configs/.eslintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"rules": {
"no-console": "off",
"global-require": "off",
"import/no-dynamic-require": "off"
}
}
53 changes: 53 additions & 0 deletions .erb/configs/webpack.config.base.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
/**
* Base webpack config used across other specific configs
*/

import webpack from "webpack";
import webpackPaths from "./webpack.paths";
import { dependencies as externals } from "../../release/app/package.json";

const configuration: webpack.Configuration = {
externals: [...Object.keys(externals || {})],

stats: "errors-only",

module: {
rules: [
{
test: /\.[jt]sx?$/,
exclude: /node_modules/,
use: {
loader: "ts-loader",
options: {
// Remove this line to enable type checking in webpack builds
transpileOnly: true,
},
},
},
],
},

output: {
path: webpackPaths.srcPath,
// https://github.com/webpack/webpack/issues/1114
library: {
type: "commonjs2",
},
},

/**
* Determine the array of extensions that should be used to resolve modules.
*/
resolve: {
extensions: [".js", ".jsx", ".json", ".ts", ".tsx"],
modules: [webpackPaths.srcPath, "node_modules"],
},

plugins: [
new webpack.EnvironmentPlugin({
NODE_ENV: "production",
}),
],
};

export default configuration;
3 changes: 3 additions & 0 deletions .erb/configs/webpack.config.eslint.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
/* eslint import/no-unresolved: off, import/no-self-import: off */

module.exports = require("./webpack.config.renderer.dev").default;
82 changes: 82 additions & 0 deletions .erb/configs/webpack.config.main.prod.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
/**
* Webpack config for production electron main process
*/

import path from "path";
import webpack from "webpack";
import { merge } from "webpack-merge";
import TerserPlugin from "terser-webpack-plugin";
import { BundleAnalyzerPlugin } from "webpack-bundle-analyzer";
import baseConfig from "./webpack.config.base";
import webpackPaths from "./webpack.paths";
import checkNodeEnv from "../scripts/check-node-env";
import deleteSourceMaps from "../scripts/delete-source-maps";

checkNodeEnv("production");
deleteSourceMaps();

const devtoolsConfig =
process.env.DEBUG_PROD === "true"
? {
devtool: "source-map",
}
: {};

const configuration: webpack.Configuration = {
...devtoolsConfig,

mode: "production",

target: "electron-main",

entry: {
main: path.join(webpackPaths.srcMainPath, "main.ts"),
preload: path.join(webpackPaths.srcMainPath, "preload.js"),
},

output: {
path: webpackPaths.distMainPath,
filename: "[name].js",
},

optimization: {
minimizer: [
new TerserPlugin({
parallel: true,
}),
],
},

plugins: [
new BundleAnalyzerPlugin({
analyzerMode: process.env.ANALYZE === "true" ? "server" : "disabled",
}),

/**
* Create global constants which can be configured at compile time.
*
* Useful for allowing different behaviour between development builds and
* release builds
*
* NODE_ENV should be production so that modules do not perform certain
* development checks
*/
new webpack.EnvironmentPlugin({
NODE_ENV: "production",
DEBUG_PROD: false,
START_MINIMIZED: false,
}),
],

/**
* Disables webpack processing of __dirname and __filename.
* If you run the bundle in node.js it falls back to these values of node.js.
* https://github.com/webpack/webpack/issues/2010
*/
node: {
__dirname: false,
__filename: false,
},
};

export default merge(baseConfig, configuration);
77 changes: 77 additions & 0 deletions .erb/configs/webpack.config.renderer.dev.dll.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
/**
* Builds the DLL for development electron renderer process
*/

import webpack from "webpack";
import path from "path";
import { merge } from "webpack-merge";
import baseConfig from "./webpack.config.base";
import webpackPaths from "./webpack.paths";
import { dependencies } from "../../package.json";
import checkNodeEnv from "../scripts/check-node-env";

checkNodeEnv("development");

const dist = webpackPaths.dllPath;

const configuration: webpack.Configuration = {
context: webpackPaths.rootPath,

devtool: "eval",

mode: "development",

target: "electron-renderer",

externals: ["fsevents", "crypto-browserify"],

/**
* Use `module` from `webpack.config.renderer.dev.js`
*/
module: require("./webpack.config.renderer.dev").default.module,

entry: {
renderer: Object.keys(dependencies || {}),
},

output: {
path: dist,
filename: "[name].dev.dll.js",
library: {
name: "renderer",
type: "var",
},
},

plugins: [
new webpack.DllPlugin({
path: path.join(dist, "[name].json"),
name: "[name]",
}),

/**
* Create global constants which can be configured at compile time.
*
* Useful for allowing different behaviour between development builds and
* release builds
*
* NODE_ENV should be production so that modules do not perform certain
* development checks
*/
new webpack.EnvironmentPlugin({
NODE_ENV: "development",
}),

new webpack.LoaderOptionsPlugin({
debug: true,
options: {
context: webpackPaths.srcPath,
output: {
path: webpackPaths.dllPath,
},
},
}),
],
};

export default merge(baseConfig, configuration);
Loading

0 comments on commit e261ecf

Please sign in to comment.