use-scroll-spy
Track scroll position and detect which heading is currently in the viewport, can be used for table of contents
Source
Docs
PackageIcon
Usage
The use-scroll-spy hook tracks the scroll position and returns the index of the
element that is currently in the viewport. It is useful for creating
table of contents components (like in the mantine.dev sidebar on the right side)
and similar features.
Scroll to heading:
Hook options
The use-scroll-spy hook accepts an object with options:
selector- selector to get headings; by default it is'h1, h2, h3, h4, h5, h6'getDepth- a function to retrieve the depth of a heading; by default depth is calculated based on the tag namegetValue- a function to retrieve the heading value; by defaultelement.textContentis usedscrollHost- host element to attach scroll event listener, if not provided,windowis usedoffset- offset from the top of the viewport to use when determining the active heading, by default0is used
Example of using custom options to get headings with the data-heading attribute:
Scroll to heading:
Reinitializing hook data
By default, use-scroll-spy does not track changes in the DOM. If you want
to update the headings data after the parent component has mounted, you can use
the reinitialize function:
Definition
All types used in the definition are exported from @mantine/hooks package.
Exported types
UseScrollSpyOptions and UseScrollSpyReturnValue types are exported from the @mantine/hooks package;
you can import them in your application: