mirror of
https://github.com/captbaritone/webamp.git
synced 2026-01-24 02:36:00 +00:00
164 lines
3.7 KiB
JavaScript
164 lines
3.7 KiB
JavaScript
import MyFile from './myFile';
|
|
import skinParser from './skinParser';
|
|
import {BANDS} from './constants';
|
|
|
|
import {clamp} from './utils';
|
|
|
|
export function play(mediaPlayer) {
|
|
return (dispatch, getState) => {
|
|
if (getState().media.status === 'PLAYING') {
|
|
mediaPlayer.stop();
|
|
dispatch({type: 'SET_MEDIA_STATUS', status: 'STOPPED'});
|
|
} else {
|
|
mediaPlayer.play();
|
|
dispatch({type: 'SET_MEDIA_STATUS', status: 'PLAYING'});
|
|
}
|
|
};
|
|
}
|
|
|
|
export function pause(mediaPlayer) {
|
|
return (dispatch, getState) => {
|
|
const status = getState().media.status;
|
|
switch (status) {
|
|
case 'PAUSED':
|
|
mediaPlayer.play();
|
|
dispatch({type: 'SET_MEDIA_STATUS', status: 'PLAYING'});
|
|
break;
|
|
case 'PLAYING':
|
|
mediaPlayer.pause();
|
|
dispatch({type: 'SET_MEDIA_STATUS', status: 'PAUSED'});
|
|
break;
|
|
}
|
|
};
|
|
}
|
|
|
|
export function stop(mediaPlayer) {
|
|
return (dispatch) => {
|
|
mediaPlayer.stop();
|
|
dispatch({type: 'SET_MEDIA_STATUS', status: 'STOPPED'});
|
|
};
|
|
}
|
|
|
|
export function close(mediaPlayer) {
|
|
return (dispatch) => {
|
|
mediaPlayer.stop();
|
|
dispatch({type: 'CLOSE_WINAMP'});
|
|
};
|
|
}
|
|
|
|
export function setVolume(mediaPlayer, volume) {
|
|
const realVolume = clamp(volume, 0, 100);
|
|
mediaPlayer.setVolume(realVolume);
|
|
return {
|
|
type: 'SET_VOLUME',
|
|
volume: realVolume
|
|
};
|
|
}
|
|
|
|
export function adjustVolume(mediaPlayer, volumeDiff) {
|
|
return (dispatch, getState) => {
|
|
const currentVolume = getState().media.volume;
|
|
return dispatch(setVolume(mediaPlayer, currentVolume + volumeDiff));
|
|
};
|
|
}
|
|
|
|
export function setBalance(mediaPlayer, balance) {
|
|
balance = clamp(balance, -100, 100);
|
|
// The balance clips to the center
|
|
if (Math.abs(balance) < 25) {
|
|
balance = 0;
|
|
}
|
|
mediaPlayer.setBalance(balance);
|
|
return {
|
|
type: 'SET_BALANCE',
|
|
balance
|
|
};
|
|
}
|
|
|
|
|
|
export function toggleRepeat(mediaPlayer) {
|
|
mediaPlayer.toggleRepeat();
|
|
return {type: 'TOGGLE_REPEAT'};
|
|
}
|
|
|
|
export function toggleShuffle(mediaPlayer) {
|
|
mediaPlayer.toggleShuffle();
|
|
return {type: 'TOGGLE_SHUFFLE'};
|
|
}
|
|
|
|
export function setSkinFromFile(skinFile) {
|
|
return (dispatch) => {
|
|
dispatch({type: 'START_LOADING'});
|
|
skinParser(skinFile).then((skinData) => {
|
|
return dispatch({
|
|
type: 'SET_SKIN_DATA',
|
|
skinImages: skinData.images,
|
|
skinColors: skinData.colors,
|
|
skinPlaylistStyle: skinData.playlistStyle
|
|
});
|
|
});
|
|
};
|
|
}
|
|
|
|
export function setSkinFromUrl(url) {
|
|
const skinFile = new MyFile();
|
|
skinFile.setUrl(url);
|
|
return setSkinFromFile(skinFile);
|
|
}
|
|
|
|
export function setSkinFromFilename(filename) {
|
|
const url = `https://cdn.rawgit.com/captbaritone/winamp-skins/master/v2/${filename}`;
|
|
return setSkinFromUrl(url);
|
|
}
|
|
|
|
export function openFileDialog(winamp) {
|
|
winamp.openFileDialog();
|
|
}
|
|
|
|
export function setEqBand(mediaPlayer, band, value) {
|
|
mediaPlayer.setEqBand(band, value);
|
|
return (dispatch) => {
|
|
return dispatch({
|
|
type: 'SET_BAND_VALUE',
|
|
band,
|
|
value
|
|
});
|
|
};
|
|
}
|
|
|
|
function _setEqTo(mediaPlayer, value) {
|
|
return (dispatch) => {
|
|
Object.keys(BANDS).forEach((key) => {
|
|
const band = BANDS[key];
|
|
mediaPlayer.setEqBand(band, value);
|
|
dispatch({
|
|
type: 'SET_BAND_VALUE',
|
|
value,
|
|
band
|
|
});
|
|
});
|
|
};
|
|
}
|
|
|
|
export function setEqToMax(mediaPlayer) {
|
|
return _setEqTo(mediaPlayer, 100);
|
|
}
|
|
|
|
export function setEqToMid(mediaPlayer) {
|
|
return _setEqTo(mediaPlayer, 50);
|
|
}
|
|
|
|
export function setEqToMin(mediaPlayer) {
|
|
return _setEqTo(mediaPlayer, 0);
|
|
}
|
|
|
|
export function setPreamp(mediaPlayer, value) {
|
|
mediaPlayer.setPreamp(value);
|
|
return (dispatch) => {
|
|
return dispatch({
|
|
type: 'SET_BAND_VALUE',
|
|
band: 'preamp',
|
|
value
|
|
});
|
|
};
|
|
}
|