UNPKG

videogular2

Version:

Videogular is a video application framework for desktop and mobile powered by Angular

298 lines 27.6 kB
"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"]}