using skydiveLogs_api.Domain; using skydiveLogs_api.DomainBusiness.Interfaces; using System.Collections.Generic; using System.Linq; namespace skydiveLogs_api.DomainBusiness { public class StatsService : IStatsService { #region Public Constructors public StatsService(IJumpService jumpService) { _jumpService = jumpService; } #endregion Public Constructors #region Public Methods public SimpleSummary GetSimpleSummary() { var allJumps = _jumpService.GetAllJumps(); var results = new SimpleSummary(); if (allJumps.Any()) { var lastJump = allJumps.OrderByDescending(j => j.JumpDate).First(); results = new SimpleSummary { LastJump = lastJump, TotalJumps = allJumps.Count(), TotalCutaways = allJumps.Where(j => j.WithCutaway).Count() }; } return results; } public IEnumerable GetStatsByAircraft() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { results = allJumps.GroupBy(j => j.Aircraft.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsByDz() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { results = allJumps.GroupBy(j => j.DropZone.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsByGear() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { results = allJumps.GroupBy(j => $"{j.Gear.Name} / {j.Gear.MainCanopy}", j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsByJumpType() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { results = allJumps.GroupBy(j => j.JumpType.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsByYear() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { results = allJumps.GroupBy(j => j.JumpDate.Year, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsForLastMonthByDz() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { var lastJump = allJumps.OrderByDescending(j => j.JumpDate).First(); var yearOfLastJump = lastJump.JumpDate.Year; var monthOfLastJump = lastJump.JumpDate.Month; results = allJumps.Where(j => j.JumpDate.Year == yearOfLastJump && j.JumpDate.Month == monthOfLastJump) .GroupBy(j => j.DropZone.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsForLastMonthByJumpType() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { var lastJump = allJumps.OrderByDescending(j => j.JumpDate).First(); var yearOfLastJump = lastJump.JumpDate.Year; var monthOfLastJump = lastJump.JumpDate.Month; results = allJumps.Where(j => j.JumpDate.Year == yearOfLastJump && j.JumpDate.Month == monthOfLastJump) .GroupBy(j => j.JumpType.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsForLastYearByDz() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { var lastJump = allJumps.OrderByDescending(j => j.JumpDate).First(); var yearOfLastJump = lastJump.JumpDate.Year; results = allJumps.Where(j => j.JumpDate.Year == yearOfLastJump) .GroupBy(j => j.DropZone.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } public IEnumerable GetStatsForLastYearByJumpType() { var allJumps = _jumpService.GetAllJumps(); var results = new List(); if (allJumps.Any()) { var lastJump = allJumps.OrderByDescending(j => j.JumpDate).First(); var yearOfLastJump = lastJump.JumpDate.Year; results = allJumps.Where(j => j.JumpDate.Year == yearOfLastJump) .GroupBy(j => j.JumpType.Name, j => j, (groupby, jumps) => new Statistic { Label = groupby.ToString(), Nb = jumps.Count() }) .ToList(); } return results; } #endregion Public Methods #region Private Fields private readonly IJumpService _jumpService; #endregion Private Fields } }