make sure that all new form field elements are not dropdowns

This commit is contained in:
burnettk 2023-01-22 00:36:16 -05:00
parent 336923b1e5
commit d282f66a5c
2 changed files with 59 additions and 12 deletions

View File

@ -225,11 +225,11 @@ export interface PermissionCheckResponseBody {
export interface FormField { export interface FormField {
id: string; id: string;
title: string; title: string;
required: boolean; required?: boolean;
type: string; type: string;
enum: string[]; enum?: string[];
default: any; default?: any;
pattern: string; pattern?: string;
} }
export interface JsonSchemaForm { export interface JsonSchemaForm {

View File

@ -1,8 +1,18 @@
import { useEffect, useState } from 'react'; import { useEffect, useState } from 'react';
// @ts-ignore // @ts-ignore
import { Button, Select, SelectItem, TextInput } from '@carbon/react';
import { useNavigate, useParams, useSearchParams } from 'react-router-dom'; import { useNavigate, useParams, useSearchParams } from 'react-router-dom';
import {
Button,
Select,
SelectItem,
TextInput,
Grid,
Column,
// @ts-ignore
} from '@carbon/react';
import validator from '@rjsf/validator-ajv8';
import { FormField, JsonSchemaForm } from '../interfaces'; import { FormField, JsonSchemaForm } from '../interfaces';
import Form from '../themes/carbon';
import { import {
modifyProcessIdentifierForPathParam, modifyProcessIdentifierForPathParam,
slugifyString, slugifyString,
@ -147,15 +157,23 @@ export default function JsonSchemaFormBuilder() {
setFormTitle(newFormTitle); setFormTitle(newFormTitle);
}; };
const getFormFieldType = (indicatedType: string) => {
if (indicatedType === 'checkbox') {
return 'boolean';
}
// undefined or 'select' or 'textbox'
return 'string';
};
const addFormField = () => { const addFormField = () => {
const newFormField: FormField = { const newFormField: FormField = {
id: formFieldId, id: formFieldId,
title: formFieldTitle, title: formFieldTitle,
required: false, required: false,
type: formFieldType, type: getFormFieldType(formFieldType),
enum: formFieldSelectOptions.split(','), enum: showFormFieldSelectTextField
pattern: '', ? formFieldSelectOptions.split(',')
default: null, : undefined,
}; };
setFormFieldIdHasBeenUpdatedByUser(false); setFormFieldIdHasBeenUpdatedByUser(false);
@ -333,9 +351,9 @@ export default function JsonSchemaFormBuilder() {
</> </>
); );
}; };
const processModelFileName = searchParams.get('file_name') || '';
const jsonFormArea = () => { const topOfPageElements = () => {
const processModelFileName = searchParams.get('file_name') || '';
return ( return (
<> <>
<ProcessBreadcrumb <ProcessBreadcrumb
@ -353,6 +371,13 @@ export default function JsonSchemaFormBuilder() {
Process Model File{processModelFileName ? ': ' : ''} Process Model File{processModelFileName ? ': ' : ''}
{processModelFileName} {processModelFileName}
</h1> </h1>
</>
);
};
const jsonFormArea = () => {
return (
<>
{formSubmitResultElement()} {formSubmitResultElement()}
<Button onClick={saveFile}>Save</Button> <Button onClick={saveFile}>Save</Button>
{jsonFormButton()} {jsonFormButton()}
@ -392,6 +417,28 @@ export default function JsonSchemaFormBuilder() {
</> </>
); );
}; };
const schemaString = renderFormJson();
const uiSchemaString = renderFormUiJson();
const schema = JSON.parse(schemaString);
const uiSchema = JSON.parse(uiSchemaString);
return <>{jsonFormArea()}</>; return (
<>
{topOfPageElements()}
<Grid fullWidth>
<Column md={5} lg={8} sm={4}>
{jsonFormArea()}
</Column>
<Column md={5} lg={8} sm={4}>
<h2>Form Preview</h2>
<Form
formData={{}}
schema={schema}
uiSchema={uiSchema}
validator={validator}
/>
</Column>
</Grid>
</>
);
} }