Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / UI / WebControls / RadioButton.cs / 3 / RadioButton.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Web; using System.Web.UI; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Globalization; using System.Security.Permissions; ////// [ Designer("System.Web.UI.Design.WebControls.CheckBoxDesigner, " + AssemblyRef.SystemDesign), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class RadioButton : CheckBox, IPostBackDataHandler { #if SHIPPINGADAPTERS internal static readonly string AltSelectedText = "(o)"; internal static readonly string AltUnselectedText = "(_)"; #endif private string _uniqueGroupName = null; ///Constructs a radio button and defines its /// properties. ////// public RadioButton() { } ///Initializes a new instance of the ///class. /// [ DefaultValue(""), WebCategory("Behavior"), WebSysDescription(SR.RadioButton_GroupName), Themeable(false), ] public virtual string GroupName { get { string s = (string)ViewState["GroupName"]; return((s == null) ? String.Empty : s); } set { ViewState["GroupName"] = value; } } // Fully qualified GroupName for rendering purposes, to take care of conflicts // between different naming containers internal string UniqueGroupName { get { if (_uniqueGroupName == null) { // For radio buttons, we must make the groupname unique, but can't just use the // UniqueID because all buttons in a group must have the same name. So // we replace the last part of the UniqueID with the group Name. string name = GroupName; string uid = UniqueID; if (uid != null) { int lastColon = uid.LastIndexOf(IdSeparator); if (lastColon >= 0) { if (name.Length > 0) { name = uid.Substring(0, lastColon+1) + name; } else if (NamingContainer is RadioButtonList) { // If GroupName is not set we simply use the naming // container as the group name name = uid.Substring(0, lastColon); } } if (name.Length == 0) { name = uid; } } _uniqueGroupName = name; } return _uniqueGroupName; } } ///Gets or /// sets the name of the group that the radio button belongs to. ////// internal string ValueAttribute { get { string valueAttr = Attributes["value"]; if (valueAttr == null) { // EnsureID(); if (ID != null) valueAttr = ID; else valueAttr = UniqueID; } return valueAttr; } } ////// /// bool IPostBackDataHandler.LoadPostData(String postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } ///Method of IPostBackDataHandler interface to process posted data. /// RadioButton determines the posted radio group state. ////// /// protected override bool LoadPostData(String postDataKey, NameValueCollection postCollection) { string post = postCollection[UniqueGroupName]; bool valueChanged = false; if ((post != null) && post.Equals(ValueAttribute)) { ValidateEvent(UniqueGroupName, post); if (Checked == false) { Checked = true; // only fire change event for RadioButton that is being checked valueChanged = true; } } else { if (Checked == true) { Checked = false; } } return valueChanged; } ///Method of IPostBackDataHandler interface to process posted data. /// RadioButton determines the posted radio group state. ////// /// Raises when posted data for a control has changed. /// void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// Raises when posted data for a control has changed. /// protected override void RaisePostDataChangedEvent() { if (AutoPostBack && !Page.IsPostBackEventControlRegistered) { // Page.AutoPostBackControl = this; if (CausesValidation) { Page.Validate(ValidationGroup); } } OnCheckedChanged(EventArgs.Empty); } ////// /// This method is invoked just prior to rendering. /// Register client script for handling postback if onChangeHandler is set. /// protected internal override void OnPreRender(EventArgs e) { // must call CheckBox PreRender base.OnPreRender(e); if (Page != null && !Checked && Enabled) { Page.RegisterRequiresPostBack(this); } } internal override void RenderInputTag(HtmlTextWriter writer, string clientID, string onClick) { writer.AddAttribute(HtmlTextWriterAttribute.Id, clientID); writer.AddAttribute(HtmlTextWriterAttribute.Type, "radio"); writer.AddAttribute(HtmlTextWriterAttribute.Name, UniqueGroupName); writer.AddAttribute(HtmlTextWriterAttribute.Value, ValueAttribute); if (Page != null) { Page.ClientScript.RegisterForEventValidation(UniqueGroupName, ValueAttribute); } if (Checked) writer.AddAttribute(HtmlTextWriterAttribute.Checked, "checked"); // ASURT 119141: Render disabled attribute on the INPUT tag (instead of the SPAN) so the checkbox actually gets disabled when Enabled=false if (!IsEnabled) { writer.AddAttribute(HtmlTextWriterAttribute.Disabled, "disabled"); } // We don't do autopostback if the radio button has been selected. // This is to make it consistent that it only posts back if its // state has been changed. Also, it avoids the problem of missing // validation since the data changed event would not be fired if the // selected radio button was posting back. if (AutoPostBack && !Checked && Page != null) { PostBackOptions options = new PostBackOptions(this, String.Empty); // ASURT 98368 // Need to merge the autopostback script with the user script if (CausesValidation) { options.PerformValidation = true; options.ValidationGroup = ValidationGroup; } if (Page.Form != null) { options.AutoPostBack = true; } onClick = Util.MergeScript(onClick, Page.ClientScript.GetPostBackEventReference(options)); writer.AddAttribute(HtmlTextWriterAttribute.Onclick, onClick); if (EnableLegacyRendering) { writer.AddAttribute("language", "javascript", false); } } else { if (onClick != null) { writer.AddAttribute(HtmlTextWriterAttribute.Onclick, onClick); } } string s = AccessKey; if (s.Length > 0) writer.AddAttribute(HtmlTextWriterAttribute.Accesskey, s); int i = TabIndex; if (i != 0) { writer.AddAttribute(HtmlTextWriterAttribute.Tabindex, i.ToString(NumberFormatInfo.InvariantInfo)); } if (_inputAttributes != null && _inputAttributes.Count != 0) { _inputAttributes.AddAttributes(writer); } writer.RenderBeginTag(HtmlTextWriterTag.Input); writer.RenderEndTag(); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.Web; using System.Web.UI; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Globalization; using System.Security.Permissions; ////// [ Designer("System.Web.UI.Design.WebControls.CheckBoxDesigner, " + AssemblyRef.SystemDesign), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class RadioButton : CheckBox, IPostBackDataHandler { #if SHIPPINGADAPTERS internal static readonly string AltSelectedText = "(o)"; internal static readonly string AltUnselectedText = "(_)"; #endif private string _uniqueGroupName = null; ///Constructs a radio button and defines its /// properties. ////// public RadioButton() { } ///Initializes a new instance of the ///class. /// [ DefaultValue(""), WebCategory("Behavior"), WebSysDescription(SR.RadioButton_GroupName), Themeable(false), ] public virtual string GroupName { get { string s = (string)ViewState["GroupName"]; return((s == null) ? String.Empty : s); } set { ViewState["GroupName"] = value; } } // Fully qualified GroupName for rendering purposes, to take care of conflicts // between different naming containers internal string UniqueGroupName { get { if (_uniqueGroupName == null) { // For radio buttons, we must make the groupname unique, but can't just use the // UniqueID because all buttons in a group must have the same name. So // we replace the last part of the UniqueID with the group Name. string name = GroupName; string uid = UniqueID; if (uid != null) { int lastColon = uid.LastIndexOf(IdSeparator); if (lastColon >= 0) { if (name.Length > 0) { name = uid.Substring(0, lastColon+1) + name; } else if (NamingContainer is RadioButtonList) { // If GroupName is not set we simply use the naming // container as the group name name = uid.Substring(0, lastColon); } } if (name.Length == 0) { name = uid; } } _uniqueGroupName = name; } return _uniqueGroupName; } } ///Gets or /// sets the name of the group that the radio button belongs to. ////// internal string ValueAttribute { get { string valueAttr = Attributes["value"]; if (valueAttr == null) { // EnsureID(); if (ID != null) valueAttr = ID; else valueAttr = UniqueID; } return valueAttr; } } ////// /// bool IPostBackDataHandler.LoadPostData(String postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } ///Method of IPostBackDataHandler interface to process posted data. /// RadioButton determines the posted radio group state. ////// /// protected override bool LoadPostData(String postDataKey, NameValueCollection postCollection) { string post = postCollection[UniqueGroupName]; bool valueChanged = false; if ((post != null) && post.Equals(ValueAttribute)) { ValidateEvent(UniqueGroupName, post); if (Checked == false) { Checked = true; // only fire change event for RadioButton that is being checked valueChanged = true; } } else { if (Checked == true) { Checked = false; } } return valueChanged; } ///Method of IPostBackDataHandler interface to process posted data. /// RadioButton determines the posted radio group state. ////// /// Raises when posted data for a control has changed. /// void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// Raises when posted data for a control has changed. /// protected override void RaisePostDataChangedEvent() { if (AutoPostBack && !Page.IsPostBackEventControlRegistered) { // Page.AutoPostBackControl = this; if (CausesValidation) { Page.Validate(ValidationGroup); } } OnCheckedChanged(EventArgs.Empty); } ////// /// This method is invoked just prior to rendering. /// Register client script for handling postback if onChangeHandler is set. /// protected internal override void OnPreRender(EventArgs e) { // must call CheckBox PreRender base.OnPreRender(e); if (Page != null && !Checked && Enabled) { Page.RegisterRequiresPostBack(this); } } internal override void RenderInputTag(HtmlTextWriter writer, string clientID, string onClick) { writer.AddAttribute(HtmlTextWriterAttribute.Id, clientID); writer.AddAttribute(HtmlTextWriterAttribute.Type, "radio"); writer.AddAttribute(HtmlTextWriterAttribute.Name, UniqueGroupName); writer.AddAttribute(HtmlTextWriterAttribute.Value, ValueAttribute); if (Page != null) { Page.ClientScript.RegisterForEventValidation(UniqueGroupName, ValueAttribute); } if (Checked) writer.AddAttribute(HtmlTextWriterAttribute.Checked, "checked"); // ASURT 119141: Render disabled attribute on the INPUT tag (instead of the SPAN) so the checkbox actually gets disabled when Enabled=false if (!IsEnabled) { writer.AddAttribute(HtmlTextWriterAttribute.Disabled, "disabled"); } // We don't do autopostback if the radio button has been selected. // This is to make it consistent that it only posts back if its // state has been changed. Also, it avoids the problem of missing // validation since the data changed event would not be fired if the // selected radio button was posting back. if (AutoPostBack && !Checked && Page != null) { PostBackOptions options = new PostBackOptions(this, String.Empty); // ASURT 98368 // Need to merge the autopostback script with the user script if (CausesValidation) { options.PerformValidation = true; options.ValidationGroup = ValidationGroup; } if (Page.Form != null) { options.AutoPostBack = true; } onClick = Util.MergeScript(onClick, Page.ClientScript.GetPostBackEventReference(options)); writer.AddAttribute(HtmlTextWriterAttribute.Onclick, onClick); if (EnableLegacyRendering) { writer.AddAttribute("language", "javascript", false); } } else { if (onClick != null) { writer.AddAttribute(HtmlTextWriterAttribute.Onclick, onClick); } } string s = AccessKey; if (s.Length > 0) writer.AddAttribute(HtmlTextWriterAttribute.Accesskey, s); int i = TabIndex; if (i != 0) { writer.AddAttribute(HtmlTextWriterAttribute.Tabindex, i.ToString(NumberFormatInfo.InvariantInfo)); } if (_inputAttributes != null && _inputAttributes.Count != 0) { _inputAttributes.AddAttributes(writer); } writer.RenderBeginTag(HtmlTextWriterTag.Input); writer.RenderEndTag(); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SaveRecipientRequest.cs
- DocumentEventArgs.cs
- XmlDigitalSignatureProcessor.cs
- SystemIcons.cs
- ZipIOZip64EndOfCentralDirectoryLocatorBlock.cs
- DataTableClearEvent.cs
- ResXFileRef.cs
- CategoryNameCollection.cs
- SafeHandle.cs
- ConsumerConnectionPoint.cs
- LoadedOrUnloadedOperation.cs
- DataControlButton.cs
- DataGridParentRows.cs
- Symbol.cs
- EncryptedPackageFilter.cs
- ConvertTextFrag.cs
- DPCustomTypeDescriptor.cs
- Metadata.cs
- DayRenderEvent.cs
- cookiecollection.cs
- UserControlParser.cs
- TemplateBindingExtension.cs
- TogglePatternIdentifiers.cs
- X509IssuerSerialKeyIdentifierClause.cs
- MediaTimeline.cs
- XmlChoiceIdentifierAttribute.cs
- ClientConvert.cs
- PerfCounterSection.cs
- HandlerFactoryWrapper.cs
- HwndStylusInputProvider.cs
- DataServiceCollectionOfT.cs
- ErrorHandler.cs
- DefaultTypeArgumentAttribute.cs
- DrawingContextDrawingContextWalker.cs
- DragSelectionMessageFilter.cs
- XmlDataSource.cs
- PartitionResolver.cs
- CodeNamespaceImportCollection.cs
- DESCryptoServiceProvider.cs
- EventLogPermissionAttribute.cs
- EmptyReadOnlyDictionaryInternal.cs
- PrimitiveXmlSerializers.cs
- MatrixKeyFrameCollection.cs
- CommandHelpers.cs
- ConfigXmlWhitespace.cs
- RepeatInfo.cs
- DoubleLink.cs
- EventDescriptor.cs
- XmlSchemaGroupRef.cs
- Parser.cs
- QilInvoke.cs
- _NegotiateClient.cs
- CheckBox.cs
- CryptoConfig.cs
- DataServiceStreamResponse.cs
- BuildProvider.cs
- HMAC.cs
- StatusCommandUI.cs
- ApplicationFileCodeDomTreeGenerator.cs
- WebBrowserEvent.cs
- QilVisitor.cs
- IsolatedStorage.cs
- WebPartMenuStyle.cs
- WpfSharedXamlSchemaContext.cs
- CompilerWrapper.cs
- SBCSCodePageEncoding.cs
- SqlBulkCopyColumnMapping.cs
- SQLGuidStorage.cs
- PersonalizationEntry.cs
- RoleServiceManager.cs
- MetadataCacheItem.cs
- CheckBoxField.cs
- EmbeddedMailObjectsCollection.cs
- DataBinding.cs
- _HelperAsyncResults.cs
- OptimizerPatterns.cs
- Range.cs
- EdmFunctionAttribute.cs
- WebControlsSection.cs
- EncryptedReference.cs
- OutputScope.cs
- BackgroundWorker.cs
- DynamicControlParameter.cs
- DashStyle.cs
- VirtualizingPanel.cs
- HandlerFactoryCache.cs
- TrackingWorkflowEventArgs.cs
- CaseInsensitiveOrdinalStringComparer.cs
- HtmlDocument.cs
- FeatureSupport.cs
- DocumentsTrace.cs
- DataControlExtensions.cs
- SecUtil.cs
- VersionValidator.cs
- CodeTypeOfExpression.cs
- Restrictions.cs
- TextParentUndoUnit.cs
- TextFormatterImp.cs
- WindowsGraphics2.cs
- DelegateSerializationHolder.cs