X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/675794872a5d064cf0a8177d662555c04b0dae51..f3da69fb1b882c7fe8feb765ad0558f13706931a:/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 f8bb589909..43c96b5536 100644 --- a/apps/workbench/app/helpers/application_helper.rb +++ b/apps/workbench/app/helpers/application_helper.rb @@ -89,7 +89,11 @@ module ApplicationHelper link_name = attrvalue.friendly_link_name else begin - link_name = resource_class.find(link_uuid).friendly_link_name + if resource_class.name == 'Collection' + link_name = collections_for_object(link_uuid).andand.first.andand.friendly_link_name + else + link_name = object_for_dataclass(resource_class, link_uuid).friendly_link_name + end rescue RuntimeError # If that lookup failed, the link will too. So don't make one. return attrvalue @@ -100,13 +104,15 @@ module ApplicationHelper link_name = "#{resource_class.to_s}: #{link_name}" end if !opts[:no_tags] and resource_class == Collection - Link.where(head_uuid: link_uuid, link_class: ["tag", "identifier"]).each do |tag| - link_name += ' ' + html_escape(tag.name) + '' + links_for_object(link_uuid).each do |tag| + if tag.link_class.in? ["tag", "identifier"] + link_name += ' ' + html_escape(tag.name) + '' + end end end if opts[:thumbnail] and resource_class == Collection # add an image thumbnail if the collection consists of a single image file. - Collection.where(uuid: link_uuid).each do |c| + collections_for_object(link_uuid).each do |c| if c.files.length == 1 and CollectionsHelper::is_image c.files.first[1] link_name += " " link_name += image_tag "#{url_for c}/#{CollectionsHelper::file_path c.files.first}", style: "height: 4em; width: auto" @@ -128,7 +134,11 @@ module ApplicationHelper def render_editable_attribute(object, attr, attrvalue=nil, htmloptions={}) attrvalue = object.send(attr) if attrvalue.nil? - return attrvalue if !object.attribute_editable? attr + if !object.attribute_editable?(attr, :ever) or + (!object.editable? and + !object.owner_uuid.in?(my_folders.collect(&:uuid))) + return attrvalue + end input_type = 'text' case object.class.attribute_info[attr.to_sym].andand[:type] @@ -197,7 +207,10 @@ module ApplicationHelper end end - unless object.andand.attribute_editable? attr + if !object or + !object.attribute_editable?(attr, :ever) or + (!object.editable? and + !object.owner_uuid.in?(my_folders.collect(&:uuid))) return link_to_if_arvados_object attrvalue end @@ -232,27 +245,45 @@ module ApplicationHelper dn += '[value]' end + # preload data + preload_uuids = [] + items = [] selectables = [] + attrtext = attrvalue if dataclass and dataclass.is_a? Class + objects = get_n_objects_of_class dataclass, 10 + objects.each do |item| + items << item + preload_uuids << item.uuid + end + if attrvalue and !attrvalue.empty? + preload_uuids << attrvalue + end + preload_links_for_objects preload_uuids + if attrvalue and !attrvalue.empty? - Link.where(head_uuid: attrvalue, link_class: ["tag", "identifier"]).each do |tag| - attrtext += " [#{tag.name}]" + links_for_object(attrvalue).each do |link| + if link.link_class.in? ["tag", "identifier"] + attrtext += " [#{tag.name}]" + end end selectables.append({name: attrtext, uuid: attrvalue, type: dataclass.to_s}) end - #dataclass.where(uuid: attrvalue).each do |item| - # selectables.append({name: item.uuid, uuid: item.uuid, type: dataclass.to_s}) - #end itemuuids = [] - dataclass.limit(10).each do |item| + items.each do |item| itemuuids << item.uuid selectables.append({name: item.uuid, uuid: item.uuid, type: dataclass.to_s}) end - Link.where(head_uuid: itemuuids, link_class: ["tag", "identifier"]).each do |tag| - selectables.each do |selectable| - if selectable['uuid'] == tag.head_uuid - selectable['name'] += ' [' + tag.name + ']' + + itemuuids.each do |itemuuid| + links_for_object(itemuuid).each do |link| + if link.link_class.in? ["tag", "identifier"] + selectables.each do |selectable| + if selectable['uuid'] == tag.head_uuid + selectable['name'] += ' [' + tag.name + ']' + end + end end end end @@ -268,7 +299,7 @@ module ApplicationHelper "data-pk" => "{id: \"#{object.uuid}\", key: \"#{object.class.to_s.underscore}\"}", "data-showbuttons" => "false", "data-value" => attrvalue, - :class => "editable #{'required' if required}", + :class => "editable #{'required' if required} form-control", :id => id }.merge(htmloptions) @@ -278,7 +309,7 @@ module ApplicationHelper lt += raw("add_form_selection_sources(#{selectables.to_json});\n") end - lt += raw("$('##{id}').editable({source: function() { return select_form_sources('#{dataclass}'); } });\n") + lt += raw("$('[data-name=\"#{dn}\"]').editable({source: function() { return select_form_sources('#{dataclass}'); } });\n") lt += raw("")