X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/92d5df330b86fb4c279a6e030258b860bed37358..fed9f70cdc99a3bc94a54bf1d182b13204a597be:/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 9ddd1d59d8..713582654f 100644 --- a/apps/workbench/app/views/projects/_show_dashboard.html.erb +++ b/apps/workbench/app/views/projects/_show_dashboard.html.erb @@ -1,179 +1,182 @@ +<%# Copyright (C) The Arvados Authors. All rights reserved. -
-
-
-
Active pipelines - - <%= link_to( - choose_pipeline_templates_path( - title: 'Choose a pipeline to run:', - action_name: 'Next: choose inputs ', - action_href: pipeline_instances_path, - action_method: 'post', - action_data: {'selection_param' => 'pipeline_instance[pipeline_template_uuid]', 'pipeline_instance[owner_uuid]' => current_user.uuid, 'success' => 'redirect-to-created-object'}.to_json), - { class: "btn btn-primary btn-xs", remote: true, method: 'get' }) do %> - Run a pipeline... - <% end %> - -
+SPDX-License-Identifier: AGPL-3.0 %> - <% _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)) %> +<% + recent_procs = recent_processes(12) -
- <% 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} %> - -
-
- <% running = [] %> - <% failed = [] %> - <% completed = [] %> - <% queued = [] %> - <% p.components.each do |k, v| %> - <% if v.is_a? Hash and v[:job] %> - <% if v[:job][:state] == "Running" %> - <% running << k %> - <% elsif v[:job][:state] == "Failed" or v[:job][:state] == "Cancelled" %> - <% failed << k %> - <% elsif v[:job][:state] == "Complete" %> - <% completed << k %> - <% elsif v[:job][:state] == "Queued" %> - <% queued << k %> - <% end %> - <% end %> - <% end %> - <% completed_pct = (completed.size * 100) / p.components.size %> - <% failed_pct = (failed.size * 100) / p.components.size %> - <% running_pct = (running.size * 100) / p.components.size %> - <% queued_pct = (queued.size * 100) / p.components.size %> - -
- -
-
- -
-
- -
-
- -
-
-
-
+ # 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? -
- 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) %>. + # fetch children of all the active crs in one call, if there are any + active_crs = recent_crs.each {|cr| cr if (cr.priority.andand > 0 and cr.state != 'Final' and cr.container_uuid)} -
- <% running.each do |k| %> - <%= k %> - <% end %> - <% queued.each do |k| %> - <%= k %> + 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.show_recent_collections_on_dashboard + 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?(: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%> + <% 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| %> + <% 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%> +
+
+ +
+ 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) %>. + +
+ <% 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 Rails.configuration.show_recent_collections_on_dashboard %>
Recent collections @@ -183,20 +186,20 @@
- <% 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 %>/ - <%= render_localized_date(p[:modified_at], "noseconds") %> -
-
<%= link_to_if_arvados_object p, {friendly_name: true, no_tags: 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} %> +
<% end %>
+ <% end %>
- -