From f391d61c9256679e9f9e3b9d445888a56ba1c63a Mon Sep 17 00:00:00 2001
From: Muhammad Shahrukh <>
Date: Wed, 13 Nov 2024 13:57:49 +0500
Subject: [PATCH] MMB-501: Add insurance tokens
---
CRM/Certificate/Token/Membership.php | 55 +++++++++++++++++++++++++++-
info.xml | 1 +
2 files changed, 54 insertions(+), 2 deletions(-)
diff --git a/CRM/Certificate/Token/Membership.php b/CRM/Certificate/Token/Membership.php
index 0e97766..cb112bc 100644
--- a/CRM/Certificate/Token/Membership.php
+++ b/CRM/Certificate/Token/Membership.php
@@ -31,6 +31,9 @@ public static function entityTokens() {
'{membership.join_date}' => ts('Member Since'),
'{membership.end_date}' => ts('Membership Expiration Date'),
'{membership.fee}' => ts('Membership Fee'),
+ '{membership.insurance_premium_ex_ipt}' => ts('Insurance Premium (excl IPT)'),
+ '{membership.insurance_premium_ipt_only}' => ts(' Insurance Premium (IPT)'),
+ '{membership.insurance_premium_inc_ipt}' => ts('Insurance Premium (incl IPT)'),
];
$extraTokens = [
'source' => ts('Membership Source'),
@@ -56,6 +59,7 @@ public static function entityTokens() {
public function prefetch(TokenValueEvent $e) {
$entityTypeId = $e->getTokenProcessor()->getContextValues('entityId');
$contactId = $e->getTokenProcessor()->getContextValues('contactId');
+ $certificateId = $e->getTokenProcessor()->getContextValues('certificateId');
$resolvedTokens = [];
@@ -63,7 +67,9 @@ public function prefetch(TokenValueEvent $e) {
if (is_array($entityTypeId)) {
$entityTypeId = $entityTypeId[0];
$contactId = $contactId[0];
- $result = $this->getMembership($entityTypeId, $contactId);
+ $certificateId = $certificateId[0] ?? 0;
+ $certificate = CRM_Certificate_BAO_CompuCertificate::findById($certificateId);
+ $result = $this->getMembership($entityTypeId, $contactId, $certificate);
if (empty($result)) {
return $resolvedTokens;
}
@@ -108,10 +114,11 @@ private function resolveFields($membership, &$resolvedTokens) {
*
* @param int $membershipId
* @param int $contactId
+ * @param object $certificate
*
* @return array
*/
- private function getMembership($membershipId, $contactId) {
+ private function getMembership($membershipId, $contactId, $certificate) {
$result = civicrm_api3('Membership', 'getsingle', [
'id' => $membershipId,
'contact_id' => $contactId,
@@ -126,8 +133,52 @@ private function getMembership($membershipId, $contactId) {
$result['status_idlabel'] = $status['membership_status'] ?? '';
$result['membership_type_idlabel'] = $type['name'] ?? '';
$result['fee'] = CRM_Utils_Money::format($type['minimum_fee'] ?? '');
+ $insuranceTokens = ['insurance_premium_ex_ipt', 'insurance_premium_inc_ipt', 'insurance_premium_ipt_only'];
+
+ if (empty(array_intersect($this->activeTokens, $insuranceTokens))) {
+ return $result;
+ }
+
+ $insuranceLineItem = $this->getValidInsuranceLineItem($certificate, $result);
+
+ $result['insurance_premium_ex_ipt'] = !empty($insuranceLineItem['lineTotal']) ?
+ CRM_Utils_Money::format($insuranceLineItem['lineTotal']) : '';
+ $result['insurance_premium_ipt_only'] = !empty($insuranceLineItem['taxAmount']) ?
+ CRM_Utils_Money::format($insuranceLineItem['taxAmount']) : '';
+ $result['insurance_premium_inc_ipt'] = !empty($insuranceLineItem['taxAmount']) && !empty($insuranceLineItem['lineTotal']) ?
+ CRM_Utils_Money::format((float) $insuranceLineItem['taxAmount'] + (float) $insuranceLineItem['lineTotal']) : '';
return $result;
}
+ private function getValidInsuranceLineItem($certificate, $membership): array {
+ $insuranceFinancialType = (int) Civi::settings()->get('insurance_premium_financial_type');
+ $query = "
+SELECT MAX(c.id) FROM civicrm_contribution c
+ INNER JOIN civicrm_membership_payment mp ON c.id = mp.contribution_id
+ WHERE mp.membership_id =" . $membership['id'] ?? 0;
+
+ if (!empty($certificate->min_valid_from_date)) {
+ $query .= " AND c.receive_date >= '" . $certificate->min_valid_from_date . "'";
+ }
+ if (!empty($certificate->max_valid_through_date)) {
+ $query .= " AND c.receive_date <= '" . $certificate->max_valid_through_date . "'";
+ }
+
+ $contribution = CRM_Core_DAO::singleValueQuery($query);
+
+ if ($contribution === NULL || $insuranceFinancialType === 0) {
+ return [];
+ }
+
+ $lineItem = Civi\Api4\LineItem::get(FALSE)
+ ->addSelect('SUM(tax_amount) AS taxAmount', 'SUM(line_total) AS lineTotal')
+ ->addWhere('contribution_id', '=', $contribution)
+ ->addWhere('financial_type_id', '=', $insuranceFinancialType)
+ ->execute()
+ ->first();
+
+ return $lineItem ?? [];
+ }
+
}
diff --git a/info.xml b/info.xml
index 258f5fe..e6f6cb7 100644
--- a/info.xml
+++ b/info.xml
@@ -28,6 +28,7 @@
uk.co.compucorp.civicase
+ io.compuco.financeextras
ang-php@1.0.0