mirror of
https://github.com/jeffvli/feishin.git
synced 2026-06-18 09:24:19 +02:00
move external playback fetch to context
This commit is contained in:
@@ -1,11 +1,9 @@
|
||||
import { useQueryClient } from '@tanstack/react-query';
|
||||
import { useEffect, useMemo, useRef } from 'react';
|
||||
import { useNavigate } from 'react-router';
|
||||
|
||||
import { getTitlePath } from '/@/renderer/components/item-list/helpers/get-title-path';
|
||||
import { ItemListStateItemWithRequiredProperties } from '/@/renderer/components/item-list/helpers/item-list-state';
|
||||
import { DefaultItemControlProps, ItemControls } from '/@/renderer/components/item-list/types';
|
||||
import { albumQueries } from '/@/renderer/features/albums/api/album-api';
|
||||
import { ContextMenuController } from '/@/renderer/features/context-menu/context-menu-controller';
|
||||
import { usePlayer } from '/@/renderer/features/player/context/player-context';
|
||||
import { useSetFavorite } from '/@/renderer/features/shared/hooks/use-set-favorite';
|
||||
@@ -36,7 +34,6 @@ const itemTypeMapping = {
|
||||
|
||||
export const useDefaultItemListControls = (args?: UseDefaultItemListControlsArgs) => {
|
||||
const player = usePlayer();
|
||||
const queryClient = useQueryClient();
|
||||
const navigate = useNavigate();
|
||||
const navigateRef = useRef(navigate);
|
||||
const setFavorite = useSetFavorite();
|
||||
@@ -391,34 +388,9 @@ export const useDefaultItemListControls = (args?: UseDefaultItemListControlsArgs
|
||||
(item as Song & { _serverType?: ServerType })._serverType ===
|
||||
ServerType.EXTERNAL;
|
||||
|
||||
if (isExternal) {
|
||||
if (
|
||||
itemType === LibraryItem.SONG ||
|
||||
itemType === LibraryItem.PLAYLIST_SONG ||
|
||||
(item as { _itemType?: LibraryItem })._itemType === LibraryItem.SONG
|
||||
) {
|
||||
player.addToQueueByData([item as Song], playType, item.id);
|
||||
return;
|
||||
}
|
||||
if (itemType === LibraryItem.ALBUM) {
|
||||
(async () => {
|
||||
try {
|
||||
const album = await queryClient.fetchQuery(
|
||||
albumQueries.detail({
|
||||
query: { id: item.id },
|
||||
serverId: 'musicbrainz',
|
||||
}),
|
||||
);
|
||||
const songs = album?.songs ?? [];
|
||||
if (songs.length > 0) {
|
||||
player.addToQueueByData(songs, playType);
|
||||
}
|
||||
} catch {
|
||||
console.error('Error fetching album songs for item', item);
|
||||
}
|
||||
})();
|
||||
return;
|
||||
}
|
||||
if (isExternal && itemType === LibraryItem.SONG) {
|
||||
player.addToQueueByData([item as Song], playType, item.id);
|
||||
return;
|
||||
}
|
||||
|
||||
player.addToQueueByFetch(item._serverId, [item.id], itemType, playType);
|
||||
@@ -458,7 +430,6 @@ export const useDefaultItemListControls = (args?: UseDefaultItemListControlsArgs
|
||||
onColumnResized,
|
||||
overrides,
|
||||
player,
|
||||
queryClient,
|
||||
setFavorite,
|
||||
setRating,
|
||||
]);
|
||||
|
||||
Reference in New Issue
Block a user