diff --git a/src/electron/frontend/core/components/Dashboard.js b/src/electron/frontend/core/components/Dashboard.js
index f23e3baee..9dd128724 100644
--- a/src/electron/frontend/core/components/Dashboard.js
+++ b/src/electron/frontend/core/components/Dashboard.js
@@ -245,32 +245,44 @@ export class Dashboard extends LitElement {
this.page.set(toPass, false);
- this.page.checkSyncState().then(async () => {
- const projectName = info.globalState?.project?.name;
-
- this.subSidebar.header = projectName
- ? `
${projectName}
Conversion Pipeline`
- : projectName;
-
- this.updateSections({ sidebar: false, main: true });
-
- if (this.#transitionPromise.value) this.#transitionPromise.trigger(page); // This ensures calls to page.to() can be properly awaited until the next page is ready
-
- const { skipped } = this.subSidebar.sections[info.section]?.pages?.[info.id] ?? {};
-
- if (skipped) {
- if (isStorybook) return; // Do not skip on storybook
-
- // Run skip functions
- Object.entries(page.workflow).forEach(([key, state]) => {
- if (typeof state.skip === "function") state.skip();
- });
-
- // Skip right over the page if configured as such
- if (previous && previous.info.previous === this.page) await this.page.onTransition(-1);
- else await this.page.onTransition(1);
- }
- });
+ this.page
+ .checkSyncState()
+ .then(async () => {
+ const projectName = info.globalState?.project?.name;
+
+ this.subSidebar.header = projectName
+ ? `${projectName}
Conversion Pipeline`
+ : projectName;
+
+ this.updateSections({ sidebar: false, main: true });
+
+ if (this.#transitionPromise.value) this.#transitionPromise.trigger(page); // This ensures calls to page.to() can be properly awaited until the next page is ready
+
+ const { skipped } = this.subSidebar.sections[info.section]?.pages?.[info.id] ?? {};
+
+ if (skipped) {
+ if (isStorybook) return; // Do not skip on storybook
+
+ // Run skip functions
+ Object.entries(page.workflow).forEach(([key, state]) => {
+ if (typeof state.skip === "function") state.skip();
+ });
+
+ // Skip right over the page if configured as such
+ if (previous && previous.info.previous === this.page) await this.page.onTransition(-1);
+ else await this.page.onTransition(1);
+ }
+ })
+ .catch((e) => {
+ const previousId = previous?.info?.id;
+ if (previousId) {
+ page.onTransition(previousId); // Revert back to previous page
+ page.notify(
+ `Fallback to previous page after error occurred
${e}`,
+ "error"
+ );
+ } else reloadPageToHome();
+ });
}
// Populate the sections tracked for this page by using the global state as a model