// Copyright (c) 2018 Dominic Masters // // MIT License // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. import React from 'react'; import { NavLink } from 'react-router-dom'; import PageBoundary from '@components/page/boundary/PageBoundary'; import Styles from './Pagination.scss'; const PaginationLink = props => { let { to, page, children, current } = props; let url = to; if(url.indexOf('$page') !== -1) { url = url.replace('$page', page); } else { if(!url.endsWith("/")) url += '/'; url += page; } let className = `o-pagination__link`; if(current && current == page) className += ` is-active`; return ( { children } ); }; export default props => { //Where Page = current page, //pages = total pages and //to = url, with $page let { page, pages, to, className } = props; page = parseInt(page) || 1; pages = parseInt(pages) || 1; let inners = []; //Internal Numbers let numbers = [1, pages];//Always start with page 1 and pages //Now add numbers page-2, page-1,page(active),page+1, page+2 for(let i = page-2; i <= page+2; i++) { if(i < 1) continue;//Don't add -2, -1, 0 etc if(i > pages) continue;//Don't go pages+1 for example 22 pages, 23 numbers.push(i); } //Uniqify and then sort. numbers = [...new Set(numbers)].sort((a,b) => a-b); //Prev Button if(page > 1) { inners.push(); } numbers.forEach(i => { inners.push(); }); //Next Button if(page < pages-1) { inners.push(); } return ( ); };