mirror of
https://github.com/spacedriveapp/spacedrive.git
synced 2026-02-20 07:37:26 -05: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
29 lines
798 B
TypeScript
29 lines
798 B
TypeScript
import { useEffect, useRef } from 'react';
|
|
|
|
/**
|
|
* DO NOT DELETE THIS HOOK
|
|
* It probably isn't used in the codebase, but it's a useful debugging tool.
|
|
*/
|
|
export function useTraceUpdate(name: string, props: object | null) {
|
|
const prev = useRef<{ [key: string]: any } | null>(props);
|
|
useEffect(() => {
|
|
const { current } = prev;
|
|
if (props == null) {
|
|
console.log(`Change ${name} to null`);
|
|
} else if (current == null) {
|
|
console.log(`Change ${name} from null to`, props);
|
|
} else {
|
|
const changedProps = Object.entries(props).reduce((ps: any, [k, v]) => {
|
|
if (current[k] !== v) {
|
|
ps[k] = [current[k], v];
|
|
}
|
|
return ps;
|
|
}, {});
|
|
if (Object.keys(changedProps).length > 0) {
|
|
console.log(`Changed ${name}:`, changedProps);
|
|
}
|
|
}
|
|
prev.current = props;
|
|
});
|
|
}
|