Move devices by bus chart to ChartJS.

This commit is contained in:
2019-11-03 04:57:44 +00:00
parent 74f5c85de8
commit 9746b4d9a6
2 changed files with 37 additions and 8 deletions

View File

@@ -249,13 +249,6 @@ namespace DiscImageChef.Server.Controllers
ThenBy(device => device.Revision).ThenBy(device => device.Bus).
ToList();
ViewData["devicesBusPieData"] = (from deviceBus in devices.Select(d => d.Bus).Distinct()
let deviceBusCount = devices.Count(d => d.Bus == deviceBus)
select new PieSeriesData
{
Name = deviceBus, Y = deviceBusCount / (double)devices.Count
}).ToList();
ViewData["devicesManufacturerPieData"] =
(from manufacturer in devices.Where(d => d.Manufacturer != null).
Select(d => d.Manufacturer.ToLowerInvariant()).Distinct()
@@ -571,5 +564,34 @@ namespace DiscImageChef.Server.Controllers
return Json(result);
}
public IActionResult GetDevicesBusData()
{
var data = ctx.DeviceStats.Select(d => d.Bus).
Distinct().
Select(deviceBus => new
{
deviceBus, deviceBusCount = ctx.DeviceStats.Count(d => d.Bus == deviceBus)
}).
Select(t => new
{
Name = t.deviceBus, Count = t.deviceBusCount
}).ToList();
string[][] result =
{
data.OrderByDescending(o => o.Count).Take(10).Select(v => v.Name).ToArray(),
data.OrderByDescending(o => o.Count).Take(10).Select(x => x.Count.ToString()).ToArray()
};
if(result[0].Length < 10)
return Json(result);
result[0][9] = "Other";
result[1][9] = (data.Sum(o => o.Count) - result[1].Take(9).Sum(long.Parse)).ToString();
return Json(result);
}
}
}