1
0
Fork 0
mirror of https://github.com/muerwre/vault-frontend.git synced 2025-04-25 04:46:40 +07:00
vault-frontend/src/components/editors/AudioGrid/index.tsx
Fedor Katurov a26e4168fd fix eslint
2023-10-30 21:49:10 +06:00

52 lines
1.2 KiB
TypeScript

import React, { FC, useCallback } from 'react';
import { SortableAudioGrid } from '~/components/sortable/SortableAudioGrid';
import { UploadStatus } from '~/store/uploader/UploaderStore';
import { IFile } from '~/types';
interface IProps {
files: IFile[];
setFiles: (val: IFile[]) => void;
locked: UploadStatus[];
}
const AudioGrid: FC<IProps> = ({ files, setFiles, locked }) => {
const onMove = useCallback(
(newFiles: IFile[]) => {
setFiles(newFiles);
},
[setFiles],
);
const onDrop = useCallback(
(remove_id: IFile['id']) => {
setFiles(files.filter((file) => file && file.id !== remove_id));
},
[setFiles, files],
);
const onTitleChange = useCallback(
(changeId: IFile['id'], title: string) => {
setFiles(
files.map((file) =>
file && file.id === changeId
? { ...file, metadata: { ...file.metadata, title } }
: file,
),
);
},
[setFiles, files],
);
return (
<SortableAudioGrid
onDelete={onDrop}
onTitleChange={onTitleChange}
onSortEnd={onMove}
items={files}
locked={locked}
/>
);
};
export { AudioGrid };