You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

users_helper.rb 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006-2022 Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. module UsersHelper
  19. include ApplicationHelper
  20. def users_status_options_for_select(selected)
  21. user_count_by_status = User.group('status').count.to_hash
  22. options_for_select([[l(:label_all), '']] + (User.valid_statuses.map {|c| ["#{l('status_' + User::LABEL_BY_STATUS[c])} (#{user_count_by_status[c].to_i})", c]}), selected.to_s)
  23. end
  24. def user_mail_notification_options(user)
  25. user.valid_notification_options.collect {|o| [l(o.last), o.first]}
  26. end
  27. def default_issue_query_options(user)
  28. global_queries = IssueQuery.for_all_projects
  29. global_public_queries = global_queries.only_public
  30. global_user_queries = global_queries.where(user_id: user.id).where.not(id: global_public_queries.pluck(:id))
  31. label = user == User.current ? 'label_my_queries' : 'label_default_queries.for_this_user'
  32. grouped = {
  33. l('label_default_queries.for_all_users') => global_public_queries.pluck(:name, :id),
  34. l(".#{label}") => global_user_queries.pluck(:name, :id),
  35. }
  36. grouped_options_for_select(grouped, user.pref.default_issue_query)
  37. end
  38. def default_project_query_options(user)
  39. global_queries = ProjectQuery
  40. global_public_queries = global_queries.only_public
  41. global_user_queries = global_queries.where(user_id: user.id).where.not(id: global_public_queries.ids)
  42. label = user == User.current ? 'label_my_queries' : 'label_default_queries.for_this_user'
  43. grouped = {
  44. l('label_default_queries.for_all_users') => global_public_queries.pluck(:name, :id),
  45. l(".#{label}") => global_user_queries.pluck(:name, :id),
  46. }
  47. grouped_options_for_select(grouped, user.pref.default_project_query)
  48. end
  49. def textarea_font_options
  50. [[l(:label_font_default), '']] + UserPreference::TEXTAREA_FONT_OPTIONS.map {|o| [l("label_font_#{o}"), o]}
  51. end
  52. def history_default_tab_options
  53. [[l('label_issue_history_notes'), 'notes'],
  54. [l('label_history'), 'history'],
  55. [l('label_issue_history_properties'), 'properties'],
  56. [l('label_time_entry_plural'), 'time_entries'],
  57. [l('label_associated_revisions'), 'changesets'],
  58. [l('label_last_tab_visited'), 'last_tab_visited']]
  59. end
  60. def change_status_link(user)
  61. url = {:controller => 'users', :action => 'update', :id => user, :page => params[:page], :status => params[:status], :tab => nil}
  62. if user.locked?
  63. link_to l(:button_unlock), url.merge(:user => {:status => User::STATUS_ACTIVE}), :method => :put, :class => 'icon icon-unlock'
  64. elsif user.registered?
  65. link_to l(:button_activate), url.merge(:user => {:status => User::STATUS_ACTIVE}), :method => :put, :class => 'icon icon-unlock'
  66. elsif user != User.current
  67. link_to l(:button_lock), url.merge(:user => {:status => User::STATUS_LOCKED}), :method => :put, :class => 'icon icon-lock'
  68. end
  69. end
  70. def additional_emails_link(user)
  71. if user.email_addresses.count > 1 || Setting.max_additional_emails.to_i > 0
  72. link_to l(:label_email_address_plural), user_email_addresses_path(@user), :class => 'icon icon-email-add', :remote => true
  73. end
  74. end
  75. def user_emails(user)
  76. emails = [user.mail]
  77. emails += user.email_addresses.order(:id).where(:is_default => false).pluck(:address)
  78. emails.map {|email| mail_to(email, nil)}.join(', ').html_safe
  79. end
  80. def user_settings_tabs
  81. tabs =
  82. [
  83. {:name => 'general', :partial => 'users/general', :label => :label_general},
  84. {:name => 'memberships', :partial => 'users/memberships', :label => :label_project_plural}
  85. ]
  86. if Group.givable.any?
  87. tabs.insert 1, {:name => 'groups', :partial => 'users/groups', :label => :label_group_plural}
  88. end
  89. tabs
  90. end
  91. def csv_content(column_name, user)
  92. case column_name
  93. when 'status'
  94. l("status_#{User::LABEL_BY_STATUS[user.status]}")
  95. when 'twofa_scheme'
  96. if user.twofa_active?
  97. l("twofa__#{user.twofa_scheme}__name")
  98. else
  99. l(:label_disabled)
  100. end
  101. else
  102. user.send(column_name)
  103. end
  104. end
  105. def users_to_csv(users)
  106. Redmine::Export::CSV.generate(:encoding => params[:encoding]) do |csv|
  107. columns = [
  108. 'login',
  109. 'firstname',
  110. 'lastname',
  111. 'mail',
  112. 'admin',
  113. 'status',
  114. 'twofa_scheme',
  115. 'created_on',
  116. 'updated_on',
  117. 'last_login_on',
  118. 'passwd_changed_on'
  119. ]
  120. user_custom_fields = UserCustomField.sorted
  121. # csv header fields
  122. csv << columns.map {|column| l('field_' + column)} + user_custom_fields.pluck(:name)
  123. # csv lines
  124. users = users.preload(:custom_values)
  125. users.each do |user|
  126. values = columns.map {|c| csv_content(c, user)} +
  127. user_custom_fields.map {|custom_field| user.custom_value_for(custom_field)}
  128. csv << values.map do |value|
  129. format_object(value, false) do |v|
  130. case v.class.name
  131. when 'Float'
  132. sprintf('%.2f', v).gsub('.', l(:general_csv_decimal_separator))
  133. else
  134. v
  135. end
  136. end
  137. end
  138. end
  139. end
  140. end
  141. end