X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/07a3aa9651168756a6f108821f6ef10ea4ba8144..58be2f1c488248d11dfb2ad730b6a8d56e557e63:/apps/workbench/app/assets/javascripts/pipeline_instances.js diff --git a/apps/workbench/app/assets/javascripts/pipeline_instances.js b/apps/workbench/app/assets/javascripts/pipeline_instances.js index 3c949f4e83..7570b2f8a5 100644 --- a/apps/workbench/app/assets/javascripts/pipeline_instances.js +++ b/apps/workbench/app/assets/javascripts/pipeline_instances.js @@ -1,6 +1,10 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// SPDX-License-Identifier: AGPL-3.0 + function run_pipeline_button_state() { - var a = $('a.editable.required.editable-empty,input.form-control.required[value=]'); - if (a.length > 0) { + var a = $('a.editable.required.editable-empty,input.form-control.required[value=""]'); + if ((a.length > 0) || ($('.unreadable-inputs-present').length)) { $(".run-pipeline-button").addClass("disabled"); } else { @@ -44,76 +48,77 @@ $(document).on('ready ajax:complete', function() { $tag.parent().prev().css("background-color", ""); } }); + $('input.required').each(function() { + var $tag = $(this); + if ($tag.hasClass("unreadable-input")) { + $tag.parent().parent().css("background-color", "#ffdddd"); + $tag.parent().parent().prev().css("background-color", "#ffdddd"); + } + else { + $tag.parent().parent().css("background-color", ""); + $tag.parent().parent().prev().css("background-color", ""); + } + }); run_pipeline_button_state(); }); -$(document).on('arv-log-event', '.arv-log-event-handler-append-logs', function(event, eventData){ - var wasatbottom = ($(this).scrollTop() + $(this).height() >= - this.scrollHeight); - var parsedData = JSON.parse(eventData); - var propertyText = undefined; - var properties = parsedData.properties; - - if (properties !== null) { - propertyText = properties.text; +$(document).on('arv-log-event', '.arv-refresh-on-state-change', function(event, eventData) { + if (this != event.target) { + // Not interested in events sent to child nodes. + return; } - if (propertyText !== undefined) { - propertyText = propertyText. - replace(/\n$/, ''). - replace(/\n/g, '
'); - $(this).append(propertyText + "
"); - } else if (parsedData.summary !== undefined) { - if (parsedData.summary.match(/^update of [-a-z0-9]{27}$/)) - ; // Not helpful. - else - $(this).append(parsedData.summary + "
"); + if (eventData.event_type == "update" && + eventData.properties.old_attributes.state != eventData.properties.new_attributes.state) + { + $(event.target).trigger('arv:pane:reload'); } - if (wasatbottom) - this.scrollTop = this.scrollHeight; -}).on('arv:pane:loaded', '#Logs,#Log', function(){ - $('.arv-log-event-handler-append-logs', this).each(function() { - this.scrollTop = this.scrollHeight; - $(this).closest('.tab-pane').on('arv:pane:reload', function(e) { - // Do not let this tab auto-refresh. - e.stopPropagation(); - }); - }); -}).on('ready ajax:complete', function(){ - $(".arv-log-event-listener[data-object-uuids-live]").each(function() { - // Look at data-object-uuid attribute of elements matching - // given selector, so the event listener can listen for events - // that appeared on the page via ajax. - var $listener = $(this); - var have_uuids = '' + $listener.attr('data-object-uuids'); - $($listener.attr('data-object-uuids-live')).each(function() { - var this_uuid = $(this).attr('data-object-uuid'); - if (have_uuids.indexOf(this_uuid) == -1) { - have_uuids = have_uuids + ' ' + this_uuid; - } - }); - $listener.attr('data-object-uuids', have_uuids); - }); }); -var showhide_compare = function() { - var form = $('form#compare')[0]; - $('input[type=hidden][name="uuids[]"]', form).remove(); - $('input[type=submit]', form).prop('disabled',true).show(); - var checked_inputs = $('[data-object-uuid*=-d1hrv-] input[name="uuids[]"]:checked'); - if (checked_inputs.length >= 2 && checked_inputs.length <= 3) { - checked_inputs.each(function(){ - if(this.checked) { - $('input[type=submit]', form).prop('disabled',false).show(); - $(form).append($('').val(this.value)); - } - }); +$(document).on('arv-log-event', '.arv-log-event-subscribe-to-pipeline-job-uuids', function(event, eventData){ + if (this != event.target) { + // Not interested in events sent to child nodes. + return; } -}; -$('[data-object-uuid*=-d1hrv-] input[name="uuids[]"]').on('click', showhide_compare); -showhide_compare(); - -setInterval(function(){ - if ($('[data-pipeline-state=RunningOnServer],[data-pipeline-state=RunningOnClient]').length > 0) { - $('#Components-tab,#Graph-tab,#pipeline-instance-tab-buttons').trigger('arv:pane:reload'); + if (!((eventData.object_kind == 'arvados#pipelineInstance') && + (eventData.event_type == "create" || + eventData.event_type == "update") && + eventData.properties && + eventData.properties.new_attributes && + eventData.properties.new_attributes.components)) { + return; + } + var objs = ""; + var components = eventData.properties.new_attributes.components; + for (a in components) { + if (components[a].job && components[a].job.uuid) { + objs += " " + components[a].job.uuid; + } } -}, 15000); + $(event.target).attr("data-object-uuids", eventData.object_uuid + objs); +}); + +$(document).on('ready ajax:success', function() { + $('.arv-log-refresh-control').each(function() { + var uuids = $(this).attr('data-object-uuids'); + var $pane = $(this).closest('[data-pane-content-url]'); + $pane.attr('data-object-uuids', uuids); + }); +}); + +// Set up all events for the pipeline instances compare button. +(function() { + var compare_form = '#compare'; + var compare_inputs = '#comparedInstances :checkbox[name="uuids[]"]'; + var update_button = function(event) { + var $form = $(compare_form); + var $checked_inputs = $(compare_inputs).filter(':checked'); + $(':submit', $form).prop('disabled', (($checked_inputs.length < 2) || + ($checked_inputs.length > 3))); + $('input[name="uuids[]"]', $form).remove(); + $form.append($checked_inputs.clone() + .removeAttr('id').attr('type', 'hidden')); + }; + $(document) + .on('ready ajax:success', compare_form, update_button) + .on('change', compare_inputs, update_button); +})();