From e7ec1b595bda5c65e06b4c612a91deaa22b9e384 Mon Sep 17 00:00:00 2001 From: Xiao Yijun Date: Sun, 11 Aug 2024 13:24:17 +0800 Subject: [PATCH] fix(console): catch timeout error when submitting form --- packages/console/src/utils/form.ts | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/packages/console/src/utils/form.ts b/packages/console/src/utils/form.ts index 4baa0ffb41f..7fc1f624f2c 100644 --- a/packages/console/src/utils/form.ts +++ b/packages/console/src/utils/form.ts @@ -1,9 +1,13 @@ -import { HTTPError } from 'ky'; +import { HTTPError, TimeoutError } from 'ky'; import { type FieldValues, type SubmitHandler } from 'react-hook-form'; +import { toast } from 'react-hot-toast'; /** * After upgrading the react-hook-form to v7.42.0, the `isSubmitting` flag does not recover when the submit handler throws. - * So we need to catch the error and do nothing if the error is an HTTPError and the status code is not 401 to prevent the `isSubmitting` flag from being stuck. + * So we need to catch the error and do nothing if the error is one of the following to prevent the `isSubmitting` flag from being stuck: + * - HTTPError with a status code that is not 401 + * - TimeoutError + * * Reference: https://github.com/orgs/react-hook-form/discussions/10103#discussioncomment-5927542 */ export const trySubmitSafe = @@ -13,6 +17,13 @@ export const trySubmitSafe = await handler(formData, event); } catch (error) { if (error instanceof HTTPError && error.response.status !== 401) { + // Returned directly, since the error has been handled by the `use-api` hook. + return; + } + + if (error instanceof TimeoutError) { + // Display a toast message for the timeout error. + toast.error(error.message); return; }