Module: Hyrax::HyraxHelperBehavior

Constant Summary

Constants included from CitationsBehaviors::TitleBehavior

CitationsBehaviors::TitleBehavior::EXPANDED_NOCAPS, CitationsBehaviors::TitleBehavior::TITLE_NOCAPS

Instance Method Summary collapse

Methods included from WorksHelper

#available_collections

Methods included from AttributesHelper

#conform_field, #conform_options, #schema, #view_options_for, #view_options_without_flexibility

Methods included from WorkflowsHelper

#workflow_restriction?

Methods included from WorkFormHelper

#admin_set_options, #form_file_set_select_for, #form_progress_sections_for, #form_tab_label_for, #form_tabs_for

Methods included from PermissionLevelsHelper

#configured_owner_permission_levels, #configured_permission_levels, #configured_permission_options

Methods included from MembershipHelper

#add_collection_from_params, #member_of_collections_json, #work_members_json

Methods included from IiifHelper

#iiif_viewer_display, #iiif_viewer_display_partial, #universal_viewer_base_url, #universal_viewer_config_url

Methods included from DashboardHelperBehavior

#link_to_works, #number_of_collections, #number_of_files, #number_of_works, #on_the_dashboard?

Methods included from ChartsHelper

#hash_to_chart

Methods included from CollectionsHelper

#append_collection_type_url, #available_child_collections, #available_parent_collections_data, #button_for_remove_from_collection, #button_for_remove_selected_from_collection, #collection_brandable?, #collection_discoverable?, #collection_member_sort_fields, #collection_metadata_label, #collection_metadata_value, #collection_permission_template_form_for, #collection_search_parameters?, #collection_sharable?, #collection_type_label, #collection_type_label_for, #has_collection_search_parameters?, #present_terms, #render_collection_links, #render_other_collection_links, #single_item_action_remove_form_fields

Methods included from LeaseHelper

#assets_under_lease, #assets_with_deactivated_leases, #assets_with_expired_leases, #lease_enforced?, #lease_history

Methods included from EmbargoHelper

#assets_under_embargo, #assets_with_deactivated_embargoes, #assets_with_expired_embargoes, #embargo_enforced?, #embargo_history

Methods included from AbilityHelper

#render_visibility_link, #visibility_badge, #visibility_options

Methods included from FileSetHelper

#display_media_download_link?, #media_display, #media_display_partial, #parent_path

Methods included from TitleHelper

#application_name, #construct_page_title, #curation_concern_page_title, #default_page_title, #title_presenter

Methods included from ContactFormHelper

#contact_form_issue_type_options

Methods included from CitationsBehavior

#export_as_apa_citation, #export_as_chicago_citation, #export_as_mla_citation, #export_as_openurl_ctx_kev

Methods included from CitationsBehaviors::TitleBehavior

#chicago_citation_title, #mla_citation_title, #process_title_parts, #setup_title_info

Methods included from CitationsBehaviors::CommonBehavior

#clean_end_punctuation, #persistent_url

Methods included from CitationsBehaviors::NameBehavior

#abbreviate_name, #all_authors, #author_list, #given_name_first, #surname_first

Methods included from CitationsBehaviors::PublicationBehavior

#setup_pub_date, #setup_pub_info, #setup_pub_place, #setup_pub_publisher

Instance Method Details

#available_admin_sets_for_creating_works(ability:) ⇒ Array<String>

Returns the list of admin sets available for creating works for this user.

Returns:

  • (Array<String>)

    the list of admin sets available for creating works for this user



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 27

def available_admin_sets_for_creating_works(ability:)
  return [] unless Flipflop.assign_admin_set?
  return [] unless ability

  source_ids = Hyrax::Collections::PermissionsService.source_ids_for_deposit(ability:, source_type: 'admin_set')

  admin_sets_list = Hyrax.query_service.find_many_by_ids(ids: source_ids).map do |source|
    [source.title.first, source.id]
  end

  # Sorts the default admin set to be first, then the rest by title.
  admin_sets_list.sort do |a, b|
    if Hyrax::AdminSetCreateService.default_admin_set?(id: a[1])
      -1
    elsif Hyrax::AdminSetCreateService.default_admin_set?(id: b[1])
      1
    else
      a[0] <=> b[0]
    end
  end
end

#available_translationsHash{String => String}

Which translations are available for the user to select

Returns:

  • (Hash{String => String})

    locale abbreviations as keys and flags as values



