diff --git a/app/helpers/issues_controller_helper.rb b/app/helpers/issues_controller_helper.rb deleted file mode 100644 index fbeedb1..0000000 --- a/app/helpers/issues_controller_helper.rb +++ /dev/null @@ -1,38 +0,0 @@ -module IssuesControllerHelper - def map_users_to_states(users, issue) - mapping = {} - journals = Journal.where("journalized_type = 'issue' AND journalized_id = :id", {id: issue.id}) - journals.each do |journal| - details = JournalDetail.where("journal_id = :id", {id: journal.id}) - assignee = nil - status = nil - details.each do |detail| - if detail.prop_key == 'status_id' - status = detail.value - end - if detail.prop_key == 'assigned_to_id' - assignee = detail.value - end - end - if assignee && status - if !mapping.key?(assignee) - mapping[assignee] = [] - end - unless mapping[assignee].include? status - mapping[assignee].push(status) - end - end - end - mapping.to_json.html_safe - end - - def status_listing - statuses = IssueStatus.order("position") - listing = {} - statuses.each do |status| - listing[status.id] = "#{status.name}" - end - listing.to_json.html_safe - end - -end \ No newline at end of file diff --git a/app/views/hooks/redmine_mentions_suggestions/_edit_mentionable.html.erb b/app/views/hooks/redmine_mentions_suggestions/_edit_mentionable.html.erb index a1e7345..dfa9941 100644 --- a/app/views/hooks/redmine_mentions_suggestions/_edit_mentionable.html.erb +++ b/app/views/hooks/redmine_mentions_suggestions/_edit_mentionable.html.erb @@ -1,18 +1,46 @@ -<% regex_find = '/\B'+Setting.plugin_redmine_mentions['trigger']+'(\w*)$/i'%> +<% regex_find = '/\B'+'@'+'(\w*)$/i'%> <% if @project %> <% users = @project.users.to_a.delete_if{|u| (u.type != 'User' || u.mail.empty?)}%> <% else %> <% users = User.active.to_a.delete_if{|u| (u.type != 'User' || u.mail.empty?)}%> <% end %> -<% users_regex = users.collect{|u| "#{Setting.plugin_redmine_mentions['trigger']}#{u.login}"}.join('|')%> +<% users_regex = users.collect{|u| "#{'@'}#{u.login}"}.join('|')%> <% regex_highlight = '/\B('+users_regex+')\b/g' %> + +<% mapping = {} %> +<% journals = Journal.where("journalized_type = 'issue' AND journalized_id = :id", {id: @issue.id}) %> +<% journals.each do |journal| %> +<% details = JournalDetail.where("journal_id = :id", {id: journal.id}) %> +<% assignee = nil %> +<% status = nil %> +<% details.each do |detail| %> +<% if detail.prop_key == 'status_id' %> +<% status = detail.value %> +<% end %> +<% if detail.prop_key == 'assigned_to_id' %> +<% assignee = detail.value %> +<% end %> +<% end %> +<% if assignee && status %> +<% if !mapping.key?(assignee) %> +<% mapping[assignee] = [] %> +<% end %> +<% unless mapping[assignee].include? status %> +<% mapping[assignee].push(status) %> +<% end %> +<% end %> +<% end %> + +<% listing = {} %> +<% IssueStatus.order("position").each { |status| listing[status.id] = "#{status.name}" } %> +