-
-
Notifications
You must be signed in to change notification settings - Fork 9.6k
Description
Have you read the Contributing Guidelines on issues?
- I have read the Contributing Guidelines on issues.
Motivation
It is convenient to be able to access page metadata as a hook, from anywhere in the tree, without any props drilling.
Some use-cases:
- @roydukkey implemented a
useFrontMatter()hook in https://github.com/roydukkey/docusaurus-theme-frontmatter - @Josh-Cena add a doc metadata banner to some docs, but it's a bit boilerplate: https://github.com/Josh-Cena/Josh-Cena.github.io/blob/04ba69169f6181bd623185bb8f9be1070a6fdb4c/src/components/DocMetadataBanner.tsx
- See also discussion: Customization use-cases #5468 (comment)
I think it could make sense to have a more generic Docusaurus core API to provide an official route context feature?
addRoute({
path: "/docs/",
component: "DocVersion",
context: {sidebars}, // Something here
routes: [
addRoute({
path: "/docs/",
component: "DocItem",
context: {docMetadata}, // Something here
}}
],
}}We could expose a generic useRouteContext(): unknown, and content plugins could expose consuming hooks to read it in a typesafe way.
If the route has multiple layers like above, we could merge the context (similar to MDXProvider components), eventually throw an error if some key is overridden.
This also means that we could remove the regular props from the existing layout components: now all the static data can always be read from the context hooks (apart from the dynamic props related to the UI state)
IMHO having "props-less" theme components also present some advantages. It would notably allow more flexibility to refactor theme components without any props breaking change.
Using context hooks also helps clarify the API surface to the context, and provides an additional layer for us to try to provide retro compatible changes in case the underlying data structures need to be updated.
I wonder what you think of this idea?
Of course, it would be a quite significant breaking change for users that have a lot of swizzled components, as props would have to be replaced by hooks calls in many places.
Self-service
- I'd be willing to do some initial work on this proposal myself.