import { MetadataInstanceForm, type FormValues, type JSONPatchOperations, type MetadataTemplateInstance, } from '@box/metadata-editor'; import { TaxonomyOptionsFetcher } from '@box/metadata-editor/lib/components/metadata-editor-fields/components/metadata-taxonomy-field/types.js'; import React from 'react'; import { ERROR_CODE_METADATA_AUTOFILL_TIMEOUT, ERROR_CODE_UNKNOWN, ERROR_CODE_METADATA_PRECONDITION_FAILED, } from '../../constants'; export interface MetadataInstanceEditorProps { areAiSuggestionsAvailable: boolean; errorCode?: ERROR_CODE_METADATA_AUTOFILL_TIMEOUT | ERROR_CODE_METADATA_PRECONDITION_FAILED | ERROR_CODE_UNKNOWN; isBetaLanguageEnabled: boolean; isBoxAiSuggestionsEnabled: boolean; isDeleteButtonDisabled: boolean; isDeleteConfirmationModalCheckboxEnabled: boolean; isLargeFile: boolean; isMetadataMultiLevelTaxonomyFieldEnabled: boolean; isUnsavedChangesModalOpen: boolean; onCancel: () => void; onDelete: (metadataInstance: MetadataTemplateInstance) => void; onDiscardUnsavedChanges: () => void; onSubmit: (values: FormValues, operations: JSONPatchOperations) => Promise; setIsUnsavedChangesModalOpen: (isUnsavedChangesModalOpen: boolean) => void; taxonomyOptionsFetcher: TaxonomyOptionsFetcher; template: MetadataTemplateInstance; } const MetadataInstanceEditor: React.FC = ({ areAiSuggestionsAvailable, errorCode, isBetaLanguageEnabled, isBoxAiSuggestionsEnabled, isDeleteButtonDisabled, isDeleteConfirmationModalCheckboxEnabled, isLargeFile, isMetadataMultiLevelTaxonomyFieldEnabled, isUnsavedChangesModalOpen, onCancel, onDelete, onDiscardUnsavedChanges, onSubmit, setIsUnsavedChangesModalOpen, taxonomyOptionsFetcher, template, }) => { return ( ); }; export default MetadataInstanceEditor;