1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00
unleash.unleash/frontend/src/hooks/usePinnedFavorites.ts
Nuno Góis 4167a60588
feat: biome lint frontend (#4903)
Follows up on https://github.com/Unleash/unleash/pull/4853 to add Biome
to the frontend as well.


![image](https://github.com/Unleash/unleash/assets/14320932/1906faf1-fc29-4172-a4d4-b2716d72cd65)

Added a few `biome-ignore` to speed up the process but we may want to
check and fix them in the future.
2023-10-02 13:25:46 +01:00

58 lines
1.7 KiB
TypeScript

import { useMemo, useState } from 'react';
import { sortTypes } from 'utils/sortTypes';
import type { Row, SortByFn } from 'react-table';
import { usePlausibleTracker } from './usePlausibleTracker';
type WithFavorite = {
favorite: boolean;
[key: string]: any;
};
export const sortTypesWithFavorites: Record<
keyof typeof sortTypes,
SortByFn<object> // TODO: possible type improvement in react-table v8
> = Object.assign(
{},
...Object.entries(sortTypes).map(([key, value]) => ({
[key]: (
v1: Row<WithFavorite>,
v2: Row<WithFavorite>,
id: string,
desc?: boolean,
) => {
if (v1?.original?.favorite && !v2?.original?.favorite)
return desc ? 1 : -1;
if (!v1?.original?.favorite && v2?.original?.favorite)
return desc ? -1 : 1;
return value(v1, v2, id, desc);
},
})),
);
/**
* Move favorites to the top of the list.
*/
export const usePinnedFavorites = (initialState = false) => {
const [isFavoritesPinned, setIsFavoritesPinned] = useState(initialState);
const { trackEvent } = usePlausibleTracker();
const onChangeIsFavoritePinned = (newState: boolean) => {
trackEvent('favorite', {
props: {
eventType: `features ${!newState ? 'un' : ''}pinned `,
},
});
setIsFavoritesPinned(newState);
};
const enhancedSortTypes = useMemo(() => {
return isFavoritesPinned ? sortTypesWithFavorites : sortTypes;
}, [isFavoritesPinned]);
return {
isFavoritesPinned,
onChangeIsFavoritePinned,
sortTypes: enhancedSortTypes,
};
};