EditorPart.cs source code in C# .NET

Source code for the .NET framework in C#

                        

Code:

/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Web / UI / WebParts / EditorPart.cs / 1305376 / EditorPart.cs

                            //------------------------------------------------------------------------------ 
// 
//     Copyright (c) Microsoft Corporation.  All rights reserved.
// 
//----------------------------------------------------------------------------- 

namespace System.Web.UI.WebControls.WebParts { 
 
    using System;
    using System.Collections; 
    using System.Collections.Specialized;
    using System.ComponentModel;
    using System.Diagnostics;
    using System.Drawing; 
    using System.Globalization;
    using System.Security.Permissions; 
    using System.Web.UI; 
    using System.Web.UI.WebControls;
 
    [
    Bindable(false),
    Designer("System.Web.UI.Design.WebControls.WebParts.EditorPartDesigner, " + AssemblyRef.SystemDesign),
    ] 
    public abstract class EditorPart : Part {
 
        private WebPart _webPartToEdit; 
        private WebPartManager _webPartManager;
        private EditorZoneBase _zone; 

        /// 
        /// Whether the editor part should be displayed to the user.
        /// An editor part may decide that it should not be shown based on the state 
        /// or the type of web part it is associated with.
        ///  
        [ 
        Browsable(false),
        DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) 
        ]
        public virtual bool Display {
            get {
                // Always want EditorPart to be visible at design time (VSWhidbey 458247) 
                if (DesignMode) {
                    return true; 
                } 

                if (WebPartToEdit != null) { 
                    // Do not display EditorParts for a ProxyWebPart, regardless of the value
                    // of AllowEdit, IsShared, and PersonalizationScope
                    if (WebPartToEdit is ProxyWebPart) {
                        return false; 
                    }
 
                    if (!WebPartToEdit.AllowEdit && 
                        WebPartToEdit.IsShared &&
                        WebPartManager != null && 
                        WebPartManager.Personalization.Scope == PersonalizationScope.User) {
                        return false;
                    }
 
                    return true;
                } 
 
                // If there is no WebPartToEdit, return false as a default case
                return false; 
            }
        }

        [ 
        Browsable(false),
        DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) 
        ] 
        public string DisplayTitle {
            get { 
                string displayTitle = Title;
                if (String.IsNullOrEmpty(displayTitle)) {
                    displayTitle = SR.GetString(SR.Part_Untitled);
                } 
                return displayTitle;
            } 
        } 

        protected WebPartManager WebPartManager { 
            get {
                return _webPartManager;
            }
        } 

        ///  
        /// The web part that is being edited by this editor part.  Set by the EditorZoneBase after 
        /// the EditorPart is added to the zone's control collection.
        ///  
        protected WebPart WebPartToEdit {
            get {
                return _webPartToEdit;
            } 
        }
 
        protected EditorZoneBase Zone { 
            get {
                return _zone; 
            }
        }

        ///  
        /// Called by the Zone when the EditorPart should apply values to its associated control.  True indicates
        /// that the save was successful, false indicates that an error occurred. 
        ///  
        public abstract bool ApplyChanges();
 
        // If custom errors are enabled, we do not want to render the exception message to the browser. (VSWhidbey 381646)
        internal string CreateErrorMessage(string exceptionMessage) {
            if (Context != null && Context.IsCustomErrorEnabled) {
                return SR.GetString(SR.EditorPart_ErrorSettingProperty); 
            }
            else { 
                return SR.GetString(SR.EditorPart_ErrorSettingPropertyWithExceptionMessage, exceptionMessage); 
            }
        } 

        [SecurityPermission(SecurityAction.Demand, Unrestricted = true)]
        protected override IDictionary GetDesignModeState() {
            IDictionary state = new HybridDictionary(1); 
            state["Zone"] = Zone;
            return state; 
        } 

        protected internal override void OnPreRender(EventArgs e) { 
            base.OnPreRender(e);

            if (Zone == null) {
                throw new InvalidOperationException(SR.GetString(SR.EditorPart_MustBeInZone, ID)); 
            }
 
            // Need to set Visible=false so postback is handled correctly for child controls 
            // i.e. CheckBox child controls will always be set to false after postback unless
            // they are marked as not visible 
            if (Display == false) {
                Visible = false;
            }
        } 

        private void RenderDisplayName(HtmlTextWriter writer, string displayName, string associatedClientID) { 
            if (Zone != null) { 
                Zone.LabelStyle.AddAttributesToRender(writer, this);
            } 
            writer.AddAttribute(HtmlTextWriterAttribute.For, associatedClientID);
            writer.RenderBeginTag(HtmlTextWriterTag.Label);
            writer.WriteEncodedText(displayName);
            writer.RenderEndTag();  // Label 
        }
 
        internal void RenderPropertyEditors(HtmlTextWriter writer, string[] propertyDisplayNames, string[] propertyDescriptions, 
                                            WebControl[] propertyEditors, string[] errorMessages) {
            Debug.Assert(propertyDisplayNames.Length == propertyEditors.Length); 
            Debug.Assert(propertyDisplayNames.Length == errorMessages.Length);
            Debug.Assert(propertyDescriptions == null || (propertyDescriptions.Length == propertyDisplayNames.Length));

            if (propertyDisplayNames.Length == 0) { 
                return;
            } 
 
            writer.AddAttribute(HtmlTextWriterAttribute.Border, "0");
            writer.AddAttribute(HtmlTextWriterAttribute.Cellspacing, "4"); 
            writer.RenderBeginTag(HtmlTextWriterTag.Table);

            for (int i = 0; i < propertyDisplayNames.Length; i++) {
                WebControl editUIControl = propertyEditors[i]; 
                if (Zone != null && !Zone.EditUIStyle.IsEmpty) {
                    editUIControl.ApplyStyle(Zone.EditUIStyle); 
                } 

                string propertyDescription = (propertyDescriptions != null) ? propertyDescriptions[i] : null; 
                if (!String.IsNullOrEmpty(propertyDescription)) {
                    writer.AddAttribute(HtmlTextWriterAttribute.Title, propertyDescription);
                }
 
                writer.RenderBeginTag(HtmlTextWriterTag.Tr);
                writer.RenderBeginTag(HtmlTextWriterTag.Td); 
 
                if (editUIControl is CheckBox) {
                    editUIControl.RenderControl(writer); 
                    writer.Write(" ");
                    RenderDisplayName(writer, propertyDisplayNames[i], editUIControl.ClientID);
                }
                else { 
                    string associatedClientID;
                    CompositeControl compositeControl = editUIControl as CompositeControl; 
                    if (compositeControl != null) { 
                        // The 

Link Menu

Network programming in C#, Network Programming in VB.NET, Network Programming in .NET
This book is available now!
Buy at Amazon US or
Buy at Amazon UK