<% if !@object.state.in? ['New', 'Ready'] %> <% pipeline_job_uuids = [] %>
Current state: <%= @object.state.sub('OnServer', '') %> 
<% render_pipeline_jobs.each do |pj| %> <% if pj[:job].andand[:uuid] pipeline_job_uuids << pj[:job][:uuid] end %> <% current_job = Job.find(pj[:job][:uuid]) rescue nil %> <% end %>
component job <%# format:'js' here helps browsers avoid using the cached js content in html context (e.g., duplicate tab -> see javascript) %> <%= link_to '(refresh)', {format: :js}, {class: 'refresh hide', remote: true, method: 'get'} %>
<%= pj[:name] %> <%= pj[:script] %>
<%= pj[:script_version] %>
<%= render(partial: 'job_status_label', locals: { j: pj[:job] }) %> <%= pj[:progress_bar] %> <% if current_job %> <%= render partial: 'show_object_button', locals: {object: current_job, size: 'xs', link_text: 'Show job details'} %> <% end %> <% if current_job.andand[:log] %> <% fixup = /([a-f0-9]{32}\+\d+)(\+?.*)/.match(current_job[:log])%> <% Collection.limit(1).where(uuid: fixup[1]).each do |c| %> <% c.files.first.andand do |file| %> <%= link_to url_for(controller: 'collections', action: 'show_file', uuid: current_job[:log], file: "#{file[0]}/#{file[1]}", disposition: 'inline', size: file[2]), class: 'btn btn-default btn-xs' do %> Show log messages <% end %> <% end %> <% end %> <% end %> <% if current_job.andand[:output] %> <%= link_to_if_arvados_object current_job[:output], {thumbnail: true, link_text: raw(' Show output files')}, {class: 'btn btn-default btn-xs'} %> <% end %>
<% if @object.state.in? %w(RunningOnServer RunningOnClient Failed) %>

Log messages from jobs

<% log_history = pipeline_log_history((pipeline_job_uuids || []) + [@object.uuid]) %>
"> <% log_history.each do |entry| %> <%=entry%>
<% end %>
<% end %> <% else %> <%# state is either New or Ready %> <% if @object.state.in? %w(New Ready) %>

Here are all of the pipeline's components (jobs that will need to run in order to complete the pipeline). If you know what you're doing (or you're experimenting) you can modify these parameters before starting the pipeline. Usually, you only need to edit the settings presented on the "Inputs" tab above.

<% end %> <% if @object.state.in? ['New', 'Ready'] %> <%= render partial: 'show_components_editable', locals: {editable: true} %> <% else %> <%= render partial: 'show_components_editable', locals: {editable: false} %> <% end %> <% end %>