@takazudo/zfb 0.1.0-next.2
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.
- package/CHANGELOG.md +17 -0
- package/LICENSE +21 -0
- package/README.md +207 -0
- package/bin/zfb.mjs +61 -0
- package/dist/config.d.ts +542 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +24 -0
- package/dist/config.js.map +1 -0
- package/dist/content.d.ts +231 -0
- package/dist/content.d.ts.map +1 -0
- package/dist/content.js +449 -0
- package/dist/content.js.map +1 -0
- package/dist/frontmatter.d.ts +23 -0
- package/dist/frontmatter.d.ts.map +1 -0
- package/dist/frontmatter.js +142 -0
- package/dist/frontmatter.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/island.d.ts +121 -0
- package/dist/island.d.ts.map +1 -0
- package/dist/island.js +273 -0
- package/dist/island.js.map +1 -0
- package/dist/jsx-types.d.ts +37 -0
- package/dist/jsx-types.d.ts.map +1 -0
- package/dist/jsx-types.js +12 -0
- package/dist/jsx-types.js.map +1 -0
- package/dist/paginate.d.ts +43 -0
- package/dist/paginate.d.ts.map +1 -0
- package/dist/paginate.js +44 -0
- package/dist/paginate.js.map +1 -0
- package/dist/plugins.d.ts +259 -0
- package/dist/plugins.d.ts.map +1 -0
- package/dist/plugins.js +42 -0
- package/dist/plugins.js.map +1 -0
- package/dist/runtime.d.ts +101 -0
- package/dist/runtime.d.ts.map +1 -0
- package/dist/runtime.js +454 -0
- package/dist/runtime.js.map +1 -0
- package/dist/types.d.ts +27 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +33 -0
- package/dist/types.js.map +1 -0
- package/package.json +98 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"content.js","sourceRoot":"","sources":["../src/content.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/** Public shape returned by [`parseFrontmatter`]. */
|
|
2
|
+
export type ParsedFrontmatter = {
|
|
3
|
+
data: Record<string, unknown>;
|
|
4
|
+
body: string;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* Parse a leading YAML-ish frontmatter block off a markdown document.
|
|
8
|
+
*
|
|
9
|
+
* **Public SDK surface.** Re-exported from `zfb/content` so consumers can
|
|
10
|
+
* write their own custom content loaders without re-implementing the
|
|
11
|
+
* (deliberately minimal) v0 frontmatter parser. The accepted grammar is
|
|
12
|
+
* documented at the top of this module.
|
|
13
|
+
*
|
|
14
|
+
* Handles:
|
|
15
|
+
* - empty frontmatter (`---\n---\nbody`) → `{ data: {}, body: "body" }`
|
|
16
|
+
* - file ending exactly with `---` (no trailing newline) → frontmatter
|
|
17
|
+
* parsed, body is empty.
|
|
18
|
+
*
|
|
19
|
+
* Returns `{ data: {}, body: <input> }` unchanged when no frontmatter
|
|
20
|
+
* fence is present, or when the opening fence has no matching closer.
|
|
21
|
+
*/
|
|
22
|
+
export declare function parseFrontmatter(raw: string): ParsedFrontmatter;
|
|
23
|
+
//# sourceMappingURL=frontmatter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontmatter.d.ts","sourceRoot":"","sources":["../src/frontmatter.ts"],"names":[],"mappings":"AA4BA,qDAAqD;AACrD,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,iBAAiB,CA2C/D"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
// `zfb/frontmatter` — public subpath for the frontmatter parser.
|
|
2
|
+
//
|
|
3
|
+
// BCI-3: `parseFrontmatter` lives in this dedicated subpath so consumers
|
|
4
|
+
// that only need frontmatter parsing can import it without pulling in
|
|
5
|
+
// `zfb/content`'s Node `fs` transitive dependency chain. Workers / edge
|
|
6
|
+
// bundlers reading user content from a CMS or KV store can therefore
|
|
7
|
+
// use this parser without bringing `node:fs/promises` into their bundle.
|
|
8
|
+
//
|
|
9
|
+
// The implementation lives directly in this module — `zfb/content`
|
|
10
|
+
// imports from here, not the other way around. Tests pin the absence of
|
|
11
|
+
// transitive `node:fs*` imports so a regression that re-introduces the
|
|
12
|
+
// fs dependency surfaces immediately.
|
|
13
|
+
//
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
// Minimal frontmatter parser. Intentionally NOT a full YAML implementation —
|
|
16
|
+
// the v0 surface accepts the subset documented below. This avoids pulling
|
|
17
|
+
// in `gray-matter` or `js-yaml` for what is, in v0, three field types:
|
|
18
|
+
//
|
|
19
|
+
// - `key: value` scalar (quoted strings unwrapped, ISO dates kept as strings)
|
|
20
|
+
// - `key:` followed by a block list of `- item` lines
|
|
21
|
+
// - blank lines and `#` comment lines are ignored
|
|
22
|
+
//
|
|
23
|
+
// Returns `{ data: {}, body: <input> }` unchanged when no frontmatter
|
|
24
|
+
// fence is present, or when the opening fence has no matching closer.
|
|
25
|
+
// ---------------------------------------------------------------------------
|
|
26
|
+
const FRONTMATTER_DELIM = "---";
|
|
27
|
+
/**
|
|
28
|
+
* Parse a leading YAML-ish frontmatter block off a markdown document.
|
|
29
|
+
*
|
|
30
|
+
* **Public SDK surface.** Re-exported from `zfb/content` so consumers can
|
|
31
|
+
* write their own custom content loaders without re-implementing the
|
|
32
|
+
* (deliberately minimal) v0 frontmatter parser. The accepted grammar is
|
|
33
|
+
* documented at the top of this module.
|
|
34
|
+
*
|
|
35
|
+
* Handles:
|
|
36
|
+
* - empty frontmatter (`---\n---\nbody`) → `{ data: {}, body: "body" }`
|
|
37
|
+
* - file ending exactly with `---` (no trailing newline) → frontmatter
|
|
38
|
+
* parsed, body is empty.
|
|
39
|
+
*
|
|
40
|
+
* Returns `{ data: {}, body: <input> }` unchanged when no frontmatter
|
|
41
|
+
* fence is present, or when the opening fence has no matching closer.
|
|
42
|
+
*/
|
|
43
|
+
export function parseFrontmatter(raw) {
|
|
44
|
+
// Strip a leading BOM and normalise line endings before splitting.
|
|
45
|
+
const text = raw.replace(/^/, "").replace(/\r\n/g, "\n");
|
|
46
|
+
if (!text.startsWith(`${FRONTMATTER_DELIM}\n`)) {
|
|
47
|
+
return { data: {}, body: text };
|
|
48
|
+
}
|
|
49
|
+
const headerStart = FRONTMATTER_DELIM.length + 1; // after first "---\n"
|
|
50
|
+
// Search for the closing fence. Accept either `\n---\n` (frontmatter
|
|
51
|
+
// followed by body) or `\n---` at the very end of the document
|
|
52
|
+
// (frontmatter with no trailing newline). Start the search at
|
|
53
|
+
// `headerStart - 1` so the empty-frontmatter case `---\n---\n...`
|
|
54
|
+
// is detected (the `\n---` at index 3 immediately follows the opener).
|
|
55
|
+
const searchFrom = headerStart - 1;
|
|
56
|
+
let closeIdx = -1;
|
|
57
|
+
let bodyStart = -1;
|
|
58
|
+
let i = searchFrom;
|
|
59
|
+
while (i <= text.length - `\n${FRONTMATTER_DELIM}`.length) {
|
|
60
|
+
const candidate = text.indexOf(`\n${FRONTMATTER_DELIM}`, i);
|
|
61
|
+
if (candidate === -1)
|
|
62
|
+
break;
|
|
63
|
+
const afterFence = candidate + `\n${FRONTMATTER_DELIM}`.length;
|
|
64
|
+
if (afterFence === text.length) {
|
|
65
|
+
// `\n---` at end-of-string — frontmatter ends here, body is empty.
|
|
66
|
+
closeIdx = candidate;
|
|
67
|
+
bodyStart = afterFence;
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
if (text.charAt(afterFence) === "\n") {
|
|
71
|
+
// `\n---\n` — body starts after the trailing newline.
|
|
72
|
+
closeIdx = candidate;
|
|
73
|
+
bodyStart = afterFence + 1;
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
// `\n---` followed by more `-` (e.g. `\n----`) — keep searching.
|
|
77
|
+
i = candidate + 1;
|
|
78
|
+
}
|
|
79
|
+
if (closeIdx === -1 || bodyStart === -1) {
|
|
80
|
+
// Malformed frontmatter (no closing delimiter): treat as plain body.
|
|
81
|
+
return { data: {}, body: text };
|
|
82
|
+
}
|
|
83
|
+
const header = text.slice(headerStart, closeIdx);
|
|
84
|
+
const body = text.slice(bodyStart);
|
|
85
|
+
return { data: parseFrontmatterHeader(header), body };
|
|
86
|
+
}
|
|
87
|
+
function parseFrontmatterHeader(header) {
|
|
88
|
+
const out = {};
|
|
89
|
+
const lines = header.split("\n");
|
|
90
|
+
let i = 0;
|
|
91
|
+
while (i < lines.length) {
|
|
92
|
+
const line = lines[i] ?? "";
|
|
93
|
+
if (line.trim() === "" || line.trimStart().startsWith("#")) {
|
|
94
|
+
i++;
|
|
95
|
+
continue;
|
|
96
|
+
}
|
|
97
|
+
// Top-level keys are unindented `key: value` or `key:` (then list).
|
|
98
|
+
const m = /^([A-Za-z_][\w-]*)\s*:\s*(.*)$/.exec(line);
|
|
99
|
+
if (!m) {
|
|
100
|
+
i++;
|
|
101
|
+
continue;
|
|
102
|
+
}
|
|
103
|
+
const key = m[1];
|
|
104
|
+
const inlineValue = (m[2] ?? "").trim();
|
|
105
|
+
if (inlineValue === "") {
|
|
106
|
+
// Possible block list.
|
|
107
|
+
const list = [];
|
|
108
|
+
let j = i + 1;
|
|
109
|
+
while (j < lines.length) {
|
|
110
|
+
const next = lines[j] ?? "";
|
|
111
|
+
const itemMatch = /^\s*-\s+(.*)$/.exec(next);
|
|
112
|
+
if (!itemMatch)
|
|
113
|
+
break;
|
|
114
|
+
list.push(unwrapScalar((itemMatch[1] ?? "").trim()));
|
|
115
|
+
j++;
|
|
116
|
+
}
|
|
117
|
+
if (list.length > 0) {
|
|
118
|
+
out[key] = list;
|
|
119
|
+
i = j;
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
// Empty value with no list — record empty string for completeness.
|
|
123
|
+
out[key] = "";
|
|
124
|
+
i++;
|
|
125
|
+
continue;
|
|
126
|
+
}
|
|
127
|
+
out[key] = unwrapScalar(inlineValue);
|
|
128
|
+
i++;
|
|
129
|
+
}
|
|
130
|
+
return out;
|
|
131
|
+
}
|
|
132
|
+
function unwrapScalar(value) {
|
|
133
|
+
if (value.length >= 2) {
|
|
134
|
+
const first = value.charAt(0);
|
|
135
|
+
const last = value.charAt(value.length - 1);
|
|
136
|
+
if ((first === '"' && last === '"') || (first === "'" && last === "'")) {
|
|
137
|
+
return value.slice(1, -1);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
return value;
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=frontmatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frontmatter.js","sourceRoot":"","sources":["../src/frontmatter.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { ANONYMOUS_COMPONENT_NAME, HYDRATE_MARKER_ATTR, Island, SKIP_SSR_MARKER_ATTR, resolveWhen, type IslandElement, type IslandProps, } from "./island.js";
|
|
2
|
+
export { scheduleHydrate, mountIslands, mountNewIslands, cancelPendingIslands, unmountIslands, } from "./runtime.js";
|
|
3
|
+
export type { IslandManifest, IslandManifestValue } from "./runtime.js";
|
|
4
|
+
export { DEFAULT_WHEN, isWhen, WHEN_VALUES, type When } from "./types.js";
|
|
5
|
+
export { definePlugin, type ZfbBuildHookContext, type ZfbDevMiddlewareContext, type ZfbDevMiddlewareHandler, type ZfbDevMiddlewareRequest, type ZfbDevMiddlewareResponse, type ZfbPlugin, type ZfbPluginLogger, } from "./plugins.js";
|
|
6
|
+
export { ContentBlockquote, ContentCode, ContentH2, ContentH3, ContentH4, ContentLink, ContentOl, ContentParagraph, ContentStrong, ContentTable, ContentUl, defaultComponents, type ContentComponentElement, type ContentComponentProps, } from "./content.js";
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAOA,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACnB,MAAM,EACN,oBAAoB,EACpB,WAAW,EACX,KAAK,aAAa,EAClB,KAAK,WAAW,GACjB,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,eAAe,EACf,YAAY,EACZ,eAAe,EACf,oBAAoB,EACpB,cAAc,GACf,MAAM,cAAc,CAAC;AACtB,YAAY,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,IAAI,EAAE,MAAM,YAAY,CAAC;AAW1E,OAAO,EACL,YAAY,EACZ,KAAK,mBAAmB,EACxB,KAAK,uBAAuB,EAC5B,KAAK,uBAAuB,EAC5B,KAAK,uBAAuB,EAC5B,KAAK,wBAAwB,EAC7B,KAAK,SAAS,EACd,KAAK,eAAe,GACrB,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,iBAAiB,EACjB,WAAW,EACX,SAAS,EACT,SAAS,EACT,SAAS,EACT,WAAW,EACX,SAAS,EACT,gBAAgB,EAChB,aAAa,EACb,YAAY,EACZ,SAAS,EACT,iBAAiB,EACjB,KAAK,uBAAuB,EAC5B,KAAK,qBAAqB,GAC3B,MAAM,cAAc,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Public entry point for the "@takazudo/zfb" package.
|
|
2
|
+
//
|
|
3
|
+
// User TSX pages reach this module via `import { Island } from "@takazudo/zfb"`.
|
|
4
|
+
// The hydration runtime (Sub 3) reaches the helper via
|
|
5
|
+
// `import { scheduleHydrate } from "@takazudo/zfb/runtime"` (or by inlining the
|
|
6
|
+
// same logic; coordinated separately).
|
|
7
|
+
export { ANONYMOUS_COMPONENT_NAME, HYDRATE_MARKER_ATTR, Island, SKIP_SSR_MARKER_ATTR, resolveWhen, } from "./island.js";
|
|
8
|
+
export { scheduleHydrate, mountIslands, mountNewIslands, cancelPendingIslands, unmountIslands, } from "./runtime.js";
|
|
9
|
+
export { DEFAULT_WHEN, isWhen, WHEN_VALUES } from "./types.js";
|
|
10
|
+
// `defaultComponents` (htmlOverrides convention) is re-exported from the
|
|
11
|
+
// root entry point so `import { defaultComponents } from "@takazudo/zfb"` is the
|
|
12
|
+
// canonical access path. Each named override is also re-exported so
|
|
13
|
+
// consumers can tree-shake-import a single one (`import { ContentLink } from "@takazudo/zfb"`)
|
|
14
|
+
// without dragging in the whole map.
|
|
15
|
+
// Plugin lifecycle types + `definePlugin` identity helper. Plugin
|
|
16
|
+
// authors typically import these from "@takazudo/zfb/plugins" but the
|
|
17
|
+
// root entry re-exports them so simple plugins can pull everything from
|
|
18
|
+
// one path.
|
|
19
|
+
export { definePlugin, } from "./plugins.js";
|
|
20
|
+
export { ContentBlockquote, ContentCode, ContentH2, ContentH3, ContentH4, ContentLink, ContentOl, ContentParagraph, ContentStrong, ContentTable, ContentUl, defaultComponents, } from "./content.js";
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,sDAAsD;AACtD,EAAE;AACF,iFAAiF;AACjF,uDAAuD;AACvD,gFAAgF;AAChF,uCAAuC;AAEvC,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACnB,MAAM,EACN,oBAAoB,EACpB,WAAW,GAGZ,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,eAAe,EACf,YAAY,EACZ,eAAe,EACf,oBAAoB,EACpB,cAAc,GACf,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW,EAAa,MAAM,YAAY,CAAC;AAE1E,yEAAyE;AACzE,iFAAiF;AACjF,oEAAoE;AACpE,+FAA+F;AAC/F,qCAAqC;AACrC,kEAAkE;AAClE,sEAAsE;AACtE,wEAAwE;AACxE,YAAY;AACZ,OAAO,EACL,YAAY,GAQb,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,iBAAiB,EACjB,WAAW,EACX,SAAS,EACT,SAAS,EACT,SAAS,EACT,WAAW,EACX,SAAS,EACT,gBAAgB,EAChB,aAAa,EACb,YAAY,EACZ,SAAS,EACT,iBAAiB,GAGlB,MAAM,cAAc,CAAC"}
|
package/dist/island.d.ts
ADDED
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import type { VNode } from "./jsx-types.js";
|
|
2
|
+
import { type When } from "./types.js";
|
|
3
|
+
export { resolveWhen } from "./types.js";
|
|
4
|
+
/**
|
|
5
|
+
* Marker attribute the SSR wrapper writes when the child component should
|
|
6
|
+
* be hydrated client-side. The hydration runtime queries
|
|
7
|
+
* `[data-${HYDRATE_MARKER_ATTR}]` to find islands.
|
|
8
|
+
*/
|
|
9
|
+
export declare const HYDRATE_MARKER_ATTR = "data-zfb-island";
|
|
10
|
+
/**
|
|
11
|
+
* Marker attribute the SSR wrapper writes when SSR is being skipped (the
|
|
12
|
+
* client:only-equivalent path). The hydration runtime queries
|
|
13
|
+
* `[data-${SKIP_SSR_MARKER_ATTR}]` to find these placeholders and renders
|
|
14
|
+
* the real component into them on hydration — there is no server output
|
|
15
|
+
* to patch up.
|
|
16
|
+
*/
|
|
17
|
+
export declare const SKIP_SSR_MARKER_ATTR = "data-zfb-island-skip-ssr";
|
|
18
|
+
/** Fallback name surfaced when child identity cannot be determined. */
|
|
19
|
+
export declare const ANONYMOUS_COMPONENT_NAME = "Anonymous";
|
|
20
|
+
/**
|
|
21
|
+
* Attribute the SSR wrapper writes to ferry the wrapped component's props
|
|
22
|
+
* across the SSR → hydrate boundary. The hydration runtime parses this
|
|
23
|
+
* with `JSON.parse` and forwards the result to the per-island `mount()`
|
|
24
|
+
* call so the hydrated component sees the same props the SSR pass did.
|
|
25
|
+
*
|
|
26
|
+
* Omitted entirely when the wrapped child has no own data props (other
|
|
27
|
+
* than `children`) — `readProps` already falls back to `{}` when the
|
|
28
|
+
* attribute is missing, and emitting `data-props=""` would just bloat
|
|
29
|
+
* the SSR markup.
|
|
30
|
+
*/
|
|
31
|
+
export declare const PROPS_DATA_ATTR = "data-props";
|
|
32
|
+
/** Props for `<Island>`. */
|
|
33
|
+
export interface IslandProps {
|
|
34
|
+
/** Hydration scheduling strategy. Defaults to `"load"`. */
|
|
35
|
+
when?: When;
|
|
36
|
+
/**
|
|
37
|
+
* If supplied, switches the island into SSR-skip mode (Astro's
|
|
38
|
+
* `client:only` equivalent). The wrapper emits the
|
|
39
|
+
* `data-zfb-island-skip-ssr` marker, the heavy `children` are **not**
|
|
40
|
+
* evaluated server-side, and `ssrFallback` is rendered in their place.
|
|
41
|
+
* On hydration the client runtime swaps in the real component.
|
|
42
|
+
*/
|
|
43
|
+
ssrFallback?: VNode;
|
|
44
|
+
/**
|
|
45
|
+
* Server-rendered children, hydrated client-side once `when` fires.
|
|
46
|
+
*
|
|
47
|
+
* Typed as `VNode` (structural union) rather than `ReactNode` so
|
|
48
|
+
* non-React frameworks can implement `IslandProps` without a React
|
|
49
|
+
* type dependency (BCI-4).
|
|
50
|
+
*/
|
|
51
|
+
children?: VNode;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Public JSX-element shape returned by [`Island`]. Intentionally widened
|
|
55
|
+
* to a structural type so consumers don't infer through the internal
|
|
56
|
+
* `{ type, props, key }` VNode shape of either Preact or React. Both
|
|
57
|
+
* jsx-runtimes accept this object on either side of the boundary.
|
|
58
|
+
*/
|
|
59
|
+
export type IslandElement = {
|
|
60
|
+
readonly type: string;
|
|
61
|
+
readonly props: Readonly<Record<string, unknown>>;
|
|
62
|
+
readonly key: unknown;
|
|
63
|
+
};
|
|
64
|
+
/**
|
|
65
|
+
* `<Island>` JSX wrapper.
|
|
66
|
+
*
|
|
67
|
+
* Returns a JSX element shape compatible with both Preact and React. The
|
|
68
|
+
* runtime tag is `"div"`. In the default (hydrate) mode the wrapper emits
|
|
69
|
+
* `data-zfb-island="ComponentName"` and `data-when="<resolved-when>"`. In
|
|
70
|
+
* SSR-skip mode (when `ssrFallback` is provided) it emits
|
|
71
|
+
* `data-zfb-island-skip-ssr="ComponentName"` instead and renders the
|
|
72
|
+
* fallback rather than the heavy child.
|
|
73
|
+
*
|
|
74
|
+
* The component-name string is derived from the child JSX element's type
|
|
75
|
+
* identity (`type.displayName ?? type.name`). For string-typed children
|
|
76
|
+
* (host elements) the tag name is used. If no usable identity can be
|
|
77
|
+
* recovered, [`ANONYMOUS_COMPONENT_NAME`] is used so the marker still
|
|
78
|
+
* lines up with the hydration shim's manifest lookup.
|
|
79
|
+
*
|
|
80
|
+
* The return type is the public [`IslandElement`] shape — the internal
|
|
81
|
+
* VNode structure is deliberately not leaked so consumers never type-infer
|
|
82
|
+
* through it.
|
|
83
|
+
*/
|
|
84
|
+
export declare function Island(props: IslandProps): IslandElement;
|
|
85
|
+
/**
|
|
86
|
+
* Pull a component-name string out of a JSX child.
|
|
87
|
+
*
|
|
88
|
+
* Both Preact and React store rendered VNodes as plain objects whose
|
|
89
|
+
* `.type` field is either:
|
|
90
|
+
* - the component function (look at `displayName ?? name`),
|
|
91
|
+
* - or the host element tag name as a string.
|
|
92
|
+
*
|
|
93
|
+
* If `children` is an array (multiple children), the first child with a
|
|
94
|
+
* usable identity wins. This is intentional: the typical island shape is
|
|
95
|
+
* `<Island><Foo /></Island>` (single child); when the caller wraps a
|
|
96
|
+
* fragment-like list we still want a deterministic, debuggable name.
|
|
97
|
+
*
|
|
98
|
+
* Exported for tests; not re-exported from `index.ts`.
|
|
99
|
+
*/
|
|
100
|
+
export declare function captureComponentName(children: unknown): string;
|
|
101
|
+
/**
|
|
102
|
+
* Serialize the wrapped child's data props as a JSON string the runtime
|
|
103
|
+
* can parse out of the `data-props` attribute on the Island marker div.
|
|
104
|
+
*
|
|
105
|
+
* Mirrors [`captureComponentName`]'s array handling: when `children` is
|
|
106
|
+
* an array (multiple JSX siblings), the first child whose own props
|
|
107
|
+
* yield a non-empty serialization wins. This keeps the "first
|
|
108
|
+
* identifiable child" contract consistent across both attributes —
|
|
109
|
+
* whatever the marker name points at is what the data-props payload
|
|
110
|
+
* describes.
|
|
111
|
+
*
|
|
112
|
+
* Returns `undefined` (not `"{}"` and not `""`) when no usable props
|
|
113
|
+
* exist. The runtime's `readProps` already maps a missing attribute to
|
|
114
|
+
* `{}`, so omitting the attribute keeps the SSR markup smaller and
|
|
115
|
+
* preserves the invariant that the attribute, when present, always
|
|
116
|
+
* parses to a non-empty record.
|
|
117
|
+
*
|
|
118
|
+
* Exported for tests; not re-exported from `index.ts`.
|
|
119
|
+
*/
|
|
120
|
+
export declare function captureSerializableProps(children: unknown): string | undefined;
|
|
121
|
+
//# sourceMappingURL=island.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"island.d.ts","sourceRoot":"","sources":["../src/island.ts"],"names":[],"mappings":"AA0CA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAe,KAAK,IAAI,EAAE,MAAM,YAAY,CAAC;AAMpD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC;;;;GAIG;AACH,eAAO,MAAM,mBAAmB,oBAAoB,CAAC;AAErD;;;;;;GAMG;AACH,eAAO,MAAM,oBAAoB,6BAA6B,CAAC;AAE/D,uEAAuE;AACvE,eAAO,MAAM,wBAAwB,cAAc,CAAC;AAEpD;;;;;;;;;;GAUG;AACH,eAAO,MAAM,eAAe,eAAe,CAAC;AAE5C,4BAA4B;AAC5B,MAAM,WAAW,WAAW;IAC1B,2DAA2D;IAC3D,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ;;;;;;OAMG;IACH,WAAW,CAAC,EAAE,KAAK,CAAC;IACpB;;;;;;OAMG;IACH,QAAQ,CAAC,EAAE,KAAK,CAAC;CAClB;AAED;;;;;GAKG;AACH,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IAClD,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,GAAG,aAAa,CAmCxD;AA2BD;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,OAAO,GAAG,MAAM,CAS9D;AAgBD;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAS9E"}
|
package/dist/island.js
ADDED
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
// Build-time `<Island when="...">` JSX wrapper.
|
|
2
|
+
//
|
|
3
|
+
// The wrapper is intentionally JSX-runtime-agnostic: it does not import
|
|
4
|
+
// preact or react and never calls h() / createElement directly. Instead it
|
|
5
|
+
// returns a plain object with a fixed shape that both Preact's and React's
|
|
6
|
+
// jsx-runtime accept when the JSX transform turns the call site into a
|
|
7
|
+
// jsx(Island, props) invocation.
|
|
8
|
+
//
|
|
9
|
+
// At build time, running through the SSR renderer (embedded V8 host):
|
|
10
|
+
//
|
|
11
|
+
// <Island when="visible"><Counter /></Island>
|
|
12
|
+
//
|
|
13
|
+
// renders as:
|
|
14
|
+
//
|
|
15
|
+
// <div data-zfb-island="Counter" data-when="visible">
|
|
16
|
+
// <Counter />
|
|
17
|
+
// </div>
|
|
18
|
+
//
|
|
19
|
+
// The component-name attribute (`data-zfb-island="ComponentName"`) is filled
|
|
20
|
+
// in *here* by reading the child's JSX type identity (`displayName` first,
|
|
21
|
+
// then `name`). Sub 3's hydration shim then `querySelectorAll`s these
|
|
22
|
+
// markers and looks each one up in the islands manifest produced by the
|
|
23
|
+
// scanner (see `crates/zfb-islands/src/manifest.rs` for the contract).
|
|
24
|
+
//
|
|
25
|
+
// SSR-skip mode: when the caller passes `ssrFallback`, the heavy child is
|
|
26
|
+
// **not** evaluated at SSR time. Instead the wrapper emits a different
|
|
27
|
+
// marker:
|
|
28
|
+
//
|
|
29
|
+
// <Island ssrFallback={<div>Loading…</div>}><HeavyClientOnly /></Island>
|
|
30
|
+
// →
|
|
31
|
+
// <div data-zfb-island-skip-ssr="HeavyClientOnly">
|
|
32
|
+
// <div>Loading…</div>
|
|
33
|
+
// </div>
|
|
34
|
+
//
|
|
35
|
+
// On the client the hydration runtime distinguishes hydrate vs. render by
|
|
36
|
+
// which marker attribute is present. This is the equivalent of Astro's
|
|
37
|
+
// `client:only="preact"`.
|
|
38
|
+
//
|
|
39
|
+
// When validation: in development we console.warn for unknown `when`
|
|
40
|
+
// values and fall back to the default. In production we silently fall
|
|
41
|
+
// back to keep the bundle path small.
|
|
42
|
+
import { resolveWhen } from "./types.js";
|
|
43
|
+
// Re-export `resolveWhen` for back-compat: tests and downstream consumers
|
|
44
|
+
// historically imported it from `./island.js`. The implementation lives in
|
|
45
|
+
// `./types.js` so the runtime scheduler can pull it in without dragging
|
|
46
|
+
// the JSX wrapper along for the ride.
|
|
47
|
+
export { resolveWhen } from "./types.js";
|
|
48
|
+
/**
|
|
49
|
+
* Marker attribute the SSR wrapper writes when the child component should
|
|
50
|
+
* be hydrated client-side. The hydration runtime queries
|
|
51
|
+
* `[data-${HYDRATE_MARKER_ATTR}]` to find islands.
|
|
52
|
+
*/
|
|
53
|
+
export const HYDRATE_MARKER_ATTR = "data-zfb-island";
|
|
54
|
+
/**
|
|
55
|
+
* Marker attribute the SSR wrapper writes when SSR is being skipped (the
|
|
56
|
+
* client:only-equivalent path). The hydration runtime queries
|
|
57
|
+
* `[data-${SKIP_SSR_MARKER_ATTR}]` to find these placeholders and renders
|
|
58
|
+
* the real component into them on hydration — there is no server output
|
|
59
|
+
* to patch up.
|
|
60
|
+
*/
|
|
61
|
+
export const SKIP_SSR_MARKER_ATTR = "data-zfb-island-skip-ssr";
|
|
62
|
+
/** Fallback name surfaced when child identity cannot be determined. */
|
|
63
|
+
export const ANONYMOUS_COMPONENT_NAME = "Anonymous";
|
|
64
|
+
/**
|
|
65
|
+
* Attribute the SSR wrapper writes to ferry the wrapped component's props
|
|
66
|
+
* across the SSR → hydrate boundary. The hydration runtime parses this
|
|
67
|
+
* with `JSON.parse` and forwards the result to the per-island `mount()`
|
|
68
|
+
* call so the hydrated component sees the same props the SSR pass did.
|
|
69
|
+
*
|
|
70
|
+
* Omitted entirely when the wrapped child has no own data props (other
|
|
71
|
+
* than `children`) — `readProps` already falls back to `{}` when the
|
|
72
|
+
* attribute is missing, and emitting `data-props=""` would just bloat
|
|
73
|
+
* the SSR markup.
|
|
74
|
+
*/
|
|
75
|
+
export const PROPS_DATA_ATTR = "data-props";
|
|
76
|
+
/**
|
|
77
|
+
* `<Island>` JSX wrapper.
|
|
78
|
+
*
|
|
79
|
+
* Returns a JSX element shape compatible with both Preact and React. The
|
|
80
|
+
* runtime tag is `"div"`. In the default (hydrate) mode the wrapper emits
|
|
81
|
+
* `data-zfb-island="ComponentName"` and `data-when="<resolved-when>"`. In
|
|
82
|
+
* SSR-skip mode (when `ssrFallback` is provided) it emits
|
|
83
|
+
* `data-zfb-island-skip-ssr="ComponentName"` instead and renders the
|
|
84
|
+
* fallback rather than the heavy child.
|
|
85
|
+
*
|
|
86
|
+
* The component-name string is derived from the child JSX element's type
|
|
87
|
+
* identity (`type.displayName ?? type.name`). For string-typed children
|
|
88
|
+
* (host elements) the tag name is used. If no usable identity can be
|
|
89
|
+
* recovered, [`ANONYMOUS_COMPONENT_NAME`] is used so the marker still
|
|
90
|
+
* lines up with the hydration shim's manifest lookup.
|
|
91
|
+
*
|
|
92
|
+
* The return type is the public [`IslandElement`] shape — the internal
|
|
93
|
+
* VNode structure is deliberately not leaked so consumers never type-infer
|
|
94
|
+
* through it.
|
|
95
|
+
*/
|
|
96
|
+
export function Island(props) {
|
|
97
|
+
const when = resolveWhen(props.when);
|
|
98
|
+
const componentName = captureComponentName(props.children);
|
|
99
|
+
const isSkipSsr = props.ssrFallback !== undefined;
|
|
100
|
+
// Always source props from `props.children` (the heavy component VNode),
|
|
101
|
+
// never from `ssrFallback` — the fallback is just SSR placeholder markup;
|
|
102
|
+
// the hydrated component is the child, so its props are what `mount()`
|
|
103
|
+
// needs at hydrate time. (Same rationale as `captureComponentName`.)
|
|
104
|
+
const dataProps = captureSerializableProps(props.children);
|
|
105
|
+
if (isSkipSsr) {
|
|
106
|
+
const skipSsrProps = {
|
|
107
|
+
[SKIP_SSR_MARKER_ATTR]: componentName,
|
|
108
|
+
"data-when": when,
|
|
109
|
+
children: props.ssrFallback ?? null,
|
|
110
|
+
};
|
|
111
|
+
if (dataProps !== undefined)
|
|
112
|
+
skipSsrProps[PROPS_DATA_ATTR] = dataProps;
|
|
113
|
+
return makeVNode({
|
|
114
|
+
type: "div",
|
|
115
|
+
props: skipSsrProps,
|
|
116
|
+
key: null,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
const hydrateProps = {
|
|
120
|
+
[HYDRATE_MARKER_ATTR]: componentName,
|
|
121
|
+
"data-when": when,
|
|
122
|
+
children: props.children,
|
|
123
|
+
};
|
|
124
|
+
if (dataProps !== undefined)
|
|
125
|
+
hydrateProps[PROPS_DATA_ATTR] = dataProps;
|
|
126
|
+
return makeVNode({
|
|
127
|
+
type: "div",
|
|
128
|
+
props: hydrateProps,
|
|
129
|
+
key: null,
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Construct the structural JSX-element shape with `constructor` set to
|
|
134
|
+
* `undefined`.
|
|
135
|
+
*
|
|
136
|
+
* Why: `preact-render-to-string` (and Preact's diff path) recognise a
|
|
137
|
+
* VNode by checking `vnode.constructor === undefined`. A plain object
|
|
138
|
+
* literal `{ type, props, key }` inherits `Object` for `.constructor`,
|
|
139
|
+
* so the renderer treats it as foreign data and emits no markup —
|
|
140
|
+
* which would silently strip every `<Island>` from SSG output. Marking
|
|
141
|
+
* `constructor: undefined` is the documented sentinel that both
|
|
142
|
+
* Preact's and React's renderers treat as a structural VNode.
|
|
143
|
+
*
|
|
144
|
+
* The cast back to `IslandElement` keeps the public type tight; the
|
|
145
|
+
* extra runtime field is JS-only and is invisible to type consumers.
|
|
146
|
+
*/
|
|
147
|
+
function makeVNode(shape) {
|
|
148
|
+
const v = shape;
|
|
149
|
+
v.constructor = undefined;
|
|
150
|
+
return shape;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Pull a component-name string out of a JSX child.
|
|
154
|
+
*
|
|
155
|
+
* Both Preact and React store rendered VNodes as plain objects whose
|
|
156
|
+
* `.type` field is either:
|
|
157
|
+
* - the component function (look at `displayName ?? name`),
|
|
158
|
+
* - or the host element tag name as a string.
|
|
159
|
+
*
|
|
160
|
+
* If `children` is an array (multiple children), the first child with a
|
|
161
|
+
* usable identity wins. This is intentional: the typical island shape is
|
|
162
|
+
* `<Island><Foo /></Island>` (single child); when the caller wraps a
|
|
163
|
+
* fragment-like list we still want a deterministic, debuggable name.
|
|
164
|
+
*
|
|
165
|
+
* Exported for tests; not re-exported from `index.ts`.
|
|
166
|
+
*/
|
|
167
|
+
export function captureComponentName(children) {
|
|
168
|
+
if (Array.isArray(children)) {
|
|
169
|
+
for (const child of children) {
|
|
170
|
+
const name = nameFromSingle(child);
|
|
171
|
+
if (name)
|
|
172
|
+
return name;
|
|
173
|
+
}
|
|
174
|
+
return ANONYMOUS_COMPONENT_NAME;
|
|
175
|
+
}
|
|
176
|
+
return nameFromSingle(children) || ANONYMOUS_COMPONENT_NAME;
|
|
177
|
+
}
|
|
178
|
+
function nameFromSingle(child) {
|
|
179
|
+
if (!child || typeof child !== "object")
|
|
180
|
+
return "";
|
|
181
|
+
const c = child;
|
|
182
|
+
const t = c.type;
|
|
183
|
+
if (typeof t === "function") {
|
|
184
|
+
const fn = t;
|
|
185
|
+
if (typeof fn.displayName === "string" && fn.displayName)
|
|
186
|
+
return fn.displayName;
|
|
187
|
+
if (typeof fn.name === "string" && fn.name)
|
|
188
|
+
return fn.name;
|
|
189
|
+
return "";
|
|
190
|
+
}
|
|
191
|
+
if (typeof t === "string" && t)
|
|
192
|
+
return t;
|
|
193
|
+
return "";
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Serialize the wrapped child's data props as a JSON string the runtime
|
|
197
|
+
* can parse out of the `data-props` attribute on the Island marker div.
|
|
198
|
+
*
|
|
199
|
+
* Mirrors [`captureComponentName`]'s array handling: when `children` is
|
|
200
|
+
* an array (multiple JSX siblings), the first child whose own props
|
|
201
|
+
* yield a non-empty serialization wins. This keeps the "first
|
|
202
|
+
* identifiable child" contract consistent across both attributes —
|
|
203
|
+
* whatever the marker name points at is what the data-props payload
|
|
204
|
+
* describes.
|
|
205
|
+
*
|
|
206
|
+
* Returns `undefined` (not `"{}"` and not `""`) when no usable props
|
|
207
|
+
* exist. The runtime's `readProps` already maps a missing attribute to
|
|
208
|
+
* `{}`, so omitting the attribute keeps the SSR markup smaller and
|
|
209
|
+
* preserves the invariant that the attribute, when present, always
|
|
210
|
+
* parses to a non-empty record.
|
|
211
|
+
*
|
|
212
|
+
* Exported for tests; not re-exported from `index.ts`.
|
|
213
|
+
*/
|
|
214
|
+
export function captureSerializableProps(children) {
|
|
215
|
+
if (Array.isArray(children)) {
|
|
216
|
+
for (const child of children) {
|
|
217
|
+
const json = propsFromSingle(child);
|
|
218
|
+
if (json !== undefined)
|
|
219
|
+
return json;
|
|
220
|
+
}
|
|
221
|
+
return undefined;
|
|
222
|
+
}
|
|
223
|
+
return propsFromSingle(children);
|
|
224
|
+
}
|
|
225
|
+
function propsFromSingle(child) {
|
|
226
|
+
if (!child || typeof child !== "object")
|
|
227
|
+
return undefined;
|
|
228
|
+
const c = child;
|
|
229
|
+
const raw = c.props;
|
|
230
|
+
if (!raw || typeof raw !== "object" || Array.isArray(raw))
|
|
231
|
+
return undefined;
|
|
232
|
+
// Exclude `children` from the serialized payload: the SSR pass already
|
|
233
|
+
// emitted the rendered children into the DOM (the hydration target),
|
|
234
|
+
// and JSX child nodes are typically VNode trees with non-serializable
|
|
235
|
+
// shapes (functions, circular refs) that would either bloat the
|
|
236
|
+
// payload or throw inside JSON.stringify. The hydration runtime
|
|
237
|
+
// re-renders into the existing DOM, so it does not need the JSX
|
|
238
|
+
// children replayed through props.
|
|
239
|
+
//
|
|
240
|
+
// Note: JSON.stringify already silently drops function / symbol /
|
|
241
|
+
// undefined values from the output, so those don't need explicit
|
|
242
|
+
// pre-filtering here.
|
|
243
|
+
const propsRecord = raw;
|
|
244
|
+
let hasOwn = false;
|
|
245
|
+
const filtered = {};
|
|
246
|
+
for (const key of Object.keys(propsRecord)) {
|
|
247
|
+
if (key === "children")
|
|
248
|
+
continue;
|
|
249
|
+
filtered[key] = propsRecord[key];
|
|
250
|
+
hasOwn = true;
|
|
251
|
+
}
|
|
252
|
+
if (!hasOwn)
|
|
253
|
+
return undefined;
|
|
254
|
+
let json;
|
|
255
|
+
try {
|
|
256
|
+
json = JSON.stringify(filtered);
|
|
257
|
+
}
|
|
258
|
+
catch {
|
|
259
|
+
// Circular references, BigInt, or any other non-serializable input
|
|
260
|
+
// — silently fall through (no `data-props`) rather than ship a
|
|
261
|
+
// partial payload. The runtime already handles the missing-attribute
|
|
262
|
+
// case by returning `{}` from `readProps`.
|
|
263
|
+
return undefined;
|
|
264
|
+
}
|
|
265
|
+
// JSON.stringify can also return `undefined` (when the top-level value
|
|
266
|
+
// serializes to nothing) or `"{}"` (when every key was a function /
|
|
267
|
+
// symbol / undefined and got dropped). Treat both as "nothing useful
|
|
268
|
+
// to ship" so the marker stays clean.
|
|
269
|
+
if (json === undefined || json === "{}")
|
|
270
|
+
return undefined;
|
|
271
|
+
return json;
|
|
272
|
+
}
|
|
273
|
+
//# sourceMappingURL=island.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"island.js","sourceRoot":"","sources":["../src/island.ts"],"names":[],"mappings":"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"}
|