Merge pull request #963 from friday/verify-poster

Make sure poster element isn't shown if the image isn't loaded
This commit is contained in:
Sam Potts
2018-05-19 11:27:52 +10:00
committed by GitHub
7 changed files with 68 additions and 21 deletions

View File

@ -120,6 +120,21 @@ const utils = {
});
},
// Load image avoiding xhr/fetch CORS issues
// Server status can't be obtained this way unfortunately, so this uses "naturalWidth" to determine if the image has loaded.
// By default it checks if it is at least 1px, but you can add a second argument to change this.
loadImage(src, minWidth = 1) {
return new Promise((resolve, reject) => {
const image = new Image();
const handler = () => {
delete image.onload;
delete image.onerror;
(image.naturalWidth >= minWidth ? resolve : reject)(image);
};
Object.assign(image, {onload: handler, onerror: handler, src});
});
},
// Load an external script
loadScript(url) {
return new Promise((resolve, reject) => {