In this tutorial, you will learn how to fix an issue after you install, or more likely upgrade, the web forms for marketers module within Sitecore CMS. If you notice that your form validation is not working within WFFM, this is the tutorial for you 🔥🔥🔥

Recently, I updated WFFM as part of a Sitecore v7.2 to v7.5 upgrade. After upgrading the module, the required field validator stopped firing whenever a site visitor tried to submit a form without filling in a required dropdown list. To fix issues like this, I recommend you start by looking within the WFFH settings, which you can find within the Sitecore editor here:

SitecoreSystemModulesWeb Forms For MarketersSettings

This screen will look like this:

Sitecore WFFM Required Field Validator Not Working On Upgrade 1

From this screen, you will see all things WFFM, including the validation items, for submission items and a few other treats. As I had a validation issue, the first thing I wanted to do was check that all the upgraded validation items were correct. The easy way to do this is to make a comparison of the values in your sie to the values from a vanilla 7.5 site. Granted this means you need to install a second site, however, I find this is typically the quickest way to move forward.

Sitecore WFFM Required Field Validator Not Working On Upgrade 2

After comparing the two trees, everything looked to be in order. At this point, I went to Sitecore support who recommended I created a custom validator. In the end, a custom validator was not the best fix, however, I'll mention how to do their fix at the end of this tutorial, in case you find it useful.

DropList Required Field Validation Error: Instead of writing a custom validator as recommended by support, I fixed the issue within Sitecore. I compared the HTML between WFFM v2.4 to 2.5. This HTML comparison can be seen below:

Working: This is the working HTML

<div class="selecter-options">
<span class="selecter-item selected" data-value=" ">Title</span>
<span class="selecter-item" data-value="Mr">Mr</span>
<span class="selecter-item" data-value="Mrs">Mrs</span>
</div>

Broken: This is the broken HTML

<div class="selecter-options" style="display: block;">
<span class="selecter-item selected" data-value="Please select">Please select</span>
<span class="selecter-item" data-value="Mr">Mr</span>
<span class="selecter-item" data-value="Mrs">Mrs</span>
</div>

In case you didn't spot it, the main difference between the two is that the data-value item is empty on the existing working one, however, it is populated on the upgraded version:

Sitecore WFFM Required Field Validator Not Working On Upgrade 3

When I looked at my Please Selectitem, its value was empty. In previous versions of WFFM, an empty value would output an empty value. From WFFM v 2.5 upwards, the text property is rendered as the value if that field is empty. In my situation, the value Please select was being rendered as a value on the form. This now explains why the required field validator on the drop list stopped working, when the form was submitted it contained a value 😔

To fix the issue, simply add a few blank spaces into the value field. This simple tweak ensured the value was rendered empty. This empty field then allowed the form validation to work as expected:

Sitecore WFFM Required Field Validator Not Working On Upgrade 4

You should now have a working form 🔥🔥🔥

Create A Custom Validator: If you want to know how to create a custom validator as recommended by Sitecore support, let's cover that. To create a custom validator you need to override the related default required field validation items. These items can be found in two locations within the master database:

SystemSystem Validation

and:

SystemValidation

As seen below:

Sitecore WFFM Required Field Validator Not Working On Upgrade 3

To override the default WFFM required field logic, locate the NotEmpty item. This is found here:

/sitecore/system/Modules/Web Forms for Marketers/Settings/System/System Validation/NotEmpty

The value of the class property defines the code that Sitecore will call when a form validation request is made. If you want to create your own custom validator, you would create a new class that implements RequiredFieldValidator. If you are unsure of what code to write, you can use a tool like DotPeek to see what the code looks like within Sitecore.Form.Validators.RequiredWithMarkerValidator. To save yourself some time, this is the code:

using System;
using System.Web.UI.WebControls;
namespace Sitecore.Form.Validators
{
public class RequiredWithMarkerValidator : RequiredFieldValidator, ICloneable
{
public string Marker
{
get
{
return this.Attributes["marker"];
}
set
{
this.Attributes["marker"] = value;
}
}
public virtual object Clone()
{
RequiredWithMarkerValidator withMarkerValidator = new RequiredWithMarkerValidator();
this.CopyBaseAttributes((WebControl) withMarkerValidator);
withMarkerValidator.ErrorMessage = this.ErrorMessage;
withMarkerValidator.Text = this.Text;
withMarkerValidator.Marker = this.Marker;
withMarkerValidator.ToolTip = this.ToolTip;
withMarkerValidator.ValidationGroup = this.ValidationGroup;
withMarkerValidator.Display = this.Display;
withMarkerValidator.ID = this.ID;
withMarkerValidator.ControlToValidate = this.ControlToValidate;
withMarkerValidator.CssClass = this.CssClass;
withMarkerValidator.InitialValue = this.InitialValue;
withMarkerValidator.EnableClientScript = this.EnableClientScript;
withMarkerValidator.Enabled = this.Enabled;
withMarkerValidator.ForeColor = this.ForeColor;
withMarkerValidator.SetFocusOnError = this.SetFocusOnError;
return (object) withMarkerValidator;
}
}
}

This code isn't that helpful, however, if you look in the base class, RequiredFieldValidator, you can find the EvaluateIsValid() method:

protected override bool EvaluateIsValid() {
// Get the control value, return true if it is not found
string controlValue = GetControlValidationValue(ControlToValidate);
if (controlValue == null) {
Debug.Fail("Should have been caught by PropertiesValid check");
return true;
}
// See if the control has changed
return(!controlValue.Trim().Equals(InitialValue.Trim()));
}

To create a custom validator you can use this logic as your foundation and then tweak it to meet your needs.


Happy Coding 🤘