|
|
@ -1,3 +1,7 @@ |
|
|
|
|
|
|
|
import { |
|
|
|
|
|
|
|
ACCOUNT_BLOCK_SUCCESS, |
|
|
|
|
|
|
|
ACCOUNT_MUTE_SUCCESS, |
|
|
|
|
|
|
|
} from 'flavours/glitch/actions/accounts'; |
|
|
|
import { CONTEXT_FETCH_SUCCESS } from 'flavours/glitch/actions/statuses'; |
|
|
|
import { CONTEXT_FETCH_SUCCESS } from 'flavours/glitch/actions/statuses'; |
|
|
|
import { TIMELINE_DELETE, TIMELINE_CONTEXT_UPDATE } from 'flavours/glitch/actions/timelines'; |
|
|
|
import { TIMELINE_DELETE, TIMELINE_CONTEXT_UPDATE } from 'flavours/glitch/actions/timelines'; |
|
|
|
import { Map as ImmutableMap, List as ImmutableList } from 'immutable'; |
|
|
|
import { Map as ImmutableMap, List as ImmutableList } from 'immutable'; |
|
|
@ -31,6 +35,12 @@ const deleteFromContexts = (state, id) => { |
|
|
|
return state; |
|
|
|
return state; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const filterContexts = (state, relationship) => { |
|
|
|
|
|
|
|
return state.map( |
|
|
|
|
|
|
|
statuses => statuses.filter( |
|
|
|
|
|
|
|
status => status.get('account') !== relationship.id)); |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
const updateContext = (state, status, references) => { |
|
|
|
const updateContext = (state, status, references) => { |
|
|
|
return state.update('descendants', map => { |
|
|
|
return state.update('descendants', map => { |
|
|
|
references.forEach(parentId => { |
|
|
|
references.forEach(parentId => { |
|
|
@ -49,6 +59,9 @@ const updateContext = (state, status, references) => { |
|
|
|
|
|
|
|
|
|
|
|
export default function contexts(state = initialState, action) { |
|
|
|
export default function contexts(state = initialState, action) { |
|
|
|
switch(action.type) { |
|
|
|
switch(action.type) { |
|
|
|
|
|
|
|
case ACCOUNT_BLOCK_SUCCESS: |
|
|
|
|
|
|
|
case ACCOUNT_MUTE_SUCCESS: |
|
|
|
|
|
|
|
return filterContexts(state, action.relationship); |
|
|
|
case CONTEXT_FETCH_SUCCESS: |
|
|
|
case CONTEXT_FETCH_SUCCESS: |
|
|
|
return normalizeContext(state, action.id, action.ancestors, action.descendants); |
|
|
|
return normalizeContext(state, action.id, action.ancestors, action.descendants); |
|
|
|
case TIMELINE_DELETE: |
|
|
|
case TIMELINE_DELETE: |
|
|
|