2022-10-10 20:50:21 +08:00
|
|
|
import { Action, AppViewState } from "./types.ts";
|
2022-03-20 16:56:28 +08:00
|
|
|
|
|
|
|
export default function reducer(
|
|
|
|
state: AppViewState,
|
2022-10-10 20:50:21 +08:00
|
|
|
action: Action,
|
2022-03-20 16:56:28 +08:00
|
|
|
): AppViewState {
|
|
|
|
// console.log("Got action", action);
|
|
|
|
switch (action.type) {
|
2022-09-06 22:21:33 +08:00
|
|
|
case "page-loading":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
isLoading: true,
|
|
|
|
currentPage: action.name,
|
|
|
|
};
|
2022-03-20 16:56:28 +08:00
|
|
|
case "page-loaded":
|
|
|
|
return {
|
|
|
|
...state,
|
2022-09-06 22:21:33 +08:00
|
|
|
isLoading: false,
|
2022-03-20 16:56:28 +08:00
|
|
|
allPages: new Set(
|
2022-03-31 23:25:34 +08:00
|
|
|
[...state.allPages].map((pageMeta) =>
|
2022-05-17 17:53:17 +08:00
|
|
|
pageMeta.name === action.meta.name
|
2022-03-31 23:25:34 +08:00
|
|
|
? { ...pageMeta, lastOpened: Date.now() }
|
|
|
|
: pageMeta
|
2022-10-10 20:50:21 +08:00
|
|
|
),
|
2022-03-20 16:56:28 +08:00
|
|
|
),
|
2022-05-17 17:53:17 +08:00
|
|
|
perm: action.meta.perm,
|
|
|
|
currentPage: action.meta.name,
|
2022-03-20 16:56:28 +08:00
|
|
|
};
|
2022-03-31 20:28:07 +08:00
|
|
|
case "page-changed":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
unsavedChanges: true,
|
|
|
|
};
|
|
|
|
case "page-saved":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
unsavedChanges: false,
|
|
|
|
};
|
2022-03-20 16:56:28 +08:00
|
|
|
case "start-navigate":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
showPageNavigator: true,
|
|
|
|
};
|
|
|
|
case "stop-navigate":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
showPageNavigator: false,
|
|
|
|
};
|
2022-10-16 01:02:56 +08:00
|
|
|
case "pages-listed": {
|
2022-08-01 21:06:32 +08:00
|
|
|
// Let's move over any "lastOpened" times to the "allPages" list
|
2022-10-16 01:02:56 +08:00
|
|
|
const oldPageMeta = new Map(
|
|
|
|
[...state.allPages].map((pm) => [pm.name, pm]),
|
|
|
|
);
|
|
|
|
for (const pageMeta of action.pages) {
|
|
|
|
const oldPageMetaItem = oldPageMeta.get(pageMeta.name);
|
2022-08-01 21:06:32 +08:00
|
|
|
if (oldPageMetaItem && oldPageMetaItem.lastOpened) {
|
|
|
|
pageMeta.lastOpened = oldPageMetaItem.lastOpened;
|
|
|
|
}
|
|
|
|
}
|
2022-03-20 16:56:28 +08:00
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
allPages: action.pages,
|
|
|
|
};
|
2022-10-16 01:02:56 +08:00
|
|
|
}
|
|
|
|
case "show-palette": {
|
|
|
|
const commands = new Map(state.commands);
|
|
|
|
for (const [k, v] of state.commands.entries()) {
|
2022-04-21 17:46:33 +08:00
|
|
|
if (
|
|
|
|
v.command.contexts &&
|
|
|
|
(!action.context || !v.command.contexts.includes(action.context))
|
|
|
|
) {
|
|
|
|
commands.delete(k);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
commands,
|
2022-03-20 16:56:28 +08:00
|
|
|
showCommandPalette: true,
|
|
|
|
};
|
2022-10-16 01:02:56 +08:00
|
|
|
}
|
2022-03-20 16:56:28 +08:00
|
|
|
case "hide-palette":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
showCommandPalette: false,
|
|
|
|
};
|
2022-05-16 21:09:36 +08:00
|
|
|
case "command-run":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
recentCommands: state.recentCommands.set(action.command, new Date()),
|
|
|
|
};
|
2022-03-20 16:56:28 +08:00
|
|
|
case "update-commands":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
commands: action.commands,
|
|
|
|
};
|
|
|
|
case "show-notification":
|
|
|
|
return {
|
|
|
|
...state,
|
2022-05-09 20:59:12 +08:00
|
|
|
notifications: [...state.notifications, action.notification],
|
2022-03-20 16:56:28 +08:00
|
|
|
};
|
|
|
|
case "dismiss-notification":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
notifications: state.notifications.filter((n) => n.id !== action.id),
|
|
|
|
};
|
2022-09-30 22:59:57 +08:00
|
|
|
case "show-panel":
|
2022-03-28 21:25:05 +08:00
|
|
|
return {
|
|
|
|
...state,
|
2022-09-30 22:59:57 +08:00
|
|
|
panels: {
|
|
|
|
...state.panels,
|
|
|
|
[action.id]: action.config,
|
|
|
|
},
|
2022-03-28 21:25:05 +08:00
|
|
|
};
|
2022-09-30 22:59:57 +08:00
|
|
|
case "hide-panel":
|
2022-03-28 21:25:05 +08:00
|
|
|
return {
|
|
|
|
...state,
|
2022-09-30 22:59:57 +08:00
|
|
|
panels: {
|
|
|
|
...state.panels,
|
|
|
|
[action.id]: {},
|
|
|
|
},
|
2022-04-27 01:04:36 +08:00
|
|
|
};
|
2022-09-30 22:59:57 +08:00
|
|
|
|
2022-04-13 20:46:52 +08:00
|
|
|
case "show-filterbox":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
showFilterBox: true,
|
|
|
|
filterBoxOnSelect: action.onSelect,
|
|
|
|
filterBoxPlaceHolder: action.placeHolder,
|
|
|
|
filterBoxOptions: action.options,
|
2022-04-21 17:46:33 +08:00
|
|
|
filterBoxLabel: action.label,
|
2022-04-13 20:46:52 +08:00
|
|
|
filterBoxHelpText: action.helpText,
|
|
|
|
};
|
|
|
|
case "hide-filterbox":
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
showFilterBox: false,
|
|
|
|
filterBoxOnSelect: () => {},
|
|
|
|
filterBoxPlaceHolder: "",
|
|
|
|
filterBoxOptions: [],
|
|
|
|
filterBoxHelpText: "",
|
|
|
|
};
|
2022-12-21 21:55:24 +08:00
|
|
|
case "set-ui-option":
|
2022-09-16 20:26:47 +08:00
|
|
|
return {
|
|
|
|
...state,
|
2022-12-21 21:55:24 +08:00
|
|
|
uiOptions: {
|
|
|
|
...state.uiOptions,
|
|
|
|
[action.key]: action.value,
|
|
|
|
},
|
2022-09-16 20:26:47 +08:00
|
|
|
};
|
2022-03-20 16:56:28 +08:00
|
|
|
}
|
|
|
|
return state;
|
|
|
|
}
|