forked from flamingchickens1540/CLUCK
-
Notifications
You must be signed in to change notification settings - Fork 0
/
esbuild-frontend.ts
72 lines (69 loc) · 2.25 KB
/
esbuild-frontend.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
import htmlPlugin from '@chialab/esbuild-plugin-html'
import { sassPlugin } from 'esbuild-sass-plugin'
import esbuild from 'esbuild'
import fs from 'fs/promises'
import path from 'path'
import logger from '~lib/logger'
fs.stat('./public').catch(async () => {
await fs.mkdir('./public')
})
const views: Record<string, string> = {
grid: '/grid/',
dash: '/dash/',
admin_members: '/admin/members/',
admin_certs: '/admin/certs/',
admin_departments: '/admin/departments/',
admin_meetings: '/admin/meetings/'
}
const contexts: esbuild.BuildContext[] = []
for (const id in views) {
contexts.push(
await esbuild.context({
entryPoints: [path.join('src/views', id, 'index.html')],
outdir: path.join('public/', views[id]),
assetNames: `assets/[name]`,
chunkNames: `assets/[name]`,
plugins: [
sassPlugin(),
htmlPlugin({ minifyOptions: { minifySvg: false } }),
{
name: 'rebuild-notify',
setup(build) {
build.onEnd((result) => {
logger.info(`${id} ended with ${result.errors.length} errors`)
// HERE: somehow restart the server from here, e.g., by sending a signal that you trap and react to inside the server.
})
}
}
],
bundle: true,
minify: true,
sourcemap: 'inline',
external: ['/static/*']
})
)
logger.info('Loaded build context for ' + id)
}
const watch = process.argv.includes('--watch')
// const endPromise = Promise.all(
// contexts.map(async (context) => {
// if (watch) {
// logger.info('adding watch listener')
// await context.watch({})
// } else {
// await context.rebuild()
// await context.dispose()
// }
// })
// )
if (watch) {
logger.info('Watching...')
for (const context of contexts) {
await context.watch({})
}
logger.info('Done...')
} else {
logger.info('Building...')
await Promise.all(contexts.map((ctx) => ctx.rebuild().then(ctx.dispose)))
logger.info('Build complete')
}