// 
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using turf_tasker.Data;
#nullable disable
namespace turf_tasker.Migrations
{
    [DbContext(typeof(ApplicationDbContext))]
    [Migration("20250621230711_AddIdentitySchema")]
    partial class AddIdentitySchema
    {
        /// 
        protected override void BuildTargetModel(ModelBuilder modelBuilder)
        {
#pragma warning disable 612, 618
            modelBuilder.HasAnnotation("ProductVersion", "8.0.6");
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole", b =>
                {
                    b.Property("Id")
                        .HasColumnType("TEXT");
                    b.Property("ConcurrencyStamp")
                        .IsConcurrencyToken()
                        .HasColumnType("TEXT");
                    b.Property("Name")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.Property("NormalizedName")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.HasIndex("NormalizedName")
                        .IsUnique()
                        .HasDatabaseName("RoleNameIndex");
                    b.ToTable("AspNetRoles", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("INTEGER");
                    b.Property("ClaimType")
                        .HasColumnType("TEXT");
                    b.Property("ClaimValue")
                        .HasColumnType("TEXT");
                    b.Property("RoleId")
                        .IsRequired()
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.HasIndex("RoleId");
                    b.ToTable("AspNetRoleClaims", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUser", b =>
                {
                    b.Property("Id")
                        .HasColumnType("TEXT");
                    b.Property("AccessFailedCount")
                        .HasColumnType("INTEGER");
                    b.Property("ConcurrencyStamp")
                        .IsConcurrencyToken()
                        .HasColumnType("TEXT");
                    b.Property("Email")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.Property("EmailConfirmed")
                        .HasColumnType("INTEGER");
                    b.Property("LockoutEnabled")
                        .HasColumnType("INTEGER");
                    b.Property("LockoutEnd")
                        .HasColumnType("TEXT");
                    b.Property("NormalizedEmail")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.Property("NormalizedUserName")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.Property("PasswordHash")
                        .HasColumnType("TEXT");
                    b.Property("PhoneNumber")
                        .HasColumnType("TEXT");
                    b.Property("PhoneNumberConfirmed")
                        .HasColumnType("INTEGER");
                    b.Property("SecurityStamp")
                        .HasColumnType("TEXT");
                    b.Property("TwoFactorEnabled")
                        .HasColumnType("INTEGER");
                    b.Property("UserName")
                        .HasMaxLength(256)
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.HasIndex("NormalizedEmail")
                        .HasDatabaseName("EmailIndex");
                    b.HasIndex("NormalizedUserName")
                        .IsUnique()
                        .HasDatabaseName("UserNameIndex");
                    b.ToTable("AspNetUsers", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("INTEGER");
                    b.Property("ClaimType")
                        .HasColumnType("TEXT");
                    b.Property("ClaimValue")
                        .HasColumnType("TEXT");
                    b.Property("UserId")
                        .IsRequired()
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.HasIndex("UserId");
                    b.ToTable("AspNetUserClaims", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b =>
                {
                    b.Property("LoginProvider")
                        .HasMaxLength(128)
                        .HasColumnType("TEXT");
                    b.Property("ProviderKey")
                        .HasMaxLength(128)
                        .HasColumnType("TEXT");
                    b.Property("ProviderDisplayName")
                        .HasColumnType("TEXT");
                    b.Property("UserId")
                        .IsRequired()
                        .HasColumnType("TEXT");
                    b.HasKey("LoginProvider", "ProviderKey");
                    b.HasIndex("UserId");
                    b.ToTable("AspNetUserLogins", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b =>
                {
                    b.Property("UserId")
                        .HasColumnType("TEXT");
                    b.Property("RoleId")
                        .HasColumnType("TEXT");
                    b.HasKey("UserId", "RoleId");
                    b.HasIndex("RoleId");
                    b.ToTable("AspNetUserRoles", (string)null);
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b =>
                {
                    b.Property("UserId")
                        .HasColumnType("TEXT");
                    b.Property("LoginProvider")
                        .HasMaxLength(128)
                        .HasColumnType("TEXT");
                    b.Property("Name")
                        .HasMaxLength(128)
                        .HasColumnType("TEXT");
                    b.Property("Value")
                        .HasColumnType("TEXT");
                    b.HasKey("UserId", "LoginProvider", "Name");
                    b.ToTable("AspNetUserTokens", (string)null);
                });
            modelBuilder.Entity("turf_tasker.Models.LawnCareEvent", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("INTEGER");
                    b.Property("AppliedAmount")
                        .HasColumnType("TEXT");
                    b.Property("EventDate")
                        .HasColumnType("TEXT");
                    b.Property("EventType")
                        .HasColumnType("INTEGER");
                    b.Property("MowerHeightInches")
                        .HasColumnType("TEXT");
                    b.Property("MowingPattern")
                        .HasColumnType("INTEGER");
                    b.Property("Notes")
                        .HasMaxLength(500)
                        .HasColumnType("TEXT");
                    b.Property("ProblemObserved")
                        .HasMaxLength(250)
                        .HasColumnType("TEXT");
                    b.Property("ProductUsed")
                        .HasMaxLength(200)
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.ToTable("LawnCareEvents");
                });
            modelBuilder.Entity("turf_tasker.Models.LawnCareTip", b =>
                {
                    b.Property("Id")
                        .ValueGeneratedOnAdd()
                        .HasColumnType("INTEGER");
                    b.Property("Category")
                        .HasColumnType("INTEGER");
                    b.Property("Content")
                        .IsRequired()
                        .HasColumnType("TEXT");
                    b.Property("Title")
                        .IsRequired()
                        .HasMaxLength(100)
                        .HasColumnType("TEXT");
                    b.HasKey("Id");
                    b.ToTable("LawnCareTips");
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b =>
                {
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null)
                        .WithMany()
                        .HasForeignKey("RoleId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b =>
                {
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
                        .WithMany()
                        .HasForeignKey("UserId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b =>
                {
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
                        .WithMany()
                        .HasForeignKey("UserId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b =>
                {
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null)
                        .WithMany()
                        .HasForeignKey("RoleId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
                        .WithMany()
                        .HasForeignKey("UserId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                });
            modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b =>
                {
                    b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
                        .WithMany()
                        .HasForeignKey("UserId")
                        .OnDelete(DeleteBehavior.Cascade)
                        .IsRequired();
                });
#pragma warning restore 612, 618
        }
    }
}