diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2016-09-22 01:08:35 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2016-09-22 01:08:35 +0200 |
commit | 2c0261ac255ace05078a5745a17886084d5f83d0 (patch) | |
tree | 4c8372d1d5b14a126d90421ff4a77f4fa077a3d9 /app/assets/javascripts/components/reducers | |
parent | 74dfefabd39c52b47c6f5413568687ee3c76772f (diff) |
Infinite scroll for timeline columns
Diffstat (limited to 'app/assets/javascripts/components/reducers')
-rw-r--r-- | app/assets/javascripts/components/reducers/notifications.jsx | 18 | ||||
-rw-r--r-- | app/assets/javascripts/components/reducers/timelines.jsx | 16 |
2 files changed, 32 insertions, 2 deletions
diff --git a/app/assets/javascripts/components/reducers/notifications.jsx b/app/assets/javascripts/components/reducers/notifications.jsx index a1d99f0e1..47641557d 100644 --- a/app/assets/javascripts/components/reducers/notifications.jsx +++ b/app/assets/javascripts/components/reducers/notifications.jsx @@ -1,8 +1,18 @@ import { COMPOSE_SUBMIT_FAIL, COMPOSE_UPLOAD_FAIL } from '../actions/compose'; import { FOLLOW_SUBMIT_FAIL } from '../actions/follow'; import { REBLOG_FAIL, FAVOURITE_FAIL } from '../actions/interactions'; -import { TIMELINE_REFRESH_FAIL } from '../actions/timelines'; +import { + TIMELINE_REFRESH_FAIL, + TIMELINE_EXPAND_FAIL +} from '../actions/timelines'; import { NOTIFICATION_DISMISS, NOTIFICATION_CLEAR } from '../actions/notifications'; +import { + ACCOUNT_FETCH_FAIL, + ACCOUNT_FOLLOW_FAIL, + ACCOUNT_UNFOLLOW_FAIL, + ACCOUNT_TIMELINE_FETCH_FAIL +} from '../actions/accounts'; +import { STATUS_FETCH_FAIL } from '../actions/statuses'; import Immutable from 'immutable'; const initialState = Immutable.List(); @@ -33,6 +43,12 @@ export default function notifications(state = initialState, action) { case REBLOG_FAIL: case FAVOURITE_FAIL: case TIMELINE_REFRESH_FAIL: + case TIMELINE_EXPAND_FAIL: + case ACCOUNT_FETCH_FAIL: + case ACCOUNT_FOLLOW_FAIL: + case ACCOUNT_UNFOLLOW_FAIL: + case ACCOUNT_TIMELINE_FETCH_FAIL: + case STATUS_FETCH_FAIL: return notificationFromError(state, action.error); case NOTIFICATION_DISMISS: return state.filterNot(item => item.get('key') === action.notification.key); diff --git a/app/assets/javascripts/components/reducers/timelines.jsx b/app/assets/javascripts/components/reducers/timelines.jsx index e6a1d0f11..e3de9e9b2 100644 --- a/app/assets/javascripts/components/reducers/timelines.jsx +++ b/app/assets/javascripts/components/reducers/timelines.jsx @@ -1,7 +1,8 @@ import { TIMELINE_REFRESH_SUCCESS, TIMELINE_UPDATE, - TIMELINE_DELETE + TIMELINE_DELETE, + TIMELINE_EXPAND_SUCCESS } from '../actions/timelines'; import { REBLOG_SUCCESS, @@ -89,6 +90,17 @@ function normalizeTimeline(state, timeline, statuses) { return state; }; +function appendNormalizedTimeline(state, timeline, statuses) { + let moreIds = Immutable.List(); + + statuses.forEach((status, i) => { + state = normalizeStatus(state, status); + moreIds = moreIds.set(i, status.get('id')); + }); + + return state.update(timeline, list => list.push(...moreIds)); +}; + function normalizeAccountTimeline(state, accountId, statuses) { statuses.forEach((status, i) => { state = normalizeStatus(state, status); @@ -141,6 +153,8 @@ export default function timelines(state = initialState, action) { switch(action.type) { case TIMELINE_REFRESH_SUCCESS: return normalizeTimeline(state, action.timeline, Immutable.fromJS(action.statuses)); + case TIMELINE_EXPAND_SUCCESS: + return appendNormalizedTimeline(state, action.timeline, Immutable.fromJS(action.statuses)); case TIMELINE_UPDATE: return updateTimeline(state, action.timeline, Immutable.fromJS(action.status)); case TIMELINE_DELETE: |