Skip to content
Snippets Groups Projects
Select Git revision
  • 590c36d74a1bf31920e856434ef41afe7a3b437f
  • master default protected
  • 1.31
  • 4.38.2
  • 4.38.1
  • 4.38.0
  • 4.37.2
  • 4.37.1
  • 4.37.0
  • 4.36.0
  • 4.35.0
  • 4.34.1
  • 4.34.0
  • 4.33.1
  • 4.33.0
  • 4.32.2
  • 4.32.1
  • 4.32.0
  • 4.31.0
  • 4.30.1
  • 4.30.0
  • 4.29.1
  • 4.29.0
23 results

tutorial-tutorial.html

Blame
  • oroperator.mjs 2.20 KiB
    /**
     * Copyright © schukai GmbH and all contributing authors, {{copyRightYear}}. All rights reserved.
     * Node module: @schukai/monster
     *
     * This source code is licensed under the GNU Affero General Public License version 3 (AGPLv3).
     * The full text of the license can be found at: https://www.gnu.org/licenses/agpl-3.0.en.html
     *
     * For those who do not wish to adhere to the AGPLv3, a commercial license is available.
     * Acquiring a commercial license allows you to use this software without complying with the AGPLv3 terms.
     * For more information about purchasing a commercial license, please contact schukai GmbH.
     *
     * SPDX-License-Identifier: AGPL-3.0
     */
    
    import { AbstractOperator } from "./abstractoperator.mjs";
    import { instanceSymbol } from "../constants.mjs";
    export { OrOperator };
    
    /**
     * Constraints are used to define conditions that must be met by the value of a variable.
     *
     * The uniform API of the constraints allows chains to be formed.
     *
     * The OrOperator is used to link several constraints. The constraint is fulfilled if one of the constraints is fulfilled.
     *
     * @externalExample ../../example/constraints/oroperator.mjs
     * @license AGPLv3
     * @since 1.3.0
     * @copyright schukai GmbH
     * @memberOf Monster.Constraints
     * @summary A or operator
     */
    class OrOperator extends AbstractOperator {
    	/**
    	 * this method return a promise containing the result of the check.
    	 *
    	 * @param {*} value
    	 * @returns {Promise}
    	 */
    	isValid(value) {
    		var self = this;
    
    		return new Promise(function (resolve, reject) {
    			let a;
    			let b;
    
    			self.operantA
    				.isValid(value)
    				.then(function () {
    					resolve();
    				})
    				.catch(function () {
    					a = false;
    					/** b has already been evaluated and was not true */
    					if (b === false) {
    						reject();
    					}
    				});
    
    			self.operantB
    				.isValid(value)
    				.then(function () {
    					resolve();
    				})
    				.catch(function () {
    					b = false;
    					/** b has already been evaluated and was not true */
    					if (a === false) {
    						reject();
    					}
    				});
    		});
    	}
    
    	/**
    	 * This method is called by the `instanceof` operator.
    	 * @returns {symbol}
    	 * @since 2.1.0
    	 */
    	static get [instanceSymbol]() {
    		return Symbol.for("@schukai/monster/constraints/or-operator");
    	}
    }