UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

206 lines (202 loc) • 7.47 kB
/** * DevExtreme (esm/__internal/pagination/pages/large.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import { createVNode, createFragment, createComponentVNode } from "inferno"; import { BaseInfernoComponent } from "@devextreme/runtime/inferno"; import { Fragment } from "inferno"; import { ConfigContext } from "../../core/r1/config_context"; import { PaginationDefaultProps } from "../common/pagination_props"; import { Page } from "./page"; const PAGER_PAGE_SEPARATOR_CLASS = "dx-separator"; const PAGES_LIMITER = 4; const PagesLargeDefaultProps = { maxPagesCount: PaginationDefaultProps.maxPagesCount, pageCount: PaginationDefaultProps.pageCount, pageIndex: PaginationDefaultProps.pageIndex, pageIndexChangedInternal: PaginationDefaultProps.pageIndexChangedInternal }; function getDelimiterType(startIndex, slidingWindowSize, pageCount) { switch (true) { case 1 === startIndex: return "high"; case startIndex + slidingWindowSize === pageCount - 1: return "low"; default: return "both" } } function createPageIndexesBySlidingWindowIndexes(slidingWindowIndexes, pageCount, delimiter) { let pageIndexes = []; let indexesForReuse = []; switch (delimiter) { case "none": pageIndexes = [...slidingWindowIndexes]; break; case "both": pageIndexes = [0, "low", ...slidingWindowIndexes, "high", pageCount - 1]; indexesForReuse = slidingWindowIndexes.slice(1, -1); break; case "high": pageIndexes = [0, ...slidingWindowIndexes, "high", pageCount - 1]; indexesForReuse = slidingWindowIndexes.slice(0, -1); break; case "low": pageIndexes = [0, "low", ...slidingWindowIndexes, pageCount - 1]; indexesForReuse = slidingWindowIndexes.slice(1) } return { slidingWindowIndexes: slidingWindowIndexes, indexesForReuse: indexesForReuse, pageIndexes: pageIndexes } } function createPageIndexes(startIndex, slidingWindowSize, pageCount, delimiter) { const slidingWindowIndexes = []; for (let i = 0; i < slidingWindowSize; i += 1) { slidingWindowIndexes.push(i + startIndex) } return createPageIndexesBySlidingWindowIndexes(slidingWindowIndexes, pageCount, delimiter) } export class PagesLarge extends BaseInfernoComponent { constructor(props) { super(props); this.state = {}; this.refs = null; this.canReuseSlidingWindow = this.canReuseSlidingWindow.bind(this); this.generatePageIndexes = this.generatePageIndexes.bind(this); this.isSlidingWindowMode = this.isSlidingWindowMode.bind(this); this.onPageClick = this.onPageClick.bind(this) } getConfig() { if (this.context[ConfigContext.id]) { return this.context[ConfigContext.id] } return ConfigContext.defaultValue } getSlidingWindowState() { const slidingWindowState = this.slidingWindowStateHolder; if (!slidingWindowState) { return { indexesForReuse: [], slidingWindowIndexes: [] } } return slidingWindowState } canReuseSlidingWindow(currentPageCount, pageIndex) { const { indexesForReuse: indexesForReuse } = this.getSlidingWindowState(); const lastPageIsFartherThanWindow = indexesForReuse.slice(-1)[0] < currentPageCount - 1; const pageIndexExistInIndexes = indexesForReuse.includes(pageIndex); return lastPageIsFartherThanWindow && pageIndexExistInIndexes } generatePageIndexes() { const { pageCount: pageCount, pageIndex: pageIndex } = this.props; let startIndex = 0; const { slidingWindowIndexes: slidingWindowIndexes } = this.getSlidingWindowState(); if (pageIndex === slidingWindowIndexes[0]) { startIndex = pageIndex - 1 } else if (pageIndex === slidingWindowIndexes[slidingWindowIndexes.length - 1]) { startIndex = pageIndex + 2 - 4 } else if (pageIndex < 4) { startIndex = 1 } else if (pageIndex >= pageCount - 4) { startIndex = pageCount - 4 - 1 } else { startIndex = pageIndex - 1 } const delimiter = getDelimiterType(startIndex, 4, pageCount); const indexes = createPageIndexes(startIndex, 4, pageCount, delimiter); const { pageIndexes: pageIndexes } = indexes; this.slidingWindowStateHolder = indexes; return pageIndexes } isSlidingWindowMode() { const { maxPagesCount: maxPagesCount, pageCount: pageCount } = this.props; return pageCount <= 4 || pageCount <= maxPagesCount } onPageClick(pageIndex) { this.props.pageIndexChangedInternal(pageIndex) } getPageIndexes() { const { pageCount: pageCount } = this.props; if (this.isSlidingWindowMode()) { return createPageIndexes(0, pageCount, pageCount, "none").pageIndexes } if (this.canReuseSlidingWindow(pageCount, this.props.pageIndex)) { const { slidingWindowIndexes: slidingWindowIndexes } = this.getSlidingWindowState(); const delimiter = getDelimiterType(slidingWindowIndexes[0], 4, pageCount); return createPageIndexesBySlidingWindowIndexes(slidingWindowIndexes, pageCount, delimiter).pageIndexes } return this.generatePageIndexes() } getPages() { var _this$getConfig; const { pageIndex: pageIndex } = this.props; const createPage = index => { const paginationProps = "low" === index || "high" === index ? null : { index: index, onClick: () => this.onPageClick(index), selected: pageIndex === index }; return { key: index.toString(), pageProps: paginationProps } }; const indices = this.getPageIndexes(); const rtlPageIndexes = null !== (_this$getConfig = this.getConfig()) && void 0 !== _this$getConfig && _this$getConfig.rtlEnabled ? [...indices].reverse() : indices; return rtlPageIndexes.map((index => createPage(index))) } render() { const PagesMarkup = this.getPages().map((_ref => { let { key: key, pageProps: pageProps } = _ref; return pageProps ? createComponentVNode(2, Page, { index: pageProps.index, selected: pageProps.selected, onClick: pageProps.onClick }, key) : createVNode(1, "div", "dx-separator", ". . .", 16, null, key) })); return createFragment(PagesMarkup, 0) } } PagesLarge.defaultProps = PagesLargeDefaultProps;