From 34155bccb1ddbff57edae9e02e2422ddd7facc49 Mon Sep 17 00:00:00 2001 From: Jin Yi Date: Thu, 6 Nov 2025 17:53:56 +0900 Subject: [PATCH] fix: Handle vite:preloadError for graceful deployment asset updates (#6609) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## Summary - Implement graceful handling of Vite preload errors that occur when assets are deleted after new deployments - Auto-reload when safe (no unsaved changes), show confirmation dialog when user has unsaved work - Add i18n support for user-friendly error messages ## Implementation Details - Add `vite:preloadError` event listener in App.vue - Smart reload logic: check `app.vueAppReady` and `workflowStore.activeWorkflow?.isModified` - User confirmation dialog using existing `dialogService.confirm` - Comprehensive i18n keys for title and message ## Background This addresses the issue described in [Vite documentation](https://vite.dev/guide/build.html#load-error-handling) where users encounter import errors when hosting services delete old assets after new deployments. [screen-capture (1).webm](https://github.com/user-attachments/assets/beed3b8e-6f32-4288-a560-55da391a79a1) 🤖 Generated with [Claude Code](https://claude.ai/code) ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-6609-fix-Handle-vite-preloadError-for-graceful-deployment-asset-updates-2a36d73d365081a0b3adeac9fcd1e1dc) by [Unito](https://www.unito.io) --- src/App.vue | 26 ++++++++++++++++++++++++++ src/locales/en/main.json | 2 ++ 2 files changed, 28 insertions(+) diff --git a/src/App.vue b/src/App.vue index a2bd28fdd..6b7c56be0 100644 --- a/src/App.vue +++ b/src/App.vue @@ -16,6 +16,10 @@ import { computed, onMounted } from 'vue' import GlobalDialog from '@/components/dialog/GlobalDialog.vue' import config from '@/config' +import { t } from '@/i18n' +import { useWorkflowStore } from '@/platform/workflow/management/stores/workflowStore' +import { app } from '@/scripts/app' +import { useDialogService } from '@/services/dialogService' import { useWorkspaceStore } from '@/stores/workspaceStore' import { useConflictDetection } from '@/workbench/extensions/manager/composables/useConflictDetection' @@ -23,6 +27,8 @@ import { electronAPI, isElectron } from './utils/envUtil' const workspaceStore = useWorkspaceStore() const conflictDetection = useConflictDetection() +const workflowStore = useWorkflowStore() +const dialogService = useDialogService() const isLoading = computed(() => workspaceStore.spinner) const handleKey = (e: KeyboardEvent) => { workspaceStore.shiftDown = e.shiftKey @@ -48,6 +54,26 @@ onMounted(() => { document.addEventListener('contextmenu', showContextMenu) } + // Handle Vite preload errors (e.g., when assets are deleted after deployment) + window.addEventListener('vite:preloadError', async (_event) => { + // Auto-reload if app is not ready or there are no unsaved changes + if (!app.vueAppReady || !workflowStore.activeWorkflow?.isModified) { + window.location.reload() + } else { + // Show confirmation dialog if there are unsaved changes + await dialogService + .confirm({ + title: t('g.vitePreloadErrorTitle'), + message: t('g.vitePreloadErrorMessage') + }) + .then((confirmed) => { + if (confirmed) { + window.location.reload() + } + }) + } + }) + // Initialize conflict detection in background // This runs async and doesn't block UI setup void conflictDetection.initializeConflictDetection() diff --git a/src/locales/en/main.json b/src/locales/en/main.json index 1492d3b80..009932302 100644 --- a/src/locales/en/main.json +++ b/src/locales/en/main.json @@ -40,6 +40,8 @@ "comfy": "Comfy", "refresh": "Refresh", "refreshNode": "Refresh Node", + "vitePreloadErrorTitle": "New Version Available", + "vitePreloadErrorMessage": "A new version of the app has been released. Would you like to reload?\nIf not, some parts of the app might not work as expected.\nFeel free to decline and save your progress before reloading.", "terminal": "Terminal", "logs": "Logs", "videoFailedToLoad": "Video failed to load",