// 
using System;
using Elecciones.Database;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace Elecciones.Database.Migrations
{
    [DbContext(typeof(EleccionesDbContext))]
    partial class EleccionesDbContextModelSnapshot : ModelSnapshot
    {
        protected override void BuildModel(ModelBuilder modelBuilder)
        {
#pragma warning disable 612, 618
            modelBuilder
                .HasAnnotation("ProductVersion", "9.0.8")
                .HasAnnotation("Relational:MaxIdentifierLength", 128);
            SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
            modelBuilder.Entity("Elecciones.Database.Entities.AgrupacionPolitica", b =>
                {
                    b.Property("Id")
                        .HasColumnType("nvarchar(450)");
                    b.Property("IdTelegrama")
                        .IsRequired()
                        .HasColumnType("nvarchar(max)");
                    b.Property("Nombre")
                        .IsRequired()
                        .HasColumnType("nvarchar(max)");
                    b.HasKey("Id");
                    b.ToTable("AgrupacionesPoliticas");
                });
            modelBuilder.Entity("Elecciones.Database.Entities.AmbitoGeografico", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("int");
                    SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id"));
                    b.Property("CircuitoId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("DistritoId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("EstablecimientoId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("MesaId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("MunicipioId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("NivelId")
                        .HasColumnType("int");
                    b.Property("Nombre")
                        .IsRequired()
                        .HasColumnType("nvarchar(max)");
                    b.Property("SeccionId")
                        .HasColumnType("nvarchar(max)");
                    b.Property("SeccionProvincialId")
                        .HasColumnType("nvarchar(max)");
                    b.HasKey("Id");
                    b.ToTable("AmbitosGeograficos");
                });
            modelBuilder.Entity("Elecciones.Database.Entities.EstadoRecuento", b =>
                {
                    b.Property("AmbitoGeograficoId")
                        .HasColumnType("int");
                    b.Property("CantidadElectores")
                        .HasColumnType("int");
                    b.Property("CantidadVotantes")
                        .HasColumnType("int");
                    b.Property("FechaTotalizacion")
                        .HasColumnType("datetime2");
                    b.Property("MesasEsperadas")
                        .HasColumnType("int");
                    b.Property("MesasTotalizadas")
                        .HasColumnType("int");
                    b.Property("MesasTotalizadasPorcentaje")
                        .HasPrecision(5, 2)
                        .HasColumnType("decimal(5,2)");
                    b.Property("ParticipacionPorcentaje")
                        .HasPrecision(5, 2)
                        .HasColumnType("decimal(5,2)");
                    b.Property("VotosEnBlanco")
                        .HasColumnType("bigint");
                    b.Property("VotosNulos")
                        .HasColumnType("bigint");
                    b.Property("VotosRecurridos")
                        .HasColumnType("bigint");
                    b.HasKey("AmbitoGeograficoId");
                    b.ToTable("EstadosRecuentos");
                });
            modelBuilder.Entity("Elecciones.Database.Entities.ResultadoVoto", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("bigint");
                    SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id"));
                    b.Property("AgrupacionPoliticaId")
                        .IsRequired()
                        .HasColumnType("nvarchar(450)");
                    b.Property("AmbitoGeograficoId")
                        .HasColumnType("int");
                    b.Property("CantidadVotos")
                        .HasColumnType("bigint");
                    b.HasKey("Id");
                    b.HasIndex("AgrupacionPoliticaId");
                    b.HasIndex("AmbitoGeograficoId", "AgrupacionPoliticaId")
                        .IsUnique();
                    b.ToTable("ResultadosVotos");
                });
            modelBuilder.Entity("Elecciones.Database.Entities.EstadoRecuento", b =>
                {
                    b.HasOne("Elecciones.Database.Entities.AmbitoGeografico", "AmbitoGeografico")
                        .WithMany()
                        .HasForeignKey("AmbitoGeograficoId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                    b.Navigation("AmbitoGeografico");
                });
            modelBuilder.Entity("Elecciones.Database.Entities.ResultadoVoto", b =>
                {
                    b.HasOne("Elecciones.Database.Entities.AgrupacionPolitica", "AgrupacionPolitica")
                        .WithMany()
                        .HasForeignKey("AgrupacionPoliticaId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                    b.HasOne("Elecciones.Database.Entities.AmbitoGeografico", "AmbitoGeografico")
                        .WithMany()
                        .HasForeignKey("AmbitoGeograficoId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                    b.Navigation("AgrupacionPolitica");
                    b.Navigation("AmbitoGeografico");
                });
#pragma warning restore 612, 618
        }
    }
}