mastodon/app/javascript/mastodon/reducers/modal.js

40 lines
1.3 KiB
JavaScript
Raw Normal View History

2017-04-01 20:11:28 +00:00
import { MODAL_OPEN, MODAL_CLOSE } from '../actions/modal';
import { TIMELINE_DELETE } from '../actions/timelines';
import { COMPOSE_UPLOAD_CHANGE_SUCCESS } from '../actions/compose';
import { Stack as ImmutableStack, Map as ImmutableMap } from 'immutable';
2016-10-24 16:07:40 +00:00
const initialState = ImmutableMap({
ignoreFocus: false,
stack: ImmutableStack(),
});
const popModal = (state, { modalType, ignoreFocus }) => {
if (modalType === undefined || modalType === state.getIn(['stack', 0, 'modalType'])) {
return state.set('ignoreFocus', !!ignoreFocus).update('stack', stack => stack.shift());
} else {
return state;
}
};
const pushModal = (state, modalType, modalProps) => {
return state.withMutations(map => {
map.set('ignoreFocus', false);
map.update('stack', stack => stack.unshift(ImmutableMap({ modalType, modalProps })));
});
};
export default function modal(state = initialState, action) {
2016-10-24 16:07:40 +00:00
switch(action.type) {
2017-04-01 20:11:28 +00:00
case MODAL_OPEN:
return pushModal(state, action.modalType, action.modalProps);
2017-01-16 12:27:58 +00:00
case MODAL_CLOSE:
return popModal(state, action);
case COMPOSE_UPLOAD_CHANGE_SUCCESS:
return popModal(state, { modalType: 'FOCAL_POINT', ignoreFocus: false });
case TIMELINE_DELETE:
return state.update('stack', stack => stack.filterNot((modal) => modal.get('modalProps').statusId === action.id));
2017-01-16 12:27:58 +00:00
default:
return state;
2016-10-24 16:07:40 +00:00
}
}