3 new commits in galaxy-central:
https://bitbucket.org/galaxy/galaxy-central/commits/2248c4d82151/
Changeset: 2248c4d82151
Branch: stable
User: jmchilton
Date: 2015-02-05 17:14:01+00:00
Summary: Workflow scheduling delay fix.
There were problems if all three of these conditions were met - 1) workflow from GUI, 2) workflow evaluation delayed, and 3) a delayed step was connected to a input dataset. This fixes these workflows.
Affected #: 3 files
diff -r 097bbb3b7d3246faaa5188a1fc2a79b01630025c -r 2248c4d82151c928a7615f9335b55aa0c55c9446 lib/galaxy/model/__init__.py
--- a/lib/galaxy/model/__init__.py
+++ b/lib/galaxy/model/__init__.py
@@ -3202,6 +3202,27 @@
def update( self ):
self.update_time = galaxy.model.orm.now.now()
+ def add_input( self, content, step_id ):
+ if content.history_content_type == "dataset":
+ request_to_content = WorkflowRequestToInputDatasetAssociation()
+ request_to_content.dataset = content
+ request_to_content.workflow_step_id = step_id
+ self.input_datasets.append( request_to_content )
+ else:
+ request_to_content = WorkflowRequestToInputDatasetCollectionAssociation()
+ request_to_content.dataset_collection = content
+ request_to_content.workflow_step_id = step_id
+ self.input_dataset_collections.append( request_to_content )
+
+ def has_input_for_step( self, step_id ):
+ for content in self.input_datasets:
+ if content.workflow_step_id == step_id:
+ return True
+ for content in self.input_dataset_collections:
+ if content.workflow_step_id == step_id:
+ return True
+ return False
+
class WorkflowInvocationStep( object, Dictifiable ):
dict_collection_visible_keys = ( 'id', 'update_time', 'job_id', 'workflow_step_id', 'action' )
diff -r 097bbb3b7d3246faaa5188a1fc2a79b01630025c -r 2248c4d82151c928a7615f9335b55aa0c55c9446 lib/galaxy/workflow/modules.py
--- a/lib/galaxy/workflow/modules.py
+++ b/lib/galaxy/workflow/modules.py
@@ -320,6 +320,11 @@
step_outputs[ 'input_ds_copy' ] = new_hdca
else:
raise Exception("Unknown history content encountered")
+ # If coming from UI - we haven't registered invocation inputs yet,
+ # so do that now so dependent steps can be recalculated. In the future
+ # everything should come in from the API and this can be eliminated.
+ if not invocation.has_input_for_step( step.id ):
+ invocation.add_input( step_outputs.values()[ 0 ], step.id )
progress.set_outputs_for_input( step, step_outputs )
return job
diff -r 097bbb3b7d3246faaa5188a1fc2a79b01630025c -r 2248c4d82151c928a7615f9335b55aa0c55c9446 lib/galaxy/workflow/run_request.py
--- a/lib/galaxy/workflow/run_request.py
+++ b/lib/galaxy/workflow/run_request.py
@@ -284,18 +284,8 @@
value=value,
type=param_types.REPLACEMENT_PARAMETERS,
)
-
for step_id, content in run_config.inputs.iteritems():
- if content.history_content_type == "dataset":
- request_to_content = model.WorkflowRequestToInputDatasetAssociation()
- request_to_content.dataset = content
- request_to_content.workflow_step_id = step_id
- workflow_invocation.input_datasets.append( request_to_content )
- else:
- request_to_content = model.WorkflowRequestToInputDatasetCollectionAssociation()
- request_to_content.dataset_collection = content
- request_to_content.workflow_step_id = step_id
- workflow_invocation.input_dataset_collections.append( request_to_content )
+ workflow_invocation.add_input( content, step_id )
for step in workflow.steps:
state = step.state
https://bitbucket.org/galaxy/galaxy-central/commits/e07163fe8bdb/
Changeset: e07163fe8bdb
Branch: stable
User: jmchilton
Date: 2015-02-05 17:14:01+00:00
Summary: Fix scheduling_manager.py for unknown attribute reference.
Not sure if this was a poor rebasing or a copy and paste error.
Affected #: 1 file
diff -r 2248c4d82151c928a7615f9335b55aa0c55c9446 -r e07163fe8bdbc3e85f48b308ed293c46578b3294 lib/galaxy/workflow/scheduling_manager.py
--- a/lib/galaxy/workflow/scheduling_manager.py
+++ b/lib/galaxy/workflow/scheduling_manager.py
@@ -116,7 +116,6 @@
for plugin_element in plugins_element.getchildren():
plugin_type = plugin_element.tag
plugin_kwds = dict( plugin_element.items() )
- plugin_kwds.update( self.extra_kwargs )
workflow_scheduler_id = plugin_kwds.get( 'id', None )
self.__init_plugin( plugin_type, workflow_scheduler_id, **plugin_kwds )
https://bitbucket.org/galaxy/galaxy-central/commits/644deef1a578/
Changeset: 644deef1a578
Branch: stable
User: jmchilton
Date: 2015-02-05 18:33:59+00:00
Summary: Bugfix for bugfix d3b1f6b.
d3b1f6b fix the GUI (in an obsecure use) but broke fairly typical uses of the API.
Affected #: 1 file
diff -r e07163fe8bdbc3e85f48b308ed293c46578b3294 -r 644deef1a5789b788552a6db7f3d6fe07d81c79d lib/galaxy/workflow/modules.py
--- a/lib/galaxy/workflow/modules.py
+++ b/lib/galaxy/workflow/modules.py
@@ -324,7 +324,9 @@
# so do that now so dependent steps can be recalculated. In the future
# everything should come in from the API and this can be eliminated.
if not invocation.has_input_for_step( step.id ):
- invocation.add_input( step_outputs.values()[ 0 ], step.id )
+ content = step_outputs.values()[ 0 ]
+ if content:
+ invocation.add_input( content, step.id )
progress.set_outputs_for_input( step, step_outputs )
return job
Repository URL: https://bitbucket.org/galaxy/galaxy-central/
--
This is a commit notification from bitbucket.org. You are receiving
this because you have the service enabled, addressing the recipient of
this email.
1 new commit in galaxy-central:
https://bitbucket.org/galaxy/galaxy-central/commits/494418e72cf0/
Changeset: 494418e72cf0
User: guerler
Date: 2015-02-05 18:34:51+00:00
Summary: ToolForm: Update version selection, use underscores for internal parameters
Affected #: 12 files
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 client/galaxy/scripts/mvc/tools/tools-form-base.js
--- a/client/galaxy/scripts/mvc/tools/tools-form-base.js
+++ b/client/galaxy/scripts/mvc/tools/tools-form-base.js
@@ -15,12 +15,10 @@
this.optionsDefault = {
// uses dynamic fields instead of text fields
is_dynamic : true,
- // shows form in compact view mode
- compact : false,
+ // shows form in narrow view mode
+ narrow : false,
// shows errors on start
- initial_errors : false,
- // use default value for disabled fields
- use_defaults : false
+ initial_errors : false
};
// configure options
@@ -58,9 +56,66 @@
$(this.container).append(this.$el);
// build this form
- this._buildForm();
+ this.build(this.options);
},
+ /** Main tool form build function. This function is called once a new model is available.
+ */
+ build: function(options) {
+ // link this
+ var self = this;
+
+ // reset events
+ this.off('refresh');
+ this.off('reset');
+
+ // reset field list, which contains the input field elements
+ this.field_list = {};
+
+ // reset sequential input definition list, which contains the input definitions as provided from the api
+ this.input_list = {};
+
+ // reset input element list, which contains the dom elements of each input element (includes also the input field)
+ this.element_list = {};
+
+ // creates a tree/json data structure from the input form
+ this.tree = new ToolTree(this);
+
+ // request history content and build form
+ this.content = new ToolContent(this);
+
+ // update model data
+ self.options.inputs = options && options.inputs;
+
+ // create ui elements
+ this._renderForm(options);
+
+ // rebuild the underlying data structure
+ this.tree.finalize();
+
+ // show errors on startup
+ if (options.initial_errors) {
+ this._errors(options);
+ }
+
+ // add refresh listener
+ this.on('refresh', function() {
+ // by using/resetting the deferred ajax queue the number of redundant calls is reduced
+ self.deferred.reset();
+ self.deferred.execute(function(){self._updateModel()});
+ });
+
+ // add reset listener
+ this.on('reset', function() {
+ for (var i in this.element_list) {
+ this.element_list[i].reset();
+ }
+ });
+
+ // refresh
+ this.trigger('refresh');
+ },
+
/** Shows the final message (usually upon successful job submission)
*/
reciept: function($el) {
@@ -105,63 +160,6 @@
}
}
},
-
- /** Main tool form build function. This function is called once a new model is available.
- */
- _buildForm: function() {
- // link this
- var self = this;
-
- // reset events
- this.off('refresh');
- this.off('reset');
-
- // reset field list, which contains the input field elements
- this.field_list = {};
-
- // reset sequential input definition list, which contains the input definitions as provided from the api
- this.input_list = {};
-
- // reset input element list, which contains the dom elements of each input element (includes also the input field)
- this.element_list = {};
-
- // creates a tree/json data structure from the input form
- this.tree = new ToolTree(this);
-
- // request history content and build form
- this.content = new ToolContent(this);
-
- // link model options
- var options = this.options;
-
- // create ui elements
- this._renderForm(options);
-
- // rebuild the underlying data structure
- this.tree.finalize();
-
- // show errors on startup
- if (options.initial_errors) {
- this._errors(options);
- }
-
- // add refresh listener
- this.on('refresh', function() {
- // by using/resetting the deferred ajax queue the number of redundant calls is reduced
- self.deferred.reset();
- self.deferred.execute(function(){self._updateModel()});
- });
-
- // add reset listener
- this.on('reset', function() {
- for (var i in this.element_list) {
- this.element_list[i].reset();
- }
- });
-
- // refresh
- this.trigger('refresh');
- },
/** Renders the UI elements required for the form
*/
@@ -175,7 +173,7 @@
// button for version selection
var requirements_button = new Ui.ButtonIcon({
icon : 'fa-info-circle',
- title : (!options.compact && 'Requirements') || null,
+ title : (!options.narrow && 'Requirements') || null,
tooltip : 'Display tool requirements',
onclick : function() {
if (!this.visible) {
@@ -200,7 +198,7 @@
// button for version selection
var versions_button = new Ui.ButtonMenu({
icon : 'fa-cubes',
- title : (!options.compact && 'Versions') || null,
+ title : (!options.narrow && 'Versions') || null,
tooltip : 'Select another tool version'
});
if (options.versions && options.versions.length > 1) {
@@ -213,8 +211,8 @@
icon : 'fa-cube',
onclick : function() {
// here we update the tool version (some tools encode the version also in the id)
- options.id = options.id.replace(options.version, this.version);
- options.version = this.version;
+ self.options.id = self.options.id.replace(self.options.version, this.version);
+ self.options.version = this.version;
// rebuild the model and form
self.deferred.reset();
@@ -230,7 +228,7 @@
// button menu
var menu_button = new Ui.ButtonMenu({
icon : 'fa-caret-down',
- title : (!options.compact && 'Options') || null,
+ title : (!options.narrow && 'Options') || null,
tooltip : 'View available options'
});
@@ -306,7 +304,7 @@
});
// remove padding
- if (options.compact) {
+ if (options.narrow) {
this.portlet.$content.css('padding', '0px');
}
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 client/galaxy/scripts/mvc/tools/tools-form-workflow.js
--- a/client/galaxy/scripts/mvc/tools/tools-form-workflow.js
+++ b/client/galaxy/scripts/mvc/tools/tools-form-workflow.js
@@ -21,9 +21,13 @@
this.options = options;
// set labels
- this.options.text_enable = 'In Advance';
- this.options.text_disable = 'At Runtime';
- this.options.use_defaults = true;
+ this.options.text_enable = 'In Advance';
+ this.options.text_disable = 'At Runtime';
+
+ // configure workflow style
+ this.options.is_dynamic = false;
+ this.options.narrow = true;
+ this.options.initial_errors = true;
// declare fields as optional
Utils.deepeach(options.inputs, function(item) {
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 client/galaxy/scripts/mvc/tools/tools-form.js
--- a/client/galaxy/scripts/mvc/tools/tools-form.js
+++ b/client/galaxy/scripts/mvc/tools/tools-form.js
@@ -24,7 +24,7 @@
}
ToolFormBase.prototype.initialize.call(this, options);
},
-
+
/** Builds a new model through api call and recreates the entire form
*/
_buildModel: function() {
@@ -47,31 +47,28 @@
}
}
}
-
+
// register process
var process_id = this.deferred.register();
-
+
// get initial model
Utils.request({
type : 'GET',
url : model_url,
success : function(response) {
- // link model data update options
- self.options = response;
-
- // build form
- self._buildForm();
-
+ // build new tool form
+ self.build(response);
+
// notification
self.message.update({
status : 'success',
message : 'Now you are using \'' + self.options.name + '\' version ' + self.options.version + '.',
persistent : false
});
-
+
// process completed
self.deferred.done(process_id);
-
+
// log success
console.debug('tools-form::initialize() - Initial tool model ready.');
console.debug(response);
@@ -79,11 +76,11 @@
error : function(response) {
// process completed
self.deferred.done(process_id);
-
+
// log error
console.debug('tools-form::initialize() - Initial tool model request failed.');
console.debug(response);
-
+
// show error
var error_message = response.error || 'Uncaught error.';
self.modal.show({
@@ -98,7 +95,7 @@
}
});
},
-
+
/** Request a new model for an already created tool form and updates the form inputs
*/
_updateModel: function() {
@@ -112,11 +109,11 @@
return null;
}
});
-
+
// log tool state
console.debug('tools-form::_refreshForm() - Refreshing states.');
console.debug(current_state);
-
+
// activates/disables spinner for dynamic fields to indicate that they are currently being updated
function wait(active) {
for (var i in self.input_list) {
@@ -131,10 +128,10 @@
}
}
}
-
+
// set wait mode
wait(true);
-
+
// register process
var process_id = this.deferred.register();
@@ -179,13 +176,13 @@
}
}
});
-
+
// unset wait mode
wait(false);
-
+
// process completed
self.deferred.done(process_id);
-
+
// log success
console.debug('tools-form::_refreshForm() - States refreshed.');
console.debug(new_model);
@@ -193,7 +190,7 @@
error : function(response) {
// process completed
self.deferred.done(process_id);
-
+
// log error
console.debug('tools-form::_refreshForm() - Refresh request failed.');
console.debug(response);
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 lib/galaxy/tools/__init__.py
--- a/lib/galaxy/tools/__init__.py
+++ b/lib/galaxy/tools/__init__.py
@@ -2254,8 +2254,8 @@
"""
Recursively creates a tool dictionary containing repeats, dynamic options and updated states.
"""
- job_id = kwd.get('job_id', None)
- dataset_id = kwd.get('dataset_id', None)
+ job_id = kwd.get('__job_id__', None)
+ dataset_id = kwd.get('__dataset_id__', None)
is_dynamic = string_as_bool(kwd.get('__is_dynamic__', True))
# load job details if provided
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/mvc/tools/tools-form-base.js
--- a/static/scripts/mvc/tools/tools-form-base.js
+++ b/static/scripts/mvc/tools/tools-form-base.js
@@ -15,12 +15,10 @@
this.optionsDefault = {
// uses dynamic fields instead of text fields
is_dynamic : true,
- // shows form in compact view mode
- compact : false,
+ // shows form in narrow view mode
+ narrow : false,
// shows errors on start
- initial_errors : false,
- // use default value for disabled fields
- use_defaults : false
+ initial_errors : false
};
// configure options
@@ -58,9 +56,66 @@
$(this.container).append(this.$el);
// build this form
- this._buildForm();
+ this.build(this.options);
},
+ /** Main tool form build function. This function is called once a new model is available.
+ */
+ build: function(options) {
+ // link this
+ var self = this;
+
+ // reset events
+ this.off('refresh');
+ this.off('reset');
+
+ // reset field list, which contains the input field elements
+ this.field_list = {};
+
+ // reset sequential input definition list, which contains the input definitions as provided from the api
+ this.input_list = {};
+
+ // reset input element list, which contains the dom elements of each input element (includes also the input field)
+ this.element_list = {};
+
+ // creates a tree/json data structure from the input form
+ this.tree = new ToolTree(this);
+
+ // request history content and build form
+ this.content = new ToolContent(this);
+
+ // update model data
+ self.options.inputs = options && options.inputs;
+
+ // create ui elements
+ this._renderForm(options);
+
+ // rebuild the underlying data structure
+ this.tree.finalize();
+
+ // show errors on startup
+ if (options.initial_errors) {
+ this._errors(options);
+ }
+
+ // add refresh listener
+ this.on('refresh', function() {
+ // by using/resetting the deferred ajax queue the number of redundant calls is reduced
+ self.deferred.reset();
+ self.deferred.execute(function(){self._updateModel()});
+ });
+
+ // add reset listener
+ this.on('reset', function() {
+ for (var i in this.element_list) {
+ this.element_list[i].reset();
+ }
+ });
+
+ // refresh
+ this.trigger('refresh');
+ },
+
/** Shows the final message (usually upon successful job submission)
*/
reciept: function($el) {
@@ -105,63 +160,6 @@
}
}
},
-
- /** Main tool form build function. This function is called once a new model is available.
- */
- _buildForm: function() {
- // link this
- var self = this;
-
- // reset events
- this.off('refresh');
- this.off('reset');
-
- // reset field list, which contains the input field elements
- this.field_list = {};
-
- // reset sequential input definition list, which contains the input definitions as provided from the api
- this.input_list = {};
-
- // reset input element list, which contains the dom elements of each input element (includes also the input field)
- this.element_list = {};
-
- // creates a tree/json data structure from the input form
- this.tree = new ToolTree(this);
-
- // request history content and build form
- this.content = new ToolContent(this);
-
- // link model options
- var options = this.options;
-
- // create ui elements
- this._renderForm(options);
-
- // rebuild the underlying data structure
- this.tree.finalize();
-
- // show errors on startup
- if (options.initial_errors) {
- this._errors(options);
- }
-
- // add refresh listener
- this.on('refresh', function() {
- // by using/resetting the deferred ajax queue the number of redundant calls is reduced
- self.deferred.reset();
- self.deferred.execute(function(){self._updateModel()});
- });
-
- // add reset listener
- this.on('reset', function() {
- for (var i in this.element_list) {
- this.element_list[i].reset();
- }
- });
-
- // refresh
- this.trigger('refresh');
- },
/** Renders the UI elements required for the form
*/
@@ -175,7 +173,7 @@
// button for version selection
var requirements_button = new Ui.ButtonIcon({
icon : 'fa-info-circle',
- title : (!options.compact && 'Requirements') || null,
+ title : (!options.narrow && 'Requirements') || null,
tooltip : 'Display tool requirements',
onclick : function() {
if (!this.visible) {
@@ -200,7 +198,7 @@
// button for version selection
var versions_button = new Ui.ButtonMenu({
icon : 'fa-cubes',
- title : (!options.compact && 'Versions') || null,
+ title : (!options.narrow && 'Versions') || null,
tooltip : 'Select another tool version'
});
if (options.versions && options.versions.length > 1) {
@@ -213,8 +211,8 @@
icon : 'fa-cube',
onclick : function() {
// here we update the tool version (some tools encode the version also in the id)
- options.id = options.id.replace(options.version, this.version);
- options.version = this.version;
+ self.options.id = self.options.id.replace(self.options.version, this.version);
+ self.options.version = this.version;
// rebuild the model and form
self.deferred.reset();
@@ -230,7 +228,7 @@
// button menu
var menu_button = new Ui.ButtonMenu({
icon : 'fa-caret-down',
- title : (!options.compact && 'Options') || null,
+ title : (!options.narrow && 'Options') || null,
tooltip : 'View available options'
});
@@ -306,7 +304,7 @@
});
// remove padding
- if (options.compact) {
+ if (options.narrow) {
this.portlet.$content.css('padding', '0px');
}
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/mvc/tools/tools-form-workflow.js
--- a/static/scripts/mvc/tools/tools-form-workflow.js
+++ b/static/scripts/mvc/tools/tools-form-workflow.js
@@ -21,9 +21,13 @@
this.options = options;
// set labels
- this.options.text_enable = 'In Advance';
- this.options.text_disable = 'At Runtime';
- this.options.use_defaults = true;
+ this.options.text_enable = 'In Advance';
+ this.options.text_disable = 'At Runtime';
+
+ // configure workflow style
+ this.options.is_dynamic = false;
+ this.options.narrow = true;
+ this.options.initial_errors = true;
// declare fields as optional
Utils.deepeach(options.inputs, function(item) {
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/mvc/tools/tools-form.js
--- a/static/scripts/mvc/tools/tools-form.js
+++ b/static/scripts/mvc/tools/tools-form.js
@@ -24,7 +24,7 @@
}
ToolFormBase.prototype.initialize.call(this, options);
},
-
+
/** Builds a new model through api call and recreates the entire form
*/
_buildModel: function() {
@@ -47,31 +47,28 @@
}
}
}
-
+
// register process
var process_id = this.deferred.register();
-
+
// get initial model
Utils.request({
type : 'GET',
url : model_url,
success : function(response) {
- // link model data update options
- self.options = response;
-
- // build form
- self._buildForm();
-
+ // build new tool form
+ self.build(response);
+
// notification
self.message.update({
status : 'success',
message : 'Now you are using \'' + self.options.name + '\' version ' + self.options.version + '.',
persistent : false
});
-
+
// process completed
self.deferred.done(process_id);
-
+
// log success
console.debug('tools-form::initialize() - Initial tool model ready.');
console.debug(response);
@@ -79,11 +76,11 @@
error : function(response) {
// process completed
self.deferred.done(process_id);
-
+
// log error
console.debug('tools-form::initialize() - Initial tool model request failed.');
console.debug(response);
-
+
// show error
var error_message = response.error || 'Uncaught error.';
self.modal.show({
@@ -98,7 +95,7 @@
}
});
},
-
+
/** Request a new model for an already created tool form and updates the form inputs
*/
_updateModel: function() {
@@ -112,11 +109,11 @@
return null;
}
});
-
+
// log tool state
console.debug('tools-form::_refreshForm() - Refreshing states.');
console.debug(current_state);
-
+
// activates/disables spinner for dynamic fields to indicate that they are currently being updated
function wait(active) {
for (var i in self.input_list) {
@@ -131,10 +128,10 @@
}
}
}
-
+
// set wait mode
wait(true);
-
+
// register process
var process_id = this.deferred.register();
@@ -179,13 +176,13 @@
}
}
});
-
+
// unset wait mode
wait(false);
-
+
// process completed
self.deferred.done(process_id);
-
+
// log success
console.debug('tools-form::_refreshForm() - States refreshed.');
console.debug(new_model);
@@ -193,7 +190,7 @@
error : function(response) {
// process completed
self.deferred.done(process_id);
-
+
// log error
console.debug('tools-form::_refreshForm() - Refresh request failed.');
console.debug(response);
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/packed/mvc/tools/tools-form-base.js
--- a/static/scripts/packed/mvc/tools/tools-form-base.js
+++ b/static/scripts/packed/mvc/tools/tools-form-base.js
@@ -1,1 +1,1 @@
-define(["utils/utils","utils/deferred","mvc/ui/ui-portlet","mvc/ui/ui-misc","mvc/citation/citation-model","mvc/citation/citation-view","mvc/tools","mvc/tools/tools-template","mvc/tools/tools-content","mvc/tools/tools-section","mvc/tools/tools-tree"],function(g,h,f,k,i,a,d,c,e,j,b){return Backbone.View.extend({initialize:function(l){this.optionsDefault={is_dynamic:true,compact:false,initial_errors:false,use_defaults:false};this.options=g.merge(l,this.optionsDefault);console.debug(this.options);var m=parent.Galaxy;if(m&&m.modal){this.modal=m.modal}else{this.modal=new k.Modal.View()}if(m&&m.currUser){this.is_admin=m.currUser.get("is_admin")}else{this.is_admin=false}this.container=this.options.container||"body";this.deferred=new h();this.setElement("<div/>");$(this.container).append(this.$el);this._buildForm()},reciept:function(l){$(this.container).empty();$(this.container).append(l)},highlight:function(m,n,l){var o=this.element_list[m];if(o){o.error(n||"Please verify this parameter.");if(!l){$(this.container).animate({scrollTop:o.$el.offset().top-20},500)}}},_errors:function(n){this.trigger("reset");if(n&&n.errors){var o=this.tree.matchResponse(n.errors);for(var m in this.element_list){var l=this.element_list[m];if(o[m]){this.highlight(m,o[m],true)}}}},_buildForm:function(){var l=this;this.off("refresh");this.off("reset");this.field_list={};this.input_list={};this.element_list={};this.tree=new b(this);this.content=new e(this);var m=this.options;this._renderForm(m);this.tree.finalize();if(m.initial_errors){this._errors(m)}this.on("refresh",function(){l.deferred.reset();l.deferred.execute(function(){l._updateModel()})});this.on("reset",function(){for(var n in this.element_list){this.element_list[n].reset()}});this.trigger("refresh")},_renderForm:function(u){var t=this;this.message=new k.Message();var q=new k.ButtonIcon({icon:"fa-info-circle",title:(!u.compact&&"Requirements")||null,tooltip:"Display tool requirements",onclick:function(){if(!this.visible){this.visible=true;t.message.update({persistent:true,message:c.requirements(u),status:"info"})}else{this.visible=false;t.message.update({message:""})}}});if(!u.requirements||u.requirements.length==0){q.$el.hide()}var m=new k.ButtonMenu({icon:"fa-cubes",title:(!u.compact&&"Versions")||null,tooltip:"Select another tool version"});if(u.versions&&u.versions.length>1){for(var o in u.versions){var r=u.versions[o];if(r!=u.version){m.addMenu({title:"Switch to "+r,version:r,icon:"fa-cube",onclick:function(){u.id=u.id.replace(u.version,this.version);u.version=this.version;t.deferred.reset();t.deferred.execute(function(){t._buildModel()})}})}}}else{m.$el.hide()}var p=new k.ButtonMenu({icon:"fa-caret-down",title:(!u.compact&&"Options")||null,tooltip:"View available options"});if(u.biostar_url){p.addMenu({icon:"fa-question-circle",title:"Question?",tooltip:"Ask a question about this tool (Biostar)",onclick:function(){window.open(u.biostar_url+"/p/new/post/")}});p.addMenu({icon:"fa-search",title:"Search",tooltip:"Search help for this tool (Biostar)",onclick:function(){window.open(u.biostar_url+"/t/"+u.id+"/")}})}p.addMenu({icon:"fa-share",title:"Share",tooltip:"Share this tool",onclick:function(){prompt("Copy to clipboard: Ctrl+C, Enter",window.location.origin+galaxy_config.root+"root?tool_id="+u.id)}});if(this.is_admin){p.addMenu({icon:"fa-download",title:"Download",tooltip:"Download this tool",onclick:function(){window.location.href=galaxy_config.root+"api/tools/"+u.id+"/download"}})}this.section=new j.View(t,{inputs:u.inputs});if(this.incompatible){this.$el.hide();$("#tool-form-classic").show();return}this.portlet=new f.View({icon:"fa-wrench",title:"<b>"+u.name+"</b> "+u.description+" (Galaxy Tool Version "+u.version+")",cls:"ui-portlet-slim",operations:{requirements:q,menu:p,versions:m},buttons:this.buttons});if(u.compact){this.portlet.$content.css("padding","0px")}this.portlet.append(this.message.$el,true);this.portlet.append(this.section.$el);this.$el.empty();this.$el.append(this.portlet.$el);if(u.help!=""){this.$el.append(c.help(u.help))}if(u.citations){var s=$("<div/>");var l=new i.ToolCitationCollection();l.tool_id=u.id;var n=new a.CitationListView({el:s,collection:l});n.render();l.fetch();this.$el.append(s)}if(u.message){this.message.update({persistent:true,status:"warning",message:u.message})}}})});
\ No newline at end of file
+define(["utils/utils","utils/deferred","mvc/ui/ui-portlet","mvc/ui/ui-misc","mvc/citation/citation-model","mvc/citation/citation-view","mvc/tools","mvc/tools/tools-template","mvc/tools/tools-content","mvc/tools/tools-section","mvc/tools/tools-tree"],function(g,h,f,k,i,a,d,c,e,j,b){return Backbone.View.extend({initialize:function(l){this.optionsDefault={is_dynamic:true,narrow:false,initial_errors:false};this.options=g.merge(l,this.optionsDefault);console.debug(this.options);var m=parent.Galaxy;if(m&&m.modal){this.modal=m.modal}else{this.modal=new k.Modal.View()}if(m&&m.currUser){this.is_admin=m.currUser.get("is_admin")}else{this.is_admin=false}this.container=this.options.container||"body";this.deferred=new h();this.setElement("<div/>");$(this.container).append(this.$el);this.build(this.options)},build:function(m){var l=this;this.off("refresh");this.off("reset");this.field_list={};this.input_list={};this.element_list={};this.tree=new b(this);this.content=new e(this);l.options.inputs=m&&m.inputs;this._renderForm(m);this.tree.finalize();if(m.initial_errors){this._errors(m)}this.on("refresh",function(){l.deferred.reset();l.deferred.execute(function(){l._updateModel()})});this.on("reset",function(){for(var n in this.element_list){this.element_list[n].reset()}});this.trigger("refresh")},reciept:function(l){$(this.container).empty();$(this.container).append(l)},highlight:function(m,n,l){var o=this.element_list[m];if(o){o.error(n||"Please verify this parameter.");if(!l){$(this.container).animate({scrollTop:o.$el.offset().top-20},500)}}},_errors:function(n){this.trigger("reset");if(n&&n.errors){var o=this.tree.matchResponse(n.errors);for(var m in this.element_list){var l=this.element_list[m];if(o[m]){this.highlight(m,o[m],true)}}}},_renderForm:function(u){var t=this;this.message=new k.Message();var q=new k.ButtonIcon({icon:"fa-info-circle",title:(!u.narrow&&"Requirements")||null,tooltip:"Display tool requirements",onclick:function(){if(!this.visible){this.visible=true;t.message.update({persistent:true,message:c.requirements(u),status:"info"})}else{this.visible=false;t.message.update({message:""})}}});if(!u.requirements||u.requirements.length==0){q.$el.hide()}var m=new k.ButtonMenu({icon:"fa-cubes",title:(!u.narrow&&"Versions")||null,tooltip:"Select another tool version"});if(u.versions&&u.versions.length>1){for(var o in u.versions){var r=u.versions[o];if(r!=u.version){m.addMenu({title:"Switch to "+r,version:r,icon:"fa-cube",onclick:function(){t.options.id=t.options.id.replace(t.options.version,this.version);t.options.version=this.version;t.deferred.reset();t.deferred.execute(function(){t._buildModel()})}})}}}else{m.$el.hide()}var p=new k.ButtonMenu({icon:"fa-caret-down",title:(!u.narrow&&"Options")||null,tooltip:"View available options"});if(u.biostar_url){p.addMenu({icon:"fa-question-circle",title:"Question?",tooltip:"Ask a question about this tool (Biostar)",onclick:function(){window.open(u.biostar_url+"/p/new/post/")}});p.addMenu({icon:"fa-search",title:"Search",tooltip:"Search help for this tool (Biostar)",onclick:function(){window.open(u.biostar_url+"/t/"+u.id+"/")}})}p.addMenu({icon:"fa-share",title:"Share",tooltip:"Share this tool",onclick:function(){prompt("Copy to clipboard: Ctrl+C, Enter",window.location.origin+galaxy_config.root+"root?tool_id="+u.id)}});if(this.is_admin){p.addMenu({icon:"fa-download",title:"Download",tooltip:"Download this tool",onclick:function(){window.location.href=galaxy_config.root+"api/tools/"+u.id+"/download"}})}this.section=new j.View(t,{inputs:u.inputs});if(this.incompatible){this.$el.hide();$("#tool-form-classic").show();return}this.portlet=new f.View({icon:"fa-wrench",title:"<b>"+u.name+"</b> "+u.description+" (Galaxy Tool Version "+u.version+")",cls:"ui-portlet-slim",operations:{requirements:q,menu:p,versions:m},buttons:this.buttons});if(u.narrow){this.portlet.$content.css("padding","0px")}this.portlet.append(this.message.$el,true);this.portlet.append(this.section.$el);this.$el.empty();this.$el.append(this.portlet.$el);if(u.help!=""){this.$el.append(c.help(u.help))}if(u.citations){var s=$("<div/>");var l=new i.ToolCitationCollection();l.tool_id=u.id;var n=new a.CitationListView({el:s,collection:l});n.render();l.fetch();this.$el.append(s)}if(u.message){this.message.update({persistent:true,status:"warning",message:u.message})}}})});
\ No newline at end of file
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/packed/mvc/tools/tools-form-workflow.js
--- a/static/scripts/packed/mvc/tools/tools-form-workflow.js
+++ b/static/scripts/packed/mvc/tools/tools-form-workflow.js
@@ -1,1 +1,1 @@
-define(["utils/utils","mvc/tools/tools-form-base"],function(b,a){var c=a.extend({initialize:function(e){this.node=workflow.active_node;if(!this.node){console.debug("FAILED - tools-form-workflow:initialize() - Node not found in workflow.");return}this.post_job_actions=this.node.post_job_actions||{};this.options=e;this.options.text_enable="In Advance";this.options.text_disable="At Runtime";this.options.use_defaults=true;b.deepeach(e.inputs,function(f){if(f.type){f.optional=(["data","data_hidden","hidden","drill_down","repeat","conditional"]).indexOf(f.type)==-1}});b.deepeach(e.inputs,function(f){if(f.type){if(f.type=="conditional"){f.test_param.optional=false}}});var d=this;b.get({url:galaxy_config.root+"api/datatypes",cache:true,success:function(f){d.datatypes=f;d._makeSections(e.inputs);a.prototype.initialize.call(d,e)}})},_makeSections:function(d){d[b.uuid()]={label:"Annotation / Notes",name:"annotation",type:"text",area:true,help:"Add an annotation or note for this step. It will be shown with the workflow.",value:this.node.annotation};var f=this.node.output_terminals&&Object.keys(this.node.output_terminals)[0];if(f){d[b.uuid()]={name:"pja__"+f+"__EmailAction",label:"Email notification",type:"boolean",value:String(Boolean(this.post_job_actions["EmailAction"+f])),ignore:"false",help:"An email notification will be send when the job has completed.",payload:{host:window.location.host}};d[b.uuid()]={name:"pja__"+f+"__DeleteIntermediatesAction",label:"Output cleanup",type:"boolean",value:String(Boolean(this.post_job_actions["DeleteIntermediatesAction"+f])),ignore:"false",help:"Delete intermediate outputs if they are not used as input for another job."};for(var e in this.node.output_terminals){d[b.uuid()]=this._makeSection(e)}}},_makeSection:function(h){var g=[];for(key in this.datatypes){g.push({0:this.datatypes[key],1:this.datatypes[key]})}g.sort(function(j,i){return j.label>i.label?1:j.label<i.label?-1:0});g.unshift({0:"Sequences",1:"Sequences"});g.unshift({0:"Roadmaps",1:"Roadmaps"});g.unshift({0:"Leave unchanged",1:""});var f={label:"Add Actions: '"+h+"'",type:"section",inputs:[{action:"RenameDatasetAction",argument:"newname",label:"Rename dataset",type:"text",value:"",ignore:"",help:'This action will rename the result dataset. Click <a href="https://wiki.galaxyproject.org/Learn/AdvancedWorkflow/Variables">here</a> for more information.'},{action:"ChangeDatatypeAction",argument:"newtype",label:"Change datatype",type:"select",ignore:"",options:g,help:"This action will change the datatype of the output to the indicated value."},{action:"TagDatasetAction",argument:"tags",label:"Tags",type:"text",value:"",ignore:"",help:"This action will set tags for the dataset."},{label:"Assign columns",type:"section",inputs:[{action:"ColumnSetAction",argument:"chromCol",label:"Chrom column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"startCol",label:"Start column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"endCol",label:"End column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"strandCol",label:"Strand column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"nameCol",label:"Name column",type:"integer",value:"",ignore:""}],help:"This action will set column assignments in the output dataset. Blank fields are ignored."}]};var d=this;function e(n,o){o=o||[];o.push(n);for(var m in n.inputs){var k=n.inputs[m];if(k.action){k.name="pja__"+h+"__"+k.action;if(k.argument){k.name+="__"+k.argument}if(k.payload){for(var s in k.payload){var q=k.payload[s];k.payload[k.name+"__"+s]=q;delete q}}var r=d.post_job_actions[k.action+h];if(r){for(var l in o){o[l].expand=true}if(k.argument){k.value=r.action_arguments&&r.action_arguments[k.argument]||k.value}else{k.value="true"}}}if(k.inputs){e(k,o.slice(0))}}}e(f);return f},_buildModel:function(){Galaxy.modal.show({title:"Coming soon...",body:"This feature has not been implemented yet.",buttons:{Close:function(){Galaxy.modal.hide()}}})},_updateModel:function(){var d=this;var e=this.tree.finalize();console.debug("tools-form-workflow::_refreshForm() - Refreshing states.");console.debug(e);var g=this.deferred.register();var f=galaxy_config.root+"workflow/editor_form_post?tool_id="+this.options.id+"&__is_dynamic__=False";b.request({type:"GET",url:f,data:e,success:function(h){d.node.update_field_data(h);d._errors(h&&h.tool_model);d.deferred.done(g);console.debug("tools-form::_refreshForm() - States refreshed.");console.debug(h)},error:function(h){d.deferred.done(g);console.debug("tools-form::_refreshForm() - Refresh request failed.");console.debug(h)}})}});return{View:c}});
\ No newline at end of file
+define(["utils/utils","mvc/tools/tools-form-base"],function(b,a){var c=a.extend({initialize:function(e){this.node=workflow.active_node;if(!this.node){console.debug("FAILED - tools-form-workflow:initialize() - Node not found in workflow.");return}this.post_job_actions=this.node.post_job_actions||{};this.options=e;this.options.text_enable="In Advance";this.options.text_disable="At Runtime";this.options.is_dynamic=false;this.options.narrow=true;this.options.initial_errors=true;b.deepeach(e.inputs,function(f){if(f.type){f.optional=(["data","data_hidden","hidden","drill_down","repeat","conditional"]).indexOf(f.type)==-1}});b.deepeach(e.inputs,function(f){if(f.type){if(f.type=="conditional"){f.test_param.optional=false}}});var d=this;b.get({url:galaxy_config.root+"api/datatypes",cache:true,success:function(f){d.datatypes=f;d._makeSections(e.inputs);a.prototype.initialize.call(d,e)}})},_makeSections:function(d){d[b.uuid()]={label:"Annotation / Notes",name:"annotation",type:"text",area:true,help:"Add an annotation or note for this step. It will be shown with the workflow.",value:this.node.annotation};var f=this.node.output_terminals&&Object.keys(this.node.output_terminals)[0];if(f){d[b.uuid()]={name:"pja__"+f+"__EmailAction",label:"Email notification",type:"boolean",value:String(Boolean(this.post_job_actions["EmailAction"+f])),ignore:"false",help:"An email notification will be send when the job has completed.",payload:{host:window.location.host}};d[b.uuid()]={name:"pja__"+f+"__DeleteIntermediatesAction",label:"Output cleanup",type:"boolean",value:String(Boolean(this.post_job_actions["DeleteIntermediatesAction"+f])),ignore:"false",help:"Delete intermediate outputs if they are not used as input for another job."};for(var e in this.node.output_terminals){d[b.uuid()]=this._makeSection(e)}}},_makeSection:function(h){var g=[];for(key in this.datatypes){g.push({0:this.datatypes[key],1:this.datatypes[key]})}g.sort(function(j,i){return j.label>i.label?1:j.label<i.label?-1:0});g.unshift({0:"Sequences",1:"Sequences"});g.unshift({0:"Roadmaps",1:"Roadmaps"});g.unshift({0:"Leave unchanged",1:""});var f={label:"Add Actions: '"+h+"'",type:"section",inputs:[{action:"RenameDatasetAction",argument:"newname",label:"Rename dataset",type:"text",value:"",ignore:"",help:'This action will rename the result dataset. Click <a href="https://wiki.galaxyproject.org/Learn/AdvancedWorkflow/Variables">here</a> for more information.'},{action:"ChangeDatatypeAction",argument:"newtype",label:"Change datatype",type:"select",ignore:"",options:g,help:"This action will change the datatype of the output to the indicated value."},{action:"TagDatasetAction",argument:"tags",label:"Tags",type:"text",value:"",ignore:"",help:"This action will set tags for the dataset."},{label:"Assign columns",type:"section",inputs:[{action:"ColumnSetAction",argument:"chromCol",label:"Chrom column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"startCol",label:"Start column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"endCol",label:"End column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"strandCol",label:"Strand column",type:"integer",value:"",ignore:""},{action:"ColumnSetAction",argument:"nameCol",label:"Name column",type:"integer",value:"",ignore:""}],help:"This action will set column assignments in the output dataset. Blank fields are ignored."}]};var d=this;function e(n,o){o=o||[];o.push(n);for(var m in n.inputs){var k=n.inputs[m];if(k.action){k.name="pja__"+h+"__"+k.action;if(k.argument){k.name+="__"+k.argument}if(k.payload){for(var s in k.payload){var q=k.payload[s];k.payload[k.name+"__"+s]=q;delete q}}var r=d.post_job_actions[k.action+h];if(r){for(var l in o){o[l].expand=true}if(k.argument){k.value=r.action_arguments&&r.action_arguments[k.argument]||k.value}else{k.value="true"}}}if(k.inputs){e(k,o.slice(0))}}}e(f);return f},_buildModel:function(){Galaxy.modal.show({title:"Coming soon...",body:"This feature has not been implemented yet.",buttons:{Close:function(){Galaxy.modal.hide()}}})},_updateModel:function(){var d=this;var e=this.tree.finalize();console.debug("tools-form-workflow::_refreshForm() - Refreshing states.");console.debug(e);var g=this.deferred.register();var f=galaxy_config.root+"workflow/editor_form_post?tool_id="+this.options.id+"&__is_dynamic__=False";b.request({type:"GET",url:f,data:e,success:function(h){d.node.update_field_data(h);d._errors(h&&h.tool_model);d.deferred.done(g);console.debug("tools-form::_refreshForm() - States refreshed.");console.debug(h)},error:function(h){d.deferred.done(g);console.debug("tools-form::_refreshForm() - Refresh request failed.");console.debug(h)}})}});return{View:c}});
\ No newline at end of file
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 static/scripts/packed/mvc/tools/tools-form.js
--- a/static/scripts/packed/mvc/tools/tools-form.js
+++ b/static/scripts/packed/mvc/tools/tools-form.js
@@ -1,1 +1,1 @@
-define(["utils/utils","mvc/ui/ui-misc","mvc/tools/tools-form-base","mvc/tools/tools-jobs"],function(c,e,b,a){var d=b.extend({initialize:function(g){var f=this;this.job_handler=new a(this);this.buttons={execute:new e.Button({icon:"fa-check",tooltip:"Execute: "+g.name,title:"Execute",cls:"btn btn-primary",floating:"clear",onclick:function(){f.job_handler.submit()}})};b.prototype.initialize.call(this,g)},_buildModel:function(){var f=this;var g=galaxy_config.root+"api/tools/"+this.options.id+"/build?";if(this.options.job_id){g+="job_id="+this.options.job_id}else{if(this.options.dataset_id){g+="dataset_id="+this.options.dataset_id}else{g+="tool_version="+this.options.version+"&";var i=top.location.href;var j=i.indexOf("?");if(i.indexOf("tool_id=")!=-1&&j!==-1){g+=i.slice(j+1)}}}var h=this.deferred.register();c.request({type:"GET",url:g,success:function(k){f.options=k;f._buildForm();f.message.update({status:"success",message:"Now you are using '"+f.options.name+"' version "+f.options.version+".",persistent:false});f.deferred.done(h);console.debug("tools-form::initialize() - Initial tool model ready.");console.debug(k)},error:function(k){f.deferred.done(h);console.debug("tools-form::initialize() - Initial tool model request failed.");console.debug(k);var l=k.error||"Uncaught error.";f.modal.show({title:"Tool cannot be executed",body:l,buttons:{Close:function(){f.modal.hide()}}})}})},_updateModel:function(){var f=this;var g=this.tree.finalize({data:function(k){if(k.values.length>0&&k.values[0]&&k.values[0].src==="hda"){return f.content.get({id:k.values[0].id,src:"hda"}).id_uncoded}return null}});console.debug("tools-form::_refreshForm() - Refreshing states.");console.debug(g);function j(n){for(var l in f.input_list){var m=f.field_list[l];var k=f.input_list[l];if(k.is_dynamic&&m.wait&&m.unwait){if(n){m.wait()}else{m.unwait()}}}}j(true);var i=this.deferred.register();var h=galaxy_config.root+"api/tools/"+this.options.id+"/build?tool_version="+this.options.version;c.request({type:"GET",url:h,data:g,success:function(k){f.tree.matchModel(k,function(m,q){var l=f.input_list[m];if(l&&l.options){if(!_.isEqual(l.options,q.options)){l.options=q.options;var r=f.field_list[m];if(r.update){var p=[];if((["data","data_collection","drill_down"]).indexOf(l.type)!=-1){p=l.options}else{for(var o in q.options){var n=q.options[o];if(n.length>2){p.push({label:n[0],value:n[1]})}}}r.update(p);r.trigger("change");console.debug("Updating options for "+m)}}}});j(false);f.deferred.done(i);console.debug("tools-form::_refreshForm() - States refreshed.");console.debug(k)},error:function(k){f.deferred.done(i);console.debug("tools-form::_refreshForm() - Refresh request failed.");console.debug(k)}})}});return{View:d}});
\ No newline at end of file
+define(["utils/utils","mvc/ui/ui-misc","mvc/tools/tools-form-base","mvc/tools/tools-jobs"],function(c,e,b,a){var d=b.extend({initialize:function(g){var f=this;this.job_handler=new a(this);this.buttons={execute:new e.Button({icon:"fa-check",tooltip:"Execute: "+g.name,title:"Execute",cls:"btn btn-primary",floating:"clear",onclick:function(){f.job_handler.submit()}})};b.prototype.initialize.call(this,g)},_buildModel:function(){var f=this;var g=galaxy_config.root+"api/tools/"+this.options.id+"/build?";if(this.options.job_id){g+="job_id="+this.options.job_id}else{if(this.options.dataset_id){g+="dataset_id="+this.options.dataset_id}else{g+="tool_version="+this.options.version+"&";var i=top.location.href;var j=i.indexOf("?");if(i.indexOf("tool_id=")!=-1&&j!==-1){g+=i.slice(j+1)}}}var h=this.deferred.register();c.request({type:"GET",url:g,success:function(k){f.build(k);f.message.update({status:"success",message:"Now you are using '"+f.options.name+"' version "+f.options.version+".",persistent:false});f.deferred.done(h);console.debug("tools-form::initialize() - Initial tool model ready.");console.debug(k)},error:function(k){f.deferred.done(h);console.debug("tools-form::initialize() - Initial tool model request failed.");console.debug(k);var l=k.error||"Uncaught error.";f.modal.show({title:"Tool cannot be executed",body:l,buttons:{Close:function(){f.modal.hide()}}})}})},_updateModel:function(){var f=this;var g=this.tree.finalize({data:function(k){if(k.values.length>0&&k.values[0]&&k.values[0].src==="hda"){return f.content.get({id:k.values[0].id,src:"hda"}).id_uncoded}return null}});console.debug("tools-form::_refreshForm() - Refreshing states.");console.debug(g);function j(n){for(var l in f.input_list){var m=f.field_list[l];var k=f.input_list[l];if(k.is_dynamic&&m.wait&&m.unwait){if(n){m.wait()}else{m.unwait()}}}}j(true);var i=this.deferred.register();var h=galaxy_config.root+"api/tools/"+this.options.id+"/build?tool_version="+this.options.version;c.request({type:"GET",url:h,data:g,success:function(k){f.tree.matchModel(k,function(m,q){var l=f.input_list[m];if(l&&l.options){if(!_.isEqual(l.options,q.options)){l.options=q.options;var r=f.field_list[m];if(r.update){var p=[];if((["data","data_collection","drill_down"]).indexOf(l.type)!=-1){p=l.options}else{for(var o in q.options){var n=q.options[o];if(n.length>2){p.push({label:n[0],value:n[1]})}}}r.update(p);r.trigger("change");console.debug("Updating options for "+m)}}}});j(false);f.deferred.done(i);console.debug("tools-form::_refreshForm() - States refreshed.");console.debug(k)},error:function(k){f.deferred.done(i);console.debug("tools-form::_refreshForm() - Refresh request failed.");console.debug(k)}})}});return{View:d}});
\ No newline at end of file
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 templates/webapps/galaxy/tool_form.mako
--- a/templates/webapps/galaxy/tool_form.mako
+++ b/templates/webapps/galaxy/tool_form.mako
@@ -9,8 +9,7 @@
## TEMPORARY: create tool dictionary in mako while both tool forms are in use.
## This avoids making two separate requests since the classic form requires the mako anyway.
params = dict(trans.request.params)
- if 'id' in params:
- params['dataset_id'] = params['id']
+ params['__dataset_id__'] = params.get('id', None)
self.form_config = tool.to_json(trans, **params)
self.form_config.update({
'id' : tool.id,
diff -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f -r 494418e72cf0007e909c7f4b9134cd2b82df49e2 templates/webapps/galaxy/workflow/editor_tool_form.mako
--- a/templates/webapps/galaxy/workflow/editor_tool_form.mako
+++ b/templates/webapps/galaxy/workflow/editor_tool_form.mako
@@ -15,9 +15,6 @@
'id' : tool.id,
'job_id' : trans.security.encode_id( job.id ) if job else None,
'history_id' : trans.security.encode_id( trans.history.id ),
- 'is_dynamic' : False,
- 'compact' : True,
- 'initial_errors' : True,
'container' : '#right-content'
})
%>
Repository URL: https://bitbucket.org/galaxy/galaxy-central/
--
This is a commit notification from bitbucket.org. You are receiving
this because you have the service enabled, addressing the recipient of
this email.
1 new commit in galaxy-central:
https://bitbucket.org/galaxy/galaxy-central/commits/ff2b00fcbd70/
Changeset: ff2b00fcbd70
User: jmchilton
Date: 2015-02-05 18:32:56+00:00
Summary: Bugfix for bugfix d3b1f6b.
d3b1f6b fix the GUI (in an obsecure use) but broke fairly typical uses of the API.
Affected #: 1 file
diff -r b6349ba5cda26cdea678c4842136e50363c0629f -r ff2b00fcbd70e3d7ce10b0444412cc68d2ede46f lib/galaxy/workflow/modules.py
--- a/lib/galaxy/workflow/modules.py
+++ b/lib/galaxy/workflow/modules.py
@@ -330,7 +330,9 @@
# so do that now so dependent steps can be recalculated. In the future
# everything should come in from the API and this can be eliminated.
if not invocation.has_input_for_step( step.id ):
- invocation.add_input( step_outputs.values()[ 0 ], step.id )
+ content = step_outputs.values()[ 0 ]
+ if content:
+ invocation.add_input( content, step.id )
progress.set_outputs_for_input( step, step_outputs )
return job
Repository URL: https://bitbucket.org/galaxy/galaxy-central/
--
This is a commit notification from bitbucket.org. You are receiving
this because you have the service enabled, addressing the recipient of
this email.
1 new commit in galaxy-central:
https://bitbucket.org/galaxy/galaxy-central/commits/cca00d61df85/
Changeset: cca00d61df85
User: dannon
Date: 2015-02-05 14:35:36+00:00
Summary: Prevent uwsgi from ever loading static middleware -- it can serve static files directly with appropriate routes in its config (see wiki).
Affected #: 1 file
diff -r 1989401bb9009e76fbaaafdeeffa68c0f12959ab -r cca00d61df85a6ecd1be49265f0c92e7482b91f9 lib/galaxy/webapps/galaxy/buildapp.py
--- a/lib/galaxy/webapps/galaxy/buildapp.py
+++ b/lib/galaxy/webapps/galaxy/buildapp.py
@@ -86,9 +86,24 @@
# Wrap the webapp in some useful middleware
if kwargs.get( 'middleware', True ):
webapp = wrap_in_middleware( webapp, global_conf, **kwargs )
- if asbool( kwargs.get( 'static_enabled', True ) ):
- webapp = wrap_in_static( webapp, global_conf, plugin_frameworks=[ app.visualizations_registry ], **kwargs )
- #webapp = wrap_in_static( webapp, global_conf, plugin_frameworks=None, **kwargs )
+ # TEST FOR UWSGI -- TODO save this somewhere so we only have to do it once.
+ is_uwsgi = False
+ try:
+ # The uwsgi module is automatically injected by the parent uwsgi
+ # process and only exists that way. If anything works, this is a
+ # uwsgi-managed process.
+ import uwsgi
+ is_uwsgi = uwsgi.numproc
+ is_uwsgi = True
+ except ImportError:
+ # This is not a uwsgi process, or something went horribly wrong.
+ pass
+ if asbool( kwargs.get( 'static_enabled', True) ):
+ if is_uwsgi:
+ log.error("Static middleware is enabled in your configuration but this is a uwsgi process. Refusing to wrap in static middleware.")
+ else:
+ webapp = wrap_in_static( webapp, global_conf, plugin_frameworks=[ app.visualizations_registry ], **kwargs )
+ #webapp = wrap_in_static( webapp, global_conf, plugin_frameworks=None, **kwargs )
if asbool(kwargs.get('pack_scripts', False)):
log.warn( "The 'pack_scripts' option is deprecated" )
pack_scripts()
Repository URL: https://bitbucket.org/galaxy/galaxy-central/
--
This is a commit notification from bitbucket.org. You are receiving
this because you have the service enabled, addressing the recipient of
this email.