handsontable
Version:
Handsontable is a JavaScript Data Grid available for React, Angular and Vue.
119 lines (114 loc) • 5.14 kB
JavaScript
exports.__esModule = true;
require("core-js/modules/es.error.cause.js");
require("core-js/modules/es.array.push.js");
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
/**
* Class responsible for all of the Selection-related operations on merged cells.
*
* @private
* @class SelectionCalculations
*/
class SelectionCalculations {
constructor(plugin) {
/**
* Reference to the Merge Cells plugin.
*
* @type {MergeCells}
*/
_defineProperty(this, "plugin", void 0);
/**
* Reference to the Handsontable instance.
*
* @type {Handsontable}
*/
_defineProperty(this, "hot", void 0);
/**
* Class name used for fully selected merged cells.
*
* @type {string}
*/
_defineProperty(this, "fullySelectedMergedCellClassName", 'fullySelectedMergedCell');
this.plugin = plugin;
this.hot = plugin.hot;
}
/**
* Generate an additional class name for the entirely-selected merged cells.
*
* @param {number} currentRow Visual row index of the currently processed cell.
* @param {number} currentColumn Visual column index of the currently cell.
* @param {Array} cornersOfSelection Array of the current selection in a form of `[startRow, startColumn, endRow, endColumn]`.
* @param {number|undefined} layerLevel Number indicating which layer of selection is currently processed.
* @returns {string|undefined} A `String`, which will act as an additional `className` to be added to the currently processed cell.
*/
getSelectedMergedCellClassName(currentRow, currentColumn, cornersOfSelection, layerLevel) {
const startRow = Math.min(cornersOfSelection[0], cornersOfSelection[2]);
const startColumn = Math.min(cornersOfSelection[1], cornersOfSelection[3]);
const endRow = Math.max(cornersOfSelection[0], cornersOfSelection[2]);
const endColumn = Math.max(cornersOfSelection[1], cornersOfSelection[3]);
if (layerLevel === undefined) {
return;
}
const isFirstRenderableMergedCell = this.plugin.mergedCellsCollection.isFirstRenderableMergedCell(currentRow, currentColumn);
// We add extra classes just to the first renderable merged cell.
if (!isFirstRenderableMergedCell) {
return;
}
const mergedCell = this.plugin.mergedCellsCollection.get(currentRow, currentColumn);
if (!mergedCell) {
return;
}
const mergeRowEnd = mergedCell.getLastRow();
const mergeColumnEnd = mergedCell.getLastColumn();
const fullMergeAreaWithinSelection = startRow <= mergedCell.row && startColumn <= mergedCell.col && endRow >= mergeRowEnd && endColumn >= mergeColumnEnd;
if (fullMergeAreaWithinSelection) {
return `${this.fullySelectedMergedCellClassName}-${layerLevel}`;
} else if (this.isMergeCellFullySelected(mergedCell, this.plugin.hot.getSelectedRange())) {
return `${this.fullySelectedMergedCellClassName}-multiple`;
}
}
/**
* Check if the provided merged cell is fully selected (by one or many layers of selection).
*
* @param {MergedCellCoords} mergedCell The merged cell to be processed.
* @param {CellRange[]} selectionRangesArray Array of selection ranges.
* @returns {boolean}
*/
isMergeCellFullySelected(mergedCell, selectionRangesArray) {
const mergedCellIndividualCoords = [];
if (!selectionRangesArray || !mergedCell) {
return false;
}
for (let r = 0; r < mergedCell.rowspan; r += 1) {
for (let c = 0; c < mergedCell.colspan; c += 1) {
mergedCellIndividualCoords.push(this.hot._createCellCoords(mergedCell.row + r, mergedCell.col + c));
}
}
for (let i = 0; i < mergedCellIndividualCoords.length; i += 1) {
const insideSelections = [];
for (let s = 0; s < selectionRangesArray.length; s += 1) {
insideSelections[s] = selectionRangesArray[s].includes(mergedCellIndividualCoords[i]);
}
if (!insideSelections.includes(true)) {
return false;
}
}
return true;
}
/**
* Generate an array of the entirely-selected merged cells' class names.
*
* @returns {string[]} An `Array` of `String`s. Each of these strings will act like class names to be removed from all the cells in the table.
*/
getSelectedMergedCellClassNameToRemove() {
const classNames = [];
for (let i = 0; i <= 7; i += 1) {
classNames.push(`${this.fullySelectedMergedCellClassName}-${i}`);
}
classNames.push(`${this.fullySelectedMergedCellClassName}-multiple`);
return classNames;
}
}
var _default = exports.default = SelectionCalculations;
;