UNPKG

handsontable

Version:

Handsontable is a JavaScript Data Grid available for React, Angular and Vue.

173 lines (159 loc) 4.74 kB
import "core-js/modules/es.array.push.js"; import { arrayEach, arrayMap } from "../../../helpers/array.mjs"; import { hasOwnProperty } from "../../../helpers/object.mjs"; import { hasClass } from "../../../helpers/dom/element.mjs"; import { SEPARATOR } from "./../predefinedItems/index.mjs"; /** * @param {CellRange[]} selRanges An array of the cell ranges. * @returns {object[]} */ export function normalizeSelection(selRanges) { return arrayMap(selRanges, range => ({ start: range.getTopStartCorner(), end: range.getBottomEndCorner() })); } /** * Check if the provided element is a submenu opener. * * @param {object} itemToTest Item element. * @returns {boolean} */ export function isItemSubMenu(itemToTest) { return hasOwnProperty(itemToTest, 'submenu'); } /** * Check if the provided element is a menu separator. * * @param {object} itemToTest Item element. * @returns {boolean} */ export function isItemSeparator(itemToTest) { return new RegExp(SEPARATOR, 'i').test(itemToTest.name); } /** * Check if the provided element presents the disabled menu item. * * @param {object} itemToTest Item element. * @param {object} hot The context for the item function. * @returns {boolean} */ export function isItemDisabled(itemToTest, hot) { return itemToTest.disabled === true || typeof itemToTest.disabled === 'function' && itemToTest.disabled.call(hot) === true; } /** * Check if the provided element presents the disabled selection menu item. * * @param {object} itemToTest Item element. * @returns {boolean} */ export function isItemSelectionDisabled(itemToTest) { return hasOwnProperty(itemToTest, 'disableSelection'); } /** * @param {HTMLElement} cell The HTML cell element to check. * @returns {boolean} */ export function isSeparator(cell) { return hasClass(cell, 'htSeparator'); } /** * @param {HTMLElement} cell The HTML cell element to check. * @returns {boolean} */ export function hasSubMenu(cell) { return hasClass(cell, 'htSubmenu'); } /** * @param {HTMLElement} cell The HTML cell element to check. * @returns {boolean} */ export function isDisabled(cell) { return hasClass(cell, 'htDisabled'); } /** * @param {HTMLElement} cell The HTML cell element to check. * @returns {boolean} */ export function isSelectionDisabled(cell) { return hasClass(cell, 'htSelectionDisabled'); } /** * @param {object} item The object which describes the context menu item properties. * @param {Core} instance The Handsontable instance. * @returns {boolean} */ export function isItemHidden(item, instance) { return !item.hidden || !(typeof item.hidden === 'function' && item.hidden.call(instance)); } /** * @param {object[]} items The context menu items collection. * @param {string} separator The string which identifies the context menu separator item. * @returns {object[]} */ function shiftSeparators(items, separator) { const result = items.slice(0); for (let i = 0; i < result.length;) { if (result[i].name === separator) { result.shift(); } else { break; } } return result; } /** * @param {object[]} items The context menu items collection. * @param {string} separator The string which identifies the context menu separator item. * @returns {object[]} */ function popSeparators(items, separator) { let result = items.slice(0); result.reverse(); result = shiftSeparators(result, separator); result.reverse(); return result; } /** * Removes duplicated menu separators from the context menu items collection. * * @param {object[]} items The context menu items collection. * @returns {object[]} */ function removeDuplicatedSeparators(items) { const result = []; arrayEach(items, (value, index) => { if (index > 0) { if (result[result.length - 1].name !== value.name) { result.push(value); } } else { result.push(value); } }); return result; } /** * Removes menu separators from the context menu items collection. * * @param {object[]} items The context menu items collection. * @param {string} separator The string which identifies the context menu separator item. * @returns {object[]} */ export function filterSeparators(items) { let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SEPARATOR; let result = items.slice(0); result = shiftSeparators(result, separator); result = popSeparators(result, separator); result = removeDuplicatedSeparators(result); return result; } /** * Check if the provided element presents the checkboxable menu item. * * @param {object} itemToTest Item element. * @returns {boolean} */ export function isItemCheckable(itemToTest) { return itemToTest.checkable === true; }