- 16 Aug 2021
- 2 Minutes to read
- Print
- DarkLight
SDK: Custom Validation(Advanced)
- Updated on 16 Aug 2021
- 2 Minutes to read
- Print
- DarkLight
Overview
Using the techniques described below, validation messages can be made to appear on the properties and inputs of steps at design time. These validations can evaluate only the value of a given property (e.g., show validation error if property X is empty) or they can be dependent on values in other properties (e.g., show validation error if property X is true AND property Y empty). Decisions has some built-in validation attributes that can be assigned to properties to check simple conditions like the value of a number or emptiness of a string. For more complex validation checks (and for validation checks of inputs as opposed to properties), use custom validation methods.
Examples of Simple Property Validation
- On a class, inherit and implement INotifyPropertyChanged. This will allow the validation messages to clear when the property value has changed to a valid value.
- Decorate the class with the ValidationRules attribute. This attribute alerts the Decisions framework that there are validation Rules on this object.
- Decorate the property with the desired validation with one of the following attributes:
- EmptyStringRule - Shows a validation issue if the property string value is empty (this check counts white space as empty).
[EmptyStringRule] public string Name { get => _name; set { _name = value; OnPropertyChanged(nameof(Name)); } }
- NullRule - Shows a validation issue if the property is null.
[NullRule(BreakLevel.Warning)] public DecisionsType Type { get => _type; set { _type = value; OnPropertyChanged(nameof(Type)); } }
- NumberAboveRule - Shows a validation issue if the property value is below a given number. Must be given at least one argument to define the minimum numeric value that this property is allowed to have.
[EmptyStringRule] public string Name { get => _name; set { _name = value; OnPropertyChanged(nameof(Name)); } }
- NumberBelowRule - Shows a validation issue if the property value is above a given number. Must be given at least one argument to define the maximum numeric value that this property is allowed to have.
[EmptyStringRule] public string Name { get => _name; set { _name = value; OnPropertyChanged(nameof(Name)); } }
- EmptyStringRule - Shows a validation issue if the property string value is empty (this check counts white space as empty).
Examples of Custom (method based) Validation
The following describes how to do more complex validations using custom methods.
- In the class, inherit from and implement IValidationSource.
- Within this method, a developer can write code that evaluates any kind of conditions desired. Below is an example showing how this method would be written to evaluate the value of a date field based on the value of a Boolean field.
public ValidationIssue[] GetValidationIssues() { List<ValidationIssue> issues = new List<ValidationIssue>(); if (ForceFutureDate && MyDate < DateTime.Now) { issues.Add(new ValidationIssue(this, "Date must be in the future", string.Empty, BreakLevel.Fatal, nameof(MyDate))); } return issues.ToArray(); }