mirror of
https://github.com/antebudimir/feishin.git
synced 2025-12-31 18:13:31 +00:00
* Remove 1920px max width * Fix position of list controls menu * Match size and color of search input * Adjust library header sizing * Move app menu to sidebar * Increase row buffer on play queue list * Fix query builder styles * Fix playerbar slider track bg * Adjust titlebar styles * Fix invalid modal prop * Various adjustments to detail pages * Fix sidebar height calculation * Fix list null indicators, add filter indicator * Adjust playqueue styles * Fix jellyfin releaseYear normalization * Suppress browser context menu on ag-grid * Add radius to drawer queue -- normalize layout * Add modal styles to provider theme * Fix playlist song list pagination * Add disc number to albums with more than one disc * Fix query builder boolean values * Adjust input placeholder color * Properly handle rating/favorite from context menu on table * Conform dropdown menu styles to context menu * Increase sort type select width * Fix drawer queue radius * Change primary color * Prevent volume wheel from invalid values * Add icons to query builder dropdowns * Update notification styles * Update scrollbar thumb styles * Remove "add to playlist" on smart playlists * Fix "add to playlist" from context menu
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
import { MouseEvent } from 'react';
|
|
import type { ICellRendererParams } from '@ag-grid-community/core';
|
|
import { Rating } from '/@/renderer/components/rating';
|
|
import { CellContainer } from '/@/renderer/components/virtual-table/cells/generic-cell';
|
|
import { useUpdateRating } from '/@/renderer/components/virtual-table/hooks/use-rating';
|
|
|
|
export const RatingCell = ({ value, node }: ICellRendererParams) => {
|
|
const updateRatingMutation = useUpdateRating();
|
|
|
|
const handleUpdateRating = (rating: number) => {
|
|
if (!value) return;
|
|
|
|
updateRatingMutation.mutate(
|
|
{
|
|
_serverId: value?.serverId,
|
|
query: {
|
|
item: [value],
|
|
rating,
|
|
},
|
|
},
|
|
{
|
|
onSuccess: () => {
|
|
node.setData({ ...node.data, userRating: rating });
|
|
},
|
|
},
|
|
);
|
|
};
|
|
|
|
const handleClearRating = (e: MouseEvent<HTMLDivElement>) => {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
updateRatingMutation.mutate(
|
|
{
|
|
_serverId: value?.serverId,
|
|
query: {
|
|
item: [value],
|
|
rating: 0,
|
|
},
|
|
},
|
|
{
|
|
onSuccess: () => {
|
|
node.setData({ ...node.data, userRating: 0 });
|
|
},
|
|
},
|
|
);
|
|
};
|
|
|
|
return (
|
|
<CellContainer position="center">
|
|
<Rating
|
|
size="xs"
|
|
value={value?.userRating}
|
|
onChange={handleUpdateRating}
|
|
onClick={handleClearRating}
|
|
/>
|
|
</CellContainer>
|
|
);
|
|
};
|