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 OpenGraph tags to playlist page head #3078

Merged
merged 9 commits into from
Jan 13, 2025
Merged

Conversation

MonkeyDo
Copy link
Member

@MonkeyDo MonkeyDo commented Dec 13, 2024

These were requested on the forums, now that we have Atom feeds for playlists and the embedded previews that use OG tags look very generic.

Followed docs at https://ogp.me/#type_music

My initial implementation used react-helmet (which we already use for the purpose of modifying head tags), but unfortunately that means the page must first load and run the react app before the tags are modified/added.

The solution required moving back to the flask/jinja template layer as those will be rendered to HTML directly.

I've modified our main index.html jinja template to support known and arbitrary opengraph tags, with sane defaults (same as before this PR) for title, description and type.

Once we have images for playlist thumbnails, we could consider adding that as og:image tags and testing that out.

Here is the resulting head when loading a playlist page:
image

N.B.: Considering LB is now a single-page-app with routing on the client-side, the opengraph tags rendered by flask will stay there even after you navigate to another page where (some of) those tags don't apply. This is not really an issue, as the meta tags are meant to be parsed by a machine once on page load while the client-side navigation is all about users in their browser page.

These were requested on the forums now that we have Atom feeds for playlists, and the embedded previews that use OG tags look very generic.
Forgot the indentifier in the playlist is a fully qualified URL, not just the ID
@pep8speaks
Copy link

pep8speaks commented Jan 8, 2025

Hello @MonkeyDo! Thanks for updating this PR. We checked the lines you've touched for PEP 8 issues, and found:

Line 594:1: E302 expected 2 blank lines, found 1

Line 14:1: E303 too many blank lines (3)
Line 29:131: E501 line too long (144 > 130 characters)

Comment last updated at 2025-01-13 13:09:30 UTC

We need to add OG meta tags *before* the react page is loaded (at which point react-helmet can take over) as the tags are read on page load in a lot of cases.

This system should allow us to add any arbitrary og: meta tag we want on various pages as needed, with sane defaults for existing OG tags such as og:type, og:description and og:title as we have them until now.
@MonkeyDo MonkeyDo force-pushed the playlist-opengraph-tags branch from 8adb168 to e240a66 Compare January 8, 2025 17:00
@MonkeyDo
Copy link
Member Author

MonkeyDo commented Jan 9, 2025

I am not sure about the description tag content. Currently I just put the playlist description, but it might be better to have something like "Playlist by mr_monkey — 123 listens — ListenBrainz" similar to what I ended up doing in #3118 , for consistency (and also because it might be more useful info?)

Any opinions?

This was left over from a previous failed attempt at getting the meta tags modified quicker after page load.
Use the playlist creator and number of items in the playlist instead of using the playlist description.
This should be more useful than the text description of the playlist.
@MonkeyDo MonkeyDo force-pushed the playlist-opengraph-tags branch from 4cc61b3 to cedeaef Compare January 13, 2025 13:09
@MonkeyDo
Copy link
Member Author

I have modified the description to show creator name and number of tracks instead of the playlist text description.

<meta property="og:description" content="Playlist by mr_monkey — 1 track — ListenBrainz">

@MonkeyDo MonkeyDo requested a review from anshg1214 January 13, 2025 13:10
Copy link
Member

@anshg1214 anshg1214 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🚀

@anshg1214 anshg1214 merged commit f714613 into master Jan 13, 2025
3 checks passed
@anshg1214 anshg1214 deleted the playlist-opengraph-tags branch January 13, 2025 17:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants