Skip to content

Commit

Permalink
[REF] Simplify code calculating the number of membership terms
Browse files Browse the repository at this point in the history
We have 2 possibilities
1) there is a price set in use - the number of line items comes from the calculated line items
2) default priceset in use - it is a submitted value

The option to submit is only present in 2 so we know that if it is
submitted it should take precedence, otherwise it comes from the line item

This simplifies the code to do that clearly
  • Loading branch information
eileenmcnaughton committed Mar 14, 2021
1 parent da28128 commit 8534621
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 19 deletions.
21 changes: 21 additions & 0 deletions CRM/Financial/BAO/Order.php
Original file line number Diff line number Diff line change
Expand Up @@ -319,6 +319,27 @@ public function getLineItems():array {
return $this->lineItems;
}

/**
* Get line items that specifically relate to memberships.
*
* return array
*
* @throws \CiviCRM_API3_Exception
*/
public function getMembershipLineItems():array {
$lines = $this->getLineItems();
foreach ($lines as $index => $line) {
if (empty($line['membership_type_id'])) {
unset($lines[$index]);
continue;
}
if (empty($line['membership_num_terms'])) {
$lines[$index]['membership_num_terms'] = 1;
}
}
return $lines;
}

/**
* @return array
* @throws \CiviCRM_API3_Exception
Expand Down
20 changes: 3 additions & 17 deletions CRM/Member/Form/Membership.php
Original file line number Diff line number Diff line change
Expand Up @@ -1055,16 +1055,6 @@ public function submit(): void {

$params['tax_amount'] = $this->order->getTotalTaxAmount();
$params['total_amount'] = $this->order->getTotalAmount();
if (!empty($lineItem[$this->_priceSetId])) {
foreach ($lineItem[$this->_priceSetId] as &$li) {
if (!empty($li['membership_type_id'])) {
if (!empty($li['membership_num_terms'])) {
$termsByType[$li['membership_type_id']] = $li['membership_num_terms'];
}
}
}
}

$params['contact_id'] = $this->_contactID;

$fields = [
Expand All @@ -1090,14 +1080,10 @@ public function submit(): void {
$startDate = $formValues['start_date'];
$endDate = $formValues['end_date'];

$memTypeNumTerms = empty($termsByType) ? CRM_Utils_Array::value('num_terms', $formValues) : NULL;

$calcDates = [];
foreach ($this->_memTypeSelected as $memType) {
if (empty($memTypeNumTerms)) {
$memTypeNumTerms = CRM_Utils_Array::value($memType, $termsByType, 1);
}
$calcDates[$memType] = CRM_Member_BAO_MembershipType::getDatesForMembershipType($memType,
foreach ($this->order->getMembershipLineItems() as $membershipLineItem) {
$memTypeNumTerms = $this->getSubmittedValue('num_terms') ?: $membershipLineItem['membership_num_terms'];
$calcDates[$membershipLineItem['membership_type_id']] = CRM_Member_BAO_MembershipType::getDatesForMembershipType($membershipLineItem['membership_type_id'],
$joinDate, $startDate, $endDate, $memTypeNumTerms
);
}
Expand Down
2 changes: 0 additions & 2 deletions tests/phpunit/CRM/Member/Form/MembershipTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -491,7 +491,6 @@ public function testSubmit(string $thousandSeparator) {
CRM_Core_Session::singleton()->getStatus(TRUE);
$this->setCurrencySeparators($thousandSeparator);
$form = $this->getForm();
$form->preProcess();
$this->mut = new CiviMailUtils($this, TRUE);
$form->_mode = 'test';
$this->createLoggedInUser();
Expand Down Expand Up @@ -591,7 +590,6 @@ public function testSubmit(string $thousandSeparator) {
public function testContributionUpdateOnMembershipTypeChange(): void {
// Step 1: Create a Membership via backoffice whose with 50.00 payment
$form = $this->getForm();
$form->preProcess();
$this->mut = new CiviMailUtils($this, TRUE);
$this->createLoggedInUser();
$priceSet = $this->callAPISuccess('PriceSet', 'Get', ["extends" => "CiviMember"]);
Expand Down

0 comments on commit 8534621

Please sign in to comment.