mirror of
https://github.com/mastodon/mastodon.git
synced 2024-12-14 23:24:55 +01:00
56 lines
1.9 KiB
JavaScript
56 lines
1.9 KiB
JavaScript
import { connectStream } from 'flavours/glitch/util/stream';
|
|
import {
|
|
updateTimeline,
|
|
deleteFromTimelines,
|
|
refreshHomeTimeline,
|
|
connectTimeline,
|
|
disconnectTimeline,
|
|
} from './timelines';
|
|
import { updateNotifications, refreshNotifications } from './notifications';
|
|
import { getLocale } from 'mastodon/locales';
|
|
|
|
const { messages } = getLocale();
|
|
|
|
export function connectTimelineStream (timelineId, path, pollingRefresh = null) {
|
|
|
|
return connectStream (path, pollingRefresh, (dispatch, getState) => {
|
|
const locale = getState().getIn(['meta', 'locale']);
|
|
return {
|
|
onConnect() {
|
|
dispatch(connectTimeline(timelineId));
|
|
},
|
|
|
|
onDisconnect() {
|
|
dispatch(disconnectTimeline(timelineId));
|
|
},
|
|
|
|
onReceive (data) {
|
|
switch(data.event) {
|
|
case 'update':
|
|
dispatch(updateTimeline(timelineId, JSON.parse(data.payload)));
|
|
break;
|
|
case 'delete':
|
|
dispatch(deleteFromTimelines(data.payload));
|
|
break;
|
|
case 'notification':
|
|
dispatch(updateNotifications(JSON.parse(data.payload), messages, locale));
|
|
break;
|
|
}
|
|
},
|
|
};
|
|
});
|
|
}
|
|
|
|
function refreshHomeTimelineAndNotification (dispatch) {
|
|
dispatch(refreshHomeTimeline());
|
|
dispatch(refreshNotifications());
|
|
}
|
|
|
|
export const connectUserStream = () => connectTimelineStream('home', 'user', refreshHomeTimelineAndNotification);
|
|
export const connectCommunityStream = () => connectTimelineStream('community', 'public:local');
|
|
export const connectMediaStream = () => connectTimelineStream('community', 'public:local');
|
|
export const connectPublicStream = () => connectTimelineStream('public', 'public');
|
|
export const connectHashtagStream = (tag) => connectTimelineStream(`hashtag:${tag}`, `hashtag&tag=${tag}`);
|
|
export const connectDirectStream = () => connectTimelineStream('direct', 'direct');
|
|
export const connectListStream = (id) => connectTimelineStream(`list:${id}`, `list&list=${id}`);
|