From 41de9b593b203a76fc2f36da38a78e6ef8a3db76 Mon Sep 17 00:00:00 2001 From: Hera Zhao Date: Sat, 11 Apr 2026 22:54:28 +0000 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=A4=9A=E9=85=8D=E6=96=B9=E4=BF=9D?= =?UTF-8?q?=E5=AD=98=E6=97=B6=E8=B7=B3=E8=BF=87=E9=87=8D=E5=90=8D=E5=90=8E?= =?UTF-8?q?=E7=BB=A7=E7=BB=AD=E5=A4=84=E7=90=86=E4=B8=8B=E4=B8=80=E6=9D=A1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-Authored-By: Claude Opus 4.6 (1M context) --- frontend/src/views/RecipeManager.vue | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/frontend/src/views/RecipeManager.vue b/frontend/src/views/RecipeManager.vue index deee404..9e25e79 100644 --- a/frontend/src/views/RecipeManager.vue +++ b/frontend/src/views/RecipeManager.vue @@ -1049,7 +1049,20 @@ async function saveCurrentRecipe() { // Dedup check for new recipes (not editing) if (!editingRecipe.value) { const result = await checkDupName(diaryPayload.name, cleanIngs) - if (result === false) return // cancelled + if (result === false) { + // Skipped — but if in multi-recipe queue, load next + if (parsedCurrentIndex.value >= 0) { + parsedRecipes.value.splice(parsedCurrentIndex.value, 1) + if (parsedRecipes.value.length > 0) { + loadParsedIntoForm(Math.min(parsedCurrentIndex.value, parsedRecipes.value.length - 1)) + ui.showToast('已跳过,请处理下一条') + } else { + parsedCurrentIndex.value = -1 + closeOverlay() + } + } + return + } if (result !== diaryPayload.name) { formName.value = result diaryPayload.name = result