@builder.io/ai-utils 0.3.10 → 0.3.11

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.
@@ -0,0 +1,30 @@
1
+ const urlParamSettings = [
2
+ "assistantType",
3
+ "theme",
4
+ "viewId",
5
+ ];
6
+ export function getAssistantUrl(opts = {}) {
7
+ var _a;
8
+ const url = new URL((_a = opts.baseUrl) !== null && _a !== void 0 ? _a : (opts.local ? "http://localhost:7242" : "https://assistant.builder.io"));
9
+ urlParamSettings.forEach((key) => {
10
+ const value = opts[key];
11
+ if (typeof value === "string" || typeof value === "boolean") {
12
+ url.searchParams.set(key, String(value));
13
+ }
14
+ });
15
+ return url.href;
16
+ }
17
+ export function parseAssistantUrlSettings(url) {
18
+ const parsed = new URL(url);
19
+ const settings = {};
20
+ urlParamSettings.forEach((key) => {
21
+ const value = parsed.searchParams.get(key);
22
+ if (value === "true" || value === "false") {
23
+ settings[key] = value === "true";
24
+ }
25
+ else if (value) {
26
+ settings[key] = value;
27
+ }
28
+ });
29
+ return settings;
30
+ }
package/README.md DELETED
@@ -1,3 +0,0 @@
1
- # Builder.io AI types and utilities
2
-
3
- Shared types between AI systems, threads, servers, etc.
package/src/codegen.ts DELETED
@@ -1,607 +0,0 @@
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
- | null;
74
-
75
- export interface ViewPathToolInput {
76
- filePath: string;
77
- viewRange?: [number, number];
78
- }
79
-
80
- export interface GlobSearchToolInput {
81
- pattern: string;
82
- }
83
-
84
- export interface GrepSearchToolInput {
85
- query: string;
86
- includeGlob?: string;
87
- excludeGlob?: string;
88
- }
89
-
90
- export interface GetRuleToolInput {
91
- name: string;
92
- }
93
-
94
- export interface GetStyleInspirationToolInput {
95
- prompt: string;
96
- }
97
-
98
- export interface GetBuildOutputToolInput {}
99
- export interface DevServerControlInput {
100
- restart?: boolean;
101
- getLogs?: boolean;
102
- }
103
-
104
- export interface BashToolInput {
105
- command?: string;
106
- restart?: boolean;
107
- }
108
-
109
- export interface WebSearchToolInput {
110
- query: string;
111
- }
112
-
113
- export interface CodeGenToolMap {
114
- view_path: ViewPathToolInput;
115
- glob_search: GlobSearchToolInput;
116
- grep_search: GrepSearchToolInput;
117
- get_rule: GetRuleToolInput;
118
- get_style_inspiration: GetStyleInspirationToolInput;
119
- get_build_output: GetBuildOutputToolInput;
120
- dev_server_control: DevServerControlInput;
121
- bash: BashToolInput;
122
- web_search: WebSearchToolInput;
123
- }
124
-
125
- export type CodeGenTools = keyof CodeGenToolMap;
126
-
127
- export type CodeGenMode =
128
- | "exact" // @deprecated
129
- | "precise" // tries to match the design as close
130
- | "precise_vision" // tries to match the design as close, also uses vision to match
131
- | "creative" // adapts the design to some generic design language
132
- | "creative_vision" // adapts the design to some generic design language, also uses vision to match
133
- | "creative_only_vision"; // adapts the design to some generic design language, but only uses vision to match
134
-
135
- export interface CodeGenInputOptions {
136
- position: string;
137
- eventName?: string;
138
- sessionId: string;
139
-
140
- codeGenMode?: "fast" | "quality" | "quality-v3";
141
- url?: string;
142
- diffActions?: boolean;
143
- planningPrompt?: boolean;
144
- customInstructions?: CustomInstruction[];
145
- userPrompt?: string;
146
- ephemeralUserPrompt?: string;
147
- displayUserPrompt?: string;
148
- files?: ProjectFile[];
149
- rerankFiles?: number;
150
- toolResults?: ContentMessageItemToolResult[];
151
- attachments?: Attachment[];
152
- beforeCommit?: string;
153
- workingDirectory?: string;
154
-
155
- // Code options
156
- builderContent?: BuilderContent;
157
- framework?: CodeGenFramework;
158
- styleLibrary?: CodeGenStyleLibrary;
159
- typescript?: boolean;
160
- userContext?: UserContext;
161
-
162
- enabledTools?: CodeGenTools[];
163
-
164
- // Options
165
- maxTokens?: number;
166
- maxPages?: number;
167
- autoContinue?: number;
168
- promptCaching?: boolean;
169
- isAutoContinue?: boolean;
170
- llmSuggestions?: boolean;
171
- conclusionText?: boolean;
172
-
173
- searchResponse?: any | null;
174
-
175
- // Prettier options
176
- prettierConfig?: PrettierOptions;
177
-
178
- /** @deprecated */
179
- history?: (UserMessageParam | AssistantMessageParam)[];
180
- /** @deprecated */
181
- prevId?: string;
182
- /** @deprecated */
183
- nextPage?: boolean;
184
- /** @deprecated */
185
- vcpId?: string;
186
- }
187
-
188
- export type Feature = "component-mapping";
189
-
190
- export interface CodegenUsage {
191
- total: number;
192
- fast: number;
193
- quality: number;
194
- features: Feature[];
195
- limits: {
196
- aiGeneration: number;
197
- aiGenerationContextWindow: number;
198
- };
199
- }
200
-
201
- export interface PromptSuggestion {
202
- type:
203
- | "missing-imports"
204
- | "lazy-code"
205
- | "no-file-for-diff"
206
- | "syntax-error"
207
- | "llm-suggested"
208
- | "diff-apply";
209
-
210
- filePath?: string;
211
- line?: number;
212
- importance: "high" | "medium" | "low";
213
- column?: number;
214
- summary: string;
215
- prompt: string;
216
- }
217
-
218
- export interface ActionItem {
219
- type:
220
- | "file"
221
- | "text"
222
- | "diff"
223
- | "thinking"
224
- | "tool"
225
- | "suggestion"
226
- | "tool_result";
227
- id?: string;
228
- content: string;
229
- filePath?: string;
230
- artifactTitle?: string;
231
- actionTitle?: string;
232
- synthetic?: boolean;
233
- incomplete?: boolean;
234
- suggestions?: PromptSuggestion[];
235
- errors?: string[];
236
- }
237
-
238
- export interface RepoInfo {
239
- remoteUrl: string;
240
- defaultBranch: string;
241
- currentBranch: string;
242
- commit: string;
243
- }
244
-
245
- export interface CodebaseSearchOptions {
246
- repoInfo?: RepoInfo;
247
- query: string;
248
- selectedFiles?: string[];
249
- sessionId: string;
250
- files?: string[];
251
- packageJson?: string;
252
- limit?: number;
253
- includeContent?: boolean;
254
- }
255
-
256
- export interface CodebaseSearchResponse {
257
- id: string;
258
- relevantPaths: string[];
259
- grepQueries: string[];
260
- streamMeta: any;
261
- ranked: RankedResult[];
262
- }
263
-
264
- export interface RankedResult {
265
- index: number;
266
- filePath: string;
267
- startIndex: number;
268
- endIndex: number;
269
- score: number;
270
- id: string;
271
- content?: string;
272
- }
273
-
274
- export interface GenerateCompletionStepThinking {
275
- type: "thinking";
276
- }
277
-
278
- export interface FileInfo {
279
- filePath: string;
280
- size: number;
281
- isCustomInstruction: boolean;
282
- }
283
-
284
- export interface GenerateCompletionStepUserInput {
285
- type: "user-input";
286
- prompt: string;
287
- files: FileInfo[];
288
- }
289
-
290
- export interface GenerateCompletionStepToolResult {
291
- type: "agent-input";
292
- toolResults: ContentMessageItemToolResult[];
293
- }
294
-
295
- export interface GenerateCompletionStepPlanning {
296
- type: "planning";
297
- content: string;
298
- }
299
-
300
- export interface GenerateCompletionStepUser {
301
- type: "user";
302
- displayPrompt: string | undefined;
303
- id: string;
304
- role: "user" | "agent";
305
- }
306
-
307
- export interface GenerateCompletionStepFile {
308
- type: "file";
309
- filePath: string;
310
- content: string;
311
- title: string;
312
- id: string;
313
- }
314
-
315
- export interface GenerateCompletionStepDiff {
316
- type: "diff";
317
- filePath: string;
318
- content: string;
319
- title: string;
320
- id: string;
321
- }
322
-
323
- export interface GenerateCompletionStepTool {
324
- type: "tool";
325
- name: string;
326
- id: string;
327
- content: string;
328
- }
329
-
330
- export interface GenerateCompletionStepText {
331
- type: "text";
332
- content: string;
333
- }
334
-
335
- export interface GenerateCompletionStepDone {
336
- type: "done";
337
- id: string;
338
- applyResults: ApplyActionsResult[];
339
- actions: ActionItem[];
340
- usage: CodegenUsage | undefined;
341
- url?: string;
342
- stopReason: CompletionStopReason;
343
- hasChanges: boolean;
344
- }
345
-
346
- export interface GenerateCompletionStepStart {
347
- type: "start";
348
- name: string;
349
- id: string | undefined;
350
- title: string;
351
- content: string;
352
- }
353
-
354
- export interface GenerateCompletionStepDelta {
355
- type: "delta";
356
- name: string;
357
- delta: string;
358
- }
359
-
360
- export interface GenerateCompletionStepError {
361
- type: "error";
362
- id?: string;
363
- stopReason?: "error" | "limit";
364
- metadata?: any;
365
- message: string;
366
- usage?: CodegenUsage;
367
- contextPrompt?: string;
368
- }
369
-
370
- export interface GenerateCompletionStepContinue {
371
- type: "continue";
372
- id: string;
373
- url: string;
374
- }
375
-
376
- export interface CodeGenHealthStatus {
377
- devServerRunning: boolean;
378
- devServerResponding: boolean;
379
- logs: string | undefined;
380
- lastInstallFailed: boolean;
381
- checkLogs: string;
382
- checkPassed: boolean;
383
- prompt: string;
384
- message: string;
385
- }
386
-
387
- export interface SuggestedActionBase {
388
- level: "info" | "warning" | "error";
389
- canAutoApply: boolean;
390
- actionButtonText: string;
391
- message: string;
392
- userMessage: GenerateUserMessage;
393
- }
394
-
395
- export interface SuggestedActionBuildError extends SuggestedActionBase {
396
- type: "build-error";
397
- healthStatus: CodeGenHealthStatus;
398
- }
399
-
400
- export type SuggestedAction = SuggestedActionBuildError;
401
-
402
- export interface GenerateCompletionStepWaitForInput {
403
- type: "wait-for-input";
404
- state: GenerateCompletionState;
405
- suggestion?: SuggestedAction;
406
- }
407
-
408
- export interface GenerateCompletionStepAbort {
409
- type: "user-abort";
410
- }
411
-
412
- export interface GenerateCompletionStepRestore {
413
- type: "restore";
414
- location: "before" | "after";
415
- files: string[];
416
- lastCompletionId: string | undefined;
417
- commitHash: string | undefined;
418
- }
419
-
420
- export type GenerateCompletionState =
421
- | "unknown"
422
- | "initial-with-url"
423
- | "initial-without-url"
424
- | "generating"
425
- | "success"
426
- | "abort"
427
- | "error"
428
- | "close";
429
-
430
- export interface GenerateCompletionStepState {
431
- type: "state";
432
- previousState: GenerateCompletionState;
433
- newState: GenerateCompletionState;
434
- }
435
-
436
- export interface GenerateCompletionStepClose {
437
- type: "close";
438
- }
439
-
440
- export interface GenerateCompletionStepStdio {
441
- type: "stdio";
442
- command: string;
443
- stream: "stdout" | "stderr";
444
- source: "run-command" | "tool-command";
445
- content: string;
446
- }
447
-
448
- export interface GenerateCompletionStepSession {
449
- type: "session";
450
- title: string | undefined;
451
- beforeCommit: string | undefined;
452
- createdUnixTime: number;
453
- updatedUnixTime: number;
454
- id: string;
455
- hasChanges: boolean;
456
- }
457
-
458
- export type GenerateCompletionStep = { timestamp?: number } & (
459
- | GenerateCompletionStepPlanning
460
- | GenerateCompletionStepStart
461
- | GenerateCompletionStepDelta
462
- | GenerateCompletionStepUser
463
- | GenerateCompletionStepFile
464
- | GenerateCompletionStepDiff
465
- | GenerateCompletionStepTool
466
- | GenerateCompletionStepError
467
- | GenerateCompletionStepContinue
468
- | GenerateCompletionStepWaitForInput
469
- | GenerateCompletionStepAbort
470
- | GenerateCompletionStepDone
471
- | GenerateCompletionStepUserInput
472
- | GenerateCompletionStepText
473
- | GenerateCompletionStepRestore
474
- | GenerateCompletionStepState
475
- | GenerateCompletionStepStdio
476
- | GenerateCompletionStepSession
477
- | GenerateCompletionStepToolResult
478
- );
479
-
480
- export interface ApplyActionsResult {
481
- filePath: string;
482
- addedLines: number;
483
- removedLines: number;
484
- action: "create" | "update" | "delete";
485
- content?: string;
486
- oldContent?: string;
487
- }
488
-
489
- export interface GenerateUserMessage {
490
- userPrompt: string;
491
- ephemeralUserPrompt?: string;
492
- displayPrompt?: string;
493
- files?: string[];
494
- includeBaseFiles?: boolean;
495
- skipSearch?: boolean;
496
- attachments?: Attachment[];
497
- debugMode?: boolean;
498
- logsCheckpoint?: boolean;
499
- }
500
-
501
- export interface UserInput {
502
- userMessage: GenerateUserMessage | undefined;
503
- userPrompt: string;
504
- attachments: Attachment[];
505
- files: ProjectFile[];
506
- searchResponse: CodebaseSearchResponse | null;
507
- rerankFiles?: number;
508
- mostRelevantFile: string | null;
509
- toolResults: ContentMessageItemToolResult[];
510
- role: "user" | "agent";
511
- }
512
-
513
- export interface CodegenTurn {
514
- state: "running" | "done" | "error" | "aborted" | "reverted";
515
- unixTime: number;
516
- completionId: string;
517
- title: string;
518
- nextUrl: string | undefined;
519
- role: "user" | "agent";
520
- actions: ActionItem[];
521
- sentiment: "positive" | "negative" | "undo" | undefined;
522
- applyResults: ApplyActionsResult[];
523
- userMessage: GenerateUserMessage | undefined;
524
- beforeCommit: string | undefined;
525
- afterCommit: string | undefined;
526
- }
527
-
528
- export interface GetSessionTurnsResult {
529
- turns: CodegenTurn[];
530
- sessionId: string;
531
- initialUrl: string | undefined;
532
- beforeCommit: string | undefined;
533
- title: string | undefined;
534
- createdUnixTime: number | undefined;
535
- updatedUnixTime: number | undefined;
536
- }
537
-
538
- export interface CodegenFeedback {
539
- id: string;
540
- feedbackText?: string;
541
- feedbackSentiment?: string;
542
- framework?: string;
543
- acceptedLines?: number;
544
- afterCommit?: string;
545
- }
546
-
547
- export interface CodegenSetLastCompletion {
548
- sessionId: string;
549
- lastCompletionId: string | undefined;
550
- }
551
-
552
- export interface GenerateCodeEventDone {
553
- type: "done";
554
- unixTime: number;
555
- stopReason: CompletionStopReason;
556
- id: string;
557
- actionTitle: string;
558
- content?: string;
559
- needsPagination: boolean;
560
- actions?: ActionItem[];
561
- suggestions: PromptSuggestion[];
562
- usage?: CodegenUsage;
563
- messageIndex: number;
564
- sessionUsage: number;
565
- nextUrl: string;
566
- }
567
-
568
- export interface GenerateCodeEventError {
569
- type: "error";
570
- stopReason: "error" | "limit";
571
- id: string;
572
- message: string;
573
- usage?: CodegenUsage;
574
- }
575
- export interface GenerateCodeEventPagination {
576
- type: "pagination";
577
- pop: number;
578
- page: number;
579
- id: string;
580
- }
581
-
582
- export interface GenerateCodeEventContinue {
583
- type: "continue";
584
- id: string;
585
- nextUrl: string;
586
- }
587
-
588
- export interface GenerateCodeEventDelta {
589
- type: "delta";
590
- content: string;
591
- }
592
-
593
- export interface GenerateCodeEventUser {
594
- type: "user";
595
- id: string;
596
- displayPrompt: string | undefined;
597
- role: "user" | "agent";
598
- }
599
-
600
- export type GenerateCodeEvent =
601
- | ActionItem
602
- | GenerateCodeEventDone
603
- | GenerateCodeEventContinue
604
- | GenerateCodeEventPagination
605
- | GenerateCodeEventDelta
606
- | GenerateCodeEventError
607
- | GenerateCodeEventUser;