import ContentTable from "@/components/ContentTable";
import Sidebar from "@/components/Sidebar";
import styles from "@/styles/modules/Article.module.scss";
import Image from "next/image";
import Markdown from "@/components/Markdown";
import { formatTextToUrlName } from "@/utils";
import prisma, { ArticleWithIncludes, CategoryWithIncludes } from "@/lib/prisma";
import ArticleControl from "../../../../components/ArticleControl";
import { IContentTableEntry } from "@/types/contentTable";
import { Prisma } from "@prisma/client";
import { useSession, signIn, signOut } from "next-auth/react";
import { CLIENT_RENEG_LIMIT } from "tls";
//* MAIN
export default function ArticlePage({ article }: { article: ArticleWithIncludes }) {
  const dateUpdated: Date = new Date(article?.dateUpdated);
  const dateCreated: Date = new Date(article?.dateCreated);
  const dateOptions: Intl.DateTimeFormatOptions = { month: "long", day: "numeric", year: "numeric" };
  return (
    <>
      
      
         ({ anchor: c.anchor, title: c.title })) : []}
        />
        
          
            
              {`Published on ${dateCreated.toLocaleDateString("en-US", dateOptions)}`}
              
              {dateUpdated > dateCreated ? `Updated on ${dateUpdated.toLocaleDateString("en-US", dateOptions)}` : ""}
            
            {article?.title}
            
            
            {article?.introduction}
           
          
         
        
       
    >
  );
}
export async function generateStaticParams() {
  let articles: ArticleWithIncludes[] = [];
  await prisma.article.findMany({ include: { category: true } }).then(
    (result: ArticleWithIncludes[]) => {
      if (result) {
        articles = result;
      }
    },
    (reason: any) => {
      console.log(reason);
    }
  );
  return await Promise.all(
    articles.map(async (article) => ({
      article: article,
    }))
  );
}
export async function getServerSideProps(context: any) {
  const articleName = formatTextToUrlName(context.params.articleName);
  let article: ArticleWithIncludes | null = null;
  await prisma.article
    .findUnique({
      where: { name: articleName },
      include: { category: true },
    })
    .then(
      (result: ArticleWithIncludes | null) => {
        if (result) {
          article = JSON.parse(JSON.stringify(result));
        }
      },
      (reason: any) => {
        console.log(reason);
      }
    );
  return {
    props: { article: article }, // will be passed to the page component as props
  };
}