UNPKG

handsontable

Version:

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

37 lines (35 loc) 1.7 kB
"use strict"; exports.__esModule = true; exports.default = rowAboveItem; var C = _interopRequireWildcard(require("../../../i18n/constants")); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); } const KEY = exports.KEY = 'row_above'; /** * @returns {object} */ function rowAboveItem() { return { key: KEY, name() { return this.getTranslatedPhrase(C.CONTEXTMENU_ITEMS_ROW_ABOVE); }, callback() { const activeSelection = this.getSelectedRangeActive().getTopLeftCorner(); this.alter('insert_row_above', activeSelection.row, 1, 'ContextMenu.rowAbove'); }, disabled() { const range = this.getSelectedRangeActive(); if (!range || this.selection.isSelectedByColumnHeader() || range.isSingleHeader() && range.highlight.row < 0 || this.countSourceRows() >= this.getSettings().maxRows) { return true; } if (this.selection.isSelectedByCorner()) { // Enable "Insert row above" only when there is at least one row. return this.countRows() === 0; } return false; }, hidden() { return !this.getSettings().allowInsertRow; } }; }