Files
jellyfin-audio-player/src/utility/PlaybackService.ts

86 lines
2.9 KiB
TypeScript
Raw Normal View History

2020-06-16 21:41:02 +02:00
/**
* This is the code that will run tied to the player.
*
* The code here might keep running in the background.
*
* You should put everything here that should be tied to the playback but not the UI
* such as processing media buttons or analytics
*/
2023-04-27 15:08:10 +02:00
import TrackPlayer, { Event, State } from 'react-native-track-player';
import store from '@/store';
2024-01-28 23:53:06 +01:00
import { setTimerDate } from '@/store/sleep-timer';
import { sendPlaybackEvent } from './JellyfinApi/playback';
2020-06-16 21:41:02 +02:00
export default async function() {
TrackPlayer.addEventListener(Event.RemotePlay, () => {
2020-06-16 21:41:02 +02:00
TrackPlayer.play();
});
TrackPlayer.addEventListener(Event.RemotePause, () => {
2020-06-16 21:41:02 +02:00
TrackPlayer.pause();
});
TrackPlayer.addEventListener(Event.RemoteNext, () => {
2020-06-16 21:41:02 +02:00
TrackPlayer.skipToNext();
});
TrackPlayer.addEventListener(Event.RemotePrevious, () => {
2020-06-16 21:41:02 +02:00
TrackPlayer.skipToPrevious();
});
TrackPlayer.addEventListener(Event.RemoteStop, () => {
2022-11-12 16:22:39 +01:00
TrackPlayer.reset();
2020-06-16 21:41:02 +02:00
});
2020-06-17 15:28:21 +02:00
TrackPlayer.addEventListener(Event.RemoteSeek, (event) => {
2020-06-17 15:28:21 +02:00
TrackPlayer.seekTo(event.position);
});
2023-04-27 15:08:10 +02:00
TrackPlayer.addEventListener(Event.PlaybackActiveTrackChanged, async (e) => {
2023-04-27 15:08:10 +02:00
// Retrieve the current settings from the Redux store
const settings = store.getState().settings;
// GUARD: Only report playback when the settings is enabled
if (settings.enablePlaybackReporting && 'track' in e) {
// GUARD: End the previous track if it's about to end
if (e.lastTrack) {
sendPlaybackEvent('/Sessions/Playing/Stopped', e.lastTrack, e.lastPosition);
}
sendPlaybackEvent('/Sessions/Playing', e.track);
2023-04-27 15:08:10 +02:00
}
});
TrackPlayer.addEventListener(Event.PlaybackProgressUpdated, () => {
// Retrieve the current settings from the Redux store
2024-01-28 23:53:06 +01:00
const { settings, sleepTimer } = store.getState();
2023-04-27 15:08:10 +02:00
// GUARD: Only report playback when the settings is enabled
if (settings.enablePlaybackReporting) {
sendPlaybackEvent('/Sessions/Playing/Progress');
2023-04-27 15:08:10 +02:00
}
2023-09-26 09:48:11 +03:00
// check if timerDate is undefined, otherwise start timer
2024-01-28 23:53:06 +01:00
if (sleepTimer.date && sleepTimer.date < new Date().valueOf()) {
2023-09-26 09:48:11 +03:00
TrackPlayer.pause();
store.dispatch(setTimerDate(null));
}
2023-04-27 15:08:10 +02:00
});
TrackPlayer.addEventListener(Event.PlaybackState, (event) => {
// Retrieve the current settings from the Redux store
const settings = store.getState().settings;
2023-04-27 15:08:10 +02:00
// GUARD: Only report playback when the settings is enabled
if (settings.enablePlaybackReporting) {
// GUARD: Only respond to stopped events
if (event.state === State.Stopped) {
sendPlaybackEvent('/Sessions/Playing/Stopped');
} else if (event.state === State.Paused) {
sendPlaybackEvent('/Sessions/Playing/Progress');
2023-04-27 15:08:10 +02:00
}
}
});
2020-06-17 15:28:21 +02:00
2020-06-16 21:41:02 +02:00
}