mirror of
https://github.com/claunia/marechai.git
synced 2025-12-16 19:14:25 +00:00
37 lines
1.9 KiB
C#
37 lines
1.9 KiB
C#
|
|
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 SoundSynthsService
|
||
|
|
{
|
||
|
|
readonly MarechaiContext _context;
|
||
|
|
|
||
|
|
public SoundSynthsService(MarechaiContext context) => _context = context;
|
||
|
|
|
||
|
|
public async Task<List<SoundSynthViewModel>> GetAsync() =>
|
||
|
|
await _context.SoundSynths.OrderBy(s => s.Company.Name).ThenBy(s => s.Name).ThenBy(s => s.ModelCode).
|
||
|
|
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();
|
||
|
|
|
||
|
|
public async Task<List<SoundSynthViewModel>> GetByMachineAsync(int machineId) =>
|
||
|
|
await _context.SoundByMachine.Where(s => s.MachineId == machineId).Select(s => s.SoundSynth).
|
||
|
|
OrderBy(s => s.Company.Name).ThenBy(s => s.Name).ThenBy(s => s.ModelCode).
|
||
|
|
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();
|
||
|
|
}
|
||
|
|
}
|