1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Windows.Input;
- namespace Aitex.Core.UI.MVVM
- {
- public class SubscriptionCommand<T> : ICommand
- {
- readonly Action<T> _execute;
- readonly Predicate<T> _canExecute;
- public event EventHandler CanExecuteChanged;
- public SubscriptionCommand(Action<T> execute)
- : this(execute, null)
- {
- }
- public SubscriptionCommand(Action<T> execute, Predicate<T> canExecute)
- {
- if (execute == null)
- throw new ArgumentNullException("execute");
- _execute = execute;
- _canExecute = canExecute;
- }
- public bool CanExecute(object parameter)
- {
- return _canExecute == null ? true : _canExecute((T)parameter);
- }
-
- // The CanExecuteChanged is automatically registered by command binding, we can assume that it has some execution logic
- // to update the button's enabled\disabled state(though we cannot see). So raises this event will cause the button's state be updated.
- public void RaiseCanExecuteChanged()
- {
- if (CanExecuteChanged != null)
- CanExecuteChanged(this, EventArgs.Empty);
- }
- public void Execute(object parameter)
- {
- _execute((T)parameter);
- }
- }
- }
|