Skip to content

Commit

Permalink
fix: on pagination keep a unique list of channels in the ChannelList
Browse files Browse the repository at this point in the history
  • Loading branch information
MartinCupela committed Oct 5, 2023
1 parent cd07418 commit 127937a
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 1 deletion.
29 changes: 29 additions & 0 deletions src/components/ChannelList/__tests__/ChannelList.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -324,6 +324,35 @@ describe('ChannelList', () => {
expect(results).toHaveNoViolations();
});

it('should show unique channels', async () => {
useMockedApis(chatClientUthred, [queryChannelsApi([testChannel1, testChannel2])]);
const ChannelPreview = (props) => <div data-testid={props.channel.id} role='listitem' />;
render(
<Chat client={chatClientUthred}>
<ChannelList filters={{}} options={{ limit: 2 }} Preview={ChannelPreview} />
</Chat>,
);

await waitFor(() => {
expect(screen.getByTestId(testChannel1.channel.id)).toBeInTheDocument();
expect(screen.getByTestId(testChannel2.channel.id)).toBeInTheDocument();
expect(screen.getAllByRole('listitem')).toHaveLength(2);
});

useMockedApis(chatClientUthred, [queryChannelsApi([testChannel1, testChannel3])]);

await act(() => {
fireEvent.click(screen.getByTestId('load-more-button'));
});

await waitFor(() => {
expect(screen.getByTestId(testChannel1.channel.id)).toBeInTheDocument();
expect(screen.getByTestId(testChannel2.channel.id)).toBeInTheDocument();
expect(screen.getByTestId(testChannel3.channel.id)).toBeInTheDocument();
expect(screen.getAllByRole('listitem')).toHaveLength(3);
});
});

describe('Default and custom active channel', () => {
let setActiveChannel;
const watchersConfig = { limit: 20, offset: 0 };
Expand Down
5 changes: 4 additions & 1 deletion src/components/ChannelList/hooks/usePaginatedChannels.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { useEffect, useMemo, useState } from 'react';
import uniqBy from 'lodash.uniqby';

import { MAX_QUERY_CHANNELS_LIMIT } from '../utils';

Expand Down Expand Up @@ -52,7 +53,9 @@ export const usePaginatedChannels = <
const channelQueryResponse = await client.queryChannels(filters, sort || {}, newOptions);

const newChannels =
queryType === 'reload' ? channelQueryResponse : [...channels, ...channelQueryResponse];
queryType === 'reload'
? channelQueryResponse
: uniqBy([...channels, ...channelQueryResponse], 'cid');

setChannels(newChannels);
setHasNextPage(channelQueryResponse.length >= newOptions.limit);
Expand Down

0 comments on commit 127937a

Please sign in to comment.