autoui-react 0.0.5-alpha → 0.1.1-alpha

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/dist/index.d.ts CHANGED
@@ -1,6 +1,13 @@
1
1
  import { z } from 'zod';
2
2
  import React from 'react';
3
3
 
4
+ /**
5
+ * Interface for the runtime data context
6
+ */
7
+ interface DataContext {
8
+ [key: string]: unknown;
9
+ }
10
+
4
11
  /**
5
12
  * Event types that can be triggered by UI elements
6
13
  */
@@ -63,6 +70,7 @@ declare const uiState: z.ZodObject<{
63
70
  payload: Record<string, unknown> | null;
64
71
  }>, "many">;
65
72
  error: z.ZodNullable<z.ZodString>;
73
+ dataContext: z.ZodRecord<z.ZodString, z.ZodUnknown>;
66
74
  }, "strip", z.ZodTypeAny, {
67
75
  layout: UISpecNodeInterface | null;
68
76
  loading: boolean;
@@ -73,6 +81,7 @@ declare const uiState: z.ZodObject<{
73
81
  payload: Record<string, unknown> | null;
74
82
  }[];
75
83
  error: string | null;
84
+ dataContext: Record<string, unknown>;
76
85
  }, {
77
86
  layout: UISpecNodeInterface | null;
78
87
  loading: boolean;
@@ -83,8 +92,11 @@ declare const uiState: z.ZodObject<{
83
92
  payload: Record<string, unknown> | null;
84
93
  }[];
85
94
  error: string | null;
95
+ dataContext: Record<string, unknown>;
86
96
  }>;
87
- type UIState = z.infer<typeof uiState>;
97
+ type UIState = z.infer<typeof uiState> & {
98
+ dataContext: DataContext;
99
+ };
88
100
  /**
89
101
  * Input for the AI planner
90
102
  */
@@ -131,25 +143,29 @@ declare const plannerInput: z.ZodObject<{
131
143
  }>;
132
144
  type PlannerInput = z.infer<typeof plannerInput>;
133
145
 
134
- /**
135
- * Interface for the runtime data context
136
- */
137
- interface DataContext {
138
- [key: string]: unknown;
139
- }
140
-
141
- /**
142
- * Action types supported by the router
143
- */
144
146
  declare enum ActionType {
145
147
  FULL_REFRESH = "FULL_REFRESH",// Generate a completely new UI
146
148
  UPDATE_NODE = "UPDATE_NODE",// Update a specific node, potentially with new children
149
+ UPDATE_DATA = "UPDATE_DATA",// Add this for input changes
150
+ ADD_ITEM = "ADD_ITEM",// Add an item to a list
151
+ DELETE_ITEM = "DELETE_ITEM",// Delete an item from a list
147
152
  ADD_DROPDOWN = "ADD_DROPDOWN",// Add a dropdown to a specific node
148
153
  SHOW_DETAIL = "SHOW_DETAIL",// Show a detail view
149
154
  HIDE_DETAIL = "HIDE_DETAIL",// Hide a detail view
155
+ HIDE_DIALOG = "HIDE_DIALOG",// Explicitly add HIDE_DIALOG
156
+ SAVE_TASK_CHANGES = "SAVE_TASK_CHANGES",// Add action for saving
150
157
  TOGGLE_STATE = "TOGGLE_STATE",// Toggle a boolean state (expanded, selected, etc.)
151
158
  UPDATE_FORM = "UPDATE_FORM",// Update a form based on selections
152
- NAVIGATE = "NAVIGATE"
159
+ NAVIGATE = "NAVIGATE",// Navigate to a different view
160
+ OPEN_DIALOG = "OPEN_DIALOG",// Open a dialog (for clarity)
161
+ CLOSE_DIALOG = "CLOSE_DIALOG",// Close a dialog (for clarity)
162
+ UPDATE_CONTEXT = "UPDATE_CONTEXT"
163
+ }
164
+
165
+ interface PlanningConfig {
166
+ prefetchDepth: number;
167
+ temperature: number;
168
+ streaming: boolean;
153
169
  }
