UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

175 lines (174 loc) 6.79 kB
/** * DevExtreme (esm/ui/grid_core/ui.grid_core.pager.js) * Version: 21.1.4 * Build date: Mon Jun 21 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import modules from "./ui.grid_core.modules"; import Pager from "../pager"; import { inArray } from "../../core/utils/array"; import { isDefined } from "../../core/utils/type"; import { hasWindow } from "../../core/utils/window"; var PAGER_CLASS = "pager"; var MAX_PAGES_COUNT = 10; var getPageIndex = function(dataController) { return 1 + (parseInt(dataController.pageIndex()) || 0) }; var PagerView = modules.View.inherit({ init: function() { var that = this; var dataController = that.getController("data"); that._isVisible = false; dataController.changed.add((function(e) { if (e && e.repaintChangesOnly) { var pager = that._getPager(); if (pager) { pager.option({ pageIndex: getPageIndex(dataController), pageSize: dataController.pageSize(), pageCount: dataController.pageCount(), totalCount: dataController.totalCount(), hasKnownLastPage: dataController.hasKnownLastPage() }) } else { that.render() } } else if (!e || "update" !== e.changeType && "updateSelection" !== e.changeType) { that.render() } })) }, _getPager: function() { var $element = this.element(); return $element && $element.data("dxPager") }, _renderCore: function() { var $element = this.element().addClass(this.addWidgetPrefix(PAGER_CLASS)); var pagerOptions = this.option("pager") || {}; var dataController = this.getController("data"); var keyboardController = this.getController("keyboardNavigation"); var options = { maxPagesCount: MAX_PAGES_COUNT, pageIndex: getPageIndex(dataController), pageCount: dataController.pageCount(), pageSize: dataController.pageSize(), showPageSizes: pagerOptions.showPageSizeSelector, showInfo: pagerOptions.showInfo, displayMode: pagerOptions.displayMode, pagesNavigatorVisible: pagerOptions.visible, showNavigationButtons: pagerOptions.showNavigationButtons, pageSizes: this.getPageSizes(), totalCount: dataController.totalCount(), hasKnownLastPage: dataController.hasKnownLastPage(), pageIndexChanged: function(pageIndex) { if (dataController.pageIndex() !== pageIndex - 1) { setTimeout((function() { dataController.pageIndex(pageIndex - 1) })) } }, pageSizeChanged: function(pageSize) { setTimeout((function() { dataController.pageSize(pageSize) })) }, onKeyDown: e => keyboardController && keyboardController.executeAction("onKeyDown", e), useLegacyKeyboardNavigation: this.option("useLegacyKeyboardNavigation"), useKeyboard: this.option("keyboardNavigation.enabled") }; if (isDefined(pagerOptions.infoText)) { options.infoText = pagerOptions.infoText } if (hasWindow()) { this._createComponent($element, Pager, options) } else { $element.addClass("dx-pager").html('<div class="dx-pages"><div class="dx-page"></div></div>') } }, getPageSizes: function() { var dataController = this.getController("data"); var pagerOptions = this.option("pager"); var allowedPageSizes = pagerOptions && pagerOptions.allowedPageSizes; var pageSize = dataController.pageSize(); if (!isDefined(this._pageSizes) || -1 === inArray(pageSize, this._pageSizes)) { this._pageSizes = []; if (pagerOptions) { if (Array.isArray(allowedPageSizes)) { this._pageSizes = allowedPageSizes } else if (allowedPageSizes && pageSize > 1) { this._pageSizes = [Math.floor(pageSize / 2), pageSize, 2 * pageSize] } } } return this._pageSizes }, isVisible: function() { var dataController = this.getController("data"); var pagerOptions = this.option("pager"); var pagerVisible = pagerOptions && pagerOptions.visible; var scrolling = this.option("scrolling"); if (this._isVisible) { return true } if ("auto" === pagerVisible) { if (scrolling && ("virtual" === scrolling.mode || "infinite" === scrolling.mode)) { pagerVisible = false } else { pagerVisible = dataController.pageCount() > 1 || dataController.isLoaded() && !dataController.hasKnownLastPage() } } this._isVisible = pagerVisible; return pagerVisible }, getHeight: function() { return this.getElementHeight() }, optionChanged: function(args) { var name = args.name; var isPager = "pager" === name; var isPaging = "paging" === name; var isDataSource = "dataSource" === name; var isScrolling = "scrolling" === name; var dataController = this.getController("data"); if (isPager || isPaging || isScrolling || isDataSource) { args.handled = true; if (dataController.skipProcessingPagingChange(args.fullName)) { return } if (isPager || isPaging) { this._pageSizes = null } if (isPager || isPaging || isScrolling) { this._isVisible = false } if (!isDataSource) { this._invalidate(); if (hasWindow() && isPager && this.component) { this.component.resize() } } } } }); export var pagerModule = { defaultOptions: function() { return { pager: { visible: "auto", showPageSizeSelector: false, allowedPageSizes: "auto" } } }, views: { pagerView: PagerView } };