mirror of
https://git.kescher.at/CatCatNya/catstodon.git
synced 2025-01-08 09:16:56 +01:00
a8a7066e97
* Add confirmation modal when closing media edit modal with unsaved changes * Move focal point media state to redux so it does not get erased by confirmation dialog * Change upload modal behavior to keep it open while saving changes Instead of closing it immediately and losing changes if they fail to save… * Make it work with react-intl 2.9
19 lines
884 B
JavaScript
19 lines
884 B
JavaScript
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';
|
|
|
|
export default function modal(state = ImmutableStack(), action) {
|
|
switch(action.type) {
|
|
case MODAL_OPEN:
|
|
return state.unshift(ImmutableMap({ modalType: action.modalType, modalProps: action.modalProps }));
|
|
case MODAL_CLOSE:
|
|
return (action.modalType === undefined || action.modalType === state.getIn([0, 'modalType'])) ? state.shift() : state;
|
|
case COMPOSE_UPLOAD_CHANGE_SUCCESS:
|
|
return state.getIn([0, 'modalType']) === 'FOCAL_POINT' ? state.shift() : state;
|
|
case TIMELINE_DELETE:
|
|
return state.filterNot((modal) => modal.get('modalProps').statusId === action.id);
|
|
default:
|
|
return state;
|
|
}
|
|
};
|