UNPKG

hyperformula-dc

Version:

HyperFormula is a JavaScript engine for efficient processing of spreadsheet-like data and formulas

350 lines (304 loc) 11.5 kB
"use strict"; 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.reflect.construct.js"); require("core-js/modules/es.symbol.js"); require("core-js/modules/es.symbol.description.js"); require("core-js/modules/es.object.to-string.js"); require("core-js/modules/es.symbol.iterator.js"); require("core-js/modules/es.array.iterator.js"); require("core-js/modules/es.string.iterator.js"); require("core-js/modules/web.dom-collections.iterator.js"); exports.__esModule = true; exports.BooleanPlugin = void 0; require("core-js/modules/web.dom-collections.for-each.js"); require("core-js/modules/es.object.get-prototype-of.js"); var _Cell = require("../../Cell"); var _errorMessage = require("../../error-message"); var _FunctionPlugin2 = require("./FunctionPlugin"); 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; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } /** * Interpreter plugin containing boolean functions */ var BooleanPlugin = /*#__PURE__*/function (_FunctionPlugin) { _inherits(BooleanPlugin, _FunctionPlugin); var _super = _createSuper(BooleanPlugin); function BooleanPlugin() { _classCallCheck(this, BooleanPlugin); return _super.apply(this, arguments); } _createClass(BooleanPlugin, [{ key: "literalTrue", value: /** * Corresponds to TRUE() * * Returns the logical true * * @param ast * @param state */ function literalTrue(ast, state) { return this.runFunction(ast.args, state, this.metadata('TRUE'), function () { return true; }); } /** * Corresponds to FALSE() * * Returns the logical false * * @param ast * @param state */ }, { key: "literalFalse", value: function literalFalse(ast, state) { return this.runFunction(ast.args, state, this.metadata('FALSE'), function () { return false; }); } /** * Corresponds to IF(expression, value_if_true, value_if_false) * * Returns value specified as second argument if expression is true and third argument if expression is false * * @param ast * @param state */ }, { key: "conditionalIf", value: function conditionalIf(ast, state) { return this.runFunction(ast.args, state, this.metadata('IF'), function (condition, arg2, arg3) { return condition ? arg2 : arg3; }); } /** * Corresponds to AND(expression1, [expression2, ...]) * * Returns true if all of the provided arguments are logically true, and false if any of it is logically false * * @param ast * @param state */ }, { key: "and", value: function and(ast, state) { return this.runFunction(ast.args, state, this.metadata('AND'), function () { for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return !args.some(function (arg) { return !arg; }); }); } /** * Corresponds to OR(expression1, [expression2, ...]) * * Returns true if any of the provided arguments are logically true, and false otherwise * * @param ast * @param state */ }, { key: "or", value: function or(ast, state) { return this.runFunction(ast.args, state, this.metadata('OR'), function () { for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { args[_key2] = arguments[_key2]; } return args.some(function (arg) { return arg; }); }); } }, { key: "not", value: function not(ast, state) { return this.runFunction(ast.args, state, this.metadata('NOT'), function (arg) { return !arg; }); } }, { key: "xor", value: function xor(ast, state) { return this.runFunction(ast.args, state, this.metadata('XOR'), function () { var cnt = 0; for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { args[_key3] = arguments[_key3]; } args.forEach(function (arg) { if (arg) { cnt++; } }); return cnt % 2 === 1; }); } }, { key: "switch", value: function _switch(ast, state) { var _this = this; return this.runFunction(ast.args, state, this.metadata('SWITCH'), function (selector) { for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) { args[_key4 - 1] = arguments[_key4]; } var n = args.length; var i = 0; for (; i + 1 < n; i += 2) { if (args[i] instanceof _Cell.CellError) { continue; } if (_this.arithmeticHelper.eq(selector, args[i])) { return args[i + 1]; } } if (i < n) { return args[i]; } else { return new _Cell.CellError(_Cell.ErrorType.NA, _errorMessage.ErrorMessage.NoDefault); } }); } }, { key: "iferror", value: function iferror(ast, state) { return this.runFunction(ast.args, state, this.metadata('IFERROR'), function (arg1, arg2) { if (arg1 instanceof _Cell.CellError) { return arg2; } else { return arg1; } }); } }, { key: "ifna", value: function ifna(ast, state) { return this.runFunction(ast.args, state, this.metadata('IFNA'), function (arg1, arg2) { if (arg1 instanceof _Cell.CellError && arg1.type === _Cell.ErrorType.NA) { return arg2; } else { return arg1; } }); } }, { key: "choose", value: function choose(ast, state) { return this.runFunction(ast.args, state, this.metadata('CHOOSE'), function (selector) { if (selector > (arguments.length <= 1 ? 0 : arguments.length - 1)) { return new _Cell.CellError(_Cell.ErrorType.NUM, _errorMessage.ErrorMessage.Selector); } return selector - 1 + 1 < 1 || arguments.length <= selector - 1 + 1 ? undefined : arguments[selector - 1 + 1]; }); } }]); return BooleanPlugin; }(_FunctionPlugin2.FunctionPlugin); exports.BooleanPlugin = BooleanPlugin; BooleanPlugin.implementedFunctions = { 'TRUE': { method: 'literalTrue', parameters: [] }, 'FALSE': { method: 'literalFalse', parameters: [] }, 'IF': { method: 'conditionalIf', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.BOOLEAN }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, defaultValue: false, passSubtype: true }] }, 'AND': { method: 'and', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.BOOLEAN }], repeatLastArgs: 1, expandRanges: true }, 'OR': { method: 'or', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.BOOLEAN }], repeatLastArgs: 1, expandRanges: true }, 'XOR': { method: 'xor', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.BOOLEAN }], repeatLastArgs: 1, expandRanges: true }, 'NOT': { method: 'not', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.BOOLEAN }] }, 'SWITCH': { method: 'switch', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.NOERROR }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }], repeatLastArgs: 1 }, 'IFERROR': { method: 'iferror', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }] }, 'IFNA': { method: 'ifna', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }] }, 'CHOOSE': { method: 'choose', parameters: [{ argumentType: _FunctionPlugin2.ArgumentTypes.INTEGER, minValue: 1 }, { argumentType: _FunctionPlugin2.ArgumentTypes.SCALAR, passSubtype: true }], repeatLastArgs: 1 } };