// Sanjay Gupta (gsanjay@novell.com)
// Lluis Sanchez Gual (lluis@novell.com)
//
-// (C) 2004 Novell, Inc. (http://www.novell.com)
+// (C) 2004-2010 Novell, Inc. (http://www.novell.com)
//
//
// 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.Collections.Specialized;
using System.Web.UI;
using System.ComponentModel;
using System.Security.Permissions;
-namespace System.Web.UI.WebControls {
-
+namespace System.Web.UI.WebControls
+{
[DefaultPropertyAttribute ("HeaderText")]
[TypeConverterAttribute (typeof(ExpandableObjectConverter))]
[AspNetHostingPermissionAttribute (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
[AspNetHostingPermissionAttribute (SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)]
public abstract class DataControlField : IStateManager, IDataSourceViewSchemaAccessor
{
+ static readonly object fieldChangedEvent = new object ();
+
bool tracking = false;
StateBag viewState;
Control control;
TableItemStyle headerStyle;
TableItemStyle itemStyle;
bool sortingEnabled;
+ EventHandlerList events = new EventHandlerList ();
+
+ internal event EventHandler FieldChanged {
+ add { events.AddHandler (fieldChangedEvent, value); }
+ remove { events.RemoveHandler (fieldChangedEvent, value); }
+ }
protected DataControlField()
{
public virtual void InitializeCell (DataControlFieldCell cell,
DataControlCellType cellType, DataControlRowState rowState, int rowIndex)
{
- if (cellType == DataControlCellType.Header)
- {
+ if (cellType == DataControlCellType.Header) {
if (HeaderText.Length > 0 && sortingEnabled && SortExpression.Length > 0)
- cell.Controls.Add (new DataControlButton (control, HeaderText, HeaderImageUrl, DataControlCommands.SortCommandName, SortExpression, true));
+ cell.Controls.Add ((Control) DataControlButton.CreateButton (String.IsNullOrEmpty (HeaderImageUrl) ? ButtonType.Link : ButtonType.Image, control, HeaderText, HeaderImageUrl, DataControlCommands.SortCommandName, SortExpression, true));
else if (HeaderImageUrl.Length > 0) {
Image image = new Image ();
image.ImageUrl = HeaderImageUrl;
cell.Controls.Add (image);
- }
- else
+ } else
cell.Text = HeaderText.Length > 0 ? HeaderText : " ";
- }
- else if (cellType == DataControlCellType.Footer) {
+ } else if (cellType == DataControlCellType.Footer) {
string footerText = FooterText;
cell.Text = (footerText.Length > 0) ? footerText : " ";
}
protected virtual void OnFieldChanged ()
{
- if (FieldChanged != null)
- FieldChanged (this, EventArgs.Empty);
+ EventHandler eh = events [fieldChangedEvent] as EventHandler;
+
+ if (eh != null)
+ eh (this, EventArgs.Empty);
}
protected virtual void LoadViewState (object savedState)
((IStateManager)ItemStyle).LoadViewState (states[4]);
}
- protected virtual object SaveViewState()
+ protected virtual object SaveViewState ()
{
object[] state = new object [5];
state [0] = viewState.SaveViewState ();
return state;
}
- protected virtual void TrackViewState()
+ protected virtual void TrackViewState ()
{
if (controlStyle != null) ((IStateManager) controlStyle).TrackViewState ();
if (footerStyle != null) ((IStateManager) footerStyle).TrackViewState ();
throw new NotSupportedException ("Callback not supported");
}
- void IStateManager.LoadViewState(object savedState)
+ void IStateManager.LoadViewState (object savedState)
{
- LoadViewState(savedState);
+ LoadViewState (savedState);
}
- object IStateManager.SaveViewState()
+ object IStateManager.SaveViewState ()
{
- return SaveViewState();
+ return SaveViewState ();
}
- void IStateManager.TrackViewState()
+ void IStateManager.TrackViewState ()
{
- TrackViewState();
+ TrackViewState ();
}
internal Exception GetNotSupportedPropException (string propName)
return new System.NotSupportedException ("The property '" + propName + "' is not supported in " + GetType().Name);
}
+ internal bool ControlStyleCreated { get { return controlStyle != null; } }
+
+ internal bool HeaderStyleCreated { get { return headerStyle != null; } }
+
+ internal bool FooterStyleCreated { get { return footerStyle != null; } }
+
+ internal bool ItemStyleCreated { get { return itemStyle != null; } }
+
[MonoTODO ("Render this")]
[DefaultValueAttribute ("")]
[LocalizableAttribute (true)]
public virtual string AccessibleHeaderText {
get {
object val = viewState ["accessibleHeaderText"];
- return val != null ? (string) val : "";
+ return val != null ? (string) val : String.Empty;
}
set {
viewState ["accessibleHeaderText"] = value;
public virtual string FooterText {
get {
object val = viewState ["footerText"];
- return val != null ? (string) val : "";
+ return val != null ? (string) val : String.Empty;
}
set {
viewState ["footerText"] = value;
public virtual string HeaderImageUrl {
get {
object val = viewState ["headerImageUrl"];
- return val != null ? (string) val : "";
+ return val != null ? (string) val : String.Empty;
}
set {
viewState ["headerImageUrl"] = value;
public virtual string HeaderText {
get {
object val = viewState ["headerText"];
- return val != null ? (string) val : "";
+ return val != null ? (string) val : String.Empty;
}
set {
viewState ["headerText"] = value;
public virtual string SortExpression {
get {
object val = viewState ["sortExpression"];
- return val != null ? (string) val : "";
+ return val != null ? (string) val : String.Empty;
}
set {
viewState ["sortExpression"] = value;
return val != null ? (bool) val : true;
}
set {
+ if (value == Visible)
+ return;
viewState ["visible"] = value;
OnFieldChanged ();
}
set {
viewState ["dataSourceViewSchema"] = value;
}
- }
-
- internal event EventHandler FieldChanged;
+ }
public override string ToString ()
{
}
}
}
-#endif