154
170
  /**
155
171
  * Routing configuration for an action
@@ -157,7 +173,6 @@ declare enum ActionType {
157
173
  interface ActionRouteConfig {
158
174
  actionType: ActionType;
159
175
  targetNodeId?: string;
160
- promptTemplate?: string;
161
176
  contextKeys?: string[];
162
177
  }
163
178
  /**
@@ -166,20 +181,16 @@ interface ActionRouteConfig {
166
181
  interface RouteResolution {
167
182
  actionType: ActionType;
168
183
  targetNodeId: string;
169
- plannerInput: PlannerInput;
170
- prompt: string;
184
+ updatedNode: UISpecNode;
185
+ updatedDataContext?: DataContext;
171
186
  }
172
187
  /**
173
188
  * Action router class - handles determining what part of the UI to update
174
189
  */
175
190
  declare class ActionRouter {
176
- private routes;
177
- /**
178
- * Register a new action route
179
- * @param eventType - UI event type to route
180
- * @param config - Route configuration
181
- */
182
- registerRoute(eventType: string, config: ActionRouteConfig): void;
191
+ private apiKey;
192
+ private planningConfig;
193
+ constructor(apiKey: string, planningConfig?: PlanningConfig);
183
194
  /**
184
195
  * Find the appropriate route for an event
185
196
  * @param event - UI event
@@ -187,29 +198,15 @@ declare class ActionRouter {
187
198
  * @param dataContext - Current data context
188
199
  * @returns Route resolution or null if no match
189
200
  */
190
- resolveRoute(event: UIEvent, schema: Record<string, unknown>, layout: UISpecNode | null, dataContext: DataContext, goal: string, userContext?: Record<string, unknown>): RouteResolution | null;
191
- /**
192
- * Process a prompt template with variables
193
- * @param template - Template string with ${var} placeholders
194
- * @param values - Values to substitute
195
- * @returns Processed string
196
- */
197
- private processTemplate;
201
+ resolveRoute(event: UIEvent, schema: Record<string, unknown>, layout: UISpecNode | null, dataContext: DataContext, goal: string, apiKey: string, userContext?: Record<string, unknown>): Promise<RouteResolution>;
198
202
  }
199
- declare function createDefaultRouter(): ActionRouter;
200
203
 
201
204
  interface UseUIStateEngineOptions {
202
205
  schema: Record<string, unknown>;
203
206
  goal: string;
204
- openaiApiKey?: string | undefined;
207
+ apiKey: string;
205
208
  userContext?: Record<string, unknown> | undefined;
206
- mockMode?: boolean | undefined;
207
- planningConfig?: {
208
- prefetchDepth?: number;
209
- temperature?: number;
210
- streaming?: boolean;
211
- } | undefined;
212
- router?: ActionRouter | undefined;
209
+ planningConfig?: PlanningConfig | undefined;
213
210
  dataContext?: Record<string, unknown> | undefined;
214
211
  enablePartialUpdates?: boolean | undefined;
215
212
  }
@@ -519,12 +516,8 @@ interface AutoUIProps extends Omit<UseUIStateEngineOptions, "router" | "dataCont
519
516
  debugMode?: boolean;
520
517
  mockMode?: boolean;
521
518
  databaseConfig?: Record<string, unknown>;
522
- planningConfig?: {
523
- prefetchDepth?: number;
524
- temperature?: number;
525
- streaming?: boolean;
526
- };
527
- openaiApiKey?: string;
519
+ planningConfig?: PlanningConfig;
520
+ apiKey: string;
528
521
  }
529
522
  /**
530
523
  * AutoUI - Main component for generating goal-oriented UIs
@@ -546,6 +539,314 @@ interface AutoUIProps extends Omit<UseUIStateEngineOptions, "router" | "dataCont
546
539
  */
