fix: check for new indexeddb_error and abort if we get it

This commit is contained in:
Derrick Hammer 2023-11-04 03:23:20 -04:00
parent dd6869e6a5
commit 9c38660562
Signed by: pcfreak30
GPG Key ID: C997C339BE476FF2
1 changed files with 24 additions and 9 deletions

View File

@ -79,6 +79,7 @@ async function boot({
onAuth: (authed: boolean) => Promise<void> | void; onAuth: (authed: boolean) => Promise<void> | void;
onBoot: (booted: boolean) => Promise<void> | void; onBoot: (booted: boolean) => Promise<void> | void;
}) { }) {
let err = false;
const reg = await navigator.serviceWorker.register("/sw.js"); const reg = await navigator.serviceWorker.register("/sw.js");
await reg.update(); await reg.update();
@ -88,9 +89,21 @@ async function boot({
console.error("[Browser.tsx] Failed to init kernel", { error: err }); console.error("[Browser.tsx] Failed to init kernel", { error: err });
}); });
await onInit(true); await onInit(true);
await kernelLoaded().catch((err) => { await kernelLoaded()
console.error("[Browser.tsx] Failed to load kernel", { error: err }); .then((result) => {
}); if ("indexeddb_error" === (result as string)) {
alert(
"Error: Please ensure 3rd party cookies are enabled, and any security like brave shield is off, then reload the app",
);
err = true;
}
})
.catch((err) => {
console.error("[Browser.tsx] Failed to load kernel", { error: err });
});
if (err) {
return;
}
await onAuth(true); await onAuth(true);
BOOT_FUNCTIONS.push( BOOT_FUNCTIONS.push(
@ -197,7 +210,9 @@ export function Navigator() {
<NavInput <NavInput
ref={(el) => (inputEl.current = el)} ref={(el) => (inputEl.current = el)}
disabled={!ready} disabled={!ready}
className={`rounded-l-full bg-neutral-800 text-white border-none focus-visible:ring-offset-0 ${!ready ? "bg-neutral-950" : ""}`} className={`rounded-l-full bg-neutral-800 text-white border-none focus-visible:ring-offset-0 ${
!ready ? "bg-neutral-950" : ""
}`}
name="url" name="url"
/> />
<Button <Button
@ -261,12 +276,12 @@ export function Browser() {
if ( if (
mutation.type === "attributes" && mutation.type === "attributes" &&
mutation.attributeName === "src" mutation.attributeName === "src"
) { ) {
setIsLoadingPage(true); setIsLoadingPage(true);
}
} }
}); }
});
observer.observe(iframe, { attributes: true }); observer.observe(iframe, { attributes: true });
return () => observer.disconnect(); // Clean up on unmount return () => observer.disconnect(); // Clean up on unmount
} }