Add project files.
This commit is contained in:
parent
00d69b9d56
commit
a5071be32b
|
@ -0,0 +1,46 @@
|
||||||
|
using AutoMapper;
|
||||||
|
using Microsoft.AspNetCore.Http;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using PokemonSleepAPI.Data;
|
||||||
|
using PokemonSleepAPI.Models;
|
||||||
|
using PokemonSleepAPI.Models.Dto;
|
||||||
|
using System;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Controllers
|
||||||
|
{
|
||||||
|
[Route("api/pokemon")]
|
||||||
|
[ApiController]
|
||||||
|
public class PokemonController : ControllerBase
|
||||||
|
{
|
||||||
|
private readonly PokemonDbContext _db;
|
||||||
|
private ResponseDto _response;
|
||||||
|
private IMapper _mapper;
|
||||||
|
|
||||||
|
public PokemonController(PokemonDbContext db, IMapper mapper)
|
||||||
|
{
|
||||||
|
_db = db;
|
||||||
|
_mapper = mapper;
|
||||||
|
_response = new ResponseDto();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Get all Pokemon */
|
||||||
|
[HttpGet]
|
||||||
|
public ResponseDto GetAllPokemon()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
IEnumerable<Pokemon> objList = _db.Pokemons.ToList();
|
||||||
|
_response.Message = "Pokemons found.";
|
||||||
|
_response.Result = _mapper.Map<IEnumerable<PokemonDto>>(objList);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_response.IsSuccess = false;
|
||||||
|
_response.Message = ex.Message;
|
||||||
|
}
|
||||||
|
return _response;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
using Azure;
|
||||||
|
using Microsoft.AspNetCore.Http;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using PokemonSleepAPI.Models.Dto;
|
||||||
|
using PokemonSleepAPI.Models;
|
||||||
|
using AutoMapper;
|
||||||
|
using PokemonSleepAPI.Data;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Controllers
|
||||||
|
{
|
||||||
|
[Route("api/nature")]
|
||||||
|
[ApiController]
|
||||||
|
public class PokemonNatureController : ControllerBase
|
||||||
|
{
|
||||||
|
private readonly PokemonDbContext _db;
|
||||||
|
private ResponseDto _response;
|
||||||
|
private IMapper _mapper;
|
||||||
|
|
||||||
|
public PokemonNatureController(PokemonDbContext db, IMapper mapper)
|
||||||
|
{
|
||||||
|
_db = db;
|
||||||
|
_mapper = mapper;
|
||||||
|
_response = new ResponseDto();
|
||||||
|
}
|
||||||
|
/* Get all Pokemon Natures */
|
||||||
|
[HttpGet]
|
||||||
|
public ResponseDto GetAllPokemonNatures()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
IEnumerable<PokemonNature> objList = _db.PokemonNatures.ToList();
|
||||||
|
_response.Message = "Pokemon Natures found.";
|
||||||
|
_response.Result = _mapper.Map<IEnumerable<PokemonNatureDto>>(objList);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_response.IsSuccess = false;
|
||||||
|
_response.Message = ex.Message;
|
||||||
|
}
|
||||||
|
return _response;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
using AutoMapper;
|
||||||
|
using Microsoft.AspNetCore.Http;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using PokemonSleepAPI.Data;
|
||||||
|
using PokemonSleepAPI.Models;
|
||||||
|
using PokemonSleepAPI.Models.Dto;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Controllers
|
||||||
|
{
|
||||||
|
[Route("api/subskill")]
|
||||||
|
[ApiController]
|
||||||
|
public class PokemonSubskillController : ControllerBase
|
||||||
|
{
|
||||||
|
private readonly PokemonDbContext _db;
|
||||||
|
private ResponseDto _response;
|
||||||
|
private IMapper _mapper;
|
||||||
|
|
||||||
|
public PokemonSubskillController(PokemonDbContext db, IMapper mapper)
|
||||||
|
{
|
||||||
|
_db = db;
|
||||||
|
_mapper = mapper;
|
||||||
|
_response = new ResponseDto();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Get all Pokemon Natures */
|
||||||
|
[HttpGet]
|
||||||
|
public ResponseDto GetAllPokemonNatures()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
IEnumerable<PokemonSubskill> objList = _db.PokemonSubskills .ToList();
|
||||||
|
_response.Message = "Pokemon Subskills found.";
|
||||||
|
_response.Result = _mapper.Map<IEnumerable<PokemonSubskillDto>>(objList);
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_response.IsSuccess = false;
|
||||||
|
_response.Message = ex.Message;
|
||||||
|
}
|
||||||
|
return _response;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,24 @@
|
||||||
|
using AutoMapper;
|
||||||
|
using PokemonSleepAPI.Models;
|
||||||
|
using PokemonSleepAPI.Models.Dto;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI
|
||||||
|
{
|
||||||
|
public class MappingConfig
|
||||||
|
{
|
||||||
|
public static MapperConfiguration RegisterMaps()
|
||||||
|
{
|
||||||
|
var mappingConfig = new MapperConfiguration(config =>
|
||||||
|
{
|
||||||
|
config.CreateMap<PokemonDto, Pokemon>();
|
||||||
|
config.CreateMap<Pokemon, PokemonDto>();
|
||||||
|
config.CreateMap<PokemonNatureDto, PokemonNature>();
|
||||||
|
config.CreateMap<PokemonNature, PokemonNatureDto>();
|
||||||
|
config.CreateMap<PokemonSubskillDto, PokemonSubskill>();
|
||||||
|
config.CreateMap<PokemonSubskill, PokemonSubskillDto>();
|
||||||
|
|
||||||
|
});
|
||||||
|
return mappingConfig;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1155
PokemonSleepAPI/Migrations/20241205173702_InitialCreateWithAvailablePokemon.Designer.cs
generated
Normal file
1155
PokemonSleepAPI/Migrations/20241205173702_InitialCreateWithAvailablePokemon.Designer.cs
generated
Normal file
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,202 @@
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
#pragma warning disable CA1814 // Prefer jagged arrays over multidimensional
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class InitialCreateWithAvailablePokemon : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "Pokemons",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
Id = table.Column<int>(type: "int", nullable: false)
|
||||||
|
.Annotation("SqlServer:Identity", "1, 1"),
|
||||||
|
Name = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
SleepType = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
Speciality = table.Column<string>(type: "nvarchar(max)", nullable: false)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_Pokemons", x => x.Id);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.InsertData(
|
||||||
|
table: "Pokemons",
|
||||||
|
columns: new[] { "Id", "Name", "SleepType", "Speciality" },
|
||||||
|
values: new object[,]
|
||||||
|
{
|
||||||
|
{ 1, "Bulbasaur", "Dozing", "Ingredients" },
|
||||||
|
{ 2, "Ivysaur", "Dozing", "Ingredients" },
|
||||||
|
{ 3, "Venasaur", "Dozing", "Ingredients" },
|
||||||
|
{ 4, "Charmander", "Snoozing", "Ingredients" },
|
||||||
|
{ 5, "Charmeleon", "Snoozing", "Ingredients" },
|
||||||
|
{ 6, "Charizard", "Snoozing", "Ingredients" },
|
||||||
|
{ 7, "Squirtle", "Slumbering", "Ingredients" },
|
||||||
|
{ 8, "Wartortle", "Slumbering", "Ingredients" },
|
||||||
|
{ 9, "Blastoise", "Slumbering", "Ingredients" },
|
||||||
|
{ 10, "Caterpie", "Dozing", "Berries" },
|
||||||
|
{ 11, "Metapod", "Dozing", "Berries" },
|
||||||
|
{ 12, "Butterfree", "Dozing", "Berries" },
|
||||||
|
{ 19, "Rattata", "Snoozing", "Berries" },
|
||||||
|
{ 20, "Raticate", "Snoozing", "Berries" },
|
||||||
|
{ 23, "Ekans", "Dozing", "Berries" },
|
||||||
|
{ 24, "Arbok", "Dozing", "Berries" },
|
||||||
|
{ 25, "Pikachu", "Snoozing", "Berries" },
|
||||||
|
{ 26, "Raticate", "Snoozing", "Berries" },
|
||||||
|
{ 35, "Clefairy", "Snoozing", "Berries" },
|
||||||
|
{ 36, "Clefable", "Snoozing", "Berries" },
|
||||||
|
{ 37, "Vulpix", "Snoozing", "Berries" },
|
||||||
|
{ 38, "Ninetails", "Snoozing", "Berries" },
|
||||||
|
{ 39, "Jigglypuff", "Snoozing", "Skills" },
|
||||||
|
{ 40, "Wigglytuff", "Snoozing", "Skills" },
|
||||||
|
{ 50, "Diglett", "Snoozing", "Ingredients" },
|
||||||
|
{ 51, "Dugtrio", "Snoozing", "Ingredients" },
|
||||||
|
{ 52, "Meowth", "Snoozing", "Skills" },
|
||||||
|
{ 53, "Persian", "Snoozing", "Skills" },
|
||||||
|
{ 54, "Psyduck", "Dozing", "Skills" },
|
||||||
|
{ 55, "Golduck", "Slumbering", "Skills" },
|
||||||
|
{ 56, "Mankey", "Dozing", "Berries" },
|
||||||
|
{ 57, "Primeape", "Dozing", "Berries" },
|
||||||
|
{ 58, "Growlithe", "Snoozing", "Skills" },
|
||||||
|
{ 59, "Arcanine", "Snoozing", "Skills" },
|
||||||
|
{ 69, "Bellsprout", "Dozing", "Ingredients" },
|
||||||
|
{ 70, "Weepinbell", "Dozing", "Ingredients" },
|
||||||
|
{ 71, "Victreebel", "Dozing", "Ingredients" },
|
||||||
|
{ 74, "Geodude", "Slumbering", "Ingredients" },
|
||||||
|
{ 75, "Graveler", "Slumbering", "Ingredients" },
|
||||||
|
{ 76, "Golem", "Slumbering", "Ingredients" },
|
||||||
|
{ 79, "Slowpoke", "Snoozing", "Skills" },
|
||||||
|
{ 80, "Slowbro", "Snoozing", "Skills" },
|
||||||
|
{ 81, "Magnemite", "Slumbering", "Skills" },
|
||||||
|
{ 82, "Magneton", "Slumbering", "Skills" },
|
||||||
|
{ 84, "Doduo", "Slumbering", "Berries" },
|
||||||
|
{ 85, "Dodrio", "Slumbering", "Berries" },
|
||||||
|
{ 92, "Gastly", "Dozing", "Ingredients" },
|
||||||
|
{ 93, "Haunter", "Dozing", "Ingredients" },
|
||||||
|
{ 94, "Gengar", "Dozing", "Ingredients" },
|
||||||
|
{ 95, "Onix", "Slumbering", "Berries" },
|
||||||
|
{ 104, "Cubone", "Slumbering", "Berries" },
|
||||||
|
{ 105, "Marowak", "Slumbering", "Berries" },
|
||||||
|
{ 122, "Mr. Mime", "Snoozing", "Ingredients" },
|
||||||
|
{ 127, "Pinsir", "Dozing", "Ingredients" },
|
||||||
|
{ 132, "Ditto", "Snoozing", "Ingredients" },
|
||||||
|
{ 133, "Eevee", "Snoozing", "Skills" },
|
||||||
|
{ 134, "Vaporeon", "Slumbering", "Skills" },
|
||||||
|
{ 135, "Jolteon", "Snoozing", "Skills" },
|
||||||
|
{ 136, "Flareon", "Snoozing", "Skills" },
|
||||||
|
{ 147, "Dratini", "Dozing", "Ingredients" },
|
||||||
|
{ 148, "Dragonair", "Dozing", "Ingredients" },
|
||||||
|
{ 149, "Dragonite", "Dozing", "Ingredients" },
|
||||||
|
{ 152, "Chikorita", "Dozing", "Berries" },
|
||||||
|
{ 153, "Bayleaf", "Dozing", "Berries" },
|
||||||
|
{ 154, "Meganium", "Dozing", "Berries" },
|
||||||
|
{ 155, "Cyndaquil", "Snoozing", "Berries" },
|
||||||
|
{ 156, "Quilava", "Snoozing", "Berries" },
|
||||||
|
{ 157, "Typhlosion", "Snoozing", "Berries" },
|
||||||
|
{ 158, "Totodile", "Slumbering", "Berries" },
|
||||||
|
{ 159, "Croconaw", "Slumbering", "Berries" },
|
||||||
|
{ 160, "Feraligatr", "Slumbering", "Berries" },
|
||||||
|
{ 172, "Pichu", "Slumbering", "Berries" },
|
||||||
|
{ 173, "Cleffa", "Slumbering", "Berries" },
|
||||||
|
{ 174, "Igglybuff", "Slumbering", "Skills" },
|
||||||
|
{ 175, "Togepi", "Slumbering", "Skills" },
|
||||||
|
{ 176, "Togetic", "Snoozing", "Skills" },
|
||||||
|
{ 179, "Mareep", "Snoozing", "Skills" },
|
||||||
|
{ 180, "Flaaffy", "Snoozing", "Skills" },
|
||||||
|
{ 181, "Ampharos", "Snoozing", "Skills" },
|
||||||
|
{ 185, "Sudowoodo", "Slumbering", "Skills" },
|
||||||
|
{ 194, "Wooper", "Slumbering", "Ingredients" },
|
||||||
|
{ 195, "Quagsire", "Slumbering", "Ingredients" },
|
||||||
|
{ 196, "Espeon", "Snoozing", "Skills" },
|
||||||
|
{ 197, "Umbreon", "Dozing", "Skills" },
|
||||||
|
{ 199, "Slowking", "Snoozing", "Skills" },
|
||||||
|
{ 202, "Wobbuffet", "Snoozing", "Skills" },
|
||||||
|
{ 208, "Steelix", "Slumbering", "Berries" },
|
||||||
|
{ 214, "Heracross", "Dozing", "Skills" },
|
||||||
|
{ 215, "Sneasel", "Dozing", "Berries" },
|
||||||
|
{ 225, "Delibird", "Dozing", "Ingredients" },
|
||||||
|
{ 228, "Houndour", "Dozing", "Berries" },
|
||||||
|
{ 229, "Houndoom", "Dozing", "Berries" },
|
||||||
|
{ 243, "Raikou", "Snoozing", "Skills" },
|
||||||
|
{ 244, "Entei", "Snoozing", "Skills" },
|
||||||
|
{ 245, "Suicune", "Slumbering", "Skills" },
|
||||||
|
{ 246, "Larvitar", "Slumbering", "Ingredients" },
|
||||||
|
{ 247, "Pupitar", "Slumbering", "Ingredients" },
|
||||||
|
{ 248, "Tyranitar", "Dozing", "Ingredients" },
|
||||||
|
{ 280, "Ralts", "Snoozing", "Skills" },
|
||||||
|
{ 281, "Kirlia", "Snoozing", "Skills" },
|
||||||
|
{ 282, "Gardevoir", "Snoozing", "Skills" },
|
||||||
|
{ 287, "Slakoth", "Snoozing", "Berries" },
|
||||||
|
{ 288, "Vigoroth", "Dozing", "Berries" },
|
||||||
|
{ 289, "Slaking", "Snoozing", "Berries" },
|
||||||
|
{ 302, "Sableye", "Dozing", "Skills" },
|
||||||
|
{ 304, "Aron", "Slumbering", "Ingredients" },
|
||||||
|
{ 305, "Lairon", "Slumbering", "Ingredients" },
|
||||||
|
{ 306, "Aggron", "Slumbering", "Ingredients" },
|
||||||
|
{ 316, "Gulpin", "Dozing", "Skills" },
|
||||||
|
{ 317, "Swalot", "Dozing", "Skills" },
|
||||||
|
{ 333, "Swablu", "Slumbering", "Berries" },
|
||||||
|
{ 334, "Altaria", "Dozing", "Berries" },
|
||||||
|
{ 353, "Shuppet", "Dozing", "Berries" },
|
||||||
|
{ 354, "Banette", "Dozing", "Berries" },
|
||||||
|
{ 359, "Absol", "Dozing", "Ingredients" },
|
||||||
|
{ 360, "Wynaut", "Slumbering", "Skills" },
|
||||||
|
{ 363, "Spheal", "Slumbering", "Berries" },
|
||||||
|
{ 364, "Sealeo", "Slumbering", "Berries" },
|
||||||
|
{ 365, "Walrein", "Slumbering", "Berries" },
|
||||||
|
{ 403, "Shinx", "Snoozing", "Ingredients" },
|
||||||
|
{ 404, "Luxio", "Snoozing", "Ingredients" },
|
||||||
|
{ 405, "Luxray", "Snoozing", "Ingredients" },
|
||||||
|
{ 425, "Drifloon", "Dozing", "Skills" },
|
||||||
|
{ 426, "Drifblim", "Dozing", "Skills" },
|
||||||
|
{ 438, "Bonsly", "Slumbering", "Skills" },
|
||||||
|
{ 439, "Mime Jr.", "Slumbering", "Ingredients" },
|
||||||
|
{ 447, "Riolu", "Slumbering", "Skills" },
|
||||||
|
{ 448, "Lucario", "Slumbering", "Skills" },
|
||||||
|
{ 453, "Croagunk", "Dozing", "Ingredients" },
|
||||||
|
{ 454, "Toxicroak", "Dozing", "Ingredients" },
|
||||||
|
{ 459, "Snover", "Slumbering", "Ingredients" },
|
||||||
|
{ 460, "Abomasnow", "Slumbering", "Ingredients" },
|
||||||
|
{ 461, "Weavile", "Dozing", "Berries" },
|
||||||
|
{ 462, "Magnezone", "Slumbering", "Skills" },
|
||||||
|
{ 468, "Togekiss", "Snoozing", "Skills" },
|
||||||
|
{ 470, "Leafeon", "Dozing", "Skills" },
|
||||||
|
{ 471, "Glaceon", "Slumbering", "Skills" },
|
||||||
|
{ 475, "Gallade", "Slumbering", "Skills" },
|
||||||
|
{ 700, "Sylveon", "Snoozing", "Skills" },
|
||||||
|
{ 702, "Dedenne", "Snoozing", "Skills" },
|
||||||
|
{ 736, "Grubbin", "Dozing", "Ingredients" },
|
||||||
|
{ 737, "Charjabug", "Dozing", "Ingredients" },
|
||||||
|
{ 738, "Vikavolt", "Dozing", "Ingredients" },
|
||||||
|
{ 759, "Stufful", "Slumbering", "Ingredients" },
|
||||||
|
{ 760, "Bewear", "Slumbering", "Ingredients" },
|
||||||
|
{ 764, "Comfey", "Snoozing", "Ingredients" },
|
||||||
|
{ 778, "Mimikyu", "Dozing", "Skills" },
|
||||||
|
{ 845, "Cramorant", "Slumbering", "Ingredients" },
|
||||||
|
{ 906, "Sprigatito", "Dozing", "Ingredients" },
|
||||||
|
{ 907, "Floragato", "Dozing", "Ingredients" },
|
||||||
|
{ 908, "Meowscarada", "Dozing", "Ingredients" },
|
||||||
|
{ 909, "Fuecoco", "Snoozing", "Ingredients" },
|
||||||
|
{ 910, "Crocalor", "Snoozing", "Ingredients" },
|
||||||
|
{ 911, "Skeledirge", "Snoozing", "Ingredients" },
|
||||||
|
{ 912, "Quaxly", "Slumbering", "Ingredients" },
|
||||||
|
{ 913, "Quaxwell", "Slumbering", "Ingredients" },
|
||||||
|
{ 914, "Quaquaval", "Slumbering", "Ingredients" }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "Pokemons");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
257
PokemonSleepAPI/Migrations/20241205180806_AddNaturesWithRatings.Designer.cs
generated
Normal file
257
PokemonSleepAPI/Migrations/20241205180806_AddNaturesWithRatings.Designer.cs
generated
Normal file
|
@ -0,0 +1,257 @@
|
||||||
|
// <auto-generated />
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||||
|
using Microsoft.EntityFrameworkCore.Metadata;
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
||||||
|
using PokemonSleepAPI.Data;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
[DbContext(typeof(PokemonDbContext))]
|
||||||
|
[Migration("20241205180806_AddNaturesWithRatings")]
|
||||||
|
partial class AddNaturesWithRatings
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
||||||
|
{
|
||||||
|
#pragma warning disable 612, 618
|
||||||
|
modelBuilder
|
||||||
|
.HasAnnotation("ProductVersion", "9.0.0")
|
||||||
|
.HasAnnotation("Relational:MaxIdentifierLength", 128);
|
||||||
|
|
||||||
|
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
|
||||||
|
|
||||||
|
modelBuilder.Entity("PokemonSleepAPI.Models.PokemonNature", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("int");
|
||||||
|
|
||||||
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("BerryRating")
|
||||||
|
.HasColumnType("int");
|
||||||
|
|
||||||
|
b.Property<int>("IngredientRating")
|
||||||
|
.HasColumnType("int");
|
||||||
|
|
||||||
|
b.Property<string>("Nature")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("nvarchar(max)");
|
||||||
|
|
||||||
|
b.Property<int>("SkillRating")
|
||||||
|
.HasColumnType("int");
|
||||||
|
|
||||||
|
b.HasKey("Id");
|
||||||
|
|
||||||
|
b.ToTable("PokemonNatures");
|
||||||
|
|
||||||
|
b.HasData(
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 1,
|
||||||
|
BerryRating = 2,
|
||||||
|
IngredientRating = 2,
|
||||||
|
Nature = "Lonely",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 2,
|
||||||
|
BerryRating = 3,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Adamant",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 3,
|
||||||
|
BerryRating = 1,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Naughty",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 4,
|
||||||
|
BerryRating = 1,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Brave",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 5,
|
||||||
|
BerryRating = -2,
|
||||||
|
IngredientRating = -2,
|
||||||
|
Nature = "Bold",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 6,
|
||||||
|
BerryRating = 1,
|
||||||
|
IngredientRating = -2,
|
||||||
|
Nature = "Impish",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 7,
|
||||||
|
BerryRating = -1,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Lax",
|
||||||
|
SkillRating = -2
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 8,
|
||||||
|
BerryRating = -1,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Relaxed",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 9,
|
||||||
|
BerryRating = -3,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Modest",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 10,
|
||||||
|
BerryRating = -1,
|
||||||
|
IngredientRating = 2,
|
||||||
|
Nature = "Mild",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 11,
|
||||||
|
BerryRating = -2,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Rash",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 12,
|
||||||
|
BerryRating = -2,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Quiet",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 13,
|
||||||
|
BerryRating = -1,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Calm",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 14,
|
||||||
|
BerryRating = 1,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Gentle",
|
||||||
|
SkillRating = 2
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 15,
|
||||||
|
BerryRating = 2,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Careful",
|
||||||
|
SkillRating = 1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 16,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Sassy",
|
||||||
|
SkillRating = 2
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 17,
|
||||||
|
BerryRating = -1,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Timid",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 18,
|
||||||
|
BerryRating = 1,
|
||||||
|
IngredientRating = 1,
|
||||||
|
Nature = "Hasty",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 19,
|
||||||
|
BerryRating = 2,
|
||||||
|
IngredientRating = -1,
|
||||||
|
Nature = "Jolly",
|
||||||
|
SkillRating = -1
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 20,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Naive",
|
||||||
|
SkillRating = -2
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 21,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Bashful",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 22,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Hardy",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 23,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Docile",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 24,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Quirky",
|
||||||
|
SkillRating = 0
|
||||||
|
},
|
||||||
|
new
|
||||||
|
{
|
||||||
|
Id = 25,
|
||||||
|
BerryRating = 0,
|
||||||
|
IngredientRating = 0,
|
||||||
|
Nature = "Serious",
|
||||||
|
SkillRating = 0
|
||||||
|
});
|
||||||
|
});
|
||||||
|
#pragma warning restore 612, 618
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,73 @@
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
#pragma warning disable CA1814 // Prefer jagged arrays over multidimensional
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class AddNaturesWithRatings : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "PokemonNatures",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
Id = table.Column<int>(type: "int", nullable: false)
|
||||||
|
.Annotation("SqlServer:Identity", "1, 1"),
|
||||||
|
Nature = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
BerryRating = table.Column<int>(type: "int", nullable: false),
|
||||||
|
IngredientRating = table.Column<int>(type: "int", nullable: false),
|
||||||
|
SkillRating = table.Column<int>(type: "int", nullable: false)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_PokemonNatures", x => x.Id);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.InsertData(
|
||||||
|
table: "PokemonNatures",
|
||||||
|
columns: new[] { "Id", "BerryRating", "IngredientRating", "Nature", "SkillRating" },
|
||||||
|
values: new object[,]
|
||||||
|
{
|
||||||
|
{ 1, 2, 2, "Lonely", 1 },
|
||||||
|
{ 2, 3, 0, "Adamant", 0 },
|
||||||
|
{ 3, 1, 1, "Naughty", -1 },
|
||||||
|
{ 4, 1, 1, "Brave", 1 },
|
||||||
|
{ 5, -2, -2, "Bold", -1 },
|
||||||
|
{ 6, 1, -2, "Impish", -1 },
|
||||||
|
{ 7, -1, -1, "Lax", -2 },
|
||||||
|
{ 8, -1, -1, "Relaxed", 0 },
|
||||||
|
{ 9, -3, 0, "Modest", 0 },
|
||||||
|
{ 10, -1, 2, "Mild", 1 },
|
||||||
|
{ 11, -2, 1, "Rash", -1 },
|
||||||
|
{ 12, -2, 1, "Quiet", 1 },
|
||||||
|
{ 13, -1, -1, "Calm", 1 },
|
||||||
|
{ 14, 1, 1, "Gentle", 2 },
|
||||||
|
{ 15, 2, -1, "Careful", 1 },
|
||||||
|
{ 16, 0, 0, "Sassy", 2 },
|
||||||
|
{ 17, -1, -1, "Timid", -1 },
|
||||||
|
{ 18, 1, 1, "Hasty", 0 },
|
||||||
|
{ 19, 2, -1, "Jolly", -1 },
|
||||||
|
{ 20, 0, 0, "Naive", -2 },
|
||||||
|
{ 21, 0, 0, "Bashful", 0 },
|
||||||
|
{ 22, 0, 0, "Hardy", 0 },
|
||||||
|
{ 23, 0, 0, "Docile", 0 },
|
||||||
|
{ 24, 0, 0, "Quirky", 0 },
|
||||||
|
{ 25, 0, 0, "Serious", 0 }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "PokemonNatures");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1376
PokemonSleepAPI/Migrations/20241205181216_AddPokemonAndNatures.Designer.cs
generated
Normal file
1376
PokemonSleepAPI/Migrations/20241205181216_AddPokemonAndNatures.Designer.cs
generated
Normal file
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,201 @@
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
#pragma warning disable CA1814 // Prefer jagged arrays over multidimensional
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class AddPokemonAndNatures : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "Pokemons",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
Id = table.Column<int>(type: "int", nullable: false)
|
||||||
|
.Annotation("SqlServer:Identity", "1, 1"),
|
||||||
|
Name = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
SleepType = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
Speciality = table.Column<string>(type: "nvarchar(max)", nullable: false)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_Pokemons", x => x.Id);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.InsertData(
|
||||||
|
table: "Pokemons",
|
||||||
|
columns: new[] { "Id", "Name", "SleepType", "Speciality" },
|
||||||
|
values: new object[,]
|
||||||
|
{
|
||||||
|
{ 2, "Ivysaur", "Dozing", "Ingredients" },
|
||||||
|
{ 3, "Venasaur", "Dozing", "Ingredients" },
|
||||||
|
{ 4, "Charmander", "Snoozing", "Ingredients" },
|
||||||
|
{ 5, "Charmeleon", "Snoozing", "Ingredients" },
|
||||||
|
{ 6, "Charizard", "Snoozing", "Ingredients" },
|
||||||
|
{ 7, "Squirtle", "Slumbering", "Ingredients" },
|
||||||
|
{ 8, "Wartortle", "Slumbering", "Ingredients" },
|
||||||
|
{ 9, "Blastoise", "Slumbering", "Ingredients" },
|
||||||
|
{ 10, "Caterpie", "Dozing", "Berries" },
|
||||||
|
{ 11, "Metapod", "Dozing", "Berries" },
|
||||||
|
{ 12, "Butterfree", "Dozing", "Berries" },
|
||||||
|
{ 19, "Rattata", "Snoozing", "Berries" },
|
||||||
|
{ 20, "Raticate", "Snoozing", "Berries" },
|
||||||
|
{ 23, "Ekans", "Dozing", "Berries" },
|
||||||
|
{ 24, "Arbok", "Dozing", "Berries" },
|
||||||
|
{ 25, "Pikachu", "Snoozing", "Berries" },
|
||||||
|
{ 26, "Raticate", "Snoozing", "Berries" },
|
||||||
|
{ 35, "Clefairy", "Snoozing", "Berries" },
|
||||||
|
{ 36, "Clefable", "Snoozing", "Berries" },
|
||||||
|
{ 37, "Vulpix", "Snoozing", "Berries" },
|
||||||
|
{ 38, "Ninetails", "Snoozing", "Berries" },
|
||||||
|
{ 39, "Jigglypuff", "Snoozing", "Skills" },
|
||||||
|
{ 40, "Wigglytuff", "Snoozing", "Skills" },
|
||||||
|
{ 50, "Diglett", "Snoozing", "Ingredients" },
|
||||||
|
{ 51, "Dugtrio", "Snoozing", "Ingredients" },
|
||||||
|
{ 52, "Meowth", "Snoozing", "Skills" },
|
||||||
|
{ 53, "Persian", "Snoozing", "Skills" },
|
||||||
|
{ 54, "Psyduck", "Dozing", "Skills" },
|
||||||
|
{ 55, "Golduck", "Slumbering", "Skills" },
|
||||||
|
{ 56, "Mankey", "Dozing", "Berries" },
|
||||||
|
{ 57, "Primeape", "Dozing", "Berries" },
|
||||||
|
{ 58, "Growlithe", "Snoozing", "Skills" },
|
||||||
|
{ 59, "Arcanine", "Snoozing", "Skills" },
|
||||||
|
{ 69, "Bellsprout", "Dozing", "Ingredients" },
|
||||||
|
{ 70, "Weepinbell", "Dozing", "Ingredients" },
|
||||||
|
{ 71, "Victreebel", "Dozing", "Ingredients" },
|
||||||
|
{ 74, "Geodude", "Slumbering", "Ingredients" },
|
||||||
|
{ 75, "Graveler", "Slumbering", "Ingredients" },
|
||||||
|
{ 76, "Golem", "Slumbering", "Ingredients" },
|
||||||
|
{ 79, "Slowpoke", "Snoozing", "Skills" },
|
||||||
|
{ 80, "Slowbro", "Snoozing", "Skills" },
|
||||||
|
{ 81, "Magnemite", "Slumbering", "Skills" },
|
||||||
|
{ 82, "Magneton", "Slumbering", "Skills" },
|
||||||
|
{ 84, "Doduo", "Slumbering", "Berries" },
|
||||||
|
{ 85, "Dodrio", "Slumbering", "Berries" },
|
||||||
|
{ 92, "Gastly", "Dozing", "Ingredients" },
|
||||||
|
{ 93, "Haunter", "Dozing", "Ingredients" },
|
||||||
|
{ 94, "Gengar", "Dozing", "Ingredients" },
|
||||||
|
{ 95, "Onix", "Slumbering", "Berries" },
|
||||||
|
{ 104, "Cubone", "Slumbering", "Berries" },
|
||||||
|
{ 105, "Marowak", "Slumbering", "Berries" },
|
||||||
|
{ 122, "Mr. Mime", "Snoozing", "Ingredients" },
|
||||||
|
{ 127, "Pinsir", "Dozing", "Ingredients" },
|
||||||
|
{ 132, "Ditto", "Snoozing", "Ingredients" },
|
||||||
|
{ 133, "Eevee", "Snoozing", "Skills" },
|
||||||
|
{ 134, "Vaporeon", "Slumbering", "Skills" },
|
||||||
|
{ 135, "Jolteon", "Snoozing", "Skills" },
|
||||||
|
{ 136, "Flareon", "Snoozing", "Skills" },
|
||||||
|
{ 147, "Dratini", "Dozing", "Ingredients" },
|
||||||
|
{ 148, "Dragonair", "Dozing", "Ingredients" },
|
||||||
|
{ 149, "Dragonite", "Dozing", "Ingredients" },
|
||||||
|
{ 152, "Chikorita", "Dozing", "Berries" },
|
||||||
|
{ 153, "Bayleaf", "Dozing", "Berries" },
|
||||||
|
{ 154, "Meganium", "Dozing", "Berries" },
|
||||||
|
{ 155, "Cyndaquil", "Snoozing", "Berries" },
|
||||||
|
{ 156, "Quilava", "Snoozing", "Berries" },
|
||||||
|
{ 157, "Typhlosion", "Snoozing", "Berries" },
|
||||||
|
{ 158, "Totodile", "Slumbering", "Berries" },
|
||||||
|
{ 159, "Croconaw", "Slumbering", "Berries" },
|
||||||
|
{ 160, "Feraligatr", "Slumbering", "Berries" },
|
||||||
|
{ 172, "Pichu", "Slumbering", "Berries" },
|
||||||
|
{ 173, "Cleffa", "Slumbering", "Berries" },
|
||||||
|
{ 174, "Igglybuff", "Slumbering", "Skills" },
|
||||||
|
{ 175, "Togepi", "Slumbering", "Skills" },
|
||||||
|
{ 176, "Togetic", "Snoozing", "Skills" },
|
||||||
|
{ 179, "Mareep", "Snoozing", "Skills" },
|
||||||
|
{ 180, "Flaaffy", "Snoozing", "Skills" },
|
||||||
|
{ 181, "Ampharos", "Snoozing", "Skills" },
|
||||||
|
{ 185, "Sudowoodo", "Slumbering", "Skills" },
|
||||||
|
{ 194, "Wooper", "Slumbering", "Ingredients" },
|
||||||
|
{ 195, "Quagsire", "Slumbering", "Ingredients" },
|
||||||
|
{ 196, "Espeon", "Snoozing", "Skills" },
|
||||||
|
{ 197, "Umbreon", "Dozing", "Skills" },
|
||||||
|
{ 199, "Slowking", "Snoozing", "Skills" },
|
||||||
|
{ 202, "Wobbuffet", "Snoozing", "Skills" },
|
||||||
|
{ 208, "Steelix", "Slumbering", "Berries" },
|
||||||
|
{ 214, "Heracross", "Dozing", "Skills" },
|
||||||
|
{ 215, "Sneasel", "Dozing", "Berries" },
|
||||||
|
{ 225, "Delibird", "Dozing", "Ingredients" },
|
||||||
|
{ 228, "Houndour", "Dozing", "Berries" },
|
||||||
|
{ 229, "Houndoom", "Dozing", "Berries" },
|
||||||
|
{ 243, "Raikou", "Snoozing", "Skills" },
|
||||||
|
{ 244, "Entei", "Snoozing", "Skills" },
|
||||||
|
{ 245, "Suicune", "Slumbering", "Skills" },
|
||||||
|
{ 246, "Larvitar", "Slumbering", "Ingredients" },
|
||||||
|
{ 247, "Pupitar", "Slumbering", "Ingredients" },
|
||||||
|
{ 248, "Tyranitar", "Dozing", "Ingredients" },
|
||||||
|
{ 280, "Ralts", "Snoozing", "Skills" },
|
||||||
|
{ 281, "Kirlia", "Snoozing", "Skills" },
|
||||||
|
{ 282, "Gardevoir", "Snoozing", "Skills" },
|
||||||
|
{ 287, "Slakoth", "Snoozing", "Berries" },
|
||||||
|
{ 288, "Vigoroth", "Dozing", "Berries" },
|
||||||
|
{ 289, "Slaking", "Snoozing", "Berries" },
|
||||||
|
{ 302, "Sableye", "Dozing", "Skills" },
|
||||||
|
{ 304, "Aron", "Slumbering", "Ingredients" },
|
||||||
|
{ 305, "Lairon", "Slumbering", "Ingredients" },
|
||||||
|
{ 306, "Aggron", "Slumbering", "Ingredients" },
|
||||||
|
{ 316, "Gulpin", "Dozing", "Skills" },
|
||||||
|
{ 317, "Swalot", "Dozing", "Skills" },
|
||||||
|
{ 333, "Swablu", "Slumbering", "Berries" },
|
||||||
|
{ 334, "Altaria", "Dozing", "Berries" },
|
||||||
|
{ 353, "Shuppet", "Dozing", "Berries" },
|
||||||
|
{ 354, "Banette", "Dozing", "Berries" },
|
||||||
|
{ 359, "Absol", "Dozing", "Ingredients" },
|
||||||
|
{ 360, "Wynaut", "Slumbering", "Skills" },
|
||||||
|
{ 363, "Spheal", "Slumbering", "Berries" },
|
||||||
|
{ 364, "Sealeo", "Slumbering", "Berries" },
|
||||||
|
{ 365, "Walrein", "Slumbering", "Berries" },
|
||||||
|
{ 403, "Shinx", "Snoozing", "Ingredients" },
|
||||||
|
{ 404, "Luxio", "Snoozing", "Ingredients" },
|
||||||
|
{ 405, "Luxray", "Snoozing", "Ingredients" },
|
||||||
|
{ 425, "Drifloon", "Dozing", "Skills" },
|
||||||
|
{ 426, "Drifblim", "Dozing", "Skills" },
|
||||||
|
{ 438, "Bonsly", "Slumbering", "Skills" },
|
||||||
|
{ 439, "Mime Jr.", "Slumbering", "Ingredients" },
|
||||||
|
{ 447, "Riolu", "Slumbering", "Skills" },
|
||||||
|
{ 448, "Lucario", "Slumbering", "Skills" },
|
||||||
|
{ 453, "Croagunk", "Dozing", "Ingredients" },
|
||||||
|
{ 454, "Toxicroak", "Dozing", "Ingredients" },
|
||||||
|
{ 459, "Snover", "Slumbering", "Ingredients" },
|
||||||
|
{ 460, "Abomasnow", "Slumbering", "Ingredients" },
|
||||||
|
{ 461, "Weavile", "Dozing", "Berries" },
|
||||||
|
{ 462, "Magnezone", "Slumbering", "Skills" },
|
||||||
|
{ 468, "Togekiss", "Snoozing", "Skills" },
|
||||||
|
{ 470, "Leafeon", "Dozing", "Skills" },
|
||||||
|
{ 471, "Glaceon", "Slumbering", "Skills" },
|
||||||
|
{ 475, "Gallade", "Slumbering", "Skills" },
|
||||||
|
{ 700, "Sylveon", "Snoozing", "Skills" },
|
||||||
|
{ 702, "Dedenne", "Snoozing", "Skills" },
|
||||||
|
{ 736, "Grubbin", "Dozing", "Ingredients" },
|
||||||
|
{ 737, "Charjabug", "Dozing", "Ingredients" },
|
||||||
|
{ 738, "Vikavolt", "Dozing", "Ingredients" },
|
||||||
|
{ 759, "Stufful", "Slumbering", "Ingredients" },
|
||||||
|
{ 760, "Bewear", "Slumbering", "Ingredients" },
|
||||||
|
{ 764, "Comfey", "Snoozing", "Ingredients" },
|
||||||
|
{ 778, "Mimikyu", "Dozing", "Skills" },
|
||||||
|
{ 845, "Cramorant", "Slumbering", "Ingredients" },
|
||||||
|
{ 906, "Sprigatito", "Dozing", "Ingredients" },
|
||||||
|
{ 907, "Floragato", "Dozing", "Ingredients" },
|
||||||
|
{ 908, "Meowscarada", "Dozing", "Ingredients" },
|
||||||
|
{ 909, "Fuecoco", "Snoozing", "Ingredients" },
|
||||||
|
{ 910, "Crocalor", "Snoozing", "Ingredients" },
|
||||||
|
{ 911, "Skeledirge", "Snoozing", "Ingredients" },
|
||||||
|
{ 912, "Quaxly", "Slumbering", "Ingredients" },
|
||||||
|
{ 913, "Quaxwell", "Slumbering", "Ingredients" },
|
||||||
|
{ 914, "Quaquaval", "Slumbering", "Ingredients" }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "Pokemons");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1540
PokemonSleepAPI/Migrations/20241205185409_AddPokemonSubskillsWithRankings.Designer.cs
generated
Normal file
1540
PokemonSleepAPI/Migrations/20241205185409_AddPokemonSubskillsWithRankings.Designer.cs
generated
Normal file
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,63 @@
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
#pragma warning disable CA1814 // Prefer jagged arrays over multidimensional
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class AddPokemonSubskillsWithRankings : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "PokemonSubskills",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
Id = table.Column<int>(type: "int", nullable: false)
|
||||||
|
.Annotation("SqlServer:Identity", "1, 1"),
|
||||||
|
SubSkill = table.Column<string>(type: "nvarchar(max)", nullable: false),
|
||||||
|
BerryRank = table.Column<int>(type: "int", nullable: false),
|
||||||
|
IngredientRank = table.Column<int>(type: "int", nullable: false),
|
||||||
|
SkillRank = table.Column<int>(type: "int", nullable: false)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_PokemonSubskills", x => x.Id);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.InsertData(
|
||||||
|
table: "PokemonSubskills",
|
||||||
|
columns: new[] { "Id", "BerryRank", "IngredientRank", "SkillRank", "SubSkill" },
|
||||||
|
values: new object[,]
|
||||||
|
{
|
||||||
|
{ 1, 2, 1, 2, "Berry Finding S" },
|
||||||
|
{ 2, 0, 0, 0, "Helping Speed S" },
|
||||||
|
{ 3, 1, 1, 1, "Helping Speed M" },
|
||||||
|
{ 4, -2, 1, 0, "Ingredient Finder S" },
|
||||||
|
{ 5, -2, 2, 1, "Ingredient Finder M" },
|
||||||
|
{ 6, -1, 0, -1, "Inventory Up S" },
|
||||||
|
{ 7, 0, 1, 0, "Inventory Up M" },
|
||||||
|
{ 8, 1, 2, 1, "Inventory Up L" },
|
||||||
|
{ 9, 0, 0, 1, "Skill Level Up S" },
|
||||||
|
{ 10, 1, 1, 2, "Skill Level Up M" },
|
||||||
|
{ 11, 0, 0, 1, "Skill Trigger S" },
|
||||||
|
{ 12, 1, 1, 2, "Skill Trigger M" },
|
||||||
|
{ 13, -1, -1, -1, "Dream Shard Bonus" },
|
||||||
|
{ 14, 0, 0, 0, "Energy Recovery Bonus" },
|
||||||
|
{ 15, 2, 2, 2, "Helping Bonus" },
|
||||||
|
{ 16, -1, -1, -1, "Research EXP Bonus" },
|
||||||
|
{ 17, 0, 0, 0, "Sleep EXP Bonus" }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "PokemonSubskills");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1547
PokemonSleepAPI/Migrations/20241205190754_AddBulbasaurBackOoops.Designer.cs
generated
Normal file
1547
PokemonSleepAPI/Migrations/20241205190754_AddBulbasaurBackOoops.Designer.cs
generated
Normal file
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,28 @@
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Migrations
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
public partial class AddBulbasaurBackOoops : Migration
|
||||||
|
{
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.InsertData(
|
||||||
|
table: "Pokemons",
|
||||||
|
columns: new[] { "Id", "Name", "SleepType", "Speciality" },
|
||||||
|
values: new object[] { 1, "Bulbasaur", "Dozing", "Ingredients" });
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc />
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DeleteData(
|
||||||
|
table: "Pokemons",
|
||||||
|
keyColumn: "Id",
|
||||||
|
keyValue: 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,10 @@
|
||||||
|
namespace PokemonSleepAPI.Models.Dto
|
||||||
|
{
|
||||||
|
public class PokemonDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string Name { get; set; }
|
||||||
|
public string SleepType { get; set; }
|
||||||
|
public string Speciality { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
namespace PokemonSleepAPI.Models.Dto
|
||||||
|
{
|
||||||
|
public class PokemonNatureDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string Nature { get; set; }
|
||||||
|
public int BerryRating { get; set; }
|
||||||
|
public int IngredientRating { get; set; }
|
||||||
|
public int SkillRating { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
namespace PokemonSleepAPI.Models.Dto
|
||||||
|
{
|
||||||
|
public class PokemonSubskillDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string SubSkill { get; set; }
|
||||||
|
public int BerryRank { get; set; }
|
||||||
|
public int IngredientRank { get; set; }
|
||||||
|
public int SkillRank { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
namespace PokemonSleepAPI.Models.Dto
|
||||||
|
{
|
||||||
|
public class ResponseDto
|
||||||
|
{
|
||||||
|
public object? Result { get; set; }
|
||||||
|
public bool IsSuccess { get; set; } = true;
|
||||||
|
public string Message { get; set; } = "";
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Models
|
||||||
|
{
|
||||||
|
public class Pokemon
|
||||||
|
{
|
||||||
|
[Key]
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string Name { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string SleepType { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string Speciality { get; set; }
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Models
|
||||||
|
{
|
||||||
|
public class PokemonNature
|
||||||
|
{
|
||||||
|
[Key]
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string Nature { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int BerryRating { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int IngredientRating { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int SkillRating { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,18 @@
|
||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace PokemonSleepAPI.Models
|
||||||
|
{
|
||||||
|
public class PokemonSubskill
|
||||||
|
{
|
||||||
|
[Key]
|
||||||
|
public int Id { get; set; }
|
||||||
|
[Required]
|
||||||
|
public string SubSkill { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int BerryRank { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int IngredientRank { get; set; }
|
||||||
|
[Required]
|
||||||
|
public int SkillRank { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net8.0</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="AutoMapper" Version="13.0.1" />
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="9.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="9.0.0">
|
||||||
|
<PrivateAssets>all</PrivateAssets>
|
||||||
|
<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
|
||||||
|
</PackageReference>
|
||||||
|
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.6.2" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
|
@ -0,0 +1,6 @@
|
||||||
|
@PokemonSleepAPI_HostAddress = http://localhost:5267
|
||||||
|
|
||||||
|
GET {{PokemonSleepAPI_HostAddress}}/weatherforecast/
|
||||||
|
Accept: application/json
|
||||||
|
|
||||||
|
###
|
|
@ -0,0 +1,41 @@
|
||||||
|
using AutoMapper;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using PokemonSleepAPI;
|
||||||
|
using PokemonSleepAPI.Data;
|
||||||
|
|
||||||
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
|
// Add services to the container.
|
||||||
|
|
||||||
|
builder.Services.AddControllers();
|
||||||
|
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
|
||||||
|
builder.Services.AddEndpointsApiExplorer();
|
||||||
|
builder.Services.AddSwaggerGen();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
builder.Services.AddDbContext<PokemonDbContext>(options =>
|
||||||
|
options.UseSqlServer(builder.Configuration.GetConnectionString("DefaultConnection")));
|
||||||
|
|
||||||
|
IMapper mapper = MappingConfig.RegisterMaps().CreateMapper();
|
||||||
|
builder.Services.AddSingleton(mapper);
|
||||||
|
builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies());
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var app = builder.Build();
|
||||||
|
|
||||||
|
// Configure the HTTP request pipeline.
|
||||||
|
if (app.Environment.IsDevelopment())
|
||||||
|
{
|
||||||
|
app.UseSwagger();
|
||||||
|
app.UseSwaggerUI();
|
||||||
|
}
|
||||||
|
|
||||||
|
app.UseHttpsRedirection();
|
||||||
|
|
||||||
|
app.UseAuthorization();
|
||||||
|
|
||||||
|
app.MapControllers();
|
||||||
|
|
||||||
|
app.Run();
|
|
@ -0,0 +1,41 @@
|
||||||
|
{
|
||||||
|
"$schema": "http://json.schemastore.org/launchsettings.json",
|
||||||
|
"iisSettings": {
|
||||||
|
"windowsAuthentication": false,
|
||||||
|
"anonymousAuthentication": true,
|
||||||
|
"iisExpress": {
|
||||||
|
"applicationUrl": "http://localhost:38221",
|
||||||
|
"sslPort": 44346
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"profiles": {
|
||||||
|
"http": {
|
||||||
|
"commandName": "Project",
|
||||||
|
"dotnetRunMessages": true,
|
||||||
|
"launchBrowser": true,
|
||||||
|
"launchUrl": "swagger",
|
||||||
|
"applicationUrl": "http://localhost:5267",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"https": {
|
||||||
|
"commandName": "Project",
|
||||||
|
"dotnetRunMessages": true,
|
||||||
|
"launchBrowser": true,
|
||||||
|
"launchUrl": "swagger",
|
||||||
|
"applicationUrl": "https://localhost:7261;http://localhost:5267",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"IIS Express": {
|
||||||
|
"commandName": "IISExpress",
|
||||||
|
"launchBrowser": true,
|
||||||
|
"launchUrl": "swagger",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
namespace PokemonSleepAPI
|
||||||
|
{
|
||||||
|
public class WeatherForecast
|
||||||
|
{
|
||||||
|
public DateOnly Date { get; set; }
|
||||||
|
|
||||||
|
public int TemperatureC { get; set; }
|
||||||
|
|
||||||
|
public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
|
||||||
|
|
||||||
|
public string? Summary { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"AllowedHosts": "*",
|
||||||
|
"ConnectionStrings": {
|
||||||
|
"DefaultConnection": "Server=(localdb)\\MSSQLFishbowlDB;Database=PokemonSleep;Trusted_Connection=True;TrustServerCertificate=True"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
|
<base href="/" />
|
||||||
|
<link rel="stylesheet" href="bootstrap/bootstrap.min.css" />
|
||||||
|
<link rel="stylesheet" href="app.css" />
|
||||||
|
<link rel="stylesheet" href="PokemonSleepInterface.styles.css" />
|
||||||
|
<link rel="icon" type="image/png" href="favicon.png" />
|
||||||
|
<HeadOutlet />
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<Routes />
|
||||||
|
<script src="_framework/blazor.web.js"></script>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
|
@ -0,0 +1,23 @@
|
||||||
|
@inherits LayoutComponentBase
|
||||||
|
|
||||||
|
<div class="page">
|
||||||
|
<div class="sidebar">
|
||||||
|
<NavMenu />
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<main>
|
||||||
|
<div class="top-row px-4">
|
||||||
|
<a href="https://learn.microsoft.com/aspnet/core/" target="_blank">About</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<article class="content px-4">
|
||||||
|
@Body
|
||||||
|
</article>
|
||||||
|
</main>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="blazor-error-ui">
|
||||||
|
An unhandled error has occurred.
|
||||||
|
<a href="" class="reload">Reload</a>
|
||||||
|
<a class="dismiss">🗙</a>
|
||||||
|
</div>
|
|
@ -0,0 +1,96 @@
|
||||||
|
.page {
|
||||||
|
position: relative;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
main {
|
||||||
|
flex: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row {
|
||||||
|
background-color: #f7f7f7;
|
||||||
|
border-bottom: 1px solid #d6d5d5;
|
||||||
|
justify-content: flex-end;
|
||||||
|
height: 3.5rem;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row ::deep a, .top-row ::deep .btn-link {
|
||||||
|
white-space: nowrap;
|
||||||
|
margin-left: 1.5rem;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row ::deep a:hover, .top-row ::deep .btn-link:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row ::deep a:first-child {
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 640.98px) {
|
||||||
|
.top-row {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row ::deep a, .top-row ::deep .btn-link {
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 641px) {
|
||||||
|
.page {
|
||||||
|
flex-direction: row;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
width: 250px;
|
||||||
|
height: 100vh;
|
||||||
|
position: sticky;
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row {
|
||||||
|
position: sticky;
|
||||||
|
top: 0;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row.auth ::deep a:first-child {
|
||||||
|
flex: 1;
|
||||||
|
text-align: right;
|
||||||
|
width: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row, article {
|
||||||
|
padding-left: 2rem !important;
|
||||||
|
padding-right: 1.5rem !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#blazor-error-ui {
|
||||||
|
background: lightyellow;
|
||||||
|
bottom: 0;
|
||||||
|
box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
|
||||||
|
display: none;
|
||||||
|
left: 0;
|
||||||
|
padding: 0.6rem 1.25rem 0.7rem 1.25rem;
|
||||||
|
position: fixed;
|
||||||
|
width: 100%;
|
||||||
|
z-index: 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
#blazor-error-ui .dismiss {
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 0.75rem;
|
||||||
|
top: 0.5rem;
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
<div class="top-row ps-3 navbar navbar-dark">
|
||||||
|
<div class="container-fluid">
|
||||||
|
<a class="navbar-brand" href="">PokemonSleepInterface</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<input type="checkbox" title="Navigation menu" class="navbar-toggler" />
|
||||||
|
|
||||||
|
<div class="nav-scrollable" onclick="document.querySelector('.navbar-toggler').click()">
|
||||||
|
<nav class="flex-column">
|
||||||
|
<div class="nav-item px-3">
|
||||||
|
<NavLink class="nav-link" href="" Match="NavLinkMatch.All">
|
||||||
|
<span class="bi bi-house-door-fill-nav-menu" aria-hidden="true"></span> Home
|
||||||
|
</NavLink>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
<div class="nav-item px-3">
|
||||||
|
<NavLink class="nav-link" href="counter">
|
||||||
|
<span class="bi bi-plus-square-fill-nav-menu" aria-hidden="true"></span> Counter
|
||||||
|
</NavLink>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="nav-item px-3">
|
||||||
|
<NavLink class="nav-link" href="weather">
|
||||||
|
<span class="bi bi-list-nested-nav-menu" aria-hidden="true"></span> Weather
|
||||||
|
</NavLink>
|
||||||
|
</div>
|
||||||
|
-->
|
||||||
|
</nav>
|
||||||
|
</div>
|
||||||
|
|
|
@ -0,0 +1,105 @@
|
||||||
|
.navbar-toggler {
|
||||||
|
appearance: none;
|
||||||
|
cursor: pointer;
|
||||||
|
width: 3.5rem;
|
||||||
|
height: 2.5rem;
|
||||||
|
color: white;
|
||||||
|
position: absolute;
|
||||||
|
top: 0.5rem;
|
||||||
|
right: 1rem;
|
||||||
|
border: 1px solid rgba(255, 255, 255, 0.1);
|
||||||
|
background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.75rem rgba(255, 255, 255, 0.1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggler:checked {
|
||||||
|
background-color: rgba(255, 255, 255, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
.top-row {
|
||||||
|
height: 3.5rem;
|
||||||
|
background-color: rgba(0,0,0,0.4);
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-brand {
|
||||||
|
font-size: 1.1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bi {
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
width: 1.25rem;
|
||||||
|
height: 1.25rem;
|
||||||
|
margin-right: 0.75rem;
|
||||||
|
top: -1px;
|
||||||
|
background-size: cover;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bi-house-door-fill-nav-menu {
|
||||||
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-house-door-fill' viewBox='0 0 16 16'%3E%3Cpath d='M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5Z'/%3E%3C/svg%3E");
|
||||||
|
}
|
||||||
|
|
||||||
|
.bi-plus-square-fill-nav-menu {
|
||||||
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-plus-square-fill' viewBox='0 0 16 16'%3E%3Cpath d='M2 0a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2H2zm6.5 4.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3a.5.5 0 0 1 1 0z'/%3E%3C/svg%3E");
|
||||||
|
}
|
||||||
|
|
||||||
|
.bi-list-nested-nav-menu {
|
||||||
|
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='white' class='bi bi-list-nested' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M4.5 11.5A.5.5 0 0 1 5 11h10a.5.5 0 0 1 0 1H5a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 3 7h10a.5.5 0 0 1 0 1H3a.5.5 0 0 1-.5-.5zm-2-4A.5.5 0 0 1 1 3h10a.5.5 0 0 1 0 1H1a.5.5 0 0 1-.5-.5z'/%3E%3C/svg%3E");
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item {
|
||||||
|
font-size: 0.9rem;
|
||||||
|
padding-bottom: 0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item:first-of-type {
|
||||||
|
padding-top: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item:last-of-type {
|
||||||
|
padding-bottom: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item ::deep .nav-link {
|
||||||
|
color: #d7d7d7;
|
||||||
|
background: none;
|
||||||
|
border: none;
|
||||||
|
border-radius: 4px;
|
||||||
|
height: 3rem;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
line-height: 3rem;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item ::deep a.active {
|
||||||
|
background-color: rgba(255,255,255,0.37);
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item ::deep .nav-link:hover {
|
||||||
|
background-color: rgba(255,255,255,0.1);
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-scrollable {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggler:checked ~ .nav-scrollable {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 641px) {
|
||||||
|
.navbar-toggler {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-scrollable {
|
||||||
|
/* Never collapse the sidebar for wide screens */
|
||||||
|
display: block;
|
||||||
|
|
||||||
|
/* Allow sidebar to scroll for tall menus */
|
||||||
|
height: calc(100vh - 3.5rem);
|
||||||
|
overflow-y: auto;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,36 @@
|
||||||
|
@page "/Error"
|
||||||
|
@using System.Diagnostics
|
||||||
|
|
||||||
|
<PageTitle>Error</PageTitle>
|
||||||
|
|
||||||
|
<h1 class="text-danger">Error.</h1>
|
||||||
|
<h2 class="text-danger">An error occurred while processing your request.</h2>
|
||||||
|
|
||||||
|
@if (ShowRequestId)
|
||||||
|
{
|
||||||
|
<p>
|
||||||
|
<strong>Request ID:</strong> <code>@RequestId</code>
|
||||||
|
</p>
|
||||||
|
}
|
||||||
|
|
||||||
|
<h3>Development Mode</h3>
|
||||||
|
<p>
|
||||||
|
Swapping to <strong>Development</strong> environment will display more detailed information about the error that occurred.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<strong>The Development environment shouldn't be enabled for deployed applications.</strong>
|
||||||
|
It can result in displaying sensitive information from exceptions to end users.
|
||||||
|
For local debugging, enable the <strong>Development</strong> environment by setting the <strong>ASPNETCORE_ENVIRONMENT</strong> environment variable to <strong>Development</strong>
|
||||||
|
and restarting the app.
|
||||||
|
</p>
|
||||||
|
|
||||||
|
@code{
|
||||||
|
[CascadingParameter]
|
||||||
|
private HttpContext? HttpContext { get; set; }
|
||||||
|
|
||||||
|
private string? RequestId { get; set; }
|
||||||
|
private bool ShowRequestId => !string.IsNullOrEmpty(RequestId);
|
||||||
|
|
||||||
|
protected override void OnInitialized() =>
|
||||||
|
RequestId = Activity.Current?.Id ?? HttpContext?.TraceIdentifier;
|
||||||
|
}
|
|
@ -0,0 +1,29 @@
|
||||||
|
@page "/"
|
||||||
|
@using PokemonSleepInterface.Models
|
||||||
|
@using PokemonSleepInterface.Service
|
||||||
|
|
||||||
|
<PageTitle>Home</PageTitle>
|
||||||
|
|
||||||
|
|
||||||
|
@inject PokemonService PokemonService
|
||||||
|
|
||||||
|
<h3>Data from API</h3>
|
||||||
|
|
||||||
|
@if (data == null)
|
||||||
|
{
|
||||||
|
<p><em>Loading...</em></p>
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
<h1>@data.Message</h1>
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@code {
|
||||||
|
private ResponseDto data;
|
||||||
|
|
||||||
|
protected override async Task OnInitializedAsync()
|
||||||
|
{
|
||||||
|
data = await PokemonService.GetAllPokemonAsync();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
<Router AppAssembly="typeof(Program).Assembly">
|
||||||
|
<Found Context="routeData">
|
||||||
|
<RouteView RouteData="routeData" DefaultLayout="typeof(Layout.MainLayout)" />
|
||||||
|
<FocusOnNavigate RouteData="routeData" Selector="h1" />
|
||||||
|
</Found>
|
||||||
|
</Router>
|
|
@ -0,0 +1,10 @@
|
||||||
|
@using System.Net.Http
|
||||||
|
@using System.Net.Http.Json
|
||||||
|
@using Microsoft.AspNetCore.Components.Forms
|
||||||
|
@using Microsoft.AspNetCore.Components.Routing
|
||||||
|
@using Microsoft.AspNetCore.Components.Web
|
||||||
|
@using static Microsoft.AspNetCore.Components.Web.RenderMode
|
||||||
|
@using Microsoft.AspNetCore.Components.Web.Virtualization
|
||||||
|
@using Microsoft.JSInterop
|
||||||
|
@using PokemonSleepInterface
|
||||||
|
@using PokemonSleepInterface.Components
|
|
@ -0,0 +1,35 @@
|
||||||
|
using Microsoft.AspNetCore.Http;
|
||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using PokemonSleepInterface.Models;
|
||||||
|
using PokemonSleepInterface.Service.IService;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Controllers
|
||||||
|
{
|
||||||
|
public class PokemonController : Controller
|
||||||
|
{
|
||||||
|
private readonly IPokemonService _pokemonService;
|
||||||
|
public PokemonController(IPokemonService pokemonService)
|
||||||
|
{
|
||||||
|
_pokemonService = pokemonService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<IActionResult> Index()
|
||||||
|
{
|
||||||
|
List<PokemonDto>? list = new();
|
||||||
|
ResponseDto? response = await _pokemonService.GetAllPokemonAsync();
|
||||||
|
|
||||||
|
if (response != null && response.IsSuccess)
|
||||||
|
{
|
||||||
|
list = JsonConvert.DeserializeObject<List<PokemonDto>>(Convert.ToString(response.Result));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
TempData["error"] = response?.Message;
|
||||||
|
}
|
||||||
|
|
||||||
|
return View(list);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
namespace PokemonSleepInterface.Models
|
||||||
|
{
|
||||||
|
public class PokemonDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string Name { get; set; }
|
||||||
|
public string SleepType { get; set; }
|
||||||
|
public string Speciality { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
namespace PokemonSleepInterface.Models
|
||||||
|
{
|
||||||
|
public class PokemonNatureDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string Nature { get; set; }
|
||||||
|
public int BerryRating { get; set; }
|
||||||
|
public int IngredientRating { get; set; }
|
||||||
|
public int SkillRating { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
namespace PokemonSleepInterface.Models
|
||||||
|
{
|
||||||
|
public class PokemonSubskillDto
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public string SubSkill { get; set; }
|
||||||
|
public int BerryRank { get; set; }
|
||||||
|
public int IngredientRank { get; set; }
|
||||||
|
public int SkillRank { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
using PokemonSleepInterface.Utility;
|
||||||
|
using static PokemonSleepInterface.Utility.StaticDetails;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Models
|
||||||
|
{
|
||||||
|
public class RequestDto
|
||||||
|
{
|
||||||
|
public ApiType ApiType { get; set; } = ApiType.GET;
|
||||||
|
public string Url { get; set; }
|
||||||
|
public object Data { get; set; }
|
||||||
|
public string AccessToken { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
namespace PokemonSleepInterface.Models
|
||||||
|
{
|
||||||
|
public class ResponseDto
|
||||||
|
{
|
||||||
|
public object? Result { get; set; }
|
||||||
|
public bool IsSuccess { get; set; } = true;
|
||||||
|
public string Message { get; set; } = "";
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net8.0</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="Newtonsoft.Json" Version="13.0.3" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
|
@ -0,0 +1,44 @@
|
||||||
|
using PokemonSleepInterface.Components;
|
||||||
|
using PokemonSleepInterface.Service;
|
||||||
|
using PokemonSleepInterface.Service.IService;
|
||||||
|
using PokemonSleepInterface.Utility;
|
||||||
|
|
||||||
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
|
||||||
|
// Add services to the container.
|
||||||
|
builder.Services.AddRazorComponents()
|
||||||
|
.AddInteractiveServerComponents();
|
||||||
|
|
||||||
|
builder.Services.AddControllersWithViews();
|
||||||
|
builder.Services.AddHttpContextAccessor();
|
||||||
|
builder.Services.AddHttpClient();
|
||||||
|
|
||||||
|
|
||||||
|
builder.Services.AddHttpClient<IPokemonService, PokemonService>();
|
||||||
|
StaticDetails.PokemonAPIBase = builder.Configuration["ServiceUrls:PokemonAPI"];
|
||||||
|
|
||||||
|
|
||||||
|
builder.Services.AddScoped<IPokemonService, PokemonService>();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
var app = builder.Build();
|
||||||
|
|
||||||
|
// Configure the HTTP request pipeline.
|
||||||
|
if (!app.Environment.IsDevelopment())
|
||||||
|
{
|
||||||
|
app.UseExceptionHandler("/Error", createScopeForErrors: true);
|
||||||
|
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
|
||||||
|
app.UseHsts();
|
||||||
|
}
|
||||||
|
|
||||||
|
app.UseHttpsRedirection();
|
||||||
|
|
||||||
|
app.UseStaticFiles();
|
||||||
|
app.UseAntiforgery();
|
||||||
|
|
||||||
|
app.MapRazorComponents<App>()
|
||||||
|
.AddInteractiveServerRenderMode();
|
||||||
|
|
||||||
|
app.Run();
|
|
@ -0,0 +1,38 @@
|
||||||
|
{
|
||||||
|
"$schema": "http://json.schemastore.org/launchsettings.json",
|
||||||
|
"iisSettings": {
|
||||||
|
"windowsAuthentication": false,
|
||||||
|
"anonymousAuthentication": true,
|
||||||
|
"iisExpress": {
|
||||||
|
"applicationUrl": "http://localhost:17310",
|
||||||
|
"sslPort": 44372
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"profiles": {
|
||||||
|
"http": {
|
||||||
|
"commandName": "Project",
|
||||||
|
"dotnetRunMessages": true,
|
||||||
|
"launchBrowser": true,
|
||||||
|
"applicationUrl": "http://localhost:5163",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"https": {
|
||||||
|
"commandName": "Project",
|
||||||
|
"dotnetRunMessages": true,
|
||||||
|
"launchBrowser": true,
|
||||||
|
"applicationUrl": "https://localhost:7096;http://localhost:5163",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"IIS Express": {
|
||||||
|
"commandName": "IISExpress",
|
||||||
|
"launchBrowser": true,
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,82 @@
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using PokemonSleepInterface.Models;
|
||||||
|
using PokemonSleepInterface.Service.IService;
|
||||||
|
using System.Net;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading;
|
||||||
|
using static PokemonSleepInterface.Utility.StaticDetails;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Service
|
||||||
|
{
|
||||||
|
public class BaseService : IBaseService
|
||||||
|
{
|
||||||
|
private readonly IHttpClientFactory _httpClientFactory;
|
||||||
|
public BaseService(IHttpClientFactory httpClientFactory)
|
||||||
|
{
|
||||||
|
_httpClientFactory = httpClientFactory;
|
||||||
|
}
|
||||||
|
public async Task<ResponseDto?> SendAsync(RequestDto requestDto, bool withBearer = true)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
HttpClient client = _httpClientFactory.CreateClient("PokemonSleepAPI");
|
||||||
|
HttpRequestMessage message = new();
|
||||||
|
message.Headers.Add("Accept", "application/json");
|
||||||
|
|
||||||
|
message.RequestUri = new Uri(requestDto.Url);
|
||||||
|
if (requestDto.Data != null)
|
||||||
|
{
|
||||||
|
message.Content = new StringContent(JsonConvert.SerializeObject(requestDto.Data), Encoding.UTF8, "application/json");
|
||||||
|
}
|
||||||
|
|
||||||
|
HttpResponseMessage? apiResponse = null;
|
||||||
|
|
||||||
|
switch (requestDto.ApiType)
|
||||||
|
{
|
||||||
|
case ApiType.POST:
|
||||||
|
message.Method = HttpMethod.Post;
|
||||||
|
break;
|
||||||
|
case ApiType.DELETE:
|
||||||
|
message.Method = HttpMethod.Delete;
|
||||||
|
break;
|
||||||
|
case ApiType.PUT:
|
||||||
|
message.Method = HttpMethod.Put;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
message.Method = HttpMethod.Get;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
apiResponse = await client.SendAsync(message);
|
||||||
|
|
||||||
|
switch (apiResponse.StatusCode)
|
||||||
|
{
|
||||||
|
case HttpStatusCode.NotFound:
|
||||||
|
return new() { IsSuccess = false, Message = "Not Found" };
|
||||||
|
case HttpStatusCode.Forbidden:
|
||||||
|
return new() { IsSuccess = false, Message = "Access Denied" };
|
||||||
|
case HttpStatusCode.Unauthorized:
|
||||||
|
return new() { IsSuccess = false, Message = "Unauthorized" };
|
||||||
|
case HttpStatusCode.InternalServerError:
|
||||||
|
return new() { IsSuccess = false, Message = "Internal Server Error" };
|
||||||
|
default:
|
||||||
|
var apiContent = await apiResponse.Content.ReadAsStringAsync();
|
||||||
|
var apiResponseDto = JsonConvert.DeserializeObject<ResponseDto>(apiContent);
|
||||||
|
return apiResponseDto;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
var dto = new ResponseDto
|
||||||
|
{
|
||||||
|
IsSuccess = false,
|
||||||
|
Message = ex.Message.ToString(),
|
||||||
|
};
|
||||||
|
return dto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
using PokemonSleepInterface.Models;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Service.IService
|
||||||
|
{
|
||||||
|
public interface IBaseService
|
||||||
|
{
|
||||||
|
Task<ResponseDto?> SendAsync(RequestDto requestDto, bool withBearer = true);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,9 @@
|
||||||
|
using PokemonSleepInterface.Models;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Service.IService
|
||||||
|
{
|
||||||
|
public interface IPokemonService
|
||||||
|
{
|
||||||
|
Task<ResponseDto?> GetAllPokemonAsync();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
using PokemonSleepInterface.Models;
|
||||||
|
using PokemonSleepInterface.Service.IService;
|
||||||
|
using PokemonSleepInterface.Utility;
|
||||||
|
|
||||||
|
namespace PokemonSleepInterface.Service
|
||||||
|
{
|
||||||
|
public class PokemonService : IPokemonService
|
||||||
|
{
|
||||||
|
private readonly IBaseService _baseService;
|
||||||
|
public PokemonService(IBaseService baseService)
|
||||||
|
{
|
||||||
|
_baseService = baseService;
|
||||||
|
}
|
||||||
|
public async Task<ResponseDto?> GetAllPokemonAsync()
|
||||||
|
{
|
||||||
|
return await _baseService.SendAsync(new RequestDto()
|
||||||
|
{
|
||||||
|
ApiType = StaticDetails.ApiType.GET,
|
||||||
|
Url = StaticDetails.PokemonAPIBase + "/api/pokemon"
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
namespace PokemonSleepInterface.Utility
|
||||||
|
{
|
||||||
|
public class StaticDetails
|
||||||
|
{
|
||||||
|
|
||||||
|
public static string PokemonAPIBase { get; set; }
|
||||||
|
|
||||||
|
public enum ApiType
|
||||||
|
{
|
||||||
|
GET, POST, PUT, DELETE
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"AllowedHosts": "*",
|
||||||
|
"ServiceUrls": {
|
||||||
|
"PokemonAPI": "https://localhost:7261"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,51 @@
|
||||||
|
html, body {
|
||||||
|
font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
a, .btn-link {
|
||||||
|
color: #006bb7;
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn-primary {
|
||||||
|
color: #fff;
|
||||||
|
background-color: #1b6ec2;
|
||||||
|
border-color: #1861ac;
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
|
||||||
|
box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.content {
|
||||||
|
padding-top: 1.1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1:focus {
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.valid.modified:not([type=checkbox]) {
|
||||||
|
outline: 1px solid #26b050;
|
||||||
|
}
|
||||||
|
|
||||||
|
.invalid {
|
||||||
|
outline: 1px solid #e50000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.validation-message {
|
||||||
|
color: #e50000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.blazor-error-boundary {
|
||||||
|
background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
|
||||||
|
padding: 1rem 1rem 1rem 3.7rem;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.blazor-error-boundary::after {
|
||||||
|
content: "An error has occurred."
|
||||||
|
}
|
||||||
|
|
||||||
|
.darker-border-checkbox.form-check-input {
|
||||||
|
border-color: #929292;
|
||||||
|
}
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Binary file not shown.
After Width: | Height: | Size: 1.1 KiB |
|
@ -0,0 +1,31 @@
|
||||||
|
|
||||||
|
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||||
|
# Visual Studio Version 17
|
||||||
|
VisualStudioVersion = 17.11.35327.3
|
||||||
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PokemonSleepAPI", "PokemonSleepAPI\PokemonSleepAPI.csproj", "{19640FE6-0A20-4231-9A0E-CC6143291A8D}"
|
||||||
|
EndProject
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PokemonSleepInterface", "PokemonSleepInterface\PokemonSleepInterface.csproj", "{D04FE20B-5AB3-4F2C-9F60-DECE3DBF8F6E}"
|
||||||
|
EndProject
|
||||||
|
Global
|
||||||
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
|
Debug|Any CPU = Debug|Any CPU
|
||||||
|
Release|Any CPU = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||||
|
{19640FE6-0A20-4231-9A0E-CC6143291A8D}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{19640FE6-0A20-4231-9A0E-CC6143291A8D}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{19640FE6-0A20-4231-9A0E-CC6143291A8D}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{19640FE6-0A20-4231-9A0E-CC6143291A8D}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
{D04FE20B-5AB3-4F2C-9F60-DECE3DBF8F6E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{D04FE20B-5AB3-4F2C-9F60-DECE3DBF8F6E}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{D04FE20B-5AB3-4F2C-9F60-DECE3DBF8F6E}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{D04FE20B-5AB3-4F2C-9F60-DECE3DBF8F6E}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
|
HideSolutionNode = FALSE
|
||||||
|
EndGlobalSection
|
||||||
|
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||||
|
SolutionGuid = {B8AC13EB-8184-491D-B1CA-A73A93ECEAD7}
|
||||||
|
EndGlobalSection
|
||||||
|
EndGlobal
|
Loading…
Reference in New Issue