mirror of
https://github.com/movie-web/movie-web.git
synced 2025-01-07 23:10:42 +01:00
7b3452c535
Co-authored-by: Jip Frijlink <JipFr@users.noreply.github.com>
43 lines
1.0 KiB
TypeScript
43 lines
1.0 KiB
TypeScript
import { MakeSlice } from "@/stores/player/slices/types";
|
|
|
|
export interface PlayingSlice {
|
|
mediaPlaying: {
|
|
isPlaying: boolean;
|
|
isPaused: boolean;
|
|
isSeeking: boolean; // seeking with progress bar
|
|
isDragSeeking: boolean; // is seeking for our custom progress bar
|
|
isLoading: boolean; // buffering or not
|
|
hasPlayedOnce: boolean; // has the video played at all?
|
|
volume: number;
|
|
playbackSpeed: number;
|
|
};
|
|
play(): void;
|
|
pause(): void;
|
|
}
|
|
|
|
export const createPlayingSlice: MakeSlice<PlayingSlice> = (set) => ({
|
|
mediaPlaying: {
|
|
isPlaying: false,
|
|
isPaused: true,
|
|
isLoading: false,
|
|
isSeeking: false,
|
|
isDragSeeking: false,
|
|
isFirstLoading: true,
|
|
hasPlayedOnce: false,
|
|
volume: 1,
|
|
playbackSpeed: 1,
|
|
},
|
|
play() {
|
|
set((state) => {
|
|
state.mediaPlaying.isPlaying = true;
|
|
state.mediaPlaying.isPaused = false;
|
|
});
|
|
},
|
|
pause() {
|
|
set((state) => {
|
|
state.mediaPlaying.isPlaying = false;
|
|
state.mediaPlaying.isPaused = false;
|
|
});
|
|
},
|
|
});
|