UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

50 lines 1.51 kB
import { useCallback, useMemo } from 'react'; import { useSharedState } from "../../shared/helpers/useSharedState.js"; function useUpload(id) { const { data, extend } = useSharedState(id); const clearFiles = useCallback(() => { extend({ files: [], internalFiles: [] }); }, [extend]); const setFiles = useCallback(files => { const newFiles = files?.filter(file => file?.file instanceof File); extend({ files: newFiles }); }, [extend]); const setInternalFiles = useCallback(internalFiles => { extend({ internalFiles }); }, [extend]); const files = useMemo(() => data?.files || [], [data?.files]); const internalFiles = useMemo(() => data?.internalFiles || [], [data?.internalFiles]); const getExistingFile = useCallback((file, fileItems = files) => { return fileItems.find(({ file: f }) => { return isFileEqual(file, f); }); }, [files]); return { files, setFiles, clearFiles, internalFiles, setInternalFiles, getExistingFile }; } export const isFileEqual = (fileA, fileB) => { const compareExistingProperty = function (a, b, property) { return a && property in a && b && property in b && (a[property] === 0 || b[property] === 0 || a[property] === b[property]); }; return fileA.name === fileB.name && compareExistingProperty(fileA, fileB, 'size') && compareExistingProperty(fileA, fileB, 'lastModified'); }; export default useUpload; //# sourceMappingURL=useUpload.js.map