|
|
@ -3,16 +3,36 @@ import { TIMELINE_DELETE } from '../actions/timelines';
|
|
|
|
import { COMPOSE_UPLOAD_CHANGE_SUCCESS } from '../actions/compose';
|
|
|
|
import { COMPOSE_UPLOAD_CHANGE_SUCCESS } from '../actions/compose';
|
|
|
|
import { Stack as ImmutableStack, Map as ImmutableMap } from 'immutable';
|
|
|
|
import { Stack as ImmutableStack, Map as ImmutableMap } from 'immutable';
|
|
|
|
|
|
|
|
|
|
|
|
export default function modal(state = ImmutableStack(), action) {
|
|
|
|
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) {
|
|
|
|
switch(action.type) {
|
|
|
|
switch(action.type) {
|
|
|
|
case MODAL_OPEN:
|
|
|
|
case MODAL_OPEN:
|
|
|
|
return state.unshift(ImmutableMap({ modalType: action.modalType, modalProps: action.modalProps }));
|
|
|
|
return pushModal(state, action.modalType, action.modalProps);
|
|
|
|
case MODAL_CLOSE:
|
|
|
|
case MODAL_CLOSE:
|
|
|
|
return (action.modalType === undefined || action.modalType === state.getIn([0, 'modalType'])) ? state.shift() : state;
|
|
|
|
return popModal(state, action);
|
|
|
|
case COMPOSE_UPLOAD_CHANGE_SUCCESS:
|
|
|
|
case COMPOSE_UPLOAD_CHANGE_SUCCESS:
|
|
|
|
return state.getIn([0, 'modalType']) === 'FOCAL_POINT' ? state.shift() : state;
|
|
|
|
return popModal(state, { modalType: 'FOCAL_POINT', ignoreFocus: false });
|
|
|
|
case TIMELINE_DELETE:
|
|
|
|
case TIMELINE_DELETE:
|
|
|
|
return state.filterNot((modal) => modal.get('modalProps').statusId === action.id);
|
|
|
|
return state.update('stack', stack => stack.filterNot((modal) => modal.get('modalProps').statusId === action.id));
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
return state;
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
}
|
|
|
|