proposals_holder.rb
2.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
class ProposalsDiscussionPlugin::ProposalsHolder < Folder
has_many :proposals, :class_name => 'ProposalsDiscussionPlugin::Proposal', :foreign_key => 'parent_id'
has_many :proposals_authors, :class_name => 'Person', :through => :children, :source => :created_by
def accept_comments?
accept_comments
end
def max_score
@max ||= [1, proposals.maximum(:comments_count)].max
end
def proposals_per_day
result = proposals.group("date(created_at)").count
fill_empty_days(result)
end
def comments_per_day
result = proposals.joins(:comments).group('date(comments.created_at)').count('comments.id')
fill_empty_days(result)
end
def most_active_participants
proposals_authors.group('profiles.id').order('count(articles.id) DESC').includes(:environment, :preferred_domain, :image)
end
def fill_empty_days(result)
from = created_at.to_date
(from..Date.today).inject({}) do |h, date|
h[date.to_s] = result[date.to_s] || 0
h
end
end
def proposal_tags
proposals.tag_counts.inject({}) do |memo,tag|
memo[tag.name] = tag.count
memo
end
end
def ranking
ProposalsDiscussionPlugin::RankingItem.joins(:proposal => :parent).where('parents_articles.id' => self.id).order(:position)
end
def compute_ranking
max_hits = proposals.maximum(:hits)
min_hits = proposals.minimum(:hits)
ranking = proposals.map do |proposal|
w = [(proposal.hits - max_hits).abs, (proposal.hits - min_hits).abs, 1].max.to_f
effective_support = (proposal.votes_for - proposal.votes_against)/w
ProposalsDiscussionPlugin::RankingItem.new(:proposal => proposal, :abstract => proposal.abstract, :votes_for => proposal.votes_for, :votes_against => proposal.votes_against, :hits => proposal.hits, :effective_support => effective_support)
end
ranking = ranking.sort_by { |p| p.effective_support.to_f }.reverse
ranking.each_with_index { |p, i| p.position = i+1 }
end
def update_ranking
new_ranking = compute_ranking
transaction do
self.ranking.destroy_all
new_ranking.each {|item| item.save!}
end
end
def cache_key_with_person(params = {}, user = nil, language = 'en')
cache_key_without_person + (user ? "-#{user.identifier}" : '')
end
alias_method_chain :cache_key, :person
end