Commit 75bd98457ff89c434ccd95672738b57dd33a9074
Committed by
Fabio Teixeira
1 parent
75a63739
Exists in
communities_ratings
Adding disabled button to community's rating page
Signed-off-by: Fabio Teixeira <fabio1079@gmail.com> Signed-off-by: Pedro de Lyra <pedrodelyra@gmail.com>
Showing
6 changed files
with
110 additions
and
10 deletions
Show diff stats
plugins/communities_ratings/lib/communities_ratings_plugin.rb
... | ... | @@ -27,7 +27,22 @@ class CommunitiesRatingsPlugin < Noosfero::Plugin |
27 | 27 | end |
28 | 28 | end |
29 | 29 | |
30 | - def self.extra_blocks | |
30 | + # Plugin Hotspot to display the average rating | |
31 | + def display_community_average_rating community | |
32 | + unless community.nil? | |
33 | + average_rating = CommunityRating.average_rating community.id | |
34 | + | |
35 | + Proc::new { | |
36 | + render :file => 'hotspots/display_community_average_rating', | |
37 | + :locals => { | |
38 | + :profile_identifier => community.identifier, | |
39 | + :average_rating => average_rating | |
40 | + } | |
41 | + } | |
42 | + end | |
43 | + end | |
44 | + | |
45 | + def self.extra_blocks | |
31 | 46 | { |
32 | 47 | CommunitiesRatingsBlock => { :type => [Community], :position => ['1']} |
33 | 48 | } | ... | ... |
plugins/communities_ratings/style.css
... | ... | @@ -38,10 +38,57 @@ |
38 | 38 | background-image: url('public/images/small-star-positive.png'); |
39 | 39 | } |
40 | 40 | |
41 | +.medium-star-negative, .medium-star-positive { | |
42 | + background-repeat: no-repeat; | |
43 | + float: left; | |
44 | + height: 20px; | |
45 | + margin-right: 2px; | |
46 | + position: relative; | |
47 | + width: 20px; | |
48 | +} | |
49 | + | |
50 | +.medium-star-positive { | |
51 | + background-image: url('public/images/star-positive-medium.png'); | |
52 | +} | |
53 | + | |
54 | +.medium-star-negative { | |
55 | + background-image: url('public/images/star-negative-medium.png'); | |
56 | +} | |
57 | + | |
41 | 58 | .star-hide { |
42 | 59 | display: none; |
43 | 60 | } |
44 | 61 | |
62 | +.community-average-rating-container { | |
63 | + border-top: 1px dotted #D3D6DE; | |
64 | + margin-top: 20px; | |
65 | + padding-top: 10px; | |
66 | +} | |
67 | + | |
68 | +.community-average-rating-container .star-rate-text { | |
69 | + float: left; | |
70 | + margin-right: 10px; | |
71 | + padding-top: 5px; | |
72 | +} | |
73 | + | |
74 | +.community-average-rating-container .rating-invitation { | |
75 | + font-size: 14px; | |
76 | + float: left; | |
77 | + margin-right: 10px; | |
78 | + padding-top: 3px; | |
79 | +} | |
80 | + | |
81 | +.community-average-rating-container .star-container { | |
82 | + float: left; | |
83 | + width: 120px; | |
84 | +} | |
85 | + | |
86 | +.community-average-rating-container .rate-this-community { | |
87 | + border-left: 1px dotted #D3D6DE; | |
88 | + float: left; | |
89 | + padding: 4px 0px 2px 10px; | |
90 | +} | |
91 | + | |
45 | 92 | .star-rate-data { |
46 | 93 | width: 100%; |
47 | 94 | padding-top: 20px; | ... | ... |
plugins/communities_ratings/views/communities_ratings_plugin_profile/_new_rating_fields.html.erb
... | ... | @@ -57,11 +57,21 @@ |
57 | 57 | |
58 | 58 | <% elsif environment.communities_ratings_vote_once %> |
59 | 59 | <div class="star-rate-form rating-vote-once"> |
60 | - <%= _("Hi, #{current_user.name}! The administrators set that you can only vote once for this community.") %> | |
60 | + <%= _("Hi, #{current_user.name}! The administrators set that you can vote") %> | |
61 | + | |
62 | + <strong><%= 'only once' %></strong> | |
63 | + | |
64 | + <%= "for this community." %> | |
65 | + <%= render :partial => 'shared/rating_button', :locals => { :disabled => true } %> | |
61 | 66 | </div> |
62 | 67 | <% else %> |
63 | 68 | <div class="star-rate-form rating-cooldown"> |
64 | - <%= _("Hi, #{current_user.name}! The administrators set the minimum time of #{environment.communities_ratings_cooldown} hour(s) between each evaluation. You can take a ride into our web site while you wait for the next record.") %> | |
69 | + <%= _("Hi, #{current_user.name}! The administrators set the minimum time of") %> | |
70 | + <strong><%= _("%s hour(s)" % environment.communities_ratings_cooldown) %></strong> | |
71 | + <%= _("between each evaluation.") %> | |
72 | + | |
73 | + <%= render :partial => 'shared/rating_button', :locals => { :disabled => true } %> | |
74 | + | |
65 | 75 | </div> |
66 | 76 | <% end %> |
67 | 77 | ... | ... |
plugins/communities_ratings/views/hotspots/display_community_average_rating.html.erb
0 → 100644
... | ... | @@ -0,0 +1,25 @@ |
1 | +<div class="community-average-rating-container"> | |
2 | + <% if average_rating %> | |
3 | + <div class="star-rate-text"> | |
4 | + <%= _("Rating: ") %> | |
5 | + </div> | |
6 | + | |
7 | + <div class="star-container"> | |
8 | + <% (1..5).each do |star_number| %> | |
9 | + <% if star_number <= average_rating %> | |
10 | + <div class="medium-star-positive"></div> | |
11 | + <% else %> | |
12 | + <div class="medium-star-negative"></div> | |
13 | + <% end %> | |
14 | + <% end %> | |
15 | + </div> | |
16 | + <% else %> | |
17 | + <div class="rating-invitation"> | |
18 | + <%= _("Be the first to rate!") %> | |
19 | + </div> | |
20 | + <% end %> | |
21 | + | |
22 | + <div class="rate-this-community"> | |
23 | + <%= link_to _('Rate this community'), url_for(:controller => 'communities_ratings_plugin_profile', :action => 'new_rating', :profile=>profile_identifier) %> | |
24 | + </div> | |
25 | +</div> | |
0 | 26 | \ No newline at end of file | ... | ... |
plugins/communities_ratings/views/shared/_make_report_block.html.erb
... | ... | @@ -17,13 +17,7 @@ |
17 | 17 | <%= _('Report your experiences.') %> |
18 | 18 | </div> |
19 | 19 | |
20 | - <div class="button-bar"> | |
21 | - <% if logged_in? %> | |
22 | - <%= button('rate',_('Rate Community'), {:controller => 'communities_ratings_plugin_profile', :action => 'new_rating'}) %> | |
23 | - <% else %> | |
24 | - <%= button('rate',_('Rate Community'), {:controller => 'account', :action => 'login'}) %> | |
25 | - <% end %> | |
26 | - </div> | |
20 | + <%= render :partial => 'shared/rating_button', :locals => { :disabled => false } %> | |
27 | 21 | |
28 | 22 | <% unless logged_in? %> |
29 | 23 | <div class="alert"> | ... | ... |
plugins/communities_ratings/views/shared/_rating_button.html.erb
0 → 100644
... | ... | @@ -0,0 +1,9 @@ |
1 | +<div class="button-bar"> | |
2 | + <% options = disabled ? {:disabled => 'disabled', :class => 'disabled-button'} : {} %> | |
3 | + | |
4 | + <% if logged_in? %> | |
5 | + <%= button('rate',_('Rate Community'), {:controller => 'communities_ratings_plugin_profile', :action => 'new_rating'}, options) %> | |
6 | + <% else %> | |
7 | + <%= button('rate',_('Rate Community'), {:controller => 'account', :action => 'login'}, options) %> | |
8 | + <% end %> | |
9 | +</div> | |
0 | 10 | \ No newline at end of file | ... | ... |