X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/26114a84293ea3fbcc5ef4adcf7900060716e62c..4c8ec1b2166a81b05b2b6cf5a6fae5b839876802:/apps/workbench/app/models/pipeline_instance.rb diff --git a/apps/workbench/app/models/pipeline_instance.rb b/apps/workbench/app/models/pipeline_instance.rb index ccb88351a7..89acbb0dbb 100644 --- a/apps/workbench/app/models/pipeline_instance.rb +++ b/apps/workbench/app/models/pipeline_instance.rb @@ -1,6 +1,32 @@ class PipelineInstance < ArvadosBase attr_accessor :pipeline_template + def self.goes_in_projects? + true + end + + def friendly_link_name + pipeline_name = self.name + if pipeline_name.nil? or pipeline_name.empty? + template = PipelineTemplate.where(uuid: self.pipeline_template_uuid).first + if template + template.name + else + self.uuid + end + else + pipeline_name + end + end + + def content_summary + begin + PipelineTemplate.find(pipeline_template_uuid).name + rescue + super + end + end + def update_job_parameters(new_params) self.components[:steps].each_with_index do |step, i| step[:params].each do |param| @@ -16,9 +42,11 @@ class PipelineInstance < ArvadosBase end end end - - def attribute_editable?(attr) - attr.to_sym == :name || (attr.to_sym == :components and self.active == nil) + + def attribute_editable? attr, *args + super && (attr.to_sym == :name || attr.to_sym == :description || + (attr.to_sym == :components and + (self.state == 'New' || self.state == 'Ready'))) end def attributes_for_display @@ -28,4 +56,19 @@ class PipelineInstance < ArvadosBase def self.creatable? false end + + def component_input_title(component_name, input_name) + component = components[component_name] + return nil if component.nil? + param_info = component[:script_parameters].andand[input_name.to_sym] + if param_info.is_a?(Hash) and param_info[:title] + param_info[:title] + else + "\"#{input_name.to_s}\" parameter for #{component[:script]} script in #{component_name} component" + end + end + + def textile_attributes + [ 'description' ] + end end