-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathdev.ts
66 lines (59 loc) · 1.5 KB
/
dev.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
import { svelte } from "@hyrious/esbuild-plugin-svelte";
import { build, Plugin, serve } from "esbuild";
import { createServer, ServerResponse } from "http";
import { icons } from "./plugins/icons";
let port = 3000;
const clients: ServerResponse[] = [];
const plugins: Plugin[] = [await icons(), svelte()];
const { stop: stopWatch } = await build({
entryPoints: ["./src/main.ts"],
bundle: true,
format: "esm",
plugins,
watch: {
onRebuild() {
clients.forEach((res) => res.write("data: update\n\n"));
clients.length = 0;
},
},
logLevel: "silent",
write: false,
outdir: "dist",
});
const { stop: stopServe } = await serve(
{
host: "localhost",
port,
servedir: "./src",
},
{
entryPoints: ["./src/main.ts"],
bundle: true,
format: "esm",
plugins,
sourcemap: true,
banner: {
js: `new EventSource("http://localhost:30000").onmessage = () => location.reload(); console.log("[dev] hot reload enabled");`,
},
define: {
"import.meta.env.DEV": "true",
},
}
);
createServer((_, res) => {
const client = res.writeHead(200, {
"Content-Type": "text/event-stream",
"Cache-Control": "no-cache",
"Access-Control-Allow-Origin": "http://localhost:3000",
Connection: "keep-alive",
});
clients.push(client);
}).listen(30000, () => console.log(`serving http://localhost:${port}`));
process.once("SIGTERM", async () => {
try {
stopWatch && stopWatch();
stopServe && stopServe();
} finally {
process.exit(0);
}
});