using System.ComponentModel; using System.Runtime.CompilerServices; using System.Windows.Input; using log4net; using SparkClient.ViewModel.Configuration; namespace SparkClient.ViewModel; public class BaseViewModel : INotifyPropertyChanged { protected static readonly ILog Logger = LogManager.GetLogger(typeof(BaseViewModel)); public event PropertyChangedEventHandler PropertyChanged; protected void OnPropertyChanged([CallerMemberName] string propertyName = null) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } public BaseViewModel() { // 记录当前 ViewModel 的名称 Logger.Info($"Initializing {GetType().Name}"); } public class RelayCommand : ICommand { private readonly Action _execute; private readonly Func _canExecute; public RelayCommand(Action execute, Func canExecute = null) { _execute = execute ?? throw new ArgumentNullException(nameof(execute)); _canExecute = canExecute; } public bool CanExecute(object parameter) => _canExecute == null || _canExecute(parameter); public void Execute(object parameter) => _execute(parameter); public event EventHandler CanExecuteChanged { add { CommandManager.RequerySuggested += value; } remove { CommandManager.RequerySuggested -= value; } } } }