Commit 87f147287451f9a57ecb46df844d57f83c2dff56
Exists in
master
and in
27 other branches
Merge branch 'stoa' of gitlab.com:colivre/noosfero into stoa
Showing
4 changed files
with
74 additions
and
11 deletions
Show diff stats
app/controllers/my_profile/friends_controller.rb
... | ... | @@ -31,6 +31,16 @@ class FriendsController < MyProfileController |
31 | 31 | end |
32 | 32 | end |
33 | 33 | |
34 | + def connections | |
35 | + @suggestion = profile.profile_suggestions.of_person.enabled.find_by_suggestion_id(params[:id]) | |
36 | + if @suggestion | |
37 | + @tags = @suggestion.tag_connections | |
38 | + @profiles = @suggestion.profile_connections | |
39 | + else | |
40 | + redirect_to :action => 'suggest' | |
41 | + end | |
42 | + end | |
43 | + | |
34 | 44 | protected |
35 | 45 | |
36 | 46 | class << self | ... | ... |
app/controllers/my_profile/memberships_controller.rb
... | ... | @@ -53,6 +53,16 @@ class MembershipsController < MyProfileController |
53 | 53 | end |
54 | 54 | end |
55 | 55 | |
56 | + def connections | |
57 | + @suggestion = profile.profile_suggestions.of_community.enabled.find_by_suggestion_id(params[:id]) | |
58 | + if @suggestion | |
59 | + @tags = @suggestion.tag_connections | |
60 | + @profiles = @suggestion.profile_connections | |
61 | + else | |
62 | + redirect_to :action => 'suggest' | |
63 | + end | |
64 | + end | |
65 | + | |
56 | 66 | protected |
57 | 67 | |
58 | 68 | def per_page | ... | ... |
app/helpers/application_helper.rb
... | ... | @@ -1422,17 +1422,25 @@ module ApplicationHelper |
1422 | 1422 | def profile_suggestion_profile_connections(suggestion) |
1423 | 1423 | profiles = suggestion.profile_connections.first(5).map do |profile| |
1424 | 1424 | link_to(profile_image(profile, :icon), profile.url, :class => 'profile-suggestion-connection-icon', :title => profile.name) |
1425 | - end.join | |
1426 | - extra = suggestion.profile_connections.count > 5 ? "<big> +#{suggestion.profile_connections.count - 5}</big>" : '' | |
1427 | - content_tag(:div, profiles + extra, :class => 'profile-connections') | |
1425 | + end | |
1426 | + | |
1427 | + controller_target = suggestion.suggestion_type == 'Person' ? :friends : :memberships | |
1428 | + profiles << link_to("<big> +#{suggestion.profile_connections.count - 5}</big>", :controller => controller_target, :action => :connections, :id => suggestion.suggestion_id) if suggestion.profile_connections.count > 5 | |
1429 | + | |
1430 | + content_tag(:div, profiles.join , :class => 'profile-connections') | |
1428 | 1431 | end |
1429 | 1432 | |
1430 | 1433 | def profile_suggestion_tag_connections(suggestion) |
1431 | - tags = suggestion.tag_connections.map do |tag| | |
1434 | + tags = suggestion.tag_connections.first(4).map do |tag| | |
1432 | 1435 | tag.name + ', ' |
1433 | 1436 | end |
1434 | 1437 | last_tag = tags.pop |
1435 | 1438 | tags << last_tag.strip.chop if last_tag.present? |
1436 | - content_tag(:div, tags.join, :class => 'tag-connections', :title => tags.join) | |
1439 | + title = tags.join | |
1440 | + | |
1441 | + controller_target = suggestion.suggestion_type == 'Person' ? :friends : :memberships | |
1442 | + tags << link_to('...', :controller => controller_target, :action => :connections, :id => suggestion.suggestion_id) if suggestion.tag_connections.count > 4 | |
1443 | + | |
1444 | + content_tag(:div, tags.join, :class => 'tag-connections', :title => title) | |
1437 | 1445 | end |
1438 | 1446 | end | ... | ... |
public/stylesheets/application.css
... | ... | @@ -4035,6 +4035,7 @@ h1#agenda-title { |
4035 | 4035 | } |
4036 | 4036 | .controller-favorite_enterprises .profile-list a.profile-link, |
4037 | 4037 | .controller-friends .profile-list a.profile-link, |
4038 | +.list-profile-connections .profile-list a.profile-link, | |
4038 | 4039 | .profiles-suggestions .profile-list a.profile-link { |
4039 | 4040 | text-decoration: none; |
4040 | 4041 | text-align: center; |
... | ... | @@ -4089,6 +4090,7 @@ h1#agenda-title { |
4089 | 4090 | } |
4090 | 4091 | |
4091 | 4092 | .profiles-suggestions .profile-list .extra_info a { |
4093 | + text-decoration: none; | |
4092 | 4094 | padding: 0; |
4093 | 4095 | } |
4094 | 4096 | |
... | ... | @@ -4124,15 +4126,48 @@ h1#agenda-title { |
4124 | 4126 | width: auto; |
4125 | 4127 | } |
4126 | 4128 | |
4127 | -.profiles-suggestions .profile-list li { | |
4128 | - width: 85px; | |
4129 | - max-width: 85px; | |
4129 | +.list-profile-connections .profile-list li { | |
4130 | + border: 1px solid transparent; | |
4131 | + -moz-border-radius: 5px; | |
4132 | + -webkit-border-radius: 5px; | |
4133 | +} | |
4134 | + | |
4135 | +.list-profile-connections .profile-list li:hover, | |
4136 | +.profiles-suggestions .profile-list li:hover { | |
4137 | + border: 1px solid #ccc; | |
4138 | + background: #eee; | |
4130 | 4139 | } |
4131 | 4140 | |
4132 | 4141 | .box-1 .profiles-suggestions .profile-list li { |
4133 | - width: 76px; | |
4134 | - max-width: 76px; | |
4135 | - border: 2px solid transparent; | |
4142 | + width: 100px; | |
4143 | + max-width: 100px; | |
4144 | + height: 130px; | |
4145 | + max-height: 100%; | |
4146 | + overflow: hidden; | |
4147 | + text-overflow: ellipsis; | |
4148 | +} | |
4149 | + | |
4150 | +.box-1 .profiles-suggestions .profile-list .remove-suggestion, | |
4151 | +.box-1 .profiles-suggestions .profile-list li > a { | |
4152 | + text-decoration: none; | |
4153 | +} | |
4154 | + | |
4155 | +.common-profile-list-block .profiles-suggestions .profile-list li { | |
4156 | + width: 100%; | |
4157 | + max-width: 100%; | |
4158 | + height: 70px; | |
4159 | + max-height: 100%; | |
4160 | + overflow: hidden; | |
4161 | + text-overflow: ellipsis; | |
4162 | +} | |
4163 | + | |
4164 | +.common-profile-list-block .profiles-suggestions .profile-list li img { | |
4165 | + float: left; | |
4166 | +} | |
4167 | + | |
4168 | +#content .common-profile-list-block .profiles-suggestions .profile-list a.profile-link { | |
4169 | + text-align: left; | |
4170 | + position: relative; | |
4136 | 4171 | } |
4137 | 4172 | |
4138 | 4173 | #content .common-profile-list-block .profiles-suggestions .profile-list li { | ... | ... |