127 lines
2.9 KiB
TypeScript
127 lines
2.9 KiB
TypeScript
|
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,
|
||
|
};
|
||
|
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-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;
|
||
|
}
|