devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
278 lines (276 loc) • 10.7 kB
JavaScript
/**
* DevExtreme (cjs/__internal/grids/pivot_grid/headers_area/module.js)
* Version: 22.1.9
* Build date: Tue Apr 18 2023
*
* Copyright (c) 2012 - 2023 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
var __importDefault = this && this.__importDefault || function(mod) {
return mod && mod.__esModule ? mod : {
default: mod
}
};
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.VerticalHeadersArea = exports.HorizontalHeadersArea = void 0;
var size_1 = require("../../../../core/utils/size");
var renderer_1 = __importDefault(require("../../../../core/renderer"));
var type_1 = require("../../../../core/utils/type");
var iterator_1 = require("../../../../core/utils/iterator");
var ui_scrollable_1 = __importDefault(require("../../../../ui/scroll_view/ui.scrollable"));
var module_1 = require("../area_item/module");
var PIVOTGRID_AREA_CLASS = "dx-pivotgrid-area";
var PIVOTGRID_AREA_COLUMN_CLASS = "dx-pivotgrid-horizontal-headers";
var PIVOTGRID_AREA_ROW_CLASS = "dx-pivotgrid-vertical-headers";
var PIVOTGRID_TOTAL_CLASS = "dx-total";
var PIVOTGRID_GRAND_TOTAL_CLASS = "dx-grandtotal";
var PIVOTGRID_ROW_TOTAL_CLASS = "dx-row-total";
var PIVOTGRID_EXPANDED_CLASS = "dx-pivotgrid-expanded";
var PIVOTGRID_COLLAPSED_CLASS = "dx-pivotgrid-collapsed";
var PIVOTGRID_LAST_CELL_CLASS = "dx-last-cell";
var PIVOTGRID_VERTICAL_SCROLL_CLASS = "dx-vertical-scroll";
var PIVOTGRID_EXPAND_BORDER = "dx-expand-border";
var isRenovatedScrollable = !!ui_scrollable_1.default.IS_RENOVATED_WIDGET;
function getCellPath(tableElement, cell) {
if (cell) {
var data = tableElement.data().data;
var rowIndex = cell.parentNode.rowIndex;
var cellIndex = cell.cellIndex;
return data[rowIndex] && data[rowIndex][cellIndex] && data[rowIndex][cellIndex].path
}
return
}
var HorizontalHeadersArea = module_1.AreaItem.inherit({
ctor: function(component) {
this.callBase(component);
this._scrollBarWidth = 0
},
_getAreaName: function() {
return "column"
},
_getAreaClassName: function() {
return PIVOTGRID_AREA_COLUMN_CLASS
},
_createGroupElement: function() {
return renderer_1.default("<div>").addClass(this._getAreaClassName()).addClass(PIVOTGRID_AREA_CLASS)
},
_applyCustomStyles: function(options) {
var cssArray = options.cssArray;
var cell = options.cell;
var rowsCount = options.rowsCount;
var classArray = options.classArray;
if (options.cellIndex === options.cellsCount - 1) {
cssArray.push((options.rtlEnabled ? "border-left:" : "border-right:") + "0px")
}
if (cell.rowspan === rowsCount - options.rowIndex || options.rowIndex + 1 === rowsCount) {
cssArray.push("border-bottom-width:0px")
}
if ("T" === cell.type || "GT" === cell.type) {
classArray.push(PIVOTGRID_ROW_TOTAL_CLASS)
}
if ("T" === options.cell.type) {
classArray.push(PIVOTGRID_TOTAL_CLASS)
}
if ("GT" === options.cell.type) {
classArray.push(PIVOTGRID_GRAND_TOTAL_CLASS)
}
if (type_1.isDefined(cell.expanded)) {
classArray.push(cell.expanded ? PIVOTGRID_EXPANDED_CLASS : PIVOTGRID_COLLAPSED_CLASS)
}
this.callBase(options)
},
_getMainElementMarkup: function() {
return "<thead class='" + this._getAreaClassName() + "'>"
},
_getCloseMainElementMarkup: function() {
return "</thead>"
},
setVirtualContentParams: function(params) {
this.callBase(params);
this._setTableCss({
left: params.left,
top: 0
});
this._virtualContentWidth = params.width
},
hasScroll: function() {
var tableWidth = this._virtualContent ? this._virtualContentWidth : this._tableWidth;
var groupWidth = this.getGroupWidth();
if (groupWidth && tableWidth) {
return tableWidth - groupWidth >= 1
}
return false
},
renderScrollable: function() {
this._groupElement.dxScrollable({
useNative: false,
useSimulatedScrollbar: false,
showScrollbar: "never",
bounceEnabled: false,
direction: "horizontal",
rtlEnabled: isRenovatedScrollable ? this.component.option("rtlEnabled") : false,
updateManually: true
})
},
updateScrollableOptions: function(_a) {
var rtlEnabled = _a.rtlEnabled;
var scrollable = this._getScrollable();
isRenovatedScrollable && scrollable.option({
rtlEnabled: rtlEnabled
})
},
processScrollBarSpacing: function(scrollBarWidth) {
var groupAlignment = this.option("rtlEnabled") ? "right" : "left";
var groupWidth = this.getGroupWidth();
if (groupWidth) {
this.setGroupWidth(groupWidth - scrollBarWidth)
}
if (this._scrollBarWidth) {
this._groupElement.next().remove()
}
this._groupElement.toggleClass(PIVOTGRID_VERTICAL_SCROLL_CLASS, scrollBarWidth > 0);
size_1.setWidth(this._groupElement.css("float", groupAlignment), this.getGroupHeight());
this._scrollBarWidth = scrollBarWidth
},
getScrollPath: function(offset) {
var tableElement = this.tableElement();
var cell;
offset -= parseInt(tableElement[0].style.left, 10) || 0;
iterator_1.each(tableElement.find("td"), (function(_, td) {
if (1 === td.colSpan && td.offsetLeft <= offset && td.offsetWidth + td.offsetLeft > offset) {
cell = td;
return false
}
return
}));
return getCellPath(tableElement, cell)
},
_moveFakeTable: function(scrollPos) {
this._moveFakeTableHorizontally(scrollPos);
this.callBase()
}
});
exports.HorizontalHeadersArea = HorizontalHeadersArea;
var VerticalHeadersArea = HorizontalHeadersArea.inherit({
_getAreaClassName: function() {
return PIVOTGRID_AREA_ROW_CLASS
},
_applyCustomStyles: function(options) {
this.callBase(options);
if (options.cellIndex === options.cellsCount - 1) {
options.classArray.push(PIVOTGRID_LAST_CELL_CLASS)
}
if (options.rowIndex === options.rowsCount - 1) {
options.cssArray.push("border-bottom: 0px")
}
if (options.cell.isWhiteSpace) {
options.classArray.push("dx-white-space-column")
}
},
_getAreaName: function() {
return "row"
},
setVirtualContentParams: function(params) {
this.callBase(params);
this._setTableCss({
top: params.top,
left: 0
});
this._virtualContentHeight = params.height
},
hasScroll: function() {
var tableHeight = this._virtualContent ? this._virtualContentHeight : this._tableHeight;
var groupHeight = this.getGroupHeight();
if (groupHeight && tableHeight) {
return tableHeight - groupHeight >= 1
}
return false
},
renderScrollable: function() {
this._groupElement.dxScrollable({
useNative: false,
useSimulatedScrollbar: false,
showScrollbar: "never",
bounceEnabled: false,
direction: "vertical",
updateManually: true
})
},
processScrollBarSpacing: function(scrollBarWidth) {
var groupHeight = this.getGroupHeight();
if (groupHeight) {
this.setGroupHeight(groupHeight - scrollBarWidth)
}
if (this._scrollBarWidth) {
this._groupElement.next().remove()
}
if (scrollBarWidth) {
var $div = renderer_1.default("<div>");
size_1.setWidth($div, "100%");
size_1.setHeight($div, scrollBarWidth - 1);
this._groupElement.after($div)
}
this._scrollBarWidth = scrollBarWidth
},
getScrollPath: function(offset) {
var tableElement = this.tableElement();
var cell;
offset -= parseInt(tableElement[0].style.top, 10) || 0;
iterator_1.each(tableElement.find("tr"), (function(_, tr) {
var td = tr.childNodes[tr.childNodes.length - 1];
if (td && 1 === td.rowSpan && td.offsetTop <= offset && td.offsetHeight + td.offsetTop > offset) {
cell = td;
return false
}
return
}));
return getCellPath(tableElement, cell)
},
_moveFakeTable: function(scrollPos) {
this._moveFakeTableTop(scrollPos);
this.callBase()
},
_getRowClassNames: function(rowIndex, cell, rowClassNames) {
if (0 !== rowIndex & cell.expanded && !rowClassNames.includes(PIVOTGRID_EXPAND_BORDER)) {
rowClassNames.push(PIVOTGRID_EXPAND_BORDER)
}
},
_getMainElementMarkup: function() {
return "<tbody class='" + this._getAreaClassName() + "'>"
},
_getCloseMainElementMarkup: function() {
return "</tbody>"
},
updateColspans: function(columnCount) {
var rows = this.tableElement()[0].rows;
var columnOffset = 0;
var columnOffsetResetIndexes = [];
if (this.getColumnsCount() - columnCount > 0) {
return
}
for (var i = 0; i < rows.length; i += 1) {
for (var j = 0; j < rows[i].cells.length; j += 1) {
var cell = rows[i].cells[j];
var rowSpan = cell.rowSpan;
if (columnOffsetResetIndexes[i]) {
columnOffset -= columnOffsetResetIndexes[i];
columnOffsetResetIndexes[i] = 0
}
var diff = columnCount - (columnOffset + cell.colSpan);
if (j === rows[i].cells.length - 1 && diff > 0) {
cell.colSpan += diff
}
columnOffsetResetIndexes[i + rowSpan] = (columnOffsetResetIndexes[i + rowSpan] || 0) + cell.colSpan;
columnOffset += cell.colSpan
}
}
}
});
exports.VerticalHeadersArea = VerticalHeadersArea;
exports.default = {
HorizontalHeadersArea: HorizontalHeadersArea,
VerticalHeadersArea: VerticalHeadersArea
};