You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			345 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			345 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // <copyright file="HtmlInputImage.cs" company="Microsoft">
 | |
| //     Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| // </copyright>                                                                
 | |
| //------------------------------------------------------------------------------
 | |
| 
 | |
| /*
 | |
|  * HtmlInputImage.cs
 | |
|  *
 | |
|  * Copyright (c) 2000 Microsoft Corporation
 | |
|  */
 | |
| 
 | |
| namespace System.Web.UI.HtmlControls {
 | |
| 
 | |
|     using System;
 | |
|     using System.Collections;
 | |
|     using System.Collections.Specialized;
 | |
|     using System.Globalization;
 | |
|     using System.ComponentModel;
 | |
|     using System.Web;
 | |
|     using System.Web.UI;
 | |
|     using System.Security.Permissions;
 | |
| 
 | |
| 
 | |
| /// <devdoc>
 | |
| ///    <para>
 | |
| ///       The <see langword='HtmlInputImage'/> class defines the
 | |
| ///       methods, properties and events for the HtmlInputImage control. This class allows
 | |
| ///       programmatic access to the HTML <input type=
 | |
| ///       image> element on the server.
 | |
| ///    </para>
 | |
| /// </devdoc>
 | |
|     [
 | |
|     DefaultEvent("ServerClick"),
 | |
|     SupportsEventValidation,
 | |
|     ]
 | |
|     public class HtmlInputImage : HtmlInputControl,
 | |
|     IPostBackDataHandler, IPostBackEventHandler {
 | |
| 
 | |
|         private static readonly object EventServerClick = new object();
 | |
|         private int _x;
 | |
|         private int _y;
 | |
| 
 | |
| 
 | |
|         /*
 | |
|          * Creates an intrinsic Html INPUT type=image control.
 | |
|          */
 | |
| 
 | |
|         public HtmlInputImage() : base("image") {
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Gets or sets the image
 | |
|         ///       alignment within the form's content flow.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Align property.
 | |
|          */
 | |
|         [
 | |
|         WebCategory("Appearance"),
 | |
|         DefaultValue(""),
 | |
|         DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
 | |
|         ]
 | |
|         public string Align {
 | |
|             get {
 | |
|                 string s = Attributes["align"];
 | |
|                 return((s != null) ? s : String.Empty);
 | |
|             }
 | |
|             set {
 | |
|                 Attributes["align"] = MapStringAttributeToString(value);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Gets or sets the alternative text
 | |
|         ///       that the browser should display if the image is either unavailable or has not
 | |
|         ///       been downloaded yet.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Alt property.
 | |
|          */
 | |
|         [
 | |
|         WebCategory("Appearance"),
 | |
|         DefaultValue(""),
 | |
|         DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden),
 | |
|         Localizable(true)
 | |
|         ]
 | |
|         public string Alt {
 | |
|             get {
 | |
|                 string s = Attributes["alt"];
 | |
|                 return((s != null) ? s : String.Empty);
 | |
|             }
 | |
|             set {
 | |
|                 Attributes["alt"] = MapStringAttributeToString(value);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Gets or sets the
 | |
|         ///       border width, in pixels, around the image.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Border property, size of border in pixels.
 | |
|          */
 | |
|         [
 | |
|         WebCategory("Appearance"),
 | |
|         DefaultValue(-1),
 | |
|         DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)
 | |
|         ]
 | |
|         public int Border {
 | |
|             get {
 | |
|                 string s = Attributes["border"];
 | |
|                 return((s != null) ? Int32.Parse(s, CultureInfo.InvariantCulture) : -1);
 | |
|             }
 | |
|             set {
 | |
|                 Attributes["border"] = MapIntegerAttributeToString(value);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Gets or sets the location of
 | |
|         ///       the image file relative to the page on which it is displayed.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Src property.
 | |
|          */
 | |
|         [
 | |
|         WebCategory("Appearance"),
 | |
|         DefaultValue(""),
 | |
|         DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden),
 | |
|         UrlProperty()
 | |
|         ]
 | |
|         public string Src {
 | |
|             get {
 | |
|                 string s = Attributes["src"];
 | |
|                 return((s != null) ? s : String.Empty);
 | |
|             }
 | |
|             set {
 | |
|                 Attributes["src"] = MapStringAttributeToString(value);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>Gets or sets whether pressing the button causes page validation to fire. This defaults to True so that when
 | |
|         ///          using validation controls, the validation state of all controls are updated when the button is clicked, both
 | |
|         ///          on the client and the server. Setting this to False is useful when defining a cancel or reset button on a page
 | |
|         ///          that has validators.</para>
 | |
|         /// </devdoc>
 | |
|         [
 | |
|         WebCategory("Behavior"),
 | |
|         DefaultValue(true),
 | |
|         ]
 | |
|         public virtual bool CausesValidation {
 | |
|             get {
 | |
|                 object b = ViewState["CausesValidation"];
 | |
|                 return((b == null) ? true : (bool)b);
 | |
|             }
 | |
|             set {
 | |
|                 ViewState["CausesValidation"] = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         [
 | |
|         WebCategory("Behavior"),
 | |
|         DefaultValue(""),
 | |
|         WebSysDescription(SR.PostBackControl_ValidationGroup)
 | |
|         ]
 | |
|         public virtual string ValidationGroup {
 | |
|             get {
 | |
|                 string s = (string)ViewState["ValidationGroup"];
 | |
|                 return((s == null) ? String.Empty : s);
 | |
|             }
 | |
|             set {
 | |
|                 ViewState["ValidationGroup"] = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Occurs on the server when a user clicks an <see langword='HtmlInputImage'/>
 | |
|         ///       control.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         [
 | |
|         WebCategory("Action"),
 | |
|         WebSysDescription(SR.HtmlInputImage_OnServerClick)
 | |
|         ]
 | |
|         public event ImageClickEventHandler ServerClick {
 | |
|             add {
 | |
|                 Events.AddHandler(EventServerClick, value);
 | |
|             }
 | |
|             remove {
 | |
|                 Events.RemoveHandler(EventServerClick, value);
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * This method is invoked just prior to rendering.
 | |
|          * Register requires handling postback to determine if image has been clicked.
 | |
|          */
 | |
|         protected internal override void OnPreRender(EventArgs e) {
 | |
|             base.OnPreRender(e);
 | |
| 
 | |
|             if (Page != null) {
 | |
|                 if (!Disabled)
 | |
|                     Page.RegisterRequiresPostBack(this);
 | |
|                 if (CausesValidation)
 | |
|                     Page.RegisterPostBackScript();
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 
 | |
| 
 | |
|         /// <devdoc>
 | |
|         ///    <para>
 | |
|         ///       Raised on the server when a user clicks an <see langword='HtmlInputImage'/>
 | |
|         ///       control.
 | |
|         ///    </para>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Method used to raise the OnServerClick event.
 | |
|          */
 | |
|         protected virtual void OnServerClick(ImageClickEventArgs e) {
 | |
|             ImageClickEventHandler handler = (ImageClickEventHandler)Events[EventServerClick];
 | |
|             if (handler != null) handler(this, e);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Method of IPostBackEventHandler interface to raise events on post back.
 | |
|          * HtmlInputImage fires an OnServerClick event.
 | |
|          */
 | |
|         void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) {
 | |
|             RaisePostBackEvent(eventArgument);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         protected virtual void RaisePostBackEvent(string eventArgument) {
 | |
|             if (CausesValidation) {
 | |
|                 Page.Validate(ValidationGroup);
 | |
|             }
 | |
|             OnServerClick(new ImageClickEventArgs(_x, _y));
 | |
|         }
 | |
|         
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Method of IPostBackDataHandler interface to process posted data.
 | |
|          * The image control will check to see if the x and y values were posted,
 | |
|          * which indicates that the image was clicked by the user.  The image
 | |
|          * control will then register with the Page that it wants to raise an event
 | |
|          * during the event processing phase.
 | |
|          */
 | |
|         bool IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection) {
 | |
|             return LoadPostData(postDataKey, postCollection);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection) {
 | |
|             string postX = postCollection[RenderedNameAttribute + ".x"];
 | |
|             string postY = postCollection[RenderedNameAttribute + ".y"];
 | |
| 
 | |
|             if (postX != null && postY != null &&
 | |
|                 postX.Length > 0 && postY.Length > 0) {
 | |
| 
 | |
|                 ValidateEvent(UniqueID);
 | |
| 
 | |
|                 _x = Int32.Parse(postX, CultureInfo.InvariantCulture);
 | |
|                 _y = Int32.Parse(postY, CultureInfo.InvariantCulture);
 | |
| 
 | |
|                 Page.RegisterRequiresRaiseEvent(this);
 | |
|             }
 | |
| 
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         /*
 | |
|          * Method of IPostBackDataHandler interface which is invoked whenever posted data
 | |
|          * for a control has changed.
 | |
|          */
 | |
|         void IPostBackDataHandler.RaisePostDataChangedEvent() {
 | |
|             RaisePostDataChangedEvent();
 | |
|         }
 | |
| 
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         protected virtual void RaisePostDataChangedEvent() {
 | |
|         }
 | |
| 
 | |
|         /*
 | |
|          * Override to render unique name attribute.
 | |
|          * The name attribute is owned by the framework.
 | |
|          */
 | |
| 
 | |
|         /// <internalonly/>
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         protected override void RenderAttributes(HtmlTextWriter writer) {
 | |
|             PreProcessRelativeReferenceAttribute(writer, "src");
 | |
| 
 | |
|             if (Page != null) {
 | |
|                 Util.WriteOnClickAttribute(
 | |
|                     writer, this, true, false,
 | |
|                     (CausesValidation && Page.GetValidators(ValidationGroup).Count > 0),
 | |
|                     ValidationGroup);
 | |
|             }
 | |
| 
 | |
|             base.RenderAttributes(writer);
 | |
|         }
 | |
|     }
 | |
| }
 |