summaryrefslogtreecommitdiff
path: root/scripts/cmd/prebuild.js
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/cmd/prebuild.js')
-rw-r--r--scripts/cmd/prebuild.js38
1 files changed, 34 insertions, 4 deletions
diff --git a/scripts/cmd/prebuild.js b/scripts/cmd/prebuild.js
index bb8220eef..99208a29f 100644
--- a/scripts/cmd/prebuild.js
+++ b/scripts/cmd/prebuild.js
@@ -1,4 +1,5 @@
import esbuild from 'esbuild';
+import { red } from 'kleur/colors';
import glob from 'tiny-glob';
import fs from 'fs';
import path from 'path';
@@ -39,11 +40,40 @@ export default async function prebuild(...args) {
}
async function prebuildFile(filepath) {
- const tscode = await fs.promises.readFile(filepath, 'utf-8');
- const esbuildresult = await esbuild.transform(tscode, {
- loader: 'ts',
+ let tscode = await fs.promises.readFile(filepath, 'utf-8');
+ // If we're bundling a client directive, modify the code to match `packages/astro/src/core/client-directive/build.ts`.
+ // If updating this code, make sure to also update that file.
+ if (filepath.includes(`runtime${path.sep}client`)) {
+ // `export default xxxDirective` is a convention used in the current client directives that we use
+ // to make sure we bundle this right. We'll error below if this convention isn't followed.
+ const newTscode = tscode.replace(
+ /export default (.*?)Directive/,
+ (_, name) =>
+ `(self.Astro || (self.Astro = {})).${name} = ${name}Directive;window.dispatchEvent(new Event('astro:${name}'))`
+ );
+ if (newTscode === tscode) {
+ console.error(
+ red(
+ `${filepath} doesn't follow the \`export default xxxDirective\` convention. The prebuilt output may be wrong. ` +
+ `For more information, check out ${fileURLToPath(import.meta.url)}`
+ )
+ );
+ }
+ tscode = newTscode;
+ }
+ const esbuildresult = await esbuild.build({
+ stdin: {
+ contents: tscode,
+ resolveDir: path.dirname(filepath),
+ loader: 'ts',
+ sourcefile: filepath,
+ },
+ format: 'iife',
minify,
+ bundle: true,
+ write: false,
});
+ const code = esbuildresult.outputFiles[0].text.trim();
const rootURL = new URL('../../', import.meta.url);
const rel = path.relative(fileURLToPath(rootURL), filepath);
const mod = `/**
@@ -52,7 +82,7 @@ export default async function prebuild(...args) {
* to generate this file.
*/
-export default \`${escapeTemplateLiterals(esbuildresult.code.trim())}\`;`;
+export default \`${escapeTemplateLiterals(code)}\`;`;
const url = getPrebuildURL(filepath);
await fs.promises.writeFile(url, mod, 'utf-8');
}