С помощью компонента класса я обычно создаю экземпляр этого компонента и могу получить доступ к функции. Я не уверен, как получить доступ к функции функционального компонента.
const errorMessages = {
browse: {
fileLimit: 'File size is too big.',
unsupportedFormat: 'The file you selected is not a supported format. Please upload a file in .csv format.',
noRows: 'No agent IDS could be found.',
maxAgents: 'A max of 25 agents can be uploaded at a time.',
noValidAgents: 'No valid agents could be found.'
},
duplicate: 'The following agents are already existing on the table.'
};
const UploadButton = (props, ref) => {
const mimeTypes = ['text/csv', 'application/vnd.ms-excel'];
let initialValue = false;
const [browseError, setBrowseError] = useState(initialValue);
const [uploadError, setUploadError] = useState(initialValue);
const [duplicateError, setDupplicateError] = useState(initialValue);
const [uploading, setUploading] = useState(false);
const fileInputRefs = useRef(initialValue);
const clearAllErrors = () => {
setBrowseError(initialValue);
setUploadError(initialValue);
setDupplicateError(initialValue);
}
....
}
Так, например, доступ к clearAllErrors или errorMessages, которые находятся за пределами функционального компонента.