loopwind 0.25.5 → 0.25.7

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.
Files changed (92) hide show
  1. package/app/.astro/types.d.ts +1 -0
  2. package/app/dist/_astro/callback.Ci5gaEfJ.css +1 -0
  3. package/app/dist/auth/callback/index.html +81 -0
  4. package/app/dist/device/index.html +70 -0
  5. package/app/dist/index.html +327 -0
  6. package/app/package-lock.json +9239 -0
  7. package/app/package.json +23 -0
  8. package/app/wrangler.toml +8 -0
  9. package/dist/cli.js +54 -0
  10. package/dist/cli.js.map +1 -1
  11. package/dist/commands/login.d.ts +5 -0
  12. package/dist/commands/login.d.ts.map +1 -0
  13. package/dist/commands/login.js +60 -0
  14. package/dist/commands/login.js.map +1 -0
  15. package/dist/commands/logout.d.ts +5 -0
  16. package/dist/commands/logout.d.ts.map +1 -0
  17. package/dist/commands/logout.js +15 -0
  18. package/dist/commands/logout.js.map +1 -0
  19. package/dist/commands/publish.d.ts +10 -0
  20. package/dist/commands/publish.d.ts.map +1 -0
  21. package/dist/commands/publish.js +155 -0
  22. package/dist/commands/publish.js.map +1 -0
  23. package/dist/commands/templates.d.ts +5 -0
  24. package/dist/commands/templates.d.ts.map +1 -0
  25. package/dist/commands/templates.js +60 -0
  26. package/dist/commands/templates.js.map +1 -0
  27. package/dist/commands/unpublish.d.ts +5 -0
  28. package/dist/commands/unpublish.d.ts.map +1 -0
  29. package/dist/commands/unpublish.js +54 -0
  30. package/dist/commands/unpublish.js.map +1 -0
  31. package/dist/commands/whoami.d.ts +5 -0
  32. package/dist/commands/whoami.d.ts.map +1 -0
  33. package/dist/commands/whoami.js +30 -0
  34. package/dist/commands/whoami.js.map +1 -0
  35. package/dist/lib/api.d.ts +92 -0
  36. package/dist/lib/api.d.ts.map +1 -0
  37. package/dist/lib/api.js +149 -0
  38. package/dist/lib/api.js.map +1 -0
  39. package/dist/lib/auth.d.ts +41 -0
  40. package/dist/lib/auth.d.ts.map +1 -0
  41. package/dist/lib/auth.js +89 -0
  42. package/dist/lib/auth.js.map +1 -0
  43. package/dist/lib/bundler.d.ts +18 -0
  44. package/dist/lib/bundler.d.ts.map +1 -0
  45. package/dist/lib/bundler.js +105 -0
  46. package/dist/lib/bundler.js.map +1 -0
  47. package/dist/lib/helpers.d.ts +35 -2
  48. package/dist/lib/helpers.d.ts.map +1 -1
  49. package/dist/lib/helpers.js +91 -13
  50. package/dist/lib/helpers.js.map +1 -1
  51. package/dist/lib/renderer.js +2 -2
  52. package/dist/lib/renderer.js.map +1 -1
  53. package/dist/lib/utils.d.ts.map +1 -1
  54. package/dist/lib/utils.js +9 -0
  55. package/dist/lib/utils.js.map +1 -1
  56. package/dist/sdk/edge.d.ts +65 -0
  57. package/dist/sdk/edge.d.ts.map +1 -0
  58. package/dist/sdk/edge.js +329 -0
  59. package/dist/sdk/edge.js.map +1 -0
  60. package/dist/sdk/errors.d.ts +64 -0
  61. package/dist/sdk/errors.d.ts.map +1 -0
  62. package/dist/sdk/errors.js +94 -0
  63. package/dist/sdk/errors.js.map +1 -0
  64. package/dist/sdk/index.d.ts +29 -0
  65. package/dist/sdk/index.d.ts.map +1 -0
  66. package/dist/sdk/index.js +30 -0
  67. package/dist/sdk/index.js.map +1 -0
  68. package/dist/sdk/render.d.ts +52 -0
  69. package/dist/sdk/render.d.ts.map +1 -0
  70. package/dist/sdk/render.js +432 -0
  71. package/dist/sdk/render.js.map +1 -0
  72. package/dist/sdk/types.d.ts +185 -0
  73. package/dist/sdk/types.d.ts.map +1 -0
  74. package/dist/sdk/types.js +5 -0
  75. package/dist/sdk/types.js.map +1 -0
  76. package/dist/types/template.d.ts +18 -0
  77. package/dist/types/template.d.ts.map +1 -1
  78. package/package.json +26 -4
  79. package/plans/PLATFORM.md +1637 -237
  80. package/plans/PLATFORM_IMPLEMENTATION.md +1347 -530
  81. package/plans/SDK.md +797 -0
  82. package/platform/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/ebad93a0a7be9c5768c512f3e30740b64d2b6e575277a40d77044af5ae8fd3f2.sqlite +0 -0
  83. package/platform/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/ebad93a0a7be9c5768c512f3e30740b64d2b6e575277a40d77044af5ae8fd3f2.sqlite-shm +0 -0
  84. package/platform/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/ebad93a0a7be9c5768c512f3e30740b64d2b6e575277a40d77044af5ae8fd3f2.sqlite-wal +0 -0
  85. package/platform/migrations/0001_initial.sql +90 -0
  86. package/platform/package-lock.json +3104 -0
  87. package/platform/package.json +30 -0
  88. package/platform/wrangler.toml +43 -0
  89. package/tests-sdk/createRenderer.test.ts +251 -0
  90. package/tests-sdk/errors.test.ts +230 -0
  91. package/tests-sdk/render.test.ts +241 -0
  92. package/tests-sdk/tw.test.ts +277 -0
@@ -0,0 +1,329 @@
1
+ /**
2
+ * Loopwind SDK - Edge Runtime Build
3
+ *
4
+ * Compatible with Cloudflare Workers, Vercel Edge Functions, and other edge runtimes.
5
+ *
6
+ * Limitations:
7
+ * - PNG/WebP/JPG work (via WASM)
8
+ * - Video (mp4/gif) NOT supported (requires Node.js)
9
+ * - Uses Web APIs instead of Node.js APIs
10
+ *
11
+ * @example
12
+ * ```typescript
13
+ * import { render } from 'loopwind/edge';
14
+ *
15
+ * export default {
16
+ * async fetch(request: Request) {
17
+ * const url = new URL(request.url);
18
+ * const title = url.searchParams.get('title') || 'Hello';
19
+ *
20
+ * const png = await render(OGImage, {
21
+ * props: { title },
22
+ * width: 1200,
23
+ * height: 630,
24
+ * format: 'png',
25
+ * });
26
+ *
27
+ * return new Response(png, {
28
+ * headers: { 'Content-Type': 'image/png' },
29
+ * });
30
+ * },
31
+ * };
32
+ * ```
33
+ *
34
+ * @packageDocumentation
35
+ */
36
+ import satori from 'satori';
37
+ import { Resvg, initWasm } from '@resvg/resvg-wasm';
38
+ import { tw as twConverter } from '../lib/tailwind.js';
39
+ import { RenderError, ValidationError, TimeoutError, } from './errors.js';
40
+ // WASM initialization state
41
+ let wasmInitialized = false;
42
+ let wasmInitPromise = null;
43
+ /**
44
+ * Initialize resvg WASM module
45
+ */
46
+ async function ensureWasm() {
47
+ if (wasmInitialized)
48
+ return;
49
+ if (wasmInitPromise) {
50
+ await wasmInitPromise;
51
+ return;
52
+ }
53
+ wasmInitPromise = (async () => {
54
+ try {
55
+ // Fetch WASM from CDN
56
+ const wasmResponse = await fetch('https://unpkg.com/@resvg/resvg-wasm@2.6.2/index_bg.wasm');
57
+ const wasmBuffer = await wasmResponse.arrayBuffer();
58
+ await initWasm(wasmBuffer);
59
+ wasmInitialized = true;
60
+ }
61
+ catch (error) {
62
+ wasmInitPromise = null;
63
+ throw new RenderError(`Failed to initialize WASM: ${error.message}`, 'rasterize', error);
64
+ }
65
+ })();
66
+ await wasmInitPromise;
67
+ }
68
+ // Default fonts cache
69
+ let defaultFonts = null;
70
+ /**
71
+ * Load default Inter fonts from CDN
72
+ */
73
+ async function loadDefaultFonts() {
74
+ if (defaultFonts)
75
+ return defaultFonts;
76
+ try {
77
+ const [regular, bold] = await Promise.all([
78
+ fetch('https://cdn.jsdelivr.net/npm/@fontsource/inter@5.0.18/files/inter-latin-400-normal.woff2')
79
+ .then(r => r.arrayBuffer()),
80
+ fetch('https://cdn.jsdelivr.net/npm/@fontsource/inter@5.0.18/files/inter-latin-700-normal.woff2')
81
+ .then(r => r.arrayBuffer()),
82
+ ]);
83
+ defaultFonts = [
84
+ { name: 'Inter', data: regular, weight: 400, style: 'normal' },
85
+ { name: 'Inter', data: bold, weight: 700, style: 'normal' },
86
+ ];
87
+ return defaultFonts;
88
+ }
89
+ catch {
90
+ throw new Error('Failed to load default fonts. Please provide custom fonts.');
91
+ }
92
+ }
93
+ /**
94
+ * Convert FontConfig array to Satori font format
95
+ */
96
+ function toSatoriFonts(fonts) {
97
+ return fonts.map(f => ({
98
+ name: f.name,
99
+ data: f.data,
100
+ weight: f.weight || 400,
101
+ style: f.style || 'normal',
102
+ }));
103
+ }
104
+ /**
105
+ * Validate render options for edge runtime
106
+ */
107
+ function validateOptions(options) {
108
+ const { width, height, format, quality, scale } = options;
109
+ // Video not supported in edge
110
+ if (format === 'mp4' || format === 'gif') {
111
+ throw new ValidationError('Video formats (mp4, gif) are not supported in edge runtime. Use Node.js runtime instead.', 'format', 'png, svg, jpg, jpeg, webp', format);
112
+ }
113
+ if (width !== undefined && (width < 1 || width > 16384)) {
114
+ throw new ValidationError('Width must be between 1 and 16384', 'width', '1-16384', width);
115
+ }
116
+ if (height !== undefined && (height < 1 || height > 16384)) {
117
+ throw new ValidationError('Height must be between 1 and 16384', 'height', '1-16384', height);
118
+ }
119
+ if (format !== undefined) {
120
+ const validFormats = ['png', 'svg', 'jpg', 'jpeg', 'webp'];
121
+ if (!validFormats.includes(format)) {
122
+ throw new ValidationError(`Invalid format: ${format}`, 'format', validFormats.join(', '), format);
123
+ }
124
+ }
125
+ if (quality !== undefined && (quality < 1 || quality > 100)) {
126
+ throw new ValidationError('Quality must be between 1 and 100', 'quality', '1-100', quality);
127
+ }
128
+ if (scale !== undefined && (scale < 0.1 || scale > 10)) {
129
+ throw new ValidationError('Scale must be between 0.1 and 10', 'scale', '0.1-10', scale);
130
+ }
131
+ }
132
+ /**
133
+ * Simple QR code helper (edge-compatible)
134
+ * Returns a placeholder - full QR support requires qrcode library
135
+ */
136
+ function qrHelper(_text) {
137
+ // In edge, we can't use the full qrcode library easily
138
+ // Return a placeholder or implement a lightweight QR generator
139
+ console.warn('QR code generation not fully supported in edge runtime');
140
+ return 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNk+M9QDwADhgGAWjR9awAAAABJRU5ErkJggg==';
141
+ }
142
+ /**
143
+ * Image loader helper (edge-compatible)
144
+ * Fetches image and converts to data URI
145
+ */
146
+ async function loadImage(url) {
147
+ if (!url.startsWith('http://') && !url.startsWith('https://')) {
148
+ // Local paths not supported in edge
149
+ console.warn('Local file paths not supported in edge runtime, returning URL as-is');
150
+ return url;
151
+ }
152
+ try {
153
+ const response = await fetch(url);
154
+ if (!response.ok) {
155
+ throw new Error(`HTTP ${response.status}`);
156
+ }
157
+ const arrayBuffer = await response.arrayBuffer();
158
+ const contentType = response.headers.get('content-type') || 'image/png';
159
+ const base64 = btoa(String.fromCharCode(...new Uint8Array(arrayBuffer)));
160
+ return `data:${contentType};base64,${base64}`;
161
+ }
162
+ catch (error) {
163
+ console.warn(`Failed to load image: ${url}`, error);
164
+ return url;
165
+ }
166
+ }
167
+ /**
168
+ * Render a single frame to SVG
169
+ */
170
+ async function renderFrameToSVG(template, props, width, height, fonts, frameInfo, config, debug) {
171
+ // Create tw helper
172
+ const twFn = (classes) => twConverter(classes, null, config || {}, {
173
+ progress: frameInfo?.progress ?? 0,
174
+ frame: frameInfo?.index ?? 0,
175
+ totalFrames: frameInfo?.total,
176
+ durationMs: frameInfo?.duration ? frameInfo.duration * 1000 : undefined,
177
+ });
178
+ // Pre-load images from props
179
+ const imageCache = new Map();
180
+ const imagePromises = [];
181
+ for (const value of Object.values(props)) {
182
+ if (typeof value === 'string' && (value.startsWith('http://') ||
183
+ value.startsWith('https://'))) {
184
+ const promise = loadImage(value)
185
+ .then(dataUri => { imageCache.set(value, dataUri); })
186
+ .catch(() => { });
187
+ imagePromises.push(promise);
188
+ }
189
+ }
190
+ await Promise.all(imagePromises);
191
+ // Helper functions
192
+ const imageHelper = (pathOrUrl) => imageCache.get(pathOrUrl) || pathOrUrl;
193
+ // Build full props
194
+ const fullProps = {
195
+ ...props,
196
+ tw: twFn,
197
+ qr: qrHelper,
198
+ image: imageHelper,
199
+ ...(frameInfo && { frame: frameInfo }),
200
+ };
201
+ // Render template to JSX
202
+ let element;
203
+ try {
204
+ element = template(fullProps);
205
+ }
206
+ catch (error) {
207
+ throw new RenderError(`Template execution failed: ${error.message}`, 'jsx', error);
208
+ }
209
+ // Render to SVG using Satori
210
+ try {
211
+ const svg = await satori(element, {
212
+ width,
213
+ height,
214
+ fonts: toSatoriFonts(fonts),
215
+ debug: debug || false,
216
+ });
217
+ return svg;
218
+ }
219
+ catch (error) {
220
+ throw new RenderError(`SVG generation failed: ${error.message}`, 'svg', error);
221
+ }
222
+ }
223
+ /**
224
+ * Convert SVG to PNG using resvg WASM
225
+ */
226
+ async function svgToPng(svg, width, scale) {
227
+ await ensureWasm();
228
+ try {
229
+ const resvg = new Resvg(svg, {
230
+ fitTo: {
231
+ mode: 'width',
232
+ value: Math.round(width * scale),
233
+ },
234
+ });
235
+ const pngData = resvg.render();
236
+ return pngData.asPng();
237
+ }
238
+ catch (error) {
239
+ throw new RenderError(`PNG rasterization failed: ${error.message}`, 'rasterize', error);
240
+ }
241
+ }
242
+ /**
243
+ * Render a template to image (edge runtime)
244
+ *
245
+ * @example
246
+ * ```typescript
247
+ * import { render } from 'loopwind/edge';
248
+ *
249
+ * const OGImage = ({ title, tw }) => (
250
+ * <div style={tw("w-full h-full bg-blue-500 flex items-center justify-center")}>
251
+ * <h1 style={tw("text-white text-6xl")}>{title}</h1>
252
+ * </div>
253
+ * );
254
+ *
255
+ * const png = await render(OGImage, {
256
+ * props: { title: 'Hello World' },
257
+ * width: 1200,
258
+ * height: 630,
259
+ * format: 'png',
260
+ * });
261
+ * ```
262
+ */
263
+ export async function render(template, options) {
264
+ // Validate options
265
+ validateOptions(options);
266
+ const { props, width = 1200, height = 630, format = 'png', scale = 2, fonts: customFonts, debug = false, timeout, } = options;
267
+ // Handle timeout
268
+ const renderPromise = (async () => {
269
+ // Load fonts
270
+ const fonts = customFonts || await loadDefaultFonts();
271
+ // Render to SVG
272
+ const svg = await renderFrameToSVG(template, props, width, height, fonts, undefined, undefined, debug);
273
+ // Return SVG if requested
274
+ if (format === 'svg') {
275
+ return new TextEncoder().encode(svg);
276
+ }
277
+ // Convert to PNG
278
+ const png = await svgToPng(svg, width, scale);
279
+ // Return PNG if requested
280
+ if (format === 'png') {
281
+ return png;
282
+ }
283
+ // For jpg/jpeg/webp in edge, we'd need a WASM-based encoder
284
+ // For now, return PNG with a warning
285
+ console.warn(`Format '${format}' not fully supported in edge runtime, returning PNG`);
286
+ return png;
287
+ })();
288
+ if (timeout) {
289
+ const startTime = Date.now();
290
+ const timeoutPromise = new Promise((_, reject) => {
291
+ setTimeout(() => {
292
+ const elapsed = Date.now() - startTime;
293
+ reject(new TimeoutError(`Render timed out after ${timeout}ms`, timeout, elapsed));
294
+ }, timeout);
295
+ });
296
+ return Promise.race([renderPromise, timeoutPromise]);
297
+ }
298
+ return renderPromise;
299
+ }
300
+ /**
301
+ * Create a reusable renderer with preset configuration (edge runtime)
302
+ */
303
+ export function createRenderer(config) {
304
+ const fonts = Array.isArray(config.fonts) ? config.fonts : undefined;
305
+ return async function (templateOrName, options) {
306
+ // Resolve template by name if string
307
+ let template;
308
+ if (typeof templateOrName === 'string') {
309
+ if (!config.templates || !config.templates[templateOrName]) {
310
+ throw new ValidationError(`Template "${templateOrName}" not found in registry`, 'template', Object.keys(config.templates || {}).join(', ') || 'no templates registered', templateOrName);
311
+ }
312
+ template = config.templates[templateOrName];
313
+ }
314
+ else {
315
+ template = templateOrName;
316
+ }
317
+ // Merge options with defaults
318
+ const mergedOptions = {
319
+ ...options,
320
+ width: options.width ?? config.defaults?.width,
321
+ height: options.height ?? config.defaults?.height,
322
+ format: options.format ?? config.defaults?.format,
323
+ fonts: options.fonts ?? fonts,
324
+ };
325
+ return render(template, mergedOptions);
326
+ };
327
+ }
328
+ export { LoopwindError, ValidationError, FontError, RenderError, TimeoutError, ImageFetchError, } from './errors.js';
329
+ //# sourceMappingURL=edge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"edge.js","sourceRoot":"","sources":["../../src/sdk/edge.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AAEH,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAEpD,OAAO,EAAE,EAAE,IAAI,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EACL,WAAW,EACX,eAAe,EACf,YAAY,GACb,MAAM,aAAa,CAAC;AAcrB,4BAA4B;AAC5B,IAAI,eAAe,GAAG,KAAK,CAAC;AAC5B,IAAI,eAAe,GAAyB,IAAI,CAAC;AAEjD;;GAEG;AACH,KAAK,UAAU,UAAU;IACvB,IAAI,eAAe;QAAE,OAAO;IAE5B,IAAI,eAAe,EAAE,CAAC;QACpB,MAAM,eAAe,CAAC;QACtB,OAAO;IACT,CAAC;IAED,eAAe,GAAG,CAAC,KAAK,IAAI,EAAE;QAC5B,IAAI,CAAC;YACH,sBAAsB;YACtB,MAAM,YAAY,GAAG,MAAM,KAAK,CAC9B,yDAAyD,CAC1D,CAAC;YACF,MAAM,UAAU,GAAG,MAAM,YAAY,CAAC,WAAW,EAAE,CAAC;YACpD,MAAM,QAAQ,CAAC,UAAU,CAAC,CAAC;YAC3B,eAAe,GAAG,IAAI,CAAC;QACzB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,eAAe,GAAG,IAAI,CAAC;YACvB,MAAM,IAAI,WAAW,CACnB,8BAA+B,KAAe,CAAC,OAAO,EAAE,EACxD,WAAW,EACX,KAAc,CACf,CAAC;QACJ,CAAC;IACH,CAAC,CAAC,EAAE,CAAC;IAEL,MAAM,eAAe,CAAC;AACxB,CAAC;AAED,sBAAsB;AACtB,IAAI,YAAY,GAAwB,IAAI,CAAC;AAE7C;;GAEG;AACH,KAAK,UAAU,gBAAgB;IAC7B,IAAI,YAAY;QAAE,OAAO,YAAY,CAAC;IAEtC,IAAI,CAAC;QACH,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACxC,KAAK,CAAC,0FAA0F,CAAC;iBAC9F,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;YAC7B,KAAK,CAAC,0FAA0F,CAAC;iBAC9F,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;SAC9B,CAAC,CAAC;QAEH,YAAY,GAAG;YACb,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE;YAC9D,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE;SAC5D,CAAC;QAEF,OAAO,YAAY,CAAC;IACtB,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;IAChF,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAS,aAAa,CAAC,KAAmB;IACxC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACrB,IAAI,EAAE,CAAC,CAAC,IAAI;QACZ,IAAI,EAAE,CAAC,CAAC,IAAI;QACZ,MAAM,EAAE,CAAC,CAAC,MAAM,IAAI,GAAG;QACvB,KAAK,EAAE,CAAC,CAAC,KAAK,IAAI,QAAQ;KAC3B,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;GAEG;AACH,SAAS,eAAe,CAA0B,OAAyB;IACzE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;IAE1D,8BAA8B;IAC9B,IAAI,MAAM,KAAK,KAAK,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;QACzC,MAAM,IAAI,eAAe,CACvB,0FAA0F,EAC1F,QAAQ,EACR,2BAA2B,EAC3B,MAAM,CACP,CAAC;IACJ,CAAC;IAED,IAAI,KAAK,KAAK,SAAS,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC;QACxD,MAAM,IAAI,eAAe,CAAC,mCAAmC,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;IAC5F,CAAC;IAED,IAAI,MAAM,KAAK,SAAS,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,GAAG,KAAK,CAAC,EAAE,CAAC;QAC3D,MAAM,IAAI,eAAe,CAAC,oCAAoC,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;IAC/F,CAAC;IAED,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,MAAM,YAAY,GAAmB,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;QAC3E,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,eAAe,CAAC,mBAAmB,MAAM,EAAE,EAAE,QAAQ,EAAE,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;QACpG,CAAC;IACH,CAAC;IAED,IAAI,OAAO,KAAK,SAAS,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,OAAO,GAAG,GAAG,CAAC,EAAE,CAAC;QAC5D,MAAM,IAAI,eAAe,CAAC,mCAAmC,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC9F,CAAC;IAED,IAAI,KAAK,KAAK,SAAS,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,KAAK,GAAG,EAAE,CAAC,EAAE,CAAC;QACvD,MAAM,IAAI,eAAe,CAAC,kCAAkC,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC1F,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,SAAS,QAAQ,CAAC,KAAa;IAC7B,uDAAuD;IACvD,+DAA+D;IAC/D,OAAO,CAAC,IAAI,CAAC,wDAAwD,CAAC,CAAC;IACvE,OAAO,wHAAwH,CAAC;AAClI,CAAC;AAED;;;GAGG;AACH,KAAK,UAAU,SAAS,CAAC,GAAW;IAClC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC9D,oCAAoC;QACpC,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;QACpF,OAAO,GAAG,CAAC;IACb,CAAC;IAED,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,QAAQ,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7C,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,WAAW,EAAE,CAAC;QACjD,MAAM,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,WAAW,CAAC;QACxE,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QAEzE,OAAO,QAAQ,WAAW,WAAW,MAAM,EAAE,CAAC;IAChD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,IAAI,CAAC,yBAAyB,GAAG,EAAE,EAAE,KAAK,CAAC,CAAC;QACpD,OAAO,GAAG,CAAC;IACb,CAAC;AACH,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,gBAAgB,CAC7B,QAAqB,EACrB,KAAQ,EACR,KAAa,EACb,MAAc,EACd,KAAmB,EACnB,SAAqB,EACrB,MAAuB,EACvB,KAAe;IAEf,mBAAmB;IACnB,MAAM,IAAI,GAAG,CAAC,OAAe,EAAE,EAAE,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,EAAE,EAAE;QACzE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI,CAAC;QAClC,KAAK,EAAE,SAAS,EAAE,KAAK,IAAI,CAAC;QAC5B,WAAW,EAAE,SAAS,EAAE,KAAK;QAC7B,UAAU,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,SAAS;KACxE,CAAC,CAAC;IAEH,6BAA6B;IAC7B,MAAM,UAAU,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC7C,MAAM,aAAa,GAAoB,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;QACzC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAC/B,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC;YAC3B,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAC7B,EAAE,CAAC;YACF,MAAM,OAAO,GAAG,SAAS,CAAC,KAAK,CAAC;iBAC7B,IAAI,CAAC,OAAO,CAAC,EAAE,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;iBACpD,KAAK,CAAC,GAAG,EAAE,GAAuB,CAAC,CAAC,CAAC;YACxC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IACD,MAAM,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAEjC,mBAAmB;IACnB,MAAM,WAAW,GAAG,CAAC,SAAiB,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC;IAElF,mBAAmB;IACnB,MAAM,SAAS,GAA0B;QACvC,GAAG,KAAK;QACR,EAAE,EAAE,IAAI;QACR,EAAE,EAAE,QAAQ;QACZ,KAAK,EAAE,WAAW;QAClB,GAAG,CAAC,SAAS,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;KACvC,CAAC;IAEF,yBAAyB;IACzB,IAAI,OAA2B,CAAC;IAChC,IAAI,CAAC;QACH,OAAO,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAChC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,WAAW,CACnB,8BAA+B,KAAe,CAAC,OAAO,EAAE,EACxD,KAAK,EACL,KAAc,CACf,CAAC;IACJ,CAAC;IAED,6BAA6B;IAC7B,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,OAAO,EAAE;YAChC,KAAK;YACL,MAAM;YACN,KAAK,EAAE,aAAa,CAAC,KAAK,CAAC;YAC3B,KAAK,EAAE,KAAK,IAAI,KAAK;SACtB,CAAC,CAAC;QACH,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,WAAW,CACnB,0BAA2B,KAAe,CAAC,OAAO,EAAE,EACpD,KAAK,EACL,KAAc,CACf,CAAC;IACJ,CAAC;AACH,CAAC;AAED;;GAEG;AACH,KAAK,UAAU,QAAQ,CAAC,GAAW,EAAE,KAAa,EAAE,KAAa;IAC/D,MAAM,UAAU,EAAE,CAAC;IAEnB,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,EAAE;YAC3B,KAAK,EAAE;gBACL,IAAI,EAAE,OAAO;gBACb,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;aACjC;SACF,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;QAC/B,OAAO,OAAO,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,WAAW,CACnB,6BAA8B,KAAe,CAAC,OAAO,EAAE,EACvD,WAAW,EACX,KAAc,CACf,CAAC;IACJ,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM,CAC1B,QAAqB,EACrB,OAAyB;IAEzB,mBAAmB;IACnB,eAAe,CAAC,OAAO,CAAC,CAAC;IAEzB,MAAM,EACJ,KAAK,EACL,KAAK,GAAG,IAAI,EACZ,MAAM,GAAG,GAAG,EACZ,MAAM,GAAG,KAAK,EACd,KAAK,GAAG,CAAC,EACT,KAAK,EAAE,WAAW,EAClB,KAAK,GAAG,KAAK,EACb,OAAO,GACR,GAAG,OAAO,CAAC;IAEZ,iBAAiB;IACjB,MAAM,aAAa,GAAG,CAAC,KAAK,IAAI,EAAE;QAChC,aAAa;QACb,MAAM,KAAK,GAAG,WAAW,IAAI,MAAM,gBAAgB,EAAE,CAAC;QAEtD,gBAAgB;QAChB,MAAM,GAAG,GAAG,MAAM,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QAEvG,0BAA0B;QAC1B,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;YACrB,OAAO,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACvC,CAAC;QAED,iBAAiB;QACjB,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAE9C,0BAA0B;QAC1B,IAAI,MAAM,KAAK,KAAK,EAAE,CAAC;YACrB,OAAO,GAAG,CAAC;QACb,CAAC;QAED,4DAA4D;QAC5D,qCAAqC;QACrC,OAAO,CAAC,IAAI,CAAC,WAAW,MAAM,sDAAsD,CAAC,CAAC;QACtF,OAAO,GAAG,CAAC;IACb,CAAC,CAAC,EAAE,CAAC;IAEL,IAAI,OAAO,EAAE,CAAC;QACZ,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC7B,MAAM,cAAc,GAAG,IAAI,OAAO,CAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;YACtD,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBACvC,MAAM,CAAC,IAAI,YAAY,CACrB,0BAA0B,OAAO,IAAI,EACrC,OAAO,EACP,OAAO,CACR,CAAC,CAAC;YACL,CAAC,EAAE,OAAO,CAAC,CAAC;QACd,CAAC,CAAC,CAAC;QAEH,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,aAAa,CAAC;AACvB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,MAAsB;IACnD,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAErE,OAAO,KAAK,WACV,cAAoC,EACpC,OAAyB;QAEzB,qCAAqC;QACrC,IAAI,QAAqB,CAAC;QAC1B,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE,CAAC;YACvC,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,CAAC;gBAC3D,MAAM,IAAI,eAAe,CACvB,aAAa,cAAc,yBAAyB,EACpD,UAAU,EACV,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,yBAAyB,EAC3E,cAAc,CACf,CAAC;YACJ,CAAC;YACD,QAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,cAAc,CAAgB,CAAC;QAC7D,CAAC;aAAM,CAAC;YACN,QAAQ,GAAG,cAAc,CAAC;QAC5B,CAAC;QAED,8BAA8B;QAC9B,MAAM,aAAa,GAAqB;YACtC,GAAG,OAAO;YACV,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC,QAAQ,EAAE,KAAK;YAC9C,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,MAAM,CAAC,QAAQ,EAAE,MAAM;YACjD,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,MAAM,CAAC,QAAQ,EAAE,MAAM;YACjD,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,KAAK;SAC9B,CAAC;QAEF,OAAO,MAAM,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;IACzC,CAAC,CAAC;AACJ,CAAC;AAoBD,OAAO,EACL,aAAa,EACb,eAAe,EACf,SAAS,EACT,WAAW,EACX,YAAY,EACZ,eAAe,GAChB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,64 @@
1
+ /**
2
+ * Loopwind SDK Error Classes
3
+ */
4
+ /**
5
+ * Base error class for all Loopwind errors
6
+ */
7
+ export declare class LoopwindError extends Error {
8
+ constructor(message: string);
9
+ }
10
+ /**
11
+ * Validation error - invalid props, dimensions, format, etc.
12
+ */
13
+ export declare class ValidationError extends LoopwindError {
14
+ /** Field that failed validation */
15
+ field: string;
16
+ /** Expected value/type */
17
+ expected: string;
18
+ /** Received value */
19
+ received: any;
20
+ constructor(message: string, field: string, expected: string, received: any);
21
+ }
22
+ /**
23
+ * Font error - font file missing, corrupt, or unsupported
24
+ */
25
+ export declare class FontError extends LoopwindError {
26
+ /** Name of the font that failed */
27
+ fontName: string;
28
+ /** Path to the font file (if applicable) */
29
+ fontPath?: string;
30
+ constructor(message: string, fontName: string, fontPath?: string);
31
+ }
32
+ /**
33
+ * Render error - JSX/SVG/rasterization/encoding failed
34
+ */
35
+ export declare class RenderError extends LoopwindError {
36
+ /** Stage where the error occurred */
37
+ stage: 'jsx' | 'svg' | 'rasterize' | 'encode';
38
+ /** Original error */
39
+ cause?: Error;
40
+ constructor(message: string, stage: 'jsx' | 'svg' | 'rasterize' | 'encode', cause?: Error);
41
+ }
42
+ /**
43
+ * Timeout error - render exceeded time limit
44
+ */
45
+ export declare class TimeoutError extends LoopwindError {
46
+ /** Timeout value in ms */
47
+ timeout: number;
48
+ /** Elapsed time in ms */
49
+ elapsed: number;
50
+ constructor(message: string, timeout: number, elapsed: number);
51
+ }
52
+ /**
53
+ * Image fetch error - external image failed to load
54
+ */
55
+ export declare class ImageFetchError extends LoopwindError {
56
+ /** URL that failed to load */
57
+ url: string;
58
+ /** HTTP status code (if applicable) */
59
+ status?: number;
60
+ /** Original error */
61
+ cause?: Error;
62
+ constructor(message: string, url: string, status?: number, cause?: Error);
63
+ }
64
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/sdk/errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;GAEG;AACH,qBAAa,aAAc,SAAQ,KAAK;gBAC1B,OAAO,EAAE,MAAM;CAI5B;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,aAAa;IAChD,mCAAmC;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,0BAA0B;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,qBAAqB;IACrB,QAAQ,EAAE,GAAG,CAAC;gBAEF,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG;CAO5E;AAED;;GAEG;AACH,qBAAa,SAAU,SAAQ,aAAa;IAC1C,mCAAmC;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,4CAA4C;IAC5C,QAAQ,CAAC,EAAE,MAAM,CAAC;gBAEN,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM;CAMjE;AAED;;GAEG;AACH,qBAAa,WAAY,SAAQ,aAAa;IAC5C,qCAAqC;IACrC,KAAK,EAAE,KAAK,GAAG,KAAK,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC9C,qBAAqB;IACrB,KAAK,CAAC,EAAE,KAAK,CAAC;gBAEF,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAG,KAAK,GAAG,WAAW,GAAG,QAAQ,EAAE,KAAK,CAAC,EAAE,KAAK;CAM1F;AAED;;GAEG;AACH,qBAAa,YAAa,SAAQ,aAAa;IAC7C,0BAA0B;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,yBAAyB;IACzB,OAAO,EAAE,MAAM,CAAC;gBAEJ,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;CAM9D;AAED;;GAEG;AACH,qBAAa,eAAgB,SAAQ,aAAa;IAChD,8BAA8B;IAC9B,GAAG,EAAE,MAAM,CAAC;IACZ,uCAAuC;IACvC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,qBAAqB;IACrB,KAAK,CAAC,EAAE,KAAK,CAAC;gBAEF,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK;CAOzE"}
@@ -0,0 +1,94 @@
1
+ /**
2
+ * Loopwind SDK Error Classes
3
+ */
4
+ /**
5
+ * Base error class for all Loopwind errors
6
+ */
7
+ export class LoopwindError extends Error {
8
+ constructor(message) {
9
+ super(message);
10
+ this.name = 'LoopwindError';
11
+ }
12
+ }
13
+ /**
14
+ * Validation error - invalid props, dimensions, format, etc.
15
+ */
16
+ export class ValidationError extends LoopwindError {
17
+ /** Field that failed validation */
18
+ field;
19
+ /** Expected value/type */
20
+ expected;
21
+ /** Received value */
22
+ received;
23
+ constructor(message, field, expected, received) {
24
+ super(message);
25
+ this.name = 'ValidationError';
26
+ this.field = field;
27
+ this.expected = expected;
28
+ this.received = received;
29
+ }
30
+ }
31
+ /**
32
+ * Font error - font file missing, corrupt, or unsupported
33
+ */
34
+ export class FontError extends LoopwindError {
35
+ /** Name of the font that failed */
36
+ fontName;
37
+ /** Path to the font file (if applicable) */
38
+ fontPath;
39
+ constructor(message, fontName, fontPath) {
40
+ super(message);
41
+ this.name = 'FontError';
42
+ this.fontName = fontName;
43
+ this.fontPath = fontPath;
44
+ }
45
+ }
46
+ /**
47
+ * Render error - JSX/SVG/rasterization/encoding failed
48
+ */
49
+ export class RenderError extends LoopwindError {
50
+ /** Stage where the error occurred */
51
+ stage;
52
+ /** Original error */
53
+ cause;
54
+ constructor(message, stage, cause) {
55
+ super(message);
56
+ this.name = 'RenderError';
57
+ this.stage = stage;
58
+ this.cause = cause;
59
+ }
60
+ }
61
+ /**
62
+ * Timeout error - render exceeded time limit
63
+ */
64
+ export class TimeoutError extends LoopwindError {
65
+ /** Timeout value in ms */
66
+ timeout;
67
+ /** Elapsed time in ms */
68
+ elapsed;
69
+ constructor(message, timeout, elapsed) {
70
+ super(message);
71
+ this.name = 'TimeoutError';
72
+ this.timeout = timeout;
73
+ this.elapsed = elapsed;
74
+ }
75
+ }
76
+ /**
77
+ * Image fetch error - external image failed to load
78
+ */
79
+ export class ImageFetchError extends LoopwindError {
80
+ /** URL that failed to load */
81
+ url;
82
+ /** HTTP status code (if applicable) */
83
+ status;
84
+ /** Original error */
85
+ cause;
86
+ constructor(message, url, status, cause) {
87
+ super(message);
88
+ this.name = 'ImageFetchError';
89
+ this.url = url;
90
+ this.status = status;
91
+ this.cause = cause;
92
+ }
93
+ }
94
+ //# sourceMappingURL=errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/sdk/errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;GAEG;AACH,MAAM,OAAO,aAAc,SAAQ,KAAK;IACtC,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAC9B,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAChD,mCAAmC;IACnC,KAAK,CAAS;IACd,0BAA0B;IAC1B,QAAQ,CAAS;IACjB,qBAAqB;IACrB,QAAQ,CAAM;IAEd,YAAY,OAAe,EAAE,KAAa,EAAE,QAAgB,EAAE,QAAa;QACzE,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,SAAU,SAAQ,aAAa;IAC1C,mCAAmC;IACnC,QAAQ,CAAS;IACjB,4CAA4C;IAC5C,QAAQ,CAAU;IAElB,YAAY,OAAe,EAAE,QAAgB,EAAE,QAAiB;QAC9D,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;QACxB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,WAAY,SAAQ,aAAa;IAC5C,qCAAqC;IACrC,KAAK,CAAyC;IAC9C,qBAAqB;IACrB,KAAK,CAAS;IAEd,YAAY,OAAe,EAAE,KAA6C,EAAE,KAAa;QACvF,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;QAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,YAAa,SAAQ,aAAa;IAC7C,0BAA0B;IAC1B,OAAO,CAAS;IAChB,yBAAyB;IACzB,OAAO,CAAS;IAEhB,YAAY,OAAe,EAAE,OAAe,EAAE,OAAe;QAC3D,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;CACF;AAED;;GAEG;AACH,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAChD,8BAA8B;IAC9B,GAAG,CAAS;IACZ,uCAAuC;IACvC,MAAM,CAAU;IAChB,qBAAqB;IACrB,KAAK,CAAS;IAEd,YAAY,OAAe,EAAE,GAAW,EAAE,MAAe,EAAE,KAAa;QACtE,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;QAC9B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Loopwind SDK
3
+ *
4
+ * A programmatic library for rendering images and videos from JSX templates.
5
+ *
6
+ * @example
7
+ * ```typescript
8
+ * import { render } from 'loopwind';
9
+ *
10
+ * const OGImage = ({ title, tw }) => (
11
+ * <div style={tw("w-full h-full bg-blue-500 flex items-center justify-center")}>
12
+ * <h1 style={tw("text-white text-6xl")}>{title}</h1>
13
+ * </div>
14
+ * );
15
+ *
16
+ * const png = await render(OGImage, {
17
+ * props: { title: 'Hello World' },
18
+ * width: 1200,
19
+ * height: 630,
20
+ * format: 'png',
21
+ * });
22
+ * ```
23
+ *
24
+ * @packageDocumentation
25
+ */
26
+ export { render, createRenderer } from './render.js';
27
+ export type { Template, TemplateProps, BaseTemplateProps, RenderOptions, RenderResult, RendererConfig, RenderFunction, TwFunction, FrameInfo, FontConfig, FontsConfig, SimpleFontFamily, FontFamilyWithFiles, TokensConfig, OutputFormat, ImageFormat, VideoFormat, ImageTransformOptions, QRCodeOptions, } from './types.js';
28
+ export { LoopwindError, ValidationError, FontError, RenderError, TimeoutError, ImageFetchError, } from './errors.js';
29
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sdk/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAGH,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAGrD,YAAY,EACV,QAAQ,EACR,aAAa,EACb,iBAAiB,EACjB,aAAa,EACb,YAAY,EACZ,cAAc,EACd,cAAc,EACd,UAAU,EACV,SAAS,EACT,UAAU,EACV,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,WAAW,EACX,qBAAqB,EACrB,aAAa,GACd,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,aAAa,EACb,eAAe,EACf,SAAS,EACT,WAAW,EACX,YAAY,EACZ,eAAe,GAChB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Loopwind SDK
3
+ *
4
+ * A programmatic library for rendering images and videos from JSX templates.
5
+ *
6
+ * @example
7
+ * ```typescript
8
+ * import { render } from 'loopwind';
9
+ *
10
+ * const OGImage = ({ title, tw }) => (
11
+ * <div style={tw("w-full h-full bg-blue-500 flex items-center justify-center")}>
12
+ * <h1 style={tw("text-white text-6xl")}>{title}</h1>
13
+ * </div>
14
+ * );
15
+ *
16
+ * const png = await render(OGImage, {
17
+ * props: { title: 'Hello World' },
18
+ * width: 1200,
19
+ * height: 630,
20
+ * format: 'png',
21
+ * });
22
+ * ```
23
+ *
24
+ * @packageDocumentation
25
+ */
26
+ // Main render functions
27
+ export { render, createRenderer } from './render.js';
28
+ // Error classes
29
+ export { LoopwindError, ValidationError, FontError, RenderError, TimeoutError, ImageFetchError, } from './errors.js';
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sdk/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAEH,wBAAwB;AACxB,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAyBrD,gBAAgB;AAChB,OAAO,EACL,aAAa,EACb,eAAe,EACf,SAAS,EACT,WAAW,EACX,YAAY,EACZ,eAAe,GAChB,MAAM,aAAa,CAAC"}
@@ -0,0 +1,52 @@
1
+ /**
2
+ * Loopwind SDK - Render Functions
3
+ */
4
+ import type { Template, TemplateProps, RenderOptions, RenderResult, RendererConfig, RenderFunction } from './types.js';
5
+ /**
6
+ * Main render function
7
+ *
8
+ * @example
9
+ * ```typescript
10
+ * import { render } from 'loopwind';
11
+ *
12
+ * const OGImage = ({ title, tw }) => (
13
+ * <div style={tw("w-full h-full bg-blue-500 flex items-center justify-center")}>
14
+ * <h1 style={tw("text-white text-6xl")}>{title}</h1>
15
+ * </div>
16
+ * );
17
+ *
18
+ * const png = await render(OGImage, {
19
+ * props: { title: 'Hello World' },
20
+ * width: 1200,
21
+ * height: 630,
22
+ * format: 'png',
23
+ * });
24
+ * ```
25
+ */
26
+ export declare function render<P extends TemplateProps>(template: Template<P>, options: RenderOptions<P>): Promise<RenderResult>;
27
+ /**
28
+ * Create a reusable renderer with preset configuration
29
+ *
30
+ * @example
31
+ * ```typescript
32
+ * import { createRenderer } from 'loopwind';
33
+ *
34
+ * const render = createRenderer({
35
+ * fonts: [
36
+ * { name: 'Inter', data: interFont, weight: 400 },
37
+ * ],
38
+ * colors: {
39
+ * primary: '#3b82f6',
40
+ * },
41
+ * defaults: {
42
+ * width: 1200,
43
+ * height: 630,
44
+ * },
45
+ * });
46
+ *
47
+ * // Now render without repeating config
48
+ * const png = await render(OGImage, { props: { title: 'Hello' }, format: 'png' });
49
+ * ```
50
+ */
51
+ export declare function createRenderer(config: RendererConfig): RenderFunction;
52
+ //# sourceMappingURL=render.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"render.d.ts","sourceRoot":"","sources":["../../src/sdk/render.ts"],"names":[],"mappings":"AAAA;;GAEG;AAcH,OAAO,KAAK,EACV,QAAQ,EACR,aAAa,EACb,aAAa,EACb,YAAY,EACZ,cAAc,EACd,cAAc,EAKf,MAAM,YAAY,CAAC;AAyapB;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAsB,MAAM,CAAC,CAAC,SAAS,aAAa,EAClD,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,GACxB,OAAO,CAAC,YAAY,CAAC,CAiCvB;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,cAAc,GAAG,cAAc,CAkErE"}