2016-09-04 16:59:46 -07:00
|
|
|
import { TIMELINE_SET, TIMELINE_UPDATE, TIMELINE_DELETE } from '../actions/timelines';
|
|
|
|
import { REBLOG_SUCCESS, FAVOURITE_SUCCESS } from '../actions/interactions';
|
2016-09-12 17:24:40 -07:00
|
|
|
import { ACCOUNT_SET_SELF } from '../actions/accounts';
|
2016-09-04 16:59:46 -07:00
|
|
|
import Immutable from 'immutable';
|
2016-08-24 08:56:44 -07:00
|
|
|
|
2016-09-04 05:04:26 -07:00
|
|
|
const initialState = Immutable.Map({
|
2016-09-04 16:59:46 -07:00
|
|
|
home: Immutable.List([]),
|
|
|
|
mentions: Immutable.List([]),
|
2016-09-04 05:04:26 -07:00
|
|
|
statuses: Immutable.Map(),
|
2016-09-12 17:24:40 -07:00
|
|
|
accounts: Immutable.Map(),
|
|
|
|
me: null
|
2016-09-04 05:04:26 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
function statusToMaps(state, status) {
|
|
|
|
// Separate account
|
|
|
|
let account = status.get('account');
|
|
|
|
status = status.set('account', account.get('id'));
|
|
|
|
|
|
|
|
// Separate reblog, repeat for reblog
|
|
|
|
let reblog = status.get('reblog');
|
|
|
|
|
|
|
|
if (reblog !== null) {
|
|
|
|
status = status.set('reblog', reblog.get('id'));
|
|
|
|
state = statusToMaps(state, reblog);
|
|
|
|
}
|
|
|
|
|
|
|
|
return state.withMutations(map => {
|
|
|
|
map.setIn(['accounts', account.get('id')], account);
|
|
|
|
map.setIn(['statuses', status.get('id')], status);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
function timelineToMaps(state, timeline, statuses) {
|
|
|
|
statuses.forEach((status, i) => {
|
|
|
|
state = statusToMaps(state, status);
|
|
|
|
state = state.setIn([timeline, i], status.get('id'));
|
2016-09-01 04:21:48 -07:00
|
|
|
});
|
2016-09-04 05:04:26 -07:00
|
|
|
|
|
|
|
return state;
|
|
|
|
};
|
|
|
|
|
|
|
|
function updateTimelineWithMaps(state, timeline, status) {
|
|
|
|
state = statusToMaps(state, status);
|
|
|
|
state = state.update(timeline, list => list.unshift(status.get('id')));
|
|
|
|
|
|
|
|
return state;
|
2016-09-01 04:21:48 -07:00
|
|
|
};
|
|
|
|
|
2016-09-04 16:59:46 -07:00
|
|
|
function deleteStatus(state, id) {
|
|
|
|
['home', 'mentions'].forEach(function (timeline) {
|
|
|
|
state = state.update(timeline, list => list.filterNot(item => item === id));
|
|
|
|
});
|
|
|
|
|
|
|
|
return state.deleteIn(['statuses', id]);
|
|
|
|
};
|
|
|
|
|
2016-08-31 07:15:12 -07:00
|
|
|
export default function timelines(state = initialState, action) {
|
2016-08-24 08:56:44 -07:00
|
|
|
switch(action.type) {
|
2016-08-31 07:15:12 -07:00
|
|
|
case TIMELINE_SET:
|
2016-09-04 05:04:26 -07:00
|
|
|
return timelineToMaps(state, action.timeline, Immutable.fromJS(action.statuses));
|
2016-08-31 07:15:12 -07:00
|
|
|
case TIMELINE_UPDATE:
|
2016-09-04 16:59:46 -07:00
|
|
|
return updateTimelineWithMaps(state, action.timeline, Immutable.fromJS(action.status));
|
|
|
|
case TIMELINE_DELETE:
|
|
|
|
return deleteStatus(state, action.id);
|
2016-09-01 04:21:48 -07:00
|
|
|
case REBLOG_SUCCESS:
|
|
|
|
case FAVOURITE_SUCCESS:
|
2016-09-04 05:04:26 -07:00
|
|
|
return statusToMaps(state, Immutable.fromJS(action.response));
|
2016-09-12 17:24:40 -07:00
|
|
|
case ACCOUNT_SET_SELF:
|
|
|
|
return state.withMutations(map => {
|
|
|
|
map.setIn(['accounts', action.account.id], Immutable.fromJS(action.account));
|
|
|
|
map.set('me', action.account.id);
|
|
|
|
});
|
2016-08-24 08:56:44 -07:00
|
|
|
default:
|
|
|
|
return state;
|
|
|
|
}
|
2016-09-12 10:20:55 -07:00
|
|
|
};
|