+<%# Copyright (C) The Arvados Authors. All rights reserved.
- <% _running_pipelines = running_pipelines %>
- <% _finished_pipelines = finished_pipelines(8) %>
- <% lookup = preload_objects_for_dataclass PipelineTemplate, (_running_pipelines.map(&:pipeline_template_uuid) + _finished_pipelines.map(&:pipeline_template_uuid)) %>
+SPDX-License-Identifier: AGPL-3.0 %>
-
- <% if _running_pipelines.empty? %>
- No pipelines are currently running.
- <% else %>
- <% _running_pipelines.each do |p| %>
-
-
- <%= link_to_if_arvados_object p, {friendly_name: true, lookup: lookup} %>
+<%
+ recent_procs = recent_processes(12)
-
-
- <% p.components.each do |k, v| %>
- <% if v.is_a? Hash and v[:job] %>
- <%= render partial: 'job_progress', locals: {:j => v[:job], :scaleby => (1.0/p.components.size)} %>
- <% end %>
- <% end %>
-
-
-
+ # 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"])
+ end
- <%
- running = p.components.select { |k, c| c.is_a? Hash and c[:job].andand[:state] == "Running" }
- queued = p.components.select { |k, c| c.is_a? Hash and c[:job].andand[:state] == "Queued" }
- %>
+ wus = {}
+ outputs = []
+ recent_procs.each do |p|
+ wu = p.work_unit
-
- Started at <%= render_localized_date(p[:started_at] || p[:created_at], "noseconds") %>.
- <% pipeline_time = Time.now - (p[:started_at] || p[:created_at]) %>
- Active for <%= render_runtime(pipeline_time, false) %>.
+ wus[p] = wu
+ outputs << wu.outputs
+ end
+ outputs = outputs.flatten.uniq
-
- <% running.each do |k,v| %>
- <%= render partial: 'job_progress', locals: {:j => v[:job], :show_progress_bar => false, :title => k} %>
- <% end %>
- <% queued.each do |k,v| %>
- <%= render partial: 'job_progress', locals: {:j => v[:job], :show_progress_bar => false, :title => k} %>
+ 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_procs_title%>
+ <% if current_user.andand.is_active %>
+
+
+ <%= link_to(
+ choose_work_unit_templates_path(
+ 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 process...
+ <% end %>
+
+
+ <%= link_to all_processes_path, class: 'btn btn-default btn-xs' do %>
+ All processes
<% end %>
-
-
-
- <% end %>
+
+
<% end %>
-
-
-
Recently finished pipelines
-
- <%= link_to pipeline_instances_path, class: 'btn btn-default btn-xs' do %>
- All pipelines
- <% end %>
-
-
-
- <% _finished_pipelines.each do |p| %>
-
+
+ <% if recent_procs.empty? %>
+ No recent pipelines or processes.
+ <% else %>
+ <% 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, lookup: lookup} %>
+ <%= link_to_if_arvados_object p, {friendly_name: true} %>
- <%= render partial: "pipeline_status_label", locals: {p: p}%>
+ <%=wu.state_label%>
- <%= render_localized_date(p[:finished_at] || p[:modified_at], "noseconds") %>
+ <%= render_localized_date(wu.finished_at || wu.modified_at, "noseconds") %>
- <% if p[:started_at] and p[:finished_at] %>
- <% pipeline_time = p[:finished_at] - p[:started_at] %>
- Active for <%= render_runtime(pipeline_time, false) %>
+ <% if wu.started_at and wu.finished_at %>
+ <% wu_time = wu.finished_at - wu.started_at %>
+ Active for <%= render_runtime(wu_time, false) %>
<% end %>
-
- <% outputs = [] %>
- <% p.components.each do |k, c| %>
- <% outputs << c[:output_uuid] if c[:output_uuid] %>
- <% end %>
- <% if outputs.size == 0 %>
- No output.
- <% elsif outputs.size == 1 %>
- <%= link_to_if_arvados_object outputs[0], friendly_name: true %>
- <% else %>
- Outputs
- <% end %>
-
+ <%= render partial: 'work_units/show_output', locals: {wu: wu, align: 'pull-right', include_icon: true} %>
-
-
-
- <% outputs.each do |out| %>
-
- <%= link_to_if_arvados_object out, friendly_name: true %>
-
- <% end %>
-
+
+ <% else %>
+
+
+
+ <%= link_to_if_arvados_object p, {friendly_name: true} %>
+
+
+ <%=wu.state_label%>
+
+
+ <% 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 %>
+ <% end %>
<% end %>
- <% nodes = Node.all %>
+ <% if show_node_status %>
+ <% nodes = Node.filter([["last_ping_at", ">", Time.now - 3600]]).results %>
-
Compute and job status
-
- <%= link_to jobs_path, class: 'btn btn-default btn-xs' do %>
- All jobs
+ Compute node status
+
+ <% if current_user.andand.is_admin %>
+
+ <%= link_to nodes_path, class: 'btn btn-default btn-xs' do %>
+ All nodes
+ <% end %>
+
<% end %>
-
+
<%= render partial: 'compute_node_summary', locals: {nodes: nodes} %>
-
+ <% active_nodes = [] %>
+ <% nodes.sort_by { |n| n.hostname || "" }.each do |n| %>
+ <% if n.crunch_worker_state.in? ["busy", "idle"] %>
+ <% active_nodes << n %>
+ <% end %>
+ <% end %>
+ <% if active_nodes.any? %>
+
+ <% end %>
- <%= render partial: 'compute_node_status', locals: {nodes: nodes} %>
+ <%= render partial: 'compute_node_status', locals: {nodes: active_nodes} %>
+ <% end %>
+ <% if Container.api_exists?(:index) %>
+
+
Container status
+
+
+ <%= render partial: 'container_summary' %>
+
+
+
+ <% end %>
+ <% if Rails.configuration.Workbench.ShowRecentCollectionsOnDashboard %>
Recent collections
@@ -160,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} %>
@@ -173,5 +224,6 @@
<% end %>
+ <% end %>