Refactor the createReport to API like every other api calls, and added alert to tell users if they sucessfully submitted a report
This commit is contained in:
		| @@ -1,50 +1,23 @@ | |||||||
| "use client" | "use client" | ||||||
| import React, { useState, useRef } from "react"; | import React, { useState, useRef } from "react"; | ||||||
|  | import { createReport | ||||||
|  |  | ||||||
|  |  } from "@/lib/api"; | ||||||
| interface ReportButtonProps { | interface ReportButtonProps { | ||||||
|     bookId: string; |     bookId: string; | ||||||
|     chapterId: string; |     chapterId: string; | ||||||
| } | } | ||||||
| async function createReport( |  | ||||||
|     error_type: string, |  | ||||||
|     details: string, |  | ||||||
|     book_id: string, |  | ||||||
|     chapter_id: string, |  | ||||||
| ) { |  | ||||||
|     const payload = { |  | ||||||
|         data:{ |  | ||||||
|             error_type: error_type, |  | ||||||
|             details: details, |  | ||||||
|             book: book_id, |  | ||||||
|             chapter: chapter_id |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     const response = await fetch( |  | ||||||
|         '/api/reports', |  | ||||||
|         { |  | ||||||
|             method: 'POST', |  | ||||||
|             headers: { |  | ||||||
|                 'Content-Type': 'application/json', |  | ||||||
|             }, |  | ||||||
|             body: JSON.stringify(payload) |  | ||||||
|         } |  | ||||||
|     ) |  | ||||||
|  |  | ||||||
|     if(!response.ok) { |  | ||||||
|         throw new Error(`API request failed with status ${response.status}`) |  | ||||||
|     } |  | ||||||
|     return response.json() |  | ||||||
| } |  | ||||||
| const ReportButton: React.FC<ReportButtonProps> = ({ bookId, chapterId }) => { | const ReportButton: React.FC<ReportButtonProps> = ({ bookId, chapterId }) => { | ||||||
|     const modalRef = useRef<HTMLDivElement>(null) |     const modalRef = useRef<HTMLDivElement>(null) | ||||||
|     const [isOpen, setIsOpen] = useState(false) |     const [isOpen, setIsOpen] = useState(false) | ||||||
|     const [errorType, setErrorType] = useState('') |     const [errorType, setErrorType] = useState('') | ||||||
|     const [details, setDetails] = useState('') |     const [details, setDetails] = useState('') | ||||||
|     const handleSubmitReport = (event: React.FormEvent<HTMLFormElement>) => { |     const handleSubmitReport = async (event: React.FormEvent<HTMLFormElement>) => { | ||||||
|         // Implement report submission here |         // Implement report submission here | ||||||
|         event.preventDefault() |         event.preventDefault() | ||||||
|         createReport(errorType,details,bookId,chapterId) |         const response = await createReport(errorType,details,bookId,chapterId) | ||||||
|  |         response.status === 201 ? alert('Report submitted successfully') : alert('Failed to submit report') | ||||||
|         setErrorType('') |         setErrorType('') | ||||||
|         setDetails('')  |         setDetails('')  | ||||||
|         setIsOpen(false) |         setIsOpen(false) | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ export async function createFromAPI<T>( | |||||||
|  |  | ||||||
|  |  | ||||||
|   const response = await fetch(`${API_URL}${endpoint}`, config) |   const response = await fetch(`${API_URL}${endpoint}`, config) | ||||||
|   if(!response.ok) { |   if (!response.ok) { | ||||||
|     throw new Error(`API request failed with status ${response.status}`) |     throw new Error(`API request failed with status ${response.status}`) | ||||||
|   } |   } | ||||||
|   return response.json() |   return response.json() | ||||||
| @@ -162,20 +162,35 @@ export async function fetchGlossaryByBookId(bookId: string): Promise<Glossary> { | |||||||
|   const data = await fetchFromAPI<Glossary>(`/api/glossaries?filters[book][documentId]=${bookId}`); |   const data = await fetchFromAPI<Glossary>(`/api/glossaries?filters[book][documentId]=${bookId}`); | ||||||
|   return data[0]; |   return data[0]; | ||||||
| } | } | ||||||
|  |  | ||||||
| export async function createReport( | export async function createReport( | ||||||
|   error_type: string, |   error_type: string, | ||||||
|   details: string, |   details: string, | ||||||
|   book_id: string, |   book_id: string, | ||||||
|   chapter_id: string |   chapter_id: string, | ||||||
| ): Promise<Report> { | ) { | ||||||
|   const payload = { |   const payload = { | ||||||
|     data: { |     data: { | ||||||
|       error_type, |       error_type: error_type, | ||||||
|       details, |       details: details, | ||||||
|       book: book_id, |       book: book_id, | ||||||
|       chapter: chapter_id |       chapter: chapter_id | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   const data = await createFromAPI<Report>(`/api/reports`, JSON.stringify(payload)) |  | ||||||
|   return data |   const response = await fetch( | ||||||
|  |     '/api/reports', | ||||||
|  |     { | ||||||
|  |       method: 'POST', | ||||||
|  |       headers: { | ||||||
|  |         'Content-Type': 'application/json', | ||||||
|  |       }, | ||||||
|  |       body: JSON.stringify(payload) | ||||||
|  |     } | ||||||
|  |   ) | ||||||
|  |  | ||||||
|  |   if (!response.ok) { | ||||||
|  |     throw new Error(`API request failed with status ${response.status}`) | ||||||
|  |   } | ||||||
|  |   return response | ||||||
| } | } | ||||||
		Reference in New Issue
	
	Block a user