e79aa3c0ed
Former-commit-id: a2155e9bd80020e49e72e86c44da02a8ac0e57a4
163 lines
6.1 KiB
C#
163 lines
6.1 KiB
C#
//------------------------------------------------------------------------------
|
|
// <copyright file="CustomValidator.cs" company="Microsoft">
|
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
// </copyright>
|
|
//------------------------------------------------------------------------------
|
|
|
|
namespace System.Web.UI.WebControls {
|
|
|
|
using System.ComponentModel;
|
|
using System.Web;
|
|
using System.Web.Util;
|
|
|
|
|
|
/// <devdoc>
|
|
/// <para> Allows custom code to perform
|
|
/// validation on the client and/or server.</para>
|
|
/// </devdoc>
|
|
[
|
|
DefaultEvent("ServerValidate"),
|
|
ToolboxData("<{0}:CustomValidator runat=\"server\" ErrorMessage=\"CustomValidator\"></{0}:CustomValidator>")
|
|
]
|
|
public class CustomValidator : BaseValidator {
|
|
|
|
private static readonly object EventServerValidate= new object();
|
|
|
|
|
|
/// <devdoc>
|
|
/// <para>Gets and sets the custom client Javascript function used
|
|
/// for validation.</para>
|
|
/// </devdoc>
|
|
[
|
|
WebCategory("Behavior"),
|
|
Themeable(false),
|
|
DefaultValue(""),
|
|
WebSysDescription(SR.CustomValidator_ClientValidationFunction)
|
|
]
|
|
public string ClientValidationFunction {
|
|
get {
|
|
object o = ViewState["ClientValidationFunction"];
|
|
return((o == null) ? String.Empty : (string)o);
|
|
}
|
|
set {
|
|
ViewState["ClientValidationFunction"] = value;
|
|
}
|
|
}
|
|
|
|
|
|
[
|
|
WebCategory("Behavior"),
|
|
Themeable(false),
|
|
DefaultValue(false),
|
|
WebSysDescription(SR.CustomValidator_ValidateEmptyText),
|
|
]
|
|
public bool ValidateEmptyText {
|
|
get {
|
|
object o = ViewState["ValidateEmptyText"];
|
|
return((o == null) ? false : (bool)o);
|
|
}
|
|
set {
|
|
ViewState["ValidateEmptyText"] = value;
|
|
}
|
|
}
|
|
|
|
|
|
/// <devdoc>
|
|
/// <para>Represents the method that will handle the
|
|
/// <see langword='ServerValidate'/> event of a
|
|
/// <see cref='System.Web.UI.WebControls.CustomValidator'/>.</para>
|
|
/// </devdoc>
|
|
[
|
|
WebSysDescription(SR.CustomValidator_ServerValidate)
|
|
]
|
|
public event ServerValidateEventHandler ServerValidate {
|
|
add {
|
|
Events.AddHandler(EventServerValidate, value);
|
|
}
|
|
remove {
|
|
Events.RemoveHandler(EventServerValidate, value);
|
|
}
|
|
}
|
|
|
|
|
|
/// <internalonly/>
|
|
/// <devdoc>
|
|
/// <para>Adds the properties of the <see cref='System.Web.UI.WebControls.CustomValidator'/> control to the
|
|
/// output stream for rendering on the client.</para>
|
|
/// </devdoc>
|
|
protected override void AddAttributesToRender(HtmlTextWriter writer) {
|
|
base.AddAttributesToRender(writer);
|
|
if (RenderUplevel) {
|
|
string id = ClientID;
|
|
HtmlTextWriter expandoAttributeWriter = (EnableLegacyRendering || IsUnobtrusive) ? writer : null;
|
|
|
|
AddExpandoAttribute(expandoAttributeWriter, id, "evaluationfunction", "CustomValidatorEvaluateIsValid", false);
|
|
if (ClientValidationFunction.Length > 0) {
|
|
AddExpandoAttribute(expandoAttributeWriter, id, "clientvalidationfunction", ClientValidationFunction);
|
|
if (ValidateEmptyText) {
|
|
AddExpandoAttribute(expandoAttributeWriter, id, "validateemptytext", "true", false);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/// <internalonly/>
|
|
/// <devdoc>
|
|
/// <para>Checks the properties of the control for valid values.</para>
|
|
/// </devdoc>
|
|
protected override bool ControlPropertiesValid() {
|
|
// Need to override the BaseValidator implementation, because for CustomValidator, it is fine
|
|
// for the ControlToValidate to be blank.
|
|
string controlToValidate = ControlToValidate;
|
|
if (controlToValidate.Length > 0) {
|
|
// Check that the property points to a valid control. Will throw and exception if not found
|
|
CheckControlValidationProperty(controlToValidate, "ControlToValidate");
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
/// <internalonly/>
|
|
/// <devdoc>
|
|
/// EvaluateIsValid method
|
|
/// </devdoc>
|
|
protected override bool EvaluateIsValid() {
|
|
|
|
// If no control is specified, we always fire the event. If they have specified a control, we
|
|
// only fire the event if the input is non-blank.
|
|
string controlValue = String.Empty;
|
|
string controlToValidate = ControlToValidate;
|
|
if (controlToValidate.Length > 0) {
|
|
controlValue = GetControlValidationValue(controlToValidate);
|
|
Debug.Assert(controlValue != null, "Should have been caught be property check");
|
|
// If the text is empty, we return true. Whitespace is ignored for coordination wiht
|
|
// RequiredFieldValidator.
|
|
if ((controlValue == null || controlValue.Trim().Length == 0) &&
|
|
!ValidateEmptyText) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return OnServerValidate(controlValue);
|
|
}
|
|
|
|
|
|
/// <devdoc>
|
|
/// <para>Raises the
|
|
/// <see langword='ServerValidate'/> event for the <see cref='System.Web.UI.WebControls.CustomValidator'/>.</para>
|
|
/// </devdoc>
|
|
protected virtual bool OnServerValidate(string value) {
|
|
ServerValidateEventHandler handler = (ServerValidateEventHandler)Events[EventServerValidate];
|
|
ServerValidateEventArgs args = new ServerValidateEventArgs(value, true);
|
|
if (handler != null) {
|
|
handler(this, args);
|
|
return args.IsValid;
|
|
}
|
|
else {
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|