Gancho de Buddypress después de cargar la imagen

2 minutos de lectura

Quiero actualizar un campo user_meta personalizado cuando un usuario carga una nueva imagen (no un avatar).

Código de trabajo para cargar avatar

add_action('xprofile_avatar_uploaded', 'callback');

function callback($user_id, $type)
{
   // $activity_id = <- the activity from the uploded image.

   update_user_meta($user_id, 'image_'.$activity_id, '1');
}

  • ¿Puedes compartir detalles sobre dónde cargar la imagen en Buddypress?

    – usuario5200704

    12 de mayo de 2016 a las 4:46

  • la carga de imagen normal DOMINIO.COM/miembros/NOMBRE DE USUARIO/medios/foto

    – Pedro

    12 de mayo de 2016 a las 4:55

  • los medios/fotos no proporcionan el valor predeterminado de buddypress, ¿cuál es el complemento externo de buddypress? Si es así, dame el nombre del complemento o el enlace que está usando el complemento.

    – usuario5200704

    12 de mayo de 2016 a las 9:44

avatar de usuario
usuario5200704

Cuando esté utilizando el complemento rtMedia para buddypress y cargue fotos, proporcione una acción rtmedia_después_de_añadir_medios con tres argumentos puedes manejar tu personalización.

add_action( 'rtmedia_after_add_media', 'rtmedia_after_add_media_update_usermeta', 10, 3 );

function rtmedia_after_add_media_update_usermeta( $media_ids, $file_object, $uploaded ){
    // its not provide user id arg so you can get current user id using function get_current_user_id() or $uploaded array have key media_author;
    // $media_ids give all attahment ids when you upload file
    // $file_object give infomation about file like name, path etc
    // $uploaded current upload give settings and update information. Its also gives authore id who is upload media.
    // $user_id = $uploaded['media_author']; 
    $user_id = $uploaded['media_author'];

}

yo anulé bp_core_avatar_handle_upload con la siguiente función. Llama a bp_core_avatar_handle_upload dentro de él, pero evita un bucle infinito al configurar y verificar el valor de una variable global.

global $my_bp_group_avatar_upload;
    function my_bp_group_avatar_upload( $upload, $file, $upload_dir_filter )
    {
    // Global.
    global $my_bp_group_avatar_upload;

    // Check upload filter.
    if ( $upload_dir_filter != ‘groups_avatar_upload_dir’ )
    return;

    // Check if this is the second call.
    if ( $my_bp_group_avatar_upload !== 2 )
    {
    // We are being called for the first time!

    // We are about to call the second time.
    $my_bp_group_avatar_upload = 2;

    // Call the function.
    // We’re calling ourselves too, but this time the global equals 2, so we are now in the else statement.
    if ( bp_core_avatar_handle_upload( $file, $upload_dir_filter ) ) {
    // Do stuff here, the upload was a success.
    }

    // We’ve executed the function. We can bail out of the original function run.
    return FALSE;
    } else {
    // We have been called a second time, so set this to something other than 2.
    $my_bp_group_avatar_upload = 0;

    // We want to continue with the execution.
    return TRUE;
    }
    }
    add_filter( ‘bp_core_pre_avatar_handle_upload’, ‘my_bp_group_avatar_upload’, 10, 3 );

¿Ha sido útil esta solución?

Esta web utiliza cookies propias y de terceros para su correcto funcionamiento y para fines analíticos y para mostrarte publicidad relacionada con sus preferencias en base a un perfil elaborado a partir de tus hábitos de navegación. Al hacer clic en el botón Aceptar, acepta el uso de estas tecnologías y el procesamiento de tus datos para estos propósitos. Configurar y más información
Privacidad