epic-designer-dev
Version:
基于vue3的设计器,可视化开发页面表单。在epic-designer的基础上新增了字典选择器
74 lines (73 loc) • 3.6 kB
TypeScript
import { ComponentSchema, EpicNodeInstance } from '../../../types/src/index';
export interface ActionsModel {
args: string;
componentId?: string;
methodName: string;
type: 'component' | 'custom' | 'public';
}
export declare function usePageManager(): {
addComponentInstance: (id: string, instance: EpicNodeInstance) => void;
addFormData: (formData: Record<string, unknown>, formName?: string) => void;
componentInstances: import('vue').Ref<Record<string, EpicNodeInstance>, Record<string, EpicNodeInstance>>;
defaultComponentIds: import('vue').Ref<string[], string[]>;
doActions: (actions: ActionsModel[], ...args: unknown[]) => void;
find: (queryValue: string, queryField?: string) => EpicNodeInstance["exposed"] | null;
findAll: (queryValue: string, queryField?: string) => EpicNodeInstance["exposed"][];
findInstance: (queryValue: string, queryField?: string) => EpicNodeInstance | null;
findInstanceAll: (queryValue: string, queryField?: string) => EpicNodeInstance[];
forms: Record<string, unknown>;
funcs: import('vue').Ref<Record<string, Function>, Record<string, Function>>;
getComponentInstance: (queryValue: string, queryField?: string) => EpicNodeInstance["exposed"] | null;
isDesignMode: import('vue').Ref<boolean, boolean>;
pageSchema: {
canvas?: {
height?: string | undefined;
mode?: "desktop" | "mobile" | "pad" | "pc" | "tablet" | undefined;
width?: string | undefined;
} | undefined;
schemas: {
[x: string]: any;
children?: /*elided*/ any[] | undefined;
componentProps?: any;
describe?: string | undefined;
editData?: object | undefined;
field?: string | undefined;
id?: string | undefined;
input?: boolean | undefined;
label?: string | undefined;
noFormItem?: boolean | undefined;
on?: {
[eventName: string]: ActionsModel[];
} | undefined;
rules?: {
[x: string]: any;
trigger?: string | string[] | undefined;
enum?: Array<boolean | null | number | string | undefined> | undefined;
isValidator?: boolean | undefined;
len?: number | undefined;
max?: number | undefined;
message?: ((a?: string) => string) | string | undefined;
min?: number | undefined;
pattern?: (RegExp | string) | undefined;
required?: boolean | undefined;
type?: string | undefined;
validator?: string | undefined;
whitespace?: boolean | undefined;
}[] | undefined;
show?: ((renderCallbackParams: import('../../../types/src/index').RenderCallbackParams) => boolean) | boolean | undefined;
slotName?: string | undefined;
slots?: {
[slotName: string]: ComponentSchema[];
} | undefined;
type: string;
}[];
script?: string | undefined;
};
removeComponentInstance: (id: string) => void;
setDefaultComponentIds: (schemas: ComponentSchema[]) => void;
setDesignMode: (isDesign?: boolean) => void;
setFormData: (formData: Record<string, unknown>, formName?: string) => void;
setMethods: (scriptStr: string, outputError?: boolean) => void;
setPageSchema: (schema: import('../../../types/src/index').PageSchema) => void;
};
export type PageManager = ReturnType<typeof usePageManager>;