videogular2
Version:
Videogular is a video application framework for desktop and mobile powered by Angular
84 lines • 16.1 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_api_1 = require("../../core/services/vg-api");
var VgTrackSelector = /** @class */ (function () {
function VgTrackSelector(ref, API) {
this.API = API;
this.subscriptions = [];
this.elem = ref.nativeElement;
}
VgTrackSelector.prototype.ngOnInit = function () {
var _this = this;
if (this.API.isPlayerReady) {
this.onPlayerReady();
}
else {
this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); }));
}
};
VgTrackSelector.prototype.onPlayerReady = function () {
this.target = this.API.getMediaById(this.vgFor);
var subs = Array.from(this.API.getMasterMedia().elem.children)
.filter(function (item) { return item.tagName === 'TRACK'; })
.filter(function (item) { return item.kind === 'subtitles'; })
.map(function (item) { return ({
label: item.label,
selected: item.default === true,
id: item.srclang
}); });
this.tracks = subs.concat([
{
id: null,
label: 'Off',
selected: subs.every(function (item) { return item.selected === false; })
}
]);
var track = this.tracks.filter(function (item) { return item.selected === true; })[0];
this.trackSelected = track.id;
this.ariaValue = track.label;
};
VgTrackSelector.prototype.selectTrack = function (trackId) {
var _this = this;
this.trackSelected = (trackId === 'null') ? null : trackId;
this.ariaValue = 'No track selected';
Array.from(this.API.getMasterMedia().elem.textTracks)
.forEach(function (item) {
if (item.language === trackId) {
_this.ariaValue = item.label;
item.mode = 'showing';
}
else {
item.mode = 'hidden';
}
});
};
VgTrackSelector.prototype.ngOnDestroy = function () {
this.subscriptions.forEach(function (s) { return s.unsubscribe(); });
};
__decorate([
core_1.Input(),
__metadata("design:type", String)
], VgTrackSelector.prototype, "vgFor", void 0);
VgTrackSelector = __decorate([
core_1.Component({
selector: 'vg-track-selector',
encapsulation: core_1.ViewEncapsulation.None,
template: "\n <div class=\"container\">\n <div class=\"track-selected\"\n [class.vg-icon-closed_caption]=\"!trackSelected\">\n {{ trackSelected || '' }}\n </div>\n \n <select class=\"trackSelector\" \n (change)=\"selectTrack($event.target.value)\"\n tabindex=\"0\"\n aria-label=\"track selector\"\n [attr.aria-valuetext]=\"ariaValue\">\n <option \n *ngFor=\"let track of tracks\"\n [value]=\"track.id\"\n [selected]=\"track.selected === true\">\n {{ track.label }}\n </option>\n </select>\n </div>\n ",
styles: ["\n vg-track-selector {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n display: flex;\n justify-content: center;\n width: 50px;\n height: 50px;\n cursor: pointer;\n color: white;\n line-height: 50px;\n }\n vg-track-selector .container {\n position: relative;\n display: flex;\n flex-grow: 1;\n align-items: center;\n \n padding: 0;\n margin: 5px;\n }\n vg-track-selector select.trackSelector {\n width: 50px;\n padding: 5px 8px;\n border: none;\n background: none;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n color: transparent;\n font-size: 16px;\n }\n vg-track-selector select.trackSelector::-ms-expand {\n display: none;\n }\n vg-track-selector select.trackSelector option {\n color: #000;\n }\n vg-track-selector .track-selected {\n position: absolute;\n width: 100%;\n height: 50px;\n top: -6px;\n text-align: center;\n text-transform: uppercase;\n font-family: Helvetica Neue, Helvetica, Arial, sans-serif;\n padding-top: 2px;\n pointer-events: none;\n }\n vg-track-selector .vg-icon-closed_caption:before {\n width: 100%;\n }\n "]
}),
__metadata("design:paramtypes", [core_1.ElementRef, vg_api_1.VgAPI])
], VgTrackSelector);
return VgTrackSelector;
}());
exports.VgTrackSelector = VgTrackSelector;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-track-selector.js","sourceRoot":"","sources":["../../../../src/controls/vg-track-selector/vg-track-selector.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,sCAAmG;AACnG,qDAAmD;AA0FnD;IAYI,yBAAY,GAAe,EAAS,GAAU;QAAV,QAAG,GAAH,GAAG,CAAO;QAJ9C,kBAAa,GAAmB,EAAE,CAAC;QAK/B,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC;IAClC,CAAC;IAED,kCAAQ,GAAR;QAAA,iBAOC;QANG,IAAI,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;aACI;YACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,SAAS,CAAC,cAAM,OAAA,KAAI,CAAC,aAAa,EAAE,EAApB,CAAoB,CAAC,CAAC,CAAC;SAC5F;IACL,CAAC;IAED,uCAAa,GAAb;QACI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEhD,IAAM,IAAI,GAAkB,KAAK,CAAC,IAAI,CAAE,IAAI,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,IAAyB,CAAC,QAAQ,CAAC;aAChG,MAAM,CAAC,UAAC,IAAiB,IAAK,OAAA,IAAI,CAAC,OAAO,KAAK,OAAO,EAAxB,CAAwB,CAAC;aACvD,MAAM,CAAC,UAAC,IAAsB,IAAK,OAAA,IAAI,CAAC,IAAI,KAAK,WAAW,EAAzB,CAAyB,CAAC;aAC7D,GAAG,CAAC,UAAC,IAAsB,IAAK,OAAA,CAAC;YAC9B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,IAAI,CAAC,OAAO,KAAK,IAAI;YAC/B,EAAE,EAAE,IAAI,CAAC,OAAO;SACnB,CAAC,EAJ+B,CAI/B,CAAC,CAAC;QAER,IAAI,CAAC,MAAM,GACJ,IAAI;YACP;gBACI,EAAE,EAAE,IAAI;gBACR,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,UAAC,IAAY,IAAK,OAAA,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAvB,CAAuB,CAAC;aAClE;UACJ,CAAC;QAEF,IAAM,KAAK,GAAW,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAC,IAAY,IAAK,OAAA,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAtB,CAAsB,CAAC,CAAE,CAAC,CAAE,CAAC;QACxF,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC;QAC9B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC;IACjC,CAAC;IAED,qCAAW,GAAX,UAAY,OAAe;QAA3B,iBAcC;QAbG,IAAI,CAAC,aAAa,GAAG,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;QAE3D,IAAI,CAAC,SAAS,GAAG,mBAAmB,CAAC;QAErC,KAAK,CAAC,IAAI,CAAE,IAAI,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,IAAyB,CAAC,UAAU,CAAC;aACtE,OAAO,CAAC,UAAC,IAAe;YACrB,IAAI,IAAI,CAAC,QAAQ,KAAK,OAAO,EAAE;gBAC3B,KAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;gBAC5B,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;aACzB;iBAAM;gBACH,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;aACxB;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED,qCAAW,GAAX;QACI,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,WAAW,EAAE,EAAf,CAAe,CAAC,CAAC;IACrD,CAAC;IApEQ;QAAR,YAAK,EAAE;;kDAAe;IADd,eAAe;QAjF3B,gBAAS,CAAC;YACP,QAAQ,EAAE,mBAAmB;YAC7B,aAAa,EAAE,wBAAiB,CAAC,IAAI;YACrC,QAAQ,EAAE,wwBAoBT;YACD,MAAM,EAAE,CAAE,+pDAuDT,CAAE;SACN,CAAC;yCAamB,iBAAU,EAAc,cAAK;OAZrC,eAAe,CAsE3B;IAAD,sBAAC;CAAA,AAtED,IAsEC;AAtEY,0CAAe","sourcesContent":["import { Component, ElementRef, OnInit, Input, ViewEncapsulation, OnDestroy } from '@angular/core';\nimport { VgAPI } from '../../core/services/vg-api';\nimport { Subscription } from 'rxjs';\n\nexport interface Option {\n    id: string;\n    label: string;\n    selected: boolean;\n}\n\n@Component({\n    selector: 'vg-track-selector',\n    encapsulation: ViewEncapsulation.None,\n    template: `\n        <div class=\"container\">\n            <div class=\"track-selected\"\n                 [class.vg-icon-closed_caption]=\"!trackSelected\">\n                {{ trackSelected || '' }}\n            </div>\n            \n            <select class=\"trackSelector\" \n                    (change)=\"selectTrack($event.target.value)\"\n                    tabindex=\"0\"\n                    aria-label=\"track selector\"\n                    [attr.aria-valuetext]=\"ariaValue\">\n                <option \n                    *ngFor=\"let track of tracks\"\n                    [value]=\"track.id\"\n                    [selected]=\"track.selected === true\">\n                    {{ track.label }}\n                </option>\n            </select>\n        </div>\n    `,\n    styles: [ `\n        vg-track-selector {\n            -webkit-touch-callout: none;\n            -webkit-user-select: none;\n            -moz-user-select: none;\n            -ms-user-select: none;\n            user-select: none;\n            display: flex;\n            justify-content: center;\n            width: 50px;\n            height: 50px;\n            cursor: pointer;\n            color: white;\n            line-height: 50px;\n        }\n        vg-track-selector .container {\n            position: relative;\n            display: flex;\n            flex-grow: 1;\n            align-items: center;\n            \n            padding: 0;\n            margin: 5px;\n        }\n        vg-track-selector select.trackSelector {\n            width: 50px;\n            padding: 5px 8px;\n            border: none;\n            background: none;\n            -webkit-appearance: none;\n            -moz-appearance: none;\n            appearance: none;\n            color: transparent;\n            font-size: 16px;\n        }\n        vg-track-selector select.trackSelector::-ms-expand {\n            display: none;\n        }\n        vg-track-selector select.trackSelector option {\n            color: #000;\n        }\n        vg-track-selector .track-selected {\n            position: absolute;\n            width: 100%;\n            height: 50px;\n            top: -6px;\n            text-align: center;\n            text-transform: uppercase;\n            font-family: Helvetica Neue, Helvetica, Arial, sans-serif;\n            padding-top: 2px;\n            pointer-events: none;\n        }\n        vg-track-selector .vg-icon-closed_caption:before {\n            width: 100%;\n        }\n    ` ]\n})\nexport class VgTrackSelector implements OnInit, OnDestroy {\n    @Input() vgFor: string;\n\n    elem: HTMLElement;\n    target: any;\n    tracks: Array<Option>;\n    trackSelected: string;\n\n    subscriptions: Subscription[] = [];\n\n    ariaValue: string;\n\n    constructor(ref: ElementRef, public API: VgAPI) {\n        this.elem = ref.nativeElement;\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        this.target = this.API.getMediaById(this.vgFor);\n\n        const subs: Array<Option> = Array.from((this.API.getMasterMedia().elem as HTMLMediaElement).children)\n            .filter((item: HTMLElement) => item.tagName === 'TRACK')\n            .filter((item: HTMLTrackElement) => item.kind === 'subtitles')\n            .map((item: HTMLTrackElement) => ({\n                label: item.label,\n                selected: item.default === true,\n                id: item.srclang\n            }));\n\n        this.tracks = [\n            ...subs,\n            {\n                id: null,\n                label: 'Off',\n                selected: subs.every((item: Option) => item.selected === false)\n            }\n        ];\n\n        const track: Option = this.tracks.filter((item: Option) => item.selected === true)[ 0 ];\n        this.trackSelected = track.id;\n        this.ariaValue = track.label;\n    }\n\n    selectTrack(trackId: string) {\n        this.trackSelected = (trackId === 'null') ? null : trackId;\n\n        this.ariaValue = 'No track selected';\n\n        Array.from((this.API.getMasterMedia().elem as HTMLMediaElement).textTracks)\n            .forEach((item: TextTrack) => {\n                if (item.language === trackId) {\n                    this.ariaValue = item.label;\n                    item.mode = 'showing';\n                } else {\n                    item.mode = 'hidden';\n                }\n            });\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n}\n"]}