X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2eaa77dc327c024f2faa3fbd322e7054454b6442..e2a4e065951ea459570ae75dbe2ed4fd4b6d4bd8:/apps/workbench/app/views/projects/_show_dashboard.html.erb diff --git a/apps/workbench/app/views/projects/_show_dashboard.html.erb b/apps/workbench/app/views/projects/_show_dashboard.html.erb index ab6eb16f51..f472b1e75a 100644 --- a/apps/workbench/app/views/projects/_show_dashboard.html.erb +++ b/apps/workbench/app/views/projects/_show_dashboard.html.erb @@ -1,10 +1,32 @@ <% recent_procs = recent_processes(12) + # preload container_uuids of any container requests + recent_crs = recent_procs.map {|p| p if p.is_a?(ContainerRequest)}.compact.uniq + recent_cr_containers = recent_crs.map {|cr| cr.container_uuid}.compact.uniq + preload_objects_for_dataclass(Container, recent_cr_containers) if recent_cr_containers.andand.any? + + # fetch children of all the active crs in one call, if there are any + active_crs = recent_crs.each {|cr| cr if (cr.priority > 0 and cr.state != 'Final' and cr.container_uuid)} + active_cr_uuids = active_crs.map(&:uuid) + active_cr_containers = active_crs.map {|cr| cr.container_uuid}.compact.uniq + cr_children = {} + if active_cr_containers.any? + active_cr_containers.each { |c| cr_children[c] = []} + cols = ContainerRequest.columns.map(&:name) - %w(id updated_at mounts) + reqs = ContainerRequest.select(cols).where(requesting_container_uuid: active_cr_containers).results + reqs.each {|cr| cr_children[cr.requesting_container_uuid] << cr} if reqs + end + wus = {} outputs = [] recent_procs.each do |p| - wu = p.work_unit + if p.uuid.in?(active_cr_uuids) + wu = p.work_unit(nil, child_objects=cr_children[p.container_uuid]) + else + wu = p.work_unit + end + wus[p] = wu outputs << wu.outputs end @@ -25,17 +47,25 @@ %> <% + recent_procs_panel_width = 6 if !PipelineInstance.api_exists?(:index) recent_procs_title = 'Recent processes' run_proc_title = 'Choose a workflow to run:' + show_node_status = false + # Recent processes panel should take the entire width when is the only one + # being rendered. + if !Rails.configuration.show_recent_collections_on_dashboard + recent_procs_panel_width = 12 + end else recent_procs_title = 'Recent pipelines and processes' run_proc_title = 'Choose a pipeline or workflow to run:' + show_node_status = true end %>
-
+
<%=recent_procs_title%> @@ -140,6 +170,7 @@
+ <% if show_node_status %> <% nodes = Node.filter([["last_ping_at", ">", Time.now - 3600]]).results %>
Compute node status @@ -173,6 +204,7 @@
+ <% end %> <% if Rails.configuration.show_recent_collections_on_dashboard %>
Recent collections