From 6c0314daa28539fa8c28e070a9072ad6bfd5b5cd Mon Sep 17 00:00:00 2001 From: gnoff Date: Sat, 12 Aug 2023 16:26:47 +0000 Subject: [PATCH] [Fizz][Float] When src or srcSet is a data URI we should not preload the image (#27218) Data URI's in images can't effectively be preloaded (the URI contains the data so preloading only duplicates the data in the stream. If we encounter an image with this protocol in the src attribute we should avoid preloading it. DiffTrain build for [1a001dac6220a64d98ae33a28e89dde78100d6c5](https://github.com/facebook/react/commit/1a001dac6220a64d98ae33a28e89dde78100d6c5) --- compiled/facebook-www/REVISION | 2 +- .../ReactDOMServer-dev.classic.js | 29 +++++++++++++++---- .../facebook-www/ReactDOMServer-dev.modern.js | 29 +++++++++++++++---- .../ReactDOMServer-prod.classic.js | 24 +++++++++++---- .../ReactDOMServer-prod.modern.js | 24 +++++++++++---- .../ReactDOMServerStreaming-dev.modern.js | 27 +++++++++++++---- .../ReactDOMServerStreaming-prod.modern.js | 22 ++++++++++---- 7 files changed, 122 insertions(+), 35 deletions(-) diff --git a/compiled/facebook-www/REVISION b/compiled/facebook-www/REVISION index 1bbd7c82a5bea..acdf592eacccc 100644 --- a/compiled/facebook-www/REVISION +++ b/compiled/facebook-www/REVISION @@ -1 +1 @@ -4e3618ae41669c95a3377ae615c727f74f89d141 +1a001dac6220a64d98ae33a28e89dde78100d6c5 diff --git a/compiled/facebook-www/ReactDOMServer-dev.classic.js b/compiled/facebook-www/ReactDOMServer-dev.classic.js index 49b2b7fd7dcb4..ff9799a8a72a9 100644 --- a/compiled/facebook-www/ReactDOMServer-dev.classic.js +++ b/compiled/facebook-www/ReactDOMServer-dev.classic.js @@ -19,7 +19,7 @@ if (__DEV__) { var React = require("react"); var ReactDOM = require("react-dom"); -var ReactVersion = "18.3.0-www-classic-fa9bab35"; +var ReactVersion = "18.3.0-www-classic-a46bb872"; // This refers to a WWW module. var warningWWW = require("warning"); @@ -4518,16 +4518,33 @@ function getImagePreloadKey(href, imageSrcSet, imageSizes) { } function pushImg(target, props, resources) { + var src = props.src, + srcSet = props.srcSet; + if ( props.loading !== "lazy" && - typeof props.src === "string" && - props.fetchPriority !== "low" + (typeof src === "string" || typeof srcSet === "string") && + props.fetchPriority !== "low" && // We exclude data URIs in src and srcSet since these should not be preloaded + !( + typeof src === "string" && + src[4] === ":" && + (src[0] === "d" || src[0] === "D") && + (src[1] === "a" || src[1] === "A") && + (src[2] === "t" || src[2] === "T") && + (src[3] === "a" || src[3] === "A") + ) && + !( + typeof srcSet === "string" && + srcSet[4] === ":" && + (srcSet[0] === "d" || srcSet[0] === "D") && + (srcSet[1] === "a" || srcSet[1] === "A") && + (srcSet[2] === "t" || srcSet[2] === "T") && + (srcSet[3] === "a" || srcSet[3] === "A") + ) ) { // We have a suspensey image and ought to preload it to optimize the loading of display blocking // resources. - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes; + var sizes = props.sizes; var key = getImagePreloadKey(src, srcSet, sizes); var resource = resources.preloadsMap.get(key); diff --git a/compiled/facebook-www/ReactDOMServer-dev.modern.js b/compiled/facebook-www/ReactDOMServer-dev.modern.js index 04f3f463f6001..ab73866505792 100644 --- a/compiled/facebook-www/ReactDOMServer-dev.modern.js +++ b/compiled/facebook-www/ReactDOMServer-dev.modern.js @@ -19,7 +19,7 @@ if (__DEV__) { var React = require("react"); var ReactDOM = require("react-dom"); -var ReactVersion = "18.3.0-www-modern-5b01b01a"; +var ReactVersion = "18.3.0-www-modern-d9bd2d78"; // This refers to a WWW module. var warningWWW = require("warning"); @@ -4518,16 +4518,33 @@ function getImagePreloadKey(href, imageSrcSet, imageSizes) { } function pushImg(target, props, resources) { + var src = props.src, + srcSet = props.srcSet; + if ( props.loading !== "lazy" && - typeof props.src === "string" && - props.fetchPriority !== "low" + (typeof src === "string" || typeof srcSet === "string") && + props.fetchPriority !== "low" && // We exclude data URIs in src and srcSet since these should not be preloaded + !( + typeof src === "string" && + src[4] === ":" && + (src[0] === "d" || src[0] === "D") && + (src[1] === "a" || src[1] === "A") && + (src[2] === "t" || src[2] === "T") && + (src[3] === "a" || src[3] === "A") + ) && + !( + typeof srcSet === "string" && + srcSet[4] === ":" && + (srcSet[0] === "d" || srcSet[0] === "D") && + (srcSet[1] === "a" || srcSet[1] === "A") && + (srcSet[2] === "t" || srcSet[2] === "T") && + (srcSet[3] === "a" || srcSet[3] === "A") + ) ) { // We have a suspensey image and ought to preload it to optimize the loading of display blocking // resources. - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes; + var sizes = props.sizes; var key = getImagePreloadKey(src, srcSet, sizes); var resource = resources.preloadsMap.get(key); diff --git a/compiled/facebook-www/ReactDOMServer-prod.classic.js b/compiled/facebook-www/ReactDOMServer-prod.classic.js index 667ceef157e21..4623f07fdcd09 100644 --- a/compiled/facebook-www/ReactDOMServer-prod.classic.js +++ b/compiled/facebook-www/ReactDOMServer-prod.classic.js @@ -1303,14 +1303,26 @@ function pushStartInstance( target$jscomp$0.push("\n"); return children$jscomp$6; case "img": + var src = props.src, + srcSet = props.srcSet; if ( "lazy" !== props.loading && - "string" === typeof props.src && - "low" !== props.fetchPriority + ("string" === typeof src || "string" === typeof srcSet) && + "low" !== props.fetchPriority && + ("string" !== typeof src || + ":" !== src[4] || + ("d" !== src[0] && "D" !== src[0]) || + ("a" !== src[1] && "A" !== src[1]) || + ("t" !== src[2] && "T" !== src[2]) || + ("a" !== src[3] && "A" !== src[3])) && + ("string" !== typeof srcSet || + ":" !== srcSet[4] || + ("d" !== srcSet[0] && "D" !== srcSet[0]) || + ("a" !== srcSet[1] && "A" !== srcSet[1]) || + ("t" !== srcSet[2] && "T" !== srcSet[2]) || + ("a" !== srcSet[3] && "A" !== srcSet[3])) ) { - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes, + var sizes = props.sizes, key$jscomp$1 = getImagePreloadKey(src, srcSet, sizes), resource$jscomp$1 = resources.preloadsMap.get(key$jscomp$1); resource$jscomp$1 || @@ -4115,4 +4127,4 @@ exports.renderToString = function (children, options) { 'The server used "renderToString" which does not support Suspense. If you intended for this Suspense boundary to render the fallback content on the server consider throwing an Error somewhere within the Suspense boundary. If you intended to have the server wait for the suspended component please switch to "renderToReadableStream" which supports Suspense on the server' ); }; -exports.version = "18.3.0-www-classic-93cba403"; +exports.version = "18.3.0-www-classic-ac75653d"; diff --git a/compiled/facebook-www/ReactDOMServer-prod.modern.js b/compiled/facebook-www/ReactDOMServer-prod.modern.js index 12db971c64967..e09fd60c6f3c6 100644 --- a/compiled/facebook-www/ReactDOMServer-prod.modern.js +++ b/compiled/facebook-www/ReactDOMServer-prod.modern.js @@ -1302,14 +1302,26 @@ function pushStartInstance( target$jscomp$0.push("\n"); return children$jscomp$6; case "img": + var src = props.src, + srcSet = props.srcSet; if ( "lazy" !== props.loading && - "string" === typeof props.src && - "low" !== props.fetchPriority + ("string" === typeof src || "string" === typeof srcSet) && + "low" !== props.fetchPriority && + ("string" !== typeof src || + ":" !== src[4] || + ("d" !== src[0] && "D" !== src[0]) || + ("a" !== src[1] && "A" !== src[1]) || + ("t" !== src[2] && "T" !== src[2]) || + ("a" !== src[3] && "A" !== src[3])) && + ("string" !== typeof srcSet || + ":" !== srcSet[4] || + ("d" !== srcSet[0] && "D" !== srcSet[0]) || + ("a" !== srcSet[1] && "A" !== srcSet[1]) || + ("t" !== srcSet[2] && "T" !== srcSet[2]) || + ("a" !== srcSet[3] && "A" !== srcSet[3])) ) { - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes, + var sizes = props.sizes, key$jscomp$1 = getImagePreloadKey(src, srcSet, sizes), resource$jscomp$1 = resources.preloadsMap.get(key$jscomp$1); resource$jscomp$1 || @@ -4013,4 +4025,4 @@ exports.renderToString = function (children, options) { 'The server used "renderToString" which does not support Suspense. If you intended for this Suspense boundary to render the fallback content on the server consider throwing an Error somewhere within the Suspense boundary. If you intended to have the server wait for the suspended component please switch to "renderToReadableStream" which supports Suspense on the server' ); }; -exports.version = "18.3.0-www-modern-ff434910"; +exports.version = "18.3.0-www-modern-85743cda"; diff --git a/compiled/facebook-www/ReactDOMServerStreaming-dev.modern.js b/compiled/facebook-www/ReactDOMServerStreaming-dev.modern.js index 4e507108a2eb2..b9ac7833b5577 100644 --- a/compiled/facebook-www/ReactDOMServerStreaming-dev.modern.js +++ b/compiled/facebook-www/ReactDOMServerStreaming-dev.modern.js @@ -4525,16 +4525,33 @@ function getImagePreloadKey(href, imageSrcSet, imageSizes) { } function pushImg(target, props, resources) { + var src = props.src, + srcSet = props.srcSet; + if ( props.loading !== "lazy" && - typeof props.src === "string" && - props.fetchPriority !== "low" + (typeof src === "string" || typeof srcSet === "string") && + props.fetchPriority !== "low" && // We exclude data URIs in src and srcSet since these should not be preloaded + !( + typeof src === "string" && + src[4] === ":" && + (src[0] === "d" || src[0] === "D") && + (src[1] === "a" || src[1] === "A") && + (src[2] === "t" || src[2] === "T") && + (src[3] === "a" || src[3] === "A") + ) && + !( + typeof srcSet === "string" && + srcSet[4] === ":" && + (srcSet[0] === "d" || srcSet[0] === "D") && + (srcSet[1] === "a" || srcSet[1] === "A") && + (srcSet[2] === "t" || srcSet[2] === "T") && + (srcSet[3] === "a" || srcSet[3] === "A") + ) ) { // We have a suspensey image and ought to preload it to optimize the loading of display blocking // resources. - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes; + var sizes = props.sizes; var key = getImagePreloadKey(src, srcSet, sizes); var resource = resources.preloadsMap.get(key); diff --git a/compiled/facebook-www/ReactDOMServerStreaming-prod.modern.js b/compiled/facebook-www/ReactDOMServerStreaming-prod.modern.js index ed82ca16ff365..0bff0e87c73b8 100644 --- a/compiled/facebook-www/ReactDOMServerStreaming-prod.modern.js +++ b/compiled/facebook-www/ReactDOMServerStreaming-prod.modern.js @@ -1332,14 +1332,26 @@ function pushStartInstance( target$jscomp$0.push("\n"); return children$jscomp$6; case "img": + var src = props.src, + srcSet = props.srcSet; if ( "lazy" !== props.loading && - "string" === typeof props.src && - "low" !== props.fetchPriority + ("string" === typeof src || "string" === typeof srcSet) && + "low" !== props.fetchPriority && + ("string" !== typeof src || + ":" !== src[4] || + ("d" !== src[0] && "D" !== src[0]) || + ("a" !== src[1] && "A" !== src[1]) || + ("t" !== src[2] && "T" !== src[2]) || + ("a" !== src[3] && "A" !== src[3])) && + ("string" !== typeof srcSet || + ":" !== srcSet[4] || + ("d" !== srcSet[0] && "D" !== srcSet[0]) || + ("a" !== srcSet[1] && "A" !== srcSet[1]) || + ("t" !== srcSet[2] && "T" !== srcSet[2]) || + ("a" !== srcSet[3] && "A" !== srcSet[3])) ) { - var src = props.src, - srcSet = props.srcSet, - sizes = props.sizes, + var sizes = props.sizes, key$jscomp$1 = getImagePreloadKey(src, srcSet, sizes), resource$jscomp$1 = resources.preloadsMap.get(key$jscomp$1); resource$jscomp$1 ||