generated from obsidianmd/obsidian-sample-plugin
-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathesbuild.config.mjs
111 lines (104 loc) · 3.01 KB
/
esbuild.config.mjs
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
110
111
import esbuild from 'esbuild'
import process from 'process'
import builtins from 'builtin-modules'
import esbuildSvelte from 'esbuild-svelte'
import sveltePreprocess from 'svelte-preprocess'
import findCacheDir from 'find-cache-dir'
import * as fs from 'fs'
import * as path from 'path'
const banner = `/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
`
const prod = process.argv[2] === 'production'
let cacheDir = findCacheDir({
name: 'inline-sevice-worker',
create: true,
})
async function buildWorker(workerPath) {
let scriptNameParts = path.basename(workerPath).split('.')
scriptNameParts.pop()
scriptNameParts.push('js')
let scriptName = scriptNameParts.join('.')
let bundlePath = path.resolve(cacheDir, scriptName)
await esbuild.build({
entryPoints: [workerPath],
bundle: true,
minify: true,
outfile: bundlePath,
target: 'es2021',
format: 'cjs',
})
return fs.promises.readFile(bundlePath, { encoding: 'utf-8' })
}
let inlineWorkerPlugin = {
name: 'inline-worker-plugin',
setup(build) {
build.onLoad(
{ filter: /\.(service|worker).(js|jsx|ts|tsx)$/ },
async ({ path: workerPath }) => {
let workerCode = await buildWorker(workerPath)
return {
contents: `
export default function inlineWorker() {
let blob = new Blob([${JSON.stringify(
workerCode,
)}], {type: 'text/javascript'})
let url = URL.createObjectURL(blob)
let worker = ${
workerPath.includes('service')
? "navigator.serviceWorker.register(url, {scope: '/'})"
: 'new Worker(url)'
};
URL.revokeObjectURL(url)
return worker
}`,
loader: 'js',
}
},
)
},
}
const context = await esbuild.context({
banner: {
js: banner,
},
entryPoints: ['main.ts'],
bundle: true,
plugins: [
inlineWorkerPlugin,
esbuildSvelte({
compilerOptions: { css: 'injected' },
preprocess: sveltePreprocess(),
}),
],
external: [
'obsidian',
'electron',
'@codemirror/autocomplete',
'@codemirror/collab',
'@codemirror/commands',
'@codemirror/language',
'@codemirror/lint',
'@codemirror/search',
'@codemirror/state',
'@codemirror/view',
'@lezer/common',
'@lezer/highlight',
'@lezer/lr',
...builtins,
],
format: 'cjs',
target: 'es2018',
logLevel: 'info',
sourcemap: prod ? false : 'inline',
treeShaking: true,
outfile: 'main.js',
})
if (prod) {
await context.rebuild()
process.exit(0)
} else {
await context.watch()
}