using System.Windows;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using NLog;
using NLog.Extensions.Logging;
using PMSWPF.Data;
using PMSWPF.Data.Entities;
using PMSWPF.Data.Repositories;
using PMSWPF.Services;
using PMSWPF.ViewModels;
using PMSWPF.Views;
using LogLevel = Microsoft.Extensions.Logging.LogLevel;
namespace PMSWPF;
///
/// Interaction logic for App.xaml
///
public partial class App : Application
{
public App()
{
var container = new ServiceCollection();
var nlog = LogManager.Setup().LoadConfigurationFromFile("Config/nlog.config").GetCurrentClassLogger();
container.AddLogging(loggingBuilder =>
{
loggingBuilder.ClearProviders();
loggingBuilder.SetMinimumLevel(LogLevel.Trace);
loggingBuilder.AddNLog();
});
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
container.AddSingleton();
Services = container.BuildServiceProvider();
// 启动服务
Services.GetRequiredService();
}
public new static App Current => (App)Application.Current;
public IServiceProvider Services { get; }
protected override void OnStartup(StartupEventArgs e)
{
base.OnStartup(e);
InitDB();
MainWindow = Services.GetRequiredService();
MainWindow.Show();
}
private void InitDB()
{
var _db = DbContext.GetInstance();
_db.DbMaintenance.CreateDatabase();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
_db.CodeFirst.InitTables();
}
}