0

Merge pull request #228 from SoldierCorp/save-volume-settings

ADD: Save volume settings in localstorage
This commit is contained in:
gingervitis 2020-10-06 22:54:57 -07:00 committed by GitHub
commit 1eb7c1985b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 11 additions and 0 deletions

View File

@ -1,6 +1,8 @@
// https://docs.videojs.com/player // https://docs.videojs.com/player
import videojs from '/js/web_modules/videojs/dist/video.min.js'; import videojs from '/js/web_modules/videojs/dist/video.min.js';
import { getLocalStorage, setLocalStorage } from '../utils/helpers.js';
import { PLAYER_VOLUME } from '../utils/constants.js';
const VIDEO_ID = 'video'; const VIDEO_ID = 'video';
// TODO: This directory is customizable in the config. So we should expose this via the config API. // TODO: This directory is customizable in the config. So we should expose this via the config API.
@ -49,6 +51,7 @@ class OwncastPlayer {
this.startPlayer = this.startPlayer.bind(this); this.startPlayer = this.startPlayer.bind(this);
this.handleReady = this.handleReady.bind(this); this.handleReady = this.handleReady.bind(this);
this.handlePlaying = this.handlePlaying.bind(this); this.handlePlaying = this.handlePlaying.bind(this);
this.handleVolume = this.handleVolume.bind(this);
this.handleEnded = this.handleEnded.bind(this); this.handleEnded = this.handleEnded.bind(this);
this.handleError = this.handleError.bind(this); this.handleError = this.handleError.bind(this);
} }
@ -79,6 +82,8 @@ class OwncastPlayer {
startPlayer() { startPlayer() {
this.log('Start playing'); this.log('Start playing');
const source = { ...VIDEO_SRC }; const source = { ...VIDEO_SRC };
this.vjsPlayer.volume(getLocalStorage(PLAYER_VOLUME) || 1);
this.vjsPlayer.src(source); this.vjsPlayer.src(source);
// this.vjsPlayer.play(); // this.vjsPlayer.play();
} }
@ -87,6 +92,7 @@ class OwncastPlayer {
this.log('on Ready'); this.log('on Ready');
this.vjsPlayer.on('error', this.handleError); this.vjsPlayer.on('error', this.handleError);
this.vjsPlayer.on('playing', this.handlePlaying); this.vjsPlayer.on('playing', this.handlePlaying);
this.vjsPlayer.on('volumechange', this.handleVolume);
this.vjsPlayer.on('ended', this.handleEnded); this.vjsPlayer.on('ended', this.handleEnded);
if (this.appPlayerReadyCallback) { if (this.appPlayerReadyCallback) {
@ -95,6 +101,10 @@ class OwncastPlayer {
} }
} }
handleVolume() {
setLocalStorage(PLAYER_VOLUME, this.vjsPlayer.muted() ? 0 : this.vjsPlayer.volume());
}
handlePlaying() { handlePlaying() {
this.log('on Playing'); this.log('on Playing');
if (this.appPlayerPlayingCallback) { if (this.appPlayerPlayingCallback) {

View File

@ -18,6 +18,7 @@ export const MESSAGE_OFFLINE = 'Stream is offline.';
export const MESSAGE_ONLINE = 'Stream is online.'; export const MESSAGE_ONLINE = 'Stream is online.';
export const URL_OWNCAST = 'https://owncast.online'; // used in footer export const URL_OWNCAST = 'https://owncast.online'; // used in footer
export const PLAYER_VOLUME = 'owncast_volume';
export const KEY_USERNAME = 'owncast_username'; export const KEY_USERNAME = 'owncast_username';