mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-15 02:14:03 +01:00
fd87e5a53b
Filtering the status collection wipes out even the profiles of muted and blocked accounts. However, the behavior is inconsistent with the server- side behavior.
74 lines
2.3 KiB
JavaScript
74 lines
2.3 KiB
JavaScript
import {
|
|
ACCOUNT_BLOCK_SUCCESS,
|
|
ACCOUNT_MUTE_SUCCESS,
|
|
} from '../actions/accounts';
|
|
import { CONTEXT_FETCH_SUCCESS } from '../actions/statuses';
|
|
import { TIMELINE_DELETE, TIMELINE_CONTEXT_UPDATE } from '../actions/timelines';
|
|
import { Map as ImmutableMap, List as ImmutableList } from 'immutable';
|
|
|
|
const initialState = ImmutableMap({
|
|
ancestors: ImmutableMap(),
|
|
descendants: ImmutableMap(),
|
|
});
|
|
|
|
const normalizeContext = (state, id, ancestors, descendants) => {
|
|
const ancestorsIds = ImmutableList(ancestors.map(ancestor => ancestor.id));
|
|
const descendantsIds = ImmutableList(descendants.map(descendant => descendant.id));
|
|
|
|
return state.withMutations(map => {
|
|
map.setIn(['ancestors', id], ancestorsIds);
|
|
map.setIn(['descendants', id], descendantsIds);
|
|
});
|
|
};
|
|
|
|
const deleteFromContexts = (state, id) => {
|
|
state.getIn(['descendants', id], ImmutableList()).forEach(descendantId => {
|
|
state = state.updateIn(['ancestors', descendantId], ImmutableList(), list => list.filterNot(itemId => itemId === id));
|
|
});
|
|
|
|
state.getIn(['ancestors', id], ImmutableList()).forEach(ancestorId => {
|
|
state = state.updateIn(['descendants', ancestorId], ImmutableList(), list => list.filterNot(itemId => itemId === id));
|
|
});
|
|
|
|
state = state.deleteIn(['descendants', id]).deleteIn(['ancestors', id]);
|
|
|
|
return state;
|
|
};
|
|
|
|
const filterContexts = (state, relationship) => {
|
|
return state.map(
|
|
statuses => statuses.filter(
|
|
status => status.get('account') !== relationship.id));
|
|
};
|
|
|
|
const updateContext = (state, status, references) => {
|
|
return state.update('descendants', map => {
|
|
references.forEach(parentId => {
|
|
map = map.update(parentId, ImmutableList(), list => {
|
|
if (list.includes(status.id)) {
|
|
return list;
|
|
}
|
|
|
|
return list.push(status.id);
|
|
});
|
|
});
|
|
|
|
return map;
|
|
});
|
|
};
|
|
|
|
export default function contexts(state = initialState, action) {
|
|
switch(action.type) {
|
|
case ACCOUNT_BLOCK_SUCCESS:
|
|
case ACCOUNT_MUTE_SUCCESS:
|
|
return filterContexts(state, action.relationship);
|
|
case CONTEXT_FETCH_SUCCESS:
|
|
return normalizeContext(state, action.id, action.ancestors, action.descendants);
|
|
case TIMELINE_DELETE:
|
|
return deleteFromContexts(state, action.id);
|
|
case TIMELINE_CONTEXT_UPDATE:
|
|
return updateContext(state, action.status, action.references);
|
|
default:
|
|
return state;
|
|
}
|
|
};
|