using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace API.Data.Migrations
{
    /// 
    public partial class UserBasedCollections : Migration
    {
        /// 
        protected override void Up(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.CreateTable(
                name: "AppUserCollection",
                columns: table => new
                {
                    Id = table.Column(type: "INTEGER", nullable: false)
                        .Annotation("Sqlite:Autoincrement", true),
                    Title = table.Column(type: "TEXT", nullable: true),
                    NormalizedTitle = table.Column(type: "TEXT", nullable: true),
                    Summary = table.Column(type: "TEXT", nullable: true),
                    Promoted = table.Column(type: "INTEGER", nullable: false),
                    CoverImage = table.Column(type: "TEXT", nullable: true),
                    CoverImageLocked = table.Column(type: "INTEGER", nullable: false),
                    AgeRating = table.Column(type: "INTEGER", nullable: false, defaultValue: 0),
                    Created = table.Column(type: "TEXT", nullable: false),
                    LastModified = table.Column(type: "TEXT", nullable: false),
                    CreatedUtc = table.Column(type: "TEXT", nullable: false),
                    LastModifiedUtc = table.Column(type: "TEXT", nullable: false),
                    LastSyncUtc = table.Column(type: "TEXT", nullable: false),
                    Source = table.Column(type: "INTEGER", nullable: false),
                    SourceUrl = table.Column(type: "TEXT", nullable: true),
                    AppUserId = table.Column(type: "INTEGER", nullable: false)
                },
                constraints: table =>
                {
                    table.PrimaryKey("PK_AppUserCollection", x => x.Id);
                    table.ForeignKey(
                        name: "FK_AppUserCollection_AspNetUsers_AppUserId",
                        column: x => x.AppUserId,
                        principalTable: "AspNetUsers",
                        principalColumn: "Id",
                        onDelete: ReferentialAction.Cascade);
                });
            migrationBuilder.CreateTable(
                name: "AppUserCollectionSeries",
                columns: table => new
                {
                    CollectionsId = table.Column(type: "INTEGER", nullable: false),
                    ItemsId = table.Column(type: "INTEGER", nullable: false)
                },
                constraints: table =>
                {
                    table.PrimaryKey("PK_AppUserCollectionSeries", x => new { x.CollectionsId, x.ItemsId });
                    table.ForeignKey(
                        name: "FK_AppUserCollectionSeries_AppUserCollection_CollectionsId",
                        column: x => x.CollectionsId,
                        principalTable: "AppUserCollection",
                        principalColumn: "Id",
                        onDelete: ReferentialAction.Cascade);
                    table.ForeignKey(
                        name: "FK_AppUserCollectionSeries_Series_ItemsId",
                        column: x => x.ItemsId,
                        principalTable: "Series",
                        principalColumn: "Id",
                        onDelete: ReferentialAction.Cascade);
                });
            migrationBuilder.CreateIndex(
                name: "IX_AppUserCollection_AppUserId",
                table: "AppUserCollection",
                column: "AppUserId");
            migrationBuilder.CreateIndex(
                name: "IX_AppUserCollectionSeries_ItemsId",
                table: "AppUserCollectionSeries",
                column: "ItemsId");
        }
        /// 
        protected override void Down(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.DropTable(
                name: "AppUserCollectionSeries");
            migrationBuilder.DropTable(
                name: "AppUserCollection");
        }
    }
}