Charitable Documentation

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

Geolocation: Map Providers, Location Coverage, and the Ambassadors Location Field

Requires: Charitable Pro 1.8.16+

Geolocation is the layer that turns latitude/longitude on individual campaigns into the maps, distance labels, and “find a campaign near me” search you see on the front end. As of 1.8.16, it supports two map providers — OpenStreetMap (Leaflet) with no API key, and Google Maps with higher-fidelity tiles — and adds a Location Data Coverage card so you can see at a glance how many of your campaigns have geo data.

This is the settings page. To display a map of those campaigns on the front end, see the Campaigns Map block doc.

The Geolocation settings panel under Charitable > Settings > Advanced > Geolocation, with OpenStreetMap (Leaflet) selected and the Location Data Coverage card showing the campaign-mapped breakdown.

What’s new in 1.8.16

Change What it means
OpenStreetMap support You no longer need a Google API key. OpenStreetMap (rendered via Leaflet) is the new default for fresh installs and is free with no account.
Map Provider picker A visual two-card picker — OpenStreetMap (Leaflet) and Google Maps — replaces the previous setup flow.
Location Data Coverage card At-a-glance stat block: how many campaigns have lat/lng set, how many have address-only, how many have no location data. Includes a one-click link to filter the campaigns list down to the campaigns missing location data.
Nominatim address autocomplete Under OpenStreetMap, address autocomplete is powered by the Nominatim service. Type two or more characters into a location field and you’ll get suggestions — no Google account required.
Default Map Center Set the lat/lng + zoom the map falls back to when no campaigns are visible. Default is the geographic center of the contiguous US (39.8283, -98.5795).
Ambassadors Location field When the Ambassadors addon is active, the public campaign-submission form gets an optional Location field with the same autocomplete (Nominatim under OpenStreetMap, Google Places under Google).

Upgrade behavior: Sites that already had a Google Places API key configured at the time of upgrade keep Google Maps as their provider. Fresh installs (and sites that had no key configured) default to OpenStreetMap. You can switch between providers at any time without data loss — campaign lat/lng meta is stored provider-agnostically.

Finding it

WordPress Admin > Charitable > Settings > Advanced > Geolocation

The Advanced tab has sub-tabs at the top of the panel (PDF Receipts, Geolocation, Multi-Currency, Migration Tools, Misc). Geolocation is the second one.

The big picture

Part Purpose
Map Provider Which tile + autocomplete service the map uses. OpenStreetMap is free; Google Maps requires a key.
Location Data Coverage Read-only summary of how many of your campaigns are mappable.
Default Distance Unit Whether distance labels render as 5 miles away or 8 km away.
Default Map Center The lat/lng + zoom the map snaps to when there’s nothing to show.
Per-campaign location Set on each campaign in the Campaign Builder (_campaign_latitude, _campaign_longitude meta).
Ambassadors location field Optional capture of location during public campaign submission.

You configure the provider once on this page. The Campaigns Map block (and the [campaigns map="1"] shortcode) then renders maps using whatever provider you’ve selected.

Map Provider

The headline choice. A two-card picker:

OpenStreetMap (Leaflet)

No setup required, free. Tiles come from OpenStreetMap’s tile servers; the map widget is the open-source Leaflet library. Recommended for most sites — there’s nothing to register, no usage caps to monitor, no key to rotate. Address autocomplete in admin UIs and the Ambassadors form is powered by Nominatim, OpenStreetMap’s free geocoding service.

A note on Nominatim usage: OpenStreetMap asks that high-volume integrations be polite (one request per second per user, results cached when possible). Charitable’s autocomplete debounces input and caches lookups, so a normal-traffic donation site is comfortably under the limit.

Google Maps

Requires a Google account and an API key. Better tile fidelity, includes satellite imagery, and the autocomplete is faster and more forgiving with partial / misspelled addresses. Choose this if you’ve already standardized on Google services or your maps will be the centerpiece of the experience.

Switching to Google reveals the Google Places API Key field and a Setup Help panel with deep-links to Google Cloud:

The Geolocation panel with Google Maps selected, showing the Google Places API Key field, the 5-step Setup Help panel, and the connection indicator.

