Home.razor 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. @page "/"
  2. @using RackPeek.Domain.Resources
  3. @using RackPeek.Domain.Resources.Hardware
  4. @using RackPeek.Domain.Resources.Services.UseCases
  5. @using RackPeek.Domain.Resources.SystemResources.UseCases
  6. @using Shared.Rcl
  7. @using Shared.Rcl.Components
  8. @inject GetSystemSummaryUseCase SystemSummaryUseCase
  9. @inject GetServiceSummaryUseCase ServiceSummaryUseCase
  10. @inject GetHardwareUseCaseSummary HardwareSummaryUseCase
  11. <PageTitle>Home</PageTitle>
  12. <div class="min-h-screen bg-zinc-950 text-zinc-200 font-mono p-6">
  13. @if (_loading)
  14. {
  15. <div class="text-zinc-500">loading summary…</div>
  16. }
  17. else
  18. {
  19. <!-- Totals -->
  20. <div class="mb-10 max-w-md">
  21. <div class="border border-zinc-800 rounded-md p-4">
  22. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  23. Totals
  24. </div>
  25. <div class="grid grid-cols-2 gap-y-2 ">
  26. <div class="hover:text-emerald-300">
  27. <NavLink href="@("hardware/tree")">Hardware</NavLink>
  28. </div>
  29. <div class="text-right">@_hardware!.TotalHardware</div>
  30. <div class="hover:text-emerald-300">
  31. <NavLink href="@("systems/list")">Systems</NavLink>
  32. </div>
  33. <div class="text-right">@_system!.TotalSystems</div>
  34. <div class="hover:text-emerald-300">
  35. <NavLink href="@("services/list")">Services</NavLink>
  36. </div>
  37. <div class="text-right">@_service!.TotalServices</div>
  38. </div>
  39. </div>
  40. </div>
  41. <div class="space-y-10 mb-10">
  42. <TagListComponent/>
  43. </div>
  44. <!-- Tree -->
  45. <div class="space-y-10">
  46. <!-- Hardware -->
  47. <div>
  48. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  49. Hardware
  50. </div>
  51. <ul class="space-y-2">
  52. <li class="text-zinc-100">
  53. ├─ Total (@_hardware!.TotalHardware)
  54. </li>
  55. @if (_hardware.HardwareByKind.Any())
  56. {
  57. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  58. @foreach (var (kind, count) in _hardware.HardwareByKind.OrderByDescending(x => x.Value))
  59. {
  60. var pluralKind = Resource.KindToPlural(kind);
  61. <NavLink href="@($"{pluralKind}/list")" class="block">
  62. <li class="text-zinc-500 hover:text-emerald-300">
  63. └─ @pluralKind (@count)
  64. </li>
  65. </NavLink>
  66. }
  67. </ul>
  68. }
  69. </ul>
  70. </div>
  71. <!-- Systems -->
  72. <div>
  73. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  74. Systems
  75. </div>
  76. <ul class="space-y-3">
  77. <li>
  78. <div class="text-zinc-100">
  79. ├─ Total (@_system!.TotalSystems)
  80. </div>
  81. @if (_system.SystemsByType.Any())
  82. {
  83. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  84. <li class="text-zinc-400">Types</li>
  85. @foreach (var (type, count) in _system.SystemsByType.OrderByDescending(x => x.Value))
  86. {
  87. <li class="text-zinc-500 hover:text-emerald-300">
  88. <NavLink href="@($"systems/list?type={type}")" class="block">
  89. └─ @type (@count)
  90. </NavLink>
  91. </li>
  92. }
  93. </ul>
  94. }
  95. @if (_system.SystemsByOs.Any())
  96. {
  97. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  98. <li class="text-zinc-400">Operating Systems</li>
  99. @foreach (var (os, count) in _system.SystemsByOs.OrderByDescending(x => x.Value))
  100. {
  101. <li class="text-zinc-500 hover:text-emerald-300">
  102. <NavLink href="@($"systems/list?os={os}")" class="block">
  103. └─ @os (@count)
  104. </NavLink>
  105. </li>
  106. }
  107. </ul>
  108. }
  109. </li>
  110. </ul>
  111. </div>
  112. <!-- Services -->
  113. <div>
  114. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  115. Services
  116. </div>
  117. <ul>
  118. <li class="text-zinc-100">
  119. └─ Total (@_service!.TotalServices)
  120. </li>
  121. <li class="ml-4 text-zinc-500">
  122. └─ IP Addresses (@_service!.TotalIpAddresses)
  123. </li>
  124. </ul>
  125. </div>
  126. </div>
  127. }
  128. </div>
  129. @code {
  130. private bool _loading = true;
  131. private SystemSummary? _system;
  132. private AllServicesSummary? _service;
  133. private HardwareSummary? _hardware;
  134. protected override async Task OnInitializedAsync()
  135. {
  136. var systemTask = SystemSummaryUseCase.ExecuteAsync();
  137. var serviceTask = ServiceSummaryUseCase.ExecuteAsync();
  138. var hardwareTask = HardwareSummaryUseCase.ExecuteAsync();
  139. await Task.WhenAll(systemTask, serviceTask, hardwareTask);
  140. _system = systemTask.Result;
  141. _service = serviceTask.Result;
  142. _hardware = hardwareTask.Result;
  143. _loading = false;
  144. }
  145. }