[Glitch] Add edit history to web UI

Port fd3a45e348 to glitch-soc

Signed-off-by: Claire <claire.github-309c@sitedethib.com>
This commit is contained in:
Eugen Rochko
2022-02-09 01:17:07 +01:00
committed by Claire
parent 322e907e04
commit 44b06c4d96
15 changed files with 596 additions and 121 deletions
@@ -0,0 +1,28 @@
import { HISTORY_FETCH_REQUEST, HISTORY_FETCH_SUCCESS, HISTORY_FETCH_FAIL } from 'flavours/glitch/actions/history';
import { Map as ImmutableMap, List as ImmutableList, fromJS } from 'immutable';
const initialHistory = ImmutableMap({
loading: false,
items: ImmutableList(),
});
const initialState = ImmutableMap();
export default function history(state = initialState, action) {
switch(action.type) {
case HISTORY_FETCH_REQUEST:
return state.update(action.statusId, initialHistory, history => history.withMutations(map => {
map.set('loading', true);
map.set('items', ImmutableList());
}));
case HISTORY_FETCH_SUCCESS:
return state.update(action.statusId, initialHistory, history => history.withMutations(map => {
map.set('loading', false);
map.set('items', fromJS(action.history.map((x, i) => ({ ...x, account: x.account.id, original: i === 0 })).reverse()));
}));
case HISTORY_FETCH_FAIL:
return state.update(action.statusId, initialHistory, history => history.set('loading', false));
default:
return state;
}
}
@@ -41,6 +41,7 @@ import markers from './markers';
import account_notes from './account_notes';
import picture_in_picture from './picture_in_picture';
import accounts_map from './accounts_map';
import history from './history';
const reducers = {
announcements,
@@ -85,6 +86,7 @@ const reducers = {
markers,
account_notes,
picture_in_picture,
history,
};
export default combineReducers(reducers);