Recently I migrated my WPF app (.NET 4.7) to .Net Core 3.1. Most of it works fine except for me not being able to generate/add EF Core migrations.
I integrated my dbContext / EF Core with help of the following post(s) using Dependency Injection:
- https://marcominerva.wordpress.com/2019/03/06/using-net-core-3-0-dependency-injection-and-service-provider-with-wpf/
 - https://marcominerva.wordpress.com/2019/03/19/using-entity-framework-core-with-wpf-on-net-core-3-0/
 
The database connects and is working properly. However when I try to add migrations by typing in the following command: Add-Migration InitialMigration I keep getting the following error:
Unable to create an object of type 'MyDBContext'. For the different patterns supported at design time, see https://go.microsoft.com/fwlink/?linkid=851728
In web applications this seems to be a common/known issue and is fixable by changing CreateHostBuilder to BuildWebHost in the program class; https://stackoverflow.com/questions/57745481/unable-to-create-an-object-of-type-mycontext-for-the-different-patterns-suppo
I also found some other posts by adding MigrationsAssembly in options.UseSqlServer. 
Long story short, I tried all these solutions but none of them seem to work. Probably because my application is not a web application (no program class e.g. BuildWebHost) but a WPF (Core) application.
My initializing code for the WPF app looks as following:
App.xaml.cs
public partial class App : Application
{
    private readonly IHost host;
    public IServiceProvider ServiceProvider { get; private set; }
    public IConfiguration Configuration { get; private set; }
    public App()
    {
        host = Host.CreateDefaultBuilder()
               .ConfigureServices((context, services) =>
               {
                   ConfigureServices(services);
               }).Build();
    }
    private void ConfigureServices(IServiceCollection services)
    {
        // services for DI...
        services.AddDbContext<MyDbContext>
            (options => 
                options.UseSqlServer(
                        Configuration.GetConnectionString("SqlConnection")));
        services.AddTransient<MainWindow>();
    }
    protected override void OnStartup(StartupEventArgs e)
    {
        var builder = new ConfigurationBuilder()
            .SetBasePath(Directory.GetCurrentDirectory())
            .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);
        Configuration = builder.Build();
        var serviceCollection = new ServiceCollection();
        ConfigureServices(serviceCollection);
        ServiceProvider = serviceCollection.BuildServiceProvider();
        var mainWindow = ServiceProvider.GetRequiredService<MainWindow>();
        mainWindow.Show();
    }
    protected override async void OnExit(ExitEventArgs e)
    {
        using (host)
        {
            await host.StopAsync(TimeSpan.FromSeconds(5));
        }
        base.OnExit(e);
    }
}
MyDbContext.cs
public class MyDbContext : DbContext
{
    public MyDbContext(DbContextOptions<MyDbContext> options) : base(options)
    {
        Database.Migrate(); 
    }
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        // Zonnescherm Model
        modelBuilder.Entity<Zonneschermen>().Property(e => e.BreedteZonnescherm).HasColumnType("decimal(17,2)");
        modelBuilder.Entity<Zonneschermen>().Property(e => e.UitvalDoek).HasColumnType("decimal(17,2)");
        modelBuilder.Entity<Zonneschermen>().Property(e => e.ArmLengte).HasColumnType("decimal(17,2)");
        // ScreenRegels Model
        modelBuilder.Entity<ScreenRegels>().Property(e => e.Breedte).HasColumnType("decimal(17,2)");
        modelBuilder.Entity<ScreenRegels>().Property(e => e.Hoogte).HasColumnType("decimal(17,2)");
        modelBuilder.Entity<ScreenRegels>().Property(e => e.DraaistangLengte).HasColumnType("decimal(17,2)");
        // Seed
        modelBuilder.Entity<Instellingen>().HasData(
            // seeding...
        );
        // Seed 
        modelBuilder.Entity<ZonneschermInstellingen>().HasData(
            // seeding...
        );
        // Seed 
        modelBuilder.Entity<ScreenInstellingen>().HasData(
            // seeding...
        );
    }
    public DbSet<Lamellen> Lamellen { get; set; }
    public DbSet<LamellenRegels> LamellenRegels { get; set; }
    public DbSet<Zonneschermen> Zonneschermen { get; set; }
    public DbSet<ZonneschermInstellingen> ZonneschermInstellingen { get; set; }
    public DbSet<Screens> Screens { get; set; }
    public DbSet<ScreenRegels> ScreenRegels { get; set; }
    public DbSet<ScreenInstellingen> ScreenInstellingen { get; set; }
    public DbSet<Instellingen> Instellingen { get; set; }
}
Any clues where it goes wrong?