mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-08 09:17:29 +03:00
27 lines
973 B
TypeScript
27 lines
973 B
TypeScript
import { DropdownItem, DropdownMenu, DropdownToggle, UncontrolledDropdown } from 'reactstrap';
|
|
|
|
interface PaginationDropdownProps {
|
|
ranges: number[];
|
|
value: number;
|
|
setValue: (newValue: number) => void;
|
|
toggleClassName?: string;
|
|
}
|
|
|
|
const PaginationDropdown = ({ toggleClassName, ranges, value, setValue }: PaginationDropdownProps) => (
|
|
<UncontrolledDropdown>
|
|
<DropdownToggle caret color="link" className={toggleClassName}>Paginate</DropdownToggle>
|
|
<DropdownMenu end>
|
|
{ranges.map((itemsPerPage) => (
|
|
<DropdownItem key={itemsPerPage} active={itemsPerPage === value} onClick={() => setValue(itemsPerPage)}>
|
|
<b>{itemsPerPage}</b> items per page
|
|
</DropdownItem>
|
|
))}
|
|
<DropdownItem divider />
|
|
<DropdownItem disabled={value === Infinity} onClick={() => setValue(Infinity)}>
|
|
<i>Clear pagination</i>
|
|
</DropdownItem>
|
|
</DropdownMenu>
|
|
</UncontrolledDropdown>
|
|
);
|
|
|
|
export default PaginationDropdown;
|