|  | @@ -95,8 +95,9 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      public class ComplexFormulaFieldNode<TType, TResult> : IComplexFormulaNode<TType, TResult>, IComplexFormulaFieldNode
 | 
	
		
			
				|  |  |      {
 | 
	
		
			
				|  |  | -        //public Expression<Func<TType, TResult>> Expression { get; set; }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |          public string Field { get; set; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public ComplexFormulaFieldNode(Expression<Func<TType, TResult>> expression)
 | 
	
		
			
				|  |  |          {
 | 
	
	
		
			
				|  | @@ -109,6 +110,7 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          string IComplexFormulaFieldNode.GetField() => Field;
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      #endregion
 | 
	
	
		
			
				|  | @@ -322,17 +324,20 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public IComplexFormulaNode<TType, TCondition> Right { get; set; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public Condition Condition { get; set; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  | +        public object? Coalesce { get; set; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public ComplexFormulaPartial0ConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, Condition condition)
 | 
	
		
			
				|  |  | +        public ComplexFormulaPartial0ConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, Condition condition, object? coalesce)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              Left = left;
 | 
	
		
			
				|  |  |              Right = right;
 | 
	
		
			
				|  |  |              Condition = condition;
 | 
	
		
			
				|  |  | +            Coalesce = coalesce;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public ComplexFormulaPartial1ConditionNode<TType, TCondition, TValue> Then(IComplexFormulaNode<TType, TValue> then)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return new ComplexFormulaPartial1ConditionNode<TType, TCondition, TValue>(Left, Right, Condition, then);
 | 
	
		
			
				|  |  | +            return new ComplexFormulaPartial1ConditionNode<TType, TCondition, TValue>(Left, Right, Condition, then, Coalesce);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -345,18 +350,21 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public IComplexFormulaNode<TType, TValue> True { get; set; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public Condition Condition { get; set; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  | +        public object? Coalesce { get; set; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public ComplexFormulaPartial1ConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, Condition condition, IComplexFormulaNode<TType, TValue> trueValue)
 | 
	
		
			
				|  |  | +        public ComplexFormulaPartial1ConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, Condition condition, IComplexFormulaNode<TType, TValue> trueValue, object? coalesce)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              Left = left;
 | 
	
		
			
				|  |  |              Right = right;
 | 
	
		
			
				|  |  |              Condition = condition;
 | 
	
		
			
				|  |  |              True = trueValue;
 | 
	
		
			
				|  |  | +            Coalesce = coalesce;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public ComplexFormulaConditionNode<TType, TCondition, TValue> Else(IComplexFormulaNode<TType, TValue> elseValue)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return new ComplexFormulaConditionNode<TType, TCondition, TValue>(Left, Right, True, elseValue, Condition);
 | 
	
		
			
				|  |  | +            return new ComplexFormulaConditionNode<TType, TCondition, TValue>(Left, Right, True, elseValue, Condition, Coalesce);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -373,6 +381,9 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public IComplexFormulaNode False { get; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public Condition Condition { get; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  | +        public object? Coalesce { get; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |      public class ComplexFormulaConditionNode<TType, TCondition, TValue> : IComplexFormulaNode<TType, TValue>, IComplexFormulaConditionNode
 | 
	
		
			
				|  |  |      {
 | 
	
	
		
			
				|  | @@ -387,14 +398,17 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public IComplexFormulaNode<TType, TValue> False { get; set; }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public Condition Condition { get; set; }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        public ComplexFormulaConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, IComplexFormulaNode<TType, TValue> trueValue, IComplexFormulaNode<TType, TValue> falseValue, Condition condition)
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  | +        public object? Coalesce { get; }
 | 
	
		
			
				|  |  | +        
 | 
	
		
			
				|  |  | +        public ComplexFormulaConditionNode(IComplexFormulaNode<TType, TCondition> left, IComplexFormulaNode<TType, TCondition> right, IComplexFormulaNode<TType, TValue> trueValue, IComplexFormulaNode<TType, TValue> falseValue, Condition condition, object? coalesce)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              Left = left;
 | 
	
		
			
				|  |  |              Right = right;
 | 
	
		
			
				|  |  |              True = trueValue;
 | 
	
		
			
				|  |  |              False = falseValue;
 | 
	
		
			
				|  |  |              Condition = condition;
 | 
	
		
			
				|  |  | +            Coalesce = coalesce;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          IComplexFormulaNode IComplexFormulaConditionNode.Left => Left;
 | 
	
	
		
			
				|  | @@ -468,9 +482,10 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public static ComplexFormulaPartial0ConditionNode<TType, TCondition, TValue> If<TType, TCondition, TValue>(
 | 
	
		
			
				|  |  |              IComplexFormulaNode<TType, TCondition> left,
 | 
	
		
			
				|  |  |              Condition condition,
 | 
	
		
			
				|  |  | -            IComplexFormulaNode<TType, TCondition> right)
 | 
	
		
			
				|  |  | +            IComplexFormulaNode<TType, TCondition> right,
 | 
	
		
			
				|  |  | +            object? coalesce = null)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return new ComplexFormulaPartial0ConditionNode<TType, TCondition, TValue>(left, right, condition);
 | 
	
		
			
				|  |  | +            return new ComplexFormulaPartial0ConditionNode<TType, TCondition, TValue>(left, right, condition, coalesce);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -505,7 +520,8 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          ComplexFormulaPartial0ConditionNode<TType, TCondition, TResult> If<TCondition>(
 | 
	
		
			
				|  |  |              Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> left,
 | 
	
		
			
				|  |  |              Condition condition,
 | 
	
		
			
				|  |  | -            Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right);
 | 
	
		
			
				|  |  | +            Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right,
 | 
	
		
			
				|  |  | +            object? coalesce);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      internal class InternalComplexFormulaGenerator<TType, TResult> : IComplexFormulaGenerator<TType, TResult>
 | 
	
	
		
			
				|  | @@ -545,13 +561,15 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |          public ComplexFormulaPartial0ConditionNode<TType, TCondition, TResult> If<TCondition>(
 | 
	
		
			
				|  |  |              Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> left,
 | 
	
		
			
				|  |  |              Condition condition,
 | 
	
		
			
				|  |  | -            Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right)
 | 
	
		
			
				|  |  | +            Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right,
 | 
	
		
			
				|  |  | +            object? coalesce)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              var generator = new InternalComplexFormulaGenerator<TType, TCondition>();
 | 
	
		
			
				|  |  |              return ComplexFormulaGenerator.If<TType, TCondition, TResult>(
 | 
	
		
			
				|  |  |                  left(generator),
 | 
	
		
			
				|  |  |                  condition,
 | 
	
		
			
				|  |  | -                right(generator));
 | 
	
		
			
				|  |  | +                right(generator),
 | 
	
		
			
				|  |  | +                coalesce);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public IComplexFormulaNode<TType, int> Count<TAggregate, TExpression>(Func<IComplexFormulaGenerator<TAggregate, TExpression>, IComplexFormulaNode<TAggregate, TExpression>> expression, KeyValuePair<Expression<Func<TAggregate, object?>>, Expression<Func<TType, object?>>>[] links, Filter<TAggregate>? filter = null)
 | 
	
	
		
			
				|  | @@ -607,9 +625,9 @@ namespace InABox.Core
 | 
	
		
			
				|  |  |              return ((IComplexFormulaGenerator<TType, TResult>)InternalGenerator).Aggregate(calculation, expression, filter);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public ComplexFormulaPartial0ConditionNode<TType, TCondition, TResult> If<TCondition>(Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> left, Condition condition, Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right)
 | 
	
		
			
				|  |  | +        public ComplexFormulaPartial0ConditionNode<TType, TCondition, TResult> If<TCondition>(Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> left, Condition condition, Func<IComplexFormulaGenerator<TType, TCondition>, IComplexFormulaNode<TType, TCondition>> right, object? coalesce = null)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return ((IComplexFormulaGenerator<TType, TResult>)InternalGenerator).If(left, condition, right);
 | 
	
		
			
				|  |  | +            return ((IComplexFormulaGenerator<TType, TResult>)InternalGenerator).If(left, condition, right, coalesce);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |          public IComplexFormulaNode<TType, int> Count<TAggregate, TExpression>(Func<IComplexFormulaGenerator<TAggregate, TExpression>, IComplexFormulaNode<TAggregate, TExpression>> expression, KeyValuePair<Expression<Func<TAggregate, object?>>, Expression<Func<TType, object?>>>[] links, Filter<TAggregate>? filter = null)
 |