-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuilder.ts
97 lines (90 loc) · 3.1 KB
/
builder.ts
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
import { LiveServerParams, start } from "live-server";
import { watch } from "chokidar";
import { build, BuildOptions } from "esbuild";
import cssModulesPlugin from "esbuild-css-modules-plugin";
import { removeSync, copySync } from "fs-extra";
import { sassPlugin } from "esbuild-sass-plugin";
import postcss from "postcss";
import autoprefixer from "autoprefixer";
import postcssPresetEnv from "postcss-preset-env";
const isWatch = process.argv.includes("--watch");
/**
* Live Server Params
* @link https://www.npmjs.com/package/live-server#usage-from-node
*/
const serverParams: LiveServerParams = {
port: 8181, // Set the server port. Defaults to 8080.
root: "build", // Set root directory that's being served. Defaults to cwd.
open: true // When false, it won't load your browser by default.
// host: "0.0.0.0", // Set the address to bind to. Defaults to 0.0.0.0 or process.env.IP.
// ignore: 'scss,my/templates', // comma-separated string for paths to ignore
// file: "index.html", // When set, serve this file (server root relative) for every 404 (useful for single-page applications)
// wait: 1000, // Waits for all changes, before reloading. Defaults to 0 sec.
// mount: [['/components', './node_modules']], // Mount a directory to a route.
// logLevel: 2, // 0 = errors only, 1 = some, 2 = lots
// middleware: [function(req, res, next) { next(); }] // Takes an array of Connect-compatible middleware that are injected into the server middleware stack
};
/**
* ESBuild Params
* @link https://esbuild.github.io/api/#build-api
*/
const buildParams: BuildOptions = {
color: true,
entryPoints: ["src/index.tsx"],
loader: { ".ts": "tsx", ".json": "json", ".png": "file", ".jpeg": "file", ".jpg": "file", ".svg": "file" },
assetNames: "assets/[name]-[hash]",
outdir: "build",
minify: !isWatch,
format: "cjs",
bundle: true,
sourcemap: isWatch,
logLevel: "error",
incremental: isWatch,
plugins: [
cssModulesPlugin(),
sassPlugin({
async transform(source) {
const { css } = await postcss([autoprefixer, postcssPresetEnv({ stage: 0 })]).process(source, {
from: undefined
});
return css;
}
})
]
};
// Clean build folder
try {
removeSync("build");
} catch (err) {
console.error(err);
}
// Copy public folder into build folder
try {
copySync("public", "build");
} catch (err) {
console.error(err);
}
if (isWatch) {
(async () => {
// Build
const result = await build(buildParams).catch(() => process.exit(1));
// Start live server
start(serverParams);
/**
* Watch development server changes
* ignored: ignore watch `.*` files
*/
return watch("src/**/*", { ignored: /(^|[/\\])\../, ignoreInitial: true }).on("all", async (event, path) => {
if (event === "change") {
console.log(`⚡ [esbuild] Rebuilding ${path}`);
console.time("⚡ [esbuild] Done");
if (result.rebuild) await result.rebuild();
console.timeEnd("⚡ [esbuild] Done");
}
});
})();
} else {
// Run build
console.log(`⚡ [esbuild] Building..`);
build(buildParams).catch(() => process.exit(1));
}