refactor(compute-parameters) rename functions and variables

This commit is contained in:
Ali BARIN
2024-08-21 10:23:48 +00:00
parent 7f9c2b687f
commit 34331d8763

View File

@@ -2,67 +2,137 @@ import get from 'lodash.get';
const variableRegExp = /({{step\.[\da-zA-Z-]+(?:\.[^.}{]+)+}})/g; const variableRegExp = /({{step\.[\da-zA-Z-]+(?:\.[^.}{]+)+}})/g;
export default function computeParameters(parameters, executionSteps) { function getParameterEntries(parameters) {
const entries = Object.entries(parameters); return Object.entries(parameters);
return entries.reduce((result, [key, value]) => { }
function computeParameterEntries(parameterEntries, executionSteps) {
const defaultComputedParameters = {};
return parameterEntries.reduce((result, [key, value]) => {
const parameterComputedValue = computeParameter(value, executionSteps);
return {
...result,
[key]: parameterComputedValue,
}
}, defaultComputedParameters);
}
function computeParameter(value, executionSteps) {
if (typeof value === 'string') { if (typeof value === 'string') {
const parts = value.split(variableRegExp); const computedStringParameter = computeStringParameter(value, executionSteps);
return computedStringParameter;
}
const computedValue = parts if (Array.isArray(value)) {
.map((part) => { const computedArrayParameter = computeArrayParameter(value, executionSteps);
const isVariable = part.match(variableRegExp); return computedArrayParameter;
}
if (isVariable) { return value;
const stepIdAndKeyPath = part.replace(/{{step.|}}/g, ''); }
function splitByVariable(stringValue) {
const parts = stringValue.split(variableRegExp);
return parts;
}
function isVariable(stringValue) {
return stringValue.match(variableRegExp);
}
function splitVariableByStepIdAndKeyPath(variableValue) {
const stepIdAndKeyPath = variableValue.replace(/{{step.|}}/g, '');
const [stepId, ...keyPaths] = stepIdAndKeyPath.split('.'); const [stepId, ...keyPaths] = stepIdAndKeyPath.split('.');
const keyPath = keyPaths.join('.'); const keyPath = keyPaths.join('.');
return {
stepId,
keyPath
}
}
function getVariableStepId(variableValue) {
const { stepId } = splitVariableByStepIdAndKeyPath(variableValue);
return stepId;
}
function getVariableKeyPath(variableValue) {
const { keyPath } = splitVariableByStepIdAndKeyPath(variableValue);
return keyPath
}
function getVariableExecutionStep(variableValue, executionSteps) {
const stepId = getVariableStepId(variableValue);
const executionStep = executionSteps.find((executionStep) => { const executionStep = executionSteps.find((executionStep) => {
return executionStep.stepId === stepId; return executionStep.stepId === stepId;
}); });
return executionStep;
}
function computeVariable(variable, executionSteps) {
const keyPath = getVariableKeyPath(variable);
const executionStep = getVariableExecutionStep(variable, executionSteps);
const data = executionStep?.dataOut; const data = executionStep?.dataOut;
const dataValue = get(data, keyPath); const computedVariable = get(data, keyPath);
// Covers both arrays and objects /**
if (typeof dataValue === 'object') { * Inline both arrays and objects. Otherwise, variables resolving to
return JSON.stringify(dataValue); * them would be resolved as `[object Object]` or lose their shape.
*/
if (typeof computedVariable === 'object') {
return JSON.stringify(computedVariable);
} }
return dataValue; return computedVariable;
} }
return part; function autoParseComputedVariable(computedVariable) {
}).join(''); // challenge the input to see if it is stringified object or array
// challenge the input to see if it is stringifies object or array
try { try {
const parsedValue = JSON.parse(computedValue); const parsedValue = JSON.parse(computedVariable);
if (typeof parsedValue === 'number') { if (typeof parsedValue === 'number') {
throw new Error('Use original unparsed value.'); throw new Error('Use original unparsed value.');
} }
return { return parsedValue;
...result,
[key]: parsedValue,
};
} catch (error) { } catch (error) {
return { return computedVariable;
...result,
[key]: computedValue,
};
} }
} }
if (Array.isArray(value)) { function computeStringParameter(stringValue, executionSteps) {
return { const parts = splitByVariable(stringValue);
...result,
[key]: value.map((item) => computeParameters(item, executionSteps)), const computedValue = parts
}; .map((part) => {
const variable = isVariable(part);
if (variable) {
return computeVariable(part, executionSteps);
} }
return { return part;
...result, })
[key]: value, .join('');
};
}, {}); const autoParsedValue = autoParseComputedVariable(computedValue);
return autoParsedValue;
}
function computeArrayParameter(arrayValue, executionSteps) {
return arrayValue.map((item) => computeParameters(item, executionSteps));
}
export default function computeParameters(parameters, executionSteps) {
const parameterEntries = getParameterEntries(parameters);
return computeParameterEntries(parameterEntries, executionSteps);
} }