videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular
274 lines • 37.7 kB
JavaScript
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
Object.defineProperty(exports, "__esModule", { value: true });
///<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 = /** @class */ (function () {
function VgImaAds(ref, API, fsAPI) {
this.API = API;
this.fsAPI = fsAPI;
this.onAdStart = new core_1.EventEmitter();
this.onAdStop = new core_1.EventEmitter();
this.onSkipAd = new core_1.EventEmitter();
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);
};
// @ts-ignore
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();
this.onSkipAd.emit(true);
};
VgImaAds.prototype.onContentPauseRequested = function () {
this.show();
this.API.pause();
this.onAdStop.emit(true);
};
VgImaAds.prototype.onContentResumeRequested = function () {
this.API.play();
this.onAdStart.emit(true);
this.hide();
};
// @ts-ignore
VgImaAds.prototype.onAdError = function (evt) {
if (this.ima.adsManager) {
this.ima.adsManager.destroy();
}
this.hide();
this.API.play();
this.onAdStop.emit(true);
};
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
this.onAdStop.emit(true);
}
};
VgImaAds.prototype.onAdComplete = function () {
// TODO: Update view with current ad count
this.ima.currentAd++;
this.onAdStop.emit(true);
};
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();
this.onAdStop.emit(true);
};
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(); });
};
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgFor", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgNetwork", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgUnitPath", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgCompanion", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", Array)
], VgImaAds.prototype, "vgCompanionSize", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgAdTagUrl", void 0);
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgImaAds.prototype, "vgSkipButton", void 0);
__decorate([
core_1.Output(),
__metadata("design:type", core_1.EventEmitter)
], VgImaAds.prototype, "onAdStart", void 0);
__decorate([
core_1.Output(),
__metadata("design:type", core_1.EventEmitter)
], VgImaAds.prototype, "onAdStop", void 0);
__decorate([
core_1.Output(),
__metadata("design:type", core_1.EventEmitter)
], VgImaAds.prototype, "onSkipAd", void 0);
__decorate([
core_1.HostBinding('style.display'),
__metadata("design:type", Object)
], VgImaAds.prototype, "displayState", void 0);
VgImaAds = __decorate([
core_1.Component({
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 "]
}),
__metadata("design:paramtypes", [core_1.ElementRef, vg_api_1.VgAPI, vg_fullscreen_api_1.VgFullscreenAPI])
], VgImaAds);
return VgImaAds;
}());
exports.VgImaAds = VgImaAds;
var Ima = /** @class */ (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":["../../../src/ima-ads/vg-ima-ads.ts"],"names":[],"mappings":"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","sourcesContent":["///<reference path='./google.ima.ts'/>\nimport { Component, ElementRef, Input, HostBinding, ViewEncapsulation, OnInit, OnDestroy, Output, EventEmitter } 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';\n\n@Component({\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})\nexport class VgImaAds implements OnInit, OnDestroy {\n    @Input() vgFor: string;\n    @Input() vgNetwork: string;\n    @Input() vgUnitPath: string;\n    @Input() vgCompanion: string;\n    @Input() vgCompanionSize: Array<Number>;\n    @Input() vgAdTagUrl: string;\n    @Input() vgSkipButton: string;\n\n    @Output() onAdStart: EventEmitter<boolean> = new EventEmitter();\n    @Output() onAdStop: EventEmitter<boolean> = new EventEmitter();\n    @Output() onSkipAd: EventEmitter<boolean> = new EventEmitter();\n\n    elem: HTMLElement;\n    target: IPlayable;\n    ima: Ima;\n    isFullscreen = false;\n    skipButton: HTMLElement;\n\n    subscriptions: Subscription[] = [];\n\n    @HostBinding('style.display') displayState = '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    // @ts-ignore\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        this.onSkipAd.emit(true);\n    }\n\n    onContentPauseRequested() {\n        this.show();\n        this.API.pause();\n        this.onAdStop.emit(true);\n    }\n\n    onContentResumeRequested() {\n        this.API.play();\n        this.onAdStart.emit(true);\n        this.hide();\n    }\n    // @ts-ignore\n    onAdError(evt) {\n        if (this.ima.adsManager) {\n            this.ima.adsManager.destroy();\n        }\n        this.hide();\n        this.API.play();\n        this.onAdStop.emit(true);\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            this.onAdStop.emit(true);\n        }\n    }\n\n    onAdComplete() {\n        // TODO: Update view with current ad count\n        this.ima.currentAd++;\n        this.onAdStop.emit(true);\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        this.onAdStop.emit(true);\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    }\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"]}