Blog benéfico

Todo lo que necesitas saber sobre Charitable y nuestro equipo.

AWARE: Banner de la campaña 30 for 30

Un vistazo a la peculiar recaudación de fondos "30 for 30" de AWARE Whistler (Tutorial)

Última actualización el

  • Por

AWARE Whistler es una organización benéfica comprometida con la protección del medio ambiente natural de Whistler, Canadá. Este año marca su 30 aniversario como organización y celebra la ocasión lanzando la recaudación de fondos 30 for 30.

El objetivo de la recaudación de fondos "30 for 30" es recaudar 60.000 $, de los cuales 30.000 $ provendrán de empresas y 30.000 $ de donaciones individuales.

AWARE está utilizando el enfoque de recaudación de fondos basado en campañas de Charitable para impulsar esta campaña, con dos campañas de recaudación de fondos individuales configuradas: una para empresas y otra para individuos.

El desafío

Por supuesto, las campañas únicas como esta tienden a tener necesidades únicas, y la recaudación de fondos "30 for 30" no es una excepción.

Dado que una de las dos campañas de recaudación de fondos se centra específicamente en obtener donaciones de empresas, se necesita un campo "Nombre de la empresa" en el formulario de donación de esa campaña. Además, cuando se muestran los donantes en el sitio (usando el shortcode o widget de Donantes), debe mostrarse el nombre de la empresa, no el nombre de la persona que dona.

Afortunadamente, la flexibilidad de Charitable se adapta perfectamente a las necesidades de AWARE. Veamos cómo.

Paso 1. Añadir un campo "Nombre de la empresa"

Lo primero que necesitamos hacer es crear un nuevo campo de donación, utilizando la API de Campos de Donación.

Veamos el código necesario para lograrlo:

/**
 * STEP 1: Register the "Company Name" Donation Field.
 *
 * On the `init` hook, we create a new Donation Field. It has a
 * key of `company_name` (this is how we will reference it later),
 * and it's set up as a required field in the donation form, shown
 * after the `last_name` field.
 */
add_action( 'init', function() {
        /**
         * Add a "Company Name" field.
         */
        $field = new Charitable_Donation_Field(
            'company_name',
            [
                'label' => 'Company Name',
                'data_type' => 'user',
                'donation_form' => [
                    'show_after' => 'last_name',
                    'required' => true,
                ],
                'admin_form' => true,
                'show_in_meta' => true,
                'show_in_export' => true,
                'email_tag' => [
                    'description' => 'The company name',
                ],
            ]
        );

        /**
         * Register the field.
         */
        charitable()->donation_fields()->register_field( $field );
}, 100 );

Aquí hay un poco de código. En primer lugar, justo en la parte superior, estamos configurando una función para que se ejecute en el hook init. Este es el mejor hook para usar cada vez que desee registrar un nuevo campo de donación.

Dentro de nuestra función, creamos un nuevo Campo de Donación con el objeto Charitable_Donation_Field. Echemos un vistazo más de cerca a esa parte:

$field = new Charitable_Donation_Field(
     'company_name',
     [
         'label' => 'Company Name',
         'data_type' => 'user',
         'donation_form' => [
             'show_after' => 'last_name',
             'required' => true,
         ],
         'admin_form' => true,
         'show_in_meta' => true,
         'show_in_export' => true,
         'email_tag' => [
             'description' => 'The company name',
         ],
     ]
 );

Lo que estamos haciendo aquí es crear un campo con una clave company_name (la necesitaremos más adelante). Hemos establecido una etiqueta, la hemos definido como un campo de usuario y hemos establecido algunas reglas básicas sobre cómo debe aparecer en el formulario de donación: justo después del campo last_name y como campo obligatorio.

También lo hemos configurado para que se muestre en el formulario de donación del administrador, en los metadatos de la donación y en el archivo de exportación de donaciones. Incluso le hemos dicho a Charitable que cree una etiqueta de correo electrónico para él, para que podamos usarla en nuestros correos electrónicos de recibo de donaciones.

Finalmente, registramos este campo con la API de Campos de Donación:

charitable()->donation_fields()->register_field( $field );

Paso 2. Mostrar el campo "Nombre de la empresa" solo en una campaña

Por defecto, cuando configuras un campo de donación, aparecerá en el formulario de donación de todas las campañas. Sin embargo, para la campaña "30 for 30", AWARE solo quiere que el campo aparezca en el formulario de donación de la recaudación de fondos para empresas.