59
60
61
62
63
64
65
66
67
68
69
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 59

def available_translations
  {
    'de' => 'Deutsch',
    'en' => 'English',
    'es' => 'Español',
    'fr' => 'Français',
    'it' => 'Italiano',
    'pt-BR' => 'Português do Brasil',
    'zh' => '中文'
  }
end

#available_user_groups(ability:) ⇒ Array<String>

Returns the list of all user groups.

Returns:

  • (Array<String>)

    the list of all user groups



51
52
53
54
55
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 51

def available_user_groups(ability:)
  return ::User.group_service.role_names if ability.admin?

  ability.user_groups
end


73
74
75
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 73

def banner_image
  Hyrax.config.banner_image
end

#cast_to_date_time_format(value, format:) ⇒ String

Parameters:

  • value (Object)

    the thing we’ll attempt to cast to a formatted date.

  • format (String)

    the ‘DateTime.strftime` format string

Returns:

  • (String)

See Also:



343
344
345
346
347
348
349
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 343

def cast_to_date_time_format(value, format:)
  return value.strftime(format).to_s if value.respond_to?(:strftime)

  (Time.zone.parse(value)&.strftime(format) || value).to_s
rescue ArgumentError, TypeError
  value.to_s
end

#collection_thumbnail(_document, _image_options = {}, _url_options = {}) ⇒ Object

Used by the gallery view



313
314
315
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 313

def collection_thumbnail(_document, _image_options = {}, _url_options = {})
  tag.span("", class: [Hyrax::ModelIcon.css_class_for(::Collection), "collection-icon-search"])
end

#collection_title_by_id(id) ⇒ Object



317
318
319
320
321
322
323
324
325
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 317

def collection_title_by_id(id)
  solr_docs = controller.blacklight_config.repository.find(id).docs
  return nil if solr_docs.empty?
  solr_field = solr_docs.first["title_tesim"]
  return nil if solr_field.nil?
  solr_field.first
rescue Blacklight::Exceptions::RecordNotFound
  nil
end

#current_search_parametersObject

Only display the current search parameters if the user is not in the dashboard. Otherwise, search defaults to the user’s works and not all of Hyrax.



292
293
294
295
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 292

def current_search_parameters
  return if on_the_dashboard?
  params[:q]
end

#human_readable_date(options) ⇒ Date

A Blacklight helper_method

Parameters:

  • options (Hash)

    from blacklight invocation of helper_method

Returns:

  • (Date)

See Also:



159
160
161
162
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 159

def human_readable_date(options)
  value = options[:value].first
  Date.parse(value).to_formatted_s(:standard)
end

Uses Rails auto_link to add links to fields

Parameters:

  • field (String, Hash)

    string to format and escape, or a hash as per helper_method

  • show_link (Boolean) (defaults to: true)

Options Hash (field):

  • :document (SolrDocument)
  • :field (String)

    name of the solr field

  • :config (Blacklight::Configuration::IndexField, Blacklight::Configuration::ShowField)
  • :value (Array)

    array of values for the field

Returns:

  • (ActiveSupport::SafeBuffer)


214
215
216
217
218
219
220
221
222
223
224
225
226
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 214

def iconify_auto_link(field, show_link = true)
  if field.is_a? Hash
    options = field[:config].separator_options || {}
    text = field[:value].to_sentence(options)
  else
    text = field
  end
  # this block is only executed when a link is inserted;
  # if we pass text containing no links, it just returns text.
  auto_link(html_escape(text)) do |value|
    "<span class='fa fa-external-link'></span>#{('&nbsp;' + value) if show_link}"
  end
end

A Blacklight helper_method

Parameters:

  • options (Hash{Symbol=>Object})

    Blacklight sends :document, :field, :config, :value and whatever else was in options

Options Hash (options):

  • :value (Array{String})
  • :config (Hash)

    including {:field_name => “my_name”}

  • :document (Hash)
  • :value (Array{String})

    the strings you might otherwise have passed to this method singly

Returns:

  • (ActiveSupport::SafeBuffer)

    the html_safe link

Raises:

  • (ArgumentError)


171
172
173
174
175
176
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 171

def index_field_link(options)
  raise ArgumentError unless options[:config] && options[:config][:field_name]
  name = options[:config][:field_name]
  links = options[:value].map { |item| link_to_field(name, item, item) }
  safe_join(links, ", ")
end

A Blacklight index field helper_method

Parameters:

  • options (Hash)

    from blacklight helper_method invocation. Maps license URIs to links with labels.

Returns:

  • (ActiveSupport::SafeBuffer)

    license links, html_safe



260
261
262
263
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 260

def license_links(options)
  service = Hyrax.config.license_service_class.new
  to_sentence(options[:value].map { |right| link_to service.label(right), right })
end

A Blacklight helper_method

Examples:

link_to_each_facet_field({ value: "Imaging > Object Photography", config: { helper_facet: :document_types_sim }})
```html
<a href=\"/catalog?f%5Bdocument_types_sim%5D%5B%5D=Imaging\">Imaging</a> &gt; <a href=\"/catalog?f%5Bdocument_types_sim%5D%5B%5D=Object+Photography\">Object Photography</a>
```

Parameters:

  • options (Hash)

    from blacklight invocation of helper_method

Options Hash (options):

  • :value (Array<#strip>)
  • ] (Hash)

    :config Example: { separator: ‘>’, helper_facet: :document_types_sim, output_separator: ‘::’ }

Returns:

  • the html_safe facet links separated by the given separator (default: ‘ > ’) to indicate facet hierarchy

Raises:

  • KeyError when the options are note properly configured



192
193
194
195
196
197
198
199
200
201
202
203
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 192

def link_to_each_facet_field(options)
  config = options.fetch(:config)
  separator = config.fetch(:separator, ' > ')
  output_separator = config.fetch(:output_separator, separator)
  facet_search = config.fetch(:helper_facet)
  facet_fields = Array.wrap(options.fetch(:value)).first.split(separator).map(&:strip)

  facet_links = facet_fields.map do |type|
    link_to(type, main_app.search_catalog_path(f: { facet_search => [type] }))
  end
  safe_join(facet_links, output_separator)
end

Returns the html_safe link.

Parameters:

  • item (Object)
  • field (String)

Returns:

  • (ActiveSupport::SafeBuffer)

    the html_safe link



120
121
122
123
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 120

def link_to_facet(item, field)
  path = main_app.search_catalog_path(search_state.add_facet_params_and_redirect(field, item))
  link_to(item, path)
end

Returns the html_safe link.

Parameters:

  • values (Array{String})

    strings to display

  • solr_field (String)

    name of the solr field to link to, without its suffix (:facetable)

  • empty_message (String) (defaults to: "No value entered")

    message to display if no values are passed in

  • separator (String) (defaults to: ", ")

    value to join with

Returns:

  • (ActiveSupport::SafeBuffer)

    the html_safe link



130
131
132
133
134
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 130

def link_to_facet_list(values, solr_field, empty_message = "No value entered", separator = ", ")
  return empty_message if values.blank?
  facet_field = solr_field.to_s + "_sim"
  safe_join(values.map { |item| link_to_facet(item, facet_field) }, separator)
end

Returns the html_safe link.

Parameters:

  • name (String)

    field name

  • value (String)

    field value

  • label (String) (defaults to: nil)

    defaults to value

  • facet_hash (Hash) (defaults to: {})

    first argument to Blacklight::SearchState.new

Returns:

  • (ActiveSupport::SafeBuffer)

    the html_safe link

See Also:

  • Blacklight::SearchState#initialize


142
143
144
145
146
147
148
149
150
151
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 142

def link_to_field(name, value, label = nil, facet_hash = {})
  label ||= value
  params = {}
  if name.present?
    params[:search_field] = name
    params[:q] = "\"#{value}\""
  end
  state = search_state_with_facets(params, facet_hash)
  link_to(label, main_app.search_catalog_path(state))
end

Sometimes a Blacklight index field helper_method rubocop:disable Metrics/CyclomaticComplexity

Parameters:

  • args (String, User, Hash{Symbol=>Array})

    if a hash, the user_key must be under :value

Returns:

  • (ActiveSupport::SafeBuffer)

    the html_safe link



232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 232

def link_to_profile(args)
  user_or_key = args.is_a?(Hash) ? args[:value].first : args
  user = case user_or_key
         when User
           user_or_key
         when String
           ::User.find_by_user_key(user_or_key)
         end
  return user_or_key if user.nil?
  text = user.respond_to?(:name) ? user.name : user_or_key
  user_path_params = [user]

  # Oh the antics, because in some cases (stares at
  # jobs/content_deposit_event_job_spec.rb) the controller is nil,
  # which means calling params will raise a NoMethodError.  I also
  # suppose it's possible that the controller won't have a set
  # params. These precautions should help with that.  I'd love to
  # use params[:locale] in this case, but the & try syntax doesn't
  # work with that.  So you get this lovely bit of logic.
  locale = controller&.params&.fetch(:locale, nil) || controller&.params&.fetch('locale', nil)
  user_path_params << { locale: locale } if locale
  link_to text, Hyrax::Engine.routes.url_helpers.user_path(*user_path_params)
end


285
286
287
288
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 285

def link_to_telephone(user)
  return unless user
  link_to user.telephone, "wtai://wp/mc;#{user.telephone}" if user.telephone
end

#orcid_label(style_class = '') ⇒ Object



77
78
79
80
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 77

def orcid_label(style_class = '')
  safe_join([image_tag('orcid.png', alt: t('hyrax.user_profile.orcid.alt'), class: style_class),
             t('hyrax.user_profile.orcid.label')], ' ')
end

#render_notifications(user:) ⇒ Object

Parameters:



93
94
95
96
97
98
99
100
101
102
103
104
105
106
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 93

def render_notifications(user:)
  mailbox = UserMailbox.new(user)
  unread_notifications = mailbox.unread_count
  link_to(hyrax.notifications_path,
          'aria-description' => mailbox.label(params[:locale]),
          class: 'notify-number nav-link') do
    capture do
      concat tag.span('', class: 'fa fa-bell', 'aria-label': t('hyrax.admin.sidebar.notifications'))
      concat "\n"
      concat tag.span(unread_notifications,
                         class: count_classes_for(unread_notifications))
    end
  end
end

A Blacklight index field helper_method

Parameters:

  • options (Hash)

    from blacklight helper_method invocation. Maps rights statement URIs to links with labels.

Returns:

  • (ActiveSupport::SafeBuffer)

    rights statement links, html_safe



268
269
270
271
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 268

def rights_statement_links(options)
  service = Hyrax.config.rights_statement_service_class.new
  to_sentence(options[:value].map { |right| link_to service.label(right), right })
end

#search_form_actionString

Returns the appropriate action url for our search form (depending on our current page).

Returns:

  • (String)

    the appropriate action url for our search form (depending on our current page)



298
299
300
301
302
303
304
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 298

def search_form_action
  if on_the_dashboard?
    search_action_for_dashboard
  else
    main_app.search_catalog_path
  end
end

#show_transfer_request_title(req) ⇒ Object

Parameters:



109
110
111
112
113
114
115
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 109

def show_transfer_request_title(req)
  if req.deleted_work? || req.canceled?
    req.to_s
  else
    link_to(req.to_s, [main_app, req.work])
  end
end

#suppressed_to_status(value) ⇒ String

A Blacklight facet field helper_method

Parameters:

  • value (String)

    from blacklight helper_method invocation.

Returns:

  • (String)

    the decoded meaning of the boolean field



276
277
278
279
280
281
282
283
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 276

def suppressed_to_status(value)
  case value
  when 'false'
    t('hyrax.admin.workflows.index.tabs.published')
  else
    t('hyrax.admin.workflows.index.tabs.under_review')
  end
end

#thumbnail_label_for(object:) ⇒ String

Returns a label for the object’s thumbnail.

Parameters:

  • an (Object)

    object that might have a thumbnail

Returns:

  • (String)

    a label for the object’s thumbnail



331
332
333
334
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 331

def thumbnail_label_for(object:)
  object.try(:thumbnail_title).presence ||
    ""
end

#user_display_name_and_key(user_key) ⇒ Object



306
307
308
309
310
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 306

def user_display_name_and_key(user_key)
  user = ::User.find_by_user_key(user_key)
  return user_key if user.nil?
  user.respond_to?(:name) ? "#{user.name} (#{user_key})" : user_key
end

#zotero_label(opts = {}) ⇒ Object



82
83
84
85
86
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 82

def zotero_label(opts = {})
  html_class = opts[:html_class] || ''
  safe_join([image_tag('zotero.png', alt: t('hyrax.user_profile.zotero.alt'), class: html_class),
             t('hyrax.user_profile.zotero.label')], ' ')
end

#zotero_profile_url(zotero_user_id) ⇒ Object



88
89
90
# File 'app/helpers/hyrax/hyrax_helper_behavior.rb', line 88

def zotero_profile_url(zotero_user_id)
  "https://www.zotero.org/users/#{zotero_user_id}"
end