X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/4d1e1b22d470d2fec9078c64c058c69850e440d6..6c7bfabc03237419decad9674c90ea7af906b615:/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 4678022f1c..fa9d6ae5a4 100644 --- a/apps/workbench/app/assets/javascripts/pipeline_instances.js +++ b/apps/workbench/app/assets/javascripts/pipeline_instances.js @@ -1,73 +1,128 @@ -(function() { - var run_pipeline_button_state = function() { - var a = $('a.editable.required.editable-empty'); - if (a.length > 0) { - $("#run-pipeline-button").addClass("disabled"); +function run_pipeline_button_state() { + var a = $('a.editable.required.editable-empty,input.form-control.required[value=]'); + if (a.length > 0) { + $(".run-pipeline-button").addClass("disabled"); + } + else { + $(".run-pipeline-button").removeClass("disabled"); + } +} + +$(document).on('editable:success', function(event, tag, response, newValue) { + var $tag = $(tag); + if ($('.run-pipeline-button').length == 0) + return; + if ($tag.hasClass("required")) { + if (newValue && newValue.trim() != "") { + $tag.removeClass("editable-empty"); + $tag.parent().css("background-color", ""); + $tag.parent().prev().css("background-color", ""); } else { - $("#run-pipeline-button").removeClass("disabled"); + $tag.addClass("editable-empty"); + $tag.parent().css("background-color", "#ffdddd"); + $tag.parent().prev().css("background-color", "#ffdddd"); } } + if ($tag.attr('data-name')) { + // Update other inputs representing the same piece of data + $('.editable[data-name="' + $tag.attr('data-name') + '"]'). + editable('setValue', newValue); + } + run_pipeline_button_state(); +}); - $.fn.editable.defaults.success = function (response, newValue) { - var tag = $(this); - if (tag.hasClass("required")) { - if (newValue && newValue.trim() != "") { - tag.removeClass("editable-empty"); - tag.parent().css("background-color", ""); - tag.parent().prev().css("background-color", ""); - } - else { - tag.addClass("editable-empty"); - tag.parent().css("background-color", "#ffdddd"); - tag.parent().prev().css("background-color", "#ffdddd"); - } +$(document).on('ready ajax:complete', function() { + $('a.editable.required').each(function() { + var $tag = $(this); + if ($tag.hasClass("editable-empty")) { + $tag.parent().css("background-color", "#ffdddd"); + $tag.parent().prev().css("background-color", "#ffdddd"); + } + else { + $tag.parent().css("background-color", ""); + $tag.parent().prev().css("background-color", ""); } - run_pipeline_button_state(); + }); + run_pipeline_button_state(); +}); + +$(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 (eventData.event_type == "update" && + eventData.properties.old_attributes.state != eventData.properties.new_attributes.state) + { + $(event.target).trigger('arv:pane:reload'); } +}); - $(window).on('load', function() { - var a = $('a.editable.required'); - for (var i = 0; i < a.length; i++) { - var tag = $(a[i]); - if (tag.hasClass("editable-empty")) { - tag.parent().css("background-color", "#ffdddd"); - tag.parent().prev().css("background-color", "#ffdddd"); - } - else { - tag.parent().css("background-color", ""); - tag.parent().prev().css("background-color", ""); - } +$(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; + } + 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; } - run_pipeline_button_state(); - } ); + } + $(event.target).attr("data-object-uuids", eventData.object_uuid + objs); +}); - $(document).on('ajax:complete ready', function() { - var a = $('.arv-log-event-listener'); - if (a.length > 0) { - $('.arv-log-event-listener').each(function() { - subscribeToEventLog(this.id); - }); - } +$(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); }); +}); - $(document).on('arv-log-event', '.arv-log-event-handler-append-logs', function(event, eventData){ - parsedData = JSON.parse(eventData); - summary = parsedData.summary; - properties = parsedData.properties; - updatedProperties = null; - if (properties !== null) { - new_attributes = properties.new_attributes; - if (new_attributes !== null) { - updatedProperties = JSON.stringify(properties.new_attributes); - } - } +$(document).on('arv-log-event', '.arv-log-event-handler-append-logs', function(event, eventData){ + if (this != event.target) { + // Not interested in events sent to child nodes. + return; + } + var wasatbottom = ($(this).scrollTop() + $(this).height() >= this.scrollHeight); - if (updatedProperties !== null) { - $(this).append(updatedProperties + "

"); - } else { - $(this).append(summary + "

"); - } - }); + if (eventData.event_type == "stderr" || eventData.event_type == "stdout") { + $(this).append(eventData.properties.text); + } -})(); + if (wasatbottom) { + this.scrollTop = this.scrollHeight; + } +}); + +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('change', '[data-object-uuid*=-d1hrv-] input[name="uuids[]"]', function(e) { + if(e.target == this) { + showhide_compare(); + } +}); +$(document).on('ready ajax:success', showhide_compare);