I'm currently using the ModelStateDictionary in asp.net mvc to hold validation errors and pass then back to the user. Being able to check if the whole model is valid with ModelState.IsValid is particularly. However, a current application I'm working on has a need to be able to report warnings. These aren't as critical so the form content can still be saved, but they should be shown to the user so that action can be optionally taken.
I've been looking through the framework to see if there are any obvious place to extend it to allow me to do this. I'm thinking that another dictionary with warnings in and a subclass of model error called model warning. I'm not sure how I'd get the framework to use my new container classes in the view etc. though, I still want all of the existing error stuff to work.
If anyone has tried anything similar or has any thoughts I'd appreciate their input.
Update:
I've got as far as extending the ViewDataDictionary to add some warnings
public class AetherViewDataDictionary : ViewDataDictionary
{
public AetherViewDataDictionary()
{
ModelStateWarning = new ModelStateDictionary();
}
public AetherViewDataDictionary(object model) : base(model)
{
ModelStateWarning = new ModelStateDictionary();
}
public AetherViewDataDictionary(ViewDataDictionary viewDataDictionary) : base(viewDataDictionary)
{
ModelStateWarning = new ModelStateDictionary();
}
public ModelStateDictionary ModelStateWarning { get; private set; }
}
The problem that I'm having now is that when I get to my view code, this is just for debug I'm losing the fact that its my new type, so when I try to cast it back and get access to my new dictionary I have no joy.
public partial class Index : ViewPage<PageViewData>
{
protected override void SetViewData(ViewDataDictionary viewData)
{
base.SetViewData(viewData);
}
}
It sets it correctly here, but when I check the type its gone.
Edit: This turned out to be a dumb way of doing things, see answer below.
I used the solution from Simon Farrow as a starting point to make the warnings work with Kendo's datasource. By default you can return and show
Data
ORErrors
but I wanted to return and showData
ANDWarnings
. So I've wrapped Kendo'sDataSourceResult
and added another extension method which returns the collected warnings.Why not simply add a list of warnings, or a dictionary, to the ViewData and then display them in your view?
e.g.
So the route that I was headed down before turned out to be a bad idea, there just isn't enough access in the framework to get at the bits that you need. At least not without reinventing the wheel a few times.
I decided to head down the route of extending the ModelState class to add a warnings collection to it:
In order to be able to easily add warnings in the same way that you would errors I created some extension methods for the ModelStateDictionary:
The GetModelStateForKey code is ropey but you should be able to see where I'm headed with this. The next thing to do is to write some extension methods that allow me to display the warnings along with the errors