diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-09-27 17:38:23 +0200 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-10-24 12:25:00 +0200 | 
| commit | 7255d25f6834a208c0ed44636356cc260f6ab6ba (patch) | |
| tree | 88016a958190f766a3ac0ab4b77f4732e17502e8 /src/pages/projets | |
| parent | ba793e043e4d8515b1a9ea490ee2c5f92b1fd6c2 (diff) | |
refactor(components): rewrite Heading component
* remove `alignment` and `withMargin` props (consumer should handle
that)
* move styles to Sass placeholders to avoid repeats with headings
coming from WordPress
* refactor some other components that depend on Heading to avoid ESlint
errors
Diffstat (limited to 'src/pages/projets')
| -rw-r--r-- | src/pages/projets/[slug].tsx | 63 | 
1 files changed, 62 insertions, 1 deletions
| diff --git a/src/pages/projets/[slug].tsx b/src/pages/projets/[slug].tsx index 9981868..afcf060 100644 --- a/src/pages/projets/[slug].tsx +++ b/src/pages/projets/[slug].tsx @@ -5,7 +5,7 @@ import dynamic from 'next/dynamic';  import Head from 'next/head';  import { useRouter } from 'next/router';  import Script from 'next/script'; -import type { ComponentType } from 'react'; +import type { ComponentType, HTMLAttributes } from 'react';  import { useIntl } from 'react-intl';  import {    Code, @@ -22,6 +22,7 @@ import {    type SocialWebsite,    Spinner,    type MetaData, +  Heading,  } from '../../components';  import styles from '../../styles/pages/project.module.scss';  import type { NextPageWithLayout, ProjectPreview, Repos } from '../../types'; @@ -44,9 +45,69 @@ const BorderedImage = (props: ResponsiveImageProps) => (    <ResponsiveImage withBorders={true} {...props} />  ); +const H1 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={1}> +    {children} +  </Heading> +); + +const H2 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={2}> +    {children} +  </Heading> +); + +const H3 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={3}> +    {children} +  </Heading> +); + +const H4 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={4}> +    {children} +  </Heading> +); + +const H5 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={5}> +    {children} +  </Heading> +); + +const H6 = ({ +  children = '', +  ...props +}: HTMLAttributes<HTMLHeadingElement>) => ( +  <Heading {...props} level={6}> +    {children} +  </Heading> +); +  const components: MDXComponents = {    Code,    Gallery, +  h1: H1, +  h2: H2, +  h3: H3, +  h4: H4, +  h5: H5, +  h6: H6,    Image: BorderedImage,    Link,  }; | 
