222 lines
5.6 KiB
TypeScript
222 lines
5.6 KiB
TypeScript
import type { PageMeta } from "../plug-api/types.ts";
|
|
import type { Action, AppViewState } from "../type/web.ts";
|
|
|
|
export default function reducer(
|
|
state: AppViewState,
|
|
action: Action,
|
|
): AppViewState {
|
|
// console.log("Got action", action);
|
|
switch (action.type) {
|
|
case "page-loading":
|
|
return {
|
|
...state,
|
|
isLoading: true,
|
|
currentPage: action.name,
|
|
panels: state.currentPage === action.name ? state.panels : {
|
|
...state.panels,
|
|
// Hide these by default to avoid flickering
|
|
top: {},
|
|
bottom: {},
|
|
},
|
|
};
|
|
case "page-loaded": {
|
|
const mouseDetected = globalThis.matchMedia("(pointer:fine)").matches;
|
|
return {
|
|
...state,
|
|
isLoading: false,
|
|
isMobile: !mouseDetected,
|
|
allPages: state.allPages.map((pageMeta) =>
|
|
pageMeta.name === action.meta.name
|
|
? { ...pageMeta, lastOpened: Date.now() }
|
|
: pageMeta
|
|
),
|
|
currentPage: action.meta.name,
|
|
currentPageMeta: action.meta,
|
|
};
|
|
}
|
|
case "page-changed":
|
|
return {
|
|
...state,
|
|
unsavedChanges: true,
|
|
};
|
|
case "page-saved": {
|
|
return {
|
|
...state,
|
|
unsavedChanges: false,
|
|
};
|
|
}
|
|
case "update-current-page-meta": {
|
|
// Update in the allPages list as well
|
|
state.allPages = state.allPages.map((pageMeta) =>
|
|
pageMeta.name === action.meta.name ? action.meta : pageMeta
|
|
);
|
|
return {
|
|
...state,
|
|
currentPageMeta: action.meta,
|
|
};
|
|
}
|
|
case "sync-change":
|
|
return {
|
|
...state,
|
|
syncFailures: action.syncSuccess ? 0 : state.syncFailures + 1,
|
|
};
|
|
case "settings-loaded":
|
|
return {
|
|
...state,
|
|
settings: action.settings,
|
|
};
|
|
case "update-page-list": {
|
|
// Let's move over any "lastOpened" times to the "allPages" list
|
|
const oldPageMeta = new Map(
|
|
[...state.allPages].map((pm) => [pm.name, pm]),
|
|
);
|
|
let currPageMeta: PageMeta | undefined;
|
|
for (const pageMeta of action.allPages) {
|
|
const oldPageMetaItem = oldPageMeta.get(pageMeta.name);
|
|
if (oldPageMetaItem && oldPageMetaItem.lastOpened) {
|
|
pageMeta.lastOpened = oldPageMetaItem.lastOpened;
|
|
}
|
|
if (pageMeta.name === state.currentPage) {
|
|
currPageMeta = pageMeta;
|
|
}
|
|
}
|
|
return {
|
|
...state,
|
|
allPages: action.allPages,
|
|
currentPageMeta: currPageMeta,
|
|
};
|
|
}
|
|
case "start-navigate": {
|
|
return {
|
|
...state,
|
|
showPageNavigator: true,
|
|
pageNavigatorMode: action.mode,
|
|
showCommandPalette: false,
|
|
showFilterBox: false,
|
|
};
|
|
}
|
|
case "stop-navigate":
|
|
return {
|
|
...state,
|
|
showPageNavigator: false,
|
|
};
|
|
|
|
case "show-palette": {
|
|
return {
|
|
...state,
|
|
showCommandPalette: true,
|
|
showPageNavigator: false,
|
|
showFilterBox: false,
|
|
showCommandPaletteContext: action.context,
|
|
};
|
|
}
|
|
case "hide-palette":
|
|
return {
|
|
...state,
|
|
showCommandPalette: false,
|
|
showCommandPaletteContext: undefined,
|
|
};
|
|
case "command-run":
|
|
return {
|
|
...state,
|
|
recentCommands: state.recentCommands.set(action.command, new Date()),
|
|
};
|
|
case "update-commands":
|
|
return {
|
|
...state,
|
|
commands: action.commands,
|
|
};
|
|
case "show-notification":
|
|
return {
|
|
...state,
|
|
notifications: [...state.notifications, action.notification],
|
|
};
|
|
case "dismiss-notification":
|
|
return {
|
|
...state,
|
|
notifications: state.notifications.filter((n) => n.id !== action.id),
|
|
};
|
|
case "show-panel":
|
|
return {
|
|
...state,
|
|
panels: {
|
|
...state.panels,
|
|
[action.id]: action.config,
|
|
},
|
|
};
|
|
case "hide-panel":
|
|
return {
|
|
...state,
|
|
panels: {
|
|
...state.panels,
|
|
[action.id]: {},
|
|
},
|
|
};
|
|
|
|
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,
|
|
showCommandPalette: false,
|
|
showPageNavigator: false,
|
|
showFilterBox: false,
|
|
filterBoxOnSelect: () => {},
|
|
filterBoxPlaceHolder: "",
|
|
filterBoxOptions: [],
|
|
filterBoxHelpText: "",
|
|
};
|
|
case "show-prompt":
|
|
return {
|
|
...state,
|
|
showPrompt: true,
|
|
promptDefaultValue: action.defaultValue,
|
|
promptMessage: action.message,
|
|
promptCallback: action.callback,
|
|
};
|
|
case "hide-prompt":
|
|
return {
|
|
...state,
|
|
showPrompt: false,
|
|
promptDefaultValue: undefined,
|
|
promptMessage: undefined,
|
|
promptCallback: undefined,
|
|
};
|
|
case "show-confirm":
|
|
return {
|
|
...state,
|
|
showConfirm: true,
|
|
confirmMessage: action.message,
|
|
confirmCallback: action.callback,
|
|
};
|
|
case "hide-confirm":
|
|
return {
|
|
...state,
|
|
showConfirm: false,
|
|
confirmMessage: undefined,
|
|
confirmCallback: undefined,
|
|
};
|
|
case "set-ui-option":
|
|
return {
|
|
...state,
|
|
uiOptions: {
|
|
...state.uiOptions,
|
|
[action.key]: action.value,
|
|
},
|
|
};
|
|
case "set-progress":
|
|
return {
|
|
...state,
|
|
progressPerc: action.progressPerc,
|
|
};
|
|
}
|
|
}
|