mirror of
https://github.com/jeffvli/feishin.git
synced 2026-05-09 20:29:36 +02:00
debounce playqueue search
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
import { useDebouncedValue } from '@mantine/hooks';
|
||||||
import { nanoid } from 'nanoid/non-secure';
|
import { nanoid } from 'nanoid/non-secure';
|
||||||
import { forwardRef, useEffect, useMemo, useRef } from 'react';
|
import { forwardRef, useEffect, useMemo, useRef } from 'react';
|
||||||
|
|
||||||
@@ -29,13 +30,15 @@ export const PlayQueue = forwardRef<ItemListHandle, QueueProps>(({ listKey, sear
|
|||||||
const queue = usePlayerQueue();
|
const queue = usePlayerQueue();
|
||||||
const isFetching = useIsPlayerFetching();
|
const isFetching = useIsPlayerFetching();
|
||||||
|
|
||||||
|
const [debouncedSearchTerm] = useDebouncedValue(searchTerm, 200);
|
||||||
|
|
||||||
const data: QueueSong[] = useMemo(() => {
|
const data: QueueSong[] = useMemo(() => {
|
||||||
if (searchTerm) {
|
if (debouncedSearchTerm) {
|
||||||
return searchSongs(queue, searchTerm);
|
return searchSongs(queue, debouncedSearchTerm);
|
||||||
}
|
}
|
||||||
|
|
||||||
return queue;
|
return queue;
|
||||||
}, [queue, searchTerm]);
|
}, [queue, debouncedSearchTerm]);
|
||||||
|
|
||||||
const playQueueKeyRef = useRef({
|
const playQueueKeyRef = useRef({
|
||||||
alreadyRendered: false,
|
alreadyRendered: false,
|
||||||
|
|||||||
Reference in New Issue
Block a user