diff options
Diffstat (limited to 'src/js')
| -rw-r--r-- | src/js/config/defaults.js | 1 | ||||
| -rw-r--r-- | src/js/plugins/ads.js | 29 | ||||
| -rw-r--r-- | src/js/plugins/previewThumbnails.js | 9 | 
3 files changed, 33 insertions, 6 deletions
| diff --git a/src/js/config/defaults.js b/src/js/config/defaults.js index 14019ca2..1bb940f8 100644 --- a/src/js/config/defaults.js +++ b/src/js/config/defaults.js @@ -404,6 +404,7 @@ const defaults = {      ads: {          enabled: false,          publisherId: '', +        tagUrl: '',      },      // YouTube nocookies mode diff --git a/src/js/plugins/ads.js b/src/js/plugins/ads.js index 375fdc13..c643c5dd 100644 --- a/src/js/plugins/ads.js +++ b/src/js/plugins/ads.js @@ -22,7 +22,7 @@ class Ads {       */      constructor(player) {          this.player = player; -        this.publisherId = player.config.ads.publisherId; +        this.config = player.config.ads;          this.playing = false;          this.initialized = false;          this.elements = { @@ -49,8 +49,13 @@ class Ads {      }      get enabled() { +        const { config } = this; +          return ( -            this.player.isHTML5 && this.player.isVideo && this.player.config.ads.enabled && !is.empty(this.publisherId) +            this.player.isHTML5 && +            this.player.isVideo && +            config.enabled && +            (!is.empty(config.publisherId) || is.url(config.tagUrl))          );      } @@ -95,8 +100,14 @@ class Ads {          this.setupIMA();      } -    // Build the default tag URL +    // Build the tag URL      get tagUrl() { +        const { config } = this; + +        if (is.url(config.tagUrl)) { +            return config.tagUrl; +        } +          const params = {              AV_PUBLISHERID: '58c25bb0073ef448b1087ad6',              AV_CHANNELID: '5a0458dc28a06145e4519d21', @@ -233,7 +244,7 @@ class Ads {                      const seekElement = this.player.elements.progress;                      if (is.element(seekElement)) { -                        const cuePercentage = 100 / this.player.duration * cuePoint; +                        const cuePercentage = (100 / this.player.duration) * cuePoint;                          const cue = createElement('span', {                              class: this.player.config.classNames.cues,                          }); @@ -273,6 +284,7 @@ class Ads {          // Retrieve the ad from the event. Some events (e.g. ALL_ADS_COMPLETED)          // don't have ad object associated          const ad = event.getAd(); +        const adData = event.getAdData();          // Proxy event          const dispatchEvent = type => { @@ -368,6 +380,12 @@ class Ads {                  dispatchEvent(event.type);                  break; +            case google.ima.AdEvent.Type.LOG: +                if (adData.adError) { +                    this.player.debug.warn(`Non-fatal ad error: ${adData.adError.getMessage()}`); +                } +                break; +              default:                  break;          } @@ -396,9 +414,8 @@ class Ads {              this.loader.contentComplete();          }); -        this.player.on('seeking', () => { +        this.player.on('timeupdate', () => {              time = this.player.currentTime; -            return time;          });          this.player.on('seeked', () => { diff --git a/src/js/plugins/previewThumbnails.js b/src/js/plugins/previewThumbnails.js index 053875c7..57b9265f 100644 --- a/src/js/plugins/previewThumbnails.js +++ b/src/js/plugins/previewThumbnails.js @@ -301,11 +301,20 @@ class PreviewThumbnails {          }          // Find the desired thumbnail index +        // TODO: Handle a video longer than the thumbs where thumbNum is null          const thumbNum = this.thumbnails[0].frames.findIndex(              frame => this.seekTime >= frame.startTime && this.seekTime <= frame.endTime,          ); +        const hasThumb = thumbNum >= 0;          let qualityIndex = 0; +        this.toggleThumbContainer(hasThumb); + +        // No matching thumb found +        if (!hasThumb) { +            return; +        } +          // Check to see if we've already downloaded higher quality versions of this image          this.thumbnails.forEach((thumbnail, index) => {              if (this.loadedImages.includes(thumbnail.frames[thumbNum].text)) { | 
