Add useListStream hook
This commit is contained in:
parent
4090d6ab51
commit
811a9af670
4 changed files with 14 additions and 11 deletions
|
@ -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,
|
||||||
};
|
};
|
||||||
|
|
|
@ -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';
|
10
app/soapbox/api/hooks/streaming/useListStream.ts
Normal file
10
app/soapbox/api/hooks/streaming/useListStream.ts
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
import { useTimelineStream } from './useTimelineStream';
|
||||||
|
|
||||||
|
function useListStream(listId: string) {
|
||||||
|
return useTimelineStream(
|
||||||
|
`list:${listId}`,
|
||||||
|
`list&list=${listId}`,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export { useListStream };
|
|
@ -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) => {
|
||||||
|
|
Loading…
Reference in a new issue