Merge pull request #228 from SoldierCorp/save-volume-settings
ADD: Save volume settings in localstorage
This commit is contained in:
commit
1eb7c1985b
@ -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) {
|
||||||
|
@ -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';
|
||||||
|
Loading…
x
Reference in New Issue
Block a user