devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
189 lines (178 loc) • 8.77 kB
JavaScript
/**
* DevExtreme (cjs/exporter/jspdf/common/row_utils.js)
* Version: 23.2.6
* Build date: Wed May 01 2024
*
* Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
;
exports.applyBordersConfig = applyBordersConfig;
exports.applyColSpans = applyColSpans;
exports.applyRowSpans = applyRowSpans;
exports.calculateCoordinates = calculateCoordinates;
exports.calculateHeights = calculateHeights;
exports.calculateTableSize = calculateTableSize;
exports.initializeCellsWidth = initializeCellsWidth;
exports.resizeFirstColumnByIndentLevel = resizeFirstColumnByIndentLevel;
var _type = require("../../../core/utils/type");
var _pdf_utils = require("./pdf_utils");
const getSum = (a, b) => a + b;
function calculateColumnWidths(doc, dataProvider, topLeftX, margin, customerColumnWidths) {
const resultWidths = dataProvider.getColumnsWidths().map(width => (0, _pdf_utils.toPdfUnit)(doc, null !== width && void 0 !== width ? width : 150));
const totalAutoColumnsWidth = resultWidths.filter((width, index) => !(0, _type.isDefined)(customerColumnWidths[index])).reduce(getSum, 0);
const totalCustomerColumnsWidth = customerColumnWidths.filter(width => (0, _type.isNumeric)(width)).reduce(getSum, 0);
const availablePageWidth = getAvailablePageAreaWidth(doc, topLeftX, margin);
const ratio = totalCustomerColumnsWidth < availablePageWidth ? (availablePageWidth - totalCustomerColumnsWidth) / totalAutoColumnsWidth : 1;
return resultWidths.map((width, index) => {
var _customerColumnWidths;
return null !== (_customerColumnWidths = customerColumnWidths[index]) && void 0 !== _customerColumnWidths ? _customerColumnWidths : width * ratio
})
}
function getAvailablePageAreaWidth(doc, topLeftX, margin) {
return (0, _pdf_utils.getPageWidth)(doc) - topLeftX - margin.left - margin.right
}
function initializeCellsWidth(doc, dataProvider, rows, options) {
const columnWidths = calculateColumnWidths(doc, dataProvider, options.topLeft.x, options.margin, options.columnWidths);
rows.forEach(row => {
row.cells.forEach((_ref, index) => {
let {
gridCell: gridCell,
pdfCell: pdfCell
} = _ref;
pdfCell._rect.w = columnWidths[index]
})
})
}
function calculateHeights(doc, rows, options) {
rows.forEach(row => {
const pdfCells = row.cells.map(c => c.pdfCell);
let customerHeight;
if (options.onRowExporting) {
const args = {
rowCells: pdfCells
};
options.onRowExporting(args);
if ((0, _type.isDefined)(args.rowHeight)) {
customerHeight = args.rowHeight
}
}
row.height = (0, _type.isDefined)(customerHeight) ? customerHeight : (0, _pdf_utils.calculateRowHeight)(doc, row.cells, pdfCells.map(c => c._rect.w));
pdfCells.forEach(cell => {
cell._rect.h = row.height
})
})
}
function applyColSpans(rows) {
for (let rowIndex = 0; rowIndex < rows.length; rowIndex++) {
const row = rows[rowIndex];
for (let cellIndex = 0; cellIndex < row.cells.length; cellIndex++) {
const cell = row.cells[cellIndex];
if ((0, _type.isDefined)(cell.colSpan) && !(0, _type.isDefined)(cell.pdfCell.isMerged)) {
for (let spanIndex = 1; spanIndex <= cell.colSpan; spanIndex++) {
const mergedCell = rows[rowIndex].cells[cellIndex + spanIndex];
cell.pdfCell._rect.w += mergedCell.pdfCell._rect.w;
mergedCell.pdfCell._rect.w = 0;
mergedCell.pdfCell.isMerged = true
}
}
}
}
}
function applyRowSpans(rows) {
for (let rowIndex = 0; rowIndex < rows.length; rowIndex++) {
const row = rows[rowIndex];
for (let cellIndex = 0; cellIndex < row.cells.length; cellIndex++) {
const cell = row.cells[cellIndex];
if ((0, _type.isDefined)(cell.rowSpan) && !(0, _type.isDefined)(cell.pdfCell.isMerged)) {
for (let spanIndex = 1; spanIndex <= cell.rowSpan; spanIndex++) {
const mergedCell = rows[rowIndex + spanIndex].cells[cellIndex];
cell.pdfCell._rect.h += mergedCell.pdfCell._rect.h;
mergedCell.pdfCell._rect.h = 0;
mergedCell.pdfCell.isMerged = true
}
}
}
}
}
function resizeFirstColumnByIndentLevel(rows, options) {
rows.forEach(row => {
row.cells[0].pdfCell._rect.w -= row.indentLevel * options.indent
})
}
function applyBordersConfig(rows) {
for (let rowIndex = 0; rowIndex < rows.length; rowIndex++) {
const cells = rows[rowIndex].cells;
for (let columnIndex = 0; columnIndex < cells.length; columnIndex++) {
const pdfCell = cells[columnIndex].pdfCell;
const leftPdfCell = columnIndex >= 1 ? cells[columnIndex - 1].pdfCell : null;
const topPdfCell = rowIndex >= 1 ? rows[rowIndex - 1].cells[columnIndex].pdfCell : null;
if (false === pdfCell.drawLeftBorder && !(0, _type.isDefined)(cells[columnIndex].colSpan)) {
if ((0, _type.isDefined)(leftPdfCell)) {
leftPdfCell.drawRightBorder = false
}
} else if (!(0, _type.isDefined)(pdfCell.drawLeftBorder)) {
if ((0, _type.isDefined)(leftPdfCell) && false === leftPdfCell.drawRightBorder) {
pdfCell.drawLeftBorder = false
}
}
if (false === pdfCell.drawTopBorder) {
if ((0, _type.isDefined)(topPdfCell)) {
topPdfCell.drawBottomBorder = false
}
} else if (!(0, _type.isDefined)(pdfCell.drawTopBorder)) {
if ((0, _type.isDefined)(topPdfCell) && false === topPdfCell.drawBottomBorder) {
pdfCell.drawTopBorder = false
}
}
}
}
}
function calculateCoordinates(doc, rows, options) {
var _topLeft$y;
const topLeft = null === options || void 0 === options ? void 0 : options.topLeft;
const margin = null === options || void 0 === options ? void 0 : options.margin;
let y = (null !== (_topLeft$y = null === topLeft || void 0 === topLeft ? void 0 : topLeft.y) && void 0 !== _topLeft$y ? _topLeft$y : 0) + margin.top;
rows.forEach(row => {
var _topLeft$x;
let x = (null !== (_topLeft$x = null === topLeft || void 0 === topLeft ? void 0 : topLeft.x) && void 0 !== _topLeft$x ? _topLeft$x : 0) + margin.left;
const intend = row.indentLevel * options.indent;
row.cells.forEach(cell => {
cell.pdfCell._rect.x = x + intend;
cell.pdfCell._rect.y = y;
x += cell.pdfCell._rect.w
});
y += row.height
})
}
function calculateTableSize(doc, cells, options) {
var _ref2, _leftPos, _options$topLeft, _ref3, _topPos, _options$topLeft2;
let leftPos;
let topPos;
let rightPos;
let bottomPos;
cells.forEach(cell => {
if (!(0, _type.isDefined)(leftPos) || leftPos > cell._rect.x) {
leftPos = cell._rect.x
}
if (!(0, _type.isDefined)(topPos) || topPos > cell._rect.y) {
topPos = cell._rect.y
}
if (!(0, _type.isDefined)(rightPos) || rightPos < cell._rect.x + cell._rect.w) {
rightPos = cell._rect.x + cell._rect.w
}
if (!(0, _type.isDefined)(bottomPos) || bottomPos < cell._rect.y + cell._rect.h) {
bottomPos = cell._rect.y + cell._rect.h
}
});
const x = null !== (_ref2 = null !== (_leftPos = leftPos) && void 0 !== _leftPos ? _leftPos : null === options || void 0 === options ? void 0 : null === (_options$topLeft = options.topLeft) || void 0 === _options$topLeft ? void 0 : _options$topLeft.x) && void 0 !== _ref2 ? _ref2 : 0;
const y = null !== (_ref3 = null !== (_topPos = topPos) && void 0 !== _topPos ? _topPos : null === options || void 0 === options ? void 0 : null === (_options$topLeft2 = options.topLeft) || void 0 === _options$topLeft2 ? void 0 : _options$topLeft2.y) && void 0 !== _ref3 ? _ref3 : 0;
const w = (0, _type.isDefined)(rightPos) ? rightPos - x : 0;
const h = (0, _type.isDefined)(bottomPos) ? bottomPos - y : 0;
return {
x: x,
y: y,
w: w,
h: h
}
}