mirror of
https://github.com/Unleash/unleash.git
synced 2024-12-28 00:06:53 +01:00
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
|
import { useMemo, useState } from 'react';
|
||
|
import { sortTypes } from 'utils/sortTypes';
|
||
|
import type { Row, SortByFn } from 'react-table';
|
||
|
|
||
|
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?.values?.favorite && !v2?.values?.favorite)
|
||
|
return desc ? 1 : -1;
|
||
|
if (!v1?.values?.favorite && v2?.values?.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 onChangeIsFavoritePinned = () => {
|
||
|
setIsFavoritesPinned(!isFavoritesPinned);
|
||
|
};
|
||
|
|
||
|
const enhancedSortTypes = useMemo(
|
||
|
() => (isFavoritesPinned ? sortTypesWithFavorites : sortTypes),
|
||
|
[isFavoritesPinned]
|
||
|
);
|
||
|
|
||
|
return {
|
||
|
isFavoritesPinned,
|
||
|
onChangeIsFavoritePinned,
|
||
|
sortTypes: enhancedSortTypes,
|
||
|
};
|
||
|
};
|