videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular 2.0
223 lines • 35.9 kB
JavaScript
"use strict";
///<reference path='./google.ima.ts'/>
var core_1 = require('@angular/core');
var vg_api_1 = require('../core/services/vg-api');
var vg_events_1 = require('../core/events/vg-events');
var vg_fullscreen_api_1 = require('../core/services/vg-fullscreen-api');
var VgImaAds = (function () {
function VgImaAds(ref, API, fsAPI) {
this.API = API;
this.fsAPI = fsAPI;
this.isFullscreen = false;
this.subscriptions = [];
this.displayState = 'none';
this.elem = ref.nativeElement;
this.onContentEnded = this.onContentEnded.bind(this);
}
VgImaAds.prototype.ngOnInit = function () {
var _this = this;
if (this.API.isPlayerReady) {
this.onPlayerReady();
}
else {
this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); }));
}
};
VgImaAds.prototype.onPlayerReady = function () {
if (typeof google === "undefined") {
this.onMissingGoogleImaLoader();
return;
}
this.target = this.API.getMediaById(this.vgFor);
this.initializations();
this.subscriptions.push(this.target.subscriptions.ended.subscribe(this.onContentEnded.bind(this)));
this.subscriptions.push(this.target.subscriptions.play.subscribe(this.onUpdateState.bind(this)));
this.subscriptions.push(this.fsAPI.onChangeFullscreen.subscribe(this.onChangeFullscreen.bind(this)));
this.ima.adsLoader.addEventListener(google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED, this.onAdsManagerLoaded.bind(this), false);
this.ima.adsLoader.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, this.onAdError.bind(this), false);
this.loadAds();
};
VgImaAds.prototype.initializations = function () {
var _this = this;
this.ima = new Ima(this.elem);
if (this.vgSkipButton) {
this.skipButton = document.querySelector(this.vgSkipButton);
this.skipButton.style.display = 'none';
this.skipButton.addEventListener('click', this.onClickSkip.bind(this));
this.elem.insertBefore(this.skipButton, this.elem.firstChild);
}
window.addEventListener('resize', function () {
var w = _this.API.videogularElement.offsetWidth;
var h = _this.API.videogularElement.offsetHeight;
if (_this.ima.adsManager) {
if (_this.isFullscreen) {
_this.ima.adsManager.resize(w, h, google.ima.ViewMode.FULLSCREEN);
}
else {
_this.ima.adsManager.resize(w, h, google.ima.ViewMode.NORMAL);
}
}
});
};
VgImaAds.prototype.loadAds = function () {
var _this = this;
if (this.vgCompanion) {
googletag.cmd.push(function () {
var adUnitPath = '/' + _this.vgNetwork + '/' + _this.vgUnitPath;
var slot = googletag.defineSlot(adUnitPath, _this.vgCompanionSize, _this.vgCompanion);
if (slot) {
slot.addService(googletag.companionAds());
slot.addService(googletag.pubads());
googletag
.companionAds()
.setRefreshUnfilledSlots(true);
googletag
.pubads()
.enableVideoAds();
googletag.enableServices();
}
});
}
};
VgImaAds.prototype.onUpdateState = function (event) {
switch (event.type) {
case vg_events_1.VgEvents.VG_PLAY:
if (!this.ima.adsLoaded) {
this.API.pause();
this.ima.adDisplayContainer.initialize();
this.requestAds(this.vgAdTagUrl);
this.ima.adsLoaded = true;
}
break;
}
};
VgImaAds.prototype.requestAds = function (adTagUrl) {
// Show only to get computed style in pixels
this.show();
var adsRequest = new google.ima.AdsRequest();
var computedStyle = window.getComputedStyle(this.elem);
adsRequest.adTagUrl = adTagUrl;
adsRequest.linearAdSlotWidth = parseInt(computedStyle.width, 10);
adsRequest.linearAdSlotHeight = parseInt(computedStyle.height, 10);
adsRequest.nonLinearAdSlotWidth = parseInt(computedStyle.width, 10);
adsRequest.nonLinearAdSlotHeight = parseInt(computedStyle.height, 10);
this.ima.adsLoader.requestAds(adsRequest);
};
VgImaAds.prototype.onAdsManagerLoaded = function (evt) {
this.show();
this.ima.adsManager = evt.getAdsManager(this.target);
this.processAdsManager(this.ima.adsManager);
};
VgImaAds.prototype.processAdsManager = function (adsManager) {
var w = this.API.videogularElement.offsetWidth;
var h = this.API.videogularElement.offsetHeight;
// Attach the pause/resume events.
this.ima.adsManager.addEventListener(google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED, this.onContentPauseRequested.bind(this), false);
this.ima.adsManager.addEventListener(google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED, this.onContentResumeRequested.bind(this), false);
this.ima.adsManager.addEventListener(google.ima.AdEvent.Type.SKIPPABLE_STATE_CHANGED, this.onSkippableStateChanged.bind(this), false);
this.ima.adsManager.addEventListener(google.ima.AdEvent.Type.ALL_ADS_COMPLETED, this.onAllAdsComplete.bind(this), false);
this.ima.adsManager.addEventListener(google.ima.AdEvent.Type.COMPLETE, this.onAdComplete.bind(this), false);
this.ima.adsManager.addEventListener(google.ima.AdErrorEvent.Type.AD_ERROR, this.onAdError.bind(this), false);
this.ima.adsManager.init(w, h, google.ima.ViewMode.NORMAL);
this.ima.adsManager.start();
};
VgImaAds.prototype.onSkippableStateChanged = function () {
var isSkippable = this.ima.adsManager.getAdSkippableState();
if (isSkippable) {
this.skipButton.style.display = 'block';
}
else {
this.skipButton.style.display = 'none';
}
};
VgImaAds.prototype.onClickSkip = function () {
this.ima.adsManager.skip();
};
VgImaAds.prototype.onContentPauseRequested = function () {
this.show();
this.API.pause();
};
VgImaAds.prototype.onContentResumeRequested = function () {
this.API.play();
this.hide();
};
VgImaAds.prototype.onAdError = function (evt) {
if (this.ima.adsManager) {
this.ima.adsManager.destroy();
}
this.hide();
this.API.play();
};
VgImaAds.prototype.onAllAdsComplete = function () {
this.hide();
// The last ad was a post-roll
if (this.ima.adsManager.getCuePoints().join().indexOf('-1') >= 0) {
this.API.pause(); // it was stop() in Videogular v1
}
};
VgImaAds.prototype.onAdComplete = function () {
// TODO: Update view with current ad count
this.ima.currentAd++;
};
VgImaAds.prototype.show = function () {
window.dispatchEvent(new CustomEvent(vg_events_1.VgEvents.VG_START_ADS));
this.displayState = 'block';
};
VgImaAds.prototype.hide = function () {
window.dispatchEvent(new CustomEvent(vg_events_1.VgEvents.VG_END_ADS));
this.displayState = 'none';
};
VgImaAds.prototype.onContentEnded = function () {
this.ima.adsLoader.contentComplete();
};
VgImaAds.prototype.onChangeFullscreen = function (fsState) {
if (!this.fsAPI.nativeFullscreen) {
this.isFullscreen = fsState;
}
};
VgImaAds.prototype.onMissingGoogleImaLoader = function () {
this.hide();
this.API.play();
};
VgImaAds.prototype.ngOnDestroy = function () {
this.subscriptions.forEach(function (s) { return s.unsubscribe(); });
};
VgImaAds.decorators = [
{ type: core_1.Component, args: [{
selector: 'vg-ima-ads',
encapsulation: core_1.ViewEncapsulation.None,
template: "<div class=\"vg-ima-ads\"></div>",
styles: ["\n vg-ima-ads {\n position: absolute;\n width: 100%;\n height: 100%;\n z-index: 300;\n }\n vg-ima-ads .vg-ima-ads {\n position: absolute;\n width: 100%;\n height: 100%;\n pointer-events: none;\n }\n "]
},] },
];
/** @nocollapse */
VgImaAds.ctorParameters = [
{ type: core_1.ElementRef, },
{ type: vg_api_1.VgAPI, },
{ type: vg_fullscreen_api_1.VgFullscreenAPI, },
];
VgImaAds.propDecorators = {
'vgFor': [{ type: core_1.Input },],
'vgNetwork': [{ type: core_1.Input },],
'vgUnitPath': [{ type: core_1.Input },],
'vgCompanion': [{ type: core_1.Input },],
'vgCompanionSize': [{ type: core_1.Input },],
'vgAdTagUrl': [{ type: core_1.Input },],
'vgSkipButton': [{ type: core_1.Input },],
'displayState': [{ type: core_1.HostBinding, args: ['style.display',] },],
};
return VgImaAds;
}());
exports.VgImaAds = VgImaAds;
var Ima = (function () {
function Ima(imaAdsElement) {
this.adDisplayContainer = new google.ima.AdDisplayContainer(imaAdsElement);
this.adsLoader = new google.ima.AdsLoader(this.adDisplayContainer);
this.adsManager = null;
this.adsLoaded = false;
this.currentAd = 0;
}
return Ima;
}());
exports.Ima = Ima;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-ima-ads.js","sourceRoot":"","sources":["vg-ima-ads.ts"],"names":[],"mappings":"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","sourcesContent":["///<reference path='./google.ima.ts'/>\nimport { Component, ElementRef, Input, HostBinding, ViewEncapsulation, OnInit, OnDestroy } from '@angular/core';\nimport { IPlayable } from '../core/vg-media/i-playable';\nimport { VgAPI } from '../core/services/vg-api';\nimport { VgEvents } from '../core/events/vg-events';\nimport { VgFullscreenAPI } from '../core/services/vg-fullscreen-api';\nimport { Subscription } from 'rxjs/Subscription';\n\n\nexport class VgImaAds implements OnInit, OnDestroy {\n     vgFor: string;\n     vgNetwork: string;\n     vgUnitPath: string;\n     vgCompanion: string;\n     vgCompanionSize: Array<Number>;\n     vgAdTagUrl: string;\n     vgSkipButton: string;\n\n    elem: HTMLElement;\n    target: IPlayable;\n    ima: Ima;\n    isFullscreen: boolean = false;\n    skipButton: HTMLElement;\n\n    subscriptions: Subscription[] = [];\n\n     displayState: string = 'none';\n\n    constructor(ref: ElementRef, public API: VgAPI, public fsAPI: VgFullscreenAPI) {\n        this.elem = ref.nativeElement;\n        this.onContentEnded = this.onContentEnded.bind(this);\n    }\n\n    ngOnInit() {\n        if (this.API.isPlayerReady) {\n            this.onPlayerReady();\n        }\n        else {\n            this.subscriptions.push(this.API.playerReadyEvent.subscribe(() => this.onPlayerReady()));\n        }\n    }\n\n    onPlayerReady() {\n        if (typeof google === \"undefined\") {\n            this.onMissingGoogleImaLoader();\n            return;\n        }\n\n        this.target = this.API.getMediaById(this.vgFor);\n\n        this.initializations();\n\n        this.subscriptions.push(this.target.subscriptions.ended.subscribe(this.onContentEnded.bind(this)));\n        this.subscriptions.push(this.target.subscriptions.play.subscribe(this.onUpdateState.bind(this)));\n\n        this.subscriptions.push(this.fsAPI.onChangeFullscreen.subscribe(this.onChangeFullscreen.bind(this)));\n\n        this.ima.adsLoader.addEventListener(\n            google.ima.AdsManagerLoadedEvent.Type.ADS_MANAGER_LOADED,\n            this.onAdsManagerLoaded.bind(this),\n            false\n        );\n        this.ima.adsLoader.addEventListener(\n            google.ima.AdErrorEvent.Type.AD_ERROR,\n            this.onAdError.bind(this),\n            false\n        );\n\n        this.loadAds();\n    }\n\n    initializations() {\n        this.ima = new Ima(this.elem);\n\n        if (this.vgSkipButton) {\n            this.skipButton = document.querySelector(this.vgSkipButton) as HTMLElement;\n            this.skipButton.style.display = 'none';\n            this.skipButton.addEventListener('click', this.onClickSkip.bind(this));\n            this.elem.insertBefore(this.skipButton, this.elem.firstChild);\n        }\n\n        window.addEventListener('resize', () => {\n            const w = this.API.videogularElement.offsetWidth;\n            const h = this.API.videogularElement.offsetHeight;\n\n            if (this.ima.adsManager) {\n                if (this.isFullscreen) {\n                    this.ima.adsManager.resize(w, h, google.ima.ViewMode.FULLSCREEN);\n                }\n                else {\n                    this.ima.adsManager.resize(w, h, google.ima.ViewMode.NORMAL);\n                }\n            }\n        });\n    }\n\n    loadAds() {\n        if (this.vgCompanion) {\n            googletag.cmd.push(\n                () => {\n                    const adUnitPath: string = '/' + this.vgNetwork + '/' + this.vgUnitPath;\n                    const slot: googletag.Slot = googletag.defineSlot(adUnitPath, this.vgCompanionSize, this.vgCompanion);\n\n                    if (slot) {\n                        slot.addService(googletag.companionAds());\n                        slot.addService(googletag.pubads());\n\n                        googletag\n                            .companionAds()\n                            .setRefreshUnfilledSlots(true);\n\n                        googletag\n                            .pubads()\n                            .enableVideoAds();\n\n                        googletag.enableServices();\n                    }\n                }\n            );\n        }\n    }\n\n    onUpdateState(event: any) {\n        switch (event.type) {\n            case VgEvents.VG_PLAY:\n                if (!this.ima.adsLoaded) {\n                    this.API.pause();\n                    this.ima.adDisplayContainer.initialize();\n                    this.requestAds(this.vgAdTagUrl);\n                    this.ima.adsLoaded = true;\n                }\n                break;\n        }\n    }\n\n    requestAds(adTagUrl: string) {\n        // Show only to get computed style in pixels\n        this.show();\n\n        const adsRequest = new google.ima.AdsRequest();\n        const computedStyle = window.getComputedStyle(this.elem);\n        adsRequest.adTagUrl = adTagUrl;\n\n        adsRequest.linearAdSlotWidth = parseInt(computedStyle.width, 10);\n        adsRequest.linearAdSlotHeight = parseInt(computedStyle.height, 10);\n        adsRequest.nonLinearAdSlotWidth = parseInt(computedStyle.width, 10);\n        adsRequest.nonLinearAdSlotHeight = parseInt(computedStyle.height, 10);\n\n        this.ima.adsLoader.requestAds(adsRequest);\n    }\n\n    onAdsManagerLoaded(evt: google.ima.AdsManagerLoadedEvent) {\n        this.show();\n        this.ima.adsManager = evt.getAdsManager(this.target);\n        this.processAdsManager(this.ima.adsManager);\n    }\n\n    processAdsManager(adsManager: google.ima.AdsManager) {\n        const w = this.API.videogularElement.offsetWidth;\n        const h = this.API.videogularElement.offsetHeight;\n\n        // Attach the pause/resume events.\n        this.ima.adsManager.addEventListener(\n            google.ima.AdEvent.Type.CONTENT_PAUSE_REQUESTED,\n            this.onContentPauseRequested.bind(this),\n            false\n        );\n        this.ima.adsManager.addEventListener(\n            google.ima.AdEvent.Type.CONTENT_RESUME_REQUESTED,\n            this.onContentResumeRequested.bind(this),\n            false\n        );\n        this.ima.adsManager.addEventListener(\n            google.ima.AdEvent.Type.SKIPPABLE_STATE_CHANGED,\n            this.onSkippableStateChanged.bind(this),\n            false\n        );\n        this.ima.adsManager.addEventListener(\n            google.ima.AdEvent.Type.ALL_ADS_COMPLETED,\n            this.onAllAdsComplete.bind(this),\n            false\n        );\n        this.ima.adsManager.addEventListener(\n            google.ima.AdEvent.Type.COMPLETE,\n            this.onAdComplete.bind(this),\n            false\n        );\n        this.ima.adsManager.addEventListener(\n            google.ima.AdErrorEvent.Type.AD_ERROR,\n            this.onAdError.bind(this),\n            false\n        );\n\n        this.ima.adsManager.init(w, h, google.ima.ViewMode.NORMAL);\n        this.ima.adsManager.start();\n    }\n\n    onSkippableStateChanged() {\n        const isSkippable = this.ima.adsManager.getAdSkippableState();\n\n        if (isSkippable) {\n            this.skipButton.style.display = 'block';\n        } else {\n            this.skipButton.style.display = 'none';\n        }\n    }\n\n    onClickSkip() {\n        this.ima.adsManager.skip();\n    }\n\n    onContentPauseRequested() {\n        this.show();\n        this.API.pause();\n    }\n\n    onContentResumeRequested() {\n        this.API.play();\n        this.hide();\n    }\n\n    onAdError(evt) {\n        if (this.ima.adsManager) {\n            this.ima.adsManager.destroy();\n        }\n        this.hide();\n        this.API.play();\n    }\n\n    onAllAdsComplete() {\n        this.hide();\n        // The last ad was a post-roll\n        if (this.ima.adsManager.getCuePoints().join().indexOf('-1') >= 0) {\n            this.API.pause(); // it was stop() in Videogular v1\n        }\n    }\n\n    onAdComplete() {\n        // TODO: Update view with current ad count\n        this.ima.currentAd++;\n    }\n\n    show() {\n        window.dispatchEvent(new CustomEvent(VgEvents.VG_START_ADS));\n        this.displayState = 'block';\n    }\n\n    hide() {\n        window.dispatchEvent(new CustomEvent(VgEvents.VG_END_ADS));\n        this.displayState = 'none';\n    }\n\n    onContentEnded() {\n        this.ima.adsLoader.contentComplete();\n    }\n\n    onChangeFullscreen(fsState: boolean) {\n        if (!this.fsAPI.nativeFullscreen) {\n            this.isFullscreen = fsState;\n        }\n    }\n\n    private onMissingGoogleImaLoader() {\n        this.hide();\n        this.API.play();\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\nstatic decorators: DecoratorInvocation[] = [\n{ type: Component, args: [{\n    selector: 'vg-ima-ads',\n    encapsulation: ViewEncapsulation.None,\n    template: `<div class=\"vg-ima-ads\"></div>`,\n    styles: [ `\n        vg-ima-ads {\n            position: absolute;\n            width: 100%;\n            height: 100%;\n            z-index: 300;\n        }\n        vg-ima-ads .vg-ima-ads {\n            position: absolute;\n            width: 100%;\n            height: 100%;\n            pointer-events: none;\n        }\n    ` ]\n}, ] },\n];\n/** @nocollapse */\nstatic ctorParameters: ({type: any, decorators?: DecoratorInvocation[]}|null)[] = [\n{type: ElementRef, },\n{type: VgAPI, },\n{type: VgFullscreenAPI, },\n];\nstatic propDecorators: {[key: string]: DecoratorInvocation[]} = {\n'vgFor': [{ type: Input },],\n'vgNetwork': [{ type: Input },],\n'vgUnitPath': [{ type: Input },],\n'vgCompanion': [{ type: Input },],\n'vgCompanionSize': [{ type: Input },],\n'vgAdTagUrl': [{ type: Input },],\n'vgSkipButton': [{ type: Input },],\n'displayState': [{ type: HostBinding, args: ['style.display', ] },],\n};\n}\n\n\nexport class Ima {\n    adDisplayContainer: google.ima.AdDisplayContainer;\n    adsLoader: google.ima.AdsLoader;\n    adsManager: google.ima.AdsManager;\n    adsLoaded: boolean;\n    currentAd: number;\n\n    constructor(imaAdsElement: HTMLElement) {\n        this.adDisplayContainer = new google.ima.AdDisplayContainer(imaAdsElement);\n        this.adsLoader = new google.ima.AdsLoader(this.adDisplayContainer);\n\n        this.adsManager = null;\n        this.adsLoaded = false;\n        this.currentAd = 0;\n    }\n}\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}