forked from treehouse/mastodon
Fix potential duplicate statuses in Explore tab (#22121)
parent
b59fb28e90
commit
c8a1faa86b
|
@ -25,7 +25,7 @@ import {
|
||||||
TRENDS_STATUSES_EXPAND_SUCCESS,
|
TRENDS_STATUSES_EXPAND_SUCCESS,
|
||||||
TRENDS_STATUSES_EXPAND_FAIL,
|
TRENDS_STATUSES_EXPAND_FAIL,
|
||||||
} from '../actions/trends';
|
} from '../actions/trends';
|
||||||
import { Map as ImmutableMap, List as ImmutableList } from 'immutable';
|
import { Map as ImmutableMap, OrderedSet as ImmutableOrderedSet } from 'immutable';
|
||||||
import {
|
import {
|
||||||
FAVOURITE_SUCCESS,
|
FAVOURITE_SUCCESS,
|
||||||
UNFAVOURITE_SUCCESS,
|
UNFAVOURITE_SUCCESS,
|
||||||
|
@ -43,22 +43,22 @@ const initialState = ImmutableMap({
|
||||||
favourites: ImmutableMap({
|
favourites: ImmutableMap({
|
||||||
next: null,
|
next: null,
|
||||||
loaded: false,
|
loaded: false,
|
||||||
items: ImmutableList(),
|
items: ImmutableOrderedSet(),
|
||||||
}),
|
}),
|
||||||
bookmarks: ImmutableMap({
|
bookmarks: ImmutableMap({
|
||||||
next: null,
|
next: null,
|
||||||
loaded: false,
|
loaded: false,
|
||||||
items: ImmutableList(),
|
items: ImmutableOrderedSet(),
|
||||||
}),
|
}),
|
||||||
pins: ImmutableMap({
|
pins: ImmutableMap({
|
||||||
next: null,
|
next: null,
|
||||||
loaded: false,
|
loaded: false,
|
||||||
items: ImmutableList(),
|
items: ImmutableOrderedSet(),
|
||||||
}),
|
}),
|
||||||
trending: ImmutableMap({
|
trending: ImmutableMap({
|
||||||
next: null,
|
next: null,
|
||||||
loaded: false,
|
loaded: false,
|
||||||
items: ImmutableList(),
|
items: ImmutableOrderedSet(),
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ const normalizeList = (state, listType, statuses, next) => {
|
||||||
map.set('next', next);
|
map.set('next', next);
|
||||||
map.set('loaded', true);
|
map.set('loaded', true);
|
||||||
map.set('isLoading', false);
|
map.set('isLoading', false);
|
||||||
map.set('items', ImmutableList(statuses.map(item => item.id)));
|
map.set('items', ImmutableOrderedSet(statuses.map(item => item.id)));
|
||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -75,20 +75,22 @@ const appendToList = (state, listType, statuses, next) => {
|
||||||
return state.update(listType, listMap => listMap.withMutations(map => {
|
return state.update(listType, listMap => listMap.withMutations(map => {
|
||||||
map.set('next', next);
|
map.set('next', next);
|
||||||
map.set('isLoading', false);
|
map.set('isLoading', false);
|
||||||
map.set('items', map.get('items').concat(statuses.map(item => item.id)));
|
map.set('items', map.get('items').union(statuses.map(item => item.id)));
|
||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
|
|
||||||
const prependOneToList = (state, listType, status) => {
|
const prependOneToList = (state, listType, status) => {
|
||||||
return state.update(listType, listMap => listMap.withMutations(map => {
|
return state.updateIn([listType, 'items'], (list) => {
|
||||||
map.set('items', map.get('items').unshift(status.get('id')));
|
if (list.includes(status.get('id'))) {
|
||||||
}));
|
return list;
|
||||||
|
} else {
|
||||||
|
return ImmutableOrderedSet([status.get('id')]).union(list);
|
||||||
|
}
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
const removeOneFromList = (state, listType, status) => {
|
const removeOneFromList = (state, listType, status) => {
|
||||||
return state.update(listType, listMap => listMap.withMutations(map => {
|
return state.updateIn([listType, 'items'], (list) => list.delete(status.get('id')));
|
||||||
map.set('items', map.get('items').filter(item => item !== status.get('id')));
|
|
||||||
}));
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function statusLists(state = initialState, action) {
|
export default function statusLists(state = initialState, action) {
|
||||||
|
@ -139,7 +141,7 @@ export default function statusLists(state = initialState, action) {
|
||||||
return removeOneFromList(state, 'pins', action.status);
|
return removeOneFromList(state, 'pins', action.status);
|
||||||
case ACCOUNT_BLOCK_SUCCESS:
|
case ACCOUNT_BLOCK_SUCCESS:
|
||||||
case ACCOUNT_MUTE_SUCCESS:
|
case ACCOUNT_MUTE_SUCCESS:
|
||||||
return state.updateIn(['trending', 'items'], ImmutableList(), list => list.filterNot(statusId => action.statuses.getIn([statusId, 'account']) === action.relationship.id));
|
return state.updateIn(['trending', 'items'], ImmutableOrderedSet(), list => list.filterNot(statusId => action.statuses.getIn([statusId, 'account']) === action.relationship.id));
|
||||||
default:
|
default:
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue