ChangeLog: Updated
[mono.git] / mcs / class / System.Web / System.Web.UI.WebControls / HyperLink.cs
index 83c1c7bc82d5bc32824f742ee44ff6dd0f14d370..81f563a18833bf40525788cd5b2531fdfcee6f2c 100755 (executable)
@@ -1,36 +1,62 @@
-/**\r
- * Namespace: System.Web.UI.WebControls\r
- * Class:     HyperLink\r
- *\r
- * Author:  Gaurav Vaish\r
- * Maintainer: gvaish@iitk.ac.in\r
- * Contact: gvaish@iitk.ac.in, myscripts_2001@yahoo.com\r
- * Implementation: yes\r
- * Status:  100%\r
- *\r
- * (C) Gaurav Vaish (2001)\r
- */\r
+//
+// System.Web.UI.WebControls.HyperLink.cs
+//
+// Authors:
+//   Gaurav Vaish (gvaish@iitk.ac.in)
+//   Gonzalo Paniagua Javier (gonzalo@ximian.com)
+//   Andreas Nahr (ClassDevelopment@A-SoftTech.com)
+//
+// (c) 2002 Ximian, Inc. (http://www.ximian.com)
+// (C) Gaurav Vaish (2002)
+// (C) 2003 Andreas Nahr
+//\r
+
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+// 
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+// 
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+//
 \r
 using System;\r
 using System.Web;\r
 using System.Web.UI;\r
-using System.ComponentModel;\r
+using System.ComponentModel;
+using System.ComponentModel.Design;\r
 \r
 namespace System.Web.UI.WebControls\r
 {\r
        [DefaultProperty("Text")]\r
-       //[Designer(??)]\r
        [ControlBuilder(typeof(HyperLinkControlBuilder))]\r
-       //[DataBindingHandler("??")]\r
+       [Designer("System.Web.UI.Design.WebControls.HyperLinkDesigner, " + Consts.AssemblySystem_Design, typeof (IDesigner))]\r
+       [DataBindingHandler("System.Web.UI.Design.HyperLinkDataBindingHandler, " + Consts.AssemblySystem_Design)]\r
        [ParseChildren(false)]\r
-       [PersistChildren(false)]\r
        [ToolboxData("<{0}:HyperLink runat=\"server\">HyperLink</{0}:HyperLink>")]\r
        public class HyperLink: WebControl\r
        {\r
+               bool textSet;\r
+\r
                public HyperLink(): base(HtmlTextWriterTag.A)\r
                {\r
                }\r
-\r
+
+               [DefaultValue (""), Bindable (true), WebCategory ("Appearance")]
+               [Editor ("System.Web.UI.Design.ImageUrlEditor, " + Consts.AssemblySystem_Design, typeof (System.Drawing.Design.UITypeEditor))]
+               [WebSysDescription ("The URL to the image file.")]\r
                public virtual string ImageUrl\r
                {\r
                        get\r
@@ -45,7 +71,10 @@ namespace System.Web.UI.WebControls
                                ViewState["ImageUrl"] = value;\r
                        }\r
                }\r
-\r
+
+               [DefaultValue (""), Bindable (true), WebCategory ("Navigation")]
+               [Editor ("System.Web.UI.Design.UrlEditor, " + Consts.AssemblySystem_Design, typeof (System.Drawing.Design.UITypeEditor))]
+               [WebSysDescription ("The URL to navigate to.")]\r
                public string NavigateUrl\r
                {\r
                        get\r
@@ -60,7 +89,10 @@ namespace System.Web.UI.WebControls
                                ViewState["NavigateUrl"] = value;\r
                        }\r
                }\r
-\r
+
+               [DefaultValue (""), Bindable (true), WebCategory ("Navigation")]
+               [TypeConverter (typeof (TargetConverter))]
+               [WebSysDescription ("The target frame in which the navigation target should be opened.")]\r
                public string Target\r
                {\r
                        get\r
@@ -75,28 +107,40 @@ namespace System.Web.UI.WebControls
                                ViewState["Target"] = value;\r
                        }\r
                }\r
-\r
+
+               [DefaultValue (""), Bindable (true), WebCategory ("Appearance")]
+               [PersistenceMode (PersistenceMode.InnerDefaultProperty)]
+               [WebSysDescription ("The text that should be shown on this HyperLink.")]\r
                public virtual string Text\r
                {\r
-                       get\r
-                       {\r
-                               object o = ViewState["Text"];\r
-                               if(o!=null)\r
-                                       return (string)o;\r
+                       get {\r
+                               object o = ViewState ["Text"];\r
+                               if (o != null)\r
+                                       return (string) o;\r
+\r
                                return String.Empty;\r
                        }\r
-                       set\r
-                       {\r
+                       set {\r
+                               if (HasControls())\r
+                                       Controls.Clear();\r
                                ViewState["Text"] = value;\r
+                               textSet = true;\r
                        }\r
                }\r
 \r
+               string InternalText\r
+               {\r
+                       get { return Text; }\r
+                       set { ViewState["Text"] = value; }\r
+               }\r
+\r
                protected override void AddAttributesToRender(HtmlTextWriter writer)\r
                {\r
                        base.AddAttributesToRender(writer);\r
                        if(NavigateUrl.Length > 0)\r
-                       {\r
-                               writer.AddAttribute(HtmlTextWriterAttribute.Href, NavigateUrl);\r
+                       {
+                               string url = ResolveUrl (NavigateUrl);
+                               writer.AddAttribute(HtmlTextWriterAttribute.Href, url);\r
                        }\r
                        if(Target.Length > 0)\r
                        {\r
@@ -113,12 +157,22 @@ namespace System.Web.UI.WebControls
                        }\r
                        if(obj is LiteralControl)\r
                        {\r
-                               Text = ((LiteralControl)obj).Text;\r
+                               // This is a hack to workaround the behaviour of the code generator, which\r
+                               // may split a text in several LiteralControls if there's a special character\r
+                               // such as '<' in it.\r
+                               if (textSet) {\r
+                                       Text = ((LiteralControl)obj).Text;\r
+                                       textSet = false;\r
+                               } else {\r
+                                       InternalText += ((LiteralControl)obj).Text;\r
+                               }\r
+                               //\r
+\r
                                return;\r
                        }\r
                        if(Text.Length > 0)\r
                        {\r
-                               base.AddParsedSubObject(Text);\r
+                               base.AddParsedSubObject(new LiteralControl (Text));\r
                                Text = String.Empty;\r
                        }\r
                        base.AddParsedSubObject (obj);\r
@@ -150,7 +204,7 @@ namespace System.Web.UI.WebControls
                        }\r
                        if(HasControls())\r
                        {\r
-                               base.RenderControl(writer);\r
+                               base.RenderContents(writer);\r
                                return;\r
                        }\r
                        writer.Write(Text);\r