You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

53 lines
1.3 KiB

// ------------------------------------
// Constants
// ------------------------------------
export const SET_SETTINGS_OPEN = 'SET_SETTINGS_OPEN'
export const SET_ACTIVE_SUBMENU = 'SET_ACTIVE_SUBMENU'
export const DISABLE_SUBMENU = 'DISABLE_SUBMENU'
// ------------------------------------
// Actions
// ------------------------------------
export function setSettingsOpen(settingsOpen) {
return {
type: SET_SETTINGS_OPEN,
settingsOpen
}
}
export function setActiveSubMenu(activeSubMenu) {
return {
type: SET_ACTIVE_SUBMENU,
activeSubMenu
}
}
export function disableSubMenu() {
return {
type: DISABLE_SUBMENU
}
}
// ------------------------------------
// Action Handlers
// ------------------------------------
const ACTION_HANDLERS = {
[SET_SETTINGS_OPEN]: (state, { settingsOpen }) => ({ ...state, settingsOpen }),
[SET_ACTIVE_SUBMENU]: (state, { activeSubMenu }) => ({ ...state, activeSubMenu }),
[DISABLE_SUBMENU]: state => ({ ...state, activeSubMenu: null })
}
// ------------------------------------
// Reducer
// ------------------------------------
const initialState = {
settingsOpen: false,
activeSubMenu: null
}
export default function settingsReducer(state = initialState, action) {
const handler = ACTION_HANDLERS[action.type]
return handler ? handler(state, action) : state
}