feishin/src/renderer/features/playlists/components/playlist-list-table-view.tsx

104 lines
3.5 KiB
TypeScript
Raw Normal View History

import { RowDoubleClickedEvent } from '@ag-grid-community/core';
2023-07-15 11:21:44 -07:00
import type { AgGridReact as AgGridReactType } from '@ag-grid-community/react/lib/agGridReact';
import { useCallback } from 'react';
2023-07-15 11:21:44 -07:00
import { generatePath, useNavigate } from 'react-router';
import { api } from '/@/renderer/api';
import { queryKeys } from '/@/renderer/api/query-keys';
import { LibraryItem, PlaylistListQuery, PlaylistListResponse } from '/@/renderer/api/types';
2023-07-15 11:21:44 -07:00
import { VirtualGridAutoSizerContainer } from '/@/renderer/components/virtual-grid';
import { VirtualTable } from '/@/renderer/components/virtual-table';
import {
AgGridFetchFn,
useVirtualTable,
} from '/@/renderer/components/virtual-table/hooks/use-virtual-table';
2023-07-15 11:21:44 -07:00
import { PLAYLIST_CONTEXT_MENU_ITEMS } from '/@/renderer/features/context-menu/context-menu-items';
import { AppRoute } from '/@/renderer/router/routes';
import {
useCurrentServer,
useGeneralSettings,
useListStoreActions,
usePlaylistListFilter,
usePlaylistListStore,
2023-07-15 11:21:44 -07:00
} from '/@/renderer/store';
interface PlaylistListTableViewProps {
itemCount?: number;
tableRef: React.MutableRefObject<AgGridReactType | null>;
}
export const PlaylistListTableView = ({ tableRef, itemCount }: PlaylistListTableViewProps) => {
const navigate = useNavigate();
const server = useCurrentServer();
const { defaultFullPlaylist } = useGeneralSettings();
const { setTable, setTablePagination } = useListStoreActions();
const pageKey = 'playlist';
const filter = usePlaylistListFilter({ key: pageKey });
const listProperties = usePlaylistListStore({ key: pageKey });
console.log('listProperties :>> ', listProperties);
const fetchFn: AgGridFetchFn<
PlaylistListResponse,
Omit<PlaylistListQuery, 'startIndex'>
> = useCallback(
async ({ filter, limit, startIndex }, signal) => {
const res = api.controller.getPlaylistList({
apiClientProps: {
server,
signal,
2023-07-15 11:21:44 -07:00
},
query: {
...filter,
limit,
sortBy: filter.sortBy,
sortOrder: filter.sortOrder,
startIndex,
2023-07-15 11:21:44 -07:00
},
});
return res;
},
[server],
2023-07-15 11:21:44 -07:00
);
const handleRowDoubleClick = (e: RowDoubleClickedEvent) => {
if (!e.data) return;
if (defaultFullPlaylist) {
navigate(generatePath(AppRoute.PLAYLISTS_DETAIL_SONGS, { playlistId: e.data.id }));
} else {
navigate(generatePath(AppRoute.PLAYLISTS_DETAIL, { playlistId: e.data.id }));
}
2023-07-15 11:21:44 -07:00
};
const tableProps = useVirtualTable<PlaylistListResponse, Omit<PlaylistListQuery, 'startIndex'>>(
{
contextMenu: PLAYLIST_CONTEXT_MENU_ITEMS,
fetch: {
filter,
fn: fetchFn,
itemCount,
queryKey: queryKeys.playlists.list,
server,
},
itemCount,
itemType: LibraryItem.PLAYLIST,
pageKey,
properties: listProperties,
setTable,
setTablePagination,
tableRef,
},
);
2023-07-15 11:21:44 -07:00
return (
<VirtualGridAutoSizerContainer>
<VirtualTable
key={`table-${tableProps.rowHeight}-${server?.id}`}
ref={tableRef}
{...tableProps}
onRowDoubleClicked={handleRowDoubleClick}
/>
</VirtualGridAutoSizerContainer>
2023-07-15 11:21:44 -07:00
);
};