Setup Help (5 steps)

  1. Create a Google Cloud project. Button opens console.cloud.google.com/projectcreate.
  2. Enable both the Maps JavaScript API and the Places API. Button opens the API Library.
  3. Create an API key. Button opens the Credentials page.
  4. Recommended: restrict the key to your domain (HTTP referrers) and to Maps JavaScript API + Places API. This prevents the key from being abused if it leaks.
  5. Paste the key above and click Save.

Connection indicator

A small status pill next to the Setup Help title reflects the current state of the API key:

State What it means
● Not configured The key field is empty. Geolocation features that need Google won’t work yet.
⋯ Checking… The key was changed; we’re pinging Google to verify. Takes 1–2 seconds.
● Connected The key is valid, the relevant APIs are enabled, and your domain restriction (if any) accepts your site’s hostname.
● Invalid key — check restrictions The key was rejected. Most common cause: HTTP-referrer restriction on the key doesn’t include your site, or the Maps JavaScript API / Places API isn’t enabled on the project. Fix the restriction or enable the API and the indicator will flip to Connected on the next page load.

The Setup Help panel and the API key field are hidden when OpenStreetMap (Leaflet) is selected — you can toggle the provider without reloading the page and they appear/disappear instantly.

Location Data Coverage

A read-only stat card that summarizes how many of your published campaigns are mappable:

The Location Data Coverage card showing the mapped, address-only, and no-location campaign breakdown.
Stat What it shows
Mapped Campaigns with explicit _campaign_latitude and _campaign_longitude meta. These render on the Campaigns Map immediately.
Address Only Campaigns with a street address but no resolved lat/lng. They won’t render on the map until the address is geocoded — typically this happens on the next save of the campaign, or you can trigger it manually.
No Location Campaigns with neither lat/lng nor address. They’ll never appear on the map until you add location data.

Above the stats is a progress bar showing the percentage of total published campaigns that have a usable mapping. Below, a one-click “View all N campaigns missing location” link filters the Campaigns admin list to show only campaigns without location data, so you can batch-fix them.

The card auto-refreshes whenever a campaign is saved, so you’ll see the count tick up as you fill in location data across your campaigns. Stats are cached for one minute to keep the settings page snappy on sites with thousands of campaigns.

Default Distance Unit

A radio: Miles or Kilometers. Used by the Campaigns Map block’s distance labels (5 miles away vs 8 km away) and any sorting by distance in the front-end search. Default: Miles.

This is a display-only setting — the underlying lat/lng calculations don’t change. Sites with audiences in km-using countries should flip this; otherwise leave it alone.

Default Map Center

Two number inputs: Latitude and Longitude. The map snaps here when there’s nothing else to show — for example, when the Campaigns Map block is configured to display only campaigns in a category that currently has zero entries, or before the visitor’s geolocation has resolved.

Default: 39.8283, -98.5795 — the geographic center of the contiguous United States. For a nonprofit with most campaigns in one region or city, set this to that region’s center instead so empty-map renders feel local.

Ambassadors Location field (requires Ambassadors addon)

When the Charitable Ambassadors addon is active and Geolocation is enabled, the public Campaign Submission form gets an optional Location field. New ambassadors can:

  • Type a street address. Autocomplete suggests matches (Nominatim under OpenStreetMap, Google Places under Google) after the first two characters, with a ~300ms debounce.
  • Click a suggestion. The input fills with the full normalized address; hidden lat/lng inputs populate; the preview map next to the field re-centers on the address.
  • Skip the field entirely — it’s optional unless you’ve made it required via filter.

Once the campaign is submitted, the lat/lng saved into _campaign_latitude / _campaign_longitude makes the campaign immediately mappable.

The autocomplete provider follows the global Map Provider setting: switch the site from Google to OpenStreetMap and the Ambassadors form quietly switches autocomplete providers on the next page load.

