UNPKG

videogular2

Version:

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

237 lines 30.2 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_api_1 = require("../../core/services/vg-api"); var vg_controls_hidden_1 = require("./../../core/services/vg-controls-hidden"); var vg_states_1 = require("../../core/states/vg-states"); var VgScrubBar = /** @class */ (function () { function VgScrubBar(ref, API, vgControlsHiddenState) { var _this = this; this.API = API; this.hideScrubBar = false; this.vgSlider = true; this.isSeeking = false; this.wasPlaying = false; this.subscriptions = []; this.elem = ref.nativeElement; this.subscriptions.push(vgControlsHiddenState.isHidden.subscribe(function (hide) { return _this.onHideScrubBar(hide); })); } VgScrubBar.prototype.ngOnInit = function () { var _this = this; if (this.API.isPlayerReady) { this.onPlayerReady(); } else { this.subscriptions.push(this.API.playerReadyEvent.subscribe(function () { return _this.onPlayerReady(); })); } }; VgScrubBar.prototype.onPlayerReady = function () { this.target = this.API.getMediaById(this.vgFor); }; VgScrubBar.prototype.seekStart = function () { if (this.target.canPlay) { this.isSeeking = true; if (this.target.state === vg_states_1.VgStates.VG_PLAYING) { this.wasPlaying = true; } this.target.pause(); } }; VgScrubBar.prototype.seekMove = function (offset) { if (this.isSeeking) { var percentage = Math.max(Math.min(offset * 100 / this.elem.scrollWidth, 99.9), 0); this.target.time.current = percentage * this.target.time.total / 100; this.target.seekTime(percentage, true); } }; VgScrubBar.prototype.seekEnd = function (offset) { this.isSeeking = false; if (this.target.canPlay) { var percentage = Math.max(Math.min(offset * 100 / this.elem.scrollWidth, 99.9), 0); this.target.seekTime(percentage, true); if (this.wasPlaying) { this.wasPlaying = false; this.target.play(); } } }; VgScrubBar.prototype.touchEnd = function () { this.isSeeking = false; if (this.wasPlaying) { this.wasPlaying = false; this.target.play(); } }; VgScrubBar.prototype.getTouchOffset = function (event) { var offsetLeft = 0; var element = event.target; while (element) { offsetLeft += element.offsetLeft; element = element.offsetParent; } return event.touches[0].pageX - offsetLeft; }; VgScrubBar.prototype.onMouseDownScrubBar = function ($event) { if (this.target) { if (!this.target.isLive) { if (!this.vgSlider) { this.seekEnd($event.offsetX); } else { this.seekStart(); } } } }; VgScrubBar.prototype.onMouseMoveScrubBar = function ($event) { if (this.target) { if (!this.target.isLive && this.vgSlider && this.isSeeking) { this.seekMove($event.offsetX); } } }; VgScrubBar.prototype.onMouseUpScrubBar = function ($event) { if (this.target) { if (!this.target.isLive && this.vgSlider && this.isSeeking) { this.seekEnd($event.offsetX); } } }; VgScrubBar.prototype.onTouchStartScrubBar = function ($event) { if (this.target) { if (!this.target.isLive) { if (!this.vgSlider) { this.seekEnd(this.getTouchOffset($event)); } else { this.seekStart(); } } } }; VgScrubBar.prototype.onTouchMoveScrubBar = function ($event) { if (this.target) { if (!this.target.isLive && this.vgSlider && this.isSeeking) { this.seekMove(this.getTouchOffset($event)); } } }; // @ts-ignore VgScrubBar.prototype.onTouchCancelScrubBar = function ($event) { if (this.target) { if (!this.target.isLive && this.vgSlider && this.isSeeking) { this.touchEnd(); } } }; // @ts-ignore VgScrubBar.prototype.onTouchEndScrubBar = function ($event) { if (this.target) { if (!this.target.isLive && this.vgSlider && this.isSeeking) { this.touchEnd(); } } }; VgScrubBar.prototype.arrowAdjustVolume = function (event) { if (this.target) { if (event.keyCode === 38 || event.keyCode === 39) { event.preventDefault(); this.target.seekTime((this.target.time.current + 5000) / 1000, false); } else if (event.keyCode === 37 || event.keyCode === 40) { event.preventDefault(); this.target.seekTime((this.target.time.current - 5000) / 1000, false); } } }; VgScrubBar.prototype.getPercentage = function () { return this.target ? ((this.target.time.current * 100) / this.target.time.total) + '%' : '0%'; }; VgScrubBar.prototype.onHideScrubBar = function (hide) { this.hideScrubBar = hide; }; VgScrubBar.prototype.ngOnDestroy = function () { this.subscriptions.forEach(function (s) { return s.unsubscribe(); }); }; __decorate([ core_1.HostBinding('class.hide'), __metadata("design:type", Object) ], VgScrubBar.prototype, "hideScrubBar", void 0); __decorate([ core_1.Input(), __metadata("design:type", String) ], VgScrubBar.prototype, "vgFor", void 0); __decorate([ core_1.Input(), __metadata("design:type", Object) ], VgScrubBar.prototype, "vgSlider", void 0); __decorate([ core_1.HostListener('mousedown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onMouseDownScrubBar", null); __decorate([ core_1.HostListener('document:mousemove', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onMouseMoveScrubBar", null); __decorate([ core_1.HostListener('document:mouseup', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onMouseUpScrubBar", null); __decorate([ core_1.HostListener('touchstart', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onTouchStartScrubBar", null); __decorate([ core_1.HostListener('document:touchmove', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onTouchMoveScrubBar", null); __decorate([ core_1.HostListener('document:touchcancel', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onTouchCancelScrubBar", null); __decorate([ core_1.HostListener('document:touchend', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "onTouchEndScrubBar", null); __decorate([ core_1.HostListener('keydown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], VgScrubBar.prototype, "arrowAdjustVolume", null); VgScrubBar = __decorate([ core_1.Component({ selector: 'vg-scrub-bar', encapsulation: core_1.ViewEncapsulation.None, template: "\n <div class=\"scrubBar\"\n tabindex=\"0\"\n role=\"slider\"\n aria-label=\"scrub bar\"\n aria-level=\"polite\"\n [attr.aria-valuenow]=\"getPercentage()\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n [attr.aria-valuetext]=\"getPercentage() + '%'\">\n <ng-content></ng-content>\n </div>\n\n ", styles: ["\n vg-scrub-bar {\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 position: absolute;\n width: 100%;\n height: 5px;\n bottom: 50px;\n margin: 0;\n cursor: pointer;\n align-items: center;\n background: rgba(0, 0, 0, 0.75);\n z-index: 250;\n -webkit-transition: bottom 1s, opacity 0.5s;\n -khtml-transition: bottom 1s, opacity 0.5s;\n -moz-transition: bottom 1s, opacity 0.5s;\n -ms-transition: bottom 1s, opacity 0.5s;\n transition: bottom 1s, opacity 0.5s;\n }\n\n vg-scrub-bar .scrubBar {\n position: relative;\n display: flex;\n flex-grow: 1;\n align-items: center;\n height: 100%;\n }\n\n vg-controls vg-scrub-bar {\n position: relative;\n bottom: 0;\n background: transparent;\n height: 50px;\n flex-grow: 1;\n flex-basis: 0;\n margin: 0 10px;\n -webkit-transition: initial;\n -khtml-transition: initial;\n -moz-transition: initial;\n -ms-transition: initial;\n transition: initial;\n }\n\n vg-scrub-bar.hide {\n bottom: 0;\n opacity: 0;\n }\n\n vg-controls vg-scrub-bar.hide {\n bottom: initial;\n opacity: initial;\n }\n "] }), __metadata("design:paramtypes", [core_1.ElementRef, vg_api_1.VgAPI, vg_controls_hidden_1.VgControlsHidden]) ], VgScrubBar); return VgScrubBar; }()); exports.VgScrubBar = VgScrubBar; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vg-scrub-bar.js","sourceRoot":"","sources":["../../../../src/controls/vg-scrub-bar/vg-scrub-bar.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component, ElementRef, Input, HostListener, OnInit, ViewEncapsulation, HostBinding,\n    OnDestroy\n} from '@angular/core';\nimport { VgAPI } from '../../core/services/vg-api';\nimport { VgControlsHidden } from './../../core/services/vg-controls-hidden';\nimport { VgStates } from '../../core/states/vg-states';\nimport { Subscription } from 'rxjs';\n\n@Component({\n    selector: 'vg-scrub-bar',\n    encapsulation: ViewEncapsulation.None,\n    template: `\n        <div class=\"scrubBar\"\n             tabindex=\"0\"\n             role=\"slider\"\n             aria-label=\"scrub bar\"\n             aria-level=\"polite\"\n             [attr.aria-valuenow]=\"getPercentage()\"\n             aria-valuemin=\"0\"\n             aria-valuemax=\"100\"\n             [attr.aria-valuetext]=\"getPercentage() + '%'\">\n            <ng-content></ng-content>\n        </div>\n\n    `,\n    styles: [ `\n        vg-scrub-bar {\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            position: absolute;\n            width: 100%;\n            height: 5px;\n            bottom: 50px;\n            margin: 0;\n            cursor: pointer;\n            align-items: center;\n            background: rgba(0, 0, 0, 0.75);\n            z-index: 250;\n            -webkit-transition: bottom 1s, opacity 0.5s;\n            -khtml-transition: bottom 1s, opacity 0.5s;\n            -moz-transition: bottom 1s, opacity 0.5s;\n            -ms-transition: bottom 1s, opacity 0.5s;\n            transition: bottom 1s, opacity 0.5s;\n        }\n\n        vg-scrub-bar .scrubBar {\n            position: relative;\n            display: flex;\n            flex-grow: 1;\n            align-items: center;\n            height: 100%;\n        }\n\n        vg-controls vg-scrub-bar {\n            position: relative;\n            bottom: 0;\n            background: transparent;\n            height: 50px;\n            flex-grow: 1;\n            flex-basis: 0;\n            margin: 0 10px;\n            -webkit-transition: initial;\n            -khtml-transition: initial;\n            -moz-transition: initial;\n            -ms-transition: initial;\n            transition: initial;\n        }\n\n        vg-scrub-bar.hide {\n            bottom: 0;\n            opacity: 0;\n        }\n\n        vg-controls vg-scrub-bar.hide {\n            bottom: initial;\n            opacity: initial;\n        }\n    ` ]\n})\nexport class VgScrubBar implements OnInit, OnDestroy {\n    @HostBinding('class.hide') hideScrubBar = false;\n\n    @Input() vgFor: string;\n    @Input() vgSlider = true;\n\n    elem: HTMLElement;\n    target: any;\n    isSeeking = false;\n    wasPlaying = false;\n\n    subscriptions: Subscription[] = [];\n\n    constructor(ref: ElementRef, public API: VgAPI, vgControlsHiddenState: VgControlsHidden) {\n        this.elem = ref.nativeElement;\n        this.subscriptions.push(vgControlsHiddenState.isHidden.subscribe(hide => this.onHideScrubBar(hide)));\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\n    protected seekStart() {\n        if (this.target.canPlay) {\n            this.isSeeking = true;\n            if (this.target.state === VgStates.VG_PLAYING) {\n                this.wasPlaying = true;\n            }\n            this.target.pause();\n        }\n    }\n\n    protected seekMove(offset: number) {\n        if (this.isSeeking) {\n            let percentage = Math.max(Math.min(offset * 100 / this.elem.scrollWidth, 99.9), 0);\n            this.target.time.current = percentage * this.target.time.total / 100;\n            this.target.seekTime(percentage, true);\n        }\n    }\n\n    protected seekEnd(offset: number) {\n        this.isSeeking = false;\n        if (this.target.canPlay) {\n            let percentage = Math.max(Math.min(offset * 100 / this.elem.scrollWidth, 99.9), 0);\n            this.target.seekTime(percentage, true);\n            if (this.wasPlaying) {\n                this.wasPlaying = false;\n                this.target.play();\n            }\n        }\n    }\n\n    protected touchEnd() {\n        this.isSeeking = false;\n        if (this.wasPlaying) {\n            this.wasPlaying = false;\n            this.target.play();\n        }\n    }\n\n    protected getTouchOffset(event: any) {\n        let offsetLeft = 0;\n        let element: any = event.target;\n        while (element) {\n            offsetLeft += element.offsetLeft;\n            element = element.offsetParent;\n        }\n        return event.touches[ 0 ].pageX - offsetLeft;\n    }\n\n    @HostListener('mousedown', [ '$event' ])\n    onMouseDownScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive) {\n                if (!this.vgSlider) {\n                    this.seekEnd($event.offsetX);\n                }\n                else {\n                    this.seekStart();\n                }\n            }\n        }\n    }\n\n    @HostListener('document:mousemove', [ '$event' ])\n    onMouseMoveScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive && this.vgSlider && this.isSeeking) {\n                this.seekMove($event.offsetX);\n            }\n        }\n    }\n\n    @HostListener('document:mouseup', [ '$event' ])\n    onMouseUpScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive && this.vgSlider && this.isSeeking) {\n                this.seekEnd($event.offsetX);\n            }\n        }\n    }\n\n    @HostListener('touchstart', [ '$event' ])\n    onTouchStartScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive) {\n                if (!this.vgSlider) {\n                    this.seekEnd(this.getTouchOffset($event));\n                }\n                else {\n                    this.seekStart();\n                }\n            }\n        }\n    }\n\n    @HostListener('document:touchmove', [ '$event' ])\n    onTouchMoveScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive && this.vgSlider && this.isSeeking) {\n                this.seekMove(this.getTouchOffset($event));\n            }\n        }\n    }\n    // @ts-ignore\n    @HostListener('document:touchcancel', [ '$event' ]) onTouchCancelScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive && this.vgSlider && this.isSeeking) {\n                this.touchEnd();\n            }\n        }\n    }\n    // @ts-ignore\n    @HostListener('document:touchend', [ '$event' ]) onTouchEndScrubBar($event: any) {\n        if (this.target) {\n            if (!this.target.isLive && this.vgSlider && this.isSeeking) {\n                this.touchEnd();\n            }\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    arrowAdjustVolume(event: KeyboardEvent) {\n        if (this.target) {\n            if (event.keyCode === 38 || event.keyCode === 39) {\n                event.preventDefault();\n                this.target.seekTime((this.target.time.current + 5000) / 1000, false);\n            }\n            else if (event.keyCode === 37 || event.keyCode === 40) {\n                event.preventDefault();\n                this.target.seekTime((this.target.time.current - 5000) / 1000, false);\n            }\n        }\n    }\n\n    getPercentage() {\n        return this.target ? ((this.target.time.current * 100) / this.target.time.total) + '%' : '0%';\n    }\n\n    onHideScrubBar(hide: boolean) {\n        this.hideScrubBar = hide;\n    }\n\n    ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n}\n"]}