mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-13 02:54:27 +00:00
make sure that all new form field elements are not dropdowns
This commit is contained in:
parent
336923b1e5
commit
d282f66a5c
@ -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 {
|
||||||
|
@ -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>
|
||||||
|
</>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user