From: Eileen McNaughton Date: Fri, 3 Nov 2023 01:42:33 +0000 (+1300) Subject: Follow up cleanup on multiple participant form edit X-Git-Url: https://vcs.fsf.org/?a=commitdiff_plain;h=cf131c8685497eb8c99985b56d569f67d618c53d;p=civicrm-core.git Follow up cleanup on multiple participant form edit In testing on the recent regression some code turned out to be unreachable. In the scenario were we have a pending pay later registration for multipl participants we find that the field priceSetId is empty when submitted and the field total_amount must be submitted, if it is submitted. Therefore we find that a) any value added to total_amount in the previously-shared preparePaidEventProcessing is overwritten shortly after by the submitted value and hence should not be set in this flow in preparePaidEventProcessing. Also the code that sets additionalDetails is only hit when priceSetID is not empty but it never is per above. So that code is setting an unused variable --- diff --git a/CRM/Event/Form/Participant.php b/CRM/Event/Form/Participant.php index b33f7acb45..660942eace 100644 --- a/CRM/Event/Form/Participant.php +++ b/CRM/Event/Form/Participant.php @@ -1492,22 +1492,12 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment 'revenue_recognition_date' => $this->getRevenueRecognitionDate(), ]; $lineItem = []; - $additionalParticipantDetails = []; if ($this->isPaymentOnExistingContribution()) { - $contributionParams['total_amount'] = $this->getParticipantValue('fee_amount'); - $params['discount_id'] = NULL; //re-enter the values for UPDATE mode $params['fee_level'] = $params['amount_level'] = $this->getParticipantValue('fee_level'); $params['fee_amount'] = $this->getParticipantValue('fee_amount'); - - //also add additional participant's fee level/priceset - if (CRM_Event_BAO_Participant::isPrimaryParticipant($this->_id)) { - $additionalIds = CRM_Event_BAO_Participant::getAdditionalParticipantIds($this->_id); - $hasLineItems = $params['priceSetId'] ?? FALSE; - $additionalParticipantDetails = $this->getFeeDetails($additionalIds, $hasLineItems); - } } else { @@ -1528,7 +1518,7 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment //when financial_type_id is passed in form, update the //lineitems with the financial type selected in form $submittedFinancialType = $params['financial_type_id'] ?? NULL; - $isPaymentRecorded = $params['record_contribution'] ?? NULL; + $isPaymentRecorded = $this->getSubmittedValue('record_contribution'); if ($isPaymentRecorded && $this->isQuickConfig() && $submittedFinancialType) { foreach ($lineItem[0] as &$values) { $values['financial_type_id'] = $submittedFinancialType; @@ -1551,9 +1541,7 @@ class CRM_Event_Form_Participant extends CRM_Contribute_Form_AbstractEditPayment if (isset($params['priceSetId'])) { if (!empty($lineItem[0])) { $this->set('lineItem', $lineItem); - $this->_lineItem = $lineItem; - $lineItem = array_merge($lineItem, $additionalParticipantDetails); } }