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,6 +31,16 @@ class FriendsController < MyProfileController | ||
31 | end | 31 | end |
32 | end | 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 | protected | 44 | protected |
35 | 45 | ||
36 | class << self | 46 | class << self |
app/controllers/my_profile/memberships_controller.rb
@@ -53,6 +53,16 @@ class MembershipsController < MyProfileController | @@ -53,6 +53,16 @@ class MembershipsController < MyProfileController | ||
53 | end | 53 | end |
54 | end | 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 | protected | 66 | protected |
57 | 67 | ||
58 | def per_page | 68 | def per_page |
app/helpers/application_helper.rb
@@ -1422,17 +1422,25 @@ module ApplicationHelper | @@ -1422,17 +1422,25 @@ module ApplicationHelper | ||
1422 | def profile_suggestion_profile_connections(suggestion) | 1422 | def profile_suggestion_profile_connections(suggestion) |
1423 | profiles = suggestion.profile_connections.first(5).map do |profile| | 1423 | profiles = suggestion.profile_connections.first(5).map do |profile| |
1424 | link_to(profile_image(profile, :icon), profile.url, :class => 'profile-suggestion-connection-icon', :title => profile.name) | 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 | end | 1431 | end |
1429 | 1432 | ||
1430 | def profile_suggestion_tag_connections(suggestion) | 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 | tag.name + ', ' | 1435 | tag.name + ', ' |
1433 | end | 1436 | end |
1434 | last_tag = tags.pop | 1437 | last_tag = tags.pop |
1435 | tags << last_tag.strip.chop if last_tag.present? | 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 | end | 1445 | end |
1438 | end | 1446 | end |
public/stylesheets/application.css
@@ -4035,6 +4035,7 @@ h1#agenda-title { | @@ -4035,6 +4035,7 @@ h1#agenda-title { | ||
4035 | } | 4035 | } |
4036 | .controller-favorite_enterprises .profile-list a.profile-link, | 4036 | .controller-favorite_enterprises .profile-list a.profile-link, |
4037 | .controller-friends .profile-list a.profile-link, | 4037 | .controller-friends .profile-list a.profile-link, |
4038 | +.list-profile-connections .profile-list a.profile-link, | ||
4038 | .profiles-suggestions .profile-list a.profile-link { | 4039 | .profiles-suggestions .profile-list a.profile-link { |
4039 | text-decoration: none; | 4040 | text-decoration: none; |
4040 | text-align: center; | 4041 | text-align: center; |
@@ -4089,6 +4090,7 @@ h1#agenda-title { | @@ -4089,6 +4090,7 @@ h1#agenda-title { | ||
4089 | } | 4090 | } |
4090 | 4091 | ||
4091 | .profiles-suggestions .profile-list .extra_info a { | 4092 | .profiles-suggestions .profile-list .extra_info a { |
4093 | + text-decoration: none; | ||
4092 | padding: 0; | 4094 | padding: 0; |
4093 | } | 4095 | } |
4094 | 4096 | ||
@@ -4124,15 +4126,48 @@ h1#agenda-title { | @@ -4124,15 +4126,48 @@ h1#agenda-title { | ||
4124 | width: auto; | 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 | .box-1 .profiles-suggestions .profile-list li { | 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 | #content .common-profile-list-block .profiles-suggestions .profile-list li { | 4173 | #content .common-profile-list-block .profiles-suggestions .profile-list li { |