Charitable Documentation

Learn how to make the most of Charitable with clear, step-by-step instructions.

Charitable Receipt Page Detection

How Automatic Receipt Page Detection Works

(Note: This is for Charitable Pro 1.8.10.5+).

When the “Donation Receipt Page” setting is set to “Automatic” in Charitable settings, the plugin automatically creates and manages receipt pages for your donations. This system works seamlessly with most WordPress themes, including both traditional (classic) themes and modern block themes.

In automatic mode, Charitable uses WordPress rewrite rules to create custom URLs like /donation-receipt/1234/ that display the receipt content without requiring you to create a physical page. The plugin handles all the technical details behind the scenes.

Themes That Work with Automatic Mode

At the time of writing (version 1.8.10.5), the following themes have been tested and work correctly with automatic receipt page detection:

Block Themes (Full Site Editing)

  • Twenty Twenty-Three – WordPress default block theme
  • Twenty Twenty-Four – WordPress default block theme
  • Twenty Twenty-Five – WordPress default block theme

Classic Themes (Traditional PHP Templates)

  • Astra – Popular multipurpose theme
  • GeneratePress – Lightweight theme
  • OceanWP – Multipurpose theme

These themes work because they properly support WordPress’s standard template hierarchy and content filters, allowing Charitable to inject the receipt content at the right time in the page rendering process.

Themes That Require Fallback Page Creation

Some themes have unique rendering systems that prevent automatic receipt page detection from working properly. When Charitable detects this issue, it automatically creates a fallback page to ensure receipts still display correctly.

Twenty Twenty-Two is a block theme that uses a different template rendering approach than later WordPress default themes. When Charitable tries to display a receipt page, the theme’s template system doesn’t properly recognize the custom receipt endpoint, resulting in a blank page.

Why it needs fallback: The theme’s block template system doesn’t correctly handle custom endpoints, causing the receipt content to not render. Charitable detects this and automatically creates a physical WordPress page with the [donation_receipt] shortcode, which the theme can then display properly.

Other documented examples at the time of this writing include YITH Wonder. YITH Wonder is a premium WooCommerce-focused theme with a custom page builder system. Similar to Twenty Twenty-Two, it has rendering quirks that prevent automatic receipt detection from working.

Note: When Charitable creates a fallback page, it automatically updates your settings to use that page. If you switch to a different theme later, Charitable will restore the “Automatic” setting if the new theme works with automatic mode.

Developer Filters

Charitable provides several filters that allow developers to customize the fallback page behavior. All filters are documented below with their default values and use cases.

charitable_receipt_fallback_enabled

Default: true

Purpose: Enable or disable the entire fallback page creation system.

When to use: If you want to completely disable automatic fallback page creation, perhaps because you’re handling receipt pages through a custom solution.

// Disable fallback page creation
add_filter( 'charitable_receipt_fallback_enabled', '__return_false' );

charitable_receipt_fallback_should_activate

Default: true

Parameters:

  • $should_activate (bool) – Whether fallback should activate
  • $current_setting (string) – Current receipt page setting (‘auto’ or page ID)

Purpose: Control whether the fallback system should activate when a blank page is detected. This gives you fine-grained control over when fallback pages are created.

When to use: If you want to prevent fallback creation in specific circumstances, such as during development or for certain user roles.

// Only activate fallback for specific themes
add_filter( 'charitable_receipt_fallback_should_activate', function( $should_activate, $current_setting ) {
    $current_theme = get_stylesheet();
    // Only allow fallback for specific problematic themes
    if ( ! in_array( $current_theme, array( 'twentytwentytwo', 'yith-wonder' ) ) ) {
        return false;
    }
    return $should_activate;
}, 10, 2 );

charitable_receipt_fallback_page_slug

Default: 'donation-receipt-page'

Purpose: Customize the URL slug for the fallback page that gets created.

When to use: If you want the fallback page to have a different URL structure, or if you need to match your site’s URL naming conventions.

// Use a custom slug for the fallback page
add_filter( 'charitable_receipt_fallback_page_slug', function( $slug ) {
    return 'receipt';
} );

charitable_receipt_fallback_page_args

Default:

array(
    'post_title'   => __( 'Donation Receipt', 'charitable-pro' ),
    'post_content' => '[donation_receipt]',
    'post_status'  => 'publish',
    'post_type'    => 'page',
    'post_name'    => $page_slug, // Set automatically
)

Purpose: Customize the properties of the fallback page when it’s created. This includes the page title, content, status, and other WordPress post properties.

When to use: If you want to customize the page title, add custom content before/after the shortcode, set a specific page template, or modify any other page properties.

// Customize the fallback page
add_filter( 'charitable_receipt_fallback_page_args', function( $args ) {
    // Change the page title
    $args['post_title'] = 'Your Donation Receipt';
    
    // Add content before the shortcode
    $args['post_content'] = '<p>Thank you for your donation!</p>' . "\n" . '[donation_receipt]';
    
    // Set a custom page template (if your theme supports it)
    // $args['page_template'] = 'custom-receipt-template.php';
    
    return $args;
} );

charitable_receipt_fallback_delete_on_theme_switch

Default: false

Purpose: Control whether the fallback page should be automatically deleted when switching away from a problematic theme.

