From d77301a3531271c062981967f2f2656d8f75bbbb Mon Sep 17 00:00:00 2001 From: Niklas von Hertzen Date: Wed, 16 Aug 2017 19:50:05 +0800 Subject: [PATCH] Fix base64 images for ios 10.3 --- src/Feature.js | 13 +++++++------ src/ImageLoader.js | 8 +++++--- 2 files changed, 12 insertions(+), 9 deletions(-) diff --git a/src/Feature.js b/src/Feature.js index 1b467f2..3679e78 100644 --- a/src/Feature.js +++ b/src/Feature.js @@ -26,15 +26,14 @@ const testRangeBounds = document => { }; // iOS 10.3 taints canvas with base64 images unless crossOrigin = 'anonymous' -const testBase64 = (document: Document): Promise => { +const testBase64 = (document: Document, src: string): Promise => { const img = new Image(); const canvas = document.createElement('canvas'); const ctx = canvas.getContext('2d'); return new Promise(resolve => { // Single pixel base64 image renders fine on iOS 10.3??? - // TODO add a smaller base64 image that still fails on iOS 10.3 - img.src = ""; + img.src = src; const onload = () => { try { @@ -90,9 +89,11 @@ const FEATURES = { // $FlowFixMe - get/set properties not yet supported get SUPPORT_BASE64_DRAWING() { 'use strict'; - const value = testBase64(document); - Object.defineProperty(FEATURES, 'SUPPORT_BASE64_DRAWING', {value}); - return value; + return (src: string) => { + const value = testBase64(document, src); + Object.defineProperty(FEATURES, 'SUPPORT_BASE64_DRAWING', {value: () => value}); + return value; + }; } }; diff --git a/src/ImageLoader.js b/src/ImageLoader.js index 3a6736a..982e230 100644 --- a/src/ImageLoader.js +++ b/src/ImageLoader.js @@ -80,9 +80,11 @@ export default class ImageLoader { }); }; - this.cache[key] = isInlineImage(src) - ? FEATURES.SUPPORT_BASE64_DRAWING.then(imageLoadHandler) - : imageLoadHandler(true); + this.cache[key] = + isInlineImage(src) && !isSVG(src) + // $FlowFixMe + ? FEATURES.SUPPORT_BASE64_DRAWING(src).then(imageLoadHandler) + : imageLoadHandler(true); return key; }