videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular
298 lines • 27.6 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 });
var core_1 = require("@angular/core");
var vg_states_1 = require("../states/vg-states");
var VgAPI = /** @class */ (function () {
function VgAPI() {
this.medias = {}; // TODO: refactor to Set<IPlayable>
this.playerReadyEvent = new core_1.EventEmitter(true);
this.isPlayerReady = false;
}
VgAPI.prototype.onPlayerReady = function (fsAPI) {
this.fsAPI = fsAPI;
this.isPlayerReady = true;
this.playerReadyEvent.emit(this);
};
VgAPI.prototype.getDefaultMedia = function () {
for (var item in this.medias) {
if (this.medias[item]) {
return this.medias[item];
}
}
};
VgAPI.prototype.getMasterMedia = function () {
var master;
for (var id in this.medias) {
if (this.medias[id].vgMaster === 'true' || this.medias[id].vgMaster === true) {
master = this.medias[id];
break;
}
}
return master || this.getDefaultMedia();
};
VgAPI.prototype.isMasterDefined = function () {
var result = false;
for (var id in this.medias) {
if (this.medias[id].vgMaster === 'true' || this.medias[id].vgMaster === true) {
result = true;
break;
}
}
return result;
};
VgAPI.prototype.getMediaById = function (id) {
if (id === void 0) { id = null; }
var media = this.medias[id];
if (!id || id === '*') {
media = this;
}
return media;
};
VgAPI.prototype.play = function () {
for (var id in this.medias) {
if (this.medias[id]) {
this.medias[id].play();
}
}
};
VgAPI.prototype.pause = function () {
for (var id in this.medias) {
if (this.medias[id]) {
this.medias[id].pause();
}
}
};
Object.defineProperty(VgAPI.prototype, "duration", {
get: function () {
return this.$$getAllProperties('duration');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "currentTime", {
get: function () {
return this.$$getAllProperties('currentTime');
},
set: function (seconds) {
this.$$setAllProperties('currentTime', seconds);
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "state", {
get: function () {
return this.$$getAllProperties('state');
},
set: function (state) {
this.$$setAllProperties('state', state);
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "volume", {
get: function () {
return this.$$getAllProperties('volume');
},
set: function (volume) {
this.$$setAllProperties('volume', volume);
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "playbackRate", {
get: function () {
return this.$$getAllProperties('playbackRate');
},
set: function (rate) {
this.$$setAllProperties('playbackRate', rate);
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "canPlay", {
get: function () {
return this.$$getAllProperties('canPlay');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "canPlayThrough", {
get: function () {
return this.$$getAllProperties('canPlayThrough');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "isMetadataLoaded", {
get: function () {
return this.$$getAllProperties('isMetadataLoaded');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "isWaiting", {
get: function () {
return this.$$getAllProperties('isWaiting');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "isCompleted", {
get: function () {
return this.$$getAllProperties('isCompleted');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "isLive", {
get: function () {
return this.$$getAllProperties('isLive');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "isMaster", {
get: function () {
return this.$$getAllProperties('isMaster');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "time", {
get: function () {
return this.$$getAllProperties('time');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "buffer", {
get: function () {
return this.$$getAllProperties('buffer');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "buffered", {
get: function () {
return this.$$getAllProperties('buffered');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "subscriptions", {
get: function () {
return this.$$getAllProperties('subscriptions');
},
enumerable: true,
configurable: true
});
Object.defineProperty(VgAPI.prototype, "textTracks", {
get: function () {
return this.$$getAllProperties('textTracks');
},
enumerable: true,
configurable: true
});
VgAPI.prototype.seekTime = function (value, byPercent) {
if (byPercent === void 0) { byPercent = false; }
for (var id in this.medias) {
if (this.medias[id]) {
this.$$seek(this.medias[id], value, byPercent);
}
}
};
VgAPI.prototype.$$seek = function (media, value, byPercent) {
if (byPercent === void 0) { byPercent = false; }
var second;
var duration = media.duration;
if (byPercent) {
if (this.isMasterDefined()) {
duration = this.getMasterMedia().duration;
}
second = value * duration / 100;
}
else {
second = value;
}
media.currentTime = second;
};
VgAPI.prototype.addTextTrack = function (type, label, language) {
for (var id in this.medias) {
if (this.medias[id]) {
this.$$addTextTrack(this.medias[id], type, label, language);
}
}
};
VgAPI.prototype.$$addTextTrack = function (media, type, label, language) {
media.addTextTrack(type, label, language);
};
VgAPI.prototype.$$getAllProperties = function (property) {
var medias = {};
var result;
for (var id in this.medias) {
if (this.medias[id]) {
medias[id] = this.medias[id];
}
}
var nMedias = Object.keys(medias).length;
switch (nMedias) {
case 0:
// Return default values until vgMedia is initialized
switch (property) {
case 'state':
result = vg_states_1.VgStates.VG_PAUSED;
break;
case 'playbackRate':
case 'volume':
result = 1;
break;
case 'time':
result = { current: 0, total: 0, left: 0 };
break;
}
break;
case 1:
// If there's only one media element then return the plain value
var firstMediaId = Object.keys(medias)[0];
result = medias[firstMediaId][property];
break;
default:
// TODO: return 'master' value
var master = this.getMasterMedia();
result = medias[master.id][property];
}
return result;
};
VgAPI.prototype.$$setAllProperties = function (property, value) {
for (var id in this.medias) {
if (this.medias[id]) {
this.medias[id][property] = value;
}
}
};
VgAPI.prototype.registerElement = function (elem) {
this.videogularElement = elem;
};
VgAPI.prototype.registerMedia = function (media) {
this.medias[media.id] = media;
};
VgAPI.prototype.unregisterMedia = function (media) {
delete this.medias[media.id];
};
VgAPI = __decorate([
core_1.Injectable(),
__metadata("design:paramtypes", [])
], VgAPI);
return VgAPI;
}());
exports.VgAPI = VgAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-api.js","sourceRoot":"","sources":["../../../../src/core/services/vg-api.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, EventEmitter} from '@angular/core';\nimport {IPlayable} from \"../vg-media/i-playable\";\nimport {VgStates} from \"../states/vg-states\";\nimport { VgFullscreenAPI } from './vg-fullscreen-api';\n\n@Injectable()\nexport class VgAPI {\n    medias:Object = {};// TODO: refactor to Set<IPlayable> \n    videogularElement: any;\n    playerReadyEvent: EventEmitter<any> = new EventEmitter(true);\n    isPlayerReady = false;\n    fsAPI: VgFullscreenAPI;\n\n    constructor() {\n\n    }\n\n    onPlayerReady(fsAPI: VgFullscreenAPI) {\n        this.fsAPI = fsAPI;\n        this.isPlayerReady = true;\n        this.playerReadyEvent.emit(this);\n    }\n\n    getDefaultMedia():IPlayable {\n        for (let item in this.medias) {\n            if (this.medias[item]) {\n                return this.medias[item];\n            }\n        }\n    }\n\n    getMasterMedia():IPlayable {\n        let master:any;\n        for (let id in this.medias) {\n            if (this.medias[id].vgMaster === 'true' || this.medias[id].vgMaster === true) {\n                master = this.medias[id];\n                break;\n            }\n        }\n        return master || this.getDefaultMedia();\n    }\n\n    isMasterDefined():boolean {\n        let result = false;\n        for (let id in this.medias) {\n            if (this.medias[id].vgMaster === 'true' || this.medias[id].vgMaster === true) {\n                result = true;\n                break;\n            }\n        }\n        return result;\n    }\n\n    getMediaById(id:string = null):IPlayable {\n        let media = this.medias[id];\n\n        if (!id || id === '*') {\n            media = this;\n        }\n\n        return media;\n    }\n\n    play() {\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                this.medias[ id ].play();\n            }\n        }\n    }\n\n    pause() {\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                this.medias[id].pause();\n            }\n        }\n    }\n\n    get duration() {\n        return this.$$getAllProperties('duration');\n    }\n\n    set currentTime(seconds) {\n        this.$$setAllProperties('currentTime', seconds);\n    }\n\n    get currentTime() {\n        return this.$$getAllProperties('currentTime');\n    }\n\n    set state(state) {\n        this.$$setAllProperties('state', state);\n    }\n\n    get state() {\n        return this.$$getAllProperties('state');\n    }\n\n    set volume(volume) {\n        this.$$setAllProperties('volume', volume);\n    }\n\n    get volume() {\n        return this.$$getAllProperties('volume');\n    }\n\n    set playbackRate(rate) {\n        this.$$setAllProperties('playbackRate', rate);\n    }\n\n    get playbackRate() {\n        return this.$$getAllProperties('playbackRate');\n    }\n\n    get canPlay() {\n        return this.$$getAllProperties('canPlay');\n    }\n\n    get canPlayThrough() {\n        return this.$$getAllProperties('canPlayThrough');\n    }\n\n    get isMetadataLoaded() {\n        return this.$$getAllProperties('isMetadataLoaded');\n    }\n\n    get isWaiting() {\n        return this.$$getAllProperties('isWaiting');\n    }\n\n    get isCompleted() {\n        return this.$$getAllProperties('isCompleted');\n    }\n\n    get isLive() {\n        return this.$$getAllProperties('isLive');\n    }\n\n    get isMaster() {\n        return this.$$getAllProperties('isMaster');\n    }\n\n    get time() {\n        return this.$$getAllProperties('time');\n    }\n\n    get buffer() {\n        return this.$$getAllProperties('buffer');\n    }\n\n    get buffered() {\n        return this.$$getAllProperties('buffered');\n    }\n\n    get subscriptions() {\n        return this.$$getAllProperties('subscriptions');\n    }\n\n    get textTracks() {\n        return this.$$getAllProperties('textTracks');\n    }\n\n    seekTime(value:number, byPercent:boolean = false) {\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                this.$$seek(this.medias[ id ], value, byPercent);\n            }\n        }\n    }\n\n    $$seek(media:IPlayable, value:number, byPercent:boolean = false) {\n        let second:number;\n        let duration:number = media.duration;\n\n        if (byPercent) {\n            if (this.isMasterDefined()) {\n                duration = this.getMasterMedia().duration;\n            }\n\n            second = value * duration / 100;\n        }\n        else {\n            second = value;\n        }\n\n        media.currentTime = second;\n    }\n\n    addTextTrack(type:string, label?:string, language?:string) {\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                this.$$addTextTrack(this.medias[ id ], type, label, language);\n            }\n        }\n    }\n    $$addTextTrack(media:IPlayable, type:string, label?:string, language?:string) {\n        media.addTextTrack(type, label, language);\n    }\n\n    $$getAllProperties(property:string){\n        const medias = {};\n        let result:any;\n\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                medias[ id ] = this.medias[ id ];\n            }\n        }\n\n        const nMedias = Object.keys(medias).length;\n        switch (nMedias) {\n            case 0:\n                // Return default values until vgMedia is initialized\n                switch (property) {\n                    case 'state':\n                        result = VgStates.VG_PAUSED;\n                        break;\n\n                    case 'playbackRate':\n                    case 'volume':\n                        result = 1;\n                        break;\n\n                    case 'time':\n                        result = {current: 0, total: 0, left: 0};\n                        break;\n                }\n                break;\n\n            case 1:\n                // If there's only one media element then return the plain value\n                const firstMediaId = Object.keys(medias)[0];\n                result = medias[firstMediaId][property];\n                break;\n                \n            default:\n                // TODO: return 'master' value\n                let master = this.getMasterMedia();\n                result = medias[master.id][property];\n        }\n        \n        return result;\n    }\n\n    $$setAllProperties(property:string, value:any){\n        for (let id in this.medias) {\n            if (this.medias[id]) {\n                this.medias[ id ][ property ] = value;\n            }\n        }\n    }\n\n    registerElement(elem:HTMLElement) {\n        this.videogularElement = elem;\n    }\n\n    registerMedia(media:IPlayable) {\n        this.medias[media.id] = media;\n    }\n\n    unregisterMedia(media:IPlayable) {\n        delete this.medias[media.id];\n    }\n\n\n}\n"]}