From 871261bdc8f30619c163c88f18e5655b1cde49cf Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Thu, 11 Mar 2021 17:04:23 -0500 Subject: [PATCH 1/2] downloading external images for translated-content Fixes #3174 --- build/check-images.js | 28 ++++++++++++++++++++++------ build/flaws.js | 7 ++++--- 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/build/check-images.js b/build/check-images.js index 965abbd6b92a..129aa2f888d7 100644 --- a/build/check-images.js +++ b/build/check-images.js @@ -9,6 +9,7 @@ const sizeOf = require("image-size"); const { Document, Image } = require("../content"); const { FLAW_LEVELS } = require("./constants"); const { findMatchesInText } = require("./matches-in-text"); +const { DEFAULT_LOCALE } = require("../libs/constants"); /** * Mutate the `$` instance for image reference and if appropriate, @@ -119,9 +120,24 @@ function checkImageReferences(doc, $, options, { url, rawContent }) { // it now, we still want the full relative URL. img.attr("src", absoluteURL.pathname); } else { + let suggestion = null; + // If this document is *not* en-US, perhaps the external image has already + // been downloaded by the en-US equivalent. If so, make that the suggestion. + if (doc.locale !== DEFAULT_LOCALE) { + const filePath = Image.findByURL( + path.join( + doc.mdn_url.replace(`/${doc.locale}/`, `/${DEFAULT_LOCALE}/`), + path.basename(src) + ) + ); + if (filePath) { + suggestion = path.basename(filePath); + } + } addImageFlaw(img, src, { explanation: "External image URL", externalImage: true, + suggestion, }); } } @@ -137,16 +153,16 @@ function checkImageReferences(doc, $, options, { url, rawContent }) { let enUSFallback = false; if ( !filePath && - doc.locale !== "en-US" && - !finalSrc.startsWith("/en-us/") + doc.locale !== DEFAULT_LOCALE && + !finalSrc.startsWith(`/${DEFAULT_LOCALE.toLowerCase()}/`) ) { - const enFinalSrc = finalSrc.replace( + const enUSFinalSrc = finalSrc.replace( `/${doc.locale.toLowerCase()}/`, - "/en-us/" + `/${DEFAULT_LOCALE.toLowerCase()}/` ); - if (Image.findByURL(enFinalSrc)) { + if (Image.findByURL(enUSFinalSrc)) { // Use the en-US src instead - finalSrc = enFinalSrc; + finalSrc = enUSFinalSrc; // Note that this `` value can work if you use the // en-US equivalent URL instead. enUSFallback = true; diff --git a/build/flaws.js b/build/flaws.js index a10ccdbd9e5b..cf696641268a 100644 --- a/build/flaws.js +++ b/build/flaws.js @@ -21,6 +21,7 @@ const { } = require("./matches-in-text"); const { humanFileSize } = require("./utils"); const { VALID_MIME_TYPES } = require("../filecheck/constants"); +const { DEFAULT_LOCALE } = require("../libs/constants"); function injectFlaws(doc, $, options, { rawContent }) { if (doc.isArchive) return; @@ -574,7 +575,9 @@ async function fixFixableFlaws(doc, options, document) { // HTML. It's only proper HTML when the kumascript macros have been // expanded. let newSrc; - if (flaw.externalImage) { + if (flaw.suggestion) { + newSrc = flaw.suggestion; + } else { // Sanity check that it's an external image const url = new URL(forceExternalURL(flaw.src)); if (url.protocol !== "https:") { @@ -673,8 +676,6 @@ async function fixFixableFlaws(doc, options, document) { throw error; } } - } else { - newSrc = flaw.suggestion; } newRawHTML = replaceMatchesInText(flaw.src, newRawHTML, newSrc, { inAttribute: "src", From 525abc693c2b3230991c23bc6aa87d8baa87dcc4 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Thu, 11 Mar 2021 17:20:21 -0500 Subject: [PATCH 2/2] eslint --- build/flaws.js | 1 - 1 file changed, 1 deletion(-) diff --git a/build/flaws.js b/build/flaws.js index cf696641268a..06b0cd8026c3 100644 --- a/build/flaws.js +++ b/build/flaws.js @@ -21,7 +21,6 @@ const { } = require("./matches-in-text"); const { humanFileSize } = require("./utils"); const { VALID_MIME_TYPES } = require("../filecheck/constants"); -const { DEFAULT_LOCALE } = require("../libs/constants"); function injectFlaws(doc, $, options, { rawContent }) { if (doc.isArchive) return;