From 28da8ecd4a4f6455e492f4e1ebf434bc9891c574 Mon Sep 17 00:00:00 2001 From: Web Access Date: Thu, 31 Mar 2016 18:48:50 +0530 Subject: [PATCH] CRM-18282: Custom Field values from Profile in Contribution Page not saved in new Membership --- CRM/Contribute/Form/Contribution/Confirm.php | 24 ++++++++------------ 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/CRM/Contribute/Form/Contribution/Confirm.php b/CRM/Contribute/Form/Contribution/Confirm.php index 7024d9645c..d586bd0397 100644 --- a/CRM/Contribute/Form/Contribution/Confirm.php +++ b/CRM/Contribute/Form/Contribution/Confirm.php @@ -1404,7 +1404,7 @@ class CRM_Contribute_Form_Contribution_Confirm extends CRM_Contribute_Form_Contr $isProcessSeparateMembershipTransaction, $financialTypeID, $membershipLineItems, $isPayLater, $isPending) { $membershipContribution = NULL; $isTest = CRM_Utils_Array::value('is_test', $membershipParams, FALSE); - $errors = $createdMemberships = $paymentResults = array(); + $errors = $paymentResults = array(); $form->_values['isMembership'] = TRUE; $isRecurForFirstTransaction = CRM_Utils_Array::value('is_recur', $form->_values, CRM_Utils_Array::value('is_recur', $membershipParams)); $totalAmount = $membershipParams['amount']; @@ -1516,9 +1516,9 @@ class CRM_Contribute_Form_Contribution_Confirm extends CRM_Contribute_Form_Contr if ($form->_priceSetId && !empty($form->_useForMember) && !empty($form->_lineItem)) { foreach ($form->_lineItem[$form->_priceSetId] as & $priceFieldOp) { if (!empty($priceFieldOp['membership_type_id']) && - isset($createdMemberships[$priceFieldOp['membership_type_id']]) + isset($membership[$priceFieldOp['membership_type_id']]) ) { - $membershipOb = $createdMemberships[$priceFieldOp['membership_type_id']]; + $membershipOb = $membership[$priceFieldOp['membership_type_id']]; $priceFieldOp['start_date'] = $membershipOb->start_date ? CRM_Utils_Date::customFormat($membershipOb->start_date, '%B %E%f, %Y') : '-'; $priceFieldOp['end_date'] = $membershipOb->end_date ? CRM_Utils_Date::customFormat($membershipOb->end_date, '%B %E%f, %Y') : '-'; } @@ -1539,23 +1539,17 @@ class CRM_Contribute_Form_Contribution_Confirm extends CRM_Contribute_Form_Contr // CRM-7851 - Moved after processing Payment Errors //@todo - the reasoning for this being here seems a little outdated - foreach ($createdMemberships as $createdMembership) { - CRM_Core_BAO_CustomValueTable::postProcess( - $form->_params, - 'civicrm_membership', - $createdMembership->id, - 'Membership' - ); - $form->_params['createdMembershipIDs'][] = $createdMembership->id; - } - if (count($createdMemberships) == 1) { + CRM_Core_BAO_CustomValueTable::postProcess($form->_params, 'civicrm_membership', $membership->id, 'Membership'); + $form->_params['createdMembershipIDs'][] = $membership->id; + + if (count($membership) == 1) { //presumably this is only relevant for exactly 1 membership - $form->_params['membershipID'] = $createdMembership->id; + $form->_params['membershipID'] = $membership->id; } //CRM-15232: Check if membership is created and on the basis of it use //membership receipt template to send payment receipt - if (count($createdMemberships)) { + if (count($membership)) { $form->_values['isMembership'] = TRUE; } if (isset($membershipContributionID)) { -- 2.25.1