import type { Route } from './+types' import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage } from '@/components/ui/form' import { isValidCPF } from '@brazilian-utils/brazilian-utils' import { zodResolver } from '@hookform/resolvers/zod' import { Loader2Icon } from 'lucide-react' import { useEffect, useState } from 'react' import { useForm } from 'react-hook-form' import { useFetcher } from 'react-router' import { z } from 'zod' import { Button } from '@/components/ui/button' import { Checkbox } from '@/components/ui/checkbox' import { Input } from '@/components/ui/input' import { Label } from '@/components/ui/label' import * as httpStatus from '@/lib/http-status' import logo from '@/components/logo.svg' const schema = z.object({ username: z .string() .nonempty('Digite um Email ou CPF') .refine((val) => { const onlyDigits = val.replace(/\D/g, '') return onlyDigits.length === 11 ? isValidCPF(val) : z.string().email().safeParse(val).success }, 'Deve ser um Email ou CPF válido'), password: z.string().nonempty('Digite uma senha') }) type Schema = z.infer export function meta({}: Route.MetaArgs) { return [{ title: 'EDUSEG®' }] } export async function action({ request, context }: Route.ActionArgs) { const issuerUrl = new URL('/session', context.cloudflare.env.ISSUER_URL) const formData = Object.fromEntries(await request.formData()) try { const r = await fetch(issuerUrl.toString(), { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(formData) }) if (r.status !== httpStatus.OK) { return Response.json(await r.json(), { status: r.status, headers: r.headers }) } const url = new URL(request.url) url.pathname = '/authorize' const headers = new Headers(r.headers) headers.set('Location', url.toString()) return new Response(await r.text(), { status: httpStatus.FOUND, headers }) } catch { return Response.json({}, { status: httpStatus.INTERNAL_SERVER }) } } export default function Index({}: Route.ComponentProps) { const [show, setShow] = useState(false) const fetcher = useFetcher() const form = useForm({ resolver: zodResolver(schema), defaultValues: { username: '', password: '' } }) const { control, handleSubmit, formState, setError } = form const onSubmit = async (data: Schema) => { await fetcher.submit(data, { method: 'post' }) } useEffect(() => { if (fetcher.state === 'idle' && fetcher.data) { const message = fetcher.data?.message switch (message) { case 'User not found': return setError('username', { message: 'Usuário não encontrado', type: 'manual' }) case 'Invalid credentials': return setError('password', { message: 'A senha está incorreta', type: 'manual' }) } } }, [fetcher.state, fetcher.data]) return ( <>
React Router

Faça login

Não tem uma conta?{' '} Cadastre-se .

( Email ou CPF )} /> (
setShow((x) => !x)} tabIndex={-1} />
)} />

Ao fazer login, você concorda com nossa{' '} política de privacidade .

) }