import Box from '@mui/material/Box'; import Grid2 from '@mui/material/Grid2'; import Paper from '@mui/material/Paper'; import { getTemplate, getUiOptions, ArrayFieldTemplateProps, ArrayFieldTemplateItemType, FormContextType, } from '@rjsf/utils'; import { CrudTextRJSFSchema } from "../widgets/crud-text-widget"; /** The `ArrayFieldTemplate` component is the template used to render all items in an array. * * @param props - The `ArrayFieldTemplateItemType` props for the component */ export default function ArrayFieldTemplate< T = any, S extends CrudTextRJSFSchema = CrudTextRJSFSchema, F extends FormContextType = any >(props: ArrayFieldTemplateProps) { const { canAdd, disabled, idSchema, uiSchema, items, onAddClick, readonly, registry, required, schema, title } = props; let gridSize = 12; if (schema.props) { if (schema.props.hasOwnProperty("items_per_row")) { gridSize = gridSize / schema.props.items_per_row; } } const uiOptions = getUiOptions(uiSchema); const ArrayFieldDescriptionTemplate = getTemplate<'ArrayFieldDescriptionTemplate', T, S, F>( 'ArrayFieldDescriptionTemplate', registry, uiOptions ); const ArrayFieldItemTemplate = getTemplate<'ArrayFieldItemTemplate', T, S, F>( 'ArrayFieldItemTemplate', registry, uiOptions ); const ArrayFieldTitleTemplate = getTemplate<'ArrayFieldTitleTemplate', T, S, F>( 'ArrayFieldTitleTemplate', registry, uiOptions ); // Button templates are not overridden in the uiSchema const { ButtonTemplates: { AddButton }, } = registry.templates; return ( {items && items.map(({ key, ...itemProps }: ArrayFieldTemplateItemType) => ( ))} {canAdd && ( )} ); }