Así es como lo logramos:

/**
 * STEP 2: Only show the field on a specific campaign.
 *
 * We only want the field to show up on a single campaign's
 * form, so we *remove* it from all other campaigns' donation
 * forms.
 */
add_filter( 'charitable_donation_form_user_fields', function( $fields, Charitable_Donation_Form $form ) {
    /**
     * Check the campaign ID of the donation form being
     * shown. If it isn't the one where we want the field,
     * remove the field using the unset() function.
     */
    if ( 123 != $form->get_campaign()->ID ) {
        unset( $fields['company_name'] );
    }

    return $fields;
}, 10, 2 );

La forma en que resolvemos este problema es eliminando el campo company_name cuando no estamos mostrando el formulario de donación de la campaña empresarial. Toda la magia ocurre aquí:

if ( 123 != $form->get_campaign()->ID ) {
     unset( $fields['company_name'] );
 }

En este caso, imaginamos que la campaña de Negocios tiene un ID de 123. Así que, cuando miramos los campos de un formulario en particular, comprobamos el ID de la campaña del formulario y, si no es 123, usamos la función unset() para deshacernos de nuestro campo, refiriéndonos a él por la clave de company_name, que establecimos en el Paso 1.

Paso 3. Personaliza el nombre del donante en el shortcode o widget de Donantes

Ahora que hemos añadido nuestro campo de Nombre de Empresa, todo lo que queda es usar eso en lugar del nombre y apellido del donante al mostrar donaciones a la campaña de Negocios.

Veamos el código:

/**
 * STEP 3: Use the company name for the donor name.
 *
 * When showing the donor name for a particular donation,
 * check if the donation was to the campaign with our
 * Company Name field. If it was, show the Company Name
 * instead of the individual's name.
 */
add_filter( 'charitable_donor_loop_donor_name', function( $name, $args ) {
    /**
     * Get the Donor object from the argument array.
     */
    $donor = $args['donor'];

    /**
     * Check if there is a Donation object associated
     * with this Donor.
     */
    $donation = $donor->get_donation();

    if ( ! $donation ) {
        return $name;
    }

    /**
     * Get the campaign that received the donation.
     */
    $campaign_id = current( $donation->get_campaign_donations() )->campaign_id;

    /**
     * If this was a donation to our campaign,
     * let's change the donor name.
     */
    if ( 123 == $campaign_id ) {
        $name = $donation->get( 'company_name' );
    }

    return $name;
}, 15, 2 );

En primer lugar, observa que esto está configurado como una función llamada en el hook charitable_donor_loop_donor_name. Usamos este hook ya que se muestra siempre que se muestra una lista de donantes con el widget de Donantes o el shortcode.

Dentro de la función, primero obtenemos el objeto Charitable_Donor del parámetro $args. Luego obtenemos el objeto Charitable_Donation a través del método $donor->get_donation():

/**
 * Check if there is a Donation object associated
 * with this Donor.
 */
$donation = $donor->get_donation();

if ( ! $donation ) {
    return $name;
}

Puede que te preguntes por qué comprobamos si $donation está establecido. La razón es que a veces, Charitable_Donor no está configurado con una donación específica. Un ejemplo es cuando el widget/shortcode de Donantes está configurado para agrupar múltiples donaciones del mismo donante en una; en ese caso, no se llama a ningún objeto Charitable_Donation, y simplemente mostraremos el nombre del donante.

Por lo tanto, una advertencia importante de este enfoque es que solo funcionará si el widget/shortcode de Donantes está configurado para mostrar cada donación individualmente, en lugar de agrupar múltiples donaciones de la misma persona.

A continuación, usamos el objeto Charitable_Donation para averiguar a qué campaña se donó y comprobamos si es nuestra campaña de Negocios (la que tiene un ID de 123):

/**
 * Get the campaign that received the donation.
 */
$campaign_id = current( $donation->get_campaign_donations() )->campaign_id;

/**
 * If this was a donation to our campaign,
 * let's change the donor name.
 */
if ( 123 == $campaign_id ) {
    $name = $donation->get( 'company_name' );
}

La última parte de esto simplemente comprueba que $campaign_id es 123. Si lo es, obtenemos el nombre de la empresa de la siguiente manera:

$donation->get( 'company_name' );

