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

🔔 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!

Integration New

Build Beautiful Fundraising Pages Visually with WPBakery Integration

We are excited to announce our brand-new integration with WPBakery, one of the most popular WordPress page builders, designed to help you create stunning layouts for your campaigns without touching a single line of code.

The Ultimate Design Experience

Designing your nonprofit’s website should be as simple as your mission is powerful. Now, you can bring Charitable functionality directly into your WPBakery workflow, using native elements to build high-converting donation pages and campaign grids in seconds.

🖱️ Drag-and-Drop Building: Easily add donation forms, campaign progress bars, and “Donate Now” buttons to your layouts using the WPBakery elements you already know and love.

🎨 Total Creative Control: Customize the look and feel of your fundraising elements using WPBakery’s native design options. Adjust margins, padding, and borders to ensure your campaigns fit perfectly with your site’s branding.

📱 Seamlessly Responsive: Every element is built to be fully responsive and mobile-friendly, ensuring your donors have a smooth, professional experience whether they are giving from a phone, tablet, or desktop.

Integration New

🖼️ Add Image Galleries to Fundraising Campaigns With Envira Gallery

Showcase the impact of your mission like never before. We are excited to announce our brand-new integration with Envira Gallery, the best WordPress gallery plugin, designed to help you tell your story through powerful, high-performance visuals.

The Ultimate Storytelling Experience

A picture is worth a thousand words – and now, it’s worth even more for your fundraising. Connect your visual impact directly to your cause by creating stunning, responsive galleries that engage donors and drive contributions.

🖼️ Visual Impact: Easily create beautiful, fast-loading galleries to show your nonprofit’s work in action, from field reports to event highlights.

🔗 Seamless Connection: Link gallery images directly to your fundraising campaigns, making it effortless for inspired visitors to go from viewing a photo to making a donation.

📱 Perfectly Responsive: Whether your donors are on a phone, tablet, or desktop, your galleries will look professional and load lightning-fast, ensuring a smooth experience on every device.

Integration New

👉🏻 New Divi Integration In Charitable Pro

Bring the power of Charitable directly into your favorite page builder and maintain total creative control with our brand-new Divi integration.

The Ultimate Design Experience

No more switching back and forth or relying on complex shortcodes. Use dedicated Divi modules to build, style, and launch high-converting donation pages without ever leaving the Divi Builder.

⚡ Native Divi Modules: Effortlessly drag and drop your donation forms, progress bars, and campaign details exactly where you want them.

⚙️ Visual Customization: Tweak colors, fonts, and spacing using Divi’s familiar design settings to ensure your fundraiser matches your brand perfectly.

🚀 Live Visual Editing: See your changes in real-time. What you see in the builder is exactly what your donors will see, ensuring a seamless giving experience every time.

donation form New

👉🏻 New Campaign Selector For Donation Forms

Take your campaign management to the next level. Find the perfect fundraiser for any page and stay in your creative flow with our new Campaign Selector integration.

The Ultimate Selection Tool

No more hunting for IDs or creating one page for every donation form. Use the new Campaign Selector to allow users to switch to a campaign with no code.

⚡ Instant Search: Quickly find any campaign leaving your page or post.

⚙️ Editor Agnostic: Whether you’re using the Block Editor, Elementor, or WPBakery, selecting your campaigns is now a unified experience.

🚀 Real-Time Previews: See exactly which campaign you’ve selected instantly, ensuring your donors always see the right cause.

Integration New

WordPress Command Palette Integration

Take your fundraising workflow to the next level. Speed up your site management and stay in your creative flow with our new WordPress Command Palette integration.

Supercharge Your Workflow
Navigate your fundraising dashboard faster than ever.

The Ultimate Keyboard Shortcut Hit Cmd + K (or Ctrl + K) to launch the Command Palette and manage your campaigns instantly.

⚡ Instant Navigation: Jump directly to your Campaigns, Donations, or Settings from anywhere in the editor.

➕ Quick Create: Start a new fundraising campaign or add a manual donation with a single command.

Efficiency Redefined
The tools you need, exactly when you need them.

⚙️ Contextual Actions: See relevant Charitable commands based on whether you’re editing a page or viewing your reports.

🚀 Seamless Integration: Built directly into the WordPress core experience for a lightweight, native feel.