@leadertechie/personal-site-kit 0.1.0-alpha.14 → 0.1.0-alpha.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"template.d.ts","sourceRoot":"","sources":["../../src/prerender/template.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;
|
|
1
|
+
{"version":3,"file":"template.d.ts","sourceRoot":"","sources":["../../src/prerender/template.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAuCD,eAAO,MAAM,kBAAkB,GAAU,2EAOtC,aAAa,KAAG,OAAO,CAAC,MAAM,CA4BhC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"website-prerender.d.ts","sourceRoot":"","sources":["../../src/prerender/website-prerender.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,aAAa,EAAE,MAAM,YAAY,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,EAAuB,MAAM,gBAAgB,CAAC;AAE1E,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,kBAAkB,CAAC,EAAE,WAAW,EAAE,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC;IACtE,UAAU,CAAC,EAAE;QAAE,KAAK,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,KAAK,OAAO,CAAC,QAAQ,CAAC,GAAG,QAAQ,CAAA;KAAE,CAAC;CAChG;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAW;IACzB,OAAO,CAAC,kBAAkB,CAAgB;IAC1C,OAAO,CAAC,WAAW,CAAgB;IACnC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,gBAAgB,CAAqD;IAC7E,OAAO,CAAC,UAAU,CAAC,CAAoF;gBAE3F,OAAO,GAAE,gBAAqB;YAmB5B,kBAAkB;YAiClB,gBAAgB;IAajB,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"website-prerender.d.ts","sourceRoot":"","sources":["../../src/prerender/website-prerender.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,aAAa,EAAE,MAAM,YAAY,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,EAAuB,MAAM,gBAAgB,CAAC;AAE1E,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,kBAAkB,CAAC,EAAE,WAAW,EAAE,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC;IACtE,UAAU,CAAC,EAAE;QAAE,KAAK,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,KAAK,OAAO,CAAC,QAAQ,CAAC,GAAG,QAAQ,CAAA;KAAE,CAAC;CAChG;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,MAAM,CAAW;IACzB,OAAO,CAAC,kBAAkB,CAAgB;IAC1C,OAAO,CAAC,WAAW,CAAgB;IACnC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,gBAAgB,CAAqD;IAC7E,OAAO,CAAC,UAAU,CAAC,CAAoF;gBAE3F,OAAO,GAAE,gBAAqB;YAmB5B,kBAAkB;YAiClB,gBAAgB;IAajB,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC;CAoH5E"}
|
package/dist/prerender.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { R2ContentLoader } from "@leadertechie/r2tohtml";
|
|
2
2
|
async function getAssetPaths(baseSiteUrl) {
|
|
3
|
+
if (baseSiteUrl.includes("localhost") || baseSiteUrl.includes("127.0.0.1")) ;
|
|
3
4
|
const assetsUrl = `${baseSiteUrl}/cdn-assets.json`;
|
|
4
5
|
try {
|
|
5
6
|
const res = await fetch(assetsUrl);
|
|
@@ -14,10 +15,12 @@ async function getAssetPaths(baseSiteUrl) {
|
|
|
14
15
|
const html = await res.text();
|
|
15
16
|
const jsMatch = html.match(/src="(\/assets\/index-[^"]+\.js)"/);
|
|
16
17
|
const cssMatch = html.match(/href="(\/assets\/index-[^"]+\.css)"/);
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
18
|
+
if (jsMatch || cssMatch) {
|
|
19
|
+
return {
|
|
20
|
+
js: jsMatch ? jsMatch[1] : "/assets/index.js",
|
|
21
|
+
css: cssMatch ? cssMatch[1] : "/assets/index.css"
|
|
22
|
+
};
|
|
23
|
+
}
|
|
21
24
|
} catch (e) {
|
|
22
25
|
}
|
|
23
26
|
return { js: "/assets/index.js", css: "/assets/index.css" };
|
|
@@ -30,7 +33,8 @@ const createHtmlTemplate = async ({
|
|
|
30
33
|
hydrationData = "",
|
|
31
34
|
baseSiteUrl = ""
|
|
32
35
|
}) => {
|
|
33
|
-
const
|
|
36
|
+
const effectiveBaseUrl = baseSiteUrl || new URL(canonicalUrl).origin;
|
|
37
|
+
const { js: jsAsset, css: cssAsset } = await getAssetPaths(effectiveBaseUrl);
|
|
34
38
|
return `<!doctype html>
|
|
35
39
|
<html lang="en" data-theme="light">
|
|
36
40
|
<head>
|
|
@@ -138,7 +142,7 @@ async function fetchLatestStorySummaries(env, count = 3) {
|
|
|
138
142
|
}
|
|
139
143
|
}
|
|
140
144
|
const generatePageContent = async (pathname, routes, footerLinks, env) => {
|
|
141
|
-
const apiUrl = env?.API_URL || env?.apiUrl;
|
|
145
|
+
const apiUrl = env?.API_URL || env?.apiUrl || "https://api.example.com";
|
|
142
146
|
const baseUrl = env?.BASE_URL || env?.baseUrl || "https://www.example.com";
|
|
143
147
|
let staticDetails = {
|
|
144
148
|
siteTitle: "My Personal Website",
|
|
@@ -345,15 +349,30 @@ class WebsitePrerender {
|
|
|
345
349
|
return null;
|
|
346
350
|
}
|
|
347
351
|
async fetch(request, env, ctx) {
|
|
348
|
-
const apiUrl = env?.API_URL || "https://api.example.com";
|
|
349
|
-
const baseSiteUrl = env?.BASE_SITE_URL || "https://site.example.com";
|
|
350
|
-
await this.fetchStaticDetails(apiUrl, env);
|
|
351
352
|
const url = new URL(request.url);
|
|
353
|
+
const apiUrl = env?.API_URL || `${url.origin}/api`;
|
|
354
|
+
const baseSiteUrl = env?.BASE_SITE_URL || url.origin;
|
|
355
|
+
if (url.pathname === "/admin" || url.pathname.startsWith("/admin/")) {
|
|
356
|
+
const templateResponse = await fetch(`${baseSiteUrl}/index.html`);
|
|
357
|
+
if (templateResponse.ok) {
|
|
358
|
+
return new Response(templateResponse.body, {
|
|
359
|
+
headers: { "content-type": "text/html" }
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
await this.fetchStaticDetails(apiUrl, env);
|
|
352
364
|
if (url.pathname.startsWith("/api/")) {
|
|
353
365
|
if (this.apiHandler) {
|
|
354
366
|
return this.apiHandler.fetch(request, env, ctx);
|
|
355
367
|
}
|
|
356
|
-
return fetch(`${apiUrl}${url.pathname}${url.search}`);
|
|
368
|
+
return fetch(`${apiUrl}${url.pathname.replace(/^\/api/, "")}${url.search}`);
|
|
369
|
+
}
|
|
370
|
+
if (env.ASSETS && (url.pathname.startsWith("/assets/") || url.pathname === "/favicon.ico" || url.pathname === "/logo.png")) {
|
|
371
|
+
try {
|
|
372
|
+
const assetRes = await env.ASSETS.fetch(request);
|
|
373
|
+
if (assetRes.ok) return assetRes;
|
|
374
|
+
} catch (e) {
|
|
375
|
+
}
|
|
357
376
|
}
|
|
358
377
|
if (url.pathname.startsWith("/images/")) {
|
|
359
378
|
const imageKey = url.pathname.slice(1);
|
|
@@ -390,6 +409,9 @@ class WebsitePrerender {
|
|
|
390
409
|
ico: "image/x-icon"
|
|
391
410
|
};
|
|
392
411
|
const contentType = contentTypes[ext || ""] || "application/octet-stream";
|
|
412
|
+
if (baseSiteUrl === url.origin) {
|
|
413
|
+
return new Response("Asset not found", { status: 404 });
|
|
414
|
+
}
|
|
393
415
|
const response = await fetch(`${baseSiteUrl}${path}`);
|
|
394
416
|
if (response.ok) {
|
|
395
417
|
return new Response(response.body, {
|
package/package.json
CHANGED