Ten en cuenta que company_name coincide con la clave del campo de donación que registramos en el paso 1.

¡Y con eso, hemos terminado!

La solución completa

Puedes ver todo el código reunido en un solo lugar en nuestra biblioteca de código de Github:

https://github.com/Charitable/library/blob/master/tutorials/new-donation-field-plus-customized-donor-name.php

Para verlo en acción – y si te gustaría mostrar tu apoyo al importante trabajo realizado por AWARE Whistler – visita la página 30 for 30 Fundraiser en su sitio web.

Palabra final

Si disfrutaste de este tutorial y te gustaría que escribiéramos uno sobre un tema diferente, ¡háznoslo saber! Puedes contactarnos por correo electrónico rellenando el formulario en nuestra página de Soporte, o dejando un comentario abajo.

Divulgación: Nuestro contenido es compatible con los lectores. Esto significa que si haces clic en algunos de nuestros enlaces, podemos ganar una comisión. Solo recomendamos productos que creemos que aportarán valor a nuestros lectores.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

Recibe consejos y recursos gratuitos directamente en tu bandeja de entrada, junto con más de 60.000 personas.

Únete a nuestro boletín

No te enviaremos spam. Solo enviamos un correo electrónico cuando creemos que realmente te ayudará. ¡Date de baja en cualquier momento!

Vídeo destacado:

Mira más vídeos en nuestro canal de YouTube.

Novedades en Benéfico

Ver las últimas actualizaciones
🔔 Suscríbete para recibir nuestras últimas actualizaciones
📧 Suscribirse a correos electrónicos

Suscripción por correo electrónico

Únete a nuestro boletín

No te enviaremos spam. Solo enviamos un correo electrónico cuando creemos que realmente te ayudará. ¡Date de baja en cualquier momento!

💂‍♂️ New DonationGuard 🛡️ Automatically Protects Your Donations!

Worried about card testing attacks or spam bots flooding your donation forms, but don’t want to ruin the giving experience for your real supporters? Charitable’s DonationGuard features:

🛡️ Real-Time Bot Detection: Actively monitors every donation submission for five distinct attack signals without slowing down your human donors.

📊 Smart Traffic Scoring: Instantly evaluates activity against a learned baseline of your site’s normal donation rhythms to catch sneaky, slow-drip card testing.

🚨 Severity-Tiered Alerts: Immediately opens structured “Attack Records” and notifies you via email and admin alerts the moment a campaign starts taking fire.

🎯 Single-Click Defense: Deploy instant security using the “Recommended Settings” preset to turn on Honeypot, Time Trap, and Rate Limit modules all at once.

🚫 Automated Blocklists: Permanently stop repeat offenders by automatically blocking suspicious email addresses based on your customized rules.

Visita esta página para obtener más información.

GiveWP Migraciones Nuevo

🧤 White Glove Migration Service for GiveWP

¿Estás pensando en cambiar tu plataforma de recaudación de fondos de GiveWP a Charitable, pero no quieres arriesgarte a perder tus datos ni a encargarte tú mismo de una configuración técnica compleja? El Servicio de Migración "White Glove" de Charitable incluye:

👥 Mapeo impecable de donantes: Transfiere de forma segura toda tu base de datos de colaboradores sin pérdida de datos.

📊 Historial financiero completo: Conserva meticulosamente cada transacción histórica para una presentación de informes continua y precisa.

🔄 Donaciones recurrentes sin interrupciones: Transfiere de forma segura las suscripciones activas sin interrumpir tus ingresos ni requerir que tus donantes actualicen su información.

💳 Cero interrupciones en la pasarela de pago: Sigue usando Stripe, PayPal o cualquier otro procesador compatible con GiveWP que ya te guste.

🚀 Configuración técnica experta: Relájate mientras nuestro equipo se encarga de la instalación y configuración de tus formularios. Además, los usuarios que cumplan los requisitos obtendrán un año completo de Charitable Pro gratis.

Visita esta página para obtener más información.

automatización Mejora

📢 Alerta de nueva función: ¡Automation Connect 2.0 ya está aquí! 🚀

¿Estás pensando en conectar tus datos de recaudación de fondos con herramientas como Mailchimp, Slack o Google Sheets, pero no quieres contratar a un desarrollador ni escribir código personalizado? El nuevo complemento de automatización de Charitable incluye:

