mirror of
https://github.com/jeffvli/feishin.git
synced 2026-06-14 23:44:01 +02:00
92 lines
3.5 KiB
TypeScript
92 lines
3.5 KiB
TypeScript
import { useQueryClient } from '@tanstack/react-query';
|
|
import { useCallback } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import { queryKeys } from '/@/renderer/api/query-keys';
|
|
import { usePlayer } from '/@/renderer/features/player/context/player-context';
|
|
import { songsQueries } from '/@/renderer/features/songs/api/songs-api';
|
|
import { useCurrentServerId, usePlayButtonBehavior } from '/@/renderer/store';
|
|
import { ContextMenu } from '/@/shared/components/context-menu/context-menu';
|
|
import { Song } from '/@/shared/types/domain-types';
|
|
import { Play } from '/@/shared/types/types';
|
|
|
|
interface PlayTrackRadioActionProps {
|
|
disabled?: boolean;
|
|
song: Song;
|
|
}
|
|
|
|
export const PlayTrackRadioAction = ({ disabled, song }: PlayTrackRadioActionProps) => {
|
|
const { t } = useTranslation();
|
|
const player = usePlayer();
|
|
const serverId = useCurrentServerId();
|
|
const queryClient = useQueryClient();
|
|
const playButtonBehavior = usePlayButtonBehavior();
|
|
|
|
const handlePlayTrackRadio = useCallback(
|
|
async (playType: Play) => {
|
|
if (!serverId || !song) return;
|
|
|
|
try {
|
|
const similarSongs = await queryClient.fetchQuery({
|
|
...songsQueries.similar({
|
|
query: {
|
|
songId: song.id,
|
|
},
|
|
serverId,
|
|
}),
|
|
queryKey: queryKeys.player.fetch({ similarSongs: song.id }),
|
|
});
|
|
|
|
if (similarSongs && similarSongs.length > 0) {
|
|
player.addToQueueByData([song, ...similarSongs], playType);
|
|
}
|
|
} catch (error) {
|
|
console.error('Failed to load track radio:', error);
|
|
}
|
|
},
|
|
[player, queryClient, serverId, song],
|
|
);
|
|
|
|
const handlePlayTrackRadioNow = useCallback(() => {
|
|
handlePlayTrackRadio(Play.NOW);
|
|
}, [handlePlayTrackRadio]);
|
|
|
|
const handlePlayTrackRadioNext = useCallback(() => {
|
|
handlePlayTrackRadio(Play.NEXT);
|
|
}, [handlePlayTrackRadio]);
|
|
|
|
const handlePlayTrackRadioLast = useCallback(() => {
|
|
handlePlayTrackRadio(Play.LAST);
|
|
}, [handlePlayTrackRadio]);
|
|
|
|
const defaultPlayTrackRadioAction = useCallback(() => {
|
|
handlePlayTrackRadio(playButtonBehavior);
|
|
}, [handlePlayTrackRadio, playButtonBehavior]);
|
|
|
|
return (
|
|
<ContextMenu.Submenu>
|
|
<ContextMenu.SubmenuTarget>
|
|
<ContextMenu.Item
|
|
disabled={disabled}
|
|
leftIcon="radio"
|
|
onSelect={defaultPlayTrackRadioAction}
|
|
rightIcon="arrowRightS"
|
|
>
|
|
{t('player.trackRadio', { postProcess: 'sentenceCase' })}
|
|
</ContextMenu.Item>
|
|
</ContextMenu.SubmenuTarget>
|
|
<ContextMenu.SubmenuContent>
|
|
<ContextMenu.Item leftIcon="mediaPlay" onSelect={handlePlayTrackRadioNow}>
|
|
{t('player.play', { postProcess: 'sentenceCase' })}
|
|
</ContextMenu.Item>
|
|
<ContextMenu.Item leftIcon="mediaPlayNext" onSelect={handlePlayTrackRadioNext}>
|
|
{t('player.addNext', { postProcess: 'sentenceCase' })}
|
|
</ContextMenu.Item>
|
|
<ContextMenu.Item leftIcon="mediaPlayLast" onSelect={handlePlayTrackRadioLast}>
|
|
{t('player.addLast', { postProcess: 'sentenceCase' })}
|
|
</ContextMenu.Item>
|
|
</ContextMenu.SubmenuContent>
|
|
</ContextMenu.Submenu>
|
|
);
|
|
};
|