Skip to:
Content

BuddyPress.org

Opened 15 years ago

Closed 15 years ago

Last modified 14 years ago

#1681 closed defect (bug) (fixed)

avatar in comment is wrong (new theme)

Reported by: arturo84's profile arturo84 Owned by:
Milestone: 1.2 Priority: major
Severity: Version:
Component: Core Keywords:
Cc:

Description

in the new theme, in comments to an article in the avatar of users who leave the comment is the same user logged in and not the gravatar's avatar or the generated avatar.

Change History (3)

#1 in reply to: ↑ description @arturo84
15 years ago

Replying to arturo84:

in the new theme, in comments to an article in the avatar of users who leave the comment is the same user logged in and not the gravatar's avatar or the generated avatar.

the same is in the "old" theme.

#2 @apeatling
15 years ago

  • Resolution set to fixed
  • Status changed from new to closed

(In [2417]) Fixes #1681

#3 @lgedeon
14 years ago

  • Component set to Core

A very similar problem still occurs, but I found a solution and learned a few things along the way that might help with other BuddyPress avatar problems.

Full text at: <a href="http://luke.gedeon.name/buddypress-wrong-avatar-fix.html">http://luke.gedeon.name/buddypress-wrong-avatar-fix.html</a>

What I found:

In the file /wp-content/plugins/buddypress/bp-core/bp-core-avatars.php, lines 344 and following contain the following code:

global $authordata;
if ( is_object( $user ) )
$id = $user->user_id;
else if ( is_numeric( $user ) )
$id = $user;
else
$id = $authordata->ID;

if ( empty( $id ) )
return $avatar;

I think that last “if statement” may be there to catch cases where the commenter does not have a BuddyPress account (which is the majority on my site at this point). However, if you look closely at the block just above the “if ( empty( $id))” you will notice $id is never going to be empty at this point.

That suggests two possible solutions.

Solution 1:

I have not tested this, but it makes sense that you could move the last “if statement” above the first “if statement.” That way you can check for “empty( $id )” before it gets set to”$authordata->ID”

Solution 2:

I found it works quite well to add these lines just under the last “if statement.”

if ( is_string( $user ) )
return $avatar;

This will catch any case where an email is sent as input, which is what all (most) non-buddypress themes send. Cases where numbers or objects are sent (the BuddyPress method) will be handled normally.

I am going to spend a little more time getting familiar with BuddyPress and then try to get dev access so I can get this fix into a future release of BuddyPress. In the mean-time, we will have to just do it as a hack.

Note: See TracTickets for help on using tickets.