]> cat aescling's git repositories - mastodon.git/commitdiff
Add modal stack to allow better boost modal and media modal interaction.
authorClaire <claire.github-309c@sitedethib.com>
Mon, 12 Jul 2021 15:00:14 +0000 (17:00 +0200)
committerClaire <claire.github-309c@sitedethib.com>
Mon, 12 Jul 2021 15:00:14 +0000 (17:00 +0200)
app/javascript/flavours/glitch/features/ui/containers/modal_container.js
app/javascript/flavours/glitch/reducers/modal.js

index f074002e44ee1b8bfbffd2e243fc9872b22b27c4..e13e745e6da465e7497ccd133544cc9d2ebe9272 100644 (file)
@@ -3,8 +3,8 @@ import { closeModal } from 'flavours/glitch/actions/modal';
 import ModalRoot from '../components/modal_root';
 
 const mapStateToProps = state => ({
-  type: state.get('modal').modalType,
-  props: state.get('modal').modalProps,
+  type: state.getIn(['modal', 0, 'modalType'], null),
+  props: state.getIn(['modal', 0, 'modalProps'], {}),
 });
 
 const mapDispatchToProps = dispatch => ({
index 52b05d69be7d766351d1fc97818f7cd5a691b27c..f8fdc29954c96d5ac3b40a7c72db0f00f8733b47 100644 (file)
@@ -1,19 +1,15 @@
 import { MODAL_OPEN, MODAL_CLOSE } from 'flavours/glitch/actions/modal';
 import { TIMELINE_DELETE } from 'flavours/glitch/actions/timelines';
+import { Stack as ImmutableStack, Map as ImmutableMap } from 'immutable';
 
-const initialState = {
-  modalType: null,
-  modalProps: {},
-};
-
-export default function modal(state = initialState, action) {
+export default function modal(state = ImmutableStack(), action) {
   switch(action.type) {
   case MODAL_OPEN:
-    return { modalType: action.modalType, modalProps: action.modalProps };
+    return state.unshift(ImmutableMap({ modalType: action.modalType, modalProps: action.modalProps }));
   case MODAL_CLOSE:
-    return (action.modalType === undefined || action.modalType === state.modalType) ? initialState : state;
+    return (action.modalType === undefined || action.modalType === state.getIn([0, 'modalType'])) ? state.shift() : state;
   case TIMELINE_DELETE:
-    return (state.modalProps.statusId === action.id) ? initialState : state;
+    return state.filterNot((modal) => modal.get('modalProps').statusId === action.id);
   default:
     return state;
   }