Canadian Tax Receipts extension for CiviCRM
NOTE: If upgrading site that uses existing Drupal CiviCRM CDN Tax Receipts module: https://drupal.org/sandbox/semperit/1289724 - you need to:
- Take note of your CiviCRM CDN Tax Receipt settings [on your Drupal side under: admin/config/civicrm_cdntaxreceipts/settings]
- Backup up both tax log tables: civicrm_cdntaxreceipts_log and civicrm_cdntaxreceipts_log_contributions
- Disable the CiviCRM CDN Tax Receipts module on the admin/modules page
- Remove the tcpdf/ from your /libraries
- For more detail see UPGRADE.txt
- Make sure your CiviCRM Extensions directory is set (Administer > System Settings > Directories).
- Make sure your CiviCRM Extensions Resource URL is set (Administer > System Settings > Resource URLs).
- Unpack the code
- cd extensions directory
- git clone https://github.com/jake-mw/CDNTaxReceipts.git org.civicrm.cdntaxreceipts
- Enable the extension at Administer > System Settings > Manage Extensions
- Configure CDN Tax Receipts at Administer > CiviContribute > CDN Tax Receipts. (Take note of the dimensions for each of the image parameters. Correct sizing is important. You might need to try a few times to get it right.)
- Review permissions: The extension has added a new permission called "CiviCRM CDN Tax Receipts: Issue Tax Receipts".
Now you should be able to use the module.
Note: Compatibility issue with open_basedir
This extension uses the TCPDF library from CiviCRM. If your server has open_basedir set initializing the library causes a warning. To avoid this please add the following to your civicrm.settings.php anywhere after $civicrm_root is defined:
/**
* Early define for tcpdf constants to avoid warnings with open_basedir.
*/
if (!defined('K_PATH_MAIN')) {
define('K_PATH_MAIN', $civicrm_root . '/packages/tcpdf/');
}
if (!defined('K_PATH_IMAGES')) {
define('K_PATH_IMAGES', K_PATH_MAIN . 'images');
}
Individual or Single Tax Receipts
These are receipts issued as one receipt to one contribution.
- To issue an individual receipt, pull up the contact record, go to 'contributions' tab, view the contribution, and click the "Tax Receipt" button. Follow on-screen instructions from there. Single receipts can be issued in bulk for multiple contributions. This process issues one receipt per contribution.
- To issue bulk-issue receipts, go to Contributions > Find Contributions, run a search, select one or more search results, and select "Issue Tax Receipts" in the actions drop-down. Follow on-screen instructions from there.
Annual Tax Receipts
These are receipts that collect all outstanding contributions for the year into one receipt. If some contributions have already been sent a receipt they will not be included in the total. Since there are multiple contributions on one receipt there are some differences in the template. In-kind fields are not shown, contribution type and source are also not shown since the collected contributions over the year could be of multiple types and from multiple sources.
- To issue Annual Tax Receipts, go to Search > Find Contacts (or Search > Advanced Search), run a search for contacts, select one or more contacts, and select "Issue Annual Tax Receipts" in the actions drop-down. Follow on-screen instructions from there.
The extension also enables two report templates, which can be used to see a list of receipts issued and receipts outstanding.
- Tax Receipts - Receipts Issued
- Tax Receipts - Receipts Not Issued
Testing Tax Receipts
- To test your template settings and view a receipt without e-mailing the contact or making a database record, follow the directions for bulk-issueing of receipts: go to Contributions > Find Contributions, run a search, select a search result, and select "Issue Tax Receipts" in the actions drop-down. On the next screen, make sure to select 'Run in preview mode?', and follow on-screen instructions for other options, a pdf will be generated.
Tracking Email openings
- Earlier versions of this Extension required a permission -> "CiviCRM CDN Tax Receipts: Open Tracking". That's no longer required - but make sure that $openTracking parameter is in the message template!
You may be in a situation where certain Contributions are eligible for tax receipts and others are not (e.g. donations are receiptable, but only for individuals, and event fees are not receiptable). If this is the case, there is a PHP hook hook_cdntaxreceipts_eligible($contribution) that can be used for complex eligibility criteria. Hook implementations should return one of TRUE or FALSE, wrapped in an array.
// Example hook implementation:
// Contributions have a custom yes/no field called "receiptable". Issue tax receipt
// on any contribution where receiptable = Yes.
function mymodule_cdntaxreceipts_eligible( $contribution ) {
// load custom field
$query = "
SELECT receiptable_119
FROM civicrm_value_tax_receipt_23
WHERE entity_id = %1";
$params = array(1 => array($contribution->id, 'Integer'));
$field = CRM_Core_DAO::singleValueQuery($query, $params);
if ( $field == 1 ) {
return array(TRUE);
}
else {
return array(FALSE);
}
}
By default, a contribution is eligible for tax receipting if it is completed, and if its Financial Type is deductible.
If you need to customize the amount that is tax-deductible on a receipt, use this hook.
// Example hook implementation:
// Return a maximum tax deduction of $1000.00
function mymodule_cdntaxreceipts_eligibleAmount( $contribution ) {
if ($contribution->total_amount - $contribution->non_deductible_amount > 1000) {
return array(1000.00);
}
else {
return $contribution->total_amount - $contribution->non_deductible_amount;
}
}
This extension has been developed in consultation with a number of non-profits and with the help of a senior accountant. The maintainers have made every reasonable effort to ensure compliance with CRA guidelines and best practices. However, it is the reponsibility of each organization using this extension to do their own due diligence in ensuring compliance with CRA guidelines and with their organizational policies.