Home.razor 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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.Components
  7. @inject GetSystemSummaryUseCase SystemSummaryUseCase
  8. @inject GetServiceSummaryUseCase ServiceSummaryUseCase
  9. @inject GetHardwareUseCaseSummary HardwareSummaryUseCase
  10. <PageTitle>Home</PageTitle>
  11. <div class="min-h-screen bg-zinc-950 text-zinc-200 font-mono p-6">
  12. @if (_loading)
  13. {
  14. <div class="text-zinc-500">loading summary…</div>
  15. }
  16. else
  17. {
  18. <!-- Totals + Tools -->
  19. <div class="mb-10 grid grid-cols-1 md:grid-cols-2 gap-6 max-w-4xl">
  20. <!-- Totals -->
  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. <!-- Tools -->
  41. <div class="border border-zinc-800 rounded-md p-4">
  42. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  43. Tools
  44. </div>
  45. <ul class="space-y-2 text-sm">
  46. <li>
  47. <NavLink href="subnets"
  48. class="block hover:text-emerald-300"
  49. data-testid="home-tool-subnets">
  50. → Subnet Browser
  51. </NavLink>
  52. </li>
  53. <li>
  54. <NavLink href="cli"
  55. class="block hover:text-emerald-300"
  56. data-testid="home-tool-cli">
  57. → CLI Emulator
  58. </NavLink>
  59. </li>
  60. <li>
  61. <NavLink href="yaml"
  62. class="block hover:text-emerald-300"
  63. data-testid="home-tool-yaml">
  64. → YAML Editor
  65. </NavLink>
  66. </li>
  67. <li>
  68. <NavLink href="ansible/inventory"
  69. class="block hover:text-emerald-300"
  70. data-testid="home-tool-ansible">
  71. → Ansible Inventory Generator
  72. </NavLink>
  73. </li>
  74. <li>
  75. <NavLink href="ssh/export"
  76. class="block hover:text-emerald-300"
  77. data-testid="home-tool-ansible">
  78. → SSH Config Export
  79. </NavLink>
  80. </li>
  81. <li>
  82. <NavLink href="hosts/export"
  83. class="block hover:text-emerald-300"
  84. data-testid="home-tool-ansible">
  85. → Hosts File Export
  86. </NavLink>
  87. </li>
  88. <li>
  89. <NavLink href="docs"
  90. class="block hover:text-emerald-300"
  91. data-testid="home-tool-docs">
  92. → Documentation
  93. </NavLink>
  94. </li>
  95. </ul>
  96. </div>
  97. </div>
  98. <div class="space-y-10 mb-10">
  99. <TagListComponent/>
  100. </div>
  101. <div class="space-y-10 mb-10">
  102. <LabelListComponent/>
  103. </div>
  104. <!-- Tree -->
  105. <div class="space-y-10">
  106. <!-- Hardware -->
  107. <div>
  108. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  109. Hardware
  110. </div>
  111. <ul class="space-y-2">
  112. <li class="text-zinc-100">
  113. ├─ Total (@_hardware!.TotalHardware)
  114. </li>
  115. @if (_hardware.HardwareByKind.Any())
  116. {
  117. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  118. @foreach (var (kind, count) in _hardware.HardwareByKind.OrderByDescending(x => x.Value))
  119. {
  120. var pluralKind = Resource.KindToPlural(kind);
  121. <NavLink href="@($"{Uri.EscapeDataString(pluralKind)}/list")" class="block">
  122. <li class="text-zinc-500 hover:text-emerald-300">
  123. └─ @pluralKind (@count)
  124. </li>
  125. </NavLink>
  126. }
  127. </ul>
  128. }
  129. </ul>
  130. </div>
  131. <!-- Systems -->
  132. <div>
  133. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  134. Systems
  135. </div>
  136. <ul class="space-y-3">
  137. <li>
  138. <div class="text-zinc-100">
  139. ├─ Total (@_system!.TotalSystems)
  140. </div>
  141. @if (_system.SystemsByType.Any())
  142. {
  143. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  144. <li class="text-zinc-400">Types</li>
  145. @foreach (var (type, count) in _system.SystemsByType.OrderByDescending(x => x.Value))
  146. {
  147. <li class="text-zinc-500 hover:text-emerald-300">
  148. <NavLink href="@($"systems/list?type={Uri.EscapeDataString(type)}")"
  149. class="block">
  150. └─ @type (@count)
  151. </NavLink>
  152. </li>
  153. }
  154. </ul>
  155. }
  156. @if (_system.SystemsByOs.Any())
  157. {
  158. <ul class="ml-4 mt-2 border-l border-zinc-800 pl-4 space-y-1">
  159. <li class="text-zinc-400">Operating Systems</li>
  160. @foreach (var (os, count) in _system.SystemsByOs.OrderByDescending(x => x.Value))
  161. {
  162. <li class="text-zinc-500 hover:text-emerald-300">
  163. <NavLink href="@($"systems/list?os={Uri.EscapeDataString(os)}")" class="block">
  164. └─ @os (@count)
  165. </NavLink>
  166. </li>
  167. }
  168. </ul>
  169. }
  170. </li>
  171. </ul>
  172. </div>
  173. <!-- Services -->
  174. <div>
  175. <div class="text-xs text-zinc-500 uppercase tracking-wider mb-3">
  176. Services
  177. </div>
  178. <ul>
  179. <li class="text-zinc-100">
  180. └─ Total (@_service!.TotalServices)
  181. </li>
  182. <li class="ml-4 text-zinc-500">
  183. └─ IP Addresses (@_service!.TotalIpAddresses)
  184. </li>
  185. </ul>
  186. </div>
  187. </div>
  188. }
  189. </div>
  190. @code {
  191. private bool _loading = true;
  192. private SystemSummary? _system;
  193. private AllServicesSummary? _service;
  194. private HardwareSummary? _hardware;
  195. protected override async Task OnInitializedAsync()
  196. {
  197. var systemTask = SystemSummaryUseCase.ExecuteAsync();
  198. var serviceTask = ServiceSummaryUseCase.ExecuteAsync();
  199. var hardwareTask = HardwareSummaryUseCase.ExecuteAsync();
  200. await Task.WhenAll(systemTask, serviceTask, hardwareTask);
  201. _system = systemTask.Result;
  202. _service = serviceTask.Result;
  203. _hardware = hardwareTask.Result;
  204. _loading = false;
  205. }
  206. }