@process.co/ui 0.0.5 → 0.0.6

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,280 @@
1
+ import * as React$1 from 'react';
2
+
3
+ interface InputProps {
4
+ /**
5
+ * Field name/key.
6
+ * Used for Yjs field path and validation error tracking.
7
+ * When nested inside NestedFieldProvider, the parent path is auto-prepended.
8
+ */
9
+ fieldName: string;
10
+ /** Display label for the field */
11
+ label: string;
12
+ /** Current value */
13
+ value: string | {
14
+ expression: string;
15
+ type: 'expression';
16
+ value?: string;
17
+ };
18
+ /** Called when value changes */
19
+ onChange: (value: string | {
20
+ expression: string;
21
+ type: 'expression';
22
+ }, metadata?: any) => void;
23
+ /** Whether the field is disabled */
24
+ disabled?: boolean;
25
+ /** Placeholder text */
26
+ placeholder?: string;
27
+ /** Expected return type for validation */
28
+ expectedType?: string;
29
+ /** Whether this is a required field */
30
+ required?: boolean;
31
+ /** Whether this field has a required property error (missing value) */
32
+ hasRequiredError?: boolean;
33
+ /** Custom className for the wrapper */
34
+ className?: string;
35
+ /** Custom className for the editor container */
36
+ editorClassName?: string;
37
+ /** Property definition (for richer context) */
38
+ propertyDefinition?: any;
39
+ }
40
+ /**
41
+ * Mock Input component for development/design mode.
42
+ *
43
+ * This is a simplified version that renders a basic input field.
44
+ * In production, this is replaced with the real Input from packages/ui
45
+ * which includes collaboration, type inference, and expression support.
46
+ *
47
+ * @example
48
+ * ```tsx
49
+ * <Input
50
+ * fieldName="firstName"
51
+ * label="First Name"
52
+ * value={value}
53
+ * onChange={setValue}
54
+ * />
55
+ * ```
56
+ */
57
+ declare function Input({ fieldName, label, value, onChange, disabled, placeholder, expectedType, required, hasRequiredError, className, editorClassName, }: InputProps): React$1.JSX.Element;
58
+
59
+ interface SelectOption {
60
+ value: string;
61
+ label: string;
62
+ }
63
+ interface SelectProps {
64
+ /**
65
+ * Field name/key.
66
+ * Used for Yjs field path and validation error tracking.
67
+ * When nested inside NestedFieldProvider, the parent path is auto-prepended.
68
+ */
69
+ fieldName: string;
70
+ /** Display label for the field */
71
+ label: string;
72
+ /** Current value */
73
+ value: string | {
74
+ expression: string;
75
+ type: 'expression';
76
+ value?: string;
77
+ };
78
+ /** Called when value changes */
79
+ onChange: (value: string | {
80
+ expression: string;
81
+ type: 'expression';
82
+ }, metadata?: any) => void;
83
+ /** Available options */
84
+ options: SelectOption[] | string[];
85
+ /** Whether the field is disabled */
86
+ disabled?: boolean;
87
+ /** Placeholder text */
88
+ placeholder?: string;
89
+ /** Expected return type for validation */
90
+ expectedType?: string;
91
+ /** Whether this is a required field */
92
+ required?: boolean;
93
+ /** Whether this field has a required property error (missing value) */
94
+ hasRequiredError?: boolean;
95
+ /** Custom className for the wrapper */
96
+ className?: string;
97
+ /** Property definition (for richer context) */
98
+ propertyDefinition?: any;
99
+ /**
100
+ * Render prop for custom select UI.
101
+ * If not provided, uses a basic HTML select.
102
+ */
103
+ children?: (props: SelectRenderProps) => React$1.ReactNode;
104
+ }
105
+ interface SelectRenderProps {
106
+ value: string;
107
+ onChange: (value: string) => void;
108
+ onFocus?: () => void;
109
+ onBlur?: () => void;
110
+ onExpressionClick: () => void;
111
+ options: SelectOption[];
112
+ localInput: string;
113
+ setLocalInput: (value: string) => void;
114
+ expressionMode: {
115
+ current: 'value' | 'expression';
116
+ isExpressionMode: boolean;
117
+ isEditorMode: boolean;
118
+ isEditing: boolean;
119
+ isFullScreen: boolean;
120
+ expression: string;
121
+ switchToValue: () => void;
122
+ switchToExpression: () => void;
123
+ switchToEditor: () => void;
124
+ clear: () => void;
125
+ };
126
+ inferredType?: string;
127
+ hasTypeMismatch?: boolean;
128
+ hasError?: boolean;
129
+ }
130
+ /**
131
+ * Mock Select component for development/design mode.
132
+ *
133
+ * This is a simplified version that renders a basic select field.
134
+ * In production, this is replaced with the real Select from packages/ui
135
+ * which includes collaboration, type inference, and expression support.
136
+ *
137
+ * @example
138
+ * ```tsx
139
+ * <Select
140
+ * fieldName="status"
141
+ * label="Status"
142
+ * value={value}
143
+ * onChange={setValue}
144
+ * options={['draft', 'published', 'archived']}
145
+ * />
146
+ * ```
147
+ */
148
+ declare function Select({ fieldName, label, value, onChange, options: rawOptions, disabled, placeholder, expectedType, required, hasRequiredError, className, children, }: SelectProps): React$1.JSX.Element;
149
+
150
+ /**
151
+ * Mock context value (always returns defaults).
152
+ * In production, this is replaced with the real context from packages/ui.
153
+ */
154
+ interface TemplateFieldContextValue {
155
+ yDoc: null;
156
+ collabUser: null;
157
+ awareness: null;
158
+ availableNodes: any;
159
+ myInterface: any;
160
+ typeDeclarations: string;
161
+ element: any;
162
+ nodeId: string;
163
+ onControlFocus: (context: any) => void;
164
+ onControlBlur: () => void;
165
+ onRecordChange: (change: any) => void;
166
+ onValidationChange: (fieldName: string, error: any) => void;
167
+ parentFieldPath: string | null;
168
+ disabled: boolean;
169
+ }
170
+ /**
171
+ * Mock hook - returns empty context values.
172
+ * Components work as basic inputs in development mode.
173
+ */
174
+ declare function useTemplateFieldContext(): TemplateFieldContextValue;
175
+ /**
176
+ * Mock hook - always returns false in development mode.
177
+ */
178
+ declare function useIsInTemplateFieldProvider(): boolean;
179
+ /**
180
+ * Mock hook - returns the fieldName as-is (no parent path in dev mode).
181
+ */
182
+ declare function useFieldPath(fieldName: string): string;
183
+ /**
184
+ * Mock provider - just renders children without context.
185
+ */
186
+ declare function TemplateFieldProvider({ children }: {
187
+ children: React.ReactNode;
188
+ }): React$1.JSX.Element;
189
+ /**
190
+ * Mock provider - just renders children without nesting context.
191
+ */
192
+ declare function NestedFieldProvider({ children }: {
193
+ children: React.ReactNode;
194
+ fieldName: string;
195
+ }): React$1.JSX.Element;
196
+ type TemplateFieldProviderProps = {
197
+ children: React.ReactNode;
198
+ nodeId?: string;
199
+ yDoc?: any;
200
+ collabUser?: any;
201
+ awareness?: any;
202
+ availableNodes?: any;
203
+ myInterface?: any;
204
+ typeDeclarations?: string;
205
+ element?: any;
206
+ onControlFocus?: (context: any) => void;
207
+ onControlBlur?: () => void;
208
+ onRecordChange?: (change: any) => void;
209
+ onValidationChange?: (fieldName: string, error: any) => void;
210
+ parentFieldPath?: string | null;
211
+ disabled?: boolean;
212
+ };
213
+ type NestedFieldProviderProps = {
214
+ children: React.ReactNode;
215
+ fieldName: string;
216
+ };
217
+ type TemplateFieldValidationError = {
218
+ hasError: boolean;
219
+ hasSyntaxError: boolean;
220
+ hasTypeMismatch: boolean;
221
+ expectedType?: string;
222
+ inferredType?: string;
223
+ errorMessage?: string;
224
+ willCoerce?: boolean;
225
+ };
226
+ type TemplateFieldFocusContext = {
227
+ nodeId: string;
228
+ fieldName: string;
229
+ propertyPath: string;
230
+ label: string;
231
+ expectedType: string;
232
+ currentValue: any;
233
+ isExpression: boolean;
234
+ editorFormat: string;
235
+ inferredType?: string;
236
+ errors?: any;
237
+ selectedNodeId?: string;
238
+ selectedNodeName?: string;
239
+ elementContext?: any;
240
+ userContext?: any;
241
+ propertyDefinition?: any;
242
+ };
243
+ type TemplateFieldChangeEvent = {
244
+ type: 'value_change' | 'mode_switch' | 'format_change' | 'field_focus' | 'panel_open' | 'panel_close';
245
+ details: {
246
+ oldValue?: string;
247
+ newValue?: string;
248
+ oldMode?: string;
249
+ newMode?: string;
250
+ description?: string;
251
+ hasError?: boolean;
252
+ hasTypeMismatch?: boolean;
253
+ willCoerce?: boolean;
254
+ expectedType?: string;
255
+ inferredType?: string;
256
+ };
257
+ };
258
+
259
+ declare const index_Input: typeof Input;
260
+ type index_InputProps = InputProps;
261
+ declare const index_NestedFieldProvider: typeof NestedFieldProvider;
262
+ type index_NestedFieldProviderProps = NestedFieldProviderProps;
263
+ declare const index_Select: typeof Select;
264
+ type index_SelectOption = SelectOption;
265
+ type index_SelectProps = SelectProps;
266
+ type index_SelectRenderProps = SelectRenderProps;
267
+ type index_TemplateFieldChangeEvent = TemplateFieldChangeEvent;
268
+ type index_TemplateFieldContextValue = TemplateFieldContextValue;
269
+ type index_TemplateFieldFocusContext = TemplateFieldFocusContext;
270
+ declare const index_TemplateFieldProvider: typeof TemplateFieldProvider;
271
+ type index_TemplateFieldProviderProps = TemplateFieldProviderProps;
272
+ type index_TemplateFieldValidationError = TemplateFieldValidationError;
273
+ declare const index_useFieldPath: typeof useFieldPath;
274
+ declare const index_useIsInTemplateFieldProvider: typeof useIsInTemplateFieldProvider;
275
+ declare const index_useTemplateFieldContext: typeof useTemplateFieldContext;
276
+ declare namespace index {
277
+ export { index_Input as Input, type index_InputProps as InputProps, index_NestedFieldProvider as NestedFieldProvider, type index_NestedFieldProviderProps as NestedFieldProviderProps, index_Select as Select, type index_SelectOption as SelectOption, type index_SelectProps as SelectProps, type index_SelectRenderProps as SelectRenderProps, type index_TemplateFieldChangeEvent as TemplateFieldChangeEvent, type index_TemplateFieldContextValue as TemplateFieldContextValue, type index_TemplateFieldFocusContext as TemplateFieldFocusContext, index_TemplateFieldProvider as TemplateFieldProvider, type index_TemplateFieldProviderProps as TemplateFieldProviderProps, type index_TemplateFieldValidationError as TemplateFieldValidationError, index_useFieldPath as useFieldPath, index_useIsInTemplateFieldProvider as useIsInTemplateFieldProvider, index_useTemplateFieldContext as useTemplateFieldContext };
278
+ }
279
+
280
+ export { Input as I, NestedFieldProvider as N, Select as S, type TemplateFieldContextValue as T, useIsInTemplateFieldProvider as a, useFieldPath as b, TemplateFieldProvider as c, type TemplateFieldProviderProps as d, type NestedFieldProviderProps as e, type TemplateFieldValidationError as f, type TemplateFieldFocusContext as g, type TemplateFieldChangeEvent as h, index as i, type InputProps as j, type SelectProps as k, type SelectOption as l, type SelectRenderProps as m, useTemplateFieldContext as u };
@@ -0,0 +1,280 @@
1
+ import * as React$1 from 'react';
2
+
3
+ interface InputProps {
4
+ /**
5
+ * Field name/key.
6
+ * Used for Yjs field path and validation error tracking.
7
+ * When nested inside NestedFieldProvider, the parent path is auto-prepended.
8
+ */
9
+ fieldName: string;
10
+ /** Display label for the field */
11
+ label: string;
12
+ /** Current value */
13
+ value: string | {
14
+ expression: string;
15
+ type: 'expression';
16
+ value?: string;
17
+ };
18
+ /** Called when value changes */
19
+ onChange: (value: string | {
20
+ expression: string;
21
+ type: 'expression';
22
+ }, metadata?: any) => void;
23
+ /** Whether the field is disabled */
24
+ disabled?: boolean;
25
+ /** Placeholder text */
26
+ placeholder?: string;
27
+ /** Expected return type for validation */
28
+ expectedType?: string;
29
+ /** Whether this is a required field */
30
+ required?: boolean;
31
+ /** Whether this field has a required property error (missing value) */
32
+ hasRequiredError?: boolean;
33
+ /** Custom className for the wrapper */
34
+ className?: string;
35
+ /** Custom className for the editor container */
36
+ editorClassName?: string;
37
+ /** Property definition (for richer context) */
38
+ propertyDefinition?: any;
39
+ }
40
+ /**
41
+ * Mock Input component for development/design mode.
42
+ *
43
+ * This is a simplified version that renders a basic input field.
44
+ * In production, this is replaced with the real Input from packages/ui
45
+ * which includes collaboration, type inference, and expression support.
46
+ *
47
+ * @example
48
+ * ```tsx
49
+ * <Input
50
+ * fieldName="firstName"
51
+ * label="First Name"
52
+ * value={value}
53
+ * onChange={setValue}
54
+ * />
55
+ * ```
56
+ */
57
+ declare function Input({ fieldName, label, value, onChange, disabled, placeholder, expectedType, required, hasRequiredError, className, editorClassName, }: InputProps): React$1.JSX.Element;
58
+
59
+ interface SelectOption {
60
+ value: string;
61
+ label: string;
62
+ }
63
+ interface SelectProps {
64
+ /**
65
+ * Field name/key.
66
+ * Used for Yjs field path and validation error tracking.
67
+ * When nested inside NestedFieldProvider, the parent path is auto-prepended.
68
+ */
69
+ fieldName: string;
70
+ /** Display label for the field */
71
+ label: string;
72
+ /** Current value */
73
+ value: string | {
74
+ expression: string;
75
+ type: 'expression';
76
+ value?: string;
77
+ };
78
+ /** Called when value changes */
79
+ onChange: (value: string | {
80
+ expression: string;
81
+ type: 'expression';
82
+ }, metadata?: any) => void;
83
+ /** Available options */
84
+ options: SelectOption[] | string[];
85
+ /** Whether the field is disabled */
86
+ disabled?: boolean;
87
+ /** Placeholder text */
88
+ placeholder?: string;
89
+ /** Expected return type for validation */
90
+ expectedType?: string;
91
+ /** Whether this is a required field */
92
+ required?: boolean;
93
+ /** Whether this field has a required property error (missing value) */
94
+ hasRequiredError?: boolean;
95
+ /** Custom className for the wrapper */
96
+ className?: string;
97
+ /** Property definition (for richer context) */
98
+ propertyDefinition?: any;
99
+ /**
100
+ * Render prop for custom select UI.
101
+ * If not provided, uses a basic HTML select.
102
+ */
103
+ children?: (props: SelectRenderProps) => React$1.ReactNode;
104
+ }
105
+ interface SelectRenderProps {
106
+ value: string;
107
+ onChange: (value: string) => void;
108
+ onFocus?: () => void;
109
+ onBlur?: () => void;
110
+ onExpressionClick: () => void;
111
+ options: SelectOption[];
112
+ localInput: string;
113
+ setLocalInput: (value: string) => void;
114
+ expressionMode: {
115
+ current: 'value' | 'expression';
116
+ isExpressionMode: boolean;
117
+ isEditorMode: boolean;
118
+ isEditing: boolean;
119
+ isFullScreen: boolean;
120
+ expression: string;
121
+ switchToValue: () => void;
122
+ switchToExpression: () => void;
123
+ switchToEditor: () => void;
124
+ clear: () => void;
125
+ };
126
+ inferredType?: string;
127
+ hasTypeMismatch?: boolean;
128
+ hasError?: boolean;
129
+ }
130
+ /**
131
+ * Mock Select component for development/design mode.
132
+ *
133
+ * This is a simplified version that renders a basic select field.
134
+ * In production, this is replaced with the real Select from packages/ui
135
+ * which includes collaboration, type inference, and expression support.
136
+ *
137
+ * @example
138
+ * ```tsx
139
+ * <Select
140
+ * fieldName="status"
141
+ * label="Status"
142
+ * value={value}
143
+ * onChange={setValue}
144
+ * options={['draft', 'published', 'archived']}
145
+ * />
146
+ * ```
147
+ */
148
+ declare function Select({ fieldName, label, value, onChange, options: rawOptions, disabled, placeholder, expectedType, required, hasRequiredError, className, children, }: SelectProps): React$1.JSX.Element;
149
+
150
+ /**
151
+ * Mock context value (always returns defaults).
152
+ * In production, this is replaced with the real context from packages/ui.
153
+ */
154
+ interface TemplateFieldContextValue {
155
+ yDoc: null;
156
+ collabUser: null;
157
+ awareness: null;
158
+ availableNodes: any;
159
+ myInterface: any;
160
+ typeDeclarations: string;
161
+ element: any;
162
+ nodeId: string;
163
+ onControlFocus: (context: any) => void;
164
+ onControlBlur: () => void;
165
+ onRecordChange: (change: any) => void;
166
+ onValidationChange: (fieldName: string, error: any) => void;
167
+ parentFieldPath: string | null;
168
+ disabled: boolean;
169
+ }
170
+ /**
171
+ * Mock hook - returns empty context values.
172
+ * Components work as basic inputs in development mode.
173
+ */
174
+ declare function useTemplateFieldContext(): TemplateFieldContextValue;
175
+ /**
176
+ * Mock hook - always returns false in development mode.
177
+ */
178
+ declare function useIsInTemplateFieldProvider(): boolean;
179
+ /**
180
+ * Mock hook - returns the fieldName as-is (no parent path in dev mode).
181
+ */
182
+ declare function useFieldPath(fieldName: string): string;
183
+ /**
184
+ * Mock provider - just renders children without context.
185
+ */
186
+ declare function TemplateFieldProvider({ children }: {
187
+ children: React.ReactNode;
188
+ }): React$1.JSX.Element;
189
+ /**
190
+ * Mock provider - just renders children without nesting context.
191
+ */
192
+ declare function NestedFieldProvider({ children }: {
193
+ children: React.ReactNode;
194
+ fieldName: string;
195
+ }): React$1.JSX.Element;
196
+ type TemplateFieldProviderProps = {
197
+ children: React.ReactNode;
198
+ nodeId?: string;
199
+ yDoc?: any;
200
+ collabUser?: any;
201
+ awareness?: any;
202
+ availableNodes?: any;
203
+ myInterface?: any;
204
+ typeDeclarations?: string;
205
+ element?: any;
206
+ onControlFocus?: (context: any) => void;
207
+ onControlBlur?: () => void;
208
+ onRecordChange?: (change: any) => void;
209
+ onValidationChange?: (fieldName: string, error: any) => void;
210
+ parentFieldPath?: string | null;
211
+ disabled?: boolean;
212
+ };
213
+ type NestedFieldProviderProps = {
214
+ children: React.ReactNode;
215
+ fieldName: string;
216
+ };
217
+ type TemplateFieldValidationError = {
218
+ hasError: boolean;
219
+ hasSyntaxError: boolean;
220
+ hasTypeMismatch: boolean;
221
+ expectedType?: string;
222
+ inferredType?: string;
223
+ errorMessage?: string;
224
+ willCoerce?: boolean;
225
+ };
226
+ type TemplateFieldFocusContext = {
227
+ nodeId: string;
228
+ fieldName: string;
229
+ propertyPath: string;
230
+ label: string;
231
+ expectedType: string;
232
+ currentValue: any;
233
+ isExpression: boolean;
234
+ editorFormat: string;
235
+ inferredType?: string;
236
+ errors?: any;
237
+ selectedNodeId?: string;
238
+ selectedNodeName?: string;
239
+ elementContext?: any;
240
+ userContext?: any;
241
+ propertyDefinition?: any;
242
+ };
243
+ type TemplateFieldChangeEvent = {
244
+ type: 'value_change' | 'mode_switch' | 'format_change' | 'field_focus' | 'panel_open' | 'panel_close';
245
+ details: {
246
+ oldValue?: string;
247
+ newValue?: string;
248
+ oldMode?: string;
249
+ newMode?: string;
250
+ description?: string;
251
+ hasError?: boolean;
252
+ hasTypeMismatch?: boolean;
253
+ willCoerce?: boolean;
254
+ expectedType?: string;
255
+ inferredType?: string;
256
+ };
257
+ };
258
+
259
+ declare const index_Input: typeof Input;
260
+ type index_InputProps = InputProps;
261
+ declare const index_NestedFieldProvider: typeof NestedFieldProvider;
262
+ type index_NestedFieldProviderProps = NestedFieldProviderProps;
263
+ declare const index_Select: typeof Select;
264
+ type index_SelectOption = SelectOption;
265
+ type index_SelectProps = SelectProps;
266
+ type index_SelectRenderProps = SelectRenderProps;
267
+ type index_TemplateFieldChangeEvent = TemplateFieldChangeEvent;
268
+ type index_TemplateFieldContextValue = TemplateFieldContextValue;
269
+ type index_TemplateFieldFocusContext = TemplateFieldFocusContext;
270
+ declare const index_TemplateFieldProvider: typeof TemplateFieldProvider;
271
+ type index_TemplateFieldProviderProps = TemplateFieldProviderProps;
272
+ type index_TemplateFieldValidationError = TemplateFieldValidationError;
273
+ declare const index_useFieldPath: typeof useFieldPath;
274
+ declare const index_useIsInTemplateFieldProvider: typeof useIsInTemplateFieldProvider;
275
+ declare const index_useTemplateFieldContext: typeof useTemplateFieldContext;
276
+ declare namespace index {
277
+ export { index_Input as Input, type index_InputProps as InputProps, index_NestedFieldProvider as NestedFieldProvider, type index_NestedFieldProviderProps as NestedFieldProviderProps, index_Select as Select, type index_SelectOption as SelectOption, type index_SelectProps as SelectProps, type index_SelectRenderProps as SelectRenderProps, type index_TemplateFieldChangeEvent as TemplateFieldChangeEvent, type index_TemplateFieldContextValue as TemplateFieldContextValue, type index_TemplateFieldFocusContext as TemplateFieldFocusContext, index_TemplateFieldProvider as TemplateFieldProvider, type index_TemplateFieldProviderProps as TemplateFieldProviderProps, type index_TemplateFieldValidationError as TemplateFieldValidationError, index_useFieldPath as useFieldPath, index_useIsInTemplateFieldProvider as useIsInTemplateFieldProvider, index_useTemplateFieldContext as useTemplateFieldContext };
278
+ }
279
+
280
+ export { Input as I, NestedFieldProvider as N, Select as S, type TemplateFieldContextValue as T, useIsInTemplateFieldProvider as a, useFieldPath as b, TemplateFieldProvider as c, type TemplateFieldProviderProps as d, type NestedFieldProviderProps as e, type TemplateFieldValidationError as f, type TemplateFieldFocusContext as g, type TemplateFieldChangeEvent as h, index as i, type InputProps as j, type SelectProps as k, type SelectOption as l, type SelectRenderProps as m, useTemplateFieldContext as u };