mirror of
https://github.com/handsomezhuzhu/AeroStart.git
synced 2026-02-20 12:00:15 +00:00
⚡ perf(search): add 100ms debounce to search suggestions
- Add setTimeout with 100ms delay to reduce API calls - Add cleanup function to clear timer on unmount 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -78,27 +78,31 @@ const SearchBox: React.FC<SearchBoxProps> = ({
|
|||||||
return () => document.removeEventListener('mousedown', handleClickOutside);
|
return () => document.removeEventListener('mousedown', handleClickOutside);
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
// Fetch suggestions immediately without debounce
|
// Fetch suggestions with 100ms debounce
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (query.trim()) {
|
const timer = setTimeout(() => {
|
||||||
fetchSuggestions(selectedEngine.name, query).then(results => {
|
if (query.trim()) {
|
||||||
// Only update if results are different to avoid unnecessary re-renders
|
fetchSuggestions(selectedEngine.name, query).then(results => {
|
||||||
setSuggestions(prev => {
|
// Only update if results are different to avoid unnecessary re-renders
|
||||||
const newSuggestions = results.slice(0, 8);
|
setSuggestions(prev => {
|
||||||
// Trigger animation only when content actually changes
|
const newSuggestions = results.slice(0, 8);
|
||||||
if (JSON.stringify(prev) !== JSON.stringify(newSuggestions)) {
|
// Trigger animation only when content actually changes
|
||||||
setAnimationKey(k => k + 1);
|
if (JSON.stringify(prev) !== JSON.stringify(newSuggestions)) {
|
||||||
}
|
setAnimationKey(k => k + 1);
|
||||||
return newSuggestions;
|
}
|
||||||
|
return newSuggestions;
|
||||||
|
});
|
||||||
|
setShowSuggestions(true);
|
||||||
|
setSelectedIndex(-1);
|
||||||
});
|
});
|
||||||
setShowSuggestions(true);
|
} else {
|
||||||
|
setSuggestions([]);
|
||||||
|
setShowSuggestions(false);
|
||||||
setSelectedIndex(-1);
|
setSelectedIndex(-1);
|
||||||
});
|
}
|
||||||
} else {
|
}, 100);
|
||||||
setSuggestions([]);
|
|
||||||
setShowSuggestions(false);
|
return () => clearTimeout(timer);
|
||||||
setSelectedIndex(-1);
|
|
||||||
}
|
|
||||||
}, [query, selectedEngine.name]);
|
}, [query, selectedEngine.name]);
|
||||||
|
|
||||||
const performSearch = useCallback((text: string) => {
|
const performSearch = useCallback((text: string) => {
|
||||||
|
|||||||
Reference in New Issue
Block a user