2022-06-09 22:17:33 +02:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2023-04-13 21:48:29 +02:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2022-06-09 22:17:33 +02:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-08-04 11:16:01 +02:00
|
|
|
import type { ShlinkPaginator } from '../../src/api-contract';
|
2023-08-02 09:01:44 +02:00
|
|
|
import { Paginator } from '../../src/short-urls/Paginator';
|
|
|
|
import { ELLIPSIS } from '../../src/utils/helpers/pagination';
|
2018-09-16 12:18:02 +02:00
|
|
|
|
|
|
|
describe('<Paginator />', () => {
|
2023-04-13 21:48:29 +02:00
|
|
|
const buildPaginator = (pagesCount?: number) => fromPartial<ShlinkPaginator>({ pagesCount, currentPage: 1 });
|
2022-06-09 22:17:33 +02:00
|
|
|
const setUp = (paginator?: ShlinkPaginator, currentQueryString?: string) => render(
|
|
|
|
<MemoryRouter>
|
2023-08-04 11:16:01 +02:00
|
|
|
<Paginator paginator={paginator} currentQueryString={currentQueryString} />
|
2022-06-09 22:17:33 +02:00
|
|
|
</MemoryRouter>,
|
|
|
|
);
|
2018-09-16 12:18:02 +02:00
|
|
|
|
2021-11-08 22:13:37 +01:00
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[undefined],
|
|
|
|
[buildPaginator()],
|
|
|
|
[buildPaginator(0)],
|
|
|
|
[buildPaginator(1)],
|
2022-12-18 10:12:34 +01:00
|
|
|
])('renders an empty gap if the number of pages is below 2', (paginator) => {
|
2022-06-09 22:17:33 +02:00
|
|
|
const { container } = setUp(paginator);
|
2022-12-18 10:12:34 +01:00
|
|
|
|
2022-12-31 10:47:15 +01:00
|
|
|
expect(container.firstChild).toBeEmptyDOMElement();
|
2022-12-18 10:12:34 +01:00
|
|
|
expect(container.firstChild).toHaveClass('pb-3');
|
2018-09-16 12:18:02 +02:00
|
|
|
});
|
|
|
|
|
2021-11-08 22:13:37 +01:00
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[buildPaginator(2), 4, 0],
|
|
|
|
[buildPaginator(3), 5, 0],
|
|
|
|
[buildPaginator(4), 6, 0],
|
|
|
|
[buildPaginator(5), 7, 1],
|
|
|
|
[buildPaginator(6), 7, 1],
|
|
|
|
[buildPaginator(23), 7, 1],
|
2021-11-08 22:13:37 +01:00
|
|
|
])('renders previous, next and the list of pages, with ellipses when expected', (
|
|
|
|
paginator,
|
|
|
|
expectedPages,
|
|
|
|
expectedEllipsis,
|
|
|
|
) => {
|
2022-06-09 22:17:33 +02:00
|
|
|
setUp(paginator);
|
|
|
|
|
|
|
|
const links = screen.getAllByRole('link');
|
|
|
|
const ellipsis = screen.queryAllByText(ELLIPSIS);
|
2021-11-08 22:13:37 +01:00
|
|
|
|
2022-06-09 22:17:33 +02:00
|
|
|
expect(links).toHaveLength(expectedPages);
|
2021-11-08 22:13:37 +01:00
|
|
|
expect(ellipsis).toHaveLength(expectedEllipsis);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('appends query string to all pages', () => {
|
|
|
|
const paginator = buildPaginator(3);
|
|
|
|
const currentQueryString = '?foo=bar';
|
|
|
|
|
2022-06-09 22:17:33 +02:00
|
|
|
setUp(paginator, currentQueryString);
|
|
|
|
const links = screen.getAllByRole('link');
|
2018-09-16 12:18:02 +02:00
|
|
|
|
2021-11-08 22:13:37 +01:00
|
|
|
expect(links).toHaveLength(5);
|
2022-06-09 22:17:33 +02:00
|
|
|
links.forEach((link) => expect(link).toHaveAttribute('href', expect.stringContaining(currentQueryString)));
|
2018-09-16 12:18:02 +02:00
|
|
|
});
|
|
|
|
});
|