securityos/contexts/process/functions.ts

138 lines
4.0 KiB
TypeScript
Raw Permalink Normal View History

2024-09-06 15:32:35 +00:00
import processDirectory from "contexts/process/directory";
import type {
Process,
ProcessArguments,
ProcessElements,
Processes,
} from "contexts/process/types";
import { PREVENT_SCROLL, PROCESS_DELIMITER } from "utils/constants";
import { preloadLibs } from "utils/functions";
const setProcessSettings =
(processId: string, settings: Partial<Process>) =>
(currentProcesses: Processes): Processes => {
const { ...newProcesses } = currentProcesses;
if (newProcesses[processId]) {
newProcesses[processId] = {
...newProcesses[processId],
...settings,
};
}
return newProcesses;
};
export const closeProcess =
(processId: string, closing?: boolean) =>
(currentProcesses: Processes): Processes => {
if (closing) {
return setProcessSettings(processId, { closing })(currentProcesses);
}
const { [processId]: _closedProcess, ...remainingProcesses } =
currentProcesses;
return remainingProcesses;
};
const createPid = (
processId: string,
url: string,
currentProcesses: Processes
): string => {
const pid = url ? `${processId}${PROCESS_DELIMITER}${url}` : processId;
const uniquePid = (instance = 0): string => {
const newPid = `${pid}${instance ? `${PROCESS_DELIMITER}${instance}` : ""}`;
return currentProcesses[newPid] ? uniquePid(instance + 1) : newPid;
};
return uniquePid();
};
export const openProcess =
(processId: string, processArguments: ProcessArguments, icon?: string) =>
(currentProcesses: Processes): Processes => {
const { url = "" } = processArguments;
const { libs, singleton } = processDirectory[processId] || {};
if (libs) preloadLibs(libs);
if (singleton) {
const currentPid = Object.keys(currentProcesses).find(
(pid) =>
pid === processId ||
pid.startsWith(`${processId}${PROCESS_DELIMITER}`)
);
if (currentPid) {
return setProcessSettings(currentPid, { url })(currentProcesses);
}
}
const id = createPid(processId, url, currentProcesses);
if (currentProcesses[id]) {
const { componentWindow } = currentProcesses[id];
componentWindow?.focus(PREVENT_SCROLL);
return currentProcesses;
}
return processDirectory[processId]
? {
...currentProcesses,
[id]: {
...processDirectory[processId],
...(typeof icon === "string" && { icon }),
...processArguments,
},
}
: currentProcesses;
};
export const maximizeProcess =
(processId: string) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, {
maximized: !currentProcesses[processId]?.maximized,
})(currentProcesses);
export const minimizeProcess =
(processId: string) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, {
minimized: !currentProcesses[processId]?.minimized,
})(currentProcesses);
export const setIcon =
(processId: string, icon: string) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, { icon })(currentProcesses);
export const setProcessArgument =
(
processId: string,
name: keyof ProcessArguments,
value: ProcessArguments[keyof ProcessArguments]
) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, { [name]: value })(currentProcesses);
export const setProcessElement =
(processId: string, name: keyof ProcessElements, element: HTMLElement) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, { [name]: element })(currentProcesses);
export const setTitle =
(processId: string, title: string) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, { title })(currentProcesses);
export const setUrl =
(processId: string, url: string) =>
(currentProcesses: Processes): Processes =>
setProcessSettings(processId, { url })(currentProcesses);