using log4net;
using SparkClient.Model.Helper;
using SparkClient.ViewModel.BaseWindow;
using SparkClient.ViewModel.Configuration.SettingsPages;
using System.Windows.Input;
using MessageBox = SparkClient.Views.Dialog.MessageBox;

namespace SparkClient.ViewModel.Configuration;

public class SettingBaseVM : BaseViewModel
{
    private static readonly ILog Logger = LogManager.GetLogger(typeof(SettingBaseVM));
    public SettingsVM CustomSetContent { get; }
    public ModelColorSetPageVM ModelColorSetContent { get; }

    public ICommand SaveCommand { get; }

    public SettingBaseVM()
    {
        try
        {
            CustomSetContent = new SettingsVM();
            ModelColorSetContent = new ModelColorSetPageVM();
            SaveCommand = new RelayCommand(Save);
        }
        catch (Exception ex)
        {
            new MessageBox().Show($"{MultilingualHelper.getString("ApplicationError")}{ex.Message}");
            Logger.Error($"È«¾ÖÒì³£²¶»ñ£º{ex.Message}", ex);
        }
    }

    public void Save(object param)
    {
        try
        {
            if (CustomSetContent.SaveUpdate(param)&&
            ModelColorSetContent.SaveUpdate(param))
            {
                WindowManager.mainViewModel.Content = WindowManager.PreviousVM();
            }
        }
        catch (Exception ex)
        {
            new MessageBox().Show($"{MultilingualHelper.getString("ApplicationError")}{ex.Message}");
            Logger.Error($"È«¾ÖÒì³£²¶»ñ£º{ex.Message}", ex);
        }
    }
}