import React from "react"
import { Metadata } from "next"
import DocumentFileContainer from "./section/DocumentFileContainer"
import { appConfig } from "@/config/app"
import { notFound } from "next/navigation"
import { cookies } from "next/headers"
import { revalidatePath } from "next/cache"

type Props = { params: { id: string } }

const fetchFolder: any = async (id: string, accessToken: string) => {
  try {
    const res = await fetch(`${appConfig.apiUrl}/documents/folders/${id}`, {
      method: "GET",
      headers: {
        "Content-Type": "application/json",
        Origin: appConfig.appUrl,
        Authorization: "Bearer " + accessToken,
      },
      cache: "no-store",
    })
    if (!res.ok) throw new Error("Failed to fetch folder data")
    return res.json()
  } catch (error) {
    console.error("Error fetching folder data:", error)
    return null
  }
}

const revalidate = async (id: number) => {
  "use server"
  revalidatePath(`${appConfig.apiUrl}/documents/${id}`)
}

export const metadata: Metadata = {
  title: "Documents",
}

export default async function DocumentFiles({ params }: Props) {
  const accessToken = cookies().get("access_token")?.value
  const { id } = params
  const folder = await fetchFolder(id, accessToken)

  if (!folder) notFound()

  return <DocumentFileContainer />
}
