You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			81 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			81 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | namespace System.Web.UI.WebControls { | |||
|  |     using System; | |||
|  |     using System.Web.ModelBinding; | |||
|  | 
 | |||
|  |     /// <summary> | |||
|  |     /// Used to invoke <see cref='System.Web.UI.Page.UpdateModel' />/<see cref='System.Web.UI.Page.TryUpdateModel' />  | |||
|  |     /// methods where <see cref='System.Web.UI.Page' /> is directly not accessible. | |||
|  |     /// An example is a custom class defining the Select/Update/Delete/InsertMethod properties for  | |||
|  |     /// data binding can have a parameter of type <see cref='System.Web.UI.WebControls.ModelMethodContext' /> | |||
|  |     /// in the above methods and use it to invoke the above methods. Alternately instead of a method parameter, | |||
|  |     /// <see cref='System.Web.UI.WebControls.ModelMethodContext.Current' /> can also be used within the  | |||
|  |     /// Select/Update/Delete/InsertMethod code to invoke TryUpdateModel/UpdateModel methods. | |||
|  |     /// </summary> | |||
|  |     public class ModelMethodContext { | |||
|  |         private Page _page; | |||
|  | 
 | |||
|  |         public ModelMethodContext(Page page) { | |||
|  |             if (page == null) { | |||
|  |                 throw new ArgumentNullException("page"); | |||
|  |             } | |||
|  | 
 | |||
|  |             _page = page; | |||
|  |         } | |||
|  | 
 | |||
|  |         public ModelStateDictionary ModelState { | |||
|  |             get { | |||
|  |                 return _page.ModelState; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets the ModelMethodContext corresponding to the <see cref='System.Web.UI.Page' /> from <see cref='System.Web.HttpContext.Current' />. | |||
|  |         /// Can be null when the current request is not for a <see cref='System.Web.UI.Page' />. | |||
|  |         /// </summary> | |||
|  |         public static ModelMethodContext Current { | |||
|  |             get { | |||
|  |                 Page page = HttpContext.Current.Handler as Page; | |||
|  |                 if (page != null) { | |||
|  |                     return new ModelMethodContext(page); | |||
|  |                 } | |||
|  | 
 | |||
|  |                 return null; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Updates the model object from the values within a databound control. This must be invoked  | |||
|  |         /// within the Select/Update/Delete/InsertMethods used for data binding. | |||
|  |         /// Throws an exception if the update fails. | |||
|  |         /// </summary> | |||
|  |         public virtual void UpdateModel<TModel>(TModel model) where TModel : class { | |||
|  |             _page.UpdateModel<TModel>(model); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Updates the model object from the values provided by given valueProvider. | |||
|  |         /// Throws an exception if the update fails. | |||
|  |         /// </summary> | |||
|  |         public virtual void UpdateModel<TModel>(TModel model, IValueProvider valueProvider) where TModel : class { | |||
|  |             _page.UpdateModel<TModel>(model, valueProvider); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Attempts to update the model object from the values provided by given valueProvider. | |||
|  |         /// </summary> | |||
|  |         /// <returns>True if the model object is updated succesfully with valid values. False otherwise.</returns> | |||
|  |         public virtual bool TryUpdateModel<TModel>(TModel model) where TModel : class { | |||
|  |             return _page.TryUpdateModel<TModel>(model); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Attempts to update the model object from the values within a databound control. This | |||
|  |         /// must be invoked within the Select/Update/Delete/InsertMethods used for data binding.  | |||
|  |         /// </summary> | |||
|  |         /// <returns>True if the model object is updated succesfully with valid values. False otherwise.</returns> | |||
|  |         public virtual bool TryUpdateModel<TModel>(TModel model, IValueProvider valueProvider) where TModel : class { | |||
|  |             return _page.TryUpdateModel<TModel>(model, valueProvider); | |||
|  |         } | |||
|  |     } | |||
|  | } |