Skip to main content

WPF-MVVM: RelayCommand Implementation

In WPF if we are implementing MVVM pattern then we need to play with Command rather than Events. You can use ICommand interface to create each command class. Implementation of ICommand in a class gives you CanExecute(), Execute() methods which take part in the action performed by Command.

 

Rather than making Command Class for each Command we can implement a generic Relay Command to get Command. Below is a RelayCommand class that we will implement.

 

/// <summary>

    /// To register commands in MMVM pattern

    /// </summary>

    class RelayCommands : ICommand

    {

        readonly Action<object> _execute;

        readonly Predicate<object> _canExecute;

        /// <summary>

        /// Constructer takes Execute events to register in CommandManager.

        /// </summary>

        /// <param name="execute">Execute method as action.</param>

        public RelayCommands(Action<object> execute)

            : this(execute, null)

        {

            try

            {

                if (null == execute)

                {

                    throw new NotImplementedException("Not implemented");

                }

                _execute = execute;

            }

            catch (Exception)

            {

                throw;

            }

        }

        /// <summary>

        /// Constructer takes Execute and CanExcecute events to register in CommandManager.

        /// </summary>

        /// <param name="execute">Execute method as action.</param>

        /// <param name="canExecute">CanExecute method as return bool type.</param>

        public RelayCommands(Action<object> execute, Predicate<object> canExecute)

        {

            try

            {

                if (null == execute)

                {

                    _execute = null;

                    throw new NotImplementedException("Not implemented");

                }

                _execute = execute;

                _canExecute = canExecute;

            }

            catch (Exception)

            {

            }

        }

        /// <summary>

        /// Can Executed Changed Event

        /// </summary>

        public event EventHandler CanExecuteChanged

        {

            add

            {

                CommandManager.RequerySuggested += value;

            }

            remove

            {

                CommandManager.RequerySuggested -= value;

            }

        }

        /// <summary>

        /// Execute method.

        /// </summary>

        /// <param name="parameter">Method parameter.</param>

        public void Execute(object parameter)

        {

            _execute(parameter);

        }

        /// <summary>

        /// CanExecute method.

        /// </summary>

        /// <param name="parameter">Method parameter.</param>

        /// <returns>Return true if can execute.</returns>

        public bool CanExecute(object parameter)

        {

            return _canExecute == null || _canExecute(parameter);

        }

        /// <summary>

        /// InvalidateCanExecute method will initiate validation of the Command.

        /// </summary>

        private void InvalidateCanExecute()

        {

            CommandManager.InvalidateRequerySuggested();

        }

    }

 

 

 

You need to create object of RelayCommand with delegate as paramenters point to CanExecute and Execute methods.

Like:

 

       ICommand _createNewCollegeCommand;
 
       /// <summary>
       /// Command to create new College.
       /// </summary>
       public ICommand CreateNewCollegeCommand
       {
           get
           {
               if (_createNewCollegeCommand == null)
               {
                   _createNewCollegeCommand = new RelayCommands(param => this.CreateNewCollegeCommand_Execute(param),
                   param => this.CreateNewCollegeCommand_CanExecute(param));
               }
               return _createNewCollegeCommand;
           }
       }
 
       bool CreateNewCollegeCommand_CanExecute(object param)
       {
           return true;
       }
 
       void CreateNewCollegeCommand_Execute(object param)
       {
           IndividualCollegeViewModel indCollegeVM = this._individualCollegeVMFactory();
 
           //Set the DataContext
           (indCollegeVM.View as AddCollege).DataContext = indCollegeVM;
 
           //Show dialog box to add College.
           (indCollegeVM.View as AddCollege).Owner = this.CurrentView;
           (indCollegeVM.View as AddCollege).ShowDialog();
       }

 

 

Hope this will be helpful to you all.

DISCLAIMER ========== This e-mail may contain privileged and confidential information which is the property of Persistent Systems Ltd. It is intended only for the use of the individual or entity to which it is addressed. If you are not the intended recipient, you are not authorized to read, retain, copy, print, distribute or use this message. If you have received this communication in error, please notify the sender and delete all copies of this message. Persistent Systems Ltd. does not accept any liability for virus infected mails.

Comments

Popular posts from this blog

.Net List with Changed event

Sometimes we need a List which can notify user when an item is added. Here is the way that you can implement a generic ArrayList which notifies user at the time of an element is added.   using  System; using  System.Collections; namespace  ArchiveData.Logging {    // A delegate type for hooking up change notifications.    public   delegate   void   ChangedEventHandler ( object  sender,  EventArgs  e);    public   class   ListWithChangedEvent  :  ArrayList   {      // An event that clients can use to be notified whenever the      // elements of the list change.      public   event   ChangedEventHandler  Changed;      public   object  NewlyAddedItem {...

What is DispatcherTimer in wpf?

DispatcherTimer When you want to set a timer working with GUI, you always come across threading problem. The problem is that if you want to send some changes to UI that is constantly/continuously changing then that will make your UI unresponsive or in other words it will hang your UI.   To overcome from this situation, WPF gives us DispatcherTimer threading functionality that will take care of such continuously changing processing on UI thread and that will not hang your UI. We can accomplish same scenario in Win Form , through System.Windows.Forms.Timer and in WPF it is System.Windows.Threading.DispatcherTimer .   Difference between DispatcherTimer and Regular timer (System.Timers.Timer) DispatcherTimer is the regular timer. It fires its Tick event on the UI thread, you can do anything you want with the UI. System.Timers.Timer is an asynchronous timer, its Elapsed event runs on a thread pool thread. You have to be very careful in your event handler...