Mercurial > hg > soundsoftware-site
diff app/helpers/activities_helper.rb @ 1484:51364c0cd58f redmine-2.4-integration
Merge from live branch. Still need to merge manually in files overridden by plugins.
author | Chris Cannam |
---|---|
date | Wed, 15 Jan 2014 09:59:14 +0000 |
parents | 261b3d9a4903 441b66f148b6 |
children | c8d3ad483bea |
line wrap: on
line diff
--- a/app/helpers/activities_helper.rb Tue Jan 14 14:37:42 2014 +0000 +++ b/app/helpers/activities_helper.rb Wed Jan 15 09:59:14 2014 +0000 @@ -18,6 +18,7 @@ # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. module ActivitiesHelper + def sort_activity_events(events) events_by_group = events.group_by(&:event_group) sorted_events = [] @@ -30,4 +31,152 @@ end sorted_events end + + def date_of_event(e) + if e.respond_to? :updated_at + e.updated_at + elsif e.respond_to? :updated_on + e.updated_on + elsif e.respond_to? :created_on + e.created_on + elsif e.respond_to? :committed_on + e.committed_on + else + nil + end + end + + def project_activity_on_events(events) + + # Score each project for which there are any events, by giving + # each event a score based on how long ago it was (the more recent + # the better). Return a hash mapping project id to score. + + projhash = Hash.new + + events.each do |e| + if e.respond_to?(:project) + p = e.project + d = date_of_event e + if !d.nil? + dd = Date.parse d.to_s + age = Date.today - dd + score = (age < 14 ? 15-age : 1) + if projhash.key? p + projhash[p] += score + else + projhash[p] = score + end + end + end + end + projhash + end + + def projects_by_activity(user, count) + + # Return up to count of the user's project ids ordered by that user's + # recent activity, omitting any projects for which no activity + # occurred in the recent past and any projects not visible to + # the current user + + activity = Redmine::Activity::Fetcher.new(User.current, :author => user) + + # Limit scope so as to exclude issues (which non-members can add) + activity.scope = [ "changesets", "files", "documents", "news", "wiki_edits", "messages", "time_entries", "publications" ] + + days = Setting.activity_days_default.to_i + events = activity.events(Date.today - days, Date.today + 1) + projhash = project_activity_on_events(events) + projhash.keys.sort_by { |k| -projhash[k] }.first(count) + end + + def render_active_colleagues(colleagues) + + s = "" + + start = Time.now + + my_inst = "" + if ! User.current.ssamr_user_detail.nil? + my_inst = User.current.ssamr_user_detail.institution_name + end + + actives = Hash.new + for c in colleagues + u = User.find_by_id(c) + active_projects = projects_by_activity(u, 3) + if !active_projects.empty? + actives[c] = active_projects + end + end + + if actives.empty? + l(:label_no_active_colleagues) + else + + s << "<dl>" + for c in actives.keys.sample(10) + u = User.find_by_id(c) + s << "<dt>" + s << avatar(u, :size => '24') + s << "<span class='user'>" + s << h(u.name) + s << "</span>" + if !u.ssamr_user_detail.nil? + inst = u.ssamr_user_detail.institution_name + if inst != "" and inst != my_inst + s << " - <span class='institution'>" + s << h(u.ssamr_user_detail.institution_name) + s << "</span>" + end + end + s << "</dt>" + s << "<dd>" + s << "<span class='active'>" + s << (actives[c].map { |p| link_to_project(p) }.join ", ") + s << "</span>" + end + s << "</dl>" + + finish = Time.now + logger.info "render_active_colleagues: took #{finish-start}" + + s.html_safe + end + end + + def busy_projects(events, count) + + # Return a list of count projects randomly selected from amongst + # the busiest projects represented by the given activity events + + projhash = project_activity_on_events(events) + + # pick N highest values and use cutoff value as selection threshold + threshold = projhash.values.sort.last(count).first + + # select projects above threshold and pick N from them randomly + busy = projhash.keys.select { |k| projhash[k] >= threshold }.sample(count) + + # return projects rather than just ids + busy.map { |pid| Project.find(pid) } + end + + def busy_institutions(events, count) + authors = events.map do |e| + e.event_author unless !e.respond_to?(:event_author) + end.compact + institutions = authors.map do |a| + if a.respond_to?(:ssamr_user_detail) and !a.ssamr_user_detail.nil? + a.ssamr_user_detail.institution_name + end + end + insthash = institutions.compact.sort.group_by { |i| i } + insthash = insthash.merge(insthash) { |k,v| v.length } + threshold = insthash.values.sort.last(count).first + insthash.keys.select { |k| insthash[k] >= threshold }.sample(count) + end + +>>>>>>> other end