PromucFlow_constructor/app/client/src/utils/FormControlFactory.tsx
akash-codemonk c3c7b9b7d7
Add new property to conditionally hide form fields in datasource and editor (#1682)
* Create a form control component which handles the hidden logic

* Add tests
2020-11-19 09:02:58 +05:30

54 lines
1.3 KiB
TypeScript

import { ControlType } from "constants/PropertyControlConstants";
import {
ControlBuilder,
ControlProps,
ControlData,
} from "components/formControls/BaseControl";
class FormControlFacotory {
static controlMap: Map<ControlType, ControlBuilder<ControlProps>> = new Map();
static registerControlBuilder(
controlType: ControlType,
controlBuilder: ControlBuilder<ControlProps>,
) {
this.controlMap.set(controlType, controlBuilder);
}
static createControl(
controlData: ControlData,
formName: string,
extraData?: ControlData[],
): JSX.Element {
const controlBuilder = this.controlMap.get(controlData.controlType);
if (controlBuilder) {
const controlProps: ControlProps = {
...controlData,
formName,
extraData,
key: controlData.id,
};
const control = controlBuilder.buildPropertyControl(controlProps);
return control;
} else {
const ex: ControlCreationException = {
message:
"Control Builder not registered for control type " +
controlData.controlType,
};
throw ex;
}
}
static getControlTypes(): ControlType[] {
return Array.from(this.controlMap.keys());
}
}
export interface ControlCreationException {
message: string;
}
export default FormControlFacotory;