From 51775f63e68009df55ff3bc436433794755934f2 Mon Sep 17 00:00:00 2001 From: Eileen McNaughton Date: Fri, 17 Nov 2023 11:13:55 +1300 Subject: [PATCH] Fix membership online preview to display subject (using token) --- .../WorkflowMessage/Membership/Membership.php | 62 +++++++++++++++++-- Civi/Test/FormTrait.php | 11 ++++ .../Form/Contribution/ConfirmTest.php | 2 + .../membership_online_receipt_subject.tpl | 2 +- 4 files changed, 70 insertions(+), 7 deletions(-) diff --git a/CRM/Member/WorkflowMessage/Membership/Membership.php b/CRM/Member/WorkflowMessage/Membership/Membership.php index 03d134e289..a66a7a46ec 100644 --- a/CRM/Member/WorkflowMessage/Membership/Membership.php +++ b/CRM/Member/WorkflowMessage/Membership/Membership.php @@ -1,9 +1,11 @@ 1) { + // Generally the online receipt is used with a contribution page so lets' focus + // on those examples for it - unless none exist. It could also be used + // on other contributions via the send receipt method so we do want to show it if + // there are not better examples. + continue; + } yield [ 'name' => 'workflow/' . $workflow . '/' . strtolower($membershipType['name']) . '_' . strtolower($priceSet['name']) . '_' . strtolower($defaultCurrency), - 'title' => $priceSet['title'] . ' - ' . $membershipType['name'] . ' : ' . $defaultCurrency, + 'title' => ($priceSet['contribution_page_id'] ? $this->getContributionPage($priceSet['contribution_page_id'])['title'] : $priceSet['title']) . ' - ' . $membershipType['name'] . ' : ' . $defaultCurrency, 'tags' => ['preview'], 'workflow' => $workflow, 'membership_type' => $membershipType, 'currency' => $defaultCurrency, 'price_set_id' => $priceSet['id'], - 'is_show_line_items' => !$priceSets['is_quick_config'], + 'contribution_page_id' => $priceSet['contribution_page_id'], + 'is_show_line_items' => !$priceSet['is_quick_config'], ]; } } @@ -96,11 +110,17 @@ class CRM_Member_WorkflowMessage_Membership_Membership extends WorkflowMessageEx 'fee_amount' => .99, 'net_amount' => $example['membership_type']['minimum_amount'] - .99, 'currency' => $example['currency'], + 'contribution_page_id' => $example['contribution_page_id'], 'trxn_id' => 123, 'invoice_id' => 'I-123', 'contribution_status_id:name' => 'Completed', 'contribution_status_id' => \CRM_Core_PseudoConstant::getKey('CRM_Contribute_BAO_Contribution', 'contribution_status_id', 'Completed'), ]; + if ($example['contribution_page_id']) { + foreach ($this->getContributionPage($example['contribution_page_id']) as $pageKey => $pageValue) { + $contribution['contribution_page_id.' . $pageKey] = $pageValue; + } + } $contribution['contribution_status_id:label'] = \CRM_Core_PseudoConstant::getLabel('CRM_Contribute_BAO_Contribution', 'contribution_status_id', $contribution['contribution_status_id']); if (isset($example['contribution_params'])) { @@ -145,10 +165,23 @@ class CRM_Member_WorkflowMessage_Membership_Membership extends WorkflowMessageEx * @throws \CRM_Core_Exception */ private function getPriceSet(): ?array { - return (array) PriceSet::get(FALSE) - ->addWhere('extends', '=', CRM_Core_Component::getComponentID('CiviMember')) - ->addOrderBy('is_quick_config', 'DESC') - ->execute()->indexBy('id'); + if (!$this->priceSets) { + $priceSets = (array) PriceSet::get(FALSE) + ->addWhere('extends', '=', CRM_Core_Component::getComponentID('CiviMember')) + ->addOrderBy('is_quick_config', 'DESC') + ->execute()->indexBy('id'); + $priceSetEntities = PriceSetEntity::get(FALSE) + ->addWhere('price_set_id', 'IN', array_keys($priceSets)) + ->addWhere('entity_table', '=', 'civicrm_contribution_page') + ->addOrderBy('entity_id') + ->addSelect('price_set_id', 'entity_id') + ->execute(); + foreach ($priceSetEntities as $priceSetEntity) { + $priceSets[$priceSetEntity['price_set_id']]['contribution_page_id'] = $priceSetEntity['entity_id']; + } + $this->priceSets = $priceSets; + } + return $this->priceSets; } /** @@ -178,4 +211,21 @@ class CRM_Member_WorkflowMessage_Membership_Membership extends WorkflowMessageEx $mockOrder->setLineItem($lineItem, $index); } + /** + * @param int $id + * + * @return array + * + * @throws \CRM_Core_Exception + * @throws \Civi\API\Exception\UnauthorizedException + */ + private function getContributionPage(int $id): array { + if (!isset($this->contributionPages[$id])) { + $this->contributionPages[$id] = ContributionPage::get(FALSE) + ->addWhere('id', '=', $id) + ->execute()->first(); + } + return $this->contributionPages[$id]; + } + } diff --git a/Civi/Test/FormTrait.php b/Civi/Test/FormTrait.php index a194768c15..77beefcc90 100644 --- a/Civi/Test/FormTrait.php +++ b/Civi/Test/FormTrait.php @@ -68,6 +68,17 @@ trait FormTrait { $this->assertStringContainsString($string, $mail['body']); } + /** + * Assert that the sent mail included the supplied string. + * + * @param string $string + * @param int $mailIndex + */ + protected function assertMailSentContainingHeaderString(string $string, int $mailIndex = 0): void { + $mail = $this->form->getMail()[$mailIndex]; + $this->assertStringContainsString($string, $mail['headers']); + } + /** * Assert that the sent mail included the supplied strings. * diff --git a/tests/phpunit/CRM/Contribute/Form/Contribution/ConfirmTest.php b/tests/phpunit/CRM/Contribute/Form/Contribution/ConfirmTest.php index dd6ff5dfae..d87cf98967 100644 --- a/tests/phpunit/CRM/Contribute/Form/Contribution/ConfirmTest.php +++ b/tests/phpunit/CRM/Contribute/Form/Contribution/ConfirmTest.php @@ -230,6 +230,8 @@ class CRM_Contribute_Form_Contribution_ConfirmTest extends CiviUnitTestCase { 'Membership Start Date', '************1111', ], 1); + $this->assertMailSentContainingHeaderString('Test Contribution Page', 0); + $this->assertMailSentContainingHeaderString('Test Contribution Page', 1); } /** diff --git a/xml/templates/message_templates/membership_online_receipt_subject.tpl b/xml/templates/message_templates/membership_online_receipt_subject.tpl index 43eed64b71..7fe701830c 100644 --- a/xml/templates/message_templates/membership_online_receipt_subject.tpl +++ b/xml/templates/message_templates/membership_online_receipt_subject.tpl @@ -1 +1 @@ -{if '{contribution.contribution_status_id:name}' === 'Pending'}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {$title} - {contact.display_name} +{if '{contribution.contribution_status_id:name}' === 'Pending'}{ts}Invoice{/ts}{else}{ts}Receipt{/ts}{/if} - {contribution.contribution_page_id.frontend_title} - {contact.display_name} -- 2.25.1