Files
DMS/DMS.WPF/ViewModels/SplashViewModel.cs

83 lines
2.9 KiB
C#
Raw Normal View History

2025-07-26 11:20:03 +08:00
// 文件: DMS.WPF/ViewModels/SplashViewModel.cs
2025-07-26 11:20:03 +08:00
using CommunityToolkit.Mvvm.ComponentModel;
using CommunityToolkit.Mvvm.Input;
using DMS.Application.Interfaces;
using DMS.WPF.Services;
using System;
using System.Threading.Tasks;
using DMS.Application.Services;
2025-09-04 14:46:50 +08:00
using DMS.WPF.Helper;
using DMS.WPF.Interfaces;
2025-07-26 12:19:05 +08:00
using DMS.WPF.Views;
using Microsoft.Extensions.DependencyInjection;
2025-09-04 14:46:50 +08:00
using Microsoft.Extensions.Logging;
2025-07-26 11:20:03 +08:00
namespace DMS.WPF.ViewModels;
/// <summary>
/// 启动加载窗口的ViewModel。
/// </summary>
public partial class SplashViewModel : ObservableObject
{
private readonly ILogger<SplashViewModel> _logger;
2025-07-26 11:20:03 +08:00
private readonly IServiceProvider _serviceProvider;
private readonly IInitializeService _initializeService;
private readonly IDataEventService _dataEventService;
private readonly IAppDataCenterService _appDataCenterService;
2025-07-26 11:20:03 +08:00
[ObservableProperty]
private string _loadingMessage = "正在加载...";
public SplashViewModel(ILogger<SplashViewModel> logger,IServiceProvider serviceProvider, IInitializeService initializeService,IDataEventService dataEventService,
IAppDataCenterService appDataCenterService)
2025-07-26 11:20:03 +08:00
{
2025-09-04 14:46:50 +08:00
_logger = logger;
2025-07-26 11:20:03 +08:00
_serviceProvider = serviceProvider;
_initializeService = initializeService;
_dataEventService = dataEventService;
this._appDataCenterService = appDataCenterService;
2025-07-26 11:20:03 +08:00
}
/// <summary>
/// 开始执行初始化任务。
/// </summary>
2025-07-26 11:51:09 +08:00
public async Task<bool> InitializeAsync()
2025-07-26 11:20:03 +08:00
{
try
{
2025-09-04 14:46:50 +08:00
_logger.LogInformation("正在初始化数据库...");
2025-07-26 11:20:03 +08:00
LoadingMessage = "正在初始化数据库...";
_initializeService.InitializeTables();
_initializeService.InitializeMenus();
2025-07-26 11:20:03 +08:00
LoadingMessage = "正在加载系统配置...";
await _appDataCenterService.DataLoaderService.LoadAllDataToMemoryAsync();
2025-07-26 11:20:03 +08:00
// 可以在这里添加加载配置的逻辑
2025-07-26 12:19:05 +08:00
await Task.Delay(500); // 模拟耗时
2025-07-26 11:20:03 +08:00
LoadingMessage = "正在连接后台服务...";
// 可以在这里添加连接服务的逻辑
2025-07-26 12:19:05 +08:00
await Task.Delay(500); // 模拟耗时
2025-07-26 11:20:03 +08:00
LoadingMessage = "加载完成,正在启动主界面...";
2025-07-26 12:19:05 +08:00
await Task.Delay(500);
2025-07-26 11:20:03 +08:00
// 初始化完成,显示主窗口
2025-07-26 12:19:05 +08:00
var mainView = App.Current.Services.GetRequiredService<MainView>();
// 将 MainView 设置为新的主窗口
App.Current.MainWindow = mainView;
mainView.Show();
2025-07-26 11:51:09 +08:00
return true;
2025-07-26 11:20:03 +08:00
}
catch (Exception ex)
{
// 处理初始化过程中的异常
LoadingMessage = $"初始化失败: {ex.Message}";
_logger.LogError(ex,$"初始化失败: {ex}");
2025-07-26 11:20:03 +08:00
// 在此可以记录日志或显示错误对话框
2025-07-26 11:51:09 +08:00
return false;
2025-07-26 11:20:03 +08:00
}
}
}