devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
175 lines (174 loc) • 6.79 kB
JavaScript
/**
* 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
}
};