You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
42 lines
2.1 KiB
42 lines
2.1 KiB
import NextHead from 'next/head';
|
|
import { useRouter } from 'next/router';
|
|
import React from 'react';
|
|
import { MetaProps } from '../types/layout';
|
|
|
|
export const WEBSITE_HOST_URL = 'https://nextjs-typescript-mdx-blog.vercel.app';
|
|
|
|
const Head = ({ customMeta }: { customMeta?: MetaProps }): JSX.Element => {
|
|
const router = useRouter();
|
|
const meta: MetaProps = {
|
|
title: 'РоботТоп - робототехнический фестиваль',
|
|
description:
|
|
'РоботТОП – это робототехнические соревнования, в которых могут принять участие молодые любители робототехники, объединившись в команды.',
|
|
image: `${WEBSITE_HOST_URL}/images/site-preview.png`,
|
|
type: 'website',
|
|
...customMeta,
|
|
};
|
|
|
|
return (
|
|
<NextHead>
|
|
<title>{meta.title}</title>
|
|
<meta content={meta.description} name="РоботТОП – это робототехнические соревнования, в которых могут принять участие молодые любители робототехники, объединившись в команды." />
|
|
<meta property="og:url" content={`${WEBSITE_HOST_URL}${router.asPath}`} />
|
|
<link rel="canonical" href={`${WEBSITE_HOST_URL}${router.asPath}`} />
|
|
<meta property="og:type" content={meta.type} />
|
|
<meta property="og:site_name" content="РоботТоп - робототехнический фестиваль" />
|
|
<meta property="og:description" content={meta.description} />
|
|
<meta property="og:title" content={meta.title} />
|
|
<meta property="og:image" content={meta.image} />
|
|
<meta name="twitter:card" content="summary_large_image" />
|
|
<meta name="twitter:site" content="@huntarosan" />
|
|
<meta name="twitter:title" content={meta.title} />
|
|
<meta name="twitter:description" content={meta.description} />
|
|
<meta name="twitter:image" content={meta.image} />
|
|
{meta.date && (
|
|
<meta property="article:published_time" content={meta.date} />
|
|
)}
|
|
</NextHead>
|
|
);
|
|
};
|
|
|
|
export default Head;
|
|
|