X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/6db406e9a2fc78ed204460deb73151f44d94b030..c446dd845656e944c2d3f91f8d00e320c37b66a1:/apps/workbench/app/helpers/application_helper.rb diff --git a/apps/workbench/app/helpers/application_helper.rb b/apps/workbench/app/helpers/application_helper.rb index 7872792307..b82ae89ddf 100644 --- a/apps/workbench/app/helpers/application_helper.rb +++ b/apps/workbench/app/helpers/application_helper.rb @@ -11,8 +11,8 @@ module ApplicationHelper Rails.configuration.arvados_v1_base.gsub /https?:\/\/|\/arvados\/v1/,'' end - def render_content_from_database(markup) - raw RedCloth.new(markup).to_html + def render_markup(markup) + raw RedCloth.new(markup.to_s).to_html(:refs_arvados, :textile) if markup end def human_readable_bytes_html(n) @@ -107,6 +107,9 @@ module ApplicationHelper end end end + if link_name.nil? or link_name.empty? + link_name = attrvalue + end if opts[:with_class_name] link_name = "#{resource_class.to_s}: #{link_name}" end @@ -133,9 +136,6 @@ module ApplicationHelper if opts[:no_link] raw(link_name) else - if link_name.nil? or link_name.empty? - link_name = "(unnamed)" - end (link_to raw(link_name), { controller: resource_class.to_s.tableize, action: 'show', id: ((opts[:name_link].andand.uuid) || link_uuid) }, style_opts) + raw(tags) end else @@ -153,9 +153,12 @@ module ApplicationHelper if !object.attribute_editable?(attr, :ever) or (!object.editable? and !object.owner_uuid.in?(my_projects.collect(&:uuid))) - return ((attrvalue && attrvalue.length > 0 && attrvalue) || - (attr == 'name' and object.andand.default_name) || - '(none)') + if attrvalue && attrvalue.length > 0 + return render_attribute_as_textile( object, attr, attrvalue, false ) + else + return (attr == 'name' and object.andand.default_name) || + '(none)' + end end input_type = 'text' @@ -169,6 +172,7 @@ module ApplicationHelper end attrvalue = attrvalue.to_json if attrvalue.is_a? Hash or attrvalue.is_a? Array + rendervalue = render_attribute_as_textile( object, attr, attrvalue, false ) ajax_options = { "data-pk" => { @@ -186,18 +190,17 @@ module ApplicationHelper @unique_id ||= (Time.now.to_f*1000000).to_i span_id = object.uuid.to_s + '-' + attr.to_s + '-' + (@unique_id += 1).to_s - puts "Span #{object.inspect} #{(object.andand.default_name || 'none')}" - - span_tag = content_tag 'span', attrvalue.to_s, { - "data-emptytext" => ('(none)'), + span_tag = content_tag 'span', rendervalue, { + "data-emptytext" => '(none)', "data-placement" => "bottom", "data-type" => input_type, "data-title" => "Edit #{attr.to_s.gsub '_', ' '}", "data-name" => attr, "data-object-uuid" => object.uuid, "data-toggle" => "manual", + "data-value" => attrvalue, "id" => span_id, - :class => "editable" + :class => "editable #{is_textile?( object, attr ) ? 'editable-textile' : ''}" }.merge(htmloptions).merge(ajax_options) edit_button = raw('') if htmloptions[:btnplacement] == :left @@ -235,6 +238,7 @@ module ApplicationHelper else attrvalue = '' end + preconfigured_search_str = value_info[:search_for] end if !object or @@ -283,7 +287,7 @@ module ApplicationHelper action_name: 'OK', action_href: pipeline_instance_path(id: object.uuid), action_method: 'patch', - preconfigured_search_str: "#{value_info[:search_for]}", + preconfigured_search_str: (preconfigured_search_str || ""), action_data: { merge: true, selection_param: selection_param, @@ -455,4 +459,19 @@ module ApplicationHelper nil end end + + def render_attribute_as_textile( object, attr, attrvalue, truncate ) + if attrvalue && (is_textile? object, attr) + markup = render_markup attrvalue + markup = markup[0,markup.index('

')+4] if (truncate && markup.index('

')) + return markup + else + return attrvalue + end + end + +private + def is_textile?( object, attr ) + is_textile = object.textile_attributes.andand.include?(attr) + end end