Add useListStream hook

This commit is contained in:
Alex Gleason 2023-07-22 14:03:00 -05:00
parent 4090d6ab51
commit 811a9af670
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
4 changed files with 14 additions and 11 deletions

View file

@ -193,9 +193,6 @@ const connectTimelineStream = (
const connectHashtagStream = (id: string, tag: string, accept: (status: APIEntity) => boolean) => const connectHashtagStream = (id: string, tag: string, accept: (status: APIEntity) => boolean) =>
connectTimelineStream(`hashtag:${id}`, `hashtag&tag=${tag}`, null, accept); connectTimelineStream(`hashtag:${id}`, `hashtag&tag=${tag}`, null, accept);
const connectListStream = (id: string) =>
connectTimelineStream(`list:${id}`, `list&list=${id}`);
const connectGroupStream = (id: string) => const connectGroupStream = (id: string) =>
connectTimelineStream(`group:${id}`, `group&group=${id}`); connectTimelineStream(`group:${id}`, `group&group=${id}`);
@ -204,7 +201,6 @@ export {
STREAMING_FOLLOW_RELATIONSHIPS_UPDATE, STREAMING_FOLLOW_RELATIONSHIPS_UPDATE,
connectTimelineStream, connectTimelineStream,
connectHashtagStream, connectHashtagStream,
connectListStream,
connectGroupStream, connectGroupStream,
type TimelineStreamOpts, type TimelineStreamOpts,
}; };

View file

@ -49,5 +49,6 @@ export { useUserStream } from './streaming/useUserStream';
export { useCommunityStream } from './streaming/useCommunityStream'; export { useCommunityStream } from './streaming/useCommunityStream';
export { usePublicStream } from './streaming/usePublicStream'; export { usePublicStream } from './streaming/usePublicStream';
export { useDirectStream } from './streaming/useDirectStream'; export { useDirectStream } from './streaming/useDirectStream';
export { useListStream } from './streaming/useListStream';
export { useRemoteStream } from './streaming/useRemoteStream'; export { useRemoteStream } from './streaming/useRemoteStream';
export { useNostrStream } from './streaming/useNostrStream'; export { useNostrStream } from './streaming/useNostrStream';

View file

@ -0,0 +1,10 @@
import { useTimelineStream } from './useTimelineStream';
function useListStream(listId: string) {
return useTimelineStream(
`list:${listId}`,
`list&list=${listId}`,
);
}
export { useListStream };

View file

@ -4,8 +4,8 @@ import { useParams } from 'react-router-dom';
import { fetchList } from 'soapbox/actions/lists'; import { fetchList } from 'soapbox/actions/lists';
import { openModal } from 'soapbox/actions/modals'; import { openModal } from 'soapbox/actions/modals';
import { connectListStream } from 'soapbox/actions/streaming';
import { expandListTimeline } from 'soapbox/actions/timelines'; import { expandListTimeline } from 'soapbox/actions/timelines';
import { useListStream } from 'soapbox/api/hooks';
import MissingIndicator from 'soapbox/components/missing-indicator'; import MissingIndicator from 'soapbox/components/missing-indicator';
import { Column, Button, Spinner } from 'soapbox/components/ui'; import { Column, Button, Spinner } from 'soapbox/components/ui';
import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks';
@ -19,15 +19,11 @@ const ListTimeline: React.FC = () => {
const list = useAppSelector((state) => state.lists.get(id)); const list = useAppSelector((state) => state.lists.get(id));
const next = useAppSelector(state => state.timelines.get(`list:${id}`)?.next); const next = useAppSelector(state => state.timelines.get(`list:${id}`)?.next);
useListStream(id);
useEffect(() => { useEffect(() => {
dispatch(fetchList(id)); dispatch(fetchList(id));
dispatch(expandListTimeline(id)); dispatch(expandListTimeline(id));
const disconnect = dispatch(connectListStream(id));
return () => {
disconnect();
};
}, [id]); }, [id]);
const handleLoadMore = (maxId: string) => { const handleLoadMore = (maxId: string) => {