2017-11-16 00:04:15 +09:00
|
|
|
import { connectStream } from '../stream';
|
2017-08-21 22:04:34 +09:00
|
|
|
import {
|
|
|
|
updateTimeline,
|
|
|
|
deleteFromTimelines,
|
2018-03-24 23:25:15 +09:00
|
|
|
expandHomeTimeline,
|
2019-03-07 22:17:52 +01:00
|
|
|
connectTimeline,
|
2017-08-21 22:04:34 +09:00
|
|
|
disconnectTimeline,
|
|
|
|
} from './timelines';
|
2018-03-25 06:07:23 +09:00
|
|
|
import { updateNotifications, expandNotifications } from './notifications';
|
2018-10-07 23:44:58 +02:00
|
|
|
import { updateConversations } from './conversations';
|
2018-06-29 15:34:36 +02:00
|
|
|
import { fetchFilters } from './filters';
|
2017-08-21 22:04:34 +09:00
|
|
|
import { getLocale } from '../locales';
|
|
|
|
|
|
|
|
const { messages } = getLocale();
|
|
|
|
|
2018-11-06 06:53:25 +13:00
|
|
|
export function connectTimelineStream (timelineId, path, pollingRefresh = null, accept = null) {
|
2017-08-21 22:04:34 +09:00
|
|
|
|
2017-11-16 00:04:15 +09:00
|
|
|
return connectStream (path, pollingRefresh, (dispatch, getState) => {
|
|
|
|
const locale = getState().getIn(['meta', 'locale']);
|
2019-03-07 22:17:52 +01:00
|
|
|
|
2017-11-16 00:04:15 +09:00
|
|
|
return {
|
2019-03-07 22:17:52 +01:00
|
|
|
onConnect() {
|
|
|
|
dispatch(connectTimeline(timelineId));
|
|
|
|
},
|
|
|
|
|
2017-11-16 00:04:15 +09:00
|
|
|
onDisconnect() {
|
2017-08-21 22:04:34 +09:00
|
|
|
dispatch(disconnectTimeline(timelineId));
|
|
|
|
},
|
|
|
|
|
2017-11-16 00:04:15 +09:00
|
|
|
onReceive (data) {
|
2017-08-21 22:04:34 +09:00
|
|
|
switch(data.event) {
|
|
|
|
case 'update':
|
2018-11-06 06:53:25 +13:00
|
|
|
dispatch(updateTimeline(timelineId, JSON.parse(data.payload), accept));
|
2017-08-21 22:04:34 +09:00
|
|
|
break;
|
|
|
|
case 'delete':
|
|
|
|
dispatch(deleteFromTimelines(data.payload));
|
|
|
|
break;
|
|
|
|
case 'notification':
|
|
|
|
dispatch(updateNotifications(JSON.parse(data.payload), messages, locale));
|
|
|
|
break;
|
2018-10-07 23:44:58 +02:00
|
|
|
case 'conversation':
|
|
|
|
dispatch(updateConversations(JSON.parse(data.payload)));
|
|
|
|
break;
|
2018-06-29 15:34:36 +02:00
|
|
|
case 'filters_changed':
|
|
|
|
dispatch(fetchFilters());
|
|
|
|
break;
|
2017-08-21 22:04:34 +09:00
|
|
|
}
|
|
|
|
},
|
|
|
|
};
|
2017-11-16 00:04:15 +09:00
|
|
|
});
|
2017-08-21 22:04:34 +09:00
|
|
|
}
|
|
|
|
|
2018-05-18 02:32:35 +02:00
|
|
|
const refreshHomeTimelineAndNotification = (dispatch, done) => {
|
|
|
|
dispatch(expandHomeTimeline({}, () => dispatch(expandNotifications({}, done))));
|
|
|
|
};
|
2017-08-21 22:04:34 +09:00
|
|
|
|
2018-05-21 19:43:38 +09:00
|
|
|
export const connectUserStream = () => connectTimelineStream('home', 'user', refreshHomeTimelineAndNotification);
|
|
|
|
export const connectCommunityStream = ({ onlyMedia } = {}) => connectTimelineStream(`community${onlyMedia ? ':media' : ''}`, `public:local${onlyMedia ? ':media' : ''}`);
|
|
|
|
export const connectPublicStream = ({ onlyMedia } = {}) => connectTimelineStream(`public${onlyMedia ? ':media' : ''}`, `public${onlyMedia ? ':media' : ''}`);
|
2018-11-06 06:53:25 +13:00
|
|
|
export const connectHashtagStream = (id, tag, accept) => connectTimelineStream(`hashtag:${id}`, `hashtag&tag=${tag}`, null, accept);
|
2018-05-21 19:43:38 +09:00
|
|
|
export const connectDirectStream = () => connectTimelineStream('direct', 'direct');
|
|
|
|
export const connectListStream = id => connectTimelineStream(`list:${id}`, `list&list=${id}`);
|