When to use: If you want to clean up fallback pages automatically when they’re no longer needed. By default, pages are kept (but settings are restored to “Automatic”) so you can manually review or delete them.

// Automatically delete fallback page on theme switch
add_filter( 'charitable_receipt_fallback_delete_on_theme_switch', '__return_true' );

Debugging

If you need to debug receipt page issues, you can enable detailed logging by adding this to your wp-config.php file:

define( 'CHARITABLE_DEBUG_RECEIPT_PAGE', true );

This will log critical events like fallback activation, page creation failures, and theme switch handling to your WordPress debug log (requires WP_DEBUG_LOG to be enabled).

Summary

The automatic receipt page system works seamlessly with most WordPress themes. When a theme has rendering issues that prevent automatic detection, Charitable automatically creates a fallback page to ensure receipts always display correctly. Developers can customize this behavior using the provided filters, and the system automatically restores settings when switching themes.

Still have questions? We’re here to help!

Last Modified:

What's New In Charitable

View The Latest Updates
🔔 Subscribe to get our latest updates
📧 Subscribe to Emails

Email Subscription

Join our Newsletter

We won’t spam you. We only send an email when we think it will genuinely help you. Unsubscribe at any time!

New Payments

⚡ Unlock India-Based Donations: Meet Charitable’s Native Razorpay Integration

Trying to collect donations in India? Charitable’s native Razorpay integration features:

⚡ Instant UPI Integration: Accept fast, local donations directly inside your form via apps like PhonePe, Google Pay, Paytm, and BHIM without sending donors away from your site.

📲 Auto-Generated Campaign QRs: Instantly render scannable QR codes encoding a UPI deep link directly on your public campaign pages and sidebars for an effortless “scan-to-give” experience.

💰 Dual Local & Global Reach: Headline your campaigns in INR while seamlessly accepting major international currencies like USD, EUR, GBP, and CAD to maximize global support.

🔁 Seamless Recurring Giving: Fully integrates with the Charitable Recurring addon to manage automatic monthly subscriptions directly through Razorpay without extra code.

↩️ Automatic Two-Way Sync: Keep your books perfectly clean with two-way refund syncing—issue a refund inside WordPress or your Razorpay dashboard and both sides update automatically.

🔒 Webhook-Verified Security: Automatically protect your donation records using HMAC-signed webhook verification to ensure every status update represents real money cleared on the rails.

Visit this page to learn more.

Integration New

🎉 New Built-in PushEngage Integration

Struggling with falling email open rates and rising ad costs just to keep your supporters engaged? Charitable’s built-in PushEngage integration features:

🔔 Zero-Fee Direct Messaging: Deliver crisp, instant pop-up notifications straight to your donors’ desktops and mobile devices.

⏱️ Four Smart Automated Triggers: Automatically send updates for immediate donation thank yous, full-list campaign launches, urgent “ending soon” alerts, and goal milestone celebrations.

📈 Group Momentum Broadcasts: Turn private milestones into public wins by automatically broadcasting alerts to your entire subscriber list the moment a campaign hits 50%, 75%, or 100% of its goal.

📊 Automatic Analytics Tracking: Monitor exactly where your incoming notification traffic is coming from with built-in attribution that requires zero complex configuration.

Visit this page to learn more.

New Security

💂‍♂️ 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.

Visit this page to learn more.

GiveWP Migrations New

🧤 White Glove Migration Service for GiveWP

Thinking about switching your fundraising platform from GiveWP to Charitable, but don’t want to risk losing your data or handle a complex technical setup yourself? Charitable’s White Glove Migration Service features:

👥 Flawless Donor Mapping: Safely transfer your entire supporter database with zero data loss.

📊 Complete Financial History: Meticulously preserve every historical transaction for continuous, accurate reporting.

🔄 Seamless Recurring Giving: Safely transfer active sustaining subscriptions without disrupting your incoming revenue or requiring your donors to update their information.

💳 Zero Gateway Disruptions: Keep using Stripe, PayPal, or any other GiveWP-compatible processor you already love.

🚀 Expert Technical Setup: Relax while our team handles the heavy lifting to install and configure your forms—plus, qualifying users get a full year of Charitable Pro completely free.

Visit this page to learn more.

automation Improvement

📢 New Feature Alert: Automation Connect 2.0 Is Here! 🚀

Thinking about connecting your fundraising data to tools like Mailchimp, Slack, or Google Sheets, but don’t want to hire a developer or write custom code? Charitalbe’s new automation addon has:

⚡ 17 Event Triggers: Instantly fire webhooks for a donor’s first gift, renewal payments, or reached campaign milestones.

🎯 Smart Conditional Logic: Use powerful AND/OR logic across 11 fields to only send data when it meets your exact criteria, like newsletter opt-ins.

📊 Custom Payload Control: Select from 80+ clean data fields across donor, donation, and campaign metadata so your apps get exactly what they need.

🚀 Pre-Built Platform Templates: Skip the setup from scratch with ready-to-go templates for Zapier, Make.com, n8n, HubSpot, and Slack.

🛡️ Reliable Developer Tools: Power your workflows with signed HMAC-SHA256 payloads, complete WordPress filters, and automatic retry logs.