RFC: allow routes to declare a React context #6885
Labels
apprentice
Issues that are good candidates to be handled by a Docusaurus apprentice / trainee
domain: content plugin
Related to content plugin emitting metadata for theme consumption
proposal
This issue is a proposal, usually non-trivial change
Milestone
Have you 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:
useFrontMatter()
hook in https://github.com/roydukkey/docusaurus-theme-frontmatterI think it could make sense to have a more generic Docusaurus core API to provide an official route context feature?
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
The text was updated successfully, but these errors were encountered: