import { settings } from '@utils/config';
import Link from 'next/link';
import { useRouter } from 'next/router';
import Script from 'next/script';
import { useIntl } from 'react-intl';
import { BreadcrumbList, WithContext } from 'schema-dts';
import styles from './Breadcrumb.module.scss';
const Breadcrumb = ({ pageTitle }: { pageTitle: string }) => {
  const intl = useIntl();
  const router = useRouter();
  const isHome = router.pathname === '/';
  const isArticle = router.pathname.includes('/article/');
  const isProject = router.pathname.includes('/projet/');
  const isSubject = router.pathname.includes('/sujet/');
  const isThematic = router.pathname.includes('/thematique/');
  const getItems = () => {
    return (
      <>
        
          
            
              {intl.formatMessage({
                defaultMessage: 'Home',
                description: 'Breadcrumb: Home item',
                id: 'Enij19',
              })}
            
          
        
        {(isArticle || isThematic || isSubject) && (
          <>
            
              
                
                  {intl.formatMessage({
                    defaultMessage: 'Blog',
                    description: 'Breadcrumb: Blog item',
                    id: 'z0ic9c',
                  })}
                
              
            
          >
        )}
        {isProject && (
          <>
            
              
                
                  {intl.formatMessage({
                    defaultMessage: 'Projects',
                    description: 'Breadcrumb: Projects item',
                    id: 'Igx3qp',
                  })}
                
              
            
          >
        )}
        {pageTitle}
      >
    );
  };
  const getElementsSchema = () => {
    const items = [];
    const homepage: BreadcrumbList['itemListElement'] = {
      '@type': 'ListItem',
      position: 1,
      name: intl.formatMessage({
        defaultMessage: 'Home',
        description: 'Breadcrumb: Home item',
        id: 'Enij19',
      }),
      item: settings.url,
    };
    items.push(homepage);
    if (isArticle || isThematic || isSubject) {
      const blog: BreadcrumbList['itemListElement'] = {
        '@type': 'ListItem',
        position: 2,
        name: intl.formatMessage({
          defaultMessage: 'Blog',
          description: 'Breadcrumb: Blog item',
          id: 'z0ic9c',
        }),
        item: `${settings.url}/blog`,
      };
      items.push(blog);
    }
    if (isProject) {
      const blog: BreadcrumbList['itemListElement'] = {
        '@type': 'ListItem',
        position: 2,
        name: intl.formatMessage({
          defaultMessage: 'Projects',
          description: 'Breadcrumb: Projects item',
          id: 'Igx3qp',
        }),
        item: `${settings.url}/projets`,
      };
      items.push(blog);
    }
    const currentPage: BreadcrumbList['itemListElement'] = {
      '@type': 'ListItem',
      position: items.length + 1,
      name: pageTitle,
      item: `${settings.url}${router.asPath}`,
    };
    items.push(currentPage);
    return items;
  };
  const schemaJsonLd: WithContext = {
    '@context': 'https://schema.org',
    '@type': 'BreadcrumbList',
    '@id': `${settings.url}/#breadcrumb`,
    itemListElement: getElementsSchema(),
  };
  return (
    <>
      
      {!isHome && (
        
      )}
    >
  );
};
export default Breadcrumb;