about summary refs log tree commit diff
path: root/app/javascript/flavours/glitch/reducers/dropdown_menu.js
diff options
context:
space:
mode:
authorDavid Yip <yipdw@member.fsf.org>2018-03-30 11:29:26 -0500
committerGitHub <noreply@github.com>2018-03-30 11:29:26 -0500
commit257146c9608b38846c9c8431c2b293b7c3cf1c6a (patch)
treed8a8d11acbff500f566cb2d543f81e02e6363858 /app/javascript/flavours/glitch/reducers/dropdown_menu.js
parent9248d1e3a73ca97eeb5d177ef2ffcb7d4d9f614c (diff)
parent48bcf4d6e89658abac5405683e823c68f27248f0 (diff)
Merge pull request #406 from ThibG/glitch-soc/fixes/menu-fixes
Backport dropdown menu fixes from Mastodon
Diffstat (limited to 'app/javascript/flavours/glitch/reducers/dropdown_menu.js')
-rw-r--r--app/javascript/flavours/glitch/reducers/dropdown_menu.js18
1 files changed, 18 insertions, 0 deletions
diff --git a/app/javascript/flavours/glitch/reducers/dropdown_menu.js b/app/javascript/flavours/glitch/reducers/dropdown_menu.js
new file mode 100644
index 000000000..5449884cc
--- /dev/null
+++ b/app/javascript/flavours/glitch/reducers/dropdown_menu.js
@@ -0,0 +1,18 @@
+import Immutable from 'immutable';
+import {
+  DROPDOWN_MENU_OPEN,
+  DROPDOWN_MENU_CLOSE,
+} from '../actions/dropdown_menu';
+
+const initialState = Immutable.Map({ openId: null, placement: null });
+
+export default function dropdownMenu(state = initialState, action) {
+  switch (action.type) {
+  case DROPDOWN_MENU_OPEN:
+    return state.merge({ openId: action.id, placement: action.placement });
+  case DROPDOWN_MENU_CLOSE:
+    return state.get('openId') === action.id ? state.set('openId', null) : state;
+  default:
+    return state;
+  }
+}