X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/94b5a59631f22e4e57561a6244c24b93db77f589..92211c8bed5aaf3abd83d02c4adbaf2329123bac:/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 e3f6fdc3c9..624cb3d4c0 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) @@ -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,16 +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 - 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 @@ -233,6 +238,7 @@ module ApplicationHelper else attrvalue = '' end + preconfigured_search_str = value_info[:search_for] end if !object or @@ -281,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, @@ -453,4 +459,23 @@ 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 + + def render_localized_date(date, opts="") + raw("#{date}") + end + +private + def is_textile?( object, attr ) + is_textile = object.textile_attributes.andand.include?(attr) + end end