2025-07-06 11:09:57 +08:00
|
|
|
using CommunityToolkit.Mvvm.Input;
|
|
|
|
|
using PMSWPF.Config;
|
|
|
|
|
using PMSWPF.Data;
|
|
|
|
|
using PMSWPF.Helper;
|
|
|
|
|
using SqlSugar;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
2025-06-23 13:42:02 +08:00
|
|
|
namespace PMSWPF.ViewModels;
|
|
|
|
|
|
2025-07-06 11:09:57 +08:00
|
|
|
public partial class SettingViewModel : ViewModelBase
|
2025-06-23 13:42:02 +08:00
|
|
|
{
|
2025-07-06 11:09:57 +08:00
|
|
|
private ConnectionSettings _connectionSettings;
|
|
|
|
|
|
|
|
|
|
public SettingViewModel()
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings = ConnectionSettings.Load();
|
|
|
|
|
AvailableDbTypes = Enum.GetNames(typeof(SqlSugar.DbType)).ToList();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public List<string> AvailableDbTypes { get; set; }
|
|
|
|
|
|
|
|
|
|
public string SelectedDbType
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.DbType;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.DbType != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.DbType = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public string Server
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.Server;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.Server != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.Server = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public int Port
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.Port;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.Port != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.Port = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public string UserId
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.UserId;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.UserId != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.UserId = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public string Password
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.Password;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.Password != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.Password = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public string Database
|
|
|
|
|
{
|
|
|
|
|
get => _connectionSettings.Database;
|
|
|
|
|
set
|
|
|
|
|
{
|
|
|
|
|
if (_connectionSettings.Database != value)
|
|
|
|
|
{
|
|
|
|
|
_connectionSettings.Database = value;
|
|
|
|
|
OnPropertyChanged();
|
|
|
|
|
_connectionSettings.Save();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[RelayCommand]
|
|
|
|
|
private async Task TestConnection()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
using (var db = DbContext.GetInstance())
|
|
|
|
|
{
|
|
|
|
|
await db.Ado.OpenAsync();
|
2025-07-06 15:36:53 +08:00
|
|
|
NotificationHelper.ShowSuccess("连接成功!");
|
2025-07-06 11:09:57 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2025-07-06 15:36:53 +08:00
|
|
|
NotificationHelper.ShowError($"连接失败:{ex.Message}", ex);
|
2025-07-06 11:09:57 +08:00
|
|
|
}
|
|
|
|
|
}
|
2025-06-23 13:42:02 +08:00
|
|
|
}
|