-
-
Notifications
You must be signed in to change notification settings - Fork 8.7k
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
feat: add linkTags API #8077
feat: add linkTags API #8077
Conversation
✅ [V2]Built without sensitive environment variables
To edit notification comments on pull requests, go to your Netlify site settings. |
⚡️ Lighthouse report for the deploy preview of this PR
|
I don't have any opinions on this, but I wonder whether we should make it a theme API (like |
I put it where it is as it seems like the logical bedfellow to |
Me neither. Feels weird since |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks almost good! Could you add some docs in https://docusaurus.io/docs/api/themes/configuration and possibly https://docusaurus.io/docs/seo?
Awesome - will do! Just heading to bed now; will put some docs up tomorrow I expect. |
Do these docs work for you @Josh-Cena? |
Paging @Josh-Cena 😅 |
Sorry! All public API additions need to be reviewed by @slorber but he'a on holiday til end of month, so this won't be merged in a while anyway... I would take a look at the documentation later. |
Awesome - thanks for the update! |
There's a failing Windows test, but by the looks of it, it's a flaky test and not linked to this PR. My guess is that if you rerun it'll pass. |
What prevents you from using a plugin instead? The API is not easy to discover but I think this impl should be good enough? function pluginMonetization(context, options) {
return {
name: "plugin-monetization",
injectHtmlTags() {
return {
headTags: [
{
tagName: "link",
attributes: {
rel: "monetization",
content: options.monetizationContent
}
}
]
};
}
};
} Similarly it should be possible to create a more generic links plugin Although I think we discussed in the past it might be convenient to add a such shortcut to add global site links more conveniently, I'm not sure it's the responsibility of the theme to do so, as it would be duplicated in another theme that we'd want to implement. Maybe it's better to add this to export function createBootstrapPlugin({
siteDir,
siteConfig,
}: LoadContext): LoadedPlugin {
const {
stylesheets,
scripts,
clientModules: siteConfigClientModules,
} = siteConfig;
return {
name: 'docusaurus-bootstrap-plugin',
content: null,
options: {
id: 'default',
},
version: {type: 'synthetic'},
path: siteDir,
getClientModules() {
return siteConfigClientModules;
},
injectHtmlTags: () => {
const stylesheetsTags = stylesheets.map(
(source): string | HtmlTagObject =>
typeof source === 'string'
? `<link rel="stylesheet" href="${source}">`
: {
tagName: 'link',
attributes: {
rel: 'stylesheet',
...source,
},
},
);
const scriptsTags = scripts.map((source): string | HtmlTagObject =>
typeof source === 'string'
? `<script src="${source}"></script>`
: {
tagName: 'script',
attributes: {
...source,
},
},
);
return {
headTags: [...stylesheetsTags, ...scriptsTags],
};
},
};
} Also not a fan of "linkTags" naming. We already have stylesheets, scripts and metadata (which afaik is plural of metadatum) so "links" makes more sense to me (also similar to Remix: https://remix.run/docs/en/v1/api/conventions#links) Side note but stylesheets + scripts are in core/siteConfig, and metadata is in the theme/themeConfig (as you noted), that's a bit weird https://docusaurus.io/docs/api/themes/configuration#metadata Maybe we'll want to add a site.metadata in core too for consistency? 🤷♂️ Maybe we'll have both site.metadata + theme.metadata? 🤷♂️ Some important thing to consider: we set some global non-core opinionated meta in the theme currently (I think just Unlike metadata, I'm not sure links are supposed to override each others (any use-case for this?). For example, let's imagine we want to fund Docusauurs with your monetization system, and added our own monetization link by default to all newly created sites: could users override such link? 🤷♂️ |
What about just using the synthetic boottrap plugin above to provide a Like suggested here: #8049 (comment) In the end it's the most flexible way to add any tag in the head, no matter what it is. anything else would just be a shortcut. I'd rather start with more generic, less convenient apis first, and then add shortcuts like Note that we already have a low-level api (plugin), but agree this shortcut ( |
It works - but this is hard to discover and very verbose for what you're trying to achieve (add some link tags). Feels like you have to buy a car when you only want to drive a mile 😄
Happy with
I'd be happy to have a go at this - do you have any examples in the codebase of how this is done already? I can't see any piping examples in the codebase so far? |
Similarly, it can also be handled in the core synthetic bootstrap plugin: export function createBootstrapPlugin({
siteDir,
siteConfig,
}: LoadContext): LoadedPlugin {
const {
stylesheets,
scripts,
head, // <==== NEW
clientModules: siteConfigClientModules,
} = siteConfig;
return {
name: 'docusaurus-bootstrap-plugin',
// other things
injectHtmlTags: () => {
const stylesheetsTags = [];
const scriptsTags = [];
return {
headTags: [
...head, // <==== NEW
...stylesheetsTags, ...scriptsTags],
};
},
};
} Does it make sense? |
Sorry no - I don't follow! I don't know what the |
I think what you're saying is add something extra to this:
But I don't know how that connects to the I guess the question is: how do users use it? I'm guessing that all users are somehow using the |
Exactly: all sites implicitly have this plugin by default.
It's just a default plugin added to all docusaurus sites. We use it to provide shortcuts because some features are already provided by lifecycle plugins so we can just implement something in core with... a plugin. If we were to provide an Use the code above where I added the NEW comments, and users will be able to use in siteconfig:
|
okay cool and they'd do it at the same level as I think I could have a crack at this. Probably at the weekend. |
Yes, I think handling I'm not against adding a But the more important is to provide the low-level API so that if someone wants to add a weird unexpected tag to head (not script, link nor stylesheet), they could. For some reason we started by providing shortcuts instead of the more flexible low-level API 🤷♂️ |
Cool - I think I get it. I'll have a go and report back! |
Pre-flight checklist
Motivation
I'm trying to add a custom link tag to the header of all the pages on my Docusaurus site. In my case I'm looking to render a web monetization link which looks like this:
It looks like there isn't a way to generically supply global link tags with Docusaurus. At least... until now!
I've implemented a new API called
linkTags
which is a generic mechanism for renderinglink
tags. It is modelled after themetadata
API and sits alongside it in theThemeConfig
ofdocusaurus.config.js
Test Plan
I'm not sure where unit tests for this would go - but if you give me a pointer I'll write one! In the meantime you can see a screenshot of this working in this PR and see it working in the preview website also.
Test links
Look at that! It works!
Deploy preview: https://deploy-preview-8077--docusaurus-2.netlify.app/
Crack open the devtools and you can see the
link
tag present and correct.Related issues/PRs
#8049