* 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;
 | |
|   }
 | |
| };
 |