ai-props 2.3.0 → 2.4.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/.turbo/turbo-build.log +4 -0
- package/CHANGELOG.md +9 -0
- package/dist/ai.d.ts +125 -0
- package/dist/ai.d.ts.map +1 -0
- package/dist/ai.js +199 -0
- package/dist/ai.js.map +1 -0
- package/dist/cache.d.ts +66 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +183 -0
- package/dist/cache.js.map +1 -0
- package/dist/cascade.d.ts +329 -0
- package/dist/cascade.d.ts.map +1 -0
- package/dist/cascade.js +522 -0
- package/dist/cascade.js.map +1 -0
- package/dist/client.d.ts +233 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +191 -0
- package/dist/client.js.map +1 -0
- package/dist/durable-cascade.d.ts +280 -0
- package/dist/durable-cascade.d.ts.map +1 -0
- package/dist/durable-cascade.js +469 -0
- package/dist/durable-cascade.js.map +1 -0
- package/dist/event-bridge.d.ts +257 -0
- package/dist/event-bridge.d.ts.map +1 -0
- package/dist/event-bridge.js +317 -0
- package/dist/event-bridge.js.map +1 -0
- package/dist/generate.d.ts +69 -0
- package/dist/generate.d.ts.map +1 -0
- package/dist/generate.js +227 -0
- package/dist/generate.js.map +1 -0
- package/dist/hoc.d.ts +164 -0
- package/dist/hoc.d.ts.map +1 -0
- package/dist/hoc.js +236 -0
- package/dist/hoc.js.map +1 -0
- package/dist/hono-jsx.d.ts +208 -0
- package/dist/hono-jsx.d.ts.map +1 -0
- package/dist/hono-jsx.js +459 -0
- package/dist/hono-jsx.js.map +1 -0
- package/dist/index.d.ts +16 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +23 -0
- package/dist/index.js.map +1 -0
- package/dist/mdx-types.d.ts +152 -0
- package/dist/mdx-types.d.ts.map +1 -0
- package/dist/mdx-types.js +9 -0
- package/dist/mdx-types.js.map +1 -0
- package/dist/mdx-utils.d.ts +106 -0
- package/dist/mdx-utils.d.ts.map +1 -0
- package/dist/mdx-utils.js +384 -0
- package/dist/mdx-utils.js.map +1 -0
- package/dist/mdx.d.ts +230 -0
- package/dist/mdx.d.ts.map +1 -0
- package/dist/mdx.js +820 -0
- package/dist/mdx.js.map +1 -0
- package/dist/rpc.d.ts +313 -0
- package/dist/rpc.d.ts.map +1 -0
- package/dist/rpc.js +359 -0
- package/dist/rpc.js.map +1 -0
- package/dist/streaming.d.ts +199 -0
- package/dist/streaming.d.ts.map +1 -0
- package/dist/streaming.js +402 -0
- package/dist/streaming.js.map +1 -0
- package/dist/types.d.ts +152 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/dist/types.js.map +1 -0
- package/dist/validate.d.ts +58 -0
- package/dist/validate.d.ts.map +1 -0
- package/dist/validate.js +251 -0
- package/dist/validate.js.map +1 -0
- package/dist/worker.d.ts +270 -0
- package/dist/worker.d.ts.map +1 -0
- package/dist/worker.js +405 -0
- package/dist/worker.js.map +1 -0
- package/package.json +4 -4
|
@@ -0,0 +1,402 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Optimized streaming utilities for AI-powered props rendering
|
|
3
|
+
*
|
|
4
|
+
* This module provides high-performance streaming capabilities with:
|
|
5
|
+
* - Adaptive chunk sizing for network efficiency
|
|
6
|
+
* - Backpressure handling to prevent memory overflow
|
|
7
|
+
* - Progress callbacks for streaming status
|
|
8
|
+
* - Memory-efficient streaming for large components
|
|
9
|
+
*
|
|
10
|
+
* @packageDocumentation
|
|
11
|
+
*/
|
|
12
|
+
import { renderToReadableStream as baseRenderToReadableStream, streamJSXResponse as baseStreamJSXResponse, createStreamingRenderer as baseCreateStreamingRenderer, createHydrationContext, serializeHydrationData, } from './hono-jsx.js';
|
|
13
|
+
import { streamMDXWithProps as baseStreamMDXWithProps } from './mdx.js';
|
|
14
|
+
// ============================================================================
|
|
15
|
+
// Constants
|
|
16
|
+
// ============================================================================
|
|
17
|
+
/** Default chunk size for optimal network performance (16KB) */
|
|
18
|
+
export const DEFAULT_CHUNK_SIZE = 16 * 1024;
|
|
19
|
+
/** Minimum chunk size to avoid excessive overhead (1KB) */
|
|
20
|
+
export const MIN_CHUNK_SIZE = 1024;
|
|
21
|
+
/** Maximum chunk size for memory efficiency (64KB) */
|
|
22
|
+
export const MAX_CHUNK_SIZE = 64 * 1024;
|
|
23
|
+
/** High water mark for backpressure (64KB) */
|
|
24
|
+
export const DEFAULT_HIGH_WATER_MARK = 64 * 1024;
|
|
25
|
+
// ============================================================================
|
|
26
|
+
// Utility Functions
|
|
27
|
+
// ============================================================================
|
|
28
|
+
/**
|
|
29
|
+
* Calculate optimal chunk size based on content size
|
|
30
|
+
*
|
|
31
|
+
* @param contentLength - Total content length in bytes
|
|
32
|
+
* @returns Optimal chunk size
|
|
33
|
+
*/
|
|
34
|
+
export function calculateOptimalChunkSize(contentLength) {
|
|
35
|
+
// For very small content, use minimum chunk size
|
|
36
|
+
if (contentLength < MIN_CHUNK_SIZE * 2) {
|
|
37
|
+
return MIN_CHUNK_SIZE;
|
|
38
|
+
}
|
|
39
|
+
// For medium content, use default
|
|
40
|
+
if (contentLength < MAX_CHUNK_SIZE * 4) {
|
|
41
|
+
return DEFAULT_CHUNK_SIZE;
|
|
42
|
+
}
|
|
43
|
+
// For large content, use larger chunks
|
|
44
|
+
return MAX_CHUNK_SIZE;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Create a progress tracker for streaming operations
|
|
48
|
+
*/
|
|
49
|
+
function createProgressTracker(totalBytes, onProgress) {
|
|
50
|
+
const startTime = Date.now();
|
|
51
|
+
return {
|
|
52
|
+
startTime,
|
|
53
|
+
update(bytesProcessed, chunksProcessed, phase) {
|
|
54
|
+
if (!onProgress)
|
|
55
|
+
return;
|
|
56
|
+
const elapsedMs = Date.now() - startTime;
|
|
57
|
+
const progress = {
|
|
58
|
+
bytesProcessed,
|
|
59
|
+
chunksProcessed,
|
|
60
|
+
phase,
|
|
61
|
+
elapsedMs,
|
|
62
|
+
};
|
|
63
|
+
if (totalBytes !== undefined) {
|
|
64
|
+
progress.totalBytes = totalBytes;
|
|
65
|
+
progress.percentComplete = Math.min(100, (bytesProcessed / totalBytes) * 100);
|
|
66
|
+
}
|
|
67
|
+
onProgress(progress);
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
// ============================================================================
|
|
72
|
+
// Core Streaming Functions
|
|
73
|
+
// ============================================================================
|
|
74
|
+
/**
|
|
75
|
+
* Render a component to a ReadableStream with optimizations
|
|
76
|
+
*
|
|
77
|
+
* Features:
|
|
78
|
+
* - Adaptive chunk sizing based on content
|
|
79
|
+
* - Backpressure handling to prevent memory overflow
|
|
80
|
+
* - Progress callbacks for monitoring
|
|
81
|
+
* - Memory-efficient streaming for large content
|
|
82
|
+
*
|
|
83
|
+
* @param component - Component function to render
|
|
84
|
+
* @param props - Props to pass to component
|
|
85
|
+
* @param options - Optimized streaming options
|
|
86
|
+
* @returns ReadableStream of rendered HTML
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* ```ts
|
|
90
|
+
* const stream = await renderToReadableStream(
|
|
91
|
+
* MyComponent,
|
|
92
|
+
* { title: 'Hello' },
|
|
93
|
+
* {
|
|
94
|
+
* chunkSize: 8192,
|
|
95
|
+
* onProgress: (progress) => console.log(`${progress.percentComplete}% complete`),
|
|
96
|
+
* }
|
|
97
|
+
* )
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export async function renderToReadableStream(component, props, options) {
|
|
101
|
+
const encoder = new TextEncoder();
|
|
102
|
+
const chunkSize = options?.chunkSize ?? DEFAULT_CHUNK_SIZE;
|
|
103
|
+
const highWaterMark = options?.highWaterMark ?? DEFAULT_HIGH_WATER_MARK;
|
|
104
|
+
// Create hydration context if needed
|
|
105
|
+
let hydrationContext = null;
|
|
106
|
+
if (options?.includeHydration) {
|
|
107
|
+
hydrationContext = createHydrationContext();
|
|
108
|
+
}
|
|
109
|
+
// Render the component
|
|
110
|
+
let content;
|
|
111
|
+
try {
|
|
112
|
+
content = await component(props);
|
|
113
|
+
}
|
|
114
|
+
catch (error) {
|
|
115
|
+
if (options?.onError && error instanceof Error) {
|
|
116
|
+
content = options.onError(error);
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
throw error;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
// Register for hydration
|
|
123
|
+
if (hydrationContext) {
|
|
124
|
+
const componentName = component.name || 'Anonymous';
|
|
125
|
+
hydrationContext.register(componentName, props);
|
|
126
|
+
}
|
|
127
|
+
// Prepare hydration script
|
|
128
|
+
let hydrationScript = '';
|
|
129
|
+
if (options?.includeHydration && hydrationContext) {
|
|
130
|
+
const hydrationData = hydrationContext.getData();
|
|
131
|
+
hydrationScript = `<script>window.__HYDRATION_DATA__=${serializeHydrationData(hydrationData)}</script>`;
|
|
132
|
+
}
|
|
133
|
+
const fullContent = content + hydrationScript;
|
|
134
|
+
const contentBytes = encoder.encode(fullContent);
|
|
135
|
+
const totalLength = contentBytes.length;
|
|
136
|
+
// Calculate optimal chunk size if not specified
|
|
137
|
+
const effectiveChunkSize = options?.chunkSize ?? calculateOptimalChunkSize(totalLength);
|
|
138
|
+
// Create progress tracker
|
|
139
|
+
const tracker = createProgressTracker(totalLength, options?.onProgress);
|
|
140
|
+
let bytesProcessed = 0;
|
|
141
|
+
let chunksProcessed = 0;
|
|
142
|
+
let offset = 0;
|
|
143
|
+
tracker.update(0, 0, 'starting');
|
|
144
|
+
return new ReadableStream({
|
|
145
|
+
pull(controller) {
|
|
146
|
+
// Check if we're done
|
|
147
|
+
if (offset >= totalLength) {
|
|
148
|
+
tracker.update(bytesProcessed, chunksProcessed, 'complete');
|
|
149
|
+
controller.close();
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
// Calculate chunk end
|
|
153
|
+
const end = Math.min(offset + effectiveChunkSize, totalLength);
|
|
154
|
+
const chunk = contentBytes.slice(offset, end);
|
|
155
|
+
controller.enqueue(chunk);
|
|
156
|
+
bytesProcessed += chunk.length;
|
|
157
|
+
chunksProcessed++;
|
|
158
|
+
offset = end;
|
|
159
|
+
tracker.update(bytesProcessed, chunksProcessed, 'streaming');
|
|
160
|
+
},
|
|
161
|
+
cancel() {
|
|
162
|
+
tracker.update(bytesProcessed, chunksProcessed, 'error');
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
// Queuing strategy for backpressure
|
|
166
|
+
new ByteLengthQueuingStrategy({ highWaterMark }));
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Create a streaming Response with optimizations
|
|
170
|
+
*
|
|
171
|
+
* @param component - Component function to render
|
|
172
|
+
* @param props - Props to pass to component
|
|
173
|
+
* @param options - Optimized streaming options
|
|
174
|
+
* @returns Response with streaming body
|
|
175
|
+
*
|
|
176
|
+
* @example
|
|
177
|
+
* ```ts
|
|
178
|
+
* // In a Hono/Worker handler
|
|
179
|
+
* export default {
|
|
180
|
+
* fetch(request, env) {
|
|
181
|
+
* return streamJSXResponse(
|
|
182
|
+
* PageComponent,
|
|
183
|
+
* { data: pageData },
|
|
184
|
+
* {
|
|
185
|
+
* streaming: true,
|
|
186
|
+
* compressionHint: true,
|
|
187
|
+
* }
|
|
188
|
+
* )
|
|
189
|
+
* }
|
|
190
|
+
* }
|
|
191
|
+
* ```
|
|
192
|
+
*/
|
|
193
|
+
export async function streamJSXResponse(component, props, options) {
|
|
194
|
+
const stream = await renderToReadableStream(component, props, options);
|
|
195
|
+
const headers = new Headers({
|
|
196
|
+
'Content-Type': 'text/html; charset=utf-8',
|
|
197
|
+
'X-Content-Type-Options': 'nosniff',
|
|
198
|
+
...options?.headers,
|
|
199
|
+
});
|
|
200
|
+
// Add streaming hints
|
|
201
|
+
if (options?.streaming) {
|
|
202
|
+
headers.set('Transfer-Encoding', 'chunked');
|
|
203
|
+
}
|
|
204
|
+
// Add compression hint
|
|
205
|
+
if (options?.compressionHint) {
|
|
206
|
+
headers.set('Vary', 'Accept-Encoding');
|
|
207
|
+
}
|
|
208
|
+
return new Response(stream, {
|
|
209
|
+
status: 200,
|
|
210
|
+
headers,
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Create a reusable streaming renderer with configuration
|
|
215
|
+
*
|
|
216
|
+
* @param options - Renderer options with optimization controls
|
|
217
|
+
* @returns Streaming renderer instance with stats
|
|
218
|
+
*
|
|
219
|
+
* @example
|
|
220
|
+
* ```ts
|
|
221
|
+
* const renderer = createStreamingRenderer({
|
|
222
|
+
* doctype: '<!DOCTYPE html>',
|
|
223
|
+
* includeHydration: true,
|
|
224
|
+
* chunkSize: 8192,
|
|
225
|
+
* onProgress: (p) => console.log(p.phase),
|
|
226
|
+
* })
|
|
227
|
+
*
|
|
228
|
+
* const stream = await renderer.render(MyComponent, props)
|
|
229
|
+
* const stats = renderer.getStats()
|
|
230
|
+
* ```
|
|
231
|
+
*/
|
|
232
|
+
export function createStreamingRenderer(options) {
|
|
233
|
+
const encoder = new TextEncoder();
|
|
234
|
+
const chunkSize = options.chunkSize ?? DEFAULT_CHUNK_SIZE;
|
|
235
|
+
const highWaterMark = options.highWaterMark ?? DEFAULT_HIGH_WATER_MARK;
|
|
236
|
+
// Stats tracking
|
|
237
|
+
let currentStats = null;
|
|
238
|
+
return {
|
|
239
|
+
async render(component, props) {
|
|
240
|
+
const startTime = Date.now();
|
|
241
|
+
let timeToFirstByte = 0;
|
|
242
|
+
let totalBytes = 0;
|
|
243
|
+
let totalChunks = 0;
|
|
244
|
+
let encounteredBackpressure = false;
|
|
245
|
+
// Create hydration context
|
|
246
|
+
const ctx = options.includeHydration ? createHydrationContext() : null;
|
|
247
|
+
// Render the component
|
|
248
|
+
const content = await component(props);
|
|
249
|
+
// Register for hydration data
|
|
250
|
+
if (ctx) {
|
|
251
|
+
const componentName = component.name || 'Anonymous';
|
|
252
|
+
ctx.register(componentName, props);
|
|
253
|
+
}
|
|
254
|
+
// Get hydration data
|
|
255
|
+
let hydrationJson = '';
|
|
256
|
+
if (options.includeHydration && ctx) {
|
|
257
|
+
hydrationJson = serializeHydrationData(ctx.getData());
|
|
258
|
+
}
|
|
259
|
+
// Apply shell wrapper if provided
|
|
260
|
+
let output;
|
|
261
|
+
if (options.shell) {
|
|
262
|
+
const hydrationScript = hydrationJson ? `window.__HYDRATION_DATA__=${hydrationJson}` : '';
|
|
263
|
+
output = options.shell(content, hydrationScript);
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
output = content;
|
|
267
|
+
if (options.includeHydration && hydrationJson) {
|
|
268
|
+
output += `<script>window.__HYDRATION_DATA__=${hydrationJson}</script>`;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
// Prepend doctype if provided
|
|
272
|
+
if (options.doctype) {
|
|
273
|
+
output = options.doctype + '\n' + output;
|
|
274
|
+
}
|
|
275
|
+
const contentBytes = encoder.encode(output);
|
|
276
|
+
const contentLength = contentBytes.length;
|
|
277
|
+
// Create progress tracker
|
|
278
|
+
const tracker = createProgressTracker(contentLength, options.onProgress);
|
|
279
|
+
tracker.update(0, 0, 'starting');
|
|
280
|
+
let offset = 0;
|
|
281
|
+
return new ReadableStream({
|
|
282
|
+
pull(controller) {
|
|
283
|
+
// Track time to first byte
|
|
284
|
+
if (totalChunks === 0) {
|
|
285
|
+
timeToFirstByte = Date.now() - startTime;
|
|
286
|
+
}
|
|
287
|
+
if (offset >= contentLength) {
|
|
288
|
+
// Finalize stats
|
|
289
|
+
currentStats = {
|
|
290
|
+
totalBytes,
|
|
291
|
+
totalChunks,
|
|
292
|
+
averageChunkSize: totalChunks > 0 ? totalBytes / totalChunks : 0,
|
|
293
|
+
timeToFirstByte,
|
|
294
|
+
totalDuration: Date.now() - startTime,
|
|
295
|
+
encounteredBackpressure,
|
|
296
|
+
};
|
|
297
|
+
tracker.update(totalBytes, totalChunks, 'complete');
|
|
298
|
+
controller.close();
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
const end = Math.min(offset + chunkSize, contentLength);
|
|
302
|
+
const chunk = contentBytes.slice(offset, end);
|
|
303
|
+
controller.enqueue(chunk);
|
|
304
|
+
totalBytes += chunk.length;
|
|
305
|
+
totalChunks++;
|
|
306
|
+
offset = end;
|
|
307
|
+
tracker.update(totalBytes, totalChunks, 'streaming');
|
|
308
|
+
},
|
|
309
|
+
cancel() {
|
|
310
|
+
tracker.update(totalBytes, totalChunks, 'error');
|
|
311
|
+
},
|
|
312
|
+
}, new ByteLengthQueuingStrategy({ highWaterMark }));
|
|
313
|
+
},
|
|
314
|
+
getStats() {
|
|
315
|
+
return currentStats;
|
|
316
|
+
},
|
|
317
|
+
resetStats() {
|
|
318
|
+
currentStats = null;
|
|
319
|
+
},
|
|
320
|
+
};
|
|
321
|
+
}
|
|
322
|
+
/**
|
|
323
|
+
* Stream MDX content with AI-generated props and optimizations
|
|
324
|
+
*
|
|
325
|
+
* @param mdx - MDX content string
|
|
326
|
+
* @param props - Props for each component
|
|
327
|
+
* @param options - Stream options with optimizations
|
|
328
|
+
* @returns ReadableStream of rendered content
|
|
329
|
+
*
|
|
330
|
+
* @example
|
|
331
|
+
* ```ts
|
|
332
|
+
* const stream = await streamMDXWithProps(
|
|
333
|
+
* '<Hero title="Welcome" />',
|
|
334
|
+
* { Hero: { title: 'Welcome', subtitle: 'To the site' } },
|
|
335
|
+
* {
|
|
336
|
+
* chunkSize: 8192,
|
|
337
|
+
* onProgress: (p) => console.log(`${p.chunksProcessed} chunks sent`),
|
|
338
|
+
* }
|
|
339
|
+
* )
|
|
340
|
+
* ```
|
|
341
|
+
*/
|
|
342
|
+
export async function streamMDXWithProps(mdx, props, options) {
|
|
343
|
+
// Get base stream from mdx module
|
|
344
|
+
const baseStream = await baseStreamMDXWithProps(mdx, props, options);
|
|
345
|
+
// If no optimization options, return base stream
|
|
346
|
+
if (!options?.chunkSize && !options?.highWaterMark && !options?.onProgress) {
|
|
347
|
+
return baseStream;
|
|
348
|
+
}
|
|
349
|
+
// Apply optimizations by re-chunking the stream
|
|
350
|
+
const reader = baseStream.getReader();
|
|
351
|
+
const encoder = new TextEncoder();
|
|
352
|
+
const chunkSize = options?.chunkSize ?? DEFAULT_CHUNK_SIZE;
|
|
353
|
+
const highWaterMark = options?.highWaterMark ?? DEFAULT_HIGH_WATER_MARK;
|
|
354
|
+
// Buffer for accumulating content
|
|
355
|
+
let buffer = new Uint8Array(0);
|
|
356
|
+
let bytesProcessed = 0;
|
|
357
|
+
let chunksProcessed = 0;
|
|
358
|
+
const tracker = createProgressTracker(undefined, options?.onProgress);
|
|
359
|
+
tracker.update(0, 0, 'starting');
|
|
360
|
+
return new ReadableStream({
|
|
361
|
+
async pull(controller) {
|
|
362
|
+
// Read from source stream
|
|
363
|
+
const { done, value } = await reader.read();
|
|
364
|
+
if (done) {
|
|
365
|
+
// Flush remaining buffer
|
|
366
|
+
if (buffer.length > 0) {
|
|
367
|
+
controller.enqueue(buffer);
|
|
368
|
+
bytesProcessed += buffer.length;
|
|
369
|
+
chunksProcessed++;
|
|
370
|
+
}
|
|
371
|
+
tracker.update(bytesProcessed, chunksProcessed, 'complete');
|
|
372
|
+
controller.close();
|
|
373
|
+
return;
|
|
374
|
+
}
|
|
375
|
+
// Append to buffer
|
|
376
|
+
const newBuffer = new Uint8Array(buffer.length + value.length);
|
|
377
|
+
newBuffer.set(buffer);
|
|
378
|
+
newBuffer.set(value, buffer.length);
|
|
379
|
+
buffer = newBuffer;
|
|
380
|
+
// Emit full chunks
|
|
381
|
+
while (buffer.length >= chunkSize) {
|
|
382
|
+
const chunk = buffer.slice(0, chunkSize);
|
|
383
|
+
controller.enqueue(chunk);
|
|
384
|
+
buffer = buffer.slice(chunkSize);
|
|
385
|
+
bytesProcessed += chunk.length;
|
|
386
|
+
chunksProcessed++;
|
|
387
|
+
tracker.update(bytesProcessed, chunksProcessed, 'streaming');
|
|
388
|
+
}
|
|
389
|
+
},
|
|
390
|
+
cancel() {
|
|
391
|
+
reader.cancel();
|
|
392
|
+
tracker.update(bytesProcessed, chunksProcessed, 'error');
|
|
393
|
+
},
|
|
394
|
+
}, new ByteLengthQueuingStrategy({ highWaterMark }));
|
|
395
|
+
}
|
|
396
|
+
// ============================================================================
|
|
397
|
+
// Re-exports from hono-jsx for convenience
|
|
398
|
+
// ============================================================================
|
|
399
|
+
export { createHydrationContext, serializeHydrationData, collectHydrationData, HydrationProvider, useHydration, } from './hono-jsx.js';
|
|
400
|
+
// Re-export base functions with different names for direct access
|
|
401
|
+
export { baseRenderToReadableStream as renderToReadableStreamBasic, baseStreamJSXResponse as streamJSXResponseBasic, baseCreateStreamingRenderer as createStreamingRendererBasic, };
|
|
402
|
+
//# sourceMappingURL=streaming.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streaming.js","sourceRoot":"","sources":["../src/streaming.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Type definitions for ai-props
|
|
3
|
+
*
|
|
4
|
+
* @packageDocumentation
|
|
5
|
+
*/
|
|
6
|
+
import type { SimpleSchema } from 'ai-functions';
|
|
7
|
+
/**
|
|
8
|
+
* Configuration for AI prop generation
|
|
9
|
+
*/
|
|
10
|
+
export interface AIPropsConfig {
|
|
11
|
+
/** Model to use for generation (default: 'sonnet') */
|
|
12
|
+
model?: string;
|
|
13
|
+
/** System prompt for generation context */
|
|
14
|
+
system?: string;
|
|
15
|
+
/** Whether to cache generated props */
|
|
16
|
+
cache?: boolean;
|
|
17
|
+
/** Cache TTL in milliseconds (default: 5 minutes) */
|
|
18
|
+
cacheTTL?: number;
|
|
19
|
+
/** Custom generation function */
|
|
20
|
+
generate?: <T>(schema: SimpleSchema, context: Record<string, unknown>) => Promise<T>;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Schema definition for component props
|
|
24
|
+
* Can be a SimpleSchema or a named type string
|
|
25
|
+
*/
|
|
26
|
+
export type PropSchema = SimpleSchema | string;
|
|
27
|
+
/**
|
|
28
|
+
* Options for prop generation
|
|
29
|
+
*/
|
|
30
|
+
export interface GeneratePropsOptions {
|
|
31
|
+
/** Schema defining the props to generate */
|
|
32
|
+
schema: PropSchema;
|
|
33
|
+
/** Partial props to use as context */
|
|
34
|
+
context?: Record<string, unknown>;
|
|
35
|
+
/** Additional prompt context */
|
|
36
|
+
prompt?: string;
|
|
37
|
+
/** Model to use */
|
|
38
|
+
model?: string;
|
|
39
|
+
/** System prompt */
|
|
40
|
+
system?: string;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Result of prop generation
|
|
44
|
+
*/
|
|
45
|
+
export interface GeneratePropsResult<T> {
|
|
46
|
+
/** Generated props */
|
|
47
|
+
props: T;
|
|
48
|
+
/** Whether props were from cache */
|
|
49
|
+
cached: boolean;
|
|
50
|
+
/** Generation metadata */
|
|
51
|
+
metadata?: {
|
|
52
|
+
model: string;
|
|
53
|
+
tokens?: number;
|
|
54
|
+
duration?: number;
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Cache entry for generated props
|
|
59
|
+
*/
|
|
60
|
+
export interface PropsCacheEntry<T = unknown> {
|
|
61
|
+
props: T;
|
|
62
|
+
timestamp: number;
|
|
63
|
+
key: string;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Props cache interface
|
|
67
|
+
*/
|
|
68
|
+
export interface PropsCache {
|
|
69
|
+
get<T>(key: string): PropsCacheEntry<T> | undefined;
|
|
70
|
+
set<T>(key: string, props: T): void;
|
|
71
|
+
delete(key: string): boolean;
|
|
72
|
+
clear(): void;
|
|
73
|
+
size: number;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Hook result for useAIProps
|
|
77
|
+
*/
|
|
78
|
+
export interface UseAIPropsResult<T> {
|
|
79
|
+
/** Generated props (null while loading) */
|
|
80
|
+
props: T | null;
|
|
81
|
+
/** Whether generation is in progress */
|
|
82
|
+
loading: boolean;
|
|
83
|
+
/** Error if generation failed */
|
|
84
|
+
error: Error | null;
|
|
85
|
+
/** Regenerate props */
|
|
86
|
+
regenerate: () => Promise<void>;
|
|
87
|
+
/** Whether props were from cache */
|
|
88
|
+
cached: boolean;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Options for useAIProps hook
|
|
92
|
+
*/
|
|
93
|
+
export interface UseAIPropsOptions<T> extends Omit<GeneratePropsOptions, 'context'> {
|
|
94
|
+
/** Partial props to merge and use as context */
|
|
95
|
+
partialProps?: Partial<T>;
|
|
96
|
+
/** Skip generation if all required props are provided */
|
|
97
|
+
skipIfComplete?: boolean;
|
|
98
|
+
/** Dependencies that trigger regeneration */
|
|
99
|
+
deps?: unknown[];
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Component wrapper options for AI()
|
|
103
|
+
*/
|
|
104
|
+
export interface AIComponentOptions<P> {
|
|
105
|
+
/** Schema for the component props */
|
|
106
|
+
schema: PropSchema;
|
|
107
|
+
/** Default props */
|
|
108
|
+
defaults?: Partial<P>;
|
|
109
|
+
/** Props that are always required (never generated) */
|
|
110
|
+
required?: (keyof P)[];
|
|
111
|
+
/** Props to exclude from generation */
|
|
112
|
+
exclude?: (keyof P)[];
|
|
113
|
+
/** AI generation config */
|
|
114
|
+
config?: AIPropsConfig;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Enhanced component type with AI capabilities
|
|
118
|
+
*/
|
|
119
|
+
export interface AIComponent<P> {
|
|
120
|
+
(props: Partial<P>): Promise<P>;
|
|
121
|
+
/** Original schema */
|
|
122
|
+
schema: PropSchema;
|
|
123
|
+
/** Generate props without rendering */
|
|
124
|
+
generateProps: (context?: Partial<P>) => Promise<P>;
|
|
125
|
+
/** Configuration */
|
|
126
|
+
config: AIPropsConfig;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Type helper to extract props type from a schema
|
|
130
|
+
*/
|
|
131
|
+
export type InferProps<S extends PropSchema> = S extends SimpleSchema ? S extends string ? string : S extends {
|
|
132
|
+
[key: string]: SimpleSchema;
|
|
133
|
+
} ? {
|
|
134
|
+
[K in keyof S]: InferProps<S[K]>;
|
|
135
|
+
} : unknown : unknown;
|
|
136
|
+
/**
|
|
137
|
+
* Validation result for props
|
|
138
|
+
*/
|
|
139
|
+
export interface ValidationResult {
|
|
140
|
+
valid: boolean;
|
|
141
|
+
errors: ValidationError[];
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Individual validation error
|
|
145
|
+
*/
|
|
146
|
+
export interface ValidationError {
|
|
147
|
+
path: string;
|
|
148
|
+
message: string;
|
|
149
|
+
expected?: string;
|
|
150
|
+
received?: unknown;
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Validation utilities for ai-props
|
|
3
|
+
*
|
|
4
|
+
* Provides prop validation against schemas.
|
|
5
|
+
*
|
|
6
|
+
* @packageDocumentation
|
|
7
|
+
*/
|
|
8
|
+
import type { PropSchema, ValidationResult } from './types.js';
|
|
9
|
+
/**
|
|
10
|
+
* Validate props against a schema
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* const result = validateProps(
|
|
15
|
+
* { name: 'John', age: '25' }, // props
|
|
16
|
+
* { name: 'Name', age: 'Age (number)' } // schema
|
|
17
|
+
* )
|
|
18
|
+
*
|
|
19
|
+
* if (!result.valid) {
|
|
20
|
+
* console.log(result.errors)
|
|
21
|
+
* // [{ path: 'age', message: 'Expected number, got string' }]
|
|
22
|
+
* }
|
|
23
|
+
* ```
|
|
24
|
+
*/
|
|
25
|
+
export declare function validateProps(props: Record<string, unknown>, schema: PropSchema): ValidationResult;
|
|
26
|
+
/**
|
|
27
|
+
* Check if all required props are present
|
|
28
|
+
*/
|
|
29
|
+
export declare function hasRequiredProps<P extends Record<string, unknown>>(props: Partial<P>, required: (keyof P)[]): boolean;
|
|
30
|
+
/**
|
|
31
|
+
* Get list of missing required props
|
|
32
|
+
*/
|
|
33
|
+
export declare function getMissingProps<P extends Record<string, unknown>>(props: Partial<P>, required: (keyof P)[]): (keyof P)[];
|
|
34
|
+
/**
|
|
35
|
+
* Check if props are complete according to schema
|
|
36
|
+
*/
|
|
37
|
+
export declare function isComplete(props: Record<string, unknown>, schema: PropSchema): boolean;
|
|
38
|
+
/**
|
|
39
|
+
* Get list of missing props according to schema
|
|
40
|
+
*/
|
|
41
|
+
export declare function getMissingFromSchema(props: Record<string, unknown>, schema: PropSchema): string[];
|
|
42
|
+
/**
|
|
43
|
+
* Sanitize props by removing extra keys not in schema
|
|
44
|
+
*/
|
|
45
|
+
export declare function sanitizeProps<P extends Record<string, unknown>>(props: P, schema: PropSchema): Partial<P>;
|
|
46
|
+
/**
|
|
47
|
+
* Merge props with defaults, respecting schema types
|
|
48
|
+
*/
|
|
49
|
+
export declare function mergeWithDefaults<P extends Record<string, unknown>>(props: Partial<P>, defaults: Partial<P>, schema: PropSchema): Partial<P>;
|
|
50
|
+
/**
|
|
51
|
+
* Create a props validator function
|
|
52
|
+
*/
|
|
53
|
+
export declare function createValidator<P extends Record<string, unknown>>(schema: PropSchema): (props: Partial<P>) => ValidationResult;
|
|
54
|
+
/**
|
|
55
|
+
* Assert props are valid, throwing on error
|
|
56
|
+
*/
|
|
57
|
+
export declare function assertValidProps(props: Record<string, unknown>, schema: PropSchema): void;
|
|
58
|
+
//# sourceMappingURL=validate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../src/validate.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAGH,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAmB,MAAM,YAAY,CAAA;AAE/E;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,aAAa,CAC3B,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,MAAM,EAAE,UAAU,GACjB,gBAAgB,CAwBlB;AAuID;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAChE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EACjB,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,GACpB,OAAO,CAET;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/D,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EACjB,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,GACpB,CAAC,MAAM,CAAC,CAAC,EAAE,CAEb;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,UAAU,GAAG,OAAO,CAMtF;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,UAAU,GAAG,MAAM,EAAE,CAMjG;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7D,KAAK,EAAE,CAAC,EACR,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,CAAC,CAAC,CAeZ;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACjE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EACjB,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,CAAC,CAAC,CAiBZ;AAsBD;;GAEG;AACH,wBAAgB,eAAe,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/D,MAAM,EAAE,UAAU,GACjB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,KAAK,gBAAgB,CAEzC;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,UAAU,GAAG,IAAI,CAMzF"}
|