Tips

  • Start on OpenStreetMap. Skip the Google Cloud account work unless you already have one. For most charity sites the OSM tile quality is fine, and you avoid an ongoing usage bill if you go viral.
  • Coverage card is your TODO list. If Address Only is a high number, those campaigns need their addresses re-saved (or you need to trigger a bulk geocode); if No Location is high, you have data-entry work to do before the map shows much.
  • Restrict your Google key. Leaving a key unrestricted means anyone who grabs it from your page source can run up your bill. Add the HTTP-referrer restriction in step 4 of the setup wizard; it’s quick and meaningfully changes your risk posture.
  • Default Map Center isn’t latitude/longitude trivia. Most visitors won’t notice it day-to-day, but if you ever ship the map embedded somewhere with no campaigns, the world snapping to a sensible region instead of mid-Kansas matters.
  • Switching providers is safe. Switch back and forth as much as you want. Lat/lng meta on campaigns is provider-agnostic; only the tile and autocomplete services change.

Developer reference

Per-campaign meta

Key Type Purpose
_campaign_latitude string (decimal) The latitude saved for this campaign. Set automatically when an address geocodes; can be set manually via Quick Edit or programmatically.
_campaign_longitude string (decimal) The longitude saved for this campaign.
_campaign_address string Optional. The original address string the donor / ambassador typed. Used for re-geocoding when the provider changes.

Filters

Filter Default Purpose
charitable_geolocation_map_provider 'leaflet' or 'google' The active map provider for a given request. Filter to override per page (e.g. force OSM in the Ambassadors flow even if the global setting is Google).
charitable_geolocation_default_distance_unit 'mi' The unit used in distance labels.
charitable_geolocation_default_center [39.8283, -98.5795] Default map center lat/lng.
charitable_geolocation_coverage_stats (array) The Location Data Coverage stats. Filter to inject custom counts (e.g., if you store location data in a non-standard meta key).
charitable_geolocation_nominatim_user_agent Site name + URL The User-Agent string sent to Nominatim. Required by their usage policy; should identify your site. Override only if you understand the policy.
charitable_geolocation_google_api_key The saved key The Google Places API key returned to client-side code. Filter to keep the key in a secret manager instead of the database.

Actions

Action When it fires
charitable_geolocation_provider_changed The site admin saved a new Map Provider. Receives $old_provider, $new_provider. Hook in to clear caches or trigger re-geocoding.
charitable_geolocation_campaign_geocoded A campaign’s address was successfully resolved to lat/lng. Receives $campaign_id, $lat, $lng.
charitable_geolocation_invalidate_coverage_stats_cache Internal hook fired when campaign data changes, to bust the 1-minute coverage card cache.

Bulk geocode helper

If a lot of campaigns are stuck in Address Only state (typically because they were imported), trigger a bulk geocode pass via WP-CLI:

wp charitable geolocation bulk-geocode --batch-size=20

Output shows progress per campaign and a summary of successes / failures at the end. The bulk command respects the provider rate limits and pauses appropriately.

Customization examples

Make Location required on the Ambassadors campaign submission form:

add_filter( 'charitable_ambassadors_submission_form_fields', function( $fields ) {
    if ( isset( $fields['location'] ) ) {
        $fields['location']['required'] = true;
    }
    return $fields;
}, 20 );

Force OpenStreetMap on a specific page (e.g., a public map embed) even if the site default is Google:

add_filter( 'charitable_geolocation_map_provider', function( $provider ) {
    if ( is_page( 'public-campaign-map' ) ) {
        return 'leaflet';
    }
    return $provider;
} );

Pull the Google API key from a secret manager instead of the DB:

add_filter( 'charitable_geolocation_google_api_key', function( $key_from_db ) {
    if ( defined( 'GOOGLE_PLACES_KEY' ) ) {
        return GOOGLE_PLACES_KEY;
    }
    return $key_from_db;
} );

Customize the default map center per region:

add_filter( 'charitable_geolocation_default_center', function( $center ) {
    return array( 'lat' => 51.5074, 'lng' => -0.1278 ); // London.
} );

Identify your site to Nominatim with a more descriptive User-Agent:

add_filter( 'charitable_geolocation_nominatim_user_agent', function( $ua ) {
    return 'YourNonprofit (https://yournonprofit.org) - geocoding for campaign maps';
} );

Related


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.