import { getTemplate, getUiOptions, ArrayFieldTemplateProps, FormContextType, RJSFSchema, StrictRJSFSchema, buttonId, } from '@rjsf/utils'; /** The `ArrayFieldTemplate` component is the template used to render all items in an array. * * @param props - The `ArrayFieldTemplateProps` props for the component */ export default function ArrayFieldTemplate< T = any, S extends StrictRJSFSchema = RJSFSchema, F extends FormContextType = any, >(props: ArrayFieldTemplateProps) { const { canAdd, className, disabled, fieldPathId, uiSchema, items, optionalDataControl, onAddClick, readonly, registry, required, schema, title, } = props; const uiOptions = getUiOptions(uiSchema); const ArrayFieldDescriptionTemplate = getTemplate<'ArrayFieldDescriptionTemplate', T, S, F>( 'ArrayFieldDescriptionTemplate', registry, uiOptions, ); const ArrayFieldTitleTemplate = getTemplate<'ArrayFieldTitleTemplate', T, S, F>( 'ArrayFieldTitleTemplate', registry, uiOptions, ); // Button templates are not overridden in the uiSchema const showOptionalDataControlInTitle = !readonly && !disabled; const { ButtonTemplates: { AddButton }, } = registry.templates; return (
{!showOptionalDataControlInTitle ? optionalDataControl : undefined}
{items}
{canAdd && ( )}
); }