diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-12-12 18:50:03 +0100 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-12-12 18:50:03 +0100 | 
| commit | 85c4c42bd601270d7be0f34a0767a34bb85e29bb (patch) | |
| tree | 16a07a89cf209139672592fd6988f0c028acb7e9 /src/pages/contact.tsx | |
| parent | 93f87c10783e3d76f1dec667779aedffcae33a39 (diff) | |
refactor(hooks): rewrite useBreadcrumbs hook
* use next/router to get the slug instead of using props
* handle cases where the current page title is not provided
* update JSON-LD schema to match the example in documentation
* add tests
Diffstat (limited to 'src/pages/contact.tsx')
| -rw-r--r-- | src/pages/contact.tsx | 20 | 
1 files changed, 8 insertions, 12 deletions
| diff --git a/src/pages/contact.tsx b/src/pages/contact.tsx index 9394ee8..264ca56 100644 --- a/src/pages/contact.tsx +++ b/src/pages/contact.tsx @@ -25,15 +25,13 @@ import {    getWebPageSchema,  } from '../utils/helpers';  import { loadTranslation } from '../utils/helpers/server'; -import { useBreadcrumb } from '../utils/hooks'; +import { useBreadcrumbs } from '../utils/hooks';  const ContactPage: NextPageWithLayout = () => {    const { dates, intro, seo, title } = meta;    const intl = useIntl(); -  const { items: breadcrumbItems, schema: breadcrumbSchema } = useBreadcrumb({ -    title, -    url: ROUTES.CONTACT, -  }); +  const { items: breadcrumbItems, schema: breadcrumbSchema } = +    useBreadcrumbs(title);    const messages = {      form: intl.formatMessage({ @@ -83,7 +81,11 @@ const ContactPage: NextPageWithLayout = () => {      slug: ROUTES.CONTACT,      title,    }); -  const schemaJsonLd = getSchemaJson([webpageSchema, contactSchema]); +  const schemaJsonLd = getSchemaJson([ +    webpageSchema, +    contactSchema, +    breadcrumbSchema, +  ]);    const submitMail: ContactFormSubmit = useCallback(      async ({ email, message, name, object }) => { @@ -148,12 +150,6 @@ const ContactPage: NextPageWithLayout = () => {          type="application/ld+json"          dangerouslySetInnerHTML={{ __html: JSON.stringify(schemaJsonLd) }}        /> -      <Script -        dangerouslySetInnerHTML={{ __html: JSON.stringify(breadcrumbSchema) }} -        // eslint-disable-next-line react/jsx-no-literals -- Id allowed -        id="schema-breadcrumb" -        type="application/ld+json" -      />        <PageHeader heading={title} intro={intro} />        <PageBody>          <ContactForm aria-label={messages.form} onSubmit={submitMail} /> | 
