X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/4a3301617ae09e6b28c7b6fd79923ccd60b6b5e9..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 4b17b4eeb8..fa9d6ae5a4 100644 --- a/apps/workbench/app/assets/javascripts/pipeline_instances.js +++ b/apps/workbench/app/assets/javascripts/pipeline_instances.js @@ -1,5 +1,5 @@ function run_pipeline_button_state() { - var a = $('a.editable.required.editable-empty'); + var a = $('a.editable.required.editable-empty,input.form-control.required[value=]'); if (a.length > 0) { $(".run-pipeline-button").addClass("disabled"); } @@ -47,36 +47,63 @@ $(document).on('ready ajax:complete', function() { run_pipeline_button_state(); }); -$(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('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'); + } +}); + +$(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; + } + } + $(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); }); - } }); $(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; + if (this != event.target) { + // Not interested in events sent to child nodes. + return; } - if (propertyText !== undefined) { - $(this).append(propertyText + "
"); - } else { - $(this).append(parsedData.summary + "
"); + var wasatbottom = ($(this).scrollTop() + $(this).height() >= this.scrollHeight); + + if (eventData.event_type == "stderr" || eventData.event_type == "stdout") { + $(this).append(eventData.properties.text); } - if (wasatbottom) - this.scrollTop = this.scrollHeight; -}).on('ready ajax:complete', function(){ - $('.arv-log-event-handler-append-logs').each(function() { + + if (wasatbottom) { this.scrollTop = this.scrollHeight; - }); + } }); var showhide_compare = function() { @@ -93,5 +120,9 @@ var showhide_compare = function() { }); } }; -$('[data-object-uuid*=-d1hrv-] input[name="uuids[]"]').on('click', showhide_compare); -showhide_compare(); +$(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);