From 49b8b49156b9a8ec29bdb306727c2d62dcd0863e Mon Sep 17 00:00:00 2001 From: Emma Imber Date: Tue, 23 Apr 2024 15:16:02 +0100 Subject: [PATCH] Show affiliate links on all eligible galleries --- .../views/fragments/galleryBody.scala.html | 1 + applications/app/views/package.scala | 1 + article/app/views/package.scala | 1 + .../DotcomRenderingUtils.scala | 1 + common/app/views/support/HtmlCleaner.scala | 14 ++++-------- .../cleaner/AffiliateLinksCleanerTest.scala | 22 +++++++++++++++++++ 6 files changed, 30 insertions(+), 10 deletions(-) diff --git a/applications/app/views/fragments/galleryBody.scala.html b/applications/app/views/fragments/galleryBody.scala.html index bd074fea597e..44847e6c4804 100644 --- a/applications/app/views/fragments/galleryBody.scala.html +++ b/applications/app/views/fragments/galleryBody.scala.html @@ -34,6 +34,7 @@ tagPaths = page.gallery.content.tags.tags.map(_.id), firstPublishedDate = page.gallery.content.fields.firstPublicationDate, pageUrl = request.uri, + contentType = "gallery", ) ) diff --git a/applications/app/views/package.scala b/applications/app/views/package.scala index 7b554497dc43..b08d180c2032 100644 --- a/applications/app/views/package.scala +++ b/applications/app/views/package.scala @@ -47,6 +47,7 @@ object GalleryCaptionCleaners { appendDisclaimer = Some(isFirstRow && page.item.lightbox.containsAffiliateableLinks), tags = page.gallery.content.tags.tags.map(_.id), page.gallery.content.fields.firstPublicationDate, + contentType = "gallery", ), ) diff --git a/article/app/views/package.scala b/article/app/views/package.scala index 05d1f6ed5114..8c96c692ed79 100644 --- a/article/app/views/package.scala +++ b/article/app/views/package.scala @@ -84,6 +84,7 @@ object BodyProcessor { showAffiliateLinks = article.content.fields.showAffiliateLinks, tags = article.content.tags.tags.map(_.id), publishedDate = article.content.fields.firstPublicationDate, + contentType = "article", ), ) ++ ListIf(true)(VideoEmbedCleaner(article)) diff --git a/common/app/model/dotcomrendering/DotcomRenderingUtils.scala b/common/app/model/dotcomrendering/DotcomRenderingUtils.scala index 4e8519f5be46..f5f29f1092e9 100644 --- a/common/app/model/dotcomrendering/DotcomRenderingUtils.scala +++ b/common/app/model/dotcomrendering/DotcomRenderingUtils.scala @@ -252,6 +252,7 @@ object DotcomRenderingUtils { tagPaths = content.content.tags.tags.map(_.id), firstPublishedDate = content.content.fields.firstPublicationDate, pageUrl = content.metadata.id, + contentType = "article", ) } diff --git a/common/app/views/support/HtmlCleaner.scala b/common/app/views/support/HtmlCleaner.scala index 608681207823..9756c01c8578 100644 --- a/common/app/views/support/HtmlCleaner.scala +++ b/common/app/views/support/HtmlCleaner.scala @@ -872,6 +872,7 @@ case class AffiliateLinksCleaner( appendDisclaimer: Option[Boolean] = None, tags: List[String], publishedDate: Option[DateTime], + contentType: String, ) extends HtmlCleaner with GuLogging { @@ -887,6 +888,7 @@ case class AffiliateLinksCleaner( tags, publishedDate, pageUrl, + contentType, ) ) { AffiliateLinksCleaner.replaceLinksInHtml(document, pageUrl, skimlinksId) @@ -943,6 +945,7 @@ object AffiliateLinksCleaner { tagPaths: List[String], firstPublishedDate: Option[DateTime], pageUrl: String, + contentType: String, ): Boolean = { val publishedCutOffDate = new DateTime(2020, 8, 14, 0, 0) @@ -964,15 +967,6 @@ object AffiliateLinksCleaner { "fashion/2024/mar/17/beauty-spot-10-best-root-cover-ups", "fashion/2024/apr/05/peptides-help-with-good-looking-skin-but-dont-expect-botox-in-a-bottle", "fashion/2024/apr/13/sali-hughes-top-50-beauty-products-for-under-20-pounds", - "fashion/gallery/2024/mar/09/spring-in-your-step-10-menswear-trends-to-update-your-wardrobe-in-pictures", - "fashion/gallery/2024/mar/08/street-smart-what-to-wear-to-run-errands", - "fashion/gallery/2024/mar/09/the-edit-mens-sweatshirts-in-pictures", - "lifeandstyle/gallery/2024/jan/22/colourful-glass-furniture-from-vases-to-lampshades-in-pictures", - "lifeandstyle/gallery/2023/nov/27/cosy-bedding-in-pictures", - "fashion/gallery/2024/mar/24/we-love-fashion-fixes-for-the-week-ahead-in-pictures", - "fashion/gallery/2024/apr/06/we-love-fashion-fixes-for-the-week-ahead-in-pictures", - "fashion/gallery/2024/apr/05/instant-spark-what-to-wear-for-a-first-date", - "fashion/gallery/2024/mar/31/crossbody-carrier-18-of-the-best-handbags-in-pictures", ) val urlIsInAllowList = affiliateLinksAllowList.contains(cleanedPageUrl) @@ -983,7 +977,7 @@ object AffiliateLinksCleaner { if ( !contentHasAlwaysOffTag(tagPaths, alwaysOffTags) && (firstPublishedDate.exists( _.isBefore(publishedCutOffDate), - ) || urlIsInAllowList) + ) || urlIsInAllowList || contentType == "gallery") ) { if (showAffiliateLinks.isDefined) { showAffiliateLinks.contains(true) diff --git a/common/test/views/support/cleaner/AffiliateLinksCleanerTest.scala b/common/test/views/support/cleaner/AffiliateLinksCleanerTest.scala index b02e7ff18ab5..e0133ebaf90c 100644 --- a/common/test/views/support/cleaner/AffiliateLinksCleanerTest.scala +++ b/common/test/views/support/cleaner/AffiliateLinksCleanerTest.scala @@ -31,6 +31,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List.empty, oldPublishedDate, deniedPageUrl, + "article", ) should be(false) shouldAddAffiliateLinks( switchedOn = true, @@ -42,6 +43,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List.empty, oldPublishedDate, deniedPageUrl, + "article", ) should be(true) shouldAddAffiliateLinks( switchedOn = true, @@ -53,6 +55,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List.empty, oldPublishedDate, deniedPageUrl, + "article", ) should be(false) shouldAddAffiliateLinks( switchedOn = true, @@ -64,6 +67,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List.empty, oldPublishedDate, deniedPageUrl, + "article", ) should be(true) shouldAddAffiliateLinks( switchedOn = true, @@ -75,6 +79,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List("bereavement"), oldPublishedDate, deniedPageUrl, + "article", ) should be(false) shouldAddAffiliateLinks( switchedOn = true, @@ -86,6 +91,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List("tech"), oldPublishedDate, deniedPageUrl, + "article", ) should be(false) shouldAddAffiliateLinks( switchedOn = true, @@ -97,6 +103,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List("tech"), oldPublishedDate, deniedPageUrl, + "article", ) should be(true) shouldAddAffiliateLinks( switchedOn = true, @@ -108,6 +115,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List("bereavement"), oldPublishedDate, deniedPageUrl, + "article", ) should be(false) shouldAddAffiliateLinks( switchedOn = true, @@ -119,6 +127,7 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List("tech"), oldPublishedDate, deniedPageUrl, + "article", ) should be(true) shouldAddAffiliateLinks( switchedOn = true, @@ -130,6 +139,19 @@ class AffiliateLinksCleanerTest extends AnyFlatSpec with Matchers { List.empty, newPublishedDate, deniedPageUrl, + "article", ) should be(false) + shouldAddAffiliateLinks( + switchedOn = true, + "film", + None, + supportedSections, + Set.empty, + Set.empty, + List.empty, + newPublishedDate, + deniedPageUrl, + "gallery", + ) should be(true) } }