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

Allow Open Graph image URL to be customised #1920

Closed
DevRCRun opened this issue Aug 18, 2020 · 3 comments · Fixed by #2673
Closed

Allow Open Graph image URL to be customised #1920

DevRCRun opened this issue Aug 18, 2020 · 3 comments · Fixed by #2673
Assignees
Labels
🕔 hours A well understood issue which we expect to take less than a day to resolve. page template small story
Milestone

Comments

@DevRCRun
Copy link

DevRCRun commented Aug 18, 2020

Hi

We've set our own absolute URL for this per the instructions in https://design-system.service.gov.uk/styles/page-template/#blocks within block head.

However because your own fallback code is outside of the head block this is still being included in the page. Looking at the comment in the page template and the discussion in alphagov/govuk-design-system#1072 this appears to be by design / at least accepted for the moment in preference to the breaking changes discussed in #1289

From our pov as a local government organisation, we are making sure there are no crown images remaining in our service. Is it okay in this respect to have two

<meta property="og:image">

I am unsure as to whether the second one from the module would or would not ever get used.

Thanks

@36degrees 36degrees added awaiting triage Needs triaging by team page template labels Aug 20, 2020
@kellylee-gds kellylee-gds added 🕔 hours A well understood issue which we expect to take less than a day to resolve. and removed awaiting triage Needs triaging by team labels Aug 24, 2020
@36degrees 36degrees added this to the v4.0.0 milestone Jun 24, 2021
@36degrees
Copy link
Contributor

@DevRCRun Thanks for raising this. In theory, it shouldn't be an issue. The opengraph spec says:

The first tag (from top to bottom) is given preference during conflicts.

<meta property="og:image" content="https://example.com/rock.jpg" />
<meta property="og:image" content="https://example.com/rock2.jpg" />

However, the GOV.UK Notify team have found that Twitter seems to be using the second og:image meta tag. This does seem to go against the spec.

They're working around this by adding a specific twitter:image meta tag – more details in alphagov/emergency-alerts-govuk#124.

This is all a little counter-intuitive, but I think fixing this might involve breaking changes. Ideally we'll revisit this as part of the upcoming 4.0 release.

@vanitabarrett
Copy link
Contributor

As discussed in the v4 planning session, we think this can probably be implemented without a breaking change by making sure we provide a default opengraph image even if we let users customise it.

@vanitabarrett vanitabarrett removed this from the v4.0.0 milestone Aug 24, 2021
@fofr
Copy link
Contributor

fofr commented Dec 7, 2021

I've noticed that when links are shared on Apple's Messages, if there are multiple opengraph images defined then both will display.

@36degrees 36degrees self-assigned this Jun 24, 2022
36degrees added a commit that referenced this issue Jun 24, 2022
We previously told users that if they needed to override the OpenGraph image they should add their own meta tag to the head block and that this would override the one in the template (based on the spec). Some users have found that this isn’t reliable [1] or can result in multiple images being displayed [2] – and it’s a waste of bytes to include a redundant meta tag.

Instead, allow the OpenGraph image URL in the template to be set using a new `opengraphImageUrl` Nunjucks option.

If no `opengraphImageUrl` is provided, keep the existing behaviour that uses `assetUrl` as a prefix for a non-customisable path of `images/govuk-opengraph-image.png`.

However, when neither `opengraphImageUrl` or `assetUrl` are passed, no longer fall back to using the `assetPath` option. OpenGraph image URLs must be absolute [3] and using the `assetPath` only gives us a relative URL, so we should just omit the OpenGraph image tag in these cases.

This is a change in behaviour, as previously an `og:image` meta tag would always be included, but it only be valid if `assetUrl` had been set.

Fixes #1920.

[1]: alphagov/emergency-alerts-govuk#124
[2]: #1920 (comment)
[3]: https://ogp.me/#data_types
36degrees added a commit that referenced this issue Jun 27, 2022
We previously told users that if they needed to override the OpenGraph image they should add their own meta tag to the head block and that this would override the one in the template (based on the spec). Some users have found that this isn’t reliable [1] or can result in multiple images being displayed [2] – and it’s a waste of bytes to include a redundant meta tag.

Instead, allow the OpenGraph image URL in the template to be set using a new `opengraphImageUrl` Nunjucks option.

If no `opengraphImageUrl` is provided, keep the existing behaviour that uses `assetUrl` as a prefix for a non-customisable path of `images/govuk-opengraph-image.png`.

However, when neither `opengraphImageUrl` or `assetUrl` are passed, no longer fall back to using the `assetPath` option. OpenGraph image URLs must be absolute [3] and using the `assetPath` only gives us a relative URL, so we should just omit the OpenGraph image tag in these cases.

This is a change in behaviour, as previously an `og:image` meta tag would always be included, but it only be valid if `assetUrl` had been set.

Fixes #1920.

[1]: alphagov/emergency-alerts-govuk#124
[2]: #1920 (comment)
[3]: https://ogp.me/#data_types
@36degrees 36degrees changed the title Customising opengraph image Allow Open Graph image URL to be customised Jun 27, 2022
@36degrees 36degrees added this to the [NEXT] milestone Jun 27, 2022
querkmachine pushed a commit that referenced this issue Oct 17, 2022
We previously told users that if they needed to override the OpenGraph image they should add their own meta tag to the head block and that this would override the one in the template (based on the spec). Some users have found that this isn’t reliable [1] or can result in multiple images being displayed [2] – and it’s a waste of bytes to include a redundant meta tag.

Instead, allow the OpenGraph image URL in the template to be set using a new `opengraphImageUrl` Nunjucks option.

If no `opengraphImageUrl` is provided, keep the existing behaviour that uses `assetUrl` as a prefix for a non-customisable path of `images/govuk-opengraph-image.png`.

However, when neither `opengraphImageUrl` or `assetUrl` are passed, no longer fall back to using the `assetPath` option. OpenGraph image URLs must be absolute [3] and using the `assetPath` only gives us a relative URL, so we should just omit the OpenGraph image tag in these cases.

This is a change in behaviour, as previously an `og:image` meta tag would always be included, but it only be valid if `assetUrl` had been set.

Fixes #1920.

[1]: alphagov/emergency-alerts-govuk#124
[2]: #1920 (comment)
[3]: https://ogp.me/#data_types
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🕔 hours A well understood issue which we expect to take less than a day to resolve. page template small story
Projects
Development

Successfully merging a pull request may close this issue.

5 participants