@ai-sdk/angular 3.0.0-beta.9 → 3.0.0-beta.90

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,577 @@
1
1
  # @ai-sdk/angular
2
2
 
3
+ ## 3.0.0-beta.90
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies [1db29c8]
8
+ - ai@7.0.0-beta.90
9
+
10
+ ## 3.0.0-beta.89
11
+
12
+ ### Patch Changes
13
+
14
+ - Updated dependencies [b3976a2]
15
+ - Updated dependencies [ff5eba1]
16
+ - @ai-sdk/provider-utils@5.0.0-beta.20
17
+ - ai@7.0.0-beta.89
18
+
19
+ ## 3.0.0-beta.88
20
+
21
+ ### Major Changes
22
+
23
+ - ef992f8: Remove CommonJS exports from all packages. All packages are now ESM-only (`"type": "module"`). Consumers using `require()` must switch to ESM `import` syntax.
24
+
25
+ ### Patch Changes
26
+
27
+ - Updated dependencies [ef992f8]
28
+ - ai@7.0.0-beta.88
29
+ - @ai-sdk/provider-utils@5.0.0-beta.19
30
+
31
+ ## 3.0.0-beta.87
32
+
33
+ ### Patch Changes
34
+
35
+ - ai@7.0.0-beta.87
36
+
37
+ ## 3.0.0-beta.86
38
+
39
+ ### Patch Changes
40
+
41
+ - Updated dependencies [5a6f514]
42
+ - ai@7.0.0-beta.86
43
+
44
+ ## 3.0.0-beta.85
45
+
46
+ ### Patch Changes
47
+
48
+ - Updated dependencies [57bf606]
49
+ - ai@7.0.0-beta.85
50
+
51
+ ## 3.0.0-beta.84
52
+
53
+ ### Patch Changes
54
+
55
+ - Updated dependencies [90e2d8a]
56
+ - @ai-sdk/provider-utils@5.0.0-beta.18
57
+ - ai@7.0.0-beta.84
58
+
59
+ ## 3.0.0-beta.83
60
+
61
+ ### Patch Changes
62
+
63
+ - ai@7.0.0-beta.83
64
+
65
+ ## 3.0.0-beta.82
66
+
67
+ ### Patch Changes
68
+
69
+ - Updated dependencies [e27ed76]
70
+ - ai@7.0.0-beta.82
71
+
72
+ ## 3.0.0-beta.81
73
+
74
+ ### Patch Changes
75
+
76
+ - Updated dependencies [2fe1099]
77
+ - Updated dependencies [f04adcb]
78
+ - ai@7.0.0-beta.81
79
+
80
+ ## 3.0.0-beta.80
81
+
82
+ ### Patch Changes
83
+
84
+ - Updated dependencies [3ae1786]
85
+ - @ai-sdk/provider-utils@5.0.0-beta.17
86
+ - ai@7.0.0-beta.80
87
+
88
+ ## 3.0.0-beta.79
89
+
90
+ ### Patch Changes
91
+
92
+ - Updated dependencies [6866afe]
93
+ - ai@7.0.0-beta.79
94
+
95
+ ## 3.0.0-beta.78
96
+
97
+ ### Patch Changes
98
+
99
+ - Updated dependencies [f372547]
100
+ - ai@7.0.0-beta.78
101
+
102
+ ## 3.0.0-beta.77
103
+
104
+ ### Patch Changes
105
+
106
+ - Updated dependencies [2add429]
107
+ - ai@7.0.0-beta.77
108
+
109
+ ## 3.0.0-beta.76
110
+
111
+ ### Patch Changes
112
+
113
+ - Updated dependencies [fcc6869]
114
+ - ai@7.0.0-beta.76
115
+
116
+ ## 3.0.0-beta.75
117
+
118
+ ### Patch Changes
119
+
120
+ - Updated dependencies [176466a]
121
+ - ai@7.0.0-beta.75
122
+ - @ai-sdk/provider-utils@5.0.0-beta.16
123
+
124
+ ## 3.0.0-beta.74
125
+
126
+ ### Patch Changes
127
+
128
+ - Updated dependencies [e311194]
129
+ - ai@7.0.0-beta.74
130
+ - @ai-sdk/provider-utils@5.0.0-beta.15
131
+
132
+ ## 3.0.0-beta.73
133
+
134
+ ### Patch Changes
135
+
136
+ - ai@7.0.0-beta.73
137
+
138
+ ## 3.0.0-beta.72
139
+
140
+ ### Patch Changes
141
+
142
+ - Updated dependencies [664a0eb]
143
+ - ai@7.0.0-beta.72
144
+
145
+ ## 3.0.0-beta.71
146
+
147
+ ### Patch Changes
148
+
149
+ - Updated dependencies [e68be55]
150
+ - ai@7.0.0-beta.71
151
+
152
+ ## 3.0.0-beta.70
153
+
154
+ ### Patch Changes
155
+
156
+ - ai@7.0.0-beta.70
157
+
158
+ ## 3.0.0-beta.69
159
+
160
+ ### Patch Changes
161
+
162
+ - Updated dependencies [34bd95d]
163
+ - Updated dependencies [008271d]
164
+ - Updated dependencies [72223e7]
165
+ - ai@7.0.0-beta.69
166
+ - @ai-sdk/provider-utils@5.0.0-beta.14
167
+
168
+ ## 3.0.0-beta.68
169
+
170
+ ### Patch Changes
171
+
172
+ - Updated dependencies [b0c2869]
173
+ - Updated dependencies [7e26e81]
174
+ - @ai-sdk/provider-utils@5.0.0-beta.13
175
+ - ai@7.0.0-beta.68
176
+
177
+ ## 3.0.0-beta.67
178
+
179
+ ### Patch Changes
180
+
181
+ - Updated dependencies [d1a8bed]
182
+ - ai@7.0.0-beta.67
183
+
184
+ ## 3.0.0-beta.66
185
+
186
+ ### Patch Changes
187
+
188
+ - ai@7.0.0-beta.66
189
+
190
+ ## 3.0.0-beta.65
191
+
192
+ ### Patch Changes
193
+
194
+ - Updated dependencies [46d1149]
195
+ - @ai-sdk/provider-utils@5.0.0-beta.12
196
+ - ai@7.0.0-beta.65
197
+
198
+ ## 3.0.0-beta.64
199
+
200
+ ### Patch Changes
201
+
202
+ - ai@7.0.0-beta.64
203
+
204
+ ## 3.0.0-beta.63
205
+
206
+ ### Patch Changes
207
+
208
+ - Updated dependencies [6fd51c0]
209
+ - @ai-sdk/provider-utils@5.0.0-beta.11
210
+ - ai@7.0.0-beta.63
211
+
212
+ ## 3.0.0-beta.62
213
+
214
+ ### Patch Changes
215
+
216
+ - ai@7.0.0-beta.62
217
+
218
+ ## 3.0.0-beta.61
219
+
220
+ ### Patch Changes
221
+
222
+ - Updated dependencies [c29a26f]
223
+ - @ai-sdk/provider-utils@5.0.0-beta.10
224
+ - ai@7.0.0-beta.61
225
+
226
+ ## 3.0.0-beta.60
227
+
228
+ ### Patch Changes
229
+
230
+ - Updated dependencies [38fc777]
231
+ - ai@7.0.0-beta.60
232
+
233
+ ## 3.0.0-beta.59
234
+
235
+ ### Patch Changes
236
+
237
+ - ai@7.0.0-beta.59
238
+
239
+ ## 3.0.0-beta.58
240
+
241
+ ### Patch Changes
242
+
243
+ - Updated dependencies [2e17091]
244
+ - ai@7.0.0-beta.58
245
+ - @ai-sdk/provider-utils@5.0.0-beta.9
246
+
247
+ ## 3.0.0-beta.57
248
+
249
+ ### Patch Changes
250
+
251
+ - Updated dependencies [986c6fd]
252
+ - Updated dependencies [493295c]
253
+ - @ai-sdk/provider-utils@5.0.0-beta.8
254
+ - ai@7.0.0-beta.57
255
+
256
+ ## 3.0.0-beta.56
257
+
258
+ ### Patch Changes
259
+
260
+ - ai@7.0.0-beta.56
261
+
262
+ ## 3.0.0-beta.55
263
+
264
+ ### Patch Changes
265
+
266
+ - Updated dependencies [b3c9f6a]
267
+ - ai@7.0.0-beta.55
268
+
269
+ ## 3.0.0-beta.54
270
+
271
+ ### Patch Changes
272
+
273
+ - Updated dependencies [5d0f18e]
274
+ - ai@7.0.0-beta.54
275
+
276
+ ## 3.0.0-beta.53
277
+
278
+ ### Patch Changes
279
+
280
+ - Updated dependencies [9b47dea]
281
+ - ai@7.0.0-beta.53
282
+
283
+ ## 3.0.0-beta.52
284
+
285
+ ### Patch Changes
286
+
287
+ - Updated dependencies [b56301c]
288
+ - ai@7.0.0-beta.52
289
+
290
+ ## 3.0.0-beta.51
291
+
292
+ ### Patch Changes
293
+
294
+ - Updated dependencies [6abd098]
295
+ - ai@7.0.0-beta.51
296
+
297
+ ## 3.0.0-beta.50
298
+
299
+ ### Patch Changes
300
+
301
+ - Updated dependencies [3debdb7]
302
+ - ai@7.0.0-beta.50
303
+
304
+ ## 3.0.0-beta.49
305
+
306
+ ### Patch Changes
307
+
308
+ - ai@7.0.0-beta.49
309
+
310
+ ## 3.0.0-beta.48
311
+
312
+ ### Patch Changes
313
+
314
+ - Updated dependencies [5c4d910]
315
+ - ai@7.0.0-beta.48
316
+
317
+ ## 3.0.0-beta.47
318
+
319
+ ### Patch Changes
320
+
321
+ - Updated dependencies [bc67b4f]
322
+ - ai@7.0.0-beta.47
323
+
324
+ ## 3.0.0-beta.46
325
+
326
+ ### Patch Changes
327
+
328
+ - Updated dependencies [31ee822]
329
+ - ai@7.0.0-beta.46
330
+
331
+ ## 3.0.0-beta.45
332
+
333
+ ### Patch Changes
334
+
335
+ - ai@7.0.0-beta.45
336
+
337
+ ## 3.0.0-beta.44
338
+
339
+ ### Patch Changes
340
+
341
+ - ai@7.0.0-beta.44
342
+
343
+ ## 3.0.0-beta.43
344
+
345
+ ### Patch Changes
346
+
347
+ - ai@7.0.0-beta.43
348
+
349
+ ## 3.0.0-beta.42
350
+
351
+ ### Patch Changes
352
+
353
+ - Updated dependencies [a3fd75b]
354
+ - ai@7.0.0-beta.42
355
+
356
+ ## 3.0.0-beta.41
357
+
358
+ ### Patch Changes
359
+
360
+ - ai@7.0.0-beta.41
361
+
362
+ ## 3.0.0-beta.40
363
+
364
+ ### Patch Changes
365
+
366
+ - Updated dependencies [989d3d2]
367
+ - ai@7.0.0-beta.40
368
+
369
+ ## 3.0.0-beta.39
370
+
371
+ ### Patch Changes
372
+
373
+ - Updated dependencies [f4cfccd]
374
+ - ai@7.0.0-beta.39
375
+
376
+ ## 3.0.0-beta.38
377
+
378
+ ### Patch Changes
379
+
380
+ - Updated dependencies [1f509d4]
381
+ - @ai-sdk/provider-utils@5.0.0-beta.7
382
+ - ai@7.0.0-beta.38
383
+
384
+ ## 3.0.0-beta.37
385
+
386
+ ### Patch Changes
387
+
388
+ - ai@7.0.0-beta.37
389
+
390
+ ## 3.0.0-beta.36
391
+
392
+ ### Patch Changes
393
+
394
+ - Updated dependencies [118b953]
395
+ - ai@7.0.0-beta.36
396
+
397
+ ## 3.0.0-beta.35
398
+
399
+ ### Patch Changes
400
+
401
+ - Updated dependencies [99bf941]
402
+ - ai@7.0.0-beta.35
403
+
404
+ ## 3.0.0-beta.34
405
+
406
+ ### Patch Changes
407
+
408
+ - ai@7.0.0-beta.34
409
+
410
+ ## 3.0.0-beta.33
411
+
412
+ ### Patch Changes
413
+
414
+ - Updated dependencies [caf1b6f]
415
+ - ai@7.0.0-beta.33
416
+
417
+ ## 3.0.0-beta.32
418
+
419
+ ### Patch Changes
420
+
421
+ - Updated dependencies [4b46062]
422
+ - ai@7.0.0-beta.32
423
+
424
+ ## 3.0.0-beta.31
425
+
426
+ ### Patch Changes
427
+
428
+ - Updated dependencies [e79e644]
429
+ - ai@7.0.0-beta.31
430
+
431
+ ## 3.0.0-beta.30
432
+
433
+ ### Patch Changes
434
+
435
+ - Updated dependencies [f5a6f89]
436
+ - ai@7.0.0-beta.30
437
+
438
+ ## 3.0.0-beta.29
439
+
440
+ ### Patch Changes
441
+
442
+ - Updated dependencies [877bf12]
443
+ - ai@7.0.0-beta.29
444
+
445
+ ## 3.0.0-beta.28
446
+
447
+ ### Patch Changes
448
+
449
+ - Updated dependencies [b9cf502]
450
+ - ai@7.0.0-beta.28
451
+
452
+ ## 3.0.0-beta.27
453
+
454
+ ### Patch Changes
455
+
456
+ - Updated dependencies [3887c70]
457
+ - @ai-sdk/provider-utils@5.0.0-beta.6
458
+ - ai@7.0.0-beta.27
459
+
460
+ ## 3.0.0-beta.26
461
+
462
+ ### Patch Changes
463
+
464
+ - Updated dependencies [f0b0b20]
465
+ - ai@7.0.0-beta.26
466
+
467
+ ## 3.0.0-beta.25
468
+
469
+ ### Patch Changes
470
+
471
+ - Updated dependencies [ff9ce30]
472
+ - ai@7.0.0-beta.25
473
+
474
+ ## 3.0.0-beta.24
475
+
476
+ ### Patch Changes
477
+
478
+ - Updated dependencies [776b617]
479
+ - @ai-sdk/provider-utils@5.0.0-beta.5
480
+ - ai@7.0.0-beta.24
481
+
482
+ ## 3.0.0-beta.23
483
+
484
+ ### Patch Changes
485
+
486
+ - Updated dependencies [80d4dde]
487
+ - Updated dependencies [61753c3]
488
+ - ai@7.0.0-beta.23
489
+ - @ai-sdk/provider-utils@5.0.0-beta.4
490
+
491
+ ## 3.0.0-beta.22
492
+
493
+ ### Patch Changes
494
+
495
+ - ai@7.0.0-beta.22
496
+
497
+ ## 3.0.0-beta.21
498
+
499
+ ### Patch Changes
500
+
501
+ - Updated dependencies [34fd051]
502
+ - ai@7.0.0-beta.21
503
+
504
+ ## 3.0.0-beta.20
505
+
506
+ ### Patch Changes
507
+
508
+ - ai@7.0.0-beta.20
509
+
510
+ ## 3.0.0-beta.19
511
+
512
+ ### Patch Changes
513
+
514
+ - Updated dependencies [f7d4f01]
515
+ - @ai-sdk/provider-utils@5.0.0-beta.3
516
+ - ai@7.0.0-beta.19
517
+
518
+ ## 3.0.0-beta.18
519
+
520
+ ### Patch Changes
521
+
522
+ - ai@7.0.0-beta.18
523
+ - @ai-sdk/provider-utils@5.0.0-beta.2
524
+
525
+ ## 3.0.0-beta.17
526
+
527
+ ### Patch Changes
528
+
529
+ - ai@7.0.0-beta.17
530
+
531
+ ## 3.0.0-beta.16
532
+
533
+ ### Patch Changes
534
+
535
+ - Updated dependencies [5b8c58f]
536
+ - ai@7.0.0-beta.16
537
+
538
+ ## 3.0.0-beta.15
539
+
540
+ ### Patch Changes
541
+
542
+ - ai@7.0.0-beta.15
543
+
544
+ ## 3.0.0-beta.14
545
+
546
+ ### Patch Changes
547
+
548
+ - ai@7.0.0-beta.14
549
+
550
+ ## 3.0.0-beta.13
551
+
552
+ ### Patch Changes
553
+
554
+ - Updated dependencies [c26ca8d]
555
+ - ai@7.0.0-beta.13
556
+
557
+ ## 3.0.0-beta.12
558
+
559
+ ### Patch Changes
560
+
561
+ - ai@7.0.0-beta.12
562
+
563
+ ## 3.0.0-beta.11
564
+
565
+ ### Patch Changes
566
+
567
+ - ai@7.0.0-beta.11
568
+
569
+ ## 3.0.0-beta.10
570
+
571
+ ### Patch Changes
572
+
573
+ - ai@7.0.0-beta.10
574
+
3
575
  ## 3.0.0-beta.9
