Skip to content
View as Markdown

Campaign Hooks

FluentCRM Core Intermediate

These action hooks fire during campaign lifecycle events, email sending, and email template design rendering.

Campaign Lifecycle

fluent_crm/campaign_created

This action runs after a campaign has been created.

Parameters

Usage:

php
add_action('fluent_crm/campaign_created', function($campaign) {
   // Do your stuff here
});

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_data_updated

This action runs after a campaign has been updated.

Parameters

Usage:

php
add_action('fluent_crm/campaign_data_updated', function($campaign, $postedData) {
   // Do your stuff here
}, 10, 2);

Source: app/Http/Controllers/CampaignController.php


fluent_crm/update_campaign_compose

This action fires when the campaign compose/body step is saved.

Parameters

Usage:

php
add_action('fluent_crm/update_campaign_compose', function($data, $campaign) {
   // Campaign body/compose step was saved
}, 10, 2);

Source: app/Http/Controllers/CampaignController.php


fluent_crm/update_campaign_subjects

This action fires when the campaign subject step is saved.

Parameters

Usage:

php
add_action('fluent_crm/update_campaign_subjects', function($data, $campaign) {
   // Campaign subject step was saved
}, 10, 2);

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_deleted

This action runs after a campaign has been deleted.

Parameters

  • $campaignId INT - deleted campaign ID

Usage:

php
add_action('fluent_crm/campaign_deleted', function($campaignId) {
   // Do your stuff here
});

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_duplicated

This action runs after a campaign has been duplicated.

Parameters

Usage:

php
add_action('fluent_crm/campaign_duplicated', function($newCampaign, $oldCampaign) {
   // Do your stuff here
}, 10, 2);

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_archived

This action fires when a campaign is archived (either manually or automatically after all emails are sent).

Parameters

Usage:

php
add_action('fluent_crm/campaign_archived', function($campaign) {
   // Campaign was archived
});

Source: app/Http/Controllers/CampaignController.php, app/Hooks/Handlers/Scheduler.php


Campaign Sending

fluent_crm/campaign_recipients_query_updated

This action runs when recipients are being updated.

Parameters

Usage:

php
add_action('fluent_crm/campaign_recipients_query_updated', function($campaign) {
   // Do your stuff here
});

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_scheduled

This action runs when a campaign is being scheduled for later.

Parameters

Usage:

php
add_action('fluent_crm/campaign_scheduled', function($campaign, $scheduleAt) {
   // Do your stuff here
}, 10, 2);

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_set_send_now

This action runs when a campaign is set to send immediately.

Parameters

Usage:

php
add_action('fluent_crm/campaign_set_send_now', function($campaign) {
   // Do your stuff here
});

Source: app/Http/Controllers/CampaignController.php


fluent_crm/campaign_processing_start

This action runs when emails of a campaign start being processed.

Parameters

Usage:

php
add_action('fluent_crm/campaign_processing_start', function($campaign) {
   // Do your stuff here
});

Source: app/Http/Controllers/CampaignController.php


fluent_crm/sending_emails_starting

This action fires at the start of each email sending batch (campaigns, sequences, and automations all use this).

Parameters

  • $campaignEmails Collection - CampaignEmail models being sent in this batch

Usage:

php
add_action('fluent_crm/sending_emails_starting', function($campaignEmails) {
   // A batch of emails is about to be sent
});

Source: app/Services/Libs/Mailer/BaseHandler.php


fluentcrm_sending_emails_done

This action fires after a batch of emails has been sent.

Parameters

  • $campaignEmails Collection - CampaignEmail models that were sent

Usage:

php
add_action('fluentcrm_sending_emails_done', function($campaignEmails) {
   // A batch of emails finished sending
});

Source: app/Services/Libs/Mailer/BaseHandler.php


Newsletter Archive

Pro

These hooks fire when rendering the public newsletter archive pages.

fluent_crm/before_newsletter_archive

Fires before rendering the newsletter archive listing page.

Parameters

  • $newsletters Array - newsletter items
  • $campaigns Collection - campaign models

Usage:

php
add_action('fluent_crm/before_newsletter_archive', function($newsletters, $campaigns) {
    // Add custom content before the archive list
}, 10, 2);

Source: fluentcampaign-pro/app/Views/all_newsletters.php


fluent_crm/after_newsletter_archive

Fires after rendering the newsletter archive listing page.

Parameters

  • $newsletters Array - newsletter items
  • $campaigns Collection - campaign models

Usage:

php
add_action('fluent_crm/after_newsletter_archive', function($newsletters, $campaigns) {
    // Add custom content after the archive list
}, 10, 2);

Source: fluentcampaign-pro/app/Views/all_newsletters.php


fluent_crm/before_newsletter_single

Fires before rendering a single newsletter page.

Parameters

  • $newsletter Array - newsletter data
  • $campaign Campaign Model

Usage:

php
add_action('fluent_crm/before_newsletter_single', function($newsletter, $campaign) {
    // Add custom content before the newsletter
}, 10, 2);

Source: fluentcampaign-pro/app/Views/single_newsletter.php


fluent_crm/after_newsletter_single

Fires after rendering a single newsletter page.

Parameters

  • $newsletter Array - newsletter data
  • $campaign Campaign Model

Usage:

php
add_action('fluent_crm/after_newsletter_single', function($newsletter, $campaign) {
    // Add custom scripts or content after the newsletter
}, 10, 2);

Source: fluentcampaign-pro/app/Views/single_newsletter.php


Email Template Design

fluent_crm/email_header

If you want to add your own custom CSS for a specific email template or all email templates then you can use this hook.

Parameters

  • $designSlug String - Design Name (classic | plain | raw_classic | simple | block_editor)

Usage:

php
/*
* Add Custom CSS for plain design type
*/
add_action('fluent_crm/email_header', function($designName) {
   if($designName == 'plain') {
    ?>
    <style>
      h1 {
        color: red !important;
      }
    </style>
    <?php
   }
});

Source: app/Views/emails/