Skip to content
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

Add Open Graph and Twitter Card meta tags for rich embeds/previews #134

Closed
tsibley opened this issue Mar 14, 2020 · 5 comments · Fixed by #1059
Closed

Add Open Graph and Twitter Card meta tags for rich embeds/previews #134

tsibley opened this issue Mar 14, 2020 · 5 comments · Fixed by #1059
Assignees
Labels
enhancement New feature or request good first issue Good for newcomers please take this issue Extra attention is needed priority: moderate To be resolved after high priority issues

Comments

@tsibley
Copy link
Member

tsibley commented Mar 14, 2020

Open Graph is a microformat that specifies <meta> tags which can be added to the <head> of pages in order to provided structured data about the page. Apps like Facebook, Twitter, and Slack will look for these tags and use them to provide richer embeds/previews when someone links to the page.

Twitter Cards build upon Open Graph to provide some extra Twitter-specific information. These may or may not be necessary in our case.

By setting this up for nextstrain.org pages, links in social apps will display a better preview. Doing so will require changes to both Gatsby and the Nextstrain extensions to Auspice.

One challenge will be picking an appropriate "cover" image, since nearly all of the fancy visuals of Nextstrain are dynamic and not static. A first-pass option might be to use the pathogen cards on the front page of Nextstrain. Later, if desired, we could provide an endpoint which generates screencaps of the tree or map or something (probably with significant caching).

@victorlin
Copy link
Member

victorlin commented Mar 25, 2020

It seems like these tags for the nextstrain.org static site have already been implemented by SEO.js + SiteConfig.js. See this Open Graph Check of https://nextstrain.org - the tags are there. It's worth noting that this seems to be outdated and the og:image points to a non-existent file.

The problem is when linking to a page for datasets or narratives. Examples:

Since these are generated by auspice (the HTML base seems to be auspice/index.html), I believe this issue should be moved over to that repository, unless you all would rather track it here.

@psthomas
Copy link

psthomas commented Apr 3, 2020

I think the og:image file is missing because the siteLogo url in siteConfig.js points to the location in the repo ("/static/logos/nextstrain-logo-small.png") rather than the public location after the static site is built ("/logos/nextstrain-logo-small.png"). I think this is due to the way Gatsby handles absolute links to static files.

Twitter cards should fall back to Open Graph tags if Twitter tags aren't present, but I don't think this is working. Their card validator finds the meta tags but doesn't render a preview, so it might just make sense to add the Twitter tags as well. I can experiment and make a pull request.

Do you have a preference for the "Summary", or "Summary with Large Image" cards? I like the low-key look of the Summary card more but it's up to you.
cards

psthomas added a commit to psthomas/nextstrain.org that referenced this issue Apr 3, 2020
I think the `og:image` file in the <meta> tags is missing because the siteLogo url in
SiteConfig.js points to the location in the repo ("/static/logos/nextstrain-logo-small.png")
rather than the public location after the static site is built ("/logos/nextstrain-logo-small.png").
I think this is due to the way Gatsby handles absolute links to static files.
https://www.gatsbyjs.org/docs/static-folder/#adding-assets-outside-of-the-module-system

Issue nextstrain#134
@tsibley
Copy link
Member Author

tsibley commented May 5, 2020

Thanks @psthomas! I too have a preference for the more condensed "Summary" cards. We'll try to review your PR soon.

@psthomas
Copy link

psthomas commented May 5, 2020

Ok, thanks! The approach I took was to read in the url and splash image relationships from the Cards, and then export a react component that uses them to sync the tags in Auspice. This component could eventually point to screencaps if you used something like Puppeteer to create them during the build.

I've tested all of the static site tags and they work, and the Auspice tags work locally. The main question I have is whether the Auspice tags will be visible to social media bots because some of them aren't rendered on the frontend until after the dataset loads. This would mainly be a problem for the description tags, which are taken from the metadata after it loads.

@genehack genehack self-assigned this Aug 14, 2024
@genehack
Copy link
Contributor

genehack commented Sep 5, 2024

Currently, the OpenGraph meta-elements are only appearing in fully hydrated pages, which is generally not the version of the page that is seen by OpenGraph-consuming applications (e.g., Twitter, Facebook, Mastodon, etc.)

