X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/c005c5ab76492b844e84d1c66f75797bd98d0996..3374f67bfe90aeae87389ca323a3bfac123ac7ea:/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..bc828c4f38 100644 --- a/apps/workbench/app/helpers/application_helper.rb +++ b/apps/workbench/app/helpers/application_helper.rb @@ -1,4 +1,6 @@ module ApplicationHelper + include VersionHelper + def current_user controller.current_user end @@ -11,8 +13,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) @@ -93,7 +95,7 @@ module ApplicationHelper if opts[:friendly_name] if attrvalue.respond_to? :friendly_link_name - link_name = attrvalue.friendly_link_name + link_name = attrvalue.friendly_link_name opts[:lookup] else begin if resource_class.name == 'Collection' @@ -150,12 +152,13 @@ module ApplicationHelper def render_editable_attribute(object, attr, attrvalue=nil, htmloptions={}) attrvalue = object.send(attr) if attrvalue.nil? - 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 not object.attribute_editable?(attr) + 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,12 +238,10 @@ module ApplicationHelper else attrvalue = '' end + preconfigured_search_str = value_info[:search_for] end - if !object or - !object.attribute_editable?(attr, :ever) or - (!object.editable? and - !object.owner_uuid.in?(my_projects.collect(&:uuid))) + if not object.andand.attribute_editable?(attr) return link_to_if_arvados_object attrvalue end @@ -260,7 +263,7 @@ module ApplicationHelper dn += '[value]' end - if dataclass == Collection + if (dataclass == Collection) or (dataclass == File) selection_param = object.class.to_s.underscore + dn display_value = attrvalue if value_info.is_a?(Hash) @@ -268,12 +271,14 @@ module ApplicationHelper display_value = link.name elsif value_info[:link_name] display_value = value_info[:link_name] + elsif value_info[:selection_name] + display_value = value_info[:selection_name] end end if (attr == :components) and (subattr.size > 2) - chooser_title = "Choose a dataset for #{object.component_input_title(subattr[0], subattr[2])}:" + chooser_title = "Choose a #{dataclass == Collection ? 'dataset' : 'file'} for #{object.component_input_title(subattr[0], subattr[2])}:" else - chooser_title = "Choose a dataset:" + chooser_title = "Choose a #{dataclass == Collection ? 'dataset' : 'file'}:" end modal_path = choose_collections_path \ ({ title: chooser_title, @@ -281,9 +286,10 @@ 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, + use_preview_selection: dataclass == File ? true : nil, selection_param: selection_param, success: 'page-refresh' }.to_json, @@ -445,12 +451,31 @@ module ApplicationHelper end end - def chooser_preview_url_for object + def chooser_preview_url_for object, use_preview_selection=false case object.class.to_s when 'Collection' - polymorphic_path(object, tab_pane: 'chooser_preview') + polymorphic_path(object, tab_pane: 'chooser_preview', use_preview_selection: use_preview_selection) else 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