- _data: switch to cachedFetch wrapper (10s timeout + 4h watch cache) - js/webmentions.js: owner reply threading, platform provenance badges, DOM dedup, Micropub reply support - js/comments.js: owner detection, reply system, Alpine.store integration - _includes/components/webmentions.njk: data-wm-* attrs, provenance badge slots, reply buttons - _includes/components/comments.njk: owner-aware comment form, threaded replies - widgets/toc.njk: Alpine.js tocScanner upgrade (replaces is-land/inline-JS) - lib/og.js + og-cli.js: OG card v3 (light theme, avatar, batched spawn, DESIGN_VERSION=3) - eleventy.config.js: hasOgImage cache, memoized date filters, batched OG/unfurl, post-build GC, YouTube check opt - base.njk: Inter font preloads + toc-scanner.js script - critical.css: font-face declarations (font-display:optional) - tailwind.css: font-display swap→optional - tailwind.config.js: prose link colors -700→-600 - Color design system: accent-700/300 → accent-600/400 across components Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
35 lines
871 B
JavaScript
35 lines
871 B
JavaScript
/**
|
|
* Podroll Status Data
|
|
* Checks if the podroll API backend is available at build time.
|
|
* Used for conditional navigation — the podroll page itself loads data client-side.
|
|
*/
|
|
|
|
import { cachedFetch } from "../lib/data-fetch.js";
|
|
|
|
const INDIEKIT_URL = process.env.SITE_URL || "https://example.com";
|
|
|
|
export default async function () {
|
|
try {
|
|
const url = `${INDIEKIT_URL}/podrollapi/api/status`;
|
|
console.log(`[podrollStatus] Checking API: ${url}`);
|
|
const data = await cachedFetch(url, {
|
|
duration: "15m",
|
|
type: "json",
|
|
});
|
|
console.log("[podrollStatus] API available");
|
|
return {
|
|
available: true,
|
|
source: "indiekit",
|
|
...data,
|
|
};
|
|
} catch (error) {
|
|
console.log(
|
|
`[podrollStatus] API unavailable: ${error.message}`
|
|
);
|
|
return {
|
|
available: false,
|
|
source: "unavailable",
|
|
};
|
|
}
|
|
}
|