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' // 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 img = new Image();
const canvas = document.createElement('canvas'); const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d'); const ctx = canvas.getContext('2d');
return new Promise(resolve => { return new Promise(resolve => {
// Single pixel base64 image renders fine on iOS 10.3??? // 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 = src;
img.src = "";
const onload = () => { const onload = () => {
try { try {
@ -90,9 +89,11 @@ const FEATURES = {
// $FlowFixMe - get/set properties not yet supported // $FlowFixMe - get/set properties not yet supported
get SUPPORT_BASE64_DRAWING() { get SUPPORT_BASE64_DRAWING() {
'use strict'; 'use strict';
const value = testBase64(document); return (src: string) => {
Object.defineProperty(FEATURES, 'SUPPORT_BASE64_DRAWING', {value}); const value = testBase64(document, src);
Object.defineProperty(FEATURES, 'SUPPORT_BASE64_DRAWING', {value: () => value});
return value; return value;
};
} }
}; };

View File

@ -80,8 +80,10 @@ export default class ImageLoader {
}); });
}; };
this.cache[key] = isInlineImage(src) this.cache[key] =
? FEATURES.SUPPORT_BASE64_DRAWING.then(imageLoadHandler) isInlineImage(src) && !isSVG(src)
// $FlowFixMe
? FEATURES.SUPPORT_BASE64_DRAWING(src).then(imageLoadHandler)
: imageLoadHandler(true); : imageLoadHandler(true);
return key; return key;
} }