2020-05-24 15:28:47 +01:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.Linq;
|
2020-05-22 03:35:50 +01:00
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
using Marechai.Database.Models;
|
2020-05-22 04:43:44 +01:00
|
|
|
|
using Marechai.ViewModels;
|
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
2020-05-22 03:35:50 +01:00
|
|
|
|
using Microsoft.Extensions.Localization;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Marechai.Services
|
|
|
|
|
|
{
|
|
|
|
|
|
public class MachinesService
|
|
|
|
|
|
{
|
|
|
|
|
|
readonly MarechaiContext _context;
|
|
|
|
|
|
readonly IStringLocalizer<MachinesService> _l;
|
2020-05-24 17:59:47 +01:00
|
|
|
|
readonly ProcessorsService _processorsService;
|
2020-05-22 03:35:50 +01:00
|
|
|
|
|
2020-05-24 17:59:47 +01:00
|
|
|
|
public MachinesService(MarechaiContext context, IStringLocalizer<MachinesService> localizer,
|
|
|
|
|
|
ProcessorsService processorsService)
|
2020-05-22 03:35:50 +01:00
|
|
|
|
{
|
2020-05-24 17:59:47 +01:00
|
|
|
|
_context = context;
|
|
|
|
|
|
_l = localizer;
|
|
|
|
|
|
_processorsService = processorsService;
|
2020-05-22 03:35:50 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-05-24 15:28:47 +01:00
|
|
|
|
public async Task<List<MachineViewModel>> GetAsync() =>
|
|
|
|
|
|
await _context.Machines.OrderBy(m => m.Company.Name).ThenBy(m => m.Name).ThenBy(m => m.Family.Name).
|
|
|
|
|
|
Select(m => new MachineViewModel
|
|
|
|
|
|
{
|
|
|
|
|
|
Id = m.Id, Company = m.Company.Name, Name = m.Name, Model = m.Model,
|
|
|
|
|
|
Introduced = m.Introduced, Type = m.Type, Family = m.Family.Name
|
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
|
2020-05-22 04:43:44 +01:00
|
|
|
|
public async Task<MachineViewModel> GetMachine(int id)
|
|
|
|
|
|
{
|
|
|
|
|
|
Machine machine = await _context.Machines.FindAsync(id);
|
|
|
|
|
|
|
|
|
|
|
|
if(machine is null)
|
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
|
|
|
|
var model = new MachineViewModel
|
|
|
|
|
|
{
|
|
|
|
|
|
Introduced = machine.Introduced, Name = machine.Name, CompanyId = machine.CompanyId,
|
|
|
|
|
|
Model = machine.Model
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
Company company = await _context.Companies.FindAsync(model.CompanyId);
|
|
|
|
|
|
|
|
|
|
|
|
if(company != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
model.CompanyName = company.Name;
|
|
|
|
|
|
|
|
|
|
|
|
IQueryable<CompanyLogo> logos = _context.CompanyLogos.Where(l => l.CompanyId == company.Id);
|
|
|
|
|
|
|
|
|
|
|
|
if(model.Introduced.HasValue)
|
|
|
|
|
|
model.CompanyLogo = (await logos.FirstOrDefaultAsync(l => l.Year >= model.Introduced.Value.Year))?.
|
|
|
|
|
|
Guid;
|
|
|
|
|
|
|
|
|
|
|
|
if(model.CompanyLogo is null &&
|
|
|
|
|
|
logos.Any())
|
|
|
|
|
|
model.CompanyLogo = (await logos.FirstAsync())?.Guid;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MachineFamily family = await _context.MachineFamilies.FindAsync(machine.FamilyId);
|
|
|
|
|
|
|
|
|
|
|
|
if(family != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
model.FamilyName = family.Name;
|
|
|
|
|
|
model.FamilyId = family.Id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
model.Gpus = await _context.GpusByMachine.Where(g => g.MachineId == machine.Id).Select(g => g.Gpu).
|
|
|
|
|
|
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();
|
|
|
|
|
|
|
|
|
|
|
|
model.Memory = await _context.MemoryByMachine.Where(m => m.MachineId == machine.Id).
|
|
|
|
|
|
Select(m => new MemoryViewModel
|
|
|
|
|
|
{
|
|
|
|
|
|
Type = m.Type, Usage = m.Usage, Size = m.Size, Speed = m.Speed
|
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
|
2020-05-24 17:59:47 +01:00
|
|
|
|
model.Processors = await _processorsService.GetByMachineAsync(machine.Id);
|
2020-05-22 04:43:44 +01:00
|
|
|
|
|
2020-05-23 05:23:50 +01:00
|
|
|
|
model.SoundSynthesizers =
|
2020-05-22 04:43:44 +01:00
|
|
|
|
await _context.SoundByMachine.Where(s => s.MachineId == machine.Id).Select(s => s.SoundSynth).
|
|
|
|
|
|
Select(s => new SoundSynthViewModel
|
|
|
|
|
|
{
|
|
|
|
|
|
Id = s.Id, Name = s.Name, CompanyId = s.Company.Id, CompanyName = s.Company.Name,
|
|
|
|
|
|
ModelCode = s.ModelCode, Introduced = s.Introduced, Voices = s.Voices,
|
|
|
|
|
|
Frequency = s.Frequency, Depth = s.Depth, SquareWave = s.SquareWave,
|
|
|
|
|
|
WhiteNoise = s.WhiteNoise, Type = s.Type
|
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
|
|
|
|
|
|
model.Storage = await _context.StorageByMachine.Where(s => s.MachineId == machine.Id).
|
|
|
|
|
|
Select(s => new StorageViewModel
|
|
|
|
|
|
{
|
|
|
|
|
|
Type = s.Type, Interface = s.Interface, Capacity = s.Capacity
|
|
|
|
|
|
}).ToListAsync();
|
|
|
|
|
|
|
|
|
|
|
|
return model;
|
|
|
|
|
|
}
|
2020-05-22 03:35:50 +01:00
|
|
|
|
}
|
|
|
|
|
|
}
|