⚡ 17 disparadores de eventos: Activa instantáneamente webhooks para el primer donativo de un donante, pagos de renovación o hitos de campaña alcanzados.

🎯 Lógica condicional inteligente: Utiliza una potente lógica AND/OR en 11 campos para enviar datos solo cuando cumplan tus criterios exactos, como las suscripciones al boletín.

📊 Control de carga útil personalizado: Selecciona entre más de 80 campos de datos limpios de metadatos de donantes, donaciones y campañas para que tus aplicaciones obtengan exactamente lo que necesitan.

🚀 Plantillas de plataforma preconstruidas: Evita la configuración desde cero con plantillas listas para usar para Zapier, Make.com, n8n, HubSpot y Slack.

🛡️ Herramientas de desarrollador fiables: Potencia tus flujos de trabajo con cargas útiles firmadas HMAC-SHA256, filtros completos de WordPress y registros de reintentos automáticos.

automatización Mejora

🔌 Charitable se une a Zapier: Conecta con más de 7000 aplicaciones y automatiza tu recaudación de fondos

¿Cansado de copiar manualmente los datos de las donaciones en hojas de contabilidad o de rastrear las nuevas suscripciones de donantes? Pon tus tareas administrativas en piloto automático. Charitable ya está oficialmente en Zapier, lo que te proporciona una forma potente y sin código para conectar tu recaudación de fondos directamente con el resto de tus herramientas favoritas.

Cada donación, suscripción de donante e hito de campaña ahora puede activar un flujo de trabajo automatizado sin problemas.

Novedades:

♾️ Conecta con más de 7000 aplicaciones: Une tus campañas de Charitable con software cotidiano como Google Sheets, QuickBooks, Slack, Mailchimp, HubSpot, Notion, Airtable y miles más.

⚡ 12 potentes disparadores: Crea flujos de trabajo profundos utilizando disparadores de automatización inteligentes que cubren todo el ciclo de vida de la donación, incluyendo Nueva Donación, Nuevo Donante, Suscripción Cancelada y Objetivo de Campaña Alcanzado.

📋 Plantillas de acciones preconstruidas: Empieza en tres minutos o menos con nuestras combinaciones de plantillas prefabricadas, como registrar automáticamente nuevas donaciones directamente en una Hoja de Cálculo de Google o enviar correos electrónicos personalizados de bienvenida a donantes a través de Gmail.

🚫 No se necesita código: No se requieren webhooks complejos ni scripts PHP personalizados. Simplemente elige tu disparador, selecciona tu aplicación, mapea tus campos y deja que Zapier se encargue del trabajo pesado.

¿Listo para ahorrar horas de tiempo administrativo? ¡Consigue Charitable Pro con el complemento Automation Connect hoy mismo y lanza tu primer Zap!

Mejora Pagos

🚀 Presentamos PayPal Commerce: Una conexión, seis formas de donar

Los donantes esperan opciones de pago modernas y flexibles cuando apoyan una causa. Si no ven su método preferido en su formulario de donación, a menudo desaparecen sin decir nada. Con PayPal Commerce, estamos brindando una experiencia de pago completamente modernizada directamente a sus campañas.

Disfrute de una única integración que mejora sus formularios, hace que las donaciones sean fluidas y le ayuda a capturar cada donación.

Novedades:

🔌 Conexión con un clic: omita las complicadas claves API y los documentos para desarrolladores. Simplemente haga clic en "Conectar con PayPal", inicie sesión en su cuenta comercial y su formulario moderno estará activo en menos de cinco minutos.

💳 Seis formas de donar: brinde a sus seguidores acceso instantáneo al saldo de PayPal, Venmo (EE. UU.), financiación "Paga más tarde", las principales tarjetas de crédito/débito, Apple Pay (Safari) y Google Pay (Chrome), todo desde el mismo formulario.

🔄 Donaciones recurrentes flexibles: admite completamente las donaciones mensuales. Elija entre la API de suscripciones de PayPal (gestionada automáticamente por PayPal) o Vault + Cron (gestionada de forma segura en su sitio).

💬 Recuperación de errores amigable: no más alertas confusas del navegador. Si se rechaza un pago, los donantes ven mensajes sencillos y en línea que los guían sobre cómo solucionar el problema y completar su donación.

¿Listo para PayPal, modernizado? Actualice a Charitable Pro 1.8.15+ (o Charitable Lite 1.8.11+) y conecte su cuenta hoy mismo.