mirror of
https://github.com/jeffvli/feishin.git
synced 2026-05-16 21:50:35 +02:00
add mpris
This commit is contained in:
@@ -5,6 +5,7 @@ import { UserFavoriteEventPayload, UserRatingEventPayload } from '/@/renderer/ev
|
|||||||
import { useDiscordRpc } from '/@/renderer/features/discord-rpc/use-discord-rpc';
|
import { useDiscordRpc } from '/@/renderer/features/discord-rpc/use-discord-rpc';
|
||||||
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 { useMPRIS } from '/@/renderer/features/player/hooks/use-mpris';
|
||||||
import { usePowerSaveBlocker } from '/@/renderer/features/player/hooks/use-power-save-blocker';
|
import { usePowerSaveBlocker } from '/@/renderer/features/player/hooks/use-power-save-blocker';
|
||||||
import { useScrobble } from '/@/renderer/features/player/hooks/use-scrobble';
|
import { useScrobble } from '/@/renderer/features/player/hooks/use-scrobble';
|
||||||
import {
|
import {
|
||||||
@@ -23,6 +24,7 @@ export const AudioPlayers = () => {
|
|||||||
useScrobble();
|
useScrobble();
|
||||||
usePowerSaveBlocker();
|
usePowerSaveBlocker();
|
||||||
useDiscordRpc();
|
useDiscordRpc();
|
||||||
|
useMPRIS();
|
||||||
|
|
||||||
// Listen to favorite and rating events to update queue songs
|
// Listen to favorite and rating events to update queue songs
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
|||||||
@@ -0,0 +1,68 @@
|
|||||||
|
import isElectron from 'is-electron';
|
||||||
|
import { useEffect } from 'react';
|
||||||
|
|
||||||
|
import { usePlayerEvents } from '/@/renderer/features/player/audio-player/hooks/use-player-events';
|
||||||
|
import { usePlayerStore } from '/@/renderer/store';
|
||||||
|
|
||||||
|
const ipc = isElectron() ? window.api.ipc : null;
|
||||||
|
const utils = isElectron() ? window.api.utils : null;
|
||||||
|
const mpris = isElectron() && utils?.isLinux() ? window.api.mpris : null;
|
||||||
|
|
||||||
|
export const useMPRIS = () => {
|
||||||
|
const player = usePlayerStore();
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.requestToggleRepeat(() => {
|
||||||
|
player.toggleRepeat();
|
||||||
|
});
|
||||||
|
|
||||||
|
mpris?.requestToggleShuffle(() => {
|
||||||
|
player.toggleShuffle();
|
||||||
|
});
|
||||||
|
|
||||||
|
return () => {
|
||||||
|
ipc?.removeAllListeners('mpris-request-toggle-repeat');
|
||||||
|
ipc?.removeAllListeners('mpris-request-toggle-shuffle');
|
||||||
|
};
|
||||||
|
}, [player]);
|
||||||
|
|
||||||
|
usePlayerEvents(
|
||||||
|
{
|
||||||
|
onPlayerProgress: (properties) => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const timestamp = properties.timestamp;
|
||||||
|
mpris?.updatePosition(timestamp);
|
||||||
|
},
|
||||||
|
onPlayerRepeat: () => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.toggleRepeat();
|
||||||
|
},
|
||||||
|
onPlayerSeek: (properties) => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const seconds = properties.seconds;
|
||||||
|
mpris?.updateSeek(seconds);
|
||||||
|
},
|
||||||
|
onPlayerShuffle: () => {
|
||||||
|
if (!mpris) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpris?.toggleShuffle();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
[],
|
||||||
|
);
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user