@yourself.create/ngx-form-designer 0.0.3 → 0.0.4
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/fesm2022/uch-web-ngx-form-designer.mjs +2866 -408
- package/fesm2022/uch-web-ngx-form-designer.mjs.map +1 -1
- package/lib/ai/provide-form-designer-angai-feature.d.ts +16 -0
- package/lib/form-core/form-engine.d.ts +7 -3
- package/lib/form-core/form-event-runner.d.ts +14 -0
- package/lib/form-core/form-journey.models.d.ts +30 -0
- package/lib/form-core/models.d.ts +7 -1
- package/lib/form-designer/designer-state.service.d.ts +1 -1
- package/lib/form-designer/events-workspace.component.d.ts +28 -3
- package/lib/form-designer/form-designer-shell.component.d.ts +30 -5
- package/lib/form-designer/form-journey-state.service.d.ts +28 -0
- package/lib/form-designer/form-preview.component.d.ts +21 -2
- package/lib/form-designer/inspector-sections/inspector-backgrounds-section.component.d.ts +5 -0
- package/lib/form-designer/inspector-sections/inspector-typography-section.component.d.ts +1 -0
- package/lib/form-designer/json-form-designer.component.d.ts +21 -2
- package/lib/form-designer/layout-canvas.component.d.ts +3 -1
- package/lib/form-designer/template-library.d.ts +2 -0
- package/lib/form-renderer/form-journey-viewer.component.d.ts +51 -0
- package/lib/form-renderer/form-viewer/form-viewer.component.d.ts +16 -3
- package/lib/form-renderer/json-form-renderer.component.d.ts +10 -2
- package/lib/form-renderer/layout-node.component.d.ts +2 -1
- package/lib/ui/ui-color-swatch.component.d.ts +1 -0
- package/lib/website/website-preview-shell.component.d.ts +1 -1
- package/lib/widgets/field-widgets/checkbox-group/checkbox-group-widget.component.d.ts +5 -0
- package/lib/widgets/field-widgets/option-field-labels.d.ts +3 -0
- package/lib/widgets/field-widgets/radio/radio-widget.component.d.ts +5 -0
- package/lib/widgets/field-widgets/search/search-widget.component.d.ts +4 -0
- package/lib/widgets/field-widgets/select/select-widget.component.d.ts +9 -0
- package/lib/widgets/field-widgets/text-field/text-field.component.d.ts +3 -0
- package/package.json +3 -2
- package/public-api.d.ts +4 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { OnInit, OnChanges, SimpleChanges, EventEmitter, OnDestroy } from '@angular/core';
|
|
2
|
-
import { DesignerEventApiDefinition, FormSchema, UploadedFileRef, WidgetEventApiExecutor } from '../form-core/models';
|
|
2
|
+
import { DesignerEventApiDefinition, FieldDisplayLabel, FormSchema, UploadedFileRef, WidgetEventApiExecutor } from '../form-core/models';
|
|
3
3
|
import { FormEngine } from '../form-core/form-engine';
|
|
4
4
|
import { DesignerStateService } from '../form-designer/designer-state.service';
|
|
5
5
|
import { type FieldDataAccessMap, type RuntimeFieldDataAccessApi } from '../data/runtime-field-data-access-registry.service';
|
|
@@ -7,6 +7,7 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
export interface FormFieldValue {
|
|
8
8
|
fieldName: string;
|
|
9
9
|
fieldValue: unknown;
|
|
10
|
+
fieldLabel?: FieldDisplayLabel;
|
|
10
11
|
fileType?: string | string[];
|
|
11
12
|
data?: string | string[];
|
|
12
13
|
}
|
|
@@ -28,8 +29,10 @@ export declare class JsonFormRendererComponent implements OnInit, OnChanges, OnD
|
|
|
28
29
|
private designerState;
|
|
29
30
|
schema: FormSchema;
|
|
30
31
|
initialValues: Record<string, any>;
|
|
32
|
+
initialFieldLabels: Record<string, FieldDisplayLabel>;
|
|
31
33
|
mode: 'live' | 'preview' | 'design';
|
|
32
34
|
device: 'desktop' | 'mobile';
|
|
35
|
+
showLayoutGuides: boolean;
|
|
33
36
|
breakpoint: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';
|
|
34
37
|
eventLogger?: {
|
|
35
38
|
log: (message: string, data?: unknown) => void;
|
|
@@ -37,6 +40,10 @@ export declare class JsonFormRendererComponent implements OnInit, OnChanges, OnD
|
|
|
37
40
|
};
|
|
38
41
|
eventApis: DesignerEventApiDefinition[];
|
|
39
42
|
eventApiExecutor?: WidgetEventApiExecutor;
|
|
43
|
+
navigateToPage?: (pageId: string) => Promise<{
|
|
44
|
+
ok: boolean;
|
|
45
|
+
reason?: string;
|
|
46
|
+
}>;
|
|
40
47
|
uploadOnSubmit: boolean;
|
|
41
48
|
fieldDataAccessMap?: FieldDataAccessMap;
|
|
42
49
|
fieldDataAccessApi?: RuntimeFieldDataAccessApi;
|
|
@@ -87,6 +94,7 @@ export declare class JsonFormRendererComponent implements OnInit, OnChanges, OnD
|
|
|
87
94
|
private encodeBytesToBase64;
|
|
88
95
|
private toSingleOrList;
|
|
89
96
|
private getUploadedFileRefs;
|
|
97
|
+
private buildFieldLabelMetadata;
|
|
90
98
|
private mergeFileMetadata;
|
|
91
99
|
private buildGroupedValues;
|
|
92
100
|
private buildCombinedValues;
|
|
@@ -94,5 +102,5 @@ export declare class JsonFormRendererComponent implements OnInit, OnChanges, OnD
|
|
|
94
102
|
private isGroupValue;
|
|
95
103
|
private isUploadedFileRef;
|
|
96
104
|
static ɵfac: i0.ɵɵFactoryDeclaration<JsonFormRendererComponent, never>;
|
|
97
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<JsonFormRendererComponent, "app-json-form-renderer", never, { "schema": { "alias": "schema"; "required": false; }; "initialValues": { "alias": "initialValues"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; "device": { "alias": "device"; "required": false; }; "breakpoint": { "alias": "breakpoint"; "required": false; }; "eventLogger": { "alias": "eventLogger"; "required": false; }; "eventApis": { "alias": "eventApis"; "required": false; }; "eventApiExecutor": { "alias": "eventApiExecutor"; "required": false; }; "uploadOnSubmit": { "alias": "uploadOnSubmit"; "required": false; }; "fieldDataAccessMap": { "alias": "fieldDataAccessMap"; "required": false; }; "fieldDataAccessApi": { "alias": "fieldDataAccessApi"; "required": false; }; "formContentId": { "alias": "formContentId"; "required": false; }; "formContentVersion": { "alias": "formContentVersion"; "required": false; }; }, { "valueChange": "valueChange"; "groupedValueChange": "groupedValueChange"; "combinedValueChange": "combinedValueChange"; "validationChange": "validationChange"; "uploadedFilesChange": "uploadedFilesChange"; "formSubmit": "formSubmit"; }, never, never, true, never>;
|
|
105
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<JsonFormRendererComponent, "app-json-form-renderer", never, { "schema": { "alias": "schema"; "required": false; }; "initialValues": { "alias": "initialValues"; "required": false; }; "initialFieldLabels": { "alias": "initialFieldLabels"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; "device": { "alias": "device"; "required": false; }; "showLayoutGuides": { "alias": "showLayoutGuides"; "required": false; }; "breakpoint": { "alias": "breakpoint"; "required": false; }; "eventLogger": { "alias": "eventLogger"; "required": false; }; "eventApis": { "alias": "eventApis"; "required": false; }; "eventApiExecutor": { "alias": "eventApiExecutor"; "required": false; }; "navigateToPage": { "alias": "navigateToPage"; "required": false; }; "uploadOnSubmit": { "alias": "uploadOnSubmit"; "required": false; }; "fieldDataAccessMap": { "alias": "fieldDataAccessMap"; "required": false; }; "fieldDataAccessApi": { "alias": "fieldDataAccessApi"; "required": false; }; "formContentId": { "alias": "formContentId"; "required": false; }; "formContentVersion": { "alias": "formContentVersion"; "required": false; }; }, { "valueChange": "valueChange"; "groupedValueChange": "groupedValueChange"; "combinedValueChange": "combinedValueChange"; "validationChange": "validationChange"; "uploadedFilesChange": "uploadedFilesChange"; "formSubmit": "formSubmit"; }, never, never, true, never>;
|
|
98
106
|
}
|
|
@@ -15,6 +15,7 @@ export declare class LayoutNodeComponent implements OnInit, OnChanges, OnDestroy
|
|
|
15
15
|
engine: FormEngine;
|
|
16
16
|
fields: FieldSchema[];
|
|
17
17
|
designMode: boolean;
|
|
18
|
+
showLayoutGuides: boolean;
|
|
18
19
|
readOnlyMode: boolean;
|
|
19
20
|
scopePath: string[];
|
|
20
21
|
device: 'desktop' | 'mobile';
|
|
@@ -107,5 +108,5 @@ export declare class LayoutNodeComponent implements OnInit, OnChanges, OnDestroy
|
|
|
107
108
|
isRuleControlled(node: LayoutNode): boolean;
|
|
108
109
|
private getFieldForWidgetNode;
|
|
109
110
|
static ɵfac: i0.ɵɵFactoryDeclaration<LayoutNodeComponent, never>;
|
|
110
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<LayoutNodeComponent, "app-layout-node", never, { "node": { "alias": "node"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "fields": { "alias": "fields"; "required": false; }; "designMode": { "alias": "designMode"; "required": false; }; "readOnlyMode": { "alias": "readOnlyMode"; "required": false; }; "scopePath": { "alias": "scopePath"; "required": false; }; "device": { "alias": "device"; "required": false; }; "breakpoint": { "alias": "breakpoint"; "required": false; }; "connectedDropLists": { "alias": "connectedDropLists"; "required": false; }; }, { "nodeDrop": "nodeDrop"; "nodeSelect": "nodeSelect"; }, never, never, true, never>;
|
|
111
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<LayoutNodeComponent, "app-layout-node", never, { "node": { "alias": "node"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "fields": { "alias": "fields"; "required": false; }; "designMode": { "alias": "designMode"; "required": false; }; "showLayoutGuides": { "alias": "showLayoutGuides"; "required": false; }; "readOnlyMode": { "alias": "readOnlyMode"; "required": false; }; "scopePath": { "alias": "scopePath"; "required": false; }; "device": { "alias": "device"; "required": false; }; "breakpoint": { "alias": "breakpoint"; "required": false; }; "connectedDropLists": { "alias": "connectedDropLists"; "required": false; }; }, { "nodeDrop": "nodeDrop"; "nodeSelect": "nodeSelect"; }, never, never, true, never>;
|
|
111
112
|
}
|
|
@@ -7,6 +7,7 @@ export declare class UiColorSwatchComponent {
|
|
|
7
7
|
value: string;
|
|
8
8
|
valueChange: EventEmitter<string>;
|
|
9
9
|
blur: EventEmitter<void>;
|
|
10
|
+
onPickerChange(color: string): void;
|
|
10
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<UiColorSwatchComponent, never>;
|
|
11
12
|
static ɵcmp: i0.ɵɵComponentDeclaration<UiColorSwatchComponent, "ui-color-swatch", never, { "label": { "alias": "label"; "required": false; }; "hint": { "alias": "hint"; "required": false; }; "helpText": { "alias": "helpText"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, { "valueChange": "valueChange"; "blur": "blur"; }, never, never, true, never>;
|
|
12
13
|
}
|
|
@@ -6,7 +6,7 @@ export declare class WebsitePreviewShellComponent {
|
|
|
6
6
|
readonly pages: import("@angular/core").Signal<import("@uch-web/ngx-form-designer").WebsitePage[]>;
|
|
7
7
|
readonly breakpoints: readonly ["xs", "sm", "md", "lg", "xl", "2xl"];
|
|
8
8
|
readonly breakpoint: import("@angular/core").WritableSignal<"xs" | "sm" | "md" | "lg" | "xl" | "2xl">;
|
|
9
|
-
readonly activeDevice: import("@angular/core").Signal<"
|
|
9
|
+
readonly activeDevice: import("@angular/core").Signal<"desktop" | "mobile">;
|
|
10
10
|
private readonly url;
|
|
11
11
|
readonly activePage: import("@angular/core").Signal<import("@uch-web/ngx-form-designer").WebsitePage | null>;
|
|
12
12
|
setBreakpoint(bp: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl'): void;
|
|
@@ -40,6 +40,11 @@ export declare class CheckboxGroupWidgetComponent implements OnInit, OnChanges,
|
|
|
40
40
|
onFocus(): void;
|
|
41
41
|
onClick(): void;
|
|
42
42
|
onBlur(): void;
|
|
43
|
+
private areApiCallsSuppressed;
|
|
44
|
+
private hasSelectedValue;
|
|
45
|
+
private withSelectedValueFallbackOptions;
|
|
46
|
+
private getStoredFieldLabel;
|
|
47
|
+
private setStoredFieldLabel;
|
|
43
48
|
static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxGroupWidgetComponent, never>;
|
|
44
49
|
static ɵcmp: i0.ɵɵComponentDeclaration<CheckboxGroupWidgetComponent, "app-checkbox-group-widget", never, { "config": { "alias": "config"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, true, never>;
|
|
45
50
|
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { FieldDisplayLabel, OptionSchema } from '../../form-core/models';
|
|
2
|
+
export declare function resolveOptionFieldLabel(value: unknown, options: OptionSchema[], existingLabel?: FieldDisplayLabel): FieldDisplayLabel | undefined;
|
|
3
|
+
export declare function buildFallbackOptions(value: unknown, label?: FieldDisplayLabel): OptionSchema[];
|
|
@@ -40,6 +40,11 @@ export declare class RadioWidgetComponent implements OnInit, OnChanges, OnDestro
|
|
|
40
40
|
onClick(): void;
|
|
41
41
|
onBlur(): void;
|
|
42
42
|
private syncEnabledState;
|
|
43
|
+
private areApiCallsSuppressed;
|
|
44
|
+
private hasSelectedValue;
|
|
45
|
+
private withSelectedValueFallbackOptions;
|
|
46
|
+
private getStoredFieldLabel;
|
|
47
|
+
private setStoredFieldLabel;
|
|
43
48
|
static ɵfac: i0.ɵɵFactoryDeclaration<RadioWidgetComponent, never>;
|
|
44
49
|
static ɵcmp: i0.ɵɵComponentDeclaration<RadioWidgetComponent, "app-radio-widget", never, { "config": { "alias": "config"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, true, never>;
|
|
45
50
|
}
|
|
@@ -26,6 +26,7 @@ export declare class SearchWidgetComponent implements OnInit, OnDestroy {
|
|
|
26
26
|
private requestId;
|
|
27
27
|
private syncingFromQuery;
|
|
28
28
|
private selectingOption;
|
|
29
|
+
private pendingSelectedLabel?;
|
|
29
30
|
private focused;
|
|
30
31
|
private hovered;
|
|
31
32
|
private blurCloseTimeout;
|
|
@@ -67,6 +68,9 @@ export declare class SearchWidgetComponent implements OnInit, OnDestroy {
|
|
|
67
68
|
private getResultLimit;
|
|
68
69
|
private toSafeNonNegativeInt;
|
|
69
70
|
private asQueryString;
|
|
71
|
+
private getDisplayValue;
|
|
72
|
+
private getStoredFieldLabel;
|
|
73
|
+
private setStoredFieldLabel;
|
|
70
74
|
static ɵfac: i0.ɵɵFactoryDeclaration<SearchWidgetComponent, never>;
|
|
71
75
|
static ɵcmp: i0.ɵɵComponentDeclaration<SearchWidgetComponent, "app-search-widget", never, { "config": { "alias": "config"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, true, never>;
|
|
72
76
|
}
|
|
@@ -79,6 +79,15 @@ export declare class SelectWidgetComponent implements OnInit, OnDestroy {
|
|
|
79
79
|
private getAccessibleLabel;
|
|
80
80
|
private syncTemplateBindingCaches;
|
|
81
81
|
private toSafeNonNegativeInt;
|
|
82
|
+
private areApiCallsSuppressed;
|
|
83
|
+
private withSelectedValueFallbackOptions;
|
|
84
|
+
private getSelectedFallbackOptions;
|
|
85
|
+
private hasOptionValue;
|
|
86
|
+
private resolveSelectedValueForFallback;
|
|
87
|
+
private hasMeaningfulValue;
|
|
88
|
+
private syncStoredFieldLabel;
|
|
89
|
+
private getStoredFieldLabel;
|
|
90
|
+
private setStoredFieldLabel;
|
|
82
91
|
static ɵfac: i0.ɵɵFactoryDeclaration<SelectWidgetComponent, never>;
|
|
83
92
|
static ɵcmp: i0.ɵɵComponentDeclaration<SelectWidgetComponent, "app-select-widget", never, { "config": { "alias": "config"; "required": false; }; "engine": { "alias": "engine"; "required": false; }; "control": { "alias": "control"; "required": false; }; }, {}, never, never, true, never>;
|
|
84
93
|
}
|
|
@@ -22,6 +22,7 @@ export declare class TextFieldWidgetComponent implements OnInit, OnDestroy {
|
|
|
22
22
|
protected readonly fieldRequiredClass = "text-red-500";
|
|
23
23
|
get fieldId(): string;
|
|
24
24
|
protected isTextarea(): boolean;
|
|
25
|
+
protected isColorField(): boolean;
|
|
25
26
|
protected getControlClass(multiline?: boolean): string;
|
|
26
27
|
protected getAccessibleLabel(): string;
|
|
27
28
|
protected nativeLabel(): string;
|
|
@@ -35,6 +36,8 @@ export declare class TextFieldWidgetComponent implements OnInit, OnDestroy {
|
|
|
35
36
|
onBlur(): void;
|
|
36
37
|
onMouseEnter(): void;
|
|
37
38
|
onMouseLeave(): void;
|
|
39
|
+
protected getColorPickerValue(): string;
|
|
40
|
+
protected onColorPickerChange(color: string): void;
|
|
38
41
|
ngOnDestroy(): void;
|
|
39
42
|
getWrapperStyles(): Record<string, any>;
|
|
40
43
|
getControlStyles(): Record<string, any>;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@yourself.create/ngx-form-designer",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.4",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^19.0.0",
|
|
6
6
|
"@angular/core": "^19.0.0",
|
|
@@ -13,7 +13,8 @@
|
|
|
13
13
|
"react": "^18.2.0",
|
|
14
14
|
"react-dom": "^18.2.0",
|
|
15
15
|
"@babel/standalone": "^7.25.0",
|
|
16
|
-
"@json-editor/json-editor": "^2.15.2"
|
|
16
|
+
"@json-editor/json-editor": "^2.15.2",
|
|
17
|
+
"ngx-color-picker": "^20.1.1"
|
|
17
18
|
},
|
|
18
19
|
"peerDependenciesMeta": {
|
|
19
20
|
"react": {
|
package/public-api.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './lib/form-core/models';
|
|
2
|
+
export * from './lib/form-core/form-journey.models';
|
|
2
3
|
export * from './lib/form-core/form-engine';
|
|
3
4
|
export * from './lib/form-core/schema-factory';
|
|
4
5
|
export * from './lib/form-core/schema-guard';
|
|
@@ -6,8 +7,10 @@ export * from './lib/form-renderer/json-form-renderer.component';
|
|
|
6
7
|
export * from './lib/form-renderer/layout-node.component';
|
|
7
8
|
export * from './lib/email-renderer/email-renderer.component';
|
|
8
9
|
export * from './lib/form-renderer/form-viewer/form-viewer.component';
|
|
10
|
+
export * from './lib/form-renderer/form-journey-viewer.component';
|
|
9
11
|
export * from './lib/form-designer/json-form-designer.component';
|
|
10
12
|
export * from './lib/form-designer/form-designer-shell.component';
|
|
13
|
+
export * from './lib/form-designer/form-journey-state.service';
|
|
11
14
|
export * from './lib/form-designer/events-workspace.component';
|
|
12
15
|
export * from './lib/form-designer/designer-state.service';
|
|
13
16
|
export * from './lib/form-designer/designer-context.service';
|
|
@@ -63,6 +66,7 @@ export * from './lib/widgets/style-helpers';
|
|
|
63
66
|
export * from './lib/widgets/widget-theme';
|
|
64
67
|
export * from './lib/ai/ai-tool-registry.service';
|
|
65
68
|
export * from './lib/ai/plugins/form-designer-tool-plugin';
|
|
69
|
+
export * from './lib/ai/provide-form-designer-angai-feature';
|
|
66
70
|
export * from './lib/data/data-catalog';
|
|
67
71
|
export * from './lib/data/data-provider';
|
|
68
72
|
export * from './lib/data/in-memory-data-catalog.service';
|