diff options
| author | Arthur Hulsman <a.hulsman@orangegames.com> | 2018-03-09 11:17:24 +0100 | 
|---|---|---|
| committer | Arthur Hulsman <a.hulsman@orangegames.com> | 2018-03-09 11:17:24 +0100 | 
| commit | 69ffcbad27353bfd0238ba7e79e6caf3835b0efd (patch) | |
| tree | e00c67db6a7741113c34c37c36166c3e427f9f6f /src/js | |
| parent | 819f7d1080ef2748fa1c123ad0f54d075c654ab9 (diff) | |
| download | plyr-69ffcbad27353bfd0238ba7e79e6caf3835b0efd.tar.lz plyr-69ffcbad27353bfd0238ba7e79e6caf3835b0efd.tar.xz plyr-69ffcbad27353bfd0238ba7e79e6caf3835b0efd.zip | |
Ad block detection would not work when calling play() right after creating the player instance, so the adsManager now also rejects on such a case. Also made sure that calling play() will wait for the adsManager promise to resolve or otherwise return the media.play() method.
Diffstat (limited to 'src/js')
| -rw-r--r-- | src/js/plugins/ads.js | 67 | ||||
| -rw-r--r-- | src/js/plyr.js | 7 | 
2 files changed, 35 insertions, 39 deletions
| diff --git a/src/js/plugins/ads.js b/src/js/plugins/ads.js index eca523f7..cc11fa13 100644 --- a/src/js/plugins/ads.js +++ b/src/js/plugins/ads.js @@ -35,35 +35,6 @@ class Ads {          this.enabled = player.config.ads.enabled;          this.playing = false;          this.initialized = false; -        this.blocked = false; - -        // Check if ads are enabled. -        if (!this.enabled) { -            return; -        } - -        // Check if the Google IMA3 SDK is loaded or load it ourselves -        if (!utils.is.object(window.google)) { -            utils.loadScript( -                player.config.urls.googleIMA.api, -                () => { -                    this.ready(); -                }, -                () => { -                    // Script failed to load or is blocked -                    this.blocked = true; -                    this.player.debug.log('Ads error: Google IMA SDK failed to load'); -                }, -            ); -        } else { -            this.ready(); -        } -    } - -    /** -     * Get the ads instance ready. -     */ -    ready() {          this.elements = {              container: null,              displayContainer: null, @@ -75,26 +46,50 @@ class Ads {          this.safetyTimer = null;          this.countdownTimer = null; -        // Set listeners on the Plyr instance -        this.listeners(); - -        // Start ticking our safety timer. If the whole advertisement -        // thing doesn't resolve within our set time; we bail -        this.startSafetyTimer(12000, 'ready()'); +        if (this.enabled) { +            // Check if the Google IMA3 SDK is loaded or load it ourselves +            if (!utils.is.object(window.google)) { +                utils.loadScript( +                    player.config.urls.googleIMA.api, +                    () => { +                        this.ready(); +                    }, +                    () => { +                        // Script failed to load or is blocked +                        this.handleEventListeners('ERROR'); +                        this.player.debug.log('Ads error: Google IMA SDK failed to load'); +                    }, +                ); +            } else { +                this.ready(); +            } +        } -        // Setup a promise to resolve if the IMA manager is ready +        // Setup a promise to resolve when the IMA manager is ready          this.managerPromise = new Promise((resolve, reject) => {              // The ad is pre-loaded and ready              this.on('ADS_MANAGER_LOADED', () => resolve());              // Ads failed              this.on('ERROR', () => reject());          }); +    } + +    /** +     * Get the ads instance ready. +     */ +    ready() { +        // Start ticking our safety timer. If the whole advertisement +        // thing doesn't resolve within our set time; we bail +        this.startSafetyTimer(12000, 'ready()');          // Clear the safety timer          this.managerPromise.then(() => {              this.clearSafetyTimer('onAdsManagerLoaded()');          }); +        // Set listeners on the Plyr instance +        this.listeners(); +          // Setup the IMA SDK          this.setupIMA();      } diff --git a/src/js/plyr.js b/src/js/plyr.js index 9b73423e..d4c3d392 100644 --- a/src/js/plyr.js +++ b/src/js/plyr.js @@ -309,14 +309,15 @@ class Plyr {       * Play the media, or play the advertisement (if they are not blocked)       */      play() { -        if (this.ads.enabled && !this.ads.initialized && !this.ads.blocked) { +        // Return the promise (for HTML5) +        if (this.ads.enabled && !this.ads.initialized) {              this.ads.managerPromise.then(() => {                  this.ads.play();              }).catch(() => { -                this.media.play(); +                return this.media.play();              });          } else { -            this.media.play(); +            return this.media.play();          }      } | 
