-
Notifications
You must be signed in to change notification settings - Fork 10.3k
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow parent plugins to declare what pluginOptions fields core should treat as subplugins #21592
Labels
topic: remark/mdx
Related to Markdown, remark & MDX ecosystem
Comments
added option c) that would encapsulate all pluginOptions related task in 1 API hook |
This was referenced Feb 23, 2020
github-actions
bot
added
the
stale?
Issue that may be closed soon due to the original author not responding any more.
label
Mar 13, 2020
johno
added
not stale
and removed
stale?
Issue that may be closed soon due to the original author not responding any more.
labels
Mar 13, 2020
It would also be beneficial if gatsby-plugin-mdx and gatsby-transformer-remark supported the same plugins. |
This issue was moved to a discussion.
You can continue the conversation there. Go to discussion →
plugins
field in pluginOptions is currently pretty special:gatsby/packages/gatsby/src/bootstrap/load-plugins/load.js
Lines 142 to 150 in 9b2d51b
We treat this as a way to define subplugins (mostly
gatsby-transformer-remark
being parent plugin andgatsby-remark-*
being subplugins).This works ok if there is single kind of plugins, or if different kind of subplugins have named exports so parent plugin know which to execute in various scenarios. The "issues" start happening when some plugin want to make use of plugins that were not created specifically for Gatsby. Example of this would be
gatsby-plugin-mdx
that makes use of 3 kinds of plugins (gatsbyRemarkPlugins
,remarkPlugins
andrehypePlugins
) - because remark and rehype plugins are not created with Gatsby being only consumer,gatsby-plugin-mdx
can't dictate contract between parent plugin and subplugins in this case (for example using named exports).In this case
gatsby-plugin-mdx
needs to have 3 different list of 3 different kinds of subplugins, but right now they don't get special handling and so there are problems: traditional way of declaring plugins is to use plugin name that gatsby core resolves to absolute path and then parent plugin can require it (there are also issues there - see #21589). This path is skipped forgatsby-plugin-mdx
and in cases where yarn/npm will not hoist subplugins (they don't end up in rootnode_modules
and instead they are nested somewhere), thengatsby-plugin-mdx
can't import them and that result in:Module not found
errors that user can't recover from.Example design of API
To solve the problem we need a way for
gatsby-plugin-mdx
to:a) either declare that
gatsbyRemarkPlugins
,remarkPlugins
andrehypePlugins
should be treated as sub plugins (so core can resolve paths). For example:b) or provide helper utility to do that on arbitrary input (the helper function would need to be scoped to each plugin instance or to gatsby-config that declared group of plugins:
(note - just resolving the path will not fix issue with not running
gatsby-x
files APIs, so probably this is bad idea)c) this could also be part of #16697, so the hypothetical
onPluginOptions
API isn't meant only for configuration merges, but would allowpluginOptions
related tasks (including declaring subPlugins)---edit:
On top of not being able to resolve module - we also are not running those subplugins
gatsby-x
files APIs (for example this remark subplugin implements gatsby-browser - https://github.com/gatsbyjs/gatsby/blob/master/packages/gatsby-remark-images/src/gatsby-browser.js which either doesn't get used right now orgatsby-plugin-mdx
need to have hacky support for by reimplementing core API runner).The text was updated successfully, but these errors were encountered: