Website : rimsha.abasa.com
backdoor
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
var
/
canvas
/
node_modules
/
@canvas
/
instui-bindings
/
react
/
Filename :
Paginator.tsx
back
Copy
/* * Copyright (C) 2018 - present Instructure, Inc. * * This file is part of Canvas. * * Canvas is free software: you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License as published by the Free * Software Foundation, version 3 of the License. * * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more * details. * * You should have received a copy of the GNU Affero General Public License along * with this program. If not, see <http://www.gnu.org/licenses/>. */ import React, {type ReactElement} from 'react' import {useScope as useI18nScope} from '@canvas/i18n' import {Pagination} from '@instructure/ui-pagination' import {PresentationContent, ScreenReaderContent} from '@instructure/ui-a11y-content' const I18n = useI18nScope('paginator') const {Page} = Pagination as any type Props = { loadPage: (page: number) => void page: number pageCount: number [key: string]: any } const Paginator = ({loadPage, page, pageCount, ...paginationProps}: Props): ReactElement => { if (pageCount <= 1) { return <span /> } return ( <Pagination variant="compact" labelNext={I18n.t('Next Page')} labelPrev={I18n.t('Previous Page')} {...paginationProps} > {Array.from(Array(pageCount)).map((v, i) => ( // eslint-disable-next-line react/no-array-index-key <Page onClick={() => loadPage(i + 1)} key={i + 1} current={page === i + 1}> <PresentationContent>{i + 1}</PresentationContent> <ScreenReaderContent>{I18n.t('Page %{page}', {page: i + 1})}</ScreenReaderContent> </Page> ))} </Pagination> ) } export default Paginator