2020-11-15 12:48:32 -06:00
|
|
|
import { connectStream } from '../stream'
|
2019-07-02 03:10:25 -04:00
|
|
|
import {
|
|
|
|
deleteFromTimelines,
|
|
|
|
connectTimeline,
|
|
|
|
disconnectTimeline,
|
Added redux functionality for queueing/dequeueing timelines
using streaming.js, when a status comes in to the current page, it queues up using updateTimelineQueue action, it then goes to the reducer to add "queuedItems" to state (up to max:40) and to tally up all count in that timeilne state "totalQueuedItemsCount".
the dequeueTimeline action takes in a "timelineId", "expandFunc", and "optionalExpandArgs". when clicking on the "click to load more" it passes in the timelineId (e.g. "home", "community", etc.) and the "handleLoadMore" function from the timeline component. if within the range of the max: 40, it pushes them to the dom, if over the max: 40 it clears the timeline and refreshes the page/timeline to show the most recent 20 statuses. Then, it resets the "queuedItems" and "totalQueuedItemsCount" in timeline state.
if no expandFunc is added, and timeline is "home" or "community" it expands those timelines with "optionalExpandArgs". Otherwise, it queues up to any other timeline (e.g. "hashtags", etc.)
2019-07-11 12:09:41 -04:00
|
|
|
updateTimelineQueue,
|
2020-11-15 12:48:32 -06:00
|
|
|
} from './timelines'
|
|
|
|
import { updateNotificationsQueue } from './notifications'
|
2020-12-15 19:31:30 -05:00
|
|
|
import { manageIncomingChatMessage } from './chat_messages'
|
2020-11-15 12:48:32 -06:00
|
|
|
import { fetchFilters } from './filters'
|
|
|
|
import { getLocale } from '../locales'
|
|
|
|
import { handleComposeSubmit } from './compose'
|
2019-07-02 03:10:25 -04:00
|
|
|
|
2020-11-15 12:48:32 -06:00
|
|
|
const { messages } = getLocale()
|
2019-07-02 03:10:25 -04:00
|
|
|
|
2020-11-15 12:48:32 -06:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
export const connectTimelineStream = (timelineId, path, pollingRefresh = null, accept = null) => {
|
2019-07-02 03:10:25 -04:00
|
|
|
|
|
|
|
return connectStream (path, pollingRefresh, (dispatch, getState) => {
|
2020-11-15 12:48:32 -06:00
|
|
|
const locale = getState().getIn(['meta', 'locale'])
|
2019-07-02 03:10:25 -04:00
|
|
|
|
|
|
|
return {
|
|
|
|
onConnect() {
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(connectTimeline(timelineId))
|
2019-07-02 03:10:25 -04:00
|
|
|
},
|
|
|
|
onDisconnect() {
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(disconnectTimeline(timelineId))
|
2019-07-02 03:10:25 -04:00
|
|
|
},
|
|
|
|
onReceive (data) {
|
|
|
|
switch(data.event) {
|
|
|
|
case 'update':
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(updateTimelineQueue(timelineId, JSON.parse(data.payload), accept))
|
|
|
|
break
|
2019-07-02 03:10:25 -04:00
|
|
|
case 'delete':
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(deleteFromTimelines(data.payload))
|
|
|
|
break
|
2019-07-02 03:10:25 -04:00
|
|
|
case 'notification':
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(updateNotificationsQueue(JSON.parse(data.payload), messages, locale, window.location.pathname))
|
|
|
|
break
|
2019-07-02 03:10:25 -04:00
|
|
|
case 'filters_changed':
|
2020-11-15 12:48:32 -06:00
|
|
|
dispatch(fetchFilters())
|
|
|
|
break
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
},
|
2020-11-15 12:48:32 -06:00
|
|
|
}
|
|
|
|
})
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
2020-11-15 12:48:32 -06:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
2019-08-28 01:26:34 -04:00
|
|
|
export const connectStatusUpdateStream = () => {
|
2020-11-15 12:48:32 -06:00
|
|
|
|
2019-08-28 01:26:34 -04:00
|
|
|
return connectStream('statuscard', null, (dispatch, getState) => {
|
2020-11-15 12:48:32 -06:00
|
|
|
|
2019-08-28 01:26:34 -04:00
|
|
|
return {
|
|
|
|
onConnect() {},
|
|
|
|
onDisconnect() {},
|
|
|
|
onReceive (data) {
|
2020-11-15 12:48:32 -06:00
|
|
|
if (!data['event'] || !data['payload']) return
|
2019-08-28 01:26:34 -04:00
|
|
|
if (data.event === 'update') {
|
|
|
|
handleComposeSubmit(dispatch, getState, {data: JSON.parse(data.payload)}, null)
|
|
|
|
}
|
|
|
|
},
|
2020-11-15 12:48:32 -06:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
export const connectUserStream = () => connectTimelineStream('home', 'user')
|
2020-11-25 15:22:37 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
2020-12-02 23:22:51 -05:00
|
|
|
export const connectChatMessagesStream = (accountId) => {
|
2020-12-03 17:13:11 -05:00
|
|
|
return connectStream(`chat_messages`, null, (dispatch, getState) => {
|
2020-11-25 15:22:37 -06:00
|
|
|
return {
|
2020-12-03 17:13:11 -05:00
|
|
|
onConnect() {},
|
|
|
|
onDisconnect() {},
|
2020-11-25 15:22:37 -06:00
|
|
|
onReceive (data) {
|
2020-12-03 17:13:11 -05:00
|
|
|
if (!data['event'] || !data['payload']) return
|
|
|
|
if (data.event === 'notification') {
|
2020-12-21 18:30:46 -05:00
|
|
|
// : todo :
|
|
|
|
//Play sound
|
2020-12-15 19:31:30 -05:00
|
|
|
dispatch(manageIncomingChatMessage(JSON.parse(data.payload)))
|
2020-12-03 17:13:11 -05:00
|
|
|
}
|
2020-11-25 15:22:37 -06:00
|
|
|
},
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|