mirror of
https://github.com/spacedriveapp/spacedrive.git
synced 2026-05-02 20:34:16 -04:00
* Update rspc, prisma-client-rust, axum and tanstack-query - Deleted some unused examples and fully commented out frontend code - Implement many changes required due to the updates - Update most rust dependencies * Re-enable p2p * Fix server * Auto format * Fix injected script format - Update some github actions - Update pnpm lock file * Fix devtools showing up when app opens - Fix million complaining about Sparkles component * Fix sd-server * Fix and improve thumbnails rendering - Fix core always saying a new thumbnail was generated even for files that it skiped thumbnail generation - Rewrite FileThumb and improve related components * Ignore tmp files when running prettier * Improve FileThumb component performance - Rework useExplorerDraggable and useExplorerItemData hooks due to reduce unecessary re-renders * More fixes for thumb component - A couple of minor performance improvements to frontend code * auto format * Fix Thumbnail and QuickPreview * Fix logic for when to show 'fail to load original' error message in QuickPreview - Updated prisma-client-rust, libp2p, tauri, tauri-specta, rspc and hyper * Fix type checking - Format scripts * Add script prettier config * Fix serde missing feature - Use rust-libp2p spacedrive fork again - Update rspc * Autoformat + fix pnpm lock * Fix thumbnail first load again * Autoformat * autoformat * Fix rust-libp2p fork url again? * Remove usePathsInfiniteQuery hook * Update tauri 2.0.6
57 lines
1.3 KiB
TypeScript
57 lines
1.3 KiB
TypeScript
import { useQueryClient } from '@tanstack/react-query';
|
|
import { useNavigate } from 'react-router';
|
|
import { useBridgeMutation, usePlausibleEvent, useZodForm } from '@sd/client';
|
|
import { Dialog, useDialog, UseDialogProps } from '@sd/ui';
|
|
import { useLocale } from '~/hooks';
|
|
import { usePlatform } from '~/util/Platform';
|
|
|
|
interface Props extends UseDialogProps {
|
|
libraryUuid: string;
|
|
}
|
|
|
|
export default function DeleteLibraryDialog(props: Props) {
|
|
const { t } = useLocale();
|
|
|
|
const submitPlausibleEvent = usePlausibleEvent();
|
|
const queryClient = useQueryClient();
|
|
const platform = usePlatform();
|
|
const navigate = useNavigate();
|
|
|
|
const deleteLib = useBridgeMutation('library.delete');
|
|
|
|
const form = useZodForm();
|
|
|
|
const onSubmit = form.handleSubmit(async () => {
|
|
try {
|
|
await deleteLib.mutateAsync(props.libraryUuid);
|
|
|
|
queryClient.invalidateQueries({ queryKey: ['library.list'] });
|
|
|
|
if (platform.refreshMenuBar) platform.refreshMenuBar();
|
|
|
|
submitPlausibleEvent({
|
|
event: {
|
|
type: 'libraryDelete'
|
|
}
|
|
});
|
|
|
|
navigate('/');
|
|
} catch (e) {
|
|
alert(`Failed to delete library: ${e}`);
|
|
}
|
|
});
|
|
|
|
return (
|
|
<Dialog
|
|
form={form}
|
|
onSubmit={onSubmit}
|
|
dialog={useDialog(props)}
|
|
title={t('delete_library')}
|
|
closeLabel={t('close')}
|
|
description={t('delete_library_description')}
|
|
ctaDanger
|
|
ctaLabel={t('delete')}
|
|
/>
|
|
);
|
|
}
|