mirror of
https://github.com/jeffvli/feishin.git
synced 2026-06-14 23:44:01 +02:00
fix mpris
This commit is contained in:
@@ -115,7 +115,7 @@ ipcMain.on('update-position', (_event, arg: number) => {
|
|||||||
mprisPlayer.getPosition = () => arg * 1e6;
|
mprisPlayer.getPosition = () => arg * 1e6;
|
||||||
});
|
});
|
||||||
|
|
||||||
ipcMain.on('mpris-update-seek', (_event, arg) => {
|
ipcMain.on('update-seek', (_event, arg) => {
|
||||||
mprisPlayer.seeked(arg * 1e6);
|
mprisPlayer.seeked(arg * 1e6);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
+35
-9
@@ -1,21 +1,42 @@
|
|||||||
import { ipcRenderer, IpcRendererEvent } from 'electron';
|
import { ipcRenderer, IpcRendererEvent } from 'electron';
|
||||||
|
|
||||||
import { PlayerRepeat } from '/@/shared/types/types';
|
import { QueueSong } from '/@/shared/types/domain-types';
|
||||||
|
import { PlayerRepeat, PlayerStatus } from '/@/shared/types/types';
|
||||||
|
|
||||||
const updatePosition = (timeSec: number) => {
|
const updatePosition = (timeSec: number) => {
|
||||||
ipcRenderer.send('mpris-update-position', timeSec);
|
ipcRenderer.send('update-position', timeSec);
|
||||||
};
|
};
|
||||||
|
|
||||||
const updateSeek = (timeSec: number) => {
|
const updateSeek = (timeSec: number) => {
|
||||||
ipcRenderer.send('mpris-update-seek', timeSec);
|
ipcRenderer.send('update-seek', timeSec);
|
||||||
};
|
};
|
||||||
|
|
||||||
const toggleRepeat = () => {
|
const updateVolume = (volume: number) => {
|
||||||
ipcRenderer.send('mpris-toggle-repeat');
|
ipcRenderer.send('update-volume', volume);
|
||||||
};
|
};
|
||||||
|
|
||||||
const toggleShuffle = () => {
|
const updateStatus = (status: PlayerStatus) => {
|
||||||
ipcRenderer.send('mpris-toggle-shuffle');
|
ipcRenderer.send('update-playback', status);
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateRepeat = (repeat: PlayerRepeat) => {
|
||||||
|
ipcRenderer.send('update-repeat', repeat);
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateShuffle = (shuffle: boolean) => {
|
||||||
|
ipcRenderer.send('update-shuffle', shuffle);
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateSong = (song: QueueSong | undefined) => {
|
||||||
|
ipcRenderer.send('update-song', song);
|
||||||
|
};
|
||||||
|
|
||||||
|
const requestSeek = (cb: (event: IpcRendererEvent, data: { offset: number }) => void) => {
|
||||||
|
ipcRenderer.on('request-seek', cb);
|
||||||
|
};
|
||||||
|
|
||||||
|
const requestPosition = (cb: (event: IpcRendererEvent, data: { position: number }) => void) => {
|
||||||
|
ipcRenderer.on('request-position', cb);
|
||||||
};
|
};
|
||||||
|
|
||||||
const requestToggleRepeat = (
|
const requestToggleRepeat = (
|
||||||
@@ -31,12 +52,17 @@ const requestToggleShuffle = (
|
|||||||
};
|
};
|
||||||
|
|
||||||
export const mpris = {
|
export const mpris = {
|
||||||
|
requestPosition,
|
||||||
|
requestSeek,
|
||||||
requestToggleRepeat,
|
requestToggleRepeat,
|
||||||
requestToggleShuffle,
|
requestToggleShuffle,
|
||||||
toggleRepeat,
|
|
||||||
toggleShuffle,
|
|
||||||
updatePosition,
|
updatePosition,
|
||||||
|
updateRepeat,
|
||||||
updateSeek,
|
updateSeek,
|
||||||
|
updateShuffle,
|
||||||
|
updateSong,
|
||||||
|
updateStatus,
|
||||||
|
updateVolume,
|
||||||
};
|
};
|
||||||
|
|
||||||
export type Mpris = typeof mpris;
|
export type Mpris = typeof mpris;
|
||||||
|
|||||||
@@ -133,8 +133,6 @@ export function MpvPlayer() {
|
|||||||
return () => clearInterval(interval);
|
return () => clearInterval(interval);
|
||||||
}, [localPlayerStatus, setTimestamp]);
|
}, [localPlayerStatus, setTimestamp]);
|
||||||
|
|
||||||
useMainPlayerListener();
|
|
||||||
|
|
||||||
const currentUrl = useSongUrl(currentSong, true, transcode);
|
const currentUrl = useSongUrl(currentSong, true, transcode);
|
||||||
const nextUrl = useSongUrl(nextSong, false, transcode);
|
const nextUrl = useSongUrl(nextSong, false, transcode);
|
||||||
|
|
||||||
|
|||||||
@@ -230,8 +230,6 @@ export function WaveSurferPlayer() {
|
|||||||
return () => clearInterval(interval);
|
return () => clearInterval(interval);
|
||||||
}, [localPlayerStatus, num, setTimestamp, transitionType]);
|
}, [localPlayerStatus, num, setTimestamp, transitionType]);
|
||||||
|
|
||||||
useMainPlayerListener();
|
|
||||||
|
|
||||||
const player1Url = useSongUrl(player1, num === 1, transcode);
|
const player1Url = useSongUrl(player1, num === 1, transcode);
|
||||||
const player2Url = useSongUrl(player2, num === 2, transcode);
|
const player2Url = useSongUrl(player2, num === 2, transcode);
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ import {
|
|||||||
WebPlayerEngine,
|
WebPlayerEngine,
|
||||||
WebPlayerEngineHandle,
|
WebPlayerEngineHandle,
|
||||||
} from '/@/renderer/features/player/audio-player/engine/web-player-engine';
|
} from '/@/renderer/features/player/audio-player/engine/web-player-engine';
|
||||||
import { useMainPlayerListener } from '/@/renderer/features/player/audio-player/hooks/use-main-player-listener';
|
|
||||||
import { usePlayerEvents } from '/@/renderer/features/player/audio-player/hooks/use-player-events';
|
import { usePlayerEvents } from '/@/renderer/features/player/audio-player/hooks/use-player-events';
|
||||||
import { useSongUrl } from '/@/renderer/features/player/audio-player/hooks/use-stream-url';
|
import { useSongUrl } from '/@/renderer/features/player/audio-player/hooks/use-stream-url';
|
||||||
import { PlayerOnProgressProps } from '/@/renderer/features/player/audio-player/types';
|
import { PlayerOnProgressProps } from '/@/renderer/features/player/audio-player/types';
|
||||||
@@ -262,8 +261,6 @@ export function WebPlayer() {
|
|||||||
return () => clearInterval(interval);
|
return () => clearInterval(interval);
|
||||||
}, [localPlayerStatus, num, setTimestamp, transitionType]);
|
}, [localPlayerStatus, num, setTimestamp, transitionType]);
|
||||||
|
|
||||||
useMainPlayerListener();
|
|
||||||
|
|
||||||
const player1Url = useSongUrl(player1, num === 1, transcode);
|
const player1Url = useSongUrl(player1, num === 1, transcode);
|
||||||
const player2Url = useSongUrl(player2, num === 2, transcode);
|
const player2Url = useSongUrl(player2, num === 2, transcode);
|
||||||
|
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import { useEffect } from 'react';
|
|||||||
import { eventEmitter } from '/@/renderer/events/event-emitter';
|
import { eventEmitter } from '/@/renderer/events/event-emitter';
|
||||||
import { UserFavoriteEventPayload, UserRatingEventPayload } from '/@/renderer/events/events';
|
import { UserFavoriteEventPayload, UserRatingEventPayload } from '/@/renderer/events/events';
|
||||||
import { useDiscordRpc } from '/@/renderer/features/discord-rpc/use-discord-rpc';
|
import { useDiscordRpc } from '/@/renderer/features/discord-rpc/use-discord-rpc';
|
||||||
|
import { useMainPlayerListener } from '/@/renderer/features/player/audio-player/hooks/use-main-player-listener';
|
||||||
import { MpvPlayer } from '/@/renderer/features/player/audio-player/mpv-player';
|
import { MpvPlayer } from '/@/renderer/features/player/audio-player/mpv-player';
|
||||||
import { WebPlayer } from '/@/renderer/features/player/audio-player/web-player';
|
import { WebPlayer } from '/@/renderer/features/player/audio-player/web-player';
|
||||||
import { useMediaSession } from '/@/renderer/features/player/hooks/use-media-session';
|
import { useMediaSession } from '/@/renderer/features/player/hooks/use-media-session';
|
||||||
@@ -26,6 +27,7 @@ export const AudioPlayers = () => {
|
|||||||
usePowerSaveBlocker();
|
usePowerSaveBlocker();
|
||||||
useDiscordRpc();
|
useDiscordRpc();
|
||||||
useMPRIS();
|
useMPRIS();
|
||||||
|
useMainPlayerListener();
|
||||||
useMediaSession();
|
useMediaSession();
|
||||||
|
|
||||||
// Listen to favorite and rating events to update queue songs
|
// Listen to favorite and rating events to update queue songs
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
import isElectron from 'is-electron';
|
import isElectron from 'is-electron';
|
||||||
import { useEffect } from 'react';
|
import { useEffect, useRef } from 'react';
|
||||||
|
|
||||||
import { usePlayerEvents } from '/@/renderer/features/player/audio-player/hooks/use-player-events';
|
import { usePlayerEvents } from '/@/renderer/features/player/audio-player/hooks/use-player-events';
|
||||||
import { usePlayerStore } from '/@/renderer/store';
|
import { usePlayerStore } from '/@/renderer/store';
|
||||||
|
import { PlayerShuffle } from '/@/shared/types/types';
|
||||||
|
|
||||||
const ipc = isElectron() ? window.api.ipc : null;
|
const ipc = isElectron() ? window.api.ipc : null;
|
||||||
const utils = isElectron() ? window.api.utils : null;
|
const utils = isElectron() ? window.api.utils : null;
|
||||||
@@ -16,6 +17,14 @@ export const useMPRIS = () => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mpris?.requestPosition((_e: unknown, data: { position: number }) => {
|
||||||
|
player.mediaSeekToTimestamp(data.position);
|
||||||
|
});
|
||||||
|
|
||||||
|
mpris?.requestSeek((_e: unknown, data: { offset: number }) => {
|
||||||
|
player.mediaSkipForward(data.offset);
|
||||||
|
});
|
||||||
|
|
||||||
mpris?.requestToggleRepeat(() => {
|
mpris?.requestToggleRepeat(() => {
|
||||||
player.toggleRepeat();
|
player.toggleRepeat();
|
||||||
});
|
});
|
||||||
@@ -27,11 +36,38 @@ export const useMPRIS = () => {
|
|||||||
return () => {
|
return () => {
|
||||||
ipc?.removeAllListeners('mpris-request-toggle-repeat');
|
ipc?.removeAllListeners('mpris-request-toggle-repeat');
|
||||||
ipc?.removeAllListeners('mpris-request-toggle-shuffle');
|
ipc?.removeAllListeners('mpris-request-toggle-shuffle');
|
||||||
|
ipc?.removeAllListeners('request-position');
|
||||||
|
ipc?.removeAllListeners('request-seek');
|
||||||
};
|
};
|
||||||
}, [player]);
|
}, [player]);
|
||||||
|
|
||||||
|
const isInitializedRef = useRef(false);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (isInitializedRef.current) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
isInitializedRef.current = true;
|
||||||
|
|
||||||
|
const currentSong = player.getCurrentSong();
|
||||||
|
|
||||||
|
if (!currentSong) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.updateSong(currentSong);
|
||||||
|
}, [player]);
|
||||||
|
|
||||||
usePlayerEvents(
|
usePlayerEvents(
|
||||||
{
|
{
|
||||||
|
onCurrentSongChange: (properties) => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.updateSong(properties.song);
|
||||||
|
},
|
||||||
onPlayerProgress: (properties) => {
|
onPlayerProgress: (properties) => {
|
||||||
if (!mpris) {
|
if (!mpris) {
|
||||||
return;
|
return;
|
||||||
@@ -40,12 +76,12 @@ export const useMPRIS = () => {
|
|||||||
const timestamp = properties.timestamp;
|
const timestamp = properties.timestamp;
|
||||||
mpris?.updatePosition(timestamp);
|
mpris?.updatePosition(timestamp);
|
||||||
},
|
},
|
||||||
onPlayerRepeat: () => {
|
onPlayerRepeat: (properties) => {
|
||||||
if (!mpris) {
|
if (!mpris) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
mpris?.toggleRepeat();
|
mpris?.updateRepeat(properties.repeat);
|
||||||
},
|
},
|
||||||
onPlayerSeek: (properties) => {
|
onPlayerSeek: (properties) => {
|
||||||
if (!mpris) {
|
if (!mpris) {
|
||||||
@@ -55,12 +91,27 @@ export const useMPRIS = () => {
|
|||||||
const seconds = properties.seconds;
|
const seconds = properties.seconds;
|
||||||
mpris?.updateSeek(seconds);
|
mpris?.updateSeek(seconds);
|
||||||
},
|
},
|
||||||
onPlayerShuffle: () => {
|
onPlayerShuffle: (properties) => {
|
||||||
if (!mpris) {
|
if (!mpris) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
mpris?.toggleShuffle();
|
const isShuffleEnabled = properties.shuffle !== PlayerShuffle.NONE;
|
||||||
|
mpris?.updateShuffle(isShuffleEnabled);
|
||||||
|
},
|
||||||
|
onPlayerStatus: (properties) => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.updateStatus(properties.status);
|
||||||
|
},
|
||||||
|
onPlayerVolume: (properties) => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.updateVolume(properties.volume);
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
[],
|
[],
|
||||||
|
|||||||
Reference in New Issue
Block a user