-
-
Notifications
You must be signed in to change notification settings - Fork 11
/
craco.config.js
109 lines (99 loc) · 3.33 KB
/
craco.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Copyright (c) 2020-2021 Drew Lemmy
// This file is part of KristWeb 2 under GPL-3.0.
// Full details: https://github.com/tmpim/KristWeb2/blob/master/LICENSE.txt
const path = require("path");
const CracoAlias = require("craco-alias");
const CracoLessPlugin = require("@lemmmy/craco-less");
const AntdDayjsWebpackPlugin = require("antd-dayjs-webpack-plugin");
const { BundleAnalyzerPlugin } = require("webpack-bundle-analyzer");
const WebpackBar = require("webpackbar");
const GitRevisionPlugin = require("git-revision-webpack-plugin");
const { DefinePlugin } = require("webpack");
const { commits } = require("./tools/commitLog");
const SentryCliPlugin = require("@sentry/webpack-plugin");
const gitRevisionPlugin = new GitRevisionPlugin({
// Include the "-dirty" suffix if the local tree has been modified, and
// include non-annotated tags.
versionCommand: "describe --always --tags --dirty"
});
module.exports = {
style: {
css: {
loaderOptions: {
url: false
}
}
},
babel: {
plugins: [
"lodash",
["@simbathesailor/babel-plugin-use-what-changed", {
"active": process.env.NODE_ENV === "development"
}]
],
},
plugins: [
{
plugin: CracoAlias,
options: {
source: "tsconfig",
baseUrl: "./src",
tsConfigPath: "./tsconfig.extend.json"
}
},
{
plugin: CracoLessPlugin,
options: {
cssLoaderOptions: {
url: false
},
lessLoaderOptions: {
webpackImporter: false,
implementation: require("less"),
lessOptions: {
relativeUrls: false,
javascriptEnabled: true,
paths: [path.resolve(__dirname, "node_modules")]
}
}
}
}
],
// I use eslint in vscode - to save my CPU I'd rather just rely on using that
// to lint instead of the react-scripts watcher.
// TODO: run this for production builds, and add a separate command for it.
eslint: {
enable: false
},
webpack: {
plugins: [
new WebpackBar({ profile: true }),
...(process.env.NODE_ENV === "development" || process.env.FORCE_ANALYZE
? [new BundleAnalyzerPlugin({ openAnalyzer: false })]
: []),
new AntdDayjsWebpackPlugin(),
gitRevisionPlugin,
new DefinePlugin({
"__GIT_VERSION__": DefinePlugin.runtimeValue(() => JSON.stringify(gitRevisionPlugin.version()), []),
"__GIT_COMMIT_HASH__": DefinePlugin.runtimeValue(() => JSON.stringify(gitRevisionPlugin.commithash()), []),
"__BUILD_TIME__": DefinePlugin.runtimeValue(Date.now),
"__GIT_COMMITS__": JSON.stringify(commits),
"__PKGBUILD__": DefinePlugin.runtimeValue(() => JSON.stringify(require("crypto").createHash("sha256").update(require("fs").readFileSync("package.json")).digest("hex").substr(0, 7)), ["package.json"])
}),
...(process.env.NODE_ENV === "production" && process.env.SENTRY_ENABLED === "true"
? [new SentryCliPlugin({
include: "./build/",
ignore: ["node_modules", "craco.config.js", "tools", "public"],
release: "kristweb2-react@" + gitRevisionPlugin.version()
})]
: [])
],
optimization: {
sideEffects: true
},
configure: {
devtool: process.env.NODE_ENV === "development"
? "eval" : "hidden-source-map"
}
},
};