| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- //
- // System.Web.UI.WebControls.BaseDataBoundControl.cs
- //
- // Authors:
- // Lluis Sanchez Gual ([email protected])
- //
- // Copyright (C) 2004-2005 Novell, Inc (http://www.novell.com)
- //
- // 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.
- //
- #if NET_2_0
- using System.Collections;
- using System.ComponentModel;
- using System.Security.Permissions;
- namespace System.Web.UI.WebControls {
- // CAS
- [AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
- [AspNetHostingPermission (SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)]
- // attributes
- [DefaultProperty ("DataSourceID")]
- [DesignerAttribute ("System.Web.UI.Design.WebControls.BaseDataBoundControlDesigner, " + Consts.AssemblySystem_Design, "System.ComponentModel.Design.IDesigner")]
- public abstract class BaseDataBoundControl: WebControl
- {
- public event EventHandler DataBound;
-
- object dataSource;
- bool initialized;
- bool preRendered;
- bool requiresDataBinding;
-
- protected BaseDataBoundControl ()
- {
- }
- /* Used for controls that used to inherit from
- * WebControl, so the tag can propagate upwards
- */
- internal BaseDataBoundControl (HtmlTextWriterTag tag) : base (tag)
- {
- }
-
- [BindableAttribute (true)]
- [ThemeableAttribute (false)]
- [DefaultValueAttribute (null)]
- [DesignerSerializationVisibilityAttribute (DesignerSerializationVisibility.Hidden)]
- public virtual object DataSource {
- get {
- return dataSource;
- }
- set {
- if(value!=null)
- ValidateDataSource (value);
- dataSource = value;
- OnDataPropertyChanged ();
- }
- }
-
- [DefaultValueAttribute ("")]
- [ThemeableAttribute (false)]
- public virtual string DataSourceID {
- get {
- return ViewState.GetString ("DataSourceID", "");
- }
- set {
- ViewState["DataSourceID"] = value;
- OnDataPropertyChanged ();
- }
- }
-
- protected bool Initialized {
- get { return initialized; }
- }
-
- protected bool IsBoundUsingDataSourceID {
- get { return DataSourceID.Length > 0; }
- }
-
- protected bool RequiresDataBinding {
- get { return requiresDataBinding; }
- set {
- // MSDN: If you set the RequiresDataBinding
- // property to true when the data-bound control
- // has already begun to render its output to the
- // page, the current HTTP request is not a
- // callback, and you are using the DataSourceID
- // property to identify the data source control
- // to bind to, the DataBind method is called
- // immediately. In this case, the
- // RequiresDataBinding property is _not_ actually
- // set to true.
- //
- // LAMESPEC, the docs quoted above mention that
- // DataBind is called in the described
- // case. This is wrong since that way we don't
- // break recursion when the property is set from
- // within the OnSelect handler in user's
- // code. EnsureDataBound makes sure that no
- // recursive binding is performed. Also the
- // property DOES get set in this case (according
- // to tests)
- if (value && preRendered && IsBoundUsingDataSourceID && Page != null && !Page.IsCallback) {
- requiresDataBinding = true;
- EnsureDataBound ();
- } else
- requiresDataBinding = value;
- }
- }
-
- protected void ConfirmInitState ()
- {
- initialized = true;
- }
-
- public override void DataBind ()
- {
- PerformSelect ();
- }
- protected virtual void EnsureDataBound ()
- {
- if (RequiresDataBinding && IsBoundUsingDataSourceID)
- DataBind ();
- }
-
- protected virtual void OnDataBound (EventArgs e)
- {
- if (DataBound != null)
- DataBound (this, e);
- }
- protected virtual void OnDataPropertyChanged ()
- {
- if (Initialized)
- RequiresDataBinding = true;
- }
-
- protected internal override void OnInit (EventArgs e)
- {
- base.OnInit (e);
- Page.PreLoad += new EventHandler (OnPagePreLoad);
- if (!IsViewStateEnabled && Page != null && Page.IsPostBack)
- RequiresDataBinding = true;
- }
-
- protected virtual void OnPagePreLoad (object sender, EventArgs e)
- {
- ConfirmInitState ();
- }
-
- protected internal override void OnPreRender (EventArgs e)
- {
- preRendered = true;
- EnsureDataBound ();
- base.OnPreRender (e);
- }
- internal Control FindDataSource ()
- {
- Control ctrl = null;
- Control namingContainer = NamingContainer;
- while (namingContainer != null) {
- ctrl = namingContainer.FindControl (DataSourceID);
- if (ctrl != null)
- break;
- namingContainer = namingContainer.NamingContainer;
- }
- return ctrl;
- }
-
- protected abstract void PerformSelect ();
-
- protected abstract void ValidateDataSource (object dataSource);
-
- }
- }
- #endif
|