2020-03-27 09:02:11 +00:00
|
|
|
import BaseWidget, { WidgetProps } from "widgets/BaseWidget";
|
|
|
|
|
import { WidgetTypes } from "constants/WidgetConstants";
|
2019-11-25 05:07:27 +00:00
|
|
|
import ContainerWidget, { ContainerWidgetProps } from "widgets/ContainerWidget";
|
|
|
|
|
import TextWidget, { TextWidgetProps } from "widgets/TextWidget";
|
|
|
|
|
import InputWidget, { InputWidgetProps } from "widgets/InputWidget";
|
|
|
|
|
import CheckboxWidget, { CheckboxWidgetProps } from "widgets/CheckboxWidget";
|
2019-03-21 12:10:32 +00:00
|
|
|
import RadioGroupWidget, {
|
2019-09-09 09:08:54 +00:00
|
|
|
RadioGroupWidgetProps,
|
2019-11-25 05:07:27 +00:00
|
|
|
} from "widgets/RadioGroupWidget";
|
2019-09-09 09:08:54 +00:00
|
|
|
import WidgetFactory from "./WidgetFactory";
|
|
|
|
|
import React from "react";
|
2019-11-25 05:07:27 +00:00
|
|
|
import ButtonWidget, { ButtonWidgetProps } from "widgets/ButtonWidget";
|
|
|
|
|
import DropdownWidget, { DropdownWidgetProps } from "widgets/DropdownWidget";
|
|
|
|
|
import ImageWidget, { ImageWidgetProps } from "widgets/ImageWidget";
|
|
|
|
|
import TableWidget, { TableWidgetProps } from "widgets/TableWidget";
|
2020-04-15 11:42:11 +00:00
|
|
|
import TabsWidget, {
|
|
|
|
|
TabsWidgetProps,
|
|
|
|
|
TabContainerWidgetProps,
|
|
|
|
|
} from "widgets/TabsWidget";
|
2020-03-27 09:02:11 +00:00
|
|
|
import ModalWidget, { ModalWidgetProps } from "widgets/ModalWidget";
|
2020-03-20 11:17:30 +00:00
|
|
|
import RichTextEditorWidget, {
|
|
|
|
|
RichTextEditorWidgetProps,
|
|
|
|
|
} from "widgets/RichTextEditorWidget";
|
2020-03-13 12:06:41 +00:00
|
|
|
import ChartWidget, { ChartWidgetProps } from "widgets/ChartWidget";
|
2020-04-15 11:42:11 +00:00
|
|
|
import MapWidget, { MapWidgetProps } from "widgets/MapWidget";
|
2019-12-30 10:02:23 +00:00
|
|
|
|
2019-11-04 14:22:50 +00:00
|
|
|
import FilePickerWidget, {
|
|
|
|
|
FilePickerWidgetProps,
|
2019-11-25 05:07:27 +00:00
|
|
|
} from "widgets/FilepickerWidget";
|
2019-11-06 12:12:41 +00:00
|
|
|
import DatePickerWidget, {
|
|
|
|
|
DatePickerWidgetProps,
|
2019-11-25 05:07:27 +00:00
|
|
|
} from "widgets/DatePickerWidget";
|
2020-03-06 09:45:21 +00:00
|
|
|
import FormWidget from "widgets/FormWidget";
|
|
|
|
|
import FormButtonWidget, {
|
|
|
|
|
FormButtonWidgetProps,
|
|
|
|
|
} from "widgets/FormButtonWidget";
|
2020-04-14 05:35:16 +00:00
|
|
|
import IconWidget, { IconWidgetProps } from "widgets/IconWidget";
|
2020-03-06 09:45:21 +00:00
|
|
|
|
2020-03-27 09:02:11 +00:00
|
|
|
import CanvasWidget from "widgets/CanvasWidget";
|
2020-04-16 11:56:36 +00:00
|
|
|
export default class WidgetBuilderRegistry {
|
2019-02-10 13:21:19 +00:00
|
|
|
static registerWidgetBuilders() {
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"CONTAINER_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(
|
|
|
|
|
widgetData: ContainerWidgetProps<WidgetProps>,
|
|
|
|
|
): JSX.Element {
|
|
|
|
|
return <ContainerWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
ContainerWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
ContainerWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
ContainerWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-02-10 14:14:58 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"TEXT_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: TextWidgetProps): JSX.Element {
|
|
|
|
|
return <TextWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
TextWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
TextWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
TextWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-03-18 13:50:24 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"BUTTON_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: ButtonWidgetProps): JSX.Element {
|
|
|
|
|
return <ButtonWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
ButtonWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
ButtonWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
ButtonWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-03-18 15:10:30 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"INPUT_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: InputWidgetProps): JSX.Element {
|
|
|
|
|
return <InputWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
InputWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
InputWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
InputWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-03-21 12:10:32 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"CHECKBOX_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: CheckboxWidgetProps): JSX.Element {
|
|
|
|
|
return <CheckboxWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
CheckboxWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
CheckboxWidget.getDerivedPropertiesMap(),
|
2020-04-02 21:15:35 +00:00
|
|
|
CheckboxWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-03-21 12:10:32 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"DROP_DOWN_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: DropdownWidgetProps): JSX.Element {
|
|
|
|
|
return <DropdownWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-10-31 05:28:11 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
DropdownWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
DropdownWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
DropdownWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-10-31 05:28:11 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"RADIO_GROUP_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: RadioGroupWidgetProps): JSX.Element {
|
|
|
|
|
return <RadioGroupWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-09-09 09:08:54 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
RadioGroupWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
RadioGroupWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
RadioGroupWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2019-10-31 08:36:04 +00:00
|
|
|
|
2019-11-19 12:44:58 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"IMAGE_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: ImageWidgetProps): JSX.Element {
|
|
|
|
|
return <ImageWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-10-31 08:36:04 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
ImageWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
ImageWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
ImageWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
|
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"TABLE_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: TableWidgetProps): JSX.Element {
|
|
|
|
|
return <TableWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-10-31 10:10:57 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
TableWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
TableWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
TableWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
|
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"FILE_PICKER_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: FilePickerWidgetProps): JSX.Element {
|
|
|
|
|
return <FilePickerWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-11-04 14:22:50 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
FilePickerWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
FilePickerWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
FilePickerWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
|
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"DATE_PICKER_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: DatePickerWidgetProps): JSX.Element {
|
|
|
|
|
return <DatePickerWidget {...widgetData} />;
|
|
|
|
|
},
|
2019-11-06 12:12:41 +00:00
|
|
|
},
|
2019-11-19 12:44:58 +00:00
|
|
|
DatePickerWidget.getPropertyValidationMap(),
|
2020-01-17 09:28:26 +00:00
|
|
|
DatePickerWidget.getDerivedPropertiesMap(),
|
2020-02-18 10:41:52 +00:00
|
|
|
DatePickerWidget.getTriggerPropertyMap(),
|
2019-11-19 12:44:58 +00:00
|
|
|
);
|
2020-04-15 11:42:11 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"TABS_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(
|
|
|
|
|
widgetProps: TabsWidgetProps<TabContainerWidgetProps>,
|
|
|
|
|
): JSX.Element {
|
|
|
|
|
return <TabsWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
TabsWidget.getPropertyValidationMap(),
|
|
|
|
|
TabsWidget.getDerivedPropertiesMap(),
|
|
|
|
|
TabsWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-03-27 09:02:11 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
WidgetTypes.MODAL_WIDGET,
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetProps: ModalWidgetProps): JSX.Element {
|
|
|
|
|
return <ModalWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
BaseWidget.getPropertyValidationMap(),
|
|
|
|
|
BaseWidget.getDerivedPropertiesMap(),
|
|
|
|
|
BaseWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-03-20 11:17:30 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"RICH_TEXT_EDITOR_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: RichTextEditorWidgetProps): JSX.Element {
|
|
|
|
|
return <RichTextEditorWidget {...widgetData} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
RichTextEditorWidget.getPropertyValidationMap(),
|
|
|
|
|
RichTextEditorWidget.getDerivedPropertiesMap(),
|
|
|
|
|
RichTextEditorWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-03-13 12:06:41 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"CHART_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetData: ChartWidgetProps): JSX.Element {
|
|
|
|
|
return <ChartWidget {...widgetData} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
ChartWidget.getPropertyValidationMap(),
|
|
|
|
|
ChartWidget.getDerivedPropertiesMap(),
|
|
|
|
|
ChartWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-03-06 09:45:21 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"FORM_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(
|
|
|
|
|
widgetProps: ContainerWidgetProps<WidgetProps>,
|
|
|
|
|
): JSX.Element {
|
|
|
|
|
return <FormWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
FormWidget.getPropertyValidationMap(),
|
|
|
|
|
FormWidget.getDerivedPropertiesMap(),
|
|
|
|
|
FormWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"FORM_BUTTON_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetProps: FormButtonWidgetProps): JSX.Element {
|
|
|
|
|
return <FormButtonWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
FormButtonWidget.getPropertyValidationMap(),
|
|
|
|
|
FormButtonWidget.getDerivedPropertiesMap(),
|
|
|
|
|
FormButtonWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-03-27 09:02:11 +00:00
|
|
|
|
2020-04-15 11:42:11 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
"MAP_WIDGET",
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetProps: MapWidgetProps): JSX.Element {
|
|
|
|
|
return <MapWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
MapWidget.getPropertyValidationMap(),
|
|
|
|
|
MapWidget.getDerivedPropertiesMap(),
|
|
|
|
|
MapWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
|
|
|
|
|
2020-03-27 09:02:11 +00:00
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
WidgetTypes.CANVAS_WIDGET,
|
|
|
|
|
{
|
|
|
|
|
buildWidget(
|
|
|
|
|
widgetData: ContainerWidgetProps<WidgetProps>,
|
|
|
|
|
): JSX.Element {
|
|
|
|
|
return <CanvasWidget {...widgetData} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
CanvasWidget.getPropertyValidationMap(),
|
|
|
|
|
CanvasWidget.getDerivedPropertiesMap(),
|
|
|
|
|
CanvasWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2020-04-14 05:35:16 +00:00
|
|
|
|
|
|
|
|
WidgetFactory.registerWidgetBuilder(
|
|
|
|
|
WidgetTypes.ICON_WIDGET,
|
|
|
|
|
{
|
|
|
|
|
buildWidget(widgetProps: IconWidgetProps): JSX.Element {
|
|
|
|
|
return <IconWidget {...widgetProps} />;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
IconWidget.getPropertyValidationMap(),
|
|
|
|
|
IconWidget.getDerivedPropertiesMap(),
|
|
|
|
|
IconWidget.getTriggerPropertyMap(),
|
|
|
|
|
);
|
2019-02-10 13:06:05 +00:00
|
|
|
}
|
2019-02-10 13:21:19 +00:00
|
|
|
}
|