547
540
  declare const AutoUI: React.FC<AutoUIProps>;
548
541
 
542
+ /**
543
+ * Component definitions for shadcn/ui integration
544
+ * This file defines which components from shadcn/ui are used by AutoUI
545
+ */
546
+
547
+ declare const componentType: z.ZodEnum<["Container", "Card", "Header", "Button", "Input", "Select", "Textarea", "Checkbox", "RadioGroup", "ListView", "Detail", "Tabs", "Dialog", "Badge", "Heading", "Text"]>;
548
+
549
+ declare const openAIUISpec: z.ZodObject<{
550
+ id: z.ZodString;
551
+ node_type: z.ZodEnum<["Container", "Card", "Header", "Button", "Input", "Select", "Textarea", "Checkbox", "RadioGroup", "ListView", "Detail", "Tabs", "Dialog", "Badge", "Heading", "Text"]>;
552
+ props: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
553
+ bindings: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
554
+ events: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodObject<{
555
+ action: z.ZodEnum<["FULL_REFRESH", "UPDATE_NODE", "UPDATE_DATA", "ADD_DROPDOWN", "SHOW_DETAIL", "HIDE_DETAIL", "HIDE_DIALOG", "SAVE_TASK_CHANGES", "TOGGLE_STATE", "UPDATE_FORM", "NAVIGATE", "OPEN_DIALOG", "CLOSE_DIALOG", "UPDATE_CONTEXT"]>;
556
+ target: z.ZodString;
557
+ payload: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
558
+ }, "strip", z.ZodTypeAny, {
559
+ payload: Record<string, string | null> | null;
560
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
561
+ target: string;
562
+ }, {
563
+ payload: Record<string, string | null> | null;
564
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
565
+ target: string;
566
+ }>>>;
567
+ } & {
568
+ children: z.ZodNullable<z.ZodArray<z.ZodObject<{
569
+ id: z.ZodString;
570
+ node_type: z.ZodEnum<["Container", "Card", "Header", "Button", "Input", "Select", "Textarea", "Checkbox", "RadioGroup", "ListView", "Detail", "Tabs", "Dialog", "Badge", "Heading", "Text"]>;
571
+ props: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
572
+ bindings: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
573
+ events: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodObject<{
574
+ action: z.ZodEnum<["FULL_REFRESH", "UPDATE_NODE", "UPDATE_DATA", "ADD_DROPDOWN", "SHOW_DETAIL", "HIDE_DETAIL", "HIDE_DIALOG", "SAVE_TASK_CHANGES", "TOGGLE_STATE", "UPDATE_FORM", "NAVIGATE", "OPEN_DIALOG", "CLOSE_DIALOG", "UPDATE_CONTEXT"]>;
575
+ target: z.ZodString;
576
+ payload: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
577
+ }, "strip", z.ZodTypeAny, {
578
+ payload: Record<string, string | null> | null;
579
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
580
+ target: string;
581
+ }, {
582
+ payload: Record<string, string | null> | null;
583
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
584
+ target: string;
585
+ }>>>;
586
+ } & {
587
+ children: z.ZodNullable<z.ZodArray<z.ZodObject<{
588
+ id: z.ZodString;
589
+ node_type: z.ZodEnum<["Container", "Card", "Header", "Button", "Input", "Select", "Textarea", "Checkbox", "RadioGroup", "ListView", "Detail", "Tabs", "Dialog", "Badge", "Heading", "Text"]>;
590
+ props: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
591
+ bindings: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
592
+ events: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodObject<{
593
+ action: z.ZodEnum<["FULL_REFRESH", "UPDATE_NODE", "UPDATE_DATA", "ADD_DROPDOWN", "SHOW_DETAIL", "HIDE_DETAIL", "HIDE_DIALOG", "SAVE_TASK_CHANGES", "TOGGLE_STATE", "UPDATE_FORM", "NAVIGATE", "OPEN_DIALOG", "CLOSE_DIALOG", "UPDATE_CONTEXT"]>;
594
+ target: z.ZodString;
595
+ payload: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
596
+ }, "strip", z.ZodTypeAny, {
597
+ payload: Record<string, string | null> | null;
598
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
599
+ target: string;
600
+ }, {
601
+ payload: Record<string, string | null> | null;
602
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
603
+ target: string;
604
+ }>>>;
605
+ } & {
606
+ children: z.ZodNullable<z.ZodArray<z.ZodObject<{
607
+ id: z.ZodString;
608
+ node_type: z.ZodEnum<["Container", "Card", "Header", "Button", "Input", "Select", "Textarea", "Checkbox", "RadioGroup", "ListView", "Detail", "Tabs", "Dialog", "Badge", "Heading", "Text"]>;
609
+ props: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
610
+ bindings: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
611
+ events: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodObject<{
612
+ action: z.ZodEnum<["FULL_REFRESH", "UPDATE_NODE", "UPDATE_DATA", "ADD_DROPDOWN", "SHOW_DETAIL", "HIDE_DETAIL", "HIDE_DIALOG", "SAVE_TASK_CHANGES", "TOGGLE_STATE", "UPDATE_FORM", "NAVIGATE", "OPEN_DIALOG", "CLOSE_DIALOG", "UPDATE_CONTEXT"]>;
613
+ target: z.ZodString;
614
+ payload: z.ZodNullable<z.ZodRecord<z.ZodString, z.ZodNullable<z.ZodString>>>;
615
+ }, "strip", z.ZodTypeAny, {
616
+ payload: Record<string, string | null> | null;
617
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
618
+ target: string;
619
+ }, {
620
+ payload: Record<string, string | null> | null;
621
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
622
+ target: string;
623
+ }>>>;
624
+ children: z.ZodNull;
625
+ }, "strip", z.ZodTypeAny, {
626
+ events: Record<string, {
627
+ payload: Record<string, string | null> | null;
628
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
629
+ target: string;
630
+ }> | null;
631
+ id: string;
632
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
633
+ props: Record<string, string | null> | null;
634
+ bindings: Record<string, string | null> | null;
635
+ children: null;
636
+ }, {
637
+ events: Record<string, {
638
+ payload: Record<string, string | null> | null;
639
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
640
+ target: string;
641
+ }> | null;
642
+ id: string;
643
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
644
+ props: Record<string, string | null> | null;
645
+ bindings: Record<string, string | null> | null;
646
+ children: null;
647
+ }>, "many">>;
648
+ }, "strip", z.ZodTypeAny, {
649
+ events: Record<string, {
650
+ payload: Record<string, string | null> | null;
651
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
652
+ target: string;
653
+ }> | null;
654
+ id: string;
655
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
656
+ props: Record<string, string | null> | null;
657
+ bindings: Record<string, string | null> | null;
658
+ children: {
659
+ events: Record<string, {
660
+ payload: Record<string, string | null> | null;
661
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
662
+ target: string;
663
+ }> | null;
664
+ id: string;
665
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
666
+ props: Record<string, string | null> | null;
667
+ bindings: Record<string, string | null> | null;
668
+ children: null;
669
+ }[] | null;
670
+ }, {
671
+ events: Record<string, {
672
+ payload: Record<string, string | null> | null;
673
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
674
+ target: string;
675
+ }> | null;
676
+ id: string;
677
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
678
+ props: Record<string, string | null> | null;
679
+ bindings: Record<string, string | null> | null;
680
+ children: {
681
+ events: Record<string, {
682
+ payload: Record<string, string | null> | null;
683
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
684
+ target: string;
685
+ }> | null;
686
+ id: string;
687
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
688
+ props: Record<string, string | null> | null;
689
+ bindings: Record<string, string | null> | null;
690
+ children: null;
691
+ }[] | null;
692
+ }>, "many">>;
693
+ }, "strip", z.ZodTypeAny, {
694
+ events: Record<string, {
695
+ payload: Record<string, string | null> | null;
696
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
697
+ target: string;
698
+ }> | null;
699
+ id: string;
700
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
701
+ props: Record<string, string | null> | null;
702
+ bindings: Record<string, string | null> | null;
703
+ children: {
704
+ events: Record<string, {
705
+ payload: Record<string, string | null> | null;
706
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
707
+ target: string;
708
+ }> | null;
709
+ id: string;
710
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
711
+ props: Record<string, string | null> | null;
712
+ bindings: Record<string, string | null> | null;
713
+ children: {
714
+ events: Record<string, {
715
+ payload: Record<string, string | null> | null;
716
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
717
+ target: string;
718
+ }> | null;
719
+ id: string;
720
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
721
+ props: Record<string, string | null> | null;
722
+ bindings: Record<string, string | null> | null;
723
+ children: null;
724
+ }[] | null;
725
+ }[] | null;
726
+ }, {
727
+ events: Record<string, {
728
+ payload: Record<string, string | null> | null;
729
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
730
+ target: string;
731
+ }> | null;
732
+ id: string;
733
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
734
+ props: Record<string, string | null> | null;
735
+ bindings: Record<string, string | null> | null;
736
+ children: {
737
+ events: Record<string, {
738
+ payload: Record<string, string | null> | null;
739
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
740
+ target: string;
741
+ }> | null;
742
+ id: string;
743
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
744
+ props: Record<string, string | null> | null;
745
+ bindings: Record<string, string | null> | null;
746
+ children: {
747
+ events: Record<string, {
748
+ payload: Record<string, string | null> | null;
749
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
750
+ target: string;
751
+ }> | null;
752
+ id: string;
753
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
754
+ props: Record<string, string | null> | null;
755
+ bindings: Record<string, string | null> | null;
756
+ children: null;
757
+ }[] | null;
758
+ }[] | null;
759
+ }>, "many">>;
760
+ }, "strip", z.ZodTypeAny, {
761
+ events: Record<string, {
762
+ payload: Record<string, string | null> | null;
763
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
764
+ target: string;
765
+ }> | null;
766
+ id: string;
767
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
768
+ props: Record<string, string | null> | null;
769
+ bindings: Record<string, string | null> | null;
770
+ children: {
771
+ events: Record<string, {
772
+ payload: Record<string, string | null> | null;
773
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
774
+ target: string;
775
+ }> | null;
776
+ id: string;
777
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
778
+ props: Record<string, string | null> | null;
779
+ bindings: Record<string, string | null> | null;
780
+ children: {
781
+ events: Record<string, {
782
+ payload: Record<string, string | null> | null;
783
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
784
+ target: string;
785
+ }> | null;
786
+ id: string;
787
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
788
+ props: Record<string, string | null> | null;
789
+ bindings: Record<string, string | null> | null;
790
+ children: {
791
+ events: Record<string, {
792
+ payload: Record<string, string | null> | null;
793
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
794
+ target: string;
795
+ }> | null;
796
+ id: string;
797
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
798
+ props: Record<string, string | null> | null;
799
+ bindings: Record<string, string | null> | null;
800
+ children: null;
801
+ }[] | null;
802
+ }[] | null;
803
+ }[] | null;
804
+ }, {
805
+ events: Record<string, {
806
+ payload: Record<string, string | null> | null;
807
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
808
+ target: string;
809
+ }> | null;
810
+ id: string;
811
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
812
+ props: Record<string, string | null> | null;
813
+ bindings: Record<string, string | null> | null;
814
+ children: {
815
+ events: Record<string, {
816
+ payload: Record<string, string | null> | null;
817
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
818
+ target: string;
819
+ }> | null;
820
+ id: string;
821
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
822
+ props: Record<string, string | null> | null;
823
+ bindings: Record<string, string | null> | null;
824
+ children: {
825
+ events: Record<string, {
826
+ payload: Record<string, string | null> | null;
827
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
828
+ target: string;
829
+ }> | null;
830
+ id: string;
831
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
832
+ props: Record<string, string | null> | null;
833
+ bindings: Record<string, string | null> | null;
834
+ children: {
835
+ events: Record<string, {
836
+ payload: Record<string, string | null> | null;
837
+ action: "FULL_REFRESH" | "UPDATE_NODE" | "UPDATE_DATA" | "ADD_DROPDOWN" | "SHOW_DETAIL" | "HIDE_DETAIL" | "HIDE_DIALOG" | "SAVE_TASK_CHANGES" | "TOGGLE_STATE" | "UPDATE_FORM" | "NAVIGATE" | "OPEN_DIALOG" | "CLOSE_DIALOG" | "UPDATE_CONTEXT";
838
+ target: string;
839
+ }> | null;
840
+ id: string;
841
+ node_type: "ListView" | "Container" | "Card" | "Header" | "Button" | "Input" | "Select" | "Textarea" | "Checkbox" | "RadioGroup" | "Detail" | "Tabs" | "Dialog" | "Badge" | "Heading" | "Text";
842
+ props: Record<string, string | null> | null;
843
+ bindings: Record<string, string | null> | null;
844
+ children: null;
845
+ }[] | null;
846
+ }[] | null;
847
+ }[] | null;
848
+ }>;
849
+
549
850
  /**
550
851
  * AI Utilities for AutoUI React
551
852
  * Provides AI-powered UI generation functionality
@@ -563,26 +864,4 @@ declare const generateUIDescription: (prompt: string) => Promise<string>;
563
864
  */
