Fix base64 images for ios 10.3

This commit is contained in:
Niklas von Hertzen 2017-08-16 19:50:05 +08:00
parent 8999c76181
commit d77301a353
2 changed files with 12 additions and 9 deletions

View File

@ -26,15 +26,14 @@ const testRangeBounds = document => {
};
// iOS 10.3 taints canvas with base64 images unless crossOrigin = 'anonymous'
const testBase64 = (document: Document): Promise<boolean> => {
const testBase64 = (document: Document, src: string): Promise<boolean> => {
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;
};
}
};

View File

@ -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;
}