handsontable
Version:
Handsontable is a JavaScript Spreadsheet Component available for React, Angular and Vue.
176 lines (136 loc) • 6.77 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
require("core-js/modules/es.array.concat.js");
require("core-js/modules/es.array.iterator.js");
require("core-js/modules/es.map.js");
require("core-js/modules/es.object.to-string.js");
require("core-js/modules/es.string.iterator.js");
require("core-js/modules/web.dom-collections.iterator.js");
exports.__esModule = true;
exports.registerOperation = registerOperation;
exports.default = void 0;
var _object = require("../../helpers/object");
var _localHooks = _interopRequireDefault(require("../../mixins/localHooks"));
var columnSorting = _interopRequireWildcard(require("./alterOperation/columnSorting"));
var insertColumn = _interopRequireWildcard(require("./alterOperation/insertColumn"));
var insertRow = _interopRequireWildcard(require("./alterOperation/insertRow"));
var removeColumn = _interopRequireWildcard(require("./alterOperation/removeColumn"));
var removeRow = _interopRequireWildcard(require("./alterOperation/removeRow"));
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
var operations = new Map();
registerOperation(columnSorting.OPERATION_NAME, columnSorting);
registerOperation(insertColumn.OPERATION_NAME, insertColumn);
registerOperation(insertRow.OPERATION_NAME, insertRow);
registerOperation(removeColumn.OPERATION_NAME, removeColumn);
registerOperation(removeRow.OPERATION_NAME, removeRow);
/**
* Alter Manager is a service that is responsible for changing the formula expressions (especially cell coordinates)
* based on specific alter operation applied into the table.
*
* For example, when a user adds a new row the algorithm that moves all the cells below the added row down by one row
* should be triggered (eq: cell A5 become A6 etc).
*
* All alter operations are defined in the "alterOperation/" directory.
*
* @class AlterManager
* @util
*/
var AlterManager = /*#__PURE__*/function () {
function AlterManager(sheet) {
_classCallCheck(this, AlterManager);
/**
* Instance of {@link Sheet}.
*
* @type {Sheet}
*/
this.sheet = sheet;
/**
* Handsontable instance.
*
* @type {Core}
*/
this.hot = sheet.hot;
/**
* Instance of {@link DataProvider}.
*
* @type {DataProvider}
*/
this.dataProvider = sheet.dataProvider;
/**
* Instance of {@link Matrix}.
*
* @type {Matrix}
*/
this.matrix = sheet.matrix;
}
/**
* Prepare to execute an alter algorithm. This preparation can be useful for collecting some variables and
* states before specific algorithm will be executed.
*
* @param {string} action One of the action defined in alterOperation.
* @param {*} args Arguments pass to alter operation.
*/
_createClass(AlterManager, [{
key: "prepareAlter",
value: function prepareAlter(action) {
if (!operations.has(action)) {
throw Error("Alter operation \"".concat(action, "\" not exist."));
}
for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
args[_key - 1] = arguments[_key];
}
operations.get(action).prepare.apply(this, args);
}
/**
* Trigger an alter algorithm and after executing code trigger local hook ("afterAlter").
*
* @param {string} action One of the action defined in alterOperation.
* @param {*} args Arguments pass to alter operation.
*/
}, {
key: "triggerAlter",
value: function triggerAlter(action) {
if (!operations.has(action)) {
throw Error("Alter operation \"".concat(action, "\" not exist."));
}
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
args[_key2 - 1] = arguments[_key2];
}
operations.get(action).operate.apply(this, args);
this.runLocalHooks.apply(this, ['afterAlter'].concat(args));
}
/**
* Destroy class.
*/
}, {
key: "destroy",
value: function destroy() {
this.sheet = null;
this.hot = null;
this.dataProvider = null;
this.matrix = null;
}
}]);
return AlterManager;
}();
(0, _object.mixin)(AlterManager, _localHooks.default);
var _default = AlterManager;
exports.default = _default;
var empty = function empty() {};
/**
* @param {string} name The ID of the operation to register.
* @param {object} descriptor The object with `prepare` and `operate` methods which holds the operation logic.
*/
function registerOperation(name, descriptor) {
if (!operations.has(name)) {
operations.set(name, {
prepare: descriptor.prepare || empty,
operate: descriptor.operate || empty
});
}
}