2020-05-24 05:42:38 +01:00
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Marechai.Database.Models;
|
|
|
|
|
using Marechai.ViewModels;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
|
|
|
|
|
namespace Marechai.Services
|
|
|
|
|
{
|
|
|
|
|
public class GpusService
|
|
|
|
|
{
|
|
|
|
|
readonly MarechaiContext _context;
|
|
|
|
|
|
|
|
|
|
public GpusService(MarechaiContext context) => _context = context;
|
|
|
|
|
|
2020-05-24 18:51:24 +01:00
|
|
|
public async Task<List<GpuViewModel>> GetAsync() =>
|
|
|
|
|
await _context.Gpus.OrderBy(g => g.Company.Name).ThenBy(g => g.Name).ThenBy(g => g.Introduced).
|
|
|
|
|
Select(g => new GpuViewModel
|
|
|
|
|
{
|
|
|
|
|
Id = g.Id, Company = g.Company.Name, Introduced = g.Introduced, ModelCode = g.ModelCode,
|
|
|
|
|
Name = g.Name
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
|
|
|
|
public async Task<List<GpuViewModel>> GetByMachineAsync(int machineId) =>
|
|
|
|
|
await _context.GpusByMachine.Where(g => g.MachineId == machineId).Select(g => g.Gpu).
|
|
|
|
|
OrderBy(g => g.Company.Name).ThenBy(g => g.Name).Select(g => new GpuViewModel
|
|
|
|
|
{
|
|
|
|
|
Id = g.Id, Name = g.Name, Company = g.Company.Name, CompanyId = g.Company.Id,
|
|
|
|
|
ModelCode = g.ModelCode, Introduced = g.Introduced, Package = g.Package,
|
|
|
|
|
Process = g.Process, ProcessNm = g.ProcessNm, DieSize = g.DieSize,
|
|
|
|
|
Transistors = g.Transistors
|
|
|
|
|
}).ToListAsync();
|
2020-05-24 21:17:14 +01:00
|
|
|
|
|
|
|
|
public async Task DeleteAsync(int id)
|
|
|
|
|
{
|
|
|
|
|
Gpu item = await _context.Gpus.FindAsync(id);
|
|
|
|
|
|
|
|
|
|
if(item is null)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
_context.Gpus.Remove(item);
|
|
|
|
|
|
|
|
|
|
await _context.SaveChangesAsync();
|
|
|
|
|
}
|
2020-05-24 05:42:38 +01:00
|
|
|
}
|
|
|
|
|
}
|