fix(SW-360): better handleSubmit error handling
This commit is contained in:
@@ -52,11 +52,19 @@ export default function Form({ link, subtitle, title }: RegisterFormProps) {
|
|||||||
const zipCode = intl.formatMessage({ id: "Zip code" })
|
const zipCode = intl.formatMessage({ id: "Zip code" })
|
||||||
|
|
||||||
async function handleSubmit(data: RegisterSchema) {
|
async function handleSubmit(data: RegisterSchema) {
|
||||||
const result = await registerUser(data)
|
try {
|
||||||
if (!result.success) {
|
const result = await registerUser(data)
|
||||||
|
if (result && !result.success) {
|
||||||
|
toast.error(intl.formatMessage({ id: "Something went wrong!" }))
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
// The server-side redirect will throw an error, which we can ignore
|
||||||
|
// as it's handled by Next.js.
|
||||||
|
if (error instanceof Error && error.message.includes("NEXT_REDIRECT")) {
|
||||||
|
return
|
||||||
|
}
|
||||||
toast.error(intl.formatMessage({ id: "Something went wrong!" }))
|
toast.error(intl.formatMessage({ id: "Something went wrong!" }))
|
||||||
}
|
}
|
||||||
// No need to handle success case here, as the redirect happens server-side.
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|||||||
@@ -140,20 +140,6 @@ export const serverActionProcedure = t.procedure.experimental_caller(
|
|||||||
})
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
export const hotelServiceServerActionProcedure = serverActionProcedure.use(
|
|
||||||
async (opts) => {
|
|
||||||
const { access_token } = await fetchServiceToken(["hotel"])
|
|
||||||
if (!access_token) {
|
|
||||||
throw internalServerError("Failed to obtain service token")
|
|
||||||
}
|
|
||||||
return opts.next({
|
|
||||||
ctx: {
|
|
||||||
serviceToken: access_token,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
export const profileServiceServerActionProcedure = serverActionProcedure.use(
|
export const profileServiceServerActionProcedure = serverActionProcedure.use(
|
||||||
async (opts) => {
|
async (opts) => {
|
||||||
const { access_token } = await fetchServiceToken(["profile"])
|
const { access_token } = await fetchServiceToken(["profile"])
|
||||||
|
|||||||
Reference in New Issue
Block a user