2018-03-26 22:14:23 +00:00
|
|
|
/**
|
|
|
|
* @author n1474335 [n1474335@gmail.com]
|
|
|
|
* @copyright Crown Copyright 2016
|
|
|
|
* @license Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
import Utils from "./Utils";
|
2018-04-02 17:06:48 +00:00
|
|
|
import {fromHex} from "./lib/Hex";
|
2018-03-26 22:14:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The arguments to operations.
|
|
|
|
*/
|
|
|
|
class Ingredient {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ingredient constructor
|
|
|
|
*
|
|
|
|
* @param {Object} ingredientConfig
|
|
|
|
*/
|
|
|
|
constructor(ingredientConfig) {
|
|
|
|
this.name = "";
|
|
|
|
this.type = "";
|
|
|
|
this._value = null;
|
2018-06-09 09:43:36 +00:00
|
|
|
this.disabled = false;
|
|
|
|
this.hint = "";
|
2019-01-09 15:28:50 +00:00
|
|
|
this.rows = 0;
|
2018-05-11 09:03:06 +00:00
|
|
|
this.toggleValues = [];
|
2018-06-10 11:03:55 +00:00
|
|
|
this.target = null;
|
2018-12-25 19:02:05 +00:00
|
|
|
this.defaultIndex = 0;
|
2018-03-26 22:14:23 +00:00
|
|
|
|
|
|
|
if (ingredientConfig) {
|
|
|
|
this._parseConfig(ingredientConfig);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads and parses the given config.
|
|
|
|
*
|
|
|
|
* @private
|
|
|
|
* @param {Object} ingredientConfig
|
|
|
|
*/
|
|
|
|
_parseConfig(ingredientConfig) {
|
|
|
|
this.name = ingredientConfig.name;
|
|
|
|
this.type = ingredientConfig.type;
|
|
|
|
this.defaultValue = ingredientConfig.value;
|
2018-06-09 09:43:36 +00:00
|
|
|
this.disabled = !!ingredientConfig.disabled;
|
|
|
|
this.hint = ingredientConfig.hint || false;
|
2019-01-09 15:28:50 +00:00
|
|
|
this.rows = ingredientConfig.rows || false;
|
2018-05-11 09:03:06 +00:00
|
|
|
this.toggleValues = ingredientConfig.toggleValues;
|
2018-06-10 11:03:55 +00:00
|
|
|
this.target = typeof ingredientConfig.target !== "undefined" ? ingredientConfig.target : null;
|
2018-12-25 19:02:05 +00:00
|
|
|
this.defaultIndex = typeof ingredientConfig.defaultIndex !== "undefined" ? ingredientConfig.defaultIndex : 0;
|
2018-03-26 22:14:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the value of the Ingredient as it should be displayed in a recipe config.
|
|
|
|
*
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
get config() {
|
|
|
|
return this._value;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the value of the Ingredient.
|
|
|
|
*
|
|
|
|
* @param {*} value
|
|
|
|
*/
|
|
|
|
set value(value) {
|
|
|
|
this._value = Ingredient.prepare(value, this.type);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the value of the Ingredient.
|
|
|
|
*
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
get value() {
|
|
|
|
return this._value;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Most values will be strings when they are entered. This function converts them to the correct
|
|
|
|
* type.
|
|
|
|
*
|
|
|
|
* @param {*} data
|
|
|
|
* @param {string} type - The name of the data type.
|
|
|
|
*/
|
|
|
|
static prepare(data, type) {
|
|
|
|
let number;
|
|
|
|
|
|
|
|
switch (type) {
|
|
|
|
case "binaryString":
|
|
|
|
case "binaryShortString":
|
|
|
|
case "editableOption":
|
2018-12-26 16:50:32 +00:00
|
|
|
case "editableOptionShort":
|
2018-03-26 22:14:23 +00:00
|
|
|
return Utils.parseEscapedChars(data);
|
|
|
|
case "byteArray":
|
|
|
|
if (typeof data == "string") {
|
|
|
|
data = data.replace(/\s+/g, "");
|
2018-04-02 17:06:48 +00:00
|
|
|
return fromHex(data);
|
2018-03-26 22:14:23 +00:00
|
|
|
} else {
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
case "number":
|
|
|
|
number = parseFloat(data);
|
|
|
|
if (isNaN(number)) {
|
|
|
|
const sample = Utils.truncate(data.toString(), 10);
|
|
|
|
throw "Invalid ingredient value. Not a number: " + sample;
|
|
|
|
}
|
|
|
|
return number;
|
|
|
|
default:
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Ingredient;
|