spacedrive/interface/hooks/useKeyDeleteFile.tsx
nikec a87d53e309
[ENG-1641] Use 'delItem' shortcut (#2138)
replace del items shortcut hooks
2024-02-28 15:36:07 +00:00

46 lines
1.3 KiB
TypeScript

import { useItemsAsEphemeralPaths, useItemsAsFilePaths, type ExplorerItem } from '@sd/client';
import { dialogManager } from '@sd/ui';
import DeleteDialog from '~/app/$libraryId/Explorer/FilePath/DeleteDialog';
import { isNonEmpty } from '~/util';
import { useShortcut } from './useShortcut';
export const useKeyDeleteFile = (selectedItems: Set<ExplorerItem>, locationId?: number | null) => {
const filePaths = useItemsAsFilePaths([...selectedItems]);
const ephemeralPaths = useItemsAsEphemeralPaths([...selectedItems]);
const deleteHandler = (e: KeyboardEvent) => {
e.preventDefault();
if ((locationId == null || !isNonEmpty(filePaths)) && !isNonEmpty(ephemeralPaths)) return;
const indexedArgs =
locationId != null && isNonEmpty(filePaths)
? { locationId, pathIds: filePaths.map((p) => p.id) }
: undefined;
const ephemeralArgs = isNonEmpty(ephemeralPaths)
? { paths: ephemeralPaths.map((p) => p.path) }
: undefined;
let dirCount = 0;
let fileCount = 0;
for (const entry of [...filePaths, ...ephemeralPaths]) {
dirCount += entry.is_dir ? 1 : 0;
fileCount += entry.is_dir ? 0 : 1;
}
dialogManager.create((dp) => (
<DeleteDialog
{...dp}
indexedArgs={indexedArgs}
ephemeralArgs={ephemeralArgs}
dirCount={dirCount}
fileCount={fileCount}
/>
));
};
useShortcut('delItem', deleteHandler);
};