61 lines
1.9 KiB
TypeScript
61 lines
1.9 KiB
TypeScript
import extensions from "components/system/Files/FileEntry/extensions";
|
|
import { getDefaultFileViewer } from "components/system/Files/FileEntry/functions";
|
|
import { useFileSystem } from "contexts/fileSystem";
|
|
import { useProcesses } from "contexts/process";
|
|
import processDirectory from "contexts/process/directory";
|
|
import { extname } from "path";
|
|
import { useEffect, useRef } from "react";
|
|
import { getSearchParam } from "utils/functions";
|
|
|
|
const useUrlLoader = (): void => {
|
|
const { exists, fs } = useFileSystem();
|
|
const { open } = useProcesses();
|
|
const loadedInitialAppRef = useRef(false);
|
|
|
|
useEffect(() => {
|
|
if (loadedInitialAppRef.current || !fs || !exists || !open) return;
|
|
|
|
loadedInitialAppRef.current = true;
|
|
|
|
const app = getSearchParam("app");
|
|
const url = getSearchParam("url");
|
|
|
|
const loadInitialApp = async (initialApp: string): Promise<void> => {
|
|
if (!initialApp) return;
|
|
|
|
let urlExists = false;
|
|
|
|
try {
|
|
urlExists =
|
|
(initialApp === "Browser" && url.startsWith("http")) ||
|
|
(await exists(url));
|
|
} catch {
|
|
// Ignore error checking if url exists
|
|
}
|
|
|
|
if (initialApp === "FileExplorer" && url && !urlExists) return;
|
|
|
|
open(initialApp, urlExists ? { url } : undefined);
|
|
};
|
|
|
|
if (app) {
|
|
const lcAppNames = Object.fromEntries(
|
|
Object.keys(processDirectory).map((name) => [name.toLowerCase(), name])
|
|
);
|
|
|
|
loadInitialApp(lcAppNames[app.toLowerCase()]);
|
|
} else if (url) {
|
|
const extension = extname(url).toLowerCase();
|
|
const { process: [defaultApp] = [] } = extensions[extension] || {};
|
|
|
|
loadInitialApp(
|
|
extension
|
|
? defaultApp || getDefaultFileViewer(extension)
|
|
: "FileExplorer"
|
|
);
|
|
}
|
|
}, [exists, fs, open]);
|
|
};
|
|
|
|
export default useUrlLoader;
|