diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-11-20 11:02:20 +0100 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-11-20 19:20:21 +0100 | 
| commit | d5ade2359539648845a5854ed353b29367961d74 (patch) | |
| tree | 45a49d90090408887135a971a7fd79c45d9dcd94 /src/pages/cv.tsx | |
| parent | 6ab9635a22d69186c8a24181ad5df7736e288577 (diff) | |
refactor(components): extract MetaItem from MetaList
* replace `items` prop on MetaList with `children` prop: it was too
restrictive and the global options was not really useful. It is better
too give control to the consumers.
Diffstat (limited to 'src/pages/cv.tsx')
| -rw-r--r-- | src/pages/cv.tsx | 54 | 
1 files changed, 26 insertions, 28 deletions
| diff --git a/src/pages/cv.tsx b/src/pages/cv.tsx index 5157249..0cda194 100644 --- a/src/pages/cv.tsx +++ b/src/pages/cv.tsx @@ -20,8 +20,9 @@ import {    PageLayout,    SocialMediaWidget,    ListItem, -  type MetaItemData,    Time, +  MetaList, +  MetaItem,  } from '../components';  import CVContent, { data, meta } from '../content/pages/cv.mdx';  import type { NextPageWithLayout } from '../types'; @@ -154,32 +155,6 @@ const CVPage: NextPageWithLayout = () => {      id: '+Dre5J',    }); -  const headerMeta: (MetaItemData | undefined)[] = [ -    { -      id: 'publication-date', -      label: intl.formatMessage({ -        defaultMessage: 'Published on:', -        description: 'Page: publication date label', -        id: '4QbTDq', -      }), -      value: <Time date={dates.publication} />, -    }, -    dates.update -      ? { -          id: 'update-date', -          label: intl.formatMessage({ -            defaultMessage: 'Updated on:', -            description: 'Page: update date label', -            id: 'Ez8Qim', -          }), -          value: <Time date={dates.update} />, -        } -      : undefined, -  ]; -  const filteredMeta = headerMeta.filter( -    (item): item is MetaItemData => !!item -  ); -    const cvCaption = intl.formatMessage(      {        defaultMessage: '<link>Download the CV in PDF</link>', @@ -282,7 +257,30 @@ const CVPage: NextPageWithLayout = () => {      <PageLayout        breadcrumb={breadcrumbItems}        breadcrumbSchema={breadcrumbSchema} -      headerMeta={filteredMeta} +      headerMeta={ +        <MetaList> +          <MetaItem +            isInline +            label={intl.formatMessage({ +              defaultMessage: 'Published on:', +              description: 'Page: publication date label', +              id: '4QbTDq', +            })} +            value={<Time date={dates.publication} />} +          /> +          {dates.update ? ( +            <MetaItem +              isInline +              label={intl.formatMessage({ +                defaultMessage: 'Updated on:', +                description: 'Page: update date label', +                id: 'Ez8Qim', +              })} +              value={<Time date={dates.update} />} +            /> +          ) : null} +        </MetaList> +      }        intro={intro}        title={title}        widgets={widgets} | 