564
865
  declare const generateUIComponent: (prompt: string) => Promise<string>;
565
866
 
566
- interface UsePlannerOptions {
567
- goal: string;
568
- schema: Record<string, unknown>;
569
- openaiApiKey?: string;
570
- userContext?: Record<string, unknown>;
571
- router?: ActionRouter;
572
- modelProvider?: unknown;
573
- initialLayout?: UISpecNode;
574
- mockMode?: boolean;
575
- }
576
- interface UsePlannerResult {
577
- layout: UISpecNode | undefined;
578
- loading: boolean;
579
- error: Error | null;
580
- handleEvent: (event: UIEvent) => Promise<void>;
581
- generateInitialLayout: () => Promise<void>;
582
- }
583
- /**
584
- * React hook for utilizing the AI planner functionality
585
- */
586
- declare function usePlanner(options: UsePlannerOptions): UsePlannerResult;
587
-
588
- export { ActionRouteConfig, ActionRouter, ActionType, AnySystemEvent, AutoUI, AutoUIProps, DrizzleAdapter, DrizzleAdapterOptions$1 as DrizzleAdapterOptions, EventHook, EventHookContext, EventHookOptions, PlannerInput, SchemaAdapter, SchemaAdapterOptions, SystemEventHook, SystemEventType, UIEvent, UIEventType, UISpecNode, UIState, createDefaultRouter, createEventHook, createSchemaAdapter, createSystemEvent, generateComponent, generateUIComponent, generateUIDescription, systemEvents, uiEvent, uiEventType, uiSpecNode, usePlanner };
867
+ export { ActionRouteConfig, ActionRouter, ActionType, AnySystemEvent, AutoUI, AutoUIProps, DrizzleAdapter, DrizzleAdapterOptions$1 as DrizzleAdapterOptions, EventHook, EventHookContext, EventHookOptions, PlannerInput, SchemaAdapter, SchemaAdapterOptions, SystemEventHook, SystemEventType, UIEvent, UIEventType, UISpecNode, UIState, componentType, createEventHook, createSchemaAdapter, createSystemEvent, generateComponent, generateUIComponent, generateUIDescription, openAIUISpec, systemEvents, uiEvent, uiEventType, uiSpecNode };