The proper fix here, it seems to me, is getting the metadata to be available in the "un-hydrated" version of the page (i.e., the page version that you see when running curl against the site, not the page version that you see in a browser's web inspector). From what I can tell by experimenting with a small demo Next.js app, the currently "correct" way to do this is with the Metadata API, which is only available when using the App Router.

Consequently, I am going to build on my recent metadata for feed auto-discovery PR and convert the blog over from the Pages Router to the App Router, fixing the OpenGraph meta tag generation along the way. Since we will still, at that point, have some pages using the Pages Router, the changes in the feed auto-discovery PR will still be relevant (hence, why I'm going to do this work on top of that branch).

Hopefully this also gives some idea about how much additional work it will be to switch completely to the Apps Router...

genehack added a commit that referenced this issue Sep 27, 2024
genehack added a commit that referenced this issue Sep 27, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Sep 27, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Sep 27, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Sep 27, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Sep 27, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Nov 5, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Nov 5, 2024
Note: this includes some updates to the FocusParagraph component which
required some knock-on changes in the 'contact' page, due to the
exports of FocusParagraph changing.
genehack added a commit that referenced this issue Nov 5, 2024
Also updates the 404 content test to match the new behavior of not
returning the full page.

Note: file renaming (`404.jsx` -> `not-found.tsx`) is because Next.js
App Router requires the latter name.

Note: old `pages/404.jsx` and `src/pages/404.jsx` are left in place
because the `ListResources` component depends on the `ErrorContainer`
style being exported from them. This will be addressed in a subsequent
commit.
genehack added a commit that referenced this issue Nov 5, 2024
* Add <UserDataWrapper> component to base layout to provide access to
  logged in user via React Context
* Wrap username or login link display into <UserOrLoginLink> Client
  Component; add to <Nav> component
genehack added a commit that referenced this issue Nov 5, 2024
Note: updates the page to use the default layout with the toolbar and
team avatars, in addition to the sponsor logos.
genehack added a commit that referenced this issue Nov 8, 2024
_Largely_ derived from material in Pages Router pages and components,
but with a number of redundant or otherwise unneeded styling elements
excised for minimalism.

Does not yet implement logged in state, and explicitly drops
"minimized" as a nav-bar concept, at least for the moment.
genehack added a commit that referenced this issue Nov 8, 2024
Note: this includes some updates to the FocusParagraph component which
required some knock-on changes in the 'contact' page, due to the
exports of FocusParagraph changing.
genehack added a commit that referenced this issue Nov 8, 2024
Also updates the 404 content test to match the new behavior of not
returning the full page.

Note: file renaming (`404.jsx` -> `not-found.tsx`) is because Next.js
App Router requires the latter name.

Note: old `pages/404.jsx` and `src/pages/404.jsx` are left in place
because the `ListResources` component depends on the `ErrorContainer`
style being exported from them. This will be addressed in a subsequent
commit.
genehack added a commit that referenced this issue Nov 8, 2024
* Add <UserDataWrapper> component to base layout to provide access to
  logged in user via React Context
* Wrap username or login link display into <UserOrLoginLink> Client
  Component; add to <Nav> component
genehack added a commit that referenced this issue Nov 8, 2024
Note: updates the page to use the default layout with the toolbar and
team avatars, in addition to the sponsor logos.
genehack added a commit that referenced this issue Nov 8, 2024
genehack added a commit that referenced this issue Nov 8, 2024
Deletes old Pages Router blog files, as well as displayMarkdown
component.
genehack added a commit that referenced this issue Nov 8, 2024
Convert 'contact', 'team', and 'whoami' to app router; partially convert '404' [#134]
genehack added a commit that referenced this issue Nov 8, 2024
genehack added a commit that referenced this issue Nov 8, 2024
Deletes old Pages Router blog files, as well as displayMarkdown
component.
genehack added a commit that referenced this issue Nov 15, 2024
The need for this update was mainly to get type information for
`marked`; version 14.1.3 was current on the day when I made this
change. (The library releases and updates versions _frequently_.)

I did not carefully review the five years worth of changelogs between
0.7 and 14.1.3, but empirically the API doesn't seem to have changed
and the code still works.
genehack added a commit that referenced this issue Nov 15, 2024
genehack added a commit that referenced this issue Nov 15, 2024
Deletes old Pages Router blog files, as well as displayMarkdown
component.
genehack added a commit that referenced this issue Nov 15, 2024
…URLs [#134]

* Prepend `/blog/` to all blog post image URLs
* Remove `https://nextstrain.org` from link URLs
genehack added a commit that referenced this issue Nov 15, 2024
Port `/blog` to App router; add blog preview cards [#134]
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request good first issue Good for newcomers please take this issue Extra attention is needed priority: moderate To be resolved after high priority issues
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants