import { Action, AppViewState } from "./types"; export default function reducer( state: AppViewState, action: Action ): AppViewState { // console.log("Got action", action); switch (action.type) { case "page-loaded": return { ...state, allPages: new Set( [...state.allPages].map((pageMeta) => pageMeta.name === action.name ? { ...pageMeta, lastOpened: Date.now() } : pageMeta ) ), currentPage: action.name, }; case "page-changed": return { ...state, unsavedChanges: true, }; case "page-saved": return { ...state, unsavedChanges: false, }; case "start-navigate": return { ...state, showPageNavigator: true, }; case "stop-navigate": return { ...state, showPageNavigator: false, }; case "pages-listed": return { ...state, allPages: action.pages, }; case "show-palette": let commands = new Map(state.commands); for (let [k, v] of state.commands.entries()) { if ( v.command.contexts && (!action.context || !v.command.contexts.includes(action.context)) ) { commands.delete(k); } } return { ...state, commands, showCommandPalette: true, }; case "hide-palette": return { ...state, showCommandPalette: false, }; case "update-commands": return { ...state, commands: action.commands, actionButtons: action.actionButtons, }; case "show-notification": return { ...state, notifications: [action.notification, ...state.notifications], }; case "dismiss-notification": return { ...state, notifications: state.notifications.filter((n) => n.id !== action.id), }; case "show-rhs": return { ...state, showRHS: action.flex, rhsHTML: action.html, }; case "hide-rhs": return { ...state, showRHS: 0, rhsHTML: "", }; case "show-lhs": return { ...state, showLHS: action.flex, lhsHTML: action.html, }; case "hide-lhs": return { ...state, showLHS: 0, lhsHTML: "", }; case "show-bhs": return { ...state, showBHS: action.flex, bhsHTML: action.html, }; case "hide-bhs": return { ...state, showBHS: 0, bhsHTML: "", }; case "show-filterbox": return { ...state, showFilterBox: true, filterBoxOnSelect: action.onSelect, filterBoxPlaceHolder: action.placeHolder, filterBoxOptions: action.options, filterBoxLabel: action.label, filterBoxHelpText: action.helpText, }; case "hide-filterbox": return { ...state, showFilterBox: false, filterBoxOnSelect: () => {}, filterBoxPlaceHolder: "", filterBoxOptions: [], filterBoxHelpText: "", }; } return state; }