1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212
|
//------------------------------------------------------------------------------
// <copyright file="ValidationSummary.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//------------------------------------------------------------------------------
using System;
using System.Collections;
using System.ComponentModel;
using System.ComponentModel.Design;
using System.Drawing;
using System.Globalization;
using System.Web;
using System.Web.UI;
using System.Web.UI.Design.WebControls;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Diagnostics;
using System.Security.Permissions;
namespace System.Web.UI.MobileControls
{
/*
* Mobile ValidationSummary class.
* The ValidationSummary shows all the validation errors in a Form in a
* summary view.
*
* Copyright (c) 2000 Microsoft Corporation
*/
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary"]/*' />
[
DefaultProperty("FormToValidate"),
Designer(typeof(System.Web.UI.Design.MobileControls.ValidationSummaryDesigner)),
DesignerAdapter(typeof(System.Web.UI.Design.MobileControls.Adapters.DesignerValidationSummaryAdapter)),
ToolboxData("<{0}:ValidationSummary runat=\"server\"></{0}:ValidationSummary>"),
ToolboxItem("System.Web.UI.Design.WebControlToolboxItem, " + AssemblyRef.SystemDesign)
]
[AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)]
[Obsolete("The System.Web.Mobile.dll assembly has been deprecated and should no longer be used. For information about how to develop ASP.NET mobile applications, see http://go.microsoft.com/fwlink/?LinkId=157231.")]
public class ValidationSummary : MobileControl
{
private bool _callValidate = true;
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.ValidationSummary"]/*' />
public ValidationSummary()
{
StyleReference = Constants.ErrorStyle;
}
////////////////////////////////////////////////////////////////////////
// Mimic some properties exposed in the original ValidatorSummary.
////////////////////////////////////////////////////////////////////////
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.HeaderText"]/*' />
[
Bindable(true),
DefaultValue(""),
MobileCategory(SR.Category_Appearance),
MobileSysDescription(SR.ValidationSummary_HeaderText)
]
public String HeaderText
{
get
{
String s = (String) ViewState["HeaderText"];
return((s != null) ? s : String.Empty);
}
set
{
ViewState["HeaderText"] = value;
}
}
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.FormToValidate"]/*' />
[
Bindable(true),
DefaultValue(""),
MobileCategory(SR.Category_Behavior),
MobileSysDescription(SR.ValidationSummary_FormToValidate),
TypeConverter(typeof(System.Web.UI.Design.MobileControls.Converters.FormConverter))
]
public String FormToValidate
{
get
{
String s = (String) ViewState["FormToValidate"];
return((s != null) ? s : String.Empty);
}
set
{
ViewState["FormToValidate"] = value;
}
}
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.BackLabel"]/*' />
[
Bindable(true),
DefaultValue(""),
MobileCategory(SR.Category_Appearance),
MobileSysDescription(SR.ValidationSummary_BackLabel)
]
public String BackLabel
{
get
{
return ToString(ViewState["BackLabel"]);
}
set
{
ViewState["BackLabel"] = value;
}
}
// Designer needs to know the correct default value in order to persist it correctly.
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.StyleReference"]/*' />
[
DefaultValue(Constants.ErrorStyle)
]
public override String StyleReference
{
get
{
return base.StyleReference;
}
set
{
base.StyleReference = value;
}
}
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.OnLoad"]/*' />
protected override void OnLoad(EventArgs e)
{
base.OnLoad(e);
// There are cases that we don't want to call the Validate()
// method on individual validators that the ValidationSummary is
// targeting to.
// This first case is when the page is hit at the first time.
// And the second case is when FormToValidate is the same as the
// form ValidationSummary is on and this form is a postback from
// the same form. In this case, the validators' validate()
// method should have been called by MobilePage if needed.
if (!MobilePage.IsPostBack ||
String.Compare(Form.UniqueID, FormToValidate, StringComparison.OrdinalIgnoreCase) == 0)
{
_callValidate = false;
}
}
private void GetErrorValidators_Helper(Control parent, ArrayList errorValidators)
{
foreach(Control control in parent.Controls)
{
BaseValidator baseVal = control as BaseValidator;
if (baseVal != null && baseVal.ErrorMessage.Length != 0)
{
if (_callValidate)
{
baseVal.Validate();
}
if (!baseVal.IsValid)
{
errorValidators.Add(baseVal);
}
}
GetErrorValidators_Helper(control, errorValidators);
}
}
/// <include file='doc\ValidationSummary.uex' path='docs/doc[@for="ValidationSummary.GetErrorMessages"]/*' />
public String[] GetErrorMessages()
{
String[] errorDescriptions = null;
ArrayList errorValidators = new ArrayList();
Form targetForm = ResolveFormReferenceNoThrow(FormToValidate);
if (targetForm == null)
{
throw new ArgumentException(
SR.GetString(SR.ValidationSummary_InvalidFormToValidate,
FormToValidate,
ID));
}
// Recursively find all validators with error messages to display.
GetErrorValidators_Helper(targetForm, errorValidators);
int count = errorValidators.Count;
if (count > 0)
{
// get the messages;
errorDescriptions = new String[count];
int iMessage = 0;
foreach (BaseValidator val in errorValidators)
{
Debug.Assert(val != null, "Null reference unexpected!");
Debug.Assert(val.ErrorMessage.Length != 0, "Programmatic error: error message here shouldn't be empty!");
errorDescriptions[iMessage] = String.Copy(val.ErrorMessage);
iMessage++;
}
Debug.Assert(count == iMessage, "Not all messages were found!");
}
return errorDescriptions;
}
}
}
|