diff options
| author | Armand Philippot <git@armandphilippot.com> | 2023-11-14 19:07:14 +0100 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2023-11-14 19:07:14 +0100 | 
| commit | be4d907efb4e2fa658baa7c9b276ed282eb920db (patch) | |
| tree | 0a7bd2d955ce9f9d5e252684ae6735bff7e9bd77 /src/components/templates | |
| parent | a3a4c50f26b8750ae1c87f1f1103b84b7d2e6315 (diff) | |
refactor(components, hooks): rewrite ToC and useHeadingsTree
* replace TableOfContents component with TocWidget to keep the name of
widget components coherent
* replace `wrapper` prop with `tree` prop (the component no longer uses
the hook, it is up to the consumer to provide the headings tree)
* let consumer handle the widget title
* add options to useHeadingsTree hook to retrieve only the wanted
headings (and do not assume that h1 is unwanted)
* expect an ref object instead of an element in useHeadingsTree hook
* rename most of the types involved
Diffstat (limited to 'src/components/templates')
| -rw-r--r-- | src/components/templates/page/page-layout.tsx | 16 | 
1 files changed, 13 insertions, 3 deletions
| diff --git a/src/components/templates/page/page-layout.tsx b/src/components/templates/page/page-layout.tsx index 28c850b..8ea0087 100644 --- a/src/components/templates/page/page-layout.tsx +++ b/src/components/templates/page/page-layout.tsx @@ -1,3 +1,4 @@ +/* eslint-disable max-statements */  import Script from 'next/script';  import {    type FC, @@ -10,7 +11,7 @@ import { useIntl } from 'react-intl';  import type { BreadcrumbList } from 'schema-dts';  import { sendComment } from '../../../services/graphql';  import type { SendCommentInput } from '../../../types'; -import { useIsMounted } from '../../../utils/hooks'; +import { useHeadingsTree, useIsMounted } from '../../../utils/hooks';  import { Heading, Sidebar } from '../../atoms';  import {    PageFooter, @@ -22,7 +23,7 @@ import {    CommentForm,    CommentsList,    type CommentsListProps, -  TableOfContents, +  TocWidget,    Breadcrumbs,    type BreadcrumbsItem,    type CommentFormSubmit, @@ -130,9 +131,15 @@ export const PageLayout: FC<PageLayoutProps> = ({      description: 'PageLayout: comment form accessible name',      id: 'l+Jcf6',    }); +  const tocTitle = intl.formatMessage({ +    defaultMessage: 'Table of Contents', +    description: 'PageLayout: table of contents title', +    id: 'eys2uX', +  });    const bodyRef = useRef<HTMLDivElement>(null);    const isMounted = useIsMounted(bodyRef); +  const headingsTree = useHeadingsTree(bodyRef, { fromLevel: 2 });    const saveComment: CommentFormSubmit = useCallback(      async (data) => { @@ -217,7 +224,10 @@ export const PageLayout: FC<PageLayoutProps> = ({            className={`${styles.sidebar} ${styles['sidebar--first']}`}          >            {isMounted && bodyRef.current ? ( -            <TableOfContents wrapper={bodyRef.current} /> +            <TocWidget +              heading={<Heading level={3}>{tocTitle}</Heading>} +              tree={headingsTree} +            />            ) : null}          </Sidebar>        ) : null} | 
