speexjs 0.2.0
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/README.md +555 -0
- package/dist/cli/index.d.ts +1 -0
- package/dist/cli/index.js +1017 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/client/index.d.ts +73 -0
- package/dist/client/index.js +927 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/signals/index.d.ts +62 -0
- package/dist/client/signals/index.js +248 -0
- package/dist/client/signals/index.js.map +1 -0
- package/dist/client/vdom/index.d.ts +50 -0
- package/dist/client/vdom/index.js +540 -0
- package/dist/client/vdom/index.js.map +1 -0
- package/dist/client/vdom/jsx-runtime.d.ts +9 -0
- package/dist/client/vdom/jsx-runtime.js +203 -0
- package/dist/client/vdom/jsx-runtime.js.map +1 -0
- package/dist/index-CMkhSDh7.d.ts +97 -0
- package/dist/index.d.ts +18 -0
- package/dist/index.js +6402 -0
- package/dist/index.js.map +1 -0
- package/dist/jsx-DGrnv8QB.d.ts +8 -0
- package/dist/response-Ca8KWK5_.d.ts +173 -0
- package/dist/rpc/index.d.ts +70 -0
- package/dist/rpc/index.js +136 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/schema/index.d.ts +231 -0
- package/dist/schema/index.js +1160 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/server/auth/index.d.ts +61 -0
- package/dist/server/auth/index.js +462 -0
- package/dist/server/auth/index.js.map +1 -0
- package/dist/server/cache/index.d.ts +45 -0
- package/dist/server/cache/index.js +238 -0
- package/dist/server/cache/index.js.map +1 -0
- package/dist/server/container/index.d.ts +20 -0
- package/dist/server/container/index.js +62 -0
- package/dist/server/container/index.js.map +1 -0
- package/dist/server/controller/index.d.ts +37 -0
- package/dist/server/controller/index.js +139 -0
- package/dist/server/controller/index.js.map +1 -0
- package/dist/server/database/index.d.ts +461 -0
- package/dist/server/database/index.js +1977 -0
- package/dist/server/database/index.js.map +1 -0
- package/dist/server/events/index.d.ts +29 -0
- package/dist/server/events/index.js +159 -0
- package/dist/server/events/index.js.map +1 -0
- package/dist/server/gate/index.d.ts +36 -0
- package/dist/server/gate/index.js +169 -0
- package/dist/server/gate/index.js.map +1 -0
- package/dist/server/http/index.d.ts +45 -0
- package/dist/server/http/index.js +871 -0
- package/dist/server/http/index.js.map +1 -0
- package/dist/server/index.d.ts +79 -0
- package/dist/server/index.js +4185 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/middleware/index.d.ts +5 -0
- package/dist/server/middleware/index.js +416 -0
- package/dist/server/middleware/index.js.map +1 -0
- package/dist/server/router/index.d.ts +5 -0
- package/dist/server/router/index.js +231 -0
- package/dist/server/router/index.js.map +1 -0
- package/dist/server/storage/index.d.ts +66 -0
- package/dist/server/storage/index.js +244 -0
- package/dist/server/storage/index.js.map +1 -0
- package/dist/session-guard-CZeN87L9.d.ts +48 -0
- package/dist/types-CXH8hPei.d.ts +38 -0
- package/package.json +138 -0
|
@@ -0,0 +1,540 @@
|
|
|
1
|
+
// src/client/signals/index.ts
|
|
2
|
+
var activeTracker = null;
|
|
3
|
+
var activeSources = null;
|
|
4
|
+
var batchDepth = 0;
|
|
5
|
+
var pendingUpdates = /* @__PURE__ */ new Set();
|
|
6
|
+
function trackSource(node) {
|
|
7
|
+
if (activeSources) activeSources.add(node);
|
|
8
|
+
if (activeTracker) node._subs.add(activeTracker);
|
|
9
|
+
}
|
|
10
|
+
var Signal = class {
|
|
11
|
+
_tag = "signal";
|
|
12
|
+
_subs = /* @__PURE__ */ new Set();
|
|
13
|
+
_value;
|
|
14
|
+
constructor(value) {
|
|
15
|
+
this._value = value;
|
|
16
|
+
}
|
|
17
|
+
get value() {
|
|
18
|
+
trackSource(this);
|
|
19
|
+
return this._value;
|
|
20
|
+
}
|
|
21
|
+
set value(val) {
|
|
22
|
+
if (val !== this._value) {
|
|
23
|
+
this._value = val;
|
|
24
|
+
this._notify();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
peek() {
|
|
28
|
+
return this._value;
|
|
29
|
+
}
|
|
30
|
+
set(v) {
|
|
31
|
+
this.value = v;
|
|
32
|
+
}
|
|
33
|
+
update(fn) {
|
|
34
|
+
this.value = fn(this._value);
|
|
35
|
+
}
|
|
36
|
+
subscribe(fn) {
|
|
37
|
+
const cb = () => fn(this._value);
|
|
38
|
+
this._subs.add(cb);
|
|
39
|
+
return () => this._subs.delete(cb);
|
|
40
|
+
}
|
|
41
|
+
toJSON() {
|
|
42
|
+
return this._value;
|
|
43
|
+
}
|
|
44
|
+
toString() {
|
|
45
|
+
return String(this._value);
|
|
46
|
+
}
|
|
47
|
+
valueOf() {
|
|
48
|
+
return this._value;
|
|
49
|
+
}
|
|
50
|
+
*[Symbol.iterator]() {
|
|
51
|
+
yield this._value;
|
|
52
|
+
}
|
|
53
|
+
_notify() {
|
|
54
|
+
if (batchDepth > 0) {
|
|
55
|
+
for (const s of this._subs) pendingUpdates.add(s);
|
|
56
|
+
} else {
|
|
57
|
+
const subs = [...this._subs];
|
|
58
|
+
for (const s of subs) s();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
var Computed = class {
|
|
63
|
+
_tag = "computed";
|
|
64
|
+
_subs = /* @__PURE__ */ new Set();
|
|
65
|
+
_fn;
|
|
66
|
+
_value;
|
|
67
|
+
_dirty = true;
|
|
68
|
+
_sources = /* @__PURE__ */ new Set();
|
|
69
|
+
_onDepChange = () => {
|
|
70
|
+
if (!this._dirty) {
|
|
71
|
+
this._dirty = true;
|
|
72
|
+
for (const s of [...this._subs]) s();
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
constructor(fn) {
|
|
76
|
+
this._fn = fn;
|
|
77
|
+
}
|
|
78
|
+
get value() {
|
|
79
|
+
trackSource(this);
|
|
80
|
+
if (this._dirty) this._eval();
|
|
81
|
+
return this._value;
|
|
82
|
+
}
|
|
83
|
+
peek() {
|
|
84
|
+
if (this._dirty) this._eval();
|
|
85
|
+
return this._value;
|
|
86
|
+
}
|
|
87
|
+
subscribe(fn) {
|
|
88
|
+
this.value;
|
|
89
|
+
const cb = () => fn(this._value);
|
|
90
|
+
this._subs.add(cb);
|
|
91
|
+
return () => this._subs.delete(cb);
|
|
92
|
+
}
|
|
93
|
+
toJSON() {
|
|
94
|
+
return this.value;
|
|
95
|
+
}
|
|
96
|
+
toString() {
|
|
97
|
+
return String(this.value);
|
|
98
|
+
}
|
|
99
|
+
valueOf() {
|
|
100
|
+
return this.value;
|
|
101
|
+
}
|
|
102
|
+
_eval() {
|
|
103
|
+
for (const src of this._sources) {
|
|
104
|
+
src._subs.delete(this._onDepChange);
|
|
105
|
+
}
|
|
106
|
+
this._sources.clear();
|
|
107
|
+
this._dirty = false;
|
|
108
|
+
const prevSources = activeSources;
|
|
109
|
+
const prevTracker = activeTracker;
|
|
110
|
+
activeSources = /* @__PURE__ */ new Set();
|
|
111
|
+
activeTracker = null;
|
|
112
|
+
try {
|
|
113
|
+
this._value = this._fn();
|
|
114
|
+
this._sources = activeSources;
|
|
115
|
+
} finally {
|
|
116
|
+
activeSources = prevSources;
|
|
117
|
+
activeTracker = prevTracker;
|
|
118
|
+
}
|
|
119
|
+
for (const src of this._sources) {
|
|
120
|
+
src._subs.add(this._onDepChange);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
// src/client/vdom/index.ts
|
|
126
|
+
var VOID_ELEMENTS = /* @__PURE__ */ new Set([
|
|
127
|
+
"area",
|
|
128
|
+
"base",
|
|
129
|
+
"br",
|
|
130
|
+
"col",
|
|
131
|
+
"embed",
|
|
132
|
+
"hr",
|
|
133
|
+
"img",
|
|
134
|
+
"input",
|
|
135
|
+
"link",
|
|
136
|
+
"meta",
|
|
137
|
+
"param",
|
|
138
|
+
"source",
|
|
139
|
+
"track",
|
|
140
|
+
"wbr"
|
|
141
|
+
]);
|
|
142
|
+
var SVG_ELEMENTS = /* @__PURE__ */ new Set([
|
|
143
|
+
"svg",
|
|
144
|
+
"path",
|
|
145
|
+
"circle",
|
|
146
|
+
"rect",
|
|
147
|
+
"g",
|
|
148
|
+
"text",
|
|
149
|
+
"line",
|
|
150
|
+
"polyline",
|
|
151
|
+
"polygon",
|
|
152
|
+
"ellipse",
|
|
153
|
+
"use",
|
|
154
|
+
"defs",
|
|
155
|
+
"clipPath",
|
|
156
|
+
"mask",
|
|
157
|
+
"linearGradient",
|
|
158
|
+
"radialGradient",
|
|
159
|
+
"stop",
|
|
160
|
+
"tspan",
|
|
161
|
+
"textPath",
|
|
162
|
+
"image",
|
|
163
|
+
"foreignObject",
|
|
164
|
+
"marker",
|
|
165
|
+
"pattern",
|
|
166
|
+
"symbol",
|
|
167
|
+
"filter",
|
|
168
|
+
"feBlend",
|
|
169
|
+
"feColorMatrix",
|
|
170
|
+
"feComponentTransfer",
|
|
171
|
+
"feComposite",
|
|
172
|
+
"feDropShadow",
|
|
173
|
+
"feFlood",
|
|
174
|
+
"feGaussianBlur",
|
|
175
|
+
"feMerge",
|
|
176
|
+
"feOffset",
|
|
177
|
+
"feImage",
|
|
178
|
+
"feTile",
|
|
179
|
+
"feTurbulence"
|
|
180
|
+
]);
|
|
181
|
+
function isSignal(val) {
|
|
182
|
+
return val instanceof Signal;
|
|
183
|
+
}
|
|
184
|
+
function isComputed(val) {
|
|
185
|
+
return val instanceof Computed;
|
|
186
|
+
}
|
|
187
|
+
function normalizeChild(child) {
|
|
188
|
+
if (child == null || typeof child === "boolean") return null;
|
|
189
|
+
if (isSignal(child) || isComputed(child)) {
|
|
190
|
+
return { type: "signal", signal: child };
|
|
191
|
+
}
|
|
192
|
+
if (typeof child === "string" || typeof child === "number") {
|
|
193
|
+
return { type: "text", text: String(child) };
|
|
194
|
+
}
|
|
195
|
+
if (Array.isArray(child)) {
|
|
196
|
+
const children = child.flat(Infinity).map(normalizeChild).filter(Boolean);
|
|
197
|
+
if (children.length === 0) return null;
|
|
198
|
+
if (children.length === 1) return children[0];
|
|
199
|
+
return { type: "fragment", children };
|
|
200
|
+
}
|
|
201
|
+
if (typeof child === "object" && child !== null && "type" in child) {
|
|
202
|
+
return child;
|
|
203
|
+
}
|
|
204
|
+
if (typeof child === "function") {
|
|
205
|
+
return { type: "component", component: child, props: {} };
|
|
206
|
+
}
|
|
207
|
+
return { type: "text", text: String(child) };
|
|
208
|
+
}
|
|
209
|
+
function h(tag, props, ...children) {
|
|
210
|
+
if (typeof tag === "function") {
|
|
211
|
+
const c = children.flat(Infinity).map(normalizeChild).filter(Boolean);
|
|
212
|
+
return {
|
|
213
|
+
type: "component",
|
|
214
|
+
component: tag,
|
|
215
|
+
props: { ...props || {}, children: c.length > 0 ? c : void 0 }
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
return {
|
|
219
|
+
type: "element",
|
|
220
|
+
tag,
|
|
221
|
+
props: props || {},
|
|
222
|
+
children: children.flat(Infinity).map(normalizeChild).filter(Boolean),
|
|
223
|
+
key: props?.key
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
function fragment(...children) {
|
|
227
|
+
const flat = children.flat(Infinity);
|
|
228
|
+
const normalized = flat.map(normalizeChild).filter(Boolean);
|
|
229
|
+
if (normalized.length === 0) return { type: "text", text: "" };
|
|
230
|
+
if (normalized.length === 1) return normalized[0];
|
|
231
|
+
return { type: "fragment", children: normalized };
|
|
232
|
+
}
|
|
233
|
+
function text(content) {
|
|
234
|
+
return { type: "text", text: content };
|
|
235
|
+
}
|
|
236
|
+
function createComponent(type, props, ...children) {
|
|
237
|
+
const c = children.flat(Infinity).map(normalizeChild).filter(Boolean);
|
|
238
|
+
return {
|
|
239
|
+
type: "component",
|
|
240
|
+
component: type,
|
|
241
|
+
props: { ...props || {}, children: c.length > 0 ? c : void 0 }
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
function setProp(el, key, value, oldValue) {
|
|
245
|
+
if (key === "key" || key === "children" || key === "ref") return;
|
|
246
|
+
if (isComputed(value)) {
|
|
247
|
+
setProp(el, key, value.peek(), oldValue);
|
|
248
|
+
value.subscribe((v) => setProp(el, key, v));
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
if (key.startsWith("on") && typeof value === "function") {
|
|
252
|
+
const event = key.slice(2).toLowerCase();
|
|
253
|
+
if (oldValue) el.removeEventListener(event, oldValue);
|
|
254
|
+
el.addEventListener(event, value);
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
if (key === "style") {
|
|
258
|
+
if (typeof value === "string") {
|
|
259
|
+
el.setAttribute("style", value);
|
|
260
|
+
} else if (typeof value === "object" && value !== null) {
|
|
261
|
+
Object.assign(el.style, value);
|
|
262
|
+
}
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
265
|
+
if (key === "class" || key === "className") {
|
|
266
|
+
if (typeof value === "string") {
|
|
267
|
+
el.setAttribute("class", value);
|
|
268
|
+
} else if (Array.isArray(value)) {
|
|
269
|
+
el.setAttribute("class", value.filter(Boolean).join(" "));
|
|
270
|
+
}
|
|
271
|
+
return;
|
|
272
|
+
}
|
|
273
|
+
if (key === "dangerouslySetInnerHTML" && typeof value === "object" && value?.__html) {
|
|
274
|
+
el.innerHTML = value.__html;
|
|
275
|
+
return;
|
|
276
|
+
}
|
|
277
|
+
if (key === "value" || key === "checked" || key === "disabled" || key === "selected") {
|
|
278
|
+
el[key] = value;
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
if (key === "htmlFor") {
|
|
282
|
+
el.setAttribute("for", value);
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
if (value === false || value === null || value === void 0) {
|
|
286
|
+
el.removeAttribute(key);
|
|
287
|
+
} else if (value === true) {
|
|
288
|
+
el.setAttribute(key, "");
|
|
289
|
+
} else {
|
|
290
|
+
el.setAttribute(key, String(value));
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
function removeProp(el, key, value) {
|
|
294
|
+
if (key === "key" || key === "children" || key === "ref") return;
|
|
295
|
+
if (key.startsWith("on") && typeof value === "function") {
|
|
296
|
+
el.removeEventListener(key.slice(2).toLowerCase(), value);
|
|
297
|
+
return;
|
|
298
|
+
}
|
|
299
|
+
if (key === "style") {
|
|
300
|
+
el.removeAttribute("style");
|
|
301
|
+
return;
|
|
302
|
+
}
|
|
303
|
+
if (key === "class" || key === "className") {
|
|
304
|
+
el.removeAttribute("class");
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
if (key === "value" || key === "checked" || key === "disabled") {
|
|
308
|
+
delete el[key];
|
|
309
|
+
return;
|
|
310
|
+
}
|
|
311
|
+
el.removeAttribute(key);
|
|
312
|
+
}
|
|
313
|
+
function createDOM(vnode) {
|
|
314
|
+
switch (vnode.type) {
|
|
315
|
+
case "element": {
|
|
316
|
+
const isSVG = SVG_ELEMENTS.has(vnode.tag);
|
|
317
|
+
const el = isSVG ? document.createElementNS("http://www.w3.org/2000/svg", vnode.tag) : document.createElement(vnode.tag);
|
|
318
|
+
for (const [key, value] of Object.entries(vnode.props)) {
|
|
319
|
+
if (key !== "key") setProp(el, key, value);
|
|
320
|
+
}
|
|
321
|
+
for (const child of vnode.children) {
|
|
322
|
+
el.appendChild(createDOM(child));
|
|
323
|
+
}
|
|
324
|
+
return el;
|
|
325
|
+
}
|
|
326
|
+
case "text":
|
|
327
|
+
return document.createTextNode(vnode.text);
|
|
328
|
+
case "fragment": {
|
|
329
|
+
const frag = document.createDocumentFragment();
|
|
330
|
+
for (const child of vnode.children) frag.appendChild(createDOM(child));
|
|
331
|
+
return frag;
|
|
332
|
+
}
|
|
333
|
+
case "component": {
|
|
334
|
+
const result = vnode.component(vnode.props);
|
|
335
|
+
if (result instanceof Promise) {
|
|
336
|
+
const placeholder = document.createComment(" async ");
|
|
337
|
+
result.then((resolved) => {
|
|
338
|
+
const node = createDOM(resolved);
|
|
339
|
+
placeholder.parentNode?.replaceChild(node, placeholder);
|
|
340
|
+
});
|
|
341
|
+
return placeholder;
|
|
342
|
+
}
|
|
343
|
+
return createDOM(result);
|
|
344
|
+
}
|
|
345
|
+
case "signal": {
|
|
346
|
+
const val = vnode.signal.value;
|
|
347
|
+
const v = normalizeChild(val);
|
|
348
|
+
const node = createDOM(v ?? text(""));
|
|
349
|
+
vnode.signal.subscribe((newVal) => {
|
|
350
|
+
const newV = normalizeChild(newVal);
|
|
351
|
+
if (newV && node.parentNode) {
|
|
352
|
+
const newNode = createDOM(newV);
|
|
353
|
+
node.parentNode.replaceChild(newNode, node);
|
|
354
|
+
}
|
|
355
|
+
});
|
|
356
|
+
return node;
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
function render(vnode, container) {
|
|
361
|
+
container.innerHTML = "";
|
|
362
|
+
container.appendChild(createDOM(vnode));
|
|
363
|
+
}
|
|
364
|
+
function isSameVNodeType(a, b) {
|
|
365
|
+
if (a.type !== b.type) return false;
|
|
366
|
+
if (a.type === "element" && b.type === "element") {
|
|
367
|
+
return a.tag === b.tag && a.key === b.key;
|
|
368
|
+
}
|
|
369
|
+
return true;
|
|
370
|
+
}
|
|
371
|
+
function patchProps(el, oldProps, newProps) {
|
|
372
|
+
const allKeys = /* @__PURE__ */ new Set([...Object.keys(oldProps), ...Object.keys(newProps)]);
|
|
373
|
+
for (const key of allKeys) {
|
|
374
|
+
if (key === "key" || key === "children") continue;
|
|
375
|
+
const oldVal = oldProps[key];
|
|
376
|
+
const newVal = newProps[key];
|
|
377
|
+
if (oldVal === newVal) continue;
|
|
378
|
+
if (newVal === void 0 || newVal === null) {
|
|
379
|
+
removeProp(el, key, oldVal);
|
|
380
|
+
} else {
|
|
381
|
+
setProp(el, key, newVal, oldVal);
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
function patchChildren(parent, oldChildren, newChildren) {
|
|
386
|
+
const maxLen = Math.max(oldChildren.length, newChildren.length);
|
|
387
|
+
for (let i = 0; i < maxLen; i++) {
|
|
388
|
+
const oldChild = oldChildren[i];
|
|
389
|
+
const newChild = newChildren[i];
|
|
390
|
+
const existingNode = parent.childNodes[i];
|
|
391
|
+
if (!oldChild && newChild) {
|
|
392
|
+
parent.appendChild(createDOM(newChild));
|
|
393
|
+
} else if (oldChild && !newChild) {
|
|
394
|
+
if (existingNode) parent.removeChild(existingNode);
|
|
395
|
+
} else if (oldChild && newChild) {
|
|
396
|
+
if (isSameVNodeType(oldChild, newChild)) {
|
|
397
|
+
patchVNode(existingNode ?? null, oldChild, newChild);
|
|
398
|
+
} else {
|
|
399
|
+
const newNode = createDOM(newChild);
|
|
400
|
+
parent.replaceChild(newNode, existingNode);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
function patchVNode(dom, oldVNode, newVNode) {
|
|
406
|
+
if (!dom) return;
|
|
407
|
+
if (oldVNode.type === "element" && newVNode.type === "element") {
|
|
408
|
+
patchProps(dom, oldVNode.props, newVNode.props);
|
|
409
|
+
patchChildren(dom, oldVNode.children, newVNode.children);
|
|
410
|
+
} else if (oldVNode.type === "text" && newVNode.type === "text") {
|
|
411
|
+
if (oldVNode.text !== newVNode.text) {
|
|
412
|
+
dom.textContent = newVNode.text;
|
|
413
|
+
}
|
|
414
|
+
} else if (oldVNode.type === "fragment" && newVNode.type === "fragment") {
|
|
415
|
+
patchChildren(dom.parentNode || dom, oldVNode.children, newVNode.children);
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
function patch(dom, oldVNode, newVNode) {
|
|
419
|
+
if (isSameVNodeType(oldVNode, newVNode)) {
|
|
420
|
+
patchVNode(dom, oldVNode, newVNode);
|
|
421
|
+
} else {
|
|
422
|
+
const parent = dom.parentNode;
|
|
423
|
+
if (parent) {
|
|
424
|
+
parent.replaceChild(createDOM(newVNode), dom);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
function hydrate(vnode, container) {
|
|
429
|
+
function hydrateNode(vn, node) {
|
|
430
|
+
if (vn.type === "element") {
|
|
431
|
+
const el = node;
|
|
432
|
+
for (const [key, value] of Object.entries(vn.props)) {
|
|
433
|
+
if (key.startsWith("on") && typeof value === "function") {
|
|
434
|
+
el.addEventListener(key.slice(2).toLowerCase(), value);
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
for (let i = 0; i < Math.min(vn.children.length, el.childNodes.length); i++) {
|
|
438
|
+
hydrateNode(vn.children[i], el.childNodes[i]);
|
|
439
|
+
}
|
|
440
|
+
} else if (vn.type === "component") {
|
|
441
|
+
const result = vn.component(vn.props);
|
|
442
|
+
if (!(result instanceof Promise)) hydrateNode(result, node);
|
|
443
|
+
} else if (vn.type === "signal") {
|
|
444
|
+
vn.signal.subscribe((newVal) => {
|
|
445
|
+
const newChild = normalizeChild(newVal);
|
|
446
|
+
if (newChild && node.parentNode) {
|
|
447
|
+
node.parentNode.replaceChild(createDOM(newChild), node);
|
|
448
|
+
}
|
|
449
|
+
});
|
|
450
|
+
}
|
|
451
|
+
}
|
|
452
|
+
if (container.firstChild) {
|
|
453
|
+
hydrateNode(vnode, container.firstChild);
|
|
454
|
+
} else {
|
|
455
|
+
render(vnode, container);
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
var ESCAPE_MAP = {
|
|
459
|
+
"&": "&",
|
|
460
|
+
"<": "<",
|
|
461
|
+
">": ">",
|
|
462
|
+
'"': """,
|
|
463
|
+
"'": "'"
|
|
464
|
+
};
|
|
465
|
+
function escapeHtml(str) {
|
|
466
|
+
return str.replace(/[&<>"']/g, (c) => ESCAPE_MAP[c] || c);
|
|
467
|
+
}
|
|
468
|
+
function renderProps(props) {
|
|
469
|
+
let out = "";
|
|
470
|
+
for (const [key, value] of Object.entries(props)) {
|
|
471
|
+
if (key === "key" || key === "children" || key === "ref") continue;
|
|
472
|
+
if (key.startsWith("on")) continue;
|
|
473
|
+
if (value === false || value === null || value === void 0) continue;
|
|
474
|
+
if (key === "style" && typeof value === "object") {
|
|
475
|
+
const styleStr = Object.entries(value).map(([k, v]) => `${k.replace(/[A-Z]/g, (m) => "-" + m.toLowerCase())}:${v}`).join(";");
|
|
476
|
+
out += ' style="' + escapeHtml(styleStr) + '"';
|
|
477
|
+
continue;
|
|
478
|
+
}
|
|
479
|
+
if (key === "class" || key === "className") {
|
|
480
|
+
const cls = Array.isArray(value) ? value.filter(Boolean).join(" ") : value;
|
|
481
|
+
out += ' class="' + escapeHtml(String(cls)) + '"';
|
|
482
|
+
continue;
|
|
483
|
+
}
|
|
484
|
+
if (key === "htmlFor") {
|
|
485
|
+
out += ' for="' + escapeHtml(String(value)) + '"';
|
|
486
|
+
continue;
|
|
487
|
+
}
|
|
488
|
+
if (value === true) {
|
|
489
|
+
out += " " + key;
|
|
490
|
+
} else {
|
|
491
|
+
out += " " + key + '="' + escapeHtml(String(value)) + '"';
|
|
492
|
+
}
|
|
493
|
+
}
|
|
494
|
+
return out;
|
|
495
|
+
}
|
|
496
|
+
function renderVNodeToString(vnode) {
|
|
497
|
+
switch (vnode.type) {
|
|
498
|
+
case "element": {
|
|
499
|
+
const children = vnode.children.map(renderVNodeToString).join("");
|
|
500
|
+
if (VOID_ELEMENTS.has(vnode.tag)) return "<" + vnode.tag + renderProps(vnode.props) + ">";
|
|
501
|
+
return "<" + vnode.tag + renderProps(vnode.props) + ">" + children + "</" + vnode.tag + ">";
|
|
502
|
+
}
|
|
503
|
+
case "text":
|
|
504
|
+
return escapeHtml(vnode.text);
|
|
505
|
+
case "fragment":
|
|
506
|
+
return vnode.children.map(renderVNodeToString).join("");
|
|
507
|
+
case "component": {
|
|
508
|
+
const result = vnode.component(vnode.props);
|
|
509
|
+
if (result instanceof Promise) throw new Error("Async components must use renderToStream or ServerRenderer");
|
|
510
|
+
return renderVNodeToString(result);
|
|
511
|
+
}
|
|
512
|
+
case "signal":
|
|
513
|
+
return renderVNodeToString(normalizeChild(vnode.signal.value) ?? text(""));
|
|
514
|
+
}
|
|
515
|
+
}
|
|
516
|
+
function renderToString(vnode) {
|
|
517
|
+
return renderVNodeToString(vnode);
|
|
518
|
+
}
|
|
519
|
+
function renderToStream(vnode) {
|
|
520
|
+
return new ReadableStream({
|
|
521
|
+
start(controller) {
|
|
522
|
+
const html = renderToString(vnode);
|
|
523
|
+
controller.enqueue(html);
|
|
524
|
+
controller.close();
|
|
525
|
+
}
|
|
526
|
+
});
|
|
527
|
+
}
|
|
528
|
+
export {
|
|
529
|
+
createComponent,
|
|
530
|
+
fragment,
|
|
531
|
+
h,
|
|
532
|
+
hydrate,
|
|
533
|
+
normalizeChild,
|
|
534
|
+
patch,
|
|
535
|
+
render,
|
|
536
|
+
renderToStream,
|
|
537
|
+
renderToString,
|
|
538
|
+
text
|
|
539
|
+
};
|
|
540
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/client/signals/index.ts","../../../src/client/vdom/index.ts"],"sourcesContent":["let activeTracker: (() => void) | null = null\nlet activeSources: Set<Subscribable> | null = null\nlet batchDepth = 0\nconst pendingUpdates = new Set<() => void>()\n\ninterface Subscribable {\n _subs: Set<() => void>\n}\n\nfunction flushPending(): void {\n const fns = [...pendingUpdates]\n pendingUpdates.clear()\n for (const fn of fns) fn()\n}\n\nfunction trackSource(node: Subscribable): void {\n if (activeSources) activeSources.add(node)\n if (activeTracker) node._subs.add(activeTracker)\n}\n\nexport class Signal<T> {\n readonly _tag = 'signal' as const\n _subs = new Set<() => void>()\n private _value: T\n\n constructor(value: T) {\n this._value = value\n }\n\n get value(): T {\n trackSource(this)\n return this._value\n }\n\n set value(val: T) {\n if (val !== this._value) {\n this._value = val\n this._notify()\n }\n }\n\n peek(): T {\n return this._value\n }\n\n set(v: T): void {\n this.value = v\n }\n\n update(fn: (v: T) => T): void {\n this.value = fn(this._value)\n }\n\n subscribe(fn: (val: T) => void): () => void {\n const cb = () => fn(this._value)\n this._subs.add(cb)\n return () => this._subs.delete(cb)\n }\n\n toJSON(): T {\n return this._value\n }\n\n toString(): string {\n return String(this._value)\n }\n\n valueOf(): T {\n return this._value\n }\n\n *[Symbol.iterator](): Iterator<T> {\n yield this._value\n }\n\n private _notify(): void {\n if (batchDepth > 0) {\n for (const s of this._subs) pendingUpdates.add(s)\n } else {\n const subs = [...this._subs]\n for (const s of subs) s()\n }\n }\n}\n\nexport class Computed<T> {\n readonly _tag = 'computed' as const\n _subs = new Set<() => void>()\n private _fn: () => T\n private _value!: T\n private _dirty = true\n private _sources = new Set<Subscribable>()\n\n private _onDepChange = (): void => {\n if (!this._dirty) {\n this._dirty = true\n for (const s of [...this._subs]) s()\n }\n }\n\n constructor(fn: () => T) {\n this._fn = fn\n }\n\n get value(): T {\n trackSource(this)\n if (this._dirty) this._eval()\n return this._value\n }\n\n peek(): T {\n if (this._dirty) this._eval()\n return this._value\n }\n\n subscribe(fn: (val: T) => void): () => void {\n this.value\n const cb = () => fn(this._value)\n this._subs.add(cb)\n return () => this._subs.delete(cb)\n }\n\n toJSON(): T {\n return this.value\n }\n\n toString(): string {\n return String(this.value)\n }\n\n valueOf(): T {\n return this.value\n }\n\n private _eval(): void {\n for (const src of this._sources) {\n src._subs.delete(this._onDepChange)\n }\n this._sources.clear()\n this._dirty = false\n\n const prevSources = activeSources\n const prevTracker = activeTracker\n activeSources = new Set()\n activeTracker = null\n try {\n this._value = this._fn()\n this._sources = activeSources\n } finally {\n activeSources = prevSources\n activeTracker = prevTracker\n }\n\n for (const src of this._sources) {\n src._subs.add(this._onDepChange)\n }\n }\n}\n\nexport class Effect {\n private _fn: () => void | (() => void)\n private _sources = new Set<Subscribable>()\n private _cleanup: (() => void) | undefined\n private _alive = true\n\n constructor(fn: () => void | (() => void)) {\n this._fn = fn\n this._run()\n }\n\n get alive(): boolean {\n return this._alive\n }\n\n stop(): void {\n if (!this._alive) return\n this._alive = false\n this._removeSubscriptions()\n if (this._cleanup) {\n this._cleanup()\n this._cleanup = undefined\n }\n }\n\n start(): void {\n if (this._alive) return\n this._alive = true\n this._run()\n }\n\n private _removeSubscriptions(): void {\n for (const src of this._sources) {\n src._subs.delete(this._run)\n }\n this._sources.clear()\n }\n\n private _run = (): void => {\n if (!this._alive) return\n this._removeSubscriptions()\n if (this._cleanup) {\n this._cleanup()\n this._cleanup = undefined\n }\n\n const prevTracker = activeTracker\n const prevSources = activeSources\n activeTracker = this._run\n activeSources = this._sources\n try {\n const result = this._fn()\n if (typeof result === 'function') {\n this._cleanup = result as () => void\n }\n } finally {\n activeTracker = prevTracker\n activeSources = prevSources\n }\n }\n}\n\nexport function signal<T>(initial: T): Signal<T> {\n return new Signal(initial)\n}\n\nexport function computed<T>(fn: () => T): Computed<T> {\n return new Computed(fn)\n}\n\nexport function effect(fn: () => void | (() => void)): Effect {\n return new Effect(fn)\n}\n\nexport function untracked<T>(fn: () => T): T {\n const prevTracker = activeTracker\n const prevSources = activeSources\n activeTracker = null\n activeSources = null\n try {\n return fn()\n } finally {\n activeTracker = prevTracker\n activeSources = prevSources\n }\n}\n\nexport function batch<T>(fn: () => T): T {\n batchDepth++\n try {\n return fn()\n } finally {\n batchDepth--\n if (batchDepth === 0) {\n flushPending()\n }\n }\n}\n\nexport function isSignal(val: unknown): val is Signal<unknown> {\n return val instanceof Signal\n}\n\nexport function isComputed(val: unknown): val is Computed<unknown> {\n return val instanceof Computed\n}\n\nexport function toSignal<T>(value: T | Signal<T>): Signal<T> {\n if (value instanceof Signal) return value\n return signal(value)\n}\n\nexport function mergeSignals<T extends Record<string, Signal<unknown>>>(signals: T): Signal<{ [K in keyof T]: T[K] extends Signal<infer V> ? V : never }> {\n return computed(() => {\n const result: Record<string, unknown> = {}\n for (const key of Object.keys(signals)) {\n result[key] = (signals as Record<string, Signal<unknown>>)[key]!.value\n }\n return result as { [K in keyof T]: T[K] extends Signal<infer V> ? V : never }\n }) as unknown as Signal<{ [K in keyof T]: T[K] extends Signal<infer V> ? V : never }>\n}\n\nexport { type Subscribable }\r\n","import { Signal, Computed } from '../signals/index.js'\r\nimport type { signal, computed, effect } from '../signals/index.js'\n\nexport type VNode = VElement | VText | VFragment | VComponent | VSignalNode\n\nexport interface VElement {\n type: 'element'\n tag: string\n props: Record<string, any>\n children: VNode[]\n key?: string\n}\n\nexport interface VText {\n type: 'text'\n text: string\n}\n\nexport interface VFragment {\n type: 'fragment'\n children: VNode[]\n}\n\nexport interface VComponent {\n type: 'component'\n component: Component\n props: Record<string, any>\n children?: VNode[]\n}\n\nexport interface VSignalNode {\n type: 'signal'\n signal: Signal<VNode>\n}\n\nexport interface Component {\n (props: Record<string, any>, context?: ComponentContext): VNode | Promise<VNode>\n}\n\nexport interface ComponentContext {\n signal: typeof signal\n computed: typeof computed\n effect: typeof effect\n props: Record<string, any>\n children?: VNode[]\n}\n\nconst VOID_ELEMENTS = new Set([\n 'area','base','br','col','embed','hr','img','input','link','meta',\n 'param','source','track','wbr',\n])\n\nconst SVG_ELEMENTS = new Set([\n 'svg','path','circle','rect','g','text','line','polyline','polygon',\n 'ellipse','use','defs','clipPath','mask','linearGradient','radialGradient',\n 'stop','tspan','textPath','image','foreignObject','marker','pattern',\n 'symbol','filter','feBlend','feColorMatrix','feComponentTransfer',\n 'feComposite','feDropShadow','feFlood','feGaussianBlur','feMerge',\n 'feOffset','feImage','feTile','feTurbulence',\n])\n\nfunction isSignal(val: unknown): val is Signal<any> {\n return val instanceof Signal\n}\n\nfunction isComputed(val: unknown): val is Computed<any> {\n return val instanceof Computed\n}\n\nexport function normalizeChild(child: any): VNode | null {\n if (child == null || typeof child === 'boolean') return null\n if (isSignal(child) || isComputed(child)) {\n return { type: 'signal', signal: child as unknown as Signal<VNode> }\n }\n if (typeof child === 'string' || typeof child === 'number') {\n return { type: 'text', text: String(child) }\n }\n if (Array.isArray(child)) {\n const children = child.flat(Infinity).map(normalizeChild).filter(Boolean) as VNode[]\r\n if (children.length === 0) return null\r\n if (children.length === 1) return children[0] as VNode\n return { type: 'fragment', children }\n }\n if (typeof child === 'object' && child !== null && 'type' in child) {\n return child as VNode\n }\n if (typeof child === 'function') {\n return { type: 'component', component: child as Component, props: {} }\n }\n return { type: 'text', text: String(child) }\n}\n\nexport function h(tag: string | Component, props?: any, ...children: any[]): VNode {\n if (typeof tag === 'function') {\n const c = children.flat(Infinity).map(normalizeChild).filter(Boolean) as VNode[]\n return {\n type: 'component',\n component: tag as Component,\n props: { ...(props || {}), children: c.length > 0 ? c : undefined },\n }\n }\n return {\n type: 'element',\n tag,\n props: props || {},\n children: children.flat(Infinity).map(normalizeChild).filter(Boolean) as VNode[],\n key: props?.key,\n }\n}\n\nexport function fragment(...children: any[]): VNode {\n const flat = children.flat(Infinity)\n const normalized = flat.map(normalizeChild).filter(Boolean) as VNode[]\n if (normalized.length === 0) return { type: 'text', text: '' }\n if (normalized.length === 1) return normalized[0]!\n return { type: 'fragment', children: normalized }\n}\n\nexport function text(content: string): VText {\n return { type: 'text', text: content }\n}\n\nexport function createComponent(type: Component, props?: any, ...children: any[]): VComponent {\n const c = children.flat(Infinity).map(normalizeChild).filter(Boolean) as VNode[]\n return {\n type: 'component',\n component: type,\n props: { ...(props || {}), children: c.length > 0 ? c : undefined },\n }\n}\n\nfunction setProp(el: Element, key: string, value: any, oldValue?: any): void {\r\n if (key === 'key' || key === 'children' || key === 'ref') return\r\n if (isComputed(value)) {\r\n setProp(el, key, value.peek(), oldValue)\r\n value.subscribe((v: any) => setProp(el, key, v))\r\n return\r\n }\r\n if (key.startsWith('on') && typeof value === 'function') {\n const event = key.slice(2).toLowerCase()\n if (oldValue) el.removeEventListener(event, oldValue)\n el.addEventListener(event, value)\n return\n }\n if (key === 'style') {\n if (typeof value === 'string') {\n el.setAttribute('style', value)\n } else if (typeof value === 'object' && value !== null) {\n Object.assign((el as HTMLElement).style, value)\n }\n return\n }\n if (key === 'class' || key === 'className') {\n if (typeof value === 'string') {\n el.setAttribute('class', value)\n } else if (Array.isArray(value)) {\n el.setAttribute('class', value.filter(Boolean).join(' '))\n }\n return\n }\n if (key === 'dangerouslySetInnerHTML' && typeof value === 'object' && value?.__html) {\n el.innerHTML = value.__html\n return\n }\n if (key === 'value' || key === 'checked' || key === 'disabled' || key === 'selected') {\n (el as any)[key] = value\n return\n }\n if (key === 'htmlFor') {\n el.setAttribute('for', value)\n return\n }\n if (value === false || value === null || value === undefined) {\n el.removeAttribute(key)\n } else if (value === true) {\n el.setAttribute(key, '')\n } else {\n el.setAttribute(key, String(value))\n }\n}\n\nfunction removeProp(el: Element, key: string, value: any): void {\n if (key === 'key' || key === 'children' || key === 'ref') return\n if (key.startsWith('on') && typeof value === 'function') {\n el.removeEventListener(key.slice(2).toLowerCase(), value)\n return\n }\n if (key === 'style') { el.removeAttribute('style'); return }\n if (key === 'class' || key === 'className') { el.removeAttribute('class'); return }\n if (key === 'value' || key === 'checked' || key === 'disabled') { delete (el as any)[key]; return }\n el.removeAttribute(key)\n}\n\nfunction createDOM(vnode: VNode): Node {\n switch (vnode.type) {\n case 'element': {\n const isSVG = SVG_ELEMENTS.has(vnode.tag)\n const el = isSVG\n ? document.createElementNS('http://www.w3.org/2000/svg', vnode.tag)\n : document.createElement(vnode.tag)\n for (const [key, value] of Object.entries(vnode.props)) {\n if (key !== 'key') setProp(el, key, value)\n }\n for (const child of vnode.children) {\n el.appendChild(createDOM(child))\n }\n return el\n }\n case 'text':\n return document.createTextNode(vnode.text)\n case 'fragment': {\n const frag = document.createDocumentFragment()\n for (const child of vnode.children) frag.appendChild(createDOM(child))\n return frag\n }\n case 'component': {\n const result = vnode.component(vnode.props)\n if (result instanceof Promise) {\n const placeholder = document.createComment(' async ')\n result.then((resolved) => {\n const node = createDOM(resolved)\n placeholder.parentNode?.replaceChild(node, placeholder)\n })\n return placeholder\n }\n return createDOM(result)\n }\n case 'signal': {\n const val = vnode.signal.value\n const v = normalizeChild(val)\n const node = createDOM(v ?? text(''))\n vnode.signal.subscribe((newVal: any) => {\n const newV = normalizeChild(newVal)\n if (newV && node.parentNode) {\n const newNode = createDOM(newV)\n node.parentNode.replaceChild(newNode, node)\n }\n })\n return node\n }\n }\n}\n\nexport function render(vnode: VNode, container: HTMLElement): void {\n container.innerHTML = ''\n container.appendChild(createDOM(vnode))\n}\n\nfunction isSameVNodeType(a: VNode, b: VNode): boolean {\n if (a.type !== b.type) return false\n if (a.type === 'element' && b.type === 'element') {\n return a.tag === b.tag && a.key === b.key\n }\n return true\n}\n\nfunction patchProps(el: Element, oldProps: Record<string, any>, newProps: Record<string, any>): void {\n const allKeys = new Set([...Object.keys(oldProps), ...Object.keys(newProps)])\n for (const key of allKeys) {\n if (key === 'key' || key === 'children') continue\n const oldVal = oldProps[key]\n const newVal = newProps[key]\n if (oldVal === newVal) continue\n if (newVal === undefined || newVal === null) {\n removeProp(el, key, oldVal)\n } else {\n setProp(el, key, newVal, oldVal)\n }\n }\n}\n\nfunction patchChildren(parent: Node, oldChildren: VNode[], newChildren: VNode[]): void {\n const maxLen = Math.max(oldChildren.length, newChildren.length)\n for (let i = 0; i < maxLen; i++) {\n const oldChild = oldChildren[i]\n const newChild = newChildren[i]\n const existingNode = parent.childNodes[i]\n if (!oldChild && newChild) {\n parent.appendChild(createDOM(newChild))\n } else if (oldChild && !newChild) {\n if (existingNode) parent.removeChild(existingNode)\n } else if (oldChild && newChild) {\r\n if (isSameVNodeType(oldChild, newChild)) {\r\n patchVNode(existingNode ?? null, oldChild, newChild)\r\n } else {\r\n const newNode = createDOM(newChild)\r\n parent.replaceChild(newNode, existingNode!)\n }\r\n }\r\n }\r\n}\r\n\r\nfunction patchVNode(dom: Node | null, oldVNode: VNode, newVNode: VNode): void {\n if (!dom) return\n if (oldVNode.type === 'element' && newVNode.type === 'element') {\n patchProps(dom as HTMLElement, oldVNode.props, newVNode.props)\n patchChildren(dom, oldVNode.children, newVNode.children)\n } else if (oldVNode.type === 'text' && newVNode.type === 'text') {\n if (oldVNode.text !== newVNode.text) {\n (dom as Text).textContent = newVNode.text\n }\n } else if (oldVNode.type === 'fragment' && newVNode.type === 'fragment') {\n patchChildren(dom.parentNode || dom, oldVNode.children, newVNode.children)\n }\n}\n\nexport function patch(dom: HTMLElement, oldVNode: VNode, newVNode: VNode): void {\n if (isSameVNodeType(oldVNode, newVNode)) {\n patchVNode(dom, oldVNode, newVNode)\n } else {\n const parent = dom.parentNode\n if (parent) {\n parent.replaceChild(createDOM(newVNode), dom)\n }\n }\n}\n\nexport function hydrate(vnode: VNode, container: HTMLElement): void {\n function hydrateNode(vn: VNode, node: Node): void {\n if (vn.type === 'element') {\n const el = node as HTMLElement\n for (const [key, value] of Object.entries(vn.props)) {\n if (key.startsWith('on') && typeof value === 'function') {\n el.addEventListener(key.slice(2).toLowerCase(), value)\n }\n }\n for (let i = 0; i < Math.min(vn.children.length, el.childNodes.length); i++) {\n hydrateNode(vn.children[i]!, el.childNodes[i]!)\n }\n } else if (vn.type === 'component') {\n const result = vn.component(vn.props)\n if (!(result instanceof Promise)) hydrateNode(result, node)\n } else if (vn.type === 'signal') {\n vn.signal.subscribe((newVal: any) => {\n const newChild = normalizeChild(newVal)\n if (newChild && node.parentNode) {\n node.parentNode.replaceChild(createDOM(newChild), node)\n }\n })\n }\n }\n if (container.firstChild) {\n hydrateNode(vnode, container.firstChild)\n } else {\n render(vnode, container)\n }\n}\n\nconst ESCAPE_MAP: Record<string, string> = {\n '&': '&', '<': '<', '>': '>', '\"': '"', \"'\": ''',\n}\n\nfunction escapeHtml(str: string): string {\n return str.replace(/[&<>\"']/g, (c) => ESCAPE_MAP[c] || c)\n}\n\nfunction renderProps(props: Record<string, any>): string {\n let out = ''\n for (const [key, value] of Object.entries(props)) {\n if (key === 'key' || key === 'children' || key === 'ref') continue\n if (key.startsWith('on')) continue\n if (value === false || value === null || value === undefined) continue\n if (key === 'style' && typeof value === 'object') {\n const styleStr = Object.entries(value)\n .map(([k, v]) => `${k.replace(/[A-Z]/g, (m) => '-' + m.toLowerCase())}:${v}`)\n .join(';')\n out += ' style=\"' + escapeHtml(styleStr) + '\"'\n continue\n }\n if (key === 'class' || key === 'className') {\n const cls = Array.isArray(value) ? value.filter(Boolean).join(' ') : value\n out += ' class=\"' + escapeHtml(String(cls)) + '\"'\n continue\n }\n if (key === 'htmlFor') { out += ' for=\"' + escapeHtml(String(value)) + '\"'; continue }\n if (value === true) { out += ' ' + key }\n else { out += ' ' + key + '=\"' + escapeHtml(String(value)) + '\"' }\n }\n return out\n}\n\nfunction renderVNodeToString(vnode: VNode): string {\n switch (vnode.type) {\n case 'element': {\n const children = vnode.children.map(renderVNodeToString).join('')\n if (VOID_ELEMENTS.has(vnode.tag)) return '<' + vnode.tag + renderProps(vnode.props) + '>'\n return '<' + vnode.tag + renderProps(vnode.props) + '>' + children + '</' + vnode.tag + '>'\n }\n case 'text': return escapeHtml(vnode.text)\n case 'fragment': return vnode.children.map(renderVNodeToString).join('')\n case 'component': {\n const result = vnode.component(vnode.props)\n if (result instanceof Promise) throw new Error('Async components must use renderToStream or ServerRenderer')\n return renderVNodeToString(result)\n }\n case 'signal': return renderVNodeToString(normalizeChild(vnode.signal.value) ?? text(''))\n }\n}\n\nexport function renderToString(vnode: VNode): string {\n return renderVNodeToString(vnode)\n}\n\nexport function renderToStream(vnode: VNode): ReadableStream<string> {\n return new ReadableStream({\n start(controller) {\n const html = renderToString(vnode)\n controller.enqueue(html)\n controller.close()\n },\n })\n}\r\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { VNode } from './index.js';
|
|
2
|
+
export { F as Fragment } from '../../jsx-DGrnv8QB.js';
|
|
3
|
+
import '../signals/index.js';
|
|
4
|
+
|
|
5
|
+
declare function jsx(tag: any, props: any, key?: string): VNode;
|
|
6
|
+
declare function jsxs(tag: any, props: any, key?: string): VNode;
|
|
7
|
+
declare function jsxDEV(tag: any, props: any, key?: string): VNode;
|
|
8
|
+
|
|
9
|
+
export { jsx, jsxDEV, jsxs };
|