Files
full-stack-fastapi-template/frontend/src/utils.ts

56 lines
1.3 KiB
TypeScript
Raw Normal View History

2024-08-01 13:01:03 -05:00
import type { ApiError } from "./client"
import useCustomToast from "./hooks/useCustomToast"
2024-08-01 13:01:03 -05:00
export const emailPattern = {
value: /^[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,}$/i,
message: "Invalid email address",
}
export const namePattern = {
value: /^[A-Za-z\s\u00C0-\u017F]{1,30}$/,
message: "Invalid name",
}
export const passwordRules = (isRequired = true) => {
const rules: any = {
minLength: {
value: 8,
message: "Password must be at least 8 characters",
},
}
if (isRequired) {
rules.required = "Password is required"
}
return rules
}
export const confirmPasswordRules = (
getValues: () => any,
isRequired = true,
) => {
const rules: any = {
validate: (value: string) => {
2024-04-15 16:34:50 -05:00
const password = getValues().password || getValues().new_password
return value === password ? true : "The passwords do not match"
},
}
if (isRequired) {
rules.required = "Password confirmation is required"
}
return rules
}
2024-08-01 13:01:03 -05:00
export const handleError = (err: ApiError) => {
const { showErrorToast } = useCustomToast()
2024-08-01 13:01:03 -05:00
const errDetail = (err.body as any)?.detail
let errorMessage = errDetail || "Something went wrong."
if (Array.isArray(errDetail) && errDetail.length > 0) {
errorMessage = errDetail[0].msg
}
showErrorToast(errorMessage)
2024-08-01 13:01:03 -05:00
}