Split tables for the stats (#6)
Reviewed-on: #6 Co-authored-by: sandre <perso@sebastienandre.com> Co-committed-by: sandre <perso@sebastienandre.com>
This commit was merged in pull request #6.
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
using skydiveLogs_api.Domain;
|
||||
using skydiveLogs_api.DomainBusiness.Interfaces;
|
||||
using skydiveLogs_api.DomainService.Repositories;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
@@ -11,12 +10,28 @@ namespace skydiveLogs_api.DomainBusiness
|
||||
#region Public Constructors
|
||||
|
||||
public StatsService(IJumpService jumpService,
|
||||
IUserStatsRepository userStatsRepository,
|
||||
IIdentityService identityService)
|
||||
IStatsByAircraftService statsByAircraftService,
|
||||
IStatsByDzService statsByDzService,
|
||||
IStatsByGearService statsByGearService,
|
||||
IStatsByJumpTypeService statsByJumpTypeService,
|
||||
IStatsByYearByJumpTypeService statsByYearByJumpTypeService,
|
||||
IStatsByYearService statsByYearService,
|
||||
IStatsForLastMonthByDzService statsForLastMonthByDzService,
|
||||
IStatsForLastMonthByJumpTypeService statsForLastMonthByJumpTypeService,
|
||||
IStatsForLastYearByDzService statsForLastYearByDzService,
|
||||
IStatsForLastYearByJumpTypeService statsForLastYearByJumpTypeService)
|
||||
{
|
||||
_jumpService = jumpService;
|
||||
_identityService = identityService;
|
||||
_userStatsRepository = userStatsRepository;
|
||||
_statsByAircraftService = statsByAircraftService;
|
||||
_statsByDzService = statsByDzService;
|
||||
_statsByGearService = statsByGearService;
|
||||
_statsByJumpTypeService = statsByJumpTypeService;
|
||||
_statsByYearByJumpTypeService = statsByYearByJumpTypeService;
|
||||
_statsByYearService = statsByYearService;
|
||||
_statsForLastMonthByDzService = statsForLastMonthByDzService;
|
||||
_statsForLastMonthByJumpTypeService = statsForLastMonthByJumpTypeService;
|
||||
_statsForLastYearByDzService = statsForLastYearByDzService;
|
||||
_statsForLastYearByJumpTypeService = statsForLastYearByJumpTypeService;
|
||||
}
|
||||
|
||||
#endregion Public Constructors
|
||||
@@ -43,339 +58,136 @@ namespace skydiveLogs_api.DomainBusiness
|
||||
return results;
|
||||
}
|
||||
|
||||
public void Reset()
|
||||
{
|
||||
_statsByAircraftService.Reset();
|
||||
_statsByDzService.Reset();
|
||||
_statsByGearService.Reset();
|
||||
_statsByJumpTypeService.Reset();
|
||||
_statsByYearByJumpTypeService.Reset();
|
||||
_statsByYearService.Reset();
|
||||
_statsForLastMonthByDzService.Reset();
|
||||
_statsForLastMonthByJumpTypeService.Reset();
|
||||
_statsForLastYearByDzService.Reset();
|
||||
_statsForLastYearByJumpTypeService.Reset();
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByAircraft()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByAircraft.Any())
|
||||
var tmp = _statsByAircraftService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
if (allJumps.Any())
|
||||
{
|
||||
results = allJumps.GroupBy(j => j.Aircraft.Name,
|
||||
j => j,
|
||||
(groupby, jumps) => new Statistic
|
||||
{
|
||||
Label = groupby.ToString(),
|
||||
Nb = jumps.Count()
|
||||
})
|
||||
.ToList();
|
||||
}
|
||||
|
||||
allStats.ByAircraft = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByAircraft;
|
||||
Label = a.Aircraft,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByDz()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByDz.Any())
|
||||
var tmp = _statsByDzService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
if (allJumps.Any())
|
||||
{
|
||||
results = allJumps.GroupBy(j => j.DropZone.Name,
|
||||
j => j,
|
||||
(groupby, jumps) => new Statistic
|
||||
{
|
||||
Label = groupby.ToString(),
|
||||
Nb = jumps.Count()
|
||||
})
|
||||
.ToList();
|
||||
}
|
||||
|
||||
allStats.ByDz = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByDz;
|
||||
Label = a.DropZone,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByGear()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByGear.Any())
|
||||
var tmp = _statsByGearService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
allStats.ByGear = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByGear;
|
||||
Label = a.Gear,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByJumpType()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByJumpType.Any())
|
||||
var tmp = _statsByJumpTypeService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
if (allJumps.Any())
|
||||
{
|
||||
results = allJumps.GroupBy(j => j.JumpType.Name,
|
||||
j => j,
|
||||
(groupby, jumps) => new Statistic
|
||||
{
|
||||
Label = groupby.ToString(),
|
||||
Nb = jumps.Count()
|
||||
})
|
||||
.ToList();
|
||||
}
|
||||
|
||||
allStats.ByJumpType = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByJumpType;
|
||||
Label = a.JumpType,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByYear()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByYear.Any())
|
||||
var tmp = _statsByYearService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
if (allJumps.Any())
|
||||
{
|
||||
results = allJumps.GroupBy(j => j.JumpDate.Year,
|
||||
j => j,
|
||||
(groupby, jumps) => new Statistic
|
||||
{
|
||||
Label = groupby.ToString(),
|
||||
Nb = jumps.Count()
|
||||
})
|
||||
.ToList();
|
||||
}
|
||||
|
||||
allStats.ByYear = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByYear;
|
||||
Label = a.Year,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsForLastMonthByDz()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ForLastMonthByDz.Any())
|
||||
var tmp = _statsForLastMonthByDzService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
allStats.ForLastMonthByDz = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ForLastMonthByDz;
|
||||
Label = a.DropZone,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsForLastMonthByJumpType()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ForLastMonthByJumpType.Any())
|
||||
var tmp = _statsForLastMonthByJumpTypeService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
allStats.ForLastMonthByJumpType = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ForLastMonthByJumpType;
|
||||
Label = a.JumpType,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsForLastYearByDz()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ForLastYearByDz.Any())
|
||||
var tmp = _statsForLastYearByDzService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
allStats.ForLastYearByDz = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ForLastYearByDz;
|
||||
Label = a.DropZone,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsForLastYearByJumpType()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ForLastYearByJumpType.Any())
|
||||
var tmp = _statsForLastYearByJumpTypeService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
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();
|
||||
}
|
||||
|
||||
allStats.ForLastYearByJumpType = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ForLastYearByJumpType;
|
||||
Label = a.JumpType,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
public IEnumerable<Statistic> GetStatsByYearByJumpType()
|
||||
{
|
||||
var allStats = GetAllStats();
|
||||
if (!allStats.ByYearByJumpType.Any())
|
||||
var tmp = _statsByYearByJumpTypeService.GetStats();
|
||||
return [.. tmp.Select(a => new Statistic
|
||||
{
|
||||
var allJumps = _jumpService.GetAllJumps();
|
||||
var results = new List<Statistic>();
|
||||
|
||||
if (allJumps.Any())
|
||||
{
|
||||
results = allJumps.GroupBy(j => new { j.JumpType.Name, j.JumpDate.Year },
|
||||
j => j,
|
||||
(groupby, jumps) => new Statistic
|
||||
{
|
||||
Label = groupby.Year.ToString(),
|
||||
Label2 = groupby.Name.ToString(),
|
||||
Nb = jumps.Count()
|
||||
})
|
||||
.ToList();
|
||||
}
|
||||
|
||||
allStats.ByYearByJumpType = results;
|
||||
_userStatsRepository.Update(allStats);
|
||||
}
|
||||
|
||||
return allStats.ByYearByJumpType;
|
||||
}
|
||||
|
||||
public void Reset()
|
||||
{
|
||||
var resetStats = new UserStats();
|
||||
var myStats = GetAllStats();
|
||||
myStats.ByAircraft = resetStats.ByAircraft;
|
||||
myStats.ByDz = resetStats.ByDz;
|
||||
myStats.ByGear = resetStats.ByGear;
|
||||
myStats.ByJumpType = resetStats.ByJumpType;
|
||||
myStats.ByYear = resetStats.ByYear;
|
||||
myStats.ForLastMonthByDz = resetStats.ForLastMonthByDz;
|
||||
myStats.ForLastMonthByJumpType = resetStats.ForLastMonthByJumpType;
|
||||
myStats.ForLastYearByDz = resetStats.ForLastYearByDz;
|
||||
myStats.ForLastYearByJumpType = resetStats.ForLastYearByJumpType;
|
||||
myStats.ByYearByJumpType = resetStats.ByYearByJumpType;
|
||||
|
||||
_userStatsRepository.Update(myStats);
|
||||
Label = a.Year,
|
||||
Label2 = a.JumpType,
|
||||
Nb = a.Nb
|
||||
})];
|
||||
}
|
||||
|
||||
#endregion Public Methods
|
||||
|
||||
#region Private Methods
|
||||
|
||||
private UserStats GetAllStats()
|
||||
{
|
||||
var allStats = _userStatsRepository.GetAll(_identityService.ConnectedUser);
|
||||
if (allStats == null)
|
||||
{
|
||||
allStats = new UserStats
|
||||
{
|
||||
User = _identityService.ConnectedUser
|
||||
};
|
||||
_userStatsRepository.Add(allStats);
|
||||
}
|
||||
|
||||
return allStats;
|
||||
}
|
||||
|
||||
#endregion Private Methods
|
||||
|
||||
#region Private Fields
|
||||
|
||||
private readonly IIdentityService _identityService;
|
||||
private readonly IJumpService _jumpService;
|
||||
private readonly IUserStatsRepository _userStatsRepository;
|
||||
private readonly IStatsByAircraftService _statsByAircraftService;
|
||||
private readonly IStatsByDzService _statsByDzService;
|
||||
private readonly IStatsByGearService _statsByGearService;
|
||||
private readonly IStatsByJumpTypeService _statsByJumpTypeService;
|
||||
private readonly IStatsByYearByJumpTypeService _statsByYearByJumpTypeService;
|
||||
private readonly IStatsByYearService _statsByYearService;
|
||||
private readonly IStatsForLastMonthByDzService _statsForLastMonthByDzService;
|
||||
private readonly IStatsForLastMonthByJumpTypeService _statsForLastMonthByJumpTypeService;
|
||||
private readonly IStatsForLastYearByDzService _statsForLastYearByDzService;
|
||||
private readonly IStatsForLastYearByJumpTypeService _statsForLastYearByJumpTypeService;
|
||||
|
||||
#endregion Private Fields
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user