2024-03-18 13:58:05 +01:00
|
|
|
import type { Row } from 'react-table';
|
2022-11-30 13:44:38 +01:00
|
|
|
import { sortTypesWithFavorites } from './usePinnedFavorites';
|
|
|
|
|
|
|
|
const data = [
|
|
|
|
{
|
|
|
|
id: 1,
|
|
|
|
favorite: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 2,
|
|
|
|
favorite: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 3,
|
|
|
|
favorite: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 4,
|
|
|
|
favorite: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 5,
|
|
|
|
favorite: false,
|
|
|
|
},
|
2023-10-02 14:25:46 +02:00
|
|
|
].map((d) => ({ values: d, original: d })) as unknown as Row<object>[];
|
2022-11-30 13:44:38 +01:00
|
|
|
|
|
|
|
test('puts favorite items first', () => {
|
|
|
|
const output = data.sort((a, b) =>
|
2023-10-02 14:25:46 +02:00
|
|
|
sortTypesWithFavorites.alphanumeric(a, b, 'id'),
|
2022-11-30 13:44:38 +01:00
|
|
|
);
|
|
|
|
const ids = output.map(({ values: { id } }) => id);
|
|
|
|
const favorites = output.map(({ values: { favorite } }) => favorite);
|
|
|
|
|
|
|
|
expect(ids).toEqual([1, 3, 2, 4, 5]);
|
|
|
|
expect(favorites).toEqual([true, true, false, false, false]);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('in descending order put favorites last (react-table will reverse order)', () => {
|
|
|
|
const output = data.sort((a, b) =>
|
2023-10-02 14:25:46 +02:00
|
|
|
sortTypesWithFavorites.alphanumeric(a, b, 'id', true),
|
2022-11-30 13:44:38 +01:00
|
|
|
);
|
|
|
|
const ids = output.map(({ values: { id } }) => id);
|
|
|
|
const favorites = output.map(({ values: { favorite } }) => favorite);
|
|
|
|
|
|
|
|
expect(ids).toEqual([2, 4, 5, 1, 3]);
|
|
|
|
expect(favorites).toEqual([false, false, false, true, true]);
|
|
|
|
});
|