import { zodResolver } from '@hookform/resolvers/zod' import { data } from 'react-router' import { getValidatedFormData } from 'remix-hook-form' import { XiorError } from 'xior' import { uploadFileRequest } from '~/apis/admin/upload-file' import { uploadSchema, type TUploadSchema } from '~/layouts/admin/dialog-upload' import { handleCookie } from '~/libs/cookies' import type { Route } from './+types/actions.admin.upload' export const action = async ({ request }: Route.ActionArgs) => { const { staffToken: accessToken } = await handleCookie(request) try { const { errors, data: payload, receivedValues: defaultValues, } = await getValidatedFormData( request, zodResolver(uploadSchema), false, ) if (errors) { return data({ success: false, errors, defaultValues }, { status: 400 }) } const { data: uploadData } = await uploadFileRequest({ payload, accessToken, }) return data( { success: true, uploadData, }, { status: 200, statusText: 'OK', }, ) } catch (error) { if (error instanceof XiorError) { return data( { success: false, message: error?.response?.data?.error?.message || error.message, }, { status: error?.response?.status || 500, }, ) } return data( { success: false, message: 'Internal server error', }, { status: 500 }, ) } }