@builder.io/ai-utils 0.3.11 → 0.3.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # Builder.io AI types and utilities
2
+
3
+ Shared types between AI systems, threads, servers, etc.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@builder.io/ai-utils",
3
- "version": "0.3.11",
3
+ "version": "0.3.12",
4
4
  "description": "Builder.io AI utils",
5
5
  "type": "module",
6
6
  "main": "src/index.js",
package/src/codegen.ts ADDED
@@ -0,0 +1,667 @@
1
+ import type {
2
+ Attachment,
3
+ ContentMessageItemToolResult,
4
+ UserMessageParam,
5
+ } from "./messages";
6
+
7
+ import type { BuilderContent } from "./completion";
8
+
9
+ import type { Options as PrettierOptions } from "prettier";
10
+ import type { UserContext } from "./mapping";
11
+ import type { AssistantMessageParam } from "./messages";
12
+
13
+ // Define the import type as a union of literal types.
14
+ export type ImportType = "named" | "default";
15
+
16
+ // Define an interface for the import descriptor.
17
+ export interface ESMImport {
18
+ importName: string; // e.g. "Button"
19
+ importPath: string; // e.g. "path"
20
+ importType: ImportType; // Either 'named' or 'default'
21
+ }
22
+
23
+ export interface ProjectFile {
24
+ filePath: string;
25
+ content?: string;
26
+ importance?: number;
27
+ dropReason?: string;
28
+ wasIncluded?: boolean;
29
+ }
30
+
31
+ export interface CustomInstruction {
32
+ id: string;
33
+ name: string;
34
+ content: string;
35
+ type?: "always" | "agent-mode";
36
+ filePath?: string;
37
+ glob?: string;
38
+ description?: string;
39
+ }
40
+
41
+ export type CodeGenFramework =
42
+ | "react"
43
+ | "html"
44
+ | "mitosis"
45
+ | "react-native"
46
+ | "angular"
47
+ | "vue"
48
+ | "svelte"
49
+ | "qwik"
50
+ | "solid"
51
+ | "marko"
52
+ | "swiftui"
53
+ | "jetpack-compose"
54
+ | "flutter";
55
+
56
+ export type CodeGenStyleLibrary =
57
+ | "tailwind"
58
+ | "tailwind-precise"
59
+ | "emotion"
60
+ | "styled-components"
61
+ | "styled-jsx"
62
+ | "react-native"
63
+ | undefined;
64
+
65
+ export type CompletionStopReason =
66
+ | "max_tokens"
67
+ | "stop_sequence"
68
+ | "tool_use"
69
+ | "end_turn"
70
+ | "content_filter"
71
+ | "error"
72
+ | "aborted"
73
+ | "pause_turn"
74
+ | "refusal"
75
+ | null;
76
+
77
+ export interface ViewPathToolInput {
78
+ file_path: string;
79
+ view_range?: [number, number];
80
+ }
81
+
82
+ export interface GlobSearchToolInput {
83
+ pattern: string;
84
+ }
85
+
86
+ export interface GrepSearchToolInput {
87
+ query: string;
88
+ include_glob?: string;
89
+ exclude_glob?: string;
90
+ }
91
+
92
+ export interface GetRuleToolInput {
93
+ name: string;
94
+ }
95
+
96
+ export interface GetStyleInspirationToolInput {
97
+ prompt: string;
98
+ }
99
+
100
+ export interface GetBuildOutputToolInput {}
101
+ export interface DevServerControlInput {
102
+ restart?: boolean;
103
+ get_logs?: boolean;
104
+ }
105
+
106
+ export interface BashToolInput {
107
+ command?: string;
108
+ restart?: boolean;
109
+ }
110
+
111
+ export interface WebSearchToolInput {
112
+ query: string;
113
+ }
114
+
115
+ export interface WriteFileInput {
116
+ title: string;
117
+ file_path: string;
118
+ content: string;
119
+ }
120
+
121
+ export interface SearchReplaceInput {
122
+ title: string;
123
+ file_path: string;
124
+ old_str: string;
125
+ new_str: string;
126
+ }
127
+
128
+ export interface CodeGenToolMap {
129
+ view_path: ViewPathToolInput;
130
+ glob_search: GlobSearchToolInput;
131
+ grep_search: GrepSearchToolInput;
132
+ get_rule: GetRuleToolInput;
133
+ get_style_inspiration: GetStyleInspirationToolInput;
134
+ get_build_output: GetBuildOutputToolInput;
135
+ dev_server_control: DevServerControlInput;
136
+ bash: BashToolInput;
137
+ web_search: WebSearchToolInput;
138
+ write_file: WriteFileInput;
139
+ search_replace_file: SearchReplaceInput;
140
+ }
141
+
142
+ export type CodeGenTools = keyof CodeGenToolMap;
143
+
144
+ export type AllCodeGenTools =
145
+ | CodeGenTools
146
+ | "str_replace_editor"
147
+ | "web_search";
148
+
149
+ export type CodeGenMode =
150
+ | "exact" // @deprecated
151
+ | "precise" // tries to match the design as close
152
+ | "precise_vision" // tries to match the design as close, also uses vision to match
153
+ | "creative" // adapts the design to some generic design language
154
+ | "creative_vision" // adapts the design to some generic design language, also uses vision to match
155
+ | "creative_only_vision"; // adapts the design to some generic design language, but only uses vision to match
156
+
157
+ export interface CodeGenInputOptions {
158
+ position: string;
159
+ eventName?: string;
160
+ sessionId: string;
161
+
162
+ codeGenMode?: "fast" | "quality" | "quality-v3";
163
+ url?: string;
164
+ diffActions?: boolean;
165
+ planningPrompt?: boolean;
166
+ customInstructions?: CustomInstruction[];
167
+ userPrompt?: string;
168
+ ephemeralUserPrompt?: string;
169
+ displayUserPrompt?: string;
170
+ files?: ProjectFile[];
171
+ rerankFiles?: number;
172
+ toolResults?: ContentMessageItemToolResult[];
173
+ attachments?: Attachment[];
174
+ beforeCommit?: string;
175
+ workingDirectory?: string;
176
+
177
+ // Code options
178
+ builderContent?: BuilderContent;
179
+ framework?: CodeGenFramework;
180
+ styleLibrary?: CodeGenStyleLibrary;
181
+ typescript?: boolean;
182
+ userContext?: UserContext;
183
+
184
+ enabledTools?: CodeGenTools[];
185
+
186
+ // Options
187
+ maxTokens?: number;
188
+ maxPages?: number;
189
+ autoContinue?: number;
190
+ promptCaching?: boolean;
191
+ llmSuggestions?: boolean;
192
+ conclusionText?: boolean;
193
+
194
+ searchResponse?: any | null;
195
+
196
+ // Prettier options
197
+ prettierConfig?: PrettierOptions;
198
+
199
+ // Role
200
+ role?: "user" | "agent";
201
+ user?: UserSource;
202
+
203
+ /** @deprecated */
204
+ history?: (UserMessageParam | AssistantMessageParam)[];
205
+ /** @deprecated */
206
+ prevId?: string;
207
+ /** @deprecated */
208
+ nextPage?: boolean;
209
+ /** @deprecated */
210
+ vcpId?: string;
211
+ }
212
+
213
+ export type Feature = "component-mapping";
214
+
215
+ export interface CodegenUsage {
216
+ total: number;
217
+ fast: number;
218
+ quality: number;
219
+ features: Feature[];
220
+ limits: {
221
+ aiGeneration: number;
222
+ aiGenerationContextWindow: number;
223
+ };
224
+ }
225
+
226
+ export interface PromptSuggestion {
227
+ type:
228
+ | "missing-imports"
229
+ | "lazy-code"
230
+ | "no-file-for-diff"
231
+ | "syntax-error"
232
+ | "llm-suggested"
233
+ | "diff-apply";
234
+
235
+ filePath?: string;
236
+ line?: number;
237
+ importance: "high" | "medium" | "low";
238
+ column?: number;
239
+ summary: string;
240
+ prompt: string;
241
+ }
242
+
243
+ export interface ActionItem {
244
+ type:
245
+ | "file"
246
+ | "text"
247
+ | "diff"
248
+ | "thinking"
249
+ | "tool"
250
+ | "suggestion"
251
+ | "tool_result"
252
+ | "server_tool_result";
253
+ id?: string;
254
+ content: string;
255
+ filePath?: string;
256
+ artifactTitle?: string;
257
+ actionTitle?: string;
258
+ synthetic?: boolean;
259
+ incomplete?: boolean;
260
+ suggestions?: PromptSuggestion[];
261
+ errors?: string[];
262
+ }
263
+
264
+ export interface RepoInfo {
265
+ remoteUrl: string;
266
+ defaultBranch: string;
267
+ currentBranch: string;
268
+ commit: string;
269
+ }
270
+
271
+ export interface CodebaseSearchOptions {
272
+ repoInfo?: RepoInfo;
273
+ query: string;
274
+ selectedFiles?: string[];
275
+ sessionId: string;
276
+ files?: string[];
277
+ packageJson?: string;
278
+ limit?: number;
279
+ includeContent?: boolean;
280
+ }
281
+
282
+ export interface CodebaseSearchResponse {
283
+ id: string;
284
+ relevantPaths: string[];
285
+ grepQueries: string[];
286
+ streamMeta: any;
287
+ ranked: RankedResult[];
288
+ }
289
+
290
+ export interface RankedResult {
291
+ index: number;
292
+ filePath: string;
293
+ startIndex: number;
294
+ endIndex: number;
295
+ score: number;
296
+ id: string;
297
+ content?: string;
298
+ }
299
+
300
+ export interface GenerateCompletionStepThinking {
301
+ type: "thinking";
302
+ }
303
+
304
+ export interface FileInfo {
305
+ filePath: string;
306
+ size: number;
307
+ isCustomInstruction: boolean;
308
+ }
309
+
310
+ export interface GenerateCompletionStepUserInput {
311
+ type: "user-input";
312
+ prompt: string;
313
+ files: FileInfo[];
314
+ }
315
+
316
+ export interface GenerateCompletionStepToolResult {
317
+ type: "agent-input";
318
+ toolResults: ContentMessageItemToolResult[];
319
+ }
320
+
321
+ export interface GenerateCompletionStepPlanning {
322
+ type: "planning";
323
+ content: string;
324
+ }
325
+
326
+ export interface GenerateCompletionStepUser {
327
+ type: "user";
328
+ displayPrompt: string | undefined;
329
+ id: string;
330
+ role: "user" | "agent";
331
+ }
332
+
333
+ export interface GenerateCompletionStepFile {
334
+ type: "file";
335
+ filePath: string;
336
+ content: string;
337
+ title: string;
338
+ id: string;
339
+ }
340
+
341
+ export interface GenerateCompletionStepDiff {
342
+ type: "diff";
343
+ filePath: string;
344
+ content: string;
345
+ title: string;
346
+ id: string;
347
+ }
348
+
349
+ export interface GenerateCompletionStepTool {
350
+ type: "tool";
351
+ name: string;
352
+ id: string;
353
+ content: string;
354
+ }
355
+
356
+ export interface GenerateCompletionStepText {
357
+ type: "text";
358
+ content: string;
359
+ }
360
+
361
+ export interface GenerateCompletionStepDone {
362
+ type: "done";
363
+ id: string;
364
+ applyResults: ApplyActionsResult[];
365
+ actions: ActionItem[];
366
+ usage: CodegenUsage | undefined;
367
+ url?: string;
368
+ stopReason: CompletionStopReason;
369
+ hasChanges: boolean;
370
+ }
371
+
372
+ export interface GenerateCompletionStepStart {
373
+ type: "start";
374
+ name: string;
375
+ id: string | undefined;
376
+ title: string;
377
+ content: string;
378
+ filePath?: string;
379
+ }
380
+
381
+ export interface GenerateCompletionStepDelta {
382
+ type: "delta";
383
+ name: string;
384
+ delta: string;
385
+ }
386
+
387
+ export interface GenerateCompletionStepError {
388
+ type: "error";
389
+ id?: string;
390
+ stopReason?: "error" | "limit";
391
+ metadata?: any;
392
+ message: string;
393
+ usage?: CodegenUsage;
394
+ contextPrompt?: string;
395
+ }
396
+
397
+ export interface GenerateCompletionStepContinue {
398
+ type: "continue";
399
+ id: string;
400
+ url: string;
401
+ }
402
+
403
+ export interface CodeGenHealthStatus {
404
+ devServerRunning: boolean;
405
+ devServerResponding: boolean;
406
+ logs: string | undefined;
407
+ lastInstallFailed: boolean;
408
+ checkLogs: string;
409
+ checkPassed: boolean;
410
+ prompt: string;
411
+ message: string;
412
+ }
413
+
414
+ export interface SuggestedActionBase {
415
+ level: "info" | "warning" | "error";
416
+ canAutoApply: boolean;
417
+ actionButtonText: string;
418
+ message: string;
419
+ userMessage: GenerateUserMessage;
420
+ }
421
+
422
+ export interface SuggestedActionBuildError extends SuggestedActionBase {
423
+ type: "build-error";
424
+ healthStatus: CodeGenHealthStatus;
425
+ }
426
+
427
+ export type SuggestedAction = SuggestedActionBuildError;
428
+
429
+ export interface GenerateCompletionStepWaitForInput {
430
+ type: "wait-for-input";
431
+ state: GenerateCompletionState;
432
+ suggestion?: SuggestedAction;
433
+ }
434
+
435
+ export interface GenerateCompletionStepAbort {
436
+ type: "user-abort";
437
+ }
438
+
439
+ export interface GenerateCompletionStepRestore {
440
+ type: "restore";
441
+ location: "before" | "after";
442
+ files: string[];
443
+ lastCompletionId: string | undefined;
444
+ commitHash: string | undefined;
445
+ }
446
+
447
+ export type GenerateCompletionState =
448
+ | "unknown"
449
+ | "initial-with-url"
450
+ | "initial-without-url"
451
+ | "generating"
452
+ | "success"
453
+ | "abort"
454
+ | "error"
455
+ | "close";
456
+
457
+ export interface GenerateCompletionStepState {
458
+ type: "state";
459
+ previousState: GenerateCompletionState;
460
+ newState: GenerateCompletionState;
461
+ }
462
+
463
+ export interface GenerateCompletionStepClose {
464
+ type: "close";
465
+ }
466
+
467
+ export interface GenerateCompletionStepStdio {
468
+ type: "stdio";
469
+ command: string;
470
+ stream: "stdout" | "stderr";
471
+ source: "run-command" | "tool-command";
472
+ content: string;
473
+ }
474
+
475
+ export interface GenerateCompletionStepSession {
476
+ type: "session";
477
+ title: string | undefined;
478
+ beforeCommit: string | undefined;
479
+ createdUnixTime: number;
480
+ updatedUnixTime: number;
481
+ id: string;
482
+ hasChanges: boolean;
483
+ }
484
+
485
+ export interface GenerateCompletionStepServerToolResult {
486
+ type: "server_tool_result";
487
+ content: any;
488
+ title: string;
489
+ id: string;
490
+ }
491
+
492
+ export type GenerateCompletionStep = { timestamp?: number } & (
493
+ | GenerateCompletionStepPlanning
494
+ | GenerateCompletionStepStart
495
+ | GenerateCompletionStepDelta
496
+ | GenerateCompletionStepUser
497
+ | GenerateCompletionStepFile
498
+ | GenerateCompletionStepDiff
499
+ | GenerateCompletionStepTool
500
+ | GenerateCompletionStepError
501
+ | GenerateCompletionStepContinue
502
+ | GenerateCompletionStepWaitForInput
503
+ | GenerateCompletionStepAbort
504
+ | GenerateCompletionStepDone
505
+ | GenerateCompletionStepUserInput
506
+ | GenerateCompletionStepText
507
+ | GenerateCompletionStepRestore
508
+ | GenerateCompletionStepState
509
+ | GenerateCompletionStepStdio
510
+ | GenerateCompletionStepSession
511
+ | GenerateCompletionStepServerToolResult
512
+ | GenerateCompletionStepToolResult
513
+ );
514
+
515
+ export interface ApplyActionsResult {
516
+ filePath: string;
517
+ addedLines: number;
518
+ removedLines: number;
519
+ action: "create" | "update" | "delete";
520
+ content?: string;
521
+ oldContent?: string;
522
+ }
523
+
524
+ export interface UserSourceBuilder {
525
+ source: "builder.io";
526
+ userId?: string;
527
+ userName?: string;
528
+ userEmail?: string;
529
+ role: "user";
530
+ }
531
+
532
+ export interface UserSourceGithub {
533
+ source: "github";
534
+ userName: string;
535
+ link?: string;
536
+ role: "user" | "agent";
537
+ }
538
+
539
+ export interface UserSourceAgent {
540
+ source: "agent";
541
+ role: "agent";
542
+ }
543
+
544
+ export type UserSource = UserSourceBuilder | UserSourceGithub | UserSourceAgent;
545
+
546
+ export interface GenerateUserMessage {
547
+ user?: UserSource;
548
+ userPrompt: string;
549
+ ephemeralUserPrompt?: string;
550
+ displayPrompt?: string;
551
+ files?: string[];
552
+ includeBaseFiles?: boolean;
553
+ skipSearch?: boolean;
554
+ attachments?: Attachment[];
555
+ debugMode?: boolean;
556
+ logsCheckpoint?: boolean;
557
+ }
558
+
559
+ export interface UserInput {
560
+ userMessage: GenerateUserMessage | undefined;
561
+ userPrompt: string;
562
+ attachments: Attachment[];
563
+ files: ProjectFile[];
564
+ searchResponse: CodebaseSearchResponse | null;
565
+ rerankFiles?: number;
566
+ mostRelevantFile: string | null;
567
+ toolResults: ContentMessageItemToolResult[];
568
+ role: "user" | "agent";
569
+ }
570
+
571
+ export interface CodegenTurn {
572
+ state: "running" | "done" | "error" | "aborted" | "reverted";
573
+ unixTime: number;
574
+ completionId: string;
575
+ title: string;
576
+ nextUrl: string | undefined;
577
+ role: "user" | "agent";
578
+ actions: ActionItem[];
579
+ sentiment: "positive" | "negative" | "undo" | undefined;
580
+ applyResults: ApplyActionsResult[];
581
+ userMessage: GenerateUserMessage | undefined;
582
+ beforeCommit: string | undefined;
583
+ afterCommit: string | undefined;
584
+ }
585
+
586
+ export interface GetSessionTurnsResult {
587
+ turns: CodegenTurn[];
588
+ sessionId: string;
589
+ initialUrl: string | undefined;
590
+ beforeCommit: string | undefined;
591
+ title: string | undefined;
592
+ createdUnixTime: number | undefined;
593
+ updatedUnixTime: number | undefined;
594
+ }
595
+
596
+ export interface CodegenFeedback {
597
+ id: string;
598
+ feedbackText?: string;
599
+ feedbackSentiment?: string;
600
+ framework?: string;
601
+ acceptedLines?: number;
602
+ afterCommit?: string;
603
+ }
604
+
605
+ export interface CodegenSetLastCompletion {
606
+ sessionId: string;
607
+ lastCompletionId: string | undefined;
608
+ }
609
+
610
+ export interface GenerateCodeEventDone {
611
+ type: "done";
612
+ unixTime: number;
613
+ stopReason: CompletionStopReason;
614
+ id: string;
615
+ actionTitle: string;
616
+ content?: string;
617
+ needsPagination: boolean;
618
+ actions?: ActionItem[];
619
+ suggestions: PromptSuggestion[];
620
+ usage?: CodegenUsage;
621
+ messageIndex: number;
622
+ sessionUsage: number;
623
+ nextUrl: string;
624
+ }
625
+
626
+ export interface GenerateCodeEventError {
627
+ type: "error";
628
+ stopReason: "error" | "limit";
629
+ id: string;
630
+ message: string;
631
+ usage?: CodegenUsage;
632
+ }
633
+ export interface GenerateCodeEventPagination {
634
+ type: "pagination";
635
+ pop: number;
636
+ page: number;
637
+ id: string;
638
+ }
639
+
640
+ export interface GenerateCodeEventContinue {
641
+ type: "continue";
642
+ id: string;
643
+ nextUrl: string;
644
+ }
645
+
646
+ export interface GenerateCodeEventDelta {
647
+ type: "delta";
648
+ content: string;
649
+ }
650
+
651
+ export interface GenerateCodeEventUser {
652
+ type: "user";
653
+ id: string;
654
+ displayPrompt: string | undefined;
655
+ user: UserSource;
656
+ /** @deprecated */
657
+ role: "user" | "agent";
658
+ }
659
+
660
+ export type GenerateCodeEvent =
661
+ | ActionItem
662
+ | GenerateCodeEventDone
663
+ | GenerateCodeEventContinue
664
+ | GenerateCodeEventPagination
665
+ | GenerateCodeEventDelta
666
+ | GenerateCodeEventError
667
+ | GenerateCodeEventUser;