diff options
| author | Albin Larsson <mail@albinlarsson.com> | 2018-05-15 05:16:06 +0200 | 
|---|---|---|
| committer | Albin Larsson <mail@albinlarsson.com> | 2018-05-15 16:21:36 +0200 | 
| commit | 16c3a7d9e5be8ed2ffbbcee1c786b88d1cecc4cd (patch) | |
| tree | 2620f3e4572e08b69c18a8adab654d39f6582585 /src/js | |
| parent | 90d5b48845661ce99a204354f93fbbbc7a19f100 (diff) | |
| download | plyr-16c3a7d9e5be8ed2ffbbcee1c786b88d1cecc4cd.tar.lz plyr-16c3a7d9e5be8ed2ffbbcee1c786b88d1cecc4cd.tar.xz plyr-16c3a7d9e5be8ed2ffbbcee1c786b88d1cecc4cd.zip | |
Rewrite ui.setPoster to check that images arent broken or youtube fallback images. Only show poster element when valid
Diffstat (limited to 'src/js')
| -rw-r--r-- | src/js/defaults.js | 2 | ||||
| -rw-r--r-- | src/js/plugins/vimeo.js | 7 | ||||
| -rw-r--r-- | src/js/plugins/youtube.js | 8 | ||||
| -rw-r--r-- | src/js/plyr.js | 5 | ||||
| -rw-r--r-- | src/js/ui.js | 39 | 
5 files changed, 41 insertions, 20 deletions
| diff --git a/src/js/defaults.js b/src/js/defaults.js index f160b1aa..7cc5c082 100644 --- a/src/js/defaults.js +++ b/src/js/defaults.js @@ -199,7 +199,6 @@ const defaults = {          youtube: {              sdk: 'https://www.youtube.com/iframe_api',              api: 'https://www.googleapis.com/youtube/v3/videos?id={0}&key={1}&fields=items(snippet(title))&part=snippet', -            poster: 'https://img.youtube.com/vi/{0}/maxresdefault.jpg,https://img.youtube.com/vi/{0}/hqdefault.jpg',          },          googleIMA: {              sdk: 'https://imasdk.googleapis.com/js/sdkloader/ima3.js', @@ -332,6 +331,7 @@ const defaults = {          embed: 'plyr__video-embed',          embedContainer: 'plyr__video-embed__container',          poster: 'plyr__poster', +        posterEnabled: 'plyr__poster-enabled',          ads: 'plyr__ads',          control: 'plyr__control',          playing: 'plyr--playing', diff --git a/src/js/plugins/vimeo.js b/src/js/plugins/vimeo.js index 0ceb89e5..96b36781 100644 --- a/src/js/plugins/vimeo.js +++ b/src/js/plugins/vimeo.js @@ -99,11 +99,8 @@ const vimeo = {              // Get original image              url.pathname = `${url.pathname.split('_')[0]}.jpg`; -            // Set attribute -            player.media.setAttribute('poster', url.href); - -            // Update -            ui.setPoster.call(player); +            // Set and show poster +            ui.setPoster.call(player, url.href);          });          // Setup instance diff --git a/src/js/plugins/youtube.js b/src/js/plugins/youtube.js index 4fde9319..4ba8089b 100644 --- a/src/js/plugins/youtube.js +++ b/src/js/plugins/youtube.js @@ -162,7 +162,13 @@ const youtube = {          player.media = utils.replaceElement(container, player.media);          // Set poster image -        player.media.setAttribute('poster', utils.format(player.config.urls.youtube.poster, videoId)); +        const posterSrc = format => `https://img.youtube.com/vi/${videoId}/${format}default.jpg`; + +        // Check thumbnail images in order of quality, but reject fallback thumbnails (120px wide) +        utils.loadImage(posterSrc('maxres'), 121) // Higest quality and unpadded +            .catch(() => utils.loadImage(posterSrc('sd'), 121)) // 480p padded 4:3 +            .catch(() => utils.loadImage(posterSrc('hq'))) // 360p padded 4:3. Always exists +            .then(image => ui.setPoster.call(player, image.src));          // Setup instance          // https://developers.google.com/youtube/iframe_api_reference diff --git a/src/js/plyr.js b/src/js/plyr.js index 6a3deade..dee90dd2 100644 --- a/src/js/plyr.js +++ b/src/js/plyr.js @@ -801,10 +801,7 @@ class Plyr {              return;          } -        if (utils.is.string(input)) { -            this.media.setAttribute('poster', input); -            ui.setPoster.call(this); -        } +        ui.setPoster.call(this, input);      }      /** diff --git a/src/js/ui.js b/src/js/ui.js index 2347b5c8..50764a86 100644 --- a/src/js/ui.js +++ b/src/js/ui.js @@ -105,8 +105,10 @@ const ui = {          // Set the title          ui.setTitle.call(this); -        // Set the poster image -        ui.setPoster.call(this); +        // Assure the poster image is set, if the property was added before the UI was created +        if (this.poster) { +            ui.setPoster.call(this, this.poster); +        }      },      // Setup aria attribute for play and iframe title @@ -146,15 +148,34 @@ const ui = {          }      }, -    // Set the poster image -    setPoster() { -        if (!utils.is.element(this.elements.poster) || utils.is.empty(this.poster)) { -            return; +    // Toggle poster +    togglePoster(enable) { +        utils.toggleClass(this.elements.container, this.config.classNames.posterEnabled, enable); +    }, + +    // Set the poster image (async) +    setPoster(poster) { +        // Set property regardless of validity +        this.media.setAttribute('poster', poster); + +        // Bail if element is missing +        if (!utils.is.element(this.elements.poster)) { +            return Promise.reject();          } -        // Set the inline style -        const posters = this.poster.split(','); -        this.elements.poster.style.backgroundImage = posters.map(p => `url('${p}')`).join(','); +        // Load the image, and set poster if successful +        const loadPromise = utils.loadImage(poster) +            .then(() => { +                this.elements.poster.style.backgroundImage = `url('${poster}')`; +                ui.togglePoster.call(this, true); +                return poster; +            }); + +        // Hide the element if the poster can't be loaded (otherwise it will just be a black element covering the video) +        loadPromise.catch(() => ui.togglePoster.call(this, false)); + +        // Return the promise so the caller can use it as well +        return loadPromise;      },      // Check playing state | 
