X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/5c9aedbd8e623a518f5e1a92e4064a25ddd66353..dac27775017bab861a9fe3e3f85766df7cd8f80d:/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 c02577fcfd..61ceaf9fec 100644 --- a/apps/workbench/app/views/projects/_show_dashboard.html.erb +++ b/apps/workbench/app/views/projects/_show_dashboard.html.erb @@ -1,20 +1,77 @@ +<%# Copyright (C) The Arvados Authors. All rights reserved. + +SPDX-License-Identifier: AGPL-3.0 %> + +<% + 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 + if recent_cr_containers.andand.any? + preload_objects_for_dataclass(Container, recent_cr_containers, nil, + ["uuid", "started_at", "finished_at", "state", "runtime_status", "created_at", "modified_at", "exit_code"]) + end + + wus = {} + outputs = [] + recent_procs.each do |p| + wu = p.work_unit + + wus[p] = wu + outputs << wu.outputs + end + outputs = outputs.flatten.uniq + + collection_pdhs = outputs.select {|x| !(m = CollectionsHelper.match(x)).nil?}.uniq.compact + collection_uuids = outputs - collection_pdhs + + if Rails.configuration.Workbench.ShowRecentCollectionsOnDashboard + recent_cs = recent_collections(8) + collection_uuids = collection_uuids + recent_cs[:collections].collect {|c| c.uuid} + collection_uuids.flatten.uniq + end + + preload_collections_for_objects collection_uuids if collection_uuids.any? + preload_for_pdhs collection_pdhs if collection_pdhs.any? + preload_links_for_objects(collection_pdhs + collection_uuids) +%> + +<% + recent_procs_panel_width = 6 + if !PipelineInstance.api_exists?(:create) + 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.Workbench.ShowRecentCollectionsOnDashboard + 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 pipelines and processes + <%=recent_procs_title%> <% if current_user.andand.is_active %> <%= link_to( choose_work_unit_templates_path( - title: 'Choose a pipeline or workflow to run:', + title: run_proc_title, action_name: 'Next: choose inputs ', action_href: work_units_path, action_method: 'post', action_data: {'selection_param' => 'work_unit[template_uuid]', 'work_unit[owner_uuid]' => current_user.uuid, 'success' => 'redirect-to-created-object'}.to_json), { class: "btn btn-primary btn-xs", remote: true }) do %> - Run a pipeline... + Run a process... <% end %> @@ -26,15 +83,24 @@ <% end %>
- <% _recent_processes = recent_processes(12) %>
- <% if _recent_processes.empty? %> + <% if recent_procs.empty? %> No recent pipelines or processes. <% else %> - <% _recent_processes.each do |p| %> - <% wu = p.work_unit %> + <% wus.each do |p, wu| %> + <% + # Set up tooltip containing useful runtime information + runtime_status_tooltip = nil + if wu.runtime_status + if wu.runtime_status[:error] + runtime_status_tooltip = "Error: #{wu.runtime_status[:error]}" + elsif wu.runtime_status[:warning] + runtime_status_tooltip = "Warning: #{wu.runtime_status[:warning]}" + end + end + %> <% if wu.is_finished? %> -
+
<%= link_to_if_arvados_object p, {friendly_name: true} %> @@ -59,43 +125,26 @@
<% else %> -
+
-
+
<%= link_to_if_arvados_object p, {friendly_name: true} %>
- <% if wu.is_running? %> -
-
- <% wu.progress %> -
-
- <% else %>
<%=wu.state_label%>
- <% end %>
- <% - children = wu.children - running = children.select { |c| c.state_label == "Running" } - queued = children.select { |c| c.state_label == "Queued" } - %> -
- Started at <%= render_localized_date(wu.started_at || wu.created_at, "noseconds") %>. - <% wu_time = Time.now - (wu.started_at || wu.created_at) %> - Active for <%= render_runtime(wu_time, false) %>. - -
- <% running.each do |r| %> - <%= r.label || r.state_label || 'Not ready' %> - <% end %> - <% queued.each do |q| %> - <%= q.label || r.state_label || 'Not ready' %> + <% if wu.started_at %> + Started at <%= render_localized_date(wu.started_at, "noseconds") %> + Active for <%= render_runtime(Time.now - wu.started_at, false) %>. + <% else %> + Created at <%= render_localized_date(wu.created_at, "noseconds") %>. + <% if wu.state_label == 'Queued' %> + Queued for <%= render_runtime(Time.now - wu.created_at, false) %>. <% end %> -
+ <% end %>
<% end %> @@ -106,7 +155,8 @@
- <% nodes = Node.filter([["last_ping_at", ">", Time.now - 3600]]) %> + <% if show_node_status %> + <% nodes = Node.filter([["last_ping_at", ">", Time.now - 3600]]).results %>
Compute node status @@ -139,6 +189,18 @@
+ <% end %> + <% if Container.api_exists?(:index) %> +
+
Container status
+
+
+ <%= render partial: 'container_summary' %> +
+
+
+ <% end %> + <% if Rails.configuration.Workbench.ShowRecentCollectionsOnDashboard %>
Recent collections @@ -148,11 +210,12 @@
- <% r = recent_collections(8) %> - <% r[:collections].each do |p| %> + <% recent_cs[:collections].each do |p| %>
- <%= link_to_if_arvados_object r[:owners][p[:owner_uuid]], friendly_name: true %>/ + <% if recent_cs[:owners][p[:owner_uuid]].is_a?(Group) %> + <%= link_to_if_arvados_object recent_cs[:owners][p[:owner_uuid]], friendly_name: true %>/ + <% end %> <%= render_localized_date(p[:modified_at], "noseconds") %>
<%= link_to_if_arvados_object p, {friendly_name: true, no_tags: true} %> @@ -161,5 +224,6 @@ <% end %>
+ <% end %>