4
576
 
5
577
  ### Patch Changes
package/dist/index.js CHANGED
@@ -1,35 +1,9 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- Chat: () => Chat,
24
- Completion: () => Completion,
25
- StructuredObject: () => StructuredObject
26
- });
27
- module.exports = __toCommonJS(src_exports);
28
-
29
1
  // src/lib/chat.ng.ts
30
- var import_core = require("@angular/core");
31
- var import_ai = require("ai");
32
- var Chat = class extends import_ai.AbstractChat {
2
+ import { signal } from "@angular/core";
3
+ import {
4
+ AbstractChat
5
+ } from "ai";
6
+ var Chat = class extends AbstractChat {
33
7
  constructor(init) {
34
8
  super({
35
9
  ...init,
@@ -39,9 +13,9 @@ var Chat = class extends import_ai.AbstractChat {
39
13
  };
40
14
  var AngularChatState = class {
41
15
  constructor(initialMessages = []) {
42
- this.#messages = (0, import_core.signal)([]);
43
- this.#status = (0, import_core.signal)("ready");
44
- this.#error = (0, import_core.signal)(void 0);
16
+ this.#messages = signal([]);
17
+ this.#status = signal("ready");
18
+ this.#error = signal(void 0);
45
19
  this.setMessages = (messages) => {
46
20
  this.#messages.set([...messages]);
47
21
  };
@@ -85,16 +59,19 @@ var AngularChatState = class {
85
59
  };
86
60
 
87
61
  // src/lib/completion.ng.ts
88
- var import_core2 = require("@angular/core");
89
- var import_ai2 = require("ai");
90
- var import_provider_utils = require("@ai-sdk/provider-utils");
62
+ import { signal as signal2 } from "@angular/core";
63
+ import {
64
+ callCompletionApi,
65
+ generateId
66
+ } from "ai";
67
+ import { normalizeHeaders } from "@ai-sdk/provider-utils";
91
68
  var Completion = class {
92
69
  constructor(options = {}) {
93
70
  // Reactive state
94
- this.#input = (0, import_core2.signal)("");
95
- this.#completion = (0, import_core2.signal)("");
96
- this.#error = (0, import_core2.signal)(void 0);
97
- this.#loading = (0, import_core2.signal)(false);
71
+ this.#input = signal2("");
72
+ this.#completion = signal2("");
73
+ this.#error = signal2(void 0);
74
+ this.#loading = signal2(false);
98
75
  this.#abortController = null;
99
76
  /** Abort the current request immediately, keep the generated tokens if any. */
100
77
  this.stop = () => {
@@ -116,13 +93,13 @@ var Completion = class {
116
93
  }
117
94
  };
118
95
  this.#triggerRequest = async (prompt, options) => {
119
- return (0, import_ai2.callCompletionApi)({
96
+ return callCompletionApi({
120
97
  api: this.api,
121
98
  prompt,
122
99
  credentials: this.#options.credentials,
123
100
  headers: {
124
- ...(0, import_provider_utils.normalizeHeaders)(this.#options.headers),
125
- ...(0, import_provider_utils.normalizeHeaders)(options?.headers)
101
+ ...normalizeHeaders(this.#options.headers),
102
+ ...normalizeHeaders(options?.headers)
126
103
  },
127
104
  body: {
128
105
  ...this.#options.body,
@@ -150,7 +127,7 @@ var Completion = class {
150
127
  this.#completion.set(options.initialCompletion ?? "");
151
128
  this.#input.set(options.initialInput ?? "");
152
129
  this.api = options.api ?? "/api/completion";
153
- this.id = options.id ?? (0, import_ai2.generateId)();
130
+ this.id = options.id ?? generateId();
154
131
  this.streamProtocol = options.streamProtocol ?? "data";
155
132
  }
156
133
  #options;
@@ -185,15 +162,24 @@ var Completion = class {
185
162
  };
186
163
 
187
164
  // src/lib/structured-object.ng.ts
188
- var import_provider_utils2 = require("@ai-sdk/provider-utils");
189
- var import_core3 = require("@angular/core");
190
- var import_ai3 = require("ai");
165
+ import {
166
+ generateId as generateId2,
167
+ isAbortError,
168
+ normalizeHeaders as normalizeHeaders2,
169
+ safeValidateTypes
170
+ } from "@ai-sdk/provider-utils";
171
+ import { signal as signal3 } from "@angular/core";
172
+ import {
173
+ asSchema,
174
+ isDeepEqualData,
175
+ parsePartialJson
176
+ } from "ai";
191
177
  var StructuredObject = class {
192
178
  constructor(options) {
193
179
  // Reactive state
194
- this.#object = (0, import_core3.signal)(void 0);
195
- this.#loading = (0, import_core3.signal)(false);
196
- this.#error = (0, import_core3.signal)(void 0);
180
+ this.#object = signal3(void 0);
181
+ this.#loading = signal3(false);
182
+ this.#error = signal3(void 0);
197
183
  /**
198
184
  * Abort the current request immediately, keep the current partial object if any.
199
185
  */
@@ -221,7 +207,7 @@ var StructuredObject = class {
221
207
  method: "POST",
222
208
  headers: {
223
209
  "Content-Type": "application/json",
224
- ...(0, import_provider_utils2.normalizeHeaders)(this.options.headers)
210
+ ...normalizeHeaders2(this.options.headers)
225
211
  },
226
212
  credentials: this.options.credentials,
227
213
  signal: abortController.signal,
@@ -244,9 +230,9 @@ var StructuredObject = class {
244
230
  throw new DOMException("Stream aborted", "AbortError");
245
231
  }
246
232
  accumulatedText += chunk;
247
- const { value } = await (0, import_ai3.parsePartialJson)(accumulatedText);
233
+ const { value } = await parsePartialJson(accumulatedText);
248
234
  const currentObject = value;
249
- if (!(0, import_ai3.isDeepEqualData)(latestObject, currentObject)) {
235
+ if (!isDeepEqualData(latestObject, currentObject)) {
250
236
  latestObject = currentObject;
251
237
  this.#object.set(currentObject);
252
238
  }
@@ -255,9 +241,9 @@ var StructuredObject = class {
255
241
  this.#loading.set(false);
256
242
  this.#abortController = void 0;
257
243
  if (this.options.onFinish != null) {
258
- const validationResult = await (0, import_provider_utils2.safeValidateTypes)({
244
+ const validationResult = await safeValidateTypes({
259
245
  value: latestObject,
260
- schema: (0, import_ai3.asSchema)(this.options.schema)
246
+ schema: asSchema(this.options.schema)
261
247
  });
262
248
  if (validationResult.success) {
263
249
  this.options.onFinish({
@@ -275,7 +261,7 @@ var StructuredObject = class {
275
261
  })
276
262
  );
277
263
  } catch (error) {
278
- if ((0, import_provider_utils2.isAbortError)(error)) {
264
+ if (isAbortError(error)) {
279
265
  return;
280
266
  }
281
267
  const coalescedError = error instanceof Error ? error : new Error(String(error));
@@ -287,7 +273,7 @@ var StructuredObject = class {
287
273
  }
288
274
  };
289
275
  this.options = options;
290
- this.id = options.id ?? (0, import_provider_utils2.generateId)();
276
+ this.id = options.id ?? generateId2();
291
277
  this.#object.set(options.initialValue);
292
278
  }
293
279
  #abortController;
@@ -311,10 +297,9 @@ var StructuredObject = class {
311
297
  return this.#loading();
312
298
  }
313
299
  };
314
- // Annotate the CommonJS export names for ESM import in node:
315
- 0 && (module.exports = {
300
+ export {
316
301
  Chat,
317
302
  Completion,
318
303
  StructuredObject
319
- });
304
+ };
320
305
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/lib/chat.ng.ts","../src/lib/completion.ng.ts","../src/lib/structured-object.ng.ts"],"sourcesContent":["export { Chat } from './lib/chat.ng';\nexport { Completion, type CompletionOptions } from './lib/completion.ng';\nexport {\n StructuredObject,\n type StructuredObjectOptions,\n} from './lib/structured-object.ng';\n","import { signal } from '@angular/core';\nimport {\n type ChatState,\n type ChatStatus,\n type UIMessage,\n type ChatInit,\n AbstractChat,\n} from 'ai';\n\nexport class Chat<\n UI_MESSAGE extends UIMessage = UIMessage,\n> extends AbstractChat<UI_MESSAGE> {\n constructor(init: ChatInit<UI_MESSAGE>) {\n super({\n ...init,\n state: new AngularChatState(init.messages),\n });\n }\n}\n\nclass AngularChatState<UI_MESSAGE extends UIMessage = UIMessage>\n implements ChatState<UI_MESSAGE>\n{\n readonly #messages = signal<UI_MESSAGE[]>([]);\n readonly #status = signal<ChatStatus>('ready');\n readonly #error = signal<Error | undefined>(undefined);\n\n get messages(): UI_MESSAGE[] {\n return this.#messages();\n }\n\n set messages(messages: UI_MESSAGE[]) {\n this.#messages.set([...messages]);\n }\n\n get status(): ChatStatus {\n return this.#status();\n }\n\n set status(status: ChatStatus) {\n this.#status.set(status);\n }\n\n get error(): Error | undefined {\n return this.#error();\n }\n\n set error(error: Error | undefined) {\n this.#error.set(error);\n }\n\n constructor(initialMessages: UI_MESSAGE[] = []) {\n this.#messages.set([...initialMessages]);\n }\n\n setMessages = (messages: UI_MESSAGE[]) => {\n this.#messages.set([...messages]);\n };\n\n pushMessage = (message: UI_MESSAGE) => {\n this.#messages.update(msgs => [...msgs, message]);\n };\n\n popMessage = () => {\n this.#messages.update(msgs => msgs.slice(0, -1));\n };\n\n replaceMessage = (index: number, message: UI_MESSAGE) => {\n this.#messages.update(msgs => {\n const copy = [...msgs];\n copy[index] = message;\n return copy;\n });\n };\n\n snapshot = <T>(thing: T): T => structuredClone(thing);\n}\n","import { signal } from '@angular/core';\nimport {\n callCompletionApi,\n generateId,\n type CompletionRequestOptions,\n type UseCompletionOptions,\n} from 'ai';\nimport { normalizeHeaders } from '@ai-sdk/provider-utils';\n\nexport type CompletionOptions = Readonly<UseCompletionOptions>;\n\nexport class Completion {\n readonly #options: CompletionOptions;\n\n // Static config\n readonly id: string;\n readonly api: string;\n readonly streamProtocol: 'data' | 'text';\n\n // Reactive state\n readonly #input = signal('');\n readonly #completion = signal<string>('');\n readonly #error = signal<Error | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n\n #abortController: AbortController | null = null;\n\n constructor(options: CompletionOptions = {}) {\n this.#options = options;\n this.#completion.set(options.initialCompletion ?? '');\n this.#input.set(options.initialInput ?? '');\n this.api = options.api ?? '/api/completion';\n this.id = options.id ?? generateId();\n this.streamProtocol = options.streamProtocol ?? 'data';\n }\n\n /** Current value of the completion. Writable. */\n get completion(): string {\n return this.#completion();\n }\n set completion(value: string) {\n this.#completion.set(value);\n }\n\n /** Current value of the input. Writable. */\n get input(): string {\n return this.#input();\n }\n set input(value: string) {\n this.#input.set(value);\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /** Flag that indicates whether an API request is in progress. */\n get loading(): boolean {\n return this.#loading();\n }\n\n /** Abort the current request immediately, keep the generated tokens if any. */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = null;\n }\n };\n\n /** Send a new prompt to the API endpoint and update the completion state. */\n complete = async (prompt: string, options?: CompletionRequestOptions) =>\n this.#triggerRequest(prompt, options);\n\n /** Form submission handler to automatically reset input and call the completion API */\n handleSubmit = async (event?: { preventDefault?: () => void }) => {\n event?.preventDefault?.();\n if (this.#input()) {\n await this.complete(this.#input());\n }\n };\n\n #triggerRequest = async (\n prompt: string,\n options?: CompletionRequestOptions,\n ) => {\n return callCompletionApi({\n api: this.api,\n prompt,\n credentials: this.#options.credentials,\n headers: {\n ...normalizeHeaders(this.#options.headers),\n ...normalizeHeaders(options?.headers),\n },\n body: {\n ...this.#options.body,\n ...options?.body,\n },\n streamProtocol: this.streamProtocol,\n fetch: this.#options.fetch,\n setCompletion: (completion: string) => {\n this.#completion.set(completion);\n },\n setLoading: (loading: boolean) => {\n this.#loading.set(loading);\n },\n setError: (error: any) => {\n this.#error.set(error);\n },\n setAbortController: abortController => {\n this.#abortController = abortController ?? null;\n },\n onFinish: this.#options.onFinish,\n onError: this.#options.onError,\n });\n };\n}\n","import {\n generateId,\n isAbortError,\n normalizeHeaders,\n safeValidateTypes,\n type FetchFunction,\n type FlexibleSchema,\n type InferSchema,\n} from '@ai-sdk/provider-utils';\nimport { signal } from '@angular/core';\nimport {\n asSchema,\n isDeepEqualData,\n parsePartialJson,\n type DeepPartial,\n} from 'ai';\n\nexport type StructuredObjectOptions<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n> = {\n /**\n * The API endpoint. It should stream JSON that matches the schema as chunked text.\n */\n api: string;\n\n /**\n * A schema that defines the shape of the complete object.\n */\n schema: SCHEMA;\n\n /**\n * A unique identifier. If not provided, a random one will be\n * generated. When provided, the `useObject` hook with the same `id` will\n * have shared states across components.\n */\n id?: string;\n\n /**\n * An optional value for the initial object.\n */\n initialValue?: DeepPartial<RESULT>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * Callback that is called when the stream has finished.\n */\n onFinish?: (event: {\n /**\n * The generated object (typed according to the schema).\n * Can be undefined if the final object does not match the schema.\n */\n object: RESULT | undefined;\n\n /**\n * Optional error object. This is e.g. a TypeValidationError when the final object does not match the schema.\n */\n error: Error | undefined;\n }) => Promise<void> | void;\n\n /**\n * Callback function to be called when an error is encountered.\n */\n onError?: (error: Error) => void;\n\n /**\n * Additional HTTP headers to be included in the request.\n */\n headers?: Record<string, string> | Headers;\n\n /**\n * The credentials mode to be used for the fetch request.\n * Possible values are: 'omit', 'same-origin', 'include'.\n * Defaults to 'same-origin'.\n */\n credentials?: RequestCredentials;\n};\n\nexport class StructuredObject<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n INPUT = unknown,\n> {\n readonly options: StructuredObjectOptions<SCHEMA, RESULT>;\n readonly id: string;\n #abortController: AbortController | undefined;\n\n // Reactive state\n readonly #object = signal<DeepPartial<RESULT> | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n readonly #error = signal<Error | undefined>(undefined);\n\n /**\n * The current value for the generated object. Updated as the API streams JSON chunks.\n */\n get object(): DeepPartial<RESULT> | undefined {\n return this.#object();\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /**\n * Flag that indicates whether an API request is in progress.\n */\n get loading(): boolean {\n return this.#loading();\n }\n\n constructor(options: StructuredObjectOptions<SCHEMA, RESULT>) {\n this.options = options;\n this.id = options.id ?? generateId();\n this.#object.set(options.initialValue);\n }\n\n /**\n * Abort the current request immediately, keep the current partial object if any.\n */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = undefined;\n }\n };\n\n /**\n * Calls the API with the provided input as JSON body.\n */\n submit = async (input: INPUT) => {\n try {\n this.#object.set(undefined); // reset the data\n this.#loading.set(true);\n this.#error.set(undefined);\n\n const abortController = new AbortController();\n this.#abortController = abortController;\n\n const actualFetch = this.options.fetch ?? fetch;\n const response = await actualFetch(this.options.api, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...normalizeHeaders(this.options.headers),\n },\n credentials: this.options.credentials,\n signal: abortController.signal,\n body: JSON.stringify(input),\n });\n\n if (!response.ok) {\n throw new Error(\n (await response.text()) ?? 'Failed to fetch the response.',\n );\n }\n\n if (response.body == null) {\n throw new Error('The response body is empty.');\n }\n\n let accumulatedText = '';\n let latestObject: DeepPartial<RESULT> | undefined = undefined;\n\n await response.body.pipeThrough(new TextDecoderStream()).pipeTo(\n new WritableStream<string>({\n write: async chunk => {\n if (abortController?.signal.aborted) {\n throw new DOMException('Stream aborted', 'AbortError');\n }\n accumulatedText += chunk;\n\n const { value } = await parsePartialJson(accumulatedText);\n const currentObject = value as DeepPartial<RESULT>;\n\n if (!isDeepEqualData(latestObject, currentObject)) {\n latestObject = currentObject;\n\n this.#object.set(currentObject);\n }\n },\n\n close: async () => {\n this.#loading.set(false);\n this.#abortController = undefined;\n\n if (this.options.onFinish != null) {\n const validationResult = await safeValidateTypes({\n value: latestObject,\n schema: asSchema(this.options.schema),\n });\n\n if (validationResult.success) {\n this.options.onFinish({\n object: validationResult.value,\n error: undefined,\n });\n } else {\n this.options.onFinish({\n object: undefined,\n error: (validationResult as { error: Error }).error,\n });\n }\n }\n },\n }),\n );\n } catch (error) {\n if (isAbortError(error)) {\n return;\n }\n\n const coalescedError =\n error instanceof Error ? error : new Error(String(error));\n if (this.options.onError) {\n this.options.onError(coalescedError);\n }\n\n this.#loading.set(false);\n this.#error.set(coalescedError);\n }\n };\n}\n"],"mappings":"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","names":["import_core","import_ai","import_provider_utils","import_core","import_ai"]}
1
+ {"version":3,"sources":["../src/lib/chat.ng.ts","../src/lib/completion.ng.ts","../src/lib/structured-object.ng.ts"],"sourcesContent":["import { signal } from '@angular/core';\nimport {\n type ChatState,\n type ChatStatus,\n type UIMessage,\n type ChatInit,\n AbstractChat,\n} from 'ai';\n\nexport class Chat<\n UI_MESSAGE extends UIMessage = UIMessage,\n> extends AbstractChat<UI_MESSAGE> {\n constructor(init: ChatInit<UI_MESSAGE>) {\n super({\n ...init,\n state: new AngularChatState(init.messages),\n });\n }\n}\n\nclass AngularChatState<\n UI_MESSAGE extends UIMessage = UIMessage,\n> implements ChatState<UI_MESSAGE> {\n readonly #messages = signal<UI_MESSAGE[]>([]);\n readonly #status = signal<ChatStatus>('ready');\n readonly #error = signal<Error | undefined>(undefined);\n\n get messages(): UI_MESSAGE[] {\n return this.#messages();\n }\n\n set messages(messages: UI_MESSAGE[]) {\n this.#messages.set([...messages]);\n }\n\n get status(): ChatStatus {\n return this.#status();\n }\n\n set status(status: ChatStatus) {\n this.#status.set(status);\n }\n\n get error(): Error | undefined {\n return this.#error();\n }\n\n set error(error: Error | undefined) {\n this.#error.set(error);\n }\n\n constructor(initialMessages: UI_MESSAGE[] = []) {\n this.#messages.set([...initialMessages]);\n }\n\n setMessages = (messages: UI_MESSAGE[]) => {\n this.#messages.set([...messages]);\n };\n\n pushMessage = (message: UI_MESSAGE) => {\n this.#messages.update(msgs => [...msgs, message]);\n };\n\n popMessage = () => {\n this.#messages.update(msgs => msgs.slice(0, -1));\n };\n\n replaceMessage = (index: number, message: UI_MESSAGE) => {\n this.#messages.update(msgs => {\n const copy = [...msgs];\n copy[index] = message;\n return copy;\n });\n };\n\n snapshot = <T>(thing: T): T => structuredClone(thing);\n}\n","import { signal } from '@angular/core';\nimport {\n callCompletionApi,\n generateId,\n type CompletionRequestOptions,\n type UseCompletionOptions,\n} from 'ai';\nimport { normalizeHeaders } from '@ai-sdk/provider-utils';\n\nexport type CompletionOptions = Readonly<UseCompletionOptions>;\n\nexport class Completion {\n readonly #options: CompletionOptions;\n\n // Static config\n readonly id: string;\n readonly api: string;\n readonly streamProtocol: 'data' | 'text';\n\n // Reactive state\n readonly #input = signal('');\n readonly #completion = signal<string>('');\n readonly #error = signal<Error | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n\n #abortController: AbortController | null = null;\n\n constructor(options: CompletionOptions = {}) {\n this.#options = options;\n this.#completion.set(options.initialCompletion ?? '');\n this.#input.set(options.initialInput ?? '');\n this.api = options.api ?? '/api/completion';\n this.id = options.id ?? generateId();\n this.streamProtocol = options.streamProtocol ?? 'data';\n }\n\n /** Current value of the completion. Writable. */\n get completion(): string {\n return this.#completion();\n }\n set completion(value: string) {\n this.#completion.set(value);\n }\n\n /** Current value of the input. Writable. */\n get input(): string {\n return this.#input();\n }\n set input(value: string) {\n this.#input.set(value);\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /** Flag that indicates whether an API request is in progress. */\n get loading(): boolean {\n return this.#loading();\n }\n\n /** Abort the current request immediately, keep the generated tokens if any. */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = null;\n }\n };\n\n /** Send a new prompt to the API endpoint and update the completion state. */\n complete = async (prompt: string, options?: CompletionRequestOptions) =>\n this.#triggerRequest(prompt, options);\n\n /** Form submission handler to automatically reset input and call the completion API */\n handleSubmit = async (event?: { preventDefault?: () => void }) => {\n event?.preventDefault?.();\n if (this.#input()) {\n await this.complete(this.#input());\n }\n };\n\n #triggerRequest = async (\n prompt: string,\n options?: CompletionRequestOptions,\n ) => {\n return callCompletionApi({\n api: this.api,\n prompt,\n credentials: this.#options.credentials,\n headers: {\n ...normalizeHeaders(this.#options.headers),\n ...normalizeHeaders(options?.headers),\n },\n body: {\n ...this.#options.body,\n ...options?.body,\n },\n streamProtocol: this.streamProtocol,\n fetch: this.#options.fetch,\n setCompletion: (completion: string) => {\n this.#completion.set(completion);\n },\n setLoading: (loading: boolean) => {\n this.#loading.set(loading);\n },\n setError: (error: any) => {\n this.#error.set(error);\n },\n setAbortController: abortController => {\n this.#abortController = abortController ?? null;\n },\n onFinish: this.#options.onFinish,\n onError: this.#options.onError,\n });\n };\n}\n","import {\n generateId,\n isAbortError,\n normalizeHeaders,\n safeValidateTypes,\n type FetchFunction,\n type FlexibleSchema,\n type InferSchema,\n} from '@ai-sdk/provider-utils';\nimport { signal } from '@angular/core';\nimport {\n asSchema,\n isDeepEqualData,\n parsePartialJson,\n type DeepPartial,\n} from 'ai';\n\nexport type StructuredObjectOptions<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n> = {\n /**\n * The API endpoint. It should stream JSON that matches the schema as chunked text.\n */\n api: string;\n\n /**\n * A schema that defines the shape of the complete object.\n */\n schema: SCHEMA;\n\n /**\n * A unique identifier. If not provided, a random one will be\n * generated. When provided, the `useObject` hook with the same `id` will\n * have shared states across components.\n */\n id?: string;\n\n /**\n * An optional value for the initial object.\n */\n initialValue?: DeepPartial<RESULT>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * Callback that is called when the stream has finished.\n */\n onFinish?: (event: {\n /**\n * The generated object (typed according to the schema).\n * Can be undefined if the final object does not match the schema.\n */\n object: RESULT | undefined;\n\n /**\n * Optional error object. This is e.g. a TypeValidationError when the final object does not match the schema.\n */\n error: Error | undefined;\n }) => Promise<void> | void;\n\n /**\n * Callback function to be called when an error is encountered.\n */\n onError?: (error: Error) => void;\n\n /**\n * Additional HTTP headers to be included in the request.\n */\n headers?: Record<string, string> | Headers;\n\n /**\n * The credentials mode to be used for the fetch request.\n * Possible values are: 'omit', 'same-origin', 'include'.\n * Defaults to 'same-origin'.\n */\n credentials?: RequestCredentials;\n};\n\nexport class StructuredObject<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n INPUT = unknown,\n> {\n readonly options: StructuredObjectOptions<SCHEMA, RESULT>;\n readonly id: string;\n #abortController: AbortController | undefined;\n\n // Reactive state\n readonly #object = signal<DeepPartial<RESULT> | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n readonly #error = signal<Error | undefined>(undefined);\n\n /**\n * The current value for the generated object. Updated as the API streams JSON chunks.\n */\n get object(): DeepPartial<RESULT> | undefined {\n return this.#object();\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /**\n * Flag that indicates whether an API request is in progress.\n */\n get loading(): boolean {\n return this.#loading();\n }\n\n constructor(options: StructuredObjectOptions<SCHEMA, RESULT>) {\n this.options = options;\n this.id = options.id ?? generateId();\n this.#object.set(options.initialValue);\n }\n\n /**\n * Abort the current request immediately, keep the current partial object if any.\n */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = undefined;\n }\n };\n\n /**\n * Calls the API with the provided input as JSON body.\n */\n submit = async (input: INPUT) => {\n try {\n this.#object.set(undefined); // reset the data\n this.#loading.set(true);\n this.#error.set(undefined);\n\n const abortController = new AbortController();\n this.#abortController = abortController;\n\n const actualFetch = this.options.fetch ?? fetch;\n const response = await actualFetch(this.options.api, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...normalizeHeaders(this.options.headers),\n },\n credentials: this.options.credentials,\n signal: abortController.signal,\n body: JSON.stringify(input),\n });\n\n if (!response.ok) {\n throw new Error(\n (await response.text()) ?? 'Failed to fetch the response.',\n );\n }\n\n if (response.body == null) {\n throw new Error('The response body is empty.');\n }\n\n let accumulatedText = '';\n let latestObject: DeepPartial<RESULT> | undefined = undefined;\n\n await response.body.pipeThrough(new TextDecoderStream()).pipeTo(\n new WritableStream<string>({\n write: async chunk => {\n if (abortController?.signal.aborted) {\n throw new DOMException('Stream aborted', 'AbortError');\n }\n accumulatedText += chunk;\n\n const { value } = await parsePartialJson(accumulatedText);\n const currentObject = value as DeepPartial<RESULT>;\n\n if (!isDeepEqualData(latestObject, currentObject)) {\n latestObject = currentObject;\n\n this.#object.set(currentObject);\n }\n },\n\n close: async () => {\n this.#loading.set(false);\n this.#abortController = undefined;\n\n if (this.options.onFinish != null) {\n const validationResult = await safeValidateTypes({\n value: latestObject,\n schema: asSchema(this.options.schema),\n });\n\n if (validationResult.success) {\n this.options.onFinish({\n object: validationResult.value,\n error: undefined,\n });\n } else {\n this.options.onFinish({\n object: undefined,\n error: (validationResult as { error: Error }).error,\n });\n }\n }\n },\n }),\n );\n } catch (error) {\n if (isAbortError(error)) {\n return;\n }\n\n const coalescedError =\n error instanceof Error ? error : new Error(String(error));\n if (this.options.onError) {\n this.options.onError(coalescedError);\n }\n\n this.#loading.set(false);\n this.#error.set(coalescedError);\n }\n };\n}\n"],"mappings":"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","names":["signal","generateId","normalizeHeaders","signal"]}
package/package.json CHANGED
@@ -1,17 +1,17 @@
1
1
  {
2
2
  "name": "@ai-sdk/angular",
3
- "version": "3.0.0-beta.9",
3
+ "version": "3.0.0-beta.90",
4
+ "type": "module",
4
5
  "description": "Angular implementation of ai-sdk.",
5
6
  "license": "Apache-2.0",
6
- "main": "dist/index.cjs",
7
- "module": "dist/index.mjs",
7
+ "main": "dist/index.js",
8
8
  "types": "dist/index.d.ts",
9
9
  "exports": {
10
10
  "./package.json": "./package.json",
11
11
  ".": {
12
12
  "types": "./dist/index.d.ts",
13
- "import": "./dist/index.mjs",
14
- "require": "./dist/index.js"
13
+ "import": "./dist/index.js",
14
+ "default": "./dist/index.js"
15
15
  }
16
16
  },
17
17
  "files": [
@@ -25,20 +25,18 @@
25
25
  "README.md"
26
26
  ],
27
27
  "dependencies": {
28
- "@ai-sdk/provider-utils": "5.0.0-beta.1",
29
- "ai": "7.0.0-beta.9"
28
+ "@ai-sdk/provider-utils": "5.0.0-beta.20",
29
+ "ai": "7.0.0-beta.90"
30
30
  },
31
31
  "devDependencies": {
32
32
  "@types/node": "20.17.24",
33
- "eslint": "8.57.1",
34
33
  "jsdom": "^24.0.0",
35
34
  "tsup": "^7.2.0",
36
35
  "typescript": "5.8.3",
37
- "vitest": "^3.0.0",
36
+ "vitest": "^4.1.0",
38
37
  "zod": "3.25.76",
39
- "@ai-sdk/test-server": "2.0.0-beta.0",
40
- "@vercel/ai-tsconfig": "0.0.0",
41
- "eslint-config-vercel-ai": "0.0.0"
38
+ "@ai-sdk/test-server": "2.0.0-beta.1",
39
+ "@vercel/ai-tsconfig": "0.0.0"
42
40
  },
43
41
  "peerDependencies": {
44
42
  "@angular/core": ">=16.0.0"
@@ -50,9 +48,7 @@
50
48
  "build": "pnpm clean && tsup --tsconfig tsconfig.build.json",
51
49
  "build:watch": "pnpm clean && tsup --tsconfig tsconfig.build.json --watch",
52
50
  "clean": "del-cli dist *.tsbuildinfo",
53
- "lint": "eslint \"./**/*.ts*\"",
54
51
  "type-check": "tsc --build",
55
- "prettier-check": "prettier --check \"./**/*.ts*\"",
56
52
  "test": "vitest --config vitest.config.ts --run",
57
53
  "test:update": "vitest --config vitest.config.ts --run -u",
58
54
  "test:watch": "vitest --config vitest.config.ts"
@@ -18,9 +18,9 @@ export class Chat<
18
18
  }
19
19
  }
20
20
 
21
- class AngularChatState<UI_MESSAGE extends UIMessage = UIMessage>
22
- implements ChatState<UI_MESSAGE>
23
- {
21
+ class AngularChatState<
22
+ UI_MESSAGE extends UIMessage = UIMessage,
23
+ > implements ChatState<UI_MESSAGE> {
24
24
  readonly #messages = signal<UI_MESSAGE[]>([]);
25
25
  readonly #status = signal<ChatStatus>('ready');
26
26
  readonly #error = signal<Error | undefined>(undefined);
package/dist/index.d.mts DELETED
@@ -1,113 +0,0 @@
1
- import { UIMessage, AbstractChat, ChatInit, UseCompletionOptions, CompletionRequestOptions, DeepPartial } from 'ai';
2
- import { FlexibleSchema, InferSchema, FetchFunction } from '@ai-sdk/provider-utils';
3
-
4
- declare class Chat<UI_MESSAGE extends UIMessage = UIMessage> extends AbstractChat<UI_MESSAGE> {
5
- constructor(init: ChatInit<UI_MESSAGE>);
6
- }
7
-
8
- type CompletionOptions = Readonly<UseCompletionOptions>;
9
- declare class Completion {
10
- #private;
11
- readonly id: string;
12
- readonly api: string;
13
- readonly streamProtocol: 'data' | 'text';
14
- constructor(options?: CompletionOptions);
15
- /** Current value of the completion. Writable. */
16
- get completion(): string;
17
- set completion(value: string);
18
- /** Current value of the input. Writable. */
19
- get input(): string;
20
- set input(value: string);
21
- /** The error object of the API request */
22
- get error(): Error | undefined;
23
- /** Flag that indicates whether an API request is in progress. */
24
- get loading(): boolean;
25
- /** Abort the current request immediately, keep the generated tokens if any. */
26
- stop: () => void;
27
- /** Send a new prompt to the API endpoint and update the completion state. */
28
- complete: (prompt: string, options?: CompletionRequestOptions) => Promise<string | null | undefined>;
29
- /** Form submission handler to automatically reset input and call the completion API */
30
- handleSubmit: (event?: {
31
- preventDefault?: () => void;
32
- }) => Promise<void>;
33
- }
34
-
35
- type StructuredObjectOptions<SCHEMA extends FlexibleSchema, RESULT = InferSchema<SCHEMA>> = {
36
- /**
37
- * The API endpoint. It should stream JSON that matches the schema as chunked text.
38
- */
39
- api: string;
40
- /**
41
- * A schema that defines the shape of the complete object.
42
- */
43
- schema: SCHEMA;
44
- /**
45
- * A unique identifier. If not provided, a random one will be
46
- * generated. When provided, the `useObject` hook with the same `id` will
47
- * have shared states across components.
48
- */
49
- id?: string;
50
- /**
51
- * An optional value for the initial object.
52
- */
53
- initialValue?: DeepPartial<RESULT>;
54
- /**
55
- * Custom fetch implementation. You can use it as a middleware to intercept requests,
56
- * or to provide a custom fetch implementation for e.g. testing.
57
- */
58
- fetch?: FetchFunction;
59
- /**
60
- * Callback that is called when the stream has finished.
61
- */
62
- onFinish?: (event: {
63
- /**
64
- * The generated object (typed according to the schema).
65
- * Can be undefined if the final object does not match the schema.
66
- */
67
- object: RESULT | undefined;
68
- /**
69
- * Optional error object. This is e.g. a TypeValidationError when the final object does not match the schema.
70
- */
71
- error: Error | undefined;
72
- }) => Promise<void> | void;
73
- /**
74
- * Callback function to be called when an error is encountered.
75
- */
76
- onError?: (error: Error) => void;
77
- /**
78
- * Additional HTTP headers to be included in the request.
79
- */
80
- headers?: Record<string, string> | Headers;
81
- /**
82
- * The credentials mode to be used for the fetch request.
83
- * Possible values are: 'omit', 'same-origin', 'include'.
84
- * Defaults to 'same-origin'.
85
- */
86
- credentials?: RequestCredentials;
87
- };
88
- declare class StructuredObject<SCHEMA extends FlexibleSchema, RESULT = InferSchema<SCHEMA>, INPUT = unknown> {
89
- #private;
90
- readonly options: StructuredObjectOptions<SCHEMA, RESULT>;
91
- readonly id: string;
92
- /**
93
- * The current value for the generated object. Updated as the API streams JSON chunks.
94
- */
95
- get object(): DeepPartial<RESULT> | undefined;
96
- /** The error object of the API request */
97
- get error(): Error | undefined;
98
- /**
99
- * Flag that indicates whether an API request is in progress.
100
- */
101
- get loading(): boolean;
102
- constructor(options: StructuredObjectOptions<SCHEMA, RESULT>);
103
- /**
104
- * Abort the current request immediately, keep the current partial object if any.
105
- */
106
- stop: () => void;
107
- /**
108
- * Calls the API with the provided input as JSON body.
109
- */
110
- submit: (input: INPUT) => Promise<void>;
111
- }
112
-
113
- export { Chat, Completion, CompletionOptions, StructuredObject, StructuredObjectOptions };
package/dist/index.mjs DELETED
@@ -1,305 +0,0 @@
1
- // src/lib/chat.ng.ts
2
- import { signal } from "@angular/core";
3
- import {
4
- AbstractChat
5
- } from "ai";
6
- var Chat = class extends AbstractChat {
7
- constructor(init) {
8
- super({
9
- ...init,
10
- state: new AngularChatState(init.messages)
11
- });
12
- }
13
- };
14
- var AngularChatState = class {
15
- constructor(initialMessages = []) {
16
- this.#messages = signal([]);
17
- this.#status = signal("ready");
18
- this.#error = signal(void 0);
19
- this.setMessages = (messages) => {
20
- this.#messages.set([...messages]);
21
- };
22
- this.pushMessage = (message) => {
23
- this.#messages.update((msgs) => [...msgs, message]);
24
- };
25
- this.popMessage = () => {
26
- this.#messages.update((msgs) => msgs.slice(0, -1));
27
- };
28
- this.replaceMessage = (index, message) => {
29
- this.#messages.update((msgs) => {
30
- const copy = [...msgs];
31
- copy[index] = message;
32
- return copy;
33
- });
34
- };
35
- this.snapshot = (thing) => structuredClone(thing);
36
- this.#messages.set([...initialMessages]);
37
- }
38
- #messages;
39
- #status;
40
- #error;
41
- get messages() {
42
- return this.#messages();
43
- }
44
- set messages(messages) {
45
- this.#messages.set([...messages]);
46
- }
47
- get status() {
48
- return this.#status();
49
- }
50
- set status(status) {
51
- this.#status.set(status);
52
- }
53
- get error() {
54
- return this.#error();
55
- }
56
- set error(error) {
57
- this.#error.set(error);
58
- }
59
- };
60
-
61
- // src/lib/completion.ng.ts
62
- import { signal as signal2 } from "@angular/core";
63
- import {
64
- callCompletionApi,
65
- generateId
66
- } from "ai";
67
- import { normalizeHeaders } from "@ai-sdk/provider-utils";
68
- var Completion = class {
69
- constructor(options = {}) {
70
- // Reactive state
71
- this.#input = signal2("");
72
- this.#completion = signal2("");
73
- this.#error = signal2(void 0);
74
- this.#loading = signal2(false);
75
- this.#abortController = null;
76
- /** Abort the current request immediately, keep the generated tokens if any. */
77
- this.stop = () => {
78
- try {
79
- this.#abortController?.abort();
80
- } catch {
81
- } finally {
82
- this.#loading.set(false);
83
- this.#abortController = null;
84
- }
85
- };
86
- /** Send a new prompt to the API endpoint and update the completion state. */
87
- this.complete = async (prompt, options) => this.#triggerRequest(prompt, options);
88
- /** Form submission handler to automatically reset input and call the completion API */
89
- this.handleSubmit = async (event) => {
90
- event?.preventDefault?.();
91
- if (this.#input()) {
92
- await this.complete(this.#input());
93
- }
94
- };
95
- this.#triggerRequest = async (prompt, options) => {
96
- return callCompletionApi({
97
- api: this.api,
98
- prompt,
99
- credentials: this.#options.credentials,
100
- headers: {
101
- ...normalizeHeaders(this.#options.headers),
102
- ...normalizeHeaders(options?.headers)
103
- },
104
- body: {
105
- ...this.#options.body,
106
- ...options?.body
107
- },
108
- streamProtocol: this.streamProtocol,
109
- fetch: this.#options.fetch,
110
- setCompletion: (completion) => {
111
- this.#completion.set(completion);
112
- },
113
- setLoading: (loading) => {
114
- this.#loading.set(loading);
115
- },
116
- setError: (error) => {
117
- this.#error.set(error);
118
- },
119
- setAbortController: (abortController) => {
120
- this.#abortController = abortController ?? null;
121
- },
122
- onFinish: this.#options.onFinish,
123
- onError: this.#options.onError
124
- });
125
- };
126
- this.#options = options;
127
- this.#completion.set(options.initialCompletion ?? "");
128
- this.#input.set(options.initialInput ?? "");
129
- this.api = options.api ?? "/api/completion";
130
- this.id = options.id ?? generateId();
131
- this.streamProtocol = options.streamProtocol ?? "data";
132
- }
133
- #options;
134
- #input;
135
- #completion;
136
- #error;
137
- #loading;
138
- #abortController;
139
- /** Current value of the completion. Writable. */
140
- get completion() {
141
- return this.#completion();
142
- }
143
- set completion(value) {
144
- this.#completion.set(value);
145
- }
146
- /** Current value of the input. Writable. */
147
- get input() {
148
- return this.#input();
149
- }
150
- set input(value) {
151
- this.#input.set(value);
152
- }
153
- /** The error object of the API request */
154
- get error() {
155
- return this.#error();
156
- }
157
- /** Flag that indicates whether an API request is in progress. */
158
- get loading() {
159
- return this.#loading();
160
- }
161
- #triggerRequest;
162
- };
163
-
164
- // src/lib/structured-object.ng.ts
165
- import {
166
- generateId as generateId2,
167
- isAbortError,
168
- normalizeHeaders as normalizeHeaders2,
169
- safeValidateTypes
170
- } from "@ai-sdk/provider-utils";
171
- import { signal as signal3 } from "@angular/core";
172
- import {
173
- asSchema,
174
- isDeepEqualData,
175
- parsePartialJson
176
- } from "ai";
177
- var StructuredObject = class {
178
- constructor(options) {
179
- // Reactive state
180
- this.#object = signal3(void 0);
181
- this.#loading = signal3(false);
182
- this.#error = signal3(void 0);
183
- /**
184
- * Abort the current request immediately, keep the current partial object if any.
185
- */
186
- this.stop = () => {
187
- try {
188
- this.#abortController?.abort();
189
- } catch {
190
- } finally {
191
- this.#loading.set(false);
192
- this.#abortController = void 0;
193
- }
194
- };
195
- /**
196
- * Calls the API with the provided input as JSON body.
197
- */
198
- this.submit = async (input) => {
199
- try {
200
- this.#object.set(void 0);
201
- this.#loading.set(true);
202
- this.#error.set(void 0);
203
- const abortController = new AbortController();
204
- this.#abortController = abortController;
205
- const actualFetch = this.options.fetch ?? fetch;
206
- const response = await actualFetch(this.options.api, {
207
- method: "POST",
208
- headers: {
209
- "Content-Type": "application/json",
210
- ...normalizeHeaders2(this.options.headers)
211
- },
212
- credentials: this.options.credentials,
213
- signal: abortController.signal,
214
- body: JSON.stringify(input)
215
- });
216
- if (!response.ok) {
217
- throw new Error(
218
- await response.text() ?? "Failed to fetch the response."
219
- );
220
- }
221
- if (response.body == null) {
222
- throw new Error("The response body is empty.");
223
- }
224
- let accumulatedText = "";
225
- let latestObject = void 0;
226
- await response.body.pipeThrough(new TextDecoderStream()).pipeTo(
227
- new WritableStream({
228
- write: async (chunk) => {
229
- if (abortController?.signal.aborted) {
230
- throw new DOMException("Stream aborted", "AbortError");
231
- }
232
- accumulatedText += chunk;
233
- const { value } = await parsePartialJson(accumulatedText);
234
- const currentObject = value;
235
- if (!isDeepEqualData(latestObject, currentObject)) {
236
- latestObject = currentObject;
237
- this.#object.set(currentObject);
238
- }
239
- },
240
- close: async () => {
241
- this.#loading.set(false);
242
- this.#abortController = void 0;
243
- if (this.options.onFinish != null) {
244
- const validationResult = await safeValidateTypes({
245
- value: latestObject,
246
- schema: asSchema(this.options.schema)
247
- });
248
- if (validationResult.success) {
249
- this.options.onFinish({
250
- object: validationResult.value,
251
- error: void 0
252
- });
253
- } else {
254
- this.options.onFinish({
255
- object: void 0,
256
- error: validationResult.error
257
- });
258
- }
259
- }
260
- }
261
- })
262
- );
263
- } catch (error) {
264
- if (isAbortError(error)) {
265
- return;
266
- }
267
- const coalescedError = error instanceof Error ? error : new Error(String(error));
268
- if (this.options.onError) {
269
- this.options.onError(coalescedError);
270
- }
271
- this.#loading.set(false);
272
- this.#error.set(coalescedError);
273
- }
274
- };
275
- this.options = options;
276
- this.id = options.id ?? generateId2();
277
- this.#object.set(options.initialValue);
278
- }
279
- #abortController;
280
- #object;
281
- #loading;
282
- #error;
283
- /**
284
- * The current value for the generated object. Updated as the API streams JSON chunks.
285
- */
286
- get object() {
287
- return this.#object();
288
- }
289
- /** The error object of the API request */
290
- get error() {
291
- return this.#error();
292
- }
293
- /**
294
- * Flag that indicates whether an API request is in progress.
295
- */
296
- get loading() {
297
- return this.#loading();
298
- }
299
- };
300
- export {
301
- Chat,
302
- Completion,
303
- StructuredObject
304
- };
305
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/chat.ng.ts","../src/lib/completion.ng.ts","../src/lib/structured-object.ng.ts"],"sourcesContent":["import { signal } from '@angular/core';\nimport {\n type ChatState,\n type ChatStatus,\n type UIMessage,\n type ChatInit,\n AbstractChat,\n} from 'ai';\n\nexport class Chat<\n UI_MESSAGE extends UIMessage = UIMessage,\n> extends AbstractChat<UI_MESSAGE> {\n constructor(init: ChatInit<UI_MESSAGE>) {\n super({\n ...init,\n state: new AngularChatState(init.messages),\n });\n }\n}\n\nclass AngularChatState<UI_MESSAGE extends UIMessage = UIMessage>\n implements ChatState<UI_MESSAGE>\n{\n readonly #messages = signal<UI_MESSAGE[]>([]);\n readonly #status = signal<ChatStatus>('ready');\n readonly #error = signal<Error | undefined>(undefined);\n\n get messages(): UI_MESSAGE[] {\n return this.#messages();\n }\n\n set messages(messages: UI_MESSAGE[]) {\n this.#messages.set([...messages]);\n }\n\n get status(): ChatStatus {\n return this.#status();\n }\n\n set status(status: ChatStatus) {\n this.#status.set(status);\n }\n\n get error(): Error | undefined {\n return this.#error();\n }\n\n set error(error: Error | undefined) {\n this.#error.set(error);\n }\n\n constructor(initialMessages: UI_MESSAGE[] = []) {\n this.#messages.set([...initialMessages]);\n }\n\n setMessages = (messages: UI_MESSAGE[]) => {\n this.#messages.set([...messages]);\n };\n\n pushMessage = (message: UI_MESSAGE) => {\n this.#messages.update(msgs => [...msgs, message]);\n };\n\n popMessage = () => {\n this.#messages.update(msgs => msgs.slice(0, -1));\n };\n\n replaceMessage = (index: number, message: UI_MESSAGE) => {\n this.#messages.update(msgs => {\n const copy = [...msgs];\n copy[index] = message;\n return copy;\n });\n };\n\n snapshot = <T>(thing: T): T => structuredClone(thing);\n}\n","import { signal } from '@angular/core';\nimport {\n callCompletionApi,\n generateId,\n type CompletionRequestOptions,\n type UseCompletionOptions,\n} from 'ai';\nimport { normalizeHeaders } from '@ai-sdk/provider-utils';\n\nexport type CompletionOptions = Readonly<UseCompletionOptions>;\n\nexport class Completion {\n readonly #options: CompletionOptions;\n\n // Static config\n readonly id: string;\n readonly api: string;\n readonly streamProtocol: 'data' | 'text';\n\n // Reactive state\n readonly #input = signal('');\n readonly #completion = signal<string>('');\n readonly #error = signal<Error | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n\n #abortController: AbortController | null = null;\n\n constructor(options: CompletionOptions = {}) {\n this.#options = options;\n this.#completion.set(options.initialCompletion ?? '');\n this.#input.set(options.initialInput ?? '');\n this.api = options.api ?? '/api/completion';\n this.id = options.id ?? generateId();\n this.streamProtocol = options.streamProtocol ?? 'data';\n }\n\n /** Current value of the completion. Writable. */\n get completion(): string {\n return this.#completion();\n }\n set completion(value: string) {\n this.#completion.set(value);\n }\n\n /** Current value of the input. Writable. */\n get input(): string {\n return this.#input();\n }\n set input(value: string) {\n this.#input.set(value);\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /** Flag that indicates whether an API request is in progress. */\n get loading(): boolean {\n return this.#loading();\n }\n\n /** Abort the current request immediately, keep the generated tokens if any. */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = null;\n }\n };\n\n /** Send a new prompt to the API endpoint and update the completion state. */\n complete = async (prompt: string, options?: CompletionRequestOptions) =>\n this.#triggerRequest(prompt, options);\n\n /** Form submission handler to automatically reset input and call the completion API */\n handleSubmit = async (event?: { preventDefault?: () => void }) => {\n event?.preventDefault?.();\n if (this.#input()) {\n await this.complete(this.#input());\n }\n };\n\n #triggerRequest = async (\n prompt: string,\n options?: CompletionRequestOptions,\n ) => {\n return callCompletionApi({\n api: this.api,\n prompt,\n credentials: this.#options.credentials,\n headers: {\n ...normalizeHeaders(this.#options.headers),\n ...normalizeHeaders(options?.headers),\n },\n body: {\n ...this.#options.body,\n ...options?.body,\n },\n streamProtocol: this.streamProtocol,\n fetch: this.#options.fetch,\n setCompletion: (completion: string) => {\n this.#completion.set(completion);\n },\n setLoading: (loading: boolean) => {\n this.#loading.set(loading);\n },\n setError: (error: any) => {\n this.#error.set(error);\n },\n setAbortController: abortController => {\n this.#abortController = abortController ?? null;\n },\n onFinish: this.#options.onFinish,\n onError: this.#options.onError,\n });\n };\n}\n","import {\n generateId,\n isAbortError,\n normalizeHeaders,\n safeValidateTypes,\n type FetchFunction,\n type FlexibleSchema,\n type InferSchema,\n} from '@ai-sdk/provider-utils';\nimport { signal } from '@angular/core';\nimport {\n asSchema,\n isDeepEqualData,\n parsePartialJson,\n type DeepPartial,\n} from 'ai';\n\nexport type StructuredObjectOptions<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n> = {\n /**\n * The API endpoint. It should stream JSON that matches the schema as chunked text.\n */\n api: string;\n\n /**\n * A schema that defines the shape of the complete object.\n */\n schema: SCHEMA;\n\n /**\n * A unique identifier. If not provided, a random one will be\n * generated. When provided, the `useObject` hook with the same `id` will\n * have shared states across components.\n */\n id?: string;\n\n /**\n * An optional value for the initial object.\n */\n initialValue?: DeepPartial<RESULT>;\n\n /**\n * Custom fetch implementation. You can use it as a middleware to intercept requests,\n * or to provide a custom fetch implementation for e.g. testing.\n */\n fetch?: FetchFunction;\n\n /**\n * Callback that is called when the stream has finished.\n */\n onFinish?: (event: {\n /**\n * The generated object (typed according to the schema).\n * Can be undefined if the final object does not match the schema.\n */\n object: RESULT | undefined;\n\n /**\n * Optional error object. This is e.g. a TypeValidationError when the final object does not match the schema.\n */\n error: Error | undefined;\n }) => Promise<void> | void;\n\n /**\n * Callback function to be called when an error is encountered.\n */\n onError?: (error: Error) => void;\n\n /**\n * Additional HTTP headers to be included in the request.\n */\n headers?: Record<string, string> | Headers;\n\n /**\n * The credentials mode to be used for the fetch request.\n * Possible values are: 'omit', 'same-origin', 'include'.\n * Defaults to 'same-origin'.\n */\n credentials?: RequestCredentials;\n};\n\nexport class StructuredObject<\n SCHEMA extends FlexibleSchema,\n RESULT = InferSchema<SCHEMA>,\n INPUT = unknown,\n> {\n readonly options: StructuredObjectOptions<SCHEMA, RESULT>;\n readonly id: string;\n #abortController: AbortController | undefined;\n\n // Reactive state\n readonly #object = signal<DeepPartial<RESULT> | undefined>(undefined);\n readonly #loading = signal<boolean>(false);\n readonly #error = signal<Error | undefined>(undefined);\n\n /**\n * The current value for the generated object. Updated as the API streams JSON chunks.\n */\n get object(): DeepPartial<RESULT> | undefined {\n return this.#object();\n }\n\n /** The error object of the API request */\n get error(): Error | undefined {\n return this.#error();\n }\n\n /**\n * Flag that indicates whether an API request is in progress.\n */\n get loading(): boolean {\n return this.#loading();\n }\n\n constructor(options: StructuredObjectOptions<SCHEMA, RESULT>) {\n this.options = options;\n this.id = options.id ?? generateId();\n this.#object.set(options.initialValue);\n }\n\n /**\n * Abort the current request immediately, keep the current partial object if any.\n */\n stop = () => {\n try {\n this.#abortController?.abort();\n } catch {\n // ignore\n } finally {\n this.#loading.set(false);\n this.#abortController = undefined;\n }\n };\n\n /**\n * Calls the API with the provided input as JSON body.\n */\n submit = async (input: INPUT) => {\n try {\n this.#object.set(undefined); // reset the data\n this.#loading.set(true);\n this.#error.set(undefined);\n\n const abortController = new AbortController();\n this.#abortController = abortController;\n\n const actualFetch = this.options.fetch ?? fetch;\n const response = await actualFetch(this.options.api, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...normalizeHeaders(this.options.headers),\n },\n credentials: this.options.credentials,\n signal: abortController.signal,\n body: JSON.stringify(input),\n });\n\n if (!response.ok) {\n throw new Error(\n (await response.text()) ?? 'Failed to fetch the response.',\n );\n }\n\n if (response.body == null) {\n throw new Error('The response body is empty.');\n }\n\n let accumulatedText = '';\n let latestObject: DeepPartial<RESULT> | undefined = undefined;\n\n await response.body.pipeThrough(new TextDecoderStream()).pipeTo(\n new WritableStream<string>({\n write: async chunk => {\n if (abortController?.signal.aborted) {\n throw new DOMException('Stream aborted', 'AbortError');\n }\n accumulatedText += chunk;\n\n const { value } = await parsePartialJson(accumulatedText);\n const currentObject = value as DeepPartial<RESULT>;\n\n if (!isDeepEqualData(latestObject, currentObject)) {\n latestObject = currentObject;\n\n this.#object.set(currentObject);\n }\n },\n\n close: async () => {\n this.#loading.set(false);\n this.#abortController = undefined;\n\n if (this.options.onFinish != null) {\n const validationResult = await safeValidateTypes({\n value: latestObject,\n schema: asSchema(this.options.schema),\n });\n\n if (validationResult.success) {\n this.options.onFinish({\n object: validationResult.value,\n error: undefined,\n });\n } else {\n this.options.onFinish({\n object: undefined,\n error: (validationResult as { error: Error }).error,\n });\n }\n }\n },\n }),\n );\n } catch (error) {\n if (isAbortError(error)) {\n return;\n }\n\n const coalescedError =\n error instanceof Error ? error : new Error(String(error));\n if (this.options.onError) {\n this.options.onError(coalescedError);\n }\n\n this.#loading.set(false);\n this.#error.set(coalescedError);\n }\n };\n}\n"],"mappings":"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","names":["signal","generateId","normalizeHeaders","signal"]}