Trying to rephrase/clean up question here:
I’m trying to do some sort of conditional statement to calculate a value. To mock my data I am assigning the value in my controller (temporarily) to see how my UI is coming along. I can perform the calculation in a function block in the view, but it’s lengthy and doesn’t belong there. So, I am trying now to do the calculation in a model (Calculations.cs).
The code for the calculation is working in that a value is being passed, except that my condition is failing and passing the default value of 0 when it should be passing another value based on my mocked value in the controller.
Here is the Calculations.cs
public class Calculations
{
PriceQuote price = new PriceQuote();
StepFilingInformation filing = new StepFilingInformation();
public decimal Chapter7Calculation
{
get
{
return
price.priceChapter7
+
((filing.PaymentPlanRadioButton ==
Models.StepFilingInformation.PaymentPlan.Yes)
?
price.pricePaymentPlanChapter7
:
0);
}
}
}
I originally had (filing.PaymentPlanRadioButton == Models.StepFilingInformation.PaymentPlan.Yes) checking whether or not the radio button was set to “Yes”, but changed it to ReferenceEquals. This doesn’t affect the outcome.
I have my controller assigning the value to PaymentPlanRadioButton to “Yes”, so pricePaymentPlanChapter7 should be the value being added to priceChapter7, but it is not. Instead “0” is being added as the fall back to the condition. So PaymentPlanRadioButton is null even though I am assigning it in the controller.
I cannot figure out how to fix this. If I assign it in the model and get it to work that will not resolve the issue as when I remove the mocking controller and expect a user to choose a radio button it will still be null and the condition will fail.
Here is the “mock” controller:
public class QuoteMailerController : Controller
{
public ActionResult EMailQuote()
{
Calculations calc = new Calculations();
var total = calc.Chapter7Calculation;
QuoteData quoteData = new QuoteData
{
StepFilingInformation = new Models.StepFilingInformation
{
//"No" is commented out, so "Yes" is assigned
//PaymentPlanRadioButton =
//Models.StepFilingInformation.PaymentPlan.No,
PaymentPlanRadioButton =
Models.StepFilingInformation.PaymentPlan.Yes,
}
};
}
}
And this is where I store prices (PriceQuote.cs):
public class PriceQuote
{
public decimal priceChapter7 { get { return 799; } }
public decimal pricePaymentPlanChapter7 { get { return 100; } }
}
This is my ViewModel:
public class QuoteData
{
public PriceQuote priceQuote;
public Calculations calculations;
public StepFilingInformation stepFilingInformation { get; set; }
public QuoteData()
{
PriceQuote = new PriceQuote();
Calculations = new Calculations();
}
}
So, the way this should work is 799 + 100 = 899, since PaymentPlan.Yes is assigned as the value to the radio button in the controller. But instead I am getting just 799 (799 + 0) because when I debug PaymentPlanRadioButton is coming up null.
Any thoughts/guidance?
Just in case, here is the PaymentPlanRadioButton located within StepFilingInformation.cs (and is one of my models):
public enum PaymentPlan
{
No,
Yes
}
public class PaymentPlanSelectorAttribute : SelectorAttribute
{
public override IEnumerable<SelectListItem> GetItems()
{
return Selector.GetItemsFromEnum<PaymentPlan>();
}
}
[PaymentPlanSelector(BulkSelectionThreshold = 3)]
public PaymentPlan? PaymentPlanRadioButton { get; set; }
Sorry for the length.
FOR CONTEXT THIS IS WHAT I WAS TRYING TO GET OUT OF DOING
I originally had this calculation code in a function block in my view. The calculation works fine there, but obviously very lengthy and not appropriate.
This is what my function block looked like (partially)
@{ Model.PriceQuote.calculationChapter7
=
Model.PriceQuote.priceChapter7
+
((Model.StepFilingInformation.PaymentPlanRadioButton ==
StepFilingInformation.PaymentPlan.No)
?
Model.PriceQuote.priceNoPaymentPlan
:
Model.PriceQuote.pricePaymentPlanChapter7)
+
...//more of the same
;
}
So I’ve been struggling to get this into a .cs file.
[Adding a 2nd answer since the added code has changed significantly since the original post].
I think the root problem here is the way you have implemented your Calculations class. The Chapter7Calculation property is always going to return 799 + 0, because it is using private local class variables to determine what values to return;
You have a ‘controller’ modifying some other instance of StepFilingInformation, which your Calculations class has no awareness of. As well, your PriceQuote class is just returning constant or static values, so there’s no real need to instantiate it. Modify that class like so;
Change your Calculations to a method like so;
And now your controller can pass in the QuoteData instance it has created, and you should see a better result. Example code for the mock controller;