UNPKG

ngx-audio-player

Version:

[![npm version](https://img.shields.io/npm/v/ngx-audio-player.svg?colorB=red)](https://www.npmjs.com/package/ngx-audio-player) [![Downloads](https://img.shields.io/npm/dm/ngx-audio-player.svg)](https://www.npmjs.com/package/ngx-audio-player) [![licence](h

444 lines (433 loc) 18.1 kB
import { BehaviorSubject } from 'rxjs'; import { MatPaginator, MatTableDataSource, MatButtonModule, MatCardModule, MatSliderModule, MatExpansionModule, MatFormFieldModule, MatTableModule, MatPaginatorModule } from '@angular/material'; import { CommonModule } from '@angular/common'; import { Injectable, ViewChild, Component, Input, Pipe, NgModule } from '@angular/core'; import { FontAwesomeModule } from '@fortawesome/angular-fontawesome'; import { library } from '@fortawesome/fontawesome-svg-core'; import { faPlay, faPause, faSpinner, faStepForward, faStepBackward } from '@fortawesome/free-solid-svg-icons'; import { FormsModule } from '@angular/forms'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class AudioPlayerService { constructor() { this.playlist = []; this.indexSong = 0; this.currentTrack = new BehaviorSubject(this.playlist[this.indexSong]); this.currentTime = 0; this.duration = 0; } ; /** * @return {?} */ init() { this.updateCurrentSong(); } ; /** * @return {?} */ nextSong() { if ((this.indexSong + 1) >= this.playlist.length) { this.indexSong = 0; } else { this.indexSong++; } this.updateCurrentSong(); } ; /** * @return {?} */ previousSong() { if ((this.indexSong - 1) < 0) { this.indexSong = (this.playlist.length - 1); } else { this.indexSong--; } this.updateCurrentSong(); } ; /** * @return {?} */ resetPlaylist() { this.indexSong = 0; this.updateCurrentSong(); } ; /** * @param {?} index * @return {?} */ selectATrack(index) { this.indexSong = index - 1; this.updateCurrentSong(); } ; /** * @return {?} */ updateCurrentSong() { /** @type {?} */ let current = this.playlist[this.indexSong]; /** @type {?} */ let previous = ((this.indexSong - 1) >= 0) ? this.playlist[this.indexSong - 1] : this.playlist[this.playlist.length - 1]; /** @type {?} */ let next = ((this.indexSong + 1) >= this.playlist.length) ? this.playlist[0] : this.playlist[this.indexSong + 1]; this.currentTrack.next([ previous, current, next ]); } ; /** * @return {?} */ getSubjectCurrentTrack() { return this.currentTrack; } ; /** * @return {?} */ getPlaylist() { return this.playlist; } ; /** * @param {?} playlist * @return {?} */ setPlaylist(playlist) { this.playlist = playlist; } /** * @return {?} */ getIndexSong() { return this.indexSong; } } AudioPlayerService.decorators = [ { type: Injectable } ]; /** @nocollapse */ AudioPlayerService.ctorParameters = () => []; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class BaseAudioPlayerFunctions { constructor() { this.loaderDisplay = false; this.isPlaying = false; this.currentTime = 0; this.duration = 0.01; } /** * @param {?} event * @return {?} */ currTimePosChanged(event) { this.player.nativeElement.currentTime = event.value; } /** * @return {?} */ bindPlayerEvent() { this.player.nativeElement.addEventListener('playing', () => { this.isPlaying = true; this.duration = Math.floor(this.player.nativeElement.duration); }); this.player.nativeElement.addEventListener('pause', () => { this.isPlaying = false; }); this.player.nativeElement.addEventListener('timeupdate', () => { this.currentTime = Math.floor(this.player.nativeElement.currentTime); }); this.player.nativeElement.addEventListener('loadstart', () => { this.loaderDisplay = true; }); this.player.nativeElement.addEventListener('loadeddata', () => { this.loaderDisplay = false; this.duration = Math.floor(this.player.nativeElement.duration); }); } ; /** * @return {?} */ playBtnHandler() { if (this.loaderDisplay) { return; } if (this.player.nativeElement.paused) { this.player.nativeElement.play(this.currentTime); } else { this.currentTime = this.player.nativeElement.currentTime; this.player.nativeElement.pause(); } } ; /** * @return {?} */ play() { setTimeout(() => { this.player.nativeElement.play(); }, 0); } ; } BaseAudioPlayerFunctions.propDecorators = { player: [{ type: ViewChild, args: ['audioPlayer',] }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class MatAdvancedAudioPlayerComponent extends BaseAudioPlayerFunctions { /** * @param {?} playlistService */ constructor(playlistService) { super(); this.playlistService = playlistService; this.displayedColumns = ['title', 'status']; this.dataSource = new MatTableDataSource(); } /** * @return {?} */ ngOnInit() { this.setDataSourceAttributes(); this.bindPlayerEvent(); this.playlistService.setPlaylist(this.playlistData); this.playlistService.getSubjectCurrentTrack().subscribe((playlistTrack) => { this.playlistTrack = playlistTrack; }); this.player.nativeElement.currentTime = 0; this.playlistService.init(); } /** * @param {?} mp * @return {?} */ set matPaginator(mp) { this.paginator = mp; this.setDataSourceAttributes(); } /** * @return {?} */ setDataSourceAttributes() { /** @type {?} */ let index = 1; if (this.playlistData) { this.playlistData.forEach(data => { data.index = index++; }); this.dataSource = new MatTableDataSource(this.playlistData); this.dataSource.paginator = this.paginator; } } /** * @return {?} */ nextSong() { if (((this.playlistService.indexSong + 1) % this.paginator.pageSize) === 0 || (this.playlistService.indexSong + 1) === this.paginator.length) { if (this.paginator.hasNextPage()) { this.paginator.nextPage(); } else if (!this.paginator.hasNextPage()) { this.paginator.firstPage(); } } this.currentTime = 0; this.duration = 0.01; this.playlistService.nextSong(); this.play(); } ; /** * @return {?} */ previousSong() { this.currentTime = 0; this.duration = 0.01; if (!this.checkIfSongHasStartedSinceAtleastTwoSeconds()) { if (((this.playlistService.indexSong) % this.paginator.pageSize) === 0 || (this.playlistService.indexSong) === 0) { if (this.paginator.hasPreviousPage()) { this.paginator.previousPage(); } else if (!this.paginator.hasPreviousPage()) { this.paginator.lastPage(); } } this.playlistService.previousSong(); } else { this.resetSong(); } this.play(); } ; /** * @return {?} */ resetSong() { this.player.nativeElement.src = this.playlistTrack[1].link; } ; /** * @param {?} index * @return {?} */ selectTrack(index) { console.log('selectTrack(index: number): void: ' + index); this.playlistService.selectATrack(index); setTimeout(() => { this.player.nativeElement.play(); }, 0); } ; /** * @return {?} */ checkIfSongHasStartedSinceAtleastTwoSeconds() { return this.player.nativeElement.currentTime > 2; } ; /** * @param {?} playlist * @return {?} */ set playlist(playlist) { this.playlistData = playlist; this.ngOnInit(); } } MatAdvancedAudioPlayerComponent.decorators = [ { type: Component, args: [{ selector: 'mat-advanced-audio-player', template: "<mat-card class=\"row d-flex justify-content-center ngx-advanced-audio-player\" style=\"margin: 0px;\">\n <audio [src]=\"playlistTrack[1].link\" #audioPlayer></audio>\n \n <button mat-button class=\"p-1\" style=\"border-left: 1px solid #ddd;\" (click)='previousSong();' [disabled]=\"loaderDisplay\">\n <fa-icon class=\"fa fa-lg\" [icon]=\"['fas','step-backward']\" aria-hidden=\"true\"></fa-icon>\n </button>\n <button mat-button class=\"p-1\" (click)='playBtnHandler();' style=\"border-left: 2px solid #ccc; border-right: 2px solid #ccc;\"\n [disabled]=\"loaderDisplay\">\n <fa-icon *ngIf=\"loaderDisplay\" title=\"loading...\" class=\"fa fa-2x loading-track\" [pulse]=\"true\" [icon]=\"['fas','spinner']\"\n aria-hidden=\"true\"></fa-icon>\n <fa-icon *ngIf=\"!loaderDisplay && !isPlaying\" class=\"fa fa-2x play-track\" style=\"color:#444\" [icon]=\"['fas','play']\"\n aria-hidden=\"true\"></fa-icon>\n <fa-icon *ngIf=\"!loaderDisplay && isPlaying\" class=\"fa fa-2x pause-track\" style=\"color:#444\" [icon]=\"['fas','pause']\"\n aria-hidden=\"true\"></fa-icon>\n </button>\n <button mat-button class=\"p-1\" style=\"border-right: 1px solid #ddd;\" (click)='nextSong();' [disabled]=\"loaderDisplay\">\n <fa-icon class=\"fa fa-lg next-track\" [icon]=\"['fas','step-forward']\" aria-hidden=\"true\"></fa-icon>\n </button>\n\n <div class=\"col\">\n <div class=\"d-flex flex-fill\">\n <div class=\"py-3 px-1\" style=\"font-size: 12px\">\n <span *ngIf=\"duration !== 0.01\">\n {{currentTime | secondsToMinutes}}\n </span>\n </div>\n <mat-slider class=\"flex-fill p-1\" style=\"width: 100%\" min=\"0\" max=\"{{duration}}\" value=\"{{currentTime}}\" (change)=\"currTimePosChanged($event)\"></mat-slider>\n\n <div class=\"py-3 px-1\" style=\"font-size: 12px; text-align: right\">\n <span *ngIf=\"duration !== 0.01\">\n -{{duration-currentTime | secondsToMinutes }}\n </span>\n </div>\n </div>\n </div>\n\n</mat-card>\n\n<mat-card *ngIf=\"displayTitle\" style=\"border: 1px solid #ddd; box-shadow: none;\">\n <div class=\"p-1\" style=\"text-align: center;\">\n <div style=\"padding:1px 3px;\">\n <span *ngIf=\"!isPlaying\">{{ playlistTrack[1].title }}</span>\n <marquee *ngIf=\"isPlaying\" behavior=\"scroll\" direction=\"left\">{{ playlistTrack[1].title }}</marquee>\n </div>\n <div class=\"clear\"></div>\n </div>\n</mat-card>\n\n<mat-accordion *ngIf=\"displayPlaylist\">\n <mat-expansion-panel>\n <mat-expansion-panel-header>\n Play List\n </mat-expansion-panel-header>\n <table mat-table [dataSource]=\"dataSource\" class=\"mat-elevation-z6\">\n <ng-container matColumnDef=\"title\">\n <th mat-header-cell *matHeaderCellDef> Title </th>\n <td mat-cell *matCellDef=\"let element\" (click)=\"selectTrack(element.index)\"> {{element.title}} </td>\n </ng-container>\n <ng-container matColumnDef=\"status\">\n <th mat-header-cell *matHeaderCellDef> </th>\n <td mat-cell *matCellDef=\"let element\">\n <div *ngIf=\"playlistTrack[1].title === element.title\">\n <fa-icon *ngIf=\"isPlaying\" class=\"fa\" [icon]=\"['fas','play']\" [spin]=\"true\" aria-hidden=\"true\"></fa-icon>\n <fa-icon *ngIf=\"!isPlaying\" class=\"fa\" [icon]=\"['fas','play']\" aria-hidden=\"true\"></fa-icon>\n </div>\n </td>\n </ng-container>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr class=\"mat-select-content\" mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </table>\n <mat-paginator [pageSizeOptions]=\"[2, 5, 10]\" showFirstLastButtons></mat-paginator>\n </mat-expansion-panel>\n</mat-accordion>", styles: ["@import url(https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.2.1/css/bootstrap-grid.min.css);mat-card{padding:0!important}mat-slider{max-height:30px}table{width:100%}button:focus,button:hover{outline:0!important}.ngx-advanced-audio-player{min-width:275px}"] }] } ]; /** @nocollapse */ MatAdvancedAudioPlayerComponent.ctorParameters = () => [ { type: AudioPlayerService } ]; MatAdvancedAudioPlayerComponent.propDecorators = { displayTitle: [{ type: Input }], displayPlaylist: [{ type: Input }], matPaginator: [{ type: ViewChild, args: [MatPaginator,] }], playlist: [{ type: Input }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class MatBasicAudioPlayerComponent extends BaseAudioPlayerFunctions { constructor() { super(); this.displayTitle = false; } /** * @return {?} */ ngOnInit() { this.bindPlayerEvent(); } /** * @return {?} */ resetSong() { this.player.nativeElement.src = this.audioUrl; } ; } MatBasicAudioPlayerComponent.decorators = [ { type: Component, args: [{ selector: 'mat-basic-audio-player', template: "<mat-card class=\"d-flex ngx-basic-audio-player\">\n <audio [src]=\"audioUrl\" #audioPlayer></audio>\n <button mat-button (click)='playBtnHandler();' class=\"p-1 ngx-basic-audio-player-button-handler\" [disabled]=\"loaderDisplay\">\n <fa-icon *ngIf=\"loaderDisplay\" title=\"loading...\" class=\"fa fa-lg loading-track\" [pulse]=\"true\" [icon]=\"['fas','spinner']\"\n aria-hidden=\"true\"></fa-icon>\n <fa-icon *ngIf=\"!loaderDisplay && !isPlaying\" class=\"fa fa-lg play-track\" [icon]=\"['fas','play']\" aria-hidden=\"true\"></fa-icon>\n <fa-icon *ngIf=\"!loaderDisplay && isPlaying\" class=\"fa fa-lg pause-track\" [icon]=\"['fas','pause']\" aria-hidden=\"true\"></fa-icon>\n </button>\n <div class=\"flex-fill p-1 ngx-basic-audio-player-slider\">\n <mat-slider style=\"width: 100%\" min=\"0\" max=\"{{duration}}\" value=\"{{currentTime}}\" (change)=\"currTimePosChanged($event)\"></mat-slider>\n </div>\n <div class=\"p-3 ngx-basic-audio-player-duration\">\n <span *ngIf=\"duration !== 0.01\">\n -{{duration-currentTime |\n secondsToMinutes }}\n </span>\n </div>\n</mat-card>\n<mat-card *ngIf=\"displayTitle && title !== ''\" style=\"border-top: 1px solid #ddd;\">\n <div style=\"text-align: center;\">\n <div style=\"padding:1px 3px;\">\n {{ title }}\n </div>\n </div>\n</mat-card>\n", styles: ["@import url(https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.2.1/css/bootstrap-grid.min.css);mat-card,mat-slider{padding:0!important}button:focus,button:hover{outline:0!important}.ngx-basic-audio-player{min-width:275px}"] }] } ]; /** @nocollapse */ MatBasicAudioPlayerComponent.ctorParameters = () => []; MatBasicAudioPlayerComponent.propDecorators = { title: [{ type: Input }], audioUrl: [{ type: Input }], displayTitle: [{ type: Input }] }; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /* * Transform seconds to minutes:seconds * Example : 270 -> 02:30 */ class SecondsToMinutesPipe { /** * @param {?} time * @return {?} */ transform(time) { /** @type {?} */ let minutes = ("0" + Math.floor(time / 60)).slice(-2); /** @type {?} */ let seconds = ("0" + time % 60).slice(-2); return `${minutes}:${seconds}`; } } SecondsToMinutesPipe.decorators = [ { type: Pipe, args: [{ name: 'secondsToMinutes' },] } ]; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class NgxAudioPlayerModule { constructor() { // Icons for User Favorite Page library.add(faPlay, faPause, faSpinner, faStepForward, faStepBackward); } } NgxAudioPlayerModule.decorators = [ { type: NgModule, args: [{ declarations: [MatBasicAudioPlayerComponent, SecondsToMinutesPipe, MatAdvancedAudioPlayerComponent], imports: [CommonModule, MatButtonModule, MatCardModule, MatTableModule, MatFormFieldModule, MatSliderModule, MatExpansionModule, MatPaginatorModule, FormsModule, FontAwesomeModule], exports: [MatBasicAudioPlayerComponent, MatAdvancedAudioPlayerComponent], providers: [AudioPlayerService] },] } ]; /** @nocollapse */ NgxAudioPlayerModule.ctorParameters = () => []; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ class Track { } /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ export { MatAdvancedAudioPlayerComponent, MatBasicAudioPlayerComponent, NgxAudioPlayerModule, Track, BaseAudioPlayerFunctions as ɵa, SecondsToMinutesPipe as ɵc, AudioPlayerService as ɵb }; //# sourceMappingURL=ngx-audio-player.js.map