ChatMessageList: fix pagination

This commit is contained in:
Alex Gleason 2022-06-17 17:33:25 -05:00
parent bf01c42397
commit a632bb99f9
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
3 changed files with 15 additions and 5 deletions

View file

@ -18,7 +18,7 @@ import DropdownMenuContainer from 'soapbox/containers/dropdown_menu_container';
import emojify from 'soapbox/features/emoji/emoji'; import emojify from 'soapbox/features/emoji/emoji';
import Bundle from 'soapbox/features/ui/components/bundle'; import Bundle from 'soapbox/features/ui/components/bundle';
import { MediaGallery } from 'soapbox/features/ui/util/async-components'; import { MediaGallery } from 'soapbox/features/ui/util/async-components';
import { useAppSelector, useAppDispatch } from 'soapbox/hooks'; import { useAppSelector, useAppDispatch, useRefEventHandler } from 'soapbox/hooks';
import { onlyEmoji } from 'soapbox/utils/rich_content'; import { onlyEmoji } from 'soapbox/utils/rich_content';
import type { Menu } from 'soapbox/components/dropdown_menu'; import type { Menu } from 'soapbox/components/dropdown_menu';
@ -134,12 +134,12 @@ const ChatMessageList: React.FC<IChatMessageList> = ({ chatId, chatMessageIds })
useEffect(() => { useEffect(() => {
dispatch(fetchChatMessages(chatId)); dispatch(fetchChatMessages(chatId));
node.current?.addEventListener('scroll', handleScroll); node.current?.addEventListener('scroll', e => handleScroll.current(e));
window.addEventListener('resize', handleResize); window.addEventListener('resize', handleResize);
scrollToBottom(); scrollToBottom();
return () => { return () => {
node.current?.removeEventListener('scroll', handleScroll); node.current?.removeEventListener('scroll', e => handleScroll.current(e));
window.removeEventListener('resize', handleResize); window.removeEventListener('resize', handleResize);
}; };
}, []); }, []);
@ -190,7 +190,7 @@ const ChatMessageList: React.FC<IChatMessageList> = ({ chatId, chatMessageIds })
setIsLoading(true); setIsLoading(true);
}; };
const handleScroll = throttle(() => { const handleScroll = useRefEventHandler(throttle(() => {
if (node.current) { if (node.current) {
const { scrollTop, offsetHeight } = node.current; const { scrollTop, offsetHeight } = node.current;
const computedScroll = lastComputedScroll.current === scrollTop; const computedScroll = lastComputedScroll.current === scrollTop;
@ -202,7 +202,7 @@ const ChatMessageList: React.FC<IChatMessageList> = ({ chatId, chatMessageIds })
} }
}, 150, { }, 150, {
trailing: true, trailing: true,
}); }));
const onOpenMedia = (media: any, index: number) => { const onOpenMedia = (media: any, index: number) => {
dispatch(openModal('MEDIA', { media, index })); dispatch(openModal('MEDIA', { media, index }));

View file

@ -4,6 +4,7 @@ export { useAppSelector } from './useAppSelector';
export { useFeatures } from './useFeatures'; export { useFeatures } from './useFeatures';
export { useOnScreen } from './useOnScreen'; export { useOnScreen } from './useOnScreen';
export { useOwnAccount } from './useOwnAccount'; export { useOwnAccount } from './useOwnAccount';
export { useRefEventHandler } from './useRefEventHandler';
export { useSettings } from './useSettings'; export { useSettings } from './useSettings';
export { useSoapboxConfig } from './useSoapboxConfig'; export { useSoapboxConfig } from './useSoapboxConfig';
export { useSystemTheme } from './useSystemTheme'; export { useSystemTheme } from './useSystemTheme';

View file

@ -0,0 +1,9 @@
import { useRef } from 'react';
/** Hook that allows using useState values in event handlers. */
// https://stackoverflow.com/a/64770671/8811886
export const useRefEventHandler = (fn: (...params: any) => void) => {
const ref = useRef(fn);
ref.current = fn;
return ref;
};